@xyo-network/react-event 7.0.0 → 7.0.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/dist/browser/index.mjs +17 -22
- package/dist/browser/index.mjs.map +1 -1
- package/package.json +6 -6
package/dist/browser/index.mjs
CHANGED
@@ -1,10 +1,7 @@
|
|
1
|
-
var __defProp = Object.defineProperty;
|
2
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
3
|
-
|
4
1
|
// src/hooks/useCustomEvent.ts
|
5
2
|
import { assertEx } from "@xylabs/assert";
|
6
3
|
import { createRef, useEffect } from "react";
|
7
|
-
var useCustomEvent =
|
4
|
+
var useCustomEvent = (type, listener, customRef) => {
|
8
5
|
const ref = customRef ?? createRef();
|
9
6
|
useEffect(() => {
|
10
7
|
const element = ref?.current;
|
@@ -25,7 +22,7 @@ var useCustomEvent = /* @__PURE__ */ __name((type, listener, customRef) => {
|
|
25
22
|
}
|
26
23
|
};
|
27
24
|
});
|
28
|
-
const dispatch =
|
25
|
+
const dispatch = (detail) => {
|
29
26
|
const event = new CustomEvent(type, {
|
30
27
|
bubbles: true,
|
31
28
|
cancelable: true,
|
@@ -33,30 +30,28 @@ var useCustomEvent = /* @__PURE__ */ __name((type, listener, customRef) => {
|
|
33
30
|
detail
|
34
31
|
});
|
35
32
|
ref.current?.dispatchEvent(event);
|
36
|
-
}
|
37
|
-
return [
|
38
|
-
|
39
|
-
dispatch
|
40
|
-
];
|
41
|
-
}, "useCustomEvent");
|
33
|
+
};
|
34
|
+
return [ref, dispatch];
|
35
|
+
};
|
42
36
|
|
43
37
|
// src/hooks/useEvent.ts
|
44
|
-
var useEvent =
|
45
|
-
const [ref, customDispatch] = useCustomEvent(
|
46
|
-
|
47
|
-
|
48
|
-
|
38
|
+
var useEvent = (listener, sharableRef) => {
|
39
|
+
const [ref, customDispatch] = useCustomEvent(
|
40
|
+
"xyo",
|
41
|
+
listener ? (detail) => {
|
42
|
+
return listener(detail.noun, detail.verb, detail.data);
|
43
|
+
} : void 0,
|
44
|
+
sharableRef
|
45
|
+
);
|
46
|
+
const dispatch = (noun, verb, data) => {
|
49
47
|
return customDispatch({
|
50
48
|
data,
|
51
49
|
noun,
|
52
50
|
verb
|
53
51
|
});
|
54
|
-
}
|
55
|
-
return [
|
56
|
-
|
57
|
-
dispatch
|
58
|
-
];
|
59
|
-
}, "useEvent");
|
52
|
+
};
|
53
|
+
return [ref, dispatch];
|
54
|
+
};
|
60
55
|
export {
|
61
56
|
useCustomEvent,
|
62
57
|
useEvent
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../src/hooks/useCustomEvent.ts","../../src/hooks/useEvent.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport type { RefObject } from 'react'\nimport { createRef, useEffect } from 'react'\n\nexport type CustomEventDispatch<T = unknown> = (detail: T) => boolean | void\n\nexport const useCustomEvent = <TElement extends HTMLElement, TDetail = unknown>(\n type: string,\n listener?: CustomEventDispatch<TDetail>,\n customRef?: RefObject<TElement | null>,\n): [RefObject<TElement | null>, CustomEventDispatch<TDetail>] => {\n // eslint-disable-next-line @eslint-react/no-create-ref\n const ref = customRef ?? createRef<TElement>()\n useEffect(() => {\n const element = ref?.current\n const currentListener = listener\n const handler\n = currentListener\n ? (event: CustomEventInit<TDetail> & Event) => {\n const detail = assertEx(event.detail, () => 'Event missing detail')\n const stop = currentListener(detail)\n if (stop) {\n event.stopPropagation()\n }\n }\n : undefined\n\n if (handler && element) {\n element?.addEventListener(type, handler)\n }\n return () => {\n if (handler && element) {\n element?.removeEventListener(type, handler)\n }\n }\n })\n const dispatch: CustomEventDispatch<TDetail> = (detail?: TDetail) => {\n const event = new CustomEvent<TDetail>(type, {\n bubbles: true,\n cancelable: true,\n composed: true,\n detail,\n })\n ref.current?.dispatchEvent(event)\n }\n return [ref, dispatch]\n}\n","import type { RefObject } from 'react'\n\nimport { useCustomEvent } from './useCustomEvent.ts'\n\nexport type EventNoun = 'payload' | 'boundwitness' | 'address' | 'hash' | 'signature' | 'schema'\nexport type ExtendEventNoun<Extension extends string | void = void> = Extension extends string ? Extension : EventNoun\n\nexport type EventVerb = 'click' | 'favorite'\n\nexport interface Event<TNoun = ExtendEventNoun, TVerb = EventVerb, TData = string> {\n data?: TData\n noun: TNoun\n verb: TVerb\n}\n\nexport type EventDispatch<TNoun = ExtendEventNoun, TVerb = EventVerb, TData = string> = (noun: TNoun, verb: TVerb, data?: TData) => boolean | void\n\nexport const useEvent = <T extends HTMLElement, TNoun = ExtendEventNoun, TVerb = EventVerb, TData = string>(\n listener?: EventDispatch<TNoun, TVerb, TData>,\n sharableRef?: RefObject<T | null>,\n): [RefObject<T | null>, EventDispatch<TNoun, TVerb, TData>] => {\n const [ref, customDispatch] = useCustomEvent<T, Event<TNoun, TVerb, TData>>(\n 'xyo',\n listener\n ? (detail: Event<TNoun, TVerb, TData>) => {\n return listener(detail.noun, detail.verb, detail.data)\n }\n : undefined,\n sharableRef,\n )\n\n const dispatch: EventDispatch<TNoun, TVerb, TData> = (noun: TNoun, verb: TVerb, data?: TData) => {\n return customDispatch({\n data, noun, verb,\n })\n }\n return [ref, dispatch]\n}\n"],"mappings":"
|
1
|
+
{"version":3,"sources":["../../src/hooks/useCustomEvent.ts","../../src/hooks/useEvent.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport type { RefObject } from 'react'\nimport { createRef, useEffect } from 'react'\n\nexport type CustomEventDispatch<T = unknown> = (detail: T) => boolean | void\n\nexport const useCustomEvent = <TElement extends HTMLElement, TDetail = unknown>(\n type: string,\n listener?: CustomEventDispatch<TDetail>,\n customRef?: RefObject<TElement | null>,\n): [RefObject<TElement | null>, CustomEventDispatch<TDetail>] => {\n // eslint-disable-next-line @eslint-react/no-create-ref\n const ref = customRef ?? createRef<TElement>()\n useEffect(() => {\n const element = ref?.current\n const currentListener = listener\n const handler\n = currentListener\n ? (event: CustomEventInit<TDetail> & Event) => {\n const detail = assertEx(event.detail, () => 'Event missing detail')\n const stop = currentListener(detail)\n if (stop) {\n event.stopPropagation()\n }\n }\n : undefined\n\n if (handler && element) {\n element?.addEventListener(type, handler)\n }\n return () => {\n if (handler && element) {\n element?.removeEventListener(type, handler)\n }\n }\n })\n const dispatch: CustomEventDispatch<TDetail> = (detail?: TDetail) => {\n const event = new CustomEvent<TDetail>(type, {\n bubbles: true,\n cancelable: true,\n composed: true,\n detail,\n })\n ref.current?.dispatchEvent(event)\n }\n return [ref, dispatch]\n}\n","import type { RefObject } from 'react'\n\nimport { useCustomEvent } from './useCustomEvent.ts'\n\nexport type EventNoun = 'payload' | 'boundwitness' | 'address' | 'hash' | 'signature' | 'schema'\nexport type ExtendEventNoun<Extension extends string | void = void> = Extension extends string ? Extension : EventNoun\n\nexport type EventVerb = 'click' | 'favorite'\n\nexport interface Event<TNoun = ExtendEventNoun, TVerb = EventVerb, TData = string> {\n data?: TData\n noun: TNoun\n verb: TVerb\n}\n\nexport type EventDispatch<TNoun = ExtendEventNoun, TVerb = EventVerb, TData = string> = (noun: TNoun, verb: TVerb, data?: TData) => boolean | void\n\nexport const useEvent = <T extends HTMLElement, TNoun = ExtendEventNoun, TVerb = EventVerb, TData = string>(\n listener?: EventDispatch<TNoun, TVerb, TData>,\n sharableRef?: RefObject<T | null>,\n): [RefObject<T | null>, EventDispatch<TNoun, TVerb, TData>] => {\n const [ref, customDispatch] = useCustomEvent<T, Event<TNoun, TVerb, TData>>(\n 'xyo',\n listener\n ? (detail: Event<TNoun, TVerb, TData>) => {\n return listener(detail.noun, detail.verb, detail.data)\n }\n : undefined,\n sharableRef,\n )\n\n const dispatch: EventDispatch<TNoun, TVerb, TData> = (noun: TNoun, verb: TVerb, data?: TData) => {\n return customDispatch({\n data, noun, verb,\n })\n }\n return [ref, dispatch]\n}\n"],"mappings":";AAAA,SAAS,gBAAgB;AAEzB,SAAS,WAAW,iBAAiB;AAI9B,IAAM,iBAAiB,CAC5B,MACA,UACA,cAC+D;AAE/D,QAAM,MAAM,aAAa,UAAoB;AAC7C,YAAU,MAAM;AACd,UAAM,UAAU,KAAK;AACrB,UAAM,kBAAkB;AACxB,UAAM,UACF,kBACE,CAAC,UAA4C;AAC3C,YAAM,SAAS,SAAS,MAAM,QAAQ,MAAM,sBAAsB;AAClE,YAAM,OAAO,gBAAgB,MAAM;AACnC,UAAI,MAAM;AACR,cAAM,gBAAgB;AAAA,MACxB;AAAA,IACF,IACA;AAEN,QAAI,WAAW,SAAS;AACtB,eAAS,iBAAiB,MAAM,OAAO;AAAA,IACzC;AACA,WAAO,MAAM;AACX,UAAI,WAAW,SAAS;AACtB,iBAAS,oBAAoB,MAAM,OAAO;AAAA,MAC5C;AAAA,IACF;AAAA,EACF,CAAC;AACD,QAAM,WAAyC,CAAC,WAAqB;AACnE,UAAM,QAAQ,IAAI,YAAqB,MAAM;AAAA,MAC3C,SAAS;AAAA,MACT,YAAY;AAAA,MACZ,UAAU;AAAA,MACV;AAAA,IACF,CAAC;AACD,QAAI,SAAS,cAAc,KAAK;AAAA,EAClC;AACA,SAAO,CAAC,KAAK,QAAQ;AACvB;;;AC7BO,IAAM,WAAW,CACtB,UACA,gBAC8D;AAC9D,QAAM,CAAC,KAAK,cAAc,IAAI;AAAA,IAC5B;AAAA,IACA,WACI,CAAC,WAAuC;AACtC,aAAO,SAAS,OAAO,MAAM,OAAO,MAAM,OAAO,IAAI;AAAA,IACvD,IACA;AAAA,IACJ;AAAA,EACF;AAEA,QAAM,WAA+C,CAAC,MAAa,MAAa,SAAiB;AAC/F,WAAO,eAAe;AAAA,MACpB;AAAA,MAAM;AAAA,MAAM;AAAA,IACd,CAAC;AAAA,EACH;AACA,SAAO,CAAC,KAAK,QAAQ;AACvB;","names":[]}
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@xyo-network/react-event",
|
3
|
-
"version": "7.0.
|
3
|
+
"version": "7.0.1",
|
4
4
|
"description": "Common React library for all XYO projects that use React",
|
5
5
|
"keywords": [
|
6
6
|
"xyo",
|
@@ -43,15 +43,15 @@
|
|
43
43
|
"src"
|
44
44
|
],
|
45
45
|
"dependencies": {
|
46
|
-
"@xylabs/assert": "
|
46
|
+
"@xylabs/assert": "~5.0.8"
|
47
47
|
},
|
48
48
|
"devDependencies": {
|
49
|
-
"@xylabs/ts-scripts-yarn3": "
|
50
|
-
"typescript": "
|
49
|
+
"@xylabs/ts-scripts-yarn3": "~7.1.1",
|
50
|
+
"typescript": "~5.9.2"
|
51
51
|
},
|
52
52
|
"peerDependencies": {
|
53
|
-
"react": "
|
54
|
-
"react-dom": "
|
53
|
+
"react": "~19",
|
54
|
+
"react-dom": "~19"
|
55
55
|
},
|
56
56
|
"publishConfig": {
|
57
57
|
"access": "public"
|