@po-ui/ng-components 18.2.0 → 18.3.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.
@@ -13,6 +13,15 @@ import * as i0 from "@angular/core";
13
13
  *
14
14
  * > Obs.: Não está documentado aqui e não indicamos a customização das cores de 'feedback' por motivos de acessibilidade e usabilidade.
15
15
  */
16
+ /**
17
+ * @example
18
+ *
19
+ * <example name="po-theme-labs" title="PO Theme Labs">
20
+ * <file name="sample-po-theme-labs/sample-po-theme-labs.component.html"> </file>
21
+ * <file name="sample-po-theme-labs/sample-po-theme-labs.component.ts"> </file>
22
+ * </example>
23
+ *
24
+ */
16
25
  export class PoThemeService {
17
26
  window;
18
27
  document;
@@ -289,4 +298,4 @@ export class PoThemeService {
289
298
  type: Inject,
290
299
  args: [ICONS_DICTIONARY]
291
300
  }] }], null); })();
292
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-theme.service.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/services/po-theme/po-theme.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport { Inject, Injectable, Optional, Renderer2, RendererFactory2 } from '@angular/core';\nimport { ICONS_DICTIONARY, PhosphorIconDictionary } from '../../components/po-icon/index';\nimport { PoThemeTypeEnum } from './enum/po-theme-type.enum';\nimport { poThemeDefault } from './helpers/po-theme-poui.constant';\nimport { PoThemeColor } from './interfaces/po-theme-color.interface';\nimport { PoThemeTokens } from './interfaces/po-theme-tokens.interface';\nimport { PoTheme } from './interfaces/po-theme.interface';\n\n/**\n * @description\n *\n * O `PoThemeService` possibilita a personalização das cores do tema padrão do `PO-UI`, permitindo a alteração dos valores das variáveis de estilo usadas no CSS padrão.\n *\n * > Para saber mais sobre como customizar as cores do tema padrão verifique o item [Customizando cores do tema padrão](https://po-ui.io/guides/colors-customization) na aba `Guias`.\n *\n * > Obs.: Não está documentado aqui e não indicamos a customização das cores de 'feedback' por motivos de acessibilidade e usabilidade.\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class PoThemeService {\n  private renderer: Renderer2;\n  private theme: PoTheme = poThemeDefault;\n  private _iconToken: { [key: string]: string };\n\n  get iconNameLib() {\n    return this._iconToken.NAME_LIB;\n  }\n\n  constructor(\n    @Inject('Window') private window: Window,\n    @Inject(DOCUMENT) private document: Document,\n    rendererFactory: RendererFactory2,\n    @Optional() @Inject(ICONS_DICTIONARY) value: { [key: string]: string }\n  ) {\n    this.renderer = rendererFactory.createRenderer(null, null);\n\n    this._iconToken = value ?? PhosphorIconDictionary;\n  }\n\n  /**\n   * Define o tema a ser aplicado no componente, de acordo com o tipo de tema especificado.\n   *\n   * Este método define o tema a ser aplicado no componente com base no objeto `theme` fornecido e no tipo de tema especificado.\n   * Ele atualiza as propriedades do componente para refletir o tema selecionado, como cores, estilos e comportamentos.\n   *\n   * @param {PoTheme} theme - Objeto contendo as definições de tema a serem aplicadas no componente.\n   * @param {PoThemeTypeEnum} [themeType=PoThemeTypeEnum.light] - (Opcional) Tipo de tema a ser aplicado, podendo ser 'light' (claro) ou 'dark' (escuro). Por padrão, o tema claro é aplicado.\n   */\n  setTheme(theme: PoTheme, themeType: PoThemeTypeEnum = PoThemeTypeEnum.light): void {\n    // Change theme name, remove special characteres and number, replace space with dash\n    theme.name = theme.name\n      .toLowerCase()\n      .replace(/[^a-zA-Z ]/g, '')\n      .replace(/\\s+/g, '-');\n    theme.active = themeType;\n\n    const _themeType = theme.type[PoThemeTypeEnum[themeType]];\n    if (!_themeType) {\n      return;\n    }\n\n    const colorStyles = _themeType.color ? this.generateThemeStyles(_themeType.color) : '';\n    const perComponentStyles = _themeType.perComponent ? this.generatePerComponentStyles(_themeType.perComponent) : '';\n    const onRootStyles = _themeType.onRoot ? this.generateAdditionalStyles(_themeType.onRoot) : '';\n    const additionalStyles = this.generateAdditionalStyles(_themeType);\n\n    const combinedStyles = `\n      .${theme.name}-${PoThemeTypeEnum[themeType]}:root {\n        ${colorStyles}\n        ${perComponentStyles}\n        ${onRootStyles}\n        ${additionalStyles}\n      }`;\n\n    this.applyThemeStyles(combinedStyles);\n    this.changeThemeType(theme);\n  }\n\n  /**\n   * @docsPrivate\n   *\n   * Gera estilos adicionais com base nos tokens de tema fornecidos, excluindo os tokens de cor.\n   * @param theme Os tokens de tema contendo os estilos adicionais a serem gerados.\n   * @returns Uma string contendo os estilos adicionais formatados.\n   */\n  private generateAdditionalStyles(theme: PoThemeTokens): string {\n    return Object.entries(theme)\n      .filter(([key]) => !['color', 'perComponent', 'onRoot'].includes(key))\n      .map(([key, value]) => `${key}: ${value};`)\n      .join(' ');\n  }\n\n  /**\n   * @docsPrivate\n   *\n   * Aplica os estilos de tema ao documento.\n   * @param styleCss Os estilos CSS a serem aplicados.\n   */\n  private applyThemeStyles(styleCss: string): void {\n    const styleElement = this.createStyleElement(styleCss);\n    const existingStyleElement = document.head.querySelector('#pouiTheme');\n\n    if (existingStyleElement) {\n      this.renderer.removeChild(document.head, existingStyleElement);\n    }\n\n    this.renderer.appendChild(document.head, styleElement);\n  }\n\n  private changeThemeType(theme: PoTheme) {\n    this.cleanThemeActive();\n    this.setThemeActive(theme);\n    document.getElementsByTagName('html')[0].classList.add(...[`${theme.name}-${PoThemeTypeEnum[theme.active]}`]);\n  }\n\n  /**\n   * Persiste e define o tema do aplicativo com base nos dados armazenados.\n   *\n   * Este método recupera os dados do tema armazenados e os aplica ao aplicativo.\n   *\n   * @returns {PoTheme} Recupera o tema armazenado.\n   */\n  persistThemeActive() {\n    const _theme = this.getThemeActive();\n    this.setTheme(_theme, _theme.active);\n    return _theme;\n  }\n\n  /**\n   * Altera o tipo do tema armazenado e aplica os novos estilos ao documento.\n   *\n   * Este método altera o tipo do tema armazenado ativo (light/dark)\n   *\n   * @param {PoThemeTypeEnum} themeType O tipo de tema a ser aplicado, light ou dark.\n   */\n  changeCurrentThemeType(type: PoThemeTypeEnum): void {\n    const _theme = this.getThemeActive();\n    _theme.active = type;\n    this.changeThemeType(_theme);\n  }\n\n  /**\n   * Método remove o tema armazenado e limpa todos os estilos de tema\n   * aplicados ao documento.\n   */\n  cleanThemeActive(): void {\n    const _theme = this.getThemeActive();\n    document.getElementsByTagName('html')[0].classList.remove(`${_theme.name}-${PoThemeTypeEnum[_theme.active]}`);\n    localStorage.removeItem('totvs-theme');\n  }\n\n  /**\n   * @docsPrivate\n   *\n   * Este método define um dados do tema e o armazena.\n   * @param theme Os tokens de tema contendo os estilos adicionais a serem gerados.\n   */\n  private setThemeActive(theme: PoTheme): void {\n    if (theme) {\n      localStorage.setItem('totvs-theme', JSON.stringify(theme));\n      this.theme = theme;\n    }\n  }\n\n  /**\n   * Retorna o tema ativo como um observable.\n   * @returns {PoTheme} Tema ativo.\n   */\n  getThemeActive(): PoTheme {\n    try {\n      const themeData = JSON.parse(localStorage.getItem('totvs-theme'));\n      if (themeData && JSON.stringify(themeData) !== JSON.stringify(this.theme)) {\n        this.theme = themeData;\n      }\n    } catch (error) {\n      console.error('Erro ao obter o tema do armazenamento local:', error);\n    }\n    return this.theme;\n  }\n\n  /**\n   * @docsPrivate\n   *\n   * Gera estilos CSS com base nos tokens de cores fornecidos.\n   * @param themeColor Os tokens de cor a serem usados para gerar os estilos.\n   * @returns Uma string contendo os estilos CSS gerados.\n   */\n  private createStyleElement(css: string): HTMLStyleElement {\n    const styleElement = this.renderer.createElement('style');\n    styleElement.id = 'pouiTheme';\n    this.renderer.appendChild(styleElement, this.renderer.createText(css));\n    return styleElement;\n  }\n\n  /**\n   * @docsPrivate\n   *\n   * Gera estilos CSS com base nos tokens de cores fornecidos.\n   * @param themeColor Os tokens de cor a serem usados para gerar os estilos.\n   * @returns Uma string contendo os estilos CSS gerados.\n   */\n  private generateThemeStyles(themeColor: PoThemeColor): string {\n    const selectBgIconStyle = this.getSelectBgIconsStyle(themeColor);\n\n    return [\n      Object.entries(themeColor)\n        .flatMap(([type, values]) =>\n          Object.entries(values).flatMap(([tonality, tonalityValues]) => {\n            if (type === 'action') {\n              return [`--color-${type}-${tonality}: ${tonalityValues};`];\n            } else {\n              return Object.entries(tonalityValues).map(\n                ([level, colorValue]) => `--color-${type}-${tonality}-${level}: ${colorValue};`\n              );\n            }\n          })\n        )\n        .join(''),\n      selectBgIconStyle\n    ].join('');\n  }\n\n  /**\n   * @docsPrivate\n   *\n   * Gera estilos CSS com base nos tokens per Component fornecidos.\n   * @param themePerComponent Os tokens de cor a serem usados para gerar os estilos.\n   * @returns Uma string contendo os estilos CSS gerados.\n   */\n  private generatePerComponentStyles(themePerComponent: any): string {\n    return Object.entries(themePerComponent)\n      .flatMap(([type, values]) =>\n        Object.entries(values).flatMap(([level, colorValue]) => [`${type} {${level}: ${colorValue};};`])\n      )\n      .join('');\n  }\n\n  /**\n   * Define o tema atual como o tema \"PoUI Padrão\".\n   *\n   * @param {PoThemeTypeEnum} type O tipo de Tema a ser aplicado, light / dark.\n   */\n  setDefaultTheme(type: PoThemeTypeEnum): void {\n    this.setTheme(poThemeDefault, type);\n  }\n\n  /**\n   * @docsPrivate\n   *\n   * Retorna o estilo CSS para o fundo dos ícones do componente po-select, com base nas cores do tema.\n   *\n   * @param {PoThemeColor} themeColor - Objeto contendo as cores do tema.\n   * @returns {string} - Estilo CSS para o fundo dos ícones do po-select.\n   */\n  private getSelectBgIconsStyle(themeColor: PoThemeColor): string {\n    let selectBgIcon = '';\n\n    if (themeColor?.brand?.['01']?.dark) {\n      const selector = this.iconNameLib === 'PhosphorIcon' ? 'po-select .po-select-phosphor' : 'po-select';\n      selectBgIcon += `${selector} { --background-image: url(${this.getSelectBgIcon(themeColor.brand['01'].dark)}); };`;\n    }\n\n    if (themeColor?.feedback?.negative?.base) {\n      if (this.iconNameLib === 'PoIcon') {\n        selectBgIcon += `po-select.ng-dirty.ng-invalid select { --background-image: url(${this.getSelectBgIcon(themeColor.feedback.negative.base)}); };`;\n      }\n\n      if (this.iconNameLib === 'PhosphorIcon') {\n        selectBgIcon += `po-select.ng-dirty.ng-invalid select.po-select-phosphor { background-image: url(${this.getSelectBgIcon(themeColor.feedback.negative.base)}); };`;\n      }\n    }\n\n    if (themeColor?.neutral?.light?.['30']) {\n      if (this.iconNameLib === 'PoIcon') {\n        selectBgIcon += `select:disabled { background-image: url(${this.getSelectBgIcon(themeColor.neutral.light['30'])}); };`;\n      }\n\n      if (this.iconNameLib === 'PhosphorIcon') {\n        selectBgIcon += `po-select select.po-select-phosphor:disabled { background-image: url(${this.getSelectBgIcon(themeColor.neutral.light['30'])}); };`;\n      }\n    }\n\n    return selectBgIcon;\n  }\n\n  /**\n   * @docsPrivate\n   *\n   * Retorna a imagem SVG utilizada como fundo do po-select.\n   *\n   * @param {string} color Cor da Imagem - Utilizada no atributo 'fill'.\n   * @returns {string} Imagem SVG utilizada no po-select.\n   */\n  private getSelectBgIcon(color: string): string {\n    let svg: string;\n\n    if (this.iconNameLib === 'PoIcon') {\n      svg = `\"data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' `;\n\n      svg = svg.concat(`xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' `);\n      svg = svg.concat(`d='M18.707 8.29301C18.316 7.90201 17.684 7.90201 17.293 8.29301L12 13.586L6.70701 `);\n      svg = svg.concat(`8.29301C6.31601 7.90201 5.68401 7.90201 5.29301 8.29301C4.90201 8.68401 4.90201 `);\n      svg = svg.concat(`9.31601 5.29301 9.70701L11.293 15.707C11.488 15.902 11.744 16 12 16C12.256 16 12.512 `);\n      svg = svg.concat(`15.902 12.707 15.707L18.707 9.70701C19.098 9.31601 19.098 8.68401 18.707 8.29301Z' `);\n      svg = svg.concat(`fill='${color.replace('#', '%23')}'/%3E%3C/svg%3E%0A\");`);\n\n      return svg;\n    }\n\n    svg = `\"data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 256 256' fill='${color.replace('#', '%23')}' `;\n    svg = svg.concat(`xmlns='http://www.w3.org/2000/svg'%3E%3Cpath `);\n    svg = svg.concat(\n      `d='M213.66,101.66l-80,80a8,8,0,0,1-11.32,0l-80-80A8,8,0,0,1,53.66,90.34L128,164.69l74.34-74.35a8,8,0,0,1,11.32,11.32Z'`\n    );\n    svg = svg.concat(`%3E%3C/path%3E%3C/svg%3E\");`);\n\n    return svg;\n  }\n}\n"]}
301
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-theme.service.js","sourceRoot":"","sources":["../../../../../../projects/ui/src/lib/services/po-theme/po-theme.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport { Inject, Injectable, Optional, Renderer2, RendererFactory2 } from '@angular/core';\nimport { ICONS_DICTIONARY, PhosphorIconDictionary } from '../../components/po-icon/index';\nimport { PoThemeTypeEnum } from './enum/po-theme-type.enum';\nimport { poThemeDefault } from './helpers/po-theme-poui.constant';\nimport { PoThemeColor } from './interfaces/po-theme-color.interface';\nimport { PoThemeTokens } from './interfaces/po-theme-tokens.interface';\nimport { PoTheme } from './interfaces/po-theme.interface';\n\n/**\n * @description\n *\n * O `PoThemeService` possibilita a personalização das cores do tema padrão do `PO-UI`, permitindo a alteração dos valores das variáveis de estilo usadas no CSS padrão.\n *\n * > Para saber mais sobre como customizar as cores do tema padrão verifique o item [Customizando cores do tema padrão](https://po-ui.io/guides/colors-customization) na aba `Guias`.\n *\n * > Obs.: Não está documentado aqui e não indicamos a customização das cores de 'feedback' por motivos de acessibilidade e usabilidade.\n */\n\n/**\n * @example\n *\n * <example name=\"po-theme-labs\" title=\"PO Theme Labs\">\n *  <file name=\"sample-po-theme-labs/sample-po-theme-labs.component.html\"> </file>\n *  <file name=\"sample-po-theme-labs/sample-po-theme-labs.component.ts\"> </file>\n * </example>\n *\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class PoThemeService {\n  private renderer: Renderer2;\n  private theme: PoTheme = poThemeDefault;\n  private _iconToken: { [key: string]: string };\n\n  get iconNameLib() {\n    return this._iconToken.NAME_LIB;\n  }\n\n  constructor(\n    @Inject('Window') private window: Window,\n    @Inject(DOCUMENT) private document: Document,\n    rendererFactory: RendererFactory2,\n    @Optional() @Inject(ICONS_DICTIONARY) value: { [key: string]: string }\n  ) {\n    this.renderer = rendererFactory.createRenderer(null, null);\n\n    this._iconToken = value ?? PhosphorIconDictionary;\n  }\n\n  /**\n   * Define o tema a ser aplicado no componente, de acordo com o tipo de tema especificado.\n   *\n   * Este método define o tema a ser aplicado no componente com base no objeto `theme` fornecido e no tipo de tema especificado.\n   * Ele atualiza as propriedades do componente para refletir o tema selecionado, como cores, estilos e comportamentos.\n   *\n   * @param {PoTheme} theme - Objeto contendo as definições de tema a serem aplicadas no componente.\n   * @param {PoThemeTypeEnum} [themeType=PoThemeTypeEnum.light] - (Opcional) Tipo de tema a ser aplicado, podendo ser 'light' (claro) ou 'dark' (escuro). Por padrão, o tema claro é aplicado.\n   */\n  setTheme(theme: PoTheme, themeType: PoThemeTypeEnum = PoThemeTypeEnum.light): void {\n    // Change theme name, remove special characteres and number, replace space with dash\n    theme.name = theme.name\n      .toLowerCase()\n      .replace(/[^a-zA-Z ]/g, '')\n      .replace(/\\s+/g, '-');\n    theme.active = themeType;\n\n    const _themeType = theme.type[PoThemeTypeEnum[themeType]];\n    if (!_themeType) {\n      return;\n    }\n\n    const colorStyles = _themeType.color ? this.generateThemeStyles(_themeType.color) : '';\n    const perComponentStyles = _themeType.perComponent ? this.generatePerComponentStyles(_themeType.perComponent) : '';\n    const onRootStyles = _themeType.onRoot ? this.generateAdditionalStyles(_themeType.onRoot) : '';\n    const additionalStyles = this.generateAdditionalStyles(_themeType);\n\n    const combinedStyles = `\n      .${theme.name}-${PoThemeTypeEnum[themeType]}:root {\n        ${colorStyles}\n        ${perComponentStyles}\n        ${onRootStyles}\n        ${additionalStyles}\n      }`;\n\n    this.applyThemeStyles(combinedStyles);\n    this.changeThemeType(theme);\n  }\n\n  /**\n   * @docsPrivate\n   *\n   * Gera estilos adicionais com base nos tokens de tema fornecidos, excluindo os tokens de cor.\n   * @param theme Os tokens de tema contendo os estilos adicionais a serem gerados.\n   * @returns Uma string contendo os estilos adicionais formatados.\n   */\n  private generateAdditionalStyles(theme: PoThemeTokens): string {\n    return Object.entries(theme)\n      .filter(([key]) => !['color', 'perComponent', 'onRoot'].includes(key))\n      .map(([key, value]) => `${key}: ${value};`)\n      .join(' ');\n  }\n\n  /**\n   * @docsPrivate\n   *\n   * Aplica os estilos de tema ao documento.\n   * @param styleCss Os estilos CSS a serem aplicados.\n   */\n  private applyThemeStyles(styleCss: string): void {\n    const styleElement = this.createStyleElement(styleCss);\n    const existingStyleElement = document.head.querySelector('#pouiTheme');\n\n    if (existingStyleElement) {\n      this.renderer.removeChild(document.head, existingStyleElement);\n    }\n\n    this.renderer.appendChild(document.head, styleElement);\n  }\n\n  private changeThemeType(theme: PoTheme) {\n    this.cleanThemeActive();\n    this.setThemeActive(theme);\n    document.getElementsByTagName('html')[0].classList.add(...[`${theme.name}-${PoThemeTypeEnum[theme.active]}`]);\n  }\n\n  /**\n   * Persiste e define o tema do aplicativo com base nos dados armazenados.\n   *\n   * Este método recupera os dados do tema armazenados e os aplica ao aplicativo.\n   *\n   * @returns {PoTheme} Recupera o tema armazenado.\n   */\n  persistThemeActive() {\n    const _theme = this.getThemeActive();\n    this.setTheme(_theme, _theme.active);\n    return _theme;\n  }\n\n  /**\n   * Altera o tipo do tema armazenado e aplica os novos estilos ao documento.\n   *\n   * Este método altera o tipo do tema armazenado ativo (light/dark)\n   *\n   * @param {PoThemeTypeEnum} themeType O tipo de tema a ser aplicado, light ou dark.\n   */\n  changeCurrentThemeType(type: PoThemeTypeEnum): void {\n    const _theme = this.getThemeActive();\n    _theme.active = type;\n    this.changeThemeType(_theme);\n  }\n\n  /**\n   * Método remove o tema armazenado e limpa todos os estilos de tema\n   * aplicados ao documento.\n   */\n  cleanThemeActive(): void {\n    const _theme = this.getThemeActive();\n    document.getElementsByTagName('html')[0].classList.remove(`${_theme.name}-${PoThemeTypeEnum[_theme.active]}`);\n    localStorage.removeItem('totvs-theme');\n  }\n\n  /**\n   * @docsPrivate\n   *\n   * Este método define um dados do tema e o armazena.\n   * @param theme Os tokens de tema contendo os estilos adicionais a serem gerados.\n   */\n  private setThemeActive(theme: PoTheme): void {\n    if (theme) {\n      localStorage.setItem('totvs-theme', JSON.stringify(theme));\n      this.theme = theme;\n    }\n  }\n\n  /**\n   * Retorna o tema ativo como um observable.\n   * @returns {PoTheme} Tema ativo.\n   */\n  getThemeActive(): PoTheme {\n    try {\n      const themeData = JSON.parse(localStorage.getItem('totvs-theme'));\n      if (themeData && JSON.stringify(themeData) !== JSON.stringify(this.theme)) {\n        this.theme = themeData;\n      }\n    } catch (error) {\n      console.error('Erro ao obter o tema do armazenamento local:', error);\n    }\n    return this.theme;\n  }\n\n  /**\n   * @docsPrivate\n   *\n   * Gera estilos CSS com base nos tokens de cores fornecidos.\n   * @param themeColor Os tokens de cor a serem usados para gerar os estilos.\n   * @returns Uma string contendo os estilos CSS gerados.\n   */\n  private createStyleElement(css: string): HTMLStyleElement {\n    const styleElement = this.renderer.createElement('style');\n    styleElement.id = 'pouiTheme';\n    this.renderer.appendChild(styleElement, this.renderer.createText(css));\n    return styleElement;\n  }\n\n  /**\n   * @docsPrivate\n   *\n   * Gera estilos CSS com base nos tokens de cores fornecidos.\n   * @param themeColor Os tokens de cor a serem usados para gerar os estilos.\n   * @returns Uma string contendo os estilos CSS gerados.\n   */\n  private generateThemeStyles(themeColor: PoThemeColor): string {\n    const selectBgIconStyle = this.getSelectBgIconsStyle(themeColor);\n\n    return [\n      Object.entries(themeColor)\n        .flatMap(([type, values]) =>\n          Object.entries(values).flatMap(([tonality, tonalityValues]) => {\n            if (type === 'action') {\n              return [`--color-${type}-${tonality}: ${tonalityValues};`];\n            } else {\n              return Object.entries(tonalityValues).map(\n                ([level, colorValue]) => `--color-${type}-${tonality}-${level}: ${colorValue};`\n              );\n            }\n          })\n        )\n        .join(''),\n      selectBgIconStyle\n    ].join('');\n  }\n\n  /**\n   * @docsPrivate\n   *\n   * Gera estilos CSS com base nos tokens per Component fornecidos.\n   * @param themePerComponent Os tokens de cor a serem usados para gerar os estilos.\n   * @returns Uma string contendo os estilos CSS gerados.\n   */\n  private generatePerComponentStyles(themePerComponent: any): string {\n    return Object.entries(themePerComponent)\n      .flatMap(([type, values]) =>\n        Object.entries(values).flatMap(([level, colorValue]) => [`${type} {${level}: ${colorValue};};`])\n      )\n      .join('');\n  }\n\n  /**\n   * Define o tema atual como o tema \"PoUI Padrão\".\n   *\n   * @param {PoThemeTypeEnum} type O tipo de Tema a ser aplicado, light / dark.\n   */\n  setDefaultTheme(type: PoThemeTypeEnum): void {\n    this.setTheme(poThemeDefault, type);\n  }\n\n  /**\n   * @docsPrivate\n   *\n   * Retorna o estilo CSS para o fundo dos ícones do componente po-select, com base nas cores do tema.\n   *\n   * @param {PoThemeColor} themeColor - Objeto contendo as cores do tema.\n   * @returns {string} - Estilo CSS para o fundo dos ícones do po-select.\n   */\n  private getSelectBgIconsStyle(themeColor: PoThemeColor): string {\n    let selectBgIcon = '';\n\n    if (themeColor?.brand?.['01']?.dark) {\n      const selector = this.iconNameLib === 'PhosphorIcon' ? 'po-select .po-select-phosphor' : 'po-select';\n      selectBgIcon += `${selector} { --background-image: url(${this.getSelectBgIcon(themeColor.brand['01'].dark)}); };`;\n    }\n\n    if (themeColor?.feedback?.negative?.base) {\n      if (this.iconNameLib === 'PoIcon') {\n        selectBgIcon += `po-select.ng-dirty.ng-invalid select { --background-image: url(${this.getSelectBgIcon(themeColor.feedback.negative.base)}); };`;\n      }\n\n      if (this.iconNameLib === 'PhosphorIcon') {\n        selectBgIcon += `po-select.ng-dirty.ng-invalid select.po-select-phosphor { background-image: url(${this.getSelectBgIcon(themeColor.feedback.negative.base)}); };`;\n      }\n    }\n\n    if (themeColor?.neutral?.light?.['30']) {\n      if (this.iconNameLib === 'PoIcon') {\n        selectBgIcon += `select:disabled { background-image: url(${this.getSelectBgIcon(themeColor.neutral.light['30'])}); };`;\n      }\n\n      if (this.iconNameLib === 'PhosphorIcon') {\n        selectBgIcon += `po-select select.po-select-phosphor:disabled { background-image: url(${this.getSelectBgIcon(themeColor.neutral.light['30'])}); };`;\n      }\n    }\n\n    return selectBgIcon;\n  }\n\n  /**\n   * @docsPrivate\n   *\n   * Retorna a imagem SVG utilizada como fundo do po-select.\n   *\n   * @param {string} color Cor da Imagem - Utilizada no atributo 'fill'.\n   * @returns {string} Imagem SVG utilizada no po-select.\n   */\n  private getSelectBgIcon(color: string): string {\n    let svg: string;\n\n    if (this.iconNameLib === 'PoIcon') {\n      svg = `\"data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' `;\n\n      svg = svg.concat(`xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' `);\n      svg = svg.concat(`d='M18.707 8.29301C18.316 7.90201 17.684 7.90201 17.293 8.29301L12 13.586L6.70701 `);\n      svg = svg.concat(`8.29301C6.31601 7.90201 5.68401 7.90201 5.29301 8.29301C4.90201 8.68401 4.90201 `);\n      svg = svg.concat(`9.31601 5.29301 9.70701L11.293 15.707C11.488 15.902 11.744 16 12 16C12.256 16 12.512 `);\n      svg = svg.concat(`15.902 12.707 15.707L18.707 9.70701C19.098 9.31601 19.098 8.68401 18.707 8.29301Z' `);\n      svg = svg.concat(`fill='${color.replace('#', '%23')}'/%3E%3C/svg%3E%0A\");`);\n\n      return svg;\n    }\n\n    svg = `\"data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 256 256' fill='${color.replace('#', '%23')}' `;\n    svg = svg.concat(`xmlns='http://www.w3.org/2000/svg'%3E%3Cpath `);\n    svg = svg.concat(\n      `d='M213.66,101.66l-80,80a8,8,0,0,1-11.32,0l-80-80A8,8,0,0,1,53.66,90.34L128,164.69l74.34-74.35a8,8,0,0,1,11.32,11.32Z'`\n    );\n    svg = svg.concat(`%3E%3C/path%3E%3C/svg%3E\");`);\n\n    return svg;\n  }\n}\n"]}
@@ -19094,6 +19094,15 @@ const poThemeDefault = {
19094
19094
  *
19095
19095
  * > Obs.: Não está documentado aqui e não indicamos a customização das cores de 'feedback' por motivos de acessibilidade e usabilidade.
19096
19096
  */
19097
+ /**
19098
+ * @example
19099
+ *
19100
+ * <example name="po-theme-labs" title="PO Theme Labs">
19101
+ * <file name="sample-po-theme-labs/sample-po-theme-labs.component.html"> </file>
19102
+ * <file name="sample-po-theme-labs/sample-po-theme-labs.component.ts"> </file>
19103
+ * </example>
19104
+ *
19105
+ */
19097
19106
  class PoThemeService {
19098
19107
  window;
19099
19108
  document;