From 21c3e3e1da2718cce65e1e96b072558f3b3569e7 Mon Sep 17 00:00:00 2001 From: jnewland-renovate <195354+jnewland-renovate[bot]@users.noreply.github.com> Date: Fri, 18 Oct 2024 00:19:02 +0000 Subject: [PATCH] chore(deps): update dependency johanfrick/custom-sonos-card to v7 --- configuration.yaml | 2 +- script/sync-components | 2 +- www/custom-sonos-card.js | 1333 +++++++++++++++++++++++++++++--------- 3 files changed, 1037 insertions(+), 300 deletions(-) diff --git a/configuration.yaml b/configuration.yaml index b1f365cf0..1572c5523 100644 --- a/configuration.yaml +++ b/configuration.yaml @@ -53,7 +53,7 @@ lovelace: type: js - url: /local/mini-media-player-bundle.js?source=https://github.com/kalkih/mini-media-player/releases/download/v1.16.9/mini-media-player-bundle.js&v=2 type: module - - url: /local/custom-sonos-card.js?source=https://github.com/johanfrick/custom-sonos-card/releases/download/v5.20.1/custom-sonos-card.js&v=3 + - url: /local/custom-sonos-card.js?source=https://github.com/johanfrick/custom-sonos-card/releases/download/v7.19.1/custom-sonos-card.js&v=3 type: module - url: /local/mini-graph-card-bundle.js?source=https://github.com/kalkih/mini-graph-card/releases/download/v0.12.1/mini-graph-card-bundle.js type: module diff --git a/script/sync-components b/script/sync-components index f96ae17c4..62b213d3c 100755 --- a/script/sync-components +++ b/script/sync-components @@ -61,7 +61,7 @@ curl -sL --fail -o www/group-card.js https://raw.githubusercontent.com/custom-ca curl -sL --fail -o www/auto-entities.js https://raw.githubusercontent.com/thomasloven/lovelace-auto-entities/v1.13.0/auto-entities.js curl -sL --fail -o www/card-mod.js https://raw.githubusercontent.com/thomasloven/lovelace-card-mod/v3.4.3/card-mod.js curl -sL --fail -o www/mini-media-player-bundle.js https://github.com/kalkih/mini-media-player/releases/download/v1.16.9/mini-media-player-bundle.js -curl -sL --fail -o www/custom-sonos-card.js https://github.com/johanfrick/custom-sonos-card/releases/download/v5.20.1/custom-sonos-card.js +curl -sL --fail -o www/custom-sonos-card.js https://github.com/johanfrick/custom-sonos-card/releases/download/v7.19.1/custom-sonos-card.js curl -sL --fail -o www/mini-graph-card-bundle.js https://github.com/kalkih/mini-graph-card/releases/download/v0.12.1/mini-graph-card-bundle.js curl -sL --fail -o www/weather-chart-card.js https://github.com/Yevgenium/weather-chart-card/releases/download/1.2.0/weather-chart-card.js diff --git a/www/custom-sonos-card.js b/www/custom-sonos-card.js index 53b51c453..49943817a 100644 --- a/www/custom-sonos-card.js +++ b/www/custom-sonos-card.js @@ -1,292 +1,820 @@ -/*! ***************************************************************************** -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 t(t,e,i,s){var o,n=arguments.length,r=n<3?e:null===s?s=Object.getOwnPropertyDescriptor(e,i):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)r=Reflect.decorate(t,e,i,s);else for(var a=t.length-1;a>=0;a--)(o=t[a])&&(r=(n<3?o(r):n>3?o(e,i,r):o(e,i))||r);return n>3&&r&&Object.defineProperty(e,i,r),r +function e(e,t,A,i){var s,o=arguments.length,r=o<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,A):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)r=Reflect.decorate(e,t,A,i);else for(var n=e.length-1;n>=0;n--)(s=e[n])&&(r=(o<3?s(r):o>3?s(t,A,r):s(t,A))||r);return o>3&&r&&Object.defineProperty(t,A,r),r}"function"==typeof SuppressedError&&SuppressedError; /** * @license * Copyright 2019 Google LLC * SPDX-License-Identifier: BSD-3-Clause - */}const e=window.ShadowRoot&&(void 0===window.ShadyCSS||window.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,i=Symbol(),s=new Map;class o{constructor(t,e){if(this._$cssResult$=!0,e!==i)throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");this.cssText=t}get styleSheet(){let t=s.get(this.cssText);return e&&void 0===t&&(s.set(this.cssText,t=new CSSStyleSheet),t.replaceSync(this.cssText)),t}toString(){return this.cssText}}const n=(t,...e)=>{const s=1===t.length?t[0]:e.reduce(((e,i,s)=>e+(t=>{if(!0===t._$cssResult$)return t.cssText;if("number"==typeof t)return t;throw Error("Value passed to 'css' function must be a 'css' function result: "+t+". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.")})(i)+t[s+1]),t[0]);return new o(s,i)},r=e?t=>t:t=>t instanceof CSSStyleSheet?(t=>{let e="";for(const i of t.cssRules)e+=i.cssText;return(t=>new o("string"==typeof t?t:t+"",i))(e)})(t):t + */ +const t=globalThis,A=t.ShadowRoot&&(void 0===t.ShadyCSS||t.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,i=Symbol(),s=new WeakMap;class o{constructor(e,t,A){if(this._$cssResult$=!0,A!==i)throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");this.cssText=e,this.t=t}get styleSheet(){let e=this.o;const t=this.t;if(A&&void 0===e){const A=void 0!==t&&1===t.length;A&&(e=s.get(t)),void 0===e&&((this.o=e=new CSSStyleSheet).replaceSync(this.cssText),A&&s.set(t,e))}return e}toString(){return this.cssText}}const r=(e,...t)=>{const A=1===e.length?e[0]:t.reduce(((t,A,i)=>t+(e=>{if(!0===e._$cssResult$)return e.cssText;if("number"==typeof e)return e;throw Error("Value passed to 'css' function must be a 'css' function result: "+e+". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.")})(A)+e[i+1]),e[0]);return new o(A,e,i)},n=A?e=>e:e=>e instanceof CSSStyleSheet?(e=>{let t="";for(const A of e.cssRules)t+=A.cssText;return(e=>new o("string"==typeof e?e:e+"",void 0,i))(t)})(e):e /** * @license * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause - */;var a;const l=window.trustedTypes,c=l?l.emptyScript:"",d=window.reactiveElementPolyfillSupport,h={toAttribute(t,e){switch(e){case Boolean:t=t?c:null;break;case Object:case Array:t=null==t?t:JSON.stringify(t)}return t},fromAttribute(t,e){let i=t;switch(e){case Boolean:i=null!==t;break;case Number:i=null===t?null:Number(t);break;case Object:case Array:try{i=JSON.parse(t)}catch(t){i=null}}return i}},u=(t,e)=>e!==t&&(e==e||t==t),p={attribute:!0,type:String,converter:h,reflect:!1,hasChanged:u};class m extends HTMLElement{constructor(){super(),this._$Et=new Map,this.isUpdatePending=!1,this.hasUpdated=!1,this._$Ei=null,this.o()}static addInitializer(t){var e;null!==(e=this.l)&&void 0!==e||(this.l=[]),this.l.push(t)}static get observedAttributes(){this.finalize();const t=[];return this.elementProperties.forEach(((e,i)=>{const s=this._$Eh(i,e);void 0!==s&&(this._$Eu.set(s,i),t.push(s))})),t}static createProperty(t,e=p){if(e.state&&(e.attribute=!1),this.finalize(),this.elementProperties.set(t,e),!e.noAccessor&&!this.prototype.hasOwnProperty(t)){const i="symbol"==typeof t?Symbol():"__"+t,s=this.getPropertyDescriptor(t,i,e);void 0!==s&&Object.defineProperty(this.prototype,t,s)}}static getPropertyDescriptor(t,e,i){return{get(){return this[e]},set(s){const o=this[t];this[e]=s,this.requestUpdate(t,o,i)},configurable:!0,enumerable:!0}}static getPropertyOptions(t){return this.elementProperties.get(t)||p}static finalize(){if(this.hasOwnProperty("finalized"))return!1;this.finalized=!0;const t=Object.getPrototypeOf(this);if(t.finalize(),this.elementProperties=new Map(t.elementProperties),this._$Eu=new Map,this.hasOwnProperty("properties")){const t=this.properties,e=[...Object.getOwnPropertyNames(t),...Object.getOwnPropertySymbols(t)];for(const i of e)this.createProperty(i,t[i])}return this.elementStyles=this.finalizeStyles(this.styles),!0}static finalizeStyles(t){const e=[];if(Array.isArray(t)){const i=new Set(t.flat(1/0).reverse());for(const t of i)e.unshift(r(t))}else void 0!==t&&e.push(r(t));return e}static _$Eh(t,e){const i=e.attribute;return!1===i?void 0:"string"==typeof i?i:"string"==typeof t?t.toLowerCase():void 0}o(){var t;this._$Ep=new Promise((t=>this.enableUpdating=t)),this._$AL=new Map,this._$Em(),this.requestUpdate(),null===(t=this.constructor.l)||void 0===t||t.forEach((t=>t(this)))}addController(t){var e,i;(null!==(e=this._$Eg)&&void 0!==e?e:this._$Eg=[]).push(t),void 0!==this.renderRoot&&this.isConnected&&(null===(i=t.hostConnected)||void 0===i||i.call(t))}removeController(t){var e;null===(e=this._$Eg)||void 0===e||e.splice(this._$Eg.indexOf(t)>>>0,1)}_$Em(){this.constructor.elementProperties.forEach(((t,e)=>{this.hasOwnProperty(e)&&(this._$Et.set(e,this[e]),delete this[e])}))}createRenderRoot(){var t;const i=null!==(t=this.shadowRoot)&&void 0!==t?t:this.attachShadow(this.constructor.shadowRootOptions);return((t,i)=>{e?t.adoptedStyleSheets=i.map((t=>t instanceof CSSStyleSheet?t:t.styleSheet)):i.forEach((e=>{const i=document.createElement("style"),s=window.litNonce;void 0!==s&&i.setAttribute("nonce",s),i.textContent=e.cssText,t.appendChild(i)}))})(i,this.constructor.elementStyles),i}connectedCallback(){var t;void 0===this.renderRoot&&(this.renderRoot=this.createRenderRoot()),this.enableUpdating(!0),null===(t=this._$Eg)||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._$Eg)||void 0===t||t.forEach((t=>{var e;return null===(e=t.hostDisconnected)||void 0===e?void 0:e.call(t)}))}attributeChangedCallback(t,e,i){this._$AK(t,i)}_$ES(t,e,i=p){var s,o;const n=this.constructor._$Eh(t,i);if(void 0!==n&&!0===i.reflect){const r=(null!==(o=null===(s=i.converter)||void 0===s?void 0:s.toAttribute)&&void 0!==o?o:h.toAttribute)(e,i.type);this._$Ei=t,null==r?this.removeAttribute(n):this.setAttribute(n,r),this._$Ei=null}}_$AK(t,e){var i,s,o;const n=this.constructor,r=n._$Eu.get(t);if(void 0!==r&&this._$Ei!==r){const t=n.getPropertyOptions(r),a=t.converter,l=null!==(o=null!==(s=null===(i=a)||void 0===i?void 0:i.fromAttribute)&&void 0!==s?s:"function"==typeof a?a:null)&&void 0!==o?o:h.fromAttribute;this._$Ei=r,this[r]=l(e,t.type),this._$Ei=null}}requestUpdate(t,e,i){let s=!0;void 0!==t&&(((i=i||this.constructor.getPropertyOptions(t)).hasChanged||u)(this[t],e)?(this._$AL.has(t)||this._$AL.set(t,e),!0===i.reflect&&this._$Ei!==t&&(void 0===this._$EC&&(this._$EC=new Map),this._$EC.set(t,i))):s=!1),!this.isUpdatePending&&s&&(this._$Ep=this._$E_())}async _$E_(){this.isUpdatePending=!0;try{await this._$Ep}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._$Et&&(this._$Et.forEach(((t,e)=>this[e]=t)),this._$Et=void 0);let e=!1;const i=this._$AL;try{e=this.shouldUpdate(i),e?(this.willUpdate(i),null===(t=this._$Eg)||void 0===t||t.forEach((t=>{var e;return null===(e=t.hostUpdate)||void 0===e?void 0:e.call(t)})),this.update(i)):this._$EU()}catch(t){throw e=!1,this._$EU(),t}e&&this._$AE(i)}willUpdate(t){}_$AE(t){var e;null===(e=this._$Eg)||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)}_$EU(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$Ep}shouldUpdate(t){return!0}update(t){void 0!==this._$EC&&(this._$EC.forEach(((t,e)=>this._$ES(e,this[e],t))),this._$EC=void 0),this._$EU()}updated(t){}firstUpdated(t){}} + */,{is:a,defineProperty:l,getOwnPropertyDescriptor:c,getOwnPropertyNames:d,getOwnPropertySymbols:h,getPrototypeOf:g}=Object,E=globalThis,B=E.trustedTypes,u=B?B.emptyScript:"",Q=E.reactiveElementPolyfillSupport,p=(e,t)=>e,m={toAttribute(e,t){switch(t){case Boolean:e=e?u:null;break;case Object:case Array:e=null==e?e:JSON.stringify(e)}return e},fromAttribute(e,t){let A=e;switch(t){case Boolean:A=null!==e;break;case Number:A=null===e?null:Number(e);break;case Object:case Array:try{A=JSON.parse(e)}catch(e){A=null}}return A}},v=(e,t)=>!a(e,t),f={attribute:!0,type:String,converter:m,reflect:!1,hasChanged:v};Symbol.metadata??=Symbol("metadata"),E.litPropertyMetadata??=new WeakMap;class C extends HTMLElement{static addInitializer(e){this._$Ei(),(this.l??=[]).push(e)}static get observedAttributes(){return this.finalize(),this._$Eh&&[...this._$Eh.keys()]}static createProperty(e,t=f){if(t.state&&(t.attribute=!1),this._$Ei(),this.elementProperties.set(e,t),!t.noAccessor){const A=Symbol(),i=this.getPropertyDescriptor(e,A,t);void 0!==i&&l(this.prototype,e,i)}}static getPropertyDescriptor(e,t,A){const{get:i,set:s}=c(this.prototype,e)??{get(){return this[t]},set(e){this[t]=e}};return{get(){return i?.call(this)},set(t){const o=i?.call(this);s.call(this,t),this.requestUpdate(e,o,A)},configurable:!0,enumerable:!0}}static getPropertyOptions(e){return this.elementProperties.get(e)??f}static _$Ei(){if(this.hasOwnProperty(p("elementProperties")))return;const e=g(this);e.finalize(),void 0!==e.l&&(this.l=[...e.l]),this.elementProperties=new Map(e.elementProperties)}static finalize(){if(this.hasOwnProperty(p("finalized")))return;if(this.finalized=!0,this._$Ei(),this.hasOwnProperty(p("properties"))){const e=this.properties,t=[...d(e),...h(e)];for(const A of t)this.createProperty(A,e[A])}const e=this[Symbol.metadata];if(null!==e){const t=litPropertyMetadata.get(e);if(void 0!==t)for(const[e,A]of t)this.elementProperties.set(e,A)}this._$Eh=new Map;for(const[e,t]of this.elementProperties){const A=this._$Eu(e,t);void 0!==A&&this._$Eh.set(A,e)}this.elementStyles=this.finalizeStyles(this.styles)}static finalizeStyles(e){const t=[];if(Array.isArray(e)){const A=new Set(e.flat(1/0).reverse());for(const e of A)t.unshift(n(e))}else void 0!==e&&t.push(n(e));return t}static _$Eu(e,t){const A=t.attribute;return!1===A?void 0:"string"==typeof A?A:"string"==typeof e?e.toLowerCase():void 0}constructor(){super(),this._$Ep=void 0,this.isUpdatePending=!1,this.hasUpdated=!1,this._$Em=null,this._$Ev()}_$Ev(){this._$ES=new Promise((e=>this.enableUpdating=e)),this._$AL=new Map,this._$E_(),this.requestUpdate(),this.constructor.l?.forEach((e=>e(this)))}addController(e){(this._$EO??=new Set).add(e),void 0!==this.renderRoot&&this.isConnected&&e.hostConnected?.()}removeController(e){this._$EO?.delete(e)}_$E_(){const e=new Map,t=this.constructor.elementProperties;for(const A of t.keys())this.hasOwnProperty(A)&&(e.set(A,this[A]),delete this[A]);e.size>0&&(this._$Ep=e)}createRenderRoot(){const e=this.shadowRoot??this.attachShadow(this.constructor.shadowRootOptions);return((e,i)=>{if(A)e.adoptedStyleSheets=i.map((e=>e instanceof CSSStyleSheet?e:e.styleSheet));else for(const A of i){const i=document.createElement("style"),s=t.litNonce;void 0!==s&&i.setAttribute("nonce",s),i.textContent=A.cssText,e.appendChild(i)}})(e,this.constructor.elementStyles),e}connectedCallback(){this.renderRoot??=this.createRenderRoot(),this.enableUpdating(!0),this._$EO?.forEach((e=>e.hostConnected?.()))}enableUpdating(e){}disconnectedCallback(){this._$EO?.forEach((e=>e.hostDisconnected?.()))}attributeChangedCallback(e,t,A){this._$AK(e,A)}_$EC(e,t){const A=this.constructor.elementProperties.get(e),i=this.constructor._$Eu(e,A);if(void 0!==i&&!0===A.reflect){const s=(void 0!==A.converter?.toAttribute?A.converter:m).toAttribute(t,A.type);this._$Em=e,null==s?this.removeAttribute(i):this.setAttribute(i,s),this._$Em=null}}_$AK(e,t){const A=this.constructor,i=A._$Eh.get(e);if(void 0!==i&&this._$Em!==i){const e=A.getPropertyOptions(i),s="function"==typeof e.converter?{fromAttribute:e.converter}:void 0!==e.converter?.fromAttribute?e.converter:m;this._$Em=i,this[i]=s.fromAttribute(t,e.type),this._$Em=null}}requestUpdate(e,t,A){if(void 0!==e){if(A??=this.constructor.getPropertyOptions(e),!(A.hasChanged??v)(this[e],t))return;this.P(e,t,A)}!1===this.isUpdatePending&&(this._$ES=this._$ET())}P(e,t,A){this._$AL.has(e)||this._$AL.set(e,t),!0===A.reflect&&this._$Em!==e&&(this._$Ej??=new Set).add(e)}async _$ET(){this.isUpdatePending=!0;try{await this._$ES}catch(e){Promise.reject(e)}const e=this.scheduleUpdate();return null!=e&&await e,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){if(!this.isUpdatePending)return;if(!this.hasUpdated){if(this.renderRoot??=this.createRenderRoot(),this._$Ep){for(const[e,t]of this._$Ep)this[e]=t;this._$Ep=void 0}const e=this.constructor.elementProperties;if(e.size>0)for(const[t,A]of e)!0!==A.wrapped||this._$AL.has(t)||void 0===this[t]||this.P(t,this[t],A)}let e=!1;const t=this._$AL;try{e=this.shouldUpdate(t),e?(this.willUpdate(t),this._$EO?.forEach((e=>e.hostUpdate?.())),this.update(t)):this._$EU()}catch(t){throw e=!1,this._$EU(),t}e&&this._$AE(t)}willUpdate(e){}_$AE(e){this._$EO?.forEach((e=>e.hostUpdated?.())),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(e)),this.updated(e)}_$EU(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$ES}shouldUpdate(e){return!0}update(e){this._$Ej&&=this._$Ej.forEach((e=>this._$EC(e,this[e]))),this._$EU()}updated(e){}firstUpdated(e){}}C.elementStyles=[],C.shadowRootOptions={mode:"open"},C[p("elementProperties")]=new Map,C[p("finalized")]=new Map,Q?.({ReactiveElement:C}),(E.reactiveElementVersions??=[]).push("2.0.4"); /** * @license * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause */ -var v;m.finalized=!0,m.elementProperties=new Map,m.elementStyles=[],m.shadowRootOptions={mode:"open"},null==d||d({ReactiveElement:m}),(null!==(a=globalThis.reactiveElementVersions)&&void 0!==a?a:globalThis.reactiveElementVersions=[]).push("1.3.0");const y=globalThis.trustedTypes,g=y?y.createPolicy("lit-html",{createHTML:t=>t}):void 0,f=`lit$${(Math.random()+"").slice(9)}$`,b="?"+f,A=`<${b}>`,w=document,S=(t="")=>w.createComment(t),$=t=>null===t||"object"!=typeof t&&"function"!=typeof t,_=Array.isArray,C=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,I=/-->/g,x=/>/g,k=/>|[ \n \r](?:([^\s"'>=/]+)([ \n \r]*=[ \n \r]*(?:[^ \n \r"'`<>=]|("|')|))|$)/g,E=/'/g,O=/"/g,P=/^(?:script|style|textarea|title)$/i,j=(t=>(e,...i)=>({_$litType$:t,strings:e,values:i}))(1),N=Symbol.for("lit-noChange"),T=Symbol.for("lit-nothing"),M=new WeakMap,D=w.createTreeWalker(w,129,null,!1),R=(t,e)=>{const i=t.length-1,s=[];let o,n=2===e?"":"",r=C;for(let e=0;e"===l[0]?(r=null!=o?o:C,c=-1):void 0===l[1]?c=-2:(c=r.lastIndex-l[2].length,a=l[1],r=void 0===l[3]?k:'"'===l[3]?O:E):r===O||r===E?r=k:r===I||r===x?r=C:(r=k,o=void 0);const h=r===k&&t[e+1].startsWith("/>")?" ":"";n+=r===C?i+A:c>=0?(s.push(a),i.slice(0,c)+"$lit$"+i.slice(c)+f+h):i+f+(-2===c?(s.push(void 0),e):h)}const a=n+(t[i]||"")+(2===e?"":"");if(!Array.isArray(t)||!t.hasOwnProperty("raw"))throw Error("invalid template strings array");return[void 0!==g?g.createHTML(a):a,s]};class B{constructor({strings:t,_$litType$:e},i){let s;this.parts=[];let o=0,n=0;const r=t.length-1,a=this.parts,[l,c]=R(t,e);if(this.el=B.createElement(l,i),D.currentNode=this.el.content,2===e){const t=this.el.content,e=t.firstChild;e.remove(),t.append(...e.childNodes)}for(;null!==(s=D.nextNode())&&a.length0){s.textContent=y?y.emptyScript:"";for(let i=0;i{var e;return _(t)||"function"==typeof(null===(e=t)||void 0===e?void 0:e[Symbol.iterator])})(t)?this.S(t):this.$(t)}A(t,e=this._$AB){return this._$AA.parentNode.insertBefore(t,e)}k(t){this._$AH!==t&&(this._$AR(),this._$AH=this.A(t))}$(t){this._$AH!==T&&$(this._$AH)?this._$AA.nextSibling.data=t:this.k(w.createTextNode(t)),this._$AH=t}T(t){var e;const{values:i,_$litType$:s}=t,o="number"==typeof s?this._$AC(t):(void 0===s.el&&(s.el=B.createElement(s.h,this.options)),s);if((null===(e=this._$AH)||void 0===e?void 0:e._$AD)===o)this._$AH.m(i);else{const t=new W(o,this),e=t.p(this.options);t.m(i),this.k(e),this._$AH=t}}_$AC(t){let e=M.get(t.strings);return void 0===e&&M.set(t.strings,e=new B(t)),e}S(t){_(this._$AH)||(this._$AH=[],this._$AR());const e=this._$AH;let i,s=0;for(const o of t)s===e.length?e.push(i=new L(this.A(S()),this.A(S()),this,this.options)):i=e[s],i._$AI(o),s++;s2||""!==i[0]||""!==i[1]?(this._$AH=Array(i.length-1).fill(new String),this.strings=i):this._$AH=T}get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}_$AI(t,e=this,i,s){const o=this.strings;let n=!1;if(void 0===o)t=U(this,t,e,0),n=!$(t)||t!==this._$AH&&t!==N,n&&(this._$AH=t);else{const s=t;let r,a;for(t=o[0],r=0;re}):void 0,w="$lit$",P=`lit$${Math.random().toFixed(9).slice(2)}$`,S="?"+P,L=`<${S}>`,V=document,O=()=>V.createComment(""),M=e=>null===e||"object"!=typeof e&&"function"!=typeof e,k=Array.isArray,H="[ \t\n\f\r]",x=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,z=/-->/g,N=/>/g,T=RegExp(`>|${H}(?:([^\\s"'>=/]+)(${H}*=${H}*(?:[^ \t\n\f\r"'\`<>=]|("|')|))|$)`,"g"),U=/'/g,X=/"/g,R=/^(?:script|style|textarea|title)$/i,j=(e=>(t,...A)=>({_$litType$:e,strings:t,values:A}))(1),G=Symbol.for("lit-noChange"),W=Symbol.for("lit-nothing"),D=new WeakMap,q=V.createTreeWalker(V,129);function Z(e,t){if(!k(e)||!e.hasOwnProperty("raw"))throw Error("invalid template strings array");return void 0!==I?I.createHTML(t):t}class J{constructor({strings:e,_$litType$:t},A){let i;this.parts=[];let s=0,o=0;const r=e.length-1,n=this.parts,[a,l]=((e,t)=>{const A=e.length-1,i=[];let s,o=2===t?"":3===t?"":"",r=x;for(let t=0;t"===a[0]?(r=s??x,l=-1):void 0===a[1]?l=-2:(l=r.lastIndex-a[2].length,n=a[1],r=void 0===a[3]?T:'"'===a[3]?X:U):r===X||r===U?r=T:r===z||r===N?r=x:(r=T,s=void 0);const d=r===T&&e[t+1].startsWith("/>")?" ":"";o+=r===x?A+L:l>=0?(i.push(n),A.slice(0,l)+w+A.slice(l)+P+d):A+P+(-2===l?t:d)}return[Z(e,o+(e[A]||"")+(2===t?"":3===t?"":"")),i]})(e,t);if(this.el=J.createElement(a,A),q.currentNode=this.el.content,2===t||3===t){const e=this.el.content.firstChild;e.replaceWith(...e.childNodes)}for(;null!==(i=q.nextNode())&&n.length0){i.textContent=b?b.emptyScript:"";for(let A=0;Ak(e)||"function"==typeof e?.[Symbol.iterator])(e)?this.k(e):this._(e)}O(e){return this._$AA.parentNode.insertBefore(e,this._$AB)}T(e){this._$AH!==e&&(this._$AR(),this._$AH=this.O(e))}_(e){this._$AH!==W&&M(this._$AH)?this._$AA.nextSibling.data=e:this.T(V.createTextNode(e)),this._$AH=e}$(e){const{values:t,_$litType$:A}=e,i="number"==typeof A?this._$AC(e):(void 0===A.el&&(A.el=J.createElement(Z(A.h,A.h[0]),this.options)),A);if(this._$AH?._$AD===i)this._$AH.p(t);else{const e=new F(i,this),A=e.u(this.options);e.p(t),this.T(A),this._$AH=e}}_$AC(e){let t=D.get(e.strings);return void 0===t&&D.set(e.strings,t=new J(e)),t}k(e){k(this._$AH)||(this._$AH=[],this._$AR());const t=this._$AH;let A,i=0;for(const s of e)i===t.length?t.push(A=new K(this.O(O()),this.O(O()),this,this.options)):A=t[i],A._$AI(s),i++;i2||""!==A[0]||""!==A[1]?(this._$AH=Array(A.length-1).fill(new String),this.strings=A):this._$AH=W}_$AI(e,t=this,A,i){const s=this.strings;let o=!1;if(void 0===s)e=Y(this,e,t,0),o=!M(e)||e!==this._$AH&&e!==G,o&&(this._$AH=e);else{const i=e;let r,n;for(e=s[0],r=0;r{var s,o;const n=null!==(s=null==i?void 0:i.renderBefore)&&void 0!==s?s:e;let r=n._$litPart$;if(void 0===r){const t=null!==(o=null==i?void 0:i.renderBefore)&&void 0!==o?o:null;n._$litPart$=r=new L(e.insertBefore(S(),t),t,void 0,null!=i?i:{})}return r._$AI(t),r})(e,this.renderRoot,this.renderOptions)}connectedCallback(){var t;super.connectedCallback(),null===(t=this._$Dt)||void 0===t||t.setConnected(!0)}disconnectedCallback(){var t;super.disconnectedCallback(),null===(t=this._$Dt)||void 0===t||t.setConnected(!1)}render(){return N}}J.finalized=!0,J._$litElement$=!0,null===(Q=globalThis.litElementHydrateSupport)||void 0===Q||Q.call(globalThis,{LitElement:J});const F=globalThis.litElementPolyfillSupport;null==F||F({LitElement:J}),(null!==(Z=globalThis.litElementVersions)&&void 0!==Z?Z:globalThis.litElementVersions=[]).push("3.2.0"); +class se extends C{constructor(){super(...arguments),this.renderOptions={host:this},this.o=void 0}createRenderRoot(){const e=super.createRenderRoot();return this.renderOptions.renderBefore??=e.firstChild,e}update(e){const t=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(e),this.o=((e,t,A)=>{const i=A?.renderBefore??t;let s=i._$litPart$;if(void 0===s){const e=A?.renderBefore??null;i._$litPart$=s=new K(t.insertBefore(O(),e),e,void 0,A??{})}return s._$AI(e),s})(t,this.renderRoot,this.renderOptions)}connectedCallback(){super.connectedCallback(),this.o?.setConnected(!0)}disconnectedCallback(){super.disconnectedCallback(),this.o?.setConnected(!1)}render(){return G}}se._$litElement$=!0,se.finalized=!0,globalThis.litElementHydrateSupport?.({LitElement:se});const oe=globalThis.litElementPolyfillSupport;oe?.({LitElement:se}),(globalThis.litElementVersions??=[]).push("4.1.0"); /** * @license * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause */ -const X=(t,e)=>"method"===e.kind&&e.descriptor&&!("value"in e.descriptor)?{...e,finisher(i){i.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(i){i.createProperty(e.key,t)}};function tt(t){return(e,i)=>void 0!==i?((t,e,i)=>{e.constructor.createProperty(i,t)})(t,e,i):X(t,e) +const re={attribute:!0,type:String,converter:m,reflect:!1,hasChanged:v},ne=(e=re,t,A)=>{const{kind:i,metadata:s}=A;let o=globalThis.litPropertyMetadata.get(s);if(void 0===o&&globalThis.litPropertyMetadata.set(s,o=new Map),o.set(A.name,e),"accessor"===i){const{name:i}=A;return{set(A){const s=t.get.call(this);t.set.call(this,A),this.requestUpdate(i,s,e)},init(t){return void 0!==t&&this.P(i,void 0,e),t}}}if("setter"===i){const{name:i}=A;return function(A){const s=this[i];t.call(this,A),this.requestUpdate(i,s,e)}}throw Error("Unsupported decorator location: "+i)};function ae(e){return(t,A)=>"object"==typeof A?ne(e,t,A):((e,t,A)=>{const i=t.hasOwnProperty(A);return t.constructor.createProperty(A,i?{...e,wrapped:!0}:e),i?Object.getOwnPropertyDescriptor(t,A):void 0})(e,t,A) /** * @license * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause - */}function et(t){return tt({...t,state:!0})} + */}function le(e){return ae({...e,state:!0,attribute:!1})} /** * @license - * Copyright 2021 Google LLC + * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause - */var it,st;null===(it=window.HTMLSlotElement)||void 0===it||it.prototype.assignedElements,function(t){t.MEDIA_BROWSER="media browser",t.GROUPS="groups",t.PLAYER="player",t.GROUPING="grouping"}(st||(st={}));const ot=1,nt=2,rt=t=>(...e)=>({_$litDirective$:t,values:e});class at{constructor(t){}get _$AU(){return this._$AM._$AU}_$AT(t,e,i){this._$Ct=t,this._$AM=e,this._$Ci=i}_$AS(t,e){return this.update(t,e)}update(t,e){return this.render(...e)}} + */const ce=(e,t,A)=>(A.configurable=!0,A.enumerable=!0,Reflect.decorate&&"object"!=typeof t&&Object.defineProperty(e,t,A),A) /** * @license - * Copyright 2018 Google LLC + * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause - */const lt=rt(class extends at{constructor(t){var e;if(super(t),t.type!==ot||"style"!==t.name||(null===(e=t.strings)||void 0===e?void 0:e.length)>2)throw Error("The `styleMap` directive must be used in the `style` attribute and must be the only part in the attribute.")}render(t){return Object.keys(t).reduce(((e,i)=>{const s=t[i];return null==s?e:e+`${i=i.replace(/(?:^(webkit|moz|ms|o)|)(?=[A-Z])/g,"-$&").toLowerCase()}:${s};`}),"")}update(t,[e]){const{style:i}=t.element;if(void 0===this.ct){this.ct=new Set;for(const t in e)this.ct.add(t);return this.render(e)}this.ct.forEach((t=>{null==e[t]&&(this.ct.delete(t),t.includes("-")?i.removeProperty(t):i[t]="")}));for(const t in e){const s=e[t];null!=s&&(this.ct.add(t),t.includes("-")?i.setProperty(t,s):i[t]=s)}return N}});function ct(t,e,i){const s=t.states[i].attributes.friendly_name||"";if(e.entityNameRegex){const t=e.entityNameRegex.split("/").filter((t=>t));if(2===t.length){const[e,i]=t;return s.replace(new RegExp(e,"g"),i)}}else if(e.entityNameRegexToReplace)return s.replace(new RegExp(e.entityNameRegexToReplace,"g"),e.entityNameReplacement||"");return s}function dt(t){return t.attributes.sonos_group||t.attributes.group_members}function ht(t,e){return t.entities?[...new Set(t.entities)].filter((t=>e.states[t])):Object.values(e.states).filter(dt).map((t=>t.entity_id)).sort()}function ut(t,e,i){const s=t.filter((i=>function(t,e,i){const s=t.states[e];try{const t=dt(s).filter((t=>i.indexOf(t)>-1)),o=(null==t?void 0:t.length)>1,n=o&&t&&t[0]===e;return!o||n}catch(t){return console.error("Failed to determine group master",JSON.stringify(s),t),!1}}(e,i,t))),o=s.map((s=>function(t,e,i,s){const o=t.states[e];try{const n=dt(o).filter((t=>t!==e&&i.indexOf(t)>-1));return{entity:e,state:o.state,roomName:ct(t,s,e),members:pt(n,t,s)}}catch(t){return console.error("Failed to create group",JSON.stringify(o),t),{}}}(e,s,t,i)));return Object.fromEntries(o.map((t=>[t.entity,t])))}function pt(t,e,i){return Object.fromEntries(t.map((t=>[t,ct(e,i,t)])))}function mt(t,e,i,s){return vt(t)?(null==s?void 0:s.mobileWidth)||i:(null==s?void 0:s.width)||e}function vt(t){var e;return innerWidth<((null===(e=t.layout)||void 0===e?void 0:e.mobileThresholdPx)||650)}function yt(t,e,i){var s;return lt(Object.assign(Object.assign({"--sonos-card-style-name":t},i),null===(s=null==e?void 0:e.styles)||void 0===s?void 0:s[t]))}function gt(t,e){return yt("button-section",t,Object.assign({background:"var(--sonos-int-button-section-background-color)",borderRadius:"var(--sonos-int-border-radius)",border:"var(--sonos-int-border-width) solid var(--sonos-int-color)",marginTop:"1rem",padding:"0 0.5rem"},e))}const ft=j`
- No Sonos player selected. Do one of the following: -
    -
  • Add the Sonos Groups card to this dashboard
  • -
  • Configure entityId for the card
  • -
  • Replace this one with the Sonos card containing all sections.
  • -
-
`;function bt(t){window.addEventListener("sonos-card-active-player",t);const e=new CustomEvent("sonos-card-request-player",{bubbles:!0,composed:!0});window.dispatchEvent(e)}function At(t){window.removeEventListener("sonos-card-active-player",t)}function wt(t){var e,i;const s=(t,e)=>console.error("Sonos Card: "+t+" configuration is deprecated. Please use "+e+" instead.");t.layout&&!(null===(e=t.layout)||void 0===e?void 0:e.mediaBrowser)&&t.layout.favorites&&(s("layout.favorites","layout.mediaBrowser"),t.layout.mediaBrowser=t.layout.favorites),t.layout&&!(null===(i=t.layout)||void 0===i?void 0:i.mediaItem)&&t.layout.favorite&&(s("layout.favorite","layout.mediaItem"),t.layout.mediaItem=t.layout.favorite),t.singleSectionMode&&s("singleSectionMode","individual cards"),t.selectedPlayer&&(s("selectedPlayer","entityId"),t.entityId=t.selectedPlayer)}const St=n` - :host { - --sonos-int-background-color: var( - --sonos-background-color, - var(--ha-card-background, var(--card-background-color, white)) - ); - --sonos-int-ha-card-background-color: var( - --sonos-ha-card-background-color, - var(--ha-card-background, var(--card-background-color, white)) - ); - --sonos-int-player-section-background: var(--sonos-player-section-background, #ffffffe6); - --sonos-int-color: var(--sonos-color, var(--secondary-text-color)); - --sonos-int-artist-album-text-color: var(--sonos-artist-album-text-color, var(--secondary-text-color)); - --sonos-int-song-text-color: var(--sonos-song-text-color, var(--sonos-accent-color, var(--accent-color))); - --sonos-int-accent-color: var(--sonos-accent-color, var(--accent-color)); - --sonos-int-title-color: var(--sonos-title-color, var(--secondary-text-color)); - --sonos-int-border-radius: var(--sonos-border-radius, 0.25rem); - --sonos-int-border-width: var(--sonos-border-width, 0.125rem); - --sonos-int-media-button-white-space: var( - --sonos-media-buttons-multiline, - var(--sonos-favorites-multiline, nowrap) - ); - --sonos-int-button-section-background-color: var( - --sonos-button-section-background-color, - var(--card-background-color) - ); - --mdc-icon-size: 1rem; - } -`;function $t(t,e){return e.showAllSections?t:j` ${t}`}function _t(t){return yt("ha-card",t,{color:"var(--sonos-int-color)",background:"var(--sonos-int-ha-card-background-color)"})}function Ct(t){return"playing"===t}function It(t){const e=t.attributes;return`${e.media_artist||""} - ${e.media_title||""}`.replace(/^ - /g,"")}class xt extends J{disconnectedCallback(){this.tracker&&(clearInterval(this.tracker),this.tracker=void 0),super.disconnectedCallback()}render(){var t;this.entity=this.hass.states[this.entityId];const e=(null===(t=this.entity)||void 0===t?void 0:t.attributes.media_duration)||0;return e>0?(this.trackProgress(),j` -
- ${kt(this.playingProgress)} -
- -
- -${kt(e-this.playingProgress)} -
- `):j``}progressStyle(){return yt("progress",this.config,{width:"100%",fontSize:"x-small",display:"flex","--paper-progress-active-color":"lightgray"})}timeStyle(){return yt("progress-time",this.config)}barStyle(){return yt("progress-bar",this.config,{display:"flex","flex-grow":"1","align-items":"center",padding:"5px"})}trackProgress(){var t,e,i;const s=(null===(t=this.entity)||void 0===t?void 0:t.attributes.media_position)||0,o=Ct(null===(e=this.entity)||void 0===e?void 0:e.state),n=(null===(i=this.entity)||void 0===i?void 0:i.attributes.media_position_updated_at)||0;this.playingProgress=o?s+(Date.now()-new Date(n).getTime())/1e3:s,this.tracker||(this.tracker=setInterval((()=>this.trackProgress()),1e3)),o||(clearInterval(this.tracker),this.tracker=void 0)}paperProgressStyle(){return yt("progress-bar-paper",this.config,{flexGrow:"1","--paper-progress-active-color":"var(--sonos-int-accent-color)"})}}t([tt({attribute:!1})],xt.prototype,"hass",void 0),t([tt()],xt.prototype,"config",void 0),t([tt()],xt.prototype,"entityId",void 0),t([et()],xt.prototype,"playingProgress",void 0);const kt=t=>{const e=new Date(1e3*t).toISOString().substring(11,19);return e.startsWith("00:")?e.substring(3):e};customElements.define("sonos-progress",xt);class Et extends J{render(){const t=this.entity.attributes;return t.media_title?j` -
-
${t.friendly_name}
-
${It(this.entity)}
-
${t.media_album_name}
- -
- `:j`
-
${t.friendly_name}
-
${this.config.noMediaText?this.config.noMediaText:"🎺 What do you want to play? 🥁"}
-
`}infoStyle(){return yt("player-info",this.config,{margin:"0.25rem",padding:"0.5rem",textAlign:"center",background:"var(--sonos-int-player-section-background)",borderRadius:"var(--sonos-int-border-radius)"})}entityStyle(){return yt("player-entity",this.config,{overflow:"hidden",textOverflow:"ellipsis",fontSize:"0.75rem",fontWeight:"500",color:"var(--sonos-int-artist-album-text-color)",whiteSpace:"wrap"})}artistAlbumStyle(){return yt("player-artist-album",this.config,{overflow:"hidden",textOverflow:"ellipsis",fontSize:"0.75rem",fontWeight:"300",color:"var(--sonos-int-artist-album-text-color)",whiteSpace:"wrap"})}songStyle(){return yt("player-song",this.config,{overflow:"hidden",textOverflow:"ellipsis",fontSize:"1.15rem",fontWeight:"400",color:"var(--sonos-int-song-text-color)",whiteSpace:"wrap"})}noMediaTextStyle(){return yt("no-media-text",this.config,{flexGrow:"1",display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",margin:"0.25rem",padding:"0.5rem"})}static get styles(){return St}}t([tt({attribute:!1})],Et.prototype,"hass",void 0),t([tt()],Et.prototype,"config",void 0),t([tt()],Et.prototype,"entity",void 0),customElements.define("sonos-player-header",Et);class Ot{constructor(t,e){this.hassService=e,this.hass=t}async join(t,e){await this.hassService.callMediaService("join",{entity_id:t,group_members:e})}async unjoin(t){await this.hassService.callMediaService("unjoin",{entity_id:t})}async createGroup(t,e){let i;for(const s of Object.values(e))if(t.indexOf(s.entity)>-1){if(Ct(s.state))return void await this.modifyExistingGroup(s,t);i=i||s}i?await this.modifyExistingGroup(i,t):await this.join(t[0],t)}async modifyExistingGroup(t,e){const i=Object.keys(t.members).filter((t=>-1===e.indexOf(t)));(null==i?void 0:i.length)&&await this.unjoin(i),await this.join(t.entity,e)}async pause(t){await this.hassService.callMediaService("media_pause",{entity_id:t})}async prev(t){await this.hassService.callMediaService("media_previous_track",{entity_id:t})}async next(t){await this.hassService.callMediaService("media_next_track",{entity_id:t})}async play(t){await this.hassService.callMediaService("media_play",{entity_id:t})}async shuffle(t,e){await this.hassService.callMediaService("shuffle_set",{entity_id:t,shuffle:e})}async repeat(t,e){const i="all"===e?"one":"one"===e?"off":"all";await this.hassService.callMediaService("repeat_set",{entity_id:t,repeat:i})}async volumeDown(t,e){await this.hassService.callMediaService("volume_down",{entity_id:t});for(const t in e)await this.hassService.callMediaService("volume_down",{entity_id:t})}async volumeUp(t,e){await this.hassService.callMediaService("volume_up",{entity_id:t});for(const t in e)await this.hassService.callMediaService("volume_up",{entity_id:t})}async volumeSet(t,e,i){const s=e/100;await this.hassService.callMediaService("volume_set",{entity_id:t,volume_level:s});for(const t in i)await this.hassService.callMediaService("volume_set",{entity_id:t,volume_level:s})}async volumeMute(t,e,i){await this.hassService.callMediaService("volume_mute",{entity_id:t,is_volume_muted:e});for(const t in i)await this.hassService.callMediaService("volume_mute",{entity_id:t,is_volume_muted:e})}async setSource(t,e){await this.hassService.callMediaService("select_source",{source:e,entity_id:t})}async playMedia(t,e){await this.hassService.callMediaService("play_media",{entity_id:t,media_content_id:e.media_content_id,media_content_type:e.media_content_type})}}class Pt{constructor(t){this.hass=t}async callMediaService(t,e){await this.hass.callService("media_player",t,e)}async browseMedia(t,e,i){return await this.hass.callWS({type:"media_player/browse_media",entity_id:t,media_content_id:i,media_content_type:e})}async getRelatedSwitchEntities(t){return new Promise((async(e,i)=>{const s={type:"render_template",template:"{{ device_entities(device_id('"+t+"')) }}"};try{const t=await this.hass.connection.subscribeMessage((i=>{t(),e(i.result.filter((t=>t.indexOf("switch")>-1)))}),s)}catch(t){i(t)}}))}async toggle(t){await this.hass.callService("homeassistant","toggle",{entity_id:t})}}class jt extends J{render(){const t=new Pt(this.hass);this.mediaControlService=new Ot(this.hass,t);const e=100*this.hass.states[this.entityId].attributes.volume_level;let i=100,s="rgb(211, 3, 32)";e<20&&(this.config.disableDynamicVolumeSlider||(i=30),s="rgb(72,187,14)");const o=this.members&&Object.keys(this.members).length?!Object.keys(this.members).some((t=>!this.hass.states[t].attributes.is_volume_muted)):this.hass.states[this.entityId].attributes.is_volume_muted;return j` -
- -
-
-
0%
- ${e>0&&e<95?j`
${Math.round(e)}%
`:""} -
${i}%
-
- - -
-
- `}async onChange(t){const e=Nt(t);return await this.setVolume(e)}async setVolume(t){return await this.mediaControlService.volumeSet(this.entityId,t,this.members)}async onClick(t,e){const i=Nt(t);i===e?this.dispatchEvent(new CustomEvent("volumeClicked")):await this.setVolume(i),t.stopPropagation()}volumeRangeStyle(t){return yt("player-volume-range",this.config,{width:"105%",marginLeft:"-3%","--paper-progress-active-color":t,"--paper-slider-knob-color":t,"--paper-slider-height":"0.3rem"})}volumeStyle(){return yt("player-volume",this.config,{display:"flex",flex:"1"})}volumeSliderStyle(){return yt("player-volume-slider",this.config,{flex:"1"})}volumeLevelStyle(){return yt("player-volume-level",this.config,{fontSize:"x-small",display:"flex"})}muteStyle(){return yt("player-mute",this.config,{"--mdc-icon-size":"1.25rem",alignSelf:"center",marginRight:"0.7rem"})}}function Nt(t){var e;return Number.parseInt(null===(e=null==t?void 0:t.target)||void 0===e?void 0:e.value)}t([tt({attribute:!1})],jt.prototype,"hass",void 0),t([tt()],jt.prototype,"config",void 0),t([tt()],jt.prototype,"entityId",void 0),t([tt()],jt.prototype,"members",void 0),t([tt()],jt.prototype,"volumeClicked",void 0),customElements.define("sonos-volume",jt); + */;var de,he;!function(e){e.MEDIA_BROWSER="media browser",e.GROUPS="groups",e.PLAYER="player",e.GROUPING="grouping",e.VOLUMES="volumes"}(de||(de={})),function(e){e[e.PAUSE=1]="PAUSE",e[e.SEEK=2]="SEEK",e[e.VOLUME_SET=4]="VOLUME_SET",e[e.VOLUME_MUTE=8]="VOLUME_MUTE",e[e.PREVIOUS_TRACK=16]="PREVIOUS_TRACK",e[e.NEXT_TRACK=32]="NEXT_TRACK",e[e.TURN_ON=128]="TURN_ON",e[e.TURN_OFF=256]="TURN_OFF",e[e.PLAY_MEDIA=512]="PLAY_MEDIA",e[e.VOLUME_BUTTONS=1024]="VOLUME_BUTTONS",e[e.SELECT_SOURCE=2048]="SELECT_SOURCE",e[e.STOP=4096]="STOP",e[e.CLEAR_PLAYLIST=8192]="CLEAR_PLAYLIST",e[e.PLAY=16384]="PLAY",e[e.SHUFFLE_SET=32768]="SHUFFLE_SET",e[e.SELECT_SOUND_MODE=65536]="SELECT_SOUND_MODE",e[e.BROWSE_MEDIA=131072]="BROWSE_MEDIA",e[e.REPEAT_SET=262144]="REPEAT_SET",e[e.GROUPING=524288]="GROUPING"}(he||(he={}));var ge="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z",Ee="M19,4H15.5L14.5,3H9.5L8.5,4H5V6H19M6,19A2,2 0 0,0 8,21H16A2,2 0 0,0 18,19V7H6V19Z",Be="M20.71,7.04C20.37,7.38 20.04,7.71 20.03,8.04C20,8.36 20.34,8.69 20.66,9C21.14,9.5 21.61,9.95 21.59,10.44C21.57,10.93 21.06,11.44 20.55,11.94L16.42,16.08L15,14.66L19.25,10.42L18.29,9.46L16.87,10.87L13.12,7.12L16.96,3.29C17.35,2.9 18,2.9 18.37,3.29L20.71,5.63C21.1,6 21.1,6.65 20.71,7.04M3,17.25L12.56,7.68L16.31,11.43L6.75,21H3V17.25Z",ue="M19,13H13V19H11V13H5V11H11V5H13V11H19V13Z",Qe="M3,9H7L12,4V20L7,15H3V9M14,11H22V13H14V11Z",pe="M3,9H7L12,4V20L7,15H3V9M14,11H17V8H19V11H22V13H19V16H17V13H14V11Z"; /** * @license * Copyright 2020 Google LLC * SPDX-License-Identifier: BSD-3-Clause */ -const Tt=(t,e)=>{var i,s;const o=t._$AN;if(void 0===o)return!1;for(const t of o)null===(s=(i=t)._$AO)||void 0===s||s.call(i,e,!1),Tt(t,e);return!0},Mt=t=>{let e,i;do{if(void 0===(e=t._$AM))break;i=e._$AN,i.delete(t),t=e}while(0===(null==i?void 0:i.size))},Dt=t=>{for(let e;e=t._$AM;t=e){let i=e._$AN;if(void 0===i)e._$AN=i=new Set;else if(i.has(t))break;i.add(t),Ut(e)}}; +const me=1,ve=2,fe=e=>(...t)=>({_$litDirective$:e,values:t}); +/** + * @license + * Copyright 2017 Google LLC + * SPDX-License-Identifier: BSD-3-Clause + */class Ce{constructor(e){}get _$AU(){return this._$AM._$AU}_$AT(e,t,A){this.t=e,this._$AM=t,this.i=A}_$AS(e,t){return this.update(e,t)}update(e,t){return this.render(...t)}} /** * @license * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause - */function Rt(t){void 0!==this._$AN?(Mt(this),this._$AM=t,Dt(this)):this._$AM=t}function Bt(t,e=!1,i=0){const s=this._$AH,o=this._$AN;if(void 0!==o&&0!==o.size)if(e)if(Array.isArray(s))for(let t=i;t{var e,i,s,o;t.type==nt&&(null!==(e=(s=t)._$AP)&&void 0!==e||(s._$AP=Bt),null!==(i=(o=t)._$AQ)&&void 0!==i||(o._$AQ=Rt))};class Wt extends at{constructor(){super(...arguments),this._$AN=void 0}_$AT(t,e,i){super._$AT(t,e,i),Dt(this),this.isConnected=t._$AU}_$AO(t,e=!0){var i,s;t!==this.isConnected&&(this.isConnected=t,t?null===(i=this.reconnected)||void 0===i||i.call(this):null===(s=this.disconnected)||void 0===s||s.call(this)),e&&(Tt(this,t),Mt(this))}setValue(t){if((t=>void 0===t.strings)(this._$Ct))this._$Ct._$AI(t,this);else{const e=[...this._$Ct._$AH];e[this._$Ci]=t,this._$Ct._$AI(e,this,0)}}disconnected(){}reconnected(){}} + */const ye=(e,t)=>{const A=e._$AN;if(void 0===A)return!1;for(const e of A)e._$AO?.(t,!1),ye(e,t);return!0},be=e=>{let t,A;do{if(void 0===(t=e._$AM))break;A=t._$AN,A.delete(e),e=t}while(0===A?.size)},Ie=e=>{for(let t;t=e._$AM;e=t){let A=t._$AN;if(void 0===A)t._$AN=A=new Set;else if(A.has(e))break;A.add(e),Se(t)}};function we(e){void 0!==this._$AN?(be(this),this._$AM=e,Ie(this)):this._$AM=e}function Pe(e,t=!1,A=0){const i=this._$AH,s=this._$AN;if(void 0!==s&&0!==s.size)if(t)if(Array.isArray(i))for(let e=A;e{e.type==ve&&(e._$AP??=Pe,e._$AQ??=we)};class Le extends Ce{constructor(){super(...arguments),this._$AN=void 0}_$AT(e,t,A){super._$AT(e,t,A),Ie(this),this.isConnected=e._$AU}_$AO(e,t=!0){e!==this.isConnected&&(this.isConnected=e,e?this.reconnected?.():this.disconnected?.()),t&&(ye(this,e),be(this))}setValue(e){if((e=>void 0===e.strings)(this.t))this.t._$AI(e,this);else{const t=[...this.t._$AH];t[this.i]=e,this.t._$AI(t,this,0)}}disconnected(){}reconnected(){}} /** * @license * Copyright 2021 Google LLC * SPDX-License-Identifier: BSD-3-Clause - */class Lt{constructor(t){this.U=t}disconnect(){this.U=void 0}reconnect(t){this.U=t}deref(){return this.U}}class zt{constructor(){this.Y=void 0,this.q=void 0}get(){return this.Y}pause(){var t;null!==(t=this.Y)&&void 0!==t||(this.Y=new Promise((t=>this.q=t)))}resume(){var t;null===(t=this.q)||void 0===t||t.call(this),this.Y=this.q=void 0}} + */class Ve{constructor(e){this.Y=e}disconnect(){this.Y=void 0}reconnect(e){this.Y=e}deref(){return this.Y}}class Oe{constructor(){this.Z=void 0,this.q=void 0}get(){return this.Z}pause(){this.Z??=new Promise((e=>this.q=e))}resume(){this.q?.(),this.Z=this.q=void 0}} /** * @license * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause - */const Vt=t=>!(t=>null===t||"object"!=typeof t&&"function"!=typeof t)(t)&&"function"==typeof t.then;const Gt=rt(class extends Wt{constructor(){super(...arguments),this._$Cwt=1073741823,this._$Cyt=[],this._$CG=new Lt(this),this._$CK=new zt}render(...t){var e;return null!==(e=t.find((t=>!Vt(t))))&&void 0!==e?e:N}update(t,e){const i=this._$Cyt;let s=i.length;this._$Cyt=e;const o=this._$CG,n=this._$CK;this.isConnected||this.disconnected();for(let t=0;tthis._$Cwt);t++){const r=e[t];if(!Vt(r))return this._$Cwt=t,r;t{for(;n.get();)await n.get();const e=o.deref();if(void 0!==e){const i=e._$Cyt.indexOf(r);i>-1&&iawait this.mediaControlService.volumeDown(this.entityId,this.members),this.prev=async()=>await this.mediaControlService.prev(this.entityId),this.play=async()=>await this.mediaControlService.play(this.entityId),this.pause=async()=>await this.mediaControlService.pause(this.entityId),this.next=async()=>await this.mediaControlService.next(this.entityId),this.shuffle=async()=>{var t;return await this.mediaControlService.shuffle(this.entityId,!(null===(t=this.entity)||void 0===t?void 0:t.attributes.shuffle))},this.repeat=async()=>{var t;return await this.mediaControlService.repeat(this.entityId,null===(t=this.entity)||void 0===t?void 0:t.attributes.repeat)},this.volUp=async()=>await this.mediaControlService.volumeUp(this.entityId,this.members),this.volumeClicked=()=>{this.isGroup&&this.toggleShowAllVolumes()},this.toggleShowAllVolumes=()=>{this.showVolumes=!this.showVolumes,clearTimeout(this.timerToggleShowAllVolumes),this.showVolumes&&(this.scrollToBottom(),this.timerToggleShowAllVolumes=window.setTimeout((()=>{this.showVolumes=!1,this.dispatchVolumesToggled(),window.scrollTo(0,0)}),3e4)),this.dispatchVolumesToggled()}}render(){this.entityId=this.entity.entity_id,this.hassService=new Pt(this.hass),this.mediaControlService=new Ot(this.hass,this.hassService);const t=ut(ht(this.config,this.hass),this.hass,this.config);this.members=t[this.entityId].members,this.isGroup=dt(this.entity).length>1;let e=[];this.isGroup&&(e=dt(this.entity).map((t=>this.groupMemberVolume(t))));const i=!Ct(this.entity.state);return j` -
-
${e}
-
- ${this.controlIcon("mdi:volume-minus",this.volDown)} ${this.controlIcon("mdi:skip-backward",this.prev)} - ${i?this.controlIcon("mdi:play",this.play):this.controlIcon("mdi:stop",this.pause)} - ${this.controlIcon("mdi:skip-forward",this.next)} ${this.controlIcon(this.shuffleIcon(),this.shuffle)} - ${this.controlIcon(this.repeatIcon(),this.repeat)} ${Gt(this.getAdditionalSwitches())} - ${this.controlIcon("mdi:arrow-expand-vertical",this.toggleShowAllVolumes,!this.isGroup)} - ${this.controlIcon("mdi:volume-plus",this.volUp)} + */const Me=e=>!(e=>null===e||"object"!=typeof e&&"function"!=typeof e)(e)&&"function"==typeof e.then,ke=1073741823;const He=fe(class extends Le{constructor(){super(...arguments),this.wt=ke,this.bt=[],this.K=new Ve(this),this.X=new Oe}render(...e){return e.find((e=>!Me(e)))??G}update(e,t){const A=this.bt;let i=A.length;this.bt=t;const s=this.K,o=this.X;this.isConnected||this.disconnected();for(let e=0;ethis.wt);e++){const r=t[e];if(!Me(r))return this.wt=e,r;e{for(;o.get();)await o.get();const t=s.deref();if(void 0!==t){const A=t.bt.indexOf(r);A>-1&&Aawait this.mediaControlService.volumeDown(this.volumePlayer,!this.config.playerVolumeEntityId),this.volUp=async()=>await this.mediaControlService.volumeUp(this.volumePlayer,!this.config.playerVolumeEntityId),this.rewind=async()=>await this.mediaControlService.seek(this.volumePlayer,this.volumePlayer.attributes.media_position-(this.config.fastForwardAndRewindStepSizeSeconds||15)),this.fastForward=async()=>await this.mediaControlService.seek(this.volumePlayer,this.volumePlayer.attributes.media_position+(this.config.fastForwardAndRewindStepSizeSeconds||15))}render(){var e;this.config=this.store.config,this.activePlayer=this.store.activePlayer,this.mediaControlService=this.store.mediaControlService;const t=!!this.config.showVolumeUpAndDownButtons&&W,A=!!this.config.showFastForwardAndRewindButtons&&W;return this.volumePlayer=null!==(e=this.activePlayer.getMember(this.config.playerVolumeEntityId))&&void 0!==e?e:this.activePlayer,j` +
+
+
+ + + + + + + + + +
+ ${this.config.showAudioInputFormat&&He(this.getAudioInputFormat())} +
+ +
+ +
+ + +
+ `}async getAudioInputFormat(){const e=(await this.store.hassService.getRelatedEntities(this.activePlayer,"sensor")).find((e=>e.entity_id.includes("audio_input_format")));return e&&e.state&&"No audio"!==e.state?j`
${e.state}
`:""}showShuffle(){return this.config.hidePlayerControlShuffleButton?[]:[xe]}showPrev(){return this.config.hidePlayerControlPrevTrackButton?[]:[Xe]}showNext(){return this.config.hidePlayerControlNextTrackButton?[]:[Ue]}showRepeat(){return this.config.hidePlayerControlRepeatButton?[]:[ze]}showBrowseMedia(){return this.config.showBrowseMediaInPlayerSection?[Re]:[]}static get styles(){return r` + .main { + overflow: hidden auto; + } + .icons { + justify-content: center; + display: flex; + align-items: center; + } + *[hide] { + display: none; + } + .big-icon { + --mdc-icon-button-size: 5rem; + --mdc-icon-size: 5rem; + } + .audio-input-format { + flex: 1 0 0; + margin-bottom: 10px; + text-align: center; + align-self: stretch; + position: relative; + } + .audio-input-format > div { + color: var(--card-background-color); + background: var(--disabled-text-color); + text-overflow: ellipsis; + overflow: hidden; + white-space: nowrap; + position: absolute; + bottom: 0; + right: 0; + max-width: 100%; + font-size: smaller; + line-height: normal; + padding: 3px; + } + .flex-1 { + flex: 1; + } + `}}e([ae({attribute:!1})],je.prototype,"store",void 0),customElements.define("sonos-player-controls",je);const Ge="sonos-card-dispatch-event-",We="active-player",De=Ge+We,qe=`${Ge}call-media-started`,Ze=`${Ge}call-media-done`,Je="item-selected",Ye=r` + .list { + --mdc-theme-primary: var(--accent-color); + --mdc-list-vertical-padding: 0px; + overflow: hidden; + } +`,Fe=r` + .title { + color: var(--secondary-text-color); + font-weight: bold; + padding: 0 0.5rem; + text-overflow: ellipsis; + overflow: hidden; + white-space: nowrap; + } +`,{TURN_ON:Ke}=he;function $e(e,t=[]){const A=e.members.map((e=>e.id)).sort();if(null==t?void 0:t.length){const e=t.find((e=>e.entities.map((e=>e.player.id)).sort().toString()===A.toString()));if(e)return e.name}return e.members.map((e=>e.name)).join(" + ")}function _e(e,t,A){et(t)?function(e,t){const A=tt(e,t);window.dispatchEvent(A)}(De,{entityId:e}):A.dispatchEvent(tt(We,{entityId:e}))}function et(e){return e.sections&&e.sections.length-1}class rt extends se{render(){this.config=this.store.config,this.activePlayer=this.store.activePlayer;const e=$e(this.activePlayer,this.store.predefinedGroups);let t=this.activePlayer.getCurrentTrack();t=t||this.config.labelWhenNoMediaIsSelected||"No media selected",this.config.showSourceInPlayer&&this.activePlayer.attributes.source&&(t=`${t} (${this.activePlayer.attributes.source})`);let A=this.activePlayer.attributes.media_album_name;return this.config.showChannelInPlayer&&this.activePlayer.attributes.media_channel?A=this.activePlayer.attributes.media_channel:!this.config.hidePlaylistInPlayer&&this.activePlayer.attributes.media_playlist&&(A=`${this.activePlayer.attributes.media_playlist} - ${A}`),j`
+
${e}
+
${t}
+
${A}
+ +
`}static get styles(){return r` + .info { + text-align: center; + } + + .entity { + overflow: hidden; + text-overflow: ellipsis; + font-size: 1rem; + font-weight: 500; + color: var(--secondary-text-color); + white-space: nowrap; + } + + .song { + overflow: hidden; + text-overflow: ellipsis; + font-size: 1.15rem; + font-weight: 400; + color: var(--accent-color); + } + + .artist-album { + overflow: hidden; + text-overflow: ellipsis; + font-size: 1rem; + font-weight: 300; + color: var(--secondary-text-color); + } + `}}e([ae({attribute:!1})],rt.prototype,"store",void 0),customElements.define("sonos-player-header",rt); +/** + * @license + * Copyright 2018 Google LLC + * SPDX-License-Identifier: BSD-3-Clause + */ +const nt="important",at=" !"+nt,lt=fe(class extends Ce{constructor(e){if(super(e),e.type!==me||"style"!==e.name||e.strings?.length>2)throw Error("The `styleMap` directive must be used in the `style` attribute and must be the only part in the attribute.")}render(e){return Object.keys(e).reduce(((t,A)=>{const i=e[A];return null==i?t:t+`${A=A.includes("-")?A:A.replace(/(?:^(webkit|moz|ms|o)|)(?=[A-Z])/g,"-$&").toLowerCase()}:${i};`}),"")}update(e,[t]){const{style:A}=e.element;if(void 0===this.ft)return this.ft=new Set(Object.keys(t)),this.render(t);for(const e of this.ft)null==t[e]&&(this.ft.delete(e),e.includes("-")?A.removeProperty(e):A[e]=null);for(const e in t){const i=t[e];if(null!=i){this.ft.add(e);const t="string"==typeof i&&i.endsWith(at);e.includes("-")||t?A.setProperty(e,t?i.slice(0,-11):i,t?nt:""):A[e]=i}}return G}});class ct extends se{constructor(){super(...arguments),this.mediaDuration=0}disconnectedCallback(){this.tracker&&(clearInterval(this.tracker),this.tracker=void 0),super.disconnectedCallback()}render(){var e;this.activePlayer=this.store.activePlayer,this.mediaDuration=(null===(e=this.activePlayer)||void 0===e?void 0:e.attributes.media_duration)||0;return this.mediaDuration>0?(this.trackProgress(),j` +
+ ${dt(this.playingProgress)} +
+
+
+ -${dt(this.mediaDuration-this.playingProgress)} +
+ `):j``}async handleSeek(e){const t=this.progressBar.offsetWidth,A=e.offsetX/t,i=this.mediaDuration*A;await this.store.mediaControlService.seek(this.activePlayer,i)}progressBarStyle(e){return lt({width:this.playingProgress/e*100+"%"})}trackProgress(){var e,t,A;const i=(null===(e=this.activePlayer)||void 0===e?void 0:e.attributes.media_position)||0,s=null===(t=this.activePlayer)||void 0===t?void 0:t.isPlaying(),o=(null===(A=this.activePlayer)||void 0===A?void 0:A.attributes.media_position_updated_at)||0;this.playingProgress=s?i+(Date.now()-new Date(o).getTime())/1e3:i,this.tracker||(this.tracker=setInterval((()=>this.trackProgress()),1e3)),s||(clearInterval(this.tracker),this.tracker=void 0)}static get styles(){return r` + .progress { + width: 100%; + font-size: x-small; + display: flex; + --paper-progress-active-color: lightgray; + } + + .bar { + display: flex; + flex-grow: 1; + align-items: center; + padding: 5px; + cursor: pointer; + } + + .progress-bar { + background-color: var(--accent-color); + height: 50%; + transition: width 0.1s linear; + } + `}}e([ae({attribute:!1})],ct.prototype,"store",void 0),e([le()],ct.prototype,"playingProgress",void 0),e([function(e,t){return(A,i,s)=>{const o=t=>t.renderRoot?.querySelector(e)??null;if(t){const{get:e,set:t}="object"==typeof i?A:s??(()=>{const e=Symbol();return{get(){return this[e]},set(t){this[e]=t}}})();return ce(A,i,{get(){let A=e.call(this);return void 0===A&&(A=o(this),(null!==A||this.hasUpdated)&&t.call(this,A)),A}})}return ce(A,i,{get(){return o(this)}})}}(".bar")],ct.prototype,"progressBar",void 0);const dt=e=>{const t=new Date(1e3*e).toISOString().substring(11,19);return t.startsWith("00:")?t.substring(3):t};customElements.define("sonos-progress",ct);class ht extends se{constructor(){super(...arguments),this.updateMembers=!0,this.slim=!1}render(){this.config=this.store.config,this.mediaControlService=this.store.mediaControlService;const e=this.player.getVolume(),t=this.getMax(e),A=this.player.isMuted(this.updateMembers)?"M3,9H7L12,4V20L7,15H3V9M16.59,12L14,9.41L15.41,8L18,10.59L20.59,8L22,9.41L19.41,12L22,14.59L20.59,16L18,13.41L15.41,16L14,14.59L16.59,12Z":"M14,3.23V5.29C16.89,6.15 19,8.83 19,12C19,15.17 16.89,17.84 14,18.7V20.77C18,19.86 21,16.28 21,12C21,7.72 18,4.14 14,3.23M16.5,12C16.5,10.23 15.5,8.71 14,7.97V16C15.5,15.29 16.5,13.76 16.5,12M3,9V15H7L12,20V4L7,9H3Z",i=this.player.ignoreVolume;return j` +
+ +
+ +
+
0%
+
${e}%
+
${t}%
+
- ${this.mainVolume()} +
${e}%
+
- `}shuffleIcon(){var t;return(null===(t=this.entity)||void 0===t?void 0:t.attributes.shuffle)?"mdi:shuffle-variant":"mdi:shuffle-disabled"}repeatIcon(){var t;const e=null===(t=this.entity)||void 0===t?void 0:t.attributes.repeat;return"all"===e?"mdi:repeat":"one"===e?"mdi:repeat-once":"mdi:repeat-off"}controlIcon(t,e,i=!1,s){return this.clickableIcon(t,e,i,this.iconStyle(s))}clickableIcon(t,e,i=!1,s){return j` `}getAdditionalSwitches(){return this.config.skipAdditionalPlayerSwitches?"":this.hassService.getRelatedSwitchEntities(this.entityId).then((t=>t.map((t=>this.controlIcon(this.hass.states[t].attributes.icon||"",(()=>this.hassService.toggle(t)),!1,"on"===this.hass.states[t].state?{color:"var(--sonos-int-accent-color)"}:{})))))}mainStyle(){return yt("media-controls",this.config,{background:"var(--sonos-int-player-section-background)",margin:"0.25rem",padding:"0.5rem",borderRadius:"var(--sonos-int-border-radius)",overflow:"hidden auto"})}iconsStyle(){return yt("media-controls-icons",this.config,{justifyContent:"space-between",display:this.showVolumes?"none":"flex"})}iconStyle(t){return yt("media-controls-icon",this.config,Object.assign({padding:"0.3rem","--mdc-icon-size":"min(100%, 1.25rem)"},t))}volumeNameStyle(t){return yt("player-volume-name",this.config,Object.assign({marginTop:"1rem",marginLeft:"0.4rem",flex:"1",overflow:"hidden",flexDirection:"column"},t&&{display:"none"}))}volumeNameTextStyle(){return yt("player-volume-name-text",this.config,{flex:"1",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"})}volumeNameIconStyle(){return yt("player-volume-name-icon",this.config,{flex:"1","--mdc-icon-size":"1.5rem",marginLeft:"-0.3rem"})}static get styles(){return[n` - ha-icon:focus, - ha-icon:hover { - color: var(--sonos-int-accent-color); - } - `,St]}mainVolume(){const t=this.config.allVolumesText?this.config.allVolumesText:"All";return this.volume(this.entityId,t,this.members)}groupMemberVolume(t){const e=ct(this.hass,this.config,t);return this.volume(t,e)}volume(t,e,i){return j`
-
-
${e}
- ${this.clickableIcon("mdi:arrow-left",(()=>this.toggleShowAllVolumes()),!i,this.volumeNameIconStyle())} + `}getMax(e){var t,A;const i=Math.max(0,Math.min(null!==(t=this.config.dynamicVolumeSliderThreshold)&&void 0!==t?t:20,100)),s=Math.max(0,Math.min(null!==(A=this.config.dynamicVolumeSliderMax)&&void 0!==A?A:30,100));return e + +
+
- -
`}dispatchVolumesToggled(){this.dispatchEvent(new CustomEvent("volumesToggled",{detail:this.showVolumes}))}scrollToBottom(){setTimeout((()=>{var t;const e=null===(t=this.renderRoot)||void 0===t?void 0:t.querySelector("#mediaControls");e&&(e.scrollTop=e.scrollHeight)}))}volumeStyle(t,e){return yt("player-volume",this.config,Object.assign({flex:t?"4":"1"},e&&{borderBottom:"dotted var(--sonos-int-color)",marginTop:"0.4rem"}))}} + `}artworkStyle(){var e;const t=null!==(e=this.config.artworkMinHeight)&&void 0!==e?e:5;return`${this.getBackgroundImage()}; min-height: ${t}rem`}getBackgroundImage(){var e;const t=`url(${null!==(e=this.config.fallbackArtwork)&&void 0!==e?e:"TV"===this.activePlayer.attributes.media_title?"":""})`,A=this.getArtworkImage();return A?`background-image: url(${A.entityImage}), ${t}${A.sizePercentage?`; background-size: ${A.sizePercentage}%`:""}`:`background-image: ${t}`}getArtworkImage(){var e;const t=this.config.artworkHostname||"",{media_title:A,media_artist:i,media_album_name:s,media_content_id:o,media_channel:r,entity_picture:n}=this.activePlayer.attributes;let a,l=n?t+n:n;const c=this.config.mediaArtworkOverrides;if(c){let t=c.find((e=>A&&A===e.mediaTitleEquals||i&&i===e.mediaArtistEquals||s&&s===e.mediaAlbumNameEquals||r&&r===e.mediaChannelEquals||o&&o===e.mediaContentIdEquals));t||(t=c.find((e=>!l&&e.ifMissing))),(null==t?void 0:t.imageUrl)&&(l=t.imageUrl,a=null!==(e=null==t?void 0:t.sizePercentage)&&void 0!==e?e:a)}return{entityImage:l,sizePercentage:a}}static get styles(){return r` + .hoverable:focus, + .hoverable:hover { + color: var(--accent-color); + } + + .hoverable:active { + color: var(--primary-color); + } + + .container { + display: grid; + grid-template-columns: 100%; + grid-template-rows: min-content auto min-content; + grid-template-areas: + 'header' + 'artwork' + 'controls'; + min-height: 100%; + background-position: center; + background-repeat: no-repeat; + background-size: cover; + } + + .header { + grid-area: header; + margin: 0.75rem 3.25rem; + padding: 0.5rem; + } + + .controls { + grid-area: controls; + overflow-y: auto; + margin: 0.25rem; + padding: 0.5rem; + } + + .artwork { + grid-area: artwork; + align-self: center; + flex-grow: 1; + flex-shrink: 0; + width: 100%; + height: 100%; + min-height: 5rem; + background-position: center; + background-repeat: no-repeat; + background-size: contain; + } + + *[hide] { + display: none; + } + + *[background] { + background-color: rgba(var(--rgb-card-background-color), 0.9); + border-radius: 10px; + } + `}}e([ae({attribute:!1})],gt.prototype,"store",void 0); /** * @license * Copyright 2021 Google LLC * SPDX-License-Identifier: BSD-3-Clause */ -function Yt(t,e,i){return t?e():null==i?void 0:i()}t([tt()],Ht.prototype,"hass",void 0),t([tt()],Ht.prototype,"config",void 0),t([tt()],Ht.prototype,"entity",void 0),t([tt()],Ht.prototype,"showVolumes",void 0),t([tt()],Ht.prototype,"volumesToggled",void 0),t([et()],Ht.prototype,"timerToggleShowAllVolumes",void 0),customElements.define("sonos-media-controls",Ht);class qt extends J{constructor(){super(...arguments),this.entityIdListener=t=>{const e=t.detail.entityId;e!==this.entityId&&(this.entityId=e,this.showVolumes=!1)}}connectedCallback(){super.connectedCallback(),bt(this.entityIdListener)}disconnectedCallback(){At(this.entityIdListener),super.disconnectedCallback()}setConfig(t){const e=JSON.parse(JSON.stringify(t));wt(e),this.config=e}render(){if(!this.entityId&&this.config.entityId&&(this.entityId=this.config.entityId),this.entityId&&this.hass){this.entity=this.hass.states[this.entityId];const t=j` -
-
- ${Yt(!this.showVolumes,(()=>j``))} - {for(const A of t)if(A[0]===e)return(0,A[1])();return A?.()};class Bt{constructor(e,t,A,i){this.hass=e,this.currentSection=t,this.card=A,this.config=i}async callMediaService(e,t){this.card.dispatchEvent(tt(qe,{section:this.currentSection}));try{await this.hass.callService("media_player",e,t)}finally{this.card.dispatchEvent(tt(Ze))}}async browseMedia(e,t,A){var i;const s=await this.hass.callWS({type:"media_player/browse_media",entity_id:e.id,media_content_id:A,media_content_type:t});return this.config.replaceHttpWithHttpsForThumbnails&&(s.children=null===(i=s.children)||void 0===i?void 0:i.map((e=>{var t;return Object.assign(Object.assign({},e),{thumbnail:null===(t=e.thumbnail)||void 0===t?void 0:t.replace("http://","https://")})}))),s}async getRelatedEntities(e,...t){return new Promise((async(A,i)=>{const s={type:"render_template",template:"{{ device_entities(device_id('"+e.id+"')) }}"};try{const e=await this.hass.connection.subscribeMessage((i=>{e(),A(i.result.filter((e=>t.some((t=>e.includes(t))))).map((e=>this.hass.states[e])))}),s)}catch(e){i(e)}}))}}const ut="";function Qt(e,t){for(const A in e)if(pt(A)===pt(t))return e[A]}function pt(e){return e.replace(/[^a-zA-Z ]/g,"")}function mt(e,t){let A=-1;return e.forEach(((e,i)=>{pt(e)===pt(t)&&(A=i)})),A}function vt(e,t){const A=e.some((e=>e.thumbnail));return e.map((e=>{const i=function(e,t,A){var i,s;let o=null!==(i=Qt(t.customThumbnail,e.title))&&void 0!==i?i:e.thumbnail;return o?(null==o?void 0:o.match(/https:\/\/brands\.home-assistant\.io\/.+\/logo.png/))&&(o=null==o?void 0:o.replace("logo.png","icon.png")):(o=Qt(t.customThumbnailIfMissing,e.title),A&&!o&&(o=(null===(s=t.customThumbnailIfMissing)||void 0===s?void 0:s.default)||ut)),o||""}(e,t,A);return Object.assign(Object.assign({},e),{thumbnail:i})}))}function ft(e,t=!0){return j` +
+
${e.title}
+ `}class Ct{constructor(e,t){this.hassService=e,this.config=t}async getFavorites(e){if(!e)return[];let t=await this.getFavoritesForPlayer(e);return t=t.flatMap((e=>e)),t=this.removeDuplicates(t),t=t.length?t:this.getFavoritesFromStates(e),t.filter((e=>{var t;return-1===mt(null!==(t=this.config.favoritesToIgnore)&&void 0!==t?t:[],e.title)}))}removeDuplicates(e){return e.filter(((e,t,A)=>t===A.findIndex((t=>t.title===e.title))))}async getFavoritesForPlayer(e){var t;try{const A=null===(t=(await this.hassService.browseMedia(e,"favorites","")).children)||void 0===t?void 0:t.map((t=>this.hassService.browseMedia(e,t.media_content_type,t.media_content_id)));return(A?await Promise.all(A):[]).flatMap((e=>{var t;return null!==(t=e.children)&&void 0!==t?t:[]}))}catch(t){return console.log(`Sonos Card: error getting favorites for player ${e.id}: ${JSON.stringify(t)}`),[]}}getFavoritesFromStates(e){return(e.attributes.hasOwnProperty("source_list")?e.attributes.source_list:[]).map((e=>({title:e})))}}class yt{constructor(e,t){this.hassService=e,this.config=t}async join(e,t){await this.hassService.callMediaService("join",{entity_id:e,group_members:t})}async unJoin(e){await this.hassService.callMediaService("unjoin",{entity_id:e})}async setVolumeAndMediaForPredefinedGroup(e){var t;for(const A of e.entities){const i=null!==(t=A.volume)&&void 0!==t?t:e.volume;i&&await this.volumeSetSinglePlayer(A.player,i),e.unmuteWhenGrouped&&await this.setVolumeMute(A.player,!1,!1)}e.media&&await this.setSource(e.entities[0].player,e.media)}async volumeDown(e,t=!0){await this.volumeStep(e,t,this.getStepDownVolume,"volume_down")}async volumeUp(e,t=!0){await this.volumeStep(e,t,this.getStepUpVolume,"volume_up")}async volumeStep(e,t,A,i){this.config.volumeStepSize?await this.volumeWithStepSize(e,t,this.config.volumeStepSize,A):await this.volumeDefaultStep(e,t,i)}async volumeWithStepSize(e,t,A,i){for(const s of e.members)if(e.id===s.id||t){const e=i(s,A);await this.volumeSetSinglePlayer(s,e)}}getStepDownVolume(e,t){return Math.max(0,e.getVolume()-t)}getStepUpVolume(e,t){return Math.min(100,e.getVolume()+t)}async volumeDefaultStep(e,t,A){for(const i of e.members)(e.id===i.id||t)&&(i.ignoreVolume||await this.hassService.callMediaService(A,{entity_id:i.id}))}async volumeSet(e,t,A){return A?await this.volumeSetGroup(e,t):await this.volumeSetSinglePlayer(e,t)}async volumeSetGroup(e,t){let A;this.config.adjustVolumeRelativeToMainPlayer&&(A=t/e.getVolume()),await Promise.all(e.members.map((e=>{let i=t;return void 0!==A&&this.config.adjustVolumeRelativeToMainPlayer&&(i=e.getVolume()*A,i=Math.min(100,Math.max(0,i))),this.volumeSetSinglePlayer(e,i)})))}async volumeSetSinglePlayer(e,t){if(!e.ignoreVolume){const A=t/100;await this.hassService.callMediaService("volume_set",{entity_id:e.id,volume_level:A})}}async toggleMute(e,t=!0){const A=!e.isMuted(t);await this.setVolumeMute(e,A,t)}async setVolumeMute(e,t,A=!0){for(const i of e.members)(e.id===i.id||A)&&await this.hassService.callMediaService("volume_mute",{entity_id:i.id,is_volume_muted:t})}async setSource(e,t){await this.hassService.callMediaService("select_source",{source:t,entity_id:e.id})}async playMedia(e,t){await this.hassService.callMediaService("play_media",{entity_id:e.id,media_content_id:t.media_content_id,media_content_type:t.media_content_type})}async seek(e,t){await this.hassService.callMediaService("media_seek",{entity_id:e.id,seek_position:t})}}class bt{constructor(e,t,A){var i;this.id=e.entity_id,this.config=t,this.name=this.getEntityName(e,t),this.state=e.state,this.attributes=e.attributes,this.members=A?this.createGroupMembers(e,A):[this],this.volumePlayer=this.determineVolumePlayer(),this.ignoreVolume=!!(null===(i=this.config.entitiesToIgnoreVolumeLevelFor)||void 0===i?void 0:i.includes(this.volumePlayer.id))}getMember(e){return this.members.find((t=>t.id===e))}hasMember(e){return void 0!==this.getMember(e)}isPlaying(){return"playing"===this.state}isMuted(e){return this.attributes.is_volume_muted&&(!e||this.members.every((e=>e.isMuted(!1))))}getCurrentTrack(){return`${this.attributes.media_artist||""} - ${this.attributes.media_title||""}`.replace(/^ - | - $/g,"")}getEntityName(e,t){const A=e.attributes.friendly_name||"";return t.entityNameRegexToReplace?A.replace(new RegExp(t.entityNameRegexToReplace,"g"),t.entityNameReplacement||""):A}createGroupMembers(e,t){return st(e).reduce(((e,A)=>{const i=t.find((e=>e.entity_id===A));return i?[...e,new bt(i,this.config)]:e}),[])}determineVolumePlayer(){let e;return this.members.length>1&&this.config.entitiesToIgnoreVolumeLevelFor&&(e=this.members.find((e=>{var t;return!(null===(t=this.config.entitiesToIgnoreVolumeLevelFor)||void 0===t?void 0:t.includes(e.id))}))),null!=e?e:this}getVolume(){let e;return e=this.members.length>1&&this.config.adjustVolumeRelativeToMainPlayer?this.getAverageVolume():100*this.volumePlayer.attributes.volume_level,Math.round(e)}getAverageVolume(){const e=this.members.filter((e=>{var t;return!(null===(t=this.config.entitiesToIgnoreVolumeLevelFor)||void 0===t?void 0:t.includes(e.id))})).map((e=>e.attributes.volume_level));return 100*e.reduce(((e,t)=>e+t),0)/e.length}}const{TURN_OFF:It,TURN_ON:wt}=he;class Pt{constructor(e,t,A,i,s){this.hass=e,this.config=t;const o=this.getMediaPlayerHassEntities(this.hass);this.allGroups=this.createPlayerGroups(o),this.allMediaPlayers=this.allGroups.reduce(((e,t)=>[...e,...t.members]),[]).sort(((e,t)=>e.name.localeCompare(t.name))),this.activePlayer=this.determineActivePlayer(s),this.hassService=new Bt(this.hass,A,i,t),this.mediaControlService=new yt(this.hassService,t),this.mediaBrowseService=new Ct(this.hassService,t),this.predefinedGroups=this.createPredefinedGroups()}createPredefinedGroups(){const e=[];if(this.config.predefinedGroups)for(const t of this.config.predefinedGroups){const A=this.createPredefinedGroup(t);A&&e.push(A)}return e}createPredefinedGroup(e){let t;const A=[];let i=e.entities;e.excludeItemsInEntitiesList&&(i=this.convertExclusionsInPredefinedGroupsToInclusions(i));for(const e of i){const t=this.createPredefinedGroupPlayer(e);t&&A.push(t)}return A.length&&(t=Object.assign(Object.assign({},e),{entities:A})),t}convertExclusionsInPredefinedGroupsToInclusions(e){return this.allMediaPlayers.filter((t=>!e.find((e=>("string"==typeof e?e:e.player)===t.id)))).map((e=>e.id))}createPredefinedGroupPlayer(e){var t;let A,i,s;if("string"==typeof e?A=e:(i=e.volume,A=e.player),"unavailable"!==(null===(t=this.hass.states[A])||void 0===t?void 0:t.state)){const e=this.allMediaPlayers.find((e=>e.id===A));e&&(s={player:e,volume:i})}else console.warn(`Player ${A} is unavailable`);return s}getMediaPlayerHassEntities(e){const t=e;return Object.values(e.states).filter((e=>!!e.entity_id.includes("media_player")&&(ot(this.config)?function(e,t,A){var i,s;const o=[...new Set(e.entities)];let r=!0;if(o.length){const A=o.includes(t.entity_id);r=!!e.excludeItemsInEntitiesList!==A}let n=!0;e.entityPlatform&&(n=(null===(s=null===(i=A.entities)||void 0===i?void 0:i[t.entity_id])||void 0===s?void 0:s.platform)===e.entityPlatform);return r&&n}(this.config,e,t):function(e,t,A){var i,s;const o=[...new Set(e.entities)];if(e.entityPlatform)return(null===(s=null===(i=A.entities)||void 0===i?void 0:i[t.entity_id])||void 0===s?void 0:s.platform)===e.entityPlatform;if(o.length){const A=o.includes(t.entity_id);return!!e.excludeItemsInEntitiesList!==A}return!1}(this.config,e,t)))).sort(((e,t)=>e.entity_id.localeCompare(t.entity_id)))}createPlayerGroups(e){return e.filter((t=>this.isMainPlayer(t,e))).map((t=>this.createPlayerGroup(t,e))).filter((e=>void 0!==e))}isMainPlayer(e,t){var A;try{const i=st(e).filter((e=>t.some((t=>t.entity_id===e)))),s=(null==i?void 0:i.length)>1,o=s&&i&&i[0]===e.entity_id,r="unavailable"!==(null===(A=this.hass.states[e.entity_id])||void 0===A?void 0:A.state);return r||console.warn(`Player ${e.entity_id} is unavailable`),(!s||o)&&r}catch(t){return console.error("Failed to determine main player",JSON.stringify(e),t),!1}}createPlayerGroup(e,t){try{return new bt(e,this.config,t)}catch(t){return void console.error("Failed to create group",JSON.stringify(e),t)}}determineActivePlayer(e){const t=e||this.config.entityId||this.getActivePlayerFromUrl();return this.allGroups.find((e=>void 0!==e.getMember(t)))||this.allGroups.find((e=>e.isPlaying()))||this.allGroups[0]}getActivePlayerFromUrl(){return window.location.href.includes("#")?window.location.href.replace(/.*#/g,""):""}showPower(e=!1){return this.config.hidePlayerControlPowerButton?[]:((this.activePlayer.attributes.supported_features||0)&Ke)!=Ke||e&&"off"!==this.activePlayer.state?[]:[wt,It]}}const{GROUPING:St,GROUPS:Lt,MEDIA_BROWSER:Vt,PLAYER:Ot,VOLUMES:Mt}=de;class kt extends se{render(){return j` + this.dispatchSection(Ot)} + selected=${this.selected(Ot)} + > + this.dispatchSection(Vt)} + selected=${this.selected(Vt)} + > + this.dispatchSection(Lt)} + selected=${this.selected(Lt)} + > + this.dispatchSection(St)} + selected=${this.selected(St)} + > + this.dispatchSection(Mt)} + selected=${this.selected(Mt)} + > + `}dispatchSection(e){this.dispatchEvent(tt("show-section",e))}selected(e){return this.section===e||W}hide(e){var t;return this.config.sections&&!(null===(t=this.config.sections)||void 0===t?void 0:t.includes(e))||W}static get styles(){return r` + :host { + display: flex; + justify-content: space-between; + } + :host > * { + padding: 1rem; + } + :host > *[selected] { + color: var(--accent-color); + } + :host > *[hide] { + display: none; + } + `}}var Ht,xt;e([ae({attribute:!1})],kt.prototype,"config",void 0),e([ae()],kt.prototype,"section",void 0),customElements.define("sonos-footer",kt),function(e){e.language="language",e.system="system",e.comma_decimal="comma_decimal",e.decimal_comma="decimal_comma",e.space_comma="space_comma",e.none="none"}(Ht||(Ht={})),function(e){e.language="language",e.system="system",e.am_pm="12",e.twenty_four="24"}(xt||(xt={}));var zt;class Nt extends se{setConfig(e){this.config=JSON.parse(JSON.stringify(e))}static get styles(){return r` + ha-svg-icon { + margin: 5px; + } + ha-control-button { + white-space: nowrap; + } + ha-control-button-group { + margin: 5px; + } + div { + margin-top: 20px; + } + `}configChanged(){!function(e,t,A,i){i=i||{},A=null==A?{}:A;var s=new Event(t,{bubbles:void 0===i.bubbles||i.bubbles,cancelable:Boolean(i.cancelable),composed:void 0===i.composed||i.composed});s.detail=A,e.dispatchEvent(s)}(this,"config-changed",{config:this.config}),this.requestUpdate()}dispatchClose(){return this.dispatchEvent(new CustomEvent("closed"))}}e([ae({attribute:!1})],Nt.prototype,"config",void 0),e([ae({attribute:!1})],Nt.prototype,"hass",void 0),function(e){e.GENERAL="General",e.ENTITIES="Entities",e.ADVANCED="Advanced",e.ARTWORK="Artwork"}(zt||(zt={}));const Tt=[{name:"entityPlatform",help:"Show all media players for the selected platform",type:"string"},{name:"hideGroupCurrentTrack",selector:{boolean:{}}},{name:"dynamicVolumeSlider",selector:{boolean:{}}},{name:"dynamicVolumeSliderThreshold",type:"integer",default:20,required:!0,valueMin:1,valueMax:100},{name:"dynamicVolumeSliderMax",type:"integer",default:30,required:!0,valueMin:1,valueMax:100},{name:"artworkMinHeight",type:"integer",help:"Minimum height of the artwork in rem",default:5,required:!0,valueMin:0},{name:"hideBrowseMediaButton",selector:{boolean:{}}},{name:"labelWhenNoMediaIsSelected",type:"string"},{name:"labelForTheAllVolumesSlider",type:"string"},{name:"mediaBrowserTitle",type:"string"},{name:"artworkHostname",type:"string"},{name:"mediaBrowserHideTitleForThumbnailIcons",selector:{boolean:{}}},{name:"topFavorites",type:"string"},{name:"numberOfFavoritesToShow",type:"integer",valueMin:1},{name:"showAudioInputFormat",selector:{boolean:{}}},{name:"adjustVolumeRelativeToMainPlayer",selector:{boolean:{}}},{name:"skipApplyButtonWhenGrouping",selector:{boolean:{}}},{name:"hideVolumeCogwheel",selector:{boolean:{}}},{name:"artworkAsBackground",selector:{boolean:{}}},{name:"playerVolumeEntityId",selector:{entity:{multiple:!1,filter:{domain:"media_player"}}}},{name:"dontSwitchPlayerWhenGrouping",selector:{boolean:{}}},{name:"showSourceInPlayer",selector:{boolean:{}}},{name:"showChannelInPlayer",selector:{boolean:{}}},{name:"hidePlaylistInPlayer",selector:{boolean:{}}},{name:"fallbackArtwork",type:"string",help:"Override default fallback artwork image if artwork is missing for the currently selected media"},{name:"entitiesToIgnoreVolumeLevelFor",help:"If you want to ignore volume level for certain players in the player section",selector:{entity:{multiple:!0,filter:{domain:"media_player"}}}},{name:"replaceHttpWithHttpsForThumbnails",selector:{boolean:{}}},{name:"volumeStepSize",type:"integer",valueMin:1},{name:"showBrowseMediaInPlayerSection",selector:{boolean:{}}}];customElements.define("sonos-card-advanced-editor",class extends Nt{render(){var e;const t=null!==(e=this.config.topFavorites)&&void 0!==e?e:[],A=Object.assign(Object.assign({},this.config),{topFavorites:t.join(", ")});return j` + +
+ The following needs to be configured using code (YAML): +
    +
  • customSources
  • +
  • customThumbnail
  • +
  • customThumbnailIfMissing
  • +
  • favoritesToIgnore
  • +
  • groupingButtonIcons
  • +
+
+ `}changed(e){const t=e.detail.value;this.config=Object.assign(Object.assign(Object.assign({},this.config),t),{topFavorites:t.topFavorites.split(/ *, */)}),this.configChanged()}});class Ut extends Nt{render(){return j``}}e([ae({type:Number})],Ut.prototype,"index",void 0),customElements.define("sonos-card-custom-source-editor",Ut);const Xt=[{type:"multi_select",options:{player:"Player","media browser":"Media Browser",groups:"Groups",grouping:"Grouping",volumes:"Volumes"},name:"sections"},{type:"integer",name:"mediaBrowserItemsPerRow",default:4,required:!0,valueMin:1,valueMax:30},{type:"string",name:"title"},{name:"showVolumeUpAndDownButtons",selector:{boolean:{}}},{name:"showFastForwardAndRewindButtons",selector:{boolean:{}}},{name:"fastForwardAndRewindStepSizeSeconds",type:"integer",default:15,required:!0},{name:"hidePlayerControlPowerButton",selector:{boolean:{}}},{name:"hidePlayerControlShuffleButton",selector:{boolean:{}}},{name:"hidePlayerControlPrevTrackButton",selector:{boolean:{}}},{name:"hidePlayerControlNextTrackButton",selector:{boolean:{}}},{name:"hidePlayerControlRepeatButton",selector:{boolean:{}}},{type:"integer",name:"widthPercentage",default:100,required:!0},{type:"integer",name:"heightPercentage",default:100,required:!0}];customElements.define("sonos-card-general-editor",class extends Nt{render(){return j` + + `}});const Rt=[{type:"string",name:"entityNameRegexToReplace"},{type:"string",name:"entityNameReplacement"},{type:"boolean",name:"excludeItemsInEntitiesList"}],jt=[{name:"entityId",help:"Not needed, but forces this player to be the selected one on loading the card (overrides url param etc)",selector:{entity:{multiple:!1,filter:{domain:"media_player"}}}},{name:"entities",help:"Required, unless you have specified entity platform",cardType:"maxi",selector:{entity:{multiple:!0,filter:{domain:"media_player"}}}},{name:"entities",help:"Not needed, unless you don't want to include all of them",cardType:"sonos",selector:{entity:{multiple:!0,filter:{domain:"media_player"}}}},{name:"showNonSonosPlayers",help:"Show all media players, including those that are not on the Sonos platform",cardType:"sonos",selector:{boolean:{}}}];class Gt extends Nt{constructor(){super(...arguments),this.entitiesSchema=jt}render(){const e=this.config.predefinedGroups;return this.entitiesSchema=jt.filter((e=>void 0===e.cardType||this.config.type.indexOf(e.cardType)>-1)),this.editGroup>-1?j`this.editGroup=-1} + >`:j` + +
+ Predefined Groups + + ${null==e?void 0:e.map(((e,t)=>j` + this.editGroup=t}> + ${e.name} + + `))} + this.editGroup=e?e.length:0}> + Add group + + +
+ +
+ Entity Renaming + +
+ `}}e([le()],Gt.prototype,"editGroup",void 0),customElements.define("sonos-card-entities-editor",Gt);class Wt extends Nt{constructor(){super(...arguments),this.schema=[{type:"string",name:"name",required:!0},{type:"string",name:"media"},{type:"boolean",name:"excludeItemsInEntitiesList"},{name:"entities",selector:{entity:{multiple:!0,filter:{domain:"media_player"}}}}]}render(){return this.predefinedGroup||this.initPredefinedGroup(),j` +

Add/Edit Predefined Group

+ this.groupChanged(e)} + > +
+

Volumes - will be set when players are grouped

+ ${this.predefinedGroup.entities.map((({player:e,volume:t})=>{var A,i;const s=[{type:"integer",name:"volume",label:`${null!==(i=null===(A=this.hass.states[e])||void 0===A?void 0:A.attributes.friendly_name)&&void 0!==i?i:""}${void 0!==t?`: ${t}`:""}`,valueMin:0,valueMax:100}];return j` + this.showVolumes=t.detail} - > + .hass=${this.hass} + .changed=${t=>this.volumeChanged(t,e)} + > + `}))} +
+ + + OK + + + Delete + + + `}initPredefinedGroup(){var e;const t=null===(e=this.config.predefinedGroups)||void 0===e?void 0:e[this.index||0];if(t){const e=t.entities.map((e=>"string"==typeof e?{player:e}:e));this.predefinedGroup=Object.assign(Object.assign({},t),{entities:e})}else this.predefinedGroup={name:"",media:"",entities:[]}}getPredefinedGroupWithoutVolumes(){return Object.assign(Object.assign({},this.predefinedGroup),{entities:this.predefinedGroup.entities.map((e=>e.player))})}groupChanged(e){const t=e.detail.value,A=t.entities.map((e=>{const t=this.predefinedGroup.entities.find((({player:t})=>t===e));return null!=t?t:{player:e}}));this.predefinedGroup=Object.assign(Object.assign({},t),{entities:A})}volumeChanged(e,t){const A=e.detail.value.volume,i=this.predefinedGroup.entities.map((e=>e.player===t?Object.assign(Object.assign({},e),{volume:A}):e));this.predefinedGroup=Object.assign(Object.assign({},this.predefinedGroup),{entities:i})}savePredefinedGroup(){let e=this.config.predefinedGroups;Array.isArray(e)||(e=[]),e[this.index]?e[this.index]=this.predefinedGroup:e=[...e,this.predefinedGroup],this.config.predefinedGroups=e,this.configChanged(),this.dispatchClose()}deletePredefinedGroup(){var e;this.config.predefinedGroups=null===(e=this.config.predefinedGroups)||void 0===e?void 0:e.filter(((e,t)=>t!==this.index)),this.index=-1,this.configChanged(),this.dispatchClose()}}e([ae({type:Number})],Wt.prototype,"index",void 0),e([le()],Wt.prototype,"predefinedGroup",void 0),customElements.define("sonos-card-predefined-group-editor",Wt);class Dt extends Nt{render(){const e=this.config.mediaArtworkOverrides;return this.editItem>-1?j`this.editItem=-1} + >`:j` +
+ Artwork Overrides + + ${null==e?void 0:e.map(((e,t)=>{const A=e.mediaTitleEquals||e.mediaArtistEquals||e.mediaAlbumNameEquals||e.mediaContentIdEquals||e.mediaChannelEquals||e.ifMissing&&"if missing"||t;return j` + this.editItem=t}> + ${A} + + `}))} + this.editItem=e?e.length:0}> + Add + +
+ `}}e([le()],Dt.prototype,"editItem",void 0),customElements.define("sonos-card-artwork-overrides-editor",Dt);const qt={ifMissing:!1};class Zt extends Nt{render(){var e;const t=null===(e=this.config.mediaArtworkOverrides)||void 0===e?void 0:e[this.index||0];return j` + Add/Edit Artwork Override + this.changed(e,this.index)} + > + + + OK + + ${t?j` + Delete + `:""} + + `}changed(e,t){const A=e.detail.value;let i=this.config.mediaArtworkOverrides;Array.isArray(i)||(i=[]),i[t]?i[t]=A:i=[...i,A],this.config.mediaArtworkOverrides=i,this.configChanged()}}e([ae({type:Number})],Zt.prototype,"index",void 0),customElements.define("sonos-card-artwork-override-editor",Zt);class Jt extends Nt{render(){return j` + + `}valueChanged(e){const t=e.detail.value;this.config=Object.assign(Object.assign({},this.config),t),this.configChanged()}}function Yt({help:e,label:t,name:A}){if(t)return t;let i=A.replace(/([A-Z])/g," $1");return i=i.charAt(0).toUpperCase()+i.slice(1),i+(e?` (${e})`:"")}e([ae({attribute:!1})],Jt.prototype,"schema",void 0),e([ae({attribute:!1})],Jt.prototype,"data",void 0),e([ae()],Jt.prototype,"changed",void 0),customElements.define("sonos-card-editor-form",Jt);const{GENERAL:Ft,ENTITIES:Kt,ADVANCED:$t,ARTWORK:_t}=zt;class eA extends Nt{constructor(){super(...arguments),this.configArea=Ft}render(){return this.config.sections&&0!==this.config.sections.length||(this.config.sections=[de.PLAYER,de.VOLUMES,de.GROUPS,de.GROUPING,de.MEDIA_BROWSER]),j` + + ${[Ft,Kt,_t,$t].map((e=>j` + this.configArea=e} + > + ${e} + + `))} + + + ${this.subEditor()} + `}subEditor(){return Et(this.configArea,[[Ft,()=>j``],[Kt,()=>j``],[$t,()=>j``],[_t,()=>j``]])}static get styles(){return r` + ha-control-button[selected] { + --control-button-background-color: var(--primary-color); + } + `}} +/** + * @license + * Copyright 2021 Google LLC + * SPDX-License-Identifier: BSD-3-Clause + */ +function tA(e,t,A){return e?t(e):A?.(e)}e([le()],eA.prototype,"configArea",void 0),customElements.define("sonos-card-editor",eA);const{GROUPING:AA,GROUPS:iA,MEDIA_BROWSER:sA,PLAYER:oA,VOLUMES:rA}=de;class nA extends se{constructor(){super(...arguments),this.showSectionListener=e=>{const t=e.detail;(!this.config.sections||this.config.sections.indexOf(t)>-1)&&(this.section=t)},this.callMediaStartedListener=e=>{this.showLoader||this.config.sections&&e.detail.section!==this.section||(this.cancelLoader=!1,setTimeout((()=>{this.cancelLoader||(this.showLoader=!0,this.loaderTimestamp=Date.now())}),300))},this.callMediaDoneListener=()=>{this.cancelLoader=!0;const e=Date.now()-this.loaderTimestamp;this.showLoader&&(e<1e3?setTimeout((()=>this.showLoader=!1),1e3-e):this.showLoader=!1)},this.activePlayerListener=e=>{var t;const A=e.detail.entityId;A!==this.activePlayerId&&(this.activePlayerId=A,(null===(t=this.config.sections)||void 0===t?void 0:t.includes(oA))&&(this.section=oA),this.requestUpdate())},this.onMediaItemSelected=()=>{var e;(null===(e=this.config.sections)||void 0===e?void 0:e.includes(oA))&&setTimeout((()=>this.section=oA),1e3)}}render(){this.createStore();let e=it(this.config.heightPercentage);const t=this.config.sections,A=!t||t.length>1,i=A?e-5:e,s=this.config.title;return e=s?e+2:e,j` + +
+
- `;return $t(t,this.config)}return ft}containerStyle(t){const e=(this.config.artworkHostname||"")+t.attributes.entity_picture,i=t.attributes.media_title,s=t.attributes.media_content_id;let o={backgroundPosition:"center",backgroundRepeat:"no-repeat",backgroundSize:"cover",backgroundImage:e?`url(${e})`:""};const n=this.config.mediaArtworkOverrides;if(n){let t=n.find((t=>i===t.mediaTitleEquals||s===t.mediaContentIdEquals));t||(t=n.find((t=>!e&&t.ifMissing))),t&&(o=Object.assign(Object.assign({},o),{backgroundImage:t.imageUrl?`url(${t.imageUrl})`:o.backgroundImage,backgroundSize:t.sizePercentage?`${t.sizePercentage}%`:o.backgroundSize}))}return yt("player-container",this.config,Object.assign({marginTop:"1rem",position:"relative",background:"var(--sonos-int-background-color)",borderRadius:"var(--sonos-int-border-radius)",paddingBottom:"100%",border:"var(--sonos-int-border-width) solid var(--sonos-int-color)"},o))}bodyStyle(){return yt("player-body",this.config,{position:"absolute",inset:"0px",display:"flex",flexDirection:"column",justifyContent:this.showVolumes?"flex-end":"space-between"})}static get styles(){return[n` - .hoverable:focus, - .hoverable:hover { - color: var(--sonos-int-accent-color); - } - `,St]}}t([tt({attribute:!1})],qt.prototype,"hass",void 0),t([tt()],qt.prototype,"config",void 0),t([et()],qt.prototype,"entityId",void 0),t([et()],qt.prototype,"showVolumes",void 0);const Kt={margin:"0.5rem 0",textAlign:"center",fontWeight:"bold",fontSize:"larger",color:"var(--sonos-int-title-color)"};class Qt extends J{render(){return this.config.singleSectionMode?this.renderDeprecatedSingleSectionMode():j` - -
${this.config.name}
-
-
- -
+ ${s?j`
${s}
`:j``} +
+ ${this.activePlayerId?Et(this.section,[[oA,()=>j` `],[iA,()=>j` `],[AA,()=>j``],[sA,()=>j` + + `],[rA,()=>j` `]]):j`
No supported players found
`} +
+ ${tA(A,(()=>j` + `))} + + `}createStore(){var e;this.activePlayerId?this.store=new Pt(this.hass,this.config,this.section,this,this.activePlayerId):(this.store=new Pt(this.hass,this.config,this.section,this),this.activePlayerId=null===(e=this.store.activePlayer)||void 0===e?void 0:e.id)}getCardSize(){return 3}static getConfigElement(){return document.createElement("sonos-card-editor")}connectedCallback(){super.connectedCallback(),et(this.config)&&window.addEventListener(De,this.activePlayerListener),window.addEventListener(qe,this.callMediaStartedListener),window.addEventListener(Ze,this.callMediaDoneListener)}disconnectedCallback(){window.removeEventListener(De,this.activePlayerListener),super.disconnectedCallback()}haCardStyle(e){const t=it(this.config.widthPercentage);return lt({color:"var(--secondary-text-color)",height:`${e}rem`,minWidth:"20rem",maxWidth:`${t}rem`,overflow:"hidden"})}footerStyle(){return lt({height:"5rem",paddingBottom:"1rem"})}contentStyle(e){return lt({overflowY:"auto",height:`${e}rem`})}setConfig(e){var t;const A=JSON.parse(JSON.stringify(e));for(const[e,t]of Object.entries(A))Array.isArray(t)&&0===t.length&&delete A[e];const i=A.sections;this.section=i?i.includes(oA)?oA:i.includes(sA)?sA:i.includes(iA)?iA:i.includes(AA)?AA:rA:oA,A.mediaBrowserItemsPerRow=A.mediaBrowserItemsPerRow||4,(null===(t=A.entities)||void 0===t?void 0:t.length)&&A.entities[0].entity&&(A.entities=A.entities.map((e=>e.entity))),ot(A)&&(A.entityPlatform="sonos",A.showNonSonosPlayers&&(A.entityPlatform=void 0)),this.config=A}static get styles(){return r` + :host { + --mdc-icon-button-size: 3rem; + --mdc-icon-size: 2rem; + } + ha-circular-progress { + --md-sys-color-primary: var(--accent-color); + } + .loader { + position: absolute; + z-index: 1000; + top: 50%; + left: 50%; + transform: translate(-50%, -50%); + --mdc-theme-primary: var(--accent-color); + } + .title { + margin: 0.4rem 0; + text-align: center; + font-weight: bold; + font-size: 1.2rem; + color: var(--secondary-text-color); + } + .no-players { + text-align: center; + margin-top: 50%; + } + `}}e([ae({attribute:!1})],nA.prototype,"hass",void 0),e([ae({attribute:!1})],nA.prototype,"config",void 0),e([le()],nA.prototype,"section",void 0),e([le()],nA.prototype,"store",void 0),e([le()],nA.prototype,"showLoader",void 0),e([le()],nA.prototype,"loaderTimestamp",void 0),e([le()],nA.prototype,"cancelLoader",void 0),e([le()],nA.prototype,"activePlayerId",void 0);class aA extends se{render(){const e=!!this.icon&&!!this.name||W;return j` + + ${this.icon?j` `:""} + ${this.name?j`${this.name}`:""} + + `}static get styles(){return r` + ha-control-button { + width: fit-content; + --control-button-background-color: var(--accent-color); + --control-button-icon-color: var(--secondary-text-color); + } + ha-control-button[selected] { + --control-button-icon-color: var(--accent-color); + } -
- - -
+ ha-icon { + padding-left: 1rem; + padding-right: 1rem; + } + ha-icon[icon-and-name] { + padding-right: 0; + } -
- -
+ span { + padding-right: 1rem; + padding-left: 1rem; + font-weight: bold; + } + `}}e([ae()],aA.prototype,"icon",void 0),e([ae()],aA.prototype,"name",void 0),e([ae()],aA.prototype,"selected",void 0),customElements.define("sonos-grouping-button",aA);class lA{constructor(e,t,A){this.isDisabled=!1,this.isMain=e.id===t.id,this.isModified=A;const i=this.isMain||t.hasMember(e.id);this.isSelected=A?!i:i,this.player=e,this.name=e.name,this.icon=this.isSelected?"check-circle":"checkbox-blank-circle-outline"}}class cA extends se{constructor(){super(...arguments),this.modifiedItems=[]}render(){return this.config=this.store.config,this.activePlayer=this.store.activePlayer,this.mediaControlService=this.store.mediaControlService,this.mediaPlayerIds=this.store.allMediaPlayers.map((e=>e.id)),this.groupingItems=this.getGroupingItems(),this.notJoinedPlayers=this.getNotJoinedPlayers(),this.joinedPlayers=this.getJoinedPlayers(),this.config.skipApplyButtonWhenGrouping&&(this.modifiedItems.length>0||this.selectedPredefinedGroup)&&this.applyGrouping(),j` +
+
+ ${this.renderJoinAllButton()} ${this.renderUnJoinAllButton()} + ${tA(this.store.predefinedGroups,(()=>this.renderPredefinedGroups()))}
- - `}renderDeprecatedSingleSectionMode(){switch(this.config.singleSectionMode){case st.GROUPING:return j` `;case st.GROUPS:return j` `;case st.MEDIA_BROWSER:return j` `;case st.PLAYER:default:return j` `}}setConfig(t){const e=JSON.parse(JSON.stringify(t));e.showAllSections=!e.singleSectionMode,wt(e),this.config=e}titleStyle(){return yt("title",this.config,Object.assign({display:this.config.name?"block":"none"},Kt))}groupsStyle(){var t;return this.columnStyle(null===(t=this.config.layout)||void 0===t?void 0:t.groups,"1","25%","groups",{padding:"0 1rem",boxSizing:"border-box"})}playersStyle(){var t;return this.columnStyle(null===(t=this.config.layout)||void 0===t?void 0:t.players,"0","40%","players")}mediaBrowserStyle(){var t;return this.columnStyle(null===(t=this.config.layout)||void 0===t?void 0:t.mediaBrowser,"2","25%","media-browser",{padding:"0 1rem",boxSizing:"border-box"})}columnStyle(t,e,i,s,o){const n=mt(this.config,i,"100%",t);let r=Object.assign({width:n,maxWidth:n},o);return vt(this.config)&&(r=Object.assign(Object.assign({},r),{order:e,padding:"0.5rem",margin:"0",boxSizing:"border-box"})),yt(s,this.config,r)}contentStyle(){return yt("content",this.config,{display:"flex",flexWrap:"wrap",justifyContent:"center"})}static get styles(){return St}}t([tt({attribute:!1})],Qt.prototype,"hass",void 0),t([tt()],Qt.prototype,"config",void 0);class Zt extends J{constructor(){super(...arguments),this.entityIdListener=t=>{this.entityId=t.detail.entityId}}connectedCallback(){super.connectedCallback(),bt(this.entityIdListener)}disconnectedCallback(){At(this.entityIdListener),super.disconnectedCallback()}setConfig(t){const e=JSON.parse(JSON.stringify(t));wt(e),this.config=e}render(){if(!this.entityId&&this.config.entityId&&(this.entityId=this.config.entityId),this.entityId&&this.hass){this.hassService=new Pt(this.hass),this.mediaControlService=new Ot(this.hass,this.hassService),this.mediaPlayers=ht(this.config,this.hass),this.groups=ut(this.mediaPlayers,this.hass,this.config);const t=this.mediaPlayers.filter((t=>t!==this.entityId&&this.groups[this.entityId].members[t])),e=this.mediaPlayers.filter((t=>t!==this.entityId&&!this.groups[this.entityId].members[t]));return $t(j` -
-
- ${this.config.groupingTitle?this.config.groupingTitle:"Grouping"} -
-
- ${this.entityId&&this.mediaPlayers.map((e=>this.renderMediaPlayerGroupButton(e,t)))} - ${Yt(e.length,(()=>this.getButton((async()=>await this.mediaControlService.join(this.entityId,e)),"mdi:checkbox-multiple-marked-outline")))} - ${Yt(t.length,(()=>this.getButton((async()=>await this.mediaControlService.unjoin(t)),"mdi:minus-box-multiple-outline")))} - ${Yt(this.config.predefinedGroups&&this.config.predefinedGroupsNoSeparateSection,(()=>this.renderPredefinedGroups()))} -
- ${Yt(this.config.predefinedGroups&&!this.config.predefinedGroupsNoSeparateSection,(()=>j`
- ${this.config.predefinedGroupsTitle?this.config.predefinedGroupsTitle:"Predefined groups"} +
+ ${this.groupingItems.map((e=>j` +
+ this.toggleItem(e)} + > +
+ ${e.name} +
-
${this.renderPredefinedGroups()}
`))} +
+ `))}
- `,this.config)}return ft}renderMediaPlayerGroupButton(t,e){const i=ct(this.hass,this.config,t);return this.groups[this.entityId].members[t]||t===this.entityId&&e.length>0?this.getButton((async()=>await this.mediaControlService.unjoin([t])),"mdi:minus",i):t!==this.entityId?this.getButton((async()=>await this.mediaControlService.join(this.entityId,[t])),"mdi:plus",i):j``}renderPredefinedGroups(){var t;return j` - ${null===(t=this.config.predefinedGroups)||void 0===t?void 0:t.filter((t=>t.entities.length>1)).map((t=>this.getButton((async()=>await this.mediaControlService.createGroup(t.entities,this.groups)),this.config.predefinedGroupsNoSeparateSection?"mdi:speaker-multiple":"",t.name,this.config.predefinedGroupsNoSeparateSection?{fontStyle:"italic"}:{})))} - `}getButton(t,e,i,s){return j` -
- ${i?j`${i}`:""} - + + Apply + Cancel +
- `}membersStyle(){return yt("members",this.config,{padding:"0",margin:"0",display:"flex",flexDirection:"row",flexWrap:"wrap",justifyContent:"space-between"})}memberStyle(t){return yt("member",this.config,Object.assign({flexGrow:"1",borderRadius:"var(--sonos-int-border-radius)",margin:"0 0.25rem 0.5rem",padding:"0.45rem",display:"flex",justifyContent:"center",border:"var(--sonos-int-border-width) solid var(--sonos-int-color)",backgroundColor:"var(--sonos-int-background-color)",maxWidth:"calc(100% - 1.4rem)"},t))}nameStyle(){return yt("member-name",this.config,{alignSelf:"center",fontSize:"1rem",overflow:"hidden",textOverflow:"ellipsis"})}iconStyle(){return yt("member-icon",this.config,{alignSelf:"center",fontSize:"0.5rem",paddingLeft:"0.1rem"})}static get styles(){return[n` - .hoverable:hover, - .hoverable:focus { - color: var(--sonos-int-accent-color); - border: var(--sonos-int-border-width) solid var(--sonos-int-accent-color); + `}static get styles(){return[Ye,r` + :host { + --mdc-icon-size: 24px; } - `,St]}}t([tt({attribute:!1})],Zt.prototype,"hass",void 0),t([tt()],Zt.prototype,"config",void 0),t([tt()],Zt.prototype,"entityId",void 0);class Jt extends J{constructor(){super(...arguments),this.selected=!1,this.entityIdListener=t=>{var e;this.selected=t.detail.entityId===(null===(e=this.group)||void 0===e?void 0:e.entity)},this.dispatchEntityIdEvent=()=>{if(this.selected){const t=new CustomEvent("sonos-card-active-player",{bubbles:!0,composed:!0,detail:{entityId:this.group.entity}});window.dispatchEvent(t)}}}connectedCallback(){var t;super.connectedCallback(),bt(this.entityIdListener),t=this.dispatchEntityIdEvent,window.addEventListener("sonos-card-request-player",t)}disconnectedCallback(){var t;At(this.entityIdListener),t=this.dispatchEntityIdEvent,window.removeEventListener("sonos-card-request-player",t),super.disconnectedCallback()}render(){const t=It(this.hass.states[this.group.entity]),e=[this.group.roomName,...Object.values(this.group.members)].join(" + ");return this.dispatchEntityIdEvent(),j` -
-
    - ${e} -
-
- ${t?j`
${t}
- ${Yt(Ct(this.group.state),(()=>j` -
-
-
-
-
- `))}`:""} + .wrapper { + display: flex; + flex-direction: column; + height: 100%; + } + + .predefined-groups { + margin: 1rem; + display: flex; + flex-wrap: wrap; + gap: 1rem; + justify-content: center; + flex-shrink: 0; + } + + .item { + color: var(--secondary-text-color); + padding: 0.5rem; + display: flex; + align-items: center; + } + + .icon { + padding-right: 0.5rem; + flex-shrink: 0; + } + + .icon[selected] { + color: var(--accent-color); + } + + .item[modified] .name { + font-weight: bold; + font-style: italic; + } + + .item[disabled] .icon { + color: var(--disabled-text-color); + } + + .list { + flex: 1; + overflow: auto; + } + + .buttons { + flex-shrink: 0; + margin: 0 1rem; + padding-top: 0.5rem; + } + + .apply { + --control-button-background-color: var(--accent-color); + } + + *[hide] { + display: none; + } + + .name-and-volume { + display: flex; + flex-direction: column; + flex: 1; + } + + .volume { + --accent-color: var(--secondary-text-color); + } + `]}toggleItem(e){e.isDisabled||this.toggleItemWithoutDisabledCheck(e)}toggleItemWithoutDisabledCheck(e){this.modifiedItems.includes(e.player.id)?this.modifiedItems=this.modifiedItems.filter((t=>t!==e.player.id)):this.modifiedItems=[...this.modifiedItems,e.player.id],this.selectedPredefinedGroup=void 0}async applyGrouping(){const e=this.groupingItems,t=this.joinedPlayers,A=this.activePlayer.id,{unJoin:i,join:s,newMainPlayer:o}=function(e,t,A){const i=e.filter((e=>e.isSelected)),s=e.filter((e=>!e.isSelected&&t.includes(e.player.id))).map((e=>e.player.id)),o=e.filter((e=>e.isSelected&&!t.includes(e.player.id))).map((e=>e.player.id));let r=A;return s.includes(A)&&(r=i[0].player.id),{unJoin:s,join:o,newMainPlayer:r}}(e,t,A);s.length>0&&await this.mediaControlService.join(o,s),i.length>0&&await this.mediaControlService.unJoin(i),this.selectedPredefinedGroup&&(console.log("Setting volume and media for predefined group",this.selectedPredefinedGroup.volume),await this.mediaControlService.setVolumeAndMediaForPredefinedGroup(this.selectedPredefinedGroup)),o===A||this.config.dontSwitchPlayerWhenGrouping||_e(o,this.config,this),this.config.entityId&&i.includes(this.config.entityId)&&this.config.dontSwitchPlayerWhenGrouping&&_e(this.config.entityId,this.config,this),this.modifiedItems=[],this.selectedPredefinedGroup=void 0}cancelGrouping(){this.modifiedItems=[]}getGroupingItems(){const e=this.store.allMediaPlayers.map((e=>new lA(e,this.activePlayer,this.modifiedItems.includes(e.id)))),t=e.filter((e=>e.isSelected));return 1===t.length&&(t[0].isDisabled=!0),e.sort(((e,t)=>e.isMain&&!t.isMain||e.isSelected&&!t.isSelected?-1:e.name.localeCompare(t.name))),e}renderJoinAllButton(){var e,t;const A=null!==(t=null===(e=this.config.groupingButtonIcons)||void 0===e?void 0:e.joinAll)&&void 0!==t?t:"mdi:checkbox-multiple-marked-outline";return tA(this.notJoinedPlayers.length,(()=>this.groupingButton(A,this.selectAll)))}groupingButton(e,t){return j` `}getNotJoinedPlayers(){return this.mediaPlayerIds.filter((e=>e!==this.activePlayer.id&&!this.activePlayer.hasMember(e)))}renderUnJoinAllButton(){var e,t;const A=null!==(t=null===(e=this.config.groupingButtonIcons)||void 0===e?void 0:e.unJoinAll)&&void 0!==t?t:"mdi:minus-box-multiple-outline";return tA(this.joinedPlayers.length,(()=>this.groupingButton(A,this.deSelectAll)))}getJoinedPlayers(){return this.mediaPlayerIds.filter((e=>e===this.activePlayer.id||this.activePlayer.hasMember(e)))}renderPredefinedGroups(){return this.store.predefinedGroups.map((e=>{var t,A,i;return j` + this.selectPredefinedGroup(e)} + .icon=${null!==(A=null===(t=this.config.groupingButtonIcons)||void 0===t?void 0:t.predefinedGroup)&&void 0!==A?A:"mdi:speaker-multiple"} + .name=${e.name} + .selected=${(null===(i=this.selectedPredefinedGroup)||void 0===i?void 0:i.name)===e.name} + > + `}))}selectPredefinedGroup(e){this.groupingItems.forEach((async t=>{const A=e.entities.some((e=>e.player.id===t.player.id));(A&&!t.isSelected||!A&&t.isSelected)&&this.toggleItemWithoutDisabledCheck(t)})),this.selectedPredefinedGroup=e}selectAll(){this.groupingItems.forEach((e=>{e.isSelected||this.toggleItem(e)}))}deSelectAll(){this.groupingItems.forEach((e=>{(!e.isMain&&e.isSelected||e.isMain&&!e.isSelected)&&this.toggleItem(e)}))}}e([ae({attribute:!1})],cA.prototype,"store",void 0),e([le()],cA.prototype,"modifiedItems",void 0),e([le()],cA.prototype,"selectedPredefinedGroup",void 0);class dA extends se{constructor(){super(...arguments),this.selected=!1,this.dispatchEntityIdEvent=()=>{if(this.selected){_e(this.player.id,this.store.config,this)}}}render(){const e=this.store.config.hideGroupCurrentTrack?"":this.player.getCurrentTrack(),t=$e(this.player,this.store.predefinedGroups),A=this.player.members.map((e=>e.attributes.icon)).filter((e=>e));return j` + this.handleGroupClicked()} + > +
+ ${this.renderIcons(A)} +
+ ${t} + ${e} +
-
- `}groupStyle(){const t=Object.assign({borderRadius:"var(--sonos-int-border-radius)",margin:"0.5rem 0",padding:"0.8rem",border:"var(--sonos-int-border-width) solid var(--sonos-int-color)",backgroundColor:"var(--sonos-int-background-color)"},this.selected&&{border:"var(--sonos-int-border-width) solid var(--sonos-int-accent-color)",color:"var(--sonos-int-accent-color)",fontWeight:"bold"});return yt("group",this.config,t)}speakersStyle(){return yt("group-speakers",this.config,{margin:"0",padding:"0"})}speakerStyle(){return yt("group-speaker",this.config,{marginRight:"0.3rem",fontSize:"1rem",maxWidth:"100%",overflow:"hidden",textOverflow:"ellipsis"})}infoStyle(){return yt("group-info",this.config,{display:"flex",flexDirection:"row",clear:"both"})}currentTrackStyle(){return lt({display:this.config.hideGroupCurrentTrack?"none":"inline",fontSize:"0.8rem"})}static barStyle(t){return lt({background:"var(--sonos-int-color)",bottom:"0.05rem",height:"0.15rem",position:"absolute",width:"0.15rem",animation:"sound 0ms -800ms linear infinite alternate",display:"block",left:1==t?"0.05rem":2==t?"0.25rem":"0.45rem",animationDuration:1==t?"474ms":2==t?"433ms":"407ms"})}handleGroupClicked(){if(!this.selected){this.selected=!0;const t=window.location.href.replace(/#.*/g,"");window.location.replace(`${t}#${this.group.entity}`),this.dispatchEntityIdEvent()}}static get styles(){return n` + + ${tA(this.player.isPlaying(),(()=>j` +
+
+
+
+
+ `))} + + `}renderIcons(e){const t=e.length;if(1===t)return j``;const A=e.slice(0,4);return j`
+ ${A.map(((e,A)=>A<3||4===t?j` `:j`+${t-3}`))} +
`}connectedCallback(){super.connectedCallback(),this.dispatchEntityIdEvent()}handleGroupClicked(){if(!this.selected){this.selected=!0;const e=window.location.href.replace(/#.*/g,"");window.location.replace(`${e}#${this.player.id}`),this.dispatchEntityIdEvent()}}static get styles(){return r` @keyframes sound { 0% { opacity: 0.35; @@ -297,86 +825,295 @@ function Yt(t,e,i){return t?e():null==i?void 0:i()}t([tt()],Ht.prototype,"hass", height: 1rem; } } - `}}t([tt()],Jt.prototype,"hass",void 0),t([tt()],Jt.prototype,"config",void 0),t([tt()],Jt.prototype,"group",void 0),t([tt()],Jt.prototype,"selected",void 0),customElements.define("sonos-group",Jt);class Ft extends J{setConfig(t){const e=JSON.parse(JSON.stringify(t));wt(e),this.config=e}render(){if(this.hass){const t=ht(this.config,this.hass);this.groups=ut(t,this.hass,this.config),this.determineEntityId(this.groups);return $t(j` -
-
- ${this.config.groupsTitle?this.config.groupsTitle:"Groups"} -
- ${Object.values(this.groups).map((t=>j` - - `))} -
- `,this.config)}return ft}determineEntityId(t){if(!this.entityId){const e=this.config.entityId||(window.location.href.indexOf("#")>0?window.location.href.replace(/.*#/g,""):"");for(const i in t)if(i===e)this.entityId=i;else for(const s in t[i].members)s===e&&(this.entityId=i);if(!this.entityId)for(const e in t)Ct(t[e].state)&&(this.entityId=e);this.entityId||(this.entityId=Object.keys(t)[0])}}static get styles(){return St}}t([tt({attribute:!1})],Ft.prototype,"hass",void 0),t([tt()],Ft.prototype,"config",void 0);class Xt extends J{getThumbnail(){var t,e;let i=this.mediaItem.thumbnail;return i?(null==i?void 0:i.match(/https:\/\/brands.home-assistant.io\/.+\/logo.png/))&&(i=null==i?void 0:i.replace("logo.png","icon.png")):(i=(null===(t=this.config.customThumbnailIfMissing)||void 0===t?void 0:t[this.mediaItem.title])||"",this.itemsWithImage&&!i&&(i=(null===(e=this.config.customThumbnailIfMissing)||void 0===e?void 0:e.fallback)||"")),i}mediaButtonStyle(){return{boxSizing:"border-box","-moz-box-sizing":"border-box","-webkit-box-sizing":"border-box",overflow:"hidden",border:"var(--sonos-int-border-width) solid var(--sonos-int-color)",display:"flex",borderRadius:"var(--sonos-int-border-radius)",backgroundColor:"var(--sonos-int-background-color)"}}wrapperStyle(){return yt("media-button-wrapper",this.config,{padding:"0 0.1rem 0.3rem 0.1rem"})}static get styles(){return n` - .hoverable:focus, - .hoverable:hover { - border-color: var(--sonos-int-accent-color); - color: var(--sonos-int-accent-color); - } - `}}t([tt()],Xt.prototype,"mediaItem",void 0),t([tt()],Xt.prototype,"config",void 0),t([tt()],Xt.prototype,"itemsWithImage",void 0);customElements.define("sonos-media-list-item",class extends Xt{constructor(){super(...arguments),this.iconStyle={position:"relative",flexShrink:"0",width:"30px",height:"30px"}}render(){const t=this.getThumbnail();return j` -
-
-
- -
${this.mediaItem.title}
-
+ + mwc-list-item { + height: fit-content; + margin: 1rem; + border-radius: 1rem; + background: var(--secondary-background-color); + padding-left: 0; + } + + .row { + display: flex; + margin: 1rem 0; + align-items: center; + } + + .text { + display: flex; + flex-direction: column; + justify-content: center; + } + + .speakers { + white-space: initial; + font-size: 1.1rem; + font-weight: bold; + color: var(--secondary-text-color); + } + + .song-title { + font-size: 0.9rem; + font-weight: bold; + } + + .icons { + text-wrap: wrap; + text-align: center; + margin: 0; + min-width: 5rem; + max-width: 5rem; + } + + ha-icon { + --mdc-icon-size: 3rem; + margin: 1rem; + } + + ha-icon.small { + --mdc-icon-size: 2rem; + margin: 0; + } + + .bars { + width: 0.55rem; + position: relative; + margin-left: 1rem; + } + + .bars > div { + background: var(--secondary-text-color); + bottom: 0.05rem; + height: 0.15rem; + position: absolute; + width: 0.15rem; + animation: sound 0ms -800ms linear infinite alternate; + display: block; + } + + .bars > div:first-child { + left: 0.05rem; + animation-duration: 474ms; + } + + .bars > div:nth-child(2) { + left: 0.25rem; + animation-duration: 433ms; + } + + .bars > div:last-child { + left: 0.45rem; + animation-duration: 407ms; + } + `}}e([ae({attribute:!1})],dA.prototype,"store",void 0),e([ae({attribute:!1})],dA.prototype,"player",void 0),e([ae({type:Boolean})],dA.prototype,"selected",void 0),customElements.define("sonos-group",dA);class hA extends se{render(){return this.activePlayer=this.store.activePlayer,this.groups=this.store.allGroups,j` + + ${this.groups.map((e=>{const t=this.activePlayer.id===e.id;return j` `}))} + + `}static get styles(){return Ye}}e([ae({attribute:!1})],hA.prototype,"store",void 0);class gA extends se{render(){return this.config=this.store.config,j` + + ${vt(this.items,this.config).map((e=>j` + this.dispatchEvent(tt(Je,e))}> +
${ft(e)}
+
+ `))} +
+ `}static get styles(){return[r` + .button { + --icon-width: 35px; + height: 40px; + } + + .row { + display: flex; + } + + .thumbnail { + width: var(--icon-width); + height: var(--icon-width); + background-size: contain; + background-repeat: no-repeat; + background-position: left; + } + + .title { + font-size: 1.1rem; + align-self: center; + flex: 1; + } + `,Fe,Ye]}}e([ae({attribute:!1})],gA.prototype,"store",void 0),e([ae({type:Array})],gA.prototype,"items",void 0),customElements.define("sonos-media-browser-list",gA);class EA extends se{render(){return this.config=this.store.config,j` +
+ ${vt(this.items,this.config).map((e=>j` + this.dispatchEvent(tt(Je,e))} + > + ${ft(e,!e.thumbnail||!this.config.mediaBrowserHideTitleForThumbnailIcons)} + + `))}
- `}listItemStyle(){return yt("media-button",this.config,Object.assign(Object.assign({},this.mediaButtonStyle()),{flexDirection:"row",justifyContent:"left",alignItems:"center",height:"30px"}))}thumbnailStyle(t){return yt("media-button-thumb",this.config,Object.assign(Object.assign(Object.assign({},this.iconStyle),{backgroundSize:"30px",backgroundRepeat:"no-repeat",backgroundPosition:"left",backgroundImage:"url("+t+")"}),!t&&{display:"none"}))}folderStyle(t){return yt("media-button-folder",this.config,Object.assign(Object.assign(Object.assign({},this.iconStyle),{"--mdc-icon-size":"90%"}),(!this.mediaItem.can_expand||t)&&{display:"none"}))}titleStyle(t){return yt("media-button-title",this.config,Object.assign({fontSize:"0.9rem",padding:"0px 0.5rem",textOverflow:"ellipsis",overflow:"hidden",whiteSpace:"nowrap",flex:"1"},(t||this.mediaItem.can_expand)&&{zIndex:"1"}))}});class te extends Xt{render(){const t=this.getThumbnail();return j` -
-
-
${this.mediaItem.title}
- -
+ `}buttonStyle(e){const t=`calc(100% / ${e} - 1% * 2)`;return lt({width:t,height:t,margin:"1%"})}static get styles(){return[Fe,r` + .icons { + display: flex; + flex-wrap: wrap; + } + + .thumbnail { + width: 100%; + padding-bottom: 100%; + margin: 0 6%; + background-size: 100%; + background-repeat: no-repeat; + background-position: center; + } + + .title { + font-size: 0.8rem; + position: absolute; + width: 100%; + line-height: 160%; + bottom: 0; + background-color: rgba(var(--rgb-card-background-color), 0.733); + } + `]}}e([ae({attribute:!1})],EA.prototype,"store",void 0),e([ae({attribute:!1})],EA.prototype,"items",void 0),customElements.define("sonos-media-browser-icons",EA);class BA extends se{render(){var e;return j` +
${null!==(e=this.store.config.mediaBrowserTitle)&&void 0!==e?e:"All Favorites"}
+ + `}static get styles(){return r` + :host { + display: flex; + justify-content: space-between; + padding: 0.5rem; + } + .title { + flex: 1; + text-align: center; + font-size: 1.2rem; + font-weight: bold; + display: flex; + align-items: center; + justify-content: center; + padding: 0.5rem; + } + *[hide] { + display: none; + } + `}}e([ae({attribute:!1})],BA.prototype,"store",void 0),customElements.define("sonos-media-browser-header",BA);class uA extends se{constructor(){super(...arguments),this.onMediaItemSelected=e=>{const t=e.detail;this.playItem(t),this.dispatchEvent(tt(Je,t))}}render(){return this.config=this.store.config,this.activePlayer=this.store.activePlayer,this.mediaBrowseService=this.store.mediaBrowseService,this.mediaControlService=this.store.mediaControlService,j` + + + ${this.activePlayer&&He(this.getFavorites(this.activePlayer).then((e=>{if(null==e?void 0:e.length){return(this.config.mediaBrowserItemsPerRow||4)>1?j` + + `:j` + + `}return j`
No favorites found
`})))} + `}async playItem(e){e.media_content_type||e.media_content_id?await this.mediaControlService.playMedia(this.activePlayer,e):await this.mediaControlService.setSource(this.activePlayer,e.title)}async getFavorites(e){var t,A,i,s;let o=await this.mediaBrowseService.getFavorites(e);return o.sort(((e,t)=>this.sortOnTopFavoritesThenAlphabetically(e.title,t.title))),o=[...(null===(A=null===(t=this.config.customSources)||void 0===t?void 0:t[this.activePlayer.id])||void 0===A?void 0:A.map(uA.createSource))||[],...(null===(s=null===(i=this.config.customSources)||void 0===i?void 0:i.all)||void 0===s?void 0:s.map(uA.createSource))||[],...o],this.config.numberOfFavoritesToShow?o.slice(0,this.config.numberOfFavoritesToShow):o}sortOnTopFavoritesThenAlphabetically(e,t){var A;const i=null!==(A=this.config.topFavorites)&&void 0!==A?A:[],s=mt(i,e),o=mt(i,t);if(s>-1&&o>-1)return s-o;{let A=o-s;return 0===A&&(A=e.localeCompare(t,"en",{sensitivity:"base"})),A}}static createSource(e){return Object.assign(Object.assign({},e),{can_play:!0})}static get styles(){return r` + .no-items { + text-align: center; + margin-top: 50%; + } + `}}e([ae({attribute:!1})],uA.prototype,"store",void 0);const{SELECT_SOURCE:QA}=he;class pA extends se{constructor(){super(...arguments),this.showSwitches={}}render(){this.config=this.store.config,this.activePlayer=this.store.activePlayer,this.hassService=this.store.hassService,this.mediaControlService=this.store.mediaControlService;const e=this.activePlayer.members;return j` + ${tA(e.length>1,(()=>this.volumeWithName(this.activePlayer)))} + ${e.map((e=>this.volumeWithName(e,!1)))} + `}volumeWithName(e,t=!0){var A;const i=t?null!==(A=this.config.labelForTheAllVolumesSlider)&&void 0!==A?A:"All":e.name,s=!!this.config.showVolumeUpAndDownButtons&&W,o=t||!this.showSwitches[e.id];return j`
+
+
${i}
- `}iconItemStyle(t){return yt("media-button",this.config,Object.assign(Object.assign(Object.assign(Object.assign({},this.mediaButtonStyle()),{flexDirection:"column",borderRadius:"var(--sonos-int-border-radius)",justifyContent:"center",backgroundColor:"var(--sonos-int-background-color)"}),(t||this.mediaItem.can_expand)&&{backgroundSize:"contain",backgroundRepeat:"no-repeat",backgroundPosition:"center",position:"relative",paddingBottom:"calc(100% - (var(--sonos-int-border-width) * 2))"}),t&&{backgroundImage:"url("+t+")"}))}titleStyle(t){return yt("media-button-title",this.config,Object.assign({width:"calc(100% - 1rem)",fontSize:"1rem",padding:"0px 0.5rem"},(t||this.mediaItem.can_expand)&&{zIndex:"1",textOverflow:"ellipsis",overflow:"hidden",whiteSpace:"var(--sonos-int-media-button-white-space)",backgroundColor:"var(--sonos-int-player-section-background)",position:"absolute",top:"0rem",left:"0rem"}))}folderStyle(t){return yt("media-button-folder",this.config,Object.assign({marginBottom:"-120%","--mdc-icon-size":"70%"},(!this.mediaItem.can_expand||t)&&{display:"none"}))}}t([tt()],te.prototype,"mediaItem",void 0),t([tt()],te.prototype,"config",void 0),customElements.define("sonos-media-icon-item",te);class ee extends J{constructor(){super(...arguments),this.headerChildStyle={flex:"1","--mdc-icon-size":"1.5rem"}}render(){var t;return j` -
-
- ${(null===(t=this.currentDir)||void 0===t?void 0:t.can_play)?j` `:""} -
-
${this.config.mediaTitle?this.config.mediaTitle:"Media"}
-
- -
+
+ await this.mediaControlService.volumeDown(e,t)} + .path=${Qe} + > + + await this.mediaControlService.volumeUp(e,t)} + .path=${pe} + > + this.toggleShowSwitches(e)} + .path=${"M12,15.5A3.5,3.5 0 0,1 8.5,12A3.5,3.5 0 0,1 12,8.5A3.5,3.5 0 0,1 15.5,12A3.5,3.5 0 0,1 12,15.5M19.43,12.97C19.47,12.65 19.5,12.33 19.5,12C19.5,11.67 19.47,11.34 19.43,11L21.54,9.37C21.73,9.22 21.78,8.95 21.66,8.73L19.66,5.27C19.54,5.05 19.27,4.96 19.05,5.05L16.56,6.05C16.04,5.66 15.5,5.32 14.87,5.07L14.5,2.42C14.46,2.18 14.25,2 14,2H10C9.75,2 9.54,2.18 9.5,2.42L9.13,5.07C8.5,5.32 7.96,5.66 7.44,6.05L4.95,5.05C4.73,4.96 4.46,5.05 4.34,5.27L2.34,8.73C2.21,8.95 2.27,9.22 2.46,9.37L4.57,11C4.53,11.34 4.5,11.67 4.5,12C4.5,12.33 4.53,12.65 4.57,12.97L2.46,14.63C2.27,14.78 2.21,15.05 2.34,15.27L4.34,18.73C4.46,18.95 4.73,19.03 4.95,18.95L7.44,17.94C7.96,18.34 8.5,18.68 9.13,18.93L9.5,21.58C9.54,21.82 9.75,22 10,22H14C14.25,22 14.46,21.82 14.5,21.58L14.87,18.93C15.5,18.67 16.04,18.34 16.56,17.94L19.05,18.95C19.27,19.03 19.54,18.95 19.66,18.73L21.66,15.27C21.78,15.05 21.73,14.78 21.54,14.63L19.43,12.97Z"} + show-switches=${this.showSwitches[e.id]||W} + >
- `}headerStyle(){return yt("media-browser-header",this.config,Object.assign({display:"flex",justifyContent:"space-between"},Kt))}titleStyle(){return yt("title",this.config,this.headerChildStyle)}playDirStyle(){return yt("media-browser-play-dir",this.config,Object.assign({textAlign:"left",paddingRight:"-0.5rem",marginLeft:"0.5rem"},this.headerChildStyle))}browseStyle(){return yt("media-browse",this.config,Object.assign({textAlign:"right",paddingRight:"0.5rem",marginLeft:"-0.5rem"},this.headerChildStyle))}static get styles(){return n` - .hoverable:focus, - .hoverable:hover { - color: var(--sonos-int-accent-color); - } - `}}function ie(t=[],e){return null==e?void 0:e.filter((e=>-1===["media-source://tts","media-source://camera"].indexOf(e.media_content_id||"")&&-1===t.indexOf(e.title)))}t([tt()],ee.prototype,"hass",void 0),t([tt()],ee.prototype,"config",void 0),t([tt()],ee.prototype,"mediaBrowser",void 0),t([tt()],ee.prototype,"browse",void 0),t([tt()],ee.prototype,"currentDir",void 0),customElements.define("sonos-media-browser-header",ee);class se{constructor(t,e){this.hass=t,this.hassService=e}async getRoot(t,e){return ie(e,(await this.hassService.browseMedia(t)).children)||[]}async getDir(t,e,i){try{return ie(i,(await this.hassService.browseMedia(t,e.media_content_type,e.media_content_id)).children)||[]}catch(t){return console.error(t),[]}}async getAllFavorites(t,e){if(!t.length)return[];let i=(await Promise.all(t.map((t=>this.getFavoritesForPlayer(t,e))))).flatMap((t=>t));return i=this.removeDuplicates(i),i.length?i:this.getFavoritesFromStates(t)}removeDuplicates(t){return t.filter(((t,e,i)=>e===i.findIndex((e=>e.title===t.title))))}async getFavoritesForPlayer(t,e){var i;const s=null===(i=(await this.hassService.browseMedia(t,"favorites","")).children)||void 0===i?void 0:i.map((e=>this.hassService.browseMedia(t,e.media_content_type,e.media_content_id)));return(s?await Promise.all(s):[]).flatMap((t=>ie(e,t.children)||[]))}getFavoritesFromStates(t){console.log("Custom Sonos Card: found no favorites with thumbnails, trying with titles only");let e=t.map((t=>this.hass.states[t])).flatMap((t=>t.attributes.source_list));return e=[...new Set(e)],e.length||console.log("Custom Sonos Card: No favorites found"),e.map((t=>({title:t})))}}class oe extends J{constructor(){super(...arguments),this.mediaItems=[],this.parentDirs=[],this.entityIdListener=t=>{this.entityId=t.detail.entityId}}connectedCallback(){super.connectedCallback(),bt(this.entityIdListener)}disconnectedCallback(){At(this.entityIdListener),super.disconnectedCallback()}setConfig(t){const e=JSON.parse(JSON.stringify(t));wt(e),this.config=e}render(){if(!this.entityId&&this.config.entityId&&(this.entityId=this.config.entityId),this.entityId&&this.hass){this.hassService=new Pt(this.hass),this.mediaBrowseService=new se(this.hass,this.hassService),this.mediaControlService=new Ot(this.hass,this.hassService),this.mediaPlayers=ht(this.config,this.hass);const t=localStorage.getItem("custom-sonos-card_currentDir");t&&(this.currentDir=JSON.parse(t),this.browse=!0);return $t(j` -
- - ${""!==this.entityId&&Gt((this.browse?this.loadMediaDir(this.currentDir):this.getAllFavorites()).then((t=>{const e=oe.hasItemsWithImage(t),i=oe.hasFolderItems(t),s=this.getMediaItemWidth(e,i);return j`
- ${t.map((t=>{const i=async()=>await this.onMediaItemClick(t),o=`width: ${s};max-width: ${s};`;return this.config.mediaBrowserItemsAsList?j` - - `:j` - - `}))} -
`})))} +
+ + + ${He(this.getAdditionalControls(o,e))} +
+
`}toggleShowSwitches(e){this.showSwitches[e.id]=!this.showSwitches[e.id],this.requestUpdate()}async getAdditionalControls(e,t){if(e)return;return(await this.hassService.getRelatedEntities(t,"switch","number","sensor")).map((e=>{var A,i,s;return e.attributes.friendly_name=null!==(s=null===(i=null===(A=e.attributes.friendly_name)||void 0===A?void 0:A.replaceAll(t.name,""))||void 0===i?void 0:i.trim())&&void 0!==s?s:"",j` +
+
- `,this.config)}return ft}getMediaItemWidth(t,e){var i,s;return t||e?this.config.mediaBrowserItemsAsList?mt(this.config,"100%","100%",null===(i=this.config.layout)||void 0===i?void 0:i.mediaItem):mt(this.config,"33%","16%",null===(s=this.config.layout)||void 0===s?void 0:s.mediaItem):"100%"}browseClicked(){this.parentDirs.length?this.setCurrentDir(this.parentDirs.pop()):this.currentDir?this.setCurrentDir(void 0):this.browse=!this.browse}setCurrentDir(t){this.currentDir=t,t?localStorage.setItem("custom-sonos-card_currentDir",JSON.stringify(t)):localStorage.removeItem("custom-sonos-card_currentDir")}async onMediaItemClick(t){t.can_expand?(this.currentDir&&this.parentDirs.push(this.currentDir),this.setCurrentDir(t)):t.can_play&&await this.playItem(t)}async playItem(t){t.media_content_type||t.media_content_id?await this.mediaControlService.playMedia(this.entityId,t):await this.mediaControlService.setSource(this.entityId,t.title)}async getAllFavorites(){var t,e,i,s;let o=await this.mediaBrowseService.getAllFavorites(this.mediaPlayers,this.config.mediaBrowserTitlesToIgnore);return this.config.shuffleFavorites?oe.shuffleArray(o):o=o.sort(((t,e)=>t.title.localeCompare(e.title,"en",{sensitivity:"base"}))),[...(null===(e=null===(t=this.config.customSources)||void 0===t?void 0:t[this.entityId])||void 0===e?void 0:e.map(oe.createSource))||[],...(null===(s=null===(i=this.config.customSources)||void 0===i?void 0:i.all)||void 0===s?void 0:s.map(oe.createSource))||[],...o]}static createSource(t){return Object.assign(Object.assign({},t),{can_play:!0})}static shuffleArray(t){for(let e=t.length-1;e>0;e--){const i=Math.floor(Math.random()*(e+1));[t[e],t[i]]=[t[i],t[e]]}}static hasItemsWithImage(t){return t.some((t=>t.thumbnail))}static hasFolderItems(t){return t.some((t=>t.can_expand))}async loadMediaDir(t){return await(t?this.mediaBrowseService.getDir(this.entityId,t,this.config.mediaBrowserTitlesToIgnore):this.mediaBrowseService.getRoot(this.entityId,this.config.mediaBrowserTitlesToIgnore))}mediaButtonsStyle(t,e){return yt("media-buttons",this.config,Object.assign({padding:"0",display:"flex",flexWrap:"wrap"},!t&&!e&&{flexDirection:"column"}))}static get styles(){return St}}t([tt({attribute:!1})],oe.prototype,"hass",void 0),t([tt()],oe.prototype,"config",void 0),t([et()],oe.prototype,"browse",void 0),t([et()],oe.prototype,"currentDir",void 0),t([et()],oe.prototype,"mediaItems",void 0),t([et()],oe.prototype,"entityId",void 0);const ne=t=>"Sonos"+(t?` (${t})`:""),re=t=>"Media player for your Sonos speakers"+(t?` (${t})`:"");window.customCards.push({type:"sonos-card",name:ne(),description:re(),preview:!0},{type:"sonos-grouping",name:ne("Grouping section"),description:re("Grouping section"),preview:!0},{type:"sonos-groups",name:ne("Groups section"),description:re("Groups section"),preview:!0},{type:"sonos-media-browser",name:ne("Media Browser section"),description:re("Media Browser section"),preview:!0},{type:"sonos-player",name:ne("Player section"),description:"Media player for your Sonos speakers (Player section)",preview:!0}),customElements.define("custom-sonos-card",class extends Qt{setConfig(t){console.error("type: custom:custom-sonos-card is deprecated, please use custom:sonos-card instead"),super.setConfig(t)}}),customElements.define("sonos-card",Qt),customElements.define("sonos-grouping",Zt),customElements.define("sonos-groups",Ft),customElements.define("sonos-media-browser",oe),customElements.define("sonos-player",qt); + `}))}static get styles(){return r` + .row { + display: flex; + flex-direction: column; + padding-top: 0.3rem; + padding-right: 1rem; + padding-bottom: 0.2rem; + } + + .row:not(:first-child) { + border-top: solid var(--secondary-background-color); + } + + .row:first-child { + padding-top: 1rem; + } + + .switches { + display: flex; + justify-content: center; + flex-direction: column; + gap: 1rem; + } + + .volume-name { + flex: 1; + overflow: hidden; + flex-direction: column; + text-align: center; + } + + .volume-name-text { + flex: 1; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + font-size: 1.1rem; + font-weight: bold; + min-height: 1rem; + } + + .slider-row { + display: flex; + } + + sonos-volume { + flex: 4; + } + + *[show-switches] { + color: var(--accent-color); + } + + *[hide] { + display: none; + } + `}}e([ae({attribute:!1})],pA.prototype,"store",void 0),e([le()],pA.prototype,"showSwitches",void 0),customElements.define("sonos-volumes",pA);class mA extends se{render(){const e=this.store.hass.states[this.store.activePlayer.id];let t=0;this.features.forEach((e=>t+=e));const A=Object.assign(Object.assign({},e),{attributes:Object.assign(Object.assign({},e.attributes),{supported_features:t})});return j` `}}e([ae({attribute:!1})],mA.prototype,"store",void 0),e([ae({attribute:!1})],mA.prototype,"features",void 0),customElements.define("sonos-ha-player",mA),window.customCards.push({type:"sonos-card",name:"Sonos",description:"Media player for your Sonos speakers",preview:!0}),customElements.define("sonos-card",nA),customElements.define("sonos-grouping",cA),customElements.define("sonos-groups",hA),customElements.define("sonos-media-browser",uA),customElements.define("sonos-player",gt); +//# sourceMappingURL=custom-sonos-card.js.map