// Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/ import { nextTick, reactive } from 'vue' import type { DestroyComponentData, PushComponentData } from './types.ts' import type { Component } from 'vue' export enum Events { Push = 'dynamic-component.push', Destroy = 'dynamic-component.destroy', } const createEvent = ( title: string, detail: T, ) => { return new CustomEvent(title, { detail }) } export const pushComponent = async ( name: string, id: string, cmp: Component, props = {}, ) => { const event = createEvent(Events.Push, { name, id, cmp, props: reactive(props), }) window.dispatchEvent(event) await nextTick() } // if no id is passed down, destroys all named components export const destroyComponent = async (name: string, id?: string) => { const event = createEvent(Events.Destroy, { name, id }) window.dispatchEvent(event) await nextTick() }