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:
commit
a787b37db4
28 changed files with 366 additions and 133 deletions
|
@ -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',
|
||||||
|
|
|
@ -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',
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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');
|
||||||
|
|
||||||
|
|
|
@ -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,
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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)) {
|
||||||
|
|
|
@ -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';
|
||||||
|
|
||||||
|
|
|
@ -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,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -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(
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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,
|
||||||
)),
|
)),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
|
@ -38,7 +38,7 @@ final class PhabricatorUserCardView extends AphrontTagView {
|
||||||
}
|
}
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
'class' => implode($classes, ' '),
|
'class' => implode(' ', $classes),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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());
|
||||||
|
|
||||||
|
|
|
@ -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()) {
|
||||||
|
|
|
@ -0,0 +1,3 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
interface PhabricatorWorkboardInterface {}
|
|
@ -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;
|
||||||
|
|
|
@ -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),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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())
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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'),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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(
|
||||||
|
|
|
@ -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']);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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,
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue