123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- // 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 = <T = PushComponentData | DestroyComponentData>(
- title: string,
- detail: T,
- ) => {
- return new CustomEvent<T>(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()
- }
|