valtech-components 2.0.422 β†’ 2.0.423

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.
package/README.md CHANGED
@@ -106,7 +106,7 @@ Import the desired standalone components in your Angular modules or components:
106
106
 
107
107
  ```typescript
108
108
  import { inject } from '@angular/core';
109
- import { TextComponent, ButtonComponent, LangService } from 'valtech-components';
109
+ import { TextComponent, ButtonComponent } from 'valtech-components';
110
110
 
111
111
  @Component({
112
112
  selector: 'your-component',
@@ -117,33 +117,19 @@ import { TextComponent, ButtonComponent, LangService } from 'valtech-components'
117
117
  ],
118
118
  template: `
119
119
  <!-- Static text -->
120
- <val-text
120
+ <val-text
121
121
  [props]="{
122
- content: 'This is a body text.',
123
- color: 'primary',
124
- bold: false,
125
- size: 'small'
122
+ content: 'This is a body text.',
123
+ color: 'primary',
124
+ bold: false,
125
+ size: 'small'
126
126
  }"
127
127
  />
128
-
129
- <!-- Reactive text from global content -->
130
- <val-text
131
- [props]="{
132
- contentKey: 'save',
133
- contentClass: '_global',
134
- contentFallback: 'Save',
135
- color: 'primary',
136
- bold: true,
137
- size: 'medium'
138
- }"
139
- />
140
-
141
- <!-- Button with reactive text -->
128
+
129
+ <!-- Button -->
142
130
  <val-button
143
131
  [props]="{
144
- contentKey: 'cancel',
145
- contentClass: '_global',
146
- contentFallback: 'Cancel',
132
+ text: 'Cancel',
147
133
  color: 'secondary',
148
134
  type: 'button'
149
135
  }"
@@ -152,238 +138,41 @@ import { TextComponent, ButtonComponent, LangService } from 'valtech-components'
152
138
  `
153
139
  })
154
140
  export class YourComponent {
155
- langService = inject(LangService);
156
-
157
141
  handleCancel() {
158
142
  console.log('Cancel clicked');
159
143
  }
160
144
  }
161
145
  ```
162
146
 
163
- ## 🌍 Reactive Internationalization (i18n)
164
-
165
- The library includes a powerful reactive internationalization system with **LangService** that automatically updates content when the language changes. It supports both **global content** (reusable across components) and **component-specific content**.
147
+ ## 🌍 Locale Management
166
148
 
167
- ### Key Features
168
-
169
- - **Global Content**: Reusable texts like buttons ("Save", "Cancel"), states ("Loading", "Error"), and confirmations
170
- - **Component-Specific Content**: Custom texts for individual components
171
- - **Reactive Updates**: Text automatically updates when language changes
172
- - **Interpolation Support**: Dynamic values in text strings with `{{variable}}` syntax
173
- - **Type-Safe**: Full TypeScript support with autocompletion
174
- - **Simple API**: Direct LangService injection, no complex setup
175
- - **Automatic Fallbacks**: Intelligent language fallback with console warnings
176
- - **Unified System**: Single service for all content needs
177
-
178
- ### Available Global Content
179
-
180
- - **Buttons**: `ok`, `cancel`, `save`, `delete`, `edit`, `close`, `back`, `next`, `previous`
181
- - **Actions**: `add`, `remove`, `search`, `filter`, `sort`, `refresh`
182
- - **States**: `loading`, `error`, `success`, `warning`, `info`, `noData`
183
- - **Forms**: `searchPlaceholder`
184
- - **Confirmations**: `deleteConfirmation`, `unsavedChanges`
185
- - **General**: `language`, `areYouSure`, `copied`
186
-
187
- ### Basic Setup
149
+ The library includes a simple locale management service using localStorage:
188
150
 
189
151
  ```typescript
190
- // main.ts
191
- import { TextContent, ValtechConfig, ValtechConfigService } from 'valtech-components';
192
-
193
- const appContent = new TextContent({
194
- es: {
195
- welcome: 'Bienvenido',
196
- description: 'Esta es la descripciΓ³n'
197
- },
198
- en: {
199
- welcome: 'Welcome',
200
- description: 'This is the description'
201
- }
202
- });
203
-
204
- const valtechConfig: ValtechConfig = {
205
- content: { AppComponent: appContent }
206
- };
207
-
208
- bootstrapApplication(AppComponent, {
209
- providers: [
210
- { provide: ValtechConfigService, useValue: valtechConfig },
211
- // ... other providers
212
- ]
213
- });
214
- ```
215
-
216
- ### Using LangService (Current API)
217
-
218
- ```typescript
219
- // component.ts
220
152
  import { inject } from '@angular/core';
221
- import { LangService } from 'valtech-components';
153
+ import { LocaleService, LanguageSelectorComponent } from 'valtech-components';
222
154
 
223
155
  @Component({
224
156
  template: `
225
- <!-- Global content using val-text -->
226
- <val-text [props]="{
227
- contentKey: 'ok',
228
- contentClass: '_global',
229
- color: 'primary',
230
- size: 'large',
231
- bold: true
232
- }"></val-text>
233
-
234
- <!-- Component-specific content using val-text -->
235
- <val-text [props]="{
236
- contentKey: 'welcome',
237
- contentClass: 'AppComponent',
238
- contentFallback: 'Welcome',
239
- color: 'secondary',
240
- size: 'medium'
241
- }"></val-text>
242
-
243
- <!-- Direct observable binding -->
244
- <h2>{{ title$ | async }}</h2>
245
-
246
- <!-- With interpolation -->
247
- <p>{{ greeting$ | async }}</p>
157
+ <val-language-selector
158
+ [props]="{ showFlags: true, showLabel: true }"
159
+ (languageChange)="onLanguageChange($event)"
160
+ ></val-language-selector>
248
161
  `
249
162
  })
250
163
  export class MyComponent {
251
- langService = inject(LangService);
252
-
253
- // Global content
254
- saveButton$ = this.langService.getContent('_global', 'save', 'Save');
255
- cancelButton$ = this.langService.getContent('_global', 'cancel', 'Cancel');
256
-
257
- // Component-specific content
258
- title$ = this.langService.getContent('AppComponent', 'welcome', 'Welcome');
259
-
260
- // Content with interpolation
261
- greeting$ = this.langService.getContentWithInterpolation(
262
- 'AppComponent',
263
- 'personalizedGreeting',
264
- { name: 'John', count: 5 },
265
- 'Hello!'
266
- );
267
-
268
- // Switch language
269
- changeLanguage() {
270
- const currentLang = this.langService.currentLang;
271
- this.langService.setLang(currentLang === 'es' ? 'en' : 'es');
272
- }
273
-
274
- constructor() {}
275
- }
276
- ```
164
+ localeService = inject(LocaleService);
277
165
 
278
- ### Content with Variables (Interpolation)
166
+ // Get current locale
167
+ currentLocale = this.localeService.getLocale(); // 'es', 'en', etc.
279
168
 
280
- ```typescript
281
- // Component with interpolation using the new API
282
- export class UserComponent {
283
- langService = inject(LangService);
284
-
285
- // Method 1: Direct service usage
286
- greeting$ = this.langService.getContentWithInterpolation(
287
- 'UserComponent',
288
- 'personalizedGreeting',
289
- { name: 'John', count: 5 },
290
- 'Hello!'
291
- );
292
- // Results in: "Hello John, you have 5 messages"
293
-
294
- // Method 2: Using val-text component
295
- // In template:
296
- // <val-text [props]="{
297
- // contentKey: 'personalizedGreeting',
298
- // contentClass: 'UserComponent',
299
- // contentInterpolation: { name: 'John', count: 5 },
300
- // contentFallback: 'Hello!'
301
- // }"></val-text>
302
- }
303
- ```
304
-
305
- ### Helper Functions
306
-
307
- ```typescript
308
- // Using utility helpers from simple-content
309
- import {
310
- fromContentWithInterpolation,
311
- interpolateStaticContent,
312
- shouldUseReactiveContent
313
- } from 'valtech-components';
314
-
315
- export class AdvancedComponent {
316
- langService = inject(LangService);
317
-
318
- // Using helper for reactive content with interpolation
319
- message$ = fromContentWithInterpolation(this.langService, {
320
- contentClass: 'MyComponent',
321
- contentKey: 'message',
322
- contentInterpolation: { count: 10 }
323
- });
324
-
325
- // Static content with interpolation
326
- processStaticText() {
327
- const text = interpolateStaticContent(
328
- 'You have {{count}} items',
329
- { count: 5 }
330
- );
331
- // Results in: "You have 5 items"
169
+ onLanguageChange(locale: string) {
170
+ // Changes locale and reloads the page
171
+ this.localeService.setLocale(locale);
332
172
  }
333
173
  }
334
174
  ```
335
175
 
336
- ### Migration Guide
337
-
338
- If you're migrating from the old `ContentService` API, here's a quick reference:
339
-
340
- ```typescript
341
- // OLD API (ContentService - removed)
342
- content = inject(ContentService);
343
- text$ = this.content.fromContent({ key: 'save' });
344
-
345
- // NEW API (LangService - current)
346
- langService = inject(LangService);
347
- text$ = this.langService.getContent('_global', 'save', 'Save');
348
-
349
- // OLD API (with interpolation)
350
- text$ = this.content.fromContentWithInterpolation({
351
- key: 'greeting',
352
- interpolation: { name: 'John' }
353
- });
354
-
355
- // NEW API (with interpolation)
356
- text$ = this.langService.getContentWithInterpolation(
357
- '_global',
358
- 'greeting',
359
- { name: 'John' },
360
- 'Hello!'
361
- );
362
- ```
363
-
364
- ### Available Utility Functions
365
-
366
- ```typescript
367
- import {
368
- shouldUseReactiveContent,
369
- extractContentConfig,
370
- interpolateStaticContent,
371
- fromContentWithInterpolation
372
- } from 'valtech-components';
373
-
374
- // Check if metadata should use reactive content
375
- const useReactive = shouldUseReactiveContent(metadata);
376
-
377
- // Extract configuration from metadata
378
- const config = extractContentConfig(metadata);
379
-
380
- // Interpolate static strings
381
- const result = interpolateStaticContent('Hello {{name}}!', { name: 'World' });
382
-
383
- // Helper for reactive content with interpolation
384
- const content$ = fromContentWithInterpolation(langService, metadata);
385
- ```
386
-
387
176
  ## πŸ”— Automatic Link Processing
388
177
 
389
178
  The library now includes automatic link detection and processing capabilities. Convert URLs and internal routes in text content into clickable links automatically:
@@ -453,15 +242,13 @@ processText(text: string) {
453
242
  - `src/lib/components/templates/` – Page templates and layouts
454
243
  - `src/lib/components/styles/` – Shared SCSS variables, mixins, and utilities
455
244
  - `src/lib/services/` – Core services:
456
- - `lang-provider/` – **LangService** for reactive internationalization
245
+ - `locale.service.ts` – Simple locale management with localStorage
457
246
  - `theme.service.ts` – Theme management
458
247
  - `navigation.service.ts` – Routing utilities
459
248
  - `download.service.ts` – File download helpers
460
249
  - `icons.service.ts` – Icon management
461
250
  - `toast.service.ts` – Toast notifications
462
251
  - `src/lib/shared/` – Shared utilities:
463
- - `utils/simple-content.ts` – Content system helpers and interfaces
464
- - `utils/content.ts` – Legacy content utilities (for backward compatibility)
465
252
  - `pipes/process-links.pipe.ts` – Automatic link processing
466
253
  - `constants/` – Shared constants
467
254
 
@@ -55,4 +55,4 @@ export var ToolbarActionType;
55
55
  ToolbarActionType["IMAGE"] = "IMAGE";
56
56
  ToolbarActionType["BUTTON"] = "BUTTON";
57
57
  })(ToolbarActionType || (ToolbarActionType = {}));
58
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../src/lib/components/types.ts"],"names":[],"mappings":"AAQA,MAAM,OAAO,GAAmB,SAAS,CAAC;AAC1C,MAAM,QAAQ,GAAmB,UAAU,CAAC;AAC5C,MAAM,OAAO,GAAmB,SAAS,CAAC;AAC1C,MAAM,KAAK,GAAmB,OAAO,CAAC;AAEtC;;GAEG;AACH,MAAM,CAAC,MAAM,eAAe,GAAG,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;AAErE;;GAEG;AACH,MAAM,CAAN,IAAY,UAMX;AAND,WAAY,UAAU;IACpB,iEAAe,CAAA;IACf,mEAAgB,CAAA;IAChB,iEAAe,CAAA;IACf,+DAAc,CAAA;IACd,uEAAkB,CAAA;AACpB,CAAC,EANW,UAAU,KAAV,UAAU,QAMrB;AAcD;;GAEG;AACH,MAAM,CAAN,IAAY,SAuBX;AAvBD,WAAY,SAAS;IACnB,yCAAI,CAAA;IACJ,iDAAQ,CAAA;IACR,2CAAK,CAAA;IACL,iDAAQ,CAAA;IACR,+CAAO,CAAA;IACP,6CAAM,CAAA;IACN,6DAAc,CAAA;IACd,iDAAQ,CAAA;IACR,yCAAI,CAAA;IACJ,qDAAU,CAAA;IACV,0CAAI,CAAA;IACJ,4CAAK,CAAA;IACL,4CAAK,CAAA;IACL,8CAAM,CAAA;IACN,4DAAa,CAAA;IACb,0DAAY,CAAA;IACZ,wEAAmB,CAAA;IACnB,0CAAI,CAAA;IACJ,8CAAM,CAAA;IACN,4CAAK,CAAA;IACL,4CAAK,CAAA;IACL,kDAAQ,CAAA;AACV,CAAC,EAvBW,SAAS,KAAT,SAAS,QAuBpB;AA6HD;;GAEG;AACH,MAAM,CAAN,IAAY,iBAKX;AALD,WAAY,iBAAiB;IAC3B,sCAAiB,CAAA;IACjB,kCAAa,CAAA;IACb,oCAAe,CAAA;IACf,sCAAiB,CAAA;AACnB,CAAC,EALW,iBAAiB,KAAjB,iBAAiB,QAK5B","sourcesContent":["import { FormControl, ValidatorFn } from '@angular/forms';\nimport { Color } from '@ionic/core';\nimport { ImageMetadata } from './atoms/image/types';\n\n/**\n * Possible states for an interactive component.\n */\nexport type ComponentState = 'ENABLED' | 'DISABLED' | 'WORKING' | 'ERROR';\nconst ENABLED: ComponentState = 'ENABLED';\nconst DISABLED: ComponentState = 'DISABLED';\nconst WORKING: ComponentState = 'WORKING';\nconst ERROR: ComponentState = 'ERROR';\n\n/**\n * Object containing all possible component states.\n */\nexport const ComponentStates = { ENABLED, DISABLED, WORKING, ERROR };\n\n/**\n * Types of actions that a button or link can perform.\n */\nexport enum ActionType {\n  BROWSER_NEW_TAB, // Open in a new browser tab\n  BROWSER_DOWNLOAD, // Download via browser\n  NATIVE_DOWNLOAD, // Download using native capabilities\n  APP_NAVIGATION, // Internal app navigation\n  BROWSER_NAVIGATION, // Navigation in the browser\n}\n\n/**\n * Represents an executable action for a button or link.\n */\nexport type Action = {\n  /** Action description */\n  description: string;\n  /** Action type */\n  type: ActionType;\n  /** Action source or destination */\n  source: string;\n};\n\n/**\n * Supported input types for forms.\n */\nexport enum InputType {\n  TEXT,\n  TEXTAREA,\n  EMAIL,\n  PASSWORD,\n  COMMENT,\n  NUMBER,\n  NUMBER_FROM_TO,\n  PIN_CODE,\n  DATE,\n  DATE_RANGE,\n  HOUR,\n  CHECK,\n  RADIO,\n  SELECT,\n  SEARCH_SELECT,\n  MULTI_SELECT,\n  MULTI_SELECT_SIMPLE,\n  FILE,\n  TOGGLE,\n  RANGE,\n  PHONE,\n  CURRENCY,\n}\n\n/**\n * Option for select, radio, etc. inputs.\n */\nexport type InputOption = {\n  /** Unique option identifier */\n  id: string;\n  /** Display name */\n  name: string;\n  /** Whether the option is selected by default */\n  selected?: boolean;\n  /** Display order */\n  order: number;\n};\n\n/**\n * Metadata for a form field.\n */\nexport type InputMetadata = {\n  /** Associated form control */\n  control: FormControl;\n  /** From control (only for NUMBER_FROM_TO type) */\n  fromControl?: FormControl;\n  /** To control (only for NUMBER_FROM_TO type) */\n  toControl?: FormControl;\n  /** Unique token for the input */\n  token: string;\n  /** Display label */\n  label: string;\n  /** Field name */\n  name: string;\n  /** Help text */\n  hint: string;\n  /** Input placeholder */\n  placeholder: string;\n  /** Input type */\n  type: InputType;\n  /** Display order */\n  order: number;\n  /** Associated validators */\n  validators: ValidatorFn[];\n  /** Options (for select, radio, etc.) */\n  options?: InputOption[];\n  /** Allowed range (for number, date, etc.) */\n  range?: {\n    min: number;\n    max: number;\n  };\n  /** Custom error messages */\n  errors: {\n    [key: string]: string;\n  };\n  /** Initial value for the field */\n  value?: string;\n  /** Default value configuration - string for custom defaults, true for auto defaults */\n  withDefault?: string | boolean;\n  /** Field state */\n  state: ComponentState;\n  /** Label for \"from\" field (only for NUMBER_FROM_TO type) */\n  fromLabel?: string;\n  /** Label for \"to\" field (only for NUMBER_FROM_TO type) */\n  toLabel?: string;\n  /** Placeholder for \"from\" field (only for NUMBER_FROM_TO type) */\n  fromPlaceholder?: string;\n  /** Placeholder for \"to\" field (only for NUMBER_FROM_TO type) */\n  toPlaceholder?: string;\n\n  // i18n support properties\n  /** Key for reactive content from LangService */\n  contentKey?: string;\n  /** Component class name for content lookup */\n  contentClass?: string;\n  /** Fallback text if content key is not found */\n  contentFallback?: string;\n\n  // select-input specific i18n properties\n  /** Custom header text for select modal */\n  modalHeader?: string;\n  /** Custom cancel button text for select modal */\n  cancelText?: string;\n  /** Custom OK button text for select modal */\n  okText?: string;\n\n  // check-input specific properties\n  /** Position of label for checkbox ('start' | 'end') */\n  labelPlacement?: 'start' | 'end';\n};\n\n/**\n * A section in a form, grouping multiple fields.\n */\nexport type FormSection = {\n  /** Section name */\n  name: string;\n  /** Display order */\n  order: number;\n  /** Fields included in the section */\n  fields: InputMetadata[];\n};\n\n/**\n * Data sent when submitting a form.\n */\nexport type FormSubmit = {\n  /** List of fields and their values */\n  fields: { key: string; value: string }[];\n  /** Optional token for the operation */\n  token?: string;\n};\n\n/**\n * Metadata for a complete form.\n */\nexport type FormMetadata = {\n  /** Form name */\n  name: string;\n  /** Form sections */\n  sections: FormSection[];\n  /** Action buttons configuration */\n  actions: ButtonMetadata;\n  /** Global form state */\n  state: ComponentState;\n};\n\n/**\n * Possible action types for a toolbar.\n */\nexport enum ToolbarActionType {\n  AVATAR = 'AVATAR',\n  ICON = 'ICON',\n  IMAGE = 'IMAGE',\n  BUTTON = 'BUTTON',\n}\n\n/**\n * Toolbar action definition.\n */\nexport type ToolbarAction = {\n  /** Action type */\n  type: 'AVATAR' | 'ICON' | 'IMAGE' | 'BUTTON';\n  /** Optional token identifier */\n  token?: string;\n  /** Toolbar position */\n  position: 'left' | 'right' | 'center';\n  /** Optional description */\n  description?: string;\n  /** Associated image (if any) */\n  image?: ImageMetadata;\n};\n\n/**\n * Metadata for an icon.\n */\nexport interface IconMetada {\n  /** Icon name */\n  name: string;\n  /** Icon slot position */\n  slot: 'start' | 'end';\n}\n\n/**\n * Button configuration object.\n * Supports both static and reactive content.\n * @type {ButtonMetadata}\n * @property text - Static button label (takes precedence over textConfig).\n * @property textConfig - Reactive content configuration for button text.\n * @property color - The button color (Ionic color string).\n * @property icon - Icon to display (optional).\n * @property state - Button state (enabled, disabled, working, etc.).\n * @property expand, fill, size, shape, href, target, download, handler, etc. - See ButtonMetadata for all options.\n */\nexport interface ButtonMetadata {\n  /** Associated action type */\n  actionType?: ActionType;\n  /** Button expansion */\n  expand?: 'full' | 'block';\n  /** Associated link */\n  link?: string;\n  /** Associated href link */\n  href?: string;\n  /** Link target */\n  target?: '_blank' | '_self' | '_parent' | '_top';\n  /** Download file name */\n  download?: string;\n  /** Button color */\n  color: Color;\n  /** Button state */\n  state: ComponentState;\n  /** Static display text (takes precedence over reactive content) */\n  text?: string;\n  /** Reactive content configuration for button text */\n  contentKey?: string;\n  /** Component class name for content lookup (required with contentKey) */\n  contentClass?: string;\n  /** Fallback text if contentKey is not found */\n  contentFallback?: string;\n  /** Values to interpolate into the content string */\n  contentInterpolation?: Record<string, string | number>;\n  /** Associated icon */\n  icon?: IconMetada;\n  /** Button shape */\n  shape?: 'round';\n  /** Button size */\n  size?: 'small' | 'default' | 'large';\n  /** Button fill */\n  fill?: 'clear' | 'outline' | 'solid' | 'default';\n  /** Button type */\n  type: 'button' | 'submit' | 'reset';\n  /** Optional token identifier */\n  token?: string;\n  /** Optional reference */\n  ref?: any;\n  /** Action handler */\n  handler?: (value: any) => any | Promise<any>;\n}\n\n/**\n * Configuration for reactive content in val-button component.\n * Use this interface when you only need to specify content-related properties.\n * This follows the same pattern as TextContentConfig for consistency.\n */\nexport interface ButtonContentConfig {\n  contentKey: string;\n  contentClass: string;\n  contentFallback?: string;\n  contentInterpolation?: Record<string, string | number>;\n}\n"]}
58
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../src/lib/components/types.ts"],"names":[],"mappings":"AAQA,MAAM,OAAO,GAAmB,SAAS,CAAC;AAC1C,MAAM,QAAQ,GAAmB,UAAU,CAAC;AAC5C,MAAM,OAAO,GAAmB,SAAS,CAAC;AAC1C,MAAM,KAAK,GAAmB,OAAO,CAAC;AAEtC;;GAEG;AACH,MAAM,CAAC,MAAM,eAAe,GAAG,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;AAErE;;GAEG;AACH,MAAM,CAAN,IAAY,UAMX;AAND,WAAY,UAAU;IACpB,iEAAe,CAAA;IACf,mEAAgB,CAAA;IAChB,iEAAe,CAAA;IACf,+DAAc,CAAA;IACd,uEAAkB,CAAA;AACpB,CAAC,EANW,UAAU,KAAV,UAAU,QAMrB;AAcD;;GAEG;AACH,MAAM,CAAN,IAAY,SAuBX;AAvBD,WAAY,SAAS;IACnB,yCAAI,CAAA;IACJ,iDAAQ,CAAA;IACR,2CAAK,CAAA;IACL,iDAAQ,CAAA;IACR,+CAAO,CAAA;IACP,6CAAM,CAAA;IACN,6DAAc,CAAA;IACd,iDAAQ,CAAA;IACR,yCAAI,CAAA;IACJ,qDAAU,CAAA;IACV,0CAAI,CAAA;IACJ,4CAAK,CAAA;IACL,4CAAK,CAAA;IACL,8CAAM,CAAA;IACN,4DAAa,CAAA;IACb,0DAAY,CAAA;IACZ,wEAAmB,CAAA;IACnB,0CAAI,CAAA;IACJ,8CAAM,CAAA;IACN,4CAAK,CAAA;IACL,4CAAK,CAAA;IACL,kDAAQ,CAAA;AACV,CAAC,EAvBW,SAAS,KAAT,SAAS,QAuBpB;AA6HD;;GAEG;AACH,MAAM,CAAN,IAAY,iBAKX;AALD,WAAY,iBAAiB;IAC3B,sCAAiB,CAAA;IACjB,kCAAa,CAAA;IACb,oCAAe,CAAA;IACf,sCAAiB,CAAA;AACnB,CAAC,EALW,iBAAiB,KAAjB,iBAAiB,QAK5B","sourcesContent":["import { FormControl, ValidatorFn } from '@angular/forms';\nimport { Color } from '@ionic/core';\nimport { ImageMetadata } from './atoms/image/types';\n\n/**\n * Possible states for an interactive component.\n */\nexport type ComponentState = 'ENABLED' | 'DISABLED' | 'WORKING' | 'ERROR';\nconst ENABLED: ComponentState = 'ENABLED';\nconst DISABLED: ComponentState = 'DISABLED';\nconst WORKING: ComponentState = 'WORKING';\nconst ERROR: ComponentState = 'ERROR';\n\n/**\n * Object containing all possible component states.\n */\nexport const ComponentStates = { ENABLED, DISABLED, WORKING, ERROR };\n\n/**\n * Types of actions that a button or link can perform.\n */\nexport enum ActionType {\n  BROWSER_NEW_TAB, // Open in a new browser tab\n  BROWSER_DOWNLOAD, // Download via browser\n  NATIVE_DOWNLOAD, // Download using native capabilities\n  APP_NAVIGATION, // Internal app navigation\n  BROWSER_NAVIGATION, // Navigation in the browser\n}\n\n/**\n * Represents an executable action for a button or link.\n */\nexport type Action = {\n  /** Action description */\n  description: string;\n  /** Action type */\n  type: ActionType;\n  /** Action source or destination */\n  source: string;\n};\n\n/**\n * Supported input types for forms.\n */\nexport enum InputType {\n  TEXT,\n  TEXTAREA,\n  EMAIL,\n  PASSWORD,\n  COMMENT,\n  NUMBER,\n  NUMBER_FROM_TO,\n  PIN_CODE,\n  DATE,\n  DATE_RANGE,\n  HOUR,\n  CHECK,\n  RADIO,\n  SELECT,\n  SEARCH_SELECT,\n  MULTI_SELECT,\n  MULTI_SELECT_SIMPLE,\n  FILE,\n  TOGGLE,\n  RANGE,\n  PHONE,\n  CURRENCY,\n}\n\n/**\n * Option for select, radio, etc. inputs.\n */\nexport type InputOption = {\n  /** Unique option identifier */\n  id: string;\n  /** Display name */\n  name: string;\n  /** Whether the option is selected by default */\n  selected?: boolean;\n  /** Display order */\n  order: number;\n};\n\n/**\n * Metadata for a form field.\n */\nexport type InputMetadata = {\n  /** Associated form control */\n  control: FormControl;\n  /** From control (only for NUMBER_FROM_TO type) */\n  fromControl?: FormControl;\n  /** To control (only for NUMBER_FROM_TO type) */\n  toControl?: FormControl;\n  /** Unique token for the input */\n  token: string;\n  /** Display label */\n  label: string;\n  /** Field name */\n  name: string;\n  /** Help text */\n  hint: string;\n  /** Input placeholder */\n  placeholder: string;\n  /** Input type */\n  type: InputType;\n  /** Display order */\n  order: number;\n  /** Associated validators */\n  validators: ValidatorFn[];\n  /** Options (for select, radio, etc.) */\n  options?: InputOption[];\n  /** Allowed range (for number, date, etc.) */\n  range?: {\n    min: number;\n    max: number;\n  };\n  /** Custom error messages */\n  errors: {\n    [key: string]: string;\n  };\n  /** Initial value for the field */\n  value?: string;\n  /** Default value configuration - string for custom defaults, true for auto defaults */\n  withDefault?: string | boolean;\n  /** Field state */\n  state: ComponentState;\n  /** Label for \"from\" field (only for NUMBER_FROM_TO type) */\n  fromLabel?: string;\n  /** Label for \"to\" field (only for NUMBER_FROM_TO type) */\n  toLabel?: string;\n  /** Placeholder for \"from\" field (only for NUMBER_FROM_TO type) */\n  fromPlaceholder?: string;\n  /** Placeholder for \"to\" field (only for NUMBER_FROM_TO type) */\n  toPlaceholder?: string;\n\n  // i18n support properties\n  /** Key for content lookup */\n  contentKey?: string;\n  /** Component class name for content lookup */\n  contentClass?: string;\n  /** Fallback text if content key is not found */\n  contentFallback?: string;\n\n  // select-input specific i18n properties\n  /** Custom header text for select modal */\n  modalHeader?: string;\n  /** Custom cancel button text for select modal */\n  cancelText?: string;\n  /** Custom OK button text for select modal */\n  okText?: string;\n\n  // check-input specific properties\n  /** Position of label for checkbox ('start' | 'end') */\n  labelPlacement?: 'start' | 'end';\n};\n\n/**\n * A section in a form, grouping multiple fields.\n */\nexport type FormSection = {\n  /** Section name */\n  name: string;\n  /** Display order */\n  order: number;\n  /** Fields included in the section */\n  fields: InputMetadata[];\n};\n\n/**\n * Data sent when submitting a form.\n */\nexport type FormSubmit = {\n  /** List of fields and their values */\n  fields: { key: string; value: string }[];\n  /** Optional token for the operation */\n  token?: string;\n};\n\n/**\n * Metadata for a complete form.\n */\nexport type FormMetadata = {\n  /** Form name */\n  name: string;\n  /** Form sections */\n  sections: FormSection[];\n  /** Action buttons configuration */\n  actions: ButtonMetadata;\n  /** Global form state */\n  state: ComponentState;\n};\n\n/**\n * Possible action types for a toolbar.\n */\nexport enum ToolbarActionType {\n  AVATAR = 'AVATAR',\n  ICON = 'ICON',\n  IMAGE = 'IMAGE',\n  BUTTON = 'BUTTON',\n}\n\n/**\n * Toolbar action definition.\n */\nexport type ToolbarAction = {\n  /** Action type */\n  type: 'AVATAR' | 'ICON' | 'IMAGE' | 'BUTTON';\n  /** Optional token identifier */\n  token?: string;\n  /** Toolbar position */\n  position: 'left' | 'right' | 'center';\n  /** Optional description */\n  description?: string;\n  /** Associated image (if any) */\n  image?: ImageMetadata;\n};\n\n/**\n * Metadata for an icon.\n */\nexport interface IconMetada {\n  /** Icon name */\n  name: string;\n  /** Icon slot position */\n  slot: 'start' | 'end';\n}\n\n/**\n * Button configuration object.\n * Supports both static and reactive content.\n * @type {ButtonMetadata}\n * @property text - Static button label (takes precedence over textConfig).\n * @property textConfig - Reactive content configuration for button text.\n * @property color - The button color (Ionic color string).\n * @property icon - Icon to display (optional).\n * @property state - Button state (enabled, disabled, working, etc.).\n * @property expand, fill, size, shape, href, target, download, handler, etc. - See ButtonMetadata for all options.\n */\nexport interface ButtonMetadata {\n  /** Associated action type */\n  actionType?: ActionType;\n  /** Button expansion */\n  expand?: 'full' | 'block';\n  /** Associated link */\n  link?: string;\n  /** Associated href link */\n  href?: string;\n  /** Link target */\n  target?: '_blank' | '_self' | '_parent' | '_top';\n  /** Download file name */\n  download?: string;\n  /** Button color */\n  color: Color;\n  /** Button state */\n  state: ComponentState;\n  /** Static display text (takes precedence over reactive content) */\n  text?: string;\n  /** Reactive content configuration for button text */\n  contentKey?: string;\n  /** Component class name for content lookup (required with contentKey) */\n  contentClass?: string;\n  /** Fallback text if contentKey is not found */\n  contentFallback?: string;\n  /** Values to interpolate into the content string */\n  contentInterpolation?: Record<string, string | number>;\n  /** Associated icon */\n  icon?: IconMetada;\n  /** Button shape */\n  shape?: 'round';\n  /** Button size */\n  size?: 'small' | 'default' | 'large';\n  /** Button fill */\n  fill?: 'clear' | 'outline' | 'solid' | 'default';\n  /** Button type */\n  type: 'button' | 'submit' | 'reset';\n  /** Optional token identifier */\n  token?: string;\n  /** Optional reference */\n  ref?: any;\n  /** Action handler */\n  handler?: (value: any) => any | Promise<any>;\n}\n\n/**\n * Configuration for reactive content in val-button component.\n * Use this interface when you only need to specify content-related properties.\n * This follows the same pattern as TextContentConfig for consistency.\n */\nexport interface ButtonContentConfig {\n  contentKey: string;\n  contentClass: string;\n  contentFallback?: string;\n  contentInterpolation?: Record<string, string | number>;\n}\n"]}