@effect-rx/rx-react 0.1.1 → 0.1.2
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/index.js +1 -2
- package/index.js.map +1 -1
- package/mjs/index.mjs +1 -2
- package/mjs/index.mjs.map +1 -1
- package/package.json +2 -2
- package/src/index.ts +2 -2
package/index.js
CHANGED
|
@@ -28,7 +28,6 @@ class RxStore {
|
|
|
28
28
|
constructor(registry, rx) {
|
|
29
29
|
this.registry = registry;
|
|
30
30
|
this.rx = rx;
|
|
31
|
-
this.value = this.registry.get(this.rx);
|
|
32
31
|
this.subscribe = f => {
|
|
33
32
|
this.value = this.registry.get(this.rx);
|
|
34
33
|
return this.registry.subscribe(this.rx, a => {
|
|
@@ -46,7 +45,7 @@ class RxStore {
|
|
|
46
45
|
const useRxValue = rx => {
|
|
47
46
|
const registry = React.useContext(RegistryContext);
|
|
48
47
|
const store = React.useRef(undefined);
|
|
49
|
-
if (store.current
|
|
48
|
+
if (store.current?.rx !== rx || store.current?.registry !== registry) {
|
|
50
49
|
store.current = new RxStore(registry, rx);
|
|
51
50
|
}
|
|
52
51
|
return React.useSyncExternalStore(store.current.subscribe, store.current.snapshot);
|
package/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["Registry","_interopRequireWildcard","require","Registry_1","exports","React","Result","Result_1","Rx","Rx_1","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","RegistryContext","createContext","make","RxStore","constructor","registry","rx","
|
|
1
|
+
{"version":3,"file":"index.js","names":["Registry","_interopRequireWildcard","require","Registry_1","exports","React","Result","Result_1","Rx","Rx_1","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","RegistryContext","createContext","make","RxStore","constructor","registry","rx","subscribe","f","value","a","snapshot","useRxValue","useContext","store","useRef","undefined","current","useSyncExternalStore","useSetRx","useCallback","useUpdateRx","useRx","useRxUpdate"],"sources":["./src/index.ts"],"sourcesContent":[null],"mappings":"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"}
|
package/mjs/index.mjs
CHANGED
|
@@ -18,7 +18,6 @@ class RxStore {
|
|
|
18
18
|
constructor(registry, rx) {
|
|
19
19
|
this.registry = registry;
|
|
20
20
|
this.rx = rx;
|
|
21
|
-
this.value = this.registry.get(this.rx);
|
|
22
21
|
this.subscribe = f => {
|
|
23
22
|
this.value = this.registry.get(this.rx);
|
|
24
23
|
return this.registry.subscribe(this.rx, a => {
|
|
@@ -36,7 +35,7 @@ class RxStore {
|
|
|
36
35
|
export const useRxValue = rx => {
|
|
37
36
|
const registry = React.useContext(RegistryContext);
|
|
38
37
|
const store = React.useRef(undefined);
|
|
39
|
-
if (store.current
|
|
38
|
+
if (store.current?.rx !== rx || store.current?.registry !== registry) {
|
|
40
39
|
store.current = new RxStore(registry, rx);
|
|
41
40
|
}
|
|
42
41
|
return React.useSyncExternalStore(store.current.subscribe, store.current.snapshot);
|
package/mjs/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","names":["Registry","React","Result","Rx","RegistryContext","createContext","make","RxStore","constructor","registry","rx","
|
|
1
|
+
{"version":3,"file":"index.mjs","names":["Registry","React","Result","Rx","RegistryContext","createContext","make","RxStore","constructor","registry","rx","subscribe","f","value","get","a","snapshot","useRxValue","useContext","store","useRef","undefined","current","useSyncExternalStore","useSetRx","useCallback","set","useUpdateRx","useRx","useRxUpdate"],"sources":["../src/index.ts"],"sourcesContent":[null],"mappings":"AAAA;;;AAGA,OAAO,KAAKA,QAAQ,MAAM,wBAAwB;AAElD,OAAO,KAAKC,KAAK,MAAM,OAAO;4BAEJ,wBAAwB;uBAAtCD,QAAQ;0BACI,sBAAsB;qBAAlCE,MAAM;sBACE,kBAAkB;iBAA1BC,EAAE;AAEd;;;;AAIA,OAAO,MAAMC,eAAe,gBAAGH,KAAK,CAACI,aAAa,eAAoBL,QAAQ,CAACM,IAAI,EAAE,CAAC;AAEtF,MAAMC,OAAO;EACXC,YACWC,QAA2B,EAC3BC,EAAY;IADZ,KAAAD,QAAQ,GAARA,QAAQ;IACR,KAAAC,EAAE,GAAFA,EAAE;IAKb,KAAAC,SAAS,GAAIC,CAAa,IAAgB;MACxC,IAAI,CAACC,KAAK,GAAG,IAAI,CAACJ,QAAQ,CAACK,GAAG,CAAC,IAAI,CAACJ,EAAE,CAAC;MACvC,OAAO,IAAI,CAACD,QAAQ,CAACE,SAAS,CAAC,IAAI,CAACD,EAAE,EAAGK,CAAC,IAAI;QAC5C,IAAI,CAACF,KAAK,GAAGE,CAAC;QACdH,CAAC,EAAE;MACL,CAAC,CAAC;IACJ,CAAC;IAED,KAAAI,QAAQ,GAAG,MAAS,IAAI,CAACH,KAAK;EAZ3B;;AAeL;;;;AAIA,OAAO,MAAMI,UAAU,GAAOP,EAAY,IAAO;EAC/C,MAAMD,QAAQ,GAAGR,KAAK,CAACiB,UAAU,CAACd,eAAe,CAAC;EAClD,MAAMe,KAAK,GAAGlB,KAAK,CAACmB,MAAM,CAAaC,SAAgB,CAAC;EACxD,IAAIF,KAAK,CAACG,OAAO,EAAEZ,EAAE,KAAKA,EAAE,IAAIS,KAAK,CAACG,OAAO,EAAEb,QAAQ,KAAKA,QAAQ,EAAE;IACpEU,KAAK,CAACG,OAAO,GAAG,IAAIf,OAAO,CAACE,QAAQ,EAAEC,EAAE,CAAC;;EAE3C,OAAOT,KAAK,CAACsB,oBAAoB,CAACJ,KAAK,CAACG,OAAO,CAACX,SAAS,EAAEQ,KAAK,CAACG,OAAO,CAACN,QAAQ,CAAC;AACpF,CAAC;AAED;;;;AAIA,OAAO,MAAMQ,QAAQ,GAAUd,EAAsB,IAAoB;EACvE,MAAMD,QAAQ,GAAGR,KAAK,CAACiB,UAAU,CAACd,eAAe,CAAC;EAClD,OAAOH,KAAK,CAACwB,WAAW,CAAEZ,KAAK,IAAKJ,QAAQ,CAACiB,GAAG,CAAChB,EAAE,EAAEG,KAAK,CAAC,EAAE,CAACJ,QAAQ,EAAEC,EAAE,CAAC,CAAC;AAC9E,CAAC;AAED;;;;AAIA,OAAO,MAAMiB,WAAW,GAAUjB,EAAsB,IAA8B;EACpF,MAAMD,QAAQ,GAAGR,KAAK,CAACiB,UAAU,CAACd,eAAe,CAAC;EAClD,OAAOH,KAAK,CAACwB,WAAW,CAAEb,CAAC,IAAKH,QAAQ,CAACiB,GAAG,CAAChB,EAAE,EAAEE,CAAC,CAACH,QAAQ,CAACK,GAAG,CAACJ,EAAE,CAAC,CAAC,CAAC,EAAE,CAACD,QAAQ,EAAEC,EAAE,CAAC,CAAC;AACxF,CAAC;AAED;;;;AAIA,OAAO,MAAMkB,KAAK,GAAUlB,EAAsB,IAChD,CACEO,UAAU,CAACP,EAAE,CAAC,EACdc,QAAQ,CAACd,EAAE,CAAC,CACJ;AAEZ;;;;AAIA,OAAO,MAAMmB,WAAW,GAAUnB,EAAsB,IACtD,CACEO,UAAU,CAACP,EAAE,CAAC,EACdiB,WAAW,CAACjB,EAAE,CAAC,CACP"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@effect-rx/rx-react",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.2",
|
|
4
4
|
"description": "Reactive toolkit for Effect",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"repository": {
|
|
@@ -35,7 +35,7 @@
|
|
|
35
35
|
"sideEffects": [],
|
|
36
36
|
"author": "Effect contributors",
|
|
37
37
|
"dependencies": {
|
|
38
|
-
"@effect-rx/rx": "^0.1.
|
|
38
|
+
"@effect-rx/rx": "^0.1.2"
|
|
39
39
|
},
|
|
40
40
|
"peerDependencies": {
|
|
41
41
|
"@effect/data": "^0.18.5",
|
package/src/index.ts
CHANGED
|
@@ -21,7 +21,7 @@ class RxStore<A> {
|
|
|
21
21
|
readonly rx: Rx.Rx<A>
|
|
22
22
|
) {}
|
|
23
23
|
|
|
24
|
-
value
|
|
24
|
+
value!: A
|
|
25
25
|
|
|
26
26
|
subscribe = (f: () => void): () => void => {
|
|
27
27
|
this.value = this.registry.get(this.rx)
|
|
@@ -41,7 +41,7 @@ class RxStore<A> {
|
|
|
41
41
|
export const useRxValue = <A>(rx: Rx.Rx<A>): A => {
|
|
42
42
|
const registry = React.useContext(RegistryContext)
|
|
43
43
|
const store = React.useRef<RxStore<A>>(undefined as any)
|
|
44
|
-
if (store.current
|
|
44
|
+
if (store.current?.rx !== rx || store.current?.registry !== registry) {
|
|
45
45
|
store.current = new RxStore(registry, rx)
|
|
46
46
|
}
|
|
47
47
|
return React.useSyncExternalStore(store.current.subscribe, store.current.snapshot)
|