@provoly/dashboard 1.1.10 → 1.1.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/import/components/import.component.mjs +6 -4
- package/esm2022/lib/core/components/modal-status/modal-status.component.mjs +3 -3
- package/esm2022/lib/core/components/share/access-rights-share/access-rights-share.component.mjs +3 -3
- package/esm2022/lib/core/components/share/access-rights-share-modal/access-rights-share-modal.component.mjs +3 -1
- package/esm2022/lib/core/components/translate-item-to-symbol/translate-item-to-symbol.pipe.mjs +8 -12
- package/esm2022/lib/core/i18n/en.translations.mjs +4 -1
- package/esm2022/lib/core/i18n/fr.translations.mjs +4 -1
- package/esm2022/lib/core/store/config/config.selectors.mjs +2 -2
- package/esm2022/lib/core/store/relation-types/relation-types.selectors.mjs +2 -2
- package/esm2022/lib/core/symbol/symbol.service.mjs +4 -4
- package/esm2022/lib/dashboard/store/dashboard.selectors.mjs +2 -2
- package/esm2022/restitution/components/restitution-list/restitution-list.component.mjs +2 -2
- package/esm2022/toolbox/components/filter-settings/filter-settings.component.mjs +3 -4
- package/esm2022/widgets/widget-aggregated-chart/style/css.component.mjs +2 -2
- package/esm2022/widgets/widget-iframe/component/widget-iframe.component.mjs +3 -3
- package/esm2022/widgets/widget-map/component/widget-map-layer.service.mjs +1 -1
- package/esm2022/widgets/widget-map/component/widget-map.component.mjs +7 -6
- package/esm2022/widgets/widget-map/style/css.component.mjs +2 -2
- package/fesm2022/provoly-dashboard-import.mjs +5 -3
- package/fesm2022/provoly-dashboard-import.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-restitution.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-toolbox.mjs +2 -3
- package/fesm2022/provoly-dashboard-toolbox.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-aggregated-chart.mjs +2 -2
- package/fesm2022/provoly-dashboard-widgets-widget-aggregated-chart.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-iframe.mjs +2 -2
- package/fesm2022/provoly-dashboard-widgets-widget-iframe.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-map.mjs +8 -7
- package/fesm2022/provoly-dashboard-widgets-widget-map.mjs.map +1 -1
- package/fesm2022/provoly-dashboard.mjs +23 -17
- package/fesm2022/provoly-dashboard.mjs.map +1 -1
- package/lib/core/components/translate-item-to-symbol/translate-item-to-symbol.pipe.d.ts +1 -7
- package/lib/core/i18n/en.translations.d.ts +3 -0
- package/lib/core/i18n/fr.translations.d.ts +3 -0
- package/package.json +49 -49
- package/styles/abstracts/_mixins.scss +1 -1
- package/styles-theme/abstracts-theme/variables/_variables-typo.scss +5 -5
- package/widgets/widget-aggregated-chart/style/_o-widget-chart.scss +1 -1
- package/widgets/widget-map/style/_m-layer-legend.scss +7 -0
|
@@ -62,11 +62,13 @@ export class PryImportComponent extends SubscriptionnerDirective {
|
|
|
62
62
|
.filter((dataset) => dataset.type === PryDatasetType.CLOSED)
|
|
63
63
|
.sort((a, b) => (a.name.toLowerCase() > b.name.toLowerCase() ? 1 : -1))));
|
|
64
64
|
this.loading$ = store.select(ImportSelectors.loading);
|
|
65
|
-
this.subscriptions.add(this.form
|
|
66
|
-
.
|
|
65
|
+
this.subscriptions.add(this.form
|
|
66
|
+
.get('dataset')
|
|
67
|
+
?.valueChanges.pipe(withLatestFrom(this.store.select(DataSourceSelectors.datasetVersions)))
|
|
67
68
|
.subscribe(([dataset, versions]) => {
|
|
68
69
|
this.clearMessage();
|
|
69
|
-
if (dataset &&
|
|
70
|
+
if (dataset &&
|
|
71
|
+
versions.some((version) => version.dataset === dataset.id && (version.state === 'ACTIVE' || version.state === 'INDEXING'))) {
|
|
70
72
|
this.getLastActiveVersion(dataset);
|
|
71
73
|
}
|
|
72
74
|
else {
|
|
@@ -162,4 +164,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
162
164
|
type: ViewChild,
|
|
163
165
|
args: ['message']
|
|
164
166
|
}] } });
|
|
165
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"import.component.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/import/components/import.component.ts","../../../../../../projects/provoly/dashboard/import/components/import.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, OnDestroy, ViewChild } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport {\n  Dataset,\n  DataSourceActions,\n  DataSourceSelectors,\n  DataSourceService,\n  DateUtils,\n  PryDatasetType,\n  PryI18nService,\n  PrySnackbarService,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { map, Observable, take } from 'rxjs';\nimport { ImportActions } from '../store/import.actions';\nimport { ImportSelectors } from '../store/import.selectors';\nimport { withLatestFrom } from 'rxjs/operators';\nimport { AbstractControl, FormControl, FormGroup, Validators } from '@angular/forms';\n\ntype FileExtension = 'csv' | 'zip';\n\ninterface ImportForm {\n  fileType: FormControl<FileExtension>;\n  file: FormControl<File | null>;\n  dataset: FormControl<Dataset | null>;\n  normalizeGeo: FormControl<boolean>;\n  productionDate: FormControl<string>;\n  producer: FormControl<string>;\n  additionalInformation: FormControl<string | null>;\n}\n\n@Component({\n  selector: 'pry-import',\n  templateUrl: './import.component.html'\n})\nexport class PryImportComponent extends SubscriptionnerDirective implements OnDestroy {\n  datasets$: Observable<Dataset[]>;\n  loading$: Observable<boolean>;\n\n  @ViewChild('message') message!: ElementRef<HTMLDivElement>;\n  showMessage: boolean = false;\n\n  maxDate = DateUtils.formatDate(new Date());\n\n  form = new FormGroup<ImportForm>({\n    fileType: new FormControl('csv', {\n      validators: [Validators.required],\n      nonNullable: true\n    }),\n    file: new FormControl(null, Validators.required),\n    dataset: new FormControl(null, Validators.required),\n    normalizeGeo: new FormControl(false, { nonNullable: true }),\n    productionDate: new FormControl(this.maxDate, {\n      validators: [Validators.required, DateUtils.onlyPastDateValidator],\n      nonNullable: true\n    }),\n    producer: new FormControl('', {\n      validators: [Validators.required],\n      nonNullable: true\n    }),\n    additionalInformation: new FormControl(null)\n  });\n\n  fileTypes: { [key in FileExtension]: { label: string; value: FileExtension; extension: string } } = {\n    csv: {\n      label: 'Csv',\n      value: 'csv',\n      extension: '.csv'\n    },\n    zip: {\n      label: 'Shapefile',\n      value: 'zip',\n      extension: '.zip'\n    }\n  };\n\n  constructor(\n    private store: Store,\n    private dsService: DataSourceService,\n    private snackbar: PrySnackbarService,\n    private i18nService: PryI18nService\n  ) {\n    super();\n    store.dispatch(DataSourceActions.dataset.loadDataset());\n    this.store.dispatch(DataSourceActions.dataset.listVersions());\n    this.datasets$ = store\n      .select(DataSourceSelectors.datasets)\n      .pipe(\n        map((datasets) =>\n          datasets\n            .filter((dataset) => dataset.type === PryDatasetType.CLOSED)\n            .sort((a, b) => (a.name.toLowerCase() > b.name.toLowerCase() ? 1 : -1))\n        )\n      );\n    this.loading$ = store.select(ImportSelectors.loading);\n\n    this.subscriptions.add(\n      this.form.get('dataset')?.valueChanges\n        .pipe(withLatestFrom(this.store.select(DataSourceSelectors.datasetVersions)))\n        .subscribe(([dataset, versions]) => {\n          this.clearMessage();\n          if (dataset && versions.some((version) => version.dataset === dataset.id && version.state === 'ACTIVE')) {\n            this.getLastActiveVersion(dataset);\n          } else {\n            this.form.patchValue({ producer: '', productionDate: DateUtils.formatDate(new Date()) });\n            this.producer.markAsPristine();\n          }\n        })\n    );\n  }\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n    this.clearMessage();\n  }\n\n  get fileType(): AbstractControl<FileExtension> {\n    return this.form.controls['fileType'];\n  }\n\n  get file(): AbstractControl<File | null> {\n    return this.form.controls['file'];\n  }\n\n  get dataset(): AbstractControl<Dataset | null> {\n    return this.form.controls['dataset'];\n  }\n\n  get normalizeGeo(): AbstractControl<boolean> {\n    return this.form.controls['normalizeGeo'];\n  }\n\n  get productionDate(): AbstractControl<string> {\n    return this.form.controls['productionDate'];\n  }\n\n  get producer(): AbstractControl<string> {\n    return this.form.controls['producer'];\n  }\n\n  uploadedChange($event: File): void {\n    if ($event.size > 1024 * 1024 * 1024 * 2) {\n      this.snackbar.open({\n        type: 'error',\n        message: this.i18nService.instant('@pry.import.tooLarge', { current: this.getFileSize($event.size) })\n      });\n    } else {\n      this.form.patchValue({ file: $event });\n    }\n  }\n\n  submit(): void {\n    const { file, dataset, fileType, normalizeGeo, producer, productionDate, additionalInformation } = this.form.value;\n    if (file && dataset && fileType) {\n      this.store.dispatch(\n        ImportActions.upload({\n          file,\n          fileType,\n          normalizeGeo,\n          dataset: dataset.id,\n          datasetVersionInformation: {\n            productionDate: productionDate ? new Date(productionDate).toISOString() : undefined,\n            producer,\n            additionalInformation: !!additionalInformation ? additionalInformation : undefined\n          }\n        })\n      );\n      this.showMessage = true;\n      setTimeout(() => this.message.nativeElement.scrollIntoView({ behavior: 'smooth' }));\n      this.form.patchValue({ file: null });\n    }\n  }\n\n  getFileSize(size: number): string {\n    if (size >= 1024 && size < 1024 * 1024) {\n      return `${(size / 1024).toFixed(1)} KB`;\n    } else if (size >= 1024 * 1024 && size < 1024 * 1024 * 1024) {\n      return `${(size / (1024 * 1024)).toFixed(1)} MB`;\n    } else if (size >= 1024 * 1024 * 1024) {\n      return `${(size / (1024 * 1024 * 1024)).toFixed(1)} GB`;\n    }\n    return `${size} bytes`;\n  }\n\n  getLastActiveVersion(dataset: Dataset): void {\n    this.subscriptions.add(\n      this.dsService\n        .getLastActiveDatasetVersion(dataset.id)\n        .pipe(take(1))\n        .subscribe((version) => {\n          if (version && version.producer) this.form.patchValue({ producer: version.producer });\n        })\n    );\n  }\n\n  clearMessage(): void {\n    if (this.showMessage) this.showMessage = false;\n  }\n\n  protected readonly Object = Object;\n  protected readonly PryDatasetType = PryDatasetType;\n}\n","<pry-import-css></pry-import-css>\n<div class=\"o-import\">\n  <h1 class=\"a-h1\">{{ '@pry.import.title' | i18n }}</h1>\n  <div class=\"u-display-flex\">\n    <form class=\"o-import__form\" [formGroup]=\"form\" (ngSubmit)=\"submit()\">\n      <div class=\"m-form-label-field\">\n        <label class=\"a-h3\" for=\"datasets\">{{ '@pry.import.fileType' | i18n }}</label>\n        <pry-select\n          formControlName=\"fileType\"\n          id=\"fileType\"\n          [items]=\"Object.values(fileTypes)\"\n          bindValue=\"value\"\n          bindLabel=\"label\"\n        ></pry-select>\n      </div>\n      <div class=\"m-form-label-field\">\n        <label class=\"a-h3\" for=\"upload_input\">\n          {{ '@pry.import.uploadTitle' + fileType.value | i18n }}\n        </label>\n        <p>{{ '@pry.import.warning' | i18n }}</p>\n        <div class=\"o-file-input\">\n          @if (file.value?.size) {\n            <div class=\"o-import__file\">\n              <pry-icon iconSvg=\"download\"></pry-icon>\n              <h3>{{ file.value?.name }}</h3>\n              <span>{{ getFileSize(file.value?.size ?? 0) }}</span>\n            </div>\n          }\n          <pry-upload\n            id=\"upload_input\"\n            [accept]=\"fileTypes[fileType.value].extension\"\n            mode=\"files\"\n            (uploadedFile)=\"uploadedChange($event)\"\n            labelTranslate=\"@pry.import.selectFile\"\n          ></pry-upload>\n        </div>\n      </div>\n      <div class=\"m-form-label-field\">\n        <label class=\"a-h3\" for=\"datasets\">{{ '@pry.import.datasetImport' | i18n }}</label>\n        <pry-select\n          formControlName=\"dataset\"\n          id=\"datasets\"\n          [items]=\"datasets$ | async\"\n          [placeholder]=\"'@pry.import.dataset' | i18n\"\n          bindLabel=\"name\"\n          [autocomplete]=\"true\"\n        ></pry-select>\n      </div>\n      <div class=\"m-form-label-field\">\n        <pry-checkbox formControlName=\"normalizeGeo\">{{ '@pry.import.normalize' | i18n }}</pry-checkbox>\n      </div>\n      <div class=\"m-form-label-field\">\n        <label class=\"a-h3\">{{ '@pry.dataset.version.productionDate' | i18n }}</label>\n        <input\n          formControlName=\"productionDate\"\n          id=\"productionDate\"\n          class=\"a-form-field\"\n          type=\"datetime-local\"\n          [max]=\"maxDate\"\n          [attr.aria-invalid]=\"productionDate.invalid\"\n        />\n        @if (productionDate.invalid) {\n          <label id=\"productionDate-error\" for=\"productionDate\" class=\"a-label a-label--help -error\">\n            @if (productionDate.errors?.['required']) {\n              <span>{{ '@pry.dataset.form.obligatory' | i18n }}</span>\n            } @else if (productionDate.errors?.['dateValidator']) {\n              <span>{{ '@pry.dataset.form.date' | i18n }}</span>\n            }\n          </label>\n        }\n      </div>\n      <div class=\"m-form-label-field\">\n        <label class=\"a-h3\">{{ '@pry.dataset.version.producer' | i18n }}</label>\n        <input formControlName=\"producer\" id=\"producer\" class=\"a-form-field\" type=\"text\" maxlength=\"100\" />\n        @if (producer.touched && producer.invalid) {\n          <label id=\"producer-error\" for=\"producer\" class=\"a-label a-label--help -error\">\n            @if (producer.errors?.['required']) {\n              <span>{{ '@pry.dataset.form.obligatory' | i18n }}</span>\n            }\n          </label>\n        }\n      </div>\n      <div class=\"m-form-label-field\">\n        <label class=\"a-h3\">{{ '@pry.dataset.version.additionalInformation' | i18n }}</label>\n        <pry-text-editor formControlName=\"additionalInformation\"></pry-text-editor>\n      </div>\n      <div class=\"o-import__actions u-display-flex -justify-center\">\n        <button class=\"a-btn a-btn--primary\" [disabled]=\"form.invalid\">\n          {{ '@pry.import.import' | i18n }}\n        </button>\n      </div>\n    </form>\n    <div class=\"o-import__message\" [class.u-visually-hidden]=\"!showMessage\" #message>\n      <span>\n        {{ '@pry.import.consultDataset1' | i18n }}\n        <strong>{{ dataset.value?.id ?? '' | translateId: { type: 'datasource', output: 'name' } | async }}</strong>\n        {{ '@pry.import.consultDataset2' | i18n }}\n      </span>\n    </div>\n  </div>\n</div>\n"]}
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"import.component.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/import/components/import.component.ts","../../../../../../projects/provoly/dashboard/import/components/import.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, OnDestroy, ViewChild } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport {\n  Dataset,\n  DataSourceActions,\n  DataSourceSelectors,\n  DataSourceService,\n  DateUtils,\n  PryDatasetType,\n  PryI18nService,\n  PrySnackbarService,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { map, Observable, take } from 'rxjs';\nimport { ImportActions } from '../store/import.actions';\nimport { ImportSelectors } from '../store/import.selectors';\nimport { withLatestFrom } from 'rxjs/operators';\nimport { AbstractControl, FormControl, FormGroup, Validators } from '@angular/forms';\n\ntype FileExtension = 'csv' | 'zip';\n\ninterface ImportForm {\n  fileType: FormControl<FileExtension>;\n  file: FormControl<File | null>;\n  dataset: FormControl<Dataset | null>;\n  normalizeGeo: FormControl<boolean>;\n  productionDate: FormControl<string>;\n  producer: FormControl<string>;\n  additionalInformation: FormControl<string | null>;\n}\n\n@Component({\n  selector: 'pry-import',\n  templateUrl: './import.component.html'\n})\nexport class PryImportComponent extends SubscriptionnerDirective implements OnDestroy {\n  datasets$: Observable<Dataset[]>;\n  loading$: Observable<boolean>;\n\n  @ViewChild('message') message!: ElementRef<HTMLDivElement>;\n  showMessage: boolean = false;\n\n  maxDate = DateUtils.formatDate(new Date());\n\n  form = new FormGroup<ImportForm>({\n    fileType: new FormControl('csv', {\n      validators: [Validators.required],\n      nonNullable: true\n    }),\n    file: new FormControl(null, Validators.required),\n    dataset: new FormControl(null, Validators.required),\n    normalizeGeo: new FormControl(false, { nonNullable: true }),\n    productionDate: new FormControl(this.maxDate, {\n      validators: [Validators.required, DateUtils.onlyPastDateValidator],\n      nonNullable: true\n    }),\n    producer: new FormControl('', {\n      validators: [Validators.required],\n      nonNullable: true\n    }),\n    additionalInformation: new FormControl(null)\n  });\n\n  fileTypes: { [key in FileExtension]: { label: string; value: FileExtension; extension: string } } = {\n    csv: {\n      label: 'Csv',\n      value: 'csv',\n      extension: '.csv'\n    },\n    zip: {\n      label: 'Shapefile',\n      value: 'zip',\n      extension: '.zip'\n    }\n  };\n\n  constructor(\n    private store: Store,\n    private dsService: DataSourceService,\n    private snackbar: PrySnackbarService,\n    private i18nService: PryI18nService\n  ) {\n    super();\n    store.dispatch(DataSourceActions.dataset.loadDataset());\n    this.store.dispatch(DataSourceActions.dataset.listVersions());\n    this.datasets$ = store\n      .select(DataSourceSelectors.datasets)\n      .pipe(\n        map((datasets) =>\n          datasets\n            .filter((dataset) => dataset.type === PryDatasetType.CLOSED)\n            .sort((a, b) => (a.name.toLowerCase() > b.name.toLowerCase() ? 1 : -1))\n        )\n      );\n    this.loading$ = store.select(ImportSelectors.loading);\n\n    this.subscriptions.add(\n      this.form\n        .get('dataset')\n        ?.valueChanges.pipe(withLatestFrom(this.store.select(DataSourceSelectors.datasetVersions)))\n        .subscribe(([dataset, versions]) => {\n          this.clearMessage();\n          if (\n            dataset &&\n            versions.some(\n              (version) =>\n                version.dataset === dataset.id && (version.state === 'ACTIVE' || version.state === 'INDEXING')\n            )\n          ) {\n            this.getLastActiveVersion(dataset);\n          } else {\n            this.form.patchValue({ producer: '', productionDate: DateUtils.formatDate(new Date()) });\n            this.producer.markAsPristine();\n          }\n        })\n    );\n  }\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n    this.clearMessage();\n  }\n\n  get fileType(): AbstractControl<FileExtension> {\n    return this.form.controls['fileType'];\n  }\n\n  get file(): AbstractControl<File | null> {\n    return this.form.controls['file'];\n  }\n\n  get dataset(): AbstractControl<Dataset | null> {\n    return this.form.controls['dataset'];\n  }\n\n  get normalizeGeo(): AbstractControl<boolean> {\n    return this.form.controls['normalizeGeo'];\n  }\n\n  get productionDate(): AbstractControl<string> {\n    return this.form.controls['productionDate'];\n  }\n\n  get producer(): AbstractControl<string> {\n    return this.form.controls['producer'];\n  }\n\n  uploadedChange($event: File): void {\n    if ($event.size > 1024 * 1024 * 1024 * 2) {\n      this.snackbar.open({\n        type: 'error',\n        message: this.i18nService.instant('@pry.import.tooLarge', { current: this.getFileSize($event.size) })\n      });\n    } else {\n      this.form.patchValue({ file: $event });\n    }\n  }\n\n  submit(): void {\n    const { file, dataset, fileType, normalizeGeo, producer, productionDate, additionalInformation } = this.form.value;\n    if (file && dataset && fileType) {\n      this.store.dispatch(\n        ImportActions.upload({\n          file,\n          fileType,\n          normalizeGeo,\n          dataset: dataset.id,\n          datasetVersionInformation: {\n            productionDate: productionDate ? new Date(productionDate).toISOString() : undefined,\n            producer,\n            additionalInformation: !!additionalInformation ? additionalInformation : undefined\n          }\n        })\n      );\n      this.showMessage = true;\n      setTimeout(() => this.message.nativeElement.scrollIntoView({ behavior: 'smooth' }));\n      this.form.patchValue({ file: null });\n    }\n  }\n\n  getFileSize(size: number): string {\n    if (size >= 1024 && size < 1024 * 1024) {\n      return `${(size / 1024).toFixed(1)} KB`;\n    } else if (size >= 1024 * 1024 && size < 1024 * 1024 * 1024) {\n      return `${(size / (1024 * 1024)).toFixed(1)} MB`;\n    } else if (size >= 1024 * 1024 * 1024) {\n      return `${(size / (1024 * 1024 * 1024)).toFixed(1)} GB`;\n    }\n    return `${size} bytes`;\n  }\n\n  getLastActiveVersion(dataset: Dataset): void {\n    this.subscriptions.add(\n      this.dsService\n        .getLastActiveDatasetVersion(dataset.id)\n        .pipe(take(1))\n        .subscribe((version) => {\n          if (version && version.producer) this.form.patchValue({ producer: version.producer });\n        })\n    );\n  }\n\n  clearMessage(): void {\n    if (this.showMessage) this.showMessage = false;\n  }\n\n  protected readonly Object = Object;\n  protected readonly PryDatasetType = PryDatasetType;\n}\n","<pry-import-css></pry-import-css>\n<div class=\"o-import\">\n  <h1 class=\"a-h1\">{{ '@pry.import.title' | i18n }}</h1>\n  <div class=\"u-display-flex\">\n    <form class=\"o-import__form\" [formGroup]=\"form\" (ngSubmit)=\"submit()\">\n      <div class=\"m-form-label-field\">\n        <label class=\"a-h3\" for=\"datasets\">{{ '@pry.import.fileType' | i18n }}</label>\n        <pry-select\n          formControlName=\"fileType\"\n          id=\"fileType\"\n          [items]=\"Object.values(fileTypes)\"\n          bindValue=\"value\"\n          bindLabel=\"label\"\n        ></pry-select>\n      </div>\n      <div class=\"m-form-label-field\">\n        <label class=\"a-h3\" for=\"upload_input\">\n          {{ '@pry.import.uploadTitle' + fileType.value | i18n }}\n        </label>\n        <p>{{ '@pry.import.warning' | i18n }}</p>\n        <div class=\"o-file-input\">\n          @if (file.value?.size) {\n            <div class=\"o-import__file\">\n              <pry-icon iconSvg=\"download\"></pry-icon>\n              <h3>{{ file.value?.name }}</h3>\n              <span>{{ getFileSize(file.value?.size ?? 0) }}</span>\n            </div>\n          }\n          <pry-upload\n            id=\"upload_input\"\n            [accept]=\"fileTypes[fileType.value].extension\"\n            mode=\"files\"\n            (uploadedFile)=\"uploadedChange($event)\"\n            labelTranslate=\"@pry.import.selectFile\"\n          ></pry-upload>\n        </div>\n      </div>\n      <div class=\"m-form-label-field\">\n        <label class=\"a-h3\" for=\"datasets\">{{ '@pry.import.datasetImport' | i18n }}</label>\n        <pry-select\n          formControlName=\"dataset\"\n          id=\"datasets\"\n          [items]=\"datasets$ | async\"\n          [placeholder]=\"'@pry.import.dataset' | i18n\"\n          bindLabel=\"name\"\n          [autocomplete]=\"true\"\n        ></pry-select>\n      </div>\n      <div class=\"m-form-label-field\">\n        <pry-checkbox formControlName=\"normalizeGeo\">{{ '@pry.import.normalize' | i18n }}</pry-checkbox>\n      </div>\n      <div class=\"m-form-label-field\">\n        <label class=\"a-h3\">{{ '@pry.dataset.version.productionDate' | i18n }}</label>\n        <input\n          formControlName=\"productionDate\"\n          id=\"productionDate\"\n          class=\"a-form-field\"\n          type=\"datetime-local\"\n          [max]=\"maxDate\"\n          [attr.aria-invalid]=\"productionDate.invalid\"\n        />\n        @if (productionDate.invalid) {\n          <label id=\"productionDate-error\" for=\"productionDate\" class=\"a-label a-label--help -error\">\n            @if (productionDate.errors?.['required']) {\n              <span>{{ '@pry.dataset.form.obligatory' | i18n }}</span>\n            } @else if (productionDate.errors?.['dateValidator']) {\n              <span>{{ '@pry.dataset.form.date' | i18n }}</span>\n            }\n          </label>\n        }\n      </div>\n      <div class=\"m-form-label-field\">\n        <label class=\"a-h3\">{{ '@pry.dataset.version.producer' | i18n }}</label>\n        <input formControlName=\"producer\" id=\"producer\" class=\"a-form-field\" type=\"text\" maxlength=\"100\" />\n        @if (producer.touched && producer.invalid) {\n          <label id=\"producer-error\" for=\"producer\" class=\"a-label a-label--help -error\">\n            @if (producer.errors?.['required']) {\n              <span>{{ '@pry.dataset.form.obligatory' | i18n }}</span>\n            }\n          </label>\n        }\n      </div>\n      <div class=\"m-form-label-field\">\n        <label class=\"a-h3\">{{ '@pry.dataset.version.additionalInformation' | i18n }}</label>\n        <pry-text-editor formControlName=\"additionalInformation\"></pry-text-editor>\n      </div>\n      <div class=\"o-import__actions u-display-flex -justify-center\">\n        <button class=\"a-btn a-btn--primary\" [disabled]=\"form.invalid\">\n          {{ '@pry.import.import' | i18n }}\n        </button>\n      </div>\n    </form>\n    <div class=\"o-import__message\" [class.u-visually-hidden]=\"!showMessage\" #message>\n      <span>\n        {{ '@pry.import.consultDataset1' | i18n }}\n        <strong>{{ dataset.value?.id ?? '' | translateId: { type: 'datasource', output: 'name' } | async }}</strong>\n        {{ '@pry.import.consultDataset2' | i18n }}\n      </span>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -32,14 +32,14 @@ export class PryModalStatusComponent {
|
|
|
32
32
|
this.gotoConsult.emit(this.version);
|
|
33
33
|
}
|
|
34
34
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: PryModalStatusComponent, deps: [{ token: i1.Store }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
35
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: PryModalStatusComponent, selector: "pry-modal-status", inputs: { version: "version" }, outputs: { gotoConsult: "gotoConsult" }, ngImport: i0, template: "<div class=\"o-modal-wrapper__backdrop\" (click)=\"goBack()\">\n <div class=\"o-modal-wrapper -extra-large\">\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\">\n {{\n '@pry.dataset.error.modalTitle.' +\n (_version?.state !== 'ERROR' && _version?.hasWarnings ? 'WARNING' : 'ERROR') | i18n\n }}\n ({{ messageCount$ | async }})\n </h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"goBack()\">\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 <table class=\"a-table\">\n <thead>\n <tr>\n <th>{{ '@pry.dataset.error.type' | i18n }}</th>\n <th>{{ '@pry.dataset.error.elements' | i18n }}</th>\n <th>{{ '@pry.dataset.error.message' | i18n }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let preview of datasetPreviews$ | async | slice : 0 : 5\">\n <td>\n {{ '@pry.dataset.error.level.' + preview.level | i18n }}\n </td>\n <td>\n {{ preview.recordId }}\n </td>\n <td>\n {{\n '@pry.dataset.error.code.' + preview.extractMessageCode\n | i18n\n : { plural: preview.name.includes(',') ? 's' : '', name: preview.name, recordId: preview.recordId }\n }}\n </td>\n </tr>\n </tbody>\n </table>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i3.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.SlicePipe, name: "slice" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
|
|
35
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: PryModalStatusComponent, selector: "pry-modal-status", inputs: { version: "version" }, outputs: { gotoConsult: "gotoConsult" }, ngImport: i0, template: "<div class=\"o-modal-wrapper__backdrop\" (click)=\"goBack()\">\n <div class=\"o-modal-wrapper -extra-large\">\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\">\n {{\n '@pry.dataset.error.modalTitle.' +\n (_version?.state !== 'ERROR' && _version?.hasWarnings ? 'WARNING' : 'ERROR') | i18n\n }}\n ({{ messageCount$ | async }})\n </h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"goBack()\">\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 <table class=\"a-table\" [attr.aria-describedby]=\"'@pry.a11y.modalStatusTableDescr' | i18n\">\n <thead>\n <tr>\n <th>{{ '@pry.dataset.error.type' | i18n }}</th>\n <th>{{ '@pry.dataset.error.elements' | i18n }}</th>\n <th>{{ '@pry.dataset.error.message' | i18n }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let preview of datasetPreviews$ | async | slice : 0 : 5\">\n <td>\n {{ '@pry.dataset.error.level.' + preview.level | i18n }}\n </td>\n <td>\n {{ preview.recordId }}\n </td>\n <td>\n {{\n '@pry.dataset.error.code.' + preview.extractMessageCode\n | i18n\n : { plural: preview.name.includes(',') ? 's' : '', name: preview.name, recordId: preview.recordId }\n }}\n </td>\n </tr>\n </tbody>\n </table>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i3.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.SlicePipe, name: "slice" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
|
|
36
36
|
}
|
|
37
37
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: PryModalStatusComponent, decorators: [{
|
|
38
38
|
type: Component,
|
|
39
|
-
args: [{ selector: 'pry-modal-status', template: "<div class=\"o-modal-wrapper__backdrop\" (click)=\"goBack()\">\n <div class=\"o-modal-wrapper -extra-large\">\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\">\n {{\n '@pry.dataset.error.modalTitle.' +\n (_version?.state !== 'ERROR' && _version?.hasWarnings ? 'WARNING' : 'ERROR') | i18n\n }}\n ({{ messageCount$ | async }})\n </h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"goBack()\">\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 <table class=\"a-table\">\n <thead>\n <tr>\n <th>{{ '@pry.dataset.error.type' | i18n }}</th>\n <th>{{ '@pry.dataset.error.elements' | i18n }}</th>\n <th>{{ '@pry.dataset.error.message' | i18n }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let preview of datasetPreviews$ | async | slice : 0 : 5\">\n <td>\n {{ '@pry.dataset.error.level.' + preview.level | i18n }}\n </td>\n <td>\n {{ preview.recordId }}\n </td>\n <td>\n {{\n '@pry.dataset.error.code.' + preview.extractMessageCode\n | i18n\n : { plural: preview.name.includes(',') ? 's' : '', name: preview.name, recordId: preview.recordId }\n }}\n </td>\n </tr>\n </tbody>\n </table>\n </div>\n</div>\n" }]
|
|
39
|
+
args: [{ selector: 'pry-modal-status', template: "<div class=\"o-modal-wrapper__backdrop\" (click)=\"goBack()\">\n <div class=\"o-modal-wrapper -extra-large\">\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\">\n {{\n '@pry.dataset.error.modalTitle.' +\n (_version?.state !== 'ERROR' && _version?.hasWarnings ? 'WARNING' : 'ERROR') | i18n\n }}\n ({{ messageCount$ | async }})\n </h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"goBack()\">\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 <table class=\"a-table\" [attr.aria-describedby]=\"'@pry.a11y.modalStatusTableDescr' | i18n\">\n <thead>\n <tr>\n <th>{{ '@pry.dataset.error.type' | i18n }}</th>\n <th>{{ '@pry.dataset.error.elements' | i18n }}</th>\n <th>{{ '@pry.dataset.error.message' | i18n }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let preview of datasetPreviews$ | async | slice : 0 : 5\">\n <td>\n {{ '@pry.dataset.error.level.' + preview.level | i18n }}\n </td>\n <td>\n {{ preview.recordId }}\n </td>\n <td>\n {{\n '@pry.dataset.error.code.' + preview.extractMessageCode\n | i18n\n : { plural: preview.name.includes(',') ? 's' : '', name: preview.name, recordId: preview.recordId }\n }}\n </td>\n </tr>\n </tbody>\n </table>\n </div>\n</div>\n" }]
|
|
40
40
|
}], ctorParameters: () => [{ type: i1.Store }], propDecorators: { gotoConsult: [{
|
|
41
41
|
type: Output
|
|
42
42
|
}], version: [{
|
|
43
43
|
type: Input
|
|
44
44
|
}] } });
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtc3RhdHVzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL2xpYi9jb3JlL2NvbXBvbmVudHMvbW9kYWwtc3RhdHVzL21vZGFsLXN0YXR1cy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2Rhc2hib2FyZC9saWIvY29yZS9jb21wb25lbnRzL21vZGFsLXN0YXR1cy9tb2RhbC1zdGF0dXMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2RSxPQUFPLEVBQUUsR0FBRyxFQUFjLE1BQU0sTUFBTSxDQUFDO0FBQ3ZDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDZDQUE2QyxDQUFDO0FBRWhGLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLCtDQUErQyxDQUFDOzs7Ozs7QUFNcEYsTUFBTSxPQUFPLHVCQUF1QjtJQWVsQyxJQUFhLE9BQU8sQ0FBQyxPQUFtQztRQUN0RCxJQUFJLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQztRQUN4QixJQUFJLENBQUMsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNkLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLGlCQUFpQixDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLEVBQUUsRUFBRSxFQUFFLE9BQU8sQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDcEYsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLG1CQUFtQixDQUFDLGVBQWUsQ0FBQyxDQUFDLElBQUksQ0FDakYsR0FBRyxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FDZixRQUFRO2lCQUNMLEdBQUcsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQztpQkFDbEMsSUFBSSxFQUFFO2lCQUNOLEdBQUcsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQztnQkFDakIsR0FBRyxPQUFPO2dCQUNWLElBQUksRUFBRSxDQUFDLE9BQU8sQ0FBQyxJQUFJLElBQUksRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUM7YUFDakQsQ0FBQyxDQUFDLENBQ04sQ0FDRixDQUFDO1lBQ0YsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxlQUFlLENBQUMsQ0FBQyxJQUFJLENBQzlFLEdBQUcsQ0FBQyxDQUFDLFFBQVEsRUFBRSxFQUFFO2dCQUNmLE9BQU8sUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDN0UsQ0FBQyxDQUFDLENBQ0gsQ0FBQztRQUNKLENBQUM7SUFDSCxDQUFDO0lBRUQsWUFBb0IsS0FBWTtRQUFaLFVBQUssR0FBTCxLQUFLLENBQU87UUFyQ3RCLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQWtCLENBQUM7SUFxQ3hCLENBQUM7SUFFcEMsTUFBTTtRQUNKLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUN0QyxDQUFDOzhHQTFDVSx1QkFBdUI7a0dBQXZCLHVCQUF1QixpSUNYcEMsbXREQStDQTs7MkZEcENhLHVCQUF1QjtrQkFKbkMsU0FBUzsrQkFDRSxrQkFBa0I7MEVBSWxCLFdBQVc7c0JBQXBCLE1BQU07Z0JBY00sT0FBTztzQkFBbkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTdG9yZSB9IGZyb20gJ0BuZ3J4L3N0b3JlJztcbmltcG9ydCB7IG1hcCwgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRGF0YVNvdXJjZUFjdGlvbnMgfSBmcm9tICcuLi8uLi9zdG9yZS9kYXRhLXNvdXJjZS9kYXRhLXNvdXJjZS5hY3Rpb25zJztcbmltcG9ydCB7IERhdGFzZXRWZXJzaW9uIH0gZnJvbSAnLi4vLi4vc3RvcmUvZGF0YS1zb3VyY2UvZGF0YS1zb3VyY2UubW9kZWwnO1xuaW1wb3J0IHsgRGF0YVNvdXJjZVNlbGVjdG9ycyB9IGZyb20gJy4uLy4uL3N0b3JlL2RhdGEtc291cmNlL2RhdGEtc291cmNlLnNlbGVjdG9ycyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ByeS1tb2RhbC1zdGF0dXMnLFxuICB0ZW1wbGF0ZVVybDogJ21vZGFsLXN0YXR1cy5jb21wb25lbnQuaHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgUHJ5TW9kYWxTdGF0dXNDb21wb25lbnQge1xuICBAT3V0cHV0KCkgZ290b0NvbnN1bHQgPSBuZXcgRXZlbnRFbWl0dGVyPERhdGFzZXRWZXJzaW9uPigpO1xuICBkYXRhc2V0UHJldmlld3MkPzogT2JzZXJ2YWJsZTxcbiAgICB7XG4gICAgICBkYXRhc2V0VmVyc2lvbklkOiBzdHJpbmc7XG4gICAgICBleHRyYWN0TWVzc2FnZUNvZGU6IHN0cmluZztcbiAgICAgIGxldmVsOiAnRVJST1InIHwgJ1dBUk5JTkcnO1xuICAgICAgbmFtZTogc3RyaW5nO1xuICAgICAgcmVjb3JkSWQ6IHN0cmluZztcbiAgICAgIHR5cGU6IHN0cmluZztcbiAgICB9W11cbiAgPjtcbiAgbWVzc2FnZUNvdW50JD86IE9ic2VydmFibGU8bnVtYmVyPjtcbiAgX3ZlcnNpb24/OiBEYXRhc2V0VmVyc2lvbjtcblxuICBASW5wdXQoKSBzZXQgdmVyc2lvbih2ZXJzaW9uOiBEYXRhc2V0VmVyc2lvbiB8IHVuZGVmaW5lZCkge1xuICAgIHRoaXMuX3ZlcnNpb24gPSB2ZXJzaW9uO1xuICAgIGlmICghIXZlcnNpb24pIHtcbiAgICAgIHRoaXMuc3RvcmUuZGlzcGF0Y2goRGF0YVNvdXJjZUFjdGlvbnMuZGF0YXNldC5wcmV2aWV3cy5nZXRCeUlkKHsgaWQ6IHZlcnNpb24uaWQgfSkpO1xuICAgICAgdGhpcy5kYXRhc2V0UHJldmlld3MkID0gdGhpcy5zdG9yZS5zZWxlY3QoRGF0YVNvdXJjZVNlbGVjdG9ycy5kYXRhc2V0UHJldmlld3MpLnBpcGUoXG4gICAgICAgIG1hcCgocHJldmlld3MpID0+XG4gICAgICAgICAgcHJldmlld3NcbiAgICAgICAgICAgIC5tYXAoKHByZXZpZXcpID0+IHByZXZpZXcubWVzc2FnZXMpXG4gICAgICAgICAgICAuZmxhdCgpXG4gICAgICAgICAgICAubWFwKChwcmV2aWV3KSA9PiAoe1xuICAgICAgICAgICAgICAuLi5wcmV2aWV3LFxuICAgICAgICAgICAgICBuYW1lOiAocHJldmlldy5uYW1lID8/ICcnKS5zcGxpdCgnLCcpLmpvaW4oJywgJylcbiAgICAgICAgICAgIH0pKVxuICAgICAgICApXG4gICAgICApO1xuICAgICAgdGhpcy5tZXNzYWdlQ291bnQkID0gdGhpcy5zdG9yZS5zZWxlY3QoRGF0YVNvdXJjZVNlbGVjdG9ycy5kYXRhc2V0UHJldmlld3MpLnBpcGUoXG4gICAgICAgIG1hcCgocHJldmlld3MpID0+IHtcbiAgICAgICAgICByZXR1cm4gcHJldmlld3MubWFwKChwcmV2aWV3KSA9PiBwcmV2aWV3LmNvdW50KS5yZWR1Y2UoKHAsIGMpID0+IHAgKyBjLCAwKTtcbiAgICAgICAgfSlcbiAgICAgICk7XG4gICAgfVxuICB9XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzdG9yZTogU3RvcmUpIHt9XG5cbiAgZ29CYWNrKCkge1xuICAgIHRoaXMuZ290b0NvbnN1bHQuZW1pdCh0aGlzLnZlcnNpb24pO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiby1tb2RhbC13cmFwcGVyX19iYWNrZHJvcFwiIChjbGljayk9XCJnb0JhY2soKVwiPlxuICA8ZGl2IGNsYXNzPVwiby1tb2RhbC13cmFwcGVyIC1leHRyYS1sYXJnZVwiPlxuICAgIDxkaXYgY2xhc3M9XCJvLW1vZGFsX190b3BcIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJvLW1vZGFsX190b3BfX3RpdGxlXCI+XG4gICAgICAgIDxoMiBjbGFzcz1cImEtaDJcIj5cbiAgICAgICAgICB7e1xuICAgICAgICAgICAgJ0BwcnkuZGF0YXNldC5lcnJvci5tb2RhbFRpdGxlLicgK1xuICAgICAgICAgICAgICAoX3ZlcnNpb24/LnN0YXRlICE9PSAnRVJST1InICYmIF92ZXJzaW9uPy5oYXNXYXJuaW5ncyA/ICdXQVJOSU5HJyA6ICdFUlJPUicpIHwgaTE4blxuICAgICAgICAgIH19XG4gICAgICAgICAgKHt7IG1lc3NhZ2VDb3VudCQgfCBhc3luYyB9fSlcbiAgICAgICAgPC9oMj5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cIm8tbW9kYWxfX3RvcF9fY2xvc2VcIj5cbiAgICAgICAgPGJ1dHRvbiBjbGFzcz1cImEtYnRuIGEtYnRuLS1pY29uLW9ubHlcIiAoY2xpY2spPVwiZ29CYWNrKClcIj5cbiAgICAgICAgICA8cHJ5LWljb24gaWNvblN2Zz1cImNsb3NlXCIgW2hlaWdodF09XCIzNVwiIFt3aWR0aF09XCIzNVwiPjwvcHJ5LWljb24+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJ1LXZpc3VhbGx5LWhpZGRlblwiPnt7ICdAcHJ5LnRvb2xib3guY2xvc2UnIHwgaTE4biB9fTwvc3Bhbj5cbiAgICAgICAgPC9idXR0b24+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8dGFibGUgY2xhc3M9XCJhLXRhYmxlXCIgW2F0dHIuYXJpYS1kZXNjcmliZWRieV09XCInQHByeS5hMTF5Lm1vZGFsU3RhdHVzVGFibGVEZXNjcicgfCBpMThuXCI+XG4gICAgICA8dGhlYWQ+XG4gICAgICAgIDx0cj5cbiAgICAgICAgICA8dGg+e3sgJ0BwcnkuZGF0YXNldC5lcnJvci50eXBlJyB8IGkxOG4gfX08L3RoPlxuICAgICAgICAgIDx0aD57eyAnQHByeS5kYXRhc2V0LmVycm9yLmVsZW1lbnRzJyB8IGkxOG4gfX08L3RoPlxuICAgICAgICAgIDx0aD57eyAnQHByeS5kYXRhc2V0LmVycm9yLm1lc3NhZ2UnIHwgaTE4biB9fTwvdGg+XG4gICAgICAgIDwvdHI+XG4gICAgICA8L3RoZWFkPlxuICAgICAgPHRib2R5PlxuICAgICAgICA8dHIgKm5nRm9yPVwibGV0IHByZXZpZXcgb2YgZGF0YXNldFByZXZpZXdzJCB8IGFzeW5jIHwgc2xpY2UgOiAwIDogNVwiPlxuICAgICAgICAgIDx0ZD5cbiAgICAgICAgICAgIHt7ICdAcHJ5LmRhdGFzZXQuZXJyb3IubGV2ZWwuJyArIHByZXZpZXcubGV2ZWwgfCBpMThuIH19XG4gICAgICAgICAgPC90ZD5cbiAgICAgICAgICA8dGQ+XG4gICAgICAgICAgICB7eyBwcmV2aWV3LnJlY29yZElkIH19XG4gICAgICAgICAgPC90ZD5cbiAgICAgICAgICA8dGQ+XG4gICAgICAgICAgICB7e1xuICAgICAgICAgICAgICAnQHByeS5kYXRhc2V0LmVycm9yLmNvZGUuJyArIHByZXZpZXcuZXh0cmFjdE1lc3NhZ2VDb2RlXG4gICAgICAgICAgICAgICAgfCBpMThuXG4gICAgICAgICAgICAgICAgICA6IHsgcGx1cmFsOiBwcmV2aWV3Lm5hbWUuaW5jbHVkZXMoJywnKSA/ICdzJyA6ICcnLCBuYW1lOiBwcmV2aWV3Lm5hbWUsIHJlY29yZElkOiBwcmV2aWV3LnJlY29yZElkIH1cbiAgICAgICAgICAgIH19XG4gICAgICAgICAgPC90ZD5cbiAgICAgICAgPC90cj5cbiAgICAgIDwvdGJvZHk+XG4gICAgPC90YWJsZT5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
package/esm2022/lib/core/components/share/access-rights-share/access-rights-share.component.mjs
CHANGED
|
@@ -126,7 +126,7 @@ export class PryAccessRightsShareComponent extends SubscriptionnerDirective {
|
|
|
126
126
|
useExisting: forwardRef(() => PryAccessRightsShareComponent),
|
|
127
127
|
multi: true
|
|
128
128
|
}
|
|
129
|
-
], usesInheritance: true, ngImport: i0, template: "<div class=\"o-access-rights-share\">\n <label for=\"share-group-select\" class=\"a-h4\">{{ '@pry.share.dashboardAccess' | i18n }}</label>\n <form class=\"u-display-flex\">\n <fieldset class=\"m-grouped-select u-display-flex\" name=\"add-access-rights\">\n <pry-select\n id=\"share-group-select\"\n class=\"o-access-rights-share__group-select\"\n name=\"share-group-select\"\n [(ngModel)]=\"selectedGroups\"\n (ngModelChange)=\"filterAvailableAccessRights()\"\n [items]=\"groups$ | async\"\n bindLabel=\"label\"\n placeholder=\"{{ ((groups$ | async)?.length === 0 ? '@pry.share.noGroups' : '@pry.share.placeholder') | i18n }}\"\n [multiple]=\"true\"\n [closeOnSelect]=\"false\"\n ></pry-select>\n <pry-select\n id=\"share-access-rights-select\"\n class=\"o-access-rights-share__access-rights-select\"\n name=\"share-access-rights-select\"\n [(ngModel)]=\"selectedAccessRight\"\n [items]=\"accessRights\"\n bindValue=\"value\"\n bindLabel=\"label\"\n ></pry-select>\n </fieldset>\n <button
|
|
129
|
+
], usesInheritance: true, ngImport: i0, template: "<div class=\"o-access-rights-share\">\n <label for=\"share-group-select\" class=\"a-h4\">{{ '@pry.share.dashboardAccess' | i18n }}</label>\n <form class=\"u-display-flex\">\n <fieldset class=\"m-grouped-select u-display-flex\" name=\"add-access-rights\">\n <legend class=\"u-visually-hidden\">{{ '@pry.share.shareAccessRights' | i18n }}</legend>\n <pry-select\n id=\"share-group-select\"\n class=\"o-access-rights-share__group-select\"\n name=\"share-group-select\"\n [(ngModel)]=\"selectedGroups\"\n (ngModelChange)=\"filterAvailableAccessRights()\"\n [items]=\"groups$ | async\"\n bindLabel=\"label\"\n placeholder=\"{{ ((groups$ | async)?.length === 0 ? '@pry.share.noGroups' : '@pry.share.placeholder') | i18n }}\"\n [multiple]=\"true\"\n [closeOnSelect]=\"false\"\n ></pry-select>\n <pry-select\n id=\"share-access-rights-select\"\n class=\"o-access-rights-share__access-rights-select\"\n name=\"share-access-rights-select\"\n [(ngModel)]=\"selectedAccessRight\"\n [items]=\"accessRights\"\n bindValue=\"value\"\n bindLabel=\"label\"\n ></pry-select>\n </fieldset>\n <button type=\"button\" class=\"a-btn a-btn--primary\" (click)=\"addAccess()\" [disabled]=\"isAddingDisabled()\">\n {{ '@pry.action.add' | i18n }}\n </button>\n </form>\n <label for=\"share-access-rights-select\" class=\"a-label\">{{ '@pry.share.accessDescription' | i18n }}</label>\n <div class=\"o-access-rights-share__groups\">\n @if (manifestDescription?.owner) {\n <div class=\"o-access-rights-share__group u-display-flex -justify-space-between -align-center\">\n <span class=\"o-access-rights-share__group-name a-h4\">{{ '@pry.share.me' | i18n }}</span>\n <span class=\"o-access-rights-share__owner\">{{ '@pry.share.owner' | i18n }}</span>\n </div>\n }\n @for (group of value | keyvalue; track group.key) {\n <div class=\"o-access-rights-share__group u-display-flex -justify-space-between -align-center\">\n <label class=\"o-access-rights-share__group-name a-h4\" for=\"modify-{{ group.key }}-access-rights-select\">\n {{ getGroupLabelByName(group.key, i18n) }}\n {{\n (userBelongsToGroup(group.key) | async) && group.key !== PUBLIC_GROUP\n ? ' (' + ('@pry.share.me' | i18n) + ')'\n : ''\n }}\n </label>\n <div class=\"u-display-flex -align-center\">\n @if (group.key === PUBLIC_GROUP || group.key === AUTHENTICATED_USERS_GROUP) {\n <span class=\"o-access-rights-share__access-rights\">{{ '@pry.share.read' | i18n }}</span>\n } @else {\n <pry-select\n id=\"modify-{{ group.key }}-access-rights-select\"\n class=\"o-access-rights-share__modify-access-rights\"\n name=\"modify-group-access-rights-select\"\n [(ngModel)]=\"group.value\"\n (ngModelChange)=\"modifyGroupAccess(group.key, group.value)\"\n [items]=\"accessRights\"\n bindValue=\"value\"\n bindLabel=\"label\"\n ></pry-select>\n }\n <button\n type=\"button\"\n class=\"a-btn a-btn--icon-only a-tooltip\"\n [attr.data-tooltip]=\"'@pry.action.delete' | i18n\"\n (click)=\"removeGroupAccess(group.key)\"\n (keydown.enter)=\"removeGroupAccess(group.key)\"\n >\n <pry-icon iconSvg=\"close\" [height]=\"15\" [width]=\"15\"></pry-icon>\n </button>\n </div>\n </div>\n }\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i4.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: i5.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.KeyValuePipe, name: "keyvalue" }, { kind: "pipe", type: i7.I18nPipe, name: "i18n" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
130
130
|
}
|
|
131
131
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: PryAccessRightsShareComponent, decorators: [{
|
|
132
132
|
type: Component,
|
|
@@ -136,7 +136,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
136
136
|
useExisting: forwardRef(() => PryAccessRightsShareComponent),
|
|
137
137
|
multi: true
|
|
138
138
|
}
|
|
139
|
-
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"o-access-rights-share\">\n <label for=\"share-group-select\" class=\"a-h4\">{{ '@pry.share.dashboardAccess' | i18n }}</label>\n <form class=\"u-display-flex\">\n <fieldset class=\"m-grouped-select u-display-flex\" name=\"add-access-rights\">\n <pry-select\n id=\"share-group-select\"\n class=\"o-access-rights-share__group-select\"\n name=\"share-group-select\"\n [(ngModel)]=\"selectedGroups\"\n (ngModelChange)=\"filterAvailableAccessRights()\"\n [items]=\"groups$ | async\"\n bindLabel=\"label\"\n placeholder=\"{{ ((groups$ | async)?.length === 0 ? '@pry.share.noGroups' : '@pry.share.placeholder') | i18n }}\"\n [multiple]=\"true\"\n [closeOnSelect]=\"false\"\n ></pry-select>\n <pry-select\n id=\"share-access-rights-select\"\n class=\"o-access-rights-share__access-rights-select\"\n name=\"share-access-rights-select\"\n [(ngModel)]=\"selectedAccessRight\"\n [items]=\"accessRights\"\n bindValue=\"value\"\n bindLabel=\"label\"\n ></pry-select>\n </fieldset>\n <button
|
|
139
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"o-access-rights-share\">\n <label for=\"share-group-select\" class=\"a-h4\">{{ '@pry.share.dashboardAccess' | i18n }}</label>\n <form class=\"u-display-flex\">\n <fieldset class=\"m-grouped-select u-display-flex\" name=\"add-access-rights\">\n <legend class=\"u-visually-hidden\">{{ '@pry.share.shareAccessRights' | i18n }}</legend>\n <pry-select\n id=\"share-group-select\"\n class=\"o-access-rights-share__group-select\"\n name=\"share-group-select\"\n [(ngModel)]=\"selectedGroups\"\n (ngModelChange)=\"filterAvailableAccessRights()\"\n [items]=\"groups$ | async\"\n bindLabel=\"label\"\n placeholder=\"{{ ((groups$ | async)?.length === 0 ? '@pry.share.noGroups' : '@pry.share.placeholder') | i18n }}\"\n [multiple]=\"true\"\n [closeOnSelect]=\"false\"\n ></pry-select>\n <pry-select\n id=\"share-access-rights-select\"\n class=\"o-access-rights-share__access-rights-select\"\n name=\"share-access-rights-select\"\n [(ngModel)]=\"selectedAccessRight\"\n [items]=\"accessRights\"\n bindValue=\"value\"\n bindLabel=\"label\"\n ></pry-select>\n </fieldset>\n <button type=\"button\" class=\"a-btn a-btn--primary\" (click)=\"addAccess()\" [disabled]=\"isAddingDisabled()\">\n {{ '@pry.action.add' | i18n }}\n </button>\n </form>\n <label for=\"share-access-rights-select\" class=\"a-label\">{{ '@pry.share.accessDescription' | i18n }}</label>\n <div class=\"o-access-rights-share__groups\">\n @if (manifestDescription?.owner) {\n <div class=\"o-access-rights-share__group u-display-flex -justify-space-between -align-center\">\n <span class=\"o-access-rights-share__group-name a-h4\">{{ '@pry.share.me' | i18n }}</span>\n <span class=\"o-access-rights-share__owner\">{{ '@pry.share.owner' | i18n }}</span>\n </div>\n }\n @for (group of value | keyvalue; track group.key) {\n <div class=\"o-access-rights-share__group u-display-flex -justify-space-between -align-center\">\n <label class=\"o-access-rights-share__group-name a-h4\" for=\"modify-{{ group.key }}-access-rights-select\">\n {{ getGroupLabelByName(group.key, i18n) }}\n {{\n (userBelongsToGroup(group.key) | async) && group.key !== PUBLIC_GROUP\n ? ' (' + ('@pry.share.me' | i18n) + ')'\n : ''\n }}\n </label>\n <div class=\"u-display-flex -align-center\">\n @if (group.key === PUBLIC_GROUP || group.key === AUTHENTICATED_USERS_GROUP) {\n <span class=\"o-access-rights-share__access-rights\">{{ '@pry.share.read' | i18n }}</span>\n } @else {\n <pry-select\n id=\"modify-{{ group.key }}-access-rights-select\"\n class=\"o-access-rights-share__modify-access-rights\"\n name=\"modify-group-access-rights-select\"\n [(ngModel)]=\"group.value\"\n (ngModelChange)=\"modifyGroupAccess(group.key, group.value)\"\n [items]=\"accessRights\"\n bindValue=\"value\"\n bindLabel=\"label\"\n ></pry-select>\n }\n <button\n type=\"button\"\n class=\"a-btn a-btn--icon-only a-tooltip\"\n [attr.data-tooltip]=\"'@pry.action.delete' | i18n\"\n (click)=\"removeGroupAccess(group.key)\"\n (keydown.enter)=\"removeGroupAccess(group.key)\"\n >\n <pry-icon iconSvg=\"close\" [height]=\"15\" [width]=\"15\"></pry-icon>\n </button>\n </div>\n </div>\n }\n </div>\n</div>\n" }]
|
|
140
140
|
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.PryI18nService }, { type: i8.PryBaseAccess, decorators: [{
|
|
141
141
|
type: Optional
|
|
142
142
|
}, {
|
|
@@ -148,4 +148,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
148
148
|
}], allowedGroups: [{
|
|
149
149
|
type: Input
|
|
150
150
|
}] } });
|
|
151
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"access-rights-share.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/provoly/dashboard/lib/core/components/share/access-rights-share/access-rights-share.component.ts","../../../../../../../../../projects/provoly/dashboard/lib/core/components/share/access-rights-share/access-rights-share.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACxG,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEzE,OAAO,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAC;AACrE,OAAO,EAAE,eAAe,EAAE,MAAM,wCAAwC,CAAC;AACzE,OAAO,EAAE,wBAAwB,EAAE,MAAM,4DAA4D,CAAC;AAEtG,OAAO,EACL,yBAAyB,EACzB,2BAA2B,EAC3B,4BAA4B,EAC5B,aAAa,EACb,mBAAmB,EACnB,YAAY,EACZ,WAAW,EACX,aAAa,EACb,YAAY,EACb,MAAM,gBAAgB,CAAC;AAGxB,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,GAAG,EAAc,EAAE,EAAE,MAAM,MAAM,CAAC;AAC3E,OAAO,EAAE,gBAAgB,EAAiB,MAAM,gCAAgC,CAAC;;;;;;;;;;AAcjF,MAAM,OAAO,6BAA8B,SAAQ,wBAAwB;IAOzE,IAAa,aAAa,CAAC,KAAsB;QAC/C,IAAI,KAAK;YAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;IAWD,YACU,KAAY,EACV,IAAoB,EACgB,MAAqB;QAEnE,KAAK,EAAE,CAAC;QAJA,UAAK,GAAL,KAAK,CAAO;QACV,SAAI,GAAJ,IAAI,CAAgB;QACgB,WAAM,GAAN,MAAM,CAAe;QAtBrE,UAAK,GAAG,EAA+B,CAAC;QAChC,cAAS,GAAG,CAAC,KAAkC,EAAE,EAAE,GAAE,CAAC,CAAC;QACvD,eAAU,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;QAG9B,oBAAe,GAAG,IAAI,eAAe,CAAuB,SAAS,CAAC,CAAC;QAMvE,4BAAuB,GAAuC,EAAE,CAAC;QACjE,iBAAY,GAAuC,EAAE,CAAC;QAEtD,mBAAc,GAAa,EAAE,CAAC;QAC9B,wBAAmB,GAAW,WAAW,CAAC;QAE1C,oBAAe,GAAG,IAAI,eAAe,CAAW,EAAE,CAAC,CAAC;QA2GjC,wBAAmB,GAAG,mBAAmB,CAAC;QAC1C,iBAAY,GAAG,YAAY,CAAC;QAC5B,8BAAyB,GAAG,yBAAyB,CAAC;QArGvE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,gBAAgB,EAAE,CAAC,CAAC;QACtD,IAAI,CAAC,OAAO,GAAG,aAAa,CAAC;YAC3B,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,eAAe,CAAC,YAAY,CAAC;YAC/C,IAAI,CAAC,eAAe;YACpB,IAAI,CAAC,eAAe;SACrB,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,aAAa,EAAE,eAAe,CAAC,EAAE,EAAE,CAC/C,MAAM;aACH,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;aAC9E,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,eAAe,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;aACxD,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;YACf,GAAG,KAAK;YACR,KAAK,EAAE,aAAa,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC;SACvC,CAAC,CAAC,CACN,CACF,CAAC;QACF,IAAI,CAAC,uBAAuB,GAAG;YAC7B,EAAE,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE;YACnE,EAAE,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE;SACtE,CAAC;QACF,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,uBAAuB,CAAC;IACnD,CAAC;IAED,UAAU,CAAC,KAA8C;QACvD,IAAI,KAAK;YAAE,IAAI,CAAC,KAAK,GAAG,4BAA4B,CAAC,KAAK,CAAC,IAAK,EAAgC,CAAC;QACjG,IAAI,CAAC,yBAAyB,EAAE,CAAC;QACjC,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,SAAS,CAAC,2BAA2B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QACxD,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED,SAAS;QACP,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;gBACpC,IAAI,CAAC,KAAK,GAAG;oBACX,GAAG,IAAI,CAAC,KAAK;oBACb,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,mBAAmB;iBACvC,CAAC;YACJ,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,yBAAyB,EAAE,CAAC;YACjC,IAAI,CAAC,QAAQ,EAAE,CAAC;QAClB,CAAC;QACD,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,iBAAiB,CAAC,KAAa,EAAE,MAAc;QAC7C,IAAI,CAAC,KAAK,GAAG;YACX,GAAG,IAAI,CAAC,KAAK;YACb,CAAC,KAAK,CAAC,EAAE,MAAM;SAChB,CAAC;QACF,IAAI,CAAC,SAAS,CAAC,2BAA2B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IAC1D,CAAC;IAED,iBAAiB,CAAC,KAAa;QAC7B,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACzB,IAAI,CAAC,SAAS,CAAC,2BAA2B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QACxD,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACnC,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,mBAAmB,GAAG,MAAM,CAAC;QAClC,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;IAClC,CAAC;IAED,gBAAgB;QACd,OAAO,IAAI,CAAC,cAAc,EAAE,MAAM,KAAK,CAAC,CAAC;IAC3C,CAAC;IAED,yBAAyB;QACvB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IACrD,CAAC;IAED,2BAA2B;QACzB,IACE,IAAI,CAAC,cAAc;YACnB,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC;YAC9B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,EACxE,CAAC;YACD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,uBAAuB,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,KAAK,WAAW,CAAC,CAAC;QACpG,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,uBAAuB,CAAC;QACnD,CAAC;IACH,CAAC;IAED,kBAAkB,CAAC,KAAa;QAC9B,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;IAC/D,CAAC;8GA3HU,6BAA6B,qEAuBlB,gBAAgB;kGAvB3B,6BAA6B,0IAT7B;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,6BAA6B,CAAC;gBAC5D,KAAK,EAAE,IAAI;aACZ;SACF,iDChCH,o8GA4EA;;2FDzCa,6BAA6B;kBAZzC,SAAS;+BACE,yBAAyB,aAExB;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,8BAA8B,CAAC;4BAC5D,KAAK,EAAE,IAAI;yBACZ;qBACF,mBACgB,uBAAuB,CAAC,MAAM;;0BAyB5C,QAAQ;;0BAAI,MAAM;2BAAC,gBAAgB;yCAlBX,mBAAmB;sBAA7C,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAEZ,aAAa;sBAAzB,KAAK","sourcesContent":["import { ChangeDetectionStrategy, Component, forwardRef, Inject, Input, Optional } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Store } from '@ngrx/store';\nimport { ConfigActions } from '../../../store/config/config.actions';\nimport { ConfigSelectors } from '../../../store/config/config.selectors';\nimport { SubscriptionnerDirective } from '../../../../dashboard/components/subscriptionner.directive';\nimport { Group } from '../share.model';\nimport {\n  AUTHENTICATED_USERS_GROUP,\n  getAccessRightsArrayByGroup,\n  getAccessRightsStringByGroup,\n  getGroupLabel,\n  getGroupLabelByName,\n  PUBLIC_GROUP,\n  READ_ACCESS,\n  SYSTEM_GROUPS,\n  WRITE_ACCESS\n} from '../share.utils';\nimport { ManifestDescription } from '../../../model/manifest.interface';\nimport { PryI18nService } from '../../../i18n/i18n.service';\nimport { BehaviorSubject, combineLatest, map, Observable, of } from 'rxjs';\nimport { PRY_ACCESS_TOKEN, PryBaseAccess } from '../../../access/access.service';\n\n@Component({\n  selector: 'pry-access-rights-share',\n  templateUrl: './access-rights-share.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PryAccessRightsShareComponent),\n      multi: true\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PryAccessRightsShareComponent extends SubscriptionnerDirective implements ControlValueAccessor {\n  value = {} as { [key: string]: string };\n  private _onChange = (value: { [key: string]: string[] }) => {};\n  private _onTouched = () => {};\n\n  @Input({ required: true }) manifestDescription?: ManifestDescription;\n  _allowedGroups$ = new BehaviorSubject<string[] | undefined>(undefined);\n  @Input() set allowedGroups(value: string[] | null) {\n    if (value) this._allowedGroups$.next(value);\n  }\n\n  groups$: Observable<(Group & { label: string })[]>;\n  AVAILABLE_ACCESS_RIGHTS: { label: string; value: string }[] = [];\n  accessRights: { label: string; value: string }[] = [];\n\n  selectedGroups?: Group[] = [];\n  selectedAccessRight: string = READ_ACCESS;\n\n  assignedGroups$ = new BehaviorSubject<string[]>([]);\n\n  constructor(\n    private store: Store,\n    protected i18n: PryI18nService,\n    @Optional() @Inject(PRY_ACCESS_TOKEN) private access: PryBaseAccess\n  ) {\n    super();\n    this.store.dispatch(ConfigActions.loadAccessGroups());\n    this.groups$ = combineLatest([\n      this.store.select(ConfigSelectors.accessGroups),\n      this._allowedGroups$,\n      this.assignedGroups$\n    ]).pipe(\n      map(([groups, allowedGroups, alreadyAssigned]) =>\n        groups\n          .filter((group) => (allowedGroups ? allowedGroups.includes(group.name) : true))\n          .filter((group) => !alreadyAssigned.includes(group.name))\n          .map((group) => ({\n            ...group,\n            label: getGroupLabel(group, this.i18n)\n          }))\n      )\n    );\n    this.AVAILABLE_ACCESS_RIGHTS = [\n      { label: this.i18n.instant('@pry.share.read'), value: READ_ACCESS },\n      { label: this.i18n.instant('@pry.share.write'), value: WRITE_ACCESS }\n    ];\n    this.accessRights = this.AVAILABLE_ACCESS_RIGHTS;\n  }\n\n  writeValue(value: { [key: string]: string[] } | undefined) {\n    if (value) this.value = getAccessRightsStringByGroup(value) ?? ({} as { [key: string]: string });\n    this.emitAlreadyAssignedGroups();\n    this._onTouched();\n  }\n\n  registerOnChange(fn: any): void {\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouched = fn;\n  }\n\n  onChange() {\n    this._onChange(getAccessRightsArrayByGroup(this.value));\n    this._onTouched();\n  }\n\n  addAccess() {\n    if (this.selectedGroups) {\n      this.selectedGroups.forEach((group) => {\n        this.value = {\n          ...this.value,\n          [group.name]: this.selectedAccessRight\n        };\n      });\n      this.emitAlreadyAssignedGroups();\n      this.onChange();\n    }\n    this.resetSelection();\n  }\n\n  modifyGroupAccess(group: string, access: string) {\n    this.value = {\n      ...this.value,\n      [group]: access\n    };\n    this._onChange(getAccessRightsArrayByGroup(this.value));\n  }\n\n  removeGroupAccess(group: string) {\n    delete this.value[group];\n    this._onChange(getAccessRightsArrayByGroup(this.value));\n    this.emitAlreadyAssignedGroups();\n  }\n\n  resetSelection() {\n    this.selectedAccessRight = 'READ';\n    this.selectedGroups = undefined;\n  }\n\n  isAddingDisabled() {\n    return this.selectedGroups?.length === 0;\n  }\n\n  emitAlreadyAssignedGroups() {\n    this.assignedGroups$.next(Object.keys(this.value));\n  }\n\n  filterAvailableAccessRights() {\n    if (\n      this.selectedGroups &&\n      this.selectedGroups.length > 0 &&\n      this.selectedGroups.every((group) => SYSTEM_GROUPS.includes(group.name))\n    ) {\n      this.accessRights = this.AVAILABLE_ACCESS_RIGHTS.filter((access) => access.value === READ_ACCESS);\n    } else {\n      this.accessRights = this.AVAILABLE_ACCESS_RIGHTS;\n    }\n  }\n\n  userBelongsToGroup(group: string): Observable<boolean> {\n    return this.access ? this.access.hasGroup(group) : of(false);\n  }\n\n  protected readonly getGroupLabelByName = getGroupLabelByName;\n  protected readonly PUBLIC_GROUP = PUBLIC_GROUP;\n  protected readonly AUTHENTICATED_USERS_GROUP = AUTHENTICATED_USERS_GROUP;\n}\n","<div class=\"o-access-rights-share\">\n  <label for=\"share-group-select\" class=\"a-h4\">{{ '@pry.share.dashboardAccess' | i18n }}</label>\n  <form class=\"u-display-flex\">\n    <fieldset class=\"m-grouped-select u-display-flex\" name=\"add-access-rights\">\n      <pry-select\n        id=\"share-group-select\"\n        class=\"o-access-rights-share__group-select\"\n        name=\"share-group-select\"\n        [(ngModel)]=\"selectedGroups\"\n        (ngModelChange)=\"filterAvailableAccessRights()\"\n        [items]=\"groups$ | async\"\n        bindLabel=\"label\"\n        placeholder=\"{{ ((groups$ | async)?.length === 0 ? '@pry.share.noGroups' : '@pry.share.placeholder') | i18n }}\"\n        [multiple]=\"true\"\n        [closeOnSelect]=\"false\"\n      ></pry-select>\n      <pry-select\n        id=\"share-access-rights-select\"\n        class=\"o-access-rights-share__access-rights-select\"\n        name=\"share-access-rights-select\"\n        [(ngModel)]=\"selectedAccessRight\"\n        [items]=\"accessRights\"\n        bindValue=\"value\"\n        bindLabel=\"label\"\n      ></pry-select>\n    </fieldset>\n    <button role=\"button\" class=\"a-btn a-btn--primary\" (click)=\"addAccess()\" [disabled]=\"isAddingDisabled()\">\n      {{ '@pry.action.add' | i18n }}\n    </button>\n  </form>\n  <label for=\"share-access-rights-select\" class=\"a-label\">{{ '@pry.share.accessDescription' | i18n }}</label>\n  <div class=\"o-access-rights-share__groups\">\n    @if (manifestDescription?.owner) {\n      <div class=\"o-access-rights-share__group u-display-flex -justify-space-between -align-center\">\n        <span class=\"o-access-rights-share__group-name a-h4\">{{ '@pry.share.me' | i18n }}</span>\n        <span class=\"o-access-rights-share__owner\">{{ '@pry.share.owner' | i18n }}</span>\n      </div>\n    }\n    @for (group of value | keyvalue; track group.key) {\n      <div class=\"o-access-rights-share__group u-display-flex -justify-space-between -align-center\">\n        <label class=\"o-access-rights-share__group-name a-h4\" for=\"modify-{{ group.key }}-access-rights-select\">\n          {{ getGroupLabelByName(group.key, i18n) }}\n          {{\n            (userBelongsToGroup(group.key) | async) && group.key !== PUBLIC_GROUP\n              ? ' (' + ('@pry.share.me' | i18n) + ')'\n              : ''\n          }}\n        </label>\n        <div class=\"u-display-flex -align-center\">\n          @if (group.key === PUBLIC_GROUP || group.key === AUTHENTICATED_USERS_GROUP) {\n            <span class=\"o-access-rights-share__access-rights\">{{ '@pry.share.read' | i18n }}</span>\n          } @else {\n            <pry-select\n              id=\"modify-{{ group.key }}-access-rights-select\"\n              class=\"o-access-rights-share__modify-access-rights\"\n              name=\"modify-group-access-rights-select\"\n              [(ngModel)]=\"group.value\"\n              (ngModelChange)=\"modifyGroupAccess(group.key, group.value)\"\n              [items]=\"accessRights\"\n              bindValue=\"value\"\n              bindLabel=\"label\"\n            ></pry-select>\n          }\n          <button\n            role=\"button\"\n            class=\"a-btn a-btn--icon-only a-tooltip\"\n            [attr.data-tooltip]=\"'@pry.action.delete' | i18n\"\n            (click)=\"removeGroupAccess(group.key)\"\n          >\n            <pry-icon iconSvg=\"close\" [height]=\"15\" [width]=\"15\"></pry-icon>\n          </button>\n        </div>\n      </div>\n    }\n  </div>\n</div>\n"]}
|
|
151
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"access-rights-share.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/provoly/dashboard/lib/core/components/share/access-rights-share/access-rights-share.component.ts","../../../../../../../../../projects/provoly/dashboard/lib/core/components/share/access-rights-share/access-rights-share.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, forwardRef, Inject, Input, Optional } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Store } from '@ngrx/store';\nimport { ConfigActions } from '../../../store/config/config.actions';\nimport { ConfigSelectors } from '../../../store/config/config.selectors';\nimport { SubscriptionnerDirective } from '../../../../dashboard/components/subscriptionner.directive';\nimport { Group } from '../share.model';\nimport {\n  AUTHENTICATED_USERS_GROUP,\n  getAccessRightsArrayByGroup,\n  getAccessRightsStringByGroup,\n  getGroupLabel,\n  getGroupLabelByName,\n  PUBLIC_GROUP,\n  READ_ACCESS,\n  SYSTEM_GROUPS,\n  WRITE_ACCESS\n} from '../share.utils';\nimport { ManifestDescription } from '../../../model/manifest.interface';\nimport { PryI18nService } from '../../../i18n/i18n.service';\nimport { BehaviorSubject, combineLatest, map, Observable, of } from 'rxjs';\nimport { PRY_ACCESS_TOKEN, PryBaseAccess } from '../../../access/access.service';\n\n@Component({\n  selector: 'pry-access-rights-share',\n  templateUrl: './access-rights-share.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PryAccessRightsShareComponent),\n      multi: true\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PryAccessRightsShareComponent extends SubscriptionnerDirective implements ControlValueAccessor {\n  value = {} as { [key: string]: string };\n  private _onChange = (value: { [key: string]: string[] }) => {};\n  private _onTouched = () => {};\n\n  @Input({ required: true }) manifestDescription?: ManifestDescription;\n  _allowedGroups$ = new BehaviorSubject<string[] | undefined>(undefined);\n  @Input() set allowedGroups(value: string[] | null) {\n    if (value) this._allowedGroups$.next(value);\n  }\n\n  groups$: Observable<(Group & { label: string })[]>;\n  AVAILABLE_ACCESS_RIGHTS: { label: string; value: string }[] = [];\n  accessRights: { label: string; value: string }[] = [];\n\n  selectedGroups?: Group[] = [];\n  selectedAccessRight: string = READ_ACCESS;\n\n  assignedGroups$ = new BehaviorSubject<string[]>([]);\n\n  constructor(\n    private store: Store,\n    protected i18n: PryI18nService,\n    @Optional() @Inject(PRY_ACCESS_TOKEN) private access: PryBaseAccess\n  ) {\n    super();\n    this.store.dispatch(ConfigActions.loadAccessGroups());\n    this.groups$ = combineLatest([\n      this.store.select(ConfigSelectors.accessGroups),\n      this._allowedGroups$,\n      this.assignedGroups$\n    ]).pipe(\n      map(([groups, allowedGroups, alreadyAssigned]) =>\n        groups\n          .filter((group) => (allowedGroups ? allowedGroups.includes(group.name) : true))\n          .filter((group) => !alreadyAssigned.includes(group.name))\n          .map((group) => ({\n            ...group,\n            label: getGroupLabel(group, this.i18n)\n          }))\n      )\n    );\n    this.AVAILABLE_ACCESS_RIGHTS = [\n      { label: this.i18n.instant('@pry.share.read'), value: READ_ACCESS },\n      { label: this.i18n.instant('@pry.share.write'), value: WRITE_ACCESS }\n    ];\n    this.accessRights = this.AVAILABLE_ACCESS_RIGHTS;\n  }\n\n  writeValue(value: { [key: string]: string[] } | undefined) {\n    if (value) this.value = getAccessRightsStringByGroup(value) ?? ({} as { [key: string]: string });\n    this.emitAlreadyAssignedGroups();\n    this._onTouched();\n  }\n\n  registerOnChange(fn: any): void {\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouched = fn;\n  }\n\n  onChange() {\n    this._onChange(getAccessRightsArrayByGroup(this.value));\n    this._onTouched();\n  }\n\n  addAccess() {\n    if (this.selectedGroups) {\n      this.selectedGroups.forEach((group) => {\n        this.value = {\n          ...this.value,\n          [group.name]: this.selectedAccessRight\n        };\n      });\n      this.emitAlreadyAssignedGroups();\n      this.onChange();\n    }\n    this.resetSelection();\n  }\n\n  modifyGroupAccess(group: string, access: string) {\n    this.value = {\n      ...this.value,\n      [group]: access\n    };\n    this._onChange(getAccessRightsArrayByGroup(this.value));\n  }\n\n  removeGroupAccess(group: string) {\n    delete this.value[group];\n    this._onChange(getAccessRightsArrayByGroup(this.value));\n    this.emitAlreadyAssignedGroups();\n  }\n\n  resetSelection() {\n    this.selectedAccessRight = 'READ';\n    this.selectedGroups = undefined;\n  }\n\n  isAddingDisabled() {\n    return this.selectedGroups?.length === 0;\n  }\n\n  emitAlreadyAssignedGroups() {\n    this.assignedGroups$.next(Object.keys(this.value));\n  }\n\n  filterAvailableAccessRights() {\n    if (\n      this.selectedGroups &&\n      this.selectedGroups.length > 0 &&\n      this.selectedGroups.every((group) => SYSTEM_GROUPS.includes(group.name))\n    ) {\n      this.accessRights = this.AVAILABLE_ACCESS_RIGHTS.filter((access) => access.value === READ_ACCESS);\n    } else {\n      this.accessRights = this.AVAILABLE_ACCESS_RIGHTS;\n    }\n  }\n\n  userBelongsToGroup(group: string): Observable<boolean> {\n    return this.access ? this.access.hasGroup(group) : of(false);\n  }\n\n  protected readonly getGroupLabelByName = getGroupLabelByName;\n  protected readonly PUBLIC_GROUP = PUBLIC_GROUP;\n  protected readonly AUTHENTICATED_USERS_GROUP = AUTHENTICATED_USERS_GROUP;\n}\n","<div class=\"o-access-rights-share\">\n  <label for=\"share-group-select\" class=\"a-h4\">{{ '@pry.share.dashboardAccess' | i18n }}</label>\n  <form class=\"u-display-flex\">\n    <fieldset class=\"m-grouped-select u-display-flex\" name=\"add-access-rights\">\n      <legend class=\"u-visually-hidden\">{{ '@pry.share.shareAccessRights' | i18n }}</legend>\n      <pry-select\n        id=\"share-group-select\"\n        class=\"o-access-rights-share__group-select\"\n        name=\"share-group-select\"\n        [(ngModel)]=\"selectedGroups\"\n        (ngModelChange)=\"filterAvailableAccessRights()\"\n        [items]=\"groups$ | async\"\n        bindLabel=\"label\"\n        placeholder=\"{{ ((groups$ | async)?.length === 0 ? '@pry.share.noGroups' : '@pry.share.placeholder') | i18n }}\"\n        [multiple]=\"true\"\n        [closeOnSelect]=\"false\"\n      ></pry-select>\n      <pry-select\n        id=\"share-access-rights-select\"\n        class=\"o-access-rights-share__access-rights-select\"\n        name=\"share-access-rights-select\"\n        [(ngModel)]=\"selectedAccessRight\"\n        [items]=\"accessRights\"\n        bindValue=\"value\"\n        bindLabel=\"label\"\n      ></pry-select>\n    </fieldset>\n    <button type=\"button\" class=\"a-btn a-btn--primary\" (click)=\"addAccess()\" [disabled]=\"isAddingDisabled()\">\n      {{ '@pry.action.add' | i18n }}\n    </button>\n  </form>\n  <label for=\"share-access-rights-select\" class=\"a-label\">{{ '@pry.share.accessDescription' | i18n }}</label>\n  <div class=\"o-access-rights-share__groups\">\n    @if (manifestDescription?.owner) {\n      <div class=\"o-access-rights-share__group u-display-flex -justify-space-between -align-center\">\n        <span class=\"o-access-rights-share__group-name a-h4\">{{ '@pry.share.me' | i18n }}</span>\n        <span class=\"o-access-rights-share__owner\">{{ '@pry.share.owner' | i18n }}</span>\n      </div>\n    }\n    @for (group of value | keyvalue; track group.key) {\n      <div class=\"o-access-rights-share__group u-display-flex -justify-space-between -align-center\">\n        <label class=\"o-access-rights-share__group-name a-h4\" for=\"modify-{{ group.key }}-access-rights-select\">\n          {{ getGroupLabelByName(group.key, i18n) }}\n          {{\n            (userBelongsToGroup(group.key) | async) && group.key !== PUBLIC_GROUP\n              ? ' (' + ('@pry.share.me' | i18n) + ')'\n              : ''\n          }}\n        </label>\n        <div class=\"u-display-flex -align-center\">\n          @if (group.key === PUBLIC_GROUP || group.key === AUTHENTICATED_USERS_GROUP) {\n            <span class=\"o-access-rights-share__access-rights\">{{ '@pry.share.read' | i18n }}</span>\n          } @else {\n            <pry-select\n              id=\"modify-{{ group.key }}-access-rights-select\"\n              class=\"o-access-rights-share__modify-access-rights\"\n              name=\"modify-group-access-rights-select\"\n              [(ngModel)]=\"group.value\"\n              (ngModelChange)=\"modifyGroupAccess(group.key, group.value)\"\n              [items]=\"accessRights\"\n              bindValue=\"value\"\n              bindLabel=\"label\"\n            ></pry-select>\n          }\n          <button\n            type=\"button\"\n            class=\"a-btn a-btn--icon-only a-tooltip\"\n            [attr.data-tooltip]=\"'@pry.action.delete' | i18n\"\n            (click)=\"removeGroupAccess(group.key)\"\n            (keydown.enter)=\"removeGroupAccess(group.key)\"\n          >\n            <pry-icon iconSvg=\"close\" [height]=\"15\" [width]=\"15\"></pry-icon>\n          </button>\n        </div>\n      </div>\n    }\n  </div>\n</div>\n"]}
|
|
@@ -5,6 +5,7 @@ import { DataSourceSelectors } from '../../../store/data-source/data-source.sele
|
|
|
5
5
|
import { getCommonDatasourceGroupsForManifest } from '../share.utils';
|
|
6
6
|
import { BehaviorSubject, map } from 'rxjs';
|
|
7
7
|
import equal from 'fast-deep-equal/es6';
|
|
8
|
+
import { DataSourceActions } from '../../../store/data-source/data-source.actions';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
import * as i1 from "@ngrx/store";
|
|
10
11
|
import * as i2 from "../../overlay/dialog-ref";
|
|
@@ -20,6 +21,7 @@ export class PryAccessRightsShareModalComponent {
|
|
|
20
21
|
this.data = data;
|
|
21
22
|
this.accessRightsByGroup = {};
|
|
22
23
|
this.disableShareButton$ = new BehaviorSubject(false);
|
|
24
|
+
this.store.dispatch(DataSourceActions.dataset.loadDataset());
|
|
23
25
|
this.manifest = this.data.manifest;
|
|
24
26
|
this.accessRightsByGroup = { ...this.manifest.accessRightsByGroup };
|
|
25
27
|
this.allowedShareGroups$ = this.store.select(DataSourceSelectors.datasets).pipe(map((datasets) => {
|
|
@@ -89,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
89
91
|
type: ViewChild,
|
|
90
92
|
args: ['crossVisibility']
|
|
91
93
|
}] } });
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"access-rights-share-modal.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/provoly/dashboard/lib/core/components/share/access-rights-share-modal/access-rights-share-modal.component.ts","../../../../../../../../../projects/provoly/dashboard/lib/core/components/share/access-rights-share-modal/access-rights-share-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Inject, ViewChild } from '@angular/core';\nimport { PryDialogRef } from '../../overlay/dialog-ref';\nimport { PRY_DIALOG_DATA } from '../../overlay/dialog.service';\nimport { ManifestDescription } from '../../../model/manifest.interface';\nimport { DashboardActions } from '../../../../dashboard/store/dashboard.actions';\nimport { DataSourceSelectors } from '../../../store/data-source/data-source.selectors';\nimport { getCommonDatasourceGroupsForManifest } from '../share.utils';\nimport { Store } from '@ngrx/store';\nimport { BehaviorSubject, map, Observable } from 'rxjs';\nimport equal from 'fast-deep-equal/es6';\n\n@Component({\n  selector: 'pry-access-rights-share-modal',\n  templateUrl: './access-rights-share-modal.component.html'\n})\nexport class PryAccessRightsShareModalComponent {\n  manifest: ManifestDescription;\n  accessRightsByGroup: { [key: string]: string[] } = {};\n\n  allowedShareGroups$: Observable<string[] | null>;\n  disableShareButton$ = new BehaviorSubject<boolean>(false);\n\n  @ViewChild('confirm') confirm!: ElementRef<HTMLButtonElement>;\n  @ViewChild('submit') submit!: ElementRef<HTMLButtonElement>;\n  @ViewChild('cross') cross!: ElementRef<HTMLButtonElement>;\n  @ViewChild('crossVisibility') crossVisibility!: ElementRef<HTMLButtonElement>;\n\n  constructor(\n    private store: Store<any>,\n    private dialogRef: PryDialogRef<PryAccessRightsShareModalComponent>,\n    @Inject(PRY_DIALOG_DATA)\n    private data: {\n      manifest: ManifestDescription;\n    }\n  ) {\n    this.manifest = this.data.manifest;\n    this.accessRightsByGroup = { ...this.manifest.accessRightsByGroup };\n\n    this.allowedShareGroups$ = this.store.select(DataSourceSelectors.datasets).pipe(\n      map((datasets) => {\n        return this.manifest.datasource.length > 0\n          ? getCommonDatasourceGroupsForManifest(this.manifest, datasets)\n          : null;\n      })\n    );\n  }\n\n  updateAccessRights($event: { [key: string]: string[] }) {\n    this.accessRightsByGroup = $event;\n    this.updateDisableButtonValue();\n  }\n\n  updateDisableButtonValue() {\n    if (equal(this.accessRightsByGroup, this.manifest.accessRightsByGroup)) {\n      this.disableShareButton$.next(true);\n    } else {\n      if (this.disableShareButton$.getValue()) {\n        this.disableShareButton$.next(false);\n      }\n    }\n  }\n\n  validate() {\n    this.store.dispatch(\n      DashboardActions.saveManifest({\n        id: this.manifest.id ?? '',\n        name: this.manifest.name ?? '',\n        description: this.manifest.description ?? '',\n        image: this.manifest.image ?? '',\n        accessRightsByGroup: this.accessRightsByGroup\n      })\n    );\n    this.toggleModal();\n  }\n\n  toggleModal() {\n    this.dialogRef.close();\n  }\n\n  focusCrossElement() {\n    if (this.crossVisibility) {\n      this.crossVisibility?.nativeElement.focus();\n    }\n    this.cross?.nativeElement.focus();\n  }\n\n  focusValidation() {\n    if (this.confirm) {\n      this.confirm.nativeElement.focus();\n    }\n    this.submit.nativeElement.focus();\n  }\n}\n","<div class=\"o-modal\" role=\"dialog\" aria-modal=\"true\" aria-labelledby=\"dialog share access rights\">\n  <div class=\"o-modal__top\">\n    <div class=\"o-modal__top__title\">\n      <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.shareAccessRights' | i18n }}</h2>\n    </div>\n    <div class=\"o-modal__top__close\">\n      <button\n        class=\"a-btn a-btn--icon-only\"\n        (click)=\"toggleModal()\"\n        #crossVisibility\n        (keydown.shift.tab)=\"focusValidation()\"\n      >\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  <pry-access-rights-share\n    [(ngModel)]=\"accessRightsByGroup\"\n    (ngModelChange)=\"updateAccessRights($event)\"\n    [manifestDescription]=\"manifest\"\n    [allowedGroups]=\"allowedShareGroups$ | async\"\n  ></pry-access-rights-share>\n  <div class=\"u-display-flex m-btn-group -justify-center\">\n    <button type=\"button\" class=\"a-btn a-btn--secondary\" (click)=\"toggleModal()\">\n      {{ '@pry.toolbox.manifest.close' | i18n }}\n    </button>\n    <button\n      type=\"submit\"\n      class=\"a-btn a-btn--primary\"\n      #submit\n      (keydown.tab)=\"focusCrossElement()\"\n      (click)=\"validate()\"\n      [disabled]=\"this.disableShareButton$ | async\"\n    >\n      {{ '@pry.toolbox.manifest.validate' | i18n }}\n    </button>\n  </div>\n</div>\n"]}
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"access-rights-share-modal.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/provoly/dashboard/lib/core/components/share/access-rights-share-modal/access-rights-share-modal.component.ts","../../../../../../../../../projects/provoly/dashboard/lib/core/components/share/access-rights-share-modal/access-rights-share-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Inject, ViewChild } from '@angular/core';\nimport { PryDialogRef } from '../../overlay/dialog-ref';\nimport { PRY_DIALOG_DATA } from '../../overlay/dialog.service';\nimport { ManifestDescription } from '../../../model/manifest.interface';\nimport { DashboardActions } from '../../../../dashboard/store/dashboard.actions';\nimport { DataSourceSelectors } from '../../../store/data-source/data-source.selectors';\nimport { getCommonDatasourceGroupsForManifest } from '../share.utils';\nimport { Store } from '@ngrx/store';\nimport { BehaviorSubject, map, Observable } from 'rxjs';\nimport equal from 'fast-deep-equal/es6';\nimport { DataSourceActions } from '../../../store/data-source/data-source.actions';\n\n@Component({\n  selector: 'pry-access-rights-share-modal',\n  templateUrl: './access-rights-share-modal.component.html'\n})\nexport class PryAccessRightsShareModalComponent {\n  manifest: ManifestDescription;\n  accessRightsByGroup: { [key: string]: string[] } = {};\n\n  allowedShareGroups$: Observable<string[] | null>;\n  disableShareButton$ = new BehaviorSubject<boolean>(false);\n\n  @ViewChild('confirm') confirm!: ElementRef<HTMLButtonElement>;\n  @ViewChild('submit') submit!: ElementRef<HTMLButtonElement>;\n  @ViewChild('cross') cross!: ElementRef<HTMLButtonElement>;\n  @ViewChild('crossVisibility') crossVisibility!: ElementRef<HTMLButtonElement>;\n\n  constructor(\n    private store: Store<any>,\n    private dialogRef: PryDialogRef<PryAccessRightsShareModalComponent>,\n    @Inject(PRY_DIALOG_DATA)\n    private data: {\n      manifest: ManifestDescription;\n    }\n  ) {\n    this.store.dispatch(DataSourceActions.dataset.loadDataset());\n    this.manifest = this.data.manifest;\n    this.accessRightsByGroup = { ...this.manifest.accessRightsByGroup };\n\n    this.allowedShareGroups$ = this.store.select(DataSourceSelectors.datasets).pipe(\n      map((datasets) => {\n        return this.manifest.datasource.length > 0\n          ? getCommonDatasourceGroupsForManifest(this.manifest, datasets)\n          : null;\n      })\n    );\n  }\n\n  updateAccessRights($event: { [key: string]: string[] }) {\n    this.accessRightsByGroup = $event;\n    this.updateDisableButtonValue();\n  }\n\n  updateDisableButtonValue() {\n    if (equal(this.accessRightsByGroup, this.manifest.accessRightsByGroup)) {\n      this.disableShareButton$.next(true);\n    } else {\n      if (this.disableShareButton$.getValue()) {\n        this.disableShareButton$.next(false);\n      }\n    }\n  }\n\n  validate() {\n    this.store.dispatch(\n      DashboardActions.saveManifest({\n        id: this.manifest.id ?? '',\n        name: this.manifest.name ?? '',\n        description: this.manifest.description ?? '',\n        image: this.manifest.image ?? '',\n        accessRightsByGroup: this.accessRightsByGroup\n      })\n    );\n    this.toggleModal();\n  }\n\n  toggleModal() {\n    this.dialogRef.close();\n  }\n\n  focusCrossElement() {\n    if (this.crossVisibility) {\n      this.crossVisibility?.nativeElement.focus();\n    }\n    this.cross?.nativeElement.focus();\n  }\n\n  focusValidation() {\n    if (this.confirm) {\n      this.confirm.nativeElement.focus();\n    }\n    this.submit.nativeElement.focus();\n  }\n}\n","<div class=\"o-modal\" role=\"dialog\" aria-modal=\"true\" aria-labelledby=\"dialog share access rights\">\n  <div class=\"o-modal__top\">\n    <div class=\"o-modal__top__title\">\n      <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.shareAccessRights' | i18n }}</h2>\n    </div>\n    <div class=\"o-modal__top__close\">\n      <button\n        class=\"a-btn a-btn--icon-only\"\n        (click)=\"toggleModal()\"\n        #crossVisibility\n        (keydown.shift.tab)=\"focusValidation()\"\n      >\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  <pry-access-rights-share\n    [(ngModel)]=\"accessRightsByGroup\"\n    (ngModelChange)=\"updateAccessRights($event)\"\n    [manifestDescription]=\"manifest\"\n    [allowedGroups]=\"allowedShareGroups$ | async\"\n  ></pry-access-rights-share>\n  <div class=\"u-display-flex m-btn-group -justify-center\">\n    <button type=\"button\" class=\"a-btn a-btn--secondary\" (click)=\"toggleModal()\">\n      {{ '@pry.toolbox.manifest.close' | i18n }}\n    </button>\n    <button\n      type=\"submit\"\n      class=\"a-btn a-btn--primary\"\n      #submit\n      (keydown.tab)=\"focusCrossElement()\"\n      (click)=\"validate()\"\n      [disabled]=\"this.disableShareButton$ | async\"\n    >\n      {{ '@pry.toolbox.manifest.validate' | i18n }}\n    </button>\n  </div>\n</div>\n"]}
|
package/esm2022/lib/core/components/translate-item-to-symbol/translate-item-to-symbol.pipe.mjs
CHANGED
|
@@ -1,21 +1,17 @@
|
|
|
1
1
|
import { Pipe } from '@angular/core';
|
|
2
2
|
import { from } from 'rxjs';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "
|
|
5
|
-
import * as i2 from "../../i18n/i18n.service";
|
|
6
|
-
import * as i3 from "../../store/image/image.service";
|
|
7
|
-
import * as i4 from "../../symbol/symbol.service";
|
|
4
|
+
import * as i1 from "../../symbol/symbol.service";
|
|
8
5
|
export class TranslateItemToSymbolPipe {
|
|
9
|
-
constructor(
|
|
10
|
-
this.store = store;
|
|
11
|
-
this.translateService = translateService;
|
|
12
|
-
this.imageService = imageService;
|
|
6
|
+
constructor(symbolService) {
|
|
13
7
|
this.symbolService = symbolService;
|
|
14
8
|
}
|
|
15
9
|
transform(value, ...args) {
|
|
16
|
-
return from(new Promise((resolve) => this.symbolService
|
|
10
|
+
return from(new Promise((resolve) => this.symbolService
|
|
11
|
+
.getSymbol(value)
|
|
12
|
+
.then((canvas) => resolve(canvas.toDataURL('image/png')))));
|
|
17
13
|
}
|
|
18
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: TranslateItemToSymbolPipe, deps: [{ token: i1.
|
|
14
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: TranslateItemToSymbolPipe, deps: [{ token: i1.SymbolService }], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
19
15
|
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.1.3", ngImport: i0, type: TranslateItemToSymbolPipe, name: "translateItemToSymbol" }); }
|
|
20
16
|
}
|
|
21
17
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: TranslateItemToSymbolPipe, decorators: [{
|
|
@@ -23,5 +19,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
23
19
|
args: [{
|
|
24
20
|
name: 'translateItemToSymbol'
|
|
25
21
|
}]
|
|
26
|
-
}], ctorParameters: () => [{ type: i1.
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
}], ctorParameters: () => [{ type: i1.SymbolService }] });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRlLWl0ZW0tdG8tc3ltYm9sLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2Rhc2hib2FyZC9saWIvY29yZS9jb21wb25lbnRzL3RyYW5zbGF0ZS1pdGVtLXRvLXN5bWJvbC90cmFuc2xhdGUtaXRlbS10by1zeW1ib2wucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUNwRCxPQUFPLEVBQUUsSUFBSSxFQUFjLE1BQU0sTUFBTSxDQUFDOzs7QUFPeEMsTUFBTSxPQUFPLHlCQUF5QjtJQUNwQyxZQUFvQixhQUE0QjtRQUE1QixrQkFBYSxHQUFiLGFBQWEsQ0FBZTtJQUFHLENBQUM7SUFFcEQsU0FBUyxDQUFDLEtBQVcsRUFBRSxHQUFHLElBQWU7UUFDdkMsT0FBTyxJQUFJLENBQ1QsSUFBSSxPQUFPLENBQ1QsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUNWLElBQUksQ0FBQyxhQUFhO2FBQ2YsU0FBUyxDQUFDLEtBQUssQ0FBQzthQUNoQixJQUFJLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQW9CLENBQ2pGLENBQ0YsQ0FBQztJQUNKLENBQUM7OEdBWlUseUJBQXlCOzRHQUF6Qix5QkFBeUI7OzJGQUF6Qix5QkFBeUI7a0JBSHJDLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLHVCQUF1QjtpQkFDOUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBmcm9tLCBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBJdGVtIH0gZnJvbSAnLi4vLi4vbW9kZWwvaXRlbS5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgU3ltYm9sU2VydmljZSB9IGZyb20gJy4uLy4uL3N5bWJvbC9zeW1ib2wuc2VydmljZSc7XG5cbkBQaXBlKHtcbiAgbmFtZTogJ3RyYW5zbGF0ZUl0ZW1Ub1N5bWJvbCdcbn0pXG5leHBvcnQgY2xhc3MgVHJhbnNsYXRlSXRlbVRvU3ltYm9sUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHN5bWJvbFNlcnZpY2U6IFN5bWJvbFNlcnZpY2UpIHt9XG5cbiAgdHJhbnNmb3JtKHZhbHVlOiBJdGVtLCAuLi5hcmdzOiB1bmtub3duW10pOiBPYnNlcnZhYmxlPHN0cmluZz4ge1xuICAgIHJldHVybiBmcm9tKFxuICAgICAgbmV3IFByb21pc2U8c3RyaW5nPihcbiAgICAgICAgKHJlc29sdmUpID0+XG4gICAgICAgICAgdGhpcy5zeW1ib2xTZXJ2aWNlXG4gICAgICAgICAgICAuZ2V0U3ltYm9sKHZhbHVlKVxuICAgICAgICAgICAgLnRoZW4oKGNhbnZhcykgPT4gcmVzb2x2ZShjYW52YXMudG9EYXRhVVJMKCdpbWFnZS9wbmcnKSkpIGFzIFByb21pc2U8c3RyaW5nPlxuICAgICAgKVxuICAgICk7XG4gIH1cbn1cbiJdfQ==
|