@jayf0x/fluidity-js 0.1.5 → 0.1.6
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/README.md +11 -1
- package/dist/globals.d.ts +15 -2
- package/dist/index.js +459 -426
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
var
|
|
2
|
-
var
|
|
3
|
-
var
|
|
1
|
+
var $I = Object.defineProperty;
|
|
2
|
+
var Ig = (C, I, i) => I in C ? $I(C, I, { enumerable: !0, configurable: !0, writable: !0, value: i }) : C[I] = i;
|
|
3
|
+
var yI = (C, I, i) => (Ig(C, typeof I != "symbol" ? I + "" : I, i), i), UI = (C, I, i) => {
|
|
4
4
|
if (!I.has(C))
|
|
5
5
|
throw TypeError("Cannot " + i);
|
|
6
6
|
};
|
|
7
|
-
var g = (C, I, i) => (
|
|
7
|
+
var g = (C, I, i) => (UI(C, I, "read from private field"), i ? i.call(C) : I.get(C)), m = (C, I, i) => {
|
|
8
8
|
if (I.has(C))
|
|
9
9
|
throw TypeError("Cannot add the same private member more than once");
|
|
10
10
|
I instanceof WeakSet ? I.add(C) : I.set(C, i);
|
|
11
|
-
},
|
|
12
|
-
var b = (C, I, i) => (
|
|
13
|
-
import { jsx as
|
|
14
|
-
import { useRef as
|
|
15
|
-
const
|
|
11
|
+
}, l = (C, I, i, e) => (UI(C, I, "write to private field"), e ? e.call(C, i) : I.set(C, i), i);
|
|
12
|
+
var b = (C, I, i) => (UI(C, I, "access private method"), i);
|
|
13
|
+
import { jsx as NI } from "react/jsx-runtime";
|
|
14
|
+
import { useRef as mI, useEffect as j, forwardRef as zI, useImperativeHandle as QI } from "react";
|
|
15
|
+
const OI = {
|
|
16
16
|
densityDissipation: 0.992,
|
|
17
17
|
velocityDissipation: 0.93,
|
|
18
18
|
pressureIterations: 1,
|
|
@@ -26,8 +26,8 @@ const JI = {
|
|
|
26
26
|
glowColor: [0.7, 0.85, 1],
|
|
27
27
|
algorithm: "standard",
|
|
28
28
|
warpStrength: 0.015
|
|
29
|
-
},
|
|
30
|
-
...
|
|
29
|
+
}, TI = {
|
|
30
|
+
...OI,
|
|
31
31
|
densityDissipation: 0.99,
|
|
32
32
|
velocityDissipation: 0.98,
|
|
33
33
|
pressureIterations: 3,
|
|
@@ -38,22 +38,23 @@ const JI = {
|
|
|
38
38
|
specularExp: 1,
|
|
39
39
|
shine: 0.1,
|
|
40
40
|
glowColor: [0, 0.502, 1]
|
|
41
|
-
},
|
|
41
|
+
}, gg = { dpr: 1, sim: 0.5 }, HI = {
|
|
42
42
|
backgroundColor: "#0a0a0a",
|
|
43
43
|
backgroundSize: "cover",
|
|
44
44
|
isMouseEnabled: !0,
|
|
45
|
-
isWorkerEnabled: !0
|
|
46
|
-
|
|
47
|
-
|
|
45
|
+
isWorkerEnabled: !0,
|
|
46
|
+
quality: gg
|
|
47
|
+
}, iI = {
|
|
48
|
+
...HI,
|
|
48
49
|
effect: 0,
|
|
49
50
|
imageSize: "cover"
|
|
50
|
-
},
|
|
51
|
-
...
|
|
51
|
+
}, $ = {
|
|
52
|
+
...HI,
|
|
52
53
|
fontSize: 100,
|
|
53
54
|
color: "#ffffff",
|
|
54
55
|
fontFamily: "sans-serif",
|
|
55
56
|
fontWeight: 900
|
|
56
|
-
},
|
|
57
|
+
}, ig = {
|
|
57
58
|
calm: {
|
|
58
59
|
densityDissipation: 0.999,
|
|
59
60
|
velocityDissipation: 0.98,
|
|
@@ -112,73 +113,73 @@ const JI = {
|
|
|
112
113
|
waterColor: [0.06, 0.06, 0.06]
|
|
113
114
|
}
|
|
114
115
|
};
|
|
115
|
-
function
|
|
116
|
-
return { ...I ? { ...i, ...
|
|
116
|
+
function pI(C = {}, I, i = OI) {
|
|
117
|
+
return { ...I ? { ...i, ...ig[I] } : i, ...C };
|
|
117
118
|
}
|
|
118
|
-
function
|
|
119
|
-
let
|
|
120
|
-
|
|
121
|
-
const t = C *
|
|
122
|
-
return { x: (i - t) / 2, y: (e -
|
|
119
|
+
function vI(C, I, i, e, s = "cover") {
|
|
120
|
+
let o;
|
|
121
|
+
s === "cover" ? o = Math.max(i / C, e / I) : s === "contain" ? o = Math.min(i / C, e / I) : typeof s == "string" && s.endsWith("%") ? o = Math.min(i / C, e / I) * (parseFloat(s) / 100) : typeof s == "string" && s.endsWith("px") ? o = parseFloat(s) / Math.max(C, I) : typeof s == "number" ? o = s : o = Math.max(i / C, e / I);
|
|
122
|
+
const t = C * o, u = I * o;
|
|
123
|
+
return { x: (i - t) / 2, y: (e - u) / 2, drawW: t, drawH: u };
|
|
123
124
|
}
|
|
124
|
-
function
|
|
125
|
-
const { text: t, fontSize:
|
|
126
|
-
((
|
|
127
|
-
if (
|
|
128
|
-
|
|
129
|
-
const { x:
|
|
130
|
-
|
|
131
|
-
|
|
125
|
+
function Cg(C, I, i, e, s = null, o = "cover") {
|
|
126
|
+
const { text: t, fontSize: u, color: a, fontFamily: c = "sans-serif", fontWeight: n = 900 } = e, G = new OffscreenCanvas(I, i), d = G.getContext("2d");
|
|
127
|
+
((F) => {
|
|
128
|
+
if (s) {
|
|
129
|
+
d.clearRect(0, 0, I, i), d.fillStyle = "black", d.fillRect(0, 0, I, i);
|
|
130
|
+
const { x: w, y: D, drawW: A, drawH: y } = vI(
|
|
131
|
+
s.width,
|
|
132
|
+
s.height,
|
|
132
133
|
I,
|
|
133
134
|
i,
|
|
134
|
-
|
|
135
|
+
o
|
|
135
136
|
);
|
|
136
|
-
|
|
137
|
+
d.drawImage(s, w, D, A, y);
|
|
137
138
|
} else
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
})(
|
|
141
|
-
const
|
|
142
|
-
|
|
143
|
-
const
|
|
144
|
-
return { backgroundTex:
|
|
139
|
+
d.fillStyle = "black", d.fillRect(0, 0, I, i);
|
|
140
|
+
d.fillStyle = F, d.font = `${n} ${u}px ${c}`, d.textAlign = "center", d.textBaseline = "middle", d.fillText(t, I / 2, i / 2);
|
|
141
|
+
})(a);
|
|
142
|
+
const W = BI(C, G);
|
|
143
|
+
d.fillStyle = "black", d.fillRect(0, 0, I, i), d.fillStyle = "white", d.font = `${n} ${u}px ${c}`, d.textAlign = "center", d.textBaseline = "middle", d.fillText(t, I / 2, i / 2);
|
|
144
|
+
const x = BI(C, G);
|
|
145
|
+
return { backgroundTex: W, obstacleTex: x, coverageTex: x };
|
|
145
146
|
}
|
|
146
|
-
function
|
|
147
|
-
const
|
|
148
|
-
if (
|
|
147
|
+
function eg(C, I, i, e, s = 0, o = "cover", t = null, u = "cover") {
|
|
148
|
+
const a = new OffscreenCanvas(i, e), c = a.getContext("2d"), { x: n, y: G, drawW: d, drawH: h } = vI(I.width, I.height, i, e, o);
|
|
149
|
+
if (c.clearRect(0, 0, i, e), c.fillStyle = "black", c.fillRect(0, 0, i, e), t) {
|
|
149
150
|
const {
|
|
150
|
-
x:
|
|
151
|
-
y:
|
|
152
|
-
drawW:
|
|
153
|
-
drawH:
|
|
154
|
-
} =
|
|
155
|
-
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
const
|
|
159
|
-
|
|
160
|
-
const
|
|
161
|
-
|
|
162
|
-
Math.max(0,
|
|
163
|
-
Math.max(0,
|
|
164
|
-
Math.min(
|
|
165
|
-
Math.min(h, e - Math.max(0,
|
|
151
|
+
x: w,
|
|
152
|
+
y: D,
|
|
153
|
+
drawW: A,
|
|
154
|
+
drawH: y
|
|
155
|
+
} = vI(t.width, t.height, i, e, u);
|
|
156
|
+
c.filter = `brightness(${s}) blur(8px)`, c.drawImage(t, w, D, A, y), c.filter = "none";
|
|
157
|
+
}
|
|
158
|
+
c.drawImage(I, n, G, d, h);
|
|
159
|
+
const W = BI(C, a);
|
|
160
|
+
c.clearRect(0, 0, i, e), c.fillStyle = "black", c.fillRect(0, 0, i, e), c.filter = `brightness(${s}) blur(8px)`, c.drawImage(I, n, G, d, h), c.filter = "none";
|
|
161
|
+
const x = BI(C, a);
|
|
162
|
+
c.clearRect(0, 0, i, e), c.fillStyle = "black", c.fillRect(0, 0, i, e), c.fillStyle = "white", c.fillRect(
|
|
163
|
+
Math.max(0, n),
|
|
164
|
+
Math.max(0, G),
|
|
165
|
+
Math.min(d, i - Math.max(0, n)),
|
|
166
|
+
Math.min(h, e - Math.max(0, G))
|
|
166
167
|
);
|
|
167
|
-
const
|
|
168
|
-
return { backgroundTex:
|
|
168
|
+
const F = BI(C, a);
|
|
169
|
+
return { backgroundTex: W, obstacleTex: x, coverageTex: F };
|
|
169
170
|
}
|
|
170
|
-
function
|
|
171
|
+
function BI(C, I) {
|
|
171
172
|
const i = C.createTexture();
|
|
172
173
|
return C.bindTexture(C.TEXTURE_2D, i), C.pixelStorei(C.UNPACK_FLIP_Y_WEBGL, !0), C.texImage2D(C.TEXTURE_2D, 0, C.RGBA, C.RGBA, C.UNSIGNED_BYTE, I), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MIN_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MAG_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_S, C.CLAMP_TO_EDGE), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_T, C.CLAMP_TO_EDGE), i;
|
|
173
174
|
}
|
|
174
|
-
async function
|
|
175
|
+
async function kI(C) {
|
|
175
176
|
const I = await fetch(C);
|
|
176
177
|
if (!I.ok)
|
|
177
178
|
throw new Error(`Failed to fetch image: ${C} (${I.status})`);
|
|
178
179
|
const i = await I.blob();
|
|
179
180
|
return createImageBitmap(i);
|
|
180
181
|
}
|
|
181
|
-
const
|
|
182
|
+
const II = (
|
|
182
183
|
/* glsl */
|
|
183
184
|
`
|
|
184
185
|
precision highp float;
|
|
@@ -195,7 +196,7 @@ const P = (
|
|
|
195
196
|
gl_Position = vec4(aPosition, 0.0, 1.0);
|
|
196
197
|
}
|
|
197
198
|
`
|
|
198
|
-
),
|
|
199
|
+
), sg = (
|
|
199
200
|
/* glsl */
|
|
200
201
|
`
|
|
201
202
|
precision highp float;
|
|
@@ -212,7 +213,7 @@ const P = (
|
|
|
212
213
|
gl_FragColor = dissipation * texture2D(uSource, coord);
|
|
213
214
|
}
|
|
214
215
|
`
|
|
215
|
-
),
|
|
216
|
+
), lg = (
|
|
216
217
|
/* glsl */
|
|
217
218
|
`
|
|
218
219
|
precision highp float;
|
|
@@ -227,7 +228,7 @@ const P = (
|
|
|
227
228
|
gl_FragColor = vec4(0.5 * (R - L + T - B), 0.0, 0.0, 1.0);
|
|
228
229
|
}
|
|
229
230
|
`
|
|
230
|
-
),
|
|
231
|
+
), og = (
|
|
231
232
|
/* glsl */
|
|
232
233
|
`
|
|
233
234
|
precision highp float;
|
|
@@ -245,7 +246,7 @@ const P = (
|
|
|
245
246
|
gl_FragColor = vec4((L + R + B + T - div) * 0.25, 0.0, 0.0, 1.0);
|
|
246
247
|
}
|
|
247
248
|
`
|
|
248
|
-
),
|
|
249
|
+
), tg = (
|
|
249
250
|
/* glsl */
|
|
250
251
|
`
|
|
251
252
|
precision highp float;
|
|
@@ -263,7 +264,7 @@ const P = (
|
|
|
263
264
|
gl_FragColor = vec4(vel, 0.0, 1.0);
|
|
264
265
|
}
|
|
265
266
|
`
|
|
266
|
-
),
|
|
267
|
+
), cg = (
|
|
267
268
|
/* glsl */
|
|
268
269
|
`
|
|
269
270
|
precision highp float;
|
|
@@ -280,7 +281,7 @@ const P = (
|
|
|
280
281
|
gl_FragColor = vec4(texture2D(uTarget, vUv).xyz + splat, 1.0);
|
|
281
282
|
}
|
|
282
283
|
`
|
|
283
|
-
),
|
|
284
|
+
), ag = (
|
|
284
285
|
/* glsl */
|
|
285
286
|
`
|
|
286
287
|
precision highp float;
|
|
@@ -294,7 +295,7 @@ const P = (
|
|
|
294
295
|
gl_FragColor = vec4(0.5 * (R - L - T + B), 0.0, 0.0, 1.0);
|
|
295
296
|
}
|
|
296
297
|
`
|
|
297
|
-
),
|
|
298
|
+
), dg = (
|
|
298
299
|
/* glsl */
|
|
299
300
|
`
|
|
300
301
|
precision highp float;
|
|
@@ -315,7 +316,7 @@ const P = (
|
|
|
315
316
|
gl_FragColor = vec4(texture2D(uVelocity, vUv).xy + force * dt, 0.0, 1.0);
|
|
316
317
|
}
|
|
317
318
|
`
|
|
318
|
-
),
|
|
319
|
+
), Ag = (
|
|
319
320
|
/* glsl */
|
|
320
321
|
`
|
|
321
322
|
precision highp float;
|
|
@@ -416,37 +417,37 @@ const P = (
|
|
|
416
417
|
}
|
|
417
418
|
`
|
|
418
419
|
);
|
|
419
|
-
function
|
|
420
|
+
function mg(C) {
|
|
420
421
|
const I = { alpha: !0, depth: !1, stencil: !1, antialias: !0, preserveDrawingBuffer: !1 };
|
|
421
422
|
let i = C.getContext("webgl2", I);
|
|
422
423
|
const e = !!i;
|
|
423
424
|
e || (i = C.getContext("webgl", I), i.getExtension("EXT_color_buffer_half_float"));
|
|
424
|
-
const
|
|
425
|
+
const s = e ? null : i.getExtension("OES_texture_half_float"), o = e ? i.HALF_FLOAT : s.HALF_FLOAT_OES;
|
|
425
426
|
return i.getExtension("EXT_color_buffer_float"), i.getExtension("OES_texture_half_float_linear"), {
|
|
426
427
|
gl: i,
|
|
427
428
|
isWebGL2: e,
|
|
428
429
|
ext: {
|
|
429
430
|
internalFormat: e ? i.RGBA16F : i.RGBA,
|
|
430
431
|
format: i.RGBA,
|
|
431
|
-
type:
|
|
432
|
+
type: o
|
|
432
433
|
}
|
|
433
434
|
};
|
|
434
435
|
}
|
|
435
|
-
class
|
|
436
|
+
class gI {
|
|
436
437
|
constructor(I, i, e) {
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
438
|
+
yI(this, "program");
|
|
439
|
+
yI(this, "uniforms", {});
|
|
440
|
+
yI(this, "_gl");
|
|
440
441
|
this._gl = I, this.program = I.createProgram(), I.attachShader(this.program, this._compile(I.VERTEX_SHADER, i)), I.attachShader(this.program, this._compile(I.FRAGMENT_SHADER, e)), I.linkProgram(this.program);
|
|
441
|
-
const
|
|
442
|
-
for (let
|
|
443
|
-
const t = I.getActiveUniform(this.program,
|
|
442
|
+
const s = I.getProgramParameter(this.program, I.ACTIVE_UNIFORMS);
|
|
443
|
+
for (let o = 0; o < s; o++) {
|
|
444
|
+
const t = I.getActiveUniform(this.program, o).name;
|
|
444
445
|
this.uniforms[t] = I.getUniformLocation(this.program, t);
|
|
445
446
|
}
|
|
446
447
|
}
|
|
447
448
|
_compile(I, i) {
|
|
448
|
-
const e = this._gl,
|
|
449
|
-
return e.shaderSource(
|
|
449
|
+
const e = this._gl, s = e.createShader(I);
|
|
450
|
+
return e.shaderSource(s, i), e.compileShader(s), s;
|
|
450
451
|
}
|
|
451
452
|
bind() {
|
|
452
453
|
this._gl.useProgram(this.program);
|
|
@@ -455,117 +456,119 @@ class _ {
|
|
|
455
456
|
this._gl.deleteProgram(this.program);
|
|
456
457
|
}
|
|
457
458
|
}
|
|
458
|
-
function
|
|
459
|
+
function rg(C) {
|
|
459
460
|
return {
|
|
460
|
-
advection: new
|
|
461
|
-
divergence: new
|
|
462
|
-
pressure: new
|
|
463
|
-
gradientSubtract: new
|
|
464
|
-
splat: new
|
|
465
|
-
curl: new
|
|
466
|
-
vorticity: new
|
|
467
|
-
display: new
|
|
461
|
+
advection: new gI(C, II, sg),
|
|
462
|
+
divergence: new gI(C, II, lg),
|
|
463
|
+
pressure: new gI(C, II, og),
|
|
464
|
+
gradientSubtract: new gI(C, II, tg),
|
|
465
|
+
splat: new gI(C, II, cg),
|
|
466
|
+
curl: new gI(C, II, ag),
|
|
467
|
+
vorticity: new gI(C, II, dg),
|
|
468
|
+
display: new gI(C, II, Ag)
|
|
468
469
|
};
|
|
469
470
|
}
|
|
470
|
-
function
|
|
471
|
+
function KI(C, I, i, e) {
|
|
471
472
|
C.activeTexture(C.TEXTURE0);
|
|
472
|
-
const
|
|
473
|
-
C.bindTexture(C.TEXTURE_2D,
|
|
474
|
-
const
|
|
475
|
-
return C.bindFramebuffer(C.FRAMEBUFFER,
|
|
473
|
+
const s = C.createTexture();
|
|
474
|
+
C.bindTexture(C.TEXTURE_2D, s), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MIN_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MAG_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_S, C.CLAMP_TO_EDGE), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_T, C.CLAMP_TO_EDGE), C.texImage2D(C.TEXTURE_2D, 0, I.internalFormat, i, e, 0, I.format, I.type, null);
|
|
475
|
+
const o = C.createFramebuffer();
|
|
476
|
+
return C.bindFramebuffer(C.FRAMEBUFFER, o), C.framebufferTexture2D(C.FRAMEBUFFER, C.COLOR_ATTACHMENT0, C.TEXTURE_2D, s, 0), { tex: s, fbo: o, width: i, height: e };
|
|
476
477
|
}
|
|
477
|
-
function
|
|
478
|
-
let
|
|
478
|
+
function WI(C, I, i, e) {
|
|
479
|
+
let s = KI(C, I, i, e), o = KI(C, I, i, e);
|
|
479
480
|
return {
|
|
480
481
|
get read() {
|
|
481
|
-
return
|
|
482
|
+
return s;
|
|
482
483
|
},
|
|
483
484
|
get write() {
|
|
484
|
-
return
|
|
485
|
+
return o;
|
|
485
486
|
},
|
|
486
487
|
swap() {
|
|
487
|
-
[
|
|
488
|
+
[s, o] = [o, s];
|
|
488
489
|
},
|
|
489
490
|
dispose() {
|
|
490
|
-
C.deleteTexture(
|
|
491
|
+
C.deleteTexture(s.tex), C.deleteFramebuffer(s.fbo), C.deleteTexture(o.tex), C.deleteFramebuffer(o.fbo);
|
|
491
492
|
}
|
|
492
493
|
};
|
|
493
494
|
}
|
|
494
|
-
function
|
|
495
|
+
function ng(C) {
|
|
495
496
|
const I = C.createBuffer();
|
|
496
497
|
return C.bindBuffer(C.ARRAY_BUFFER, I), C.bufferData(C.ARRAY_BUFFER, new Float32Array([-1, -1, -1, 1, 1, 1, 1, -1]), C.STATIC_DRAW), C.vertexAttribPointer(0, 2, C.FLOAT, !1, 0, 0), C.enableVertexAttribArray(0), function(e) {
|
|
497
498
|
C.bindFramebuffer(C.FRAMEBUFFER, e), C.drawArrays(C.TRIANGLE_FAN, 0, 4);
|
|
498
499
|
};
|
|
499
500
|
}
|
|
500
|
-
const
|
|
501
|
-
var
|
|
502
|
-
class
|
|
503
|
-
constructor(I, i = {}) {
|
|
501
|
+
const xI = typeof requestAnimationFrame < "u" ? requestAnimationFrame.bind(globalThis) : (C) => setTimeout(C, 1e3 / 60), ug = typeof cancelAnimationFrame < "u" ? cancelAnimationFrame.bind(globalThis) : clearTimeout, MI = 0.016, Zg = { standard: 0, glass: 1, ink: 2, aurora: 3, ripple: 4 };
|
|
502
|
+
var lI, X, SI, oI, rI, K, R, CI, eI, k, nI, P, H, B, E, J, N, _, v, z, f, uI, tI, L, Y, Q, cI, bI, aI, GI, LI, YI, sI, AI, dI, hI, VI, FI, wI, DI, RI, jI;
|
|
503
|
+
class EI {
|
|
504
|
+
constructor(I, i = {}, e = {}) {
|
|
504
505
|
// ---------------------------------------------------------------------------
|
|
505
506
|
// Private helpers
|
|
506
507
|
// ---------------------------------------------------------------------------
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
508
|
+
m(this, aI);
|
|
509
|
+
m(this, LI);
|
|
510
|
+
m(this, sI);
|
|
511
|
+
m(this, dI);
|
|
512
|
+
m(this, VI);
|
|
513
|
+
m(this, wI);
|
|
514
|
+
m(this, RI);
|
|
515
|
+
m(this, lI, void 0);
|
|
516
|
+
m(this, X, void 0);
|
|
517
|
+
m(this, SI, void 0);
|
|
518
|
+
m(this, oI, void 0);
|
|
519
|
+
m(this, rI, void 0);
|
|
520
|
+
m(this, K, 0);
|
|
521
|
+
m(this, R, 0);
|
|
522
|
+
m(this, CI, 0);
|
|
523
|
+
m(this, eI, 0);
|
|
524
|
+
m(this, k, 1);
|
|
525
|
+
m(this, nI, 1);
|
|
526
|
+
m(this, P, 0.5);
|
|
527
|
+
m(this, H, null);
|
|
528
|
+
m(this, B, null);
|
|
529
|
+
m(this, E, null);
|
|
530
|
+
m(this, J, null);
|
|
531
|
+
m(this, N, null);
|
|
532
|
+
m(this, _, null);
|
|
533
|
+
m(this, v, null);
|
|
534
|
+
m(this, z, null);
|
|
532
535
|
// binary content mask for transparent canvas support
|
|
533
|
-
|
|
536
|
+
m(this, f, null);
|
|
534
537
|
// optional background image (from backgroundSrc prop)
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
+
m(this, uI, "cover");
|
|
539
|
+
m(this, tI, void 0);
|
|
540
|
+
m(this, L, { x: 0, y: 0, dx: 0, dy: 0, targetX: 0, targetY: 0, moved: !1 });
|
|
538
541
|
// Stores source so textures can be rebuilt on resize
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
const { gl:
|
|
545
|
-
|
|
542
|
+
m(this, Y, null);
|
|
543
|
+
m(this, Q, null);
|
|
544
|
+
m(this, cI, !1);
|
|
545
|
+
m(this, bI, !1);
|
|
546
|
+
l(this, lI, I), l(this, nI, Math.max(0.1, Math.min(1, e.dpr ?? 1))), l(this, P, Math.max(0.1, Math.min(1, e.sim ?? 0.5))), l(this, tI, pI(i));
|
|
547
|
+
const { gl: s, ext: o } = mg(I);
|
|
548
|
+
l(this, X, s), l(this, SI, o), l(this, oI, rg(s)), l(this, rI, ng(s)), s.clearColor(0, 0, 0, 0);
|
|
546
549
|
}
|
|
547
550
|
// ---------------------------------------------------------------------------
|
|
548
551
|
// Public API
|
|
549
552
|
// ---------------------------------------------------------------------------
|
|
550
553
|
setTextSource(I) {
|
|
551
|
-
|
|
554
|
+
l(this, Y, { type: "text", opts: I }), b(this, aI, GI).call(this), b(this, sI, AI).call(this), b(this, dI, hI).call(this);
|
|
552
555
|
}
|
|
553
556
|
async setImageSource(I, i = 0, e = "cover") {
|
|
554
|
-
const
|
|
555
|
-
if (g(this,
|
|
556
|
-
|
|
557
|
+
const s = await kI(I);
|
|
558
|
+
if (g(this, bI)) {
|
|
559
|
+
s.close();
|
|
557
560
|
return;
|
|
558
561
|
}
|
|
559
|
-
|
|
562
|
+
l(this, Y, { type: "image", bitmap: s, effect: i, size: e }), b(this, aI, GI).call(this), b(this, sI, AI).call(this), b(this, dI, hI).call(this);
|
|
560
563
|
}
|
|
561
564
|
setImageBitmap(I, i = 0, e = "cover") {
|
|
562
|
-
|
|
565
|
+
l(this, Y, { type: "image", bitmap: I, effect: i, size: e }), b(this, aI, GI).call(this), b(this, sI, AI).call(this), b(this, dI, hI).call(this);
|
|
563
566
|
}
|
|
564
567
|
setBackground(I, i = "cover") {
|
|
565
|
-
g(this,
|
|
568
|
+
g(this, f) && g(this, f) !== I && g(this, f).close(), l(this, f, I), l(this, uI, i ?? "cover"), g(this, Y) && g(this, K) > 0 && g(this, R) > 0 && b(this, sI, AI).call(this);
|
|
566
569
|
}
|
|
567
570
|
handleMove(I, i, e = 1) {
|
|
568
|
-
g(this,
|
|
571
|
+
g(this, L).moved = !0, g(this, L).dx = (I - g(this, L).targetX) * e, g(this, L).dy = (i - g(this, L).targetY) * e, g(this, L).targetX = I, g(this, L).targetY = i;
|
|
569
572
|
}
|
|
570
573
|
/**
|
|
571
574
|
* Immediately applies one fluid splat at (x, y) with explicit velocity (vx, vy).
|
|
@@ -574,29 +577,32 @@ class fI {
|
|
|
574
577
|
* where you want N independent injection points per frame without flooding the
|
|
575
578
|
* mouse-state machine or the worker message queue.
|
|
576
579
|
*/
|
|
577
|
-
splat(I, i, e,
|
|
578
|
-
if (!g(this,
|
|
580
|
+
splat(I, i, e, s, o = 1) {
|
|
581
|
+
if (!g(this, cI) || g(this, K) === 0)
|
|
579
582
|
return;
|
|
580
|
-
const t = g(this,
|
|
581
|
-
t.viewport(0, 0, g(this,
|
|
583
|
+
const t = g(this, X), u = g(this, tI), { splat: a } = g(this, oI), c = g(this, rI);
|
|
584
|
+
t.viewport(0, 0, g(this, CI), g(this, eI)), a.bind(), t.uniform1f(a.uniforms.aspectRatio, g(this, K) / g(this, R)), t.uniform2f(a.uniforms.point, I * g(this, k) / g(this, K), 1 - i * g(this, k) / g(this, R)), t.uniform1f(a.uniforms.radius, u.splatRadius), t.uniform1i(a.uniforms.uTarget, 0), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, g(this, B).read.tex), t.uniform3f(a.uniforms.color, e * u.splatForce * o, -s * u.splatForce * o, 0), c(g(this, B).write.fbo), g(this, B).swap(), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, g(this, H).read.tex), t.uniform3f(a.uniforms.color, o, o, o), c(g(this, H).write.fbo), g(this, H).swap();
|
|
585
|
+
}
|
|
586
|
+
updateQuality(I) {
|
|
587
|
+
I.dpr !== void 0 && l(this, nI, Math.max(0.1, Math.min(1, I.dpr))), I.sim !== void 0 && l(this, P, Math.max(0.1, Math.min(1, I.sim)));
|
|
582
588
|
}
|
|
583
589
|
resize(I, i, e) {
|
|
584
|
-
if (e !== void 0 ?
|
|
590
|
+
if (e !== void 0 ? l(this, k, e) : typeof window < "u" && window.devicePixelRatio && l(this, k, window.devicePixelRatio), I !== void 0 && I > 0) {
|
|
585
591
|
if (i === void 0 || i <= 0)
|
|
586
592
|
return;
|
|
587
|
-
|
|
593
|
+
l(this, K, g(this, lI).width = I), l(this, R, g(this, lI).height = i), l(this, CI, Math.max(1, Math.round(I * g(this, P)))), l(this, eI, Math.max(1, Math.round(i * g(this, P)))), b(this, LI, YI).call(this);
|
|
588
594
|
} else
|
|
589
|
-
b(this,
|
|
590
|
-
g(this,
|
|
595
|
+
b(this, aI, GI).call(this);
|
|
596
|
+
g(this, Y) && b(this, sI, AI).call(this), b(this, dI, hI).call(this);
|
|
591
597
|
}
|
|
592
598
|
updateConfig(I) {
|
|
593
|
-
Object.assign(g(this,
|
|
599
|
+
Object.assign(g(this, tI), I);
|
|
594
600
|
}
|
|
595
601
|
destroy() {
|
|
596
|
-
|
|
597
|
-
const I = g(this,
|
|
598
|
-
b(this,
|
|
599
|
-
for (const e of Object.values(g(this,
|
|
602
|
+
l(this, bI, !0), this.stop();
|
|
603
|
+
const I = g(this, X);
|
|
604
|
+
b(this, VI, FI).call(this), b(this, wI, DI).call(this), g(this, f) && (g(this, f).close(), l(this, f, null));
|
|
605
|
+
for (const e of Object.values(g(this, oI)))
|
|
600
606
|
e.dispose();
|
|
601
607
|
const i = I.getExtension("WEBGL_lose_context");
|
|
602
608
|
i == null || i.loseContext();
|
|
@@ -605,118 +611,123 @@ class fI {
|
|
|
605
611
|
// Loop control
|
|
606
612
|
// ---------------------------------------------------------------------------
|
|
607
613
|
start() {
|
|
608
|
-
if (g(this,
|
|
614
|
+
if (g(this, Q) !== null)
|
|
609
615
|
return;
|
|
610
616
|
const I = () => {
|
|
611
|
-
b(this,
|
|
617
|
+
b(this, RI, jI).call(this), l(this, Q, xI(I));
|
|
612
618
|
};
|
|
613
|
-
|
|
619
|
+
l(this, Q, xI(I));
|
|
614
620
|
}
|
|
615
621
|
stop() {
|
|
616
|
-
g(this,
|
|
622
|
+
g(this, Q) !== null && (ug(g(this, Q)), l(this, Q, null));
|
|
617
623
|
}
|
|
618
624
|
get isRunning() {
|
|
619
|
-
return g(this,
|
|
625
|
+
return g(this, Q) !== null;
|
|
620
626
|
}
|
|
621
627
|
}
|
|
622
|
-
|
|
623
|
-
const I = g(this,
|
|
624
|
-
"clientWidth" in I && I.clientWidth > 0 ? (
|
|
625
|
-
},
|
|
626
|
-
const I = g(this,
|
|
627
|
-
b(this,
|
|
628
|
-
},
|
|
629
|
-
if (!(!g(this,
|
|
630
|
-
if (b(this,
|
|
631
|
-
const { backgroundTex: I, obstacleTex: i, coverageTex: e } =
|
|
628
|
+
lI = new WeakMap(), X = new WeakMap(), SI = new WeakMap(), oI = new WeakMap(), rI = new WeakMap(), K = new WeakMap(), R = new WeakMap(), CI = new WeakMap(), eI = new WeakMap(), k = new WeakMap(), nI = new WeakMap(), P = new WeakMap(), H = new WeakMap(), B = new WeakMap(), E = new WeakMap(), J = new WeakMap(), N = new WeakMap(), _ = new WeakMap(), v = new WeakMap(), z = new WeakMap(), f = new WeakMap(), uI = new WeakMap(), tI = new WeakMap(), L = new WeakMap(), Y = new WeakMap(), Q = new WeakMap(), cI = new WeakMap(), bI = new WeakMap(), aI = new WeakSet(), GI = function() {
|
|
629
|
+
const I = g(this, lI);
|
|
630
|
+
"clientWidth" in I && I.clientWidth > 0 ? (l(this, k, (typeof window < "u" && window.devicePixelRatio || 1) * g(this, nI)), l(this, K, I.width = Math.round(I.clientWidth * g(this, k))), l(this, R, I.height = Math.round(I.clientHeight * g(this, k)))) : (l(this, K, I.width), l(this, R, I.height)), !(g(this, K) === 0 || g(this, R) === 0) && (l(this, CI, Math.max(1, Math.round(g(this, K) * g(this, P)))), l(this, eI, Math.max(1, Math.round(g(this, R) * g(this, P)))), b(this, LI, YI).call(this));
|
|
631
|
+
}, LI = new WeakSet(), YI = function() {
|
|
632
|
+
const I = g(this, X), i = g(this, SI), e = g(this, CI), s = g(this, eI);
|
|
633
|
+
b(this, VI, FI).call(this), l(this, H, WI(I, i, e, s)), l(this, B, WI(I, i, e, s)), l(this, J, WI(I, i, e, s)), l(this, E, KI(I, i, e, s)), l(this, N, KI(I, i, e, s));
|
|
634
|
+
}, sI = new WeakSet(), AI = function() {
|
|
635
|
+
if (!(!g(this, Y) || g(this, K) === 0 || g(this, R) === 0)) {
|
|
636
|
+
if (b(this, wI, DI).call(this), g(this, Y).type === "text") {
|
|
637
|
+
const { backgroundTex: I, obstacleTex: i, coverageTex: e } = Cg(
|
|
638
|
+
g(this, X),
|
|
639
|
+
g(this, K),
|
|
632
640
|
g(this, R),
|
|
633
|
-
g(this,
|
|
634
|
-
g(this,
|
|
635
|
-
g(this,
|
|
636
|
-
g(this, F),
|
|
637
|
-
g(this, dI)
|
|
641
|
+
g(this, Y).opts,
|
|
642
|
+
g(this, f),
|
|
643
|
+
g(this, uI)
|
|
638
644
|
);
|
|
639
|
-
|
|
645
|
+
l(this, _, I), l(this, v, i), l(this, z, e);
|
|
640
646
|
} else {
|
|
641
|
-
const { backgroundTex: I, obstacleTex: i, coverageTex: e } =
|
|
647
|
+
const { backgroundTex: I, obstacleTex: i, coverageTex: e } = eg(
|
|
648
|
+
g(this, X),
|
|
649
|
+
g(this, Y).bitmap,
|
|
650
|
+
g(this, K),
|
|
642
651
|
g(this, R),
|
|
643
|
-
g(this,
|
|
644
|
-
g(this,
|
|
645
|
-
g(this,
|
|
646
|
-
g(this,
|
|
647
|
-
g(this, U).size,
|
|
648
|
-
g(this, F),
|
|
649
|
-
g(this, dI)
|
|
652
|
+
g(this, Y).effect,
|
|
653
|
+
g(this, Y).size,
|
|
654
|
+
g(this, f),
|
|
655
|
+
g(this, uI)
|
|
650
656
|
);
|
|
651
|
-
|
|
657
|
+
l(this, _, I), l(this, v, i), l(this, z, e);
|
|
652
658
|
}
|
|
653
|
-
|
|
659
|
+
l(this, cI, !0);
|
|
654
660
|
}
|
|
655
|
-
},
|
|
656
|
-
g(this,
|
|
657
|
-
},
|
|
661
|
+
}, dI = new WeakSet(), hI = function() {
|
|
662
|
+
g(this, cI) && !this.isRunning && this.start();
|
|
663
|
+
}, VI = new WeakSet(), FI = function() {
|
|
658
664
|
var I, i, e;
|
|
659
|
-
(I = g(this, H)) == null || I.dispose(), (i = g(this,
|
|
660
|
-
},
|
|
661
|
-
g(this,
|
|
662
|
-
},
|
|
663
|
-
if (!g(this,
|
|
665
|
+
(I = g(this, H)) == null || I.dispose(), (i = g(this, B)) == null || i.dispose(), (e = g(this, J)) == null || e.dispose(), g(this, E) && (g(this, X).deleteTexture(g(this, E).tex), g(this, X).deleteFramebuffer(g(this, E).fbo)), g(this, N) && (g(this, X).deleteTexture(g(this, N).tex), g(this, X).deleteFramebuffer(g(this, N).fbo)), l(this, H, l(this, B, l(this, J, l(this, E, l(this, N, null)))));
|
|
666
|
+
}, wI = new WeakSet(), DI = function() {
|
|
667
|
+
g(this, _) && g(this, X).deleteTexture(g(this, _)), g(this, v) && g(this, X).deleteTexture(g(this, v)), g(this, z) && g(this, z) !== g(this, v) && g(this, X).deleteTexture(g(this, z)), l(this, _, l(this, v, l(this, z, null)));
|
|
668
|
+
}, RI = new WeakSet(), jI = function() {
|
|
669
|
+
if (!g(this, cI) || g(this, K) === 0 || !g(this, H) || !g(this, B))
|
|
664
670
|
return;
|
|
665
|
-
const I = g(this,
|
|
666
|
-
g(this,
|
|
667
|
-
const
|
|
668
|
-
I.viewport(0, 0,
|
|
669
|
-
for (let
|
|
670
|
-
I.uniform1i(
|
|
671
|
-
t.bind(), I.uniform2f(t.uniforms.texelSize, 1 /
|
|
671
|
+
const I = g(this, X), i = g(this, tI), { advection: e, divergence: s, pressure: o, gradientSubtract: t, splat: u, curl: a, vorticity: c, display: n } = g(this, oI);
|
|
672
|
+
g(this, L).x += (g(this, L).targetX - g(this, L).x) * 0.15, g(this, L).y += (g(this, L).targetY - g(this, L).y) * 0.15;
|
|
673
|
+
const G = g(this, CI), d = g(this, eI), h = g(this, rI);
|
|
674
|
+
I.viewport(0, 0, G, d), e.bind(), I.uniform2f(e.uniforms.texelSize, 1 / G, 1 / d), I.uniform1f(e.uniforms.dt, MI), I.uniform1i(e.uniforms.uObstacle, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, v)), I.uniform1f(e.uniforms.dissipation, i.velocityDissipation), I.uniform1i(e.uniforms.uVelocity, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(e.uniforms.uSource, 1), h(g(this, B).write.fbo), g(this, B).swap(), I.uniform1f(e.uniforms.dissipation, i.densityDissipation), I.uniform1i(e.uniforms.uSource, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, H).read.tex), h(g(this, H).write.fbo), g(this, H).swap(), a.bind(), I.uniform2f(a.uniforms.texelSize, 1 / G, 1 / d), I.uniform1i(a.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), h(g(this, N).fbo), c.bind(), I.uniform2f(c.uniforms.texelSize, 1 / G, 1 / d), I.uniform1f(c.uniforms.curl, i.curl), I.uniform1f(c.uniforms.dt, MI), I.uniform1i(c.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(c.uniforms.uCurl, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, N).tex), h(g(this, B).write.fbo), g(this, B).swap(), g(this, L).moved && (u.bind(), I.uniform1f(u.uniforms.aspectRatio, g(this, K) / g(this, R)), I.uniform2f(u.uniforms.point, g(this, L).x * g(this, k) / g(this, K), 1 - g(this, L).y * g(this, k) / g(this, R)), I.uniform1f(u.uniforms.radius, i.splatRadius), I.uniform1i(u.uniforms.uTarget, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform3f(u.uniforms.color, g(this, L).dx * i.splatForce, -g(this, L).dy * i.splatForce, 0), h(g(this, B).write.fbo), g(this, B).swap(), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, H).read.tex), I.uniform3f(u.uniforms.color, 1, 1, 1), h(g(this, H).write.fbo), g(this, H).swap(), g(this, L).moved = !1), s.bind(), I.uniform2f(s.uniforms.texelSize, 1 / G, 1 / d), I.uniform1i(s.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(s.uniforms.uObstacle, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, v)), h(g(this, E).fbo), o.bind(), I.uniform2f(o.uniforms.texelSize, 1 / G, 1 / d), I.uniform1i(o.uniforms.uDivergence, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, E).tex), I.uniform1i(o.uniforms.uObstacle, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, v));
|
|
675
|
+
for (let W = 0; W < i.pressureIterations; W++)
|
|
676
|
+
I.uniform1i(o.uniforms.uPressure, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, J).read.tex), h(g(this, J).write.fbo), g(this, J).swap();
|
|
677
|
+
t.bind(), I.uniform2f(t.uniforms.texelSize, 1 / G, 1 / d), I.uniform1i(t.uniforms.uPressure, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, J).read.tex), I.uniform1i(t.uniforms.uVelocity, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(t.uniforms.uObstacle, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, v)), h(g(this, B).write.fbo), g(this, B).swap(), I.viewport(0, 0, g(this, K), g(this, R)), I.bindFramebuffer(I.FRAMEBUFFER, null), I.clear(I.COLOR_BUFFER_BIT), n.bind(), I.uniform2f(n.uniforms.texelSize, 1 / g(this, K), 1 / g(this, R)), I.uniform3fv(n.uniforms.uWaterColor, i.waterColor), I.uniform3fv(n.uniforms.uGlowColor, i.glowColor), I.uniform1f(n.uniforms.uRefraction, i.refraction), I.uniform1f(n.uniforms.uSpecularExp, i.specularExp), I.uniform1f(n.uniforms.uShine, i.shine), I.uniform1f(n.uniforms.uWarpStrength, i.warpStrength ?? 0.015), I.uniform1i(n.uniforms.uAlgorithm, Zg[i.algorithm] ?? 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, H).read.tex), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, v)), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, _)), I.activeTexture(I.TEXTURE3), I.bindTexture(I.TEXTURE_2D, g(this, z)), I.activeTexture(I.TEXTURE4), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(n.uniforms.uTexture, 0), I.uniform1i(n.uniforms.uObstacle, 1), I.uniform1i(n.uniforms.uBackground, 2), I.uniform1i(n.uniforms.uCoverage, 3), I.uniform1i(n.uniforms.uVelocity, 4), h(null);
|
|
672
678
|
};
|
|
673
|
-
const zI = "var ye = Object.defineProperty;
var De = (i, e, r) => e in i ? ye(i, e, { enumerable: !0, configurable: !0, writable: !0, value: r }) : i[e] = r;
var se = (i, e, r) => (De(i, typeof e != "symbol" ? e + "" : e, r), r), he = (i, e, r) => {
  if (!e.has(i))
    throw TypeError("Cannot " + r);
};
var t = (i, e, r) => (he(i, e, "read from private field"), r ? r.call(i) : e.get(i)), l = (i, e, r) => {
  if (e.has(i))
    throw TypeError("Cannot add the same private member more than once");
  e instanceof WeakSet ? e.add(i) : e.set(i, r);
}, a = (i, e, r, o) => (he(i, e, "write to private field"), o ? o.call(i, r) : e.set(i, r), r);
var d = (i, e, r) => (he(i, e, "access private method"), r);
const ge = {
  densityDissipation: 0.992,
  velocityDissipation: 0.93,
  pressureIterations: 1,
  curl: 1e-4,
  splatRadius: 4e-3,
  splatForce: 0.91,
  refraction: 0.25,
  specularExp: 1.01,
  shine: 0.01,
  waterColor: [0, 0, 0],
  glowColor: [0.7, 0.85, 1],
  algorithm: "standard",
  warpStrength: 0.015
};
({
  ...ge
});
const Ue = {
  calm: {
    densityDissipation: 0.999,
    velocityDissipation: 0.98,
    curl: 1e-4,
    splatRadius: 3e-3,
    splatForce: 0.5,
    refraction: 0.15,
    shine: 5e-3,
    glowColor: [0.6, 0.85, 1],
    waterColor: [0, 0.02, 0.05]
  },
  sand: {
    densityDissipation: 0.997,
    velocityDissipation: 0.98,
    curl: 1,
    splatRadius: 0.01,
    splatForce: 0.9,
    refraction: 0.8,
    specularExp: 0.1,
    shine: 0.05,
    glowColor: [0.027, 0.027, 0.027],
    waterColor: [0.451, 0.329, 0.125]
  },
  wave: {
    densityDissipation: 0.994,
    velocityDissipation: 0.92,
    curl: 0.2,
    splatRadius: 5e-3,
    splatForce: 1.2,
    refraction: 0.35,
    shine: 0.03,
    glowColor: [0.5, 0.8, 1],
    waterColor: [0, 0.01, 0.03]
  },
  neon: {
    densityDissipation: 0.985,
    velocityDissipation: 0.93,
    curl: 0.05,
    splatRadius: 8e-3,
    splatForce: 1.5,
    refraction: 0.25,
    specularExp: 0.5,
    shine: 0.14,
    glowColor: [1, 0.2, 0.8],
    waterColor: [0.05, 0, 0.08]
  },
  smoke: {
    densityDissipation: 0.996,
    velocityDissipation: 0.97,
    curl: 0.04,
    splatRadius: 9e-3,
    splatForce: 0.8,
    refraction: 0.08,
    shine: 0,
    glowColor: [0.5, 0.5, 0.5],
    waterColor: [0.06, 0.06, 0.06]
  }
};
function _e(i = {}, e, r = ge) {
  return { ...e ? { ...r, ...Ue[e] } : r, ...i };
}
const P = (
  /* glsl */
  `
  precision highp float;
  attribute vec2 aPosition;
  varying vec2 vUv;
  varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform vec2 texelSize;
  void main () {
    vUv = aPosition * 0.5 + 0.5;
    vL = vUv - vec2(texelSize.x, 0.0);
    vR = vUv + vec2(texelSize.x, 0.0);
    vT = vUv + vec2(0.0, texelSize.y);
    vB = vUv - vec2(0.0, texelSize.y);
    gl_Position = vec4(aPosition, 0.0, 1.0);
  }
`
), we = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv;
  uniform sampler2D uVelocity;
  uniform sampler2D uSource;
  uniform sampler2D uObstacle;
  uniform vec2 texelSize;
  uniform float dt;
  uniform float dissipation;
  void main () {
    if (texture2D(uObstacle, vUv).r > 0.5) { gl_FragColor = vec4(0.0); return; }
    vec2 coord = vUv - dt * texture2D(uVelocity, vUv).xy * texelSize;
    gl_FragColor = dissipation * texture2D(uSource, coord);
  }
`
), Ce = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uVelocity;
  uniform sampler2D uObstacle;
  void main () {
    float L = texture2D(uObstacle, vL).r > 0.5 ? 0.0 : texture2D(uVelocity, vL).x;
    float R = texture2D(uObstacle, vR).r > 0.5 ? 0.0 : texture2D(uVelocity, vR).x;
    float T = texture2D(uObstacle, vT).r > 0.5 ? 0.0 : texture2D(uVelocity, vT).y;
    float B = texture2D(uObstacle, vB).r > 0.5 ? 0.0 : texture2D(uVelocity, vB).y;
    gl_FragColor = vec4(0.5 * (R - L + T - B), 0.0, 0.0, 1.0);
  }
`
), Se = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv; varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uPressure;
  uniform sampler2D uDivergence;
  uniform sampler2D uObstacle;
  void main () {
    float C = texture2D(uPressure, vUv).x;
    float L = texture2D(uObstacle, vL).r > 0.5 ? C : texture2D(uPressure, vL).x;
    float R = texture2D(uObstacle, vR).r > 0.5 ? C : texture2D(uPressure, vR).x;
    float T = texture2D(uObstacle, vT).r > 0.5 ? C : texture2D(uPressure, vT).x;
    float B = texture2D(uObstacle, vB).r > 0.5 ? C : texture2D(uPressure, vB).x;
    float div = texture2D(uDivergence, vUv).x;
    gl_FragColor = vec4((L + R + B + T - div) * 0.25, 0.0, 0.0, 1.0);
  }
`
), Fe = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv; varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uPressure;
  uniform sampler2D uVelocity;
  uniform sampler2D uObstacle;
  void main () {
    if (texture2D(uObstacle, vUv).r > 0.5) { gl_FragColor = vec4(0.0); return; }
    float L = texture2D(uPressure, vL).x;
    float R = texture2D(uPressure, vR).x;
    float T = texture2D(uPressure, vT).x;
    float B = texture2D(uPressure, vB).x;
    vec2 vel = texture2D(uVelocity, vUv).xy - vec2(R - L, T - B);
    gl_FragColor = vec4(vel, 0.0, 1.0);
  }
`
), Xe = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv;
  uniform sampler2D uTarget;
  uniform float aspectRatio;
  uniform vec3 color;
  uniform vec2 point;
  uniform float radius;
  void main () {
    vec2 p = vUv - point.xy;
    p.x *= aspectRatio;
    vec3 splat = exp(-dot(p, p) / radius) * color;
    gl_FragColor = vec4(texture2D(uTarget, vUv).xyz + splat, 1.0);
  }
`
), Be = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uVelocity;
  void main () {
    float L = texture2D(uVelocity, vL).y;
    float R = texture2D(uVelocity, vR).y;
    float T = texture2D(uVelocity, vT).x;
    float B = texture2D(uVelocity, vB).x;
    gl_FragColor = vec4(0.5 * (R - L - T + B), 0.0, 0.0, 1.0);
  }
`
), Ae = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv; varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uVelocity;
  uniform sampler2D uCurl;
  uniform float curl;
  uniform float dt;
  void main () {
    float L = texture2D(uCurl, vL).x;
    float R = texture2D(uCurl, vR).x;
    float T = texture2D(uCurl, vT).x;
    float B = texture2D(uCurl, vB).x;
    float C = texture2D(uCurl, vUv).x;
    vec2 force = 0.5 * vec2(abs(T) - abs(B), abs(R) - abs(L));
    force /= length(force) + 0.0001;
    force *= curl * 30.0 * C;
    gl_FragColor = vec4(texture2D(uVelocity, vUv).xy + force * dt, 0.0, 1.0);
  }
`
), Le = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv;

  uniform sampler2D uTexture;
  uniform sampler2D uObstacle;
  uniform sampler2D uBackground;
  uniform sampler2D uCoverage;
  uniform sampler2D uVelocity;

  uniform vec2  texelSize;
  uniform vec3  uWaterColor;
  uniform vec3  uGlowColor;
  uniform float uRefraction;
  uniform float uSpecularExp;
  uniform float uShine;
  uniform float uWarpStrength;
  uniform int   uAlgorithm;

  void main () {
    float obs      = texture2D(uObstacle,  vUv).r;
    // Mask density inside obstacles so splats don't flicker the text/image content.
    float density  = max(texture2D(uTexture, vUv).r, 0.0) * (1.0 - step(0.5, obs));
    float coverage = texture2D(uCoverage,  vUv).r;

    float dL = max(texture2D(uTexture, vUv - vec2(texelSize.x * 2.0, 0.0)).r, 0.0);
    float dR = max(texture2D(uTexture, vUv + vec2(texelSize.x * 2.0, 0.0)).r, 0.0);
    float dT = max(texture2D(uTexture, vUv + vec2(0.0, texelSize.y * 2.0)).r, 0.0);
    float dB = max(texture2D(uTexture, vUv - vec2(0.0, texelSize.y * 2.0)).r, 0.0);

    vec3  normal   = normalize(vec3(dL - dR, dB - dT, 0.2));
    vec3  lightDir = normalize(vec3(0.5, 1.0, 0.5));
    vec3  halfV    = normalize(lightDir + vec3(0.0, 0.0, 1.0));
    float spec     = pow(max(dot(normal, halfV), 0.0), uSpecularExp) * uShine * density;

    // In transparent (non-coverage) areas the background texture is empty black canvas.
    // Replace it with uWaterColor so fluid colour is not contaminated by that black,
    // allowing the CSS backgroundColor to show through correctly via premultiplied alpha.
    vec3 bgRaw = texture2D(uBackground, vUv).rgb;
    vec3 bg    = mix(uWaterColor, bgRaw, coverage);
    vec3 color = bg;

    if (uAlgorithm == 1) {
      // ── glass ──────────────────────────────────────────────────────────────
      // Strong UV distortion only. Image bends but no colour overlay.
      vec2 refrUv = clamp(vUv + normal.xy * uRefraction * density * 3.0, 0.0, 1.0);
      vec3 refrBg = mix(uWaterColor, texture2D(uBackground, mix(vUv, refrUv, 1.0 - obs)).rgb, coverage);
      color = refrBg + spec * uGlowColor * 2.5;
      color = mix(color, bg * 0.6, obs * 0.3);

    } else if (uAlgorithm == 2) {
      // ── ink ────────────────────────────────────────────────────────────────
      // Dense opaque pigment that stains. Subtle refraction underneath.
      float inkD  = min(density * 4.0, 1.0);
      vec2 refrUv = clamp(vUv + normal.xy * uRefraction * density * 0.4, 0.0, 1.0);
      vec3 refrBg = mix(uWaterColor, texture2D(uBackground, mix(vUv, refrUv, 1.0 - obs)).rgb, coverage);
      color = mix(refrBg, uWaterColor + spec * uGlowColor, inkD);
      color = mix(color, bg * 0.5, obs * 0.15);

    } else if (uAlgorithm == 3) {
      // ── aurora ─────────────────────────────────────────────────────────────
      // Velocity field warps background UVs — liquid metal / lava-lamp feel.
      vec2  vel    = texture2D(uVelocity, vUv).xy;
      float velMag = clamp(length(vel) * 20.0, 0.0, 1.0);
      vec2  warpUv = clamp(vUv + vel * uWarpStrength, 0.0, 1.0);
      vec3  warpBg = mix(uWaterColor, texture2D(uBackground, warpUv).rgb, coverage);
      color  = mix(bg, warpBg, velMag * (1.0 - obs));
      color += spec * uGlowColor * velMag * 1.5;
      color += uWaterColor * density * 0.3;
      color  = mix(color, bg * 0.5, obs * 0.2);

    } else if (uAlgorithm == 4) {
      // ── ripple ─────────────────────────────────────────────────────────────
      // Exaggerated normal perturbation + Fresnel rim — calm water surface.
      vec2  rippleUv = clamp(vUv + normal.xy * uRefraction * density * 6.0, 0.0, 1.0);
      vec3  refrBg   = mix(uWaterColor, texture2D(uBackground, mix(vUv, rippleUv, 1.0 - obs)).rgb, coverage);
      float fresnel  = pow(clamp(1.0 - dot(normal, vec3(0.0, 0.0, 1.0)), 0.0, 1.0), 3.0) * density;
      color  = refrBg;
      color += fresnel * uGlowColor * 2.0;
      color += spec * uGlowColor * density * 2.0;
      color  = mix(color, bg * 0.5, obs * 0.2);

    } else {
      // ── standard (0) ───────────────────────────────────────────────────────
      // Original: colour overlay blended over refracted background.
      vec2 refrUv = vUv + normal.xy * uRefraction * density;
      vec3 refrBg = mix(uWaterColor, texture2D(uBackground, mix(vUv, refrUv, 1.0 - obs)).rgb, coverage);
      color  = mix(refrBg, uWaterColor, min(density * 1.5, 0.8));
      color += spec * uGlowColor;
      color  = mix(color, bg * 0.5, obs * 0.2);
    }

    // Premultiplied alpha — transparent where there is neither content nor fluid,
    // letting the CSS backgroundColor on the container div show through.
    float alpha = clamp(max(density * 1.5, coverage), 0.0, 1.0);
    gl_FragColor = vec4(color * alpha, alpha);
  }
`
);
function Pe(i) {
  const e = { alpha: !0, depth: !1, stencil: !1, antialias: !0, preserveDrawingBuffer: !1 };
  let r = i.getContext("webgl2", e);
  const o = !!r;
  o || (r = i.getContext("webgl", e), r.getExtension("EXT_color_buffer_half_float"));
  const s = o ? null : r.getExtension("OES_texture_half_float"), n = o ? r.HALF_FLOAT : s.HALF_FLOAT_OES;
  return r.getExtension("EXT_color_buffer_float"), r.getExtension("OES_texture_half_float_linear"), {
    gl: r,
    isWebGL2: o,
    ext: {
      internalFormat: o ? r.RGBA16F : r.RGBA,
      format: r.RGBA,
      type: n
    }
  };
}
class O {
  constructor(e, r, o) {
    se(this, "program");
    se(this, "uniforms", {});
    se(this, "_gl");
    this._gl = e, this.program = e.createProgram(), e.attachShader(this.program, this._compile(e.VERTEX_SHADER, r)), e.attachShader(this.program, this._compile(e.FRAGMENT_SHADER, o)), e.linkProgram(this.program);
    const s = e.getProgramParameter(this.program, e.ACTIVE_UNIFORMS);
    for (let n = 0; n < s; n++) {
      const u = e.getActiveUniform(this.program, n).name;
      this.uniforms[u] = e.getUniformLocation(this.program, u);
    }
  }
  _compile(e, r) {
    const o = this._gl, s = o.createShader(e);
    return o.shaderSource(s, r), o.compileShader(s), s;
  }
  bind() {
    this._gl.useProgram(this.program);
  }
  dispose() {
    this._gl.deleteProgram(this.program);
  }
}
function Oe(i) {
  return {
    advection: new O(i, P, we),
    divergence: new O(i, P, Ce),
    pressure: new O(i, P, Se),
    gradientSubtract: new O(i, P, Fe),
    splat: new O(i, P, Xe),
    curl: new O(i, P, Be),
    vorticity: new O(i, P, Ae),
    display: new O(i, P, Le)
  };
}
function ae(i, e, r, o) {
  i.activeTexture(i.TEXTURE0);
  const s = i.createTexture();
  i.bindTexture(i.TEXTURE_2D, s), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_MIN_FILTER, i.LINEAR), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_MAG_FILTER, i.LINEAR), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_WRAP_S, i.CLAMP_TO_EDGE), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_WRAP_T, i.CLAMP_TO_EDGE), i.texImage2D(i.TEXTURE_2D, 0, e.internalFormat, r, o, 0, e.format, e.type, null);
  const n = i.createFramebuffer();
  return i.bindFramebuffer(i.FRAMEBUFFER, n), i.framebufferTexture2D(i.FRAMEBUFFER, i.COLOR_ATTACHMENT0, i.TEXTURE_2D, s, 0), { tex: s, fbo: n, width: r, height: o };
}
function me(i, e, r, o) {
  let s = ae(i, e, r, o), n = ae(i, e, r, o);
  return {
    get read() {
      return s;
    },
    get write() {
      return n;
    },
    swap() {
      [s, n] = [n, s];
    },
    dispose() {
      i.deleteTexture(s.tex), i.deleteFramebuffer(s.fbo), i.deleteTexture(n.tex), i.deleteFramebuffer(n.fbo);
    }
  };
}
function ke(i) {
  const e = i.createBuffer();
  return i.bindBuffer(i.ARRAY_BUFFER, e), i.bufferData(i.ARRAY_BUFFER, new Float32Array([-1, -1, -1, 1, 1, 1, 1, -1]), i.STATIC_DRAW), i.vertexAttribPointer(0, 2, i.FLOAT, !1, 0, 0), i.enableVertexAttribArray(0), function(o) {
    i.bindFramebuffer(i.FRAMEBUFFER, o), i.drawArrays(i.TRIANGLE_FAN, 0, 4);
  };
}
function xe(i, e, r, o, s = "cover") {
  let n;
  s === "cover" ? n = Math.max(r / i, o / e) : s === "contain" ? n = Math.min(r / i, o / e) : typeof s == "string" && s.endsWith("%") ? n = Math.min(r / i, o / e) * (parseFloat(s) / 100) : typeof s == "string" && s.endsWith("px") ? n = parseFloat(s) / Math.max(i, e) : typeof s == "number" ? n = s : n = Math.max(r / i, o / e);
  const u = i * n, T = e * n;
  return { x: (r - u) / 2, y: (o - T) / 2, drawW: u, drawH: T };
}
function Ie(i, e, r, o, s = null, n = "cover") {
  const { text: u, fontSize: T, color: E, fontFamily: c = "sans-serif", fontWeight: h = 900 } = o, R = new OffscreenCanvas(e, r), f = R.getContext("2d");
  ((ue) => {
    if (s) {
      f.clearRect(0, 0, e, r), f.fillStyle = "black", f.fillRect(0, 0, e, r);
      const { x: le, y: ce, drawW: fe, drawH: ve } = xe(
        s.width,
        s.height,
        e,
        r,
        n
      );
      f.drawImage(s, le, ce, fe, ve);
    } else
      f.fillStyle = "black", f.fillRect(0, 0, e, r);
    f.fillStyle = ue, f.font = `${h} ${T}px ${c}`, f.textAlign = "center", f.textBaseline = "middle", f.fillText(u, e / 2, r / 2);
  })(E);
  const Y = Q(i, R);
  f.fillStyle = "black", f.fillRect(0, 0, e, r), f.fillStyle = "white", f.font = `${h} ${T}px ${c}`, f.textAlign = "center", f.textBaseline = "middle", f.fillText(u, e / 2, r / 2);
  const oe = Q(i, R);
  return { backgroundTex: Y, obstacleTex: oe, coverageTex: oe };
}
function Me(i, e, r, o, s = 0, n = "cover", u = null, T = "cover") {
  const E = new OffscreenCanvas(r, o), c = E.getContext("2d"), { x: h, y: R, drawW: f, drawH: D } = xe(e.width, e.height, r, o, n);
  if (c.clearRect(0, 0, r, o), c.fillStyle = "black", c.fillRect(0, 0, r, o), u) {
    const {
      x: le,
      y: ce,
      drawW: fe,
      drawH: ve
    } = xe(u.width, u.height, r, o, T);
    c.filter = `brightness(${s}) blur(8px)`, c.drawImage(u, le, ce, fe, ve), c.filter = "none";
  }
  c.drawImage(e, h, R, f, D);
  const Y = Q(i, E);
  c.clearRect(0, 0, r, o), c.fillStyle = "black", c.fillRect(0, 0, r, o), c.filter = `brightness(${s}) blur(8px)`, c.drawImage(e, h, R, f, D), c.filter = "none";
  const oe = Q(i, E);
  c.clearRect(0, 0, r, o), c.fillStyle = "black", c.fillRect(0, 0, r, o), c.fillStyle = "white", c.fillRect(
    Math.max(0, h),
    Math.max(0, R),
    Math.min(f, r - Math.max(0, h)),
    Math.min(D, o - Math.max(0, R))
  );
  const ue = Q(i, E);
  return { backgroundTex: Y, obstacleTex: oe, coverageTex: ue };
}
function Q(i, e) {
  const r = i.createTexture();
  return i.bindTexture(i.TEXTURE_2D, r), i.pixelStorei(i.UNPACK_FLIP_Y_WEBGL, !0), i.texImage2D(i.TEXTURE_2D, 0, i.RGBA, i.RGBA, i.UNSIGNED_BYTE, e), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_MIN_FILTER, i.LINEAR), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_MAG_FILTER, i.LINEAR), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_WRAP_S, i.CLAMP_TO_EDGE), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_WRAP_T, i.CLAMP_TO_EDGE), r;
}
async function Ve(i) {
  const e = await fetch(i);
  if (!e.ok)
    throw new Error(`Failed to fetch image: ${i} (${e.status})`);
  const r = await e.blob();
  return createImageBitmap(r);
}
const Ee = typeof requestAnimationFrame < "u" ? requestAnimationFrame.bind(globalThis) : (i) => setTimeout(i, 1e3 / 60), We = typeof cancelAnimationFrame < "u" ? cancelAnimationFrame.bind(globalThis) : clearTimeout, be = 0.016, Ge = { standard: 0, glass: 1, ink: 2, aurora: 3, ripple: 4 };
var V, b, Z, W, H, p, y, k, I, w, g, v, S, F, X, L, U, B, C, j, G, x, _, A, z, ee, N, K, te, Te, M, q, $, J, re, de, ie, pe, ne, Re;
class ze {
  constructor(e, r = {}) {
    // ---------------------------------------------------------------------------
    // Private helpers
    // ---------------------------------------------------------------------------
    l(this, N);
    l(this, te);
    l(this, M);
    l(this, $);
    l(this, re);
    l(this, ie);
    l(this, ne);
    l(this, V, void 0);
    l(this, b, void 0);
    l(this, Z, void 0);
    l(this, W, void 0);
    l(this, H, void 0);
    l(this, p, 0);
    l(this, y, 0);
    l(this, k, 0);
    l(this, I, 0);
    l(this, w, 1);
    l(this, g, null);
    l(this, v, null);
    l(this, S, null);
    l(this, F, null);
    l(this, X, null);
    l(this, L, null);
    l(this, U, null);
    l(this, B, null);
    // binary content mask for transparent canvas support
    l(this, C, null);
    // optional background image (from backgroundSrc prop)
    l(this, j, "cover");
    l(this, G, void 0);
    l(this, x, { x: 0, y: 0, dx: 0, dy: 0, targetX: 0, targetY: 0, moved: !1 });
    // Stores source so textures can be rebuilt on resize
    l(this, _, null);
    l(this, A, null);
    l(this, z, !1);
    l(this, ee, !1);
    a(this, V, e), a(this, G, _e(r));
    const { gl: o, ext: s } = Pe(e);
    a(this, b, o), a(this, Z, s), a(this, W, Oe(o)), a(this, H, ke(o)), o.clearColor(0, 0, 0, 0);
  }
  // ---------------------------------------------------------------------------
  // Public API
  // ---------------------------------------------------------------------------
  setTextSource(e) {
    a(this, _, { type: "text", opts: e }), d(this, N, K).call(this), d(this, M, q).call(this), d(this, $, J).call(this);
  }
  async setImageSource(e, r = 0, o = "cover") {
    const s = await Ve(e);
    if (t(this, ee)) {
      s.close();
      return;
    }
    a(this, _, { type: "image", bitmap: s, effect: r, size: o }), d(this, N, K).call(this), d(this, M, q).call(this), d(this, $, J).call(this);
  }
  setImageBitmap(e, r = 0, o = "cover") {
    a(this, _, { type: "image", bitmap: e, effect: r, size: o }), d(this, N, K).call(this), d(this, M, q).call(this), d(this, $, J).call(this);
  }
  setBackground(e, r = "cover") {
    t(this, C) && t(this, C) !== e && t(this, C).close(), a(this, C, e), a(this, j, r ?? "cover"), t(this, _) && t(this, p) > 0 && d(this, M, q).call(this);
  }
  handleMove(e, r, o = 1) {
    t(this, x).moved = !0, t(this, x).dx = (e - t(this, x).targetX) * o, t(this, x).dy = (r - t(this, x).targetY) * o, t(this, x).targetX = e, t(this, x).targetY = r;
  }
  /**
   * Immediately applies one fluid splat at (x, y) with explicit velocity (vx, vy).
   * Safe to call multiple times per frame — each call writes directly to the FBOs.
   * Designed for programmatic use cases (e.g. particle systems, attractor paths)
   * where you want N independent injection points per frame without flooding the
   * mouse-state machine or the worker message queue.
   */
  splat(e, r, o, s, n = 1) {
    if (!t(this, z) || t(this, p) === 0)
      return;
    const u = t(this, b), T = t(this, G), { splat: E } = t(this, W), c = t(this, H);
    u.viewport(0, 0, t(this, k), t(this, I)), E.bind(), u.uniform1f(E.uniforms.aspectRatio, t(this, p) / t(this, y)), u.uniform2f(E.uniforms.point, e * t(this, w) / t(this, p), 1 - r * t(this, w) / t(this, y)), u.uniform1f(E.uniforms.radius, T.splatRadius), u.uniform1i(E.uniforms.uTarget, 0), u.activeTexture(u.TEXTURE0), u.bindTexture(u.TEXTURE_2D, t(this, v).read.tex), u.uniform3f(E.uniforms.color, o * T.splatForce * n, -s * T.splatForce * n, 0), c(t(this, v).write.fbo), t(this, v).swap(), u.activeTexture(u.TEXTURE0), u.bindTexture(u.TEXTURE_2D, t(this, g).read.tex), u.uniform3f(E.uniforms.color, n, n, n), c(t(this, g).write.fbo), t(this, g).swap();
  }
  resize(e, r, o) {
    if (o !== void 0 ? a(this, w, o) : typeof window < "u" && window.devicePixelRatio && a(this, w, window.devicePixelRatio), e !== void 0 && e > 0) {
      if (r === void 0 || r <= 0)
        return;
      a(this, p, t(this, V).width = e), a(this, y, t(this, V).height = r), a(this, k, e >> 1), a(this, I, r >> 1), d(this, te, Te).call(this);
    } else
      d(this, N, K).call(this);
    t(this, _) && d(this, M, q).call(this), d(this, $, J).call(this);
  }
  updateConfig(e) {
    Object.assign(t(this, G), e);
  }
  destroy() {
    a(this, ee, !0), this.stop();
    const e = t(this, b);
    d(this, re, de).call(this), d(this, ie, pe).call(this), t(this, C) && (t(this, C).close(), a(this, C, null));
    for (const o of Object.values(t(this, W)))
      o.dispose();
    const r = e.getExtension("WEBGL_lose_context");
    r == null || r.loseContext();
  }
  // ---------------------------------------------------------------------------
  // Loop control
  // ---------------------------------------------------------------------------
  start() {
    if (t(this, A) !== null)
      return;
    const e = () => {
      d(this, ne, Re).call(this), a(this, A, Ee(e));
    };
    a(this, A, Ee(e));
  }
  stop() {
    t(this, A) !== null && (We(t(this, A)), a(this, A, null));
  }
  get isRunning() {
    return t(this, A) !== null;
  }
}
V = new WeakMap(), b = new WeakMap(), Z = new WeakMap(), W = new WeakMap(), H = new WeakMap(), p = new WeakMap(), y = new WeakMap(), k = new WeakMap(), I = new WeakMap(), w = new WeakMap(), g = new WeakMap(), v = new WeakMap(), S = new WeakMap(), F = new WeakMap(), X = new WeakMap(), L = new WeakMap(), U = new WeakMap(), B = new WeakMap(), C = new WeakMap(), j = new WeakMap(), G = new WeakMap(), x = new WeakMap(), _ = new WeakMap(), A = new WeakMap(), z = new WeakMap(), ee = new WeakMap(), N = new WeakSet(), K = function() {
  const e = t(this, V);
  "clientWidth" in e && e.clientWidth > 0 ? (a(this, w, typeof window < "u" && window.devicePixelRatio || 1), a(this, p, e.width = Math.round(e.clientWidth * t(this, w))), a(this, y, e.height = Math.round(e.clientHeight * t(this, w)))) : (a(this, p, e.width), a(this, y, e.height)), !(t(this, p) === 0 || t(this, y) === 0) && (a(this, k, t(this, p) >> 1), a(this, I, t(this, y) >> 1), d(this, te, Te).call(this));
}, te = new WeakSet(), Te = function() {
  const e = t(this, b), r = t(this, Z), o = t(this, k), s = t(this, I);
  d(this, re, de).call(this), a(this, g, me(e, r, o, s)), a(this, v, me(e, r, o, s)), a(this, F, me(e, r, o, s)), a(this, S, ae(e, r, o, s)), a(this, X, ae(e, r, o, s));
}, M = new WeakSet(), q = function() {
  if (!(!t(this, _) || t(this, p) === 0)) {
    if (d(this, ie, pe).call(this), t(this, _).type === "text") {
      const { backgroundTex: e, obstacleTex: r, coverageTex: o } = Ie(
        t(this, b),
        t(this, p),
        t(this, y),
        t(this, _).opts,
        t(this, C),
        t(this, j)
      );
      a(this, L, e), a(this, U, r), a(this, B, o);
    } else {
      const { backgroundTex: e, obstacleTex: r, coverageTex: o } = Me(
        t(this, b),
        t(this, _).bitmap,
        t(this, p),
        t(this, y),
        t(this, _).effect,
        t(this, _).size,
        t(this, C),
        t(this, j)
      );
      a(this, L, e), a(this, U, r), a(this, B, o);
    }
    a(this, z, !0);
  }
}, $ = new WeakSet(), J = function() {
  t(this, z) && !this.isRunning && this.start();
}, re = new WeakSet(), de = function() {
  var e, r, o;
  (e = t(this, g)) == null || e.dispose(), (r = t(this, v)) == null || r.dispose(), (o = t(this, F)) == null || o.dispose(), t(this, S) && (t(this, b).deleteTexture(t(this, S).tex), t(this, b).deleteFramebuffer(t(this, S).fbo)), t(this, X) && (t(this, b).deleteTexture(t(this, X).tex), t(this, b).deleteFramebuffer(t(this, X).fbo)), a(this, g, a(this, v, a(this, F, a(this, S, a(this, X, null)))));
}, ie = new WeakSet(), pe = function() {
  t(this, L) && t(this, b).deleteTexture(t(this, L)), t(this, U) && t(this, b).deleteTexture(t(this, U)), t(this, B) && t(this, B) !== t(this, U) && t(this, b).deleteTexture(t(this, B)), a(this, L, a(this, U, a(this, B, null)));
}, ne = new WeakSet(), Re = function() {
  if (!t(this, z) || t(this, p) === 0 || !t(this, g) || !t(this, v))
    return;
  const e = t(this, b), r = t(this, G), { advection: o, divergence: s, pressure: n, gradientSubtract: u, splat: T, curl: E, vorticity: c, display: h } = t(this, W);
  t(this, x).x += (t(this, x).targetX - t(this, x).x) * 0.15, t(this, x).y += (t(this, x).targetY - t(this, x).y) * 0.15;
  const R = t(this, k), f = t(this, I), D = t(this, H);
  e.viewport(0, 0, R, f), o.bind(), e.uniform2f(o.uniforms.texelSize, 1 / R, 1 / f), e.uniform1f(o.uniforms.dt, be), e.uniform1i(o.uniforms.uObstacle, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, U)), e.uniform1f(o.uniforms.dissipation, r.velocityDissipation), e.uniform1i(o.uniforms.uVelocity, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, v).read.tex), e.uniform1i(o.uniforms.uSource, 1), D(t(this, v).write.fbo), t(this, v).swap(), e.uniform1f(o.uniforms.dissipation, r.densityDissipation), e.uniform1i(o.uniforms.uSource, 2), e.activeTexture(e.TEXTURE2), e.bindTexture(e.TEXTURE_2D, t(this, g).read.tex), D(t(this, g).write.fbo), t(this, g).swap(), E.bind(), e.uniform2f(E.uniforms.texelSize, 1 / R, 1 / f), e.uniform1i(E.uniforms.uVelocity, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, v).read.tex), D(t(this, X).fbo), c.bind(), e.uniform2f(c.uniforms.texelSize, 1 / R, 1 / f), e.uniform1f(c.uniforms.curl, r.curl), e.uniform1f(c.uniforms.dt, be), e.uniform1i(c.uniforms.uVelocity, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, v).read.tex), e.uniform1i(c.uniforms.uCurl, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, X).tex), D(t(this, v).write.fbo), t(this, v).swap(), t(this, x).moved && (T.bind(), e.uniform1f(T.uniforms.aspectRatio, t(this, p) / t(this, y)), e.uniform2f(T.uniforms.point, t(this, x).x * t(this, w) / t(this, p), 1 - t(this, x).y * t(this, w) / t(this, y)), e.uniform1f(T.uniforms.radius, r.splatRadius), e.uniform1i(T.uniforms.uTarget, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, v).read.tex), e.uniform3f(T.uniforms.color, t(this, x).dx * r.splatForce, -t(this, x).dy * r.splatForce, 0), D(t(this, v).write.fbo), t(this, v).swap(), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, g).read.tex), e.uniform3f(T.uniforms.color, 1, 1, 1), D(t(this, g).write.fbo), t(this, g).swap(), t(this, x).moved = !1), s.bind(), e.uniform2f(s.uniforms.texelSize, 1 / R, 1 / f), e.uniform1i(s.uniforms.uVelocity, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, v).read.tex), e.uniform1i(s.uniforms.uObstacle, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, U)), D(t(this, S).fbo), n.bind(), e.uniform2f(n.uniforms.texelSize, 1 / R, 1 / f), e.uniform1i(n.uniforms.uDivergence, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, S).tex), e.uniform1i(n.uniforms.uObstacle, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, U));
  for (let Y = 0; Y < r.pressureIterations; Y++)
    e.uniform1i(n.uniforms.uPressure, 2), e.activeTexture(e.TEXTURE2), e.bindTexture(e.TEXTURE_2D, t(this, F).read.tex), D(t(this, F).write.fbo), t(this, F).swap();
  u.bind(), e.uniform2f(u.uniforms.texelSize, 1 / R, 1 / f), e.uniform1i(u.uniforms.uPressure, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, F).read.tex), e.uniform1i(u.uniforms.uVelocity, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, v).read.tex), e.uniform1i(u.uniforms.uObstacle, 2), e.activeTexture(e.TEXTURE2), e.bindTexture(e.TEXTURE_2D, t(this, U)), D(t(this, v).write.fbo), t(this, v).swap(), e.viewport(0, 0, t(this, p), t(this, y)), e.bindFramebuffer(e.FRAMEBUFFER, null), e.clear(e.COLOR_BUFFER_BIT), h.bind(), e.uniform2f(h.uniforms.texelSize, 1 / t(this, p), 1 / t(this, y)), e.uniform3fv(h.uniforms.uWaterColor, r.waterColor), e.uniform3fv(h.uniforms.uGlowColor, r.glowColor), e.uniform1f(h.uniforms.uRefraction, r.refraction), e.uniform1f(h.uniforms.uSpecularExp, r.specularExp), e.uniform1f(h.uniforms.uShine, r.shine), e.uniform1f(h.uniforms.uWarpStrength, r.warpStrength ?? 0.015), e.uniform1i(h.uniforms.uAlgorithm, Ge[r.algorithm] ?? 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, g).read.tex), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, U)), e.activeTexture(e.TEXTURE2), e.bindTexture(e.TEXTURE_2D, t(this, L)), e.activeTexture(e.TEXTURE3), e.bindTexture(e.TEXTURE_2D, t(this, B)), e.activeTexture(e.TEXTURE4), e.bindTexture(e.TEXTURE_2D, t(this, v).read.tex), e.uniform1i(h.uniforms.uTexture, 0), e.uniform1i(h.uniforms.uObstacle, 1), e.uniform1i(h.uniforms.uBackground, 2), e.uniform1i(h.uniforms.uCoverage, 3), e.uniform1i(h.uniforms.uVelocity, 4), D(null);
};
let m = null;
self.onmessage = async (i) => {
  const { type: e, ...r } = i.data;
  try {
    switch (e) {
      case "init": {
        const { canvas: o, width: s, height: n, config: u, dpr: T } = r;
        o.width = s, o.height = n, m = new ze(o, u), m.resize(s, n, T || 1), self.postMessage({ type: "ready" });
        break;
      }
      case "setTextSource": {
        if (!m)
          return;
        m.setTextSource(r.opts);
        break;
      }
      case "setImageSource": {
        if (!m)
          return;
        await m.setImageSource(
          r.src,
          r.effect,
          r.size
        );
        break;
      }
      case "setImageBitmap": {
        if (!m)
          return;
        m.setImageBitmap(
          r.bitmap,
          r.effect,
          r.size
        );
        break;
      }
      case "setBackground": {
        if (!m)
          return;
        m.setBackground(r.bitmap, r.size);
        break;
      }
      case "splat": {
        if (!m)
          return;
        m.splat(
          r.x,
          r.y,
          r.vx,
          r.vy,
          r.strength ?? 1
        );
        break;
      }
      case "move": {
        if (!m)
          return;
        m.handleMove(r.x, r.y, r.strength ?? 1);
        break;
      }
      case "resize": {
        if (!m)
          return;
        m.resize(r.width, r.height, r.dpr);
        break;
      }
      case "updateConfig": {
        if (!m)
          return;
        m.updateConfig(r.config);
        break;
      }
      case "destroy": {
        m == null || m.destroy(), m = null;
        break;
      }
      default:
        console.warn("[fluidity-js worker] Unknown message type:", e);
    }
  } catch (o) {
    self.postMessage({ type: "error", message: (o == null ? void 0 : o.message) ?? String(o) });
  }
};
", FI = typeof window < "u" && window.Blob && new Blob([atob(zI)], { type: "text/javascript;charset=utf-8" });
|
|
674
|
-
function
|
|
679
|
+
const PI = "var Ue = Object.defineProperty;
var _e = (i, e, r) => e in i ? Ue(i, e, { enumerable: !0, configurable: !0, writable: !0, value: r }) : i[e] = r;
var ne = (i, e, r) => (_e(i, typeof e != "symbol" ? e + "" : e, r), r), xe = (i, e, r) => {
  if (!e.has(i))
    throw TypeError("Cannot " + r);
};
var t = (i, e, r) => (xe(i, e, "read from private field"), r ? r.call(i) : e.get(i)), l = (i, e, r) => {
  if (e.has(i))
    throw TypeError("Cannot add the same private member more than once");
  e instanceof WeakSet ? e.add(i) : e.set(i, r);
}, a = (i, e, r, o) => (xe(i, e, "write to private field"), o ? o.call(i, r) : e.set(i, r), r);
var T = (i, e, r) => (xe(i, e, "access private method"), r);
const ye = {
  densityDissipation: 0.992,
  velocityDissipation: 0.93,
  pressureIterations: 1,
  curl: 1e-4,
  splatRadius: 4e-3,
  splatForce: 0.91,
  refraction: 0.25,
  specularExp: 1.01,
  shine: 0.01,
  waterColor: [0, 0, 0],
  glowColor: [0.7, 0.85, 1],
  algorithm: "standard",
  warpStrength: 0.015
};
({
  ...ye
});
const we = {
  calm: {
    densityDissipation: 0.999,
    velocityDissipation: 0.98,
    curl: 1e-4,
    splatRadius: 3e-3,
    splatForce: 0.5,
    refraction: 0.15,
    shine: 5e-3,
    glowColor: [0.6, 0.85, 1],
    waterColor: [0, 0.02, 0.05]
  },
  sand: {
    densityDissipation: 0.997,
    velocityDissipation: 0.98,
    curl: 1,
    splatRadius: 0.01,
    splatForce: 0.9,
    refraction: 0.8,
    specularExp: 0.1,
    shine: 0.05,
    glowColor: [0.027, 0.027, 0.027],
    waterColor: [0.451, 0.329, 0.125]
  },
  wave: {
    densityDissipation: 0.994,
    velocityDissipation: 0.92,
    curl: 0.2,
    splatRadius: 5e-3,
    splatForce: 1.2,
    refraction: 0.35,
    shine: 0.03,
    glowColor: [0.5, 0.8, 1],
    waterColor: [0, 0.01, 0.03]
  },
  neon: {
    densityDissipation: 0.985,
    velocityDissipation: 0.93,
    curl: 0.05,
    splatRadius: 8e-3,
    splatForce: 1.5,
    refraction: 0.25,
    specularExp: 0.5,
    shine: 0.14,
    glowColor: [1, 0.2, 0.8],
    waterColor: [0.05, 0, 0.08]
  },
  smoke: {
    densityDissipation: 0.996,
    velocityDissipation: 0.97,
    curl: 0.04,
    splatRadius: 9e-3,
    splatForce: 0.8,
    refraction: 0.08,
    shine: 0,
    glowColor: [0.5, 0.5, 0.5],
    waterColor: [0.06, 0.06, 0.06]
  }
};
function Se(i = {}, e, r = ye) {
  return { ...e ? { ...r, ...we[e] } : r, ...i };
}
const P = (
  /* glsl */
  `
  precision highp float;
  attribute vec2 aPosition;
  varying vec2 vUv;
  varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform vec2 texelSize;
  void main () {
    vUv = aPosition * 0.5 + 0.5;
    vL = vUv - vec2(texelSize.x, 0.0);
    vR = vUv + vec2(texelSize.x, 0.0);
    vT = vUv + vec2(0.0, texelSize.y);
    vB = vUv - vec2(0.0, texelSize.y);
    gl_Position = vec4(aPosition, 0.0, 1.0);
  }
`
), Ce = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv;
  uniform sampler2D uVelocity;
  uniform sampler2D uSource;
  uniform sampler2D uObstacle;
  uniform vec2 texelSize;
  uniform float dt;
  uniform float dissipation;
  void main () {
    if (texture2D(uObstacle, vUv).r > 0.5) { gl_FragColor = vec4(0.0); return; }
    vec2 coord = vUv - dt * texture2D(uVelocity, vUv).xy * texelSize;
    gl_FragColor = dissipation * texture2D(uSource, coord);
  }
`
), Fe = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uVelocity;
  uniform sampler2D uObstacle;
  void main () {
    float L = texture2D(uObstacle, vL).r > 0.5 ? 0.0 : texture2D(uVelocity, vL).x;
    float R = texture2D(uObstacle, vR).r > 0.5 ? 0.0 : texture2D(uVelocity, vR).x;
    float T = texture2D(uObstacle, vT).r > 0.5 ? 0.0 : texture2D(uVelocity, vT).y;
    float B = texture2D(uObstacle, vB).r > 0.5 ? 0.0 : texture2D(uVelocity, vB).y;
    gl_FragColor = vec4(0.5 * (R - L + T - B), 0.0, 0.0, 1.0);
  }
`
), Xe = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv; varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uPressure;
  uniform sampler2D uDivergence;
  uniform sampler2D uObstacle;
  void main () {
    float C = texture2D(uPressure, vUv).x;
    float L = texture2D(uObstacle, vL).r > 0.5 ? C : texture2D(uPressure, vL).x;
    float R = texture2D(uObstacle, vR).r > 0.5 ? C : texture2D(uPressure, vR).x;
    float T = texture2D(uObstacle, vT).r > 0.5 ? C : texture2D(uPressure, vT).x;
    float B = texture2D(uObstacle, vB).r > 0.5 ? C : texture2D(uPressure, vB).x;
    float div = texture2D(uDivergence, vUv).x;
    gl_FragColor = vec4((L + R + B + T - div) * 0.25, 0.0, 0.0, 1.0);
  }
`
), Be = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv; varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uPressure;
  uniform sampler2D uVelocity;
  uniform sampler2D uObstacle;
  void main () {
    if (texture2D(uObstacle, vUv).r > 0.5) { gl_FragColor = vec4(0.0); return; }
    float L = texture2D(uPressure, vL).x;
    float R = texture2D(uPressure, vR).x;
    float T = texture2D(uPressure, vT).x;
    float B = texture2D(uPressure, vB).x;
    vec2 vel = texture2D(uVelocity, vUv).xy - vec2(R - L, T - B);
    gl_FragColor = vec4(vel, 0.0, 1.0);
  }
`
), Ae = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv;
  uniform sampler2D uTarget;
  uniform float aspectRatio;
  uniform vec3 color;
  uniform vec2 point;
  uniform float radius;
  void main () {
    vec2 p = vUv - point.xy;
    p.x *= aspectRatio;
    vec3 splat = exp(-dot(p, p) / radius) * color;
    gl_FragColor = vec4(texture2D(uTarget, vUv).xyz + splat, 1.0);
  }
`
), Le = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uVelocity;
  void main () {
    float L = texture2D(uVelocity, vL).y;
    float R = texture2D(uVelocity, vR).y;
    float T = texture2D(uVelocity, vT).x;
    float B = texture2D(uVelocity, vB).x;
    gl_FragColor = vec4(0.5 * (R - L - T + B), 0.0, 0.0, 1.0);
  }
`
), Me = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv; varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uVelocity;
  uniform sampler2D uCurl;
  uniform float curl;
  uniform float dt;
  void main () {
    float L = texture2D(uCurl, vL).x;
    float R = texture2D(uCurl, vR).x;
    float T = texture2D(uCurl, vT).x;
    float B = texture2D(uCurl, vB).x;
    float C = texture2D(uCurl, vUv).x;
    vec2 force = 0.5 * vec2(abs(T) - abs(B), abs(R) - abs(L));
    force /= length(force) + 0.0001;
    force *= curl * 30.0 * C;
    gl_FragColor = vec4(texture2D(uVelocity, vUv).xy + force * dt, 0.0, 1.0);
  }
`
), Pe = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv;

  uniform sampler2D uTexture;
  uniform sampler2D uObstacle;
  uniform sampler2D uBackground;
  uniform sampler2D uCoverage;
  uniform sampler2D uVelocity;

  uniform vec2  texelSize;
  uniform vec3  uWaterColor;
  uniform vec3  uGlowColor;
  uniform float uRefraction;
  uniform float uSpecularExp;
  uniform float uShine;
  uniform float uWarpStrength;
  uniform int   uAlgorithm;

  void main () {
    float obs      = texture2D(uObstacle,  vUv).r;
    // Mask density inside obstacles so splats don't flicker the text/image content.
    float density  = max(texture2D(uTexture, vUv).r, 0.0) * (1.0 - step(0.5, obs));
    float coverage = texture2D(uCoverage,  vUv).r;

    float dL = max(texture2D(uTexture, vUv - vec2(texelSize.x * 2.0, 0.0)).r, 0.0);
    float dR = max(texture2D(uTexture, vUv + vec2(texelSize.x * 2.0, 0.0)).r, 0.0);
    float dT = max(texture2D(uTexture, vUv + vec2(0.0, texelSize.y * 2.0)).r, 0.0);
    float dB = max(texture2D(uTexture, vUv - vec2(0.0, texelSize.y * 2.0)).r, 0.0);

    vec3  normal   = normalize(vec3(dL - dR, dB - dT, 0.2));
    vec3  lightDir = normalize(vec3(0.5, 1.0, 0.5));
    vec3  halfV    = normalize(lightDir + vec3(0.0, 0.0, 1.0));
    float spec     = pow(max(dot(normal, halfV), 0.0), uSpecularExp) * uShine * density;

    // In transparent (non-coverage) areas the background texture is empty black canvas.
    // Replace it with uWaterColor so fluid colour is not contaminated by that black,
    // allowing the CSS backgroundColor to show through correctly via premultiplied alpha.
    vec3 bgRaw = texture2D(uBackground, vUv).rgb;
    vec3 bg    = mix(uWaterColor, bgRaw, coverage);
    vec3 color = bg;

    if (uAlgorithm == 1) {
      // ── glass ──────────────────────────────────────────────────────────────
      // Strong UV distortion only. Image bends but no colour overlay.
      vec2 refrUv = clamp(vUv + normal.xy * uRefraction * density * 3.0, 0.0, 1.0);
      vec3 refrBg = mix(uWaterColor, texture2D(uBackground, mix(vUv, refrUv, 1.0 - obs)).rgb, coverage);
      color = refrBg + spec * uGlowColor * 2.5;
      color = mix(color, bg * 0.6, obs * 0.3);

    } else if (uAlgorithm == 2) {
      // ── ink ────────────────────────────────────────────────────────────────
      // Dense opaque pigment that stains. Subtle refraction underneath.
      float inkD  = min(density * 4.0, 1.0);
      vec2 refrUv = clamp(vUv + normal.xy * uRefraction * density * 0.4, 0.0, 1.0);
      vec3 refrBg = mix(uWaterColor, texture2D(uBackground, mix(vUv, refrUv, 1.0 - obs)).rgb, coverage);
      color = mix(refrBg, uWaterColor + spec * uGlowColor, inkD);
      color = mix(color, bg * 0.5, obs * 0.15);

    } else if (uAlgorithm == 3) {
      // ── aurora ─────────────────────────────────────────────────────────────
      // Velocity field warps background UVs — liquid metal / lava-lamp feel.
      vec2  vel    = texture2D(uVelocity, vUv).xy;
      float velMag = clamp(length(vel) * 20.0, 0.0, 1.0);
      vec2  warpUv = clamp(vUv + vel * uWarpStrength, 0.0, 1.0);
      vec3  warpBg = mix(uWaterColor, texture2D(uBackground, warpUv).rgb, coverage);
      color  = mix(bg, warpBg, velMag * (1.0 - obs));
      color += spec * uGlowColor * velMag * 1.5;
      color += uWaterColor * density * 0.3;
      color  = mix(color, bg * 0.5, obs * 0.2);

    } else if (uAlgorithm == 4) {
      // ── ripple ─────────────────────────────────────────────────────────────
      // Exaggerated normal perturbation + Fresnel rim — calm water surface.
      vec2  rippleUv = clamp(vUv + normal.xy * uRefraction * density * 6.0, 0.0, 1.0);
      vec3  refrBg   = mix(uWaterColor, texture2D(uBackground, mix(vUv, rippleUv, 1.0 - obs)).rgb, coverage);
      float fresnel  = pow(clamp(1.0 - dot(normal, vec3(0.0, 0.0, 1.0)), 0.0, 1.0), 3.0) * density;
      color  = refrBg;
      color += fresnel * uGlowColor * 2.0;
      color += spec * uGlowColor * density * 2.0;
      color  = mix(color, bg * 0.5, obs * 0.2);

    } else {
      // ── standard (0) ───────────────────────────────────────────────────────
      // Original: colour overlay blended over refracted background.
      vec2 refrUv = vUv + normal.xy * uRefraction * density;
      vec3 refrBg = mix(uWaterColor, texture2D(uBackground, mix(vUv, refrUv, 1.0 - obs)).rgb, coverage);
      color  = mix(refrBg, uWaterColor, min(density * 1.5, 0.8));
      color += spec * uGlowColor;
      color  = mix(color, bg * 0.5, obs * 0.2);
    }

    // Premultiplied alpha — transparent where there is neither content nor fluid,
    // letting the CSS backgroundColor on the container div show through.
    float alpha = clamp(max(density * 1.5, coverage), 0.0, 1.0);
    gl_FragColor = vec4(color * alpha, alpha);
  }
`
);
function ke(i) {
  const e = { alpha: !0, depth: !1, stencil: !1, antialias: !0, preserveDrawingBuffer: !1 };
  let r = i.getContext("webgl2", e);
  const o = !!r;
  o || (r = i.getContext("webgl", e), r.getExtension("EXT_color_buffer_half_float"));
  const s = o ? null : r.getExtension("OES_texture_half_float"), n = o ? r.HALF_FLOAT : s.HALF_FLOAT_OES;
  return r.getExtension("EXT_color_buffer_float"), r.getExtension("OES_texture_half_float_linear"), {
    gl: r,
    isWebGL2: o,
    ext: {
      internalFormat: o ? r.RGBA16F : r.RGBA,
      format: r.RGBA,
      type: n
    }
  };
}
class k {
  constructor(e, r, o) {
    ne(this, "program");
    ne(this, "uniforms", {});
    ne(this, "_gl");
    this._gl = e, this.program = e.createProgram(), e.attachShader(this.program, this._compile(e.VERTEX_SHADER, r)), e.attachShader(this.program, this._compile(e.FRAGMENT_SHADER, o)), e.linkProgram(this.program);
    const s = e.getProgramParameter(this.program, e.ACTIVE_UNIFORMS);
    for (let n = 0; n < s; n++) {
      const u = e.getActiveUniform(this.program, n).name;
      this.uniforms[u] = e.getUniformLocation(this.program, u);
    }
  }
  _compile(e, r) {
    const o = this._gl, s = o.createShader(e);
    return o.shaderSource(s, r), o.compileShader(s), s;
  }
  bind() {
    this._gl.useProgram(this.program);
  }
  dispose() {
    this._gl.deleteProgram(this.program);
  }
}
function Oe(i) {
  return {
    advection: new k(i, P, Ce),
    divergence: new k(i, P, Fe),
    pressure: new k(i, P, Xe),
    gradientSubtract: new k(i, P, Be),
    splat: new k(i, P, Ae),
    curl: new k(i, P, Le),
    vorticity: new k(i, P, Me),
    display: new k(i, P, Pe)
  };
}
function ue(i, e, r, o) {
  i.activeTexture(i.TEXTURE0);
  const s = i.createTexture();
  i.bindTexture(i.TEXTURE_2D, s), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_MIN_FILTER, i.LINEAR), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_MAG_FILTER, i.LINEAR), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_WRAP_S, i.CLAMP_TO_EDGE), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_WRAP_T, i.CLAMP_TO_EDGE), i.texImage2D(i.TEXTURE_2D, 0, e.internalFormat, r, o, 0, e.format, e.type, null);
  const n = i.createFramebuffer();
  return i.bindFramebuffer(i.FRAMEBUFFER, n), i.framebufferTexture2D(i.FRAMEBUFFER, i.COLOR_ATTACHMENT0, i.TEXTURE_2D, s, 0), { tex: s, fbo: n, width: r, height: o };
}
function de(i, e, r, o) {
  let s = ue(i, e, r, o), n = ue(i, e, r, o);
  return {
    get read() {
      return s;
    },
    get write() {
      return n;
    },
    swap() {
      [s, n] = [n, s];
    },
    dispose() {
      i.deleteTexture(s.tex), i.deleteFramebuffer(s.fbo), i.deleteTexture(n.tex), i.deleteFramebuffer(n.fbo);
    }
  };
}
function Ie(i) {
  const e = i.createBuffer();
  return i.bindBuffer(i.ARRAY_BUFFER, e), i.bufferData(i.ARRAY_BUFFER, new Float32Array([-1, -1, -1, 1, 1, 1, 1, -1]), i.STATIC_DRAW), i.vertexAttribPointer(0, 2, i.FLOAT, !1, 0, 0), i.enableVertexAttribArray(0), function(o) {
    i.bindFramebuffer(i.FRAMEBUFFER, o), i.drawArrays(i.TRIANGLE_FAN, 0, 4);
  };
}
function Te(i, e, r, o, s = "cover") {
  let n;
  s === "cover" ? n = Math.max(r / i, o / e) : s === "contain" ? n = Math.min(r / i, o / e) : typeof s == "string" && s.endsWith("%") ? n = Math.min(r / i, o / e) * (parseFloat(s) / 100) : typeof s == "string" && s.endsWith("px") ? n = parseFloat(s) / Math.max(i, e) : typeof s == "number" ? n = s : n = Math.max(r / i, o / e);
  const u = i * n, d = e * n;
  return { x: (r - u) / 2, y: (o - d) / 2, drawW: u, drawH: d };
}
function Ve(i, e, r, o, s = null, n = "cover") {
  const { text: u, fontSize: d, color: p, fontFamily: c = "sans-serif", fontWeight: m = 900 } = o, y = new OffscreenCanvas(e, r), f = y.getContext("2d");
  ((ce) => {
    if (s) {
      f.clearRect(0, 0, e, r), f.fillStyle = "black", f.fillRect(0, 0, e, r);
      const { x: fe, y: he, drawW: ve, drawH: me } = Te(
        s.width,
        s.height,
        e,
        r,
        n
      );
      f.drawImage(s, fe, he, ve, me);
    } else
      f.fillStyle = "black", f.fillRect(0, 0, e, r);
    f.fillStyle = ce, f.font = `${m} ${d}px ${c}`, f.textAlign = "center", f.textBaseline = "middle", f.fillText(u, e / 2, r / 2);
  })(p);
  const H = ee(i, y);
  f.fillStyle = "black", f.fillRect(0, 0, e, r), f.fillStyle = "white", f.font = `${m} ${d}px ${c}`, f.textAlign = "center", f.textBaseline = "middle", f.fillText(u, e / 2, r / 2);
  const ae = ee(i, y);
  return { backgroundTex: H, obstacleTex: ae, coverageTex: ae };
}
function We(i, e, r, o, s = 0, n = "cover", u = null, d = "cover") {
  const p = new OffscreenCanvas(r, o), c = p.getContext("2d"), { x: m, y, drawW: f, drawH: D } = Te(e.width, e.height, r, o, n);
  if (c.clearRect(0, 0, r, o), c.fillStyle = "black", c.fillRect(0, 0, r, o), u) {
    const {
      x: fe,
      y: he,
      drawW: ve,
      drawH: me
    } = Te(u.width, u.height, r, o, d);
    c.filter = `brightness(${s}) blur(8px)`, c.drawImage(u, fe, he, ve, me), c.filter = "none";
  }
  c.drawImage(e, m, y, f, D);
  const H = ee(i, p);
  c.clearRect(0, 0, r, o), c.fillStyle = "black", c.fillRect(0, 0, r, o), c.filter = `brightness(${s}) blur(8px)`, c.drawImage(e, m, y, f, D), c.filter = "none";
  const ae = ee(i, p);
  c.clearRect(0, 0, r, o), c.fillStyle = "black", c.fillRect(0, 0, r, o), c.fillStyle = "white", c.fillRect(
    Math.max(0, m),
    Math.max(0, y),
    Math.min(f, r - Math.max(0, m)),
    Math.min(D, o - Math.max(0, y))
  );
  const ce = ee(i, p);
  return { backgroundTex: H, obstacleTex: ae, coverageTex: ce };
}
function ee(i, e) {
  const r = i.createTexture();
  return i.bindTexture(i.TEXTURE_2D, r), i.pixelStorei(i.UNPACK_FLIP_Y_WEBGL, !0), i.texImage2D(i.TEXTURE_2D, 0, i.RGBA, i.RGBA, i.UNSIGNED_BYTE, e), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_MIN_FILTER, i.LINEAR), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_MAG_FILTER, i.LINEAR), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_WRAP_S, i.CLAMP_TO_EDGE), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_WRAP_T, i.CLAMP_TO_EDGE), r;
}
async function Ge(i) {
  const e = await fetch(i);
  if (!e.ok)
    throw new Error(`Failed to fetch image: ${i} (${e.status})`);
  const r = await e.blob();
  return createImageBitmap(r);
}
const ge = typeof requestAnimationFrame < "u" ? requestAnimationFrame.bind(globalThis) : (i) => setTimeout(i, 1e3 / 60), ze = typeof cancelAnimationFrame < "u" ? cancelAnimationFrame.bind(globalThis) : clearTimeout, Re = 0.016, Ne = { standard: 0, glass: 1, ink: 2, aurora: 3, ripple: 4 };
var W, g, te, G, q, E, b, O, I, w, Q, L, R, h, C, F, X, M, U, B, S, K, z, x, _, A, N, re, $, J, ie, pe, V, j, Y, Z, oe, Ee, se, be, le, De;
class $e {
  constructor(e, r = {}, o = {}) {
    // ---------------------------------------------------------------------------
    // Private helpers
    // ---------------------------------------------------------------------------
    l(this, $);
    l(this, ie);
    l(this, V);
    l(this, Y);
    l(this, oe);
    l(this, se);
    l(this, le);
    l(this, W, void 0);
    l(this, g, void 0);
    l(this, te, void 0);
    l(this, G, void 0);
    l(this, q, void 0);
    l(this, E, 0);
    l(this, b, 0);
    l(this, O, 0);
    l(this, I, 0);
    l(this, w, 1);
    l(this, Q, 1);
    l(this, L, 0.5);
    l(this, R, null);
    l(this, h, null);
    l(this, C, null);
    l(this, F, null);
    l(this, X, null);
    l(this, M, null);
    l(this, U, null);
    l(this, B, null);
    // binary content mask for transparent canvas support
    l(this, S, null);
    // optional background image (from backgroundSrc prop)
    l(this, K, "cover");
    l(this, z, void 0);
    l(this, x, { x: 0, y: 0, dx: 0, dy: 0, targetX: 0, targetY: 0, moved: !1 });
    // Stores source so textures can be rebuilt on resize
    l(this, _, null);
    l(this, A, null);
    l(this, N, !1);
    l(this, re, !1);
    a(this, W, e), a(this, Q, Math.max(0.1, Math.min(1, o.dpr ?? 1))), a(this, L, Math.max(0.1, Math.min(1, o.sim ?? 0.5))), a(this, z, Se(r));
    const { gl: s, ext: n } = ke(e);
    a(this, g, s), a(this, te, n), a(this, G, Oe(s)), a(this, q, Ie(s)), s.clearColor(0, 0, 0, 0);
  }
  // ---------------------------------------------------------------------------
  // Public API
  // ---------------------------------------------------------------------------
  setTextSource(e) {
    a(this, _, { type: "text", opts: e }), T(this, $, J).call(this), T(this, V, j).call(this), T(this, Y, Z).call(this);
  }
  async setImageSource(e, r = 0, o = "cover") {
    const s = await Ge(e);
    if (t(this, re)) {
      s.close();
      return;
    }
    a(this, _, { type: "image", bitmap: s, effect: r, size: o }), T(this, $, J).call(this), T(this, V, j).call(this), T(this, Y, Z).call(this);
  }
  setImageBitmap(e, r = 0, o = "cover") {
    a(this, _, { type: "image", bitmap: e, effect: r, size: o }), T(this, $, J).call(this), T(this, V, j).call(this), T(this, Y, Z).call(this);
  }
  setBackground(e, r = "cover") {
    t(this, S) && t(this, S) !== e && t(this, S).close(), a(this, S, e), a(this, K, r ?? "cover"), t(this, _) && t(this, E) > 0 && t(this, b) > 0 && T(this, V, j).call(this);
  }
  handleMove(e, r, o = 1) {
    t(this, x).moved = !0, t(this, x).dx = (e - t(this, x).targetX) * o, t(this, x).dy = (r - t(this, x).targetY) * o, t(this, x).targetX = e, t(this, x).targetY = r;
  }
  /**
   * Immediately applies one fluid splat at (x, y) with explicit velocity (vx, vy).
   * Safe to call multiple times per frame — each call writes directly to the FBOs.
   * Designed for programmatic use cases (e.g. particle systems, attractor paths)
   * where you want N independent injection points per frame without flooding the
   * mouse-state machine or the worker message queue.
   */
  splat(e, r, o, s, n = 1) {
    if (!t(this, N) || t(this, E) === 0)
      return;
    const u = t(this, g), d = t(this, z), { splat: p } = t(this, G), c = t(this, q);
    u.viewport(0, 0, t(this, O), t(this, I)), p.bind(), u.uniform1f(p.uniforms.aspectRatio, t(this, E) / t(this, b)), u.uniform2f(p.uniforms.point, e * t(this, w) / t(this, E), 1 - r * t(this, w) / t(this, b)), u.uniform1f(p.uniforms.radius, d.splatRadius), u.uniform1i(p.uniforms.uTarget, 0), u.activeTexture(u.TEXTURE0), u.bindTexture(u.TEXTURE_2D, t(this, h).read.tex), u.uniform3f(p.uniforms.color, o * d.splatForce * n, -s * d.splatForce * n, 0), c(t(this, h).write.fbo), t(this, h).swap(), u.activeTexture(u.TEXTURE0), u.bindTexture(u.TEXTURE_2D, t(this, R).read.tex), u.uniform3f(p.uniforms.color, n, n, n), c(t(this, R).write.fbo), t(this, R).swap();
  }
  updateQuality(e) {
    e.dpr !== void 0 && a(this, Q, Math.max(0.1, Math.min(1, e.dpr))), e.sim !== void 0 && a(this, L, Math.max(0.1, Math.min(1, e.sim)));
  }
  resize(e, r, o) {
    if (o !== void 0 ? a(this, w, o) : typeof window < "u" && window.devicePixelRatio && a(this, w, window.devicePixelRatio), e !== void 0 && e > 0) {
      if (r === void 0 || r <= 0)
        return;
      a(this, E, t(this, W).width = e), a(this, b, t(this, W).height = r), a(this, O, Math.max(1, Math.round(e * t(this, L)))), a(this, I, Math.max(1, Math.round(r * t(this, L)))), T(this, ie, pe).call(this);
    } else
      T(this, $, J).call(this);
    t(this, _) && T(this, V, j).call(this), T(this, Y, Z).call(this);
  }
  updateConfig(e) {
    Object.assign(t(this, z), e);
  }
  destroy() {
    a(this, re, !0), this.stop();
    const e = t(this, g);
    T(this, oe, Ee).call(this), T(this, se, be).call(this), t(this, S) && (t(this, S).close(), a(this, S, null));
    for (const o of Object.values(t(this, G)))
      o.dispose();
    const r = e.getExtension("WEBGL_lose_context");
    r == null || r.loseContext();
  }
  // ---------------------------------------------------------------------------
  // Loop control
  // ---------------------------------------------------------------------------
  start() {
    if (t(this, A) !== null)
      return;
    const e = () => {
      T(this, le, De).call(this), a(this, A, ge(e));
    };
    a(this, A, ge(e));
  }
  stop() {
    t(this, A) !== null && (ze(t(this, A)), a(this, A, null));
  }
  get isRunning() {
    return t(this, A) !== null;
  }
}
W = new WeakMap(), g = new WeakMap(), te = new WeakMap(), G = new WeakMap(), q = new WeakMap(), E = new WeakMap(), b = new WeakMap(), O = new WeakMap(), I = new WeakMap(), w = new WeakMap(), Q = new WeakMap(), L = new WeakMap(), R = new WeakMap(), h = new WeakMap(), C = new WeakMap(), F = new WeakMap(), X = new WeakMap(), M = new WeakMap(), U = new WeakMap(), B = new WeakMap(), S = new WeakMap(), K = new WeakMap(), z = new WeakMap(), x = new WeakMap(), _ = new WeakMap(), A = new WeakMap(), N = new WeakMap(), re = new WeakMap(), $ = new WeakSet(), J = function() {
  const e = t(this, W);
  "clientWidth" in e && e.clientWidth > 0 ? (a(this, w, (typeof window < "u" && window.devicePixelRatio || 1) * t(this, Q)), a(this, E, e.width = Math.round(e.clientWidth * t(this, w))), a(this, b, e.height = Math.round(e.clientHeight * t(this, w)))) : (a(this, E, e.width), a(this, b, e.height)), !(t(this, E) === 0 || t(this, b) === 0) && (a(this, O, Math.max(1, Math.round(t(this, E) * t(this, L)))), a(this, I, Math.max(1, Math.round(t(this, b) * t(this, L)))), T(this, ie, pe).call(this));
}, ie = new WeakSet(), pe = function() {
  const e = t(this, g), r = t(this, te), o = t(this, O), s = t(this, I);
  T(this, oe, Ee).call(this), a(this, R, de(e, r, o, s)), a(this, h, de(e, r, o, s)), a(this, F, de(e, r, o, s)), a(this, C, ue(e, r, o, s)), a(this, X, ue(e, r, o, s));
}, V = new WeakSet(), j = function() {
  if (!(!t(this, _) || t(this, E) === 0 || t(this, b) === 0)) {
    if (T(this, se, be).call(this), t(this, _).type === "text") {
      const { backgroundTex: e, obstacleTex: r, coverageTex: o } = Ve(
        t(this, g),
        t(this, E),
        t(this, b),
        t(this, _).opts,
        t(this, S),
        t(this, K)
      );
      a(this, M, e), a(this, U, r), a(this, B, o);
    } else {
      const { backgroundTex: e, obstacleTex: r, coverageTex: o } = We(
        t(this, g),
        t(this, _).bitmap,
        t(this, E),
        t(this, b),
        t(this, _).effect,
        t(this, _).size,
        t(this, S),
        t(this, K)
      );
      a(this, M, e), a(this, U, r), a(this, B, o);
    }
    a(this, N, !0);
  }
}, Y = new WeakSet(), Z = function() {
  t(this, N) && !this.isRunning && this.start();
}, oe = new WeakSet(), Ee = function() {
  var e, r, o;
  (e = t(this, R)) == null || e.dispose(), (r = t(this, h)) == null || r.dispose(), (o = t(this, F)) == null || o.dispose(), t(this, C) && (t(this, g).deleteTexture(t(this, C).tex), t(this, g).deleteFramebuffer(t(this, C).fbo)), t(this, X) && (t(this, g).deleteTexture(t(this, X).tex), t(this, g).deleteFramebuffer(t(this, X).fbo)), a(this, R, a(this, h, a(this, F, a(this, C, a(this, X, null)))));
}, se = new WeakSet(), be = function() {
  t(this, M) && t(this, g).deleteTexture(t(this, M)), t(this, U) && t(this, g).deleteTexture(t(this, U)), t(this, B) && t(this, B) !== t(this, U) && t(this, g).deleteTexture(t(this, B)), a(this, M, a(this, U, a(this, B, null)));
}, le = new WeakSet(), De = function() {
  if (!t(this, N) || t(this, E) === 0 || !t(this, R) || !t(this, h))
    return;
  const e = t(this, g), r = t(this, z), { advection: o, divergence: s, pressure: n, gradientSubtract: u, splat: d, curl: p, vorticity: c, display: m } = t(this, G);
  t(this, x).x += (t(this, x).targetX - t(this, x).x) * 0.15, t(this, x).y += (t(this, x).targetY - t(this, x).y) * 0.15;
  const y = t(this, O), f = t(this, I), D = t(this, q);
  e.viewport(0, 0, y, f), o.bind(), e.uniform2f(o.uniforms.texelSize, 1 / y, 1 / f), e.uniform1f(o.uniforms.dt, Re), e.uniform1i(o.uniforms.uObstacle, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, U)), e.uniform1f(o.uniforms.dissipation, r.velocityDissipation), e.uniform1i(o.uniforms.uVelocity, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, h).read.tex), e.uniform1i(o.uniforms.uSource, 1), D(t(this, h).write.fbo), t(this, h).swap(), e.uniform1f(o.uniforms.dissipation, r.densityDissipation), e.uniform1i(o.uniforms.uSource, 2), e.activeTexture(e.TEXTURE2), e.bindTexture(e.TEXTURE_2D, t(this, R).read.tex), D(t(this, R).write.fbo), t(this, R).swap(), p.bind(), e.uniform2f(p.uniforms.texelSize, 1 / y, 1 / f), e.uniform1i(p.uniforms.uVelocity, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, h).read.tex), D(t(this, X).fbo), c.bind(), e.uniform2f(c.uniforms.texelSize, 1 / y, 1 / f), e.uniform1f(c.uniforms.curl, r.curl), e.uniform1f(c.uniforms.dt, Re), e.uniform1i(c.uniforms.uVelocity, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, h).read.tex), e.uniform1i(c.uniforms.uCurl, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, X).tex), D(t(this, h).write.fbo), t(this, h).swap(), t(this, x).moved && (d.bind(), e.uniform1f(d.uniforms.aspectRatio, t(this, E) / t(this, b)), e.uniform2f(d.uniforms.point, t(this, x).x * t(this, w) / t(this, E), 1 - t(this, x).y * t(this, w) / t(this, b)), e.uniform1f(d.uniforms.radius, r.splatRadius), e.uniform1i(d.uniforms.uTarget, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, h).read.tex), e.uniform3f(d.uniforms.color, t(this, x).dx * r.splatForce, -t(this, x).dy * r.splatForce, 0), D(t(this, h).write.fbo), t(this, h).swap(), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, R).read.tex), e.uniform3f(d.uniforms.color, 1, 1, 1), D(t(this, R).write.fbo), t(this, R).swap(), t(this, x).moved = !1), s.bind(), e.uniform2f(s.uniforms.texelSize, 1 / y, 1 / f), e.uniform1i(s.uniforms.uVelocity, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, h).read.tex), e.uniform1i(s.uniforms.uObstacle, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, U)), D(t(this, C).fbo), n.bind(), e.uniform2f(n.uniforms.texelSize, 1 / y, 1 / f), e.uniform1i(n.uniforms.uDivergence, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, C).tex), e.uniform1i(n.uniforms.uObstacle, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, U));
  for (let H = 0; H < r.pressureIterations; H++)
    e.uniform1i(n.uniforms.uPressure, 2), e.activeTexture(e.TEXTURE2), e.bindTexture(e.TEXTURE_2D, t(this, F).read.tex), D(t(this, F).write.fbo), t(this, F).swap();
  u.bind(), e.uniform2f(u.uniforms.texelSize, 1 / y, 1 / f), e.uniform1i(u.uniforms.uPressure, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, F).read.tex), e.uniform1i(u.uniforms.uVelocity, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, h).read.tex), e.uniform1i(u.uniforms.uObstacle, 2), e.activeTexture(e.TEXTURE2), e.bindTexture(e.TEXTURE_2D, t(this, U)), D(t(this, h).write.fbo), t(this, h).swap(), e.viewport(0, 0, t(this, E), t(this, b)), e.bindFramebuffer(e.FRAMEBUFFER, null), e.clear(e.COLOR_BUFFER_BIT), m.bind(), e.uniform2f(m.uniforms.texelSize, 1 / t(this, E), 1 / t(this, b)), e.uniform3fv(m.uniforms.uWaterColor, r.waterColor), e.uniform3fv(m.uniforms.uGlowColor, r.glowColor), e.uniform1f(m.uniforms.uRefraction, r.refraction), e.uniform1f(m.uniforms.uSpecularExp, r.specularExp), e.uniform1f(m.uniforms.uShine, r.shine), e.uniform1f(m.uniforms.uWarpStrength, r.warpStrength ?? 0.015), e.uniform1i(m.uniforms.uAlgorithm, Ne[r.algorithm] ?? 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, R).read.tex), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, U)), e.activeTexture(e.TEXTURE2), e.bindTexture(e.TEXTURE_2D, t(this, M)), e.activeTexture(e.TEXTURE3), e.bindTexture(e.TEXTURE_2D, t(this, B)), e.activeTexture(e.TEXTURE4), e.bindTexture(e.TEXTURE_2D, t(this, h).read.tex), e.uniform1i(m.uniforms.uTexture, 0), e.uniform1i(m.uniforms.uObstacle, 1), e.uniform1i(m.uniforms.uBackground, 2), e.uniform1i(m.uniforms.uCoverage, 3), e.uniform1i(m.uniforms.uVelocity, 4), D(null);
};
let v = null;
self.onmessage = async (i) => {
  const { type: e, ...r } = i.data;
  try {
    switch (e) {
      case "init": {
        const { canvas: o, width: s, height: n, config: u, dpr: d, quality: p } = r;
        o.width = s, o.height = n, v = new $e(o, u, p ?? {}), v.resize(s, n, d || 1), self.postMessage({ type: "ready" });
        break;
      }
      case "setTextSource": {
        if (!v)
          return;
        v.setTextSource(r.opts);
        break;
      }
      case "setImageSource": {
        if (!v)
          return;
        await v.setImageSource(
          r.src,
          r.effect,
          r.size
        );
        break;
      }
      case "setImageBitmap": {
        if (!v)
          return;
        v.setImageBitmap(
          r.bitmap,
          r.effect,
          r.size
        );
        break;
      }
      case "setBackground": {
        if (!v)
          return;
        v.setBackground(r.bitmap, r.size);
        break;
      }
      case "splat": {
        if (!v)
          return;
        v.splat(
          r.x,
          r.y,
          r.vx,
          r.vy,
          r.strength ?? 1
        );
        break;
      }
      case "move": {
        if (!v)
          return;
        v.handleMove(r.x, r.y, r.strength ?? 1);
        break;
      }
      case "resize": {
        if (!v)
          return;
        v.resize(r.width, r.height, r.dpr);
        break;
      }
      case "updateQuality": {
        if (!v)
          return;
        v.updateQuality(r.quality);
        break;
      }
      case "updateConfig": {
        if (!v)
          return;
        v.updateConfig(r.config);
        break;
      }
      case "destroy": {
        v == null || v.destroy(), v = null;
        break;
      }
      default:
        console.warn("[fluidity-js worker] Unknown message type:", e);
    }
  } catch (o) {
    self.postMessage({ type: "error", message: (o == null ? void 0 : o.message) ?? String(o) });
  }
};
", JI = typeof window < "u" && window.Blob && new Blob([atob(PI)], { type: "text/javascript;charset=utf-8" });
|
|
680
|
+
function Gg() {
|
|
675
681
|
let C;
|
|
676
682
|
try {
|
|
677
|
-
if (C =
|
|
683
|
+
if (C = JI && (window.URL || window.webkitURL).createObjectURL(JI), !C)
|
|
678
684
|
throw "";
|
|
679
685
|
return new Worker(C);
|
|
680
686
|
} catch {
|
|
681
|
-
return new Worker("data:application/javascript;base64," +
|
|
687
|
+
return new Worker("data:application/javascript;base64," + PI, { type: "module" });
|
|
682
688
|
} finally {
|
|
683
689
|
C && (window.URL || window.webkitURL).revokeObjectURL(C);
|
|
684
690
|
}
|
|
685
691
|
}
|
|
686
|
-
const
|
|
687
|
-
var p,
|
|
688
|
-
class
|
|
689
|
-
constructor(I, {
|
|
692
|
+
const hg = typeof Worker < "u" && typeof OffscreenCanvas < "u";
|
|
693
|
+
var p, U, ZI, T, O, XI, _I;
|
|
694
|
+
class Bg {
|
|
695
|
+
constructor(I, {
|
|
696
|
+
isWorkerEnabled: i = !0,
|
|
697
|
+
quality: e = {},
|
|
698
|
+
config: s = {}
|
|
699
|
+
} = {}) {
|
|
690
700
|
// ---------------------------------------------------------------------------
|
|
691
701
|
// Private
|
|
692
702
|
// ---------------------------------------------------------------------------
|
|
693
|
-
|
|
694
|
-
|
|
695
|
-
|
|
696
|
-
|
|
697
|
-
|
|
698
|
-
|
|
703
|
+
m(this, XI);
|
|
704
|
+
m(this, p, null);
|
|
705
|
+
m(this, U, null);
|
|
706
|
+
m(this, ZI, void 0);
|
|
707
|
+
m(this, T, void 0);
|
|
708
|
+
m(this, O, void 0);
|
|
709
|
+
l(this, T, Math.max(0.1, Math.min(1, e.dpr ?? 1))), l(this, O, Math.max(0.1, Math.min(1, e.sim ?? 0.5))), l(this, ZI, i && hg), g(this, ZI) ? b(this, XI, _I).call(this, I, s) : l(this, U, new EI(I, s, { dpr: g(this, T), sim: g(this, O) }));
|
|
699
710
|
}
|
|
700
711
|
// ---------------------------------------------------------------------------
|
|
701
712
|
// Source setters
|
|
702
713
|
// ---------------------------------------------------------------------------
|
|
703
714
|
setTextSource(I) {
|
|
704
|
-
g(this, p) ? g(this, p).postMessage({ type: "setTextSource", opts: I }) : g(this,
|
|
715
|
+
g(this, p) ? g(this, p).postMessage({ type: "setTextSource", opts: I }) : g(this, U).setTextSource(I);
|
|
705
716
|
}
|
|
706
|
-
setImageSource(I, i =
|
|
717
|
+
setImageSource(I, i = iI.effect, e = iI.imageSize) {
|
|
707
718
|
if (g(this, p)) {
|
|
708
|
-
const
|
|
709
|
-
g(this, p).postMessage({ type: "setImageSource", src:
|
|
719
|
+
const s = new URL(I, location.href).href;
|
|
720
|
+
g(this, p).postMessage({ type: "setImageSource", src: s, effect: i, size: e });
|
|
710
721
|
} else
|
|
711
|
-
g(this,
|
|
722
|
+
g(this, U).setImageSource(I, i, e);
|
|
712
723
|
}
|
|
713
724
|
setBackground(I, i = "cover") {
|
|
714
725
|
var e;
|
|
715
726
|
if (g(this, p)) {
|
|
716
|
-
const
|
|
717
|
-
g(this, p).postMessage({ type: "setBackground", bitmap: I ?? null, size: i },
|
|
727
|
+
const s = I ? [I] : [];
|
|
728
|
+
g(this, p).postMessage({ type: "setBackground", bitmap: I ?? null, size: i }, s);
|
|
718
729
|
} else
|
|
719
|
-
(e = g(this,
|
|
730
|
+
(e = g(this, U)) == null || e.setBackground(I ?? null, i);
|
|
720
731
|
}
|
|
721
732
|
// ---------------------------------------------------------------------------
|
|
722
733
|
// Interaction
|
|
@@ -725,165 +736,185 @@ class ug {
|
|
|
725
736
|
* Immediately injects one splat at (x, y) with explicit velocity (vx, vy).
|
|
726
737
|
* Safe to call multiple times per frame. See FluidSimulation.splat for details.
|
|
727
738
|
*/
|
|
728
|
-
splat(I, i, e,
|
|
729
|
-
g(this, p) ? g(this, p).postMessage({ type: "splat", x: I, y: i, vx: e, vy:
|
|
739
|
+
splat(I, i, e, s, o = 1) {
|
|
740
|
+
g(this, p) ? g(this, p).postMessage({ type: "splat", x: I, y: i, vx: e, vy: s, strength: o }) : g(this, U).splat(I, i, e, s, o);
|
|
730
741
|
}
|
|
731
742
|
handleMove(I, i, e = 1) {
|
|
732
|
-
g(this, p) ? g(this, p).postMessage({ type: "move", x: I, y: i, strength: e }) : g(this,
|
|
743
|
+
g(this, p) ? g(this, p).postMessage({ type: "move", x: I, y: i, strength: e }) : g(this, U).handleMove(I, i, e);
|
|
733
744
|
}
|
|
734
745
|
// ---------------------------------------------------------------------------
|
|
735
746
|
// Config + control
|
|
736
747
|
// ---------------------------------------------------------------------------
|
|
748
|
+
updateQuality(I) {
|
|
749
|
+
l(this, T, Math.max(0.1, Math.min(1, I.dpr ?? g(this, T)))), l(this, O, Math.max(0.1, Math.min(1, I.sim ?? g(this, O)))), g(this, p) ? g(this, p).postMessage({ type: "updateQuality", quality: { dpr: g(this, T), sim: g(this, O) } }) : g(this, U).updateQuality(I);
|
|
750
|
+
}
|
|
737
751
|
updateConfig(I) {
|
|
738
|
-
g(this, p) ? g(this, p).postMessage({ type: "updateConfig", config: I }) : g(this,
|
|
752
|
+
g(this, p) ? g(this, p).postMessage({ type: "updateConfig", config: I }) : g(this, U).updateConfig(I);
|
|
739
753
|
}
|
|
740
754
|
resize(I, i) {
|
|
741
|
-
|
|
742
|
-
|
|
743
|
-
g(this, p).postMessage({ type: "resize", width: I, height: i, dpr: e });
|
|
744
|
-
} else
|
|
745
|
-
g(this, k).resize(I, i);
|
|
755
|
+
const e = (typeof window < "u" && window.devicePixelRatio || 1) * g(this, T);
|
|
756
|
+
g(this, p) ? g(this, p).postMessage({ type: "resize", width: I, height: i, dpr: e }) : g(this, U).resize(I, i, e);
|
|
746
757
|
}
|
|
747
758
|
destroy() {
|
|
748
759
|
var I;
|
|
749
760
|
if (g(this, p)) {
|
|
750
761
|
const i = g(this, p);
|
|
751
|
-
|
|
762
|
+
l(this, p, null), i.postMessage({ type: "destroy" }), setTimeout(() => i.terminate(), 50);
|
|
752
763
|
} else
|
|
753
|
-
(I = g(this,
|
|
764
|
+
(I = g(this, U)) == null || I.destroy(), l(this, U, null);
|
|
754
765
|
}
|
|
755
766
|
}
|
|
756
|
-
p = new WeakMap(),
|
|
757
|
-
const e = typeof window < "u" && window.devicePixelRatio || 1,
|
|
758
|
-
I.width =
|
|
767
|
+
p = new WeakMap(), U = new WeakMap(), ZI = new WeakMap(), T = new WeakMap(), O = new WeakMap(), XI = new WeakSet(), _I = function(I, i) {
|
|
768
|
+
const e = (typeof window < "u" && window.devicePixelRatio || 1) * g(this, T), s = Math.round(I.clientWidth * e), o = Math.round(I.clientHeight * e);
|
|
769
|
+
I.width = s, I.height = o;
|
|
759
770
|
let t;
|
|
760
771
|
try {
|
|
761
772
|
t = I.transferControlToOffscreen();
|
|
762
773
|
} catch {
|
|
763
774
|
console.warn(
|
|
764
775
|
"[fluidity-js] OffscreenCanvas transfer failed — falling back to main-thread mode. This is expected in React StrictMode development."
|
|
765
|
-
),
|
|
776
|
+
), l(this, ZI, !1), l(this, U, new EI(I, i, { dpr: g(this, T), sim: g(this, O) }));
|
|
766
777
|
return;
|
|
767
778
|
}
|
|
768
|
-
const
|
|
769
|
-
|
|
770
|
-
console.error("[fluidity-js] Worker error:",
|
|
771
|
-
},
|
|
772
|
-
|
|
773
|
-
},
|
|
779
|
+
const u = l(this, p, new Gg());
|
|
780
|
+
u.onerror = (a) => {
|
|
781
|
+
console.error("[fluidity-js] Worker error:", a.message);
|
|
782
|
+
}, u.onmessage = (a) => {
|
|
783
|
+
a.data.type === "error" && console.error("[fluidity-js] Simulation error:", a.data.message);
|
|
784
|
+
}, u.postMessage(
|
|
785
|
+
{ type: "init", canvas: t, width: s, height: o, config: i, dpr: e, quality: { dpr: g(this, T), sim: g(this, O) } },
|
|
786
|
+
[t]
|
|
787
|
+
);
|
|
774
788
|
};
|
|
775
|
-
function
|
|
776
|
-
const
|
|
777
|
-
|
|
778
|
-
|
|
779
|
-
|
|
789
|
+
function qI(C, { isWorkerEnabled: I = !0, quality: i = {}, config: e = {} } = {}) {
|
|
790
|
+
const s = mI(null), o = mI({ isWorkerEnabled: I, quality: i, config: e }), t = mI(Math.max(0.1, Math.min(1, i.dpr ?? 1))), u = mI({
|
|
791
|
+
dpr: i.dpr,
|
|
792
|
+
sim: i.sim
|
|
793
|
+
});
|
|
794
|
+
return j(() => {
|
|
795
|
+
const a = C.current;
|
|
796
|
+
if (!a)
|
|
780
797
|
return;
|
|
781
|
-
const
|
|
782
|
-
|
|
783
|
-
const
|
|
784
|
-
|
|
785
|
-
|
|
786
|
-
|
|
787
|
-
const
|
|
788
|
-
|
|
789
|
-
|
|
790
|
-
|
|
798
|
+
const c = document.createElement("canvas");
|
|
799
|
+
c.style.cssText = "position:absolute;inset:0;width:100%;height:100%;display:block;", a.appendChild(c);
|
|
800
|
+
const { isWorkerEnabled: n, quality: G, config: d } = o.current, h = (window.devicePixelRatio || 1) * t.current, W = a.getBoundingClientRect(), x = Math.round((W.width || a.clientWidth) * h) || 0, F = Math.round((W.height || a.clientHeight) * h) || 0;
|
|
801
|
+
x > 0 && (c.width = x, c.height = F), F === 0 && console.warn(
|
|
802
|
+
"[fluidity-js] Container has zero height — simulation will not render. Avoid height:auto or percentage heights without a sized ancestor. Use explicit pixel values instead."
|
|
803
|
+
);
|
|
804
|
+
const w = new Bg(c, { isWorkerEnabled: n, quality: G, config: d });
|
|
805
|
+
s.current = w;
|
|
806
|
+
const D = new ResizeObserver((A) => {
|
|
807
|
+
for (const y of A) {
|
|
808
|
+
const r = (window.devicePixelRatio || 1) * t.current, { inlineSize: Z, blockSize: V } = y.contentBoxSize[0];
|
|
809
|
+
w.resize(Math.round(Z * r), Math.round(V * r));
|
|
791
810
|
}
|
|
792
811
|
});
|
|
793
|
-
return
|
|
794
|
-
|
|
812
|
+
return D.observe(a), () => {
|
|
813
|
+
D.disconnect(), w.destroy(), c.remove(), s.current = null;
|
|
795
814
|
};
|
|
796
|
-
}, []),
|
|
815
|
+
}, []), j(() => {
|
|
816
|
+
t.current = Math.max(0.1, Math.min(1, i.dpr ?? 1));
|
|
817
|
+
const a = u.current;
|
|
818
|
+
u.current = { dpr: i.dpr, sim: i.sim };
|
|
819
|
+
const c = s.current, n = C.current;
|
|
820
|
+
if (!c || !n || a.dpr === i.dpr && a.sim === i.sim)
|
|
821
|
+
return;
|
|
822
|
+
c.updateQuality(i);
|
|
823
|
+
const G = (window.devicePixelRatio || 1) * t.current, d = n.clientWidth, h = n.clientHeight;
|
|
824
|
+
d > 0 && h > 0 && c.resize(Math.round(d * G), Math.round(h * G));
|
|
825
|
+
}, [i.dpr, i.sim]), s;
|
|
797
826
|
}
|
|
798
|
-
const
|
|
827
|
+
const Lg = zI(function({
|
|
799
828
|
text: I,
|
|
800
|
-
fontSize: i =
|
|
801
|
-
color: e =
|
|
802
|
-
fontFamily:
|
|
803
|
-
fontWeight:
|
|
829
|
+
fontSize: i = $.fontSize,
|
|
830
|
+
color: e = $.color,
|
|
831
|
+
fontFamily: s = $.fontFamily,
|
|
832
|
+
fontWeight: o = $.fontWeight,
|
|
804
833
|
className: t,
|
|
805
|
-
style:
|
|
806
|
-
config:
|
|
807
|
-
preset:
|
|
808
|
-
algorithm:
|
|
809
|
-
backgroundColor:
|
|
810
|
-
backgroundSrc:
|
|
811
|
-
backgroundSize: h =
|
|
812
|
-
isMouseEnabled:
|
|
813
|
-
isWorkerEnabled:
|
|
814
|
-
|
|
815
|
-
|
|
816
|
-
|
|
817
|
-
|
|
834
|
+
style: u,
|
|
835
|
+
config: a,
|
|
836
|
+
preset: c,
|
|
837
|
+
algorithm: n,
|
|
838
|
+
backgroundColor: G = $.backgroundColor,
|
|
839
|
+
backgroundSrc: d,
|
|
840
|
+
backgroundSize: h = $.backgroundSize,
|
|
841
|
+
isMouseEnabled: W = $.isMouseEnabled,
|
|
842
|
+
isWorkerEnabled: x = $.isWorkerEnabled,
|
|
843
|
+
quality: F = HI.quality
|
|
844
|
+
}, w) {
|
|
845
|
+
const D = mI(null), A = qI(D, {
|
|
846
|
+
isWorkerEnabled: x,
|
|
847
|
+
quality: F,
|
|
848
|
+
config: pI({ ...a, ...n ? { algorithm: n } : {} }, c, TI)
|
|
818
849
|
});
|
|
819
|
-
|
|
820
|
-
|
|
850
|
+
QI(
|
|
851
|
+
w,
|
|
821
852
|
() => ({
|
|
822
853
|
reset() {
|
|
823
|
-
var
|
|
824
|
-
(
|
|
854
|
+
var r;
|
|
855
|
+
(r = A.current) == null || r.setTextSource({ text: I, fontSize: i, color: e, fontFamily: s, fontWeight: o });
|
|
825
856
|
},
|
|
826
|
-
move(
|
|
827
|
-
var
|
|
828
|
-
(
|
|
857
|
+
move(r, Z, V = 1) {
|
|
858
|
+
var S;
|
|
859
|
+
(S = A.current) == null || S.handleMove(r, Z, V);
|
|
829
860
|
},
|
|
830
|
-
splat(
|
|
831
|
-
var
|
|
832
|
-
(
|
|
861
|
+
splat(r, Z, V, S, M = 1) {
|
|
862
|
+
var q;
|
|
863
|
+
(q = A.current) == null || q.splat(r, Z, V, S, M);
|
|
833
864
|
},
|
|
834
|
-
updateConfig(
|
|
835
|
-
var
|
|
836
|
-
(
|
|
865
|
+
updateConfig(r) {
|
|
866
|
+
var Z;
|
|
867
|
+
(Z = A.current) == null || Z.updateConfig(r);
|
|
837
868
|
}
|
|
838
869
|
}),
|
|
839
|
-
[I, i, e,
|
|
840
|
-
),
|
|
841
|
-
var
|
|
842
|
-
(
|
|
843
|
-
}, [I, i, e,
|
|
844
|
-
const
|
|
845
|
-
return
|
|
846
|
-
var
|
|
847
|
-
(
|
|
848
|
-
|
|
870
|
+
[I, i, e, s, o]
|
|
871
|
+
), j(() => {
|
|
872
|
+
var r;
|
|
873
|
+
(r = A.current) == null || r.setTextSource({ text: I, fontSize: i, color: e, fontFamily: s, fontWeight: o });
|
|
874
|
+
}, [I, i, e, s, o]);
|
|
875
|
+
const y = JSON.stringify(a);
|
|
876
|
+
return j(() => {
|
|
877
|
+
var r;
|
|
878
|
+
(r = A.current) == null || r.updateConfig(
|
|
879
|
+
pI({ ...a, ...n !== void 0 ? { algorithm: n } : {} }, c, TI)
|
|
849
880
|
);
|
|
850
|
-
}, [
|
|
851
|
-
var
|
|
852
|
-
if (!
|
|
853
|
-
(
|
|
881
|
+
}, [c, n, y]), j(() => {
|
|
882
|
+
var Z;
|
|
883
|
+
if (!d) {
|
|
884
|
+
(Z = A.current) == null || Z.setBackground(null);
|
|
854
885
|
return;
|
|
855
886
|
}
|
|
856
|
-
let
|
|
857
|
-
return
|
|
858
|
-
var
|
|
859
|
-
if (
|
|
860
|
-
|
|
887
|
+
let r = !1;
|
|
888
|
+
return kI(d).then((V) => {
|
|
889
|
+
var S;
|
|
890
|
+
if (r) {
|
|
891
|
+
V.close();
|
|
861
892
|
return;
|
|
862
893
|
}
|
|
863
|
-
(
|
|
864
|
-
}).catch((
|
|
865
|
-
|
|
894
|
+
(S = A.current) == null || S.setBackground(V, h);
|
|
895
|
+
}).catch((V) => console.error("[fluidity-js] backgroundSrc load failed:", V)), () => {
|
|
896
|
+
r = !0;
|
|
866
897
|
};
|
|
867
|
-
}, [
|
|
868
|
-
if (!
|
|
898
|
+
}, [d, h]), j(() => {
|
|
899
|
+
if (!W)
|
|
869
900
|
return;
|
|
870
|
-
const
|
|
871
|
-
if (!
|
|
901
|
+
const r = D.current;
|
|
902
|
+
if (!r)
|
|
872
903
|
return;
|
|
873
|
-
const
|
|
874
|
-
var
|
|
875
|
-
const
|
|
876
|
-
(
|
|
877
|
-
},
|
|
878
|
-
var
|
|
879
|
-
|
|
880
|
-
const
|
|
881
|
-
(
|
|
904
|
+
const Z = (S) => {
|
|
905
|
+
var q;
|
|
906
|
+
const M = r.getBoundingClientRect();
|
|
907
|
+
(q = A.current) == null || q.handleMove(S.clientX - M.left, S.clientY - M.top, 2);
|
|
908
|
+
}, V = (S) => {
|
|
909
|
+
var fI;
|
|
910
|
+
S.preventDefault();
|
|
911
|
+
const M = r.getBoundingClientRect(), q = S.touches[0];
|
|
912
|
+
(fI = A.current) == null || fI.handleMove(q.clientX - M.left, q.clientY - M.top, 1);
|
|
882
913
|
};
|
|
883
|
-
return
|
|
884
|
-
|
|
914
|
+
return r.addEventListener("mousemove", Z), r.addEventListener("touchmove", V, { passive: !1 }), () => {
|
|
915
|
+
r.removeEventListener("mousemove", Z), r.removeEventListener("touchmove", V);
|
|
885
916
|
};
|
|
886
|
-
}, [
|
|
917
|
+
}, [W]), /* @__PURE__ */ NI(
|
|
887
918
|
"div",
|
|
888
919
|
{
|
|
889
920
|
ref: D,
|
|
@@ -893,125 +924,127 @@ const hg = xI(function({
|
|
|
893
924
|
display: "block",
|
|
894
925
|
width: "100%",
|
|
895
926
|
height: "100%",
|
|
896
|
-
background:
|
|
897
|
-
...
|
|
927
|
+
background: G,
|
|
928
|
+
...u
|
|
898
929
|
}
|
|
899
930
|
}
|
|
900
931
|
);
|
|
901
|
-
}),
|
|
932
|
+
}), Vg = zI(function({
|
|
902
933
|
src: I,
|
|
903
|
-
effect: i =
|
|
904
|
-
imageSize: e =
|
|
905
|
-
className:
|
|
906
|
-
style:
|
|
934
|
+
effect: i = iI.effect,
|
|
935
|
+
imageSize: e = iI.imageSize,
|
|
936
|
+
className: s,
|
|
937
|
+
style: o,
|
|
907
938
|
config: t,
|
|
908
|
-
preset:
|
|
909
|
-
algorithm:
|
|
910
|
-
backgroundColor:
|
|
911
|
-
backgroundSrc:
|
|
912
|
-
backgroundSize:
|
|
913
|
-
isMouseEnabled:
|
|
914
|
-
isWorkerEnabled: h =
|
|
915
|
-
|
|
916
|
-
|
|
939
|
+
preset: u,
|
|
940
|
+
algorithm: a,
|
|
941
|
+
backgroundColor: c = iI.backgroundColor,
|
|
942
|
+
backgroundSrc: n,
|
|
943
|
+
backgroundSize: G = iI.backgroundSize,
|
|
944
|
+
isMouseEnabled: d = iI.isMouseEnabled,
|
|
945
|
+
isWorkerEnabled: h = iI.isWorkerEnabled,
|
|
946
|
+
quality: W = HI.quality
|
|
947
|
+
}, x) {
|
|
948
|
+
const F = mI(null), w = qI(F, {
|
|
917
949
|
isWorkerEnabled: h,
|
|
918
|
-
|
|
950
|
+
quality: W,
|
|
951
|
+
config: pI({ ...t, ...a ? { algorithm: a } : {} }, u)
|
|
919
952
|
});
|
|
920
|
-
|
|
921
|
-
|
|
953
|
+
QI(
|
|
954
|
+
x,
|
|
922
955
|
() => ({
|
|
923
956
|
reset() {
|
|
924
|
-
var
|
|
925
|
-
I && ((
|
|
957
|
+
var A;
|
|
958
|
+
I && ((A = w.current) == null || A.setImageSource(I, i, e));
|
|
926
959
|
},
|
|
927
|
-
move(
|
|
928
|
-
var
|
|
929
|
-
(
|
|
960
|
+
move(A, y, r = 1) {
|
|
961
|
+
var Z;
|
|
962
|
+
(Z = w.current) == null || Z.handleMove(A, y, r);
|
|
930
963
|
},
|
|
931
|
-
splat(
|
|
932
|
-
var
|
|
933
|
-
(
|
|
964
|
+
splat(A, y, r, Z, V = 1) {
|
|
965
|
+
var S;
|
|
966
|
+
(S = w.current) == null || S.splat(A, y, r, Z, V);
|
|
934
967
|
},
|
|
935
|
-
updateConfig(
|
|
936
|
-
var
|
|
937
|
-
(
|
|
968
|
+
updateConfig(A) {
|
|
969
|
+
var y;
|
|
970
|
+
(y = w.current) == null || y.updateConfig(A);
|
|
938
971
|
}
|
|
939
972
|
}),
|
|
940
973
|
[I, i, e]
|
|
941
|
-
),
|
|
942
|
-
var
|
|
943
|
-
I && ((
|
|
974
|
+
), j(() => {
|
|
975
|
+
var A;
|
|
976
|
+
I && ((A = w.current) == null || A.setImageSource(I, i, e));
|
|
944
977
|
}, [I, i, e]);
|
|
945
978
|
const D = JSON.stringify(t);
|
|
946
|
-
return
|
|
947
|
-
var
|
|
948
|
-
(
|
|
949
|
-
|
|
979
|
+
return j(() => {
|
|
980
|
+
var A;
|
|
981
|
+
(A = w.current) == null || A.updateConfig(
|
|
982
|
+
pI({ ...t, ...a !== void 0 ? { algorithm: a } : {} }, u)
|
|
950
983
|
);
|
|
951
|
-
}, [
|
|
952
|
-
var
|
|
953
|
-
if (!
|
|
954
|
-
(
|
|
984
|
+
}, [u, a, D]), j(() => {
|
|
985
|
+
var y;
|
|
986
|
+
if (!n) {
|
|
987
|
+
(y = w.current) == null || y.setBackground(null);
|
|
955
988
|
return;
|
|
956
989
|
}
|
|
957
|
-
let
|
|
958
|
-
return
|
|
959
|
-
var
|
|
960
|
-
if (
|
|
961
|
-
|
|
990
|
+
let A = !1;
|
|
991
|
+
return kI(n).then((r) => {
|
|
992
|
+
var Z;
|
|
993
|
+
if (A) {
|
|
994
|
+
r.close();
|
|
962
995
|
return;
|
|
963
996
|
}
|
|
964
|
-
(
|
|
965
|
-
}).catch((
|
|
966
|
-
|
|
997
|
+
(Z = w.current) == null || Z.setBackground(r, G);
|
|
998
|
+
}).catch((r) => console.error("[fluidity-js] backgroundSrc load failed:", r)), () => {
|
|
999
|
+
A = !0;
|
|
967
1000
|
};
|
|
968
|
-
}, [
|
|
969
|
-
if (!
|
|
1001
|
+
}, [n, G]), j(() => {
|
|
1002
|
+
if (!d)
|
|
970
1003
|
return;
|
|
971
|
-
const
|
|
972
|
-
if (!
|
|
1004
|
+
const A = F.current;
|
|
1005
|
+
if (!A)
|
|
973
1006
|
return;
|
|
974
|
-
const
|
|
975
|
-
var
|
|
976
|
-
const
|
|
977
|
-
(
|
|
978
|
-
},
|
|
979
|
-
var
|
|
980
|
-
|
|
981
|
-
const
|
|
982
|
-
(
|
|
1007
|
+
const y = (Z) => {
|
|
1008
|
+
var S;
|
|
1009
|
+
const V = A.getBoundingClientRect();
|
|
1010
|
+
(S = w.current) == null || S.handleMove(Z.clientX - V.left, Z.clientY - V.top, 2);
|
|
1011
|
+
}, r = (Z) => {
|
|
1012
|
+
var M;
|
|
1013
|
+
Z.preventDefault();
|
|
1014
|
+
const V = A.getBoundingClientRect(), S = Z.touches[0];
|
|
1015
|
+
(M = w.current) == null || M.handleMove(S.clientX - V.left, S.clientY - V.top, 1);
|
|
983
1016
|
};
|
|
984
|
-
return
|
|
985
|
-
|
|
1017
|
+
return A.addEventListener("mousemove", y), A.addEventListener("touchmove", r, { passive: !1 }), () => {
|
|
1018
|
+
A.removeEventListener("mousemove", y), A.removeEventListener("touchmove", r);
|
|
986
1019
|
};
|
|
987
|
-
}, [
|
|
1020
|
+
}, [d]), /* @__PURE__ */ NI(
|
|
988
1021
|
"div",
|
|
989
1022
|
{
|
|
990
|
-
ref:
|
|
991
|
-
className:
|
|
1023
|
+
ref: F,
|
|
1024
|
+
className: s,
|
|
992
1025
|
style: {
|
|
993
1026
|
position: "relative",
|
|
994
1027
|
display: "block",
|
|
995
1028
|
width: "100%",
|
|
996
1029
|
height: "100%",
|
|
997
|
-
background:
|
|
998
|
-
...
|
|
1030
|
+
background: c,
|
|
1031
|
+
...o
|
|
999
1032
|
}
|
|
1000
1033
|
}
|
|
1001
1034
|
);
|
|
1002
1035
|
});
|
|
1003
1036
|
export {
|
|
1004
|
-
|
|
1005
|
-
|
|
1006
|
-
|
|
1007
|
-
|
|
1008
|
-
|
|
1009
|
-
|
|
1010
|
-
|
|
1011
|
-
|
|
1012
|
-
|
|
1013
|
-
|
|
1014
|
-
|
|
1015
|
-
|
|
1016
|
-
|
|
1037
|
+
OI as DEFAULT_CONFIG,
|
|
1038
|
+
TI as DEFAULT_CONFIG_TEXT,
|
|
1039
|
+
iI as DEFAULT_PROPS_IMAGE,
|
|
1040
|
+
HI as DEFAULT_PROPS_SHARED,
|
|
1041
|
+
$ as DEFAULT_PROPS_TEXT,
|
|
1042
|
+
Bg as FluidController,
|
|
1043
|
+
Vg as FluidImage,
|
|
1044
|
+
EI as FluidSimulation,
|
|
1045
|
+
Lg as FluidText,
|
|
1046
|
+
ig as PRESETS,
|
|
1047
|
+
kI as loadImageBitmap,
|
|
1048
|
+
pI as mergeConfig,
|
|
1049
|
+
qI as useFluid
|
|
1017
1050
|
};
|