@jayf0x/fluidity-js 0.1.4 → 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 +22 -14
- package/dist/globals.d.ts +16 -3
- package/dist/index.js +536 -498
- package/package.json +4 -1
package/dist/index.js
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
var
|
|
2
|
-
var
|
|
3
|
-
var
|
|
4
|
-
if (!
|
|
5
|
-
throw TypeError("Cannot " +
|
|
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
|
+
if (!I.has(C))
|
|
5
|
+
throw TypeError("Cannot " + i);
|
|
6
6
|
};
|
|
7
|
-
var
|
|
8
|
-
if (
|
|
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
|
+
if (I.has(C))
|
|
9
9
|
throw TypeError("Cannot add the same private member more than once");
|
|
10
|
-
|
|
11
|
-
},
|
|
12
|
-
var
|
|
13
|
-
import { jsx as
|
|
14
|
-
import { useRef as
|
|
15
|
-
const
|
|
10
|
+
I instanceof WeakSet ? I.add(C) : I.set(C, i);
|
|
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 Mg = {
|
|
|
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 Mg = {
|
|
|
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,
|
|
@@ -65,17 +66,17 @@ const Mg = {
|
|
|
65
66
|
glowColor: [0.6, 0.85, 1],
|
|
66
67
|
waterColor: [0, 0.02, 0.05]
|
|
67
68
|
},
|
|
68
|
-
|
|
69
|
-
densityDissipation: 0.
|
|
70
|
-
velocityDissipation: 0.
|
|
71
|
-
curl:
|
|
72
|
-
splatRadius: 0.
|
|
73
|
-
splatForce:
|
|
74
|
-
refraction: 0.
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
69
|
+
sand: {
|
|
70
|
+
densityDissipation: 0.997,
|
|
71
|
+
velocityDissipation: 0.98,
|
|
72
|
+
curl: 1,
|
|
73
|
+
splatRadius: 0.01,
|
|
74
|
+
splatForce: 0.9,
|
|
75
|
+
refraction: 0.8,
|
|
76
|
+
specularExp: 0.1,
|
|
77
|
+
shine: 0.05,
|
|
78
|
+
glowColor: [0.027, 0.027, 0.027],
|
|
79
|
+
waterColor: [0.451, 0.329, 0.125]
|
|
79
80
|
},
|
|
80
81
|
wave: {
|
|
81
82
|
densityDissipation: 0.994,
|
|
@@ -85,7 +86,6 @@ const Mg = {
|
|
|
85
86
|
splatForce: 1.2,
|
|
86
87
|
refraction: 0.35,
|
|
87
88
|
shine: 0.03,
|
|
88
|
-
pressureIterations: 5,
|
|
89
89
|
glowColor: [0.5, 0.8, 1],
|
|
90
90
|
waterColor: [0, 0.01, 0.03]
|
|
91
91
|
},
|
|
@@ -113,73 +113,73 @@ const Mg = {
|
|
|
113
113
|
waterColor: [0.06, 0.06, 0.06]
|
|
114
114
|
}
|
|
115
115
|
};
|
|
116
|
-
function
|
|
117
|
-
return { ...
|
|
116
|
+
function pI(C = {}, I, i = OI) {
|
|
117
|
+
return { ...I ? { ...i, ...ig[I] } : i, ...C };
|
|
118
118
|
}
|
|
119
|
-
function
|
|
120
|
-
let
|
|
121
|
-
|
|
122
|
-
const
|
|
123
|
-
return { x: (
|
|
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 };
|
|
124
124
|
}
|
|
125
|
-
function
|
|
126
|
-
const { text:
|
|
127
|
-
((
|
|
128
|
-
if (
|
|
129
|
-
|
|
130
|
-
const { x:
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
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,
|
|
133
|
+
I,
|
|
134
|
+
i,
|
|
135
|
+
o
|
|
136
136
|
);
|
|
137
|
-
|
|
137
|
+
d.drawImage(s, w, D, A, y);
|
|
138
138
|
} else
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
})(
|
|
142
|
-
const
|
|
143
|
-
|
|
144
|
-
const
|
|
145
|
-
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 };
|
|
146
146
|
}
|
|
147
|
-
function
|
|
148
|
-
const
|
|
149
|
-
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) {
|
|
150
150
|
const {
|
|
151
|
-
x:
|
|
152
|
-
y:
|
|
153
|
-
drawW:
|
|
154
|
-
drawH:
|
|
155
|
-
} =
|
|
156
|
-
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
const
|
|
160
|
-
|
|
161
|
-
const
|
|
162
|
-
|
|
163
|
-
Math.max(0,
|
|
164
|
-
Math.max(0,
|
|
165
|
-
Math.min(
|
|
166
|
-
Math.min(
|
|
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))
|
|
167
167
|
);
|
|
168
|
-
const
|
|
169
|
-
return { backgroundTex:
|
|
168
|
+
const F = BI(C, a);
|
|
169
|
+
return { backgroundTex: W, obstacleTex: x, coverageTex: F };
|
|
170
170
|
}
|
|
171
|
-
function
|
|
172
|
-
const
|
|
173
|
-
return
|
|
171
|
+
function BI(C, I) {
|
|
172
|
+
const i = C.createTexture();
|
|
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;
|
|
174
174
|
}
|
|
175
|
-
async function
|
|
176
|
-
const
|
|
177
|
-
if (!
|
|
178
|
-
throw new Error(`Failed to fetch image: ${
|
|
179
|
-
const
|
|
180
|
-
return createImageBitmap(
|
|
175
|
+
async function kI(C) {
|
|
176
|
+
const I = await fetch(C);
|
|
177
|
+
if (!I.ok)
|
|
178
|
+
throw new Error(`Failed to fetch image: ${C} (${I.status})`);
|
|
179
|
+
const i = await I.blob();
|
|
180
|
+
return createImageBitmap(i);
|
|
181
181
|
}
|
|
182
|
-
const
|
|
182
|
+
const II = (
|
|
183
183
|
/* glsl */
|
|
184
184
|
`
|
|
185
185
|
precision highp float;
|
|
@@ -196,7 +196,7 @@ const P = (
|
|
|
196
196
|
gl_Position = vec4(aPosition, 0.0, 1.0);
|
|
197
197
|
}
|
|
198
198
|
`
|
|
199
|
-
),
|
|
199
|
+
), sg = (
|
|
200
200
|
/* glsl */
|
|
201
201
|
`
|
|
202
202
|
precision highp float;
|
|
@@ -213,7 +213,7 @@ const P = (
|
|
|
213
213
|
gl_FragColor = dissipation * texture2D(uSource, coord);
|
|
214
214
|
}
|
|
215
215
|
`
|
|
216
|
-
),
|
|
216
|
+
), lg = (
|
|
217
217
|
/* glsl */
|
|
218
218
|
`
|
|
219
219
|
precision highp float;
|
|
@@ -228,7 +228,7 @@ const P = (
|
|
|
228
228
|
gl_FragColor = vec4(0.5 * (R - L + T - B), 0.0, 0.0, 1.0);
|
|
229
229
|
}
|
|
230
230
|
`
|
|
231
|
-
),
|
|
231
|
+
), og = (
|
|
232
232
|
/* glsl */
|
|
233
233
|
`
|
|
234
234
|
precision highp float;
|
|
@@ -246,7 +246,7 @@ const P = (
|
|
|
246
246
|
gl_FragColor = vec4((L + R + B + T - div) * 0.25, 0.0, 0.0, 1.0);
|
|
247
247
|
}
|
|
248
248
|
`
|
|
249
|
-
),
|
|
249
|
+
), tg = (
|
|
250
250
|
/* glsl */
|
|
251
251
|
`
|
|
252
252
|
precision highp float;
|
|
@@ -264,7 +264,7 @@ const P = (
|
|
|
264
264
|
gl_FragColor = vec4(vel, 0.0, 1.0);
|
|
265
265
|
}
|
|
266
266
|
`
|
|
267
|
-
),
|
|
267
|
+
), cg = (
|
|
268
268
|
/* glsl */
|
|
269
269
|
`
|
|
270
270
|
precision highp float;
|
|
@@ -281,7 +281,7 @@ const P = (
|
|
|
281
281
|
gl_FragColor = vec4(texture2D(uTarget, vUv).xyz + splat, 1.0);
|
|
282
282
|
}
|
|
283
283
|
`
|
|
284
|
-
),
|
|
284
|
+
), ag = (
|
|
285
285
|
/* glsl */
|
|
286
286
|
`
|
|
287
287
|
precision highp float;
|
|
@@ -295,7 +295,7 @@ const P = (
|
|
|
295
295
|
gl_FragColor = vec4(0.5 * (R - L - T + B), 0.0, 0.0, 1.0);
|
|
296
296
|
}
|
|
297
297
|
`
|
|
298
|
-
),
|
|
298
|
+
), dg = (
|
|
299
299
|
/* glsl */
|
|
300
300
|
`
|
|
301
301
|
precision highp float;
|
|
@@ -316,7 +316,7 @@ const P = (
|
|
|
316
316
|
gl_FragColor = vec4(texture2D(uVelocity, vUv).xy + force * dt, 0.0, 1.0);
|
|
317
317
|
}
|
|
318
318
|
`
|
|
319
|
-
),
|
|
319
|
+
), Ag = (
|
|
320
320
|
/* glsl */
|
|
321
321
|
`
|
|
322
322
|
precision highp float;
|
|
@@ -338,8 +338,9 @@ const P = (
|
|
|
338
338
|
uniform int uAlgorithm;
|
|
339
339
|
|
|
340
340
|
void main () {
|
|
341
|
-
float density = max(texture2D(uTexture, vUv).r, 0.0);
|
|
342
341
|
float obs = texture2D(uObstacle, vUv).r;
|
|
342
|
+
// Mask density inside obstacles so splats don't flicker the text/image content.
|
|
343
|
+
float density = max(texture2D(uTexture, vUv).r, 0.0) * (1.0 - step(0.5, obs));
|
|
343
344
|
float coverage = texture2D(uCoverage, vUv).r;
|
|
344
345
|
|
|
345
346
|
float dL = max(texture2D(uTexture, vUv - vec2(texelSize.x * 2.0, 0.0)).r, 0.0);
|
|
@@ -416,37 +417,37 @@ const P = (
|
|
|
416
417
|
}
|
|
417
418
|
`
|
|
418
419
|
);
|
|
419
|
-
function
|
|
420
|
-
const
|
|
421
|
-
let
|
|
422
|
-
const e = !!
|
|
423
|
-
e || (
|
|
424
|
-
const
|
|
425
|
-
return
|
|
426
|
-
gl:
|
|
420
|
+
function mg(C) {
|
|
421
|
+
const I = { alpha: !0, depth: !1, stencil: !1, antialias: !0, preserveDrawingBuffer: !1 };
|
|
422
|
+
let i = C.getContext("webgl2", I);
|
|
423
|
+
const e = !!i;
|
|
424
|
+
e || (i = C.getContext("webgl", I), i.getExtension("EXT_color_buffer_half_float"));
|
|
425
|
+
const s = e ? null : i.getExtension("OES_texture_half_float"), o = e ? i.HALF_FLOAT : s.HALF_FLOAT_OES;
|
|
426
|
+
return i.getExtension("EXT_color_buffer_float"), i.getExtension("OES_texture_half_float_linear"), {
|
|
427
|
+
gl: i,
|
|
427
428
|
isWebGL2: e,
|
|
428
429
|
ext: {
|
|
429
|
-
internalFormat: e ?
|
|
430
|
-
format:
|
|
431
|
-
type:
|
|
430
|
+
internalFormat: e ? i.RGBA16F : i.RGBA,
|
|
431
|
+
format: i.RGBA,
|
|
432
|
+
type: o
|
|
432
433
|
}
|
|
433
434
|
};
|
|
434
435
|
}
|
|
435
|
-
class
|
|
436
|
-
constructor(
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
this._gl =
|
|
441
|
-
const
|
|
442
|
-
for (let
|
|
443
|
-
const
|
|
444
|
-
this.uniforms[
|
|
436
|
+
class gI {
|
|
437
|
+
constructor(I, i, e) {
|
|
438
|
+
yI(this, "program");
|
|
439
|
+
yI(this, "uniforms", {});
|
|
440
|
+
yI(this, "_gl");
|
|
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);
|
|
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;
|
|
445
|
+
this.uniforms[t] = I.getUniformLocation(this.program, t);
|
|
445
446
|
}
|
|
446
447
|
}
|
|
447
|
-
_compile(
|
|
448
|
-
const e = this._gl,
|
|
449
|
-
return e.shaderSource(
|
|
448
|
+
_compile(I, i) {
|
|
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,112 +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
|
-
|
|
472
|
-
const
|
|
473
|
-
|
|
474
|
-
const
|
|
475
|
-
return
|
|
471
|
+
function KI(C, I, i, e) {
|
|
472
|
+
C.activeTexture(C.TEXTURE0);
|
|
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
|
-
|
|
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
|
-
const
|
|
496
|
-
return
|
|
497
|
-
|
|
495
|
+
function ng(C) {
|
|
496
|
+
const I = C.createBuffer();
|
|
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) {
|
|
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(
|
|
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
|
-
|
|
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);
|
|
545
549
|
}
|
|
546
550
|
// ---------------------------------------------------------------------------
|
|
547
551
|
// Public API
|
|
548
552
|
// ---------------------------------------------------------------------------
|
|
549
|
-
setTextSource(
|
|
550
|
-
|
|
553
|
+
setTextSource(I) {
|
|
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);
|
|
551
555
|
}
|
|
552
|
-
async setImageSource(
|
|
553
|
-
const
|
|
554
|
-
|
|
556
|
+
async setImageSource(I, i = 0, e = "cover") {
|
|
557
|
+
const s = await kI(I);
|
|
558
|
+
if (g(this, bI)) {
|
|
559
|
+
s.close();
|
|
560
|
+
return;
|
|
561
|
+
}
|
|
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);
|
|
555
563
|
}
|
|
556
|
-
setImageBitmap(
|
|
557
|
-
|
|
564
|
+
setImageBitmap(I, i = 0, e = "cover") {
|
|
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);
|
|
558
566
|
}
|
|
559
|
-
setBackground(
|
|
560
|
-
|
|
567
|
+
setBackground(I, i = "cover") {
|
|
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);
|
|
561
569
|
}
|
|
562
|
-
handleMove(
|
|
563
|
-
|
|
570
|
+
handleMove(I, i, e = 1) {
|
|
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;
|
|
564
572
|
}
|
|
565
573
|
/**
|
|
566
574
|
* Immediately applies one fluid splat at (x, y) with explicit velocity (vx, vy).
|
|
@@ -569,149 +577,157 @@ class Fg {
|
|
|
569
577
|
* where you want N independent injection points per frame without flooding the
|
|
570
578
|
* mouse-state machine or the worker message queue.
|
|
571
579
|
*/
|
|
572
|
-
splat(
|
|
573
|
-
if (!
|
|
580
|
+
splat(I, i, e, s, o = 1) {
|
|
581
|
+
if (!g(this, cI) || g(this, K) === 0)
|
|
574
582
|
return;
|
|
575
|
-
const
|
|
576
|
-
|
|
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)));
|
|
577
588
|
}
|
|
578
|
-
resize(
|
|
579
|
-
if (e !== void 0 ?
|
|
580
|
-
if (
|
|
589
|
+
resize(I, i, e) {
|
|
590
|
+
if (e !== void 0 ? l(this, k, e) : typeof window < "u" && window.devicePixelRatio && l(this, k, window.devicePixelRatio), I !== void 0 && I > 0) {
|
|
591
|
+
if (i === void 0 || i <= 0)
|
|
581
592
|
return;
|
|
582
|
-
|
|
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);
|
|
583
594
|
} else
|
|
584
|
-
|
|
585
|
-
|
|
595
|
+
b(this, aI, GI).call(this);
|
|
596
|
+
g(this, Y) && b(this, sI, AI).call(this), b(this, dI, hI).call(this);
|
|
586
597
|
}
|
|
587
|
-
updateConfig(
|
|
588
|
-
Object.assign(
|
|
598
|
+
updateConfig(I) {
|
|
599
|
+
Object.assign(g(this, tI), I);
|
|
589
600
|
}
|
|
590
601
|
destroy() {
|
|
591
|
-
this.stop();
|
|
592
|
-
const
|
|
593
|
-
|
|
594
|
-
for (const e of Object.values(
|
|
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)))
|
|
595
606
|
e.dispose();
|
|
596
|
-
const
|
|
597
|
-
|
|
607
|
+
const i = I.getExtension("WEBGL_lose_context");
|
|
608
|
+
i == null || i.loseContext();
|
|
598
609
|
}
|
|
599
610
|
// ---------------------------------------------------------------------------
|
|
600
611
|
// Loop control
|
|
601
612
|
// ---------------------------------------------------------------------------
|
|
602
613
|
start() {
|
|
603
|
-
if (
|
|
614
|
+
if (g(this, Q) !== null)
|
|
604
615
|
return;
|
|
605
|
-
const
|
|
606
|
-
|
|
616
|
+
const I = () => {
|
|
617
|
+
b(this, RI, jI).call(this), l(this, Q, xI(I));
|
|
607
618
|
};
|
|
608
|
-
|
|
619
|
+
l(this, Q, xI(I));
|
|
609
620
|
}
|
|
610
621
|
stop() {
|
|
611
|
-
|
|
622
|
+
g(this, Q) !== null && (ug(g(this, Q)), l(this, Q, null));
|
|
612
623
|
}
|
|
613
624
|
get isRunning() {
|
|
614
|
-
return
|
|
625
|
+
return g(this, Q) !== null;
|
|
615
626
|
}
|
|
616
627
|
}
|
|
617
|
-
|
|
618
|
-
const
|
|
619
|
-
"clientWidth" in
|
|
620
|
-
},
|
|
621
|
-
const
|
|
622
|
-
|
|
623
|
-
},
|
|
624
|
-
if (!(!
|
|
625
|
-
if (
|
|
626
|
-
const { backgroundTex:
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
|
|
631
|
-
|
|
632
|
-
|
|
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),
|
|
640
|
+
g(this, R),
|
|
641
|
+
g(this, Y).opts,
|
|
642
|
+
g(this, f),
|
|
643
|
+
g(this, uI)
|
|
633
644
|
);
|
|
634
|
-
|
|
645
|
+
l(this, _, I), l(this, v, i), l(this, z, e);
|
|
635
646
|
} else {
|
|
636
|
-
const { backgroundTex:
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
647
|
+
const { backgroundTex: I, obstacleTex: i, coverageTex: e } = eg(
|
|
648
|
+
g(this, X),
|
|
649
|
+
g(this, Y).bitmap,
|
|
650
|
+
g(this, K),
|
|
651
|
+
g(this, R),
|
|
652
|
+
g(this, Y).effect,
|
|
653
|
+
g(this, Y).size,
|
|
654
|
+
g(this, f),
|
|
655
|
+
g(this, uI)
|
|
645
656
|
);
|
|
646
|
-
|
|
657
|
+
l(this, _, I), l(this, v, i), l(this, z, e);
|
|
647
658
|
}
|
|
648
|
-
|
|
649
|
-
}
|
|
650
|
-
},
|
|
651
|
-
|
|
652
|
-
},
|
|
653
|
-
var
|
|
654
|
-
(
|
|
655
|
-
},
|
|
656
|
-
|
|
657
|
-
},
|
|
658
|
-
if (!
|
|
659
|
+
l(this, cI, !0);
|
|
660
|
+
}
|
|
661
|
+
}, dI = new WeakSet(), hI = function() {
|
|
662
|
+
g(this, cI) && !this.isRunning && this.start();
|
|
663
|
+
}, VI = new WeakSet(), FI = function() {
|
|
664
|
+
var I, i, e;
|
|
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))
|
|
659
670
|
return;
|
|
660
|
-
const
|
|
661
|
-
|
|
662
|
-
const
|
|
663
|
-
|
|
664
|
-
for (let
|
|
665
|
-
|
|
666
|
-
|
|
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);
|
|
667
678
|
};
|
|
668
|
-
const Og = "var Re = Object.defineProperty;
var ye = (i, e, r) => e in i ? Re(i, e, { enumerable: !0, configurable: !0, writable: !0, value: r }) : i[e] = r;
var oe = (i, e, r) => (ye(i, typeof e != "symbol" ? e + "" : e, r), r), ve = (i, e, r) => {
  if (!e.has(i))
    throw TypeError("Cannot " + r);
};
var t = (i, e, r) => (ve(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) => (ve(i, e, "write to private field"), o ? o.call(i, r) : e.set(i, r), r);
var d = (i, e, r) => (ve(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 De = {
  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]
  },
  storm: {
    densityDissipation: 0.97,
    velocityDissipation: 0.88,
    curl: 0.45,
    splatRadius: 0.012,
    splatForce: 3,
    refraction: 0.6,
    shine: 0.08,
    glowColor: [0.2, 0.3, 0.8],
    waterColor: [0, 0, 0.1],
    pressureIterations: 150
  },
  wave: {
    densityDissipation: 0.994,
    velocityDissipation: 0.92,
    curl: 0.2,
    splatRadius: 5e-3,
    splatForce: 1.2,
    refraction: 0.35,
    shine: 0.03,
    pressureIterations: 5,
    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 Ue(i = {}, e, r = ge) {
  return { ...e ? { ...r, ...De[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);
  }
`
), _e = (
  /* 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);
  }
`
), we = (
  /* 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);
  }
`
), Ce = (
  /* 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);
  }
`
), 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 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);
  }
`
), Fe = (
  /* 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);
  }
`
), Xe = (
  /* 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);
  }
`
), Be = (
  /* 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);
  }
`
), Ae = (
  /* 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 density  = max(texture2D(uTexture,   vUv).r, 0.0);
    float obs      = texture2D(uObstacle,  vUv).r;
    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 Le(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) {
    oe(this, "program");
    oe(this, "uniforms", {});
    oe(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 Pe(i) {
  return {
    advection: new O(i, P, _e),
    divergence: new O(i, P, we),
    pressure: new O(i, P, Ce),
    gradientSubtract: new O(i, P, Se),
    splat: new O(i, P, Fe),
    curl: new O(i, P, Xe),
    vorticity: new O(i, P, Be),
    display: new O(i, P, Ae)
  };
}
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 he(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 Oe(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 me(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 ke(i, e, r, o, s = null, n = "cover") {
  const { text: u, fontSize: T, color: E, fontFamily: c = "sans-serif", fontWeight: h = 900 } = o, b = new OffscreenCanvas(e, r), f = b.getContext("2d");
  ((ie) => {
    if (s) {
      f.clearRect(0, 0, e, r), f.fillStyle = "black", f.fillRect(0, 0, e, r);
      const { x: ue, y: le, drawW: ce, drawH: fe } = me(
        s.width,
        s.height,
        e,
        r,
        n
      );
      f.drawImage(s, ue, le, ce, fe);
    } else
      f.fillStyle = "black", f.fillRect(0, 0, e, r);
    f.shadowColor = ie, f.fillStyle = ie, f.font = `${h} ${T}px ${c}`, f.textAlign = "center", f.textBaseline = "middle", f.fillText(u, e / 2, r / 2);
  })(E);
  const $ = J(i, b);
  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 re = J(i, b);
  return { backgroundTex: $, obstacleTex: re, coverageTex: re };
}
function Ie(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: b, drawW: f, drawH: D } = me(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: ue,
      y: le,
      drawW: ce,
      drawH: fe
    } = me(u.width, u.height, r, o, T);
    c.filter = `brightness(${s}) blur(8px)`, c.drawImage(u, ue, le, ce, fe), c.filter = "none";
  }
  c.drawImage(e, h, b, f, D);
  const $ = J(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, b, f, D), c.filter = "none";
  const re = J(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, b),
    Math.min(f, r - Math.max(0, h)),
    Math.min(D, o - Math.max(0, b))
  );
  const ie = J(i, E);
  return { backgroundTex: $, obstacleTex: re, coverageTex: ie };
}
function J(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 Me(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 pe = typeof requestAnimationFrame < "u" ? requestAnimationFrame.bind(globalThis) : (i) => setTimeout(i, 1e3 / 60), Ve = typeof cancelAnimationFrame < "u" ? cancelAnimationFrame.bind(globalThis) : clearTimeout, Ee = 0.016, We = { standard: 0, glass: 1, ink: 2, aurora: 3, ripple: 4 };
var V, g, Q, W, q, p, R, k, I, w, y, v, S, F, X, L, U, B, C, H, G, x, _, A, z, N, K, Z, xe, M, Y, j, se, ee, Te, te, de, ne, be;
class Ge {
  constructor(e, r = {}) {
    // ---------------------------------------------------------------------------
    // Private helpers
    // ---------------------------------------------------------------------------
    l(this, N);
    l(this, Z);
    l(this, M);
    l(this, j);
    l(this, ee);
    l(this, te);
    l(this, ne);
    l(this, V, void 0);
    l(this, g, void 0);
    l(this, Q, void 0);
    l(this, W, void 0);
    l(this, q, void 0);
    l(this, p, 0);
    l(this, R, 0);
    l(this, k, 0);
    l(this, I, 0);
    l(this, w, 1);
    l(this, y, 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, H, "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);
    a(this, V, e), a(this, G, Ue(r));
    const { gl: o, ext: s } = Le(e);
    a(this, g, o), a(this, Q, s), a(this, W, Pe(o)), a(this, q, Oe(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, Y).call(this), d(this, j, se).call(this);
  }
  async setImageSource(e, r = 0, o = "cover") {
    const s = await Me(e);
    a(this, _, { type: "image", bitmap: s, effect: r, size: o }), d(this, N, K).call(this), d(this, M, Y).call(this), d(this, j, se).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, Y).call(this), d(this, j, se).call(this);
  }
  setBackground(e, r = "cover") {
    t(this, C) && t(this, C) !== e && t(this, C).close(), a(this, C, e), a(this, H, r ?? "cover"), t(this, _) && t(this, p) > 0 && d(this, M, Y).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, g), T = t(this, G), { splat: E } = t(this, W), c = t(this, q);
    u.viewport(0, 0, t(this, k), t(this, I)), E.bind(), u.uniform1f(E.uniforms.aspectRatio, t(this, p) / t(this, R)), u.uniform2f(E.uniforms.point, e * t(this, w) / t(this, p), 1 - r * t(this, w) / t(this, R)), 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, y).read.tex), u.uniform3f(E.uniforms.color, n, n, n), c(t(this, y).write.fbo), t(this, y).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, R, t(this, V).height = r), a(this, k, e >> 1), a(this, I, r >> 1), d(this, Z, xe).call(this);
    } else
      d(this, N, K).call(this);
    t(this, _) && d(this, M, Y).call(this);
  }
  updateConfig(e) {
    Object.assign(t(this, G), e);
  }
  destroy() {
    this.stop();
    const e = t(this, g);
    d(this, ee, Te).call(this), d(this, te, de).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, be).call(this), a(this, A, pe(e));
    };
    a(this, A, pe(e));
  }
  stop() {
    t(this, A) !== null && (Ve(t(this, A)), a(this, A, null));
  }
  get isRunning() {
    return t(this, A) !== null;
  }
}
V = new WeakMap(), g = new WeakMap(), Q = new WeakMap(), W = new WeakMap(), q = new WeakMap(), p = new WeakMap(), R = new WeakMap(), k = new WeakMap(), I = new WeakMap(), w = new WeakMap(), y = 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(), H = new WeakMap(), G = new WeakMap(), x = new WeakMap(), _ = new WeakMap(), A = new WeakMap(), z = 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, R, e.height = Math.round(e.clientHeight * t(this, w)))) : (a(this, p, e.width), a(this, R, e.height)), !(t(this, p) === 0 || t(this, R) === 0) && (a(this, k, t(this, p) >> 1), a(this, I, t(this, R) >> 1), d(this, Z, xe).call(this));
}, Z = new WeakSet(), xe = function() {
  const e = t(this, g), r = t(this, Q), o = t(this, k), s = t(this, I);
  d(this, ee, Te).call(this), a(this, y, he(e, r, o, s)), a(this, v, he(e, r, o, s)), a(this, F, he(e, r, o, s)), a(this, S, ae(e, r, o, s)), a(this, X, ae(e, r, o, s));
}, M = new WeakSet(), Y = function() {
  if (!(!t(this, _) || t(this, p) === 0)) {
    if (d(this, te, de).call(this), t(this, _).type === "text") {
      const { backgroundTex: e, obstacleTex: r, coverageTex: o } = ke(
        t(this, g),
        t(this, p),
        t(this, R),
        t(this, _).opts,
        t(this, C),
        t(this, H)
      );
      a(this, L, e), a(this, U, r), a(this, B, o);
    } else {
      const { backgroundTex: e, obstacleTex: r, coverageTex: o } = Ie(
        t(this, g),
        t(this, _).bitmap,
        t(this, p),
        t(this, R),
        t(this, _).effect,
        t(this, _).size,
        t(this, C),
        t(this, H)
      );
      a(this, L, e), a(this, U, r), a(this, B, o);
    }
    a(this, z, !0);
  }
}, j = new WeakSet(), se = function() {
  t(this, z) && !this.isRunning && this.start();
}, ee = new WeakSet(), Te = function() {
  var e, r, o;
  (e = t(this, y)) == null || e.dispose(), (r = t(this, v)) == null || r.dispose(), (o = t(this, F)) == null || o.dispose(), t(this, S) && (t(this, g).deleteTexture(t(this, S).tex), t(this, g).deleteFramebuffer(t(this, S).fbo)), t(this, X) && (t(this, g).deleteTexture(t(this, X).tex), t(this, g).deleteFramebuffer(t(this, X).fbo)), a(this, y, a(this, v, a(this, F, a(this, S, a(this, X, null)))));
}, te = new WeakSet(), de = function() {
  t(this, L) && t(this, g).deleteTexture(t(this, L)), 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, L, a(this, U, a(this, B, null)));
}, ne = new WeakSet(), be = function() {
  if (!t(this, z) || t(this, p) === 0)
    return;
  const e = t(this, g), 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 b = t(this, k), f = t(this, I), D = t(this, q);
  e.viewport(0, 0, b, f), o.bind(), e.uniform2f(o.uniforms.texelSize, 1 / b, 1 / f), e.uniform1f(o.uniforms.dt, Ee), 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, y).read.tex), D(t(this, y).write.fbo), t(this, y).swap(), E.bind(), e.uniform2f(E.uniforms.texelSize, 1 / b, 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 / b, 1 / f), e.uniform1f(c.uniforms.curl, r.curl), e.uniform1f(c.uniforms.dt, Ee), 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, R)), 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, R)), 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, y).read.tex), e.uniform3f(T.uniforms.color, 1, 1, 1), D(t(this, y).write.fbo), t(this, y).swap(), t(this, x).moved = !1), s.bind(), e.uniform2f(s.uniforms.texelSize, 1 / b, 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 / b, 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 $ = 0; $ < r.pressureIterations; $++)
    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 / b, 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, R)), 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, R)), 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, We[r.algorithm] ?? 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, y).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 Ge(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) });
  }
};
", fg = typeof window < "u" && window.Blob && new Blob([atob(Og)], { type: "text/javascript;charset=utf-8" });
|
|
669
|
-
function
|
|
670
|
-
let
|
|
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() {
|
|
681
|
+
let C;
|
|
671
682
|
try {
|
|
672
|
-
if (
|
|
683
|
+
if (C = JI && (window.URL || window.webkitURL).createObjectURL(JI), !C)
|
|
673
684
|
throw "";
|
|
674
|
-
return new Worker(
|
|
685
|
+
return new Worker(C);
|
|
675
686
|
} catch {
|
|
676
|
-
return new Worker("data:application/javascript;base64," +
|
|
687
|
+
return new Worker("data:application/javascript;base64," + PI, { type: "module" });
|
|
677
688
|
} finally {
|
|
678
|
-
|
|
689
|
+
C && (window.URL || window.webkitURL).revokeObjectURL(C);
|
|
679
690
|
}
|
|
680
691
|
}
|
|
681
|
-
const
|
|
682
|
-
var
|
|
683
|
-
class
|
|
684
|
-
constructor(
|
|
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
|
+
} = {}) {
|
|
685
700
|
// ---------------------------------------------------------------------------
|
|
686
701
|
// Private
|
|
687
702
|
// ---------------------------------------------------------------------------
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
|
|
691
|
-
|
|
692
|
-
|
|
693
|
-
|
|
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) }));
|
|
694
710
|
}
|
|
695
711
|
// ---------------------------------------------------------------------------
|
|
696
712
|
// Source setters
|
|
697
713
|
// ---------------------------------------------------------------------------
|
|
698
|
-
setTextSource(
|
|
699
|
-
|
|
714
|
+
setTextSource(I) {
|
|
715
|
+
g(this, p) ? g(this, p).postMessage({ type: "setTextSource", opts: I }) : g(this, U).setTextSource(I);
|
|
700
716
|
}
|
|
701
|
-
setImageSource(
|
|
702
|
-
if (
|
|
703
|
-
const
|
|
704
|
-
|
|
717
|
+
setImageSource(I, i = iI.effect, e = iI.imageSize) {
|
|
718
|
+
if (g(this, p)) {
|
|
719
|
+
const s = new URL(I, location.href).href;
|
|
720
|
+
g(this, p).postMessage({ type: "setImageSource", src: s, effect: i, size: e });
|
|
705
721
|
} else
|
|
706
|
-
|
|
722
|
+
g(this, U).setImageSource(I, i, e);
|
|
707
723
|
}
|
|
708
|
-
setBackground(
|
|
724
|
+
setBackground(I, i = "cover") {
|
|
709
725
|
var e;
|
|
710
|
-
if (
|
|
711
|
-
const
|
|
712
|
-
|
|
726
|
+
if (g(this, p)) {
|
|
727
|
+
const s = I ? [I] : [];
|
|
728
|
+
g(this, p).postMessage({ type: "setBackground", bitmap: I ?? null, size: i }, s);
|
|
713
729
|
} else
|
|
714
|
-
(e =
|
|
730
|
+
(e = g(this, U)) == null || e.setBackground(I ?? null, i);
|
|
715
731
|
}
|
|
716
732
|
// ---------------------------------------------------------------------------
|
|
717
733
|
// Interaction
|
|
@@ -720,293 +736,315 @@ class rI {
|
|
|
720
736
|
* Immediately injects one splat at (x, y) with explicit velocity (vx, vy).
|
|
721
737
|
* Safe to call multiple times per frame. See FluidSimulation.splat for details.
|
|
722
738
|
*/
|
|
723
|
-
splat(
|
|
724
|
-
|
|
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);
|
|
725
741
|
}
|
|
726
|
-
handleMove(
|
|
727
|
-
|
|
742
|
+
handleMove(I, i, e = 1) {
|
|
743
|
+
g(this, p) ? g(this, p).postMessage({ type: "move", x: I, y: i, strength: e }) : g(this, U).handleMove(I, i, e);
|
|
728
744
|
}
|
|
729
745
|
// ---------------------------------------------------------------------------
|
|
730
746
|
// Config + control
|
|
731
747
|
// ---------------------------------------------------------------------------
|
|
732
|
-
|
|
733
|
-
I(this,
|
|
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);
|
|
734
750
|
}
|
|
735
|
-
|
|
736
|
-
|
|
737
|
-
|
|
738
|
-
|
|
739
|
-
|
|
740
|
-
|
|
751
|
+
updateConfig(I) {
|
|
752
|
+
g(this, p) ? g(this, p).postMessage({ type: "updateConfig", config: I }) : g(this, U).updateConfig(I);
|
|
753
|
+
}
|
|
754
|
+
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);
|
|
741
757
|
}
|
|
742
758
|
destroy() {
|
|
743
|
-
var
|
|
744
|
-
if (
|
|
745
|
-
const
|
|
746
|
-
|
|
759
|
+
var I;
|
|
760
|
+
if (g(this, p)) {
|
|
761
|
+
const i = g(this, p);
|
|
762
|
+
l(this, p, null), i.postMessage({ type: "destroy" }), setTimeout(() => i.terminate(), 50);
|
|
747
763
|
} else
|
|
748
|
-
(
|
|
764
|
+
(I = g(this, U)) == null || I.destroy(), l(this, U, null);
|
|
749
765
|
}
|
|
750
766
|
}
|
|
751
|
-
|
|
752
|
-
const e = typeof window < "u" && window.devicePixelRatio || 1,
|
|
753
|
-
|
|
754
|
-
let
|
|
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;
|
|
770
|
+
let t;
|
|
755
771
|
try {
|
|
756
|
-
|
|
772
|
+
t = I.transferControlToOffscreen();
|
|
757
773
|
} catch {
|
|
758
774
|
console.warn(
|
|
759
775
|
"[fluidity-js] OffscreenCanvas transfer failed — falling back to main-thread mode. This is expected in React StrictMode development."
|
|
760
|
-
),
|
|
776
|
+
), l(this, ZI, !1), l(this, U, new EI(I, i, { dpr: g(this, T), sim: g(this, O) }));
|
|
761
777
|
return;
|
|
762
778
|
}
|
|
763
|
-
const
|
|
764
|
-
|
|
765
|
-
console.error("[fluidity-js] Worker error:",
|
|
766
|
-
},
|
|
767
|
-
|
|
768
|
-
},
|
|
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
|
+
);
|
|
769
788
|
};
|
|
770
|
-
function
|
|
771
|
-
const
|
|
772
|
-
|
|
773
|
-
|
|
774
|
-
|
|
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)
|
|
775
797
|
return;
|
|
776
|
-
const
|
|
777
|
-
|
|
778
|
-
const n = window.devicePixelRatio || 1,
|
|
779
|
-
|
|
780
|
-
|
|
781
|
-
|
|
782
|
-
const
|
|
783
|
-
|
|
784
|
-
|
|
785
|
-
|
|
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));
|
|
786
810
|
}
|
|
787
811
|
});
|
|
788
|
-
return
|
|
789
|
-
|
|
812
|
+
return D.observe(a), () => {
|
|
813
|
+
D.disconnect(), w.destroy(), c.remove(), s.current = null;
|
|
790
814
|
};
|
|
791
|
-
}, []),
|
|
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;
|
|
792
826
|
}
|
|
793
|
-
const
|
|
794
|
-
text:
|
|
795
|
-
fontSize:
|
|
796
|
-
color: e =
|
|
797
|
-
fontFamily:
|
|
798
|
-
fontWeight:
|
|
799
|
-
className:
|
|
800
|
-
style:
|
|
801
|
-
config:
|
|
802
|
-
preset:
|
|
803
|
-
algorithm:
|
|
804
|
-
backgroundColor:
|
|
805
|
-
backgroundSrc:
|
|
806
|
-
backgroundSize:
|
|
807
|
-
isMouseEnabled:
|
|
808
|
-
isWorkerEnabled:
|
|
827
|
+
const Lg = zI(function({
|
|
828
|
+
text: I,
|
|
829
|
+
fontSize: i = $.fontSize,
|
|
830
|
+
color: e = $.color,
|
|
831
|
+
fontFamily: s = $.fontFamily,
|
|
832
|
+
fontWeight: o = $.fontWeight,
|
|
833
|
+
className: t,
|
|
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
|
|
809
844
|
}, w) {
|
|
810
|
-
const
|
|
811
|
-
isWorkerEnabled:
|
|
812
|
-
|
|
845
|
+
const D = mI(null), A = qI(D, {
|
|
846
|
+
isWorkerEnabled: x,
|
|
847
|
+
quality: F,
|
|
848
|
+
config: pI({ ...a, ...n ? { algorithm: n } : {} }, c, TI)
|
|
813
849
|
});
|
|
814
|
-
|
|
850
|
+
QI(
|
|
815
851
|
w,
|
|
816
852
|
() => ({
|
|
817
853
|
reset() {
|
|
818
|
-
var
|
|
819
|
-
(
|
|
854
|
+
var r;
|
|
855
|
+
(r = A.current) == null || r.setTextSource({ text: I, fontSize: i, color: e, fontFamily: s, fontWeight: o });
|
|
820
856
|
},
|
|
821
|
-
move(
|
|
857
|
+
move(r, Z, V = 1) {
|
|
822
858
|
var S;
|
|
823
|
-
(S =
|
|
859
|
+
(S = A.current) == null || S.handleMove(r, Z, V);
|
|
824
860
|
},
|
|
825
|
-
splat(
|
|
826
|
-
var
|
|
827
|
-
(
|
|
861
|
+
splat(r, Z, V, S, M = 1) {
|
|
862
|
+
var q;
|
|
863
|
+
(q = A.current) == null || q.splat(r, Z, V, S, M);
|
|
828
864
|
},
|
|
829
|
-
updateConfig(
|
|
830
|
-
var
|
|
831
|
-
(
|
|
865
|
+
updateConfig(r) {
|
|
866
|
+
var Z;
|
|
867
|
+
(Z = A.current) == null || Z.updateConfig(r);
|
|
832
868
|
}
|
|
833
869
|
}),
|
|
834
|
-
[
|
|
835
|
-
),
|
|
836
|
-
var
|
|
837
|
-
(
|
|
838
|
-
}, [
|
|
839
|
-
const
|
|
840
|
-
return
|
|
841
|
-
var
|
|
842
|
-
(
|
|
843
|
-
|
|
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)
|
|
844
880
|
);
|
|
845
|
-
}, [
|
|
846
|
-
var
|
|
847
|
-
if (!
|
|
848
|
-
(
|
|
881
|
+
}, [c, n, y]), j(() => {
|
|
882
|
+
var Z;
|
|
883
|
+
if (!d) {
|
|
884
|
+
(Z = A.current) == null || Z.setBackground(null);
|
|
849
885
|
return;
|
|
850
886
|
}
|
|
851
|
-
let
|
|
852
|
-
return
|
|
887
|
+
let r = !1;
|
|
888
|
+
return kI(d).then((V) => {
|
|
853
889
|
var S;
|
|
854
|
-
if (
|
|
855
|
-
|
|
890
|
+
if (r) {
|
|
891
|
+
V.close();
|
|
856
892
|
return;
|
|
857
893
|
}
|
|
858
|
-
(S =
|
|
859
|
-
}).catch((
|
|
860
|
-
|
|
894
|
+
(S = A.current) == null || S.setBackground(V, h);
|
|
895
|
+
}).catch((V) => console.error("[fluidity-js] backgroundSrc load failed:", V)), () => {
|
|
896
|
+
r = !0;
|
|
861
897
|
};
|
|
862
|
-
}, [
|
|
863
|
-
if (!
|
|
898
|
+
}, [d, h]), j(() => {
|
|
899
|
+
if (!W)
|
|
864
900
|
return;
|
|
865
|
-
const
|
|
866
|
-
if (!
|
|
901
|
+
const r = D.current;
|
|
902
|
+
if (!r)
|
|
867
903
|
return;
|
|
868
|
-
const
|
|
869
|
-
var
|
|
870
|
-
const
|
|
871
|
-
(
|
|
872
|
-
},
|
|
873
|
-
var
|
|
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;
|
|
874
910
|
S.preventDefault();
|
|
875
|
-
const
|
|
876
|
-
(
|
|
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);
|
|
877
913
|
};
|
|
878
|
-
return
|
|
879
|
-
|
|
914
|
+
return r.addEventListener("mousemove", Z), r.addEventListener("touchmove", V, { passive: !1 }), () => {
|
|
915
|
+
r.removeEventListener("mousemove", Z), r.removeEventListener("touchmove", V);
|
|
880
916
|
};
|
|
881
|
-
}, [
|
|
917
|
+
}, [W]), /* @__PURE__ */ NI(
|
|
882
918
|
"div",
|
|
883
919
|
{
|
|
884
|
-
ref:
|
|
885
|
-
className:
|
|
920
|
+
ref: D,
|
|
921
|
+
className: t,
|
|
886
922
|
style: {
|
|
887
923
|
position: "relative",
|
|
888
924
|
display: "block",
|
|
889
925
|
width: "100%",
|
|
890
926
|
height: "100%",
|
|
891
|
-
background:
|
|
892
|
-
...
|
|
927
|
+
background: G,
|
|
928
|
+
...u
|
|
893
929
|
}
|
|
894
930
|
}
|
|
895
931
|
);
|
|
896
|
-
}),
|
|
897
|
-
src:
|
|
898
|
-
effect:
|
|
899
|
-
imageSize: e =
|
|
900
|
-
className:
|
|
901
|
-
style:
|
|
902
|
-
config:
|
|
903
|
-
preset:
|
|
904
|
-
algorithm:
|
|
905
|
-
backgroundColor:
|
|
906
|
-
backgroundSrc:
|
|
907
|
-
backgroundSize:
|
|
908
|
-
isMouseEnabled:
|
|
909
|
-
isWorkerEnabled:
|
|
910
|
-
|
|
911
|
-
|
|
912
|
-
|
|
913
|
-
|
|
932
|
+
}), Vg = zI(function({
|
|
933
|
+
src: I,
|
|
934
|
+
effect: i = iI.effect,
|
|
935
|
+
imageSize: e = iI.imageSize,
|
|
936
|
+
className: s,
|
|
937
|
+
style: o,
|
|
938
|
+
config: t,
|
|
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, {
|
|
949
|
+
isWorkerEnabled: h,
|
|
950
|
+
quality: W,
|
|
951
|
+
config: pI({ ...t, ...a ? { algorithm: a } : {} }, u)
|
|
914
952
|
});
|
|
915
|
-
|
|
916
|
-
|
|
953
|
+
QI(
|
|
954
|
+
x,
|
|
917
955
|
() => ({
|
|
918
956
|
reset() {
|
|
919
|
-
var
|
|
920
|
-
|
|
957
|
+
var A;
|
|
958
|
+
I && ((A = w.current) == null || A.setImageSource(I, i, e));
|
|
921
959
|
},
|
|
922
|
-
move(
|
|
923
|
-
var
|
|
924
|
-
(
|
|
960
|
+
move(A, y, r = 1) {
|
|
961
|
+
var Z;
|
|
962
|
+
(Z = w.current) == null || Z.handleMove(A, y, r);
|
|
925
963
|
},
|
|
926
|
-
splat(
|
|
964
|
+
splat(A, y, r, Z, V = 1) {
|
|
927
965
|
var S;
|
|
928
|
-
(S = w.current) == null || S.splat(
|
|
966
|
+
(S = w.current) == null || S.splat(A, y, r, Z, V);
|
|
929
967
|
},
|
|
930
|
-
updateConfig(
|
|
931
|
-
var
|
|
932
|
-
(
|
|
968
|
+
updateConfig(A) {
|
|
969
|
+
var y;
|
|
970
|
+
(y = w.current) == null || y.updateConfig(A);
|
|
933
971
|
}
|
|
934
972
|
}),
|
|
935
|
-
[
|
|
936
|
-
),
|
|
937
|
-
var
|
|
938
|
-
|
|
939
|
-
}, [
|
|
940
|
-
const
|
|
941
|
-
return
|
|
942
|
-
var
|
|
943
|
-
(
|
|
944
|
-
|
|
973
|
+
[I, i, e]
|
|
974
|
+
), j(() => {
|
|
975
|
+
var A;
|
|
976
|
+
I && ((A = w.current) == null || A.setImageSource(I, i, e));
|
|
977
|
+
}, [I, i, e]);
|
|
978
|
+
const D = JSON.stringify(t);
|
|
979
|
+
return j(() => {
|
|
980
|
+
var A;
|
|
981
|
+
(A = w.current) == null || A.updateConfig(
|
|
982
|
+
pI({ ...t, ...a !== void 0 ? { algorithm: a } : {} }, u)
|
|
945
983
|
);
|
|
946
|
-
}, [
|
|
947
|
-
var
|
|
948
|
-
if (!
|
|
949
|
-
(
|
|
984
|
+
}, [u, a, D]), j(() => {
|
|
985
|
+
var y;
|
|
986
|
+
if (!n) {
|
|
987
|
+
(y = w.current) == null || y.setBackground(null);
|
|
950
988
|
return;
|
|
951
989
|
}
|
|
952
|
-
let
|
|
953
|
-
return
|
|
954
|
-
var
|
|
955
|
-
if (
|
|
956
|
-
|
|
990
|
+
let A = !1;
|
|
991
|
+
return kI(n).then((r) => {
|
|
992
|
+
var Z;
|
|
993
|
+
if (A) {
|
|
994
|
+
r.close();
|
|
957
995
|
return;
|
|
958
996
|
}
|
|
959
|
-
(
|
|
960
|
-
}).catch((
|
|
961
|
-
|
|
997
|
+
(Z = w.current) == null || Z.setBackground(r, G);
|
|
998
|
+
}).catch((r) => console.error("[fluidity-js] backgroundSrc load failed:", r)), () => {
|
|
999
|
+
A = !0;
|
|
962
1000
|
};
|
|
963
|
-
}, [
|
|
964
|
-
if (!
|
|
1001
|
+
}, [n, G]), j(() => {
|
|
1002
|
+
if (!d)
|
|
965
1003
|
return;
|
|
966
|
-
const
|
|
967
|
-
if (!
|
|
1004
|
+
const A = F.current;
|
|
1005
|
+
if (!A)
|
|
968
1006
|
return;
|
|
969
|
-
const
|
|
1007
|
+
const y = (Z) => {
|
|
970
1008
|
var S;
|
|
971
|
-
const
|
|
972
|
-
(S = w.current) == null || S.handleMove(
|
|
973
|
-
},
|
|
974
|
-
var
|
|
975
|
-
|
|
976
|
-
const
|
|
977
|
-
(
|
|
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);
|
|
978
1016
|
};
|
|
979
|
-
return
|
|
980
|
-
|
|
1017
|
+
return A.addEventListener("mousemove", y), A.addEventListener("touchmove", r, { passive: !1 }), () => {
|
|
1018
|
+
A.removeEventListener("mousemove", y), A.removeEventListener("touchmove", r);
|
|
981
1019
|
};
|
|
982
|
-
}, [
|
|
1020
|
+
}, [d]), /* @__PURE__ */ NI(
|
|
983
1021
|
"div",
|
|
984
1022
|
{
|
|
985
|
-
ref:
|
|
986
|
-
className:
|
|
1023
|
+
ref: F,
|
|
1024
|
+
className: s,
|
|
987
1025
|
style: {
|
|
988
1026
|
position: "relative",
|
|
989
1027
|
display: "block",
|
|
990
1028
|
width: "100%",
|
|
991
1029
|
height: "100%",
|
|
992
|
-
background:
|
|
993
|
-
...
|
|
1030
|
+
background: c,
|
|
1031
|
+
...o
|
|
994
1032
|
}
|
|
995
1033
|
}
|
|
996
1034
|
);
|
|
997
1035
|
});
|
|
998
1036
|
export {
|
|
999
|
-
|
|
1000
|
-
|
|
1001
|
-
|
|
1002
|
-
|
|
1003
|
-
|
|
1004
|
-
|
|
1005
|
-
|
|
1006
|
-
|
|
1007
|
-
|
|
1008
|
-
|
|
1009
|
-
|
|
1010
|
-
|
|
1011
|
-
|
|
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
|
|
1012
1050
|
};
|