mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-14 16:51:08 +01:00
Add Hovercards / restyle feed one line stories.
Summary: This adds hovercards to most stories and removes the profile photo from one line stories. I don't know about my implementation, which has difficulties with application transactions (because it shows status). Which leads me to a bigger question, which is can we render all people through a common function like AphrontTagView so we can easily class and/or hovercard it anywhere. Test Plan: Reviewed my feed, various stories. Reviewers: epriestley, btrahan Reviewed By: epriestley CC: aran, Korvin Differential Revision: https://secure.phabricator.com/D6684
This commit is contained in:
parent
5a352d0a69
commit
b348aaefb9
8 changed files with 77 additions and 36 deletions
|
@ -3791,7 +3791,7 @@ celerity_register_resource_map(array(
|
|||
),
|
||||
'phui-feed-story-css' =>
|
||||
array(
|
||||
'uri' => '/res/5d7ab26c/rsrc/css/phui/phui-feed-story.css',
|
||||
'uri' => '/res/68a0ce41/rsrc/css/phui/phui-feed-story.css',
|
||||
'type' => 'css',
|
||||
'requires' =>
|
||||
array(
|
||||
|
@ -3827,7 +3827,7 @@ celerity_register_resource_map(array(
|
|||
),
|
||||
'phui-remarkup-preview-css' =>
|
||||
array(
|
||||
'uri' => '/res/6c886e63/rsrc/css/phui/phui-remarkup-preview.css',
|
||||
'uri' => '/res/4535e062/rsrc/css/phui/phui-remarkup-preview.css',
|
||||
'type' => 'css',
|
||||
'requires' =>
|
||||
array(
|
||||
|
|
|
@ -232,11 +232,19 @@ abstract class PhabricatorFeedStory implements PhabricatorPolicyInterface {
|
|||
// NOTE: We render our own link here to customize the styling and add
|
||||
// the '_top' target for framed feeds.
|
||||
|
||||
return phutil_tag(
|
||||
$class = null;
|
||||
if ($handle->getType() == PhabricatorPeoplePHIDTypeUser::TYPECONST) {
|
||||
$class = 'phui-link-person';
|
||||
}
|
||||
|
||||
return javelin_tag(
|
||||
'a',
|
||||
array(
|
||||
'href' => $handle->getURI(),
|
||||
'target' => $this->framed ? '_top' : null,
|
||||
'sigil' => 'hovercard',
|
||||
'meta' => array('hoverPHID' => $phid),
|
||||
'class' => $class,
|
||||
),
|
||||
$handle->getLinkName());
|
||||
}
|
||||
|
|
|
@ -19,6 +19,7 @@ final class PhabricatorFeedStoryPhriction extends PhabricatorFeedStory {
|
|||
$data = $this->getStoryData();
|
||||
|
||||
$author_phid = $data->getAuthorPHID();
|
||||
$author_link = $this->linkTo($author_phid);
|
||||
$document_phid = $data->getValue('phid');
|
||||
|
||||
$view = $this->newStoryView();
|
||||
|
@ -38,7 +39,7 @@ final class PhabricatorFeedStoryPhriction extends PhabricatorFeedStory {
|
|||
$from_handle = $this->getHandle($from_phid);
|
||||
$view->setTitle(pht(
|
||||
'%s moved the document %s from %s to %s.',
|
||||
$this->linkTo($author_phid),
|
||||
$author_link,
|
||||
$document_handle->renderLink(),
|
||||
phutil_tag(
|
||||
'a',
|
||||
|
@ -58,7 +59,7 @@ final class PhabricatorFeedStoryPhriction extends PhabricatorFeedStory {
|
|||
default:
|
||||
$view->setTitle(pht(
|
||||
'%s %s the document %s.',
|
||||
$this->linkTo($author_phid),
|
||||
$author_link,
|
||||
$verb,
|
||||
$this->linkTo($document_phid)));
|
||||
break;
|
||||
|
@ -76,7 +77,8 @@ final class PhabricatorFeedStoryPhriction extends PhabricatorFeedStory {
|
|||
}
|
||||
|
||||
public function renderText() {
|
||||
$author_name = $this->getHandle($this->getAuthorPHID())->getLinkName();
|
||||
$author_phid = $this->getHandle($this->getAuthorPHID());
|
||||
$author_link = $this->linkTo($author_phid);
|
||||
|
||||
$document_handle = $this->getHandle($this->getPrimaryObjectPHID());
|
||||
$document_title = $document_handle->getLinkName();
|
||||
|
@ -85,7 +87,7 @@ final class PhabricatorFeedStoryPhriction extends PhabricatorFeedStory {
|
|||
$action = $this->getValue('action');
|
||||
$verb = PhrictionActionConstants::getActionPastTenseVerb($action);
|
||||
|
||||
$text = "{$author_name} {$verb} the document".
|
||||
$text = "{$author_link} {$verb} the document".
|
||||
" {$document_title} {$document_uri}";
|
||||
|
||||
return $text;
|
||||
|
|
|
@ -33,18 +33,21 @@ final class PhabricatorFeedStoryProject extends PhabricatorFeedStory {
|
|||
$proj_phid = $data->getValue('projectPHID');
|
||||
|
||||
$author_phid = $data->getAuthorPHID();
|
||||
$author_link = $this->linkTo($author_phid);
|
||||
|
||||
switch ($type) {
|
||||
case PhabricatorProjectTransactionType::TYPE_NAME:
|
||||
if (strlen($old)) {
|
||||
$action = hsprintf(
|
||||
'renamed project %s from %s to %s.',
|
||||
$action = pht(
|
||||
'% renamed project %s from %s to %s.',
|
||||
$author_link,
|
||||
$this->linkTo($proj_phid),
|
||||
$this->renderString($old),
|
||||
$this->renderString($new));
|
||||
} else {
|
||||
$action = hsprintf(
|
||||
'created project %s (as %s).',
|
||||
$action = pht(
|
||||
'% created project %s (as %s).',
|
||||
$author_link,
|
||||
$this->linkTo($proj_phid),
|
||||
$this->renderString($new));
|
||||
}
|
||||
|
@ -52,8 +55,9 @@ final class PhabricatorFeedStoryProject extends PhabricatorFeedStory {
|
|||
case PhabricatorProjectTransactionType::TYPE_STATUS:
|
||||
$old_name = PhabricatorProjectStatus::getNameForStatus($old);
|
||||
$new_name = PhabricatorProjectStatus::getNameForStatus($new);
|
||||
$action = hsprintf(
|
||||
'changed project %s status from %s to %s.',
|
||||
$action = pht(
|
||||
'%s changed project %s status from %s to %s.',
|
||||
$author_link,
|
||||
$this->linkTo($proj_phid),
|
||||
$this->renderString($old_name),
|
||||
$this->renderString($new_name));
|
||||
|
@ -64,48 +68,64 @@ final class PhabricatorFeedStoryProject extends PhabricatorFeedStory {
|
|||
|
||||
if ((count($add) == 1) && (count($rem) == 0) &&
|
||||
(head($add) == $author_phid)) {
|
||||
$action = hsprintf('joined project %s.', $this->linkTo($proj_phid));
|
||||
$action = pht(
|
||||
'% joined project %s.',
|
||||
$author_link,
|
||||
$this->linkTo($proj_phid));
|
||||
} else if ((count($add) == 0) && (count($rem) == 1) &&
|
||||
(head($rem) == $author_phid)) {
|
||||
$action = hsprintf('left project %s.', $this->linkTo($proj_phid));
|
||||
$action = pht(
|
||||
'%s left project %s.',
|
||||
$author_link,
|
||||
$this->linkTo($proj_phid));
|
||||
} else if (empty($rem)) {
|
||||
$action = hsprintf(
|
||||
'added members to project %s: %s.',
|
||||
$action = pht(
|
||||
'%s added members to project %s: %s.',
|
||||
$author_link,
|
||||
$this->linkTo($proj_phid),
|
||||
$this->renderHandleList($add));
|
||||
} else if (empty($add)) {
|
||||
$action = hsprintf(
|
||||
'removed members from project %s: %s.',
|
||||
$action = pht(
|
||||
'%s removed members from project %s: %s.',
|
||||
$author_link,
|
||||
$this->linkTo($proj_phid),
|
||||
$this->renderHandleList($rem));
|
||||
} else {
|
||||
$action = hsprintf(
|
||||
'changed members of project %s, added: %s; removed: %s.',
|
||||
$action = pht(
|
||||
'%s changed members of project %s, added: %s; removed: %s.',
|
||||
$author_link,
|
||||
$this->linkTo($proj_phid),
|
||||
$this->renderHandleList($add),
|
||||
$this->renderHandleList($rem));
|
||||
}
|
||||
break;
|
||||
case PhabricatorProjectTransactionType::TYPE_CAN_VIEW:
|
||||
$action = hsprintf(
|
||||
'changed the visibility for %s.',
|
||||
$action = pht(
|
||||
'%s changed the visibility for %s.',
|
||||
$author_link,
|
||||
$this->linkTo($proj_phid));
|
||||
break;
|
||||
case PhabricatorProjectTransactionType::TYPE_CAN_EDIT:
|
||||
$action = hsprintf(
|
||||
'changed the edit policy for %s.',
|
||||
$action = pht(
|
||||
'%s changed the edit policy for %s.',
|
||||
$author_link,
|
||||
$this->linkTo($proj_phid));
|
||||
break;
|
||||
case PhabricatorProjectTransactionType::TYPE_CAN_JOIN:
|
||||
$action = hsprintf(
|
||||
'changed the join policy for %s.',
|
||||
$action = pht(
|
||||
'%s changed the join policy for %s.',
|
||||
$author_link,
|
||||
$this->linkTo($proj_phid));
|
||||
break;
|
||||
default:
|
||||
$action = hsprintf('updated project %s.', $this->linkTo($proj_phid));
|
||||
$action = pht(
|
||||
'%s updated project %s.',
|
||||
$author_link,
|
||||
$this->linkTo($proj_phid));
|
||||
break;
|
||||
}
|
||||
$view->setTitle(hsprintf('%s %s', $this->linkTo($author_phid), $action));
|
||||
|
||||
$view->setTitle($action);
|
||||
$view->setImage($this->getHandle($author_phid)->getImageURI());
|
||||
|
||||
return $view;
|
||||
|
@ -121,7 +141,7 @@ final class PhabricatorFeedStoryProject extends PhabricatorFeedStory {
|
|||
$proj_uri = PhabricatorEnv::getURI($proj_handle->getURI());
|
||||
|
||||
$author_phid = $this->getAuthorPHID();
|
||||
$author_name = $this->getHandle($author_phid)->getLinkName();
|
||||
$author_name = $this->linkTo($author_phid);
|
||||
|
||||
switch ($type) {
|
||||
case PhabricatorProjectTransactionType::TYPE_NAME:
|
||||
|
|
|
@ -28,7 +28,7 @@ final class PhabricatorFeedStoryStatus extends PhabricatorFeedStory {
|
|||
$author_name = $author_handle->getLinkName();
|
||||
$author_uri = PhabricatorEnv::getURI($author_handle->getURI());
|
||||
|
||||
$text = pht('% supdated their status %s', $author_name, $author_uri);
|
||||
$text = pht('% updated their status %s', $author_name, $author_uri);
|
||||
|
||||
return $text;
|
||||
}
|
||||
|
|
|
@ -172,24 +172,28 @@ final class PhabricatorObjectHandle
|
|||
if ($name === null) {
|
||||
$name = $this->getLinkName();
|
||||
}
|
||||
$class = null;
|
||||
$classes = array();
|
||||
$title = $this->title;
|
||||
|
||||
if ($this->status != PhabricatorObjectHandleStatus::STATUS_OPEN) {
|
||||
$class .= ' handle-status-'.$this->status;
|
||||
$classes[] = 'handle-status-'.$this->status;
|
||||
$title = $title ? $title : $this->status;
|
||||
}
|
||||
|
||||
if ($this->disabled) {
|
||||
$class .= ' handle-disabled';
|
||||
$classes[] = 'handle-disabled';
|
||||
$title = 'disabled'; // Overwrite status.
|
||||
}
|
||||
|
||||
if ($this->getType() == PhabricatorPeoplePHIDTypeUser::TYPECONST) {
|
||||
$classes[] = 'phui-link-person';
|
||||
}
|
||||
|
||||
return phutil_tag(
|
||||
'a',
|
||||
array(
|
||||
'href' => $this->getURI(),
|
||||
'class' => $class,
|
||||
'class' => implode(' ', $classes),
|
||||
'title' => $title,
|
||||
),
|
||||
$name);
|
||||
|
|
|
@ -123,6 +123,7 @@ final class PHUIFeedStoryView extends AphrontView {
|
|||
public function render() {
|
||||
|
||||
require_celerity_resource('phui-feed-story-css');
|
||||
Javelin::initBehavior('phabricator-hovercards');
|
||||
$oneline = $this->isEmptyContent($this->renderChildren());
|
||||
|
||||
$body = null;
|
||||
|
@ -204,7 +205,7 @@ final class PHUIFeedStoryView extends AphrontView {
|
|||
'class' => 'phui-feed-story-head',
|
||||
),
|
||||
array(
|
||||
$actor,
|
||||
(!$oneline ? $actor : null),
|
||||
nonempty($this->title, pht('Untitled Story')),
|
||||
$icons,
|
||||
$ol_foot
|
||||
|
|
|
@ -19,7 +19,12 @@
|
|||
.phui-feed-story-head {
|
||||
padding: 8px;
|
||||
overflow: hidden;
|
||||
color: #555;
|
||||
}
|
||||
|
||||
.phui-feed-story-head .phui-link-person {
|
||||
color: #333;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.phui-feed-story-body {
|
||||
|
@ -99,5 +104,6 @@
|
|||
color: #777;
|
||||
margin-top: 2px;
|
||||
line-height: 14px;
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue