@provoly/dashboard 0.21.5 → 0.21.6

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 (25) hide show
  1. package/esm2022/lib/core/model/search-mono-class.model.mjs +1 -1
  2. package/esm2022/lib/core/model/search-multi-class.model.mjs +1 -1
  3. package/esm2022/lib/core/store/aggregation/backend-aggregation.service.mjs +2 -2
  4. package/esm2022/lib/core/store/config/config.actions.mjs +4 -2
  5. package/esm2022/lib/core/store/config/config.reducer.mjs +6 -2
  6. package/esm2022/lib/core/store/config/config.selectors.mjs +5 -2
  7. package/esm2022/lib/core/store/image/image.service.mjs +3 -3
  8. package/esm2022/lib/core/store/search/search.service.mjs +14 -4
  9. package/esm2022/lib/core/symbol/symbol.service.mjs +7 -10
  10. package/esm2022/presentation/components/presentation.component.mjs +4 -4
  11. package/esm2022/restitution/components/restitution-catalog/restitution-catalog.component.mjs +3 -4
  12. package/fesm2022/provoly-dashboard-presentation.mjs +3 -3
  13. package/fesm2022/provoly-dashboard-presentation.mjs.map +1 -1
  14. package/fesm2022/provoly-dashboard-restitution.mjs +2 -3
  15. package/fesm2022/provoly-dashboard-restitution.mjs.map +1 -1
  16. package/fesm2022/provoly-dashboard.mjs +34 -19
  17. package/fesm2022/provoly-dashboard.mjs.map +1 -1
  18. package/lib/core/model/search-mono-class.model.d.ts +1 -0
  19. package/lib/core/model/search-multi-class.model.d.ts +2 -0
  20. package/lib/core/store/config/config.actions.d.ts +10 -0
  21. package/lib/core/store/config/config.reducer.d.ts +3 -0
  22. package/lib/core/store/config/config.selectors.d.ts +5 -0
  23. package/lib/core/store/image/image.service.d.ts +1 -1
  24. package/lib/core/store/search/search.service.d.ts +4 -1
  25. package/package.json +7 -7
@@ -180,15 +180,12 @@ export class SymbolService {
180
180
  image.onload = () => {
181
181
  resolve(image);
182
182
  };
183
- if (url.startsWith(INTERNALLY_STORED_IMAGE_PREFIX)) {
184
- const regexp = new RegExp('^' + INTERNALLY_STORED_IMAGE_PREFIX);
185
- this.imageService.getImage(url.replace(regexp, '')).subscribe((res) => {
186
- image.src = this.sanitizer.sanitize(SecurityContext.URL, res.url) ?? DEFAULT_ICON_URL;
187
- });
188
- }
189
- else {
190
- image.src = this.sanitizer.sanitize(SecurityContext.URL, url) ?? DEFAULT_ICON_URL;
191
- }
183
+ const regexp = new RegExp('^' + INTERNALLY_STORED_IMAGE_PREFIX);
184
+ this.imageService
185
+ .getImage(url.replace(regexp, ''), !url.startsWith(INTERNALLY_STORED_IMAGE_PREFIX))
186
+ .subscribe((res) => {
187
+ image.src = this.sanitizer.sanitize(SecurityContext.URL, res.url) ?? DEFAULT_ICON_URL;
188
+ });
192
189
  });
193
190
  return this.cache[url];
194
191
  }
@@ -219,4 +216,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
219
216
  providedIn: 'root'
220
217
  }]
221
218
  }], ctorParameters: function () { return [{ type: i1.Store }, { type: i2.DomSanitizer }, { type: i3.ImageService }]; } });
222
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"symbol.service.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/lib/core/symbol/symbol.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, SecurityContext } from '@angular/core';\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\nimport { Store } from '@ngrx/store';\nimport { Icon, Style } from 'ol/style';\nimport { AttributeMultipleValue, AttributeSimpleValue, Item } from '../model/item.interface';\nimport { Class } from '../store/class/class.interface';\nimport { ClassSelectors } from '../store/class/class.selectors';\nimport { ConfigSelectors } from '../store/config/config.selectors';\nimport {\n  compareOperationFunctions,\n  DEFAULT_ICON_URL,\n  IconDefinitions,\n  IconOptions,\n  IconPosition,\n  IconRule\n} from '../store/config/icon-definitions.interface';\nimport { ImageService, INTERNALLY_STORED_IMAGE_PREFIX } from '../store/image/image.service';\n\nconst defaultImage = new Image();\ndefaultImage.src = DEFAULT_ICON_URL;\n\nconst SUB_ICON_SIZE_PERCENT = 0.25;\n\nexport interface ImageCache {\n  [classId: string]: {\n    ruleSignature: string;\n    images: {\n      [rulesMatch: string]: Promise<HTMLCanvasElement>;\n    };\n    borderedImages: {\n      [rulesMatch: string]: Promise<HTMLCanvasElement>;\n    };\n  };\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class SymbolService {\n  private definitions: IconDefinitions = {};\n  private classes: Class[] = [];\n  private imageCache: ImageCache = {};\n\n  constructor(private store: Store<any>, private sanitizer: DomSanitizer, private imageService: ImageService) {\n    this.store.select(ClassSelectors.classes).subscribe((classes) => (this.classes = classes));\n    this.store.select(ConfigSelectors.iconDefinitions).subscribe((defs) => {\n      this.definitions = defs;\n\n      // For each class, generate all icons for ruleset\n      Object.keys(this.definitions).forEach((classId) => {\n        if (!this.imageCache[classId]) {\n          this.imageCache[classId] = { images: {}, borderedImages: {}, ruleSignature: '--init--' };\n        }\n        if (\n          !this.imageCache[classId] ||\n          this.imageCache[classId].ruleSignature !== JSON.stringify(this.definitions[classId])\n        ) {\n          this.imageCache[classId].ruleSignature = JSON.stringify(this.definitions[classId]);\n          this.imageCache[classId].images = this.generateAllRulesCombinaisonImages(this.definitions[classId]);\n          this.imageCache[classId].borderedImages = this.generateAllRulesCombinaisonImages(\n            this.definitions[classId],\n            '#8cd560'\n          );\n        }\n      });\n    });\n  }\n\n  private generateAllRulesCombinaisonImages(definition: IconOptions[], borderColor?: string) {\n    return this.recursiveRuleMatches(definition)\n      .map((ruleMatch) => ({ [ruleMatch]: this.generateImageForRuleMatch(ruleMatch, definition, borderColor) }))\n      .reduce((p, c) => ({ ...p, ...c }), {});\n  }\n\n  recursiveRuleMatches(definition: IconOptions[]): string[] {\n    const [rule, ...otherRules] = definition;\n    if (!rule) {\n      return [''];\n    }\n    return this.recursiveRuleMatches(otherRules)\n      .map((rule: string) => ['0' + rule, '1' + rule])\n      .flat();\n  }\n\n  private generateImageForRuleMatch(\n    ruleMatch: string,\n    definition: IconOptions[],\n    borderColor?: string\n  ): Promise<HTMLCanvasElement> {\n    const canvas = document.createElement('canvas');\n    const ctx = canvas.getContext('2d') ?? (null as unknown as CanvasRenderingContext2D);\n\n    let applicableRules = definition.filter((_, idx) => ruleMatch[idx] === '1');\n    if (applicableRules.length === 0) {\n      // If no rule match, then apply default rule only\n      applicableRules = definition.filter((def) => !!def.isDefault);\n    }\n\n    const promiseImages = Promise.all(applicableRules.map((rule) => this.downloadImage(rule.iconUrl)));\n\n    return new Promise((resolve, reject) => {\n      promiseImages\n        .then((images) => {\n          canvas.width = 600;\n          canvas.height = 600;\n          const subSize = {\n            width: 600 * SUB_ICON_SIZE_PERCENT,\n            height: 600 * SUB_ICON_SIZE_PERCENT,\n            offsetToRight: 600 * (1 - SUB_ICON_SIZE_PERCENT),\n            offsetToBottom: 600 * (1 - SUB_ICON_SIZE_PERCENT)\n          };\n\n          // Then draw everything\n          applicableRules.forEach((def, idx, arr) => {\n            const image = images[idx];\n            switch (def.position) {\n              case IconPosition.BOTTOM_RIGHT:\n                ctx.globalCompositeOperation = 'source-over';\n                ctx.drawImage(image, subSize.offsetToRight, subSize.offsetToBottom, subSize.width, subSize.height);\n                break;\n              case IconPosition.BOTTOM_LEFT:\n                ctx.globalCompositeOperation = 'source-over';\n                ctx.drawImage(image, 0, subSize.offsetToBottom, subSize.width, subSize.height);\n                break;\n              case IconPosition.TOP_RIGHT:\n                ctx.globalCompositeOperation = 'source-over';\n                ctx.drawImage(image, subSize.offsetToRight, 0, subSize.width, subSize.height);\n                break;\n              case IconPosition.TOP_LEFT:\n                ctx.globalCompositeOperation = 'source-over';\n                ctx.drawImage(image, 0, 0, subSize.width, subSize.height);\n                break;\n              case IconPosition.FULL:\n              default:\n                if (!borderColor) {\n                  // draw original image in normal mode\n                  ctx.globalCompositeOperation = 'source-over';\n                  ctx.drawImage(image, 0, 0, 600, 600);\n                } else {\n                  let i = 0;\n                  const dArr = [-1, -1, 0, -1, 1, -1, -1, 0, 1, 0, -1, 1, 0, 1, 1, 1]; // final y position\n                  const strokeWidth = Math.round(600 * 0.05); // border width: 5% of image width\n                  // draw images at offsets from the array scaled by s\n                  for (; i < dArr.length; i += 2) {\n                    ctx.drawImage(\n                      image,\n                      strokeWidth + dArr[i] * strokeWidth,\n                      strokeWidth + dArr[i + 1] * strokeWidth,\n                      600,\n                      600\n                    );\n                  }\n\n                  // fill with color\n                  ctx.globalCompositeOperation = 'source-in';\n                  ctx.fillStyle = borderColor;\n                  ctx.fillRect(0, 0, canvas.width, canvas.height);\n\n                  // draw original image in normal mode\n                  ctx.globalCompositeOperation = 'source-over';\n                  ctx.drawImage(image, strokeWidth, strokeWidth, 600, 600);\n                }\n            }\n          });\n\n          resolve(canvas);\n        })\n        .catch((err) => reject(err));\n    });\n  }\n\n  getSymbol(item: Item, bordered?: boolean): Promise<HTMLCanvasElement> {\n    // First, we try to apply non-default rules\n    let ruleMatch = (this.definitions[item.oClass] ?? this.definitions['default'])\n      .map((def) => (this.matchRule(item, def.rule) && !def.isDefault ? '1' : '0'))\n      .join('');\n\n    const imageSet = this.imageCache[item.oClass] ?? this.imageCache['default'];\n\n    return imageSet[bordered ? 'borderedImages' : 'images'][ruleMatch];\n  }\n\n  getSymbolOfClass(id: string, noDefault = false): Promise<SafeUrl | null> {\n    const definitionsForClass = (this.definitions[id] || []).find((def) => def.isDefault);\n    const url = definitionsForClass?.iconUrl ?? DEFAULT_ICON_URL;\n    if (url === DEFAULT_ICON_URL && noDefault) {\n      return Promise.resolve(null);\n    }\n    return this.downloadAsUrl(url);\n  }\n\n  downloadAsUrl(url: string): Promise<string> {\n    return new Promise((resolve) => {\n      this.downloadImage((!url ? null : url) ?? DEFAULT_ICON_URL).then((image) => {\n        const canvas = document.createElement('canvas');\n        const ctx = canvas.getContext('2d') ?? (null as unknown as CanvasRenderingContext2D);\n        canvas.width = image.width;\n        canvas.height = image.height;\n        ctx.globalCompositeOperation = 'source-over';\n        ctx.drawImage(image, 0, 0, image.width, image.height);\n        resolve(canvas.toDataURL('image/png'));\n      });\n    });\n  }\n\n  getSymbolAsIconStyle(item: Item, bordered?: boolean): Promise<Style> {\n    return new Promise<Style>((resolve, reject) => {\n      this.getSymbol(item, bordered)\n        .then((canvas) => {\n          const size = (this.definitions[item.oClass] ?? this.definitions['default'])[0].iconSize;\n          const scale = [size[0] / canvas.width, size[1] / canvas.height];\n\n          resolve(\n            new Style({\n              image: new Icon({\n                img: canvas,\n                imgSize: [canvas.width, canvas.height],\n                scale\n              })\n            })\n          );\n        })\n        .catch((err) => console.error(err));\n    });\n  }\n\n  cache: { [url: string]: Promise<HTMLImageElement> } = {};\n\n  downloadImage(url: string): Promise<HTMLImageElement> {\n    if (!!this.cache[url]) return this.cache[url];\n\n    this.cache[url] = new Promise((resolve) => {\n      const image = new Image();\n      image.crossOrigin = 'Anonymous';\n      image.onerror = () => {\n        console.error('error with image', url);\n        resolve(defaultImage);\n      };\n      image.onload = () => {\n        resolve(image);\n      };\n\n      if (url.startsWith(INTERNALLY_STORED_IMAGE_PREFIX)) {\n        const regexp = new RegExp('^' + INTERNALLY_STORED_IMAGE_PREFIX);\n        this.imageService.getImage(url.replace(regexp, '')).subscribe((res) => {\n          image.src = this.sanitizer.sanitize(SecurityContext.URL, res.url) ?? DEFAULT_ICON_URL;\n        });\n      } else {\n        image.src = this.sanitizer.sanitize(SecurityContext.URL, url) ?? DEFAULT_ICON_URL;\n      }\n    });\n\n    return this.cache[url];\n  }\n\n  private matchRule(item: Item, rule?: IconRule) {\n    if (!rule) {\n      return true;\n    }\n    if (!!item.attributes[rule.attributeName]) {\n      if (item.attributes[rule.attributeName].type === 'MULTI') {\n        // multi valued\n        return (item.attributes[rule.attributeName] as AttributeMultipleValue).values\n          .map((attrValue) => compareOperationFunctions[rule.operation](attrValue.value, rule.value))\n          .reduce((p, c) => c || p);\n      } else {\n        // single valued\n        return compareOperationFunctions[rule.operation](\n          (item.attributes[rule.attributeName] as AttributeSimpleValue).value,\n          rule.value\n        );\n      }\n    }\n    return false;\n  }\n}\n"]}
219
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"symbol.service.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/lib/core/symbol/symbol.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, SecurityContext } from '@angular/core';\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\nimport { Store } from '@ngrx/store';\nimport { Icon, Style } from 'ol/style';\nimport { AttributeMultipleValue, AttributeSimpleValue, Item } from '../model/item.interface';\nimport { Class } from '../store/class/class.interface';\nimport { ClassSelectors } from '../store/class/class.selectors';\nimport { ConfigSelectors } from '../store/config/config.selectors';\nimport {\n  compareOperationFunctions,\n  DEFAULT_ICON_URL,\n  IconDefinitions,\n  IconOptions,\n  IconPosition,\n  IconRule\n} from '../store/config/icon-definitions.interface';\nimport { ImageService, INTERNALLY_STORED_IMAGE_PREFIX } from '../store/image/image.service';\n\nconst defaultImage = new Image();\ndefaultImage.src = DEFAULT_ICON_URL;\n\nconst SUB_ICON_SIZE_PERCENT = 0.25;\n\nexport interface ImageCache {\n  [classId: string]: {\n    ruleSignature: string;\n    images: {\n      [rulesMatch: string]: Promise<HTMLCanvasElement>;\n    };\n    borderedImages: {\n      [rulesMatch: string]: Promise<HTMLCanvasElement>;\n    };\n  };\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class SymbolService {\n  private definitions: IconDefinitions = {};\n  private classes: Class[] = [];\n  private imageCache: ImageCache = {};\n\n  constructor(private store: Store<any>, private sanitizer: DomSanitizer, private imageService: ImageService) {\n    this.store.select(ClassSelectors.classes).subscribe((classes) => (this.classes = classes));\n    this.store.select(ConfigSelectors.iconDefinitions).subscribe((defs) => {\n      this.definitions = defs;\n\n      // For each class, generate all icons for ruleset\n      Object.keys(this.definitions).forEach((classId) => {\n        if (!this.imageCache[classId]) {\n          this.imageCache[classId] = { images: {}, borderedImages: {}, ruleSignature: '--init--' };\n        }\n        if (\n          !this.imageCache[classId] ||\n          this.imageCache[classId].ruleSignature !== JSON.stringify(this.definitions[classId])\n        ) {\n          this.imageCache[classId].ruleSignature = JSON.stringify(this.definitions[classId]);\n          this.imageCache[classId].images = this.generateAllRulesCombinaisonImages(this.definitions[classId]);\n          this.imageCache[classId].borderedImages = this.generateAllRulesCombinaisonImages(\n            this.definitions[classId],\n            '#8cd560'\n          );\n        }\n      });\n    });\n  }\n\n  private generateAllRulesCombinaisonImages(definition: IconOptions[], borderColor?: string) {\n    return this.recursiveRuleMatches(definition)\n      .map((ruleMatch) => ({ [ruleMatch]: this.generateImageForRuleMatch(ruleMatch, definition, borderColor) }))\n      .reduce((p, c) => ({ ...p, ...c }), {});\n  }\n\n  recursiveRuleMatches(definition: IconOptions[]): string[] {\n    const [rule, ...otherRules] = definition;\n    if (!rule) {\n      return [''];\n    }\n    return this.recursiveRuleMatches(otherRules)\n      .map((rule: string) => ['0' + rule, '1' + rule])\n      .flat();\n  }\n\n  private generateImageForRuleMatch(\n    ruleMatch: string,\n    definition: IconOptions[],\n    borderColor?: string\n  ): Promise<HTMLCanvasElement> {\n    const canvas = document.createElement('canvas');\n    const ctx = canvas.getContext('2d') ?? (null as unknown as CanvasRenderingContext2D);\n\n    let applicableRules = definition.filter((_, idx) => ruleMatch[idx] === '1');\n    if (applicableRules.length === 0) {\n      // If no rule match, then apply default rule only\n      applicableRules = definition.filter((def) => !!def.isDefault);\n    }\n\n    const promiseImages = Promise.all(applicableRules.map((rule) => this.downloadImage(rule.iconUrl)));\n\n    return new Promise((resolve, reject) => {\n      promiseImages\n        .then((images) => {\n          canvas.width = 600;\n          canvas.height = 600;\n          const subSize = {\n            width: 600 * SUB_ICON_SIZE_PERCENT,\n            height: 600 * SUB_ICON_SIZE_PERCENT,\n            offsetToRight: 600 * (1 - SUB_ICON_SIZE_PERCENT),\n            offsetToBottom: 600 * (1 - SUB_ICON_SIZE_PERCENT)\n          };\n\n          // Then draw everything\n          applicableRules.forEach((def, idx, arr) => {\n            const image = images[idx];\n            switch (def.position) {\n              case IconPosition.BOTTOM_RIGHT:\n                ctx.globalCompositeOperation = 'source-over';\n                ctx.drawImage(image, subSize.offsetToRight, subSize.offsetToBottom, subSize.width, subSize.height);\n                break;\n              case IconPosition.BOTTOM_LEFT:\n                ctx.globalCompositeOperation = 'source-over';\n                ctx.drawImage(image, 0, subSize.offsetToBottom, subSize.width, subSize.height);\n                break;\n              case IconPosition.TOP_RIGHT:\n                ctx.globalCompositeOperation = 'source-over';\n                ctx.drawImage(image, subSize.offsetToRight, 0, subSize.width, subSize.height);\n                break;\n              case IconPosition.TOP_LEFT:\n                ctx.globalCompositeOperation = 'source-over';\n                ctx.drawImage(image, 0, 0, subSize.width, subSize.height);\n                break;\n              case IconPosition.FULL:\n              default:\n                if (!borderColor) {\n                  // draw original image in normal mode\n                  ctx.globalCompositeOperation = 'source-over';\n                  ctx.drawImage(image, 0, 0, 600, 600);\n                } else {\n                  let i = 0;\n                  const dArr = [-1, -1, 0, -1, 1, -1, -1, 0, 1, 0, -1, 1, 0, 1, 1, 1]; // final y position\n                  const strokeWidth = Math.round(600 * 0.05); // border width: 5% of image width\n                  // draw images at offsets from the array scaled by s\n                  for (; i < dArr.length; i += 2) {\n                    ctx.drawImage(\n                      image,\n                      strokeWidth + dArr[i] * strokeWidth,\n                      strokeWidth + dArr[i + 1] * strokeWidth,\n                      600,\n                      600\n                    );\n                  }\n\n                  // fill with color\n                  ctx.globalCompositeOperation = 'source-in';\n                  ctx.fillStyle = borderColor;\n                  ctx.fillRect(0, 0, canvas.width, canvas.height);\n\n                  // draw original image in normal mode\n                  ctx.globalCompositeOperation = 'source-over';\n                  ctx.drawImage(image, strokeWidth, strokeWidth, 600, 600);\n                }\n            }\n          });\n\n          resolve(canvas);\n        })\n        .catch((err) => reject(err));\n    });\n  }\n\n  getSymbol(item: Item, bordered?: boolean): Promise<HTMLCanvasElement> {\n    // First, we try to apply non-default rules\n    let ruleMatch = (this.definitions[item.oClass] ?? this.definitions['default'])\n      .map((def) => (this.matchRule(item, def.rule) && !def.isDefault ? '1' : '0'))\n      .join('');\n\n    const imageSet = this.imageCache[item.oClass] ?? this.imageCache['default'];\n\n    return imageSet[bordered ? 'borderedImages' : 'images'][ruleMatch];\n  }\n\n  getSymbolOfClass(id: string, noDefault = false): Promise<SafeUrl | null> {\n    const definitionsForClass = (this.definitions[id] || []).find((def) => def.isDefault);\n    const url = definitionsForClass?.iconUrl ?? DEFAULT_ICON_URL;\n    if (url === DEFAULT_ICON_URL && noDefault) {\n      return Promise.resolve(null);\n    }\n    return this.downloadAsUrl(url);\n  }\n\n  downloadAsUrl(url: string): Promise<string> {\n    return new Promise((resolve) => {\n      this.downloadImage((!url ? null : url) ?? DEFAULT_ICON_URL).then((image) => {\n        const canvas = document.createElement('canvas');\n        const ctx = canvas.getContext('2d') ?? (null as unknown as CanvasRenderingContext2D);\n        canvas.width = image.width;\n        canvas.height = image.height;\n        ctx.globalCompositeOperation = 'source-over';\n        ctx.drawImage(image, 0, 0, image.width, image.height);\n        resolve(canvas.toDataURL('image/png'));\n      });\n    });\n  }\n\n  getSymbolAsIconStyle(item: Item, bordered?: boolean): Promise<Style> {\n    return new Promise<Style>((resolve, reject) => {\n      this.getSymbol(item, bordered)\n        .then((canvas) => {\n          const size = (this.definitions[item.oClass] ?? this.definitions['default'])[0].iconSize;\n          const scale = [size[0] / canvas.width, size[1] / canvas.height];\n\n          resolve(\n            new Style({\n              image: new Icon({\n                img: canvas,\n                imgSize: [canvas.width, canvas.height],\n                scale\n              })\n            })\n          );\n        })\n        .catch((err) => console.error(err));\n    });\n  }\n\n  cache: { [url: string]: Promise<HTMLImageElement> } = {};\n\n  downloadImage(url: string): Promise<HTMLImageElement> {\n    if (!!this.cache[url]) return this.cache[url];\n\n    this.cache[url] = new Promise((resolve) => {\n      const image = new Image();\n      image.crossOrigin = 'Anonymous';\n      image.onerror = () => {\n        console.error('error with image', url);\n        resolve(defaultImage);\n      };\n      image.onload = () => {\n        resolve(image);\n      };\n\n      const regexp = new RegExp('^' + INTERNALLY_STORED_IMAGE_PREFIX);\n      this.imageService\n        .getImage(url.replace(regexp, ''), !url.startsWith(INTERNALLY_STORED_IMAGE_PREFIX))\n        .subscribe((res) => {\n          image.src = this.sanitizer.sanitize(SecurityContext.URL, res.url) ?? DEFAULT_ICON_URL;\n        });\n    });\n\n    return this.cache[url];\n  }\n\n  private matchRule(item: Item, rule?: IconRule) {\n    if (!rule) {\n      return true;\n    }\n    if (!!item.attributes[rule.attributeName]) {\n      if (item.attributes[rule.attributeName].type === 'MULTI') {\n        // multi valued\n        return (item.attributes[rule.attributeName] as AttributeMultipleValue).values\n          .map((attrValue) => compareOperationFunctions[rule.operation](attrValue.value, rule.value))\n          .reduce((p, c) => c || p);\n      } else {\n        // single valued\n        return compareOperationFunctions[rule.operation](\n          (item.attributes[rule.attributeName] as AttributeSimpleValue).value,\n          rule.value\n        );\n      }\n    }\n    return false;\n  }\n}\n"]}
@@ -134,10 +134,10 @@ export class PryPresentationComponent extends SubscriptionnerDirective {
134
134
  this.overlayRef.attach(new TemplatePortal(this.templateModalActions, this.viewContainerRef));
135
135
  const contextMenu = document.querySelector('div.m-context-menu');
136
136
  if (!!contextMenu && moreButton) {
137
- const toggleActionsModalButton = document.querySelector('#' + moreButton.id);
138
- const rect = toggleActionsModalButton?.getBoundingClientRect();
137
+ const rect = moreButton.getBoundingClientRect();
138
+ contextMenu.style.minWidth = '185px';
139
139
  contextMenu.style.left = (rect?.left ?? 0) - (contextMenu?.clientWidth ?? 0) + 23 + 'px';
140
- contextMenu.style.top = (rect?.top ?? 0) + 25 + 'px';
140
+ contextMenu.style.top = (rect?.top ?? 0) + 30 + 'px';
141
141
  }
142
142
  }
143
143
  else {
@@ -248,4 +248,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
248
248
  }], search: [{
249
249
  type: Input
250
250
  }] } });
251
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"presentation.component.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/presentation/components/presentation.component.ts","../../../../../../projects/provoly/dashboard/presentation/components/presentation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { Component, ElementRef, Input, NgZone, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  DashboardActions,\n  DashboardGridLayout,\n  DashboardManifest,\n  DashboardSelectors,\n  ManifestDescription,\n  PryTitleService,\n  PryVisibility,\n  PryVisibilityType,\n  SubscriptionnerDirective,\n  ViewMode\n} from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, map, Observable, startWith } from 'rxjs';\nimport { v4 } from 'uuid';\n\n@Component({\n  selector: 'pry-presentation',\n  templateUrl: './presentation.component.html'\n})\nexport class PryPresentationComponent extends SubscriptionnerDirective {\n  manifests$: Observable<ManifestDescription[]>;\n  selectedPresentation$ = new BehaviorSubject<ManifestDescription | null>(null);\n  presentation?: ManifestDescription;\n  staticManifest$?: Observable<DashboardManifest>;\n  selectedMode: ViewMode = ViewMode.CATALOG;\n  modalOpened = false;\n  @ViewChild('modalActions', { read: TemplateRef }) templateModalActions!: TemplateRef<any>;\n  @ViewChild('modal', { read: TemplateRef }) template!: TemplateRef<any>;\n  @ViewChild('openModal') openModal!: ElementRef<HTMLButtonElement>;\n  @ViewChild('confirm') confirm!: ElementRef<HTMLButtonElement>;\n  @ViewChild('submit') submit!: ElementRef<HTMLButtonElement>;\n  @ViewChild('cross') cross!: ElementRef<HTMLButtonElement>;\n  @ViewChild('crossVisibility') crossVisibility!: ElementRef<HTMLButtonElement>;\n  @ViewChild('visibilityModal') visibilityModal!: ElementRef;\n  overlayRef?: OverlayRef;\n  visibility: PryVisibility = { type: PryVisibilityType.PRIVATE };\n  PryVisibilityType = PryVisibilityType;\n  accessGroups: string[] = [];\n  @Input() editionStartUrl: string = '/';\n  @Input() consultStartUrl: string = '/';\n  @Input() meAsOwner?: string;\n  ViewMode = ViewMode;\n  search$ = new BehaviorSubject('');\n  filteredPresentations$: Observable<ManifestDescription[]>;\n  listOfManifests$ = new BehaviorSubject<ManifestDescription[] | null>(null);\n  @Input() mode: 'theme' | 'meta' = 'meta';\n\n  @Input() set listOfManifests(manifests: ManifestDescription[] | null) {\n    this.listOfManifests$.next(Array.isArray(manifests) ? manifests : null);\n  }\n\n  @Input() hideToolbox = false;\n  inputSearch$ = new BehaviorSubject('');\n  @Input() set search(query: string) {\n    this.inputSearch$.next(query);\n  }\n\n  constructor(\n    protected store: Store<any>,\n    protected overlay: Overlay,\n    protected viewContainerRef: ViewContainerRef,\n    protected router: Router,\n    protected titleService: PryTitleService,\n    protected activatedRoute: ActivatedRoute,\n    protected ngZone: NgZone\n  ) {\n    super();\n    this.subscriptions.add(\n      this.activatedRoute.queryParams.subscribe((params) => {\n        if (params['create']) {\n          this.creation();\n        }\n      })\n    );\n    this.store.dispatch(DashboardActions.fetchManifestsList());\n    this.manifests$ = combineLatest([\n      this.store\n        .select(DashboardSelectors.manifestsList)\n        .pipe(\n          map((manifestList) =>\n            [...manifestList].sort((a, b) =>\n              a.modificationDate ? b.modificationDate.localeCompare(a.modificationDate) : 1\n            )\n          )\n        ),\n      this.listOfManifests$\n    ]).pipe(map(([dynamics, statics]) => statics ?? dynamics));\n\n    this.staticManifest$ = this.store\n      .select(DashboardSelectors.staticManifest)\n      .pipe(map((staticM) => staticM.windows[0]));\n    this.filteredPresentations$ = combineLatest([\n      this.manifests$,\n      this.search$,\n      this.inputSearch$.pipe(startWith(''))\n    ]).pipe(\n      map(([presentations, search, inputSearch]) =>\n        presentations.filter((presentations) => {\n          const [name, description] = [presentations.name.toLowerCase(), presentations.description.toLowerCase()];\n          const [searchQuery, inputSearchQuery] = [search?.toLowerCase(), inputSearch?.toLowerCase()];\n          return !!searchQuery || !!inputSearchQuery\n            ? (!!searchQuery && (name.includes(searchQuery) || description.includes(searchQuery))) ||\n                (!!inputSearchQuery && (name.includes(inputSearchQuery) || description.includes(inputSearchQuery)))\n            : true;\n        })\n      )\n    );\n    this.subscriptions.add(\n      this.store.select(DashboardSelectors.presentation).subscribe((presentation) => {\n        this.selectedMode = presentation?.viewMode ?? this.ViewMode.CATALOG;\n        this.selectedPresentation$.next(presentation.current ?? null);\n      })\n    );\n    this.titleService.changeTitle('@pry.presentation.title');\n  }\n\n  closeRestitution() {\n    this.selectedPresentation$.next(null);\n    this.selectedMode = ViewMode.CATALOG;\n    this.store.dispatch(DashboardActions.selectPresentation({ presentation: undefined, viewMode: ViewMode.CATALOG }));\n  }\n\n  fetch(presentation: ManifestDescription) {\n    this.store.dispatch(DashboardActions.loadPresentation({ presentation, viewMode: ViewMode.CONSULT }));\n    this.ngZone.run(() => {\n      this.router?.navigateByUrl(this.consultStartUrl);\n    });\n  }\n\n  creation() {\n    this.selectedMode = ViewMode.CREATION;\n    this.store.dispatch(DashboardActions.updateManifest({ manifest: { windows: [] }, selectedIds: [] }));\n    const newPresentation = {\n      presentation: {\n        id: v4(),\n        name: '',\n        description: '',\n        visibility: { type: PryVisibilityType.PRIVATE },\n        groups: [] as string[],\n        owner: true\n      } as ManifestDescription,\n      viewMode: ViewMode.CREATION\n    };\n    this.store.dispatch(DashboardActions.selectPresentation(newPresentation));\n    this.store.dispatch(DashboardActions.setGridLayout({ layout: DashboardGridLayout.FULL }));\n    this.store.dispatch(DashboardActions.updateDisplayOptions({ mode: ViewMode.CREATION }));\n  }\n\n  edit(presentation: ManifestDescription) {\n    this.selectedMode = ViewMode.EDITION;\n    this.selectedPresentation$.next(presentation);\n    this.titleService.changeTitle(presentation.name);\n    this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.EDITION }));\n    this.store.dispatch(DashboardActions.fetchStaticManifest({ id: presentation.id }));\n    this.store.dispatch(DashboardActions.updateDisplayOptions({ mode: ViewMode.EDITION }));\n    this.overlayRef?.dispose();\n    this.overlayRef = undefined;\n  }\n\n  delete(id: string) {\n    this.store.dispatch(DashboardActions.confirmManifestDeletion({ id }));\n    this.toggleModalActions();\n  }\n\n  toggleModalActions(presentation?: ManifestDescription | null, moreButton?: HTMLButtonElement) {\n    if (!this.overlayRef && presentation) {\n      this.selectedPresentation$.next(presentation);\n      this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.CATALOG }));\n      this.store.dispatch(DashboardActions.loadManifest({ id: presentation.id }));\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['m-context-menu-wrapper'],\n          backdropClass: 'backdrop'\n        })\n      );\n      this.overlayRef.backdropClick().subscribe(() => this.toggleModalActions(presentation));\n      this.overlayRef.attach(new TemplatePortal(this.templateModalActions, this.viewContainerRef));\n      const contextMenu = document.querySelector('div.m-context-menu') as HTMLDivElement;\n      if (!!contextMenu && moreButton) {\n        const toggleActionsModalButton = document.querySelector('#' + moreButton.id);\n        const rect = toggleActionsModalButton?.getBoundingClientRect();\n        contextMenu.style.left = (rect?.left ?? 0) - (contextMenu?.clientWidth ?? 0) + 23 + 'px';\n        contextMenu.style.top = (rect?.top ?? 0) + 25 + 'px';\n      }\n    } else {\n      this.overlayRef?.dispose();\n      this.overlayRef = undefined;\n      this.selectedPresentation$.next(null);\n    }\n  }\n\n  toggleModal(presentation?: ManifestDescription | null) {\n    this.modalOpened = !this.modalOpened;\n    if (this.modalOpened && presentation) {\n      this.toggleModalActions();\n      this.selectedPresentation$.next(presentation);\n      this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.CATALOG }));\n      /* we need to load manifest in order to be able to save it later */\n      this.store.dispatch(DashboardActions.loadManifest({ id: presentation.id }));\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['o-modal-wrapper'],\n          backdropClass: 'backdrop'\n        })\n      );\n      this.overlayRef.backdropClick().subscribe(() => this.toggleModal(presentation));\n      this.overlayRef.attach(new TemplatePortal(this.template, this.viewContainerRef));\n      setTimeout(() => {\n        const focus = this.visibilityModal.nativeElement.children[0].children[1].firstElementChild as HTMLButtonElement;\n        focus.focus();\n      }, 10);\n    } else {\n      this.overlayRef?.dispose();\n      this.selectedPresentation$.next(null);\n      this.overlayRef = undefined;\n    }\n  }\n\n  changeVisibility(presentation?: ManifestDescription) {\n    if (presentation) {\n      this.store.dispatch(\n        DashboardActions.saveManifest({\n          id: presentation.id ?? '',\n          name: presentation.name ?? '',\n          description: presentation.description ?? '',\n          image: presentation.image ?? '',\n          groups: this.accessGroups,\n          visibility: this.visibility\n        })\n      );\n    }\n    this.toggleModal(presentation);\n  }\n\n  focusCrossElement() {\n    if (this.crossVisibility) {\n      this.crossVisibility?.nativeElement.focus();\n    }\n    this.cross?.nativeElement.focus();\n  }\n\n  focusValidation() {\n    if (this.confirm) {\n      this.confirm.nativeElement.focus();\n    }\n    this.submit.nativeElement.focus();\n  }\n\n  editContent(selectedPresentation: ManifestDescription) {\n    this.store.dispatch(\n      DashboardActions.loadPresentation({ presentation: selectedPresentation, viewMode: ViewMode.EDITION })\n    );\n    this.ngZone.run(() => {\n      this.router?.navigateByUrl(this.consultStartUrl);\n    });\n  }\n}\n","<pry-presentation-css></pry-presentation-css>\n<div class=\"o-manifest-layout\" [ngSwitch]=\"selectedMode\">\n  <ng-container *ngSwitchDefault>\n    <div class=\"o-manifest-layout__toolbox\" [class.-u-hidden]=\"hideToolbox\">\n      <button\n        class=\"a-btn a-btn--primary a-btn--icon-text a-tooltip -tooltip-no-wrap\"\n        [attr.data-tooltip]=\"'@pry.presentation.create' | i18n\"\n        data-tooltip-position=\"bottom\"\n        type=\"button\"\n        (click)=\"creation()\"\n        *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'create' }\"\n      >\n        {{ '@pry.context.create' | i18n }}\n      </button>\n      <div>\n        <div class=\"o-manifest-layout__toolbox__search\">\n          <label id=\"catalog-search-label\" for=\"catalog-search\" class=\"u-visually-hidden\">\n            <span>{{ '@pry.toolbox.catalog.filter.name' | i18n }}</span>\n          </label>\n          <input\n            id=\"catalog-search\"\n            type=\"text\"\n            class=\"a-form-field\"\n            [placeholder]=\"'@pry.presentation.search' | i18n\"\n            [ngModel]=\"search$ | async\"\n            (ngModelChange)=\"this.search$.next($event)\"\n          />\n          <pry-icon class=\"search-icon\" iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n        </div>\n      </div>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <h1 class=\"a-h1\">{{ '@pry.presentation.title' | i18n }}</h1>\n      <div class=\"o-presentation-wrapper\">\n        <ul class=\"o-presentation\">\n          <li\n            class=\"o-presentation__item\"\n            *ngFor=\"let presentation of filteredPresentations$ | async; let index = index\"\n          >\n            <div class=\"o-presentation__item__header\">\n              <ng-container\n                *ngIf=\"presentation.visibility ? presentation.visibility?.type === PryVisibilityType.PRIVATE : true\"\n              >\n                <pry-icon\n                  iconSvg=\"private\"\n                  class=\"is-private a-tooltip -tooltip-no-wrap\"\n                  [attr.data-tooltip]=\"'@pry.presentation.private' | i18n\"\n                  [height]=\"17\"\n                  [width]=\"17\"\n                ></pry-icon>\n              </ng-container>\n              <div\n                class=\"a-tooltip -tooltip-no-wrap\"\n                (click)=\"fetch(presentation)\"\n                [attr.data-tooltip]=\"'@pry.presentation.view' | i18n\"\n              >\n                <div class=\"o-presentation__item__image\">\n                  <img\n                    alt=\"\"\n                    [class.is-full-width]=\"presentation.cover\"\n                    [src]=\"presentation.image | getSecuredImage | async\"\n                  />\n                </div>\n              </div>\n              <ng-container *ngIf=\"presentation.owner\">\n                <div class=\"more-button\" *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'share' }\">\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--more a-tooltip -tooltip-no-wrap\"\n                    [id]=\"'more-button-' + index\"\n                    [attr.data-tooltip]=\"'@pry.restitution.more' | i18n\"\n                    (click)=\"$event.stopPropagation(); toggleModalActions(presentation, button)\"\n                    #button\n                  >\n                    <pry-icon [height]=\"25\" [width]=\"25\" iconSvg=\"more_horiz\"></pry-icon>\n                  </button>\n                </div>\n              </ng-container>\n            </div>\n            <div class=\"o-presentation__item__txt\" (click)=\"fetch(presentation)\">\n              <div class=\"o-presentation__item__title-container\" ellipsis textElementSelector=\".a-h3\">\n                <h3 class=\"a-h3\">{{ presentation.name }}</h3>\n              </div>\n              <div class=\"o-presentation__item__description-container\" ellipsis textElementSelector=\".a-p\">\n                <div class=\"o-presentation__item__description a-p\">\n                  {{ presentation.description }}\n                </div>\n              </div>\n              <p class=\"a-p -date\">{{ presentation.modificationDate | sinceDate }}</p>\n            </div>\n            <div\n              class=\"o-presentation__item__footer a-tooltip -tooltip-no-wrap\"\n              (click)=\"fetch(presentation)\"\n              [attr.data-tooltip]=\"'@pry.presentation.view' | i18n\"\n            >\n              <button class=\"a-btn\">\n                {{ '@pry.presentation.consult' | i18n }}\n                <pry-icon [width]=\"20\" [height]=\"20\" iconSvg=\"arrow_right\"></pry-icon>\n              </button>\n            </div>\n          </li>\n        </ul>\n      </div>\n    </div>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"ViewMode.CREATION\">\n    <pry-add-edit-presentation\n      [selectedPresentation]=\"selectedPresentation$ | async\"\n      (goBack)=\"closeRestitution()\"\n      [editionStartUrl]=\"editionStartUrl\"\n      [edition]=\"false\"\n      [mode]=\"mode\"\n    ></pry-add-edit-presentation>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"ViewMode.EDITION\">\n    <pry-add-edit-presentation\n      [selectedPresentation]=\"selectedPresentation$ | async\"\n      (goBack)=\"closeRestitution()\"\n      [editionStartUrl]=\"editionStartUrl\"\n      [edition]=\"true\"\n      [mode]=\"mode\"\n    ></pry-add-edit-presentation>\n  </ng-container>\n</div>\n\n<ng-template #modal>\n  <div\n    class=\"o-modal\"\n    #visibilityModal\n    role=\"dialog\"\n    aria-modal=\"true\"\n    aria-labelledby=\"dialog change visibility\"\n    *ngIf=\"selectedPresentation$ | async as selectedPresentation\"\n  >\n    <div class=\"o-modal__top\">\n      <div class=\"o-modal__top__title\">\n        <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.share' | i18n }}</h2>\n      </div>\n      <div class=\"o-modal__top__close\">\n        <button\n          class=\"a-btn a-btn--icon-only\"\n          #crossVisibility\n          (keydown.shift.tab)=\"focusValidation()\"\n          (click)=\"toggleModal()\"\n        >\n          <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n          <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n        </button>\n      </div>\n    </div>\n    <pry-share [ngModel]=\"selectedPresentation.visibility\" (ngModelChange)=\"visibility = $event\"></pry-share>\n    <div class=\"m-btn-group\">\n      <button type=\"button\" class=\"a-btn a-btn--secondary\" (click)=\"toggleModal()\">\n        {{ '@pry.toolbox.manifest.close' | i18n }}\n      </button>\n      <button\n        type=\"submit\"\n        class=\"a-btn a-btn--primary\"\n        #submit\n        (keydown.tab)=\"focusCrossElement()\"\n        (click)=\"changeVisibility(selectedPresentation)\"\n      >\n        {{ '@pry.toolbox.manifest.check' | i18n }}\n      </button>\n    </div>\n  </div>\n</ng-template>\n<ng-template #modalActions>\n  <div class=\"m-context-menu\">\n    <ul\n      class=\"m-context-menu__list\"\n      role=\"dialog\"\n      aria-modal=\"true\"\n      aria-labelledby=\"dialog presentation options\"\n      *ngIf=\"selectedPresentation$ | async as selectedPresentation\"\n    >\n      <li class=\"m-context-menu__list__item\">\n        <button\n          class=\"a-btn -link-like\"\n          (click)=\"edit(selectedPresentation)\"\n          [disabled]=\"!selectedPresentation.owner\"\n          *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'edit' }\"\n        >\n          {{ '@pry.presentation.edition' | i18n }}\n        </button>\n      </li>\n      <li class=\"m-context-menu__list__item\">\n        <button\n          class=\"a-btn -link-like\"\n          (click)=\"editContent(selectedPresentation)\"\n          [disabled]=\"!selectedPresentation.owner\"\n          *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'edit' }\"\n        >\n          {{ '@pry.presentation.editionContent' | i18n }}\n        </button>\n      </li>\n      <li class=\"m-context-menu__list__item\">\n        <button\n          (click)=\"toggleModal(selectedPresentation)\"\n          class=\"a-btn -link-like\"\n          aria-haspopup=\"dialog\"\n          [disabled]=\"!selectedPresentation.owner\"\n          *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'share' }\"\n        >\n          {{ '@pry.presentation.share' | i18n }}\n        </button>\n      </li>\n      <li class=\"m-context-menu__list__item\">\n        <button\n          class=\"a-btn -link-like\"\n          #openModal\n          (click)=\"delete(selectedPresentation.id)\"\n          [disabled]=\"!selectedPresentation.owner\"\n          *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'delete' }\"\n        >\n          {{ '@pry.presentation.delete' | i18n }}\n        </button>\n      </li>\n    </ul>\n  </div>\n</ng-template>\n"]}
251
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"presentation.component.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/presentation/components/presentation.component.ts","../../../../../../projects/provoly/dashboard/presentation/components/presentation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { Component, ElementRef, Input, NgZone, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  DashboardActions,\n  DashboardGridLayout,\n  DashboardManifest,\n  DashboardSelectors,\n  ManifestDescription,\n  PryTitleService,\n  PryVisibility,\n  PryVisibilityType,\n  SubscriptionnerDirective,\n  ViewMode\n} from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, map, Observable, startWith } from 'rxjs';\nimport { v4 } from 'uuid';\n\n@Component({\n  selector: 'pry-presentation',\n  templateUrl: './presentation.component.html'\n})\nexport class PryPresentationComponent extends SubscriptionnerDirective {\n  manifests$: Observable<ManifestDescription[]>;\n  selectedPresentation$ = new BehaviorSubject<ManifestDescription | null>(null);\n  presentation?: ManifestDescription;\n  staticManifest$?: Observable<DashboardManifest>;\n  selectedMode: ViewMode = ViewMode.CATALOG;\n  modalOpened = false;\n  @ViewChild('modalActions', { read: TemplateRef }) templateModalActions!: TemplateRef<any>;\n  @ViewChild('modal', { read: TemplateRef }) template!: TemplateRef<any>;\n  @ViewChild('openModal') openModal!: ElementRef<HTMLButtonElement>;\n  @ViewChild('confirm') confirm!: ElementRef<HTMLButtonElement>;\n  @ViewChild('submit') submit!: ElementRef<HTMLButtonElement>;\n  @ViewChild('cross') cross!: ElementRef<HTMLButtonElement>;\n  @ViewChild('crossVisibility') crossVisibility!: ElementRef<HTMLButtonElement>;\n  @ViewChild('visibilityModal') visibilityModal!: ElementRef;\n  overlayRef?: OverlayRef;\n  visibility: PryVisibility = { type: PryVisibilityType.PRIVATE };\n  PryVisibilityType = PryVisibilityType;\n  accessGroups: string[] = [];\n  @Input() editionStartUrl: string = '/';\n  @Input() consultStartUrl: string = '/';\n  @Input() meAsOwner?: string;\n  ViewMode = ViewMode;\n  search$ = new BehaviorSubject('');\n  filteredPresentations$: Observable<ManifestDescription[]>;\n  listOfManifests$ = new BehaviorSubject<ManifestDescription[] | null>(null);\n  @Input() mode: 'theme' | 'meta' = 'meta';\n\n  @Input() set listOfManifests(manifests: ManifestDescription[] | null) {\n    this.listOfManifests$.next(Array.isArray(manifests) ? manifests : null);\n  }\n\n  @Input() hideToolbox = false;\n  inputSearch$ = new BehaviorSubject('');\n  @Input() set search(query: string) {\n    this.inputSearch$.next(query);\n  }\n\n  constructor(\n    protected store: Store<any>,\n    protected overlay: Overlay,\n    protected viewContainerRef: ViewContainerRef,\n    protected router: Router,\n    protected titleService: PryTitleService,\n    protected activatedRoute: ActivatedRoute,\n    protected ngZone: NgZone\n  ) {\n    super();\n    this.subscriptions.add(\n      this.activatedRoute.queryParams.subscribe((params) => {\n        if (params['create']) {\n          this.creation();\n        }\n      })\n    );\n    this.store.dispatch(DashboardActions.fetchManifestsList());\n    this.manifests$ = combineLatest([\n      this.store\n        .select(DashboardSelectors.manifestsList)\n        .pipe(\n          map((manifestList) =>\n            [...manifestList].sort((a, b) =>\n              a.modificationDate ? b.modificationDate.localeCompare(a.modificationDate) : 1\n            )\n          )\n        ),\n      this.listOfManifests$\n    ]).pipe(map(([dynamics, statics]) => statics ?? dynamics));\n\n    this.staticManifest$ = this.store\n      .select(DashboardSelectors.staticManifest)\n      .pipe(map((staticM) => staticM.windows[0]));\n    this.filteredPresentations$ = combineLatest([\n      this.manifests$,\n      this.search$,\n      this.inputSearch$.pipe(startWith(''))\n    ]).pipe(\n      map(([presentations, search, inputSearch]) =>\n        presentations.filter((presentations) => {\n          const [name, description] = [presentations.name.toLowerCase(), presentations.description.toLowerCase()];\n          const [searchQuery, inputSearchQuery] = [search?.toLowerCase(), inputSearch?.toLowerCase()];\n          return !!searchQuery || !!inputSearchQuery\n            ? (!!searchQuery && (name.includes(searchQuery) || description.includes(searchQuery))) ||\n                (!!inputSearchQuery && (name.includes(inputSearchQuery) || description.includes(inputSearchQuery)))\n            : true;\n        })\n      )\n    );\n    this.subscriptions.add(\n      this.store.select(DashboardSelectors.presentation).subscribe((presentation) => {\n        this.selectedMode = presentation?.viewMode ?? this.ViewMode.CATALOG;\n        this.selectedPresentation$.next(presentation.current ?? null);\n      })\n    );\n    this.titleService.changeTitle('@pry.presentation.title');\n  }\n\n  closeRestitution() {\n    this.selectedPresentation$.next(null);\n    this.selectedMode = ViewMode.CATALOG;\n    this.store.dispatch(DashboardActions.selectPresentation({ presentation: undefined, viewMode: ViewMode.CATALOG }));\n  }\n\n  fetch(presentation: ManifestDescription) {\n    this.store.dispatch(DashboardActions.loadPresentation({ presentation, viewMode: ViewMode.CONSULT }));\n    this.ngZone.run(() => {\n      this.router?.navigateByUrl(this.consultStartUrl);\n    });\n  }\n\n  creation() {\n    this.selectedMode = ViewMode.CREATION;\n    this.store.dispatch(DashboardActions.updateManifest({ manifest: { windows: [] }, selectedIds: [] }));\n    const newPresentation = {\n      presentation: {\n        id: v4(),\n        name: '',\n        description: '',\n        visibility: { type: PryVisibilityType.PRIVATE },\n        groups: [] as string[],\n        owner: true\n      } as ManifestDescription,\n      viewMode: ViewMode.CREATION\n    };\n    this.store.dispatch(DashboardActions.selectPresentation(newPresentation));\n    this.store.dispatch(DashboardActions.setGridLayout({ layout: DashboardGridLayout.FULL }));\n    this.store.dispatch(DashboardActions.updateDisplayOptions({ mode: ViewMode.CREATION }));\n  }\n\n  edit(presentation: ManifestDescription) {\n    this.selectedMode = ViewMode.EDITION;\n    this.selectedPresentation$.next(presentation);\n    this.titleService.changeTitle(presentation.name);\n    this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.EDITION }));\n    this.store.dispatch(DashboardActions.fetchStaticManifest({ id: presentation.id }));\n    this.store.dispatch(DashboardActions.updateDisplayOptions({ mode: ViewMode.EDITION }));\n    this.overlayRef?.dispose();\n    this.overlayRef = undefined;\n  }\n\n  delete(id: string) {\n    this.store.dispatch(DashboardActions.confirmManifestDeletion({ id }));\n    this.toggleModalActions();\n  }\n\n  toggleModalActions(presentation?: ManifestDescription | null, moreButton?: HTMLButtonElement) {\n    if (!this.overlayRef && presentation) {\n      this.selectedPresentation$.next(presentation);\n      this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.CATALOG }));\n      this.store.dispatch(DashboardActions.loadManifest({ id: presentation.id }));\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['m-context-menu-wrapper'],\n          backdropClass: 'backdrop'\n        })\n      );\n      this.overlayRef.backdropClick().subscribe(() => this.toggleModalActions(presentation));\n      this.overlayRef.attach(new TemplatePortal(this.templateModalActions, this.viewContainerRef));\n      const contextMenu = document.querySelector('div.m-context-menu') as HTMLDivElement;\n      if (!!contextMenu && moreButton) {\n        const rect = moreButton.getBoundingClientRect();\n        contextMenu.style.minWidth = '185px'\n        contextMenu.style.left = (rect?.left ?? 0) - (contextMenu?.clientWidth ?? 0) + 23 + 'px';\n        contextMenu.style.top = (rect?.top ?? 0) + 30 + 'px';\n      }\n    } else {\n      this.overlayRef?.dispose();\n      this.overlayRef = undefined;\n      this.selectedPresentation$.next(null);\n    }\n  }\n\n  toggleModal(presentation?: ManifestDescription | null) {\n    this.modalOpened = !this.modalOpened;\n    if (this.modalOpened && presentation) {\n      this.toggleModalActions();\n      this.selectedPresentation$.next(presentation);\n      this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.CATALOG }));\n      /* we need to load manifest in order to be able to save it later */\n      this.store.dispatch(DashboardActions.loadManifest({ id: presentation.id }));\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['o-modal-wrapper'],\n          backdropClass: 'backdrop'\n        })\n      );\n      this.overlayRef.backdropClick().subscribe(() => this.toggleModal(presentation));\n      this.overlayRef.attach(new TemplatePortal(this.template, this.viewContainerRef));\n      setTimeout(() => {\n        const focus = this.visibilityModal.nativeElement.children[0].children[1].firstElementChild as HTMLButtonElement;\n        focus.focus();\n      }, 10);\n    } else {\n      this.overlayRef?.dispose();\n      this.selectedPresentation$.next(null);\n      this.overlayRef = undefined;\n    }\n  }\n\n  changeVisibility(presentation?: ManifestDescription) {\n    if (presentation) {\n      this.store.dispatch(\n        DashboardActions.saveManifest({\n          id: presentation.id ?? '',\n          name: presentation.name ?? '',\n          description: presentation.description ?? '',\n          image: presentation.image ?? '',\n          groups: this.accessGroups,\n          visibility: this.visibility\n        })\n      );\n    }\n    this.toggleModal(presentation);\n  }\n\n  focusCrossElement() {\n    if (this.crossVisibility) {\n      this.crossVisibility?.nativeElement.focus();\n    }\n    this.cross?.nativeElement.focus();\n  }\n\n  focusValidation() {\n    if (this.confirm) {\n      this.confirm.nativeElement.focus();\n    }\n    this.submit.nativeElement.focus();\n  }\n\n  editContent(selectedPresentation: ManifestDescription) {\n    this.store.dispatch(\n      DashboardActions.loadPresentation({ presentation: selectedPresentation, viewMode: ViewMode.EDITION })\n    );\n    this.ngZone.run(() => {\n      this.router?.navigateByUrl(this.consultStartUrl);\n    });\n  }\n}\n","<pry-presentation-css></pry-presentation-css>\n<div class=\"o-manifest-layout\" [ngSwitch]=\"selectedMode\">\n  <ng-container *ngSwitchDefault>\n    <div class=\"o-manifest-layout__toolbox\" [class.-u-hidden]=\"hideToolbox\">\n      <button\n        class=\"a-btn a-btn--primary a-btn--icon-text a-tooltip -tooltip-no-wrap\"\n        [attr.data-tooltip]=\"'@pry.presentation.create' | i18n\"\n        data-tooltip-position=\"bottom\"\n        type=\"button\"\n        (click)=\"creation()\"\n        *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'create' }\"\n      >\n        {{ '@pry.context.create' | i18n }}\n      </button>\n      <div>\n        <div class=\"o-manifest-layout__toolbox__search\">\n          <label id=\"catalog-search-label\" for=\"catalog-search\" class=\"u-visually-hidden\">\n            <span>{{ '@pry.toolbox.catalog.filter.name' | i18n }}</span>\n          </label>\n          <input\n            id=\"catalog-search\"\n            type=\"text\"\n            class=\"a-form-field\"\n            [placeholder]=\"'@pry.presentation.search' | i18n\"\n            [ngModel]=\"search$ | async\"\n            (ngModelChange)=\"this.search$.next($event)\"\n          />\n          <pry-icon class=\"search-icon\" iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n        </div>\n      </div>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <h1 class=\"a-h1\">{{ '@pry.presentation.title' | i18n }}</h1>\n      <div class=\"o-presentation-wrapper\">\n        <ul class=\"o-presentation\">\n          <li\n            class=\"o-presentation__item\"\n            *ngFor=\"let presentation of filteredPresentations$ | async; let index = index\"\n          >\n            <div class=\"o-presentation__item__header\">\n              <ng-container\n                *ngIf=\"presentation.visibility ? presentation.visibility?.type === PryVisibilityType.PRIVATE : true\"\n              >\n                <pry-icon\n                  iconSvg=\"private\"\n                  class=\"is-private a-tooltip -tooltip-no-wrap\"\n                  [attr.data-tooltip]=\"'@pry.presentation.private' | i18n\"\n                  [height]=\"17\"\n                  [width]=\"17\"\n                ></pry-icon>\n              </ng-container>\n              <div\n                class=\"a-tooltip -tooltip-no-wrap\"\n                (click)=\"fetch(presentation)\"\n                [attr.data-tooltip]=\"'@pry.presentation.view' | i18n\"\n              >\n                <div class=\"o-presentation__item__image\">\n                  <img\n                    alt=\"\"\n                    [class.is-full-width]=\"presentation.cover\"\n                    [src]=\"presentation.image | getSecuredImage | async\"\n                  />\n                </div>\n              </div>\n              <ng-container *ngIf=\"presentation.owner\">\n                <div class=\"more-button\" *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'share' }\">\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--more a-tooltip -tooltip-no-wrap\"\n                    [id]=\"'more-button-' + index\"\n                    [attr.data-tooltip]=\"'@pry.restitution.more' | i18n\"\n                    (click)=\"$event.stopPropagation(); toggleModalActions(presentation, button)\"\n                    #button\n                  >\n                    <pry-icon [height]=\"25\" [width]=\"25\" iconSvg=\"more_horiz\"></pry-icon>\n                  </button>\n                </div>\n              </ng-container>\n            </div>\n            <div class=\"o-presentation__item__txt\" (click)=\"fetch(presentation)\">\n              <div class=\"o-presentation__item__title-container\" ellipsis textElementSelector=\".a-h3\">\n                <h3 class=\"a-h3\">{{ presentation.name }}</h3>\n              </div>\n              <div class=\"o-presentation__item__description-container\" ellipsis textElementSelector=\".a-p\">\n                <div class=\"o-presentation__item__description a-p\">\n                  {{ presentation.description }}\n                </div>\n              </div>\n              <p class=\"a-p -date\">{{ presentation.modificationDate | sinceDate }}</p>\n            </div>\n            <div\n              class=\"o-presentation__item__footer a-tooltip -tooltip-no-wrap\"\n              (click)=\"fetch(presentation)\"\n              [attr.data-tooltip]=\"'@pry.presentation.view' | i18n\"\n            >\n              <button class=\"a-btn\">\n                {{ '@pry.presentation.consult' | i18n }}\n                <pry-icon [width]=\"20\" [height]=\"20\" iconSvg=\"arrow_right\"></pry-icon>\n              </button>\n            </div>\n          </li>\n        </ul>\n      </div>\n    </div>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"ViewMode.CREATION\">\n    <pry-add-edit-presentation\n      [selectedPresentation]=\"selectedPresentation$ | async\"\n      (goBack)=\"closeRestitution()\"\n      [editionStartUrl]=\"editionStartUrl\"\n      [edition]=\"false\"\n      [mode]=\"mode\"\n    ></pry-add-edit-presentation>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"ViewMode.EDITION\">\n    <pry-add-edit-presentation\n      [selectedPresentation]=\"selectedPresentation$ | async\"\n      (goBack)=\"closeRestitution()\"\n      [editionStartUrl]=\"editionStartUrl\"\n      [edition]=\"true\"\n      [mode]=\"mode\"\n    ></pry-add-edit-presentation>\n  </ng-container>\n</div>\n\n<ng-template #modal>\n  <div\n    class=\"o-modal\"\n    #visibilityModal\n    role=\"dialog\"\n    aria-modal=\"true\"\n    aria-labelledby=\"dialog change visibility\"\n    *ngIf=\"selectedPresentation$ | async as selectedPresentation\"\n  >\n    <div class=\"o-modal__top\">\n      <div class=\"o-modal__top__title\">\n        <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.share' | i18n }}</h2>\n      </div>\n      <div class=\"o-modal__top__close\">\n        <button\n          class=\"a-btn a-btn--icon-only\"\n          #crossVisibility\n          (keydown.shift.tab)=\"focusValidation()\"\n          (click)=\"toggleModal()\"\n        >\n          <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n          <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n        </button>\n      </div>\n    </div>\n    <pry-share [ngModel]=\"selectedPresentation.visibility\" (ngModelChange)=\"visibility = $event\"></pry-share>\n    <div class=\"m-btn-group\">\n      <button type=\"button\" class=\"a-btn a-btn--secondary\" (click)=\"toggleModal()\">\n        {{ '@pry.toolbox.manifest.close' | i18n }}\n      </button>\n      <button\n        type=\"submit\"\n        class=\"a-btn a-btn--primary\"\n        #submit\n        (keydown.tab)=\"focusCrossElement()\"\n        (click)=\"changeVisibility(selectedPresentation)\"\n      >\n        {{ '@pry.toolbox.manifest.check' | i18n }}\n      </button>\n    </div>\n  </div>\n</ng-template>\n<ng-template #modalActions>\n  <div class=\"m-context-menu\">\n    <ul\n      class=\"m-context-menu__list\"\n      role=\"dialog\"\n      aria-modal=\"true\"\n      aria-labelledby=\"dialog presentation options\"\n      *ngIf=\"selectedPresentation$ | async as selectedPresentation\"\n    >\n      <li class=\"m-context-menu__list__item\">\n        <button\n          class=\"a-btn -link-like\"\n          (click)=\"edit(selectedPresentation)\"\n          [disabled]=\"!selectedPresentation.owner\"\n          *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'edit' }\"\n        >\n          {{ '@pry.presentation.edition' | i18n }}\n        </button>\n      </li>\n      <li class=\"m-context-menu__list__item\">\n        <button\n          class=\"a-btn -link-like\"\n          (click)=\"editContent(selectedPresentation)\"\n          [disabled]=\"!selectedPresentation.owner\"\n          *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'edit' }\"\n        >\n          {{ '@pry.presentation.editionContent' | i18n }}\n        </button>\n      </li>\n      <li class=\"m-context-menu__list__item\">\n        <button\n          (click)=\"toggleModal(selectedPresentation)\"\n          class=\"a-btn -link-like\"\n          aria-haspopup=\"dialog\"\n          [disabled]=\"!selectedPresentation.owner\"\n          *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'share' }\"\n        >\n          {{ '@pry.presentation.share' | i18n }}\n        </button>\n      </li>\n      <li class=\"m-context-menu__list__item\">\n        <button\n          class=\"a-btn -link-like\"\n          #openModal\n          (click)=\"delete(selectedPresentation.id)\"\n          [disabled]=\"!selectedPresentation.owner\"\n          *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'delete' }\"\n        >\n          {{ '@pry.presentation.delete' | i18n }}\n        </button>\n      </li>\n    </ul>\n  </div>\n</ng-template>\n"]}
@@ -64,10 +64,9 @@ export class PryRestitutionCatalogComponent {
64
64
  this.overlayRef.attach(new TemplatePortal(this.templateActions, this.viewContainerRef));
65
65
  const contextMenu = document.querySelector('div.m-context-menu');
66
66
  if (!!contextMenu && moreButton) {
67
- const toggleActionsModalButton = document.querySelector('#' + moreButton.id);
68
- const rect = toggleActionsModalButton?.getBoundingClientRect();
67
+ const rect = moreButton?.getBoundingClientRect();
69
68
  contextMenu.style.left = (rect?.left ?? 0) - (contextMenu?.clientWidth ?? 0) + 23 + 'px';
70
- contextMenu.style.top = (rect?.top ?? 0) + 25 + 'px';
69
+ contextMenu.style.top = (rect?.top ?? 0) + 30 + 'px';
71
70
  }
72
71
  }
73
72
  else {
@@ -86,4 +85,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
86
85
  type: ViewChild,
87
86
  args: ['modalActions', { read: TemplateRef }]
88
87
  }] } });
89
- //# 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":"AAAA,OAAO,EAAW,aAAa,EAAc,MAAM,sBAAsB,CAAC;AAC1E,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,SAAS,EAAoB,MAAM,eAAe,CAAC;AAEpF,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,iBAAiB,EAAE,QAAQ,EAAU,MAAM,oBAAoB,CAAC;AACzG,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,GAAG,EAAc,MAAM,MAAM,CAAC;AACvE,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;;;;;;;;;;AAMrD,MAAM,OAAO,8BAA8B;IAYzC,YAAoB,KAAY,EAAY,OAAgB,EAAY,gBAAkC;QAAtF,UAAK,GAAL,KAAK,CAAO;QAAY,YAAO,GAAP,OAAO,CAAS;QAAY,qBAAgB,GAAhB,gBAAgB,CAAkB;QAV1G,YAAO,GAAG,IAAI,eAAe,CAAC,EAAE,CAAC,CAAC;QAElC,SAAI,GAAG,QAAQ,CAAC;QAChB,iBAAY,GAAa,QAAQ,CAAC,OAAO,CAAC;QAC1C,wBAAmB,GAAkB,IAAI,CAAC;QAE1C,sBAAiB,GAAG,iBAAiB,CAAC;QAKpC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC,CAAC;QACjD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC,CAAC;QAElD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK;aAC5B,MAAM,CAAC,eAAe,CAAC,OAAO,CAAC;aAC/B,IAAI,CACH,GAAG,CAAC,CAAC,eAAe,EAAE,EAAE,CACtB,CAAC,GAAG,eAAe,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACjC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC,CAC9E,CACF,CACF,CAAC;QACJ,IAAI,CAAC,oBAAoB,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAChF,GAAG,CAAC,CAAC,CAAC,YAAY,EAAE,MAAM,CAAC,EAAE,EAAE,CAC7B,YAAY,CAAC,MAAM,CACjB,CAAC,WAAW,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,IAAI,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CACtG,CACF,CACF,CAAC;IACJ,CAAC;IAED,UAAU,CAAC,OAAiB;QAC1B,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC;IAC9B,CAAC;IAED,iBAAiB,CAAC,WAAmB;QACnC,IAAI,CAAC,mBAAmB,GAAG,WAAW,CAAC;QACvC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACnC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACxB,CAAC;IAED,gBAAgB,CAAC,MAAY;QAC3B,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;QAChC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACrC,CAAC;IAED,iBAAiB,CAAC,EAAU;QAC1B,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,0BAA0B,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QACtE,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,eAAe,CAAC,WAAmB;QACjC,IAAI,CAAC,mBAAmB,GAAG,WAAW,CAAC;QACvC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QAClC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACtB,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,CAAC;QAC3B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;IAC9B,CAAC;IAED,kBAAkB,CAAC,WAAoB,EAAE,UAA8B;QACrE,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,WAAW,EAAE;YACnC,IAAI,CAAC,mBAAmB,GAAG,WAAW,CAAC;YACvC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CACnC,IAAI,aAAa,CAAC;gBAChB,WAAW,EAAE,IAAI;gBACjB,UAAU,EAAE,CAAC,wBAAwB,CAAC;gBACtC,aAAa,EAAE,UAAU;aAC1B,CAAC,CACH,CAAC;YACF,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,CAAC,CAAC;YACtF,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,cAAc,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC;YACxF,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC,oBAAoB,CAAmB,CAAC;YACnF,IAAI,CAAC,CAAC,WAAW,IAAI,UAAU,EAAE;gBAC/B,MAAM,wBAAwB,GAAG,QAAQ,CAAC,aAAa,CAAC,GAAG,GAAG,UAAU,CAAC,EAAE,CAAC,CAAC;gBAC7E,MAAM,IAAI,GAAG,wBAAwB,EAAE,qBAAqB,EAAE,CAAC;gBAC/D,WAAW,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,IAAI,EAAE,IAAI,IAAI,CAAC,CAAC,GAAG,CAAC,WAAW,EAAE,WAAW,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC;gBACzF,WAAW,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC;aACtD;SACF;aAAM;YACL,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,CAAC;YAC3B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;YAC5B,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;SACjC;IACH,CAAC;+GAtFU,8BAA8B;mGAA9B,8BAA8B,2JAUN,WAAW,6BCrBhD,4/OAsLA;;4FD3Ka,8BAA8B;kBAJ1C,SAAS;+BACE,yBAAyB;iJAae,eAAe;sBAAhE,SAAS;uBAAC,cAAc,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { Component, TemplateRef, ViewChild, 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';\nimport { TemplatePortal } from '@angular/cdk/portal';\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  mode = ViewMode;\n  selectedMode: ViewMode = ViewMode.CATALOG;\n  selectedRestitution: Widget | null = null;\n  restitution?: Widget;\n  PryVisibilityType = PryVisibilityType;\n  overlayRef?: OverlayRef;\n  @ViewChild('modalActions', { read: TemplateRef }) templateActions!: TemplateRef<any>;\n\n  constructor(private store: Store, protected overlay: Overlay, protected viewContainerRef: ViewContainerRef) {\n    this.store.dispatch(ConfigActions.loadWidgets());\n    this.store.dispatch(ConfigActions.getMapStyles());\n\n    this.restitutions$ = this.store\n      .select(ConfigSelectors.catalog)\n      .pipe(\n        map((restitutionList) =>\n          [...restitutionList].sort((a, b) =>\n            a.modificationDate ? b.modificationDate.localeCompare(a.modificationDate) : 1\n          )\n        )\n      );\n    this.filteredRestitution$ = combineLatest([this.restitutions$, this.search$]).pipe(\n      map(([restitutions, search]) =>\n        restitutions.filter(\n          (restitution) => search.length === 0 || restitution.name.toLowerCase().includes(search.toLowerCase())\n        )\n      )\n    );\n  }\n\n  selectMode(newMode: ViewMode) {\n    this.selectedMode = newMode;\n  }\n\n  selectRestitution(restitution: Widget) {\n    this.selectedRestitution = restitution;\n    this.selectMode(this.mode.CONSULT);\n    this.search$.next('');\n  }\n\n  closeRestitution($event: void) {\n    this.selectedRestitution = null;\n    this.selectMode(this.mode.CATALOG);\n  }\n\n  deleteRestitution(id: string) {\n    this.store.dispatch(ConfigActions.confirmRestitutionDeletion({ id }));\n    this.toggleModalActions();\n  }\n\n  editRestitution(restitution: Widget) {\n    this.selectedRestitution = restitution;\n    this.selectMode(ViewMode.EDITION);\n    this.search$.next('');\n    this.overlayRef?.dispose();\n    this.overlayRef = undefined;\n  }\n\n  toggleModalActions(restitution?: Widget, moreButton?: HTMLButtonElement) {\n    if (!this.overlayRef && restitution) {\n      this.selectedRestitution = restitution;\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['m-context-menu-wrapper'],\n          backdropClass: 'backdrop'\n        })\n      );\n      this.overlayRef.backdropClick().subscribe(() => this.toggleModalActions(restitution));\n      this.overlayRef.attach(new TemplatePortal(this.templateActions, this.viewContainerRef));\n      const contextMenu = document.querySelector('div.m-context-menu') as HTMLDivElement;\n      if (!!contextMenu && moreButton) {\n        const toggleActionsModalButton = document.querySelector('#' + moreButton.id);\n        const rect = toggleActionsModalButton?.getBoundingClientRect();\n        contextMenu.style.left = (rect?.left ?? 0) - (contextMenu?.clientWidth ?? 0) + 23 + 'px';\n        contextMenu.style.top = (rect?.top ?? 0) + 25 + 'px';\n      }\n    } else {\n      this.overlayRef?.dispose();\n      this.overlayRef = undefined;\n      this.selectedRestitution = null;\n    }\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 -tooltip-no-wrap\"\n        [attr.data-tooltip]=\"'@pry.restitution.create' | i18n\"\n        data-tooltip-position=\"bottom\"\n        *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'create' }\"\n      >\n        {{ '@pry.context.create' | i18n }}\n      </button>\n      <div>\n        <div class=\"o-catalog__search o-manifest-layout__toolbox__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; let index = index\">\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 -tooltip-no-wrap\"\n                  [attr.data-tooltip]=\"'@pry.restitution.lock' | i18n\"\n                  [height]=\"17\"\n                  [width]=\"17\"\n                ></pry-icon>\n              </ng-container>\n              <div\n                class=\"a-tooltip -tooltip-no-wrap\"\n                (click)=\"selectRestitution(restitution)\"\n                [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n              >\n                <div class=\"o-presentation__item__image\">\n                  <img\n                    alt=\"\"\n                    [class.is-full-width]=\"restitution.cover\"\n                    [src]=\"restitution.image | getSecuredImage : [600, 600] | async\"\n                    class=\"pointer\"\n                  />\n                </div>\n              </div>\n              <ng-container *ngIf=\"restitution.owner\">\n                <div class=\"more-button\">\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--more a-tooltip -tooltip-no-wrap\"\n                    [id]=\"'more-actions-' + index\"\n                    [attr.data-tooltip]=\"'@pry.restitution.more' | i18n\"\n                    (click)=\"toggleModalActions(restitution, button)\"\n                    #button\n                  >\n                    <pry-icon [height]=\"25\" [width]=\"25\" iconSvg=\"more_horiz\"></pry-icon>\n                  </button>\n                </div>\n              </ng-container>\n            </div>\n            <div\n              class=\"o-presentation__item__txt\"\n              (click)=\"selectRestitution(restitution)\"\n              [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n            >\n              <div class=\"o-presentation__item__title-container\" ellipsis textElementSelector=\".a-h3\">\n                <h3 class=\"a-h3\">{{ restitution.name }}</h3>\n              </div>\n              <div class=\"o-presentation__item__description-container\" ellipsis textElementSelector=\".a-p\">\n                <div class=\"o-presentation__item__description a-p\">\n                  {{ restitution.description }}\n                </div>\n              </div>\n              <p class=\"a-p -date\">{{ restitution.modificationDate | sinceDate }}</p>\n            </div>\n\n            <div\n              class=\"o-presentation__item__footer a-tooltip -tooltip-no-wrap\"\n              (click)=\"selectRestitution(restitution)\"\n              [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n            >\n              <button class=\"a-btn\">\n                {{ '@pry.restitution.view' | i18n }}\n                <pry-icon [width]=\"20\" [height]=\"20\" iconSvg=\"arrow_right\"></pry-icon>\n              </button>\n            </div>\n          </li>\n        </ul>\n      </div>\n    </div>\n  </ng-template>\n  <ng-template #modalActions>\n    <div class=\"m-context-menu\">\n      <ul\n        *ngIf=\"selectedRestitution\"\n        class=\"m-context-menu__list\"\n        role=\"dialog\"\n        aria-modal=\"true\"\n        aria-labelledby=\"dialog restitution options\"\n      >\n        <li class=\"m-context-menu__list__item\">\n          <button\n            class=\"a-btn -link-like\"\n            (click)=\"editRestitution(selectedRestitution)\"\n            [disabled]=\"!selectedRestitution.owner\"\n            *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'edit' }\"\n          >\n            {{ '@pry.restitution.update' | i18n }}\n          </button>\n        </li>\n        <li class=\"m-context-menu__list__item\">\n          <button\n            class=\"a-btn -link-like\"\n            #openModal\n            (click)=\"deleteRestitution(selectedRestitution.id)\"\n            [disabled]=\"!selectedRestitution.owner\"\n            *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'delete' }\"\n          >\n            {{ '@pry.restitution.delete' | i18n }}\n          </button>\n        </li>\n      </ul>\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"]}
88
+ //# 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, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { Component, TemplateRef, ViewChild, 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';\nimport { TemplatePortal } from '@angular/cdk/portal';\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  mode = ViewMode;\n  selectedMode: ViewMode = ViewMode.CATALOG;\n  selectedRestitution: Widget | null = null;\n  restitution?: Widget;\n  PryVisibilityType = PryVisibilityType;\n  overlayRef?: OverlayRef;\n  @ViewChild('modalActions', { read: TemplateRef }) templateActions!: TemplateRef<any>;\n\n  constructor(private store: Store, protected overlay: Overlay, protected viewContainerRef: ViewContainerRef) {\n    this.store.dispatch(ConfigActions.loadWidgets());\n    this.store.dispatch(ConfigActions.getMapStyles());\n\n    this.restitutions$ = this.store\n      .select(ConfigSelectors.catalog)\n      .pipe(\n        map((restitutionList) =>\n          [...restitutionList].sort((a, b) =>\n            a.modificationDate ? b.modificationDate.localeCompare(a.modificationDate) : 1\n          )\n        )\n      );\n    this.filteredRestitution$ = combineLatest([this.restitutions$, this.search$]).pipe(\n      map(([restitutions, search]) =>\n        restitutions.filter(\n          (restitution) => search.length === 0 || restitution.name.toLowerCase().includes(search.toLowerCase())\n        )\n      )\n    );\n  }\n\n  selectMode(newMode: ViewMode) {\n    this.selectedMode = newMode;\n  }\n\n  selectRestitution(restitution: Widget) {\n    this.selectedRestitution = restitution;\n    this.selectMode(this.mode.CONSULT);\n    this.search$.next('');\n  }\n\n  closeRestitution($event: void) {\n    this.selectedRestitution = null;\n    this.selectMode(this.mode.CATALOG);\n  }\n\n  deleteRestitution(id: string) {\n    this.store.dispatch(ConfigActions.confirmRestitutionDeletion({ id }));\n    this.toggleModalActions();\n  }\n\n  editRestitution(restitution: Widget) {\n    this.selectedRestitution = restitution;\n    this.selectMode(ViewMode.EDITION);\n    this.search$.next('');\n    this.overlayRef?.dispose();\n    this.overlayRef = undefined;\n  }\n\n  toggleModalActions(restitution?: Widget, moreButton?: HTMLButtonElement) {\n    if (!this.overlayRef && restitution) {\n      this.selectedRestitution = restitution;\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['m-context-menu-wrapper'],\n          backdropClass: 'backdrop'\n        })\n      );\n      this.overlayRef.backdropClick().subscribe(() => this.toggleModalActions(restitution));\n      this.overlayRef.attach(new TemplatePortal(this.templateActions, this.viewContainerRef));\n      const contextMenu = document.querySelector('div.m-context-menu') as HTMLDivElement;\n      if (!!contextMenu && moreButton) {\n        const rect = moreButton?.getBoundingClientRect();\n        contextMenu.style.left = (rect?.left ?? 0) - (contextMenu?.clientWidth ?? 0) + 23 + 'px';\n        contextMenu.style.top = (rect?.top ?? 0) + 30 + 'px';\n      }\n    } else {\n      this.overlayRef?.dispose();\n      this.overlayRef = undefined;\n      this.selectedRestitution = null;\n    }\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 -tooltip-no-wrap\"\n        [attr.data-tooltip]=\"'@pry.restitution.create' | i18n\"\n        data-tooltip-position=\"bottom\"\n        *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'create' }\"\n      >\n        {{ '@pry.context.create' | i18n }}\n      </button>\n      <div>\n        <div class=\"o-catalog__search o-manifest-layout__toolbox__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; let index = index\">\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 -tooltip-no-wrap\"\n                  [attr.data-tooltip]=\"'@pry.restitution.lock' | i18n\"\n                  [height]=\"17\"\n                  [width]=\"17\"\n                ></pry-icon>\n              </ng-container>\n              <div\n                class=\"a-tooltip -tooltip-no-wrap\"\n                (click)=\"selectRestitution(restitution)\"\n                [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n              >\n                <div class=\"o-presentation__item__image\">\n                  <img\n                    alt=\"\"\n                    [class.is-full-width]=\"restitution.cover\"\n                    [src]=\"restitution.image | getSecuredImage : [600, 600] | async\"\n                    class=\"pointer\"\n                  />\n                </div>\n              </div>\n              <ng-container *ngIf=\"restitution.owner\">\n                <div class=\"more-button\">\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--more a-tooltip -tooltip-no-wrap\"\n                    [id]=\"'more-actions-' + index\"\n                    [attr.data-tooltip]=\"'@pry.restitution.more' | i18n\"\n                    (click)=\"toggleModalActions(restitution, button)\"\n                    #button\n                  >\n                    <pry-icon [height]=\"25\" [width]=\"25\" iconSvg=\"more_horiz\"></pry-icon>\n                  </button>\n                </div>\n              </ng-container>\n            </div>\n            <div\n              class=\"o-presentation__item__txt\"\n              (click)=\"selectRestitution(restitution)\"\n              [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n            >\n              <div class=\"o-presentation__item__title-container\" ellipsis textElementSelector=\".a-h3\">\n                <h3 class=\"a-h3\">{{ restitution.name }}</h3>\n              </div>\n              <div class=\"o-presentation__item__description-container\" ellipsis textElementSelector=\".a-p\">\n                <div class=\"o-presentation__item__description a-p\">\n                  {{ restitution.description }}\n                </div>\n              </div>\n              <p class=\"a-p -date\">{{ restitution.modificationDate | sinceDate }}</p>\n            </div>\n\n            <div\n              class=\"o-presentation__item__footer a-tooltip -tooltip-no-wrap\"\n              (click)=\"selectRestitution(restitution)\"\n              [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n            >\n              <button class=\"a-btn\">\n                {{ '@pry.restitution.view' | i18n }}\n                <pry-icon [width]=\"20\" [height]=\"20\" iconSvg=\"arrow_right\"></pry-icon>\n              </button>\n            </div>\n          </li>\n        </ul>\n      </div>\n    </div>\n  </ng-template>\n  <ng-template #modalActions>\n    <div class=\"m-context-menu\">\n      <ul\n        *ngIf=\"selectedRestitution\"\n        class=\"m-context-menu__list\"\n        role=\"dialog\"\n        aria-modal=\"true\"\n        aria-labelledby=\"dialog restitution options\"\n      >\n        <li class=\"m-context-menu__list__item\">\n          <button\n            class=\"a-btn -link-like\"\n            (click)=\"editRestitution(selectedRestitution)\"\n            [disabled]=\"!selectedRestitution.owner\"\n            *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'edit' }\"\n          >\n            {{ '@pry.restitution.update' | i18n }}\n          </button>\n        </li>\n        <li class=\"m-context-menu__list__item\">\n          <button\n            class=\"a-btn -link-like\"\n            #openModal\n            (click)=\"deleteRestitution(selectedRestitution.id)\"\n            [disabled]=\"!selectedRestitution.owner\"\n            *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'delete' }\"\n          >\n            {{ '@pry.restitution.delete' | i18n }}\n          </button>\n        </li>\n      </ul>\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"]}
@@ -336,10 +336,10 @@ class PryPresentationComponent extends SubscriptionnerDirective {
336
336
  this.overlayRef.attach(new TemplatePortal(this.templateModalActions, this.viewContainerRef));
337
337
  const contextMenu = document.querySelector('div.m-context-menu');
338
338
  if (!!contextMenu && moreButton) {
339
- const toggleActionsModalButton = document.querySelector('#' + moreButton.id);
340
- const rect = toggleActionsModalButton?.getBoundingClientRect();
339
+ const rect = moreButton.getBoundingClientRect();
340
+ contextMenu.style.minWidth = '185px';
341
341
  contextMenu.style.left = (rect?.left ?? 0) - (contextMenu?.clientWidth ?? 0) + 23 + 'px';
342
- contextMenu.style.top = (rect?.top ?? 0) + 25 + 'px';
342
+ contextMenu.style.top = (rect?.top ?? 0) + 30 + 'px';
343
343
  }
344
344
  }
345
345
  else {