mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-15 09:11:07 +01:00
Add similiar questions sidebar to Ponder
Summary: Ref T9099. Testing out a two column layout in Ponder, with the main idea being creating a more browsable, discoverable product. I'd like the side column though to be a little smarter and provide project based searching. Ideally, if I'm reading Resolved Maniphest questions, other Resolved Maniphest questions are likely interesting. Another scenario is if I'm answering questions, in which case browsing more Open questions would also be interesting. Ponder "Main Column" still needs to be redesigned. Test Plan: Browse open questions, resolved questions. Reviewers: epriestley Reviewed By: epriestley Subscribers: Korvin Maniphest Tasks: T9099 Differential Revision: https://secure.phabricator.com/D13849
This commit is contained in:
parent
efa8855e03
commit
b4e038d2af
6 changed files with 149 additions and 12 deletions
|
@ -148,6 +148,7 @@ return array(
|
||||||
'rsrc/css/phui/phui-tag-view.css' => '402691cc',
|
'rsrc/css/phui/phui-tag-view.css' => '402691cc',
|
||||||
'rsrc/css/phui/phui-text.css' => 'cf019f54',
|
'rsrc/css/phui/phui-text.css' => 'cf019f54',
|
||||||
'rsrc/css/phui/phui-timeline-view.css' => 'f1bccf73',
|
'rsrc/css/phui/phui-timeline-view.css' => 'f1bccf73',
|
||||||
|
'rsrc/css/phui/phui-two-column-view.css' => 'add0a7d1',
|
||||||
'rsrc/css/phui/phui-workboard-view.css' => '6704d68d',
|
'rsrc/css/phui/phui-workboard-view.css' => '6704d68d',
|
||||||
'rsrc/css/phui/phui-workpanel-view.css' => 'adec7699',
|
'rsrc/css/phui/phui-workpanel-view.css' => 'adec7699',
|
||||||
'rsrc/css/sprite-login.css' => '1ebb9bf9',
|
'rsrc/css/sprite-login.css' => '1ebb9bf9',
|
||||||
|
@ -801,6 +802,7 @@ return array(
|
||||||
'phui-text-css' => 'cf019f54',
|
'phui-text-css' => 'cf019f54',
|
||||||
'phui-theme-css' => '6b451f24',
|
'phui-theme-css' => '6b451f24',
|
||||||
'phui-timeline-view-css' => 'f1bccf73',
|
'phui-timeline-view-css' => 'f1bccf73',
|
||||||
|
'phui-two-column-view-css' => 'add0a7d1',
|
||||||
'phui-workboard-view-css' => '6704d68d',
|
'phui-workboard-view-css' => '6704d68d',
|
||||||
'phui-workpanel-view-css' => 'adec7699',
|
'phui-workpanel-view-css' => 'adec7699',
|
||||||
'phuix-action-list-view' => 'b5c256b8',
|
'phuix-action-list-view' => 'b5c256b8',
|
||||||
|
|
|
@ -1406,6 +1406,7 @@ phutil_register_library_map(array(
|
||||||
'PHUITimelineEventView' => 'view/phui/PHUITimelineEventView.php',
|
'PHUITimelineEventView' => 'view/phui/PHUITimelineEventView.php',
|
||||||
'PHUITimelineExample' => 'applications/uiexample/examples/PHUITimelineExample.php',
|
'PHUITimelineExample' => 'applications/uiexample/examples/PHUITimelineExample.php',
|
||||||
'PHUITimelineView' => 'view/phui/PHUITimelineView.php',
|
'PHUITimelineView' => 'view/phui/PHUITimelineView.php',
|
||||||
|
'PHUITwoColumnView' => 'view/phui/PHUITwoColumnView.php',
|
||||||
'PHUITypeaheadExample' => 'applications/uiexample/examples/PHUITypeaheadExample.php',
|
'PHUITypeaheadExample' => 'applications/uiexample/examples/PHUITypeaheadExample.php',
|
||||||
'PHUIWorkboardView' => 'view/phui/PHUIWorkboardView.php',
|
'PHUIWorkboardView' => 'view/phui/PHUIWorkboardView.php',
|
||||||
'PHUIWorkpanelView' => 'view/phui/PHUIWorkpanelView.php',
|
'PHUIWorkpanelView' => 'view/phui/PHUIWorkpanelView.php',
|
||||||
|
@ -5183,6 +5184,7 @@ phutil_register_library_map(array(
|
||||||
'PHUITimelineEventView' => 'AphrontView',
|
'PHUITimelineEventView' => 'AphrontView',
|
||||||
'PHUITimelineExample' => 'PhabricatorUIExample',
|
'PHUITimelineExample' => 'PhabricatorUIExample',
|
||||||
'PHUITimelineView' => 'AphrontView',
|
'PHUITimelineView' => 'AphrontView',
|
||||||
|
'PHUITwoColumnView' => 'AphrontTagView',
|
||||||
'PHUITypeaheadExample' => 'PhabricatorUIExample',
|
'PHUITypeaheadExample' => 'PhabricatorUIExample',
|
||||||
'PHUIWorkboardView' => 'AphrontTagView',
|
'PHUIWorkboardView' => 'AphrontTagView',
|
||||||
'PHUIWorkpanelView' => 'AphrontTagView',
|
'PHUIWorkpanelView' => 'AphrontTagView',
|
||||||
|
|
|
@ -26,6 +26,16 @@ final class PonderQuestionStatus extends PonderConstants {
|
||||||
return idx($map, $status, pht('Unknown'));
|
return idx($map, $status, pht('Unknown'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static function getQuestionStatusName($status) {
|
||||||
|
$map = array(
|
||||||
|
self::STATUS_OPEN => pht('Open'),
|
||||||
|
self::STATUS_CLOSED_RESOLVED => pht('Resolved'),
|
||||||
|
self::STATUS_CLOSED_OBSOLETE => pht('Obsolete'),
|
||||||
|
self::STATUS_CLOSED_DUPLICATE => pht('Duplicate'),
|
||||||
|
);
|
||||||
|
return idx($map, $status, pht('Unknown'));
|
||||||
|
}
|
||||||
|
|
||||||
public static function getQuestionStatusDescription($status) {
|
public static function getQuestionStatusDescription($status) {
|
||||||
$map = array(
|
$map = array(
|
||||||
self::STATUS_OPEN =>
|
self::STATUS_OPEN =>
|
||||||
|
|
|
@ -10,6 +10,7 @@ final class PonderQuestionViewController extends PonderController {
|
||||||
->setViewer($viewer)
|
->setViewer($viewer)
|
||||||
->withIDs(array($id))
|
->withIDs(array($id))
|
||||||
->needAnswers(true)
|
->needAnswers(true)
|
||||||
|
->needProjectPHIDs(true)
|
||||||
->executeOne();
|
->executeOne();
|
||||||
if (!$question) {
|
if (!$question) {
|
||||||
return new Aphront404Response();
|
return new Aphront404Response();
|
||||||
|
@ -51,6 +52,7 @@ final class PonderQuestionViewController extends PonderController {
|
||||||
|
|
||||||
$actions = $this->buildActionListView($question);
|
$actions = $this->buildActionListView($question);
|
||||||
$properties = $this->buildPropertyListView($question, $actions);
|
$properties = $this->buildPropertyListView($question, $actions);
|
||||||
|
$sidebar = $this->buildSidebar($question);
|
||||||
|
|
||||||
$object_box = id(new PHUIObjectBoxView())
|
$object_box = id(new PHUIObjectBoxView())
|
||||||
->setHeader($header)
|
->setHeader($header)
|
||||||
|
@ -59,21 +61,19 @@ final class PonderQuestionViewController extends PonderController {
|
||||||
$crumbs = $this->buildApplicationCrumbs($this->buildSideNavView());
|
$crumbs = $this->buildApplicationCrumbs($this->buildSideNavView());
|
||||||
$crumbs->addTextCrumb('Q'.$id, '/Q'.$id);
|
$crumbs->addTextCrumb('Q'.$id, '/Q'.$id);
|
||||||
|
|
||||||
$ponder_view = phutil_tag(
|
$ponder_view = id(new PHUITwoColumnView())
|
||||||
'div',
|
->setMainColumn(array(
|
||||||
array(
|
|
||||||
'class' => 'ponder-question-view',
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
$crumbs,
|
|
||||||
$object_box,
|
$object_box,
|
||||||
$question_xactions,
|
$question_xactions,
|
||||||
$answers,
|
$answers,
|
||||||
$answer_add_panel,
|
$answer_add_panel,
|
||||||
));
|
))
|
||||||
|
->setSideColumn($sidebar)
|
||||||
|
->addClass('ponder-question-view');
|
||||||
|
|
||||||
return $this->buildApplicationPage(
|
return $this->buildApplicationPage(
|
||||||
array(
|
array(
|
||||||
|
$crumbs,
|
||||||
$ponder_view,
|
$ponder_view,
|
||||||
),
|
),
|
||||||
array(
|
array(
|
||||||
|
@ -410,4 +410,46 @@ final class PonderQuestionViewController extends PonderController {
|
||||||
return array($show, $hide);
|
return array($show, $hide);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function buildSidebar(PonderQuestion $question) {
|
||||||
|
$viewer = $this->getViewer();
|
||||||
|
$status = $question->getStatus();
|
||||||
|
$id = $question->getID();
|
||||||
|
|
||||||
|
$questions = id(new PonderQuestionQuery())
|
||||||
|
->setViewer($viewer)
|
||||||
|
->withStatuses(array($status))
|
||||||
|
->withEdgeLogicPHIDs(
|
||||||
|
PhabricatorProjectObjectHasProjectEdgeType::EDGECONST,
|
||||||
|
PhabricatorQueryConstraint::OPERATOR_OR,
|
||||||
|
$question->getProjectPHIDs())
|
||||||
|
->setLimit(10)
|
||||||
|
->execute();
|
||||||
|
|
||||||
|
$list = id(new PHUIObjectItemListView())
|
||||||
|
->setUser($viewer)
|
||||||
|
->setNoDataString(pht('No similar questions found.'));
|
||||||
|
|
||||||
|
foreach ($questions as $question) {
|
||||||
|
if ($id == $question->getID()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$item = new PHUIObjectItemView();
|
||||||
|
$item->setObjectName('Q'.$question->getID());
|
||||||
|
$item->setHeader($question->getTitle());
|
||||||
|
$item->setHref('/Q'.$question->getID());
|
||||||
|
$item->setObject($question);
|
||||||
|
|
||||||
|
$item->addAttribute(
|
||||||
|
pht('%d Answer(s)', $question->getAnswerCount()));
|
||||||
|
|
||||||
|
$list->addItem($item);
|
||||||
|
}
|
||||||
|
|
||||||
|
$box = id(new PHUIObjectBoxView())
|
||||||
|
->setHeaderText(pht('Similar Questions'))
|
||||||
|
->setObjectList($list);
|
||||||
|
|
||||||
|
return $box;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
48
src/view/phui/PHUITwoColumnView.php
Normal file
48
src/view/phui/PHUITwoColumnView.php
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PHUITwoColumnView extends AphrontTagView {
|
||||||
|
|
||||||
|
private $mainColumn;
|
||||||
|
private $sideColumn;
|
||||||
|
|
||||||
|
public function setMainColumn($main) {
|
||||||
|
$this->mainColumn = $main;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setSideColumn($side) {
|
||||||
|
$this->sideColumn = $side;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getTagAttributes() {
|
||||||
|
return array(
|
||||||
|
'class' => 'phui-two-column-view grouped',
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getTagContent() {
|
||||||
|
require_celerity_resource('phui-two-column-view-css');
|
||||||
|
|
||||||
|
$main = phutil_tag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'class' => 'phui-main-column',
|
||||||
|
),
|
||||||
|
$this->mainColumn);
|
||||||
|
|
||||||
|
$side = phutil_tag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'class' => 'phui-side-column',
|
||||||
|
),
|
||||||
|
$this->sideColumn);
|
||||||
|
|
||||||
|
return phutil_tag_div(
|
||||||
|
'phui-two-column-row',
|
||||||
|
array(
|
||||||
|
$main,
|
||||||
|
$side,
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
33
webroot/rsrc/css/phui/phui-two-column-view.css
Normal file
33
webroot/rsrc/css/phui/phui-two-column-view.css
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
/**
|
||||||
|
* @provides phui-two-column-view-css
|
||||||
|
*/
|
||||||
|
|
||||||
|
.phui-two-column-view {
|
||||||
|
display: table;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.phui-two-column-row {
|
||||||
|
display: table-row;
|
||||||
|
}
|
||||||
|
|
||||||
|
.device-desktop .phui-two-column-view .phui-main-column {
|
||||||
|
display: table-cell;
|
||||||
|
vertical-align: top;
|
||||||
|
}
|
||||||
|
|
||||||
|
.device-desktop .phui-two-column-view .phui-side-column {
|
||||||
|
width: 320px;
|
||||||
|
display: table-cell;
|
||||||
|
vertical-align: top;
|
||||||
|
}
|
||||||
|
|
||||||
|
.device-desktop .phui-two-column-view
|
||||||
|
.phui-main-column .phui-object-box:first-child {
|
||||||
|
margin: 0 16px 0 16px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.device-desktop .phui-two-column-view
|
||||||
|
.phui-side-column .phui-object-box:first-child {
|
||||||
|
margin: 0 16px 16px 0;
|
||||||
|
}
|
Loading…
Reference in a new issue