valtech-components 2.0.302 → 2.0.305

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 (32) hide show
  1. package/esm2022/lib/components/atoms/button/button.component.mjs +103 -23
  2. package/esm2022/lib/components/types.mjs +1 -1
  3. package/esm2022/lib/services/lang-provider/content.mjs +1 -72
  4. package/esm2022/lib/services/lang-provider/lang-provider.service.mjs +4 -9
  5. package/esm2022/lib/shared/utils/content.mjs +2 -8
  6. package/esm2022/public-api.mjs +1 -12
  7. package/fesm2022/valtech-components.mjs +124 -2824
  8. package/fesm2022/valtech-components.mjs.map +1 -1
  9. package/lib/components/atoms/button/button.component.d.ts +33 -2
  10. package/lib/components/types.d.ts +19 -7
  11. package/package.json +1 -1
  12. package/public-api.d.ts +0 -10
  13. package/esm2022/lib/examples/comprehensive-link-test.component.mjs +0 -208
  14. package/esm2022/lib/examples/custom-content-demo.component.mjs +0 -291
  15. package/esm2022/lib/examples/display-demo.component.mjs +0 -518
  16. package/esm2022/lib/examples/display-simple-example.component.mjs +0 -202
  17. package/esm2022/lib/examples/link-processing-example.component.mjs +0 -233
  18. package/esm2022/lib/examples/multi-language-demo.component.mjs +0 -304
  19. package/esm2022/lib/examples/reactive-components-demo.component.mjs +0 -303
  20. package/esm2022/lib/examples/reactivity-test.component.mjs +0 -200
  21. package/esm2022/lib/examples/selector-examples.component.mjs +0 -234
  22. package/esm2022/lib/examples/user-issue-test.component.mjs +0 -267
  23. package/lib/examples/comprehensive-link-test.component.d.ts +0 -23
  24. package/lib/examples/custom-content-demo.component.d.ts +0 -26
  25. package/lib/examples/display-demo.component.d.ts +0 -62
  26. package/lib/examples/display-simple-example.component.d.ts +0 -23
  27. package/lib/examples/link-processing-example.component.d.ts +0 -26
  28. package/lib/examples/multi-language-demo.component.d.ts +0 -34
  29. package/lib/examples/reactive-components-demo.component.d.ts +0 -45
  30. package/lib/examples/reactivity-test.component.d.ts +0 -27
  31. package/lib/examples/selector-examples.component.d.ts +0 -21
  32. package/lib/examples/user-issue-test.component.d.ts +0 -31
@@ -1,202 +0,0 @@
1
- import { Component } from '@angular/core';
2
- import { DisplayComponent } from '../components/atoms/display/display.component';
3
- import * as i0 from "@angular/core";
4
- /**
5
- * Ejemplo rápido de uso del componente val-display con contenido reactivo
6
- */
7
- export class DisplayExampleComponent {
8
- constructor() {
9
- // ✅ Ejemplos de contenido estático
10
- this.staticTitle = {
11
- content: 'Este es un título estático',
12
- color: 'primary',
13
- size: 'xlarge',
14
- };
15
- this.staticSubtitle = {
16
- content: 'Este es un subtítulo que no cambia',
17
- color: 'medium',
18
- size: 'large',
19
- };
20
- // ✅ Ejemplos de contenido reactivo (requiere configuración de i18n)
21
- this.reactiveWelcome = {
22
- contentConfig: {
23
- className: 'displayExample',
24
- key: 'welcome.title',
25
- fallback: 'Bienvenido a la aplicación',
26
- },
27
- color: 'primary',
28
- size: 'xlarge',
29
- };
30
- this.reactiveDescription = {
31
- contentConfig: {
32
- className: 'displayExample',
33
- key: 'welcome.description',
34
- fallback: 'Esta descripción cambia según el idioma',
35
- },
36
- color: 'dark',
37
- size: 'medium',
38
- };
39
- // ✅ Ejemplos con interpolación de variables
40
- this.userGreeting = {
41
- contentConfig: {
42
- className: 'displayExample',
43
- key: 'user.greeting',
44
- fallback: 'Hola, {{name}}! Tienes {{messages}} mensajes.',
45
- interpolation: {
46
- name: 'María',
47
- messages: 5,
48
- },
49
- },
50
- color: 'tertiary',
51
- size: 'large',
52
- };
53
- this.statusMessage = {
54
- contentConfig: {
55
- className: 'displayExample',
56
- key: 'status.online',
57
- fallback: 'Estado: {{status}} desde {{time}}',
58
- interpolation: {
59
- status: 'En línea',
60
- time: '10:30 AM',
61
- },
62
- },
63
- color: 'success',
64
- size: 'small',
65
- };
66
- // ✅ Ejemplos de diferentes tamaños
67
- this.smallText = {
68
- content: 'Texto pequeño (small)',
69
- color: 'dark',
70
- size: 'small',
71
- };
72
- this.mediumText = {
73
- content: 'Texto mediano (medium)',
74
- color: 'dark',
75
- size: 'medium',
76
- };
77
- this.largeText = {
78
- content: 'Texto grande (large)',
79
- color: 'dark',
80
- size: 'large',
81
- };
82
- this.xlargeText = {
83
- content: 'Texto extra grande (xlarge)',
84
- color: 'dark',
85
- size: 'xlarge',
86
- };
87
- // ✅ Ejemplos de diferentes colores
88
- this.primaryText = {
89
- content: 'Texto color primary',
90
- color: 'primary',
91
- size: 'medium',
92
- };
93
- this.successText = {
94
- content: 'Texto color success',
95
- color: 'success',
96
- size: 'medium',
97
- };
98
- this.warningText = {
99
- content: 'Texto color warning',
100
- color: 'warning',
101
- size: 'medium',
102
- };
103
- this.dangerText = {
104
- content: 'Texto color danger',
105
- color: 'danger',
106
- size: 'medium',
107
- };
108
- }
109
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DisplayExampleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
110
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DisplayExampleComponent, isStandalone: true, selector: "app-display-example", ngImport: i0, template: `
111
- <div class="display-examples">
112
- <h2>Ejemplos de val-display</h2>
113
-
114
- <!-- Contenido estático -->
115
- <div class="section">
116
- <h3>Contenido Estático</h3>
117
- <val-display [props]="staticTitle"></val-display>
118
- <val-display [props]="staticSubtitle"></val-display>
119
- </div>
120
-
121
- <!-- Contenido reactivo -->
122
- <div class="section">
123
- <h3>Contenido Reactivo</h3>
124
- <val-display [props]="reactiveWelcome"></val-display>
125
- <val-display [props]="reactiveDescription"></val-display>
126
- </div>
127
-
128
- <!-- Contenido con interpolación -->
129
- <div class="section">
130
- <h3>Contenido con Variables</h3>
131
- <val-display [props]="userGreeting"></val-display>
132
- <val-display [props]="statusMessage"></val-display>
133
- </div>
134
-
135
- <!-- Diferentes tamaños -->
136
- <div class="section">
137
- <h3>Diferentes Tamaños</h3>
138
- <val-display [props]="smallText"></val-display>
139
- <val-display [props]="mediumText"></val-display>
140
- <val-display [props]="largeText"></val-display>
141
- <val-display [props]="xlargeText"></val-display>
142
- </div>
143
-
144
- <!-- Diferentes colores -->
145
- <div class="section">
146
- <h3>Diferentes Colores</h3>
147
- <val-display [props]="primaryText"></val-display>
148
- <val-display [props]="successText"></val-display>
149
- <val-display [props]="warningText"></val-display>
150
- <val-display [props]="dangerText"></val-display>
151
- </div>
152
- </div>
153
- `, isInline: true, styles: [".display-examples{padding:20px;max-width:800px;margin:0 auto}.section{margin:30px 0;padding:20px;border:1px solid var(--ion-color-light);border-radius:8px;background:var(--ion-color-step-50)}.section h3{margin:0 0 15px;color:var(--ion-color-primary)}val-display{display:block;margin:10px 0}\n"], dependencies: [{ kind: "component", type: DisplayComponent, selector: "val-display", inputs: ["props"] }] }); }
154
- }
155
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DisplayExampleComponent, decorators: [{
156
- type: Component,
157
- args: [{ selector: 'app-display-example', standalone: true, imports: [DisplayComponent], template: `
158
- <div class="display-examples">
159
- <h2>Ejemplos de val-display</h2>
160
-
161
- <!-- Contenido estático -->
162
- <div class="section">
163
- <h3>Contenido Estático</h3>
164
- <val-display [props]="staticTitle"></val-display>
165
- <val-display [props]="staticSubtitle"></val-display>
166
- </div>
167
-
168
- <!-- Contenido reactivo -->
169
- <div class="section">
170
- <h3>Contenido Reactivo</h3>
171
- <val-display [props]="reactiveWelcome"></val-display>
172
- <val-display [props]="reactiveDescription"></val-display>
173
- </div>
174
-
175
- <!-- Contenido con interpolación -->
176
- <div class="section">
177
- <h3>Contenido con Variables</h3>
178
- <val-display [props]="userGreeting"></val-display>
179
- <val-display [props]="statusMessage"></val-display>
180
- </div>
181
-
182
- <!-- Diferentes tamaños -->
183
- <div class="section">
184
- <h3>Diferentes Tamaños</h3>
185
- <val-display [props]="smallText"></val-display>
186
- <val-display [props]="mediumText"></val-display>
187
- <val-display [props]="largeText"></val-display>
188
- <val-display [props]="xlargeText"></val-display>
189
- </div>
190
-
191
- <!-- Diferentes colores -->
192
- <div class="section">
193
- <h3>Diferentes Colores</h3>
194
- <val-display [props]="primaryText"></val-display>
195
- <val-display [props]="successText"></val-display>
196
- <val-display [props]="warningText"></val-display>
197
- <val-display [props]="dangerText"></val-display>
198
- </div>
199
- </div>
200
- `, styles: [".display-examples{padding:20px;max-width:800px;margin:0 auto}.section{margin:30px 0;padding:20px;border:1px solid var(--ion-color-light);border-radius:8px;background:var(--ion-color-step-50)}.section h3{margin:0 0 15px;color:var(--ion-color-primary)}val-display{display:block;margin:10px 0}\n"] }]
201
- }] });
202
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"display-simple-example.component.js","sourceRoot":"","sources":["../../../../../projects/valtech-components/src/lib/examples/display-simple-example.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component } from '@angular/core';\nimport { DisplayComponent } from '../components/atoms/display/display.component';\nimport { DisplayMetadata } from '../components/atoms/display/types';\n\n/**\n * Ejemplo rápido de uso del componente val-display con contenido reactivo\n */\n@Component({\n  selector: 'app-display-example',\n  standalone: true,\n  imports: [DisplayComponent],\n  template: `\n    <div class=\"display-examples\">\n      <h2>Ejemplos de val-display</h2>\n\n      <!-- Contenido estático -->\n      <div class=\"section\">\n        <h3>Contenido Estático</h3>\n        <val-display [props]=\"staticTitle\"></val-display>\n        <val-display [props]=\"staticSubtitle\"></val-display>\n      </div>\n\n      <!-- Contenido reactivo -->\n      <div class=\"section\">\n        <h3>Contenido Reactivo</h3>\n        <val-display [props]=\"reactiveWelcome\"></val-display>\n        <val-display [props]=\"reactiveDescription\"></val-display>\n      </div>\n\n      <!-- Contenido con interpolación -->\n      <div class=\"section\">\n        <h3>Contenido con Variables</h3>\n        <val-display [props]=\"userGreeting\"></val-display>\n        <val-display [props]=\"statusMessage\"></val-display>\n      </div>\n\n      <!-- Diferentes tamaños -->\n      <div class=\"section\">\n        <h3>Diferentes Tamaños</h3>\n        <val-display [props]=\"smallText\"></val-display>\n        <val-display [props]=\"mediumText\"></val-display>\n        <val-display [props]=\"largeText\"></val-display>\n        <val-display [props]=\"xlargeText\"></val-display>\n      </div>\n\n      <!-- Diferentes colores -->\n      <div class=\"section\">\n        <h3>Diferentes Colores</h3>\n        <val-display [props]=\"primaryText\"></val-display>\n        <val-display [props]=\"successText\"></val-display>\n        <val-display [props]=\"warningText\"></val-display>\n        <val-display [props]=\"dangerText\"></val-display>\n      </div>\n    </div>\n  `,\n  styles: [\n    `\n      .display-examples {\n        padding: 20px;\n        max-width: 800px;\n        margin: 0 auto;\n      }\n\n      .section {\n        margin: 30px 0;\n        padding: 20px;\n        border: 1px solid var(--ion-color-light);\n        border-radius: 8px;\n        background: var(--ion-color-step-50);\n      }\n\n      .section h3 {\n        margin: 0 0 15px 0;\n        color: var(--ion-color-primary);\n      }\n\n      val-display {\n        display: block;\n        margin: 10px 0;\n      }\n    `,\n  ],\n})\nexport class DisplayExampleComponent {\n  // ✅ Ejemplos de contenido estático\n  staticTitle: DisplayMetadata = {\n    content: 'Este es un título estático',\n    color: 'primary',\n    size: 'xlarge',\n  };\n\n  staticSubtitle: DisplayMetadata = {\n    content: 'Este es un subtítulo que no cambia',\n    color: 'medium',\n    size: 'large',\n  };\n\n  // ✅ Ejemplos de contenido reactivo (requiere configuración de i18n)\n  reactiveWelcome: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayExample',\n      key: 'welcome.title',\n      fallback: 'Bienvenido a la aplicación',\n    },\n    color: 'primary',\n    size: 'xlarge',\n  };\n\n  reactiveDescription: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayExample',\n      key: 'welcome.description',\n      fallback: 'Esta descripción cambia según el idioma',\n    },\n    color: 'dark',\n    size: 'medium',\n  };\n\n  // ✅ Ejemplos con interpolación de variables\n  userGreeting: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayExample',\n      key: 'user.greeting',\n      fallback: 'Hola, {{name}}! Tienes {{messages}} mensajes.',\n      interpolation: {\n        name: 'María',\n        messages: 5,\n      },\n    },\n    color: 'tertiary',\n    size: 'large',\n  };\n\n  statusMessage: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayExample',\n      key: 'status.online',\n      fallback: 'Estado: {{status}} desde {{time}}',\n      interpolation: {\n        status: 'En línea',\n        time: '10:30 AM',\n      },\n    },\n    color: 'success',\n    size: 'small',\n  };\n\n  // ✅ Ejemplos de diferentes tamaños\n  smallText: DisplayMetadata = {\n    content: 'Texto pequeño (small)',\n    color: 'dark',\n    size: 'small',\n  };\n\n  mediumText: DisplayMetadata = {\n    content: 'Texto mediano (medium)',\n    color: 'dark',\n    size: 'medium',\n  };\n\n  largeText: DisplayMetadata = {\n    content: 'Texto grande (large)',\n    color: 'dark',\n    size: 'large',\n  };\n\n  xlargeText: DisplayMetadata = {\n    content: 'Texto extra grande (xlarge)',\n    color: 'dark',\n    size: 'xlarge',\n  };\n\n  // ✅ Ejemplos de diferentes colores\n  primaryText: DisplayMetadata = {\n    content: 'Texto color primary',\n    color: 'primary',\n    size: 'medium',\n  };\n\n  successText: DisplayMetadata = {\n    content: 'Texto color success',\n    color: 'success',\n    size: 'medium',\n  };\n\n  warningText: DisplayMetadata = {\n    content: 'Texto color warning',\n    color: 'warning',\n    size: 'medium',\n  };\n\n  dangerText: DisplayMetadata = {\n    content: 'Texto color danger',\n    color: 'danger',\n    size: 'medium',\n  };\n}\n"]}
@@ -1,233 +0,0 @@
1
- import { Component } from '@angular/core';
2
- import { TextComponent } from '../components/atoms/text/text.component';
3
- import * as i0 from "@angular/core";
4
- /**
5
- * LinkProcessingExampleComponent - Componente de ejemplo que demuestra el procesamiento automático de enlaces.
6
- *
7
- * Este componente muestra diferentes casos de uso para el procesamiento automático de enlaces
8
- * en el componente val-text, incluyendo enlaces externos, rutas internas y configuraciones personalizadas.
9
- *
10
- * @example Uso en template:
11
- * ```html
12
- * <val-link-processing-example></val-link-processing-example>
13
- * ```
14
- */
15
- export class LinkProcessingExampleComponent {
16
- constructor() {
17
- this.basicTextProps = {
18
- content: 'Este texto contiene https://angular.io y /dashboard pero no se procesan como enlaces.',
19
- size: 'medium',
20
- color: 'dark',
21
- bold: false,
22
- processLinks: false,
23
- };
24
- this.basicLinksProps = {
25
- content: 'Visita https://angular.io para documentación o ve a /dashboard para el panel principal.',
26
- size: 'medium',
27
- color: 'dark',
28
- bold: false,
29
- processLinks: true,
30
- };
31
- this.customLinksProps = {
32
- content: 'Enlaces personalizados: https://github.com/angular/angular y /profile/settings',
33
- size: 'medium',
34
- color: 'dark',
35
- bold: false,
36
- processLinks: true,
37
- linkConfig: {
38
- openExternalInNewTab: true,
39
- openInternalInNewTab: false,
40
- linkClass: 'custom-link-style',
41
- externalLinkClass: 'external-custom',
42
- internalLinkClass: 'internal-custom',
43
- },
44
- };
45
- this.mixedLinksProps = {
46
- content: 'Consulta la documentación en https://ionicframework.com/docs, revisa el código en https://github.com/ionic-team/ionic-framework, o navega a /components/buttons para ejemplos internos.',
47
- size: 'medium',
48
- color: 'dark',
49
- bold: false,
50
- processLinks: true,
51
- linkConfig: {
52
- openExternalInNewTab: true,
53
- openInternalInNewTab: false,
54
- linkClass: 'processed-link',
55
- externalLinkClass: 'external-link',
56
- internalLinkClass: 'internal-link',
57
- },
58
- };
59
- this.sameTabLinksProps = {
60
- content: 'Estos enlaces no abren en nueva pestaña: https://example.com y /home',
61
- size: 'medium',
62
- color: 'dark',
63
- bold: false,
64
- processLinks: true,
65
- linkConfig: {
66
- openExternalInNewTab: false,
67
- openInternalInNewTab: false,
68
- linkClass: 'same-tab-link',
69
- externalLinkClass: 'external-same-tab',
70
- internalLinkClass: 'internal-same-tab',
71
- },
72
- };
73
- this.markdownLinksProps = {
74
- content: 'Consulta [la documentación de Angular](https://angular.io/docs) y ve a [configuración del perfil](/profile/settings) para más opciones.',
75
- size: 'medium',
76
- color: 'dark',
77
- bold: false,
78
- processLinks: true,
79
- linkConfig: {
80
- openExternalInNewTab: true,
81
- openInternalInNewTab: false,
82
- processMarkdownLinks: true,
83
- linkClass: 'markdown-link',
84
- externalLinkClass: 'markdown-external',
85
- internalLinkClass: 'markdown-internal',
86
- },
87
- };
88
- this.mixedFormatsProps = {
89
- content: 'Aquí hay [documentación oficial](https://angular.io/docs), un enlace directo https://github.com/angular/angular, y una ruta interna /dashboard/analytics. ¡Todos funcionan!',
90
- size: 'medium',
91
- color: 'dark',
92
- bold: false,
93
- processLinks: true,
94
- linkConfig: {
95
- openExternalInNewTab: true,
96
- openInternalInNewTab: false,
97
- processMarkdownLinks: true,
98
- linkClass: 'mixed-link',
99
- externalLinkClass: 'mixed-external',
100
- internalLinkClass: 'mixed-internal',
101
- },
102
- };
103
- this.punctuationTestProps = {
104
- content: 'URLs con puntuación final: https://ionicframework.com/docs, también https://angular.io! Pregunta sobre https://github.com/angular? Y punto final: https://typescript.org. Paréntesis (https://rxjs.dev) y comillas "https://zone.js". ¡Todos funcionan!',
105
- size: 'medium',
106
- color: 'dark',
107
- bold: false,
108
- processLinks: true,
109
- linkConfig: {
110
- openExternalInNewTab: true,
111
- linkClass: 'punctuation-test',
112
- externalLinkClass: 'external-punct',
113
- },
114
- };
115
- this.complexUrlsProps = {
116
- content: 'URLs complejas: https://example.com/path?param=value&other=123#section, búsqueda en https://google.com/search?q=angular+components, y API https://api.github.com/repos/owner/repo/issues?state=open. Todos con parámetros y fragmentos.',
117
- size: 'medium',
118
- color: 'dark',
119
- bold: false,
120
- processLinks: true,
121
- linkConfig: {
122
- openExternalInNewTab: true,
123
- linkClass: 'complex-url',
124
- externalLinkClass: 'complex-external',
125
- },
126
- };
127
- }
128
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: LinkProcessingExampleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
129
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: LinkProcessingExampleComponent, isStandalone: true, selector: "val-link-processing-example", ngImport: i0, template: `
130
- <div class="link-examples">
131
- <h2>Ejemplos de Procesamiento de Enlaces</h2>
132
-
133
- <div class="example-section">
134
- <h3>Texto sin procesamiento de enlaces:</h3>
135
- <val-text [props]="basicTextProps"></val-text>
136
- </div>
137
-
138
- <div class="example-section">
139
- <h3>Texto con procesamiento básico de enlaces:</h3>
140
- <val-text [props]="basicLinksProps"></val-text>
141
- </div>
142
-
143
- <div class="example-section">
144
- <h3>Enlaces con configuración personalizada:</h3>
145
- <val-text [props]="customLinksProps"></val-text>
146
- </div>
147
-
148
- <div class="example-section">
149
- <h3>Enlaces internos y externos mezclados:</h3>
150
- <val-text [props]="mixedLinksProps"></val-text>
151
- </div>
152
-
153
- <div class="example-section">
154
- <h3>Enlaces sin abrir en nueva pestaña:</h3>
155
- <val-text [props]="sameTabLinksProps"></val-text>
156
- </div>
157
-
158
- <div class="example-section">
159
- <h3>Enlaces estilo Markdown [texto](url):</h3>
160
- <val-text [props]="markdownLinksProps"></val-text>
161
- </div>
162
-
163
- <div class="example-section">
164
- <h3>Mezcla de enlaces directos y Markdown:</h3>
165
- <val-text [props]="mixedFormatsProps"></val-text>
166
- </div>
167
-
168
- <div class="example-section">
169
- <h3>Corrección de puntuación en URLs:</h3>
170
- <val-text [props]="punctuationTestProps"></val-text>
171
- </div>
172
-
173
- <div class="example-section">
174
- <h3>URLs complejas con parámetros y fragmentos:</h3>
175
- <val-text [props]="complexUrlsProps"></val-text>
176
- </div>
177
- </div>
178
- `, isInline: true, styles: [".example-section{margin-bottom:24px;padding:16px;border:1px solid var(--ion-color-light, #f4f5f8);border-radius:8px;background:var(--ion-color-light-tint, #f5f6f9)}h2{color:var(--ion-color-primary, #3880ff);margin-bottom:20px}h3{color:var(--ion-color-dark, #222428);margin-bottom:10px;font-size:16px}\n"], dependencies: [{ kind: "component", type: TextComponent, selector: "val-text", inputs: ["props"] }] }); }
179
- }
180
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: LinkProcessingExampleComponent, decorators: [{
181
- type: Component,
182
- args: [{ selector: 'val-link-processing-example', standalone: true, imports: [TextComponent], template: `
183
- <div class="link-examples">
184
- <h2>Ejemplos de Procesamiento de Enlaces</h2>
185
-
186
- <div class="example-section">
187
- <h3>Texto sin procesamiento de enlaces:</h3>
188
- <val-text [props]="basicTextProps"></val-text>
189
- </div>
190
-
191
- <div class="example-section">
192
- <h3>Texto con procesamiento básico de enlaces:</h3>
193
- <val-text [props]="basicLinksProps"></val-text>
194
- </div>
195
-
196
- <div class="example-section">
197
- <h3>Enlaces con configuración personalizada:</h3>
198
- <val-text [props]="customLinksProps"></val-text>
199
- </div>
200
-
201
- <div class="example-section">
202
- <h3>Enlaces internos y externos mezclados:</h3>
203
- <val-text [props]="mixedLinksProps"></val-text>
204
- </div>
205
-
206
- <div class="example-section">
207
- <h3>Enlaces sin abrir en nueva pestaña:</h3>
208
- <val-text [props]="sameTabLinksProps"></val-text>
209
- </div>
210
-
211
- <div class="example-section">
212
- <h3>Enlaces estilo Markdown [texto](url):</h3>
213
- <val-text [props]="markdownLinksProps"></val-text>
214
- </div>
215
-
216
- <div class="example-section">
217
- <h3>Mezcla de enlaces directos y Markdown:</h3>
218
- <val-text [props]="mixedFormatsProps"></val-text>
219
- </div>
220
-
221
- <div class="example-section">
222
- <h3>Corrección de puntuación en URLs:</h3>
223
- <val-text [props]="punctuationTestProps"></val-text>
224
- </div>
225
-
226
- <div class="example-section">
227
- <h3>URLs complejas con parámetros y fragmentos:</h3>
228
- <val-text [props]="complexUrlsProps"></val-text>
229
- </div>
230
- </div>
231
- `, styles: [".example-section{margin-bottom:24px;padding:16px;border:1px solid var(--ion-color-light, #f4f5f8);border-radius:8px;background:var(--ion-color-light-tint, #f5f6f9)}h2{color:var(--ion-color-primary, #3880ff);margin-bottom:20px}h3{color:var(--ion-color-dark, #222428);margin-bottom:10px;font-size:16px}\n"] }]
232
- }] });
233
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link-processing-example.component.js","sourceRoot":"","sources":["../../../../../projects/valtech-components/src/lib/examples/link-processing-example.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component } from '@angular/core';\nimport { TextComponent } from '../components/atoms/text/text.component';\nimport { TextMetadata } from '../components/atoms/text/types';\n/**\n * LinkProcessingExampleComponent - Componente de ejemplo que demuestra el procesamiento automático de enlaces.\n *\n * Este componente muestra diferentes casos de uso para el procesamiento automático de enlaces\n * en el componente val-text, incluyendo enlaces externos, rutas internas y configuraciones personalizadas.\n *\n * @example Uso en template:\n * ```html\n * <val-link-processing-example></val-link-processing-example>\n * ```\n */\n@Component({\n  selector: 'val-link-processing-example',\n  standalone: true,\n  imports: [TextComponent],\n  template: `\n    <div class=\"link-examples\">\n      <h2>Ejemplos de Procesamiento de Enlaces</h2>\n\n      <div class=\"example-section\">\n        <h3>Texto sin procesamiento de enlaces:</h3>\n        <val-text [props]=\"basicTextProps\"></val-text>\n      </div>\n\n      <div class=\"example-section\">\n        <h3>Texto con procesamiento básico de enlaces:</h3>\n        <val-text [props]=\"basicLinksProps\"></val-text>\n      </div>\n\n      <div class=\"example-section\">\n        <h3>Enlaces con configuración personalizada:</h3>\n        <val-text [props]=\"customLinksProps\"></val-text>\n      </div>\n\n      <div class=\"example-section\">\n        <h3>Enlaces internos y externos mezclados:</h3>\n        <val-text [props]=\"mixedLinksProps\"></val-text>\n      </div>\n\n      <div class=\"example-section\">\n        <h3>Enlaces sin abrir en nueva pestaña:</h3>\n        <val-text [props]=\"sameTabLinksProps\"></val-text>\n      </div>\n\n      <div class=\"example-section\">\n        <h3>Enlaces estilo Markdown [texto](url):</h3>\n        <val-text [props]=\"markdownLinksProps\"></val-text>\n      </div>\n\n      <div class=\"example-section\">\n        <h3>Mezcla de enlaces directos y Markdown:</h3>\n        <val-text [props]=\"mixedFormatsProps\"></val-text>\n      </div>\n\n      <div class=\"example-section\">\n        <h3>Corrección de puntuación en URLs:</h3>\n        <val-text [props]=\"punctuationTestProps\"></val-text>\n      </div>\n\n      <div class=\"example-section\">\n        <h3>URLs complejas con parámetros y fragmentos:</h3>\n        <val-text [props]=\"complexUrlsProps\"></val-text>\n      </div>\n    </div>\n  `,\n  styles: [\n    `\n      .example-section {\n        margin-bottom: 24px;\n        padding: 16px;\n        border: 1px solid var(--ion-color-light, #f4f5f8);\n        border-radius: 8px;\n        background: var(--ion-color-light-tint, #f5f6f9);\n      }\n\n      h2 {\n        color: var(--ion-color-primary, #3880ff);\n        margin-bottom: 20px;\n      }\n\n      h3 {\n        color: var(--ion-color-dark, #222428);\n        margin-bottom: 10px;\n        font-size: 16px;\n      }\n    `,\n  ],\n})\nexport class LinkProcessingExampleComponent {\n  basicTextProps: TextMetadata = {\n    content: 'Este texto contiene https://angular.io y /dashboard pero no se procesan como enlaces.',\n    size: 'medium',\n    color: 'dark',\n    bold: false,\n    processLinks: false,\n  };\n\n  basicLinksProps: TextMetadata = {\n    content: 'Visita https://angular.io para documentación o ve a /dashboard para el panel principal.',\n    size: 'medium',\n    color: 'dark',\n    bold: false,\n    processLinks: true,\n  };\n\n  customLinksProps: TextMetadata = {\n    content: 'Enlaces personalizados: https://github.com/angular/angular y /profile/settings',\n    size: 'medium',\n    color: 'dark',\n    bold: false,\n    processLinks: true,\n    linkConfig: {\n      openExternalInNewTab: true,\n      openInternalInNewTab: false,\n      linkClass: 'custom-link-style',\n      externalLinkClass: 'external-custom',\n      internalLinkClass: 'internal-custom',\n    },\n  };\n\n  mixedLinksProps: TextMetadata = {\n    content:\n      'Consulta la documentación en https://ionicframework.com/docs, revisa el código en https://github.com/ionic-team/ionic-framework, o navega a /components/buttons para ejemplos internos.',\n    size: 'medium',\n    color: 'dark',\n    bold: false,\n    processLinks: true,\n    linkConfig: {\n      openExternalInNewTab: true,\n      openInternalInNewTab: false,\n      linkClass: 'processed-link',\n      externalLinkClass: 'external-link',\n      internalLinkClass: 'internal-link',\n    },\n  };\n\n  sameTabLinksProps: TextMetadata = {\n    content: 'Estos enlaces no abren en nueva pestaña: https://example.com y /home',\n    size: 'medium',\n    color: 'dark',\n    bold: false,\n    processLinks: true,\n    linkConfig: {\n      openExternalInNewTab: false,\n      openInternalInNewTab: false,\n      linkClass: 'same-tab-link',\n      externalLinkClass: 'external-same-tab',\n      internalLinkClass: 'internal-same-tab',\n    },\n  };\n\n  markdownLinksProps: TextMetadata = {\n    content:\n      'Consulta [la documentación de Angular](https://angular.io/docs) y ve a [configuración del perfil](/profile/settings) para más opciones.',\n    size: 'medium',\n    color: 'dark',\n    bold: false,\n    processLinks: true,\n    linkConfig: {\n      openExternalInNewTab: true,\n      openInternalInNewTab: false,\n      processMarkdownLinks: true,\n      linkClass: 'markdown-link',\n      externalLinkClass: 'markdown-external',\n      internalLinkClass: 'markdown-internal',\n    },\n  };\n\n  mixedFormatsProps: TextMetadata = {\n    content:\n      'Aquí hay [documentación oficial](https://angular.io/docs), un enlace directo https://github.com/angular/angular, y una ruta interna /dashboard/analytics. ¡Todos funcionan!',\n    size: 'medium',\n    color: 'dark',\n    bold: false,\n    processLinks: true,\n    linkConfig: {\n      openExternalInNewTab: true,\n      openInternalInNewTab: false,\n      processMarkdownLinks: true,\n      linkClass: 'mixed-link',\n      externalLinkClass: 'mixed-external',\n      internalLinkClass: 'mixed-internal',\n    },\n  };\n\n  punctuationTestProps: TextMetadata = {\n    content:\n      'URLs con puntuación final: https://ionicframework.com/docs, también https://angular.io! Pregunta sobre https://github.com/angular? Y punto final: https://typescript.org. Paréntesis (https://rxjs.dev) y comillas \"https://zone.js\". ¡Todos funcionan!',\n    size: 'medium',\n    color: 'dark',\n    bold: false,\n    processLinks: true,\n    linkConfig: {\n      openExternalInNewTab: true,\n      linkClass: 'punctuation-test',\n      externalLinkClass: 'external-punct',\n    },\n  };\n\n  complexUrlsProps: TextMetadata = {\n    content:\n      'URLs complejas: https://example.com/path?param=value&other=123#section, búsqueda en https://google.com/search?q=angular+components, y API https://api.github.com/repos/owner/repo/issues?state=open. Todos con parámetros y fragmentos.',\n    size: 'medium',\n    color: 'dark',\n    bold: false,\n    processLinks: true,\n    linkConfig: {\n      openExternalInNewTab: true,\n      linkClass: 'complex-url',\n      externalLinkClass: 'complex-external',\n    },\n  };\n}\n"]}