@motiadev/stream-client-react 0.17.6-beta.188-710084 → 0.17.6-beta.188-853774

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/index.js CHANGED
@@ -1,5 +1,6 @@
1
1
  import { Stream, Stream as Stream$1, StreamGroupSubscription, StreamItemSubscription } from "@motiadev/stream-client-browser";
2
- import React, { useCallback, useEffect, useMemo, useRef, useState } from "react";
2
+ import { c } from "react/compiler-runtime";
3
+ import React, { useEffect, useRef, useState } from "react";
3
4
  import { jsx } from "react/jsx-runtime";
4
5
 
5
6
  //#region src/motia-stream-context.ts
@@ -7,18 +8,46 @@ const MotiaStreamContext = React.createContext({ stream: null });
7
8
 
8
9
  //#endregion
9
10
  //#region src/motia-stream-provider.tsx
10
- const MotiaStreamProvider = ({ children, address, protocols }) => {
11
+ const MotiaStreamProvider = (t0) => {
12
+ const $ = c(9);
13
+ const { children, address, protocols } = t0;
11
14
  const [stream, setStream] = useState(null);
12
- useEffect(() => {
13
- const streamInstance = new Stream$1(address, { protocols });
14
- setStream(streamInstance);
15
- return () => streamInstance.close();
16
- }, [address, protocols]);
17
- const contextValue = useMemo(() => ({ stream }), [stream]);
18
- return /* @__PURE__ */ jsx(MotiaStreamContext.Provider, {
19
- value: contextValue,
20
- children
21
- });
15
+ let t1;
16
+ let t2;
17
+ if ($[0] !== address || $[1] !== protocols) {
18
+ t1 = () => {
19
+ const streamInstance = new Stream$1(address, { protocols });
20
+ setStream(streamInstance);
21
+ return () => streamInstance.close();
22
+ };
23
+ t2 = [address, protocols];
24
+ $[0] = address;
25
+ $[1] = protocols;
26
+ $[2] = t1;
27
+ $[3] = t2;
28
+ } else {
29
+ t1 = $[2];
30
+ t2 = $[3];
31
+ }
32
+ useEffect(t1, t2);
33
+ let t3;
34
+ if ($[4] !== stream) {
35
+ t3 = { stream };
36
+ $[4] = stream;
37
+ $[5] = t3;
38
+ } else t3 = $[5];
39
+ const contextValue = t3;
40
+ let t4;
41
+ if ($[6] !== children || $[7] !== contextValue) {
42
+ t4 = /* @__PURE__ */ jsx(MotiaStreamContext.Provider, {
43
+ value: contextValue,
44
+ children
45
+ });
46
+ $[6] = children;
47
+ $[7] = contextValue;
48
+ $[8] = t4;
49
+ } else t4 = $[8];
50
+ return t4;
22
51
  };
23
52
 
24
53
  //#endregion
@@ -54,17 +83,35 @@ const useMotiaStream = () => {
54
83
  * useStreamEventHandler({ event, type: 'on-custom-event', listener: onEventHandled }, [])
55
84
  * ```
56
85
  */
57
- const useStreamEventHandler = ({ event, type, listener }, dependencies) => {
58
- useEffect(() => {
59
- if (event) {
60
- event.onEvent(type, listener);
61
- return () => event.offEvent(type, listener);
62
- }
63
- }, [
64
- event,
65
- type,
66
- ...dependencies
67
- ]);
86
+ const useStreamEventHandler = (t0, dependencies) => {
87
+ const $ = c(8);
88
+ const { event, type, listener } = t0;
89
+ let t1;
90
+ if ($[0] !== event || $[1] !== listener || $[2] !== type) {
91
+ t1 = () => {
92
+ if (event) {
93
+ event.onEvent(type, listener);
94
+ return () => event.offEvent(type, listener);
95
+ }
96
+ };
97
+ $[0] = event;
98
+ $[1] = listener;
99
+ $[2] = type;
100
+ $[3] = t1;
101
+ } else t1 = $[3];
102
+ let t2;
103
+ if ($[4] !== dependencies || $[5] !== event || $[6] !== type) {
104
+ t2 = [
105
+ event,
106
+ type,
107
+ ...dependencies
108
+ ];
109
+ $[4] = dependencies;
110
+ $[5] = event;
111
+ $[6] = type;
112
+ $[7] = t2;
113
+ } else t2 = $[7];
114
+ useEffect(t1, t2);
68
115
  };
69
116
 
70
117
  //#endregion
@@ -103,8 +150,8 @@ const useStreamGroup = (args) => {
103
150
  return;
104
151
  }
105
152
  subscriptionRef.current = stream.subscribeGroup(streamName, groupId, sortKey);
106
- subscriptionRef.current.addChangeListener((data$1) => {
107
- const typedData = data$1;
153
+ subscriptionRef.current.addChangeListener((data_0) => {
154
+ const typedData = data_0;
108
155
  setData(typedData);
109
156
  setDataCallback?.(typedData);
110
157
  });
@@ -145,34 +192,68 @@ const useStreamGroup = (args) => {
145
192
  * ```
146
193
  */
147
194
  const useStreamItem = (args) => {
195
+ const $ = c(12);
148
196
  const { stream } = useMotiaStream();
149
197
  const [data, setData] = useState();
150
198
  const [event, setEvent] = useState(null);
151
- const { streamName, groupId, id } = args || {};
152
- const handleChange = useCallback((data$1) => {
153
- setData(data$1);
154
- }, []);
155
- useEffect(() => {
156
- if (!streamName || !groupId || !id || !stream) return;
157
- const subscription = stream.subscribeItem(streamName, groupId, id);
158
- subscription.addChangeListener(handleChange);
159
- setEvent(subscription);
160
- return () => {
161
- setData(void 0);
162
- setEvent(null);
163
- subscription.close();
199
+ let t0;
200
+ if ($[0] !== args) {
201
+ t0 = args || {};
202
+ $[0] = args;
203
+ $[1] = t0;
204
+ } else t0 = $[1];
205
+ const { streamName, groupId, id } = t0;
206
+ let t1;
207
+ if ($[2] === Symbol.for("react.memo_cache_sentinel")) {
208
+ t1 = (data_0) => {
209
+ setData(data_0);
164
210
  };
165
- }, [
166
- stream,
167
- streamName,
168
- groupId,
169
- id,
170
- handleChange
171
- ]);
172
- return {
173
- data,
174
- event
175
- };
211
+ $[2] = t1;
212
+ } else t1 = $[2];
213
+ const handleChange = t1;
214
+ let t2;
215
+ let t3;
216
+ if ($[3] !== groupId || $[4] !== id || $[5] !== stream || $[6] !== streamName) {
217
+ t2 = () => {
218
+ if (!streamName || !groupId || !id || !stream) return;
219
+ const subscription = stream.subscribeItem(streamName, groupId, id);
220
+ subscription.addChangeListener(handleChange);
221
+ setEvent(subscription);
222
+ return () => {
223
+ setData(void 0);
224
+ setEvent(null);
225
+ subscription.close();
226
+ };
227
+ };
228
+ t3 = [
229
+ stream,
230
+ streamName,
231
+ groupId,
232
+ id,
233
+ handleChange
234
+ ];
235
+ $[3] = groupId;
236
+ $[4] = id;
237
+ $[5] = stream;
238
+ $[6] = streamName;
239
+ $[7] = t2;
240
+ $[8] = t3;
241
+ } else {
242
+ t2 = $[7];
243
+ t3 = $[8];
244
+ }
245
+ useEffect(t2, t3);
246
+ let t4;
247
+ if ($[9] !== data || $[10] !== event) {
248
+ t4 = {
249
+ data,
250
+ event
251
+ };
252
+ $[9] = data;
253
+ $[10] = event;
254
+ $[11] = t4;
255
+ } else t4 = $[11];
256
+ return t4;
176
257
  };
177
258
 
178
259
  //#endregion
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["MotiaStreamProvider: React.FC<Props>","Stream","data","data"],"sources":["../src/motia-stream-context.ts","../src/motia-stream-provider.tsx","../src/use-motia-stream.ts","../src/use-stream-event-handler.ts","../src/use-stream-group.ts","../src/use-stream-item.ts"],"sourcesContent":["import type { Stream } from '@motiadev/stream-client-browser'\nimport React from 'react'\n\ntype MotiaStreamContextType = {\n stream: Stream | null\n}\n\nexport const MotiaStreamContext = React.createContext<MotiaStreamContextType>({\n stream: null,\n})\n","import { Stream } from '@motiadev/stream-client-browser'\nimport { useEffect, useMemo, useState } from 'react'\nimport { MotiaStreamContext } from './motia-stream-context'\n\ntype Props = React.PropsWithChildren<{\n /**\n * The address of the stream server.\n *\n * @example\n * ```tsx\n * <MotiaStreamProvider address=\"ws://localhost:3000\">\n * <App />\n * </MotiaStreamProvider>\n * */\n address: string\n protocols?: string | string[] | undefined\n}>\n\nexport const MotiaStreamProvider: React.FC<Props> = ({ children, address, protocols }) => {\n const [stream, setStream] = useState<Stream | null>(null)\n\n useEffect(() => {\n const streamInstance = new Stream(address, { protocols })\n setStream(streamInstance)\n return () => streamInstance.close()\n }, [address, protocols])\n\n const contextValue = useMemo(() => ({ stream }), [stream])\n\n return <MotiaStreamContext.Provider value={contextValue}>{children}</MotiaStreamContext.Provider>\n}\n","import React from 'react'\nimport { MotiaStreamContext } from './motia-stream-context'\n\n/**\n * A hook to get the stream context.\n *\n * @example\n * ```tsx\n * const { stream } = useMotiaStream()\n * ```\n */\nexport const useMotiaStream = () => {\n const context = React.useContext(MotiaStreamContext)\n\n if (!context) {\n throw new Error('useMotiaStream must be used within a MotiaStreamProvider')\n }\n\n return context\n}\n","import type { StreamSubscription } from '@motiadev/stream-client-browser'\nimport { type DependencyList, useEffect } from 'react'\n\ntype UseStreamEventHandler = {\n event: StreamSubscription | null\n type: string\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n listener: (event: any) => void\n}\n\n/**\n * A hook to handle custom stream events.\n *\n * @example\n * ```tsx\n * const { event } = useStreamItem({ streamName: 'my-stream', id: '123' })\n *\n * const onEventHandled = (event: any) => {\n * // this is going to be called whenever 'on-custom-event' is sent from the server\n * console.log(event)\n * }\n *\n * useStreamEventHandler({ event, type: 'on-custom-event', listener: onEventHandled }, [])\n * ```\n */\nexport const useStreamEventHandler = (\n { event, type, listener }: UseStreamEventHandler,\n dependencies: DependencyList,\n) => {\n useEffect(() => {\n if (event) {\n event.onEvent(type, listener)\n return () => event.offEvent(type, listener)\n }\n }, [event, type, ...dependencies])\n}\n","import type { StreamSubscription } from '@motiadev/stream-client-browser'\nimport { useEffect, useRef, useState } from 'react'\nimport { useMotiaStream } from './use-motia-stream'\n\nexport type StreamGroupArgs<TData extends { id: string }> = {\n streamName: string\n groupId: string\n sortKey?: keyof TData\n setData?: (data: TData[]) => void\n}\n\n/**\n * A hook to get a group of items from a stream.\n *\n * @example\n * ```tsx\n * const { data } = useStreamGroup<{ id:string; name: string }>({\n * streamName: 'my-stream',\n * groupId: '123',\n * })\n *\n * return (\n * <div>\n * {data.map((item) => (\n * <div key={item.id}>{item.name}</div>\n * ))}\n * </div>\n * )\n * ```\n */\nexport const useStreamGroup = <TData extends { id: string }>(args?: StreamGroupArgs<TData>) => {\n const { stream } = useMotiaStream()\n const [data, setData] = useState<TData[]>([])\n const subscriptionRef = useRef<StreamSubscription | null>(null)\n\n const { streamName, groupId, sortKey, setData: setDataCallback } = args || {}\n\n useEffect(() => {\n if (!streamName || !groupId || !stream) {\n console.error('useStreamGroup: streamName, groupId or stream is not defined', { streamName, groupId, stream })\n return\n }\n\n subscriptionRef.current = stream.subscribeGroup(streamName, groupId, sortKey)\n\n subscriptionRef.current.addChangeListener((data) => {\n const typedData = data as TData[]\n setData(typedData)\n setDataCallback?.(typedData)\n })\n\n return () => {\n subscriptionRef.current?.close()\n subscriptionRef.current = null\n setData([])\n }\n }, [stream, streamName, groupId, sortKey, setDataCallback])\n\n return { data, event: subscriptionRef.current }\n}\n","import type { StreamSubscription } from '@motiadev/stream-client-browser'\nimport { useCallback, useEffect, useState } from 'react'\nimport { useMotiaStream } from './use-motia-stream'\n\nexport type StreamItemArgs = {\n streamName: string\n groupId: string\n id?: string\n}\n\n/**\n * A hook to get a single item from a stream.\n *\n * @example\n * ```tsx\n * const { data } = useStreamItem<{ id:string; name: string }>({\n * streamName: 'my-stream',\n * groupId: '123',\n * id: '123',\n * })\n *\n * return (\n * <div>{data?.name}</div>\n * )\n * ```\n */\nexport const useStreamItem = <TData>(args?: StreamItemArgs) => {\n const { stream } = useMotiaStream()\n const [data, setData] = useState<TData | null | undefined>()\n const [event, setEvent] = useState<StreamSubscription | null>(null)\n const { streamName, groupId, id } = args || {}\n\n const handleChange = useCallback((data: unknown) => {\n setData(data as TData)\n }, [])\n\n useEffect(() => {\n if (!streamName || !groupId || !id || !stream) return\n\n const subscription = stream.subscribeItem(streamName, groupId, id)\n\n subscription.addChangeListener(handleChange)\n setEvent(subscription)\n\n return () => {\n setData(undefined)\n setEvent(null)\n subscription.close()\n }\n }, [stream, streamName, groupId, id, handleChange])\n\n return { data, event }\n}\n"],"mappings":";;;;;AAOA,MAAa,qBAAqB,MAAM,cAAsC,EAC5E,QAAQ,MACT,CAAC;;;;ACSF,MAAaA,uBAAwC,EAAE,UAAU,SAAS,gBAAgB;CACxF,MAAM,CAAC,QAAQ,aAAa,SAAwB,KAAK;AAEzD,iBAAgB;EACd,MAAM,iBAAiB,IAAIC,SAAO,SAAS,EAAE,WAAW,CAAC;AACzD,YAAU,eAAe;AACzB,eAAa,eAAe,OAAO;IAClC,CAAC,SAAS,UAAU,CAAC;CAExB,MAAM,eAAe,eAAe,EAAE,QAAQ,GAAG,CAAC,OAAO,CAAC;AAE1D,QAAO,oBAAC,mBAAmB;EAAS,OAAO;EAAe;GAAuC;;;;;;;;;;;;;AClBnG,MAAa,uBAAuB;CAClC,MAAM,UAAU,MAAM,WAAW,mBAAmB;AAEpD,KAAI,CAAC,QACH,OAAM,IAAI,MAAM,2DAA2D;AAG7E,QAAO;;;;;;;;;;;;;;;;;;;;ACOT,MAAa,yBACX,EAAE,OAAO,MAAM,YACf,iBACG;AACH,iBAAgB;AACd,MAAI,OAAO;AACT,SAAM,QAAQ,MAAM,SAAS;AAC7B,gBAAa,MAAM,SAAS,MAAM,SAAS;;IAE5C;EAAC;EAAO;EAAM,GAAG;EAAa,CAAC;;;;;;;;;;;;;;;;;;;;;;;;ACJpC,MAAa,kBAAgD,SAAkC;CAC7F,MAAM,EAAE,WAAW,gBAAgB;CACnC,MAAM,CAAC,MAAM,WAAW,SAAkB,EAAE,CAAC;CAC7C,MAAM,kBAAkB,OAAkC,KAAK;CAE/D,MAAM,EAAE,YAAY,SAAS,SAAS,SAAS,oBAAoB,QAAQ,EAAE;AAE7E,iBAAgB;AACd,MAAI,CAAC,cAAc,CAAC,WAAW,CAAC,QAAQ;AACtC,WAAQ,MAAM,gEAAgE;IAAE;IAAY;IAAS;IAAQ,CAAC;AAC9G;;AAGF,kBAAgB,UAAU,OAAO,eAAe,YAAY,SAAS,QAAQ;AAE7E,kBAAgB,QAAQ,mBAAmB,WAAS;GAClD,MAAM,YAAYC;AAClB,WAAQ,UAAU;AAClB,qBAAkB,UAAU;IAC5B;AAEF,eAAa;AACX,mBAAgB,SAAS,OAAO;AAChC,mBAAgB,UAAU;AAC1B,WAAQ,EAAE,CAAC;;IAEZ;EAAC;EAAQ;EAAY;EAAS;EAAS;EAAgB,CAAC;AAE3D,QAAO;EAAE;EAAM,OAAO,gBAAgB;EAAS;;;;;;;;;;;;;;;;;;;;;AChCjD,MAAa,iBAAwB,SAA0B;CAC7D,MAAM,EAAE,WAAW,gBAAgB;CACnC,MAAM,CAAC,MAAM,WAAW,UAAoC;CAC5D,MAAM,CAAC,OAAO,YAAY,SAAoC,KAAK;CACnE,MAAM,EAAE,YAAY,SAAS,OAAO,QAAQ,EAAE;CAE9C,MAAM,eAAe,aAAa,WAAkB;AAClD,UAAQC,OAAc;IACrB,EAAE,CAAC;AAEN,iBAAgB;AACd,MAAI,CAAC,cAAc,CAAC,WAAW,CAAC,MAAM,CAAC,OAAQ;EAE/C,MAAM,eAAe,OAAO,cAAc,YAAY,SAAS,GAAG;AAElE,eAAa,kBAAkB,aAAa;AAC5C,WAAS,aAAa;AAEtB,eAAa;AACX,WAAQ,OAAU;AAClB,YAAS,KAAK;AACd,gBAAa,OAAO;;IAErB;EAAC;EAAQ;EAAY;EAAS;EAAI;EAAa,CAAC;AAEnD,QAAO;EAAE;EAAM;EAAO"}
1
+ {"version":3,"file":"index.js","names":["Stream","React","MotiaStreamContextType","stream","MotiaStreamContext","createContext","Stream","useEffect","useMemo","useState","MotiaStreamContext","Props","React","PropsWithChildren","address","protocols","MotiaStreamProvider","FC","t0","$","_c","children","stream","setStream","t1","t2","streamInstance","close","t3","contextValue","t4","React","MotiaStreamContext","useMotiaStream","context","useContext","Error","StreamSubscription","DependencyList","useEffect","UseStreamEventHandler","event","type","listener","useStreamEventHandler","t0","dependencies","$","_c","t1","onEvent","offEvent","t2","StreamSubscription","useEffect","useRef","useState","useMotiaStream","StreamGroupArgs","id","streamName","groupId","sortKey","TData","setData","data","useStreamGroup","args","stream","subscriptionRef","setDataCallback","console","error","current","subscribeGroup","addChangeListener","typedData","close","event","StreamSubscription","useCallback","useEffect","useState","useMotiaStream","StreamItemArgs","streamName","groupId","id","useStreamItem","args","$","_c","stream","data","setData","event","setEvent","t0","t1","Symbol","for","data_0","TData","handleChange","t2","t3","subscription","subscribeItem","addChangeListener","undefined","close","t4"],"sources":["../src/motia-stream-context.ts","../src/motia-stream-provider.tsx","../src/use-motia-stream.ts","../src/use-stream-event-handler.ts","../src/use-stream-group.ts","../src/use-stream-item.ts"],"sourcesContent":["import type { Stream } from '@motiadev/stream-client-browser'\nimport React from 'react'\n\ntype MotiaStreamContextType = {\n stream: Stream | null\n}\n\nexport const MotiaStreamContext = React.createContext<MotiaStreamContextType>({\n stream: null,\n})\n","import { Stream } from '@motiadev/stream-client-browser'\nimport { useEffect, useMemo, useState } from 'react'\nimport { MotiaStreamContext } from './motia-stream-context'\n\ntype Props = React.PropsWithChildren<{\n /**\n * The address of the stream server.\n *\n * @example\n * ```tsx\n * <MotiaStreamProvider address=\"ws://localhost:3000\">\n * <App />\n * </MotiaStreamProvider>\n * */\n address: string\n protocols?: string | string[] | undefined\n}>\n\nexport const MotiaStreamProvider: React.FC<Props> = ({ children, address, protocols }) => {\n const [stream, setStream] = useState<Stream | null>(null)\n\n useEffect(() => {\n const streamInstance = new Stream(address, { protocols })\n setStream(streamInstance)\n return () => streamInstance.close()\n }, [address, protocols])\n\n const contextValue = useMemo(() => ({ stream }), [stream])\n\n return <MotiaStreamContext.Provider value={contextValue}>{children}</MotiaStreamContext.Provider>\n}\n","import React from 'react'\nimport { MotiaStreamContext } from './motia-stream-context'\n\n/**\n * A hook to get the stream context.\n *\n * @example\n * ```tsx\n * const { stream } = useMotiaStream()\n * ```\n */\nexport const useMotiaStream = () => {\n const context = React.useContext(MotiaStreamContext)\n\n if (!context) {\n throw new Error('useMotiaStream must be used within a MotiaStreamProvider')\n }\n\n return context\n}\n","import type { StreamSubscription } from '@motiadev/stream-client-browser'\nimport { type DependencyList, useEffect } from 'react'\n\ntype UseStreamEventHandler = {\n event: StreamSubscription | null\n type: string\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n listener: (event: any) => void\n}\n\n/**\n * A hook to handle custom stream events.\n *\n * @example\n * ```tsx\n * const { event } = useStreamItem({ streamName: 'my-stream', id: '123' })\n *\n * const onEventHandled = (event: any) => {\n * // this is going to be called whenever 'on-custom-event' is sent from the server\n * console.log(event)\n * }\n *\n * useStreamEventHandler({ event, type: 'on-custom-event', listener: onEventHandled }, [])\n * ```\n */\nexport const useStreamEventHandler = (\n { event, type, listener }: UseStreamEventHandler,\n dependencies: DependencyList,\n) => {\n useEffect(() => {\n if (event) {\n event.onEvent(type, listener)\n return () => event.offEvent(type, listener)\n }\n }, [event, type, ...dependencies])\n}\n","import type { StreamSubscription } from '@motiadev/stream-client-browser'\nimport { useEffect, useRef, useState } from 'react'\nimport { useMotiaStream } from './use-motia-stream'\n\nexport type StreamGroupArgs<TData extends { id: string }> = {\n streamName: string\n groupId: string\n sortKey?: keyof TData\n setData?: (data: TData[]) => void\n}\n\n/**\n * A hook to get a group of items from a stream.\n *\n * @example\n * ```tsx\n * const { data } = useStreamGroup<{ id:string; name: string }>({\n * streamName: 'my-stream',\n * groupId: '123',\n * })\n *\n * return (\n * <div>\n * {data.map((item) => (\n * <div key={item.id}>{item.name}</div>\n * ))}\n * </div>\n * )\n * ```\n */\nexport const useStreamGroup = <TData extends { id: string }>(args?: StreamGroupArgs<TData>) => {\n const { stream } = useMotiaStream()\n const [data, setData] = useState<TData[]>([])\n const subscriptionRef = useRef<StreamSubscription | null>(null)\n\n const { streamName, groupId, sortKey, setData: setDataCallback } = args || {}\n\n useEffect(() => {\n if (!streamName || !groupId || !stream) {\n console.error('useStreamGroup: streamName, groupId or stream is not defined', { streamName, groupId, stream })\n return\n }\n\n subscriptionRef.current = stream.subscribeGroup(streamName, groupId, sortKey)\n\n subscriptionRef.current.addChangeListener((data) => {\n const typedData = data as TData[]\n setData(typedData)\n setDataCallback?.(typedData)\n })\n\n return () => {\n subscriptionRef.current?.close()\n subscriptionRef.current = null\n setData([])\n }\n }, [stream, streamName, groupId, sortKey, setDataCallback])\n\n return { data, event: subscriptionRef.current }\n}\n","import type { StreamSubscription } from '@motiadev/stream-client-browser'\nimport { useCallback, useEffect, useState } from 'react'\nimport { useMotiaStream } from './use-motia-stream'\n\nexport type StreamItemArgs = {\n streamName: string\n groupId: string\n id?: string\n}\n\n/**\n * A hook to get a single item from a stream.\n *\n * @example\n * ```tsx\n * const { data } = useStreamItem<{ id:string; name: string }>({\n * streamName: 'my-stream',\n * groupId: '123',\n * id: '123',\n * })\n *\n * return (\n * <div>{data?.name}</div>\n * )\n * ```\n */\nexport const useStreamItem = <TData>(args?: StreamItemArgs) => {\n const { stream } = useMotiaStream()\n const [data, setData] = useState<TData | null | undefined>()\n const [event, setEvent] = useState<StreamSubscription | null>(null)\n const { streamName, groupId, id } = args || {}\n\n const handleChange = useCallback((data: unknown) => {\n setData(data as TData)\n }, [])\n\n useEffect(() => {\n if (!streamName || !groupId || !id || !stream) return\n\n const subscription = stream.subscribeItem(streamName, groupId, id)\n\n subscription.addChangeListener(handleChange)\n setEvent(subscription)\n\n return () => {\n setData(undefined)\n setEvent(null)\n subscription.close()\n }\n }, [stream, streamName, groupId, id, handleChange])\n\n return { data, event }\n}\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@motiadev/stream-client-react",
3
3
  "description": "Motia Stream Client React Package – Responsible for managing streams of data.",
4
- "version": "0.17.6-beta.188-710084",
4
+ "version": "0.17.6-beta.188-853774",
5
5
  "license": "Elastic-2.0",
6
6
  "type": "module",
7
7
  "main": "./dist/index.js",
@@ -11,13 +11,14 @@
11
11
  "react": "^19.2.3"
12
12
  },
13
13
  "dependencies": {
14
- "@motiadev/stream-client-browser": "0.17.6-beta.188-710084"
14
+ "@motiadev/stream-client-browser": "0.17.6-beta.188-853774"
15
15
  },
16
16
  "devDependencies": {
17
+ "@rollup/plugin-babel": "^6.1.0",
17
18
  "@types/react": "^19.2.7",
19
+ "react": "^19.2.3",
18
20
  "tsdown": "^0.16.6",
19
- "typescript": "^5.7.2",
20
- "react": "^19.2.3"
21
+ "typescript": "^5.7.2"
21
22
  },
22
23
  "exports": {
23
24
  ".": "./dist/index.js",
package/tsdown.config.ts CHANGED
@@ -1,3 +1,4 @@
1
+ import pluginBabel from '@rollup/plugin-babel'
1
2
  import { defineConfig } from 'tsdown'
2
3
 
3
4
  export default defineConfig({
@@ -6,7 +7,7 @@ export default defineConfig({
6
7
  },
7
8
  format: 'esm',
8
9
  platform: 'browser',
9
- external: ['@motiadev/stream-client-browser', /^react($|\/)/, /^react-dom($|\/)/],
10
+ external: ['@motiadev/stream-client-browser', /^react($|\/)/, /^react-dom($|\/)/, 'react/jsx-runtime'],
10
11
  dts: {
11
12
  build: true,
12
13
  },
@@ -15,4 +16,15 @@ export default defineConfig({
15
16
  exports: {
16
17
  devExports: 'development',
17
18
  },
19
+ plugins: [
20
+ pluginBabel({
21
+ babelHelpers: 'bundled',
22
+ parserOpts: {
23
+ sourceType: 'module',
24
+ plugins: ['jsx', 'typescript'],
25
+ },
26
+ plugins: ['babel-plugin-react-compiler'],
27
+ extensions: ['.js', '.jsx', '.ts', '.tsx'],
28
+ }),
29
+ ],
18
30
  })