mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-25 08:12:40 +01:00
147302dfa6
Summary: - The dialog has no body text. - It uses an "Ignore" link because it predates action items. Test Plan: {F49894} {F49895} {F49896} Reviewers: chad, btrahan Reviewed By: chad CC: aran Differential Revision: https://secure.phabricator.com/D6433
65 lines
1.9 KiB
PHP
65 lines
1.9 KiB
PHP
<?php
|
|
|
|
final class PhabricatorConfigIgnoreController
|
|
extends PhabricatorApplicationsController {
|
|
|
|
private $verb;
|
|
private $issue;
|
|
|
|
public function willProcessRequest(array $data) {
|
|
$this->verb = $data['verb'];
|
|
$this->issue = $data['key'];
|
|
}
|
|
|
|
public function processRequest() {
|
|
$request = $this->getRequest();
|
|
$issue_uri = $this->getApplicationURI('issue');
|
|
|
|
if ($request->isDialogFormPost()) {
|
|
$this->manageApplication();
|
|
return id(new AphrontRedirectResponse())->setURI($issue_uri);
|
|
}
|
|
|
|
if ($this->verb == 'ignore') {
|
|
$title = pht('Really ignore this setup issue?');
|
|
$submit_title = pht('Ignore');
|
|
$body = pht(
|
|
"You can ignore an issue if you don't want to fix it, or plan to ".
|
|
"fix it later. Ignored issues won't appear on every page but will ".
|
|
"still be shown in the list of open issues.");
|
|
} else if ($this->verb == 'unignore') {
|
|
$title = pht('Unignore this setup issue?');
|
|
$submit_title = pht('Unignore');
|
|
$body = pht(
|
|
"This issue will no longer be suppressed, and will return to its ".
|
|
"rightful place as a global setup warning.");
|
|
} else {
|
|
throw new Exception('Unrecognized verb: ' . $this->verb);
|
|
}
|
|
|
|
$dialog = id(new AphrontDialogView())
|
|
->setUser($request->getUser())
|
|
->setTitle($title)
|
|
->appendChild($body)
|
|
->addSubmitButton($submit_title)
|
|
->addCancelButton($issue_uri);
|
|
|
|
return id(new AphrontDialogResponse())->setDialog($dialog);
|
|
}
|
|
|
|
public function manageApplication() {
|
|
$key = 'config.ignore-issues';
|
|
$config_entry = PhabricatorConfigEntry::loadConfigEntry($key);
|
|
$list = $config_entry->getValue();
|
|
|
|
if (isset($list[$this->issue])) {
|
|
unset($list[$this->issue]);
|
|
} else {
|
|
$list[$this->issue] = true;
|
|
}
|
|
|
|
PhabricatorConfigEditor::storeNewValue(
|
|
$config_entry, $list, $this->getRequest());
|
|
}
|
|
|
|
}
|