@provoly/dashboard 0.18.9 → 0.19.0
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/dataset/components/dataset-card/dataset-card.component.d.ts +5 -5
- package/dataset/i18n/en.translations.d.ts +1 -0
- package/dataset/i18n/fr.translations.d.ts +1 -0
- package/dataset/style/_o-pry-dataset.scss +1 -1
- package/esm2022/dataset/components/dataset-card/dataset-card.component.mjs +8 -8
- package/esm2022/dataset/components/dataset-detail/dataset-detail.component.mjs +2 -1
- package/esm2022/dataset/components/dataset.component.mjs +3 -3
- package/esm2022/dataset/i18n/en.translations.mjs +2 -1
- package/esm2022/dataset/i18n/fr.translations.mjs +2 -1
- package/esm2022/dataset/style/css.component.mjs +2 -2
- package/esm2022/lib/core/components/snackbar/snackbar.service.mjs +4 -1
- package/esm2022/lib/core/errors/http-error-interceptor.service.mjs +4 -5
- package/esm2022/lib/dashboard/dashboard.module.mjs +8 -3
- package/esm2022/lib/dashboard/filter/components/filter-group/filter-group.component.mjs +44 -0
- package/esm2022/lib/dashboard/filter/public-api.mjs +3 -1
- package/esm2022/lib/dashboard/filter/style/css.component.mjs +11 -0
- package/esm2022/presentation/components/presentation.component.mjs +2 -1
- package/esm2022/presentation/components/title-presentation/title-presentation.component.mjs +3 -3
- package/esm2022/restitution/components/restitution-catalog/restitution-catalog.component.mjs +3 -1
- package/esm2022/widgets/widget-aggregated-chart/component/widget-aggregated-chart.component.mjs +21 -6
- package/esm2022/widgets/widget-table/component/widget-table.component.mjs +4 -7
- package/fesm2022/provoly-dashboard-dataset.mjs +10 -7
- package/fesm2022/provoly-dashboard-dataset.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-presentation.mjs +3 -2
- package/fesm2022/provoly-dashboard-presentation.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-restitution.mjs +2 -0
- package/fesm2022/provoly-dashboard-restitution.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-aggregated-chart.mjs +20 -5
- package/fesm2022/provoly-dashboard-widgets-widget-aggregated-chart.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-table.mjs +3 -6
- package/fesm2022/provoly-dashboard-widgets-widget-table.mjs.map +1 -1
- package/fesm2022/provoly-dashboard.mjs +57 -9
- package/fesm2022/provoly-dashboard.mjs.map +1 -1
- package/lib/core/components/snackbar/snackbar.service.d.ts +1 -0
- package/lib/dashboard/dashboard.module.d.ts +17 -15
- package/lib/dashboard/filter/components/filter-group/filter-group.component.d.ts +17 -0
- package/lib/dashboard/filter/public-api.d.ts +2 -0
- package/lib/dashboard/filter/style/_o-pry-filter-group.scss +41 -0
- package/lib/dashboard/filter/style/css.component.d.ts +5 -0
- package/package.json +25 -25
- package/styles/layout/_o-workspace.scss +0 -29
- package/widgets/widget-aggregated-chart/component/widget-aggregated-chart.component.d.ts +14 -1
- package/widgets/widget-table/component/widget-table.component.d.ts +0 -1
|
@@ -35,6 +35,7 @@ import { WidgetPlaceholderComponent } from './components/widgets/widget-placehol
|
|
|
35
35
|
import { WidgetPlacementUtils } from './components/widgets/widget-placement/widget-placement.utils';
|
|
36
36
|
import { BaseFilterComponent } from './filter/base-filter.component';
|
|
37
37
|
import { FilterInstanciatorComponent } from './filter/components/filter-instanciator/filter-instanciator.component';
|
|
38
|
+
import { FilterGroupComponent } from "./filter/components/filter-group/filter-group.component";
|
|
38
39
|
import { FILTER_DEFINITION } from './filter/filter-factory.service';
|
|
39
40
|
import { DefaultViewGuard } from './guard/default-view.guard';
|
|
40
41
|
import { BASE_CONFIG, DashboardInitService } from './store/dashboard-init.service';
|
|
@@ -45,6 +46,7 @@ import { PryTitleService } from './store/title.service';
|
|
|
45
46
|
import { BaseTooltipComponent } from './tooltip/base-tooltip.component';
|
|
46
47
|
import { DefaultTooltipComponent } from './tooltip/components/default/default.tooltip.component';
|
|
47
48
|
import { TOOLTIP_DEFINITION } from './tooltip/tooltip-factory.service';
|
|
49
|
+
import { PryFilterGroupCssComponent } from "./filter/style/css.component";
|
|
48
50
|
import * as i0 from "@angular/core";
|
|
49
51
|
import * as i1 from "@ngrx/store";
|
|
50
52
|
import * as i2 from "@ngrx/effects";
|
|
@@ -66,6 +68,7 @@ const components = [
|
|
|
66
68
|
BaseTooltipComponent,
|
|
67
69
|
BaseFilterComponent,
|
|
68
70
|
FilterInstanciatorComponent,
|
|
71
|
+
FilterGroupComponent,
|
|
69
72
|
DatasourceSelectorComponent
|
|
70
73
|
];
|
|
71
74
|
export class PryDashboardModule {
|
|
@@ -109,7 +112,8 @@ export class PryDashboardModule {
|
|
|
109
112
|
BaseTooltipComponent,
|
|
110
113
|
BaseFilterComponent,
|
|
111
114
|
FilterInstanciatorComponent,
|
|
112
|
-
|
|
115
|
+
FilterGroupComponent,
|
|
116
|
+
DatasourceSelectorComponent, PryFilterGroupCssComponent], imports: [CommonModule,
|
|
113
117
|
FormsModule,
|
|
114
118
|
PrySelectModule,
|
|
115
119
|
PryIconModule,
|
|
@@ -135,6 +139,7 @@ export class PryDashboardModule {
|
|
|
135
139
|
BaseTooltipComponent,
|
|
136
140
|
BaseFilterComponent,
|
|
137
141
|
FilterInstanciatorComponent,
|
|
142
|
+
FilterGroupComponent,
|
|
138
143
|
DatasourceSelectorComponent] }); }
|
|
139
144
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryDashboardModule, providers: [WidgetFactoryService], imports: [CommonModule,
|
|
140
145
|
FormsModule,
|
|
@@ -153,7 +158,7 @@ export class PryDashboardModule {
|
|
|
153
158
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryDashboardModule, decorators: [{
|
|
154
159
|
type: NgModule,
|
|
155
160
|
args: [{
|
|
156
|
-
declarations: [...components],
|
|
161
|
+
declarations: [...components, PryFilterGroupCssComponent],
|
|
157
162
|
imports: [
|
|
158
163
|
CommonModule,
|
|
159
164
|
FormsModule,
|
|
@@ -173,4 +178,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
|
|
|
173
178
|
providers: [WidgetFactoryService]
|
|
174
179
|
}]
|
|
175
180
|
}] });
|
|
176
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard.module.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/lib/dashboard/dashboard.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { OverlayModule } from '@angular/cdk/overlay';\nimport { CommonModule } from '@angular/common';\nimport { ModuleWithProviders, NgModule } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { EffectsModule } from '@ngrx/effects';\nimport { StoreModule } from '@ngrx/store';\nimport { PryCheckboxModule } from '@provoly/dashboard/components/checkbox';\nimport { PryDatePickerModule } from '../core/components/date-picker/date-picker.module';\nimport { PryIconModule } from '../core/components/icon/icon.module';\nimport { PryOverlayModule } from '../core/components/overlay/overlay.module';\nimport { PrySelectModule } from '../core/components/select/select.module';\nimport { PryToggleModule } from '../core/components/toggle/toggle.module';\nimport { PryCoreModule } from '../core/core.module';\nimport { PryI18nModule } from '../core/i18n/i18n.module';\nimport { ConfigService } from '../core/store/config/config.service';\nimport { ToolboxManifestService } from '../core/toolbox/toolbox-manifest.service';\nimport { WebsocketService } from '../core/ws/websocket.service';\nimport { ActionBusEffects } from './action-bus/effect/action-bus.effects';\nimport { BusService } from './action-bus/service/bus.service';\nimport { ContextMenuComponent } from './components/context-menu/context-menu.component';\nimport { PryObjectEditionComponent } from './components/context-menu/object-edition/object-edition.component';\nimport { DashboardComponent } from './components/dashboard.component';\nimport { ManifestsComponent } from './components/manifests/manifests.component';\nimport { MetadataComponent } from './components/metadata/metadata.component';\nimport { VizualizeRawComponent } from './components/vizualize-raw/vizualize-raw.component';\nimport { BaseWidgetComponent } from './components/widgets/base-widget.component';\nimport { DataWidgetComponent } from './components/widgets/data-widget.component';\nimport { DatasourceSelectorComponent } from './components/widgets/datasource-selector/datasource-selector.component';\nimport { ResultSetSizePipe } from './components/widgets/header/resultset-size.pipe';\nimport { PryWidgetHeaderComponent } from './components/widgets/header/widget-header.component';\nimport { SettingsComponent } from './components/widgets/settings/settings.component';\nimport {\n  WIDGET_DEFINITION,\n  WidgetFactoryService\n} from './components/widgets/widget-instanciator/widget-factory.service';\nimport { WidgetInstanciatorComponent } from './components/widgets/widget-instanciator/widget-instanciator.component';\nimport { WidgetDefinition } from './components/widgets/widget-instanciator/widgets-definition.model';\nimport { WidgetPlaceholderComponent } from './components/widgets/widget-placeholder/widget-placeholder.component';\nimport {\n  LayoutPlacementOptionImplementationFn,\n  LayoutSizeImplementationFn,\n  WidgetPlacementUtils\n} from './components/widgets/widget-placement/widget-placement.utils';\nimport { BaseFilterComponent } from './filter/base-filter.component';\nimport { FilterInstanciatorComponent } from './filter/components/filter-instanciator/filter-instanciator.component';\nimport { FILTER_DEFINITION, FilterDefinition } from './filter/filter-factory.service';\nimport { DefaultViewGuard } from './guard/default-view.guard';\nimport { BASE_CONFIG, DashboardInitService } from './store/dashboard-init.service';\nimport { DashboardEffects } from './store/dashboard.effects';\nimport { dashboardFeatureKey, dashboardReducer } from './store/dashboard.reducers';\nimport { RefreshService } from './store/refresh.service';\nimport { PryTitleService } from './store/title.service';\nimport { BaseTooltipComponent } from './tooltip/base-tooltip.component';\nimport { DefaultTooltipComponent } from './tooltip/components/default/default.tooltip.component';\nimport { TOOLTIP_DEFINITION, TooltipDefinition } from './tooltip/tooltip-factory.service';\n\nconst components = [\n  DashboardComponent,\n  WidgetInstanciatorComponent,\n  WidgetPlaceholderComponent,\n  SettingsComponent,\n  ManifestsComponent,\n  MetadataComponent,\n  ContextMenuComponent,\n  DataWidgetComponent,\n  BaseWidgetComponent,\n  PryWidgetHeaderComponent,\n  PryObjectEditionComponent,\n  VizualizeRawComponent,\n  ResultSetSizePipe,\n  DefaultTooltipComponent,\n  BaseTooltipComponent,\n  BaseFilterComponent,\n  FilterInstanciatorComponent,\n  DatasourceSelectorComponent\n];\n\n@NgModule({\n  declarations: [...components],\n  imports: [\n    CommonModule,\n    FormsModule,\n    PrySelectModule,\n    PryIconModule,\n    OverlayModule,\n    PryCoreModule,\n    PryCheckboxModule,\n    PryToggleModule,\n    PryOverlayModule,\n    StoreModule.forFeature(dashboardFeatureKey, dashboardReducer),\n    EffectsModule.forFeature([ActionBusEffects, DashboardEffects]),\n    PryDatePickerModule,\n    PryI18nModule\n  ],\n  exports: [...components],\n  providers: [WidgetFactoryService]\n})\nexport class PryDashboardModule {\n  static forRoot(\n    widgetReference: { [key: string]: WidgetDefinition },\n    options: {\n      path?: string;\n      mapUrl?: string;\n      pryUrl?: string;\n      wsUrl?: string;\n      geoServerUrl?: string;\n    },\n    tooltipReference: { [key: string]: TooltipDefinition },\n    filterReference: { [key: string]: FilterDefinition },\n    additionalGridImplementations: {\n      type: string;\n      sizeImpl: LayoutSizeImplementationFn;\n      placementImpl: LayoutPlacementOptionImplementationFn;\n      image?: string;\n    }[] = []\n  ): ModuleWithProviders<PryDashboardModule> {\n    additionalGridImplementations.forEach((impl) => {\n      WidgetPlacementUtils.addLayoutImplementation(impl.type, impl.sizeImpl, impl.placementImpl, impl.image);\n    });\n    return {\n      ngModule: PryDashboardModule,\n      providers: [\n        { provide: BASE_CONFIG, useValue: options },\n        { provide: WIDGET_DEFINITION, useValue: widgetReference },\n        { provide: TOOLTIP_DEFINITION, useValue: tooltipReference },\n        { provide: FILTER_DEFINITION, useValue: filterReference },\n        BusService,\n        DashboardInitService,\n        ToolboxManifestService,\n        DefaultViewGuard,\n        RefreshService,\n        PryTitleService,\n        WebsocketService,\n        ConfigService\n      ]\n    };\n  }\n}\n"]}
|
|
181
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard.module.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/lib/dashboard/dashboard.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { OverlayModule } from '@angular/cdk/overlay';\nimport { CommonModule } from '@angular/common';\nimport { ModuleWithProviders, NgModule } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { EffectsModule } from '@ngrx/effects';\nimport { StoreModule } from '@ngrx/store';\nimport { PryCheckboxModule } from '@provoly/dashboard/components/checkbox';\nimport { PryDatePickerModule } from '../core/components/date-picker/date-picker.module';\nimport { PryIconModule } from '../core/components/icon/icon.module';\nimport { PryOverlayModule } from '../core/components/overlay/overlay.module';\nimport { PrySelectModule } from '../core/components/select/select.module';\nimport { PryToggleModule } from '../core/components/toggle/toggle.module';\nimport { PryCoreModule } from '../core/core.module';\nimport { PryI18nModule } from '../core/i18n/i18n.module';\nimport { ConfigService } from '../core/store/config/config.service';\nimport { ToolboxManifestService } from '../core/toolbox/toolbox-manifest.service';\nimport { WebsocketService } from '../core/ws/websocket.service';\nimport { ActionBusEffects } from './action-bus/effect/action-bus.effects';\nimport { BusService } from './action-bus/service/bus.service';\nimport { ContextMenuComponent } from './components/context-menu/context-menu.component';\nimport { PryObjectEditionComponent } from './components/context-menu/object-edition/object-edition.component';\nimport { DashboardComponent } from './components/dashboard.component';\nimport { ManifestsComponent } from './components/manifests/manifests.component';\nimport { MetadataComponent } from './components/metadata/metadata.component';\nimport { VizualizeRawComponent } from './components/vizualize-raw/vizualize-raw.component';\nimport { BaseWidgetComponent } from './components/widgets/base-widget.component';\nimport { DataWidgetComponent } from './components/widgets/data-widget.component';\nimport { DatasourceSelectorComponent } from './components/widgets/datasource-selector/datasource-selector.component';\nimport { ResultSetSizePipe } from './components/widgets/header/resultset-size.pipe';\nimport { PryWidgetHeaderComponent } from './components/widgets/header/widget-header.component';\nimport { SettingsComponent } from './components/widgets/settings/settings.component';\nimport {\n  WIDGET_DEFINITION,\n  WidgetFactoryService\n} from './components/widgets/widget-instanciator/widget-factory.service';\nimport { WidgetInstanciatorComponent } from './components/widgets/widget-instanciator/widget-instanciator.component';\nimport { WidgetDefinition } from './components/widgets/widget-instanciator/widgets-definition.model';\nimport { WidgetPlaceholderComponent } from './components/widgets/widget-placeholder/widget-placeholder.component';\nimport {\n  LayoutPlacementOptionImplementationFn,\n  LayoutSizeImplementationFn,\n  WidgetPlacementUtils\n} from './components/widgets/widget-placement/widget-placement.utils';\nimport { BaseFilterComponent } from './filter/base-filter.component';\nimport { FilterInstanciatorComponent } from './filter/components/filter-instanciator/filter-instanciator.component';\nimport { FilterGroupComponent } from \"./filter/components/filter-group/filter-group.component\";\nimport { FILTER_DEFINITION, FilterDefinition } from './filter/filter-factory.service';\nimport { DefaultViewGuard } from './guard/default-view.guard';\nimport { BASE_CONFIG, DashboardInitService } from './store/dashboard-init.service';\nimport { DashboardEffects } from './store/dashboard.effects';\nimport { dashboardFeatureKey, dashboardReducer } from './store/dashboard.reducers';\nimport { RefreshService } from './store/refresh.service';\nimport { PryTitleService } from './store/title.service';\nimport { BaseTooltipComponent } from './tooltip/base-tooltip.component';\nimport { DefaultTooltipComponent } from './tooltip/components/default/default.tooltip.component';\nimport { TOOLTIP_DEFINITION, TooltipDefinition } from './tooltip/tooltip-factory.service';\nimport { PryFilterGroupCssComponent } from \"./filter/style/css.component\";\n\nconst components = [\n  DashboardComponent,\n  WidgetInstanciatorComponent,\n  WidgetPlaceholderComponent,\n  SettingsComponent,\n  ManifestsComponent,\n  MetadataComponent,\n  ContextMenuComponent,\n  DataWidgetComponent,\n  BaseWidgetComponent,\n  PryWidgetHeaderComponent,\n  PryObjectEditionComponent,\n  VizualizeRawComponent,\n  ResultSetSizePipe,\n  DefaultTooltipComponent,\n  BaseTooltipComponent,\n  BaseFilterComponent,\n  FilterInstanciatorComponent,\n  FilterGroupComponent,\n  DatasourceSelectorComponent\n];\n\n@NgModule({\n  declarations: [...components, PryFilterGroupCssComponent],\n  imports: [\n    CommonModule,\n    FormsModule,\n    PrySelectModule,\n    PryIconModule,\n    OverlayModule,\n    PryCoreModule,\n    PryCheckboxModule,\n    PryToggleModule,\n    PryOverlayModule,\n    StoreModule.forFeature(dashboardFeatureKey, dashboardReducer),\n    EffectsModule.forFeature([ActionBusEffects, DashboardEffects]),\n    PryDatePickerModule,\n    PryI18nModule\n  ],\n  exports: [...components],\n  providers: [WidgetFactoryService]\n})\nexport class PryDashboardModule {\n  static forRoot(\n    widgetReference: { [key: string]: WidgetDefinition },\n    options: {\n      path?: string;\n      mapUrl?: string;\n      pryUrl?: string;\n      wsUrl?: string;\n      geoServerUrl?: string;\n    },\n    tooltipReference: { [key: string]: TooltipDefinition },\n    filterReference: { [key: string]: FilterDefinition },\n    additionalGridImplementations: {\n      type: string;\n      sizeImpl: LayoutSizeImplementationFn;\n      placementImpl: LayoutPlacementOptionImplementationFn;\n      image?: string;\n    }[] = []\n  ): ModuleWithProviders<PryDashboardModule> {\n    additionalGridImplementations.forEach((impl) => {\n      WidgetPlacementUtils.addLayoutImplementation(impl.type, impl.sizeImpl, impl.placementImpl, impl.image);\n    });\n    return {\n      ngModule: PryDashboardModule,\n      providers: [\n        { provide: BASE_CONFIG, useValue: options },\n        { provide: WIDGET_DEFINITION, useValue: widgetReference },\n        { provide: TOOLTIP_DEFINITION, useValue: tooltipReference },\n        { provide: FILTER_DEFINITION, useValue: filterReference },\n        BusService,\n        DashboardInitService,\n        ToolboxManifestService,\n        DefaultViewGuard,\n        RefreshService,\n        PryTitleService,\n        WebsocketService,\n        ConfigService\n      ]\n    };\n  }\n}\n"]}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { Component, Inject } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject } from "rxjs";
|
|
3
|
+
import { DashboardSelectors } from "../../../store/dashboard.selectors";
|
|
4
|
+
import { DashboardActions } from "../../../store/dashboard.actions";
|
|
5
|
+
import { DOCUMENT } from "@angular/common";
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@ngrx/store";
|
|
8
|
+
import * as i2 from "@angular/common";
|
|
9
|
+
import * as i3 from "../../../../core/components/icon/icon.component";
|
|
10
|
+
import * as i4 from "../filter-instanciator/filter-instanciator.component";
|
|
11
|
+
import * as i5 from "../../style/css.component";
|
|
12
|
+
import * as i6 from "../../../../core/i18n/i18n.pipe";
|
|
13
|
+
export class FilterGroupComponent {
|
|
14
|
+
constructor(store, document) {
|
|
15
|
+
this.store = store;
|
|
16
|
+
this.document = document;
|
|
17
|
+
this.apply$ = new BehaviorSubject(undefined);
|
|
18
|
+
this.isSelectOpen = false;
|
|
19
|
+
this.globalManifest$ = this.store.select(DashboardSelectors.globalManifest);
|
|
20
|
+
}
|
|
21
|
+
filter() {
|
|
22
|
+
this.apply$.next();
|
|
23
|
+
this.store.dispatch(DashboardActions.dispatchFilters());
|
|
24
|
+
}
|
|
25
|
+
clearFilters() {
|
|
26
|
+
this.store.dispatch(DashboardActions.clearAllFilterValues());
|
|
27
|
+
}
|
|
28
|
+
openSelect() {
|
|
29
|
+
this.isSelectOpen =
|
|
30
|
+
this.document
|
|
31
|
+
.querySelector('.o-container__filter-container')
|
|
32
|
+
?.contains(document.querySelector('ng-dropdown-panel.ng-dropdown-panel')) || false;
|
|
33
|
+
}
|
|
34
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: FilterGroupComponent, deps: [{ token: i1.Store }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
35
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: FilterGroupComponent, selector: "pry-filter-group", ngImport: i0, template: "<pry-filter-group-css></pry-filter-group-css>\n <ng-container *ngIf=\"globalManifest$ | async as manifest\">\n <div class=\"o-container__filters\" *ngIf=\"manifest.filters && manifest.filters.length > 0\">\n <div class=\"o-container__filter-container\" (click)=\"openSelect()\" [class.o-container__filter-container--ng-select-open]=\"isSelectOpen\">\n <pry-filter-instanciator\n *ngFor=\"let filter of manifest.filters\"\n [filter]=\"filter\"\n [applyFilter$]=\"apply$\"\n ></pry-filter-instanciator>\n </div>\n <div class=\"o-container__filter-actions\">\n <button type=\"button\" class=\"a-btn a-btn--secondary a-btn--icon-only -size-md\" (click)=\"clearFilters()\">\n <pry-icon iconSvg=\"clear_filter\"></pry-icon>\n </button>\n <button type=\"button\" class=\"a-btn a-btn--primary -size-md\" (click)=\"filter()\">\n {{ '@pry.toolbox.filter' | i18n }}\n <pry-icon iconSvg=\"refresh_filter\"></pry-icon>\n </button>\n </div>\n </div>\n </ng-container>\n\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "component", type: i4.FilterInstanciatorComponent, selector: "pry-filter-instanciator", inputs: ["filter", "applyFilter$"] }, { kind: "component", type: i5.PryFilterGroupCssComponent, selector: "pry-filter-group-css" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.I18nPipe, name: "i18n" }] }); }
|
|
36
|
+
}
|
|
37
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: FilterGroupComponent, decorators: [{
|
|
38
|
+
type: Component,
|
|
39
|
+
args: [{ selector: 'pry-filter-group', template: "<pry-filter-group-css></pry-filter-group-css>\n <ng-container *ngIf=\"globalManifest$ | async as manifest\">\n <div class=\"o-container__filters\" *ngIf=\"manifest.filters && manifest.filters.length > 0\">\n <div class=\"o-container__filter-container\" (click)=\"openSelect()\" [class.o-container__filter-container--ng-select-open]=\"isSelectOpen\">\n <pry-filter-instanciator\n *ngFor=\"let filter of manifest.filters\"\n [filter]=\"filter\"\n [applyFilter$]=\"apply$\"\n ></pry-filter-instanciator>\n </div>\n <div class=\"o-container__filter-actions\">\n <button type=\"button\" class=\"a-btn a-btn--secondary a-btn--icon-only -size-md\" (click)=\"clearFilters()\">\n <pry-icon iconSvg=\"clear_filter\"></pry-icon>\n </button>\n <button type=\"button\" class=\"a-btn a-btn--primary -size-md\" (click)=\"filter()\">\n {{ '@pry.toolbox.filter' | i18n }}\n <pry-icon iconSvg=\"refresh_filter\"></pry-icon>\n </button>\n </div>\n </div>\n </ng-container>\n\n" }]
|
|
40
|
+
}], ctorParameters: function () { return [{ type: i1.Store }, { type: Document, decorators: [{
|
|
41
|
+
type: Inject,
|
|
42
|
+
args: [DOCUMENT]
|
|
43
|
+
}] }]; } });
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWdyb3VwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL2xpYi9kYXNoYm9hcmQvZmlsdGVyL2NvbXBvbmVudHMvZmlsdGVyLWdyb3VwL2ZpbHRlci1ncm91cC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2Rhc2hib2FyZC9saWIvZGFzaGJvYXJkL2ZpbHRlci9jb21wb25lbnRzL2ZpbHRlci1ncm91cC9maWx0ZXItZ3JvdXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEQsT0FBTyxFQUFFLGVBQWUsRUFBYyxNQUFNLE1BQU0sQ0FBQztBQUduRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUN4RSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNwRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0saUJBQWlCLENBQUM7Ozs7Ozs7O0FBTzNDLE1BQU0sT0FBTyxvQkFBb0I7SUFLL0IsWUFBb0IsS0FBWSxFQUE0QixRQUFrQjtRQUExRCxVQUFLLEdBQUwsS0FBSyxDQUFPO1FBQTRCLGFBQVEsR0FBUixRQUFRLENBQVU7UUFIOUUsV0FBTSxHQUFHLElBQUksZUFBZSxDQUFPLFNBQVMsQ0FBQyxDQUFDO1FBQzlDLGlCQUFZLEdBQUcsS0FBSyxDQUFDO1FBR25CLElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsa0JBQWtCLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDOUUsQ0FBQztJQUVELE1BQU07UUFDSixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ25CLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLGdCQUFnQixDQUFDLGVBQWUsRUFBRSxDQUFDLENBQUM7SUFDMUQsQ0FBQztJQUVELFlBQVk7UUFDVixJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQyxvQkFBb0IsRUFBRSxDQUFDLENBQUM7SUFDL0QsQ0FBQztJQUVELFVBQVU7UUFDUixJQUFJLENBQUMsWUFBWTtZQUNmLElBQUksQ0FBQyxRQUFRO2lCQUNWLGFBQWEsQ0FBQyxnQ0FBZ0MsQ0FBQztnQkFDaEQsRUFBRSxRQUFRLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxxQ0FBcUMsQ0FBQyxDQUFDLElBQUksS0FBSyxDQUFDO0lBQ3pGLENBQUM7OEdBdkJVLG9CQUFvQix1Q0FLVyxRQUFRO2tHQUx2QyxvQkFBb0Isd0RDYmpDLDJqQ0FzQkE7OzJGRFRhLG9CQUFvQjtrQkFMaEMsU0FBUzsrQkFDRSxrQkFBa0I7OzBCQVNPLE1BQU07MkJBQUMsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tIFwicnhqc1wiO1xuaW1wb3J0IHsgU3RvcmUgfSBmcm9tIFwiQG5ncngvc3RvcmVcIjtcbmltcG9ydCB7IEdsb2JhbE1hbmlmZXN0IH0gZnJvbSBcIi4uLy4uLy4uLy4uL2NvcmUvbW9kZWwvbWFuaWZlc3QuaW50ZXJmYWNlXCI7XG5pbXBvcnQgeyBEYXNoYm9hcmRTZWxlY3RvcnMgfSBmcm9tIFwiLi4vLi4vLi4vc3RvcmUvZGFzaGJvYXJkLnNlbGVjdG9yc1wiO1xuaW1wb3J0IHsgRGFzaGJvYXJkQWN0aW9ucyB9IGZyb20gXCIuLi8uLi8uLi9zdG9yZS9kYXNoYm9hcmQuYWN0aW9uc1wiO1xuaW1wb3J0IHsgRE9DVU1FTlQgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ByeS1maWx0ZXItZ3JvdXAnLFxuICB0ZW1wbGF0ZVVybDonLi9maWx0ZXItZ3JvdXAuY29tcG9uZW50Lmh0bWwnXG59KVxuXG5leHBvcnQgY2xhc3MgRmlsdGVyR3JvdXBDb21wb25lbnQge1xuICBnbG9iYWxNYW5pZmVzdCQ6IE9ic2VydmFibGU8R2xvYmFsTWFuaWZlc3Q+O1xuICBhcHBseSQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PHZvaWQ+KHVuZGVmaW5lZCk7XG4gIGlzU2VsZWN0T3BlbiA9IGZhbHNlO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc3RvcmU6IFN0b3JlLCBASW5qZWN0KERPQ1VNRU5UKSBwcml2YXRlIGRvY3VtZW50OiBEb2N1bWVudCkge1xuICAgIHRoaXMuZ2xvYmFsTWFuaWZlc3QkID0gdGhpcy5zdG9yZS5zZWxlY3QoRGFzaGJvYXJkU2VsZWN0b3JzLmdsb2JhbE1hbmlmZXN0KTtcbiAgfVxuXG4gIGZpbHRlcigpIHtcbiAgICB0aGlzLmFwcGx5JC5uZXh0KCk7XG4gICAgdGhpcy5zdG9yZS5kaXNwYXRjaChEYXNoYm9hcmRBY3Rpb25zLmRpc3BhdGNoRmlsdGVycygpKTtcbiAgfVxuXG4gIGNsZWFyRmlsdGVycygpIHtcbiAgICB0aGlzLnN0b3JlLmRpc3BhdGNoKERhc2hib2FyZEFjdGlvbnMuY2xlYXJBbGxGaWx0ZXJWYWx1ZXMoKSk7XG4gIH1cblxuICBvcGVuU2VsZWN0KCkge1xuICAgIHRoaXMuaXNTZWxlY3RPcGVuID1cbiAgICAgIHRoaXMuZG9jdW1lbnRcbiAgICAgICAgLnF1ZXJ5U2VsZWN0b3IoJy5vLWNvbnRhaW5lcl9fZmlsdGVyLWNvbnRhaW5lcicpXG4gICAgICAgID8uY29udGFpbnMoZG9jdW1lbnQucXVlcnlTZWxlY3RvcignbmctZHJvcGRvd24tcGFuZWwubmctZHJvcGRvd24tcGFuZWwnKSkgfHwgZmFsc2U7XG4gIH1cbn1cbiIsIjxwcnktZmlsdGVyLWdyb3VwLWNzcz48L3ByeS1maWx0ZXItZ3JvdXAtY3NzPlxuICA8bmctY29udGFpbmVyICpuZ0lmPVwiZ2xvYmFsTWFuaWZlc3QkIHwgYXN5bmMgYXMgbWFuaWZlc3RcIj5cbiAgICA8ZGl2IGNsYXNzPVwiby1jb250YWluZXJfX2ZpbHRlcnNcIiAqbmdJZj1cIm1hbmlmZXN0LmZpbHRlcnMgJiYgbWFuaWZlc3QuZmlsdGVycy5sZW5ndGggPiAwXCI+XG4gICAgICA8ZGl2IGNsYXNzPVwiby1jb250YWluZXJfX2ZpbHRlci1jb250YWluZXJcIiAoY2xpY2spPVwib3BlblNlbGVjdCgpXCIgW2NsYXNzLm8tY29udGFpbmVyX19maWx0ZXItY29udGFpbmVyLS1uZy1zZWxlY3Qtb3Blbl09XCJpc1NlbGVjdE9wZW5cIj5cbiAgICAgICAgPHByeS1maWx0ZXItaW5zdGFuY2lhdG9yXG4gICAgICAgICAgKm5nRm9yPVwibGV0IGZpbHRlciBvZiBtYW5pZmVzdC5maWx0ZXJzXCJcbiAgICAgICAgICBbZmlsdGVyXT1cImZpbHRlclwiXG4gICAgICAgICAgW2FwcGx5RmlsdGVyJF09XCJhcHBseSRcIlxuICAgICAgICA+PC9wcnktZmlsdGVyLWluc3RhbmNpYXRvcj5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cIm8tY29udGFpbmVyX19maWx0ZXItYWN0aW9uc1wiPlxuICAgICAgICA8YnV0dG9uIHR5cGU9XCJidXR0b25cIiBjbGFzcz1cImEtYnRuIGEtYnRuLS1zZWNvbmRhcnkgYS1idG4tLWljb24tb25seSAtc2l6ZS1tZFwiIChjbGljayk9XCJjbGVhckZpbHRlcnMoKVwiPlxuICAgICAgICAgIDxwcnktaWNvbiBpY29uU3ZnPVwiY2xlYXJfZmlsdGVyXCI+PC9wcnktaWNvbj5cbiAgICAgICAgPC9idXR0b24+XG4gICAgICAgIDxidXR0b24gdHlwZT1cImJ1dHRvblwiIGNsYXNzPVwiYS1idG4gYS1idG4tLXByaW1hcnkgLXNpemUtbWRcIiAoY2xpY2spPVwiZmlsdGVyKClcIj5cbiAgICAgICAgICB7eyAnQHByeS50b29sYm94LmZpbHRlcicgfCBpMThuIH19XG4gICAgICAgICAgPHByeS1pY29uIGljb25Tdmc9XCJyZWZyZXNoX2ZpbHRlclwiPjwvcHJ5LWljb24+XG4gICAgICAgIDwvYnV0dG9uPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIDwvbmctY29udGFpbmVyPlxuXG4iXX0=
|
|
@@ -3,4 +3,6 @@ export * from './base-filter.module';
|
|
|
3
3
|
export * from './filter-factory.service';
|
|
4
4
|
export * from './filter-loader.function';
|
|
5
5
|
export * from './components/filter-instanciator/filter-instanciator.component';
|
|
6
|
-
|
|
6
|
+
export * from './components/filter-group/filter-group.component';
|
|
7
|
+
export * from './style/css.component';
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL2xpYi9kYXNoYm9hcmQvZmlsdGVyL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLGdFQUFnRSxDQUFDO0FBQy9FLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyx1QkFBdUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYmFzZS1maWx0ZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vYmFzZS1maWx0ZXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vZmlsdGVyLWZhY3Rvcnkuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2ZpbHRlci1sb2FkZXIuZnVuY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2ZpbHRlci1pbnN0YW5jaWF0b3IvZmlsdGVyLWluc3RhbmNpYXRvci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2ZpbHRlci1ncm91cC9maWx0ZXItZ3JvdXAuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc3R5bGUvY3NzLmNvbXBvbmVudCc7XG4iXX0=
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Component, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class PryFilterGroupCssComponent {
|
|
4
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryFilterGroupCssComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
5
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: PryFilterGroupCssComponent, selector: "pry-filter-group-css", ngImport: i0, template: '', isInline: true, styles: [".o-container{height:100%}.o-container__filters{display:flex;padding:.5rem .625rem;max-height:60px;gap:.625rem}.o-container__filter-container{display:flex;justify-content:flex-start;margin-bottom:-.3125rem;max-height:60px;padding:.25rem 0;overflow-x:auto;overflow-y:hidden}.o-container__filter-container:has(ng-dropdown-panel.ng-dropdown-panel){padding-bottom:350px;background-clip:content-box,padding-box;overflow-x:hidden}.o-container__filter-container--ng-select-open{padding-bottom:350px;background-clip:content-box,padding-box}.o-container__filter-actions{display:flex;align-items:center;gap:.625rem;padding:0 .625rem}\n"], encapsulation: i0.ViewEncapsulation.None }); }
|
|
6
|
+
}
|
|
7
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryFilterGroupCssComponent, decorators: [{
|
|
8
|
+
type: Component,
|
|
9
|
+
args: [{ selector: 'pry-filter-group-css', template: '', encapsulation: ViewEncapsulation.None, styles: [".o-container{height:100%}.o-container__filters{display:flex;padding:.5rem .625rem;max-height:60px;gap:.625rem}.o-container__filter-container{display:flex;justify-content:flex-start;margin-bottom:-.3125rem;max-height:60px;padding:.25rem 0;overflow-x:auto;overflow-y:hidden}.o-container__filter-container:has(ng-dropdown-panel.ng-dropdown-panel){padding-bottom:350px;background-clip:content-box,padding-box;overflow-x:hidden}.o-container__filter-container--ng-select-open{padding-bottom:350px;background-clip:content-box,padding-box}.o-container__filter-actions{display:flex;align-items:center;gap:.625rem;padding:0 .625rem}\n"] }]
|
|
10
|
+
}] });
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3NzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL2xpYi9kYXNoYm9hcmQvZmlsdGVyL3N0eWxlL2Nzcy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFPN0QsTUFBTSxPQUFPLDBCQUEwQjs4R0FBMUIsMEJBQTBCO2tHQUExQiwwQkFBMEIsNERBSjNCLEVBQUU7OzJGQUlELDBCQUEwQjtrQkFOdEMsU0FBUzsrQkFDRSxzQkFBc0IsWUFDdEIsRUFBRSxpQkFFRyxpQkFBaUIsQ0FBQyxJQUFJIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncHJ5LWZpbHRlci1ncm91cC1jc3MnLFxuICB0ZW1wbGF0ZTogJycsXG4gIHN0eWxlVXJsczogWycuL19vLXByeS1maWx0ZXItZ3JvdXAuc2NzcyddLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lXG59KVxuZXhwb3J0IGNsYXNzIFByeUZpbHRlckdyb3VwQ3NzQ29tcG9uZW50IHt9XG4iXX0=
|
|
@@ -109,6 +109,7 @@ export class PryPresentationComponent extends SubscriptionnerDirective {
|
|
|
109
109
|
this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.EDITION }));
|
|
110
110
|
this.store.dispatch(DashboardActions.fetchStaticManifest({ id: presentation.id }));
|
|
111
111
|
this.store.dispatch(DashboardActions.updateDisplayOptions({ mode: DisplayMode.EDIT }));
|
|
112
|
+
this.search$.next('');
|
|
112
113
|
}
|
|
113
114
|
delete(id) {
|
|
114
115
|
this.store.dispatch(DashboardActions.confirmManifestDeletion({ id }));
|
|
@@ -201,4 +202,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
|
|
|
201
202
|
}], meAsOwner: [{
|
|
202
203
|
type: Input
|
|
203
204
|
}] } });
|
|
204
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"presentation.component.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/presentation/components/presentation.component.ts","../../../../../../projects/provoly/dashboard/presentation/components/presentation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { Component, ElementRef, Input, NgZone, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  DashboardActions,\n  DashboardGridLayout,\n  DashboardManifest,\n  DashboardSelectors,\n  DisplayMode,\n  GlobalManifest,\n  ManifestDescription,\n  PryTitleService,\n  PryVisibility,\n  PryVisibilityType,\n  SubscriptionnerDirective,\n  ViewMode\n} from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, debounceTime, map, Observable, take } from 'rxjs';\nimport { v4 } from 'uuid';\n\n@Component({\n  selector: 'pry-presentation',\n  templateUrl: './presentation.component.html'\n})\nexport class PryPresentationComponent extends SubscriptionnerDirective {\n  manifests$: Observable<ManifestDescription[]>;\n  selectedPresentation$ = new BehaviorSubject<ManifestDescription | null>(null);\n  presentation?: ManifestDescription;\n  staticManifest$?: Observable<DashboardManifest>;\n  selectedMode: ViewMode = ViewMode.CATALOG;\n  modalOpened = false;\n  @ViewChild('modal', { read: TemplateRef }) template!: TemplateRef<any>;\n  @ViewChild('templateModal', { read: TemplateRef }) templateModal!: TemplateRef<any>;\n  @ViewChild('openModal') openModal!: ElementRef<HTMLButtonElement>;\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  @ViewChild('visibilityModal') visibilityModal!: ElementRef;\n  overlayRef?: OverlayRef;\n  visibility: PryVisibility = { type: PryVisibilityType.PRIVATE };\n  PryVisibilityType = PryVisibilityType;\n  @Input() editionStartUrl: string = '/';\n  @Input() consultStartUrl: string = '/';\n  @Input() meAsOwner?: string;\n  ViewMode = ViewMode;\n  search$ = new BehaviorSubject('');\n  filteredPresentations$: Observable<ManifestDescription[]>;\n\n  constructor(\n    protected store: Store<any>,\n    protected overlay: Overlay,\n    protected viewContainerRef: ViewContainerRef,\n    protected router: Router,\n    protected ngZone: NgZone,\n    protected titleService: PryTitleService\n  ) {\n    super();\n    this.store.dispatch(DashboardActions.fetchManifestsList());\n    this.manifests$ = this.store\n      .select(DashboardSelectors.manifestsList)\n      .pipe(\n        map((manifestList) =>\n          [...manifestList].sort((a, b) =>\n            a.modificationDate ? b.modificationDate.localeCompare(a.modificationDate) : 1\n          )\n        )\n      );\n    this.staticManifest$ = this.store\n      .select(DashboardSelectors.staticManifest)\n      .pipe(map((staticM) => staticM.windows[0]));\n    this.filteredPresentations$ = combineLatest([this.manifests$, this.search$]).pipe(\n      map(([presentations, search]) =>\n        presentations.filter(\n          (presentations) =>\n            search.length === 0 ||\n            presentations.description.toLowerCase().includes(search.toLowerCase()) ||\n            presentations.name.toLowerCase().includes(search.toLowerCase())\n        )\n      )\n    );\n    this.subscriptions.add(\n      this.store.select(DashboardSelectors.presentation).subscribe((presentation) => {\n        if (!!presentation.current) {\n          this.selectedPresentation$.next(presentation.current ?? null);\n          this.selectedMode = presentation?.viewMode ?? this.ViewMode.CATALOG;\n        }\n      })\n    );\n    this.titleService.changeTitle('@pry.presentation.title');\n  }\n\n  closeRestitution() {\n    this.selectedPresentation$.next(null);\n    this.selectedMode = ViewMode.CATALOG;\n    this.store.dispatch(DashboardActions.selectPresentation({ presentation: undefined, viewMode: ViewMode.CATALOG }));\n  }\n\n  fetch(presentation: ManifestDescription) {\n    this.store.dispatch(\n      DashboardActions.updateManifest({\n        manifest: { windows: [] },\n        selectedIds: []\n      })\n    );\n    this.store.dispatch(\n      DashboardActions.selectPresentation({\n        presentation: presentation,\n        viewMode: ViewMode.CATALOG\n      })\n    );\n    this.titleService.changeTitle(presentation.name);\n    this.store.dispatch(DashboardActions.fetchStaticManifest({ id: presentation.id }));\n    this.store\n      .select(DashboardSelectors.staticManifest)\n      .pipe(debounceTime(1000), take(1))\n      .subscribe((staticManifest: GlobalManifest) => {\n        this.store.dispatch(\n          DashboardActions.updateManifest({\n            manifest: staticManifest,\n            selectedIds: [],\n            manifestId: presentation.id\n          })\n        );\n        this.store.dispatch(\n          DashboardActions.setInitialPresentation({\n            initial: staticManifest\n          })\n        );\n      });\n    this.store.dispatch(DashboardActions.updateDisplayOptions({ mode: DisplayMode.CONSULT }));\n    this.store.dispatch(DashboardActions.followManifestRoute());\n    this.ngZone.run(() => {\n      this.router?.navigateByUrl(this.consultStartUrl);\n    });\n  }\n\n  creation() {\n    this.selectedMode = ViewMode.CREATION;\n    this.store.dispatch(DashboardActions.updateManifest({ manifest: { windows: [] }, selectedIds: [] }));\n    const newPresentation = {\n      presentation: {\n        id: v4(),\n        name: '',\n        description: '',\n        visibility: { type: PryVisibilityType.PRIVATE },\n        owner: true\n      } as ManifestDescription,\n      viewMode: ViewMode.CREATION\n    };\n    this.store.dispatch(DashboardActions.selectPresentation(newPresentation));\n    this.store.dispatch(DashboardActions.setGridLayout({ layout: DashboardGridLayout.FULL }));\n    this.store.dispatch(DashboardActions.updateDisplayOptions({ mode: DisplayMode.CREATE }));\n  }\n\n  edit(presentation: ManifestDescription) {\n    this.selectedMode = ViewMode.EDITION;\n    this.selectedPresentation$.next(presentation);\n    this.titleService.changeTitle(presentation.name);\n    this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.EDITION }));\n    this.store.dispatch(DashboardActions.fetchStaticManifest({ id: presentation.id }));\n    this.store.dispatch(DashboardActions.updateDisplayOptions({ mode: DisplayMode.EDIT }));\n  }\n\n  delete(id: string) {\n    this.store.dispatch(DashboardActions.confirmManifestDeletion({ id }));\n  }\n\n  default(id: string, name: string) {\n    this.store.dispatch(DashboardActions.defaultManifest({ id, name }));\n  }\n\n  toggleModal(presentation?: ManifestDescription | null) {\n    this.modalOpened = !this.modalOpened;\n    if (this.modalOpened && presentation) {\n      this.selectedPresentation$.next(presentation);\n      this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.CATALOG }));\n      /* we need to load manifest in order to be able to save it later */\n      this.store.dispatch(DashboardActions.loadManifest({ id: presentation.id }));\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['o-modal-wrapper'],\n          backdropClass: 'backdrop'\n        })\n      );\n      this.overlayRef.backdropClick().subscribe(() => this.toggleModal(presentation));\n      this.overlayRef.attach(new TemplatePortal(this.template, this.viewContainerRef));\n      setTimeout(() => {\n        const focus = this.visibilityModal.nativeElement.children[0].children[1].firstElementChild as HTMLButtonElement;\n        focus.focus();\n      }, 10);\n    } else {\n      this.overlayRef?.dispose();\n      this.selectedPresentation$.next(null);\n    }\n  }\n\n  changeVisibility(presentation?: ManifestDescription) {\n    if (presentation) {\n      this.store.dispatch(\n        DashboardActions.saveManifest({\n          id: presentation.id ?? '',\n          name: presentation.name ?? '',\n          description: presentation.description ?? '',\n          image: presentation.image ?? '',\n          visibility: this.visibility\n        })\n      );\n    }\n    this.toggleModal(presentation);\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","<pry-presentation-css></pry-presentation-css>\n<div class=\"o-manifest-layout\" [ngSwitch]=\"selectedMode\">\n  <ng-container *ngSwitchCase=\"ViewMode.CATALOG\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button\n        class=\"a-btn a-btn--primary a-btn--icon-text a-tooltip\"\n        [attr.data-tooltip]=\"'@pry.presentation.create' | i18n\"\n        data-tooltip-position=\"bottom\"\n        type=\"button\"\n        (click)=\"creation()\"\n        *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'create' }\"\n      >\n        {{ '@pry.presentation.create' | i18n }}\n      </button>\n      <div>\n        <div class=\"a-presentation__search\">\n          <label id=\"catalog-search-label\" for=\"catalog-search\" class=\"u-visually-hidden\">\n            <span>{{ '@pry.toolbox.catalog.filter.name' | i18n }}</span>\n          </label>\n          <input\n            id=\"catalog-search\"\n            type=\"text\"\n            class=\"a-form-field\"\n            [placeholder]=\"'@pry.presentation.search' | i18n\"\n            [ngModel]=\"search$ | async\"\n            (ngModelChange)=\"this.search$.next($event)\"\n          />\n          <pry-icon iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n        </div>\n      </div>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <h1 class=\"a-h1\">{{ '@pry.presentation.title' | i18n }}</h1>\n      <div class=\"o-presentation-wrapper\">\n        <ul class=\"o-presentation\">\n          <li class=\"o-presentation__item\" *ngFor=\"let presentation of filteredPresentations$ | async\">\n            <div class=\"o-presentation__item__header\">\n              <ng-container *ngIf=\"presentation.visibility.type === PryVisibilityType.PRIVATE\">\n                <pry-icon\n                  [iconSvg]=\"presentation.visibility.type.toLowerCase()\"\n                  class=\"is-private a-tooltip\"\n                  [attr.data-tooltip]=\"'@pry.presentation.private' | i18n\"\n                  [height]=\"17\"\n                  [width]=\"17\"\n                ></pry-icon>\n              </ng-container>\n              <div class=\"a-tooltip\" [attr.data-tooltip]=\"'@pry.presentation.view' | i18n\">\n                <div class=\"o-presentation__item__image\">\n                  <img\n                    alt=\"\"\n                    [height]=\"presentation.cover ? 600 : 128\"\n                    [width]=\"presentation.cover ? 600 : 128\"\n                    [class.is-full-width]=\"presentation.cover\"\n                    [src]=\"presentation.image | getSecuredImage | async\"\n                    (click)=\"fetch(presentation)\"\n                  />\n                </div>\n              </div>\n            </div>\n\n            <div class=\"o-presentation__item__txt\">\n              <h3 class=\"a-h3\">{{ presentation.name }}</h3>\n              <div class=\"a-p\">\n                <div class=\"description-container\">\n                  <span class=\"description\">\n                    {{ presentation.description }}\n                  </span>\n                  <div class=\"description-tooltip\">{{ presentation.description }}</div>\n                </div>\n              </div>\n              <p class=\"a-p -date\">{{ presentation.modificationDate | sinceDate }}</p>\n            </div>\n\n            <div class=\"o-presentation__item__footer\">\n              <ul class=\"m-actions-list\">\n                <li>\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--icon-only a-tooltip\"\n                    [attr.data-tooltip]=\"'@pry.presentation.homeView' | i18n\"\n                    (click)=\"default(presentation.id, presentation.name)\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'default' }\"\n                  >\n                    <pry-icon [iconSvg]=\"presentation.default ? 'home-fill' : 'home-line'\"></pry-icon>\n                    <span class=\"u-visually-hidden\"></span>\n                  </button>\n                </li>\n                <li>\n                  <button\n                    class=\"a-btn a-btn--icon-only a-tooltip\"\n                    [attr.data-tooltip]=\"'@pry.presentation.change' | i18n\"\n                    (click)=\"edit(presentation)\"\n                    [disabled]=\"!presentation.owner\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'edit' }\"\n                  >\n                    <pry-icon iconSvg=\"edit\"></pry-icon>\n                    <span class=\"u-visually-hidden\">{{ '@pry.presentation.edition' | i18n }}</span>\n                  </button>\n                </li>\n                <li>\n                  <button\n                    (click)=\"toggleModal(presentation)\"\n                    class=\"a-btn a-btn--icon-only a-tooltip\"\n                    [attr.data-tooltip]=\"'@pry.presentation.share' | i18n\"\n                    aria-haspopup=\"dialog\"\n                    [disabled]=\"!presentation.owner\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'share' }\"\n                  >\n                    <pry-icon iconSvg=\"share\"></pry-icon>\n                    <span class=\"u-visually-hidden\">{{ '@pry.presentation.share' | i18n }}</span>\n                  </button>\n                </li>\n                <li>\n                  <button\n                    class=\"a-btn a-btn--icon-only a-tooltip\"\n                    [attr.data-tooltip]=\"'@pry.presentation.erase' | i18n\"\n                    #openModal\n                    (click)=\"delete(presentation.id)\"\n                    [disabled]=\"!presentation.owner\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'delete' }\"\n                  >\n                    <pry-icon iconSvg=\"delete\"></pry-icon>\n                    <span class=\"u-visually-hidden\">{{ '@pry.presentation.delete' | i18n }}</span>\n                  </button>\n                </li>\n              </ul>\n            </div>\n          </li>\n        </ul>\n      </div>\n    </div>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"ViewMode.CREATION\">\n    <pry-add-edit-presentation\n      [selectedPresentation]=\"selectedPresentation$ | async\"\n      (goBack)=\"closeRestitution()\"\n      [editionStartUrl]=\"editionStartUrl\"\n      [edition]=\"false\"\n    ></pry-add-edit-presentation>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"ViewMode.EDITION\">\n    <pry-add-edit-presentation\n      [selectedPresentation]=\"selectedPresentation$ | async\"\n      (goBack)=\"closeRestitution()\"\n      [editionStartUrl]=\"editionStartUrl\"\n      [edition]=\"true\"\n    ></pry-add-edit-presentation>\n  </ng-container>\n</div>\n\n<ng-template #modal>\n  <div\n    class=\"o-modal\"\n    (click)=\"$event.stopPropagation()\"\n    #visibilityModal\n    role=\"dialog\"\n    aria-modal=\"true\"\n    aria-labelledby=\"dialog change visibility\"\n    *ngIf=\"selectedPresentation$ | async as selectedPresentation\"\n  >\n    <div class=\"o-modal__top\">\n      <div class=\"o-modal__top__title\">\n        <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.rename' | i18n }}</h2>\n      </div>\n      <div class=\"o-modal__top__close\">\n        <button\n          class=\"a-btn a-btn--icon-only\"\n          #crossVisibility\n          (keydown.shift.tab)=\"focusValidation()\"\n          (click)=\"toggleModal()\"\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-share [ngModel]=\"selectedPresentation.visibility\" (ngModelChange)=\"visibility = $event\"></pry-share>\n    <div class=\"m-btn-group\">\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)=\"changeVisibility(selectedPresentation)\"\n      >\n        {{ '@pry.toolbox.manifest.check' | i18n }}\n      </button>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
205
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"presentation.component.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/presentation/components/presentation.component.ts","../../../../../../projects/provoly/dashboard/presentation/components/presentation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { Component, ElementRef, Input, NgZone, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  DashboardActions,\n  DashboardGridLayout,\n  DashboardManifest,\n  DashboardSelectors,\n  DisplayMode,\n  GlobalManifest,\n  ManifestDescription,\n  PryTitleService,\n  PryVisibility,\n  PryVisibilityType,\n  SubscriptionnerDirective,\n  ViewMode\n} from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, debounceTime, map, Observable, take } from 'rxjs';\nimport { v4 } from 'uuid';\n\n@Component({\n  selector: 'pry-presentation',\n  templateUrl: './presentation.component.html'\n})\nexport class PryPresentationComponent extends SubscriptionnerDirective {\n  manifests$: Observable<ManifestDescription[]>;\n  selectedPresentation$ = new BehaviorSubject<ManifestDescription | null>(null);\n  presentation?: ManifestDescription;\n  staticManifest$?: Observable<DashboardManifest>;\n  selectedMode: ViewMode = ViewMode.CATALOG;\n  modalOpened = false;\n  @ViewChild('modal', { read: TemplateRef }) template!: TemplateRef<any>;\n  @ViewChild('templateModal', { read: TemplateRef }) templateModal!: TemplateRef<any>;\n  @ViewChild('openModal') openModal!: ElementRef<HTMLButtonElement>;\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  @ViewChild('visibilityModal') visibilityModal!: ElementRef;\n  overlayRef?: OverlayRef;\n  visibility: PryVisibility = { type: PryVisibilityType.PRIVATE };\n  PryVisibilityType = PryVisibilityType;\n  @Input() editionStartUrl: string = '/';\n  @Input() consultStartUrl: string = '/';\n  @Input() meAsOwner?: string;\n  ViewMode = ViewMode;\n  search$ = new BehaviorSubject('');\n  filteredPresentations$: Observable<ManifestDescription[]>;\n\n  constructor(\n    protected store: Store<any>,\n    protected overlay: Overlay,\n    protected viewContainerRef: ViewContainerRef,\n    protected router: Router,\n    protected ngZone: NgZone,\n    protected titleService: PryTitleService\n  ) {\n    super();\n    this.store.dispatch(DashboardActions.fetchManifestsList());\n    this.manifests$ = this.store\n      .select(DashboardSelectors.manifestsList)\n      .pipe(\n        map((manifestList) =>\n          [...manifestList].sort((a, b) =>\n            a.modificationDate ? b.modificationDate.localeCompare(a.modificationDate) : 1\n          )\n        )\n      );\n    this.staticManifest$ = this.store\n      .select(DashboardSelectors.staticManifest)\n      .pipe(map((staticM) => staticM.windows[0]));\n    this.filteredPresentations$ = combineLatest([this.manifests$, this.search$]).pipe(\n      map(([presentations, search]) =>\n        presentations.filter(\n          (presentations) =>\n            search.length === 0 ||\n            presentations.description.toLowerCase().includes(search.toLowerCase()) ||\n            presentations.name.toLowerCase().includes(search.toLowerCase())\n        )\n      )\n    );\n    this.subscriptions.add(\n      this.store.select(DashboardSelectors.presentation).subscribe((presentation) => {\n        if (!!presentation.current) {\n          this.selectedPresentation$.next(presentation.current ?? null);\n          this.selectedMode = presentation?.viewMode ?? this.ViewMode.CATALOG;\n        }\n      })\n    );\n    this.titleService.changeTitle('@pry.presentation.title');\n  }\n\n  closeRestitution() {\n    this.selectedPresentation$.next(null);\n    this.selectedMode = ViewMode.CATALOG;\n    this.store.dispatch(DashboardActions.selectPresentation({ presentation: undefined, viewMode: ViewMode.CATALOG }));\n  }\n\n  fetch(presentation: ManifestDescription) {\n    this.store.dispatch(\n      DashboardActions.updateManifest({\n        manifest: { windows: [] },\n        selectedIds: []\n      })\n    );\n    this.store.dispatch(\n      DashboardActions.selectPresentation({\n        presentation: presentation,\n        viewMode: ViewMode.CATALOG\n      })\n    );\n    this.titleService.changeTitle(presentation.name);\n    this.store.dispatch(DashboardActions.fetchStaticManifest({ id: presentation.id }));\n    this.store\n      .select(DashboardSelectors.staticManifest)\n      .pipe(debounceTime(1000), take(1))\n      .subscribe((staticManifest: GlobalManifest) => {\n        this.store.dispatch(\n          DashboardActions.updateManifest({\n            manifest: staticManifest,\n            selectedIds: [],\n            manifestId: presentation.id\n          })\n        );\n        this.store.dispatch(\n          DashboardActions.setInitialPresentation({\n            initial: staticManifest\n          })\n        );\n      });\n    this.store.dispatch(DashboardActions.updateDisplayOptions({ mode: DisplayMode.CONSULT }));\n    this.store.dispatch(DashboardActions.followManifestRoute());\n    this.ngZone.run(() => {\n      this.router?.navigateByUrl(this.consultStartUrl);\n    });\n  }\n\n  creation() {\n    this.selectedMode = ViewMode.CREATION;\n    this.store.dispatch(DashboardActions.updateManifest({ manifest: { windows: [] }, selectedIds: [] }));\n    const newPresentation = {\n      presentation: {\n        id: v4(),\n        name: '',\n        description: '',\n        visibility: { type: PryVisibilityType.PRIVATE },\n        owner: true\n      } as ManifestDescription,\n      viewMode: ViewMode.CREATION\n    };\n    this.store.dispatch(DashboardActions.selectPresentation(newPresentation));\n    this.store.dispatch(DashboardActions.setGridLayout({ layout: DashboardGridLayout.FULL }));\n    this.store.dispatch(DashboardActions.updateDisplayOptions({ mode: DisplayMode.CREATE }));\n  }\n\n  edit(presentation: ManifestDescription) {\n    this.selectedMode = ViewMode.EDITION;\n    this.selectedPresentation$.next(presentation);\n    this.titleService.changeTitle(presentation.name);\n    this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.EDITION }));\n    this.store.dispatch(DashboardActions.fetchStaticManifest({ id: presentation.id }));\n    this.store.dispatch(DashboardActions.updateDisplayOptions({ mode: DisplayMode.EDIT }));\n    this.search$.next('');\n  }\n\n  delete(id: string) {\n    this.store.dispatch(DashboardActions.confirmManifestDeletion({ id }));\n  }\n\n  default(id: string, name: string) {\n    this.store.dispatch(DashboardActions.defaultManifest({ id, name }));\n  }\n\n  toggleModal(presentation?: ManifestDescription | null) {\n    this.modalOpened = !this.modalOpened;\n    if (this.modalOpened && presentation) {\n      this.selectedPresentation$.next(presentation);\n      this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.CATALOG }));\n      /* we need to load manifest in order to be able to save it later */\n      this.store.dispatch(DashboardActions.loadManifest({ id: presentation.id }));\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['o-modal-wrapper'],\n          backdropClass: 'backdrop'\n        })\n      );\n      this.overlayRef.backdropClick().subscribe(() => this.toggleModal(presentation));\n      this.overlayRef.attach(new TemplatePortal(this.template, this.viewContainerRef));\n      setTimeout(() => {\n        const focus = this.visibilityModal.nativeElement.children[0].children[1].firstElementChild as HTMLButtonElement;\n        focus.focus();\n      }, 10);\n    } else {\n      this.overlayRef?.dispose();\n      this.selectedPresentation$.next(null);\n    }\n  }\n\n  changeVisibility(presentation?: ManifestDescription) {\n    if (presentation) {\n      this.store.dispatch(\n        DashboardActions.saveManifest({\n          id: presentation.id ?? '',\n          name: presentation.name ?? '',\n          description: presentation.description ?? '',\n          image: presentation.image ?? '',\n          visibility: this.visibility\n        })\n      );\n    }\n    this.toggleModal(presentation);\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","<pry-presentation-css></pry-presentation-css>\n<div class=\"o-manifest-layout\" [ngSwitch]=\"selectedMode\">\n  <ng-container *ngSwitchCase=\"ViewMode.CATALOG\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button\n        class=\"a-btn a-btn--primary a-btn--icon-text a-tooltip\"\n        [attr.data-tooltip]=\"'@pry.presentation.create' | i18n\"\n        data-tooltip-position=\"bottom\"\n        type=\"button\"\n        (click)=\"creation()\"\n        *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'create' }\"\n      >\n        {{ '@pry.presentation.create' | i18n }}\n      </button>\n      <div>\n        <div class=\"a-presentation__search\">\n          <label id=\"catalog-search-label\" for=\"catalog-search\" class=\"u-visually-hidden\">\n            <span>{{ '@pry.toolbox.catalog.filter.name' | i18n }}</span>\n          </label>\n          <input\n            id=\"catalog-search\"\n            type=\"text\"\n            class=\"a-form-field\"\n            [placeholder]=\"'@pry.presentation.search' | i18n\"\n            [ngModel]=\"search$ | async\"\n            (ngModelChange)=\"this.search$.next($event)\"\n          />\n          <pry-icon iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n        </div>\n      </div>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <h1 class=\"a-h1\">{{ '@pry.presentation.title' | i18n }}</h1>\n      <div class=\"o-presentation-wrapper\">\n        <ul class=\"o-presentation\">\n          <li class=\"o-presentation__item\" *ngFor=\"let presentation of filteredPresentations$ | async\">\n            <div class=\"o-presentation__item__header\">\n              <ng-container *ngIf=\"presentation.visibility.type === PryVisibilityType.PRIVATE\">\n                <pry-icon\n                  [iconSvg]=\"presentation.visibility.type.toLowerCase()\"\n                  class=\"is-private a-tooltip\"\n                  [attr.data-tooltip]=\"'@pry.presentation.private' | i18n\"\n                  [height]=\"17\"\n                  [width]=\"17\"\n                ></pry-icon>\n              </ng-container>\n              <div class=\"a-tooltip\" [attr.data-tooltip]=\"'@pry.presentation.view' | i18n\">\n                <div class=\"o-presentation__item__image\">\n                  <img\n                    alt=\"\"\n                    [height]=\"presentation.cover ? 600 : 128\"\n                    [width]=\"presentation.cover ? 600 : 128\"\n                    [class.is-full-width]=\"presentation.cover\"\n                    [src]=\"presentation.image | getSecuredImage | async\"\n                    (click)=\"fetch(presentation)\"\n                  />\n                </div>\n              </div>\n            </div>\n\n            <div class=\"o-presentation__item__txt\">\n              <h3 class=\"a-h3\">{{ presentation.name }}</h3>\n              <div class=\"a-p\">\n                <div class=\"description-container\">\n                  <span class=\"description\">\n                    {{ presentation.description }}\n                  </span>\n                  <div class=\"description-tooltip\">{{ presentation.description }}</div>\n                </div>\n              </div>\n              <p class=\"a-p -date\">{{ presentation.modificationDate | sinceDate }}</p>\n            </div>\n\n            <div class=\"o-presentation__item__footer\">\n              <ul class=\"m-actions-list\">\n                <li>\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--icon-only a-tooltip\"\n                    [attr.data-tooltip]=\"'@pry.presentation.homeView' | i18n\"\n                    (click)=\"default(presentation.id, presentation.name)\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'default' }\"\n                  >\n                    <pry-icon [iconSvg]=\"presentation.default ? 'home-fill' : 'home-line'\"></pry-icon>\n                    <span class=\"u-visually-hidden\"></span>\n                  </button>\n                </li>\n                <li>\n                  <button\n                    class=\"a-btn a-btn--icon-only a-tooltip\"\n                    [attr.data-tooltip]=\"'@pry.presentation.change' | i18n\"\n                    (click)=\"edit(presentation)\"\n                    [disabled]=\"!presentation.owner\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'edit' }\"\n                  >\n                    <pry-icon iconSvg=\"edit\"></pry-icon>\n                    <span class=\"u-visually-hidden\">{{ '@pry.presentation.edition' | i18n }}</span>\n                  </button>\n                </li>\n                <li>\n                  <button\n                    (click)=\"toggleModal(presentation)\"\n                    class=\"a-btn a-btn--icon-only a-tooltip\"\n                    [attr.data-tooltip]=\"'@pry.presentation.share' | i18n\"\n                    aria-haspopup=\"dialog\"\n                    [disabled]=\"!presentation.owner\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'share' }\"\n                  >\n                    <pry-icon iconSvg=\"share\"></pry-icon>\n                    <span class=\"u-visually-hidden\">{{ '@pry.presentation.share' | i18n }}</span>\n                  </button>\n                </li>\n                <li>\n                  <button\n                    class=\"a-btn a-btn--icon-only a-tooltip\"\n                    [attr.data-tooltip]=\"'@pry.presentation.erase' | i18n\"\n                    #openModal\n                    (click)=\"delete(presentation.id)\"\n                    [disabled]=\"!presentation.owner\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'delete' }\"\n                  >\n                    <pry-icon iconSvg=\"delete\"></pry-icon>\n                    <span class=\"u-visually-hidden\">{{ '@pry.presentation.delete' | i18n }}</span>\n                  </button>\n                </li>\n              </ul>\n            </div>\n          </li>\n        </ul>\n      </div>\n    </div>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"ViewMode.CREATION\">\n    <pry-add-edit-presentation\n      [selectedPresentation]=\"selectedPresentation$ | async\"\n      (goBack)=\"closeRestitution()\"\n      [editionStartUrl]=\"editionStartUrl\"\n      [edition]=\"false\"\n    ></pry-add-edit-presentation>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"ViewMode.EDITION\">\n    <pry-add-edit-presentation\n      [selectedPresentation]=\"selectedPresentation$ | async\"\n      (goBack)=\"closeRestitution()\"\n      [editionStartUrl]=\"editionStartUrl\"\n      [edition]=\"true\"\n    ></pry-add-edit-presentation>\n  </ng-container>\n</div>\n\n<ng-template #modal>\n  <div\n    class=\"o-modal\"\n    (click)=\"$event.stopPropagation()\"\n    #visibilityModal\n    role=\"dialog\"\n    aria-modal=\"true\"\n    aria-labelledby=\"dialog change visibility\"\n    *ngIf=\"selectedPresentation$ | async as selectedPresentation\"\n  >\n    <div class=\"o-modal__top\">\n      <div class=\"o-modal__top__title\">\n        <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.rename' | i18n }}</h2>\n      </div>\n      <div class=\"o-modal__top__close\">\n        <button\n          class=\"a-btn a-btn--icon-only\"\n          #crossVisibility\n          (keydown.shift.tab)=\"focusValidation()\"\n          (click)=\"toggleModal()\"\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-share [ngModel]=\"selectedPresentation.visibility\" (ngModelChange)=\"visibility = $event\"></pry-share>\n    <div class=\"m-btn-group\">\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)=\"changeVisibility(selectedPresentation)\"\n      >\n        {{ '@pry.toolbox.manifest.check' | i18n }}\n      </button>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
@@ -23,10 +23,10 @@ export class PryTitlePresentationComponent {
|
|
|
23
23
|
}));
|
|
24
24
|
}
|
|
25
25
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryTitlePresentationComponent, deps: [{ token: i1.Store }, { token: i2.PryI18nService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
26
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: PryTitlePresentationComponent, selector: "pry-title-presentation", ngImport: i0, template: "<div class=\"title-container\">\n <h1 class=\"a-h1 a-presentation-title\">{{ presentationTitle$ | async }}</h1>\n <ng-container *ngIf=\"presentation$ | async as presentation\">\n <div class=\"info-icon description-container description\">\n <span class=\"info-text\">i</span>\n </div>\n <div *ngIf=\"!!presentation.description\" class=\"description-tooltip title-tooltip\">\n <p class=\"a-p\">{{ presentation.description }}</p>\n </div>\n </ng-container>\n</div>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] }); }
|
|
26
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: PryTitlePresentationComponent, selector: "pry-title-presentation", ngImport: i0, template: "<div class=\"title-container\">\n <h1 class=\"a-h1 a-presentation-title\">{{ presentationTitle$ | async }}</h1>\n <ng-container *ngIf=\"presentation$ | async as presentation\">\n <div *ngIf=\"!!presentation.description\" class=\"info-icon description-container description\">\n <span class=\"info-text\">i</span>\n </div>\n <div *ngIf=\"!!presentation.description\" class=\"description-tooltip title-tooltip\">\n <p class=\"a-p\">{{ presentation.description }}</p>\n </div>\n </ng-container>\n</div>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] }); }
|
|
27
27
|
}
|
|
28
28
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryTitlePresentationComponent, decorators: [{
|
|
29
29
|
type: Component,
|
|
30
|
-
args: [{ selector: 'pry-title-presentation', template: "<div class=\"title-container\">\n <h1 class=\"a-h1 a-presentation-title\">{{ presentationTitle$ | async }}</h1>\n <ng-container *ngIf=\"presentation$ | async as presentation\">\n <div class=\"info-icon description-container description\">\n <span class=\"info-text\">i</span>\n </div>\n <div *ngIf=\"!!presentation.description\" class=\"description-tooltip title-tooltip\">\n <p class=\"a-p\">{{ presentation.description }}</p>\n </div>\n </ng-container>\n</div>\n" }]
|
|
30
|
+
args: [{ selector: 'pry-title-presentation', template: "<div class=\"title-container\">\n <h1 class=\"a-h1 a-presentation-title\">{{ presentationTitle$ | async }}</h1>\n <ng-container *ngIf=\"presentation$ | async as presentation\">\n <div *ngIf=\"!!presentation.description\" class=\"info-icon description-container description\">\n <span class=\"info-text\">i</span>\n </div>\n <div *ngIf=\"!!presentation.description\" class=\"description-tooltip title-tooltip\">\n <p class=\"a-p\">{{ presentation.description }}</p>\n </div>\n </ng-container>\n</div>\n" }]
|
|
31
31
|
}], ctorParameters: function () { return [{ type: i1.Store }, { type: i2.PryI18nService }]; } });
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGl0bGUtcHJlc2VudGF0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL3ByZXNlbnRhdGlvbi9jb21wb25lbnRzL3RpdGxlLXByZXNlbnRhdGlvbi90aXRsZS1wcmVzZW50YXRpb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvcHJlc2VudGF0aW9uL2NvbXBvbmVudHMvdGl0bGUtcHJlc2VudGF0aW9uL3RpdGxlLXByZXNlbnRhdGlvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTFDLE9BQU8sRUFBRSxHQUFHLEVBQWMsTUFBTSxNQUFNLENBQUM7QUFDdkMsT0FBTyxFQUFFLGtCQUFrQixFQUF1QyxNQUFNLG9CQUFvQixDQUFDOzs7OztBQU03RixNQUFNLE9BQU8sNkJBQTZCO0lBSXhDLFlBQW9CLEtBQVksRUFBVSxXQUEyQjtRQUFqRCxVQUFLLEdBQUwsS0FBSyxDQUFPO1FBQVUsZ0JBQVcsR0FBWCxXQUFXLENBQWdCO1FBQ25FLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsa0JBQWtCLENBQUMsWUFBWSxDQUFDLENBQUMsSUFBSSxDQUMxRSxHQUFHLENBQUMsQ0FBQyxZQUFZLEVBQUUsRUFBRTtZQUNuQixJQUFJLFlBQVksQ0FBQyxPQUFPLEVBQUU7Z0JBQ3hCLE9BQU8sWUFBWSxDQUFDLE9BQU8sQ0FBQzthQUM3QjtZQUNELE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQyxDQUFDLENBQ0gsQ0FBQztRQUVGLElBQUksQ0FBQyxrQkFBa0IsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FDL0MsR0FBRyxDQUFDLENBQUMsWUFBWSxFQUFFLEVBQUU7WUFDbkIsSUFBSSxZQUFZLEVBQUU7Z0JBQ2hCLE9BQU8sWUFBWSxDQUFDLElBQUksQ0FBQzthQUMxQjtZQUNELE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsbUNBQW1DLENBQUMsQ0FBQztRQUN2RSxDQUFDLENBQUMsQ0FDSCxDQUFDO0lBQ0osQ0FBQzs4R0F0QlUsNkJBQTZCO2tHQUE3Qiw2QkFBNkIsOERDVDFDLGdoQkFXQTs7MkZERmEsNkJBQTZCO2tCQUp6QyxTQUFTOytCQUNFLHdCQUF3QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3RvcmUgfSBmcm9tICdAbmdyeC9zdG9yZSc7XG5pbXBvcnQgeyBtYXAsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IERhc2hib2FyZFNlbGVjdG9ycywgTWFuaWZlc3REZXNjcmlwdGlvbiwgUHJ5STE4blNlcnZpY2UgfSBmcm9tICdAcHJvdm9seS9kYXNoYm9hcmQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdwcnktdGl0bGUtcHJlc2VudGF0aW9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3RpdGxlLXByZXNlbnRhdGlvbi5jb21wb25lbnQuaHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgUHJ5VGl0bGVQcmVzZW50YXRpb25Db21wb25lbnQge1xuICBwcmVzZW50YXRpb24kOiBPYnNlcnZhYmxlPE1hbmlmZXN0RGVzY3JpcHRpb24gfCBudWxsPjtcbiAgcHJlc2VudGF0aW9uVGl0bGUkOiBPYnNlcnZhYmxlPHN0cmluZyB8IG51bGw+O1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc3RvcmU6IFN0b3JlLCBwcml2YXRlIGkxOG5TZXJ2aWNlOiBQcnlJMThuU2VydmljZSkge1xuICAgIHRoaXMucHJlc2VudGF0aW9uJCA9IHRoaXMuc3RvcmUuc2VsZWN0KERhc2hib2FyZFNlbGVjdG9ycy5wcmVzZW50YXRpb24pLnBpcGUoXG4gICAgICBtYXAoKHByZXNlbnRhdGlvbikgPT4ge1xuICAgICAgICBpZiAocHJlc2VudGF0aW9uLmN1cnJlbnQpIHtcbiAgICAgICAgICByZXR1cm4gcHJlc2VudGF0aW9uLmN1cnJlbnQ7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgICB9KVxuICAgICk7XG5cbiAgICB0aGlzLnByZXNlbnRhdGlvblRpdGxlJCA9IHRoaXMucHJlc2VudGF0aW9uJC5waXBlKFxuICAgICAgbWFwKChwcmVzZW50YXRpb24pID0+IHtcbiAgICAgICAgaWYgKHByZXNlbnRhdGlvbikge1xuICAgICAgICAgIHJldHVybiBwcmVzZW50YXRpb24ubmFtZTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdGhpcy5pMThuU2VydmljZS5pbnN0YW50KCdAcHJ5LmhlYWRlci5ub0N1cnJlbnRQcmVzZW50YXRpb24nKTtcbiAgICAgIH0pXG4gICAgKTtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cInRpdGxlLWNvbnRhaW5lclwiPlxuICA8aDEgY2xhc3M9XCJhLWgxIGEtcHJlc2VudGF0aW9uLXRpdGxlXCI+e3sgcHJlc2VudGF0aW9uVGl0bGUkIHwgYXN5bmMgfX08L2gxPlxuICA8bmctY29udGFpbmVyICpuZ0lmPVwicHJlc2VudGF0aW9uJCB8IGFzeW5jIGFzIHByZXNlbnRhdGlvblwiPlxuICAgIDxkaXYgKm5nSWY9XCIhIXByZXNlbnRhdGlvbi5kZXNjcmlwdGlvblwiIGNsYXNzPVwiaW5mby1pY29uIGRlc2NyaXB0aW9uLWNvbnRhaW5lciBkZXNjcmlwdGlvblwiPlxuICAgICAgPHNwYW4gY2xhc3M9XCJpbmZvLXRleHRcIj5pPC9zcGFuPlxuICAgIDwvZGl2PlxuICAgIDxkaXYgKm5nSWY9XCIhIXByZXNlbnRhdGlvbi5kZXNjcmlwdGlvblwiIGNsYXNzPVwiZGVzY3JpcHRpb24tdG9vbHRpcCB0aXRsZS10b29sdGlwXCI+XG4gICAgICA8cCBjbGFzcz1cImEtcFwiPnt7IHByZXNlbnRhdGlvbi5kZXNjcmlwdGlvbiB9fTwvcD5cbiAgICA8L2Rpdj5cbiAgPC9uZy1jb250YWluZXI+XG48L2Rpdj5cbiJdfQ==
|
package/esm2022/restitution/components/restitution-catalog/restitution-catalog.component.mjs
CHANGED
|
@@ -33,6 +33,7 @@ export class PryRestitutionCatalogComponent {
|
|
|
33
33
|
selectRestitution(restitution) {
|
|
34
34
|
this.selectedRestitution = restitution;
|
|
35
35
|
this.selectMode(this.mode.CONSULT);
|
|
36
|
+
this.search$.next('');
|
|
36
37
|
}
|
|
37
38
|
closeRestitution($event) {
|
|
38
39
|
this.selectedRestitution = null;
|
|
@@ -44,6 +45,7 @@ export class PryRestitutionCatalogComponent {
|
|
|
44
45
|
editRestitution(restitution) {
|
|
45
46
|
this.selectedRestitution = restitution;
|
|
46
47
|
this.selectMode(ViewMode.EDITION);
|
|
48
|
+
this.search$.next('');
|
|
47
49
|
}
|
|
48
50
|
focusElement(element) {
|
|
49
51
|
element.focus();
|
|
@@ -55,4 +57,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
|
|
|
55
57
|
type: Component,
|
|
56
58
|
args: [{ selector: 'pry-restitution-catalog', template: "<pry-restitution-css></pry-restitution-css>\n<div class=\"o-manifest-layout o-restitution-catalog\">\n <ng-template [ngIf]=\"selectedMode === mode.CATALOG\">\n <div class=\"o-manifest-layout__toolbox\">\n <button\n type=\"button\"\n (click)=\"selectMode(mode.CREATION)\"\n class=\"a-btn a-btn--primary a-tooltip\"\n [attr.data-tooltip]=\"'@pry.restitution.create_title' | i18n\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'create' }\"\n >\n {{ '@pry.restitution.create_title' | i18n }}\n </button>\n <div>\n <div class=\"o-catalog__search\">\n <label id=\"catalog-search-label\" for=\"catalog-search\" class=\"u-visually-hidden\">\n <span>{{ '@pry.toolbox.catalog.filter.name' | i18n }}</span>\n </label>\n <input\n id=\"catalog-search\"\n type=\"text\"\n class=\"a-form-field\"\n [placeholder]=\"'@pry.restitution.search' | i18n\"\n [ngModel]=\"search$ | async\"\n (ngModelChange)=\"this.search$.next($event)\"\n />\n\n <pry-icon iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n </div>\n </div>\n </div>\n <div class=\"o-manifest-layout__content\">\n <h1 class=\"a-h1\">{{ '@pry.restitution.catalog' | i18n }}</h1>\n\n <div class=\"o-presentation-wrapper\">\n <ul class=\"o-presentation\">\n <li class=\"o-presentation__item\" *ngFor=\"let restitution of filteredRestitution$ | async\">\n <div class=\"o-presentation__item__header\">\n <ng-container *ngIf=\"restitution.visibility?.type === PryVisibilityType.PRIVATE\">\n <pry-icon\n iconSvg=\"private\"\n class=\"is-private a-tooltip\"\n [attr.data-tooltip]=\"'@pry.restitution.lock' | i18n\"\n [height]=\"17\"\n [width]=\"17\"\n ></pry-icon>\n </ng-container>\n <div class=\"a-tooltip\" [attr.data-tooltip]=\"'@pry.restitution.visualize' | i18n\">\n <div class=\"o-presentation__item__image\">\n <img\n alt=\"\"\n [height]=\"restitution.cover ? 600 : 128\"\n [width]=\"restitution.cover ? 600 : 128\"\n [class.is-full-width]=\"restitution.cover\"\n [src]=\"restitution.image | getSecuredImage : [600, 600] | async\"\n class=\"pointer\"\n (click)=\"selectRestitution(restitution)\"\n />\n </div>\n </div>\n </div>\n\n <div class=\"o-presentation__item__txt\">\n <h3 class=\"a-h3\">{{ restitution.name }}</h3>\n <p class=\"a-p -date\">{{ restitution.modificationDate | sinceDate }}</p>\n </div>\n\n <div class=\"o-presentation__item__footer\">\n <ul class=\"m-actions-list\">\n <li>\n <button\n type=\"button\"\n class=\"a-btn a-btn icon-only a-tooltip\"\n [attr.data-tooltip]=\"'@pry.restitution.consult' | i18n\"\n (click)=\"selectRestitution(restitution)\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'consult' }\"\n >\n <pry-icon iconSvg=\"eye\"></pry-icon>\n </button>\n </li>\n <li>\n <button\n type=\"button\"\n class=\"a-btn a-btn icon-only a-tooltip\"\n [attr.data-tooltip]=\"'@pry.restitution.update' | i18n\"\n (click)=\"editRestitution(restitution)\"\n [disabled]=\"!restitution.owner\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'edit' }\"\n >\n <pry-icon iconSvg=\"edit\"></pry-icon>\n </button>\n </li>\n <li>\n <button\n type=\"button\"\n class=\"a-btn a-btn icon-only a-tooltip\"\n [attr.data-tooltip]=\"'@pry.restitution.delete' | i18n\"\n (click)=\"deleteRestitution(restitution.id)\"\n [disabled]=\"!restitution.owner\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'delete' }\"\n >\n <pry-icon iconSvg=\"delete\"></pry-icon>\n </button>\n </li>\n </ul>\n </div>\n </li>\n </ul>\n </div>\n </div>\n </ng-template>\n\n <ng-template [ngIf]=\"selectedMode === mode.CONSULT\">\n <div class=\"o-manifest-layout__toolbox\">\n <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n {{ '@pry.restitution.backToCatalog' | i18n }}\n </button>\n </div>\n <div class=\"o-manifest-layout__content\">\n <pry-restitution\n [selectedRestitution]=\"selectedRestitution\"\n [edit]=\"false\"\n (restitutionCreated)=\"closeRestitution($event)\"\n class=\"restitution\"\n ></pry-restitution>\n </div>\n </ng-template>\n <ng-template [ngIf]=\"selectedMode === mode.CREATION\">\n <div class=\"o-manifest-layout__toolbox\">\n <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n {{ '@pry.restitution.backToCatalog' | i18n }}\n </button>\n </div>\n <div class=\"o-manifest-layout__content\">\n <pry-restitution (restitutionCreated)=\"closeRestitution($event)\" class=\"restitution\"></pry-restitution>\n </div>\n </ng-template>\n <ng-template [ngIf]=\"selectedMode === mode.EDITION\">\n <div class=\"o-manifest-layout__toolbox\">\n <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n {{ '@pry.restitution.backToCatalog' | i18n }}\n </button>\n </div>\n <div class=\"o-manifest-layout__content\">\n <pry-restitution\n (restitutionCreated)=\"closeRestitution($event)\"\n [selectedRestitution]=\"selectedRestitution\"\n class=\"restitution\"\n ></pry-restitution>\n </div>\n </ng-template>\n</div>\n" }]
|
|
57
59
|
}], ctorParameters: function () { return [{ type: i1.Store }, { type: i2.Overlay }, { type: i0.ViewContainerRef }]; } });
|
|
58
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restitution-catalog.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/restitution/components/restitution-catalog/restitution-catalog.component.ts","../../../../../../../projects/provoly/dashboard/restitution/components/restitution-catalog/restitution-catalog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay } from '@angular/cdk/overlay';\nimport { Component, ViewContainerRef } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport { ConfigActions, ConfigSelectors, PryVisibilityType, ViewMode, Widget } from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, map, Observable } from 'rxjs';\n\n@Component({\n  selector: 'pry-restitution-catalog',\n  templateUrl: './restitution-catalog.component.html'\n})\nexport class PryRestitutionCatalogComponent {\n  restitutions$: Observable<Widget[]>;\n  search$ = new BehaviorSubject('');\n  filteredRestitution$: Observable<Widget[]>;\n  selectedItem?: Element | null;\n  mode = ViewMode;\n  selectedMode: ViewMode = ViewMode.CATALOG;\n  selectedRestitution: Widget | null = null;\n  restitution?: Widget;\n  PryVisibilityType = PryVisibilityType;\n\n  constructor(private store: Store, protected overlay: Overlay, protected viewContainerRef: ViewContainerRef) {\n    this.store.dispatch(ConfigActions.loadWidgets());\n    this.store.dispatch(ConfigActions.getMapStyles());\n\n    this.restitutions$ = this.store\n      .select(ConfigSelectors.catalog)\n      .pipe(\n        map((restitutionList) =>\n          [...restitutionList].sort((a, b) =>\n            a.modificationDate ? b.modificationDate.localeCompare(a.modificationDate) : 1\n          )\n        )\n      );\n    this.filteredRestitution$ = combineLatest([this.restitutions$, this.search$]).pipe(\n      map(([restitutions, search]) =>\n        restitutions.filter(\n          (restitution) => search.length === 0 || restitution.name.toLowerCase().includes(search.toLowerCase())\n        )\n      )\n    );\n  }\n\n  selectMode(newMode: ViewMode) {\n    this.selectedMode = newMode;\n  }\n\n  selectRestitution(restitution: Widget) {\n    this.selectedRestitution = restitution;\n    this.selectMode(this.mode.CONSULT);\n  }\n\n  closeRestitution($event: void) {\n    this.selectedRestitution = null;\n    this.selectMode(this.mode.CATALOG);\n  }\n\n  deleteRestitution(id: string) {\n    this.store.dispatch(ConfigActions.confirmRestitutionDeletion({ id }));\n  }\n\n  editRestitution(restitution: Widget) {\n    this.selectedRestitution = restitution;\n    this.selectMode(ViewMode.EDITION);\n  }\n\n  focusElement(element: HTMLButtonElement) {\n    element.focus();\n  }\n}\n","<pry-restitution-css></pry-restitution-css>\n<div class=\"o-manifest-layout o-restitution-catalog\">\n  <ng-template [ngIf]=\"selectedMode === mode.CATALOG\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button\n        type=\"button\"\n        (click)=\"selectMode(mode.CREATION)\"\n        class=\"a-btn a-btn--primary a-tooltip\"\n        [attr.data-tooltip]=\"'@pry.restitution.create_title' | i18n\"\n        *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'create' }\"\n      >\n        {{ '@pry.restitution.create_title' | i18n }}\n      </button>\n      <div>\n        <div class=\"o-catalog__search\">\n          <label id=\"catalog-search-label\" for=\"catalog-search\" class=\"u-visually-hidden\">\n            <span>{{ '@pry.toolbox.catalog.filter.name' | i18n }}</span>\n          </label>\n          <input\n            id=\"catalog-search\"\n            type=\"text\"\n            class=\"a-form-field\"\n            [placeholder]=\"'@pry.restitution.search' | i18n\"\n            [ngModel]=\"search$ | async\"\n            (ngModelChange)=\"this.search$.next($event)\"\n          />\n\n          <pry-icon iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n        </div>\n      </div>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <h1 class=\"a-h1\">{{ '@pry.restitution.catalog' | i18n }}</h1>\n\n      <div class=\"o-presentation-wrapper\">\n        <ul class=\"o-presentation\">\n          <li class=\"o-presentation__item\" *ngFor=\"let restitution of filteredRestitution$ | async\">\n            <div class=\"o-presentation__item__header\">\n              <ng-container *ngIf=\"restitution.visibility?.type === PryVisibilityType.PRIVATE\">\n                <pry-icon\n                  iconSvg=\"private\"\n                  class=\"is-private a-tooltip\"\n                  [attr.data-tooltip]=\"'@pry.restitution.lock' | i18n\"\n                  [height]=\"17\"\n                  [width]=\"17\"\n                ></pry-icon>\n              </ng-container>\n              <div class=\"a-tooltip\" [attr.data-tooltip]=\"'@pry.restitution.visualize' | i18n\">\n                <div class=\"o-presentation__item__image\">\n                  <img\n                    alt=\"\"\n                    [height]=\"restitution.cover ? 600 : 128\"\n                    [width]=\"restitution.cover ? 600 : 128\"\n                    [class.is-full-width]=\"restitution.cover\"\n                    [src]=\"restitution.image | getSecuredImage : [600, 600] | async\"\n                    class=\"pointer\"\n                    (click)=\"selectRestitution(restitution)\"\n                  />\n                </div>\n              </div>\n            </div>\n\n            <div class=\"o-presentation__item__txt\">\n              <h3 class=\"a-h3\">{{ restitution.name }}</h3>\n              <p class=\"a-p -date\">{{ restitution.modificationDate | sinceDate }}</p>\n            </div>\n\n            <div class=\"o-presentation__item__footer\">\n              <ul class=\"m-actions-list\">\n                <li>\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn icon-only a-tooltip\"\n                    [attr.data-tooltip]=\"'@pry.restitution.consult' | i18n\"\n                    (click)=\"selectRestitution(restitution)\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'consult' }\"\n                  >\n                    <pry-icon iconSvg=\"eye\"></pry-icon>\n                  </button>\n                </li>\n                <li>\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn icon-only a-tooltip\"\n                    [attr.data-tooltip]=\"'@pry.restitution.update' | i18n\"\n                    (click)=\"editRestitution(restitution)\"\n                    [disabled]=\"!restitution.owner\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'edit' }\"\n                  >\n                    <pry-icon iconSvg=\"edit\"></pry-icon>\n                  </button>\n                </li>\n                <li>\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn icon-only a-tooltip\"\n                    [attr.data-tooltip]=\"'@pry.restitution.delete' | i18n\"\n                    (click)=\"deleteRestitution(restitution.id)\"\n                    [disabled]=\"!restitution.owner\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'delete' }\"\n                  >\n                    <pry-icon iconSvg=\"delete\"></pry-icon>\n                  </button>\n                </li>\n              </ul>\n            </div>\n          </li>\n        </ul>\n      </div>\n    </div>\n  </ng-template>\n\n  <ng-template [ngIf]=\"selectedMode === mode.CONSULT\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n        {{ '@pry.restitution.backToCatalog' | i18n }}\n      </button>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <pry-restitution\n        [selectedRestitution]=\"selectedRestitution\"\n        [edit]=\"false\"\n        (restitutionCreated)=\"closeRestitution($event)\"\n        class=\"restitution\"\n      ></pry-restitution>\n    </div>\n  </ng-template>\n  <ng-template [ngIf]=\"selectedMode === mode.CREATION\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n        {{ '@pry.restitution.backToCatalog' | i18n }}\n      </button>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <pry-restitution (restitutionCreated)=\"closeRestitution($event)\" class=\"restitution\"></pry-restitution>\n    </div>\n  </ng-template>\n  <ng-template [ngIf]=\"selectedMode === mode.EDITION\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n        {{ '@pry.restitution.backToCatalog' | i18n }}\n      </button>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <pry-restitution\n        (restitutionCreated)=\"closeRestitution($event)\"\n        [selectedRestitution]=\"selectedRestitution\"\n        class=\"restitution\"\n      ></pry-restitution>\n    </div>\n  </ng-template>\n</div>\n"]}
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restitution-catalog.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/restitution/components/restitution-catalog/restitution-catalog.component.ts","../../../../../../../projects/provoly/dashboard/restitution/components/restitution-catalog/restitution-catalog.component.html"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAoB,MAAM,eAAe,CAAC;AAE5D,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,iBAAiB,EAAE,QAAQ,EAAU,MAAM,oBAAoB,CAAC;AACzG,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,GAAG,EAAc,MAAM,MAAM,CAAC;;;;;;;;;;AAMvE,MAAM,OAAO,8BAA8B;IAWzC,YAAoB,KAAY,EAAY,OAAgB,EAAY,gBAAkC;QAAtF,UAAK,GAAL,KAAK,CAAO;QAAY,YAAO,GAAP,OAAO,CAAS;QAAY,qBAAgB,GAAhB,gBAAgB,CAAkB;QAT1G,YAAO,GAAG,IAAI,eAAe,CAAC,EAAE,CAAC,CAAC;QAGlC,SAAI,GAAG,QAAQ,CAAC;QAChB,iBAAY,GAAa,QAAQ,CAAC,OAAO,CAAC;QAC1C,wBAAmB,GAAkB,IAAI,CAAC;QAE1C,sBAAiB,GAAG,iBAAiB,CAAC;QAGpC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC,CAAC;QACjD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC,CAAC;QAElD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK;aAC5B,MAAM,CAAC,eAAe,CAAC,OAAO,CAAC;aAC/B,IAAI,CACH,GAAG,CAAC,CAAC,eAAe,EAAE,EAAE,CACtB,CAAC,GAAG,eAAe,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACjC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC,CAC9E,CACF,CACF,CAAC;QACJ,IAAI,CAAC,oBAAoB,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAChF,GAAG,CAAC,CAAC,CAAC,YAAY,EAAE,MAAM,CAAC,EAAE,EAAE,CAC7B,YAAY,CAAC,MAAM,CACjB,CAAC,WAAW,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,IAAI,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CACtG,CACF,CACF,CAAC;IACJ,CAAC;IAED,UAAU,CAAC,OAAiB;QAC1B,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC;IAC9B,CAAC;IAED,iBAAiB,CAAC,WAAmB;QACnC,IAAI,CAAC,mBAAmB,GAAG,WAAW,CAAC;QACvC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACnC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACxB,CAAC;IAED,gBAAgB,CAAC,MAAY;QAC3B,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;QAChC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACrC,CAAC;IAED,iBAAiB,CAAC,EAAU;QAC1B,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,0BAA0B,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACxE,CAAC;IAED,eAAe,CAAC,WAAmB;QACjC,IAAI,CAAC,mBAAmB,GAAG,WAAW,CAAC;QACvC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QAClC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACxB,CAAC;IAED,YAAY,CAAC,OAA0B;QACrC,OAAO,CAAC,KAAK,EAAE,CAAC;IAClB,CAAC;8GA5DU,8BAA8B;kGAA9B,8BAA8B,+DCV3C,g3MAwJA;;2FD9Ia,8BAA8B;kBAJ1C,SAAS;+BACE,yBAAyB","sourcesContent":["import { Overlay } from '@angular/cdk/overlay';\nimport { Component, ViewContainerRef } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport { ConfigActions, ConfigSelectors, PryVisibilityType, ViewMode, Widget } from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, map, Observable } from 'rxjs';\n\n@Component({\n  selector: 'pry-restitution-catalog',\n  templateUrl: './restitution-catalog.component.html'\n})\nexport class PryRestitutionCatalogComponent {\n  restitutions$: Observable<Widget[]>;\n  search$ = new BehaviorSubject('');\n  filteredRestitution$: Observable<Widget[]>;\n  selectedItem?: Element | null;\n  mode = ViewMode;\n  selectedMode: ViewMode = ViewMode.CATALOG;\n  selectedRestitution: Widget | null = null;\n  restitution?: Widget;\n  PryVisibilityType = PryVisibilityType;\n\n  constructor(private store: Store, protected overlay: Overlay, protected viewContainerRef: ViewContainerRef) {\n    this.store.dispatch(ConfigActions.loadWidgets());\n    this.store.dispatch(ConfigActions.getMapStyles());\n\n    this.restitutions$ = this.store\n      .select(ConfigSelectors.catalog)\n      .pipe(\n        map((restitutionList) =>\n          [...restitutionList].sort((a, b) =>\n            a.modificationDate ? b.modificationDate.localeCompare(a.modificationDate) : 1\n          )\n        )\n      );\n    this.filteredRestitution$ = combineLatest([this.restitutions$, this.search$]).pipe(\n      map(([restitutions, search]) =>\n        restitutions.filter(\n          (restitution) => search.length === 0 || restitution.name.toLowerCase().includes(search.toLowerCase())\n        )\n      )\n    );\n  }\n\n  selectMode(newMode: ViewMode) {\n    this.selectedMode = newMode;\n  }\n\n  selectRestitution(restitution: Widget) {\n    this.selectedRestitution = restitution;\n    this.selectMode(this.mode.CONSULT);\n    this.search$.next('');\n  }\n\n  closeRestitution($event: void) {\n    this.selectedRestitution = null;\n    this.selectMode(this.mode.CATALOG);\n  }\n\n  deleteRestitution(id: string) {\n    this.store.dispatch(ConfigActions.confirmRestitutionDeletion({ id }));\n  }\n\n  editRestitution(restitution: Widget) {\n    this.selectedRestitution = restitution;\n    this.selectMode(ViewMode.EDITION);\n    this.search$.next('');\n  }\n\n  focusElement(element: HTMLButtonElement) {\n    element.focus();\n  }\n}\n","<pry-restitution-css></pry-restitution-css>\n<div class=\"o-manifest-layout o-restitution-catalog\">\n  <ng-template [ngIf]=\"selectedMode === mode.CATALOG\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button\n        type=\"button\"\n        (click)=\"selectMode(mode.CREATION)\"\n        class=\"a-btn a-btn--primary a-tooltip\"\n        [attr.data-tooltip]=\"'@pry.restitution.create_title' | i18n\"\n        *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'create' }\"\n      >\n        {{ '@pry.restitution.create_title' | i18n }}\n      </button>\n      <div>\n        <div class=\"o-catalog__search\">\n          <label id=\"catalog-search-label\" for=\"catalog-search\" class=\"u-visually-hidden\">\n            <span>{{ '@pry.toolbox.catalog.filter.name' | i18n }}</span>\n          </label>\n          <input\n            id=\"catalog-search\"\n            type=\"text\"\n            class=\"a-form-field\"\n            [placeholder]=\"'@pry.restitution.search' | i18n\"\n            [ngModel]=\"search$ | async\"\n            (ngModelChange)=\"this.search$.next($event)\"\n          />\n\n          <pry-icon iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n        </div>\n      </div>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <h1 class=\"a-h1\">{{ '@pry.restitution.catalog' | i18n }}</h1>\n\n      <div class=\"o-presentation-wrapper\">\n        <ul class=\"o-presentation\">\n          <li class=\"o-presentation__item\" *ngFor=\"let restitution of filteredRestitution$ | async\">\n            <div class=\"o-presentation__item__header\">\n              <ng-container *ngIf=\"restitution.visibility?.type === PryVisibilityType.PRIVATE\">\n                <pry-icon\n                  iconSvg=\"private\"\n                  class=\"is-private a-tooltip\"\n                  [attr.data-tooltip]=\"'@pry.restitution.lock' | i18n\"\n                  [height]=\"17\"\n                  [width]=\"17\"\n                ></pry-icon>\n              </ng-container>\n              <div class=\"a-tooltip\" [attr.data-tooltip]=\"'@pry.restitution.visualize' | i18n\">\n                <div class=\"o-presentation__item__image\">\n                  <img\n                    alt=\"\"\n                    [height]=\"restitution.cover ? 600 : 128\"\n                    [width]=\"restitution.cover ? 600 : 128\"\n                    [class.is-full-width]=\"restitution.cover\"\n                    [src]=\"restitution.image | getSecuredImage : [600, 600] | async\"\n                    class=\"pointer\"\n                    (click)=\"selectRestitution(restitution)\"\n                  />\n                </div>\n              </div>\n            </div>\n\n            <div class=\"o-presentation__item__txt\">\n              <h3 class=\"a-h3\">{{ restitution.name }}</h3>\n              <p class=\"a-p -date\">{{ restitution.modificationDate | sinceDate }}</p>\n            </div>\n\n            <div class=\"o-presentation__item__footer\">\n              <ul class=\"m-actions-list\">\n                <li>\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn icon-only a-tooltip\"\n                    [attr.data-tooltip]=\"'@pry.restitution.consult' | i18n\"\n                    (click)=\"selectRestitution(restitution)\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'consult' }\"\n                  >\n                    <pry-icon iconSvg=\"eye\"></pry-icon>\n                  </button>\n                </li>\n                <li>\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn icon-only a-tooltip\"\n                    [attr.data-tooltip]=\"'@pry.restitution.update' | i18n\"\n                    (click)=\"editRestitution(restitution)\"\n                    [disabled]=\"!restitution.owner\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'edit' }\"\n                  >\n                    <pry-icon iconSvg=\"edit\"></pry-icon>\n                  </button>\n                </li>\n                <li>\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn icon-only a-tooltip\"\n                    [attr.data-tooltip]=\"'@pry.restitution.delete' | i18n\"\n                    (click)=\"deleteRestitution(restitution.id)\"\n                    [disabled]=\"!restitution.owner\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'delete' }\"\n                  >\n                    <pry-icon iconSvg=\"delete\"></pry-icon>\n                  </button>\n                </li>\n              </ul>\n            </div>\n          </li>\n        </ul>\n      </div>\n    </div>\n  </ng-template>\n\n  <ng-template [ngIf]=\"selectedMode === mode.CONSULT\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n        {{ '@pry.restitution.backToCatalog' | i18n }}\n      </button>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <pry-restitution\n        [selectedRestitution]=\"selectedRestitution\"\n        [edit]=\"false\"\n        (restitutionCreated)=\"closeRestitution($event)\"\n        class=\"restitution\"\n      ></pry-restitution>\n    </div>\n  </ng-template>\n  <ng-template [ngIf]=\"selectedMode === mode.CREATION\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n        {{ '@pry.restitution.backToCatalog' | i18n }}\n      </button>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <pry-restitution (restitutionCreated)=\"closeRestitution($event)\" class=\"restitution\"></pry-restitution>\n    </div>\n  </ng-template>\n  <ng-template [ngIf]=\"selectedMode === mode.EDITION\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n        {{ '@pry.restitution.backToCatalog' | i18n }}\n      </button>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <pry-restitution\n        (restitutionCreated)=\"closeRestitution($event)\"\n        [selectedRestitution]=\"selectedRestitution\"\n        class=\"restitution\"\n      ></pry-restitution>\n    </div>\n  </ng-template>\n</div>\n"]}
|