2013-01-24 17:23:05 -08:00
|
|
|
<?php
|
|
|
|
|
|
|
|
final class ConpherenceTransactionView extends AphrontView {
|
|
|
|
|
2015-04-14 11:28:33 -07:00
|
|
|
private $conpherenceThread;
|
2013-01-24 17:23:05 -08:00
|
|
|
private $conpherenceTransaction;
|
|
|
|
private $handles;
|
2013-02-06 17:53:51 -08:00
|
|
|
private $markupEngine;
|
2015-05-28 15:27:08 -07:00
|
|
|
private $fullDisplay;
|
2015-04-14 12:25:35 -07:00
|
|
|
private $classes = array();
|
|
|
|
private $timeOnly;
|
2013-02-06 17:53:51 -08:00
|
|
|
|
2015-04-14 12:25:35 -07:00
|
|
|
public function setConpherenceThread(ConpherenceThread $t) {
|
|
|
|
$this->conpherenceThread = $t;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getConpherenceThread() {
|
|
|
|
return $this->conpherenceThread;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setConpherenceTransaction(ConpherenceTransaction $tx) {
|
|
|
|
$this->conpherenceTransaction = $tx;
|
2013-02-06 17:53:51 -08:00
|
|
|
return $this;
|
|
|
|
}
|
2013-01-24 17:23:05 -08:00
|
|
|
|
2015-04-14 12:25:35 -07:00
|
|
|
private function getConpherenceTransaction() {
|
|
|
|
return $this->conpherenceTransaction;
|
|
|
|
}
|
|
|
|
|
2013-01-24 17:23:05 -08:00
|
|
|
public function setHandles(array $handles) {
|
|
|
|
assert_instances_of($handles, 'PhabricatorObjectHandle');
|
|
|
|
$this->handles = $handles;
|
|
|
|
return $this;
|
|
|
|
}
|
2014-07-10 08:12:48 +10:00
|
|
|
|
2013-01-24 17:23:05 -08:00
|
|
|
public function getHandles() {
|
|
|
|
return $this->handles;
|
|
|
|
}
|
|
|
|
|
2015-04-14 12:25:35 -07:00
|
|
|
public function setMarkupEngine(PhabricatorMarkupEngine $markup_engine) {
|
|
|
|
$this->markupEngine = $markup_engine;
|
2015-04-14 11:28:33 -07:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2015-04-14 12:25:35 -07:00
|
|
|
private function getMarkupEngine() {
|
|
|
|
return $this->markupEngine;
|
2015-04-14 11:28:33 -07:00
|
|
|
}
|
|
|
|
|
2015-05-28 15:27:08 -07:00
|
|
|
public function setFullDisplay($bool) {
|
|
|
|
$this->fullDisplay = $bool;
|
2013-01-24 17:23:05 -08:00
|
|
|
return $this;
|
|
|
|
}
|
2014-07-10 08:12:48 +10:00
|
|
|
|
2015-05-28 15:27:08 -07:00
|
|
|
private function getFullDisplay() {
|
|
|
|
return $this->fullDisplay;
|
Conpherence - make the durable column kind of work and stuff
Summary:
Ref T7014. This hooks up the durable column such that when you open it up it loads your most recent Conpherence. You can then switch amongst the various widgets and stuff and everything works nicely.
Except...
- scroll bar does not work
- also doesn't work at HEAD when I add a ton of text to the UI with no changes? (wrapped $copy in array_fill(0, 1000, $copy))
- "widget selector" does not collapse when you select something else
- this part wasn't really specified so I used the aphlict dropdown stuff. didn't want to keep working on that if this was the wrong UI choice
- can not edit title
- do we still want that to be done by clicking on the title, which pops a dialogue?
- can not add participants or calendar events
- what should this UI be? maybe just a button on the top for "participants" and a button on the bottom for calendar? both on top?
- this is not pixel perfect to the mock or two I've seen around. Aside from generally being bad at that, I definitely didn't get the name + timestamps formatting correctly, because the standard DOM of that has timestamp FIRST which appears second due to a "float right". Seemed like a lot of special-casing for what might not even be that important in the UI so I punted. (And again, there's likely many unknown ways in which this isn't pixel perfect)
There's also code quality issues
- `ConpherenceWidgetConfigConstants` is hopefully temporary or at least gets more sleek as we keep progressing here
- copied some CSS from main Conpherence app
- DOM structure is pretty different
- there's some minor CSS tweaks too given the different width (not to mention the DOM structure being different)
- copied some JS from behavior-pontificate.js to sync threads relative to aphlict updates
- JS in general is like a better version of existing JS; these should collapse I'd hope?
- maybe the aphlict-behavior-dropdown change was badsauce?
...but all that said, this definitely feels really nice and I feel like adding stuff is going to be really easy compared to how normal Conpherence is.
Also includes a bonus bug fix - we now correctly update participation. The user would encounter this issue if they were in a conpherence that got some updates and then they went to a different page; they would have unread status for the messages that were ajax'd in. This patch fixes that by making sure we mark participation up to date with the proper transaction in all cases.
Test Plan: hit "\" to invoke the column and saw nice loading UI and my latest conpherence load. sent messages and verified they received A-OK by looking in DOM console. toggled various widges and verified they rendered correctly. opened up a second browser with a second user on the thread, sent a message, and it was received in a nice asynchronous fashion
Reviewers: chad, epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7014
Differential Revision: https://secure.phabricator.com/D11968
2015-03-05 10:33:39 -08:00
|
|
|
}
|
|
|
|
|
2015-04-14 12:25:35 -07:00
|
|
|
public function addClass($class) {
|
|
|
|
$this->classes[] = $class;
|
Conpherence - make the durable column kind of work and stuff
Summary:
Ref T7014. This hooks up the durable column such that when you open it up it loads your most recent Conpherence. You can then switch amongst the various widgets and stuff and everything works nicely.
Except...
- scroll bar does not work
- also doesn't work at HEAD when I add a ton of text to the UI with no changes? (wrapped $copy in array_fill(0, 1000, $copy))
- "widget selector" does not collapse when you select something else
- this part wasn't really specified so I used the aphlict dropdown stuff. didn't want to keep working on that if this was the wrong UI choice
- can not edit title
- do we still want that to be done by clicking on the title, which pops a dialogue?
- can not add participants or calendar events
- what should this UI be? maybe just a button on the top for "participants" and a button on the bottom for calendar? both on top?
- this is not pixel perfect to the mock or two I've seen around. Aside from generally being bad at that, I definitely didn't get the name + timestamps formatting correctly, because the standard DOM of that has timestamp FIRST which appears second due to a "float right". Seemed like a lot of special-casing for what might not even be that important in the UI so I punted. (And again, there's likely many unknown ways in which this isn't pixel perfect)
There's also code quality issues
- `ConpherenceWidgetConfigConstants` is hopefully temporary or at least gets more sleek as we keep progressing here
- copied some CSS from main Conpherence app
- DOM structure is pretty different
- there's some minor CSS tweaks too given the different width (not to mention the DOM structure being different)
- copied some JS from behavior-pontificate.js to sync threads relative to aphlict updates
- JS in general is like a better version of existing JS; these should collapse I'd hope?
- maybe the aphlict-behavior-dropdown change was badsauce?
...but all that said, this definitely feels really nice and I feel like adding stuff is going to be really easy compared to how normal Conpherence is.
Also includes a bonus bug fix - we now correctly update participation. The user would encounter this issue if they were in a conpherence that got some updates and then they went to a different page; they would have unread status for the messages that were ajax'd in. This patch fixes that by making sure we mark participation up to date with the proper transaction in all cases.
Test Plan: hit "\" to invoke the column and saw nice loading UI and my latest conpherence load. sent messages and verified they received A-OK by looking in DOM console. toggled various widges and verified they rendered correctly. opened up a second browser with a second user on the thread, sent a message, and it was received in a nice asynchronous fashion
Reviewers: chad, epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7014
Differential Revision: https://secure.phabricator.com/D11968
2015-03-05 10:33:39 -08:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2013-01-24 17:23:05 -08:00
|
|
|
public function render() {
|
2015-05-28 15:27:08 -07:00
|
|
|
$viewer = $this->getUser();
|
|
|
|
if (!$viewer) {
|
2015-06-18 07:06:37 +10:00
|
|
|
throw new PhutilInvalidStateException('setUser');
|
2015-04-14 12:25:35 -07:00
|
|
|
}
|
|
|
|
|
2015-04-14 12:33:02 -07:00
|
|
|
require_celerity_resource('conpherence-transaction-css');
|
2015-04-14 11:28:33 -07:00
|
|
|
|
2013-01-24 17:23:05 -08:00
|
|
|
$transaction = $this->getConpherenceTransaction();
|
2013-05-30 14:24:50 -07:00
|
|
|
switch ($transaction->getTransactionType()) {
|
2015-06-08 09:54:53 +10:00
|
|
|
case ConpherenceTransaction::TYPE_DATE_MARKER:
|
2015-05-13 11:06:54 -07:00
|
|
|
return javelin_tag(
|
2013-05-30 14:24:50 -07:00
|
|
|
'div',
|
|
|
|
array(
|
2015-04-14 12:33:02 -07:00
|
|
|
'class' => 'conpherence-transaction-view date-marker',
|
2015-05-13 11:06:54 -07:00
|
|
|
'sigil' => 'conpherence-transaction-view',
|
|
|
|
'meta' => array(
|
|
|
|
'id' => $transaction->getID() + 0.5,
|
|
|
|
),
|
2013-05-30 14:24:50 -07:00
|
|
|
),
|
|
|
|
array(
|
|
|
|
phutil_tag(
|
|
|
|
'span',
|
|
|
|
array(
|
|
|
|
'class' => 'date',
|
|
|
|
),
|
|
|
|
phabricator_format_local_time(
|
|
|
|
$transaction->getDateCreated(),
|
2015-05-28 15:27:08 -07:00
|
|
|
$viewer,
|
2014-10-08 00:01:04 +11:00
|
|
|
'M jS, Y')),
|
|
|
|
));
|
2013-05-30 14:24:50 -07:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2015-04-14 12:25:35 -07:00
|
|
|
$info = $this->renderTransactionInfo();
|
|
|
|
$actions = $this->renderTransactionActions();
|
|
|
|
$image = $this->renderTransactionImage();
|
|
|
|
$content = $this->renderTransactionContent();
|
|
|
|
$classes = implode(' ', $this->classes);
|
|
|
|
|
2015-05-28 15:27:08 -07:00
|
|
|
$transaction_dom_id = null;
|
|
|
|
if ($this->getFullDisplay()) {
|
|
|
|
$transaction_dom_id = 'anchor-'.$transaction->getID();
|
|
|
|
}
|
2015-04-14 12:25:35 -07:00
|
|
|
|
|
|
|
$header = phutil_tag_div(
|
2015-04-14 12:33:02 -07:00
|
|
|
'conpherence-transaction-header grouped',
|
2015-04-14 12:25:35 -07:00
|
|
|
array($actions, $info));
|
|
|
|
|
2015-05-13 11:06:54 -07:00
|
|
|
return javelin_tag(
|
2015-04-14 12:25:35 -07:00
|
|
|
'div',
|
|
|
|
array(
|
2015-04-14 12:33:02 -07:00
|
|
|
'class' => 'conpherence-transaction-view '.$classes,
|
2015-05-28 15:27:08 -07:00
|
|
|
'id' => $transaction_dom_id,
|
2015-05-13 11:06:54 -07:00
|
|
|
'sigil' => 'conpherence-transaction-view',
|
|
|
|
'meta' => array(
|
|
|
|
'id' => $transaction->getID(),
|
|
|
|
),
|
2015-04-14 12:25:35 -07:00
|
|
|
),
|
|
|
|
array(
|
|
|
|
$image,
|
2015-04-14 12:33:02 -07:00
|
|
|
phutil_tag_div('conpherence-transaction-detail grouped',
|
2015-04-14 12:25:35 -07:00
|
|
|
array($header, $content)),
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
private function renderTransactionInfo() {
|
2015-05-28 15:27:08 -07:00
|
|
|
$viewer = $this->getUser();
|
|
|
|
$thread = $this->getConpherenceThread();
|
|
|
|
$transaction = $this->getConpherenceTransaction();
|
2015-04-14 12:25:35 -07:00
|
|
|
$info = array();
|
|
|
|
|
2015-05-28 15:27:08 -07:00
|
|
|
Javelin::initBehavior('phabricator-tooltips');
|
|
|
|
$tip = phabricator_datetime($transaction->getDateCreated(), $viewer);
|
|
|
|
$label = phabricator_time($transaction->getDateCreated(), $viewer);
|
|
|
|
$width = 360;
|
|
|
|
if ($this->getFullDisplay()) {
|
2015-04-14 12:25:35 -07:00
|
|
|
Javelin::initBehavior('phabricator-watch-anchor');
|
|
|
|
$anchor = id(new PhabricatorAnchorView())
|
2015-05-28 15:27:08 -07:00
|
|
|
->setAnchorName($transaction->getID())
|
2015-04-14 12:25:35 -07:00
|
|
|
->render();
|
|
|
|
|
|
|
|
$info[] = hsprintf(
|
|
|
|
'%s%s',
|
|
|
|
$anchor,
|
2015-05-28 15:27:08 -07:00
|
|
|
javelin_tag(
|
2015-04-14 12:25:35 -07:00
|
|
|
'a',
|
|
|
|
array(
|
2015-05-28 15:27:08 -07:00
|
|
|
'href' => '#'.$transaction->getID(),
|
2015-04-14 12:25:35 -07:00
|
|
|
'class' => 'anchor-link',
|
2015-05-28 15:27:08 -07:00
|
|
|
'sigil' => 'has-tooltip',
|
|
|
|
'meta' => array(
|
|
|
|
'tip' => $tip,
|
|
|
|
'size' => $width,
|
|
|
|
),
|
2015-04-14 12:25:35 -07:00
|
|
|
),
|
2015-05-28 15:27:08 -07:00
|
|
|
$label));
|
|
|
|
} else {
|
|
|
|
$href = '/'.$thread->getMonogram().'#'.$transaction->getID();
|
|
|
|
$info[] = javelin_tag(
|
|
|
|
'a',
|
|
|
|
array(
|
|
|
|
'href' => $href,
|
|
|
|
'class' => 'epoch-link',
|
|
|
|
'sigil' => 'has-tooltip',
|
|
|
|
'meta' => array(
|
|
|
|
'tip' => $tip,
|
|
|
|
'size' => $width,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
$label);
|
2015-04-14 12:25:35 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
return phutil_tag(
|
|
|
|
'span',
|
|
|
|
array(
|
2015-04-14 12:33:02 -07:00
|
|
|
'class' => 'conpherence-transaction-info',
|
2015-04-14 12:25:35 -07:00
|
|
|
),
|
|
|
|
$info);
|
|
|
|
}
|
|
|
|
|
|
|
|
private function renderTransactionActions() {
|
|
|
|
$transaction = $this->getConpherenceTransaction();
|
|
|
|
|
|
|
|
switch ($transaction->getTransactionType()) {
|
|
|
|
case PhabricatorTransactions::TYPE_COMMENT:
|
|
|
|
$handles = $this->getHandles();
|
|
|
|
$author = $handles[$transaction->getAuthorPHID()];
|
|
|
|
$actions = array($author->renderLink());
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
$actions = null;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $actions;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function renderTransactionImage() {
|
|
|
|
$image = null;
|
2016-09-29 23:28:28 +00:00
|
|
|
$transaction = $this->getConpherenceTransaction();
|
|
|
|
switch ($transaction->getTransactionType()) {
|
|
|
|
case PhabricatorTransactions::TYPE_COMMENT:
|
|
|
|
$handles = $this->getHandles();
|
|
|
|
$author = $handles[$transaction->getAuthorPHID()];
|
|
|
|
$image_uri = $author->getImageURI();
|
|
|
|
$image = phutil_tag(
|
|
|
|
'span',
|
|
|
|
array(
|
|
|
|
'class' => 'conpherence-transaction-image',
|
|
|
|
'style' => 'background-image: url('.$image_uri.');',
|
|
|
|
));
|
|
|
|
break;
|
Conpherence - make the durable column kind of work and stuff
Summary:
Ref T7014. This hooks up the durable column such that when you open it up it loads your most recent Conpherence. You can then switch amongst the various widgets and stuff and everything works nicely.
Except...
- scroll bar does not work
- also doesn't work at HEAD when I add a ton of text to the UI with no changes? (wrapped $copy in array_fill(0, 1000, $copy))
- "widget selector" does not collapse when you select something else
- this part wasn't really specified so I used the aphlict dropdown stuff. didn't want to keep working on that if this was the wrong UI choice
- can not edit title
- do we still want that to be done by clicking on the title, which pops a dialogue?
- can not add participants or calendar events
- what should this UI be? maybe just a button on the top for "participants" and a button on the bottom for calendar? both on top?
- this is not pixel perfect to the mock or two I've seen around. Aside from generally being bad at that, I definitely didn't get the name + timestamps formatting correctly, because the standard DOM of that has timestamp FIRST which appears second due to a "float right". Seemed like a lot of special-casing for what might not even be that important in the UI so I punted. (And again, there's likely many unknown ways in which this isn't pixel perfect)
There's also code quality issues
- `ConpherenceWidgetConfigConstants` is hopefully temporary or at least gets more sleek as we keep progressing here
- copied some CSS from main Conpherence app
- DOM structure is pretty different
- there's some minor CSS tweaks too given the different width (not to mention the DOM structure being different)
- copied some JS from behavior-pontificate.js to sync threads relative to aphlict updates
- JS in general is like a better version of existing JS; these should collapse I'd hope?
- maybe the aphlict-behavior-dropdown change was badsauce?
...but all that said, this definitely feels really nice and I feel like adding stuff is going to be really easy compared to how normal Conpherence is.
Also includes a bonus bug fix - we now correctly update participation. The user would encounter this issue if they were in a conpherence that got some updates and then they went to a different page; they would have unread status for the messages that were ajax'd in. This patch fixes that by making sure we mark participation up to date with the proper transaction in all cases.
Test Plan: hit "\" to invoke the column and saw nice loading UI and my latest conpherence load. sent messages and verified they received A-OK by looking in DOM console. toggled various widges and verified they rendered correctly. opened up a second browser with a second user on the thread, sent a message, and it was received in a nice asynchronous fashion
Reviewers: chad, epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7014
Differential Revision: https://secure.phabricator.com/D11968
2015-03-05 10:33:39 -08:00
|
|
|
}
|
2015-04-14 12:25:35 -07:00
|
|
|
return $image;
|
|
|
|
}
|
2013-01-24 17:23:05 -08:00
|
|
|
|
2015-04-14 12:25:35 -07:00
|
|
|
private function renderTransactionContent() {
|
|
|
|
$transaction = $this->getConpherenceTransaction();
|
Fix every HTML issue I could find
Summary:
I attempted to test every interface. I probably missed some stuff, but I at least have some level of confidence that the `phutil_tag` branch is fairly stable.
Fixed these issues:
[1] Fixed a Herald issue with object links in transcripts. Some actions return
links; this was previously hard-coded.
[2] DarkConsole refactoring created an issue where the "`" event handler registered too many times.
[3] Fixed a bug where `strlen($value)` was being checked, but fields may now return array(). Possibly we should implement phutil_is_empty_html() or similar.
[4] Fixed a undefined variable issue for image edit transactions.
[5] Fixed an issue with rendering participant transactions. This required phutil_safe_html() because `pht()` can't handle `array()` for `%s`.
[6] Fixed an issue where feed was entirely overescaped by reverting an overly ambitious render_tag -> tag.
[7] Fixed an issue with strict tables and inserting `''` instead of `0` into an integer column.
[8] Fixed an issue where • was shown escaped.
[9] Fixed an issue where "no data" was overescaped.
[10] Fixed an issue with strict tables and inserting `''` instead of `0` into an integer column.
[11] Fixed an issue with strict tables and inserting `''`.
[12] Fixed an issue with missing space after ":" for mini panels.
Encountered (but did not fix) these issues:
[X1] "e" works incorrectly on comments you are not allowed to edit. Did not fix.
[X2] Coverage currently interacts incorrectly with "--everything" for Phutil tests.
Test Plan:
- Viewed Differential.
- Created a diff via copy/paste.
- Viewed standalone diff.
- Jumped to diff via changeset table.
- Created a revision.
- Updated revision.
- Added a comment.
- Edited revision dependencies.
- Edited revision tasks.
- Viewed MetaMTA transcripts.
- Viewed Herald transcripts [1].
- Downloaded raw diff.
- Flagged / unflagged revision.
- Added/edited/deleted inline comment.
- Collapsed/expanded file.
- Did show raw left.
- Did show raw right.
- Checked previews for available actions.
- Clicked remarkup buttons
- Used filetree view.
- Used keyboard: F, j, k, J, K, n, p, t, h, "?" [2] [X1].
- Created a meme.
- Uploaded a file via drag and drop.
- Viewed a revision with no reviewers.
- Viewed a revision with >100 files.
- Viewed various other revisions [3].
- Viewed an image diff.
- Added image diff inline comments.
- Viewed Maniphest.
- Ran various queries.
- Created task.
- Created similar task.
- Added comments to tasks.
- Ran custom query.
- Saved custom query.
- Edited custom queries.
- Drag-reordered tasks.
- Batch edited tasks.
- Exported tasks to excel.
- Looked at reports (issue in T2311 notwithstanding).
- Viewed Diffusion.
- Browsed Git, SVN, HG repositories.
- Looked at history, browse, change, commit views.
- Viewed audit.
- Performed various audit searches.
- Viewed Paste.
- Performed paste searches.
- Created, edited, forked paste.
- Viewed Phriction.
- Edited a page.
- Viewed edit history.
- Used search typeahead to search for user / application.
- Used search to search for text.
- Viewed Phame.
- Viewed Blog, Post.
- Viewed live post.
- Published/unpublished post.
- Previewed post.
- Viewed Pholio.
- Edited/commented mock.
- Viewed ponder.
- Viewed question.
- Added answer/comment.
- Viewed Diviner.
- Viewed Conpherence [4] [5].
- Made Conpherence updates.
- Viewed calendar.
- Created status.
- Viewed status.
- Viewed Feed [6].
- Viewed Projects.
- Viewed project detail.
- Edited project.
- Viewed Owners.
- Viewed package detail.
- Edited package [7].
- Viewed flags.
- Edited flag.
- Deleted flag.
- Viewed Herald.
- Viewed rules.
- Created rule.
- Edited rule.
- Viewed edit log.
- Viewed transcripts.
- Inspected a transcript.
- Viewed People.
- Viewed list.
- Administrated user.
- Checked username/delete stuff.
- Looked at create/import LDAP/activity logs.
- Looked at a user profile.
- Looked at user about page.
- Looked at Repositories.
- Edited repository.
- Edited arcanist project.
- Looked at daemons.
- Looked at all daemons [8].
- Viewed combined log.
- Looked at configuration.
- Edited configuration.
- Looked at setup issues [9].
- Looked at current settings.
- Looked at application list.
- Installed / uninstalled applications [10].
- Looked at mailing lists.
- Created a mailing list.
- Edited a mailing list.
- Looked at sent mail.
- Looked at received mail.
- Looked at send/receive tests.
- Looked at settings.
- Clicked through all the panels.
- Looked at slowvote.
- Created a slowvote [11].
- Voted in a slowvote.
- Looked at Macro.
- Created a macro.
- Edited a macro.
- Commented on a macro.
- Looked at Countdown.
- Created a Countdown.
- Looked at it.
- Looked at Drydock.
- Poked around a bit.
- Looked at Fact.
- Poked around a bit.
- Looked at files.
- Looked at a file.
- Uploaded a file.
- Looked at Conduit.
- Made a Conduit call.
- Looked at UIExamples.
- Looked at PHPAST.
- Looked at PHIDs.
- Looked at notification menu.
- Looked at notification detail.
- Logged out.
- Logged in.
- Looked at homepage [12].
- Ran `arc unit --everything --no-coverage` [X2].
Reviewers: vrana, btrahan
Reviewed By: vrana
CC: aran
Maniphest Tasks: T2432
Differential Revision: https://secure.phabricator.com/D4807
2013-02-04 17:06:34 -08:00
|
|
|
$content = null;
|
2013-01-24 17:23:05 -08:00
|
|
|
$content_class = null;
|
2013-02-06 17:53:51 -08:00
|
|
|
$content = null;
|
2015-04-14 12:25:35 -07:00
|
|
|
$handles = $this->getHandles();
|
2013-01-24 17:23:05 -08:00
|
|
|
switch ($transaction->getTransactionType()) {
|
2015-06-08 09:54:53 +10:00
|
|
|
case ConpherenceTransaction::TYPE_TITLE:
|
2016-09-14 18:34:11 -07:00
|
|
|
case ConpherenceTransaction::TYPE_TOPIC:
|
2015-06-08 09:54:53 +10:00
|
|
|
case ConpherenceTransaction::TYPE_PICTURE:
|
|
|
|
case ConpherenceTransaction::TYPE_PICTURE_CROP:
|
|
|
|
case ConpherenceTransaction::TYPE_PARTICIPANTS:
|
2015-03-24 13:04:33 -07:00
|
|
|
case PhabricatorTransactions::TYPE_VIEW_POLICY:
|
|
|
|
case PhabricatorTransactions::TYPE_EDIT_POLICY:
|
|
|
|
case PhabricatorTransactions::TYPE_JOIN_POLICY:
|
2015-04-13 18:12:48 -07:00
|
|
|
case PhabricatorTransactions::TYPE_EDGE:
|
2013-01-24 17:23:05 -08:00
|
|
|
$content = $transaction->getTitle();
|
2015-04-14 12:25:35 -07:00
|
|
|
$this->addClass('conpherence-edited');
|
2013-01-24 17:23:05 -08:00
|
|
|
break;
|
|
|
|
case PhabricatorTransactions::TYPE_COMMENT:
|
2015-04-14 12:25:35 -07:00
|
|
|
$this->addClass('conpherence-comment');
|
|
|
|
$author = $handles[$transaction->getAuthorPHID()];
|
2013-01-24 17:23:05 -08:00
|
|
|
$comment = $transaction->getComment();
|
2015-04-14 12:25:35 -07:00
|
|
|
$content = $this->getMarkupEngine()->getOutput(
|
2013-01-24 17:23:05 -08:00
|
|
|
$comment,
|
2013-02-06 17:53:51 -08:00
|
|
|
PhabricatorApplicationTransactionComment::MARKUP_FIELD_COMMENT);
|
2015-04-14 12:33:02 -07:00
|
|
|
$content_class = 'conpherence-message';
|
2015-05-28 15:27:08 -07:00
|
|
|
break;
|
2013-01-24 17:23:05 -08:00
|
|
|
}
|
|
|
|
|
2015-04-14 12:25:35 -07:00
|
|
|
$this->appendChild(
|
2013-03-09 13:52:41 -08:00
|
|
|
phutil_tag(
|
2013-01-24 17:23:05 -08:00
|
|
|
'div',
|
|
|
|
array(
|
2014-10-08 00:01:04 +11:00
|
|
|
'class' => $content_class,
|
2013-01-24 17:23:05 -08:00
|
|
|
),
|
2013-03-09 13:52:41 -08:00
|
|
|
$content));
|
2013-01-24 17:23:05 -08:00
|
|
|
|
2015-04-14 12:25:35 -07:00
|
|
|
return phutil_tag_div(
|
2015-04-14 12:33:02 -07:00
|
|
|
'conpherence-transaction-content',
|
2015-04-14 12:25:35 -07:00
|
|
|
$this->renderChildren());
|
Conpherence - make the durable column kind of work and stuff
Summary:
Ref T7014. This hooks up the durable column such that when you open it up it loads your most recent Conpherence. You can then switch amongst the various widgets and stuff and everything works nicely.
Except...
- scroll bar does not work
- also doesn't work at HEAD when I add a ton of text to the UI with no changes? (wrapped $copy in array_fill(0, 1000, $copy))
- "widget selector" does not collapse when you select something else
- this part wasn't really specified so I used the aphlict dropdown stuff. didn't want to keep working on that if this was the wrong UI choice
- can not edit title
- do we still want that to be done by clicking on the title, which pops a dialogue?
- can not add participants or calendar events
- what should this UI be? maybe just a button on the top for "participants" and a button on the bottom for calendar? both on top?
- this is not pixel perfect to the mock or two I've seen around. Aside from generally being bad at that, I definitely didn't get the name + timestamps formatting correctly, because the standard DOM of that has timestamp FIRST which appears second due to a "float right". Seemed like a lot of special-casing for what might not even be that important in the UI so I punted. (And again, there's likely many unknown ways in which this isn't pixel perfect)
There's also code quality issues
- `ConpherenceWidgetConfigConstants` is hopefully temporary or at least gets more sleek as we keep progressing here
- copied some CSS from main Conpherence app
- DOM structure is pretty different
- there's some minor CSS tweaks too given the different width (not to mention the DOM structure being different)
- copied some JS from behavior-pontificate.js to sync threads relative to aphlict updates
- JS in general is like a better version of existing JS; these should collapse I'd hope?
- maybe the aphlict-behavior-dropdown change was badsauce?
...but all that said, this definitely feels really nice and I feel like adding stuff is going to be really easy compared to how normal Conpherence is.
Also includes a bonus bug fix - we now correctly update participation. The user would encounter this issue if they were in a conpherence that got some updates and then they went to a different page; they would have unread status for the messages that were ajax'd in. This patch fixes that by making sure we mark participation up to date with the proper transaction in all cases.
Test Plan: hit "\" to invoke the column and saw nice loading UI and my latest conpherence load. sent messages and verified they received A-OK by looking in DOM console. toggled various widges and verified they rendered correctly. opened up a second browser with a second user on the thread, sent a message, and it was received in a nice asynchronous fashion
Reviewers: chad, epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7014
Differential Revision: https://secure.phabricator.com/D11968
2015-03-05 10:33:39 -08:00
|
|
|
}
|
|
|
|
|
2013-01-24 17:23:05 -08:00
|
|
|
}
|