sibujs 1.5.0 → 2.1.0

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.
Files changed (208) hide show
  1. package/dist/browser.cjs +332 -121
  2. package/dist/browser.d.cts +5 -0
  3. package/dist/browser.d.ts +5 -0
  4. package/dist/browser.js +6 -6
  5. package/dist/build.cjs +1049 -344
  6. package/dist/build.js +15 -13
  7. package/dist/cdn.global.js +17 -16
  8. package/dist/chunk-2RA7SHDA.js +65 -0
  9. package/dist/chunk-2UPRY23K.js +80 -0
  10. package/dist/{chunk-BMPL52BF.js → chunk-3DZP6OIT.js} +118 -66
  11. package/dist/chunk-3JHCYHWN.js +125 -0
  12. package/dist/{chunk-CZUGLNJS.js → chunk-45YP72ZQ.js} +3 -3
  13. package/dist/{chunk-JCDUJN2F.js → chunk-AMK2TYNW.js} +490 -153
  14. package/dist/{chunk-NHUC2QWH.js → chunk-CWBVQML6.js} +1 -1
  15. package/dist/{chunk-XHK6BDAJ.js → chunk-DRUZZAK4.js} +25 -8
  16. package/dist/{chunk-RJ46C3CS.js → chunk-GWWURC5M.js} +71 -20
  17. package/dist/{chunk-3X2YG6YM.js → chunk-JYD2PWXH.js} +59 -28
  18. package/dist/{chunk-2BYQDGN3.js → chunk-KGYT6UO6.js} +234 -63
  19. package/dist/{chunk-5X6PP2UK.js → chunk-LMLD24FC.js} +2 -2
  20. package/dist/{chunk-M4NLBH4I.js → chunk-LYTCUZ7H.js} +3 -2
  21. package/dist/{chunk-XUEEGU5O.js → chunk-NASX6ST2.js} +16 -4
  22. package/dist/{chunk-VQDZK23A.js → chunk-O6EFQ3KT.js} +181 -66
  23. package/dist/{chunk-BGN5ZMP4.js → chunk-OJ3P4ECI.js} +14 -2
  24. package/dist/chunk-ON5MMR2J.js +1327 -0
  25. package/dist/{chunk-SFKNRVCU.js → chunk-P2HSJDDN.js} +135 -79
  26. package/dist/chunk-QO3WC6FS.js +384 -0
  27. package/dist/{chunk-WZSPOOER.js → chunk-RDTDJCAB.js} +8 -5
  28. package/dist/{chunk-7GRNSCFT.js → chunk-TH2ILCYW.js} +312 -185
  29. package/dist/chunk-UCS6AMJ7.js +79 -0
  30. package/dist/{chunk-VAPYJN4X.js → chunk-V6C4FADE.js} +93 -23
  31. package/dist/{chunk-OUZZEE4S.js → chunk-WANSMF2L.js} +17 -11
  32. package/dist/{chunk-23VV7YD3.js → chunk-WIPZPFBQ.js} +25 -30
  33. package/dist/chunk-WZA53FXU.js +149 -0
  34. package/dist/{chunk-BGTHZHJ5.js → chunk-ZAQSMOED.js} +188 -44
  35. package/dist/{customElement-BL3Uo8dL.d.cts → customElement-CPfIrbvg.d.cts} +14 -10
  36. package/dist/{customElement-BL3Uo8dL.d.ts → customElement-CPfIrbvg.d.ts} +14 -10
  37. package/dist/data.cjs +536 -151
  38. package/dist/data.d.cts +20 -2
  39. package/dist/data.d.ts +20 -2
  40. package/dist/data.js +11 -9
  41. package/dist/devtools.cjs +613 -266
  42. package/dist/devtools.d.cts +1 -1
  43. package/dist/devtools.d.ts +1 -1
  44. package/dist/devtools.js +12 -6
  45. package/dist/ecosystem.cjs +602 -197
  46. package/dist/ecosystem.d.cts +9 -7
  47. package/dist/ecosystem.d.ts +9 -7
  48. package/dist/ecosystem.js +12 -11
  49. package/dist/extras.cjs +3500 -1608
  50. package/dist/extras.d.cts +9 -9
  51. package/dist/extras.d.ts +9 -9
  52. package/dist/extras.js +58 -45
  53. package/dist/index.cjs +1055 -344
  54. package/dist/index.d.cts +85 -8
  55. package/dist/index.d.ts +85 -8
  56. package/dist/index.js +32 -16
  57. package/dist/{introspect-BumjnBKr.d.cts → introspect-2TOlQ7oa.d.cts} +25 -3
  58. package/dist/{introspect-CZrlcaYy.d.ts → introspect-DnIpHQQz.d.ts} +25 -3
  59. package/dist/motion.cjs +122 -63
  60. package/dist/motion.js +4 -4
  61. package/dist/patterns.cjs +450 -110
  62. package/dist/patterns.d.cts +11 -12
  63. package/dist/patterns.d.ts +11 -12
  64. package/dist/patterns.js +7 -7
  65. package/dist/performance.cjs +373 -149
  66. package/dist/performance.d.cts +23 -16
  67. package/dist/performance.d.ts +23 -16
  68. package/dist/performance.js +13 -8
  69. package/dist/plugin-D30wlGW5.d.cts +71 -0
  70. package/dist/plugin-D30wlGW5.d.ts +71 -0
  71. package/dist/plugins.cjs +729 -301
  72. package/dist/plugins.d.cts +10 -3
  73. package/dist/plugins.d.ts +10 -3
  74. package/dist/plugins.js +106 -38
  75. package/dist/{ssr-Do_SiVoL.d.cts → ssr-CrVNy6Pa.d.cts} +9 -15
  76. package/dist/{ssr-Do_SiVoL.d.ts → ssr-CrVNy6Pa.d.ts} +9 -15
  77. package/dist/{ssr-4PBXAOO3.js → ssr-FXD2PPMC.js} +4 -3
  78. package/dist/ssr.cjs +736 -274
  79. package/dist/ssr.d.cts +26 -6
  80. package/dist/ssr.d.ts +26 -6
  81. package/dist/ssr.js +12 -11
  82. package/dist/{tagFactory-DaJ0YWX6.d.cts → tagFactory-S17H2qxu.d.cts} +9 -1
  83. package/dist/{tagFactory-DaJ0YWX6.d.ts → tagFactory-S17H2qxu.d.ts} +9 -1
  84. package/dist/testing.cjs +303 -76
  85. package/dist/testing.d.cts +17 -4
  86. package/dist/testing.d.ts +17 -4
  87. package/dist/testing.js +100 -44
  88. package/dist/ui.cjs +589 -178
  89. package/dist/ui.d.cts +1 -1
  90. package/dist/ui.d.ts +1 -1
  91. package/dist/ui.js +20 -17
  92. package/dist/widgets.cjs +1103 -146
  93. package/dist/widgets.d.cts +104 -2
  94. package/dist/widgets.d.ts +104 -2
  95. package/dist/widgets.js +9 -7
  96. package/package.json +8 -2
  97. package/dist/chunk-32DY64NT.js +0 -282
  98. package/dist/chunk-3AIRKM3B.js +0 -1263
  99. package/dist/chunk-3ARAQO7B.js +0 -398
  100. package/dist/chunk-3CRQALYP.js +0 -877
  101. package/dist/chunk-4EI4AG32.js +0 -482
  102. package/dist/chunk-4MYMUBRS.js +0 -21
  103. package/dist/chunk-5ZYQ6KDD.js +0 -154
  104. package/dist/chunk-6BMPXPUW.js +0 -26
  105. package/dist/chunk-6HLLIF3K.js +0 -398
  106. package/dist/chunk-6LSNVCS2.js +0 -937
  107. package/dist/chunk-6SA3QQES.js +0 -61
  108. package/dist/chunk-77L6NL3X.js +0 -1097
  109. package/dist/chunk-7BF6TK55.js +0 -1097
  110. package/dist/chunk-7TQKR4PP.js +0 -294
  111. package/dist/chunk-7V26P53V.js +0 -712
  112. package/dist/chunk-AZ3ISID5.js +0 -298
  113. package/dist/chunk-B7SWRFUT.js +0 -332
  114. package/dist/chunk-BTU3TJDS.js +0 -365
  115. package/dist/chunk-BW3WT46K.js +0 -937
  116. package/dist/chunk-C6KFWOFV.js +0 -616
  117. package/dist/chunk-CHF5OHIA.js +0 -61
  118. package/dist/chunk-CHJ27IGK.js +0 -26
  119. package/dist/chunk-CMBFNA7L.js +0 -27
  120. package/dist/chunk-DAHRH4ON.js +0 -331
  121. package/dist/chunk-DKOHBI74.js +0 -924
  122. package/dist/chunk-DTCOOBMX.js +0 -725
  123. package/dist/chunk-EBGIRKQY.js +0 -616
  124. package/dist/chunk-EUZND3CB.js +0 -27
  125. package/dist/chunk-EVCZO745.js +0 -365
  126. package/dist/chunk-EWFVA3TJ.js +0 -282
  127. package/dist/chunk-F3FA4F32.js +0 -292
  128. package/dist/chunk-FGOEVHY3.js +0 -60
  129. package/dist/chunk-G3BOQPVO.js +0 -365
  130. package/dist/chunk-GCOK2LC3.js +0 -282
  131. package/dist/chunk-GJPXRJ45.js +0 -37
  132. package/dist/chunk-HGMJFBC7.js +0 -654
  133. package/dist/chunk-JAKHTMQU.js +0 -1000
  134. package/dist/chunk-JCI5M6U6.js +0 -956
  135. package/dist/chunk-K4G4ZQNR.js +0 -286
  136. package/dist/chunk-K5ZUMYVS.js +0 -89
  137. package/dist/chunk-KQPDEVVS.js +0 -398
  138. package/dist/chunk-L6JRBDNS.js +0 -60
  139. package/dist/chunk-LA6KQEDU.js +0 -712
  140. package/dist/chunk-MB6QFH3I.js +0 -2776
  141. package/dist/chunk-MDVXJWFN.js +0 -304
  142. package/dist/chunk-MEZVEBPN.js +0 -2008
  143. package/dist/chunk-MK4ERFYL.js +0 -2249
  144. package/dist/chunk-MLKGABMK.js +0 -9
  145. package/dist/chunk-MQ5GOYPH.js +0 -2249
  146. package/dist/chunk-MYRV7VDM.js +0 -742
  147. package/dist/chunk-N6IZB6KJ.js +0 -567
  148. package/dist/chunk-NEKUBFPT.js +0 -60
  149. package/dist/chunk-NMRUZALC.js +0 -1097
  150. package/dist/chunk-NYVAC6P5.js +0 -37
  151. package/dist/chunk-NZIIMDWI.js +0 -84
  152. package/dist/chunk-OF7UZIVB.js +0 -725
  153. package/dist/chunk-P3XWXJZU.js +0 -282
  154. package/dist/chunk-P6W3STU4.js +0 -2249
  155. package/dist/chunk-PBHF5WKN.js +0 -616
  156. package/dist/chunk-PDZQY43A.js +0 -616
  157. package/dist/chunk-PTQJDMRT.js +0 -146
  158. package/dist/chunk-PZEGYCF5.js +0 -61
  159. package/dist/chunk-QBMDLBU2.js +0 -975
  160. package/dist/chunk-QWZG56ET.js +0 -2744
  161. package/dist/chunk-RQGQSLQK.js +0 -725
  162. package/dist/chunk-SDLZDHKP.js +0 -107
  163. package/dist/chunk-TDGZL5CU.js +0 -365
  164. package/dist/chunk-TNQWPPE6.js +0 -37
  165. package/dist/chunk-TSOKIX5Z.js +0 -654
  166. package/dist/chunk-UHNL42EF.js +0 -2730
  167. package/dist/chunk-UNXCEF6S.js +0 -21
  168. package/dist/chunk-V2XTI523.js +0 -347
  169. package/dist/chunk-VAU366PN.js +0 -2241
  170. package/dist/chunk-VMVDTCXB.js +0 -712
  171. package/dist/chunk-VQNQZCWJ.js +0 -61
  172. package/dist/chunk-VRW3FULF.js +0 -725
  173. package/dist/chunk-WADYRCO2.js +0 -304
  174. package/dist/chunk-WILQZRO4.js +0 -282
  175. package/dist/chunk-WR5D4EGH.js +0 -26
  176. package/dist/chunk-WUHJISPP.js +0 -298
  177. package/dist/chunk-XYU6TZOW.js +0 -182
  178. package/dist/chunk-Y6GP4QGG.js +0 -276
  179. package/dist/chunk-YECR7UIA.js +0 -347
  180. package/dist/chunk-YUTWTI4B.js +0 -654
  181. package/dist/chunk-Z65KYU7I.js +0 -26
  182. package/dist/chunk-Z6POF5YC.js +0 -975
  183. package/dist/chunk-ZBJP6WFL.js +0 -482
  184. package/dist/chunk-ZD6OAMTH.js +0 -277
  185. package/dist/chunk-ZWKZCBO6.js +0 -317
  186. package/dist/contracts-DDrwxvJ-.d.cts +0 -245
  187. package/dist/contracts-DDrwxvJ-.d.ts +0 -245
  188. package/dist/contracts-DOrhwbke.d.cts +0 -245
  189. package/dist/contracts-DOrhwbke.d.ts +0 -245
  190. package/dist/contracts-xo5ckdRP.d.cts +0 -240
  191. package/dist/contracts-xo5ckdRP.d.ts +0 -240
  192. package/dist/customElement-BKQfbSZQ.d.cts +0 -262
  193. package/dist/customElement-BKQfbSZQ.d.ts +0 -262
  194. package/dist/customElement-D2DJp_xn.d.cts +0 -313
  195. package/dist/customElement-D2DJp_xn.d.ts +0 -313
  196. package/dist/customElement-yz8uyk-0.d.cts +0 -308
  197. package/dist/customElement-yz8uyk-0.d.ts +0 -308
  198. package/dist/introspect-Cb0zgpi2.d.cts +0 -477
  199. package/dist/introspect-Y2xNXGSf.d.ts +0 -477
  200. package/dist/plugin-Bek4RhJY.d.cts +0 -43
  201. package/dist/plugin-Bek4RhJY.d.ts +0 -43
  202. package/dist/ssr-3RXHP5ES.js +0 -38
  203. package/dist/ssr-6GIMY5MX.js +0 -38
  204. package/dist/ssr-BA6sxxUd.d.cts +0 -135
  205. package/dist/ssr-BA6sxxUd.d.ts +0 -135
  206. package/dist/ssr-WKUPVSSK.js +0 -36
  207. package/dist/tagFactory-Dl8QCLga.d.cts +0 -23
  208. package/dist/tagFactory-Dl8QCLga.d.ts +0 -23
@@ -1,398 +0,0 @@
1
- import {
2
- signal
3
- } from "./chunk-YECR7UIA.js";
4
-
5
- // src/ui/transition.ts
6
- function transition(element, options = {}) {
7
- const {
8
- property = "all",
9
- duration = 300,
10
- easing = "ease",
11
- delay = 0,
12
- enterClass,
13
- leaveClass,
14
- activeClass,
15
- onEnterDone,
16
- onLeaveDone
17
- } = options;
18
- const transitionValue = `${property} ${duration}ms ${easing} ${delay}ms`;
19
- function enter() {
20
- return new Promise((resolve) => {
21
- element.style.transition = transitionValue;
22
- if (enterClass) element.classList.add(enterClass);
23
- if (leaveClass) element.classList.remove(leaveClass);
24
- void element.offsetHeight;
25
- if (activeClass) element.classList.add(activeClass);
26
- const done = () => {
27
- if (enterClass) element.classList.remove(enterClass);
28
- onEnterDone?.();
29
- resolve();
30
- };
31
- if (duration > 0) {
32
- setTimeout(done, duration + delay);
33
- } else {
34
- done();
35
- }
36
- });
37
- }
38
- function leave() {
39
- return new Promise((resolve) => {
40
- element.style.transition = transitionValue;
41
- if (activeClass) element.classList.remove(activeClass);
42
- if (leaveClass) element.classList.add(leaveClass);
43
- if (enterClass) element.classList.remove(enterClass);
44
- const done = () => {
45
- if (leaveClass) element.classList.remove(leaveClass);
46
- onLeaveDone?.();
47
- resolve();
48
- };
49
- if (duration > 0) {
50
- setTimeout(done, duration + delay);
51
- } else {
52
- done();
53
- }
54
- });
55
- }
56
- return { enter, leave };
57
- }
58
- function spring(element, keyframes, options = {}) {
59
- const defaults = {
60
- duration: 300,
61
- easing: "cubic-bezier(0.34, 1.56, 0.64, 1)",
62
- fill: "forwards"
63
- };
64
- return new Promise((resolve) => {
65
- const animation = element.animate(keyframes, { ...defaults, ...options });
66
- animation.onfinish = () => resolve();
67
- animation.oncancel = () => resolve();
68
- });
69
- }
70
-
71
- // src/ui/animationPresets.ts
72
- var prefersReducedMotion = () => typeof window !== "undefined" && window.matchMedia?.("(prefers-reduced-motion: reduce)").matches;
73
- function createPreset(keyframes, defaults, overrides) {
74
- const opts = {
75
- ...defaults,
76
- ...overrides,
77
- fill: overrides?.fill ?? defaults.fill ?? "forwards"
78
- };
79
- if (prefersReducedMotion()) {
80
- return {
81
- keyframes: [keyframes[keyframes.length - 1]],
82
- options: { ...opts, duration: 0, delay: 0 }
83
- };
84
- }
85
- return { keyframes, options: opts };
86
- }
87
- function applyPreset(el, preset) {
88
- return new Promise((resolve) => {
89
- const anim = el.animate(preset.keyframes, preset.options);
90
- anim.onfinish = () => resolve();
91
- anim.oncancel = () => resolve();
92
- });
93
- }
94
- function fadeIn(opts) {
95
- return createPreset([{ opacity: 0 }, { opacity: 1 }], { duration: 300, easing: "ease-out" }, opts);
96
- }
97
- function fadeOut(opts) {
98
- return createPreset([{ opacity: 1 }, { opacity: 0 }], { duration: 300, easing: "ease-in" }, opts);
99
- }
100
- var slideOffsets = {
101
- up: "translateY(20px)",
102
- down: "translateY(-20px)",
103
- left: "translateX(20px)",
104
- right: "translateX(-20px)"
105
- };
106
- function slideIn(direction = "up", opts) {
107
- return createPreset(
108
- [
109
- { transform: slideOffsets[direction], opacity: 0 },
110
- { transform: "translate(0, 0)", opacity: 1 }
111
- ],
112
- { duration: 400, easing: "cubic-bezier(0.16, 1, 0.3, 1)" },
113
- opts
114
- );
115
- }
116
- function slideOut(direction = "down", opts) {
117
- return createPreset(
118
- [
119
- { transform: "translate(0, 0)", opacity: 1 },
120
- { transform: slideOffsets[direction], opacity: 0 }
121
- ],
122
- { duration: 300, easing: "cubic-bezier(0.4, 0, 1, 1)" },
123
- opts
124
- );
125
- }
126
- function scaleUp(opts) {
127
- return createPreset(
128
- [
129
- { transform: "scale(0.85)", opacity: 0 },
130
- { transform: "scale(1)", opacity: 1 }
131
- ],
132
- { duration: 350, easing: "cubic-bezier(0.34, 1.56, 0.64, 1)" },
133
- opts
134
- );
135
- }
136
- function scaleDown(opts) {
137
- return createPreset(
138
- [
139
- { transform: "scale(1)", opacity: 1 },
140
- { transform: "scale(0.85)", opacity: 0 }
141
- ],
142
- { duration: 250, easing: "ease-in" },
143
- opts
144
- );
145
- }
146
- function bounceIn(opts) {
147
- return createPreset(
148
- [
149
- { transform: "scale(0.3)", opacity: 0 },
150
- { transform: "scale(1.05)", opacity: 0.8, offset: 0.5 },
151
- { transform: "scale(0.95)", opacity: 0.9, offset: 0.7 },
152
- { transform: "scale(1)", opacity: 1 }
153
- ],
154
- { duration: 500, easing: "cubic-bezier(0.34, 1.56, 0.64, 1)" },
155
- opts
156
- );
157
- }
158
- function bounceOut(opts) {
159
- return createPreset(
160
- [
161
- { transform: "scale(1)", opacity: 1 },
162
- { transform: "scale(1.05)", opacity: 0.9, offset: 0.3 },
163
- { transform: "scale(0.3)", opacity: 0 }
164
- ],
165
- { duration: 400, easing: "ease-in" },
166
- opts
167
- );
168
- }
169
- function flipIn(axis = "x", opts) {
170
- const prop = axis === "x" ? "rotateX" : "rotateY";
171
- return createPreset(
172
- [
173
- { transform: `perspective(400px) ${prop}(90deg)`, opacity: 0 },
174
- { transform: `perspective(400px) ${prop}(-10deg)`, opacity: 1, offset: 0.6 },
175
- { transform: `perspective(400px) ${prop}(0deg)`, opacity: 1 }
176
- ],
177
- { duration: 500, easing: "ease-out" },
178
- opts
179
- );
180
- }
181
- function shake(opts) {
182
- return createPreset(
183
- [
184
- { transform: "translateX(0)" },
185
- { transform: "translateX(-8px)", offset: 0.1 },
186
- { transform: "translateX(8px)", offset: 0.2 },
187
- { transform: "translateX(-6px)", offset: 0.3 },
188
- { transform: "translateX(6px)", offset: 0.4 },
189
- { transform: "translateX(-4px)", offset: 0.5 },
190
- { transform: "translateX(4px)", offset: 0.6 },
191
- { transform: "translateX(-2px)", offset: 0.7 },
192
- { transform: "translateX(0)" }
193
- ],
194
- { duration: 500, easing: "ease-out", fill: "none" },
195
- opts
196
- );
197
- }
198
- function pulse(opts) {
199
- return createPreset(
200
- [{ transform: "scale(1)" }, { transform: "scale(1.08)", offset: 0.5 }, { transform: "scale(1)" }],
201
- { duration: 400, easing: "ease-in-out", fill: "none" },
202
- opts
203
- );
204
- }
205
- function animate(el, preset) {
206
- return applyPreset(el, preset);
207
- }
208
- function stagger(elements, preset, delayBetween = 50) {
209
- const promises = elements.map(
210
- (el, i) => applyPreset(el, {
211
- keyframes: preset.keyframes,
212
- options: {
213
- ...preset.options,
214
- delay: (preset.options.delay || 0) + i * delayBetween
215
- }
216
- })
217
- );
218
- return Promise.all(promises).then(() => {
219
- });
220
- }
221
- async function sequence(steps) {
222
- for (const step of steps) {
223
- await applyPreset(step.el, step.preset);
224
- }
225
- }
226
-
227
- // src/ui/TransitionGroup.ts
228
- function TransitionGroup(options) {
229
- const [elements, setElements] = signal([]);
230
- const positions = /* @__PURE__ */ new Map();
231
- function add(el) {
232
- setElements((prev) => [...prev, el]);
233
- if (options.enter) {
234
- options.enter(el);
235
- }
236
- }
237
- async function remove(el) {
238
- if (options.leave) {
239
- await options.leave(el);
240
- }
241
- setElements((prev) => prev.filter((e) => e !== el));
242
- }
243
- function track(newElements) {
244
- const oldPositions = /* @__PURE__ */ new Map();
245
- for (const el of elements()) {
246
- if (typeof el.getBoundingClientRect === "function") {
247
- oldPositions.set(el, el.getBoundingClientRect());
248
- }
249
- }
250
- const currentSet = new Set(elements());
251
- for (const el of newElements) {
252
- if (!currentSet.has(el)) {
253
- if (options.enter) {
254
- options.enter(el);
255
- }
256
- }
257
- }
258
- const newSet = new Set(newElements);
259
- for (const el of elements()) {
260
- if (!newSet.has(el)) {
261
- if (options.leave) {
262
- options.leave(el);
263
- }
264
- }
265
- }
266
- setElements(newElements);
267
- if (options.move) {
268
- for (const el of newElements) {
269
- const oldRect = oldPositions.get(el);
270
- if (oldRect && typeof el.getBoundingClientRect === "function") {
271
- const newRect = el.getBoundingClientRect();
272
- if (oldRect.left !== newRect.left || oldRect.top !== newRect.top) {
273
- options.move(el);
274
- }
275
- }
276
- }
277
- }
278
- positions.clear();
279
- for (const el of newElements) {
280
- if (typeof el.getBoundingClientRect === "function") {
281
- positions.set(el, el.getBoundingClientRect());
282
- }
283
- }
284
- }
285
- return { add, remove, track };
286
- }
287
-
288
- // src/ui/viewTransition.ts
289
- function viewTransition(callback) {
290
- const [isTransitioning, setIsTransitioning] = signal(false);
291
- async function start() {
292
- setIsTransitioning(true);
293
- try {
294
- if (typeof document !== "undefined" && "startViewTransition" in document && typeof document.startViewTransition === "function") {
295
- const transition2 = document.startViewTransition(callback);
296
- await transition2.finished;
297
- } else {
298
- await callback();
299
- }
300
- } finally {
301
- setIsTransitioning(false);
302
- }
303
- }
304
- return { start, isTransitioning };
305
- }
306
-
307
- // src/ui/reducedMotion.ts
308
- function reducedMotion() {
309
- if (typeof window === "undefined" || typeof window.matchMedia !== "function") {
310
- const [reduced2] = signal(false);
311
- return { reduced: reduced2, dispose: () => {
312
- } };
313
- }
314
- const mql = window.matchMedia("(prefers-reduced-motion: reduce)");
315
- const [reduced, setReduced] = signal(mql.matches);
316
- const handler = (event) => {
317
- setReduced(event.matches);
318
- };
319
- mql.addEventListener("change", handler);
320
- function dispose() {
321
- mql.removeEventListener("change", handler);
322
- }
323
- return { reduced, dispose };
324
- }
325
-
326
- // src/ui/springSignal.ts
327
- var prefersReducedMotion2 = () => typeof window !== "undefined" && !!window.matchMedia?.("(prefers-reduced-motion: reduce)").matches;
328
- function springSignal(initial, options) {
329
- const stiffness = options?.stiffness ?? 0.15;
330
- const damping = options?.damping ?? 0.8;
331
- const precision = options?.precision ?? 0.01;
332
- const [value, setValue] = signal(initial);
333
- let current = initial;
334
- let velocity = 0;
335
- let target = initial;
336
- let rafId = null;
337
- function tick() {
338
- const force = -stiffness * (current - target);
339
- const dampingForce = -damping * velocity;
340
- velocity += force + dampingForce;
341
- current += velocity;
342
- if (Math.abs(current - target) < precision && Math.abs(velocity) < precision) {
343
- current = target;
344
- velocity = 0;
345
- rafId = null;
346
- setValue(current);
347
- return;
348
- }
349
- setValue(current);
350
- rafId = requestAnimationFrame(tick);
351
- }
352
- function set(newTarget) {
353
- target = newTarget;
354
- if (prefersReducedMotion2()) {
355
- current = newTarget;
356
- velocity = 0;
357
- if (rafId !== null) {
358
- cancelAnimationFrame(rafId);
359
- rafId = null;
360
- }
361
- setValue(current);
362
- return;
363
- }
364
- if (rafId === null) {
365
- rafId = requestAnimationFrame(tick);
366
- }
367
- }
368
- function dispose() {
369
- if (rafId !== null) {
370
- cancelAnimationFrame(rafId);
371
- rafId = null;
372
- }
373
- }
374
- return [value, set, dispose];
375
- }
376
-
377
- export {
378
- transition,
379
- spring,
380
- fadeIn,
381
- fadeOut,
382
- slideIn,
383
- slideOut,
384
- scaleUp,
385
- scaleDown,
386
- bounceIn,
387
- bounceOut,
388
- flipIn,
389
- shake,
390
- pulse,
391
- animate,
392
- stagger,
393
- sequence,
394
- TransitionGroup,
395
- viewTransition,
396
- reducedMotion,
397
- springSignal
398
- };