diff --git a/components/IconButton.vue b/components/IconButton.vue
index 950783c..7aa9211 100644
--- a/components/IconButton.vue
+++ b/components/IconButton.vue
@@ -2,17 +2,17 @@
-
+
+
-
+
+
diff --git a/components/PdfViewer.vue b/components/PdfViewer.vue
new file mode 100644
index 0000000..92b633d
--- /dev/null
+++ b/components/PdfViewer.vue
@@ -0,0 +1,19 @@
+
+
+
+
+
+
+
+
+
+
diff --git a/layouts/default.vue b/layouts/default.vue
index c1edae5..c133210 100644
--- a/layouts/default.vue
+++ b/layouts/default.vue
@@ -37,6 +37,9 @@
+
diff --git a/nuxt.config.ts b/nuxt.config.ts
index 5c7fa0d..251c637 100644
--- a/nuxt.config.ts
+++ b/nuxt.config.ts
@@ -28,5 +28,15 @@ export default defineNuxtConfig({
},
experimental: {
payloadExtraction: true
- }
+ },
+ vite: {
+ optimizeDeps: {
+ include: ['pdfjs-dist'],
+ },
+ esbuildOptions: {
+ supported: {
+ topLevelAwait: true,
+ },
+ },
+ },
})
diff --git a/package.json b/package.json
index 83b5e73..8cb2b36 100644
--- a/package.json
+++ b/package.json
@@ -25,10 +25,12 @@
},
"dependencies": {
"@pinia/nuxt": "^0.11.3",
+ "@vue-pdf-viewer/viewer": "^3.8.0",
"mongodb": "^7.1.0",
"nuxt": "^4.3.1",
"nuxt-swiper": "^1.2.2",
"nuxt-umami": "^3.2.1",
+ "pdfjs-dist": "^5.4.624",
"pinia": "^3.0.4",
"sharp": "^0.34.5"
}
diff --git a/stores/ModalStore.js b/stores/ModalStore.js
index b883b19..c8ff811 100644
--- a/stores/ModalStore.js
+++ b/stores/ModalStore.js
@@ -1,15 +1,16 @@
import {defineStore} from "pinia";
export const useModalStore = defineStore("ModalStore", {
- state: () => ({"type": "", "aspect":"", "isOpen":false, "bucket":"", "gallery":"", "vimeo_trackid":""}),
+ state: () => ({ "type": "", "aspect":"", "isOpen":false, "bucket":"", "gallery":"", "vimeo_trackid":"", "pdfUrl":""}),
actions: {
- setModalProps(type, aspect, isOpen, bucket, gallery, vimeo_trackid) {
+ setModalProps(type, aspect, isOpen, bucket, gallery, vimeo_trackid, pdfUrl = '') {
this.type = type
this.aspect = aspect
this.isOpen = isOpen
this.bucket = bucket
this.gallery = gallery
this.vimeo_trackid = vimeo_trackid
+ this.pdfUrl = pdfUrl
}
}
})
\ No newline at end of file