@xyo-network/react-event 7.5.8 → 7.5.11

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.
@@ -2,9 +2,9 @@ import type { RefObject } from 'react';
2
2
  export type EventNoun = 'payload' | 'boundwitness' | 'address' | 'hash' | 'signature' | 'schema';
3
3
  export type ExtendEventNoun<Extension extends string | void = void> = Extension extends string ? Extension : EventNoun;
4
4
  export type EventVerb = 'click' | 'favorite';
5
- export type EventData = {
5
+ export interface EventData {
6
6
  sourceEvent?: globalThis.Event;
7
- };
7
+ }
8
8
  export interface Event<TNoun = ExtendEventNoun, TVerb = EventVerb, TData = string> {
9
9
  data?: TData;
10
10
  noun: TNoun;
@@ -1 +1 @@
1
- {"version":3,"file":"useEvent.d.ts","sourceRoot":"","sources":["../../../src/hooks/useEvent.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAItC,MAAM,MAAM,SAAS,GAAG,SAAS,GAAG,cAAc,GAAG,SAAS,GAAG,MAAM,GAAG,WAAW,GAAG,QAAQ,CAAA;AAChG,MAAM,MAAM,eAAe,CAAC,SAAS,SAAS,MAAM,GAAG,IAAI,GAAG,IAAI,IAAI,SAAS,SAAS,MAAM,GAAG,SAAS,GAAG,SAAS,CAAA;AAEtH,MAAM,MAAM,SAAS,GAAG,OAAO,GAAG,UAAU,CAAA;AAE5C,MAAM,MAAM,SAAS,GAAG;IAAE,WAAW,CAAC,EAAE,UAAU,CAAC,KAAK,CAAA;CAAE,CAAA;AAE1D,MAAM,WAAW,KAAK,CAAC,KAAK,GAAG,eAAe,EAAE,KAAK,GAAG,SAAS,EAAE,KAAK,GAAG,MAAM;IAC/E,IAAI,CAAC,EAAE,KAAK,CAAA;IACZ,IAAI,EAAE,KAAK,CAAA;IACX,WAAW,CAAC,EAAE,UAAU,CAAC,KAAK,CAAA;IAC9B,IAAI,EAAE,KAAK,CAAA;CACZ;AAED,MAAM,MAAM,aAAa,CAAC,KAAK,GAAG,eAAe,EAAE,KAAK,GAAG,SAAS,EAAE,KAAK,GAAG,MAAM,IAAI,CACtF,IAAI,EAAE,KAAK,EACX,IAAI,EAAE,KAAK,EACX,IAAI,CAAC,EAAE,KAAK,EACZ,WAAW,CAAC,EAAE,UAAU,CAAC,KAAK,KAC3B,OAAO,GAAG,IAAI,CAAA;AAEnB,eAAO,MAAM,QAAQ,GAAI,CAAC,SAAS,WAAW,EAAE,KAAK,GAAG,eAAe,EAAE,KAAK,GAAG,SAAS,EAAE,KAAK,GAAG,MAAM,EACxG,WAAW,aAAa,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,EAC7C,cAAc,SAAS,CAAC,CAAC,GAAG,IAAI,CAAC,KAChC,CAAC,SAAS,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,aAAa,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAiB1D,CAAA"}
1
+ {"version":3,"file":"useEvent.d.ts","sourceRoot":"","sources":["../../../src/hooks/useEvent.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAItC,MAAM,MAAM,SAAS,GAAG,SAAS,GAAG,cAAc,GAAG,SAAS,GAAG,MAAM,GAAG,WAAW,GAAG,QAAQ,CAAA;AAChG,MAAM,MAAM,eAAe,CAAC,SAAS,SAAS,MAAM,GAAG,IAAI,GAAG,IAAI,IAAI,SAAS,SAAS,MAAM,GAAG,SAAS,GAAG,SAAS,CAAA;AAEtH,MAAM,MAAM,SAAS,GAAG,OAAO,GAAG,UAAU,CAAA;AAE5C,MAAM,WAAW,SAAS;IAAG,WAAW,CAAC,EAAE,UAAU,CAAC,KAAK,CAAA;CAAE;AAE7D,MAAM,WAAW,KAAK,CAAC,KAAK,GAAG,eAAe,EAAE,KAAK,GAAG,SAAS,EAAE,KAAK,GAAG,MAAM;IAC/E,IAAI,CAAC,EAAE,KAAK,CAAA;IACZ,IAAI,EAAE,KAAK,CAAA;IACX,WAAW,CAAC,EAAE,UAAU,CAAC,KAAK,CAAA;IAC9B,IAAI,EAAE,KAAK,CAAA;CACZ;AAED,MAAM,MAAM,aAAa,CAAC,KAAK,GAAG,eAAe,EAAE,KAAK,GAAG,SAAS,EAAE,KAAK,GAAG,MAAM,IAAI,CACtF,IAAI,EAAE,KAAK,EACX,IAAI,EAAE,KAAK,EACX,IAAI,CAAC,EAAE,KAAK,EACZ,WAAW,CAAC,EAAE,UAAU,CAAC,KAAK,KAC3B,OAAO,GAAG,IAAI,CAAA;AAEnB,eAAO,MAAM,QAAQ,GAAI,CAAC,SAAS,WAAW,EAAE,KAAK,GAAG,eAAe,EAAE,KAAK,GAAG,SAAS,EAAE,KAAK,GAAG,MAAM,EACxG,WAAW,aAAa,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,EAC7C,cAAc,SAAS,CAAC,CAAC,GAAG,IAAI,CAAC,KAChC,CAAC,SAAS,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,aAAa,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAiB1D,CAAA"}
@@ -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/sdk-js";
6
3
  import { useEffect, useRef } from "react";
7
- var useCustomEvent = /* @__PURE__ */ __name((type, listener, customRef) => {
4
+ var useCustomEvent = (type, listener, customRef) => {
8
5
  const newRef = useRef(null);
9
6
  const ref = customRef ?? newRef;
10
7
  useEffect(() => {
@@ -27,7 +24,7 @@ var useCustomEvent = /* @__PURE__ */ __name((type, listener, customRef) => {
27
24
  }
28
25
  };
29
26
  });
30
- const dispatch = /* @__PURE__ */ __name((detail, sourceEvent) => {
27
+ const dispatch = (detail, sourceEvent) => {
31
28
  const event = new CustomEvent(type, {
32
29
  bubbles: true,
33
30
  cancelable: true,
@@ -38,30 +35,28 @@ var useCustomEvent = /* @__PURE__ */ __name((type, listener, customRef) => {
38
35
  }
39
36
  });
40
37
  ref.current?.dispatchEvent(event);
41
- }, "dispatch");
42
- return [
43
- ref,
44
- dispatch
45
- ];
46
- }, "useCustomEvent");
38
+ };
39
+ return [ref, dispatch];
40
+ };
47
41
 
48
42
  // src/hooks/useEvent.ts
49
- var useEvent = /* @__PURE__ */ __name((listener, sharableRef) => {
50
- const [ref, customDispatch] = useCustomEvent("xyo", listener ? (detail) => {
51
- return listener(detail.noun, detail.verb, detail.data, detail.sourceEvent);
52
- } : void 0, sharableRef);
53
- const dispatch = /* @__PURE__ */ __name((noun, verb, data, sourceEvent) => {
43
+ var useEvent = (listener, sharableRef) => {
44
+ const [ref, customDispatch] = useCustomEvent(
45
+ "xyo",
46
+ listener ? (detail) => {
47
+ return listener(detail.noun, detail.verb, detail.data, detail.sourceEvent);
48
+ } : void 0,
49
+ sharableRef
50
+ );
51
+ const dispatch = (noun, verb, data, sourceEvent) => {
54
52
  return customDispatch({
55
53
  data,
56
54
  noun,
57
55
  verb
58
56
  }, sourceEvent);
59
- }, "dispatch");
60
- return [
61
- ref,
62
- dispatch
63
- ];
64
- }, "useEvent");
57
+ };
58
+ return [ref, dispatch];
59
+ };
65
60
  export {
66
61
  useCustomEvent,
67
62
  useEvent
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hooks/useCustomEvent.ts","../../src/hooks/useEvent.ts"],"sourcesContent":["import { assertEx } from '@xylabs/sdk-js'\nimport type { RefObject } from 'react'\nimport { useEffect, useRef } from 'react'\n\nexport type CustomEventListener<T = unknown> = (detail: T, event?: Event) => boolean | void\n\nexport const useCustomEvent = <TElement extends HTMLElement, TDetail = unknown>(\n type: string,\n listener?: CustomEventListener<TDetail>,\n customRef?: RefObject<TElement | null>,\n): [RefObject<TElement | null>, CustomEventListener<TDetail>] => {\n const newRef = useRef<TElement>(null)\n const ref = customRef ?? newRef\n useEffect(() => {\n const element = ref?.current\n const currentListener = listener\n const handler\n = currentListener\n ? (event: Event) => {\n const customEvent = event as CustomEvent<TDetail>\n const detail = assertEx(customEvent.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: CustomEventListener<TDetail> = (detail?: TDetail, sourceEvent?: Event) => {\n const event = new CustomEvent<TDetail>(type, {\n bubbles: true,\n cancelable: true,\n composed: true,\n detail: {\n ...detail,\n sourceEvent,\n } as TDetail,\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 type EventData = { sourceEvent?: globalThis.Event }\n\nexport interface Event<TNoun = ExtendEventNoun, TVerb = EventVerb, TData = string> {\n data?: TData\n noun: TNoun\n sourceEvent?: globalThis.Event\n verb: TVerb\n}\n\nexport type EventDispatch<TNoun = ExtendEventNoun, TVerb = EventVerb, TData = string> = (\n noun: TNoun,\n verb: TVerb,\n data?: TData,\n sourceEvent?: globalThis.Event,\n) => 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, detail.sourceEvent)\n }\n : undefined,\n sharableRef,\n )\n\n const dispatch: EventDispatch<TNoun, TVerb, TData> = (noun: TNoun, verb: TVerb, data?: TData, sourceEvent?: globalThis.Event) => {\n return customDispatch({\n data, noun, verb,\n }, sourceEvent)\n }\n return [ref, dispatch]\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AAEzB,SAASC,WAAWC,cAAc;AAI3B,IAAMC,iBAAiB,wBAC5BC,MACAC,UACAC,cAAAA;AAEA,QAAMC,SAASC,OAAiB,IAAA;AAChC,QAAMC,MAAMH,aAAaC;AACzBG,YAAU,MAAA;AACR,UAAMC,UAAUF,KAAKG;AACrB,UAAMC,kBAAkBR;AACxB,UAAMS,UACFD,kBACE,CAACE,UAAAA;AACC,YAAMC,cAAcD;AACpB,YAAME,SAASC,SAASF,YAAYC,QAAQ,MAAM,sBAAA;AAClD,YAAME,OAAON,gBAAgBI,MAAAA;AAC7B,UAAIE,MAAM;AACRJ,cAAMK,gBAAe;MACvB;IACF,IACAC;AAEN,QAAIP,WAAWH,SAAS;AACtBA,eAASW,iBAAiBlB,MAAMU,OAAAA;IAClC;AACA,WAAO,MAAA;AACL,UAAIA,WAAWH,SAAS;AACtBA,iBAASY,oBAAoBnB,MAAMU,OAAAA;MACrC;IACF;EACF,CAAA;AACA,QAAMU,WAAyC,wBAACP,QAAkBQ,gBAAAA;AAChE,UAAMV,QAAQ,IAAIW,YAAqBtB,MAAM;MAC3CuB,SAAS;MACTC,YAAY;MACZC,UAAU;MACVZ,QAAQ;QACN,GAAGA;QACHQ;MACF;IACF,CAAA;AACAhB,QAAIG,SAASkB,cAAcf,KAAAA;EAC7B,GAX+C;AAY/C,SAAO;IAACN;IAAKe;;AACf,GA5C8B;;;ACmBvB,IAAMO,WAAW,wBACtBC,UACAC,gBAAAA;AAEA,QAAM,CAACC,KAAKC,cAAAA,IAAkBC,eAC5B,OACAJ,WACI,CAACK,WAAAA;AACC,WAAOL,SAASK,OAAOC,MAAMD,OAAOE,MAAMF,OAAOG,MAAMH,OAAOI,WAAW;EAC3E,IACAC,QACJT,WAAAA;AAGF,QAAMU,WAA+C,wBAACL,MAAaC,MAAaC,MAAcC,gBAAAA;AAC5F,WAAON,eAAe;MACpBK;MAAMF;MAAMC;IACd,GAAGE,WAAAA;EACL,GAJqD;AAKrD,SAAO;IAACP;IAAKS;;AACf,GApBwB;","names":["assertEx","useEffect","useRef","useCustomEvent","type","listener","customRef","newRef","useRef","ref","useEffect","element","current","currentListener","handler","event","customEvent","detail","assertEx","stop","stopPropagation","undefined","addEventListener","removeEventListener","dispatch","sourceEvent","CustomEvent","bubbles","cancelable","composed","dispatchEvent","useEvent","listener","sharableRef","ref","customDispatch","useCustomEvent","detail","noun","verb","data","sourceEvent","undefined","dispatch"]}
1
+ {"version":3,"sources":["../../src/hooks/useCustomEvent.ts","../../src/hooks/useEvent.ts"],"sourcesContent":["import { assertEx } from '@xylabs/sdk-js'\nimport type { RefObject } from 'react'\nimport { useEffect, useRef } from 'react'\n\nexport type CustomEventListener<T = unknown> = (detail: T, event?: Event) => boolean | void\n\nexport const useCustomEvent = <TElement extends HTMLElement, TDetail = unknown>(\n type: string,\n listener?: CustomEventListener<TDetail>,\n customRef?: RefObject<TElement | null>,\n): [RefObject<TElement | null>, CustomEventListener<TDetail>] => {\n const newRef = useRef<TElement>(null)\n const ref = customRef ?? newRef\n useEffect(() => {\n const element = ref?.current\n const currentListener = listener\n const handler\n = currentListener\n ? (event: Event) => {\n const customEvent = event as CustomEvent<TDetail>\n const detail = assertEx(customEvent.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: CustomEventListener<TDetail> = (detail?: TDetail, sourceEvent?: Event) => {\n const event = new CustomEvent<TDetail>(type, {\n bubbles: true,\n cancelable: true,\n composed: true,\n detail: {\n ...detail,\n sourceEvent,\n } as TDetail,\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 EventData { sourceEvent?: globalThis.Event }\n\nexport interface Event<TNoun = ExtendEventNoun, TVerb = EventVerb, TData = string> {\n data?: TData\n noun: TNoun\n sourceEvent?: globalThis.Event\n verb: TVerb\n}\n\nexport type EventDispatch<TNoun = ExtendEventNoun, TVerb = EventVerb, TData = string> = (\n noun: TNoun,\n verb: TVerb,\n data?: TData,\n sourceEvent?: globalThis.Event,\n) => 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, detail.sourceEvent)\n }\n : undefined,\n sharableRef,\n )\n\n const dispatch: EventDispatch<TNoun, TVerb, TData> = (noun: TNoun, verb: TVerb, data?: TData, sourceEvent?: globalThis.Event) => {\n return customDispatch({\n data, noun, verb,\n }, sourceEvent)\n }\n return [ref, dispatch]\n}\n"],"mappings":";AAAA,SAAS,gBAAgB;AAEzB,SAAS,WAAW,cAAc;AAI3B,IAAM,iBAAiB,CAC5B,MACA,UACA,cAC+D;AAC/D,QAAM,SAAS,OAAiB,IAAI;AACpC,QAAM,MAAM,aAAa;AACzB,YAAU,MAAM;AACd,UAAM,UAAU,KAAK;AACrB,UAAM,kBAAkB;AACxB,UAAM,UACF,kBACE,CAAC,UAAiB;AAChB,YAAM,cAAc;AACpB,YAAM,SAAS,SAAS,YAAY,QAAQ,MAAM,sBAAsB;AACxE,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,QAAkB,gBAAwB;AACxF,UAAM,QAAQ,IAAI,YAAqB,MAAM;AAAA,MAC3C,SAAS;AAAA,MACT,YAAY;AAAA,MACZ,UAAU;AAAA,MACV,QAAQ;AAAA,QACN,GAAG;AAAA,QACH;AAAA,MACF;AAAA,IACF,CAAC;AACD,QAAI,SAAS,cAAc,KAAK;AAAA,EAClC;AACA,SAAO,CAAC,KAAK,QAAQ;AACvB;;;ACzBO,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,MAAM,OAAO,WAAW;AAAA,IAC3E,IACA;AAAA,IACJ;AAAA,EACF;AAEA,QAAM,WAA+C,CAAC,MAAa,MAAa,MAAc,gBAAmC;AAC/H,WAAO,eAAe;AAAA,MACpB;AAAA,MAAM;AAAA,MAAM;AAAA,IACd,GAAG,WAAW;AAAA,EAChB;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.5.8",
3
+ "version": "7.5.11",
4
4
  "description": "Common React library for all XYO projects that use React",
5
5
  "keywords": [
6
6
  "xyo",
@@ -36,26 +36,50 @@
36
36
  },
37
37
  "./package.json": "./package.json"
38
38
  },
39
- "module": "dist/browser/index.mjs",
40
- "types": "dist/browser/index.d.ts",
41
39
  "files": [
42
40
  "dist",
43
- "src"
41
+ "README.md"
44
42
  ],
45
- "dependencies": {
46
- "@xylabs/sdk-js": "~5.0.90"
47
- },
48
43
  "devDependencies": {
49
- "@xylabs/ts-scripts-common": "~7.5.6",
50
- "@xylabs/ts-scripts-yarn3": "~7.5.6",
51
- "typescript": "^5.9.3"
44
+ "@opentelemetry/api": "^1.9.1",
45
+ "@opentelemetry/sdk-trace-base": "^2.7.0",
46
+ "@types/node": "~25.6.0",
47
+ "@xylabs/sdk-js": "^5.0.100",
48
+ "@xylabs/toolchain": "~7.11.9",
49
+ "@xylabs/tsconfig": "^7.11.9",
50
+ "@xylabs/tsconfig-dom": "^7.11.9",
51
+ "@xylabs/tsconfig-react": "~7.11.9",
52
+ "async-mutex": "^0.5.0",
53
+ "axios": "^1.15.2",
54
+ "bn.js": "^5.2.3",
55
+ "buffer": "^6.0.3",
56
+ "chalk": "^5.6.2",
57
+ "esbuild": "~0.28.0",
58
+ "eslint": "^10.2.1",
59
+ "ethers": "^6.16.0",
60
+ "pako": "^2.1.0",
61
+ "react": "^19.2.5",
62
+ "typescript": "^5.9.3",
63
+ "zod": "^4.3.6"
52
64
  },
53
65
  "peerDependencies": {
54
- "react": "^19",
55
- "react-dom": "^19"
66
+ "@opentelemetry/api": "^1.9.1",
67
+ "@opentelemetry/sdk-trace-base": "^2.7.0",
68
+ "@xylabs/sdk-js": "^5.0.100",
69
+ "@xylabs/tsconfig": "^7.11.9",
70
+ "@xylabs/tsconfig-dom": "^7.11.9",
71
+ "async-mutex": "^0.5.0",
72
+ "axios": "^1.15.2",
73
+ "bn.js": "^5.2.3",
74
+ "buffer": "^6.0.3",
75
+ "chalk": "^5.6.2",
76
+ "ethers": "^6.16.0",
77
+ "pako": "^2.1.0",
78
+ "react": "^19.2.5",
79
+ "zod": "^4.3.6"
56
80
  },
57
81
  "publishConfig": {
58
82
  "access": "public"
59
83
  },
60
84
  "docs": "dist/docs.json"
61
- }
85
+ }
@@ -1,2 +0,0 @@
1
- export * from './useCustomEvent.ts'
2
- export * from './useEvent.ts'
@@ -1,51 +0,0 @@
1
- import { assertEx } from '@xylabs/sdk-js'
2
- import type { RefObject } from 'react'
3
- import { useEffect, useRef } from 'react'
4
-
5
- export type CustomEventListener<T = unknown> = (detail: T, event?: Event) => boolean | void
6
-
7
- export const useCustomEvent = <TElement extends HTMLElement, TDetail = unknown>(
8
- type: string,
9
- listener?: CustomEventListener<TDetail>,
10
- customRef?: RefObject<TElement | null>,
11
- ): [RefObject<TElement | null>, CustomEventListener<TDetail>] => {
12
- const newRef = useRef<TElement>(null)
13
- const ref = customRef ?? newRef
14
- useEffect(() => {
15
- const element = ref?.current
16
- const currentListener = listener
17
- const handler
18
- = currentListener
19
- ? (event: Event) => {
20
- const customEvent = event as CustomEvent<TDetail>
21
- const detail = assertEx(customEvent.detail, () => 'Event missing detail')
22
- const stop = currentListener(detail)
23
- if (stop) {
24
- event.stopPropagation()
25
- }
26
- }
27
- : undefined
28
-
29
- if (handler && element) {
30
- element?.addEventListener(type, handler)
31
- }
32
- return () => {
33
- if (handler && element) {
34
- element?.removeEventListener(type, handler)
35
- }
36
- }
37
- })
38
- const dispatch: CustomEventListener<TDetail> = (detail?: TDetail, sourceEvent?: Event) => {
39
- const event = new CustomEvent<TDetail>(type, {
40
- bubbles: true,
41
- cancelable: true,
42
- composed: true,
43
- detail: {
44
- ...detail,
45
- sourceEvent,
46
- } as TDetail,
47
- })
48
- ref.current?.dispatchEvent(event)
49
- }
50
- return [ref, dispatch]
51
- }
@@ -1,46 +0,0 @@
1
- import type { RefObject } from 'react'
2
-
3
- import { useCustomEvent } from './useCustomEvent.ts'
4
-
5
- export type EventNoun = 'payload' | 'boundwitness' | 'address' | 'hash' | 'signature' | 'schema'
6
- export type ExtendEventNoun<Extension extends string | void = void> = Extension extends string ? Extension : EventNoun
7
-
8
- export type EventVerb = 'click' | 'favorite'
9
-
10
- export type EventData = { sourceEvent?: globalThis.Event }
11
-
12
- export interface Event<TNoun = ExtendEventNoun, TVerb = EventVerb, TData = string> {
13
- data?: TData
14
- noun: TNoun
15
- sourceEvent?: globalThis.Event
16
- verb: TVerb
17
- }
18
-
19
- export type EventDispatch<TNoun = ExtendEventNoun, TVerb = EventVerb, TData = string> = (
20
- noun: TNoun,
21
- verb: TVerb,
22
- data?: TData,
23
- sourceEvent?: globalThis.Event,
24
- ) => boolean | void
25
-
26
- export const useEvent = <T extends HTMLElement, TNoun = ExtendEventNoun, TVerb = EventVerb, TData = string>(
27
- listener?: EventDispatch<TNoun, TVerb, TData>,
28
- sharableRef?: RefObject<T | null>,
29
- ): [RefObject<T | null>, EventDispatch<TNoun, TVerb, TData>] => {
30
- const [ref, customDispatch] = useCustomEvent<T, Event<TNoun, TVerb, TData>>(
31
- 'xyo',
32
- listener
33
- ? (detail: Event<TNoun, TVerb, TData>) => {
34
- return listener(detail.noun, detail.verb, detail.data, detail.sourceEvent)
35
- }
36
- : undefined,
37
- sharableRef,
38
- )
39
-
40
- const dispatch: EventDispatch<TNoun, TVerb, TData> = (noun: TNoun, verb: TVerb, data?: TData, sourceEvent?: globalThis.Event) => {
41
- return customDispatch({
42
- data, noun, verb,
43
- }, sourceEvent)
44
- }
45
- return [ref, dispatch]
46
- }
package/src/index.ts DELETED
@@ -1 +0,0 @@
1
- export * from './hooks/index.ts'