/* 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/. */ const { ContextualIdentityService } = ChromeUtils.importESModule( "resource://gre/modules/ContextualIdentityService.sys.mjs" ); /** * We want to set the window title immediately to prevent flickers. */ function setTitle() { let params = window.arguments[0] || {}; let winElem = document.documentElement; if (params.userContextId) { document.l10n.setAttributes(winElem, "containers-window-update-settings2", { name: params.identity.name, }); } else { document.l10n.setAttributes(winElem, "containers-window-new2"); } } setTitle(); let gContainersManager = { icons: [ "fingerprint", "briefcase", "dollar", "cart", "vacation", "gift", "food", "fruit", "pet", "tree", "chill", "circle", "fence", ], colors: [ "blue", "turquoise", "green", "yellow", "orange", "red", "pink", "purple", "toolbar", ], onLoad() { let params = window.arguments[0] || {}; this.init(params); }, init(aParams) { this._dialog = document.querySelector("dialog"); this.userContextId = aParams.userContextId || null; this.identity = aParams.identity; const iconWrapper = document.getElementById("iconWrapper"); iconWrapper.appendChild(this.createIconButtons()); const colorWrapper = document.getElementById("colorWrapper"); colorWrapper.appendChild(this.createColorSwatches()); if (this.identity.name) { const name = document.getElementById("name"); name.value = this.identity.name; this.checkForm(); } document.addEventListener("dialogaccept", () => this.onApplyChanges()); // This is to prevent layout jank caused by the svgs and outlines rendering at different times document.getElementById("containers-content").removeAttribute("hidden"); }, uninit() {}, // Check if name is provided to determine if the form can be submitted checkForm() { const name = document.getElementById("name"); this._dialog.setAttribute("buttondisabledaccept", !name.value); }, createIconButtons(defaultIcon) { let radiogroup = document.createXULElement("radiogroup"); radiogroup.setAttribute("id", "icon"); radiogroup.className = "icon-buttons radio-buttons"; for (let icon of this.icons) { let iconSwatch = document.createXULElement("radio"); iconSwatch.id = "iconbutton-" + icon; iconSwatch.name = "icon"; iconSwatch.type = "radio"; iconSwatch.value = icon; if (this.identity.icon && this.identity.icon == icon) { iconSwatch.setAttribute("selected", true); } document.l10n.setAttributes(iconSwatch, `containers-icon-${icon}`); let iconElement = document.createXULElement("hbox"); iconElement.className = "userContext-icon"; iconElement.classList.add("identity-icon-" + icon); iconSwatch.appendChild(iconElement); radiogroup.appendChild(iconSwatch); } return radiogroup; }, createColorSwatches(defaultColor) { let radiogroup = document.createXULElement("radiogroup"); radiogroup.setAttribute("id", "color"); radiogroup.className = "radio-buttons"; for (let color of this.colors) { let colorSwatch = document.createXULElement("radio"); colorSwatch.id = "colorswatch-" + color; colorSwatch.name = "color"; colorSwatch.type = "radio"; colorSwatch.value = color; if (this.identity.color && this.identity.color == color) { colorSwatch.setAttribute("selected", true); } document.l10n.setAttributes(colorSwatch, `containers-color-${color}`); let iconElement = document.createXULElement("hbox"); iconElement.className = "userContext-icon"; iconElement.classList.add("identity-icon-circle"); iconElement.classList.add("identity-color-" + color); colorSwatch.appendChild(iconElement); radiogroup.appendChild(colorSwatch); } return radiogroup; }, onApplyChanges() { let icon = document.getElementById("icon").value; let color = document.getElementById("color").value; let name = document.getElementById("name").value; if (!this.icons.includes(icon)) { throw new Error("Internal error. The icon value doesn't match."); } if (!this.colors.includes(color)) { throw new Error("Internal error. The color value doesn't match."); } if (this.userContextId) { ContextualIdentityService.update(this.userContextId, name, icon, color); } else { ContextualIdentityService.create(name, icon, color); } window.parent.location.reload(); }, };