From eff2f2b530e691a0df78f4f3bba4e42ffa735839 Mon Sep 17 00:00:00 2001 From: Dominik Schmidt Date: Fri, 4 Aug 2023 02:54:40 +0200 Subject: [PATCH] get rid of boilerplate --- packages/web-app-pdf-viewer/src/App.vue | 32 ------------------- packages/web-app-pdf-viewer/src/PdfViewer.vue | 25 +++++++++++++++ .../src/components/ErrorScreen.vue | 13 -------- .../src/components/LoadingScreen.vue | 14 -------- packages/web-app-pdf-viewer/src/index.ts | 10 ++++-- packages/web-app-text-editor/src/App.vue | 22 ------------- packages/web-app-text-editor/src/index.ts | 7 ++-- .../AppTemplates/AppWrapperRoute.ts | 25 +++++++++++++++ 8 files changed, 63 insertions(+), 85 deletions(-) delete mode 100644 packages/web-app-pdf-viewer/src/App.vue create mode 100644 packages/web-app-pdf-viewer/src/PdfViewer.vue delete mode 100644 packages/web-app-pdf-viewer/src/components/ErrorScreen.vue delete mode 100644 packages/web-app-pdf-viewer/src/components/LoadingScreen.vue delete mode 100644 packages/web-app-text-editor/src/App.vue create mode 100644 packages/web-pkg/src/components/AppTemplates/AppWrapperRoute.ts diff --git a/packages/web-app-pdf-viewer/src/App.vue b/packages/web-app-pdf-viewer/src/App.vue deleted file mode 100644 index e5a1f4cc6d2..00000000000 --- a/packages/web-app-pdf-viewer/src/App.vue +++ /dev/null @@ -1,32 +0,0 @@ - - - - - diff --git a/packages/web-app-pdf-viewer/src/PdfViewer.vue b/packages/web-app-pdf-viewer/src/PdfViewer.vue new file mode 100644 index 00000000000..d0e9a9aafec --- /dev/null +++ b/packages/web-app-pdf-viewer/src/PdfViewer.vue @@ -0,0 +1,25 @@ + + + + + diff --git a/packages/web-app-pdf-viewer/src/components/ErrorScreen.vue b/packages/web-app-pdf-viewer/src/components/ErrorScreen.vue deleted file mode 100644 index 54da550eb45..00000000000 --- a/packages/web-app-pdf-viewer/src/components/ErrorScreen.vue +++ /dev/null @@ -1,13 +0,0 @@ - - - diff --git a/packages/web-app-pdf-viewer/src/components/LoadingScreen.vue b/packages/web-app-pdf-viewer/src/components/LoadingScreen.vue deleted file mode 100644 index 641f4c1e09b..00000000000 --- a/packages/web-app-pdf-viewer/src/components/LoadingScreen.vue +++ /dev/null @@ -1,14 +0,0 @@ - - - diff --git a/packages/web-app-pdf-viewer/src/index.ts b/packages/web-app-pdf-viewer/src/index.ts index 13c0c0a70ea..53fb11815b4 100644 --- a/packages/web-app-pdf-viewer/src/index.ts +++ b/packages/web-app-pdf-viewer/src/index.ts @@ -1,5 +1,6 @@ import translations from '../l10n/translations.json' -import App from './App.vue' +import { AppWrapperRoute } from 'web-pkg/src/components/AppTemplates/AppWrapperRoute' +import PdfViewer from './PdfViewer.vue' // just a dummy function to trick gettext tools function $gettext(msg) { @@ -9,7 +10,12 @@ function $gettext(msg) { const routes = [ { path: '/:driveAliasAndItem(.*)?', - component: App, + component: AppWrapperRoute(PdfViewer, { + applicationId: 'pdf-viewer', + urlForResourceOptions: { + disposition: 'inline' + } + }), name: 'pdf-viewer', meta: { authContext: 'hybrid', diff --git a/packages/web-app-text-editor/src/App.vue b/packages/web-app-text-editor/src/App.vue deleted file mode 100644 index fb904ad84da..00000000000 --- a/packages/web-app-text-editor/src/App.vue +++ /dev/null @@ -1,22 +0,0 @@ - - - diff --git a/packages/web-app-text-editor/src/index.ts b/packages/web-app-text-editor/src/index.ts index b6b1b049602..8125e926e56 100644 --- a/packages/web-app-text-editor/src/index.ts +++ b/packages/web-app-text-editor/src/index.ts @@ -1,5 +1,6 @@ -import App from './App.vue' import translations from '../l10n/translations.json' +import TextEditor from './TextEditor.vue' +import { AppWrapperRoute } from 'web-pkg/src/components/AppTemplates/AppWrapperRoute' // just a dummy function to trick gettext tools function $gettext(msg) { @@ -11,7 +12,9 @@ const appId = 'text-editor' const routes = [ { path: '/:driveAliasAndItem(.*)?', - component: App, + component: AppWrapperRoute(TextEditor, { + applicationId: appId + }), name: 'text-editor', meta: { authContext: 'hybrid', diff --git a/packages/web-pkg/src/components/AppTemplates/AppWrapperRoute.ts b/packages/web-pkg/src/components/AppTemplates/AppWrapperRoute.ts new file mode 100644 index 00000000000..e62dd6d1529 --- /dev/null +++ b/packages/web-pkg/src/components/AppTemplates/AppWrapperRoute.ts @@ -0,0 +1,25 @@ +import { defineComponent, h } from 'vue' +import AppWrapper, { AppWrapperSlotArgs } from './AppWrapper.vue' +import { UrlForResourceOptions } from 'web-pkg/src/composables' + +export function AppWrapperRoute( + fileEditor: ReturnType, + options: { applicationId: string; urlForResourceOptions?: UrlForResourceOptions } +) { + return defineComponent({ + render() { + return h(AppWrapper, options, { + default: (slotArgs: AppWrapperSlotArgs) => { + const { currentContent, ...restArgs } = slotArgs + return h(fileEditor, { + currentContent: currentContent.value, + 'onUpdate:currentContent': (value) => { + currentContent.value = value + }, + ...restArgs + }) + } + }) + } + }) +}