valtech-components 2.0.421 β 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
|
|
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
|
-
<!--
|
|
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
|
-
|
|
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
|
-
## π
|
|
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
|
-
|
|
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 {
|
|
153
|
+
import { LocaleService, LanguageSelectorComponent } from 'valtech-components';
|
|
222
154
|
|
|
223
155
|
@Component({
|
|
224
156
|
template: `
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
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
|
-
|
|
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
|
-
|
|
166
|
+
// Get current locale
|
|
167
|
+
currentLocale = this.localeService.getLocale(); // 'es', 'en', etc.
|
|
279
168
|
|
|
280
|
-
|
|
281
|
-
//
|
|
282
|
-
|
|
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
|
-
- `
|
|
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"]}
|