diff --git a/src/content-handlers/iiif/extensions/uv-aleph-extension/Extension.ts b/src/content-handlers/iiif/extensions/uv-aleph-extension/Extension.ts index 75bf2f9c0..88bfa1916 100644 --- a/src/content-handlers/iiif/extensions/uv-aleph-extension/Extension.ts +++ b/src/content-handlers/iiif/extensions/uv-aleph-extension/Extension.ts @@ -121,16 +121,21 @@ export default class Extension } getEmbedScript(template: string, width: number, height: number): string { + const hashParams = new URLSearchParams({ + manifest: this.helper.manifestUri, + }); + const appUri: string = this.getAppUri(); - const title: string = this.helper.getLabel() || ""; - const iframeSrc: string = `${appUri}#?manifest=${this.helper.manifestUri}`; + const title: string = this.helper.getLabel() ?? ""; const script: string = Strings.format( template, - iframeSrc, + appUri, + hashParams.toString(), width.toString(), height.toString(), title ); + return script; } } diff --git a/src/content-handlers/iiif/extensions/uv-aleph-extension/config/config.json b/src/content-handlers/iiif/extensions/uv-aleph-extension/config/config.json index f53a7097f..127b7c4c8 100644 --- a/src/content-handlers/iiif/extensions/uv-aleph-extension/config/config.json +++ b/src/content-handlers/iiif/extensions/uv-aleph-extension/config/config.json @@ -239,7 +239,7 @@ "options": { "embedEnabled": true, "shareEnabled": true, - "embedTemplate": "", + "embedTemplate": "", "instructionsEnabled": false, "shareFrameEnabled": true, "shareManifestsEnabled": true, diff --git a/src/content-handlers/iiif/extensions/uv-av-extension/Extension.ts b/src/content-handlers/iiif/extensions/uv-av-extension/Extension.ts index 2319b82f7..ea50ca548 100644 --- a/src/content-handlers/iiif/extensions/uv-av-extension/Extension.ts +++ b/src/content-handlers/iiif/extensions/uv-av-extension/Extension.ts @@ -149,16 +149,25 @@ export default class Extension } getEmbedScript(template: string, width: number, height: number): string { + const hashParams = new URLSearchParams({ + manifest: this.helper.manifestUri, + c: this.helper.collectionIndex.toString(), + m: this.helper.manifestIndex.toString(), + cv: this.helper.canvasIndex.toString(), + rid: this.helper.rangeId?.toString() ?? "", + }); + const appUri: string = this.getAppUri(); - const title: string = this.helper.getLabel() || ""; - const iframeSrc: string = `${appUri}#?manifest=${this.helper.manifestUri}&c=${this.helper.collectionIndex}&m=${this.helper.manifestIndex}&cv=${this.helper.canvasIndex}&rid=${this.helper.rangeId}`; + const title: string = this.helper.getLabel() ?? ""; const script: string = Strings.format( template, - iframeSrc, + appUri, + hashParams.toString(), width.toString(), height.toString(), title ); + return script; } diff --git a/src/content-handlers/iiif/extensions/uv-av-extension/config/config.json b/src/content-handlers/iiif/extensions/uv-av-extension/config/config.json index ab32b2ed9..f0cacda84 100644 --- a/src/content-handlers/iiif/extensions/uv-av-extension/config/config.json +++ b/src/content-handlers/iiif/extensions/uv-av-extension/config/config.json @@ -283,7 +283,7 @@ "options": { "embedEnabled": true, "shareEnabled": true, - "embedTemplate": "", + "embedTemplate": "", "instructionsEnabled": false, "shareFrameEnabled": true, "shareManifestsEnabled": true, diff --git a/src/content-handlers/iiif/extensions/uv-default-extension/Extension.ts b/src/content-handlers/iiif/extensions/uv-default-extension/Extension.ts index 2cbc30b26..28d7e91b0 100644 --- a/src/content-handlers/iiif/extensions/uv-default-extension/Extension.ts +++ b/src/content-handlers/iiif/extensions/uv-default-extension/Extension.ts @@ -116,16 +116,24 @@ export default class Extension } getEmbedScript(template: string, width: number, height: number): string { + const hashParams = new URLSearchParams({ + manifest: this.helper.manifestUri, + c: this.helper.collectionIndex.toString(), + m: this.helper.manifestIndex.toString(), + cv: this.helper.canvasIndex.toString(), + }); + const appUri: string = this.getAppUri(); - const title: string = this.helper.getLabel() || ""; - const iframeSrc: string = `${appUri}#?manifest=${this.helper.manifestUri}&c=${this.helper.collectionIndex}&m=${this.helper.manifestIndex}&cv=${this.helper.canvasIndex}`; + const title: string = this.helper.getLabel() ?? ""; const script: string = Strings.format( template, - iframeSrc, + appUri, + hashParams.toString(), width.toString(), height.toString(), title ); + return script; } } diff --git a/src/content-handlers/iiif/extensions/uv-default-extension/config/config.json b/src/content-handlers/iiif/extensions/uv-default-extension/config/config.json index 4c01ff653..3ce6e83de 100644 --- a/src/content-handlers/iiif/extensions/uv-default-extension/config/config.json +++ b/src/content-handlers/iiif/extensions/uv-default-extension/config/config.json @@ -65,7 +65,7 @@ "options": { "embedEnabled": true, "shareEnabled": true, - "embedTemplate": "", + "embedTemplate": "", "instructionsEnabled": false, "shareFrameEnabled": true, "shareManifestsEnabled": true, diff --git a/src/content-handlers/iiif/extensions/uv-ebook-extension/Extension.ts b/src/content-handlers/iiif/extensions/uv-ebook-extension/Extension.ts index a5b0f4592..cfadf23cb 100644 --- a/src/content-handlers/iiif/extensions/uv-ebook-extension/Extension.ts +++ b/src/content-handlers/iiif/extensions/uv-ebook-extension/Extension.ts @@ -142,16 +142,22 @@ export default class Extension } getEmbedScript(template: string, width: number, height: number): string { + const hashParams = new URLSearchParams({ + manifest: this.helper.manifestUri, + cfi: this.cfiFragement, + }); + const appUri: string = this.getAppUri(); - const title: string = this.helper.getLabel() || ""; - const iframeSrc: string = `${appUri}#?manifest=${this.helper.manifestUri}&cfi=${this.cfiFragement}`; + const title: string = this.helper.getLabel() ?? ""; const script: string = Strings.format( template, - iframeSrc, + appUri, + hashParams.toString(), width.toString(), height.toString(), title ); + return script; } diff --git a/src/content-handlers/iiif/extensions/uv-ebook-extension/config/config.json b/src/content-handlers/iiif/extensions/uv-ebook-extension/config/config.json index 1df06c3ff..f94367159 100644 --- a/src/content-handlers/iiif/extensions/uv-ebook-extension/config/config.json +++ b/src/content-handlers/iiif/extensions/uv-ebook-extension/config/config.json @@ -234,7 +234,7 @@ "options": { "embedEnabled": true, "shareEnabled": true, - "embedTemplate": "", + "embedTemplate": "", "instructionsEnabled": false, "shareFrameEnabled": true, "shareManifestsEnabled": true, diff --git a/src/content-handlers/iiif/extensions/uv-mediaelement-extension/Extension.ts b/src/content-handlers/iiif/extensions/uv-mediaelement-extension/Extension.ts index 37dec4ade..4f7a4bc96 100644 --- a/src/content-handlers/iiif/extensions/uv-mediaelement-extension/Extension.ts +++ b/src/content-handlers/iiif/extensions/uv-mediaelement-extension/Extension.ts @@ -236,16 +236,24 @@ export default class Extension } getEmbedScript(template: string, width: number, height: number): string { + const hashParams = new URLSearchParams({ + manifest: this.helper.manifestUri, + c: this.helper.collectionIndex.toString(), + m: this.helper.manifestIndex.toString(), + cv: this.helper.canvasIndex.toString(), + }); + const appUri: string = this.getAppUri(); - const title: string = this.helper.getLabel() || ""; - const iframeSrc: string = `${appUri}#?manifest=${this.helper.manifestUri}&c=${this.helper.collectionIndex}&m=${this.helper.manifestIndex}&cv=${this.helper.canvasIndex}`; + const title: string = this.helper.getLabel() ?? ""; const script: string = Strings.format( template, - iframeSrc, + appUri, + hashParams.toString(), width.toString(), height.toString(), title ); + return script; } diff --git a/src/content-handlers/iiif/extensions/uv-mediaelement-extension/config/config.json b/src/content-handlers/iiif/extensions/uv-mediaelement-extension/config/config.json index ecd1734e5..5c4e12edb 100644 --- a/src/content-handlers/iiif/extensions/uv-mediaelement-extension/config/config.json +++ b/src/content-handlers/iiif/extensions/uv-mediaelement-extension/config/config.json @@ -65,7 +65,7 @@ "options": { "embedEnabled": true, "shareEnabled": true, - "embedTemplate": "", + "embedTemplate": "", "instructionsEnabled": false, "shareFrameEnabled": true, "shareManifestsEnabled": true, diff --git a/src/content-handlers/iiif/extensions/uv-model-viewer-extension/Extension.ts b/src/content-handlers/iiif/extensions/uv-model-viewer-extension/Extension.ts index 7ff9a38da..adee391bb 100644 --- a/src/content-handlers/iiif/extensions/uv-model-viewer-extension/Extension.ts +++ b/src/content-handlers/iiif/extensions/uv-model-viewer-extension/Extension.ts @@ -255,16 +255,24 @@ export default class ModelViewerExtension extends BaseExtension { } getEmbedScript(template: string, width: number, height: number): string { + const hashParams = new URLSearchParams({ + manifest: this.helper.manifestUri, + c: this.helper.collectionIndex.toString(), + m: this.helper.manifestIndex.toString(), + cv: this.helper.canvasIndex.toString(), + }); + const appUri: string = this.getAppUri(); - const title: string = this.helper.getLabel() || ""; - const iframeSrc: string = `${appUri}#?manifest=${this.helper.manifestUri}&c=${this.helper.collectionIndex}&m=${this.helper.manifestIndex}&cv=${this.helper.canvasIndex}`; + const title: string = this.helper.getLabel() ?? ""; const script: string = Strings.format( template, - iframeSrc, + appUri, + hashParams.toString(), width.toString(), height.toString(), title ); + return script; } } diff --git a/src/content-handlers/iiif/extensions/uv-model-viewer-extension/config/config.json b/src/content-handlers/iiif/extensions/uv-model-viewer-extension/config/config.json index 13479234c..c8be5a7e6 100644 --- a/src/content-handlers/iiif/extensions/uv-model-viewer-extension/config/config.json +++ b/src/content-handlers/iiif/extensions/uv-model-viewer-extension/config/config.json @@ -78,7 +78,7 @@ "options": { "embedEnabled": true, "shareEnabled": true, - "embedTemplate": "", + "embedTemplate": "", "instructionsEnabled": false, "shareFrameEnabled": true, "shareManifestsEnabled": true, diff --git a/src/content-handlers/iiif/extensions/uv-openseadragon-extension/Extension.ts b/src/content-handlers/iiif/extensions/uv-openseadragon-extension/Extension.ts index eee4845fc..d15a340f3 100644 --- a/src/content-handlers/iiif/extensions/uv-openseadragon-extension/Extension.ts +++ b/src/content-handlers/iiif/extensions/uv-openseadragon-extension/Extension.ts @@ -1369,18 +1369,30 @@ export default class OpenSeadragonExtension extends BaseExtension { zoom: string, rotation: number ): string { - const config: string = this.data.config!.uri || ""; - const locales: string | null = this.getSerializedLocales(); + const config: string = this.data.config?.uri ?? ""; + const locales: string = this.getSerializedLocales() ?? ""; + const hashParams = new URLSearchParams({ + manifest: this.helper.manifestUri, + c: this.helper.collectionIndex.toString(), + m: this.helper.manifestIndex.toString(), + cv: this.helper.canvasIndex.toString(), + config: config, + locales: locales, + xywh: zoom, + r: rotation.toString(), + }); + const appUri: string = this.getAppUri(); const title: string = this.helper.getLabel() || ""; - const iframeSrc: string = `${appUri}#?manifest=${this.helper.manifestUri}&c=${this.helper.collectionIndex}&m=${this.helper.manifestIndex}&cv=${this.helper.canvasIndex}&config=${config}&locales=${locales}&xywh=${zoom}&r=${rotation}`; const script: string = Strings.format( template, - iframeSrc, + appUri, + hashParams.toString(), width.toString(), height.toString(), title ); + return script; } diff --git a/src/content-handlers/iiif/extensions/uv-openseadragon-extension/config/config.json b/src/content-handlers/iiif/extensions/uv-openseadragon-extension/config/config.json index 6fa3d2127..a2e1786e1 100644 --- a/src/content-handlers/iiif/extensions/uv-openseadragon-extension/config/config.json +++ b/src/content-handlers/iiif/extensions/uv-openseadragon-extension/config/config.json @@ -445,7 +445,7 @@ "shareDialogue": { "options": { "embedEnabled": true, - "embedTemplate": "", + "embedTemplate": "", "instructionsEnabled": false, "shareEnabled": true, "shareFrameEnabled": true, diff --git a/src/content-handlers/iiif/extensions/uv-pdf-extension/Extension.ts b/src/content-handlers/iiif/extensions/uv-pdf-extension/Extension.ts index 596d7dc7b..f7fd40c02 100644 --- a/src/content-handlers/iiif/extensions/uv-pdf-extension/Extension.ts +++ b/src/content-handlers/iiif/extensions/uv-pdf-extension/Extension.ts @@ -160,16 +160,24 @@ export default class Extension } getEmbedScript(template: string, width: number, height: number): string { + const hashParams = new URLSearchParams({ + manifest: this.helper.manifestUri, + c: this.helper.collectionIndex.toString(), + m: this.helper.manifestIndex.toString(), + cv: this.helper.canvasIndex.toString(), + }); + const appUri: string = this.getAppUri(); - const title: string = this.helper.getLabel() || ""; - const iframeSrc: string = `${appUri}#?manifest=${this.helper.manifestUri}&c=${this.helper.collectionIndex}&m=${this.helper.manifestIndex}&cv=${this.helper.canvasIndex}`; + const title: string = this.helper.getLabel() ?? ""; const script: string = Strings.format( template, - iframeSrc, + appUri, + hashParams.toString(), width.toString(), height.toString(), title ); + return script; } } diff --git a/src/content-handlers/iiif/extensions/uv-pdf-extension/config/config.json b/src/content-handlers/iiif/extensions/uv-pdf-extension/config/config.json index 7aafa2bed..2347780c5 100644 --- a/src/content-handlers/iiif/extensions/uv-pdf-extension/config/config.json +++ b/src/content-handlers/iiif/extensions/uv-pdf-extension/config/config.json @@ -289,7 +289,7 @@ "options": { "embedEnabled": true, "shareEnabled": true, - "embedTemplate": "", + "embedTemplate": "", "instructionsEnabled": false, "shareFrameEnabled": true, "shareManifestsEnabled": true, diff --git a/src/content-handlers/iiif/modules/uv-shared-module/BaseExtension.ts b/src/content-handlers/iiif/modules/uv-shared-module/BaseExtension.ts index 6d850cfab..2168f7f3d 100644 --- a/src/content-handlers/iiif/modules/uv-shared-module/BaseExtension.ts +++ b/src/content-handlers/iiif/modules/uv-shared-module/BaseExtension.ts @@ -765,13 +765,8 @@ export class BaseExtension implements IExtension { } getAppUri(): string { - const appUri: string = - window.location.protocol + - "//" + - window.location.hostname + - (window.location.port ? ":" + window.location.port : ""); - - return appUri + "/uv.html"; + const port = window.location.port ? `:${window.location.port}` : ""; + return `${window.location.protocol}//${window.location.hostname}${port}/uv.html`; } getSettings(): ISettings { diff --git a/src/uv-iiif-config.json b/src/uv-iiif-config.json index 108d55ca5..1769cc205 100644 --- a/src/uv-iiif-config.json +++ b/src/uv-iiif-config.json @@ -43,6 +43,11 @@ "options": { "downloadEnabled": true } + }, + "shareDialogue": { + "options": { + "embedTemplate": "" + } } } }