* @author Timo Hund */ class DateRangeFacet extends AbstractFacet { const TYPE_DATE_RANGE = 'dateRange'; /** * String * @var string */ protected static $type = self::TYPE_DATE_RANGE; /** * @var DateRange */ protected $range; /** * OptionsFacet constructor * * @param SearchResultSet $resultSet * @param string $name * @param string $field * @param string $label * @param array $configuration Facet configuration passed from typoscript */ public function __construct(SearchResultSet $resultSet, $name, $field, $label = '', array $configuration = []) { parent::__construct($resultSet, $name, $field, $label, $configuration); } /** * @param DateRange $range */ public function setRange(DateRange $range) { $this->range = $range; } /** * @return DateRange */ public function getRange() { return $this->range; } /** * Get facet partial name used for rendering the facet * * @return string */ public function getPartialName() { return !empty($this->configuration['partialName']) ? $this->configuration['partialName'] : 'RangeDate.html'; } /** * Since the DateRange contains only one or two items when return a collection with the range only to * allow to render the date range as other facet items. * * @return AbstractFacetItemCollection */ public function getAllFacetItems() { return new DateRangeCollection([$this->range]); } }