as-model 0.1.18 → 0.1.19
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 +41 -3
- package/esm/identifiers/index.js +5 -1
- package/esm/store/enhance/selector.js +3 -0
- package/esm/store/enhance/signal.js +3 -0
- package/esm/store/index.js +3 -0
- package/esm/updater/index.js +6 -1
- package/esm/updater/notifier.js +3 -1
- package/esm/updater/token.js +16 -0
- package/esm/validation/index.js +11 -2
- package/index.d.ts +8 -0
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -141,6 +141,9 @@
|
|
|
141
141
|
function modelStoreIdentifier() {
|
|
142
142
|
return true;
|
|
143
143
|
}
|
|
144
|
+
function tokenIdentifier() {
|
|
145
|
+
return true;
|
|
146
|
+
}
|
|
144
147
|
|
|
145
148
|
// src/validation/index.ts
|
|
146
149
|
var noStateAModelKey = "no-state-a-model-key";
|
|
@@ -177,11 +180,18 @@
|
|
|
177
180
|
}
|
|
178
181
|
return data.modelStoreIdentifier === modelStoreIdentifier && data.modelStoreIdentifier();
|
|
179
182
|
}
|
|
183
|
+
function isToken(data) {
|
|
184
|
+
if (!data) {
|
|
185
|
+
return false;
|
|
186
|
+
}
|
|
187
|
+
return data.tokenIdentifier === tokenIdentifier && data.tokenIdentifier();
|
|
188
|
+
}
|
|
180
189
|
var validations = {
|
|
181
190
|
isInstanceFromNoStateModel,
|
|
182
191
|
isModelKey,
|
|
183
192
|
isModelStore,
|
|
184
|
-
isModelUsage
|
|
193
|
+
isModelUsage,
|
|
194
|
+
isToken
|
|
185
195
|
};
|
|
186
196
|
|
|
187
197
|
// src/tools/proxy.ts
|
|
@@ -274,6 +284,20 @@
|
|
|
274
284
|
};
|
|
275
285
|
}
|
|
276
286
|
|
|
287
|
+
// src/updater/token.ts
|
|
288
|
+
function createToken() {
|
|
289
|
+
var value = {};
|
|
290
|
+
return {
|
|
291
|
+
isDifferent: function isDifferent(token) {
|
|
292
|
+
if (!isToken(token)) {
|
|
293
|
+
return true;
|
|
294
|
+
}
|
|
295
|
+
return token.value !== value;
|
|
296
|
+
},
|
|
297
|
+
value
|
|
298
|
+
};
|
|
299
|
+
}
|
|
300
|
+
|
|
277
301
|
// src/updater/notifier.ts
|
|
278
302
|
function defaultNotifyImplement(dispatches, action) {
|
|
279
303
|
dispatches.forEach(function(callback) {
|
|
@@ -361,7 +385,8 @@
|
|
|
361
385
|
return _object_spread_props(_object_spread({}, u), {
|
|
362
386
|
state,
|
|
363
387
|
instance: nextInstance,
|
|
364
|
-
version: u.version + 1
|
|
388
|
+
version: u.version + 1,
|
|
389
|
+
token: createToken()
|
|
365
390
|
});
|
|
366
391
|
});
|
|
367
392
|
}
|
|
@@ -580,6 +605,7 @@
|
|
|
580
605
|
var _args_model;
|
|
581
606
|
var model2 = (_args_model = args.model) !== null && _args_model !== void 0 ? _args_model : u.model;
|
|
582
607
|
var state = "state" in args ? args.state : u.state;
|
|
608
|
+
var token = createToken();
|
|
583
609
|
if (u.controlled) {
|
|
584
610
|
var instance = model2(state);
|
|
585
611
|
return _object_spread_props(_object_spread({}, u), {
|
|
@@ -601,7 +627,8 @@
|
|
|
601
627
|
model: model2,
|
|
602
628
|
state,
|
|
603
629
|
instance: instance1,
|
|
604
|
-
initialized: true
|
|
630
|
+
initialized: true,
|
|
631
|
+
token
|
|
605
632
|
}), initializedUpdater);
|
|
606
633
|
}
|
|
607
634
|
if (Object.is(u.model, model2) && Object.is(u.state, state)) {
|
|
@@ -622,6 +649,7 @@
|
|
|
622
649
|
state,
|
|
623
650
|
model: model2,
|
|
624
651
|
instance: instance2,
|
|
652
|
+
token,
|
|
625
653
|
initialized: true,
|
|
626
654
|
cacheFields: {},
|
|
627
655
|
cacheMethods: {}
|
|
@@ -639,6 +667,7 @@
|
|
|
639
667
|
var updater = _object_spread({
|
|
640
668
|
sidePayload: void 0,
|
|
641
669
|
version: 0,
|
|
670
|
+
token: createToken(),
|
|
642
671
|
isDestroyed: false,
|
|
643
672
|
model: model2,
|
|
644
673
|
instance: defaultInstance,
|
|
@@ -895,6 +924,9 @@
|
|
|
895
924
|
var storeKey = store.key;
|
|
896
925
|
return {
|
|
897
926
|
key: storeKey,
|
|
927
|
+
getToken: function getToken() {
|
|
928
|
+
return store.getToken();
|
|
929
|
+
},
|
|
898
930
|
subscribe: function subscribe(dispatcher) {
|
|
899
931
|
return store.subscribe(enhance(dispatcher));
|
|
900
932
|
},
|
|
@@ -1085,6 +1117,9 @@
|
|
|
1085
1117
|
}
|
|
1086
1118
|
return {
|
|
1087
1119
|
key: store.key,
|
|
1120
|
+
getToken: function getToken() {
|
|
1121
|
+
return store.getToken();
|
|
1122
|
+
},
|
|
1088
1123
|
subscribe: function subscribe(dispatcher) {
|
|
1089
1124
|
return store.subscribe(enhance(dispatcher));
|
|
1090
1125
|
},
|
|
@@ -1152,6 +1187,9 @@
|
|
|
1152
1187
|
};
|
|
1153
1188
|
var store = {
|
|
1154
1189
|
key,
|
|
1190
|
+
getToken: function getToken() {
|
|
1191
|
+
return updater.token;
|
|
1192
|
+
},
|
|
1155
1193
|
subscribe: function subscribe(dispatcher) {
|
|
1156
1194
|
var _updater_createTunnel = updater.createTunnel(dispatcher), connect = _updater_createTunnel.connect, disconnect = _updater_createTunnel.disconnect;
|
|
1157
1195
|
connect();
|
package/esm/identifiers/index.js
CHANGED
|
@@ -7,8 +7,12 @@ function modelUsageIdentifier() {
|
|
|
7
7
|
function modelStoreIdentifier() {
|
|
8
8
|
return true;
|
|
9
9
|
}
|
|
10
|
+
function tokenIdentifier() {
|
|
11
|
+
return true;
|
|
12
|
+
}
|
|
10
13
|
export {
|
|
11
14
|
modelKeyIdentifier,
|
|
12
15
|
modelStoreIdentifier,
|
|
13
|
-
modelUsageIdentifier
|
|
16
|
+
modelUsageIdentifier,
|
|
17
|
+
tokenIdentifier
|
|
14
18
|
};
|
package/esm/store/index.js
CHANGED
package/esm/updater/index.js
CHANGED
|
@@ -24,6 +24,7 @@ import {
|
|
|
24
24
|
createUnInitializedUpdater,
|
|
25
25
|
destroy
|
|
26
26
|
} from "./tunnel";
|
|
27
|
+
import { createToken } from "./token";
|
|
27
28
|
function createInitializedUpdater(updater, middleWare) {
|
|
28
29
|
const createTunnel = generateTunnelCreator(updater);
|
|
29
30
|
return {
|
|
@@ -37,6 +38,7 @@ function createUpdateFn(updater, middleWare) {
|
|
|
37
38
|
var _a;
|
|
38
39
|
const model = (_a = args.model) != null ? _a : u.model;
|
|
39
40
|
const state = "state" in args ? args.state : u.state;
|
|
41
|
+
const token = createToken();
|
|
40
42
|
if (u.controlled) {
|
|
41
43
|
const instance2 = model(state);
|
|
42
44
|
return __spreadProps(__spreadValues({}, u), { state, instance: instance2, model });
|
|
@@ -56,7 +58,8 @@ function createUpdateFn(updater, middleWare) {
|
|
|
56
58
|
model,
|
|
57
59
|
state,
|
|
58
60
|
instance: instance2,
|
|
59
|
-
initialized: true
|
|
61
|
+
initialized: true,
|
|
62
|
+
token
|
|
60
63
|
}), initializedUpdater);
|
|
61
64
|
}
|
|
62
65
|
if (Object.is(u.model, model) && Object.is(u.state, state)) {
|
|
@@ -77,6 +80,7 @@ function createUpdateFn(updater, middleWare) {
|
|
|
77
80
|
state,
|
|
78
81
|
model,
|
|
79
82
|
instance,
|
|
83
|
+
token,
|
|
80
84
|
initialized: true,
|
|
81
85
|
cacheFields: {},
|
|
82
86
|
cacheMethods: {}
|
|
@@ -93,6 +97,7 @@ function createUpdater(model, middleWare, config = {}) {
|
|
|
93
97
|
const updater = __spreadValues({
|
|
94
98
|
sidePayload: void 0,
|
|
95
99
|
version: 0,
|
|
100
|
+
token: createToken(),
|
|
96
101
|
isDestroyed: false,
|
|
97
102
|
model,
|
|
98
103
|
instance: defaultInstance,
|
package/esm/updater/notifier.js
CHANGED
|
@@ -18,6 +18,7 @@ var __spreadValues = (a, b) => {
|
|
|
18
18
|
};
|
|
19
19
|
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
20
20
|
import { simpleErrorProcess } from "../tools";
|
|
21
|
+
import { createToken } from "./token";
|
|
21
22
|
function defaultNotifyImplement(dispatches, action) {
|
|
22
23
|
dispatches.forEach((callback) => {
|
|
23
24
|
callback(action);
|
|
@@ -88,7 +89,8 @@ function generateNotifier(updater, middleWare) {
|
|
|
88
89
|
updater.mutate((u) => __spreadProps(__spreadValues({}, u), {
|
|
89
90
|
state,
|
|
90
91
|
instance: nextInstance,
|
|
91
|
-
version: u.version + 1
|
|
92
|
+
version: u.version + 1,
|
|
93
|
+
token: createToken()
|
|
92
94
|
}));
|
|
93
95
|
}
|
|
94
96
|
const notifyAction = function notifyAction2(act) {
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { isToken } from "../validation";
|
|
2
|
+
function createToken() {
|
|
3
|
+
const value = {};
|
|
4
|
+
return {
|
|
5
|
+
isDifferent(token) {
|
|
6
|
+
if (!isToken(token)) {
|
|
7
|
+
return true;
|
|
8
|
+
}
|
|
9
|
+
return token.value !== value;
|
|
10
|
+
},
|
|
11
|
+
value
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
export {
|
|
15
|
+
createToken
|
|
16
|
+
};
|
package/esm/validation/index.js
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import {
|
|
2
2
|
modelKeyIdentifier,
|
|
3
3
|
modelStoreIdentifier,
|
|
4
|
-
modelUsageIdentifier
|
|
4
|
+
modelUsageIdentifier,
|
|
5
|
+
tokenIdentifier
|
|
5
6
|
} from "../identifiers";
|
|
6
7
|
const noStateAModelKey = "no-state-a-model-key";
|
|
7
8
|
function createNoStateModel() {
|
|
@@ -39,16 +40,24 @@ function isModelStore(data) {
|
|
|
39
40
|
}
|
|
40
41
|
return data.modelStoreIdentifier === modelStoreIdentifier && data.modelStoreIdentifier();
|
|
41
42
|
}
|
|
43
|
+
function isToken(data) {
|
|
44
|
+
if (!data) {
|
|
45
|
+
return false;
|
|
46
|
+
}
|
|
47
|
+
return data.tokenIdentifier === tokenIdentifier && data.tokenIdentifier();
|
|
48
|
+
}
|
|
42
49
|
const validations = {
|
|
43
50
|
isInstanceFromNoStateModel,
|
|
44
51
|
isModelKey,
|
|
45
52
|
isModelStore,
|
|
46
|
-
isModelUsage
|
|
53
|
+
isModelUsage,
|
|
54
|
+
isToken
|
|
47
55
|
};
|
|
48
56
|
export {
|
|
49
57
|
createNoStateModel,
|
|
50
58
|
isModelKey,
|
|
51
59
|
isModelStore,
|
|
52
60
|
isModelUsage,
|
|
61
|
+
isToken,
|
|
53
62
|
validations
|
|
54
63
|
};
|
package/index.d.ts
CHANGED
|
@@ -41,6 +41,11 @@ export declare type Action<S = any, T extends ModelInstance = ModelInstance> = {
|
|
|
41
41
|
prevInstance?: T;
|
|
42
42
|
};
|
|
43
43
|
|
|
44
|
+
export interface Token {
|
|
45
|
+
isDifferent: (token: Token) => boolean;
|
|
46
|
+
value: unknown;
|
|
47
|
+
}
|
|
48
|
+
|
|
44
49
|
export declare type Dispatch = (action: Action) => any;
|
|
45
50
|
|
|
46
51
|
export declare interface Key<
|
|
@@ -93,6 +98,7 @@ export declare interface Store<
|
|
|
93
98
|
R extends (instance: () => T) => any = (instance: () => T) => T
|
|
94
99
|
> extends StoreIndex<S, T, R> {
|
|
95
100
|
subscribe: (dispatcher: Dispatch) => () => void;
|
|
101
|
+
getToken: () => Token;
|
|
96
102
|
getInstance: () => T;
|
|
97
103
|
update: (args?: { model?: Model<S, T>; initialState?: S; state?: S }) => void;
|
|
98
104
|
destroy: () => void;
|
|
@@ -195,6 +201,7 @@ declare interface SignalStore<
|
|
|
195
201
|
T extends ModelInstance = any,
|
|
196
202
|
R extends (instance: () => T) => any = (instance: () => T) => any
|
|
197
203
|
> extends StoreIndex<S, T, R> {
|
|
204
|
+
getToken: () => Token;
|
|
198
205
|
subscribe: (dispatcher: Dispatch) => () => void;
|
|
199
206
|
getSignal: () => {
|
|
200
207
|
(): T;
|
|
@@ -230,6 +237,7 @@ declare interface SelectorStore<
|
|
|
230
237
|
T extends ModelInstance = any,
|
|
231
238
|
R extends (instance: () => T) => any = (instance: () => T) => any
|
|
232
239
|
> extends StoreIndex<S, T, R> {
|
|
240
|
+
getToken: () => Token;
|
|
233
241
|
subscribe: (dispatcher: Dispatch) => () => void;
|
|
234
242
|
select: SelectMethod<T, R>;
|
|
235
243
|
}
|