2019-05-18 20:50:14 -04:00
|
|
|
<?php
|
2020-02-09 09:45:36 -05:00
|
|
|
/**
|
2022-01-02 02:27:47 -05:00
|
|
|
* @copyright Copyright (C) 2010-2022, the Friendica project
|
2020-02-09 09:45:36 -05:00
|
|
|
*
|
|
|
|
* @license GNU AGPL version 3 or any later version
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
2019-05-18 20:50:14 -04:00
|
|
|
|
|
|
|
namespace Friendica\Object\Search;
|
|
|
|
|
|
|
|
use Friendica\Model\Search;
|
|
|
|
|
|
|
|
/**
|
2019-05-20 12:42:27 -04:00
|
|
|
* A list of search results with metadata
|
2019-05-18 20:50:14 -04:00
|
|
|
*
|
|
|
|
* @see Search for details
|
|
|
|
*/
|
2019-05-20 12:42:27 -04:00
|
|
|
class ResultList
|
2019-05-18 20:50:14 -04:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Page of the result list
|
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
private $page;
|
|
|
|
/**
|
|
|
|
* Total count of results
|
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
private $total;
|
|
|
|
/**
|
|
|
|
* items per page
|
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
private $itemsPage;
|
|
|
|
/**
|
|
|
|
* Array of results
|
2019-05-18 23:13:06 -04:00
|
|
|
*
|
2019-05-20 12:42:27 -04:00
|
|
|
* @var IResult[]
|
2019-05-18 20:50:14 -04:00
|
|
|
*/
|
|
|
|
private $results;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function getPage()
|
|
|
|
{
|
|
|
|
return $this->page;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function getTotal()
|
|
|
|
{
|
|
|
|
return $this->total;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function getItemsPage()
|
|
|
|
{
|
|
|
|
return $this->itemsPage;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-05-20 12:42:27 -04:00
|
|
|
* @return IResult[]
|
2019-05-18 20:50:14 -04:00
|
|
|
*/
|
|
|
|
public function getResults()
|
|
|
|
{
|
|
|
|
return $this->results;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-05-18 23:13:06 -04:00
|
|
|
* @param int $page
|
|
|
|
* @param int $total
|
|
|
|
* @param int $itemsPage
|
2019-05-20 12:42:27 -04:00
|
|
|
* @param IResult[] $results
|
2019-05-18 20:50:14 -04:00
|
|
|
*/
|
|
|
|
public function __construct($page = 0, $total = 0, $itemsPage = 0, array $results = [])
|
|
|
|
{
|
|
|
|
$this->page = $page;
|
|
|
|
$this->total = $total;
|
|
|
|
$this->itemsPage = $itemsPage;
|
|
|
|
|
|
|
|
$this->results = $results;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds a result to the result list
|
|
|
|
*
|
2019-05-20 12:42:27 -04:00
|
|
|
* @param IResult $result
|
2019-05-18 20:50:14 -04:00
|
|
|
*/
|
2019-05-20 12:42:27 -04:00
|
|
|
public function addResult(IResult $result)
|
2019-05-18 20:50:14 -04:00
|
|
|
{
|
|
|
|
$this->results[] = $result;
|
|
|
|
}
|
|
|
|
}
|