mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-07 13:21:02 +01:00
08bcb8c30a
Summary: I broke this a bit a few revisions ago by making `phabricator_render_csrf_magic()` return array instead of string without actually grepping for callsites. Instead of building a form in JS, build it in PHP and just change its action in JS. This is simpler and doesn't require us to expose CSRF magic in more places. This change triggered a rather subtle bug: if we rendered a normal form on the page (and thus installed the "disable forms when submitted" behavior), the download button would incorrectly disable after being clicked. This doesn't currently happen in Files because we don't put a form on the same page as the download button. Instead, make the "disable" behavior check if the form is downloading stuff, and not disable stuff if it is. Then mark the lightbox and Files form as both download forms. Test Plan: Used lightbox; used Files. Verified download buttons download the right stuff and behave correctly. Grepped for other download forms, but all the other places where we write "download" don't appear to actually be download links. Reviewers: vrana, btrahan Reviewed By: vrana CC: aran Maniphest Tasks: T2432 Differential Revision: https://secure.phabricator.com/D4685
156 lines
3.4 KiB
PHP
156 lines
3.4 KiB
PHP
<?php
|
|
|
|
final class PhabricatorActionView extends AphrontView {
|
|
|
|
private $name;
|
|
private $icon;
|
|
private $href;
|
|
private $disabled;
|
|
private $workflow;
|
|
private $renderAsForm;
|
|
private $download;
|
|
|
|
public function setDownload($download) {
|
|
$this->download = $download;
|
|
return $this;
|
|
}
|
|
|
|
public function getDownload() {
|
|
return $this->download;
|
|
}
|
|
|
|
public function setHref($href) {
|
|
$this->href = $href;
|
|
return $this;
|
|
}
|
|
|
|
public function setIcon($icon) {
|
|
$this->icon = $icon;
|
|
return $this;
|
|
}
|
|
|
|
public function setName($name) {
|
|
$this->name = $name;
|
|
return $this;
|
|
}
|
|
|
|
public function setDisabled($disabled) {
|
|
$this->disabled = $disabled;
|
|
return $this;
|
|
}
|
|
|
|
public function setWorkflow($workflow) {
|
|
$this->workflow = $workflow;
|
|
return $this;
|
|
}
|
|
|
|
public function setRenderAsForm($form) {
|
|
$this->renderAsForm = $form;
|
|
return $this;
|
|
}
|
|
|
|
public function render() {
|
|
|
|
$icon = null;
|
|
if ($this->icon) {
|
|
|
|
$suffix = '';
|
|
if ($this->disabled) {
|
|
$suffix = '-grey';
|
|
}
|
|
|
|
require_celerity_resource('sprite-icon-css');
|
|
$icon = phutil_tag(
|
|
'span',
|
|
array(
|
|
'class' => 'phabricator-action-view-icon sprite-icon '.
|
|
'action-'.$this->icon.$suffix,
|
|
),
|
|
'');
|
|
}
|
|
|
|
if ($this->href) {
|
|
if ($this->renderAsForm) {
|
|
if (!$this->user) {
|
|
throw new Exception(
|
|
'Call setUser() when rendering an action as a form.');
|
|
}
|
|
|
|
$item = javelin_tag(
|
|
'button',
|
|
array(
|
|
'class' => 'phabricator-action-view-item',
|
|
),
|
|
$this->name);
|
|
|
|
$sigils = array();
|
|
if ($this->workflow) {
|
|
$sigils[] = 'workflow';
|
|
}
|
|
if ($this->download) {
|
|
$sigils[] = 'download';
|
|
}
|
|
|
|
$item = phabricator_render_form(
|
|
$this->user,
|
|
array(
|
|
'action' => $this->href,
|
|
'method' => 'POST',
|
|
'sigil' => implode(' ', $sigils),
|
|
),
|
|
$item);
|
|
} else {
|
|
$item = javelin_tag(
|
|
'a',
|
|
array(
|
|
'href' => $this->href,
|
|
'class' => 'phabricator-action-view-item',
|
|
'sigil' => $this->workflow ? 'workflow' : null,
|
|
),
|
|
$this->name);
|
|
}
|
|
} else {
|
|
$item = phutil_tag(
|
|
'span',
|
|
array(
|
|
'class' => 'phabricator-action-view-item',
|
|
),
|
|
$this->name);
|
|
}
|
|
|
|
$classes = array();
|
|
$classes[] = 'phabricator-action-view';
|
|
if ($this->disabled) {
|
|
$classes[] = 'phabricator-action-view-disabled';
|
|
}
|
|
|
|
return phutil_tag(
|
|
'li',
|
|
array(
|
|
'class' => implode(' ', $classes),
|
|
),
|
|
array($icon, $item));
|
|
}
|
|
|
|
public static function getAvailableIcons() {
|
|
$root = dirname(phutil_get_library_root('phabricator'));
|
|
$path = $root.'/resources/sprite/manifest/icon.json';
|
|
$data = Filesystem::readFile($path);
|
|
$manifest = json_decode($data, true);
|
|
|
|
$results = array();
|
|
$prefix = 'action-';
|
|
foreach ($manifest['sprites'] as $sprite) {
|
|
$name = $sprite['name'];
|
|
if (preg_match('/-(white|grey)$/', $name)) {
|
|
continue;
|
|
}
|
|
if (!strncmp($name, $prefix, strlen($prefix))) {
|
|
$results[] = substr($name, strlen($prefix));
|
|
}
|
|
}
|
|
|
|
return $results;
|
|
}
|
|
|
|
}
|