mirror of
https://we.phorge.it/source/phorge.git
synced 2024-12-02 03:32:42 +01:00
801607381d
Summary: Ref T8099. This adds a new class which all search engines return for layout. I thought about this a number of ways, and I think this is the cleanest path. Each Engine can return whatever UI bits they needs, and AppSearch or Dashboard picks and lays the bits out as needed. In the AppSearch case, interfaces like Notifications, Calendar, Legalpad all need more custom layouts. I think this also leaves a resonable path forward for NUX as well. Also, not sure I implemented the class correctly, but assume thats easy to fix? Test Plan: Review and do a search in each application changed. Grep for all call sites. Reviewers: btrahan, epriestley Reviewed By: epriestley Subscribers: epriestley, Korvin Maniphest Tasks: T8099 Differential Revision: https://secure.phabricator.com/D13332
101 lines
2.3 KiB
PHP
101 lines
2.3 KiB
PHP
<?php
|
|
|
|
final class PhabricatorSpacesNamespaceSearchEngine
|
|
extends PhabricatorApplicationSearchEngine {
|
|
|
|
public function getApplicationClassName() {
|
|
return 'PhabricatorSpacesApplication';
|
|
}
|
|
|
|
public function getResultTypeDescription() {
|
|
return pht('Spaces');
|
|
}
|
|
|
|
public function newQuery() {
|
|
return new PhabricatorSpacesNamespaceQuery();
|
|
}
|
|
|
|
protected function buildCustomSearchFields() {
|
|
return array(
|
|
id(new PhabricatorSearchThreeStateField())
|
|
->setLabel(pht('Active'))
|
|
->setKey('active')
|
|
->setOptions(
|
|
pht('(Show All)'),
|
|
pht('Show Only Active Spaces'),
|
|
pht('Hide Active Spaces')),
|
|
);
|
|
}
|
|
|
|
protected function buildQueryFromParameters(array $map) {
|
|
$query = $this->newQuery();
|
|
|
|
if ($map['active']) {
|
|
$query->withIsArchived(!$map['active']);
|
|
}
|
|
|
|
return $query;
|
|
}
|
|
|
|
protected function getURI($path) {
|
|
return '/spaces/'.$path;
|
|
}
|
|
|
|
protected function getBuiltinQueryNames() {
|
|
$names = array(
|
|
'active' => pht('Active Spaces'),
|
|
'all' => pht('All Spaces'),
|
|
);
|
|
|
|
return $names;
|
|
}
|
|
|
|
public function buildSavedQueryFromBuiltin($query_key) {
|
|
$query = $this->newSavedQuery();
|
|
$query->setQueryKey($query_key);
|
|
|
|
switch ($query_key) {
|
|
case 'active':
|
|
return $query->setParameter('active', true);
|
|
case 'all':
|
|
return $query;
|
|
}
|
|
|
|
return parent::buildSavedQueryFromBuiltin($query_key);
|
|
}
|
|
|
|
protected function renderResultList(
|
|
array $spaces,
|
|
PhabricatorSavedQuery $query,
|
|
array $handles) {
|
|
assert_instances_of($spaces, 'PhabricatorSpacesNamespace');
|
|
|
|
$viewer = $this->requireViewer();
|
|
|
|
$list = new PHUIObjectItemListView();
|
|
$list->setUser($viewer);
|
|
foreach ($spaces as $space) {
|
|
$item = id(new PHUIObjectItemView())
|
|
->setObjectName($space->getMonogram())
|
|
->setHeader($space->getNamespaceName())
|
|
->setHref('/'.$space->getMonogram());
|
|
|
|
if ($space->getIsDefaultNamespace()) {
|
|
$item->addIcon('fa-certificate', pht('Default Space'));
|
|
}
|
|
|
|
if ($space->getIsArchived()) {
|
|
$item->setDisabled(true);
|
|
}
|
|
|
|
$list->addItem($item);
|
|
}
|
|
|
|
$result = new PhabricatorApplicationSearchResultView();
|
|
$result->setObjectList($list);
|
|
$result->setNoDataString(pht('No spaces found.'));
|
|
|
|
return $result;
|
|
}
|
|
|
|
}
|