muya 2.0.3 → 2.0.5
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/cjs/index.js +1 -1
- package/esm/create-state.js +1 -1
- package/esm/use-value.js +1 -1
- package/package.json +1 -1
- package/src/create-state.ts +6 -2
- package/src/types.ts +2 -2
- package/src/use-value.ts +5 -2
- package/types/types.d.ts +2 -2
- package/types/use-value.d.ts +1 -1
package/cjs/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";var g=Object.defineProperty;var R=Object.getOwnPropertyDescriptor;var L=Object.getOwnPropertyNames;var z=Object.prototype.hasOwnProperty;var H=(e,t)=>{for(var r in t)g(e,r,{get:t[r],enumerable:!0})},M=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of L(t))!z.call(e,o)&&o!==r&&g(e,o,{get:()=>t[o],enumerable:!(n=R(t,o))||n.enumerable});return e};var j=e=>M(g({},"__esModule",{value:!0}),e);var Y={};H(Y,{EMPTY_SELECTOR:()=>k,create:()=>
|
|
1
|
+
"use strict";var g=Object.defineProperty;var R=Object.getOwnPropertyDescriptor;var L=Object.getOwnPropertyNames;var z=Object.prototype.hasOwnProperty;var H=(e,t)=>{for(var r in t)g(e,r,{get:t[r],enumerable:!0})},M=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of L(t))!z.call(e,o)&&o!==r&&g(e,o,{get:()=>t[o],enumerable:!(n=R(t,o))||n.enumerable});return e};var j=e=>M(g({},"__esModule",{value:!0}),e);var Y={};H(Y,{EMPTY_SELECTOR:()=>k,create:()=>U,select:()=>h,shallow:()=>q,useValue:()=>x});module.exports=j(Y);var k=e=>e;function f(e){return e instanceof Promise}function C(e){return typeof e=="function"}function V(e){return e instanceof Map}function P(e){return e instanceof Set}function O(e){return Array.isArray(e)}function p(e,t){return e===t?!0:!!Object.is(e,t)}function I(e){return typeof e=="function"}function v(e){return e instanceof T}function A(e){return e instanceof Error}function d(e){return e===void 0}var T=class extends Error{static Error="AbortError"};function N(e,t){t&&t.abort();let r=new AbortController,{signal:n}=r;return{promise:new Promise((i,s)=>{n.addEventListener("abort",()=>{s(new T)}),e.then(i).catch(s)}),controller:r}}function b(e,t=p){if(!d(e.current)){if(!d(e.previous)&&t(e.current,e.previous))return!1;e.previous=e.current}return!0}function m(e,t,r){if(!f(r))return r;e.abortController&&e.abortController.abort();let{promise:n,controller:o}=N(r,e.abortController);return e.abortController=o,n.then(i=>{e.current=i,t()}).catch(i=>{v(i)||(e.current=i,t())})}function G(){let e=new Map,t=new Set,r=performance.now(),n=!1;function o(){let s=performance.now(),a=s-r,{size:u}=t;if(a<.2&&u>0&&u<10){r=s,i();return}n||(n=!0,Promise.resolve().then(()=>{n=!1,r=performance.now(),i()}))}function i(){if(t.size===0)return;let s=new Set;for(let a of t){if(e.has(a.id)){s.add(a.id);let{onResolveItem:u}=e.get(a.id);u&&u(a.value)}t.delete(a)}if(t.size>0){o();return}for(let a of s)e.get(a)?.onFinish()}return{add(s,a){return e.set(s,a),()=>{e.delete(s)}},schedule(s,a){t.add({value:a,id:s}),o()}}}function h(e,t,r){let n={};function o(){let c=e.map(l=>l.get());return t(...c)}function i(){if(d(n.current)){let c=o();n.current=m(n,a.emitter.emit,c)}return n.current}let s=[];for(let c of e){let l=c.emitter.subscribe(()=>{S.schedule(a.id,null)});s.push(l)}let a=y({destroy(){for(let c of s)c();u(),a.emitter.clear(),n.current=void 0},get:i}),u=S.add(a.id,{onFinish(){let c=o();n.current=m(n,a.emitter.emit,c),b(n,r)&&a.emitter.emit()}});return a}var w=require("react");function x(e,t=k){let{emitter:r}=e,n=(0,w.useSyncExternalStore)(e.emitter.subscribe,()=>t(r.getSnapshot()),()=>t(r.getInitialSnapshot?r.getInitialSnapshot():r.getSnapshot()));if((0,w.useDebugValue)(n),f(n)||A(n))throw n;return n}function D(e,t){let r=new Set,n=[];return{clear:()=>{for(let o of n)o();r.clear()},subscribe:o=>(r.add(o),()=>{r.delete(o)}),emit:(...o)=>{for(let i of r)i(...o)},contains:o=>r.has(o),getSnapshot:e,getInitialSnapshot:t,getSize:()=>r.size,subscribeToOtherEmitter(o){let i=o.subscribe(()=>{this.emit()});n.push(i)}}}var _=0;function K(){return _++}function y(e){let{get:t,destroy:r,set:n}=e,o=!!n,i=function(s){return x(i,s)};return i.isSet=o,i.id=K(),i.emitter=D(t),i.destroy=r,i.listen=function(s){return this.emitter.subscribe(()=>{let a=t();f(a)||s(t())})},i.withName=function(s){return this.stateName=s,this},i.select=function(s,a=p){return h([i],s,a)},i.get=t,i.set=n,i}var S=G();function U(e,t=p){let r={};function n(){try{if(d(r.current)){let u=C(e)?e():e,c=m(r,s.emitter.emit,u);return r.current=c,r.current}return r.current}catch(u){r.current=u}return r.current}async function o(u,c){await u;let l=c(r.current),E=m(r,s.emitter.emit,l);r.current=E}function i(u){let c=n(),l=I(u);if(l&&f(c)){o(c,u);return}r.abortController&&r.abortController.abort();let E=l?u(c):u,F=m(r,s.emitter.emit,E);r.current=F}let s=y({get:n,destroy(){n(),a(),s.emitter.clear(),r.current=void 0},set(u){S.schedule(s.id,u)}}),a=S.add(s.id,{onFinish(){r.current=n(),b(r,t)&&s.emitter.emit()},onResolveItem:i});return C(e)||n(),s}function q(e,t){if(e==t)return!0;if(typeof e!="object"||e==null||typeof t!="object"||t==null)return!1;if(V(e)&&V(t)){if(e.size!==t.size)return!1;for(let[o,i]of e)if(!Object.is(i,t.get(o)))return!1;return!0}if(P(e)&&P(t)){if(e.size!==t.size)return!1;for(let o of e)if(!t.has(o))return!1;return!0}if(O(e)&&O(t)){if(e.length!==t.length)return!1;for(let[o,i]of e.entries())if(!Object.is(i,t[o]))return!1;return!0}let r=Object.keys(e),n=Object.keys(t);if(r.length!==n.length)return!1;for(let o of r)if(!Object.prototype.hasOwnProperty.call(t,o)||!Object.is(e[o],t[o]))return!1;return!0}
|
package/esm/create-state.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{select as u}from"./select";import{useValue as l}from"./use-value";import{createEmitter as S}from"./utils/create-emitter";import{isEqualBase as c}from"./utils/is";let
|
|
1
|
+
import{select as u}from"./select";import{useValue as l}from"./use-value";import{createEmitter as S}from"./utils/create-emitter";import{isEqualBase as c,isPromise as m}from"./utils/is";let d=0;function f(){return d++}function g(i){const{get:r,destroy:n,set:a}=i,o=!!a,t=function(e){return l(t,e)};return t.isSet=o,t.id=f(),t.emitter=S(r),t.destroy=n,t.listen=function(e){return this.emitter.subscribe(()=>{const s=r();m(s)||e(r())})},t.withName=function(e){return this.stateName=e,this},t.select=function(e,s=c){return u([t],e,s)},t.get=r,t.set=a,t}export{g as createState};
|
package/esm/use-value.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{useDebugValue as
|
|
1
|
+
import{useDebugValue as r,useSyncExternalStore as o}from"react";import{EMPTY_SELECTOR as a}from"./types";import{isError as s,isPromise as S}from"./utils/is";function d(i,n=a){const{emitter:e}=i,t=o(i.emitter.subscribe,()=>n(e.getSnapshot()),()=>n(e.getInitialSnapshot?e.getInitialSnapshot():e.getSnapshot()));if(r(t),S(t)||s(t))throw t;return t}export{d as useValue};
|
package/package.json
CHANGED
package/src/create-state.ts
CHANGED
|
@@ -2,7 +2,7 @@ import { select } from './select'
|
|
|
2
2
|
import type { GetState, SetValue, State } from './types'
|
|
3
3
|
import { useValue } from './use-value'
|
|
4
4
|
import { createEmitter } from './utils/create-emitter'
|
|
5
|
-
import { isEqualBase } from './utils/is'
|
|
5
|
+
import { isEqualBase, isPromise } from './utils/is'
|
|
6
6
|
|
|
7
7
|
interface GetStateOptions<T> {
|
|
8
8
|
readonly get: () => T
|
|
@@ -33,7 +33,11 @@ export function createState<T>(options: GetStateOptions<T>): FullState<T> {
|
|
|
33
33
|
state.destroy = destroy
|
|
34
34
|
state.listen = function (listener) {
|
|
35
35
|
return this.emitter.subscribe(() => {
|
|
36
|
-
|
|
36
|
+
const value = get()
|
|
37
|
+
if (isPromise(value)) {
|
|
38
|
+
return
|
|
39
|
+
}
|
|
40
|
+
listener(get() as Awaited<T>)
|
|
37
41
|
})
|
|
38
42
|
}
|
|
39
43
|
state.withName = function (name) {
|
package/src/types.ts
CHANGED
|
@@ -14,7 +14,7 @@ export interface Cache<T> {
|
|
|
14
14
|
export const EMPTY_SELECTOR = <T, S>(stateValue: T) => stateValue as unknown as S
|
|
15
15
|
|
|
16
16
|
export interface GetState<T> {
|
|
17
|
-
<S>(selector?: (stateValue: T) => S): undefined extends S ? T : S
|
|
17
|
+
<S>(selector?: (stateValue: T) => S): Awaited<undefined extends S ? T : S>
|
|
18
18
|
/**
|
|
19
19
|
* Get the cached state value.
|
|
20
20
|
*/
|
|
@@ -30,7 +30,7 @@ export interface GetState<T> {
|
|
|
30
30
|
/**
|
|
31
31
|
* Listen to changes in the state.
|
|
32
32
|
*/
|
|
33
|
-
listen: Listener<T
|
|
33
|
+
listen: Listener<Awaited<T>>
|
|
34
34
|
/**
|
|
35
35
|
* Destroy / cleanup the state.
|
|
36
36
|
* Clean all listeners and make cache value undefined.
|
package/src/use-value.ts
CHANGED
|
@@ -2,7 +2,10 @@ import { useDebugValue, useSyncExternalStore } from 'react'
|
|
|
2
2
|
import { EMPTY_SELECTOR, type GetState } from './types'
|
|
3
3
|
import { isError, isPromise } from './utils/is'
|
|
4
4
|
|
|
5
|
-
export function useValue<T, S>(
|
|
5
|
+
export function useValue<T, S>(
|
|
6
|
+
state: GetState<T>,
|
|
7
|
+
selector: (stateValue: T) => S = EMPTY_SELECTOR,
|
|
8
|
+
): Awaited<undefined extends S ? T : S> {
|
|
6
9
|
const { emitter } = state
|
|
7
10
|
const value = useSyncExternalStore<S>(
|
|
8
11
|
state.emitter.subscribe,
|
|
@@ -18,5 +21,5 @@ export function useValue<T, S>(state: GetState<T>, selector: (stateValue: T) =>
|
|
|
18
21
|
throw value
|
|
19
22
|
}
|
|
20
23
|
|
|
21
|
-
return value as undefined extends S ? T : S
|
|
24
|
+
return value as Awaited<undefined extends S ? T : S>
|
|
22
25
|
}
|
package/types/types.d.ts
CHANGED
|
@@ -11,7 +11,7 @@ export interface Cache<T> {
|
|
|
11
11
|
}
|
|
12
12
|
export declare const EMPTY_SELECTOR: <T, S>(stateValue: T) => S;
|
|
13
13
|
export interface GetState<T> {
|
|
14
|
-
<S>(selector?: (stateValue: T) => S): undefined extends S ? T : S
|
|
14
|
+
<S>(selector?: (stateValue: T) => S): Awaited<undefined extends S ? T : S>;
|
|
15
15
|
/**
|
|
16
16
|
* Get the cached state value.
|
|
17
17
|
*/
|
|
@@ -27,7 +27,7 @@ export interface GetState<T> {
|
|
|
27
27
|
/**
|
|
28
28
|
* Listen to changes in the state.
|
|
29
29
|
*/
|
|
30
|
-
listen: Listener<T
|
|
30
|
+
listen: Listener<Awaited<T>>;
|
|
31
31
|
/**
|
|
32
32
|
* Destroy / cleanup the state.
|
|
33
33
|
* Clean all listeners and make cache value undefined.
|
package/types/use-value.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import { type GetState } from './types';
|
|
2
|
-
export declare function useValue<T, S>(state: GetState<T>, selector?: (stateValue: T) => S): undefined extends S ? T : S
|
|
2
|
+
export declare function useValue<T, S>(state: GetState<T>, selector?: (stateValue: T) => S): Awaited<undefined extends S ? T : S>;
|