@provoly/dashboard 1.3.6 → 1.3.7

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 (43) hide show
  1. package/admin/components/admin-classes/admin-classes-view/admin-classes-view.component.d.ts +3 -2
  2. package/admin/components/admin-dataset/admin-dataset.component.d.ts +2 -0
  3. package/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.d.ts +4 -3
  4. package/admin/i18n/en.translations.d.ts +7 -0
  5. package/admin/i18n/fr.translations.d.ts +5 -0
  6. package/assets/svgs/groups.svg +16 -0
  7. package/assets/svgs/public.svg +1 -16
  8. package/esm2022/admin/components/admin-classes/admin-classes-view/admin-attributes-form/admin-attributes-form.component.mjs +2 -2
  9. package/esm2022/admin/components/admin-classes/admin-classes-view/admin-classes-view.component.mjs +12 -9
  10. package/esm2022/admin/components/admin-dataset/admin-dataset.component.mjs +6 -4
  11. package/esm2022/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.mjs +7 -5
  12. package/esm2022/admin/i18n/en.translations.mjs +10 -3
  13. package/esm2022/admin/i18n/fr.translations.mjs +6 -1
  14. package/esm2022/lib/core/components/chips-selector/chips-selector.component.mjs +4 -4
  15. package/esm2022/lib/core/components/share/group-share/group-share.component.mjs +28 -40
  16. package/esm2022/lib/core/components/share/share.utils.mjs +13 -1
  17. package/esm2022/lib/core/i18n/en.translations.mjs +11 -4
  18. package/esm2022/lib/core/i18n/fr.translations.mjs +11 -4
  19. package/esm2022/lib/core/store/class/class.reducer.mjs +8 -2
  20. package/esm2022/lib/core/store/class/class.selectors.mjs +4 -2
  21. package/esm2022/lib/dashboard/store/dashboard.actions.mjs +4 -3
  22. package/esm2022/lib/dashboard/store/dashboard.reducers.mjs +12 -5
  23. package/esm2022/restitution/components/restitution/restitution.component.mjs +4 -4
  24. package/esm2022/restitution/i18n/fr.translations.mjs +2 -2
  25. package/esm2022/widgets/widget-map/component/widget-map.component.mjs +70 -61
  26. package/fesm2022/provoly-dashboard-admin.mjs +34 -15
  27. package/fesm2022/provoly-dashboard-admin.mjs.map +1 -1
  28. package/fesm2022/provoly-dashboard-restitution.mjs +4 -4
  29. package/fesm2022/provoly-dashboard-restitution.mjs.map +1 -1
  30. package/fesm2022/provoly-dashboard-widgets-widget-map.mjs +69 -60
  31. package/fesm2022/provoly-dashboard-widgets-widget-map.mjs.map +1 -1
  32. package/fesm2022/provoly-dashboard.mjs +226 -196
  33. package/fesm2022/provoly-dashboard.mjs.map +1 -1
  34. package/lib/core/components/share/group-share/group-share.component.d.ts +4 -7
  35. package/lib/core/components/share/share.utils.d.ts +2 -0
  36. package/lib/core/i18n/en.translations.d.ts +10 -3
  37. package/lib/core/i18n/fr.translations.d.ts +10 -3
  38. package/lib/core/store/class/class.selectors.d.ts +1 -0
  39. package/lib/dashboard/store/dashboard.actions.d.ts +7 -6
  40. package/package.json +12 -12
  41. package/styles/components/_a-page-loader.scss +6 -0
  42. package/styles/components/_o-layer-settings.scss +2 -2
  43. package/widgets/widget-map/component/widget-map.component.d.ts +4 -2
@@ -2,7 +2,7 @@ import { Overlay } from '@angular/cdk/overlay';
2
2
  import { OnDestroy, OnInit, TemplateRef, ViewContainerRef } from '@angular/core';
3
3
  import { ActivatedRoute, Router } from '@angular/router';
4
4
  import { Store } from '@ngrx/store';
5
- import { Attribute, AttributeExtended, Category, Class, Field } from '@provoly/dashboard';
5
+ import { Attribute, AttributeExtended, Category, Class, Field, PryI18nService } from '@provoly/dashboard';
6
6
  import { Observable, Subscription } from 'rxjs';
7
7
  import * as i0 from "@angular/core";
8
8
  export declare class AdminClassesViewComponent implements OnInit, OnDestroy {
@@ -11,6 +11,7 @@ export declare class AdminClassesViewComponent implements OnInit, OnDestroy {
11
11
  private route;
12
12
  private overlay;
13
13
  private viewContainerRef;
14
+ private i18n;
14
15
  selectedclass$?: Observable<Class>;
15
16
  interClass$?: Observable<Class | undefined>;
16
17
  attributes$: Observable<Attribute[]>;
@@ -28,7 +29,7 @@ export declare class AdminClassesViewComponent implements OnInit, OnDestroy {
28
29
  openModal$: Observable<boolean>;
29
30
  private overlayRef?;
30
31
  confirmationModal: TemplateRef<any>;
31
- constructor(store: Store<any>, router: Router, route: ActivatedRoute, overlay: Overlay, viewContainerRef: ViewContainerRef);
32
+ constructor(store: Store<any>, router: Router, route: ActivatedRoute, overlay: Overlay, viewContainerRef: ViewContainerRef, i18n: PryI18nService);
32
33
  ngOnInit(): void;
33
34
  ngOnDestroy(): void;
34
35
  private getAttrExtended;
@@ -19,6 +19,7 @@ export declare class AdminDatasetComponent {
19
19
  configHeader: Array<IConfigHeader>;
20
20
  labelDatasetSelected: string;
21
21
  editOpened: boolean;
22
+ loading$: Observable<boolean>;
22
23
  validateAction: () => void;
23
24
  cancelAction: () => void;
24
25
  constructor(store: Store<DataSourceState>, translateService: PryI18nService, router: Router, route: ActivatedRoute);
@@ -27,6 +28,7 @@ export declare class AdminDatasetComponent {
27
28
  validateName(newLabel: string): void;
28
29
  changeValue($event: any): void;
29
30
  selectDataset(dataset: Dataset): void;
31
+ protected readonly getShareLevel: (groups: string[]) => import("@provoly/dashboard").PryShareMode;
30
32
  static ɵfac: i0.ɵɵFactoryDeclaration<AdminDatasetComponent, never>;
31
33
  static ɵcmp: i0.ɵɵComponentDeclaration<AdminDatasetComponent, "pry-admin-dataset", never, {}, {}, never, never, false, never>;
32
34
  }
@@ -1,4 +1,4 @@
1
- import { OnDestroy, OnInit } from '@angular/core';
1
+ import { ChangeDetectorRef, OnDestroy, OnInit } from '@angular/core';
2
2
  import { ActivatedRoute, Router } from '@angular/router';
3
3
  import { Store } from '@ngrx/store';
4
4
  import { Associations, Dataset, MetadataValue, MissingGroupsByEntity, PryBaseAccess, PryI18nService, PryShareMode, SubscriptionnerDirective } from '@provoly/dashboard';
@@ -16,6 +16,7 @@ export declare class AdminSelectDatasetComponent extends SubscriptionnerDirectiv
16
16
  private router;
17
17
  private route;
18
18
  private i18n;
19
+ private cdr;
19
20
  protected access: PryBaseAccess;
20
21
  static id: string;
21
22
  selectedDataset$: Observable<Dataset | null>;
@@ -29,7 +30,7 @@ export declare class AdminSelectDatasetComponent extends SubscriptionnerDirectiv
29
30
  missingGroups$: Observable<MissingGroups | undefined>;
30
31
  shareRadioValue$: BehaviorSubject<PryShareMode | undefined>;
31
32
  disableShareButton$: BehaviorSubject<boolean>;
32
- constructor(store: Store<any>, router: Router, route: ActivatedRoute, i18n: PryI18nService, access: PryBaseAccess);
33
+ constructor(store: Store<any>, router: Router, route: ActivatedRoute, i18n: PryI18nService, cdr: ChangeDetectorRef, access: PryBaseAccess);
33
34
  ngOnInit(): void;
34
35
  closePanel(): void;
35
36
  removeMetadata(metadata: MetaEventType): void;
@@ -40,7 +41,7 @@ export declare class AdminSelectDatasetComponent extends SubscriptionnerDirectiv
40
41
  updateGroups($event: PryShareMode): void;
41
42
  updateDisableButtonValue(): void;
42
43
  canModify$(dataset: Dataset): Observable<boolean>;
43
- static ɵfac: i0.ɵɵFactoryDeclaration<AdminSelectDatasetComponent, [null, null, null, null, { optional: true; }]>;
44
+ static ɵfac: i0.ɵɵFactoryDeclaration<AdminSelectDatasetComponent, [null, null, null, null, null, { optional: true; }]>;
44
45
  static ɵcmp: i0.ɵɵComponentDeclaration<AdminSelectDatasetComponent, "pry-admin-select-dataset", never, {}, {}, never, never, false, never>;
45
46
  }
46
47
  export {};
@@ -29,7 +29,13 @@ export declare const enTranslations: {
29
29
  defaultRule: string;
30
30
  displayModeImage: string;
31
31
  size: string;
32
+ share: string;
32
33
  deleteAttributeConfirmMessage: string;
34
+ attributes: {
35
+ unknownField: string;
36
+ unknownCategory: string;
37
+ noCategory: string;
38
+ };
33
39
  position: {
34
40
  FULL: string;
35
41
  TOP_LEFT: string;
@@ -134,6 +140,7 @@ export declare const enTranslations: {
134
140
  dataset: {
135
141
  delete: string;
136
142
  title: string;
143
+ datasetDetails: string;
137
144
  details: string;
138
145
  id: string;
139
146
  name: string;
@@ -31,6 +31,11 @@ export declare const frTranslations: {
31
31
  displayModeImage: string;
32
32
  size: string;
33
33
  deleteAttributeConfirmMessage: string;
34
+ attributes: {
35
+ unknownField: string;
36
+ unknownCategory: string;
37
+ noCategory: string;
38
+ };
34
39
  position: {
35
40
  FULL: string;
36
41
  TOP_LEFT: string;
@@ -0,0 +1,16 @@
1
+ <svg fill="none" height="18" viewBox="0 0 20 18" width="20" xmlns="http://www.w3.org/2000/svg"
2
+ xmlns:xlink="http://www.w3.org/1999/xlink">
3
+ <clipPath id="a">
4
+ <path d="m0 0h19.87v17.82h-19.87z" />
5
+ </clipPath>
6
+ <g clip-path="url(#a)" fill="#000">
7
+ <path
8
+ d="m12.7995 8.23004c-2.28 0-4.12001-1.86-4.11001-4.16.01-2.24 1.89001-4.07999943 4.15001-4.06999943 2.25.01000003 4.1 1.87999943 4.08 4.10999943-.02 2.29-1.85 4.12-4.13 4.12z" />
9
+ <path
10
+ d="m12.6497 17.8204c-1.99 0-3.99 0-5.98 0-.83 0-1.23-.48-1.21-1.45.06-3.42 2.34-6.48004 5.23-6.90004 1.48-.21 2.99-.27 4.46.11 2.56.66004 4.51 3.38004 4.69 6.45004 0 .14.02.28.02.42.02.83-.41 1.36-1.11 1.36-1.04 0-2.09 0-3.13 0-.99 0-1.98 0-2.97 0z" />
11
+ <path
12
+ d="m6.71039 4.04962c0-.77.16-1.5.43-2.18-.17-.03-.34-.05-.51-.06-2.03-.01-3.72 1.64-3.73 3.66 0 2.07 1.64 3.73 3.69 3.74.77 0 1.48-.23 2.07-.63-1.2-1.13-1.96-2.73-1.95-4.53z" />
13
+ <path
14
+ d="m3.36021 17.0692c.04-2.63.87-5.07 2.61-6.91-.37.03-.9.1-1.27.15-2.6.39-4.6500018 3.14-4.70000177 6.21-.01.87.33999977 1.3 1.09000177 1.3h2.34c-.04-.22-.07-.46-.06-.74z" />
15
+ </g>
16
+ </svg>
@@ -1,16 +1 @@
1
- <svg fill="none" height="18" viewBox="0 0 20 18" width="20" xmlns="http://www.w3.org/2000/svg"
2
- xmlns:xlink="http://www.w3.org/1999/xlink">
3
- <clipPath id="a">
4
- <path d="m0 0h19.87v17.82h-19.87z" />
5
- </clipPath>
6
- <g clip-path="url(#a)" fill="#000">
7
- <path
8
- d="m12.7995 8.23004c-2.28 0-4.12001-1.86-4.11001-4.16.01-2.24 1.89001-4.07999943 4.15001-4.06999943 2.25.01000003 4.1 1.87999943 4.08 4.10999943-.02 2.29-1.85 4.12-4.13 4.12z" />
9
- <path
10
- d="m12.6497 17.8204c-1.99 0-3.99 0-5.98 0-.83 0-1.23-.48-1.21-1.45.06-3.42 2.34-6.48004 5.23-6.90004 1.48-.21 2.99-.27 4.46.11 2.56.66004 4.51 3.38004 4.69 6.45004 0 .14.02.28.02.42.02.83-.41 1.36-1.11 1.36-1.04 0-2.09 0-3.13 0-.99 0-1.98 0-2.97 0z" />
11
- <path
12
- d="m6.71039 4.04962c0-.77.16-1.5.43-2.18-.17-.03-.34-.05-.51-.06-2.03-.01-3.72 1.64-3.73 3.66 0 2.07 1.64 3.73 3.69 3.74.77 0 1.48-.23 2.07-.63-1.2-1.13-1.96-2.73-1.95-4.53z" />
13
- <path
14
- d="m3.36021 17.0692c.04-2.63.87-5.07 2.61-6.91-.37.03-.9.1-1.27.15-2.6.39-4.6500018 3.14-4.70000177 6.21-.01.87.33999977 1.3 1.09000177 1.3h2.34c-.04-.22-.07-.46-.06-.74z" />
15
- </g>
16
- </svg>
1
+ <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 -960 960 960" width="24px" fill="#5f6368"><path d="M480-80q-83 0-156-31.5T197-197q-54-54-85.5-127T80-480q0-83 31.5-156T197-763q54-54 127-85.5T480-880q83 0 156 31.5T763-763q54 54 85.5 127T880-480q0 83-31.5 156T763-197q-54 54-127 85.5T480-80Zm-40-82v-78q-33 0-56.5-23.5T360-320v-40L168-552q-3 18-5.5 36t-2.5 36q0 121 79.5 212T440-162Zm276-102q20-22 36-47.5t26.5-53q10.5-27.5 16-56.5t5.5-59q0-98-54.5-179T600-776v16q0 33-23.5 56.5T520-680h-80v80q0 17-11.5 28.5T400-560h-80v80h240q17 0 28.5 11.5T600-440v120h40q26 0 47 15.5t29 40.5Z"/></svg>
@@ -129,7 +129,7 @@ export class AdminAttributesFormComponent extends SubscriptionnerDirective {
129
129
  ref.component.entityType = 'attribute';
130
130
  this.subscriptions.add(ref.component.category.subscribe((category) => {
131
131
  this.attrForm.patchValue({
132
- categories: category.id
132
+ category: category.id
133
133
  });
134
134
  }));
135
135
  this.subscriptions.add(ref.component.closeModal.subscribe(() => ref.close()));
@@ -147,4 +147,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
147
147
  }], selectedAttribute: [{
148
148
  type: Input
149
149
  }] } });
150
- //# 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_OPTIONS,\n  FieldActions,\n  FieldSelectors,\n  PryDialogService,\n  PryI18nService,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { debounceTime, distinctUntilChanged, map, Observable, startWith, switchMap } 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 | undefined>;\n  fieldTypeDescription = FIELD_OPTIONS;\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$ = this.attrForm.get('field')?.valueChanges.pipe(\n      startWith(this.attrForm.get('field')?.value),\n      distinctUntilChanged(),\n      switchMap((selectedFieldId) => {\n        return this.fields$.pipe(\n          map((fields) => {\n            const fieldDescription = this.fieldTypeDescription.find(\n              (fieldType) => fieldType.varType === fields.find((field) => field.id === selectedFieldId)?.type\n            );\n            return fieldDescription ? this.i18nService.instant(fieldDescription.description) : '';\n          })\n        );\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          categories: category.id\n        });\n      })\n    );\n    this.subscriptions.add(ref.component!.closeModal.subscribe(() => ref.close()));\n  }\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\" *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\" *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        *ngIf=\"selectedFieldTypeDescription$ | async as description\"\n        class=\"m-info-icon a-tooltip -tooltip-width-lg u-self-center -flex-shrink-0\"\n        [attr.data-tooltip]=\"description\"\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\">{{ '@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"]}
150
+ //# 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_OPTIONS,\n  FieldActions,\n  FieldSelectors,\n  PryDialogService,\n  PryI18nService,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { debounceTime, distinctUntilChanged, map, Observable, startWith, switchMap } 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 | undefined>;\n  fieldTypeDescription = FIELD_OPTIONS;\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$ = this.attrForm.get('field')?.valueChanges.pipe(\n      startWith(this.attrForm.get('field')?.value),\n      distinctUntilChanged(),\n      switchMap((selectedFieldId) => {\n        return this.fields$.pipe(\n          map((fields) => {\n            const fieldDescription = this.fieldTypeDescription.find(\n              (fieldType) => fieldType.varType === fields.find((field) => field.id === selectedFieldId)?.type\n            );\n            return fieldDescription ? this.i18nService.instant(fieldDescription.description) : '';\n          })\n        );\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","<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\" *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\" *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        *ngIf=\"selectedFieldTypeDescription$ | async as description\"\n        class=\"m-info-icon a-tooltip -tooltip-width-lg u-self-center -flex-shrink-0\"\n        [attr.data-tooltip]=\"description\"\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\">{{ '@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"]}
@@ -10,15 +10,16 @@ import * as i0 from "@angular/core";
10
10
  import * as i1 from "@ngrx/store";
11
11
  import * as i2 from "@angular/router";
12
12
  import * as i3 from "@angular/cdk/overlay";
13
- import * as i4 from "@angular/common";
14
- import * as i5 from "@provoly/dashboard";
13
+ import * as i4 from "@provoly/dashboard";
14
+ import * as i5 from "@angular/common";
15
15
  export class AdminClassesViewComponent {
16
- constructor(store, router, route, overlay, viewContainerRef) {
16
+ constructor(store, router, route, overlay, viewContainerRef, i18n) {
17
17
  this.store = store;
18
18
  this.router = router;
19
19
  this.route = route;
20
20
  this.overlay = overlay;
21
21
  this.viewContainerRef = viewContainerRef;
22
+ this.i18n = i18n;
22
23
  this.attributes$ = of([]);
23
24
  this.fields$ = of([]);
24
25
  this.categories$ = of([]);
@@ -71,8 +72,10 @@ export class AdminClassesViewComponent {
71
72
  return combineLatest([this.attributes$, this.fields$, this.categories$]).pipe(filter(([attributes, fields, categories]) => fields.length > 0 && categories.length > 0), map(([attributes, fields, categories]) => {
72
73
  return attributes.map((attr) => ({
73
74
  ...attr,
74
- fieldName: fields.find((field) => field.id === attr.field)?.name || 'unknown',
75
- categoryName: categories.find((category) => category.id === attr.category)?.name || 'unknown'
75
+ fieldName: fields.find((field) => field.id === attr.field)?.name || this.i18n.instant('@pry.admin.attributes.unknownField'),
76
+ categoryName: attr.category ?
77
+ categories.find((category) => category.id === attr.category)?.name ?? this.i18n.instant('@pry.admin.attributes.unknownCategory')
78
+ : this.i18n.instant('@pry.admin.attributes.noCategory')
76
79
  }));
77
80
  }));
78
81
  }
@@ -171,14 +174,14 @@ export class AdminClassesViewComponent {
171
174
  }
172
175
  this.dispatchCloseModal();
173
176
  }
174
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: AdminClassesViewComponent, deps: [{ token: i1.Store }, { token: i2.Router }, { token: i2.ActivatedRoute }, { token: i3.Overlay }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
175
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: AdminClassesViewComponent, selector: "pry-admin-classes-view", viewQueries: [{ propertyName: "confirmationModal", first: true, predicate: ["confirmationModal"], descendants: true, read: TemplateRef }], ngImport: i0, template: "<ng-container *ngIf=\"(selectedclass$ | async) || (interClass$ | async) as selectedClass\">\n <div class=\"o-base-container\">\n <h1 class=\"a-h1\">\n {{ '@pry.admin.classes.title' | i18n : { class: selectedClass.name } }}\n </h1>\n <table\n class=\"a-table\"\n prySortTable\n prySortActive=\"name\"\n prySortDirection=\"asc\"\n (prySortChange)=\"sortActive = $event.active; sortDirection = $event.direction\"\n >\n <caption>\n {{\n '@pry.admin.classes.title' | i18n\n }},\n {{\n '@pry.action.sortableColumnHeader' | i18n\n }}\n </caption>\n <thead>\n <tr>\n <th></th>\n <th prySortHeader=\"technicalName\">{{ '@pry.admin.classes.attributes.technicalName' | i18n }}</th>\n <th prySortHeader=\"name\">{{ '@pry.admin.classes.attributes.name' | i18n }}</th>\n <th prySortHeader=\"field\">{{ '@pry.admin.classes.attributes.field' | i18n }}</th>\n <th prySortHeader=\"category\">{{ '@pry.admin.classes.attributes.category' | i18n }}</th>\n </tr>\n </thead>\n <tbody>\n <tr\n *ngFor=\"let attr of attributesExtended$ | async | prySortData : sortActive : sortDirection\"\n (click)=\"selectAttr(attr)\"\n [class.is-selected]=\"(selectedAttributeId$ | async) === attr.id\"\n >\n <td class=\"view-details\">\n <button\n [id]=\"'button-attr-' + attr.id\"\n type=\"button\"\n class=\"a-btn a-btn--icon-only\"\n title=\"{{ '@pry.action.viewDetails' | i18n }}\"\n [attr.aria-expanded]=\"(selectedAttributeId$ | async) === attr.id\"\n aria-haspopup\n [attr.aria-controls]=\"'panel-attr-' + attr.id\"\n >\n <span class=\"u-visually-hidden\">{{ attr.name }}, {{ '@pry.action.viewDetails' | i18n }}</span>\n <pry-icon iconSvg=\"eye\" [width]=\"15\" [height]=\"15\"></pry-icon>\n </button>\n </td>\n <td>{{ attr.technicalName }}</td>\n <td>{{ attr.name }}</td>\n <td>{{ attr.fieldName }}</td>\n <td>{{ attr.categoryName }}</td>\n </tr>\n </tbody>\n </table>\n </div>\n</ng-container>\n\n<ng-template #confirmationModal>\n <div class=\"o-modal\">\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title\">\n {{ '@pry.admin.classes.createClassConfirmMessage' | i18n }}\n </h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"dispatchCloseModal()\">\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <div class=\"m-btn-group\">\n <button type=\"button\" class=\"a-btn a-btn--primary\" (click)=\"saveClass()\">\n {{ '@pry.toolbox.manifest.validate' | i18n }}\n </button>\n <button type=\"button\" class=\"a-btn a-btn--secondary\" (click)=\"dispatchCloseModal()\">\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "component", type: i5.PrySortHeaderComponent, selector: "th[prySortHeader]", inputs: ["prySortHeader"], outputs: ["sortChange"] }, { kind: "directive", type: i5.PrySortHeaderDirective, selector: "[prySortHeader]" }, { kind: "directive", type: i5.PrySortTableDirective, selector: "[prySortTable]", inputs: ["prySortActive", "prySortDirection"], outputs: ["prySortChange"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.PrySortDataPipe, name: "prySortData" }, { kind: "pipe", type: i5.I18nPipe, name: "i18n" }] }); }
177
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: AdminClassesViewComponent, deps: [{ token: i1.Store }, { token: i2.Router }, { token: i2.ActivatedRoute }, { token: i3.Overlay }, { token: i0.ViewContainerRef }, { token: i4.PryI18nService }], target: i0.ɵɵFactoryTarget.Component }); }
178
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: AdminClassesViewComponent, selector: "pry-admin-classes-view", viewQueries: [{ propertyName: "confirmationModal", first: true, predicate: ["confirmationModal"], descendants: true, read: TemplateRef }], ngImport: i0, template: "<ng-container *ngIf=\"(selectedclass$ | async) || (interClass$ | async) as selectedClass\">\n <div class=\"o-base-container\">\n <h1 class=\"a-h1\">\n {{ '@pry.admin.classes.title' | i18n : { class: selectedClass.name } }}\n </h1>\n <table\n class=\"a-table\"\n prySortTable\n prySortActive=\"name\"\n prySortDirection=\"asc\"\n (prySortChange)=\"sortActive = $event.active; sortDirection = $event.direction\"\n >\n <caption>\n {{\n '@pry.admin.classes.title' | i18n\n }},\n {{\n '@pry.action.sortableColumnHeader' | i18n\n }}\n </caption>\n <thead>\n <tr>\n <th></th>\n <th prySortHeader=\"technicalName\">{{ '@pry.admin.classes.attributes.technicalName' | i18n }}</th>\n <th prySortHeader=\"name\">{{ '@pry.admin.classes.attributes.name' | i18n }}</th>\n <th prySortHeader=\"field\">{{ '@pry.admin.classes.attributes.field' | i18n }}</th>\n <th prySortHeader=\"category\">{{ '@pry.admin.classes.attributes.category' | i18n }}</th>\n </tr>\n </thead>\n <tbody>\n <tr\n *ngFor=\"let attr of attributesExtended$ | async | prySortData : sortActive : sortDirection\"\n (click)=\"selectAttr(attr)\"\n [class.is-selected]=\"(selectedAttributeId$ | async) === attr.id\"\n >\n <td class=\"view-details\">\n <button\n [id]=\"'button-attr-' + attr.id\"\n type=\"button\"\n class=\"a-btn a-btn--icon-only\"\n title=\"{{ '@pry.action.viewDetails' | i18n }}\"\n [attr.aria-expanded]=\"(selectedAttributeId$ | async) === attr.id\"\n aria-haspopup\n [attr.aria-controls]=\"'panel-attr-' + attr.id\"\n >\n <span class=\"u-visually-hidden\">{{ attr.name }}, {{ '@pry.action.viewDetails' | i18n }}</span>\n <pry-icon iconSvg=\"eye\" [width]=\"15\" [height]=\"15\"></pry-icon>\n </button>\n </td>\n <td>{{ attr.technicalName }}</td>\n <td>{{ attr.name }}</td>\n <td>{{ attr.fieldName }}</td>\n <td>{{ attr.categoryName }}</td>\n </tr>\n </tbody>\n </table>\n </div>\n</ng-container>\n\n<ng-template #confirmationModal>\n <div class=\"o-modal\">\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title\">\n {{ '@pry.admin.classes.createClassConfirmMessage' | i18n }}\n </h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"dispatchCloseModal()\">\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <div class=\"m-btn-group\">\n <button type=\"button\" class=\"a-btn a-btn--primary\" (click)=\"saveClass()\">\n {{ '@pry.toolbox.manifest.validate' | i18n }}\n </button>\n <button type=\"button\" class=\"a-btn a-btn--secondary\" (click)=\"dispatchCloseModal()\">\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "component", type: i4.PrySortHeaderComponent, selector: "th[prySortHeader]", inputs: ["prySortHeader"], outputs: ["sortChange"] }, { kind: "directive", type: i4.PrySortHeaderDirective, selector: "[prySortHeader]" }, { kind: "directive", type: i4.PrySortTableDirective, selector: "[prySortTable]", inputs: ["prySortActive", "prySortDirection"], outputs: ["prySortChange"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.PrySortDataPipe, name: "prySortData" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
176
179
  }
177
180
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: AdminClassesViewComponent, decorators: [{
178
181
  type: Component,
179
182
  args: [{ selector: 'pry-admin-classes-view', template: "<ng-container *ngIf=\"(selectedclass$ | async) || (interClass$ | async) as selectedClass\">\n <div class=\"o-base-container\">\n <h1 class=\"a-h1\">\n {{ '@pry.admin.classes.title' | i18n : { class: selectedClass.name } }}\n </h1>\n <table\n class=\"a-table\"\n prySortTable\n prySortActive=\"name\"\n prySortDirection=\"asc\"\n (prySortChange)=\"sortActive = $event.active; sortDirection = $event.direction\"\n >\n <caption>\n {{\n '@pry.admin.classes.title' | i18n\n }},\n {{\n '@pry.action.sortableColumnHeader' | i18n\n }}\n </caption>\n <thead>\n <tr>\n <th></th>\n <th prySortHeader=\"technicalName\">{{ '@pry.admin.classes.attributes.technicalName' | i18n }}</th>\n <th prySortHeader=\"name\">{{ '@pry.admin.classes.attributes.name' | i18n }}</th>\n <th prySortHeader=\"field\">{{ '@pry.admin.classes.attributes.field' | i18n }}</th>\n <th prySortHeader=\"category\">{{ '@pry.admin.classes.attributes.category' | i18n }}</th>\n </tr>\n </thead>\n <tbody>\n <tr\n *ngFor=\"let attr of attributesExtended$ | async | prySortData : sortActive : sortDirection\"\n (click)=\"selectAttr(attr)\"\n [class.is-selected]=\"(selectedAttributeId$ | async) === attr.id\"\n >\n <td class=\"view-details\">\n <button\n [id]=\"'button-attr-' + attr.id\"\n type=\"button\"\n class=\"a-btn a-btn--icon-only\"\n title=\"{{ '@pry.action.viewDetails' | i18n }}\"\n [attr.aria-expanded]=\"(selectedAttributeId$ | async) === attr.id\"\n aria-haspopup\n [attr.aria-controls]=\"'panel-attr-' + attr.id\"\n >\n <span class=\"u-visually-hidden\">{{ attr.name }}, {{ '@pry.action.viewDetails' | i18n }}</span>\n <pry-icon iconSvg=\"eye\" [width]=\"15\" [height]=\"15\"></pry-icon>\n </button>\n </td>\n <td>{{ attr.technicalName }}</td>\n <td>{{ attr.name }}</td>\n <td>{{ attr.fieldName }}</td>\n <td>{{ attr.categoryName }}</td>\n </tr>\n </tbody>\n </table>\n </div>\n</ng-container>\n\n<ng-template #confirmationModal>\n <div class=\"o-modal\">\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title\">\n {{ '@pry.admin.classes.createClassConfirmMessage' | i18n }}\n </h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"dispatchCloseModal()\">\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <div class=\"m-btn-group\">\n <button type=\"button\" class=\"a-btn a-btn--primary\" (click)=\"saveClass()\">\n {{ '@pry.toolbox.manifest.validate' | i18n }}\n </button>\n <button type=\"button\" class=\"a-btn a-btn--secondary\" (click)=\"dispatchCloseModal()\">\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n </div>\n </div>\n</ng-template>\n" }]
180
- }], ctorParameters: () => [{ type: i1.Store }, { type: i2.Router }, { type: i2.ActivatedRoute }, { type: i3.Overlay }, { type: i0.ViewContainerRef }], propDecorators: { confirmationModal: [{
183
+ }], ctorParameters: () => [{ type: i1.Store }, { type: i2.Router }, { type: i2.ActivatedRoute }, { type: i3.Overlay }, { type: i0.ViewContainerRef }, { type: i4.PryI18nService }], propDecorators: { confirmationModal: [{
181
184
  type: ViewChild,
182
185
  args: ['confirmationModal', { read: TemplateRef }]
183
186
  }] } });
184
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-classes-view.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-view/admin-classes-view.component.ts","../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-view/admin-classes-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { Component, OnDestroy, OnInit, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  Attribute,\n  AttributeExtended,\n  BaseToolboxAction,\n  Category,\n  CategoryActions,\n  CategorySelectors,\n  Class,\n  ClassActions,\n  ClassSelectors,\n  ConfigActions,\n  Field,\n  FieldActions,\n  FieldSelectors\n} from '@provoly/dashboard';\nimport { combineLatest, filter, map, Observable, of, Subscription } from 'rxjs';\nimport { AdminActions } from '../../../store/admin.actions';\nimport { AdminClassActions } from '../store/admin-class.actions';\nimport { AdminClassSelectors } from '../store/admin-class.selectors';\n\n@Component({\n  selector: 'pry-admin-classes-view',\n  templateUrl: './admin-classes-view.component.html'\n})\nexport class AdminClassesViewComponent implements OnInit, OnDestroy {\n  selectedclass$?: Observable<Class>;\n  interClass$?: Observable<Class | undefined>;\n  attributes$: Observable<Attribute[]> = of([]);\n  fields$: Observable<Field[]> = of([]);\n  categories$: Observable<Category[]> = of([]);\n  attributesExtended$?: Observable<AttributeExtended[]>;\n  selectedAttributeId$: Observable<string | undefined>;\n\n  interClass?: Class;\n\n  sub = new Subscription();\n  sortActive? = 'name';\n  sortDirection? = 'asc';\n  selectedClassId = '';\n  backPath: string;\n  addAttributePath: string;\n  openModal$: Observable<boolean>;\n  private overlayRef?: OverlayRef;\n  @ViewChild('confirmationModal', { read: TemplateRef }) confirmationModal!: TemplateRef<any>;\n\n  constructor(\n    private store: Store<any>,\n    private router: Router,\n    private route: ActivatedRoute,\n    private overlay: Overlay,\n    private viewContainerRef: ViewContainerRef\n  ) {\n    this.store.dispatch(ClassActions.load());\n    this.store.dispatch(FieldActions.load());\n    this.store.dispatch(CategoryActions.load());\n    this.store.dispatch(AdminClassActions.unselectAttribute());\n\n    this.fields$ = this.store.select(FieldSelectors.fields);\n    this.categories$ = this.store.select(CategorySelectors.categories);\n    this.selectedAttributeId$ = this.store.select(AdminClassSelectors.selectedAttributeId);\n    this.backPath = this.router.createUrlTree(['..'], { relativeTo: this.route }).toString();\n    this.addAttributePath = this.router.createUrlTree(['.', 'new'], { relativeTo: this.route }).toString();\n    this.openModal$ = this.store.select(AdminClassSelectors.openModal);\n  }\n\n  ngOnInit(): void {\n    this.interClass$ = this.store.select(AdminClassSelectors.interClass);\n    this.sub.add(this.interClass$.subscribe((c) => (this.interClass = c)));\n    if (this.interClass) {\n      if (this.interClass.attributes.length > 0) {\n        this.attributes$ = of(this.interClass.attributes);\n        this.attributesExtended$ = this.getAttrExtended();\n      }\n    } else {\n      this.route.params.subscribe((params) => {\n        this.selectedClassId = params['id'];\n        this.selectedclass$ = this.store.select(ClassSelectors.classById(this.selectedClassId));\n        this.attributes$ = this.selectedclass$.pipe(map((selectedClass) => selectedClass.attributes));\n        this.attributesExtended$ = this.getAttrExtended();\n      });\n    }\n    this.setClassActions();\n    this.sub.add(\n      this.openModal$.subscribe((open) => {\n        if (open) {\n          this.showModal();\n        } else {\n          this.closeModal();\n        }\n      })\n    );\n  }\n\n  ngOnDestroy(): void {\n    this.sub.unsubscribe();\n  }\n\n  private getAttrExtended() {\n    return combineLatest([this.attributes$, this.fields$, this.categories$]).pipe(\n      filter(([attributes, fields, categories]) => fields.length > 0 && categories.length > 0),\n      map(([attributes, fields, categories]) => {\n        return attributes.map(\n          (attr: Attribute) =>\n            ({\n              ...attr,\n              fieldName: fields.find((field) => field.id === attr.field)?.name || 'unknown',\n              categoryName: categories.find((category) => category.id === attr.category)?.name || 'unknown'\n            }) as AttributeExtended\n        );\n      })\n    );\n  }\n\n  private setClassActions() {\n    this.store.dispatch(AdminActions.resetActions());\n    let actions = [\n      {\n        action: AdminClassActions.back({ path: this.backPath }),\n        label: 'back',\n        icon: 'arrow_back'\n      },\n      {\n        action: AdminActions.routeTo({ path: this.addAttributePath }),\n        label: 'addAttribute',\n        icon: 'add_column',\n        moduleAccess: 'admin',\n        pageAccess: 'classes',\n        actionAccess: 'write'\n      }\n    ] as BaseToolboxAction[];\n\n    if (this.interClass) {\n      actions.push({\n        action: AdminClassActions.openModal(),\n        label: 'addClass',\n        icon: 'add_column',\n        moduleAccess: 'admin',\n        pageAccess: 'classes',\n        actionAccess: 'write'\n      });\n    }\n\n    this.store.dispatch(\n      AdminActions.mainActions({\n        actions: actions\n      })\n    );\n  }\n\n  private setAttributeActions(attrId: string) {\n    this.sub.add(\n      this.selectedAttributeId$.subscribe((attributeId) => {\n        let editPath = this.router.createUrlTree([attributeId, 'edit'], { relativeTo: this.route }).toString();\n\n        this.store.dispatch(\n          AdminActions.mainActions({\n            actions: [\n              {\n                action: AdminClassActions.back({ path: this.backPath }),\n                label: 'back',\n                icon: 'arrow_back'\n              },\n              {\n                action: AdminActions.routeTo({ path: editPath }),\n                label: 'edit',\n                icon: 'edit',\n                moduleAccess: 'admin',\n                pageAccess: 'fields',\n                actionAccess: 'write'\n              },\n              {\n                action: AdminClassActions.confirmAttributeDeletion({\n                  classId: this.selectedClassId,\n                  attrId: attrId,\n                  backPath: this.backPath,\n                  addAttrPath: this.addAttributePath\n                }),\n                label: 'delete',\n                icon: 'delete',\n                moduleAccess: 'admin',\n                pageAccess: 'classes',\n                actionAccess: 'write'\n              }\n            ]\n          })\n        );\n      })\n    );\n  }\n\n  selectAttr(attr: AttributeExtended) {\n    this.store.dispatch(AdminClassActions.selectAttribute({ attrExtended: attr }));\n    this.store.dispatch(AdminActions.selectComponentType({ componentType: 'AdminAttributesSelectComponent' }));\n    this.setAttributeActions(attr.id);\n    this.store.dispatch(AdminActions.fetchAttributeAssociations({ id: attr.id }));\n  }\n\n  dispatchCloseModal() {\n    this.store.dispatch(AdminClassActions.closeModal());\n  }\n\n  showModal() {\n    this.overlayRef = this.overlay.create(\n      new OverlayConfig({\n        hasBackdrop: true,\n        panelClass: ['o-modal-wrapper'],\n        backdropClass: 'backdrop'\n      })\n    );\n    this.store.dispatch(ConfigActions.addingOverlay({ id: this.constructor.name }));\n    this.overlayRef.backdropClick().subscribe((_) => this.closeModal());\n    this.overlayRef.attach(new TemplatePortal(this.confirmationModal, this.viewContainerRef));\n  }\n\n  closeModal() {\n    this.overlayRef?.dispose();\n    this.store.dispatch(ConfigActions.closeOverlay({ id: this.constructor.name }));\n  }\n\n  saveClass() {\n    if (this.interClass) {\n      this.store.dispatch(AdminClassActions.saveClass({ class: this.interClass, route: this.backPath }));\n    }\n    this.dispatchCloseModal();\n  }\n}\n","<ng-container *ngIf=\"(selectedclass$ | async) || (interClass$ | async) as selectedClass\">\n  <div class=\"o-base-container\">\n    <h1 class=\"a-h1\">\n      {{ '@pry.admin.classes.title' | i18n : { class: selectedClass.name } }}\n    </h1>\n    <table\n      class=\"a-table\"\n      prySortTable\n      prySortActive=\"name\"\n      prySortDirection=\"asc\"\n      (prySortChange)=\"sortActive = $event.active; sortDirection = $event.direction\"\n    >\n      <caption>\n        {{\n          '@pry.admin.classes.title' | i18n\n        }},\n        {{\n          '@pry.action.sortableColumnHeader' | i18n\n        }}\n      </caption>\n      <thead>\n        <tr>\n          <th></th>\n          <th prySortHeader=\"technicalName\">{{ '@pry.admin.classes.attributes.technicalName' | i18n }}</th>\n          <th prySortHeader=\"name\">{{ '@pry.admin.classes.attributes.name' | i18n }}</th>\n          <th prySortHeader=\"field\">{{ '@pry.admin.classes.attributes.field' | i18n }}</th>\n          <th prySortHeader=\"category\">{{ '@pry.admin.classes.attributes.category' | i18n }}</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr\n          *ngFor=\"let attr of attributesExtended$ | async | prySortData : sortActive : sortDirection\"\n          (click)=\"selectAttr(attr)\"\n          [class.is-selected]=\"(selectedAttributeId$ | async) === attr.id\"\n        >\n          <td class=\"view-details\">\n            <button\n              [id]=\"'button-attr-' + attr.id\"\n              type=\"button\"\n              class=\"a-btn a-btn--icon-only\"\n              title=\"{{ '@pry.action.viewDetails' | i18n }}\"\n              [attr.aria-expanded]=\"(selectedAttributeId$ | async) === attr.id\"\n              aria-haspopup\n              [attr.aria-controls]=\"'panel-attr-' + attr.id\"\n            >\n              <span class=\"u-visually-hidden\">{{ attr.name }}, {{ '@pry.action.viewDetails' | i18n }}</span>\n              <pry-icon iconSvg=\"eye\" [width]=\"15\" [height]=\"15\"></pry-icon>\n            </button>\n          </td>\n          <td>{{ attr.technicalName }}</td>\n          <td>{{ attr.name }}</td>\n          <td>{{ attr.fieldName }}</td>\n          <td>{{ attr.categoryName }}</td>\n        </tr>\n      </tbody>\n    </table>\n  </div>\n</ng-container>\n\n<ng-template #confirmationModal>\n  <div class=\"o-modal\">\n    <div class=\"o-modal__top\">\n      <div class=\"o-modal__top__title\">\n        <h2 class=\"a-h2\" id=\"dialog_title\">\n          {{ '@pry.admin.classes.createClassConfirmMessage' | i18n }}\n        </h2>\n      </div>\n      <div class=\"o-modal__top__close\">\n        <button class=\"a-btn a-btn--icon-only\" (click)=\"dispatchCloseModal()\">\n          <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n          <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n        </button>\n      </div>\n    </div>\n    <div class=\"m-btn-group\">\n      <button type=\"button\" class=\"a-btn a-btn--primary\" (click)=\"saveClass()\">\n        {{ '@pry.toolbox.manifest.validate' | i18n }}\n      </button>\n      <button type=\"button\" class=\"a-btn a-btn--secondary\" (click)=\"dispatchCloseModal()\">\n        {{ '@pry.toolbox.manifest.close' | i18n }}\n      </button>\n    </div>\n  </div>\n</ng-template>\n"]}
187
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-classes-view.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-view/admin-classes-view.component.ts","../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-view/admin-classes-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { Component, OnDestroy, OnInit, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  Attribute,\n  AttributeExtended,\n  BaseToolboxAction,\n  Category,\n  CategoryActions,\n  CategorySelectors,\n  Class,\n  ClassActions,\n  ClassSelectors,\n  ConfigActions,\n  Field,\n  FieldActions,\n  FieldSelectors,\n  PryI18nService\n} from '@provoly/dashboard';\nimport { combineLatest, filter, map, Observable, of, Subscription } from 'rxjs';\nimport { AdminActions } from '../../../store/admin.actions';\nimport { AdminClassActions } from '../store/admin-class.actions';\nimport { AdminClassSelectors } from '../store/admin-class.selectors';\n\n@Component({\n  selector: 'pry-admin-classes-view',\n  templateUrl: './admin-classes-view.component.html'\n})\nexport class AdminClassesViewComponent implements OnInit, OnDestroy {\n  selectedclass$?: Observable<Class>;\n  interClass$?: Observable<Class | undefined>;\n  attributes$: Observable<Attribute[]> = of([]);\n  fields$: Observable<Field[]> = of([]);\n  categories$: Observable<Category[]> = of([]);\n  attributesExtended$?: Observable<AttributeExtended[]>;\n  selectedAttributeId$: Observable<string | undefined>;\n\n  interClass?: Class;\n\n  sub = new Subscription();\n  sortActive? = 'name';\n  sortDirection? = 'asc';\n  selectedClassId = '';\n  backPath: string;\n  addAttributePath: string;\n  openModal$: Observable<boolean>;\n  private overlayRef?: OverlayRef;\n  @ViewChild('confirmationModal', { read: TemplateRef }) confirmationModal!: TemplateRef<any>;\n\n  constructor(\n    private store: Store<any>,\n    private router: Router,\n    private route: ActivatedRoute,\n    private overlay: Overlay,\n    private viewContainerRef: ViewContainerRef,\n    private i18n: PryI18nService\n  ) {\n    this.store.dispatch(ClassActions.load());\n    this.store.dispatch(FieldActions.load());\n    this.store.dispatch(CategoryActions.load());\n    this.store.dispatch(AdminClassActions.unselectAttribute());\n\n    this.fields$ = this.store.select(FieldSelectors.fields);\n    this.categories$ = this.store.select(CategorySelectors.categories);\n    this.selectedAttributeId$ = this.store.select(AdminClassSelectors.selectedAttributeId);\n    this.backPath = this.router.createUrlTree(['..'], { relativeTo: this.route }).toString();\n    this.addAttributePath = this.router.createUrlTree(['.', 'new'], { relativeTo: this.route }).toString();\n    this.openModal$ = this.store.select(AdminClassSelectors.openModal);\n  }\n\n  ngOnInit(): void {\n    this.interClass$ = this.store.select(AdminClassSelectors.interClass);\n    this.sub.add(this.interClass$.subscribe((c) => (this.interClass = c)));\n    if (this.interClass) {\n      if (this.interClass.attributes.length > 0) {\n        this.attributes$ = of(this.interClass.attributes);\n        this.attributesExtended$ = this.getAttrExtended();\n      }\n    } else {\n      this.route.params.subscribe((params) => {\n        this.selectedClassId = params['id'];\n        this.selectedclass$ = this.store.select(ClassSelectors.classById(this.selectedClassId));\n        this.attributes$ = this.selectedclass$.pipe(map((selectedClass) => selectedClass.attributes));\n        this.attributesExtended$ = this.getAttrExtended();\n      });\n    }\n    this.setClassActions();\n    this.sub.add(\n      this.openModal$.subscribe((open) => {\n        if (open) {\n          this.showModal();\n        } else {\n          this.closeModal();\n        }\n      })\n    );\n  }\n\n  ngOnDestroy(): void {\n    this.sub.unsubscribe();\n  }\n\n  private getAttrExtended() {\n    return combineLatest([this.attributes$, this.fields$, this.categories$]).pipe(\n      filter(([attributes, fields, categories]) => fields.length > 0 && categories.length > 0),\n      map(([attributes, fields, categories]) => {\n        return attributes.map(\n          (attr: Attribute) =>\n            ({\n              ...attr,\n              fieldName: fields.find((field) => field.id === attr.field)?.name || this.i18n.instant('@pry.admin.attributes.unknownField'),\n              categoryName: attr.category ?\n                categories.find((category) => category.id === attr.category)?.name ?? this.i18n.instant('@pry.admin.attributes.unknownCategory')\n                : this.i18n.instant('@pry.admin.attributes.noCategory')\n            }) as AttributeExtended\n        );\n      })\n    );\n  }\n\n  private setClassActions() {\n    this.store.dispatch(AdminActions.resetActions());\n    let actions = [\n      {\n        action: AdminClassActions.back({ path: this.backPath }),\n        label: 'back',\n        icon: 'arrow_back'\n      },\n      {\n        action: AdminActions.routeTo({ path: this.addAttributePath }),\n        label: 'addAttribute',\n        icon: 'add_column',\n        moduleAccess: 'admin',\n        pageAccess: 'classes',\n        actionAccess: 'write'\n      }\n    ] as BaseToolboxAction[];\n\n    if (this.interClass) {\n      actions.push({\n        action: AdminClassActions.openModal(),\n        label: 'addClass',\n        icon: 'add_column',\n        moduleAccess: 'admin',\n        pageAccess: 'classes',\n        actionAccess: 'write'\n      });\n    }\n\n    this.store.dispatch(\n      AdminActions.mainActions({\n        actions: actions\n      })\n    );\n  }\n\n  private setAttributeActions(attrId: string) {\n    this.sub.add(\n      this.selectedAttributeId$.subscribe((attributeId) => {\n        let editPath = this.router.createUrlTree([attributeId, 'edit'], { relativeTo: this.route }).toString();\n\n        this.store.dispatch(\n          AdminActions.mainActions({\n            actions: [\n              {\n                action: AdminClassActions.back({ path: this.backPath }),\n                label: 'back',\n                icon: 'arrow_back'\n              },\n              {\n                action: AdminActions.routeTo({ path: editPath }),\n                label: 'edit',\n                icon: 'edit',\n                moduleAccess: 'admin',\n                pageAccess: 'fields',\n                actionAccess: 'write'\n              },\n              {\n                action: AdminClassActions.confirmAttributeDeletion({\n                  classId: this.selectedClassId,\n                  attrId: attrId,\n                  backPath: this.backPath,\n                  addAttrPath: this.addAttributePath\n                }),\n                label: 'delete',\n                icon: 'delete',\n                moduleAccess: 'admin',\n                pageAccess: 'classes',\n                actionAccess: 'write'\n              }\n            ]\n          })\n        );\n      })\n    );\n  }\n\n  selectAttr(attr: AttributeExtended) {\n    this.store.dispatch(AdminClassActions.selectAttribute({ attrExtended: attr }));\n    this.store.dispatch(AdminActions.selectComponentType({ componentType: 'AdminAttributesSelectComponent' }));\n    this.setAttributeActions(attr.id);\n    this.store.dispatch(AdminActions.fetchAttributeAssociations({ id: attr.id }));\n  }\n\n  dispatchCloseModal() {\n    this.store.dispatch(AdminClassActions.closeModal());\n  }\n\n  showModal() {\n    this.overlayRef = this.overlay.create(\n      new OverlayConfig({\n        hasBackdrop: true,\n        panelClass: ['o-modal-wrapper'],\n        backdropClass: 'backdrop'\n      })\n    );\n    this.store.dispatch(ConfigActions.addingOverlay({ id: this.constructor.name }));\n    this.overlayRef.backdropClick().subscribe((_) => this.closeModal());\n    this.overlayRef.attach(new TemplatePortal(this.confirmationModal, this.viewContainerRef));\n  }\n\n  closeModal() {\n    this.overlayRef?.dispose();\n    this.store.dispatch(ConfigActions.closeOverlay({ id: this.constructor.name }));\n  }\n\n  saveClass() {\n    if (this.interClass) {\n      this.store.dispatch(AdminClassActions.saveClass({ class: this.interClass, route: this.backPath }));\n    }\n    this.dispatchCloseModal();\n  }\n}\n","<ng-container *ngIf=\"(selectedclass$ | async) || (interClass$ | async) as selectedClass\">\n  <div class=\"o-base-container\">\n    <h1 class=\"a-h1\">\n      {{ '@pry.admin.classes.title' | i18n : { class: selectedClass.name } }}\n    </h1>\n    <table\n      class=\"a-table\"\n      prySortTable\n      prySortActive=\"name\"\n      prySortDirection=\"asc\"\n      (prySortChange)=\"sortActive = $event.active; sortDirection = $event.direction\"\n    >\n      <caption>\n        {{\n          '@pry.admin.classes.title' | i18n\n        }},\n        {{\n          '@pry.action.sortableColumnHeader' | i18n\n        }}\n      </caption>\n      <thead>\n        <tr>\n          <th></th>\n          <th prySortHeader=\"technicalName\">{{ '@pry.admin.classes.attributes.technicalName' | i18n }}</th>\n          <th prySortHeader=\"name\">{{ '@pry.admin.classes.attributes.name' | i18n }}</th>\n          <th prySortHeader=\"field\">{{ '@pry.admin.classes.attributes.field' | i18n }}</th>\n          <th prySortHeader=\"category\">{{ '@pry.admin.classes.attributes.category' | i18n }}</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr\n          *ngFor=\"let attr of attributesExtended$ | async | prySortData : sortActive : sortDirection\"\n          (click)=\"selectAttr(attr)\"\n          [class.is-selected]=\"(selectedAttributeId$ | async) === attr.id\"\n        >\n          <td class=\"view-details\">\n            <button\n              [id]=\"'button-attr-' + attr.id\"\n              type=\"button\"\n              class=\"a-btn a-btn--icon-only\"\n              title=\"{{ '@pry.action.viewDetails' | i18n }}\"\n              [attr.aria-expanded]=\"(selectedAttributeId$ | async) === attr.id\"\n              aria-haspopup\n              [attr.aria-controls]=\"'panel-attr-' + attr.id\"\n            >\n              <span class=\"u-visually-hidden\">{{ attr.name }}, {{ '@pry.action.viewDetails' | i18n }}</span>\n              <pry-icon iconSvg=\"eye\" [width]=\"15\" [height]=\"15\"></pry-icon>\n            </button>\n          </td>\n          <td>{{ attr.technicalName }}</td>\n          <td>{{ attr.name }}</td>\n          <td>{{ attr.fieldName }}</td>\n          <td>{{ attr.categoryName }}</td>\n        </tr>\n      </tbody>\n    </table>\n  </div>\n</ng-container>\n\n<ng-template #confirmationModal>\n  <div class=\"o-modal\">\n    <div class=\"o-modal__top\">\n      <div class=\"o-modal__top__title\">\n        <h2 class=\"a-h2\" id=\"dialog_title\">\n          {{ '@pry.admin.classes.createClassConfirmMessage' | i18n }}\n        </h2>\n      </div>\n      <div class=\"o-modal__top__close\">\n        <button class=\"a-btn a-btn--icon-only\" (click)=\"dispatchCloseModal()\">\n          <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n          <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n        </button>\n      </div>\n    </div>\n    <div class=\"m-btn-group\">\n      <button type=\"button\" class=\"a-btn a-btn--primary\" (click)=\"saveClass()\">\n        {{ '@pry.toolbox.manifest.validate' | i18n }}\n      </button>\n      <button type=\"button\" class=\"a-btn a-btn--secondary\" (click)=\"dispatchCloseModal()\">\n        {{ '@pry.toolbox.manifest.close' | i18n }}\n      </button>\n    </div>\n  </div>\n</ng-template>\n"]}