1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-09 14:21:02 +01:00

Add fulltext search to Maniphest custom query screen.

Summary: Allow fulltext search on custom query screen using the same fulltext search as the search page.

Test Plan: Enter search terms - with and without additional filters - see the expected results.  Don't enter search terms - with or without additional filters - and see the expected results.

Reviewers: epriestley

CC: aran, Korvin

Maniphest Tasks: T1305

Differential Revision: https://secure.phabricator.com/D2763
This commit is contained in:
Jonathan Lomas 2012-06-15 14:09:49 -07:00
parent 444c634b6c
commit f91fc70b14
2 changed files with 46 additions and 1 deletions

View file

@ -34,6 +34,8 @@ final class ManiphestTaskQuery {
private $anyProject = false; private $anyProject = false;
private $includeNoProject = null; private $includeNoProject = null;
private $fullTextSearch = '';
private $status = 'status-any'; private $status = 'status-any';
const STATUS_ANY = 'status-any'; const STATUS_ANY = 'status-any';
const STATUS_OPEN = 'status-open'; const STATUS_OPEN = 'status-open';
@ -117,6 +119,11 @@ final class ManiphestTaskQuery {
return $this; return $this;
} }
public function withFullTextSearch($fulltext_search) {
$this->fullTextSearch = $fulltext_search;
return $this;
}
public function setGroupBy($group) { public function setGroupBy($group) {
$this->groupBy = $group; $this->groupBy = $group;
return $this; return $this;
@ -176,6 +183,7 @@ final class ManiphestTaskQuery {
$where[] = $this->buildSubscriberWhereClause($conn); $where[] = $this->buildSubscriberWhereClause($conn);
$where[] = $this->buildProjectWhereClause($conn); $where[] = $this->buildProjectWhereClause($conn);
$where[] = $this->buildXProjectWhereClause($conn); $where[] = $this->buildXProjectWhereClause($conn);
$where[] = $this->buildFullTextWhereClause($conn);
$where = array_filter($where); $where = array_filter($where);
if ($where) { if ($where) {
@ -336,6 +344,25 @@ final class ManiphestTaskQuery {
} }
} }
private function buildFullTextWhereClause($conn) {
if (!$this->fullTextSearch) {
return null;
}
// In doing a fulltext search, we first find all the PHIDs that match the
// fulltext search, and then use that to limit the rest of the search
$fulltext_query = new PhabricatorSearchQuery();
$fulltext_query->setQuery($this->fullTextSearch);
$engine = PhabricatorSearchEngineSelector::newSelector()->newEngine();
$fulltext_results = $engine->executeSearch($fulltext_query);
return qsprintf(
$conn,
'phid IN (%Ls)',
$fulltext_results);
}
private function buildSubscriberWhereClause($conn) { private function buildSubscriberWhereClause($conn) {
if (!$this->subscriberPHIDs) { if (!$this->subscriberPHIDs) {
return null; return null;

View file

@ -46,13 +46,17 @@ final class ManiphestTaskListController extends ManiphestController {
$task_ids = $request->getStr('set_tasks'); $task_ids = $request->getStr('set_tasks');
$task_ids = nonempty($task_ids, null); $task_ids = nonempty($task_ids, null);
$search_text = $request->getStr('set_search');
$search_text = nonempty($search_text, null);
$uri = $request->getRequestURI() $uri = $request->getRequestURI()
->alter('users', $this->getArrToStrList('set_users')) ->alter('users', $this->getArrToStrList('set_users'))
->alter('projects', $this->getArrToStrList('set_projects')) ->alter('projects', $this->getArrToStrList('set_projects'))
->alter('xprojects', $this->getArrToStrList('set_xprojects')) ->alter('xprojects', $this->getArrToStrList('set_xprojects'))
->alter('owners', $this->getArrToStrList('set_owners')) ->alter('owners', $this->getArrToStrList('set_owners'))
->alter('authors', $this->getArrToStrList('set_authors')) ->alter('authors', $this->getArrToStrList('set_authors'))
->alter('tasks', $task_ids); ->alter('tasks', $task_ids)
->alter('search', $search_text);
return id(new AphrontRedirectResponse())->setURI($uri); return id(new AphrontRedirectResponse())->setURI($uri);
} }
@ -99,6 +103,8 @@ final class ManiphestTaskListController extends ManiphestController {
// Extract information we need to render the filters from the query. // Extract information we need to render the filters from the query.
$search_text = $query->getParameter('fullTextSearch');
$user_phids = $query->getParameter('userPHIDs', array()); $user_phids = $query->getParameter('userPHIDs', array());
$task_ids = $query->getParameter('taskIDs', array()); $task_ids = $query->getParameter('taskIDs', array());
$owner_phids = $query->getParameter('ownerPHIDs', array()); $owner_phids = $query->getParameter('ownerPHIDs', array());
@ -143,6 +149,12 @@ final class ManiphestTaskListController extends ManiphestController {
} }
if ($this->view == 'custom') { if ($this->view == 'custom') {
$form->appendChild(
id(new AphrontFormTextControl())
->setName('set_search')
->setLabel('Search')
->setValue($search_text)
);
$form->appendChild( $form->appendChild(
id(new AphrontFormTextControl()) id(new AphrontFormTextControl())
->setName('set_tasks') ->setName('set_tasks')
@ -355,6 +367,7 @@ final class ManiphestTaskListController extends ManiphestController {
public static function loadTasks(PhabricatorSearchQuery $search_query) { public static function loadTasks(PhabricatorSearchQuery $search_query) {
$any_project = false; $any_project = false;
$search_text = $search_query->getParameter('fullTextSearch');
$user_phids = $search_query->getParameter('userPHIDs', array()); $user_phids = $search_query->getParameter('userPHIDs', array());
$project_phids = $search_query->getParameter('projectPHIDs', array()); $project_phids = $search_query->getParameter('projectPHIDs', array());
$task_ids = $search_query->getParameter('taskIDs', array()); $task_ids = $search_query->getParameter('taskIDs', array());
@ -419,6 +432,8 @@ final class ManiphestTaskListController extends ManiphestController {
$query->withAnyProject($any_project); $query->withAnyProject($any_project);
$query->withFullTextSearch($search_text);
$order_map = array( $order_map = array(
'priority' => ManiphestTaskQuery::ORDER_PRIORITY, 'priority' => ManiphestTaskQuery::ORDER_PRIORITY,
'created' => ManiphestTaskQuery::ORDER_CREATED, 'created' => ManiphestTaskQuery::ORDER_CREATED,
@ -649,6 +664,8 @@ final class ManiphestTaskListController extends ManiphestController {
$owner_phids = $request->getStrList('owners'); $owner_phids = $request->getStrList('owners');
$author_phids = $request->getStrList('authors'); $author_phids = $request->getStrList('authors');
$search_string = $request->getStr('search');
$page = $request->getInt('offset'); $page = $request->getInt('offset');
$page_size = self::DEFAULT_PAGE_SIZE; $page_size = self::DEFAULT_PAGE_SIZE;
@ -656,6 +673,7 @@ final class ManiphestTaskListController extends ManiphestController {
$query->setQuery('<<maniphest>>'); $query->setQuery('<<maniphest>>');
$query->setParameters( $query->setParameters(
array( array(
'fullTextSearch' => $search_string,
'view' => $this->view, 'view' => $this->view,
'userPHIDs' => $user_phids, 'userPHIDs' => $user_phids,
'projectPHIDs' => $project_phids, 'projectPHIDs' => $project_phids,