@ndmspc/ndmvr-core 0.0.1

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.
@@ -0,0 +1,2728 @@
1
+ var we = Object.defineProperty;
2
+ var Rt = (n) => {
3
+ throw TypeError(n);
4
+ };
5
+ var be = (n, t, e) => t in n ? we(n, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : n[t] = e;
6
+ var m = (n, t, e) => be(n, typeof t != "symbol" ? t + "" : t, e), Kt = (n, t, e) => t.has(n) || Rt("Cannot " + e);
7
+ var w = (n, t, e) => (Kt(n, t, "read from private field"), e ? e.call(n) : t.get(n)), q = (n, t, e) => t.has(n) ? Rt("Cannot add the same private member more than once") : t instanceof WeakSet ? t.add(n) : t.set(n, e), E = (n, t, e, A) => (Kt(n, t, "write to private field"), A ? A.call(n, e) : t.set(n, e), e);
8
+ import { ReplaySubject as ft, Subject as ne, BehaviorSubject as Nt, filter as ct, concatMap as ve, from as xe, finalize as ye, EMPTY as Ce } from "rxjs";
9
+ import { openFile as Be, parse as $t, makeImage as De, create as ze, build3d as re } from "jsroot";
10
+ import { Vector3 as H, Color as X, Vector2 as oe, Raycaster as Me, BoxGeometry as xt, EdgesGeometry as _t, InstancedBufferGeometry as yt, InstancedBufferAttribute as N, LineSegments as te, ShaderMaterial as ce, Mesh as Ct, Object3D as Oe, Box3 as Bt, PlaneGeometry as ae, MeshBasicMaterial as le, DoubleSide as he, TextureLoader as He, Loader as Pe, FileLoader as Ye, ShapePath as qe, Group as ue } from "three";
11
+ class Ot {
12
+ constructor(t, e, A, s) {
13
+ this.url = t, this.ws = null, this.channel = A, e && this.connect(), this.initTime = Date.now(), this.timeout = s || 6e4, this.timeFlag = !0;
14
+ }
15
+ connect() {
16
+ return this.ws === null && (console.log("Trying to establish websocket connection on address: " + this.url), this.ws = new WebSocket(this.url)), this.ws.onerror = (t) => {
17
+ this.timeFlag || (this.initTime = Date.now(), this.timeFlag = !0), setTimeout(() => {
18
+ this.initTime + this.timeout < Date.now() || this.connect();
19
+ }, 500);
20
+ }, this.ws.onclose = (t) => {
21
+ this.disconnect(), this.timeFlag || (this.initTime = Date.now(), this.timeFlag = !0), setTimeout(() => {
22
+ this.initTime + this.timeout < Date.now() || this.connect();
23
+ }, 500);
24
+ }, this.ws.onmessage = (t) => {
25
+ this.channel.next(t.data);
26
+ }, this.ws.onopen = () => {
27
+ console.log("Websocket connection established on address: " + this.url), this.timeFlag = !1;
28
+ }, this;
29
+ }
30
+ disconnect() {
31
+ this.ws && (this.ws.close(), this.ws = null);
32
+ }
33
+ send(t) {
34
+ this.ws === null && this.connect(), this.ws.send(t);
35
+ }
36
+ subscribe(t) {
37
+ return this.channel.subscribe({
38
+ next: (A) => t(A)
39
+ });
40
+ }
41
+ unsubscribe(t) {
42
+ t.unsubscribe();
43
+ }
44
+ }
45
+ let Ht;
46
+ var et, k;
47
+ class Ie {
48
+ constructor() {
49
+ q(this, et);
50
+ q(this, k);
51
+ /**
52
+ * Function that adds ws to its map,
53
+ * takes searchParams, can obtain it by <new URL(window.location.href).searchParams>
54
+ * if not defined otherwise, client automatically connects to that websocket,
55
+ * otherwise connectWs(url) must be called.
56
+ * */
57
+ m(this, "createWsFromParams", (t) => {
58
+ const e = t.get("autoConnect") === "true", A = Number(t.get("timeout"));
59
+ t.getAll("ws").forEach((s) => {
60
+ this.createWs(s, e, A);
61
+ });
62
+ });
63
+ m(this, "createWs", (t, e, A) => {
64
+ w(this, k).has(t) && w(this, k).delete(t);
65
+ const s = new Ot(t, e, w(this, et), A);
66
+ w(this, k).set(t, s);
67
+ });
68
+ m(this, "getBrokerByUrl", (t, e) => {
69
+ let A = w(this, k).get(t);
70
+ return A || (A = new Ot(t, e, w(this, et)), w(this, k).set(t, A)), e && A.connect(), A;
71
+ });
72
+ m(this, "connectWsByUrl", (t) => {
73
+ let e = w(this, k).get(t);
74
+ return e || (e = new Ot(t, !0, w(this, et)), w(this, k).set(t, e)), e.connect(), e;
75
+ });
76
+ /**
77
+ * Function that disconnects ws,
78
+ * @param url if is defined, disconnects from that ws, if it's not disconnectAll
79
+ * */
80
+ m(this, "disconnectWsByUrl", (t) => {
81
+ t ? w(this, k).get(t).disconnect() : w(this, k).forEach((e) => {
82
+ e.disconnect();
83
+ });
84
+ });
85
+ m(this, "getSubject", () => w(this, et));
86
+ E(this, et, new ft(1)), E(this, k, /* @__PURE__ */ new Map());
87
+ }
88
+ }
89
+ et = new WeakMap(), k = new WeakMap();
90
+ const Ee = () => (Ht || (Ht = new Ie()), Ht), DA = () => {
91
+ Ee().createWsFromParams(new URL(window.location.href).searchParams);
92
+ }, zA = async (n) => {
93
+ try {
94
+ const t = await fetch(n);
95
+ if (!t.ok)
96
+ throw new Error(`Response status: ${t.status}`);
97
+ return t.json();
98
+ } catch (t) {
99
+ throw t;
100
+ }
101
+ };
102
+ let Pt;
103
+ var ht;
104
+ class Xe {
105
+ constructor() {
106
+ q(this, ht);
107
+ E(this, ht, new ne());
108
+ }
109
+ getObservable() {
110
+ return w(this, ht).asObservable();
111
+ }
112
+ next(t) {
113
+ w(this, ht).next(t);
114
+ }
115
+ }
116
+ ht = new WeakMap();
117
+ const Ge = () => (Pt || (Pt = new Xe()), Pt);
118
+ let Yt;
119
+ var st;
120
+ class Ve {
121
+ constructor() {
122
+ q(this, st);
123
+ E(this, st, new Nt({
124
+ inputDevice: "keyboard"
125
+ }));
126
+ }
127
+ getObservable() {
128
+ return w(this, st).asObservable();
129
+ }
130
+ next(t) {
131
+ let e = w(this, st).getValue();
132
+ t.inputDevice && (e.inputDevice = t.inputDevice), w(this, st).next(t);
133
+ }
134
+ }
135
+ st = new WeakMap();
136
+ const de = () => (Yt || (Yt = new Ve()), Yt);
137
+ let qt;
138
+ var it;
139
+ class Qe {
140
+ constructor() {
141
+ q(this, it);
142
+ E(this, it, new Nt({
143
+ sets: [],
144
+ selectedSet: [],
145
+ arrays: ["content"],
146
+ selectedArray: "content"
147
+ }));
148
+ }
149
+ getObservable() {
150
+ return w(this, it).asObservable();
151
+ }
152
+ getValue() {
153
+ return w(this, it).getValue();
154
+ }
155
+ next(t) {
156
+ w(this, it).next(t);
157
+ }
158
+ }
159
+ it = new WeakMap();
160
+ const tt = () => (qt || (qt = new Qe()), qt);
161
+ let It;
162
+ var nt;
163
+ class Fe {
164
+ constructor() {
165
+ q(this, nt);
166
+ E(this, nt, new ft());
167
+ }
168
+ /**
169
+ * Function that takes functions and proposes them to histogram with add flag.
170
+ * @param input can be Array of objects with appropriate flags and functions, or single object with flag and function.
171
+ * */
172
+ addFunctions(t) {
173
+ if (!t) return;
174
+ let e;
175
+ t instanceof Array ? e = t : e = Array.of(t), e.forEach((A) => {
176
+ let s = A.target.id;
177
+ s instanceof Array || (s = Array.of(s)), w(this, nt).next({
178
+ flag: "add",
179
+ target: {
180
+ entity: A.target.entity,
181
+ id: s
182
+ },
183
+ event: A.event,
184
+ function: A.function
185
+ });
186
+ });
187
+ }
188
+ /**
189
+ * Function that takes array of functions and proposes them to histogram with delete flag.
190
+ * */
191
+ removeFunctions(t) {
192
+ if (!t) return;
193
+ let e;
194
+ t instanceof Array ? e = t : e = Array.of(t), e.forEach((A) => {
195
+ console.log(A);
196
+ let s = A.target.id;
197
+ s instanceof Array || (s = Array.of(s)), w(this, nt).next({
198
+ flag: A.event ? "remove" : "removeAll",
199
+ target: {
200
+ entity: A.target.entity,
201
+ id: s
202
+ },
203
+ event: A.event,
204
+ function: A.function
205
+ });
206
+ });
207
+ }
208
+ getObservable() {
209
+ return w(this, nt).asObservable();
210
+ }
211
+ }
212
+ nt = new WeakMap();
213
+ const fe = () => (It || (It = new Fe()), It);
214
+ var Dt, zt, Mt, wt;
215
+ class Te {
216
+ constructor(t) {
217
+ q(this, Dt);
218
+ q(this, zt);
219
+ q(this, Mt);
220
+ q(this, wt);
221
+ E(this, Dt, t), E(this, zt, this.open(t));
222
+ }
223
+ static async open(t) {
224
+ return Be(t);
225
+ }
226
+ async getHistogram(t, e, A) {
227
+ if (t === 0)
228
+ return w(this, Mt).readObject("hMap");
229
+ {
230
+ let s = w(this, wt).reduce((i, o) => i * o, 1);
231
+ for (let i = 0; i <= t; i++)
232
+ s /= w(this, wt)[i];
233
+ }
234
+ }
235
+ static async parseFile(t) {
236
+ const e = await this.open(t);
237
+ await this.computeMaxInstancesPerLayer(e);
238
+ }
239
+ static async computeMaxInstancesPerLayer(t) {
240
+ if (!t) return;
241
+ const e = await t.readObject("hMap");
242
+ e.children = {};
243
+ const A = e.fXaxis.fNbins * e.fYaxis.fNbins * e.fZaxis.fNbins;
244
+ let s = [];
245
+ s.push(A);
246
+ const i = async (c, r) => {
247
+ for (const a of Object.keys(e.children))
248
+ for (let u = 0; u < c.length; u += 100) {
249
+ const d = [], g = Math.min(u + 100, c.length);
250
+ for (let p = u; p < g; p++)
251
+ d.push(r.readObject(`content/${c[p].fName}/${a}`));
252
+ console.log(`Processing batch: ${u} to ${g - 1} (${d.length} items)`), await Promise.all(d);
253
+ }
254
+ return console.log("done"), c.forEach((a) => {
255
+ }), s;
256
+ }, o = await t.readObject("content");
257
+ return (await t.readObject(`content/${o.fKeys[0].fName}`)).fKeys.forEach((c) => {
258
+ e.children[c.fName] = [];
259
+ }), console.log(e), i(o.fKeys, t), s;
260
+ }
261
+ }
262
+ Dt = new WeakMap(), zt = new WeakMap(), Mt = new WeakMap(), wt = new WeakMap();
263
+ var K;
264
+ class We {
265
+ constructor(t) {
266
+ q(this, K);
267
+ E(this, K, $t(t));
268
+ }
269
+ static async parseJson(t) {
270
+ return $t(t);
271
+ }
272
+ computeMaxInstancesPerLayer() {
273
+ if (!w(this, K)) return;
274
+ const t = w(this, K).fXaxis.fNbins * w(this, K).fYaxis.fNbins * w(this, K).fZaxis.fNbins;
275
+ let e = [];
276
+ e.push(t);
277
+ const A = (s, i = 1) => {
278
+ let o = 0;
279
+ return i >= e.length && e.push(0), Object.entries(s).forEach((l, c) => {
280
+ l[1].forEach((r) => {
281
+ r && (o = r.fXaxis.fNbins * r.fYaxis.fNbins * r.fZaxis.fNbins, o > e[i] && (e[i] = o), r.children && A(r.children, i + 1));
282
+ });
283
+ }), e;
284
+ };
285
+ return A(w(this, K).children), Promise.resolve(e);
286
+ }
287
+ }
288
+ K = new WeakMap();
289
+ function Se(n, t, e, { scale: A, padding: s, origin: i }) {
290
+ const o = n.config ?? {};
291
+ o.environment || (o.environment = {}), o.environment.histogramPads || (o.environment.histogramPads = []);
292
+ const l = o.environment.histogramPads;
293
+ let c = 1, r = t.length;
294
+ if (typeof e == "string") {
295
+ const d = e.match(/^grid(\d+)x(\d+)$/i);
296
+ d ? (c = parseInt(d[1], 10), r = parseInt(d[2], 10)) : (e === "simple" || e === "flex") && (c = 1, r = t.length);
297
+ }
298
+ c * r < t.length && (r = Math.ceil(Math.sqrt(t.length)), c = Math.ceil(t.length / r));
299
+ let a = 0, u = 0;
300
+ return t.forEach((d) => {
301
+ const g = i.x + u * (A.x + s.x) + A.x / 2, p = i.y + (c - 1 - a) * (A.y + s.y) + A.y / 2, v = i.z - A.z / 2;
302
+ l.push({
303
+ id: d,
304
+ position: { x: g, y: p, z: v },
305
+ scale: { ...A },
306
+ padding: { ...s },
307
+ origin: { ...i },
308
+ grid: {
309
+ row: a,
310
+ col: u,
311
+ rows: c,
312
+ cols: r,
313
+ disp_kind: e
314
+ }
315
+ }), u++, u >= r && (u = 0, a++);
316
+ }), n;
317
+ }
318
+ function ke(n) {
319
+ const t = {
320
+ resetHistogram: "r",
321
+ goToPreviousLayer: "z",
322
+ hideOutlines: "o"
323
+ };
324
+ n.bindings = n.bindings || {};
325
+ for (const e in t)
326
+ n.bindings.hasOwnProperty(e) || (n.bindings[e] = t[e]);
327
+ return n;
328
+ }
329
+ function Lt(n, t = null) {
330
+ const e = typeof n == "string" ? JSON.parse(n) : n;
331
+ function A(c) {
332
+ if (Array.isArray(c)) return c;
333
+ if (c && typeof c == "object" && "type" in c) {
334
+ const r = c.prefix ?? "histogram", h = c.type.match(/grid(\d+)x(\d+)x(\d+)/);
335
+ if (!h) return [c];
336
+ const a = +h[1], u = +h[2], d = +h[3], g = c.scale || { x: 1, y: 1, z: 1 }, p = c.padding || { x: 0, y: 0, z: 0 }, v = c.origin || { x: 0, y: 0, z: 0 }, f = new H(
337
+ (g.x - p.x * (a - 1)) / a,
338
+ (g.y - p.y * (u - 1)) / u,
339
+ (g.z - p.z * (d - 1)) / d
340
+ ), b = [];
341
+ let y = 1;
342
+ for (let x = 0; x < a; x++)
343
+ for (let B = 0; B < u; B++)
344
+ for (let D = 0; D < d; D++)
345
+ b.push({
346
+ id: `${r}${y++}`,
347
+ position: new H(
348
+ v.x + x * (f.x + p.x) + f.x / 2,
349
+ v.y + B * (f.y + p.y) + f.y / 2,
350
+ v.z - D * (f.z + p.z) - f.z / 2
351
+ ),
352
+ scale: f.clone()
353
+ });
354
+ return b;
355
+ }
356
+ return [c];
357
+ }
358
+ function s(c) {
359
+ const r = {};
360
+ for (const h in c) {
361
+ const a = c[h];
362
+ a && typeof a == "object" && "x" in a && "y" in a && "z" in a && Object.keys(a).length === 3 ? r[h] = new H(a.x, a.y, a.z) : typeof a == "string" && a.startsWith("0x") ? r[h] = new X(parseInt(a)) : a && typeof a == "object" && !Array.isArray(a) ? r[h] = s(a) : r[h] = a;
363
+ }
364
+ return r;
365
+ }
366
+ function i(c, r = null, h = null, a = !1) {
367
+ if (Array.isArray(c))
368
+ return a ? c : c.map((u) => i(u, r, c, !1));
369
+ if (c && typeof c == "object") {
370
+ if (r === "histogramPads")
371
+ return A(c).map((g) => s(g));
372
+ if ("x" in c && "y" in c && "z" in c && Object.keys(c).length === 3)
373
+ return new H(c.x, c.y, c.z);
374
+ const u = {};
375
+ for (const d in c) {
376
+ const g = d === "histogramPads";
377
+ u[d] = i(c[d], d, c, g);
378
+ }
379
+ return "target" in u || (u.target = { entity: "*", id: "*" }), u;
380
+ }
381
+ return typeof c == "string" && c.startsWith("0x") ? new X(parseInt(c)) : c;
382
+ }
383
+ function o(c, r) {
384
+ if (!c || Array.isArray(r) || !r || typeof r != "object" || r instanceof H || r instanceof X)
385
+ return r;
386
+ const h = { ...c };
387
+ for (const a in r) {
388
+ const u = c[a], d = r[a];
389
+ u && typeof u == "object" && !Array.isArray(u) && !(u instanceof H) && !(u instanceof X) && d && typeof d == "object" && !Array.isArray(d) && !(d instanceof H) && !(d instanceof X) ? h[a] = o(u, d) : h[a] = d;
390
+ }
391
+ return h;
392
+ }
393
+ const l = i(e);
394
+ return o(t, l);
395
+ }
396
+ let Et;
397
+ var $;
398
+ class Le {
399
+ constructor() {
400
+ q(this, $, /* @__PURE__ */ new Map());
401
+ }
402
+ // id → ReplaySubject(1)
403
+ getStream(t) {
404
+ return w(this, $).has(t) || w(this, $).set(t, new ft(1)), w(this, $).get(t).asObservable();
405
+ }
406
+ async next(t) {
407
+ if (!t.id) throw new Error("Missing id in event");
408
+ if (console.log(t), typeof t.obj == "string")
409
+ t.obj = await Te.parseFile(t.obj);
410
+ else if (typeof t.obj == "object")
411
+ t.obj = await We.parseJson(t.obj), t.opts = t.opts || {}, t.opts.config = Lt(t.opts.config);
412
+ else
413
+ throw new Error("Unsupported data type");
414
+ w(this, $).has(t.id) || w(this, $).set(t.id, new ft(1)), w(this, $).get(t.id).next(t);
415
+ }
416
+ }
417
+ $ = new WeakMap();
418
+ const MA = () => (Et || (Et = new Le()), Et);
419
+ let Xt;
420
+ var ut;
421
+ class Ne {
422
+ constructor() {
423
+ q(this, ut);
424
+ E(this, ut, new ft(1));
425
+ }
426
+ getObservable() {
427
+ return w(this, ut).asObservable();
428
+ }
429
+ next(t) {
430
+ w(this, ut).next(t);
431
+ }
432
+ }
433
+ ut = new WeakMap();
434
+ const ge = () => (Xt || (Xt = new Ne()), Xt), je = { environment: { dbClickTimeout: 200, desktopSpeed: 10, vrSpeed: 10, camera: { position: { x: 0, y: 1.7, z: 10 } }, canvas: { position: { x: 0, y: 20, z: -20 }, rotation: { x: 8, y: 0, z: 0 }, scale: { x: 6, y: 5, z: 1 } }, histogramPads: { type: "grid1x1x1", prefix: "histogram", scale: { x: 20, y: 10, z: 10 }, padding: { x: 0, y: 0, z: 0 }, origin: { x: -10, y: 0, z: -5 } } }, histogram: { padding: { default: { x: 0, y: 0, z: 0 }, layer: [], sets: { x: 0, y: 0, z: 0 } }, scale: { default: { min: 0.5, max: 1 }, layer: [] }, sets: { scale: { maximum: "relative" } }, TH1ZScale: { default: 0.8, layer: [1, 1, 1, 1], set: 0.01 }, wireframe: { display: { start: 0, end: 4 }, displaySets: !1, layer: [], color: { default: "0x00FF00", layer: ["0x000000", "0x0000FF", "0x00FF00", "0x00FFFF"], set: [] } }, color: { default: { min: "0x0000ff", max: "0xff0000" }, layer: [], set: [{ min: "0x222222", max: "0xffaa00" }, { min: "0x00ffff", max: "0xff7f00" }, { min: "0x00ff00", max: "0x800080" }, { min: "0x0000ff", max: "0xff0000" }] } }, bindings: { resetHistogram: "r", goToPreviousLayer: "z", hideOutlines: "o" } }, Ue = {
435
+ config: je
436
+ };
437
+ let Gt;
438
+ var U;
439
+ class Ze {
440
+ constructor() {
441
+ q(this, U);
442
+ E(this, U, new Nt(Lt(Ue, {})));
443
+ }
444
+ getObservable() {
445
+ return w(this, U).asObservable();
446
+ }
447
+ getValue() {
448
+ return w(this, U).getValue();
449
+ }
450
+ next(t) {
451
+ const e = Lt(t, w(this, U).getValue());
452
+ return w(this, U).next(e), e;
453
+ }
454
+ appendPads(t, e, A) {
455
+ const s = Se(w(this, U).getValue(), t, e, A);
456
+ w(this, U).next(s);
457
+ }
458
+ mergeHistogramConfig(t, e = w(this, U).value.config.histogram) {
459
+ if (t == null)
460
+ return e;
461
+ if (typeof e != "object" || e === null || typeof t != "object" || t === null)
462
+ return t;
463
+ const A = (i) => Array.isArray(i) || i instanceof X || i instanceof H || i && i.isColor === !0 || // Handle converted THREE.Color objects
464
+ i && i.isVector3 === !0;
465
+ if (A(e))
466
+ return A(t) ? t : e;
467
+ const s = { ...e };
468
+ for (const i in t)
469
+ t.hasOwnProperty(i) && t[i] !== void 0 && (A(t[i]) || A(s[i]) ? s[i] = t[i] : /* Recursively merge if both are plain objects */ typeof t[i] == "object" && t[i] !== null && typeof s[i] == "object" && s[i] !== null ? s[i] = this.mergeHistogramConfig(t[i], s[i]) : s[i] = t[i]);
470
+ return s;
471
+ }
472
+ }
473
+ U = new WeakMap();
474
+ const lt = () => (Gt || (Gt = new Ze()), Gt);
475
+ let Vt;
476
+ var rt;
477
+ class Je {
478
+ constructor() {
479
+ q(this, rt);
480
+ E(this, rt, new ft(1));
481
+ }
482
+ getObservable() {
483
+ return w(this, rt).asObservable();
484
+ }
485
+ getValue() {
486
+ return w(this, rt).getValue();
487
+ }
488
+ next(t) {
489
+ w(this, rt).next(t);
490
+ }
491
+ }
492
+ rt = new WeakMap();
493
+ const me = () => (Vt || (Vt = new Je()), Vt);
494
+ let Qt;
495
+ var At, Z;
496
+ class Re {
497
+ constructor() {
498
+ q(this, At);
499
+ q(this, Z);
500
+ E(this, At, document.createElement("a-entity")), w(this, At).id = "cameraRig", w(this, At).setAttribute("position", "0 1.6 0"), w(this, At).innerHTML = `
501
+ <a-camera id="camera" wasd-controls-custom="acceleration: 10" wasd-controls="acceleration: 50">
502
+ </a-camera>
503
+ `, E(this, Z, document.createElement("a-entity")), w(this, Z).id = "oculus-controller", w(this, Z).setAttribute("oculus-controller", ""), de().getObservable().subscribe(
504
+ this.handleStateChange.bind(this)
505
+ );
506
+ }
507
+ handleStateChange(t) {
508
+ const e = document.getElementById("cameraRig");
509
+ if (t.inputDevice === "oculus") {
510
+ if (!e || e.contains(w(this, Z))) return;
511
+ e.appendChild(w(this, Z));
512
+ } else {
513
+ if (!e || !e.contains(w(this, Z))) return;
514
+ e.removeChild(w(this, Z));
515
+ }
516
+ }
517
+ getCamera() {
518
+ return w(this, At);
519
+ }
520
+ }
521
+ At = new WeakMap(), Z = new WeakMap();
522
+ const OA = () => (Qt || (Qt = new Re()), Qt.getCamera());
523
+ let Ft;
524
+ var W, ot;
525
+ class Ke {
526
+ constructor() {
527
+ q(this, W);
528
+ q(this, ot);
529
+ /**
530
+ * Zmena vertikálnej polohy kamery.
531
+ * @param {boolean} moveUp - Ak je True, kamera vyššie ak je False kamera nižšie
532
+ * @param {number} speed - Rýchlosť zmeny pozície kamery
533
+ * @return {void}
534
+ */
535
+ m(this, "verticalMoveCamera", (t, e) => {
536
+ if (w(this, W) === null && E(this, W, document.getElementById("cameraRig")), w(this, W) !== null) {
537
+ const A = new H(), s = w(this, W).object3D.position.clone();
538
+ t ? (A.copy(s).add(new H(0, +e, 0)), w(this, W).object3D.position.lerp(A, 0.5)) : w(this, W).object3D.position.y > 1.6 && (A.copy(s).add(new H(0, -e, 0)), w(this, W).object3D.position.lerp(A, 0.5));
539
+ }
540
+ });
541
+ m(this, "horizontalMoveCameraLocal", (t, e, A) => {
542
+ if (!w(this, W) || !w(this, ot)) return;
543
+ let s = new oe(t, e), i = w(this, ot).object3D.rotation.y;
544
+ s.rotateAround(new H(0, 0), -i), s.normalize(), s.multiplyScalar(A), w(this, W).object3D.position.x += s.x, w(this, W).object3D.position.z += s.y;
545
+ });
546
+ setTimeout(() => {
547
+ E(this, W, document.getElementById("cameraRig")), E(this, ot, document.getElementById("camera"));
548
+ }, 100);
549
+ }
550
+ getCamera() {
551
+ return w(this, ot);
552
+ }
553
+ }
554
+ W = new WeakMap(), ot = new WeakMap();
555
+ const $e = () => (Ft || (Ft = new Ke()), Ft), ee = "data:image/png;base64,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AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAws/8fNABrcJixPQsAAAAASUVORK5CYII=", _e = "data:image/png;base64,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", tA = "data:image/png;base64,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";
556
+ var bt, vt, dt, _;
557
+ class HA {
558
+ constructor() {
559
+ q(this, bt);
560
+ q(this, vt);
561
+ q(this, dt);
562
+ q(this, _);
563
+ E(this, dt, $e()), setTimeout(() => {
564
+ this.setUpArrowListener(), this.setDownArrowListener();
565
+ }, 100), this.setUpArrowListener = this.setUpArrowListener.bind(this), this.startUpClick = this.startUpClick.bind(this), this.endUpClick = this.endUpClick.bind(this), this.upClickFunction = this.upClickFunction.bind(this), this.setDownArrowListener = this.setDownArrowListener.bind(this), this.startDownClick = this.startDownClick.bind(this), this.endDownClick = this.endDownClick.bind(this), this.downClickFunction = this.downClickFunction.bind(this), this.initController(), de().getObservable().subscribe((t) => {
566
+ if (t.inputDevice === "mobile")
567
+ document.getElementById("container").appendChild(this.getController());
568
+ else {
569
+ const e = document.getElementById("container");
570
+ if (!e || !e.contains(this.getController())) return;
571
+ e.removeChild(this.getController());
572
+ }
573
+ });
574
+ }
575
+ getController() {
576
+ return w(this, _);
577
+ }
578
+ upClickFunction() {
579
+ w(this, dt).verticalMoveCamera(!0, 0.15);
580
+ }
581
+ downClickFunction() {
582
+ w(this, dt).verticalMoveCamera(!1, 0.15);
583
+ }
584
+ startUpClick(t) {
585
+ t.preventDefault(), this.upClickFunction(), E(this, bt, setInterval(this.upClickFunction, 10));
586
+ }
587
+ endUpClick() {
588
+ clearInterval(w(this, bt));
589
+ }
590
+ startDownClick(t) {
591
+ t.preventDefault(), this.downClickFunction(), E(this, vt, setInterval(this.downClickFunction, 10));
592
+ }
593
+ endDownClick() {
594
+ clearInterval(w(this, vt));
595
+ }
596
+ /**
597
+ * Sets event listener for move up button.
598
+ * When user clicks/holds this button, verticalMoveCamera
599
+ * from cameraService with frequency 100ms is called to move camera up
600
+ * */
601
+ setUpArrowListener() {
602
+ const t = document.getElementById("up-arrow");
603
+ t ? (t.addEventListener("touchstart", this.startUpClick), t.addEventListener("touchend", this.endUpClick)) : setTimeout(this.setUpArrowListener, 100);
604
+ }
605
+ /**
606
+ * Sets event listener for move down button.
607
+ * When user clicks/holds this button, verticalMoveCamera
608
+ * from cameraService with frequency 100ms is called to move camera down
609
+ * */
610
+ setDownArrowListener() {
611
+ const t = document.getElementById("down-arrow");
612
+ t ? (t.addEventListener("touchstart", this.startDownClick), t.addEventListener("touchend", this.endDownClick)) : setTimeout(this.setUpArrowListener, 100);
613
+ }
614
+ clearUpArrowListener() {
615
+ const t = document.getElementById("up-arrow");
616
+ t && (t.removeEventListener("touchstart", this.startUpClick), t.removeEventListener("touchend", this.endUpClick));
617
+ }
618
+ clearDownArrowListener() {
619
+ const t = document.getElementById("down-arrow");
620
+ t && (t.removeEventListener("touchstart", this.startDownClick), t.removeEventListener("touchend", this.endDownClick));
621
+ }
622
+ initController() {
623
+ E(this, _, document.createElement("div")), w(this, _).className = "mainUI", w(this, _).id = "uiDiv", w(this, _).oncontextmenu = (t) => t.preventDefault(), w(this, _).innerHTML = `
624
+ <div class="mainUI" id="uiDiv" oncontextmenu="event.preventDefault()">
625
+ <!-- top-left-->
626
+ <div class="regionUI skyColor" style="top: 10px; left: 10px;" oncontextmenu="event.preventDefault()">
627
+ </div>
628
+
629
+ <!-- top-right-->
630
+ <div class="regionUI" style="top: 10px; right: 10px;">
631
+ </div>
632
+
633
+ <!-- bottom-left-->
634
+ <div class="regionUI" style="bottom: 50px; left: 50px; flex-direction: column;">
635
+ <div style="display: flex; flex-direction: row; margin-left: -32px;">
636
+ <div id="up-arrow" class="buttonUI" style="width: 64px; height: 64px;">
637
+ <img style="transform: rotate(0deg);" src="${ee}" alt="Up Arrow" />
638
+ </div>
639
+ <div id="down-arrow" class="buttonUI" style="width: 64px; height: 64px;">
640
+ <img style="transform: rotate(180deg);" src="${ee}" alt="Down Arrow" />
641
+ </div>
642
+ </div>
643
+ <div class="buttonUI" style="width: 128px; opacity: 0.8;">
644
+ <img src="${_e}" alt="Joystick Base" />
645
+ <div id="stick1" style="position: absolute;">
646
+ <img src="${tA}" alt="Joystick Blue" />
647
+ </div>
648
+ </div>
649
+ </div>
650
+
651
+ <!-- bottom-right-->
652
+ <div class="regionUI baseColor" style="bottom: 10px; right: 10px;">
653
+ </div>
654
+ </div>
655
+ `;
656
+ }
657
+ }
658
+ bt = new WeakMap(), vt = new WeakMap(), dt = new WeakMap(), _ = new WeakMap();
659
+ const PA = async (n) => {
660
+ let t;
661
+ n.startsWith("root://") ? t = n.replace(/^root:\/\//, "https://").replace(/\/\//g, "/") : t = n, console.log(`Fetching from URL: ${t}`);
662
+ const e = await fetch(t);
663
+ if (!e.ok)
664
+ throw new Error(`Response status: ${e.status}`);
665
+ return e.json();
666
+ };
667
+ class YA {
668
+ constructor(t, e) {
669
+ m(this, "raycaster");
670
+ m(this, "mouse");
671
+ m(this, "cameraElement");
672
+ m(this, "sceneElement");
673
+ m(this, "singleClickTimer");
674
+ m(this, "dbClickTimeout");
675
+ m(this, "configSub");
676
+ m(this, "rendererElement");
677
+ m(this, "raycastOn");
678
+ this.singleClickTimer = null, this.dbClickTimeout = 190, this.raycastOn = !0, this.rendererElement = e, this.raycaster = new Me(), this.mouse = new oe(), this.sceneElement = t, this.checkInterval = 1, this.lastCheck = void 0, t.traverse((A) => {
679
+ A.isCamera && (this.cameraElement = A);
680
+ }), this.mousemoveEventHandle = this.mousemoveEventHandle.bind(this), this.clickEventHandle = this.clickEventHandle.bind(this), this.setupRaycasting(), this.configSub = lt().getObservable().subscribe((A) => {
681
+ this.dbClickTimeout = A.config.environment.dbClickTimeout ?? 190;
682
+ });
683
+ }
684
+ setupRaycasting() {
685
+ window.addEventListener("mousemove", this.mousemoveEventHandle), window.addEventListener("click", this.clickEventHandle);
686
+ }
687
+ destroyRaycasting() {
688
+ window.removeEventListener("mousemove", this.mousemoveEventHandle), window.removeEventListener("click", this.clickEventHandle);
689
+ }
690
+ toggleRaycasting() {
691
+ this.raycastOn = !this.raycastOn, this.raycastOn ? this.setupRaycasting() : this.destroyRaycasting();
692
+ }
693
+ mousemoveEventHandle(t) {
694
+ const e = performance.now();
695
+ e - this.lastCheck < this.checkInterval || (this.lastCheck = e, this.updateRaycaster(t));
696
+ }
697
+ clickEventHandle(t) {
698
+ const e = this.rendererElement.getBoundingClientRect();
699
+ this.mouse.x = (t.clientX - e.left) / e.width * 2 - 1, this.mouse.y = -((t.clientY - e.top) / e.height) * 2 + 1, this.raycaster.setFromCamera(this.mouse, this.cameraElement);
700
+ const A = Date.now(), i = (this.lastClick ? A - this.lastClick : 1 / 0) < this.dbClickTimeout;
701
+ this.singleClickTimer && (clearTimeout(this.singleClickTimer), this.singleClickTimer = null), i ? (this.raycaster._triggerSource = t.shiftKey ? "shiftmousedbclick" : "mousedbclick", this.handleRaycast()) : this.singleClickTimer = setTimeout(() => {
702
+ this.raycaster._triggerSource = t.shiftKey ? "shiftmouseclick" : "mouseclick", this.handleRaycast(), this.singleClickTimer = null;
703
+ }, this.dbClickTimeout), this.lastClick = A;
704
+ }
705
+ handleRaycast() {
706
+ this.raycaster.intersectObjects(this.sceneElement.children, !0).length > 0;
707
+ }
708
+ updateRaycaster(t) {
709
+ const e = this.rendererElement.getBoundingClientRect();
710
+ this.mouse.x = (t.clientX - e.left) / e.width * 2 - 1, this.mouse.y = -((t.clientY - e.top) / e.height) * 2 + 1, this.raycaster.setFromCamera(this.mouse, this.cameraElement), this.raycaster._triggerSource = "mousemove", this.raycaster.intersectObjects(this.sceneElement.children, !0);
711
+ }
712
+ }
713
+ class pe {
714
+ constructor(t) {
715
+ this.limits = new Int32Array(t), this.values = new Int32Array(t.length);
716
+ }
717
+ increment() {
718
+ for (let t = 0; t < this.values.length; t++) {
719
+ if (this.values[t]++, this.values[t] < this.limits[t]) return !0;
720
+ this.values[t] = 0;
721
+ }
722
+ return !1;
723
+ }
724
+ getIndex() {
725
+ let t = 0, e = 1;
726
+ for (let A = 0; A < this.values.length; A++)
727
+ t += this.values[A] * e, e *= this.limits[A];
728
+ return t;
729
+ }
730
+ setFromNumber(t) {
731
+ for (let e = 0; e < this.limits.length; e++)
732
+ this.values[e] = Math.floor(t % this.limits[e]), t = Math.floor(t / this.limits[e]);
733
+ }
734
+ getValueAt(t) {
735
+ return this.values[t];
736
+ }
737
+ getValues() {
738
+ return [...this.values];
739
+ }
740
+ reset() {
741
+ this.values.fill(0);
742
+ }
743
+ }
744
+ function eA(n, t) {
745
+ return t <= 0 ? n.fXmin : t > n.fNbins ? n.fXmax : n.GetBinLowEdge(t + 1);
746
+ }
747
+ function Tt(n, t, e, A, s, i, o) {
748
+ const l = t + 1, c = n.GetBinLowEdge(l), r = eA(n, l), h = Math.abs(r - c);
749
+ if (o.size = h, o.pos = c + h * 0.5 - n.fXmin, e) {
750
+ const u = (n.fXmax - n.fXmin) * n.fNbins / (e * n.fNbins);
751
+ o.pos /= u, o.size /= u, o.size *= 1 - A, o.pos -= e * 0.5, o.pos += s;
752
+ }
753
+ }
754
+ function AA(n, t, e, A, s, i, o) {
755
+ Tt(n.fXaxis, t.x, e == null ? void 0 : e.x, A == null ? void 0 : A.x, s == null ? void 0 : s.x, i, o.x), Tt(n.fYaxis, t.y, e == null ? void 0 : e.z, A == null ? void 0 : A.y, s == null ? void 0 : s.z, i, o.y), Tt(n.fZaxis, t.z, e == null ? void 0 : e.y, A == null ? void 0 : A.z, s == null ? void 0 : s.y, i, o.z);
756
+ }
757
+ function sA(n) {
758
+ const t = n.y.size, e = n.y.pos;
759
+ return n.y.size = n.z.size, n.y.pos = n.z.pos, n.z.size = t, n.z.pos = e, n;
760
+ }
761
+ function iA(n, t, e, A, s, i, o) {
762
+ return AA(n, t, A, e, s, i, o), o;
763
+ }
764
+ function nA(n, t, e) {
765
+ return e.z.pos = 2 * n - e.z.pos, e;
766
+ }
767
+ function Ae(n, t) {
768
+ if (n.length !== t.length) return !1;
769
+ const e = {};
770
+ for (const A of n)
771
+ e[A] = (e[A] || 0) + 1;
772
+ for (const A of t) {
773
+ if (!e[A])
774
+ return !1;
775
+ e[A]--;
776
+ }
777
+ return !0;
778
+ }
779
+ function Wt(n, t, e, A) {
780
+ let s = Array(n.length).fill(0);
781
+ const i = (o, l, c) => {
782
+ const r = l.fXaxis.fNbins, h = l.fYaxis.fNbins;
783
+ l.fZaxis.fNbins;
784
+ const u = e.slice(
785
+ -e.length + o + 1
786
+ ).reduce((d, g) => d * g, 1);
787
+ if (s[c] += (n[o].x + n[o].y * r + n[o].z * r * h) * u, o + 1 < n.length) {
788
+ let d;
789
+ l.children.content ? d = l.children.content[l.getBin(
790
+ n[o].x + 1,
791
+ n[o].y + 1,
792
+ n[o].z + 1
793
+ )] : d = l.children[A[0]][l.getBin(
794
+ n[o].x + 1,
795
+ n[o].y + 1,
796
+ n[o].z + 1
797
+ )], c > o && i(o + 1, d, c);
798
+ }
799
+ };
800
+ for (let o = 0; o < n.length; o++)
801
+ i(0, t, o);
802
+ return s;
803
+ }
804
+ function mt(n, t, e) {
805
+ var s;
806
+ let A = Array(n.length).fill(0);
807
+ for (let i = 0; i < n.length; i++)
808
+ if (A[i] = t.getBin(
809
+ n[i].x + 1,
810
+ n[i].y + 1,
811
+ n[i].z + 1
812
+ ), t.children)
813
+ (s = t.children) != null && s.content ? t = t.children.content[A[i]] : t = t.children[e[0]][A[i]];
814
+ else
815
+ return A;
816
+ return A;
817
+ }
818
+ function pt(n, t, e, A, s, i = 0) {
819
+ var r, h, a, u;
820
+ const o = ["x", "y", "z"], l = Number.parseInt(e._typename.substring(2, 3), 10);
821
+ let c = {};
822
+ if (n[0]) {
823
+ for (let d = 0; d < l; d++) {
824
+ const g = o[d], p = e[`f${g.toUpperCase()}axis`], v = n[0][g];
825
+ c[g] = {
826
+ min: p.GetBinLowEdge(v + 1),
827
+ max: p.GetBinCenter(v + 1) * 2 - p.GetBinLowEdge(v + 1),
828
+ name: p.fName,
829
+ title: p.fTitle,
830
+ label: (h = (r = p.fLabels) == null ? void 0 : r.arr[v]) == null ? void 0 : h.fString
831
+ };
832
+ }
833
+ c = { ...c, color: A.getColorAt(i, t), name: e.fName };
834
+ }
835
+ if (n[1]) {
836
+ let d;
837
+ return (a = e.children) != null && a.content ? d = e.children.content[e.getBin(n[0].x + 1, n[0].y + 1, n[0].z + 1)] : (u = e.children) != null && u[s[0]] && (d = e.children[s[0]][e.getBin(n[0].x + 1, n[0].y + 1, n[0].z + 1)]), [c, ...pt(n.slice(1), t, d, A, s, i + 1)];
838
+ } else
839
+ return [c];
840
+ }
841
+ function rA(n, t, e, A) {
842
+ let s = 0;
843
+ const i = e.slice(1), o = [];
844
+ for (let c = 0; c < i.length; c++) {
845
+ const r = i.slice(c).reduce((h, a) => h * a, 1);
846
+ o.push(r);
847
+ }
848
+ const l = (c, r) => {
849
+ const { fNbins: h } = r.fXaxis, { fNbins: a } = r.fYaxis, { fNbins: u } = r.fZaxis, d = n[c].x + n[c].y * h + n[c].z * h * a;
850
+ if (s += d * o[c], c + 1 < n.length) {
851
+ const g = oA(r, n[c], A);
852
+ l(c + 1, g);
853
+ }
854
+ };
855
+ return l(0, t), s;
856
+ }
857
+ function oA(n, t, e) {
858
+ const A = n.getBin(
859
+ t.x + 1,
860
+ t.y + 1,
861
+ t.z + 1
862
+ );
863
+ return n.children.content ? n.children.content[A] : n.children[e[0]][A];
864
+ }
865
+ function cA(n) {
866
+ if (!n) return;
867
+ const t = (s) => {
868
+ let i = -1 / 0;
869
+ for (let o = 0; o < s.length; o++) {
870
+ const l = s[o];
871
+ l > i && (i = l);
872
+ }
873
+ return i;
874
+ }, e = [];
875
+ e[0] = { content: t(n.fArray) }, n.fArrays && Object.keys(n == null ? void 0 : n.fArrays).forEach((s) => {
876
+ e[0] = {
877
+ ...e[0],
878
+ [s]: t(n.fArrays[s])
879
+ };
880
+ });
881
+ const A = (s, i = 1) => {
882
+ e[i] || (e[i] = {}), Object.entries(s).forEach(([o, l]) => {
883
+ l.forEach((c) => {
884
+ if (!c) return;
885
+ const r = t(c.fArray);
886
+ (!(o in e[i]) || r > e[i][o]) && (e[i][o] = r), c.children && A(c.children, i + 1);
887
+ });
888
+ });
889
+ };
890
+ return n.children && A(n.children), e;
891
+ }
892
+ function aA(n) {
893
+ if (!n) return;
894
+ const t = (s) => {
895
+ let i = 1 / 0;
896
+ for (let o = 0; o < s.length; o++) {
897
+ const l = s[o];
898
+ l < i && (i = l);
899
+ }
900
+ return i;
901
+ }, e = [];
902
+ e[0] = {
903
+ content: t(n.fArray.filter((s) => s !== 0))
904
+ }, n.fArrays && Object.keys(n == null ? void 0 : n.fArrays).forEach((s) => {
905
+ e[0] = {
906
+ ...e[0],
907
+ [s]: t(
908
+ n.fArrays[s].values.filter((i) => i !== 0)
909
+ )
910
+ };
911
+ });
912
+ const A = (s, i = 1) => {
913
+ e[i] || (e[i] = {}), Object.entries(s).forEach(([o, l]) => {
914
+ l.forEach((c) => {
915
+ if (!c) return;
916
+ const r = t(c.fArray.filter((h) => h !== 0));
917
+ (!(o in e[i]) || r > e[i][o]) && (e[i][o] = r), c.children && A(c.children, i + 1);
918
+ });
919
+ });
920
+ };
921
+ return n.children && A(n.children), e;
922
+ }
923
+ function lA(n) {
924
+ if (!n) return;
925
+ const t = n.fXaxis.fNbins * n.fYaxis.fNbins * n.fZaxis.fNbins;
926
+ let e = [];
927
+ e.push(t);
928
+ const A = (s, i = 1) => {
929
+ let o = 0;
930
+ return i >= e.length && e.push(0), Object.entries(s).forEach((l, c) => {
931
+ l[1].forEach((r) => {
932
+ r && (o = r.fXaxis.fNbins * r.fYaxis.fNbins * r.fZaxis.fNbins, o > e[i] && (e[i] = o), r.children && A(r.children, i + 1));
933
+ });
934
+ }), e;
935
+ };
936
+ return n.children && A(n.children), e.push(1), e;
937
+ }
938
+ function hA(n, t, e) {
939
+ new X(n.color.default.min).toArray(e, 0), new X(n.color.default.max).toArray(e, 3);
940
+ let A = 1;
941
+ n.color.layer.forEach((s) => {
942
+ const i = A * 6;
943
+ new X(s.min).toArray(e, i), new X(s.max).toArray(e, i + 3), A++;
944
+ }), n.color.set.forEach((s) => {
945
+ const i = A * 6;
946
+ new X(s.min).toArray(e, i), new X(s.max).toArray(e, i + 3), A++;
947
+ }), t.uniforms.colorPairs = { value: e }, t.uniformsNeedUpdate = !0;
948
+ }
949
+ function uA(n, t, e, A, s, i, o) {
950
+ const c = ((h, a, u) => (h - a) / (u - a))(e, A, s);
951
+ let r = 0;
952
+ return n.set[i] ? r = 1 + n.layer.length + i : n.layer[o] && (r = 1 + o), r + c;
953
+ }
954
+ function se(n, t, e, A, s, i, o) {
955
+ if (!(1 / n === -1 / 0 || n < 0))
956
+ return o[0] = t[n], o[1] = t[n + 1], o[2] = t[n + 2], o[3] = e[n], o[4] = e[n + 1], o[5] = e[n + 2], o;
957
+ const c = Math.abs(n), r = i !== null ? A[s][i] : A[s];
958
+ return o[0] = r.pos[c], o[1] = r.pos[c + 1], o[2] = r.pos[c + 2], o[3] = r.scale[c], o[4] = r.scale[c + 1], o[5] = r.scale[c + 2], o;
959
+ }
960
+ function St(n, t, e, A, s, i, o) {
961
+ const l = t.fXaxis.fNbins, c = t.fYaxis.fNbins, r = t.fZaxis.fNbins;
962
+ let h = 0, a = 0;
963
+ const u = new Float32Array((l * c * r - 1) * 3), d = new Float32Array((l * c * r - 1) * 3), g = new Float32Array(l * c * r - 1), p = new Float32Array(l * c * r - 1), v = new Float32Array(l * c * r - 1), f = new Float32Array(6), b = new Float32Array(6), y = (C) => {
964
+ const z = B * 3;
965
+ u[z] = C[0], u[z + 1] = C[1], u[z + 2] = C[2], d[z] = C[3], d[z + 1] = C[4], d[z + 2] = C[5], g[B] = C[6], p[B] = C[7], v[B] = C[8];
966
+ }, x = (C, z, O, I) => {
967
+ se(C, u, d, n, O, I, f), se(z, u, d, n, O, I, b);
968
+ const Y = f[0] - f[3] * 0.5 < b[0] - b[3] * 0.5 ? f[0] - f[3] * 0.5 : b[0] - b[3] * 0.5, P = f[1] - f[4] * 0.5 < b[1] - b[4] * 0.5 ? f[1] - f[4] * 0.5 : b[1] - b[4] * 0.5, S = f[2] - f[5] * 0.5 < b[2] - b[5] * 0.5 ? f[2] - f[5] * 0.5 : b[2] - b[5] * 0.5, V = f[0] + f[3] * 0.5 > b[0] + b[3] * 0.5 ? f[0] + f[3] * 0.5 : b[0] + b[3] * 0.5, L = f[1] + f[4] * 0.5 > b[1] + b[4] * 0.5 ? f[1] + f[4] * 0.5 : b[1] + b[4] * 0.5, Q = f[2] + f[5] * 0.5 > b[2] + b[5] * 0.5 ? f[2] + f[5] * 0.5 : b[2] + b[5] * 0.5, G = new Float32Array(9);
969
+ return G[0] = (Y + V) * 0.5, G[1] = (P + L) * 0.5, G[2] = (S + Q) * 0.5, G[3] = V - Y, G[4] = L - P, G[5] = Q - S, G;
970
+ };
971
+ let B = 0;
972
+ for (let C = 0; C < c; C++) {
973
+ for (let O = 0; O < r; O++) {
974
+ const I = h + o;
975
+ let Y = new Array(l);
976
+ for (let P = 0; P < l; P++)
977
+ Y[P] = -P - I;
978
+ for (; Y.length > 1; ) {
979
+ let P = 0;
980
+ const S = Math.floor(Y.length / 2);
981
+ for (let V = 0; V < S; V++) {
982
+ const L = Y[P], Q = Y[P + 1], G = x(L * 3, Q * 3, e, A);
983
+ Y.splice(P, 2, B), kt(G, i), G[6] = 1 / L === -1 / 0 || L < 0 ? L : v[L], G[7] = 1 / Q === -1 / 0 || Q < 0 ? Q : v[Q], G[8] = a, y(G), B += 1, a += 1, P += 1;
984
+ }
985
+ }
986
+ h += l;
987
+ }
988
+ const z = new Array(r);
989
+ for (let O = 0; O < r; O++)
990
+ z[O] = B - 1 - (r - 1 - O) * (l - 1);
991
+ for (; z.length > 1; ) {
992
+ let O = 0;
993
+ const I = Math.floor(z.length / 2);
994
+ for (let Y = 0; Y < I; Y++) {
995
+ const P = z[O], S = z[O + 1], V = x(P * 3, S * 3, e, A);
996
+ z.splice(O, 2, B), kt(V, i), V[6] = v[P], V[7] = v[S], V[8] = a, y(V), B += 1, a += 1, O += 1;
997
+ }
998
+ }
999
+ }
1000
+ const D = new Array(c);
1001
+ for (let C = 0; C < c; C++)
1002
+ D[C] = B - 1 - (c - 1 - C) * (l * r - 1);
1003
+ for (; D.length > 1; ) {
1004
+ let C = 0;
1005
+ const z = Math.floor(D.length / 2);
1006
+ for (let O = 0; O < z; O++) {
1007
+ const I = D[C], Y = D[C + 1], P = x(I * 3, Y * 3, e, A);
1008
+ D.splice(C, 2, B), kt(P, i), P[6] = v[I], P[7] = v[Y], P[8] = a, y(P), B += 1, a += 1, C += 1;
1009
+ }
1010
+ }
1011
+ return {
1012
+ pos: u,
1013
+ scale: d,
1014
+ left: g,
1015
+ right: p
1016
+ };
1017
+ }
1018
+ function dA(n, t, e, A, s, i, o) {
1019
+ const l = new Array(n.length).fill().map((r) => []);
1020
+ l[l.length - 1] = Array.from(
1021
+ { length: s.length },
1022
+ () => []
1023
+ ), l[0] = [St(
1024
+ n,
1025
+ t,
1026
+ e,
1027
+ null,
1028
+ s,
1029
+ i,
1030
+ 0
1031
+ )];
1032
+ const c = (r, h, a) => {
1033
+ var v;
1034
+ if (!r.children) return;
1035
+ const u = new pe(
1036
+ [
1037
+ r.fXaxis.fNbins,
1038
+ r.fYaxis.fNbins,
1039
+ r.fZaxis.fNbins
1040
+ ]
1041
+ ), d = r.fXaxis.fNbins * r.fYaxis.fNbins * r.fZaxis.fNbins, g = o.slice(1, h - 1).reduce((f, b) => f * b, o[1]), p = o[h];
1042
+ for (let f = 0; f < d; f++) {
1043
+ const b = { x: u.getValueAt(0), y: u.getValueAt(1), z: u.getValueAt(2) };
1044
+ if ((v = r == null ? void 0 : r.children) != null && v.content) {
1045
+ const y = r.children.content[r.getBin(b.x + 1, b.y + 1, b.z + 1)];
1046
+ if (!y) {
1047
+ if (u.increment() === !1) break;
1048
+ continue;
1049
+ }
1050
+ l[h][f + a] = St(
1051
+ n,
1052
+ y,
1053
+ h,
1054
+ null,
1055
+ s,
1056
+ i,
1057
+ (f + a) * p
1058
+ ), c(y, h + 1, (u.getIndex() + a) * g);
1059
+ } else r.children && !r.children.hasOwnProperty("content") && A.forEach((y) => {
1060
+ const x = s.indexOf(y), B = (f + a) * p;
1061
+ let D = !1;
1062
+ for (let z = B; z < B + o[h]; z++)
1063
+ if (n[h][x].rendered[z] !== -1) {
1064
+ D = !0;
1065
+ break;
1066
+ }
1067
+ if (!D) {
1068
+ l[h][x].push(null);
1069
+ return;
1070
+ }
1071
+ const C = r.children[y][r.getBin(b.x + 1, b.z + 1, b.y + 1)];
1072
+ C && (l[h][x][f + a] = St(
1073
+ n,
1074
+ C,
1075
+ h,
1076
+ x,
1077
+ s,
1078
+ i,
1079
+ (f + a) * p
1080
+ ), c(
1081
+ C,
1082
+ h + 1,
1083
+ (u.getIndex() + a) * g
1084
+ ));
1085
+ });
1086
+ if (u.increment() === !1) break;
1087
+ }
1088
+ };
1089
+ return c(t, 1, 0), l;
1090
+ }
1091
+ function kt(n, t) {
1092
+ const e = t.elements, A = Math.sqrt(e[0] * e[0] + e[1] * e[1] + e[2] * e[2]), s = Math.sqrt(e[4] * e[4] + e[5] * e[5] + e[6] * e[6]), i = Math.sqrt(e[8] * e[8] + e[9] * e[9] + e[10] * e[10]);
1093
+ n[0] = n[0] * A + e[12], n[1] = n[1] * s + e[13], n[2] = n[2] * i + e[14], n[3] = n[3] * A, n[4] = n[4] * s, n[5] = n[5] * i;
1094
+ }
1095
+ class ie {
1096
+ constructor(t) {
1097
+ m(this, "rootObj");
1098
+ m(this, "origin");
1099
+ m(this, "parentPath", []);
1100
+ m(this, "path");
1101
+ m(this, "title");
1102
+ m(this, "range", []);
1103
+ m(this, "isOnSet", !1);
1104
+ this.rootObj = t, this.origin = this.rootObj, this.title = this.origin.fTitle, this.path = this.origin.fName;
1105
+ }
1106
+ /**
1107
+ * sets origin of pointer to one of child's.
1108
+ * @param index is an index in child mapping.
1109
+ * @param set if children contains sets, parameter need to be specified.
1110
+ * */
1111
+ setOriginToChild(t, e, A) {
1112
+ var i, o;
1113
+ if (!t) return;
1114
+ const s = t.splice(0, 1);
1115
+ if ((i = this.origin) != null && i.children) {
1116
+ if ((o = this.origin.children) != null && o.content)
1117
+ this.parentPath.push({ origin: this.origin, range: A, bin: s }), this.origin = this.origin.children.content[s], this.isOnSet = !1;
1118
+ else if (Object.keys(this.origin.children).includes(e))
1119
+ this.parentPath.push({ origin: this.origin, range: A, bin: s }), this.origin = this.origin.children[e][s], this.isOnSet = !0;
1120
+ else {
1121
+ console.error("Bad set or index specified.");
1122
+ return;
1123
+ }
1124
+ this.title = this.origin.fTitle, this.path = this.path + "/" + this.origin.fName, t.length > 0 && this.setOriginToChild(t, e);
1125
+ }
1126
+ }
1127
+ /**
1128
+ * Method to get child (jsroot object) by position
1129
+ * @warning for @param position only supply shallow copy of value,
1130
+ * @note Index have to exclude first index as the pointer is already on this node.
1131
+ * as if deep copy is supplied, the original is rewritten.
1132
+ * @param node Defines origin from which child set by position is obtained.
1133
+ * @param index Defines index specified by jsroot indexing of bins.
1134
+ * @param set Defines set from which histogram will be choosen, if possible.
1135
+ * Has to be array (can go through more layers at once) where each entry represents children position in layer.
1136
+ * */
1137
+ /**
1138
+ * */
1139
+ getChildByPosition(t, e, A = this.origin) {
1140
+ var i;
1141
+ if (!t || t.length === 0) return A;
1142
+ const s = t.pop();
1143
+ return A != null && A.children ? (i = A.children) != null && i.content ? this.getChildByPosition(t, e, A.children.content[s]) : Object.keys(A.children).includes(e) ? this.getChildByPosition(t, e, A.children[e][s]) : (console.error("Bad set or index specified."), null) : A;
1144
+ }
1145
+ /**
1146
+ * sets origin of pointer to one of parent nodes.
1147
+ * @param steps (optional, default = 1) defines how many steps in path should pointer go upwards.
1148
+ * */
1149
+ setOriginToParent(t = 1) {
1150
+ if (t <= 0 || this.parentPath.length === 0) return;
1151
+ const e = this.path.lastIndexOf("/");
1152
+ this.path = this.path.slice(0, e);
1153
+ const A = this.parentPath.pop();
1154
+ A && (this.origin = A.origin), this.title = this.origin.fTitle, this.setOriginToParent(t - 1), this.isOnSet = !1;
1155
+ }
1156
+ }
1157
+ class fA {
1158
+ constructor(t, e, A) {
1159
+ m(this, "wireframe");
1160
+ m(this, "instGeom");
1161
+ m(this, "material");
1162
+ m(this, "totalInstances");
1163
+ m(this, "maxInstancesPerLayer");
1164
+ m(this, "instancePositions");
1165
+ m(this, "instanceScales");
1166
+ m(this, "instanceColors");
1167
+ m(this, "colorArray");
1168
+ m(this, "configSub");
1169
+ m(this, "stateSub");
1170
+ m(this, "config");
1171
+ m(this, "numOfavailableSets");
1172
+ m(this, "visibility", !0);
1173
+ this.config = A, this.maxInstancesPerLayer = t;
1174
+ const s = new xt(1, 1, 1), i = new _t(s);
1175
+ this.instGeom = new yt(), this.instGeom.instanceCount = 0, this.instGeom.frustumCulled = !1, this.instGeom.index = i.index;
1176
+ for (const o in i.attributes)
1177
+ this.instGeom.setAttribute(o, i.attributes[o]);
1178
+ this.material = this.createMaterial(), this.colorArray = new Float32Array(32 * 3), this.fillColorArray(), this.instancePositions = new Float32Array(3), this.instanceScales = new Float32Array(3), this.instanceColors = new Float32Array(1), this.instGeom.setAttribute(
1179
+ "instancePosition",
1180
+ new N(this.instancePositions, 3)
1181
+ ), this.instGeom.setAttribute(
1182
+ "instanceScale",
1183
+ new N(this.instanceScales, 3)
1184
+ ), this.instGeom.setAttribute(
1185
+ "instanceColorIndex",
1186
+ new N(this.instanceColors, 1)
1187
+ ), this.wireframe = new te(this.instGeom, this.material), this.wireframe.frustumCulled = !1, this.stateSub = tt().getObservable().subscribe((o) => {
1188
+ this.numOfavailableSets = o.sets.length;
1189
+ });
1190
+ }
1191
+ pushVisibleInstances(t, e, A) {
1192
+ let s = this.wireframe.parent;
1193
+ s && (s.remove(this.wireframe), this.instGeom.dispose());
1194
+ const i = [], o = t.length - 1;
1195
+ {
1196
+ const b = (Array.isArray(t[o]) ? t[o][A] : t[o]).rendered, y = new Uint8Array(b.length);
1197
+ for (let x = 0; x < b.length; x++) y[x] = b[x] !== -1 ? 1 : 0;
1198
+ i[o] = y;
1199
+ }
1200
+ for (let f = o - 1; f >= 0; f--) {
1201
+ const y = (Array.isArray(t[f]) ? t[f][A] : t[f]).rendered, x = i[f + 1], B = e[f + 1] || 0, D = new Uint8Array(y.length);
1202
+ for (let C = 0; C < y.length; C++) {
1203
+ if (y[C] !== -1) {
1204
+ D[C] = 1;
1205
+ continue;
1206
+ }
1207
+ const z = C * B, O = z + B;
1208
+ for (let I = z; I < O; I++)
1209
+ if (x[I]) {
1210
+ D[C] = 1;
1211
+ break;
1212
+ }
1213
+ }
1214
+ i[f] = D;
1215
+ }
1216
+ const l = (f, b) => i[f][b] === 1, c = (f, b) => {
1217
+ let y = 0, x = f, B = b;
1218
+ for (; x + 1 < t.length; ) {
1219
+ x++, B *= e[x];
1220
+ const D = t[x], C = Array.isArray(D) ? D[A] : D;
1221
+ for (let z = B; z < B + e[x]; z++)
1222
+ if (C.rendered[z] !== -1) {
1223
+ y = x - f;
1224
+ break;
1225
+ }
1226
+ }
1227
+ return y;
1228
+ };
1229
+ let r = 0;
1230
+ for (let f = 0; f < t.length; f++) {
1231
+ const b = t[f];
1232
+ if (!Array.isArray(b))
1233
+ for (let y = 0; y < b.rendered.length; y++)
1234
+ l(f, y) && r++;
1235
+ }
1236
+ const h = new Float32Array(r * 3), a = new Float32Array(r * 3), u = new Float32Array(r);
1237
+ let d = 0;
1238
+ for (let f = 0; f < t.length; f++) {
1239
+ const b = t[f], y = this.getColorIndex(f, A);
1240
+ if (!Array.isArray(b)) {
1241
+ for (let x = 0; x < b.rendered.length; x++)
1242
+ if (l(f, x)) {
1243
+ const B = c(f, x) * 0.05;
1244
+ h[d * 3] = b.pos[x * 3], h[d * 3 + 1] = b.pos[x * 3 + 1], h[d * 3 + 2] = b.pos[x * 3 + 2], a[d * 3] = b.scale[x * 3] + B, a[d * 3 + 1] = b.scale[x * 3 + 1] + B, a[d * 3 + 2] = b.scale[x * 3 + 2] + B, u[d++] = y;
1245
+ }
1246
+ }
1247
+ }
1248
+ const g = new xt(1, 1, 1), p = new _t(g);
1249
+ this.instGeom = new yt(), this.instGeom.instanceCount = r, this.instGeom.frustumCulled = !1, this.instGeom.index = p.index;
1250
+ const v = p.attributes;
1251
+ for (const f in v)
1252
+ this.instGeom.setAttribute(f, v[f]);
1253
+ this.instancePositions = h, this.instanceScales = a, this.instanceColors = u, this.instGeom.setAttribute("instancePosition", new N(h, 3)), this.instGeom.setAttribute("instanceScale", new N(a, 3)), this.instGeom.setAttribute("instanceColorIndex", new N(u, 1)), this.wireframe = new te(this.instGeom, this.material), this.wireframe.frustumCulled = !1, s && s.add(this.wireframe);
1254
+ }
1255
+ //TODO cool
1256
+ toggleVisibility(t, e, A) {
1257
+ this.visibility = !this.visibility, this.visibility ? this.pushVisibleInstances(t, e, A) : this.clearWireframe();
1258
+ }
1259
+ //TODO cool
1260
+ dispose() {
1261
+ this.instancePositions = [], this.instanceScales = [], this.wireframe.parent.remove(this.wireframe), this.instGeom.dispose();
1262
+ }
1263
+ //TODO cool
1264
+ clearWireframe() {
1265
+ this.instancePositions = new Float32Array(3), this.instanceScales = new Float32Array(3), this.instanceColors = new Float32Array(1), this.instGeom.dispose(), this.instGeom.instanceCount = 0;
1266
+ }
1267
+ //TODO cool
1268
+ fillColorArray() {
1269
+ new X(this.config.color.default).toArray(this.colorArray, 0);
1270
+ let t = 1;
1271
+ this.config.color.layer.map((e) => new X(e)).forEach((e) => {
1272
+ const A = t * 3;
1273
+ e.toArray(this.colorArray, A), t++;
1274
+ }), this.config.color.set.map((e) => new X(e)).forEach((e) => {
1275
+ const A = t * 3;
1276
+ e.toArray(this.colorArray, A), t++;
1277
+ }), this.material.uniforms.colorArray = { value: this.colorArray }, this.material.uniformsNeedUpdate = !0;
1278
+ }
1279
+ //TODO cool
1280
+ createMaterial() {
1281
+ return new ce({
1282
+ vertexShader: `
1283
+ attribute vec3 instancePosition;
1284
+ attribute vec3 instanceScale;
1285
+ attribute float instanceColorIndex;
1286
+
1287
+ uniform vec3 colorArray[32]; // must match maxColors in JS
1288
+
1289
+ varying vec3 vColor;
1290
+
1291
+ void main() {
1292
+ vec3 transformed = position * instanceScale + instancePosition;
1293
+ gl_Position = projectionMatrix * modelViewMatrix * vec4(transformed, 1.0);
1294
+
1295
+ int idx = int(instanceColorIndex);
1296
+ vColor = colorArray[idx];
1297
+ }
1298
+ `,
1299
+ fragmentShader: `
1300
+ varying vec3 vColor;
1301
+ void main() {
1302
+ gl_FragColor = vec4(vColor, 1.0);
1303
+ }
1304
+ `,
1305
+ transparent: !1
1306
+ });
1307
+ }
1308
+ //TODO cool
1309
+ getColorIndex(t, e) {
1310
+ return this.config.color.set[e] ? this.config.color.layer.length + 1 : this.config.color.layer[t] ? t + 1 : 0;
1311
+ }
1312
+ //TODO cool
1313
+ getColorAt(t, e) {
1314
+ return this.config.color.set[e] ? this.config.color.set[e] : this.config.color.layer[t] ? this.config.color.layer[t] : this.config.color.default;
1315
+ }
1316
+ }
1317
+ class gA {
1318
+ //
1319
+ constructor(t, e, A) {
1320
+ m(this, "id");
1321
+ m(this, "functionSub");
1322
+ // stateSub = undefined;
1323
+ m(this, "configSub");
1324
+ m(this, "dispatchSub");
1325
+ m(this, "rootObj");
1326
+ m(this, "config");
1327
+ m(this, "limits", {
1328
+ position: new H(0, 0, 0),
1329
+ scale: new H(10, 10, 10)
1330
+ });
1331
+ m(this, "mouseEvents", []);
1332
+ m(this, "keydownEvents", []);
1333
+ m(this, "keyupEvents", []);
1334
+ m(this, "keyBindings", {});
1335
+ m(this, "opts");
1336
+ var s;
1337
+ this.rootObj = t.obj, this.id = e, this.opts = A, this.config = lt().mergeHistogramConfig((s = this == null ? void 0 : this.opts) == null ? void 0 : s.config), this.functionSub = fe().getObservable().pipe(
1338
+ ct(
1339
+ (i) => i.target.entity === "nested-histogram" && (i.target.id.includes("*") || i.target.id.includes(this.id))
1340
+ )
1341
+ ).subscribe((i) => this.functionSubjectHandler(i)), this.configSub = lt().getObservable().pipe(
1342
+ ct(
1343
+ (i) => i.target.id.includes("*") || i.target.id.includes(this.id)
1344
+ )
1345
+ ).subscribe((i) => {
1346
+ var l;
1347
+ this.config = lt().mergeHistogramConfig((l = this == null ? void 0 : this.opts) == null ? void 0 : l.config), this.keyBindings = ke(i.config.bindings);
1348
+ const o = i.config.environment.histogramPads.find(
1349
+ (c) => c.id === this.id
1350
+ );
1351
+ this.limits = o ?? {
1352
+ scale: { x: 20, y: 10, z: 20 },
1353
+ padding: { x: 0, y: 0, z: 0 },
1354
+ position: { x: 0, y: 0, z: -5 }
1355
+ };
1356
+ }), this.dispatchSub = Ge().getObservable().pipe(
1357
+ ct((i) => i.target.id === "*" || i.target.id === this.id)
1358
+ ).subscribe((i) => this.dispatchSubjectHandler(i)), this.initDefaultFunctions();
1359
+ }
1360
+ remove() {
1361
+ this.functionSub.unsubscribe(), this.configSub.unsubscribe(), this.dispatchSub.unsubscribe(), window.removeEventListener("keydown", this.keyDownHandler), window.removeEventListener("keydown", this.keyUpHandler);
1362
+ }
1363
+ initDefaultFunctions() {
1364
+ this.keyDownHandler = this.keyDownHandler.bind(this), this.keyUpHandler = this.keyUpHandler.bind(this), this.raycastHandler = this.raycastHandler.bind(this), this.mouseClickDefault = this.mouseClickDefault.bind(this), this.mousemoveDefault = this.mousemoveDefault.bind(this), this.shiftMouseClickDefault = this.shiftMouseClickDefault.bind(this), this.mouseDBClickDefault = this.mouseDBClickDefault.bind(this), this.shiftMouseDBClickDefault = this.shiftMouseDBClickDefault.bind(this), window.addEventListener("keydown", this.keyDownHandler), window.addEventListener("keydown", this.keyUpHandler), this.addEvent("mouseclick", this.mouseClickDefault), this.addEvent("mousemove", this.mousemoveDefault), this.addEvent("shiftmouseclick", this.shiftMouseClickDefault), this.addEvent("mousedbclick", this.mouseDBClickDefault), this.addEvent("shiftmousedbclick", this.shiftMouseDBClickDefault);
1365
+ }
1366
+ functionSubjectHandler(t) {
1367
+ if (t.flag === "add")
1368
+ if (t.function)
1369
+ this.addEvent(t.event, t.function);
1370
+ else
1371
+ switch (t.event) {
1372
+ case "mousemove":
1373
+ this.addEvent(t.event, this.mousemoveDefault);
1374
+ break;
1375
+ case "mouseclick":
1376
+ this.addEvent(t.event, this.mouseClickDefault);
1377
+ break;
1378
+ case "shiftmouseclick":
1379
+ this.addEvent(t.event, this.shiftMouseClickDefault);
1380
+ break;
1381
+ case "mousedbclick":
1382
+ this.addEvent(t.event, this.mouseDBClickDefault);
1383
+ break;
1384
+ case "shiftmousedbclick":
1385
+ this.addEvent(t.event, this.shiftMouseDBClickDefault);
1386
+ break;
1387
+ }
1388
+ else if (t.flag === "remove" && t.function)
1389
+ this.removeEvent(t.event, t.function);
1390
+ else if (t.flag === "remove")
1391
+ switch (t == null ? void 0 : t.state) {
1392
+ case "keydown":
1393
+ this.keydownEvents = [];
1394
+ break;
1395
+ case "keyup":
1396
+ this.keyupEvents = [];
1397
+ break;
1398
+ default:
1399
+ this.mouseEvents = this.mouseEvents.filter((e) => e.event !== t.event);
1400
+ }
1401
+ else t.flag === "removeAll" && (this.keydownEvents = [], this.keyupEvents = [], this.mouseEvents = []);
1402
+ }
1403
+ /**
1404
+ * @desc Adds function that will be called, if specified event is triggered.
1405
+ * @param event can be either mouseevent in which only name of event is required (e.g. mousclick, shiftmousedbclick),
1406
+ * or keyboard event which has to concise state (keydown or keyup) and keyCode (e.g. Numpad1)
1407
+ * @param func Function that is called if event is triggered.
1408
+ * */
1409
+ addEvent(t, e) {
1410
+ (t == null ? void 0 : t.state) === "keydown" ? this.keydownEvents.push({
1411
+ key: t.key,
1412
+ function: e
1413
+ }) : (t == null ? void 0 : t.state) === "keyup" ? this.keyupEvents.push({
1414
+ key: t.key,
1415
+ function: e
1416
+ }) : this.mouseEvents.push({
1417
+ event: t,
1418
+ function: e
1419
+ });
1420
+ }
1421
+ /**
1422
+ * @desc Removes function from event listener.
1423
+ * @param event Defines from which event should listening be removed.
1424
+ * @param func has to have same reference to one that was added by addEvent.
1425
+ * */
1426
+ removeEvent(t, e) {
1427
+ const A = this.mouseEvents.find((s) => s === e);
1428
+ A && this.mouseEvents.splice(A, 1);
1429
+ }
1430
+ mouseClickDefault(t) {
1431
+ console.log("mouse click default");
1432
+ }
1433
+ mousemoveDefault(t) {
1434
+ console.log("mouse move default");
1435
+ }
1436
+ shiftMouseClickDefault(t) {
1437
+ console.log("shift mouse click");
1438
+ }
1439
+ mouseDBClickDefault(t) {
1440
+ console.log("mouseDBClick default");
1441
+ }
1442
+ shiftMouseDBClickDefault(t) {
1443
+ console.log("shift mouse db click default");
1444
+ }
1445
+ dispatchSubjectHandler(t) {
1446
+ console.log("dispatch: ", t);
1447
+ }
1448
+ }
1449
+ class qA extends gA {
1450
+ constructor(e, A, s) {
1451
+ super(e, A, s);
1452
+ m(this, "stateSub");
1453
+ m(this, "pointer");
1454
+ m(this, "wireframe");
1455
+ m(this, "BVHTree", []);
1456
+ m(this, "maxInstancesPerLayer");
1457
+ m(this, "maxContentPerLayer");
1458
+ m(this, "totalInstances");
1459
+ m(this, "color", new X());
1460
+ m(this, "matrixCache");
1461
+ m(this, "selectedSet", []);
1462
+ m(this, "selectedArray", "content");
1463
+ m(this, "availableSets", []);
1464
+ m(this, "renderHistory", []);
1465
+ m(this, "dirtyInstance", []);
1466
+ m(this, "mesh");
1467
+ m(this, "instGeom");
1468
+ m(this, "material");
1469
+ m(this, "instancePositions");
1470
+ m(this, "instanceScales");
1471
+ m(this, "instanceColors");
1472
+ m(this, "colorArray");
1473
+ this.pointer = new ie(this.rootObj), this.handleStateChange = this.handleStateChange.bind(this), this.stateSub = tt().getObservable().subscribe(this.handleStateChange), this.init(), this.renderHistogram(0, this.totalInstances, 0);
1474
+ }
1475
+ updateHistogram(e) {
1476
+ const A = this.mesh.parent, s = this.mesh.raycast;
1477
+ this.mesh.raycast = () => {
1478
+ }, this.matrixCache = [], this.BVHTree = [], this.availableSets = [], this.selectedSet = [], tt().next({
1479
+ sets: [],
1480
+ selectedSet: [],
1481
+ arrays: ["content"],
1482
+ selectedArray: "content"
1483
+ }), this.wireframe.dispose(), this.instGeom.dispose(), A.remove(this.mesh), this.rootObj = e.obj, this.pointer = new ie(this.rootObj), this.init(), this.renderHistogram(0, this.totalInstances, 0), setTimeout(() => {
1484
+ A.add(this.mesh), this.mesh.raycast = s;
1485
+ }, 0), A.add(this.wireframe.wireframe);
1486
+ }
1487
+ remove() {
1488
+ super.remove(), this.matrixCache = [], this.instGeom.dispose(), this.mesh.parent && (this.mesh.parent.remove(this.mesh), this.wireframe.dispose()), this.stateSub.unsubscribe();
1489
+ }
1490
+ /**
1491
+ * @desc Initializes base values and objects.
1492
+ * */
1493
+ init() {
1494
+ this.setAvailableSets(this.pointer.origin), this.setAvailableArrays(this.pointer.origin), this.maxInstancesPerLayer = lA(this.pointer.origin), this.maxContentPerLayer = cA(this.pointer.origin), this.minContentPerLayer = aA(this.pointer.origin), this.totalInstances = this.maxInstancesPerLayer.reduce((e, A) => e * A, 1), this.setupInsBufGeom(), this.wireframe = new fA(
1495
+ this.maxInstancesPerLayer,
1496
+ this.matrixCache,
1497
+ this.config.wireframe
1498
+ );
1499
+ }
1500
+ setupMatrixCache() {
1501
+ this.matrixCache = new Array(this.maxInstancesPerLayer.length - 1);
1502
+ const e = this.availableSets.length > 0;
1503
+ e && (this.matrixCache[this.matrixCache.length - 1] = new Array(this.availableSets.length));
1504
+ let A = this.maxInstancesPerLayer[0];
1505
+ for (let i = 0; i < this.maxInstancesPerLayer.length - 1 - (e ? 1 : 0); i++)
1506
+ this.matrixCache[i] = {
1507
+ pos: new Float32Array(A * 3),
1508
+ scale: new Float32Array(A * 3),
1509
+ rendered: new Float32Array(A).fill(-1)
1510
+ }, A *= this.maxInstancesPerLayer[i + 1];
1511
+ if (!e) return;
1512
+ const s = this.matrixCache[this.matrixCache.length - 1];
1513
+ for (let i = 0; i < s.length; i++)
1514
+ s[i] = {
1515
+ pos: new Float32Array(A * 3),
1516
+ scale: new Float32Array(A * 3),
1517
+ rendered: new Float32Array(A).fill(-1)
1518
+ };
1519
+ }
1520
+ setupInsBufGeom() {
1521
+ this.setupMatrixCache();
1522
+ let e = this.maxInstancesPerLayer.reduce((s, i) => s * i, 1);
1523
+ this.selectedSet.length > 1 && (e *= this.selectedSet.length);
1524
+ const A = new xt(1, 1, 1);
1525
+ this.instGeom = new yt(), this.instGeom.instanceCount = 0, this.instGeom.frustumCulled = !1, this.instGeom.index = A.index;
1526
+ for (const s in A.attributes)
1527
+ this.instGeom.setAttribute(s, A.attributes[s]);
1528
+ this.material = this.createMaterial(), this.colorArray = new Float32Array(32 * 6), this.material.uniforms.colorArray = { value: this.colorArray }, hA(this.config, this.material, this.colorArray), this.instancePositions = new Float32Array(3), this.instanceScales = new Float32Array(3), this.instanceColors = new Float32Array(1), this.instGeom.setAttribute(
1529
+ "instancePosition",
1530
+ new N(this.instancePositions, 3)
1531
+ ), this.instGeom.setAttribute(
1532
+ "instanceScale",
1533
+ new N(this.instanceScales, 3)
1534
+ ), this.instGeom.setAttribute(
1535
+ "instanceColorIndex",
1536
+ new N(this.instanceColors, 1)
1537
+ ), this.mesh = new Ct(this.instGeom, this.material), this.mesh.raycast = this.raycastHandler, this.mesh.frustumCulled = !1, this.material.uniforms.colorArray = { value: this.colorArray }, this.mesh.material.uniformsNeedUpdate = !0;
1538
+ }
1539
+ pushVisibleInstances() {
1540
+ let e = this.mesh.parent;
1541
+ e && (e.remove(this.mesh), this.instGeom.dispose());
1542
+ let A = 0;
1543
+ for (let h = 0; h < this.matrixCache.length; h++) {
1544
+ const a = this.matrixCache[h];
1545
+ if (Array.isArray(a))
1546
+ for (let u = 0; u < a.length; u++) {
1547
+ const d = a[u];
1548
+ for (let g = 0; g < d.rendered.length; g++)
1549
+ d.rendered[g] !== -1 && A++;
1550
+ }
1551
+ else
1552
+ for (let u = 0; u < a.rendered.length; u++)
1553
+ a.rendered[u] !== -1 && A++;
1554
+ }
1555
+ const s = new Float32Array(A * 3), i = new Float32Array(A * 3), o = new Float32Array(A);
1556
+ let l = 0;
1557
+ for (let h = 0; h < this.matrixCache.length; h++) {
1558
+ const a = this.matrixCache[h];
1559
+ if (Array.isArray(a))
1560
+ for (let u = 0; u < a.length; u++) {
1561
+ const d = a[u];
1562
+ for (let g = 0; g < d.rendered.length; g++)
1563
+ d.rendered[g] !== -1 && (s[l * 3] = d.pos[g * 3], s[l * 3 + 1] = d.pos[g * 3 + 1], s[l * 3 + 2] = d.pos[g * 3 + 2], i[l * 3] = d.scale[g * 3], i[l * 3 + 1] = d.scale[g * 3 + 1], i[l * 3 + 2] = d.scale[g * 3 + 2], o[l++] = d.rendered[g]);
1564
+ }
1565
+ else
1566
+ for (let u = 0; u < a.rendered.length; u++)
1567
+ a.rendered[u] !== -1 && (s[l * 3] = a.pos[u * 3], s[l * 3 + 1] = a.pos[u * 3 + 1], s[l * 3 + 2] = a.pos[u * 3 + 2], i[l * 3] = a.scale[u * 3], i[l * 3 + 1] = a.scale[u * 3 + 1], i[l * 3 + 2] = a.scale[u * 3 + 2], o[l++] = a.rendered[u]);
1568
+ }
1569
+ const c = new xt(1, 1, 1);
1570
+ this.instGeom = new yt(), this.instGeom.instanceCount = A, this.instGeom.frustumCulled = !1, this.instGeom.index = c.index;
1571
+ const r = c.attributes;
1572
+ for (const h in r)
1573
+ this.instGeom.setAttribute(h, r[h]);
1574
+ this.instancePositions = s, this.instanceScales = i, this.instanceColors = o, this.instGeom.setAttribute("instancePosition", new N(s, 3)), this.instGeom.setAttribute("instanceScale", new N(i, 3)), this.instGeom.setAttribute("instanceColorIndex", new N(o, 1)), this.mesh = new Ct(this.instGeom, this.material), this.mesh.raycast = this.raycastHandler, this.mesh.frustumCulled = !1, e && e.add(this.mesh);
1575
+ }
1576
+ setMatrixCacheAt(e, A, s, i, o) {
1577
+ const l = A !== null ? this.matrixCache[e][A] : this.matrixCache[e];
1578
+ l.pos[s * 3] = i.x.pos, l.pos[s * 3 + 1] = i.y.pos, l.pos[s * 3 + 2] = i.z.pos, l.scale[s * 3] = i.x.size, l.scale[s * 3 + 1] = i.y.size, l.scale[s * 3 + 2] = i.z.size, l.rendered[s] = o;
1579
+ }
1580
+ /**
1581
+ * @desc Render whole or part of histogram.
1582
+ * @param startIndex Linear index of bin from which render will start.
1583
+ * @param endIndex Linear index of bin on which render will end.
1584
+ * @param layer Defines layer which will be rendered.
1585
+ * @note Linear index is set in this form:
1586
+ * Bins of the deepest layer are offset by 1.
1587
+ * Bins from each upward layer are offset by maximum number of layer beneath.
1588
+ * */
1589
+ renderHistogram(e, A, s) {
1590
+ if (!this.pointer || s >= this.maxInstancesPerLayer.length - 1) return;
1591
+ this.logRender({
1592
+ procedure: "render",
1593
+ value: {
1594
+ startIndex: e,
1595
+ endIndex: A,
1596
+ layer: s
1597
+ }
1598
+ });
1599
+ const i = {
1600
+ x: { size: 0, pos: 0 },
1601
+ y: { size: 0, pos: 0 },
1602
+ z: { size: 0, pos: 0 }
1603
+ }, o = async (l, c, r, h, a, u) => {
1604
+ var S, V, L, Q, G, jt, Ut;
1605
+ if (r > s || !h) return;
1606
+ const d = new pe(
1607
+ [h.fXaxis.fNbins, h.fYaxis.fNbins, h.fZaxis.fNbins]
1608
+ );
1609
+ let g, p, v, f;
1610
+ const b = ((V = (S = h.fArrays) == null ? void 0 : S[this.selectedArray]) == null ? void 0 : V.outside) ?? !1, y = this.selectedSet.indexOf(u), x = this.availableSets.indexOf(u);
1611
+ if (this.config.sets.scale.maximum === "relative") {
1612
+ const T = (L = h.fArrays) == null ? void 0 : L[this.selectedArray];
1613
+ if (T) {
1614
+ const F = T.values.filter(
1615
+ (M) => M !== 0
1616
+ );
1617
+ v = Math.min(...F), f = Math.max(...F), g = T.min ?? v, p = T.max ?? f;
1618
+ } else {
1619
+ const F = h.fArray.filter((M) => M !== 0);
1620
+ g = Math.min(...F), p = Math.max(...F);
1621
+ }
1622
+ } else u && this.maxContentPerLayer[r][u] ? (p = this.maxContentPerLayer[r][u], g = this.minContentPerLayer[r][u]) : (p = this.maxContentPerLayer[r][this.selectedArray], g = this.minContentPerLayer[r][this.selectedArray]);
1623
+ g === p && (g = p - 1);
1624
+ const B = h._typename.substring(0, 3) === "TH3", D = h._typename.substring(0, 3) === "TH2", C = h._typename.substring(0, 3) === "TH1", z = this.maxInstancesPerLayer.slice(r + 1).reduce((T, F) => T * F, 1);
1625
+ d.setFromNumber(l / z);
1626
+ const O = this.config.padding.layer[r] ?? this.config.padding.default;
1627
+ let I = !this.config.padding.layer[r] && C ? { x: O.x, y: O.y, z: O.z } : { ...O };
1628
+ u && this.config.padding.sets && C && (I = { x: this.config.padding.sets.x, y: 0, z: 0 }), this.pointer.isOnSet && (I = { x: 0, y: 0, z: 0 });
1629
+ const { min: Y, max: P } = (Q = this.config.scale) != null && Q[r] ? (G = this.config.scale) == null ? void 0 : G[r] : this.config.scale.default;
1630
+ for (let T = l; T < c; T += z) {
1631
+ const F = {
1632
+ x: d.getValueAt(0),
1633
+ y: d.getValueAt(1),
1634
+ z: d.getValueAt(2)
1635
+ }, M = nA(
1636
+ a.position.z,
1637
+ a.scale.z,
1638
+ sA(iA(
1639
+ h,
1640
+ F,
1641
+ I,
1642
+ a == null ? void 0 : a.scale,
1643
+ a == null ? void 0 : a.position,
1644
+ r,
1645
+ i
1646
+ ))
1647
+ ), J = this.getBinContent(
1648
+ h,
1649
+ F.x,
1650
+ F.y,
1651
+ F.z,
1652
+ this.selectedArray
1653
+ );
1654
+ let j = 1;
1655
+ if ((J >= g && J <= p) == !b) {
1656
+ const R = (J - g) / (p - g);
1657
+ if (!b)
1658
+ j = Number.isInteger(J) && J === 0 ? j = 0 : (P - Y) * R + Y;
1659
+ else {
1660
+ const at = (J - v) / (f - v);
1661
+ j = Number.isInteger(J) && J === 0 ? j = 0 : (P - Y) * at + Y;
1662
+ }
1663
+ } else
1664
+ j = 0;
1665
+ this.color = uA(
1666
+ this.config.color,
1667
+ this.availableSets,
1668
+ J,
1669
+ 0,
1670
+ p,
1671
+ x,
1672
+ r
1673
+ );
1674
+ const gt = M.y.size * j;
1675
+ if (j === 0)
1676
+ M.x.size = 0, M.z.size = 0, M.y.size = 0;
1677
+ else if (B)
1678
+ M.x.size *= j, M.z.size *= j, M.y.size = gt;
1679
+ else if (D)
1680
+ M.y.pos -= (M.y.size - gt) / 2, M.y.size = gt;
1681
+ else if (M.y.pos -= (M.y.size - gt) / 2, M.y.size = gt, u) {
1682
+ const R = this.config.TH1ZScale.set;
1683
+ M.z.size = R || 0.01;
1684
+ } else
1685
+ (Ut = (jt = this.config.TH1ZScale) == null ? void 0 : jt.layer) != null && Ut[r] ? M.z.size = a.scale.z * this.config.TH1ZScale.layer[r] : M.z.size = a.scale.z * this.config.TH1ZScale.default;
1686
+ if (u ? (M.z.size = 0.01, M.z.pos += (y - (this.selectedSet.length - 1) / 2) * 0.1, this.setMatrixCacheAt(
1687
+ r,
1688
+ x,
1689
+ T / z,
1690
+ M,
1691
+ r === s && j !== 0 ? this.color : -1
1692
+ )) : (this.pointer.isOnSet && (M.z.size = 0.01, M.z.pos += (y - (this.selectedSet.length - 1) / 2) * 0.1), this.setMatrixCacheAt(
1693
+ r,
1694
+ null,
1695
+ T / z,
1696
+ M,
1697
+ r === s && j !== 0 ? this.color : -1
1698
+ )), r === s) {
1699
+ let R = T;
1700
+ u && (R += this.totalInstances * y);
1701
+ } else {
1702
+ const R = h.getBin(F.x + 1, F.y + 1, F.z + 1);
1703
+ let at;
1704
+ const Zt = {
1705
+ position: new H(M.x.pos, M.y.pos, M.z.pos),
1706
+ scale: new H(M.x.size, M.y.size, M.z.size)
1707
+ };
1708
+ h.children.content ? (at = h.children.content[R], o(T, c, r + 1, at, Zt)) : this.selectedSet.forEach((Jt) => {
1709
+ at = h.children[Jt][R], o(T, c, r + 1, at, Zt, Jt);
1710
+ });
1711
+ }
1712
+ if (!d.increment()) break;
1713
+ }
1714
+ };
1715
+ o(e, A, 0, this.pointer.origin, this.limits).then(() => {
1716
+ setTimeout(() => {
1717
+ this.wireframe.pushVisibleInstances(
1718
+ this.matrixCache,
1719
+ this.maxInstancesPerLayer,
1720
+ this.availableSets.indexOf(this.selectedSet[0])
1721
+ ), this.pushVisibleInstances(), this.BVHTree = dA(
1722
+ this.matrixCache,
1723
+ this.pointer.origin,
1724
+ 0,
1725
+ this.selectedSet,
1726
+ this.availableSets,
1727
+ this.mesh.matrixWorld,
1728
+ this.maxInstancesPerLayer
1729
+ );
1730
+ }, 0);
1731
+ });
1732
+ }
1733
+ createMaterial() {
1734
+ return new ce({
1735
+ vertexShader: `
1736
+ attribute vec3 instancePosition;
1737
+ attribute vec3 instanceScale;
1738
+ attribute float instanceColorIndex;
1739
+
1740
+ uniform vec3 colorArray[32]; // must match maxColors in JS
1741
+
1742
+ varying vec3 vColor;
1743
+
1744
+ void main() {
1745
+ vec3 transformed = position * instanceScale + instancePosition;
1746
+ gl_Position = projectionMatrix * modelViewMatrix * vec4(transformed, 1.0);
1747
+
1748
+ // --- Gradient logic ---
1749
+ float colorIndex = clamp(instanceColorIndex, 0.0, 31.9999); // stay within bounds
1750
+ int idx0 = int(floor(colorIndex));
1751
+ int idx1 = int(ceil(colorIndex));
1752
+ float t = fract(colorIndex); // blend amount between the two colors
1753
+
1754
+ vec3 c0 = colorArray[idx0];
1755
+ vec3 c1 = colorArray[idx1];
1756
+ vColor = mix(c0, c1, t); // smooth blend
1757
+ }
1758
+ `,
1759
+ fragmentShader: `
1760
+ varying vec3 vColor;
1761
+ void main() {
1762
+ gl_FragColor = vec4(vColor, 1.0);
1763
+ }
1764
+ `,
1765
+ transparent: !1
1766
+ });
1767
+ }
1768
+ mouseClickDefault(e) {
1769
+ this.showChildHistogram(e.index), ge().next({
1770
+ // id: this.id + "-cinema",
1771
+ id: "*",
1772
+ obj: e.jsrootObj
1773
+ });
1774
+ }
1775
+ mousemoveDefault(e) {
1776
+ if (((g, p) => {
1777
+ if (g.length !== p.length) return !1;
1778
+ for (let v = 0; v < g.length; v++) {
1779
+ const f = g[v], b = p[v];
1780
+ if (f.x !== b.x || f.y !== b.y || f.z !== b.z) return !1;
1781
+ }
1782
+ return !0;
1783
+ })(e.index, this.dirtyInstance)) {
1784
+ this.dirtyInstance = null;
1785
+ return;
1786
+ }
1787
+ const s = this.pointer.parentPath.map((g) => {
1788
+ const p = g.range[0];
1789
+ return {
1790
+ bin: g.bin[0],
1791
+ ...p
1792
+ };
1793
+ });
1794
+ e.range = e.range.map((g, p) => {
1795
+ const v = e.jsrootInstance[p];
1796
+ return { ...g, bin: v };
1797
+ });
1798
+ const i = {
1799
+ ...e,
1800
+ level: s.length,
1801
+ range: s.concat(e.range)
1802
+ }, { range: o, level: l, content: c, error: r, set: h, triggerSource: a, instanceId: u } = i, d = { coords: o, level: l, content: c, error: r, set: h, triggerSource: a, instanceId: u };
1803
+ me().next(d);
1804
+ }
1805
+ shiftMouseClickDefault(e) {
1806
+ this.hideChildHistogram(e.index);
1807
+ }
1808
+ mouseDBClickDefault(e) {
1809
+ e.set ? this.setPointerToChild(e.index, e.set) : this.setPointerToChild(e.index, this.selectedSet[0]);
1810
+ }
1811
+ shiftMouseDBClickDefault(e) {
1812
+ this.setPointerToParent();
1813
+ }
1814
+ intersectionHandler(e, A) {
1815
+ this.mouseEvents.filter((s) => s.event === A).forEach((s) => s.function(e, this)), this.dirtyInstance = e.index;
1816
+ }
1817
+ raycastHandler(e) {
1818
+ try {
1819
+ const s = this.checkIntersectionBVH(e.ray)[0];
1820
+ if (s) {
1821
+ const i = e._triggerSource;
1822
+ this.intersectionHandler(s, i);
1823
+ }
1824
+ } catch (A) {
1825
+ console.log(A);
1826
+ }
1827
+ }
1828
+ handleStateChange(e) {
1829
+ if (Ae(e.sets, this.availableSets) && (!Ae(e.selectedSet, this.selectedSet) || this.selectedArray !== e.selectedArray)) {
1830
+ this.selectedArray = e.selectedArray, this.selectedSet = e.selectedSet;
1831
+ const A = this.mesh.parent;
1832
+ this.instGeom.dispose(), A.remove(this.mesh), this.setupInsBufGeom(), A.add(this.mesh);
1833
+ const s = this.renderHistory;
1834
+ this.renderHistory = [], s.forEach((i) => {
1835
+ i.procedure === "render" ? this.renderHistogram(
1836
+ i.value.startIndex,
1837
+ i.value.endIndex,
1838
+ i.value.layer
1839
+ ) : i.procedure === "hide" && this.hideChildHistogram(i.value);
1840
+ });
1841
+ } else
1842
+ this.availableSets = e.sets, this.selectedSet = e.selectedSet;
1843
+ }
1844
+ /**
1845
+ * @desc Method to set pointers origin to one of origins child.
1846
+ * In result, only part of histogram specified by child is rendered.
1847
+ * @param position Array in which each entry represents position specified by jsroot.
1848
+ * e.g. ([{x: 1, y: 3, z: 2}, {x: 89, 0, 0}])
1849
+ * @param set Specifies from which set should child be chosen.
1850
+ * If children contains sets, parameter need to be specified.
1851
+ * */
1852
+ setPointerToChild(e, A) {
1853
+ const s = this.mesh.parent;
1854
+ this.matrixCache = [], this.instGeom.dispose(), this.wireframe.dispose(), s.remove(this.mesh);
1855
+ const i = pt(
1856
+ e,
1857
+ A,
1858
+ this.pointer.origin,
1859
+ this.wireframe,
1860
+ this.selectedSet
1861
+ );
1862
+ this.pointer.setOriginToChild(
1863
+ mt(e, this.pointer.origin, this.selectedSet),
1864
+ A,
1865
+ i
1866
+ ), this.init(), console.log("path: ", this.pointer.path), console.log("title: ", this.pointer.title), this.renderHistogram(0, this.totalInstances, 0), s.add(this.mesh), s.add(this.wireframe.wireframe);
1867
+ }
1868
+ /**
1869
+ * @desc Method to set pointers origin to its parent.
1870
+ * * */
1871
+ setPointerToParent() {
1872
+ const e = this.mesh.parent;
1873
+ this.matrixCache = [], this.instGeom.dispose(), this.wireframe.dispose(), e.remove(this.mesh), this.pointer.setOriginToParent(1), console.log("path: ", this.pointer.path), console.log("title: ", this.pointer.title), this.init(), this.renderHistogram(0, this.totalInstances, 0), e.add(this.mesh), e.add(this.wireframe.wireframe);
1874
+ }
1875
+ /**
1876
+ * @desc Method to show (render) histogram that is currently represented by bin.
1877
+ * @param position – should be array with position for each layer.
1878
+ * e.g. ([{x: 1, y: 3, z: 2}, {x: 89, 0, 0}])
1879
+ * */
1880
+ showChildHistogram(e) {
1881
+ const A = Wt(
1882
+ e,
1883
+ this.pointer.origin,
1884
+ this.maxInstancesPerLayer,
1885
+ this.selectedSet
1886
+ ), i = this.maxInstancesPerLayer.slice(
1887
+ -this.maxInstancesPerLayer.length + e.length
1888
+ ).reduce((o, l) => o * l, 1);
1889
+ this.renderHistogram(
1890
+ A.slice(-1)[0],
1891
+ A.slice(-1)[0] + i,
1892
+ e.length
1893
+ );
1894
+ }
1895
+ /**
1896
+ * @desc Method to hide (child) histogram and show (render) bin from layer above.
1897
+ * @param position – should be array with position for each layer.
1898
+ * e.g. ([{x: 1, y: 3, z: 2}, {x: 89, 0, 0}])
1899
+ * */
1900
+ hideChildHistogram(e) {
1901
+ if (e.length === 1) return;
1902
+ const A = this.maxInstancesPerLayer.slice(
1903
+ e.length - 1
1904
+ ), s = this.maxInstancesPerLayer.slice(
1905
+ e.length - 1,
1906
+ this.maxInstancesPerLayer.length - 1
1907
+ ), i = A.reduce(
1908
+ (c, r) => c * r,
1909
+ 1
1910
+ ), o = rA(
1911
+ e,
1912
+ this.pointer.origin,
1913
+ this.maxInstancesPerLayer,
1914
+ this.selectedSet
1915
+ ), l = Math.floor(o / i) * i;
1916
+ this.clearMatrixCacheRange(
1917
+ l,
1918
+ i,
1919
+ s,
1920
+ e.length - 1
1921
+ ), this.logRender({
1922
+ procedure: "hide",
1923
+ value: e
1924
+ }), this.renderHistogram(
1925
+ l,
1926
+ l + i,
1927
+ e.length - 2
1928
+ ), this.renderHistory.pop();
1929
+ }
1930
+ /**
1931
+ * @desc Method to clear matrix cache from start index to end index,
1932
+ * including objects in sub-layers with corresponding index.
1933
+ * @param startIndex Defines linear index from which objects will be deleted.
1934
+ * @param multiplier Defines offset from start index to end index.
1935
+ * At upmost layer endIndex = startIndex + multiplier.
1936
+ * @param dimensions Array with number of instances for each layer that will be cleared.
1937
+ * @param baseLayerIndex start index of layer from which cache is cleared.
1938
+ * */
1939
+ clearMatrixCacheRange(e, A, s, i) {
1940
+ let o = e, l = A;
1941
+ const c = {
1942
+ x: { pos: 0, size: 0 },
1943
+ y: { pos: 0, size: 0 },
1944
+ z: { pos: 0, size: 0 }
1945
+ };
1946
+ for (let r = i + s.length - 1; r >= i; r--) {
1947
+ if (Array.isArray(this.matrixCache[r]))
1948
+ for (let h = 0; h < this.matrixCache[r].length; h++)
1949
+ for (let a = o; a < o + l; a++)
1950
+ this.setMatrixCacheAt(r, h, a, c, -1);
1951
+ else
1952
+ for (let h = o; h < o + l; h++)
1953
+ this.setMatrixCacheAt(r, null, h, c, -1);
1954
+ r > i && (o /= s[r - i], l /= s[r - i]);
1955
+ }
1956
+ }
1957
+ /**
1958
+ * @desc Method to set available sets based on origin.
1959
+ * @param origin Jsroot histogram object
1960
+ * @return is null. Sets that are found are set in stateSubject.
1961
+ * */
1962
+ setAvailableSets(e) {
1963
+ var A;
1964
+ if ((A = e.children) != null && A.content) {
1965
+ const s = e.children.content.find((i) => i);
1966
+ this.setAvailableSets(s);
1967
+ } else if (e != null && e.children) {
1968
+ const s = tt().getValue();
1969
+ s.sets = Object.keys(e.children), s.selectedSet.length === 0 ? (this.selectedSet.push(s.sets[0]), s.selectedSet.push(s.sets[0])) : this.selectedSet.every((i) => s.sets.find((o) => o === i)) || (s.selectedSet = [s.sets[0]]), tt().next(s);
1970
+ } else {
1971
+ const s = tt().getValue();
1972
+ s.sets = [], s.selectedSet = [];
1973
+ }
1974
+ }
1975
+ setAvailableArrays(e) {
1976
+ const A = tt().getValue();
1977
+ A.arrays = [], e.fArrays && (A.arrays = Object.keys(e.fArrays)), A.arrays.unshift("content"), tt().next(A);
1978
+ }
1979
+ /**
1980
+ * @desc Key down handler for nested histogram.
1981
+ * Creates functionality where user can render each layer at once.
1982
+ * @param event Defines incoming event which will be put against regex.
1983
+ * */
1984
+ keyDownHandler(e) {
1985
+ const A = /^(?:Digit|Numpad)(\d+)$/, s = e.code.match(A);
1986
+ if (s) {
1987
+ if (parseInt(s[1]) > this.matrixCache.length) return;
1988
+ const i = new Oe();
1989
+ i.scale.set(0, 0, 0), i.updateMatrix();
1990
+ let o = this.maxInstancesPerLayer.reduce((l, c) => l * c, 1);
1991
+ this.selectedSet.length > 1 && (o *= this.selectedSet.length), this.setupMatrixCache(), this.wireframe.clearWireframe(), this.renderHistogram(
1992
+ 0,
1993
+ this.totalInstances,
1994
+ parseInt(s[1]) - 1
1995
+ );
1996
+ } else e.key === this.keyBindings.hideOutlines ? this.wireframe.toggleVisibility(
1997
+ this.matrixCache,
1998
+ this.maxInstancesPerLayer,
1999
+ this.availableSets.indexOf(this.selectedSet[0])
2000
+ ) : e.key === this.keyBindings.resetHistogram ? this.resetHistogram() : e.key === this.keyBindings.goToPreviousLayer && this.setPointerToParent();
2001
+ }
2002
+ keyUpHandler(e) {
2003
+ }
2004
+ resetHistogram() {
2005
+ this.updateHistogram({ obj: this.rootObj });
2006
+ }
2007
+ /**
2008
+ * Logs rendering events (including showing and hiding child histograms)
2009
+ * to the `renderHistory`.
2010
+ *
2011
+ * This is especially useful when the selected set changes.
2012
+ *
2013
+ * @param {Object} obj - The render operation details.
2014
+ * @param {"render" | "hide"} obj.procedure - The type of operation.
2015
+ * @param {number | Object} obj.value - The associated value:
2016
+ * - If `procedure` is `"hide"`, this is the position used in the hide method.
2017
+ * - If `procedure` is `"render"`, this is an object containing:
2018
+ * @param {number} obj.value.startIndex - The starting index.
2019
+ * @param {number} obj.value.endIndex - The ending index.
2020
+ * @param {number} obj.value.layer - The layer used in rendering.
2021
+ */
2022
+ logRender(e) {
2023
+ e.procedure === "render" && e.value.startIndex === 0 && e.value.endIndex === this.totalInstances && (this.renderHistory = []), this.renderHistory.push(e);
2024
+ }
2025
+ getBinContent(e, A, s, i, o) {
2026
+ var l;
2027
+ if (o === "content" || !e.fArrays)
2028
+ return e.getBinContent(A + 1, s + 1, i + 1);
2029
+ {
2030
+ const c = e.getBin(A + 1, s + 1, i + 1);
2031
+ return (l = e.fArrays) == null ? void 0 : l[o].values[c];
2032
+ }
2033
+ }
2034
+ checkIntersectionBVH(e) {
2035
+ const A = new H(), s = (r, h, a, u) => {
2036
+ var d;
2037
+ if (h < 0 || 1 / h === -1 / 0) {
2038
+ const g = h * -1, p = u && u !== "content" ? (d = this.matrixCache[r]) == null ? void 0 : d[this.availableSets.indexOf(u)] : this.matrixCache[r];
2039
+ return p ? new Bt().setFromCenterAndSize(
2040
+ new H(p.pos[g * 3], p.pos[g * 3 + 1], p.pos[g * 3 + 2]),
2041
+ new H(p.scale[g * 3], p.scale[g * 3 + 1], p.scale[g * 3 + 2])
2042
+ ) : void 0;
2043
+ } else {
2044
+ const g = u && u !== "content" ? this.BVHTree[r][this.availableSets.indexOf(u)][a] : this.BVHTree[r][a];
2045
+ return g ? new Bt().setFromCenterAndSize(
2046
+ new H(g.pos[h * 3], g.pos[h * 3 + 1], g.pos[h * 3 + 2]),
2047
+ new H(g.scale[h * 3], g.scale[h * 3 + 1], g.scale[h * 3 + 2])
2048
+ ) : void 0;
2049
+ }
2050
+ }, i = (r, h) => {
2051
+ let a = 0, u = r, d = h;
2052
+ for (; u + 1 < this.matrixCache.length; ) {
2053
+ u++;
2054
+ const g = this.matrixCache[u];
2055
+ if (Array.isArray(g))
2056
+ this.selectedSet.forEach((p) => {
2057
+ const v = this.availableSets.indexOf(p);
2058
+ for (let f = d; f < d + this.maxInstancesPerLayer[u]; f++)
2059
+ if (g[v].rendered[f] !== -1) {
2060
+ a = u - r;
2061
+ break;
2062
+ }
2063
+ });
2064
+ else {
2065
+ if (!g) return a;
2066
+ for (let p = d; p < d + this.maxInstancesPerLayer[u]; p++)
2067
+ if (g.rendered[p] !== -1) {
2068
+ a = u - r;
2069
+ break;
2070
+ }
2071
+ }
2072
+ d *= this.maxInstancesPerLayer[u + 1];
2073
+ }
2074
+ return a;
2075
+ }, o = (r, h, a, u) => {
2076
+ const d = u && u !== "content" ? this.BVHTree[a][this.availableSets.indexOf(u)][h] : this.BVHTree[a][h], g = s(a, d.left[r], h, u), p = s(a, d.right[r], h, u), v = [];
2077
+ return e.intersectBox(g, A) ? v.push({
2078
+ index: d.left[r],
2079
+ target: A.clone(),
2080
+ distance: e.origin.distanceTo(A)
2081
+ }) : v.push(null), e.intersectBox(p, A) ? v.push({
2082
+ index: d.right[r],
2083
+ target: A.clone(),
2084
+ distance: e.origin.distanceTo(A)
2085
+ }) : v.push(null), v;
2086
+ }, l = (r, h, a) => {
2087
+ const u = [], d = (p) => {
2088
+ if (p.index < 0 || 1 / p.index === -1 / 0) {
2089
+ u.push(p);
2090
+ return;
2091
+ }
2092
+ const [v, f] = o(
2093
+ p.index,
2094
+ h,
2095
+ r,
2096
+ a
2097
+ );
2098
+ v && d(v), f && d(f);
2099
+ }, g = a && a !== "content" ? this.BVHTree[r][this.availableSets.indexOf(a)][h] : this.BVHTree[r][h];
2100
+ return g && d({
2101
+ index: g.left.length - 1,
2102
+ target: null,
2103
+ distance: null
2104
+ }), u;
2105
+ }, c = (r, h, a = 0, u = [], d = void 0) => {
2106
+ const g = [], p = this.maxInstancesPerLayer[h + 1], v = this.maxInstancesPerLayer[h] * this.maxInstancesPerLayer[h + 1];
2107
+ return l(h, a, d).forEach((f) => {
2108
+ var C;
2109
+ const b = Math.abs(f.index) - a * this.maxInstancesPerLayer[h], y = b % r.fXaxis.fNbins, x = Math.floor(
2110
+ b % (r.fXaxis.fNbins * r.fYaxis.fNbins) / r.fXaxis.fNbins
2111
+ ), B = Math.floor(
2112
+ b / (r.fXaxis.fNbins * r.fYaxis.fNbins)
2113
+ ), D = [...u, { x: y, y: x, z: B }];
2114
+ if (r.children) {
2115
+ const O = Object.entries(r.children).flatMap(([I, Y]) => {
2116
+ const P = r.getBin(y + 1, x + 1, B + 1), S = Y == null ? void 0 : Y[P];
2117
+ if (!S) return [];
2118
+ const V = a * v + (y + x * r.fXaxis.fNbins + B * (r.fXaxis.fNbins * r.fYaxis.fNbins)) * p;
2119
+ if (!(i(h, V) > 0)) return [];
2120
+ let Q = c(
2121
+ S,
2122
+ h + 1,
2123
+ Math.abs(f.index),
2124
+ D,
2125
+ I
2126
+ );
2127
+ return I !== "content" && (Q = Q.map((G) => ({ ...G, set: I }))), Q;
2128
+ });
2129
+ if (O.length > 0)
2130
+ g.push(...O);
2131
+ else {
2132
+ const I = a * this.maxInstancesPerLayer[h] + (y + x * r.fXaxis.fNbins + B * (r.fXaxis.fNbins * r.fYaxis.fNbins));
2133
+ (d && d !== "content" ? (C = this.matrixCache[h]) == null ? void 0 : C[this.availableSets.indexOf(d)] : this.matrixCache[h]).rendered[I] !== -1 && g.push({
2134
+ index: D,
2135
+ target: f.target,
2136
+ distance: f.distance,
2137
+ set: d,
2138
+ instanceId: Wt(
2139
+ D,
2140
+ this.pointer.origin,
2141
+ this.maxInstancesPerLayer,
2142
+ this.selectedSet
2143
+ ),
2144
+ jsrootInstance: mt(
2145
+ D,
2146
+ this.pointer.origin,
2147
+ this.selectedSet
2148
+ ),
2149
+ range: pt(
2150
+ D,
2151
+ d,
2152
+ this.pointer.origin,
2153
+ this.wireframe,
2154
+ this.selectedSet
2155
+ ),
2156
+ origin: this,
2157
+ jsrootObj: r,
2158
+ content: this.getBinContent(r, y, x, B, this.selectedArray),
2159
+ error: r.getBinError(y + 1, x + 1, B + 1)
2160
+ });
2161
+ }
2162
+ } else
2163
+ g.push({
2164
+ index: D,
2165
+ target: f.target,
2166
+ distance: f.distance,
2167
+ set: d,
2168
+ instanceId: Wt(
2169
+ D,
2170
+ this.pointer.origin,
2171
+ this.maxInstancesPerLayer,
2172
+ this.selectedSet
2173
+ ),
2174
+ jsrootInstance: mt(
2175
+ D,
2176
+ this.pointer.origin,
2177
+ this.selectedSet
2178
+ ),
2179
+ range: pt(
2180
+ D,
2181
+ d,
2182
+ this.pointer.origin,
2183
+ this.wireframe,
2184
+ this.selectedSet
2185
+ ),
2186
+ origin: this,
2187
+ jsrootObj: r,
2188
+ content: this.getBinContent(r, y, x, B, this.selectedArray),
2189
+ error: r.getBinError(y + 1, x + 1, B + 1)
2190
+ });
2191
+ }), g.sort((f, b) => f.distance - b.distance);
2192
+ };
2193
+ return c(this.pointer.origin, 0);
2194
+ }
2195
+ dispatchSubjectHandler(e) {
2196
+ console.log("dispatch: ", e);
2197
+ const A = e.event.index.map((o) => ({ x: o.x - 1, y: o.y - 1, z: o.z - 1 })), s = this.pointer.getChildByPosition(
2198
+ mt([...A]).slice(0, -1),
2199
+ e.event.set,
2200
+ this.selectedSet
2201
+ ), i = {
2202
+ index: A,
2203
+ set: e.event.set,
2204
+ jsrootInstance: mt(
2205
+ A,
2206
+ this.pointer.origin,
2207
+ this.selectedSet
2208
+ ),
2209
+ range: pt(
2210
+ A,
2211
+ e.event.set,
2212
+ this.pointer.origin,
2213
+ this.wireframe,
2214
+ this.selectedSet
2215
+ ),
2216
+ origin: this,
2217
+ jsrootObj: s,
2218
+ content: this.getBinContent(
2219
+ s,
2220
+ A[0].x + 1,
2221
+ A[0].y + 1,
2222
+ A[0].z + 1,
2223
+ this.selectedArray
2224
+ ),
2225
+ error: s.getBinError(A[0].x + 1, A[0].y + 1, A[0].z + 1)
2226
+ };
2227
+ this.intersectionHandler(i, e.event.source);
2228
+ }
2229
+ }
2230
+ class IA {
2231
+ constructor(t, e, A, s, i) {
2232
+ m(this, "plane");
2233
+ m(this, "cinemaSub");
2234
+ m(this, "position");
2235
+ m(this, "rotation");
2236
+ m(this, "scale");
2237
+ m(this, "id");
2238
+ m(this, "configSub");
2239
+ const o = new ae(s.x, s.y), l = new le({
2240
+ color: new X().setHex(16777215),
2241
+ side: he
2242
+ });
2243
+ this.plane || (this.plane = new Ct(o, l), this.plane.position.set(e.x, e.y, e.z)), t && this.updateTexture(t), this.id = i, this.position = e, this.rotation = A, this.scale = s, this.cinemaSub = ge().getObservable().pipe(ct((c) => c.id === this.id || c.id === "*")).subscribe((c) => {
2244
+ console.log("obj: ", c);
2245
+ const r = c.obj;
2246
+ De({ format: "png", object: r, width: 1200, height: 600 }).then(
2247
+ (h) => {
2248
+ this.updateTexture(h);
2249
+ }
2250
+ );
2251
+ }), this.configSub = lt().getObservable().pipe(
2252
+ ct(
2253
+ (c) => c.target.id.includes("*") || c.target.id.includes(this.id)
2254
+ )
2255
+ ).subscribe((c) => {
2256
+ this.position = c.config.environment.canvas.position, this.rotation = c.config.environment.canvas.rotation, this.scale = c.config.environment.canvas.scale, this.updateMesh();
2257
+ });
2258
+ }
2259
+ updateMesh() {
2260
+ this.plane.scale.set(this.scale.x, this.scale.y, this.scale.z), this.plane.position.set(this.position.x, this.position.y, this.position.z);
2261
+ const t = Math.PI / 180;
2262
+ this.plane.rotation.set(
2263
+ this.rotation.x * t,
2264
+ this.rotation.y * t,
2265
+ this.rotation.z * t
2266
+ );
2267
+ }
2268
+ updateTexture(t) {
2269
+ if (!t) {
2270
+ console.warn("updateTexture called with null/undefined");
2271
+ return;
2272
+ }
2273
+ const e = new He();
2274
+ if (typeof t == "string" && (t.startsWith("data:") || t.startsWith("http")))
2275
+ e.load(
2276
+ t,
2277
+ (A) => {
2278
+ this.plane.material.map = A, this.plane.material.needsUpdate = !0;
2279
+ },
2280
+ void 0,
2281
+ (A) => console.error("Texture load failed", A)
2282
+ );
2283
+ else if (t instanceof HTMLImageElement) {
2284
+ const A = new Texture(t);
2285
+ A.needsUpdate = !0, this.plane.material.map = A, this.plane.material.needsUpdate = !0;
2286
+ } else
2287
+ console.error("Unsupported image type passed to updateTexture:", t);
2288
+ }
2289
+ remove() {
2290
+ this.plane.parent && (this.plane.parent.remove(this.plane), this.cinemaSub.unsubscribe(), this.configSub.unsubscribe());
2291
+ }
2292
+ getPlane() {
2293
+ return this.plane;
2294
+ }
2295
+ }
2296
+ class mA extends Pe {
2297
+ constructor(t) {
2298
+ super(t);
2299
+ }
2300
+ load(t, e, A, s) {
2301
+ const i = this, o = new Ye(this.manager);
2302
+ o.setPath(this.path), o.setRequestHeader(this.requestHeader), o.setWithCredentials(this.withCredentials), o.load(t, function(l) {
2303
+ const c = i.parse(JSON.parse(l));
2304
+ e && e(c);
2305
+ }, A, s);
2306
+ }
2307
+ parse(t) {
2308
+ return new pA(t);
2309
+ }
2310
+ }
2311
+ class pA {
2312
+ constructor(t) {
2313
+ this.isFont = !0, this.type = "Font", this.data = t;
2314
+ }
2315
+ generateShapes(t, e = 100) {
2316
+ const A = [], s = wA(t, e, this.data);
2317
+ for (let i = 0, o = s.length; i < o; i++)
2318
+ A.push(...s[i].toShapes());
2319
+ return A;
2320
+ }
2321
+ }
2322
+ function wA(n, t, e) {
2323
+ const A = Array.from(n), s = t / e.resolution, i = (e.boundingBox.yMax - e.boundingBox.yMin + e.underlineThickness) * s, o = [];
2324
+ let l = 0, c = 0;
2325
+ for (let r = 0; r < A.length; r++) {
2326
+ const h = A[r];
2327
+ if (h === `
2328
+ `)
2329
+ l = 0, c -= i;
2330
+ else {
2331
+ const a = bA(h, s, l, c, e);
2332
+ l += a.offsetX, o.push(a.path);
2333
+ }
2334
+ }
2335
+ return o;
2336
+ }
2337
+ function bA(n, t, e, A, s) {
2338
+ const i = s.glyphs[n] || s.glyphs["?"];
2339
+ if (!i) {
2340
+ console.error('THREE.Font: character "' + n + '" does not exists in font family ' + s.familyName + ".");
2341
+ return;
2342
+ }
2343
+ const o = new qe();
2344
+ let l, c, r, h, a, u, d, g;
2345
+ if (i.o) {
2346
+ const p = i._cachedOutline || (i._cachedOutline = i.o.split(" "));
2347
+ for (let v = 0, f = p.length; v < f; )
2348
+ switch (p[v++]) {
2349
+ case "m":
2350
+ l = p[v++] * t + e, c = p[v++] * t + A, o.moveTo(l, c);
2351
+ break;
2352
+ case "l":
2353
+ l = p[v++] * t + e, c = p[v++] * t + A, o.lineTo(l, c);
2354
+ break;
2355
+ case "q":
2356
+ r = p[v++] * t + e, h = p[v++] * t + A, a = p[v++] * t + e, u = p[v++] * t + A, o.quadraticCurveTo(a, u, r, h);
2357
+ break;
2358
+ case "b":
2359
+ r = p[v++] * t + e, h = p[v++] * t + A, a = p[v++] * t + e, u = p[v++] * t + A, d = p[v++] * t + e, g = p[v++] * t + A, o.bezierCurveTo(a, u, d, g, r, h);
2360
+ break;
2361
+ }
2362
+ }
2363
+ return { offsetX: i.ha * t, path: o };
2364
+ }
2365
+ class vA {
2366
+ constructor(t, e = {}) {
2367
+ this.camera = t, this.options = {
2368
+ backgroundColor: 11184810,
2369
+ textColor: 1,
2370
+ // ROOT color index
2371
+ titleColor: 0,
2372
+ // ROOT color index for title
2373
+ padding: 2e-3,
2374
+ lineHeight: 2e-3,
2375
+ textSize: 10,
2376
+ width: 0.031,
2377
+ ...e
2378
+ }, this.loader = new mA(), this.queue = new ne();
2379
+ let A = !1, s = null;
2380
+ this.queueSub = this.queue.pipe(
2381
+ ve((i) => A ? (s = i, Ce) : (A = !0, xe(this.updateVisualization(i)).pipe(
2382
+ ye(() => {
2383
+ if (A = !1, s) {
2384
+ const o = s;
2385
+ s = null, this.queue.next(o);
2386
+ }
2387
+ })
2388
+ )))
2389
+ ).subscribe(), this.group = new ue();
2390
+ }
2391
+ /**
2392
+ * Parse bin data and extract display information
2393
+ */
2394
+ parseData(t) {
2395
+ const e = [];
2396
+ if (t.title && e.push({ text: t.title, isTitle: !0 }), t.coords && Array.isArray(t.coords) && t.coords.forEach((A) => {
2397
+ Object.entries(A).forEach(([s, i]) => {
2398
+ if (i && typeof i == "object" && !("isColor" in i)) {
2399
+ const o = `${s} = [${i.min.toFixed(2)}, ${i.max.toFixed(2)})`;
2400
+ e.push({ text: o, isTitle: !1 });
2401
+ }
2402
+ });
2403
+ }), t.index && Array.isArray(t.index) && t.index.forEach((A) => {
2404
+ let s = `bin = ${t.object.bins[t.instanceId]}`;
2405
+ Object.entries(A).forEach(([i, o]) => {
2406
+ s += `, ${i}: ${o}`;
2407
+ }), e.push({ text: s, isTitle: !1 });
2408
+ }), t.content !== void 0) {
2409
+ const A = Number.isInteger(t.content) ? `content = ${t.content}` : `content = ${t.content.toFixed(2)}`;
2410
+ e.push({ text: A, isTitle: !1 });
2411
+ }
2412
+ if (t.error !== void 0) {
2413
+ const A = Number.isInteger(t.error) ? `error = ${t.error}` : `error = ${t.error.toFixed(2)}`;
2414
+ e.push({ text: A, isTitle: !1 });
2415
+ }
2416
+ return e;
2417
+ }
2418
+ /**
2419
+ * Create background panel
2420
+ */
2421
+ createBackgroundPanel(t) {
2422
+ const { width: e, backgroundColor: A } = this.options, s = new ae(e, t), i = new le({
2423
+ color: A,
2424
+ side: he
2425
+ });
2426
+ return new Ct(s, i);
2427
+ }
2428
+ /**
2429
+ * Update the 3D visualization
2430
+ * @important DO NOT CALL THIS! Should only be called by queue subject!
2431
+ */
2432
+ async updateVisualization(t) {
2433
+ for (t === null && this.clear(); this.group.children.length > 0; ) {
2434
+ const y = this.group.children[0];
2435
+ y.geometry && y.geometry.dispose(), y.material && y.material.dispose(), this.group.remove(y);
2436
+ }
2437
+ const e = this.parseData(t);
2438
+ if (e.length === 0) return;
2439
+ const { padding: A, lineHeight: s, textSize: i, textColor: o, titleColor: l, width: c } = this.options, r = e.length * s + A * 2, h = this.createBackgroundPanel(r);
2440
+ this.group.add(h);
2441
+ const a = r / 2 - A - s / 2;
2442
+ for (let y = 0; y < e.length; y++) {
2443
+ const x = e[y], B = a - y * s;
2444
+ try {
2445
+ const D = ze("TLatex");
2446
+ D.fTitle = x.text, D.fTextAlign = 12, D.fTextFont = 2, D.fTitleFont = 2, D.fLabelFont = 2, D.fTextColor = x.isTitle ? l : o, D.fTextSize = x.isTitle ? i + 2 : i;
2447
+ const C = await re(D, "p", B * 100, "", "");
2448
+ C.scale.set(16e-5, 16e-5, 16e-5), C.position.x = -(c / 2) + A, C.position.y = B, C.position.z = 1e-3, this.group.add(C);
2449
+ } catch (D) {
2450
+ console.error("Error creating text line:", D);
2451
+ }
2452
+ }
2453
+ const u = new H(t.point.x, t.point.y, t.point.z);
2454
+ this.camera.worldToLocal(u);
2455
+ const d = new H().subVectors(u, this.camera.position).normalize(), p = new H().copy(this.camera.position).addScaledVector(d, 0.1), v = new Bt().setFromObject(this.group), f = new H();
2456
+ v.getSize(f);
2457
+ const b = f.clone().multiplyScalar(0.5);
2458
+ p.add(new H(b.x, b.y, 0)), this.group.position.copy(p), this.camera.add(this.group);
2459
+ }
2460
+ /**
2461
+ * Get the THREE.Group containing the visualization
2462
+ */
2463
+ getGroup() {
2464
+ return this.group;
2465
+ }
2466
+ /**
2467
+ * Set position of the info panel
2468
+ */
2469
+ setPosition(t, e, A) {
2470
+ this.group.position.set(t, e, A);
2471
+ }
2472
+ /**
2473
+ * Set rotation of the info panel
2474
+ */
2475
+ setRotation(t, e, A) {
2476
+ this.group.rotation.set(t, e, A);
2477
+ }
2478
+ /**
2479
+ * Clear panel
2480
+ */
2481
+ clear() {
2482
+ for (; this.group.children.length > 0; ) {
2483
+ const t = this.group.children[0];
2484
+ t.geometry && t.geometry.dispose(), t.material && t.material.dispose(), this.group.remove(t);
2485
+ }
2486
+ }
2487
+ /**
2488
+ * Clean up resources
2489
+ */
2490
+ dispose() {
2491
+ for (this.queueSub.unsubscribe(); this.group.children.length > 0; ) {
2492
+ const t = this.group.children[0];
2493
+ t.geometry && t.geometry.dispose(), t.material && t.material.dispose(), this.group.remove(t);
2494
+ }
2495
+ }
2496
+ }
2497
+ class EA {
2498
+ constructor(t, e, A) {
2499
+ m(this, "histogramGroup");
2500
+ m(this, "binInfoComponent");
2501
+ m(this, "id");
2502
+ m(this, "configSub");
2503
+ m(this, "rootObj");
2504
+ m(this, "histoSub");
2505
+ m(this, "dummyEl");
2506
+ m(this, "defaultRaycastHandler");
2507
+ m(this, "mouseEvents", []);
2508
+ m(this, "color", new X());
2509
+ m(this, "colorTarget", new X(65535));
2510
+ m(this, "buildPromise");
2511
+ this.id = t, this.rootObj = e, this.camera = A, this.histogramGroup = new ue(), this.dummyEl = document.getElementById("dummyDiv" + t), this.dummyEl && document.body.removeChild(this.dummyEl), this.binInfoComponent = new vA(
2512
+ this.camera,
2513
+ {
2514
+ backgroundColor: 3556687,
2515
+ textColor: 0,
2516
+ // ROOT color index
2517
+ titleColor: 0
2518
+ // ROOT color index
2519
+ }
2520
+ ), this.dummyEl = document.createElement("div"), this.dummyEl.id = "dummyDiv" + t, document.body.appendChild(this.dummyEl), this.configSub = lt().getObservable().pipe(ct((s) => s.target.id.includes("*") || s.target.id.includes(this.id))).subscribe((s) => {
2521
+ this.config = { ...s.config };
2522
+ const o = this.config.environment.histogramPads.find((l) => l.id === this.id).position;
2523
+ this.histogramGroup.position.set(o.x, o.y, o.z);
2524
+ }), this.sub = fe().getObservable().pipe(
2525
+ ct(
2526
+ (s) => s.target.id.includes("*") || s.target.id.includes(this.id)
2527
+ )
2528
+ ).subscribe((s) => {
2529
+ if (s.flag === "add")
2530
+ if (s.function)
2531
+ this.addEvent(s.event, s.function);
2532
+ else
2533
+ switch (s.event) {
2534
+ case "mousemove":
2535
+ this.addEvent(s.event, this.mousemoveDefault);
2536
+ break;
2537
+ case "mouseclick":
2538
+ this.addEvent(s.event, this.mouseClickDefault);
2539
+ break;
2540
+ case "shiftmouseclick":
2541
+ this.addEvent(s.event, this.shiftMouseClickDefault);
2542
+ break;
2543
+ case "mousedbclick":
2544
+ this.addEvent(s.event, this.mouseDBClickDefault);
2545
+ break;
2546
+ case "shiftmousedbclick":
2547
+ this.addEvent(s.event, this.shiftMouseDBClickDefault);
2548
+ break;
2549
+ }
2550
+ else if (s.flag === "remove" && s.function)
2551
+ this.removeEvent(s.event, s.function);
2552
+ else if (s.flag === "remove")
2553
+ switch (s == null ? void 0 : s.state) {
2554
+ case "keydown":
2555
+ this.keydownEvents = [];
2556
+ break;
2557
+ case "keyup":
2558
+ this.keyupEvents = [];
2559
+ break;
2560
+ default:
2561
+ this.mouseEvents = this.mouseEvents.filter((i) => i.event !== s.event), this.mousemoveDefault({
2562
+ object: this.getInstancedMesh(),
2563
+ instanceId: null
2564
+ });
2565
+ }
2566
+ else s.flag === "removeAll" && (this.keydownEvents = [], this.keyupEvents = [], this.mouseEvents = []);
2567
+ }), this.raycastHandler = this.raycastHandler.bind(this), this.mouseClickDefault = this.mouseClickDefault.bind(this), this.mousemoveDefault = this.mousemoveDefault.bind(this), this.shiftMouseClickDefault = this.shiftMouseClickDefault.bind(this), this.mouseDBClickDefault = this.mouseDBClickDefault.bind(this), this.shiftMouseDBClickDefault = this.shiftMouseDBClickDefault.bind(this), this.addEvent("mouseclick", this.mouseClickDefault), this.addEvent("mousemove", this.mousemoveDefault), this.addEvent("shiftmouseclick", this.shiftMouseClickDefault), this.addEvent("mousedbclick", this.mouseDBClickDefault), this.addEvent("shiftmousedbclick", this.shiftMouseDBClickDefault), this.buildPromise = this.renderWithBuild3d();
2568
+ }
2569
+ updateHistogram(t) {
2570
+ this.rootObj = t, this.histogramGroup.clear(), this.buildPromise = this.renderWithBuild3d();
2571
+ }
2572
+ renderWithBuild3d() {
2573
+ return re(this.rootObj).then((t) => {
2574
+ var o;
2575
+ const e = (o = this.config.environment.histogramPads.find((l) => l.id === this.id)) == null ? void 0 : o.scale, A = new Bt().setFromObject(t), s = new H();
2576
+ A.getSize(s), t.scale.set(
2577
+ e.x / s.x,
2578
+ e.z / s.y,
2579
+ e.y / s.z
2580
+ ), t.rotateX(-Math.PI / 2), t.translateZ(-(e.y / 2)), this.histogramGroup.add(t);
2581
+ const i = this.getInstancedMesh();
2582
+ i && (this.defaultRaycastHandler = i.raycast.bind(i), i.raycast = this.raycastHandler.bind(this));
2583
+ }).catch((t) => {
2584
+ const e = this.config.environment.histogramPads.find((A) => A.id === this.id);
2585
+ throw console.log("JSROOT was not able to build object: ", t, e), {
2586
+ message: t,
2587
+ scale: e == null ? void 0 : e.scale,
2588
+ position: e == null ? void 0 : e.position
2589
+ };
2590
+ });
2591
+ }
2592
+ raycastHandler(t, e) {
2593
+ this.defaultRaycastHandler(t, e), setTimeout(() => {
2594
+ const A = e.filter((a) => a.instanceId !== void 0).sort((a, u) => a.distance - u.distance)[0];
2595
+ if (!A) {
2596
+ this.mouseEvents.filter((a) => a.event === "mousemove").forEach((a) => a.function(
2597
+ {
2598
+ instanceId: void 0,
2599
+ object: this.getInstancedMesh()
2600
+ },
2601
+ this
2602
+ ));
2603
+ return;
2604
+ }
2605
+ const s = A.object.bins[A.instanceId], i = this.rootObj.fXaxis.fNbins + 2, o = this.rootObj.fYaxis.fNbins + 2, l = {
2606
+ x: s % i,
2607
+ y: Math.floor(s % (i * o) / i),
2608
+ z: Math.floor(s / (i * o))
2609
+ }, c = this.getRangeByPosition([l]), r = this.rootObj.fName, h = {
2610
+ ...A,
2611
+ index: [l],
2612
+ coords: [{ ...c, bin: s, name: r }],
2613
+ content: this.rootObj.getBinContent(l.x, l.y, l.z),
2614
+ error: this.rootObj.getBinError(l.x, l.y, l.z)
2615
+ };
2616
+ this.mouseEvents.filter((a) => a.event === t._triggerSource).forEach((a) => a.function(h, this)), this.dirtyInstance = A.instanceId;
2617
+ }, 0);
2618
+ }
2619
+ /**
2620
+ * @desc Adds function that will be called, if specified event is triggered.
2621
+ * @param event can be either mouseevent in which only name of event is required (e.g. mousclick, shiftmousedbclick),
2622
+ * or keyboard event which has to concise state (keydown or keyup) and keyCode (e.g. Numpad1)
2623
+ * @param func Function that is called if event is triggered.
2624
+ * */
2625
+ addEvent(t, e) {
2626
+ (t == null ? void 0 : t.state) === "keydown" ? this.keydownEvents.push({
2627
+ key: t.key,
2628
+ function: e
2629
+ }) : (t == null ? void 0 : t.state) === "keyup" ? this.keyupEvents.push({
2630
+ key: t.key,
2631
+ function: e
2632
+ }) : this.mouseEvents.push({
2633
+ event: t,
2634
+ function: e
2635
+ });
2636
+ }
2637
+ /**
2638
+ * @desc Removes function from event listener.
2639
+ * @param event Defines from which event should listening be removed.
2640
+ * @param func has to have same reference to one that was added by addEvent.
2641
+ * */
2642
+ removeEvent(t, e) {
2643
+ const A = this.mouseEvents.find((s) => s === e);
2644
+ A && this.mouseEvents.splice(A, 1);
2645
+ }
2646
+ mouseClickDefault(t) {
2647
+ console.log("mouseclick default");
2648
+ }
2649
+ mousemoveDefault(t) {
2650
+ if (t.instanceId === this.dirtyInstance) return;
2651
+ const e = t.object;
2652
+ if (this.dirtyInstance !== void 0) {
2653
+ e.getColorAt(this.dirtyInstance, this.color);
2654
+ const A = 0.5;
2655
+ this.color.lerp(this.colorTarget, -A / (1 - A)), e.setColorAt(this.dirtyInstance, this.color);
2656
+ }
2657
+ this.dirtyInstance = t.instanceId, e.getColorAt(this.dirtyInstance, this.color), this.color.lerp(this.colorTarget, 0.5), e.setColorAt(this.dirtyInstance, this.color), e.instanceColor.needsUpdate = !0, this.binInfoComponent.queue.next(t), me().next(t);
2658
+ }
2659
+ shiftMouseClickDefault(t) {
2660
+ console.log("shiftMouseClickDefault");
2661
+ }
2662
+ mouseDBClickDefault(t) {
2663
+ console.log("mouseDBClickDefault");
2664
+ }
2665
+ shiftMouseDBClickDefault(t) {
2666
+ console.log("shiftMouseDBClickDefault");
2667
+ }
2668
+ getInstancedMesh(t = this.histogramGroup) {
2669
+ if (!t) return null;
2670
+ if (t.isInstancedMesh === !0)
2671
+ return t;
2672
+ if (t.children && t.children.length > 0)
2673
+ for (const e of t.children) {
2674
+ const A = this.getInstancedMesh(e);
2675
+ if (A) return A;
2676
+ }
2677
+ return null;
2678
+ }
2679
+ /**
2680
+ * Method to obtain range of axes.
2681
+ * @param position – should be array with position for each layer.
2682
+ * e.g. ([{x: 1, y: 3, z: 2}, {x: 89, 0, 0}])
2683
+ * */
2684
+ getRangeByPosition(t) {
2685
+ const e = ["x", "y", "z"], A = Number.parseInt(this.rootObj._typename.substring(2, 3), 10);
2686
+ let s = {};
2687
+ if (t[0]) {
2688
+ for (let i = 0; i < A; i++) {
2689
+ const o = e[i], l = this.rootObj[`f${o.toUpperCase()}axis`], c = t[0][o];
2690
+ s[o] = {
2691
+ min: l.GetBinLowEdge(c),
2692
+ max: l.GetBinCenter(c) * 2 - l.GetBinLowEdge(c),
2693
+ name: l.fName,
2694
+ title: l.fTitle
2695
+ };
2696
+ }
2697
+ s = { ...s, color: new X(0) };
2698
+ }
2699
+ return s;
2700
+ }
2701
+ remove() {
2702
+ this.histogramGroup.parent.remove(this.histogramGroup), this.dummyEl = document.getElementById("dummyDiv" + this.id), this.dummyEl && document.body.removeChild(this.dummyEl), this.configSub.unsubscribe(), this.sub.unsubscribe();
2703
+ }
2704
+ getHistogramMesh() {
2705
+ return this.histogramGroup;
2706
+ }
2707
+ }
2708
+ export {
2709
+ IA as CanvasClass,
2710
+ EA as HistogramJsrootClass,
2711
+ ie as HistogramPointerClass,
2712
+ HA as MobileController,
2713
+ YA as NdmvrRaycaster,
2714
+ qA as THnPainter,
2715
+ me as binInfoSubjectGet,
2716
+ Ee as brokerManagerGet,
2717
+ ge as canvasSubjectGet,
2718
+ lt as configSubjectGet,
2719
+ Ge as dispatchSubjectGet,
2720
+ PA as fetchTFile,
2721
+ fe as functionSubjectGet,
2722
+ OA as getCameraComponent,
2723
+ MA as histogramSubjectGet,
2724
+ zA as httpRequest,
2725
+ DA as initNdmvrAframe,
2726
+ de as inputDeviceSubjectGet,
2727
+ tt as stateSubjectGet
2728
+ };