ctt-babylon 0.1.235 → 0.1.236

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.
@@ -32,12 +32,14 @@ export class BabylonColorPickerComponent {
32
32
  });
33
33
  }
34
34
  ngOnInit() {
35
- const params = new URLSearchParams(window.location.search);
36
- this.mostrarPanel = params.has('activar_panel');
37
- const storedTab = this.colorService.getStoredTab(this.tabs);
38
- this.activeTab = storedTab;
39
- this.renderer.listen('window', 'mousemove', (e) => this.onDragMove(e));
40
- this.renderer.listen('window', 'mouseup', () => this.onDragEnd());
35
+ if (isPlatformBrowser(this.platformId)) {
36
+ const params = new URLSearchParams(window.location.search);
37
+ this.mostrarPanel = params.has('activar_panel');
38
+ const storedTab = this.colorService.getStoredTab(this.tabs);
39
+ this.activeTab = storedTab;
40
+ this.renderer.listen('window', 'mousemove', (e) => this.onDragMove(e));
41
+ this.renderer.listen('window', 'mouseup', () => this.onDragEnd());
42
+ }
41
43
  }
42
44
  async login() {
43
45
  if (isPlatformBrowser(this.platformId)) {
@@ -262,4 +264,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
262
264
  type: ViewChild,
263
265
  args: ['panel', { static: false }]
264
266
  }] } });
265
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"babylon-color-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/babylon/src/lib/components/core/babylon-color-picker/babylon-color-picker.component.ts","../../../../../../../projects/babylon/src/lib/components/core/babylon-color-picker/babylon-color-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, isPlatformBrowser } from '@angular/common';\nimport {\n    Component,\n    ElementRef,\n    Inject,\n    OnInit,\n    PLATFORM_ID,\n    Renderer2,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {\n    FormBuilder,\n    FormGroup,\n    FormsModule,\n    ReactiveFormsModule,\n} from '@angular/forms';\nimport { ColorPickerService } from '../../../services/color-panel.service';\n\n@Component({\n    selector: 'lib-babylon-color-picker',\n    standalone: true,\n    imports: [CommonModule, FormsModule, ReactiveFormsModule],\n    templateUrl: './babylon-color-picker.component.html',\n    styleUrls: ['./babylon-color-picker.component.scss'],\n    encapsulation: ViewEncapsulation.ShadowDom,\n})\nexport class BabylonColorPickerComponent implements OnInit {\n    userPanelInternal = '';\n    passPanelInternal = '';\n    @ViewChild('panel', { static: false }) panelRef!: ElementRef;\n\n    googleFontsApiKey = 'AIzaSyAVbzzOmAJfsAsi951e636ym-ABWy2BOMA';\n    mostrarPanel = false;\n    loginHecho = false;\n    minimizado = false;\n\n    loginForm: FormGroup;\n\n    tabs = ['Colores', 'Textos', 'Botones', 'Comunes', 'Otros'];\n    activeTab = 'Colores';\n\n    groupedVariables = new Map<string, { name: string; value: string }[]>();\n    copiedStatus = new Map<string, boolean>();\n    expandedGroups = new Set<string>();\n    fontValues: { [key: string]: string } = {};\n\n    isDragging = false;\n    dragStartX = 0;\n    dragStartY = 0;\n\n    constructor(\n        public colorService: ColorPickerService,\n        private renderer: Renderer2,\n        @Inject(PLATFORM_ID) private readonly platformId: Object,\n        private fb: FormBuilder\n    ) {\n        this.loginForm = this.fb.group({\n            email: [''],\n            password: [''],\n        });\n    }\n\n    ngOnInit(): void {\n        const params = new URLSearchParams(window.location.search);\n        this.mostrarPanel = params.has('activar_panel');\n\n        const storedTab = this.colorService.getStoredTab(this.tabs);\n        this.activeTab = storedTab;\n\n        this.renderer.listen('window', 'mousemove', (e) => this.onDragMove(e));\n        this.renderer.listen('window', 'mouseup', () => this.onDragEnd());\n    }\n\n    async login(): Promise<void> {\n        if (isPlatformBrowser(this.platformId)) {\n            const { email, password } = this.loginForm.value;\n            if (\n                email === this.userPanelInternal &&\n                password === this.passPanelInternal\n            ) {\n                this.loginHecho = true;\n                sessionStorage.setItem('panel-login-ok', 'true');\n                const variables = this.colorService.getAllCSSVariables();\n                this.groupedVariables =\n                    this.colorService.groupByCategory(variables);\n                await this.colorService.fetchGoogleFonts(\n                    this.googleFontsApiKey\n                );\n                this.setInitialFontValues();\n            } else {\n                alert('Usuario o contraseña incorrectos');\n            }\n        }\n    }\n\n    setInitialFontValues(): void {\n        const gruposFuente = [\n            'Títulos',\n            'Pretítulos',\n            'Subtítulos',\n            'Textos',\n            'Fuentes',\n            'Tipografías',\n        ];\n\n        if (isPlatformBrowser(this.platformId)) {\n            for (const [group, variables] of this.groupedVariables) {\n                if (gruposFuente.includes(group)) {\n                    for (const variable of variables) {\n                        const currentValue = getComputedStyle(\n                            document.documentElement\n                        )\n                            .getPropertyValue(variable.name)\n                            .trim();\n                        const fontName = this.getFontNameOnly(currentValue);\n                        this.fontValues[variable.name] = fontName;\n                    }\n                }\n            }\n        }\n    }\n\n    onDragStart(event: MouseEvent): void {\n        const target = event.target as HTMLElement;\n        const isInteractive = [\n            'INPUT',\n            'BUTTON',\n            'LABEL',\n            'SPAN',\n            'SELECT',\n        ].includes(target.tagName);\n        if (isInteractive || !this.panelRef) return;\n\n        this.isDragging = true;\n        this.dragStartX =\n            event.clientX - this.panelRef.nativeElement.offsetLeft;\n        this.dragStartY = event.clientY - this.panelRef.nativeElement.offsetTop;\n        event.preventDefault();\n    }\n\n    onDragMove(event: MouseEvent): void {\n        if (!this.isDragging || !this.panelRef) return;\n\n        const x = event.clientX - this.dragStartX;\n        const y = event.clientY - this.dragStartY;\n\n        const panel = this.panelRef.nativeElement;\n        panel.style.left = `${x}px`;\n        panel.style.top = `${y}px`;\n    }\n\n    onDragEnd(): void {\n        this.isDragging = false;\n    }\n\n    toggleGroup(group: string): void {\n        if (this.expandedGroups.has(group)) {\n            this.expandedGroups.delete(group);\n        } else {\n            this.expandedGroups.add(group);\n        }\n    }\n\n    isGroupExpanded(group: string): boolean {\n        return this.expandedGroups.has(group);\n    }\n\n    isColor(value: string): boolean {\n        return this.colorService.isColor(value);\n    }\n\n    changeColor(event: Event, variableName: string): void {\n        const input = event.target as HTMLInputElement | HTMLSelectElement;\n        const value = input?.value;\n        if (!value) return;\n\n        const isFontVariable =\n            variableName.startsWith('--font-') &&\n            !variableName.includes('--font-size');\n\n        if (isFontVariable) {\n            this.fontValues[variableName] = value;\n            const newFontValue = `'${value}', Helvetica, sans-serif`;\n            this.colorService.changeColor(\n                variableName,\n                newFontValue,\n                this.groupedVariables\n            );\n        } else {\n            this.colorService.changeColor(\n                variableName,\n                value,\n                this.groupedVariables\n            );\n        }\n    }\n\n    resetColors(): void {\n        this.colorService.resetColors(this.groupedVariables);\n    }\n\n    copyToClipboard(value: string, name: string): void {\n        this.colorService.copyToClipboard(value, name, this.copiedStatus);\n    }\n\n    wasCopied(variableName: string): boolean {\n        return this.copiedStatus.get(variableName) === true;\n    }\n\n    getTabForGroup(group: string): string {\n        return this.colorService.getTabForGroup(group);\n    }\n\n    setActiveTab(tab: string): void {\n        if (isPlatformBrowser(this.platformId)) {\n            this.activeTab = tab;\n            localStorage.setItem('panel-estilos-tab', tab);\n        }\n    }\n\n    toggleMinimizado() {\n        this.minimizado = !this.minimizado;\n    }\n\n    exportCSS(): void {\n        this.colorService.exportCustomVariables(this.groupedVariables);\n    }\n\n    getFontNameOnly(fullValue: string): string {\n        const match = fullValue.match(/^['\"]?([^'\",]+)['\"]?/);\n        return match ? match[1] : fullValue;\n    }\n\n    async updateFontVariable(\n        event: Event,\n        variableName: string\n    ): Promise<void> {\n        if (isPlatformBrowser(this.platformId)) {\n            const target = event.target as HTMLSelectElement | null;\n            const fontName = target?.value;\n            if (!fontName) return;\n\n            const value = `'${fontName}', Helvetica, sans-serif`;\n            this.colorService.changeColor(\n                variableName,\n                value,\n                this.groupedVariables\n            );\n            this.fontValues[variableName] = fontName;\n\n            const isGoogleFont =\n                this.colorService.googleFonts.includes(fontName);\n            if (!isGoogleFont) return; // ⛔ No insertar si no es Google Font\n\n            const formattedFont = fontName.replace(/ /g, '+');\n            const id = `font-${formattedFont}`;\n            if (document.getElementById(id)) return;\n\n            const link = document.createElement('link');\n            link.id = id;\n            link.rel = 'stylesheet';\n            link.href = `https://fonts.googleapis.com/css2?family=${formattedFont}&display=swap`;\n            link.onerror = () => link.remove();\n            document.head.appendChild(link);\n        }\n    }\n\n    getComputedColor(variableName: string): string {\n        if (isPlatformBrowser(this.platformId)) {\n            const raw = getComputedStyle(document.documentElement)\n                .getPropertyValue(variableName)\n                .trim();\n            const clean = raw.replace(/[\"']/g, '');\n\n            if (/^#([0-9a-fA-F]{3})$/.test(clean)) {\n                return (\n                    '#' +\n                    clean\n                        .slice(1)\n                        .split('')\n                        .map((c) => c + c)\n                        .join('')\n                );\n            }\n\n            return this.colorService.isColor(clean) ? clean : '#000000';\n        }\n        return '#000000';\n    }\n\n    getHexForColorInput(variableName: string): string {\n        if (isPlatformBrowser(this.platformId)) {\n            const color = getComputedStyle(document.documentElement)\n                .getPropertyValue(variableName)\n                .trim();\n\n            const el = document.createElement('div');\n            el.style.color = color;\n            document.body.appendChild(el);\n            const resolved = getComputedStyle(el).color;\n            document.body.removeChild(el);\n\n            const match = resolved.match(/\\d+/g);\n            if (!match || match.length < 3) return '#000000';\n\n            const [r, g, b] = match;\n            return (\n                '#' +\n                parseInt(r).toString(16).padStart(2, '0') +\n                parseInt(g).toString(16).padStart(2, '0') +\n                parseInt(b).toString(16).padStart(2, '0')\n            );\n        }\n        return '';\n    }\n\n    setCredentials(user: string, pass: string): void {\n        if (isPlatformBrowser(this.platformId)) {\n            this.userPanelInternal = user;\n            this.passPanelInternal = pass;\n\n            const params = new URLSearchParams(window.location.search);\n            this.mostrarPanel = params.has('activar_panel');\n\n            if (this.mostrarPanel) {\n                const storedSession = sessionStorage.getItem('panel-login-ok');\n                if (storedSession === 'true') {\n                    this.loginHecho = true;\n                    const variables = this.colorService.getAllCSSVariables();\n                    this.groupedVariables =\n                        this.colorService.groupByCategory(variables);\n                    this.colorService.fetchGoogleFonts(this.googleFontsApiKey);\n                    this.setInitialFontValues();\n                }\n            }\n        }\n    }\n}\n","<!-- Mostrar TODO solo si mostrarPanel es true -->\n@if (mostrarPanel) {\n\n  <!-- LOGIN PANEL -->\n  @if (!loginHecho) {\n    <form [formGroup]=\"loginForm\" (ngSubmit)=\"login()\">\n      <div class=\"login-panel\">\n        <h2>Panel de estilos</h2>\n        <input\n          type=\"text\"\n          placeholder=\"Usuario\"\n          formControlName=\"email\"\n          (keydown.enter)=\"login()\"\n        />\n        <input\n          type=\"password\"\n          placeholder=\"Contraseña\"\n          formControlName=\"password\"\n          (keydown.enter)=\"login()\"\n        />\n        <button type=\"submit\">Entrar</button>\n      </div>\n    </form>\n  } @else {\n    <!-- ESTILO PANEL -->\n    <div\n      #panel\n      class=\"color-picker-panel\"\n      [class.minimizado]=\"minimizado\"\n      (mousedown)=\"onDragStart($event)\"\n    >\n      <div class=\"drag-header\">\n        <h1>Panel de estilos</h1>\n        <button\n          class=\"minimize-btn\"\n          (click)=\"toggleMinimizado()\"\n          title=\"Minimizar/Restaurar panel\"\n        >\n          {{ minimizado ? '＋' : '－' }}\n        </button>\n      </div>\n\n      @if (!minimizado) {\n        <div class=\"tabs\">\n          @for (tab of tabs; track tab) {\n            <button\n              [class.active]=\"activeTab === tab\"\n              (click)=\"setActiveTab(tab)\"\n            >\n              {{ tab }}\n            </button>\n          }\n        </div>\n\n        <div class=\"reset-export-container\">\n          <button class=\"reset-button\" (click)=\"resetColors()\">Resetear estilos</button>\n          <button class=\"export-button\" (click)=\"exportCSS()\">Exportar CSS</button>\n        </div>\n\n        <div class=\"groups-wrapper\">\n          @for (group of groupedVariables | keyvalue; track group.key) {\n            @if (getTabForGroup(group.key) === activeTab) {\n              <div class=\"group-box\">\n                <div class=\"group-header\" (click)=\"toggleGroup(group.key)\">\n                  <h2>{{ group.key }}</h2>\n                  <span class=\"arrow\" [class.expanded]=\"isGroupExpanded(group.key)\">⌵</span>\n                </div>\n\n                @if (isGroupExpanded(group.key)) {\n                  <div class=\"group-content\">\n                    @for (variable of group.value; track variable.name) {\n                      <div class=\"color-picker-item\">\n                        <label>{{ variable.name.replace('--', '') }}</label>\n\n                        @if (isColor(variable.value)) {\n                          <input\n                            type=\"color\"\n                            [value]=\"getHexForColorInput(variable.name)\"\n                            (input)=\"changeColor($event, variable.name)\"\n                          />\n                        } @else {\n                          @if (['Títulos', 'Pretítulos', 'Subtítulos', 'Textos', 'Fuentes', 'Tipografías'].includes(group.key)) {\n                            <select\n                              [value]=\"fontValues[variable.name]\"\n                              (change)=\"updateFontVariable($event, variable.name)\"\n                            >\n                              <optgroup label=\"Fuentes del proyecto\">\n                                @for (font of colorService.projectFonts; track font) {\n                                  @if (!['font-title', 'font-pretitle', 'font-text', 'font-claim'].includes(font)) {\n                                    <option [value]=\"font\">{{ font }}</option>\n                                  }\n                                }\n                              </optgroup>\n\n                              <optgroup label=\"Google Fonts\">\n                                @for (font of colorService.googleFonts; track font) {\n                                  <option [value]=\"font\">{{ font }}</option>\n                                }\n                              </optgroup>\n                            </select>\n                          } @else {\n                            <input\n                              type=\"text\"\n                              [value]=\"variable.value\"\n                              (input)=\"changeColor($event, variable.name)\"\n                            />\n                          }\n                        }\n\n                        <div class=\"tooltip-container\">\n                          <button class=\"copy-btn\" (click)=\"copyToClipboard(variable.value, variable.name)\">\n                            📋\n                          </button>\n                          <span class=\"tooltip-text\">Copiar</span>\n                        </div>\n\n                        @if (wasCopied(variable.name)) {\n                          <span class=\"copied-msg\">Copiado ✔️</span>\n                        }\n                      </div>\n                    }\n                  </div>\n                }\n              </div>\n            }\n          }\n        </div>\n      }\n    </div>\n  }\n}\n"]}
267
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"babylon-color-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/babylon/src/lib/components/core/babylon-color-picker/babylon-color-picker.component.ts","../../../../../../../projects/babylon/src/lib/components/core/babylon-color-picker/babylon-color-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, isPlatformBrowser } from '@angular/common';\nimport {\n    Component,\n    ElementRef,\n    Inject,\n    OnInit,\n    PLATFORM_ID,\n    Renderer2,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {\n    FormBuilder,\n    FormGroup,\n    FormsModule,\n    ReactiveFormsModule,\n} from '@angular/forms';\nimport { ColorPickerService } from '../../../services/color-panel.service';\n\n@Component({\n    selector: 'lib-babylon-color-picker',\n    standalone: true,\n    imports: [CommonModule, FormsModule, ReactiveFormsModule],\n    templateUrl: './babylon-color-picker.component.html',\n    styleUrls: ['./babylon-color-picker.component.scss'],\n    encapsulation: ViewEncapsulation.ShadowDom,\n})\nexport class BabylonColorPickerComponent implements OnInit {\n    userPanelInternal = '';\n    passPanelInternal = '';\n    @ViewChild('panel', { static: false }) panelRef!: ElementRef;\n\n    googleFontsApiKey = 'AIzaSyAVbzzOmAJfsAsi951e636ym-ABWy2BOMA';\n    mostrarPanel = false;\n    loginHecho = false;\n    minimizado = false;\n\n    loginForm: FormGroup;\n\n    tabs = ['Colores', 'Textos', 'Botones', 'Comunes', 'Otros'];\n    activeTab = 'Colores';\n\n    groupedVariables = new Map<string, { name: string; value: string }[]>();\n    copiedStatus = new Map<string, boolean>();\n    expandedGroups = new Set<string>();\n    fontValues: { [key: string]: string } = {};\n\n    isDragging = false;\n    dragStartX = 0;\n    dragStartY = 0;\n\n    constructor(\n        public colorService: ColorPickerService,\n        private renderer: Renderer2,\n        @Inject(PLATFORM_ID) private readonly platformId: Object,\n        private fb: FormBuilder\n    ) {\n        this.loginForm = this.fb.group({\n            email: [''],\n            password: [''],\n        });\n    }\n\n    ngOnInit(): void {\n        if (isPlatformBrowser(this.platformId)) {\n            const params = new URLSearchParams(window.location.search);\n            this.mostrarPanel = params.has('activar_panel');\n\n            const storedTab = this.colorService.getStoredTab(this.tabs);\n            this.activeTab = storedTab;\n\n            this.renderer.listen('window', 'mousemove', (e) =>\n                this.onDragMove(e)\n            );\n            this.renderer.listen('window', 'mouseup', () => this.onDragEnd());\n        }\n    }\n\n    async login(): Promise<void> {\n        if (isPlatformBrowser(this.platformId)) {\n            const { email, password } = this.loginForm.value;\n            if (\n                email === this.userPanelInternal &&\n                password === this.passPanelInternal\n            ) {\n                this.loginHecho = true;\n                sessionStorage.setItem('panel-login-ok', 'true');\n                const variables = this.colorService.getAllCSSVariables();\n                this.groupedVariables =\n                    this.colorService.groupByCategory(variables);\n                await this.colorService.fetchGoogleFonts(\n                    this.googleFontsApiKey\n                );\n                this.setInitialFontValues();\n            } else {\n                alert('Usuario o contraseña incorrectos');\n            }\n        }\n    }\n\n    setInitialFontValues(): void {\n        const gruposFuente = [\n            'Títulos',\n            'Pretítulos',\n            'Subtítulos',\n            'Textos',\n            'Fuentes',\n            'Tipografías',\n        ];\n\n        if (isPlatformBrowser(this.platformId)) {\n            for (const [group, variables] of this.groupedVariables) {\n                if (gruposFuente.includes(group)) {\n                    for (const variable of variables) {\n                        const currentValue = getComputedStyle(\n                            document.documentElement\n                        )\n                            .getPropertyValue(variable.name)\n                            .trim();\n                        const fontName = this.getFontNameOnly(currentValue);\n                        this.fontValues[variable.name] = fontName;\n                    }\n                }\n            }\n        }\n    }\n\n    onDragStart(event: MouseEvent): void {\n        const target = event.target as HTMLElement;\n        const isInteractive = [\n            'INPUT',\n            'BUTTON',\n            'LABEL',\n            'SPAN',\n            'SELECT',\n        ].includes(target.tagName);\n        if (isInteractive || !this.panelRef) return;\n\n        this.isDragging = true;\n        this.dragStartX =\n            event.clientX - this.panelRef.nativeElement.offsetLeft;\n        this.dragStartY = event.clientY - this.panelRef.nativeElement.offsetTop;\n        event.preventDefault();\n    }\n\n    onDragMove(event: MouseEvent): void {\n        if (!this.isDragging || !this.panelRef) return;\n\n        const x = event.clientX - this.dragStartX;\n        const y = event.clientY - this.dragStartY;\n\n        const panel = this.panelRef.nativeElement;\n        panel.style.left = `${x}px`;\n        panel.style.top = `${y}px`;\n    }\n\n    onDragEnd(): void {\n        this.isDragging = false;\n    }\n\n    toggleGroup(group: string): void {\n        if (this.expandedGroups.has(group)) {\n            this.expandedGroups.delete(group);\n        } else {\n            this.expandedGroups.add(group);\n        }\n    }\n\n    isGroupExpanded(group: string): boolean {\n        return this.expandedGroups.has(group);\n    }\n\n    isColor(value: string): boolean {\n        return this.colorService.isColor(value);\n    }\n\n    changeColor(event: Event, variableName: string): void {\n        const input = event.target as HTMLInputElement | HTMLSelectElement;\n        const value = input?.value;\n        if (!value) return;\n\n        const isFontVariable =\n            variableName.startsWith('--font-') &&\n            !variableName.includes('--font-size');\n\n        if (isFontVariable) {\n            this.fontValues[variableName] = value;\n            const newFontValue = `'${value}', Helvetica, sans-serif`;\n            this.colorService.changeColor(\n                variableName,\n                newFontValue,\n                this.groupedVariables\n            );\n        } else {\n            this.colorService.changeColor(\n                variableName,\n                value,\n                this.groupedVariables\n            );\n        }\n    }\n\n    resetColors(): void {\n        this.colorService.resetColors(this.groupedVariables);\n    }\n\n    copyToClipboard(value: string, name: string): void {\n        this.colorService.copyToClipboard(value, name, this.copiedStatus);\n    }\n\n    wasCopied(variableName: string): boolean {\n        return this.copiedStatus.get(variableName) === true;\n    }\n\n    getTabForGroup(group: string): string {\n        return this.colorService.getTabForGroup(group);\n    }\n\n    setActiveTab(tab: string): void {\n        if (isPlatformBrowser(this.platformId)) {\n            this.activeTab = tab;\n            localStorage.setItem('panel-estilos-tab', tab);\n        }\n    }\n\n    toggleMinimizado() {\n        this.minimizado = !this.minimizado;\n    }\n\n    exportCSS(): void {\n        this.colorService.exportCustomVariables(this.groupedVariables);\n    }\n\n    getFontNameOnly(fullValue: string): string {\n        const match = fullValue.match(/^['\"]?([^'\",]+)['\"]?/);\n        return match ? match[1] : fullValue;\n    }\n\n    async updateFontVariable(\n        event: Event,\n        variableName: string\n    ): Promise<void> {\n        if (isPlatformBrowser(this.platformId)) {\n            const target = event.target as HTMLSelectElement | null;\n            const fontName = target?.value;\n            if (!fontName) return;\n\n            const value = `'${fontName}', Helvetica, sans-serif`;\n            this.colorService.changeColor(\n                variableName,\n                value,\n                this.groupedVariables\n            );\n            this.fontValues[variableName] = fontName;\n\n            const isGoogleFont =\n                this.colorService.googleFonts.includes(fontName);\n            if (!isGoogleFont) return; // ⛔ No insertar si no es Google Font\n\n            const formattedFont = fontName.replace(/ /g, '+');\n            const id = `font-${formattedFont}`;\n            if (document.getElementById(id)) return;\n\n            const link = document.createElement('link');\n            link.id = id;\n            link.rel = 'stylesheet';\n            link.href = `https://fonts.googleapis.com/css2?family=${formattedFont}&display=swap`;\n            link.onerror = () => link.remove();\n            document.head.appendChild(link);\n        }\n    }\n\n    getComputedColor(variableName: string): string {\n        if (isPlatformBrowser(this.platformId)) {\n            const raw = getComputedStyle(document.documentElement)\n                .getPropertyValue(variableName)\n                .trim();\n            const clean = raw.replace(/[\"']/g, '');\n\n            if (/^#([0-9a-fA-F]{3})$/.test(clean)) {\n                return (\n                    '#' +\n                    clean\n                        .slice(1)\n                        .split('')\n                        .map((c) => c + c)\n                        .join('')\n                );\n            }\n\n            return this.colorService.isColor(clean) ? clean : '#000000';\n        }\n        return '#000000';\n    }\n\n    getHexForColorInput(variableName: string): string {\n        if (isPlatformBrowser(this.platformId)) {\n            const color = getComputedStyle(document.documentElement)\n                .getPropertyValue(variableName)\n                .trim();\n\n            const el = document.createElement('div');\n            el.style.color = color;\n            document.body.appendChild(el);\n            const resolved = getComputedStyle(el).color;\n            document.body.removeChild(el);\n\n            const match = resolved.match(/\\d+/g);\n            if (!match || match.length < 3) return '#000000';\n\n            const [r, g, b] = match;\n            return (\n                '#' +\n                parseInt(r).toString(16).padStart(2, '0') +\n                parseInt(g).toString(16).padStart(2, '0') +\n                parseInt(b).toString(16).padStart(2, '0')\n            );\n        }\n        return '';\n    }\n\n    setCredentials(user: string, pass: string): void {\n        if (isPlatformBrowser(this.platformId)) {\n            this.userPanelInternal = user;\n            this.passPanelInternal = pass;\n\n            const params = new URLSearchParams(window.location.search);\n            this.mostrarPanel = params.has('activar_panel');\n\n            if (this.mostrarPanel) {\n                const storedSession = sessionStorage.getItem('panel-login-ok');\n                if (storedSession === 'true') {\n                    this.loginHecho = true;\n                    const variables = this.colorService.getAllCSSVariables();\n                    this.groupedVariables =\n                        this.colorService.groupByCategory(variables);\n                    this.colorService.fetchGoogleFonts(this.googleFontsApiKey);\n                    this.setInitialFontValues();\n                }\n            }\n        }\n    }\n}\n","<!-- Mostrar TODO solo si mostrarPanel es true -->\n@if (mostrarPanel) {\n\n  <!-- LOGIN PANEL -->\n  @if (!loginHecho) {\n    <form [formGroup]=\"loginForm\" (ngSubmit)=\"login()\">\n      <div class=\"login-panel\">\n        <h2>Panel de estilos</h2>\n        <input\n          type=\"text\"\n          placeholder=\"Usuario\"\n          formControlName=\"email\"\n          (keydown.enter)=\"login()\"\n        />\n        <input\n          type=\"password\"\n          placeholder=\"Contraseña\"\n          formControlName=\"password\"\n          (keydown.enter)=\"login()\"\n        />\n        <button type=\"submit\">Entrar</button>\n      </div>\n    </form>\n  } @else {\n    <!-- ESTILO PANEL -->\n    <div\n      #panel\n      class=\"color-picker-panel\"\n      [class.minimizado]=\"minimizado\"\n      (mousedown)=\"onDragStart($event)\"\n    >\n      <div class=\"drag-header\">\n        <h1>Panel de estilos</h1>\n        <button\n          class=\"minimize-btn\"\n          (click)=\"toggleMinimizado()\"\n          title=\"Minimizar/Restaurar panel\"\n        >\n          {{ minimizado ? '＋' : '－' }}\n        </button>\n      </div>\n\n      @if (!minimizado) {\n        <div class=\"tabs\">\n          @for (tab of tabs; track tab) {\n            <button\n              [class.active]=\"activeTab === tab\"\n              (click)=\"setActiveTab(tab)\"\n            >\n              {{ tab }}\n            </button>\n          }\n        </div>\n\n        <div class=\"reset-export-container\">\n          <button class=\"reset-button\" (click)=\"resetColors()\">Resetear estilos</button>\n          <button class=\"export-button\" (click)=\"exportCSS()\">Exportar CSS</button>\n        </div>\n\n        <div class=\"groups-wrapper\">\n          @for (group of groupedVariables | keyvalue; track group.key) {\n            @if (getTabForGroup(group.key) === activeTab) {\n              <div class=\"group-box\">\n                <div class=\"group-header\" (click)=\"toggleGroup(group.key)\">\n                  <h2>{{ group.key }}</h2>\n                  <span class=\"arrow\" [class.expanded]=\"isGroupExpanded(group.key)\">⌵</span>\n                </div>\n\n                @if (isGroupExpanded(group.key)) {\n                  <div class=\"group-content\">\n                    @for (variable of group.value; track variable.name) {\n                      <div class=\"color-picker-item\">\n                        <label>{{ variable.name.replace('--', '') }}</label>\n\n                        @if (isColor(variable.value)) {\n                          <input\n                            type=\"color\"\n                            [value]=\"getHexForColorInput(variable.name)\"\n                            (input)=\"changeColor($event, variable.name)\"\n                          />\n                        } @else {\n                          @if (['Títulos', 'Pretítulos', 'Subtítulos', 'Textos', 'Fuentes', 'Tipografías'].includes(group.key)) {\n                            <select\n                              [value]=\"fontValues[variable.name]\"\n                              (change)=\"updateFontVariable($event, variable.name)\"\n                            >\n                              <optgroup label=\"Fuentes del proyecto\">\n                                @for (font of colorService.projectFonts; track font) {\n                                  @if (!['font-title', 'font-pretitle', 'font-text', 'font-claim'].includes(font)) {\n                                    <option [value]=\"font\">{{ font }}</option>\n                                  }\n                                }\n                              </optgroup>\n\n                              <optgroup label=\"Google Fonts\">\n                                @for (font of colorService.googleFonts; track font) {\n                                  <option [value]=\"font\">{{ font }}</option>\n                                }\n                              </optgroup>\n                            </select>\n                          } @else {\n                            <input\n                              type=\"text\"\n                              [value]=\"variable.value\"\n                              (input)=\"changeColor($event, variable.name)\"\n                            />\n                          }\n                        }\n\n                        <div class=\"tooltip-container\">\n                          <button class=\"copy-btn\" (click)=\"copyToClipboard(variable.value, variable.name)\">\n                            📋\n                          </button>\n                          <span class=\"tooltip-text\">Copiar</span>\n                        </div>\n\n                        @if (wasCopied(variable.name)) {\n                          <span class=\"copied-msg\">Copiado ✔️</span>\n                        }\n                      </div>\n                    }\n                  </div>\n                }\n              </div>\n            }\n          }\n        </div>\n      }\n    </div>\n  }\n}\n"]}
@@ -20,14 +20,20 @@ export class BabylonHeaderBookShowComponent {
20
20
  this.platformId = inject(PLATFORM_ID);
21
21
  }
22
22
  ngOnInit() {
23
- this.checkScreen();
24
- window.addEventListener('resize', this.checkScreen.bind(this));
23
+ if (isPlatformBrowser(this.platformId)) {
24
+ this.checkScreen();
25
+ window.addEventListener('resize', this.checkScreen.bind(this));
26
+ }
25
27
  }
26
28
  ngOnDestroy() {
27
- window.removeEventListener('resize', this.checkScreen.bind(this));
29
+ if (isPlatformBrowser(this.platformId)) {
30
+ window.removeEventListener('resize', this.checkScreen.bind(this));
31
+ }
28
32
  }
29
33
  checkScreen() {
30
- this.showBtnBook.set(window.innerWidth <= this.screenBreakpoint);
34
+ if (isPlatformBrowser(this.platformId)) {
35
+ this.showBtnBook.set(window.innerWidth <= this.screenBreakpoint);
36
+ }
31
37
  }
32
38
  preventLink(linkType) {
33
39
  if (linkType.includes('internal')) {
@@ -113,4 +119,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
113
119
  }], modalClick: [{
114
120
  type: Output
115
121
  }] } });
116
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"babylon-header-book-show.component.js","sourceRoot":"","sources":["../../../../../../../projects/babylon/src/lib/components/core/babylon-header-book-show/babylon-header-book-show.component.ts","../../../../../../../projects/babylon/src/lib/components/core/babylon-header-book-show/babylon-header-book-show.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, isPlatformBrowser } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    PLATFORM_ID,\n    signal,\n} from '@angular/core';\nimport { RouterModule } from '@angular/router';\nimport { BabylonLinkTypeDirective } from '../../../directives/link-type/link-type.directive';\nimport { LogoType } from '../../../Enum/logo-type.enum';\nimport { BabylonButtonI } from '../../../interfaces/babylon-button.interface';\nimport { BabylonImageI } from '../../../interfaces/babylon-image.interface';\nimport { BabylonMenuButtonI } from '../../../interfaces/babylon-menu-button.interface';\nimport { BabylonMenuInfoI } from '../../../interfaces/babylon-menu-info.interface';\nimport { ScreenSizerService } from '../../../services';\nimport { BabylonModalMenuComponent } from '../babylon-modal-menu/babylon-modal-menu.component';\n\n@Component({\n    selector: 'lib-babylon-header-book-show',\n    standalone: true,\n    imports: [\n        CommonModule,\n        RouterModule,\n        BabylonLinkTypeDirective,\n        BabylonModalMenuComponent,\n    ],\n    templateUrl: './babylon-header-book-show.component.html',\n    styleUrl: './babylon-header-book-show.component.scss',\n    providers: [BabylonLinkTypeDirective],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BabylonHeaderBookShowComponent implements OnInit, OnDestroy {\n    @Input() headerFixed: boolean = false;\n    @Input() logos?: Record<LogoType, BabylonImageI | undefined>;\n    @Input() linkLogo?: BabylonButtonI;\n    @Input() menu?: BabylonMenuButtonI[];\n    @Input() menuInfo?: BabylonMenuInfoI;\n    @Input() btnBook?: BabylonButtonI;\n    @Input() lang?: string;\n    @Input() title?: string;\n    @Input() ndTitle?: string;\n    @Input() headerInMenu?: boolean = false;\n\n    @Input() screenBreakpoint: number = 1279;\n\n    @Output() openEngine = new EventEmitter();\n    @Output() openLanguages = new EventEmitter();\n    @Output() openNews = new EventEmitter();\n    @Output() modalClick = new EventEmitter<string>();\n\n    showBtnBook = signal(false);\n\n    private platformId = inject(PLATFORM_ID);\n\n    constructor(private readonly screenSizer: ScreenSizerService) {}\n\n    ngOnInit(): void {\n        this.checkScreen();\n        window.addEventListener('resize', this.checkScreen.bind(this));\n    }\n\n    ngOnDestroy(): void {\n        window.removeEventListener('resize', this.checkScreen.bind(this));\n    }\n\n    checkScreen(): void {\n        this.showBtnBook.set(window.innerWidth <= this.screenBreakpoint);\n    }\n\n    preventLink(linkType: string): void {\n        if (linkType.includes('internal')) {\n            this.toggleMenu();\n        }\n    }\n\n    toggleMenu(): void {\n        if (isPlatformBrowser(this.platformId)) {\n            const hamburger = document.querySelector('.hamburger');\n            const panelMenu = document.querySelector('.panel_menu');\n            const body = document.body;\n            const header = document.querySelector('header');\n\n            if (hamburger) {\n                hamburger.classList.toggle('is-active');\n            }\n            if (panelMenu) {\n                panelMenu.classList.toggle('active');\n            }\n            if (body) {\n                body.classList.toggle('no_scroll');\n            }\n            if (header) {\n                header.classList.toggle('header_color');\n            }\n        }\n    }\n\n    openLanguagesModal(): void {\n        this.openLanguages.emit();\n    }\n\n    openEngineModal(): void {\n        this.openEngine.emit();\n    }\n\n    openNewsletter(): void {\n        this.openNews.emit();\n    }\n\n    onAnchorClicked(): void {\n        if (isPlatformBrowser(this.platformId)) {\n            const panelMenu = document.querySelector('.panel_menu');\n            if (panelMenu && panelMenu.classList.contains('active')) {\n                this.toggleMenu();\n            }\n        }\n    }\n}\n","<div class=\"babylon-header cs-header-component fixed_header\">\n    <header\n        class=\"cs_site_header cs_style_1 cs_transparent_header cs_primary_color cs_sticky_header fixed_header\"\n        [ngClass]=\"{ cs_gescout_sticky: headerFixed }\"\n    >\n        <div class=\"cs_main_header\" id=\"headerBookShow\">\n            <div class=\"container-fluid cs_plr_100\">\n                <div class=\"cs_main_header_in\">\n                    @if (logos?.logoDesktop) {\n                        <div class=\"cs_main_header_left\">\n                            <a\n                                [attr.aria-label]=\"linkLogo?.url\"\n                                class=\"cs_site_branding\"\n                                [href]=\"linkLogo?.url\"\n                                [linkType]=\"linkLogo?.linkType\"\n                            >\n                                <img\n                                    [src]=\"logos?.logoDesktop?.src\"\n                                    width=\"240\"\n                                    height=\"60\"\n                                    [alt]=\"logos?.logoDesktop?.alt\"\n                                    loading=\"lazy\"\n                                />\n                            </a>\n                        </div>\n                    }\n                    @if (logos?.logo) {\n                        <div class=\"cs_main_header_left_sticky\">\n                            <a\n                                [attr.aria-label]=\"linkLogo?.url\"\n                                class=\"cs_site_branding\"\n                                [href]=\"linkLogo?.url\"\n                                [linkType]=\"linkLogo?.linkType\"\n                            >\n                                <img\n                                    [src]=\"logos?.logo?.src\"\n                                    width=\"240\"\n                                    height=\"60\"\n                                    [alt]=\"logos?.logo?.alt\"\n                                    loading=\"lazy\"\n                                />\n                            </a>\n                        </div>\n                    }\n                    @if (menu) {\n                        <div class=\"cs_main_header_center babylon__header__box\">\n                            <nav\n                                class=\"cs_nav cs_fs_13 cs_semibold cs_menu_item_global\"\n                            >\n                                @if (menu.length) {\n                                    <ul class=\"cs_nav_list\">\n                                        @for (link of menu; track $index) {\n                                            <li\n                                                [ngClass]=\"{\n                                                    'menu-item-has-children':\n                                                        link.children?.length,\n                                                }\"\n                                            >\n                                                <a\n                                                    [attr.aria-label]=\"\n                                                        link.label\n                                                    \"\n                                                    [linkType]=\"link.linkType\"\n                                                    [href]=\"link.url\"\n                                                    (anchorClicked)=\"\n                                                        onAnchorClicked()\n                                                    \"\n                                                >\n                                                    {{ link.label }}\n                                                </a>\n                                                @if (link.children?.length) {\n                                                    <ul>\n                                                        @for (\n                                                            item of link.children;\n                                                            track $index\n                                                        ) {\n                                                            <li>\n                                                                <a\n                                                                    [attr.aria-label]=\"\n                                                                        item.label\n                                                                    \"\n                                                                    [linkType]=\"\n                                                                        item.linkType\n                                                                    \"\n                                                                    [href]=\"\n                                                                        item.url\n                                                                    \"\n                                                                    (anchorClicked)=\"\n                                                                        onAnchorClicked()\n                                                                    \"\n                                                                >\n                                                                    {{\n                                                                        item.label\n                                                                    }}\n                                                                </a>\n                                                            </li>\n                                                        }\n                                                    </ul>\n                                                }\n                                            </li>\n                                        }\n                                    </ul>\n                                }\n                            </nav>\n                        </div>\n                    }\n                    <div class=\"cs_main_header_right\">\n                        @if (btnBook && showBtnBook()) {\n                            <button\n                                [name]=\"btnBook.label\"\n                                class=\"btn btn_call btn--light1\"\n                                (click)=\"openEngineModal()\"\n                                id=\"btn-book\"\n                            >\n                                <b>{{ btnBook.label }} </b>\n                            </button>\n                        }\n\n                        @if (lang) {\n                            <button\n                                [name]=\"lang\"\n                                class=\"btn btn_primary btn--light ml--20 btn-lang\"\n                                id=\"btn-lang\"\n                                (click)=\"openLanguagesModal()\"\n                            >\n                                <b>{{ lang }}</b>\n                            </button>\n                        }\n\n                        <button\n                            name=\"hamburguer\"\n                            class=\"cs_hamburger_btn ml--20\"\n                            aria-label=\"menu\"\n                            (click)=\"toggleMenu()\"\n                        >\n                            <span class=\"cs_hamburger_btn_in\">\n                                <span></span>\n                                <span></span>\n                                <span></span>\n                                <span></span>\n                            </span>\n                        </button>\n                    </div>\n                </div>\n            </div>\n        </div>\n    </header>\n\n    @if (menuInfo && menu) {\n      <section class=\"babylon__menu\">\n            <lib-babylon-modal-menu\n                class=\"panel_menu\"\n                [menu]=\"menu\"\n                [address]=\"menuInfo.address\"\n                [addressTitle]=\"menuInfo.address?.title\"\n                [contact]=\"menuInfo.contact?.links\"\n                [contactTitle]=\"menuInfo.contact?.title\"\n                [socialMedia]=\"menuInfo.socialMedia\"\n                [img]=\"menuInfo.img\"\n                [linkLogo]=\"linkLogo\"\n                [logo]=\"logos?.logoMenu\"\n                (anchorClicked)=\"onAnchorClicked()\"\n                [modalEvent]=\"modalClick\"\n                [imgBackground]=\"menuInfo.imgBackground\"\n                [tags]=\"menuInfo.tags\"\n                [textColors]=\"menuInfo.textColors\"\n            ></lib-babylon-modal-menu>\n        </section>\n    }\n</div>\n"]}
122
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"babylon-header-book-show.component.js","sourceRoot":"","sources":["../../../../../../../projects/babylon/src/lib/components/core/babylon-header-book-show/babylon-header-book-show.component.ts","../../../../../../../projects/babylon/src/lib/components/core/babylon-header-book-show/babylon-header-book-show.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, isPlatformBrowser } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    PLATFORM_ID,\n    signal,\n} from '@angular/core';\nimport { RouterModule } from '@angular/router';\nimport { BabylonLinkTypeDirective } from '../../../directives/link-type/link-type.directive';\nimport { LogoType } from '../../../Enum/logo-type.enum';\nimport { BabylonButtonI } from '../../../interfaces/babylon-button.interface';\nimport { BabylonImageI } from '../../../interfaces/babylon-image.interface';\nimport { BabylonMenuButtonI } from '../../../interfaces/babylon-menu-button.interface';\nimport { BabylonMenuInfoI } from '../../../interfaces/babylon-menu-info.interface';\nimport { ScreenSizerService } from '../../../services';\nimport { BabylonModalMenuComponent } from '../babylon-modal-menu/babylon-modal-menu.component';\n\n@Component({\n    selector: 'lib-babylon-header-book-show',\n    standalone: true,\n    imports: [\n        CommonModule,\n        RouterModule,\n        BabylonLinkTypeDirective,\n        BabylonModalMenuComponent,\n    ],\n    templateUrl: './babylon-header-book-show.component.html',\n    styleUrl: './babylon-header-book-show.component.scss',\n    providers: [BabylonLinkTypeDirective],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BabylonHeaderBookShowComponent implements OnInit, OnDestroy {\n    @Input() headerFixed: boolean = false;\n    @Input() logos?: Record<LogoType, BabylonImageI | undefined>;\n    @Input() linkLogo?: BabylonButtonI;\n    @Input() menu?: BabylonMenuButtonI[];\n    @Input() menuInfo?: BabylonMenuInfoI;\n    @Input() btnBook?: BabylonButtonI;\n    @Input() lang?: string;\n    @Input() title?: string;\n    @Input() ndTitle?: string;\n    @Input() headerInMenu?: boolean = false;\n\n    @Input() screenBreakpoint: number = 1279;\n\n    @Output() openEngine = new EventEmitter();\n    @Output() openLanguages = new EventEmitter();\n    @Output() openNews = new EventEmitter();\n    @Output() modalClick = new EventEmitter<string>();\n\n    showBtnBook = signal(false);\n\n    private platformId = inject(PLATFORM_ID);\n\n    constructor(private readonly screenSizer: ScreenSizerService) {}\n\n    ngOnInit(): void {\n        if (isPlatformBrowser(this.platformId)) {\n            this.checkScreen();\n            window.addEventListener('resize', this.checkScreen.bind(this));\n        }\n    }\n\n    ngOnDestroy(): void {\n        if (isPlatformBrowser(this.platformId)) {\n            window.removeEventListener('resize', this.checkScreen.bind(this));\n        }\n    }\n\n    checkScreen(): void {\n        if (isPlatformBrowser(this.platformId)) {\n            this.showBtnBook.set(window.innerWidth <= this.screenBreakpoint);\n        }\n    }\n\n    preventLink(linkType: string): void {\n        if (linkType.includes('internal')) {\n            this.toggleMenu();\n        }\n    }\n\n    toggleMenu(): void {\n        if (isPlatformBrowser(this.platformId)) {\n            const hamburger = document.querySelector('.hamburger');\n            const panelMenu = document.querySelector('.panel_menu');\n            const body = document.body;\n            const header = document.querySelector('header');\n\n            if (hamburger) {\n                hamburger.classList.toggle('is-active');\n            }\n            if (panelMenu) {\n                panelMenu.classList.toggle('active');\n            }\n            if (body) {\n                body.classList.toggle('no_scroll');\n            }\n            if (header) {\n                header.classList.toggle('header_color');\n            }\n        }\n    }\n\n    openLanguagesModal(): void {\n        this.openLanguages.emit();\n    }\n\n    openEngineModal(): void {\n        this.openEngine.emit();\n    }\n\n    openNewsletter(): void {\n        this.openNews.emit();\n    }\n\n    onAnchorClicked(): void {\n        if (isPlatformBrowser(this.platformId)) {\n            const panelMenu = document.querySelector('.panel_menu');\n            if (panelMenu && panelMenu.classList.contains('active')) {\n                this.toggleMenu();\n            }\n        }\n    }\n}\n","<div class=\"babylon-header cs-header-component fixed_header\">\n    <header\n        class=\"cs_site_header cs_style_1 cs_transparent_header cs_primary_color cs_sticky_header fixed_header\"\n        [ngClass]=\"{ cs_gescout_sticky: headerFixed }\"\n    >\n        <div class=\"cs_main_header\" id=\"headerBookShow\">\n            <div class=\"container-fluid cs_plr_100\">\n                <div class=\"cs_main_header_in\">\n                    @if (logos?.logoDesktop) {\n                        <div class=\"cs_main_header_left\">\n                            <a\n                                [attr.aria-label]=\"linkLogo?.url\"\n                                class=\"cs_site_branding\"\n                                [href]=\"linkLogo?.url\"\n                                [linkType]=\"linkLogo?.linkType\"\n                            >\n                                <img\n                                    [src]=\"logos?.logoDesktop?.src\"\n                                    width=\"240\"\n                                    height=\"60\"\n                                    [alt]=\"logos?.logoDesktop?.alt\"\n                                    loading=\"lazy\"\n                                />\n                            </a>\n                        </div>\n                    }\n                    @if (logos?.logo) {\n                        <div class=\"cs_main_header_left_sticky\">\n                            <a\n                                [attr.aria-label]=\"linkLogo?.url\"\n                                class=\"cs_site_branding\"\n                                [href]=\"linkLogo?.url\"\n                                [linkType]=\"linkLogo?.linkType\"\n                            >\n                                <img\n                                    [src]=\"logos?.logo?.src\"\n                                    width=\"240\"\n                                    height=\"60\"\n                                    [alt]=\"logos?.logo?.alt\"\n                                    loading=\"lazy\"\n                                />\n                            </a>\n                        </div>\n                    }\n                    @if (menu) {\n                        <div class=\"cs_main_header_center babylon__header__box\">\n                            <nav\n                                class=\"cs_nav cs_fs_13 cs_semibold cs_menu_item_global\"\n                            >\n                                @if (menu.length) {\n                                    <ul class=\"cs_nav_list\">\n                                        @for (link of menu; track $index) {\n                                            <li\n                                                [ngClass]=\"{\n                                                    'menu-item-has-children':\n                                                        link.children?.length,\n                                                }\"\n                                            >\n                                                <a\n                                                    [attr.aria-label]=\"\n                                                        link.label\n                                                    \"\n                                                    [linkType]=\"link.linkType\"\n                                                    [href]=\"link.url\"\n                                                    (anchorClicked)=\"\n                                                        onAnchorClicked()\n                                                    \"\n                                                >\n                                                    {{ link.label }}\n                                                </a>\n                                                @if (link.children?.length) {\n                                                    <ul>\n                                                        @for (\n                                                            item of link.children;\n                                                            track $index\n                                                        ) {\n                                                            <li>\n                                                                <a\n                                                                    [attr.aria-label]=\"\n                                                                        item.label\n                                                                    \"\n                                                                    [linkType]=\"\n                                                                        item.linkType\n                                                                    \"\n                                                                    [href]=\"\n                                                                        item.url\n                                                                    \"\n                                                                    (anchorClicked)=\"\n                                                                        onAnchorClicked()\n                                                                    \"\n                                                                >\n                                                                    {{\n                                                                        item.label\n                                                                    }}\n                                                                </a>\n                                                            </li>\n                                                        }\n                                                    </ul>\n                                                }\n                                            </li>\n                                        }\n                                    </ul>\n                                }\n                            </nav>\n                        </div>\n                    }\n                    <div class=\"cs_main_header_right\">\n                        @if (btnBook && showBtnBook()) {\n                            <button\n                                [name]=\"btnBook.label\"\n                                class=\"btn btn_call btn--light1\"\n                                (click)=\"openEngineModal()\"\n                                id=\"btn-book\"\n                            >\n                                <b>{{ btnBook.label }} </b>\n                            </button>\n                        }\n\n                        @if (lang) {\n                            <button\n                                [name]=\"lang\"\n                                class=\"btn btn_primary btn--light ml--20 btn-lang\"\n                                id=\"btn-lang\"\n                                (click)=\"openLanguagesModal()\"\n                            >\n                                <b>{{ lang }}</b>\n                            </button>\n                        }\n\n                        <button\n                            name=\"hamburguer\"\n                            class=\"cs_hamburger_btn ml--20\"\n                            aria-label=\"menu\"\n                            (click)=\"toggleMenu()\"\n                        >\n                            <span class=\"cs_hamburger_btn_in\">\n                                <span></span>\n                                <span></span>\n                                <span></span>\n                                <span></span>\n                            </span>\n                        </button>\n                    </div>\n                </div>\n            </div>\n        </div>\n    </header>\n\n    @if (menuInfo && menu) {\n      <section class=\"babylon__menu\">\n            <lib-babylon-modal-menu\n                class=\"panel_menu\"\n                [menu]=\"menu\"\n                [address]=\"menuInfo.address\"\n                [addressTitle]=\"menuInfo.address?.title\"\n                [contact]=\"menuInfo.contact?.links\"\n                [contactTitle]=\"menuInfo.contact?.title\"\n                [socialMedia]=\"menuInfo.socialMedia\"\n                [img]=\"menuInfo.img\"\n                [linkLogo]=\"linkLogo\"\n                [logo]=\"logos?.logoMenu\"\n                (anchorClicked)=\"onAnchorClicked()\"\n                [modalEvent]=\"modalClick\"\n                [imgBackground]=\"menuInfo.imgBackground\"\n                [tags]=\"menuInfo.tags\"\n                [textColors]=\"menuInfo.textColors\"\n            ></lib-babylon-modal-menu>\n        </section>\n    }\n</div>\n"]}
@@ -1,5 +1,5 @@
1
- import { CommonModule } from '@angular/common';
2
- import { ChangeDetectionStrategy, Component, Input, HostListener, } from '@angular/core';
1
+ import { CommonModule, isPlatformBrowser } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, HostListener, inject, Input, PLATFORM_ID, } from '@angular/core';
3
3
  import { BabylonLinkTypeDirective } from '../../../directives/link-type/link-type.directive';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/common";
@@ -7,6 +7,7 @@ export class BabylonSubmenuHotelComponent {
7
7
  constructor() {
8
8
  this.headerFixed = false;
9
9
  this.isDropdownOpen = false;
10
+ this.platformId = inject(PLATFORM_ID);
10
11
  }
11
12
  ngOnInit() {
12
13
  this.checkScroll();
@@ -15,8 +16,10 @@ export class BabylonSubmenuHotelComponent {
15
16
  this.checkScroll();
16
17
  }
17
18
  checkScroll() {
18
- const scrollPosition = window.scrollY;
19
- this.headerFixed = scrollPosition > 100;
19
+ if (isPlatformBrowser(this.platformId)) {
20
+ const scrollPosition = window.scrollY;
21
+ this.headerFixed = scrollPosition > 100;
22
+ }
20
23
  }
21
24
  toggleDropdown() {
22
25
  this.isDropdownOpen = !this.isDropdownOpen;
@@ -35,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
35
38
  type: HostListener,
36
39
  args: ['window:scroll', []]
37
40
  }] } });
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFieWxvbi1zdWJtZW51LWhvdGVsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhYnlsb24vc3JjL2xpYi9jb21wb25lbnRzL2NvcmUvYmFieWxvbi1zdWJtZW51LWhvdGVsL2JhYnlsb24tc3VibWVudS1ob3RlbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYWJ5bG9uL3NyYy9saWIvY29tcG9uZW50cy9jb3JlL2JhYnlsb24tc3VibWVudS1ob3RlbC9iYWJ5bG9uLXN1Ym1lbnUtaG90ZWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFDSCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULEtBQUssRUFFTCxZQUFZLEdBQ2YsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sbURBQW1ELENBQUM7OztBQVU3RixNQUFNLE9BQU8sNEJBQTRCO0lBUnpDO1FBWUksZ0JBQVcsR0FBRyxLQUFLLENBQUM7UUFDcEIsbUJBQWMsR0FBRyxLQUFLLENBQUM7S0FtQjFCO0lBakJHLFFBQVE7UUFDSixJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDdkIsQ0FBQztJQUdELGNBQWM7UUFDVixJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDdkIsQ0FBQztJQUVPLFdBQVc7UUFDZixNQUFNLGNBQWMsR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxXQUFXLEdBQUcsY0FBYyxHQUFHLEdBQUcsQ0FBQztJQUM1QyxDQUFDO0lBRUQsY0FBYztRQUNWLElBQUksQ0FBQyxjQUFjLEdBQUcsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDO0lBQy9DLENBQUM7K0dBdkJRLDRCQUE0QjttR0FBNUIsNEJBQTRCLHFNQ25CekMsMi9DQTRDQSw4MjBCRDlCYyxZQUFZLDZIQUFFLHdCQUF3Qjs7NEZBS3ZDLDRCQUE0QjtrQkFSeEMsU0FBUzsrQkFDSSwyQkFBMkIsY0FDekIsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLHdCQUF3QixDQUFDLG1CQUdoQyx1QkFBdUIsQ0FBQyxNQUFNOzhCQUd0QyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFVTixjQUFjO3NCQURiLFlBQVk7dUJBQUMsZUFBZSxFQUFFLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgICBDb21wb25lbnQsXG4gICAgSW5wdXQsXG4gICAgT25Jbml0LFxuICAgIEhvc3RMaXN0ZW5lcixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCYWJ5bG9uQnV0dG9uSSB9IGZyb20gJy4uLy4uLy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgQmFieWxvbkxpbmtUeXBlRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vLi4vZGlyZWN0aXZlcy9saW5rLXR5cGUvbGluay10eXBlLmRpcmVjdGl2ZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbGliLWJhYnlsb24tc3VibWVudS1ob3RlbCcsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBCYWJ5bG9uTGlua1R5cGVEaXJlY3RpdmVdLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9iYWJ5bG9uLXN1Ym1lbnUtaG90ZWwuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsOiAnLi9iYWJ5bG9uLXN1Ym1lbnUtaG90ZWwuY29tcG9uZW50LnNjc3MnLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBCYWJ5bG9uU3VibWVudUhvdGVsQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBASW5wdXQoKSBpdGVtcz86IEJhYnlsb25CdXR0b25JW107XG4gICAgQElucHV0KCkgc2VsZWN0ZWQ/OiBCYWJ5bG9uQnV0dG9uSTtcblxuICAgIGhlYWRlckZpeGVkID0gZmFsc2U7XG4gICAgaXNEcm9wZG93bk9wZW4gPSBmYWxzZTtcblxuICAgIG5nT25Jbml0KCkge1xuICAgICAgICB0aGlzLmNoZWNrU2Nyb2xsKCk7XG4gICAgfVxuXG4gICAgQEhvc3RMaXN0ZW5lcignd2luZG93OnNjcm9sbCcsIFtdKVxuICAgIG9uV2luZG93U2Nyb2xsKCkge1xuICAgICAgICB0aGlzLmNoZWNrU2Nyb2xsKCk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBjaGVja1Njcm9sbCgpIHtcbiAgICAgICAgY29uc3Qgc2Nyb2xsUG9zaXRpb24gPSB3aW5kb3cuc2Nyb2xsWTtcbiAgICAgICAgdGhpcy5oZWFkZXJGaXhlZCA9IHNjcm9sbFBvc2l0aW9uID4gMTAwO1xuICAgIH1cblxuICAgIHRvZ2dsZURyb3Bkb3duKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmlzRHJvcGRvd25PcGVuID0gIXRoaXMuaXNEcm9wZG93bk9wZW47XG4gICAgfVxufVxuIiwiPHNlY3Rpb25cbiAgICBjbGFzcz1cImJhYnlsb25fX3N1Ym1lbnUtaG90ZWxcIlxuICAgIFtuZ0NsYXNzXT1cIntcbiAgICAgICAgY3NfZ2VzY291dF9zdGlja3k6IGhlYWRlckZpeGVkLFxuICAgICAgICAnc3VibWVudS1vcGVuJzogaXNEcm9wZG93bk9wZW4sXG4gICAgfVwiXG4+XG4gICAgPCEtLSBUcmlnZ2VyIGZvciB0YWJsZXQgLS0+XG4gICAgPGRpdiBjbGFzcz1cInN1Ym1lbnUtdHJpZ2dlclwiIChjbGljayk9XCJ0b2dnbGVEcm9wZG93bigpXCI+XG4gICAgICAgIDxzcGFuPk1FTlU8L3NwYW4+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwiaGFtYnVyZ2VyLWljb25cIj5cbiAgICAgICAgICAgIDxzcGFuPjwvc3Bhbj5cbiAgICAgICAgICAgIDxzcGFuPjwvc3Bhbj5cbiAgICAgICAgICAgIDxzcGFuPjwvc3Bhbj5cbiAgICAgICAgPC9zcGFuPlxuICAgIDwvZGl2PlxuXG4gICAgQGlmIChpdGVtcykge1xuICAgICAgICA8ZGl2IGNsYXNzPVwiY29udGFpbmVyXCI+XG4gICAgICAgICAgICA8bmF2IGNsYXNzPVwic3VibWVudVwiPlxuICAgICAgICAgICAgICAgIDx1bD5cbiAgICAgICAgICAgICAgICAgICAgQGZvciAoaXRlbSBvZiBpdGVtczsgdHJhY2sgJGluZGV4KSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBAaWYgKGl0ZW0pIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8bGk+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxhXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbYXR0ci5hcmlhLWxhYmVsXT1cIml0ZW0ubGFiZWxcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2hyZWZdPVwiaXRlbS51cmxcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cInRvZ2dsZURyb3Bkb3duKClcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2xpbmtUeXBlXT1cIml0ZW0ubGlua1R5cGVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW25nQ2xhc3NdPVwie1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFjdGl2ZTpcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc2VsZWN0ZWQ/LmxhYmVsPy50b0xvd2VyQ2FzZSgpID09PVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpdGVtPy5sYWJlbD8udG9Mb3dlckNhc2UoKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH1cIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPnt7IGl0ZW0/LmxhYmVsIH19PC9hXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L2xpPlxuICAgICAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgPC91bD5cbiAgICAgICAgICAgIDwvbmF2PlxuICAgICAgICA8L2Rpdj5cbiAgICB9XG48L3NlY3Rpb24+XG4iXX0=
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFieWxvbi1zdWJtZW51LWhvdGVsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhYnlsb24vc3JjL2xpYi9jb21wb25lbnRzL2NvcmUvYmFieWxvbi1zdWJtZW51LWhvdGVsL2JhYnlsb24tc3VibWVudS1ob3RlbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYWJ5bG9uL3NyYy9saWIvY29tcG9uZW50cy9jb3JlL2JhYnlsb24tc3VibWVudS1ob3RlbC9iYWJ5bG9uLXN1Ym1lbnUtaG90ZWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ2xFLE9BQU8sRUFDSCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFlBQVksRUFDWixNQUFNLEVBQ04sS0FBSyxFQUVMLFdBQVcsR0FDZCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQzs7O0FBVzdGLE1BQU0sT0FBTyw0QkFBNEI7SUFSekM7UUFZSSxnQkFBVyxHQUFHLEtBQUssQ0FBQztRQUNwQixtQkFBYyxHQUFHLEtBQUssQ0FBQztRQUVmLGVBQVUsR0FBRyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7S0FxQjVDO0lBbkJHLFFBQVE7UUFDSixJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDdkIsQ0FBQztJQUdELGNBQWM7UUFDVixJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDdkIsQ0FBQztJQUVPLFdBQVc7UUFDZixJQUFJLGlCQUFpQixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsRUFBRTtZQUNwQyxNQUFNLGNBQWMsR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDO1lBQ3RDLElBQUksQ0FBQyxXQUFXLEdBQUcsY0FBYyxHQUFHLEdBQUcsQ0FBQztTQUMzQztJQUNMLENBQUM7SUFFRCxjQUFjO1FBQ1YsSUFBSSxDQUFDLGNBQWMsR0FBRyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUM7SUFDL0MsQ0FBQzsrR0EzQlEsNEJBQTRCO21HQUE1Qiw0QkFBNEIscU1DckJ6QywyL0NBNENBLDgyMEJENUJjLFlBQVksNkhBQUUsd0JBQXdCOzs0RkFLdkMsNEJBQTRCO2tCQVJ4QyxTQUFTOytCQUNJLDJCQUEyQixjQUN6QixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsd0JBQXdCLENBQUMsbUJBR2hDLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQVlOLGNBQWM7c0JBRGIsWUFBWTt1QkFBQyxlQUFlLEVBQUUsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSwgaXNQbGF0Zm9ybUJyb3dzZXIgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgICBDb21wb25lbnQsXG4gICAgSG9zdExpc3RlbmVyLFxuICAgIGluamVjdCxcbiAgICBJbnB1dCxcbiAgICBPbkluaXQsXG4gICAgUExBVEZPUk1fSUQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmFieWxvbkxpbmtUeXBlRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vLi4vZGlyZWN0aXZlcy9saW5rLXR5cGUvbGluay10eXBlLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBCYWJ5bG9uQnV0dG9uSSB9IGZyb20gJy4uLy4uLy4uL2ludGVyZmFjZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2xpYi1iYWJ5bG9uLXN1Ym1lbnUtaG90ZWwnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgQmFieWxvbkxpbmtUeXBlRGlyZWN0aXZlXSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vYmFieWxvbi1zdWJtZW51LWhvdGVsLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybDogJy4vYmFieWxvbi1zdWJtZW51LWhvdGVsLmNvbXBvbmVudC5zY3NzJyxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgQmFieWxvblN1Ym1lbnVIb3RlbENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgQElucHV0KCkgaXRlbXM/OiBCYWJ5bG9uQnV0dG9uSVtdO1xuICAgIEBJbnB1dCgpIHNlbGVjdGVkPzogQmFieWxvbkJ1dHRvbkk7XG5cbiAgICBoZWFkZXJGaXhlZCA9IGZhbHNlO1xuICAgIGlzRHJvcGRvd25PcGVuID0gZmFsc2U7XG5cbiAgICBwcml2YXRlIHBsYXRmb3JtSWQgPSBpbmplY3QoUExBVEZPUk1fSUQpO1xuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIHRoaXMuY2hlY2tTY3JvbGwoKTtcbiAgICB9XG5cbiAgICBASG9zdExpc3RlbmVyKCd3aW5kb3c6c2Nyb2xsJywgW10pXG4gICAgb25XaW5kb3dTY3JvbGwoKSB7XG4gICAgICAgIHRoaXMuY2hlY2tTY3JvbGwoKTtcbiAgICB9XG5cbiAgICBwcml2YXRlIGNoZWNrU2Nyb2xsKCkge1xuICAgICAgICBpZiAoaXNQbGF0Zm9ybUJyb3dzZXIodGhpcy5wbGF0Zm9ybUlkKSkge1xuICAgICAgICAgICAgY29uc3Qgc2Nyb2xsUG9zaXRpb24gPSB3aW5kb3cuc2Nyb2xsWTtcbiAgICAgICAgICAgIHRoaXMuaGVhZGVyRml4ZWQgPSBzY3JvbGxQb3NpdGlvbiA+IDEwMDtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHRvZ2dsZURyb3Bkb3duKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmlzRHJvcGRvd25PcGVuID0gIXRoaXMuaXNEcm9wZG93bk9wZW47XG4gICAgfVxufVxuIiwiPHNlY3Rpb25cbiAgICBjbGFzcz1cImJhYnlsb25fX3N1Ym1lbnUtaG90ZWxcIlxuICAgIFtuZ0NsYXNzXT1cIntcbiAgICAgICAgY3NfZ2VzY291dF9zdGlja3k6IGhlYWRlckZpeGVkLFxuICAgICAgICAnc3VibWVudS1vcGVuJzogaXNEcm9wZG93bk9wZW4sXG4gICAgfVwiXG4+XG4gICAgPCEtLSBUcmlnZ2VyIGZvciB0YWJsZXQgLS0+XG4gICAgPGRpdiBjbGFzcz1cInN1Ym1lbnUtdHJpZ2dlclwiIChjbGljayk9XCJ0b2dnbGVEcm9wZG93bigpXCI+XG4gICAgICAgIDxzcGFuPk1FTlU8L3NwYW4+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwiaGFtYnVyZ2VyLWljb25cIj5cbiAgICAgICAgICAgIDxzcGFuPjwvc3Bhbj5cbiAgICAgICAgICAgIDxzcGFuPjwvc3Bhbj5cbiAgICAgICAgICAgIDxzcGFuPjwvc3Bhbj5cbiAgICAgICAgPC9zcGFuPlxuICAgIDwvZGl2PlxuXG4gICAgQGlmIChpdGVtcykge1xuICAgICAgICA8ZGl2IGNsYXNzPVwiY29udGFpbmVyXCI+XG4gICAgICAgICAgICA8bmF2IGNsYXNzPVwic3VibWVudVwiPlxuICAgICAgICAgICAgICAgIDx1bD5cbiAgICAgICAgICAgICAgICAgICAgQGZvciAoaXRlbSBvZiBpdGVtczsgdHJhY2sgJGluZGV4KSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBAaWYgKGl0ZW0pIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8bGk+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxhXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbYXR0ci5hcmlhLWxhYmVsXT1cIml0ZW0ubGFiZWxcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2hyZWZdPVwiaXRlbS51cmxcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cInRvZ2dsZURyb3Bkb3duKClcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2xpbmtUeXBlXT1cIml0ZW0ubGlua1R5cGVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW25nQ2xhc3NdPVwie1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFjdGl2ZTpcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc2VsZWN0ZWQ/LmxhYmVsPy50b0xvd2VyQ2FzZSgpID09PVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpdGVtPy5sYWJlbD8udG9Mb3dlckNhc2UoKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH1cIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPnt7IGl0ZW0/LmxhYmVsIH19PC9hXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L2xpPlxuICAgICAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgPC91bD5cbiAgICAgICAgICAgIDwvbmF2PlxuICAgICAgICA8L2Rpdj5cbiAgICB9XG48L3NlY3Rpb24+XG4iXX0=