1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-15 17:21:10 +01:00

Update feed on projects, profile.

Summary: Does a few things, standardizes feed a bit more on people, projects. Cleans up Project pages to be more dashboard like. Adds usable mobile support. Remove extenal public feed styles. The Project pages won't win any design awards, but they are much more usable and responsive (mobile). I assume the default view to be workboard still at some point.

Test Plan: Test out Profile, Project Profile, Public Feed, normal Feed. Mobile and Chrome.

Reviewers: epriestley, btrahan

Reviewed By: epriestley

CC: aran, Korvin

Differential Revision: https://secure.phabricator.com/D5700
This commit is contained in:
Chad Little 2013-04-15 13:07:54 -07:00
parent 141228343c
commit 6e86a04ab1
14 changed files with 110 additions and 75 deletions

View file

@ -2980,7 +2980,7 @@ celerity_register_resource_map(array(
),
'phabricator-feed-css' =>
array(
'uri' => '/res/e337f54b/rsrc/css/application/feed/feed.css',
'uri' => '/res/6db1087e/rsrc/css/application/feed/feed.css',
'type' => 'css',
'requires' =>
array(
@ -3212,7 +3212,7 @@ celerity_register_resource_map(array(
),
'phabricator-profile-css' =>
array(
'uri' => '/res/a54f47a7/rsrc/css/application/profile/profile-view.css',
'uri' => '/res/76766eb6/rsrc/css/application/profile/profile-view.css',
'type' => 'css',
'requires' =>
array(
@ -3221,7 +3221,7 @@ celerity_register_resource_map(array(
),
'phabricator-profile-header-css' =>
array(
'uri' => '/res/1ccc6f0b/rsrc/css/application/profile/profile-header-view.css',
'uri' => '/res/a03c1e20/rsrc/css/application/profile/profile-header-view.css',
'type' => 'css',
'requires' =>
array(

View file

@ -7,7 +7,7 @@ final class PhabricatorApplicationFeed extends PhabricatorApplication {
}
public function getShortDescription() {
return 'Review activity.';
return pht('Review activity.');
}
public function getIconName() {

View file

@ -56,9 +56,8 @@ final class PhabricatorFeedBuilder {
$null_view->appendChild($view);
}
return id(new AphrontNullView())->appendChild(hsprintf(
'<div class="phabricator-feed-frame">%s</div>',
$null_view->render()));
return id(new AphrontNullView())
->appendChild($null_view->render());
}
}

View file

@ -57,6 +57,10 @@ final class PhabricatorFeedMainController extends PhabricatorFeedController {
$feed_view = $builder->buildView();
}
$feed_view = hsprintf(
'<div class="phabricator-feed-frame">%s</div>',
$feed_view);
$crumbs = $this
->buildApplicationCrumbs($nav)
->addCrumb(

View file

@ -25,14 +25,14 @@ final class PhabricatorFeedPublicStreamController
->setFramed(true)
->setUser($viewer);
$view = $builder->buildView();
$view = hsprintf('<div class="phabricator-public-feed-frame">%s</div>',
$builder->buildView());
return $this->buildStandardPageResponse(
$view,
array(
'title' => pht('Public Feed'),
'public' => true,
'dust' => true,
));
}
}

View file

@ -1,5 +0,0 @@
<?php
abstract class PhabricatorFeedView extends AphrontView {
}

View file

@ -179,7 +179,7 @@ final class PhabricatorPeopleProfileController
$blurb = $engine->markupText($blurb);
$content = hsprintf(
'<div class="phabricator-profile-info-group ml">
'<div class="phabricator-profile-info-group profile-wrap-responsive">
<h1 class="phabricator-profile-info-header">%s</h1>
<div class="phabricator-profile-info-pane">
<table class="phabricator-profile-info-table">
@ -194,7 +194,7 @@ final class PhabricatorPeopleProfileController
</table>
</div>
</div>'.
'<div class="phabricator-profile-info-group ml">
'<div class="phabricator-profile-info-group profile-wrap-responsive">
<h1 class="phabricator-profile-info-header">%s</h1>
<div class="phabricator-profile-info-pane">
<table class="phabricator-profile-info-table">
@ -234,7 +234,7 @@ final class PhabricatorPeopleProfileController
$view = $builder->buildView();
return hsprintf(
'<div class="phabricator-profile-info-group">
'<div class="profile-feed profile-wrap-responsive">
%s
</div>',
$view->render());

View file

@ -30,16 +30,15 @@ abstract class PhabricatorProjectController extends PhabricatorController {
$edit_uri = '/project/edit/'.$id.'/';
$members_uri = '/project/members/'.$id.'/';
$nav_view->addLabel(pht('Project'));
$nav_view->addFilter('dashboard', pht('Dashboard'));
$nav_view->addFilter('feed', pht('Feed'));
$nav_view->addFilter(null, pht('Tasks').' '.$external_arrow, $tasks_uri);
$nav_view->addFilter(null, pht('Wiki').' '.$external_arrow, $phriction_uri);
$nav_view->addFilter('people', pht('People'));
$nav_view->addFilter('about', pht('About'));
$user = $this->getRequest()->getUser();
$can_edit = PhabricatorPolicyCapability::CAN_EDIT;
$nav_view->addLabel(pht('Manage'));
if (PhabricatorPolicyFilter::hasCapability($user, $project, $can_edit)) {
$nav_view->addFilter('edit', pht("Edit Project"), $edit_uri);
$nav_view->addFilter('members', pht("Edit Members"), $members_uri);
@ -61,10 +60,6 @@ abstract class PhabricatorProjectController extends PhabricatorController {
return $nav_view;
}
public function buildApplicationMenu() {
return $this->buildSideNavView(null, true)->getMenu();
}
public function buildSideNavView($filter = null, $for_app = false) {
$user = $this->getRequest()->getUser();

View file

@ -144,4 +144,8 @@ final class PhabricatorProjectListController
'dust' => true,
));
}
public function buildApplicationMenu() {
return $this->buildSideNavView(null, true)->getMenu();
}
}

View file

@ -18,11 +18,8 @@ final class PhabricatorProjectProfileController
$query = id(new PhabricatorProjectQuery())
->setViewer($user)
->withIDs(array($this->id));
if ($this->page == 'people') {
$query->needMembers(true);
}
->withIDs(array($this->id))
->needMembers(true);
$project = $query->executeOne();
$this->project = $project;
@ -42,34 +39,31 @@ final class PhabricatorProjectProfileController
$this->page = $nav_view->selectFilter($this->page, 'dashboard');
require_celerity_resource('phabricator-profile-css');
switch ($this->page) {
case 'dashboard':
$content = $this->renderTasksPage($project, $profile);
$query = new PhabricatorFeedQuery();
$query->setFilterPHIDs(
array(
$project->getPHID(),
));
$query->setLimit(50);
$query->setViewer($this->getRequest()->getUser());
$stories = $query->execute();
$tasks = $this->renderTasksPage($project, $profile);
$content = hsprintf('%s%s', $content, $this->renderStories($stories));
break;
case 'about':
$content = $this->renderAboutPage($project, $profile);
break;
case 'people':
$content = $this->renderPeoplePage($project, $profile);
break;
case 'feed':
$content = $this->renderFeedPage($project, $profile);
break;
default:
throw new Exception("Unimplemented filter '{$this->page}'.");
}
$query = new PhabricatorFeedQuery();
$query->setFilterPHIDs(
array(
$project->getPHID(),
));
$query->setLimit(50);
$query->setViewer($this->getRequest()->getUser());
$stories = $query->execute();
$feed = $this->renderStories($stories);
$about = $this->renderAboutPage($project, $profile);
$people = $this->renderPeoplePage($project, $profile);
$col1 = hsprintf('%s%s', $about, $people);
$content = id(new AphrontMultiColumnView())
->addColumn($col1)
->addColumn($feed)
->setFluidLayout(true);
$content = hsprintf(
'<div class="phabricator-project-layout">%s%s</div>',
$tasks,
$content);
$header = new PhabricatorProfileHeaderView();
$header->setName($project->getName());
@ -111,16 +105,15 @@ final class PhabricatorProjectProfileController
}
$header->addAction($action);
$nav_view->appendChild($header);
$content = hsprintf('<div style="padding: 1em;">%s</div>', $content);
$header->appendChild($content);
return $this->buildApplicationPage(
$nav_view,
array(
'title' => pht('%s Project', $project->getName()),
'device' => true,
'dust' => true,
));
}
@ -140,8 +133,8 @@ final class PhabricatorProjectProfileController
$timestamp = phabricator_datetime($project->getDateCreated(), $viewer);
$about = hsprintf(
'<div class="phabricator-profile-info-group">
<h1 class="phabricator-profile-info-header">About</h1>
'<div class="phabricator-profile-info-group profile-wrap-responsive">
<h1 class="phabricator-profile-info-header">%s</h1>
<div class="phabricator-profile-info-pane">
<table class="phabricator-profile-info-table">
<tr>
@ -163,6 +156,7 @@ final class PhabricatorProjectProfileController
</table>
</div>
</div>',
pht('About This Project'),
pht('Creator'),
$handles[$project->getAuthorPHID()]->renderLink(),
pht('Created'),
@ -194,7 +188,7 @@ final class PhabricatorProjectProfileController
}
return hsprintf(
'<div class="phabricator-profile-info-group">'.
'<div class="phabricator-profile-info-group profile-wrap-responsive">'.
'<h1 class="phabricator-profile-info-header">%s</h1>'.
'<div class="phabricator-profile-info-pane">%s</div>'.
'</div>',
@ -227,11 +221,9 @@ final class PhabricatorProjectProfileController
$view = $builder->buildView();
return hsprintf(
'<div class="phabricator-profile-info-group">'.
'<h1 class="phabricator-profile-info-header">%s</h1>'.
'<div class="phabricator-profile-info-pane">%s</div>'.
'<div class="profile-feed profile-wrap-responsive">'.
'%s'.
'</div>',
pht('Activity Feed'),
$view->render());
}
@ -273,7 +265,7 @@ final class PhabricatorProjectProfileController
pht("View All Open Tasks \xC2\xBB"));
$content = hsprintf(
'<div class="phabricator-profile-info-group">
'<div class="phabricator-profile-info-group profile-wrap-responsive">
<h1 class="phabricator-profile-info-header">%s</h1>'.
'<div class="phabricator-profile-info-pane">'.
'%s'.
@ -287,4 +279,8 @@ final class PhabricatorProjectProfileController
return $content;
}
public function buildApplicationMenu() {
return $this->buildLocalNavigation($this->project)->getMenu();
}
}

View file

@ -100,13 +100,15 @@ final class PHUIFeedStoryView extends AphrontView {
$body = null;
$foot = null;
$image_style = null;
$body = phutil_tag(
'div',
array(
'class' => 'phui-feed-story-body',
),
$this->renderChildren());
$body_content = $this->renderChildren();
if ($body_content) {
$body = phutil_tag(
'div',
array(
'class' => 'phui-feed-story-body',
),
$body_content);
}
if ($this->epoch) {
$foot = phabricator_datetime($this->epoch, $this->user);

View file

@ -3,7 +3,12 @@
*/
.phabricator-feed-frame {
margin: 20px 10px;
}
.phabricator-public-feed-frame {
margin: 10px;
max-width: 600px;
}
.phabricator-feed-frame .phabricator-action-header-title {
@ -12,8 +17,8 @@
}
.device-desktop .phabricator-feed-frame {
width: 600px;
margin: 20px auto;
max-width: 600px;
margin: 20px;
}
.phabricator-feed-story-date-separator {
@ -29,3 +34,15 @@
float: right;
font-weight: bold;
}
.phabricator-public-feed-frame .phui-feed-story-foot {
background: none;
}
.phabricator-public-feed-frame .phui-feed-story {
box-shadow: none;
}
.phabricator-public-feed-frame .phui-feed-wrap {
border: none;
}

View file

@ -8,7 +8,6 @@
border-style: solid;
border-color: #c0c5d1;
width: 100%;
box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
.phabricator-profile-header .profile-header-name {

View file

@ -102,3 +102,27 @@ img.phabricator-profile-image {
font-weight: bold;
margin: .5em 1em 0;
}
.profile-wrap-responsive {
margin: 20px;
}
.device .profile-wrap-responsive {
margin-left: 10px;
margin-right: 10px;
}
.device-desktop .profile-feed {
max-width: 640px;
}
.profile-feed .phabricator-action-header-title {
font-size: 16px;
margin-bottom: 5px;
}
.device-desktop .phabricator-project-layout
.aphront-multi-column-column-outer:first-child
.phabricator-profile-info-group {
margin-right: 0;
}