2017-07-03 03:29:58 +01:00
|
|
|
<?php
|
|
|
|
|
2017-08-19 04:19:06 +01:00
|
|
|
namespace Pterodactyl\Repositories\Concerns;
|
2017-07-03 03:29:58 +01:00
|
|
|
|
2017-08-19 04:19:06 +01:00
|
|
|
trait Searchable
|
2017-07-03 03:29:58 +01:00
|
|
|
{
|
2017-07-08 20:07:51 +01:00
|
|
|
/**
|
2018-01-05 04:49:50 +00:00
|
|
|
* The search term to use when filtering results.
|
2017-08-19 04:19:06 +01:00
|
|
|
*
|
2018-01-05 04:49:50 +00:00
|
|
|
* @var null|string
|
2017-07-15 17:52:34 +01:00
|
|
|
*/
|
2018-01-05 04:49:50 +00:00
|
|
|
protected $searchTerm;
|
2017-07-15 17:52:34 +01:00
|
|
|
|
|
|
|
/**
|
2018-01-05 04:49:50 +00:00
|
|
|
* Set the search term.
|
2017-08-19 04:19:06 +01:00
|
|
|
*
|
2018-01-05 04:49:50 +00:00
|
|
|
* @param string|null $term
|
2017-08-19 04:19:06 +01:00
|
|
|
* @return $this
|
2018-01-05 04:49:50 +00:00
|
|
|
* @deprecated
|
2017-07-08 20:07:51 +01:00
|
|
|
*/
|
2017-07-15 17:52:34 +01:00
|
|
|
public function search($term)
|
2018-01-05 04:49:50 +00:00
|
|
|
{
|
|
|
|
return $this->setSearchTerm($term);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the search term to use when requesting all records from
|
|
|
|
* the model.
|
|
|
|
*
|
|
|
|
* @param string|null $term
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function setSearchTerm(string $term = null)
|
2017-07-15 17:52:34 +01:00
|
|
|
{
|
|
|
|
if (empty($term)) {
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
$clone = clone $this;
|
|
|
|
$clone->searchTerm = $term;
|
|
|
|
|
|
|
|
return $clone;
|
|
|
|
}
|
2018-01-05 04:49:50 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Determine if a valid search term is set on this repository.
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function hasSearchTerm(): bool
|
|
|
|
{
|
|
|
|
return ! empty($this->searchTerm);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the search term.
|
|
|
|
*
|
|
|
|
* @return string|null
|
|
|
|
*/
|
|
|
|
public function getSearchTerm()
|
|
|
|
{
|
|
|
|
return $this->searchTerm;
|
|
|
|
}
|
2017-07-03 03:29:58 +01:00
|
|
|
}
|