summaryrefslogtreecommitdiff
path: root/src/components/jet/item/ContentModal.svelte
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/components/jet/item/ContentModal.svelte
init commit
Diffstat (limited to 'src/components/jet/item/ContentModal.svelte')
-rw-r--r--src/components/jet/item/ContentModal.svelte39
1 files changed, 39 insertions, 0 deletions
diff --git a/src/components/jet/item/ContentModal.svelte b/src/components/jet/item/ContentModal.svelte
new file mode 100644
index 0000000..486937d
--- /dev/null
+++ b/src/components/jet/item/ContentModal.svelte
@@ -0,0 +1,39 @@
+<script lang="ts">
+ import ContentModal from '@amp/web-app-components/src/components/Modal/ContentModal.svelte';
+ import { getI18n } from '~/stores/i18n';
+ import { createEventDispatcher } from 'svelte';
+ import { getJet } from '~/jet';
+
+ export let title: string | null;
+ export let subtitle: string | null;
+ export let text: string | null = null;
+ export let dialogTitleId: string | null = null;
+ export let targetId: string = 'close';
+
+ const i18n = getI18n();
+ const jet = getJet();
+ const dispatch = createEventDispatcher();
+
+ const translateFn = (key: string) => $i18n.t(key);
+
+ const handleCloseModal = () => {
+ dispatch('close');
+ jet.recordCustomMetricsEvent({
+ eventType: 'click',
+ targetId,
+ targetType: 'button',
+ actionType: 'close',
+ });
+ };
+</script>
+
+<ContentModal
+ on:close={handleCloseModal}
+ {translateFn}
+ {title}
+ {subtitle}
+ text={text || undefined}
+ {dialogTitleId}
+>
+ <slot name="content" slot="content" />
+</ContentModal>