1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-26 06:28:19 +01:00

(stable) Promote 2019 Week 43

This commit is contained in:
epriestley 2019-10-26 08:24:39 -07:00
commit a787b37db4
28 changed files with 366 additions and 133 deletions

View file

@ -9,7 +9,7 @@ return array(
'names' => array( 'names' => array(
'conpherence.pkg.css' => '3c8a0668', 'conpherence.pkg.css' => '3c8a0668',
'conpherence.pkg.js' => '020aebcf', 'conpherence.pkg.js' => '020aebcf',
'core.pkg.css' => '7ce5a944', 'core.pkg.css' => '686ae87c',
'core.pkg.js' => '6e5c894f', 'core.pkg.js' => '6e5c894f',
'differential.pkg.css' => '607c84be', 'differential.pkg.css' => '607c84be',
'differential.pkg.js' => 'a0212a0b', 'differential.pkg.js' => 'a0212a0b',
@ -36,7 +36,7 @@ return array(
'rsrc/css/aphront/typeahead-browse.css' => 'b7ed02d2', 'rsrc/css/aphront/typeahead-browse.css' => 'b7ed02d2',
'rsrc/css/aphront/typeahead.css' => '8779483d', 'rsrc/css/aphront/typeahead.css' => '8779483d',
'rsrc/css/application/almanac/almanac.css' => '2e050f4f', 'rsrc/css/application/almanac/almanac.css' => '2e050f4f',
'rsrc/css/application/auth/auth.css' => 'add92fd8', 'rsrc/css/application/auth/auth.css' => 'c2f23d74',
'rsrc/css/application/base/main-menu-view.css' => '17b71bbc', 'rsrc/css/application/base/main-menu-view.css' => '17b71bbc',
'rsrc/css/application/base/notification-menu.css' => '4df1ee30', 'rsrc/css/application/base/notification-menu.css' => '4df1ee30',
'rsrc/css/application/base/phui-theme.css' => '35883b37', 'rsrc/css/application/base/phui-theme.css' => '35883b37',
@ -169,7 +169,7 @@ return array(
'rsrc/css/phui/phui-pager.css' => 'd022c7ad', 'rsrc/css/phui/phui-pager.css' => 'd022c7ad',
'rsrc/css/phui/phui-pinboard-view.css' => '1f08f5d8', 'rsrc/css/phui/phui-pinboard-view.css' => '1f08f5d8',
'rsrc/css/phui/phui-policy-section-view.css' => '139fdc64', 'rsrc/css/phui/phui-policy-section-view.css' => '139fdc64',
'rsrc/css/phui/phui-property-list-view.css' => '807b1632', 'rsrc/css/phui/phui-property-list-view.css' => '9c477af1',
'rsrc/css/phui/phui-remarkup-preview.css' => '91767007', 'rsrc/css/phui/phui-remarkup-preview.css' => '91767007',
'rsrc/css/phui/phui-segment-bar-view.css' => '5166b370', 'rsrc/css/phui/phui-segment-bar-view.css' => '5166b370',
'rsrc/css/phui/phui-spacing.css' => 'b05cadc3', 'rsrc/css/phui/phui-spacing.css' => 'b05cadc3',
@ -540,7 +540,7 @@ return array(
'aphront-tooltip-css' => 'e3f2412f', 'aphront-tooltip-css' => 'e3f2412f',
'aphront-typeahead-control-css' => '8779483d', 'aphront-typeahead-control-css' => '8779483d',
'application-search-view-css' => '0f7c06d8', 'application-search-view-css' => '0f7c06d8',
'auth-css' => 'add92fd8', 'auth-css' => 'c2f23d74',
'bulk-job-css' => '73af99f5', 'bulk-job-css' => '73af99f5',
'conduit-api-css' => 'ce2cfc41', 'conduit-api-css' => 'ce2cfc41',
'config-options-css' => '16c920ae', 'config-options-css' => '16c920ae',
@ -865,7 +865,7 @@ return array(
'phui-pager-css' => 'd022c7ad', 'phui-pager-css' => 'd022c7ad',
'phui-pinboard-view-css' => '1f08f5d8', 'phui-pinboard-view-css' => '1f08f5d8',
'phui-policy-section-view-css' => '139fdc64', 'phui-policy-section-view-css' => '139fdc64',
'phui-property-list-view-css' => '807b1632', 'phui-property-list-view-css' => '9c477af1',
'phui-remarkup-preview-css' => '91767007', 'phui-remarkup-preview-css' => '91767007',
'phui-segment-bar-view-css' => '5166b370', 'phui-segment-bar-view-css' => '5166b370',
'phui-spacing-css' => 'b05cadc3', 'phui-spacing-css' => 'b05cadc3',

View file

@ -996,6 +996,7 @@ phutil_register_library_map(array(
'DiffusionRepositoryManagementOtherPanelGroup' => 'applications/diffusion/management/DiffusionRepositoryManagementOtherPanelGroup.php', 'DiffusionRepositoryManagementOtherPanelGroup' => 'applications/diffusion/management/DiffusionRepositoryManagementOtherPanelGroup.php',
'DiffusionRepositoryManagementPanel' => 'applications/diffusion/management/DiffusionRepositoryManagementPanel.php', 'DiffusionRepositoryManagementPanel' => 'applications/diffusion/management/DiffusionRepositoryManagementPanel.php',
'DiffusionRepositoryManagementPanelGroup' => 'applications/diffusion/management/DiffusionRepositoryManagementPanelGroup.php', 'DiffusionRepositoryManagementPanelGroup' => 'applications/diffusion/management/DiffusionRepositoryManagementPanelGroup.php',
'DiffusionRepositoryMetricsSearchEngineAttachment' => 'applications/diffusion/engineextension/DiffusionRepositoryMetricsSearchEngineAttachment.php',
'DiffusionRepositoryPath' => 'applications/diffusion/data/DiffusionRepositoryPath.php', 'DiffusionRepositoryPath' => 'applications/diffusion/data/DiffusionRepositoryPath.php',
'DiffusionRepositoryPoliciesManagementPanel' => 'applications/diffusion/management/DiffusionRepositoryPoliciesManagementPanel.php', 'DiffusionRepositoryPoliciesManagementPanel' => 'applications/diffusion/management/DiffusionRepositoryPoliciesManagementPanel.php',
'DiffusionRepositoryProfilePictureController' => 'applications/diffusion/controller/DiffusionRepositoryProfilePictureController.php', 'DiffusionRepositoryProfilePictureController' => 'applications/diffusion/controller/DiffusionRepositoryProfilePictureController.php',
@ -5044,6 +5045,7 @@ phutil_register_library_map(array(
'PhabricatorWeekStartDaySetting' => 'applications/settings/setting/PhabricatorWeekStartDaySetting.php', 'PhabricatorWeekStartDaySetting' => 'applications/settings/setting/PhabricatorWeekStartDaySetting.php',
'PhabricatorWildConfigType' => 'applications/config/type/PhabricatorWildConfigType.php', 'PhabricatorWildConfigType' => 'applications/config/type/PhabricatorWildConfigType.php',
'PhabricatorWordPressAuthProvider' => 'applications/auth/provider/PhabricatorWordPressAuthProvider.php', 'PhabricatorWordPressAuthProvider' => 'applications/auth/provider/PhabricatorWordPressAuthProvider.php',
'PhabricatorWorkboardInterface' => 'applications/project/interface/PhabricatorWorkboardInterface.php',
'PhabricatorWorkboardViewState' => 'applications/project/state/PhabricatorWorkboardViewState.php', 'PhabricatorWorkboardViewState' => 'applications/project/state/PhabricatorWorkboardViewState.php',
'PhabricatorWorker' => 'infrastructure/daemon/workers/PhabricatorWorker.php', 'PhabricatorWorker' => 'infrastructure/daemon/workers/PhabricatorWorker.php',
'PhabricatorWorkerActiveTask' => 'infrastructure/daemon/workers/storage/PhabricatorWorkerActiveTask.php', 'PhabricatorWorkerActiveTask' => 'infrastructure/daemon/workers/storage/PhabricatorWorkerActiveTask.php',
@ -6963,6 +6965,7 @@ phutil_register_library_map(array(
'DiffusionRepositoryManagementOtherPanelGroup' => 'DiffusionRepositoryManagementPanelGroup', 'DiffusionRepositoryManagementOtherPanelGroup' => 'DiffusionRepositoryManagementPanelGroup',
'DiffusionRepositoryManagementPanel' => 'Phobject', 'DiffusionRepositoryManagementPanel' => 'Phobject',
'DiffusionRepositoryManagementPanelGroup' => 'Phobject', 'DiffusionRepositoryManagementPanelGroup' => 'Phobject',
'DiffusionRepositoryMetricsSearchEngineAttachment' => 'PhabricatorSearchEngineAttachment',
'DiffusionRepositoryPath' => 'Phobject', 'DiffusionRepositoryPath' => 'Phobject',
'DiffusionRepositoryPoliciesManagementPanel' => 'DiffusionRepositoryManagementPanel', 'DiffusionRepositoryPoliciesManagementPanel' => 'DiffusionRepositoryManagementPanel',
'DiffusionRepositoryProfilePictureController' => 'DiffusionController', 'DiffusionRepositoryProfilePictureController' => 'DiffusionController',
@ -10748,6 +10751,7 @@ phutil_register_library_map(array(
'PhabricatorColumnProxyInterface', 'PhabricatorColumnProxyInterface',
'PhabricatorSpacesInterface', 'PhabricatorSpacesInterface',
'PhabricatorEditEngineSubtypeInterface', 'PhabricatorEditEngineSubtypeInterface',
'PhabricatorWorkboardInterface',
), ),
'PhabricatorProjectActivityChartEngine' => 'PhabricatorChartEngine', 'PhabricatorProjectActivityChartEngine' => 'PhabricatorChartEngine',
'PhabricatorProjectAddHeraldAction' => 'PhabricatorProjectHeraldAction', 'PhabricatorProjectAddHeraldAction' => 'PhabricatorProjectHeraldAction',

View file

@ -286,4 +286,26 @@ abstract class PhabricatorAuthController extends PhabricatorController {
->appendChild($invite_list); ->appendChild($invite_list);
} }
final protected function newCustomStartMessage() {
$viewer = $this->getViewer();
$text = PhabricatorAuthMessage::loadMessageText(
$viewer,
PhabricatorAuthLoginMessageType::MESSAGEKEY);
if (!strlen($text)) {
return null;
}
$remarkup_view = new PHUIRemarkupView($viewer, $text);
return phutil_tag(
'div',
array(
'class' => 'auth-custom-message',
),
$remarkup_view);
}
} }

View file

@ -238,18 +238,24 @@ final class PhabricatorAuthLoginController
$content) { $content) {
$crumbs = $this->buildApplicationCrumbs(); $crumbs = $this->buildApplicationCrumbs();
$viewer = $this->getViewer();
if ($this->getRequest()->getUser()->isLoggedIn()) { if ($viewer->isLoggedIn()) {
$crumbs->addTextCrumb(pht('Link Account'), $provider->getSettingsURI()); $crumbs->addTextCrumb(pht('Link Account'), $provider->getSettingsURI());
} else { } else {
$crumbs->addTextCrumb(pht('Log In'), $this->getApplicationURI('start/')); $crumbs->addTextCrumb(pht('Login'), $this->getApplicationURI('start/'));
$content = array(
$this->newCustomStartMessage(),
$content,
);
} }
$crumbs->addTextCrumb($provider->getProviderName()); $crumbs->addTextCrumb($provider->getProviderName());
$crumbs->setBorder(true); $crumbs->setBorder(true);
return $this->newPage() return $this->newPage()
->setTitle(pht('Log In')) ->setTitle(pht('Login'))
->setCrumbs($crumbs) ->setCrumbs($crumbs)
->appendChild($content); ->appendChild($content);
} }

View file

@ -298,27 +298,6 @@ final class PhabricatorAuthStartController
->setURI($auto_uri); ->setURI($auto_uri);
} }
private function newCustomStartMessage() {
$viewer = $this->getViewer();
$text = PhabricatorAuthMessage::loadMessageText(
$viewer,
PhabricatorAuthLoginMessageType::MESSAGEKEY);
if (!strlen($text)) {
return null;
}
$remarkup_view = new PHUIRemarkupView($viewer, $text);
return phutil_tag(
'div',
array(
'class' => 'auth-custom-message',
),
$remarkup_view);
}
private function newEmailLoginView(array $configs) { private function newEmailLoginView(array $configs) {
assert_instances_of($configs, 'PhabricatorAuthProviderConfig'); assert_instances_of($configs, 'PhabricatorAuthProviderConfig');

View file

@ -69,7 +69,7 @@ final class PhabricatorDashboardApplication extends PhabricatorApplication {
'PhabricatorDashboardPortalListController', 'PhabricatorDashboardPortalListController',
$this->getEditRoutePattern('edit/') => $this->getEditRoutePattern('edit/') =>
'PhabricatorDashboardPortalEditController', 'PhabricatorDashboardPortalEditController',
'view/(?P<portalID>\d)/' => array( 'view/(?P<portalID>\d+)/' => array(
'' => 'PhabricatorDashboardPortalViewController', '' => 'PhabricatorDashboardPortalViewController',
) + $menu_rules, ) + $menu_rules,

View file

@ -103,7 +103,7 @@ final class PhabricatorDifferentialRevisionTestDataGenerator
$newcode2[] = $altcodearr[$randomlines_new[$c++]]; $newcode2[] = $altcodearr[$randomlines_new[$c++]];
} }
} }
return implode($newcode2, "\n"); return implode("\n", $newcode2);
} }
} }

View file

@ -1686,6 +1686,16 @@ final class DifferentialChangesetParser extends Phobject {
break; break;
} }
$type_delete = DifferentialChangeType::TYPE_DELETE;
$type_add = DifferentialChangeType::TYPE_ADD;
$change_type = $changeset->getChangeType();
$no_old = ($change_type == $type_add);
$no_new = ($change_type == $type_delete);
if ($no_old) {
$old_ref = null;
} else {
$old_ref = id(new PhabricatorDocumentRef()) $old_ref = id(new PhabricatorDocumentRef())
->setName($changeset->getOldFile()); ->setName($changeset->getOldFile());
if ($old_file) { if ($old_file) {
@ -1697,7 +1707,11 @@ final class DifferentialChangesetParser extends Phobject {
$old_ref->setData($old_data); $old_ref->setData($old_data);
} }
}
if ($no_new) {
$new_ref = null;
} else {
$new_ref = id(new PhabricatorDocumentRef()) $new_ref = id(new PhabricatorDocumentRef())
->setName($changeset->getFilename()); ->setName($changeset->getFilename());
if ($new_file) { if ($new_file) {
@ -1709,15 +1723,24 @@ final class DifferentialChangesetParser extends Phobject {
$new_ref->setData($new_data); $new_ref->setData($new_data);
} }
}
$old_engines = null;
if ($old_ref) {
$old_engines = PhabricatorDocumentEngine::getEnginesForRef( $old_engines = PhabricatorDocumentEngine::getEnginesForRef(
$viewer, $viewer,
$old_ref); $old_ref);
}
$new_engines = null;
if ($new_ref) {
$new_engines = PhabricatorDocumentEngine::getEnginesForRef( $new_engines = PhabricatorDocumentEngine::getEnginesForRef(
$viewer, $viewer,
$new_ref); $new_ref);
}
if ($new_engines !== null && $old_engines !== null) {
$shared_engines = array_intersect_key($new_engines, $old_engines); $shared_engines = array_intersect_key($new_engines, $old_engines);
$default_engine = head_key($new_engines); $default_engine = head_key($new_engines);
@ -1726,6 +1749,15 @@ final class DifferentialChangesetParser extends Phobject {
unset($shared_engines[$key]); unset($shared_engines[$key]);
} }
} }
} else if ($new_engines !== null) {
$shared_engines = $new_engines;
$default_engine = head_key($shared_engines);
} else if ($old_engines !== null) {
$shared_engines = $old_engines;
$default_engine = head_key($shared_engines);
} else {
return null;
}
$engine_key = $this->getDocumentEngineKey(); $engine_key = $this->getDocumentEngineKey();
if (strlen($engine_key)) { if (strlen($engine_key)) {

View file

@ -371,17 +371,27 @@ final class DifferentialChangesetOneUpRenderer
$cell_classes = $block_diff->getNewClasses(); $cell_classes = $block_diff->getNewClasses();
} }
} else if ($row_type === 'old') { } else if ($row_type === 'old') {
if (!$old_ref) {
continue;
}
$cell_content = $engine->newBlockContentView( $cell_content = $engine->newBlockContentView(
$old_ref, $old_ref,
$old); $old);
$cell_classes[] = 'old'; $cell_classes[] = 'old';
$cell_classes[] = 'old-full'; $cell_classes[] = 'old-full';
$new_key = null; $new_key = null;
} else if ($row_type === 'new') { } else if ($row_type === 'new') {
if (!$new_ref) {
continue;
}
$cell_content = $engine->newBlockContentView( $cell_content = $engine->newBlockContentView(
$new_ref, $new_ref,
$new); $new);
$cell_classes[] = 'new'; $cell_classes[] = 'new';
$cell_classes[] = 'new-full'; $cell_classes[] = 'new-full';

View file

@ -0,0 +1,41 @@
<?php
final class DiffusionRepositoryMetricsSearchEngineAttachment
extends PhabricatorSearchEngineAttachment {
public function getAttachmentName() {
return pht('Repository Metrics');
}
public function getAttachmentDescription() {
return pht(
'Get metrics (like commit count and most recent commit) for each '.
'repository.');
}
public function willLoadAttachmentData($query, $spec) {
$query
->needCommitCounts(true)
->needMostRecentCommits(true);
}
public function getAttachmentForObject($object, $data, $spec) {
$commit = $object->getMostRecentCommit();
if ($commit !== null) {
$recent_commit = $commit->getFieldValuesForConduit();
} else {
$recent_commit = null;
}
$commit_count = $object->getCommitCount();
if ($commit_count !== null) {
$commit_count = (int)$commit_count;
}
return array(
'commitCount' => $commit_count,
'recentCommit' => $recent_commit,
);
}
}

View file

@ -15,7 +15,10 @@ final class PhabricatorDocumentEngineBlocks
return $this->messages; return $this->messages;
} }
public function addBlockList(PhabricatorDocumentRef $ref, array $blocks) { public function addBlockList(
PhabricatorDocumentRef $ref = null,
array $blocks = array()) {
assert_instances_of($blocks, 'PhabricatorDocumentEngineBlock'); assert_instances_of($blocks, 'PhabricatorDocumentEngineBlock');
$this->lists[] = array( $this->lists[] = array(

View file

@ -32,8 +32,8 @@ abstract class PhabricatorDocumentEngine
} }
public function canDiffDocuments( public function canDiffDocuments(
PhabricatorDocumentRef $uref, PhabricatorDocumentRef $uref = null,
PhabricatorDocumentRef $vref) { PhabricatorDocumentRef $vref = null) {
return false; return false;
} }

View file

@ -18,21 +18,38 @@ final class PhabricatorImageDocumentEngine
} }
public function canDiffDocuments( public function canDiffDocuments(
PhabricatorDocumentRef $uref, PhabricatorDocumentRef $uref = null,
PhabricatorDocumentRef $vref) { PhabricatorDocumentRef $vref = null) {
// For now, we can only render a rich image diff if both documents have // For now, we can only render a rich image diff if the documents have
// their data stored in Files already. // their data stored in Files already.
return ($uref->getFile() && $vref->getFile()); if ($uref && !$uref->getFile()) {
return false;
}
if ($vref && !$vref->getFile()) {
return false;
}
return true;
} }
public function newEngineBlocks( public function newEngineBlocks(
PhabricatorDocumentRef $uref, PhabricatorDocumentRef $uref = null,
PhabricatorDocumentRef $vref) { PhabricatorDocumentRef $vref = null) {
if ($uref) {
$u_blocks = $this->newDiffBlocks($uref); $u_blocks = $this->newDiffBlocks($uref);
} else {
$u_blocks = array();
}
if ($vref) {
$v_blocks = $this->newDiffBlocks($vref); $v_blocks = $this->newDiffBlocks($vref);
} else {
$v_blocks = array();
}
return id(new PhabricatorDocumentEngineBlocks()) return id(new PhabricatorDocumentEngineBlocks())
->addBlockList($uref, $u_blocks) ->addBlockList($uref, $u_blocks)

View file

@ -36,20 +36,29 @@ final class PhabricatorJupyterDocumentEngine
} }
public function canDiffDocuments( public function canDiffDocuments(
PhabricatorDocumentRef $uref, PhabricatorDocumentRef $uref = null,
PhabricatorDocumentRef $vref) { PhabricatorDocumentRef $vref = null) {
return true; return true;
} }
public function newEngineBlocks( public function newEngineBlocks(
PhabricatorDocumentRef $uref, PhabricatorDocumentRef $uref = null,
PhabricatorDocumentRef $vref) { PhabricatorDocumentRef $vref = null) {
$blocks = new PhabricatorDocumentEngineBlocks(); $blocks = new PhabricatorDocumentEngineBlocks();
try { try {
if ($uref) {
$u_blocks = $this->newDiffBlocks($uref); $u_blocks = $this->newDiffBlocks($uref);
} else {
$u_blocks = array();
}
if ($vref) {
$v_blocks = $this->newDiffBlocks($vref); $v_blocks = $this->newDiffBlocks($vref);
} else {
$v_blocks = array();
}
$blocks->addBlockList($uref, $u_blocks); $blocks->addBlockList($uref, $u_blocks);
$blocks->addBlockList($vref, $v_blocks); $blocks->addBlockList($vref, $v_blocks);
@ -93,6 +102,54 @@ final class PhabricatorJupyterDocumentEngine
$u_content = $this->newCellContainer($u_content); $u_content = $this->newCellContainer($u_content);
$v_content = $this->newCellContainer($v_content); $v_content = $this->newCellContainer($v_content);
return id(new PhabricatorDocumentEngineBlockDiff())
->setOldContent($u_content)
->addOldClass('old')
->setNewContent($v_content)
->addNewClass('new');
case 'code/line':
$usource = idx($ucell, 'raw');
$vsource = idx($vcell, 'raw');
$udisplay = idx($ucell, 'display');
$vdisplay = idx($vcell, 'display');
$ulabel = idx($ucell, 'label');
$vlabel = idx($vcell, 'label');
$intraline_segments = ArcanistDiffUtils::generateIntralineDiff(
$usource,
$vsource);
$u_segments = array();
foreach ($intraline_segments[0] as $u_segment) {
$u_segments[] = $u_segment;
}
$v_segments = array();
foreach ($intraline_segments[1] as $v_segment) {
$v_segments[] = $v_segment;
}
$usource = ArcanistDiffUtils::applyIntralineDiff(
$udisplay,
$u_segments);
$vsource = ArcanistDiffUtils::applyIntralineDiff(
$vdisplay,
$v_segments);
$u_content = $this->newCodeLineCell($ucell, $usource);
$v_content = $this->newCodeLineCell($vcell, $vsource);
$classes = array(
'jupyter-cell-flush',
);
$u_content = $this->newJupyterCell($ulabel, $u_content, $classes);
$v_content = $this->newJupyterCell($vlabel, $v_content, $classes);
$u_content = $this->newCellContainer($u_content);
$v_content = $this->newCellContainer($v_content);
return id(new PhabricatorDocumentEngineBlockDiff()) return id(new PhabricatorDocumentEngineBlockDiff())
->setOldContent($u_content) ->setOldContent($u_content)
->addOldClass('old') ->addOldClass('old')
@ -441,8 +498,10 @@ final class PhabricatorJupyterDocumentEngine
return $this->newCodeOutputCell($cell); return $this->newCodeOutputCell($cell);
} }
return $this->newRawCell(id(new PhutilJSON()) $json_content = id(new PhutilJSON())
->encodeFormatted($cell)); ->encodeFormatted($cell);
return $this->newRawCell($json_content);
} }
private function newRawCell($content) { private function newRawCell($content) {
@ -514,7 +573,7 @@ final class PhabricatorJupyterDocumentEngine
); );
} }
private function newCodeLineCell(array $cell) { private function newCodeLineCell(array $cell, $content = null) {
$classes = array(); $classes = array();
$classes[] = 'PhabricatorMonospaced'; $classes[] = 'PhabricatorMonospaced';
$classes[] = 'remarkup-code'; $classes[] = 'remarkup-code';
@ -531,6 +590,10 @@ final class PhabricatorJupyterDocumentEngine
$classes = implode(' ', $classes); $classes = implode(' ', $classes);
if ($content === null) {
$content = $cell['display'];
}
return array( return array(
$cell['label'], $cell['label'],
array( array(
@ -540,7 +603,7 @@ final class PhabricatorJupyterDocumentEngine
'class' => $classes, 'class' => $classes,
), ),
array( array(
$cell['display'], $content,
)), )),
), ),
); );

View file

@ -38,7 +38,7 @@ final class PhabricatorUserCardView extends AphrontTagView {
} }
return array( return array(
'class' => implode($classes, ' '), 'class' => implode(' ', $classes),
); );
} }

View file

@ -63,14 +63,14 @@ final class PhabricatorProjectProfileController
$member_list = id(new PhabricatorProjectMemberListView()) $member_list = id(new PhabricatorProjectMemberListView())
->setUser($viewer) ->setUser($viewer)
->setProject($project) ->setProject($project)
->setLimit(5) ->setLimit(10)
->setBackground(PHUIObjectBoxView::BLUE_PROPERTY) ->setBackground(PHUIObjectBoxView::BLUE_PROPERTY)
->setUserPHIDs($project->getMemberPHIDs()); ->setUserPHIDs($project->getMemberPHIDs());
$watcher_list = id(new PhabricatorProjectWatcherListView()) $watcher_list = id(new PhabricatorProjectWatcherListView())
->setUser($viewer) ->setUser($viewer)
->setProject($project) ->setProject($project)
->setLimit(5) ->setLimit(10)
->setBackground(PHUIObjectBoxView::BLUE_PROPERTY) ->setBackground(PHUIObjectBoxView::BLUE_PROPERTY)
->setUserPHIDs($project->getWatcherPHIDs()); ->setUserPHIDs($project->getWatcherPHIDs());

View file

@ -301,6 +301,12 @@ final class PhabricatorBoardLayoutEngine extends Phobject {
->execute(); ->execute();
$boards = mpull($boards, null, 'getPHID'); $boards = mpull($boards, null, 'getPHID');
foreach ($boards as $key => $board) {
if (!($board instanceof PhabricatorWorkboardInterface)) {
unset($boards[$key]);
}
}
if (!$this->fetchAllBoards) { if (!$this->fetchAllBoards) {
foreach ($boards as $key => $board) { foreach ($boards as $key => $board) {
if (!$board->getHasWorkboard()) { if (!$board->getHasWorkboard()) {

View file

@ -0,0 +1,3 @@
<?php
interface PhabricatorWorkboardInterface {}

View file

@ -13,7 +13,8 @@ final class PhabricatorProject extends PhabricatorProjectDAO
PhabricatorConduitResultInterface, PhabricatorConduitResultInterface,
PhabricatorColumnProxyInterface, PhabricatorColumnProxyInterface,
PhabricatorSpacesInterface, PhabricatorSpacesInterface,
PhabricatorEditEngineSubtypeInterface { PhabricatorEditEngineSubtypeInterface,
PhabricatorWorkboardInterface {
protected $name; protected $name;
protected $status = PhabricatorProjectStatus::STATUS_ACTIVE; protected $status = PhabricatorProjectStatus::STATUS_ACTIVE;

View file

@ -36,7 +36,7 @@ final class PhabricatorProjectCardView extends AphrontTagView {
$classes[] = 'project-card-'.$color; $classes[] = 'project-card-'.$color;
return array( return array(
'class' => implode($classes, ' '), 'class' => implode(' ', $classes),
); );
} }

View file

@ -1,6 +1,7 @@
<?php <?php
abstract class PhabricatorProjectUserListView extends AphrontView { abstract class PhabricatorProjectUserListView
extends AphrontView {
private $project; private $project;
private $userPHIDs; private $userPHIDs;
@ -57,49 +58,74 @@ abstract class PhabricatorProjectUserListView extends AphrontView {
$user_phids = $this->getUserPHIDs(); $user_phids = $this->getUserPHIDs();
$can_edit = $this->canEditList(); $can_edit = $this->canEditList();
$supports_edit = $project->supportsEditMembers();
$no_data = $this->getNoDataString(); $no_data = $this->getNoDataString();
$list = id(new PHUIObjectItemListView()) $list = id(new PHUIObjectItemListView())
->setNoDataString($no_data); ->setNoDataString($no_data);
$limit = $this->getLimit(); $limit = $this->getLimit();
$is_panel = (bool)$limit;
// If we're showing everything, show oldest to newest. If we're showing
// only a slice, show newest to oldest.
if (!$limit) {
$user_phids = array_reverse($user_phids);
}
$handles = $viewer->loadHandles($user_phids); $handles = $viewer->loadHandles($user_phids);
// Always put the viewer first if they are on the list. // Reorder users in display order. We're going to put the viewer first
$user_phids = array_fuse($user_phids); // if they're a member, then enabled users, then disabled/invalid users.
$user_phids =
array_select_keys($user_phids, array($viewer->getPHID())) +
$user_phids;
if ($limit) { $phid_map = array();
$render_phids = array_slice($user_phids, 0, $limit); foreach ($user_phids as $user_phid) {
} else {
$render_phids = $user_phids;
}
foreach ($render_phids as $user_phid) {
$handle = $handles[$user_phid]; $handle = $handles[$user_phid];
$is_viewer = ($user_phid === $viewer->getPHID());
$is_enabled = ($handle->isComplete() && !$handle->isDisabled());
// If we're showing the main member list, show oldest to newest. If we're
// showing only a slice in a panel, show newest to oldest.
if ($limit) {
$order_scalar = 1;
} else {
$order_scalar = -1;
}
$phid_map[$user_phid] = id(new PhutilSortVector())
->addInt($is_viewer ? 0 : 1)
->addInt($is_enabled ? 0 : 1)
->addInt($order_scalar * count($phid_map));
}
$phid_map = msortv($phid_map, 'getSelf');
$handles = iterator_to_array($handles);
$handles = array_select_keys($handles, array_keys($phid_map));
if ($limit) {
$handles = array_slice($handles, 0, $limit);
}
foreach ($handles as $user_phid => $handle) {
$item = id(new PHUIObjectItemView()) $item = id(new PHUIObjectItemView())
->setHeader($handle->getFullName()) ->setHeader($handle->getFullName())
->setHref($handle->getURI()) ->setHref($handle->getURI())
->setImageURI($handle->getImageURI()); ->setImageURI($handle->getImageURI());
if ($handle->isDisabled()) {
if ($is_panel) {
// Don't show disabled users in the panel view at all.
continue;
}
$item
->setDisabled(true)
->addAttribute(pht('Disabled'));
} else {
$icon = id(new PHUIIconView()) $icon = id(new PHUIIconView())
->setIcon($handle->getIcon()); ->setIcon($handle->getIcon());
$subtitle = $handle->getSubtitle(); $subtitle = $handle->getSubtitle();
$item->addAttribute(array($icon, ' ', $subtitle)); $item->addAttribute(array($icon, ' ', $subtitle));
}
if ($can_edit && !$limit) { if ($supports_edit && !$is_panel) {
$remove_uri = $this->getRemoveURI($user_phid); $remove_uri = $this->getRemoveURI($user_phid);
$item->addAction( $item->addAction(
@ -107,6 +133,7 @@ abstract class PhabricatorProjectUserListView extends AphrontView {
->setIcon('fa-times') ->setIcon('fa-times')
->setName(pht('Remove')) ->setName(pht('Remove'))
->setHref($remove_uri) ->setHref($remove_uri)
->setDisabled(!$can_edit)
->setWorkflow(true)); ->setWorkflow(true));
} }
@ -128,14 +155,9 @@ abstract class PhabricatorProjectUserListView extends AphrontView {
->setHeader($header_text); ->setHeader($header_text);
if ($limit) { if ($limit) {
$header->addActionLink( $list->newTailButton()
id(new PHUIButtonView())
->setTag('a')
->setIcon(
id(new PHUIIconView())
->setIcon('fa-list-ul'))
->setText(pht('View All')) ->setText(pht('View All'))
->setHref("/project/members/{$id}/")); ->setHref("/project/members/{$id}/");
} }
$box = id(new PHUIObjectBoxView()) $box = id(new PHUIObjectBoxView())

View file

@ -215,6 +215,8 @@ final class PhabricatorRepositoryQuery
$commits = id(new DiffusionCommitQuery()) $commits = id(new DiffusionCommitQuery())
->setViewer($this->getViewer()) ->setViewer($this->getViewer())
->withIDs($commit_ids) ->withIDs($commit_ids)
->needCommitData(true)
->needIdentities(true)
->execute(); ->execute();
} else { } else {
$commits = array(); $commits = array();

View file

@ -2757,6 +2757,14 @@ final class PhabricatorRepository extends PhabricatorRepositoryDAO
->setDescription( ->setDescription(
pht( pht(
'The "Fetch" and "Permanent Ref" rules for this repository.')), 'The "Fetch" and "Permanent Ref" rules for this repository.')),
id(new PhabricatorConduitSearchFieldSpecification())
->setKey('defaultBranch')
->setType('string?')
->setDescription(pht('Default branch name.')),
id(new PhabricatorConduitSearchFieldSpecification())
->setKey('description')
->setType('remarkup')
->setDescription(pht('Repository description.')),
); );
} }
@ -2769,6 +2777,11 @@ final class PhabricatorRepository extends PhabricatorRepositoryDAO
$track_rules = $this->getStringListForConduit($track_rules); $track_rules = $this->getStringListForConduit($track_rules);
$permanent_rules = $this->getStringListForConduit($permanent_rules); $permanent_rules = $this->getStringListForConduit($permanent_rules);
$default_branch = $this->getDefaultBranch();
if (!strlen($default_branch)) {
$default_branch = null;
}
return array( return array(
'name' => $this->getName(), 'name' => $this->getName(),
'vcs' => $this->getVersionControlSystem(), 'vcs' => $this->getVersionControlSystem(),
@ -2782,6 +2795,10 @@ final class PhabricatorRepository extends PhabricatorRepositoryDAO
'trackRules' => $track_rules, 'trackRules' => $track_rules,
'permanentRefRules' => $permanent_rules, 'permanentRefRules' => $permanent_rules,
), ),
'defaultBranch' => $default_branch,
'description' => array(
'raw' => (string)$this->getDetail('description'),
),
); );
} }
@ -2804,6 +2821,8 @@ final class PhabricatorRepository extends PhabricatorRepositoryDAO
return array( return array(
id(new DiffusionRepositoryURIsSearchEngineAttachment()) id(new DiffusionRepositoryURIsSearchEngineAttachment())
->setAttachmentKey('uris'), ->setAttachmentKey('uris'),
id(new DiffusionRepositoryMetricsSearchEngineAttachment())
->setAttachmentKey('metrics'),
); );
} }

View file

@ -103,8 +103,11 @@ EOREMARKUP
if (!($object instanceof PhabricatorApplicationTransactionInterface)) { if (!($object instanceof PhabricatorApplicationTransactionInterface)) {
throw new Exception( throw new Exception(
pht( pht(
'Object "%s" does not implement "%s", so transactions can not '. 'Object "%s" (of type "%s") does not implement "%s", so '.
'be loaded for it.')); 'transactions can not be loaded for it.',
$object_name,
get_class($object),
'PhabricatorApplicationTransactionInterface'));
} }
$xaction_query = PhabricatorApplicationTransactionQuery::newQueryForObject( $xaction_query = PhabricatorApplicationTransactionQuery::newQueryForObject(

View file

@ -284,7 +284,7 @@ final class PHUIPropertyListView extends AphrontView {
return phutil_tag( return phutil_tag(
'div', 'div',
array( array(
'class' => implode($classes, ' '), 'class' => implode(' ', $classes),
), ),
$part['content']); $part['content']);
} }
@ -295,7 +295,7 @@ final class PHUIPropertyListView extends AphrontView {
return phutil_tag( return phutil_tag(
'div', 'div',
array( array(
'class' => implode($classes, ' '), 'class' => implode(' ', $classes),
), ),
$part['content']); $part['content']);
} }

View file

@ -220,7 +220,7 @@ final class PHUITwoColumnView extends AphrontTagView {
return phutil_tag( return phutil_tag(
'div', 'div',
array( array(
'class' => implode($classes, ' '), 'class' => implode(' ', $classes),
), ),
array( array(
$navigation, $navigation,

View file

@ -57,7 +57,7 @@
} }
.auth-custom-message { .auth-custom-message {
margin: 32px auto 64px; margin: 32px auto 48px;
max-width: 548px; max-width: 548px;
background: #fff; background: #fff;
padding: 16px; padding: 16px;

View file

@ -316,12 +316,12 @@ div.phui-property-list-stacked .phui-property-list-properties
} }
td.new .jupyter-cell-code-line { td.new .jupyter-cell-code-line {
background: {$new-background}; background: rgba(255, 255, 255, 0.5);
border-color: {$new-bright}; border-color: {$new-bright};
} }
td.old .jupyter-cell-code-line { td.old .jupyter-cell-code-line {
background: {$old-background}; background: rgba(255, 255, 255, 0.5);
border-color: {$old-bright}; border-color: {$old-bright};
} }