@provoly/dashboard 0.15.2 → 0.15.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (144) hide show
  1. package/components/card/card.module.d.ts +1 -1
  2. package/dataset/style/_o-pry-dataset-detail.scss +4 -0
  3. package/esm2022/components/card/card.component.mjs +3 -3
  4. package/esm2022/components/card/card.module.mjs +5 -5
  5. package/esm2022/dataset/components/dataset-detail/dataset-detail.component.mjs +3 -3
  6. package/esm2022/dataset/style/css.component.mjs +2 -2
  7. package/esm2022/lib/core/auth/geoAuth.service.mjs +26 -0
  8. package/esm2022/lib/core/components/overlay/overlay.module.mjs +4 -5
  9. package/esm2022/lib/core/components/toggle/toggle.component.mjs +4 -5
  10. package/esm2022/lib/core/core.module.mjs +8 -2
  11. package/esm2022/lib/core/errors/http-error-interceptor.service.mjs +2 -5
  12. package/esm2022/lib/core/public-api.mjs +2 -2
  13. package/esm2022/lib/core/store/aggregation/backend-aggregation.service.mjs +21 -10
  14. package/esm2022/lib/core/store/search/search.effects.mjs +3 -3
  15. package/esm2022/lib/core/toolbox/toolbox-menu.service.mjs +10 -4
  16. package/esm2022/lib/dashboard/components/widgets/data-widget.component.mjs +7 -4
  17. package/esm2022/lib/dashboard/components/widgets/header/widget-header.component.mjs +24 -12
  18. package/esm2022/lib/dashboard/components/widgets/settings/settings.component.mjs +4 -5
  19. package/esm2022/lib/dashboard/store/dashboard.effects.mjs +4 -7
  20. package/esm2022/notification/components/notification/notification.component.mjs +3 -3
  21. package/esm2022/notification/i18n/en.translations.mjs +2 -1
  22. package/esm2022/notification/i18n/fr.translations.mjs +2 -1
  23. package/esm2022/presentation/components/add-edit-presentation/add-edit-presentation.component.mjs +5 -3
  24. package/esm2022/presentation/components/presentation.component.mjs +5 -4
  25. package/esm2022/presentation/style/css.component.mjs +2 -2
  26. package/esm2022/restitution/components/restitution/restitution.component.mjs +5 -2
  27. package/esm2022/restitution/components/restitution-catalog/restitution-catalog.component.mjs +3 -3
  28. package/esm2022/restitution/components/restitution-list-item/restitution-list-item.component.mjs +3 -3
  29. package/esm2022/restitution/style/css.component.mjs +2 -2
  30. package/esm2022/search/i18n/en.translations.mjs +9 -3
  31. package/esm2022/search/i18n/fr.translations.mjs +9 -3
  32. package/esm2022/search/search-fulltext/search-fulltext/search-fulltext.component.mjs +3 -3
  33. package/esm2022/search/search-home/search-home.component.mjs +3 -3
  34. package/esm2022/search/search-multi-class/components/multi-class-condition/multi-class-condition.component.mjs +6 -3
  35. package/esm2022/search/search-multi-class/components/search-multi-class/search-multi-class.component.mjs +3 -3
  36. package/esm2022/search/search-tools/search-tools.component.mjs +3 -3
  37. package/esm2022/toolbox/components/automate-refresh/automate-refresh.component.mjs +3 -3
  38. package/esm2022/toolbox/components/clear-view/clear-view.component.mjs +3 -3
  39. package/esm2022/toolbox/components/drag-widgets/drag-widgets.component.mjs +3 -3
  40. package/esm2022/toolbox/components/filter-settings/filter-settings.component.mjs +3 -3
  41. package/esm2022/toolbox/components/launch-tab/launch-tab.component.mjs +3 -3
  42. package/esm2022/toolbox/components/named-query/named-query.component.mjs +3 -3
  43. package/esm2022/toolbox/components/refresh-datasets/refresh-datasets.component.mjs +3 -3
  44. package/esm2022/toolbox/components/save-view/save-view.component.mjs +3 -3
  45. package/esm2022/toolbox/components/select-grid-layout/select-grid-layout.component.mjs +3 -3
  46. package/esm2022/toolbox/style/css.component.mjs +2 -2
  47. package/esm2022/tooltips/attribute/attribute-tooltip.component.mjs +22 -7
  48. package/esm2022/widgets/widget-aggregated-chart/component/widget-aggregated-chart.component.mjs +19 -9
  49. package/esm2022/widgets/widget-aggregated-chart/i18n/en.translations.mjs +2 -1
  50. package/esm2022/widgets/widget-aggregated-chart/i18n/fr.translations.mjs +2 -1
  51. package/esm2022/widgets/widget-chart/component/widget-chart.component.mjs +1 -1
  52. package/esm2022/widgets/widget-detail/component/widget-detail.component.mjs +1 -1
  53. package/esm2022/widgets/widget-graph/component/widget-graph.component.mjs +3 -3
  54. package/esm2022/widgets/widget-graph/style/css.component.mjs +2 -2
  55. package/esm2022/widgets/widget-iframe/component/widget-iframe.component.mjs +1 -1
  56. package/esm2022/widgets/widget-map/component/widget-map-layer.service.mjs +5 -1
  57. package/esm2022/widgets/widget-map/component/widget-map.component.mjs +34 -32
  58. package/esm2022/widgets/widget-map/interaction/interaction-manager.class.mjs +8 -12
  59. package/esm2022/widgets/widget-map/style/css.component.mjs +2 -2
  60. package/esm2022/widgets/widget-table/component/widget-table.component.mjs +1 -1
  61. package/esm2022/widgets/widget-tile/component/widget-tile.component.mjs +1 -1
  62. package/esm2022/widgets/widget-vega/component/widget-vega.component.mjs +1 -1
  63. package/fesm2022/provoly-dashboard-components-card.mjs +6 -6
  64. package/fesm2022/provoly-dashboard-components-card.mjs.map +1 -1
  65. package/fesm2022/provoly-dashboard-dataset.mjs +4 -4
  66. package/fesm2022/provoly-dashboard-dataset.mjs.map +1 -1
  67. package/fesm2022/provoly-dashboard-notification.mjs +4 -2
  68. package/fesm2022/provoly-dashboard-notification.mjs.map +1 -1
  69. package/fesm2022/provoly-dashboard-presentation.mjs +10 -7
  70. package/fesm2022/provoly-dashboard-presentation.mjs.map +1 -1
  71. package/fesm2022/provoly-dashboard-restitution.mjs +10 -7
  72. package/fesm2022/provoly-dashboard-restitution.mjs.map +1 -1
  73. package/fesm2022/provoly-dashboard-search.mjs +29 -14
  74. package/fesm2022/provoly-dashboard-search.mjs.map +1 -1
  75. package/fesm2022/provoly-dashboard-toolbox.mjs +20 -20
  76. package/fesm2022/provoly-dashboard-toolbox.mjs.map +1 -1
  77. package/fesm2022/provoly-dashboard-tooltips-attribute.mjs +21 -6
  78. package/fesm2022/provoly-dashboard-tooltips-attribute.mjs.map +1 -1
  79. package/fesm2022/provoly-dashboard-widgets-widget-aggregated-chart.mjs +20 -8
  80. package/fesm2022/provoly-dashboard-widgets-widget-aggregated-chart.mjs.map +1 -1
  81. package/fesm2022/provoly-dashboard-widgets-widget-chart.mjs +1 -1
  82. package/fesm2022/provoly-dashboard-widgets-widget-chart.mjs.map +1 -1
  83. package/fesm2022/provoly-dashboard-widgets-widget-detail.mjs +1 -1
  84. package/fesm2022/provoly-dashboard-widgets-widget-detail.mjs.map +1 -1
  85. package/fesm2022/provoly-dashboard-widgets-widget-graph.mjs +4 -4
  86. package/fesm2022/provoly-dashboard-widgets-widget-graph.mjs.map +1 -1
  87. package/fesm2022/provoly-dashboard-widgets-widget-iframe.mjs +1 -1
  88. package/fesm2022/provoly-dashboard-widgets-widget-iframe.mjs.map +1 -1
  89. package/fesm2022/provoly-dashboard-widgets-widget-map.mjs +43 -40
  90. package/fesm2022/provoly-dashboard-widgets-widget-map.mjs.map +1 -1
  91. package/fesm2022/provoly-dashboard-widgets-widget-table.mjs +1 -1
  92. package/fesm2022/provoly-dashboard-widgets-widget-table.mjs.map +1 -1
  93. package/fesm2022/provoly-dashboard-widgets-widget-tile.mjs +1 -1
  94. package/fesm2022/provoly-dashboard-widgets-widget-tile.mjs.map +1 -1
  95. package/fesm2022/provoly-dashboard-widgets-widget-vega.mjs +1 -1
  96. package/fesm2022/provoly-dashboard-widgets-widget-vega.mjs.map +1 -1
  97. package/fesm2022/provoly-dashboard.mjs +114 -175
  98. package/fesm2022/provoly-dashboard.mjs.map +1 -1
  99. package/lib/core/auth/geoAuth.service.d.ts +12 -0
  100. package/lib/core/components/overlay/overlay.module.d.ts +8 -9
  101. package/lib/core/core.module.d.ts +1 -0
  102. package/lib/core/public-api.d.ts +1 -1
  103. package/lib/core/store/aggregation/backend-aggregation.service.d.ts +2 -0
  104. package/lib/core/store/search/search.effects.d.ts +3 -0
  105. package/lib/core/toolbox/toolbox-menu.service.d.ts +2 -0
  106. package/lib/dashboard/components/widgets/data-widget.component.d.ts +3 -2
  107. package/lib/dashboard/components/widgets/header/widget-header.component.d.ts +8 -5
  108. package/notification/i18n/en.translations.d.ts +1 -0
  109. package/notification/i18n/fr.translations.d.ts +1 -0
  110. package/package.json +41 -42
  111. package/presentation/components/add-edit-presentation/add-edit-presentation.component.d.ts +2 -2
  112. package/presentation/style/_o-pry-presentation.scss +17 -13
  113. package/restitution/components/restitution/restitution.component.d.ts +7 -0
  114. package/schematics/migration.json +5 -0
  115. package/schematics/ng-add/index.js +0 -1
  116. package/schematics/ng-add/index.js.map +1 -1
  117. package/schematics/ng-update/version-0-15/index.d.ts +2 -0
  118. package/schematics/ng-update/version-0-15/index.js +19 -0
  119. package/schematics/ng-update/version-0-15/index.js.map +1 -0
  120. package/schematics/ng-update/version-0-15/index.spec.d.ts +1 -0
  121. package/schematics/ng-update/version-0-15/index.spec.js +51 -0
  122. package/schematics/ng-update/version-0-15/index.spec.js.map +1 -0
  123. package/search/i18n/en.translations.d.ts +6 -0
  124. package/search/i18n/fr.translations.d.ts +6 -0
  125. package/search/search-multi-class/components/multi-class-condition/multi-class-condition.component.d.ts +1 -0
  126. package/styles/components/_a-tooltip.scss +76 -0
  127. package/styles/components/_o-dashboard.scss +1 -1
  128. package/styles/components/_o-pry-card.scss +14 -0
  129. package/styles/components/_o-widget.scss +1 -0
  130. package/styles/layout/_o-workspace.scss +0 -1
  131. package/styles/main.scss +2 -0
  132. package/styles-theme/components-theme/_a-tooltip.theme.scss +12 -0
  133. package/styles-theme/main-theme.scss +1 -0
  134. package/toolbox/style/_o-toolbox.scss +6 -0
  135. package/tooltips/attribute/attribute-tooltip.component.d.ts +2 -1
  136. package/widgets/widget-aggregated-chart/component/widget-aggregated-chart.component.d.ts +2 -0
  137. package/widgets/widget-aggregated-chart/i18n/en.translations.d.ts +1 -0
  138. package/widgets/widget-aggregated-chart/i18n/fr.translations.d.ts +1 -0
  139. package/widgets/widget-graph/style/_o-widget-graph.scss +15 -1
  140. package/widgets/widget-map/component/widget-map-layer.service.d.ts +3 -1
  141. package/widgets/widget-map/component/widget-map.component.d.ts +4 -7
  142. package/widgets/widget-map/style/_o-widget-map.scss +14 -0
  143. package/esm2022/lib/core/components/overlay/tooltip.directive.mjs +0 -121
  144. package/lib/core/components/overlay/tooltip.directive.d.ts +0 -28
@@ -42,11 +42,13 @@ export class PryRestitutionComponent extends SubscriptionnerDirective {
42
42
  this.type = LibraryTypes.ILLUSTRATION;
43
43
  this.isDataSourceSelected = false;
44
44
  this.image = DEFAULT_RESTITUTION_ICON_URL;
45
+ this.widgetTypes = [];
45
46
  this.store.dispatch(DataSourceActions.load());
46
47
  this.store.dispatch(ClassActions.load());
47
48
  this.store.dispatch(ConfigActions.loadCustomization());
48
49
  this.store.dispatch(FieldActions.load());
49
50
  this.types$ = this.toolboxMenuService.types$.pipe(map((type) => type.filter((filteredType) => filteredType.type !== 'detail')));
51
+ this.subscriptions.add(this.types$.subscribe((types) => (this.widgetTypes = types)));
50
52
  this.classes$ = this.store.select(ClassSelectors.classes);
51
53
  this.widgetsList$ = this.toolboxMenuService.menuStructure$.pipe(map((menu) => menu
52
54
  .map((items) => [...items.sub.filter((s) => this.toolboxManifestService.isModel(s.type))])
@@ -113,6 +115,7 @@ export class PryRestitutionComponent extends SubscriptionnerDirective {
113
115
  this.goNext(stepper);
114
116
  return;
115
117
  }
118
+ const widgetType = this.widgetTypes.find((widgetType) => widgetType.type === this.form.selectedWidget);
116
119
  this.customManifest = {
117
120
  ...this.customManifest,
118
121
  type: this.form.selectedWidget,
@@ -129,7 +132,7 @@ export class PryRestitutionComponent extends SubscriptionnerDirective {
129
132
  changeSpot: false
130
133
  },
131
134
  options: {
132
- ...this.customManifest.options,
135
+ ...widgetType?.manifest.options,
133
136
  title: this.form.title
134
137
  }
135
138
  };
@@ -196,4 +199,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
196
199
  }], bindId: [{
197
200
  type: Input
198
201
  }] } });
199
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restitution.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/restitution/components/restitution/restitution.component.ts","../../../../../../../projects/provoly/dashboard/restitution/components/restitution/restitution.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport {\n  CatalogEntry,\n  Class,\n  ClassActions,\n  ClassSelectors,\n  ConfigActions,\n  DataSource,\n  DataSourceActions,\n  DEFAULT_RESTITUTION_ICON_URL,\n  FieldActions,\n  LibraryTypes,\n  PryVisibility,\n  PryVisibilityType,\n  SearchActions,\n  SubscriptionnerDirective,\n  ToolboxManifestService,\n  ToolboxMenuService,\n  Widget,\n  WidgetManifest\n} from '@provoly/dashboard';\nimport { PryStepperComponent } from '@provoly/dashboard/components/stepper';\nimport { map, Observable, Subject } from 'rxjs';\nimport { v4 } from 'uuid';\nimport { RestitutionForm } from '../../model/restitution.model';\n\n@Component({\n  selector: 'pry-restitution',\n  templateUrl: './restitution.component.html'\n})\nexport class PryRestitutionComponent extends SubscriptionnerDirective implements OnInit {\n  types$: Observable<{ icon: string; label: string; type: string }[]>;\n  classes$: Observable<Class[]>;\n  customManifest: WidgetManifest = {\n    type: 'detail',\n    layout: { x: 1, y: 1, width: 1, height: 1 },\n    options: { itemIds: [] as string[] }\n  };\n  form: RestitutionForm = {\n    selectedWidget: '',\n    selectedDataSource: [],\n    title: '',\n    image: DEFAULT_RESTITUTION_ICON_URL,\n    description: '',\n    cover: false\n  };\n  visibility: PryVisibility = {\n    type: PryVisibilityType.PRIVATE,\n    users: []\n  };\n  openSettings$: Subject<void> = new Subject<void>();\n  users$: Observable<any[]> | null = null;\n  consultMode: boolean = false;\n  @Input() selectedRestitution: Widget | null = null;\n  @Input() edit: boolean = true;\n  @Output() restitutionCreated = new EventEmitter<void>();\n  widgetsList$: Observable<CatalogEntry[]>;\n  type: LibraryTypes = LibraryTypes.ILLUSTRATION;\n  @Input() isDataSourceSelected = false;\n  @Input() bindId: any;\n  image: string = DEFAULT_RESTITUTION_ICON_URL;\n\n  constructor(\n    private toolboxManifestService: ToolboxManifestService,\n    private store: Store,\n    private toolboxMenuService: ToolboxMenuService\n  ) {\n    super();\n    this.store.dispatch(DataSourceActions.load());\n    this.store.dispatch(ClassActions.load());\n    this.store.dispatch(ConfigActions.loadCustomization());\n    this.store.dispatch(FieldActions.load());\n\n    this.types$ = this.toolboxMenuService.types$.pipe(\n      map((type) => type.filter((filteredType) => filteredType.type !== 'detail'))\n    );\n    this.classes$ = this.store.select(ClassSelectors.classes);\n    this.widgetsList$ = this.toolboxMenuService.menuStructure$.pipe(\n      map((menu) =>\n        menu\n          .map((items) => [...items.sub.filter((s) => this.toolboxManifestService.isModel(s.type))])\n          .reduce((acc, items) => [...acc, ...items], [])\n      )\n    );\n  }\n\n  ngOnInit(): void {\n    if (this.selectedRestitution) {\n      if (!this.edit) {\n        this.consultMode = true;\n      }\n      this.customManifest = JSON.parse(this.selectedRestitution.content);\n      if (Array.isArray(this.customManifest.datasource)) {\n        this.customManifest.datasource.forEach((dataSource: string) => {\n          this.store.dispatch(SearchActions.getDatasourceItems({ id: dataSource }));\n        });\n      } else {\n        this.store.dispatch(SearchActions.getDatasourceItems({ id: this.customManifest.datasource as string }));\n      }\n      if (this.selectedRestitution.visibility) {\n        this.visibility = this.selectedRestitution.visibility;\n      }\n      this.form.selectedDataSource.forEach((dataSource: string) => {\n        this.store.dispatch(SearchActions.getDatasourceItems({ id: dataSource }));\n      });\n      this.customManifest = JSON.parse(this.selectedRestitution.content);\n      this.customManifest.header = {\n        datasourceSelection: false,\n        parameters: true,\n        window: false,\n        maximize: false,\n        addToCatalog: false,\n        delete: false,\n        changeSpot: false\n      };\n      this.form = {\n        selectedWidget: this.customManifest.type,\n        selectedDataSource: this.customManifest.datasource as string[],\n        title: this.selectedRestitution.name,\n        cover: this.selectedRestitution.cover,\n        ...this.selectedRestitution\n      };\n    }\n    this.image = this.selectedRestitution?.image ?? DEFAULT_RESTITUTION_ICON_URL;\n  }\n\n  cancel(stepper: PryStepperComponent) {\n    this.form.selectedWidget = '';\n    this.form.selectedDataSource = [];\n    this.form.title = '';\n    this.form.description = '';\n    this.form.image = '';\n    this.form.cover = false;\n    if (this.consultMode || this.selectedRestitution) {\n      this.restitutionCreated.emit();\n      return;\n    }\n    this.prev(stepper);\n  }\n\n  datasourcesChanged($event: DataSource[]) {\n    this.form.selectedDataSource = $event.map((ds) => ds.id);\n  }\n\n  submit(stepper: PryStepperComponent) {\n    if (this.consultMode) {\n      this.goNext(stepper);\n      return;\n    }\n    this.customManifest = {\n      ...this.customManifest,\n      type: this.form.selectedWidget,\n      title: this.form.title,\n      datasource: this.form.selectedDataSource,\n      cover: this.form.cover ?? false,\n      header: {\n        datasourceSelection: false,\n        parameters: true,\n        window: false,\n        maximize: false,\n        addToCatalog: false,\n        delete: false,\n        changeSpot: false\n      },\n      options: {\n        ...this.customManifest.options,\n        title: this.form.title\n      }\n    };\n    this.form.selectedDataSource.forEach((nameQuery: string) => {\n      this.store.dispatch(SearchActions.getDatasourceItems({ id: nameQuery }));\n    });\n    this.goNext(stepper);\n    setTimeout(() => {\n      this.openSettings$.next();\n    }, 150);\n  }\n\n  isSubmitDisabled() {\n    return (\n      this.form.selectedWidget === '' ||\n      this.form.title.trim().length === 0 ||\n      this.form.title.length > 30 ||\n      this.form.description.length > 255\n    );\n  }\n\n  noDataSourceSelected() {\n    return !this.form.selectedDataSource || this.form.selectedDataSource.length === 0;\n  }\n\n  goNext(stepper: PryStepperComponent) {\n    stepper.next();\n  }\n\n  prev(stepper: PryStepperComponent) {\n    stepper.prev();\n  }\n\n  updateManifest($event: { widgetIndex: number; manifest: WidgetManifest }) {\n    this.customManifest = $event.manifest;\n  }\n\n  lastStepCompleted() {\n    this.form.image = this.image;\n    if (this.edit) {\n      this.store.dispatch(\n        ConfigActions.saveWidget({\n          widget: {\n            id: this.selectedRestitution?.id ?? v4(),\n            content: JSON.stringify(this.customManifest),\n            name: this.form.title,\n            description: this.form.description,\n            image: this.form.image ?? '',\n            visibility: this.visibility,\n            datasource: this.form.selectedDataSource,\n            cover: this.form.cover ?? false,\n            modificationDate: ''\n          }\n        })\n      );\n    }\n    this.store.dispatch(ConfigActions.loadWidgets());\n    this.restitutionCreated.emit();\n  }\n}\n","<pry-restitution-css></pry-restitution-css>\n<div class=\"o-restitution\">\n  <h3 class=\"a-h2 o-restitution__title\">\n    {{ (consultMode ? '@pry.restitution.consult_title' : '@pry.restitution.create_title') | i18n }}\n  </h3>\n  <pry-stepper #stepper [isConsultMode]=\"consultMode || edit\" (lastStepCompleted)=\"lastStepCompleted()\">\n    <pry-step>\n      <h4 class=\"m-stepper-item__title\" *stepTitle>{{ '@pry.restitution.configure' | i18n }}</h4>\n      <div>\n        <div class=\"m-form-label-field\">\n          <label for=\"restitution\" class=\"a-label\">{{ '@pry.restitution.restitution_type' | i18n }}</label>\n          <pry-select\n            id=\"restitution\"\n            class=\"a-pry-select\"\n            [itemsAsOption]=\"true\"\n            [items]=\"types$ | async\"\n            [labelTranslate]=\"true\"\n            [(ngModel)]=\"form.selectedWidget\"\n            [disabled]=\"consultMode\"\n            bindIcon=\"icon\"\n            bindLabel=\"label\"\n            bindValue=\"type\"\n          >\n          </pry-select>\n        </div>\n        <div *ngIf=\"form.selectedWidget !== ''\">\n          <div class=\"m-form-label-field\">\n            <label for=\"graphTitle\" class=\"a-label\">{{ '@pry.restitution.graph_title' | i18n }}</label>\n            <input\n              name=\"title\"\n              id=\"graphTitle\"\n              class=\"a-form-field\"\n              [(ngModel)]=\"form.title\"\n              type=\"text\"\n              [disabled]=\"consultMode\"\n              maxlength=\"30\"\n              ngDefaultControl\n            />\n          </div>\n          <div class=\"m-form-label-field\">\n            <label for=\"description\" class=\"a-label\">{{ '@pry.restitution.description' | i18n }}</label>\n            <textarea\n              name=\"description\"\n              id=\"description\"\n              class=\"a-form-field\"\n              [(ngModel)]=\"form.description\"\n              style=\"resize: none\"\n              [disabled]=\"consultMode\"\n              maxlength=\"255\"\n              ngDefaultControl\n            >\n            </textarea>\n          </div>\n          <div class=\"m-form-label-field -width-full\">\n            <label class=\"a-label\">{{ '@pry.presentation.form.image' | i18n }}</label>\n            <div class=\"o-file-input\">\n              <pry-select-image (changed)=\"image = $event\" [iconUrl]=\"image\" [mode]=\"type\"></pry-select-image>\n              <pry-checkbox [(ngModel)]=\"form.cover\" name=\"cover\"> {{ '@pry.restitution.cover' | i18n }}</pry-checkbox>\n            </div>\n          </div>\n          <div class=\"m-btn-group -space-evenly actions\">\n            <button (click)=\"cancel(stepper)\" type=\"button\" class=\"a-btn a-btn--secondary\">\n              {{ '@pry.restitution.close' | i18n }}\n            </button>\n            <button (click)=\"goNext(stepper)\" [disabled]=\"isSubmitDisabled()\" class=\"a-btn a-btn--primary\">\n              {{ '@pry.restitution.validate' | i18n }}\n            </button>\n          </div>\n        </div>\n      </div>\n    </pry-step>\n    <pry-step>\n      <h4 class=\"m-stepper-item__title\" *stepTitle>{{ '@pry.restitution.dataSource' | i18n }}</h4>\n      <pry-datasource-selector\n        (cancel)=\"prev(stepper)\"\n        (validated)=\"submit(stepper)\"\n        (datasourcesChanged)=\"datasourcesChanged($event)\"\n        [datasourceIds]=\"form.selectedDataSource\"\n      ></pry-datasource-selector>\n    </pry-step>\n    <pry-step>\n      <h4 class=\"m-stepper-item__title\" *stepTitle>{{ '@pry.restitution.visualize' | i18n }}</h4>\n      <div class=\"widget-instanciator\">\n        <pry-widget-instanciator\n          [standalone]=\"true\"\n          [staticManifest]=\"customManifest\"\n          [open$]=\"openSettings$\"\n          (manifestModified)=\"updateManifest($event)\"\n        ></pry-widget-instanciator>\n      </div>\n      <div class=\"m-btn-group -space-evenly actions\" *ngIf=\"!consultMode; else consult\">\n        <button (click)=\"prev(stepper)\" type=\"button\" class=\"a-btn a-btn--secondary\">\n          {{ '@pry.restitution.close' | i18n }}\n        </button>\n        <button (click)=\"goNext(stepper)\" type=\"button\" class=\"a-btn a-btn--primary\">\n          {{ '@pry.restitution.validate' | i18n }}\n        </button>\n      </div>\n    </pry-step>\n    <pry-step>\n      <h4 class=\"m-stepper-item__title\" *stepTitle>{{ '@pry.restitution.broadcast' | i18n }}</h4>\n      <div class=\"\">\n        <h3>{{ '@pry.restitution.access' | i18n }}</h3>\n        {{ '@pry.restitution.choice' | i18n }}\n        <ul>\n          <li>\n            {{ '@pry.restitution.public' | i18n }}\n          </li>\n        </ul>\n        {{ '@pry.restitution.or' | i18n }}\n        <ul>\n          <li>\n            {{ '@pry.restitution.private' | i18n }}\n          </li>\n        </ul>\n      </div>\n      <pry-share\n        [(ngModel)]=\"visibility\"\n        [users$]=\"users$\"\n        labelProperty=\"name\"\n        valueProperty=\"id\"\n        [disabled]=\"consultMode\"\n      ></pry-share>\n      <div class=\"m-btn-group -space-evenly actions\" *ngIf=\"!consultMode; else consult\">\n        <button (click)=\"prev(stepper)\" type=\"button\" class=\"a-btn a-btn--secondary\">\n          {{ '@pry.restitution.close' | i18n }}\n        </button>\n        <button\n          (click)=\"goNext(stepper)\"\n          [disabled]=\"noDataSourceSelected() || isSubmitDisabled()\"\n          type=\"button\"\n          class=\"a-btn a-btn--primary\"\n        >\n          {{ '@pry.restitution.broadcast' | i18n }}\n        </button>\n      </div>\n    </pry-step>\n  </pry-stepper>\n</div>\n\n<ng-template #consult>\n  <div class=\"m-btn-group -space-evenly actions\">\n    <button (click)=\"prev(stepper)\" type=\"button\" class=\"a-btn a-btn--secondary\">\n      {{ '@pry.restitution.close' | i18n }}\n    </button>\n    <button (click)=\"goNext(stepper)\" type=\"button\" class=\"a-btn a-btn--primary\">\n      {{ '@pry.restitution.next' | i18n }}\n    </button>\n  </div>\n</ng-template>\n<ng-template #noDatasource>\n  <p class=\"search-home__container-search\">{{ '@pry.restitution.noDataSource' | i18n }}</p>\n</ng-template>\n"]}
202
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restitution.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/restitution/components/restitution/restitution.component.ts","../../../../../../../projects/provoly/dashboard/restitution/components/restitution/restitution.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport {\n  CatalogEntry,\n  Class,\n  ClassActions,\n  ClassSelectors,\n  ConfigActions,\n  DataSource,\n  DataSourceActions,\n  DEFAULT_RESTITUTION_ICON_URL,\n  FieldActions,\n  LibraryTypes,\n  PryVisibility,\n  PryVisibilityType,\n  SearchActions,\n  SubscriptionnerDirective,\n  ToolboxManifestService,\n  ToolboxMenuService,\n  Widget,\n  WidgetManifest\n} from '@provoly/dashboard';\nimport { PryStepperComponent } from '@provoly/dashboard/components/stepper';\nimport { map, Observable, Subject } from 'rxjs';\nimport { v4 } from 'uuid';\nimport { RestitutionForm } from '../../model/restitution.model';\n\n@Component({\n  selector: 'pry-restitution',\n  templateUrl: './restitution.component.html'\n})\nexport class PryRestitutionComponent extends SubscriptionnerDirective implements OnInit {\n  types$: Observable<{ icon: string; label: string; type: string; manifest: WidgetManifest }[]>;\n  classes$: Observable<Class[]>;\n  customManifest: WidgetManifest = {\n    type: 'detail',\n    layout: { x: 1, y: 1, width: 1, height: 1 },\n    options: { itemIds: [] as string[] }\n  };\n  form: RestitutionForm = {\n    selectedWidget: '',\n    selectedDataSource: [],\n    title: '',\n    image: DEFAULT_RESTITUTION_ICON_URL,\n    description: '',\n    cover: false\n  };\n  visibility: PryVisibility = {\n    type: PryVisibilityType.PRIVATE,\n    users: []\n  };\n  openSettings$: Subject<void> = new Subject<void>();\n  users$: Observable<any[]> | null = null;\n  consultMode: boolean = false;\n  @Input() selectedRestitution: Widget | null = null;\n  @Input() edit: boolean = true;\n  @Output() restitutionCreated = new EventEmitter<void>();\n  widgetsList$: Observable<CatalogEntry[]>;\n  type: LibraryTypes = LibraryTypes.ILLUSTRATION;\n  @Input() isDataSourceSelected = false;\n  @Input() bindId: any;\n  image: string = DEFAULT_RESTITUTION_ICON_URL;\n  widgetTypes: { icon: string; label: string; type: string; manifest: WidgetManifest }[] = [];\n\n  constructor(\n    private toolboxManifestService: ToolboxManifestService,\n    private store: Store,\n    private toolboxMenuService: ToolboxMenuService\n  ) {\n    super();\n    this.store.dispatch(DataSourceActions.load());\n    this.store.dispatch(ClassActions.load());\n    this.store.dispatch(ConfigActions.loadCustomization());\n    this.store.dispatch(FieldActions.load());\n\n    this.types$ = this.toolboxMenuService.types$.pipe(\n      map((type) => type.filter((filteredType) => filteredType.type !== 'detail'))\n    );\n    this.subscriptions.add(this.types$.subscribe((types) => (this.widgetTypes = types)));\n    this.classes$ = this.store.select(ClassSelectors.classes);\n    this.widgetsList$ = this.toolboxMenuService.menuStructure$.pipe(\n      map((menu) =>\n        menu\n          .map((items) => [...items.sub.filter((s) => this.toolboxManifestService.isModel(s.type))])\n          .reduce((acc, items) => [...acc, ...items], [])\n      )\n    );\n  }\n\n  ngOnInit(): void {\n    if (this.selectedRestitution) {\n      if (!this.edit) {\n        this.consultMode = true;\n      }\n      this.customManifest = JSON.parse(this.selectedRestitution.content);\n      if (Array.isArray(this.customManifest.datasource)) {\n        this.customManifest.datasource.forEach((dataSource: string) => {\n          this.store.dispatch(SearchActions.getDatasourceItems({ id: dataSource }));\n        });\n      } else {\n        this.store.dispatch(SearchActions.getDatasourceItems({ id: this.customManifest.datasource as string }));\n      }\n      if (this.selectedRestitution.visibility) {\n        this.visibility = this.selectedRestitution.visibility;\n      }\n      this.form.selectedDataSource.forEach((dataSource: string) => {\n        this.store.dispatch(SearchActions.getDatasourceItems({ id: dataSource }));\n      });\n      this.customManifest = JSON.parse(this.selectedRestitution.content);\n      this.customManifest.header = {\n        datasourceSelection: false,\n        parameters: true,\n        window: false,\n        maximize: false,\n        addToCatalog: false,\n        delete: false,\n        changeSpot: false\n      };\n      this.form = {\n        selectedWidget: this.customManifest.type,\n        selectedDataSource: this.customManifest.datasource as string[],\n        title: this.selectedRestitution.name,\n        cover: this.selectedRestitution.cover,\n        ...this.selectedRestitution\n      };\n    }\n    this.image = this.selectedRestitution?.image ?? DEFAULT_RESTITUTION_ICON_URL;\n  }\n\n  cancel(stepper: PryStepperComponent) {\n    this.form.selectedWidget = '';\n    this.form.selectedDataSource = [];\n    this.form.title = '';\n    this.form.description = '';\n    this.form.image = '';\n    this.form.cover = false;\n    if (this.consultMode || this.selectedRestitution) {\n      this.restitutionCreated.emit();\n      return;\n    }\n    this.prev(stepper);\n  }\n\n  datasourcesChanged($event: DataSource[]) {\n    this.form.selectedDataSource = $event.map((ds) => ds.id);\n  }\n\n  submit(stepper: PryStepperComponent) {\n    if (this.consultMode) {\n      this.goNext(stepper);\n      return;\n    }\n\n    const widgetType = this.widgetTypes.find((widgetType) => widgetType.type === this.form.selectedWidget);\n\n    this.customManifest = {\n      ...this.customManifest,\n      type: this.form.selectedWidget,\n      title: this.form.title,\n      datasource: this.form.selectedDataSource,\n      cover: this.form.cover ?? false,\n      header: {\n        datasourceSelection: false,\n        parameters: true,\n        window: false,\n        maximize: false,\n        addToCatalog: false,\n        delete: false,\n        changeSpot: false\n      },\n      options: {\n        ...widgetType?.manifest.options,\n        title: this.form.title\n      }\n    };\n    this.form.selectedDataSource.forEach((nameQuery: string) => {\n      this.store.dispatch(SearchActions.getDatasourceItems({ id: nameQuery }));\n    });\n    this.goNext(stepper);\n    setTimeout(() => {\n      this.openSettings$.next();\n    }, 150);\n  }\n\n  isSubmitDisabled() {\n    return (\n      this.form.selectedWidget === '' ||\n      this.form.title.trim().length === 0 ||\n      this.form.title.length > 30 ||\n      this.form.description.length > 255\n    );\n  }\n\n  noDataSourceSelected() {\n    return !this.form.selectedDataSource || this.form.selectedDataSource.length === 0;\n  }\n\n  goNext(stepper: PryStepperComponent) {\n    stepper.next();\n  }\n\n  prev(stepper: PryStepperComponent) {\n    stepper.prev();\n  }\n\n  updateManifest($event: { widgetIndex: number; manifest: WidgetManifest }) {\n    this.customManifest = $event.manifest;\n  }\n\n  lastStepCompleted() {\n    this.form.image = this.image;\n    if (this.edit) {\n      this.store.dispatch(\n        ConfigActions.saveWidget({\n          widget: {\n            id: this.selectedRestitution?.id ?? v4(),\n            content: JSON.stringify(this.customManifest),\n            name: this.form.title,\n            description: this.form.description,\n            image: this.form.image ?? '',\n            visibility: this.visibility,\n            datasource: this.form.selectedDataSource,\n            cover: this.form.cover ?? false,\n            modificationDate: ''\n          }\n        })\n      );\n    }\n    this.store.dispatch(ConfigActions.loadWidgets());\n    this.restitutionCreated.emit();\n  }\n}\n","<pry-restitution-css></pry-restitution-css>\n<div class=\"o-restitution\">\n  <h3 class=\"a-h2 o-restitution__title\">\n    {{ (consultMode ? '@pry.restitution.consult_title' : '@pry.restitution.create_title') | i18n }}\n  </h3>\n  <pry-stepper #stepper [isConsultMode]=\"consultMode || edit\" (lastStepCompleted)=\"lastStepCompleted()\">\n    <pry-step>\n      <h4 class=\"m-stepper-item__title\" *stepTitle>{{ '@pry.restitution.configure' | i18n }}</h4>\n      <div>\n        <div class=\"m-form-label-field\">\n          <label for=\"restitution\" class=\"a-label\">{{ '@pry.restitution.restitution_type' | i18n }}</label>\n          <pry-select\n            id=\"restitution\"\n            class=\"a-pry-select\"\n            [itemsAsOption]=\"true\"\n            [items]=\"types$ | async\"\n            [labelTranslate]=\"true\"\n            [(ngModel)]=\"form.selectedWidget\"\n            [disabled]=\"consultMode\"\n            bindIcon=\"icon\"\n            bindLabel=\"label\"\n            bindValue=\"type\"\n          >\n          </pry-select>\n        </div>\n        <div *ngIf=\"form.selectedWidget !== ''\">\n          <div class=\"m-form-label-field\">\n            <label for=\"graphTitle\" class=\"a-label\">{{ '@pry.restitution.graph_title' | i18n }}</label>\n            <input\n              name=\"title\"\n              id=\"graphTitle\"\n              class=\"a-form-field\"\n              [(ngModel)]=\"form.title\"\n              type=\"text\"\n              [disabled]=\"consultMode\"\n              maxlength=\"30\"\n              ngDefaultControl\n            />\n          </div>\n          <div class=\"m-form-label-field\">\n            <label for=\"description\" class=\"a-label\">{{ '@pry.restitution.description' | i18n }}</label>\n            <textarea\n              name=\"description\"\n              id=\"description\"\n              class=\"a-form-field\"\n              [(ngModel)]=\"form.description\"\n              style=\"resize: none\"\n              [disabled]=\"consultMode\"\n              maxlength=\"255\"\n              ngDefaultControl\n            >\n            </textarea>\n          </div>\n          <div class=\"m-form-label-field -width-full\">\n            <label class=\"a-label\">{{ '@pry.presentation.form.image' | i18n }}</label>\n            <div class=\"o-file-input\">\n              <pry-select-image (changed)=\"image = $event\" [iconUrl]=\"image\" [mode]=\"type\"></pry-select-image>\n              <pry-checkbox [(ngModel)]=\"form.cover\" name=\"cover\"> {{ '@pry.restitution.cover' | i18n }}</pry-checkbox>\n            </div>\n          </div>\n          <div class=\"m-btn-group -space-evenly actions\">\n            <button (click)=\"cancel(stepper)\" type=\"button\" class=\"a-btn a-btn--secondary\">\n              {{ '@pry.restitution.close' | i18n }}\n            </button>\n            <button (click)=\"goNext(stepper)\" [disabled]=\"isSubmitDisabled()\" class=\"a-btn a-btn--primary\">\n              {{ '@pry.restitution.validate' | i18n }}\n            </button>\n          </div>\n        </div>\n      </div>\n    </pry-step>\n    <pry-step>\n      <h4 class=\"m-stepper-item__title\" *stepTitle>{{ '@pry.restitution.dataSource' | i18n }}</h4>\n      <pry-datasource-selector\n        (cancel)=\"prev(stepper)\"\n        (validated)=\"submit(stepper)\"\n        (datasourcesChanged)=\"datasourcesChanged($event)\"\n        [datasourceIds]=\"form.selectedDataSource\"\n      ></pry-datasource-selector>\n    </pry-step>\n    <pry-step>\n      <h4 class=\"m-stepper-item__title\" *stepTitle>{{ '@pry.restitution.visualize' | i18n }}</h4>\n      <div class=\"widget-instanciator\">\n        <pry-widget-instanciator\n          [standalone]=\"true\"\n          [staticManifest]=\"customManifest\"\n          [open$]=\"openSettings$\"\n          (manifestModified)=\"updateManifest($event)\"\n        ></pry-widget-instanciator>\n      </div>\n      <div class=\"m-btn-group -space-evenly actions\" *ngIf=\"!consultMode; else consult\">\n        <button (click)=\"prev(stepper)\" type=\"button\" class=\"a-btn a-btn--secondary\">\n          {{ '@pry.restitution.close' | i18n }}\n        </button>\n        <button (click)=\"goNext(stepper)\" type=\"button\" class=\"a-btn a-btn--primary\">\n          {{ '@pry.restitution.validate' | i18n }}\n        </button>\n      </div>\n    </pry-step>\n    <pry-step>\n      <h4 class=\"m-stepper-item__title\" *stepTitle>{{ '@pry.restitution.broadcast' | i18n }}</h4>\n      <div class=\"\">\n        <h3>{{ '@pry.restitution.access' | i18n }}</h3>\n        {{ '@pry.restitution.choice' | i18n }}\n        <ul>\n          <li>\n            {{ '@pry.restitution.public' | i18n }}\n          </li>\n        </ul>\n        {{ '@pry.restitution.or' | i18n }}\n        <ul>\n          <li>\n            {{ '@pry.restitution.private' | i18n }}\n          </li>\n        </ul>\n      </div>\n      <pry-share\n        [(ngModel)]=\"visibility\"\n        [users$]=\"users$\"\n        labelProperty=\"name\"\n        valueProperty=\"id\"\n        [disabled]=\"consultMode\"\n      ></pry-share>\n      <div class=\"m-btn-group -space-evenly actions\" *ngIf=\"!consultMode; else consult\">\n        <button (click)=\"prev(stepper)\" type=\"button\" class=\"a-btn a-btn--secondary\">\n          {{ '@pry.restitution.close' | i18n }}\n        </button>\n        <button\n          (click)=\"goNext(stepper)\"\n          [disabled]=\"noDataSourceSelected() || isSubmitDisabled()\"\n          type=\"button\"\n          class=\"a-btn a-btn--primary\"\n        >\n          {{ '@pry.restitution.broadcast' | i18n }}\n        </button>\n      </div>\n    </pry-step>\n  </pry-stepper>\n</div>\n\n<ng-template #consult>\n  <div class=\"m-btn-group -space-evenly actions\">\n    <button (click)=\"prev(stepper)\" type=\"button\" class=\"a-btn a-btn--secondary\">\n      {{ '@pry.restitution.close' | i18n }}\n    </button>\n    <button (click)=\"goNext(stepper)\" type=\"button\" class=\"a-btn a-btn--primary\">\n      {{ '@pry.restitution.next' | i18n }}\n    </button>\n  </div>\n</ng-template>\n<ng-template #noDatasource>\n  <p class=\"search-home__container-search\">{{ '@pry.restitution.noDataSource' | i18n }}</p>\n</ng-template>\n"]}
@@ -49,10 +49,10 @@ export class PryRestitutionCatalogComponent {
49
49
  element.focus();
50
50
  }
51
51
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryRestitutionCatalogComponent, deps: [{ token: i1.Store }, { token: i2.Overlay }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
52
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: PryRestitutionCatalogComponent, selector: "pry-restitution-catalog", ngImport: i0, 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 [pryTooltip]=\"infoTooltipCreateRestitution\"\n class=\"a-btn a-btn--primary\"\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 [pryTooltip]=\"private\"\n class=\"is-private\"\n [height]=\"17\"\n [width]=\"17\"\n ></pry-icon>\n </ng-container>\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 [pryTooltip]=\"infoTooltipEye\"\n />\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\"\n (click)=\"selectRestitution(restitution)\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'consult' }\"\n >\n <pry-icon iconSvg=\"eye\" [pryTooltip]=\"infoTooltipEye\"></pry-icon>\n </button>\n </li>\n <li>\n <button\n type=\"button\"\n class=\"a-btn a-btn&#45;&#45;icon-only\"\n (click)=\"editRestitution(restitution)\"\n [disabled]=\"!restitution.owner\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'edit' }\"\n >\n <pry-icon iconSvg=\"edit\" [pryTooltip]=\"infoTooltipUpdate\"></pry-icon>\n </button>\n </li>\n <li>\n <button\n type=\"button\"\n class=\"a-btn a-btn&#45;&#45;icon-only\"\n (click)=\"deleteRestitution(restitution.id)\"\n [disabled]=\"!restitution.owner\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'delete' }\"\n >\n <pry-icon iconSvg=\"delete\" [pryTooltip]=\"infoTooltipDelete\"></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\n<ng-template #infoTooltipEye>\n <div class=\"card-title-tooltip__wrapper\">\n <span class=\"card-title-tooltip__name\">{{ '@pry.restitution.consult' | i18n }}</span>\n </div>\n</ng-template>\n\n<ng-template #infoTooltipUpdate>\n <div class=\"card-title-tooltip__wrapper\">\n <span class=\"card-title-tooltip__name\">{{ '@pry.restitution.update' | i18n }}</span>\n </div>\n</ng-template>\n\n<ng-template #infoTooltipDelete>\n <div class=\"card-title-tooltip__wrapper\">\n <span class=\"card-title-tooltip__name\">{{ '@pry.restitution.delete' | i18n }}</span>\n </div>\n</ng-template>\n\n<ng-template #infoTooltipCreateRestitution>\n <div class=\"card-title-tooltip__wrapper\">\n <span class=\"card-title-tooltip__name\">{{ '@pry.restitution.create_title' | i18n }}</span>\n </div>\n</ng-template>\n<ng-template #private>\n <div class=\"m-tooltip\" role=\"tooltip\">\n <span class=\"m-tooltip__text\">{{ '@pry.restitution.lock' | i18n }}</span>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.PryAccessDirective, selector: "[pryAccess]", inputs: ["pryAccess"] }, { kind: "component", type: i4.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.PryTooltipDirective, selector: "[pryTooltip]", inputs: ["pryTooltip", "styleReversed", "pryTooltipContext", "pryTooltipPosition", "pryTooltipShowDelay"] }, { kind: "component", type: i6.PryRestitutionComponent, selector: "pry-restitution", inputs: ["selectedRestitution", "edit", "isDataSourceSelected", "bindId"], outputs: ["restitutionCreated"] }, { kind: "component", type: i7.PryCatalogCssComponent, selector: "pry-restitution-css" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.GetSecuredImagePipe, name: "getSecuredImage" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }, { kind: "pipe", type: i8.PrySinceDatePipe, name: "sinceDate" }] }); }
52
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: PryRestitutionCatalogComponent, selector: "pry-restitution-catalog", ngImport: i0, 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.presentation.view' | 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", dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.PryAccessDirective, selector: "[pryAccess]", inputs: ["pryAccess"] }, { kind: "component", type: i4.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.PryRestitutionComponent, selector: "pry-restitution", inputs: ["selectedRestitution", "edit", "isDataSourceSelected", "bindId"], outputs: ["restitutionCreated"] }, { kind: "component", type: i7.PryCatalogCssComponent, selector: "pry-restitution-css" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.GetSecuredImagePipe, name: "getSecuredImage" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }, { kind: "pipe", type: i8.PrySinceDatePipe, name: "sinceDate" }] }); }
53
53
  }
54
54
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryRestitutionCatalogComponent, decorators: [{
55
55
  type: Component,
56
- 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 [pryTooltip]=\"infoTooltipCreateRestitution\"\n class=\"a-btn a-btn--primary\"\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 [pryTooltip]=\"private\"\n class=\"is-private\"\n [height]=\"17\"\n [width]=\"17\"\n ></pry-icon>\n </ng-container>\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 [pryTooltip]=\"infoTooltipEye\"\n />\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\"\n (click)=\"selectRestitution(restitution)\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'consult' }\"\n >\n <pry-icon iconSvg=\"eye\" [pryTooltip]=\"infoTooltipEye\"></pry-icon>\n </button>\n </li>\n <li>\n <button\n type=\"button\"\n class=\"a-btn a-btn&#45;&#45;icon-only\"\n (click)=\"editRestitution(restitution)\"\n [disabled]=\"!restitution.owner\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'edit' }\"\n >\n <pry-icon iconSvg=\"edit\" [pryTooltip]=\"infoTooltipUpdate\"></pry-icon>\n </button>\n </li>\n <li>\n <button\n type=\"button\"\n class=\"a-btn a-btn&#45;&#45;icon-only\"\n (click)=\"deleteRestitution(restitution.id)\"\n [disabled]=\"!restitution.owner\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'delete' }\"\n >\n <pry-icon iconSvg=\"delete\" [pryTooltip]=\"infoTooltipDelete\"></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\n<ng-template #infoTooltipEye>\n <div class=\"card-title-tooltip__wrapper\">\n <span class=\"card-title-tooltip__name\">{{ '@pry.restitution.consult' | i18n }}</span>\n </div>\n</ng-template>\n\n<ng-template #infoTooltipUpdate>\n <div class=\"card-title-tooltip__wrapper\">\n <span class=\"card-title-tooltip__name\">{{ '@pry.restitution.update' | i18n }}</span>\n </div>\n</ng-template>\n\n<ng-template #infoTooltipDelete>\n <div class=\"card-title-tooltip__wrapper\">\n <span class=\"card-title-tooltip__name\">{{ '@pry.restitution.delete' | i18n }}</span>\n </div>\n</ng-template>\n\n<ng-template #infoTooltipCreateRestitution>\n <div class=\"card-title-tooltip__wrapper\">\n <span class=\"card-title-tooltip__name\">{{ '@pry.restitution.create_title' | i18n }}</span>\n </div>\n</ng-template>\n<ng-template #private>\n <div class=\"m-tooltip\" role=\"tooltip\">\n <span class=\"m-tooltip__text\">{{ '@pry.restitution.lock' | i18n }}</span>\n </div>\n</ng-template>\n" }]
56
+ 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.presentation.view' | 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
57
  }], 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        [pryTooltip]=\"infoTooltipCreateRestitution\"\n        class=\"a-btn a-btn--primary\"\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                  [pryTooltip]=\"private\"\n                  class=\"is-private\"\n                  [height]=\"17\"\n                  [width]=\"17\"\n                ></pry-icon>\n              </ng-container>\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                [pryTooltip]=\"infoTooltipEye\"\n              />\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\"\n                    (click)=\"selectRestitution(restitution)\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'consult' }\"\n                  >\n                    <pry-icon iconSvg=\"eye\" [pryTooltip]=\"infoTooltipEye\"></pry-icon>\n                  </button>\n                </li>\n                <li>\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn&#45;&#45;icon-only\"\n                    (click)=\"editRestitution(restitution)\"\n                    [disabled]=\"!restitution.owner\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'edit' }\"\n                  >\n                    <pry-icon iconSvg=\"edit\" [pryTooltip]=\"infoTooltipUpdate\"></pry-icon>\n                  </button>\n                </li>\n                <li>\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn&#45;&#45;icon-only\"\n                    (click)=\"deleteRestitution(restitution.id)\"\n                    [disabled]=\"!restitution.owner\"\n                    *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'delete' }\"\n                  >\n                    <pry-icon iconSvg=\"delete\" [pryTooltip]=\"infoTooltipDelete\"></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\n<ng-template #infoTooltipEye>\n  <div class=\"card-title-tooltip__wrapper\">\n    <span class=\"card-title-tooltip__name\">{{ '@pry.restitution.consult' | i18n }}</span>\n  </div>\n</ng-template>\n\n<ng-template #infoTooltipUpdate>\n  <div class=\"card-title-tooltip__wrapper\">\n    <span class=\"card-title-tooltip__name\">{{ '@pry.restitution.update' | i18n }}</span>\n  </div>\n</ng-template>\n\n<ng-template #infoTooltipDelete>\n  <div class=\"card-title-tooltip__wrapper\">\n    <span class=\"card-title-tooltip__name\">{{ '@pry.restitution.delete' | i18n }}</span>\n  </div>\n</ng-template>\n\n<ng-template #infoTooltipCreateRestitution>\n  <div class=\"card-title-tooltip__wrapper\">\n    <span class=\"card-title-tooltip__name\">{{ '@pry.restitution.create_title' | i18n }}</span>\n  </div>\n</ng-template>\n<ng-template #private>\n  <div class=\"m-tooltip\" role=\"tooltip\">\n    <span class=\"m-tooltip__text\">{{ '@pry.restitution.lock' | i18n }}</span>\n  </div>\n</ng-template>\n"]}
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.presentation.view' | 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"]}
@@ -38,11 +38,11 @@ export class PryRestitutionListItemComponent extends SubscriptionnerDirective {
38
38
  this.store.dispatch(DashboardActions.addWidgetToPresentation({ widgetType: widget.type }));
39
39
  }
40
40
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryRestitutionListItemComponent, deps: [{ token: i1.Store }, { token: i2.ToolboxManifestService }], target: i0.ɵɵFactoryTarget.Component }); }
41
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: PryRestitutionListItemComponent, selector: "pry-catalog-item", inputs: { widget: "widget", translate: "translate" }, outputs: { selectRestitution: "selectRestitution" }, usesInheritance: true, ngImport: i0, template: "<li\n class=\"o-catalog__list__item\"\n [class.is-point]=\"automaticGridMode$ | async\"\n [draggable]=\"!(automaticGridMode$ | async)\"\n role=\"listitem\"\n aria-grabbed=\"false\"\n aria-haspopup=\"true\"\n tabindex=\"-1\"\n [title]=\"widget.description ?? widget.label | i18n : { warn: false }\"\n (dragstart)=\"dragStart($event, widget.type)\"\n>\n <ng-container *ngIf=\"automaticGridMode$ | async\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--icon-only\"\n (click)=\"viewInDashboard(widget)\"\n [title]=\"'@pry.restitution.add_icon' | i18n\"\n >\n <pry-icon [width]=\"25\" [height]=\"25\" iconSvg=\"add_column\" class=\"o-catalog__list__icon\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.restitution.add_icon' | i18n }}</span>\n </button>\n </ng-container>\n <img\n [alt]=\"widget.label | i18n : { warn: false }\"\n [src]=\"widget.icon | getSecuredImage : [600, 600] | async\"\n [height]=\"widget.cover ? 600 : 53\"\n [width]=\"widget.cover ? 600 : 53\"\n [class.is-full-width]=\"widget.cover\"\n />\n <p class=\"o-catalog__list__item__libelle\" *ngIf=\"widget.isCustom; else translate\">{{ widget.label }}</p>\n <ng-template #translate>\n <p class=\"o-catalog__list__item__libelle\">{{ widget.label | i18n : { warn: false } }}</p>\n </ng-template>\n <ng-container *ngIf=\"widget.visibility?.type === PryVisibilityType.PRIVATE\">\n <pry-icon iconSvg=\"private\" [pryTooltip]=\"private\" class=\"is-private\" [height]=\"17\" [width]=\"17\"></pry-icon>\n </ng-container>\n <div class=\"o-catalog__list__item__action\" *ngIf=\"widget.isCustom\">\n <button type=\"button\" class=\"a-btn a-btn--ghost\" (click)=\"emitSelectedRestitution(widget)\">\n {{ '@pry.restitution.view' | i18n }}\n </button>\n </div>\n</li>\n\n<ng-template #private>\n <div class=\"m-tooltip\" role=\"tooltip\">\n <span class=\"m-tooltip__text\">{{ '@pry.restitution.lock' | i18n }}</span>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "directive", type: i2.PryTooltipDirective, selector: "[pryTooltip]", inputs: ["pryTooltip", "styleReversed", "pryTooltipContext", "pryTooltipPosition", "pryTooltipShowDelay"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.GetSecuredImagePipe, name: "getSecuredImage" }, { kind: "pipe", type: i2.I18nPipe, name: "i18n" }] }); }
41
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: PryRestitutionListItemComponent, selector: "pry-catalog-item", inputs: { widget: "widget", translate: "translate" }, outputs: { selectRestitution: "selectRestitution" }, usesInheritance: true, ngImport: i0, template: "<li\n class=\"o-catalog__list__item\"\n [class.is-point]=\"automaticGridMode$ | async\"\n [draggable]=\"!(automaticGridMode$ | async)\"\n role=\"listitem\"\n aria-grabbed=\"false\"\n aria-haspopup=\"true\"\n tabindex=\"-1\"\n [title]=\"widget.description ?? widget.label | i18n : { warn: false }\"\n (dragstart)=\"dragStart($event, widget.type)\"\n>\n <ng-container *ngIf=\"automaticGridMode$ | async\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--icon-only\"\n (click)=\"viewInDashboard(widget)\"\n [title]=\"'@pry.restitution.add_icon' | i18n\"\n >\n <pry-icon [width]=\"25\" [height]=\"25\" iconSvg=\"add_column\" class=\"o-catalog__list__icon\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.restitution.add_icon' | i18n }}</span>\n </button>\n </ng-container>\n <img\n [alt]=\"widget.label | i18n : { warn: false }\"\n [src]=\"widget.icon | getSecuredImage : [600, 600] | async\"\n [height]=\"widget.cover ? 600 : 53\"\n [width]=\"widget.cover ? 600 : 53\"\n [class.is-full-width]=\"widget.cover\"\n />\n <p class=\"o-catalog__list__item__libelle\" *ngIf=\"widget.isCustom; else translate\">{{ widget.label }}</p>\n <ng-template #translate>\n <p class=\"o-catalog__list__item__libelle\">{{ widget.label | i18n : { warn: false } }}</p>\n </ng-template>\n <ng-container *ngIf=\"widget.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=\"o-catalog__list__item__action\" *ngIf=\"widget.isCustom\">\n <button type=\"button\" class=\"a-btn a-btn--ghost\" (click)=\"emitSelectedRestitution(widget)\">\n {{ '@pry.restitution.view' | i18n }}\n </button>\n </div>\n</li>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.GetSecuredImagePipe, name: "getSecuredImage" }, { kind: "pipe", type: i2.I18nPipe, name: "i18n" }] }); }
42
42
  }
43
43
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryRestitutionListItemComponent, decorators: [{
44
44
  type: Component,
45
- args: [{ selector: 'pry-catalog-item', template: "<li\n class=\"o-catalog__list__item\"\n [class.is-point]=\"automaticGridMode$ | async\"\n [draggable]=\"!(automaticGridMode$ | async)\"\n role=\"listitem\"\n aria-grabbed=\"false\"\n aria-haspopup=\"true\"\n tabindex=\"-1\"\n [title]=\"widget.description ?? widget.label | i18n : { warn: false }\"\n (dragstart)=\"dragStart($event, widget.type)\"\n>\n <ng-container *ngIf=\"automaticGridMode$ | async\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--icon-only\"\n (click)=\"viewInDashboard(widget)\"\n [title]=\"'@pry.restitution.add_icon' | i18n\"\n >\n <pry-icon [width]=\"25\" [height]=\"25\" iconSvg=\"add_column\" class=\"o-catalog__list__icon\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.restitution.add_icon' | i18n }}</span>\n </button>\n </ng-container>\n <img\n [alt]=\"widget.label | i18n : { warn: false }\"\n [src]=\"widget.icon | getSecuredImage : [600, 600] | async\"\n [height]=\"widget.cover ? 600 : 53\"\n [width]=\"widget.cover ? 600 : 53\"\n [class.is-full-width]=\"widget.cover\"\n />\n <p class=\"o-catalog__list__item__libelle\" *ngIf=\"widget.isCustom; else translate\">{{ widget.label }}</p>\n <ng-template #translate>\n <p class=\"o-catalog__list__item__libelle\">{{ widget.label | i18n : { warn: false } }}</p>\n </ng-template>\n <ng-container *ngIf=\"widget.visibility?.type === PryVisibilityType.PRIVATE\">\n <pry-icon iconSvg=\"private\" [pryTooltip]=\"private\" class=\"is-private\" [height]=\"17\" [width]=\"17\"></pry-icon>\n </ng-container>\n <div class=\"o-catalog__list__item__action\" *ngIf=\"widget.isCustom\">\n <button type=\"button\" class=\"a-btn a-btn--ghost\" (click)=\"emitSelectedRestitution(widget)\">\n {{ '@pry.restitution.view' | i18n }}\n </button>\n </div>\n</li>\n\n<ng-template #private>\n <div class=\"m-tooltip\" role=\"tooltip\">\n <span class=\"m-tooltip__text\">{{ '@pry.restitution.lock' | i18n }}</span>\n </div>\n</ng-template>\n" }]
45
+ args: [{ selector: 'pry-catalog-item', template: "<li\n class=\"o-catalog__list__item\"\n [class.is-point]=\"automaticGridMode$ | async\"\n [draggable]=\"!(automaticGridMode$ | async)\"\n role=\"listitem\"\n aria-grabbed=\"false\"\n aria-haspopup=\"true\"\n tabindex=\"-1\"\n [title]=\"widget.description ?? widget.label | i18n : { warn: false }\"\n (dragstart)=\"dragStart($event, widget.type)\"\n>\n <ng-container *ngIf=\"automaticGridMode$ | async\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--icon-only\"\n (click)=\"viewInDashboard(widget)\"\n [title]=\"'@pry.restitution.add_icon' | i18n\"\n >\n <pry-icon [width]=\"25\" [height]=\"25\" iconSvg=\"add_column\" class=\"o-catalog__list__icon\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.restitution.add_icon' | i18n }}</span>\n </button>\n </ng-container>\n <img\n [alt]=\"widget.label | i18n : { warn: false }\"\n [src]=\"widget.icon | getSecuredImage : [600, 600] | async\"\n [height]=\"widget.cover ? 600 : 53\"\n [width]=\"widget.cover ? 600 : 53\"\n [class.is-full-width]=\"widget.cover\"\n />\n <p class=\"o-catalog__list__item__libelle\" *ngIf=\"widget.isCustom; else translate\">{{ widget.label }}</p>\n <ng-template #translate>\n <p class=\"o-catalog__list__item__libelle\">{{ widget.label | i18n : { warn: false } }}</p>\n </ng-template>\n <ng-container *ngIf=\"widget.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=\"o-catalog__list__item__action\" *ngIf=\"widget.isCustom\">\n <button type=\"button\" class=\"a-btn a-btn--ghost\" (click)=\"emitSelectedRestitution(widget)\">\n {{ '@pry.restitution.view' | i18n }}\n </button>\n </div>\n</li>\n" }]
46
46
  }], ctorParameters: function () { return [{ type: i1.Store }, { type: i2.ToolboxManifestService }]; }, propDecorators: { widget: [{
47
47
  type: Input
48
48
  }], translate: [{
@@ -50,4 +50,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
50
50
  }], selectRestitution: [{
51
51
  type: Output
52
52
  }] } });
53
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restitution-list-item.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/restitution/components/restitution-list-item/restitution-list-item.component.ts","../../../../../../../projects/provoly/dashboard/restitution/components/restitution-list-item/restitution-list-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvE,OAAO,EAEL,eAAe,EACf,gBAAgB,EAChB,mBAAmB,EACnB,kBAAkB,EAClB,iBAAiB,EACjB,wBAAwB,EAGzB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,GAAG,EAAc,MAAM,MAAM,CAAC;;;;;AAMvC,MAAM,OAAO,+BAAgC,SAAQ,wBAAwB;IAS3E,YAAoB,KAAY,EAAU,sBAA8C;QACtF,KAAK,EAAE,CAAC;QADU,UAAK,GAAL,KAAK,CAAO;QAAU,2BAAsB,GAAtB,sBAAsB,CAAwB;QAP/E,cAAS,GAAY,IAAI,CAAC;QACzB,sBAAiB,GAAG,IAAI,YAAY,EAAU,CAAC;QAGzD,sBAAiB,GAAY,KAAK,CAAC;QACnC,sBAAiB,GAAG,iBAAiB,CAAC;QAIpC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,OAAiB,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,CAAC,CAAC;QACtG,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,KAAK;aACjC,MAAM,CAAC,kBAAkB,CAAC,UAAU,CAAC;aACrC,IAAI,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,KAAK,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC;QAChE,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,iBAAiB,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;IAC/G,CAAC;IAED,SAAS,CAAC,MAAiB,EAAE,IAAY;QACvC,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;YAC3B,IAAI,CAAC,sBAAsB,CAAC,YAAY,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;SACxD;IACH,CAAC;IAED,uBAAuB,CAAC,YAA0B;QAChD,IAAI,YAAY,CAAC,QAAQ,EAAE;YACzB,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,MAAc,EAAE,EAAE;gBACvC,IAAI,MAAM,CAAC,EAAE,KAAK,YAAY,CAAC,IAAI,EAAE;oBACnC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;iBACrC;YACH,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED,eAAe,CAAC,MAAoB;QAClC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,uBAAuB,CAAC,EAAE,UAAU,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAC7F,CAAC;8GApCU,+BAA+B;kGAA/B,+BAA+B,0LCnB5C,w9DAgDA;;2FD7Ba,+BAA+B;kBAJ3C,SAAS;+BACE,kBAAkB;iIAInB,MAAM;sBAAd,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACI,iBAAiB;sBAA1B,MAAM","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport {\n  CatalogEntry,\n  ConfigSelectors,\n  DashboardActions,\n  DashboardGridLayout,\n  DashboardSelectors,\n  PryVisibilityType,\n  SubscriptionnerDirective,\n  ToolboxManifestService,\n  Widget\n} from '@provoly/dashboard';\nimport { map, Observable } from 'rxjs';\n\n@Component({\n  selector: 'pry-catalog-item',\n  templateUrl: './restitution-list-item.component.html'\n})\nexport class PryRestitutionListItemComponent extends SubscriptionnerDirective {\n  @Input() widget!: CatalogEntry;\n  @Input() translate: boolean = true;\n  @Output() selectRestitution = new EventEmitter<Widget>();\n  catalog: Widget[] | undefined;\n  automaticGridMode$: Observable<boolean>;\n  automaticGridMode: boolean = false;\n  PryVisibilityType = PryVisibilityType;\n\n  constructor(private store: Store, private toolboxManifestService: ToolboxManifestService) {\n    super();\n    this.store.select(ConfigSelectors.catalog).subscribe((catalog: Widget[]) => (this.catalog = catalog));\n    this.automaticGridMode$ = this.store\n      .select(DashboardSelectors.gridLayout)\n      .pipe(map((layout) => layout !== DashboardGridLayout.MANUAL));\n    this.subscriptions.add(this.automaticGridMode$.subscribe((modeAuto) => (this.automaticGridMode = modeAuto)));\n  }\n\n  dragStart($event: DragEvent, type: string) {\n    if (!this.automaticGridMode) {\n      this.toolboxManifestService.dataTransfer($event, type);\n    }\n  }\n\n  emitSelectedRestitution(catalogEntry: CatalogEntry) {\n    if (catalogEntry.isCustom) {\n      this.catalog?.forEach((widget: Widget) => {\n        if (widget.id === catalogEntry.type) {\n          this.selectRestitution.emit(widget);\n        }\n      });\n    }\n  }\n\n  viewInDashboard(widget: CatalogEntry) {\n    this.store.dispatch(DashboardActions.addWidgetToPresentation({ widgetType: widget.type }));\n  }\n}\n","<li\n  class=\"o-catalog__list__item\"\n  [class.is-point]=\"automaticGridMode$ | async\"\n  [draggable]=\"!(automaticGridMode$ | async)\"\n  role=\"listitem\"\n  aria-grabbed=\"false\"\n  aria-haspopup=\"true\"\n  tabindex=\"-1\"\n  [title]=\"widget.description ?? widget.label | i18n : { warn: false }\"\n  (dragstart)=\"dragStart($event, widget.type)\"\n>\n  <ng-container *ngIf=\"automaticGridMode$ | async\">\n    <button\n      type=\"button\"\n      class=\"a-btn a-btn--icon-only\"\n      (click)=\"viewInDashboard(widget)\"\n      [title]=\"'@pry.restitution.add_icon' | i18n\"\n    >\n      <pry-icon [width]=\"25\" [height]=\"25\" iconSvg=\"add_column\" class=\"o-catalog__list__icon\"></pry-icon>\n      <span class=\"u-visually-hidden\">{{ '@pry.restitution.add_icon' | i18n }}</span>\n    </button>\n  </ng-container>\n  <img\n    [alt]=\"widget.label | i18n : { warn: false }\"\n    [src]=\"widget.icon | getSecuredImage : [600, 600] | async\"\n    [height]=\"widget.cover ? 600 : 53\"\n    [width]=\"widget.cover ? 600 : 53\"\n    [class.is-full-width]=\"widget.cover\"\n  />\n  <p class=\"o-catalog__list__item__libelle\" *ngIf=\"widget.isCustom; else translate\">{{ widget.label }}</p>\n  <ng-template #translate>\n    <p class=\"o-catalog__list__item__libelle\">{{ widget.label | i18n : { warn: false } }}</p>\n  </ng-template>\n  <ng-container *ngIf=\"widget.visibility?.type === PryVisibilityType.PRIVATE\">\n    <pry-icon iconSvg=\"private\" [pryTooltip]=\"private\" class=\"is-private\" [height]=\"17\" [width]=\"17\"></pry-icon>\n  </ng-container>\n  <div class=\"o-catalog__list__item__action\" *ngIf=\"widget.isCustom\">\n    <button type=\"button\" class=\"a-btn a-btn--ghost\" (click)=\"emitSelectedRestitution(widget)\">\n      {{ '@pry.restitution.view' | i18n }}\n    </button>\n  </div>\n</li>\n\n<ng-template #private>\n  <div class=\"m-tooltip\" role=\"tooltip\">\n    <span class=\"m-tooltip__text\">{{ '@pry.restitution.lock' | i18n }}</span>\n  </div>\n</ng-template>\n"]}
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzdGl0dXRpb24tbGlzdC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL3Jlc3RpdHV0aW9uL2NvbXBvbmVudHMvcmVzdGl0dXRpb24tbGlzdC1pdGVtL3Jlc3RpdHV0aW9uLWxpc3QtaXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2Rhc2hib2FyZC9yZXN0aXR1dGlvbi9jb21wb25lbnRzL3Jlc3RpdHV0aW9uLWxpc3QtaXRlbS9yZXN0aXR1dGlvbi1saXN0LWl0ZW0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2RSxPQUFPLEVBRUwsZUFBZSxFQUNmLGdCQUFnQixFQUNoQixtQkFBbUIsRUFDbkIsa0JBQWtCLEVBQ2xCLGlCQUFpQixFQUNqQix3QkFBd0IsRUFHekIsTUFBTSxvQkFBb0IsQ0FBQztBQUM1QixPQUFPLEVBQUUsR0FBRyxFQUFjLE1BQU0sTUFBTSxDQUFDOzs7OztBQU12QyxNQUFNLE9BQU8sK0JBQWdDLFNBQVEsd0JBQXdCO0lBUzNFLFlBQW9CLEtBQVksRUFBVSxzQkFBOEM7UUFDdEYsS0FBSyxFQUFFLENBQUM7UUFEVSxVQUFLLEdBQUwsS0FBSyxDQUFPO1FBQVUsMkJBQXNCLEdBQXRCLHNCQUFzQixDQUF3QjtRQVAvRSxjQUFTLEdBQVksSUFBSSxDQUFDO1FBQ3pCLHNCQUFpQixHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7UUFHekQsc0JBQWlCLEdBQVksS0FBSyxDQUFDO1FBQ25DLHNCQUFpQixHQUFHLGlCQUFpQixDQUFDO1FBSXBDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxPQUFpQixFQUFFLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQztRQUN0RyxJQUFJLENBQUMsa0JBQWtCLEdBQUcsSUFBSSxDQUFDLEtBQUs7YUFDakMsTUFBTSxDQUFDLGtCQUFrQixDQUFDLFVBQVUsQ0FBQzthQUNyQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxNQUFNLEtBQUssbUJBQW1CLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUNoRSxJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsU0FBUyxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDL0csQ0FBQztJQUVELFNBQVMsQ0FBQyxNQUFpQixFQUFFLElBQVk7UUFDdkMsSUFBSSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsRUFBRTtZQUMzQixJQUFJLENBQUMsc0JBQXNCLENBQUMsWUFBWSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztTQUN4RDtJQUNILENBQUM7SUFFRCx1QkFBdUIsQ0FBQyxZQUEwQjtRQUNoRCxJQUFJLFlBQVksQ0FBQyxRQUFRLEVBQUU7WUFDekIsSUFBSSxDQUFDLE9BQU8sRUFBRSxPQUFPLENBQUMsQ0FBQyxNQUFjLEVBQUUsRUFBRTtnQkFDdkMsSUFBSSxNQUFNLENBQUMsRUFBRSxLQUFLLFlBQVksQ0FBQyxJQUFJLEVBQUU7b0JBQ25DLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7aUJBQ3JDO1lBQ0gsQ0FBQyxDQUFDLENBQUM7U0FDSjtJQUNILENBQUM7SUFFRCxlQUFlLENBQUMsTUFBb0I7UUFDbEMsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsZ0JBQWdCLENBQUMsdUJBQXVCLENBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztJQUM3RixDQUFDOzhHQXBDVSwrQkFBK0I7a0dBQS9CLCtCQUErQiwwTENuQjVDLHMzREFnREE7OzJGRDdCYSwrQkFBK0I7a0JBSjNDLFNBQVM7K0JBQ0Usa0JBQWtCO2lJQUluQixNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDSSxpQkFBaUI7c0JBQTFCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3RvcmUgfSBmcm9tICdAbmdyeC9zdG9yZSc7XG5pbXBvcnQge1xuICBDYXRhbG9nRW50cnksXG4gIENvbmZpZ1NlbGVjdG9ycyxcbiAgRGFzaGJvYXJkQWN0aW9ucyxcbiAgRGFzaGJvYXJkR3JpZExheW91dCxcbiAgRGFzaGJvYXJkU2VsZWN0b3JzLFxuICBQcnlWaXNpYmlsaXR5VHlwZSxcbiAgU3Vic2NyaXB0aW9ubmVyRGlyZWN0aXZlLFxuICBUb29sYm94TWFuaWZlc3RTZXJ2aWNlLFxuICBXaWRnZXRcbn0gZnJvbSAnQHByb3ZvbHkvZGFzaGJvYXJkJztcbmltcG9ydCB7IG1hcCwgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdwcnktY2F0YWxvZy1pdGVtJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3Jlc3RpdHV0aW9uLWxpc3QtaXRlbS5jb21wb25lbnQuaHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgUHJ5UmVzdGl0dXRpb25MaXN0SXRlbUNvbXBvbmVudCBleHRlbmRzIFN1YnNjcmlwdGlvbm5lckRpcmVjdGl2ZSB7XG4gIEBJbnB1dCgpIHdpZGdldCE6IENhdGFsb2dFbnRyeTtcbiAgQElucHV0KCkgdHJhbnNsYXRlOiBib29sZWFuID0gdHJ1ZTtcbiAgQE91dHB1dCgpIHNlbGVjdFJlc3RpdHV0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjxXaWRnZXQ+KCk7XG4gIGNhdGFsb2c6IFdpZGdldFtdIHwgdW5kZWZpbmVkO1xuICBhdXRvbWF0aWNHcmlkTW9kZSQ6IE9ic2VydmFibGU8Ym9vbGVhbj47XG4gIGF1dG9tYXRpY0dyaWRNb2RlOiBib29sZWFuID0gZmFsc2U7XG4gIFByeVZpc2liaWxpdHlUeXBlID0gUHJ5VmlzaWJpbGl0eVR5cGU7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzdG9yZTogU3RvcmUsIHByaXZhdGUgdG9vbGJveE1hbmlmZXN0U2VydmljZTogVG9vbGJveE1hbmlmZXN0U2VydmljZSkge1xuICAgIHN1cGVyKCk7XG4gICAgdGhpcy5zdG9yZS5zZWxlY3QoQ29uZmlnU2VsZWN0b3JzLmNhdGFsb2cpLnN1YnNjcmliZSgoY2F0YWxvZzogV2lkZ2V0W10pID0+ICh0aGlzLmNhdGFsb2cgPSBjYXRhbG9nKSk7XG4gICAgdGhpcy5hdXRvbWF0aWNHcmlkTW9kZSQgPSB0aGlzLnN0b3JlXG4gICAgICAuc2VsZWN0KERhc2hib2FyZFNlbGVjdG9ycy5ncmlkTGF5b3V0KVxuICAgICAgLnBpcGUobWFwKChsYXlvdXQpID0+IGxheW91dCAhPT0gRGFzaGJvYXJkR3JpZExheW91dC5NQU5VQUwpKTtcbiAgICB0aGlzLnN1YnNjcmlwdGlvbnMuYWRkKHRoaXMuYXV0b21hdGljR3JpZE1vZGUkLnN1YnNjcmliZSgobW9kZUF1dG8pID0+ICh0aGlzLmF1dG9tYXRpY0dyaWRNb2RlID0gbW9kZUF1dG8pKSk7XG4gIH1cblxuICBkcmFnU3RhcnQoJGV2ZW50OiBEcmFnRXZlbnQsIHR5cGU6IHN0cmluZykge1xuICAgIGlmICghdGhpcy5hdXRvbWF0aWNHcmlkTW9kZSkge1xuICAgICAgdGhpcy50b29sYm94TWFuaWZlc3RTZXJ2aWNlLmRhdGFUcmFuc2ZlcigkZXZlbnQsIHR5cGUpO1xuICAgIH1cbiAgfVxuXG4gIGVtaXRTZWxlY3RlZFJlc3RpdHV0aW9uKGNhdGFsb2dFbnRyeTogQ2F0YWxvZ0VudHJ5KSB7XG4gICAgaWYgKGNhdGFsb2dFbnRyeS5pc0N1c3RvbSkge1xuICAgICAgdGhpcy5jYXRhbG9nPy5mb3JFYWNoKCh3aWRnZXQ6IFdpZGdldCkgPT4ge1xuICAgICAgICBpZiAod2lkZ2V0LmlkID09PSBjYXRhbG9nRW50cnkudHlwZSkge1xuICAgICAgICAgIHRoaXMuc2VsZWN0UmVzdGl0dXRpb24uZW1pdCh3aWRnZXQpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9XG4gIH1cblxuICB2aWV3SW5EYXNoYm9hcmQod2lkZ2V0OiBDYXRhbG9nRW50cnkpIHtcbiAgICB0aGlzLnN0b3JlLmRpc3BhdGNoKERhc2hib2FyZEFjdGlvbnMuYWRkV2lkZ2V0VG9QcmVzZW50YXRpb24oeyB3aWRnZXRUeXBlOiB3aWRnZXQudHlwZSB9KSk7XG4gIH1cbn1cbiIsIjxsaVxuICBjbGFzcz1cIm8tY2F0YWxvZ19fbGlzdF9faXRlbVwiXG4gIFtjbGFzcy5pcy1wb2ludF09XCJhdXRvbWF0aWNHcmlkTW9kZSQgfCBhc3luY1wiXG4gIFtkcmFnZ2FibGVdPVwiIShhdXRvbWF0aWNHcmlkTW9kZSQgfCBhc3luYylcIlxuICByb2xlPVwibGlzdGl0ZW1cIlxuICBhcmlhLWdyYWJiZWQ9XCJmYWxzZVwiXG4gIGFyaWEtaGFzcG9wdXA9XCJ0cnVlXCJcbiAgdGFiaW5kZXg9XCItMVwiXG4gIFt0aXRsZV09XCJ3aWRnZXQuZGVzY3JpcHRpb24gPz8gd2lkZ2V0LmxhYmVsIHwgaTE4biA6IHsgd2FybjogZmFsc2UgfVwiXG4gIChkcmFnc3RhcnQpPVwiZHJhZ1N0YXJ0KCRldmVudCwgd2lkZ2V0LnR5cGUpXCJcbj5cbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImF1dG9tYXRpY0dyaWRNb2RlJCB8IGFzeW5jXCI+XG4gICAgPGJ1dHRvblxuICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICBjbGFzcz1cImEtYnRuIGEtYnRuLS1pY29uLW9ubHlcIlxuICAgICAgKGNsaWNrKT1cInZpZXdJbkRhc2hib2FyZCh3aWRnZXQpXCJcbiAgICAgIFt0aXRsZV09XCInQHByeS5yZXN0aXR1dGlvbi5hZGRfaWNvbicgfCBpMThuXCJcbiAgICA+XG4gICAgICA8cHJ5LWljb24gW3dpZHRoXT1cIjI1XCIgW2hlaWdodF09XCIyNVwiIGljb25Tdmc9XCJhZGRfY29sdW1uXCIgY2xhc3M9XCJvLWNhdGFsb2dfX2xpc3RfX2ljb25cIj48L3ByeS1pY29uPlxuICAgICAgPHNwYW4gY2xhc3M9XCJ1LXZpc3VhbGx5LWhpZGRlblwiPnt7ICdAcHJ5LnJlc3RpdHV0aW9uLmFkZF9pY29uJyB8IGkxOG4gfX08L3NwYW4+XG4gICAgPC9idXR0b24+XG4gIDwvbmctY29udGFpbmVyPlxuICA8aW1nXG4gICAgW2FsdF09XCJ3aWRnZXQubGFiZWwgfCBpMThuIDogeyB3YXJuOiBmYWxzZSB9XCJcbiAgICBbc3JjXT1cIndpZGdldC5pY29uIHwgZ2V0U2VjdXJlZEltYWdlIDogWzYwMCwgNjAwXSB8IGFzeW5jXCJcbiAgICBbaGVpZ2h0XT1cIndpZGdldC5jb3ZlciA/IDYwMCA6IDUzXCJcbiAgICBbd2lkdGhdPVwid2lkZ2V0LmNvdmVyID8gNjAwIDogNTNcIlxuICAgIFtjbGFzcy5pcy1mdWxsLXdpZHRoXT1cIndpZGdldC5jb3ZlclwiXG4gIC8+XG4gIDxwIGNsYXNzPVwiby1jYXRhbG9nX19saXN0X19pdGVtX19saWJlbGxlXCIgKm5nSWY9XCJ3aWRnZXQuaXNDdXN0b207IGVsc2UgdHJhbnNsYXRlXCI+e3sgd2lkZ2V0LmxhYmVsIH19PC9wPlxuICA8bmctdGVtcGxhdGUgI3RyYW5zbGF0ZT5cbiAgICA8cCBjbGFzcz1cIm8tY2F0YWxvZ19fbGlzdF9faXRlbV9fbGliZWxsZVwiPnt7IHdpZGdldC5sYWJlbCB8IGkxOG4gOiB7IHdhcm46IGZhbHNlIH0gfX08L3A+XG4gIDwvbmctdGVtcGxhdGU+XG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCJ3aWRnZXQudmlzaWJpbGl0eT8udHlwZSA9PT0gUHJ5VmlzaWJpbGl0eVR5cGUuUFJJVkFURVwiPlxuICAgIDxwcnktaWNvblxuICAgICAgaWNvblN2Zz1cInByaXZhdGVcIlxuICAgICAgY2xhc3M9XCJpcy1wcml2YXRlIGEtdG9vbHRpcFwiXG4gICAgICBbYXR0ci5kYXRhLXRvb2x0aXBdPVwiJ0BwcnkucmVzdGl0dXRpb24ubG9jaycgfCBpMThuXCJcbiAgICAgIFtoZWlnaHRdPVwiMTdcIlxuICAgICAgW3dpZHRoXT1cIjE3XCJcbiAgICA+PC9wcnktaWNvbj5cbiAgPC9uZy1jb250YWluZXI+XG4gIDxkaXYgY2xhc3M9XCJvLWNhdGFsb2dfX2xpc3RfX2l0ZW1fX2FjdGlvblwiICpuZ0lmPVwid2lkZ2V0LmlzQ3VzdG9tXCI+XG4gICAgPGJ1dHRvbiB0eXBlPVwiYnV0dG9uXCIgY2xhc3M9XCJhLWJ0biBhLWJ0bi0tZ2hvc3RcIiAoY2xpY2spPVwiZW1pdFNlbGVjdGVkUmVzdGl0dXRpb24od2lkZ2V0KVwiPlxuICAgICAge3sgJ0BwcnkucmVzdGl0dXRpb24udmlldycgfCBpMThuIH19XG4gICAgPC9idXR0b24+XG4gIDwvZGl2PlxuPC9saT5cbiJdfQ==
@@ -2,10 +2,10 @@ import { Component, ViewEncapsulation } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  export class PryCatalogCssComponent {
4
4
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryCatalogCssComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
5
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: PryCatalogCssComponent, selector: "pry-restitution-css", ngImport: i0, template: '', isInline: true, styles: [".o-catalog__filters__by-type__list,.o-catalog__list{margin:0;padding:0}.o-catalog__filters__by-type__list li,.o-catalog__list li{list-style:none}.o-catalog{display:flex;flex-direction:column;overflow:scroll;width:28.125rem;height:100%;padding:.9375rem;border-right-width:.0625rem;border-right-style:solid}.o-catalog .a-h2{padding-top:.625rem}.o-catalog pry-restitution{flex:1}.o-catalog__filters{padding-top:.3125rem}.o-catalog__filters__by-name{position:relative;margin-bottom:1.25rem}.o-catalog__filters__by-name .a-icon{position:absolute;left:.6875rem;bottom:.5625rem;pointer-events:none}.o-catalog__filters__by-name .a-form-field{width:60%;padding-left:2.1875rem}.o-catalog__filters__by-type{display:flex;flex-wrap:wrap;column-gap:1.25rem}.o-catalog__filters__by-type__list{display:flex;gap:.3125rem}.o-catalog__filters__by-type__list li{width:2.1875rem;height:2.1875rem}.o-catalog__filters__by-type__list li .a-label{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%;margin:0;border-width:.0625rem;border-style:solid;border-radius:.3125rem}.o-catalog__filters__by-type .a-btn.a-btn--icon-text.-link-like{margin-top:5px;font-weight:300;font-size:.8125rem}.o-catalog__filters__by-type .a-btn.a-btn--icon-text.-link-like[disabled]{opacity:0}.o-catalog .is-point{cursor:default}.o-catalog__list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:.9375rem;justify-content:space-around;padding:1.875rem 0}.o-catalog__list__icon{cursor:pointer}.o-catalog__list pry-catalog-item{max-height:13.125rem}.o-catalog__list__item{position:relative;display:flex;flex-direction:column;justify-content:space-between;align-items:center;max-width:8.125rem;height:100%;text-align:center;cursor:move}.o-catalog__list__item .is-private{position:absolute;top:.3125rem;left:.3125rem}.o-catalog__list__item img{margin-top:.625rem}.o-catalog__list__item img.is-full-width{width:100%;height:30%;object-fit:cover}.o-catalog__list__item .a-btn--icon-only{margin-bottom:.6875rem;padding:.8125rem}.o-catalog__list__item__libelle{width:100%;margin-bottom:0;padding:.9375rem .625rem;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.o-catalog__list__item__action{width:100%;padding:.375rem .625rem;text-align:center}.o-catalog__list__item__action .a-btn--ghost{height:auto;padding:0 .3125rem}.o-catalog__create{align-self:center;width:-moz-fit-content;width:fit-content;margin-bottom:1rem}.o-catalog .o-accordion pry-accordion-item:first-child .o-accordion__title{border-top-style:solid;border-top-width:.0625rem;margin-top:.625rem}\n", ".o-restitution{height:100%;margin:0 auto;border-collapse:collapse;font-size:.875rem;min-width:20.625rem;overflow:hidden}.o-restitution .widget-instanciator{position:relative;height:100%}.o-restitution .m-btn-group.actions{padding-top:1.5625rem;padding-bottom:1.25rem}.o-restitution .a-checkbox{margin-bottom:0rem}.o-restitution label{border-radius:10%}\n", ".o-presentation{margin:0;padding:0}.o-presentation li{list-style:none}.o-manifest-layout__toolbox{height:5.25rem}.o-manifest-layout__toolbox div:first-child{margin-left:auto}.o-manifest-layout__content{height:100%}.o-manifest-layout__content .pointer{cursor:pointer}.pry-viewingpresentation{display:flex;overflow-y:scroll}.pry-viewingpresentation .o-manifest-layout__content,.pry-viewingpresentation .o-dashboard-widget{flex:100% 1 1}.o-presentation{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:1.875rem;padding:.25rem .25rem 1.25rem;overflow-y:visible}.o-presentation .a-h3{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.o-presentation__item{display:flex;flex-direction:column;align-items:stretch}.o-presentation__item__header{position:relative;display:flex;align-items:center;justify-content:center;height:6.875rem}.o-presentation__item__header img{width:auto;height:90%;cursor:pointer}.o-presentation__item__header img.is-full-width{width:100%;height:100%;object-fit:cover}.o-presentation__item__header pry-icon.is-private{position:absolute;top:.625rem;left:.625rem}.o-presentation__item__txt{flex-grow:1;padding:.625rem .9375rem}.o-presentation__item__txt .a-h3{font-size:.875rem}.o-presentation__item__txt .a-p{font-size:.8125rem}.o-presentation__item__txt .a-p.-date{margin-bottom:0}.o-presentation__item__footer{padding:.625rem .9375rem}.o-presentation__item__footer .m-actions-list{justify-content:space-evenly}.o-presentation-consult{width:100%;padding:.9375rem}.description-container{position:relative;width:100%}.description{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;display:inherit;position:relative;line-height:2rem;box-sizing:border-box;pointer-events:none}.description:after{content:\"\";display:block;position:absolute;top:0;right:0;width:40px;height:48px;z-index:1;pointer-events:initial}.description:hover:after{cursor:pointer}.description-tooltip{position:absolute;max-width:50vw;visibility:hidden;background-color:#fff;padding:20px;-webkit-box-shadow:0 0 50px 0 rgba(0,0,0,.3);opacity:0;transition:opacity .5s ease;z-index:2}.description:hover+.description-tooltip{visibility:visible;transition:opacity .2s ease;opacity:1}.title-tooltip{transform:translateY(4rem)}h1.a-presentation-title{font-size:16px;padding-right:20px}.title-container{display:flex}.info-icon{position:relative;width:1.5rem;height:1.5rem;border-radius:50%;background-color:#ccc;cursor:pointer;display:inline-flex;justify-content:center;align-items:center;align-self:center;margin-right:1rem}.o-restitution-catalog .o-manifest-layout__toolbox{height:5.25rem;display:flex;flex-direction:row;justify-content:space-between;align-items:center}.o-restitution-catalog .o-manifest-layout__toolbox div:first-child{margin-left:auto}.o-restitution-catalog .o-catalog__search{position:relative}.o-restitution-catalog .o-catalog__search .a-icon{position:absolute;right:.6875rem;bottom:.5625rem;opacity:.5;pointer-events:none}.o-restitution-catalog .o-manifest-layout__content .o-restitution-wrapper .o-restitution{width:100%}\n"], encapsulation: i0.ViewEncapsulation.None }); }
5
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: PryCatalogCssComponent, selector: "pry-restitution-css", ngImport: i0, template: '', isInline: true, styles: [".o-catalog__filters__by-type__list,.o-catalog__list{margin:0;padding:0}.o-catalog__filters__by-type__list li,.o-catalog__list li{list-style:none}.o-catalog{display:flex;flex-direction:column;overflow:scroll;width:28.125rem;height:100%;padding:.9375rem;border-right-width:.0625rem;border-right-style:solid}.o-catalog .a-h2{padding-top:.625rem}.o-catalog pry-restitution{flex:1}.o-catalog__filters{padding-top:.3125rem}.o-catalog__filters__by-name{position:relative;margin-bottom:1.25rem}.o-catalog__filters__by-name .a-icon{position:absolute;left:.6875rem;bottom:.5625rem;pointer-events:none}.o-catalog__filters__by-name .a-form-field{width:60%;padding-left:2.1875rem}.o-catalog__filters__by-type{display:flex;flex-wrap:wrap;column-gap:1.25rem}.o-catalog__filters__by-type__list{display:flex;gap:.3125rem}.o-catalog__filters__by-type__list li{width:2.1875rem;height:2.1875rem}.o-catalog__filters__by-type__list li .a-label{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%;margin:0;border-width:.0625rem;border-style:solid;border-radius:.3125rem}.o-catalog__filters__by-type .a-btn.a-btn--icon-text.-link-like{margin-top:5px;font-weight:300;font-size:.8125rem}.o-catalog__filters__by-type .a-btn.a-btn--icon-text.-link-like[disabled]{opacity:0}.o-catalog .is-point{cursor:default}.o-catalog__list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:.9375rem;justify-content:space-around;padding:1.875rem 0}.o-catalog__list__icon{cursor:pointer}.o-catalog__list pry-catalog-item{max-height:13.125rem}.o-catalog__list__item{position:relative;display:flex;flex-direction:column;justify-content:space-between;align-items:center;max-width:8.125rem;height:100%;text-align:center;cursor:move}.o-catalog__list__item .is-private{position:absolute;top:.3125rem;left:.3125rem}.o-catalog__list__item img{margin-top:.625rem}.o-catalog__list__item img.is-full-width{width:100%;height:30%;object-fit:cover}.o-catalog__list__item .a-btn--icon-only{margin-bottom:.6875rem;padding:.8125rem}.o-catalog__list__item__libelle{width:100%;margin-bottom:0;padding:.9375rem .625rem;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.o-catalog__list__item__action{width:100%;padding:.375rem .625rem;text-align:center}.o-catalog__list__item__action .a-btn--ghost{height:auto;padding:0 .3125rem}.o-catalog__create{align-self:center;width:-moz-fit-content;width:fit-content;margin-bottom:1rem}.o-catalog .o-accordion pry-accordion-item:first-child .o-accordion__title{border-top-style:solid;border-top-width:.0625rem;margin-top:.625rem}\n", ".o-restitution{height:100%;margin:0 auto;border-collapse:collapse;font-size:.875rem;min-width:20.625rem;overflow:hidden}.o-restitution .widget-instanciator{position:relative;height:100%}.o-restitution .m-btn-group.actions{padding-top:1.5625rem;padding-bottom:1.25rem}.o-restitution .a-checkbox{margin-bottom:0rem}.o-restitution label{border-radius:10%}\n", ".o-presentation{margin:0;padding:0}.o-presentation li{list-style:none}.o-manifest-layout__toolbox{height:5.25rem}.o-manifest-layout__toolbox div:first-child{margin-left:auto}.o-manifest-layout__content{height:100%}.o-manifest-layout__content .pointer{cursor:pointer}.pry-viewingpresentation{display:flex;overflow-y:scroll}.pry-viewingpresentation .o-manifest-layout__content,.pry-viewingpresentation .o-dashboard-widget{flex:100% 1 1}.o-presentation{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:1.875rem;padding:.25rem .25rem 1.25rem;overflow-y:visible}.o-presentation .a-h3{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.o-presentation__item{display:flex;flex-direction:column;align-items:stretch}.o-presentation__item .a-tooltip{height:100%}.o-presentation__item__image{width:auto;height:90%;cursor:pointer;overflow:hidden}.o-presentation__item__image .is-full-width{width:100%;height:100%;object-fit:cover}.o-presentation__item__header{position:relative;display:flex;align-items:center;justify-content:center;height:6.875rem}.o-presentation__item__header pry-icon.is-private{position:absolute;top:.625rem;left:.625rem}.o-presentation__item__txt{flex-grow:1;padding:.625rem .9375rem}.o-presentation__item__txt .a-h3{font-size:.875rem}.o-presentation__item__txt .a-p{font-size:.8125rem}.o-presentation__item__txt .a-p.-date{margin-bottom:0}.o-presentation__item__footer{padding:.625rem .9375rem}.o-presentation__item__footer .m-actions-list{justify-content:space-evenly}.o-presentation-consult{width:100%;padding:.9375rem}.description-container{position:relative;width:100%}.description{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;display:inherit;position:relative;line-height:2rem;box-sizing:border-box;pointer-events:none}.description:after{content:\"\";display:block;position:absolute;top:0;right:0;width:40px;height:48px;z-index:1;pointer-events:initial}.description:hover:after{cursor:pointer}.description-tooltip{position:absolute;max-width:50vw;visibility:hidden;background-color:#fff;padding:20px;-webkit-box-shadow:0 0 50px 0 rgba(0,0,0,.3);opacity:0;transition:opacity .5s ease;z-index:2}.description:hover+.description-tooltip{visibility:visible;transition:opacity .2s ease;opacity:1}.title-tooltip{transform:translateY(4rem)}h1.a-presentation-title{font-size:16px;padding-right:20px}.title-container{display:flex}.info-icon{position:relative;width:1.5rem;height:1.5rem;border-radius:50%;background-color:#ccc;cursor:pointer;display:inline-flex;justify-content:center;align-items:center;align-self:center;margin-right:1rem}.o-restitution-catalog .o-manifest-layout__toolbox{height:5.25rem;display:flex;flex-direction:row;justify-content:space-between;align-items:center}.o-restitution-catalog .o-manifest-layout__toolbox div:first-child{margin-left:auto}.o-restitution-catalog .o-catalog__search{position:relative}.o-restitution-catalog .o-catalog__search .a-icon{position:absolute;right:.6875rem;bottom:.5625rem;opacity:.5;pointer-events:none}.o-restitution-catalog .o-manifest-layout__content .o-restitution-wrapper .o-restitution{width:100%}\n"], encapsulation: i0.ViewEncapsulation.None }); }
6
6
  }
7
7
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryCatalogCssComponent, decorators: [{
8
8
  type: Component,
9
- args: [{ selector: 'pry-restitution-css', template: '', encapsulation: ViewEncapsulation.None, styles: [".o-catalog__filters__by-type__list,.o-catalog__list{margin:0;padding:0}.o-catalog__filters__by-type__list li,.o-catalog__list li{list-style:none}.o-catalog{display:flex;flex-direction:column;overflow:scroll;width:28.125rem;height:100%;padding:.9375rem;border-right-width:.0625rem;border-right-style:solid}.o-catalog .a-h2{padding-top:.625rem}.o-catalog pry-restitution{flex:1}.o-catalog__filters{padding-top:.3125rem}.o-catalog__filters__by-name{position:relative;margin-bottom:1.25rem}.o-catalog__filters__by-name .a-icon{position:absolute;left:.6875rem;bottom:.5625rem;pointer-events:none}.o-catalog__filters__by-name .a-form-field{width:60%;padding-left:2.1875rem}.o-catalog__filters__by-type{display:flex;flex-wrap:wrap;column-gap:1.25rem}.o-catalog__filters__by-type__list{display:flex;gap:.3125rem}.o-catalog__filters__by-type__list li{width:2.1875rem;height:2.1875rem}.o-catalog__filters__by-type__list li .a-label{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%;margin:0;border-width:.0625rem;border-style:solid;border-radius:.3125rem}.o-catalog__filters__by-type .a-btn.a-btn--icon-text.-link-like{margin-top:5px;font-weight:300;font-size:.8125rem}.o-catalog__filters__by-type .a-btn.a-btn--icon-text.-link-like[disabled]{opacity:0}.o-catalog .is-point{cursor:default}.o-catalog__list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:.9375rem;justify-content:space-around;padding:1.875rem 0}.o-catalog__list__icon{cursor:pointer}.o-catalog__list pry-catalog-item{max-height:13.125rem}.o-catalog__list__item{position:relative;display:flex;flex-direction:column;justify-content:space-between;align-items:center;max-width:8.125rem;height:100%;text-align:center;cursor:move}.o-catalog__list__item .is-private{position:absolute;top:.3125rem;left:.3125rem}.o-catalog__list__item img{margin-top:.625rem}.o-catalog__list__item img.is-full-width{width:100%;height:30%;object-fit:cover}.o-catalog__list__item .a-btn--icon-only{margin-bottom:.6875rem;padding:.8125rem}.o-catalog__list__item__libelle{width:100%;margin-bottom:0;padding:.9375rem .625rem;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.o-catalog__list__item__action{width:100%;padding:.375rem .625rem;text-align:center}.o-catalog__list__item__action .a-btn--ghost{height:auto;padding:0 .3125rem}.o-catalog__create{align-self:center;width:-moz-fit-content;width:fit-content;margin-bottom:1rem}.o-catalog .o-accordion pry-accordion-item:first-child .o-accordion__title{border-top-style:solid;border-top-width:.0625rem;margin-top:.625rem}\n", ".o-restitution{height:100%;margin:0 auto;border-collapse:collapse;font-size:.875rem;min-width:20.625rem;overflow:hidden}.o-restitution .widget-instanciator{position:relative;height:100%}.o-restitution .m-btn-group.actions{padding-top:1.5625rem;padding-bottom:1.25rem}.o-restitution .a-checkbox{margin-bottom:0rem}.o-restitution label{border-radius:10%}\n", ".o-presentation{margin:0;padding:0}.o-presentation li{list-style:none}.o-manifest-layout__toolbox{height:5.25rem}.o-manifest-layout__toolbox div:first-child{margin-left:auto}.o-manifest-layout__content{height:100%}.o-manifest-layout__content .pointer{cursor:pointer}.pry-viewingpresentation{display:flex;overflow-y:scroll}.pry-viewingpresentation .o-manifest-layout__content,.pry-viewingpresentation .o-dashboard-widget{flex:100% 1 1}.o-presentation{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:1.875rem;padding:.25rem .25rem 1.25rem;overflow-y:visible}.o-presentation .a-h3{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.o-presentation__item{display:flex;flex-direction:column;align-items:stretch}.o-presentation__item__header{position:relative;display:flex;align-items:center;justify-content:center;height:6.875rem}.o-presentation__item__header img{width:auto;height:90%;cursor:pointer}.o-presentation__item__header img.is-full-width{width:100%;height:100%;object-fit:cover}.o-presentation__item__header pry-icon.is-private{position:absolute;top:.625rem;left:.625rem}.o-presentation__item__txt{flex-grow:1;padding:.625rem .9375rem}.o-presentation__item__txt .a-h3{font-size:.875rem}.o-presentation__item__txt .a-p{font-size:.8125rem}.o-presentation__item__txt .a-p.-date{margin-bottom:0}.o-presentation__item__footer{padding:.625rem .9375rem}.o-presentation__item__footer .m-actions-list{justify-content:space-evenly}.o-presentation-consult{width:100%;padding:.9375rem}.description-container{position:relative;width:100%}.description{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;display:inherit;position:relative;line-height:2rem;box-sizing:border-box;pointer-events:none}.description:after{content:\"\";display:block;position:absolute;top:0;right:0;width:40px;height:48px;z-index:1;pointer-events:initial}.description:hover:after{cursor:pointer}.description-tooltip{position:absolute;max-width:50vw;visibility:hidden;background-color:#fff;padding:20px;-webkit-box-shadow:0 0 50px 0 rgba(0,0,0,.3);opacity:0;transition:opacity .5s ease;z-index:2}.description:hover+.description-tooltip{visibility:visible;transition:opacity .2s ease;opacity:1}.title-tooltip{transform:translateY(4rem)}h1.a-presentation-title{font-size:16px;padding-right:20px}.title-container{display:flex}.info-icon{position:relative;width:1.5rem;height:1.5rem;border-radius:50%;background-color:#ccc;cursor:pointer;display:inline-flex;justify-content:center;align-items:center;align-self:center;margin-right:1rem}.o-restitution-catalog .o-manifest-layout__toolbox{height:5.25rem;display:flex;flex-direction:row;justify-content:space-between;align-items:center}.o-restitution-catalog .o-manifest-layout__toolbox div:first-child{margin-left:auto}.o-restitution-catalog .o-catalog__search{position:relative}.o-restitution-catalog .o-catalog__search .a-icon{position:absolute;right:.6875rem;bottom:.5625rem;opacity:.5;pointer-events:none}.o-restitution-catalog .o-manifest-layout__content .o-restitution-wrapper .o-restitution{width:100%}\n"] }]
9
+ args: [{ selector: 'pry-restitution-css', template: '', encapsulation: ViewEncapsulation.None, styles: [".o-catalog__filters__by-type__list,.o-catalog__list{margin:0;padding:0}.o-catalog__filters__by-type__list li,.o-catalog__list li{list-style:none}.o-catalog{display:flex;flex-direction:column;overflow:scroll;width:28.125rem;height:100%;padding:.9375rem;border-right-width:.0625rem;border-right-style:solid}.o-catalog .a-h2{padding-top:.625rem}.o-catalog pry-restitution{flex:1}.o-catalog__filters{padding-top:.3125rem}.o-catalog__filters__by-name{position:relative;margin-bottom:1.25rem}.o-catalog__filters__by-name .a-icon{position:absolute;left:.6875rem;bottom:.5625rem;pointer-events:none}.o-catalog__filters__by-name .a-form-field{width:60%;padding-left:2.1875rem}.o-catalog__filters__by-type{display:flex;flex-wrap:wrap;column-gap:1.25rem}.o-catalog__filters__by-type__list{display:flex;gap:.3125rem}.o-catalog__filters__by-type__list li{width:2.1875rem;height:2.1875rem}.o-catalog__filters__by-type__list li .a-label{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%;margin:0;border-width:.0625rem;border-style:solid;border-radius:.3125rem}.o-catalog__filters__by-type .a-btn.a-btn--icon-text.-link-like{margin-top:5px;font-weight:300;font-size:.8125rem}.o-catalog__filters__by-type .a-btn.a-btn--icon-text.-link-like[disabled]{opacity:0}.o-catalog .is-point{cursor:default}.o-catalog__list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:.9375rem;justify-content:space-around;padding:1.875rem 0}.o-catalog__list__icon{cursor:pointer}.o-catalog__list pry-catalog-item{max-height:13.125rem}.o-catalog__list__item{position:relative;display:flex;flex-direction:column;justify-content:space-between;align-items:center;max-width:8.125rem;height:100%;text-align:center;cursor:move}.o-catalog__list__item .is-private{position:absolute;top:.3125rem;left:.3125rem}.o-catalog__list__item img{margin-top:.625rem}.o-catalog__list__item img.is-full-width{width:100%;height:30%;object-fit:cover}.o-catalog__list__item .a-btn--icon-only{margin-bottom:.6875rem;padding:.8125rem}.o-catalog__list__item__libelle{width:100%;margin-bottom:0;padding:.9375rem .625rem;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.o-catalog__list__item__action{width:100%;padding:.375rem .625rem;text-align:center}.o-catalog__list__item__action .a-btn--ghost{height:auto;padding:0 .3125rem}.o-catalog__create{align-self:center;width:-moz-fit-content;width:fit-content;margin-bottom:1rem}.o-catalog .o-accordion pry-accordion-item:first-child .o-accordion__title{border-top-style:solid;border-top-width:.0625rem;margin-top:.625rem}\n", ".o-restitution{height:100%;margin:0 auto;border-collapse:collapse;font-size:.875rem;min-width:20.625rem;overflow:hidden}.o-restitution .widget-instanciator{position:relative;height:100%}.o-restitution .m-btn-group.actions{padding-top:1.5625rem;padding-bottom:1.25rem}.o-restitution .a-checkbox{margin-bottom:0rem}.o-restitution label{border-radius:10%}\n", ".o-presentation{margin:0;padding:0}.o-presentation li{list-style:none}.o-manifest-layout__toolbox{height:5.25rem}.o-manifest-layout__toolbox div:first-child{margin-left:auto}.o-manifest-layout__content{height:100%}.o-manifest-layout__content .pointer{cursor:pointer}.pry-viewingpresentation{display:flex;overflow-y:scroll}.pry-viewingpresentation .o-manifest-layout__content,.pry-viewingpresentation .o-dashboard-widget{flex:100% 1 1}.o-presentation{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:1.875rem;padding:.25rem .25rem 1.25rem;overflow-y:visible}.o-presentation .a-h3{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.o-presentation__item{display:flex;flex-direction:column;align-items:stretch}.o-presentation__item .a-tooltip{height:100%}.o-presentation__item__image{width:auto;height:90%;cursor:pointer;overflow:hidden}.o-presentation__item__image .is-full-width{width:100%;height:100%;object-fit:cover}.o-presentation__item__header{position:relative;display:flex;align-items:center;justify-content:center;height:6.875rem}.o-presentation__item__header pry-icon.is-private{position:absolute;top:.625rem;left:.625rem}.o-presentation__item__txt{flex-grow:1;padding:.625rem .9375rem}.o-presentation__item__txt .a-h3{font-size:.875rem}.o-presentation__item__txt .a-p{font-size:.8125rem}.o-presentation__item__txt .a-p.-date{margin-bottom:0}.o-presentation__item__footer{padding:.625rem .9375rem}.o-presentation__item__footer .m-actions-list{justify-content:space-evenly}.o-presentation-consult{width:100%;padding:.9375rem}.description-container{position:relative;width:100%}.description{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;display:inherit;position:relative;line-height:2rem;box-sizing:border-box;pointer-events:none}.description:after{content:\"\";display:block;position:absolute;top:0;right:0;width:40px;height:48px;z-index:1;pointer-events:initial}.description:hover:after{cursor:pointer}.description-tooltip{position:absolute;max-width:50vw;visibility:hidden;background-color:#fff;padding:20px;-webkit-box-shadow:0 0 50px 0 rgba(0,0,0,.3);opacity:0;transition:opacity .5s ease;z-index:2}.description:hover+.description-tooltip{visibility:visible;transition:opacity .2s ease;opacity:1}.title-tooltip{transform:translateY(4rem)}h1.a-presentation-title{font-size:16px;padding-right:20px}.title-container{display:flex}.info-icon{position:relative;width:1.5rem;height:1.5rem;border-radius:50%;background-color:#ccc;cursor:pointer;display:inline-flex;justify-content:center;align-items:center;align-self:center;margin-right:1rem}.o-restitution-catalog .o-manifest-layout__toolbox{height:5.25rem;display:flex;flex-direction:row;justify-content:space-between;align-items:center}.o-restitution-catalog .o-manifest-layout__toolbox div:first-child{margin-left:auto}.o-restitution-catalog .o-catalog__search{position:relative}.o-restitution-catalog .o-catalog__search .a-icon{position:absolute;right:.6875rem;bottom:.5625rem;opacity:.5;pointer-events:none}.o-restitution-catalog .o-manifest-layout__content .o-restitution-wrapper .o-restitution{width:100%}\n"] }]
10
10
  }] });
11
11
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3NzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL3Jlc3RpdHV0aW9uL3N0eWxlL2Nzcy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFRN0QsTUFBTSxPQUFPLHNCQUFzQjs4R0FBdEIsc0JBQXNCO2tHQUF0QixzQkFBc0IsMkRBSnZCLEVBQUU7OzJGQUlELHNCQUFzQjtrQkFObEMsU0FBUzsrQkFDRSxxQkFBcUIsWUFDckIsRUFBRSxpQkFFRyxpQkFBaUIsQ0FBQyxJQUFJIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdwcnktcmVzdGl0dXRpb24tY3NzJyxcbiAgdGVtcGxhdGU6ICcnLFxuICBzdHlsZVVybHM6IFsnLi9fby1yZXN0aXR1dGlvbi1saXN0LnNjc3MnLCAnLi9fby1yZXN0aXR1dGlvbi5zY3NzJywgJy4vcmVzdGl0dXRpb24tY2F0YWxvZy5jb21wb25lbnQuc2NzcyddLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lXG59KVxuZXhwb3J0IGNsYXNzIFByeUNhdGFsb2dDc3NDb21wb25lbnQge31cbiJdfQ==
@@ -15,7 +15,10 @@ export const enTranslations = {
15
15
  or: 'or',
16
16
  title: 'My search',
17
17
  ssTitle: 'New search',
18
- searchByCriteria: 'search by criteria'
18
+ searchByCriteria: 'search by criteria',
19
+ associatedWidget: 'widget associated with this search',
20
+ showAssociatedWidget: 'Show the widget associated with this search',
21
+ otherActions: 'Other actions'
19
22
  },
20
23
  attribute: {
21
24
  title: 'Attribute: ',
@@ -104,12 +107,15 @@ export const enTranslations = {
104
107
  allClasses: 'All classes',
105
108
  oneClass: 'One selected class',
106
109
  manyClasses: '{{nb}} selected classes',
107
- search: 'Search'
110
+ selectClass: 'Select class',
111
+ search: 'Search',
112
+ clear: 'Clear input'
108
113
  },
109
114
  multi: {
110
115
  title: 'Add criterias',
111
116
  addCondition: 'Add one criteria',
112
117
  options: 'Options',
118
+ extraOptions: 'Extra options',
113
119
  multiType: 'Kind of association',
114
120
  search: 'Search',
115
121
  requiredError: 'Value is missing',
@@ -129,4 +135,4 @@ export const enTranslations = {
129
135
  }
130
136
  }
131
137
  };
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"en.translations.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/search/i18n/en.translations.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,cAAc,GAAG;IAC5B,MAAM,EAAE;QACN,MAAM,EAAE;YACN,KAAK,EAAE,QAAQ;YACf,MAAM,EAAE;gBACN,MAAM,EAAE,MAAM;gBACd,MAAM,EAAE,QAAQ;gBAChB,MAAM,EAAE,QAAQ;gBAChB,KAAK,EAAE,OAAO;gBACd,UAAU,EAAE,uBAAuB;gBACnC,IAAI,EAAE,cAAc;gBACpB,KAAK,EAAE,uBAAuB;aAC/B;YACD,IAAI,EAAE;gBACJ,EAAE,EAAE,IAAI;gBACR,KAAK,EAAE,WAAW;gBAClB,OAAO,EAAE,YAAY;gBACrB,gBAAgB,EAAE,oBAAoB;aACvC;YACD,SAAS,EAAE;gBACT,KAAK,EAAE,aAAa;gBACpB,MAAM,EAAE,yBAAyB;aAClC;YACD,IAAI,EAAE;gBACJ,GAAG,EAAE,KAAK;gBACV,EAAE,EAAE,IAAI;aACT;YACD,QAAQ,EAAE;gBACR,KAAK,EAAE,OAAO;gBACd,KAAK,EAAE,iBAAiB;gBACxB,KAAK,EAAE,UAAU;gBACjB,MAAM,EAAE,WAAW;gBACnB,MAAM,EAAE,YAAY;gBACpB,SAAS,EAAE,MAAM;gBACjB,iBAAiB,EAAE,gBAAgB;gBACnC,kBAAkB,EAAE,yCAAyC;gBAC7D,YAAY,EAAE,eAAe;gBAC7B,QAAQ,EAAE,kBAAkB;gBAC5B,WAAW,EAAE,qBAAqB;aACnC;YACD,QAAQ,EAAE;gBACR,QAAQ,EAAE,SAAS;gBACnB,SAAS,EAAE,YAAY;gBACvB,OAAO,EAAE,UAAU;gBACnB,eAAe,EAAE,gBAAgB;gBACjC,YAAY,EAAE,OAAO;gBACrB,YAAY,EAAE,UAAU;gBACxB,iBAAiB,EAAE,cAAc;gBACjC,eAAe,EAAE,YAAY;gBAC7B,iBAAiB,EAAE,SAAS;gBAC5B,iBAAiB,EAAE,SAAS;gBAC5B,eAAe,EAAE,OAAO;gBACxB,aAAa,EAAE,QAAQ;gBACvB,eAAe,EAAE,SAAS;gBAC1B,eAAe,EAAE,SAAS;aAC3B;YACD,WAAW,EAAE;gBACX,MAAM,EAAE,gBAAgB;gBACxB,QAAQ,EAAE,cAAc;gBACxB,QAAQ,EAAE,cAAc;aACzB;YACD,UAAU,EAAE;gBACV,eAAe,EAAE,iBAAiB;gBAClC,IAAI,EAAE,gBAAgB;gBACtB,KAAK,EAAE,4BAA4B;gBACnC,SAAS,EAAE,aAAa;gBACxB,WAAW,EAAE,eAAe;gBAC5B,MAAM,EAAE,QAAQ;gBAChB,IAAI,EAAE,MAAM;gBACZ,WAAW,EAAE,aAAa;gBAC1B,QAAQ,EAAE,KAAK;gBACf,UAAU,EAAE,QAAQ;gBACpB,OAAO,EAAE,SAAS;gBAClB,WAAW,EAAE,SAAS;gBACtB,MAAM,EAAE,eAAe;gBACvB,KAAK,EAAE,YAAY;gBACnB,IAAI,EAAE,MAAM;gBACZ,SAAS,EAAE,sCAAsC;gBACjD,GAAG,EAAE,wBAAwB;gBAC7B,MAAM,EAAE,QAAQ;gBAChB,IAAI,EAAE,MAAM;gBACZ,OAAO,EAAE,UAAU;gBACnB,OAAO,EAAE,UAAU;gBACnB,OAAO,EAAE,eAAe;gBACxB,IAAI,EAAE;oBACJ,GAAG,EAAE,KAAK;oBACV,KAAK,EAAE,OAAO;oBACd,KAAK,EAAE,OAAO;oBACd,KAAK,EAAE,kBAAkB;iBAC1B;gBACD,cAAc,EAAE,mCAAmC;gBACnD,OAAO,EAAE;oBACP,KAAK,EAAE,mBAAmB;oBAC1B,CAAC,EAAE,UAAU;oBACb,EAAE,EAAE,YAAY;oBAChB,EAAE,EAAE,YAAY;oBAChB,EAAE,EAAE,UAAU;iBACf;aACF;YACD,IAAI,EAAE;gBACJ,KAAK,EAAE,0BAA0B;aAClC;YACD,QAAQ,EAAE;gBACR,UAAU,EAAE,aAAa;gBACzB,QAAQ,EAAE,oBAAoB;gBAC9B,WAAW,EAAE,yBAAyB;gBACtC,MAAM,EAAE,QAAQ;aACjB;YACD,KAAK,EAAE;gBACL,KAAK,EAAE,eAAe;gBACtB,YAAY,EAAE,kBAAkB;gBAChC,OAAO,EAAE,SAAS;gBAClB,SAAS,EAAE,qBAAqB;gBAChC,MAAM,EAAE,QAAQ;gBAChB,aAAa,EAAE,kBAAkB;gBACjC,YAAY,EAAE,qBAAqB;gBACnC,WAAW,EAAE,qBAAqB;gBAClC,MAAM,EAAE,6BAA6B;gBACrC,EAAE,EAAE,IAAI;aACT;YACD,MAAM,EAAE;gBACN,KAAK,EAAE,mBAAmB;gBAC1B,MAAM,EAAE,eAAe;gBACvB,UAAU,EAAE;oBACV,KAAK,EAAE,UAAU;oBACjB,WAAW,EAAE,+FAA+F;iBAC7G;aACF;SACF;KACF;CACF,CAAC","sourcesContent":["export const enTranslations = {\n  '@pry': {\n    search: {\n      title: 'Search',\n      button: {\n        update: 'Save',\n        search: 'Search',\n        cancel: 'Cancel',\n        reset: 'Reset',\n        backSearch: 'Back to searches list',\n        mono: 'Class search',\n        multi: 'Business field search'\n      },\n      home: {\n        or: 'or',\n        title: 'My search',\n        ssTitle: 'New search',\n        searchByCriteria: 'search by criteria'\n      },\n      attribute: {\n        title: 'Attribute: ',\n        remove: 'Remove attribute filter'\n      },\n      type: {\n        and: 'AND',\n        or: 'OR'\n      },\n      composed: {\n        class: 'Class',\n        title: 'Include filters',\n        order: 'Add sort',\n        orderA: 'Ascending',\n        orderD: 'Descending',\n        orderNone: 'None',\n        shouldSelectClass: 'Select a class',\n        changeClassWarning: 'Change class will remove all conditions',\n        addCondition: 'Add condition',\n        addGroup: 'Add nested group',\n        removeGroup: 'Remove nested group'\n      },\n      operator: {\n        contains: 'Contain',\n        startWith: 'Start with',\n        endWith: 'End with',\n        notEqualsString: 'Different from',\n        equalsString: 'Match',\n        equalsNumber: 'Equal to',\n        greaterThanNumber: 'Greater than',\n        lowerThanNumber: 'Lower than',\n        innerBoundsNumber: 'Between',\n        outerBoundsNumber: 'Outside',\n        greaterThanDate: 'After',\n        lowerThanDate: 'Before',\n        innerBoundsDate: 'Between',\n        outerBoundsDate: 'Outside'\n      },\n      placeholder: {\n        search: 'Enter value...',\n        minValue: 'Min value...',\n        maxValue: 'Max value...'\n      },\n      namedQuery: {\n        emptyNamedQuery: 'No saved search',\n        open: 'Save search...',\n        title: 'Give a name to this search',\n        saveTitle: 'Save search',\n        renameTitle: 'Rename search',\n        rename: 'Rename',\n        name: 'Name',\n        description: 'Description',\n        favorite: 'Pin',\n        noFavorite: 'Detach',\n        display: 'Display',\n        refreshData: 'Refresh',\n        noSpot: 'Unused search',\n        color: 'Data color',\n        spot: 'Spot',\n        spotTitle: 'This query is used {{length}} times:',\n        use: 'View n°{{windowIndex}}',\n        delete: 'Delete',\n        edit: 'Edit',\n        seeLess: 'see less',\n        seeMore: 'see More',\n        explore: 'Exploring set',\n        type: {\n          map: 'Map',\n          table: 'Table',\n          chart: 'Chart',\n          graph: 'Network Relation'\n        },\n        alreadyEditing: 'A search is already being edited.',\n        refresh: {\n          title: 'Automatic refresh',\n          0: 'Inactive',\n          10: '10 seconds',\n          30: '30 seconds',\n          60: '1 minute'\n        }\n      },\n      mono: {\n        title: 'Search advanded criteria'\n      },\n      fulltext: {\n        allClasses: 'All classes',\n        oneClass: 'One selected class',\n        manyClasses: '{{nb}} selected classes',\n        search: 'Search'\n      },\n      multi: {\n        title: 'Add criterias',\n        addCondition: 'Add one criteria',\n        options: 'Options',\n        multiType: 'Kind of association',\n        search: 'Search',\n        requiredError: 'Value is missing',\n        patternError: 'Format is incorrect',\n        selectField: 'Select the criteria',\n        legend: 'Criteria / classes using it',\n        in: 'in'\n      },\n      params: {\n        title: 'Search parameters',\n        button: 'Save settings',\n        namedQuery: {\n          title: 'Searches',\n          description: 'This part presents default parameters when creating a new search, like color or refresh rate.'\n        }\n      }\n    }\n  }\n};\n"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"en.translations.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/search/i18n/en.translations.ts"],"names":[],"mappings":"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","sourcesContent":["export const enTranslations = {\n  '@pry': {\n    search: {\n      title: 'Search',\n      button: {\n        update: 'Save',\n        search: 'Search',\n        cancel: 'Cancel',\n        reset: 'Reset',\n        backSearch: 'Back to searches list',\n        mono: 'Class search',\n        multi: 'Business field search'\n      },\n      home: {\n        or: 'or',\n        title: 'My search',\n        ssTitle: 'New search',\n        searchByCriteria: 'search by criteria',\n        associatedWidget: 'widget associated with this search',\n        showAssociatedWidget: 'Show the widget associated with this search',\n        otherActions: 'Other actions'\n      },\n      attribute: {\n        title: 'Attribute: ',\n        remove: 'Remove attribute filter'\n      },\n      type: {\n        and: 'AND',\n        or: 'OR'\n      },\n      composed: {\n        class: 'Class',\n        title: 'Include filters',\n        order: 'Add sort',\n        orderA: 'Ascending',\n        orderD: 'Descending',\n        orderNone: 'None',\n        shouldSelectClass: 'Select a class',\n        changeClassWarning: 'Change class will remove all conditions',\n        addCondition: 'Add condition',\n        addGroup: 'Add nested group',\n        removeGroup: 'Remove nested group'\n      },\n      operator: {\n        contains: 'Contain',\n        startWith: 'Start with',\n        endWith: 'End with',\n        notEqualsString: 'Different from',\n        equalsString: 'Match',\n        equalsNumber: 'Equal to',\n        greaterThanNumber: 'Greater than',\n        lowerThanNumber: 'Lower than',\n        innerBoundsNumber: 'Between',\n        outerBoundsNumber: 'Outside',\n        greaterThanDate: 'After',\n        lowerThanDate: 'Before',\n        innerBoundsDate: 'Between',\n        outerBoundsDate: 'Outside'\n      },\n      placeholder: {\n        search: 'Enter value...',\n        minValue: 'Min value...',\n        maxValue: 'Max value...'\n      },\n      namedQuery: {\n        emptyNamedQuery: 'No saved search',\n        open: 'Save search...',\n        title: 'Give a name to this search',\n        saveTitle: 'Save search',\n        renameTitle: 'Rename search',\n        rename: 'Rename',\n        name: 'Name',\n        description: 'Description',\n        favorite: 'Pin',\n        noFavorite: 'Detach',\n        display: 'Display',\n        refreshData: 'Refresh',\n        noSpot: 'Unused search',\n        color: 'Data color',\n        spot: 'Spot',\n        spotTitle: 'This query is used {{length}} times:',\n        use: 'View n°{{windowIndex}}',\n        delete: 'Delete',\n        edit: 'Edit',\n        seeLess: 'see less',\n        seeMore: 'see More',\n        explore: 'Exploring set',\n        type: {\n          map: 'Map',\n          table: 'Table',\n          chart: 'Chart',\n          graph: 'Network Relation'\n        },\n        alreadyEditing: 'A search is already being edited.',\n        refresh: {\n          title: 'Automatic refresh',\n          0: 'Inactive',\n          10: '10 seconds',\n          30: '30 seconds',\n          60: '1 minute'\n        }\n      },\n      mono: {\n        title: 'Search advanded criteria'\n      },\n      fulltext: {\n        allClasses: 'All classes',\n        oneClass: 'One selected class',\n        manyClasses: '{{nb}} selected classes',\n        selectClass: 'Select class',\n        search: 'Search',\n        clear: 'Clear input'\n      },\n      multi: {\n        title: 'Add criterias',\n        addCondition: 'Add one criteria',\n        options: 'Options',\n        extraOptions: 'Extra options',\n        multiType: 'Kind of association',\n        search: 'Search',\n        requiredError: 'Value is missing',\n        patternError: 'Format is incorrect',\n        selectField: 'Select the criteria',\n        legend: 'Criteria / classes using it',\n        in: 'in'\n      },\n      params: {\n        title: 'Search parameters',\n        button: 'Save settings',\n        namedQuery: {\n          title: 'Searches',\n          description: 'This part presents default parameters when creating a new search, like color or refresh rate.'\n        }\n      }\n    }\n  }\n};\n"]}