mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-09-17 23:16:04 +02:00
42 lines
1.1 KiB
PHP
42 lines
1.1 KiB
PHP
<?php
|
|
/**
|
|
* Selects numerical/date content greater than the input
|
|
*
|
|
* @todo documentation
|
|
*
|
|
* @package framework
|
|
* @subpackage search
|
|
*/
|
|
class GreaterThanFilter extends SearchFilter {
|
|
|
|
/**
|
|
* @return DataQuery
|
|
*/
|
|
protected function applyOne(DataQuery $query) {
|
|
$this->model = $query->applyRelation($this->relation);
|
|
$value = $this->getDbFormattedValue();
|
|
|
|
if(is_numeric($value)) $filter = sprintf("%s > %s", $this->getDbName(), Convert::raw2sql($value));
|
|
else $filter = sprintf("%s > '%s'", $this->getDbName(), Convert::raw2sql($value));
|
|
|
|
return $query->where($filter);
|
|
}
|
|
|
|
/**
|
|
* @return DataQuery
|
|
*/
|
|
protected function excludeOne(DataQuery $query) {
|
|
$this->model = $query->applyRelation($this->relation);
|
|
$value = $this->getDbFormattedValue();
|
|
|
|
if(is_numeric($value)) $filter = sprintf("%s <= %s", $this->getDbName(), Convert::raw2sql($value));
|
|
else $filter = sprintf("%s <= '%s'", $this->getDbName(), Convert::raw2sql($value));
|
|
|
|
return $query->where($filter);
|
|
}
|
|
|
|
public function isEmpty() {
|
|
return $this->getValue() === array() || $this->getValue() === null || $this->getValue() === '';
|
|
}
|
|
}
|