@esportsplus/template 0.22.5 → 0.23.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/build/attributes.js +20 -39
- package/build/slot/effect.d.ts +2 -2
- package/build/slot/effect.js +15 -3
- package/package.json +1 -1
- package/src/attributes.ts +25 -54
- package/src/slot/effect.ts +29 -13
- package/src/slot/index.ts +1 -1
package/build/attributes.js
CHANGED
|
@@ -27,52 +27,33 @@ function apply(element, name, value) {
|
|
|
27
27
|
function context(element) {
|
|
28
28
|
return (element[STORE] ??= { element });
|
|
29
29
|
}
|
|
30
|
-
function list(ctx, element, id, name,
|
|
30
|
+
function list(ctx, element, id, name, state, value) {
|
|
31
31
|
if (value == null || value === false || value === '') {
|
|
32
32
|
value = '';
|
|
33
33
|
}
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
34
|
+
if (!value || typeof value !== 'string') {
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
let delimiter = delimiters[name], store = (ctx ??= context(element)).store ??= {}, v = store[name];
|
|
38
|
+
if (v === undefined) {
|
|
39
|
+
v = store[name] = (element.getAttribute(name) || '').trim();
|
|
39
40
|
}
|
|
40
41
|
if (id === null) {
|
|
41
|
-
|
|
42
|
-
store[base] += (store[base] ? delimiter : '') + value;
|
|
43
|
-
}
|
|
42
|
+
v = store[name] += (v ? delimiter : '') + value;
|
|
44
43
|
}
|
|
45
44
|
else {
|
|
46
|
-
let
|
|
47
|
-
if (
|
|
48
|
-
|
|
49
|
-
for (let i = 0, n = parts.length; i < n; i++) {
|
|
50
|
-
part = parts[i].trim();
|
|
51
|
-
if (part === '') {
|
|
52
|
-
continue;
|
|
53
|
-
}
|
|
54
|
-
dynamic[part] = null;
|
|
55
|
-
hot[part] = null;
|
|
56
|
-
}
|
|
45
|
+
let current = delimiter + value, previous = store[id];
|
|
46
|
+
if (previous === undefined) {
|
|
47
|
+
v = store[name] += current;
|
|
57
48
|
}
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
for (let part in cold) {
|
|
61
|
-
if (part in hot) {
|
|
62
|
-
continue;
|
|
63
|
-
}
|
|
64
|
-
delete dynamic[part];
|
|
65
|
-
}
|
|
49
|
+
else if (previous !== current) {
|
|
50
|
+
v = store[name] = store[name].replace(previous, current);
|
|
66
51
|
}
|
|
67
|
-
store[id] =
|
|
52
|
+
store[id] = current;
|
|
68
53
|
}
|
|
69
|
-
|
|
70
|
-
for (let key in dynamic) {
|
|
71
|
-
value += (value ? delimiter : '') + key;
|
|
72
|
-
}
|
|
73
|
-
schedule(ctx, element, name, state, value);
|
|
54
|
+
schedule(ctx, element, name, state, v);
|
|
74
55
|
}
|
|
75
|
-
function property(ctx, element, id, name,
|
|
56
|
+
function property(ctx, element, id, name, state, value) {
|
|
76
57
|
if (value == null || value === false || value === '') {
|
|
77
58
|
value = '';
|
|
78
59
|
}
|
|
@@ -137,9 +118,9 @@ const set = (element, name, value, state = STATE_HYDRATING) => {
|
|
|
137
118
|
else if (isArray(v)) {
|
|
138
119
|
let last = v.length - 1;
|
|
139
120
|
for (let i = 0, n = v.length; i < n; i++) {
|
|
140
|
-
fn(ctx, element, id, name,
|
|
121
|
+
fn(ctx, element, id, name, state === STATE_HYDRATING
|
|
141
122
|
? state
|
|
142
|
-
: i !== last ? STATE_WAITING : state);
|
|
123
|
+
: i !== last ? STATE_WAITING : state, v[i]);
|
|
143
124
|
}
|
|
144
125
|
}
|
|
145
126
|
});
|
|
@@ -147,7 +128,7 @@ const set = (element, name, value, state = STATE_HYDRATING) => {
|
|
|
147
128
|
return;
|
|
148
129
|
}
|
|
149
130
|
if (type !== 'object') {
|
|
150
|
-
fn(null, element, null, name,
|
|
131
|
+
fn(null, element, null, name, state, value);
|
|
151
132
|
return;
|
|
152
133
|
}
|
|
153
134
|
if (isArray(value)) {
|
|
@@ -160,7 +141,7 @@ const set = (element, name, value, state = STATE_HYDRATING) => {
|
|
|
160
141
|
}
|
|
161
142
|
return;
|
|
162
143
|
}
|
|
163
|
-
fn(null, element, null, name,
|
|
144
|
+
fn(null, element, null, name, state, value);
|
|
164
145
|
};
|
|
165
146
|
const spread = function (element, value) {
|
|
166
147
|
if (isObject(value)) {
|
package/build/slot/effect.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { Element } from '../types.js';
|
|
2
|
-
declare const _default: (anchor: Element, fn:
|
|
1
|
+
import { Element, Renderable } from '../types.js';
|
|
2
|
+
declare const _default: (anchor: Element, fn: (dispose?: VoidFunction) => Renderable<any>) => void;
|
|
3
3
|
export default _default;
|
package/build/slot/effect.js
CHANGED
|
@@ -43,9 +43,21 @@ export default (anchor, fn) => {
|
|
|
43
43
|
let context = {
|
|
44
44
|
group: undefined,
|
|
45
45
|
textnode: undefined
|
|
46
|
-
},
|
|
47
|
-
|
|
48
|
-
|
|
46
|
+
}, dispose = fn.length ? () => {
|
|
47
|
+
let { group, textnode } = context;
|
|
48
|
+
if (textnode) {
|
|
49
|
+
group = { head: anchor, tail: textnode };
|
|
50
|
+
}
|
|
51
|
+
else if (group) {
|
|
52
|
+
group.head = anchor;
|
|
53
|
+
}
|
|
54
|
+
d();
|
|
55
|
+
if (group) {
|
|
56
|
+
remove([group]);
|
|
57
|
+
}
|
|
58
|
+
} : undefined, state = STATE_HYDRATING;
|
|
59
|
+
let d = effect(() => {
|
|
60
|
+
let value = fn(dispose);
|
|
49
61
|
if (state === STATE_HYDRATING) {
|
|
50
62
|
update.call(context, anchor, value);
|
|
51
63
|
state = STATE_NONE;
|
package/package.json
CHANGED
package/src/attributes.ts
CHANGED
|
@@ -54,72 +54,43 @@ function list(
|
|
|
54
54
|
element: Element,
|
|
55
55
|
id: null | number,
|
|
56
56
|
name: string,
|
|
57
|
-
|
|
58
|
-
|
|
57
|
+
state: State,
|
|
58
|
+
value: unknown
|
|
59
59
|
) {
|
|
60
60
|
if (value == null || value === false || value === '') {
|
|
61
61
|
value = '';
|
|
62
62
|
}
|
|
63
63
|
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
dynamic = store[name] as Attributes | undefined,
|
|
68
|
-
type = typeof value;
|
|
64
|
+
if (!value || typeof value !== 'string') {
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
69
67
|
|
|
70
|
-
|
|
71
|
-
|
|
68
|
+
let delimiter = delimiters[name],
|
|
69
|
+
store = (ctx ??= context(element)).store ??= {},
|
|
70
|
+
v = store[name];
|
|
72
71
|
|
|
73
|
-
|
|
74
|
-
store[name] =
|
|
72
|
+
if (v === undefined) {
|
|
73
|
+
v = store[name] = (element.getAttribute(name) || '').trim();
|
|
75
74
|
}
|
|
76
75
|
|
|
77
76
|
if (id === null) {
|
|
78
|
-
|
|
79
|
-
store[base] += (store[base] ? delimiter : '') + value;
|
|
80
|
-
}
|
|
77
|
+
v = store[name] += (v ? delimiter : '') + value;
|
|
81
78
|
}
|
|
82
79
|
else {
|
|
83
|
-
let
|
|
80
|
+
let current = delimiter + value,
|
|
81
|
+
previous = store[id] as string | undefined;
|
|
84
82
|
|
|
85
|
-
if (
|
|
86
|
-
|
|
87
|
-
parts = (value as string).split(delimiter);
|
|
88
|
-
|
|
89
|
-
for (let i = 0, n = parts.length; i < n; i++) {
|
|
90
|
-
part = parts[i].trim();
|
|
91
|
-
|
|
92
|
-
if (part === '') {
|
|
93
|
-
continue;
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
dynamic[part] = null;
|
|
97
|
-
hot[part] = null;
|
|
98
|
-
}
|
|
83
|
+
if (previous === undefined) {
|
|
84
|
+
v = store[name] += current;
|
|
99
85
|
}
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
if (cold !== undefined) {
|
|
104
|
-
for (let part in cold) {
|
|
105
|
-
if (part in hot) {
|
|
106
|
-
continue;
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
delete dynamic[part];
|
|
110
|
-
}
|
|
86
|
+
else if (previous !== current) {
|
|
87
|
+
v = store[name] = (store[name] as string).replace(previous, current);
|
|
111
88
|
}
|
|
112
89
|
|
|
113
|
-
store[id] =
|
|
90
|
+
store[id] = current;
|
|
114
91
|
}
|
|
115
92
|
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
for (let key in dynamic) {
|
|
119
|
-
value += (value ? delimiter : '') + key;
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
schedule(ctx, element, name, state, value);
|
|
93
|
+
schedule(ctx, element, name, state, v);
|
|
123
94
|
}
|
|
124
95
|
|
|
125
96
|
function property(
|
|
@@ -127,8 +98,8 @@ function property(
|
|
|
127
98
|
element: Element,
|
|
128
99
|
id: null | number,
|
|
129
100
|
name: string,
|
|
130
|
-
|
|
131
|
-
|
|
101
|
+
state: State,
|
|
102
|
+
value: unknown
|
|
132
103
|
) {
|
|
133
104
|
if (value == null || value === false || value === '') {
|
|
134
105
|
value = '';
|
|
@@ -224,10 +195,10 @@ const set = (element: Element, name: string, value: unknown, state: State = STAT
|
|
|
224
195
|
element,
|
|
225
196
|
id,
|
|
226
197
|
name,
|
|
227
|
-
v[i],
|
|
228
198
|
state === STATE_HYDRATING
|
|
229
199
|
? state
|
|
230
|
-
: i !== last ? STATE_WAITING : state
|
|
200
|
+
: i !== last ? STATE_WAITING : state,
|
|
201
|
+
v[i],
|
|
231
202
|
);
|
|
232
203
|
}
|
|
233
204
|
}
|
|
@@ -239,7 +210,7 @@ const set = (element: Element, name: string, value: unknown, state: State = STAT
|
|
|
239
210
|
}
|
|
240
211
|
|
|
241
212
|
if (type !== 'object') {
|
|
242
|
-
fn(null, element, null, name,
|
|
213
|
+
fn(null, element, null, name, state, value);
|
|
243
214
|
return;
|
|
244
215
|
}
|
|
245
216
|
|
|
@@ -256,7 +227,7 @@ const set = (element: Element, name: string, value: unknown, state: State = STAT
|
|
|
256
227
|
return;
|
|
257
228
|
}
|
|
258
229
|
|
|
259
|
-
fn(null, element, null, name,
|
|
230
|
+
fn(null, element, null, name, state, value);
|
|
260
231
|
};
|
|
261
232
|
|
|
262
233
|
const spread = function (element: Element, value: Attributes | Attributes[]) {
|
package/src/slot/effect.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { effect } from '@esportsplus/reactivity';
|
|
2
2
|
import { STATE_HYDRATING, STATE_NONE } from '~/constants';
|
|
3
|
-
import { Element, SlotGroup } from '~/types';
|
|
3
|
+
import { Element, Renderable, SlotGroup } from '~/types';
|
|
4
4
|
import { firstChild, lastChild, nodeValue } from '~/utilities/node'
|
|
5
5
|
import { raf } from '~/utilities/queue'
|
|
6
6
|
import { remove } from './cleanup';
|
|
@@ -52,24 +52,40 @@ function update(this: { group?: SlotGroup, textnode?: Node }, anchor: Element, v
|
|
|
52
52
|
}
|
|
53
53
|
|
|
54
54
|
|
|
55
|
-
export default (anchor: Element, fn:
|
|
55
|
+
export default (anchor: Element, fn: (dispose?: VoidFunction) => Renderable<any>) => {
|
|
56
56
|
let context = {
|
|
57
57
|
group: undefined as SlotGroup | undefined,
|
|
58
58
|
textnode: undefined as Node | undefined
|
|
59
59
|
},
|
|
60
|
+
dispose = fn.length ? () => {
|
|
61
|
+
let { group, textnode } = context;
|
|
62
|
+
|
|
63
|
+
if (textnode) {
|
|
64
|
+
group = { head: anchor, tail: textnode as Element };
|
|
65
|
+
}
|
|
66
|
+
else if (group) {
|
|
67
|
+
group.head = anchor;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
d();
|
|
71
|
+
|
|
72
|
+
if (group) {
|
|
73
|
+
remove([group]);
|
|
74
|
+
}
|
|
75
|
+
} : undefined,
|
|
60
76
|
state = STATE_HYDRATING;
|
|
61
77
|
|
|
62
|
-
effect(() => {
|
|
63
|
-
|
|
78
|
+
let d = effect(() => {
|
|
79
|
+
let value = fn(dispose);
|
|
64
80
|
|
|
65
|
-
|
|
66
|
-
update.call(context, anchor, value);
|
|
67
|
-
state = STATE_NONE;
|
|
68
|
-
}
|
|
69
|
-
else if (state === STATE_NONE) {
|
|
70
|
-
raf.add(() => {
|
|
81
|
+
if (state === STATE_HYDRATING) {
|
|
71
82
|
update.call(context, anchor, value);
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
83
|
+
state = STATE_NONE;
|
|
84
|
+
}
|
|
85
|
+
else if (state === STATE_NONE) {
|
|
86
|
+
raf.add(() => {
|
|
87
|
+
update.call(context, anchor, value);
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
});
|
|
75
91
|
};
|
package/src/slot/index.ts
CHANGED
|
@@ -5,7 +5,7 @@ import render from './render';
|
|
|
5
5
|
|
|
6
6
|
export default (anchor: Element, value: unknown): void => {
|
|
7
7
|
if (typeof value === 'function') {
|
|
8
|
-
effect(anchor, value as
|
|
8
|
+
effect(anchor, value as Parameters<typeof effect>[1]);
|
|
9
9
|
}
|
|
10
10
|
else {
|
|
11
11
|
anchor.after( render(anchor, value) );
|