@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.
- package/.turbo/turbo-build.log +22 -0
- package/CHANGELOG.md +13 -0
- package/dist/index.d.mts +17 -0
- package/dist/index.d.ts +17 -0
- package/dist/index.js +128 -0
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +99 -0
- package/dist/index.mjs.map +1 -0
- package/package.json +38 -0
- package/src/handlers-registry.ts +29 -0
- package/src/index.ts +3 -0
- package/src/init.ts +39 -0
- package/src/lifecycle-events.ts +54 -0
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
|
|
2
|
+
> @elementor/frontend-handlers@0.1.1 build
|
|
3
|
+
> tsup --config=../../tsup.build.ts
|
|
4
|
+
|
|
5
|
+
[34mCLI[39m Building entry: src/index.ts
|
|
6
|
+
[34mCLI[39m Using tsconfig: ../../../tsconfig.json
|
|
7
|
+
[34mCLI[39m tsup v8.5.0
|
|
8
|
+
[34mCLI[39m Using tsup config: /home/runner/work/elementor-packages/elementor-packages/tsup.build.ts
|
|
9
|
+
[34mCLI[39m Target: esnext
|
|
10
|
+
[34mCLI[39m Cleaning output folder
|
|
11
|
+
[34mESM[39m Build start
|
|
12
|
+
[34mCJS[39m Build start
|
|
13
|
+
[32mCJS[39m [1mdist/index.js [22m[32m3.69 KB[39m
|
|
14
|
+
[32mCJS[39m [1mdist/index.js.map [22m[32m5.69 KB[39m
|
|
15
|
+
[32mCJS[39m ⚡️ Build success in 256ms
|
|
16
|
+
[32mESM[39m [1mdist/index.mjs [22m[32m2.64 KB[39m
|
|
17
|
+
[32mESM[39m [1mdist/index.mjs.map [22m[32m5.52 KB[39m
|
|
18
|
+
[32mESM[39m ⚡️ Build success in 266ms
|
|
19
|
+
[34mDTS[39m Build start
|
|
20
|
+
[32mDTS[39m ⚡️ Build success in 25566ms
|
|
21
|
+
[32mDTS[39m [1mdist/index.d.mts [22m[32m415.00 B[39m
|
|
22
|
+
[32mDTS[39m [1mdist/index.d.ts [22m[32m415.00 B[39m
|
package/CHANGELOG.md
ADDED
package/dist/index.d.mts
ADDED
|
@@ -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.d.ts
ADDED
|
@@ -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
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
|
+
};
|