mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-15 09:11:07 +01:00
v0 embedding slowvotes
Summary: Slowvotes can now be embed using {V*} syntax. Nothing fancy there yet. Test Plan: {F40842} Reviewers: epriestley Reviewed By: epriestley CC: aran, Korvin, chad Maniphest Tasks: T2883 Differential Revision: https://secure.phabricator.com/D5713
This commit is contained in:
parent
42c1e39ae6
commit
5943ae4670
7 changed files with 203 additions and 1 deletions
|
@ -3297,7 +3297,7 @@ celerity_register_resource_map(array(
|
||||||
),
|
),
|
||||||
'phabricator-slowvote-css' =>
|
'phabricator-slowvote-css' =>
|
||||||
array(
|
array(
|
||||||
'uri' => '/res/94d20443/rsrc/css/application/slowvote/slowvote.css',
|
'uri' => '/res/dd7e273e/rsrc/css/application/slowvote/slowvote.css',
|
||||||
'type' => 'css',
|
'type' => 'css',
|
||||||
'requires' =>
|
'requires' =>
|
||||||
array(
|
array(
|
||||||
|
|
|
@ -1728,6 +1728,8 @@ phutil_register_library_map(array(
|
||||||
'ReleephStatusFieldSpecification' => 'applications/releeph/field/specification/ReleephStatusFieldSpecification.php',
|
'ReleephStatusFieldSpecification' => 'applications/releeph/field/specification/ReleephStatusFieldSpecification.php',
|
||||||
'ReleephSummaryFieldSpecification' => 'applications/releeph/field/specification/ReleephSummaryFieldSpecification.php',
|
'ReleephSummaryFieldSpecification' => 'applications/releeph/field/specification/ReleephSummaryFieldSpecification.php',
|
||||||
'ReleephUserView' => 'applications/releeph/view/user/ReleephUserView.php',
|
'ReleephUserView' => 'applications/releeph/view/user/ReleephUserView.php',
|
||||||
|
'SlowvoteEmbedView' => 'applications/slowvote/view/SlowvoteEmbedView.php',
|
||||||
|
'SlowvoteRemarkupRule' => 'applications/slowvote/remarkup/SlowvoteRemarkupRule.php',
|
||||||
),
|
),
|
||||||
'function' =>
|
'function' =>
|
||||||
array(
|
array(
|
||||||
|
@ -3455,5 +3457,7 @@ phutil_register_library_map(array(
|
||||||
'ReleephStatusFieldSpecification' => 'ReleephFieldSpecification',
|
'ReleephStatusFieldSpecification' => 'ReleephFieldSpecification',
|
||||||
'ReleephSummaryFieldSpecification' => 'ReleephFieldSpecification',
|
'ReleephSummaryFieldSpecification' => 'ReleephFieldSpecification',
|
||||||
'ReleephUserView' => 'AphrontView',
|
'ReleephUserView' => 'AphrontView',
|
||||||
|
'SlowvoteEmbedView' => 'AphrontView',
|
||||||
|
'SlowvoteRemarkupRule' => 'PhabricatorRemarkupRuleObject',
|
||||||
),
|
),
|
||||||
));
|
));
|
||||||
|
|
|
@ -138,6 +138,11 @@ final class PhabricatorObjectHandleData {
|
||||||
->execute();
|
->execute();
|
||||||
return mpull($mocks, null, 'getPHID');
|
return mpull($mocks, null, 'getPHID');
|
||||||
|
|
||||||
|
case PhabricatorPHIDConstants::PHID_TYPE_POLL:
|
||||||
|
$polls = id(new PhabricatorSlowvotePoll())
|
||||||
|
->loadAllWhere('phid IN (%Ls)', $phids);
|
||||||
|
return mpull($polls, null, 'getPHID');
|
||||||
|
|
||||||
case PhabricatorPHIDConstants::PHID_TYPE_XACT:
|
case PhabricatorPHIDConstants::PHID_TYPE_XACT:
|
||||||
$subtypes = array();
|
$subtypes = array();
|
||||||
foreach ($phids as $phid) {
|
foreach ($phids as $phid) {
|
||||||
|
@ -620,6 +625,25 @@ final class PhabricatorObjectHandleData {
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case PhabricatorPHIDConstants::PHID_TYPE_POLL:
|
||||||
|
foreach ($phids as $phid) {
|
||||||
|
$handle = new PhabricatorObjectHandle();
|
||||||
|
$handle->setPHID($phid);
|
||||||
|
$handle->setType($type);
|
||||||
|
if (empty($objects[$phid])) {
|
||||||
|
$handle->setName('Unknown Slowvote');
|
||||||
|
} else {
|
||||||
|
$poll = $objects[$phid];
|
||||||
|
$handle->setName('V'.$poll->getID());
|
||||||
|
$handle->setFullName(
|
||||||
|
'V'.$poll->getID().': '.$poll->getQuestion());
|
||||||
|
$handle->setURI('/V'.$poll->getID());
|
||||||
|
$handle->setComplete(true);
|
||||||
|
}
|
||||||
|
$handles[$phid] = $handle;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case PhabricatorPHIDConstants::PHID_TYPE_MCRO:
|
case PhabricatorPHIDConstants::PHID_TYPE_MCRO:
|
||||||
foreach ($phids as $phid) {
|
foreach ($phids as $phid) {
|
||||||
$handle = new PhabricatorObjectHandle();
|
$handle = new PhabricatorObjectHandle();
|
||||||
|
|
|
@ -30,6 +30,12 @@ final class PhabricatorApplicationSlowvote extends PhabricatorApplication {
|
||||||
return self::GROUP_UTILITIES;
|
return self::GROUP_UTILITIES;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getRemarkupRules() {
|
||||||
|
return array(
|
||||||
|
new SlowvoteRemarkupRule(),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
public function getRoutes() {
|
public function getRoutes() {
|
||||||
return array(
|
return array(
|
||||||
'/V(?P<id>[1-9]\d*)' => 'PhabricatorSlowvotePollController',
|
'/V(?P<id>[1-9]\d*)' => 'PhabricatorSlowvotePollController',
|
||||||
|
|
41
src/applications/slowvote/remarkup/SlowvoteRemarkupRule.php
Normal file
41
src/applications/slowvote/remarkup/SlowvoteRemarkupRule.php
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group slowvote
|
||||||
|
*/
|
||||||
|
final class SlowvoteRemarkupRule
|
||||||
|
extends PhabricatorRemarkupRuleObject {
|
||||||
|
|
||||||
|
protected function getObjectNamePrefix() {
|
||||||
|
return 'V';
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function loadObjects(array $ids) {
|
||||||
|
$polls = array(id(new PhabricatorSlowvotePoll())->load(head($ids)));
|
||||||
|
|
||||||
|
return id(new PhabricatorSlowvotePoll())
|
||||||
|
->loadAllWhere('id IN (%Ld)', $ids);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function renderObjectEmbed($object, $handle, $options) {
|
||||||
|
$viewer = $this->getEngine()->getConfig('viewer');
|
||||||
|
|
||||||
|
$options = id(new PhabricatorSlowvoteOption())->loadAllWhere(
|
||||||
|
'pollID = %d',
|
||||||
|
$object->getID());
|
||||||
|
$choices = id(new PhabricatorSlowvoteChoice())->loadAllWhere(
|
||||||
|
'pollID = %d',
|
||||||
|
$object->getID());
|
||||||
|
$choices_by_user = mgroup($choices, 'getAuthorPHID');
|
||||||
|
|
||||||
|
$viewer_choices = idx($choices_by_user, $viewer->getPHID(), array());
|
||||||
|
|
||||||
|
$embed = id(new SlowvoteEmbedView())
|
||||||
|
->setPoll($object)
|
||||||
|
->setOptions($options)
|
||||||
|
->setViewerChoices($viewer_choices);
|
||||||
|
|
||||||
|
return $embed->render();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
105
src/applications/slowvote/view/SlowvoteEmbedView.php
Normal file
105
src/applications/slowvote/view/SlowvoteEmbedView.php
Normal file
|
@ -0,0 +1,105 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group slowvote
|
||||||
|
*/
|
||||||
|
final class SlowvoteEmbedView extends AphrontView {
|
||||||
|
|
||||||
|
private $poll;
|
||||||
|
private $options;
|
||||||
|
private $viewerChoices;
|
||||||
|
|
||||||
|
public function setPoll(PhabricatorSlowvotePoll $poll) {
|
||||||
|
$this->poll = $poll;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setOptions(array $options) {
|
||||||
|
$this->options = $options;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setViewerChoices(array $viewer_choices) {
|
||||||
|
$this->viewerChoices = $viewer_choices;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function render() {
|
||||||
|
|
||||||
|
if (!$this->poll) {
|
||||||
|
throw new Exception("Call setPoll() before render()!");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$this->options) {
|
||||||
|
throw new Exception("Call setOptions() before render()!");
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->poll->getShuffle()) {
|
||||||
|
shuffle($this->options);
|
||||||
|
}
|
||||||
|
|
||||||
|
require_celerity_resource('phabricator-slowvote-css');
|
||||||
|
|
||||||
|
$user_choices = array();
|
||||||
|
if (!empty($this->viewerChoices)) {
|
||||||
|
$user_choices = mpull($this->viewerChoices, null, 'getOptionID');
|
||||||
|
}
|
||||||
|
|
||||||
|
$options = array();
|
||||||
|
$ribbon_colors = array('#DF0101', '#DF7401', '#D7DF01', '#74DF00',
|
||||||
|
'#01DF01', '#01DF74', '#01DFD7', '#0174DF', '#0101DF', '#5F04B4',
|
||||||
|
'#B404AE');
|
||||||
|
shuffle($ribbon_colors);
|
||||||
|
|
||||||
|
foreach ($this->options as $option) {
|
||||||
|
$classes = 'phabricator-slowvote-embed-option-text';
|
||||||
|
|
||||||
|
$selected = '';
|
||||||
|
|
||||||
|
if (idx($user_choices, $option->getID(), false)) {
|
||||||
|
$classes .= ' phabricator-slowvote-embed-option-selected';
|
||||||
|
$selected = '@';
|
||||||
|
}
|
||||||
|
|
||||||
|
$option_text = phutil_tag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'class' => $classes
|
||||||
|
),
|
||||||
|
$selected.$option->getName());
|
||||||
|
|
||||||
|
$options[] = phutil_tag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'class' => 'phabricator-slowvote-embed-option',
|
||||||
|
'style' =>
|
||||||
|
sprintf('border-left: 7px solid %s;', array_shift($ribbon_colors))
|
||||||
|
),
|
||||||
|
array($option_text));
|
||||||
|
}
|
||||||
|
|
||||||
|
$link_to_slowvote = phutil_tag(
|
||||||
|
'a',
|
||||||
|
array(
|
||||||
|
'href' => '/V'.$this->poll->getID()
|
||||||
|
),
|
||||||
|
$this->poll->getQuestion());
|
||||||
|
|
||||||
|
$header = phutil_tag(
|
||||||
|
'div',
|
||||||
|
array(),
|
||||||
|
array('V'.$this->poll->getID().': ', $link_to_slowvote));
|
||||||
|
|
||||||
|
$body = phutil_tag(
|
||||||
|
'div',
|
||||||
|
array(),
|
||||||
|
$options);
|
||||||
|
|
||||||
|
return phutil_tag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'class' => 'phabricator-slowvote-embed'
|
||||||
|
),
|
||||||
|
array($header, $body));
|
||||||
|
}
|
||||||
|
}
|
|
@ -67,3 +67,25 @@
|
||||||
float: left;
|
float: left;
|
||||||
margin: 0px 4px 6px 0px;
|
margin: 0px 4px 6px 0px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.phabricator-slowvote-embed {
|
||||||
|
width: 400px;
|
||||||
|
background: #f7f7f7;
|
||||||
|
border: 1px solid #dbdbdb;
|
||||||
|
padding: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.phabricator-slowvote-embed-option {
|
||||||
|
margin: 1px;
|
||||||
|
background: #F0FFFF;
|
||||||
|
}
|
||||||
|
|
||||||
|
.phabricator-slowvote-embed-option-selected {
|
||||||
|
padding-left: 0px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.phabricator-slowvote-embed-option-text {
|
||||||
|
border: 1px solid #dbdbdb;
|
||||||
|
border-left: 0px;
|
||||||
|
padding-left: 1em;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue