mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:30:27 +00:00
ff0033e97d
- Bug 1231975 - Part 3: Break a reference cycle between PendingResolution and DNSRequestChild. r=drno (ecf45de535) - Bug 1231975 - Part 4: Add some logging and simplification in TestNrSocket. r=drno (fa811f7743) - Bug 1231975 - Part 5: Fix an intermittent failure caused by the NAT simulator erroneously canceling NR_ASYNC_WAIT_READ. r=drno (e436a8cc75) - var-let (d228288673) - Bug 1256022 - dom/network slow GC on mochitest fix r=dragana (e0dffd5033) - Bug 1231130 - added mHadLocalInstance to constructor.r=jaas (c4f6d0c530) - Bug 1121290: Use "%ls" instead of "%s" in _snwprintf_s format string# r=bsmedberg (e0434aca5a) - Bug 1206952 - Rename MagicRequest to ByteRangeRequest. r=sicking (6780309aa2) - Bug 1206952 - Convert PluginStreamListener to use channel->AsyncOpen2(). r=sicking (8f41f3e148) - Bug 1262335 - Part 2. Remove Android GB/HC defines from OMX. r=snorp (e5b7435d92) - Bug 956899 - Add a std::condition_variable work-alike; r=froydnj (98076c707e) - Bug 1254123 - Handle OOM more gracefully in js::ErrorToException. (r=Waldo) (f9a2ef18d1) - Bug 1255128 - Standard argument coercion in new ArrayBuffer(length). r=nbp. Thanks to snowmantw for tests. (06e5cedd80) - Bug 1251919 - Nuke Debugger wrappers on failure. (r=shu) (64bc41b1f1) - Bug 1254190 - Propagate failure of matchAllDebuggeeGlobals() in Debugger. (r=shu) (927bf01ec5) - Bug 1254172 - Make UnboxedLayout::makeNativeGroup robust to unknownProperties on unboxed type. (r=jandem) (398a6b3aa7) - Bug 1268213 - BlobImplFile::GetTypeRunnable can be a WorkerMainThreadRunnable, r=khuey (30e4ff4b75) - Bug 1250523 - Wait for the markup-view to be loaded in browser_markup_load_01.js; r=gl (acf9e9d88b) - Bug 1230325 - markup-view: skip keyboard shortcuts if any modifier;r=pbrosset (ab974dfac7) - Bug 1155465 - part1: layout-view: use content-type CSS_VALUE for editors;r=miker (d21e70b811) - Bug 1155465 - part2: inplace-editor: disable increment on up/down for PLAIN_TEXT;r=miker (5d72e05f63) - Bug 1241126 - ruleview property: open editor for prop. name on click on ":";r=gl (4889010c34) - Bug 1128340 - Allow renaming with non-ASCII characters in WebIDE. r=jryans (f9844e3afb) - Bug 1039482 - Properly position and style the file name edit field in the projecteditor. r=bgrins (4c29b80958) - Bug 1268231 - Get rid of StopSyncLoopRunnable, r=khuey (29b0a0ed4f) - Bug 1267904 - Add telemetry for WorkerMainThreadRunnable, r=khuey (970d39bcce) - Bug 1261317 - part1: inplace-editor: small refactor of keypress event handler;r=pbro (5261bca85a) - Bug 1261317 - part2: prevent autocomplete on arrow keys in multiline editor;r=pbro (859738623a) - Bug 1246677 - 1 - Make waitForSuccess work with async functions; r=miker (3927347635) - Bug 1227810 - split browser_ruleview_authored.js into three tests; r=pbrosset (f6e4760908) - Bug 1246677 - 2 - Stop using CPOWs in simulateColorPickerChange; r=miker (69a31024cf) - Bug 1246677 - 3 - Remove all usages of getNode in ruleview tests; r=tromey (2f25bec099) - Bug 1240813 - Fixed the unhandled promise rejections in browser_rules_colorpicker-* tests; r=ochameau (bd534ec71b) - Bug 1217328 - let filter editor work on invalid values. r=pbrosset (91602cac94) - Bug 1225236 - Removed the 360 value limit for the hue-rotate field in the CSS filter popup. r=pbro (9bceb9947d) - Bug 1223076 - make FilterWidget handle "unset", "initial", and "inherit". r=pbrosset (6542d5cc99) - Bug 1221156 - make FilterWidget try to preserve URL quoting; r=pbrosset (3e1105c3d5) - Bug 1226543 - fix URL quoting in CSSFilterEditorWidget.getValueAt. r=pbrosset (1770cc279a) - Bug 1241527 - 1 - Fix some unhandled rejected promises in colorpicker, cubicbezier and cssfilter ruleview tests; r=gl (059df355be) - Bug 1241527 - 2 - Use ruleview-changed event to avoid pending requests when browser_rules_search-filter* tests end; r=gl (407d5866b0) - Bug 1241527 - 3 - Fix typo in hideTooltipAndWaitForRuleviewChanged; r=gl (964270c8c3) - Bug 1241527 - 4 - Use ruleview-changed event to avoid pending requests in browser_rules_multiple* tests; r=gl (2947abf296) - Bug 1241527 - 5 - Use ruleview-changed event to fix remaining pending requests in tests; r=gl (5391857e12) - Bug 1246677 - 4 - Stop using content.getComputedStyle in ruleview tests; r=miker (f61cd8d5aa) - Bug 1237885 - fix add-rules_01 intermittent by splitting in two tests;r=gl (45e4de6012) - Bug 1166956 - add valid unit when incrementing CSS value "0";r=tromey (40ca31b909) - Bug 1241155 - correctly use indexOf in browser_rules_user-agent-styles.js; r=bgrins (0966d23f7e) - Bug 1229911 - recognize DevToolsUtils.defineLazyGetter and defineLazyModuleGetter. r=miker (876e4b9f3b) - Bug 1230093 - Make the import-headjs-globals rule store variables correctly; r=Mossop (be3ddcb7fb) - Bug 1229224: Support more forms of defining globals and make anywhere we import scripts use them too. r=miker (c9a243fcae) - Bug 1231963 - handle top-level "this.mumble" assignments in eslint; r=mikeratcliffe (be07835449) - Bug 1224289 - add eslint rule to reject Cu.importGlobalProperties; r=mikeratcliffe (eac54ddcce) - Bug 1241544 - add documentation for this-top-level-scope eslint rule; r=mikeratcliffe (9d832af29d) - Bug 1239426 - handle arrow functions in getASTSource; r=mikeratcliffe (889b5ff89c) - Bug 1242584 - Remove dead code in import-headjs-globals. r=tromey (e7b07c59b3) - Bug 1229224: Support more forms of defining globals and make anywhere we import scripts use them too. r=miker (cf4a3d4d48) - Bug 1242584 - import-globals-from should carry over to tests. r=tromey (f1f7d7269a) - Bug 1224735 - only emit one error per possible CPOW use; r=miker,Ms2ger (621dba76e1) - Bug 1245916: Unify eslint global discovery rules. r=pbrosset (e80d38e097) - Bug 1246677 - 7 - Clean remaining ruleview and tests eslint warnings; r=jdescottes (9415147b5b) - Bug 1246677 - 5 - Get rid of 'content' in ruleview test files; r=jdescottes (d868fde632) - Bug 1209295 - Ensure browser_rules_add-property-cancel_02.js waits for the correct change notification. r=pbrosset (4099437554) - Bug 1240778 - Fixed the unhandled promise rejection in browser_rules_add-property_01.js; r=ochameau (838bd1f99c) - Bug 1246677 - 8 - Use addProperty and remove code duplication; r=gl (2c33059028) - Bug 1246677 - 9 - Get rid of all remaining _applyingModifications usage in tests; r=ochameau (a9bc3b2495) - Bug 1143742 - part1: multiline inplace editor: cleanup existing tests;r=gl (2bc96e58d3) - Bug 1243695 - ensure caret is visible in ruleview prop editor;r=miker (3353a5a77c) - Bug 1143742 - part2: multiline inplace-editor should support a maxWidth option;r=gl (98809c04cb) - Bug 1178462 - Cancel inplace editor autocomplete on window blur;r=gl (c4af4c03d2) - Bug 1261827 - inplace-editor: copyTextStyles should not copy line-height property;r=pbro (1fc8d7d432) - Bug 1069829 - 1 - Remove a usage of domUtils.cssPropertyIsValid in inplace-editor; r=tromey (7898eed84b) - Bug 1143742 - part3: multiline inplace-editor autocomplete behavior;r=gl (53b369dccb) - Bug 1143742 - part4: add textarea to valid targets when copying;r=gl (84af495716) - Bug 1143742 - part5: fix eslint error in inspector ruleview test;r=bustage (d7a53a6217) - Bug 1249888 - try/catch SourceMapConsumer to avoid empty rule-view when source map is invalid; r=gl (c78a7a6ac7) - Bug 1255787 - Do not assume sourceMap appears only in external stylesheets; r=gl (7c69e1e559) - Bug 1029459 - remove output-parser iteration limit. r=pbrosset (f2438a8642) - Bug 1250835 - Display swatch for angles in the rules panel. r=miker (87721e80f2) - Bug 1259777 - Remove unnecessary DOMUtils lazy load in css-angle.js . r=pbro (e199a014d5) - Bug 1259559 - Units cycling with shift+click persists value in Style editor. r=miker (b7074813e9) - Bug 1245996 - inspector: fix xul scrollbars stealing focus;r=pbro (bcb19ffa83) - Bug 1180349 - Increase the timeout for browser_markupview_links_01.js (b67cd0d2be) - Bug 1253935 - Remove all CPOW usages in styleeditor tests and use ContentTask instead of custom frame-script; r=ochameau (485308e7b1) - Bug 1257246: Update devtools for eslint 2. r=pbro (c04f7f3046) - Bug 1264968 part 2 - Allow persisting attributes of xul:window if its owner document is not root. r=enndeakin (ca8182b534) - Bug 1244948 - silence the 'loaded script twice' warning. r=bz (fa571b837c)
339 lines
11 KiB
JavaScript
339 lines
11 KiB
JavaScript
/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*- */
|
|
/* vim: set ft=javascript ts=2 et sw=2 tw=80: */
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
/* import-globals-from animation-controller.js */
|
|
/* globals document */
|
|
|
|
"use strict";
|
|
|
|
const {AnimationsTimeline} = require("devtools/client/animationinspector/components/animation-timeline");
|
|
const {RateSelector} = require("devtools/client/animationinspector/components/rate-selector");
|
|
const {formatStopwatchTime} = require("devtools/client/animationinspector/utils");
|
|
|
|
var $ = (selector, target = document) => target.querySelector(selector);
|
|
|
|
/**
|
|
* The main animations panel UI.
|
|
*/
|
|
var AnimationsPanel = {
|
|
UI_UPDATED_EVENT: "ui-updated",
|
|
PANEL_INITIALIZED: "panel-initialized",
|
|
|
|
initialize: Task.async(function* () {
|
|
if (AnimationsController.destroyed) {
|
|
console.warn("Could not initialize the animation-panel, controller " +
|
|
"was destroyed");
|
|
return;
|
|
}
|
|
if (this.initialized) {
|
|
yield this.initialized.promise;
|
|
return;
|
|
}
|
|
this.initialized = promise.defer();
|
|
|
|
this.playersEl = $("#players");
|
|
this.errorMessageEl = $("#error-message");
|
|
this.pickerButtonEl = $("#element-picker");
|
|
this.toggleAllButtonEl = $("#toggle-all");
|
|
this.playTimelineButtonEl = $("#pause-resume-timeline");
|
|
this.rewindTimelineButtonEl = $("#rewind-timeline");
|
|
this.timelineCurrentTimeEl = $("#timeline-current-time");
|
|
this.rateSelectorEl = $("#timeline-rate");
|
|
|
|
this.rewindTimelineButtonEl.setAttribute("title",
|
|
L10N.getStr("timeline.rewindButtonTooltip"));
|
|
|
|
// If the server doesn't support toggling all animations at once, hide the
|
|
// whole global toolbar.
|
|
if (!AnimationsController.traits.hasToggleAll) {
|
|
$("#global-toolbar").style.display = "none";
|
|
}
|
|
|
|
// Binding functions that need to be called in scope.
|
|
for (let functionName of ["onKeyDown", "onPickerStarted",
|
|
"onPickerStopped", "refreshAnimationsUI", "onToggleAllClicked",
|
|
"onTabNavigated", "onTimelineDataChanged", "onTimelinePlayClicked",
|
|
"onTimelineRewindClicked", "onRateChanged"]) {
|
|
this[functionName] = this[functionName].bind(this);
|
|
}
|
|
let hUtils = gToolbox.highlighterUtils;
|
|
this.togglePicker = hUtils.togglePicker.bind(hUtils);
|
|
|
|
this.animationsTimelineComponent = new AnimationsTimeline(gInspector,
|
|
AnimationsController.traits);
|
|
this.animationsTimelineComponent.init(this.playersEl);
|
|
|
|
if (AnimationsController.traits.hasSetPlaybackRate) {
|
|
this.rateSelectorComponent = new RateSelector();
|
|
this.rateSelectorComponent.init(this.rateSelectorEl);
|
|
}
|
|
|
|
this.startListeners();
|
|
|
|
yield this.refreshAnimationsUI();
|
|
|
|
this.initialized.resolve();
|
|
this.emit(this.PANEL_INITIALIZED);
|
|
}),
|
|
|
|
destroy: Task.async(function* () {
|
|
if (!this.initialized) {
|
|
return;
|
|
}
|
|
|
|
if (this.destroyed) {
|
|
yield this.destroyed.promise;
|
|
return;
|
|
}
|
|
this.destroyed = promise.defer();
|
|
|
|
this.stopListeners();
|
|
|
|
this.animationsTimelineComponent.destroy();
|
|
this.animationsTimelineComponent = null;
|
|
|
|
if (this.rateSelectorComponent) {
|
|
this.rateSelectorComponent.destroy();
|
|
this.rateSelectorComponent = null;
|
|
}
|
|
|
|
this.playersEl = this.errorMessageEl = null;
|
|
this.toggleAllButtonEl = this.pickerButtonEl = null;
|
|
this.playTimelineButtonEl = this.rewindTimelineButtonEl = null;
|
|
this.timelineCurrentTimeEl = this.rateSelectorEl = null;
|
|
|
|
this.destroyed.resolve();
|
|
}),
|
|
|
|
startListeners: function() {
|
|
AnimationsController.on(AnimationsController.PLAYERS_UPDATED_EVENT,
|
|
this.refreshAnimationsUI);
|
|
|
|
this.pickerButtonEl.addEventListener("click", this.togglePicker);
|
|
gToolbox.on("picker-started", this.onPickerStarted);
|
|
gToolbox.on("picker-stopped", this.onPickerStopped);
|
|
|
|
this.toggleAllButtonEl.addEventListener("click", this.onToggleAllClicked);
|
|
this.playTimelineButtonEl.addEventListener(
|
|
"click", this.onTimelinePlayClicked);
|
|
this.rewindTimelineButtonEl.addEventListener(
|
|
"click", this.onTimelineRewindClicked);
|
|
|
|
document.addEventListener("keydown", this.onKeyDown, false);
|
|
|
|
gToolbox.target.on("navigate", this.onTabNavigated);
|
|
|
|
this.animationsTimelineComponent.on("timeline-data-changed",
|
|
this.onTimelineDataChanged);
|
|
|
|
if (this.rateSelectorComponent) {
|
|
this.rateSelectorComponent.on("rate-changed", this.onRateChanged);
|
|
}
|
|
},
|
|
|
|
stopListeners: function() {
|
|
AnimationsController.off(AnimationsController.PLAYERS_UPDATED_EVENT,
|
|
this.refreshAnimationsUI);
|
|
|
|
this.pickerButtonEl.removeEventListener("click", this.togglePicker);
|
|
gToolbox.off("picker-started", this.onPickerStarted);
|
|
gToolbox.off("picker-stopped", this.onPickerStopped);
|
|
|
|
this.toggleAllButtonEl.removeEventListener("click",
|
|
this.onToggleAllClicked);
|
|
this.playTimelineButtonEl.removeEventListener("click",
|
|
this.onTimelinePlayClicked);
|
|
this.rewindTimelineButtonEl.removeEventListener("click",
|
|
this.onTimelineRewindClicked);
|
|
|
|
document.removeEventListener("keydown", this.onKeyDown, false);
|
|
|
|
gToolbox.target.off("navigate", this.onTabNavigated);
|
|
|
|
this.animationsTimelineComponent.off("timeline-data-changed",
|
|
this.onTimelineDataChanged);
|
|
|
|
if (this.rateSelectorComponent) {
|
|
this.rateSelectorComponent.off("rate-changed", this.onRateChanged);
|
|
}
|
|
},
|
|
|
|
onKeyDown: function(event) {
|
|
let keyEvent = Ci.nsIDOMKeyEvent;
|
|
|
|
// If the space key is pressed, it should toggle the play state of
|
|
// the animations displayed in the panel, or of all the animations on
|
|
// the page if the selected node does not have any animation on it.
|
|
if (event.keyCode === keyEvent.DOM_VK_SPACE) {
|
|
if (AnimationsController.animationPlayers.length > 0) {
|
|
this.playPauseTimeline().catch(ex => console.error(ex));
|
|
} else {
|
|
this.toggleAll().catch(ex => console.error(ex));
|
|
}
|
|
event.preventDefault();
|
|
}
|
|
},
|
|
|
|
togglePlayers: function(isVisible) {
|
|
if (isVisible) {
|
|
document.body.removeAttribute("empty");
|
|
document.body.setAttribute("timeline", "true");
|
|
} else {
|
|
document.body.setAttribute("empty", "true");
|
|
document.body.removeAttribute("timeline");
|
|
$("#error-type").textContent =
|
|
L10N.getStr("panel.invalidElementSelected");
|
|
}
|
|
},
|
|
|
|
onPickerStarted: function() {
|
|
this.pickerButtonEl.setAttribute("checked", "true");
|
|
},
|
|
|
|
onPickerStopped: function() {
|
|
this.pickerButtonEl.removeAttribute("checked");
|
|
},
|
|
|
|
onToggleAllClicked: function() {
|
|
this.toggleAll().catch(ex => console.error(ex));
|
|
},
|
|
|
|
/**
|
|
* Toggle (pause/play) all animations in the current target
|
|
* and update the UI the toggleAll button.
|
|
*/
|
|
toggleAll: Task.async(function* () {
|
|
this.toggleAllButtonEl.classList.toggle("paused");
|
|
yield AnimationsController.toggleAll();
|
|
}),
|
|
|
|
onTimelinePlayClicked: function() {
|
|
this.playPauseTimeline().catch(ex => console.error(ex));
|
|
},
|
|
|
|
/**
|
|
* Depending on the state of the timeline either pause or play the animations
|
|
* displayed in it.
|
|
* If the animations are finished, this will play them from the start again.
|
|
* If the animations are playing, this will pause them.
|
|
* If the animations are paused, this will resume them.
|
|
*
|
|
* @return {Promise} Resolves when the playState is changed and the UI
|
|
* is refreshed
|
|
*/
|
|
playPauseTimeline: function() {
|
|
return AnimationsController
|
|
.toggleCurrentAnimations(this.timelineData.isMoving)
|
|
.then(() => this.refreshAnimationsStateAndUI());
|
|
},
|
|
|
|
onTimelineRewindClicked: function() {
|
|
this.rewindTimeline().catch(ex => console.error(ex));
|
|
},
|
|
|
|
/**
|
|
* Reset the startTime of all current animations shown in the timeline and
|
|
* pause them.
|
|
*
|
|
* @return {Promise} Resolves when currentTime is set and the UI is refreshed
|
|
*/
|
|
rewindTimeline: function() {
|
|
return AnimationsController
|
|
.setCurrentTimeAll(0, true)
|
|
.then(() => this.refreshAnimationsStateAndUI());
|
|
},
|
|
|
|
/**
|
|
* Set the playback rate of all current animations shown in the timeline to
|
|
* the value of this.rateSelectorEl.
|
|
*/
|
|
onRateChanged: function(e, rate) {
|
|
AnimationsController.setPlaybackRateAll(rate)
|
|
.then(() => this.refreshAnimationsStateAndUI())
|
|
.catch(ex => console.error(ex));
|
|
},
|
|
|
|
onTabNavigated: function() {
|
|
this.toggleAllButtonEl.classList.remove("paused");
|
|
},
|
|
|
|
onTimelineDataChanged: function(e, data) {
|
|
this.timelineData = data;
|
|
let {isMoving, isUserDrag, time} = data;
|
|
|
|
this.playTimelineButtonEl.classList.toggle("paused", !isMoving);
|
|
|
|
let l10nPlayProperty = isMoving ? "timeline.resumedButtonTooltip" :
|
|
"timeline.pausedButtonTooltip";
|
|
|
|
this.playTimelineButtonEl.setAttribute("title",
|
|
L10N.getStr(l10nPlayProperty));
|
|
|
|
// If the timeline data changed as a result of the user dragging the
|
|
// scrubber, then pause all animations and set their currentTimes.
|
|
// (Note that we want server-side requests to be sequenced, so we only do
|
|
// this after the previous currentTime setting was done).
|
|
if (isUserDrag && !this.setCurrentTimeAllPromise) {
|
|
this.setCurrentTimeAllPromise =
|
|
AnimationsController.setCurrentTimeAll(time, true)
|
|
.catch(error => console.error(error))
|
|
.then(() => {
|
|
this.setCurrentTimeAllPromise = null;
|
|
});
|
|
}
|
|
|
|
this.displayTimelineCurrentTime();
|
|
},
|
|
|
|
displayTimelineCurrentTime: function() {
|
|
let {time} = this.timelineData;
|
|
this.timelineCurrentTimeEl.textContent = formatStopwatchTime(time);
|
|
},
|
|
|
|
/**
|
|
* Make sure all known animations have their states up to date (which is
|
|
* useful after the playState or currentTime has been changed and in case the
|
|
* animations aren't auto-refreshing), and then refresh the UI.
|
|
*/
|
|
refreshAnimationsStateAndUI: Task.async(function* () {
|
|
for (let player of AnimationsController.animationPlayers) {
|
|
yield player.refreshState();
|
|
}
|
|
yield this.refreshAnimationsUI();
|
|
}),
|
|
|
|
/**
|
|
* Refresh the list of animations UI. This will empty the panel and re-render
|
|
* the various components again.
|
|
*/
|
|
refreshAnimationsUI: Task.async(function* () {
|
|
// Empty the whole panel first.
|
|
this.togglePlayers(true);
|
|
|
|
// Re-render the timeline component.
|
|
this.animationsTimelineComponent.render(
|
|
AnimationsController.animationPlayers,
|
|
AnimationsController.documentCurrentTime);
|
|
|
|
// Re-render the rate selector component.
|
|
if (this.rateSelectorComponent) {
|
|
this.rateSelectorComponent.render(AnimationsController.animationPlayers);
|
|
}
|
|
|
|
// If there are no players to show, show the error message instead and
|
|
// return.
|
|
if (!AnimationsController.animationPlayers.length) {
|
|
this.togglePlayers(false);
|
|
this.emit(this.UI_UPDATED_EVENT);
|
|
return;
|
|
}
|
|
|
|
this.emit(this.UI_UPDATED_EVENT);
|
|
})
|
|
};
|
|
|
|
EventEmitter.decorate(AnimationsPanel);
|