aboutsummaryrefslogtreecommitdiffstats
path: root/components/export/ExportZipModal.vue
diff options
context:
space:
mode:
authorLeonardo Bishop <me@leonardobishop.com>2024-03-13 19:33:33 +0000
committerLeonardo Bishop <me@leonardobishop.com>2024-03-13 19:33:33 +0000
commitbd26b2800e2675613c6990673ad0b7b5175aa841 (patch)
tree26d1a89d9ed60ad73a82fbe3371d8c58578702f5 /components/export/ExportZipModal.vue
parent825d2cadee4ddf34d0dde8c278fc8e8a99e95b95 (diff)
Add zip export
Diffstat (limited to 'components/export/ExportZipModal.vue')
-rw-r--r--components/export/ExportZipModal.vue67
1 files changed, 67 insertions, 0 deletions
diff --git a/components/export/ExportZipModal.vue b/components/export/ExportZipModal.vue
new file mode 100644
index 0000000..b84690d
--- /dev/null
+++ b/components/export/ExportZipModal.vue
@@ -0,0 +1,67 @@
+<script setup lang="ts">
+import { saveAs } from 'file-saver';
+
+const session = useSessionStore();
+const exportStore = useExportStore();
+
+const showModal = ref(false);
+
+const status = computed(() => exportStore.getZipStatus());
+
+const startExport = async () => {
+ const quests = session.getQuests();
+ const categories = session.getCategories();
+ const items = session.getItems();
+
+ exportStore.setZipStatus('preparing');
+
+ const { transformedQuests, transformedCategories, transformedItems } = await prepareZip(quests, categories, items);
+
+ exportStore.setZipStatus('compressing');
+
+ try {
+ const blob = await createZip(transformedQuests, transformedCategories, transformedItems);
+
+ exportStore.setZipContents(blob);
+ exportStore.setZipStatus('ready');
+
+ saveAs(blob, "quests.zip");
+ } catch {
+ exportStore.setZipStatus('failed');
+ }
+}
+
+const open = () => {
+ showModal.value = true;
+}
+
+defineExpose({
+ open,
+ startExport
+})
+</script>
+
+<template>
+ <Modal v-model="showModal">
+ <template v-slot:header>
+ <h2>Export as ZIP</h2>
+ </template>
+
+ <p v-if="status === 'preparing'">Preparing quests for export...</p>
+ <p v-if="status === 'compressing'">Compressing zip...</p>
+ <p v-if="status === 'ready'">Done.</p>
+ <p v-if="status === 'failed'">Failed to create zip.</p>
+
+ <div id="controls" class="control-group">
+ <Button :icon="['fas', 'xmark']" :label="'Close'" @click="showModal = false"></Button>
+ </div>
+ </Modal>
+</template>
+
+<style scoped>
+#controls {
+ display: flex;
+ justify-content: flex-end;
+ margin-top: 1rem;
+}
+</style> \ No newline at end of file