@infineon/infineon-design-system-stencil 37.0.1--canary.1950.a2d1718e2db9df50e98b87bf993422b18ab13404.0 → 37.0.1--canary.1950.943614af196a0993de93a7c60293796fb0b8042e.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (35) hide show
  1. package/dist/cjs/ifx-alert_2.cjs.entry.js +128 -97
  2. package/dist/cjs/ifx-alert_2.cjs.entry.js.map +1 -1
  3. package/dist/cjs/ifx-icon.cjs.entry.js +127 -0
  4. package/dist/cjs/ifx-icon.cjs.entry.js.map +1 -0
  5. package/dist/cjs/index-7f4df11a.js +8 -8
  6. package/dist/cjs/infineon-design-system-stencil.cjs.js +1 -1
  7. package/dist/cjs/loader.cjs.js +1 -1
  8. package/dist/collection/global/utils/framework-detection.js +2 -2
  9. package/dist/collection/global/utils/framework-detection.js.map +1 -1
  10. package/dist/components/ifx-alert.js +1 -1
  11. package/dist/components/ifx-templates-ui.js +1 -1
  12. package/dist/components/{p-825ec41f.js → p-2c77fcad.js} +3 -3
  13. package/dist/components/p-2c77fcad.js.map +1 -0
  14. package/dist/esm/ifx-alert_2.entry.js +129 -98
  15. package/dist/esm/ifx-alert_2.entry.js.map +1 -1
  16. package/dist/esm/ifx-icon.entry.js +123 -0
  17. package/dist/esm/ifx-icon.entry.js.map +1 -0
  18. package/dist/esm/index-6c9eba32.js +8 -8
  19. package/dist/esm/infineon-design-system-stencil.js +1 -1
  20. package/dist/esm/loader.js +1 -1
  21. package/dist/infineon-design-system-stencil/infineon-design-system-stencil.esm.js +1 -1
  22. package/dist/infineon-design-system-stencil/p-157fea53.entry.js +2 -0
  23. package/dist/infineon-design-system-stencil/p-157fea53.entry.js.map +1 -0
  24. package/dist/infineon-design-system-stencil/p-6376233f.entry.js +2 -0
  25. package/dist/infineon-design-system-stencil/p-6376233f.entry.js.map +1 -0
  26. package/package.json +1 -1
  27. package/dist/cjs/ifx-template.cjs.entry.js +0 -156
  28. package/dist/cjs/ifx-template.cjs.entry.js.map +0 -1
  29. package/dist/components/p-825ec41f.js.map +0 -1
  30. package/dist/esm/ifx-template.entry.js +0 -152
  31. package/dist/esm/ifx-template.entry.js.map +0 -1
  32. package/dist/infineon-design-system-stencil/p-0cf02a78.entry.js +0 -2
  33. package/dist/infineon-design-system-stencil/p-0cf02a78.entry.js.map +0 -1
  34. package/dist/infineon-design-system-stencil/p-bfa94f97.entry.js +0 -2
  35. package/dist/infineon-design-system-stencil/p-bfa94f97.entry.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"names":["detectFramework","win","window","console","log","React","document","querySelector","Array","from","querySelectorAll","some","e","_reactRootContainer","undefined","Object","keys","k","startsWith","angular","getAllAngularRootElements","_b","_a","ng","coreTokens","NgZone","Backbone","Ember","Vue","Meteor","Zepto","jQuery","alertCss","IfxAlertStyle0","Alert","constructor","hostRef","this","variant","closable","AriaLive","alertTypeDescription","primary","success","danger","warning","info","handleClose","ifxClose","emit","renderCloseButton","h","class","onClick","bind","icon","generateUniqueId","prefix","Math","random","toString","substring","componentWillLoad","uniqueId","isNestedInIfxComponent","el","framework","trackComponent","render","role","name","id","infineonIconStencilCss","IfxIconStyle0","InfineonIconStencil","updateIcon","newIcon","internalIcon","setIcon","convertStringToHtml","htmlString","div","createElement","innerHTML","firstChild","convertHtmlToObject","htmlElement","pathToObject","attributes","value","reduce","acc","current","convertPathsToVnode","htmlPath","svgPaths","parentPath","parentPathToVnode","push","paths","pathLength","length","i","objToVnode","getSVG","svgPath","ifxIcon","width","getAttribute","height","fill","viewBox","xmlns","constructIcon","SVG","error","consoleError","toCamelCase","str","replace","_","chr","toUpperCase","m","toLowerCase","iconName","getIcon","isInsideAgGrid","className","parentElement","isInsideChoices","Host","key"],"sources":["src/global/utils/framework-detection.ts","src/components/alert/alert.scss?tag=ifx-alert&encapsulation=shadow","src/components/alert/alert.tsx","src/components/icon/infineonIconStencil.scss?tag=ifx-icon","src/components/icon/infineonIconStencil.tsx"],"sourcesContent":["export const detectFramework = (): string => {\n const win = window as any;\n\n console.log('here')\n\n if(!!win.React || !!document.querySelector('[data-reactroot], [data-reactid]') ||\n Array.from(document.querySelectorAll('*')).some((e: any) => e._reactRootContainer !== undefined || Object.keys(e).some(k => k.startsWith('__reactContainer')))\n ) { \n console.log('React.js');\n return 'React'\n }\n \n if(!!document.querySelector('script[id=__NEXT_DATA__]')) {\n console.log('Next.js');\n }\n \n\n if(!!document.querySelector('[id=___gatsby]')) {\n console.log('Gatsby.js');\n }\n \n\n if(!!win.angular ||\n !!document.querySelector('.ng-binding, [ng-app], [data-ng-app], [ng-controller], [data-ng-controller], [ng-repeat], [data-ng-repeat]') ||\n !!document.querySelector('script[src*=\"angular.js\"], script[src*=\"angular.min.js\"]')\n ) {\n console.log('Angular.js');\n }\n \n\n if (!!win.getAllAngularRootElements || !!win.ng?.coreTokens?.NgZone) {\n console.log('Angular');\n }\n \n\n if(!!win.Backbone) console.log('Backbone.js');\n if(!!win.Ember) console.log('Ember.js');\n if(!!win.Vue) console.log('Vue.js');\n if(!!win.Meteor) console.log('Meteor.js');\n if(!!win.Zepto) console.log('Zepto.js');\n if(!!win.jQuery) console.log('jQuery.js');\n\n console.log('vanilla')\n return 'vanilla'\n};","@use \"~@infineon/design-system-tokens/dist/tokens\";\n@use \"../../global/font.scss\";\n\n:host {\n display: block;\n}\n\n.alert__info-wrapper {\n display: flex;\n padding: 16px 24px;\n font-family: var(--ifx-font-family); // tokens.$ifxFontFamilyBody;\n\n\n box-shadow: 0px 6px 9px 0px #1D1D1D1A;\n\n & .info__text-wrapper {\n display: flex;\n flex-direction: column;\n gap: tokens.$ifxSpace100;\n width: 100%;\n\n & .info__headline-wrapper {\n display: -webkit-box;\n -webkit-line-clamp: 1;\n line-clamp: 1;\n -webkit-box-orient: vertical;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n & .info__headline-wrapper,\n .info__description-wrapper {\n color: #1D1D1D;\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n\n ::slotted(p) {\n padding: 0;\n margin: 0;\n }\n }\n\n & .info__description-wrapper {\n font-weight: 400;\n }\n }\n\n & .close-icon-wrapper {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n justify-content: flex-start;\n //min-width: tokens.$ifxSize500;\n\n & button {\n all: unset;\n display: flex;\n align-items: center;\n justify-content: center;\n line-height: 0;\n color: tokens.$ifxColorBaseBlack;\n height: tokens.$ifxSize300;\n width: tokens.$ifxSize300;\n\n\n &:focus {\n outline: 2px solid tokens.$ifxColorOcean500;\n outline-offset: 2px;\n }\n }\n }\n}\n\n.alert {\n display: flex;\n border: 1px solid tokens.$ifxColorOcean500;\n border-radius: tokens.$ifxBorderRadius12;\n color: tokens.$ifxColorBaseBlack;\n background-color: tokens.$ifxColorBaseWhite;\n font-family: var(--ifx-font-family); // tokens.$ifxFontFamilyBody;\n\n\n box-shadow: 0px 6px 9px 0px #1D1D1D1A;\n\n\n & .close-icon-wrapper {\n display: flex;\n align-items: center;\n justify-content: center;\n min-width: tokens.$ifxSize500;\n\n & button {\n all: unset;\n display: flex;\n align-items: center;\n justify-content: center;\n line-height: 0;\n color: tokens.$ifxColorBaseBlack;\n height: tokens.$ifxSize300;\n width: tokens.$ifxSize300;\n\n &:focus {\n outline: 2px solid tokens.$ifxColorOcean500;\n outline-offset: 2px;\n }\n }\n }\n\n & .icon-wrapper {\n position: relative;\n min-width: tokens.$ifxSize600;\n display: flex;\n justify-content: center;\n align-items: center;\n background-color: tokens.$ifxColorOcean500;\n }\n\n & .alert-text {\n font-size: 16px;\n width: 100%;\n padding: 12px 0px 12px 12px;\n color: tokens.$ifxColorBaseBlack;\n\n white-space: pre-wrap;\n /* wraps text at spaces and within words */\n word-wrap: break-word;\n /* breaks text within a word if necessary */\n overflow-wrap: anywhere;\n /* breaks text at arbitrary points when needed */\n }\n\n &.primary {\n border: 1px solid tokens.$ifxColorOcean500;\n\n & .icon-wrapper {\n background-color: tokens.$ifxColorOcean500;\n color: tokens.$ifxColorBaseWhite;\n }\n }\n\n &.success {\n border: 1px solid tokens.$ifxColorGreen500;\n\n & .icon-wrapper {\n background-color: tokens.$ifxColorGreen500;\n color: tokens.$ifxColorBaseWhite;\n }\n }\n\n &.danger {\n border: 1px solid tokens.$ifxColorRed500;\n\n & .icon-wrapper {\n background-color: tokens.$ifxColorRed500;\n color: tokens.$ifxColorBaseWhite;\n }\n }\n\n &.warning {\n border: 1px solid tokens.$ifxColorOrange500;\n\n & .icon-wrapper {\n background-color: tokens.$ifxColorOrange500;\n color: tokens.$ifxColorBaseWhite;\n }\n }\n}\n\n.close-icon-wrapper {\n & ifx-icon {\n &:hover {\n cursor: pointer;\n }\n }\n}","import { Component, Prop, h, Event, EventEmitter, State, Element } from '@stencil/core';\nimport { trackComponent } from '../../global/utils/tracking';\nimport { isNestedInIfxComponent } from '../../global/utils/dom-utils';\nimport { detectFramework } from '../../global/utils/framework-detection';\n\n@Component({\n tag: 'ifx-alert',\n styleUrl: 'alert.scss',\n shadow: true,\n})\nexport class Alert {\n @Element() el: HTMLElement;\n @Prop() variant: 'primary' | 'success' | 'danger' | 'warning' | 'info' = 'primary';\n @Prop() icon: string;\n @Event() ifxClose: EventEmitter;\n @Prop() closable: boolean = true;\n @Prop() AriaLive = 'assertive';\n @State() uniqueId: string;\n\n alertTypeDescription = {\n \"primary\": 'Neutral alert',\n \"success\": 'Success Alert',\n \"danger\": 'Error Alert',\n \"warning\": 'Warning Alert',\n \"info\": 'Neutral alert',\n };\n\n handleClose() {\n this.ifxClose.emit();\n }\n\n renderCloseButton() {\n return (\n <div class=\"close-icon-wrapper\">\n <button onClick={this.handleClose.bind(this)} aria-label=\"Dismiss alert\">\n <ifx-icon icon=\"cross-16\" />\n </button>\n </div>\n );\n }\n\n generateUniqueId(prefix = 'id') {\n return `${prefix}-${Math.random().toString(36).substring(2, 9)}`;\n }\n\n componentWillLoad() { \n if (!this.uniqueId) {\n this.uniqueId = this.generateUniqueId('alert');\n }\n\n if(!isNestedInIfxComponent(this.el)) {\n const framework = detectFramework();\n console.log('framework', framework)\n trackComponent('ifx-alert', { framework });\n\n }\n }\n\n render() {\n return this.variant === 'info' ? (\n <div class=\"alert__info-wrapper\" role=\"alert\" aria-live={this.AriaLive} aria-describedby={this.alertTypeDescription[this.variant]} aria-labelledby=\"alert-text alert-description\">\n <div class=\"info__text-wrapper\">\n <div class=\"info__headline-wrapper\">\n <slot name=\"headline\" />\n </div>\n <div id={`alert-description-${this.uniqueId}`} class=\"info__description-wrapper\">\n <slot name=\"desc\" />\n </div>\n </div>\n {this.closable ? this.renderCloseButton() : null}\n </div>\n ) : (\n <div class={`alert ${this.variant}`} role=\"alert\">\n {this.icon && (\n <div class=\"icon-wrapper\">\n <ifx-icon icon={this.icon} />\n </div>\n )}\n <div class=\"alert-text\" id={`alert-text-${this.uniqueId}`}>\n <slot />\n </div>\n {this.closable ? this.renderCloseButton() : null}\n </div>\n );\n }\n}\n","ifx-icon {\n display: inline-flex;\n justify-content: center;\n\n &:empty {\n display: none;\n }\n}","import { Component, Prop, h, Host, Event, EventEmitter, Watch, State, Element } from '@stencil/core';\nimport { getIcon } from '@infineon/infineon-icons'\nimport { trackComponent } from '../../global/utils/tracking'; \nimport { isNestedInIfxComponent } from '../../global/utils/dom-utils';\n\n\n@Component({\n tag: 'ifx-icon',\n styleUrl: './infineonIconStencil.scss'\n})\n\nexport class InfineonIconStencil {\n @Element() el: HTMLElement;\n @Prop({ mutable: true }) icon: string = \"\"\n @Prop({ mutable: true }) ifxIcon: any;\n @State() internalIcon: string;\n @Event() consoleError: EventEmitter<boolean>;\n\n @Watch('icon')\n updateIcon(newIcon: string) { \n this.internalIcon = newIcon;\n this.setIcon()\n }\n\n convertStringToHtml(htmlString) { \n const div = document.createElement('div')\n div.innerHTML = htmlString\n return div.firstChild\n }\n\n convertHtmlToObject(htmlElement) { \n let pathToObject = Array\n .from(htmlElement.attributes, ({ name, value }) => ({ name, value }))\n .reduce((acc, current) => {\n acc[current.name] = current.value\n return acc\n }, {})\n\n return pathToObject\n }\n\n convertPathsToVnode(htmlPath) { \n let svgPaths = []\n const parentPath = this.convertHtmlToObject(htmlPath);\n const parentPathToVnode = h(\"path\", parentPath);\n svgPaths.push(parentPathToVnode)\n if(htmlPath.firstChild) { \n const paths = htmlPath.querySelectorAll('path');\n const pathLength = htmlPath.querySelectorAll('path').length;\n for(let i = 0; i < pathLength; i++) { \n let pathToObject = this.convertHtmlToObject(paths[i])\n let objToVnode = h(\"path\", pathToObject)\n svgPaths.push(objToVnode)\n } \n }\n return svgPaths\n }\n\n getSVG(svgPath) {\n const htmlPath = this.convertStringToHtml(this.ifxIcon) as SVGElement;\n const width = htmlPath.getAttribute('width');\n const height = htmlPath.getAttribute('height');\n const fill = htmlPath.getAttribute('fill');\n const viewBox = htmlPath.getAttribute('viewBox');\n \n return <svg class=\"inline-svg\" width={width} height={height} xmlns=\"http://www.w3.org/2000/svg\" fill={fill} viewBox={viewBox}>{...svgPath}</svg>\n }\n\n constructIcon() {\n if(this.ifxIcon) {\n const htmlPath = this.convertStringToHtml(this.ifxIcon)\n const svgPath = this.convertPathsToVnode(htmlPath)\n const SVG = this.getSVG(svgPath)\n return SVG;\n } else if(this.icon !== \"\") {\n console.error('Icon not found!')\n this.consoleError.emit(true)\n return;\n } else { \n return;\n }\n }\n\nsetIcon() { \n const toCamelCase = str =>\n str\n .replace(/[-_]+(.)/g, (_, chr) => chr.toUpperCase()) // handle - and _ to uppercase\n .replace(/^(.)/, (m) => m.toLowerCase()); // ensure first letter is lowercase\n\n const iconName = toCamelCase(this.internalIcon);\n this.ifxIcon = getIcon(iconName);\n}\n\n isInsideAgGrid(el: HTMLElement): boolean {\n let current = el;\n while (current) {\n if (current.className?.toLowerCase().startsWith('ag-')) {\n return true;\n }\n current = current.parentElement;\n }\n return false;\n}\n\n isInsideChoices(el: HTMLElement): boolean {\n let current = el;\n while (current) {\n if (current.className?.toLowerCase().startsWith('choices__')) {\n return true;\n }\n current = current.parentElement;\n }\n return false;\n }\n\n componentWillLoad() {\n this.internalIcon = this.icon;\n this.setIcon()\n\n if(!isNestedInIfxComponent(this.el)) { \n if(!this.isInsideAgGrid(this.el) && !this.isInsideChoices(this.el)) { \n trackComponent('ifx-icon')\n }\n }\n }\n\n render() {\n return (\n <Host>\n {this.constructIcon()}\n </Host>\n );\n }\n}"],"mappings":"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","ignoreList":[]}