@jayf0x/fluidity-js 0.1.3 → 0.1.5
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 +101 -118
- package/dist/globals.d.ts +63 -0
- package/dist/index.d.ts +65 -0
- package/dist/index.js +1017 -0
- package/package.json +10 -7
- package/dist/fluidity-js.js +0 -956
- package/types/index.d.ts +0 -290
package/dist/index.js
ADDED
|
@@ -0,0 +1,1017 @@
|
|
|
1
|
+
var jI = Object.defineProperty;
|
|
2
|
+
var PI = (C, I, i) => I in C ? jI(C, I, { enumerable: !0, configurable: !0, writable: !0, value: i }) : C[I] = i;
|
|
3
|
+
var BI = (C, I, i) => (PI(C, typeof I != "symbol" ? I + "" : I, i), i), LI = (C, I, i) => {
|
|
4
|
+
if (!I.has(C))
|
|
5
|
+
throw TypeError("Cannot " + i);
|
|
6
|
+
};
|
|
7
|
+
var g = (C, I, i) => (LI(C, I, "read from private field"), i ? i.call(C) : I.get(C)), n = (C, I, i) => {
|
|
8
|
+
if (I.has(C))
|
|
9
|
+
throw TypeError("Cannot add the same private member more than once");
|
|
10
|
+
I instanceof WeakSet ? I.add(C) : I.set(C, i);
|
|
11
|
+
}, o = (C, I, i, e) => (LI(C, I, "write to private field"), e ? e.call(C, i) : I.set(C, i), i);
|
|
12
|
+
var b = (C, I, i) => (LI(C, I, "access private method"), i);
|
|
13
|
+
import { jsx as TI } from "react/jsx-runtime";
|
|
14
|
+
import { useRef as bI, useEffect as Q, forwardRef as xI, useImperativeHandle as MI } from "react";
|
|
15
|
+
const JI = {
|
|
16
|
+
densityDissipation: 0.992,
|
|
17
|
+
velocityDissipation: 0.93,
|
|
18
|
+
pressureIterations: 1,
|
|
19
|
+
curl: 1e-4,
|
|
20
|
+
splatRadius: 4e-3,
|
|
21
|
+
splatForce: 0.91,
|
|
22
|
+
refraction: 0.25,
|
|
23
|
+
specularExp: 1.01,
|
|
24
|
+
shine: 0.01,
|
|
25
|
+
waterColor: [0, 0, 0],
|
|
26
|
+
glowColor: [0.7, 0.85, 1],
|
|
27
|
+
algorithm: "standard",
|
|
28
|
+
warpStrength: 0.015
|
|
29
|
+
}, kI = {
|
|
30
|
+
...JI,
|
|
31
|
+
densityDissipation: 0.99,
|
|
32
|
+
velocityDissipation: 0.98,
|
|
33
|
+
pressureIterations: 3,
|
|
34
|
+
curl: 0.15,
|
|
35
|
+
splatRadius: 0.01,
|
|
36
|
+
splatForce: 3,
|
|
37
|
+
refraction: 0.25,
|
|
38
|
+
specularExp: 1,
|
|
39
|
+
shine: 0.1,
|
|
40
|
+
glowColor: [0, 0.502, 1]
|
|
41
|
+
}, EI = {
|
|
42
|
+
backgroundColor: "#0a0a0a",
|
|
43
|
+
backgroundSize: "cover",
|
|
44
|
+
isMouseEnabled: !0,
|
|
45
|
+
isWorkerEnabled: !0
|
|
46
|
+
}, q = {
|
|
47
|
+
...EI,
|
|
48
|
+
effect: 0,
|
|
49
|
+
imageSize: "cover"
|
|
50
|
+
}, j = {
|
|
51
|
+
...EI,
|
|
52
|
+
fontSize: 100,
|
|
53
|
+
color: "#ffffff",
|
|
54
|
+
fontFamily: "sans-serif",
|
|
55
|
+
fontWeight: 900
|
|
56
|
+
}, _I = {
|
|
57
|
+
calm: {
|
|
58
|
+
densityDissipation: 0.999,
|
|
59
|
+
velocityDissipation: 0.98,
|
|
60
|
+
curl: 1e-4,
|
|
61
|
+
splatRadius: 3e-3,
|
|
62
|
+
splatForce: 0.5,
|
|
63
|
+
refraction: 0.15,
|
|
64
|
+
shine: 5e-3,
|
|
65
|
+
glowColor: [0.6, 0.85, 1],
|
|
66
|
+
waterColor: [0, 0.02, 0.05]
|
|
67
|
+
},
|
|
68
|
+
sand: {
|
|
69
|
+
densityDissipation: 0.997,
|
|
70
|
+
velocityDissipation: 0.98,
|
|
71
|
+
curl: 1,
|
|
72
|
+
splatRadius: 0.01,
|
|
73
|
+
splatForce: 0.9,
|
|
74
|
+
refraction: 0.8,
|
|
75
|
+
specularExp: 0.1,
|
|
76
|
+
shine: 0.05,
|
|
77
|
+
glowColor: [0.027, 0.027, 0.027],
|
|
78
|
+
waterColor: [0.451, 0.329, 0.125]
|
|
79
|
+
},
|
|
80
|
+
wave: {
|
|
81
|
+
densityDissipation: 0.994,
|
|
82
|
+
velocityDissipation: 0.92,
|
|
83
|
+
curl: 0.2,
|
|
84
|
+
splatRadius: 5e-3,
|
|
85
|
+
splatForce: 1.2,
|
|
86
|
+
refraction: 0.35,
|
|
87
|
+
shine: 0.03,
|
|
88
|
+
glowColor: [0.5, 0.8, 1],
|
|
89
|
+
waterColor: [0, 0.01, 0.03]
|
|
90
|
+
},
|
|
91
|
+
neon: {
|
|
92
|
+
densityDissipation: 0.985,
|
|
93
|
+
velocityDissipation: 0.93,
|
|
94
|
+
curl: 0.05,
|
|
95
|
+
splatRadius: 8e-3,
|
|
96
|
+
splatForce: 1.5,
|
|
97
|
+
refraction: 0.25,
|
|
98
|
+
specularExp: 0.5,
|
|
99
|
+
shine: 0.14,
|
|
100
|
+
glowColor: [1, 0.2, 0.8],
|
|
101
|
+
waterColor: [0.05, 0, 0.08]
|
|
102
|
+
},
|
|
103
|
+
smoke: {
|
|
104
|
+
densityDissipation: 0.996,
|
|
105
|
+
velocityDissipation: 0.97,
|
|
106
|
+
curl: 0.04,
|
|
107
|
+
splatRadius: 9e-3,
|
|
108
|
+
splatForce: 0.8,
|
|
109
|
+
refraction: 0.08,
|
|
110
|
+
shine: 0,
|
|
111
|
+
glowColor: [0.5, 0.5, 0.5],
|
|
112
|
+
waterColor: [0.06, 0.06, 0.06]
|
|
113
|
+
}
|
|
114
|
+
};
|
|
115
|
+
function uI(C = {}, I, i = JI) {
|
|
116
|
+
return { ...I ? { ...i, ..._I[I] } : i, ...C };
|
|
117
|
+
}
|
|
118
|
+
function RI(C, I, i, e, l = "cover") {
|
|
119
|
+
let s;
|
|
120
|
+
l === "cover" ? s = Math.max(i / C, e / I) : l === "contain" ? s = Math.min(i / C, e / I) : typeof l == "string" && l.endsWith("%") ? s = Math.min(i / C, e / I) * (parseFloat(l) / 100) : typeof l == "string" && l.endsWith("px") ? s = parseFloat(l) / Math.max(C, I) : typeof l == "number" ? s = l : s = Math.max(i / C, e / I);
|
|
121
|
+
const t = C * s, m = I * s;
|
|
122
|
+
return { x: (i - t) / 2, y: (e - m) / 2, drawW: t, drawH: m };
|
|
123
|
+
}
|
|
124
|
+
function qI(C, I, i, e, l = null, s = "cover") {
|
|
125
|
+
const { text: t, fontSize: m, color: r, fontFamily: a = "sans-serif", fontWeight: u = 900 } = e, S = new OffscreenCanvas(I, i), A = S.getContext("2d");
|
|
126
|
+
((K) => {
|
|
127
|
+
if (l) {
|
|
128
|
+
A.clearRect(0, 0, I, i), A.fillStyle = "black", A.fillRect(0, 0, I, i);
|
|
129
|
+
const { x: D, y: c, drawW: w, drawH: d } = RI(
|
|
130
|
+
l.width,
|
|
131
|
+
l.height,
|
|
132
|
+
I,
|
|
133
|
+
i,
|
|
134
|
+
s
|
|
135
|
+
);
|
|
136
|
+
A.drawImage(l, D, c, w, d);
|
|
137
|
+
} else
|
|
138
|
+
A.fillStyle = "black", A.fillRect(0, 0, I, i);
|
|
139
|
+
A.fillStyle = K, A.font = `${u} ${m}px ${a}`, A.textAlign = "center", A.textBaseline = "middle", A.fillText(t, I / 2, i / 2);
|
|
140
|
+
})(r);
|
|
141
|
+
const v = rI(C, S);
|
|
142
|
+
A.fillStyle = "black", A.fillRect(0, 0, I, i), A.fillStyle = "white", A.font = `${u} ${m}px ${a}`, A.textAlign = "center", A.textBaseline = "middle", A.fillText(t, I / 2, i / 2);
|
|
143
|
+
const Y = rI(C, S);
|
|
144
|
+
return { backgroundTex: v, obstacleTex: Y, coverageTex: Y };
|
|
145
|
+
}
|
|
146
|
+
function $I(C, I, i, e, l = 0, s = "cover", t = null, m = "cover") {
|
|
147
|
+
const r = new OffscreenCanvas(i, e), a = r.getContext("2d"), { x: u, y: S, drawW: A, drawH: h } = RI(I.width, I.height, i, e, s);
|
|
148
|
+
if (a.clearRect(0, 0, i, e), a.fillStyle = "black", a.fillRect(0, 0, i, e), t) {
|
|
149
|
+
const {
|
|
150
|
+
x: D,
|
|
151
|
+
y: c,
|
|
152
|
+
drawW: w,
|
|
153
|
+
drawH: d
|
|
154
|
+
} = RI(t.width, t.height, i, e, m);
|
|
155
|
+
a.filter = `brightness(${l}) blur(8px)`, a.drawImage(t, D, c, w, d), a.filter = "none";
|
|
156
|
+
}
|
|
157
|
+
a.drawImage(I, u, S, A, h);
|
|
158
|
+
const v = rI(C, r);
|
|
159
|
+
a.clearRect(0, 0, i, e), a.fillStyle = "black", a.fillRect(0, 0, i, e), a.filter = `brightness(${l}) blur(8px)`, a.drawImage(I, u, S, A, h), a.filter = "none";
|
|
160
|
+
const Y = rI(C, r);
|
|
161
|
+
a.clearRect(0, 0, i, e), a.fillStyle = "black", a.fillRect(0, 0, i, e), a.fillStyle = "white", a.fillRect(
|
|
162
|
+
Math.max(0, u),
|
|
163
|
+
Math.max(0, S),
|
|
164
|
+
Math.min(A, i - Math.max(0, u)),
|
|
165
|
+
Math.min(h, e - Math.max(0, S))
|
|
166
|
+
);
|
|
167
|
+
const K = rI(C, r);
|
|
168
|
+
return { backgroundTex: v, obstacleTex: Y, coverageTex: K };
|
|
169
|
+
}
|
|
170
|
+
function rI(C, I) {
|
|
171
|
+
const i = C.createTexture();
|
|
172
|
+
return C.bindTexture(C.TEXTURE_2D, i), C.pixelStorei(C.UNPACK_FLIP_Y_WEBGL, !0), C.texImage2D(C.TEXTURE_2D, 0, C.RGBA, C.RGBA, C.UNSIGNED_BYTE, I), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MIN_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MAG_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_S, C.CLAMP_TO_EDGE), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_T, C.CLAMP_TO_EDGE), i;
|
|
173
|
+
}
|
|
174
|
+
async function XI(C) {
|
|
175
|
+
const I = await fetch(C);
|
|
176
|
+
if (!I.ok)
|
|
177
|
+
throw new Error(`Failed to fetch image: ${C} (${I.status})`);
|
|
178
|
+
const i = await I.blob();
|
|
179
|
+
return createImageBitmap(i);
|
|
180
|
+
}
|
|
181
|
+
const P = (
|
|
182
|
+
/* glsl */
|
|
183
|
+
`
|
|
184
|
+
precision highp float;
|
|
185
|
+
attribute vec2 aPosition;
|
|
186
|
+
varying vec2 vUv;
|
|
187
|
+
varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
|
|
188
|
+
uniform vec2 texelSize;
|
|
189
|
+
void main () {
|
|
190
|
+
vUv = aPosition * 0.5 + 0.5;
|
|
191
|
+
vL = vUv - vec2(texelSize.x, 0.0);
|
|
192
|
+
vR = vUv + vec2(texelSize.x, 0.0);
|
|
193
|
+
vT = vUv + vec2(0.0, texelSize.y);
|
|
194
|
+
vB = vUv - vec2(0.0, texelSize.y);
|
|
195
|
+
gl_Position = vec4(aPosition, 0.0, 1.0);
|
|
196
|
+
}
|
|
197
|
+
`
|
|
198
|
+
), Ig = (
|
|
199
|
+
/* glsl */
|
|
200
|
+
`
|
|
201
|
+
precision highp float;
|
|
202
|
+
varying vec2 vUv;
|
|
203
|
+
uniform sampler2D uVelocity;
|
|
204
|
+
uniform sampler2D uSource;
|
|
205
|
+
uniform sampler2D uObstacle;
|
|
206
|
+
uniform vec2 texelSize;
|
|
207
|
+
uniform float dt;
|
|
208
|
+
uniform float dissipation;
|
|
209
|
+
void main () {
|
|
210
|
+
if (texture2D(uObstacle, vUv).r > 0.5) { gl_FragColor = vec4(0.0); return; }
|
|
211
|
+
vec2 coord = vUv - dt * texture2D(uVelocity, vUv).xy * texelSize;
|
|
212
|
+
gl_FragColor = dissipation * texture2D(uSource, coord);
|
|
213
|
+
}
|
|
214
|
+
`
|
|
215
|
+
), gg = (
|
|
216
|
+
/* glsl */
|
|
217
|
+
`
|
|
218
|
+
precision highp float;
|
|
219
|
+
varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
|
|
220
|
+
uniform sampler2D uVelocity;
|
|
221
|
+
uniform sampler2D uObstacle;
|
|
222
|
+
void main () {
|
|
223
|
+
float L = texture2D(uObstacle, vL).r > 0.5 ? 0.0 : texture2D(uVelocity, vL).x;
|
|
224
|
+
float R = texture2D(uObstacle, vR).r > 0.5 ? 0.0 : texture2D(uVelocity, vR).x;
|
|
225
|
+
float T = texture2D(uObstacle, vT).r > 0.5 ? 0.0 : texture2D(uVelocity, vT).y;
|
|
226
|
+
float B = texture2D(uObstacle, vB).r > 0.5 ? 0.0 : texture2D(uVelocity, vB).y;
|
|
227
|
+
gl_FragColor = vec4(0.5 * (R - L + T - B), 0.0, 0.0, 1.0);
|
|
228
|
+
}
|
|
229
|
+
`
|
|
230
|
+
), ig = (
|
|
231
|
+
/* glsl */
|
|
232
|
+
`
|
|
233
|
+
precision highp float;
|
|
234
|
+
varying vec2 vUv; varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
|
|
235
|
+
uniform sampler2D uPressure;
|
|
236
|
+
uniform sampler2D uDivergence;
|
|
237
|
+
uniform sampler2D uObstacle;
|
|
238
|
+
void main () {
|
|
239
|
+
float C = texture2D(uPressure, vUv).x;
|
|
240
|
+
float L = texture2D(uObstacle, vL).r > 0.5 ? C : texture2D(uPressure, vL).x;
|
|
241
|
+
float R = texture2D(uObstacle, vR).r > 0.5 ? C : texture2D(uPressure, vR).x;
|
|
242
|
+
float T = texture2D(uObstacle, vT).r > 0.5 ? C : texture2D(uPressure, vT).x;
|
|
243
|
+
float B = texture2D(uObstacle, vB).r > 0.5 ? C : texture2D(uPressure, vB).x;
|
|
244
|
+
float div = texture2D(uDivergence, vUv).x;
|
|
245
|
+
gl_FragColor = vec4((L + R + B + T - div) * 0.25, 0.0, 0.0, 1.0);
|
|
246
|
+
}
|
|
247
|
+
`
|
|
248
|
+
), Cg = (
|
|
249
|
+
/* glsl */
|
|
250
|
+
`
|
|
251
|
+
precision highp float;
|
|
252
|
+
varying vec2 vUv; varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
|
|
253
|
+
uniform sampler2D uPressure;
|
|
254
|
+
uniform sampler2D uVelocity;
|
|
255
|
+
uniform sampler2D uObstacle;
|
|
256
|
+
void main () {
|
|
257
|
+
if (texture2D(uObstacle, vUv).r > 0.5) { gl_FragColor = vec4(0.0); return; }
|
|
258
|
+
float L = texture2D(uPressure, vL).x;
|
|
259
|
+
float R = texture2D(uPressure, vR).x;
|
|
260
|
+
float T = texture2D(uPressure, vT).x;
|
|
261
|
+
float B = texture2D(uPressure, vB).x;
|
|
262
|
+
vec2 vel = texture2D(uVelocity, vUv).xy - vec2(R - L, T - B);
|
|
263
|
+
gl_FragColor = vec4(vel, 0.0, 1.0);
|
|
264
|
+
}
|
|
265
|
+
`
|
|
266
|
+
), eg = (
|
|
267
|
+
/* glsl */
|
|
268
|
+
`
|
|
269
|
+
precision highp float;
|
|
270
|
+
varying vec2 vUv;
|
|
271
|
+
uniform sampler2D uTarget;
|
|
272
|
+
uniform float aspectRatio;
|
|
273
|
+
uniform vec3 color;
|
|
274
|
+
uniform vec2 point;
|
|
275
|
+
uniform float radius;
|
|
276
|
+
void main () {
|
|
277
|
+
vec2 p = vUv - point.xy;
|
|
278
|
+
p.x *= aspectRatio;
|
|
279
|
+
vec3 splat = exp(-dot(p, p) / radius) * color;
|
|
280
|
+
gl_FragColor = vec4(texture2D(uTarget, vUv).xyz + splat, 1.0);
|
|
281
|
+
}
|
|
282
|
+
`
|
|
283
|
+
), lg = (
|
|
284
|
+
/* glsl */
|
|
285
|
+
`
|
|
286
|
+
precision highp float;
|
|
287
|
+
varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
|
|
288
|
+
uniform sampler2D uVelocity;
|
|
289
|
+
void main () {
|
|
290
|
+
float L = texture2D(uVelocity, vL).y;
|
|
291
|
+
float R = texture2D(uVelocity, vR).y;
|
|
292
|
+
float T = texture2D(uVelocity, vT).x;
|
|
293
|
+
float B = texture2D(uVelocity, vB).x;
|
|
294
|
+
gl_FragColor = vec4(0.5 * (R - L - T + B), 0.0, 0.0, 1.0);
|
|
295
|
+
}
|
|
296
|
+
`
|
|
297
|
+
), sg = (
|
|
298
|
+
/* glsl */
|
|
299
|
+
`
|
|
300
|
+
precision highp float;
|
|
301
|
+
varying vec2 vUv; varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
|
|
302
|
+
uniform sampler2D uVelocity;
|
|
303
|
+
uniform sampler2D uCurl;
|
|
304
|
+
uniform float curl;
|
|
305
|
+
uniform float dt;
|
|
306
|
+
void main () {
|
|
307
|
+
float L = texture2D(uCurl, vL).x;
|
|
308
|
+
float R = texture2D(uCurl, vR).x;
|
|
309
|
+
float T = texture2D(uCurl, vT).x;
|
|
310
|
+
float B = texture2D(uCurl, vB).x;
|
|
311
|
+
float C = texture2D(uCurl, vUv).x;
|
|
312
|
+
vec2 force = 0.5 * vec2(abs(T) - abs(B), abs(R) - abs(L));
|
|
313
|
+
force /= length(force) + 0.0001;
|
|
314
|
+
force *= curl * 30.0 * C;
|
|
315
|
+
gl_FragColor = vec4(texture2D(uVelocity, vUv).xy + force * dt, 0.0, 1.0);
|
|
316
|
+
}
|
|
317
|
+
`
|
|
318
|
+
), og = (
|
|
319
|
+
/* glsl */
|
|
320
|
+
`
|
|
321
|
+
precision highp float;
|
|
322
|
+
varying vec2 vUv;
|
|
323
|
+
|
|
324
|
+
uniform sampler2D uTexture;
|
|
325
|
+
uniform sampler2D uObstacle;
|
|
326
|
+
uniform sampler2D uBackground;
|
|
327
|
+
uniform sampler2D uCoverage;
|
|
328
|
+
uniform sampler2D uVelocity;
|
|
329
|
+
|
|
330
|
+
uniform vec2 texelSize;
|
|
331
|
+
uniform vec3 uWaterColor;
|
|
332
|
+
uniform vec3 uGlowColor;
|
|
333
|
+
uniform float uRefraction;
|
|
334
|
+
uniform float uSpecularExp;
|
|
335
|
+
uniform float uShine;
|
|
336
|
+
uniform float uWarpStrength;
|
|
337
|
+
uniform int uAlgorithm;
|
|
338
|
+
|
|
339
|
+
void main () {
|
|
340
|
+
float obs = texture2D(uObstacle, vUv).r;
|
|
341
|
+
// Mask density inside obstacles so splats don't flicker the text/image content.
|
|
342
|
+
float density = max(texture2D(uTexture, vUv).r, 0.0) * (1.0 - step(0.5, obs));
|
|
343
|
+
float coverage = texture2D(uCoverage, vUv).r;
|
|
344
|
+
|
|
345
|
+
float dL = max(texture2D(uTexture, vUv - vec2(texelSize.x * 2.0, 0.0)).r, 0.0);
|
|
346
|
+
float dR = max(texture2D(uTexture, vUv + vec2(texelSize.x * 2.0, 0.0)).r, 0.0);
|
|
347
|
+
float dT = max(texture2D(uTexture, vUv + vec2(0.0, texelSize.y * 2.0)).r, 0.0);
|
|
348
|
+
float dB = max(texture2D(uTexture, vUv - vec2(0.0, texelSize.y * 2.0)).r, 0.0);
|
|
349
|
+
|
|
350
|
+
vec3 normal = normalize(vec3(dL - dR, dB - dT, 0.2));
|
|
351
|
+
vec3 lightDir = normalize(vec3(0.5, 1.0, 0.5));
|
|
352
|
+
vec3 halfV = normalize(lightDir + vec3(0.0, 0.0, 1.0));
|
|
353
|
+
float spec = pow(max(dot(normal, halfV), 0.0), uSpecularExp) * uShine * density;
|
|
354
|
+
|
|
355
|
+
// In transparent (non-coverage) areas the background texture is empty black canvas.
|
|
356
|
+
// Replace it with uWaterColor so fluid colour is not contaminated by that black,
|
|
357
|
+
// allowing the CSS backgroundColor to show through correctly via premultiplied alpha.
|
|
358
|
+
vec3 bgRaw = texture2D(uBackground, vUv).rgb;
|
|
359
|
+
vec3 bg = mix(uWaterColor, bgRaw, coverage);
|
|
360
|
+
vec3 color = bg;
|
|
361
|
+
|
|
362
|
+
if (uAlgorithm == 1) {
|
|
363
|
+
// ── glass ──────────────────────────────────────────────────────────────
|
|
364
|
+
// Strong UV distortion only. Image bends but no colour overlay.
|
|
365
|
+
vec2 refrUv = clamp(vUv + normal.xy * uRefraction * density * 3.0, 0.0, 1.0);
|
|
366
|
+
vec3 refrBg = mix(uWaterColor, texture2D(uBackground, mix(vUv, refrUv, 1.0 - obs)).rgb, coverage);
|
|
367
|
+
color = refrBg + spec * uGlowColor * 2.5;
|
|
368
|
+
color = mix(color, bg * 0.6, obs * 0.3);
|
|
369
|
+
|
|
370
|
+
} else if (uAlgorithm == 2) {
|
|
371
|
+
// ── ink ────────────────────────────────────────────────────────────────
|
|
372
|
+
// Dense opaque pigment that stains. Subtle refraction underneath.
|
|
373
|
+
float inkD = min(density * 4.0, 1.0);
|
|
374
|
+
vec2 refrUv = clamp(vUv + normal.xy * uRefraction * density * 0.4, 0.0, 1.0);
|
|
375
|
+
vec3 refrBg = mix(uWaterColor, texture2D(uBackground, mix(vUv, refrUv, 1.0 - obs)).rgb, coverage);
|
|
376
|
+
color = mix(refrBg, uWaterColor + spec * uGlowColor, inkD);
|
|
377
|
+
color = mix(color, bg * 0.5, obs * 0.15);
|
|
378
|
+
|
|
379
|
+
} else if (uAlgorithm == 3) {
|
|
380
|
+
// ── aurora ─────────────────────────────────────────────────────────────
|
|
381
|
+
// Velocity field warps background UVs — liquid metal / lava-lamp feel.
|
|
382
|
+
vec2 vel = texture2D(uVelocity, vUv).xy;
|
|
383
|
+
float velMag = clamp(length(vel) * 20.0, 0.0, 1.0);
|
|
384
|
+
vec2 warpUv = clamp(vUv + vel * uWarpStrength, 0.0, 1.0);
|
|
385
|
+
vec3 warpBg = mix(uWaterColor, texture2D(uBackground, warpUv).rgb, coverage);
|
|
386
|
+
color = mix(bg, warpBg, velMag * (1.0 - obs));
|
|
387
|
+
color += spec * uGlowColor * velMag * 1.5;
|
|
388
|
+
color += uWaterColor * density * 0.3;
|
|
389
|
+
color = mix(color, bg * 0.5, obs * 0.2);
|
|
390
|
+
|
|
391
|
+
} else if (uAlgorithm == 4) {
|
|
392
|
+
// ── ripple ─────────────────────────────────────────────────────────────
|
|
393
|
+
// Exaggerated normal perturbation + Fresnel rim — calm water surface.
|
|
394
|
+
vec2 rippleUv = clamp(vUv + normal.xy * uRefraction * density * 6.0, 0.0, 1.0);
|
|
395
|
+
vec3 refrBg = mix(uWaterColor, texture2D(uBackground, mix(vUv, rippleUv, 1.0 - obs)).rgb, coverage);
|
|
396
|
+
float fresnel = pow(clamp(1.0 - dot(normal, vec3(0.0, 0.0, 1.0)), 0.0, 1.0), 3.0) * density;
|
|
397
|
+
color = refrBg;
|
|
398
|
+
color += fresnel * uGlowColor * 2.0;
|
|
399
|
+
color += spec * uGlowColor * density * 2.0;
|
|
400
|
+
color = mix(color, bg * 0.5, obs * 0.2);
|
|
401
|
+
|
|
402
|
+
} else {
|
|
403
|
+
// ── standard (0) ───────────────────────────────────────────────────────
|
|
404
|
+
// Original: colour overlay blended over refracted background.
|
|
405
|
+
vec2 refrUv = vUv + normal.xy * uRefraction * density;
|
|
406
|
+
vec3 refrBg = mix(uWaterColor, texture2D(uBackground, mix(vUv, refrUv, 1.0 - obs)).rgb, coverage);
|
|
407
|
+
color = mix(refrBg, uWaterColor, min(density * 1.5, 0.8));
|
|
408
|
+
color += spec * uGlowColor;
|
|
409
|
+
color = mix(color, bg * 0.5, obs * 0.2);
|
|
410
|
+
}
|
|
411
|
+
|
|
412
|
+
// Premultiplied alpha — transparent where there is neither content nor fluid,
|
|
413
|
+
// letting the CSS backgroundColor on the container div show through.
|
|
414
|
+
float alpha = clamp(max(density * 1.5, coverage), 0.0, 1.0);
|
|
415
|
+
gl_FragColor = vec4(color * alpha, alpha);
|
|
416
|
+
}
|
|
417
|
+
`
|
|
418
|
+
);
|
|
419
|
+
function tg(C) {
|
|
420
|
+
const I = { alpha: !0, depth: !1, stencil: !1, antialias: !0, preserveDrawingBuffer: !1 };
|
|
421
|
+
let i = C.getContext("webgl2", I);
|
|
422
|
+
const e = !!i;
|
|
423
|
+
e || (i = C.getContext("webgl", I), i.getExtension("EXT_color_buffer_half_float"));
|
|
424
|
+
const l = e ? null : i.getExtension("OES_texture_half_float"), s = e ? i.HALF_FLOAT : l.HALF_FLOAT_OES;
|
|
425
|
+
return i.getExtension("EXT_color_buffer_float"), i.getExtension("OES_texture_half_float_linear"), {
|
|
426
|
+
gl: i,
|
|
427
|
+
isWebGL2: e,
|
|
428
|
+
ext: {
|
|
429
|
+
internalFormat: e ? i.RGBA16F : i.RGBA,
|
|
430
|
+
format: i.RGBA,
|
|
431
|
+
type: s
|
|
432
|
+
}
|
|
433
|
+
};
|
|
434
|
+
}
|
|
435
|
+
class _ {
|
|
436
|
+
constructor(I, i, e) {
|
|
437
|
+
BI(this, "program");
|
|
438
|
+
BI(this, "uniforms", {});
|
|
439
|
+
BI(this, "_gl");
|
|
440
|
+
this._gl = I, this.program = I.createProgram(), I.attachShader(this.program, this._compile(I.VERTEX_SHADER, i)), I.attachShader(this.program, this._compile(I.FRAGMENT_SHADER, e)), I.linkProgram(this.program);
|
|
441
|
+
const l = I.getProgramParameter(this.program, I.ACTIVE_UNIFORMS);
|
|
442
|
+
for (let s = 0; s < l; s++) {
|
|
443
|
+
const t = I.getActiveUniform(this.program, s).name;
|
|
444
|
+
this.uniforms[t] = I.getUniformLocation(this.program, t);
|
|
445
|
+
}
|
|
446
|
+
}
|
|
447
|
+
_compile(I, i) {
|
|
448
|
+
const e = this._gl, l = e.createShader(I);
|
|
449
|
+
return e.shaderSource(l, i), e.compileShader(l), l;
|
|
450
|
+
}
|
|
451
|
+
bind() {
|
|
452
|
+
this._gl.useProgram(this.program);
|
|
453
|
+
}
|
|
454
|
+
dispose() {
|
|
455
|
+
this._gl.deleteProgram(this.program);
|
|
456
|
+
}
|
|
457
|
+
}
|
|
458
|
+
function cg(C) {
|
|
459
|
+
return {
|
|
460
|
+
advection: new _(C, P, Ig),
|
|
461
|
+
divergence: new _(C, P, gg),
|
|
462
|
+
pressure: new _(C, P, ig),
|
|
463
|
+
gradientSubtract: new _(C, P, Cg),
|
|
464
|
+
splat: new _(C, P, eg),
|
|
465
|
+
curl: new _(C, P, lg),
|
|
466
|
+
vorticity: new _(C, P, sg),
|
|
467
|
+
display: new _(C, P, og)
|
|
468
|
+
};
|
|
469
|
+
}
|
|
470
|
+
function VI(C, I, i, e) {
|
|
471
|
+
C.activeTexture(C.TEXTURE0);
|
|
472
|
+
const l = C.createTexture();
|
|
473
|
+
C.bindTexture(C.TEXTURE_2D, l), 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);
|
|
474
|
+
const s = C.createFramebuffer();
|
|
475
|
+
return C.bindFramebuffer(C.FRAMEBUFFER, s), C.framebufferTexture2D(C.FRAMEBUFFER, C.COLOR_ATTACHMENT0, C.TEXTURE_2D, l, 0), { tex: l, fbo: s, width: i, height: e };
|
|
476
|
+
}
|
|
477
|
+
function KI(C, I, i, e) {
|
|
478
|
+
let l = VI(C, I, i, e), s = VI(C, I, i, e);
|
|
479
|
+
return {
|
|
480
|
+
get read() {
|
|
481
|
+
return l;
|
|
482
|
+
},
|
|
483
|
+
get write() {
|
|
484
|
+
return s;
|
|
485
|
+
},
|
|
486
|
+
swap() {
|
|
487
|
+
[l, s] = [s, l];
|
|
488
|
+
},
|
|
489
|
+
dispose() {
|
|
490
|
+
C.deleteTexture(l.tex), C.deleteFramebuffer(l.fbo), C.deleteTexture(s.tex), C.deleteFramebuffer(s.fbo);
|
|
491
|
+
}
|
|
492
|
+
};
|
|
493
|
+
}
|
|
494
|
+
function dg(C) {
|
|
495
|
+
const I = C.createBuffer();
|
|
496
|
+
return C.bindBuffer(C.ARRAY_BUFFER, I), C.bufferData(C.ARRAY_BUFFER, new Float32Array([-1, -1, -1, 1, 1, 1, 1, -1]), C.STATIC_DRAW), C.vertexAttribPointer(0, 2, C.FLOAT, !1, 0, 0), C.enableVertexAttribArray(0), function(e) {
|
|
497
|
+
C.bindFramebuffer(C.FRAMEBUFFER, e), C.drawArrays(C.TRIANGLE_FAN, 0, 4);
|
|
498
|
+
};
|
|
499
|
+
}
|
|
500
|
+
const YI = typeof requestAnimationFrame < "u" ? requestAnimationFrame.bind(globalThis) : (C) => setTimeout(C, 1e3 / 60), ag = typeof cancelAnimationFrame < "u" ? cancelAnimationFrame.bind(globalThis) : clearTimeout, DI = 0.016, Ag = { standard: 0, glass: 1, ink: 2, aurora: 3, ripple: 4 };
|
|
501
|
+
var iI, R, mI, CI, cI, y, W, $, II, f, H, Z, x, M, J, z, X, E, F, dI, eI, V, U, N, lI, GI, sI, AI, ZI, HI, gI, tI, oI, nI, hI, WI, SI, vI, pI, NI;
|
|
502
|
+
class fI {
|
|
503
|
+
constructor(I, i = {}) {
|
|
504
|
+
// ---------------------------------------------------------------------------
|
|
505
|
+
// Private helpers
|
|
506
|
+
// ---------------------------------------------------------------------------
|
|
507
|
+
n(this, sI);
|
|
508
|
+
n(this, ZI);
|
|
509
|
+
n(this, gI);
|
|
510
|
+
n(this, oI);
|
|
511
|
+
n(this, hI);
|
|
512
|
+
n(this, SI);
|
|
513
|
+
n(this, pI);
|
|
514
|
+
n(this, iI, void 0);
|
|
515
|
+
n(this, R, void 0);
|
|
516
|
+
n(this, mI, void 0);
|
|
517
|
+
n(this, CI, void 0);
|
|
518
|
+
n(this, cI, void 0);
|
|
519
|
+
n(this, y, 0);
|
|
520
|
+
n(this, W, 0);
|
|
521
|
+
n(this, $, 0);
|
|
522
|
+
n(this, II, 0);
|
|
523
|
+
n(this, f, 1);
|
|
524
|
+
n(this, H, null);
|
|
525
|
+
n(this, Z, null);
|
|
526
|
+
n(this, x, null);
|
|
527
|
+
n(this, M, null);
|
|
528
|
+
n(this, J, null);
|
|
529
|
+
n(this, z, null);
|
|
530
|
+
n(this, X, null);
|
|
531
|
+
n(this, E, null);
|
|
532
|
+
// binary content mask for transparent canvas support
|
|
533
|
+
n(this, F, null);
|
|
534
|
+
// optional background image (from backgroundSrc prop)
|
|
535
|
+
n(this, dI, "cover");
|
|
536
|
+
n(this, eI, void 0);
|
|
537
|
+
n(this, V, { x: 0, y: 0, dx: 0, dy: 0, targetX: 0, targetY: 0, moved: !1 });
|
|
538
|
+
// Stores source so textures can be rebuilt on resize
|
|
539
|
+
n(this, U, null);
|
|
540
|
+
n(this, N, null);
|
|
541
|
+
n(this, lI, !1);
|
|
542
|
+
n(this, GI, !1);
|
|
543
|
+
o(this, iI, I), o(this, eI, uI(i));
|
|
544
|
+
const { gl: e, ext: l } = tg(I);
|
|
545
|
+
o(this, R, e), o(this, mI, l), o(this, CI, cg(e)), o(this, cI, dg(e)), e.clearColor(0, 0, 0, 0);
|
|
546
|
+
}
|
|
547
|
+
// ---------------------------------------------------------------------------
|
|
548
|
+
// Public API
|
|
549
|
+
// ---------------------------------------------------------------------------
|
|
550
|
+
setTextSource(I) {
|
|
551
|
+
o(this, U, { type: "text", opts: I }), b(this, sI, AI).call(this), b(this, gI, tI).call(this), b(this, oI, nI).call(this);
|
|
552
|
+
}
|
|
553
|
+
async setImageSource(I, i = 0, e = "cover") {
|
|
554
|
+
const l = await XI(I);
|
|
555
|
+
if (g(this, GI)) {
|
|
556
|
+
l.close();
|
|
557
|
+
return;
|
|
558
|
+
}
|
|
559
|
+
o(this, U, { type: "image", bitmap: l, effect: i, size: e }), b(this, sI, AI).call(this), b(this, gI, tI).call(this), b(this, oI, nI).call(this);
|
|
560
|
+
}
|
|
561
|
+
setImageBitmap(I, i = 0, e = "cover") {
|
|
562
|
+
o(this, U, { type: "image", bitmap: I, effect: i, size: e }), b(this, sI, AI).call(this), b(this, gI, tI).call(this), b(this, oI, nI).call(this);
|
|
563
|
+
}
|
|
564
|
+
setBackground(I, i = "cover") {
|
|
565
|
+
g(this, F) && g(this, F) !== I && g(this, F).close(), o(this, F, I), o(this, dI, i ?? "cover"), g(this, U) && g(this, y) > 0 && b(this, gI, tI).call(this);
|
|
566
|
+
}
|
|
567
|
+
handleMove(I, i, e = 1) {
|
|
568
|
+
g(this, V).moved = !0, g(this, V).dx = (I - g(this, V).targetX) * e, g(this, V).dy = (i - g(this, V).targetY) * e, g(this, V).targetX = I, g(this, V).targetY = i;
|
|
569
|
+
}
|
|
570
|
+
/**
|
|
571
|
+
* Immediately applies one fluid splat at (x, y) with explicit velocity (vx, vy).
|
|
572
|
+
* Safe to call multiple times per frame — each call writes directly to the FBOs.
|
|
573
|
+
* Designed for programmatic use cases (e.g. particle systems, attractor paths)
|
|
574
|
+
* where you want N independent injection points per frame without flooding the
|
|
575
|
+
* mouse-state machine or the worker message queue.
|
|
576
|
+
*/
|
|
577
|
+
splat(I, i, e, l, s = 1) {
|
|
578
|
+
if (!g(this, lI) || g(this, y) === 0)
|
|
579
|
+
return;
|
|
580
|
+
const t = g(this, R), m = g(this, eI), { splat: r } = g(this, CI), a = g(this, cI);
|
|
581
|
+
t.viewport(0, 0, g(this, $), g(this, II)), r.bind(), t.uniform1f(r.uniforms.aspectRatio, g(this, y) / g(this, W)), t.uniform2f(r.uniforms.point, I * g(this, f) / g(this, y), 1 - i * g(this, f) / g(this, W)), t.uniform1f(r.uniforms.radius, m.splatRadius), t.uniform1i(r.uniforms.uTarget, 0), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, g(this, Z).read.tex), t.uniform3f(r.uniforms.color, e * m.splatForce * s, -l * m.splatForce * s, 0), a(g(this, Z).write.fbo), g(this, Z).swap(), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, g(this, H).read.tex), t.uniform3f(r.uniforms.color, s, s, s), a(g(this, H).write.fbo), g(this, H).swap();
|
|
582
|
+
}
|
|
583
|
+
resize(I, i, e) {
|
|
584
|
+
if (e !== void 0 ? o(this, f, e) : typeof window < "u" && window.devicePixelRatio && o(this, f, window.devicePixelRatio), I !== void 0 && I > 0) {
|
|
585
|
+
if (i === void 0 || i <= 0)
|
|
586
|
+
return;
|
|
587
|
+
o(this, y, g(this, iI).width = I), o(this, W, g(this, iI).height = i), o(this, $, I >> 1), o(this, II, i >> 1), b(this, ZI, HI).call(this);
|
|
588
|
+
} else
|
|
589
|
+
b(this, sI, AI).call(this);
|
|
590
|
+
g(this, U) && b(this, gI, tI).call(this), b(this, oI, nI).call(this);
|
|
591
|
+
}
|
|
592
|
+
updateConfig(I) {
|
|
593
|
+
Object.assign(g(this, eI), I);
|
|
594
|
+
}
|
|
595
|
+
destroy() {
|
|
596
|
+
o(this, GI, !0), this.stop();
|
|
597
|
+
const I = g(this, R);
|
|
598
|
+
b(this, hI, WI).call(this), b(this, SI, vI).call(this), g(this, F) && (g(this, F).close(), o(this, F, null));
|
|
599
|
+
for (const e of Object.values(g(this, CI)))
|
|
600
|
+
e.dispose();
|
|
601
|
+
const i = I.getExtension("WEBGL_lose_context");
|
|
602
|
+
i == null || i.loseContext();
|
|
603
|
+
}
|
|
604
|
+
// ---------------------------------------------------------------------------
|
|
605
|
+
// Loop control
|
|
606
|
+
// ---------------------------------------------------------------------------
|
|
607
|
+
start() {
|
|
608
|
+
if (g(this, N) !== null)
|
|
609
|
+
return;
|
|
610
|
+
const I = () => {
|
|
611
|
+
b(this, pI, NI).call(this), o(this, N, YI(I));
|
|
612
|
+
};
|
|
613
|
+
o(this, N, YI(I));
|
|
614
|
+
}
|
|
615
|
+
stop() {
|
|
616
|
+
g(this, N) !== null && (ag(g(this, N)), o(this, N, null));
|
|
617
|
+
}
|
|
618
|
+
get isRunning() {
|
|
619
|
+
return g(this, N) !== null;
|
|
620
|
+
}
|
|
621
|
+
}
|
|
622
|
+
iI = new WeakMap(), R = new WeakMap(), mI = new WeakMap(), CI = new WeakMap(), cI = new WeakMap(), y = new WeakMap(), W = new WeakMap(), $ = new WeakMap(), II = new WeakMap(), f = new WeakMap(), H = new WeakMap(), Z = new WeakMap(), x = new WeakMap(), M = new WeakMap(), J = new WeakMap(), z = new WeakMap(), X = new WeakMap(), E = new WeakMap(), F = new WeakMap(), dI = new WeakMap(), eI = new WeakMap(), V = new WeakMap(), U = new WeakMap(), N = new WeakMap(), lI = new WeakMap(), GI = new WeakMap(), sI = new WeakSet(), AI = function() {
|
|
623
|
+
const I = g(this, iI);
|
|
624
|
+
"clientWidth" in I && I.clientWidth > 0 ? (o(this, f, typeof window < "u" && window.devicePixelRatio || 1), o(this, y, I.width = Math.round(I.clientWidth * g(this, f))), o(this, W, I.height = Math.round(I.clientHeight * g(this, f)))) : (o(this, y, I.width), o(this, W, I.height)), !(g(this, y) === 0 || g(this, W) === 0) && (o(this, $, g(this, y) >> 1), o(this, II, g(this, W) >> 1), b(this, ZI, HI).call(this));
|
|
625
|
+
}, ZI = new WeakSet(), HI = function() {
|
|
626
|
+
const I = g(this, R), i = g(this, mI), e = g(this, $), l = g(this, II);
|
|
627
|
+
b(this, hI, WI).call(this), o(this, H, KI(I, i, e, l)), o(this, Z, KI(I, i, e, l)), o(this, M, KI(I, i, e, l)), o(this, x, VI(I, i, e, l)), o(this, J, VI(I, i, e, l));
|
|
628
|
+
}, gI = new WeakSet(), tI = function() {
|
|
629
|
+
if (!(!g(this, U) || g(this, y) === 0)) {
|
|
630
|
+
if (b(this, SI, vI).call(this), g(this, U).type === "text") {
|
|
631
|
+
const { backgroundTex: I, obstacleTex: i, coverageTex: e } = qI(
|
|
632
|
+
g(this, R),
|
|
633
|
+
g(this, y),
|
|
634
|
+
g(this, W),
|
|
635
|
+
g(this, U).opts,
|
|
636
|
+
g(this, F),
|
|
637
|
+
g(this, dI)
|
|
638
|
+
);
|
|
639
|
+
o(this, z, I), o(this, X, i), o(this, E, e);
|
|
640
|
+
} else {
|
|
641
|
+
const { backgroundTex: I, obstacleTex: i, coverageTex: e } = $I(
|
|
642
|
+
g(this, R),
|
|
643
|
+
g(this, U).bitmap,
|
|
644
|
+
g(this, y),
|
|
645
|
+
g(this, W),
|
|
646
|
+
g(this, U).effect,
|
|
647
|
+
g(this, U).size,
|
|
648
|
+
g(this, F),
|
|
649
|
+
g(this, dI)
|
|
650
|
+
);
|
|
651
|
+
o(this, z, I), o(this, X, i), o(this, E, e);
|
|
652
|
+
}
|
|
653
|
+
o(this, lI, !0);
|
|
654
|
+
}
|
|
655
|
+
}, oI = new WeakSet(), nI = function() {
|
|
656
|
+
g(this, lI) && !this.isRunning && this.start();
|
|
657
|
+
}, hI = new WeakSet(), WI = function() {
|
|
658
|
+
var I, i, e;
|
|
659
|
+
(I = g(this, H)) == null || I.dispose(), (i = g(this, Z)) == null || i.dispose(), (e = g(this, M)) == null || e.dispose(), g(this, x) && (g(this, R).deleteTexture(g(this, x).tex), g(this, R).deleteFramebuffer(g(this, x).fbo)), g(this, J) && (g(this, R).deleteTexture(g(this, J).tex), g(this, R).deleteFramebuffer(g(this, J).fbo)), o(this, H, o(this, Z, o(this, M, o(this, x, o(this, J, null)))));
|
|
660
|
+
}, SI = new WeakSet(), vI = function() {
|
|
661
|
+
g(this, z) && g(this, R).deleteTexture(g(this, z)), g(this, X) && g(this, R).deleteTexture(g(this, X)), g(this, E) && g(this, E) !== g(this, X) && g(this, R).deleteTexture(g(this, E)), o(this, z, o(this, X, o(this, E, null)));
|
|
662
|
+
}, pI = new WeakSet(), NI = function() {
|
|
663
|
+
if (!g(this, lI) || g(this, y) === 0 || !g(this, H) || !g(this, Z))
|
|
664
|
+
return;
|
|
665
|
+
const I = g(this, R), i = g(this, eI), { advection: e, divergence: l, pressure: s, gradientSubtract: t, splat: m, curl: r, vorticity: a, display: u } = g(this, CI);
|
|
666
|
+
g(this, V).x += (g(this, V).targetX - g(this, V).x) * 0.15, g(this, V).y += (g(this, V).targetY - g(this, V).y) * 0.15;
|
|
667
|
+
const S = g(this, $), A = g(this, II), h = g(this, cI);
|
|
668
|
+
I.viewport(0, 0, S, A), e.bind(), I.uniform2f(e.uniforms.texelSize, 1 / S, 1 / A), I.uniform1f(e.uniforms.dt, DI), I.uniform1i(e.uniforms.uObstacle, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, X)), I.uniform1f(e.uniforms.dissipation, i.velocityDissipation), I.uniform1i(e.uniforms.uVelocity, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, Z).read.tex), I.uniform1i(e.uniforms.uSource, 1), h(g(this, Z).write.fbo), g(this, Z).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(), r.bind(), I.uniform2f(r.uniforms.texelSize, 1 / S, 1 / A), I.uniform1i(r.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, Z).read.tex), h(g(this, J).fbo), a.bind(), I.uniform2f(a.uniforms.texelSize, 1 / S, 1 / A), I.uniform1f(a.uniforms.curl, i.curl), I.uniform1f(a.uniforms.dt, DI), I.uniform1i(a.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, Z).read.tex), I.uniform1i(a.uniforms.uCurl, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, J).tex), h(g(this, Z).write.fbo), g(this, Z).swap(), g(this, V).moved && (m.bind(), I.uniform1f(m.uniforms.aspectRatio, g(this, y) / g(this, W)), I.uniform2f(m.uniforms.point, g(this, V).x * g(this, f) / g(this, y), 1 - g(this, V).y * g(this, f) / g(this, W)), I.uniform1f(m.uniforms.radius, i.splatRadius), I.uniform1i(m.uniforms.uTarget, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, Z).read.tex), I.uniform3f(m.uniforms.color, g(this, V).dx * i.splatForce, -g(this, V).dy * i.splatForce, 0), h(g(this, Z).write.fbo), g(this, Z).swap(), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, H).read.tex), I.uniform3f(m.uniforms.color, 1, 1, 1), h(g(this, H).write.fbo), g(this, H).swap(), g(this, V).moved = !1), l.bind(), I.uniform2f(l.uniforms.texelSize, 1 / S, 1 / A), I.uniform1i(l.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, Z).read.tex), I.uniform1i(l.uniforms.uObstacle, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, X)), h(g(this, x).fbo), s.bind(), I.uniform2f(s.uniforms.texelSize, 1 / S, 1 / A), I.uniform1i(s.uniforms.uDivergence, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, x).tex), I.uniform1i(s.uniforms.uObstacle, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, X));
|
|
669
|
+
for (let v = 0; v < i.pressureIterations; v++)
|
|
670
|
+
I.uniform1i(s.uniforms.uPressure, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, M).read.tex), h(g(this, M).write.fbo), g(this, M).swap();
|
|
671
|
+
t.bind(), I.uniform2f(t.uniforms.texelSize, 1 / S, 1 / A), I.uniform1i(t.uniforms.uPressure, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, M).read.tex), I.uniform1i(t.uniforms.uVelocity, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, Z).read.tex), I.uniform1i(t.uniforms.uObstacle, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, X)), h(g(this, Z).write.fbo), g(this, Z).swap(), I.viewport(0, 0, g(this, y), g(this, W)), I.bindFramebuffer(I.FRAMEBUFFER, null), I.clear(I.COLOR_BUFFER_BIT), u.bind(), I.uniform2f(u.uniforms.texelSize, 1 / g(this, y), 1 / g(this, W)), I.uniform3fv(u.uniforms.uWaterColor, i.waterColor), I.uniform3fv(u.uniforms.uGlowColor, i.glowColor), I.uniform1f(u.uniforms.uRefraction, i.refraction), I.uniform1f(u.uniforms.uSpecularExp, i.specularExp), I.uniform1f(u.uniforms.uShine, i.shine), I.uniform1f(u.uniforms.uWarpStrength, i.warpStrength ?? 0.015), I.uniform1i(u.uniforms.uAlgorithm, Ag[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, X)), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, z)), I.activeTexture(I.TEXTURE3), I.bindTexture(I.TEXTURE_2D, g(this, E)), I.activeTexture(I.TEXTURE4), I.bindTexture(I.TEXTURE_2D, g(this, Z).read.tex), I.uniform1i(u.uniforms.uTexture, 0), I.uniform1i(u.uniforms.uObstacle, 1), I.uniform1i(u.uniforms.uBackground, 2), I.uniform1i(u.uniforms.uCoverage, 3), I.uniform1i(u.uniforms.uVelocity, 4), h(null);
|
|
672
|
+
};
|
|
673
|
+
const zI = "dmFyIHllID0gT2JqZWN0LmRlZmluZVByb3BlcnR5Owp2YXIgRGUgPSAoaSwgZSwgcikgPT4gZSBpbiBpID8geWUoaSwgZSwgeyBlbnVtZXJhYmxlOiAhMCwgY29uZmlndXJhYmxlOiAhMCwgd3JpdGFibGU6ICEwLCB2YWx1ZTogciB9KSA6IGlbZV0gPSByOwp2YXIgc2UgPSAoaSwgZSwgcikgPT4gKERlKGksIHR5cGVvZiBlICE9ICJzeW1ib2wiID8gZSArICIiIDogZSwgciksIHIpLCBoZSA9IChpLCBlLCByKSA9PiB7CiAgaWYgKCFlLmhhcyhpKSkKICAgIHRocm93IFR5cGVFcnJvcigiQ2Fubm90ICIgKyByKTsKfTsKdmFyIHQgPSAoaSwgZSwgcikgPT4gKGhlKGksIGUsICJyZWFkIGZyb20gcHJpdmF0ZSBmaWVsZCIpLCByID8gci5jYWxsKGkpIDogZS5nZXQoaSkpLCBsID0gKGksIGUsIHIpID0+IHsKICBpZiAoZS5oYXMoaSkpCiAgICB0aHJvdyBUeXBlRXJyb3IoIkNhbm5vdCBhZGQgdGhlIHNhbWUgcHJpdmF0ZSBtZW1iZXIgbW9yZSB0aGFuIG9uY2UiKTsKICBlIGluc3RhbmNlb2YgV2Vha1NldCA/IGUuYWRkKGkpIDogZS5zZXQoaSwgcik7Cn0sIGEgPSAoaSwgZSwgciwgbykgPT4gKGhlKGksIGUsICJ3cml0ZSB0byBwcml2YXRlIGZpZWxkIiksIG8gPyBvLmNhbGwoaSwgcikgOiBlLnNldChpLCByKSwgcik7CnZhciBkID0gKGksIGUsIHIpID0+IChoZShpLCBlLCAiYWNjZXNzIHByaXZhdGUgbWV0aG9kIiksIHIpOwpjb25zdCBnZSA9IHsKICBkZW5zaXR5RGlzc2lwYXRpb246IDAuOTkyLAogIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTMsCiAgcHJlc3N1cmVJdGVyYXRpb25zOiAxLAogIGN1cmw6IDFlLTQsCiAgc3BsYXRSYWRpdXM6IDRlLTMsCiAgc3BsYXRGb3JjZTogMC45MSwKICByZWZyYWN0aW9uOiAwLjI1LAogIHNwZWN1bGFyRXhwOiAxLjAxLAogIHNoaW5lOiAwLjAxLAogIHdhdGVyQ29sb3I6IFswLCAwLCAwXSwKICBnbG93Q29sb3I6IFswLjcsIDAuODUsIDFdLAogIGFsZ29yaXRobTogInN0YW5kYXJkIiwKICB3YXJwU3RyZW5ndGg6IDAuMDE1Cn07Cih7CiAgLi4uZ2UKfSk7CmNvbnN0IFVlID0gewogIGNhbG06IHsKICAgIGRlbnNpdHlEaXNzaXBhdGlvbjogMC45OTksCiAgICB2ZWxvY2l0eURpc3NpcGF0aW9uOiAwLjk4LAogICAgY3VybDogMWUtNCwKICAgIHNwbGF0UmFkaXVzOiAzZS0zLAogICAgc3BsYXRGb3JjZTogMC41LAogICAgcmVmcmFjdGlvbjogMC4xNSwKICAgIHNoaW5lOiA1ZS0zLAogICAgZ2xvd0NvbG9yOiBbMC42LCAwLjg1LCAxXSwKICAgIHdhdGVyQ29sb3I6IFswLCAwLjAyLCAwLjA1XQogIH0sCiAgc2FuZDogewogICAgZGVuc2l0eURpc3NpcGF0aW9uOiAwLjk5NywKICAgIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTgsCiAgICBjdXJsOiAxLAogICAgc3BsYXRSYWRpdXM6IDAuMDEsCiAgICBzcGxhdEZvcmNlOiAwLjksCiAgICByZWZyYWN0aW9uOiAwLjgsCiAgICBzcGVjdWxhckV4cDogMC4xLAogICAgc2hpbmU6IDAuMDUsCiAgICBnbG93Q29sb3I6IFswLjAyNywgMC4wMjcsIDAuMDI3XSwKICAgIHdhdGVyQ29sb3I6IFswLjQ1MSwgMC4zMjksIDAuMTI1XQogIH0sCiAgd2F2ZTogewogICAgZGVuc2l0eURpc3NpcGF0aW9uOiAwLjk5NCwKICAgIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTIsCiAgICBjdXJsOiAwLjIsCiAgICBzcGxhdFJhZGl1czogNWUtMywKICAgIHNwbGF0Rm9yY2U6IDEuMiwKICAgIHJlZnJhY3Rpb246IDAuMzUsCiAgICBzaGluZTogMC4wMywKICAgIGdsb3dDb2xvcjogWzAuNSwgMC44LCAxXSwKICAgIHdhdGVyQ29sb3I6IFswLCAwLjAxLCAwLjAzXQogIH0sCiAgbmVvbjogewogICAgZGVuc2l0eURpc3NpcGF0aW9uOiAwLjk4NSwKICAgIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTMsCiAgICBjdXJsOiAwLjA1LAogICAgc3BsYXRSYWRpdXM6IDhlLTMsCiAgICBzcGxhdEZvcmNlOiAxLjUsCiAgICByZWZyYWN0aW9uOiAwLjI1LAogICAgc3BlY3VsYXJFeHA6IDAuNSwKICAgIHNoaW5lOiAwLjE0LAogICAgZ2xvd0NvbG9yOiBbMSwgMC4yLCAwLjhdLAogICAgd2F0ZXJDb2xvcjogWzAuMDUsIDAsIDAuMDhdCiAgfSwKICBzbW9rZTogewogICAgZGVuc2l0eURpc3NpcGF0aW9uOiAwLjk5NiwKICAgIHZlbG9jaXR5RGlzc2lwYXRpb246IDAuOTcsCiAgICBjdXJsOiAwLjA0LAogICAgc3BsYXRSYWRpdXM6IDllLTMsCiAgICBzcGxhdEZvcmNlOiAwLjgsCiAgICByZWZyYWN0aW9uOiAwLjA4LAogICAgc2hpbmU6IDAsCiAgICBnbG93Q29sb3I6IFswLjUsIDAuNSwgMC41XSwKICAgIHdhdGVyQ29sb3I6IFswLjA2LCAwLjA2LCAwLjA2XQogIH0KfTsKZnVuY3Rpb24gX2UoaSA9IHt9LCBlLCByID0gZ2UpIHsKICByZXR1cm4geyAuLi5lID8geyAuLi5yLCAuLi5VZVtlXSB9IDogciwgLi4uaSB9Owp9CmNvbnN0IFAgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgYXR0cmlidXRlIHZlYzIgYVBvc2l0aW9uOwogIHZhcnlpbmcgdmVjMiB2VXY7CiAgdmFyeWluZyB2ZWMyIHZMOyB2YXJ5aW5nIHZlYzIgdlI7IHZhcnlpbmcgdmVjMiB2VDsgdmFyeWluZyB2ZWMyIHZCOwogIHVuaWZvcm0gdmVjMiB0ZXhlbFNpemU7CiAgdm9pZCBtYWluICgpIHsKICAgIHZVdiA9IGFQb3NpdGlvbiAqIDAuNSArIDAuNTsKICAgIHZMID0gdlV2IC0gdmVjMih0ZXhlbFNpemUueCwgMC4wKTsKICAgIHZSID0gdlV2ICsgdmVjMih0ZXhlbFNpemUueCwgMC4wKTsKICAgIHZUID0gdlV2ICsgdmVjMigwLjAsIHRleGVsU2l6ZS55KTsKICAgIHZCID0gdlV2IC0gdmVjMigwLjAsIHRleGVsU2l6ZS55KTsKICAgIGdsX1Bvc2l0aW9uID0gdmVjNChhUG9zaXRpb24sIDAuMCwgMS4wKTsKICB9CmAKKSwgd2UgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVNvdXJjZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1T2JzdGFjbGU7CiAgdW5pZm9ybSB2ZWMyIHRleGVsU2l6ZTsKICB1bmlmb3JtIGZsb2F0IGR0OwogIHVuaWZvcm0gZmxvYXQgZGlzc2lwYXRpb247CiAgdm9pZCBtYWluICgpIHsKICAgIGlmICh0ZXh0dXJlMkQodU9ic3RhY2xlLCB2VXYpLnIgPiAwLjUpIHsgZ2xfRnJhZ0NvbG9yID0gdmVjNCgwLjApOyByZXR1cm47IH0KICAgIHZlYzIgY29vcmQgPSB2VXYgLSBkdCAqIHRleHR1cmUyRCh1VmVsb2NpdHksIHZVdikueHkgKiB0ZXhlbFNpemU7CiAgICBnbF9GcmFnQ29sb3IgPSBkaXNzaXBhdGlvbiAqIHRleHR1cmUyRCh1U291cmNlLCBjb29yZCk7CiAgfQpgCiksIENlID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2TDsgdmFyeWluZyB2ZWMyIHZSOyB2YXJ5aW5nIHZlYzIgdlQ7IHZhcnlpbmcgdmVjMiB2QjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdU9ic3RhY2xlOwogIHZvaWQgbWFpbiAoKSB7CiAgICBmbG9hdCBMID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdkwpLnIgPiAwLjUgPyAwLjAgOiB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2TCkueDsKICAgIGZsb2F0IFIgPSB0ZXh0dXJlMkQodU9ic3RhY2xlLCB2UikuciA+IDAuNSA/IDAuMCA6IHRleHR1cmUyRCh1VmVsb2NpdHksIHZSKS54OwogICAgZmxvYXQgVCA9IHRleHR1cmUyRCh1T2JzdGFjbGUsIHZUKS5yID4gMC41ID8gMC4wIDogdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlQpLnk7CiAgICBmbG9hdCBCID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdkIpLnIgPiAwLjUgPyAwLjAgOiB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2QikueTsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQoMC41ICogKFIgLSBMICsgVCAtIEIpLCAwLjAsIDAuMCwgMS4wKTsKICB9CmAKKSwgU2UgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsgdmFyeWluZyB2ZWMyIHZMOyB2YXJ5aW5nIHZlYzIgdlI7IHZhcnlpbmcgdmVjMiB2VDsgdmFyeWluZyB2ZWMyIHZCOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVQcmVzc3VyZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1RGl2ZXJnZW5jZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1T2JzdGFjbGU7CiAgdm9pZCBtYWluICgpIHsKICAgIGZsb2F0IEMgPSB0ZXh0dXJlMkQodVByZXNzdXJlLCB2VXYpLng7CiAgICBmbG9hdCBMID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdkwpLnIgPiAwLjUgPyBDIDogdGV4dHVyZTJEKHVQcmVzc3VyZSwgdkwpLng7CiAgICBmbG9hdCBSID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdlIpLnIgPiAwLjUgPyBDIDogdGV4dHVyZTJEKHVQcmVzc3VyZSwgdlIpLng7CiAgICBmbG9hdCBUID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdlQpLnIgPiAwLjUgPyBDIDogdGV4dHVyZTJEKHVQcmVzc3VyZSwgdlQpLng7CiAgICBmbG9hdCBCID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgdkIpLnIgPiAwLjUgPyBDIDogdGV4dHVyZTJEKHVQcmVzc3VyZSwgdkIpLng7CiAgICBmbG9hdCBkaXYgPSB0ZXh0dXJlMkQodURpdmVyZ2VuY2UsIHZVdikueDsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQoKEwgKyBSICsgQiArIFQgLSBkaXYpICogMC4yNSwgMC4wLCAwLjAsIDEuMCk7CiAgfQpgCiksIEZlID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2VXY7IHZhcnlpbmcgdmVjMiB2TDsgdmFyeWluZyB2ZWMyIHZSOyB2YXJ5aW5nIHZlYzIgdlQ7IHZhcnlpbmcgdmVjMiB2QjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1UHJlc3N1cmU7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVZlbG9jaXR5OwogIHVuaWZvcm0gc2FtcGxlcjJEIHVPYnN0YWNsZTsKICB2b2lkIG1haW4gKCkgewogICAgaWYgKHRleHR1cmUyRCh1T2JzdGFjbGUsIHZVdikuciA+IDAuNSkgeyBnbF9GcmFnQ29sb3IgPSB2ZWM0KDAuMCk7IHJldHVybjsgfQogICAgZmxvYXQgTCA9IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZMKS54OwogICAgZmxvYXQgUiA9IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZSKS54OwogICAgZmxvYXQgVCA9IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZUKS54OwogICAgZmxvYXQgQiA9IHRleHR1cmUyRCh1UHJlc3N1cmUsIHZCKS54OwogICAgdmVjMiB2ZWwgPSB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2VXYpLnh5IC0gdmVjMihSIC0gTCwgVCAtIEIpOwogICAgZ2xfRnJhZ0NvbG9yID0gdmVjNCh2ZWwsIDAuMCwgMS4wKTsKICB9CmAKKSwgWGUgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VGFyZ2V0OwogIHVuaWZvcm0gZmxvYXQgYXNwZWN0UmF0aW87CiAgdW5pZm9ybSB2ZWMzIGNvbG9yOwogIHVuaWZvcm0gdmVjMiBwb2ludDsKICB1bmlmb3JtIGZsb2F0IHJhZGl1czsKICB2b2lkIG1haW4gKCkgewogICAgdmVjMiBwID0gdlV2IC0gcG9pbnQueHk7CiAgICBwLnggKj0gYXNwZWN0UmF0aW87CiAgICB2ZWMzIHNwbGF0ID0gZXhwKC1kb3QocCwgcCkgLyByYWRpdXMpICogY29sb3I7CiAgICBnbF9GcmFnQ29sb3IgPSB2ZWM0KHRleHR1cmUyRCh1VGFyZ2V0LCB2VXYpLnh5eiArIHNwbGF0LCAxLjApOwogIH0KYAopLCBCZSA9ICgKICAvKiBnbHNsICovCiAgYAogIHByZWNpc2lvbiBoaWdocCBmbG9hdDsKICB2YXJ5aW5nIHZlYzIgdkw7IHZhcnlpbmcgdmVjMiB2UjsgdmFyeWluZyB2ZWMyIHZUOyB2YXJ5aW5nIHZlYzIgdkI7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdVZlbG9jaXR5OwogIHZvaWQgbWFpbiAoKSB7CiAgICBmbG9hdCBMID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdkwpLnk7CiAgICBmbG9hdCBSID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlIpLnk7CiAgICBmbG9hdCBUID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdlQpLng7CiAgICBmbG9hdCBCID0gdGV4dHVyZTJEKHVWZWxvY2l0eSwgdkIpLng7CiAgICBnbF9GcmFnQ29sb3IgPSB2ZWM0KDAuNSAqIChSIC0gTCAtIFQgKyBCKSwgMC4wLCAwLjAsIDEuMCk7CiAgfQpgCiksIEFlID0gKAogIC8qIGdsc2wgKi8KICBgCiAgcHJlY2lzaW9uIGhpZ2hwIGZsb2F0OwogIHZhcnlpbmcgdmVjMiB2VXY7IHZhcnlpbmcgdmVjMiB2TDsgdmFyeWluZyB2ZWMyIHZSOyB2YXJ5aW5nIHZlYzIgdlQ7IHZhcnlpbmcgdmVjMiB2QjsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdUN1cmw7CiAgdW5pZm9ybSBmbG9hdCBjdXJsOwogIHVuaWZvcm0gZmxvYXQgZHQ7CiAgdm9pZCBtYWluICgpIHsKICAgIGZsb2F0IEwgPSB0ZXh0dXJlMkQodUN1cmwsIHZMKS54OwogICAgZmxvYXQgUiA9IHRleHR1cmUyRCh1Q3VybCwgdlIpLng7CiAgICBmbG9hdCBUID0gdGV4dHVyZTJEKHVDdXJsLCB2VCkueDsKICAgIGZsb2F0IEIgPSB0ZXh0dXJlMkQodUN1cmwsIHZCKS54OwogICAgZmxvYXQgQyA9IHRleHR1cmUyRCh1Q3VybCwgdlV2KS54OwogICAgdmVjMiBmb3JjZSA9IDAuNSAqIHZlYzIoYWJzKFQpIC0gYWJzKEIpLCBhYnMoUikgLSBhYnMoTCkpOwogICAgZm9yY2UgLz0gbGVuZ3RoKGZvcmNlKSArIDAuMDAwMTsKICAgIGZvcmNlICo9IGN1cmwgKiAzMC4wICogQzsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQodGV4dHVyZTJEKHVWZWxvY2l0eSwgdlV2KS54eSArIGZvcmNlICogZHQsIDAuMCwgMS4wKTsKICB9CmAKKSwgTGUgPSAoCiAgLyogZ2xzbCAqLwogIGAKICBwcmVjaXNpb24gaGlnaHAgZmxvYXQ7CiAgdmFyeWluZyB2ZWMyIHZVdjsKCiAgdW5pZm9ybSBzYW1wbGVyMkQgdVRleHR1cmU7CiAgdW5pZm9ybSBzYW1wbGVyMkQgdU9ic3RhY2xlOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVCYWNrZ3JvdW5kOwogIHVuaWZvcm0gc2FtcGxlcjJEIHVDb3ZlcmFnZTsKICB1bmlmb3JtIHNhbXBsZXIyRCB1VmVsb2NpdHk7CgogIHVuaWZvcm0gdmVjMiAgdGV4ZWxTaXplOwogIHVuaWZvcm0gdmVjMyAgdVdhdGVyQ29sb3I7CiAgdW5pZm9ybSB2ZWMzICB1R2xvd0NvbG9yOwogIHVuaWZvcm0gZmxvYXQgdVJlZnJhY3Rpb247CiAgdW5pZm9ybSBmbG9hdCB1U3BlY3VsYXJFeHA7CiAgdW5pZm9ybSBmbG9hdCB1U2hpbmU7CiAgdW5pZm9ybSBmbG9hdCB1V2FycFN0cmVuZ3RoOwogIHVuaWZvcm0gaW50ICAgdUFsZ29yaXRobTsKCiAgdm9pZCBtYWluICgpIHsKICAgIGZsb2F0IG9icyAgICAgID0gdGV4dHVyZTJEKHVPYnN0YWNsZSwgIHZVdikucjsKICAgIC8vIE1hc2sgZGVuc2l0eSBpbnNpZGUgb2JzdGFjbGVzIHNvIHNwbGF0cyBkb24ndCBmbGlja2VyIHRoZSB0ZXh0L2ltYWdlIGNvbnRlbnQuCiAgICBmbG9hdCBkZW5zaXR5ICA9IG1heCh0ZXh0dXJlMkQodVRleHR1cmUsIHZVdikuciwgMC4wKSAqICgxLjAgLSBzdGVwKDAuNSwgb2JzKSk7CiAgICBmbG9hdCBjb3ZlcmFnZSA9IHRleHR1cmUyRCh1Q292ZXJhZ2UsICB2VXYpLnI7CgogICAgZmxvYXQgZEwgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgLSB2ZWMyKHRleGVsU2l6ZS54ICogMi4wLCAwLjApKS5yLCAwLjApOwogICAgZmxvYXQgZFIgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgKyB2ZWMyKHRleGVsU2l6ZS54ICogMi4wLCAwLjApKS5yLCAwLjApOwogICAgZmxvYXQgZFQgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgKyB2ZWMyKDAuMCwgdGV4ZWxTaXplLnkgKiAyLjApKS5yLCAwLjApOwogICAgZmxvYXQgZEIgPSBtYXgodGV4dHVyZTJEKHVUZXh0dXJlLCB2VXYgLSB2ZWMyKDAuMCwgdGV4ZWxTaXplLnkgKiAyLjApKS5yLCAwLjApOwoKICAgIHZlYzMgIG5vcm1hbCAgID0gbm9ybWFsaXplKHZlYzMoZEwgLSBkUiwgZEIgLSBkVCwgMC4yKSk7CiAgICB2ZWMzICBsaWdodERpciA9IG5vcm1hbGl6ZSh2ZWMzKDAuNSwgMS4wLCAwLjUpKTsKICAgIHZlYzMgIGhhbGZWICAgID0gbm9ybWFsaXplKGxpZ2h0RGlyICsgdmVjMygwLjAsIDAuMCwgMS4wKSk7CiAgICBmbG9hdCBzcGVjICAgICA9IHBvdyhtYXgoZG90KG5vcm1hbCwgaGFsZlYpLCAwLjApLCB1U3BlY3VsYXJFeHApICogdVNoaW5lICogZGVuc2l0eTsKCiAgICAvLyBJbiB0cmFuc3BhcmVudCAobm9uLWNvdmVyYWdlKSBhcmVhcyB0aGUgYmFja2dyb3VuZCB0ZXh0dXJlIGlzIGVtcHR5IGJsYWNrIGNhbnZhcy4KICAgIC8vIFJlcGxhY2UgaXQgd2l0aCB1V2F0ZXJDb2xvciBzbyBmbHVpZCBjb2xvdXIgaXMgbm90IGNvbnRhbWluYXRlZCBieSB0aGF0IGJsYWNrLAogICAgLy8gYWxsb3dpbmcgdGhlIENTUyBiYWNrZ3JvdW5kQ29sb3IgdG8gc2hvdyB0aHJvdWdoIGNvcnJlY3RseSB2aWEgcHJlbXVsdGlwbGllZCBhbHBoYS4KICAgIHZlYzMgYmdSYXcgPSB0ZXh0dXJlMkQodUJhY2tncm91bmQsIHZVdikucmdiOwogICAgdmVjMyBiZyAgICA9IG1peCh1V2F0ZXJDb2xvciwgYmdSYXcsIGNvdmVyYWdlKTsKICAgIHZlYzMgY29sb3IgPSBiZzsKCiAgICBpZiAodUFsZ29yaXRobSA9PSAxKSB7CiAgICAgIC8vIOKUgOKUgCBnbGFzcyDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgICAgLy8gU3Ryb25nIFVWIGRpc3RvcnRpb24gb25seS4gSW1hZ2UgYmVuZHMgYnV0IG5vIGNvbG91ciBvdmVybGF5LgogICAgICB2ZWMyIHJlZnJVdiA9IGNsYW1wKHZVdiArIG5vcm1hbC54eSAqIHVSZWZyYWN0aW9uICogZGVuc2l0eSAqIDMuMCwgMC4wLCAxLjApOwogICAgICB2ZWMzIHJlZnJCZyA9IG1peCh1V2F0ZXJDb2xvciwgdGV4dHVyZTJEKHVCYWNrZ3JvdW5kLCBtaXgodlV2LCByZWZyVXYsIDEuMCAtIG9icykpLnJnYiwgY292ZXJhZ2UpOwogICAgICBjb2xvciA9IHJlZnJCZyArIHNwZWMgKiB1R2xvd0NvbG9yICogMi41OwogICAgICBjb2xvciA9IG1peChjb2xvciwgYmcgKiAwLjYsIG9icyAqIDAuMyk7CgogICAgfSBlbHNlIGlmICh1QWxnb3JpdGhtID09IDIpIHsKICAgICAgLy8g4pSA4pSAIGluayDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgICAgLy8gRGVuc2Ugb3BhcXVlIHBpZ21lbnQgdGhhdCBzdGFpbnMuIFN1YnRsZSByZWZyYWN0aW9uIHVuZGVybmVhdGguCiAgICAgIGZsb2F0IGlua0QgID0gbWluKGRlbnNpdHkgKiA0LjAsIDEuMCk7CiAgICAgIHZlYzIgcmVmclV2ID0gY2xhbXAodlV2ICsgbm9ybWFsLnh5ICogdVJlZnJhY3Rpb24gKiBkZW5zaXR5ICogMC40LCAwLjAsIDEuMCk7CiAgICAgIHZlYzMgcmVmckJnID0gbWl4KHVXYXRlckNvbG9yLCB0ZXh0dXJlMkQodUJhY2tncm91bmQsIG1peCh2VXYsIHJlZnJVdiwgMS4wIC0gb2JzKSkucmdiLCBjb3ZlcmFnZSk7CiAgICAgIGNvbG9yID0gbWl4KHJlZnJCZywgdVdhdGVyQ29sb3IgKyBzcGVjICogdUdsb3dDb2xvciwgaW5rRCk7CiAgICAgIGNvbG9yID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4xNSk7CgogICAgfSBlbHNlIGlmICh1QWxnb3JpdGhtID09IDMpIHsKICAgICAgLy8g4pSA4pSAIGF1cm9yYSDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIAKICAgICAgLy8gVmVsb2NpdHkgZmllbGQgd2FycHMgYmFja2dyb3VuZCBVVnMg4oCUIGxpcXVpZCBtZXRhbCAvIGxhdmEtbGFtcCBmZWVsLgogICAgICB2ZWMyICB2ZWwgICAgPSB0ZXh0dXJlMkQodVZlbG9jaXR5LCB2VXYpLnh5OwogICAgICBmbG9hdCB2ZWxNYWcgPSBjbGFtcChsZW5ndGgodmVsKSAqIDIwLjAsIDAuMCwgMS4wKTsKICAgICAgdmVjMiAgd2FycFV2ID0gY2xhbXAodlV2ICsgdmVsICogdVdhcnBTdHJlbmd0aCwgMC4wLCAxLjApOwogICAgICB2ZWMzICB3YXJwQmcgPSBtaXgodVdhdGVyQ29sb3IsIHRleHR1cmUyRCh1QmFja2dyb3VuZCwgd2FycFV2KS5yZ2IsIGNvdmVyYWdlKTsKICAgICAgY29sb3IgID0gbWl4KGJnLCB3YXJwQmcsIHZlbE1hZyAqICgxLjAgLSBvYnMpKTsKICAgICAgY29sb3IgKz0gc3BlYyAqIHVHbG93Q29sb3IgKiB2ZWxNYWcgKiAxLjU7CiAgICAgIGNvbG9yICs9IHVXYXRlckNvbG9yICogZGVuc2l0eSAqIDAuMzsKICAgICAgY29sb3IgID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4yKTsKCiAgICB9IGVsc2UgaWYgKHVBbGdvcml0aG0gPT0gNCkgewogICAgICAvLyDilIDilIAgcmlwcGxlIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgAogICAgICAvLyBFeGFnZ2VyYXRlZCBub3JtYWwgcGVydHVyYmF0aW9uICsgRnJlc25lbCByaW0g4oCUIGNhbG0gd2F0ZXIgc3VyZmFjZS4KICAgICAgdmVjMiAgcmlwcGxlVXYgPSBjbGFtcCh2VXYgKyBub3JtYWwueHkgKiB1UmVmcmFjdGlvbiAqIGRlbnNpdHkgKiA2LjAsIDAuMCwgMS4wKTsKICAgICAgdmVjMyAgcmVmckJnICAgPSBtaXgodVdhdGVyQ29sb3IsIHRleHR1cmUyRCh1QmFja2dyb3VuZCwgbWl4KHZVdiwgcmlwcGxlVXYsIDEuMCAtIG9icykpLnJnYiwgY292ZXJhZ2UpOwogICAgICBmbG9hdCBmcmVzbmVsICA9IHBvdyhjbGFtcCgxLjAgLSBkb3Qobm9ybWFsLCB2ZWMzKDAuMCwgMC4wLCAxLjApKSwgMC4wLCAxLjApLCAzLjApICogZGVuc2l0eTsKICAgICAgY29sb3IgID0gcmVmckJnOwogICAgICBjb2xvciArPSBmcmVzbmVsICogdUdsb3dDb2xvciAqIDIuMDsKICAgICAgY29sb3IgKz0gc3BlYyAqIHVHbG93Q29sb3IgKiBkZW5zaXR5ICogMi4wOwogICAgICBjb2xvciAgPSBtaXgoY29sb3IsIGJnICogMC41LCBvYnMgKiAwLjIpOwoKICAgIH0gZWxzZSB7CiAgICAgIC8vIOKUgOKUgCBzdGFuZGFyZCAoMCkg4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSACiAgICAgIC8vIE9yaWdpbmFsOiBjb2xvdXIgb3ZlcmxheSBibGVuZGVkIG92ZXIgcmVmcmFjdGVkIGJhY2tncm91bmQuCiAgICAgIHZlYzIgcmVmclV2ID0gdlV2ICsgbm9ybWFsLnh5ICogdVJlZnJhY3Rpb24gKiBkZW5zaXR5OwogICAgICB2ZWMzIHJlZnJCZyA9IG1peCh1V2F0ZXJDb2xvciwgdGV4dHVyZTJEKHVCYWNrZ3JvdW5kLCBtaXgodlV2LCByZWZyVXYsIDEuMCAtIG9icykpLnJnYiwgY292ZXJhZ2UpOwogICAgICBjb2xvciAgPSBtaXgocmVmckJnLCB1V2F0ZXJDb2xvciwgbWluKGRlbnNpdHkgKiAxLjUsIDAuOCkpOwogICAgICBjb2xvciArPSBzcGVjICogdUdsb3dDb2xvcjsKICAgICAgY29sb3IgID0gbWl4KGNvbG9yLCBiZyAqIDAuNSwgb2JzICogMC4yKTsKICAgIH0KCiAgICAvLyBQcmVtdWx0aXBsaWVkIGFscGhhIOKAlCB0cmFuc3BhcmVudCB3aGVyZSB0aGVyZSBpcyBuZWl0aGVyIGNvbnRlbnQgbm9yIGZsdWlkLAogICAgLy8gbGV0dGluZyB0aGUgQ1NTIGJhY2tncm91bmRDb2xvciBvbiB0aGUgY29udGFpbmVyIGRpdiBzaG93IHRocm91Z2guCiAgICBmbG9hdCBhbHBoYSA9IGNsYW1wKG1heChkZW5zaXR5ICogMS41LCBjb3ZlcmFnZSksIDAuMCwgMS4wKTsKICAgIGdsX0ZyYWdDb2xvciA9IHZlYzQoY29sb3IgKiBhbHBoYSwgYWxwaGEpOwogIH0KYAopOwpmdW5jdGlvbiBQZShpKSB7CiAgY29uc3QgZSA9IHsgYWxwaGE6ICEwLCBkZXB0aDogITEsIHN0ZW5jaWw6ICExLCBhbnRpYWxpYXM6ICEwLCBwcmVzZXJ2ZURyYXdpbmdCdWZmZXI6ICExIH07CiAgbGV0IHIgPSBpLmdldENvbnRleHQoIndlYmdsMiIsIGUpOwogIGNvbnN0IG8gPSAhIXI7CiAgbyB8fCAociA9IGkuZ2V0Q29udGV4dCgid2ViZ2wiLCBlKSwgci5nZXRFeHRlbnNpb24oIkVYVF9jb2xvcl9idWZmZXJfaGFsZl9mbG9hdCIpKTsKICBjb25zdCBzID0gbyA/IG51bGwgOiByLmdldEV4dGVuc2lvbigiT0VTX3RleHR1cmVfaGFsZl9mbG9hdCIpLCBuID0gbyA/IHIuSEFMRl9GTE9BVCA6IHMuSEFMRl9GTE9BVF9PRVM7CiAgcmV0dXJuIHIuZ2V0RXh0ZW5zaW9uKCJFWFRfY29sb3JfYnVmZmVyX2Zsb2F0IiksIHIuZ2V0RXh0ZW5zaW9uKCJPRVNfdGV4dHVyZV9oYWxmX2Zsb2F0X2xpbmVhciIpLCB7CiAgICBnbDogciwKICAgIGlzV2ViR0wyOiBvLAogICAgZXh0OiB7CiAgICAgIGludGVybmFsRm9ybWF0OiBvID8gci5SR0JBMTZGIDogci5SR0JBLAogICAgICBmb3JtYXQ6IHIuUkdCQSwKICAgICAgdHlwZTogbgogICAgfQogIH07Cn0KY2xhc3MgTyB7CiAgY29uc3RydWN0b3IoZSwgciwgbykgewogICAgc2UodGhpcywgInByb2dyYW0iKTsKICAgIHNlKHRoaXMsICJ1bmlmb3JtcyIsIHt9KTsKICAgIHNlKHRoaXMsICJfZ2wiKTsKICAgIHRoaXMuX2dsID0gZSwgdGhpcy5wcm9ncmFtID0gZS5jcmVhdGVQcm9ncmFtKCksIGUuYXR0YWNoU2hhZGVyKHRoaXMucHJvZ3JhbSwgdGhpcy5fY29tcGlsZShlLlZFUlRFWF9TSEFERVIsIHIpKSwgZS5hdHRhY2hTaGFkZXIodGhpcy5wcm9ncmFtLCB0aGlzLl9jb21waWxlKGUuRlJBR01FTlRfU0hBREVSLCBvKSksIGUubGlua1Byb2dyYW0odGhpcy5wcm9ncmFtKTsKICAgIGNvbnN0IHMgPSBlLmdldFByb2dyYW1QYXJhbWV0ZXIodGhpcy5wcm9ncmFtLCBlLkFDVElWRV9VTklGT1JNUyk7CiAgICBmb3IgKGxldCBuID0gMDsgbiA8IHM7IG4rKykgewogICAgICBjb25zdCB1ID0gZS5nZXRBY3RpdmVVbmlmb3JtKHRoaXMucHJvZ3JhbSwgbikubmFtZTsKICAgICAgdGhpcy51bmlmb3Jtc1t1XSA9IGUuZ2V0VW5pZm9ybUxvY2F0aW9uKHRoaXMucHJvZ3JhbSwgdSk7CiAgICB9CiAgfQogIF9jb21waWxlKGUsIHIpIHsKICAgIGNvbnN0IG8gPSB0aGlzLl9nbCwgcyA9IG8uY3JlYXRlU2hhZGVyKGUpOwogICAgcmV0dXJuIG8uc2hhZGVyU291cmNlKHMsIHIpLCBvLmNvbXBpbGVTaGFkZXIocyksIHM7CiAgfQogIGJpbmQoKSB7CiAgICB0aGlzLl9nbC51c2VQcm9ncmFtKHRoaXMucHJvZ3JhbSk7CiAgfQogIGRpc3Bvc2UoKSB7CiAgICB0aGlzLl9nbC5kZWxldGVQcm9ncmFtKHRoaXMucHJvZ3JhbSk7CiAgfQp9CmZ1bmN0aW9uIE9lKGkpIHsKICByZXR1cm4gewogICAgYWR2ZWN0aW9uOiBuZXcgTyhpLCBQLCB3ZSksCiAgICBkaXZlcmdlbmNlOiBuZXcgTyhpLCBQLCBDZSksCiAgICBwcmVzc3VyZTogbmV3IE8oaSwgUCwgU2UpLAogICAgZ3JhZGllbnRTdWJ0cmFjdDogbmV3IE8oaSwgUCwgRmUpLAogICAgc3BsYXQ6IG5ldyBPKGksIFAsIFhlKSwKICAgIGN1cmw6IG5ldyBPKGksIFAsIEJlKSwKICAgIHZvcnRpY2l0eTogbmV3IE8oaSwgUCwgQWUpLAogICAgZGlzcGxheTogbmV3IE8oaSwgUCwgTGUpCiAgfTsKfQpmdW5jdGlvbiBhZShpLCBlLCByLCBvKSB7CiAgaS5hY3RpdmVUZXh0dXJlKGkuVEVYVFVSRTApOwogIGNvbnN0IHMgPSBpLmNyZWF0ZVRleHR1cmUoKTsKICBpLmJpbmRUZXh0dXJlKGkuVEVYVFVSRV8yRCwgcyksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9NSU5fRklMVEVSLCBpLkxJTkVBUiksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9NQUdfRklMVEVSLCBpLkxJTkVBUiksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9XUkFQX1MsIGkuQ0xBTVBfVE9fRURHRSksIGkudGV4UGFyYW1ldGVyaShpLlRFWFRVUkVfMkQsIGkuVEVYVFVSRV9XUkFQX1QsIGkuQ0xBTVBfVE9fRURHRSksIGkudGV4SW1hZ2UyRChpLlRFWFRVUkVfMkQsIDAsIGUuaW50ZXJuYWxGb3JtYXQsIHIsIG8sIDAsIGUuZm9ybWF0LCBlLnR5cGUsIG51bGwpOwogIGNvbnN0IG4gPSBpLmNyZWF0ZUZyYW1lYnVmZmVyKCk7CiAgcmV0dXJuIGkuYmluZEZyYW1lYnVmZmVyKGkuRlJBTUVCVUZGRVIsIG4pLCBpLmZyYW1lYnVmZmVyVGV4dHVyZTJEKGkuRlJBTUVCVUZGRVIsIGkuQ09MT1JfQVRUQUNITUVOVDAsIGkuVEVYVFVSRV8yRCwgcywgMCksIHsgdGV4OiBzLCBmYm86IG4sIHdpZHRoOiByLCBoZWlnaHQ6IG8gfTsKfQpmdW5jdGlvbiBtZShpLCBlLCByLCBvKSB7CiAgbGV0IHMgPSBhZShpLCBlLCByLCBvKSwgbiA9IGFlKGksIGUsIHIsIG8pOwogIHJldHVybiB7CiAgICBnZXQgcmVhZCgpIHsKICAgICAgcmV0dXJuIHM7CiAgICB9LAogICAgZ2V0IHdyaXRlKCkgewogICAgICByZXR1cm4gbjsKICAgIH0sCiAgICBzd2FwKCkgewogICAgICBbcywgbl0gPSBbbiwgc107CiAgICB9LAogICAgZGlzcG9zZSgpIHsKICAgICAgaS5kZWxldGVUZXh0dXJlKHMudGV4KSwgaS5kZWxldGVGcmFtZWJ1ZmZlcihzLmZibyksIGkuZGVsZXRlVGV4dHVyZShuLnRleCksIGkuZGVsZXRlRnJhbWVidWZmZXIobi5mYm8pOwogICAgfQogIH07Cn0KZnVuY3Rpb24ga2UoaSkgewogIGNvbnN0IGUgPSBpLmNyZWF0ZUJ1ZmZlcigpOwogIHJldHVybiBpLmJpbmRCdWZmZXIoaS5BUlJBWV9CVUZGRVIsIGUpLCBpLmJ1ZmZlckRhdGEoaS5BUlJBWV9CVUZGRVIsIG5ldyBGbG9hdDMyQXJyYXkoWy0xLCAtMSwgLTEsIDEsIDEsIDEsIDEsIC0xXSksIGkuU1RBVElDX0RSQVcpLCBpLnZlcnRleEF0dHJpYlBvaW50ZXIoMCwgMiwgaS5GTE9BVCwgITEsIDAsIDApLCBpLmVuYWJsZVZlcnRleEF0dHJpYkFycmF5KDApLCBmdW5jdGlvbihvKSB7CiAgICBpLmJpbmRGcmFtZWJ1ZmZlcihpLkZSQU1FQlVGRkVSLCBvKSwgaS5kcmF3QXJyYXlzKGkuVFJJQU5HTEVfRkFOLCAwLCA0KTsKICB9Owp9CmZ1bmN0aW9uIHhlKGksIGUsIHIsIG8sIHMgPSAiY292ZXIiKSB7CiAgbGV0IG47CiAgcyA9PT0gImNvdmVyIiA/IG4gPSBNYXRoLm1heChyIC8gaSwgbyAvIGUpIDogcyA9PT0gImNvbnRhaW4iID8gbiA9IE1hdGgubWluKHIgLyBpLCBvIC8gZSkgOiB0eXBlb2YgcyA9PSAic3RyaW5nIiAmJiBzLmVuZHNXaXRoKCIlIikgPyBuID0gTWF0aC5taW4ociAvIGksIG8gLyBlKSAqIChwYXJzZUZsb2F0KHMpIC8gMTAwKSA6IHR5cGVvZiBzID09ICJzdHJpbmciICYmIHMuZW5kc1dpdGgoInB4IikgPyBuID0gcGFyc2VGbG9hdChzKSAvIE1hdGgubWF4KGksIGUpIDogdHlwZW9mIHMgPT0gIm51bWJlciIgPyBuID0gcyA6IG4gPSBNYXRoLm1heChyIC8gaSwgbyAvIGUpOwogIGNvbnN0IHUgPSBpICogbiwgVCA9IGUgKiBuOwogIHJldHVybiB7IHg6IChyIC0gdSkgLyAyLCB5OiAobyAtIFQpIC8gMiwgZHJhd1c6IHUsIGRyYXdIOiBUIH07Cn0KZnVuY3Rpb24gSWUoaSwgZSwgciwgbywgcyA9IG51bGwsIG4gPSAiY292ZXIiKSB7CiAgY29uc3QgeyB0ZXh0OiB1LCBmb250U2l6ZTogVCwgY29sb3I6IEUsIGZvbnRGYW1pbHk6IGMgPSAic2Fucy1zZXJpZiIsIGZvbnRXZWlnaHQ6IGggPSA5MDAgfSA9IG8sIFIgPSBuZXcgT2Zmc2NyZWVuQ2FudmFzKGUsIHIpLCBmID0gUi5nZXRDb250ZXh0KCIyZCIpOwogICgodWUpID0+IHsKICAgIGlmIChzKSB7CiAgICAgIGYuY2xlYXJSZWN0KDAsIDAsIGUsIHIpLCBmLmZpbGxTdHlsZSA9ICJibGFjayIsIGYuZmlsbFJlY3QoMCwgMCwgZSwgcik7CiAgICAgIGNvbnN0IHsgeDogbGUsIHk6IGNlLCBkcmF3VzogZmUsIGRyYXdIOiB2ZSB9ID0geGUoCiAgICAgICAgcy53aWR0aCwKICAgICAgICBzLmhlaWdodCwKICAgICAgICBlLAogICAgICAgIHIsCiAgICAgICAgbgogICAgICApOwogICAgICBmLmRyYXdJbWFnZShzLCBsZSwgY2UsIGZlLCB2ZSk7CiAgICB9IGVsc2UKICAgICAgZi5maWxsU3R5bGUgPSAiYmxhY2siLCBmLmZpbGxSZWN0KDAsIDAsIGUsIHIpOwogICAgZi5maWxsU3R5bGUgPSB1ZSwgZi5mb250ID0gYCR7aH0gJHtUfXB4ICR7Y31gLCBmLnRleHRBbGlnbiA9ICJjZW50ZXIiLCBmLnRleHRCYXNlbGluZSA9ICJtaWRkbGUiLCBmLmZpbGxUZXh0KHUsIGUgLyAyLCByIC8gMik7CiAgfSkoRSk7CiAgY29uc3QgWSA9IFEoaSwgUik7CiAgZi5maWxsU3R5bGUgPSAiYmxhY2siLCBmLmZpbGxSZWN0KDAsIDAsIGUsIHIpLCBmLmZpbGxTdHlsZSA9ICJ3aGl0ZSIsIGYuZm9udCA9IGAke2h9ICR7VH1weCAke2N9YCwgZi50ZXh0QWxpZ24gPSAiY2VudGVyIiwgZi50ZXh0QmFzZWxpbmUgPSAibWlkZGxlIiwgZi5maWxsVGV4dCh1LCBlIC8gMiwgciAvIDIpOwogIGNvbnN0IG9lID0gUShpLCBSKTsKICByZXR1cm4geyBiYWNrZ3JvdW5kVGV4OiBZLCBvYnN0YWNsZVRleDogb2UsIGNvdmVyYWdlVGV4OiBvZSB9Owp9CmZ1bmN0aW9uIE1lKGksIGUsIHIsIG8sIHMgPSAwLCBuID0gImNvdmVyIiwgdSA9IG51bGwsIFQgPSAiY292ZXIiKSB7CiAgY29uc3QgRSA9IG5ldyBPZmZzY3JlZW5DYW52YXMociwgbyksIGMgPSBFLmdldENvbnRleHQoIjJkIiksIHsgeDogaCwgeTogUiwgZHJhd1c6IGYsIGRyYXdIOiBEIH0gPSB4ZShlLndpZHRoLCBlLmhlaWdodCwgciwgbywgbik7CiAgaWYgKGMuY2xlYXJSZWN0KDAsIDAsIHIsIG8pLCBjLmZpbGxTdHlsZSA9ICJibGFjayIsIGMuZmlsbFJlY3QoMCwgMCwgciwgbyksIHUpIHsKICAgIGNvbnN0IHsKICAgICAgeDogbGUsCiAgICAgIHk6IGNlLAogICAgICBkcmF3VzogZmUsCiAgICAgIGRyYXdIOiB2ZQogICAgfSA9IHhlKHUud2lkdGgsIHUuaGVpZ2h0LCByLCBvLCBUKTsKICAgIGMuZmlsdGVyID0gYGJyaWdodG5lc3MoJHtzfSkgYmx1cig4cHgpYCwgYy5kcmF3SW1hZ2UodSwgbGUsIGNlLCBmZSwgdmUpLCBjLmZpbHRlciA9ICJub25lIjsKICB9CiAgYy5kcmF3SW1hZ2UoZSwgaCwgUiwgZiwgRCk7CiAgY29uc3QgWSA9IFEoaSwgRSk7CiAgYy5jbGVhclJlY3QoMCwgMCwgciwgbyksIGMuZmlsbFN0eWxlID0gImJsYWNrIiwgYy5maWxsUmVjdCgwLCAwLCByLCBvKSwgYy5maWx0ZXIgPSBgYnJpZ2h0bmVzcygke3N9KSBibHVyKDhweClgLCBjLmRyYXdJbWFnZShlLCBoLCBSLCBmLCBEKSwgYy5maWx0ZXIgPSAibm9uZSI7CiAgY29uc3Qgb2UgPSBRKGksIEUpOwogIGMuY2xlYXJSZWN0KDAsIDAsIHIsIG8pLCBjLmZpbGxTdHlsZSA9ICJibGFjayIsIGMuZmlsbFJlY3QoMCwgMCwgciwgbyksIGMuZmlsbFN0eWxlID0gIndoaXRlIiwgYy5maWxsUmVjdCgKICAgIE1hdGgubWF4KDAsIGgpLAogICAgTWF0aC5tYXgoMCwgUiksCiAgICBNYXRoLm1pbihmLCByIC0gTWF0aC5tYXgoMCwgaCkpLAogICAgTWF0aC5taW4oRCwgbyAtIE1hdGgubWF4KDAsIFIpKQogICk7CiAgY29uc3QgdWUgPSBRKGksIEUpOwogIHJldHVybiB7IGJhY2tncm91bmRUZXg6IFksIG9ic3RhY2xlVGV4OiBvZSwgY292ZXJhZ2VUZXg6IHVlIH07Cn0KZnVuY3Rpb24gUShpLCBlKSB7CiAgY29uc3QgciA9IGkuY3JlYXRlVGV4dHVyZSgpOwogIHJldHVybiBpLmJpbmRUZXh0dXJlKGkuVEVYVFVSRV8yRCwgciksIGkucGl4ZWxTdG9yZWkoaS5VTlBBQ0tfRkxJUF9ZX1dFQkdMLCAhMCksIGkudGV4SW1hZ2UyRChpLlRFWFRVUkVfMkQsIDAsIGkuUkdCQSwgaS5SR0JBLCBpLlVOU0lHTkVEX0JZVEUsIGUpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfTUlOX0ZJTFRFUiwgaS5MSU5FQVIpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfTUFHX0ZJTFRFUiwgaS5MSU5FQVIpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfV1JBUF9TLCBpLkNMQU1QX1RPX0VER0UpLCBpLnRleFBhcmFtZXRlcmkoaS5URVhUVVJFXzJELCBpLlRFWFRVUkVfV1JBUF9ULCBpLkNMQU1QX1RPX0VER0UpLCByOwp9CmFzeW5jIGZ1bmN0aW9uIFZlKGkpIHsKICBjb25zdCBlID0gYXdhaXQgZmV0Y2goaSk7CiAgaWYgKCFlLm9rKQogICAgdGhyb3cgbmV3IEVycm9yKGBGYWlsZWQgdG8gZmV0Y2ggaW1hZ2U6ICR7aX0gKCR7ZS5zdGF0dXN9KWApOwogIGNvbnN0IHIgPSBhd2FpdCBlLmJsb2IoKTsKICByZXR1cm4gY3JlYXRlSW1hZ2VCaXRtYXAocik7Cn0KY29uc3QgRWUgPSB0eXBlb2YgcmVxdWVzdEFuaW1hdGlvbkZyYW1lIDwgInUiID8gcmVxdWVzdEFuaW1hdGlvbkZyYW1lLmJpbmQoZ2xvYmFsVGhpcykgOiAoaSkgPT4gc2V0VGltZW91dChpLCAxZTMgLyA2MCksIFdlID0gdHlwZW9mIGNhbmNlbEFuaW1hdGlvbkZyYW1lIDwgInUiID8gY2FuY2VsQW5pbWF0aW9uRnJhbWUuYmluZChnbG9iYWxUaGlzKSA6IGNsZWFyVGltZW91dCwgYmUgPSAwLjAxNiwgR2UgPSB7IHN0YW5kYXJkOiAwLCBnbGFzczogMSwgaW5rOiAyLCBhdXJvcmE6IDMsIHJpcHBsZTogNCB9Owp2YXIgViwgYiwgWiwgVywgSCwgcCwgeSwgaywgSSwgdywgZywgdiwgUywgRiwgWCwgTCwgVSwgQiwgQywgaiwgRywgeCwgXywgQSwgeiwgZWUsIE4sIEssIHRlLCBUZSwgTSwgcSwgJCwgSiwgcmUsIGRlLCBpZSwgcGUsIG5lLCBSZTsKY2xhc3MgemUgewogIGNvbnN0cnVjdG9yKGUsIHIgPSB7fSkgewogICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICAvLyBQcml2YXRlIGhlbHBlcnMKICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgbCh0aGlzLCBOKTsKICAgIGwodGhpcywgdGUpOwogICAgbCh0aGlzLCBNKTsKICAgIGwodGhpcywgJCk7CiAgICBsKHRoaXMsIHJlKTsKICAgIGwodGhpcywgaWUpOwogICAgbCh0aGlzLCBuZSk7CiAgICBsKHRoaXMsIFYsIHZvaWQgMCk7CiAgICBsKHRoaXMsIGIsIHZvaWQgMCk7CiAgICBsKHRoaXMsIFosIHZvaWQgMCk7CiAgICBsKHRoaXMsIFcsIHZvaWQgMCk7CiAgICBsKHRoaXMsIEgsIHZvaWQgMCk7CiAgICBsKHRoaXMsIHAsIDApOwogICAgbCh0aGlzLCB5LCAwKTsKICAgIGwodGhpcywgaywgMCk7CiAgICBsKHRoaXMsIEksIDApOwogICAgbCh0aGlzLCB3LCAxKTsKICAgIGwodGhpcywgZywgbnVsbCk7CiAgICBsKHRoaXMsIHYsIG51bGwpOwogICAgbCh0aGlzLCBTLCBudWxsKTsKICAgIGwodGhpcywgRiwgbnVsbCk7CiAgICBsKHRoaXMsIFgsIG51bGwpOwogICAgbCh0aGlzLCBMLCBudWxsKTsKICAgIGwodGhpcywgVSwgbnVsbCk7CiAgICBsKHRoaXMsIEIsIG51bGwpOwogICAgLy8gYmluYXJ5IGNvbnRlbnQgbWFzayBmb3IgdHJhbnNwYXJlbnQgY2FudmFzIHN1cHBvcnQKICAgIGwodGhpcywgQywgbnVsbCk7CiAgICAvLyBvcHRpb25hbCBiYWNrZ3JvdW5kIGltYWdlIChmcm9tIGJhY2tncm91bmRTcmMgcHJvcCkKICAgIGwodGhpcywgaiwgImNvdmVyIik7CiAgICBsKHRoaXMsIEcsIHZvaWQgMCk7CiAgICBsKHRoaXMsIHgsIHsgeDogMCwgeTogMCwgZHg6IDAsIGR5OiAwLCB0YXJnZXRYOiAwLCB0YXJnZXRZOiAwLCBtb3ZlZDogITEgfSk7CiAgICAvLyBTdG9yZXMgc291cmNlIHNvIHRleHR1cmVzIGNhbiBiZSByZWJ1aWx0IG9uIHJlc2l6ZQogICAgbCh0aGlzLCBfLCBudWxsKTsKICAgIGwodGhpcywgQSwgbnVsbCk7CiAgICBsKHRoaXMsIHosICExKTsKICAgIGwodGhpcywgZWUsICExKTsKICAgIGEodGhpcywgViwgZSksIGEodGhpcywgRywgX2UocikpOwogICAgY29uc3QgeyBnbDogbywgZXh0OiBzIH0gPSBQZShlKTsKICAgIGEodGhpcywgYiwgbyksIGEodGhpcywgWiwgcyksIGEodGhpcywgVywgT2UobykpLCBhKHRoaXMsIEgsIGtlKG8pKSwgby5jbGVhckNvbG9yKDAsIDAsIDAsIDApOwogIH0KICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAvLyBQdWJsaWMgQVBJCiAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgc2V0VGV4dFNvdXJjZShlKSB7CiAgICBhKHRoaXMsIF8sIHsgdHlwZTogInRleHQiLCBvcHRzOiBlIH0pLCBkKHRoaXMsIE4sIEspLmNhbGwodGhpcyksIGQodGhpcywgTSwgcSkuY2FsbCh0aGlzKSwgZCh0aGlzLCAkLCBKKS5jYWxsKHRoaXMpOwogIH0KICBhc3luYyBzZXRJbWFnZVNvdXJjZShlLCByID0gMCwgbyA9ICJjb3ZlciIpIHsKICAgIGNvbnN0IHMgPSBhd2FpdCBWZShlKTsKICAgIGlmICh0KHRoaXMsIGVlKSkgewogICAgICBzLmNsb3NlKCk7CiAgICAgIHJldHVybjsKICAgIH0KICAgIGEodGhpcywgXywgeyB0eXBlOiAiaW1hZ2UiLCBiaXRtYXA6IHMsIGVmZmVjdDogciwgc2l6ZTogbyB9KSwgZCh0aGlzLCBOLCBLKS5jYWxsKHRoaXMpLCBkKHRoaXMsIE0sIHEpLmNhbGwodGhpcyksIGQodGhpcywgJCwgSikuY2FsbCh0aGlzKTsKICB9CiAgc2V0SW1hZ2VCaXRtYXAoZSwgciA9IDAsIG8gPSAiY292ZXIiKSB7CiAgICBhKHRoaXMsIF8sIHsgdHlwZTogImltYWdlIiwgYml0bWFwOiBlLCBlZmZlY3Q6IHIsIHNpemU6IG8gfSksIGQodGhpcywgTiwgSykuY2FsbCh0aGlzKSwgZCh0aGlzLCBNLCBxKS5jYWxsKHRoaXMpLCBkKHRoaXMsICQsIEopLmNhbGwodGhpcyk7CiAgfQogIHNldEJhY2tncm91bmQoZSwgciA9ICJjb3ZlciIpIHsKICAgIHQodGhpcywgQykgJiYgdCh0aGlzLCBDKSAhPT0gZSAmJiB0KHRoaXMsIEMpLmNsb3NlKCksIGEodGhpcywgQywgZSksIGEodGhpcywgaiwgciA/PyAiY292ZXIiKSwgdCh0aGlzLCBfKSAmJiB0KHRoaXMsIHApID4gMCAmJiBkKHRoaXMsIE0sIHEpLmNhbGwodGhpcyk7CiAgfQogIGhhbmRsZU1vdmUoZSwgciwgbyA9IDEpIHsKICAgIHQodGhpcywgeCkubW92ZWQgPSAhMCwgdCh0aGlzLCB4KS5keCA9IChlIC0gdCh0aGlzLCB4KS50YXJnZXRYKSAqIG8sIHQodGhpcywgeCkuZHkgPSAociAtIHQodGhpcywgeCkudGFyZ2V0WSkgKiBvLCB0KHRoaXMsIHgpLnRhcmdldFggPSBlLCB0KHRoaXMsIHgpLnRhcmdldFkgPSByOwogIH0KICAvKioKICAgKiBJbW1lZGlhdGVseSBhcHBsaWVzIG9uZSBmbHVpZCBzcGxhdCBhdCAoeCwgeSkgd2l0aCBleHBsaWNpdCB2ZWxvY2l0eSAodngsIHZ5KS4KICAgKiBTYWZlIHRvIGNhbGwgbXVsdGlwbGUgdGltZXMgcGVyIGZyYW1lIOKAlCBlYWNoIGNhbGwgd3JpdGVzIGRpcmVjdGx5IHRvIHRoZSBGQk9zLgogICAqIERlc2lnbmVkIGZvciBwcm9ncmFtbWF0aWMgdXNlIGNhc2VzIChlLmcuIHBhcnRpY2xlIHN5c3RlbXMsIGF0dHJhY3RvciBwYXRocykKICAgKiB3aGVyZSB5b3Ugd2FudCBOIGluZGVwZW5kZW50IGluamVjdGlvbiBwb2ludHMgcGVyIGZyYW1lIHdpdGhvdXQgZmxvb2RpbmcgdGhlCiAgICogbW91c2Utc3RhdGUgbWFjaGluZSBvciB0aGUgd29ya2VyIG1lc3NhZ2UgcXVldWUuCiAgICovCiAgc3BsYXQoZSwgciwgbywgcywgbiA9IDEpIHsKICAgIGlmICghdCh0aGlzLCB6KSB8fCB0KHRoaXMsIHApID09PSAwKQogICAgICByZXR1cm47CiAgICBjb25zdCB1ID0gdCh0aGlzLCBiKSwgVCA9IHQodGhpcywgRyksIHsgc3BsYXQ6IEUgfSA9IHQodGhpcywgVyksIGMgPSB0KHRoaXMsIEgpOwogICAgdS52aWV3cG9ydCgwLCAwLCB0KHRoaXMsIGspLCB0KHRoaXMsIEkpKSwgRS5iaW5kKCksIHUudW5pZm9ybTFmKEUudW5pZm9ybXMuYXNwZWN0UmF0aW8sIHQodGhpcywgcCkgLyB0KHRoaXMsIHkpKSwgdS51bmlmb3JtMmYoRS51bmlmb3Jtcy5wb2ludCwgZSAqIHQodGhpcywgdykgLyB0KHRoaXMsIHApLCAxIC0gciAqIHQodGhpcywgdykgLyB0KHRoaXMsIHkpKSwgdS51bmlmb3JtMWYoRS51bmlmb3Jtcy5yYWRpdXMsIFQuc3BsYXRSYWRpdXMpLCB1LnVuaWZvcm0xaShFLnVuaWZvcm1zLnVUYXJnZXQsIDApLCB1LmFjdGl2ZVRleHR1cmUodS5URVhUVVJFMCksIHUuYmluZFRleHR1cmUodS5URVhUVVJFXzJELCB0KHRoaXMsIHYpLnJlYWQudGV4KSwgdS51bmlmb3JtM2YoRS51bmlmb3Jtcy5jb2xvciwgbyAqIFQuc3BsYXRGb3JjZSAqIG4sIC1zICogVC5zcGxhdEZvcmNlICogbiwgMCksIGModCh0aGlzLCB2KS53cml0ZS5mYm8pLCB0KHRoaXMsIHYpLnN3YXAoKSwgdS5hY3RpdmVUZXh0dXJlKHUuVEVYVFVSRTApLCB1LmJpbmRUZXh0dXJlKHUuVEVYVFVSRV8yRCwgdCh0aGlzLCBnKS5yZWFkLnRleCksIHUudW5pZm9ybTNmKEUudW5pZm9ybXMuY29sb3IsIG4sIG4sIG4pLCBjKHQodGhpcywgZykud3JpdGUuZmJvKSwgdCh0aGlzLCBnKS5zd2FwKCk7CiAgfQogIHJlc2l6ZShlLCByLCBvKSB7CiAgICBpZiAobyAhPT0gdm9pZCAwID8gYSh0aGlzLCB3LCBvKSA6IHR5cGVvZiB3aW5kb3cgPCAidSIgJiYgd2luZG93LmRldmljZVBpeGVsUmF0aW8gJiYgYSh0aGlzLCB3LCB3aW5kb3cuZGV2aWNlUGl4ZWxSYXRpbyksIGUgIT09IHZvaWQgMCAmJiBlID4gMCkgewogICAgICBpZiAociA9PT0gdm9pZCAwIHx8IHIgPD0gMCkKICAgICAgICByZXR1cm47CiAgICAgIGEodGhpcywgcCwgdCh0aGlzLCBWKS53aWR0aCA9IGUpLCBhKHRoaXMsIHksIHQodGhpcywgVikuaGVpZ2h0ID0gciksIGEodGhpcywgaywgZSA+PiAxKSwgYSh0aGlzLCBJLCByID4+IDEpLCBkKHRoaXMsIHRlLCBUZSkuY2FsbCh0aGlzKTsKICAgIH0gZWxzZQogICAgICBkKHRoaXMsIE4sIEspLmNhbGwodGhpcyk7CiAgICB0KHRoaXMsIF8pICYmIGQodGhpcywgTSwgcSkuY2FsbCh0aGlzKSwgZCh0aGlzLCAkLCBKKS5jYWxsKHRoaXMpOwogIH0KICB1cGRhdGVDb25maWcoZSkgewogICAgT2JqZWN0LmFzc2lnbih0KHRoaXMsIEcpLCBlKTsKICB9CiAgZGVzdHJveSgpIHsKICAgIGEodGhpcywgZWUsICEwKSwgdGhpcy5zdG9wKCk7CiAgICBjb25zdCBlID0gdCh0aGlzLCBiKTsKICAgIGQodGhpcywgcmUsIGRlKS5jYWxsKHRoaXMpLCBkKHRoaXMsIGllLCBwZSkuY2FsbCh0aGlzKSwgdCh0aGlzLCBDKSAmJiAodCh0aGlzLCBDKS5jbG9zZSgpLCBhKHRoaXMsIEMsIG51bGwpKTsKICAgIGZvciAoY29uc3QgbyBvZiBPYmplY3QudmFsdWVzKHQodGhpcywgVykpKQogICAgICBvLmRpc3Bvc2UoKTsKICAgIGNvbnN0IHIgPSBlLmdldEV4dGVuc2lvbigiV0VCR0xfbG9zZV9jb250ZXh0Iik7CiAgICByID09IG51bGwgfHwgci5sb3NlQ29udGV4dCgpOwogIH0KICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICAvLyBMb29wIGNvbnRyb2wKICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICBzdGFydCgpIHsKICAgIGlmICh0KHRoaXMsIEEpICE9PSBudWxsKQogICAgICByZXR1cm47CiAgICBjb25zdCBlID0gKCkgPT4gewogICAgICBkKHRoaXMsIG5lLCBSZSkuY2FsbCh0aGlzKSwgYSh0aGlzLCBBLCBFZShlKSk7CiAgICB9OwogICAgYSh0aGlzLCBBLCBFZShlKSk7CiAgfQogIHN0b3AoKSB7CiAgICB0KHRoaXMsIEEpICE9PSBudWxsICYmIChXZSh0KHRoaXMsIEEpKSwgYSh0aGlzLCBBLCBudWxsKSk7CiAgfQogIGdldCBpc1J1bm5pbmcoKSB7CiAgICByZXR1cm4gdCh0aGlzLCBBKSAhPT0gbnVsbDsKICB9Cn0KViA9IG5ldyBXZWFrTWFwKCksIGIgPSBuZXcgV2Vha01hcCgpLCBaID0gbmV3IFdlYWtNYXAoKSwgVyA9IG5ldyBXZWFrTWFwKCksIEggPSBuZXcgV2Vha01hcCgpLCBwID0gbmV3IFdlYWtNYXAoKSwgeSA9IG5ldyBXZWFrTWFwKCksIGsgPSBuZXcgV2Vha01hcCgpLCBJID0gbmV3IFdlYWtNYXAoKSwgdyA9IG5ldyBXZWFrTWFwKCksIGcgPSBuZXcgV2Vha01hcCgpLCB2ID0gbmV3IFdlYWtNYXAoKSwgUyA9IG5ldyBXZWFrTWFwKCksIEYgPSBuZXcgV2Vha01hcCgpLCBYID0gbmV3IFdlYWtNYXAoKSwgTCA9IG5ldyBXZWFrTWFwKCksIFUgPSBuZXcgV2Vha01hcCgpLCBCID0gbmV3IFdlYWtNYXAoKSwgQyA9IG5ldyBXZWFrTWFwKCksIGogPSBuZXcgV2Vha01hcCgpLCBHID0gbmV3IFdlYWtNYXAoKSwgeCA9IG5ldyBXZWFrTWFwKCksIF8gPSBuZXcgV2Vha01hcCgpLCBBID0gbmV3IFdlYWtNYXAoKSwgeiA9IG5ldyBXZWFrTWFwKCksIGVlID0gbmV3IFdlYWtNYXAoKSwgTiA9IG5ldyBXZWFrU2V0KCksIEsgPSBmdW5jdGlvbigpIHsKICBjb25zdCBlID0gdCh0aGlzLCBWKTsKICAiY2xpZW50V2lkdGgiIGluIGUgJiYgZS5jbGllbnRXaWR0aCA+IDAgPyAoYSh0aGlzLCB3LCB0eXBlb2Ygd2luZG93IDwgInUiICYmIHdpbmRvdy5kZXZpY2VQaXhlbFJhdGlvIHx8IDEpLCBhKHRoaXMsIHAsIGUud2lkdGggPSBNYXRoLnJvdW5kKGUuY2xpZW50V2lkdGggKiB0KHRoaXMsIHcpKSksIGEodGhpcywgeSwgZS5oZWlnaHQgPSBNYXRoLnJvdW5kKGUuY2xpZW50SGVpZ2h0ICogdCh0aGlzLCB3KSkpKSA6IChhKHRoaXMsIHAsIGUud2lkdGgpLCBhKHRoaXMsIHksIGUuaGVpZ2h0KSksICEodCh0aGlzLCBwKSA9PT0gMCB8fCB0KHRoaXMsIHkpID09PSAwKSAmJiAoYSh0aGlzLCBrLCB0KHRoaXMsIHApID4+IDEpLCBhKHRoaXMsIEksIHQodGhpcywgeSkgPj4gMSksIGQodGhpcywgdGUsIFRlKS5jYWxsKHRoaXMpKTsKfSwgdGUgPSBuZXcgV2Vha1NldCgpLCBUZSA9IGZ1bmN0aW9uKCkgewogIGNvbnN0IGUgPSB0KHRoaXMsIGIpLCByID0gdCh0aGlzLCBaKSwgbyA9IHQodGhpcywgayksIHMgPSB0KHRoaXMsIEkpOwogIGQodGhpcywgcmUsIGRlKS5jYWxsKHRoaXMpLCBhKHRoaXMsIGcsIG1lKGUsIHIsIG8sIHMpKSwgYSh0aGlzLCB2LCBtZShlLCByLCBvLCBzKSksIGEodGhpcywgRiwgbWUoZSwgciwgbywgcykpLCBhKHRoaXMsIFMsIGFlKGUsIHIsIG8sIHMpKSwgYSh0aGlzLCBYLCBhZShlLCByLCBvLCBzKSk7Cn0sIE0gPSBuZXcgV2Vha1NldCgpLCBxID0gZnVuY3Rpb24oKSB7CiAgaWYgKCEoIXQodGhpcywgXykgfHwgdCh0aGlzLCBwKSA9PT0gMCkpIHsKICAgIGlmIChkKHRoaXMsIGllLCBwZSkuY2FsbCh0aGlzKSwgdCh0aGlzLCBfKS50eXBlID09PSAidGV4dCIpIHsKICAgICAgY29uc3QgeyBiYWNrZ3JvdW5kVGV4OiBlLCBvYnN0YWNsZVRleDogciwgY292ZXJhZ2VUZXg6IG8gfSA9IEllKAogICAgICAgIHQodGhpcywgYiksCiAgICAgICAgdCh0aGlzLCBwKSwKICAgICAgICB0KHRoaXMsIHkpLAogICAgICAgIHQodGhpcywgXykub3B0cywKICAgICAgICB0KHRoaXMsIEMpLAogICAgICAgIHQodGhpcywgaikKICAgICAgKTsKICAgICAgYSh0aGlzLCBMLCBlKSwgYSh0aGlzLCBVLCByKSwgYSh0aGlzLCBCLCBvKTsKICAgIH0gZWxzZSB7CiAgICAgIGNvbnN0IHsgYmFja2dyb3VuZFRleDogZSwgb2JzdGFjbGVUZXg6IHIsIGNvdmVyYWdlVGV4OiBvIH0gPSBNZSgKICAgICAgICB0KHRoaXMsIGIpLAogICAgICAgIHQodGhpcywgXykuYml0bWFwLAogICAgICAgIHQodGhpcywgcCksCiAgICAgICAgdCh0aGlzLCB5KSwKICAgICAgICB0KHRoaXMsIF8pLmVmZmVjdCwKICAgICAgICB0KHRoaXMsIF8pLnNpemUsCiAgICAgICAgdCh0aGlzLCBDKSwKICAgICAgICB0KHRoaXMsIGopCiAgICAgICk7CiAgICAgIGEodGhpcywgTCwgZSksIGEodGhpcywgVSwgciksIGEodGhpcywgQiwgbyk7CiAgICB9CiAgICBhKHRoaXMsIHosICEwKTsKICB9Cn0sICQgPSBuZXcgV2Vha1NldCgpLCBKID0gZnVuY3Rpb24oKSB7CiAgdCh0aGlzLCB6KSAmJiAhdGhpcy5pc1J1bm5pbmcgJiYgdGhpcy5zdGFydCgpOwp9LCByZSA9IG5ldyBXZWFrU2V0KCksIGRlID0gZnVuY3Rpb24oKSB7CiAgdmFyIGUsIHIsIG87CiAgKGUgPSB0KHRoaXMsIGcpKSA9PSBudWxsIHx8IGUuZGlzcG9zZSgpLCAociA9IHQodGhpcywgdikpID09IG51bGwgfHwgci5kaXNwb3NlKCksIChvID0gdCh0aGlzLCBGKSkgPT0gbnVsbCB8fCBvLmRpc3Bvc2UoKSwgdCh0aGlzLCBTKSAmJiAodCh0aGlzLCBiKS5kZWxldGVUZXh0dXJlKHQodGhpcywgUykudGV4KSwgdCh0aGlzLCBiKS5kZWxldGVGcmFtZWJ1ZmZlcih0KHRoaXMsIFMpLmZibykpLCB0KHRoaXMsIFgpICYmICh0KHRoaXMsIGIpLmRlbGV0ZVRleHR1cmUodCh0aGlzLCBYKS50ZXgpLCB0KHRoaXMsIGIpLmRlbGV0ZUZyYW1lYnVmZmVyKHQodGhpcywgWCkuZmJvKSksIGEodGhpcywgZywgYSh0aGlzLCB2LCBhKHRoaXMsIEYsIGEodGhpcywgUywgYSh0aGlzLCBYLCBudWxsKSkpKSk7Cn0sIGllID0gbmV3IFdlYWtTZXQoKSwgcGUgPSBmdW5jdGlvbigpIHsKICB0KHRoaXMsIEwpICYmIHQodGhpcywgYikuZGVsZXRlVGV4dHVyZSh0KHRoaXMsIEwpKSwgdCh0aGlzLCBVKSAmJiB0KHRoaXMsIGIpLmRlbGV0ZVRleHR1cmUodCh0aGlzLCBVKSksIHQodGhpcywgQikgJiYgdCh0aGlzLCBCKSAhPT0gdCh0aGlzLCBVKSAmJiB0KHRoaXMsIGIpLmRlbGV0ZVRleHR1cmUodCh0aGlzLCBCKSksIGEodGhpcywgTCwgYSh0aGlzLCBVLCBhKHRoaXMsIEIsIG51bGwpKSk7Cn0sIG5lID0gbmV3IFdlYWtTZXQoKSwgUmUgPSBmdW5jdGlvbigpIHsKICBpZiAoIXQodGhpcywgeikgfHwgdCh0aGlzLCBwKSA9PT0gMCB8fCAhdCh0aGlzLCBnKSB8fCAhdCh0aGlzLCB2KSkKICAgIHJldHVybjsKICBjb25zdCBlID0gdCh0aGlzLCBiKSwgciA9IHQodGhpcywgRyksIHsgYWR2ZWN0aW9uOiBvLCBkaXZlcmdlbmNlOiBzLCBwcmVzc3VyZTogbiwgZ3JhZGllbnRTdWJ0cmFjdDogdSwgc3BsYXQ6IFQsIGN1cmw6IEUsIHZvcnRpY2l0eTogYywgZGlzcGxheTogaCB9ID0gdCh0aGlzLCBXKTsKICB0KHRoaXMsIHgpLnggKz0gKHQodGhpcywgeCkudGFyZ2V0WCAtIHQodGhpcywgeCkueCkgKiAwLjE1LCB0KHRoaXMsIHgpLnkgKz0gKHQodGhpcywgeCkudGFyZ2V0WSAtIHQodGhpcywgeCkueSkgKiAwLjE1OwogIGNvbnN0IFIgPSB0KHRoaXMsIGspLCBmID0gdCh0aGlzLCBJKSwgRCA9IHQodGhpcywgSCk7CiAgZS52aWV3cG9ydCgwLCAwLCBSLCBmKSwgby5iaW5kKCksIGUudW5pZm9ybTJmKG8udW5pZm9ybXMudGV4ZWxTaXplLCAxIC8gUiwgMSAvIGYpLCBlLnVuaWZvcm0xZihvLnVuaWZvcm1zLmR0LCBiZSksIGUudW5pZm9ybTFpKG8udW5pZm9ybXMudU9ic3RhY2xlLCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBVKSksIGUudW5pZm9ybTFmKG8udW5pZm9ybXMuZGlzc2lwYXRpb24sIHIudmVsb2NpdHlEaXNzaXBhdGlvbiksIGUudW5pZm9ybTFpKG8udW5pZm9ybXMudVZlbG9jaXR5LCAxKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTEpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCB2KS5yZWFkLnRleCksIGUudW5pZm9ybTFpKG8udW5pZm9ybXMudVNvdXJjZSwgMSksIEQodCh0aGlzLCB2KS53cml0ZS5mYm8pLCB0KHRoaXMsIHYpLnN3YXAoKSwgZS51bmlmb3JtMWYoby51bmlmb3Jtcy5kaXNzaXBhdGlvbiwgci5kZW5zaXR5RGlzc2lwYXRpb24pLCBlLnVuaWZvcm0xaShvLnVuaWZvcm1zLnVTb3VyY2UsIDIpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMiksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIGcpLnJlYWQudGV4KSwgRCh0KHRoaXMsIGcpLndyaXRlLmZibyksIHQodGhpcywgZykuc3dhcCgpLCBFLmJpbmQoKSwgZS51bmlmb3JtMmYoRS51bmlmb3Jtcy50ZXhlbFNpemUsIDEgLyBSLCAxIC8gZiksIGUudW5pZm9ybTFpKEUudW5pZm9ybXMudVZlbG9jaXR5LCAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCB2KS5yZWFkLnRleCksIEQodCh0aGlzLCBYKS5mYm8pLCBjLmJpbmQoKSwgZS51bmlmb3JtMmYoYy51bmlmb3Jtcy50ZXhlbFNpemUsIDEgLyBSLCAxIC8gZiksIGUudW5pZm9ybTFmKGMudW5pZm9ybXMuY3VybCwgci5jdXJsKSwgZS51bmlmb3JtMWYoYy51bmlmb3Jtcy5kdCwgYmUpLCBlLnVuaWZvcm0xaShjLnVuaWZvcm1zLnVWZWxvY2l0eSwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgdikucmVhZC50ZXgpLCBlLnVuaWZvcm0xaShjLnVuaWZvcm1zLnVDdXJsLCAxKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTEpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBYKS50ZXgpLCBEKHQodGhpcywgdikud3JpdGUuZmJvKSwgdCh0aGlzLCB2KS5zd2FwKCksIHQodGhpcywgeCkubW92ZWQgJiYgKFQuYmluZCgpLCBlLnVuaWZvcm0xZihULnVuaWZvcm1zLmFzcGVjdFJhdGlvLCB0KHRoaXMsIHApIC8gdCh0aGlzLCB5KSksIGUudW5pZm9ybTJmKFQudW5pZm9ybXMucG9pbnQsIHQodGhpcywgeCkueCAqIHQodGhpcywgdykgLyB0KHRoaXMsIHApLCAxIC0gdCh0aGlzLCB4KS55ICogdCh0aGlzLCB3KSAvIHQodGhpcywgeSkpLCBlLnVuaWZvcm0xZihULnVuaWZvcm1zLnJhZGl1cywgci5zcGxhdFJhZGl1cyksIGUudW5pZm9ybTFpKFQudW5pZm9ybXMudVRhcmdldCwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgdikucmVhZC50ZXgpLCBlLnVuaWZvcm0zZihULnVuaWZvcm1zLmNvbG9yLCB0KHRoaXMsIHgpLmR4ICogci5zcGxhdEZvcmNlLCAtdCh0aGlzLCB4KS5keSAqIHIuc3BsYXRGb3JjZSwgMCksIEQodCh0aGlzLCB2KS53cml0ZS5mYm8pLCB0KHRoaXMsIHYpLnN3YXAoKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBnKS5yZWFkLnRleCksIGUudW5pZm9ybTNmKFQudW5pZm9ybXMuY29sb3IsIDEsIDEsIDEpLCBEKHQodGhpcywgZykud3JpdGUuZmJvKSwgdCh0aGlzLCBnKS5zd2FwKCksIHQodGhpcywgeCkubW92ZWQgPSAhMSksIHMuYmluZCgpLCBlLnVuaWZvcm0yZihzLnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIFIsIDEgLyBmKSwgZS51bmlmb3JtMWkocy51bmlmb3Jtcy51VmVsb2NpdHksIDApLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMCksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIHYpLnJlYWQudGV4KSwgZS51bmlmb3JtMWkocy51bmlmb3Jtcy51T2JzdGFjbGUsIDEpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMSksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFUpKSwgRCh0KHRoaXMsIFMpLmZibyksIG4uYmluZCgpLCBlLnVuaWZvcm0yZihuLnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIFIsIDEgLyBmKSwgZS51bmlmb3JtMWkobi51bmlmb3Jtcy51RGl2ZXJnZW5jZSwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgUykudGV4KSwgZS51bmlmb3JtMWkobi51bmlmb3Jtcy51T2JzdGFjbGUsIDEpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMSksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIFUpKTsKICBmb3IgKGxldCBZID0gMDsgWSA8IHIucHJlc3N1cmVJdGVyYXRpb25zOyBZKyspCiAgICBlLnVuaWZvcm0xaShuLnVuaWZvcm1zLnVQcmVzc3VyZSwgMiksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUyKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgRikucmVhZC50ZXgpLCBEKHQodGhpcywgRikud3JpdGUuZmJvKSwgdCh0aGlzLCBGKS5zd2FwKCk7CiAgdS5iaW5kKCksIGUudW5pZm9ybTJmKHUudW5pZm9ybXMudGV4ZWxTaXplLCAxIC8gUiwgMSAvIGYpLCBlLnVuaWZvcm0xaSh1LnVuaWZvcm1zLnVQcmVzc3VyZSwgMCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUwKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgRikucmVhZC50ZXgpLCBlLnVuaWZvcm0xaSh1LnVuaWZvcm1zLnVWZWxvY2l0eSwgMSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUxKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgdikucmVhZC50ZXgpLCBlLnVuaWZvcm0xaSh1LnVuaWZvcm1zLnVPYnN0YWNsZSwgMiksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUyKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgVSkpLCBEKHQodGhpcywgdikud3JpdGUuZmJvKSwgdCh0aGlzLCB2KS5zd2FwKCksIGUudmlld3BvcnQoMCwgMCwgdCh0aGlzLCBwKSwgdCh0aGlzLCB5KSksIGUuYmluZEZyYW1lYnVmZmVyKGUuRlJBTUVCVUZGRVIsIG51bGwpLCBlLmNsZWFyKGUuQ09MT1JfQlVGRkVSX0JJVCksIGguYmluZCgpLCBlLnVuaWZvcm0yZihoLnVuaWZvcm1zLnRleGVsU2l6ZSwgMSAvIHQodGhpcywgcCksIDEgLyB0KHRoaXMsIHkpKSwgZS51bmlmb3JtM2Z2KGgudW5pZm9ybXMudVdhdGVyQ29sb3IsIHIud2F0ZXJDb2xvciksIGUudW5pZm9ybTNmdihoLnVuaWZvcm1zLnVHbG93Q29sb3IsIHIuZ2xvd0NvbG9yKSwgZS51bmlmb3JtMWYoaC51bmlmb3Jtcy51UmVmcmFjdGlvbiwgci5yZWZyYWN0aW9uKSwgZS51bmlmb3JtMWYoaC51bmlmb3Jtcy51U3BlY3VsYXJFeHAsIHIuc3BlY3VsYXJFeHApLCBlLnVuaWZvcm0xZihoLnVuaWZvcm1zLnVTaGluZSwgci5zaGluZSksIGUudW5pZm9ybTFmKGgudW5pZm9ybXMudVdhcnBTdHJlbmd0aCwgci53YXJwU3RyZW5ndGggPz8gMC4wMTUpLCBlLnVuaWZvcm0xaShoLnVuaWZvcm1zLnVBbGdvcml0aG0sIEdlW3IuYWxnb3JpdGhtXSA/PyAwKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTApLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBnKS5yZWFkLnRleCksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkUxKSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgVSkpLCBlLmFjdGl2ZVRleHR1cmUoZS5URVhUVVJFMiksIGUuYmluZFRleHR1cmUoZS5URVhUVVJFXzJELCB0KHRoaXMsIEwpKSwgZS5hY3RpdmVUZXh0dXJlKGUuVEVYVFVSRTMpLCBlLmJpbmRUZXh0dXJlKGUuVEVYVFVSRV8yRCwgdCh0aGlzLCBCKSksIGUuYWN0aXZlVGV4dHVyZShlLlRFWFRVUkU0KSwgZS5iaW5kVGV4dHVyZShlLlRFWFRVUkVfMkQsIHQodGhpcywgdikucmVhZC50ZXgpLCBlLnVuaWZvcm0xaShoLnVuaWZvcm1zLnVUZXh0dXJlLCAwKSwgZS51bmlmb3JtMWkoaC51bmlmb3Jtcy51T2JzdGFjbGUsIDEpLCBlLnVuaWZvcm0xaShoLnVuaWZvcm1zLnVCYWNrZ3JvdW5kLCAyKSwgZS51bmlmb3JtMWkoaC51bmlmb3Jtcy51Q292ZXJhZ2UsIDMpLCBlLnVuaWZvcm0xaShoLnVuaWZvcm1zLnVWZWxvY2l0eSwgNCksIEQobnVsbCk7Cn07CmxldCBtID0gbnVsbDsKc2VsZi5vbm1lc3NhZ2UgPSBhc3luYyAoaSkgPT4gewogIGNvbnN0IHsgdHlwZTogZSwgLi4uciB9ID0gaS5kYXRhOwogIHRyeSB7CiAgICBzd2l0Y2ggKGUpIHsKICAgICAgY2FzZSAiaW5pdCI6IHsKICAgICAgICBjb25zdCB7IGNhbnZhczogbywgd2lkdGg6IHMsIGhlaWdodDogbiwgY29uZmlnOiB1LCBkcHI6IFQgfSA9IHI7CiAgICAgICAgby53aWR0aCA9IHMsIG8uaGVpZ2h0ID0gbiwgbSA9IG5ldyB6ZShvLCB1KSwgbS5yZXNpemUocywgbiwgVCB8fCAxKSwgc2VsZi5wb3N0TWVzc2FnZSh7IHR5cGU6ICJyZWFkeSIgfSk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAic2V0VGV4dFNvdXJjZSI6IHsKICAgICAgICBpZiAoIW0pCiAgICAgICAgICByZXR1cm47CiAgICAgICAgbS5zZXRUZXh0U291cmNlKHIub3B0cyk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAic2V0SW1hZ2VTb3VyY2UiOiB7CiAgICAgICAgaWYgKCFtKQogICAgICAgICAgcmV0dXJuOwogICAgICAgIGF3YWl0IG0uc2V0SW1hZ2VTb3VyY2UoCiAgICAgICAgICByLnNyYywKICAgICAgICAgIHIuZWZmZWN0LAogICAgICAgICAgci5zaXplCiAgICAgICAgKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJzZXRJbWFnZUJpdG1hcCI6IHsKICAgICAgICBpZiAoIW0pCiAgICAgICAgICByZXR1cm47CiAgICAgICAgbS5zZXRJbWFnZUJpdG1hcCgKICAgICAgICAgIHIuYml0bWFwLAogICAgICAgICAgci5lZmZlY3QsCiAgICAgICAgICByLnNpemUKICAgICAgICApOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgInNldEJhY2tncm91bmQiOiB7CiAgICAgICAgaWYgKCFtKQogICAgICAgICAgcmV0dXJuOwogICAgICAgIG0uc2V0QmFja2dyb3VuZChyLmJpdG1hcCwgci5zaXplKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJzcGxhdCI6IHsKICAgICAgICBpZiAoIW0pCiAgICAgICAgICByZXR1cm47CiAgICAgICAgbS5zcGxhdCgKICAgICAgICAgIHIueCwKICAgICAgICAgIHIueSwKICAgICAgICAgIHIudngsCiAgICAgICAgICByLnZ5LAogICAgICAgICAgci5zdHJlbmd0aCA/PyAxCiAgICAgICAgKTsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBjYXNlICJtb3ZlIjogewogICAgICAgIGlmICghbSkKICAgICAgICAgIHJldHVybjsKICAgICAgICBtLmhhbmRsZU1vdmUoci54LCByLnksIHIuc3RyZW5ndGggPz8gMSk7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KICAgICAgY2FzZSAicmVzaXplIjogewogICAgICAgIGlmICghbSkKICAgICAgICAgIHJldHVybjsKICAgICAgICBtLnJlc2l6ZShyLndpZHRoLCByLmhlaWdodCwgci5kcHIpOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgInVwZGF0ZUNvbmZpZyI6IHsKICAgICAgICBpZiAoIW0pCiAgICAgICAgICByZXR1cm47CiAgICAgICAgbS51cGRhdGVDb25maWcoci5jb25maWcpOwogICAgICAgIGJyZWFrOwogICAgICB9CiAgICAgIGNhc2UgImRlc3Ryb3kiOiB7CiAgICAgICAgbSA9PSBudWxsIHx8IG0uZGVzdHJveSgpLCBtID0gbnVsbDsKICAgICAgICBicmVhazsKICAgICAgfQogICAgICBkZWZhdWx0OgogICAgICAgIGNvbnNvbGUud2FybigiW2ZsdWlkaXR5LWpzIHdvcmtlcl0gVW5rbm93biBtZXNzYWdlIHR5cGU6IiwgZSk7CiAgICB9CiAgfSBjYXRjaCAobykgewogICAgc2VsZi5wb3N0TWVzc2FnZSh7IHR5cGU6ICJlcnJvciIsIG1lc3NhZ2U6IChvID09IG51bGwgPyB2b2lkIDAgOiBvLm1lc3NhZ2UpID8/IFN0cmluZyhvKSB9KTsKICB9Cn07Cg==", FI = typeof window < "u" && window.Blob && new Blob([atob(zI)], { type: "text/javascript;charset=utf-8" });
|
|
674
|
+
function ng() {
|
|
675
|
+
let C;
|
|
676
|
+
try {
|
|
677
|
+
if (C = FI && (window.URL || window.webkitURL).createObjectURL(FI), !C)
|
|
678
|
+
throw "";
|
|
679
|
+
return new Worker(C);
|
|
680
|
+
} catch {
|
|
681
|
+
return new Worker("data:application/javascript;base64," + zI, { type: "module" });
|
|
682
|
+
} finally {
|
|
683
|
+
C && (window.URL || window.webkitURL).revokeObjectURL(C);
|
|
684
|
+
}
|
|
685
|
+
}
|
|
686
|
+
const rg = typeof Worker < "u" && typeof OffscreenCanvas < "u";
|
|
687
|
+
var p, k, aI, wI, yI, QI;
|
|
688
|
+
class ug {
|
|
689
|
+
constructor(I, { isWorkerEnabled: i = !0, config: e = {} } = {}) {
|
|
690
|
+
// ---------------------------------------------------------------------------
|
|
691
|
+
// Private
|
|
692
|
+
// ---------------------------------------------------------------------------
|
|
693
|
+
n(this, yI);
|
|
694
|
+
n(this, p, null);
|
|
695
|
+
n(this, k, null);
|
|
696
|
+
n(this, aI, void 0);
|
|
697
|
+
n(this, wI, void 0);
|
|
698
|
+
o(this, wI, I), o(this, aI, i && rg), g(this, aI) ? b(this, yI, QI).call(this, I, e) : o(this, k, new fI(I, e));
|
|
699
|
+
}
|
|
700
|
+
// ---------------------------------------------------------------------------
|
|
701
|
+
// Source setters
|
|
702
|
+
// ---------------------------------------------------------------------------
|
|
703
|
+
setTextSource(I) {
|
|
704
|
+
g(this, p) ? g(this, p).postMessage({ type: "setTextSource", opts: I }) : g(this, k).setTextSource(I);
|
|
705
|
+
}
|
|
706
|
+
setImageSource(I, i = q.effect, e = q.imageSize) {
|
|
707
|
+
if (g(this, p)) {
|
|
708
|
+
const l = new URL(I, location.href).href;
|
|
709
|
+
g(this, p).postMessage({ type: "setImageSource", src: l, effect: i, size: e });
|
|
710
|
+
} else
|
|
711
|
+
g(this, k).setImageSource(I, i, e);
|
|
712
|
+
}
|
|
713
|
+
setBackground(I, i = "cover") {
|
|
714
|
+
var e;
|
|
715
|
+
if (g(this, p)) {
|
|
716
|
+
const l = I ? [I] : [];
|
|
717
|
+
g(this, p).postMessage({ type: "setBackground", bitmap: I ?? null, size: i }, l);
|
|
718
|
+
} else
|
|
719
|
+
(e = g(this, k)) == null || e.setBackground(I ?? null, i);
|
|
720
|
+
}
|
|
721
|
+
// ---------------------------------------------------------------------------
|
|
722
|
+
// Interaction
|
|
723
|
+
// ---------------------------------------------------------------------------
|
|
724
|
+
/**
|
|
725
|
+
* Immediately injects one splat at (x, y) with explicit velocity (vx, vy).
|
|
726
|
+
* Safe to call multiple times per frame. See FluidSimulation.splat for details.
|
|
727
|
+
*/
|
|
728
|
+
splat(I, i, e, l, s = 1) {
|
|
729
|
+
g(this, p) ? g(this, p).postMessage({ type: "splat", x: I, y: i, vx: e, vy: l, strength: s }) : g(this, k).splat(I, i, e, l, s);
|
|
730
|
+
}
|
|
731
|
+
handleMove(I, i, e = 1) {
|
|
732
|
+
g(this, p) ? g(this, p).postMessage({ type: "move", x: I, y: i, strength: e }) : g(this, k).handleMove(I, i, e);
|
|
733
|
+
}
|
|
734
|
+
// ---------------------------------------------------------------------------
|
|
735
|
+
// Config + control
|
|
736
|
+
// ---------------------------------------------------------------------------
|
|
737
|
+
updateConfig(I) {
|
|
738
|
+
g(this, p) ? g(this, p).postMessage({ type: "updateConfig", config: I }) : g(this, k).updateConfig(I);
|
|
739
|
+
}
|
|
740
|
+
resize(I, i) {
|
|
741
|
+
if (g(this, p)) {
|
|
742
|
+
const e = typeof window < "u" && window.devicePixelRatio || 1;
|
|
743
|
+
g(this, p).postMessage({ type: "resize", width: I, height: i, dpr: e });
|
|
744
|
+
} else
|
|
745
|
+
g(this, k).resize(I, i);
|
|
746
|
+
}
|
|
747
|
+
destroy() {
|
|
748
|
+
var I;
|
|
749
|
+
if (g(this, p)) {
|
|
750
|
+
const i = g(this, p);
|
|
751
|
+
o(this, p, null), i.postMessage({ type: "destroy" }), setTimeout(() => i.terminate(), 50);
|
|
752
|
+
} else
|
|
753
|
+
(I = g(this, k)) == null || I.destroy(), o(this, k, null);
|
|
754
|
+
}
|
|
755
|
+
}
|
|
756
|
+
p = new WeakMap(), k = new WeakMap(), aI = new WeakMap(), wI = new WeakMap(), yI = new WeakSet(), QI = function(I, i) {
|
|
757
|
+
const e = typeof window < "u" && window.devicePixelRatio || 1, l = Math.round(I.clientWidth * e), s = Math.round(I.clientHeight * e);
|
|
758
|
+
I.width = l, I.height = s;
|
|
759
|
+
let t;
|
|
760
|
+
try {
|
|
761
|
+
t = I.transferControlToOffscreen();
|
|
762
|
+
} catch {
|
|
763
|
+
console.warn(
|
|
764
|
+
"[fluidity-js] OffscreenCanvas transfer failed — falling back to main-thread mode. This is expected in React StrictMode development."
|
|
765
|
+
), o(this, aI, !1), o(this, k, new fI(I, i));
|
|
766
|
+
return;
|
|
767
|
+
}
|
|
768
|
+
const m = o(this, p, new ng());
|
|
769
|
+
m.onerror = (r) => {
|
|
770
|
+
console.error("[fluidity-js] Worker error:", r.message);
|
|
771
|
+
}, m.onmessage = (r) => {
|
|
772
|
+
r.data.type === "error" && console.error("[fluidity-js] Simulation error:", r.data.message);
|
|
773
|
+
}, m.postMessage({ type: "init", canvas: t, width: l, height: s, config: i, dpr: e }, [t]);
|
|
774
|
+
};
|
|
775
|
+
function OI(C, { isWorkerEnabled: I = !0, config: i = {} } = {}) {
|
|
776
|
+
const e = bI(null), l = bI({ isWorkerEnabled: I, config: i });
|
|
777
|
+
return Q(() => {
|
|
778
|
+
const s = C.current;
|
|
779
|
+
if (!s)
|
|
780
|
+
return;
|
|
781
|
+
const t = document.createElement("canvas");
|
|
782
|
+
t.style.cssText = "position:absolute;inset:0;width:100%;height:100%;display:block;", s.appendChild(t);
|
|
783
|
+
const m = window.devicePixelRatio || 1, r = s.getBoundingClientRect(), a = Math.round((r.width || s.clientWidth) * m) || 0, u = Math.round((r.height || s.clientHeight) * m) || 0;
|
|
784
|
+
a > 0 && (t.width = a, t.height = u);
|
|
785
|
+
const { isWorkerEnabled: S, config: A } = l.current, h = new ug(t, { isWorkerEnabled: S, config: A });
|
|
786
|
+
e.current = h;
|
|
787
|
+
const v = new ResizeObserver((Y) => {
|
|
788
|
+
for (const K of Y) {
|
|
789
|
+
const D = window.devicePixelRatio || 1, { inlineSize: c, blockSize: w } = K.contentBoxSize[0];
|
|
790
|
+
h.resize(Math.round(c * D), Math.round(w * D));
|
|
791
|
+
}
|
|
792
|
+
});
|
|
793
|
+
return v.observe(s), () => {
|
|
794
|
+
v.disconnect(), h.destroy(), t.remove(), e.current = null;
|
|
795
|
+
};
|
|
796
|
+
}, []), e;
|
|
797
|
+
}
|
|
798
|
+
const hg = xI(function({
|
|
799
|
+
text: I,
|
|
800
|
+
fontSize: i = j.fontSize,
|
|
801
|
+
color: e = j.color,
|
|
802
|
+
fontFamily: l = j.fontFamily,
|
|
803
|
+
fontWeight: s = j.fontWeight,
|
|
804
|
+
className: t,
|
|
805
|
+
style: m,
|
|
806
|
+
config: r,
|
|
807
|
+
preset: a,
|
|
808
|
+
algorithm: u,
|
|
809
|
+
backgroundColor: S = j.backgroundColor,
|
|
810
|
+
backgroundSrc: A,
|
|
811
|
+
backgroundSize: h = j.backgroundSize,
|
|
812
|
+
isMouseEnabled: v = j.isMouseEnabled,
|
|
813
|
+
isWorkerEnabled: Y = j.isWorkerEnabled
|
|
814
|
+
}, K) {
|
|
815
|
+
const D = bI(null), c = OI(D, {
|
|
816
|
+
isWorkerEnabled: Y,
|
|
817
|
+
config: uI({ ...r, ...u ? { algorithm: u } : {} }, a, kI)
|
|
818
|
+
});
|
|
819
|
+
MI(
|
|
820
|
+
K,
|
|
821
|
+
() => ({
|
|
822
|
+
reset() {
|
|
823
|
+
var d;
|
|
824
|
+
(d = c.current) == null || d.setTextSource({ text: I, fontSize: i, color: e, fontFamily: l, fontWeight: s });
|
|
825
|
+
},
|
|
826
|
+
move({ x: d, y: G, strength: L = 1 }) {
|
|
827
|
+
var B;
|
|
828
|
+
(B = c.current) == null || B.handleMove(d, G, L);
|
|
829
|
+
},
|
|
830
|
+
splat(d, G, L, B, T = 1) {
|
|
831
|
+
var O;
|
|
832
|
+
(O = c.current) == null || O.splat(d, G, L, B, T);
|
|
833
|
+
},
|
|
834
|
+
updateConfig(d) {
|
|
835
|
+
var G;
|
|
836
|
+
(G = c.current) == null || G.updateConfig(d);
|
|
837
|
+
}
|
|
838
|
+
}),
|
|
839
|
+
[I, i, e, l, s]
|
|
840
|
+
), Q(() => {
|
|
841
|
+
var d;
|
|
842
|
+
(d = c.current) == null || d.setTextSource({ text: I, fontSize: i, color: e, fontFamily: l, fontWeight: s });
|
|
843
|
+
}, [I, i, e, l, s]);
|
|
844
|
+
const w = JSON.stringify(r);
|
|
845
|
+
return Q(() => {
|
|
846
|
+
var d;
|
|
847
|
+
(d = c.current) == null || d.updateConfig(
|
|
848
|
+
uI({ ...r, ...u !== void 0 ? { algorithm: u } : {} }, a, kI)
|
|
849
|
+
);
|
|
850
|
+
}, [a, u, w]), Q(() => {
|
|
851
|
+
var G;
|
|
852
|
+
if (!A) {
|
|
853
|
+
(G = c.current) == null || G.setBackground(null);
|
|
854
|
+
return;
|
|
855
|
+
}
|
|
856
|
+
let d = !1;
|
|
857
|
+
return XI(A).then((L) => {
|
|
858
|
+
var B;
|
|
859
|
+
if (d) {
|
|
860
|
+
L.close();
|
|
861
|
+
return;
|
|
862
|
+
}
|
|
863
|
+
(B = c.current) == null || B.setBackground(L, h);
|
|
864
|
+
}).catch((L) => console.error("[fluidity-js] backgroundSrc load failed:", L)), () => {
|
|
865
|
+
d = !0;
|
|
866
|
+
};
|
|
867
|
+
}, [A, h]), Q(() => {
|
|
868
|
+
if (!v)
|
|
869
|
+
return;
|
|
870
|
+
const d = D.current;
|
|
871
|
+
if (!d)
|
|
872
|
+
return;
|
|
873
|
+
const G = (B) => {
|
|
874
|
+
var O;
|
|
875
|
+
const T = d.getBoundingClientRect();
|
|
876
|
+
(O = c.current) == null || O.handleMove(B.clientX - T.left, B.clientY - T.top, 2);
|
|
877
|
+
}, L = (B) => {
|
|
878
|
+
var UI;
|
|
879
|
+
B.preventDefault();
|
|
880
|
+
const T = d.getBoundingClientRect(), O = B.touches[0];
|
|
881
|
+
(UI = c.current) == null || UI.handleMove(O.clientX - T.left, O.clientY - T.top, 1);
|
|
882
|
+
};
|
|
883
|
+
return d.addEventListener("mousemove", G), d.addEventListener("touchmove", L, { passive: !1 }), () => {
|
|
884
|
+
d.removeEventListener("mousemove", G), d.removeEventListener("touchmove", L);
|
|
885
|
+
};
|
|
886
|
+
}, [v]), /* @__PURE__ */ TI(
|
|
887
|
+
"div",
|
|
888
|
+
{
|
|
889
|
+
ref: D,
|
|
890
|
+
className: t,
|
|
891
|
+
style: {
|
|
892
|
+
position: "relative",
|
|
893
|
+
display: "block",
|
|
894
|
+
width: "100%",
|
|
895
|
+
height: "100%",
|
|
896
|
+
background: S,
|
|
897
|
+
...m
|
|
898
|
+
}
|
|
899
|
+
}
|
|
900
|
+
);
|
|
901
|
+
}), Sg = xI(function({
|
|
902
|
+
src: I,
|
|
903
|
+
effect: i = q.effect,
|
|
904
|
+
imageSize: e = q.imageSize,
|
|
905
|
+
className: l,
|
|
906
|
+
style: s,
|
|
907
|
+
config: t,
|
|
908
|
+
preset: m,
|
|
909
|
+
algorithm: r,
|
|
910
|
+
backgroundColor: a = q.backgroundColor,
|
|
911
|
+
backgroundSrc: u,
|
|
912
|
+
backgroundSize: S = q.backgroundSize,
|
|
913
|
+
isMouseEnabled: A = q.isMouseEnabled,
|
|
914
|
+
isWorkerEnabled: h = q.isWorkerEnabled
|
|
915
|
+
}, v) {
|
|
916
|
+
const Y = bI(null), K = OI(Y, {
|
|
917
|
+
isWorkerEnabled: h,
|
|
918
|
+
config: uI({ ...t, ...r ? { algorithm: r } : {} }, m)
|
|
919
|
+
});
|
|
920
|
+
MI(
|
|
921
|
+
v,
|
|
922
|
+
() => ({
|
|
923
|
+
reset() {
|
|
924
|
+
var c;
|
|
925
|
+
I && ((c = K.current) == null || c.setImageSource(I, i, e));
|
|
926
|
+
},
|
|
927
|
+
move({ x: c, y: w, strength: d = 1 }) {
|
|
928
|
+
var G;
|
|
929
|
+
(G = K.current) == null || G.handleMove(c, w, d);
|
|
930
|
+
},
|
|
931
|
+
splat(c, w, d, G, L = 1) {
|
|
932
|
+
var B;
|
|
933
|
+
(B = K.current) == null || B.splat(c, w, d, G, L);
|
|
934
|
+
},
|
|
935
|
+
updateConfig(c) {
|
|
936
|
+
var w;
|
|
937
|
+
(w = K.current) == null || w.updateConfig(c);
|
|
938
|
+
}
|
|
939
|
+
}),
|
|
940
|
+
[I, i, e]
|
|
941
|
+
), Q(() => {
|
|
942
|
+
var c;
|
|
943
|
+
I && ((c = K.current) == null || c.setImageSource(I, i, e));
|
|
944
|
+
}, [I, i, e]);
|
|
945
|
+
const D = JSON.stringify(t);
|
|
946
|
+
return Q(() => {
|
|
947
|
+
var c;
|
|
948
|
+
(c = K.current) == null || c.updateConfig(
|
|
949
|
+
uI({ ...t, ...r !== void 0 ? { algorithm: r } : {} }, m)
|
|
950
|
+
);
|
|
951
|
+
}, [m, r, D]), Q(() => {
|
|
952
|
+
var w;
|
|
953
|
+
if (!u) {
|
|
954
|
+
(w = K.current) == null || w.setBackground(null);
|
|
955
|
+
return;
|
|
956
|
+
}
|
|
957
|
+
let c = !1;
|
|
958
|
+
return XI(u).then((d) => {
|
|
959
|
+
var G;
|
|
960
|
+
if (c) {
|
|
961
|
+
d.close();
|
|
962
|
+
return;
|
|
963
|
+
}
|
|
964
|
+
(G = K.current) == null || G.setBackground(d, S);
|
|
965
|
+
}).catch((d) => console.error("[fluidity-js] backgroundSrc load failed:", d)), () => {
|
|
966
|
+
c = !0;
|
|
967
|
+
};
|
|
968
|
+
}, [u, S]), Q(() => {
|
|
969
|
+
if (!A)
|
|
970
|
+
return;
|
|
971
|
+
const c = Y.current;
|
|
972
|
+
if (!c)
|
|
973
|
+
return;
|
|
974
|
+
const w = (G) => {
|
|
975
|
+
var B;
|
|
976
|
+
const L = c.getBoundingClientRect();
|
|
977
|
+
(B = K.current) == null || B.handleMove(G.clientX - L.left, G.clientY - L.top, 2);
|
|
978
|
+
}, d = (G) => {
|
|
979
|
+
var T;
|
|
980
|
+
G.preventDefault();
|
|
981
|
+
const L = c.getBoundingClientRect(), B = G.touches[0];
|
|
982
|
+
(T = K.current) == null || T.handleMove(B.clientX - L.left, B.clientY - L.top, 1);
|
|
983
|
+
};
|
|
984
|
+
return c.addEventListener("mousemove", w), c.addEventListener("touchmove", d, { passive: !1 }), () => {
|
|
985
|
+
c.removeEventListener("mousemove", w), c.removeEventListener("touchmove", d);
|
|
986
|
+
};
|
|
987
|
+
}, [A]), /* @__PURE__ */ TI(
|
|
988
|
+
"div",
|
|
989
|
+
{
|
|
990
|
+
ref: Y,
|
|
991
|
+
className: l,
|
|
992
|
+
style: {
|
|
993
|
+
position: "relative",
|
|
994
|
+
display: "block",
|
|
995
|
+
width: "100%",
|
|
996
|
+
height: "100%",
|
|
997
|
+
background: a,
|
|
998
|
+
...s
|
|
999
|
+
}
|
|
1000
|
+
}
|
|
1001
|
+
);
|
|
1002
|
+
});
|
|
1003
|
+
export {
|
|
1004
|
+
JI as DEFAULT_CONFIG,
|
|
1005
|
+
kI as DEFAULT_CONFIG_TEXT,
|
|
1006
|
+
q as DEFAULT_PROPS_IMAGE,
|
|
1007
|
+
EI as DEFAULT_PROPS_SHARED,
|
|
1008
|
+
j as DEFAULT_PROPS_TEXT,
|
|
1009
|
+
ug as FluidController,
|
|
1010
|
+
Sg as FluidImage,
|
|
1011
|
+
fI as FluidSimulation,
|
|
1012
|
+
hg as FluidText,
|
|
1013
|
+
_I as PRESETS,
|
|
1014
|
+
XI as loadImageBitmap,
|
|
1015
|
+
uI as mergeConfig,
|
|
1016
|
+
OI as useFluid
|
|
1017
|
+
};
|