@a-type/ui 1.1.5 → 1.1.7
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/cjs/components/masonry/masonry.js +13 -11
- package/dist/cjs/components/masonry/masonry.js.map +1 -1
- package/dist/cjs/components/masonry/masonry.stories.js +13 -10
- package/dist/cjs/components/masonry/masonry.stories.js.map +1 -1
- package/dist/cjs/uno.preset.js +3 -3
- package/dist/css/main.css +3 -3
- package/dist/esm/components/masonry/masonry.js +13 -11
- package/dist/esm/components/masonry/masonry.js.map +1 -1
- package/dist/esm/components/masonry/masonry.stories.js +13 -10
- package/dist/esm/components/masonry/masonry.stories.js.map +1 -1
- package/dist/esm/uno.preset.js +3 -3
- package/package.json +1 -1
- package/src/components/masonry/masonry.stories.tsx +14 -9
- package/src/components/masonry/masonry.tsx +15 -11
- package/src/uno.preset.ts +3 -3
|
@@ -26,10 +26,7 @@ class MasonryLayout {
|
|
|
26
26
|
container.style.setProperty('visibility', 'visible');
|
|
27
27
|
container.childNodes.forEach((node) => {
|
|
28
28
|
if (node instanceof HTMLElement) {
|
|
29
|
-
|
|
30
|
-
// hide until laid out
|
|
31
|
-
node.style.setProperty('visibility', 'hidden');
|
|
32
|
-
this.childSizeObserver.observe(node);
|
|
29
|
+
this.setupChild(node);
|
|
33
30
|
}
|
|
34
31
|
});
|
|
35
32
|
this.updateFromContainerSize(container.offsetWidth);
|
|
@@ -43,6 +40,15 @@ class MasonryLayout {
|
|
|
43
40
|
this.container = null;
|
|
44
41
|
};
|
|
45
42
|
};
|
|
43
|
+
this.setupChild = (child) => {
|
|
44
|
+
child.style.setProperty('position', 'absolute');
|
|
45
|
+
// hide until laid out
|
|
46
|
+
child.style.setProperty('visibility', 'hidden');
|
|
47
|
+
this.childSizeObserver.observe(child);
|
|
48
|
+
this.childMutationObserver.observe(child, {
|
|
49
|
+
attributeFilter: ['data-span'],
|
|
50
|
+
});
|
|
51
|
+
};
|
|
46
52
|
this.updateConfig = (config) => {
|
|
47
53
|
var _a, _b;
|
|
48
54
|
const gapChanged = config.gap !== this.config.gap;
|
|
@@ -71,12 +77,8 @@ class MasonryLayout {
|
|
|
71
77
|
this.handleContainerMutation = (entries) => {
|
|
72
78
|
for (const entry of entries) {
|
|
73
79
|
entry.addedNodes.forEach((node) => {
|
|
74
|
-
var _a;
|
|
75
80
|
if (node instanceof HTMLElement) {
|
|
76
|
-
|
|
77
|
-
// hide until laid out
|
|
78
|
-
node.style.setProperty('visibility', 'hidden');
|
|
79
|
-
(_a = this.childSizeObserver) === null || _a === void 0 ? void 0 : _a.observe(node);
|
|
81
|
+
this.setupChild(node);
|
|
80
82
|
}
|
|
81
83
|
});
|
|
82
84
|
entry.removedNodes.forEach((node) => {
|
|
@@ -86,8 +88,7 @@ class MasonryLayout {
|
|
|
86
88
|
}
|
|
87
89
|
});
|
|
88
90
|
}
|
|
89
|
-
|
|
90
|
-
setTimeout(this.relayout, 100);
|
|
91
|
+
this.relayout();
|
|
91
92
|
};
|
|
92
93
|
this.handleChildResize = (entries) => {
|
|
93
94
|
// only worry about height changes
|
|
@@ -145,6 +146,7 @@ class MasonryLayout {
|
|
|
145
146
|
this.columns =
|
|
146
147
|
typeof config.columns === 'function' ? config.columns(0) : config.columns;
|
|
147
148
|
this.childSizeObserver = new ResizeObserver(this.handleChildResize);
|
|
149
|
+
this.childMutationObserver = new MutationObserver(this.relayout);
|
|
148
150
|
}
|
|
149
151
|
}
|
|
150
152
|
function pickTrack(tracks, trackSpan) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"masonry.js","sourceRoot":"","sources":["../../../../src/components/masonry/masonry.tsx"],"names":[],"mappings":";;;;AAAA,yCAAyC;AACzC,iCAA8E;AAO9E,MAAM,aAAa;
|
|
1
|
+
{"version":3,"file":"masonry.js","sourceRoot":"","sources":["../../../../src/components/masonry/masonry.tsx"],"names":[],"mappings":"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"}
|
|
@@ -4,6 +4,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
4
4
|
exports.WithSpan = exports.Default = void 0;
|
|
5
5
|
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
6
|
const masonry_js_1 = require("./masonry.js");
|
|
7
|
+
const react_1 = require("react");
|
|
7
8
|
const meta = {
|
|
8
9
|
title: 'Masonry',
|
|
9
10
|
component: masonry_js_1.Masonry,
|
|
@@ -13,18 +14,20 @@ const meta = {
|
|
|
13
14
|
},
|
|
14
15
|
};
|
|
15
16
|
exports.default = meta;
|
|
17
|
+
const randomSpan = () => {
|
|
18
|
+
let span = 1;
|
|
19
|
+
if (Math.random() < 0.1) {
|
|
20
|
+
span = 2;
|
|
21
|
+
}
|
|
22
|
+
else if (Math.random() < 0.03) {
|
|
23
|
+
span = 3;
|
|
24
|
+
}
|
|
25
|
+
return span;
|
|
26
|
+
};
|
|
16
27
|
const content = (spans) => Array.from({ length: 100 }, (_, i) => {
|
|
17
28
|
const size = 100 + Math.floor(Math.random() * 100);
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
if (Math.random() < 0.1) {
|
|
21
|
-
span = 2;
|
|
22
|
-
}
|
|
23
|
-
else if (Math.random() < 0.03) {
|
|
24
|
-
span = 3;
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
return ((0, jsx_runtime_1.jsx)("div", Object.assign({ className: "bg-gray-5 rounded-lg", style: { height: size }, "data-span": span }, { children: size }), i));
|
|
29
|
+
const [span, setSpan] = (0, react_1.useState)(randomSpan);
|
|
30
|
+
return ((0, jsx_runtime_1.jsx)("div", Object.assign({ className: "bg-gray-5 rounded-lg", style: { height: size }, "data-span": spans ? span : undefined, onClick: () => setSpan((v) => (v === 1 ? 2 : 1)) }, { children: size }), i));
|
|
28
31
|
});
|
|
29
32
|
exports.Default = {
|
|
30
33
|
render(props) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"masonry.stories.js","sourceRoot":"","sources":["../../../../src/components/masonry/masonry.stories.tsx"],"names":[],"mappings":";;;;AACA,6CAAuC;
|
|
1
|
+
{"version":3,"file":"masonry.stories.js","sourceRoot":"","sources":["../../../../src/components/masonry/masonry.stories.tsx"],"names":[],"mappings":";;;;AACA,6CAAuC;AACvC,iCAAiC;AAEjC,MAAM,IAAI,GAAG;IACZ,KAAK,EAAE,SAAS;IAChB,SAAS,EAAE,oBAAO;IAClB,QAAQ,EAAE,EAAE;IACZ,UAAU,EAAE;QACX,QAAQ,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE;KAC5B;CAC8B,CAAC;AAEjC,kBAAe,IAAI,CAAC;AAIpB,MAAM,UAAU,GAAG,GAAG,EAAE;IACvB,IAAI,IAAI,GAAG,CAAC,CAAC;IACb,IAAI,IAAI,CAAC,MAAM,EAAE,GAAG,GAAG,EAAE;QACxB,IAAI,GAAG,CAAC,CAAC;KACT;SAAM,IAAI,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,EAAE;QAChC,IAAI,GAAG,CAAC,CAAC;KACT;IACD,OAAO,IAAI,CAAC;AACb,CAAC,CAAC;AAEF,MAAM,OAAO,GAAG,CAAC,KAAe,EAAE,EAAE,CACnC,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;IACpC,MAAM,IAAI,GAAG,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,GAAG,CAAC,CAAC;IACnD,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,IAAA,gBAAQ,EAAC,UAAU,CAAC,CAAC;IAE7C,OAAO,CACN,8CAEC,SAAS,EAAC,sBAAsB,EAChC,KAAK,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,eACZ,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,EACnC,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,gBAE/C,IAAI,KANA,CAAC,CAOD,CACN,CAAC;AACH,CAAC,CAAC,CAAC;AAES,QAAA,OAAO,GAAU;IAC7B,MAAM,CAAC,KAAK;QACX,OAAO,uBAAC,oBAAO,oBAAK,KAAK,cAAG,OAAO,EAAE,IAAW,CAAC;IAClD,CAAC;CACD,CAAC;AAEW,QAAA,QAAQ,GAAU;IAC9B,MAAM,CAAC,KAAK;QACX,OAAO,uBAAC,oBAAO,oBAAK,KAAK,cAAG,OAAO,CAAC,IAAI,CAAC,IAAW,CAAC;IACtD,CAAC;CACD,CAAC"}
|
package/dist/cjs/uno.preset.js
CHANGED
|
@@ -402,9 +402,9 @@ function presetAglio({ spacingIncrement = 0.25, interFontLocation = 'https://res
|
|
|
402
402
|
--palette-red-00: #321f19;
|
|
403
403
|
--palette-green-90: #e9fff1;
|
|
404
404
|
--palette-green-80: #c2ffe1;
|
|
405
|
-
--palette-green-70: #
|
|
406
|
-
--palette-green-60: #
|
|
407
|
-
--palette-green-50: #
|
|
405
|
+
--palette-green-70: #8ff8d3;
|
|
406
|
+
--palette-green-60: #79fdcd;
|
|
407
|
+
--palette-green-50: #63cea5;
|
|
408
408
|
--palette-green-40: #499d92;
|
|
409
409
|
--palette-green-30: #1f837c;
|
|
410
410
|
--palette-green-20: #246869;
|
package/dist/css/main.css
CHANGED
|
@@ -14,9 +14,9 @@
|
|
|
14
14
|
--palette-red-00: #321f19;
|
|
15
15
|
--palette-green-90: #e9fff1;
|
|
16
16
|
--palette-green-80: #c2ffe1;
|
|
17
|
-
--palette-green-70: #
|
|
18
|
-
--palette-green-60: #
|
|
19
|
-
--palette-green-50: #
|
|
17
|
+
--palette-green-70: #8ff8d3;
|
|
18
|
+
--palette-green-60: #79fdcd;
|
|
19
|
+
--palette-green-50: #63cea5;
|
|
20
20
|
--palette-green-40: #499d92;
|
|
21
21
|
--palette-green-30: #1f837c;
|
|
22
22
|
--palette-green-20: #246869;
|
|
@@ -23,10 +23,7 @@ class MasonryLayout {
|
|
|
23
23
|
container.style.setProperty('visibility', 'visible');
|
|
24
24
|
container.childNodes.forEach((node) => {
|
|
25
25
|
if (node instanceof HTMLElement) {
|
|
26
|
-
|
|
27
|
-
// hide until laid out
|
|
28
|
-
node.style.setProperty('visibility', 'hidden');
|
|
29
|
-
this.childSizeObserver.observe(node);
|
|
26
|
+
this.setupChild(node);
|
|
30
27
|
}
|
|
31
28
|
});
|
|
32
29
|
this.updateFromContainerSize(container.offsetWidth);
|
|
@@ -40,6 +37,15 @@ class MasonryLayout {
|
|
|
40
37
|
this.container = null;
|
|
41
38
|
};
|
|
42
39
|
};
|
|
40
|
+
this.setupChild = (child) => {
|
|
41
|
+
child.style.setProperty('position', 'absolute');
|
|
42
|
+
// hide until laid out
|
|
43
|
+
child.style.setProperty('visibility', 'hidden');
|
|
44
|
+
this.childSizeObserver.observe(child);
|
|
45
|
+
this.childMutationObserver.observe(child, {
|
|
46
|
+
attributeFilter: ['data-span'],
|
|
47
|
+
});
|
|
48
|
+
};
|
|
43
49
|
this.updateConfig = (config) => {
|
|
44
50
|
var _a, _b;
|
|
45
51
|
const gapChanged = config.gap !== this.config.gap;
|
|
@@ -68,12 +74,8 @@ class MasonryLayout {
|
|
|
68
74
|
this.handleContainerMutation = (entries) => {
|
|
69
75
|
for (const entry of entries) {
|
|
70
76
|
entry.addedNodes.forEach((node) => {
|
|
71
|
-
var _a;
|
|
72
77
|
if (node instanceof HTMLElement) {
|
|
73
|
-
|
|
74
|
-
// hide until laid out
|
|
75
|
-
node.style.setProperty('visibility', 'hidden');
|
|
76
|
-
(_a = this.childSizeObserver) === null || _a === void 0 ? void 0 : _a.observe(node);
|
|
78
|
+
this.setupChild(node);
|
|
77
79
|
}
|
|
78
80
|
});
|
|
79
81
|
entry.removedNodes.forEach((node) => {
|
|
@@ -83,8 +85,7 @@ class MasonryLayout {
|
|
|
83
85
|
}
|
|
84
86
|
});
|
|
85
87
|
}
|
|
86
|
-
|
|
87
|
-
setTimeout(this.relayout, 100);
|
|
88
|
+
this.relayout();
|
|
88
89
|
};
|
|
89
90
|
this.handleChildResize = (entries) => {
|
|
90
91
|
// only worry about height changes
|
|
@@ -142,6 +143,7 @@ class MasonryLayout {
|
|
|
142
143
|
this.columns =
|
|
143
144
|
typeof config.columns === 'function' ? config.columns(0) : config.columns;
|
|
144
145
|
this.childSizeObserver = new ResizeObserver(this.handleChildResize);
|
|
146
|
+
this.childMutationObserver = new MutationObserver(this.relayout);
|
|
145
147
|
}
|
|
146
148
|
}
|
|
147
149
|
function pickTrack(tracks, trackSpan) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"masonry.js","sourceRoot":"","sources":["../../../../src/components/masonry/masonry.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAA4B,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAO9E,MAAM,aAAa;
|
|
1
|
+
{"version":3,"file":"masonry.js","sourceRoot":"","sources":["../../../../src/components/masonry/masonry.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
// @unocss-include
|
|
2
2
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
3
|
import { Masonry } from './masonry.js';
|
|
4
|
+
import { useState } from 'react';
|
|
4
5
|
const meta = {
|
|
5
6
|
title: 'Masonry',
|
|
6
7
|
component: Masonry,
|
|
@@ -10,18 +11,20 @@ const meta = {
|
|
|
10
11
|
},
|
|
11
12
|
};
|
|
12
13
|
export default meta;
|
|
14
|
+
const randomSpan = () => {
|
|
15
|
+
let span = 1;
|
|
16
|
+
if (Math.random() < 0.1) {
|
|
17
|
+
span = 2;
|
|
18
|
+
}
|
|
19
|
+
else if (Math.random() < 0.03) {
|
|
20
|
+
span = 3;
|
|
21
|
+
}
|
|
22
|
+
return span;
|
|
23
|
+
};
|
|
13
24
|
const content = (spans) => Array.from({ length: 100 }, (_, i) => {
|
|
14
25
|
const size = 100 + Math.floor(Math.random() * 100);
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
if (Math.random() < 0.1) {
|
|
18
|
-
span = 2;
|
|
19
|
-
}
|
|
20
|
-
else if (Math.random() < 0.03) {
|
|
21
|
-
span = 3;
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
return (_jsx("div", Object.assign({ className: "bg-gray-5 rounded-lg", style: { height: size }, "data-span": span }, { children: size }), i));
|
|
26
|
+
const [span, setSpan] = useState(randomSpan);
|
|
27
|
+
return (_jsx("div", Object.assign({ className: "bg-gray-5 rounded-lg", style: { height: size }, "data-span": spans ? span : undefined, onClick: () => setSpan((v) => (v === 1 ? 2 : 1)) }, { children: size }), i));
|
|
25
28
|
});
|
|
26
29
|
export const Default = {
|
|
27
30
|
render(props) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"masonry.stories.js","sourceRoot":"","sources":["../../../../src/components/masonry/masonry.stories.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"masonry.stories.js","sourceRoot":"","sources":["../../../../src/components/masonry/masonry.stories.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEjC,MAAM,IAAI,GAAG;IACZ,KAAK,EAAE,SAAS;IAChB,SAAS,EAAE,OAAO;IAClB,QAAQ,EAAE,EAAE;IACZ,UAAU,EAAE;QACX,QAAQ,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE;KAC5B;CAC8B,CAAC;AAEjC,eAAe,IAAI,CAAC;AAIpB,MAAM,UAAU,GAAG,GAAG,EAAE;IACvB,IAAI,IAAI,GAAG,CAAC,CAAC;IACb,IAAI,IAAI,CAAC,MAAM,EAAE,GAAG,GAAG,EAAE;QACxB,IAAI,GAAG,CAAC,CAAC;KACT;SAAM,IAAI,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,EAAE;QAChC,IAAI,GAAG,CAAC,CAAC;KACT;IACD,OAAO,IAAI,CAAC;AACb,CAAC,CAAC;AAEF,MAAM,OAAO,GAAG,CAAC,KAAe,EAAE,EAAE,CACnC,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;IACpC,MAAM,IAAI,GAAG,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,GAAG,CAAC,CAAC;IACnD,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC;IAE7C,OAAO,CACN,4BAEC,SAAS,EAAC,sBAAsB,EAChC,KAAK,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,eACZ,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,EACnC,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,gBAE/C,IAAI,KANA,CAAC,CAOD,CACN,CAAC;AACH,CAAC,CAAC,CAAC;AAEJ,MAAM,CAAC,MAAM,OAAO,GAAU;IAC7B,MAAM,CAAC,KAAK;QACX,OAAO,KAAC,OAAO,oBAAK,KAAK,cAAG,OAAO,EAAE,IAAW,CAAC;IAClD,CAAC;CACD,CAAC;AAEF,MAAM,CAAC,MAAM,QAAQ,GAAU;IAC9B,MAAM,CAAC,KAAK;QACX,OAAO,KAAC,OAAO,oBAAK,KAAK,cAAG,OAAO,CAAC,IAAI,CAAC,IAAW,CAAC;IACtD,CAAC;CACD,CAAC"}
|
package/dist/esm/uno.preset.js
CHANGED
|
@@ -400,9 +400,9 @@ export default function presetAglio({ spacingIncrement = 0.25, interFontLocation
|
|
|
400
400
|
--palette-red-00: #321f19;
|
|
401
401
|
--palette-green-90: #e9fff1;
|
|
402
402
|
--palette-green-80: #c2ffe1;
|
|
403
|
-
--palette-green-70: #
|
|
404
|
-
--palette-green-60: #
|
|
405
|
-
--palette-green-50: #
|
|
403
|
+
--palette-green-70: #8ff8d3;
|
|
404
|
+
--palette-green-60: #79fdcd;
|
|
405
|
+
--palette-green-50: #63cea5;
|
|
406
406
|
--palette-green-40: #499d92;
|
|
407
407
|
--palette-green-30: #1f837c;
|
|
408
408
|
--palette-green-20: #246869;
|
package/package.json
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import type { Meta, StoryObj } from '@storybook/react';
|
|
2
2
|
import { Masonry } from './masonry.js';
|
|
3
|
+
import { useState } from 'react';
|
|
3
4
|
|
|
4
5
|
const meta = {
|
|
5
6
|
title: 'Masonry',
|
|
@@ -14,24 +15,28 @@ export default meta;
|
|
|
14
15
|
|
|
15
16
|
type Story = StoryObj<typeof Masonry>;
|
|
16
17
|
|
|
18
|
+
const randomSpan = () => {
|
|
19
|
+
let span = 1;
|
|
20
|
+
if (Math.random() < 0.1) {
|
|
21
|
+
span = 2;
|
|
22
|
+
} else if (Math.random() < 0.03) {
|
|
23
|
+
span = 3;
|
|
24
|
+
}
|
|
25
|
+
return span;
|
|
26
|
+
};
|
|
27
|
+
|
|
17
28
|
const content = (spans?: boolean) =>
|
|
18
29
|
Array.from({ length: 100 }, (_, i) => {
|
|
19
30
|
const size = 100 + Math.floor(Math.random() * 100);
|
|
20
|
-
|
|
21
|
-
if (spans) {
|
|
22
|
-
if (Math.random() < 0.1) {
|
|
23
|
-
span = 2;
|
|
24
|
-
} else if (Math.random() < 0.03) {
|
|
25
|
-
span = 3;
|
|
26
|
-
}
|
|
27
|
-
}
|
|
31
|
+
const [span, setSpan] = useState(randomSpan);
|
|
28
32
|
|
|
29
33
|
return (
|
|
30
34
|
<div
|
|
31
35
|
key={i}
|
|
32
36
|
className="bg-gray-5 rounded-lg"
|
|
33
37
|
style={{ height: size }}
|
|
34
|
-
data-span={span}
|
|
38
|
+
data-span={spans ? span : undefined}
|
|
39
|
+
onClick={() => setSpan((v) => (v === 1 ? 2 : 1))}
|
|
35
40
|
>
|
|
36
41
|
{size}
|
|
37
42
|
</div>
|
|
@@ -10,6 +10,7 @@ class MasonryLayout {
|
|
|
10
10
|
private containerResizeObserver: ResizeObserver | null = null;
|
|
11
11
|
private containerMutationObserver: MutationObserver | null = null;
|
|
12
12
|
private childSizeObserver: ResizeObserver;
|
|
13
|
+
private childMutationObserver: MutationObserver;
|
|
13
14
|
|
|
14
15
|
private container: HTMLElement | null = null;
|
|
15
16
|
|
|
@@ -19,6 +20,7 @@ class MasonryLayout {
|
|
|
19
20
|
this.columns =
|
|
20
21
|
typeof config.columns === 'function' ? config.columns(0) : config.columns;
|
|
21
22
|
this.childSizeObserver = new ResizeObserver(this.handleChildResize);
|
|
23
|
+
this.childMutationObserver = new MutationObserver(this.relayout);
|
|
22
24
|
}
|
|
23
25
|
|
|
24
26
|
attach = (container: HTMLElement) => {
|
|
@@ -41,10 +43,7 @@ class MasonryLayout {
|
|
|
41
43
|
container.style.setProperty('visibility', 'visible');
|
|
42
44
|
container.childNodes.forEach((node) => {
|
|
43
45
|
if (node instanceof HTMLElement) {
|
|
44
|
-
|
|
45
|
-
// hide until laid out
|
|
46
|
-
node.style.setProperty('visibility', 'hidden');
|
|
47
|
-
this.childSizeObserver.observe(node);
|
|
46
|
+
this.setupChild(node);
|
|
48
47
|
}
|
|
49
48
|
});
|
|
50
49
|
|
|
@@ -61,6 +60,16 @@ class MasonryLayout {
|
|
|
61
60
|
};
|
|
62
61
|
};
|
|
63
62
|
|
|
63
|
+
private setupChild = (child: HTMLElement) => {
|
|
64
|
+
child.style.setProperty('position', 'absolute');
|
|
65
|
+
// hide until laid out
|
|
66
|
+
child.style.setProperty('visibility', 'hidden');
|
|
67
|
+
this.childSizeObserver.observe(child);
|
|
68
|
+
this.childMutationObserver.observe(child, {
|
|
69
|
+
attributeFilter: ['data-span'],
|
|
70
|
+
});
|
|
71
|
+
};
|
|
72
|
+
|
|
64
73
|
updateConfig = (config: MasonryLayoutConfig) => {
|
|
65
74
|
const gapChanged = config.gap !== this.config.gap;
|
|
66
75
|
this.config = config;
|
|
@@ -94,11 +103,7 @@ class MasonryLayout {
|
|
|
94
103
|
for (const entry of entries) {
|
|
95
104
|
entry.addedNodes.forEach((node) => {
|
|
96
105
|
if (node instanceof HTMLElement) {
|
|
97
|
-
|
|
98
|
-
// hide until laid out
|
|
99
|
-
node.style.setProperty('visibility', 'hidden');
|
|
100
|
-
|
|
101
|
-
this.childSizeObserver?.observe(node);
|
|
106
|
+
this.setupChild(node);
|
|
102
107
|
}
|
|
103
108
|
});
|
|
104
109
|
entry.removedNodes.forEach((node) => {
|
|
@@ -107,8 +112,7 @@ class MasonryLayout {
|
|
|
107
112
|
}
|
|
108
113
|
});
|
|
109
114
|
}
|
|
110
|
-
|
|
111
|
-
setTimeout(this.relayout, 100);
|
|
115
|
+
this.relayout();
|
|
112
116
|
};
|
|
113
117
|
|
|
114
118
|
private handleChildResize = (entries: ResizeObserverEntry[]) => {
|
package/src/uno.preset.ts
CHANGED
|
@@ -433,9 +433,9 @@ export default function presetAglio({
|
|
|
433
433
|
--palette-red-00: #321f19;
|
|
434
434
|
--palette-green-90: #e9fff1;
|
|
435
435
|
--palette-green-80: #c2ffe1;
|
|
436
|
-
--palette-green-70: #
|
|
437
|
-
--palette-green-60: #
|
|
438
|
-
--palette-green-50: #
|
|
436
|
+
--palette-green-70: #8ff8d3;
|
|
437
|
+
--palette-green-60: #79fdcd;
|
|
438
|
+
--palette-green-50: #63cea5;
|
|
439
439
|
--palette-green-40: #499d92;
|
|
440
440
|
--palette-green-30: #1f837c;
|
|
441
441
|
--palette-green-20: #246869;
|