1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2024-12-16 02:20:54 +01:00

(stable) Promote 2017 Week 31

This commit is contained in:
epriestley 2017-08-05 03:44:18 -07:00
commit e0970a7e3d
87 changed files with 442 additions and 551 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.7 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 9.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 9.2 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 16 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.9 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 12 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 9 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.9 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 9.2 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.5 KiB

View file

@ -9,7 +9,7 @@ return array(
'names' => array( 'names' => array(
'conpherence.pkg.css' => 'e68cf1fa', 'conpherence.pkg.css' => 'e68cf1fa',
'conpherence.pkg.js' => 'b5b51108', 'conpherence.pkg.js' => 'b5b51108',
'core.pkg.css' => 'd9c9cfd0', 'core.pkg.css' => 'cc0772c6',
'core.pkg.js' => '5d80e0db', 'core.pkg.js' => '5d80e0db',
'darkconsole.pkg.js' => '1f9a31bc', 'darkconsole.pkg.js' => '1f9a31bc',
'differential.pkg.css' => '45951e9e', 'differential.pkg.css' => '45951e9e',
@ -42,7 +42,7 @@ return array(
'rsrc/css/application/base/main-menu-view.css' => '16053029', 'rsrc/css/application/base/main-menu-view.css' => '16053029',
'rsrc/css/application/base/notification-menu.css' => '73fefdfa', 'rsrc/css/application/base/notification-menu.css' => '73fefdfa',
'rsrc/css/application/base/phui-theme.css' => '9f261c6b', 'rsrc/css/application/base/phui-theme.css' => '9f261c6b',
'rsrc/css/application/base/standard-page-view.css' => 'eb5b80c5', 'rsrc/css/application/base/standard-page-view.css' => 'a0dae682',
'rsrc/css/application/chatlog/chatlog.css' => 'd295b020', 'rsrc/css/application/chatlog/chatlog.css' => 'd295b020',
'rsrc/css/application/conduit/conduit-api.css' => '7bc725c4', 'rsrc/css/application/conduit/conduit-api.css' => '7bc725c4',
'rsrc/css/application/config/config-options.css' => 'd55ed093', 'rsrc/css/application/config/config-options.css' => 'd55ed093',
@ -139,10 +139,10 @@ return array(
'rsrc/css/phui/object-item/phui-oi-list-view.css' => 'bf094950', 'rsrc/css/phui/object-item/phui-oi-list-view.css' => 'bf094950',
'rsrc/css/phui/object-item/phui-oi-simple-ui.css' => 'a8beebea', 'rsrc/css/phui/object-item/phui-oi-simple-ui.css' => 'a8beebea',
'rsrc/css/phui/phui-action-list.css' => '6ee16164', 'rsrc/css/phui/phui-action-list.css' => '6ee16164',
'rsrc/css/phui/phui-action-panel.css' => '91c7b835', 'rsrc/css/phui/phui-action-panel.css' => 'b4798122',
'rsrc/css/phui/phui-badge.css' => '22c0cf4f', 'rsrc/css/phui/phui-badge.css' => '22c0cf4f',
'rsrc/css/phui/phui-basic-nav-view.css' => 'a0705f53', 'rsrc/css/phui/phui-basic-nav-view.css' => 'a0705f53',
'rsrc/css/phui/phui-big-info-view.css' => 'd13afcde', 'rsrc/css/phui/phui-big-info-view.css' => 'acc3492c',
'rsrc/css/phui/phui-box.css' => '745e881d', 'rsrc/css/phui/phui-box.css' => '745e881d',
'rsrc/css/phui/phui-chart.css' => '6bf6f78e', 'rsrc/css/phui/phui-chart.css' => '6bf6f78e',
'rsrc/css/phui/phui-cms.css' => '504b4b23', 'rsrc/css/phui/phui-cms.css' => '504b4b23',
@ -163,7 +163,6 @@ return array(
'rsrc/css/phui/phui-icon-set-selector.css' => '87db8fee', 'rsrc/css/phui/phui-icon-set-selector.css' => '87db8fee',
'rsrc/css/phui/phui-icon.css' => '5c4a5de6', 'rsrc/css/phui/phui-icon.css' => '5c4a5de6',
'rsrc/css/phui/phui-image-mask.css' => 'a8498f9c', 'rsrc/css/phui/phui-image-mask.css' => 'a8498f9c',
'rsrc/css/phui/phui-info-panel.css' => '27ea50a1',
'rsrc/css/phui/phui-info-view.css' => 'e1b4ec37', 'rsrc/css/phui/phui-info-view.css' => 'e1b4ec37',
'rsrc/css/phui/phui-invisible-character-view.css' => '6993d9f0', 'rsrc/css/phui/phui-invisible-character-view.css' => '6993d9f0',
'rsrc/css/phui/phui-left-right.css' => 'f60c67e7', 'rsrc/css/phui/phui-left-right.css' => 'f60c67e7',
@ -179,7 +178,7 @@ return array(
'rsrc/css/phui/phui-status.css' => 'd5263e49', 'rsrc/css/phui/phui-status.css' => 'd5263e49',
'rsrc/css/phui/phui-tag-view.css' => 'b4719c50', 'rsrc/css/phui/phui-tag-view.css' => 'b4719c50',
'rsrc/css/phui/phui-timeline-view.css' => 'f21db7ca', 'rsrc/css/phui/phui-timeline-view.css' => 'f21db7ca',
'rsrc/css/phui/phui-two-column-view.css' => '5b8cd553', 'rsrc/css/phui/phui-two-column-view.css' => 'ae38a939',
'rsrc/css/phui/workboards/phui-workboard-color.css' => '783cdff5', 'rsrc/css/phui/workboards/phui-workboard-color.css' => '783cdff5',
'rsrc/css/phui/workboards/phui-workboard.css' => '3bc85455', 'rsrc/css/phui/workboards/phui-workboard.css' => '3bc85455',
'rsrc/css/phui/workboards/phui-workcard.css' => 'cca5fa92', 'rsrc/css/phui/workboards/phui-workcard.css' => 'cca5fa92',
@ -529,7 +528,7 @@ return array(
'rsrc/js/phui/behavior-phui-tab-group.js' => '0a0b10e9', 'rsrc/js/phui/behavior-phui-tab-group.js' => '0a0b10e9',
'rsrc/js/phuix/PHUIXActionListView.js' => 'b5c256b8', 'rsrc/js/phuix/PHUIXActionListView.js' => 'b5c256b8',
'rsrc/js/phuix/PHUIXActionView.js' => '442efd08', 'rsrc/js/phuix/PHUIXActionView.js' => '442efd08',
'rsrc/js/phuix/PHUIXAutocomplete.js' => 'f6699267', 'rsrc/js/phuix/PHUIXAutocomplete.js' => '4b7430ab',
'rsrc/js/phuix/PHUIXButtonView.js' => 'a37126bd', 'rsrc/js/phuix/PHUIXButtonView.js' => 'a37126bd',
'rsrc/js/phuix/PHUIXDropdownMenu.js' => '8018ee50', 'rsrc/js/phuix/PHUIXDropdownMenu.js' => '8018ee50',
'rsrc/js/phuix/PHUIXExample.js' => '68af71ca', 'rsrc/js/phuix/PHUIXExample.js' => '68af71ca',
@ -803,7 +802,7 @@ return array(
'phabricator-shaped-request' => '7cbe244b', 'phabricator-shaped-request' => '7cbe244b',
'phabricator-slowvote-css' => 'a94b7230', 'phabricator-slowvote-css' => 'a94b7230',
'phabricator-source-code-view-css' => 'aea41829', 'phabricator-source-code-view-css' => 'aea41829',
'phabricator-standard-page-view' => 'eb5b80c5', 'phabricator-standard-page-view' => 'a0dae682',
'phabricator-textareautils' => '320810c8', 'phabricator-textareautils' => '320810c8',
'phabricator-title' => '485aaa6c', 'phabricator-title' => '485aaa6c',
'phabricator-tooltip' => '358b8c04', 'phabricator-tooltip' => '358b8c04',
@ -819,10 +818,10 @@ return array(
'phortune-invoice-css' => '476055e2', 'phortune-invoice-css' => '476055e2',
'phrequent-css' => 'ffc185ad', 'phrequent-css' => 'ffc185ad',
'phriction-document-css' => '4282e4ad', 'phriction-document-css' => '4282e4ad',
'phui-action-panel-css' => '91c7b835', 'phui-action-panel-css' => 'b4798122',
'phui-badge-view-css' => '22c0cf4f', 'phui-badge-view-css' => '22c0cf4f',
'phui-basic-nav-view-css' => 'a0705f53', 'phui-basic-nav-view-css' => 'a0705f53',
'phui-big-info-view-css' => 'd13afcde', 'phui-big-info-view-css' => 'acc3492c',
'phui-box-css' => '745e881d', 'phui-box-css' => '745e881d',
'phui-button-bar-css' => 'f1ff5494', 'phui-button-bar-css' => 'f1ff5494',
'phui-button-css' => '3ca51caa', 'phui-button-css' => '3ca51caa',
@ -852,7 +851,6 @@ return array(
'phui-icon-set-selector-css' => '87db8fee', 'phui-icon-set-selector-css' => '87db8fee',
'phui-icon-view-css' => '5c4a5de6', 'phui-icon-view-css' => '5c4a5de6',
'phui-image-mask-css' => 'a8498f9c', 'phui-image-mask-css' => 'a8498f9c',
'phui-info-panel-css' => '27ea50a1',
'phui-info-view-css' => 'e1b4ec37', 'phui-info-view-css' => 'e1b4ec37',
'phui-inline-comment-view-css' => '65ae3bc2', 'phui-inline-comment-view-css' => '65ae3bc2',
'phui-invisible-character-view-css' => '6993d9f0', 'phui-invisible-character-view-css' => '6993d9f0',
@ -876,14 +874,14 @@ return array(
'phui-tag-view-css' => 'b4719c50', 'phui-tag-view-css' => 'b4719c50',
'phui-theme-css' => '9f261c6b', 'phui-theme-css' => '9f261c6b',
'phui-timeline-view-css' => 'f21db7ca', 'phui-timeline-view-css' => 'f21db7ca',
'phui-two-column-view-css' => '5b8cd553', 'phui-two-column-view-css' => 'ae38a939',
'phui-workboard-color-css' => '783cdff5', 'phui-workboard-color-css' => '783cdff5',
'phui-workboard-view-css' => '3bc85455', 'phui-workboard-view-css' => '3bc85455',
'phui-workcard-view-css' => 'cca5fa92', 'phui-workcard-view-css' => 'cca5fa92',
'phui-workpanel-view-css' => 'a3a63478', 'phui-workpanel-view-css' => 'a3a63478',
'phuix-action-list-view' => 'b5c256b8', 'phuix-action-list-view' => 'b5c256b8',
'phuix-action-view' => '442efd08', 'phuix-action-view' => '442efd08',
'phuix-autocomplete' => 'f6699267', 'phuix-autocomplete' => '4b7430ab',
'phuix-button-view' => 'a37126bd', 'phuix-button-view' => 'a37126bd',
'phuix-dropdown-menu' => '8018ee50', 'phuix-dropdown-menu' => '8018ee50',
'phuix-form-control-view' => '83e03671', 'phuix-form-control-view' => '83e03671',
@ -1239,6 +1237,12 @@ return array(
'javelin-util', 'javelin-util',
'phabricator-shaped-request', 'phabricator-shaped-request',
), ),
'4b7430ab' => array(
'javelin-install',
'javelin-dom',
'phuix-icon-view',
'phabricator-prefab',
),
'4c193c96' => array( '4c193c96' => array(
'javelin-behavior', 'javelin-behavior',
'javelin-uri', 'javelin-uri',
@ -2129,12 +2133,6 @@ return array(
'javelin-util', 'javelin-util',
'javelin-reactor', 'javelin-reactor',
), ),
'f6699267' => array(
'javelin-install',
'javelin-dom',
'phuix-icon-view',
'phabricator-prefab',
),
'f7fc67ec' => array( 'f7fc67ec' => array(
'javelin-install', 'javelin-install',
'javelin-typeahead', 'javelin-typeahead',

View file

@ -48,8 +48,13 @@ if (!$repository) {
} }
if (!$repository->isHosted()) { if (!$repository->isHosted()) {
// This should be redundant, but double check just in case. // In Mercurial, the "pretxnchangegroup" hook fires for both pulls and
throw new Exception(pht('Repository "%s" is not hosted!', $argv[1])); // pushes. Normally we only install the hook for hosted repositories, but
// if a hosted repository is later converted into an observed repository we
// can end up with an observed repository that has the hook installed.
// If we're running hooks from an observed repository, just exit without
// taking action. For more discussion, see PHI24.
return 0;
} }
$engine->setRepository($repository); $engine->setRepository($repository);

View file

@ -747,7 +747,6 @@ phutil_register_library_map(array(
'DiffusionLowLevelGitRefQuery' => 'applications/diffusion/query/lowlevel/DiffusionLowLevelGitRefQuery.php', 'DiffusionLowLevelGitRefQuery' => 'applications/diffusion/query/lowlevel/DiffusionLowLevelGitRefQuery.php',
'DiffusionLowLevelMercurialBranchesQuery' => 'applications/diffusion/query/lowlevel/DiffusionLowLevelMercurialBranchesQuery.php', 'DiffusionLowLevelMercurialBranchesQuery' => 'applications/diffusion/query/lowlevel/DiffusionLowLevelMercurialBranchesQuery.php',
'DiffusionLowLevelMercurialPathsQuery' => 'applications/diffusion/query/lowlevel/DiffusionLowLevelMercurialPathsQuery.php', 'DiffusionLowLevelMercurialPathsQuery' => 'applications/diffusion/query/lowlevel/DiffusionLowLevelMercurialPathsQuery.php',
'DiffusionLowLevelMercurialPathsQueryTests' => 'applications/diffusion/query/lowlevel/__tests__/DiffusionLowLevelMercurialPathsQueryTests.php',
'DiffusionLowLevelParentsQuery' => 'applications/diffusion/query/lowlevel/DiffusionLowLevelParentsQuery.php', 'DiffusionLowLevelParentsQuery' => 'applications/diffusion/query/lowlevel/DiffusionLowLevelParentsQuery.php',
'DiffusionLowLevelQuery' => 'applications/diffusion/query/lowlevel/DiffusionLowLevelQuery.php', 'DiffusionLowLevelQuery' => 'applications/diffusion/query/lowlevel/DiffusionLowLevelQuery.php',
'DiffusionLowLevelResolveRefsQuery' => 'applications/diffusion/query/lowlevel/DiffusionLowLevelResolveRefsQuery.php', 'DiffusionLowLevelResolveRefsQuery' => 'applications/diffusion/query/lowlevel/DiffusionLowLevelResolveRefsQuery.php',
@ -1770,8 +1769,6 @@ phutil_register_library_map(array(
'PHUIImageMaskExample' => 'applications/uiexample/examples/PHUIImageMaskExample.php', 'PHUIImageMaskExample' => 'applications/uiexample/examples/PHUIImageMaskExample.php',
'PHUIImageMaskView' => 'view/phui/PHUIImageMaskView.php', 'PHUIImageMaskView' => 'view/phui/PHUIImageMaskView.php',
'PHUIInfoExample' => 'applications/uiexample/examples/PHUIInfoExample.php', 'PHUIInfoExample' => 'applications/uiexample/examples/PHUIInfoExample.php',
'PHUIInfoPanelExample' => 'applications/uiexample/examples/PHUIInfoPanelExample.php',
'PHUIInfoPanelView' => 'view/phui/PHUIInfoPanelView.php',
'PHUIInfoView' => 'view/form/PHUIInfoView.php', 'PHUIInfoView' => 'view/form/PHUIInfoView.php',
'PHUIInvisibleCharacterTestCase' => 'view/phui/__tests__/PHUIInvisibleCharacterTestCase.php', 'PHUIInvisibleCharacterTestCase' => 'view/phui/__tests__/PHUIInvisibleCharacterTestCase.php',
'PHUIInvisibleCharacterView' => 'view/phui/PHUIInvisibleCharacterView.php', 'PHUIInvisibleCharacterView' => 'view/phui/PHUIInvisibleCharacterView.php',
@ -2645,6 +2642,8 @@ phutil_register_library_map(array(
'PhabricatorDefaultSyntaxStyle' => 'infrastructure/syntax/PhabricatorDefaultSyntaxStyle.php', 'PhabricatorDefaultSyntaxStyle' => 'infrastructure/syntax/PhabricatorDefaultSyntaxStyle.php',
'PhabricatorDesktopNotificationsSetting' => 'applications/settings/setting/PhabricatorDesktopNotificationsSetting.php', 'PhabricatorDesktopNotificationsSetting' => 'applications/settings/setting/PhabricatorDesktopNotificationsSetting.php',
'PhabricatorDesktopNotificationsSettingsPanel' => 'applications/settings/panel/PhabricatorDesktopNotificationsSettingsPanel.php', 'PhabricatorDesktopNotificationsSettingsPanel' => 'applications/settings/panel/PhabricatorDesktopNotificationsSettingsPanel.php',
'PhabricatorDestructibleCodex' => 'applications/system/codex/PhabricatorDestructibleCodex.php',
'PhabricatorDestructibleCodexInterface' => 'applications/system/interface/PhabricatorDestructibleCodexInterface.php',
'PhabricatorDestructibleInterface' => 'applications/system/interface/PhabricatorDestructibleInterface.php', 'PhabricatorDestructibleInterface' => 'applications/system/interface/PhabricatorDestructibleInterface.php',
'PhabricatorDestructionEngine' => 'applications/system/engine/PhabricatorDestructionEngine.php', 'PhabricatorDestructionEngine' => 'applications/system/engine/PhabricatorDestructionEngine.php',
'PhabricatorDestructionEngineExtension' => 'applications/system/engine/PhabricatorDestructionEngineExtension.php', 'PhabricatorDestructionEngineExtension' => 'applications/system/engine/PhabricatorDestructionEngineExtension.php',
@ -3783,6 +3782,7 @@ phutil_register_library_map(array(
'PhabricatorRepositoryCommitTestCase' => 'applications/repository/storage/__tests__/PhabricatorRepositoryCommitTestCase.php', 'PhabricatorRepositoryCommitTestCase' => 'applications/repository/storage/__tests__/PhabricatorRepositoryCommitTestCase.php',
'PhabricatorRepositoryConfigOptions' => 'applications/repository/config/PhabricatorRepositoryConfigOptions.php', 'PhabricatorRepositoryConfigOptions' => 'applications/repository/config/PhabricatorRepositoryConfigOptions.php',
'PhabricatorRepositoryDAO' => 'applications/repository/storage/PhabricatorRepositoryDAO.php', 'PhabricatorRepositoryDAO' => 'applications/repository/storage/PhabricatorRepositoryDAO.php',
'PhabricatorRepositoryDestructibleCodex' => 'applications/repository/codex/PhabricatorRepositoryDestructibleCodex.php',
'PhabricatorRepositoryDiscoveryEngine' => 'applications/repository/engine/PhabricatorRepositoryDiscoveryEngine.php', 'PhabricatorRepositoryDiscoveryEngine' => 'applications/repository/engine/PhabricatorRepositoryDiscoveryEngine.php',
'PhabricatorRepositoryEditor' => 'applications/repository/editor/PhabricatorRepositoryEditor.php', 'PhabricatorRepositoryEditor' => 'applications/repository/editor/PhabricatorRepositoryEditor.php',
'PhabricatorRepositoryEngine' => 'applications/repository/engine/PhabricatorRepositoryEngine.php', 'PhabricatorRepositoryEngine' => 'applications/repository/engine/PhabricatorRepositoryEngine.php',
@ -3859,7 +3859,6 @@ phutil_register_library_map(array(
'PhabricatorRepositoryURITransaction' => 'applications/repository/storage/PhabricatorRepositoryURITransaction.php', 'PhabricatorRepositoryURITransaction' => 'applications/repository/storage/PhabricatorRepositoryURITransaction.php',
'PhabricatorRepositoryURITransactionQuery' => 'applications/repository/query/PhabricatorRepositoryURITransactionQuery.php', 'PhabricatorRepositoryURITransactionQuery' => 'applications/repository/query/PhabricatorRepositoryURITransactionQuery.php',
'PhabricatorRepositoryVCSPassword' => 'applications/repository/storage/PhabricatorRepositoryVCSPassword.php', 'PhabricatorRepositoryVCSPassword' => 'applications/repository/storage/PhabricatorRepositoryVCSPassword.php',
'PhabricatorRepositoryVersion' => 'applications/repository/constants/PhabricatorRepositoryVersion.php',
'PhabricatorRepositoryWorkingCopyVersion' => 'applications/repository/storage/PhabricatorRepositoryWorkingCopyVersion.php', 'PhabricatorRepositoryWorkingCopyVersion' => 'applications/repository/storage/PhabricatorRepositoryWorkingCopyVersion.php',
'PhabricatorRequestExceptionHandler' => 'aphront/handler/PhabricatorRequestExceptionHandler.php', 'PhabricatorRequestExceptionHandler' => 'aphront/handler/PhabricatorRequestExceptionHandler.php',
'PhabricatorResourceSite' => 'aphront/site/PhabricatorResourceSite.php', 'PhabricatorResourceSite' => 'aphront/site/PhabricatorResourceSite.php',
@ -5743,7 +5742,6 @@ phutil_register_library_map(array(
'DiffusionLowLevelGitRefQuery' => 'DiffusionLowLevelQuery', 'DiffusionLowLevelGitRefQuery' => 'DiffusionLowLevelQuery',
'DiffusionLowLevelMercurialBranchesQuery' => 'DiffusionLowLevelQuery', 'DiffusionLowLevelMercurialBranchesQuery' => 'DiffusionLowLevelQuery',
'DiffusionLowLevelMercurialPathsQuery' => 'DiffusionLowLevelQuery', 'DiffusionLowLevelMercurialPathsQuery' => 'DiffusionLowLevelQuery',
'DiffusionLowLevelMercurialPathsQueryTests' => 'PhabricatorTestCase',
'DiffusionLowLevelParentsQuery' => 'DiffusionLowLevelQuery', 'DiffusionLowLevelParentsQuery' => 'DiffusionLowLevelQuery',
'DiffusionLowLevelQuery' => 'Phobject', 'DiffusionLowLevelQuery' => 'Phobject',
'DiffusionLowLevelResolveRefsQuery' => 'DiffusionLowLevelQuery', 'DiffusionLowLevelResolveRefsQuery' => 'DiffusionLowLevelQuery',
@ -6928,8 +6926,6 @@ phutil_register_library_map(array(
'PHUIImageMaskExample' => 'PhabricatorUIExample', 'PHUIImageMaskExample' => 'PhabricatorUIExample',
'PHUIImageMaskView' => 'AphrontTagView', 'PHUIImageMaskView' => 'AphrontTagView',
'PHUIInfoExample' => 'PhabricatorUIExample', 'PHUIInfoExample' => 'PhabricatorUIExample',
'PHUIInfoPanelExample' => 'PhabricatorUIExample',
'PHUIInfoPanelView' => 'AphrontView',
'PHUIInfoView' => 'AphrontTagView', 'PHUIInfoView' => 'AphrontTagView',
'PHUIInvisibleCharacterTestCase' => 'PhabricatorTestCase', 'PHUIInvisibleCharacterTestCase' => 'PhabricatorTestCase',
'PHUIInvisibleCharacterView' => 'AphrontView', 'PHUIInvisibleCharacterView' => 'AphrontView',
@ -7944,6 +7940,7 @@ phutil_register_library_map(array(
'PhabricatorDefaultSyntaxStyle' => 'PhabricatorSyntaxStyle', 'PhabricatorDefaultSyntaxStyle' => 'PhabricatorSyntaxStyle',
'PhabricatorDesktopNotificationsSetting' => 'PhabricatorInternalSetting', 'PhabricatorDesktopNotificationsSetting' => 'PhabricatorInternalSetting',
'PhabricatorDesktopNotificationsSettingsPanel' => 'PhabricatorSettingsPanel', 'PhabricatorDesktopNotificationsSettingsPanel' => 'PhabricatorSettingsPanel',
'PhabricatorDestructibleCodex' => 'Phobject',
'PhabricatorDestructionEngine' => 'Phobject', 'PhabricatorDestructionEngine' => 'Phobject',
'PhabricatorDestructionEngineExtension' => 'Phobject', 'PhabricatorDestructionEngineExtension' => 'Phobject',
'PhabricatorDestructionEngineExtensionModule' => 'PhabricatorConfigModule', 'PhabricatorDestructionEngineExtensionModule' => 'PhabricatorConfigModule',
@ -9248,6 +9245,7 @@ phutil_register_library_map(array(
'PhabricatorFlaggableInterface', 'PhabricatorFlaggableInterface',
'PhabricatorMarkupInterface', 'PhabricatorMarkupInterface',
'PhabricatorDestructibleInterface', 'PhabricatorDestructibleInterface',
'PhabricatorDestructibleCodexInterface',
'PhabricatorProjectInterface', 'PhabricatorProjectInterface',
'PhabricatorSpacesInterface', 'PhabricatorSpacesInterface',
'PhabricatorConduitResultInterface', 'PhabricatorConduitResultInterface',
@ -9290,6 +9288,7 @@ phutil_register_library_map(array(
'PhabricatorRepositoryCommitTestCase' => 'PhabricatorTestCase', 'PhabricatorRepositoryCommitTestCase' => 'PhabricatorTestCase',
'PhabricatorRepositoryConfigOptions' => 'PhabricatorApplicationConfigOptions', 'PhabricatorRepositoryConfigOptions' => 'PhabricatorApplicationConfigOptions',
'PhabricatorRepositoryDAO' => 'PhabricatorLiskDAO', 'PhabricatorRepositoryDAO' => 'PhabricatorLiskDAO',
'PhabricatorRepositoryDestructibleCodex' => 'PhabricatorDestructibleCodex',
'PhabricatorRepositoryDiscoveryEngine' => 'PhabricatorRepositoryEngine', 'PhabricatorRepositoryDiscoveryEngine' => 'PhabricatorRepositoryEngine',
'PhabricatorRepositoryEditor' => 'PhabricatorApplicationTransactionEditor', 'PhabricatorRepositoryEditor' => 'PhabricatorApplicationTransactionEditor',
'PhabricatorRepositoryEngine' => 'Phobject', 'PhabricatorRepositoryEngine' => 'Phobject',
@ -9391,7 +9390,6 @@ phutil_register_library_map(array(
'PhabricatorRepositoryURITransaction' => 'PhabricatorApplicationTransaction', 'PhabricatorRepositoryURITransaction' => 'PhabricatorApplicationTransaction',
'PhabricatorRepositoryURITransactionQuery' => 'PhabricatorApplicationTransactionQuery', 'PhabricatorRepositoryURITransactionQuery' => 'PhabricatorApplicationTransactionQuery',
'PhabricatorRepositoryVCSPassword' => 'PhabricatorRepositoryDAO', 'PhabricatorRepositoryVCSPassword' => 'PhabricatorRepositoryDAO',
'PhabricatorRepositoryVersion' => 'Phobject',
'PhabricatorRepositoryWorkingCopyVersion' => 'PhabricatorRepositoryDAO', 'PhabricatorRepositoryWorkingCopyVersion' => 'PhabricatorRepositoryDAO',
'PhabricatorRequestExceptionHandler' => 'AphrontRequestExceptionHandler', 'PhabricatorRequestExceptionHandler' => 'AphrontRequestExceptionHandler',
'PhabricatorResourceSite' => 'PhabricatorSite', 'PhabricatorResourceSite' => 'PhabricatorSite',

View file

@ -54,7 +54,7 @@ final class PhabricatorAuthFinishController
->addHiddenInput(AphrontRequest::TYPE_HISEC, true) ->addHiddenInput(AphrontRequest::TYPE_HISEC, true)
->appendParagraph( ->appendParagraph(
pht( pht(
'Welcome, %s. To complete the login process, provide your '. 'Welcome, %s. To complete the process of logging in, provide your '.
'multi-factor credentials.', 'multi-factor credentials.',
phutil_tag('strong', array(), $viewer->getUsername()))) phutil_tag('strong', array(), $viewer->getUsername())))
->appendChild($form->buildLayoutView()) ->appendChild($form->buildLayoutView())

View file

@ -92,8 +92,8 @@ final class PhabricatorAuthLoginController
} else { } else {
return $this->renderError( return $this->renderError(
pht( pht(
'The external account ("%s") you just used to login is already '. 'The external account ("%s") you just used to log in is already '.
'associated with another Phabricator user account. Login to the '. 'associated with another Phabricator user account. Log in to the '.
'other Phabricator account and unlink the external account before '. 'other Phabricator account and unlink the external account before '.
'linking it to a new Phabricator account.', 'linking it to a new Phabricator account.',
$provider->getProviderName())); $provider->getProviderName()));
@ -214,7 +214,7 @@ final class PhabricatorAuthLoginController
if (!$provider) { if (!$provider) {
return $this->renderError( return $this->renderError(
pht( pht(
'The account you are attempting to login with uses a nonexistent '. 'The account you are attempting to log in with uses a nonexistent '.
'or disabled authentication provider (with key "%s"). An '. 'or disabled authentication provider (with key "%s"). An '.
'administrator may have recently disabled this provider.', 'administrator may have recently disabled this provider.',
$this->providerKey)); $this->providerKey));
@ -240,14 +240,14 @@ final class PhabricatorAuthLoginController
if ($this->getRequest()->getUser()->isLoggedIn()) { if ($this->getRequest()->getUser()->isLoggedIn()) {
$crumbs->addTextCrumb(pht('Link Account'), $provider->getSettingsURI()); $crumbs->addTextCrumb(pht('Link Account'), $provider->getSettingsURI());
} else { } else {
$crumbs->addTextCrumb(pht('Login'), $this->getApplicationURI('start/')); $crumbs->addTextCrumb(pht('Log In'), $this->getApplicationURI('start/'));
} }
$crumbs->addTextCrumb($provider->getProviderName()); $crumbs->addTextCrumb($provider->getProviderName());
$crumbs->setBorder(true); $crumbs->setBorder(true);
return $this->newPage() return $this->newPage()
->setTitle(pht('Login')) ->setTitle(pht('Log In'))
->setCrumbs($crumbs) ->setCrumbs($crumbs)
->appendChild($content); ->appendChild($content);
} }
@ -257,9 +257,8 @@ final class PhabricatorAuthLoginController
$message) { $message) {
$message = pht( $message = pht(
'Authentication provider ("%s") encountered an error during login. %s', 'Authentication provider ("%s") encountered an error while attempting '.
$provider->getProviderName(), 'to log in. %s', $provider->getProviderName(), $message);
$message);
return $this->renderError($message); return $this->renderError($message);
} }

View file

@ -68,7 +68,7 @@ final class PhabricatorAuthOneTimeLoginController
if (!$token) { if (!$token) {
return $this->newDialog() return $this->newDialog()
->setTitle(pht('Unable to Login')) ->setTitle(pht('Unable to Log In'))
->setShortTitle(pht('Login Failure')) ->setShortTitle(pht('Login Failure'))
->appendParagraph( ->appendParagraph(
pht( pht(
@ -170,7 +170,7 @@ final class PhabricatorAuthOneTimeLoginController
case PhabricatorAuthSessionEngine::ONETIME_USERNAME: case PhabricatorAuthSessionEngine::ONETIME_USERNAME:
case PhabricatorAuthSessionEngine::ONETIME_RESET: case PhabricatorAuthSessionEngine::ONETIME_RESET:
default: default:
$title = pht('Login to Phabricator'); $title = pht('Log in to Phabricator');
break; break;
} }
@ -193,7 +193,7 @@ final class PhabricatorAuthOneTimeLoginController
$dialog = $this->newDialog() $dialog = $this->newDialog()
->setTitle($title) ->setTitle($title)
->addSubmitButton(pht('Login (%s)', $target_user->getUsername())) ->addSubmitButton(pht('Log In (%s)', $target_user->getUsername()))
->addCancelButton('/'); ->addCancelButton('/');
foreach ($body as $paragraph) { foreach ($body as $paragraph) {

View file

@ -483,14 +483,14 @@ final class PhabricatorAuthRegisterController
if ($can_edit_username) { if ($can_edit_username) {
$form->appendChild( $form->appendChild(
id(new AphrontFormTextControl()) id(new AphrontFormTextControl())
->setLabel(pht('Phabricator Username')) ->setLabel(pht('Username'))
->setName('username') ->setName('username')
->setValue($value_username) ->setValue($value_username)
->setError($e_username)); ->setError($e_username));
} else { } else {
$form->appendChild( $form->appendChild(
id(new AphrontFormMarkupControl()) id(new AphrontFormMarkupControl())
->setLabel(pht('Phabricator Username')) ->setLabel(pht('Username'))
->setValue($value_username) ->setValue($value_username)
->setError($e_username)); ->setError($e_username));
} }
@ -546,7 +546,7 @@ final class PhabricatorAuthRegisterController
} else { } else {
$submit $submit
->addCancelButton($this->getApplicationURI('start/')) ->addCancelButton($this->getApplicationURI('start/'))
->setValue(pht('Register Phabricator Account')); ->setValue(pht('Register Account'));
} }
@ -560,7 +560,7 @@ final class PhabricatorAuthRegisterController
} else { } else {
$crumbs->addTextCrumb(pht('Register')); $crumbs->addTextCrumb(pht('Register'));
$crumbs->addTextCrumb($provider->getProviderName()); $crumbs->addTextCrumb($provider->getProviderName());
$title = pht('Phabricator Registration'); $title = pht('Create a New Account');
} }
$crumbs->setBorder(true); $crumbs->setBorder(true);

View file

@ -198,7 +198,7 @@ final class PhabricatorAuthStartController
$crumbs->addTextCrumb(pht('Login')); $crumbs->addTextCrumb(pht('Login'));
$crumbs->setBorder(true); $crumbs->setBorder(true);
$title = pht('Login to Phabricator'); $title = pht('Login');
$view = array( $view = array(
$header, $header,
$invite_message, $invite_message,
@ -239,8 +239,8 @@ final class PhabricatorAuthStartController
return $this->newDialog() return $this->newDialog()
->setTitle(pht('Login Required')) ->setTitle(pht('Login Required'))
->appendParagraph(pht('You must login to take this action.')) ->appendParagraph(pht('You must log in to take this action.'))
->addSubmitButton(pht('Login')) ->addSubmitButton(pht('Log In'))
->addCancelButton('/'); ->addCancelButton('/');
} }

View file

@ -104,7 +104,7 @@ final class PhabricatorAuthUnlinkController
pht( pht(
'You can not unlink this account because you have no other '. 'You can not unlink this account because you have no other '.
'valid login accounts. If you removed it, you would be unable '. 'valid login accounts. If you removed it, you would be unable '.
'to login. Add another authentication method before removing '. 'to log in. Add another authentication method before removing '.
'this one.')) 'this one.'))
->addCancelButton($this->getDoneURI()); ->addCancelButton($this->getDoneURI());

View file

@ -114,7 +114,7 @@ final class PhabricatorEmailLoginController
->setTitle(pht('Check Your Email')) ->setTitle(pht('Check Your Email'))
->setShortTitle(pht('Email Sent')) ->setShortTitle(pht('Email Sent'))
->appendParagraph( ->appendParagraph(
pht('An email has been sent with a link you can use to login.')) pht('An email has been sent with a link you can use to log in.'))
->addCancelButton('/', pht('Done')); ->addCancelButton('/', pht('Done'));
} }
} }

View file

@ -52,9 +52,9 @@ final class PhabricatorLogoutController
if ($viewer->getPHID()) { if ($viewer->getPHID()) {
return $this->newDialog() return $this->newDialog()
->setTitle(pht('Log out of Phabricator?')) ->setTitle(pht('Log Out?'))
->appendChild(pht('Are you sure you want to log out?')) ->appendChild(pht('Are you sure you want to log out?'))
->addSubmitButton(pht('Logout')) ->addSubmitButton(pht('Log Out'))
->addCancelButton('/'); ->addCancelButton('/');
} }

View file

@ -33,7 +33,7 @@ final class PhabricatorMustVerifyEmailController
} }
$must_verify = pht( $must_verify = pht(
'You must verify your email address to login. You should have a '. 'You must verify your email address to log in. You should have a '.
'new email message from Phabricator with verification instructions '. 'new email message from Phabricator with verification instructions '.
'in your inbox (%s).', 'in your inbox (%s).',
phutil_tag('strong', array(), $email_address)); phutil_tag('strong', array(), $email_address));

View file

@ -389,7 +389,7 @@ abstract class PhabricatorAuthProvider extends Phobject {
* @param AphrontRequest HTTP request. * @param AphrontRequest HTTP request.
* @param string Request mode string. * @param string Request mode string.
* @param map Additional parameters, see above. * @param map Additional parameters, see above.
* @return wild Login button. * @return wild Log in button.
*/ */
protected function renderStandardLoginButton( protected function renderStandardLoginButton(
AphrontRequest $request, AphrontRequest $request,
@ -414,9 +414,9 @@ abstract class PhabricatorAuthProvider extends Phobject {
} else if ($mode == 'invite') { } else if ($mode == 'invite') {
$button_text = pht('Register Account'); $button_text = pht('Register Account');
} else if ($this->shouldAllowRegistration()) { } else if ($this->shouldAllowRegistration()) {
$button_text = pht('Login or Register'); $button_text = pht('Log In or Register');
} else { } else {
$button_text = pht('Login'); $button_text = pht('Log In');
} }
$icon = id(new PHUIIconView()) $icon = id(new PHUIIconView())

View file

@ -80,11 +80,11 @@ final class PhabricatorLDAPAuthProvider extends PhabricatorAuthProvider {
$dialog->addCancelButton($this->getSettingsURI()); $dialog->addCancelButton($this->getSettingsURI());
} else { } else {
if ($this->shouldAllowRegistration()) { if ($this->shouldAllowRegistration()) {
$dialog->setTitle(pht('Login or Register with LDAP')); $dialog->setTitle(pht('Log In or Register with LDAP'));
$dialog->addSubmitButton(pht('Login or Register')); $dialog->addSubmitButton(pht('Log In or Register'));
} else { } else {
$dialog->setTitle(pht('Login with LDAP')); $dialog->setTitle(pht('Log In with LDAP'));
$dialog->addSubmitButton(pht('Login')); $dialog->addSubmitButton(pht('Log In'));
} }
if ($mode == 'login') { if ($mode == 'login') {
$dialog->addCancelButton($this->getStartURI()); $dialog->addCancelButton($this->getStartURI());
@ -315,7 +315,7 @@ final class PhabricatorLDAPAuthProvider extends PhabricatorAuthProvider {
"credentials (which is more complicated, but more powerful).\n\n". "credentials (which is more complicated, but more powerful).\n\n".
"For many installs, direct binding is sufficient. However, you may ". "For many installs, direct binding is sufficient. However, you may ".
"want to search first if:\n\n". "want to search first if:\n\n".
" - You want users to be able to login with either their username ". " - You want users to be able to log in with either their username ".
" or their email address.\n". " or their email address.\n".
" - The login/username is not part of the distinguished name in ". " - The login/username is not part of the distinguished name in ".
" your LDAP records.\n". " your LDAP records.\n".
@ -344,16 +344,16 @@ final class PhabricatorLDAPAuthProvider extends PhabricatorAuthProvider {
"`sn`, which will work the same way direct binding works:\n\n". "`sn`, which will work the same way direct binding works:\n\n".
" lang=text,name=Simple Example\n". " lang=text,name=Simple Example\n".
" sn\n\n". " sn\n\n".
"A slightly more complex configuration might let the user login with ". "A slightly more complex configuration might let the user log in with ".
"either their login name or email address:\n\n". "either their login name or email address:\n\n".
" lang=text,name=Match Several Attributes\n". " lang=text,name=Match Several Attributes\n".
" mail\n". " mail\n".
" sn\n\n". " sn\n\n".
"If your LDAP directory is more complex, or you want to perform ". "If your LDAP directory is more complex, or you want to perform ".
"sophisticated filtering, you can use more complex queries. Depending ". "sophisticated filtering, you can use more complex queries. Depending ".
"on your directory structure, this example might allow users to login ". "on your directory structure, this example might allow users to log ".
"with either their email address or username, but only if they're in ". "in with either their email address or username, but only if they're ".
"specific departments:\n\n". "in specific departments:\n\n".
" lang=text,name=Complex Example\n". " lang=text,name=Complex Example\n".
" (&(mail=\${login})(|(departmentNumber=1)(departmentNumber=2)))\n". " (&(mail=\${login})(|(departmentNumber=1)(departmentNumber=2)))\n".
" (&(sn=\${login})(|(departmentNumber=1)(departmentNumber=2)))\n\n". " (&(sn=\${login})(|(departmentNumber=1)(departmentNumber=2)))\n\n".

View file

@ -100,7 +100,7 @@ final class PhabricatorPasswordAuthProvider extends PhabricatorAuthProvider {
public function getDescriptionForCreate() { public function getDescriptionForCreate() {
return pht( return pht(
'Allow users to login or register using a username and password.'); 'Allow users to log in or register using a username and password.');
} }
public function getAdapter() { public function getAdapter() {
@ -174,8 +174,8 @@ final class PhabricatorPasswordAuthProvider extends PhabricatorAuthProvider {
$dialog = id(new AphrontDialogView()) $dialog = id(new AphrontDialogView())
->setSubmitURI($this->getLoginURI()) ->setSubmitURI($this->getLoginURI())
->setUser($viewer) ->setUser($viewer)
->setTitle(pht('Login to Phabricator')) ->setTitle(pht('Log In'))
->addSubmitButton(pht('Login')); ->addSubmitButton(pht('Log In'));
if ($this->shouldAllowRegistration()) { if ($this->shouldAllowRegistration()) {
$dialog->addCancelButton( $dialog->addCancelButton(

View file

@ -108,6 +108,7 @@ final class PhabricatorConduitTokensSettingsPanel
$panel = id(new PHUIObjectBoxView()) $panel = id(new PHUIObjectBoxView())
->setHeader($header) ->setHeader($header)
->setBackground(PHUIObjectBoxView::BLUE_PROPERTY)
->setTable($table); ->setTable($table);
return $panel; return $panel;

View file

@ -99,12 +99,12 @@ final class PhabricatorBinariesSetupCheck extends PhabricatorSetupCheck {
continue; continue;
} }
$version = null; $version = PhutilBinaryAnalyzer::getForBinary($binary)
->getBinaryVersion();
switch ($vcs['versionControlSystem']) { switch ($vcs['versionControlSystem']) {
case PhabricatorRepositoryType::REPOSITORY_TYPE_GIT: case PhabricatorRepositoryType::REPOSITORY_TYPE_GIT:
$bad_versions = array(); $bad_versions = array();
list($err, $stdout, $stderr) = exec_manual('git --version');
$version = trim(substr($stdout, strlen('git version ')));
break; break;
case PhabricatorRepositoryType::REPOSITORY_TYPE_SVN: case PhabricatorRepositoryType::REPOSITORY_TYPE_SVN:
$bad_versions = array( $bad_versions = array(
@ -117,8 +117,6 @@ final class PhabricatorBinariesSetupCheck extends PhabricatorSetupCheck {
'for files added in rN (Subversion issue #2873), fixed in 1.7.2.', 'for files added in rN (Subversion issue #2873), fixed in 1.7.2.',
'svn diff -c N'), 'svn diff -c N'),
); );
list($err, $stdout, $stderr) = exec_manual('svn --version --quiet');
$version = trim($stdout);
break; break;
case PhabricatorRepositoryType::REPOSITORY_TYPE_MERCURIAL: case PhabricatorRepositoryType::REPOSITORY_TYPE_MERCURIAL:
$bad_versions = array( $bad_versions = array(
@ -134,7 +132,6 @@ final class PhabricatorBinariesSetupCheck extends PhabricatorSetupCheck {
'in 2.2.1. Pushing fails with this version as well; see %s.', 'in 2.2.1. Pushing fails with this version as well; see %s.',
'T3046#54922'), 'T3046#54922'),
); );
$version = PhabricatorRepositoryVersion::getMercurialVersion();
break; break;
} }

View file

@ -64,6 +64,29 @@ final class PhabricatorConfigVersionController
$version_from_file); $version_from_file);
} }
$binaries = PhutilBinaryAnalyzer::getAllBinaries();
foreach ($binaries as $binary) {
if (!$binary->isBinaryAvailable()) {
$binary_info = pht('Not Available');
} else {
$version = $binary->getBinaryVersion();
$path = $binary->getBinaryPath();
if ($path === null && $version === null) {
$binary_info = pht('-');
} else if ($path === null) {
$binary_info = $version;
} else if ($version === null) {
$binary_info = pht('- at %s', $path);
} else {
$binary_info = pht('%s at %s', $version, $path);
}
}
$version_property_list->addProperty(
$binary->getBinaryName(),
$binary_info);
}
return $version_property_list; return $version_property_list;
} }

View file

@ -195,7 +195,7 @@ final class ConpherenceViewController extends
->appendChild( ->appendChild(
id(new PHUIButtonView()) id(new PHUIButtonView())
->setTag('a') ->setTag('a')
->setText(pht('Login to Participate')) ->setText(pht('Log In to Participate'))
->setHref((string)$login_href)); ->setHref((string)$login_href));
} }
} }

View file

@ -24,11 +24,12 @@ final class DiffusionLowLevelMercurialPathsQuery
$path = $this->path; $path = $this->path;
$commit = $this->commit; $commit = $this->commit;
$hg_paths_command = 'locate --print0 --rev %s -I %s'; $has_files = PhutilBinaryAnalyzer::getForBinary('hg')
$hg_version = PhabricatorRepositoryVersion::getMercurialVersion(); ->isMercurialFilesCommandAvailable();
if (PhabricatorRepositoryVersion::isMercurialFilesCommandAvailable( if ($has_files) {
$hg_version)) {
$hg_paths_command = 'files --print0 --rev %s -I %s'; $hg_paths_command = 'files --print0 --rev %s -I %s';
} else {
$hg_paths_command = 'locate --print0 --rev %s -I %s';
} }
$match_against = trim($path, '/'); $match_against = trim($path, '/');

View file

@ -1,31 +0,0 @@
<?php
final class DiffusionLowLevelMercurialPathsQueryTests
extends PhabricatorTestCase {
public function testCommandByVersion() {
$cases = array(
array(
'name' => pht('Versions which should not use `files`'),
'versions' => array('2.6.2', '2.9', '3.1'),
'match' => false,
),
array(
'name' => pht('Versions which should use `files`'),
'versions' => array('3.2', '3.3', '3.5.2'),
'match' => true,
),
);
foreach ($cases as $case) {
foreach ($case['versions'] as $version) {
$actual = PhabricatorRepositoryVersion
::isMercurialFilesCommandAvailable($version);
$expect = $case['match'];
$this->assertEqual($expect, $actual, $case['name']);
}
}
}
}

View file

@ -76,7 +76,7 @@ final class PhabricatorFileLightboxController
->appendChild( ->appendChild(
id(new PHUIButtonView()) id(new PHUIButtonView())
->setTag('a') ->setTag('a')
->setText(pht('Login to Comment')) ->setText(pht('Log In to Comment'))
->setHref((string)$login_href)); ->setHref((string)$login_href));
} }

View file

@ -23,7 +23,7 @@ final class PhabricatorOAuthServerApplication extends PhabricatorApplication {
} }
public function getFlavorText() { public function getFlavorText() {
return pht('Login with Phabricator'); return pht('Log In with Phabricator');
} }
public function getApplicationGroup() { public function getApplicationGroup() {

View file

@ -134,6 +134,7 @@ final class PhabricatorOAuthServerAuthorizationsSettingsPanel
$panel = id(new PHUIObjectBoxView()) $panel = id(new PHUIObjectBoxView())
->setHeader($header) ->setHeader($header)
->setBackground(PHUIObjectBoxView::BLUE_PROPERTY)
->setTable($table); ->setTable($table);
return $panel; return $panel;

View file

@ -72,7 +72,7 @@ final class PonderAddAnswerView extends AphrontView {
->appendChild( ->appendChild(
id(new PHUIButtonView()) id(new PHUIButtonView())
->setTag('a') ->setTag('a')
->setText(pht('Login to Answer')) ->setText(pht('Log In to Answer'))
->setHref((string)$login_href)); ->setHref((string)$login_href));
} }

View file

@ -124,38 +124,16 @@ final class PhabricatorProjectEditPictureController
} }
} }
$builtins = array( $root = dirname(phutil_get_library_root('phabricator'));
'projects/v3/book.png', $root = $root.'/resources/builtin/projects/v3/';
'projects/v3/bug.png',
'projects/v3/calendar.png', $builtins = id(new FileFinder($root))
'projects/v3/clipboard.png', ->withType('f')
'projects/v3/cloud.png', ->withFollowSymlinks(true)
'projects/v3/creditcard.png', ->find();
'projects/v3/database.png',
'projects/v3/desktop.png',
'projects/v3/experimental.png',
'projects/v3/flag.png',
'projects/v3/folder.png',
'projects/v3/lightbulb.png',
'projects/v3/lock.png',
'projects/v3/mail.png',
'projects/v3/marker.png',
'projects/v3/mobile.png',
'projects/v3/organization.png',
'projects/v3/people.png',
'projects/v3/piechart.png',
'projects/v3/robot.png',
'projects/v3/rocket.png',
'projects/v3/servers.png',
'projects/v3/sitemap.png',
'projects/v3/tag.png',
'projects/v3/trash.png',
'projects/v3/truck.png',
'projects/v3/umbrella.png',
);
foreach ($builtins as $builtin) { foreach ($builtins as $builtin) {
$file = PhabricatorFile::loadBuiltin($viewer, $builtin); $file = PhabricatorFile::loadBuiltin($viewer, 'projects/v3/'.$builtin);
$images[$file->getPHID()] = array( $images[$file->getPHID()] = array(
'uri' => $file->getBestURI(), 'uri' => $file->getBestURI(),
'tip' => pht('Builtin Image'), 'tip' => pht('Builtin Image'),

View file

@ -0,0 +1,23 @@
<?php
final class PhabricatorRepositoryDestructibleCodex
extends PhabricatorDestructibleCodex {
public function getDestructionNotes() {
$repository = $this->getObject();
$notes = array();
if ($repository->hasLocalWorkingCopy()) {
$notes[] = pht(
'Database records for repository "%s" were destroyed, but this '.
'script does not remove working copies on disk. If you also want to '.
'destroy the repository working copy, manually remove "%s".',
$repository->getDisplayName(),
$repository->getLocalPath());
}
return $notes;
}
}

View file

@ -1,40 +0,0 @@
<?php
final class PhabricatorRepositoryVersion extends Phobject {
public static function getMercurialVersion() {
list($err, $stdout, $stderr) = exec_manual('hg --version --quiet');
// NOTE: At least on OSX, recent versions of Mercurial report this
// string in this format:
//
// Mercurial Distributed SCM (version 3.1.1+20140916)
$matches = null;
$pattern = '/^Mercurial Distributed SCM \(version ([\d.]+)/m';
if (preg_match($pattern, $stdout, $matches)) {
return $matches[1];
}
return null;
}
/**
* The `locate` command is deprecated as of Mercurial 3.2, to be
* replaced with `files` command, which supports most of the same
* arguments. This determines whether the new `files` command should
* be used instead of the `locate` command.
*
* @param string $mercurial_version - The current version of mercurial
* which can be retrieved by calling:
* PhabricatorRepositoryVersion::getMercurialVersion()
*
* @return boolean True if the version of Mercurial is new enough to support
* the `files` command, or false if otherwise.
*/
public static function isMercurialFilesCommandAvailable($mercurial_version) {
$min_version_for_files = '3.2';
return version_compare($mercurial_version, $min_version_for_files, '>=');
}
}

View file

@ -135,6 +135,11 @@ abstract class PhabricatorRepositoryEngine extends Phobject {
$exists = true; $exists = true;
} }
// These URIs may have plaintext HTTP credentials. If they do, censor
// them for display. See T12945.
$display_remote = phutil_censor_credentials($remote_uri);
$display_expect = phutil_censor_credentials($expect_remote);
if (!$valid) { if (!$valid) {
if (!$exists) { if (!$exists) {
// If there's no "origin" remote, just create it regardless of how // If there's no "origin" remote, just create it regardless of how
@ -172,8 +177,8 @@ abstract class PhabricatorRepositoryEngine extends Phobject {
'set the remote URI correctly. To avoid breaking anything, '. 'set the remote URI correctly. To avoid breaking anything, '.
'Phabricator will not automatically fix this.', 'Phabricator will not automatically fix this.',
$repository->getLocalPath(), $repository->getLocalPath(),
$remote_uri, $display_remote,
$expect_remote); $display_expect);
throw new Exception($message); throw new Exception($message);
} }
} }

View file

@ -485,8 +485,8 @@ final class PhabricatorRepositoryPullEngine
// On vulnerable versions of Mercurial, we refuse to clone remotes which // On vulnerable versions of Mercurial, we refuse to clone remotes which
// contain characters which may be interpreted by the shell. // contain characters which may be interpreted by the shell.
$hg_version = PhabricatorRepositoryVersion::getMercurialVersion(); $hg_binary = PhutilBinaryAnalyzer::getForBinary('hg');
$is_vulnerable = version_compare($hg_version, '3.2.4', '<'); $is_vulnerable = $hg_binary->isMercurialVulnerableToInjection();
if ($is_vulnerable) { if ($is_vulnerable) {
$cleartext = $remote->openEnvelope(); $cleartext = $remote->openEnvelope();
// The use of "%R" here is an attempt to limit collateral damage // The use of "%R" here is an attempt to limit collateral damage
@ -501,7 +501,7 @@ final class PhabricatorRepositoryPullEngine
'command injection security vulnerability. The remote URI for '. 'command injection security vulnerability. The remote URI for '.
'this repository (%s) is potentially unsafe. Upgrade Mercurial '. 'this repository (%s) is potentially unsafe. Upgrade Mercurial '.
'to at least 3.2.4 to clone it.', 'to at least 3.2.4 to clone it.',
$hg_version, $hg_binary->getBinaryVersion(),
$repository->getMonogram())); $repository->getMonogram()));
} }
} }

View file

@ -12,6 +12,7 @@ final class PhabricatorRepository extends PhabricatorRepositoryDAO
PhabricatorFlaggableInterface, PhabricatorFlaggableInterface,
PhabricatorMarkupInterface, PhabricatorMarkupInterface,
PhabricatorDestructibleInterface, PhabricatorDestructibleInterface,
PhabricatorDestructibleCodexInterface,
PhabricatorProjectInterface, PhabricatorProjectInterface,
PhabricatorSpacesInterface, PhabricatorSpacesInterface,
PhabricatorConduitResultInterface, PhabricatorConduitResultInterface,
@ -2557,6 +2558,14 @@ final class PhabricatorRepository extends PhabricatorRepositoryDAO
} }
/* -( PhabricatorDestructibleCodexInterface )------------------------------ */
public function newDestructibleCodex() {
return new PhabricatorRepositoryDestructibleCodex();
}
/* -( PhabricatorSpacesInterface )----------------------------------------- */ /* -( PhabricatorSpacesInterface )----------------------------------------- */

View file

@ -554,9 +554,10 @@ final class PhabricatorMySQLFulltextStorageEngine
// "ab.cd", where short substrings are separated by periods, do not produce // "ab.cd", where short substrings are separated by periods, do not produce
// any queryable tokens. These terms are meaningful if at least one // any queryable tokens. These terms are meaningful if at least one
// substring is longer than the minimum length, like "example.py". See // substring is longer than the minimum length, like "example.py". See
// T12928. // T12928. This also applies to words with intermediate apostrophes, like
// "to's".
$parts = preg_split('/[.]+/', $value); $parts = preg_split('/[.\']+/', $value);
foreach ($parts as $part) { foreach ($parts as $part) {
if (phutil_utf8_strlen($part) >= $min_length) { if (phutil_utf8_strlen($part) >= $min_length) {

View file

@ -112,15 +112,27 @@ final class PhabricatorSettingsMainController
$crumbs = $this->buildApplicationCrumbs(); $crumbs = $this->buildApplicationCrumbs();
$crumbs->addTextCrumb($panel->getPanelName()); $crumbs->addTextCrumb($panel->getPanelName());
$crumbs->setBorder(true);
if ($this->user) {
$header_text = pht('Edit Settings (%s)', $user->getUserName());
} else {
$header_text = pht('Edit Global Settings');
}
$header = id(new PHUIHeaderView())
->setHeader($header_text)
->setHeaderIcon('fa-pencil');
$title = $panel->getPanelName(); $title = $panel->getPanelName();
$view = id(new PHUITwoColumnView()) $view = id(new PHUITwoColumnView())
->setNavigation($nav) ->setHeader($header)
->setMainColumn($response); ->setFooter($response);
return $this->newPage() return $this->newPage()
->setTitle($title) ->setTitle($title)
->setNavigation($nav)
->setCrumbs($crumbs) ->setCrumbs($crumbs)
->appendChild($view); ->appendChild($view);

View file

@ -63,7 +63,12 @@ final class PhabricatorSettingsEditEngine
} }
protected function getObjectEditTitleText($object) { protected function getObjectEditTitleText($object) {
return pht('Edit Settings'); $user = $object->getUser();
if ($user) {
return pht('Edit Settings (%s)', $user->getUserName());
} else {
return pht('Edit Global Settings');
}
} }
protected function getObjectEditShortText($object) { protected function getObjectEditShortText($object) {

View file

@ -48,6 +48,7 @@ final class PhabricatorActivitySettingsPanel extends PhabricatorSettingsPanel {
$panel = id(new PHUIObjectBoxView()) $panel = id(new PHUIObjectBoxView())
->setHeaderText(pht('Account Activity Logs')) ->setHeaderText(pht('Account Activity Logs'))
->setBackground(PHUIObjectBoxView::BLUE_PROPERTY)
->setTable($table); ->setTable($table);
$pager_box = id(new PHUIBoxView()) $pager_box = id(new PHUIBoxView())

View file

@ -157,6 +157,7 @@ final class PhabricatorDesktopNotificationsSettingsPanel
->setHeader(pht('Desktop Notifications')) ->setHeader(pht('Desktop Notifications'))
->addActionLink($test_button)) ->addActionLink($test_button))
->setForm($form) ->setForm($form)
->setBackground(PHUIObjectBoxView::BLUE_PROPERTY)
->setInfoView($status_box) ->setInfoView($status_box)
->setFormSaved($request->getBool('saved')); ->setFormSaved($request->getBool('saved'));

View file

@ -22,7 +22,6 @@ abstract class PhabricatorEditEngineSettingsPanel
$engine = id(new PhabricatorSettingsEditEngine()) $engine = id(new PhabricatorSettingsEditEngine())
->setController($this->getController()) ->setController($this->getController())
->setNavigation($this->getNavigation()) ->setNavigation($this->getNavigation())
->setHideHeader(true)
->setIsSelfEdit($is_self) ->setIsSelfEdit($is_self)
->setProfileURI($profile_uri); ->setProfileURI($profile_uri);

View file

@ -153,6 +153,7 @@ final class PhabricatorEmailAddressesSettingsPanel
} }
$view->setHeader($header); $view->setHeader($header);
$view->setTable($table); $view->setTable($table);
$view->setBackground(PHUIObjectBoxView::BLUE_PROPERTY);
return $view; return $view;
} }

View file

@ -136,6 +136,7 @@ final class PhabricatorEmailPreferencesSettingsPanel
->setHeaderText(pht('Email Preferences')) ->setHeaderText(pht('Email Preferences'))
->setFormSaved($request->getStr('saved')) ->setFormSaved($request->getStr('saved'))
->setFormErrors($errors) ->setFormErrors($errors)
->setBackground(PHUIObjectBoxView::BLUE_PROPERTY)
->setForm($form); ->setForm($form);
return $form_box; return $form_box;

View file

@ -131,10 +131,12 @@ final class PhabricatorExternalAccountsSettingsPanel
$linked_box = id(new PHUIObjectBoxView()) $linked_box = id(new PHUIObjectBoxView())
->setHeader($linked_head) ->setHeader($linked_head)
->setBackground(PHUIObjectBoxView::BLUE_PROPERTY)
->setObjectList($linked); ->setObjectList($linked);
$linkable_box = id(new PHUIObjectBoxView()) $linkable_box = id(new PHUIObjectBoxView())
->setHeader($linkable_head) ->setHeader($linkable_head)
->setBackground(PHUIObjectBoxView::BLUE_PROPERTY)
->setObjectList($linkable); ->setObjectList($linkable);
return array( return array(

View file

@ -126,6 +126,7 @@ final class PhabricatorMultiFactorSettingsPanel
$panel->setHeader($header); $panel->setHeader($header);
$panel->setTable($table); $panel->setTable($table);
$panel->setBackground(PHUIObjectBoxView::BLUE_PROPERTY);
return $panel; return $panel;
} }

View file

@ -206,6 +206,7 @@ final class PhabricatorPasswordSettingsPanel extends PhabricatorSettingsPanel {
->setHeaderText(pht('Change Password')) ->setHeaderText(pht('Change Password'))
->setFormSaved($request->getStr('saved')) ->setFormSaved($request->getStr('saved'))
->setFormErrors($errors) ->setFormErrors($errors)
->setBackground(PHUIObjectBoxView::BLUE_PROPERTY)
->setForm($form); ->setForm($form);
return array( return array(

View file

@ -50,6 +50,7 @@ final class PhabricatorSSHKeysSettingsPanel extends PhabricatorSettingsPanel {
$panel->setHeader($header); $panel->setHeader($header);
$panel->setTable($table); $panel->setTable($table);
$panel->setBackground(PHUIObjectBoxView::BLUE_PROPERTY);
return $panel; return $panel;
} }

View file

@ -136,7 +136,8 @@ final class PhabricatorSessionsSettingsPanel extends PhabricatorSettingsPanel {
$panel = id(new PHUIObjectBoxView()) $panel = id(new PHUIObjectBoxView())
->setHeader($header) ->setHeader($header)
->setTable($table); ->setTable($table)
->setBackground(PHUIObjectBoxView::BLUE_PROPERTY);
return $panel; return $panel;
} }

View file

@ -84,6 +84,7 @@ final class PhabricatorTokensSettingsPanel extends PhabricatorSettingsPanel {
$panel = id(new PHUIObjectBoxView()) $panel = id(new PHUIObjectBoxView())
->setHeader($header) ->setHeader($header)
->setBackground(PHUIObjectBoxView::BLUE_PROPERTY)
->setTable($table); ->setTable($table);
return $panel; return $panel;

View file

@ -0,0 +1,66 @@
<?php
abstract class PhabricatorDestructibleCodex
extends Phobject {
private $viewer;
private $object;
public function getDestructionNotes() {
return array();
}
final public function setViewer(PhabricatorUser $viewer) {
$this->viewer = $viewer;
return $this;
}
final public function getViewer() {
return $this->viewer;
}
final public function setObject(
PhabricatorDestructibleCodexInterface $object) {
$this->object = $object;
return $this;
}
final public function getObject() {
return $this->object;
}
final public static function newFromObject(
PhabricatorDestructibleCodexInterface $object,
PhabricatorUser $viewer) {
if (!($object instanceof PhabricatorDestructibleInterface)) {
throw new Exception(
pht(
'Object (of class "%s") implements interface "%s", but must also '.
'implement interface "%s".',
get_class($object),
'PhabricatorDestructibleCodexInterface',
'PhabricatorDestructibleInterface'));
}
$codex = $object->newDestructibleCodex();
if (!($codex instanceof PhabricatorDestructibleCodex)) {
throw new Exception(
pht(
'Object (of class "%s") implements interface "%s", but defines '.
'method "%s" incorrectly: this method must return an object of '.
'class "%s".',
get_class($object),
'PhabricatorDestructibleCodexInterface',
'newDestructibleCodex()',
__CLASS__));
}
$codex
->setObject($object)
->setViewer($viewer);
return $codex;
}
}

View file

@ -3,6 +3,17 @@
final class PhabricatorDestructionEngine extends Phobject { final class PhabricatorDestructionEngine extends Phobject {
private $rootLogID; private $rootLogID;
private $collectNotes;
private $notes = array();
public function setCollectNotes($collect_notes) {
$this->collectNotes = $collect_notes;
return $this;
}
public function getNotes() {
return $this->notes;
}
public function getViewer() { public function getViewer() {
return PhabricatorUser::getOmnipotentUser(); return PhabricatorUser::getOmnipotentUser();
@ -36,6 +47,18 @@ final class PhabricatorDestructionEngine extends Phobject {
$this->rootLogID = $log->getID(); $this->rootLogID = $log->getID();
} }
if ($this->collectNotes) {
if ($object instanceof PhabricatorDestructibleCodexInterface) {
$codex = PhabricatorDestructibleCodex::newFromObject(
$object,
$this->getViewer());
foreach ($codex->getDestructionNotes() as $note) {
$this->notes[] = $note;
}
}
}
$object->destroyObjectPermanently($this); $object->destroyObjectPermanently($this);
if ($object_phid) { if ($object_phid) {

View file

@ -0,0 +1,18 @@
<?php
interface PhabricatorDestructibleCodexInterface {
public function newDestructibleCodex();
}
// TEMPLATE IMPLEMENTATION /////////////////////////////////////////////////////
/* -( PhabricatorDestructibleCodexInterface )------------------------------ */
/*
public function newDestructibleCodex() {
return new <<...>>DestructibleCodex();
}
*/

View file

@ -145,6 +145,7 @@ EOBANNER;
$console->writeOut("%s\n", pht('Destroying objects...')); $console->writeOut("%s\n", pht('Destroying objects...'));
$notes = array();
foreach ($named_objects as $object_name => $object) { foreach ($named_objects as $object_name => $object) {
$console->writeOut( $console->writeOut(
pht( pht(
@ -152,8 +153,14 @@ EOBANNER;
get_class($object), get_class($object),
$object_name)); $object_name));
id(new PhabricatorDestructionEngine()) $engine = id(new PhabricatorDestructionEngine())
->destroyObject($object); ->setCollectNotes(true);
$engine->destroyObject($object);
foreach ($engine->getNotes() as $note) {
$notes[] = $note;
}
} }
$console->writeOut( $console->writeOut(
@ -162,6 +169,12 @@ EOBANNER;
'Permanently destroyed %s object(s).', 'Permanently destroyed %s object(s).',
phutil_count($named_objects))); phutil_count($named_objects)));
if ($notes) {
id(new PhutilConsoleList())
->addItems($notes)
->draw();
}
return 0; return 0;
} }

View file

@ -29,7 +29,6 @@ abstract class PhabricatorEditEngine
private $page; private $page;
private $pages; private $pages;
private $navigation; private $navigation;
private $hideHeader;
final public function setViewer(PhabricatorUser $viewer) { final public function setViewer(PhabricatorUser $viewer) {
$this->viewer = $viewer; $this->viewer = $viewer;
@ -127,15 +126,6 @@ abstract class PhabricatorEditEngine
return $this->navigation; return $this->navigation;
} }
public function setHideHeader($hide_header) {
$this->hideHeader = $hide_header;
return $this;
}
public function getHideHeader() {
return $this->hideHeader;
}
/* -( Managing Fields )---------------------------------------------------- */ /* -( Managing Fields )---------------------------------------------------- */
@ -1194,15 +1184,10 @@ abstract class PhabricatorEditEngine
$crumbs = $this->buildCrumbs($object, $final = true); $crumbs = $this->buildCrumbs($object, $final = true);
if ($this->getHideHeader()) {
$header = null;
$crumbs->setBorder(false);
} else {
$header = id(new PHUIHeaderView()) $header = id(new PHUIHeaderView())
->setHeader($header_text) ->setHeader($header_text)
->setHeaderIcon($header_icon); ->setHeaderIcon($header_icon);
$crumbs->setBorder(true); $crumbs->setBorder(true);
}
if ($action_button) { if ($action_button) {
$header->addActionLink($action_button); $header->addActionLink($action_button);
@ -1231,19 +1216,19 @@ abstract class PhabricatorEditEngine
$view->setHeader($header); $view->setHeader($header);
} }
$navigation = $this->getNavigation();
if ($navigation) {
$view
->setNavigation($navigation)
->setMainColumn($content);
} else {
$view->setFooter($content); $view->setFooter($content);
}
return $controller->newPage() $page = $controller->newPage()
->setTitle($header_text) ->setTitle($header_text)
->setCrumbs($crumbs) ->setCrumbs($crumbs)
->appendChild($view); ->appendChild($view);
$navigation = $this->getNavigation();
if ($navigation) {
$page->setNavigation($navigation);
}
return $page;
} }
protected function newEditResponse( protected function newEditResponse(

View file

@ -199,7 +199,7 @@ class PhabricatorApplicationTransactionCommentView extends AphrontView {
'class' => 'login-to-comment button', 'class' => 'login-to-comment button',
'href' => $uri, 'href' => $uri,
), ),
pht('Login to Comment'))); pht('Log In to Comment')));
} }
$data = array(); $data = array();

View file

@ -11,10 +11,15 @@ final class PHUIActionPanelExample extends PhabricatorUIExample {
} }
public function renderExample() { public function renderExample() {
$viewer = $this->getRequest()->getUser();
$view = id(new AphrontMultiColumnView()) $view = id(new AphrontMultiColumnView())
->setFluidLayout(true); ->setFluidLayout(true);
$credit = PhabricatorFile::loadBuiltin(
$viewer, 'projects/v3/creditcard.png');
$image = $credit->getBestURI();
/* Action Panels */ /* Action Panels */
$panel1 = id(new PHUIActionPanelView()) $panel1 = id(new PHUIActionPanelView())
->setIcon('fa-book') ->setIcon('fa-book')
@ -53,7 +58,7 @@ final class PHUIActionPanelExample extends PhabricatorUIExample {
/* Action Panels */ /* Action Panels */
$panel1 = id(new PHUIActionPanelView()) $panel1 = id(new PHUIActionPanelView())
->setIcon('fa-credit-card') ->setImage($image)
->setHeader(pht('Account Balance')) ->setHeader(pht('Account Balance'))
->setHref('#') ->setHref('#')
->setSubHeader(pht('You were last billed $2,245.12 on Dec 12, 2014.')) ->setSubHeader(pht('You were last billed $2,245.12 on Dec 12, 2014.'))

View file

@ -158,7 +158,7 @@ final class PHUIButtonExample extends PhabricatorUIExample {
->setSize(PHUIButtonView::BIG) ->setSize(PHUIButtonView::BIG)
->setColor(PHUIButtonView::GREY) ->setColor(PHUIButtonView::GREY)
->setIcon($image) ->setIcon($image)
->setText(pht('Login or Register')) ->setText(pht('Log In or Register'))
->setSubtext($icon) ->setSubtext($icon)
->addClass(PHUI::MARGIN_MEDIUM_RIGHT); ->addClass(PHUI::MARGIN_MEDIUM_RIGHT);
} }

View file

@ -1,138 +0,0 @@
<?php
final class PHUIInfoPanelExample extends PhabricatorUIExample {
public function getName() {
return pht('Info Panel');
}
public function getDescription() {
return pht('A medium sized box with bits of gooey information.');
}
public function renderExample() {
$header1 = id(new PHUIHeaderView())
->setHeader(pht('Conpherence'));
$header2 = id(new PHUIHeaderView())
->setHeader(pht('Diffusion'));
$header3 = id(new PHUIHeaderView())
->setHeader(pht('Backend Ops Projects'));
$header4 = id(new PHUIHeaderView())
->setHeader(pht('Revamp Liberty'))
->setSubHeader(pht('For great justice'))
->setImage(
celerity_get_resource_uri('/rsrc/image/people/washington.png'));
$header5 = id(new PHUIHeaderView())
->setHeader(pht('Phacility Redesign'))
->setSubHeader(pht('Move them pixels'))
->setImage(
celerity_get_resource_uri('/rsrc/image/people/harding.png'));
$header6 = id(new PHUIHeaderView())
->setHeader(pht('Python Phlux'))
->setSubHeader(pht('No. Sleep. Till Brooklyn.'))
->setImage(
celerity_get_resource_uri('/rsrc/image/people/taft.png'));
$column1 = id(new PHUIInfoPanelView())
->setHeader($header1)
->setColumns(3)
->addInfoBlock(3, pht('Needs Triage'))
->addInfoBlock(5, pht('Unbreak Now'))
->addInfoBlock(0, pht('High'))
->addInfoBlock(0, pht('Normal'))
->addInfoBlock(12, pht('Low'))
->addInfoBlock(123, pht('Wishlist'));
$column2 = id(new PHUIInfoPanelView())
->setHeader($header2)
->setColumns(3)
->addInfoBlock(3, pht('Needs Triage'))
->addInfoBlock(5, pht('Unbreak Now'))
->addInfoBlock(0, pht('High'))
->addInfoBlock(0, pht('Normal'))
->addInfoBlock(12, pht('Low'))
->addInfoBlock(123, pht('Wishlist'));
$column3 = id(new PHUIInfoPanelView())
->setHeader($header3)
->setColumns(3)
->addInfoBlock(3, pht('Needs Triage'))
->addInfoBlock(5, pht('Unbreak Now'))
->addInfoBlock(0, pht('High'))
->addInfoBlock(0, pht('Normal'))
->addInfoBlock(12, pht('Low'))
->addInfoBlock(123, pht('Wishlist'));
$column4 = id(new PHUIInfoPanelView())
->setHeader($header4)
->setColumns(3)
->setProgress(90)
->addInfoBlock(3, pht('Needs Triage'))
->addInfoBlock(5, pht('Unbreak Now'))
->addInfoBlock(0, pht('High'))
->addInfoBlock(0, pht('Normal'))
->addInfoBlock(0, pht('Wishlist'));
$column5 = id(new PHUIInfoPanelView())
->setHeader($header5)
->setColumns(2)
->setProgress(25)
->addInfoBlock(3, pht('Needs Triage'))
->addInfoBlock(5, pht('Unbreak Now'))
->addInfoBlock(0, pht('High'))
->addInfoBlock(0, pht('Normal'));
$column6 = id(new PHUIInfoPanelView())
->setHeader($header6)
->setColumns(2)
->setProgress(50)
->addInfoBlock(3, pht('Needs Triage'))
->addInfoBlock(5, pht('Unbreak Now'))
->addInfoBlock(0, pht('High'))
->addInfoBlock(0, pht('Normal'));
$layout1 = id(new AphrontMultiColumnView())
->addColumn($column1)
->addColumn($column2)
->addColumn($column3)
->setFluidLayout(true);
$layout2 = id(new AphrontMultiColumnView())
->addColumn($column4)
->addColumn($column5)
->addColumn($column6)
->setFluidLayout(true);
$head1 = id(new PHUIHeaderView())
->setHeader(pht('Flagged'));
$head2 = id(new PHUIHeaderView())
->setHeader(pht('Sprints'));
$wrap1 = id(new PHUIBoxView())
->appendChild($layout1)
->addMargin(PHUI::MARGIN_LARGE_BOTTOM);
$wrap2 = id(new PHUIBoxView())
->appendChild($layout2)
->addMargin(PHUI::MARGIN_LARGE_BOTTOM);
return phutil_tag(
'div',
array(),
array(
$head1,
$wrap1,
$head2,
$wrap2,
));
}
}

View file

@ -19,6 +19,7 @@ final class PhabricatorStandardPageView extends PhabricatorBarePageView
private $showFooter = true; private $showFooter = true;
private $showDurableColumn = true; private $showDurableColumn = true;
private $quicksandConfig = array(); private $quicksandConfig = array();
private $tabs;
private $crumbs; private $crumbs;
private $navigation; private $navigation;
@ -159,6 +160,17 @@ final class PhabricatorStandardPageView extends PhabricatorBarePageView
return $this->crumbs; return $this->crumbs;
} }
public function setTabs(PHUIListView $tabs) {
$tabs->setType(PHUIListView::TABBAR_LIST);
$tabs->addClass('phabricator-standard-page-tabs');
$this->tabs = $tabs;
return $this;
}
public function getTabs() {
return $this->tabs;
}
public function setNavigation(AphrontSideNavFilterView $navigation) { public function setNavigation(AphrontSideNavFilterView $navigation) {
$this->navigation = $navigation; $this->navigation = $navigation;
return $this; return $this;
@ -528,6 +540,7 @@ final class PhabricatorStandardPageView extends PhabricatorBarePageView
$footer = $this->renderFooter(); $footer = $this->renderFooter();
$nav = $this->getNavigation(); $nav = $this->getNavigation();
$tabs = $this->getTabs();
if ($nav) { if ($nav) {
$crumbs = $this->getCrumbs(); $crumbs = $this->getCrumbs();
if ($crumbs) { if ($crumbs) {
@ -541,9 +554,17 @@ final class PhabricatorStandardPageView extends PhabricatorBarePageView
$crumbs = $this->getCrumbs(); $crumbs = $this->getCrumbs();
if ($crumbs) { if ($crumbs) {
if ($this->getTabs()) {
$crumbs->setBorder(true);
}
$content[] = $crumbs; $content[] = $crumbs;
} }
$tabs = $this->getTabs();
if ($tabs) {
$content[] = $tabs;
}
$content[] = $body; $content[] = $body;
$content[] = $footer; $content[] = $footer;

View file

@ -4,6 +4,7 @@ final class PHUIActionPanelView extends AphrontTagView {
private $href; private $href;
private $fontIcon; private $fontIcon;
private $image;
private $header; private $header;
private $subHeader; private $subHeader;
private $bigText; private $bigText;
@ -29,6 +30,11 @@ final class PHUIActionPanelView extends AphrontTagView {
return $this; return $this;
} }
public function setImage($image) {
$this->image = $image;
return $this;
}
public function setBigText($text) { public function setBigText($text) {
$this->bigText = $text; $this->bigText = $text;
return $this; return $this;
@ -89,6 +95,21 @@ final class PHUIActionPanelView extends AphrontTagView {
$fonticon); $fonticon);
} }
if ($this->image) {
$image = phutil_tag(
'img',
array(
'class' => 'phui-action-panel-image',
'src' => $this->image,
));
$icon = phutil_tag(
'span',
array(
'class' => 'phui-action-panel-icon',
),
$image);
}
$header = null; $header = null;
if ($this->header) { if ($this->header) {
$header = phutil_tag( $header = phutil_tag(

View file

@ -5,6 +5,7 @@ final class PHUIBigInfoView extends AphrontTagView {
private $icon; private $icon;
private $title; private $title;
private $description; private $description;
private $image;
private $actions = array(); private $actions = array();
public function setIcon($icon) { public function setIcon($icon) {
@ -22,6 +23,11 @@ final class PHUIBigInfoView extends AphrontTagView {
return $this; return $this;
} }
public function setImage($image) {
$this->image = $image;
return $this;
}
public function addAction(PHUIButtonView $button) { public function addAction(PHUIButtonView $button) {
$this->actions[] = $button; $this->actions[] = $button;
return $this; return $this;
@ -43,6 +49,7 @@ final class PHUIBigInfoView extends AphrontTagView {
protected function getTagContent() { protected function getTagContent() {
require_celerity_resource('phui-big-info-view-css'); require_celerity_resource('phui-big-info-view-css');
if ($this->icon) {
$icon = id(new PHUIIconView()) $icon = id(new PHUIIconView())
->setIcon($this->icon) ->setIcon($this->icon)
->addClass('phui-big-info-icon'); ->addClass('phui-big-info-icon');
@ -53,6 +60,22 @@ final class PHUIBigInfoView extends AphrontTagView {
'class' => 'phui-big-info-icon-container', 'class' => 'phui-big-info-icon-container',
), ),
$icon); $icon);
}
if ($this->image) {
$image = phutil_tag(
'img',
array(
'class' => 'phui-big-info-image',
'src' => $this->image,
));
$icon = phutil_tag(
'span',
array(
'class' => 'phui-big-info-icon-container',
),
$image);
}
$title = phutil_tag( $title = phutil_tag(
'div', 'div',

View file

@ -1,120 +0,0 @@
<?php
final class PHUIInfoPanelView extends AphrontView {
private $header;
private $progress = null;
private $columns = 3;
private $infoblock = array();
protected function canAppendChild() {
return false;
}
public function setHeader(PHUIHeaderView $header) {
$this->header = $header;
return $this;
}
public function setProgress($progress) {
$this->progress = $progress;
return $this;
}
public function setColumns($columns) {
$this->columns = $columns;
return $this;
}
public function addInfoblock($num, $text) {
$this->infoblock[] = array($num, $text);
return $this;
}
public function render() {
require_celerity_resource('phui-info-panel-css');
$trs = array();
$rows = ceil(count($this->infoblock) / $this->columns);
for ($i = 0; $i < $rows; $i++) {
$tds = array();
$ii = 1;
foreach ($this->infoblock as $key => $cell) {
$tds[] = $this->renderCell($cell);
unset($this->infoblock[$key]);
$ii++;
if ($ii > $this->columns) {
break;
}
}
$trs[] = phutil_tag(
'tr',
array(
'class' => 'phui-info-panel-table-row',
),
$tds);
}
$table = phutil_tag(
'table',
array(
'class' => 'phui-info-panel-table',
),
$trs);
$table = id(new PHUIBoxView())
->addPadding(PHUI::PADDING_MEDIUM)
->appendChild($table);
$progress = null;
if ($this->progress) {
$progress = phutil_tag(
'div',
array(
'class' => 'phui-info-panel-progress',
'style' => 'width: '.(int)$this->progress.'%;',
),
null);
}
$box = id(new PHUIObjectBoxView())
->setHeader($this->header)
->appendChild($table)
->appendChild($progress);
return phutil_tag(
'div',
array(
'class' => 'phui-info-panel',
),
$box);
}
private function renderCell($cell) {
$number = phutil_tag(
'div',
array(
'class' => 'phui-info-panel-number',
),
$cell[0]);
$text = phutil_tag(
'div',
array(
'class' => 'phui-info-panel-text',
),
$cell[1]);
return phutil_tag(
'td',
array(
'class' => 'phui-info-panel-table-cell',
'align' => 'center',
'width' => floor(100 / $this->columns).'%',
),
array(
$number,
$text,
));
}
}

View file

@ -6,7 +6,7 @@ final class PHUITwoColumnView extends AphrontTagView {
private $sideColumn = null; private $sideColumn = null;
private $navigation; private $navigation;
private $display; private $display;
private $fluid; private $fixed;
private $header; private $header;
private $subheader; private $subheader;
private $footer; private $footer;
@ -71,8 +71,8 @@ final class PHUITwoColumnView extends AphrontTagView {
return $this->curtain; return $this->curtain;
} }
public function setFluid($fluid) { public function setFixed($fixed) {
$this->fluid = $fluid; $this->fixed = $fixed;
return $this; return $this;
} }
@ -94,8 +94,8 @@ final class PHUITwoColumnView extends AphrontTagView {
$classes[] = 'phui-two-column-view'; $classes[] = 'phui-two-column-view';
$classes[] = $this->getDisplay(); $classes[] = $this->getDisplay();
if ($this->fluid) { if ($this->fixed) {
$classes[] = 'phui-two-column-fluid'; $classes[] = 'phui-two-column-fixed';
} }
if ($this->tabs) { if ($this->tabs) {

View file

@ -176,3 +176,14 @@ a.handle-status-closed:hover {
position: absolute; position: absolute;
left: -50px; left: -50px;
} }
.phabricator-standard-page-tabs {
padding: 0 32px;
margin-bottom: 32px;
background: {$page.content};
box-shadow: 0 0 3px 0 rgba(0,0,0,0.2);
}
.phabricator-standard-page-tabs.phui-list-tabbar .phui-list-item-href {
padding: 12px 24px;
}

View file

@ -47,6 +47,12 @@
display: table-cell; display: table-cell;
} }
.phui-action-panel-image {
width: 48px;
height: 48px;
margin: 0 auto;
}
.phui-action-panel-icon a { .phui-action-panel-icon a {
display: block; display: block;
} }

View file

@ -35,3 +35,10 @@
.phui-big-info-button + .phui-big-info-button { .phui-big-info-button + .phui-big-info-button {
margin-left: 12px; margin-left: 12px;
} }
.phui-big-info-view .phui-big-info-image {
height: 64px;
width: 64px;
margin: 0 auto;
padding-bottom: 12px;
}

View file

@ -1,50 +0,0 @@
/**
* @provides phui-info-panel-css
*/
.phui-info-panel .phui-object-box .phui-header-has-image {
padding: 2px 0 0 2px;
}
.phui-info-panel .phui-object-box .phui-header-image {
margin: 0 8px 0 0;
}
.phui-info-panel-table {
border-collapse: collapse;
border-style: hidden;
width: 100%;
}
.phui-info-panel-table td,
.phui-info-panel-table th {
border: 1px solid {$thinblueborder};
}
.phui-info-panel-table-cell {
padding: 8px;
}
.phui-info-panel-number,
.phui-info-panel-number a {
font-size: 30px;
font-weight: bold;
color: {$lightgreytext};
-webkit-font-smoothing: antialiased;
}
.phui-info-panel-text,
.phui-info-panel-text a {
color: {$lightgreytext};
}
.phui-info-panel-number a:hover,
.phui-info-panel-text a:hover {
color: {$greytext};
text-decoration: none;
}
.phui-info-panel-progress {
background: {$green};
height: 6px;
}

View file

@ -2,6 +2,11 @@
* @provides phui-two-column-view-css * @provides phui-two-column-view-css
*/ */
.phui-two-column-fixed {
max-width: 1140px;
margin: 0 auto;
}
.phui-two-column-view .phui-two-column-header { .phui-two-column-view .phui-two-column-header {
background-color: {$page.content}; background-color: {$page.content};
border-bottom: 1px solid rgba({$alphagrey}, .12); border-bottom: 1px solid rgba({$alphagrey}, .12);

View file

@ -199,7 +199,7 @@ JX.install('PHUIXAutocomplete', {
// to press Alt to type characters like "@" on a German keyboard layout. // to press Alt to type characters like "@" on a German keyboard layout.
// The cost of misfiring autocompleters is very small since we do not // The cost of misfiring autocompleters is very small since we do not
// eat the keystroke. See T10252. // eat the keystroke. See T10252.
if (r.metaKey || r.ctrlKey) { if (r.metaKey || (r.ctrlKey && !r.altKey)) {
return; return;
} }