mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-07 21:31:02 +01:00
Remove setTimeout() hacks for Javelin behavior initialization
Summary: - Prioritize higher-priority behaviors on the server. - Remove setTimeout() hacks. Test Plan: Loaded Differential, didn't get CSRF races for comment previews. Reviewers: aran, jg, cpojer Reviewed By: jg CC: btrahan, jungejason, aran, epriestley, jg Differential Revision: 1183
This commit is contained in:
parent
4fc37c3dde
commit
c16c920f94
4 changed files with 28 additions and 5 deletions
|
@ -146,9 +146,31 @@ final class CelerityStaticResourceResponse {
|
||||||
|
|
||||||
$onload = array();
|
$onload = array();
|
||||||
if ($this->behaviors) {
|
if ($this->behaviors) {
|
||||||
$behavior = json_encode($this->behaviors);
|
$behaviors = $this->behaviors;
|
||||||
$onload[] = 'JX.initBehaviors('.$behavior.')';
|
|
||||||
$this->behaviors = array();
|
$this->behaviors = array();
|
||||||
|
|
||||||
|
$higher_priority_names = array(
|
||||||
|
'refresh-csrf',
|
||||||
|
);
|
||||||
|
|
||||||
|
$higher_priority_behaviors = array_select_keys(
|
||||||
|
$behaviors,
|
||||||
|
$higher_priority_names);
|
||||||
|
|
||||||
|
foreach ($higher_priority_names as $name) {
|
||||||
|
unset($behaviors[$name]);
|
||||||
|
}
|
||||||
|
|
||||||
|
$behavior_groups = array(
|
||||||
|
$higher_priority_behaviors,
|
||||||
|
$behaviors);
|
||||||
|
|
||||||
|
foreach ($behavior_groups as $group) {
|
||||||
|
if (!$group) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$onload[] = 'JX.initBehaviors('.json_encode($group).')';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($onload) {
|
if ($onload) {
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
phutil_require_module('phabricator', 'infrastructure/celerity/map');
|
phutil_require_module('phabricator', 'infrastructure/celerity/map');
|
||||||
|
|
||||||
phutil_require_module('phutil', 'markup');
|
phutil_require_module('phutil', 'markup');
|
||||||
|
phutil_require_module('phutil', 'utils');
|
||||||
|
|
||||||
|
|
||||||
phutil_require_source('CelerityStaticResourceResponse.php');
|
phutil_require_source('CelerityStaticResourceResponse.php');
|
||||||
|
|
|
@ -30,7 +30,7 @@ JX.behavior('differential-feedback-preview', function(config) {
|
||||||
JX.DOM.listen(content, 'keydown', null, trigger);
|
JX.DOM.listen(content, 'keydown', null, trigger);
|
||||||
JX.DOM.listen(action, 'change', null, trigger);
|
JX.DOM.listen(action, 'change', null, trigger);
|
||||||
|
|
||||||
setTimeout(function() { request.start(); }, 0);
|
request.start();
|
||||||
|
|
||||||
|
|
||||||
function refreshInlinePreview() {
|
function refreshInlinePreview() {
|
||||||
|
@ -46,5 +46,5 @@ JX.behavior('differential-feedback-preview', function(config) {
|
||||||
null,
|
null,
|
||||||
refreshInlinePreview);
|
refreshInlinePreview);
|
||||||
|
|
||||||
setTimeout(refreshInlinePreview, 0);
|
refreshInlinePreview();
|
||||||
});
|
});
|
||||||
|
|
|
@ -46,5 +46,5 @@ JX.behavior('maniphest-transaction-preview', function(config) {
|
||||||
JX.DOM.listen(comments, 'keydown', null, trigger);
|
JX.DOM.listen(comments, 'keydown', null, trigger);
|
||||||
JX.DOM.listen(action, 'change', null, trigger);
|
JX.DOM.listen(action, 'change', null, trigger);
|
||||||
|
|
||||||
setTimeout(function() { request.start(); }, 0);
|
request.start();
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue