gecko-dev/toolkit/modules/FindBarContent.jsm

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

125 строки
2.9 KiB
JavaScript
Исходник Обычный вид История

// vim: set ts=2 sw=2 sts=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/.
"use strict";
var EXPORTED_SYMBOLS = ["FindBarContent"];
Bug 1514594: Part 3 - Change ChromeUtils.import API. *** Bug 1514594: Part 3a - Change ChromeUtils.import to return an exports object; not pollute global. r=mccr8 This changes the behavior of ChromeUtils.import() to return an exports object, rather than a module global, in all cases except when `null` is passed as a second argument, and changes the default behavior not to pollute the global scope with the module's exports. Thus, the following code written for the old model: ChromeUtils.import("resource://gre/modules/Services.jsm"); is approximately the same as the following, in the new model: var {Services} = ChromeUtils.import("resource://gre/modules/Services.jsm"); Since the two behaviors are mutually incompatible, this patch will land with a scripted rewrite to update all existing callers to use the new model rather than the old. *** Bug 1514594: Part 3b - Mass rewrite all JS code to use the new ChromeUtils.import API. rs=Gijs This was done using the followng script: https://bitbucket.org/kmaglione/m-c-rewrites/src/tip/processors/cu-import-exports.jsm *** Bug 1514594: Part 3c - Update ESLint plugin for ChromeUtils.import API changes. r=Standard8 Differential Revision: https://phabricator.services.mozilla.com/D16747 *** Bug 1514594: Part 3d - Remove/fix hundreds of duplicate imports from sync tests. r=Gijs Differential Revision: https://phabricator.services.mozilla.com/D16748 *** Bug 1514594: Part 3e - Remove no-op ChromeUtils.import() calls. r=Gijs Differential Revision: https://phabricator.services.mozilla.com/D16749 *** Bug 1514594: Part 3f.1 - Cleanup various test corner cases after mass rewrite. r=Gijs *** Bug 1514594: Part 3f.2 - Cleanup various non-test corner cases after mass rewrite. r=Gijs Differential Revision: https://phabricator.services.mozilla.com/D16750 --HG-- extra : rebase_source : 359574ee3064c90f33bf36c2ebe3159a24cc8895 extra : histedit_source : b93c8f42808b1599f9122d7842d2c0b3e656a594%2C64a3a4e3359dc889e2ab2b49461bab9e27fc10a7
2019-01-17 21:18:31 +03:00
const { XPCOMUtils } = ChromeUtils.import(
"resource://gre/modules/XPCOMUtils.jsm"
);
ChromeUtils.defineModuleGetter(
this,
"Services",
"resource://gre/modules/Services.jsm"
);
/* Please keep in sync with toolkit/content/widgets/findbar.xml */
const FIND_NORMAL = 0;
const FIND_TYPEAHEAD = 1;
const FIND_LINKS = 2;
class FindBarContent {
constructor(mm) {
this.mm = mm;
this.findMode = 0;
this.inQuickFind = false;
this.mm.addMessageListener("Findbar:UpdateState", this);
Services.els.addSystemEventListener(this.mm, "mouseup", this, false);
}
start(event) {
this.inPassThrough = true;
}
startQuickFind(event, autostart = false) {
let mode = FIND_TYPEAHEAD;
if (
event.charCode == "'".charAt(0) ||
(autostart && FindBarContent.typeAheadLinksOnly)
) {
mode = FIND_LINKS;
}
// Set findMode immediately (without waiting for child->parent->child roundtrip)
// to ensure we pass any further keypresses, too.
this.findMode = mode;
this.passKeyToParent(event);
}
receiveMessage(msg) {
switch (msg.name) {
case "Findbar:UpdateState":
this.findMode = msg.data.findMode;
this.inQuickFind = msg.data.hasQuickFindTimeout;
if (msg.data.isOpenAndFocused) {
this.inPassThrough = false;
}
break;
}
}
handleEvent(event) {
switch (event.type) {
case "keypress":
this.onKeypress(event);
break;
case "mouseup":
this.onMouseup(event);
break;
}
}
onKeypress(event) {
if (this.inPassThrough) {
this.passKeyToParent(event);
} else if (
this.findMode != FIND_NORMAL &&
this.inQuickFind &&
event.charCode
) {
this.passKeyToParent(event);
}
}
passKeyToParent(event) {
event.preventDefault();
// These are the properties required to dispatch another 'real' event
// to the findbar in the parent in _dispatchKeypressEvent in findbar.xml .
// If you make changes here, verify that that method can still do its job.
const kRequiredProps = [
"type",
"bubbles",
"cancelable",
"ctrlKey",
"altKey",
"shiftKey",
"metaKey",
"keyCode",
"charCode",
];
let fakeEvent = {};
for (let prop of kRequiredProps) {
fakeEvent[prop] = event[prop];
}
this.mm.sendAsyncMessage("Findbar:Keypress", fakeEvent);
}
onMouseup(event) {
if (this.findMode != FIND_NORMAL) {
this.mm.sendAsyncMessage("Findbar:Mouseup");
}
}
}
XPCOMUtils.defineLazyPreferenceGetter(
FindBarContent,
"typeAheadLinksOnly",
"accessibility.typeaheadfind.linksonly"
);