mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-29 18:22:41 +01:00
Add basic transaction/timeline view
Summary: This is still rough and not completely accurate to the mocks (and the mobile view is quite crude and mostly just "hey this technically works"), but I want to build Pholio on top of it rather than building it on something else and then swapping it out later and the API is reasonable enough. This should probably be called `PhabricatorTransactionView` but we already have one of those. I might juggle the names in a future diff. Test Plan: Desktop {F22352} Mobile {F22351} Reviewers: chad, btrahan Reviewed By: btrahan CC: aran Maniphest Tasks: T2097 Differential Revision: https://secure.phabricator.com/D3833
This commit is contained in:
parent
6f913b7124
commit
1d5551789d
5 changed files with 439 additions and 0 deletions
|
@ -1113,7 +1113,10 @@ phutil_register_library_map(array(
|
|||
'PhabricatorTimelineDAO' => 'infrastructure/daemon/timeline/storage/PhabricatorTimelineDAO.php',
|
||||
'PhabricatorTimelineEvent' => 'infrastructure/daemon/timeline/storage/PhabricatorTimelineEvent.php',
|
||||
'PhabricatorTimelineEventData' => 'infrastructure/daemon/timeline/storage/PhabricatorTimelineEventData.php',
|
||||
'PhabricatorTimelineEventView' => 'view/layout/PhabricatorTimelineEventView.php',
|
||||
'PhabricatorTimelineExample' => 'applications/uiexample/examples/PhabricatorTimelineExample.php',
|
||||
'PhabricatorTimelineIterator' => 'infrastructure/daemon/timeline/cursor/PhabricatorTimelineIterator.php',
|
||||
'PhabricatorTimelineView' => 'view/layout/PhabricatorTimelineView.php',
|
||||
'PhabricatorTimer' => 'applications/countdown/storage/PhabricatorTimer.php',
|
||||
'PhabricatorTransactionView' => 'view/layout/PhabricatorTransactionView.php',
|
||||
'PhabricatorTransformedFile' => 'applications/files/storage/PhabricatorTransformedFile.php',
|
||||
|
@ -2295,7 +2298,10 @@ phutil_register_library_map(array(
|
|||
'PhabricatorTimelineDAO' => 'PhabricatorLiskDAO',
|
||||
'PhabricatorTimelineEvent' => 'PhabricatorTimelineDAO',
|
||||
'PhabricatorTimelineEventData' => 'PhabricatorTimelineDAO',
|
||||
'PhabricatorTimelineEventView' => 'AphrontView',
|
||||
'PhabricatorTimelineExample' => 'PhabricatorUIExample',
|
||||
'PhabricatorTimelineIterator' => 'Iterator',
|
||||
'PhabricatorTimelineView' => 'AphrontView',
|
||||
'PhabricatorTimer' => 'PhabricatorCountdownDAO',
|
||||
'PhabricatorTransactionView' => 'AphrontView',
|
||||
'PhabricatorTransformedFile' => 'PhabricatorFileDAO',
|
||||
|
|
|
@ -0,0 +1,103 @@
|
|||
<?php
|
||||
|
||||
/*
|
||||
* Copyright 2012 Facebook, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
final class PhabricatorTimelineExample extends PhabricatorUIExample {
|
||||
|
||||
public function getName() {
|
||||
return 'Timeline View';
|
||||
}
|
||||
|
||||
public function getDescription() {
|
||||
return 'Use <tt>PhabricatorTimelineView</tt> to comments and transactions.';
|
||||
}
|
||||
|
||||
public function renderExample() {
|
||||
$request = $this->getRequest();
|
||||
$user = $request->getUser();
|
||||
|
||||
$handle = PhabricatorObjectHandleData::loadOneHandle(
|
||||
$user->getPHID(),
|
||||
$user);
|
||||
|
||||
$events = array();
|
||||
|
||||
$events[] = id(new PhabricatorTimelineEventView())
|
||||
->setUserHandle($handle)
|
||||
->setTitle('A major event.')
|
||||
->appendChild('This is a major timeline event.');
|
||||
|
||||
$events[] = id(new PhabricatorTimelineEventView())
|
||||
->setUserHandle($handle)
|
||||
->setTitle('A minor event.');
|
||||
|
||||
$events[] = id(new PhabricatorTimelineEventView())
|
||||
->setUserHandle($handle)
|
||||
->appendChild('A major event with no title.');
|
||||
|
||||
$events[] = id(new PhabricatorTimelineEventView())
|
||||
->setUserHandle($handle)
|
||||
->setTitle('Another minor event.');
|
||||
|
||||
$events[] = id(new PhabricatorTimelineEventView())
|
||||
->setUserHandle($handle);
|
||||
|
||||
$events[] = id(new PhabricatorTimelineEventView())
|
||||
->setUserHandle($handle)
|
||||
->setTitle('Major Red Event')
|
||||
->appendChild('This event is red!')
|
||||
->addClass('phabricator-timeline-red');
|
||||
|
||||
$events[] = id(new PhabricatorTimelineEventView())
|
||||
->setUserHandle($handle)
|
||||
->setTitle('Minor Red Event')
|
||||
->addClass('phabricator-timeline-red');
|
||||
|
||||
$events[] = id(new PhabricatorTimelineEventView())
|
||||
->setUserHandle($handle)
|
||||
->setTitle('Minor Not-Red Event');
|
||||
|
||||
$events[] = id(new PhabricatorTimelineEventView())
|
||||
->setUserHandle($handle)
|
||||
->setTitle('Minor Red Event')
|
||||
->addClass('phabricator-timeline-red');
|
||||
|
||||
$events[] = id(new PhabricatorTimelineEventView())
|
||||
->setUserHandle($handle)
|
||||
->setTitle('Minor Not-Red Event');
|
||||
|
||||
$events[] = id(new PhabricatorTimelineEventView())
|
||||
->setUserHandle($handle)
|
||||
->setTitle('Unstyled event')
|
||||
->appendChild('This event disables standard title and content styling.')
|
||||
->setDisableStandardTitleStyle(true)
|
||||
->setDisableStandardContentStyle(true);
|
||||
|
||||
$events[] = id(new PhabricatorTimelineEventView())
|
||||
->setUserHandle($handle)
|
||||
->setTitle('Major Green Event')
|
||||
->appendChild('This event is green!')
|
||||
->addClass('phabricator-timeline-green');
|
||||
|
||||
$timeline = id(new PhabricatorTimelineView());
|
||||
foreach ($events as $event) {
|
||||
$timeline->addEvent($event);
|
||||
}
|
||||
|
||||
return $timeline;
|
||||
}
|
||||
}
|
143
src/view/layout/PhabricatorTimelineEventView.php
Normal file
143
src/view/layout/PhabricatorTimelineEventView.php
Normal file
|
@ -0,0 +1,143 @@
|
|||
<?php
|
||||
|
||||
/*
|
||||
* Copyright 2012 Facebook, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
final class PhabricatorTimelineEventView extends AphrontView {
|
||||
|
||||
private $userHandle;
|
||||
private $title;
|
||||
private $classes = array();
|
||||
private $disableStandardTitleStyle;
|
||||
private $disableStandardContentStyle;
|
||||
|
||||
public function setUserHandle(PhabricatorObjectHandle $handle) {
|
||||
$this->userHandle = $handle;
|
||||
return $this;
|
||||
}
|
||||
|
||||
public function setTitle($title) {
|
||||
$this->title = $title;
|
||||
return $this;
|
||||
}
|
||||
|
||||
public function addClass($class) {
|
||||
$this->classes[] = $class;
|
||||
return $this;
|
||||
}
|
||||
|
||||
public function setDisableStandardTitleStyle($disable) {
|
||||
$this->disableStandardTitleStyle = $disable;
|
||||
return $this;
|
||||
}
|
||||
|
||||
public function setDisableStandardContentStyle($disable) {
|
||||
$this->disableStandardContentStyle = $disable;
|
||||
return $this;
|
||||
}
|
||||
|
||||
public function render() {
|
||||
$content = $this->renderChildren();
|
||||
|
||||
$title = $this->title;
|
||||
if (($title === null) && !strlen($content)) {
|
||||
$title = '';
|
||||
}
|
||||
|
||||
if ($title !== null) {
|
||||
$title_classes = array();
|
||||
$title_classes[] = 'phabricator-timeline-title';
|
||||
if (!$this->disableStandardTitleStyle) {
|
||||
$title_classes[] = 'phabricator-timeline-standard-title';
|
||||
}
|
||||
|
||||
$title = phutil_render_tag(
|
||||
'div',
|
||||
array(
|
||||
'class' => implode(' ', $title_classes),
|
||||
),
|
||||
$title);
|
||||
}
|
||||
|
||||
$wedge = phutil_render_tag(
|
||||
'div',
|
||||
array(
|
||||
'class' => 'phabricator-timeline-wedge phabricator-timeline-border',
|
||||
),
|
||||
'');
|
||||
|
||||
$image_uri = $this->userHandle->getImageURI();
|
||||
$image = phutil_render_tag(
|
||||
'div',
|
||||
array(
|
||||
'style' => 'background-image: url('.$image_uri.')',
|
||||
'class' => 'phabricator-timeline-image',
|
||||
),
|
||||
'');
|
||||
|
||||
$content_classes = array();
|
||||
$content_classes[] = 'phabricator-timeline-content';
|
||||
if (!$this->disableStandardContentStyle) {
|
||||
$content_classes[] = 'phabricator-timeline-standard-content';
|
||||
}
|
||||
|
||||
$classes = array();
|
||||
$classes[] = 'phabricator-timeline-event-view';
|
||||
$classes[] = 'phabricator-timeline-border';
|
||||
if ($content) {
|
||||
$classes[] = 'phabricator-timeline-major-event';
|
||||
$content = phutil_render_tag(
|
||||
'div',
|
||||
array(
|
||||
'class' => implode(' ', $content_classes),
|
||||
),
|
||||
phutil_render_tag(
|
||||
'div',
|
||||
array(
|
||||
'class' => 'phabricator-timeline-inner-content',
|
||||
),
|
||||
$title.
|
||||
phutil_render_tag(
|
||||
'div',
|
||||
array(
|
||||
'class' => 'phabricator-timeline-core-content',
|
||||
),
|
||||
$content)));
|
||||
$content = $image.$wedge.$content;
|
||||
} else {
|
||||
$classes[] = 'phabricator-timeline-minor-event';
|
||||
$content = phutil_render_tag(
|
||||
'div',
|
||||
array(
|
||||
'class' => implode(' ', $content_classes),
|
||||
),
|
||||
$image.$wedge.$title);
|
||||
}
|
||||
|
||||
return phutil_render_tag(
|
||||
'div',
|
||||
array(
|
||||
'class' => implode(' ', $this->classes),
|
||||
),
|
||||
phutil_render_tag(
|
||||
'div',
|
||||
array(
|
||||
'class' => implode(' ', $classes),
|
||||
),
|
||||
$content));
|
||||
}
|
||||
|
||||
}
|
51
src/view/layout/PhabricatorTimelineView.php
Normal file
51
src/view/layout/PhabricatorTimelineView.php
Normal file
|
@ -0,0 +1,51 @@
|
|||
<?php
|
||||
|
||||
/*
|
||||
* Copyright 2012 Facebook, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
final class PhabricatorTimelineView extends AphrontView {
|
||||
|
||||
private $events = array();
|
||||
|
||||
public function addEvent(PhabricatorTimelineEventView $event) {
|
||||
$this->events[] = $event;
|
||||
return $this;
|
||||
}
|
||||
|
||||
public function render() {
|
||||
require_celerity_resource('phabricator-timeline-view-css');
|
||||
|
||||
$events = array();
|
||||
foreach ($this->events as $event) {
|
||||
$events[] = phutil_render_tag(
|
||||
'div',
|
||||
array(
|
||||
'class' => 'phabricator-timeline-event-view '.
|
||||
'phabricator-timeline-spacer',
|
||||
),
|
||||
'');
|
||||
$events[] = $this->renderSingleView($event);
|
||||
}
|
||||
|
||||
return phutil_render_tag(
|
||||
'div',
|
||||
array(
|
||||
'class' => 'phabricator-timeline-view',
|
||||
),
|
||||
implode('', $events));
|
||||
}
|
||||
|
||||
}
|
136
webroot/rsrc/css/layout/phabricator-timeline-view.css
Normal file
136
webroot/rsrc/css/layout/phabricator-timeline-view.css
Normal file
|
@ -0,0 +1,136 @@
|
|||
/**
|
||||
* @provides phabricator-timeline-view-css
|
||||
*/
|
||||
|
||||
.phabricator-timeline-event-view {
|
||||
border-width: 0 0 0 3px;
|
||||
border-style: solid;
|
||||
border-color: #eaeaea;
|
||||
}
|
||||
|
||||
.device-desktop .phabricator-timeline-event-view {
|
||||
margin-left: 80px;
|
||||
margin-right: 12px;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.device-desktop .phabricator-timeline-spacer {
|
||||
min-height: 10px;
|
||||
border-right-width: 0;
|
||||
}
|
||||
|
||||
.device-desktop .phabricator-timeline-major-event {
|
||||
border-right-width: 3px;
|
||||
}
|
||||
|
||||
.device-desktop .phabricator-timeline-wedge {
|
||||
border-bottom: 3px solid #eaeaea;
|
||||
position: absolute;
|
||||
width: 10px;
|
||||
}
|
||||
|
||||
.device-desktop .phabricator-timeline-major-event
|
||||
.phabricator-timeline-content {
|
||||
min-height: 70px;
|
||||
}
|
||||
|
||||
.phabricator-timeline-major-event .phabricator-timeline-content {
|
||||
border-style: solid;
|
||||
border-color: #eaeaea;
|
||||
border-width: 1px 0;
|
||||
}
|
||||
|
||||
.device-desktop .phabricator-timeline-minor-event
|
||||
.phabricator-timeline-content {
|
||||
margin-left: 35px;
|
||||
padding: 5px 0;
|
||||
min-height: 25px;
|
||||
}
|
||||
|
||||
.device-desktop .phabricator-timeline-title {
|
||||
line-height: 25px;
|
||||
}
|
||||
|
||||
.device-desktop .phabricator-timeline-major-event .phabricator-timeline-wedge {
|
||||
left: -10px;
|
||||
top: 34px;
|
||||
}
|
||||
|
||||
.device-desktop .phabricator-timeline-minor-event .phabricator-timeline-wedge {
|
||||
left: 0px;
|
||||
top: 17px;
|
||||
}
|
||||
|
||||
.phabricator-timeline-image {
|
||||
background: #eaeaea;
|
||||
background-repeat: no-repeat;
|
||||
position: absolute;
|
||||
}
|
||||
|
||||
.device-desktop .phabricator-timeline-major-event .phabricator-timeline-image {
|
||||
width: 50px;
|
||||
height: 50px;
|
||||
top: 10px;
|
||||
left: -60px;
|
||||
}
|
||||
|
||||
.device-desktop .phabricator-timeline-minor-event .phabricator-timeline-image {
|
||||
width: 25px;
|
||||
height: 25px;
|
||||
background-size: 25px auto;
|
||||
top: 5px;
|
||||
left: 10px;
|
||||
}
|
||||
|
||||
.device-desktop .phabricator-timeline-major-event
|
||||
.phabricator-timeline-standard-title {
|
||||
background: #f7f7f7;
|
||||
}
|
||||
|
||||
.device-desktop .phabricator-timeline-standard-title {
|
||||
padding: 0 5px;
|
||||
}
|
||||
|
||||
.phabricator-timeline-major-event .phabricator-timeline-standard-content
|
||||
.phabricator-timeline-core-content {
|
||||
padding: 5px;
|
||||
}
|
||||
|
||||
|
||||
.phabricator-timeline-red .phabricator-timeline-border {
|
||||
border-color: #dd0000;
|
||||
}
|
||||
|
||||
.phabricator-timeline-green .phabricator-timeline-border {
|
||||
border-color: #009966;
|
||||
}
|
||||
|
||||
.device-tablet .phabricator-timeline-event-view,
|
||||
.device-phone .phabricator-timeline-event-view {
|
||||
min-height: 25px;
|
||||
position: relative;
|
||||
margin-left: 3px;
|
||||
margin-right: 3px;
|
||||
|
||||
border-right-width: 3px;
|
||||
border-right-style: solid;
|
||||
}
|
||||
|
||||
.device-tablet .phabricator-timeline-image,
|
||||
.device-phone .phabricator-timeline-image {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.device-tablet .phabricator-timeline-title,
|
||||
.device-phone .phabricator-timeline-title {
|
||||
line-height: 25px;
|
||||
min-height: 25px;
|
||||
background: #f7f7f7;
|
||||
padding: 0 5px;
|
||||
}
|
||||
|
||||
.device-tablet .phabricator-timeline-spacer,
|
||||
.device-phone .phabricator-timeline-spacer {
|
||||
min-height: 8px;
|
||||
border-width: 0;
|
||||
}
|
Loading…
Reference in a new issue