summaryrefslogtreecommitdiff
path: root/src/jet/utils/handle-modal-presentation.ts
diff options
context:
space:
mode:
authorrxliuli <rxliuli@gmail.com>2025-11-04 05:03:50 +0800
committerrxliuli <rxliuli@gmail.com>2025-11-04 05:03:50 +0800
commitbce557cc2dc767628bed6aac87301a1be7c5431b (patch)
treeb51a051228d01fe3306cd7626d4a96768aadb944 /src/jet/utils/handle-modal-presentation.ts
init commit
Diffstat (limited to 'src/jet/utils/handle-modal-presentation.ts')
-rw-r--r--src/jet/utils/handle-modal-presentation.ts29
1 files changed, 29 insertions, 0 deletions
diff --git a/src/jet/utils/handle-modal-presentation.ts b/src/jet/utils/handle-modal-presentation.ts
new file mode 100644
index 0000000..9040d4f
--- /dev/null
+++ b/src/jet/utils/handle-modal-presentation.ts
@@ -0,0 +1,29 @@
+import { getModalPageStore } from '~/stores/modalPage';
+import { isGenericPage, type Page } from '../models';
+import type { Logger } from '@amp/web-apps-logger/src';
+
+/**
+ * This function handles rendering flow action pages into a modal container.
+ * NOTE: Rendering a page in a modal will not update URL or history
+ *
+ * @param page page promise
+ * @param log app logger
+ */
+export const handleModalPresentation = (
+ page: { promise: Promise<Page> },
+ log: Logger<unknown[]>,
+ pageDetail?: string,
+) => {
+ page.promise
+ .then((page) => {
+ if (isGenericPage(page)) {
+ const modalStore = getModalPageStore();
+ modalStore.setPage({ page, pageDetail });
+ } else {
+ throw new Error('only generic page is rendered in modal');
+ }
+ })
+ .catch((e) => {
+ log.error('modal presentation failed', e);
+ });
+};