.openInParentProcess = false; let win = this.element.ownerGlobal; win.removeEventListener("pagehide", this, { mozSystemGroup: true }); this.element.removeEventListener("blur", this, { mozSystemGroup: true }); this.element.removeEventListener("transitionend", this, { mozSystemGroup: true, }); this.element = null; this.actor = null; this.mut.disconnect(); this._updateTimer.disarm(); this._updateTimer = null; gOpen = false; }, showDropDown() { this.element.openInParentProcess = true; this._setupPseudoClassStyles(); let rect = this._getBoundingContentRect(); let computedStyles = getComputedStyles(this.element); let options = this._buildOptionList(); let defaultStyles = this.element.ownerGlobal.getDefaultComputedStyle( this.element ); this.actor.sendAsyncMessage("Forms:ShowDropDown", { isOpenedViaTouch: this.isOpenedViaTouch, options, rect, custom: this._allowCustomStyling(computedStyles), selectedIndex: this.element.selectedIndex, isDarkBackground: ChromeUtils.isDarkBackground(this.element), style: supportedStyles(computedStyles, SUPPORTED_SELECT_PROPERTIES), defaultStyle: supportedStyles(defaultStyles, SUPPORTED_SELECT_PROPERTIES), }); this._clearPseudoClassStyles(); gOpen = true; }, _setupPseudoClassStyles() { if (this._pseudoStylesSetup) { throw new Error("pseudo styles must not be set up yet"); } // Do all of the things that change style at once, before we read // any styles. this._pseudoStylesSetup = true; InspectorUtils.addPseudoClassLock(this.element, ":focus"); }, _clearPseudoClassStyles() { if (!this._pseudoStylesSetup) { throw new Error("pseudo styles must be set up already"); } // Undo all of the things that change style at once, after we're // done reading styles. InspectorUtils.clearPseudoClassLocks(this.element); this._pseudoStylesSetup = false; }, _getBoundingContentRect() { return lazy.LayoutUtils.getElementBoundingScreenRect(this.element); }, _buildOptionList() { if (!this._pseudoStylesSetup) { throw new Error("pseudo styles must be set up"); } let uniqueStyles = []; let options = buildOptionListForChildren(this.element, uniqueStyles); return { options, uniqueStyles }; }, _allowCustomStyling(styles) { if (this.element.nodePrincipal.isSystemPrincipal) { // We assume that our UI integrates reasonably with the OS, so we don't // need custom styling. return false; } if (styles.backgroundImage !== "none") { // Disable custom styling if the select uses background-image. We can't // reasonably support arbitrary background-images (because it'd require // doing image loads on the parent for images specified by content, which // is a no-go). Plus, isDarkBackground() and such don't deal particularly // well with it. return false; } return true; }, _update() { // The popup is open. let contentHelper = currentSelectContentHelper.get(this); if (contentHelper) { contentHelper.handleEvent(event); } return; } switch (event.type) { case "mozshowdropdown": { let contentHelper = new SelectContentHelper( event.target, { isOpenedViaTouch: false }, this ); currentSelectContentHelper.set(this, contentHelper); break; } case "mozshowdropdown-sourcetouch": { let contentHelper = new SelectContentHelper( event.target, { isOpenedViaTouch: true }, this ); currentSelectContentHelper.set(this, contentHelper); break; } } } receiveMessage(message) { let contentHelper = currentSelectContentHelper.get(this); if (contentHelper) { contentHelper.receiveMessage(message); } } } PK