persian_date-8.x-4.1/src/Plugin/views/filter/Date.php

src/Plugin/views/filter/Date.php
<?php

namespace Drupal\persian_date\Plugin\views\filter;

use Drupal\Core\Form\FormStateInterface;
use Drupal\persian_date\Library\Jalali\jDateTime;
use Drupal\persian_date\Service\Translation\OffsetFilterTranslator;

/**
 * Filter to handle dates stored as a timestamp.
 *
 * @ingroup views_filter_handlers
 *
 * @ViewsFilter("date")
 */
class Date extends \Drupal\views\Plugin\views\filter\Date
{

  /**
   * @inheritDoc
   */
  protected function valueForm(&$form, FormStateInterface $form_state) {
    parent::valueForm($form, $form_state);
    if (isset($form['value'])) {
      $form['value']['#attributes']['autocomplete'] = 'off';
    }
  }

  protected function opSimple($field)
    {
        // if type is offset translate value and delegate handling to parent class
        if (!empty($this->value['type']) && $this->value['type'] == 'offset') {
            $this->value['value'] = OffsetFilterTranslator::translate($this->value['value']);
            parent::opSimple($field);
            return;
        }

      $min = $value = (jDateTime::createCarbonFromFormat('Y-m-d H:i:s', $this->value['value'] . ' 00:00:00'));
      $max = $value = (jDateTime::createCarbonFromFormat('Y-m-d H:i:s', $this->value['value'] . ' 23:59:59'));
      $a = intval($min->getTimestamp());
      $b = intval($max->getTimestamp());

      // This is safe because we are manually scrubbing the values.
      // It is necessary to do it this way because $a and $b are formulas when using an offset.
      $this->query->addWhereExpression($this->options['group'], "$field BETWEEN $a AND $b");
    }

    protected function opBetween($field)
    {
        // if type is offset translate value and delegate handling to parent class
        if ($this->value['type'] == 'offset') {
            $this->value['min'] = OffsetFilterTranslator::translate($this->value['min']);
            $this->value['max'] = OffsetFilterTranslator::translate($this->value['max']);
            parent::opBetween($field);
            return;
        }

        $min = $value = (jDateTime::createCarbonFromFormat('Y-m-d H:i:s', $this->value['min'] . ' 00:00:00'));
        $max = $value = (jDateTime::createCarbonFromFormat('Y-m-d H:i:s', $this->value['max'] . ' 23:59:59'));
        $a = intval($min->getTimestamp());
        $b = intval($max->getTimestamp());

        // This is safe because we are manually scrubbing the values.
        // It is necessary to do it this way because $a and $b are formulas when using an offset.
        $operator = strtoupper($this->operator);
        $this->query->addWhereExpression($this->options['group'], "$field $operator $a AND $b");
    }
}

Главная | Обратная связь

drupal hosting | друпал хостинг | it patrol .inc