diff --git a/card-mod.js b/card-mod.js index fa9588f..6929cac 100644 --- a/card-mod.js +++ b/card-mod.js @@ -1,1142 +1,5 @@ -function hass() { - if(document.querySelector('hc-main')) - return document.querySelector('hc-main').hass; - - if(document.querySelector('home-assistant')) - return document.querySelector('home-assistant').hass; - - return undefined; -}function lovelace_view() { - var root = document.querySelector("hc-main"); - if(root) { - root = root && root.shadowRoot; - root = root && root.querySelector("hc-lovelace"); - root = root && root.shadowRoot; - root = root && root.querySelector("hui-view") || root.querySelector("hui-panel-view"); - return root; - } - - root = document.querySelector("home-assistant"); - root = root && root.shadowRoot; - root = root && root.querySelector("home-assistant-main"); - root = root && root.shadowRoot; - root = root && root.querySelector("app-drawer-layout partial-panel-resolver"); - root = root && root.shadowRoot || root; - root = root && root.querySelector("ha-panel-lovelace"); - root = root && root.shadowRoot; - root = root && root.querySelector("hui-root"); - root = root && root.shadowRoot; - root = root && root.querySelector("ha-app-layout"); - root = root && root.querySelector("#view"); - root = root && root.firstElementChild; - return root; -} - -function fireEvent(ev, detail, entity=null) { - ev = new Event(ev, { - bubbles: true, - cancelable: false, - composed: true, - }); - ev.detail = detail || {}; - if(entity) { - entity.dispatchEvent(ev); - } else { - var root = lovelace_view(); - if (root) root.dispatchEvent(ev); - } -} - -/****************************************************************************** -Copyright (c) Microsoft Corporation. - -Permission to use, copy, modify, and/or distribute this software for any -purpose with or without fee is hereby granted. - -THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH -REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY -AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, -INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM -LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR -OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR -PERFORMANCE OF THIS SOFTWARE. -***************************************************************************** */ - -function __decorate(decorators, target, key, desc) { - var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; - if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); - else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; - return c > 3 && r && Object.defineProperty(target, key, r), r; -} - -/** - * @license - * Copyright 2019 Google LLC - * SPDX-License-Identifier: BSD-3-Clause - */ -const t$1=window,e$3=t$1.ShadowRoot&&(void 0===t$1.ShadyCSS||t$1.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,s$3=Symbol(),n$4=new WeakMap;let o$3 = class o{constructor(t,e,n){if(this._$cssResult$=!0,n!==s$3)throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");this.cssText=t,this.t=e;}get styleSheet(){let t=this.o;const s=this.t;if(e$3&&void 0===t){const e=void 0!==s&&1===s.length;e&&(t=n$4.get(s)),void 0===t&&((this.o=t=new CSSStyleSheet).replaceSync(this.cssText),e&&n$4.set(s,t));}return t}toString(){return this.cssText}};const r$2=t=>new o$3("string"==typeof t?t:t+"",void 0,s$3),S$1=(s,n)=>{e$3?s.adoptedStyleSheets=n.map((t=>t instanceof CSSStyleSheet?t:t.styleSheet)):n.forEach((e=>{const n=document.createElement("style"),o=t$1.litNonce;void 0!==o&&n.setAttribute("nonce",o),n.textContent=e.cssText,s.appendChild(n);}));},c$1=e$3?t=>t:t=>t instanceof CSSStyleSheet?(t=>{let e="";for(const s of t.cssRules)e+=s.cssText;return r$2(e)})(t):t; - -/** - * @license - * Copyright 2017 Google LLC - * SPDX-License-Identifier: BSD-3-Clause - */var s$2;const e$2=window,r$1=e$2.trustedTypes,h$1=r$1?r$1.emptyScript:"",o$2=e$2.reactiveElementPolyfillSupport,n$3={toAttribute(t,i){switch(i){case Boolean:t=t?h$1:null;break;case Object:case Array:t=null==t?t:JSON.stringify(t);}return t},fromAttribute(t,i){let s=t;switch(i){case Boolean:s=null!==t;break;case Number:s=null===t?null:Number(t);break;case Object:case Array:try{s=JSON.parse(t);}catch(t){s=null;}}return s}},a$1=(t,i)=>i!==t&&(i==i||t==t),l$2={attribute:!0,type:String,converter:n$3,reflect:!1,hasChanged:a$1};let d$1 = class d extends HTMLElement{constructor(){super(),this._$Ei=new Map,this.isUpdatePending=!1,this.hasUpdated=!1,this._$El=null,this.u();}static addInitializer(t){var i;this.finalize(),(null!==(i=this.h)&&void 0!==i?i:this.h=[]).push(t);}static get observedAttributes(){this.finalize();const t=[];return this.elementProperties.forEach(((i,s)=>{const e=this._$Ep(s,i);void 0!==e&&(this._$Ev.set(e,s),t.push(e));})),t}static createProperty(t,i=l$2){if(i.state&&(i.attribute=!1),this.finalize(),this.elementProperties.set(t,i),!i.noAccessor&&!this.prototype.hasOwnProperty(t)){const s="symbol"==typeof t?Symbol():"__"+t,e=this.getPropertyDescriptor(t,s,i);void 0!==e&&Object.defineProperty(this.prototype,t,e);}}static getPropertyDescriptor(t,i,s){return {get(){return this[i]},set(e){const r=this[t];this[i]=e,this.requestUpdate(t,r,s);},configurable:!0,enumerable:!0}}static getPropertyOptions(t){return this.elementProperties.get(t)||l$2}static finalize(){if(this.hasOwnProperty("finalized"))return !1;this.finalized=!0;const t=Object.getPrototypeOf(this);if(t.finalize(),void 0!==t.h&&(this.h=[...t.h]),this.elementProperties=new Map(t.elementProperties),this._$Ev=new Map,this.hasOwnProperty("properties")){const t=this.properties,i=[...Object.getOwnPropertyNames(t),...Object.getOwnPropertySymbols(t)];for(const s of i)this.createProperty(s,t[s]);}return this.elementStyles=this.finalizeStyles(this.styles),!0}static finalizeStyles(i){const s=[];if(Array.isArray(i)){const e=new Set(i.flat(1/0).reverse());for(const i of e)s.unshift(c$1(i));}else void 0!==i&&s.push(c$1(i));return s}static _$Ep(t,i){const s=i.attribute;return !1===s?void 0:"string"==typeof s?s:"string"==typeof t?t.toLowerCase():void 0}u(){var t;this._$E_=new Promise((t=>this.enableUpdating=t)),this._$AL=new Map,this._$Eg(),this.requestUpdate(),null===(t=this.constructor.h)||void 0===t||t.forEach((t=>t(this)));}addController(t){var i,s;(null!==(i=this._$ES)&&void 0!==i?i:this._$ES=[]).push(t),void 0!==this.renderRoot&&this.isConnected&&(null===(s=t.hostConnected)||void 0===s||s.call(t));}removeController(t){var i;null===(i=this._$ES)||void 0===i||i.splice(this._$ES.indexOf(t)>>>0,1);}_$Eg(){this.constructor.elementProperties.forEach(((t,i)=>{this.hasOwnProperty(i)&&(this._$Ei.set(i,this[i]),delete this[i]);}));}createRenderRoot(){var t;const s=null!==(t=this.shadowRoot)&&void 0!==t?t:this.attachShadow(this.constructor.shadowRootOptions);return S$1(s,this.constructor.elementStyles),s}connectedCallback(){var t;void 0===this.renderRoot&&(this.renderRoot=this.createRenderRoot()),this.enableUpdating(!0),null===(t=this._$ES)||void 0===t||t.forEach((t=>{var i;return null===(i=t.hostConnected)||void 0===i?void 0:i.call(t)}));}enableUpdating(t){}disconnectedCallback(){var t;null===(t=this._$ES)||void 0===t||t.forEach((t=>{var i;return null===(i=t.hostDisconnected)||void 0===i?void 0:i.call(t)}));}attributeChangedCallback(t,i,s){this._$AK(t,s);}_$EO(t,i,s=l$2){var e;const r=this.constructor._$Ep(t,s);if(void 0!==r&&!0===s.reflect){const h=(void 0!==(null===(e=s.converter)||void 0===e?void 0:e.toAttribute)?s.converter:n$3).toAttribute(i,s.type);this._$El=t,null==h?this.removeAttribute(r):this.setAttribute(r,h),this._$El=null;}}_$AK(t,i){var s;const e=this.constructor,r=e._$Ev.get(t);if(void 0!==r&&this._$El!==r){const t=e.getPropertyOptions(r),h="function"==typeof t.converter?{fromAttribute:t.converter}:void 0!==(null===(s=t.converter)||void 0===s?void 0:s.fromAttribute)?t.converter:n$3;this._$El=r,this[r]=h.fromAttribute(i,t.type),this._$El=null;}}requestUpdate(t,i,s){let e=!0;void 0!==t&&(((s=s||this.constructor.getPropertyOptions(t)).hasChanged||a$1)(this[t],i)?(this._$AL.has(t)||this._$AL.set(t,i),!0===s.reflect&&this._$El!==t&&(void 0===this._$EC&&(this._$EC=new Map),this._$EC.set(t,s))):e=!1),!this.isUpdatePending&&e&&(this._$E_=this._$Ej());}async _$Ej(){this.isUpdatePending=!0;try{await this._$E_;}catch(t){Promise.reject(t);}const t=this.scheduleUpdate();return null!=t&&await t,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){var t;if(!this.isUpdatePending)return;this.hasUpdated,this._$Ei&&(this._$Ei.forEach(((t,i)=>this[i]=t)),this._$Ei=void 0);let i=!1;const s=this._$AL;try{i=this.shouldUpdate(s),i?(this.willUpdate(s),null===(t=this._$ES)||void 0===t||t.forEach((t=>{var i;return null===(i=t.hostUpdate)||void 0===i?void 0:i.call(t)})),this.update(s)):this._$Ek();}catch(t){throw i=!1,this._$Ek(),t}i&&this._$AE(s);}willUpdate(t){}_$AE(t){var i;null===(i=this._$ES)||void 0===i||i.forEach((t=>{var i;return null===(i=t.hostUpdated)||void 0===i?void 0:i.call(t)})),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(t)),this.updated(t);}_$Ek(){this._$AL=new Map,this.isUpdatePending=!1;}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$E_}shouldUpdate(t){return !0}update(t){void 0!==this._$EC&&(this._$EC.forEach(((t,i)=>this._$EO(i,this[i],t))),this._$EC=void 0),this._$Ek();}updated(t){}firstUpdated(t){}};d$1.finalized=!0,d$1.elementProperties=new Map,d$1.elementStyles=[],d$1.shadowRootOptions={mode:"open"},null==o$2||o$2({ReactiveElement:d$1}),(null!==(s$2=e$2.reactiveElementVersions)&&void 0!==s$2?s$2:e$2.reactiveElementVersions=[]).push("1.4.2"); - -/** - * @license - * Copyright 2017 Google LLC - * SPDX-License-Identifier: BSD-3-Clause - */ -var t;const i$1=window,s$1=i$1.trustedTypes,e$1=s$1?s$1.createPolicy("lit-html",{createHTML:t=>t}):void 0,o$1=`lit$${(Math.random()+"").slice(9)}$`,n$2="?"+o$1,l$1=`<${n$2}>`,h=document,r=(t="")=>h.createComment(t),d=t=>null===t||"object"!=typeof t&&"function"!=typeof t,u=Array.isArray,c=t=>u(t)||"function"==typeof(null==t?void 0:t[Symbol.iterator]),v=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,a=/-->/g,f=/>/g,_=RegExp(">|[ \t\n\f\r](?:([^\\s\"'>=/]+)([ \t\n\f\r]*=[ \t\n\f\r]*(?:[^ \t\n\f\r\"'`<>=]|(\"|')|))|$)","g"),m=/'/g,p=/"/g,$=/^(?:script|style|textarea|title)$/i,g=t=>(i,...s)=>({_$litType$:t,strings:i,values:s}),y=g(1),x=Symbol.for("lit-noChange"),b=Symbol.for("lit-nothing"),T=new WeakMap,A=h.createTreeWalker(h,129,null,!1),E=(t,i)=>{const s=t.length-1,n=[];let h,r=2===i?"":"",d=v;for(let i=0;i"===u[0]?(d=null!=h?h:v,c=-1):void 0===u[1]?c=-2:(c=d.lastIndex-u[2].length,e=u[1],d=void 0===u[3]?_:'"'===u[3]?p:m):d===p||d===m?d=_:d===a||d===f?d=v:(d=_,h=void 0);const y=d===_&&t[i+1].startsWith("/>")?" ":"";r+=d===v?s+l$1:c>=0?(n.push(e),s.slice(0,c)+"$lit$"+s.slice(c)+o$1+y):s+o$1+(-2===c?(n.push(void 0),i):y);}const u=r+(t[s]||"")+(2===i?"":"");if(!Array.isArray(t)||!t.hasOwnProperty("raw"))throw Error("invalid template strings array");return [void 0!==e$1?e$1.createHTML(u):u,n]};class C{constructor({strings:t,_$litType$:i},e){let l;this.parts=[];let h=0,d=0;const u=t.length-1,c=this.parts,[v,a]=E(t,i);if(this.el=C.createElement(v,e),A.currentNode=this.el.content,2===i){const t=this.el.content,i=t.firstChild;i.remove(),t.append(...i.childNodes);}for(;null!==(l=A.nextNode())&&c.length0){l.textContent=s$1?s$1.emptyScript:"";for(let s=0;s2||""!==s[0]||""!==s[1]?(this._$AH=Array(s.length-1).fill(new String),this.strings=s):this._$AH=b;}get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}_$AI(t,i=this,s,e){const o=this.strings;let n=!1;if(void 0===o)t=P(this,t,i,0),n=!d(t)||t!==this._$AH&&t!==x,n&&(this._$AH=t);else {const e=t;let l,h;for(t=o[0],l=0;l{var e,o;const n=null!==(e=null==s?void 0:s.renderBefore)&&void 0!==e?e:i;let l=n._$litPart$;if(void 0===l){const t=null!==(o=null==s?void 0:s.renderBefore)&&void 0!==o?o:null;n._$litPart$=l=new N(i.insertBefore(r(),t),t,void 0,null!=s?s:{});}return l._$AI(t),l}; - -/** - * @license - * Copyright 2017 Google LLC - * SPDX-License-Identifier: BSD-3-Clause - */var l,o;class s extends d$1{constructor(){super(...arguments),this.renderOptions={host:this},this._$Do=void 0;}createRenderRoot(){var t,e;const i=super.createRenderRoot();return null!==(t=(e=this.renderOptions).renderBefore)&&void 0!==t||(e.renderBefore=i.firstChild),i}update(t){const i=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(t),this._$Do=Z(i,this.renderRoot,this.renderOptions);}connectedCallback(){var t;super.connectedCallback(),null===(t=this._$Do)||void 0===t||t.setConnected(!0);}disconnectedCallback(){var t;super.disconnectedCallback(),null===(t=this._$Do)||void 0===t||t.setConnected(!1);}render(){return x}}s.finalized=!0,s._$litElement$=!0,null===(l=globalThis.litElementHydrateSupport)||void 0===l||l.call(globalThis,{LitElement:s});const n$1=globalThis.litElementPolyfillSupport;null==n$1||n$1({LitElement:s});(null!==(o=globalThis.litElementVersions)&&void 0!==o?o:globalThis.litElementVersions=[]).push("3.2.2"); - -/** - * @license - * Copyright 2017 Google LLC - * SPDX-License-Identifier: BSD-3-Clause - */ -const i=(i,e)=>"method"===e.kind&&e.descriptor&&!("value"in e.descriptor)?{...e,finisher(n){n.createProperty(e.key,i);}}:{kind:"field",key:Symbol(),placement:"own",descriptor:{},originalKey:e.key,initializer(){"function"==typeof e.initializer&&(this[e.key]=e.initializer.call(this));},finisher(n){n.createProperty(e.key,i);}};function e(e){return (n,t)=>void 0!==t?((i,e,n)=>{e.constructor.createProperty(n,i);})(e,n,t):i(e,n)} - -/** - * @license - * Copyright 2021 Google LLC - * SPDX-License-Identifier: BSD-3-Clause - */var n;null!=(null===(n=window.HTMLSlotElement)||void 0===n?void 0:n.prototype.assignedElements)?(o,n)=>o.assignedElements(n):(o,n)=>o.assignedNodes(n).filter((o=>o.nodeType===Node.ELEMENT_NODE)); - -const ID_STORAGE_KEY = 'lovelace-player-device-id'; -function _deviceID() { - if(!localStorage[ID_STORAGE_KEY]) - { - const s4 = () => { - return Math.floor((1+Math.random())*100000).toString(16).substring(1); - }; - if(window['fully'] && typeof fully.getDeviceId === "function") - localStorage[ID_STORAGE_KEY] = fully.getDeviceId(); - else - localStorage[ID_STORAGE_KEY] = `${s4()}${s4()}-${s4()}${s4()}`; - } - return localStorage[ID_STORAGE_KEY]; -} -let deviceID = _deviceID(); - -const setDeviceID = (id) => { - if(id === null) return; - if(id === "clear") { - localStorage.removeItem(ID_STORAGE_KEY); - } else { - localStorage[ID_STORAGE_KEY] = id; - } - deviceID = _deviceID(); -}; - -const params = new URLSearchParams(window.location.search); -if(params.get('deviceID')) { - setDeviceID(params.get('deviceID')); -} - -window.cardMod_template_cache = - window.cardMod_template_cache || {}; -const cachedTemplates = window - .cardMod_template_cache; -function template_updated(key, result) { - const cache = cachedTemplates[key]; - if (!cache) { - return; - } - cache.value = result.result; - cache.callbacks.forEach((f) => f(result.result)); -} -async function bind_template(callback, template, variables) { - const connection = hass().connection; - const cacheKey = JSON.stringify([template, variables]); - let cache = cachedTemplates[cacheKey]; - if (!cache) { - unbind_template(callback); - callback(""); - variables = Object.assign({ user: hass().user.name, browser: deviceID, hash: location.hash.substr(1) || "" }, variables); - cachedTemplates[cacheKey] = cache = { - template, - variables, - value: "", - callbacks: new Set([callback]), - unsubscribe: connection.subscribeMessage((result) => template_updated(cacheKey, result), { - type: "render_template", - template, - variables, - }), - }; - } - else { - if (!cache.callbacks.has(callback)) - unbind_template(callback); - callback(cache.value); - cache.callbacks.add(callback); - } -} -async function unbind_template(callback) { - let unsubscriber; - for (const [key, cache] of Object.entries(cachedTemplates)) { - if (cache.callbacks.has(callback)) { - cache.callbacks.delete(callback); - if (cache.callbacks.size == 0) { - unsubscriber = cache.unsubscribe; - delete cachedTemplates[key]; - } - break; - } - } - if (unsubscriber) - await (await unsubscriber)(); -} - -function hasTemplate(str) { - if(String(str).includes("{%")) - return true; - if(String(str).includes("{{")) - return true; -} - -var name = "card-mod"; -var version = "3.1.6b1"; -var description = ""; -var scripts = { - build: "rollup -c", - watch: "rollup -c --watch", - "update-card-tools": "npm uninstall card-tools && npm install thomasloven/lovelace-card-tools" -}; -var keywords = [ -]; -var author = "Thomas Lovén"; -var license = "MIT"; -var devDependencies = { - "rollup-plugin-terser": "^7.0.2" -}; -var dependencies = { - "@babel/core": "^7.20.2", - "@rollup/plugin-babel": "^6.0.2", - "@rollup/plugin-json": "^5.0.1", - "@rollup/plugin-node-resolve": "^15.0.1", - "card-tools": "github:thomasloven/lovelace-card-tools", - lit: "^2.4.1", - rollup: "^3.4.0", - "rollup-plugin-typescript2": "^0.34.1", - typescript: "^4.9.3" -}; -var pjson = { - name: name, - "private": true, - version: version, - description: description, - scripts: scripts, - keywords: keywords, - author: author, - license: license, - devDependencies: devDependencies, - dependencies: dependencies -}; - -async function _selectTree(root, path, all=false) { - let el = root; - if(typeof(path) === "string") { - path = path.split(/(\$| )/); - } - if(path[path.length-1] === "") - path.pop(); - for(const [i, p] of path.entries()) { - if(!p.trim().length) continue; - if(!el) return null; - if(el.localName && el.localName.includes("-")) - await customElements.whenDefined(el.localName); - if(el.updateComplete) - await el.updateComplete; - if(p === "$") - if(all && i == path.length-1) - el = [el.shadowRoot]; - else - el = el.shadowRoot; - else - if(all && i == path.length-1) - el = el.querySelectorAll(p); - else - el = el.querySelector(p); - } - return el; -} - -async function selectTree(root, path, all=false, timeout=10000) { - return Promise.race([ - _selectTree(root, path, all), - new Promise((_, reject) => setTimeout(() => reject(new Error('timeout')), timeout)) - ]).catch((err) => { - if(!err.message || err.message !== "timeout") - throw(err); - return null; - }); -} - -const _load_yaml2json = async () => { - if(customElements.get("developer-tools-event")) return; - - await customElements.whenDefined("partial-panel-resolver"); - const ppr = document.createElement('partial-panel-resolver'); - - ppr.hass = {panels: [{ - url_path: "tmp", - component_name: "developer-tools", - }]}; - ppr._updateRoutes(); - - await ppr.routerOptions.routes.tmp.load(); - - await customElements.whenDefined("developer-tools-router"); - const dtr = document.createElement("developer-tools-router"); - await dtr.routerOptions.routes.event.load(); -}; - -const yaml2json = async (yaml) => { - await _load_yaml2json(); - const el = document.createElement("developer-tools-event"); - return el._computeParsedEventData(yaml); -}; - -async function applyToElement(el, type, styles = "", variables = {}, entity_ids = null, // deprecated -shadow = true) { - var _a; - if (!el) - return; - if ((_a = el.localName) === null || _a === void 0 ? void 0 : _a.includes("-")) - await customElements.whenDefined(el.localName); - if (el.updateComplete) - await el.updateComplete; - if (el._cardMod === undefined) { - el._cardMod = []; - } - let cardMod; - for (const cm of el._cardMod) { - if (cm.type === type) { - cardMod = cm; - break; - } - } - if (!cardMod) { - cardMod = document.createElement("card-mod"); - cardMod.type = type; - el._cardMod.push(cardMod); - } - queueMicrotask(async () => { - const target = el.modElement - ? el.modElement - : shadow - ? el.shadowRoot || el - : el; - if (!target.contains(cardMod)) - target.appendChild(cardMod); - cardMod.variables = variables; - cardMod.styles = styles; - }); - return cardMod; -} -async function get_theme(root) { - var _a, _b; - if (!root.type) - return null; - const el = root.parentElement ? root.parentElement : root; - const theme = window - .getComputedStyle(el) - .getPropertyValue("--card-mod-theme"); - if (!hass()) - return {}; - const themes = (_b = (_a = hass()) === null || _a === void 0 ? void 0 : _a.themes.themes) !== null && _b !== void 0 ? _b : {}; - if (!themes[theme]) - return {}; - if (themes[theme][`card-mod-${root.type}-yaml`]) { - return yaml2json(themes[theme][`card-mod-${root.type}-yaml`]); - } - else if (themes[theme][`card-mod-${root.type}`]) { - return { ".": themes[theme][`card-mod-${root.type}`] }; - } - else { - return {}; - } -} -function merge_deep(target, source) { - const isObject = (i) => { - return i && typeof i === "object" && !Array.isArray(i); - }; - if (isObject(target) && isObject(source)) { - for (const key in source) { - if (isObject(source[key])) { - if (!target[key]) - Object.assign(target, { [key]: {} }); - if (typeof target[key] === "string") - target[key] = { ".": target[key] }; - merge_deep(target[key], source[key]); - } - else { - if (target[key]) - target[key] = source[key] + target[key]; - else - target[key] = source[key]; - } - } - } - return target; -} -function compare_deep(a, b) { - if (a === b) - return true; - if (typeof a !== typeof b) - return false; - if (!(a instanceof Object && b instanceof Object)) - return false; - for (const x in a) { - if (!a.hasOwnProperty(x)) - continue; - if (!b.hasOwnProperty(x)) - return false; - if (a[x] === b[x]) - continue; - if (typeof a[x] !== "object") - return false; - if (!compare_deep(a[x], b[x])) - return false; - } - for (const x in b) { - if (!b.hasOwnProperty(x)) - continue; - if (!a.hasOwnProperty(x)) - return false; - } - return true; -} -function findConfig(node) { - if (node.config) - return node.config; - if (node._config) - return node._config; - if (node.host) - return findConfig(node.host); - if (node.parentElement) - return findConfig(node.parentElement); - if (node.parentNode) - return findConfig(node.parentNode); - return null; -} -function joinSet(dst, src) { - for (const s of src) - dst.add(s); -} -async function findParentCardMod(node, step = 0) { - let cardMods = new Set(); - if (step == 10) - return cardMods; - if (!node) - return cardMods; - if (node._cardMod) { - for (const cm of node._cardMod) { - if (cm.styles) - cardMods.add(cm); - } - } - if (node.updateComplete) - await node.updateComplete; - if (node.parentElement) - joinSet(cardMods, await findParentCardMod(node.parentElement, step + 1)); - else if (node.parentNode) - joinSet(cardMods, await findParentCardMod(node.parentNode, step + 1)); - if (node.host) - joinSet(cardMods, await findParentCardMod(node.host, step + 1)); - return cardMods; -} -function parentElement(el) { - if (!el) - return undefined; - const node = el.parentElement || el.parentNode; - if (!node) - return undefined; - return node.host ? node.host : node; -} -function getResources() { - var _a, _b, _c; - const scriptElements = document.querySelectorAll("script"); - const retval = []; - for (const script of scriptElements) { - if ((_b = (_a = script === null || script === void 0 ? void 0 : script.innerText) === null || _a === void 0 ? void 0 : _a.trim()) === null || _b === void 0 ? void 0 : _b.startsWith("import(")) { - const imports = (_c = script.innerText.split("\n")) === null || _c === void 0 ? void 0 : _c.map((e) => e.trim()); - for (const imp of imports) { - retval.push(imp.replace(/^import\(\"/, "").replace(/\"\);/, "")); - } - } - } - return retval; -} - -class CardMod extends s { - static get applyToElement() { - return applyToElement; - } - constructor() { - super(); - this._rendered_styles = ""; - this._styleChildren = new Set(); - this._observer = new MutationObserver((mutations) => { - for (const m of mutations) { - if (m.target.localName === "card-mod") - return; - if (m.addedNodes.length) - m.addedNodes.forEach((n) => { - if (n.localName !== "card-mod") - ; - }); - if (m.removedNodes.length) - m.removedNodes.forEach((n) => { - if (n.localName !== "card-mod") - ; - }); - } - if (stop) - return; - this.refresh(); - }); - document.addEventListener("cm_update", () => { - this.refresh(); - }); - } - connectedCallback() { - super.connectedCallback(); - this._connect(); - this.setAttribute("slot", "none"); - } - disconnectedCallback() { - super.disconnectedCallback(); - this._disconnect(); - } - set styles(stl) { - if (compare_deep(stl, this._input_styles)) - return; - this._input_styles = stl; - (async () => { - // Always work with yaml styles internally - let styles = JSON.parse(JSON.stringify(stl || {})); - if (typeof styles === "string") - styles = { ".": styles }; - // Merge card_mod styles with theme styles - const theme_styles = await get_theme(this); - merge_deep(styles, theme_styles); - this._fixed_styles = styles; - this._connect(); - })(); - } - get styles() { - return this._styles; - } - refresh() { - this._connect(); - } - async _styleChildEl(element, value = undefined) { - if (value === undefined) { - // Find the style for the element - const styles = this._fixed_styles; - for (const [key, val] of Object.entries(styles)) { - if (key === ".") - continue; - const elements = await selectTree(this.parentElement || this.parentNode, key, true); - elements.forEach((el) => { - if (el === element) { - value = val; - } - }); - if (value !== undefined) - break; - } - if (value === undefined) - return; - } - if (!element) - return; - const child = await applyToElement(element, `${this.type}-child`, value, this.variables, null, false); - child.refresh; - return child; - } - async _connect() { - var _a; - const styles = (_a = this._fixed_styles) !== null && _a !== void 0 ? _a : {}; - const styleChildren = new Set(); - let thisStyle = ""; - let hasChildren = false; - const parent = this.parentElement || this.parentNode; - for (const [key, value] of Object.entries(styles)) { - if (key === ".") { - thisStyle = value; - } - else { - hasChildren = true; - const elements = await selectTree(parent, key, true); - if (!elements) - continue; - for (const el of elements) { - const ch = await this._styleChildEl(el, value); - if (ch) - styleChildren.add(ch); - } - } - } - // Prune old child elements - for (const oldCh of this._styleChildren) { - if (!styleChildren.has(oldCh)) { - if (oldCh) - oldCh.styles = ""; - } - } - this._styleChildren = styleChildren; - if (this._styles === thisStyle) - return; - this._styles = thisStyle; - if (this._styles && hasTemplate(this._styles)) { - this._renderer = this._renderer || this._style_rendered.bind(this); - bind_template(this._renderer, this._styles, this.variables); - } - else { - this._style_rendered(this._styles || ""); - } - if (hasChildren) { - this._observer.disconnect(); - this._observer.observe(parentElement(this), { childList: true }); - } - } - async _disconnect() { - this._observer.disconnect(); - this._styles = ""; - await unbind_template(this._renderer); - } - _style_rendered(result) { - if (this._rendered_styles !== result) - this._rendered_styles = result; - this.dispatchEvent(new Event("card-mod-update")); - } - createRenderRoot() { - return this; - } - render() { - return y ` +function t(){return document.querySelector("hc-main")?document.querySelector("hc-main").hass:document.querySelector("home-assistant")?document.querySelector("home-assistant").hass:void 0}function e(t,e,o,s){var i,n=arguments.length,r=n<3?e:null===s?s=Object.getOwnPropertyDescriptor(e,o):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)r=Reflect.decorate(t,e,o,s);else for(var a=t.length-1;a>=0;a--)(i=t[a])&&(r=(n<3?i(r):n>3?i(e,o,r):i(e,o))||r);return n>3&&r&&Object.defineProperty(e,o,r),r}const o=window,s=o.ShadowRoot&&(void 0===o.ShadyCSS||o.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,i=Symbol(),n=new WeakMap;const r=t=>new class{constructor(t,e,o){if(this._$cssResult$=!0,o!==i)throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");this.cssText=t,this.t=e}get styleSheet(){let t=this.o;const e=this.t;if(s&&void 0===t){const o=void 0!==e&&1===e.length;o&&(t=n.get(e)),void 0===t&&((this.o=t=new CSSStyleSheet).replaceSync(this.cssText),o&&n.set(e,t))}return t}toString(){return this.cssText}}("string"==typeof t?t:t+"",void 0,i),a=s?t=>t:t=>t instanceof CSSStyleSheet?(t=>{let e="";for(const o of t.cssRules)e+=o.cssText;return r(e)})(t):t;var d;const l=window,c=l.trustedTypes,h=c?c.emptyScript:"",u=l.reactiveElementPolyfillSupport,p={toAttribute(t,e){switch(e){case Boolean:t=t?h:null;break;case Object:case Array:t=null==t?t:JSON.stringify(t)}return t},fromAttribute(t,e){let o=t;switch(e){case Boolean:o=null!==t;break;case Number:o=null===t?null:Number(t);break;case Object:case Array:try{o=JSON.parse(t)}catch(t){o=null}}return o}},m=(t,e)=>e!==t&&(e==e||t==t),f={attribute:!0,type:String,converter:p,reflect:!1,hasChanged:m};let v=class extends HTMLElement{constructor(){super(),this._$Ei=new Map,this.isUpdatePending=!1,this.hasUpdated=!1,this._$El=null,this.u()}static addInitializer(t){var e;this.finalize(),(null!==(e=this.h)&&void 0!==e?e:this.h=[]).push(t)}static get observedAttributes(){this.finalize();const t=[];return this.elementProperties.forEach(((e,o)=>{const s=this._$Ep(o,e);void 0!==s&&(this._$Ev.set(s,o),t.push(s))})),t}static createProperty(t,e=f){if(e.state&&(e.attribute=!1),this.finalize(),this.elementProperties.set(t,e),!e.noAccessor&&!this.prototype.hasOwnProperty(t)){const o="symbol"==typeof t?Symbol():"__"+t,s=this.getPropertyDescriptor(t,o,e);void 0!==s&&Object.defineProperty(this.prototype,t,s)}}static getPropertyDescriptor(t,e,o){return{get(){return this[e]},set(s){const i=this[t];this[e]=s,this.requestUpdate(t,i,o)},configurable:!0,enumerable:!0}}static getPropertyOptions(t){return this.elementProperties.get(t)||f}static finalize(){if(this.hasOwnProperty("finalized"))return!1;this.finalized=!0;const t=Object.getPrototypeOf(this);if(t.finalize(),void 0!==t.h&&(this.h=[...t.h]),this.elementProperties=new Map(t.elementProperties),this._$Ev=new Map,this.hasOwnProperty("properties")){const t=this.properties,e=[...Object.getOwnPropertyNames(t),...Object.getOwnPropertySymbols(t)];for(const o of e)this.createProperty(o,t[o])}return this.elementStyles=this.finalizeStyles(this.styles),!0}static finalizeStyles(t){const e=[];if(Array.isArray(t)){const o=new Set(t.flat(1/0).reverse());for(const t of o)e.unshift(a(t))}else void 0!==t&&e.push(a(t));return e}static _$Ep(t,e){const o=e.attribute;return!1===o?void 0:"string"==typeof o?o:"string"==typeof t?t.toLowerCase():void 0}u(){var t;this._$E_=new Promise((t=>this.enableUpdating=t)),this._$AL=new Map,this._$Eg(),this.requestUpdate(),null===(t=this.constructor.h)||void 0===t||t.forEach((t=>t(this)))}addController(t){var e,o;(null!==(e=this._$ES)&&void 0!==e?e:this._$ES=[]).push(t),void 0!==this.renderRoot&&this.isConnected&&(null===(o=t.hostConnected)||void 0===o||o.call(t))}removeController(t){var e;null===(e=this._$ES)||void 0===e||e.splice(this._$ES.indexOf(t)>>>0,1)}_$Eg(){this.constructor.elementProperties.forEach(((t,e)=>{this.hasOwnProperty(e)&&(this._$Ei.set(e,this[e]),delete this[e])}))}createRenderRoot(){var t;const e=null!==(t=this.shadowRoot)&&void 0!==t?t:this.attachShadow(this.constructor.shadowRootOptions);return((t,e)=>{s?t.adoptedStyleSheets=e.map((t=>t instanceof CSSStyleSheet?t:t.styleSheet)):e.forEach((e=>{const s=document.createElement("style"),i=o.litNonce;void 0!==i&&s.setAttribute("nonce",i),s.textContent=e.cssText,t.appendChild(s)}))})(e,this.constructor.elementStyles),e}connectedCallback(){var t;void 0===this.renderRoot&&(this.renderRoot=this.createRenderRoot()),this.enableUpdating(!0),null===(t=this._$ES)||void 0===t||t.forEach((t=>{var e;return null===(e=t.hostConnected)||void 0===e?void 0:e.call(t)}))}enableUpdating(t){}disconnectedCallback(){var t;null===(t=this._$ES)||void 0===t||t.forEach((t=>{var e;return null===(e=t.hostDisconnected)||void 0===e?void 0:e.call(t)}))}attributeChangedCallback(t,e,o){this._$AK(t,o)}_$EO(t,e,o=f){var s;const i=this.constructor._$Ep(t,o);if(void 0!==i&&!0===o.reflect){const n=(void 0!==(null===(s=o.converter)||void 0===s?void 0:s.toAttribute)?o.converter:p).toAttribute(e,o.type);this._$El=t,null==n?this.removeAttribute(i):this.setAttribute(i,n),this._$El=null}}_$AK(t,e){var o;const s=this.constructor,i=s._$Ev.get(t);if(void 0!==i&&this._$El!==i){const t=s.getPropertyOptions(i),n="function"==typeof t.converter?{fromAttribute:t.converter}:void 0!==(null===(o=t.converter)||void 0===o?void 0:o.fromAttribute)?t.converter:p;this._$El=i,this[i]=n.fromAttribute(e,t.type),this._$El=null}}requestUpdate(t,e,o){let s=!0;void 0!==t&&(((o=o||this.constructor.getPropertyOptions(t)).hasChanged||m)(this[t],e)?(this._$AL.has(t)||this._$AL.set(t,e),!0===o.reflect&&this._$El!==t&&(void 0===this._$EC&&(this._$EC=new Map),this._$EC.set(t,o))):s=!1),!this.isUpdatePending&&s&&(this._$E_=this._$Ej())}async _$Ej(){this.isUpdatePending=!0;try{await this._$E_}catch(t){Promise.reject(t)}const t=this.scheduleUpdate();return null!=t&&await t,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){var t;if(!this.isUpdatePending)return;this.hasUpdated,this._$Ei&&(this._$Ei.forEach(((t,e)=>this[e]=t)),this._$Ei=void 0);let e=!1;const o=this._$AL;try{e=this.shouldUpdate(o),e?(this.willUpdate(o),null===(t=this._$ES)||void 0===t||t.forEach((t=>{var e;return null===(e=t.hostUpdate)||void 0===e?void 0:e.call(t)})),this.update(o)):this._$Ek()}catch(t){throw e=!1,this._$Ek(),t}e&&this._$AE(o)}willUpdate(t){}_$AE(t){var e;null===(e=this._$ES)||void 0===e||e.forEach((t=>{var e;return null===(e=t.hostUpdated)||void 0===e?void 0:e.call(t)})),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(t)),this.updated(t)}_$Ek(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$E_}shouldUpdate(t){return!0}update(t){void 0!==this._$EC&&(this._$EC.forEach(((t,e)=>this._$EO(e,this[e],t))),this._$EC=void 0),this._$Ek()}updated(t){}firstUpdated(t){}};var y;v.finalized=!0,v.elementProperties=new Map,v.elementStyles=[],v.shadowRootOptions={mode:"open"},null==u||u({ReactiveElement:v}),(null!==(d=l.reactiveElementVersions)&&void 0!==d?d:l.reactiveElementVersions=[]).push("1.4.2");const _=window,g=_.trustedTypes,$=g?g.createPolicy("lit-html",{createHTML:t=>t}):void 0,w=`lit$${(Math.random()+"").slice(9)}$`,E="?"+w,b=`<${E}>`,A=document,S=(t="")=>A.createComment(t),C=t=>null===t||"object"!=typeof t&&"function"!=typeof t,N=Array.isArray,P=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,O=/-->/g,U=/>/g,R=RegExp(">|[ \t\n\f\r](?:([^\\s\"'>=/]+)([ \t\n\f\r]*=[ \t\n\f\r]*(?:[^ \t\n\f\r\"'`<>=]|(\"|')|))|$)","g"),M=/'/g,x=/"/g,D=/^(?:script|style|textarea|title)$/i,T=(t=>(e,...o)=>({_$litType$:t,strings:e,values:o}))(1),k=Symbol.for("lit-noChange"),H=Symbol.for("lit-nothing"),L=new WeakMap,q=A.createTreeWalker(A,129,null,!1),I=(t,e)=>{const o=t.length-1,s=[];let i,n=2===e?"":"",r=P;for(let e=0;e"===d[0]?(r=null!=i?i:P,l=-1):void 0===d[1]?l=-2:(l=r.lastIndex-d[2].length,a=d[1],r=void 0===d[3]?R:'"'===d[3]?x:M):r===x||r===M?r=R:r===O||r===U?r=P:(r=R,i=void 0);const h=r===R&&t[e+1].startsWith("/>")?" ":"";n+=r===P?o+b:l>=0?(s.push(a),o.slice(0,l)+"$lit$"+o.slice(l)+w+h):o+w+(-2===l?(s.push(void 0),e):h)}const a=n+(t[o]||"")+(2===e?"":"");if(!Array.isArray(t)||!t.hasOwnProperty("raw"))throw Error("invalid template strings array");return[void 0!==$?$.createHTML(a):a,s]};class j{constructor({strings:t,_$litType$:e},o){let s;this.parts=[];let i=0,n=0;const r=t.length-1,a=this.parts,[d,l]=I(t,e);if(this.el=j.createElement(d,o),q.currentNode=this.el.content,2===e){const t=this.el.content,e=t.firstChild;e.remove(),t.append(...e.childNodes)}for(;null!==(s=q.nextNode())&&a.length0){s.textContent=g?g.emptyScript:"";for(let o=0;oN(t)||"function"==typeof(null==t?void 0:t[Symbol.iterator]))(t)?this.k(t):this.g(t)}O(t,e=this._$AB){return this._$AA.parentNode.insertBefore(t,e)}T(t){this._$AH!==t&&(this._$AR(),this._$AH=this.O(t))}g(t){this._$AH!==H&&C(this._$AH)?this._$AA.nextSibling.data=t:this.T(A.createTextNode(t)),this._$AH=t}$(t){var e;const{values:o,_$litType$:s}=t,i="number"==typeof s?this._$AC(t):(void 0===s.el&&(s.el=j.createElement(s.h,this.options)),s);if((null===(e=this._$AH)||void 0===e?void 0:e._$AD)===i)this._$AH.p(o);else{const t=new B(i,this),e=t.v(this.options);t.p(o),this.T(e),this._$AH=t}}_$AC(t){let e=L.get(t.strings);return void 0===e&&L.set(t.strings,e=new j(t)),e}k(t){N(this._$AH)||(this._$AH=[],this._$AR());const e=this._$AH;let o,s=0;for(const i of t)s===e.length?e.push(o=new V(this.O(S()),this.O(S()),this,this.options)):o=e[s],o._$AI(i),s++;s2||""!==o[0]||""!==o[1]?(this._$AH=Array(o.length-1).fill(new String),this.strings=o):this._$AH=H}get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}_$AI(t,e=this,o,s){const i=this.strings;let n=!1;if(void 0===i)t=z(this,t,e,0),n=!C(t)||t!==this._$AH&&t!==k,n&&(this._$AH=t);else{const s=t;let r,a;for(t=i[0],r=0;r{var s,i;const n=null!==(s=null==o?void 0:o.renderBefore)&&void 0!==s?s:e;let r=n._$litPart$;if(void 0===r){const t=null!==(i=null==o?void 0:o.renderBefore)&&void 0!==i?i:null;n._$litPart$=r=new V(e.insertBefore(S(),t),t,void 0,null!=o?o:{})}return r._$AI(t),r})(e,this.renderRoot,this.renderOptions)}connectedCallback(){var t;super.connectedCallback(),null===(t=this._$Do)||void 0===t||t.setConnected(!0)}disconnectedCallback(){var t;super.disconnectedCallback(),null===(t=this._$Do)||void 0===t||t.setConnected(!1)}render(){return k}}tt.finalized=!0,tt._$litElement$=!0,null===(Q=globalThis.litElementHydrateSupport)||void 0===Q||Q.call(globalThis,{LitElement:tt});const et=globalThis.litElementPolyfillSupport;null==et||et({LitElement:tt}),(null!==(X=globalThis.litElementVersions)&&void 0!==X?X:globalThis.litElementVersions=[]).push("3.2.2");const ot=(t,e)=>"method"===e.kind&&e.descriptor&&!("value"in e.descriptor)?{...e,finisher(o){o.createProperty(e.key,t)}}:{kind:"field",key:Symbol(),placement:"own",descriptor:{},originalKey:e.key,initializer(){"function"==typeof e.initializer&&(this[e.key]=e.initializer.call(this))},finisher(o){o.createProperty(e.key,t)}};function st(t){return(e,o)=>void 0!==o?((t,e,o)=>{e.constructor.createProperty(o,t)})(t,e,o):ot(t,e)}var it;null===(it=window.HTMLSlotElement)||void 0===it||it.prototype.assignedElements;const nt="lovelace-player-device-id";function rt(){if(!localStorage[nt]){const t=()=>Math.floor(1e5*(1+Math.random())).toString(16).substring(1);window.fully&&"function"==typeof fully.getDeviceId?localStorage[nt]=fully.getDeviceId():localStorage[nt]=`${t()}${t()}-${t()}${t()}`}return localStorage[nt]}let at=rt();const dt=new URLSearchParams(window.location.search);var lt;dt.get("deviceID")&&null!==(lt=dt.get("deviceID"))&&("clear"===lt?localStorage.removeItem(nt):localStorage[nt]=lt,at=rt()),window.cardMod_template_cache=window.cardMod_template_cache||{};const ct=window.cardMod_template_cache;async function ht(e,o,s){const i=t().connection,n=JSON.stringify([o,s]);let r=ct[n];r?(r.callbacks.has(e)||ut(e),e(r.value),r.callbacks.add(e)):(ut(e),e(""),s=Object.assign({user:t().user.name,browser:at,hash:location.hash.substr(1)||""},s),ct[n]=r={template:o,variables:s,value:"",callbacks:new Set([e]),unsubscribe:i.subscribeMessage((t=>function(t,e){const o=ct[t];o&&(o.value=e.result,o.callbacks.forEach((t=>t(e.result))))}(n,t)),{type:"render_template",template:o,variables:s})})}async function ut(t){let e;for(const[o,s]of Object.entries(ct))if(s.callbacks.has(t)){s.callbacks.delete(t),0==s.callbacks.size&&(e=s.unsubscribe,delete ct[o]);break}e&&await(await e)()}var pt="3.2.0";async function mt(t,e,o=!1){let s=t;"string"==typeof e&&(e=e.split(/(\$| )/)),""===e[e.length-1]&&e.pop();for(const[t,i]of e.entries())if(i.trim().length){if(!s)return null;s.localName&&s.localName.includes("-")&&await customElements.whenDefined(s.localName),s.updateComplete&&await s.updateComplete,s="$"===i?o&&t==e.length-1?[s.shadowRoot]:s.shadowRoot:o&&t==e.length-1?s.querySelectorAll(i):s.querySelector(i)}return s}async function ft(t,e,o=!1,s=1e4){return Promise.race([mt(t,e,o),new Promise(((t,e)=>setTimeout((()=>e(new Error("timeout"))),s)))]).catch((t=>{if(!t.message||"timeout"!==t.message)throw t;return null}))}const vt=async t=>{await(async()=>{if(customElements.get("developer-tools-event"))return;await customElements.whenDefined("partial-panel-resolver");const t=document.createElement("partial-panel-resolver");t.hass={panels:[{url_path:"tmp",component_name:"developer-tools"}]},t._updateRoutes(),await t.routerOptions.routes.tmp.load(),await customElements.whenDefined("developer-tools-router");const e=document.createElement("developer-tools-router");await e.routerOptions.routes.event.load()})();return document.createElement("developer-tools-event")._computeParsedEventData(t)};async function yt(t,e,o="",s={},i=null,n=!0){var r;if(!t)return;let a;(null===(r=t.localName)||void 0===r?void 0:r.includes("-"))&&await customElements.whenDefined(t.localName),t.updateComplete&&await t.updateComplete,void 0===t._cardMod&&(t._cardMod=[]);for(const o of t._cardMod)if(o.type===e){a=o;break}return a||(a=document.createElement("card-mod"),a.type=e,t._cardMod.push(a)),queueMicrotask((async()=>{const e=t.modElement?t.modElement:n&&t.shadowRoot||t;e.contains(a)||e.appendChild(a),a.variables=s,a.styles=o})),a}function _t(t,e){const o=t=>t&&"object"==typeof t&&!Array.isArray(t);if(o(t)&&o(e))for(const s in e)o(e[s])?(t[s]||Object.assign(t,{[s]:{}}),"string"==typeof t[s]&&(t[s]={".":t[s]}),_t(t[s],e[s])):t[s]?t[s]=e[s]+t[s]:t[s]=e[s];return t}function gt(t,e){if(t===e)return!0;if(typeof t!=typeof e)return!1;if(!(t instanceof Object&&e instanceof Object))return!1;for(const o in t)if(t.hasOwnProperty(o)){if(!e.hasOwnProperty(o))return!1;if(t[o]!==e[o]){if("object"!=typeof t[o])return!1;if(!gt(t[o],e[o]))return!1}}for(const o in e)if(e.hasOwnProperty(o)&&!t.hasOwnProperty(o))return!1;return!0}function $t(t){return t.config?t.config:t._config?t._config:t.host?$t(t.host):t.parentElement?$t(t.parentElement):t.parentNode?$t(t.parentNode):null}function wt(t,e){for(const o of e)t.add(o)}async function Et(t,e=0){let o=new Set;if(10==e)return o;if(!t)return o;if(t._cardMod)for(const e of t._cardMod)e.styles&&o.add(e);return t.updateComplete&&await t.updateComplete,t.parentElement?wt(o,await Et(t.parentElement,e+1)):t.parentNode&&wt(o,await Et(t.parentNode,e+1)),t.host&&wt(o,await Et(t.host,e+1)),o}class bt extends tt{static get applyToElement(){return yt}constructor(){super(),this._rendered_styles="",this._styleChildren=new Set,this._observer=new MutationObserver((t=>{for(const e of t){if("card-mod"===e.target.localName)return;e.addedNodes.length&&e.addedNodes.forEach((t=>{t.localName})),e.removedNodes.length&&e.removedNodes.forEach((t=>{t.localName}))}stop||this.refresh()})),document.addEventListener("cm_update",(()=>{this.refresh()}))}connectedCallback(){super.connectedCallback(),this._connect(),this.setAttribute("slot","none")}disconnectedCallback(){super.disconnectedCallback(),this._disconnect()}set styles(e){gt(e,this._input_styles)||(this._input_styles=e,(async()=>{let o=JSON.parse(JSON.stringify(e||{}));"string"==typeof o&&(o={".":o});_t(o,await async function(e){var o,s;if(!e.type)return null;const i=e.parentElement?e.parentElement:e,n=window.getComputedStyle(i).getPropertyValue("--card-mod-theme");if(!t())return{};const r=null!==(s=null===(o=t())||void 0===o?void 0:o.themes.themes)&&void 0!==s?s:{};return r[n]?r[n][`card-mod-${e.type}-yaml`]?vt(r[n][`card-mod-${e.type}-yaml`]):r[n][`card-mod-${e.type}`]?{".":r[n][`card-mod-${e.type}`]}:{}:{}}(this)),this._fixed_styles=o,this._connect()})())}get styles(){return this._styles}refresh(){this._connect()}async _styleChildEl(t,e){if(void 0===e){const o=this._fixed_styles;for(const[s,i]of Object.entries(o)){if("."===s)continue;if((await ft(this.parentElement||this.parentNode,s,!0)).forEach((o=>{o===t&&(e=i)})),void 0!==e)break}if(void 0===e)return}if(!t)return;const o=await yt(t,`${this.type}-child`,e,this.variables,null,!1);return o.refresh,o}async _connect(){var t;const e=null!==(t=this._fixed_styles)&&void 0!==t?t:{},o=new Set;let s="",i=!1;const n=this.parentElement||this.parentNode;for(const[t,r]of Object.entries(e))if("."===t)s=r;else{i=!0;const e=await ft(n,t,!0);if(!e)continue;for(const t of e){const e=await this._styleChildEl(t,r);e&&o.add(e)}}for(const t of this._styleChildren)o.has(t)||t&&(t.styles="");var r;(this._styleChildren=o,this._styles!==s)&&(this._styles=s,this._styles&&(r=this._styles,String(r).includes("{%")||String(r).includes("{{"))?(this._renderer=this._renderer||this._style_rendered.bind(this),ht(this._renderer,this._styles,this.variables)):this._style_rendered(this._styles||""),i&&(this._observer.disconnect(),this._observer.observe(function(t){if(!t)return;const e=t.parentElement||t.parentNode;return e?e.host?e.host:e:void 0}(this),{childList:!0})))}async _disconnect(){this._observer.disconnect(),this._styles="",await ut(this._renderer)}_style_rendered(t){this._rendered_styles!==t&&(this._rendered_styles=t),this.dispatchEvent(new Event("card-mod-update"))}createRenderRoot(){return this}render(){return T` - `; - } -} -__decorate([ - e() -], CardMod.prototype, "_rendered_styles", void 0); -(async () => { - // Wait for scoped customElements registry to be set up - // otherwise the customElements registry card-mod is defined in - // may get overwritten by the polyfill if card-mod is loaded as a module - while (customElements.get("home-assistant") === undefined) - await new Promise((resolve) => window.setTimeout(resolve, 100)); - if (!customElements.get("card-mod")) { - customElements.define("card-mod", CardMod); - console.info(`%cCARD-MOD ${pjson.version} IS INSTALLED`, "color: green; font-weight: bold"); - } -})(); - -customElements.whenDefined("ha-card").then(() => { - const HaCard = customElements.get("ha-card"); - if (HaCard.prototype.cardmod_patched) - return; - HaCard.prototype.cardmod_patched = true; - const _firstUpdated = HaCard.prototype.firstUpdated; - HaCard.prototype.firstUpdated = function (...args) { - var _a, _b; - _firstUpdated === null || _firstUpdated === void 0 ? void 0 : _firstUpdated.bind(this)(...args); - const config = findConfig(this); - if ((_a = config === null || config === void 0 ? void 0 : config.card_mod) === null || _a === void 0 ? void 0 : _a.class) - this.classList.add(config.card_mod.class); - if (config === null || config === void 0 ? void 0 : config.type) - this.classList.add(`type-${config.type.replace(":", "-")}`); - applyToElement(this, "card", ((_b = config === null || config === void 0 ? void 0 : config.card_mod) === null || _b === void 0 ? void 0 : _b.style) || (config === null || config === void 0 ? void 0 : config.style) || "", { config }, null, false).then((cardMod) => { - var _a; - const pn = (_a = this.parentNode) === null || _a === void 0 ? void 0 : _a.host; - if (!pn) - return; - if (pn.setConfig && !pn.setConfig.cm_patched) { - // Patch the setConfig function to get live updates in GUI editor - const _setConfig = pn.setConfig; - pn.setConfig = function (config, ...rest) { - var _a; - _setConfig.bind(this)(config, ...rest); - cardMod.variables = { config }; - cardMod.styles = ((_a = config.card_mod) === null || _a === void 0 ? void 0 : _a.style) || {}; - }; - pn.setConfig.cm_patched = true; - } - if (pn.update && !pn.update.cm_patched) { - const _update = pn.update; - pn.update = function (...args) { - _update.bind(this)(...args); - if (this.updateComplete) - this.updateComplete.then(() => { - cardMod.refresh(); - }); - else - cardMod.refresh(); - }; - pn.update.cm_patched = true; - } - }); - }; -}); - -customElements.whenDefined("hui-entities-card").then(() => { - const EntitiesCard = customElements.get("hui-entities-card"); - if (EntitiesCard.prototype.cardmod_patched) - return; - EntitiesCard.prototype.cardmod_patched = true; - const _renderEntity = EntitiesCard.prototype.renderEntity; - EntitiesCard.prototype.renderEntity = function (config, ...rest) { - var _a; - const retval = _renderEntity.bind(this)(config, ...rest); - if (!retval || !retval.values) - return retval; - const row = retval.values[0]; - if (!row) - return retval; - if ((config === null || config === void 0 ? void 0 : config.type) === "custom:mod-card") - return retval; - if ((_a = config === null || config === void 0 ? void 0 : config.card_mod) === null || _a === void 0 ? void 0 : _a.class) - row.classList.add(config.card_mod.class); - if (config === null || config === void 0 ? void 0 : config.type) - row.classList.add(`type-${config.type.replace(":", "-")}`); - const apply = async () => { - var _a; - return applyToElement(row, "row", ((_a = config === null || config === void 0 ? void 0 : config.card_mod) === null || _a === void 0 ? void 0 : _a.style) || (config === null || config === void 0 ? void 0 : config.style) || "", { config }); - }; - (async () => { - const cardMod = await apply(); - if (row.update && !row.update.cm_patched) { - const _update = row.update; - row.update = function (...args) { - _update.bind(this)(...args); - if (this.updateComplete) - this.updateComplete.then(() => { - cardMod.refresh(); - }); - else - cardMod.refresh(); - }; - } - })(); - this.updateComplete.then(() => apply()); - if (retval.values[0]) - retval.values[0].addEventListener("ll-rebuild", apply); - return retval; - }; -}); - -const ENTITY_STYLES = ` -div { - width: 100%; - text-align: center; - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; -} -.name { - min-height: var(--paper-font-body1_-_line-height, 20px); -} -state-badge { - margin: 8px 0; -} -`; -customElements.whenDefined("hui-glance-card").then(() => { - const GlanceCard = customElements.get("hui-glance-card"); - if (GlanceCard.prototype.cardmod_patched) - return; - GlanceCard.prototype.cardmod_patched = true; - const _updated = GlanceCard.prototype.updated; - GlanceCard.prototype.updated = function (...args) { - var _a, _b; - _updated === null || _updated === void 0 ? void 0 : _updated.bind(this)(...args); - for (const e of this.shadowRoot.querySelectorAll("ha-card div.entity")) { - if (!e.cardmod_patched) { - e.cardmod_patched = true; - // Move everything into a shadowRoot so it can be styled more easily - const root = e.attachShadow({ mode: "open" }); - while (e.firstChild) - root.append(e.firstChild); - // Add the default styles to the shadowRoot too - const styletag = document.createElement("style"); - root.appendChild(styletag); - styletag.innerHTML = ENTITY_STYLES; - } - const config = e.config || e.entityConf; - if ((_a = config === null || config === void 0 ? void 0 : config.card_mod) === null || _a === void 0 ? void 0 : _a.class) - e.classList.add(config.card_mod.class); - applyToElement(e, "glance", ((_b = config === null || config === void 0 ? void 0 : config.card_mod) === null || _b === void 0 ? void 0 : _b.style) || (config === null || config === void 0 ? void 0 : config.style) || "", { config }); - } - }; -}); - -customElements.whenDefined("hui-state-label-badge").then(() => { - const HuiStateLabelBadge = customElements.get("hui-state-label-badge"); - if (HuiStateLabelBadge.prototype.cardmod_patched) - return; - HuiStateLabelBadge.prototype.cardmod_patched = true; - const _firstUpdated = HuiStateLabelBadge.prototype.firstUpdated; - HuiStateLabelBadge.prototype.firstUpdated = function (...args) { - var _a, _b; - _firstUpdated === null || _firstUpdated === void 0 ? void 0 : _firstUpdated.bind(this)(...args); - const config = this._config; - if ((_a = config === null || config === void 0 ? void 0 : config.card_mod) === null || _a === void 0 ? void 0 : _a.class) - this.classList.add(config.card_mod.class); - applyToElement(this, "badge", ((_b = config === null || config === void 0 ? void 0 : config.card_mod) === null || _b === void 0 ? void 0 : _b.style) || (config === null || config === void 0 ? void 0 : config.style) || "", { - config, - }); - }; -}); - -customElements.whenDefined("hui-view").then(() => { - const HuiView = customElements.get("hui-view"); - if (HuiView.prototype.cardmod_patched) - return; - HuiView.prototype.cardmod_patched = true; - const _firstUpdated = HuiView.prototype.firstUpdated; - HuiView.prototype.firstUpdated = function (...args) { - _firstUpdated === null || _firstUpdated === void 0 ? void 0 : _firstUpdated.bind(this)(...args); - applyToElement(this, "view"); - }; -}); - -customElements.whenDefined("hui-root").then(() => { - const HuiRoot = customElements.get("hui-root"); - if (HuiRoot.prototype.cardmod_patched) - return; - HuiRoot.prototype.cardmod_patched = true; - const _firstUpdated = HuiRoot.prototype.firstUpdated; - HuiRoot.prototype.firstUpdated = async function (...args) { - _firstUpdated === null || _firstUpdated === void 0 ? void 0 : _firstUpdated.bind(this)(...args); - applyToElement(this, "root"); - }; - selectTree(document, "home-assistant$home-assistant-main$app-drawer-layout partial-panel-resolver ha-panel-lovelace$hui-root", false).then((root) => { - root === null || root === void 0 ? void 0 : root.firstUpdated(); - }); -}); - -customElements.whenDefined("ha-more-info-dialog").then(() => { - const HaMoreInfoDialog = customElements.get("ha-more-info-dialog"); - if (HaMoreInfoDialog.prototype.cardmod_patched) - return; - HaMoreInfoDialog.prototype.cardmod_patched = true; - const _showDialog = HaMoreInfoDialog.prototype.showDialog; - HaMoreInfoDialog.prototype.showDialog = function (params, ...rest) { - _showDialog === null || _showDialog === void 0 ? void 0 : _showDialog.bind(this)(params, ...rest); - this.requestUpdate(); - this.updateComplete.then(async () => { - const haDialog = this.shadowRoot.querySelector("ha-dialog"); - if (haDialog) { - applyToElement(haDialog, "more-info", "", { config: params }, null, false); - } - }); - }; - selectTree(document, "home-assistant$ha-more-info-dialog", false).then((root) => { - if (root) { - root.showDialog = HaMoreInfoDialog.prototype.showDialog.bind(root); - root.showDialog({ entityId: root.entityId }); - } - }); -}); - -customElements.whenDefined("ha-sidebar").then(() => { - const HaSidebar = customElements.get("ha-sidebar"); - if (HaSidebar.prototype.cardmod_patched) - return; - HaSidebar.prototype.cardmod_patched = true; - const _firstUpdated = HaSidebar.prototype.firstUpdated; - HaSidebar.prototype.firstUpdated = async function (...args) { - _firstUpdated === null || _firstUpdated === void 0 ? void 0 : _firstUpdated.bind(this)(...args); - applyToElement(this, "sidebar"); - }; - selectTree(document, "home-assistant$home-assistant-main$app-drawer-layout app-drawer ha-sidebar", false).then((root) => root === null || root === void 0 ? void 0 : root.firstUpdated()); -}); - -customElements.whenDefined("hui-card-element-editor").then(() => { - const HuiCardElementEditor = customElements.get("hui-card-element-editor"); - if (HuiCardElementEditor.prototype.cardmod_patched) - return; - HuiCardElementEditor.prototype.cardmod_patched = true; - const _getConfigElement = HuiCardElementEditor.prototype.getConfigElement; - HuiCardElementEditor.prototype.getConfigElement = async function () { - const retval = await _getConfigElement.bind(this)(); - // Catch and patch the configElement - if (retval) { - const _setConfig = retval.setConfig; - retval.setConfig = function (config, ...rest) { - var _a, _b; - // Strip card_mod from the data that's sent to the config element - // and put it back after the config has been checked - const newConfig = JSON.parse(JSON.stringify(config)); - this._cardModData = { - card: newConfig.card_mod, - entities: [], - }; - if (newConfig.entities) { - for (const [i, e] of (_a = newConfig.entities) === null || _a === void 0 ? void 0 : _a.entries()) { - this._cardModData.entities[i] = e.card_mod; - delete e.card_mod; - } - } - delete newConfig.card_mod; - _setConfig.bind(this)(newConfig, ...rest); - if (newConfig.entities) { - for (const [i, e] of (_b = newConfig.entities) === null || _b === void 0 ? void 0 : _b.entries()) { - if (this._cardModData.entities[i]) - e.card_mod = this._cardModData.entities[i]; - } - } - }; - } - return retval; - }; - const _handleUIConfigChanged = HuiCardElementEditor.prototype._handleUIConfigChanged; - HuiCardElementEditor.prototype._handleUIConfigChanged = function (ev, ...rest) { - if (this._configElement && this._configElement._cardModData) { - const cardMod = this._configElement._cardModData; - if (cardMod.card) - ev.detail.config.card_mod = cardMod.card; - } - _handleUIConfigChanged.bind(this)(ev, ...rest); - }; -}); -customElements.whenDefined("hui-dialog-edit-card").then(() => { - const HuiDialogEditCard = customElements.get("hui-dialog-edit-card"); - if (HuiDialogEditCard.prototype.cardmod_patched) - return; - HuiDialogEditCard.prototype.cardmod_patched = true; - const _updated = HuiDialogEditCard.prototype.updated; - HuiDialogEditCard.prototype.updated = function (...args) { - _updated === null || _updated === void 0 ? void 0 : _updated.bind(this)(...args); - this.updateComplete.then(async () => { - var _a, _b, _c; - if (!this._cardModIcon) { - this._cardModIcon = document.createElement("ha-icon"); - this._cardModIcon.icon = "mdi:brush"; - } - const button = this.shadowRoot.querySelector("mwc-button[slot=secondaryAction]"); - if (!button) - return; - button.appendChild(this._cardModIcon); - if (((_a = this._cardConfig) === null || _a === void 0 ? void 0 : _a.card_mod) || - ((_c = (_b = this._cardConfig) === null || _b === void 0 ? void 0 : _b.entities) === null || _c === void 0 ? void 0 : _c.some((e) => e.card_mod))) { - this._cardModIcon.style.visibility = "visible"; - } - else { - this._cardModIcon.style.visibility = "hidden"; - } - }); - }; -}); - -customElements.whenDefined("hui-picture-elements-card").then(() => { - const HuiPictureElementsCard = customElements.get("hui-picture-elements-card"); - if (HuiPictureElementsCard.prototype.cardmod_patched) - return; - HuiPictureElementsCard.prototype.cardmod_patched = true; - const _setConfig = HuiPictureElementsCard.prototype.setConfig; - HuiPictureElementsCard.prototype.setConfig = function (...args) { - var _a, _b; - _setConfig === null || _setConfig === void 0 ? void 0 : _setConfig.bind(this)(...args); - for (const [i, el] of this._elements.entries()) { - const config = this._config.elements[i]; - if ((_a = config === null || config === void 0 ? void 0 : config.card_mod) === null || _a === void 0 ? void 0 : _a.class) - el.classList.add(config.card_mod.class); - if (config === null || config === void 0 ? void 0 : config.type) - el.classList.add(`type-${config.type.replace(":", "-")}`); - applyToElement(el, "element", (_b = config === null || config === void 0 ? void 0 : config.card_mod) === null || _b === void 0 ? void 0 : _b.style, { config }); - } - }; -}); - -const updateIcon = (el) => { - const styles = window.getComputedStyle(el); - const filter = styles.getPropertyValue("--card-mod-icon-dim"); - if (filter === "none") - el.style.filter = "none"; - const icon = styles.getPropertyValue("--card-mod-icon"); - if (icon) - el.icon = icon.trim(); - const color = styles.getPropertyValue("--card-mod-icon-color"); - if (color) - el.style.color = color; -}; -const bindCardMod = async (el) => { - if (el.cardmod_bound) - return; - el.cardmod_bound = true; - const _bind = async () => { - const cardMods = await findParentCardMod(el); - for (const cm of cardMods) { - cm.addEventListener("card-mod-update", async () => { - await cm.updateComplete; - updateIcon(el); - }); - } - updateIcon(el); - return cardMods; - }; - if ((await _bind()).size == 0) - window.setTimeout(() => _bind(), 1000); -}; -customElements.whenDefined("ha-state-icon").then(() => { - const HaStateIcon = customElements.get("ha-state-icon"); - if (HaStateIcon.prototype.cardmod_patched) - return; - HaStateIcon.prototype.cardmod_patched = true; - const _updated = HaStateIcon.prototype.updated; - HaStateIcon.prototype.updated = function (...args) { - _updated.bind(this)(...args); - bindCardMod(this); - updateIcon(this); - }; -}); -customElements.whenDefined("ha-icon").then(() => { - const HaIcon = customElements.get("ha-icon"); - if (HaIcon.prototype.cardmod_patched) - return; - HaIcon.prototype.cardmod_patched = true; - const _updated = HaIcon.prototype.updated; - HaIcon.prototype.updated = function (...args) { - _updated === null || _updated === void 0 ? void 0 : _updated.bind(this)(...args); - bindCardMod(this); - }; -}); -customElements.whenDefined("ha-svg-icon").then(() => { - const HaSvgIcon = customElements.get("ha-svg-icon"); - if (HaSvgIcon.prototype.cardmod_patched) - return; - HaSvgIcon.prototype.cardmod_patched = true; - const _updated = HaSvgIcon.prototype.updated; - HaSvgIcon.prototype.updated = function (...args) { - var _a, _b; - _updated === null || _updated === void 0 ? void 0 : _updated.bind(this)(...args); - if (((_b = (_a = this.parentNode) === null || _a === void 0 ? void 0 : _a.host) === null || _b === void 0 ? void 0 : _b.localName) === "ha-icon") - return; - bindCardMod(this); - }; -}); - -const NO_STYLE = ` -ha-card { - background: none; - box-shadow: none; - border: none; - transition: none; -}`; -class ModCard extends s { - setConfig(config) { - var _a; - this._config = JSON.parse(JSON.stringify(config)); - let style = ((_a = this._config.card_mod) === null || _a === void 0 ? void 0 : _a.style) || this._config.style; - if (style === undefined) { - style = NO_STYLE; - } - else if (typeof style === "string") { - style = NO_STYLE + style; - } - else if (style["."]) { - style["."] = NO_STYLE + style["."]; - } - else { - style["."] = NO_STYLE; - } - this._config.card_mod = { style }; - this.build_card(config.card); - } - async build_card(config) { - if (this._hass === undefined) - await new Promise((resolve) => (this._hassResolve = resolve)); - this._hassResolve = undefined; - const helpers = await window.loadCardHelpers(); - this.card = await helpers.createCardElement(config); - this.card.hass = this._hass; - } - firstUpdated() { - window.setTimeout(() => { - var _a, _b; - if ((_b = (_a = this.card) === null || _a === void 0 ? void 0 : _a.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector("ha-card")) { - console.info("%cYou are doing it wrong!", "color: red; font-weight: bold"); - let cardName = this.card.localName.replace(/hui-(.*)-card/, "$1"); - console.info(`mod-card should NEVER be used with a card that already has a ha-card element, such as ${cardName}`); - } - }, 3000); - } - set hass(hass) { - this._hass = hass; - if (this.card) - this.card.hass = hass; - if (this._hassResolve) - this._hassResolve(); - } - render() { - return y ` ${this.card} `; - } - getCardSize() { - if (this._config.report_size) - return this._config.report_size; - let ret = this.shadowRoot; - if (ret) - ret = ret.querySelector("ha-card card-maker"); - if (ret) - ret = ret.getCardSize; - if (ret) - ret = ret(); - if (ret) - return ret; - return 1; - } -} -__decorate([ - e() -], ModCard.prototype, "card", void 0); -(async () => { - // See explanation in card-mod.ts - while (customElements.get("home-assistant") === undefined) - await new Promise((resolve) => window.setTimeout(resolve, 100)); - if (!customElements.get("mod-card")) { - customElements.define("mod-card", ModCard); - } -})(); - -function refresh_theme() { - document.dispatchEvent(new Event("cm_update")); -} -const bases = [ - customElements.whenDefined("home-assistant"), - customElements.whenDefined("hc-main"), -]; -Promise.race(bases).then(() => { - window.setTimeout(async () => { - var _a, _b; - while (!hass()) { - await new Promise((resolve) => window.setTimeout(resolve, 500)); - } - hass().connection.subscribeEvents(() => { - window.setTimeout(refresh_theme, 500); - }, "themes_updated"); - (_a = document - .querySelector("home-assistant")) === null || _a === void 0 ? void 0 : _a.addEventListener("settheme", refresh_theme); - (_b = document - .querySelector("hc-main")) === null || _b === void 0 ? void 0 : _b.addEventListener("settheme", refresh_theme); - }, 1000); -}); - -const resources = getResources(); -if (resources.some((r) => r.endsWith("card-mod.js"))) ; -else { - fireEvent("ll-rebuild", {}); - console.info("You may not be getting optimal performance out of card-mod.\nSee https://github.com/thomasloven/lovelace-card-mod#performance-improvements"); -} + `}}e([st()],bt.prototype,"_rendered_styles",void 0),(async()=>{for(;void 0===customElements.get("home-assistant");)await new Promise((t=>window.setTimeout(t,100)));customElements.get("card-mod")||(customElements.define("card-mod",bt),console.info(`%cCARD-MOD ${pt} IS INSTALLED`,"color: green; font-weight: bold"))})(),customElements.whenDefined("ha-card").then((()=>{const t=customElements.get("ha-card");if(t.prototype.cardmod_patched)return;t.prototype.cardmod_patched=!0;const e=t.prototype.firstUpdated;t.prototype.firstUpdated=function(...t){var o,s;null==e||e.bind(this)(...t);const i=$t(this);(null===(o=null==i?void 0:i.card_mod)||void 0===o?void 0:o.class)&&this.classList.add(i.card_mod.class),(null==i?void 0:i.type)&&this.classList.add(`type-${i.type.replace(":","-")}`),yt(this,"card",(null===(s=null==i?void 0:i.card_mod)||void 0===s?void 0:s.style)||(null==i?void 0:i.style)||"",{config:i},null,!1).then((t=>{var e;const o=null===(e=this.parentNode)||void 0===e?void 0:e.host;if(o){if(o.setConfig&&!o.setConfig.cm_patched){const e=o.setConfig;o.setConfig=function(o,...s){var i;e.bind(this)(o,...s),t.variables={config:o},t.styles=(null===(i=o.card_mod)||void 0===i?void 0:i.style)||{}},o.setConfig.cm_patched=!0}if(o.update&&!o.update.cm_patched){const e=o.update;o.update=function(...o){e.bind(this)(...o),this.updateComplete?this.updateComplete.then((()=>{t.refresh()})):t.refresh()},o.update.cm_patched=!0}}}))}})),customElements.whenDefined("hui-entities-card").then((()=>{const t=customElements.get("hui-entities-card");if(t.prototype.cardmod_patched)return;t.prototype.cardmod_patched=!0;const e=t.prototype.renderEntity;t.prototype.renderEntity=function(t,...o){var s;const i=e.bind(this)(t,...o);if(!i||!i.values)return i;const n=i.values[0];if(!n)return i;if("custom:mod-card"===(null==t?void 0:t.type))return i;(null===(s=null==t?void 0:t.card_mod)||void 0===s?void 0:s.class)&&n.classList.add(t.card_mod.class),(null==t?void 0:t.type)&&n.classList.add(`type-${t.type.replace(":","-")}`);const r=async()=>{var e;return yt(n,"row",(null===(e=null==t?void 0:t.card_mod)||void 0===e?void 0:e.style)||(null==t?void 0:t.style)||"",{config:t})};return(async()=>{const t=await r();if(n.update&&!n.update.cm_patched){const e=n.update;n.update=function(...o){e.bind(this)(...o),this.updateComplete?this.updateComplete.then((()=>{t.refresh()})):t.refresh()}}})(),this.updateComplete.then((()=>r())),i.values[0]&&i.values[0].addEventListener("ll-rebuild",r),i}}));customElements.whenDefined("hui-glance-card").then((()=>{const t=customElements.get("hui-glance-card");if(t.prototype.cardmod_patched)return;t.prototype.cardmod_patched=!0;const e=t.prototype.updated;t.prototype.updated=function(...t){var o,s;null==e||e.bind(this)(...t);for(const t of this.shadowRoot.querySelectorAll("ha-card div.entity")){if(!t.cardmod_patched){t.cardmod_patched=!0;const e=t.attachShadow({mode:"open"});for(;t.firstChild;)e.append(t.firstChild);const o=document.createElement("style");e.appendChild(o),o.innerHTML="\ndiv {\n width: 100%;\n text-align: center;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n.name {\n min-height: var(--paper-font-body1_-_line-height, 20px);\n}\nstate-badge {\n margin: 8px 0;\n}\n"}const e=t.config||t.entityConf;(null===(o=null==e?void 0:e.card_mod)||void 0===o?void 0:o.class)&&t.classList.add(e.card_mod.class),yt(t,"glance",(null===(s=null==e?void 0:e.card_mod)||void 0===s?void 0:s.style)||(null==e?void 0:e.style)||"",{config:e})}}})),customElements.whenDefined("hui-state-label-badge").then((()=>{const t=customElements.get("hui-state-label-badge");if(t.prototype.cardmod_patched)return;t.prototype.cardmod_patched=!0;const e=t.prototype.firstUpdated;t.prototype.firstUpdated=function(...t){var o,s;null==e||e.bind(this)(...t);const i=this._config;(null===(o=null==i?void 0:i.card_mod)||void 0===o?void 0:o.class)&&this.classList.add(i.card_mod.class),yt(this,"badge",(null===(s=null==i?void 0:i.card_mod)||void 0===s?void 0:s.style)||(null==i?void 0:i.style)||"",{config:i})}})),customElements.whenDefined("hui-view").then((()=>{const t=customElements.get("hui-view");if(t.prototype.cardmod_patched)return;t.prototype.cardmod_patched=!0;const e=t.prototype.firstUpdated;t.prototype.firstUpdated=function(...t){null==e||e.bind(this)(...t),yt(this,"view")}})),customElements.whenDefined("hui-root").then((()=>{const t=customElements.get("hui-root");if(t.prototype.cardmod_patched)return;t.prototype.cardmod_patched=!0;const e=t.prototype.firstUpdated;t.prototype.firstUpdated=async function(...t){null==e||e.bind(this)(...t),yt(this,"root")},ft(document,"home-assistant$home-assistant-main$app-drawer-layout partial-panel-resolver ha-panel-lovelace$hui-root",!1).then((t=>{null==t||t.firstUpdated()}))})),customElements.whenDefined("ha-more-info-dialog").then((()=>{const t=customElements.get("ha-more-info-dialog");if(t.prototype.cardmod_patched)return;t.prototype.cardmod_patched=!0;const e=t.prototype.showDialog;t.prototype.showDialog=function(t,...o){null==e||e.bind(this)(t,...o),this.requestUpdate(),this.updateComplete.then((async()=>{const e=this.shadowRoot.querySelector("ha-dialog");e&&yt(e,"more-info","",{config:t},null,!1)}))},ft(document,"home-assistant$ha-more-info-dialog",!1).then((e=>{e&&(e.showDialog=t.prototype.showDialog.bind(e),e.showDialog({entityId:e.entityId}))}))})),customElements.whenDefined("ha-sidebar").then((()=>{const t=customElements.get("ha-sidebar");if(t.prototype.cardmod_patched)return;t.prototype.cardmod_patched=!0;const e=t.prototype.firstUpdated;t.prototype.firstUpdated=async function(...t){null==e||e.bind(this)(...t),yt(this,"sidebar")},ft(document,"home-assistant$home-assistant-main$app-drawer-layout app-drawer ha-sidebar",!1).then((t=>null==t?void 0:t.firstUpdated()))})),customElements.whenDefined("hui-card-element-editor").then((()=>{const t=customElements.get("hui-card-element-editor");if(t.prototype.cardmod_patched)return;t.prototype.cardmod_patched=!0;const e=t.prototype.getConfigElement;t.prototype.getConfigElement=async function(){const t=await e.bind(this)();if(t){const e=t.setConfig;t.setConfig=function(t,...o){var s,i;const n=JSON.parse(JSON.stringify(t));if(this._cardModData={card:n.card_mod,entities:[]},n.entities)for(const[t,e]of null===(s=n.entities)||void 0===s?void 0:s.entries())this._cardModData.entities[t]=e.card_mod,delete e.card_mod;if(delete n.card_mod,e.bind(this)(n,...o),n.entities)for(const[t,e]of null===(i=n.entities)||void 0===i?void 0:i.entries())this._cardModData.entities[t]&&(e.card_mod=this._cardModData.entities[t])}}return t};const o=t.prototype._handleUIConfigChanged;t.prototype._handleUIConfigChanged=function(t,...e){if(this._configElement&&this._configElement._cardModData){const e=this._configElement._cardModData;e.card&&(t.detail.config.card_mod=e.card)}o.bind(this)(t,...e)}})),customElements.whenDefined("hui-dialog-edit-card").then((()=>{const t=customElements.get("hui-dialog-edit-card");if(t.prototype.cardmod_patched)return;t.prototype.cardmod_patched=!0;const e=t.prototype.updated;t.prototype.updated=function(...t){null==e||e.bind(this)(...t),this.updateComplete.then((async()=>{var t,e,o;this._cardModIcon||(this._cardModIcon=document.createElement("ha-icon"),this._cardModIcon.icon="mdi:brush");const s=this.shadowRoot.querySelector("mwc-button[slot=secondaryAction]");s&&(s.appendChild(this._cardModIcon),(null===(t=this._cardConfig)||void 0===t?void 0:t.card_mod)||(null===(o=null===(e=this._cardConfig)||void 0===e?void 0:e.entities)||void 0===o?void 0:o.some((t=>t.card_mod)))?this._cardModIcon.style.visibility="visible":this._cardModIcon.style.visibility="hidden")}))}})),customElements.whenDefined("hui-picture-elements-card").then((()=>{const t=customElements.get("hui-picture-elements-card");if(t.prototype.cardmod_patched)return;t.prototype.cardmod_patched=!0;const e=t.prototype.setConfig;t.prototype.setConfig=function(...t){var o,s;null==e||e.bind(this)(...t);for(const[t,e]of this._elements.entries()){const i=this._config.elements[t];(null===(o=null==i?void 0:i.card_mod)||void 0===o?void 0:o.class)&&e.classList.add(i.card_mod.class),(null==i?void 0:i.type)&&e.classList.add(`type-${i.type.replace(":","-")}`),yt(e,"element",null===(s=null==i?void 0:i.card_mod)||void 0===s?void 0:s.style,{config:i})}}}));const At=t=>{const e=window.getComputedStyle(t);"none"===e.getPropertyValue("--card-mod-icon-dim")&&(t.style.filter="none");const o=e.getPropertyValue("--card-mod-icon");o&&(t.icon=o.trim());const s=e.getPropertyValue("--card-mod-icon-color");s&&(t.style.color=s)},St=async t=>{if(t.cardmod_bound)return;t.cardmod_bound=!0;const e=async()=>{const e=await Et(t);for(const o of e)o.addEventListener("card-mod-update",(async()=>{await o.updateComplete,At(t)}));return At(t),e};0==(await e()).size&&window.setTimeout((()=>e()),1e3)};customElements.whenDefined("ha-state-icon").then((()=>{const t=customElements.get("ha-state-icon");if(t.prototype.cardmod_patched)return;t.prototype.cardmod_patched=!0;const e=t.prototype.updated;t.prototype.updated=function(...t){e.bind(this)(...t),St(this),At(this)}})),customElements.whenDefined("ha-icon").then((()=>{const t=customElements.get("ha-icon");if(t.prototype.cardmod_patched)return;t.prototype.cardmod_patched=!0;const e=t.prototype.updated;t.prototype.updated=function(...t){null==e||e.bind(this)(...t),St(this)}})),customElements.whenDefined("ha-svg-icon").then((()=>{const t=customElements.get("ha-svg-icon");if(t.prototype.cardmod_patched)return;t.prototype.cardmod_patched=!0;const e=t.prototype.updated;t.prototype.updated=function(...t){var o,s;null==e||e.bind(this)(...t),"ha-icon"!==(null===(s=null===(o=this.parentNode)||void 0===o?void 0:o.host)||void 0===s?void 0:s.localName)&&St(this)}}));const Ct="\nha-card {\n background: none;\n box-shadow: none;\n border: none;\n transition: none;\n}";class Nt extends tt{setConfig(t){var e;this._config=JSON.parse(JSON.stringify(t));let o=(null===(e=this._config.card_mod)||void 0===e?void 0:e.style)||this._config.style;void 0===o?o=Ct:"string"==typeof o?o=Ct+o:o["."]?o["."]=Ct+o["."]:o["."]=Ct,this._config.card_mod={style:o},this.build_card(t.card)}async build_card(t){void 0===this._hass&&await new Promise((t=>this._hassResolve=t)),this._hassResolve=void 0;const e=await window.loadCardHelpers();this.card=await e.createCardElement(t),this.card.hass=this._hass}firstUpdated(){window.setTimeout((()=>{var t,e;if(null===(e=null===(t=this.card)||void 0===t?void 0:t.shadowRoot)||void 0===e?void 0:e.querySelector("ha-card")){console.info("%cYou are doing it wrong!","color: red; font-weight: bold");let t=this.card.localName.replace(/hui-(.*)-card/,"$1");console.info(`mod-card should NEVER be used with a card that already has a ha-card element, such as ${t}`)}}),3e3)}set hass(t){this._hass=t,this.card&&(this.card.hass=t),this._hassResolve&&this._hassResolve()}render(){return T` ${this.card} `}getCardSize(){if(this._config.report_size)return this._config.report_size;let t=this.shadowRoot;return t&&(t=t.querySelector("ha-card card-maker")),t&&(t=t.getCardSize),t&&(t=t()),t||1}}function Pt(){document.dispatchEvent(new Event("cm_update"))}e([st()],Nt.prototype,"card",void 0),(async()=>{for(;void 0===customElements.get("home-assistant");)await new Promise((t=>window.setTimeout(t,100)));customElements.get("mod-card")||customElements.define("mod-card",Nt)})();const Ot=[customElements.whenDefined("home-assistant"),customElements.whenDefined("hc-main")];Promise.race(Ot).then((()=>{window.setTimeout((async()=>{for(var e,o;!t();)await new Promise((t=>window.setTimeout(t,500)));t().connection.subscribeEvents((()=>{window.setTimeout(Pt,500)}),"themes_updated"),null===(e=document.querySelector("home-assistant"))||void 0===e||e.addEventListener("settheme",Pt),null===(o=document.querySelector("hc-main"))||void 0===o||o.addEventListener("settheme",Pt)}),1e3)}));const Ut=function(){var t,e,o;const s=document.querySelectorAll("script"),i=[];for(const n of s)if(null===(e=null===(t=null==n?void 0:n.innerText)||void 0===t?void 0:t.trim())||void 0===e?void 0:e.startsWith("import(")){const t=null===(o=n.innerText.split("\n"))||void 0===o?void 0:o.map((t=>t.trim()));for(const e of t)i.push(e.replace(/^import\(\"/,"").replace(/\"\);/,""))}return i}();Ut.some((t=>t.endsWith("card-mod.js")))||(!function(t,e,o=null){if((t=new Event(t,{bubbles:!0,cancelable:!1,composed:!0})).detail=e||{},o)o.dispatchEvent(t);else{var s=function(){var t=document.querySelector("hc-main");return t?(t=(t=(t=t&&t.shadowRoot)&&t.querySelector("hc-lovelace"))&&t.shadowRoot)&&t.querySelector("hui-view")||t.querySelector("hui-panel-view"):(t=(t=(t=(t=(t=(t=(t=(t=(t=(t=(t=(t=document.querySelector("home-assistant"))&&t.shadowRoot)&&t.querySelector("home-assistant-main"))&&t.shadowRoot)&&t.querySelector("app-drawer-layout partial-panel-resolver"))&&t.shadowRoot||t)&&t.querySelector("ha-panel-lovelace"))&&t.shadowRoot)&&t.querySelector("hui-root"))&&t.shadowRoot)&&t.querySelector("ha-app-layout"))&&t.querySelector("#view"))&&t.firstElementChild}();s&&s.dispatchEvent(t)}}("ll-rebuild",{}),console.info("You may not be getting optimal performance out of card-mod.\nSee https://github.com/thomasloven/lovelace-card-mod#performance-improvements")); diff --git a/package.json b/package.json index 41752e9..4e5c2a9 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "card-mod", "private": true, - "version": "3.1.6b1", + "version": "3.2.0", "description": "", "scripts": { "build": "rollup -c",