@siemens/ix-icons 0.0.0-20240515161342 → 0.0.0-20240729073852
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/cjs/{icon-8d6a19b5.js → icon-ee6021fa.js} +13 -65
- package/dist/cjs/icon-ee6021fa.js.map +1 -0
- package/dist/cjs/{index-af0541e0.js → index-8f585802.js} +3 -1
- package/dist/cjs/index-8f585802.js.map +1 -0
- package/dist/cjs/index.cjs.js +1681 -2
- package/dist/cjs/index.cjs.js.map +1 -1
- package/dist/cjs/ix-icon.cjs.entry.js +2 -2
- package/dist/cjs/ix-icons.cjs.js +1 -1
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/collection/components/icon/icons.js +135 -19
- package/dist/collection/components/icon/icons.js.map +1 -1
- package/dist/collection/components/icon/meta-tag.js +0 -25
- package/dist/collection/components/icon/meta-tag.js.map +1 -1
- package/dist/collection/components/icon/resolveIcon.js +10 -40
- package/dist/collection/components/icon/resolveIcon.js.map +1 -1
- package/dist/collection/components/icon/test/resolveIcon.spec.js +38 -10
- package/dist/collection/components/icon/test/resolveIcon.spec.js.map +1 -1
- package/dist/collection/index.js +2 -0
- package/dist/collection/index.js.map +1 -1
- package/dist/collection/legacy-support.js +45 -0
- package/dist/collection/legacy-support.js.map +1 -0
- package/dist/components/icon.js +9 -64
- package/dist/components/icon.js.map +1 -1
- package/dist/components/index.js +1683 -0
- package/dist/components/index.js.map +1 -1
- package/dist/esm/{icon-9458edad.js → icon-76ecbfbf.js} +11 -66
- package/dist/esm/icon-76ecbfbf.js.map +1 -0
- package/dist/esm/{index-8088fea1.js → index-d1072d3f.js} +3 -2
- package/dist/esm/index-d1072d3f.js.map +1 -0
- package/dist/esm/index.js +1685 -2
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/ix-icon.entry.js +2 -2
- package/dist/esm/ix-icons.js +2 -2
- package/dist/esm/loader.js +2 -2
- package/dist/ix-icons/index.esm.js +1 -1
- package/dist/ix-icons/index.esm.js.map +1 -1
- package/dist/ix-icons/ix-icons.esm.js +1 -1
- package/dist/ix-icons/p-05455ad0.js +3 -0
- package/dist/ix-icons/p-05455ad0.js.map +1 -0
- package/dist/ix-icons/p-20e57a64.entry.js +2 -0
- package/dist/ix-icons/p-31deceec.js +2 -0
- package/dist/ix-icons/p-31deceec.js.map +1 -0
- package/dist/sample.json +116 -0
- package/dist/types/components/icon/icons.d.ts +136 -20
- package/dist/types/components/icon/meta-tag.d.ts +0 -6
- package/dist/types/components/icon/resolveIcon.d.ts +1 -0
- package/dist/types/index.d.ts +2 -0
- package/dist/types/legacy-support.d.ts +1 -0
- package/icons/index.d.ts +116 -0
- package/icons/index.js +135 -19
- package/icons/index.mjs +135 -19
- package/icons/package.json +1 -1
- package/package.json +1 -1
- package/svg/add-filter-filled.svg +1 -0
- package/svg/add-filter.svg +1 -0
- package/svg/add-selection.svg +1 -0
- package/svg/add-shield-half.svg +1 -0
- package/svg/alarm-clock-cancelled.svg +1 -0
- package/svg/alarm-clock-success.svg +1 -0
- package/svg/battery-bolt.svg +1 -0
- package/svg/battery-upright-bolt.svg +1 -0
- package/svg/battery-upright-check.svg +1 -0
- package/svg/battery-upright-empty.svg +1 -0
- package/svg/battery-upright-exclamation.svg +1 -0
- package/svg/battery-upright-full-check.svg +1 -0
- package/svg/battery-upright-full.svg +1 -0
- package/svg/battery-upright-half.svg +1 -0
- package/svg/battery-upright-low.svg +1 -0
- package/svg/battery-upright-quarter.svg +1 -0
- package/svg/battery-upright-question.svg +1 -0
- package/svg/battery-upright-slash.svg +1 -0
- package/svg/battery-upright-three-quarter.svg +1 -0
- package/svg/battery-upright-xmark.svg +1 -0
- package/svg/box-closed.svg +1 -0
- package/svg/box-ipc-fail.svg +1 -0
- package/svg/box-ipc-question.svg +1 -0
- package/svg/box-ipc-success.svg +1 -0
- package/svg/box-ipc.svg +1 -0
- package/svg/box-open.svg +1 -0
- package/svg/bug-filled.svg +1 -0
- package/svg/bug.svg +1 -0
- package/svg/calculator.svg +1 -0
- package/svg/chevron-down-bar-small.svg +1 -0
- package/svg/chevron-down-bar.svg +1 -0
- package/svg/chevron-down.svg +1 -1
- package/svg/chevron-left-bar-small.svg +1 -0
- package/svg/chevron-left-bar.svg +1 -0
- package/svg/chevron-right-bar-small.svg +1 -0
- package/svg/chevron-right-bar.svg +1 -0
- package/svg/chevron-up-bar-small.svg +1 -0
- package/svg/chevron-up-bar.svg +1 -0
- package/svg/clear-filter-filled.svg +1 -1
- package/svg/clear-filter.svg +1 -1
- package/svg/cloud-fail-filled.svg +1 -1
- package/svg/cloud-fail.svg +1 -1
- package/svg/cloud-success-filled.svg +1 -1
- package/svg/cloud-success.svg +1 -1
- package/svg/compare.svg +1 -0
- package/svg/copy-filled.svg +1 -0
- package/svg/counter.svg +1 -0
- package/svg/crosshairs-filled.svg +1 -0
- package/svg/crosshairs.svg +1 -0
- package/svg/customer-filled.svg +1 -0
- package/svg/customer.svg +1 -0
- package/svg/cut-filled.svg +1 -0
- package/svg/device-driver.svg +1 -0
- package/svg/device-fan.svg +1 -0
- package/svg/disk-pen.svg +1 -1
- package/svg/drag-and-drop.svg +1 -0
- package/svg/drag-gripper.svg +1 -0
- package/svg/drop-zone.svg +1 -0
- package/svg/duplicate-filled.svg +1 -0
- package/svg/edit-document-filled.svg +1 -0
- package/svg/edit-document.svg +1 -0
- package/svg/firmware.svg +1 -0
- package/svg/flashing.svg +1 -0
- package/svg/handshake.svg +1 -0
- package/svg/hard-disk-drive.svg +1 -0
- package/svg/heading.svg +1 -0
- package/svg/health-filled.svg +1 -1
- package/svg/health.svg +1 -1
- package/svg/heart-filled.svg +1 -1
- package/svg/heart.svg +1 -1
- package/svg/height.svg +1 -0
- package/svg/hourglass-empty.svg +1 -0
- package/svg/hourglass-end.svg +1 -0
- package/svg/hourglass-filled.svg +1 -0
- package/svg/hourglass-start.svg +1 -0
- package/svg/ipcs.svg +1 -0
- package/svg/join.svg +1 -0
- package/svg/link-break.svg +1 -0
- package/svg/link-diagonal.svg +1 -0
- package/svg/list-sorted-alt.svg +1 -0
- package/svg/list-sorted.svg +1 -0
- package/svg/move.svg +1 -0
- package/svg/operate-plant.svg +1 -1
- package/svg/operating-system.svg +1 -0
- package/svg/panel-ipc-fail.svg +1 -0
- package/svg/panel-ipc-question.svg +1 -0
- package/svg/panel-ipc-success.svg +1 -0
- package/svg/panel-ipc.svg +1 -0
- package/svg/power-supply.svg +1 -0
- package/svg/quote.svg +1 -0
- package/svg/rack-ipc-fail.svg +1 -0
- package/svg/rack-ipc-question.svg +1 -0
- package/svg/rack-ipc-success.svg +1 -0
- package/svg/rack-ipc.svg +1 -0
- package/svg/refresh-exclamation.svg +1 -0
- package/svg/refresh-settings.svg +1 -0
- package/svg/reorder.svg +1 -0
- package/svg/replace.svg +1 -1
- package/svg/runtime-settings.svg +1 -0
- package/svg/sd-card-filled.svg +1 -0
- package/svg/sd-card-micro-filled.svg +1 -0
- package/svg/sd-card-micro.svg +1 -0
- package/svg/sd-card.svg +1 -0
- package/svg/separator-line.svg +1 -0
- package/svg/shield-broken-filled.svg +1 -0
- package/svg/shield-broken.svg +1 -0
- package/svg/shield-check-filled.svg +1 -0
- package/svg/shield-check.svg +1 -0
- package/svg/shield-filled.svg +1 -0
- package/svg/shield-half.svg +1 -0
- package/svg/shield.svg +1 -0
- package/svg/solid-state-drive.svg +1 -0
- package/svg/sort-alt.svg +1 -0
- package/svg/sort.svg +1 -1
- package/svg/split.svg +1 -0
- package/svg/sword-swing.svg +1 -0
- package/svg/text-bold.svg +1 -0
- package/svg/text-italic.svg +1 -0
- package/svg/text-strike-through.svg +1 -0
- package/svg/text-underline.svg +1 -0
- package/svg/thermometer.svg +1 -0
- package/svg/trend-downward-circle.svg +1 -0
- package/svg/trend-sideways-circle.svg +1 -0
- package/svg/trend-upward-circle.svg +1 -0
- package/svg/trophy-filled.svg +1 -0
- package/svg/trophy.svg +1 -0
- package/svg/usb-drive.svg +1 -0
- package/svg/user-check-filled.svg +1 -1
- package/svg/user-check.svg +1 -1
- package/svg/user-fail-filled.svg +1 -1
- package/svg/user-fail.svg +1 -1
- package/svg/user-success-filled.svg +1 -0
- package/svg/user-success.svg +1 -0
- package/svg/width.svg +1 -0
- package/svg/zone.svg +1 -0
- package/dist/cjs/icon-8d6a19b5.js.map +0 -1
- package/dist/cjs/icons-0dd6f96e.js +0 -1405
- package/dist/cjs/icons-0dd6f96e.js.map +0 -1
- package/dist/cjs/index-af0541e0.js.map +0 -1
- package/dist/components/icons.js +0 -705
- package/dist/components/icons.js.map +0 -1
- package/dist/esm/icon-9458edad.js.map +0 -1
- package/dist/esm/icons-84dc9236.js +0 -705
- package/dist/esm/icons-84dc9236.js.map +0 -1
- package/dist/esm/index-8088fea1.js.map +0 -1
- package/dist/ix-icons/p-1dac0290.js +0 -2
- package/dist/ix-icons/p-1dac0290.js.map +0 -1
- package/dist/ix-icons/p-51684ec4.js +0 -2
- package/dist/ix-icons/p-51684ec4.js.map +0 -1
- package/dist/ix-icons/p-efdd4090.js +0 -3
- package/dist/ix-icons/p-efdd4090.js.map +0 -1
- package/dist/ix-icons/p-f748c4c1.entry.js +0 -2
- /package/dist/ix-icons/{p-f748c4c1.entry.js.map → p-20e57a64.entry.js.map} +0 -0
@@ -1,2 +0,0 @@
|
|
1
|
-
import{g as t,r as e,h as n,H as i,a as r}from"./p-efdd4090.js";function s(){return document.querySelector("meta[name='ix-icons:v3-preview']")}function o(){const t=s();if(t){return t.getAttribute("content").split(";")}return null}function a(){const t=document.querySelector("meta[name='ix-icons:path']");if(t){const e=t.getAttribute("content");return e}return false}function c(){const t=o();if(!t){return false}if(t.includes("svg-path-loading")){return true}return false}let h;const f=new Map;let d=null;function u(t){t=t.replace(/[\(\)\[\]\{\}\=\?\!\.\:,\-_\+\\\"#~\/]/g," ");let e="";let n=true;t=t.toLowerCase();for(let i=0;t.length>i;i++){let r=t.charAt(i);if(r.match(/^\s+$/g)||r.match(/[\(\)\[\]\{\}\\\/]/g)){n=true}else if(n){r=r.toUpperCase();n=false}e+=r}const i=e.replace(/\s+/g,"");return i.charAt(0).toUpperCase()+i.slice(1)}const l=()=>{if(typeof window==="undefined"){return new Map}if(!h){window.IxIcons=window.IxIcons||{};h=window.IxIcons.map=window.IxIcons.map||new Map}return h};const w=t=>{if(!t){return false}if(typeof t!=="string"){return false}return t.startsWith("data:image/svg+xml")};function g(t){if(typeof window["DOMParser"]==="undefined"){console.warn("DOMParser not supported by your browser.");return}if(d===null){d=new window["DOMParser"]}const e=d.parseFromString(t,"text/html");const n=e.querySelector("svg");if(!n){throw Error("No valid svg data provided")}return n.outerHTML}async function m(t){const e=f.get(t);if(e){return e}const n=l();if(n.has(t)){return n.get(t)}const i=fetch(t).then((async e=>{const i=await e.text();if(!e.ok){console.error(i);throw Error(i)}const r=g(i);n.set(t,r);return r}));f.set(t,i);return i}const v=/^(?:(?:https?|ftp):\/\/)?(?:\S+(?::\S*)?@)?(?:www\.)?(?:\S+\.\S+)(?:\S*)$/i;function p(t){return v.test(t)}function y(e){const n=a();if(n){return`${n}/${e}.svg`}return t(`svg/${e}.svg`)}async function L(t){const e=await import("./p-51684ec4.js");let n=u(t);n=`icon${n}`;return g(e[n])}async function b(t){if(!t){throw Error("No icon name provided")}if(w(t)){return g(t)}if(p(t)){try{return m(t)}catch(t){throw t}}if(c()){console.warn("Using V3 preview feature for loading icons.");try{return m(y(t))}catch(t){throw Error("Cannot resolve any icon")}}return L(t)}const M=":host{display:inline-flex;height:1.5rem;width:1.5rem;min-height:1.5rem;min-width:1.5rem;color:inherit}:host .svg-container{display:block;position:relative;width:100%;height:100%}:host .svg-container svg{display:block;position:relative;height:100%;width:100%}:host .svg-container svg,:host .svg-container svg[fill],:host .svg-container svg [fill]{fill:currentColor !important}:host(.size-12){height:0.75rem;width:0.75rem;min-height:0.75rem;min-width:0.75rem}:host(.size-16){height:1rem;width:1rem;min-height:1rem;min-width:1rem}:host(.size-32){height:2rem;width:2rem;min-height:2rem;min-width:2rem}";const x=M;const z="data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='512' height='512' viewBox='0 0 512 512'><path fill-rule='evenodd' d='M384,0 L384,384 L0,384 L0,0 L384,0 Z M192,207.085 L57.751,341.333 L326.248,341.333 L192,207.085 Z M42.666,57.751 L42.666,326.248 L176.915,192 L42.666,57.751 Z M341.333,57.751 L207.085,192 L341.333,326.248 L341.333,57.751 Z M326.248,42.666 L57.751,42.666 L192,176.915 L326.248,42.666 Z' transform='translate(64 64)'/></svg>";const $=class{constructor(t){e(this,t);this.size=undefined;this.color=undefined;this.name=undefined;this.lazyLoading=false;this.svgContent=undefined;this.isVisible=false}connectedCallback(){this.waitForRendering((()=>{this.isVisible=true;this.loadIconContent()}))}async loadIconContent(){try{this.svgContent=await b(this.name)}catch(t){this.svgContent=g(z)}}waitForRendering(t){if(this.lazyLoading&&typeof window!=="undefined"&&window.IntersectionObserver){const e=new IntersectionObserver((n=>{n.forEach((n=>{if(n.isIntersecting){t();e.disconnect()}}))}),{rootMargin:"25px"});e.observe(this.hostElement)}else{t()}}render(){const t={};if(this.color){t["color"]=`var(--theme-${this.color})`}return n(i,{key:"8dc18bf3b1ab1e2a521bd0fee33fa91b856dc52b",style:t,class:{["size-12"]:this.size==="12",["size-16"]:this.size==="16",["size-24"]:this.size==="24",["size-32"]:this.size==="32"}},n("div",{key:"48c3e8ae8e0d36be5fa112dbd408756f56c19535",class:"svg-container",innerHTML:this.svgContent}))}static get assetsDirs(){return["svg"]}get hostElement(){return r(this)}static get watchers(){return{name:["loadIconContent"]}}};$.style=x;export{$ as I};
|
2
|
-
//# sourceMappingURL=p-1dac0290.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"names":["getV3PreviewMetaElement","document","querySelector","getV3PreviewMetaContent","v3PreviewMetaElement","getAttribute","split","getCustomAssetUrl","assetPath","path","isV3PreviewEnabled","features","includes","fetchCache","requests","Map","parser","toCamelCase","value","replace","returnValue","makeNextUppercase","toLowerCase","i","length","c","charAt","match","toUpperCase","normalized","slice","getIconCacheMap","window","IxIcons","map","isSvgDataUrl","url","startsWith","parseSVGDataContent","content","console","warn","svgDocument","parseFromString","svgElement","Error","outerHTML","async","fetchSVG","request","get","cache","has","fetching","fetch","then","response","responseText","text","ok","error","svgContent","set","urlRegex","isValidUrl","test","getAssetUrl","name","customAssetUrl","getAssetPath","getESMIcon","esmIcon","import","iconName","resolveIcon","iconCss","IxIconStyle0","iconMissingSymbol","Icon","connectedCallback","this","waitForRendering","isVisible","loadIconContent","onRender","lazyLoading","IntersectionObserver","observer","entries","forEach","entry","isIntersecting","disconnect","rootMargin","observe","hostElement","render","style","color","h","Host","key","class","size","innerHTML"],"sources":["src/components/icon/meta-tag.ts","src/components/icon/resolveIcon.ts","src/components/icon/icon.scss?tag=ix-icon&encapsulation=shadow","src/components/icon/icon.tsx"],"sourcesContent":["/*\n * COPYRIGHT (c) Siemens AG 2018-2024 ALL RIGHTS RESERVED.\n */\n\nfunction getV3PreviewMetaElement() {\n return document.querySelector(\"meta[name='ix-icons:v3-preview']\");\n}\n\nfunction getV3PreviewMetaContent() {\n const v3PreviewMetaElement = getV3PreviewMetaElement();\n if (v3PreviewMetaElement) {\n return v3PreviewMetaElement.getAttribute('content').split(';');\n }\n\n return null;\n}\n\n/**\n * Provide custom SVG path for icons\n *\n * <meta name=\"ix-icons:path\" content=\"/build/svg\" />\n */\nexport function getCustomAssetUrl() {\n const assetPath = document.querySelector(\"meta[name='ix-icons:path']\");\n if (assetPath) {\n const path = assetPath.getAttribute('content');\n return path;\n }\n\n return false;\n}\n\n/**\n * Enable v3 preview features\n *\n * <meta name=\"ix-icons:v3-preview\" content=\"svg-path-loading;\" />\n */\nexport function isV3PreviewEnabled() {\n const features = getV3PreviewMetaContent();\n\n if (!features) {\n return false;\n }\n\n if (features.includes('svg-path-loading')) {\n return true;\n }\n\n return false;\n}\n","/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { getAssetPath } from '@stencil/core';\nimport { getCustomAssetUrl, isV3PreviewEnabled } from './meta-tag';\n\ndeclare global {\n interface Window {\n IxIcons: any;\n }\n}\n\nlet fetchCache: Map<string, string>;\nconst requests = new Map<string, Promise<string>>();\nlet parser = null;\n\nfunction toCamelCase(value: string) {\n value = value.replace(/[\\(\\)\\[\\]\\{\\}\\=\\?\\!\\.\\:,\\-_\\+\\\\\\\"#~\\/]/g, ' ');\n let returnValue = '';\n let makeNextUppercase = true;\n value = value.toLowerCase();\n for (let i = 0; value.length > i; i++) {\n let c = value.charAt(i);\n if (c.match(/^\\s+$/g) || c.match(/[\\(\\)\\[\\]\\{\\}\\\\\\/]/g)) {\n makeNextUppercase = true;\n } else if (makeNextUppercase) {\n c = c.toUpperCase();\n makeNextUppercase = false;\n }\n returnValue += c;\n }\n const normalized = returnValue.replace(/\\s+/g, '');\n return normalized.charAt(0).toUpperCase() + normalized.slice(1);\n}\n\nexport const getIconCacheMap = (): Map<string, string> => {\n if (typeof window === 'undefined') {\n return new Map();\n }\n\n if (!fetchCache) {\n window.IxIcons = window.IxIcons || {};\n fetchCache = window.IxIcons.map = window.IxIcons.map || new Map();\n }\n return fetchCache;\n};\n\nexport const isSvgDataUrl = (url: string) => {\n if (!url) {\n return false;\n }\n\n if (typeof url !== 'string') {\n return false;\n }\n\n return url.startsWith('data:image/svg+xml');\n};\n\nexport function parseSVGDataContent(content: string) {\n if (typeof window['DOMParser'] === 'undefined') {\n console.warn('DOMParser not supported by your browser.');\n return;\n }\n\n if (parser === null) {\n parser = new window['DOMParser']();\n }\n\n const svgDocument = parser.parseFromString(content, 'text/html');\n const svgElement = svgDocument.querySelector('svg') as HTMLElement;\n\n if (!svgElement) {\n throw Error('No valid svg data provided');\n }\n\n return svgElement.outerHTML;\n}\n\nasync function fetchSVG(url: string) {\n const request = requests.get(url);\n\n if (request) {\n return request;\n }\n\n const cache = getIconCacheMap();\n\n if (cache.has(url)) {\n return cache.get(url);\n }\n\n const fetching = fetch(url).then(async response => {\n const responseText = await response.text();\n\n if (!response.ok) {\n console.error(responseText);\n throw Error(responseText);\n }\n\n const svgContent = parseSVGDataContent(responseText);\n cache.set(url, svgContent);\n\n return svgContent;\n });\n\n requests.set(url, fetching);\n return fetching;\n}\nconst urlRegex = /^(?:(?:https?|ftp):\\/\\/)?(?:\\S+(?::\\S*)?@)?(?:www\\.)?(?:\\S+\\.\\S+)(?:\\S*)$/i;\n\nfunction isValidUrl(url: string) {\n return urlRegex.test(url);\n}\n\nfunction getAssetUrl(name: string) {\n const customAssetUrl = getCustomAssetUrl();\n if (customAssetUrl) {\n return `${customAssetUrl}/${name}.svg`;\n }\n\n return getAssetPath(`svg/${name}.svg`);\n}\n\nasync function getESMIcon(name: string) {\n const esmIcon = await import('./icons');\n let iconName = toCamelCase(name);\n iconName = `icon${iconName}`;\n\n return parseSVGDataContent(esmIcon[iconName]);\n}\n\nexport async function resolveIcon(iconName: string) {\n if (!iconName) {\n throw Error('No icon name provided');\n }\n\n if (isSvgDataUrl(iconName)) {\n return parseSVGDataContent(iconName);\n }\n\n if (isValidUrl(iconName)) {\n try {\n return fetchSVG(iconName);\n } catch (error) {\n throw error;\n }\n }\n\n if (isV3PreviewEnabled()) {\n console.warn('Using V3 preview feature for loading icons.');\n try {\n return fetchSVG(getAssetUrl(iconName));\n } catch (error) {\n throw Error('Cannot resolve any icon');\n }\n }\n\n return getESMIcon(iconName);\n}\n","/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n@mixin size($size) {\n height: $size;\n width: $size;\n min-height: $size;\n min-width: $size;\n}\n\n:host {\n display: inline-flex;\n @include size(1.5rem);\n color: inherit;\n\n .svg-container {\n display: block;\n position: relative;\n width: 100%;\n height: 100%;\n\n svg {\n display: block;\n position: relative;\n height: 100%;\n width: 100%;\n }\n\n svg,\n svg[fill],\n svg [fill] {\n fill: currentColor !important;\n }\n }\n}\n\n:host(.size-12) {\n @include size(0.75rem);\n}\n\n:host(.size-16) {\n @include size(1rem);\n}\n\n:host(.size-32) {\n @include size(2rem);\n}\n","/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { Component, h, Host, Prop, State, Watch, Element, Build } from '@stencil/core';\nimport { parseSVGDataContent, resolveIcon } from './resolveIcon';\n\nconst iconMissingSymbol =\n \"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='512' height='512' viewBox='0 0 512 512'><path fill-rule='evenodd' d='M384,0 L384,384 L0,384 L0,0 L384,0 Z M192,207.085 L57.751,341.333 L326.248,341.333 L192,207.085 Z M42.666,57.751 L42.666,326.248 L176.915,192 L42.666,57.751 Z M341.333,57.751 L207.085,192 L341.333,326.248 L341.333,57.751 Z M326.248,42.666 L57.751,42.666 L192,176.915 L326.248,42.666 Z' transform='translate(64 64)'/></svg>\";\n\n@Component({\n tag: 'ix-icon',\n styleUrl: 'icon.scss',\n shadow: true,\n assetsDirs: ['svg'],\n})\nexport class Icon {\n @Element() hostElement: HTMLIxIconElement;\n\n /**\n * Size of the icon\n */\n @Prop() size: '12' | '16' | '24' | '32';\n\n /**\n * Color of the icon\n */\n @Prop() color: string;\n\n /**\n * Use one of our defined icon names e.g. `copy`\n *\n * https://ix.siemens.io/docs/icon-library/icons\n *\n * or the import variant\n *\n * ```\n * import { rocket } from '@siemens/ix-icons/icons';\n *\n * <ix-icon name={rocket}></ix-icon>\n * ```\n */\n @Prop() name: string;\n\n @Prop() lazyLoading = false;\n\n @State() svgContent?: string;\n @State() isVisible = false;\n\n connectedCallback() {\n this.waitForRendering(() => {\n this.isVisible = true;\n this.loadIconContent();\n });\n }\n\n @Watch('name')\n async loadIconContent() {\n try {\n this.svgContent = await resolveIcon(this.name);\n } catch (error) {\n this.svgContent = parseSVGDataContent(iconMissingSymbol);\n }\n }\n\n private waitForRendering(onRender: () => void) {\n if (Build.isBrowser && this.lazyLoading && typeof window !== 'undefined' && (window as any).IntersectionObserver) {\n const observer = new IntersectionObserver(\n entries => {\n entries.forEach(entry => {\n if (entry.isIntersecting) {\n onRender();\n observer.disconnect();\n }\n });\n },\n {\n rootMargin: '25px',\n },\n );\n\n observer.observe(this.hostElement);\n } else {\n onRender();\n }\n }\n\n render() {\n const style: {\n [key: string]: string;\n } = {};\n\n if (this.color) {\n style['color'] = `var(--theme-${this.color})`;\n }\n\n return (\n <Host\n style={style}\n class={{\n ['size-12']: this.size === '12',\n ['size-16']: this.size === '16',\n ['size-24']: this.size === '24',\n ['size-32']: this.size === '32',\n }}\n >\n <div class={'svg-container'} innerHTML={this.svgContent}></div>\n </Host>\n );\n }\n}\n"],"mappings":"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"}
|