design-angular-kit 1.0.0-prerelease.1 → 1.0.0-prerelease.2
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 +184 -106
- package/esm2022/lib/abstracts/abstract-form.component.mjs +6 -6
- package/esm2022/lib/abstracts/abstract.component.mjs +5 -5
- package/esm2022/lib/components/core/accordion/accordion.component.mjs +7 -6
- package/esm2022/lib/components/core/alert/alert.component.mjs +5 -6
- package/esm2022/lib/components/core/avatar/avatar-dropdown/avatar-dropdown.component.mjs +10 -10
- package/esm2022/lib/components/core/avatar/avatar-group/avatar-group.component.mjs +10 -10
- package/esm2022/lib/components/core/avatar/avatar.directive.mjs +4 -4
- package/esm2022/lib/components/core/avatar/avatar.module.mjs +33 -0
- package/esm2022/lib/components/core/badge/badge.directive.mjs +4 -4
- package/esm2022/lib/components/core/button/button.directive.mjs +6 -6
- package/esm2022/lib/components/core/callout/callout.component.mjs +6 -6
- package/esm2022/lib/components/core/card/card.component.mjs +6 -6
- package/esm2022/lib/components/core/carousel/carousel/carousel.component.mjs +13 -10
- package/esm2022/lib/components/core/carousel/carousel-item/carousel-item.component.mjs +3 -3
- package/esm2022/lib/components/core/carousel/carousel.module.mjs +7 -12
- package/esm2022/lib/components/core/chip/chip.component.mjs +80 -40
- package/esm2022/lib/components/core/collapse/collapse.component.mjs +4 -4
- package/esm2022/lib/components/core/dimmer/dimmer-buttons/dimmer-buttons.component.mjs +3 -3
- package/esm2022/lib/components/core/dimmer/dimmer-icon/dimmer-icon.component.mjs +3 -3
- package/esm2022/lib/components/core/dimmer/dimmer.component.mjs +27 -31
- package/esm2022/lib/components/core/dimmer/dimmer.module.mjs +7 -15
- package/esm2022/lib/components/core/dropdown/dropdown/dropdown.component.mjs +10 -7
- package/esm2022/lib/components/core/dropdown/dropdown-item/dropdown-item.component.mjs +5 -6
- package/esm2022/lib/components/core/dropdown/dropdown.module.mjs +6 -6
- package/esm2022/lib/components/core/forward/forward.directive.mjs +6 -6
- package/esm2022/lib/components/core/link/link.component.mjs +6 -6
- package/esm2022/lib/components/core/list/list/list.component.mjs +6 -6
- package/esm2022/lib/components/core/list/list-item/list-item.component.mjs +6 -6
- package/esm2022/lib/components/core/list/list.module.mjs +7 -12
- package/esm2022/lib/components/core/modal/modal.component.mjs +6 -7
- package/esm2022/lib/components/core/notifications/notifications.component.mjs +8 -9
- package/esm2022/lib/components/core/pagination/pagination.component.mjs +19 -16
- package/esm2022/lib/components/core/popover/popover.directive.mjs +5 -5
- package/esm2022/lib/components/core/progress-bar/progress-bar.component.mjs +7 -7
- package/esm2022/lib/components/core/progress-button/progress-button.component.mjs +5 -6
- package/esm2022/lib/components/core/spinner/spinner.component.mjs +5 -6
- package/esm2022/lib/components/core/steppers/steppers-container/steppers-container.component.mjs +15 -11
- package/esm2022/lib/components/core/steppers/steppers-item/steppers-item.component.mjs +7 -6
- package/esm2022/lib/components/core/steppers/steppers.module.mjs +7 -12
- package/esm2022/lib/components/core/tab/tab-container/tab-container.component.mjs +12 -9
- package/esm2022/lib/components/core/tab/tab-item/tab-item.component.mjs +3 -3
- package/esm2022/lib/components/core/tab/tab.module.mjs +7 -12
- package/esm2022/lib/components/core/table/sort/sort-header/sort-header.component.mjs +10 -12
- package/esm2022/lib/components/core/table/sort/sort.directive.mjs +6 -6
- package/esm2022/lib/components/core/table/table.component.mjs +3 -3
- package/esm2022/lib/components/core/table/table.module.mjs +19 -0
- package/esm2022/lib/components/core/tooltip/tooltip.directive.mjs +5 -5
- package/esm2022/lib/components/form/autocomplete/autocomplete.component.mjs +17 -6
- package/esm2022/lib/components/form/checkbox/checkbox.component.mjs +6 -6
- package/esm2022/lib/components/form/form.module.mjs +4 -4
- package/esm2022/lib/components/form/input/input.component.mjs +6 -6
- package/esm2022/lib/components/form/password-input/password-input.component.mjs +8 -8
- package/esm2022/lib/components/form/radio-button/radio-button.component.mjs +9 -7
- package/esm2022/lib/components/form/range/range.component.mjs +11 -11
- package/esm2022/lib/components/form/rating/rating.component.mjs +5 -6
- package/esm2022/lib/components/form/select/select.component.mjs +6 -6
- package/esm2022/lib/components/form/textarea/textarea.component.mjs +6 -6
- package/esm2022/lib/components/form/upload-drag-drop/upload-drag-drop.component.mjs +12 -10
- package/esm2022/lib/components/form/upload-file-list/upload-file-list.component.mjs +7 -7
- package/esm2022/lib/components/navigation/back-button/back-button.component.mjs +7 -7
- package/esm2022/lib/components/navigation/back-to-top/back-to-top.component.mjs +4 -4
- package/esm2022/lib/components/navigation/breadcrumbs/breadcrumb/breadcrumb.component.mjs +13 -17
- package/esm2022/lib/components/navigation/breadcrumbs/breadcrumb-item/breadcrumb-item.component.mjs +3 -3
- package/esm2022/lib/components/navigation/breadcrumbs/breadcrumbs.module.mjs +6 -6
- package/esm2022/lib/components/navigation/header/header.component.mjs +21 -7
- package/esm2022/lib/components/navigation/megamenu/megamenu.component.mjs +27 -0
- package/esm2022/lib/components/navigation/navbar/navbar/navbar.component.mjs +5 -6
- package/esm2022/lib/components/navigation/navbar/navbar-item/navbar-item.component.mjs +5 -7
- package/esm2022/lib/components/navigation/navbar/navbar.module.mjs +6 -6
- package/esm2022/lib/components/utils/error-page/error-page.component.mjs +6 -7
- package/esm2022/lib/components/utils/icon/icon.component.mjs +18 -16
- package/esm2022/lib/components/utils/language-switcher/language-switcher.component.mjs +12 -9
- package/esm2022/lib/design-angular-kit.module.mjs +201 -56
- package/esm2022/lib/interfaces/design-angular-kit-config.mjs +7 -0
- package/esm2022/lib/pipes/date-ago.pipe.mjs +5 -5
- package/esm2022/lib/pipes/duration.pipe.mjs +4 -4
- package/esm2022/lib/pipes/mark-matching-text.pipe.mjs +5 -5
- package/esm2022/lib/provide-design-angular-kit.mjs +61 -0
- package/esm2022/lib/services/notification/notification.service.mjs +3 -3
- package/esm2022/lib/utils/date-utils.mjs +1 -1
- package/esm2022/lib/utils/file-utils.mjs +1 -1
- package/esm2022/lib/validators/it-validators.mjs +1 -1
- package/esm2022/public_api.mjs +10 -9
- package/fesm2022/design-angular-kit.mjs +1500 -1394
- package/fesm2022/design-angular-kit.mjs.map +1 -1
- package/lib/components/core/accordion/accordion.component.d.ts +1 -1
- package/lib/components/core/avatar/avatar.module.d.ts +9 -0
- package/lib/components/core/chip/chip.component.d.ts +24 -13
- package/lib/components/core/dimmer/dimmer.component.d.ts +2 -2
- package/lib/components/core/dropdown/dropdown/dropdown.component.d.ts +7 -1
- package/lib/components/core/pagination/pagination.component.d.ts +1 -1
- package/lib/components/core/progress-bar/progress-bar.component.d.ts +1 -1
- package/lib/components/core/steppers/steppers-container/steppers-container.component.d.ts +1 -1
- package/lib/components/core/steppers/steppers-item/steppers-item.component.d.ts +1 -1
- package/lib/components/core/table/sort/sort-header/sort-header.component.d.ts +2 -2
- package/lib/components/core/table/table.module.d.ts +9 -0
- package/lib/components/form/autocomplete/autocomplete.component.d.ts +7 -1
- package/lib/components/form/radio-button/radio-button.component.d.ts +1 -1
- package/lib/components/form/upload-drag-drop/upload-drag-drop.component.d.ts +13 -7
- package/lib/components/form/upload-file-list/upload-file-list.component.d.ts +1 -1
- package/lib/components/navigation/breadcrumbs/breadcrumb/breadcrumb.component.d.ts +0 -5
- package/lib/components/navigation/header/header.component.d.ts +7 -1
- package/lib/components/navigation/megamenu/megamenu.component.d.ts +22 -0
- package/lib/components/utils/icon/icon.component.d.ts +14 -6
- package/lib/design-angular-kit.module.d.ts +43 -8
- package/lib/interfaces/design-angular-kit-config.d.ts +30 -0
- package/lib/pipes/date-ago.pipe.d.ts +3 -3
- package/lib/provide-design-angular-kit.d.ts +7 -0
- package/package.json +8 -7
- package/public_api.d.ts +9 -7
- package/esm2022/lib/components/components.module.mjs +0 -218
- package/esm2022/lib/design-angular-kit-config.mjs +0 -15
- package/esm2022/lib/interfaces/design-angular-kit-init.mjs +0 -2
- package/lib/components/components.module.d.ts +0 -45
- package/lib/design-angular-kit-config.d.ts +0 -16
- package/lib/interfaces/design-angular-kit-init.d.ts +0 -7
package/README.md
CHANGED
|
@@ -26,25 +26,14 @@
|
|
|
26
26
|
</p>
|
|
27
27
|
|
|
28
28
|
<p align="center">
|
|
29
|
-
<a href="https://github.com/semantic-release/semantic-release">
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
<a href="https://github.com/prettier/prettier">
|
|
33
|
-
<img src="https://img.shields.io/badge/code%20style-prettier-ff69b4?logo=Prettier" alt="code style: prettier" />
|
|
34
|
-
</a>
|
|
35
|
-
<a href="https://github.com/eslint/eslint">
|
|
36
|
-
<img src="https://img.shields.io/badge/formatter-angular--eslint-4B32C3?logo=eslint" alt="formatter: angular-eslint" />
|
|
37
|
-
</a>
|
|
29
|
+
<a href="https://github.com/semantic-release/semantic-release"><img src="https://img.shields.io/badge/semantic--release-angular-e10079?logo=semantic-release" alt="semantic-release: angular" /></a>
|
|
30
|
+
<a href="https://github.com/prettier/prettier"><img src="https://img.shields.io/badge/code%20style-prettier-ff69b4?logo=Prettier" alt="code style: prettier" /></a>
|
|
31
|
+
<a href="https://github.com/eslint/eslint"><img src="https://img.shields.io/badge/formatter-angular--eslint-4B32C3?logo=eslint" alt="formatter: angular-eslint" /></a>
|
|
38
32
|
</p>
|
|
39
33
|
|
|
40
34
|
<p align="center">
|
|
41
|
-
<a href="https://developersitalia.slack.com/messages/C04H3C19D52/">
|
|
42
|
-
|
|
43
|
-
</a>
|
|
44
|
-
<a href="https://slack.developers.italia.it/">
|
|
45
|
-
<img src="https://slack.developers.italia.it/badge.svg" alt="Get invited" />
|
|
46
|
-
</a>
|
|
47
|
-
</p>
|
|
35
|
+
<a href="https://developersitalia.slack.com/messages/C04H3C19D52/"><img src="https://img.shields.io/badge/Slack%20channel-%23design--dev--angular-blue.svg" alt="Join the #design-dev-angular channel" /></a>
|
|
36
|
+
<a href="https://slack.developers.italia.it/"><img src="https://slack.developers.italia.it/badge.svg" alt="Get invited" /></a></p>
|
|
48
37
|
|
|
49
38
|
_⚠️ Attenzione: questo codice è ancora in fase di sviluppo e non è pronto per essere utilizzato! Stiamo lavorando all'aggiornamento per portare il kit alla versione 1.0.0, commenti e contributi di tutta la community sono più che benvenuti! Se si necessita della vecchia versione il codice e la sua documentazione possono essere reperiti [qua](https://github.com/italia/design-angular-kit/tree/0.x)._
|
|
50
39
|
|
|
@@ -69,7 +58,7 @@ Sul branch `main` potete trovare il codice dei lavori in corso e nella [mileston
|
|
|
69
58
|
- [Discussione sulla nuova release](https://github.com/italia/design-angular-kit/discussions/127)
|
|
70
59
|
- [Milestone 1.0.0](https://github.com/italia/design-angular-kit/milestone/3)
|
|
71
60
|
|
|
72
|
-
##
|
|
61
|
+
## Installazione
|
|
73
62
|
|
|
74
63
|
Design Angular Kit è disponibile su NPM, per installarlo su una applicazione esistente sulla quale provare la libreria (attualmente non stabile) esegui il comando
|
|
75
64
|
|
|
@@ -77,66 +66,128 @@ Design Angular Kit è disponibile su NPM, per installarlo su una applicazione es
|
|
|
77
66
|
npm install design-angular-kit@prerelease --save
|
|
78
67
|
```
|
|
79
68
|
|
|
80
|
-
|
|
69
|
+
Scegli la versione corrispondente alla tua versione Angular:
|
|
70
|
+
|
|
71
|
+
| Angular | design-angular-kit |
|
|
72
|
+
|---------|-----------------------|
|
|
73
|
+
| 17+ | v1.0.0-prerelease.2 + |
|
|
74
|
+
| 16+ | v1.0.0-17 + |
|
|
75
|
+
| 15+ | v1.0.0-2 + |
|
|
76
|
+
|
|
77
|
+
## Configurazione
|
|
78
|
+
|
|
79
|
+
### Configurazione app
|
|
80
|
+
|
|
81
|
+
La libreria `design-angular-kit` può essere utilizzata con i componenti _standalone_ o con l'applicazione che utilizza i moduli. Segui la sezione di
|
|
82
|
+
configurazione che corrisponde alla tua applicazione.
|
|
83
|
+
|
|
84
|
+
#### Applicazione standalone
|
|
85
|
+
|
|
86
|
+
Utilizza la funzione `provideDesignAngularKit` nella configurazione dell'applicazione `ApplicationConfig` per
|
|
87
|
+
poter inizializzare le funzionalità della libreria.
|
|
81
88
|
|
|
82
89
|
```typescript
|
|
83
|
-
import {
|
|
90
|
+
import { provideHttpClient } from '@angular/common/http';
|
|
91
|
+
import { provideAnimations } from '@angular/platform-browser/animations';
|
|
92
|
+
import { provideDesignAngularKit } from 'design-angular-kit';
|
|
93
|
+
|
|
94
|
+
export const appConfig: ApplicationConfig = {
|
|
95
|
+
providers: [
|
|
96
|
+
...
|
|
97
|
+
provideAnimations(), // Necessario per il funzionamento della libreria
|
|
98
|
+
provideHttpClient(), // Necessario per il funzionamento della libreria
|
|
99
|
+
provideDesignAngularKit(),
|
|
100
|
+
]
|
|
101
|
+
}
|
|
102
|
+
```
|
|
103
|
+
|
|
104
|
+
#### Applicazione modulare
|
|
105
|
+
|
|
106
|
+
È necessario importare `DesignAngularKitModule` all'interno del modulo principale dell'applicazione (solitamente denominato **AppModule**)
|
|
107
|
+
utilizzando il metodo `forRoot` per poter inizializzare le funzionalità della libreria e importare tutti i componenti.
|
|
108
|
+
|
|
109
|
+
```typescript
|
|
110
|
+
import { HttpClientModule } from '@angular/common/http';
|
|
111
|
+
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
|
|
112
|
+
import { DesignAngularKitModule } from 'design-angular-kit';
|
|
84
113
|
|
|
85
114
|
@NgModule({
|
|
86
115
|
imports: [
|
|
87
116
|
...
|
|
88
|
-
|
|
89
|
-
|
|
117
|
+
HttpClientModule, // Necessario per il funzionamento della libreria
|
|
118
|
+
BrowserAnimationsModule, // Necessario per il funzionamento della libreria
|
|
119
|
+
DesignAngularKitModule.forRoot()
|
|
90
120
|
]
|
|
91
121
|
})
|
|
122
|
+
export class AppModule { }
|
|
92
123
|
```
|
|
93
|
-
<details>
|
|
94
|
-
<summary>Configurazione custom della libreria</summary>
|
|
95
124
|
|
|
96
|
-
|
|
97
|
-
import {DesignAngularKitModule, DesignAngularKitInit} from 'design-angular-kit';
|
|
98
|
-
|
|
99
|
-
// Puoi aggiungere alla libreria una configurazione iniziale
|
|
100
|
-
const initConfig: DesignAngularKitInit | undefined = {
|
|
101
|
-
/**
|
|
102
|
-
* The initial path in the `href` attribute in the `IconComponent` component
|
|
103
|
-
* @default './bootstrap-italia/dist/svg/sprites.svg'
|
|
104
|
-
*/
|
|
105
|
-
iconHref: string | undefined,
|
|
106
|
-
};
|
|
107
|
-
|
|
108
|
-
@NgModule({
|
|
109
|
-
imports: [
|
|
110
|
-
...
|
|
111
|
-
DesignAngularKitModule.forRoot(initConfig)
|
|
112
|
-
]
|
|
113
|
-
})
|
|
114
|
-
```
|
|
115
|
-
</details>
|
|
125
|
+
Utilizza il metodo `forChild` durante l'importazione del modulo `DesignAngularKitModule` in altri moduli dell'applicazione per importare tutti i componenti della libreria.
|
|
116
126
|
|
|
117
|
-
Usa `ItComponentsModule` per importare tutti i componenti della libreria, in alternativa puoi importare solo i componenti/moduli di cui hai bisogno, ad es. Alert, Paginazione e Breadcrumb.
|
|
118
127
|
|
|
119
128
|
```typescript
|
|
120
|
-
import {
|
|
129
|
+
import { DesignAngularKitModule } from 'design-angular-kit';
|
|
121
130
|
|
|
122
131
|
@NgModule({
|
|
123
132
|
imports: [
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
ItBreadcrumbsModule // Include ItBreadcrumbComponent e ItBreadcrumbItemComponent
|
|
133
|
+
...
|
|
134
|
+
DesignAngularKitModule.forChild()
|
|
127
135
|
],
|
|
136
|
+
exports: [DesignAngularKitModule],
|
|
128
137
|
})
|
|
129
|
-
export class
|
|
130
|
-
|
|
138
|
+
export class SharedModule { }
|
|
139
|
+
```
|
|
131
140
|
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
141
|
+
#### Applicazione ibrida
|
|
142
|
+
|
|
143
|
+
Se nella tua applicazione è presente il modulo **AppModule** ma vuoi utilizzare i nostri componenti con la configurazione _standalone_,
|
|
144
|
+
utilizza la funzione `provideDesignAngularKit` all'interno del modulo principale dell'applicazione per poter inizializzare le funzionalità della libreria.
|
|
145
|
+
|
|
146
|
+
```typescript
|
|
147
|
+
import { HttpClientModule } from '@angular/common/http';
|
|
148
|
+
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
|
|
149
|
+
import { provideDesignAngularKit } from 'design-angular-kit';
|
|
150
|
+
|
|
151
|
+
@NgModule({
|
|
152
|
+
imports: [
|
|
153
|
+
...
|
|
154
|
+
HttpClientModule, // Necessario per il funzionamento della libreria
|
|
155
|
+
BrowserAnimationsModule, // Necessario per il funzionamento della libreria
|
|
156
|
+
],
|
|
157
|
+
providers: [
|
|
158
|
+
provideDesignAngularKit(),
|
|
159
|
+
]
|
|
137
160
|
})
|
|
138
|
-
export class
|
|
139
|
-
|
|
161
|
+
export class AppModule { }
|
|
162
|
+
```
|
|
163
|
+
|
|
164
|
+
#### Parametri di configurazione
|
|
165
|
+
|
|
166
|
+
Sia per la funzione `provideDesignAngularKit` che per il modulo `DesignAngularKitModule.forRoot()` è possibile utilizzare una configurazione iniziale [`DesignAngularKitConfig`](/projects/design-angular-kit/src/lib/interfaces/design-angular-kit-config.ts).
|
|
167
|
+
|
|
168
|
+
```typescript
|
|
169
|
+
import { provideDesignAngularKit, DesignAngularKitModule, DesignAngularKitConfig } from 'design-angular-kit';
|
|
170
|
+
|
|
171
|
+
// Puoi aggiungere alla libreria una configurazione iniziale
|
|
172
|
+
const initConfig: DesignAngularKitConfig | undefined = {
|
|
173
|
+
/**
|
|
174
|
+
* The bootstrap-italia asset folder path
|
|
175
|
+
* @default ./bootstrap-italia
|
|
176
|
+
*/
|
|
177
|
+
assetBasePath: string | undefined,
|
|
178
|
+
|
|
179
|
+
/**
|
|
180
|
+
* Load the <a href="https://italia.github.io/bootstrap-italia/docs/come-iniziare/introduzione/#fonts">bootstrap-italia fonts</a>
|
|
181
|
+
* @default true
|
|
182
|
+
*/
|
|
183
|
+
loadFont: boolean | undefined,
|
|
184
|
+
|
|
185
|
+
...
|
|
186
|
+
};
|
|
187
|
+
|
|
188
|
+
provideDesignAngularKit(initConfig)
|
|
189
|
+
|
|
190
|
+
DesignAngularKitModule.forRoot(initConfig)
|
|
140
191
|
```
|
|
141
192
|
|
|
142
193
|
### Importazione stili bootstrap-italia
|
|
@@ -150,8 +201,8 @@ Configura gli stili richiesti nel file `styles.scss`. Importa la libreria SCSS c
|
|
|
150
201
|
<details>
|
|
151
202
|
<summary>Come personalizzare e sovrascrivere le variabili di default della libreria (es. colori, font-family, misure, ecc.)</summary>
|
|
152
203
|
|
|
153
|
-
Bootstrap Italia eredita ed estende tutte le variabili di default di Bootstrap, sovrascrivendo
|
|
154
|
-
alcuni valori in fase di compilazione e impostandone di nuovi all’occorenza. Un esempio fra tutti è
|
|
204
|
+
Bootstrap Italia eredita ed estende tutte le variabili di default di Bootstrap, sovrascrivendo
|
|
205
|
+
alcuni valori in fase di compilazione e impostandone di nuovi all’occorenza. Un esempio fra tutti è
|
|
155
206
|
il valore del colore $primary che in Bootstrap Italia è rappresentato dal colore blu #0066CC,
|
|
156
207
|
tipico della libreria.
|
|
157
208
|
|
|
@@ -188,7 +239,8 @@ $font-family-monospace: 'Custom Font', 'Courier New', Courier, monospace;
|
|
|
188
239
|
|
|
189
240
|
Per aggiungere il supporto icone/assets, modifica il tuo `angular.json` aggiungendo:
|
|
190
241
|
|
|
191
|
-
```
|
|
242
|
+
```json
|
|
243
|
+
{
|
|
192
244
|
"assets": [
|
|
193
245
|
...
|
|
194
246
|
{
|
|
@@ -197,7 +249,8 @@ Per aggiungere il supporto icone/assets, modifica il tuo `angular.json` aggiunge
|
|
|
197
249
|
"output": "/bootstrap-italia/"
|
|
198
250
|
}
|
|
199
251
|
]
|
|
200
|
-
|
|
252
|
+
}
|
|
253
|
+
```
|
|
201
254
|
|
|
202
255
|
### Supporto i18n (localizzazione)
|
|
203
256
|
|
|
@@ -205,8 +258,9 @@ La libreria usa [ngx-translate](https://github.com/ngx-translate/core) per aggiu
|
|
|
205
258
|
|
|
206
259
|
Modifica il tuo `angular.json` aggiungendo:
|
|
207
260
|
|
|
208
|
-
```
|
|
209
|
-
|
|
261
|
+
```json
|
|
262
|
+
{
|
|
263
|
+
"assets": [
|
|
210
264
|
...
|
|
211
265
|
{
|
|
212
266
|
"glob": "**/*",
|
|
@@ -214,71 +268,95 @@ Modifica il tuo `angular.json` aggiungendo:
|
|
|
214
268
|
"output": "/bootstrap-italia/i18n/"
|
|
215
269
|
}
|
|
216
270
|
]
|
|
217
|
-
|
|
271
|
+
}
|
|
272
|
+
```
|
|
273
|
+
Puoi utilizzare le label localizzate della libreria `design-angular-kit` nella tua applicazione, ad esempio `{{'it.errors.required-field' | translate}}`. [Vedi le nostre label](projects/design-angular-kit/assets/i18n/it.json)
|
|
218
274
|
|
|
219
275
|
#### Localizzazione esistente
|
|
220
276
|
|
|
221
277
|
Se utilizzi già i file di localizzazione nella tua app, puoi utilizzare la libreria [ngx-translate-multi-http-loader](https://www.npmjs.com/package/ngx-translate-multi-http-loader)
|
|
222
|
-
per caricare i file di localizzazione dell'app
|
|
278
|
+
per caricare sia i file di localizzazione dell'app che quelli della libreria `design-angular-kit`
|
|
279
|
+
|
|
223
280
|
|
|
224
|
-
|
|
281
|
+
**Utilizzando la funzione `provideDesignAngularKit`:**
|
|
225
282
|
|
|
226
283
|
```typescript
|
|
227
|
-
@
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
284
|
+
import { HttpBackend } from '@angular/common/http';
|
|
285
|
+
import { TranslateLoader } from '@ngx-translate/core';
|
|
286
|
+
import { MultiTranslateHttpLoader } from 'ngx-translate-multi-http-loader';
|
|
287
|
+
import { provideDesignAngularKit } from 'design-angular-kit';
|
|
288
|
+
|
|
289
|
+
provideDesignAngularKit({
|
|
290
|
+
translateLoader: (itPrefix: string, itSuffix: string) => ({
|
|
291
|
+
provide: TranslateLoader,
|
|
292
|
+
useFactory: (http: HttpBackend) => new MultiTranslateHttpLoader(http, [
|
|
293
|
+
{ prefix: itPrefix, suffix: itSuffix }, // Load library translations first, so you can edit the keys in your localization file
|
|
294
|
+
{ prefix: './assets/i18n/' }, // Your i18n location
|
|
295
|
+
]),
|
|
296
|
+
deps: [HttpBackend]
|
|
297
|
+
}),
|
|
298
|
+
})
|
|
299
|
+
```
|
|
300
|
+
|
|
301
|
+
**Utilizzando il modulo `DesignAngularKitModule`:**
|
|
302
|
+
```typescript
|
|
303
|
+
import { HttpBackend } from '@angular/common/http';
|
|
304
|
+
import { TranslateLoader } from '@ngx-translate/core';
|
|
305
|
+
import { MultiTranslateHttpLoader } from 'ngx-translate-multi-http-loader';
|
|
306
|
+
import { DesignAngularKitModule } from 'design-angular-kit';
|
|
307
|
+
|
|
308
|
+
DesignAngularKitModule.forRoot({
|
|
309
|
+
translateLoader: (itPrefix: string, itSuffix: string) => ({
|
|
310
|
+
provide: TranslateLoader,
|
|
311
|
+
useFactory: (http: HttpBackend) => new MultiTranslateHttpLoader(http, [
|
|
312
|
+
{ prefix: itPrefix, suffix: itSuffix }, // Load library translations first, so you can edit the keys in your localization file
|
|
313
|
+
{ prefix: './assets/i18n/' }, // Your i18n location
|
|
314
|
+
]),
|
|
315
|
+
deps: [HttpBackend]
|
|
316
|
+
}),
|
|
244
317
|
})
|
|
245
318
|
```
|
|
246
319
|
|
|
247
|
-
|
|
320
|
+
#### Personalizzazione della localizzazione
|
|
248
321
|
|
|
249
|
-
|
|
322
|
+
Se vuoi personalizzare le nostre label:
|
|
323
|
+
- Non includere il supporto i18n nel tuo `angular.json`
|
|
324
|
+
- Crea i tuoi file di localizzazione personalizzati nella tua cartella `assets/bootstrap-italia/i18n/` (crea il percorso se non esiste)
|
|
325
|
+
- Il json deve avere [questo formato](projects/design-angular-kit/assets/i18n/it.json).
|
|
326
|
+
- Aggiungi nella configurazione iniziale della libreria il `translateLoader` custom, sostituendo la stringa `assets/bootstrap-italia/i18n/` all'attributo `itPrefix`
|
|
327
|
+
- Oppure, aggiungi le localizzazioni nei tuoi file json, sovrascrivendo le [chiavi del json della libreria](projects/design-angular-kit/assets/i18n/it.json).
|
|
250
328
|
|
|
251
|
-
|
|
329
|
+
## Utilizzo
|
|
252
330
|
|
|
253
|
-
|
|
331
|
+
Utilizzando il modulo `DesignAngularKitModule` tutti i componenti della libreria verranno importati nell'applicazione.
|
|
332
|
+
|
|
333
|
+
In alternativa, poiché tutti i nostri componenti e direttive sono _standalone_, puoi importare solo i componenti/moduli di cui hai bisogno, ad es. Alert, Paginazione e Breadcrumb.
|
|
254
334
|
|
|
255
335
|
```typescript
|
|
336
|
+
import { ItAlertComponent, ItPaginationComponent, ItBreadcrumbsModule } from 'design-angular-kit';
|
|
337
|
+
|
|
256
338
|
@NgModule({
|
|
257
339
|
imports: [
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
providers: [
|
|
262
|
-
TranslateStore
|
|
340
|
+
ItAlertComponent,
|
|
341
|
+
ItPaginationComponent,
|
|
342
|
+
ItBreadcrumbsModule // Include ItBreadcrumbComponent e ItBreadcrumbItemComponent
|
|
263
343
|
],
|
|
264
344
|
})
|
|
345
|
+
export class YourAppModule {
|
|
346
|
+
}
|
|
265
347
|
```
|
|
266
348
|
|
|
267
|
-
Se vuoi personalizzare le nostre label:
|
|
268
|
-
- Non includere il supporto i18n nel tuo `angular.json` ma crea i tuoi file di localizzazione personalizzati nella tua cartella `assets/bootstrap-italia/i18n/` (crea il percorso se non esiste).
|
|
269
|
-
- Il json deve avere [questo formato](projects/design-angular-kit/assets/i18n/it.json).
|
|
270
|
-
|
|
271
|
-
### Supporto animazione
|
|
272
|
-
|
|
273
|
-
La libreria usa BrowserAnimationsModule per gestire alcune animazioni.
|
|
274
|
-
|
|
275
|
-
Per abilitarle, bisogna aggiungere al tuo `app.module.ts` il modulo :
|
|
276
|
-
|
|
277
349
|
```typescript
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
350
|
+
import { ItAlertComponent, ItPaginationComponent, ItBreadcrumbsModule } from 'design-angular-kit';
|
|
351
|
+
|
|
352
|
+
@Component({
|
|
353
|
+
selector: 'app-product',
|
|
354
|
+
standalone: true,
|
|
355
|
+
imports: [ItAlertComponent, ItPaginationComponent, ItBreadcrumbsModule],
|
|
356
|
+
templateUrl: './product.component.html'
|
|
357
|
+
})
|
|
358
|
+
export class ProductComponent {
|
|
359
|
+
}
|
|
282
360
|
```
|
|
283
361
|
|
|
284
362
|
## Segnalazione bug e richieste di aiuto
|
|
@@ -166,17 +166,17 @@ export class ItAbstractFormComponent extends ItAbstractComponent {
|
|
|
166
166
|
}
|
|
167
167
|
return this.control.getError(errorCode, path);
|
|
168
168
|
}
|
|
169
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
170
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "
|
|
169
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: ItAbstractFormComponent, deps: [{ token: i1.TranslateService }, { token: i2.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
170
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.1.2", type: ItAbstractFormComponent, selector: "ng-component", inputs: { label: "label", validationMode: "validationMode", disabled: ["disabled", "disabled", inputToBoolean] }, usesInheritance: true, ngImport: i0, template: '', isInline: true }); }
|
|
171
171
|
}
|
|
172
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
172
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: ItAbstractFormComponent, decorators: [{
|
|
173
173
|
type: Component,
|
|
174
174
|
args: [{ template: '' }]
|
|
175
|
-
}], ctorParameters:
|
|
175
|
+
}], ctorParameters: () => [{ type: i1.TranslateService }, { type: i2.NgControl, decorators: [{
|
|
176
176
|
type: Self
|
|
177
177
|
}, {
|
|
178
178
|
type: Optional
|
|
179
|
-
}] }]
|
|
179
|
+
}] }], propDecorators: { label: [{
|
|
180
180
|
type: Input
|
|
181
181
|
}], validationMode: [{
|
|
182
182
|
type: Input
|
|
@@ -184,4 +184,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.7", ngImpor
|
|
|
184
184
|
type: Input,
|
|
185
185
|
args: [{ transform: inputToBoolean }]
|
|
186
186
|
}] } });
|
|
187
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-form.component.js","sourceRoot":"","sources":["../../../../../projects/design-angular-kit/src/lib/abstracts/abstract-form.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAwB,WAAW,EAA0B,MAAM,gBAAgB,CAAC;AAC3F,OAAO,EAAE,SAAS,EAAW,KAAK,EAAU,QAAQ,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAClF,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAG3D,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;;;;AAGnD,MAAM,OAAgB,uBAAiC,SAAQ,mBAAmB;IAiBhF;;OAEG;IACH,IAA0C,QAAQ,CAAC,UAAmB;QACpE,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC;IACpC,CAAC;IAOD,YACqB,iBAAmC,EACf,UAAqB;QAE5D,KAAK,EAAE,CAAC;QAHW,sBAAiB,GAAjB,iBAAiB,CAAkB;QACf,eAAU,GAAV,UAAU,CAAW;QAxB9D;;;;;;;WAOG;QACM,mBAAc,GAA4C,cAAc,CAAC;QAoElF,aAAQ,GAAG,CAAC,CAAI,EAAE,EAAE;QACpB,CAAC,CAAC;QAEF,cAAS,GAAG,GAAG,EAAE;QACjB,CAAC,CAAC;QArDA,IAAI,CAAC,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;QACjC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,GAAG,IAAI,CAAC,CAAC;IAC5D,CAAC;IAED;;OAEG;IACH,IAAI,SAAS;QACX,IAAI,IAAI,CAAC,cAAc,KAAK,YAAY,IAAI,CAAC,IAAI,CAAC,cAAc,KAAK,cAAc,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE;YAC5G,OAAO,SAAS,CAAC;SAClB;QAED,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,OAAO,IAAI,CAAC,UAAU,CAAC,OAAO,KAAK,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,IAAI,IAAI,CAAC,UAAU,CAAC,OAAO,KAAK,IAAI,CAAC,CAAC;SAC5G;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IAClF,CAAC;IAED;;OAEG;IACH,IAAI,OAAO;QACT,IAAI,IAAI,CAAC,cAAc,KAAK,cAAc,IAAI,CAAC,IAAI,CAAC,cAAc,KAAK,YAAY,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE;YAC5G,OAAO,SAAS,CAAC;SAClB;QAED,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,KAAK,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,IAAI,IAAI,CAAC,UAAU,CAAC,OAAO,KAAK,IAAI,CAAC,CAAC;SAC1G;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,IAAI,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IAChF,CAAC;IAED;;OAEG;IACH,IAAI,cAAc;QAChB,IAAI,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE;YAC7B,OAAO,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,0BAA0B,CAAC,CAAC;SAC/D;QAED,OAAO,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,yBAAyB,CAAC,CAAC;IAC/D,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE;YAC5B,IAAI,CAAC,OAAO,CAAC,aAAa,CAAE,IAAI,CAAC,UAAU,CAAC,OAAuB,CAAC,SAAS,CAAC,CAAC;SAChF;IACH,CAAC;IAQD,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;QACxC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,UAAU,EAAE;YACd,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;SAC/B;QACD,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;IACxB,CAAC;IAED,UAAU,CAAC,KAAQ;QACjB,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;QACnD,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC;IAC1C,CAAC;IAED;;OAEG;IACH,aAAa;QACX,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE;YACzB,IAAI,CAAC,SAAS,EAAE,CAAC;SAClB;IACH,CAAC;IAED;;OAEG;IACH,SAAS;QACP,IAAI,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE;YAC5B,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC;YAC1C,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,KAAK,SAAS,CAAC,OAAO,EAAE;gBAC9C,IAAI,SAAS,CAAC,OAAO,EAAE;oBACrB,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC;iBAC9B;qBAAM;oBACL,IAAI,CAAC,OAAO,CAAC,eAAe,EAAE,CAAC;iBAChC;aACF;YACD,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,KAAK,SAAS,CAAC,QAAQ,EAAE;gBAChD,IAAI,SAAS,CAAC,QAAQ,EAAE;oBACtB,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;iBAC/B;qBAAM;oBACL,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;iBAC5B;aACF;SACF;QACD,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC;IAC1C,CAAC;IAED;;;;OAIG;IACO,aAAa,CAAC,UAAuC;QAC7D,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE;YAC9B,UAAU,GAAG,CAAC,UAAU,CAAC,CAAC;SAC3B;QAED,UAAU,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YAC7B,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE;gBACzC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;aACvC;YAED,IAAI,IAAI,CAAC,UAAU,EAAE,OAAO,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE;gBAChF,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;aAClD;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;OAOG;IACI,QAAQ,CAAC,SAAiB,EAAE,IAAsC;QACvE,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,OAAO,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;SAClD;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;IAChD,CAAC;IAED;;;;;;;OAOG;IACI,QAAQ,CAAC,SAAiB,EAAE,IAAsC;QACvE,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,OAAO,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;SAClD;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;IAChD,CAAC;8GAhMmB,uBAAuB;kGAAvB,uBAAuB,2HAoBvB,cAAc,oDArBb,EAAE;;2FACH,uBAAuB;kBAD5C,SAAS;mBAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;;0BAgCtB,IAAI;;0BAAI,QAAQ;4CA1BV,KAAK;sBAAb,KAAK;gBAUG,cAAc;sBAAtB,KAAK;gBAKoC,QAAQ;sBAAjD,KAAK;uBAAC,EAAE,SAAS,EAAE,cAAc,EAAE","sourcesContent":["import { ControlValueAccessor, FormControl, NgControl, ValidatorFn } from '@angular/forms';\nimport { Component, DoCheck, Input, OnInit, Optional, Self } from '@angular/core';\nimport { ItAbstractComponent } from './abstract.component';\nimport { Observable } from 'rxjs';\nimport { TranslateService } from '@ngx-translate/core';\nimport { inputToBoolean } from '../utils/coercion';\n\n@Component({ template: '' })\nexport abstract class ItAbstractFormComponent<T = any> extends ItAbstractComponent implements OnInit, ControlValueAccessor, DoCheck {\n\n  /**\n   * The label of form control\n   */\n  @Input() label?: string;\n\n  /**\n   * Validation color display mode (validation triggered if field is touched or not pristine)\n   * - <b>true</b>: Always show the validation color\n   * - <b>false</b>: Never show validation color\n   * - <b>only-valid</b>: Show only valid validation color\n   * - <b>only-invalid</b>: Show only invalid validation color\n   * @default <b>only-invalid</b>: Show only invalid validation color\n   */\n  @Input() validationMode: boolean | 'only-valid' | 'only-invalid' = 'only-invalid';\n\n  /**\n   * Set the disabled state\n   */\n  @Input({ transform: inputToBoolean }) set disabled(isDisabled: boolean) {\n    this.setDisabledState(isDisabled);\n  }\n\n  /**\n   * Internal form control\n   */\n  protected control: FormControl<T>;\n\n  constructor(\n    protected readonly _translateService: TranslateService,\n    @Self() @Optional() protected readonly _ngControl: NgControl\n  ) {\n    super();\n    this.control = new FormControl();\n    this._ngControl && (this._ngControl.valueAccessor = this);\n  }\n\n  /**\n   * Check if field is invalid (Validation failed)\n   */\n  get isInvalid(): boolean | undefined {\n    if (this.validationMode === 'only-valid' || (this.validationMode !== 'only-invalid' && !this.validationMode)) {\n      return undefined;\n    }\n\n    if (this._ngControl) {\n      return this._ngControl.invalid === true && (!this._ngControl.pristine || this._ngControl.touched === true);\n    }\n    return this.control.invalid && (!this.control.pristine || this.control.touched);\n  }\n\n  /**\n   * Check if field is valid (Validation successful)\n   */\n  get isValid(): boolean | undefined {\n    if (this.validationMode === 'only-invalid' || (this.validationMode !== 'only-valid' && !this.validationMode)) {\n      return undefined;\n    }\n\n    if (this._ngControl) {\n      return this._ngControl.valid === true && (!this._ngControl.pristine || this._ngControl.touched === true);\n    }\n    return this.control.valid && (!this.control.pristine || this.control.touched);\n  }\n\n  /**\n   * Return the invalid message string from TranslateService\n   */\n  get invalidMessage(): Observable<string> {\n    if (this.hasError('required')) {\n      return this._translateService.get('it.errors.required-field');\n    }\n\n    return this._translateService.get('it.errors.invalid-field');\n  }\n\n  ngOnInit(): void {\n    if (this._ngControl?.control) {\n      this.control.setValidators((this._ngControl.control as FormControl).validator);\n    }\n  }\n\n  onChange = (_: T) => {\n  };\n\n  onTouched = () => {\n  };\n\n  registerOnChange(fn: any): void {\n    this.control.valueChanges.subscribe(fn);\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    if (isDisabled) {\n      return this.control.disable();\n    }\n    this.control.enable();\n  }\n\n  writeValue(value: T): void {\n    this.control.setValue(value, { emitEvent: false });\n    this._changeDetectorRef.detectChanges();\n  }\n\n  /**\n   * Mark the control as touched\n   */\n  markAsTouched(): void {\n    if (!this.control.touched) {\n      this.onTouched();\n    }\n  }\n\n  /**\n   * Fired to check if form control is touched\n   */\n  ngDoCheck() {\n    if (this._ngControl?.control) {\n      const ngControl = this._ngControl.control;\n      if (this.control.touched !== ngControl.touched) {\n        if (ngControl.touched) {\n          this.control.markAsTouched();\n        } else {\n          this.control.markAsUntouched();\n        }\n      }\n      if (this.control.pristine !== ngControl.pristine) {\n        if (ngControl.pristine) {\n          this.control.markAsPristine();\n        } else {\n          this.control.markAsDirty();\n        }\n      }\n    }\n    this._changeDetectorRef.detectChanges();\n  }\n\n  /**\n   * Add the validators in control and parent control\n   * @param validators the validators\n   * @protected\n   */\n  protected addValidators(validators: ValidatorFn | ValidatorFn[]): void {\n    if (!Array.isArray(validators)) {\n      validators = [validators];\n    }\n\n    validators.forEach(validator => {\n      if (!this.control.hasValidator(validator)) {\n        this.control.addValidators(validator);\n      }\n\n      if (this._ngControl?.control && !this._ngControl.control.hasValidator(validator)) {\n        this._ngControl.control.addValidators(validator);\n      }\n    });\n  }\n\n  /**\n   * Reports whether the control with the given path has the error specified. <br/>\n   * If the control is not present, false is returned.\n   * @param errorCode The code of the error to check\n   * @param path A list of control names that designates how to move from the current control\n   * to the control that should be queried for errors.\n   * @returns whether the given error is present in the control at the given path.\n   */\n  public hasError(errorCode: string, path?: Array<string | number> | string): boolean {\n    if (this._ngControl) {\n      return this._ngControl.hasError(errorCode, path);\n    }\n    return this.control.hasError(errorCode, path);\n  }\n\n  /**\n   * Reports error data for the control with the given path.\n   * @param errorCode The code of the error to check\n   * @param path A list of control names that designates how to move from the current control\n   * to the control that should be queried for errors.\n   * @returns error data for that particular error. If the control or error is not present,\n   * null is returned.\n   */\n  public getError(errorCode: string, path?: Array<string | number> | string): any {\n    if (this._ngControl) {\n      return this._ngControl.getError(errorCode, path);\n    }\n    return this.control.getError(errorCode, path);\n  }\n}\n"]}
|
|
187
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-form.component.js","sourceRoot":"","sources":["../../../../../projects/design-angular-kit/src/lib/abstracts/abstract-form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ControlValueAccessor, FormControl, NgControl, ValidatorFn } from '@angular/forms';\nimport { Component, DoCheck, Input, OnInit, Optional, Self } from '@angular/core';\nimport { ItAbstractComponent } from './abstract.component';\nimport { Observable } from 'rxjs';\nimport { TranslateService } from '@ngx-translate/core';\nimport { inputToBoolean } from '../utils/coercion';\n\n@Component({ template: '' })\nexport abstract class ItAbstractFormComponent<T = any> extends ItAbstractComponent implements OnInit, ControlValueAccessor, DoCheck {\n\n  /**\n   * The label of form control\n   */\n  @Input() label?: string;\n\n  /**\n   * Validation color display mode (validation triggered if field is touched or not pristine)\n   * - <b>true</b>: Always show the validation color\n   * - <b>false</b>: Never show validation color\n   * - <b>only-valid</b>: Show only valid validation color\n   * - <b>only-invalid</b>: Show only invalid validation color\n   * @default <b>only-invalid</b>: Show only invalid validation color\n   */\n  @Input() validationMode: boolean | 'only-valid' | 'only-invalid' = 'only-invalid';\n\n  /**\n   * Set the disabled state\n   */\n  @Input({ transform: inputToBoolean }) set disabled(isDisabled: boolean) {\n    this.setDisabledState(isDisabled);\n  }\n\n  /**\n   * Internal form control\n   */\n  protected control: FormControl<T>;\n\n  constructor(\n    protected readonly _translateService: TranslateService,\n    @Self() @Optional() protected readonly _ngControl: NgControl\n  ) {\n    super();\n    this.control = new FormControl();\n    this._ngControl && (this._ngControl.valueAccessor = this);\n  }\n\n  /**\n   * Check if field is invalid (Validation failed)\n   */\n  get isInvalid(): boolean | undefined {\n    if (this.validationMode === 'only-valid' || (this.validationMode !== 'only-invalid' && !this.validationMode)) {\n      return undefined;\n    }\n\n    if (this._ngControl) {\n      return this._ngControl.invalid === true && (!this._ngControl.pristine || this._ngControl.touched === true);\n    }\n    return this.control.invalid && (!this.control.pristine || this.control.touched);\n  }\n\n  /**\n   * Check if field is valid (Validation successful)\n   */\n  get isValid(): boolean | undefined {\n    if (this.validationMode === 'only-invalid' || (this.validationMode !== 'only-valid' && !this.validationMode)) {\n      return undefined;\n    }\n\n    if (this._ngControl) {\n      return this._ngControl.valid === true && (!this._ngControl.pristine || this._ngControl.touched === true);\n    }\n    return this.control.valid && (!this.control.pristine || this.control.touched);\n  }\n\n  /**\n   * Return the invalid message string from TranslateService\n   */\n  get invalidMessage(): Observable<string> {\n    if (this.hasError('required')) {\n      return this._translateService.get('it.errors.required-field');\n    }\n\n    return this._translateService.get('it.errors.invalid-field');\n  }\n\n  ngOnInit(): void {\n    if (this._ngControl?.control) {\n      this.control.setValidators((this._ngControl.control as FormControl).validator);\n    }\n  }\n\n  onChange = (_: T) => {\n  };\n\n  onTouched = () => {\n  };\n\n  registerOnChange(fn: any): void {\n    this.control.valueChanges.subscribe(fn);\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    if (isDisabled) {\n      return this.control.disable();\n    }\n    this.control.enable();\n  }\n\n  writeValue(value: T): void {\n    this.control.setValue(value, { emitEvent: false });\n    this._changeDetectorRef.detectChanges();\n  }\n\n  /**\n   * Mark the control as touched\n   */\n  markAsTouched(): void {\n    if (!this.control.touched) {\n      this.onTouched();\n    }\n  }\n\n  /**\n   * Fired to check if form control is touched\n   */\n  ngDoCheck() {\n    if (this._ngControl?.control) {\n      const ngControl = this._ngControl.control;\n      if (this.control.touched !== ngControl.touched) {\n        if (ngControl.touched) {\n          this.control.markAsTouched();\n        } else {\n          this.control.markAsUntouched();\n        }\n      }\n      if (this.control.pristine !== ngControl.pristine) {\n        if (ngControl.pristine) {\n          this.control.markAsPristine();\n        } else {\n          this.control.markAsDirty();\n        }\n      }\n    }\n    this._changeDetectorRef.detectChanges();\n  }\n\n  /**\n   * Add the validators in control and parent control\n   * @param validators the validators\n   * @protected\n   */\n  protected addValidators(validators: ValidatorFn | ValidatorFn[]): void {\n    if (!Array.isArray(validators)) {\n      validators = [validators];\n    }\n\n    validators.forEach(validator => {\n      if (!this.control.hasValidator(validator)) {\n        this.control.addValidators(validator);\n      }\n\n      if (this._ngControl?.control && !this._ngControl.control.hasValidator(validator)) {\n        this._ngControl.control.addValidators(validator);\n      }\n    });\n  }\n\n  /**\n   * Reports whether the control with the given path has the error specified. <br/>\n   * If the control is not present, false is returned.\n   * @param errorCode The code of the error to check\n   * @param path A list of control names that designates how to move from the current control\n   * to the control that should be queried for errors.\n   * @returns whether the given error is present in the control at the given path.\n   */\n  public hasError(errorCode: string, path?: Array<string | number> | string): boolean {\n    if (this._ngControl) {\n      return this._ngControl.hasError(errorCode, path);\n    }\n    return this.control.hasError(errorCode, path);\n  }\n\n  /**\n   * Reports error data for the control with the given path.\n   * @param errorCode The code of the error to check\n   * @param path A list of control names that designates how to move from the current control\n   * to the control that should be queried for errors.\n   * @returns error data for that particular error. If the control or error is not present,\n   * null is returned.\n   */\n  public getError(errorCode: string, path?: Array<string | number> | string): any {\n    if (this._ngControl) {\n      return this._ngControl.getError(errorCode, path);\n    }\n    return this.control.getError(errorCode, path);\n  }\n}\n"]}
|
|
@@ -31,15 +31,15 @@ export class ItAbstractComponent {
|
|
|
31
31
|
const kebabName = name.replace(/[A-Z]+(?![a-z])|[A-Z]/g, ($, ofs) => (ofs ? '-' : '') + $.toLowerCase());
|
|
32
32
|
return `${kebabName}-${ItAbstractComponent.instances++}`;
|
|
33
33
|
}
|
|
34
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
35
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
34
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: ItAbstractComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
35
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: ItAbstractComponent, selector: "ng-component", inputs: { id: "id" }, outputs: { valueChanges: "valueChanges" }, usesOnChanges: true, ngImport: i0, template: '', isInline: true }); }
|
|
36
36
|
}
|
|
37
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
37
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: ItAbstractComponent, decorators: [{
|
|
38
38
|
type: Component,
|
|
39
39
|
args: [{ template: '' }]
|
|
40
|
-
}], ctorParameters:
|
|
40
|
+
}], ctorParameters: () => [], propDecorators: { id: [{
|
|
41
41
|
type: Input
|
|
42
42
|
}], valueChanges: [{
|
|
43
43
|
type: Output
|
|
44
44
|
}] } });
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzaWduLWFuZ3VsYXIta2l0L3NyYy9saWIvYWJzdHJhY3RzL2Fic3RyYWN0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsaUJBQWlCLEVBQ2pCLFNBQVMsRUFDVCxVQUFVLEVBQ1YsWUFBWSxFQUNaLE1BQU0sRUFDTixLQUFLLEVBRUwsTUFBTSxFQUNOLFNBQVMsRUFFVixNQUFNLGVBQWUsQ0FBQzs7QUFHdkIsTUFBTSxPQUFnQixtQkFBbUI7SUFZdkM7OztPQUdHO2FBQ1ksY0FBUyxHQUFHLENBQUMsQUFBSixDQUFLO0lBTzdCO1FBckJBOztXQUVHO1FBQ00sT0FBRSxHQUFXLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQW1CeEMsSUFBSSxDQUFDLFNBQVMsR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDbkMsSUFBSSxDQUFDLFdBQVcsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDdEMsSUFBSSxDQUFDLGtCQUFrQixHQUFHLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1FBRXBELElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztJQUMvQyxDQUFDO0lBRUQsZUFBZTtRQUNiLElBQUksQ0FBQyxTQUFTLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ3ZFLENBQUM7SUFFRCxXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLDBCQUEwQjtJQUN0RCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0ssWUFBWTtRQUNsQixNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQzVELE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsd0JBQXdCLEVBQUUsQ0FBQyxDQUFDLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztRQUN6RyxPQUFPLEdBQUcsU0FBUyxJQUFJLG1CQUFtQixDQUFDLFNBQVMsRUFBRSxFQUFFLENBQUM7SUFDM0QsQ0FBQzs4R0EvQ21CLG1CQUFtQjtrR0FBbkIsbUJBQW1CLDBJQURsQixFQUFFOzsyRkFDSCxtQkFBbUI7a0JBRHhDLFNBQVM7bUJBQUMsRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFO3dEQU1oQixFQUFFO3NCQUFWLEtBQUs7Z0JBS1csWUFBWTtzQkFBNUIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFmdGVyVmlld0luaXQsXG4gIENoYW5nZURldGVjdG9yUmVmLFxuICBDb21wb25lbnQsXG4gIEVsZW1lbnRSZWYsXG4gIEV2ZW50RW1pdHRlcixcbiAgaW5qZWN0LFxuICBJbnB1dCxcbiAgT25DaGFuZ2VzLFxuICBPdXRwdXQsXG4gIFJlbmRlcmVyMixcbiAgU2ltcGxlQ2hhbmdlc1xufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7IHRlbXBsYXRlOiAnJyB9KVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEl0QWJzdHJhY3RDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0LCBPbkNoYW5nZXMge1xuXG4gIC8qKlxuICAgKiBUaGUgZWxlbWVudCBJRFxuICAgKi9cbiAgQElucHV0KCkgaWQ6IHN0cmluZyA9IHRoaXMuZ2V0RGVmYXVsdElkKCk7XG5cbiAgLyoqXG4gICAqIEZpcmVkIHdoZW4gY29tcG9uZW50IGlucHV0IGF0dHJpYnV0ZXMgd2FzIGNoYW5nZWRcbiAgICovXG4gIEBPdXRwdXQoKSBwdWJsaWMgdmFsdWVDaGFuZ2VzOiBFdmVudEVtaXR0ZXI8dm9pZD47XG5cbiAgLyoqXG4gICAqIENvdW50ZXIgb2YgYWN0aXZlIGluc3RhbmNlc1xuICAgKiBAcHJpdmF0ZVxuICAgKi9cbiAgcHJpdmF0ZSBzdGF0aWMgaW5zdGFuY2VzID0gMDtcblxuXG4gIHByb3RlY3RlZCByZWFkb25seSBfcmVuZGVyZXI6IFJlbmRlcmVyMjsgLy8gSW5qZWN0ZWRcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IF9lbGVtZW50UmVmOiBFbGVtZW50UmVmOyAvLyBJbmplY3RlZFxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgX2NoYW5nZURldGVjdG9yUmVmOiBDaGFuZ2VEZXRlY3RvclJlZjsgLy8gSW5qZWN0ZWRcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLl9yZW5kZXJlciA9IGluamVjdChSZW5kZXJlcjIpO1xuICAgIHRoaXMuX2VsZW1lbnRSZWYgPSBpbmplY3QoRWxlbWVudFJlZik7XG4gICAgdGhpcy5fY2hhbmdlRGV0ZWN0b3JSZWYgPSBpbmplY3QoQ2hhbmdlRGV0ZWN0b3JSZWYpO1xuXG4gICAgdGhpcy52YWx1ZUNoYW5nZXMgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG4gIH1cblxuICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgdGhpcy5fcmVuZGVyZXIucmVtb3ZlQXR0cmlidXRlKHRoaXMuX2VsZW1lbnRSZWYubmF0aXZlRWxlbWVudCwgJ2lkJyk7XG4gIH1cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgdGhpcy52YWx1ZUNoYW5nZXMubmV4dCgpOyAvLyBUaGUgaW5wdXRzIHdlcmUgY2hhbmdlZFxuICB9XG5cbiAgLyoqXG4gICAqIEdlbmVyYXRlIHVuaXF1ZSBpZCBmb3IgY29tcG9uZW50c1xuICAgKiBAcHJpdmF0ZVxuICAgKi9cbiAgcHJpdmF0ZSBnZXREZWZhdWx0SWQoKTogc3RyaW5nIHtcbiAgICBjb25zdCBuYW1lID0gdGhpcy5jb25zdHJ1Y3Rvci5uYW1lLnJlcGxhY2UoJ0NvbXBvbmVudCcsICcnKTtcbiAgICBjb25zdCBrZWJhYk5hbWUgPSBuYW1lLnJlcGxhY2UoL1tBLVpdKyg/IVthLXpdKXxbQS1aXS9nLCAoJCwgb2ZzKSA9PiAob2ZzID8gJy0nIDogJycpICsgJC50b0xvd2VyQ2FzZSgpKTtcbiAgICByZXR1cm4gYCR7a2ViYWJOYW1lfS0ke0l0QWJzdHJhY3RDb21wb25lbnQuaW5zdGFuY2VzKyt9YDtcbiAgfVxufVxuIl19
|
|
@@ -23,16 +23,17 @@ export class ItAccordionComponent extends ItCollapseComponent {
|
|
|
23
23
|
this._changeDetectorRef.detectChanges();
|
|
24
24
|
});
|
|
25
25
|
}
|
|
26
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
27
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
26
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: ItAccordionComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
27
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: ItAccordionComponent, isStandalone: true, selector: "it-accordion", inputs: { title: "title" }, viewQueries: [{ propertyName: "collapseDiv", first: true, predicate: ["collapse"], descendants: true }], exportAs: ["itAccordion"], usesInheritance: true, ngImport: i0, template: "<div class=\"accordion\">\n <div class=\"accordion-item\">\n\n <h2 class=\"accordion-header\" id=\"collapse-{{id}}-heading\">\n <button\n class=\"accordion-button\"\n type=\"button\"\n data-bs-toggle=\"collapse\"\n [class.collapsed]=\"isCollapsed\"\n [attr.data-bs-target]=\"'#collapse-' + id\"\n [attr.aria-controls]=\"'collapse-' + id\"\n [attr.aria-expanded]=\"opened ? 'true' : 'false'\">\n {{title}}\n </button>\n </h2>\n\n <div #collapse id=\"collapse-{{id}}\" role=\"region\"\n class=\"accordion-collapse collapse {{class}}\"\n [attr.aria-labelledby]=\"'collapse-' + id + '-heading'\">\n\n <div class=\"accordion-body\">\n <ng-content></ng-content>\n </div>\n </div>\n </div>\n</div>\n\n", changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
28
28
|
}
|
|
29
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: ItAccordionComponent, decorators: [{
|
|
30
30
|
type: Component,
|
|
31
|
-
args: [{ standalone: true, selector: 'it-accordion
|
|
31
|
+
args: [{ standalone: true, selector: 'it-accordion', exportAs: 'itAccordion', changeDetection: ChangeDetectionStrategy.OnPush, imports: [], template: "<div class=\"accordion\">\n <div class=\"accordion-item\">\n\n <h2 class=\"accordion-header\" id=\"collapse-{{id}}-heading\">\n <button\n class=\"accordion-button\"\n type=\"button\"\n data-bs-toggle=\"collapse\"\n [class.collapsed]=\"isCollapsed\"\n [attr.data-bs-target]=\"'#collapse-' + id\"\n [attr.aria-controls]=\"'collapse-' + id\"\n [attr.aria-expanded]=\"opened ? 'true' : 'false'\">\n {{title}}\n </button>\n </h2>\n\n <div #collapse id=\"collapse-{{id}}\" role=\"region\"\n class=\"accordion-collapse collapse {{class}}\"\n [attr.aria-labelledby]=\"'collapse-' + id + '-heading'\">\n\n <div class=\"accordion-body\">\n <ng-content></ng-content>\n </div>\n </div>\n </div>\n</div>\n\n" }]
|
|
32
32
|
}], propDecorators: { title: [{
|
|
33
|
-
type: Input
|
|
33
|
+
type: Input,
|
|
34
|
+
args: [{ required: true }]
|
|
34
35
|
}], collapseDiv: [{
|
|
35
36
|
type: ViewChild,
|
|
36
37
|
args: ['collapse']
|
|
37
38
|
}] } });
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS9hY2NvcmRpb24vYWNjb3JkaW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS9hY2NvcmRpb24vYWNjb3JkaW9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBaUIsdUJBQXVCLEVBQUUsU0FBUyxFQUFjLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEgsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7O0FBRXJFOzs7R0FHRztBQVNILE1BQU0sT0FBTyxvQkFBcUIsU0FBUSxtQkFBbUI7SUFSN0Q7O1FBZ0JZLGdCQUFXLEdBQVksSUFBSSxDQUFDO0tBZ0J2QztJQWRVLGVBQWU7UUFDdEIsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxTQUFTLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBRXhFLElBQUksQ0FBQyxXQUFXLEdBQUcsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDO1FBQ2hDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUM1QixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQztZQUN4QixJQUFJLENBQUMsa0JBQWtCLENBQUMsYUFBYSxFQUFFLENBQUM7UUFDMUMsQ0FBQyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDNUIsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLENBQUM7WUFDekIsSUFBSSxDQUFDLGtCQUFrQixDQUFDLGFBQWEsRUFBRSxDQUFDO1FBQzFDLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs4R0F2QlUsb0JBQW9CO2tHQUFwQixvQkFBb0IsK1BDZmpDLHl5QkEyQkE7OzJGRFphLG9CQUFvQjtrQkFSaEMsU0FBUztpQ0FDSSxJQUFJLFlBQ04sY0FBYyxZQUVkLGFBQWEsbUJBQ04sdUJBQXVCLENBQUMsTUFBTSxXQUN0QyxFQUFFOzhCQU1nQixLQUFLO3NCQUEvQixLQUFLO3VCQUFDLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRTtnQkFFaUIsV0FBVztzQkFBcEQsU0FBUzt1QkFBQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRWxlbWVudFJlZiwgSW5wdXQsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSXRDb2xsYXBzZUNvbXBvbmVudCB9IGZyb20gJy4uL2NvbGxhcHNlL2NvbGxhcHNlLmNvbXBvbmVudCc7XG5cbi8qKlxuICogQWNjb3JkaW9uXG4gKiBAZGVzY3JpcHRpb24gQnVpbGQgdmVydGljYWxseSBjb2xsYXBzaWJsZSBhY2NvcmRpb25zIGJhc2VkIG9uIENvbGxhcHNlLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdpdC1hY2NvcmRpb24nLFxuICB0ZW1wbGF0ZVVybDogJy4vYWNjb3JkaW9uLmNvbXBvbmVudC5odG1sJyxcbiAgZXhwb3J0QXM6ICdpdEFjY29yZGlvbicsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBpbXBvcnRzOiBbXSxcbn0pXG5leHBvcnQgY2xhc3MgSXRBY2NvcmRpb25Db21wb25lbnQgZXh0ZW5kcyBJdENvbGxhcHNlQ29tcG9uZW50IGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCB7XG4gIC8qKlxuICAgKiBBY2NvcmRpb24gVGl0bGVcbiAgICovXG4gIEBJbnB1dCh7IHJlcXVpcmVkOiB0cnVlIH0pIHRpdGxlITogc3RyaW5nO1xuXG4gIEBWaWV3Q2hpbGQoJ2NvbGxhcHNlJykgcHJvdGVjdGVkIG92ZXJyaWRlIGNvbGxhcHNlRGl2PzogRWxlbWVudFJlZjxIVE1MRGl2RWxlbWVudD47XG5cbiAgcHJvdGVjdGVkIGlzQ29sbGFwc2VkOiBib29sZWFuID0gdHJ1ZTtcblxuICBvdmVycmlkZSBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgc3VwZXIubmdBZnRlclZpZXdJbml0KCk7XG4gICAgdGhpcy5fcmVuZGVyZXIucmVtb3ZlQXR0cmlidXRlKHRoaXMuX2VsZW1lbnRSZWYubmF0aXZlRWxlbWVudCwgJ3RpdGxlJyk7XG5cbiAgICB0aGlzLmlzQ29sbGFwc2VkID0gIXRoaXMub3BlbmVkO1xuICAgIHRoaXMuaGlkZUV2ZW50LnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICB0aGlzLmlzQ29sbGFwc2VkID0gdHJ1ZTtcbiAgICAgIHRoaXMuX2NoYW5nZURldGVjdG9yUmVmLmRldGVjdENoYW5nZXMoKTtcbiAgICB9KTtcbiAgICB0aGlzLnNob3dFdmVudC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgdGhpcy5pc0NvbGxhcHNlZCA9IGZhbHNlO1xuICAgICAgdGhpcy5fY2hhbmdlRGV0ZWN0b3JSZWYuZGV0ZWN0Q2hhbmdlcygpO1xuICAgIH0pO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiYWNjb3JkaW9uXCI+XG4gIDxkaXYgY2xhc3M9XCJhY2NvcmRpb24taXRlbVwiPlxuXG4gICAgPGgyIGNsYXNzPVwiYWNjb3JkaW9uLWhlYWRlclwiIGlkPVwiY29sbGFwc2Ute3tpZH19LWhlYWRpbmdcIj5cbiAgICAgIDxidXR0b25cbiAgICAgICAgY2xhc3M9XCJhY2NvcmRpb24tYnV0dG9uXCJcbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIGRhdGEtYnMtdG9nZ2xlPVwiY29sbGFwc2VcIlxuICAgICAgICBbY2xhc3MuY29sbGFwc2VkXT1cImlzQ29sbGFwc2VkXCJcbiAgICAgICAgW2F0dHIuZGF0YS1icy10YXJnZXRdPVwiJyNjb2xsYXBzZS0nICsgaWRcIlxuICAgICAgICBbYXR0ci5hcmlhLWNvbnRyb2xzXT1cIidjb2xsYXBzZS0nICsgaWRcIlxuICAgICAgICBbYXR0ci5hcmlhLWV4cGFuZGVkXT1cIm9wZW5lZCA/ICd0cnVlJyA6ICdmYWxzZSdcIj5cbiAgICAgICAge3t0aXRsZX19XG4gICAgICA8L2J1dHRvbj5cbiAgICA8L2gyPlxuXG4gICAgPGRpdiAjY29sbGFwc2UgaWQ9XCJjb2xsYXBzZS17e2lkfX1cIiByb2xlPVwicmVnaW9uXCJcbiAgICAgICAgIGNsYXNzPVwiYWNjb3JkaW9uLWNvbGxhcHNlIGNvbGxhcHNlIHt7Y2xhc3N9fVwiXG4gICAgICAgICBbYXR0ci5hcmlhLWxhYmVsbGVkYnldPVwiJ2NvbGxhcHNlLScgKyBpZCArICctaGVhZGluZydcIj5cblxuICAgICAgPGRpdiBjbGFzcz1cImFjY29yZGlvbi1ib2R5XCI+XG4gICAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbjwvZGl2PlxuXG4iXX0=
|