mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-23 07:12:41 +01:00
Use a "pinboard" UI to display image macros
Summary: Moves toward unblocking D3547. Use a pinboard/album view to show image macros. Modernize and make (mostly) responsive. Test Plan: Will attach screenshots. Reviewers: btrahan, vrana, chad, teisenbe Reviewed By: vrana CC: aran Maniphest Tasks: T175 Differential Revision: https://secure.phabricator.com/D3576
This commit is contained in:
parent
f1cd22716a
commit
faa50c5d93
5 changed files with 244 additions and 68 deletions
|
@ -920,6 +920,8 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorPeopleLogsController' => 'applications/people/controller/PhabricatorPeopleLogsController.php',
|
'PhabricatorPeopleLogsController' => 'applications/people/controller/PhabricatorPeopleLogsController.php',
|
||||||
'PhabricatorPeopleProfileController' => 'applications/people/controller/PhabricatorPeopleProfileController.php',
|
'PhabricatorPeopleProfileController' => 'applications/people/controller/PhabricatorPeopleProfileController.php',
|
||||||
'PhabricatorPeopleQuery' => 'applications/people/PhabricatorPeopleQuery.php',
|
'PhabricatorPeopleQuery' => 'applications/people/PhabricatorPeopleQuery.php',
|
||||||
|
'PhabricatorPinboardItemView' => 'view/layout/PhabricatorPinboardItemView.php',
|
||||||
|
'PhabricatorPinboardView' => 'view/layout/PhabricatorPinboardView.php',
|
||||||
'PhabricatorPolicies' => 'applications/policy/constants/PhabricatorPolicies.php',
|
'PhabricatorPolicies' => 'applications/policy/constants/PhabricatorPolicies.php',
|
||||||
'PhabricatorPolicy' => 'applications/policy/filter/PhabricatorPolicy.php',
|
'PhabricatorPolicy' => 'applications/policy/filter/PhabricatorPolicy.php',
|
||||||
'PhabricatorPolicyAwareQuery' => 'infrastructure/query/policy/PhabricatorPolicyAwareQuery.php',
|
'PhabricatorPolicyAwareQuery' => 'infrastructure/query/policy/PhabricatorPolicyAwareQuery.php',
|
||||||
|
@ -2049,6 +2051,8 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorPeopleLogsController' => 'PhabricatorPeopleController',
|
'PhabricatorPeopleLogsController' => 'PhabricatorPeopleController',
|
||||||
'PhabricatorPeopleProfileController' => 'PhabricatorPeopleController',
|
'PhabricatorPeopleProfileController' => 'PhabricatorPeopleController',
|
||||||
'PhabricatorPeopleQuery' => 'PhabricatorOffsetPagedQuery',
|
'PhabricatorPeopleQuery' => 'PhabricatorOffsetPagedQuery',
|
||||||
|
'PhabricatorPinboardItemView' => 'AphrontView',
|
||||||
|
'PhabricatorPinboardView' => 'AphrontView',
|
||||||
'PhabricatorPolicies' => 'PhabricatorPolicyConstants',
|
'PhabricatorPolicies' => 'PhabricatorPolicyConstants',
|
||||||
'PhabricatorPolicyAwareQuery' => 'PhabricatorOffsetPagedQuery',
|
'PhabricatorPolicyAwareQuery' => 'PhabricatorOffsetPagedQuery',
|
||||||
'PhabricatorPolicyAwareTestQuery' => 'PhabricatorPolicyAwareQuery',
|
'PhabricatorPolicyAwareTestQuery' => 'PhabricatorPolicyAwareQuery',
|
||||||
|
|
|
@ -22,12 +22,19 @@ final class PhabricatorMacroListController
|
||||||
public function processRequest() {
|
public function processRequest() {
|
||||||
|
|
||||||
$request = $this->getRequest();
|
$request = $this->getRequest();
|
||||||
|
$viewer = $request->getUser();
|
||||||
|
|
||||||
$macro_table = new PhabricatorFileImageMacro();
|
$macro_table = new PhabricatorFileImageMacro();
|
||||||
if ($request->getStr('name') !== null) {
|
|
||||||
|
$filter = $request->getStr('name');
|
||||||
|
if (strlen($filter)) {
|
||||||
$macros = $macro_table->loadAllWhere(
|
$macros = $macro_table->loadAllWhere(
|
||||||
'name LIKE %~',
|
'name LIKE %~',
|
||||||
$request->getStr('name'));
|
$filter);
|
||||||
|
|
||||||
|
$nodata = pht(
|
||||||
|
'There are no macros matching the filter "%s".',
|
||||||
|
phutil_escape_html($filter));
|
||||||
} else {
|
} else {
|
||||||
$pager = new AphrontPagerView();
|
$pager = new AphrontPagerView();
|
||||||
$pager->setOffset($request->getInt('page'));
|
$pager->setOffset($request->getInt('page'));
|
||||||
|
@ -47,6 +54,8 @@ final class PhabricatorMacroListController
|
||||||
|
|
||||||
$pager->setCount($count);
|
$pager->setCount($count);
|
||||||
$pager->setURI($request->getRequestURI(), 'page');
|
$pager->setURI($request->getRequestURI(), 'page');
|
||||||
|
|
||||||
|
$nodata = pht('There are no image macros yet.');
|
||||||
}
|
}
|
||||||
|
|
||||||
$file_phids = mpull($macros, 'getFilePHID');
|
$file_phids = mpull($macros, 'getFilePHID');
|
||||||
|
@ -57,66 +66,11 @@ final class PhabricatorMacroListController
|
||||||
"phid IN (%Ls)",
|
"phid IN (%Ls)",
|
||||||
$file_phids);
|
$file_phids);
|
||||||
$author_phids = mpull($files, 'getAuthorPHID', 'getPHID');
|
$author_phids = mpull($files, 'getAuthorPHID', 'getPHID');
|
||||||
$handles = $this->loadViewerHandles($author_phids);
|
|
||||||
|
$this->loadHandles($author_phids);
|
||||||
}
|
}
|
||||||
$files_map = mpull($files, null, 'getPHID');
|
$files_map = mpull($files, null, 'getPHID');
|
||||||
|
|
||||||
$rows = array();
|
|
||||||
foreach ($macros as $macro) {
|
|
||||||
$file_phid = $macro->getFilePHID();
|
|
||||||
$file = idx($files_map, $file_phid);
|
|
||||||
|
|
||||||
$author_link = isset($author_phids[$file_phid])
|
|
||||||
? $handles[$author_phids[$file_phid]]->renderLink()
|
|
||||||
: null;
|
|
||||||
|
|
||||||
$rows[] = array(
|
|
||||||
phutil_render_tag(
|
|
||||||
'a',
|
|
||||||
array(
|
|
||||||
'href' => $this->getApplicationURI('/edit/'.$macro->getID().'/'),
|
|
||||||
),
|
|
||||||
phutil_escape_html($macro->getName())),
|
|
||||||
|
|
||||||
$author_link,
|
|
||||||
phutil_render_tag(
|
|
||||||
'a',
|
|
||||||
array(
|
|
||||||
'href' => $file ? $file->getBestURI() : null,
|
|
||||||
'target' => '_blank',
|
|
||||||
),
|
|
||||||
phutil_render_tag(
|
|
||||||
'img',
|
|
||||||
array(
|
|
||||||
'src' => $file ? $file->getBestURI() : null,
|
|
||||||
))),
|
|
||||||
javelin_render_tag(
|
|
||||||
'a',
|
|
||||||
array(
|
|
||||||
'href' => $this->getApplicationURI('/delete/'.$macro->getID().'/'),
|
|
||||||
'sigil' => 'workflow',
|
|
||||||
'class' => 'grey small button',
|
|
||||||
),
|
|
||||||
'Delete'),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
$table = new AphrontTableView($rows);
|
|
||||||
$table->setHeaders(
|
|
||||||
array(
|
|
||||||
'Name',
|
|
||||||
'Author',
|
|
||||||
'Image',
|
|
||||||
'',
|
|
||||||
));
|
|
||||||
$table->setColumnClasses(
|
|
||||||
array(
|
|
||||||
'pri',
|
|
||||||
'',
|
|
||||||
'wide thumb',
|
|
||||||
'action',
|
|
||||||
));
|
|
||||||
|
|
||||||
$filter_form = id(new AphrontFormView())
|
$filter_form = id(new AphrontFormView())
|
||||||
->setMethod('GET')
|
->setMethod('GET')
|
||||||
->setUser($request->getUser())
|
->setUser($request->getUser())
|
||||||
|
@ -124,7 +78,7 @@ final class PhabricatorMacroListController
|
||||||
id(new AphrontFormTextControl())
|
id(new AphrontFormTextControl())
|
||||||
->setName('name')
|
->setName('name')
|
||||||
->setLabel('Name')
|
->setLabel('Name')
|
||||||
->setValue($request->getStr('name')))
|
->setValue($filter))
|
||||||
->appendChild(
|
->appendChild(
|
||||||
id(new AphrontFormSubmitControl())
|
id(new AphrontFormSubmitControl())
|
||||||
->setValue('Filter Image Macros'));
|
->setValue('Filter Image Macros'));
|
||||||
|
@ -132,22 +86,55 @@ final class PhabricatorMacroListController
|
||||||
$filter_view = new AphrontListFilterView();
|
$filter_view = new AphrontListFilterView();
|
||||||
$filter_view->appendChild($filter_form);
|
$filter_view->appendChild($filter_form);
|
||||||
|
|
||||||
$panel = new AphrontPanelView();
|
|
||||||
$panel->appendChild($table);
|
|
||||||
$panel->setHeader('Image Macros');
|
|
||||||
if ($request->getStr('name') === null) {
|
|
||||||
$panel->appendChild($pager);
|
|
||||||
}
|
|
||||||
|
|
||||||
$nav = $this->buildSideNavView();
|
$nav = $this->buildSideNavView();
|
||||||
$nav->selectFilter('/');
|
$nav->selectFilter('/');
|
||||||
|
|
||||||
$nav->appendChild($filter_view);
|
$nav->appendChild($filter_view);
|
||||||
$nav->appendChild($panel);
|
|
||||||
|
|
||||||
|
if ($macros) {
|
||||||
|
$pinboard = new PhabricatorPinboardView();
|
||||||
|
foreach ($macros as $macro) {
|
||||||
|
$file_phid = $macro->getFilePHID();
|
||||||
|
$file = idx($files_map, $file_phid);
|
||||||
|
|
||||||
|
$item = new PhabricatorPinboardItemView();
|
||||||
|
$item->setImageURI($file->getThumb160x120URI());
|
||||||
|
$item->setImageSize(160, 120);
|
||||||
|
$item->setURI($this->getApplicationURI('/edit/'.$macro->getID().'/'));
|
||||||
|
$item->setHeader($macro->getName());
|
||||||
|
|
||||||
|
if ($file->getAuthorPHID()) {
|
||||||
|
$author_handle = $this->getHandle($file->getAuthorPHID());
|
||||||
|
$item->appendChild(
|
||||||
|
'Created by '.$author_handle->renderLink());
|
||||||
|
}
|
||||||
|
|
||||||
|
$datetime = phabricator_date($file->getDateCreated(), $viewer);
|
||||||
|
$item->appendChild(
|
||||||
|
phutil_render_tag(
|
||||||
|
'div',
|
||||||
|
array(),
|
||||||
|
'Created on '.$datetime));
|
||||||
|
|
||||||
|
$pinboard->addItem($item);
|
||||||
|
}
|
||||||
|
$nav->appendChild($pinboard);
|
||||||
|
} else {
|
||||||
|
$list = new PhabricatorObjectItemListView();
|
||||||
|
$list->setNoDataString($nodata);
|
||||||
|
$nav->appendChild($list);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if ($filter === null) {
|
||||||
|
$nav->appendChild($pager);
|
||||||
|
}
|
||||||
|
|
||||||
return $this->buildApplicationPage(
|
return $this->buildApplicationPage(
|
||||||
$nav,
|
$nav,
|
||||||
array(
|
array(
|
||||||
|
'device' => true,
|
||||||
'title' => 'Image Macros',
|
'title' => 'Image Macros',
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
93
src/view/layout/PhabricatorPinboardItemView.php
Normal file
93
src/view/layout/PhabricatorPinboardItemView.php
Normal file
|
@ -0,0 +1,93 @@
|
||||||
|
<?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 PhabricatorPinboardItemView extends AphrontView {
|
||||||
|
|
||||||
|
private $imageURI;
|
||||||
|
private $uri;
|
||||||
|
private $header;
|
||||||
|
|
||||||
|
|
||||||
|
public function setHeader($header) {
|
||||||
|
$this->header = $header;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setURI($uri) {
|
||||||
|
$this->uri = $uri;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setImageURI($image_uri) {
|
||||||
|
$this->imageURI = $image_uri;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setImageSize($x, $y) {
|
||||||
|
$this->imageWidth = $x;
|
||||||
|
$this->imageHeight = $y;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function render() {
|
||||||
|
$header = null;
|
||||||
|
if ($this->header) {
|
||||||
|
$header = phutil_render_tag(
|
||||||
|
'a',
|
||||||
|
array(
|
||||||
|
'href' => $this->uri,
|
||||||
|
'class' => 'phabricator-pinboard-item-header',
|
||||||
|
),
|
||||||
|
phutil_escape_html($this->header));
|
||||||
|
}
|
||||||
|
|
||||||
|
$image = phutil_render_tag(
|
||||||
|
'a',
|
||||||
|
array(
|
||||||
|
'href' => $this->uri,
|
||||||
|
'class' => 'phabricator-pinboard-item-image-link',
|
||||||
|
),
|
||||||
|
phutil_render_tag(
|
||||||
|
'img',
|
||||||
|
array(
|
||||||
|
'src' => $this->imageURI,
|
||||||
|
'width' => $this->imageWidth,
|
||||||
|
'height' => $this->imageHeight,
|
||||||
|
)));
|
||||||
|
|
||||||
|
$content = $this->renderChildren();
|
||||||
|
if ($content) {
|
||||||
|
$content = phutil_render_tag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'class' => 'phabricator-pinboard-item-content',
|
||||||
|
),
|
||||||
|
$content);
|
||||||
|
}
|
||||||
|
|
||||||
|
return phutil_render_tag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'class' => 'phabricator-pinboard-item-view',
|
||||||
|
),
|
||||||
|
$header.
|
||||||
|
$image.
|
||||||
|
$content);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
39
src/view/layout/PhabricatorPinboardView.php
Normal file
39
src/view/layout/PhabricatorPinboardView.php
Normal file
|
@ -0,0 +1,39 @@
|
||||||
|
<?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 PhabricatorPinboardView extends AphrontView {
|
||||||
|
|
||||||
|
private $items = array();
|
||||||
|
|
||||||
|
public function addItem(PhabricatorPinBoardItemView $item) {
|
||||||
|
$this->items[] = $item;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function render() {
|
||||||
|
require_celerity_resource('phabricator-pinboard-view-css');
|
||||||
|
|
||||||
|
return phutil_render_tag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'class' => 'phabricator-pinboard-view',
|
||||||
|
),
|
||||||
|
$this->renderSingleView($this->items));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
53
webroot/rsrc/css/layout/phabricator-pinboard-view.css
Normal file
53
webroot/rsrc/css/layout/phabricator-pinboard-view.css
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
/**
|
||||||
|
* @provides phabricator-pinboard-view-css
|
||||||
|
*/
|
||||||
|
|
||||||
|
.phabricator-pinboard-view {
|
||||||
|
padding: 0 2%;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.device-phone .phabricator-pinboard-view {
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.phabricator-pinboard-item-view {
|
||||||
|
margin: 0 10px 20px;
|
||||||
|
border: 1px solid #aaaaaa;
|
||||||
|
background: #ffffff;
|
||||||
|
|
||||||
|
display: block;
|
||||||
|
float: left;
|
||||||
|
box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.15);
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* On phones, show a single column of items. */
|
||||||
|
.device-phone .phabricator-pinboard-item-view {
|
||||||
|
float: none;
|
||||||
|
margin: 0 auto 20px;
|
||||||
|
|
||||||
|
/* NOTE: This needs to be changed if we use images other than 160px wide. */
|
||||||
|
width: 200px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.phabricator-pinboard-item-header {
|
||||||
|
padding: 5px 20px;
|
||||||
|
display: block;
|
||||||
|
background: #f3f3f3;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.phabricator-pinboard-item-image-link {
|
||||||
|
padding: 20px;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
.phabricator-pinboard-item-content {
|
||||||
|
padding: 5px 20px;
|
||||||
|
overflow: hidden;
|
||||||
|
background: #f3f3f3;
|
||||||
|
color: #666666;
|
||||||
|
font-size: smaller;
|
||||||
|
}
|
Loading…
Reference in a new issue