diff options
author | Matt A. Tobin <email@mattatobin.com> | 2018-02-09 06:46:43 -0500 |
---|---|---|
committer | Matt A. Tobin <email@mattatobin.com> | 2018-02-09 06:46:43 -0500 |
commit | ac46df8daea09899ce30dc8fd70986e258c746bf (patch) | |
tree | 2750d3125fc253fd5b0671e4bd268eff1fd97296 /addon-sdk/source/lib/dev/theme.js | |
parent | 8cecf8d5208f3945b35f879bba3015bb1a11bec6 (diff) | |
download | UXP-ac46df8daea09899ce30dc8fd70986e258c746bf.tar UXP-ac46df8daea09899ce30dc8fd70986e258c746bf.tar.gz UXP-ac46df8daea09899ce30dc8fd70986e258c746bf.tar.lz UXP-ac46df8daea09899ce30dc8fd70986e258c746bf.tar.xz UXP-ac46df8daea09899ce30dc8fd70986e258c746bf.zip |
Move Add-on SDK source to toolkit/jetpack
Diffstat (limited to 'addon-sdk/source/lib/dev/theme.js')
-rw-r--r-- | addon-sdk/source/lib/dev/theme.js | 135 |
1 files changed, 0 insertions, 135 deletions
diff --git a/addon-sdk/source/lib/dev/theme.js b/addon-sdk/source/lib/dev/theme.js deleted file mode 100644 index 05930a502..000000000 --- a/addon-sdk/source/lib/dev/theme.js +++ /dev/null @@ -1,135 +0,0 @@ -/* 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"; - -module.metadata = { - "stability": "experimental" -}; - -const { Class } = require("../sdk/core/heritage"); -const { EventTarget } = require("../sdk/event/target"); -const { Disposable, setup, dispose } = require("../sdk/core/disposable"); -const { contract, validate } = require("../sdk/util/contract"); -const { id: addonID } = require("../sdk/self"); -const { onEnable, onDisable } = require("dev/theme/hooks"); -const { isString, instanceOf, isFunction } = require("sdk/lang/type"); -const { add } = require("sdk/util/array"); -const { data } = require("../sdk/self"); -const { isLocalURL } = require("../sdk/url"); - -const makeID = name => - ("dev-theme-" + addonID + (name ? "-" + name : "")). - split(/[ . /]/).join("-"). - replace(/[^A-Za-z0-9_\-]/g, ""); - -const Theme = Class({ - extends: Disposable, - implements: [EventTarget], - - initialize: function(options) { - this.name = options.name; - this.label = options.label; - this.styles = options.styles; - - // Event handlers - this.onEnable = options.onEnable; - this.onDisable = options.onDisable; - }, - get id() { - return makeID(this.name || this.label); - }, - setup: function() { - // Any initialization steps done at the registration time. - }, - getStyles: function() { - if (!this.styles) { - return []; - } - - if (isString(this.styles)) { - if (isLocalURL(this.styles)) { - return [data.url(this.styles)]; - } - } - - let result = []; - for (let style of this.styles) { - if (isString(style)) { - if (isLocalURL(style)) { - style = data.url(style); - } - add(result, style); - } else if (instanceOf(style, Theme)) { - result = result.concat(style.getStyles()); - } - } - return result; - }, - getClassList: function() { - let result = []; - for (let style of this.styles) { - if (instanceOf(style, Theme)) { - result = result.concat(style.getClassList()); - } - } - - if (this.name) { - add(result, this.name); - } - - return result; - } -}); - -exports.Theme = Theme; - -// Initialization & dispose - -setup.define(Theme, (theme) => { - theme.classList = []; - theme.setup(); -}); - -dispose.define(Theme, function(theme) { - theme.dispose(); -}); - -// Validation - -validate.define(Theme, contract({ - label: { - is: ["string"], - msg: "The `option.label` must be a provided" - }, -})); - -// Support theme events: apply and unapply the theme. - -onEnable.define(Theme, (theme, {window, oldTheme}) => { - if (isFunction(theme.onEnable)) { - theme.onEnable(window, oldTheme); - } -}); - -onDisable.define(Theme, (theme, {window, newTheme}) => { - if (isFunction(theme.onDisable)) { - theme.onDisable(window, newTheme); - } -}); - -// Support for built-in themes - -const LightTheme = Theme({ - name: "theme-light", - styles: "chrome://devtools/skin/light-theme.css", -}); - -const DarkTheme = Theme({ - name: "theme-dark", - styles: "chrome://devtools/skin/dark-theme.css", -}); - -exports.LightTheme = LightTheme; -exports.DarkTheme = DarkTheme; |