From 842090ae1cf44a54f67280748500fef312ffa726 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Thomas=20Lov=C3=A9n?= Date: Mon, 17 May 2021 20:00:16 +0000 Subject: [PATCH] Make fullcolor icons work better in safari too --- custom_components/fontawesome/main.js | 2 +- custom_components/fontawesome/manifest.json | 2 +- js/main.js | 12 ++++++++---- 3 files changed, 10 insertions(+), 6 deletions(-) diff --git a/custom_components/fontawesome/main.js b/custom_components/fontawesome/main.js index 22785cf..42efc7f 100644 --- a/custom_components/fontawesome/main.js +++ b/custom_components/fontawesome/main.js @@ -1 +1 @@ -(()=>{const t={},o={"fa-primary":"primary","fa-secondary":"secondary",primary:"primary",secondary:"secondary"},e=(e,s)=>new Promise((async(n,a)=>{const r=`${e}:${s}`;t[r]&&n(t[r]),t[r]=(async(t,e)=>{const[s,n]=e.split("#"),a=await fetch(`/fontawesome/icons/${t}/${s}.svg`),r=await a.text(),c=(new DOMParser).parseFromString(r,"text/html");if(!c||!c.querySelector("svg"))return{};const i=c.querySelector("svg").getAttribute("viewBox"),l=c.querySelectorAll("path"),d={};let h="";for(const t of l){h+=t.getAttribute("d");const e=t.classList[0];o[e]&&(d[o[e]]=t.getAttribute("d"))}let m=null;const p=c.querySelector("svg");return Array.from(p.attributes).some((t=>t.name.startsWith("on")))||p.getElementsByTagName("script").length||(m=p),{viewBox:i,path:h,paths:d,format:n,fullCode:m}})(e,s),n(t[r])}));window.getIcon=e,"customIconsets"in window||(window.customIconsets={}),window.customIconsets.fab=t=>e("brands",t),window.customIconsets.far=t=>e("regular",t),window.customIconsets.fas=t=>e("solid",t),window.customIconsets.fapro=t=>e("pro",t),window.customIconsets.facustom=t=>e("pro",t),customElements.whenDefined("ha-icon").then((()=>{customElements.get("ha-icon").prototype._setCustomPath=async function(t){const o=await t;this._path=o.path,this._viewBox=o.viewBox,await this.UpdateComplete;const e=this.shadowRoot.querySelector("ha-svg-icon");if(e&&e.setPaths)if(o.fullCode&&"fullcolor"===o.format){await e.updateComplete;const t=e.shadowRoot.querySelector("g");t.firstElementChild&&(t.firstElementChild.style.display="none"),t.appendChild(o.fullCode.cloneNode(!0))}else e.setPaths(o.paths),o.format&&e.classList.add(...o.format.split("-"))}})),customElements.whenDefined("ha-svg-icon").then((()=>{customElements.get("ha-svg-icon").prototype.setPaths=async function(t){if(await this.updateComplete,null==t||0===Object.keys(t).length)return;const o=this.shadowRoot.querySelector("style")||document.createElement("style");o.innerHTML="\n .secondary {\n opacity: 0.4;\n }\n :host(.invert) .secondary {\n opacity: 1;\n }\n :host(.invert) .primary {\n opacity: 0.4;\n }\n :host(.color) .primary {\n opacity: 1;\n }\n :host(.color) .secondary {\n opacity: 1;\n }\n :host(.color:not(.invert)) .secondary {\n fill: var(--icon-secondary-color, var(--disabled-text-color));\n }\n :host(.color.invert) .primary {\n fill: var(--icon-secondary-color, var(--disabled-text-color));\n }\n path:not(.primary):not(.secondary) {\n opacity: 0;\n }\n ",this.shadowRoot.appendChild(o);const e=this.shadowRoot.querySelector("g");for(const o in t){const s=document.createElementNS("http://www.w3.org/2000/svg","path");s.setAttribute("d",t[o]),s.classList.add(o),e.appendChild(s)}}}))})(); \ No newline at end of file +(()=>{const t={},o={"fa-primary":"primary","fa-secondary":"secondary",primary:"primary",secondary:"secondary"},e=(e,n)=>new Promise((async(s,a)=>{const r=`${e}:${n}`;t[r]&&s(t[r]),t[r]=(async(t,e)=>{const[n,s]=e.split("#"),a=await fetch(`/fontawesome/icons/${t}/${n}.svg`),r=await a.text(),c=(new DOMParser).parseFromString(r,"text/html");if(!c||!c.querySelector("svg"))return{};const i=c.querySelector("svg").getAttribute("viewBox"),l=c.querySelectorAll("path"),d={};let h="";for(const t of l){h+=t.getAttribute("d");const e=t.classList[0];o[e]&&(d[o[e]]=t.getAttribute("d"))}let p=null;const m=c.querySelector("svg");return Array.from(m.attributes).some((t=>t.name.startsWith("on")))||m.getElementsByTagName("script").length||(p=m),{viewBox:i,path:h,paths:d,format:s,fullCode:p}})(e,n),s(t[r])}));window.getIcon=e,"customIconsets"in window||(window.customIconsets={}),window.customIconsets.fab=t=>e("brands",t),window.customIconsets.far=t=>e("regular",t),window.customIconsets.fas=t=>e("solid",t),window.customIconsets.fapro=t=>e("pro",t),window.customIconsets.facustom=t=>e("pro",t),customElements.whenDefined("ha-icon").then((()=>{customElements.get("ha-icon").prototype._setCustomPath=async function(t){const o=await t;this._path=o.path,this._viewBox=o.viewBox,await this.UpdateComplete;const e=this.shadowRoot.querySelector("ha-svg-icon");if(e&&e.setPaths)if(o.fullCode&&"fullcolor"===o.format){await e.updateComplete;const t=e.shadowRoot.querySelector("svg"),n=document.createElement("style");n.innerHTML="\n svg:first-child>g:first-of-type>path {\n display: none;\n }\n ",t.appendChild(n),t.appendChild(o.fullCode.cloneNode(!0))}else e.setPaths(o.paths),o.format&&e.classList.add(...o.format.split("-"))}})),customElements.whenDefined("ha-svg-icon").then((()=>{customElements.get("ha-svg-icon").prototype.setPaths=async function(t){if(await this.updateComplete,null==t||0===Object.keys(t).length)return;const o=this.shadowRoot.querySelector("style")||document.createElement("style");o.innerHTML="\n .secondary {\n opacity: 0.4;\n }\n :host(.invert) .secondary {\n opacity: 1;\n }\n :host(.invert) .primary {\n opacity: 0.4;\n }\n :host(.color) .primary {\n opacity: 1;\n }\n :host(.color) .secondary {\n opacity: 1;\n }\n :host(.color:not(.invert)) .secondary {\n fill: var(--icon-secondary-color, var(--disabled-text-color));\n }\n :host(.color.invert) .primary {\n fill: var(--icon-secondary-color, var(--disabled-text-color));\n }\n path:not(.primary):not(.secondary) {\n opacity: 0;\n }\n ",this.shadowRoot.appendChild(o);const e=this.shadowRoot.querySelector("g");for(const o in t){const n=document.createElementNS("http://www.w3.org/2000/svg","path");n.setAttribute("d",t[o]),n.classList.add(o),e.appendChild(n)}}}))})(); \ No newline at end of file diff --git a/custom_components/fontawesome/manifest.json b/custom_components/fontawesome/manifest.json index a77672d..cfffe83 100644 --- a/custom_components/fontawesome/manifest.json +++ b/custom_components/fontawesome/manifest.json @@ -6,6 +6,6 @@ "codeowners": [], "requirements": [], "config_flow": true, - "version": "2.1.1", + "version": "2.1.2", "iot_class": "local_polling" } \ No newline at end of file diff --git a/js/main.js b/js/main.js index cbffd59..09f0776 100644 --- a/js/main.js +++ b/js/main.js @@ -92,10 +92,14 @@ customElements.whenDefined("ha-icon").then(() => { } if (icon.fullCode && icon.format === "fullcolor") { await el.updateComplete; - const root = el.shadowRoot.querySelector("g"); - if (root.firstElementChild) { - root.firstElementChild.style.display = "none"; - } + const root = el.shadowRoot.querySelector("svg"); + const styleEl = document.createElement("style"); + styleEl.innerHTML = ` + svg:first-child>g:first-of-type>path { + display: none; + } + `; + root.appendChild(styleEl); root.appendChild(icon.fullCode.cloneNode(true)); } else { el.setPaths(icon.paths);