ctt-babylon 0.1.171 → 0.1.173

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (31) hide show
  1. package/esm2022/lib/components/core/babylon-color-picker/babylon-color-picker.component.mjs +14 -12
  2. package/esm2022/lib/components/core/babylon-contact-form/babylon-contact-form.component.mjs +5 -3
  3. package/esm2022/lib/components/core/babylon-header-book-show/babylon-header-book-show.component.mjs +4 -6
  4. package/esm2022/lib/components/core/babylon-header-book-show/babylon-header-book-show.interface.mjs +1 -1
  5. package/esm2022/lib/components/core/babylon-header-clear/babylon-header-clear.component.mjs +4 -6
  6. package/esm2022/lib/components/core/babylon-header-clear/babylon-header-clear.interface.mjs +1 -1
  7. package/esm2022/lib/components/core/babylon-header-menu-center/babylon-header-menu-center.component.mjs +46 -9
  8. package/esm2022/lib/components/core/babylon-header-menu-logo-center/babylon-header-menu-logo-center.component.mjs +1 -4
  9. package/esm2022/lib/components/core/babylon-header-menu-show/babylon-header-menu-show.component.mjs +4 -6
  10. package/esm2022/lib/components/core/babylon-header-menu-show/babylon-header-menu-show.interface.mjs +1 -1
  11. package/esm2022/lib/components/core/babylon-header-mobile/babylon-header-mobile.component.mjs +4 -6
  12. package/esm2022/lib/components/core/babylon-info-zig-zag/babylon-info-zig-zag.component.mjs +3 -3
  13. package/esm2022/lib/components/core/babylon-info-zigzag-v2/babylon-info-zigzag-v2.component.mjs +3 -3
  14. package/esm2022/lib/components/core/babylon-newsletter/babylon-newsletter.component.mjs +3 -3
  15. package/esm2022/lib/components/core/babylon-slider4col/babylon-slider4col.component.mjs +3 -3
  16. package/esm2022/lib/services/mapper/mapper.service.mjs +4 -4
  17. package/fesm2022/ctt-babylon.mjs +84 -55
  18. package/fesm2022/ctt-babylon.mjs.map +1 -1
  19. package/lib/components/core/babylon-color-picker/babylon-color-picker.component.d.ts +1 -1
  20. package/lib/components/core/babylon-contact-form/babylon-contact-form.component.d.ts +2 -1
  21. package/lib/components/core/babylon-header-book-show/babylon-header-book-show.component.d.ts +3 -3
  22. package/lib/components/core/babylon-header-book-show/babylon-header-book-show.interface.d.ts +2 -2
  23. package/lib/components/core/babylon-header-clear/babylon-header-clear.component.d.ts +3 -3
  24. package/lib/components/core/babylon-header-clear/babylon-header-clear.interface.d.ts +2 -2
  25. package/lib/components/core/babylon-header-menu-center/babylon-header-menu-center.component.d.ts +6 -3
  26. package/lib/components/core/babylon-header-menu-logo-center/babylon-header-menu-logo-center.component.d.ts +0 -1
  27. package/lib/components/core/babylon-header-menu-show/babylon-header-menu-show.component.d.ts +3 -3
  28. package/lib/components/core/babylon-header-menu-show/babylon-header-menu-show.interface.d.ts +2 -2
  29. package/lib/components/core/babylon-header-mobile/babylon-header-mobile.component.d.ts +3 -3
  30. package/lib/components/core/babylon-newsletter/babylon-newsletter.component.d.ts +2 -2
  31. package/package.json +1 -1
@@ -164,25 +164,27 @@ export class BabylonColorPickerComponent {
164
164
  const match = fullValue.match(/^['"]?([^'",]+)['"]?/);
165
165
  return match ? match[1] : fullValue;
166
166
  }
167
- updateFontVariable(event, variableName) {
167
+ async updateFontVariable(event, variableName) {
168
168
  const target = event.target;
169
169
  const fontName = target?.value;
170
170
  if (!fontName)
171
171
  return;
172
172
  const value = `'${fontName}', Helvetica, sans-serif`;
173
173
  this.colorService.changeColor(variableName, value, this.groupedVariables);
174
- const isPredefined = ['font-title', 'font-pretitle', 'font-text', 'font-claim'].includes(fontName);
175
- if (isPredefined)
176
- return;
174
+ this.fontValues[variableName] = fontName;
175
+ const isGoogleFont = this.colorService.googleFonts.includes(fontName);
176
+ if (!isGoogleFont)
177
+ return; // ⛔ No insertar si no es Google Font
177
178
  const formattedFont = fontName.replace(/ /g, '+');
178
179
  const id = `font-${formattedFont}`;
179
- if (!document.getElementById(id)) {
180
- const link = document.createElement('link');
181
- link.id = id;
182
- link.rel = 'stylesheet';
183
- link.href = `https://fonts.googleapis.com/css2?family=${formattedFont}&display=swap`;
184
- document.head.appendChild(link);
185
- }
180
+ if (document.getElementById(id))
181
+ return;
182
+ const link = document.createElement('link');
183
+ link.id = id;
184
+ link.rel = 'stylesheet';
185
+ link.href = `https://fonts.googleapis.com/css2?family=${formattedFont}&display=swap`;
186
+ link.onerror = () => link.remove();
187
+ document.head.appendChild(link);
186
188
  }
187
189
  getComputedColor(variableName) {
188
190
  const raw = getComputedStyle(document.documentElement)
@@ -234,4 +236,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
234
236
  type: ViewChild,
235
237
  args: ['panel', { static: false }]
236
238
  }] } });
237
- //# 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    Input,\n    OnInit,\n    PLATFORM_ID,\n    Renderer2,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { FormsModule, ReactiveFormsModule, FormBuilder, FormGroup } 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    @Input() userPanel = '';\n    @Input() passPanel = '';\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            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            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        const { email, password } = this.loginForm.value;\n        if (email === this.userPanel && password === this.passPanel) {\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(this.googleFontsApiKey);\n            this.setInitialFontValues();\n        } else {\n            alert('Usuario o contraseña incorrectos');\n        }\n    }\n\n    setInitialFontValues(): void {\n      const gruposFuente = ['Títulos', 'Pretítulos', 'Subtítulos', 'Textos', 'Fuentes', 'Tipografías'];\n\n      for (const [group, variables] of this.groupedVariables) {\n        if (gruposFuente.includes(group)) {\n          for (const variable of variables) {\n            const currentValue = getComputedStyle(document.documentElement)\n              .getPropertyValue(variable.name)\n              .trim();\n            const fontName = this.getFontNameOnly(currentValue);\n            this.fontValues[variable.name] = fontName;\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        this.activeTab = tab;\n        localStorage.setItem('panel-estilos-tab', tab);\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    updateFontVariable(event: Event, variableName: string): void {\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(variableName, value, this.groupedVariables);\n\n      const isPredefined = ['font-title', 'font-pretitle', 'font-text', 'font-claim'].includes(fontName);\n      if (isPredefined) return;\n\n      const formattedFont = fontName.replace(/ /g, '+');\n      const id = `font-${formattedFont}`;\n\n      if (!document.getElementById(id)) {\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        document.head.appendChild(link);\n      }\n    }\n\n    getComputedColor(variableName: string): string {\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\n    getHexForColorInput(variableName: string): string {\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}\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"]}
239
+ //# 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    Input,\n    OnInit,\n    PLATFORM_ID,\n    Renderer2,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { FormsModule, ReactiveFormsModule, FormBuilder, FormGroup } 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    @Input() userPanel = '';\n    @Input() passPanel = '';\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            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            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        const { email, password } = this.loginForm.value;\n        if (email === this.userPanel && password === this.passPanel) {\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(this.googleFontsApiKey);\n            this.setInitialFontValues();\n        } else {\n            alert('Usuario o contraseña incorrectos');\n        }\n    }\n\n    setInitialFontValues(): void {\n      const gruposFuente = ['Títulos', 'Pretítulos', 'Subtítulos', 'Textos', 'Fuentes', 'Tipografías'];\n\n      for (const [group, variables] of this.groupedVariables) {\n        if (gruposFuente.includes(group)) {\n          for (const variable of variables) {\n            const currentValue = getComputedStyle(document.documentElement)\n              .getPropertyValue(variable.name)\n              .trim();\n            const fontName = this.getFontNameOnly(currentValue);\n            this.fontValues[variable.name] = fontName;\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        this.activeTab = tab;\n        localStorage.setItem('panel-estilos-tab', tab);\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(event: Event, variableName: string): Promise<void> {\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(variableName, value, this.groupedVariables);\n      this.fontValues[variableName] = fontName;\n\n      const isGoogleFont = 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    getComputedColor(variableName: string): string {\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\n    getHexForColorInput(variableName: string): string {\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}\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"]}