@elementor/frontend-handlers 0.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,22 @@
1
+
2
+ > @elementor/frontend-handlers@0.1.1 build
3
+ > tsup --config=../../tsup.build.ts
4
+
5
+ CLI Building entry: src/index.ts
6
+ CLI Using tsconfig: ../../../tsconfig.json
7
+ CLI tsup v8.5.0
8
+ CLI Using tsup config: /home/runner/work/elementor-packages/elementor-packages/tsup.build.ts
9
+ CLI Target: esnext
10
+ CLI Cleaning output folder
11
+ ESM Build start
12
+ CJS Build start
13
+ CJS dist/index.js 3.69 KB
14
+ CJS dist/index.js.map 5.69 KB
15
+ CJS ⚡️ Build success in 256ms
16
+ ESM dist/index.mjs 2.64 KB
17
+ ESM dist/index.mjs.map 5.52 KB
18
+ ESM ⚡️ Build success in 266ms
19
+ DTS Build start
20
+ DTS ⚡️ Build success in 25566ms
21
+ DTS dist/index.d.mts 415.00 B
22
+ DTS dist/index.d.ts 415.00 B
package/CHANGELOG.md ADDED
@@ -0,0 +1,13 @@
1
+ # @elementor/frontend-handlers
2
+
3
+ ## 0.1.1
4
+
5
+ ### Patch Changes
6
+
7
+ - efa2526: Make the package as public
8
+
9
+ ## 0.1.0
10
+
11
+ ### Minor Changes
12
+
13
+ - ef08352: Make the package as public
@@ -0,0 +1,17 @@
1
+ type Handler = (params: {
2
+ element: Element;
3
+ signal: AbortSignal;
4
+ }) => (() => void) | undefined;
5
+ declare const register: ({ elementType, id, callback }: {
6
+ elementType: string;
7
+ id: string;
8
+ callback: Handler;
9
+ }) => void;
10
+ declare const unregister: ({ elementType, id }: {
11
+ elementType: string;
12
+ id?: string;
13
+ }) => void;
14
+
15
+ declare function init(): void;
16
+
17
+ export { init, register, unregister };
@@ -0,0 +1,17 @@
1
+ type Handler = (params: {
2
+ element: Element;
3
+ signal: AbortSignal;
4
+ }) => (() => void) | undefined;
5
+ declare const register: ({ elementType, id, callback }: {
6
+ elementType: string;
7
+ id: string;
8
+ callback: Handler;
9
+ }) => void;
10
+ declare const unregister: ({ elementType, id }: {
11
+ elementType: string;
12
+ id?: string;
13
+ }) => void;
14
+
15
+ declare function init(): void;
16
+
17
+ export { init, register, unregister };
package/dist/index.js ADDED
@@ -0,0 +1,128 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/index.ts
21
+ var index_exports = {};
22
+ __export(index_exports, {
23
+ init: () => init,
24
+ register: () => register,
25
+ unregister: () => unregister
26
+ });
27
+ module.exports = __toCommonJS(index_exports);
28
+
29
+ // src/handlers-registry.ts
30
+ var handlers = /* @__PURE__ */ new Map();
31
+ var register = ({ elementType, id, callback }) => {
32
+ if (!handlers.has(elementType)) {
33
+ handlers.set(elementType, /* @__PURE__ */ new Map());
34
+ }
35
+ if (!handlers.get(elementType)?.has(id)) {
36
+ handlers.get(elementType)?.set(id, callback);
37
+ }
38
+ };
39
+ var unregister = ({ elementType, id }) => {
40
+ if (!handlers.has(elementType)) {
41
+ return;
42
+ }
43
+ if (id) {
44
+ handlers.get(elementType)?.delete(id);
45
+ if (handlers.get(elementType)?.size === 0) {
46
+ handlers.delete(elementType);
47
+ }
48
+ } else {
49
+ handlers.delete(elementType);
50
+ }
51
+ };
52
+
53
+ // src/lifecycle-events.ts
54
+ var unmountCallbacks = /* @__PURE__ */ new Map();
55
+ var onElementRender = ({
56
+ element,
57
+ elementType,
58
+ elementId
59
+ }) => {
60
+ const controller = new AbortController();
61
+ const manualUnmount = [];
62
+ if (!handlers.has(elementType)) {
63
+ return;
64
+ }
65
+ Array.from(handlers.get(elementType)?.values() ?? []).forEach((handler) => {
66
+ const unmount = handler({ element, signal: controller.signal });
67
+ if (typeof unmount === "function") {
68
+ manualUnmount.push(unmount);
69
+ }
70
+ });
71
+ if (!unmountCallbacks.has(elementType)) {
72
+ unmountCallbacks.set(elementType, /* @__PURE__ */ new Map());
73
+ }
74
+ unmountCallbacks.get(elementType)?.set(elementId, () => {
75
+ controller.abort();
76
+ manualUnmount.forEach((callback) => callback());
77
+ });
78
+ };
79
+ var onElementDestroy = ({ elementType, elementId }) => {
80
+ const unmount = unmountCallbacks.get(elementType)?.get(elementId);
81
+ if (!unmount) {
82
+ return;
83
+ }
84
+ unmount();
85
+ unmountCallbacks.get(elementType)?.delete(elementId);
86
+ if (unmountCallbacks.get(elementType)?.size === 0) {
87
+ unmountCallbacks.delete(elementType);
88
+ }
89
+ };
90
+
91
+ // src/init.ts
92
+ function init() {
93
+ window.addEventListener("elementor/element/render", (_event) => {
94
+ const event = _event;
95
+ const { id, type, element } = event.detail;
96
+ onElementRender({ element, elementType: type, elementId: id });
97
+ });
98
+ window.addEventListener("elementor/element/destroy", (_event) => {
99
+ const event = _event;
100
+ const { id, type } = event.detail;
101
+ onElementDestroy({ elementType: type, elementId: id });
102
+ });
103
+ document.addEventListener("DOMContentLoaded", () => {
104
+ document.querySelectorAll("[data-e-type]").forEach((element) => {
105
+ const el = element;
106
+ const { eType, id } = el.dataset;
107
+ if (!eType || !id) {
108
+ return;
109
+ }
110
+ window.dispatchEvent(
111
+ new CustomEvent("elementor/element/render", {
112
+ detail: {
113
+ id,
114
+ type: eType,
115
+ element
116
+ }
117
+ })
118
+ );
119
+ });
120
+ });
121
+ }
122
+ // Annotate the CommonJS export names for ESM import in node:
123
+ 0 && (module.exports = {
124
+ init,
125
+ register,
126
+ unregister
127
+ });
128
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/index.ts","../src/handlers-registry.ts","../src/lifecycle-events.ts","../src/init.ts"],"sourcesContent":["export { register, unregister } from './handlers-registry';\n\nexport { init } from './init';\n","type Handler = ( params: { element: Element; signal: AbortSignal } ) => ( () => void ) | undefined;\n\nexport const handlers: Map< string, Map< string, Handler > > = new Map();\n\nexport const register = ( { elementType, id, callback }: { elementType: string; id: string; callback: Handler } ) => {\n\tif ( ! handlers.has( elementType ) ) {\n\t\thandlers.set( elementType, new Map() );\n\t}\n\n\tif ( ! handlers.get( elementType )?.has( id ) ) {\n\t\thandlers.get( elementType )?.set( id, callback );\n\t}\n};\n\nexport const unregister = ( { elementType, id }: { elementType: string; id?: string } ) => {\n\tif ( ! handlers.has( elementType ) ) {\n\t\treturn;\n\t}\n\n\tif ( id ) {\n\t\thandlers.get( elementType )?.delete( id );\n\n\t\tif ( handlers.get( elementType )?.size === 0 ) {\n\t\t\thandlers.delete( elementType );\n\t\t}\n\t} else {\n\t\thandlers.delete( elementType );\n\t}\n};\n","import { handlers } from './handlers-registry';\n\nconst unmountCallbacks: Map< string, Map< string, () => void > > = new Map();\n\nexport const onElementRender = ( {\n\telement,\n\telementType,\n\telementId,\n}: {\n\telement: Element;\n\telementType: string;\n\telementId: string;\n} ) => {\n\tconst controller = new AbortController();\n\tconst manualUnmount: ( () => void )[] = [];\n\n\tif ( ! handlers.has( elementType ) ) {\n\t\treturn;\n\t}\n\n\tArray.from( handlers.get( elementType )?.values() ?? [] ).forEach( ( handler ) => {\n\t\tconst unmount = handler( { element, signal: controller.signal } );\n\n\t\tif ( typeof unmount === 'function' ) {\n\t\t\tmanualUnmount.push( unmount );\n\t\t}\n\t} );\n\n\tif ( ! unmountCallbacks.has( elementType ) ) {\n\t\tunmountCallbacks.set( elementType, new Map() );\n\t}\n\n\tunmountCallbacks.get( elementType )?.set( elementId, () => {\n\t\tcontroller.abort();\n\n\t\tmanualUnmount.forEach( ( callback ) => callback() );\n\t} );\n};\n\nexport const onElementDestroy = ( { elementType, elementId }: { elementType: string; elementId: string } ) => {\n\tconst unmount = unmountCallbacks.get( elementType )?.get( elementId );\n\n\tif ( ! unmount ) {\n\t\treturn;\n\t}\n\n\tunmount();\n\n\tunmountCallbacks.get( elementType )?.delete( elementId );\n\n\tif ( unmountCallbacks.get( elementType )?.size === 0 ) {\n\t\tunmountCallbacks.delete( elementType );\n\t}\n};\n","import { onElementDestroy, onElementRender } from './lifecycle-events';\n\nexport function init() {\n\twindow.addEventListener( 'elementor/element/render', ( _event ) => {\n\t\tconst event = _event as CustomEvent< { id: string; type: string; element: Element } >;\n\t\tconst { id, type, element } = event.detail;\n\n\t\tonElementRender( { element, elementType: type, elementId: id } );\n\t} );\n\n\twindow.addEventListener( 'elementor/element/destroy', ( _event ) => {\n\t\tconst event = _event as CustomEvent< { id: string; type: string } >;\n\t\tconst { id, type } = event.detail;\n\n\t\tonElementDestroy( { elementType: type, elementId: id } );\n\t} );\n\n\tdocument.addEventListener( 'DOMContentLoaded', () => {\n\t\tdocument.querySelectorAll( '[data-e-type]' ).forEach( ( element ) => {\n\t\t\tconst el = element as HTMLElement;\n\n\t\t\tconst { eType, id } = el.dataset;\n\n\t\t\tif ( ! eType || ! id ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\twindow.dispatchEvent(\n\t\t\t\tnew CustomEvent( 'elementor/element/render', {\n\t\t\t\t\tdetail: {\n\t\t\t\t\t\tid,\n\t\t\t\t\t\ttype: eType,\n\t\t\t\t\t\telement,\n\t\t\t\t\t},\n\t\t\t\t} )\n\t\t\t);\n\t\t} );\n\t} );\n}\n"],"mappings":"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","names":[]}
package/dist/index.mjs ADDED
@@ -0,0 +1,99 @@
1
+ // src/handlers-registry.ts
2
+ var handlers = /* @__PURE__ */ new Map();
3
+ var register = ({ elementType, id, callback }) => {
4
+ if (!handlers.has(elementType)) {
5
+ handlers.set(elementType, /* @__PURE__ */ new Map());
6
+ }
7
+ if (!handlers.get(elementType)?.has(id)) {
8
+ handlers.get(elementType)?.set(id, callback);
9
+ }
10
+ };
11
+ var unregister = ({ elementType, id }) => {
12
+ if (!handlers.has(elementType)) {
13
+ return;
14
+ }
15
+ if (id) {
16
+ handlers.get(elementType)?.delete(id);
17
+ if (handlers.get(elementType)?.size === 0) {
18
+ handlers.delete(elementType);
19
+ }
20
+ } else {
21
+ handlers.delete(elementType);
22
+ }
23
+ };
24
+
25
+ // src/lifecycle-events.ts
26
+ var unmountCallbacks = /* @__PURE__ */ new Map();
27
+ var onElementRender = ({
28
+ element,
29
+ elementType,
30
+ elementId
31
+ }) => {
32
+ const controller = new AbortController();
33
+ const manualUnmount = [];
34
+ if (!handlers.has(elementType)) {
35
+ return;
36
+ }
37
+ Array.from(handlers.get(elementType)?.values() ?? []).forEach((handler) => {
38
+ const unmount = handler({ element, signal: controller.signal });
39
+ if (typeof unmount === "function") {
40
+ manualUnmount.push(unmount);
41
+ }
42
+ });
43
+ if (!unmountCallbacks.has(elementType)) {
44
+ unmountCallbacks.set(elementType, /* @__PURE__ */ new Map());
45
+ }
46
+ unmountCallbacks.get(elementType)?.set(elementId, () => {
47
+ controller.abort();
48
+ manualUnmount.forEach((callback) => callback());
49
+ });
50
+ };
51
+ var onElementDestroy = ({ elementType, elementId }) => {
52
+ const unmount = unmountCallbacks.get(elementType)?.get(elementId);
53
+ if (!unmount) {
54
+ return;
55
+ }
56
+ unmount();
57
+ unmountCallbacks.get(elementType)?.delete(elementId);
58
+ if (unmountCallbacks.get(elementType)?.size === 0) {
59
+ unmountCallbacks.delete(elementType);
60
+ }
61
+ };
62
+
63
+ // src/init.ts
64
+ function init() {
65
+ window.addEventListener("elementor/element/render", (_event) => {
66
+ const event = _event;
67
+ const { id, type, element } = event.detail;
68
+ onElementRender({ element, elementType: type, elementId: id });
69
+ });
70
+ window.addEventListener("elementor/element/destroy", (_event) => {
71
+ const event = _event;
72
+ const { id, type } = event.detail;
73
+ onElementDestroy({ elementType: type, elementId: id });
74
+ });
75
+ document.addEventListener("DOMContentLoaded", () => {
76
+ document.querySelectorAll("[data-e-type]").forEach((element) => {
77
+ const el = element;
78
+ const { eType, id } = el.dataset;
79
+ if (!eType || !id) {
80
+ return;
81
+ }
82
+ window.dispatchEvent(
83
+ new CustomEvent("elementor/element/render", {
84
+ detail: {
85
+ id,
86
+ type: eType,
87
+ element
88
+ }
89
+ })
90
+ );
91
+ });
92
+ });
93
+ }
94
+ export {
95
+ init,
96
+ register,
97
+ unregister
98
+ };
99
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/handlers-registry.ts","../src/lifecycle-events.ts","../src/init.ts"],"sourcesContent":["type Handler = ( params: { element: Element; signal: AbortSignal } ) => ( () => void ) | undefined;\n\nexport const handlers: Map< string, Map< string, Handler > > = new Map();\n\nexport const register = ( { elementType, id, callback }: { elementType: string; id: string; callback: Handler } ) => {\n\tif ( ! handlers.has( elementType ) ) {\n\t\thandlers.set( elementType, new Map() );\n\t}\n\n\tif ( ! handlers.get( elementType )?.has( id ) ) {\n\t\thandlers.get( elementType )?.set( id, callback );\n\t}\n};\n\nexport const unregister = ( { elementType, id }: { elementType: string; id?: string } ) => {\n\tif ( ! handlers.has( elementType ) ) {\n\t\treturn;\n\t}\n\n\tif ( id ) {\n\t\thandlers.get( elementType )?.delete( id );\n\n\t\tif ( handlers.get( elementType )?.size === 0 ) {\n\t\t\thandlers.delete( elementType );\n\t\t}\n\t} else {\n\t\thandlers.delete( elementType );\n\t}\n};\n","import { handlers } from './handlers-registry';\n\nconst unmountCallbacks: Map< string, Map< string, () => void > > = new Map();\n\nexport const onElementRender = ( {\n\telement,\n\telementType,\n\telementId,\n}: {\n\telement: Element;\n\telementType: string;\n\telementId: string;\n} ) => {\n\tconst controller = new AbortController();\n\tconst manualUnmount: ( () => void )[] = [];\n\n\tif ( ! handlers.has( elementType ) ) {\n\t\treturn;\n\t}\n\n\tArray.from( handlers.get( elementType )?.values() ?? [] ).forEach( ( handler ) => {\n\t\tconst unmount = handler( { element, signal: controller.signal } );\n\n\t\tif ( typeof unmount === 'function' ) {\n\t\t\tmanualUnmount.push( unmount );\n\t\t}\n\t} );\n\n\tif ( ! unmountCallbacks.has( elementType ) ) {\n\t\tunmountCallbacks.set( elementType, new Map() );\n\t}\n\n\tunmountCallbacks.get( elementType )?.set( elementId, () => {\n\t\tcontroller.abort();\n\n\t\tmanualUnmount.forEach( ( callback ) => callback() );\n\t} );\n};\n\nexport const onElementDestroy = ( { elementType, elementId }: { elementType: string; elementId: string } ) => {\n\tconst unmount = unmountCallbacks.get( elementType )?.get( elementId );\n\n\tif ( ! unmount ) {\n\t\treturn;\n\t}\n\n\tunmount();\n\n\tunmountCallbacks.get( elementType )?.delete( elementId );\n\n\tif ( unmountCallbacks.get( elementType )?.size === 0 ) {\n\t\tunmountCallbacks.delete( elementType );\n\t}\n};\n","import { onElementDestroy, onElementRender } from './lifecycle-events';\n\nexport function init() {\n\twindow.addEventListener( 'elementor/element/render', ( _event ) => {\n\t\tconst event = _event as CustomEvent< { id: string; type: string; element: Element } >;\n\t\tconst { id, type, element } = event.detail;\n\n\t\tonElementRender( { element, elementType: type, elementId: id } );\n\t} );\n\n\twindow.addEventListener( 'elementor/element/destroy', ( _event ) => {\n\t\tconst event = _event as CustomEvent< { id: string; type: string } >;\n\t\tconst { id, type } = event.detail;\n\n\t\tonElementDestroy( { elementType: type, elementId: id } );\n\t} );\n\n\tdocument.addEventListener( 'DOMContentLoaded', () => {\n\t\tdocument.querySelectorAll( '[data-e-type]' ).forEach( ( element ) => {\n\t\t\tconst el = element as HTMLElement;\n\n\t\t\tconst { eType, id } = el.dataset;\n\n\t\t\tif ( ! eType || ! id ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\twindow.dispatchEvent(\n\t\t\t\tnew CustomEvent( 'elementor/element/render', {\n\t\t\t\t\tdetail: {\n\t\t\t\t\t\tid,\n\t\t\t\t\t\ttype: eType,\n\t\t\t\t\t\telement,\n\t\t\t\t\t},\n\t\t\t\t} )\n\t\t\t);\n\t\t} );\n\t} );\n}\n"],"mappings":"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","names":[]}
package/package.json ADDED
@@ -0,0 +1,38 @@
1
+ {
2
+ "name": "@elementor/frontend-handlers",
3
+ "description": "Elementor Frontend Handlers",
4
+ "version": "0.1.1",
5
+ "private": false,
6
+ "author": "Elementor Team",
7
+ "homepage": "https://elementor.com/",
8
+ "license": "GPL-3.0-or-later",
9
+ "main": "dist/index.ts",
10
+ "module": "dist/index.mjs",
11
+ "types": "dist/index.d.ts",
12
+ "exports": {
13
+ ".": {
14
+ "types": "./dist/index.d.ts",
15
+ "import": "./dist/index.mjs",
16
+ "require": "./dist/index.ts"
17
+ },
18
+ "./package.json": "./package.json"
19
+ },
20
+ "repository": {
21
+ "type": "git",
22
+ "url": "https://github.com/elementor/elementor-packages.git",
23
+ "directory": "packages/core/frontend-handlers"
24
+ },
25
+ "bugs": {
26
+ "url": "https://github.com/elementor/elementor-packages/issues"
27
+ },
28
+ "publishConfig": {
29
+ "access": "public"
30
+ },
31
+ "scripts": {
32
+ "build": "tsup --config=../../tsup.build.ts",
33
+ "dev": "tsup --config=../../tsup.dev.ts"
34
+ },
35
+ "devDependencies": {
36
+ "tsup": "^8.3.5"
37
+ }
38
+ }
@@ -0,0 +1,29 @@
1
+ type Handler = ( params: { element: Element; signal: AbortSignal } ) => ( () => void ) | undefined;
2
+
3
+ export const handlers: Map< string, Map< string, Handler > > = new Map();
4
+
5
+ export const register = ( { elementType, id, callback }: { elementType: string; id: string; callback: Handler } ) => {
6
+ if ( ! handlers.has( elementType ) ) {
7
+ handlers.set( elementType, new Map() );
8
+ }
9
+
10
+ if ( ! handlers.get( elementType )?.has( id ) ) {
11
+ handlers.get( elementType )?.set( id, callback );
12
+ }
13
+ };
14
+
15
+ export const unregister = ( { elementType, id }: { elementType: string; id?: string } ) => {
16
+ if ( ! handlers.has( elementType ) ) {
17
+ return;
18
+ }
19
+
20
+ if ( id ) {
21
+ handlers.get( elementType )?.delete( id );
22
+
23
+ if ( handlers.get( elementType )?.size === 0 ) {
24
+ handlers.delete( elementType );
25
+ }
26
+ } else {
27
+ handlers.delete( elementType );
28
+ }
29
+ };
package/src/index.ts ADDED
@@ -0,0 +1,3 @@
1
+ export { register, unregister } from './handlers-registry';
2
+
3
+ export { init } from './init';
package/src/init.ts ADDED
@@ -0,0 +1,39 @@
1
+ import { onElementDestroy, onElementRender } from './lifecycle-events';
2
+
3
+ export function init() {
4
+ window.addEventListener( 'elementor/element/render', ( _event ) => {
5
+ const event = _event as CustomEvent< { id: string; type: string; element: Element } >;
6
+ const { id, type, element } = event.detail;
7
+
8
+ onElementRender( { element, elementType: type, elementId: id } );
9
+ } );
10
+
11
+ window.addEventListener( 'elementor/element/destroy', ( _event ) => {
12
+ const event = _event as CustomEvent< { id: string; type: string } >;
13
+ const { id, type } = event.detail;
14
+
15
+ onElementDestroy( { elementType: type, elementId: id } );
16
+ } );
17
+
18
+ document.addEventListener( 'DOMContentLoaded', () => {
19
+ document.querySelectorAll( '[data-e-type]' ).forEach( ( element ) => {
20
+ const el = element as HTMLElement;
21
+
22
+ const { eType, id } = el.dataset;
23
+
24
+ if ( ! eType || ! id ) {
25
+ return;
26
+ }
27
+
28
+ window.dispatchEvent(
29
+ new CustomEvent( 'elementor/element/render', {
30
+ detail: {
31
+ id,
32
+ type: eType,
33
+ element,
34
+ },
35
+ } )
36
+ );
37
+ } );
38
+ } );
39
+ }
@@ -0,0 +1,54 @@
1
+ import { handlers } from './handlers-registry';
2
+
3
+ const unmountCallbacks: Map< string, Map< string, () => void > > = new Map();
4
+
5
+ export const onElementRender = ( {
6
+ element,
7
+ elementType,
8
+ elementId,
9
+ }: {
10
+ element: Element;
11
+ elementType: string;
12
+ elementId: string;
13
+ } ) => {
14
+ const controller = new AbortController();
15
+ const manualUnmount: ( () => void )[] = [];
16
+
17
+ if ( ! handlers.has( elementType ) ) {
18
+ return;
19
+ }
20
+
21
+ Array.from( handlers.get( elementType )?.values() ?? [] ).forEach( ( handler ) => {
22
+ const unmount = handler( { element, signal: controller.signal } );
23
+
24
+ if ( typeof unmount === 'function' ) {
25
+ manualUnmount.push( unmount );
26
+ }
27
+ } );
28
+
29
+ if ( ! unmountCallbacks.has( elementType ) ) {
30
+ unmountCallbacks.set( elementType, new Map() );
31
+ }
32
+
33
+ unmountCallbacks.get( elementType )?.set( elementId, () => {
34
+ controller.abort();
35
+
36
+ manualUnmount.forEach( ( callback ) => callback() );
37
+ } );
38
+ };
39
+
40
+ export const onElementDestroy = ( { elementType, elementId }: { elementType: string; elementId: string } ) => {
41
+ const unmount = unmountCallbacks.get( elementType )?.get( elementId );
42
+
43
+ if ( ! unmount ) {
44
+ return;
45
+ }
46
+
47
+ unmount();
48
+
49
+ unmountCallbacks.get( elementType )?.delete( elementId );
50
+
51
+ if ( unmountCallbacks.get( elementType )?.size === 0 ) {
52
+ unmountCallbacks.delete( elementType );
53
+ }
54
+ };