@net7/components 4.2.5 → 4.2.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,85 +1,34 @@
1
1
  import { Component, Input } from '@angular/core';
2
- import manifest from 'src/scripts/mirador/manifest.json';
2
+ // eslint-disable-next-line import/no-extraneous-dependencies
3
+ import Mirador from 'mirador';
3
4
  import { customTheme } from './miradorTheme';
4
5
  import * as i0 from "@angular/core";
5
- const assetsPath = 'scripts/mirador';
6
6
  export class MiradorComponent {
7
7
  constructor() {
8
8
  this._loaded = false;
9
- this.assetsLoadResults = [];
10
- this.scriptNodes = [];
11
- this.styleNodes = [];
12
- this.jsPaths = Object.values(manifest.allFiles)
13
- .filter((script) => typeof script === 'string' && script.endsWith('.js'))
14
- .map((script) => assetsPath + script);
15
- this.cssPaths = Object.values(manifest.allFiles)
16
- .filter((script) => typeof script === 'string' && script.endsWith('.css'))
17
- .map((script) => assetsPath + script);
18
- }
19
- ngOnInit() {
20
- const customThemeJSON = JSON.stringify(customTheme);
21
- this.customThemeJSON = customThemeJSON;
22
- const dataJSON = JSON.stringify(this.data);
23
- this.dataJSON = dataJSON;
9
+ this.theme = null;
24
10
  }
25
11
  ngAfterViewInit() {
26
- this.loadLibrary();
27
12
  if (this._loaded) {
28
13
  return;
29
14
  }
30
15
  this._loaded = true;
16
+ if (!this.data.libOptions.useDefaultTheme) {
17
+ this.theme = customTheme;
18
+ }
31
19
  // Configuration for Mirador viewer
32
- // const mirador = Mirador.viewer({
33
- // ...customTheme,
34
- // ...this.data.libOptions,
35
- // });
36
- // if (this.data._setInstance) {
37
- // this.data._setInstance(mirador);
38
- // }
39
- }
40
- loadLibrary() {
41
- this.jsPaths.forEach((path) => {
42
- const scriptElement = document.createElement('script');
43
- scriptElement.src = path;
44
- document.body.appendChild(scriptElement);
45
- this.scriptNodes.push(scriptElement);
46
- this.assetsLoadResults.push(this.getAssetsLoadResults(scriptElement));
47
- });
48
- this.cssPaths.forEach((path) => {
49
- const styleElement = document.createElement('link');
50
- styleElement.rel = 'stylesheet';
51
- styleElement.href = path;
52
- document.head.appendChild(styleElement);
53
- this.styleNodes.push(styleElement);
54
- this.assetsLoadResults.push(this.getAssetsLoadResults(styleElement));
55
- });
56
- Promise.all(this.assetsLoadResults).then(() => {
57
- // any code that depends on the library being loaded
58
- });
59
- }
60
- ngOnDestroy() {
61
- this.removeLibrary();
62
- }
63
- getAssetsLoadResults(node) {
64
- return new Promise((resolve, reject) => {
65
- node.onload = () => resolve();
66
- node.onerror = () => reject();
67
- });
68
- }
69
- removeLibrary() {
70
- this.scriptNodes.forEach((node) => {
71
- node.remove();
72
- });
73
- this.styleNodes.forEach((node) => {
74
- node.remove();
20
+ const mirador = Mirador.viewer({
21
+ ...this.theme,
22
+ ...this.data.libOptions,
75
23
  });
24
+ if (this.data._setInstance) {
25
+ this.data._setInstance(mirador);
26
+ }
76
27
  }
77
28
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MiradorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
78
29
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: MiradorComponent, selector: "n7-mirador", inputs: { data: "data" }, ngImport: i0, template: `<div
79
30
  #miradorContainer
80
- id="mr-mirador-container"
81
- [attr.data]="dataJSON"
82
- [attr.customTheme]="customThemeJSON">
31
+ [id]="data.libOptions.id">
83
32
  </div>`, isInline: true }); }
84
33
  }
85
34
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MiradorComponent, decorators: [{
@@ -88,12 +37,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
88
37
  selector: 'n7-mirador',
89
38
  template: `<div
90
39
  #miradorContainer
91
- id="mr-mirador-container"
92
- [attr.data]="dataJSON"
93
- [attr.customTheme]="customThemeJSON">
40
+ [id]="data.libOptions.id">
94
41
  </div>`
95
42
  }]
96
43
  }], propDecorators: { data: [{
97
44
  type: Input
98
45
  }] } });
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mirador.js","sourceRoot":"","sources":["../../../../../../projects/dv-components-lib/src/lib/components/mirador/mirador.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, Input, OnDestroy, OnInit } from '@angular/core';\nimport manifest from 'src/scripts/mirador/manifest.json';\nimport { customTheme } from './miradorTheme';\n\nconst assetsPath = 'scripts/mirador';\n\nexport interface MiradorData {\n  /** Mirador configuration */\n  libOptions: any;\n  useCustomTheme?: boolean;\n  /** Sets the Mirador instance to the given parameter */\n  _setInstance?: (mirador) => void;\n}\n\n@Component({\n  selector: 'n7-mirador',\n  template: `<div \n    #miradorContainer\n    id=\"mr-mirador-container\"\n    [attr.data]=\"dataJSON\"\n    [attr.customTheme]=\"customThemeJSON\">\n  </div>`\n})\nexport class MiradorComponent implements AfterViewInit, OnInit, OnDestroy {\n  @Input() data: MiradorData;\n  \n  _loaded = false;\n\n  assetsLoadResults: Promise<void>[] = [];\n\n  protected scriptNodes: HTMLScriptElement[] = [];\n  \n  protected styleNodes: HTMLLinkElement[] = [];\n  \n  protected customThemeJSON: any;\n  \n  protected dataJSON: any;\n\n  protected jsPaths = Object.values(manifest.allFiles)\n    .filter((script: unknown) => typeof script === 'string' && script.endsWith('.js'))\t\n    .map((script: string) => assetsPath + script);\n  \n  protected cssPaths = Object.values(manifest.allFiles)\n    .filter((script: unknown) => typeof script === 'string' && script.endsWith('.css'))\n    .map((script) => assetsPath + script);\n\n  ngOnInit(): void {\n    const customThemeJSON = JSON.stringify(customTheme);\n    this.customThemeJSON = customThemeJSON;\n    const dataJSON = JSON.stringify(this.data);\n    this.dataJSON = dataJSON;\n  }\n\n  ngAfterViewInit(): void {\n    this.loadLibrary();\n\n    if (this._loaded) {\n      return;\n    }\n    this._loaded = true;\n    \n    // Configuration for Mirador viewer\n    // const mirador = Mirador.viewer({\n    //   ...customTheme,\n    //   ...this.data.libOptions,\n    // });\n    // if (this.data._setInstance) {\n    //   this.data._setInstance(mirador);\n    // }\n  }\n\n  loadLibrary() {\n    this.jsPaths.forEach((path: any) => {\n      const scriptElement = document.createElement('script');\n      scriptElement.src = path;\n      document.body.appendChild(scriptElement);\n      this.scriptNodes.push(scriptElement);\n      this.assetsLoadResults.push(this.getAssetsLoadResults(scriptElement));\n    });\n    this.cssPaths.forEach((path: any) => {\n      const styleElement = document.createElement('link');\n      styleElement.rel = 'stylesheet';\n      styleElement.href = path;\n      document.head.appendChild(styleElement);\n      this.styleNodes.push(styleElement);\n      this.assetsLoadResults.push(this.getAssetsLoadResults(styleElement));\n    });\n    Promise.all(this.assetsLoadResults).then(() => {\n      // any code that depends on the library being loaded\n    });\n  }\n\n  ngOnDestroy() {\n    this.removeLibrary();\n  }\n\n  getAssetsLoadResults(\n    node: HTMLScriptElement | HTMLLinkElement\n  ): Promise<void> {\n    return new Promise((resolve, reject) => {\n      node.onload = () => resolve();\n      node.onerror = () => reject();\n    });\n  }\n\n  removeLibrary() {\n    this.scriptNodes.forEach((node: HTMLScriptElement) => {\n      node.remove();\n    });\n    this.styleNodes.forEach((node: HTMLLinkElement) => {\n      node.remove();\n    });\n  }\n}\n"]}
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWlyYWRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2R2LWNvbXBvbmVudHMtbGliL3NyYy9saWIvY29tcG9uZW50cy9taXJhZG9yL21pcmFkb3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQixTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hFLDZEQUE2RDtBQUM3RCxPQUFPLE9BQU8sTUFBTSxTQUFTLENBQUM7QUFDOUIsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQWdCN0MsTUFBTSxPQUFPLGdCQUFnQjtJQVA3QjtRQVVFLFlBQU8sR0FBRyxLQUFLLENBQUM7UUFFTixVQUFLLEdBQUcsSUFBSSxDQUFDO0tBcUJ4QjtJQW5CQyxlQUFlO1FBQ2IsSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDakIsT0FBTztRQUNULENBQUM7UUFDRCxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQztRQUVwQixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsZUFBZSxFQUFFLENBQUM7WUFDMUMsSUFBSSxDQUFDLEtBQUssR0FBRyxXQUFXLENBQUM7UUFDM0IsQ0FBQztRQUVELG1DQUFtQztRQUNuQyxNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDO1lBQzdCLEdBQUcsSUFBSSxDQUFDLEtBQUs7WUFDYixHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVTtTQUN4QixDQUFDLENBQUM7UUFDSCxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7WUFDM0IsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDbEMsQ0FBQztJQUNILENBQUM7K0dBekJVLGdCQUFnQjttR0FBaEIsZ0JBQWdCLDRFQUxqQjs7O1NBR0g7OzRGQUVJLGdCQUFnQjtrQkFQNUIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsWUFBWTtvQkFDdEIsUUFBUSxFQUFFOzs7U0FHSDtpQkFDUjs4QkFFVSxJQUFJO3NCQUFaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlclZpZXdJbml0LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgaW1wb3J0L25vLWV4dHJhbmVvdXMtZGVwZW5kZW5jaWVzXG5pbXBvcnQgTWlyYWRvciBmcm9tICdtaXJhZG9yJztcbmltcG9ydCB7IGN1c3RvbVRoZW1lIH0gZnJvbSAnLi9taXJhZG9yVGhlbWUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIE1pcmFkb3JEYXRhIHtcbiAgLyoqIE1pcmFkb3IgY29uZmlndXJhdGlvbiAqL1xuICBsaWJPcHRpb25zOiBhbnk7XG4gIC8qKiBTZXRzIHRoZSBNaXJhZG9yIGluc3RhbmNlIHRvIHRoZSBnaXZlbiBwYXJhbWV0ZXIgKi9cbiAgX3NldEluc3RhbmNlPzogKG1pcmFkb3IpID0+IHZvaWQ7XG59XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ243LW1pcmFkb3InLFxuICB0ZW1wbGF0ZTogYDxkaXYgXG4gICAgI21pcmFkb3JDb250YWluZXJcbiAgICBbaWRdPVwiZGF0YS5saWJPcHRpb25zLmlkXCI+XG4gIDwvZGl2PmBcbn0pXG5leHBvcnQgY2xhc3MgTWlyYWRvckNvbXBvbmVudCBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQge1xuICBASW5wdXQoKSBkYXRhOiBNaXJhZG9yRGF0YTtcbiAgXG4gIF9sb2FkZWQgPSBmYWxzZTtcblxuICBwcm90ZWN0ZWQgdGhlbWUgPSBudWxsO1xuXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5fbG9hZGVkKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHRoaXMuX2xvYWRlZCA9IHRydWU7XG5cbiAgICBpZiAoIXRoaXMuZGF0YS5saWJPcHRpb25zLnVzZURlZmF1bHRUaGVtZSkge1xuICAgICAgdGhpcy50aGVtZSA9IGN1c3RvbVRoZW1lO1xuICAgIH1cblxuICAgIC8vIENvbmZpZ3VyYXRpb24gZm9yIE1pcmFkb3Igdmlld2VyXG4gICAgY29uc3QgbWlyYWRvciA9IE1pcmFkb3Iudmlld2VyKHtcbiAgICAgIC4uLnRoaXMudGhlbWUsXG4gICAgICAuLi50aGlzLmRhdGEubGliT3B0aW9ucyxcbiAgICB9KTtcbiAgICBpZiAodGhpcy5kYXRhLl9zZXRJbnN0YW5jZSkge1xuICAgICAgdGhpcy5kYXRhLl9zZXRJbnN0YW5jZShtaXJhZG9yKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
@@ -9,7 +9,7 @@ export const MIRADOR_MOCK = {
9
9
  sideBarOpenByDefault: true,
10
10
  },
11
11
  // ID of the Mirador container
12
- id: 'mr-mirador-container',
12
+ id: 'mirador-container',
13
13
  windows: [
14
14
  {
15
15
  canvasIndex: 2,
@@ -21,7 +21,7 @@ export const MIRADOR_MOCK = {
21
21
  'https://iiif.harvardartmuseums.org/manifests/object/231737', // esempio con annotazioni
22
22
  },
23
23
  ],
24
- },
25
- useCustomTheme: true,
24
+ useDefaultTheme: false,
25
+ }
26
26
  };
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWlyYWRvci5tb2NrLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZHYtY29tcG9uZW50cy1saWIvc3JjL2xpYi9jb21wb25lbnRzL21pcmFkb3IvbWlyYWRvci5tb2NrLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBOzs7R0FHRztBQUdILE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBZ0I7SUFFdkMsVUFBVSxFQUFFO1FBQ1YsTUFBTSxFQUFFO1lBQ04sMEJBQTBCO1lBQzFCLG9CQUFvQixFQUFFLElBQUk7U0FDM0I7UUFDRCw4QkFBOEI7UUFDOUIsRUFBRSxFQUFFLHNCQUFzQjtRQUMxQixPQUFPLEVBQUU7WUFDUDtnQkFDRSxXQUFXLEVBQUUsQ0FBQztnQkFDZCxxQkFBcUI7Z0JBQ3JCLGlCQUFpQixFQUFFLElBQUk7Z0JBQ3ZCLDRDQUE0QztnQkFDNUMsVUFBVTtnQkFDUixpRUFBaUU7Z0JBQ2pFLDREQUE0RCxFQUFFLDBCQUEwQjthQUMzRjtTQUNGO0tBQ0Y7SUFDRCxjQUFjLEVBQUUsSUFBSTtDQUNyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWlyYWRvckRhdGEgfSBmcm9tICcuL21pcmFkb3InO1xuXG4vKipcbiAqIFJlZmVyZW5jZWQgZnJvbTpcbiAqIGh0dHBzOi8vZ2l0aHViLmNvbS9zdGVyZW56L21pcmFkb3ItYW5ub3RhdGlvbnMvYmxvYi9hbm5vdGF0aW9uLXNlcnZlci9zcmMvY29tcG9uZW50cy9NaXJhZG9yVmlld2VyLmpzXG4gKi9cblxuXG5leHBvcnQgY29uc3QgTUlSQURPUl9NT0NLOiBNaXJhZG9yRGF0YSA9IHtcblxuICBsaWJPcHRpb25zOiB7XG4gICAgd2luZG93OiB7XG4gICAgICAvLyBPcGVuIHNpZGViYXIgYnkgZGVmYXVsdFxuICAgICAgc2lkZUJhck9wZW5CeURlZmF1bHQ6IHRydWUsXG4gICAgfSxcbiAgICAvLyBJRCBvZiB0aGUgTWlyYWRvciBjb250YWluZXJcbiAgICBpZDogJ21yLW1pcmFkb3ItY29udGFpbmVyJyxcbiAgICB3aW5kb3dzOiBbXG4gICAgICB7XG4gICAgICAgIGNhbnZhc0luZGV4OiAyLFxuICAgICAgICAvLyBFbmFibGUgaW1hZ2UgdG9vbHNcbiAgICAgICAgaW1hZ2VUb29sc0VuYWJsZWQ6IHRydWUsXG4gICAgICAgIC8vIE1hbmlmZXN0IElEIG9mIHRoZSBJSUlGIG1hbmlmZXN0IHRvIGxvYWRzXG4gICAgICAgIG1hbmlmZXN0SWQ6XG4gICAgICAgICAgLy8gJ2h0dHBzOi8vZGFtLmljY3Uuc2JuLml0L21vbF80NDcvY29udGFpbmVycy9kUFFXTFdlL21hbmlmZXN0JyxcbiAgICAgICAgICAnaHR0cHM6Ly9paWlmLmhhcnZhcmRhcnRtdXNldW1zLm9yZy9tYW5pZmVzdHMvb2JqZWN0LzIzMTczNycsIC8vIGVzZW1waW8gY29uIGFubm90YXppb25pXG4gICAgICB9LFxuICAgIF0sXG4gIH0sXG4gIHVzZUN1c3RvbVRoZW1lOiB0cnVlLFxufTtcbiJdfQ==
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWlyYWRvci5tb2NrLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZHYtY29tcG9uZW50cy1saWIvc3JjL2xpYi9jb21wb25lbnRzL21pcmFkb3IvbWlyYWRvci5tb2NrLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBOzs7R0FHRztBQUdILE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBZ0I7SUFFdkMsVUFBVSxFQUFFO1FBQ1YsTUFBTSxFQUFFO1lBQ04sMEJBQTBCO1lBQzFCLG9CQUFvQixFQUFFLElBQUk7U0FDM0I7UUFDRCw4QkFBOEI7UUFDOUIsRUFBRSxFQUFFLG1CQUFtQjtRQUN2QixPQUFPLEVBQUU7WUFDUDtnQkFDRSxXQUFXLEVBQUUsQ0FBQztnQkFDZCxxQkFBcUI7Z0JBQ3JCLGlCQUFpQixFQUFFLElBQUk7Z0JBQ3ZCLDRDQUE0QztnQkFDNUMsVUFBVTtnQkFDUixpRUFBaUU7Z0JBQ2pFLDREQUE0RCxFQUFFLDBCQUEwQjthQUMzRjtTQUNGO1FBQ0QsZUFBZSxFQUFFLEtBQUs7S0FDdkI7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWlyYWRvckRhdGEgfSBmcm9tICcuL21pcmFkb3InO1xuXG4vKipcbiAqIFJlZmVyZW5jZWQgZnJvbTpcbiAqIGh0dHBzOi8vZ2l0aHViLmNvbS9zdGVyZW56L21pcmFkb3ItYW5ub3RhdGlvbnMvYmxvYi9hbm5vdGF0aW9uLXNlcnZlci9zcmMvY29tcG9uZW50cy9NaXJhZG9yVmlld2VyLmpzXG4gKi9cblxuXG5leHBvcnQgY29uc3QgTUlSQURPUl9NT0NLOiBNaXJhZG9yRGF0YSA9IHtcblxuICBsaWJPcHRpb25zOiB7XG4gICAgd2luZG93OiB7XG4gICAgICAvLyBPcGVuIHNpZGViYXIgYnkgZGVmYXVsdFxuICAgICAgc2lkZUJhck9wZW5CeURlZmF1bHQ6IHRydWUsXG4gICAgfSxcbiAgICAvLyBJRCBvZiB0aGUgTWlyYWRvciBjb250YWluZXJcbiAgICBpZDogJ21pcmFkb3ItY29udGFpbmVyJyxcbiAgICB3aW5kb3dzOiBbXG4gICAgICB7XG4gICAgICAgIGNhbnZhc0luZGV4OiAyLFxuICAgICAgICAvLyBFbmFibGUgaW1hZ2UgdG9vbHNcbiAgICAgICAgaW1hZ2VUb29sc0VuYWJsZWQ6IHRydWUsXG4gICAgICAgIC8vIE1hbmlmZXN0IElEIG9mIHRoZSBJSUlGIG1hbmlmZXN0IHRvIGxvYWRzXG4gICAgICAgIG1hbmlmZXN0SWQ6XG4gICAgICAgICAgLy8gJ2h0dHBzOi8vZGFtLmljY3Uuc2JuLml0L21vbF80NDcvY29udGFpbmVycy9kUFFXTFdlL21hbmlmZXN0JyxcbiAgICAgICAgICAnaHR0cHM6Ly9paWlmLmhhcnZhcmRhcnRtdXNldW1zLm9yZy9tYW5pZmVzdHMvb2JqZWN0LzIzMTczNycsIC8vIGVzZW1waW8gY29uIGFubm90YXppb25pXG4gICAgICB9LFxuICAgIF0sXG4gICAgdXNlRGVmYXVsdFRoZW1lOiBmYWxzZSxcbiAgfVxufTtcbiJdfQ==
@@ -4,7 +4,7 @@ import * as i1 from '@angular/common';
4
4
  import { CommonModule } from '@angular/common';
5
5
  import * as i2 from '@angular/router';
6
6
  import { RouterModule } from '@angular/router';
7
- import manifest from 'src/scripts/mirador/manifest.json';
7
+ import Mirador from 'mirador';
8
8
 
9
9
  //---------------------------
10
10
  // ANCHOR-WRAPPER.ts
@@ -1892,84 +1892,32 @@ const customTheme = {
1892
1892
  },
1893
1893
  };
1894
1894
 
1895
- const assetsPath = 'scripts/mirador';
1896
1895
  class MiradorComponent {
1897
1896
  constructor() {
1898
1897
  this._loaded = false;
1899
- this.assetsLoadResults = [];
1900
- this.scriptNodes = [];
1901
- this.styleNodes = [];
1902
- this.jsPaths = Object.values(manifest.allFiles)
1903
- .filter((script) => typeof script === 'string' && script.endsWith('.js'))
1904
- .map((script) => assetsPath + script);
1905
- this.cssPaths = Object.values(manifest.allFiles)
1906
- .filter((script) => typeof script === 'string' && script.endsWith('.css'))
1907
- .map((script) => assetsPath + script);
1908
- }
1909
- ngOnInit() {
1910
- const customThemeJSON = JSON.stringify(customTheme);
1911
- this.customThemeJSON = customThemeJSON;
1912
- const dataJSON = JSON.stringify(this.data);
1913
- this.dataJSON = dataJSON;
1898
+ this.theme = null;
1914
1899
  }
1915
1900
  ngAfterViewInit() {
1916
- this.loadLibrary();
1917
1901
  if (this._loaded) {
1918
1902
  return;
1919
1903
  }
1920
1904
  this._loaded = true;
1905
+ if (!this.data.libOptions.useDefaultTheme) {
1906
+ this.theme = customTheme;
1907
+ }
1921
1908
  // Configuration for Mirador viewer
1922
- // const mirador = Mirador.viewer({
1923
- // ...customTheme,
1924
- // ...this.data.libOptions,
1925
- // });
1926
- // if (this.data._setInstance) {
1927
- // this.data._setInstance(mirador);
1928
- // }
1929
- }
1930
- loadLibrary() {
1931
- this.jsPaths.forEach((path) => {
1932
- const scriptElement = document.createElement('script');
1933
- scriptElement.src = path;
1934
- document.body.appendChild(scriptElement);
1935
- this.scriptNodes.push(scriptElement);
1936
- this.assetsLoadResults.push(this.getAssetsLoadResults(scriptElement));
1937
- });
1938
- this.cssPaths.forEach((path) => {
1939
- const styleElement = document.createElement('link');
1940
- styleElement.rel = 'stylesheet';
1941
- styleElement.href = path;
1942
- document.head.appendChild(styleElement);
1943
- this.styleNodes.push(styleElement);
1944
- this.assetsLoadResults.push(this.getAssetsLoadResults(styleElement));
1945
- });
1946
- Promise.all(this.assetsLoadResults).then(() => {
1947
- // any code that depends on the library being loaded
1948
- });
1949
- }
1950
- ngOnDestroy() {
1951
- this.removeLibrary();
1952
- }
1953
- getAssetsLoadResults(node) {
1954
- return new Promise((resolve, reject) => {
1955
- node.onload = () => resolve();
1956
- node.onerror = () => reject();
1957
- });
1958
- }
1959
- removeLibrary() {
1960
- this.scriptNodes.forEach((node) => {
1961
- node.remove();
1962
- });
1963
- this.styleNodes.forEach((node) => {
1964
- node.remove();
1909
+ const mirador = Mirador.viewer({
1910
+ ...this.theme,
1911
+ ...this.data.libOptions,
1965
1912
  });
1913
+ if (this.data._setInstance) {
1914
+ this.data._setInstance(mirador);
1915
+ }
1966
1916
  }
1967
1917
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MiradorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
1968
1918
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: MiradorComponent, selector: "n7-mirador", inputs: { data: "data" }, ngImport: i0, template: `<div
1969
1919
  #miradorContainer
1970
- id="mr-mirador-container"
1971
- [attr.data]="dataJSON"
1972
- [attr.customTheme]="customThemeJSON">
1920
+ [id]="data.libOptions.id">
1973
1921
  </div>`, isInline: true }); }
1974
1922
  }
1975
1923
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MiradorComponent, decorators: [{
@@ -1978,9 +1926,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
1978
1926
  selector: 'n7-mirador',
1979
1927
  template: `<div
1980
1928
  #miradorContainer
1981
- id="mr-mirador-container"
1982
- [attr.data]="dataJSON"
1983
- [attr.customTheme]="customThemeJSON">
1929
+ [id]="data.libOptions.id">
1984
1930
  </div>`
1985
1931
  }]
1986
1932
  }], propDecorators: { data: [{
@@ -5172,7 +5118,7 @@ const MIRADOR_MOCK = {
5172
5118
  sideBarOpenByDefault: true,
5173
5119
  },
5174
5120
  // ID of the Mirador container
5175
- id: 'mr-mirador-container',
5121
+ id: 'mirador-container',
5176
5122
  windows: [
5177
5123
  {
5178
5124
  canvasIndex: 2,
@@ -5184,8 +5130,8 @@ const MIRADOR_MOCK = {
5184
5130
  'https://iiif.harvardartmuseums.org/manifests/object/231737', // esempio con annotazioni
5185
5131
  },
5186
5132
  ],
5187
- },
5188
- useCustomTheme: true,
5133
+ useDefaultTheme: false,
5134
+ }
5189
5135
  };
5190
5136
 
5191
5137
  const NAV_MOCK = {