mirror of
https://we.phorge.it/source/phorge.git
synced 2025-04-04 00:18:21 +02:00
Use EditEngine for Conpherence preferences
Summary: Ref T4103. Only trick here is hiding the panel if Conpherence is not installed. Test Plan: - Edited Conpherence preferences. - Uninstalled Conpherence, saw panel vanish. Reviewers: chad Reviewed By: chad Maniphest Tasks: T4103 Differential Revision: https://secure.phabricator.com/D16022
This commit is contained in:
parent
d5f924b3fa
commit
ef28adae9a
5 changed files with 23 additions and 58 deletions
|
@ -6689,7 +6689,7 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorConfigWelcomeController' => 'PhabricatorConfigController',
|
'PhabricatorConfigWelcomeController' => 'PhabricatorConfigController',
|
||||||
'PhabricatorConpherenceApplication' => 'PhabricatorApplication',
|
'PhabricatorConpherenceApplication' => 'PhabricatorApplication',
|
||||||
'PhabricatorConpherenceNotificationsSetting' => 'PhabricatorSelectSetting',
|
'PhabricatorConpherenceNotificationsSetting' => 'PhabricatorSelectSetting',
|
||||||
'PhabricatorConpherencePreferencesSettingsPanel' => 'PhabricatorSettingsPanel',
|
'PhabricatorConpherencePreferencesSettingsPanel' => 'PhabricatorEditEngineSettingsPanel',
|
||||||
'PhabricatorConpherenceThreadPHIDType' => 'PhabricatorPHIDType',
|
'PhabricatorConpherenceThreadPHIDType' => 'PhabricatorPHIDType',
|
||||||
'PhabricatorConsoleApplication' => 'PhabricatorApplication',
|
'PhabricatorConsoleApplication' => 'PhabricatorApplication',
|
||||||
'PhabricatorConsoleContentSource' => 'PhabricatorContentSource',
|
'PhabricatorConsoleContentSource' => 'PhabricatorContentSource',
|
||||||
|
|
|
@ -80,11 +80,14 @@ final class PhabricatorSettingsMainController
|
||||||
}
|
}
|
||||||
|
|
||||||
private function buildPanels() {
|
private function buildPanels() {
|
||||||
|
$viewer = $this->getViewer();
|
||||||
$panels = PhabricatorSettingsPanel::getAllDisplayPanels();
|
$panels = PhabricatorSettingsPanel::getAllDisplayPanels();
|
||||||
|
|
||||||
$result = array();
|
$result = array();
|
||||||
foreach ($panels as $key => $panel) {
|
foreach ($panels as $key => $panel) {
|
||||||
$panel->setUser($this->user);
|
$panel
|
||||||
|
->setViewer($viewer)
|
||||||
|
->setUser($this->user);
|
||||||
|
|
||||||
if (!$panel->isEnabled()) {
|
if (!$panel->isEnabled()) {
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -1,16 +1,9 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
final class PhabricatorConpherencePreferencesSettingsPanel
|
final class PhabricatorConpherencePreferencesSettingsPanel
|
||||||
extends PhabricatorSettingsPanel {
|
extends PhabricatorEditEngineSettingsPanel {
|
||||||
|
|
||||||
public function isEnabled() {
|
const PANELKEY = 'conpherence';
|
||||||
return PhabricatorApplication::isClassInstalled(
|
|
||||||
'PhabricatorConpherenceApplication');
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getPanelKey() {
|
|
||||||
return 'conpherence';
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getPanelName() {
|
public function getPanelName() {
|
||||||
return pht('Conpherence Preferences');
|
return pht('Conpherence Preferences');
|
||||||
|
@ -20,51 +13,4 @@ final class PhabricatorConpherencePreferencesSettingsPanel
|
||||||
return PhabricatorSettingsApplicationsPanelGroup::PANELGROUPKEY;
|
return PhabricatorSettingsApplicationsPanelGroup::PANELGROUPKEY;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function processRequest(AphrontRequest $request) {
|
|
||||||
$user = $request->getUser();
|
|
||||||
$preferences = $user->loadPreferences();
|
|
||||||
|
|
||||||
$pref = PhabricatorUserPreferences::PREFERENCE_CONPH_NOTIFICATIONS;
|
|
||||||
|
|
||||||
if ($request->isFormPost()) {
|
|
||||||
$notifications = $request->getInt($pref);
|
|
||||||
$preferences->setPreference($pref, $notifications);
|
|
||||||
$preferences->save();
|
|
||||||
return id(new AphrontRedirectResponse())
|
|
||||||
->setURI($this->getPanelURI('?saved=true'));
|
|
||||||
}
|
|
||||||
|
|
||||||
$form = id(new AphrontFormView())
|
|
||||||
->setUser($user)
|
|
||||||
->appendChild(
|
|
||||||
id(new AphrontFormSelectControl())
|
|
||||||
->setLabel(pht('Conpherence Notifications'))
|
|
||||||
->setName($pref)
|
|
||||||
->setValue($preferences->getPreference($pref))
|
|
||||||
->setOptions(
|
|
||||||
array(
|
|
||||||
ConpherenceSettings::EMAIL_ALWAYS
|
|
||||||
=> pht('Email Always'),
|
|
||||||
ConpherenceSettings::NOTIFICATIONS_ONLY
|
|
||||||
=> pht('Notifications Only'),
|
|
||||||
))
|
|
||||||
->setCaption(
|
|
||||||
pht(
|
|
||||||
'Should Conpherence send emails for updates or '.
|
|
||||||
'notifications only? This global setting can be overridden '.
|
|
||||||
'on a per-thread basis within Conpherence.')))
|
|
||||||
->appendChild(
|
|
||||||
id(new AphrontFormSubmitControl())
|
|
||||||
->setValue(pht('Save Preferences')));
|
|
||||||
|
|
||||||
$form_box = id(new PHUIObjectBoxView())
|
|
||||||
->setHeaderText(pht('Conpherence Preferences'))
|
|
||||||
->setForm($form)
|
|
||||||
->setFormSaved($request->getBool('saved'));
|
|
||||||
|
|
||||||
return array(
|
|
||||||
$form_box,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,6 +38,12 @@ abstract class PhabricatorEditEngineSettingsPanel
|
||||||
return $engine->buildResponse();
|
return $engine->buildResponse();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
final public function isEnabled() {
|
||||||
|
// Only enable the panel if it has any fields.
|
||||||
|
$field_keys = $this->getPanelSettingsKeys();
|
||||||
|
return (bool)$field_keys;
|
||||||
|
}
|
||||||
|
|
||||||
final public function newEditEnginePage() {
|
final public function newEditEnginePage() {
|
||||||
$field_keys = $this->getPanelSettingsKeys();
|
$field_keys = $this->getPanelSettingsKeys();
|
||||||
if (!$field_keys) {
|
if (!$field_keys) {
|
||||||
|
|
|
@ -12,11 +12,21 @@ final class PhabricatorConpherenceNotificationsSetting
|
||||||
return pht('Conpherence Notifications');
|
return pht('Conpherence Notifications');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getSettingPanelKey() {
|
||||||
|
return PhabricatorConpherencePreferencesSettingsPanel::PANELKEY;
|
||||||
|
}
|
||||||
|
|
||||||
protected function getControlInstructions() {
|
protected function getControlInstructions() {
|
||||||
return pht(
|
return pht(
|
||||||
'Choose the default notification behavior for Conpherence rooms.');
|
'Choose the default notification behavior for Conpherence rooms.');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function isEnabledForViewer(PhabricatorUser $viewer) {
|
||||||
|
return PhabricatorApplication::isClassInstalledForViewer(
|
||||||
|
'PhabricatorConpherenceApplication',
|
||||||
|
$viewer);
|
||||||
|
}
|
||||||
|
|
||||||
public function getSettingDefaultValue() {
|
public function getSettingDefaultValue() {
|
||||||
return self::VALUE_CONPHERENCE_EMAIL;
|
return self::VALUE_CONPHERENCE_EMAIL;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue