@provoly/dashboard 1.3.12 → 1.3.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (40) hide show
  1. package/components/paginator/paginator.component.d.ts +2 -1
  2. package/esm2022/admin/components/admin-classes/admin-classes-view/admin-attributes-form/admin-attributes-form.component.mjs +5 -2
  3. package/esm2022/components/data-format/data-format.pipe.mjs +7 -19
  4. package/esm2022/components/paginator/paginator.component.mjs +9 -2
  5. package/esm2022/import/components/list/import-list.component.mjs +16 -8
  6. package/esm2022/import/components/version-modal/version-modal.component.mjs +5 -4
  7. package/esm2022/import/i18n/en.translations.mjs +3 -3
  8. package/esm2022/import/i18n/fr.translations.mjs +3 -3
  9. package/esm2022/lib/core/i18n/en.translations.mjs +2 -2
  10. package/esm2022/lib/core/i18n/fr.translations.mjs +2 -2
  11. package/esm2022/lib/core/store/data-source/data-source.actions.mjs +1 -1
  12. package/esm2022/lib/core/store/data-source/data-source.service.mjs +4 -4
  13. package/esm2022/lib/core/store/search/search.effects.mjs +1 -1
  14. package/esm2022/lib/dashboard/action-bus/service/bus.service.mjs +4 -4
  15. package/esm2022/lib/dashboard/store/dashboard.effects.mjs +3 -3
  16. package/esm2022/lib/dashboard/store/dashboard.reducers.mjs +4 -4
  17. package/esm2022/lib/dashboard/store/manifest-utils.class.mjs +2 -2
  18. package/esm2022/widgets/widget-aggregated-chart/component/widget-aggregated-chart.component.mjs +2 -2
  19. package/esm2022/widgets/widget-table/component/widget-table.component.mjs +1 -1
  20. package/fesm2022/provoly-dashboard-admin.mjs +4 -1
  21. package/fesm2022/provoly-dashboard-admin.mjs.map +1 -1
  22. package/fesm2022/provoly-dashboard-components-data-format.mjs +6 -18
  23. package/fesm2022/provoly-dashboard-components-data-format.mjs.map +1 -1
  24. package/fesm2022/provoly-dashboard-components-paginator.mjs +8 -1
  25. package/fesm2022/provoly-dashboard-components-paginator.mjs.map +1 -1
  26. package/fesm2022/provoly-dashboard-import.mjs +21 -14
  27. package/fesm2022/provoly-dashboard-import.mjs.map +1 -1
  28. package/fesm2022/provoly-dashboard-widgets-widget-aggregated-chart.mjs +1 -1
  29. package/fesm2022/provoly-dashboard-widgets-widget-aggregated-chart.mjs.map +1 -1
  30. package/fesm2022/provoly-dashboard-widgets-widget-table.mjs +1 -1
  31. package/fesm2022/provoly-dashboard-widgets-widget-table.mjs.map +1 -1
  32. package/fesm2022/provoly-dashboard.mjs +12 -12
  33. package/fesm2022/provoly-dashboard.mjs.map +1 -1
  34. package/import/components/list/import-list.component.d.ts +5 -3
  35. package/lib/core/i18n/en.translations.d.ts +1 -1
  36. package/lib/core/i18n/fr.translations.d.ts +1 -1
  37. package/lib/core/store/data-source/data-source.actions.d.ts +4 -4
  38. package/lib/core/store/data-source/data-source.effects.d.ts +2 -2
  39. package/lib/core/store/data-source/data-source.service.d.ts +2 -2
  40. package/package.json +1 -1
@@ -7,6 +7,7 @@ export declare class PryPaginatorComponent {
7
7
  nbPerPage: import("@angular/core").InputSignal<number>;
8
8
  totalItemNb: import("@angular/core").InputSignal<number>;
9
9
  mode: import("@angular/core").InputSignal<"long" | "short">;
10
+ goBackToFirstPage: import("@angular/core").InputSignal<any>;
10
11
  nbOfPages: import("@angular/core").Signal<number>;
11
12
  pages: import("@angular/core").Signal<number[]>;
12
13
  currentPage: import("@angular/core").WritableSignal<number>;
@@ -15,5 +16,5 @@ export declare class PryPaginatorComponent {
15
16
  dispatchPageChangeAction(): void;
16
17
  changePage(page: number): void;
17
18
  static ɵfac: i0.ɵɵFactoryDeclaration<PryPaginatorComponent, never>;
18
- static ɵcmp: i0.ɵɵComponentDeclaration<PryPaginatorComponent, "pry-paginator", never, { "action": { "alias": "action"; "required": false; "isSignal": true; }; "nbPerPage": { "alias": "nbPerPage"; "required": false; "isSignal": true; }; "totalItemNb": { "alias": "totalItemNb"; "required": false; "isSignal": true; }; "mode": { "alias": "mode"; "required": false; "isSignal": true; }; }, { "pageChange": "pageChange"; }, never, never, false, never>;
19
+ static ɵcmp: i0.ɵɵComponentDeclaration<PryPaginatorComponent, "pry-paginator", never, { "action": { "alias": "action"; "required": false; "isSignal": true; }; "nbPerPage": { "alias": "nbPerPage"; "required": false; "isSignal": true; }; "totalItemNb": { "alias": "totalItemNb"; "required": false; "isSignal": true; }; "mode": { "alias": "mode"; "required": false; "isSignal": true; }; "goBackToFirstPage": { "alias": "goBackToFirstPage"; "required": false; "isSignal": true; }; }, { "pageChange": "pageChange"; }, never, never, false, never>;
19
20
  }
@@ -84,7 +84,10 @@ export class AdminAttributesFormComponent extends SubscriptionnerDirective {
84
84
  this.selectedFieldTypeDescription$ = combineLatest([
85
85
  this.attrForm.get('field').valueChanges.pipe(startWith(this.attrForm.get('field')?.value)),
86
86
  this.fields$
87
- ]).pipe(map(([selectedFieldId, fields]) => FIELD_I18N.information + fields.find((field) => field.id === selectedFieldId)?.type));
87
+ ]).pipe(map(([selectedFieldId, fields]) => !selectedFieldId
88
+ ? ''
89
+ : FIELD_I18N.information +
90
+ fields.find((field) => field.id === (typeof selectedFieldId === 'string' ? selectedFieldId : selectedFieldId.id))?.type));
88
91
  }
89
92
  goBack() {
90
93
  const redirectPath = this.selectedAttribute ? '../..' : '..';
@@ -145,4 +148,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
145
148
  }], selectedAttribute: [{
146
149
  type: Input
147
150
  }] } });
148
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-attributes-form.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-view/admin-attributes-form/admin-attributes-form.component.ts","../../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-view/admin-attributes-form/admin-attributes-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAqB,MAAM,eAAe,CAAC;AACpE,OAAO,EAAwC,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAGlF,OAAO,EAGL,eAAe,EACf,iBAAiB,EAEjB,qBAAqB,EAErB,UAAU,EACV,YAAY,EACZ,cAAc,EAGd,wBAAwB,EACzB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,oBAAoB,EAAE,GAAG,EAAc,SAAS,EAAE,MAAM,MAAM,CAAC;AACrG,OAAO,EAAE,EAAE,IAAI,IAAI,EAAE,MAAM,MAAM,CAAC;AAClC,OAAO,EAAE,qBAAqB,EAAE,MAAM,wCAAwC,CAAC;AAC/E,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAC/D,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,EAAE,yBAAyB,EAAE,MAAM,iEAAiE,CAAC;;;;;;;AAO5G,MAAM,OAAO,4BAA6B,SAAQ,wBAAwB;IAkBxE,YACU,KAAiB,EACjB,MAAc,EACd,KAAqB,EACrB,WAA+B,EAC/B,WAA2B,EAC3B,MAAwB;QAEhC,KAAK,EAAE,CAAC;QAPA,UAAK,GAAL,KAAK,CAAY;QACjB,WAAM,GAAN,MAAM,CAAQ;QACd,UAAK,GAAL,KAAK,CAAgB;QACrB,gBAAW,GAAX,WAAW,CAAoB;QAC/B,gBAAW,GAAX,WAAW,CAAgB;QAC3B,WAAM,GAAN,MAAM,CAAkB;QAjBlC,sBAAiB,GAAG,KAAK,CAAC;QAC1B,+BAA0B,GAAG,KAAK,CAAC;QAgKhB,eAAU,GAAG,UAAU,CAAC;QA7IzC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC,CAAC;QACzC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QACxD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC,CAAC;QAC5C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;QAEnE,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;YACrC,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC;YACZ,aAAa,EAAE;gBACb,EAAE;gBACF,CAAC,UAAU,CAAC,QAAQ,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,qBAAqB,CAAC;aACjG;YACD,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE,qBAAqB,CAAC,CAAC;YAC7D,WAAW,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;YAC5C,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YAClC,QAAQ,EAAE,CAAC,qBAAqB,CAAC;YACjC,WAAW,EAAE,CAAC,KAAK,CAAC;SACrB,CAAC,CAAC;IACL,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,UAAU,EAAE,UAAU,CAAC,GAAG,CAAC,CAAC,IAAe,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACtF,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,UAAU,EAAE,UAAU,CAAC,GAAG,CAAC,CAAC,IAAe,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAExG,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,IAAe,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACxF,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,IAAe,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YAE1G,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBAC3B,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC;oBACvB,EAAE,EAAE,IAAI,CAAC,iBAAiB,CAAC,EAAE;oBAC7B,aAAa,EAAE,IAAI,CAAC,iBAAiB,CAAC,aAAa;oBACnD,IAAI,EAAE,IAAI,CAAC,iBAAiB,CAAC,IAAI,IAAI,IAAI,CAAC,iBAAiB,CAAC,aAAa;oBACzE,KAAK,EAAE,IAAI,CAAC,iBAAiB,CAAC,KAAK;oBACnC,QAAQ,EAAE,IAAI,CAAC,iBAAiB,CAAC,QAAQ;iBAC1C,CAAC,CAAC;gBACH,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,CAAC;YAC5C,CAAC;QACH,CAAC;QAED,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,QAAQ;iBACpC,GAAG,CAAC,MAAM,CAAE;iBACZ,YAAY,CAAC,IAAI,CAChB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,IAAI,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,CAChG,CAAC;YACJ,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QACzG,CAAC;QAED,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,IAAI,CAAC,QAAQ;aACV,GAAG,CAAC,eAAe,CAAE;aACrB,YAAY,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC;aAC5D,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACnB,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC;gBACvB,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC;aACzB,CAAC,CAAC;QACL,CAAC,CAAC,CACL,CAAC;QAEF,IAAI,IAAI,CAAC,uBAAuB,EAAE,CAAC;YACjC,IAAI,CAAC,2BAA2B,GAAG,IAAI,CAAC,QAAQ;iBAC7C,GAAG,CAAC,eAAe,CAAE;iBACrB,YAAY,CAAC,IAAI,CAChB,GAAG,CACD,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,uBAAuB,EAAE,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,IAAI,IAAI,CAAC,iBAAiB,EAAE,aAAa,CAC7G,CACF,CAAC;YACJ,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,IAAI,CAAC,2BAA2B,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;gBACnD,IAAI,CAAC,0BAA0B,GAAG,KAAK,CAAC;YAC1C,CAAC,CAAC,CACH,CAAC;QACJ,CAAC;QAED,IAAI,CAAC,6BAA6B,GAAG,aAAa,CAAC;YACjD,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAE,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,KAAK,CAAC,CAAC;YAC3F,IAAI,CAAC,OAAO;SACb,CAAC,CAAC,IAAI,CACL,GAAG,CACD,CAAC,CAAC,eAAe,EAAE,MAAM,CAAC,EAAE,EAAE,CAC5B,UAAU,CAAC,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,eAAe,CAAC,EAAE,IAAI,CACtF,CACF,CAAC;IACJ,CAAC;IAED,MAAM;QACJ,MAAM,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC;QAC7D,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,YAAY,CAAC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QACnF,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC;IACvE,CAAC;IAED,YAAY;QACV,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC;YACvB,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE;SACtC,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;YAC9B,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC;gBACvB,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC;aACrD,CAAC,CAAC;QACL,CAAC;QAED,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;YACxB,IAAI,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAe,CAAC;YAC1D,IAAI,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;YAEzE,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBAC3B,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;YAC1E,CAAC;YAED,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;gBACvB,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,iBAAiB,CAAC,qBAAqB,CAAC;oBACtC,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC,EAAE;oBAC9B,SAAS,EAAE,UAAU;oBACrB,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE;iBACvB,CAAC,CACH,CAAC;YACJ,CAAC;iBAAM,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;gBAC3B,IAAI,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;gBACnE,IAAI,iBAAiB,GAAG,EAAE,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;gBAC/C,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gBAChC,iBAAiB,CAAC,UAAU,GAAG,cAAc,CAAC;gBAC9C,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,iBAAiB,CAAC,cAAc,CAAC,EAAE,KAAK,EAAE,iBAAiB,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC;YAC9G,CAAC;QACH,CAAC;IACH,CAAC;IAED,SAAS;QACP,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;QACxD,GAAG,CAAC,SAAU,CAAC,UAAU,GAAG,WAAW,CAAC;QACxC,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,GAAG,CAAC,SAAU,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;YAC7C,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC;gBACvB,QAAQ,EAAE,QAAQ,CAAC,EAAE;aACtB,CAAC,CAAC;QACL,CAAC,CAAC,CACH,CAAC;QACF,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,GAAG,CAAC,SAAU,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;IACjF,CAAC;8GAtKU,4BAA4B;kGAA5B,4BAA4B,sMC/BzC,25JAqHA;;2FDtFa,4BAA4B;kBAJxC,SAAS;+BACE,2BAA2B;yNAiB5B,aAAa;sBAArB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\nimport { UntypedFormBuilder, UntypedFormGroup, Validators } from '@angular/forms';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  Attribute,\n  Category,\n  CategoryActions,\n  CategorySelectors,\n  Class,\n  DEFAULT_CATEGORY_UUID,\n  Field,\n  FIELD_I18N,\n  FieldActions,\n  FieldSelectors,\n  PryDialogService,\n  PryI18nService,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { combineLatest, debounceTime, distinctUntilChanged, map, Observable, startWith } from 'rxjs';\nimport { v4 as uuid } from 'uuid';\nimport { noWhitespaceValidator } from '../../../../components/admin.component';\nimport { AdminActions } from '../../../../store/admin.actions';\nimport { AdminClassActions } from '../../store/admin-class.actions';\nimport { AddCategoryModalComponent } from '../../../shared/add-category-modal/add-category-modal.component';\nimport { withLatestFrom } from 'rxjs/operators';\n\n@Component({\n  selector: 'pry-admin-attributes-form',\n  templateUrl: './admin-attributes-form.component.html'\n})\nexport class AdminAttributesFormComponent extends SubscriptionnerDirective implements OnInit, OnDestroy {\n  attrForm: UntypedFormGroup;\n\n  attributeNames?: string[];\n  attributeTechnicalNames?: string[];\n  nameAlreadyExists$?: Observable<boolean>;\n  technicalNameAlreadyExists$?: Observable<boolean>;\n  nameAlreadyExists = false;\n  technicalNameAlreadyExists = false;\n\n  fields$: Observable<Field[]>;\n  selectedFieldTypeDescription$!: Observable<string>;\n  categories$: Observable<Category[]>;\n\n  @Input() selectedClass?: Class;\n  @Input() interClass?: Class;\n  @Input() selectedAttribute?: Attribute;\n\n  constructor(\n    private store: Store<any>,\n    private router: Router,\n    private route: ActivatedRoute,\n    private formBuilder: UntypedFormBuilder,\n    private i18nService: PryI18nService,\n    private dialog: PryDialogService\n  ) {\n    super();\n    this.store.dispatch(FieldActions.load());\n    this.fields$ = this.store.select(FieldSelectors.fields);\n    this.store.dispatch(CategoryActions.load());\n    this.categories$ = this.store.select(CategorySelectors.categories);\n\n    this.attrForm = this.formBuilder.group({\n      id: [uuid()],\n      technicalName: [\n        '',\n        [Validators.required, Validators.minLength(2), Validators.maxLength(100), noWhitespaceValidator]\n      ],\n      name: ['', [Validators.maxLength(50), noWhitespaceValidator]],\n      description: [{ value: '', disabled: true }],\n      field: ['', [Validators.required]],\n      category: [DEFAULT_CATEGORY_UUID],\n      multiValued: [false]\n    });\n  }\n\n  ngOnInit(): void {\n    this.attributeNames = this.interClass?.attributes.map((attr: Attribute) => attr.name);\n    this.attributeTechnicalNames = this.interClass?.attributes.map((attr: Attribute) => attr.technicalName);\n\n    if (this.selectedClass) {\n      this.attributeNames = this.selectedClass.attributes.map((attr: Attribute) => attr.name);\n      this.attributeTechnicalNames = this.selectedClass.attributes.map((attr: Attribute) => attr.technicalName);\n\n      if (this.selectedAttribute) {\n        this.attrForm.patchValue({\n          id: this.selectedAttribute.id,\n          technicalName: this.selectedAttribute.technicalName,\n          name: this.selectedAttribute.name ?? this.selectedAttribute.technicalName,\n          field: this.selectedAttribute.field,\n          category: this.selectedAttribute.category\n        });\n        this.attrForm.controls['field'].disable();\n      }\n    }\n\n    if (this.attributeNames) {\n      this.nameAlreadyExists$ = this.attrForm\n        .get('name')!\n        .valueChanges.pipe(\n          map((value) => !!this.attributeNames?.includes(value) && value != this.selectedAttribute?.name)\n        );\n      this.subscriptions.add(this.nameAlreadyExists$.subscribe((value) => (this.nameAlreadyExists = value)));\n    }\n\n    this.subscriptions.add(\n      this.attrForm\n        .get('technicalName')!\n        .valueChanges.pipe(distinctUntilChanged(), debounceTime(500))\n        .subscribe((value) => {\n          this.attrForm.patchValue({\n            name: value.slice(0, 50)\n          });\n        })\n    );\n\n    if (this.attributeTechnicalNames) {\n      this.technicalNameAlreadyExists$ = this.attrForm\n        .get('technicalName')!\n        .valueChanges.pipe(\n          map(\n            (value) => !!this.attributeTechnicalNames?.includes(value) && value != this.selectedAttribute?.technicalName\n          )\n        );\n      this.subscriptions.add(\n        this.technicalNameAlreadyExists$.subscribe((value) => {\n          this.technicalNameAlreadyExists = value;\n        })\n      );\n    }\n\n    this.selectedFieldTypeDescription$ = combineLatest([\n      this.attrForm.get('field')!.valueChanges.pipe(startWith(this.attrForm.get('field')?.value)),\n      this.fields$\n    ]).pipe(\n      map(\n        ([selectedFieldId, fields]) =>\n          FIELD_I18N.information + fields.find((field) => field.id === selectedFieldId)?.type\n      )\n    );\n  }\n\n  goBack() {\n    const redirectPath = this.selectedAttribute ? '../..' : '..';\n    const path = this.router.createUrlTree([redirectPath], { relativeTo: this.route });\n    this.store.dispatch(AdminActions.routeTo({ path: path.toString() }));\n  }\n\n  addAttribute() {\n    this.attrForm.patchValue({\n      name: this.attrForm.value.name.trim()\n    });\n\n    if (!this.attrForm.value.name) {\n      this.attrForm.patchValue({\n        name: this.attrForm.value.technicalName.slice(0, 50)\n      });\n    }\n\n    if (this.attrForm.valid) {\n      let attrToSave = this.attrForm.getRawValue() as Attribute;\n      let path = this.router.createUrlTree(['..'], { relativeTo: this.route });\n\n      if (this.selectedAttribute) {\n        path = this.router.createUrlTree(['../..'], { relativeTo: this.route });\n      }\n\n      if (this.selectedClass) {\n        this.store.dispatch(\n          AdminClassActions.saveAttributeForClass({\n            classId: this.selectedClass.id,\n            attribute: attrToSave,\n            route: path.toString()\n          })\n        );\n      } else if (this.interClass) {\n        let interAttribute = Object.assign([], this.interClass.attributes);\n        let interClassUpdated = { ...this.interClass };\n        interAttribute.push(attrToSave);\n        interClassUpdated.attributes = interAttribute;\n        this.store.dispatch(AdminClassActions.saveInterClass({ class: interClassUpdated, route: path.toString() }));\n      }\n    }\n  }\n\n  openModal() {\n    const ref = this.dialog.open(AddCategoryModalComponent);\n    ref.component!.entityType = 'attribute';\n    this.subscriptions.add(\n      ref.component!.category.subscribe((category) => {\n        this.attrForm.patchValue({\n          category: category.id\n        });\n      })\n    );\n    this.subscriptions.add(ref.component!.closeModal.subscribe(() => ref.close()));\n  }\n\n  protected readonly FIELD_I18N = FIELD_I18N;\n}\n","<form class=\"o-form\" [formGroup]=\"attrForm\" (ngSubmit)=\"addAttribute()\">\n  <div class=\"m-form-label-field -width-sm\">\n    <label class=\"a-label\" for=\"attr_technicalName\">{{ '@pry.admin.classes.attributes.technicalName' | i18n }}</label>\n    <input id=\"attr_technicalName\" type=\"text\" class=\"a-form-field\" formControlName=\"technicalName\" required />\n    <label class=\"a-label a-label--help -error\" for=\"attr_technicalName\" *ngIf=\"technicalNameAlreadyExists$ | async\">{{\n      '@pry.admin.exists' | i18n\n    }}</label>\n    <div *ngIf=\"attrForm.get('technicalName')?.invalid\">\n      <div *ngIf=\"attrForm.get('technicalName')?.dirty && attrForm.get('technicalName')?.hasError('required')\">\n        <label class=\"a-label a-label--help -error\" for=\"attr_technicalName\">{{ '@pry.admin.required' | i18n }}</label>\n      </div>\n      <div *ngIf=\"attrForm.get('technicalName')?.hasError('minlength')\">\n        <label class=\"a-label a-label--help -error\" for=\"attr_technicalName\">{{\n          '@pry.admin.minLength' | i18n: { len: 2 }\n        }}</label>\n      </div>\n      <div *ngIf=\"attrForm.get('technicalName')?.hasError('maxlength')\">\n        <label class=\"a-label a-label--help -error\" for=\"attr_technicalName\">{{\n          '@pry.admin.maxLength' | i18n: { len: 100 }\n        }}</label>\n      </div>\n      <div\n        *ngIf=\"\n          attrForm.get('technicalName')?.hasError('whitespace') && !attrForm.get('technicalName')?.hasError('minlength')\n        \"\n      >\n        <label class=\"a-label a-label--help -error\" for=\"attr_technicalName\">{{\n          '@pry.admin.noWhitespace' | i18n\n        }}</label>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"m-form-label-field -width-sm\">\n    <label class=\"a-label\" for=\"attr_name\">{{ '@pry.admin.classes.attributes.name' | i18n }}</label>\n    <input id=\"attr_name\" type=\"text\" class=\"a-form-field\" formControlName=\"name\" />\n    <label class=\"a-label a-label--help -error\" for=\"attr_name\" *ngIf=\"nameAlreadyExists$ | async\">{{\n      '@pry.admin.exists' | i18n\n    }}</label>\n    <div *ngIf=\"attrForm.get('name')?.invalid\">\n      <div *ngIf=\"attrForm.get('name')?.hasError('maxlength')\">\n        <label class=\"a-label a-label--help -error\" for=\"attr_name\">{{\n          '@pry.admin.maxLength' | i18n: { len: 50 }\n        }}</label>\n      </div>\n      <div *ngIf=\"attrForm.get('name')?.hasError('whitespace')\">\n        <label class=\"a-label a-label--help -error\" for=\"attr_name\">{{ '@pry.admin.noWhitespace' | i18n }}</label>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"m-form-label-field -width-sm\">\n    <label class=\"a-label\" for=\"type\">{{ '@pry.admin.classes.attributes.field' | i18n }}</label>\n    <div class=\"u-display-flex\">\n      <pry-select\n        id=\"type\"\n        formControlName=\"field\"\n        [items]=\"fields$ | async\"\n        [autocomplete]=\"true\"\n        bindLabel=\"name\"\n        bindValue=\"id\"\n        [isForm]=\"true\"\n        required=\"true\"\n        [template]=\"templateOption\"\n      ></pry-select>\n      <ng-template #templateOption let-item=\"item\">\n        <div class=\"aligned-option\">\n          <p>{{ item.name }}</p>\n          <div class=\"a-chip\" *ngIf=\"item.crs\">{{ item.crs }}</div>\n        </div>\n      </ng-template>\n      <div\n        class=\"m-info-icon a-tooltip -tooltip-width-lg u-self-center u-flex-shrink-0\"\n        [attr.data-tooltip]=\"(selectedFieldTypeDescription$ | async) ?? '' | i18n\"\n        data-tooltip-position=\"right\"\n      >\n        <span>i</span>\n      </div>\n    </div>\n    <div *ngIf=\"attrForm.get('field')?.invalid\">\n      <div *ngIf=\"attrForm.get('field')?.dirty && attrForm.get('field')?.hasError('required')\">\n        <label class=\"a-label a-label--help -error\" for=\"type\">{{ '@pry.admin.required' | i18n }}</label>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"m-form-label-field -width-sm\">\n    <label class=\"a-label\" for=\"category\">{{ '@pry.admin.classes.attributes.category' | i18n }}</label>\n    <pry-select\n      id=\"category\"\n      class=\"form-control\"\n      formControlName=\"category\"\n      [items]=\"categories$ | async\"\n      (click)=\"openModal()\"\n      bindValue=\"id\"\n      bindLabel=\"name\"\n      [isForm]=\"true\"\n      [readonly]=\"true\"\n    ></pry-select>\n  </div>\n\n  <div class=\"m-btn-group -width-sm\">\n    <button\n      type=\"button\"\n      class=\"a-btn a-btn--secondary\"\n      (click)=\"goBack()\"\n      [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n    ></button>\n    <button\n      *pryAccess=\"{ module: 'admin', page: 'classes', action: 'add_attribute' }\"\n      class=\"a-btn a-btn--primary\"\n      type=\"submit\"\n      [disabled]=\"attrForm.invalid || nameAlreadyExists || technicalNameAlreadyExists\"\n      [innerHTML]=\"(selectedAttribute ? '@pry.admin.edit' : '@pry.admin.create') | i18n\"\n    ></button>\n  </div>\n</form>\n"]}
151
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-attributes-form.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-view/admin-attributes-form/admin-attributes-form.component.ts","../../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-view/admin-attributes-form/admin-attributes-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\nimport { UntypedFormBuilder, UntypedFormGroup, Validators } from '@angular/forms';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  Attribute,\n  Category,\n  CategoryActions,\n  CategorySelectors,\n  Class,\n  DEFAULT_CATEGORY_UUID,\n  Field,\n  FIELD_I18N,\n  FieldActions,\n  FieldSelectors,\n  PryDialogService,\n  PryI18nService,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { combineLatest, debounceTime, distinctUntilChanged, map, Observable, startWith } from 'rxjs';\nimport { v4 as uuid } from 'uuid';\nimport { noWhitespaceValidator } from '../../../../components/admin.component';\nimport { AdminActions } from '../../../../store/admin.actions';\nimport { AdminClassActions } from '../../store/admin-class.actions';\nimport { AddCategoryModalComponent } from '../../../shared/add-category-modal/add-category-modal.component';\n\n@Component({\n  selector: 'pry-admin-attributes-form',\n  templateUrl: './admin-attributes-form.component.html'\n})\nexport class AdminAttributesFormComponent extends SubscriptionnerDirective implements OnInit, OnDestroy {\n  attrForm: UntypedFormGroup;\n\n  attributeNames?: string[];\n  attributeTechnicalNames?: string[];\n  nameAlreadyExists$?: Observable<boolean>;\n  technicalNameAlreadyExists$?: Observable<boolean>;\n  nameAlreadyExists = false;\n  technicalNameAlreadyExists = false;\n\n  fields$: Observable<Field[]>;\n  selectedFieldTypeDescription$!: Observable<string>;\n  categories$: Observable<Category[]>;\n\n  @Input() selectedClass?: Class;\n  @Input() interClass?: Class;\n  @Input() selectedAttribute?: Attribute;\n\n  constructor(\n    private store: Store<any>,\n    private router: Router,\n    private route: ActivatedRoute,\n    private formBuilder: UntypedFormBuilder,\n    private i18nService: PryI18nService,\n    private dialog: PryDialogService\n  ) {\n    super();\n    this.store.dispatch(FieldActions.load());\n    this.fields$ = this.store.select(FieldSelectors.fields);\n    this.store.dispatch(CategoryActions.load());\n    this.categories$ = this.store.select(CategorySelectors.categories);\n\n    this.attrForm = this.formBuilder.group({\n      id: [uuid()],\n      technicalName: [\n        '',\n        [Validators.required, Validators.minLength(2), Validators.maxLength(100), noWhitespaceValidator]\n      ],\n      name: ['', [Validators.maxLength(50), noWhitespaceValidator]],\n      description: [{ value: '', disabled: true }],\n      field: ['', [Validators.required]],\n      category: [DEFAULT_CATEGORY_UUID],\n      multiValued: [false]\n    });\n  }\n\n  ngOnInit(): void {\n    this.attributeNames = this.interClass?.attributes.map((attr: Attribute) => attr.name);\n    this.attributeTechnicalNames = this.interClass?.attributes.map((attr: Attribute) => attr.technicalName);\n\n    if (this.selectedClass) {\n      this.attributeNames = this.selectedClass.attributes.map((attr: Attribute) => attr.name);\n      this.attributeTechnicalNames = this.selectedClass.attributes.map((attr: Attribute) => attr.technicalName);\n\n      if (this.selectedAttribute) {\n        this.attrForm.patchValue({\n          id: this.selectedAttribute.id,\n          technicalName: this.selectedAttribute.technicalName,\n          name: this.selectedAttribute.name ?? this.selectedAttribute.technicalName,\n          field: this.selectedAttribute.field,\n          category: this.selectedAttribute.category\n        });\n        this.attrForm.controls['field'].disable();\n      }\n    }\n\n    if (this.attributeNames) {\n      this.nameAlreadyExists$ = this.attrForm\n        .get('name')!\n        .valueChanges.pipe(\n          map((value) => !!this.attributeNames?.includes(value) && value != this.selectedAttribute?.name)\n        );\n      this.subscriptions.add(this.nameAlreadyExists$.subscribe((value) => (this.nameAlreadyExists = value)));\n    }\n\n    this.subscriptions.add(\n      this.attrForm\n        .get('technicalName')!\n        .valueChanges.pipe(distinctUntilChanged(), debounceTime(500))\n        .subscribe((value) => {\n          this.attrForm.patchValue({\n            name: value.slice(0, 50)\n          });\n        })\n    );\n\n    if (this.attributeTechnicalNames) {\n      this.technicalNameAlreadyExists$ = this.attrForm\n        .get('technicalName')!\n        .valueChanges.pipe(\n          map(\n            (value) => !!this.attributeTechnicalNames?.includes(value) && value != this.selectedAttribute?.technicalName\n          )\n        );\n      this.subscriptions.add(\n        this.technicalNameAlreadyExists$.subscribe((value) => {\n          this.technicalNameAlreadyExists = value;\n        })\n      );\n    }\n\n    this.selectedFieldTypeDescription$ = combineLatest([\n      this.attrForm.get('field')!.valueChanges.pipe(startWith(this.attrForm.get('field')?.value)),\n      this.fields$\n    ]).pipe(\n      map(([selectedFieldId, fields]) =>\n        !selectedFieldId\n          ? ''\n          : FIELD_I18N.information +\n            fields.find(\n              (field) => field.id === (typeof selectedFieldId === 'string' ? selectedFieldId : selectedFieldId.id)\n            )?.type\n      )\n    );\n  }\n\n  goBack() {\n    const redirectPath = this.selectedAttribute ? '../..' : '..';\n    const path = this.router.createUrlTree([redirectPath], { relativeTo: this.route });\n    this.store.dispatch(AdminActions.routeTo({ path: path.toString() }));\n  }\n\n  addAttribute() {\n    this.attrForm.patchValue({\n      name: this.attrForm.value.name.trim()\n    });\n\n    if (!this.attrForm.value.name) {\n      this.attrForm.patchValue({\n        name: this.attrForm.value.technicalName.slice(0, 50)\n      });\n    }\n\n    if (this.attrForm.valid) {\n      let attrToSave = this.attrForm.getRawValue() as Attribute;\n      let path = this.router.createUrlTree(['..'], { relativeTo: this.route });\n\n      if (this.selectedAttribute) {\n        path = this.router.createUrlTree(['../..'], { relativeTo: this.route });\n      }\n\n      if (this.selectedClass) {\n        this.store.dispatch(\n          AdminClassActions.saveAttributeForClass({\n            classId: this.selectedClass.id,\n            attribute: attrToSave,\n            route: path.toString()\n          })\n        );\n      } else if (this.interClass) {\n        let interAttribute = Object.assign([], this.interClass.attributes);\n        let interClassUpdated = { ...this.interClass };\n        interAttribute.push(attrToSave);\n        interClassUpdated.attributes = interAttribute;\n        this.store.dispatch(AdminClassActions.saveInterClass({ class: interClassUpdated, route: path.toString() }));\n      }\n    }\n  }\n\n  openModal() {\n    const ref = this.dialog.open(AddCategoryModalComponent);\n    ref.component!.entityType = 'attribute';\n    this.subscriptions.add(\n      ref.component!.category.subscribe((category) => {\n        this.attrForm.patchValue({\n          category: category.id\n        });\n      })\n    );\n    this.subscriptions.add(ref.component!.closeModal.subscribe(() => ref.close()));\n  }\n\n  protected readonly FIELD_I18N = FIELD_I18N;\n}\n","<form class=\"o-form\" [formGroup]=\"attrForm\" (ngSubmit)=\"addAttribute()\">\n  <div class=\"m-form-label-field -width-sm\">\n    <label class=\"a-label\" for=\"attr_technicalName\">{{ '@pry.admin.classes.attributes.technicalName' | i18n }}</label>\n    <input id=\"attr_technicalName\" type=\"text\" class=\"a-form-field\" formControlName=\"technicalName\" required />\n    <label class=\"a-label a-label--help -error\" for=\"attr_technicalName\" *ngIf=\"technicalNameAlreadyExists$ | async\">{{\n      '@pry.admin.exists' | i18n\n    }}</label>\n    <div *ngIf=\"attrForm.get('technicalName')?.invalid\">\n      <div *ngIf=\"attrForm.get('technicalName')?.dirty && attrForm.get('technicalName')?.hasError('required')\">\n        <label class=\"a-label a-label--help -error\" for=\"attr_technicalName\">{{ '@pry.admin.required' | i18n }}</label>\n      </div>\n      <div *ngIf=\"attrForm.get('technicalName')?.hasError('minlength')\">\n        <label class=\"a-label a-label--help -error\" for=\"attr_technicalName\">{{\n          '@pry.admin.minLength' | i18n: { len: 2 }\n        }}</label>\n      </div>\n      <div *ngIf=\"attrForm.get('technicalName')?.hasError('maxlength')\">\n        <label class=\"a-label a-label--help -error\" for=\"attr_technicalName\">{{\n          '@pry.admin.maxLength' | i18n: { len: 100 }\n        }}</label>\n      </div>\n      <div\n        *ngIf=\"\n          attrForm.get('technicalName')?.hasError('whitespace') && !attrForm.get('technicalName')?.hasError('minlength')\n        \"\n      >\n        <label class=\"a-label a-label--help -error\" for=\"attr_technicalName\">{{\n          '@pry.admin.noWhitespace' | i18n\n        }}</label>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"m-form-label-field -width-sm\">\n    <label class=\"a-label\" for=\"attr_name\">{{ '@pry.admin.classes.attributes.name' | i18n }}</label>\n    <input id=\"attr_name\" type=\"text\" class=\"a-form-field\" formControlName=\"name\" />\n    <label class=\"a-label a-label--help -error\" for=\"attr_name\" *ngIf=\"nameAlreadyExists$ | async\">{{\n      '@pry.admin.exists' | i18n\n    }}</label>\n    <div *ngIf=\"attrForm.get('name')?.invalid\">\n      <div *ngIf=\"attrForm.get('name')?.hasError('maxlength')\">\n        <label class=\"a-label a-label--help -error\" for=\"attr_name\">{{\n          '@pry.admin.maxLength' | i18n: { len: 50 }\n        }}</label>\n      </div>\n      <div *ngIf=\"attrForm.get('name')?.hasError('whitespace')\">\n        <label class=\"a-label a-label--help -error\" for=\"attr_name\">{{ '@pry.admin.noWhitespace' | i18n }}</label>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"m-form-label-field -width-sm\">\n    <label class=\"a-label\" for=\"type\">{{ '@pry.admin.classes.attributes.field' | i18n }}</label>\n    <div class=\"u-display-flex\">\n      <pry-select\n        id=\"type\"\n        formControlName=\"field\"\n        [items]=\"fields$ | async\"\n        [autocomplete]=\"true\"\n        bindLabel=\"name\"\n        bindValue=\"id\"\n        [isForm]=\"true\"\n        required=\"true\"\n        [template]=\"templateOption\"\n      ></pry-select>\n      <ng-template #templateOption let-item=\"item\">\n        <div class=\"aligned-option\">\n          <p>{{ item.name }}</p>\n          <div class=\"a-chip\" *ngIf=\"item.crs\">{{ item.crs }}</div>\n        </div>\n      </ng-template>\n      <div\n        class=\"m-info-icon a-tooltip -tooltip-width-lg u-self-center u-flex-shrink-0\"\n        [attr.data-tooltip]=\"(selectedFieldTypeDescription$ | async) ?? '' | i18n\"\n        data-tooltip-position=\"right\"\n      >\n        <span>i</span>\n      </div>\n    </div>\n    <div *ngIf=\"attrForm.get('field')?.invalid\">\n      <div *ngIf=\"attrForm.get('field')?.dirty && attrForm.get('field')?.hasError('required')\">\n        <label class=\"a-label a-label--help -error\" for=\"type\">{{ '@pry.admin.required' | i18n }}</label>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"m-form-label-field -width-sm\">\n    <label class=\"a-label\" for=\"category\">{{ '@pry.admin.classes.attributes.category' | i18n }}</label>\n    <pry-select\n      id=\"category\"\n      class=\"form-control\"\n      formControlName=\"category\"\n      [items]=\"categories$ | async\"\n      (click)=\"openModal()\"\n      bindValue=\"id\"\n      bindLabel=\"name\"\n      [isForm]=\"true\"\n      [readonly]=\"true\"\n    ></pry-select>\n  </div>\n\n  <div class=\"m-btn-group -width-sm\">\n    <button\n      type=\"button\"\n      class=\"a-btn a-btn--secondary\"\n      (click)=\"goBack()\"\n      [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n    ></button>\n    <button\n      *pryAccess=\"{ module: 'admin', page: 'classes', action: 'add_attribute' }\"\n      class=\"a-btn a-btn--primary\"\n      type=\"submit\"\n      [disabled]=\"attrForm.invalid || nameAlreadyExists || technicalNameAlreadyExists\"\n      [innerHTML]=\"(selectedAttribute ? '@pry.admin.edit' : '@pry.admin.create') | i18n\"\n    ></button>\n  </div>\n</form>\n"]}
@@ -13,22 +13,21 @@ export class DataFormatPipe {
13
13
  if (typeof value === 'object') {
14
14
  return JSON.stringify(value);
15
15
  }
16
- if (decimalPrecision) {
17
- result = new Intl.NumberFormat(undefined, {
16
+ if (decimalPrecision || localeFormat) {
17
+ result = new Intl.NumberFormat(LOCALE.value, {
18
18
  // @ts-ignore
19
19
  roundingMode: 'floor',
20
20
  minimumFractionDigits: decimalPrecision,
21
- maximumFractionDigits: decimalPrecision
21
+ maximumFractionDigits: decimalPrecision,
22
+ useGrouping: localeFormat
22
23
  }).format(value);
23
24
  }
24
- if (localeFormat) {
25
- result = toLocaleString(result);
26
- }
27
25
  if (unit) {
28
26
  result = result + ' ' + unit;
29
27
  }
30
28
  if (format) {
31
- result = new Intl.DateTimeFormat(LOCALE.value, dateFormatOptions.value[format]).format(getDate(value));
29
+ const actualDate = getDate(value);
30
+ result = new Intl.DateTimeFormat(LOCALE.value, dateFormatOptions.value[format]).format(actualDate);
32
31
  }
33
32
  return result;
34
33
  }
@@ -39,17 +38,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
39
38
  type: Pipe,
40
39
  args: [{ name: 'dataFormat' }]
41
40
  }], ctorParameters: () => [] });
42
- // number formatting methods
43
- const toLocaleString = (value) => {
44
- switch (typeof value) {
45
- case 'number':
46
- return new Intl.NumberFormat(LOCALE.value, { maximumFractionDigits: 20 }).format(value);
47
- case 'string':
48
- return value;
49
- default:
50
- return value;
51
- }
52
- };
53
41
  // date formatting methods
54
42
  export const dateFormatOptions = {
55
43
  value: {
@@ -110,4 +98,4 @@ export const toD3Format = (format) => {
110
98
  return '%Y-%B-%dT%H:%M:%S';
111
99
  }
112
100
  };
113
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1mb3JtYXQucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL2NvbXBvbmVudHMvZGF0YS1mb3JtYXQvZGF0YS1mb3JtYXQucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQzs7QUFHcEQsTUFBTSxDQUFDLE1BQU0sTUFBTSxHQUFHO0lBQ3BCLEtBQUssRUFBRSxTQUFTLENBQUMsU0FBUyxJQUFJLFNBQVMsQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsUUFBUTtDQUN2RyxDQUFDO0FBR0YsTUFBTSxPQUFPLGNBQWM7SUFDekIsZ0JBQWUsQ0FBQztJQUVoQixTQUFTLENBQ1AsS0FBVSxFQUNWLEVBQUUsWUFBWSxFQUFFLElBQUksRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLEtBQXlDLEVBQUU7UUFFekYsSUFBSSxNQUFNLEdBQUcsS0FBSyxDQUFDO1FBRW5CLElBQUksS0FBSyxLQUFLLElBQUksSUFBSSxLQUFLLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDMUMsT0FBTyxLQUFLLENBQUM7UUFDZixDQUFDO1FBRUQsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUM5QixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDL0IsQ0FBQztRQUVELElBQUksZ0JBQWdCLEVBQUUsQ0FBQztZQUNyQixNQUFNLEdBQUcsSUFBSSxJQUFJLENBQUMsWUFBWSxDQUFDLFNBQVMsRUFBRTtnQkFDeEMsYUFBYTtnQkFDYixZQUFZLEVBQUUsT0FBTztnQkFDckIscUJBQXFCLEVBQUUsZ0JBQWdCO2dCQUN2QyxxQkFBcUIsRUFBRSxnQkFBZ0I7YUFD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QU8sSUFBSSxDQUFDO1FBQ2QsS0FBSyxLQUFLO1lBQ1IsT0FBTyxJQUFJLENBQUM7UUFDZDtZQUNFLE9BQU8sbUJBQW1CLENBQUM7SUFDL0IsQ0FBQztBQUNILENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1hdE9wdGlvbnMgfSBmcm9tICdAcHJvdm9seS9kYXNoYm9hcmQnO1xuXG5leHBvcnQgY29uc3QgTE9DQUxFID0ge1xuICB2YWx1ZTogbmF2aWdhdG9yLmxhbmd1YWdlcyAmJiBuYXZpZ2F0b3IubGFuZ3VhZ2VzLmxlbmd0aCA/IG5hdmlnYXRvci5sYW5ndWFnZXNbMF0gOiBuYXZpZ2F0b3IubGFuZ3VhZ2Vcbn07XG5cbkBQaXBlKHsgbmFtZTogJ2RhdGFGb3JtYXQnIH0pXG5leHBvcnQgY2xhc3MgRGF0YUZvcm1hdFBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIHRyYW5zZm9ybShcbiAgICB2YWx1ZTogYW55LFxuICAgIHsgbG9jYWxlRm9ybWF0LCB1bml0LCBkZWNpbWFsUHJlY2lzaW9uLCBmb3JtYXQgfTogUGFydGlhbDxGb3JtYXRPcHRpb25zPiB8IHVuZGVmaW5lZCA9IHt9XG4gICk6IGFueSB7XG4gICAgbGV0IHJlc3VsdCA9IHZhbHVlO1xuXG4gICAgaWYgKHZhbHVlID09PSBudWxsIHx8IHZhbHVlID09PSB1bmRlZmluZWQpIHtcbiAgICAgIHJldHVybiB2YWx1ZTtcbiAgICB9XG5cbiAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnb2JqZWN0Jykge1xuICAgICAgcmV0dXJuIEpTT04uc3RyaW5naWZ5KHZhbHVlKTtcbiAgICB9XG5cbiAgICBpZiAoZGVjaW1hbFByZWNpc2lvbikge1xuICAgICAgcmVzdWx0ID0gbmV3IEludGwuTnVtYmVyRm9ybWF0KHVuZGVmaW5lZCwge1xuICAgICAgICAvLyBAdHMtaWdub3JlXG4gICAgICAgIHJvdW5kaW5nTW9kZTogJ2Zsb29yJyxcbiAgICAgICAgbWluaW11bUZyYWN0aW9uRGlnaXRzOiBkZWNpbWFsUHJlY2lzaW9uLFxuICAgICAgICBtYXhpbXVtRnJhY3Rpb25EaWdpdHM6IGRlY2ltYWxQcmVjaXNpb25cbiAgICAgIH0pLmZvcm1hdCh2YWx1ZSk7XG4gICAgfVxuXG4gICAgaWYgKGxvY2FsZUZvcm1hdCkge1xuICAgICAgcmVzdWx0ID0gdG9Mb2NhbGVTdHJpbmcocmVzdWx0KTtcbiAgICB9XG4gICAgaWYgKHVuaXQpIHtcbiAgICAgIHJlc3VsdCA9IHJlc3VsdCArICfigK8nICsgdW5pdDtcbiAgICB9XG5cbiAgICBpZiAoZm9ybWF0KSB7XG4gICAgICByZXN1bHQgPSBuZXcgSW50bC5EYXRlVGltZUZvcm1hdChMT0NBTEUudmFsdWUsIGRhdGVGb3JtYXRPcHRpb25zLnZhbHVlW2Zvcm1hdF0pLmZvcm1hdChnZXREYXRlKHZhbHVlKSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHJlc3VsdDtcbiAgfVxufVxuXG4vLyBudW1iZXIgZm9ybWF0dGluZyBtZXRob2RzXG5jb25zdCB0b0xvY2FsZVN0cmluZyA9ICh2YWx1ZT86IHN0cmluZyB8IG51bWJlcikgPT4ge1xuICBzd2l0Y2ggKHR5cGVvZiB2YWx1ZSkge1xuICAgIGNhc2UgJ251bWJlcic6XG4gICAgICByZXR1cm4gbmV3IEludGwuTnVtYmVyRm9ybWF0KExPQ0FMRS52YWx1ZSwgeyBtYXhpbXVtRnJhY3Rpb25EaWdpdHM6IDIwIH0pLmZvcm1hdCh2YWx1ZSk7XG4gICAgY2FzZSAnc3RyaW5nJzpcbiAgICAgIHJldHVybiB2YWx1ZTtcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIHZhbHVlO1xuICB9XG59O1xuXG4vLyBkYXRlIGZvcm1hdHRpbmcgbWV0aG9kc1xuZXhwb3J0IGNvbnN0IGRhdGVGb3JtYXRPcHRpb25zOiB7IHZhbHVlOiB7IFtrZXk6IHN0cmluZ106IEludGwuRGF0ZVRpbWVGb3JtYXRPcHRpb25zIH0gfSA9IHtcbiAgdmFsdWU6IHtcbiAgICBEQVRFVElNRToge1xuICAgICAgeWVhcjogJ251bWVyaWMnLFxuICAgICAgbW9udGg6ICdudW1lcmljJyxcbiAgICAgIGRheTogJ251bWVyaWMnLFxuICAgICAgaG91cjogJ251bWVyaWMnLFxuICAgICAgbWludXRlOiAnbnVtZXJpYydcbiAgICB9LFxuICAgIERBVEU6IHtcbiAgICAgIHllYXI6ICdudW1lcmljJyxcbiAgICAgIG1vbnRoOiAnMi1kaWdpdCcsXG4gICAgICBkYXk6ICcyLWRpZ2l0J1xuICAgIH0sXG4gICAgTU9OVEhfWUVBUjoge1xuICAgICAgbW9udGg6ICcyLWRpZ2l0JyxcbiAgICAgIHllYXI6ICdudW1lcmljJ1xuICAgIH0sXG4gICAgREFZX01PTlRIOiB7XG4gICAgICBtb250aDogJzItZGlnaXQnLFxuICAgICAgZGF5OiAnMi1kaWdpdCdcbiAgICB9LFxuICAgIFlFQVI6IHtcbiAgICAgIHllYXI6ICdudW1lcmljJ1xuICAgIH0sXG4gICAgTU9OVEg6IHtcbiAgICAgIG1vbnRoOiAnMi1kaWdpdCdcbiAgICB9LFxuICAgIERBWToge1xuICAgICAgZGF5OiAnMi1kaWdpdCdcbiAgICB9XG4gIH1cbn07XG5cbmNvbnN0IGdldERhdGUgPSAodmFsdWU6IHN0cmluZyB8IG51bWJlciB8IERhdGUpOiBEYXRlID0+IHtcbiAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycgfHwgdHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJykge1xuICAgIHJldHVybiBuZXcgRGF0ZSh2YWx1ZSk7XG4gIH1cbiAgcmV0dXJuIHZhbHVlO1xufTtcblxuZXhwb3J0IGNvbnN0IHRvRDNGb3JtYXQgPSAoZm9ybWF0Pzogc3RyaW5nKSA9PiB7XG4gIHN3aXRjaCAoZm9ybWF0KSB7XG4gICAgY2FzZSAnREFURVRJTUUnOlxuICAgICAgcmV0dXJuICclWS0lbS0lZFQlSDolTTolUyc7XG4gICAgY2FzZSAnREFURSc6XG4gICAgICByZXR1cm4gJyVZLSVtLSVkJztcbiAgICBjYXNlICdNT05USF9ZRUFSJzpcbiAgICAgIHJldHVybiAnJW0tJVknO1xuICAgIGNhc2UgJ0RBWV9NT05USCc6XG4gICAgICByZXR1cm4gJyVkLSVtJztcbiAgICBjYXNlICdZRUFSJzpcbiAgICAgIHJldHVybiAnJVknO1xuICAgIGNhc2UgJ01PTlRIJzpcbiAgICAgIHJldHVybiAnJW0nO1xuICAgIGNhc2UgJ0RBWSc6XG4gICAgICByZXR1cm4gJyVkJztcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuICclWS0lQi0lZFQlSDolTTolUyc7XG4gIH1cbn07XG4iXX0=
101
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1mb3JtYXQucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL2NvbXBvbmVudHMvZGF0YS1mb3JtYXQvZGF0YS1mb3JtYXQucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQzs7QUFHcEQsTUFBTSxDQUFDLE1BQU0sTUFBTSxHQUFHO0lBQ3BCLEtBQUssRUFBRSxTQUFTLENBQUMsU0FBUyxJQUFJLFNBQVMsQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsUUFBUTtDQUN2RyxDQUFDO0FBR0YsTUFBTSxPQUFPLGNBQWM7SUFDekIsZ0JBQWUsQ0FBQztJQUVoQixTQUFTLENBQ1AsS0FBVSxFQUNWLEVBQUUsWUFBWSxFQUFFLElBQUksRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLEtBQXlDLEVBQUU7UUFFekYsSUFBSSxNQUFNLEdBQUcsS0FBSyxDQUFDO1FBRW5CLElBQUksS0FBSyxLQUFLLElBQUksSUFBSSxLQUFLLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDMUMsT0FBTyxLQUFLLENBQUM7UUFDZixDQUFDO1FBRUQsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLEVBQUUsQ0FBQztZQUM5QixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDL0IsQ0FBQztRQUVELElBQUksZ0JBQWdCLElBQUksWUFBWSxFQUFFLENBQUM7WUFDckMsTUFBTSxHQUFHLElBQUksSUFBSSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFO2dCQUMzQyxhQUFhO2dCQUNiLFlBQVksRUFBRSxPQUFPO2dCQUNyQixxQkFBcUIsRUFBRSxnQkFBZ0I7Z0JBQ3ZDLHFCQUFxQixFQUFFLGdCQUFnQjtnQkFDdkMsV0FBVyxFQUFFLFlBQVk7YUFDMUIsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNuQixDQUFDO1FBRUQsSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUNULE1BQU0sR0FBRyxNQUFNLEdBQUcsR0FBRyxHQUFHLElBQUksQ0FBQztRQUMvQixDQUFDO1FBRUQsSUFBSSxNQUFNLEVBQUUsQ0FBQztZQUNYLE1BQU0sVUFBVSxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNsQyxNQUFNLEdBQUcsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsaUJBQWlCLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ3JHLENBQUM7UUFFRCxPQUFPLE1BQU0sQ0FBQztJQUNoQixDQUFDOzhHQXJDVSxjQUFjOzRHQUFkLGNBQWM7OzJGQUFkLGNBQWM7a0JBRDFCLElBQUk7bUJBQUMsRUFBRSxJQUFJLEVBQUUsWUFBWSxFQUFFOztBQXlDNUIsMEJBQTBCO0FBQzFCLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUE2RDtJQUN6RixLQUFLLEVBQUU7UUFDTCxRQUFRLEVBQUU7WUFDUixJQUFJLEVBQUUsU0FBUztZQUNmLEtBQUssRUFBRSxTQUFTO1lBQ2hCLEdBQUcsRUFBRSxTQUFTO1lBQ2QsSUFBSSxFQUFFLFNBQVM7WUFDZixNQUFNLEVBQUUsU0FBUztTQUNsQjtRQUNELElBQUksRUFBRTtZQUNKLElBQUksRUFBRSxTQUFTO1lBQ2YsS0FBSyxFQUFFLFNBQVM7WUFDaEIsR0FBRyxFQUFFLFNBQVM7U0FDZjtRQUNELFVBQVUsRUFBRTtZQUNWLEtBQUssRUFBRSxTQUFTO1lBQ2hCLElBQUksRUFBRSxTQUFTO1NBQ2hCO1FBQ0QsU0FBUyxFQUFFO1lBQ1QsS0FBSyxFQUFFLFNBQVM7WUFDaEIsR0FBRyxFQUFFLFNBQVM7U0FDZjtRQUNELElBQUksRUFBRTtZQUNKLElBQUksRUFBRSxTQUFTO1NBQ2hCO1FBQ0QsS0FBSyxFQUFFO1lBQ0wsS0FBSyxFQUFFLFNBQVM7U0FDakI7UUFDRCxHQUFHLEVBQUU7WUFDSCxHQUFHLEVBQUUsU0FBUztTQUNmO0tBQ0Y7Q0FDRixDQUFDO0FBRUYsTUFBTSxPQUFPLEdBQUcsQ0FBQyxLQUE2QixFQUFRLEVBQUU7SUFDdEQsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLElBQUksT0FBTyxLQUFLLEtBQUssUUFBUSxFQUFFLENBQUM7UUFDM0QsT0FBTyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN6QixDQUFDO0lBQ0QsT0FBTyxLQUFLLENBQUM7QUFDZixDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUcsQ0FBQyxNQUFlLEVBQUUsRUFBRTtJQUM1QyxRQUFRLE1BQU0sRUFBRSxDQUFDO1FBQ2YsS0FBSyxVQUFVO1lBQ2IsT0FBTyxtQkFBbUIsQ0FBQztRQUM3QixLQUFLLE1BQU07WUFDVCxPQUFPLFVBQVUsQ0FBQztRQUNwQixLQUFLLFlBQVk7WUFDZixPQUFPLE9BQU8sQ0FBQztRQUNqQixLQUFLLFdBQVc7WUFDZCxPQUFPLE9BQU8sQ0FBQztRQUNqQixLQUFLLE1BQU07WUFDVCxPQUFPLElBQUksQ0FBQztRQUNkLEtBQUssT0FBTztZQUNWLE9BQU8sSUFBSSxDQUFDO1FBQ2QsS0FBSyxLQUFLO1lBQ1IsT0FBTyxJQUFJLENBQUM7UUFDZDtZQUNFLE9BQU8sbUJBQW1CLENBQUM7SUFDL0IsQ0FBQztBQUNILENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1hdE9wdGlvbnMgfSBmcm9tICdAcHJvdm9seS9kYXNoYm9hcmQnO1xuXG5leHBvcnQgY29uc3QgTE9DQUxFID0ge1xuICB2YWx1ZTogbmF2aWdhdG9yLmxhbmd1YWdlcyAmJiBuYXZpZ2F0b3IubGFuZ3VhZ2VzLmxlbmd0aCA/IG5hdmlnYXRvci5sYW5ndWFnZXNbMF0gOiBuYXZpZ2F0b3IubGFuZ3VhZ2Vcbn07XG5cbkBQaXBlKHsgbmFtZTogJ2RhdGFGb3JtYXQnIH0pXG5leHBvcnQgY2xhc3MgRGF0YUZvcm1hdFBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIHRyYW5zZm9ybShcbiAgICB2YWx1ZTogYW55LFxuICAgIHsgbG9jYWxlRm9ybWF0LCB1bml0LCBkZWNpbWFsUHJlY2lzaW9uLCBmb3JtYXQgfTogUGFydGlhbDxGb3JtYXRPcHRpb25zPiB8IHVuZGVmaW5lZCA9IHt9XG4gICk6IGFueSB7XG4gICAgbGV0IHJlc3VsdCA9IHZhbHVlO1xuXG4gICAgaWYgKHZhbHVlID09PSBudWxsIHx8IHZhbHVlID09PSB1bmRlZmluZWQpIHtcbiAgICAgIHJldHVybiB2YWx1ZTtcbiAgICB9XG5cbiAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnb2JqZWN0Jykge1xuICAgICAgcmV0dXJuIEpTT04uc3RyaW5naWZ5KHZhbHVlKTtcbiAgICB9XG5cbiAgICBpZiAoZGVjaW1hbFByZWNpc2lvbiB8fCBsb2NhbGVGb3JtYXQpIHtcbiAgICAgIHJlc3VsdCA9IG5ldyBJbnRsLk51bWJlckZvcm1hdChMT0NBTEUudmFsdWUsIHtcbiAgICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgICByb3VuZGluZ01vZGU6ICdmbG9vcicsXG4gICAgICAgIG1pbmltdW1GcmFjdGlvbkRpZ2l0czogZGVjaW1hbFByZWNpc2lvbixcbiAgICAgICAgbWF4aW11bUZyYWN0aW9uRGlnaXRzOiBkZWNpbWFsUHJlY2lzaW9uLFxuICAgICAgICB1c2VHcm91cGluZzogbG9jYWxlRm9ybWF0XG4gICAgICB9KS5mb3JtYXQodmFsdWUpO1xuICAgIH1cblxuICAgIGlmICh1bml0KSB7XG4gICAgICByZXN1bHQgPSByZXN1bHQgKyAn4oCvJyArIHVuaXQ7XG4gICAgfVxuXG4gICAgaWYgKGZvcm1hdCkge1xuICAgICAgY29uc3QgYWN0dWFsRGF0ZSA9IGdldERhdGUodmFsdWUpO1xuICAgICAgcmVzdWx0ID0gbmV3IEludGwuRGF0ZVRpbWVGb3JtYXQoTE9DQUxFLnZhbHVlLCBkYXRlRm9ybWF0T3B0aW9ucy52YWx1ZVtmb3JtYXRdKS5mb3JtYXQoYWN0dWFsRGF0ZSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHJlc3VsdDtcbiAgfVxufVxuXG4vLyBkYXRlIGZvcm1hdHRpbmcgbWV0aG9kc1xuZXhwb3J0IGNvbnN0IGRhdGVGb3JtYXRPcHRpb25zOiB7IHZhbHVlOiB7IFtrZXk6IHN0cmluZ106IEludGwuRGF0ZVRpbWVGb3JtYXRPcHRpb25zIH0gfSA9IHtcbiAgdmFsdWU6IHtcbiAgICBEQVRFVElNRToge1xuICAgICAgeWVhcjogJ251bWVyaWMnLFxuICAgICAgbW9udGg6ICdudW1lcmljJyxcbiAgICAgIGRheTogJ251bWVyaWMnLFxuICAgICAgaG91cjogJ251bWVyaWMnLFxuICAgICAgbWludXRlOiAnbnVtZXJpYydcbiAgICB9LFxuICAgIERBVEU6IHtcbiAgICAgIHllYXI6ICdudW1lcmljJyxcbiAgICAgIG1vbnRoOiAnMi1kaWdpdCcsXG4gICAgICBkYXk6ICcyLWRpZ2l0J1xuICAgIH0sXG4gICAgTU9OVEhfWUVBUjoge1xuICAgICAgbW9udGg6ICcyLWRpZ2l0JyxcbiAgICAgIHllYXI6ICdudW1lcmljJ1xuICAgIH0sXG4gICAgREFZX01PTlRIOiB7XG4gICAgICBtb250aDogJzItZGlnaXQnLFxuICAgICAgZGF5OiAnMi1kaWdpdCdcbiAgICB9LFxuICAgIFlFQVI6IHtcbiAgICAgIHllYXI6ICdudW1lcmljJ1xuICAgIH0sXG4gICAgTU9OVEg6IHtcbiAgICAgIG1vbnRoOiAnMi1kaWdpdCdcbiAgICB9LFxuICAgIERBWToge1xuICAgICAgZGF5OiAnMi1kaWdpdCdcbiAgICB9XG4gIH1cbn07XG5cbmNvbnN0IGdldERhdGUgPSAodmFsdWU6IHN0cmluZyB8IG51bWJlciB8IERhdGUpOiBEYXRlID0+IHtcbiAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycgfHwgdHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJykge1xuICAgIHJldHVybiBuZXcgRGF0ZSh2YWx1ZSk7XG4gIH1cbiAgcmV0dXJuIHZhbHVlO1xufTtcblxuZXhwb3J0IGNvbnN0IHRvRDNGb3JtYXQgPSAoZm9ybWF0Pzogc3RyaW5nKSA9PiB7XG4gIHN3aXRjaCAoZm9ybWF0KSB7XG4gICAgY2FzZSAnREFURVRJTUUnOlxuICAgICAgcmV0dXJuICclWS0lbS0lZFQlSDolTTolUyc7XG4gICAgY2FzZSAnREFURSc6XG4gICAgICByZXR1cm4gJyVZLSVtLSVkJztcbiAgICBjYXNlICdNT05USF9ZRUFSJzpcbiAgICAgIHJldHVybiAnJW0tJVknO1xuICAgIGNhc2UgJ0RBWV9NT05USCc6XG4gICAgICByZXR1cm4gJyVkLSVtJztcbiAgICBjYXNlICdZRUFSJzpcbiAgICAgIHJldHVybiAnJVknO1xuICAgIGNhc2UgJ01PTlRIJzpcbiAgICAgIHJldHVybiAnJW0nO1xuICAgIGNhc2UgJ0RBWSc6XG4gICAgICByZXR1cm4gJyVkJztcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuICclWS0lQi0lZFQlSDolTTolUyc7XG4gIH1cbn07XG4iXX0=
@@ -11,6 +11,7 @@ export class PryPaginatorComponent {
11
11
  this.nbPerPage = input(10);
12
12
  this.totalItemNb = input(100);
13
13
  this.mode = input('long');
14
+ this.goBackToFirstPage = input();
14
15
  this.nbOfPages = computed(() => {
15
16
  return Math.floor(this.totalItemNb() / this.nbPerPage());
16
17
  });
@@ -20,10 +21,16 @@ export class PryPaginatorComponent {
20
21
  this.currentPage = signal(1);
21
22
  this.pageChange = new EventEmitter();
22
23
  effect(() => {
24
+ // if current page changes, dispatch action to load data
23
25
  if (this.currentPage()) {
24
26
  this.dispatchPageChangeAction();
25
27
  }
26
28
  }, { allowSignalWrites: true });
29
+ effect(() => {
30
+ if (this.goBackToFirstPage()) {
31
+ this.changePage(1);
32
+ }
33
+ }, { allowSignalWrites: true });
27
34
  }
28
35
  dispatchPageChangeAction() {
29
36
  if (untracked(this.action)) {
@@ -40,7 +47,7 @@ export class PryPaginatorComponent {
40
47
  this.pageChange.emit(page);
41
48
  }
42
49
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: PryPaginatorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
43
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: PryPaginatorComponent, selector: "pry-paginator", inputs: { action: { classPropertyName: "action", publicName: "action", isSignal: true, isRequired: false, transformFunction: null }, nbPerPage: { classPropertyName: "nbPerPage", publicName: "nbPerPage", isSignal: true, isRequired: false, transformFunction: null }, totalItemNb: { classPropertyName: "totalItemNb", publicName: "totalItemNb", isSignal: true, isRequired: false, transformFunction: null }, mode: { classPropertyName: "mode", publicName: "mode", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { pageChange: "pageChange" }, ngImport: i0, template: "<pry-paginator-css></pry-paginator-css>\n<div\n class=\"o-paginator u-display-flex -align-center\"\n [class.o-paginator--long]=\"mode() === 'long'\"\n [class.o-paginator--short]=\"mode() === 'short'\"\n>\n @if (mode() === 'long') {\n <ng-container *ngTemplateOutlet=\"longPaginator\"></ng-container>\n } @else {\n <ng-container *ngTemplateOutlet=\"shortPaginator\"></ng-container>\n }\n</div>\n\n<ng-template #shortPaginator>\n <button (click)=\"changePage(1)\" [disabled]=\"currentPage() === 1\">\n <pry-icon iconSvg=\"skip-left-fill\"></pry-icon>\n </button>\n <button (click)=\"changePage(currentPage() - 1)\" [disabled]=\"currentPage() === 1\">\n <pry-icon iconSvg=\"arrow-left-s-fill\"></pry-icon>\n </button>\n <span class=\"o-paginator__page-counter\">{{ currentPage() }} / {{ nbOfPages() }}</span>\n <button (click)=\"changePage(currentPage() + 1)\" [disabled]=\"currentPage() === nbOfPages()\">\n <pry-icon iconSvg=\"arrow-right-s-fill\"></pry-icon>\n </button>\n <button (click)=\"changePage(nbOfPages())\" [disabled]=\"currentPage() === nbOfPages()\">\n <pry-icon iconSvg=\"skip-right-fill\"></pry-icon>\n </button>\n</ng-template>\n\n<ng-template #longPaginator>\n @if (currentPage() > 1) {\n <button (click)=\"changePage(currentPage() - 1)\">\n <pry-icon iconSvg=\"chevron_left\"></pry-icon>\n </button>\n }\n @if (nbOfPages() > 8) {\n @if (currentPage() < 3) {\n @for (page of pages().slice(0, 3); track page) {\n <button\n class=\"a-btn -small-circle -no-padding\"\n [class.a-btn--primary]=\"page === currentPage()\"\n [class.a-btn--ghost]=\"page !== currentPage()\"\n (click)=\"changePage(page)\"\n >\n {{ page }}\n </button>\n }\n <span class=\"u-self-end\">...</span>\n <button class=\"a-btn -small-circle -no-padding\" (click)=\"changePage(pages().length)\">\n {{ pages().length }}\n </button>\n } @else if (currentPage() > pages().length - 2) {\n <button\n class=\"a-btn -small-circle -no-padding\"\n (click)=\"changePage(1)\"\n [class.a-btn--primary]=\"currentPage() === 1\"\n [class.a-btn--ghost]=\"currentPage() !== 1\"\n >\n 1\n </button>\n <span class=\"u-self-end\">...</span>\n @for (page of pages().slice(-3); track page) {\n <button\n class=\"a-btn -small-circle -no-padding\"\n [class.a-btn--primary]=\"page === currentPage()\"\n [class.a-btn--ghost]=\"page !== currentPage()\"\n (click)=\"changePage(page)\"\n >\n {{ page }}\n </button>\n }\n } @else {\n <button class=\"a-btn -small-circle -no-padding\" (click)=\"changePage(1)\">1</button>\n <span>...</span>\n @for (page of pages().slice(currentPage() - 2, currentPage() + 1); track page) {\n <button\n class=\"a-btn -small-circle -no-padding\"\n [class.a-btn--primary]=\"page === currentPage()\"\n [class.a-btn--ghost]=\"page !== currentPage()\"\n (click)=\"changePage(page)\"\n >\n {{ page }}\n </button>\n }\n <span>...</span>\n <button\n class=\"a-btn -small-circle -no-padding\"\n [class.a-btn--primary]=\"currentPage() === pages().length\"\n [class.a-btn--ghost]=\"currentPage() !== pages().length\"\n (click)=\"changePage(pages().length)\"\n >\n {{ pages().length }}\n </button>\n }\n } @else {\n @for (page of pages(); track page) {\n <button\n class=\"a-btn -small-circle -no-padding\"\n [class.a-btn--primary]=\"page === currentPage()\"\n [class.a-btn--ghost]=\"page !== currentPage()\"\n (click)=\"changePage(page)\"\n >\n {{ page }}\n </button>\n }\n }\n @if (currentPage() < pages().length) {\n <button (click)=\"changePage(currentPage() + 1)\">\n <pry-icon iconSvg=\"chevron_right\"></pry-icon>\n </button>\n }\n</ng-template>\n", dependencies: [{ kind: "component", type: i1.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.PryPaginatorCssComponent, selector: "pry-paginator-css" }] }); }
50
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: PryPaginatorComponent, selector: "pry-paginator", inputs: { action: { classPropertyName: "action", publicName: "action", isSignal: true, isRequired: false, transformFunction: null }, nbPerPage: { classPropertyName: "nbPerPage", publicName: "nbPerPage", isSignal: true, isRequired: false, transformFunction: null }, totalItemNb: { classPropertyName: "totalItemNb", publicName: "totalItemNb", isSignal: true, isRequired: false, transformFunction: null }, mode: { classPropertyName: "mode", publicName: "mode", isSignal: true, isRequired: false, transformFunction: null }, goBackToFirstPage: { classPropertyName: "goBackToFirstPage", publicName: "goBackToFirstPage", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { pageChange: "pageChange" }, ngImport: i0, template: "<pry-paginator-css></pry-paginator-css>\n<div\n class=\"o-paginator u-display-flex -align-center\"\n [class.o-paginator--long]=\"mode() === 'long'\"\n [class.o-paginator--short]=\"mode() === 'short'\"\n>\n @if (mode() === 'long') {\n <ng-container *ngTemplateOutlet=\"longPaginator\"></ng-container>\n } @else {\n <ng-container *ngTemplateOutlet=\"shortPaginator\"></ng-container>\n }\n</div>\n\n<ng-template #shortPaginator>\n <button (click)=\"changePage(1)\" [disabled]=\"currentPage() === 1\">\n <pry-icon iconSvg=\"skip-left-fill\"></pry-icon>\n </button>\n <button (click)=\"changePage(currentPage() - 1)\" [disabled]=\"currentPage() === 1\">\n <pry-icon iconSvg=\"arrow-left-s-fill\"></pry-icon>\n </button>\n <span class=\"o-paginator__page-counter\">{{ currentPage() }} / {{ nbOfPages() }}</span>\n <button (click)=\"changePage(currentPage() + 1)\" [disabled]=\"currentPage() === nbOfPages()\">\n <pry-icon iconSvg=\"arrow-right-s-fill\"></pry-icon>\n </button>\n <button (click)=\"changePage(nbOfPages())\" [disabled]=\"currentPage() === nbOfPages()\">\n <pry-icon iconSvg=\"skip-right-fill\"></pry-icon>\n </button>\n</ng-template>\n\n<ng-template #longPaginator>\n @if (currentPage() > 1) {\n <button (click)=\"changePage(currentPage() - 1)\">\n <pry-icon iconSvg=\"chevron_left\"></pry-icon>\n </button>\n }\n @if (nbOfPages() > 8) {\n @if (currentPage() < 3) {\n @for (page of pages().slice(0, 3); track page) {\n <button\n class=\"a-btn -small-circle -no-padding\"\n [class.a-btn--primary]=\"page === currentPage()\"\n [class.a-btn--ghost]=\"page !== currentPage()\"\n (click)=\"changePage(page)\"\n >\n {{ page }}\n </button>\n }\n <span class=\"u-self-end\">...</span>\n <button class=\"a-btn -small-circle -no-padding\" (click)=\"changePage(pages().length)\">\n {{ pages().length }}\n </button>\n } @else if (currentPage() > pages().length - 2) {\n <button\n class=\"a-btn -small-circle -no-padding\"\n (click)=\"changePage(1)\"\n [class.a-btn--primary]=\"currentPage() === 1\"\n [class.a-btn--ghost]=\"currentPage() !== 1\"\n >\n 1\n </button>\n <span class=\"u-self-end\">...</span>\n @for (page of pages().slice(-3); track page) {\n <button\n class=\"a-btn -small-circle -no-padding\"\n [class.a-btn--primary]=\"page === currentPage()\"\n [class.a-btn--ghost]=\"page !== currentPage()\"\n (click)=\"changePage(page)\"\n >\n {{ page }}\n </button>\n }\n } @else {\n <button class=\"a-btn -small-circle -no-padding\" (click)=\"changePage(1)\">1</button>\n <span>...</span>\n @for (page of pages().slice(currentPage() - 2, currentPage() + 1); track page) {\n <button\n class=\"a-btn -small-circle -no-padding\"\n [class.a-btn--primary]=\"page === currentPage()\"\n [class.a-btn--ghost]=\"page !== currentPage()\"\n (click)=\"changePage(page)\"\n >\n {{ page }}\n </button>\n }\n <span>...</span>\n <button\n class=\"a-btn -small-circle -no-padding\"\n [class.a-btn--primary]=\"currentPage() === pages().length\"\n [class.a-btn--ghost]=\"currentPage() !== pages().length\"\n (click)=\"changePage(pages().length)\"\n >\n {{ pages().length }}\n </button>\n }\n } @else {\n @for (page of pages(); track page) {\n <button\n class=\"a-btn -small-circle -no-padding\"\n [class.a-btn--primary]=\"page === currentPage()\"\n [class.a-btn--ghost]=\"page !== currentPage()\"\n (click)=\"changePage(page)\"\n >\n {{ page }}\n </button>\n }\n }\n @if (currentPage() < pages().length) {\n <button (click)=\"changePage(currentPage() + 1)\">\n <pry-icon iconSvg=\"chevron_right\"></pry-icon>\n </button>\n }\n</ng-template>\n", dependencies: [{ kind: "component", type: i1.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.PryPaginatorCssComponent, selector: "pry-paginator-css" }] }); }
44
51
  }
45
52
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: PryPaginatorComponent, decorators: [{
46
53
  type: Component,
@@ -48,4 +55,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
48
55
  }], ctorParameters: () => [], propDecorators: { pageChange: [{
49
56
  type: Output
50
57
  }] } });
51
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/components/paginator/paginator.component.ts","../../../../../../projects/provoly/dashboard/components/paginator/paginator.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACpH,OAAO,EAAU,KAAK,EAAE,MAAM,aAAa,CAAC;;;;;AAM5C,MAAM,OAAO,qBAAqB;IAkBhC;QAjBA,UAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAEtB,WAAM,GAAG,KAAK,EAAU,CAAC;QACzB,cAAS,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;QAC9B,gBAAW,GAAG,KAAK,CAAS,GAAG,CAAC,CAAC;QACjC,SAAI,GAAG,KAAK,CAAmB,MAAM,CAAC,CAAC;QAEvC,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE;YACxB,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QAC3D,CAAC,CAAC,CAAC;QACH,UAAK,GAAG,QAAQ,CAAC,GAAG,EAAE;YACpB,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,SAAS,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACnE,CAAC,CAAC,CAAC;QACH,gBAAW,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAEd,eAAU,GAAG,IAAI,YAAY,EAAU,CAAC;QAGhD,MAAM,CACJ,GAAG,EAAE;YACH,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;gBACvB,IAAI,CAAC,wBAAwB,EAAE,CAAC;YAClC,CAAC;QACH,CAAC,EACD,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAC5B,CAAC;IACJ,CAAC;IAED,wBAAwB;QACtB,IAAI,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;YAC3B,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;gBAClB,GAAG,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC;gBACzB,aAAa;gBACb,MAAM,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE;gBACnD,KAAK,EAAE,IAAI,CAAC,SAAS,EAAE;aACxB,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,UAAU,CAAC,IAAY;QACrB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC3B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;8GA3CU,qBAAqB;kGAArB,qBAAqB,smBCPlC,47HAgHA;;2FDzGa,qBAAqB;kBAJjC,SAAS;+BACE,eAAe;wDAmBf,UAAU;sBAAnB,MAAM","sourcesContent":["import { Component, computed, effect, EventEmitter, inject, input, Output, signal, untracked } from '@angular/core';\nimport { Action, Store } from '@ngrx/store';\n\n@Component({\n  selector: 'pry-paginator',\n  templateUrl: './paginator.component.html'\n})\nexport class PryPaginatorComponent {\n  store = inject(Store);\n\n  action = input<Action>();\n  nbPerPage = input<number>(10);\n  totalItemNb = input<number>(100);\n  mode = input<'long' | 'short'>('long');\n\n  nbOfPages = computed(() => {\n    return Math.floor(this.totalItemNb() / this.nbPerPage());\n  });\n  pages = computed(() => {\n    return Array.from({ length: this.nbOfPages() }, (_, i) => i + 1);\n  });\n  currentPage = signal(1);\n\n  @Output() pageChange = new EventEmitter<number>();\n\n  constructor() {\n    effect(\n      () => {\n        if (this.currentPage()) {\n          this.dispatchPageChangeAction();\n        }\n      },\n      { allowSignalWrites: true }\n    );\n  }\n\n  dispatchPageChangeAction() {\n    if (untracked(this.action)) {\n      this.store.dispatch({\n        ...untracked(this.action),\n        // @ts-ignore\n        offset: (this.currentPage() - 1) * this.nbPerPage(),\n        limit: this.nbPerPage()\n      });\n    }\n  }\n\n  changePage(page: number) {\n    this.currentPage.set(page);\n    this.pageChange.emit(page);\n  }\n}\n","<pry-paginator-css></pry-paginator-css>\n<div\n  class=\"o-paginator u-display-flex -align-center\"\n  [class.o-paginator--long]=\"mode() === 'long'\"\n  [class.o-paginator--short]=\"mode() === 'short'\"\n>\n  @if (mode() === 'long') {\n    <ng-container *ngTemplateOutlet=\"longPaginator\"></ng-container>\n  } @else {\n    <ng-container *ngTemplateOutlet=\"shortPaginator\"></ng-container>\n  }\n</div>\n\n<ng-template #shortPaginator>\n  <button (click)=\"changePage(1)\" [disabled]=\"currentPage() === 1\">\n    <pry-icon iconSvg=\"skip-left-fill\"></pry-icon>\n  </button>\n  <button (click)=\"changePage(currentPage() - 1)\" [disabled]=\"currentPage() === 1\">\n    <pry-icon iconSvg=\"arrow-left-s-fill\"></pry-icon>\n  </button>\n  <span class=\"o-paginator__page-counter\">{{ currentPage() }} / {{ nbOfPages() }}</span>\n  <button (click)=\"changePage(currentPage() + 1)\" [disabled]=\"currentPage() === nbOfPages()\">\n    <pry-icon iconSvg=\"arrow-right-s-fill\"></pry-icon>\n  </button>\n  <button (click)=\"changePage(nbOfPages())\" [disabled]=\"currentPage() === nbOfPages()\">\n    <pry-icon iconSvg=\"skip-right-fill\"></pry-icon>\n  </button>\n</ng-template>\n\n<ng-template #longPaginator>\n  @if (currentPage() > 1) {\n    <button (click)=\"changePage(currentPage() - 1)\">\n      <pry-icon iconSvg=\"chevron_left\"></pry-icon>\n    </button>\n  }\n  @if (nbOfPages() > 8) {\n    @if (currentPage() < 3) {\n      @for (page of pages().slice(0, 3); track page) {\n        <button\n          class=\"a-btn -small-circle -no-padding\"\n          [class.a-btn--primary]=\"page === currentPage()\"\n          [class.a-btn--ghost]=\"page !== currentPage()\"\n          (click)=\"changePage(page)\"\n        >\n          {{ page }}\n        </button>\n      }\n      <span class=\"u-self-end\">...</span>\n      <button class=\"a-btn -small-circle -no-padding\" (click)=\"changePage(pages().length)\">\n        {{ pages().length }}\n      </button>\n    } @else if (currentPage() > pages().length - 2) {\n      <button\n        class=\"a-btn -small-circle -no-padding\"\n        (click)=\"changePage(1)\"\n        [class.a-btn--primary]=\"currentPage() === 1\"\n        [class.a-btn--ghost]=\"currentPage() !== 1\"\n      >\n        1\n      </button>\n      <span class=\"u-self-end\">...</span>\n      @for (page of pages().slice(-3); track page) {\n        <button\n          class=\"a-btn -small-circle -no-padding\"\n          [class.a-btn--primary]=\"page === currentPage()\"\n          [class.a-btn--ghost]=\"page !== currentPage()\"\n          (click)=\"changePage(page)\"\n        >\n          {{ page }}\n        </button>\n      }\n    } @else {\n      <button class=\"a-btn -small-circle -no-padding\" (click)=\"changePage(1)\">1</button>\n      <span>...</span>\n      @for (page of pages().slice(currentPage() - 2, currentPage() + 1); track page) {\n        <button\n          class=\"a-btn -small-circle -no-padding\"\n          [class.a-btn--primary]=\"page === currentPage()\"\n          [class.a-btn--ghost]=\"page !== currentPage()\"\n          (click)=\"changePage(page)\"\n        >\n          {{ page }}\n        </button>\n      }\n      <span>...</span>\n      <button\n        class=\"a-btn -small-circle -no-padding\"\n        [class.a-btn--primary]=\"currentPage() === pages().length\"\n        [class.a-btn--ghost]=\"currentPage() !== pages().length\"\n        (click)=\"changePage(pages().length)\"\n      >\n        {{ pages().length }}\n      </button>\n    }\n  } @else {\n    @for (page of pages(); track page) {\n      <button\n        class=\"a-btn -small-circle -no-padding\"\n        [class.a-btn--primary]=\"page === currentPage()\"\n        [class.a-btn--ghost]=\"page !== currentPage()\"\n        (click)=\"changePage(page)\"\n      >\n        {{ page }}\n      </button>\n    }\n  }\n  @if (currentPage() < pages().length) {\n    <button (click)=\"changePage(currentPage() + 1)\">\n      <pry-icon iconSvg=\"chevron_right\"></pry-icon>\n    </button>\n  }\n</ng-template>\n"]}
58
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/components/paginator/paginator.component.ts","../../../../../../projects/provoly/dashboard/components/paginator/paginator.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACpH,OAAO,EAAU,KAAK,EAAE,MAAM,aAAa,CAAC;;;;;AAM5C,MAAM,OAAO,qBAAqB;IAmBhC;QAlBA,UAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAEtB,WAAM,GAAG,KAAK,EAAU,CAAC;QACzB,cAAS,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;QAC9B,gBAAW,GAAG,KAAK,CAAS,GAAG,CAAC,CAAC;QACjC,SAAI,GAAG,KAAK,CAAmB,MAAM,CAAC,CAAC;QACvC,sBAAiB,GAAG,KAAK,EAAO,CAAC;QAEjC,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE;YACxB,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QAC3D,CAAC,CAAC,CAAC;QACH,UAAK,GAAG,QAAQ,CAAC,GAAG,EAAE;YACpB,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,SAAS,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACnE,CAAC,CAAC,CAAC;QACH,gBAAW,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAEd,eAAU,GAAG,IAAI,YAAY,EAAU,CAAC;QAGhD,MAAM,CACJ,GAAG,EAAE;YACH,wDAAwD;YACxD,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;gBACvB,IAAI,CAAC,wBAAwB,EAAE,CAAC;YAClC,CAAC;QACH,CAAC,EACD,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAC5B,CAAC;QACF,MAAM,CACJ,GAAG,EAAE;YACH,IAAI,IAAI,CAAC,iBAAiB,EAAE,EAAE,CAAC;gBAC7B,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACrB,CAAC;QACH,CAAC,EACD,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAC5B,CAAC;IACJ,CAAC;IAED,wBAAwB;QACtB,IAAI,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;YAC3B,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;gBAClB,GAAG,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC;gBACzB,aAAa;gBACb,MAAM,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE;gBACnD,KAAK,EAAE,IAAI,CAAC,SAAS,EAAE;aACxB,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,UAAU,CAAC,IAAY;QACrB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC3B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;8GArDU,qBAAqB;kGAArB,qBAAqB,kwBCPlC,47HAgHA;;2FDzGa,qBAAqB;kBAJjC,SAAS;+BACE,eAAe;wDAoBf,UAAU;sBAAnB,MAAM","sourcesContent":["import { Component, computed, effect, EventEmitter, inject, input, Output, signal, untracked } from '@angular/core';\nimport { Action, Store } from '@ngrx/store';\n\n@Component({\n  selector: 'pry-paginator',\n  templateUrl: './paginator.component.html'\n})\nexport class PryPaginatorComponent {\n  store = inject(Store);\n\n  action = input<Action>();\n  nbPerPage = input<number>(10);\n  totalItemNb = input<number>(100);\n  mode = input<'long' | 'short'>('long');\n  goBackToFirstPage = input<any>();\n\n  nbOfPages = computed(() => {\n    return Math.floor(this.totalItemNb() / this.nbPerPage());\n  });\n  pages = computed(() => {\n    return Array.from({ length: this.nbOfPages() }, (_, i) => i + 1);\n  });\n  currentPage = signal(1);\n\n  @Output() pageChange = new EventEmitter<number>();\n\n  constructor() {\n    effect(\n      () => {\n        // if current page changes, dispatch action to load data\n        if (this.currentPage()) {\n          this.dispatchPageChangeAction();\n        }\n      },\n      { allowSignalWrites: true }\n    );\n    effect(\n      () => {\n        if (this.goBackToFirstPage()) {\n          this.changePage(1);\n        }\n      },\n      { allowSignalWrites: true }\n    );\n  }\n\n  dispatchPageChangeAction() {\n    if (untracked(this.action)) {\n      this.store.dispatch({\n        ...untracked(this.action),\n        // @ts-ignore\n        offset: (this.currentPage() - 1) * this.nbPerPage(),\n        limit: this.nbPerPage()\n      });\n    }\n  }\n\n  changePage(page: number) {\n    this.currentPage.set(page);\n    this.pageChange.emit(page);\n  }\n}\n","<pry-paginator-css></pry-paginator-css>\n<div\n  class=\"o-paginator u-display-flex -align-center\"\n  [class.o-paginator--long]=\"mode() === 'long'\"\n  [class.o-paginator--short]=\"mode() === 'short'\"\n>\n  @if (mode() === 'long') {\n    <ng-container *ngTemplateOutlet=\"longPaginator\"></ng-container>\n  } @else {\n    <ng-container *ngTemplateOutlet=\"shortPaginator\"></ng-container>\n  }\n</div>\n\n<ng-template #shortPaginator>\n  <button (click)=\"changePage(1)\" [disabled]=\"currentPage() === 1\">\n    <pry-icon iconSvg=\"skip-left-fill\"></pry-icon>\n  </button>\n  <button (click)=\"changePage(currentPage() - 1)\" [disabled]=\"currentPage() === 1\">\n    <pry-icon iconSvg=\"arrow-left-s-fill\"></pry-icon>\n  </button>\n  <span class=\"o-paginator__page-counter\">{{ currentPage() }} / {{ nbOfPages() }}</span>\n  <button (click)=\"changePage(currentPage() + 1)\" [disabled]=\"currentPage() === nbOfPages()\">\n    <pry-icon iconSvg=\"arrow-right-s-fill\"></pry-icon>\n  </button>\n  <button (click)=\"changePage(nbOfPages())\" [disabled]=\"currentPage() === nbOfPages()\">\n    <pry-icon iconSvg=\"skip-right-fill\"></pry-icon>\n  </button>\n</ng-template>\n\n<ng-template #longPaginator>\n  @if (currentPage() > 1) {\n    <button (click)=\"changePage(currentPage() - 1)\">\n      <pry-icon iconSvg=\"chevron_left\"></pry-icon>\n    </button>\n  }\n  @if (nbOfPages() > 8) {\n    @if (currentPage() < 3) {\n      @for (page of pages().slice(0, 3); track page) {\n        <button\n          class=\"a-btn -small-circle -no-padding\"\n          [class.a-btn--primary]=\"page === currentPage()\"\n          [class.a-btn--ghost]=\"page !== currentPage()\"\n          (click)=\"changePage(page)\"\n        >\n          {{ page }}\n        </button>\n      }\n      <span class=\"u-self-end\">...</span>\n      <button class=\"a-btn -small-circle -no-padding\" (click)=\"changePage(pages().length)\">\n        {{ pages().length }}\n      </button>\n    } @else if (currentPage() > pages().length - 2) {\n      <button\n        class=\"a-btn -small-circle -no-padding\"\n        (click)=\"changePage(1)\"\n        [class.a-btn--primary]=\"currentPage() === 1\"\n        [class.a-btn--ghost]=\"currentPage() !== 1\"\n      >\n        1\n      </button>\n      <span class=\"u-self-end\">...</span>\n      @for (page of pages().slice(-3); track page) {\n        <button\n          class=\"a-btn -small-circle -no-padding\"\n          [class.a-btn--primary]=\"page === currentPage()\"\n          [class.a-btn--ghost]=\"page !== currentPage()\"\n          (click)=\"changePage(page)\"\n        >\n          {{ page }}\n        </button>\n      }\n    } @else {\n      <button class=\"a-btn -small-circle -no-padding\" (click)=\"changePage(1)\">1</button>\n      <span>...</span>\n      @for (page of pages().slice(currentPage() - 2, currentPage() + 1); track page) {\n        <button\n          class=\"a-btn -small-circle -no-padding\"\n          [class.a-btn--primary]=\"page === currentPage()\"\n          [class.a-btn--ghost]=\"page !== currentPage()\"\n          (click)=\"changePage(page)\"\n        >\n          {{ page }}\n        </button>\n      }\n      <span>...</span>\n      <button\n        class=\"a-btn -small-circle -no-padding\"\n        [class.a-btn--primary]=\"currentPage() === pages().length\"\n        [class.a-btn--ghost]=\"currentPage() !== pages().length\"\n        (click)=\"changePage(pages().length)\"\n      >\n        {{ pages().length }}\n      </button>\n    }\n  } @else {\n    @for (page of pages(); track page) {\n      <button\n        class=\"a-btn -small-circle -no-padding\"\n        [class.a-btn--primary]=\"page === currentPage()\"\n        [class.a-btn--ghost]=\"page !== currentPage()\"\n        (click)=\"changePage(page)\"\n      >\n        {{ page }}\n      </button>\n    }\n  }\n  @if (currentPage() < pages().length) {\n    <button (click)=\"changePage(currentPage() + 1)\">\n      <pry-icon iconSvg=\"chevron_right\"></pry-icon>\n    </button>\n  }\n</ng-template>\n"]}
@@ -1,5 +1,6 @@
1
1
  import { Component, input, signal } from '@angular/core';
2
2
  import { DataSourceActions, DataSourceSelectors, PryStatusModalComponent, SubscriptionnerDirective } from '@provoly/dashboard';
3
+ import { Subject } from 'rxjs';
3
4
  import { PryVersionModalComponent } from '../version-modal/version-modal.component';
4
5
  import { GlobalPositionStrategy } from '@angular/cdk/overlay';
5
6
  import * as i0 from "@angular/core";
@@ -14,7 +15,7 @@ export class PryImportListComponent extends SubscriptionnerDirective {
14
15
  super();
15
16
  this.store = store;
16
17
  this.dialog = dialog;
17
- this.loadDataAction = signal(DataSourceActions.dataset.listVersions({}));
18
+ this.loadDataAction = signal(DataSourceActions.dataset.listVersions({ orderBy: 'DATE', sortBy: 'desc' }));
18
19
  this.refreshClick = input();
19
20
  this.possibleStatus = ['LOADING', 'INDEXING', 'INACTIVE', 'ERROR', 'ACTIVE', 'DELETING', 'DELETE_ERROR'];
20
21
  this.filters = {
@@ -23,7 +24,8 @@ export class PryImportListComponent extends SubscriptionnerDirective {
23
24
  dateMin: undefined,
24
25
  dateMax: undefined
25
26
  };
26
- this.sort = {};
27
+ this.sort = { orderBy: 'DATE', sortBy: 'desc' };
28
+ this.goBackToFirstPage$ = new Subject();
27
29
  this.store.dispatch(DataSourceActions.dataset.loadDataset());
28
30
  this.datasets$ = this.store.select(DataSourceSelectors.datasets);
29
31
  this.datasetVersions$ = this.store.select(DataSourceSelectors.datasetVersions);
@@ -34,19 +36,20 @@ export class PryImportListComponent extends SubscriptionnerDirective {
34
36
  }
35
37
  clearFilters() {
36
38
  this.filters = { dataset: undefined, status: undefined, dateMin: undefined, dateMax: undefined };
39
+ this.loadDataAction.update((loadDataAction) => ({ ...loadDataAction, offset: 0 }));
37
40
  this.store.dispatch({
38
41
  ...this.loadDataAction(),
39
42
  limit: 10,
40
43
  ...this.sort
41
44
  });
45
+ this.goBackToFirstPage();
42
46
  }
43
47
  loadData() {
44
48
  this.store.dispatch({
45
49
  ...this.loadDataAction(),
46
- limit: 10,
47
- ...this.filters,
48
- ...this.sort
50
+ limit: 10
49
51
  });
52
+ this.goBackToFirstPage();
50
53
  }
51
54
  openInfoModal(version) {
52
55
  this.dialog.open(PryVersionModalComponent, {
@@ -66,16 +69,21 @@ export class PryImportListComponent extends SubscriptionnerDirective {
66
69
  sortChange($event) {
67
70
  this.sort.sortBy = $event.direction;
68
71
  this.sort.orderBy = $event.active;
72
+ this.loadDataAction.update((loadDataAction) => ({ ...loadDataAction, ...this.sort }));
69
73
  this.loadData();
70
74
  }
71
75
  updateFilters() {
72
76
  this.loadDataAction.update((loadDataAction) => ({ ...loadDataAction, ...this.filters }));
73
77
  }
78
+ goBackToFirstPage() {
79
+ this.goBackToFirstPage$.next(true);
80
+ setTimeout(() => this.goBackToFirstPage$.next(false), 50);
81
+ }
74
82
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: PryImportListComponent, deps: [{ token: i1.Store }, { token: i2.PryDialogService }], target: i0.ɵɵFactoryTarget.Component }); }
75
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: PryImportListComponent, selector: "pry-import-list", inputs: { refreshClick: { classPropertyName: "refreshClick", publicName: "refreshClick", isSignal: true, isRequired: false, transformFunction: null } }, usesInheritance: true, ngImport: i0, template: "<pry-import-css></pry-import-css>\n<div class=\"o-import-list u-display-flex -column -gap-20\">\n <h1 class=\"a-h1\">{{ '@pry.importList.title' | i18n }}</h1>\n <div class=\"o-import-list__filters u-display-flex -gap-20\">\n <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__dataset-filter\" #dsRef>\n <label class=\"a-label m-filter__label\" for=\"dataset_name_filter\">\n {{ '@pry.importList.filter.dsName' | i18n }}&nbsp;:&nbsp;\n </label>\n <pry-select\n id=\"dataset_name_filter\"\n [items]=\"datasets$ | async\"\n [(ngModel)]=\"filters.dataset\"\n (ngModelChange)=\"updateFilters()\"\n [clearable]=\"true\"\n [autocomplete]=\"true\"\n aria-labelledby=\"item-label\"\n bindLabel=\"name\"\n bindValue=\"id\"\n [elementRef]=\"dsRef\"\n ></pry-select>\n </div>\n <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__state-filter\" #statusRef>\n <label class=\"a-label m-filter__label\" for=\"import_status\">\n {{ '@pry.importList.filter.status' | i18n }}&nbsp;:&nbsp;\n </label>\n <pry-select\n id=\"import_status\"\n [items]=\"possibleStatus\"\n [(ngModel)]=\"filters.status\"\n (ngModelChange)=\"updateFilters()\"\n [clearable]=\"true\"\n aria-labelledby=\"item-label\"\n [elementRef]=\"statusRef\"\n i18nPrefix=\"@pry.dataset.version.stateFilter.\"\n ></pry-select>\n </div>\n <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__date-filter\">\n <fieldset class=\"u-display-flex -align-center\">\n <legend class=\"a-label m-filter__label\">{{ '@pry.importList.filter.date' | i18n }}&nbsp;:&nbsp;</legend>\n <input class=\"m-filter__input\" type=\"date\" [(ngModel)]=\"filters.dateMin\" (ngModelChange)=\"updateFilters()\" />\n <span class=\"m-filter__date-input-separator\">&nbsp;-&nbsp;</span>\n <input class=\"m-filter__input\" type=\"date\" [(ngModel)]=\"filters.dateMax\" (ngModelChange)=\"updateFilters()\" />\n </fieldset>\n </div>\n <button type=\"button\" class=\"a-btn a-btn--icon-only u-self-center\" (click)=\"clearFilters()\">\n <pry-icon iconSvg=\"clear_filter\" [width]=\"30\" [height]=\"30\"></pry-icon>\n </button>\n <button type=\"button\" class=\"a-btn a-btn--primary\" (click)=\"loadData()\">\n {{ '@pry.toolbox.apply' | i18n }}\n <pry-icon iconSvg=\"refresh_filter\" [width]=\"18\" [height]=\"18\"></pry-icon>\n </button>\n </div>\n <div class=\"o-import-list__content\">\n <table class=\"a-table\" prySortTable (prySortChange)=\"sortChange($event)\">\n <caption>\n {{\n '@pry.admin.dataset.title' | i18n\n }},\n {{\n '@pry.action.sortableColumnHeader' | i18n\n }}\n </caption>\n <thead>\n <tr>\n <th id=\"import_list_header_dataset\" prySortHeader=\"DATASET_NAME\">\n {{ '@pry.importList.dsName' | i18n }}\n </th>\n <th>{{ '@pry.importList.number' | i18n }}</th>\n <th id=\"import_list_header_date\" prySortHeader=\"DATE\" (sortChange)=\"sortChange($event)\">\n {{ '@pry.importList.date' | i18n }}\n </th>\n <th>{{ '@pry.importList.status' | i18n }}</th>\n <th>{{ '@pry.importList.actions' | i18n }}</th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n @for (version of datasetVersions$ | async; track version.id) {\n <tr>\n <td>{{ version.dataset.name }}</td>\n <td>\n {{ version.version }}\n </td>\n <td>\n {{ version.productionDate | date: 'dd/MM/yyyy HH:mm' }}\n </td>\n <td class=\"u-display-flex -align-center -cell-with-icon\">\n @if (version.state === 'ACTIVE') {\n <pry-icon iconSvg=\"check\" class=\"check\" [height]=\"20\" [width]=\"20\"></pry-icon>\n } @else if (version.state === 'WARNING' || version.state === 'ERROR') {\n <pry-icon iconSvg=\"warning-triangle\" class=\"warning\" [height]=\"20\" [width]=\"20\"></pry-icon>\n }\n {{\n version.id === version.dataset.activeVersion?.id\n ? '@pry.dataset.version.state.currentlyActive'\n : ('@pry.dataset.version.state.' + version.state | i18n)\n }}\n </td>\n @if (version.state === 'ACTIVE' || version.state === 'INACTIVE') {\n <td>\n <button class=\"a-btn a-btn--secondary\" (click)=\"openInfoModal(version)\">Consulter</button>\n </td>\n } @else if (version.state === 'ERROR' || version.state === 'WARNING') {\n <td>\n <button class=\"a-btn a-btn--secondary\" (click)=\"openErrorModal(version)\">\n {{ version.state === 'ERROR' ? 'Consulter erreurs' : 'Consulter warnings' }}\n </button>\n </td>\n }\n </tr>\n }\n </tbody>\n </table>\n </div>\n <pry-paginator\n [action]=\"loadDataAction()\"\n [nbPerPage]=\"10\"\n [totalItemNb]=\"(totalVersionCount$ | async)!\"\n class=\"u-self-center\"\n ></pry-paginator>\n</div>\n", dependencies: [{ kind: "component", type: i2.PrySelectComponent, selector: "pry-select", inputs: ["items", "clearable", "multiple", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "autocomplete", "alwaysShowAutosuggestedValues", "externalAutocompleteService", "bindValue", "bindLabel", "iconSize", "bindIcon", "template", "i18nPrefix", "bindClasses", "loading", "elementRef"], outputs: ["searched", "cleared", "clicked"] }, { kind: "component", type: i2.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.PryPaginatorComponent, selector: "pry-paginator", inputs: ["action", "nbPerPage", "totalItemNb", "mode"], outputs: ["pageChange"] }, { kind: "component", type: i2.PrySortHeaderComponent, selector: "th[prySortHeader]", inputs: ["prySortHeader"], outputs: ["sortChange"] }, { kind: "directive", type: i2.PrySortHeaderDirective, selector: "[prySortHeader]" }, { kind: "directive", type: i2.PrySortTableDirective, selector: "[prySortTable]", inputs: ["prySortActive", "prySortDirection"], outputs: ["prySortChange"] }, { kind: "component", type: i5.PryImportCssComponent, selector: "pry-import-css" }, { kind: "pipe", type: i2.I18nPipe, name: "i18n" }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.DatePipe, name: "date" }] }); }
83
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: PryImportListComponent, selector: "pry-import-list", inputs: { refreshClick: { classPropertyName: "refreshClick", publicName: "refreshClick", isSignal: true, isRequired: false, transformFunction: null } }, usesInheritance: true, ngImport: i0, template: "<pry-import-css></pry-import-css>\n<div class=\"o-import-list u-display-flex -column -gap-20\">\n <h1 class=\"a-h1\">{{ '@pry.importList.title' | i18n }}</h1>\n <div class=\"o-import-list__filters u-display-flex -gap-20\">\n <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__dataset-filter\" #dsRef>\n <label class=\"a-label m-filter__label\" for=\"dataset_name_filter\">\n {{ '@pry.importList.filter.dsName' | i18n }}&nbsp;:&nbsp;\n </label>\n <pry-select\n id=\"dataset_name_filter\"\n [items]=\"datasets$ | async\"\n [(ngModel)]=\"filters.dataset\"\n (ngModelChange)=\"updateFilters()\"\n [clearable]=\"true\"\n [autocomplete]=\"true\"\n aria-labelledby=\"item-label\"\n bindLabel=\"name\"\n bindValue=\"id\"\n [elementRef]=\"dsRef\"\n ></pry-select>\n </div>\n <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__state-filter\" #statusRef>\n <label class=\"a-label m-filter__label\" for=\"import_status\">\n {{ '@pry.importList.filter.status' | i18n }}&nbsp;:&nbsp;\n </label>\n <pry-select\n id=\"import_status\"\n [items]=\"possibleStatus\"\n [(ngModel)]=\"filters.status\"\n (ngModelChange)=\"updateFilters()\"\n [clearable]=\"true\"\n aria-labelledby=\"item-label\"\n [elementRef]=\"statusRef\"\n i18nPrefix=\"@pry.dataset.version.stateFilter.\"\n ></pry-select>\n </div>\n <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__date-filter\">\n <fieldset class=\"u-display-flex -align-center\">\n <legend class=\"a-label m-filter__label\">{{ '@pry.importList.filter.date' | i18n }}&nbsp;:&nbsp;</legend>\n <input class=\"m-filter__input\" type=\"date\" [(ngModel)]=\"filters.dateMin\" (ngModelChange)=\"updateFilters()\" />\n <span class=\"m-filter__date-input-separator\">&nbsp;-&nbsp;</span>\n <input class=\"m-filter__input\" type=\"date\" [(ngModel)]=\"filters.dateMax\" (ngModelChange)=\"updateFilters()\" />\n </fieldset>\n </div>\n <button type=\"button\" class=\"a-btn a-btn--icon-only u-self-center\" (click)=\"clearFilters()\">\n <pry-icon iconSvg=\"clear_filter\" [width]=\"30\" [height]=\"30\"></pry-icon>\n </button>\n <button type=\"button\" class=\"a-btn a-btn--primary\" (click)=\"loadData()\">\n {{ '@pry.toolbox.apply' | i18n }}\n <pry-icon iconSvg=\"refresh_filter\" [width]=\"18\" [height]=\"18\"></pry-icon>\n </button>\n </div>\n <div class=\"o-import-list__content\">\n <table\n class=\"a-table\"\n prySortTable\n (prySortChange)=\"sortChange($event)\"\n [prySortDirection]=\"sort.sortBy\"\n [prySortActive]=\"sort.orderBy\"\n >\n <caption>\n {{\n '@pry.admin.dataset.title' | i18n\n }},\n {{\n '@pry.action.sortableColumnHeader' | i18n\n }}\n </caption>\n <thead>\n <tr>\n <th id=\"import_list_header_dataset\" prySortHeader=\"DATASET_NAME\">\n {{ '@pry.importList.dsName' | i18n }}\n </th>\n <th>{{ '@pry.importList.number' | i18n }}</th>\n <th id=\"import_list_header_date\" prySortHeader=\"DATE\" (sortChange)=\"sortChange($event)\">\n {{ '@pry.importList.date' | i18n }}\n </th>\n <th>{{ '@pry.importList.status' | i18n }}</th>\n <th>{{ '@pry.importList.actions' | i18n }}</th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n @for (version of datasetVersions$ | async; track version.id) {\n <tr>\n <td>{{ version.dataset.name }}</td>\n <td>\n {{ version.version }}\n </td>\n <td>\n {{ version.lastModified | date: 'dd/MM/yyyy HH:mm' }}\n </td>\n <td class=\"u-display-flex -align-center -cell-with-icon\">\n @if (version.state === 'ACTIVE') {\n <pry-icon iconSvg=\"check\" class=\"check\" [height]=\"20\" [width]=\"20\"></pry-icon>\n } @else if (version.state === 'WARNING' || version.state === 'ERROR') {\n <pry-icon iconSvg=\"warning-triangle\" class=\"warning\" [height]=\"20\" [width]=\"20\"></pry-icon>\n }\n {{\n version.id === version.dataset.activeVersion?.id\n ? '@pry.dataset.version.state.currentlyActive'\n : ('@pry.dataset.version.state.' + version.state | i18n)\n }}\n </td>\n @if (version.state === 'ACTIVE' || version.state === 'INACTIVE') {\n <td>\n <button class=\"a-btn a-btn--secondary\" (click)=\"openInfoModal(version)\">\n {{ '@pry.dataset.buttonAction.' + version.state | i18n }}\n </button>\n </td>\n @if (version.hasWarnings) {\n <td>\n <button class=\"a-btn a-btn--secondary\" (click)=\"openErrorModal(version)\">\n {{ '@pry.dataset.buttonAction.WARNING' | i18n }}\n </button>\n </td>\n }\n } @else if (version.state === 'ERROR') {\n <td>\n <button class=\"a-btn a-btn--secondary\" (click)=\"openErrorModal(version)\">\n {{ '@pry.dataset.buttonAction.' + version.state | i18n }}\n </button>\n </td>\n }\n </tr>\n }\n </tbody>\n </table>\n </div>\n <pry-paginator\n [action]=\"loadDataAction()\"\n [nbPerPage]=\"10\"\n [totalItemNb]=\"(totalVersionCount$ | async)!\"\n class=\"u-self-center\"\n [goBackToFirstPage]=\"goBackToFirstPage$ | async\"\n ></pry-paginator>\n</div>\n", dependencies: [{ kind: "component", type: i2.PrySelectComponent, selector: "pry-select", inputs: ["items", "clearable", "multiple", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "autocomplete", "alwaysShowAutosuggestedValues", "externalAutocompleteService", "bindValue", "bindLabel", "iconSize", "bindIcon", "template", "i18nPrefix", "bindClasses", "loading", "elementRef"], outputs: ["searched", "cleared", "clicked"] }, { kind: "component", type: i2.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.PryPaginatorComponent, selector: "pry-paginator", inputs: ["action", "nbPerPage", "totalItemNb", "mode", "goBackToFirstPage"], outputs: ["pageChange"] }, { kind: "component", type: i2.PrySortHeaderComponent, selector: "th[prySortHeader]", inputs: ["prySortHeader"], outputs: ["sortChange"] }, { kind: "directive", type: i2.PrySortHeaderDirective, selector: "[prySortHeader]" }, { kind: "directive", type: i2.PrySortTableDirective, selector: "[prySortTable]", inputs: ["prySortActive", "prySortDirection"], outputs: ["prySortChange"] }, { kind: "component", type: i5.PryImportCssComponent, selector: "pry-import-css" }, { kind: "pipe", type: i2.I18nPipe, name: "i18n" }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.DatePipe, name: "date" }] }); }
76
84
  }
77
85
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: PryImportListComponent, decorators: [{
78
86
  type: Component,
79
- args: [{ selector: 'pry-import-list', template: "<pry-import-css></pry-import-css>\n<div class=\"o-import-list u-display-flex -column -gap-20\">\n <h1 class=\"a-h1\">{{ '@pry.importList.title' | i18n }}</h1>\n <div class=\"o-import-list__filters u-display-flex -gap-20\">\n <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__dataset-filter\" #dsRef>\n <label class=\"a-label m-filter__label\" for=\"dataset_name_filter\">\n {{ '@pry.importList.filter.dsName' | i18n }}&nbsp;:&nbsp;\n </label>\n <pry-select\n id=\"dataset_name_filter\"\n [items]=\"datasets$ | async\"\n [(ngModel)]=\"filters.dataset\"\n (ngModelChange)=\"updateFilters()\"\n [clearable]=\"true\"\n [autocomplete]=\"true\"\n aria-labelledby=\"item-label\"\n bindLabel=\"name\"\n bindValue=\"id\"\n [elementRef]=\"dsRef\"\n ></pry-select>\n </div>\n <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__state-filter\" #statusRef>\n <label class=\"a-label m-filter__label\" for=\"import_status\">\n {{ '@pry.importList.filter.status' | i18n }}&nbsp;:&nbsp;\n </label>\n <pry-select\n id=\"import_status\"\n [items]=\"possibleStatus\"\n [(ngModel)]=\"filters.status\"\n (ngModelChange)=\"updateFilters()\"\n [clearable]=\"true\"\n aria-labelledby=\"item-label\"\n [elementRef]=\"statusRef\"\n i18nPrefix=\"@pry.dataset.version.stateFilter.\"\n ></pry-select>\n </div>\n <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__date-filter\">\n <fieldset class=\"u-display-flex -align-center\">\n <legend class=\"a-label m-filter__label\">{{ '@pry.importList.filter.date' | i18n }}&nbsp;:&nbsp;</legend>\n <input class=\"m-filter__input\" type=\"date\" [(ngModel)]=\"filters.dateMin\" (ngModelChange)=\"updateFilters()\" />\n <span class=\"m-filter__date-input-separator\">&nbsp;-&nbsp;</span>\n <input class=\"m-filter__input\" type=\"date\" [(ngModel)]=\"filters.dateMax\" (ngModelChange)=\"updateFilters()\" />\n </fieldset>\n </div>\n <button type=\"button\" class=\"a-btn a-btn--icon-only u-self-center\" (click)=\"clearFilters()\">\n <pry-icon iconSvg=\"clear_filter\" [width]=\"30\" [height]=\"30\"></pry-icon>\n </button>\n <button type=\"button\" class=\"a-btn a-btn--primary\" (click)=\"loadData()\">\n {{ '@pry.toolbox.apply' | i18n }}\n <pry-icon iconSvg=\"refresh_filter\" [width]=\"18\" [height]=\"18\"></pry-icon>\n </button>\n </div>\n <div class=\"o-import-list__content\">\n <table class=\"a-table\" prySortTable (prySortChange)=\"sortChange($event)\">\n <caption>\n {{\n '@pry.admin.dataset.title' | i18n\n }},\n {{\n '@pry.action.sortableColumnHeader' | i18n\n }}\n </caption>\n <thead>\n <tr>\n <th id=\"import_list_header_dataset\" prySortHeader=\"DATASET_NAME\">\n {{ '@pry.importList.dsName' | i18n }}\n </th>\n <th>{{ '@pry.importList.number' | i18n }}</th>\n <th id=\"import_list_header_date\" prySortHeader=\"DATE\" (sortChange)=\"sortChange($event)\">\n {{ '@pry.importList.date' | i18n }}\n </th>\n <th>{{ '@pry.importList.status' | i18n }}</th>\n <th>{{ '@pry.importList.actions' | i18n }}</th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n @for (version of datasetVersions$ | async; track version.id) {\n <tr>\n <td>{{ version.dataset.name }}</td>\n <td>\n {{ version.version }}\n </td>\n <td>\n {{ version.productionDate | date: 'dd/MM/yyyy HH:mm' }}\n </td>\n <td class=\"u-display-flex -align-center -cell-with-icon\">\n @if (version.state === 'ACTIVE') {\n <pry-icon iconSvg=\"check\" class=\"check\" [height]=\"20\" [width]=\"20\"></pry-icon>\n } @else if (version.state === 'WARNING' || version.state === 'ERROR') {\n <pry-icon iconSvg=\"warning-triangle\" class=\"warning\" [height]=\"20\" [width]=\"20\"></pry-icon>\n }\n {{\n version.id === version.dataset.activeVersion?.id\n ? '@pry.dataset.version.state.currentlyActive'\n : ('@pry.dataset.version.state.' + version.state | i18n)\n }}\n </td>\n @if (version.state === 'ACTIVE' || version.state === 'INACTIVE') {\n <td>\n <button class=\"a-btn a-btn--secondary\" (click)=\"openInfoModal(version)\">Consulter</button>\n </td>\n } @else if (version.state === 'ERROR' || version.state === 'WARNING') {\n <td>\n <button class=\"a-btn a-btn--secondary\" (click)=\"openErrorModal(version)\">\n {{ version.state === 'ERROR' ? 'Consulter erreurs' : 'Consulter warnings' }}\n </button>\n </td>\n }\n </tr>\n }\n </tbody>\n </table>\n </div>\n <pry-paginator\n [action]=\"loadDataAction()\"\n [nbPerPage]=\"10\"\n [totalItemNb]=\"(totalVersionCount$ | async)!\"\n class=\"u-self-center\"\n ></pry-paginator>\n</div>\n" }]
87
+ args: [{ selector: 'pry-import-list', template: "<pry-import-css></pry-import-css>\n<div class=\"o-import-list u-display-flex -column -gap-20\">\n <h1 class=\"a-h1\">{{ '@pry.importList.title' | i18n }}</h1>\n <div class=\"o-import-list__filters u-display-flex -gap-20\">\n <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__dataset-filter\" #dsRef>\n <label class=\"a-label m-filter__label\" for=\"dataset_name_filter\">\n {{ '@pry.importList.filter.dsName' | i18n }}&nbsp;:&nbsp;\n </label>\n <pry-select\n id=\"dataset_name_filter\"\n [items]=\"datasets$ | async\"\n [(ngModel)]=\"filters.dataset\"\n (ngModelChange)=\"updateFilters()\"\n [clearable]=\"true\"\n [autocomplete]=\"true\"\n aria-labelledby=\"item-label\"\n bindLabel=\"name\"\n bindValue=\"id\"\n [elementRef]=\"dsRef\"\n ></pry-select>\n </div>\n <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__state-filter\" #statusRef>\n <label class=\"a-label m-filter__label\" for=\"import_status\">\n {{ '@pry.importList.filter.status' | i18n }}&nbsp;:&nbsp;\n </label>\n <pry-select\n id=\"import_status\"\n [items]=\"possibleStatus\"\n [(ngModel)]=\"filters.status\"\n (ngModelChange)=\"updateFilters()\"\n [clearable]=\"true\"\n aria-labelledby=\"item-label\"\n [elementRef]=\"statusRef\"\n i18nPrefix=\"@pry.dataset.version.stateFilter.\"\n ></pry-select>\n </div>\n <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__date-filter\">\n <fieldset class=\"u-display-flex -align-center\">\n <legend class=\"a-label m-filter__label\">{{ '@pry.importList.filter.date' | i18n }}&nbsp;:&nbsp;</legend>\n <input class=\"m-filter__input\" type=\"date\" [(ngModel)]=\"filters.dateMin\" (ngModelChange)=\"updateFilters()\" />\n <span class=\"m-filter__date-input-separator\">&nbsp;-&nbsp;</span>\n <input class=\"m-filter__input\" type=\"date\" [(ngModel)]=\"filters.dateMax\" (ngModelChange)=\"updateFilters()\" />\n </fieldset>\n </div>\n <button type=\"button\" class=\"a-btn a-btn--icon-only u-self-center\" (click)=\"clearFilters()\">\n <pry-icon iconSvg=\"clear_filter\" [width]=\"30\" [height]=\"30\"></pry-icon>\n </button>\n <button type=\"button\" class=\"a-btn a-btn--primary\" (click)=\"loadData()\">\n {{ '@pry.toolbox.apply' | i18n }}\n <pry-icon iconSvg=\"refresh_filter\" [width]=\"18\" [height]=\"18\"></pry-icon>\n </button>\n </div>\n <div class=\"o-import-list__content\">\n <table\n class=\"a-table\"\n prySortTable\n (prySortChange)=\"sortChange($event)\"\n [prySortDirection]=\"sort.sortBy\"\n [prySortActive]=\"sort.orderBy\"\n >\n <caption>\n {{\n '@pry.admin.dataset.title' | i18n\n }},\n {{\n '@pry.action.sortableColumnHeader' | i18n\n }}\n </caption>\n <thead>\n <tr>\n <th id=\"import_list_header_dataset\" prySortHeader=\"DATASET_NAME\">\n {{ '@pry.importList.dsName' | i18n }}\n </th>\n <th>{{ '@pry.importList.number' | i18n }}</th>\n <th id=\"import_list_header_date\" prySortHeader=\"DATE\" (sortChange)=\"sortChange($event)\">\n {{ '@pry.importList.date' | i18n }}\n </th>\n <th>{{ '@pry.importList.status' | i18n }}</th>\n <th>{{ '@pry.importList.actions' | i18n }}</th>\n <th></th>\n </tr>\n </thead>\n <tbody>\n @for (version of datasetVersions$ | async; track version.id) {\n <tr>\n <td>{{ version.dataset.name }}</td>\n <td>\n {{ version.version }}\n </td>\n <td>\n {{ version.lastModified | date: 'dd/MM/yyyy HH:mm' }}\n </td>\n <td class=\"u-display-flex -align-center -cell-with-icon\">\n @if (version.state === 'ACTIVE') {\n <pry-icon iconSvg=\"check\" class=\"check\" [height]=\"20\" [width]=\"20\"></pry-icon>\n } @else if (version.state === 'WARNING' || version.state === 'ERROR') {\n <pry-icon iconSvg=\"warning-triangle\" class=\"warning\" [height]=\"20\" [width]=\"20\"></pry-icon>\n }\n {{\n version.id === version.dataset.activeVersion?.id\n ? '@pry.dataset.version.state.currentlyActive'\n : ('@pry.dataset.version.state.' + version.state | i18n)\n }}\n </td>\n @if (version.state === 'ACTIVE' || version.state === 'INACTIVE') {\n <td>\n <button class=\"a-btn a-btn--secondary\" (click)=\"openInfoModal(version)\">\n {{ '@pry.dataset.buttonAction.' + version.state | i18n }}\n </button>\n </td>\n @if (version.hasWarnings) {\n <td>\n <button class=\"a-btn a-btn--secondary\" (click)=\"openErrorModal(version)\">\n {{ '@pry.dataset.buttonAction.WARNING' | i18n }}\n </button>\n </td>\n }\n } @else if (version.state === 'ERROR') {\n <td>\n <button class=\"a-btn a-btn--secondary\" (click)=\"openErrorModal(version)\">\n {{ '@pry.dataset.buttonAction.' + version.state | i18n }}\n </button>\n </td>\n }\n </tr>\n }\n </tbody>\n </table>\n </div>\n <pry-paginator\n [action]=\"loadDataAction()\"\n [nbPerPage]=\"10\"\n [totalItemNb]=\"(totalVersionCount$ | async)!\"\n class=\"u-self-center\"\n [goBackToFirstPage]=\"goBackToFirstPage$ | async\"\n ></pry-paginator>\n</div>\n" }]
80
88
  }], ctorParameters: () => [{ type: i1.Store }, { type: i2.PryDialogService }] });
81
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"import-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/import/components/list/import-list.component.ts","../../../../../../../projects/provoly/dashboard/import/components/list/import-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, effect, input, OnInit, signal, WritableSignal } from '@angular/core';\nimport { Action, Store } from '@ngrx/store';\nimport {\n  Dataset,\n  DatasetVersion,\n  DataSourceActions,\n  DataSourceSelectors,\n  PryDialogService,\n  PrySortChange,\n  PryStatusModalComponent,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { Observable } from 'rxjs';\nimport { PryVersionModalComponent } from '../version-modal/version-modal.component';\nimport { GlobalPositionStrategy } from '@angular/cdk/overlay';\n\n@Component({\n  selector: 'pry-import-list',\n  templateUrl: './import-list.component.html'\n})\nexport class PryImportListComponent extends SubscriptionnerDirective implements OnInit {\n  loadDataAction = signal(DataSourceActions.dataset.listVersions({}));\n  refreshClick = input<Observable<void>>();\n\n  datasets$: Observable<Dataset[]>;\n  possibleStatus = ['LOADING', 'INDEXING', 'INACTIVE', 'ERROR', 'ACTIVE', 'DELETING', 'DELETE_ERROR'];\n  datasetVersions$: Observable<DatasetVersion[]>;\n  totalVersionCount$: Observable<number>;\n  filters: { dataset?: string; status?: string; dateMin?: string; dateMax?: string } = {\n    dataset: undefined,\n    status: undefined,\n    dateMin: undefined,\n    dateMax: undefined\n  };\n  sort: { orderBy?: 'DATASET_NAME' | 'DATE'; sortBy?: 'asc' | 'desc' } = {};\n\n  constructor(\n    private store: Store,\n    private dialog: PryDialogService\n  ) {\n    super();\n    this.store.dispatch(DataSourceActions.dataset.loadDataset());\n    this.datasets$ = this.store.select(DataSourceSelectors.datasets);\n    this.datasetVersions$ = this.store.select(DataSourceSelectors.datasetVersions);\n    this.totalVersionCount$ = this.store.select(DataSourceSelectors.totalVersionCount);\n  }\n\n  ngOnInit() {\n    this.subscriptions.add(this.refreshClick()?.subscribe(() => this.loadData()));\n  }\n\n  clearFilters(): void {\n    this.filters = { dataset: undefined, status: undefined, dateMin: undefined, dateMax: undefined };\n    this.store.dispatch({\n      ...this.loadDataAction(),\n      limit: 10,\n      ...this.sort\n    });\n  }\n\n  loadData(): void {\n    this.store.dispatch({\n      ...this.loadDataAction(),\n      limit: 10,\n      ...this.filters,\n      ...this.sort\n    });\n  }\n\n  openInfoModal(version: DatasetVersion) {\n    this.dialog.open(PryVersionModalComponent, {\n      data: { version },\n      overlayConfig: {\n        positionStrategy: new GlobalPositionStrategy().centerVertically().right('20px'),\n        hasBackdrop: true,\n        backdropClass: 'cdk-overlay-transparent-backdrop'\n      }\n    });\n  }\n\n  openErrorModal(version: DatasetVersion) {\n    this.dialog.open(PryStatusModalComponent, {\n      data: { version }\n    });\n  }\n\n  sortChange($event: PrySortChange) {\n    this.sort.sortBy = $event.direction as 'asc' | 'desc';\n    this.sort.orderBy = $event.active as 'DATASET_NAME' | 'DATE';\n    this.loadData();\n  }\n\n  updateFilters() {\n    this.loadDataAction.update((loadDataAction) => ({ ...loadDataAction, ...this.filters }));\n  }\n}\n","<pry-import-css></pry-import-css>\n<div class=\"o-import-list u-display-flex -column -gap-20\">\n  <h1 class=\"a-h1\">{{ '@pry.importList.title' | i18n }}</h1>\n  <div class=\"o-import-list__filters u-display-flex -gap-20\">\n    <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__dataset-filter\" #dsRef>\n      <label class=\"a-label m-filter__label\" for=\"dataset_name_filter\">\n        {{ '@pry.importList.filter.dsName' | i18n }}&nbsp;:&nbsp;\n      </label>\n      <pry-select\n        id=\"dataset_name_filter\"\n        [items]=\"datasets$ | async\"\n        [(ngModel)]=\"filters.dataset\"\n        (ngModelChange)=\"updateFilters()\"\n        [clearable]=\"true\"\n        [autocomplete]=\"true\"\n        aria-labelledby=\"item-label\"\n        bindLabel=\"name\"\n        bindValue=\"id\"\n        [elementRef]=\"dsRef\"\n      ></pry-select>\n    </div>\n    <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__state-filter\" #statusRef>\n      <label class=\"a-label m-filter__label\" for=\"import_status\">\n        {{ '@pry.importList.filter.status' | i18n }}&nbsp;:&nbsp;\n      </label>\n      <pry-select\n        id=\"import_status\"\n        [items]=\"possibleStatus\"\n        [(ngModel)]=\"filters.status\"\n        (ngModelChange)=\"updateFilters()\"\n        [clearable]=\"true\"\n        aria-labelledby=\"item-label\"\n        [elementRef]=\"statusRef\"\n        i18nPrefix=\"@pry.dataset.version.stateFilter.\"\n      ></pry-select>\n    </div>\n    <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__date-filter\">\n      <fieldset class=\"u-display-flex -align-center\">\n        <legend class=\"a-label m-filter__label\">{{ '@pry.importList.filter.date' | i18n }}&nbsp;:&nbsp;</legend>\n        <input class=\"m-filter__input\" type=\"date\" [(ngModel)]=\"filters.dateMin\" (ngModelChange)=\"updateFilters()\" />\n        <span class=\"m-filter__date-input-separator\">&nbsp;-&nbsp;</span>\n        <input class=\"m-filter__input\" type=\"date\" [(ngModel)]=\"filters.dateMax\" (ngModelChange)=\"updateFilters()\" />\n      </fieldset>\n    </div>\n    <button type=\"button\" class=\"a-btn a-btn--icon-only u-self-center\" (click)=\"clearFilters()\">\n      <pry-icon iconSvg=\"clear_filter\" [width]=\"30\" [height]=\"30\"></pry-icon>\n    </button>\n    <button type=\"button\" class=\"a-btn a-btn--primary\" (click)=\"loadData()\">\n      {{ '@pry.toolbox.apply' | i18n }}\n      <pry-icon iconSvg=\"refresh_filter\" [width]=\"18\" [height]=\"18\"></pry-icon>\n    </button>\n  </div>\n  <div class=\"o-import-list__content\">\n    <table class=\"a-table\" prySortTable (prySortChange)=\"sortChange($event)\">\n      <caption>\n        {{\n          '@pry.admin.dataset.title' | i18n\n        }},\n        {{\n          '@pry.action.sortableColumnHeader' | i18n\n        }}\n      </caption>\n      <thead>\n        <tr>\n          <th id=\"import_list_header_dataset\" prySortHeader=\"DATASET_NAME\">\n            {{ '@pry.importList.dsName' | i18n }}\n          </th>\n          <th>{{ '@pry.importList.number' | i18n }}</th>\n          <th id=\"import_list_header_date\" prySortHeader=\"DATE\" (sortChange)=\"sortChange($event)\">\n            {{ '@pry.importList.date' | i18n }}\n          </th>\n          <th>{{ '@pry.importList.status' | i18n }}</th>\n          <th>{{ '@pry.importList.actions' | i18n }}</th>\n          <th></th>\n        </tr>\n      </thead>\n      <tbody>\n        @for (version of datasetVersions$ | async; track version.id) {\n          <tr>\n            <td>{{ version.dataset.name }}</td>\n            <td>\n              {{ version.version }}\n            </td>\n            <td>\n              {{ version.productionDate | date: 'dd/MM/yyyy HH:mm' }}\n            </td>\n            <td class=\"u-display-flex -align-center -cell-with-icon\">\n              @if (version.state === 'ACTIVE') {\n                <pry-icon iconSvg=\"check\" class=\"check\" [height]=\"20\" [width]=\"20\"></pry-icon>\n              } @else if (version.state === 'WARNING' || version.state === 'ERROR') {\n                <pry-icon iconSvg=\"warning-triangle\" class=\"warning\" [height]=\"20\" [width]=\"20\"></pry-icon>\n              }\n              {{\n                version.id === version.dataset.activeVersion?.id\n                  ? '@pry.dataset.version.state.currentlyActive'\n                  : ('@pry.dataset.version.state.' + version.state | i18n)\n              }}\n            </td>\n            @if (version.state === 'ACTIVE' || version.state === 'INACTIVE') {\n              <td>\n                <button class=\"a-btn a-btn--secondary\" (click)=\"openInfoModal(version)\">Consulter</button>\n              </td>\n            } @else if (version.state === 'ERROR' || version.state === 'WARNING') {\n              <td>\n                <button class=\"a-btn a-btn--secondary\" (click)=\"openErrorModal(version)\">\n                  {{ version.state === 'ERROR' ? 'Consulter erreurs' : 'Consulter warnings' }}\n                </button>\n              </td>\n            }\n          </tr>\n        }\n      </tbody>\n    </table>\n  </div>\n  <pry-paginator\n    [action]=\"loadDataAction()\"\n    [nbPerPage]=\"10\"\n    [totalItemNb]=\"(totalVersionCount$ | async)!\"\n    class=\"u-self-center\"\n  ></pry-paginator>\n</div>\n"]}
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"import-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/import/components/list/import-list.component.ts","../../../../../../../projects/provoly/dashboard/import/components/list/import-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, effect, input, OnInit, signal, WritableSignal } from '@angular/core';\nimport { Action, Store } from '@ngrx/store';\nimport {\n  Dataset,\n  DatasetVersion,\n  DataSourceActions,\n  DataSourceSelectors,\n  PryDialogService,\n  PrySortChange,\n  PryStatusModalComponent,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { Observable, Subject } from 'rxjs';\nimport { PryVersionModalComponent } from '../version-modal/version-modal.component';\nimport { GlobalPositionStrategy } from '@angular/cdk/overlay';\n\n@Component({\n  selector: 'pry-import-list',\n  templateUrl: './import-list.component.html'\n})\nexport class PryImportListComponent extends SubscriptionnerDirective implements OnInit {\n  loadDataAction = signal(DataSourceActions.dataset.listVersions({ orderBy: 'DATE', sortBy: 'desc' }));\n  refreshClick = input<Observable<void>>();\n\n  datasets$: Observable<Dataset[]>;\n  possibleStatus = ['LOADING', 'INDEXING', 'INACTIVE', 'ERROR', 'ACTIVE', 'DELETING', 'DELETE_ERROR'];\n  datasetVersions$: Observable<DatasetVersion[]>;\n  totalVersionCount$: Observable<number>;\n  filters: { dataset?: string; status?: string; dateMin?: string; dateMax?: string } = {\n    dataset: undefined,\n    status: undefined,\n    dateMin: undefined,\n    dateMax: undefined\n  };\n  sort: { orderBy?: 'DATASET_NAME' | 'DATE'; sortBy?: 'asc' | 'desc' } = { orderBy: 'DATE', sortBy: 'desc' };\n  goBackToFirstPage$ = new Subject<boolean>();\n\n  constructor(\n    private store: Store,\n    private dialog: PryDialogService\n  ) {\n    super();\n    this.store.dispatch(DataSourceActions.dataset.loadDataset());\n    this.datasets$ = this.store.select(DataSourceSelectors.datasets);\n    this.datasetVersions$ = this.store.select(DataSourceSelectors.datasetVersions);\n    this.totalVersionCount$ = this.store.select(DataSourceSelectors.totalVersionCount);\n  }\n\n  ngOnInit() {\n    this.subscriptions.add(this.refreshClick()?.subscribe(() => this.loadData()));\n  }\n\n  clearFilters(): void {\n    this.filters = { dataset: undefined, status: undefined, dateMin: undefined, dateMax: undefined };\n    this.loadDataAction.update((loadDataAction) => ({ ...loadDataAction, offset: 0 }));\n    this.store.dispatch({\n      ...this.loadDataAction(),\n      limit: 10,\n      ...this.sort\n    });\n    this.goBackToFirstPage();\n  }\n\n  loadData(): void {\n    this.store.dispatch({\n      ...this.loadDataAction(),\n      limit: 10\n    });\n    this.goBackToFirstPage();\n  }\n\n  openInfoModal(version: DatasetVersion) {\n    this.dialog.open(PryVersionModalComponent, {\n      data: { version },\n      overlayConfig: {\n        positionStrategy: new GlobalPositionStrategy().centerVertically().right('20px'),\n        hasBackdrop: true,\n        backdropClass: 'cdk-overlay-transparent-backdrop'\n      }\n    });\n  }\n\n  openErrorModal(version: DatasetVersion) {\n    this.dialog.open(PryStatusModalComponent, {\n      data: { version }\n    });\n  }\n\n  sortChange($event: PrySortChange) {\n    this.sort.sortBy = $event.direction as 'asc' | 'desc';\n    this.sort.orderBy = $event.active as 'DATASET_NAME' | 'DATE';\n    this.loadDataAction.update((loadDataAction) => ({ ...loadDataAction, ...this.sort }));\n    this.loadData();\n  }\n\n  updateFilters() {\n    this.loadDataAction.update((loadDataAction) => ({ ...loadDataAction, ...this.filters }));\n  }\n\n  goBackToFirstPage() {\n    this.goBackToFirstPage$.next(true);\n    setTimeout(() => this.goBackToFirstPage$.next(false), 50);\n  }\n}\n","<pry-import-css></pry-import-css>\n<div class=\"o-import-list u-display-flex -column -gap-20\">\n  <h1 class=\"a-h1\">{{ '@pry.importList.title' | i18n }}</h1>\n  <div class=\"o-import-list__filters u-display-flex -gap-20\">\n    <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__dataset-filter\" #dsRef>\n      <label class=\"a-label m-filter__label\" for=\"dataset_name_filter\">\n        {{ '@pry.importList.filter.dsName' | i18n }}&nbsp;:&nbsp;\n      </label>\n      <pry-select\n        id=\"dataset_name_filter\"\n        [items]=\"datasets$ | async\"\n        [(ngModel)]=\"filters.dataset\"\n        (ngModelChange)=\"updateFilters()\"\n        [clearable]=\"true\"\n        [autocomplete]=\"true\"\n        aria-labelledby=\"item-label\"\n        bindLabel=\"name\"\n        bindValue=\"id\"\n        [elementRef]=\"dsRef\"\n      ></pry-select>\n    </div>\n    <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__state-filter\" #statusRef>\n      <label class=\"a-label m-filter__label\" for=\"import_status\">\n        {{ '@pry.importList.filter.status' | i18n }}&nbsp;:&nbsp;\n      </label>\n      <pry-select\n        id=\"import_status\"\n        [items]=\"possibleStatus\"\n        [(ngModel)]=\"filters.status\"\n        (ngModelChange)=\"updateFilters()\"\n        [clearable]=\"true\"\n        aria-labelledby=\"item-label\"\n        [elementRef]=\"statusRef\"\n        i18nPrefix=\"@pry.dataset.version.stateFilter.\"\n      ></pry-select>\n    </div>\n    <div class=\"m-filter__input-wrapper m-filter__input-wrapper--dropdown o-import-list__date-filter\">\n      <fieldset class=\"u-display-flex -align-center\">\n        <legend class=\"a-label m-filter__label\">{{ '@pry.importList.filter.date' | i18n }}&nbsp;:&nbsp;</legend>\n        <input class=\"m-filter__input\" type=\"date\" [(ngModel)]=\"filters.dateMin\" (ngModelChange)=\"updateFilters()\" />\n        <span class=\"m-filter__date-input-separator\">&nbsp;-&nbsp;</span>\n        <input class=\"m-filter__input\" type=\"date\" [(ngModel)]=\"filters.dateMax\" (ngModelChange)=\"updateFilters()\" />\n      </fieldset>\n    </div>\n    <button type=\"button\" class=\"a-btn a-btn--icon-only u-self-center\" (click)=\"clearFilters()\">\n      <pry-icon iconSvg=\"clear_filter\" [width]=\"30\" [height]=\"30\"></pry-icon>\n    </button>\n    <button type=\"button\" class=\"a-btn a-btn--primary\" (click)=\"loadData()\">\n      {{ '@pry.toolbox.apply' | i18n }}\n      <pry-icon iconSvg=\"refresh_filter\" [width]=\"18\" [height]=\"18\"></pry-icon>\n    </button>\n  </div>\n  <div class=\"o-import-list__content\">\n    <table\n      class=\"a-table\"\n      prySortTable\n      (prySortChange)=\"sortChange($event)\"\n      [prySortDirection]=\"sort.sortBy\"\n      [prySortActive]=\"sort.orderBy\"\n    >\n      <caption>\n        {{\n          '@pry.admin.dataset.title' | i18n\n        }},\n        {{\n          '@pry.action.sortableColumnHeader' | i18n\n        }}\n      </caption>\n      <thead>\n        <tr>\n          <th id=\"import_list_header_dataset\" prySortHeader=\"DATASET_NAME\">\n            {{ '@pry.importList.dsName' | i18n }}\n          </th>\n          <th>{{ '@pry.importList.number' | i18n }}</th>\n          <th id=\"import_list_header_date\" prySortHeader=\"DATE\" (sortChange)=\"sortChange($event)\">\n            {{ '@pry.importList.date' | i18n }}\n          </th>\n          <th>{{ '@pry.importList.status' | i18n }}</th>\n          <th>{{ '@pry.importList.actions' | i18n }}</th>\n          <th></th>\n        </tr>\n      </thead>\n      <tbody>\n        @for (version of datasetVersions$ | async; track version.id) {\n          <tr>\n            <td>{{ version.dataset.name }}</td>\n            <td>\n              {{ version.version }}\n            </td>\n            <td>\n              {{ version.lastModified | date: 'dd/MM/yyyy HH:mm' }}\n            </td>\n            <td class=\"u-display-flex -align-center -cell-with-icon\">\n              @if (version.state === 'ACTIVE') {\n                <pry-icon iconSvg=\"check\" class=\"check\" [height]=\"20\" [width]=\"20\"></pry-icon>\n              } @else if (version.state === 'WARNING' || version.state === 'ERROR') {\n                <pry-icon iconSvg=\"warning-triangle\" class=\"warning\" [height]=\"20\" [width]=\"20\"></pry-icon>\n              }\n              {{\n                version.id === version.dataset.activeVersion?.id\n                  ? '@pry.dataset.version.state.currentlyActive'\n                  : ('@pry.dataset.version.state.' + version.state | i18n)\n              }}\n            </td>\n            @if (version.state === 'ACTIVE' || version.state === 'INACTIVE') {\n              <td>\n                <button class=\"a-btn a-btn--secondary\" (click)=\"openInfoModal(version)\">\n                  {{ '@pry.dataset.buttonAction.' + version.state | i18n }}\n                </button>\n              </td>\n              @if (version.hasWarnings) {\n                <td>\n                  <button class=\"a-btn a-btn--secondary\" (click)=\"openErrorModal(version)\">\n                    {{ '@pry.dataset.buttonAction.WARNING' | i18n }}\n                  </button>\n                </td>\n              }\n            } @else if (version.state === 'ERROR') {\n              <td>\n                <button class=\"a-btn a-btn--secondary\" (click)=\"openErrorModal(version)\">\n                  {{ '@pry.dataset.buttonAction.' + version.state | i18n }}\n                </button>\n              </td>\n            }\n          </tr>\n        }\n      </tbody>\n    </table>\n  </div>\n  <pry-paginator\n    [action]=\"loadDataAction()\"\n    [nbPerPage]=\"10\"\n    [totalItemNb]=\"(totalVersionCount$ | async)!\"\n    class=\"u-self-center\"\n    [goBackToFirstPage]=\"goBackToFirstPage$ | async\"\n  ></pry-paginator>\n</div>\n"]}