ctx-core 6.8.3 → 7.0.1
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/all/be_/index.d.ts +24 -0
- package/all/be_/index.js +28 -0
- package/all/be_/index.test.ts +26 -0
- package/all/be_lock_memosig_triple/index.d.ts +7 -8
- package/all/be_lock_memosig_triple/index.js +20 -17
- package/all/be_lock_memosig_triple/index.test.ts +100 -86
- package/all/be_memo_pair/index.d.ts +7 -8
- package/all/be_memo_pair/index.js +22 -20
- package/all/be_memo_pair/index.test.ts +114 -97
- package/all/be_memosig_triple/index.d.ts +7 -8
- package/all/be_memosig_triple/index.test.ts +115 -100
- package/all/be_sig_triple/index.d.ts +7 -8
- package/all/be_sig_triple/index.js +20 -17
- package/all/be_sig_triple/index.test.ts +63 -52
- package/all/event_log/index.js +11 -9
- package/all/is_development/index.js +6 -5
- package/all/is_production/index.js +6 -5
- package/all/is_staging/index.js +5 -4
- package/all/rmemo/index.d.ts +44 -30
- package/all/rmemo/index.js +88 -94
- package/all/rmemo/index.test.ts +131 -115
- package/all/rmemo__wait/index.test.ts +2 -2
- package/all/wanimato/index.js +12 -12
- package/package.json +7 -7
package/all/rmemo/index.test.ts
CHANGED
|
@@ -19,14 +19,14 @@ import {
|
|
|
19
19
|
} from './index.js'
|
|
20
20
|
test('memo_|static value', ()=>{
|
|
21
21
|
let count = 0
|
|
22
|
-
const memo = memo_(()=>{
|
|
22
|
+
const memo$ = memo_(()=>{
|
|
23
23
|
count++
|
|
24
24
|
return 'rmemo-value'
|
|
25
25
|
})
|
|
26
26
|
equal(count, 0)
|
|
27
|
-
equal(memo(), 'rmemo-value')
|
|
27
|
+
equal(memo$(), 'rmemo-value')
|
|
28
28
|
equal(count, 1)
|
|
29
|
-
equal(memo(), 'rmemo-value')
|
|
29
|
+
equal(memo$(), 'rmemo-value')
|
|
30
30
|
equal(count, 1)
|
|
31
31
|
})
|
|
32
32
|
test('memo_|def function|rmemo argument', ()=>{
|
|
@@ -38,17 +38,17 @@ test('memo_|def function|rmemo argument', ()=>{
|
|
|
38
38
|
equal(memo(), 'custom_val0-val0')
|
|
39
39
|
memo.custom = 'custom_val1'
|
|
40
40
|
equal(memo(), 'custom_val0-val0')
|
|
41
|
-
sig.
|
|
41
|
+
sig.set('val1')
|
|
42
42
|
equal(memo(), 'custom_val1-val1')
|
|
43
43
|
})
|
|
44
44
|
test('memo_|side effect', ()=>{
|
|
45
45
|
const history:string[] = []
|
|
46
46
|
const s = sig_('This')
|
|
47
47
|
memo_(()=>history.push(s()))()
|
|
48
|
-
s.
|
|
49
|
-
s.
|
|
50
|
-
s.
|
|
51
|
-
s.
|
|
48
|
+
s.set('is')
|
|
49
|
+
s.set('a')
|
|
50
|
+
s.set('test')
|
|
51
|
+
s.set('test')
|
|
52
52
|
equal(history, ['This', 'is', 'a', 'test'])
|
|
53
53
|
})
|
|
54
54
|
test('memo_|undefined', ()=>{
|
|
@@ -73,33 +73,33 @@ test('memo_|conditional', ()=>{
|
|
|
73
73
|
const sum$ = memo_(()=>(++trigger_count, cond$() ? a$() + b$() : c$() + d$()))
|
|
74
74
|
equal(sum$(), 3)
|
|
75
75
|
equal(trigger_count, 1)
|
|
76
|
-
a$.
|
|
76
|
+
a$.set(11)
|
|
77
77
|
equal(sum$(), 13)
|
|
78
78
|
equal(trigger_count, 2)
|
|
79
|
-
b$.
|
|
79
|
+
b$.set(12)
|
|
80
80
|
equal(sum$(), 23)
|
|
81
81
|
equal(trigger_count, 3)
|
|
82
82
|
// Changing c$ or d$ won't triggered the effect as they're not its current dependencies
|
|
83
|
-
c$.
|
|
83
|
+
c$.set(13)
|
|
84
84
|
equal(sum$(), 23)
|
|
85
85
|
equal(trigger_count, 3)
|
|
86
|
-
d$.
|
|
86
|
+
d$.set(14)
|
|
87
87
|
equal(sum$(), 23)
|
|
88
88
|
equal(trigger_count, 3)
|
|
89
|
-
cond$.
|
|
89
|
+
cond$.set(false)
|
|
90
90
|
equal(sum$(), 27)
|
|
91
91
|
equal(trigger_count, 4)
|
|
92
|
-
c$.
|
|
92
|
+
c$.set(23)
|
|
93
93
|
equal(sum$(), 37)
|
|
94
94
|
equal(trigger_count, 5)
|
|
95
|
-
d$.
|
|
95
|
+
d$.set(24)
|
|
96
96
|
equal(sum$(), 47)
|
|
97
97
|
equal(trigger_count, 6)
|
|
98
98
|
// Changing a$ or b$ won't triggered the effect as they're not its current dependencies
|
|
99
|
-
a$.
|
|
99
|
+
a$.set(21)
|
|
100
100
|
equal(sum$(), 47)
|
|
101
101
|
equal(trigger_count, 6)
|
|
102
|
-
b$.
|
|
102
|
+
b$.set(22)
|
|
103
103
|
equal(sum$(), 47)
|
|
104
104
|
equal(trigger_count, 6)
|
|
105
105
|
})
|
|
@@ -109,20 +109,20 @@ test('memosig_', ()=>{
|
|
|
109
109
|
// TODO: Jetbrains or Typescript type inference is wrong without generic
|
|
110
110
|
const selected_index$ = memosig_<number>(()=>(items$(), 0))
|
|
111
111
|
const selected_item$ = memo_(()=>items$()[selected_index$()])
|
|
112
|
-
num_items$.
|
|
112
|
+
num_items$.set(3)
|
|
113
113
|
equal(num_items$(), 3)
|
|
114
114
|
equal(items$().join(','), 'Item 1,Item 2,Item 3')
|
|
115
115
|
equal(selected_index$(), 0)
|
|
116
116
|
equal(selected_item$(), 'Item 1')
|
|
117
|
-
selected_index$.
|
|
117
|
+
selected_index$.set(2)
|
|
118
118
|
equal(selected_index$(), 2)
|
|
119
119
|
equal(selected_item$(), 'Item 3')
|
|
120
|
-
num_items$.
|
|
120
|
+
num_items$.set(5)
|
|
121
121
|
equal(num_items$(), 5)
|
|
122
122
|
equal(items$().join(','), 'Item 1,Item 2,Item 3,Item 4,Item 5')
|
|
123
123
|
equal(selected_index$(), 0)
|
|
124
124
|
equal(selected_item$(), 'Item 1')
|
|
125
|
-
selected_index$.
|
|
125
|
+
selected_index$.set(3)
|
|
126
126
|
equal(selected_index$(), 3)
|
|
127
127
|
equal(selected_item$(), 'Item 4')
|
|
128
128
|
})
|
|
@@ -132,15 +132,15 @@ test('lock_memosig_', ()=>{
|
|
|
132
132
|
// TODO: Jetbrains or Typescript type inference is wrong without generic
|
|
133
133
|
const selected_index$ = lock_memosig_<number>(()=>(items$(), 0))
|
|
134
134
|
const selected_item$ = memo_(()=>items$()[selected_index$()])
|
|
135
|
-
num_items$.
|
|
135
|
+
num_items$.set(3)
|
|
136
136
|
equal(num_items$(), 3)
|
|
137
137
|
equal(items$().join(','), 'Item 1,Item 2,Item 3')
|
|
138
138
|
equal(selected_index$(), 0)
|
|
139
139
|
equal(selected_item$(), 'Item 1')
|
|
140
|
-
selected_index$.
|
|
140
|
+
selected_index$.set(2)
|
|
141
141
|
equal(selected_index$(), 2)
|
|
142
142
|
equal(selected_item$(), 'Item 3')
|
|
143
|
-
num_items$.
|
|
143
|
+
num_items$.set(5)
|
|
144
144
|
equal(num_items$(), 5)
|
|
145
145
|
equal(selected_index$(), 2)
|
|
146
146
|
})
|
|
@@ -161,7 +161,7 @@ test('memo_|error|case 2', ()=>{
|
|
|
161
161
|
equal(r1(), 2)
|
|
162
162
|
equal(r2(), 1)
|
|
163
163
|
equal(r3(), 1)
|
|
164
|
-
rw0.
|
|
164
|
+
rw0.set(3)
|
|
165
165
|
equal(r1(), 6)
|
|
166
166
|
// r2() keeps it's old value of 1 due to error
|
|
167
167
|
equal(r2(), 1)
|
|
@@ -170,12 +170,12 @@ test('memo_|error|case 2', ()=>{
|
|
|
170
170
|
test('sig_', ()=>{
|
|
171
171
|
const sig = sig_('val0')
|
|
172
172
|
equal(sig(), 'val0')
|
|
173
|
-
sig.
|
|
173
|
+
sig.set('val1')
|
|
174
174
|
equal(sig(), 'val1')
|
|
175
175
|
})
|
|
176
176
|
test('sig_|set before read', ()=>{
|
|
177
177
|
const sig = sig_('val0')
|
|
178
|
-
sig.
|
|
178
|
+
sig.set('val1')
|
|
179
179
|
equal(sig(), 'val1')
|
|
180
180
|
})
|
|
181
181
|
test('sig_|undefined', ()=>{
|
|
@@ -188,12 +188,14 @@ test('rmemo|add|has strong reference to the return value', ()=>{
|
|
|
188
188
|
const add_arg_aa:[sig_T<number|undefined>, number|undefined][] = []
|
|
189
189
|
let memo:memo_T<number>|undefined
|
|
190
190
|
const num$ = sig_<number|undefined>(
|
|
191
|
-
undefined
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
191
|
+
undefined,
|
|
192
|
+
[
|
|
193
|
+
sig=>
|
|
194
|
+
memo = memo_<number>(memo=>{
|
|
195
|
+
add_arg_aa.push([sig, memo.val])
|
|
196
|
+
return 99
|
|
197
|
+
})
|
|
198
|
+
])
|
|
197
199
|
equal(num$.a, undefined)
|
|
198
200
|
equal(add_arg_aa, [])
|
|
199
201
|
equal(num$(), undefined)
|
|
@@ -206,15 +208,17 @@ test('rmemo|add|notified if sig is set before read', ()=>{
|
|
|
206
208
|
let count = 0
|
|
207
209
|
let add__num:number|undefined = undefined
|
|
208
210
|
const num$ = sig_<number|undefined>(
|
|
209
|
-
undefined
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
211
|
+
undefined,
|
|
212
|
+
[
|
|
213
|
+
num$=>
|
|
214
|
+
memo_(()=>{
|
|
215
|
+
count++
|
|
216
|
+
add__num = num$()
|
|
217
|
+
})
|
|
218
|
+
])
|
|
215
219
|
equal(count, 0)
|
|
216
220
|
equal(add__num, undefined)
|
|
217
|
-
num$.
|
|
221
|
+
num$.set(1)
|
|
218
222
|
equal(count, 1)
|
|
219
223
|
equal(add__num, 1)
|
|
220
224
|
num$()
|
|
@@ -225,37 +229,43 @@ test('rmemo_|add|sets sig', ()=>{
|
|
|
225
229
|
const base$ = sig_(0)
|
|
226
230
|
let count = 0
|
|
227
231
|
const num$ = sig_(
|
|
228
|
-
0
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
232
|
+
0,
|
|
233
|
+
[
|
|
234
|
+
num$=>
|
|
235
|
+
memo_(()=>{
|
|
236
|
+
count++
|
|
237
|
+
num$.set(base$() + 1)
|
|
238
|
+
})
|
|
239
|
+
])
|
|
234
240
|
equal(count, 0)
|
|
235
241
|
equal(num$(), 1)
|
|
236
242
|
equal(count, 1)
|
|
237
|
-
base$.
|
|
243
|
+
base$.set(5)
|
|
238
244
|
equal(num$(), 6)
|
|
239
245
|
equal(count, 2)
|
|
240
246
|
})
|
|
241
247
|
test('rmemo|add|nullish', ()=>{
|
|
242
248
|
let add_undefined_count = 0
|
|
243
249
|
const add_undefined_num$ = sig_(
|
|
244
|
-
0
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
250
|
+
0,
|
|
251
|
+
[
|
|
252
|
+
()=>{
|
|
253
|
+
add_undefined_count++
|
|
254
|
+
return undefined
|
|
255
|
+
}
|
|
256
|
+
])
|
|
249
257
|
equal(add_undefined_count, 0)
|
|
250
258
|
equal(add_undefined_num$(), 0)
|
|
251
259
|
equal(add_undefined_count, 1)
|
|
252
260
|
let add_null_count = 0
|
|
253
261
|
const add_null_num$ = sig_(
|
|
254
|
-
0
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
262
|
+
0,
|
|
263
|
+
[
|
|
264
|
+
()=>{
|
|
265
|
+
add_null_count++
|
|
266
|
+
return null
|
|
267
|
+
}
|
|
268
|
+
])
|
|
259
269
|
equal(add_null_count, 0)
|
|
260
270
|
equal(add_null_num$(), 0)
|
|
261
271
|
equal(add_null_count, 1)
|
|
@@ -267,13 +277,15 @@ test('sig_|async add|case 1', async ()=>{
|
|
|
267
277
|
const id$ = sig_('id-0')
|
|
268
278
|
let count = 0
|
|
269
279
|
const user$ = sig_<{ id:string }|null>(
|
|
270
|
-
null
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
280
|
+
null,
|
|
281
|
+
[
|
|
282
|
+
(_user$)=>memo_(async ()=>{
|
|
283
|
+
count++
|
|
284
|
+
id$()
|
|
285
|
+
const user:{ id:string } = await new Promise(_resolve=>resolve = _resolve)
|
|
286
|
+
_user$.set(user)
|
|
287
|
+
})
|
|
288
|
+
])
|
|
277
289
|
equal(count, 0)
|
|
278
290
|
equal(user$(), null)
|
|
279
291
|
equal(count, 1)
|
|
@@ -282,7 +294,7 @@ test('sig_|async add|case 1', async ()=>{
|
|
|
282
294
|
equal(count, 1)
|
|
283
295
|
equal(user$(), user0)
|
|
284
296
|
equal(count, 1)
|
|
285
|
-
id$.
|
|
297
|
+
id$.set('id-1')
|
|
286
298
|
equal(count, 2)
|
|
287
299
|
equal(user$(), user0)
|
|
288
300
|
resolve!(user1)
|
|
@@ -295,19 +307,21 @@ test('sig_|async add|case 2', async ()=>{
|
|
|
295
307
|
const sleepCycles = 5
|
|
296
308
|
const taskArgumentsCalls:number[][] = []
|
|
297
309
|
const sum$ = sig_<null|number>(
|
|
298
|
-
null
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
310
|
+
null,
|
|
311
|
+
[
|
|
312
|
+
sum$=>
|
|
313
|
+
memo_(async ()=>{
|
|
314
|
+
taskArgumentsCalls.push([a$(), b$()])
|
|
315
|
+
for (let i = 0; i < sleepCycles; i++) {
|
|
316
|
+
await Promise.resolve()
|
|
317
|
+
}
|
|
318
|
+
sum$.set(a$() + b$())
|
|
319
|
+
})
|
|
320
|
+
])
|
|
307
321
|
equal(sum$(), null)
|
|
308
322
|
deepStrictEqual(taskArgumentsCalls, [[1, 2]])
|
|
309
|
-
a$.
|
|
310
|
-
b$.
|
|
323
|
+
a$.set(10)
|
|
324
|
+
b$.set(20)
|
|
311
325
|
for (let i = 0; i < sleepCycles; i++) {
|
|
312
326
|
equal(sum$(), null)
|
|
313
327
|
await Promise.resolve()
|
|
@@ -337,7 +351,7 @@ test('memo_+sig_|simple graph', ()=>{
|
|
|
337
351
|
equal(dep1$(), 'base0-dep0-dep1')
|
|
338
352
|
equal(dep0$(), 'base0-dep0')
|
|
339
353
|
equal(base$(), 'base0')
|
|
340
|
-
base$.
|
|
354
|
+
base$.set('base1')
|
|
341
355
|
equal(base$(), 'base1')
|
|
342
356
|
equal(dep0$(), 'base1-dep0')
|
|
343
357
|
equal(dep1$(), 'base1-dep0-dep1')
|
|
@@ -353,13 +367,14 @@ test('prevents diamond dependency problem 1', ()=>{
|
|
|
353
367
|
const c$ = memo_(()=>a$().replace('a', 'c'))
|
|
354
368
|
const d$ = memo_(()=>a$().replace('a', 'd'))
|
|
355
369
|
memo_(
|
|
356
|
-
()=>`${b$()}${c$()}${d$()}
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
370
|
+
()=>`${b$()}${c$()}${d$()}`,
|
|
371
|
+
[
|
|
372
|
+
combined$=>
|
|
373
|
+
memo_(()=>values.push(combined$()))
|
|
374
|
+
])()
|
|
360
375
|
deepStrictEqual(values, ['b0c0d0'])
|
|
361
|
-
store$.
|
|
362
|
-
store$.
|
|
376
|
+
store$.set(1)
|
|
377
|
+
store$.set(2)
|
|
363
378
|
deepStrictEqual(values, ['b0c0d0', 'b1c1d1', 'b2c2d2'])
|
|
364
379
|
})
|
|
365
380
|
test('prevents diamond dependency problem 2', ()=>{
|
|
@@ -371,12 +386,12 @@ test('prevents diamond dependency problem 2', ()=>{
|
|
|
371
386
|
const d$ = memo_(()=>c$().replace('c', 'd'))
|
|
372
387
|
const e$ = memo_(()=>d$().replace('d', 'e'))
|
|
373
388
|
memo_<string>(
|
|
374
|
-
()=>[a$(), e$()].join('')
|
|
375
|
-
|
|
389
|
+
()=>[a$(), e$()].join(''),
|
|
390
|
+
[$=>
|
|
376
391
|
memo_(()=>values.push($()))
|
|
377
|
-
)()
|
|
392
|
+
])()
|
|
378
393
|
deepStrictEqual(values, ['a0e0'])
|
|
379
|
-
store$.
|
|
394
|
+
store$.set(1)
|
|
380
395
|
deepStrictEqual(values, ['a0e0', 'a1e1'])
|
|
381
396
|
})
|
|
382
397
|
test('prevents diamond dependency problem 3', ()=>{
|
|
@@ -387,12 +402,12 @@ test('prevents diamond dependency problem 3', ()=>{
|
|
|
387
402
|
const c$ = memo_(()=>b$().replace('b', 'c'))
|
|
388
403
|
const d$ = memo_(()=>c$().replace('c', 'd'))
|
|
389
404
|
memo_<string>(
|
|
390
|
-
()=>`${a$()}${b$()}${c$()}${d$()}
|
|
391
|
-
|
|
405
|
+
()=>`${a$()}${b$()}${c$()}${d$()}`,
|
|
406
|
+
[combined$=>
|
|
392
407
|
memo_(()=>values.push(combined$()))
|
|
393
|
-
)()
|
|
408
|
+
])()
|
|
394
409
|
deepStrictEqual(values, ['a0b0c0d0'])
|
|
395
|
-
store$.
|
|
410
|
+
store$.set(1)
|
|
396
411
|
deepStrictEqual(values, ['a0b0c0d0', 'a1b1c1d1'])
|
|
397
412
|
})
|
|
398
413
|
test('autosubscribe: prevents diamond dependency problem 4 (complex)', ()=>{
|
|
@@ -407,18 +422,18 @@ test('autosubscribe: prevents diamond dependency problem 4 (complex)', ()=>{
|
|
|
407
422
|
const f$ = memo_(()=>`f${e$()}`)
|
|
408
423
|
const g$ = memo_(()=>`g${f$()}`)
|
|
409
424
|
memo_(
|
|
410
|
-
()=>e$()
|
|
411
|
-
|
|
425
|
+
()=>e$(),
|
|
426
|
+
[combined1$=>
|
|
412
427
|
memo_(()=>values.push(combined1$()))
|
|
413
|
-
)()
|
|
428
|
+
])()
|
|
414
429
|
memo_(
|
|
415
|
-
()=>[e$(), g$()].join('')
|
|
416
|
-
|
|
430
|
+
()=>[e$(), g$()].join(''),
|
|
431
|
+
[combined2$=>
|
|
417
432
|
memo_(()=>values.push(combined2$()))
|
|
418
|
-
)()
|
|
433
|
+
])()
|
|
419
434
|
deepStrictEqual(values, ['eca0b0da0', 'eca0b0da0gfeca0b0da0'])
|
|
420
|
-
store1$.
|
|
421
|
-
store2$.
|
|
435
|
+
store1$.set(1)
|
|
436
|
+
store2$.set(2)
|
|
422
437
|
deepStrictEqual(values, [
|
|
423
438
|
'eca0b0da0',
|
|
424
439
|
'eca0b0da0gfeca0b0da0',
|
|
@@ -447,10 +462,10 @@ test('prevents diamond dependency problem 5', ()=>{
|
|
|
447
462
|
equal(events, '')
|
|
448
463
|
equal(displayName$(), 'John Doe')
|
|
449
464
|
equal(events, 'display short full ')
|
|
450
|
-
firstName$.
|
|
465
|
+
firstName$.set('Benedict')
|
|
451
466
|
equal(displayName$(), 'Benedict Doe')
|
|
452
467
|
equal(events, 'display short full short full display ')
|
|
453
|
-
firstName$.
|
|
468
|
+
firstName$.set('Montgomery')
|
|
454
469
|
equal(displayName$(), 'Montgomery')
|
|
455
470
|
equal(events, 'display short full short full display short full display ')
|
|
456
471
|
})
|
|
@@ -462,12 +477,12 @@ test('prevents diamond dependency problem 6', ()=>{
|
|
|
462
477
|
const b$ = memo_(()=>`b${store2$()}`)
|
|
463
478
|
const c$ = memo_(()=>b$().replace('b', 'c'))
|
|
464
479
|
memo_(
|
|
465
|
-
()=>`${a$()}${c$()}
|
|
466
|
-
|
|
480
|
+
()=>`${a$()}${c$()}`,
|
|
481
|
+
[combined$=>
|
|
467
482
|
memo_(()=>values.push(combined$()))
|
|
468
|
-
)()
|
|
483
|
+
])()
|
|
469
484
|
deepStrictEqual(values, ['a0c0'])
|
|
470
|
-
store1$.
|
|
485
|
+
store1$.set(1)
|
|
471
486
|
deepStrictEqual(values, ['a0c0', 'a1c0'])
|
|
472
487
|
})
|
|
473
488
|
test('prevents dependency listeners from being out of order', ()=>{
|
|
@@ -477,13 +492,14 @@ test('prevents dependency listeners from being out of order', ()=>{
|
|
|
477
492
|
})
|
|
478
493
|
const values:string[] = []
|
|
479
494
|
const b$ = memo_(
|
|
480
|
-
()=>`${a$()}b
|
|
481
|
-
|
|
482
|
-
memo_(()=>values.push(b$()))
|
|
495
|
+
()=>`${a$()}b`,
|
|
496
|
+
[b$=>
|
|
497
|
+
memo_(()=>values.push(b$()))
|
|
498
|
+
])
|
|
483
499
|
equal(b$(), '0ab')
|
|
484
500
|
deepStrictEqual(values, ['0ab'])
|
|
485
501
|
equal(a$(), '0a')
|
|
486
|
-
base$.
|
|
502
|
+
base$.set(1)
|
|
487
503
|
deepStrictEqual(values, ['0ab', '1ab'])
|
|
488
504
|
})
|
|
489
505
|
test('computes initial value when argument is undefined', ()=>{
|
|
@@ -498,7 +514,7 @@ test('memo__bind', ()=>{
|
|
|
498
514
|
const bind_memo$ = bind_fn.memo_(bind_fn)
|
|
499
515
|
equal(bind_fn(), 11)
|
|
500
516
|
equal(bind_memo$(), 11)
|
|
501
|
-
base$.
|
|
517
|
+
base$.set(2)
|
|
502
518
|
equal(bind_fn(), 12)
|
|
503
519
|
equal(bind_memo$(), 12)
|
|
504
520
|
})
|
|
@@ -516,13 +532,13 @@ test('rmemo__on,rmemo__off__add,rmemo__off', ()=>{
|
|
|
516
532
|
})
|
|
517
533
|
equal(memo$(), 11)
|
|
518
534
|
equal(count, 1)
|
|
519
|
-
base$.
|
|
535
|
+
base$.set(2)
|
|
520
536
|
equal(memo$(), 12)
|
|
521
537
|
equal(count, 2)
|
|
522
538
|
equal(rmemo__off__add_arg_aa, [])
|
|
523
539
|
rmemo__off(memo$)
|
|
524
540
|
equal(rmemo__off__add_arg_aa, [[memo$]])
|
|
525
|
-
base$.
|
|
541
|
+
base$.set(3)
|
|
526
542
|
equal(memo$(), 12)
|
|
527
543
|
equal(count, 2)
|
|
528
544
|
equal(rmemo__off__add_arg_aa, [[memo$]])
|
|
@@ -538,7 +554,7 @@ test('rmemo__on,rmemo__off__add,rmemo__off', ()=>{
|
|
|
538
554
|
equal(rmemo__off__add_arg_aa, [[memo$], [memo$]])
|
|
539
555
|
equal(rmemo__on__off_arg_aa, [])
|
|
540
556
|
equal(count, 4)
|
|
541
|
-
base$.
|
|
557
|
+
base$.set(4)
|
|
542
558
|
equal(memo$(), 14)
|
|
543
559
|
equal(count, 5)
|
|
544
560
|
equal(rmemo__off__add_arg_aa, [[memo$], [memo$]])
|
|
@@ -559,10 +575,10 @@ test('rmemo__add', ()=>{
|
|
|
559
575
|
equal(add_arg_aa_val_aaa, [])
|
|
560
576
|
base$()
|
|
561
577
|
equal(add_arg_aa_val_aaa, [[[base$], undefined, 1]])
|
|
562
|
-
base$.
|
|
578
|
+
base$.set(2)
|
|
563
579
|
equal(add_arg_aa_val_aaa, [[[base$], undefined, 1], [[base$], 'val-1', 2]])
|
|
564
580
|
off()
|
|
565
|
-
base$.
|
|
581
|
+
base$.set(3)
|
|
566
582
|
equal(add_arg_aa_val_aaa, [[[base$], undefined, 1], [[base$], 'val-1', 2]])
|
|
567
583
|
})
|
|
568
584
|
test('rmemo__unset', ()=>{
|
|
@@ -10,7 +10,7 @@ test('rmemo__wait|rmemo', async ()=>{
|
|
|
10
10
|
10_000)
|
|
11
11
|
// equal(promise.m.t, [])
|
|
12
12
|
equal(subject$(), -1)
|
|
13
|
-
subject$.
|
|
13
|
+
subject$.set(1)
|
|
14
14
|
equal(subject$(), 1)
|
|
15
15
|
await promise
|
|
16
16
|
equal(subject$(), 1)
|
|
@@ -23,7 +23,7 @@ test('rmemo__wait|rmemolike', async ()=>{
|
|
|
23
23
|
10_000)
|
|
24
24
|
// equal(promise.m.t, [])
|
|
25
25
|
equal(subject$(), -1)
|
|
26
|
-
subject$.
|
|
26
|
+
subject$.set(1)
|
|
27
27
|
equal(subject$(), 1)
|
|
28
28
|
await promise
|
|
29
29
|
equal(subject$(), 1)
|
package/all/wanimato/index.js
CHANGED
|
@@ -8,36 +8,36 @@ export function wanimato__new($, el, animation_) {
|
|
|
8
8
|
if ($.val?.el === el) return $.val
|
|
9
9
|
let _animation = animation_(el)
|
|
10
10
|
_animation.addEventListener('finish', ()=>{
|
|
11
|
-
$.
|
|
11
|
+
$.set({
|
|
12
12
|
...$(),
|
|
13
13
|
is_finish: true,
|
|
14
14
|
finish_currentTime: $().animation.currentTime
|
|
15
|
-
}
|
|
15
|
+
})
|
|
16
16
|
})
|
|
17
17
|
_animation.addEventListener('remove', ()=>{
|
|
18
|
-
$.
|
|
18
|
+
$.set({
|
|
19
19
|
...$(),
|
|
20
20
|
is_remove: true
|
|
21
|
-
}
|
|
21
|
+
})
|
|
22
22
|
})
|
|
23
23
|
let play_state__ensure = ()=>{
|
|
24
24
|
if ($().is_play !== true || $().is_finish !== false) {
|
|
25
|
-
$.
|
|
25
|
+
$.set({
|
|
26
26
|
...$(),
|
|
27
27
|
is_play: true,
|
|
28
28
|
is_finish: false
|
|
29
|
-
}
|
|
29
|
+
})
|
|
30
30
|
}
|
|
31
31
|
}
|
|
32
32
|
let begin_state__ensure__setTimeout = ()=>{
|
|
33
33
|
setTimeout(
|
|
34
34
|
()=>{
|
|
35
35
|
if ($().is_play !== !!_animation.currentTime || $().is_finish !== false) {
|
|
36
|
-
$.
|
|
36
|
+
$.set({
|
|
37
37
|
...$(),
|
|
38
38
|
is_play: !!_animation.currentTime,
|
|
39
39
|
is_finish: false,
|
|
40
|
-
}
|
|
40
|
+
})
|
|
41
41
|
}
|
|
42
42
|
},
|
|
43
43
|
_animation.currentTime / -_animation.playbackRate)
|
|
@@ -62,21 +62,21 @@ export function wanimato__new($, el, animation_) {
|
|
|
62
62
|
finish() {
|
|
63
63
|
_animation.finish()
|
|
64
64
|
if ($().is_play !== false || $().is_finish !== !!_animation.currentTime) {
|
|
65
|
-
$.
|
|
65
|
+
$.set({
|
|
66
66
|
...$(),
|
|
67
67
|
is_play: false,
|
|
68
68
|
is_finish: !!_animation.currentTime
|
|
69
|
-
}
|
|
69
|
+
})
|
|
70
70
|
}
|
|
71
71
|
},
|
|
72
72
|
cancel() {
|
|
73
73
|
_animation.cancel()
|
|
74
74
|
if ($().is_play !== false || $().is_finish !== false) {
|
|
75
|
-
$.
|
|
75
|
+
$.set({
|
|
76
76
|
...$(),
|
|
77
77
|
is_play: false,
|
|
78
78
|
is_finish: false
|
|
79
|
-
}
|
|
79
|
+
})
|
|
80
80
|
}
|
|
81
81
|
},
|
|
82
82
|
updatePlaybackRate(playbackRate) {
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "ctx-core",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "7.0.1",
|
|
4
4
|
"description": "ctx-core core library",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"ctx-core",
|
|
@@ -346,7 +346,7 @@
|
|
|
346
346
|
"import": {
|
|
347
347
|
"./be": "{ be_ }"
|
|
348
348
|
},
|
|
349
|
-
"limit": "
|
|
349
|
+
"limit": "101 B"
|
|
350
350
|
},
|
|
351
351
|
{
|
|
352
352
|
"name": "be_ ctx_",
|
|
@@ -374,28 +374,28 @@
|
|
|
374
374
|
"import": {
|
|
375
375
|
"./rmemo": "{ memo_ }"
|
|
376
376
|
},
|
|
377
|
-
"limit": "
|
|
377
|
+
"limit": "358 B"
|
|
378
378
|
},
|
|
379
379
|
{
|
|
380
380
|
"name": "memo_ sig_",
|
|
381
381
|
"import": {
|
|
382
382
|
"./rmemo": "{ sig_, memo_ }"
|
|
383
383
|
},
|
|
384
|
-
"limit": "
|
|
384
|
+
"limit": "381 B"
|
|
385
385
|
},
|
|
386
386
|
{
|
|
387
387
|
"name": "memo_ sig_ be_ ctx_",
|
|
388
388
|
"import": {
|
|
389
389
|
"./rmemo": "{ sig_, memo_, be_, ctx_ }"
|
|
390
390
|
},
|
|
391
|
-
"limit": "
|
|
391
|
+
"limit": "476 B"
|
|
392
392
|
},
|
|
393
393
|
{
|
|
394
394
|
"name": "memo_ sig_ be_ ctx_ be_memo_pair_ be_sig_triple_",
|
|
395
395
|
"import": {
|
|
396
396
|
"./rmemo": "{ sig_, memo_, be_, ctx_, be_memo_pair_, be_sig_triple_ }"
|
|
397
397
|
},
|
|
398
|
-
"limit": "
|
|
398
|
+
"limit": "559 B"
|
|
399
399
|
},
|
|
400
400
|
{
|
|
401
401
|
"name": "class_",
|
|
@@ -430,7 +430,7 @@
|
|
|
430
430
|
"import": {
|
|
431
431
|
"./web_animation": "{ memo_, wanimato__new }"
|
|
432
432
|
},
|
|
433
|
-
"limit": "
|
|
433
|
+
"limit": "707 B"
|
|
434
434
|
}
|
|
435
435
|
],
|
|
436
436
|
"scripts": {
|