mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
59e31c9007
- Bug 1182987 - Part 1: Remove unreferenced files immediately; r=baku (3ced56ca25) - Bug 1182987 - Part 2: Add getQuotaObjects() to mozIStorageConnection; r=mak (64b4dc418c) - Bug 1182987 - Part 3: Add "cleanup" transaction with disabled quota checks and vacuuming/checkpointing after commit; r=baku (7c19f28ae2) - Bug 1182987 - Part 4: Add a test for QuotaExceededError recovery and the new "cleanup" transaction type; r=baku (f91935e737) - Bug 1182987 - Part 5: Change mode of "readwrite" transaction to "cleanup" after QuotaExceeded is fired; r=baku (79d709970d) - Bug 1257725 part 3. Get rid of ThreadsafeAutoJSContext usage in Promise code. r=bholley (405d3c03d4) - Bug 1257725 part 1. Get rid of ThreadsafeAutoJSContext usage in JSEventHandler::HandleEvent. r=smaug (3222a73565) - Bug 1257725 part 4. Get rid of ThreadsafeAutoJSContext usage in IndexedDB code, except for IDBRequest::CaptureCaller. r=khuey (8ad88560f0) - Bug 1257725 part 5. Get rid of ThreadsafeAutoJSContext usage in IDBRequest::CaptureCaller. r=khuey (50a1f05ec9) - Bug 1257725 part 6. Get rid of ThreadsafeAutoJSContext. r=bholley (8968c69fcc) - Bug 1247420 - part1: removeContentState. r=smaug (6c7a54b58e) - Bug 1247420 - part2: IPC hover state management for select. r=Felipc (c7809aec7c) - Bug 1223533 - Don't hide the select popup on irrelevant pagehide events. r=mconley (0cf218515a) - Bug 1253486, [e10s only] hide select popups when the select element is removed, r=mconley (8a7049b6f1) - Bug 1180827 - Fix reuse of previous search results. r=MattN (6b4e65d318) - Bug 1242208 - Fix cached form history results with a datalist present. r=MattN (10078ada31) - Bug 1252074 - test_form_autocomplete.html and test_form_autocomplete_with_list.html should pass on e10s. r=paolo (8a9cf4a5f1) - Bug 1260441 - Never pass a null js context to OpenCursor() r=bz (8d818b0257) - Bug 1170045 - part 2 - use SegmentedVector in the DeferredFinalize implementation; r=mccr8 (3954a5e390) - Bug 1265770. Don't try to get a prototype for the interface object for an interface that's [NoInterfaceObject], since it's just unnecessary work that can't even be done at all in some cases (e.g. when the parent interface is also [NoInterfaceObject]). r=peterv (53d3077e31) - Bug 1264187 - check for a ProtoAndIfaceCache before blindly destroying it; r=bz (97536e815b) - Bug 1104955 part 3. Pass our unscopable names to CreateInterfaceObjects and have it define the right thing on the prototype. r=khuey (48386ab6b5) - Bug 934889: Use JS_InitStandardClasses everywhere now that it works. r=bz (01d545259a) - Bug 1258585. Remove some remaining vestiges of WebIDL quickstubs. r=peterv (3fa02388f1)
148 lines
4.6 KiB
JavaScript
148 lines
4.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/. */
|
|
|
|
"use strict";
|
|
|
|
const Cc = Components.classes;
|
|
const Ci = Components.interfaces;
|
|
const Cu = Components.utils;
|
|
|
|
Cu.import("resource://gre/modules/XPCOMUtils.jsm");
|
|
|
|
XPCOMUtils.defineLazyModuleGetter(this, "BrowserUtils",
|
|
"resource://gre/modules/BrowserUtils.jsm");
|
|
XPCOMUtils.defineLazyServiceGetter(this, "DOMUtils",
|
|
"@mozilla.org/inspector/dom-utils;1", "inIDOMUtils");
|
|
|
|
const kStateHover = 0x00000004; // NS_EVENT_STATE_HOVER
|
|
|
|
this.EXPORTED_SYMBOLS = [
|
|
"SelectContentHelper"
|
|
];
|
|
|
|
this.SelectContentHelper = function (aElement, aGlobal) {
|
|
this.element = aElement;
|
|
this.initialSelection = aElement[aElement.selectedIndex] || null;
|
|
this.global = aGlobal;
|
|
this.init();
|
|
this.showDropDown();
|
|
}
|
|
|
|
this.SelectContentHelper.prototype = {
|
|
init: function() {
|
|
this.global.addMessageListener("Forms:SelectDropDownItem", this);
|
|
this.global.addMessageListener("Forms:DismissedDropDown", this);
|
|
this.global.addMessageListener("Forms:MouseOver", this);
|
|
this.global.addMessageListener("Forms:MouseOut", this);
|
|
this.global.addEventListener("pagehide", this);
|
|
this.global.addEventListener("mozhidedropdown", this);
|
|
},
|
|
|
|
uninit: function() {
|
|
this.global.removeMessageListener("Forms:SelectDropDownItem", this);
|
|
this.global.removeMessageListener("Forms:DismissedDropDown", this);
|
|
this.global.removeMessageListener("Forms:MouseOver", this);
|
|
this.global.removeMessageListener("Forms:MouseOut", this);
|
|
this.global.removeEventListener("pagehide", this);
|
|
this.global.removeEventListener("mozhidedropdown", this);
|
|
this.element = null;
|
|
this.global = null;
|
|
},
|
|
|
|
showDropDown: function() {
|
|
let rect = this._getBoundingContentRect();
|
|
|
|
this.global.sendAsyncMessage("Forms:ShowDropDown", {
|
|
rect: rect,
|
|
options: this._buildOptionList(),
|
|
selectedIndex: this.element.selectedIndex,
|
|
});
|
|
},
|
|
|
|
_getBoundingContentRect: function() {
|
|
return BrowserUtils.getElementBoundingScreenRect(this.element);
|
|
},
|
|
|
|
_buildOptionList: function() {
|
|
return buildOptionListForChildren(this.element);
|
|
},
|
|
|
|
receiveMessage: function(message) {
|
|
switch (message.name) {
|
|
case "Forms:SelectDropDownItem":
|
|
this.element.selectedIndex = message.data.value;
|
|
break;
|
|
|
|
case "Forms:DismissedDropDown":
|
|
if (this.initialSelection != this.element.item[this.element.selectedIndex]) {
|
|
let event = this.element.ownerDocument.createEvent("Events");
|
|
event.initEvent("change", true, true);
|
|
this.element.dispatchEvent(event);
|
|
}
|
|
|
|
this.uninit();
|
|
break;
|
|
|
|
case "Forms:MouseOver":
|
|
DOMUtils.setContentState(this.element, kStateHover);
|
|
break;
|
|
|
|
case "Forms:MouseOut":
|
|
DOMUtils.removeContentState(this.element, kStateHover);
|
|
break;
|
|
|
|
}
|
|
},
|
|
|
|
handleEvent: function(event) {
|
|
switch (event.type) {
|
|
case "pagehide":
|
|
if (this.element.ownerDocument === event.target) {
|
|
this.global.sendAsyncMessage("Forms:HideDropDown", {});
|
|
this.uninit();
|
|
}
|
|
break;
|
|
case "mozhidedropdown":
|
|
if (this.element === event.target) {
|
|
this.global.sendAsyncMessage("Forms:HideDropDown", {});
|
|
this.uninit();
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
function buildOptionListForChildren(node) {
|
|
let result = [];
|
|
for (let child = node.firstChild; child; child = child.nextSibling) {
|
|
if (child.tagName == 'OPTION' || child.tagName == 'OPTGROUP') {
|
|
let textContent =
|
|
child.tagName == 'OPTGROUP' ? child.getAttribute("label")
|
|
: child.textContent;
|
|
|
|
if (textContent != null) {
|
|
textContent = textContent.trim();
|
|
} else {
|
|
textContent = ""
|
|
}
|
|
|
|
let info = {
|
|
tagName: child.tagName,
|
|
textContent: textContent,
|
|
// XXX this uses a highlight color when this is the selected element.
|
|
// We need to suppress such highlighting in the content process to get
|
|
// the option's correct unhighlighted color here.
|
|
// We also need to detect default color vs. custom so that a standard
|
|
// color does not override color: menutext in the parent.
|
|
// backgroundColor: computedStyle.backgroundColor,
|
|
// color: computedStyle.color,
|
|
children: child.tagName == 'OPTGROUP' ? buildOptionListForChildren(child) : []
|
|
};
|
|
result.push(info);
|
|
}
|
|
}
|
|
return result;
|
|
}
|