summaryrefslogtreecommitdiff
path: root/app/Filter/BaseFilter.php
blob: a7e6a61a8664a8dd0fcddf918790a606be9bfdde (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
<?php

namespace Kanboard\Filter;

use PicoDb\Table;

/**
 * Base filter class
 *
 * @package filter
 * @author  Frederic Guillot
 */
abstract class BaseFilter
{
    /**
     * @var Table
     */
    protected $query;

    /**
     * @var mixed
     */
    protected $value;

    /**
     * BaseFilter constructor
     *
     * @access public
     * @param  mixed $value
     */
    public function __construct($value = null)
    {
        $this->value = $value;
    }

    /**
     * Get object instance
     *
     * @static
     * @access public
     * @param  mixed $value
     * @return static
     */
    public static function getInstance($value = null)
    {
        $self = new static($value);
        return $self;
    }

    /**
     * Set query
     *
     * @access public
     * @param  Table $query
     * @return \Kanboard\Core\Filter\FilterInterface
     */
    public function withQuery(Table $query)
    {
        $this->query = $query;
        return $this;
    }

    /**
     * Set the value
     *
     * @access public
     * @param  string $value
     * @return \Kanboard\Core\Filter\FilterInterface
     */
    public function withValue($value)
    {
        $this->value = $value;
        return $this;
    }

    /**
     * Parse operator in the input string
     *
     * @access protected
     * @return string
     */
    protected function parseOperator()
    {
        $operators = array(
            '<=' => 'lte',
            '>=' => 'gte',
            '<' => 'lt',
            '>' => 'gt',
        );

        foreach ($operators as $operator => $method) {
            if (strpos($this->value, $operator) === 0) {
                $this->value = substr($this->value, strlen($operator));
                return $method;
            }
        }

        return '';
    }

    /**
     * Apply a date filter
     *
     * @access protected
     * @param  string $field
     */
    protected function applyDateFilter($field)
    {
        $timestamp = strtotime($this->value);
        $method = $this->parseOperator();

        if ($method !== '') {
            $this->query->$method($field, $timestamp);
        } else {
            $this->query->gte($field, $timestamp);
            $this->query->lte($field, $timestamp + 86399);
        }
    }
}