// Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/ import { useRoute } from 'vue-router' import { closeOverlayContainer, getOpenedOverlayContainers, getOverlayContainerMeta, isOverlayContainerOpened, openOverlayContainer, useOverlayContainer, type OverlayContainerOptions, } from '#desktop/composables/useOverlayContainer.ts' import { getCurrentApp } from '#desktop/currentApp.ts' const OVERLAY_CONTAINER_TYPE = 'dialog' export const getOpenedDialogs = () => getOpenedOverlayContainers(OVERLAY_CONTAINER_TYPE) export const isDialogOpened = (name?: string) => isOverlayContainerOpened(OVERLAY_CONTAINER_TYPE, name) export const getDialogMeta = () => { const overlayContainerMeta = getOverlayContainerMeta(OVERLAY_CONTAINER_TYPE) return { dialogsOptions: overlayContainerMeta.options, openedDialogs: overlayContainerMeta.opened, } } export const openDialog = async ( name: string, props: Record, global: boolean = false, ) => { let currentName = name if (!global) { getCurrentApp().runWithContext(() => { const route = useRoute() currentName = `${name}_${route.path}` }) } return openOverlayContainer(OVERLAY_CONTAINER_TYPE, currentName, props) } export const closeDialog = async (name: string, global: boolean = false) => { let currentName = name if (!global) { getCurrentApp().runWithContext(() => { const route = useRoute() currentName = `${name}_${route.path}` }) } return closeOverlayContainer(OVERLAY_CONTAINER_TYPE, currentName) } export const useDialog = (options: OverlayContainerOptions) => { return useOverlayContainer(OVERLAY_CONTAINER_TYPE, options) }