(stable) Promote 2017 Week 31
BIN
resources/builtin/projects/v3/archive.png
Normal file
After Width: | Height: | Size: 4.4 KiB |
BIN
resources/builtin/projects/v3/basic-book.png
Normal file
After Width: | Height: | Size: 3.1 KiB |
BIN
resources/builtin/projects/v3/contact.png
Normal file
After Width: | Height: | Size: 6.7 KiB |
BIN
resources/builtin/projects/v3/discussion.png
Normal file
After Width: | Height: | Size: 9.8 KiB |
BIN
resources/builtin/projects/v3/download.png
Normal file
After Width: | Height: | Size: 9.2 KiB |
BIN
resources/builtin/projects/v3/gears.png
Normal file
After Width: | Height: | Size: 16 KiB |
BIN
resources/builtin/projects/v3/gold.png
Normal file
After Width: | Height: | Size: 6.9 KiB |
BIN
resources/builtin/projects/v3/home.png
Normal file
After Width: | Height: | Size: 8.6 KiB |
BIN
resources/builtin/projects/v3/library.png
Normal file
After Width: | Height: | Size: 5.6 KiB |
BIN
resources/builtin/projects/v3/manage.png
Normal file
After Width: | Height: | Size: 6.1 KiB |
BIN
resources/builtin/projects/v3/one-server.png
Normal file
After Width: | Height: | Size: 4 KiB |
BIN
resources/builtin/projects/v3/police-badge.png
Normal file
After Width: | Height: | Size: 12 KiB |
BIN
resources/builtin/projects/v3/purchase-order.png
Normal file
After Width: | Height: | Size: 5.1 KiB |
BIN
resources/builtin/projects/v3/server-documentation.png
Normal file
After Width: | Height: | Size: 5.5 KiB |
BIN
resources/builtin/projects/v3/shield.png
Normal file
After Width: | Height: | Size: 9 KiB |
BIN
resources/builtin/projects/v3/silver.png
Normal file
After Width: | Height: | Size: 5.9 KiB |
BIN
resources/builtin/projects/v3/support.png
Normal file
After Width: | Height: | Size: 4.6 KiB |
BIN
resources/builtin/projects/v3/sword.png
Normal file
After Width: | Height: | Size: 6.6 KiB |
BIN
resources/builtin/projects/v3/three-servers.png
Normal file
After Width: | Height: | Size: 6.5 KiB |
BIN
resources/builtin/projects/v3/two-servers.png
Normal file
After Width: | Height: | Size: 5.3 KiB |
BIN
resources/builtin/projects/v3/upload.png
Normal file
After Width: | Height: | Size: 9.2 KiB |
BIN
resources/builtin/projects/v3/wand.png
Normal file
After Width: | Height: | Size: 8.5 KiB |
|
@ -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',
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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',
|
||||||
|
|
|
@ -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())
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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(
|
||||||
|
@ -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) {
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
|
@ -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,
|
||||||
|
@ -240,7 +240,7 @@ final class PhabricatorAuthStartController
|
||||||
return $this->newDialog()
|
return $this->newDialog()
|
||||||
->setTitle(pht('Login Required'))
|
->setTitle(pht('Login Required'))
|
||||||
->appendParagraph(pht('You must log in to take this action.'))
|
->appendParagraph(pht('You must log in to take this action.'))
|
||||||
->addSubmitButton(pht('Login'))
|
->addSubmitButton(pht('Log In'))
|
||||||
->addCancelButton('/');
|
->addCancelButton('/');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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('/');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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())
|
||||||
|
|
|
@ -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());
|
||||||
|
@ -351,9 +351,9 @@ final class PhabricatorLDAPAuthProvider extends PhabricatorAuthProvider {
|
||||||
" 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".
|
||||||
|
|
|
@ -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(
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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, '/');
|
||||||
|
|
|
@ -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']);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -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));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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() {
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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'),
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -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, '>=');
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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 )----------------------------------------- */
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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())
|
||||||
|
|
|
@ -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'));
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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(
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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(
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -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) {
|
||||||
|
|
|
@ -0,0 +1,18 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
interface PhabricatorDestructibleCodexInterface {
|
||||||
|
|
||||||
|
public function newDestructibleCodex();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// TEMPLATE IMPLEMENTATION /////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
/* -( PhabricatorDestructibleCodexInterface )------------------------------ */
|
||||||
|
/*
|
||||||
|
|
||||||
|
public function newDestructibleCodex() {
|
||||||
|
return new <<...>>DestructibleCodex();
|
||||||
|
}
|
||||||
|
|
||||||
|
*/
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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(
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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.'))
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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,
|
|
||||||
));
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
@ -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(
|
||||||
|
|
|
@ -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',
|
||||||
|
|
|
@ -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,
|
|
||||||
));
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
|
@ -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;
|
|
||||||
}
|
|
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|