mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
a2174af992
- Bug 1143038 - Use AppConstants in tabbrowser.xml (r=gavin) (7974d0be4) - Bug 1087726: Make JS callers of ios.newChannel call ios.newChannel2 in browser/ (r=gijs) (995267699) - Bug 1149037 - Make nsLayoutUtils::ComputeSizeForDrawing* take a CSSIntSize param instead of a unit-less nsIntSize. r=roc (34aebc313) - Bug 1149215 - Remove nsLayoutUtils::GetWholeImageDestination that use unitless nsIntSize. r=dholbert (dba5c0392) - Bug 1149222 part 1 - Make nsLayoutUtils::DrawBackgroundImage and SVGImageContext use CSSIntSize instead of unitless nsIntSize. r=dholbert (32052dcf6) - Bug 1149222 part 2 - Make nsSVGImageFrame::PaintSVG use LayoutDeviceSize & LayoutDevicePixel::ToAppUnits, when setting up its dest-rect. r=mats (d7505c2ab) - Bug 1102048 (Part 15, VectorImage) - Make image/src files comply with the Mozilla Coding Style Guide. r=seth (c38d91d61) - do not uselessly run the preprocessor (280c69776) - Bug 1130816 - Bad argument passed to newChannelFromURI2 in WindowsPreviewPerTab.jsm (r=gijs) (70cd2eec7) - AppConstants.jsm changes - Bug 1149334 - Remove preprocessing of nsUpdateService.js and use AppConstants.jsm. r=gavin.sharp (ab53e3bc2) - Bug 1153657 - Performance Monitoring is not ready to ride the trains. r=yoric (582aef2de) - Bug 1140672 - Remove app update file migration code for Windows. r=spohl (c7d6a39ab) - Bug 1137901 - Remove param from refreshUpdateStatus. r=spohl (4d6bfc4e0) - Remove FHR from app update Bug 1121018 - FHR data migration: org.mozilla.update. r=spohl (70db64336) - lost bits of 1. main patch - Bug 843497 - Update check says 'up to date' for out (0975d2954) - 1. File renames for Bug 1136358 - Preprocessing and file includes make it difficult to debug app update tests. r=spohl (c94361eee) - 2. Build changes for Bug 1136358 - Preprocessing and file includes make it difficult to debug app update tests. r=spohl, r=gps (d4f2581a1) - 3. Main patch for Bug 1136358 - Preprocessing and file includes make it difficult to debug app update tests. r=spohl (f4f7e68c6) - 4. Use XPCOMUtils for Bug 1136358 - Preprocessing and file includes make it difficult to debug app update tests. r=spohl (0f4a9df9e) - Bug 1137447 - New app update telemetry for patch type (complete or partial), extended error codes, and general cleanup. r=bbondy (12fb03ead) - Bug 1149590 - Update/Upgrade for application dowloaded and installed, setting to ask/prompt for action ignored. r=spohl (2be30a384) - changes for nsUpdateService.js - Bug 1149334 - Remove preprocessing of nsUpdateService.js and use AppConstants.jsm. r=spohl (e404305ee) - Bug 1139958 - Start using AppConstants.jsm in Toolkit r=mossop (3e39e1160) - Bug 1150688 - Update sections of GMPInstallManager.jsm, which were copied from nsUpdateService.js, to reflect the changes to nsUpdateService.js from bug 1149334. r=spohl (3fa552f68) - Followup patch to Bug 1139958 forgot to add a comment to AppConstants.jsm r=mossop (be2408473)
106 lines
3.6 KiB
JavaScript
106 lines
3.6 KiB
JavaScript
/* 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/. */
|
|
|
|
Components.utils.import("resource://gre/modules/AppConstants.jsm");
|
|
|
|
const USE_HITTEST = /^(win|macosx)/i.test(AppConstants.platform);
|
|
|
|
this.EXPORTED_SYMBOLS = [ "WindowDraggingElement" ];
|
|
|
|
this.WindowDraggingElement = function WindowDraggingElement(elem) {
|
|
this._elem = elem;
|
|
this._window = elem.ownerDocument.defaultView;
|
|
|
|
if (USE_HITTEST && !this.isPanel())
|
|
this._elem.addEventListener("MozMouseHittest", this, false);
|
|
else
|
|
this._elem.addEventListener("mousedown", this, false);
|
|
};
|
|
|
|
WindowDraggingElement.prototype = {
|
|
mouseDownCheck: function(e) { return true; },
|
|
dragTags: ["box", "hbox", "vbox", "spacer", "label", "statusbarpanel", "stack",
|
|
"toolbaritem", "toolbarseparator", "toolbarspring", "toolbarspacer",
|
|
"radiogroup", "deck", "scrollbox", "arrowscrollbox", "tabs"],
|
|
shouldDrag: function(aEvent) {
|
|
if (aEvent.button != 0 ||
|
|
this._window.fullScreen ||
|
|
!this.mouseDownCheck.call(this._elem, aEvent) ||
|
|
aEvent.defaultPrevented)
|
|
return false;
|
|
|
|
let target = aEvent.originalTarget, parent = aEvent.originalTarget;
|
|
|
|
// The target may be inside an embedded iframe or browser. (bug 615152)
|
|
if (target.ownerDocument.defaultView != this._window)
|
|
return false;
|
|
|
|
while (parent != this._elem) {
|
|
let mousethrough = parent.getAttribute("mousethrough");
|
|
if (mousethrough == "always")
|
|
target = parent.parentNode;
|
|
else if (mousethrough == "never")
|
|
break;
|
|
parent = parent.parentNode;
|
|
}
|
|
while (target != this._elem) {
|
|
if (this.dragTags.indexOf(target.localName) == -1)
|
|
return false;
|
|
target = target.parentNode;
|
|
}
|
|
return true;
|
|
},
|
|
isPanel : function() {
|
|
return this._elem instanceof Components.interfaces.nsIDOMXULElement &&
|
|
this._elem.localName == "panel";
|
|
},
|
|
handleEvent: function(aEvent) {
|
|
let isPanel = this.isPanel();
|
|
if (USE_HITTEST && !isPanel) {
|
|
if (this.shouldDrag(aEvent))
|
|
aEvent.preventDefault();
|
|
return;
|
|
}
|
|
|
|
switch (aEvent.type) {
|
|
case "mousedown":
|
|
if (!this.shouldDrag(aEvent))
|
|
return;
|
|
|
|
if (/^gtk/i.test(AppConstants.MOZ_WIDGET_TOOLKIT)) {
|
|
// On GTK, there is a toolkit-level function which handles
|
|
// window dragging, which must be used.
|
|
this._window.beginWindowMove(aEvent, isPanel ? this._elem : null);
|
|
break;
|
|
}
|
|
if (isPanel) {
|
|
let screenRect = this._elem.getOuterScreenRect();
|
|
this._deltaX = aEvent.screenX - screenRect.left;
|
|
this._deltaY = aEvent.screenY - screenRect.top;
|
|
}
|
|
else {
|
|
this._deltaX = aEvent.screenX - this._window.screenX;
|
|
this._deltaY = aEvent.screenY - this._window.screenY;
|
|
}
|
|
this._draggingWindow = true;
|
|
this._window.addEventListener("mousemove", this, false);
|
|
this._window.addEventListener("mouseup", this, false);
|
|
break;
|
|
case "mousemove":
|
|
if (this._draggingWindow) {
|
|
let toDrag = this.isPanel() ? this._elem : this._window;
|
|
toDrag.moveTo(aEvent.screenX - this._deltaX, aEvent.screenY - this._deltaY);
|
|
}
|
|
break;
|
|
case "mouseup":
|
|
if (this._draggingWindow) {
|
|
this._draggingWindow = false;
|
|
this._window.removeEventListener("mousemove", this, false);
|
|
this._window.removeEventListener("mouseup", this, false);
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
}
|