design-angular-kit 1.1.0 → 1.1.1
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 +66 -60
- package/esm2022/lib/components/core/dimmer/dimmer.component.mjs +5 -5
- package/esm2022/lib/components/form/form.module.mjs +5 -1
- package/esm2022/lib/components/form/transfer/store/transfer.reducers.mjs +191 -0
- package/esm2022/lib/components/form/transfer/store/transfer.state.mjs +2 -0
- package/esm2022/lib/components/form/transfer/store/transfer.store.mjs +70 -0
- package/esm2022/lib/components/form/transfer/transfer-list/transfer-list.component.mjs +70 -0
- package/esm2022/lib/components/form/transfer/transfer.component.mjs +147 -0
- package/esm2022/lib/components/form/transfer/transfer.model.mjs +6 -0
- package/esm2022/lib/components/navigation/navscroll/navscroll-list-item.component.mjs +98 -0
- package/esm2022/lib/components/navigation/navscroll/navscroll-list-items.component.mjs +44 -0
- package/esm2022/lib/components/navigation/navscroll/navscroll.component.mjs +116 -0
- package/esm2022/lib/components/navigation/navscroll/navscroll.model.mjs +2 -0
- package/esm2022/lib/components/navigation/navscroll/navscroll.store.mjs +65 -0
- package/esm2022/lib/components/navigation/navscroll/navscroll.utils.mjs +23 -0
- package/esm2022/lib/design-angular-kit.module.mjs +10 -6
- package/esm2022/lib/provide-design-angular-kit.mjs +5 -5
- package/esm2022/public_api.mjs +25 -21
- package/fesm2022/design-angular-kit.mjs +1045 -255
- package/fesm2022/design-angular-kit.mjs.map +1 -1
- package/lib/components/form/form.module.d.ts +4 -3
- package/lib/components/form/transfer/store/transfer.reducers.d.ts +103 -0
- package/lib/components/form/transfer/store/transfer.state.d.ts +18 -0
- package/lib/components/form/transfer/store/transfer.store.d.ts +23 -0
- package/lib/components/form/transfer/transfer-list/transfer-list.component.d.ts +48 -0
- package/lib/components/form/transfer/transfer.component.d.ts +75 -0
- package/lib/components/form/transfer/transfer.model.d.ts +6 -0
- package/lib/components/navigation/navscroll/navscroll-list-item.component.d.ts +16 -0
- package/lib/components/navigation/navscroll/navscroll-list-items.component.d.ts +7 -0
- package/lib/components/navigation/navscroll/navscroll.component.d.ts +47 -0
- package/lib/components/navigation/navscroll/navscroll.model.d.ts +10 -0
- package/lib/components/navigation/navscroll/navscroll.store.d.ts +16 -0
- package/lib/components/navigation/navscroll/navscroll.utils.d.ts +6 -0
- package/lib/design-angular-kit.module.d.ts +8 -7
- package/package.json +5 -1
- package/public_api.d.ts +24 -20
- package/schematics/collection.json +19 -0
- package/schematics/ng-add/index.d.ts +3 -0
- package/schematics/ng-add/index.js +29 -0
- package/schematics/ng-add/index.js.map +1 -0
- package/schematics/ng-add/index.spec.d.ts +1 -0
- package/schematics/ng-add/index.spec.js +43 -0
- package/schematics/ng-add/index.spec.js.map +1 -0
- package/schematics/ng-add/rules/setup-project/add-animations.d.ts +2 -0
- package/schematics/ng-add/rules/setup-project/add-animations.js +11 -0
- package/schematics/ng-add/rules/setup-project/add-animations.js.map +1 -0
- package/schematics/ng-add/rules/setup-project/add-assets.d.ts +3 -0
- package/schematics/ng-add/rules/setup-project/add-assets.js +50 -0
- package/schematics/ng-add/rules/setup-project/add-assets.js.map +1 -0
- package/schematics/ng-add/rules/setup-project/add-design-angular-kit.d.ts +3 -0
- package/schematics/ng-add/rules/setup-project/add-design-angular-kit.js +43 -0
- package/schematics/ng-add/rules/setup-project/add-design-angular-kit.js.map +1 -0
- package/schematics/ng-add/rules/setup-project/add-http-client.d.ts +2 -0
- package/schematics/ng-add/rules/setup-project/add-http-client.js +11 -0
- package/schematics/ng-add/rules/setup-project/add-http-client.js.map +1 -0
- package/schematics/ng-add/rules/setup-project/add-import-to-style-file.d.ts +11 -0
- package/schematics/ng-add/rules/setup-project/add-import-to-style-file.js +112 -0
- package/schematics/ng-add/rules/setup-project/add-import-to-style-file.js.map +1 -0
- package/schematics/ng-add/rules/setup-project/add-localisation.d.ts +3 -0
- package/schematics/ng-add/rules/setup-project/add-localisation.js +50 -0
- package/schematics/ng-add/rules/setup-project/add-localisation.js.map +1 -0
- package/schematics/ng-add/rules/setup-project/angular-json-helper.d.ts +2 -0
- package/schematics/ng-add/rules/setup-project/angular-json-helper.js +13 -0
- package/schematics/ng-add/rules/setup-project/angular-json-helper.js.map +1 -0
- package/schematics/ng-add/rules/setup-project/exceptions.d.ts +7 -0
- package/schematics/ng-add/rules/setup-project/exceptions.js +17 -0
- package/schematics/ng-add/rules/setup-project/exceptions.js.map +1 -0
- package/schematics/ng-add/rules/setup-project/index.d.ts +6 -0
- package/schematics/ng-add/rules/setup-project/index.js +23 -0
- package/schematics/ng-add/rules/setup-project/index.js.map +1 -0
- package/schematics/ng-add/schema.d.ts +3 -0
- package/schematics/ng-add/schema.js +3 -0
- package/schematics/ng-add/schema.js.map +1 -0
- package/schematics/ng-add/schema.json +16 -0
- package/schematics/ng-add/setup-project.d.ts +3 -0
- package/schematics/ng-add/setup-project.js +37 -0
- package/schematics/ng-add/setup-project.js.map +1 -0
- package/schematics/ng-add/setup-project.spec.d.ts +1 -0
- package/schematics/ng-add/setup-project.spec.js +139 -0
- package/schematics/ng-add/setup-project.spec.js.map +1 -0
- package/schematics/ng-add/utils.d.ts +14 -0
- package/schematics/ng-add/utils.js +49 -0
- package/schematics/ng-add/utils.js.map +1 -0
- package/schematics/ng-add/versions-helper.d.ts +3 -0
- package/schematics/ng-add/versions-helper.js +40 -0
- package/schematics/ng-add/versions-helper.js.map +1 -0
package/README.md
CHANGED
|
@@ -64,10 +64,25 @@ npm install design-angular-kit --save
|
|
|
64
64
|
Scegli la versione corrispondente alla tua versione Angular:
|
|
65
65
|
|
|
66
66
|
| Angular | design-angular-kit |
|
|
67
|
-
|
|
67
|
+
| ------- | ------------------ |
|
|
68
68
|
| 18+ | v1.1.0 + |
|
|
69
69
|
| 17+ | v1.0.0 + |
|
|
70
70
|
|
|
71
|
+
In alternativa, puoi lanciar il comando
|
|
72
|
+
|
|
73
|
+
```sh
|
|
74
|
+
ng add design-angular-kit --project <projectName>
|
|
75
|
+
```
|
|
76
|
+
|
|
77
|
+
Eseguirà in serie:
|
|
78
|
+
|
|
79
|
+
- scelta della corretta versione da installare
|
|
80
|
+
- installazione della dipendenza
|
|
81
|
+
- aggiunta della dipendenza al package.json
|
|
82
|
+
- configurazione dell'applicazione
|
|
83
|
+
|
|
84
|
+
Le istruzioni del paragrafo successivo, **Configurazione**, verranno eseguite automaticamente, eccetto per la personalizzazione della configurazione di _i18n_.
|
|
85
|
+
|
|
71
86
|
## Configurazione
|
|
72
87
|
|
|
73
88
|
### Configurazione app
|
|
@@ -84,49 +99,39 @@ poter inizializzare le funzionalità della libreria.
|
|
|
84
99
|
import { provideDesignAngularKit } from 'design-angular-kit';
|
|
85
100
|
|
|
86
101
|
export const appConfig: ApplicationConfig = {
|
|
87
|
-
providers: [
|
|
88
|
-
|
|
89
|
-
provideDesignAngularKit(),
|
|
90
|
-
]
|
|
91
|
-
}
|
|
102
|
+
providers: [...provideDesignAngularKit()],
|
|
103
|
+
};
|
|
92
104
|
```
|
|
93
105
|
|
|
94
106
|
#### Applicazione modulare
|
|
95
107
|
|
|
96
|
-
È necessario importare `DesignAngularKitModule` all'interno del modulo principale dell'applicazione (solitamente denominato **AppModule**)
|
|
108
|
+
È necessario importare `DesignAngularKitModule` all'interno del modulo principale dell'applicazione (solitamente denominato **AppModule**)
|
|
97
109
|
utilizzando il metodo `forRoot` per poter inizializzare le funzionalità della libreria e **importare tutti i componenti**.
|
|
98
110
|
|
|
99
111
|
```typescript
|
|
100
112
|
import { DesignAngularKitModule } from 'design-angular-kit';
|
|
101
113
|
|
|
102
114
|
@NgModule({
|
|
103
|
-
imports: [
|
|
104
|
-
...
|
|
105
|
-
DesignAngularKitModule.forRoot()
|
|
106
|
-
]
|
|
115
|
+
imports: [...DesignAngularKitModule.forRoot()],
|
|
107
116
|
})
|
|
108
|
-
export class AppModule {
|
|
117
|
+
export class AppModule {}
|
|
109
118
|
```
|
|
110
119
|
|
|
111
120
|
Utilizza il metodo `forChild` durante l'importazione del modulo `DesignAngularKitModule` in altri moduli dell'applicazione per **importare tutti i componenti** della libreria.
|
|
112
121
|
|
|
113
|
-
|
|
114
122
|
```typescript
|
|
115
123
|
import { DesignAngularKitModule } from 'design-angular-kit';
|
|
116
124
|
|
|
117
125
|
@NgModule({
|
|
118
|
-
imports: [
|
|
119
|
-
...
|
|
120
|
-
DesignAngularKitModule.forChild()
|
|
121
|
-
],
|
|
126
|
+
imports: [...DesignAngularKitModule.forChild()],
|
|
122
127
|
exports: [DesignAngularKitModule],
|
|
123
128
|
})
|
|
124
|
-
export class SharedModule {
|
|
129
|
+
export class SharedModule {}
|
|
125
130
|
```
|
|
126
131
|
|
|
127
132
|
#### Applicazione ibrida
|
|
128
133
|
|
|
129
|
-
Se nella tua applicazione è presente il modulo **AppModule** ma vuoi utilizzare i nostri **componenti con la configurazione _standalone_**,
|
|
134
|
+
Se nella tua applicazione è presente il modulo **AppModule** ma vuoi utilizzare i nostri **componenti con la configurazione _standalone_**,
|
|
130
135
|
utilizza la funzione `provideDesignAngularKit` all'interno del modulo principale dell'applicazione per poter inizializzare le funzionalità della libreria.
|
|
131
136
|
|
|
132
137
|
```typescript
|
|
@@ -134,11 +139,9 @@ import { provideDesignAngularKit } from 'design-angular-kit';
|
|
|
134
139
|
|
|
135
140
|
@NgModule({
|
|
136
141
|
imports: [],
|
|
137
|
-
providers: [
|
|
138
|
-
provideDesignAngularKit(),
|
|
139
|
-
]
|
|
142
|
+
providers: [provideDesignAngularKit()],
|
|
140
143
|
})
|
|
141
|
-
export class AppModule {
|
|
144
|
+
export class AppModule {}
|
|
142
145
|
```
|
|
143
146
|
|
|
144
147
|
#### Parametri di configurazione
|
|
@@ -161,7 +164,7 @@ const initConfig: DesignAngularKitConfig | undefined = {
|
|
|
161
164
|
* @default true
|
|
162
165
|
*/
|
|
163
166
|
loadFont: boolean | undefined,
|
|
164
|
-
|
|
167
|
+
|
|
165
168
|
...
|
|
166
169
|
};
|
|
167
170
|
|
|
@@ -171,11 +174,12 @@ DesignAngularKitModule.forRoot(initConfig)
|
|
|
171
174
|
```
|
|
172
175
|
|
|
173
176
|
### Importazione stili bootstrap-italia
|
|
177
|
+
|
|
174
178
|
Configura gli stili richiesti nel file `styles.scss`. Importa la libreria SCSS come mostrato nell'esempio qui sotto.
|
|
175
179
|
|
|
176
180
|
```scss
|
|
177
181
|
// Importazione libreria SCSS di bootstrap-italia
|
|
178
|
-
@import
|
|
182
|
+
@import 'bootstrap-italia/src/scss/bootstrap-italia';
|
|
179
183
|
```
|
|
180
184
|
|
|
181
185
|
<details>
|
|
@@ -190,7 +194,6 @@ L’utilizzo del blu #0066CC dovrebbe però essere riservato alle amministrazion
|
|
|
190
194
|
Stato, e quindi ci si può trovare nella condizione di dover personalizzare i valori delle variabili
|
|
191
195
|
colore di Bootstrap Italia, impostando nuovi valori per le proprie necessità.
|
|
192
196
|
|
|
193
|
-
|
|
194
197
|
Questo colore e le altre tonalità vengono generate a partire dalla terna HSB, pertanto occorre modificare le variabili primary-h, primary-s e primary-b.
|
|
195
198
|
Per avere la corrispondenza tra valore esadecimale del colore e HSB si può utilizzare il portale rgb.to, ad esempio https://rgb.to/0066CC.
|
|
196
199
|
|
|
@@ -213,6 +216,7 @@ $font-family-monospace: 'Custom Font', 'Courier New', Courier, monospace;
|
|
|
213
216
|
// Importazione libreria SCSS di bootstrap-italia
|
|
214
217
|
@import 'bootstrap-italia/src/scss/bootstrap-italia';
|
|
215
218
|
```
|
|
219
|
+
|
|
216
220
|
</details>
|
|
217
221
|
|
|
218
222
|
### Supporto icone e assets
|
|
@@ -250,6 +254,7 @@ Modifica il tuo `angular.json` aggiungendo:
|
|
|
250
254
|
]
|
|
251
255
|
}
|
|
252
256
|
```
|
|
257
|
+
|
|
253
258
|
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)
|
|
254
259
|
|
|
255
260
|
#### Localizzazione esistente
|
|
@@ -257,7 +262,6 @@ Puoi utilizzare le label localizzate della libreria `design-angular-kit` nella t
|
|
|
257
262
|
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)
|
|
258
263
|
per caricare sia i file di localizzazione dell'app che quelli della libreria `design-angular-kit`
|
|
259
264
|
|
|
260
|
-
|
|
261
265
|
**Utilizzando la funzione `provideDesignAngularKit`:**
|
|
262
266
|
|
|
263
267
|
```typescript
|
|
@@ -269,16 +273,18 @@ import { provideDesignAngularKit } from 'design-angular-kit';
|
|
|
269
273
|
provideDesignAngularKit({
|
|
270
274
|
translateLoader: (itPrefix: string, itSuffix: string) => ({
|
|
271
275
|
provide: TranslateLoader,
|
|
272
|
-
useFactory: (http: HttpBackend) =>
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
276
|
+
useFactory: (http: HttpBackend) =>
|
|
277
|
+
new MultiTranslateHttpLoader(http, [
|
|
278
|
+
{ prefix: itPrefix, suffix: itSuffix }, // Load library translations first, so you can edit the keys in your localization file
|
|
279
|
+
{ prefix: './assets/i18n/' }, // Your i18n location
|
|
280
|
+
]),
|
|
281
|
+
deps: [HttpBackend],
|
|
277
282
|
}),
|
|
278
|
-
})
|
|
283
|
+
});
|
|
279
284
|
```
|
|
280
285
|
|
|
281
286
|
**Utilizzando il modulo `DesignAngularKitModule`:**
|
|
287
|
+
|
|
282
288
|
```typescript
|
|
283
289
|
import { HttpBackend } from '@angular/common/http';
|
|
284
290
|
import { TranslateLoader } from '@ngx-translate/core';
|
|
@@ -288,22 +294,24 @@ import { DesignAngularKitModule } from 'design-angular-kit';
|
|
|
288
294
|
DesignAngularKitModule.forRoot({
|
|
289
295
|
translateLoader: (itPrefix: string, itSuffix: string) => ({
|
|
290
296
|
provide: TranslateLoader,
|
|
291
|
-
useFactory: (http: HttpBackend) =>
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
297
|
+
useFactory: (http: HttpBackend) =>
|
|
298
|
+
new MultiTranslateHttpLoader(http, [
|
|
299
|
+
{ prefix: itPrefix, suffix: itSuffix }, // Load library translations first, so you can edit the keys in your localization file
|
|
300
|
+
{ prefix: './assets/i18n/' }, // Your i18n location
|
|
301
|
+
]),
|
|
302
|
+
deps: [HttpBackend],
|
|
296
303
|
}),
|
|
297
|
-
})
|
|
304
|
+
});
|
|
298
305
|
```
|
|
299
306
|
|
|
300
307
|
#### Personalizzazione della localizzazione
|
|
301
308
|
|
|
302
309
|
Se vuoi personalizzare le nostre label:
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
310
|
+
|
|
311
|
+
- Non includere il supporto i18n nel tuo `angular.json`
|
|
312
|
+
- Crea i tuoi file di localizzazione personalizzati nella tua cartella `assets/bootstrap-italia/i18n/` (crea il percorso se non esiste)
|
|
313
|
+
- Il json deve avere [questo formato](projects/design-angular-kit/assets/i18n/it.json).
|
|
314
|
+
- Aggiungi nella configurazione iniziale della libreria il `translateLoader` custom, sostituendo la stringa `assets/bootstrap-italia/i18n/` all'attributo `itPrefix`
|
|
307
315
|
- Oppure, aggiungi le localizzazioni nei tuoi file json, sovrascrivendo le [chiavi del json della libreria](projects/design-angular-kit/assets/i18n/it.json).
|
|
308
316
|
|
|
309
317
|
### Utilizzo
|
|
@@ -317,13 +325,12 @@ import { ItAlertComponent, ItPaginationComponent, ItBreadcrumbsModule } from 'de
|
|
|
317
325
|
|
|
318
326
|
@NgModule({
|
|
319
327
|
imports: [
|
|
320
|
-
ItAlertComponent,
|
|
321
|
-
ItPaginationComponent,
|
|
322
|
-
ItBreadcrumbsModule // Include ItBreadcrumbComponent e ItBreadcrumbItemComponent
|
|
328
|
+
ItAlertComponent,
|
|
329
|
+
ItPaginationComponent,
|
|
330
|
+
ItBreadcrumbsModule, // Include ItBreadcrumbComponent e ItBreadcrumbItemComponent
|
|
323
331
|
],
|
|
324
332
|
})
|
|
325
|
-
export class YourAppModule {
|
|
326
|
-
}
|
|
333
|
+
export class YourAppModule {}
|
|
327
334
|
```
|
|
328
335
|
|
|
329
336
|
```typescript
|
|
@@ -333,24 +340,23 @@ import { ItAlertComponent, ItPaginationComponent, ItBreadcrumbsModule } from 'de
|
|
|
333
340
|
selector: 'app-product',
|
|
334
341
|
standalone: true,
|
|
335
342
|
imports: [ItAlertComponent, ItPaginationComponent, ItBreadcrumbsModule],
|
|
336
|
-
templateUrl: './product.component.html'
|
|
343
|
+
templateUrl: './product.component.html',
|
|
337
344
|
})
|
|
338
|
-
export class ProductComponent {
|
|
339
|
-
}
|
|
345
|
+
export class ProductComponent {}
|
|
340
346
|
```
|
|
341
347
|
|
|
342
348
|
## Come contribuire 💙
|
|
343
349
|
|
|
344
350
|
👉🏻 È possibile contribuire alla libreria in vari modi:
|
|
345
351
|
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
352
|
+
- Con il proprio codice, prendendo in carico una issue tra quelle aperte e non già assegnate tra [le issue](https://github.com/italia/design-angular-kit/issues) di Angular Kit (è sufficiente anche un commento sulla issue per notificare la volontà di presa in carico).
|
|
353
|
+
- Attraverso la segnalazione di bug o miglioramenti al [repository ufficiale](https://github.com/italia/design-angular-kit/) di Angular Kit.
|
|
354
|
+
- Scrivendoci sul [canale dedicato](https://developersitalia.slack.com/messages/C04H3C19D52/) di Slack.
|
|
349
355
|
|
|
350
356
|
## Come contribuire con il codice
|
|
351
357
|
|
|
352
358
|
Vorresti dare una mano su Design Angular Kit? **Sei nel posto giusto!**
|
|
353
|
-
|
|
359
|
+
|
|
354
360
|
Se non l'hai già fatto, inizia spendendo qualche minuto per approfondire la tua conoscenza sulle
|
|
355
361
|
[linee guida di design per i servizi web della PA](https://design-italia.readthedocs.io/it/stable/index.html),
|
|
356
362
|
e fai riferimento alle [indicazioni su come contribuire a Design Angular Kit](https://github.com/italia/design-angular-kit/blob/main/CONTRIBUTING.md).
|
|
@@ -410,7 +416,7 @@ git clone https://github.com/italia/design-angular-kit.git
|
|
|
410
416
|
|
|
411
417
|
3. Al caricamento, Visual Studio Code riconoscerà la presenta della configurazione di un Devcontainer. Aprire il progetto con il devcontainer. Altre info [qui](https://code.visualstudio.com/docs/devcontainers/create-dev-container).
|
|
412
418
|
|
|
413
|
-
4. Visual Studio Code effettuerà il setup del container, andando ad installare la corretta versione di NodeJs, di npm e delle estensioni dell'IDE. Le dipendenze di progetto saranno installate nel processo di creazione del container. L'ambiente di sviuppo sarà pronto a setup ultimato.
|
|
419
|
+
4. Visual Studio Code effettuerà il setup del container, andando ad installare la corretta versione di NodeJs, di npm e delle estensioni dell'IDE. Le dipendenze di progetto saranno installate nel processo di creazione del container. L'ambiente di sviuppo sarà pronto a setup ultimato.
|
|
414
420
|
|
|
415
421
|
5. Lanciare l'applicazione in locale
|
|
416
422
|
|
|
@@ -438,9 +444,9 @@ npm run test
|
|
|
438
444
|
|
|
439
445
|
Un grazie speciale a chi ha reso possibile lo sviluppo di questa libreria
|
|
440
446
|
|
|
441
|
-
[](https://github.com/AntoninoBonanno) | [](https://github.com/cri99) | [](https://github.com/alenap93) |
|
|
442
|
-
|
|
443
|
-
Antonino Bonanno
|
|
447
|
+
| [](https://github.com/AntoninoBonanno) | [](https://github.com/cri99) | [](https://github.com/alenap93) |
|
|
448
|
+
| ---------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------- |
|
|
449
|
+
| Antonino Bonanno | Cristian Borelli | Alessio Napolitano |
|
|
444
450
|
|
|
445
451
|
e grazie in particolare al team di [NetService](https://www.net-serv.it/):
|
|
446
452
|
|
|
@@ -448,7 +454,7 @@ e grazie in particolare al team di [NetService](https://www.net-serv.it/):
|
|
|
448
454
|
|
|
449
455
|
---
|
|
450
456
|
|
|
451
|
-
Tutti i contributor (
|
|
457
|
+
Tutti i contributor (_made with [contributors-img](https://contrib.rocks)_)
|
|
452
458
|
|
|
453
459
|
<a href = "https://github.com/italia/design-angular-kit/graphs/contributors">
|
|
454
460
|
<img src = "https://contrib.rocks/image?repo=italia/design-angular-kit"/>
|
|
@@ -32,9 +32,9 @@ export class ItDimmerComponent {
|
|
|
32
32
|
this.elementRef?.nativeElement?.parentElement?.classList?.add('dimmable');
|
|
33
33
|
}
|
|
34
34
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItDimmerComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
35
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.6", type: ItDimmerComponent, isStandalone: true, selector: "it-dimmer", inputs: { active: "active", color: "color" }, ngImport: i0, template: "@if (active) {\n <div class=\"dimmer\" @fade [ngClass]=\"[color]\">\n <div class=\"dimmer-inner\">\n <ng-content></ng-content>\n </div>\n </div>\n}\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], animations: [
|
|
35
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.6", type: ItDimmerComponent, isStandalone: true, selector: "it-dimmer", inputs: { active: "active", color: "color" }, ngImport: i0, template: "@if (active) {\n <div class=\"dimmer\" @fade [ngClass]=\"[color, 'show']\">\n <div class=\"dimmer-inner\">\n <ng-content></ng-content>\n </div>\n </div>\n}\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], animations: [
|
|
36
36
|
trigger('fade', [
|
|
37
|
-
transition(':enter', [style({ opacity: 0 }), animate('150ms', style({ opacity: 0.
|
|
37
|
+
transition(':enter', [style({ opacity: 0 }), animate('150ms', style({ opacity: 0.9 }))]),
|
|
38
38
|
transition(':leave', [animate('150ms', style({ opacity: 0 }))]),
|
|
39
39
|
]),
|
|
40
40
|
], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
@@ -43,13 +43,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImpor
|
|
|
43
43
|
type: Component,
|
|
44
44
|
args: [{ standalone: true, selector: 'it-dimmer', changeDetection: ChangeDetectionStrategy.OnPush, animations: [
|
|
45
45
|
trigger('fade', [
|
|
46
|
-
transition(':enter', [style({ opacity: 0 }), animate('150ms', style({ opacity: 0.
|
|
46
|
+
transition(':enter', [style({ opacity: 0 }), animate('150ms', style({ opacity: 0.9 }))]),
|
|
47
47
|
transition(':leave', [animate('150ms', style({ opacity: 0 }))]),
|
|
48
48
|
]),
|
|
49
|
-
], imports: [NgClass], template: "@if (active) {\n <div class=\"dimmer\" @fade [ngClass]=\"[color]\">\n <div class=\"dimmer-inner\">\n <ng-content></ng-content>\n </div>\n </div>\n}\n" }]
|
|
49
|
+
], imports: [NgClass], template: "@if (active) {\n <div class=\"dimmer\" @fade [ngClass]=\"[color, 'show']\">\n <div class=\"dimmer-inner\">\n <ng-content></ng-content>\n </div>\n </div>\n}\n" }]
|
|
50
50
|
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { active: [{
|
|
51
51
|
type: Input
|
|
52
52
|
}], color: [{
|
|
53
53
|
type: Input
|
|
54
54
|
}] } });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGltbWVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS9kaW1tZXIvZGltbWVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS9kaW1tZXIvZGltbWVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLFVBQVUsRUFBRSxPQUFPLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUMxRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFjLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUM5RixPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0saUJBQWlCLENBQUM7O0FBaUIxQyxNQUFNLE9BQU8saUJBQWlCO0lBQzVCOzs7T0FHRztJQUNILElBQWEsTUFBTSxDQUFDLEtBQWM7UUFDaEMsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7SUFDdkIsQ0FBQztJQUNELElBQUksTUFBTTtRQUNSLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0lBR0Q7OztPQUdHO0lBQ0gsSUFBYSxLQUFLLENBQUMsS0FBa0I7UUFDbkMsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7SUFDdEIsQ0FBQztJQUNELElBQUksS0FBSztRQUNQLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUNyQixDQUFDO0lBR0QsWUFBb0IsVUFBc0I7UUFBdEIsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQWRsQyxZQUFPLEdBQUcsS0FBSyxDQUFDO1FBWWhCLFdBQU0sR0FBZ0IsRUFBRSxDQUFDO0lBRVksQ0FBQztJQUU5QyxRQUFRO1FBQ04sSUFBSSxDQUFDLFVBQVUsRUFBRSxhQUFhLEVBQUUsYUFBYSxFQUFFLFNBQVMsRUFBRSxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDNUUsQ0FBQzs4R0E3QlUsaUJBQWlCO2tHQUFqQixpQkFBaUIsbUhDbkI5Qiw0S0FPQSw0Q0RVWSxPQUFPLHNFQU5MO1lBQ1YsT0FBTyxDQUFDLE1BQU0sRUFBRTtnQkFDZCxVQUFVLENBQUMsUUFBUSxFQUFFLENBQUMsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsT0FBTyxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ3hGLFVBQVUsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQzthQUNoRSxDQUFDO1NBQ0g7OzJGQUdVLGlCQUFpQjtrQkFiN0IsU0FBUztpQ0FDSSxJQUFJLFlBQ04sV0FBVyxtQkFFSix1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DO3dCQUNWLE9BQU8sQ0FBQyxNQUFNLEVBQUU7NEJBQ2QsVUFBVSxDQUFDLFFBQVEsRUFBRSxDQUFDLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDOzRCQUN4RixVQUFVLENBQUMsUUFBUSxFQUFFLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7eUJBQ2hFLENBQUM7cUJBQ0gsV0FDUSxDQUFDLE9BQU8sQ0FBQzsrRUFPTCxNQUFNO3NCQUFsQixLQUFLO2dCQVlPLEtBQUs7c0JBQWpCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBhbmltYXRlLCBzdHlsZSwgdHJhbnNpdGlvbiwgdHJpZ2dlciB9IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRWxlbWVudFJlZiwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdDbGFzcyB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmV4cG9ydCB0eXBlIERpbW1lckNvbG9yID0gJycgfCAnZGltbWVyLXByaW1hcnknO1xuXG5AQ29tcG9uZW50KHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdpdC1kaW1tZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vZGltbWVyLmNvbXBvbmVudC5odG1sJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGFuaW1hdGlvbnM6IFtcbiAgICB0cmlnZ2VyKCdmYWRlJywgW1xuICAgICAgdHJhbnNpdGlvbignOmVudGVyJywgW3N0eWxlKHsgb3BhY2l0eTogMCB9KSwgYW5pbWF0ZSgnMTUwbXMnLCBzdHlsZSh7IG9wYWNpdHk6IDAuOSB9KSldKSxcbiAgICAgIHRyYW5zaXRpb24oJzpsZWF2ZScsIFthbmltYXRlKCcxNTBtcycsIHN0eWxlKHsgb3BhY2l0eTogMCB9KSldKSxcbiAgICBdKSxcbiAgXSxcbiAgaW1wb3J0czogW05nQ2xhc3NdLFxufSlcbmV4cG9ydCBjbGFzcyBJdERpbW1lckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIC8qKlxuICAgKiBEaW1tZXIgc3RhdHVzXG4gICAqIEBkZWZhdWx0IGZhbHNlXG4gICAqL1xuICBASW5wdXQoKSBzZXQgYWN0aXZlKHZhbHVlOiBib29sZWFuKSB7XG4gICAgdGhpcy5fYWN0aXZlID0gdmFsdWU7XG4gIH1cbiAgZ2V0IGFjdGl2ZSgpIHtcbiAgICByZXR1cm4gdGhpcy5fYWN0aXZlO1xuICB9XG4gIHByaXZhdGUgX2FjdGl2ZSA9IGZhbHNlO1xuXG4gIC8qKlxuICAgKiBDb2xvcmUgZGVsIGRpbW1lclxuICAgKiBAZGVmYXVsdCAnJ1xuICAgKi9cbiAgQElucHV0KCkgc2V0IGNvbG9yKHZhbHVlOiBEaW1tZXJDb2xvcikge1xuICAgIHRoaXMuX2NvbG9yID0gdmFsdWU7XG4gIH1cbiAgZ2V0IGNvbG9yKCkge1xuICAgIHJldHVybiB0aGlzLl9jb2xvcjtcbiAgfVxuICBwcml2YXRlIF9jb2xvcjogRGltbWVyQ29sb3IgPSAnJztcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHt9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5lbGVtZW50UmVmPy5uYXRpdmVFbGVtZW50Py5wYXJlbnRFbGVtZW50Py5jbGFzc0xpc3Q/LmFkZCgnZGltbWFibGUnKTtcbiAgfVxufVxuIiwiQGlmIChhY3RpdmUpIHtcbiAgPGRpdiBjbGFzcz1cImRpbW1lclwiIEBmYWRlIFtuZ0NsYXNzXT1cIltjb2xvciwgJ3Nob3cnXVwiPlxuICAgIDxkaXYgY2xhc3M9XCJkaW1tZXItaW5uZXJcIj5cbiAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG59XG4iXX0=
|
|
@@ -10,6 +10,7 @@ import { ItTextareaComponent } from './textarea/textarea.component';
|
|
|
10
10
|
import { ItUploadDragDropComponent } from './upload-drag-drop/upload-drag-drop.component';
|
|
11
11
|
import { ItUploadFileListComponent } from './upload-file-list/upload-file-list.component';
|
|
12
12
|
import { ItAutocompleteComponent } from './autocomplete/autocomplete.component';
|
|
13
|
+
import { ItTransferComponent } from './transfer/transfer.component';
|
|
13
14
|
import * as i0 from "@angular/core";
|
|
14
15
|
const formComponents = [
|
|
15
16
|
ItAutocompleteComponent,
|
|
@@ -21,6 +22,7 @@ const formComponents = [
|
|
|
21
22
|
ItRatingComponent,
|
|
22
23
|
ItSelectComponent,
|
|
23
24
|
ItTextareaComponent,
|
|
25
|
+
ItTransferComponent,
|
|
24
26
|
ItUploadDragDropComponent,
|
|
25
27
|
ItUploadFileListComponent,
|
|
26
28
|
];
|
|
@@ -35,6 +37,7 @@ export class ItFormModule {
|
|
|
35
37
|
ItRatingComponent,
|
|
36
38
|
ItSelectComponent,
|
|
37
39
|
ItTextareaComponent,
|
|
40
|
+
ItTransferComponent,
|
|
38
41
|
ItUploadDragDropComponent,
|
|
39
42
|
ItUploadFileListComponent], exports: [ItAutocompleteComponent,
|
|
40
43
|
ItCheckboxComponent,
|
|
@@ -45,6 +48,7 @@ export class ItFormModule {
|
|
|
45
48
|
ItRatingComponent,
|
|
46
49
|
ItSelectComponent,
|
|
47
50
|
ItTextareaComponent,
|
|
51
|
+
ItTransferComponent,
|
|
48
52
|
ItUploadDragDropComponent,
|
|
49
53
|
ItUploadFileListComponent] }); }
|
|
50
54
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItFormModule, imports: [formComponents] }); }
|
|
@@ -56,4 +60,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImpor
|
|
|
56
60
|
exports: formComponents,
|
|
57
61
|
}]
|
|
58
62
|
}] });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tYW5ndWxhci1raXQvc3JjL2xpYi9jb21wb25lbnRzL2Zvcm0vZm9ybS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNwRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUNyRixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUMvRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNwRSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQztBQUMxRixPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQztBQUMxRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUNoRixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQzs7QUFFcEUsTUFBTSxjQUFjLEdBQUc7SUFDckIsdUJBQXVCO0lBQ3ZCLG1CQUFtQjtJQUNuQixnQkFBZ0I7SUFDaEIsd0JBQXdCO0lBQ3hCLHNCQUFzQjtJQUN0QixnQkFBZ0I7SUFDaEIsaUJBQWlCO0lBQ2pCLGlCQUFpQjtJQUNqQixtQkFBbUI7SUFDbkIsbUJBQW1CO0lBQ25CLHlCQUF5QjtJQUN6Qix5QkFBeUI7Q0FDMUIsQ0FBQztBQU1GLE1BQU0sT0FBTyxZQUFZOzhHQUFaLFlBQVk7K0dBQVosWUFBWSxZQWxCdkIsdUJBQXVCO1lBQ3ZCLG1CQUFtQjtZQUNuQixnQkFBZ0I7WUFDaEIsd0JBQXdCO1lBQ3hCLHNCQUFzQjtZQUN0QixnQkFBZ0I7WUFDaEIsaUJBQWlCO1lBQ2pCLGlCQUFpQjtZQUNqQixtQkFBbUI7WUFDbkIsbUJBQW1CO1lBQ25CLHlCQUF5QjtZQUN6Qix5QkFBeUIsYUFYekIsdUJBQXVCO1lBQ3ZCLG1CQUFtQjtZQUNuQixnQkFBZ0I7WUFDaEIsd0JBQXdCO1lBQ3hCLHNCQUFzQjtZQUN0QixnQkFBZ0I7WUFDaEIsaUJBQWlCO1lBQ2pCLGlCQUFpQjtZQUNqQixtQkFBbUI7WUFDbkIsbUJBQW1CO1lBQ25CLHlCQUF5QjtZQUN6Qix5QkFBeUI7K0dBT2QsWUFBWSxZQUhkLGNBQWM7OzJGQUdaLFlBQVk7a0JBSnhCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLGNBQWM7b0JBQ3ZCLE9BQU8sRUFBRSxjQUFjO2lCQUN4QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJdENoZWNrYm94Q29tcG9uZW50IH0gZnJvbSAnLi9jaGVja2JveC9jaGVja2JveC5jb21wb25lbnQnO1xuaW1wb3J0IHsgSXRJbnB1dENvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQvaW5wdXQuY29tcG9uZW50JztcbmltcG9ydCB7IEl0UGFzc3dvcmRJbnB1dENvbXBvbmVudCB9IGZyb20gJy4vcGFzc3dvcmQtaW5wdXQvcGFzc3dvcmQtaW5wdXQuY29tcG9uZW50JztcbmltcG9ydCB7IEl0UmFkaW9CdXR0b25Db21wb25lbnQgfSBmcm9tICcuL3JhZGlvLWJ1dHRvbi9yYWRpby1idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7IEl0UmFuZ2VDb21wb25lbnQgfSBmcm9tICcuL3JhbmdlL3JhbmdlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJdFJhdGluZ0NvbXBvbmVudCB9IGZyb20gJy4vcmF0aW5nL3JhdGluZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgSXRTZWxlY3RDb21wb25lbnQgfSBmcm9tICcuL3NlbGVjdC9zZWxlY3QuY29tcG9uZW50JztcbmltcG9ydCB7IEl0VGV4dGFyZWFDb21wb25lbnQgfSBmcm9tICcuL3RleHRhcmVhL3RleHRhcmVhLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJdFVwbG9hZERyYWdEcm9wQ29tcG9uZW50IH0gZnJvbSAnLi91cGxvYWQtZHJhZy1kcm9wL3VwbG9hZC1kcmFnLWRyb3AuY29tcG9uZW50JztcbmltcG9ydCB7IEl0VXBsb2FkRmlsZUxpc3RDb21wb25lbnQgfSBmcm9tICcuL3VwbG9hZC1maWxlLWxpc3QvdXBsb2FkLWZpbGUtbGlzdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgSXRBdXRvY29tcGxldGVDb21wb25lbnQgfSBmcm9tICcuL2F1dG9jb21wbGV0ZS9hdXRvY29tcGxldGUuY29tcG9uZW50JztcbmltcG9ydCB7IEl0VHJhbnNmZXJDb21wb25lbnQgfSBmcm9tICcuL3RyYW5zZmVyL3RyYW5zZmVyLmNvbXBvbmVudCc7XG5cbmNvbnN0IGZvcm1Db21wb25lbnRzID0gW1xuICBJdEF1dG9jb21wbGV0ZUNvbXBvbmVudCxcbiAgSXRDaGVja2JveENvbXBvbmVudCxcbiAgSXRJbnB1dENvbXBvbmVudCxcbiAgSXRQYXNzd29yZElucHV0Q29tcG9uZW50LFxuICBJdFJhZGlvQnV0dG9uQ29tcG9uZW50LFxuICBJdFJhbmdlQ29tcG9uZW50LFxuICBJdFJhdGluZ0NvbXBvbmVudCxcbiAgSXRTZWxlY3RDb21wb25lbnQsXG4gIEl0VGV4dGFyZWFDb21wb25lbnQsXG4gIEl0VHJhbnNmZXJDb21wb25lbnQsXG4gIEl0VXBsb2FkRHJhZ0Ryb3BDb21wb25lbnQsXG4gIEl0VXBsb2FkRmlsZUxpc3RDb21wb25lbnQsXG5dO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBmb3JtQ29tcG9uZW50cyxcbiAgZXhwb3J0czogZm9ybUNvbXBvbmVudHMsXG59KVxuZXhwb3J0IGNsYXNzIEl0Rm9ybU1vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
//#region private utility functions
|
|
2
|
+
const generateSelectAll = (checked, items) => {
|
|
3
|
+
const selected = new Set();
|
|
4
|
+
if (checked) {
|
|
5
|
+
items.forEach(item => selected.add(item));
|
|
6
|
+
}
|
|
7
|
+
return selected;
|
|
8
|
+
};
|
|
9
|
+
const updateSelected = (set, item) => {
|
|
10
|
+
if (set.has(item)) {
|
|
11
|
+
set.delete(item);
|
|
12
|
+
}
|
|
13
|
+
else {
|
|
14
|
+
set.add(item);
|
|
15
|
+
}
|
|
16
|
+
return set;
|
|
17
|
+
};
|
|
18
|
+
//#endregion
|
|
19
|
+
//#region reducers
|
|
20
|
+
const init = (state, { source, target }) => ({
|
|
21
|
+
...state,
|
|
22
|
+
initialItems: {
|
|
23
|
+
source: [...source],
|
|
24
|
+
target: [...target],
|
|
25
|
+
},
|
|
26
|
+
current: {
|
|
27
|
+
source: [...source],
|
|
28
|
+
target: [...target],
|
|
29
|
+
},
|
|
30
|
+
});
|
|
31
|
+
const transfer = (state) => {
|
|
32
|
+
return {
|
|
33
|
+
...state,
|
|
34
|
+
current: {
|
|
35
|
+
...state.current,
|
|
36
|
+
source: state.current.source.filter(i => !state.selections.source.has(i)),
|
|
37
|
+
target: Array.from(new Set([...state.current.target, ...Array.from(state.selections.source)])),
|
|
38
|
+
},
|
|
39
|
+
selections: {
|
|
40
|
+
...state.selections,
|
|
41
|
+
source: new Set(),
|
|
42
|
+
},
|
|
43
|
+
operationsEnabled: {
|
|
44
|
+
...state.operationsEnabled,
|
|
45
|
+
transfer: false,
|
|
46
|
+
reset: true,
|
|
47
|
+
},
|
|
48
|
+
};
|
|
49
|
+
};
|
|
50
|
+
const backtransfer = (state) => {
|
|
51
|
+
return {
|
|
52
|
+
...state,
|
|
53
|
+
current: {
|
|
54
|
+
...state.current,
|
|
55
|
+
target: state.current.target.filter(i => !state.selections.target.has(i)),
|
|
56
|
+
source: Array.from(new Set([...state.current.source, ...Array.from(state.selections.target)])),
|
|
57
|
+
},
|
|
58
|
+
selections: {
|
|
59
|
+
...state.selections,
|
|
60
|
+
target: new Set(),
|
|
61
|
+
},
|
|
62
|
+
operationsEnabled: {
|
|
63
|
+
...state.operationsEnabled,
|
|
64
|
+
backtransfer: false,
|
|
65
|
+
reset: true,
|
|
66
|
+
},
|
|
67
|
+
};
|
|
68
|
+
};
|
|
69
|
+
const reset = (state) => {
|
|
70
|
+
return {
|
|
71
|
+
...state,
|
|
72
|
+
current: {
|
|
73
|
+
source: [...state.initialItems.source],
|
|
74
|
+
target: [...state.initialItems.target],
|
|
75
|
+
},
|
|
76
|
+
operationsEnabled: {
|
|
77
|
+
...state.operationsEnabled,
|
|
78
|
+
reset: false,
|
|
79
|
+
},
|
|
80
|
+
};
|
|
81
|
+
};
|
|
82
|
+
const selectAllSource = (state, { checked }) => {
|
|
83
|
+
const items = state.current.source;
|
|
84
|
+
const selected = generateSelectAll(checked, items);
|
|
85
|
+
const transfer = Boolean(selected.size);
|
|
86
|
+
return {
|
|
87
|
+
...state,
|
|
88
|
+
selections: {
|
|
89
|
+
...state.selections,
|
|
90
|
+
source: selected,
|
|
91
|
+
},
|
|
92
|
+
operationsEnabled: {
|
|
93
|
+
...state.operationsEnabled,
|
|
94
|
+
transfer,
|
|
95
|
+
},
|
|
96
|
+
};
|
|
97
|
+
};
|
|
98
|
+
const selectAllTarget = (state, { checked }) => {
|
|
99
|
+
const items = state.current.target;
|
|
100
|
+
const selected = generateSelectAll(checked, items);
|
|
101
|
+
const backtransfer = Boolean(selected.size);
|
|
102
|
+
return {
|
|
103
|
+
...state,
|
|
104
|
+
selections: {
|
|
105
|
+
...state.selections,
|
|
106
|
+
target: selected,
|
|
107
|
+
},
|
|
108
|
+
operationsEnabled: {
|
|
109
|
+
...state.operationsEnabled,
|
|
110
|
+
backtransfer,
|
|
111
|
+
},
|
|
112
|
+
};
|
|
113
|
+
};
|
|
114
|
+
const selectionItemSource = (previousState, { item }) => {
|
|
115
|
+
const selected = updateSelected(previousState.selections.source, item);
|
|
116
|
+
const selectedItems = Array.from(selected);
|
|
117
|
+
const transfer = Boolean(selectedItems.length);
|
|
118
|
+
const source = new Set([...selectedItems]);
|
|
119
|
+
const state = {
|
|
120
|
+
...previousState,
|
|
121
|
+
selections: {
|
|
122
|
+
...previousState.selections,
|
|
123
|
+
source,
|
|
124
|
+
},
|
|
125
|
+
operationsEnabled: {
|
|
126
|
+
...previousState.operationsEnabled,
|
|
127
|
+
transfer,
|
|
128
|
+
},
|
|
129
|
+
};
|
|
130
|
+
return state;
|
|
131
|
+
};
|
|
132
|
+
const selectionItemTarget = (previousState, { item }) => {
|
|
133
|
+
const selected = updateSelected(previousState.selections.target, item);
|
|
134
|
+
const selectedItems = Array.from(selected);
|
|
135
|
+
const backtransfer = Boolean(selectedItems.length);
|
|
136
|
+
const target = new Set([...selectedItems]);
|
|
137
|
+
const state = {
|
|
138
|
+
...previousState,
|
|
139
|
+
selections: {
|
|
140
|
+
...previousState.selections,
|
|
141
|
+
target,
|
|
142
|
+
},
|
|
143
|
+
operationsEnabled: {
|
|
144
|
+
...previousState.operationsEnabled,
|
|
145
|
+
backtransfer,
|
|
146
|
+
},
|
|
147
|
+
};
|
|
148
|
+
return state;
|
|
149
|
+
};
|
|
150
|
+
//#endregion reducers
|
|
151
|
+
//#region public reducers
|
|
152
|
+
const initialStateFn = () => ({
|
|
153
|
+
initialItems: {
|
|
154
|
+
source: [],
|
|
155
|
+
target: [],
|
|
156
|
+
},
|
|
157
|
+
current: {
|
|
158
|
+
source: [],
|
|
159
|
+
target: [],
|
|
160
|
+
},
|
|
161
|
+
selections: {
|
|
162
|
+
source: new Set(),
|
|
163
|
+
target: new Set(),
|
|
164
|
+
},
|
|
165
|
+
operationsEnabled: {
|
|
166
|
+
transfer: false,
|
|
167
|
+
backtransfer: false,
|
|
168
|
+
reset: false,
|
|
169
|
+
},
|
|
170
|
+
});
|
|
171
|
+
const initFn = (payload) => (state) => init(state, payload);
|
|
172
|
+
const transferFn = () => (state) => transfer(state);
|
|
173
|
+
const backtransferFn = () => (state) => backtransfer(state);
|
|
174
|
+
const resetFn = () => (state) => reset(state);
|
|
175
|
+
const selectAllSourceFn = ({ checked }) => (state) => selectAllSource(state, { checked });
|
|
176
|
+
const selectAllTargetFn = ({ checked }) => (state) => selectAllTarget(state, { checked });
|
|
177
|
+
const selectionItemSourceFn = ({ item }) => (state) => selectionItemSource(state, { item });
|
|
178
|
+
const selectionItemTargetFn = ({ item }) => (state) => selectionItemTarget(state, { item });
|
|
179
|
+
//#endregion
|
|
180
|
+
export default {
|
|
181
|
+
initialStateFn,
|
|
182
|
+
initFn,
|
|
183
|
+
transferFn,
|
|
184
|
+
backtransferFn,
|
|
185
|
+
resetFn,
|
|
186
|
+
selectAllSourceFn,
|
|
187
|
+
selectAllTargetFn,
|
|
188
|
+
selectionItemSourceFn,
|
|
189
|
+
selectionItemTargetFn,
|
|
190
|
+
};
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transfer.reducers.js","sourceRoot":"","sources":["../../../../../../../../projects/design-angular-kit/src/lib/components/form/transfer/store/transfer.reducers.ts"],"names":[],"mappings":"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","sourcesContent":["import { TransferItem, TransferItemSelection } from '../transfer.model';\nimport { SelectionState, State } from './transfer.state';\n\n//#region private utility functions\nconst generateSelectAll = <T>(checked: boolean, items: TransferItem<T>[]) => {\n  const selected = new Set<TransferItem<T>>();\n  if (checked) {\n    items.forEach(item => selected.add(item));\n  }\n\n  return selected;\n};\n\nconst updateSelected = <T>(set: Set<TransferItem<T>>, item: TransferItem<T>) => {\n  if (set.has(item)) {\n    set.delete(item);\n  } else {\n    set.add(item);\n  }\n\n  return set;\n};\n//#endregion\n\n//#region reducers\nconst init = <T>(state: State<T>, { source, target }: SelectionState<T>) => ({\n  ...state,\n  initialItems: {\n    source: [...source],\n    target: [...target],\n  },\n  current: {\n    source: [...source],\n    target: [...target],\n  },\n});\n\nconst transfer = <T>(state: State<T>) => {\n  return {\n    ...state,\n    current: {\n      ...state.current,\n      source: state.current.source.filter(i => !state.selections.source.has(i)),\n      target: Array.from(new Set([...state.current.target, ...Array.from(state.selections.source)] as TransferItemSelection<T>)),\n    },\n    selections: {\n      ...state.selections,\n      source: new Set<TransferItem<T>>(),\n    },\n    operationsEnabled: {\n      ...state.operationsEnabled,\n      transfer: false,\n      reset: true,\n    },\n  } satisfies State<T>;\n};\n\nconst backtransfer = <T>(state: State<T>) => {\n  return {\n    ...state,\n    current: {\n      ...state.current,\n      target: state.current.target.filter(i => !state.selections.target.has(i)),\n      source: Array.from(new Set([...state.current.source, ...Array.from(state.selections.target)] as TransferItemSelection<T>)),\n    },\n    selections: {\n      ...state.selections,\n      target: new Set<TransferItem<T>>(),\n    },\n    operationsEnabled: {\n      ...state.operationsEnabled,\n      backtransfer: false,\n      reset: true,\n    },\n  } satisfies State<T>;\n};\n\nconst reset = <T>(state: State<T>) => {\n  return {\n    ...state,\n    current: {\n      source: [...state.initialItems.source],\n      target: [...state.initialItems.target],\n    },\n    operationsEnabled: {\n      ...state.operationsEnabled,\n      reset: false,\n    },\n  } satisfies State<T>;\n};\n\nconst selectAllSource = <T>(state: State<T>, { checked }: { checked: boolean }) => {\n  const items = state.current.source;\n  const selected = generateSelectAll(checked, items);\n  const transfer = Boolean(selected.size);\n\n  return {\n    ...state,\n    selections: {\n      ...state.selections,\n      source: selected,\n    },\n    operationsEnabled: {\n      ...state.operationsEnabled,\n      transfer,\n    },\n  } satisfies State<T>;\n};\n\nconst selectAllTarget = <T>(state: State<T>, { checked }: { checked: boolean }) => {\n  const items = state.current.target;\n  const selected = generateSelectAll(checked, items);\n  const backtransfer = Boolean(selected.size);\n\n  return {\n    ...state,\n    selections: {\n      ...state.selections,\n      target: selected,\n    },\n    operationsEnabled: {\n      ...state.operationsEnabled,\n      backtransfer,\n    },\n  } satisfies State<T>;\n};\n\nconst selectionItemSource = <T>(previousState: State<T>, { item }: { item: TransferItem<T> }) => {\n  const selected = updateSelected(previousState.selections.source, item);\n  const selectedItems = Array.from(selected);\n  const transfer = Boolean(selectedItems.length);\n  const source = new Set([...selectedItems]);\n\n  const state = {\n    ...previousState,\n    selections: {\n      ...previousState.selections,\n      source,\n    },\n    operationsEnabled: {\n      ...previousState.operationsEnabled,\n      transfer,\n    },\n  } satisfies State<T>;\n\n  return state;\n};\n\nconst selectionItemTarget = <T>(previousState: State<T>, { item }: { item: TransferItem<T> }) => {\n  const selected = updateSelected(previousState.selections.target, item);\n  const selectedItems = Array.from(selected);\n  const backtransfer = Boolean(selectedItems.length);\n  const target = new Set([...selectedItems]);\n\n  const state = {\n    ...previousState,\n    selections: {\n      ...previousState.selections,\n      target,\n    },\n    operationsEnabled: {\n      ...previousState.operationsEnabled,\n      backtransfer,\n    },\n  } satisfies State<T>;\n\n  return state;\n};\n//#endregion reducers\n\n//#region public reducers\nconst initialStateFn = <T>() => ({\n  initialItems: {\n    source: [],\n    target: [],\n  },\n  current: {\n    source: [],\n    target: [],\n  },\n  selections: {\n    source: new Set<TransferItem<T>>(),\n    target: new Set<TransferItem<T>>(),\n  },\n  operationsEnabled: {\n    transfer: false,\n    backtransfer: false,\n    reset: false,\n  },\n});\nconst initFn =\n  <T>(payload: SelectionState<T>) =>\n  (state: State<T>) =>\n    init(state, payload);\n\nconst transferFn =\n  <T>() =>\n  (state: State<T>) =>\n    transfer(state);\n\nconst backtransferFn =\n  <T>() =>\n  (state: State<T>) =>\n    backtransfer(state);\n\nconst resetFn =\n  <T>() =>\n  (state: State<T>) =>\n    reset(state);\n\nconst selectAllSourceFn =\n  <T>({ checked }: { checked: boolean }) =>\n  (state: State<T>) =>\n    selectAllSource(state, { checked }) as State<T>;\n\nconst selectAllTargetFn =\n  <T>({ checked }: { checked: boolean }) =>\n  (state: State<T>) =>\n    selectAllTarget(state, { checked }) as State<T>;\n\nconst selectionItemSourceFn =\n  <T>({ item }: { item: TransferItem<T> }) =>\n  (state: State<T>) =>\n    selectionItemSource(state, { item }) as State<T>;\n\nconst selectionItemTargetFn =\n  <T>({ item }: { item: TransferItem<T> }) =>\n  (state: State<T>) =>\n    selectionItemTarget(state, { item }) as State<T>;\n//#endregion\n\nexport default {\n  initialStateFn,\n  initFn,\n  transferFn,\n  backtransferFn,\n  resetFn,\n  selectAllSourceFn,\n  selectAllTargetFn,\n  selectionItemSourceFn,\n  selectionItemTargetFn,\n};\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNmZXIuc3RhdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tYW5ndWxhci1raXQvc3JjL2xpYi9jb21wb25lbnRzL2Zvcm0vdHJhbnNmZXIvc3RvcmUvdHJhbnNmZXIuc3RhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRyYW5zZmVySXRlbSB9IGZyb20gJy4uL3RyYW5zZmVyLm1vZGVsJztcblxuZXhwb3J0IGludGVyZmFjZSBTZWxlY3Rpb25TdGF0ZTxUPiB7XG4gIHNvdXJjZTogQXJyYXk8VHJhbnNmZXJJdGVtPFQ+PjtcbiAgdGFyZ2V0OiBBcnJheTxUcmFuc2Zlckl0ZW08VD4+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFN0YXRlPFQ+IHtcbiAgaW5pdGlhbEl0ZW1zOiBTZWxlY3Rpb25TdGF0ZTxUPjtcbiAgY3VycmVudDogU2VsZWN0aW9uU3RhdGU8VD47XG4gIHNlbGVjdGlvbnM6IHtcbiAgICBzb3VyY2U6IFNldDxUcmFuc2Zlckl0ZW08VD4+O1xuICAgIHRhcmdldDogU2V0PFRyYW5zZmVySXRlbTxUPj47XG4gIH07XG4gIG9wZXJhdGlvbnNFbmFibGVkOiB7XG4gICAgdHJhbnNmZXI6IGJvb2xlYW47XG4gICAgYmFja3RyYW5zZmVyOiBib29sZWFuO1xuICAgIHJlc2V0OiBib29sZWFuO1xuICB9O1xufVxuIl19
|