dhx-react-suite 1.1.8 → 1.1.9

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.
@@ -1,6 +1,6 @@
1
1
  import { jsxs as g, jsx as t, Fragment as Ye } from "react/jsx-runtime";
2
- import { useEffect as _, useRef as oe, useCallback as ae, useState as N, useMemo as ue, createContext as Qe, useContext as Ze } from "react";
3
- import { Tooltip as et, Legend as tt, CartesianGrid as nt, XAxis as Ee, YAxis as Re, BarChart as rt, Bar as ot, LineChart as it, Line as lt, AreaChart as st, Area as at, PieChart as dt, Pie as ct, Cell as ut, RadarChart as pt, PolarGrid as ht, PolarAngleAxis as ft, PolarRadiusAxis as xt, Radar as gt, ScatterChart as yt, Scatter as bt, ResponsiveContainer as mt, Treemap as vt } from "recharts";
2
+ import { useEffect as J, useRef as le, useCallback as ae, useState as B, useMemo as ue, createContext as Qe, useContext as Ze } from "react";
3
+ import { Tooltip as et, Legend as tt, CartesianGrid as nt, XAxis as Ne, YAxis as Ee, BarChart as rt, Bar as ot, LineChart as it, Line as lt, AreaChart as st, Area as at, PieChart as dt, Pie as ct, Cell as ut, RadarChart as pt, PolarGrid as ht, PolarAngleAxis as ft, PolarRadiusAxis as gt, Radar as xt, ScatterChart as yt, Scatter as bt, ResponsiveContainer as mt, Treemap as vt } from "recharts";
4
4
  const e = {
5
5
  primary: "#0288d1",
6
6
  primaryDk: "#01579b",
@@ -21,7 +21,7 @@ const e = {
21
21
  rMd: "8px",
22
22
  font: "'Segoe UI', system-ui, -apple-system, sans-serif"
23
23
  }, We = "dhx-react-styles";
24
- function q() {
24
+ function Q() {
25
25
  if (typeof document > "u" || document.getElementById(We)) return;
26
26
  const n = document.createElement("style");
27
27
  n.id = We, n.textContent = `
@@ -66,28 +66,28 @@ function q() {
66
66
  .dhx-tag-warning{background:#fff3e0;color:#e65100}
67
67
  `, document.head.appendChild(n);
68
68
  }
69
- const kt = {
69
+ const St = {
70
70
  sm: { height: 24, padding: "0 8px", fontSize: 12 },
71
71
  md: {},
72
72
  lg: { height: 38, padding: "0 18px", fontSize: 14 }
73
73
  };
74
- function _t({
74
+ function Xt({
75
75
  children: n,
76
- variant: o = "primary",
76
+ variant: i = "primary",
77
77
  size: d = "md",
78
78
  icon: l,
79
- disabled: f,
80
- onClick: a,
81
- style: h,
82
- className: u = ""
79
+ disabled: u,
80
+ onClick: s,
81
+ style: f,
82
+ className: p = ""
83
83
  }) {
84
- return _(q, []), /* @__PURE__ */ g(
84
+ return J(Q, []), /* @__PURE__ */ g(
85
85
  "button",
86
86
  {
87
- className: `dhx dhx-btn dhx-btn-${o} ${u}`,
88
- style: { ...kt[d], ...h },
89
- disabled: f,
90
- onClick: a,
87
+ className: `dhx dhx-btn dhx-btn-${i} ${p}`,
88
+ style: { ...St[d], ...f },
89
+ disabled: u,
90
+ onClick: s,
91
91
  children: [
92
92
  l && /* @__PURE__ */ t("span", { style: { fontSize: 16 }, children: l }),
93
93
  n
@@ -95,83 +95,83 @@ function _t({
95
95
  }
96
96
  );
97
97
  }
98
- function ge(n, o) {
99
- _(() => {
98
+ function xe(n, i) {
99
+ J(() => {
100
100
  const d = (l) => {
101
- n.current && !n.current.contains(l.target) && o(l);
101
+ n.current && !n.current.contains(l.target) && i(l);
102
102
  };
103
103
  return document.addEventListener("mousedown", d), () => document.removeEventListener("mousedown", d);
104
- }, [n, o]);
104
+ }, [n, i]);
105
105
  }
106
- function St(n) {
107
- const o = oe(!1), d = oe({ x: 0, y: 0, ox: 0, oy: 0 });
106
+ function kt(n) {
107
+ const i = le(!1), d = le({ x: 0, y: 0, ox: 0, oy: 0 });
108
108
  return ae(
109
- (l, f = 0, a = 0) => {
110
- o.current = !0, d.current = { x: l.clientX, y: l.clientY, ox: f, oy: a };
111
- const h = (x) => {
112
- if (!o.current) return;
113
- const { x: w, y: r, ox: i, oy: c } = d.current;
114
- n(i + x.clientX - w, c + x.clientY - r);
115
- }, u = () => {
116
- o.current = !1, document.removeEventListener("mousemove", h), document.removeEventListener("mouseup", u);
109
+ (l, u = 0, s = 0) => {
110
+ i.current = !0, d.current = { x: l.clientX, y: l.clientY, ox: u, oy: s };
111
+ const f = (x) => {
112
+ if (!i.current) return;
113
+ const { x: z, y: r, ox: b, oy: h } = d.current;
114
+ n(b + x.clientX - z, h + x.clientY - r);
115
+ }, p = () => {
116
+ i.current = !1, document.removeEventListener("mousemove", f), document.removeEventListener("mouseup", p);
117
117
  };
118
- document.addEventListener("mousemove", h), document.addEventListener("mouseup", u), l.preventDefault();
118
+ document.addEventListener("mousemove", f), document.addEventListener("mouseup", p), l.preventDefault();
119
119
  },
120
120
  [n]
121
121
  );
122
122
  }
123
- function be({ items: n, onSelect: o, style: d }) {
124
- const [l, f] = N(null);
125
- return /* @__PURE__ */ t("div", { className: "dhx dhx-anim-fade", style: { position: "absolute", top: "calc(100% + 4px)", left: 0, minWidth: 180, background: e.surface, border: `1px solid ${e.border}`, borderRadius: e.r, boxShadow: e.shadowLg, zIndex: 200, padding: "4px 0", ...d }, children: n.map((a, h) => {
126
- var x, w;
127
- if (a.type === "separator") return /* @__PURE__ */ t("div", { style: { height: 1, background: e.border, margin: "4px 0" } }, h);
128
- const u = l === h;
129
- return /* @__PURE__ */ g("div", { style: { position: "relative" }, onMouseEnter: () => f(h), onMouseLeave: () => f(null), children: [
123
+ function ge({ items: n, onSelect: i, style: d }) {
124
+ const [l, u] = B(null);
125
+ return /* @__PURE__ */ t("div", { className: "dhx dhx-anim-fade", style: { position: "absolute", top: "calc(100% + 4px)", left: 0, minWidth: 180, background: e.surface, border: `1px solid ${e.border}`, borderRadius: e.r, boxShadow: e.shadowLg, zIndex: 200, padding: "4px 0", ...d }, children: n.map((s, f) => {
126
+ var x, z;
127
+ if (s.type === "separator") return /* @__PURE__ */ t("div", { style: { height: 1, background: e.border, margin: "4px 0" } }, f);
128
+ const p = l === f;
129
+ return /* @__PURE__ */ g("div", { style: { position: "relative" }, onMouseEnter: () => u(f), onMouseLeave: () => u(null), children: [
130
130
  /* @__PURE__ */ g(
131
131
  "div",
132
132
  {
133
133
  onClick: () => {
134
134
  var r;
135
- return !a.disabled && !((r = a.items) != null && r.length) && o(a);
135
+ return !s.disabled && !((r = s.items) != null && r.length) && i(s);
136
136
  },
137
- style: { display: "flex", alignItems: "center", gap: 8, padding: "8px 14px", cursor: a.disabled ? "not-allowed" : "pointer", fontSize: 13, color: a.disabled ? e.textMut : e.text, background: u && !a.disabled ? e.bg : "transparent", opacity: a.disabled ? 0.5 : 1 },
137
+ style: { display: "flex", alignItems: "center", gap: 8, padding: "8px 14px", cursor: s.disabled ? "not-allowed" : "pointer", fontSize: 13, color: s.disabled ? e.textMut : e.text, background: p && !s.disabled ? e.bg : "transparent", opacity: s.disabled ? 0.5 : 1 },
138
138
  children: [
139
- a.icon && /* @__PURE__ */ t("span", { style: { fontSize: 15, width: 18, textAlign: "center" }, children: a.icon }),
140
- /* @__PURE__ */ t("span", { style: { flex: 1 }, children: a.value || a.id }),
141
- a.hotkey && /* @__PURE__ */ t("span", { style: { fontSize: 11, color: e.textMut }, children: a.hotkey }),
142
- (x = a.items) != null && x.length ? /* @__PURE__ */ t("span", { style: { fontSize: 10, color: e.textMut }, children: "▶" }) : null
139
+ s.icon && /* @__PURE__ */ t("span", { style: { fontSize: 15, width: 18, textAlign: "center" }, children: s.icon }),
140
+ /* @__PURE__ */ t("span", { style: { flex: 1 }, children: s.value || s.id }),
141
+ s.hotkey && /* @__PURE__ */ t("span", { style: { fontSize: 11, color: e.textMut }, children: s.hotkey }),
142
+ (x = s.items) != null && x.length ? /* @__PURE__ */ t("span", { style: { fontSize: 10, color: e.textMut }, children: "▶" }) : null
143
143
  ]
144
144
  }
145
145
  ),
146
- u && ((w = a.items) != null && w.length) ? /* @__PURE__ */ t(be, { items: a.items, onSelect: o, style: { position: "absolute", left: "100%", top: -4 } }) : null
147
- ] }, a.id || h);
146
+ p && ((z = s.items) != null && z.length) ? /* @__PURE__ */ t(ge, { items: s.items, onSelect: i, style: { position: "absolute", left: "100%", top: -4 } }) : null
147
+ ] }, s.id || f);
148
148
  }) });
149
149
  }
150
- function Vt({ items: n = [], label: o = "Menu", onSelect: d, style: l }) {
151
- const [f, a] = N(!1), h = oe(null);
152
- return _(q, []), ge(h, ae(() => a(!1), [])), /* @__PURE__ */ g("div", { ref: h, className: "dhx", style: { position: "relative", display: "inline-block", ...l }, children: [
153
- /* @__PURE__ */ g("button", { className: "dhx dhx-btn dhx-btn-secondary", onClick: () => a((u) => !u), children: [
154
- o,
150
+ function qt({ items: n = [], label: i = "Menu", onSelect: d, style: l }) {
151
+ const [u, s] = B(!1), f = le(null);
152
+ return J(Q, []), xe(f, ae(() => s(!1), [])), /* @__PURE__ */ g("div", { ref: f, className: "dhx", style: { position: "relative", display: "inline-block", ...l }, children: [
153
+ /* @__PURE__ */ g("button", { className: "dhx dhx-btn dhx-btn-secondary", onClick: () => s((p) => !p), children: [
154
+ i,
155
155
  " ",
156
- /* @__PURE__ */ t("span", { style: { fontSize: 10 }, children: f ? "▲" : "▼" })
156
+ /* @__PURE__ */ t("span", { style: { fontSize: 10 }, children: u ? "▲" : "▼" })
157
157
  ] }),
158
- f && /* @__PURE__ */ t(be, { items: n, onSelect: (u) => {
159
- d == null || d(u), a(!1);
158
+ u && /* @__PURE__ */ t(ge, { items: n, onSelect: (p) => {
159
+ d == null || d(p), s(!1);
160
160
  } })
161
161
  ] });
162
162
  }
163
- function Xt({ items: n = [], onSelect: o, children: d }) {
164
- const [l, f] = N(null), a = oe(null);
165
- return _(q, []), ge(a, ae(() => f(null), [])), /* @__PURE__ */ g("div", { ref: a, onContextMenu: (u) => {
166
- u.preventDefault(), f({ x: u.clientX, y: u.clientY });
163
+ function Gt({ items: n = [], onSelect: i, children: d }) {
164
+ const [l, u] = B(null), s = le(null);
165
+ return J(Q, []), xe(s, ae(() => u(null), [])), /* @__PURE__ */ g("div", { ref: s, onContextMenu: (p) => {
166
+ p.preventDefault(), u({ x: p.clientX, y: p.clientY });
167
167
  }, style: { position: "relative", display: "contents" }, children: [
168
168
  d,
169
- l && /* @__PURE__ */ t("div", { style: { position: "fixed", left: l.x, top: l.y, zIndex: 9999 }, children: /* @__PURE__ */ t(be, { items: n, onSelect: (u) => {
170
- o == null || o(u), f(null);
169
+ l && /* @__PURE__ */ t("div", { style: { position: "fixed", left: l.x, top: l.y, zIndex: 9999 }, children: /* @__PURE__ */ t(ge, { items: n, onSelect: (p) => {
170
+ i == null || i(p), u(null);
171
171
  } }) })
172
172
  ] });
173
173
  }
174
- function Ae({ count: n }) {
174
+ function Be({ count: n }) {
175
175
  return /* @__PURE__ */ t("span", { style: {
176
176
  position: "absolute",
177
177
  top: 2,
@@ -191,33 +191,33 @@ function Ae({ count: n }) {
191
191
  pointerEvents: "none"
192
192
  }, children: n });
193
193
  }
194
- function qt({ items: n = [], onAction: o, style: d }) {
195
- const [l, f] = N(null), [a, h] = N(() => {
194
+ function Jt({ items: n = [], onAction: i, style: d }) {
195
+ const [l, u] = B(null), [s, f] = B(() => {
196
196
  const r = {};
197
- return n.forEach((i) => {
198
- i.id && (i.twoState || i.group) && i.active && (r[i.id] = !0);
197
+ return n.forEach((b) => {
198
+ b.id && (b.twoState || b.group) && b.active && (r[b.id] = !0);
199
199
  }), r;
200
- }), u = oe(null);
201
- _(q, []), ge(u, ae(() => f(null), []));
202
- const x = (r, i) => {
203
- var c, m;
200
+ }), p = le(null);
201
+ J(Q, []), xe(p, ae(() => u(null), []));
202
+ const x = (r, b) => {
203
+ var h, M;
204
204
  if (!r.disabled) {
205
- if (r.twoState && r.id && h((S) => ({ ...S, [r.id]: !S[r.id] })), r.group && r.id && h((S) => {
206
- const s = { ...S };
207
- return n.forEach((b) => {
208
- b.group === r.group && b.id && (s[b.id] = !1);
209
- }), s[r.id] = !0, s;
210
- }), (c = r.items) != null && c.length) {
211
- f((S) => S === i ? null : i);
205
+ if (r.twoState && r.id && f((R) => ({ ...R, [r.id]: !R[r.id] })), r.group && r.id && f((R) => {
206
+ const a = { ...R };
207
+ return n.forEach((k) => {
208
+ k.group === r.group && k.id && (a[k.id] = !1);
209
+ }), a[r.id] = !0, a;
210
+ }), (h = r.items) != null && h.length) {
211
+ u((R) => R === b ? null : b);
212
212
  return;
213
213
  }
214
- (m = r.onClick) == null || m.call(r, r.id || ""), o == null || o(r.id || "");
214
+ (M = r.onClick) == null || M.call(r, r.id || ""), i == null || i(r.id || "");
215
215
  }
216
- }, w = (r, i) => {
217
- var s, b;
216
+ }, z = (r, b) => {
217
+ var a, k;
218
218
  if (r.hidden) return null;
219
- if (r.type === "separator") return /* @__PURE__ */ t("div", { style: { width: 1, background: e.border, margin: "6px 4px", alignSelf: "stretch" } }, i);
220
- if (r.type === "spacer") return /* @__PURE__ */ t("div", { style: { flex: 1 } }, i);
219
+ if (r.type === "separator") return /* @__PURE__ */ t("div", { style: { width: 1, background: e.border, margin: "6px 4px", alignSelf: "stretch" } }, b);
220
+ if (r.type === "spacer") return /* @__PURE__ */ t("div", { style: { flex: 1 } }, b);
221
221
  if (r.type === "input") return /* @__PURE__ */ g("div", { style: { display: "flex", alignItems: "center", gap: 6 }, children: [
222
222
  r.label && /* @__PURE__ */ t("span", { style: { fontSize: 12, color: e.textSec, fontWeight: 500 }, children: r.label }),
223
223
  /* @__PURE__ */ g("div", { style: { position: "relative", display: "flex", alignItems: "center" }, children: [
@@ -229,14 +229,14 @@ function qt({ items: n = [], onAction: o, style: d }) {
229
229
  style: { width: r.width || 140, height: 28, paddingLeft: r.icon ? 30 : void 0 },
230
230
  placeholder: r.placeholder,
231
231
  defaultValue: r.value,
232
- onChange: (M) => {
233
- var D;
234
- return (D = r.onChange) == null ? void 0 : D.call(r, M.target.value);
232
+ onChange: (C) => {
233
+ var L;
234
+ return (L = r.onChange) == null ? void 0 : L.call(r, C.target.value);
235
235
  }
236
236
  }
237
237
  )
238
238
  ] })
239
- ] }, i);
239
+ ] }, b);
240
240
  if (r.type === "select") return /* @__PURE__ */ g("div", { style: { display: "flex", alignItems: "center", gap: 6 }, children: [
241
241
  r.label && /* @__PURE__ */ t("span", { style: { fontSize: 12, color: e.textSec, fontWeight: 500 }, children: r.label }),
242
242
  /* @__PURE__ */ t(
@@ -245,14 +245,14 @@ function qt({ items: n = [], onAction: o, style: d }) {
245
245
  className: "dhx dhx-input",
246
246
  style: { width: r.width || 100, height: 28, cursor: "pointer" },
247
247
  defaultValue: r.value,
248
- onChange: (M) => {
249
- var D;
250
- return (D = r.onChange) == null ? void 0 : D.call(r, M.target.value);
248
+ onChange: (C) => {
249
+ var L;
250
+ return (L = r.onChange) == null ? void 0 : L.call(r, C.target.value);
251
251
  },
252
- children: (s = r.options) == null ? void 0 : s.map((M) => /* @__PURE__ */ t("option", { value: M.value, children: M.label }, M.value))
252
+ children: (a = r.options) == null ? void 0 : a.map((C) => /* @__PURE__ */ t("option", { value: C.value, children: C.label }, C.value))
253
253
  }
254
254
  )
255
- ] }, i);
255
+ ] }, b);
256
256
  if (r.type === "imageButton") return /* @__PURE__ */ g(
257
257
  "button",
258
258
  {
@@ -270,15 +270,15 @@ function qt({ items: n = [], onAction: o, style: d }) {
270
270
  background: "transparent",
271
271
  flexShrink: 0
272
272
  },
273
- onClick: () => x(r, i),
273
+ onClick: () => x(r, b),
274
274
  children: [
275
275
  r.src && /* @__PURE__ */ t("img", { src: r.src, alt: r.value || "", style: { width: "100%", height: "100%", objectFit: "cover", borderRadius: "50%" } }),
276
- r.count !== void 0 && /* @__PURE__ */ t(Ae, { count: r.count })
276
+ r.count !== void 0 && /* @__PURE__ */ t(Be, { count: r.count })
277
277
  ]
278
278
  },
279
- i
279
+ b
280
280
  );
281
- const c = !!(r.id && a[r.id]), m = r.value ?? r.text, S = !!((b = r.items) != null && b.length);
281
+ const h = !!(r.id && s[r.id]), M = r.value ?? r.text, R = !!((k = r.items) != null && k.length);
282
282
  return /* @__PURE__ */ g("div", { style: { position: "relative" }, children: [
283
283
  /* @__PURE__ */ g(
284
284
  "button",
@@ -290,34 +290,34 @@ function qt({ items: n = [], onAction: o, style: d }) {
290
290
  height: 32,
291
291
  gap: 4,
292
292
  position: "relative",
293
- background: c ? e.primaryLt : "transparent",
294
- color: c ? e.primary : r.disabled ? e.textMut : e.text,
293
+ background: h ? e.primaryLt : "transparent",
294
+ color: h ? e.primary : r.disabled ? e.textMut : e.text,
295
295
  opacity: r.disabled ? 0.55 : 1,
296
296
  cursor: r.disabled ? "not-allowed" : "pointer"
297
297
  },
298
- onClick: () => x(r, i),
298
+ onClick: () => x(r, b),
299
299
  children: [
300
300
  r.icon && /* @__PURE__ */ t("span", { style: { fontSize: 16 }, children: r.icon }),
301
- m && /* @__PURE__ */ t("span", { style: { fontSize: 13 }, children: m }),
302
- S && /* @__PURE__ */ t("span", { style: { fontSize: 9, opacity: 0.55, marginLeft: 2 }, children: "▼" }),
303
- r.count !== void 0 && /* @__PURE__ */ t(Ae, { count: r.count })
301
+ M && /* @__PURE__ */ t("span", { style: { fontSize: 13 }, children: M }),
302
+ R && /* @__PURE__ */ t("span", { style: { fontSize: 9, opacity: 0.55, marginLeft: 2 }, children: "▼" }),
303
+ r.count !== void 0 && /* @__PURE__ */ t(Be, { count: r.count })
304
304
  ]
305
305
  }
306
306
  ),
307
- S && l === i && /* @__PURE__ */ t(
308
- be,
307
+ R && l === b && /* @__PURE__ */ t(
308
+ ge,
309
309
  {
310
310
  items: r.items,
311
- onSelect: () => f(null),
311
+ onSelect: () => u(null),
312
312
  style: { top: "100%", left: 0 }
313
313
  }
314
314
  )
315
- ] }, i);
315
+ ] }, b);
316
316
  };
317
317
  return /* @__PURE__ */ t(
318
318
  "div",
319
319
  {
320
- ref: u,
320
+ ref: p,
321
321
  className: "dhx",
322
322
  style: {
323
323
  display: "flex",
@@ -330,72 +330,72 @@ function qt({ items: n = [], onAction: o, style: d }) {
330
330
  flexWrap: "wrap",
331
331
  ...d
332
332
  },
333
- children: n.map(w)
333
+ children: n.map(z)
334
334
  }
335
335
  );
336
336
  }
337
337
  function wt(n) {
338
338
  return n === "primary" ? e.primary : n === "success" ? "#43a047" : n === "secondary" ? "#9e9e9e" : "#e53935";
339
339
  }
340
- function zt(n, o) {
341
- const d = [], l = (f) => {
342
- var a;
343
- f.id && f.group === o && d.push(f.id), (a = f.items) == null || a.forEach(l);
340
+ function zt(n, i) {
341
+ const d = [], l = (u) => {
342
+ var s;
343
+ u.id && u.group === i && d.push(u.id), (s = u.items) == null || s.forEach(l);
344
344
  };
345
345
  return n.forEach(l), d;
346
346
  }
347
347
  function Mt(n) {
348
- const o = {}, d = (l) => {
349
- var f;
350
- l.id && l.twoState && l.active && (o[l.id] = !0), (f = l.items) == null || f.forEach(d);
348
+ const i = {}, d = (l) => {
349
+ var u;
350
+ l.id && l.twoState && l.active && (i[l.id] = !0), (u = l.items) == null || u.forEach(d);
351
351
  };
352
- return n.forEach(d), o;
352
+ return n.forEach(d), i;
353
353
  }
354
- function Gt({
354
+ function Ut({
355
355
  items: n = [],
356
- width: o = 240,
356
+ width: i = 240,
357
357
  minWidth: d = 64,
358
358
  header: l,
359
- footer: f,
360
- collapsed: a,
361
- defaultCollapsed: h,
362
- selected: u,
359
+ footer: u,
360
+ collapsed: s,
361
+ defaultCollapsed: f,
362
+ selected: p,
363
363
  defaultSelected: x,
364
- onSelect: w,
364
+ onSelect: z,
365
365
  onCollapse: r,
366
- onExpand: i,
367
- onBeforeCollapse: c,
368
- onBeforeExpand: m,
369
- onToggleItem: S,
370
- style: s
366
+ onExpand: b,
367
+ onBeforeCollapse: h,
368
+ onBeforeExpand: M,
369
+ onToggleItem: R,
370
+ style: a
371
371
  }) {
372
- const b = a !== void 0, M = u !== void 0, [D, R] = N(h ?? !1), [z, C] = N(x ?? null), [F, p] = N({}), [I, W] = N(() => Mt(n));
373
- _(q, []);
374
- const v = b ? a : D, X = M ? u ?? null : z, J = v ? d : o, se = () => {
375
- if (v) {
376
- if ((m == null ? void 0 : m()) === !1) return;
377
- b || R(!1), i == null || i();
372
+ const k = s !== void 0, C = p !== void 0, [L, H] = B(f ?? !1), [$, D] = B(x ?? null), [K, c] = B({}), [N, A] = B(() => Mt(n));
373
+ J(Q, []);
374
+ const S = k ? s : L, U = C ? p ?? null : $, Z = S ? d : i, o = () => {
375
+ if (S) {
376
+ if ((M == null ? void 0 : M()) === !1) return;
377
+ k || H(!1), b == null || b();
378
378
  } else {
379
- if ((c == null ? void 0 : c()) === !1) return;
380
- b || R(!0), r == null || r();
379
+ if ((h == null ? void 0 : h()) === !1) return;
380
+ k || H(!0), r == null || r();
381
381
  }
382
- }, U = (k) => {
383
- M || C(k.id ?? null), w == null || w(k), k.id && k.onClick && k.onClick(k.id);
384
- }, ie = (k) => {
385
- if (!k.id) return;
386
- const P = !I[k.id];
387
- let O = { ...I, [k.id]: P };
388
- k.group && P && zt(n, k.group).forEach((G) => {
389
- G !== k.id && (O[G] = !1);
390
- }), W(O), S == null || S(k.id, P);
391
- }, E = (k, P) => {
392
- if (k.count === void 0) return null;
393
- const O = wt(k.countColor), G = k.count > 99 ? "99+" : String(k.count);
394
- return P ? /* @__PURE__ */ t("span", { style: {
382
+ }, E = (m) => {
383
+ C || D(m.id ?? null), z == null || z(m), m.id && m.onClick && m.onClick(m.id);
384
+ }, _ = (m) => {
385
+ if (!m.id) return;
386
+ const j = !N[m.id];
387
+ let Y = { ...N, [m.id]: j };
388
+ m.group && j && zt(n, m.group).forEach((G) => {
389
+ G !== m.id && (Y[G] = !1);
390
+ }), A(Y), R == null || R(m.id, j);
391
+ }, w = (m, j) => {
392
+ if (m.count === void 0) return null;
393
+ const Y = wt(m.countColor), G = m.count > 99 ? "99+" : String(m.count);
394
+ return j ? /* @__PURE__ */ t("span", { style: {
395
395
  position: "absolute",
396
396
  top: 1,
397
397
  right: 1,
398
- background: O,
398
+ background: Y,
399
399
  color: "#fff",
400
400
  borderRadius: 8,
401
401
  fontSize: 9,
@@ -406,7 +406,7 @@ function Gt({
406
406
  lineHeight: "14px",
407
407
  pointerEvents: "none"
408
408
  }, children: G }) : /* @__PURE__ */ t("span", { style: {
409
- background: O,
409
+ background: Y,
410
410
  color: "#fff",
411
411
  borderRadius: 10,
412
412
  padding: "1px 6px",
@@ -414,14 +414,14 @@ function Gt({
414
414
  fontWeight: 700,
415
415
  flexShrink: 0
416
416
  }, children: G });
417
- }, $ = (k, P, O) => {
417
+ }, v = (m, j, Y) => {
418
418
  var ce;
419
- if (k.hidden) return null;
420
- const G = k.id ?? `${k.type ?? "navItem"}-${P}-${O}`, K = k.type ?? "navItem";
421
- if (K === "separator") return /* @__PURE__ */ t("div", { style: { height: 1, background: e.border, margin: "6px 8px", flexShrink: 0 } }, G);
422
- if (K === "spacer") return /* @__PURE__ */ t("div", { style: { flex: 1 } }, G);
423
- if (K === "title")
424
- return v ? null : /* @__PURE__ */ t("div", { style: {
419
+ if (m.hidden) return null;
420
+ const G = m.id ?? `${m.type ?? "navItem"}-${j}-${Y}`, V = m.type ?? "navItem";
421
+ if (V === "separator") return /* @__PURE__ */ t("div", { style: { height: 1, background: e.border, margin: "6px 8px", flexShrink: 0 } }, G);
422
+ if (V === "spacer") return /* @__PURE__ */ t("div", { style: { flex: 1 } }, G);
423
+ if (V === "title")
424
+ return S ? null : /* @__PURE__ */ t("div", { style: {
425
425
  padding: "10px 14px 4px",
426
426
  fontSize: 10,
427
427
  fontWeight: 700,
@@ -429,47 +429,47 @@ function Gt({
429
429
  letterSpacing: 1,
430
430
  color: e.textMut,
431
431
  flexShrink: 0
432
- }, children: k.value }, G);
433
- if (K === "customHTML") return /* @__PURE__ */ t(
432
+ }, children: m.value }, G);
433
+ if (V === "customHTML") return /* @__PURE__ */ t(
434
434
  "div",
435
435
  {
436
- dangerouslySetInnerHTML: { __html: k.html ?? "" },
436
+ dangerouslySetInnerHTML: { __html: m.html ?? "" },
437
437
  style: { padding: "8px 12px", flexShrink: 0 }
438
438
  },
439
439
  G
440
440
  );
441
- const V = (((ce = k.items) == null ? void 0 : ce.length) ?? 0) > 0, Q = !!F[k.id ?? ""], Z = k.twoState ? !!I[k.id ?? ""] : !1, ne = !k.twoState && X === k.id || Z, H = !!k.disabled, de = v ? 0 : 12 + P * 16, me = () => {
442
- H || (k.twoState ? (ie(k), U(k)) : (V && p((le) => ({ ...le, [k.id ?? ""]: !le[k.id ?? ""] })), U(k)));
441
+ const q = (((ce = m.items) == null ? void 0 : ce.length) ?? 0) > 0, ee = !!K[m.id ?? ""], te = m.twoState ? !!N[m.id ?? ""] : !1, ne = !m.twoState && U === m.id || te, P = !!m.disabled, de = S ? 0 : 12 + j * 16, ve = () => {
442
+ P || (m.twoState ? (_(m), E(m)) : (q && c((se) => ({ ...se, [m.id ?? ""]: !se[m.id ?? ""] })), E(m)));
443
443
  };
444
444
  return /* @__PURE__ */ g("div", { style: { flexShrink: 0 }, children: [
445
445
  /* @__PURE__ */ g(
446
446
  "div",
447
447
  {
448
- title: k.tooltip,
449
- onClick: me,
448
+ title: m.tooltip,
449
+ onClick: ve,
450
450
  style: {
451
451
  display: "flex",
452
452
  alignItems: "center",
453
- gap: v ? 0 : 8,
454
- justifyContent: v ? "center" : "flex-start",
453
+ gap: S ? 0 : 8,
454
+ justifyContent: S ? "center" : "flex-start",
455
455
  paddingTop: 8,
456
456
  paddingBottom: 8,
457
- paddingLeft: v ? 0 : de,
458
- paddingRight: v ? 0 : 10,
457
+ paddingLeft: S ? 0 : de,
458
+ paddingRight: S ? 0 : 10,
459
459
  borderRadius: e.r,
460
460
  margin: "1px 6px",
461
- cursor: H ? "not-allowed" : "pointer",
461
+ cursor: P ? "not-allowed" : "pointer",
462
462
  userSelect: "none",
463
463
  transition: "background .15s",
464
464
  background: ne ? e.primaryLt : "transparent",
465
- color: H ? e.textMut : ne ? e.primary : e.text,
466
- opacity: H ? 0.55 : 1
465
+ color: P ? e.textMut : ne ? e.primary : e.text,
466
+ opacity: P ? 0.55 : 1
467
467
  },
468
- onMouseEnter: (le) => {
469
- !ne && !H && (le.currentTarget.style.background = e.bg);
468
+ onMouseEnter: (se) => {
469
+ !ne && !P && (se.currentTarget.style.background = e.bg);
470
470
  },
471
- onMouseLeave: (le) => {
472
- !ne && !H && (le.currentTarget.style.background = "transparent");
471
+ onMouseLeave: (se) => {
472
+ !ne && !P && (se.currentTarget.style.background = "transparent");
473
473
  },
474
474
  children: [
475
475
  /* @__PURE__ */ g("span", { style: {
@@ -480,19 +480,19 @@ function Gt({
480
480
  flexShrink: 0,
481
481
  lineHeight: 1
482
482
  }, children: [
483
- k.icon ?? (k.value && !k.icon, null),
484
- v && E(k, !0)
483
+ m.icon ?? (m.value && !m.icon, null),
484
+ S && w(m, !0)
485
485
  ] }),
486
- !v && /* @__PURE__ */ t("span", { style: {
486
+ !S && /* @__PURE__ */ t("span", { style: {
487
487
  flex: 1,
488
488
  fontSize: 13,
489
489
  fontWeight: ne ? 600 : 400,
490
490
  overflow: "hidden",
491
491
  textOverflow: "ellipsis",
492
492
  whiteSpace: "nowrap"
493
- }, children: k.value }),
494
- !v && E(k, !1),
495
- !v && k.twoState && /* @__PURE__ */ t("span", { style: {
493
+ }, children: m.value }),
494
+ !S && w(m, !1),
495
+ !S && m.twoState && /* @__PURE__ */ t("span", { style: {
496
496
  width: 14,
497
497
  height: 14,
498
498
  borderRadius: 2,
@@ -503,29 +503,29 @@ function Gt({
503
503
  alignItems: "center",
504
504
  justifyContent: "center"
505
505
  }, children: ne && /* @__PURE__ */ t("span", { style: { color: "#fff", fontSize: 8, fontWeight: 700, lineHeight: 1 }, children: "✓" }) }),
506
- !v && V && !k.twoState && /* @__PURE__ */ t("span", { style: {
506
+ !S && q && !m.twoState && /* @__PURE__ */ t("span", { style: {
507
507
  fontSize: 11,
508
508
  color: e.textMut,
509
509
  flexShrink: 0,
510
510
  transition: "transform .2s",
511
- transform: Q ? "rotate(90deg)" : "rotate(0deg)",
511
+ transform: ee ? "rotate(90deg)" : "rotate(0deg)",
512
512
  display: "inline-block"
513
513
  }, children: "▶" })
514
514
  ]
515
515
  }
516
516
  ),
517
- V && Q && !v && /* @__PURE__ */ t("div", { children: k.items.map((le, ye) => $(le, P + 1, ye)) })
517
+ q && ee && !S && /* @__PURE__ */ t("div", { children: m.items.map((se, be) => v(se, j + 1, be)) })
518
518
  ] }, G);
519
- }, j = /* @__PURE__ */ g(
519
+ }, T = /* @__PURE__ */ g(
520
520
  "div",
521
521
  {
522
- onClick: se,
522
+ onClick: o,
523
523
  style: {
524
524
  display: "flex",
525
525
  alignItems: "center",
526
- justifyContent: v ? "center" : "flex-start",
526
+ justifyContent: S ? "center" : "flex-start",
527
527
  gap: 8,
528
- padding: v ? "8px 0" : "8px 14px",
528
+ padding: S ? "8px 0" : "8px 14px",
529
529
  margin: "4px 6px",
530
530
  borderRadius: e.r,
531
531
  cursor: "pointer",
@@ -535,11 +535,11 @@ function Gt({
535
535
  transition: "background .15s",
536
536
  flexShrink: 0
537
537
  },
538
- onMouseEnter: (k) => k.currentTarget.style.background = e.bg,
539
- onMouseLeave: (k) => k.currentTarget.style.background = "transparent",
538
+ onMouseEnter: (m) => m.currentTarget.style.background = e.bg,
539
+ onMouseLeave: (m) => m.currentTarget.style.background = "transparent",
540
540
  children: [
541
- /* @__PURE__ */ t("span", { style: { fontSize: 16, fontWeight: 700, lineHeight: 1 }, children: v ? "›" : "‹" }),
542
- !v && /* @__PURE__ */ t("span", { children: "Collapse" })
541
+ /* @__PURE__ */ t("span", { style: { fontSize: 16, fontWeight: 700, lineHeight: 1 }, children: S ? "›" : "‹" }),
542
+ !S && /* @__PURE__ */ t("span", { children: "Collapse" })
543
543
  ]
544
544
  }
545
545
  );
@@ -548,25 +548,25 @@ function Gt({
548
548
  {
549
549
  className: "dhx",
550
550
  style: {
551
- width: J,
552
- minWidth: J,
551
+ width: Z,
552
+ minWidth: Z,
553
553
  background: e.surface,
554
554
  borderRight: `1px solid ${e.border}`,
555
555
  display: "flex",
556
556
  flexDirection: "column",
557
557
  transition: "width .2s ease, min-width .2s ease",
558
558
  overflow: "hidden",
559
- ...s
559
+ ...a
560
560
  },
561
561
  children: [
562
562
  l && /* @__PURE__ */ t("div", { style: {
563
- padding: v ? "12px 0" : "12px 14px",
563
+ padding: S ? "12px 0" : "12px 14px",
564
564
  borderBottom: `1px solid ${e.border}`,
565
565
  fontWeight: 700,
566
566
  fontSize: 15,
567
567
  display: "flex",
568
568
  alignItems: "center",
569
- justifyContent: v ? "center" : "flex-start",
569
+ justifyContent: S ? "center" : "flex-start",
570
570
  overflow: "hidden",
571
571
  flexShrink: 0
572
572
  }, children: l }),
@@ -575,17 +575,17 @@ function Gt({
575
575
  {
576
576
  className: "dhx-scroll",
577
577
  style: { flex: 1, overflowY: "auto", overflowX: "hidden", display: "flex", flexDirection: "column" },
578
- children: n.map((k, P) => $(k, 0, P))
578
+ children: n.map((m, j) => v(m, 0, j))
579
579
  }
580
580
  ),
581
- j,
582
- f && !v && /* @__PURE__ */ t("div", { style: { padding: "10px 14px", borderTop: `1px solid ${e.border}`, flexShrink: 0 }, children: f })
581
+ T,
582
+ u && !S && /* @__PURE__ */ t("div", { style: { padding: "10px 14px", borderTop: `1px solid ${e.border}`, flexShrink: 0 }, children: u })
583
583
  ]
584
584
  }
585
585
  );
586
586
  }
587
587
  function $t({ config: n }) {
588
- const [o, d] = N(!1), l = {
588
+ const [i, d] = B(!1), l = {
589
589
  position: "relative",
590
590
  background: e.surface,
591
591
  border: `1px solid ${e.border}`,
@@ -593,121 +593,121 @@ function $t({ config: n }) {
593
593
  overflow: "hidden",
594
594
  ...n.width ? { width: n.width, minWidth: n.width } : { flex: 1 },
595
595
  ...n.height ? { height: n.height, minHeight: n.height } : { minHeight: 40 },
596
- ...o ? { flex: "0 0 auto" } : {}
596
+ ...i ? { flex: "0 0 auto" } : {}
597
597
  };
598
598
  return /* @__PURE__ */ g("div", { style: l, children: [
599
599
  n.header && /* @__PURE__ */ g("div", { style: { display: "flex", alignItems: "center", justifyContent: "space-between", padding: "6px 12px", background: e.bg, borderBottom: `1px solid ${e.border}`, fontSize: 12, fontWeight: 600, color: e.textSec, userSelect: "none" }, children: [
600
600
  /* @__PURE__ */ t("span", { children: n.header }),
601
- n.collapsable && /* @__PURE__ */ t("button", { onClick: () => d((f) => !f), style: { background: "none", border: "none", cursor: "pointer", color: e.textMut, fontSize: 16, lineHeight: 1 }, children: o ? "▼" : "▲" })
601
+ n.collapsable && /* @__PURE__ */ t("button", { onClick: () => d((u) => !u), style: { background: "none", border: "none", cursor: "pointer", color: e.textMut, fontSize: 16, lineHeight: 1 }, children: i ? "▼" : "▲" })
602
602
  ] }),
603
- !o && /* @__PURE__ */ g("div", { style: { padding: n.padding || 0, height: n.header ? "calc(100% - 33px)" : "100%", overflow: "auto" }, children: [
603
+ !i && /* @__PURE__ */ g("div", { style: { padding: n.padding || 0, height: n.header ? "calc(100% - 33px)" : "100%", overflow: "auto" }, children: [
604
604
  n.html ? /* @__PURE__ */ t("div", { dangerouslySetInnerHTML: { __html: n.html } }) : n.content,
605
- (n.rows || n.cols) && /* @__PURE__ */ t(Dt, { rows: n.rows, cols: n.cols, style: { height: "100%" } })
605
+ (n.rows || n.cols) && /* @__PURE__ */ t(Ct, { rows: n.rows, cols: n.cols, style: { height: "100%" } })
606
606
  ] })
607
607
  ] });
608
608
  }
609
- function Dt({ rows: n, cols: o, type: d = "line", style: l, children: f }) {
610
- _(q, []);
611
- const a = d === "space" ? 12 : d === "wide" ? 8 : 1, h = n || o, u = !!n;
612
- return h ? /* @__PURE__ */ t("div", { className: "dhx", style: { display: "flex", flexDirection: u ? "column" : "row", gap: a, width: "100%", height: "100%", ...l }, children: h.map((x, w) => /* @__PURE__ */ t($t, { config: x }, x.id || w)) }) : /* @__PURE__ */ t("div", { className: "dhx", style: { width: "100%", height: "100%", ...l }, children: f });
609
+ function Ct({ rows: n, cols: i, type: d = "line", style: l, children: u }) {
610
+ J(Q, []);
611
+ const s = d === "space" ? 12 : d === "wide" ? 8 : 1, f = n || i, p = !!n;
612
+ return f ? /* @__PURE__ */ t("div", { className: "dhx", style: { display: "flex", flexDirection: p ? "column" : "row", gap: s, width: "100%", height: "100%", ...l }, children: f.map((x, z) => /* @__PURE__ */ t($t, { config: x }, x.id || z)) }) : /* @__PURE__ */ t("div", { className: "dhx", style: { width: "100%", height: "100%", ...l }, children: u });
613
613
  }
614
- function Jt({ views: n = [], mode: o = "top", tabAlign: d = "left", closable: l = [], disabled: f = [], defaultActive: a, onBeforeChange: h, onChange: u, style: x }) {
615
- var z;
616
- const [w, r] = N(a || ((z = n[0]) == null ? void 0 : z.id)), [i, c] = N(n.map((C) => C.id));
617
- _(q, []);
618
- const m = (C, F) => {
619
- C.stopPropagation(), c((p) => p.filter((I) => I !== F)), w === F && r(i.find((p) => p !== F) ?? "");
620
- }, S = (C) => {
621
- f.includes(C) || h && h(C) === !1 || (r(C), u == null || u(C));
622
- }, s = o === "left" || o === "right", b = n.filter((C) => i.includes(C.id)), M = /* @__PURE__ */ t("div", { style: { display: "flex", flexDirection: s ? "column" : "row", justifyContent: d === "center" ? "center" : d === "right" ? "flex-end" : "flex-start", background: e.surface, borderBottom: !s && o !== "bottom" ? `2px solid ${e.border}` : "none", borderTop: o === "bottom" ? `2px solid ${e.border}` : "none", borderRight: o === "left" ? `2px solid ${e.border}` : "none", borderLeft: o === "right" ? `2px solid ${e.border}` : "none", overflowX: "auto", flexShrink: 0 }, children: b.map((C) => {
623
- const F = w === C.id, p = f.includes(C.id), I = o === "bottom" ? { borderTop: `2px solid ${e.primary}`, color: e.primary, fontWeight: 600 } : s ? { color: e.primary, fontWeight: 600, background: e.primaryLt, [o === "left" ? "borderRight" : "borderLeft"]: `2px solid ${e.primary}` } : { borderBottom: `2px solid ${e.primary}`, color: e.primary, fontWeight: 600 };
614
+ function Qt({ views: n = [], mode: i = "top", tabAlign: d = "left", closable: l = [], disabled: u = [], defaultActive: s, onBeforeChange: f, onChange: p, style: x }) {
615
+ var $;
616
+ const [z, r] = B(s || (($ = n[0]) == null ? void 0 : $.id)), [b, h] = B(n.map((D) => D.id));
617
+ J(Q, []);
618
+ const M = (D, K) => {
619
+ D.stopPropagation(), h((c) => c.filter((N) => N !== K)), z === K && r(b.find((c) => c !== K) ?? "");
620
+ }, R = (D) => {
621
+ u.includes(D) || f && f(D) === !1 || (r(D), p == null || p(D));
622
+ }, a = i === "left" || i === "right", k = n.filter((D) => b.includes(D.id)), C = /* @__PURE__ */ t("div", { style: { display: "flex", flexDirection: a ? "column" : "row", justifyContent: d === "center" ? "center" : d === "right" ? "flex-end" : "flex-start", background: e.surface, borderBottom: !a && i !== "bottom" ? `2px solid ${e.border}` : "none", borderTop: i === "bottom" ? `2px solid ${e.border}` : "none", borderRight: i === "left" ? `2px solid ${e.border}` : "none", borderLeft: i === "right" ? `2px solid ${e.border}` : "none", overflowX: "auto", flexShrink: 0 }, children: k.map((D) => {
623
+ const K = z === D.id, c = u.includes(D.id), N = i === "bottom" ? { borderTop: `2px solid ${e.primary}`, color: e.primary, fontWeight: 600 } : a ? { color: e.primary, fontWeight: 600, background: e.primaryLt, [i === "left" ? "borderRight" : "borderLeft"]: `2px solid ${e.primary}` } : { borderBottom: `2px solid ${e.primary}`, color: e.primary, fontWeight: 600 };
624
624
  return /* @__PURE__ */ g(
625
625
  "div",
626
626
  {
627
- onClick: () => S(C.id),
628
- style: { display: "flex", alignItems: "center", gap: 6, padding: "10px 16px", cursor: p ? "not-allowed" : "pointer", whiteSpace: "nowrap", fontSize: 13, transition: "color .15s", userSelect: "none", minWidth: s ? 120 : "auto", ...F ? I : { color: p ? e.textMut : e.textSec } },
627
+ onClick: () => R(D.id),
628
+ style: { display: "flex", alignItems: "center", gap: 6, padding: "10px 16px", cursor: c ? "not-allowed" : "pointer", whiteSpace: "nowrap", fontSize: 13, transition: "color .15s", userSelect: "none", minWidth: a ? 120 : "auto", ...K ? N : { color: c ? e.textMut : e.textSec } },
629
629
  children: [
630
- C.icon && /* @__PURE__ */ t("span", { style: { fontSize: 16 }, children: C.icon }),
631
- /* @__PURE__ */ t("span", { children: C.tab }),
632
- l.includes(C.id) && /* @__PURE__ */ t("span", { onClick: (W) => m(W, C.id), style: { marginLeft: 4, opacity: 0.6, fontSize: 12, cursor: "pointer" }, children: "✕" })
630
+ D.icon && /* @__PURE__ */ t("span", { style: { fontSize: 16 }, children: D.icon }),
631
+ /* @__PURE__ */ t("span", { children: D.tab }),
632
+ l.includes(D.id) && /* @__PURE__ */ t("span", { onClick: (A) => M(A, D.id), style: { marginLeft: 4, opacity: 0.6, fontSize: 12, cursor: "pointer" }, children: "✕" })
633
633
  ]
634
634
  },
635
- C.id
635
+ D.id
636
636
  );
637
- }) }), D = b.find((C) => C.id === w), R = /* @__PURE__ */ g("div", { className: "dhx-scroll", style: { flex: 1, overflow: "auto" }, children: [
638
- D == null ? void 0 : D.content,
639
- (D == null ? void 0 : D.html) && /* @__PURE__ */ t("div", { dangerouslySetInnerHTML: { __html: D.html }, style: { padding: 16 } })
637
+ }) }), L = k.find((D) => D.id === z), H = /* @__PURE__ */ g("div", { className: "dhx-scroll", style: { flex: 1, overflow: "auto" }, children: [
638
+ L == null ? void 0 : L.content,
639
+ (L == null ? void 0 : L.html) && /* @__PURE__ */ t("div", { dangerouslySetInnerHTML: { __html: L.html }, style: { padding: 16 } })
640
640
  ] });
641
- return /* @__PURE__ */ g("div", { className: "dhx", style: { display: "flex", flexDirection: o === "top" ? "column" : o === "bottom" ? "column-reverse" : o === "left" ? "row" : "row-reverse", width: "100%", height: "100%", background: e.surface, border: `1px solid ${e.border}`, borderRadius: e.r, overflow: "hidden", ...x }, children: [
642
- M,
643
- R
641
+ return /* @__PURE__ */ g("div", { className: "dhx", style: { display: "flex", flexDirection: i === "top" ? "column" : i === "bottom" ? "column-reverse" : i === "left" ? "row" : "row-reverse", width: "100%", height: "100%", background: e.surface, border: `1px solid ${e.border}`, borderRadius: e.r, overflow: "hidden", ...x }, children: [
642
+ C,
643
+ H
644
644
  ] });
645
645
  }
646
- const he = `1px solid ${e.border}`;
647
- function Ct({ active: n, dir: o }) {
646
+ const fe = `1px solid ${e.border}`;
647
+ function Dt({ active: n, dir: i }) {
648
648
  return /* @__PURE__ */ g("span", { style: { display: "inline-flex", flexDirection: "column", gap: 1, flexShrink: 0, marginLeft: 4 }, children: [
649
- /* @__PURE__ */ t("svg", { width: "7", height: "4", viewBox: "0 0 7 4", children: /* @__PURE__ */ t("path", { d: "M3.5 0L7 4H0z", fill: n && o === "asc" ? e.primary : e.borderDk }) }),
650
- /* @__PURE__ */ t("svg", { width: "7", height: "4", viewBox: "0 0 7 4", children: /* @__PURE__ */ t("path", { d: "M3.5 4L0 0H7z", fill: n && o === "desc" ? e.primary : e.borderDk }) })
649
+ /* @__PURE__ */ t("svg", { width: "7", height: "4", viewBox: "0 0 7 4", children: /* @__PURE__ */ t("path", { d: "M3.5 0L7 4H0z", fill: n && i === "asc" ? e.primary : e.borderDk }) }),
650
+ /* @__PURE__ */ t("svg", { width: "7", height: "4", viewBox: "0 0 7 4", children: /* @__PURE__ */ t("path", { d: "M3.5 4L0 0H7z", fill: n && i === "desc" ? e.primary : e.borderDk }) })
651
651
  ] });
652
652
  }
653
- function Lt({ options: n, value: o, onChange: d, onCommit: l, onCancel: f }) {
654
- const [a, h] = N(o), [u, x] = N(!0), w = oe(null);
655
- _(() => {
656
- const i = (c) => {
657
- w.current && !w.current.contains(c.target) && l();
653
+ function Lt({ options: n, value: i, onChange: d, onCommit: l, onCancel: u }) {
654
+ const [s, f] = B(i), [p, x] = B(!0), z = le(null);
655
+ J(() => {
656
+ const b = (h) => {
657
+ z.current && !z.current.contains(h.target) && l();
658
658
  };
659
- return document.addEventListener("mousedown", i), () => document.removeEventListener("mousedown", i);
659
+ return document.addEventListener("mousedown", b), () => document.removeEventListener("mousedown", b);
660
660
  }, [l]);
661
- const r = n.filter((i) => !a || i.toLowerCase().includes(a.toLowerCase()));
662
- return /* @__PURE__ */ g("div", { ref: w, style: { width: "100%", position: "relative" }, children: [
661
+ const r = n.filter((b) => !s || b.toLowerCase().includes(s.toLowerCase()));
662
+ return /* @__PURE__ */ g("div", { ref: z, style: { width: "100%", position: "relative" }, children: [
663
663
  /* @__PURE__ */ t(
664
664
  "input",
665
665
  {
666
666
  autoFocus: !0,
667
- value: a,
668
- onChange: (i) => {
669
- h(i.target.value), d(i.target.value), x(!0);
667
+ value: s,
668
+ onChange: (b) => {
669
+ f(b.target.value), d(b.target.value), x(!0);
670
670
  },
671
- onKeyDown: (i) => {
672
- i.key === "Enter" && l(), i.key === "Escape" && f();
671
+ onKeyDown: (b) => {
672
+ b.key === "Enter" && l(), b.key === "Escape" && u();
673
673
  },
674
- onClick: (i) => i.stopPropagation(),
674
+ onClick: (b) => b.stopPropagation(),
675
675
  style: { width: "100%", border: "none", outline: `2px solid ${e.primary}`, borderRadius: 2, fontSize: 13, padding: "2px 4px", background: e.surface, color: e.text }
676
676
  }
677
677
  ),
678
- u && r.length > 0 && /* @__PURE__ */ t("div", { style: { position: "absolute", top: "100%", left: 0, right: 0, zIndex: 50, background: e.surface, border: `1px solid ${e.border}`, borderRadius: e.r, boxShadow: e.shadowLg, maxHeight: 160, overflowY: "auto" }, children: r.map((i) => /* @__PURE__ */ t(
678
+ p && r.length > 0 && /* @__PURE__ */ t("div", { style: { position: "absolute", top: "100%", left: 0, right: 0, zIndex: 50, background: e.surface, border: `1px solid ${e.border}`, borderRadius: e.r, boxShadow: e.shadowLg, maxHeight: 160, overflowY: "auto" }, children: r.map((b) => /* @__PURE__ */ t(
679
679
  "div",
680
680
  {
681
- onMouseDown: (c) => {
682
- c.preventDefault(), d(i), h(i), x(!1), l();
681
+ onMouseDown: (h) => {
682
+ h.preventDefault(), d(b), f(b), x(!1), l();
683
683
  },
684
684
  style: { padding: "6px 10px", cursor: "pointer", fontSize: 13, color: e.text },
685
- onMouseEnter: (c) => c.currentTarget.style.background = e.bg,
686
- onMouseLeave: (c) => c.currentTarget.style.background = e.surface,
687
- children: i
685
+ onMouseEnter: (h) => h.currentTarget.style.background = e.bg,
686
+ onMouseLeave: (h) => h.currentTarget.style.background = e.surface,
687
+ children: b
688
688
  },
689
- i
689
+ b
690
690
  )) })
691
691
  ] });
692
692
  }
693
- function It(n, o) {
693
+ function Tt(n, i) {
694
694
  if (n == null) return "";
695
- if (o === "number") return typeof n == "number" ? n.toLocaleString() : String(n);
696
- if (o === "date") {
695
+ if (i === "number") return typeof n == "number" ? n.toLocaleString() : String(n);
696
+ if (i === "date") {
697
697
  const d = n instanceof Date ? n : new Date(String(n));
698
698
  return isNaN(d.getTime()) ? String(n) : d.toLocaleDateString();
699
699
  }
700
700
  return String(n);
701
701
  }
702
- function Tt(n, o, d) {
703
- return n == null ? 1 : o == null ? -1 : d === "date" ? new Date(String(n)).getTime() - new Date(String(o)).getTime() : d === "number" ? Number(n) - Number(o) : String(n) < String(o) ? -1 : String(n) > String(o) ? 1 : 0;
702
+ function It(n, i, d) {
703
+ return n == null ? 1 : i == null ? -1 : d === "date" ? new Date(String(n)).getTime() - new Date(String(i)).getTime() : d === "number" ? Number(n) - Number(i) : String(n) < String(i) ? -1 : String(n) > String(i) ? 1 : 0;
704
704
  }
705
- function Se(n) {
706
- var o;
707
- return Array.isArray(n.header) && ((o = n.header[1]) == null ? void 0 : o.content) != null ? n.header[1].content : n.filterable ? n.filterType === "select" ? "selectFilter" : "inputFilter" : null;
705
+ function we(n) {
706
+ var i;
707
+ return Array.isArray(n.header) && ((i = n.header[1]) == null ? void 0 : i.content) != null ? n.header[1].content : n.filterable ? n.filterType === "select" ? "selectFilter" : "inputFilter" : null;
708
708
  }
709
- function Nt(n, o, d, l, f) {
710
- const a = {
709
+ function Rt(n, i, d, l, u) {
710
+ const s = {
711
711
  width: "100%",
712
712
  border: "none",
713
713
  outline: `2px solid ${e.primary}`,
@@ -716,240 +716,240 @@ function Nt(n, o, d, l, f) {
716
716
  padding: "2px 4px",
717
717
  background: e.surface,
718
718
  color: e.text
719
- }, h = n.editorType ?? "input";
720
- if (h === "select") return /* @__PURE__ */ t(
719
+ }, f = n.editorType ?? "input";
720
+ if (f === "select") return /* @__PURE__ */ t(
721
721
  "select",
722
722
  {
723
723
  autoFocus: !0,
724
- value: o,
724
+ value: i,
725
725
  onChange: (x) => d(x.target.value),
726
726
  onBlur: l,
727
727
  onKeyDown: (x) => {
728
- x.key === "Enter" && l(), x.key === "Escape" && f();
728
+ x.key === "Enter" && l(), x.key === "Escape" && u();
729
729
  },
730
730
  onClick: (x) => x.stopPropagation(),
731
- style: { ...a, cursor: "pointer" },
731
+ style: { ...s, cursor: "pointer" },
732
732
  children: (n.options ?? []).map((x) => /* @__PURE__ */ t("option", { value: x, children: x }, x))
733
733
  }
734
734
  );
735
- if (h === "combobox") return /* @__PURE__ */ t(
735
+ if (f === "combobox") return /* @__PURE__ */ t(
736
736
  Lt,
737
737
  {
738
738
  options: n.options ?? [],
739
- value: o,
739
+ value: i,
740
740
  onChange: d,
741
741
  onCommit: l,
742
- onCancel: f
742
+ onCancel: u
743
743
  }
744
744
  );
745
- const u = n.type === "number" ? "number" : n.type === "date" ? "date" : "text";
745
+ const p = n.type === "number" ? "number" : n.type === "date" ? "date" : "text";
746
746
  return /* @__PURE__ */ t(
747
747
  "input",
748
748
  {
749
749
  autoFocus: !0,
750
- type: u,
751
- value: o,
750
+ type: p,
751
+ value: i,
752
752
  onChange: (x) => d(x.target.value),
753
753
  onBlur: l,
754
754
  onKeyDown: (x) => {
755
- x.key === "Enter" && l(), x.key === "Escape" && f();
755
+ x.key === "Enter" && l(), x.key === "Escape" && u();
756
756
  },
757
757
  onClick: (x) => x.stopPropagation(),
758
- style: a
758
+ style: s
759
759
  }
760
760
  );
761
761
  }
762
- function Ut({
762
+ function Zt({
763
763
  columns: n,
764
- data: o = [],
764
+ data: i = [],
765
765
  height: d = 400,
766
766
  rowHeight: l = 40,
767
- headerRowHeight: f = 40,
768
- footerRowHeight: a = 40,
769
- sortable: h = !0,
770
- resizable: u = !0,
767
+ headerRowHeight: u = 40,
768
+ footerRowHeight: s = 40,
769
+ sortable: f = !0,
770
+ resizable: p = !0,
771
771
  editable: x = !1,
772
- stripe: w = !1,
772
+ stripe: z = !1,
773
773
  autoWidth: r = !1,
774
- keyNavigation: i = !1,
775
- selection: c,
776
- multiselect: m,
777
- leftSplit: S = 0,
778
- onSelect: s,
779
- onChange: b,
780
- style: M
774
+ keyNavigation: b = !1,
775
+ selection: h,
776
+ multiselect: M,
777
+ leftSplit: R = 0,
778
+ onSelect: a,
779
+ onChange: k,
780
+ style: C
781
781
  }) {
782
- var Ce;
783
- const [D, R] = N(null), [z, C] = N("asc"), [F, p] = N({}), [I, W] = N(/* @__PURE__ */ new Set()), [v, X] = N(-1), [J, se] = N(
782
+ var De;
783
+ const [L, H] = B(null), [$, D] = B("asc"), [K, c] = B({}), [N, A] = B(/* @__PURE__ */ new Set()), [S, U] = B(-1), [Z, o] = B(
784
784
  () => Object.fromEntries(n.map((y) => [y.id, y.width ?? y.minWidth ?? 150]))
785
- ), [U, ie] = N(null), [E, $] = N(""), [j, k] = N({}), P = oe(null), [O, G] = N(0);
786
- _(q, []), _(() => {
787
- if (!r || !P.current) return;
785
+ ), [E, _] = B(null), [w, v] = B(""), [T, m] = B({}), j = le(null), [Y, G] = B(0);
786
+ J(Q, []), J(() => {
787
+ if (!r || !j.current) return;
788
788
  const y = new ResizeObserver(() => {
789
- var L;
790
- return G(((L = P.current) == null ? void 0 : L.offsetWidth) ?? 0);
789
+ var I;
790
+ return G(((I = j.current) == null ? void 0 : I.offsetWidth) ?? 0);
791
791
  });
792
- return y.observe(P.current), () => y.disconnect();
792
+ return y.observe(j.current), () => y.disconnect();
793
793
  }, [r]);
794
- const K = ue(
794
+ const V = ue(
795
795
  () => n.map(
796
796
  (y) => y.summary && (!y.footer || y.footer.length === 0) ? { ...y, footer: [{ summary: y.summary }] } : y
797
797
  ),
798
798
  [n]
799
- ), V = ue(
800
- () => K.filter((y) => !y.hidden),
801
- [K]
802
- ), Q = ue(() => {
803
- if (!r || O === 0) return J;
804
- const y = V.reduce((T, A) => T + (J[A.id] ?? 150), 0);
805
- if (O <= y) return J;
806
- const L = (O - y) / V.length;
807
- return Object.fromEntries(V.map((T) => [T.id, (J[T.id] ?? 150) + L]));
808
- }, [r, O, J, V]), Z = ue(() => {
809
- let y = o.map((L, T) => {
810
- const A = String(L.id ?? T);
811
- return j[A] ? { ...L, ...j[A] } : L;
799
+ ), q = ue(
800
+ () => V.filter((y) => !y.hidden),
801
+ [V]
802
+ ), ee = ue(() => {
803
+ if (!r || Y === 0) return Z;
804
+ const y = q.reduce((W, F) => W + (Z[F.id] ?? 150), 0);
805
+ if (Y <= y) return Z;
806
+ const I = (Y - y) / q.length;
807
+ return Object.fromEntries(q.map((W) => [W.id, (Z[W.id] ?? 150) + I]));
808
+ }, [r, Y, Z, q]), te = ue(() => {
809
+ let y = i.map((I, W) => {
810
+ const F = String(I.id ?? W);
811
+ return T[F] ? { ...I, ...T[F] } : I;
812
812
  }).filter(
813
- (L) => Object.entries(F).every(
814
- ([T, A]) => !A || String(L[T] ?? "").toLowerCase().includes(A.toLowerCase())
813
+ (I) => Object.entries(K).every(
814
+ ([W, F]) => !F || String(I[W] ?? "").toLowerCase().includes(F.toLowerCase())
815
815
  )
816
816
  );
817
- if (D) {
818
- const L = K.find((T) => T.id === D);
819
- y = [...y].sort((T, A) => {
820
- const Y = Tt(T[D], A[D], L == null ? void 0 : L.type);
821
- return z === "asc" ? Y : -Y;
817
+ if (L) {
818
+ const I = V.find((W) => W.id === L);
819
+ y = [...y].sort((W, F) => {
820
+ const X = It(W[L], F[L], I == null ? void 0 : I.type);
821
+ return $ === "asc" ? X : -X;
822
822
  });
823
823
  }
824
824
  return y;
825
- }, [o, D, z, F, j, K]), fe = ue(() => {
825
+ }, [i, L, $, K, T, V]), pe = ue(() => {
826
826
  const y = {};
827
- return K.forEach((L) => {
828
- var T;
829
- if ((T = L.footer) != null && T.some((A) => A.summary)) {
830
- const A = Z.map((B) => Number(B[L.id])).filter((B) => !isNaN(B)), Y = A.reduce((B, ee) => B + ee, 0);
831
- y[L.id] = { sum: Y, avg: A.length ? Y / A.length : 0, count: Z.length, min: A.length ? Math.min(...A) : 0, max: A.length ? Math.max(...A) : 0 };
827
+ return V.forEach((I) => {
828
+ var W;
829
+ if ((W = I.footer) != null && W.some((F) => F.summary)) {
830
+ const F = te.map((O) => Number(O[I.id])).filter((O) => !isNaN(O)), X = F.reduce((O, re) => O + re, 0);
831
+ y[I.id] = { sum: X, avg: F.length ? X / F.length : 0, count: te.length, min: F.length ? Math.min(...F) : 0, max: F.length ? Math.max(...F) : 0 };
832
832
  }
833
833
  }), y;
834
- }, [Z, K]), ne = ue(() => {
834
+ }, [te, V]), ne = ue(() => {
835
835
  const y = {};
836
- return V.filter((L) => {
837
- const T = Se(L);
838
- return T === "selectFilter" || T === "comboFilter";
839
- }).forEach((L) => {
840
- y[L.id] = [...new Set(o.map((T) => String(T[L.id] ?? "")))].sort();
836
+ return q.filter((I) => {
837
+ const W = we(I);
838
+ return W === "selectFilter" || W === "comboFilter";
839
+ }).forEach((I) => {
840
+ y[I.id] = [...new Set(i.map((W) => String(W[I.id] ?? "")))].sort();
841
841
  }), y;
842
- }, [o, V]), H = V.some((y) => Se(y) !== null), de = K.some((y) => {
843
- var L;
844
- return (L = y.footer) == null ? void 0 : L.length;
845
- }), me = V.reduce((y, L) => y + (Q[L.id] ?? 150), 0), ce = ue(() => {
846
- if (!S) return {};
842
+ }, [i, q]), P = q.some((y) => we(y) !== null), de = V.some((y) => {
843
+ var I;
844
+ return (I = y.footer) == null ? void 0 : I.length;
845
+ }), ve = q.reduce((y, I) => y + (ee[I.id] ?? 150), 0), ce = ue(() => {
846
+ if (!R) return {};
847
847
  let y = 0;
848
- const L = {};
849
- return V.forEach((T, A) => {
850
- A < S && (L[T.id] = y, y += Q[T.id] ?? 150);
851
- }), L;
852
- }, [S, V, Q]), le = S > 0 ? (Ce = V[S - 1]) == null ? void 0 : Ce.id : null, ye = (y, L) => y.id ?? L, Xe = (y) => {
853
- !h || y.sortable === !1 || (C((L) => D === y.id && L === "asc" ? "desc" : "asc"), R(y.id));
854
- }, ve = (y, L) => {
855
- if (!c) return;
856
- const T = ye(y, L);
857
- X(L), W((A) => {
858
- const Y = m ? new Set(A) : /* @__PURE__ */ new Set();
859
- return Y.has(T) ? Y.delete(T) : Y.add(T), Y;
860
- }), s == null || s(y);
848
+ const I = {};
849
+ return q.forEach((W, F) => {
850
+ F < R && (I[W.id] = y, y += ee[W.id] ?? 150);
851
+ }), I;
852
+ }, [R, q, ee]), se = R > 0 ? (De = q[R - 1]) == null ? void 0 : De.id : null, be = (y, I) => y.id ?? I, Xe = (y) => {
853
+ !f || y.sortable === !1 || (D((I) => L === y.id && I === "asc" ? "desc" : "asc"), H(y.id));
854
+ }, Se = (y, I) => {
855
+ if (!h) return;
856
+ const W = be(y, I);
857
+ U(I), A((F) => {
858
+ const X = M ? new Set(F) : /* @__PURE__ */ new Set();
859
+ return X.has(W) ? X.delete(W) : X.add(W), X;
860
+ }), a == null || a(y);
861
861
  }, qe = () => {
862
- if (!U) return;
863
- const { key: y, colId: L } = U;
864
- k((A) => ({ ...A, [String(y)]: { ...A[String(y)] || {}, [L]: E } }));
865
- const T = Z.find((A, Y) => ye(A, Y) === y);
866
- T && (b == null || b(T, L, E)), ie(null);
862
+ if (!E) return;
863
+ const { key: y, colId: I } = E;
864
+ m((F) => ({ ...F, [String(y)]: { ...F[String(y)] || {}, [I]: w } }));
865
+ const W = te.find((F, X) => be(F, X) === y);
866
+ W && (k == null || k(W, I, w)), _(null);
867
867
  }, Ge = (y) => {
868
- if (U && y.key === "Escape") {
869
- ie(null);
868
+ if (E && y.key === "Escape") {
869
+ _(null);
870
870
  return;
871
871
  }
872
- if (!(!i || !c)) {
872
+ if (!(!b || !h)) {
873
873
  if (y.key === "ArrowDown") {
874
874
  y.preventDefault();
875
- const L = Math.min(v + 1, Z.length - 1);
876
- L >= 0 && ve(Z[L], L);
875
+ const I = Math.min(S + 1, te.length - 1);
876
+ I >= 0 && Se(te[I], I);
877
877
  } else if (y.key === "ArrowUp") {
878
878
  y.preventDefault();
879
- const L = Math.max(v - 1, 0);
880
- L >= 0 && ve(Z[L], L);
879
+ const I = Math.max(S - 1, 0);
880
+ I >= 0 && Se(te[I], I);
881
881
  }
882
882
  }
883
- }, Je = (y, L) => {
883
+ }, Je = (y, I) => {
884
884
  y.preventDefault(), y.stopPropagation();
885
- const T = y.clientX, A = J[L] ?? 150, Y = n.find((te) => te.id === L), B = (te) => se((pe) => ({
886
- ...pe,
887
- [L]: Math.max((Y == null ? void 0 : Y.minWidth) || 50, A + te.clientX - T)
888
- })), ee = () => {
889
- document.removeEventListener("mousemove", B), document.removeEventListener("mouseup", ee);
885
+ const W = y.clientX, F = Z[I] ?? 150, X = n.find((oe) => oe.id === I), O = (oe) => o((he) => ({
886
+ ...he,
887
+ [I]: Math.max((X == null ? void 0 : X.minWidth) || 50, F + oe.clientX - W)
888
+ })), re = () => {
889
+ document.removeEventListener("mousemove", O), document.removeEventListener("mouseup", re);
890
890
  };
891
- document.addEventListener("mousemove", B), document.addEventListener("mouseup", ee);
892
- }, ke = (y, L, T, A, Y, B = "hidden") => {
893
- const ee = y in ce;
891
+ document.addEventListener("mousemove", O), document.addEventListener("mouseup", re);
892
+ }, ke = (y, I, W, F, X, O = "hidden") => {
893
+ const re = y in ce;
894
894
  return {
895
- width: L,
896
- minWidth: L,
895
+ width: I,
896
+ minWidth: I,
897
897
  flexShrink: 0,
898
898
  boxSizing: "border-box",
899
899
  padding: "0 12px",
900
- height: Y,
900
+ height: X,
901
901
  display: "flex",
902
902
  alignItems: "center",
903
- overflow: B,
903
+ overflow: O,
904
904
  textOverflow: "ellipsis",
905
905
  whiteSpace: "nowrap",
906
906
  fontSize: 13,
907
- textAlign: T,
908
- justifyContent: T === "center" ? "center" : T === "right" ? "flex-end" : "flex-start",
909
- borderLeft: A ? "none" : he,
910
- position: ee ? "sticky" : "relative",
911
- ...ee ? {
907
+ textAlign: W,
908
+ justifyContent: W === "center" ? "center" : W === "right" ? "flex-end" : "flex-start",
909
+ borderLeft: F ? "none" : fe,
910
+ position: re ? "sticky" : "relative",
911
+ ...re ? {
912
912
  left: ce[y],
913
913
  zIndex: 1,
914
- boxShadow: y === le ? "2px 0 6px rgba(0,0,0,0.1)" : void 0
914
+ boxShadow: y === se ? "2px 0 6px rgba(0,0,0,0.1)" : void 0
915
915
  } : {}
916
916
  };
917
917
  };
918
918
  return /* @__PURE__ */ t(
919
919
  "div",
920
920
  {
921
- ref: P,
921
+ ref: j,
922
922
  className: "dhx",
923
- tabIndex: i ? 0 : void 0,
923
+ tabIndex: b ? 0 : void 0,
924
924
  onKeyDown: Ge,
925
- style: { width: "100%", height: d, display: "flex", flexDirection: "column", border: he, borderRadius: e.r, overflow: "hidden", outline: "none", ...M },
926
- children: /* @__PURE__ */ t("div", { className: "dhx-scroll", style: { overflow: "auto", flex: 1 }, children: /* @__PURE__ */ g("div", { style: { minWidth: me, display: "flex", flexDirection: "column", minHeight: "100%" }, children: [
927
- /* @__PURE__ */ t("div", { style: { display: "flex", background: e.bg, borderBottom: he, flexShrink: 0, position: "sticky", top: 0, zIndex: 3 }, children: V.map((y, L) => {
928
- const T = Array.isArray(y.header) ? y.header[0] : null, A = (T == null ? void 0 : T.text) ?? (typeof y.header == "string" ? y.header : y.id), Y = (T == null ? void 0 : T.align) ?? y.align, B = Q[y.id] ?? 150, ee = y.id in ce;
925
+ style: { width: "100%", height: d, display: "flex", flexDirection: "column", border: fe, borderRadius: e.r, overflow: "hidden", outline: "none", ...C },
926
+ children: /* @__PURE__ */ t("div", { className: "dhx-scroll", style: { overflow: "auto", flex: 1 }, children: /* @__PURE__ */ g("div", { style: { minWidth: ve, display: "flex", flexDirection: "column", minHeight: "100%" }, children: [
927
+ /* @__PURE__ */ t("div", { style: { display: "flex", background: e.bg, borderBottom: fe, flexShrink: 0, position: "sticky", top: 0, zIndex: 3 }, children: q.map((y, I) => {
928
+ const W = Array.isArray(y.header) ? y.header[0] : null, F = (W == null ? void 0 : W.text) ?? (typeof y.header == "string" ? y.header : y.id), X = (W == null ? void 0 : W.align) ?? y.align, O = ee[y.id] ?? 150, re = y.id in ce;
929
929
  return /* @__PURE__ */ g(
930
930
  "div",
931
931
  {
932
932
  onClick: () => Xe(y),
933
933
  style: {
934
- ...ke(y.id, B, Y, L === 0, f),
934
+ ...ke(y.id, O, X, I === 0, u),
935
935
  fontWeight: 500,
936
936
  color: e.text,
937
937
  background: e.bg,
938
- cursor: h && y.sortable !== !1 ? "pointer" : "default",
938
+ cursor: f && y.sortable !== !1 ? "pointer" : "default",
939
939
  userSelect: "none",
940
- ...ee ? { zIndex: 4 } : {}
940
+ ...re ? { zIndex: 4 } : {}
941
941
  },
942
942
  children: [
943
- T != null && T.htmlEnable ? /* @__PURE__ */ t("span", { style: { flex: 1, overflow: "hidden" }, dangerouslySetInnerHTML: { __html: A } }) : /* @__PURE__ */ t("span", { style: { flex: 1, overflow: "hidden", textOverflow: "ellipsis", whiteSpace: "nowrap" }, children: A }),
944
- h && y.sortable !== !1 && /* @__PURE__ */ t(Ct, { active: D === y.id, dir: z }),
945
- u && y.resizable !== !1 && L < V.length - 1 && /* @__PURE__ */ t(
943
+ W != null && W.htmlEnable ? /* @__PURE__ */ t("span", { style: { flex: 1, overflow: "hidden" }, dangerouslySetInnerHTML: { __html: F } }) : /* @__PURE__ */ t("span", { style: { flex: 1, overflow: "hidden", textOverflow: "ellipsis", whiteSpace: "nowrap" }, children: F }),
944
+ f && y.sortable !== !1 && /* @__PURE__ */ t(Dt, { active: L === y.id, dir: $ }),
945
+ p && y.resizable !== !1 && I < q.length - 1 && /* @__PURE__ */ t(
946
946
  "div",
947
947
  {
948
- onMouseDown: (te) => Je(te, y.id),
949
- onClick: (te) => te.stopPropagation(),
948
+ onMouseDown: (oe) => Je(oe, y.id),
949
+ onClick: (oe) => oe.stopPropagation(),
950
950
  style: { position: "absolute", right: 0, top: 0, bottom: 0, width: 4, cursor: "col-resize", zIndex: 1 },
951
- onMouseEnter: (te) => te.currentTarget.style.background = e.primary + "55",
952
- onMouseLeave: (te) => te.currentTarget.style.background = "transparent"
951
+ onMouseEnter: (oe) => oe.currentTarget.style.background = e.primary + "55",
952
+ onMouseLeave: (oe) => oe.currentTarget.style.background = "transparent"
953
953
  }
954
954
  )
955
955
  ]
@@ -957,370 +957,370 @@ function Ut({
957
957
  y.id
958
958
  );
959
959
  }) }),
960
- H && /* @__PURE__ */ t("div", { style: {
960
+ P && /* @__PURE__ */ t("div", { style: {
961
961
  display: "flex",
962
- borderBottom: he,
962
+ borderBottom: fe,
963
963
  background: e.surface,
964
964
  flexShrink: 0,
965
- ...S ? { position: "sticky", top: f, zIndex: 3 } : {}
966
- }, children: V.map((y, L) => {
967
- const T = Se(y), A = Q[y.id] ?? 150, Y = y.id in ce;
965
+ ...R ? { position: "sticky", top: u, zIndex: 3 } : {}
966
+ }, children: q.map((y, I) => {
967
+ const W = we(y), F = ee[y.id] ?? 150, X = y.id in ce;
968
968
  return /* @__PURE__ */ t("div", { style: {
969
- width: A,
970
- minWidth: A,
969
+ width: F,
970
+ minWidth: F,
971
971
  flexShrink: 0,
972
972
  padding: "4px 6px",
973
973
  boxSizing: "border-box",
974
- borderLeft: L === 0 ? "none" : he,
974
+ borderLeft: I === 0 ? "none" : fe,
975
975
  background: e.surface,
976
- ...Y ? {
976
+ ...X ? {
977
977
  position: "sticky",
978
978
  left: ce[y.id],
979
979
  zIndex: 4,
980
- boxShadow: y.id === le ? "2px 0 6px rgba(0,0,0,0.1)" : void 0
980
+ boxShadow: y.id === se ? "2px 0 6px rgba(0,0,0,0.1)" : void 0
981
981
  } : {}
982
- }, children: T === "selectFilter" || T === "comboFilter" ? /* @__PURE__ */ g(
982
+ }, children: W === "selectFilter" || W === "comboFilter" ? /* @__PURE__ */ g(
983
983
  "select",
984
984
  {
985
985
  className: "dhx dhx-input",
986
986
  style: { height: 26, fontSize: 12, padding: "0 4px" },
987
- value: F[y.id] || "",
988
- onChange: (B) => p((ee) => ({ ...ee, [y.id]: B.target.value })),
987
+ value: K[y.id] || "",
988
+ onChange: (O) => c((re) => ({ ...re, [y.id]: O.target.value })),
989
989
  children: [
990
990
  /* @__PURE__ */ t("option", { value: "", children: "All" }),
991
- (ne[y.id] || []).map((B) => /* @__PURE__ */ t("option", { value: B, children: B }, B))
991
+ (ne[y.id] || []).map((O) => /* @__PURE__ */ t("option", { value: O, children: O }, O))
992
992
  ]
993
993
  }
994
- ) : T === "inputFilter" ? /* @__PURE__ */ t(
994
+ ) : W === "inputFilter" ? /* @__PURE__ */ t(
995
995
  "input",
996
996
  {
997
997
  className: "dhx dhx-input",
998
998
  style: { height: 26, fontSize: 12 },
999
999
  placeholder: "Filter...",
1000
- value: F[y.id] || "",
1001
- onChange: (B) => p((ee) => ({ ...ee, [y.id]: B.target.value }))
1000
+ value: K[y.id] || "",
1001
+ onChange: (O) => c((re) => ({ ...re, [y.id]: O.target.value }))
1002
1002
  }
1003
1003
  ) : null }, y.id);
1004
1004
  }) }),
1005
1005
  /* @__PURE__ */ g("div", { style: { flex: 1 }, children: [
1006
- Z.map((y, L) => {
1007
- const T = ye(y, L), A = I.has(T), Y = A ? e.primaryLt : w && L % 2 !== 0 ? e.bg : e.surface;
1006
+ te.map((y, I) => {
1007
+ const W = be(y, I), F = N.has(W), X = F ? e.primaryLt : z && I % 2 !== 0 ? e.bg : e.surface;
1008
1008
  return /* @__PURE__ */ t(
1009
1009
  "div",
1010
1010
  {
1011
- style: { display: "flex", height: l, borderBottom: he, flexShrink: 0, background: Y, transition: "background .1s", cursor: c ? "pointer" : "default" },
1012
- onMouseEnter: (B) => !A && (B.currentTarget.style.background = e.primaryLt + "80"),
1013
- onMouseLeave: (B) => !A && (B.currentTarget.style.background = Y),
1014
- children: V.map((B, ee) => {
1015
- const te = (U == null ? void 0 : U.key) === T && (U == null ? void 0 : U.colId) === B.id, pe = y[B.id], Ue = Q[B.id] ?? 150, Le = (x || B.editable) && B.editable !== !1;
1016
- let xe;
1017
- return te ? xe = Nt(B, E, $, qe, () => ie(null)) : B.template ? xe = B.template(pe, y) : B.htmlEnable ? xe = /* @__PURE__ */ t("span", { dangerouslySetInnerHTML: { __html: String(pe ?? "") } }) : B.type === "boolean" ? xe = /* @__PURE__ */ t(
1011
+ style: { display: "flex", height: l, borderBottom: fe, flexShrink: 0, background: X, transition: "background .1s", cursor: h ? "pointer" : "default" },
1012
+ onMouseEnter: (O) => !F && (O.currentTarget.style.background = e.primaryLt + "80"),
1013
+ onMouseLeave: (O) => !F && (O.currentTarget.style.background = X),
1014
+ children: q.map((O, re) => {
1015
+ const oe = (E == null ? void 0 : E.key) === W && (E == null ? void 0 : E.colId) === O.id, he = y[O.id], Ue = ee[O.id] ?? 150, Le = (x || O.editable) && O.editable !== !1;
1016
+ let ye;
1017
+ return oe ? ye = Rt(O, w, v, qe, () => _(null)) : O.template ? ye = O.template(he, y) : O.htmlEnable ? ye = /* @__PURE__ */ t("span", { dangerouslySetInnerHTML: { __html: String(he ?? "") } }) : O.type === "boolean" ? ye = /* @__PURE__ */ t(
1018
1018
  "input",
1019
1019
  {
1020
1020
  type: "checkbox",
1021
1021
  readOnly: !0,
1022
- checked: !!pe,
1022
+ checked: !!he,
1023
1023
  style: { width: 16, height: 16, accentColor: e.primary, cursor: Le ? "pointer" : "default" }
1024
1024
  }
1025
- ) : xe = It(pe, B.type), /* @__PURE__ */ t(
1025
+ ) : ye = Tt(he, O.type), /* @__PURE__ */ t(
1026
1026
  "div",
1027
1027
  {
1028
1028
  onClick: () => {
1029
- if (ve(y, L), !!Le)
1030
- if (B.type === "boolean") {
1031
- const Ie = !pe, Te = String(T);
1032
- k((Ne) => ({ ...Ne, [Te]: { ...Ne[Te] || {}, [B.id]: Ie } })), b == null || b(y, B.id, Ie);
1029
+ if (Se(y, I), !!Le)
1030
+ if (O.type === "boolean") {
1031
+ const Te = !he, Ie = String(W);
1032
+ m((Re) => ({ ...Re, [Ie]: { ...Re[Ie] || {}, [O.id]: Te } })), k == null || k(y, O.id, Te);
1033
1033
  } else
1034
- ie({ key: T, colId: B.id }), $(String(pe ?? ""));
1034
+ _({ key: W, colId: O.id }), v(String(he ?? ""));
1035
1035
  },
1036
- style: { ...ke(B.id, Ue, B.align, ee === 0, l, te ? "visible" : "hidden"), background: Y },
1037
- children: xe
1036
+ style: { ...ke(O.id, Ue, O.align, re === 0, l, oe ? "visible" : "hidden"), background: X },
1037
+ children: ye
1038
1038
  },
1039
- B.id
1039
+ O.id
1040
1040
  );
1041
1041
  })
1042
1042
  },
1043
- String(T)
1043
+ String(W)
1044
1044
  );
1045
1045
  }),
1046
- Z.length === 0 && /* @__PURE__ */ t("div", { style: { textAlign: "center", padding: 40, color: e.textMut, fontSize: 13 }, children: "No data" })
1046
+ te.length === 0 && /* @__PURE__ */ t("div", { style: { textAlign: "center", padding: 40, color: e.textMut, fontSize: 13 }, children: "No data" })
1047
1047
  ] }),
1048
- de && /* @__PURE__ */ t("div", { style: { display: "flex", borderTop: he, background: e.bg, flexShrink: 0, position: "sticky", bottom: 0, zIndex: 2 }, children: V.map((y, L) => {
1049
- var te;
1050
- const T = (te = y.footer) == null ? void 0 : te[0], A = fe[y.id] ?? { sum: 0, avg: 0, count: 0, min: 0, max: 0 };
1051
- let Y = "";
1052
- T && (typeof T.text == "function" ? Y = T.text(A) : T.text ? Y = T.text : T.summary && (Y = String(Math.round(A[T.summary] * 100) / 100)));
1053
- const B = Q[y.id] ?? 150, ee = y.id in ce;
1048
+ de && /* @__PURE__ */ t("div", { style: { display: "flex", borderTop: fe, background: e.bg, flexShrink: 0, position: "sticky", bottom: 0, zIndex: 2 }, children: q.map((y, I) => {
1049
+ var oe;
1050
+ const W = (oe = y.footer) == null ? void 0 : oe[0], F = pe[y.id] ?? { sum: 0, avg: 0, count: 0, min: 0, max: 0 };
1051
+ let X = "";
1052
+ W && (typeof W.text == "function" ? X = W.text(F) : W.text ? X = W.text : W.summary && (X = String(Math.round(F[W.summary] * 100) / 100)));
1053
+ const O = ee[y.id] ?? 150, re = y.id in ce;
1054
1054
  return /* @__PURE__ */ t("div", { style: {
1055
- ...ke(y.id, B, y.align, L === 0, a),
1055
+ ...ke(y.id, O, y.align, I === 0, s),
1056
1056
  fontWeight: 600,
1057
1057
  color: e.text,
1058
1058
  background: e.bg,
1059
- ...ee ? { zIndex: 3 } : {}
1060
- }, children: Y }, y.id);
1059
+ ...re ? { zIndex: 3 } : {}
1060
+ }, children: X }, y.id);
1061
1061
  }) })
1062
1062
  ] }) })
1063
1063
  }
1064
1064
  );
1065
1065
  }
1066
- const re = ["#0288d1", "#43a047", "#f57c00", "#e53935", "#8e24aa", "#00838f", "#ef6c00", "#2e7d32"];
1067
- function Et(n, o, d) {
1068
- const l = n.filter((a) => !a.parent), f = n.filter((a) => !!a.parent);
1069
- return l.map((a) => ({
1070
- name: a[d],
1071
- children: f.filter((h) => h.parent === a.id).map((h) => ({ name: h[d], value: Number(h[o] ?? 0) }))
1066
+ const ie = ["#0288d1", "#43a047", "#f57c00", "#e53935", "#8e24aa", "#00838f", "#ef6c00", "#2e7d32"];
1067
+ function Nt(n, i, d) {
1068
+ const l = n.filter((s) => !s.parent), u = n.filter((s) => !!s.parent);
1069
+ return l.map((s) => ({
1070
+ name: s[d],
1071
+ children: u.filter((f) => f.parent === s.id).map((f) => ({ name: f[d], value: Number(f[i] ?? 0) }))
1072
1072
  }));
1073
1073
  }
1074
- function Qt({
1074
+ function en({
1075
1075
  type: n = "bar",
1076
- data: o = [],
1076
+ data: i = [],
1077
1077
  series: d = [],
1078
1078
  scales: l = {},
1079
- legend: f,
1080
- height: a = 280,
1081
- style: h
1079
+ legend: u,
1080
+ height: s = 280,
1081
+ style: f
1082
1082
  }) {
1083
- var b, M, D, R, z, C, F, p, I, W, v, X, J, se, U, ie;
1084
- _(q, []);
1085
- const u = ((b = l.bottom) == null ? void 0 : b.text) || o[0] && Object.keys(o[0])[0] || "x", x = /* @__PURE__ */ t(
1083
+ var k, C, L, H, $, D, K, c, N, A, S, U, Z, o, E, _;
1084
+ J(Q, []);
1085
+ const p = ((k = l.bottom) == null ? void 0 : k.text) || i[0] && Object.keys(i[0])[0] || "x", x = /* @__PURE__ */ t(
1086
1086
  et,
1087
1087
  {
1088
1088
  contentStyle: { fontSize: 12, borderRadius: e.r, border: `1px solid ${e.border}` }
1089
1089
  }
1090
- ), w = f ? /* @__PURE__ */ t(
1090
+ ), z = u ? /* @__PURE__ */ t(
1091
1091
  tt,
1092
1092
  {
1093
1093
  iconSize: 10,
1094
1094
  wrapperStyle: { fontSize: 12 },
1095
- verticalAlign: f.valign === "bottom" ? "bottom" : f.valign === "middle" ? "middle" : "top",
1096
- align: f.halign ?? "center"
1095
+ verticalAlign: u.valign === "bottom" ? "bottom" : u.valign === "middle" ? "middle" : "top",
1096
+ align: u.halign ?? "center"
1097
1097
  }
1098
- ) : null, r = /* @__PURE__ */ t(nt, { strokeDasharray: "3 3", stroke: e.border }), i = /* @__PURE__ */ t(
1099
- Ee,
1098
+ ) : null, r = /* @__PURE__ */ t(nt, { strokeDasharray: "3 3", stroke: e.border }), b = /* @__PURE__ */ t(
1099
+ Ne,
1100
1100
  {
1101
- dataKey: u,
1101
+ dataKey: p,
1102
1102
  tick: { fontSize: 11, fill: e.textSec },
1103
1103
  axisLine: { stroke: e.border },
1104
1104
  tickLine: !1,
1105
- label: (M = l.bottom) != null && M.title ? { value: l.bottom.title, position: "insideBottom", offset: -4, fontSize: 11 } : void 0
1105
+ label: (C = l.bottom) != null && C.title ? { value: l.bottom.title, position: "insideBottom", offset: -4, fontSize: 11 } : void 0
1106
1106
  }
1107
- ), c = /* @__PURE__ */ t(
1108
- Re,
1107
+ ), h = /* @__PURE__ */ t(
1108
+ Ee,
1109
1109
  {
1110
1110
  tick: { fontSize: 11, fill: e.textSec },
1111
1111
  axisLine: !1,
1112
1112
  tickLine: !1,
1113
- domain: [((D = l.left) == null ? void 0 : D.min) ?? "auto", ((R = l.left) == null ? void 0 : R.max) ?? "auto"],
1114
- tickCount: (z = l.left) == null ? void 0 : z.maxTicks,
1115
- label: (C = l.left) != null && C.title ? { value: l.left.title, angle: -90, position: "insideLeft", fontSize: 11 } : void 0
1113
+ domain: [((L = l.left) == null ? void 0 : L.min) ?? "auto", ((H = l.left) == null ? void 0 : H.max) ?? "auto"],
1114
+ tickCount: ($ = l.left) == null ? void 0 : $.maxTicks,
1115
+ label: (D = l.left) != null && D.title ? { value: l.left.title, angle: -90, position: "insideLeft", fontSize: 11 } : void 0
1116
1116
  }
1117
- ), m = {
1117
+ ), M = {
1118
1118
  top: 10,
1119
1119
  right: 20,
1120
1120
  left: 0,
1121
- bottom: (F = l.bottom) != null && F.title ? 20 : 0
1122
- }, S = { data: o, margin: m };
1123
- let s;
1121
+ bottom: (K = l.bottom) != null && K.title ? 20 : 0
1122
+ }, R = { data: i, margin: M };
1123
+ let a;
1124
1124
  if (n === "bar")
1125
- s = /* @__PURE__ */ g(rt, { ...S, children: [
1125
+ a = /* @__PURE__ */ g(rt, { ...R, children: [
1126
1126
  r,
1127
- i,
1128
- c,
1127
+ b,
1128
+ h,
1129
1129
  x,
1130
- w,
1131
- d.map((E, $) => /* @__PURE__ */ t(
1130
+ z,
1131
+ d.map((w, v) => /* @__PURE__ */ t(
1132
1132
  ot,
1133
1133
  {
1134
- dataKey: E.value || E.id || "",
1135
- name: E.label || E.id,
1136
- fill: E.fill || E.color || re[$ % re.length],
1134
+ dataKey: w.value || w.id || "",
1135
+ name: w.label || w.id,
1136
+ fill: w.fill || w.color || ie[v % ie.length],
1137
1137
  radius: [3, 3, 0, 0]
1138
1138
  },
1139
- E.id ?? $
1139
+ w.id ?? v
1140
1140
  ))
1141
1141
  ] });
1142
1142
  else if (n === "line")
1143
- s = /* @__PURE__ */ g(it, { ...S, children: [
1143
+ a = /* @__PURE__ */ g(it, { ...R, children: [
1144
1144
  r,
1145
- i,
1146
- c,
1145
+ b,
1146
+ h,
1147
1147
  x,
1148
- w,
1149
- d.map((E, $) => {
1150
- const j = E.color || re[$ % re.length];
1148
+ z,
1149
+ d.map((w, v) => {
1150
+ const T = w.color || ie[v % ie.length];
1151
1151
  return /* @__PURE__ */ t(
1152
1152
  lt,
1153
1153
  {
1154
1154
  type: "monotone",
1155
- dataKey: E.value || E.id || "",
1156
- name: E.label || E.id,
1157
- stroke: j,
1158
- strokeWidth: E.strokeWidth ?? 2,
1159
- dot: { r: 3, fill: j }
1155
+ dataKey: w.value || w.id || "",
1156
+ name: w.label || w.id,
1157
+ stroke: T,
1158
+ strokeWidth: w.strokeWidth ?? 2,
1159
+ dot: { r: 3, fill: T }
1160
1160
  },
1161
- E.id ?? $
1161
+ w.id ?? v
1162
1162
  );
1163
1163
  })
1164
1164
  ] });
1165
1165
  else if (n === "area")
1166
- s = /* @__PURE__ */ g(st, { ...S, children: [
1166
+ a = /* @__PURE__ */ g(st, { ...R, children: [
1167
1167
  r,
1168
- i,
1169
- c,
1168
+ b,
1169
+ h,
1170
1170
  x,
1171
- w,
1172
- d.map((E, $) => {
1173
- const j = E.color || re[$ % re.length];
1171
+ z,
1172
+ d.map((w, v) => {
1173
+ const T = w.color || ie[v % ie.length];
1174
1174
  return /* @__PURE__ */ t(
1175
1175
  at,
1176
1176
  {
1177
1177
  type: "monotone",
1178
- dataKey: E.value || E.id || "",
1179
- name: E.label || E.id,
1180
- stroke: j,
1181
- fill: (E.fill || j) + "33",
1182
- strokeWidth: E.strokeWidth ?? 2
1178
+ dataKey: w.value || w.id || "",
1179
+ name: w.label || w.id,
1180
+ stroke: T,
1181
+ fill: (w.fill || T) + "33",
1182
+ strokeWidth: w.strokeWidth ?? 2
1183
1183
  },
1184
- E.id ?? $
1184
+ w.id ?? v
1185
1185
  );
1186
1186
  })
1187
1187
  ] });
1188
1188
  else if (n === "pie" || n === "donut") {
1189
- const E = d[0] || {}, $ = E.value || "value", j = E.text || "name", k = E.color && o[0] && E.color in o[0] ? E.color : null;
1190
- s = /* @__PURE__ */ g(dt, { children: [
1189
+ const w = d[0] || {}, v = w.value || "value", T = w.text || "name", m = w.color && i[0] && w.color in i[0] ? w.color : null;
1190
+ a = /* @__PURE__ */ g(dt, { children: [
1191
1191
  /* @__PURE__ */ t(
1192
1192
  ct,
1193
1193
  {
1194
- data: o,
1194
+ data: i,
1195
1195
  cx: "50%",
1196
1196
  cy: "50%",
1197
1197
  outerRadius: n === "donut" ? "70%" : "80%",
1198
1198
  innerRadius: n === "donut" ? "40%" : 0,
1199
- dataKey: $,
1200
- nameKey: j,
1201
- stroke: E.stroke || "none",
1202
- strokeWidth: E.strokeWidth ?? 0,
1203
- label: ({ name: P, percent: O }) => `${P ?? ""} ${((O ?? 0) * 100).toFixed(0)}%`,
1199
+ dataKey: v,
1200
+ nameKey: T,
1201
+ stroke: w.stroke || "none",
1202
+ strokeWidth: w.strokeWidth ?? 0,
1203
+ label: ({ name: j, percent: Y }) => `${j ?? ""} ${((Y ?? 0) * 100).toFixed(0)}%`,
1204
1204
  labelLine: !0,
1205
1205
  paddingAngle: 2,
1206
- children: o.map((P, O) => /* @__PURE__ */ t(
1206
+ children: i.map((j, Y) => /* @__PURE__ */ t(
1207
1207
  ut,
1208
1208
  {
1209
- fill: k ? P[k] : re[O % re.length]
1209
+ fill: m ? j[m] : ie[Y % ie.length]
1210
1210
  },
1211
- O
1211
+ Y
1212
1212
  ))
1213
1213
  }
1214
1214
  ),
1215
1215
  x,
1216
- w
1216
+ z
1217
1217
  ] });
1218
1218
  } else if (n === "radar") {
1219
- const E = ((p = l.radial) == null ? void 0 : p.value) || u;
1220
- s = /* @__PURE__ */ g(pt, { ...S, cx: "50%", cy: "50%", children: [
1219
+ const w = ((c = l.radial) == null ? void 0 : c.value) || p;
1220
+ a = /* @__PURE__ */ g(pt, { ...R, cx: "50%", cy: "50%", children: [
1221
1221
  /* @__PURE__ */ t(ht, {}),
1222
- /* @__PURE__ */ t(ft, { dataKey: E, tick: { fontSize: 11 } }),
1223
- /* @__PURE__ */ t(xt, { tick: { fontSize: 9, fill: e.textMut }, axisLine: !1 }),
1224
- d.map(($, j) => {
1225
- const k = $.color || $.pointColor || re[j % re.length];
1222
+ /* @__PURE__ */ t(ft, { dataKey: w, tick: { fontSize: 11 } }),
1223
+ /* @__PURE__ */ t(gt, { tick: { fontSize: 9, fill: e.textMut }, axisLine: !1 }),
1224
+ d.map((v, T) => {
1225
+ const m = v.color || v.pointColor || ie[T % ie.length];
1226
1226
  return /* @__PURE__ */ t(
1227
- gt,
1227
+ xt,
1228
1228
  {
1229
- dataKey: $.value || $.id || "",
1230
- name: $.label || $.id,
1231
- stroke: k,
1232
- fill: k + "44"
1229
+ dataKey: v.value || v.id || "",
1230
+ name: v.label || v.id,
1231
+ stroke: m,
1232
+ fill: m + "44"
1233
1233
  },
1234
- $.id ?? j
1234
+ v.id ?? T
1235
1235
  );
1236
1236
  }),
1237
1237
  x,
1238
- w
1238
+ z
1239
1239
  ] });
1240
1240
  } else if (n === "scatter")
1241
- s = /* @__PURE__ */ g(yt, { margin: m, children: [
1241
+ a = /* @__PURE__ */ g(yt, { margin: M, children: [
1242
1242
  r,
1243
1243
  /* @__PURE__ */ t(
1244
- Ee,
1244
+ Ne,
1245
1245
  {
1246
1246
  type: "number",
1247
1247
  dataKey: "x",
1248
- name: ((I = l.bottom) == null ? void 0 : I.title) || "x",
1248
+ name: ((N = l.bottom) == null ? void 0 : N.title) || "x",
1249
1249
  tick: { fontSize: 11, fill: e.textSec },
1250
1250
  tickLine: !1,
1251
- domain: [((W = l.bottom) == null ? void 0 : W.min) ?? "auto", ((v = l.bottom) == null ? void 0 : v.max) ?? "auto"],
1252
- label: (X = l.bottom) != null && X.title ? { value: l.bottom.title, position: "insideBottom", offset: -4, fontSize: 11 } : void 0
1251
+ domain: [((A = l.bottom) == null ? void 0 : A.min) ?? "auto", ((S = l.bottom) == null ? void 0 : S.max) ?? "auto"],
1252
+ label: (U = l.bottom) != null && U.title ? { value: l.bottom.title, position: "insideBottom", offset: -4, fontSize: 11 } : void 0
1253
1253
  }
1254
1254
  ),
1255
1255
  /* @__PURE__ */ t(
1256
- Re,
1256
+ Ee,
1257
1257
  {
1258
1258
  type: "number",
1259
1259
  dataKey: "y",
1260
- name: ((J = l.left) == null ? void 0 : J.title) || "y",
1260
+ name: ((Z = l.left) == null ? void 0 : Z.title) || "y",
1261
1261
  tick: { fontSize: 11, fill: e.textSec },
1262
1262
  tickLine: !1,
1263
1263
  axisLine: !1,
1264
- domain: [((se = l.left) == null ? void 0 : se.min) ?? "auto", ((U = l.left) == null ? void 0 : U.max) ?? "auto"],
1265
- label: (ie = l.left) != null && ie.title ? { value: l.left.title, angle: -90, position: "insideLeft", fontSize: 11 } : void 0
1264
+ domain: [((o = l.left) == null ? void 0 : o.min) ?? "auto", ((E = l.left) == null ? void 0 : E.max) ?? "auto"],
1265
+ label: (_ = l.left) != null && _.title ? { value: l.left.title, angle: -90, position: "insideLeft", fontSize: 11 } : void 0
1266
1266
  }
1267
1267
  ),
1268
1268
  x,
1269
- w,
1270
- d.map((E, $) => {
1271
- const j = E.value || "x", k = E.valueY || "y", P = (E.data || o).map((O) => ({
1272
- x: O[j],
1273
- y: O[k]
1269
+ z,
1270
+ d.map((w, v) => {
1271
+ const T = w.value || "x", m = w.valueY || "y", j = (w.data || i).map((Y) => ({
1272
+ x: Y[T],
1273
+ y: Y[m]
1274
1274
  }));
1275
1275
  return /* @__PURE__ */ t(
1276
1276
  bt,
1277
1277
  {
1278
- data: P,
1279
- name: E.label || E.id,
1280
- fill: E.color || re[$ % re.length]
1278
+ data: j,
1279
+ name: w.label || w.id,
1280
+ fill: w.color || ie[v % ie.length]
1281
1281
  },
1282
- E.id ?? $
1282
+ w.id ?? v
1283
1283
  );
1284
1284
  })
1285
1285
  ] });
1286
1286
  else if (n === "treeMap") {
1287
- const E = d[0] || {}, $ = E.value || "value", j = E.text || "name", k = Et(o, $, j), P = E.stroke || e.surface, O = E.strokeWidth ?? 2;
1288
- s = /* @__PURE__ */ t(
1287
+ const w = d[0] || {}, v = w.value || "value", T = w.text || "name", m = Nt(i, v, T), j = w.stroke || e.surface, Y = w.strokeWidth ?? 2;
1288
+ a = /* @__PURE__ */ t(
1289
1289
  vt,
1290
1290
  {
1291
- data: k,
1291
+ data: m,
1292
1292
  dataKey: "value",
1293
1293
  aspectRatio: 4 / 3,
1294
- stroke: P,
1294
+ stroke: j,
1295
1295
  content: (G) => {
1296
- const { x: K, y: V, width: Q, height: Z, depth: fe, index: ne, name: H } = G;
1297
- if (fe === 0) return null;
1298
- const de = re[ne % re.length];
1296
+ const { x: V, y: q, width: ee, height: te, depth: pe, index: ne, name: P } = G;
1297
+ if (pe === 0) return null;
1298
+ const de = ie[ne % ie.length];
1299
1299
  return /* @__PURE__ */ g("g", { children: [
1300
1300
  /* @__PURE__ */ t(
1301
1301
  "rect",
1302
1302
  {
1303
- x: K,
1304
- y: V,
1305
- width: Q,
1306
- height: Z,
1303
+ x: V,
1304
+ y: q,
1305
+ width: ee,
1306
+ height: te,
1307
1307
  fill: de,
1308
- stroke: P,
1309
- strokeWidth: O,
1308
+ stroke: j,
1309
+ strokeWidth: Y,
1310
1310
  style: { borderRadius: 3 }
1311
1311
  }
1312
1312
  ),
1313
- Q > 40 && Z > 20 && /* @__PURE__ */ t(
1313
+ ee > 40 && te > 20 && /* @__PURE__ */ t(
1314
1314
  "text",
1315
1315
  {
1316
- x: K + Q / 2,
1317
- y: V + Z / 2,
1316
+ x: V + ee / 2,
1317
+ y: q + te / 2,
1318
1318
  textAnchor: "middle",
1319
1319
  dominantBaseline: "middle",
1320
1320
  fill: "#fff",
1321
1321
  fontSize: 11,
1322
1322
  pointerEvents: "none",
1323
- children: H
1323
+ children: P
1324
1324
  }
1325
1325
  )
1326
1326
  ] });
@@ -1332,195 +1332,195 @@ function Qt({
1332
1332
  "div",
1333
1333
  {
1334
1334
  className: "dhx",
1335
- style: { width: "100%", height: a, padding: 12, background: e.surface, borderRadius: e.rMd, ...h },
1336
- children: /* @__PURE__ */ t(mt, { width: "100%", height: "100%", children: s })
1335
+ style: { width: "100%", height: s, padding: 12, background: e.surface, borderRadius: e.rMd, ...f },
1336
+ children: /* @__PURE__ */ t(mt, { width: "100%", height: "100%", children: a })
1337
1337
  }
1338
1338
  );
1339
1339
  }
1340
- const Rt = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"], Wt = ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"];
1341
- function Zt({ value: n, range: o = !1, timepicker: d = !1, onChange: l, style: f }) {
1342
- const a = /* @__PURE__ */ new Date(), h = n ? new Date(Array.isArray(n) ? n[0] : n) : a, [u, x] = N(h), [w, r] = N(n ?? (o ? [null, null] : null)), [i, c] = N(null), [m, S] = N({ h: 0, m: 0 });
1343
- _(q, []);
1344
- const s = u.getFullYear(), b = u.getMonth(), M = new Date(s, b, 1).getDay(), D = new Date(s, b + 1, 0).getDate(), R = [];
1345
- for (let p = 0; p < M; p++) R.push(null);
1346
- for (let p = 1; p <= D; p++) R.push(new Date(s, b, p));
1347
- const z = (p) => p.toDateString() === a.toDateString(), C = (p) => {
1348
- if (!w) return !1;
1349
- if (o && Array.isArray(w)) {
1350
- const [I, W] = w;
1351
- if (!I) return !1;
1352
- const v = p.getTime();
1353
- return W ? v >= I.getTime() && v <= W.getTime() : p.toDateString() === I.toDateString();
1340
+ const Et = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"], Wt = ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"];
1341
+ function tn({ value: n, range: i = !1, timepicker: d = !1, onChange: l, style: u }) {
1342
+ const s = /* @__PURE__ */ new Date(), f = n ? new Date(Array.isArray(n) ? n[0] : n) : s, [p, x] = B(f), [z, r] = B(n ?? (i ? [null, null] : null)), [b, h] = B(null), [M, R] = B({ h: 0, m: 0 });
1343
+ J(Q, []);
1344
+ const a = p.getFullYear(), k = p.getMonth(), C = new Date(a, k, 1).getDay(), L = new Date(a, k + 1, 0).getDate(), H = [];
1345
+ for (let c = 0; c < C; c++) H.push(null);
1346
+ for (let c = 1; c <= L; c++) H.push(new Date(a, k, c));
1347
+ const $ = (c) => c.toDateString() === s.toDateString(), D = (c) => {
1348
+ if (!z) return !1;
1349
+ if (i && Array.isArray(z)) {
1350
+ const [N, A] = z;
1351
+ if (!N) return !1;
1352
+ const S = c.getTime();
1353
+ return A ? S >= N.getTime() && S <= A.getTime() : c.toDateString() === N.toDateString();
1354
1354
  }
1355
- return p.toDateString() === w.toDateString();
1356
- }, F = (p) => {
1357
- if (o) {
1358
- const [I, W] = Array.isArray(w) ? w : [null, null];
1359
- if (!I || W)
1360
- r([p, null]);
1355
+ return c.toDateString() === z.toDateString();
1356
+ }, K = (c) => {
1357
+ if (i) {
1358
+ const [N, A] = Array.isArray(z) ? z : [null, null];
1359
+ if (!N || A)
1360
+ r([c, null]);
1361
1361
  else {
1362
- const v = p < I ? [p, I] : [I, p];
1363
- r(v), l == null || l(v);
1362
+ const S = c < N ? [c, N] : [N, c];
1363
+ r(S), l == null || l(S);
1364
1364
  }
1365
1365
  } else
1366
- r(p), l == null || l(p);
1366
+ r(c), l == null || l(c);
1367
1367
  };
1368
- return /* @__PURE__ */ g("div", { className: "dhx", style: { background: e.surface, border: `1px solid ${e.border}`, borderRadius: e.rMd, padding: 16, display: "inline-block", boxShadow: e.shadow, ...f }, children: [
1368
+ return /* @__PURE__ */ g("div", { className: "dhx", style: { background: e.surface, border: `1px solid ${e.border}`, borderRadius: e.rMd, padding: 16, display: "inline-block", boxShadow: e.shadow, ...u }, children: [
1369
1369
  /* @__PURE__ */ g("div", { style: { display: "flex", alignItems: "center", justifyContent: "space-between", marginBottom: 12 }, children: [
1370
- /* @__PURE__ */ t("button", { onClick: () => x((p) => new Date(p.getFullYear(), p.getMonth() - 1, 1)), className: "dhx dhx-btn dhx-btn-ghost", style: { height: 28, padding: "0 8px", fontSize: 16 }, children: "‹" }),
1370
+ /* @__PURE__ */ t("button", { onClick: () => x((c) => new Date(c.getFullYear(), c.getMonth() - 1, 1)), className: "dhx dhx-btn dhx-btn-ghost", style: { height: 28, padding: "0 8px", fontSize: 16 }, children: "‹" }),
1371
1371
  /* @__PURE__ */ g("div", { style: { fontWeight: 700, fontSize: 14 }, children: [
1372
- Rt[b],
1372
+ Et[k],
1373
1373
  " ",
1374
- s
1374
+ a
1375
1375
  ] }),
1376
- /* @__PURE__ */ t("button", { onClick: () => x((p) => new Date(p.getFullYear(), p.getMonth() + 1, 1)), className: "dhx dhx-btn dhx-btn-ghost", style: { height: 28, padding: "0 8px", fontSize: 16 }, children: "›" })
1376
+ /* @__PURE__ */ t("button", { onClick: () => x((c) => new Date(c.getFullYear(), c.getMonth() + 1, 1)), className: "dhx dhx-btn dhx-btn-ghost", style: { height: 28, padding: "0 8px", fontSize: 16 }, children: "›" })
1377
1377
  ] }),
1378
1378
  /* @__PURE__ */ g("div", { style: { display: "grid", gridTemplateColumns: "repeat(7, 32px)", gap: 2 }, children: [
1379
- Wt.map((p) => /* @__PURE__ */ t("div", { style: { textAlign: "center", fontSize: 11, fontWeight: 600, color: e.textMut, paddingBottom: 4 }, children: p }, p)),
1380
- R.map((p, I) => {
1381
- const W = p ? C(p) : !1, v = p && i && p.toDateString() === i.toDateString();
1379
+ Wt.map((c) => /* @__PURE__ */ t("div", { style: { textAlign: "center", fontSize: 11, fontWeight: 600, color: e.textMut, paddingBottom: 4 }, children: c }, c)),
1380
+ H.map((c, N) => {
1381
+ const A = c ? D(c) : !1, S = c && b && c.toDateString() === b.toDateString();
1382
1382
  return /* @__PURE__ */ t(
1383
1383
  "div",
1384
1384
  {
1385
- onClick: () => p && F(p),
1386
- onMouseEnter: () => p && c(p),
1387
- onMouseLeave: () => c(null),
1388
- style: { width: 32, height: 32, display: "flex", alignItems: "center", justifyContent: "center", borderRadius: e.r, cursor: p ? "pointer" : "default", fontSize: 12, fontWeight: p && z(p) ? 700 : 400, background: W ? e.primary : v ? e.bg : "transparent", color: W ? "#fff" : p && z(p) ? e.primary : p ? e.text : "transparent", border: p && z(p) && !W ? `1px solid ${e.primary}` : "1px solid transparent", transition: "all .1s" },
1389
- children: p == null ? void 0 : p.getDate()
1385
+ onClick: () => c && K(c),
1386
+ onMouseEnter: () => c && h(c),
1387
+ onMouseLeave: () => h(null),
1388
+ style: { width: 32, height: 32, display: "flex", alignItems: "center", justifyContent: "center", borderRadius: e.r, cursor: c ? "pointer" : "default", fontSize: 12, fontWeight: c && $(c) ? 700 : 400, background: A ? e.primary : S ? e.bg : "transparent", color: A ? "#fff" : c && $(c) ? e.primary : c ? e.text : "transparent", border: c && $(c) && !A ? `1px solid ${e.primary}` : "1px solid transparent", transition: "all .1s" },
1389
+ children: c == null ? void 0 : c.getDate()
1390
1390
  },
1391
- I
1391
+ N
1392
1392
  );
1393
1393
  })
1394
1394
  ] }),
1395
1395
  d && /* @__PURE__ */ g("div", { style: { borderTop: `1px solid ${e.border}`, marginTop: 12, paddingTop: 12, display: "flex", alignItems: "center", justifyContent: "center", gap: 8 }, children: [
1396
- /* @__PURE__ */ t("input", { type: "number", min: 0, max: 23, value: m.h, onChange: (p) => S((I) => ({ ...I, h: +p.target.value })), className: "dhx dhx-input", style: { width: 50, textAlign: "center" } }),
1396
+ /* @__PURE__ */ t("input", { type: "number", min: 0, max: 23, value: M.h, onChange: (c) => R((N) => ({ ...N, h: +c.target.value })), className: "dhx dhx-input", style: { width: 50, textAlign: "center" } }),
1397
1397
  /* @__PURE__ */ t("span", { style: { fontWeight: 700, color: e.textSec }, children: ":" }),
1398
- /* @__PURE__ */ t("input", { type: "number", min: 0, max: 59, value: m.m, onChange: (p) => S((I) => ({ ...I, m: +p.target.value })), className: "dhx dhx-input", style: { width: 50, textAlign: "center" } })
1398
+ /* @__PURE__ */ t("input", { type: "number", min: 0, max: 59, value: M.m, onChange: (c) => R((N) => ({ ...N, m: +c.target.value })), className: "dhx dhx-input", style: { width: 50, textAlign: "center" } })
1399
1399
  ] })
1400
1400
  ] });
1401
1401
  }
1402
- function At({ value: n, onChange: o, timeFormat: d = 12, controls: l = !1, minuteStep: f = 5, style: a }) {
1403
- const [h, u] = N((n == null ? void 0 : n.h) ?? (d === 24 ? 0 : 12)), [x, w] = N((n == null ? void 0 : n.m) ?? 0), [r, i] = N((n == null ? void 0 : n.ampm) ?? "AM"), [c, m] = N(null);
1404
- _(q, []);
1405
- const S = d === 24 ? Array.from({ length: 24 }, (z, C) => C) : Array.from({ length: 12 }, (z, C) => C + 1), s = Array.from({ length: Math.ceil(60 / f) }, (z, C) => C * f), b = (z, C, F) => {
1406
- const p = d === 24 ? { h: z, m: C } : { h: z, m: C, ampm: F };
1407
- l ? m(p) : o == null || o(p);
1408
- }, M = () => {
1409
- m(null), u((n == null ? void 0 : n.h) ?? (d === 24 ? 0 : 12)), w((n == null ? void 0 : n.m) ?? 0), i((n == null ? void 0 : n.ampm) ?? "AM");
1410
- }, D = { display: "flex", flexDirection: "column", alignItems: "center", gap: 4 }, R = (z) => ({
1402
+ function Bt({ value: n, onChange: i, timeFormat: d = 12, controls: l = !1, minuteStep: u = 5, style: s }) {
1403
+ const [f, p] = B((n == null ? void 0 : n.h) ?? (d === 24 ? 0 : 12)), [x, z] = B((n == null ? void 0 : n.m) ?? 0), [r, b] = B((n == null ? void 0 : n.ampm) ?? "AM"), [h, M] = B(null);
1404
+ J(Q, []);
1405
+ const R = d === 24 ? Array.from({ length: 24 }, ($, D) => D) : Array.from({ length: 12 }, ($, D) => D + 1), a = Array.from({ length: Math.ceil(60 / u) }, ($, D) => D * u), k = ($, D, K) => {
1406
+ const c = d === 24 ? { h: $, m: D } : { h: $, m: D, ampm: K };
1407
+ l ? M(c) : i == null || i(c);
1408
+ }, C = () => {
1409
+ M(null), p((n == null ? void 0 : n.h) ?? (d === 24 ? 0 : 12)), z((n == null ? void 0 : n.m) ?? 0), b((n == null ? void 0 : n.ampm) ?? "AM");
1410
+ }, L = { display: "flex", flexDirection: "column", alignItems: "center", gap: 4 }, H = ($) => ({
1411
1411
  height: 32,
1412
1412
  display: "flex",
1413
1413
  alignItems: "center",
1414
1414
  justifyContent: "center",
1415
1415
  cursor: "pointer",
1416
1416
  fontSize: 13,
1417
- fontWeight: z ? 700 : 400,
1418
- background: z ? e.primaryLt : "transparent",
1419
- color: z ? e.primary : e.text
1417
+ fontWeight: $ ? 700 : 400,
1418
+ background: $ ? e.primaryLt : "transparent",
1419
+ color: $ ? e.primary : e.text
1420
1420
  });
1421
- return /* @__PURE__ */ g("div", { className: "dhx", style: { background: e.surface, border: `1px solid ${e.border}`, borderRadius: e.rMd, padding: 16, display: "inline-block", boxShadow: e.shadow, ...a }, children: [
1421
+ return /* @__PURE__ */ g("div", { className: "dhx", style: { background: e.surface, border: `1px solid ${e.border}`, borderRadius: e.rMd, padding: 16, display: "inline-block", boxShadow: e.shadow, ...s }, children: [
1422
1422
  /* @__PURE__ */ g("div", { style: { display: "flex", gap: 8, alignItems: "stretch" }, children: [
1423
- /* @__PURE__ */ g("div", { style: D, children: [
1423
+ /* @__PURE__ */ g("div", { style: L, children: [
1424
1424
  /* @__PURE__ */ t("span", { style: { fontSize: 11, fontWeight: 600, color: e.textMut }, children: "Hours" }),
1425
- /* @__PURE__ */ t("div", { className: "dhx-scroll", style: { height: 160, overflowY: "auto", width: 48, border: `1px solid ${e.border}`, borderRadius: e.r }, children: S.map((z) => /* @__PURE__ */ t(
1425
+ /* @__PURE__ */ t("div", { className: "dhx-scroll", style: { height: 160, overflowY: "auto", width: 48, border: `1px solid ${e.border}`, borderRadius: e.r }, children: R.map(($) => /* @__PURE__ */ t(
1426
1426
  "div",
1427
1427
  {
1428
1428
  onClick: () => {
1429
- u(z), b(z, x, r);
1429
+ p($), k($, x, r);
1430
1430
  },
1431
- style: R(h === z),
1432
- onMouseEnter: (C) => h !== z && (C.currentTarget.style.background = e.bg),
1433
- onMouseLeave: (C) => h !== z && (C.currentTarget.style.background = "transparent"),
1434
- children: String(z).padStart(2, "0")
1431
+ style: H(f === $),
1432
+ onMouseEnter: (D) => f !== $ && (D.currentTarget.style.background = e.bg),
1433
+ onMouseLeave: (D) => f !== $ && (D.currentTarget.style.background = "transparent"),
1434
+ children: String($).padStart(2, "0")
1435
1435
  },
1436
- z
1436
+ $
1437
1437
  )) })
1438
1438
  ] }),
1439
- /* @__PURE__ */ g("div", { style: D, children: [
1439
+ /* @__PURE__ */ g("div", { style: L, children: [
1440
1440
  /* @__PURE__ */ t("span", { style: { fontSize: 11, fontWeight: 600, color: e.textMut }, children: "Minutes" }),
1441
- /* @__PURE__ */ t("div", { className: "dhx-scroll", style: { height: 160, overflowY: "auto", width: 48, border: `1px solid ${e.border}`, borderRadius: e.r }, children: s.map((z) => /* @__PURE__ */ t(
1441
+ /* @__PURE__ */ t("div", { className: "dhx-scroll", style: { height: 160, overflowY: "auto", width: 48, border: `1px solid ${e.border}`, borderRadius: e.r }, children: a.map(($) => /* @__PURE__ */ t(
1442
1442
  "div",
1443
1443
  {
1444
1444
  onClick: () => {
1445
- w(z), b(h, z, r);
1445
+ z($), k(f, $, r);
1446
1446
  },
1447
- style: R(x === z),
1448
- onMouseEnter: (C) => x !== z && (C.currentTarget.style.background = e.bg),
1449
- onMouseLeave: (C) => x !== z && (C.currentTarget.style.background = "transparent"),
1450
- children: String(z).padStart(2, "0")
1447
+ style: H(x === $),
1448
+ onMouseEnter: (D) => x !== $ && (D.currentTarget.style.background = e.bg),
1449
+ onMouseLeave: (D) => x !== $ && (D.currentTarget.style.background = "transparent"),
1450
+ children: String($).padStart(2, "0")
1451
1451
  },
1452
- z
1452
+ $
1453
1453
  )) })
1454
1454
  ] }),
1455
- d === 12 && /* @__PURE__ */ g("div", { style: D, children: [
1455
+ d === 12 && /* @__PURE__ */ g("div", { style: L, children: [
1456
1456
  /* @__PURE__ */ t("span", { style: { fontSize: 11, fontWeight: 600, color: e.textMut }, children: "AM/PM" }),
1457
- /* @__PURE__ */ t("div", { style: { display: "flex", flexDirection: "column", border: `1px solid ${e.border}`, borderRadius: e.r, overflow: "hidden" }, children: ["AM", "PM"].map((z) => /* @__PURE__ */ t(
1457
+ /* @__PURE__ */ t("div", { style: { display: "flex", flexDirection: "column", border: `1px solid ${e.border}`, borderRadius: e.r, overflow: "hidden" }, children: ["AM", "PM"].map(($) => /* @__PURE__ */ t(
1458
1458
  "div",
1459
1459
  {
1460
1460
  onClick: () => {
1461
- i(z), b(h, x, z);
1461
+ b($), k(f, x, $);
1462
1462
  },
1463
- style: { height: 40, display: "flex", alignItems: "center", justifyContent: "center", cursor: "pointer", padding: "0 12px", fontSize: 13, fontWeight: r === z ? 700 : 400, background: r === z ? e.primary : e.surface, color: r === z ? "#fff" : e.text },
1464
- children: z
1463
+ style: { height: 40, display: "flex", alignItems: "center", justifyContent: "center", cursor: "pointer", padding: "0 12px", fontSize: 13, fontWeight: r === $ ? 700 : 400, background: r === $ ? e.primary : e.surface, color: r === $ ? "#fff" : e.text },
1464
+ children: $
1465
1465
  },
1466
- z
1466
+ $
1467
1467
  )) })
1468
1468
  ] })
1469
1469
  ] }),
1470
1470
  /* @__PURE__ */ g("div", { style: { textAlign: "center", marginTop: 12, fontSize: 22, fontWeight: 700, color: e.primary, letterSpacing: 2 }, children: [
1471
- String(h).padStart(2, "0"),
1471
+ String(f).padStart(2, "0"),
1472
1472
  ":",
1473
1473
  String(x).padStart(2, "0"),
1474
1474
  d === 12 ? ` ${r}` : ""
1475
1475
  ] }),
1476
1476
  l && /* @__PURE__ */ g("div", { style: { display: "flex", gap: 8, justifyContent: "flex-end", marginTop: 12 }, children: [
1477
- /* @__PURE__ */ t("button", { className: "dhx dhx-btn dhx-btn-secondary", onClick: M, children: "Cancel" }),
1477
+ /* @__PURE__ */ t("button", { className: "dhx dhx-btn dhx-btn-secondary", onClick: C, children: "Cancel" }),
1478
1478
  /* @__PURE__ */ t("button", { className: "dhx dhx-btn dhx-btn-primary", onClick: () => {
1479
- const z = c ?? (d === 24 ? { h, m: x } : { h, m: x, ampm: r });
1480
- o == null || o(z);
1479
+ const $ = h ?? (d === 24 ? { h: f, m: x } : { h: f, m: x, ampm: r });
1480
+ i == null || i($);
1481
1481
  }, children: "Apply" })
1482
1482
  ] })
1483
1483
  ] });
1484
1484
  }
1485
- const Bt = ({ open: n }) => /* @__PURE__ */ t("svg", { width: "12", height: "12", viewBox: "0 0 12 12", style: { flexShrink: 0, transition: "transform .15s", transform: n ? "rotate(180deg)" : "rotate(0deg)" }, children: /* @__PURE__ */ t("path", { d: "M2 4l4 4 4-4", stroke: e.textMut, strokeWidth: "1.5", fill: "none", strokeLinecap: "round", strokeLinejoin: "round" }) });
1486
- function Be({ data: n = [], value: o, placeholder: d = "Select or type...", multiselection: l = !1, label: f, onChange: a, style: h }) {
1487
- var F;
1488
- const [u, x] = N(!1), [w, r] = N(""), [i, c] = N(
1489
- l ? o ? [].concat(o) : [] : o || null
1490
- ), m = oe(null), S = oe(null);
1491
- _(q, []), ge(m, ae(() => {
1485
+ const Ht = ({ open: n }) => /* @__PURE__ */ t("svg", { width: "12", height: "12", viewBox: "0 0 12 12", style: { flexShrink: 0, transition: "transform .15s", transform: n ? "rotate(180deg)" : "rotate(0deg)" }, children: /* @__PURE__ */ t("path", { d: "M2 4l4 4 4-4", stroke: e.textMut, strokeWidth: "1.5", fill: "none", strokeLinecap: "round", strokeLinejoin: "round" }) });
1486
+ function He({ data: n = [], value: i, placeholder: d = "Select or type...", multiselection: l = !1, label: u, onChange: s, style: f }) {
1487
+ var K;
1488
+ const [p, x] = B(!1), [z, r] = B(""), [b, h] = B(
1489
+ l ? i ? [].concat(i) : [] : i || null
1490
+ ), M = le(null), R = le(null);
1491
+ J(Q, []), xe(M, ae(() => {
1492
1492
  x(!1), r("");
1493
1493
  }, []));
1494
- const s = ue(
1495
- () => n.filter((p) => !w || p.value.toLowerCase().includes(w.toLowerCase())),
1496
- [n, w]
1497
- ), b = (p) => l ? (i || []).includes(p) : i === p, M = (p) => {
1498
- const I = p.id || p.value;
1494
+ const a = ue(
1495
+ () => n.filter((c) => !z || c.value.toLowerCase().includes(z.toLowerCase())),
1496
+ [n, z]
1497
+ ), k = (c) => l ? (b || []).includes(c) : b === c, C = (c) => {
1498
+ const N = c.id || c.value;
1499
1499
  if (l) {
1500
- const W = b(I) ? i.filter((v) => v !== I) : [...i || [], I];
1501
- c(W), a == null || a(W);
1500
+ const A = k(N) ? b.filter((S) => S !== N) : [...b || [], N];
1501
+ h(A), s == null || s(A);
1502
1502
  } else
1503
- c(I), r(""), x(!1), a == null || a(I);
1504
- }, D = (p) => {
1505
- const I = i.filter((W) => W !== p);
1506
- c(I), a == null || a(I);
1507
- }, R = () => {
1503
+ h(N), r(""), x(!1), s == null || s(N);
1504
+ }, L = (c) => {
1505
+ const N = b.filter((A) => A !== c);
1506
+ h(N), s == null || s(N);
1507
+ }, H = () => {
1508
1508
  x(!0), setTimeout(() => {
1509
- var p;
1510
- return (p = S.current) == null ? void 0 : p.focus();
1509
+ var c;
1510
+ return (c = R.current) == null ? void 0 : c.focus();
1511
1511
  }, 0);
1512
- }, z = ((F = n.find((p) => (p.id || p.value) === i)) == null ? void 0 : F.value) || "", C = l ? i || [] : [];
1513
- return /* @__PURE__ */ g("div", { ref: m, className: "dhx", style: { position: "relative", ...h }, children: [
1514
- f && /* @__PURE__ */ t("label", { className: "dhx dhx-label", children: f }),
1512
+ }, $ = ((K = n.find((c) => (c.id || c.value) === b)) == null ? void 0 : K.value) || "", D = l ? b || [] : [];
1513
+ return /* @__PURE__ */ g("div", { ref: M, className: "dhx", style: { position: "relative", ...f }, children: [
1514
+ u && /* @__PURE__ */ t("label", { className: "dhx dhx-label", children: u }),
1515
1515
  /* @__PURE__ */ g(
1516
1516
  "div",
1517
1517
  {
1518
- onClick: R,
1518
+ onClick: H,
1519
1519
  style: {
1520
1520
  display: "flex",
1521
1521
  alignItems: "center",
1522
1522
  flexWrap: l ? "wrap" : "nowrap",
1523
- border: `1px solid ${u ? e.primary : e.border}`,
1523
+ border: `1px solid ${p ? e.primary : e.border}`,
1524
1524
  borderRadius: e.r,
1525
1525
  minHeight: 34,
1526
1526
  padding: "4px 8px",
@@ -1528,12 +1528,12 @@ function Be({ data: n = [], value: o, placeholder: d = "Select or type...", mult
1528
1528
  background: e.surface,
1529
1529
  gap: 4,
1530
1530
  transition: "border-color .15s",
1531
- boxShadow: u ? `0 0 0 3px ${e.primary}22` : "none"
1531
+ boxShadow: p ? `0 0 0 3px ${e.primary}22` : "none"
1532
1532
  },
1533
1533
  children: [
1534
1534
  l && /* @__PURE__ */ g(Ye, { children: [
1535
- C.map((p) => {
1536
- var I;
1535
+ D.map((c) => {
1536
+ var N;
1537
1537
  return /* @__PURE__ */ g("span", { style: {
1538
1538
  display: "inline-flex",
1539
1539
  alignItems: "center",
@@ -1546,30 +1546,30 @@ function Be({ data: n = [], value: o, placeholder: d = "Select or type...", mult
1546
1546
  lineHeight: 1.5,
1547
1547
  whiteSpace: "nowrap"
1548
1548
  }, children: [
1549
- ((I = n.find((W) => (W.id || W.value) === p)) == null ? void 0 : I.value) || p,
1549
+ ((N = n.find((A) => (A.id || A.value) === c)) == null ? void 0 : N.value) || c,
1550
1550
  /* @__PURE__ */ t(
1551
1551
  "span",
1552
1552
  {
1553
- onClick: (W) => {
1554
- W.stopPropagation(), D(p);
1553
+ onClick: (A) => {
1554
+ A.stopPropagation(), L(c);
1555
1555
  },
1556
1556
  style: { cursor: "pointer", fontSize: 15, lineHeight: 1, opacity: 0.75, marginLeft: 2 },
1557
1557
  children: "×"
1558
1558
  }
1559
1559
  )
1560
- ] }, p);
1560
+ ] }, c);
1561
1561
  }),
1562
1562
  /* @__PURE__ */ t(
1563
1563
  "input",
1564
1564
  {
1565
- ref: S,
1566
- value: w,
1567
- onChange: (p) => {
1568
- r(p.target.value), x(!0);
1565
+ ref: R,
1566
+ value: z,
1567
+ onChange: (c) => {
1568
+ r(c.target.value), x(!0);
1569
1569
  },
1570
1570
  onFocus: () => x(!0),
1571
- onClick: (p) => p.stopPropagation(),
1572
- placeholder: C.length ? "" : d,
1571
+ onClick: (c) => c.stopPropagation(),
1572
+ placeholder: D.length ? "" : d,
1573
1573
  style: { flex: 1, minWidth: 60, border: "none", outline: "none", fontSize: 13, background: "transparent", color: e.text, padding: 0 }
1574
1574
  }
1575
1575
  )
@@ -1577,24 +1577,24 @@ function Be({ data: n = [], value: o, placeholder: d = "Select or type...", mult
1577
1577
  !l && /* @__PURE__ */ t(
1578
1578
  "input",
1579
1579
  {
1580
- ref: S,
1581
- value: u ? w : z,
1582
- onChange: (p) => {
1583
- r(p.target.value), x(!0);
1580
+ ref: R,
1581
+ value: p ? z : $,
1582
+ onChange: (c) => {
1583
+ r(c.target.value), x(!0);
1584
1584
  },
1585
1585
  onFocus: () => {
1586
1586
  x(!0), r("");
1587
1587
  },
1588
- onClick: (p) => p.stopPropagation(),
1588
+ onClick: (c) => c.stopPropagation(),
1589
1589
  placeholder: d,
1590
1590
  style: { flex: 1, border: "none", outline: "none", fontSize: 13, background: "transparent", color: e.text, padding: 0 }
1591
1591
  }
1592
1592
  ),
1593
- /* @__PURE__ */ t(Bt, { open: u })
1593
+ /* @__PURE__ */ t(Ht, { open: p })
1594
1594
  ]
1595
1595
  }
1596
1596
  ),
1597
- u && /* @__PURE__ */ t("div", { className: "dhx dhx-anim-fade", style: {
1597
+ p && /* @__PURE__ */ t("div", { className: "dhx dhx-anim-fade", style: {
1598
1598
  position: "absolute",
1599
1599
  top: "calc(100% + 4px)",
1600
1600
  left: 0,
@@ -1605,12 +1605,12 @@ function Be({ data: n = [], value: o, placeholder: d = "Select or type...", mult
1605
1605
  boxShadow: e.shadowLg,
1606
1606
  zIndex: 100
1607
1607
  }, children: /* @__PURE__ */ g("div", { className: "dhx-scroll", style: { maxHeight: 220, overflowY: "auto" }, children: [
1608
- s.map((p) => {
1609
- const I = p.id || p.value, W = b(I);
1608
+ a.map((c) => {
1609
+ const N = c.id || c.value, A = k(N);
1610
1610
  return /* @__PURE__ */ g(
1611
1611
  "div",
1612
1612
  {
1613
- onClick: () => M(p),
1613
+ onClick: () => C(c),
1614
1614
  style: {
1615
1615
  padding: "8px 12px",
1616
1616
  cursor: "pointer",
@@ -1618,277 +1618,277 @@ function Be({ data: n = [], value: o, placeholder: d = "Select or type...", mult
1618
1618
  alignItems: "center",
1619
1619
  gap: 8,
1620
1620
  fontSize: 13,
1621
- background: W ? e.primaryLt : "transparent",
1622
- color: W ? e.primary : e.text
1621
+ background: A ? e.primaryLt : "transparent",
1622
+ color: A ? e.primary : e.text
1623
1623
  },
1624
- onMouseEnter: (v) => !W && (v.currentTarget.style.background = e.bg),
1625
- onMouseLeave: (v) => !W && (v.currentTarget.style.background = "transparent"),
1624
+ onMouseEnter: (S) => !A && (S.currentTarget.style.background = e.bg),
1625
+ onMouseLeave: (S) => !A && (S.currentTarget.style.background = "transparent"),
1626
1626
  children: [
1627
1627
  l && /* @__PURE__ */ t("span", { style: {
1628
1628
  width: 14,
1629
1629
  height: 14,
1630
1630
  flexShrink: 0,
1631
- border: `2px solid ${W ? e.primary : e.borderDk}`,
1631
+ border: `2px solid ${A ? e.primary : e.borderDk}`,
1632
1632
  borderRadius: 3,
1633
1633
  display: "flex",
1634
1634
  alignItems: "center",
1635
1635
  justifyContent: "center",
1636
- background: W ? e.primary : "transparent"
1637
- }, children: W && /* @__PURE__ */ t("span", { style: { color: "#fff", fontSize: 9, lineHeight: 1 }, children: "✓" }) }),
1638
- /* @__PURE__ */ t("span", { style: { flex: 1 }, children: p.value }),
1639
- !l && W && /* @__PURE__ */ t("span", { style: { color: e.primary, fontSize: 12, fontWeight: 700 }, children: "✓" }),
1640
- p.count !== void 0 && /* @__PURE__ */ g("span", { style: { fontSize: 11, color: e.textMut }, children: [
1636
+ background: A ? e.primary : "transparent"
1637
+ }, children: A && /* @__PURE__ */ t("span", { style: { color: "#fff", fontSize: 9, lineHeight: 1 }, children: "✓" }) }),
1638
+ /* @__PURE__ */ t("span", { style: { flex: 1 }, children: c.value }),
1639
+ !l && A && /* @__PURE__ */ t("span", { style: { color: e.primary, fontSize: 12, fontWeight: 700 }, children: "✓" }),
1640
+ c.count !== void 0 && /* @__PURE__ */ g("span", { style: { fontSize: 11, color: e.textMut }, children: [
1641
1641
  "(",
1642
- p.count,
1642
+ c.count,
1643
1643
  ")"
1644
1644
  ] })
1645
1645
  ]
1646
1646
  },
1647
- I
1647
+ N
1648
1648
  );
1649
1649
  }),
1650
- s.length === 0 && /* @__PURE__ */ t("div", { style: { padding: 16, textAlign: "center", color: e.textMut, fontSize: 13 }, children: "No matches" })
1650
+ a.length === 0 && /* @__PURE__ */ t("div", { style: { padding: 16, textAlign: "center", color: e.textMut, fontSize: 13 }, children: "No matches" })
1651
1651
  ] }) })
1652
1652
  ] });
1653
1653
  }
1654
- function He({ min: n = 0, max: o = 100, step: d = 1, value: l, range: f = !1, label: a, tick: h, disabled: u = !1, onChange: x, style: w }) {
1655
- const [r, i] = N(l ?? (f ? [n, o] : n));
1656
- _(q, []);
1657
- const c = (M, D) => {
1658
- if (!u)
1659
- if (f) {
1660
- const R = [...r];
1661
- R[M] = D, i(R), x == null || x(R);
1654
+ function Ae({ min: n = 0, max: i = 100, step: d = 1, value: l, range: u = !1, label: s, tick: f, disabled: p = !1, onChange: x, style: z }) {
1655
+ const [r, b] = B(l ?? (u ? [n, i] : n));
1656
+ J(Q, []);
1657
+ const h = (C, L) => {
1658
+ if (!p)
1659
+ if (u) {
1660
+ const H = [...r];
1661
+ H[C] = L, b(H), x == null || x(H);
1662
1662
  } else
1663
- i(D), x == null || x(D);
1664
- }, m = (M) => (M - n) / (o - n) * 100, S = f ? r : [r], s = f ? { left: `${m(S[0])}%`, width: `${m(S[1]) - m(S[0])}%` } : { left: 0, width: `${m(S[0])}%` }, b = u ? e.border : e.primary;
1665
- return /* @__PURE__ */ g("div", { className: "dhx", style: { width: "100%", opacity: u ? 0.5 : 1, ...w }, children: [
1666
- a && /* @__PURE__ */ t("label", { className: "dhx dhx-label", children: a }),
1663
+ b(L), x == null || x(L);
1664
+ }, M = (C) => (C - n) / (i - n) * 100, R = u ? r : [r], a = u ? { left: `${M(R[0])}%`, width: `${M(R[1]) - M(R[0])}%` } : { left: 0, width: `${M(R[0])}%` }, k = p ? e.border : e.primary;
1665
+ return /* @__PURE__ */ g("div", { className: "dhx", style: { width: "100%", opacity: p ? 0.5 : 1, ...z }, children: [
1666
+ s && /* @__PURE__ */ t("label", { className: "dhx dhx-label", children: s }),
1667
1667
  /* @__PURE__ */ t("div", { style: { position: "relative", height: 36, display: "flex", alignItems: "center" }, children: /* @__PURE__ */ g("div", { style: { position: "relative", flex: 1, height: 4, background: e.border, borderRadius: 2 }, children: [
1668
- /* @__PURE__ */ t("div", { style: { position: "absolute", ...s, height: "100%", background: b, borderRadius: 2 } }),
1669
- S.map((M, D) => /* @__PURE__ */ t(
1668
+ /* @__PURE__ */ t("div", { style: { position: "absolute", ...a, height: "100%", background: k, borderRadius: 2 } }),
1669
+ R.map((C, L) => /* @__PURE__ */ t(
1670
1670
  "input",
1671
1671
  {
1672
1672
  type: "range",
1673
1673
  min: n,
1674
- max: o,
1674
+ max: i,
1675
1675
  step: d,
1676
- value: M,
1677
- disabled: u,
1678
- onChange: (R) => {
1679
- const z = +R.target.value;
1680
- f && D === 0 && z >= r[1] || f && D === 1 && z <= r[0] || c(D, z);
1676
+ value: C,
1677
+ disabled: p,
1678
+ onChange: (H) => {
1679
+ const $ = +H.target.value;
1680
+ u && L === 0 && $ >= r[1] || u && L === 1 && $ <= r[0] || h(L, $);
1681
1681
  },
1682
- style: { position: "absolute", width: "100%", height: "100%", opacity: 0, cursor: u ? "not-allowed" : "pointer", top: 0, left: 0, margin: 0 }
1682
+ style: { position: "absolute", width: "100%", height: "100%", opacity: 0, cursor: p ? "not-allowed" : "pointer", top: 0, left: 0, margin: 0 }
1683
1683
  },
1684
- D
1684
+ L
1685
1685
  )),
1686
- S.map((M, D) => /* @__PURE__ */ t("div", { style: { position: "absolute", left: `${m(M)}%`, top: "50%", transform: "translate(-50%, -50%)", width: 16, height: 16, borderRadius: "50%", background: e.surface, border: `2px solid ${b}`, boxShadow: "0 1px 4px rgba(0,0,0,.2)", pointerEvents: "none" }, children: /* @__PURE__ */ t("div", { style: { position: "absolute", bottom: "calc(100% + 6px)", left: "50%", transform: "translateX(-50%)", background: u ? e.textMut : e.primaryDk, color: "#fff", padding: "2px 6px", borderRadius: e.r, fontSize: 11, fontWeight: 700, whiteSpace: "nowrap" }, children: M }) }, D))
1686
+ R.map((C, L) => /* @__PURE__ */ t("div", { style: { position: "absolute", left: `${M(C)}%`, top: "50%", transform: "translate(-50%, -50%)", width: 16, height: 16, borderRadius: "50%", background: e.surface, border: `2px solid ${k}`, boxShadow: "0 1px 4px rgba(0,0,0,.2)", pointerEvents: "none" }, children: /* @__PURE__ */ t("div", { style: { position: "absolute", bottom: "calc(100% + 6px)", left: "50%", transform: "translateX(-50%)", background: p ? e.textMut : e.primaryDk, color: "#fff", padding: "2px 6px", borderRadius: e.r, fontSize: 11, fontWeight: 700, whiteSpace: "nowrap" }, children: C }) }, L))
1687
1687
  ] }) }),
1688
- h && /* @__PURE__ */ t("div", { style: { display: "flex", justifyContent: "space-between", marginTop: 2 }, children: [n, Math.round((o + n) / 2), o].map((M) => /* @__PURE__ */ t("span", { style: { fontSize: 10, color: e.textMut }, children: M }, M)) })
1688
+ f && /* @__PURE__ */ t("div", { style: { display: "flex", justifyContent: "space-between", marginTop: 2 }, children: [n, Math.round((i + n) / 2), i].map((C) => /* @__PURE__ */ t("span", { style: { fontSize: 10, color: e.textMut }, children: C }, C)) })
1689
1689
  ] });
1690
1690
  }
1691
- const Ht = ["#f44336", "#e91e63", "#9c27b0", "#673ab7", "#3f51b5", "#2196f3", "#03a9f4", "#00bcd4", "#009688", "#4caf50", "#8bc34a", "#cddc39", "#ffeb3b", "#ffc107", "#ff9800", "#ff5722", "#795548", "#607d8b", "#9e9e9e", "#000000", "#ffffff", "#0288d1", "#01579b", "#43a047", "#e53935", "#f57c00"];
1692
- function we(n) {
1693
- const o = parseInt(n.slice(1, 3), 16) / 255, d = parseInt(n.slice(3, 5), 16) / 255, l = parseInt(n.slice(5, 7), 16) / 255, f = Math.max(o, d, l), a = Math.min(o, d, l);
1694
- let h = 0, u = 0;
1695
- const x = (f + a) / 2;
1696
- if (f !== a) {
1697
- const w = f - a;
1698
- u = x > 0.5 ? w / (2 - f - a) : w / (f + a), h = f === o ? ((d - l) / w + (d < l ? 6 : 0)) / 6 : f === d ? ((l - o) / w + 2) / 6 : ((o - d) / w + 4) / 6;
1691
+ const At = ["#f44336", "#e91e63", "#9c27b0", "#673ab7", "#3f51b5", "#2196f3", "#03a9f4", "#00bcd4", "#009688", "#4caf50", "#8bc34a", "#cddc39", "#ffeb3b", "#ffc107", "#ff9800", "#ff5722", "#795548", "#607d8b", "#9e9e9e", "#000000", "#ffffff", "#0288d1", "#01579b", "#43a047", "#e53935", "#f57c00"];
1692
+ function ze(n) {
1693
+ const i = parseInt(n.slice(1, 3), 16) / 255, d = parseInt(n.slice(3, 5), 16) / 255, l = parseInt(n.slice(5, 7), 16) / 255, u = Math.max(i, d, l), s = Math.min(i, d, l);
1694
+ let f = 0, p = 0;
1695
+ const x = (u + s) / 2;
1696
+ if (u !== s) {
1697
+ const z = u - s;
1698
+ p = x > 0.5 ? z / (2 - u - s) : z / (u + s), f = u === i ? ((d - l) / z + (d < l ? 6 : 0)) / 6 : u === d ? ((l - i) / z + 2) / 6 : ((i - d) / z + 4) / 6;
1699
1699
  }
1700
- return [Math.round(h * 360), Math.round(u * 100), Math.round(x * 100)];
1700
+ return [Math.round(f * 360), Math.round(p * 100), Math.round(x * 100)];
1701
1701
  }
1702
- function je(n, o, d) {
1703
- o /= 100, d /= 100;
1704
- const l = o * Math.min(d, 1 - d), f = (a) => {
1705
- const h = (a + n / 30) % 12, u = d - l * Math.max(Math.min(h - 3, 9 - h, 1), -1);
1706
- return Math.round(255 * u).toString(16).padStart(2, "0");
1702
+ function je(n, i, d) {
1703
+ i /= 100, d /= 100;
1704
+ const l = i * Math.min(d, 1 - d), u = (s) => {
1705
+ const f = (s + n / 30) % 12, p = d - l * Math.max(Math.min(f - 3, 9 - f, 1), -1);
1706
+ return Math.round(255 * p).toString(16).padStart(2, "0");
1707
1707
  };
1708
- return "#" + f(0) + f(8) + f(4);
1708
+ return "#" + u(0) + u(8) + u(4);
1709
1709
  }
1710
- function en({ value: n = "#0288d1", onChange: o, style: d }) {
1711
- const [l, f] = N(() => we(n)), a = je(...l);
1712
- _(q, []);
1713
- const h = (u) => {
1714
- f(u), o == null || o(je(...u));
1710
+ function nn({ value: n = "#0288d1", onChange: i, style: d }) {
1711
+ const [l, u] = B(() => ze(n)), s = je(...l);
1712
+ J(Q, []);
1713
+ const f = (p) => {
1714
+ u(p), i == null || i(je(...p));
1715
1715
  };
1716
1716
  return /* @__PURE__ */ g("div", { className: "dhx", style: { background: e.surface, border: `1px solid ${e.border}`, borderRadius: e.rMd, padding: 16, display: "inline-block", boxShadow: e.shadow, ...d }, children: [
1717
1717
  /* @__PURE__ */ t("div", { style: { width: 200, height: 120, borderRadius: e.r, marginBottom: 12, background: `linear-gradient(to bottom, transparent, black), linear-gradient(to right, white, hsl(${l[0]},100%,50%))`, cursor: "crosshair" } }),
1718
- [["Hue", 0, 360, l[0]], ["Saturation", 0, 100, l[1]], ["Lightness", 0, 100, l[2]]].map(([u, x, w, r], i) => /* @__PURE__ */ g("div", { style: { marginBottom: i < 2 ? 8 : 12 }, children: [
1718
+ [["Hue", 0, 360, l[0]], ["Saturation", 0, 100, l[1]], ["Lightness", 0, 100, l[2]]].map(([p, x, z, r], b) => /* @__PURE__ */ g("div", { style: { marginBottom: b < 2 ? 8 : 12 }, children: [
1719
1719
  /* @__PURE__ */ g("div", { className: "dhx dhx-label", children: [
1720
- u,
1721
- i > 0 ? ` (${r}%)` : ""
1720
+ p,
1721
+ b > 0 ? ` (${r}%)` : ""
1722
1722
  ] }),
1723
- /* @__PURE__ */ t("input", { type: "range", min: x, max: w, value: r, onChange: (c) => {
1724
- const m = [...l];
1725
- m[i] = +c.target.value, h(m);
1723
+ /* @__PURE__ */ t("input", { type: "range", min: x, max: z, value: r, onChange: (h) => {
1724
+ const M = [...l];
1725
+ M[b] = +h.target.value, f(M);
1726
1726
  }, style: { width: "100%", accentColor: e.primary } })
1727
- ] }, u)),
1727
+ ] }, p)),
1728
1728
  /* @__PURE__ */ g("div", { style: { display: "flex", alignItems: "center", gap: 8, marginBottom: 12 }, children: [
1729
- /* @__PURE__ */ t("div", { style: { width: 36, height: 36, borderRadius: e.r, background: a, border: `1px solid ${e.border}`, flexShrink: 0 } }),
1729
+ /* @__PURE__ */ t("div", { style: { width: 36, height: 36, borderRadius: e.r, background: s, border: `1px solid ${e.border}`, flexShrink: 0 } }),
1730
1730
  /* @__PURE__ */ t(
1731
1731
  "input",
1732
1732
  {
1733
1733
  className: "dhx dhx-input",
1734
1734
  style: { flex: 1, fontFamily: "monospace", fontSize: 12 },
1735
- value: a,
1736
- onChange: (u) => {
1735
+ value: s,
1736
+ onChange: (p) => {
1737
1737
  try {
1738
- h(we(u.target.value)), o == null || o(u.target.value);
1738
+ f(ze(p.target.value)), i == null || i(p.target.value);
1739
1739
  } catch {
1740
1740
  }
1741
1741
  }
1742
1742
  }
1743
1743
  )
1744
1744
  ] }),
1745
- /* @__PURE__ */ t("div", { style: { display: "grid", gridTemplateColumns: "repeat(13, 1fr)", gap: 3 }, children: Ht.map((u) => /* @__PURE__ */ t(
1745
+ /* @__PURE__ */ t("div", { style: { display: "grid", gridTemplateColumns: "repeat(13, 1fr)", gap: 3 }, children: At.map((p) => /* @__PURE__ */ t(
1746
1746
  "div",
1747
1747
  {
1748
1748
  onClick: () => {
1749
- f(we(u)), o == null || o(u);
1749
+ u(ze(p)), i == null || i(p);
1750
1750
  },
1751
- style: { width: 14, height: 14, borderRadius: 2, background: u, cursor: "pointer", border: a === u ? `2px solid ${e.text}` : "1px solid rgba(0,0,0,.15)", transition: "transform .1s" },
1751
+ style: { width: 14, height: 14, borderRadius: 2, background: p, cursor: "pointer", border: s === p ? `2px solid ${e.text}` : "1px solid rgba(0,0,0,.15)", transition: "transform .1s" },
1752
1752
  onMouseEnter: (x) => x.currentTarget.style.transform = "scale(1.3)",
1753
1753
  onMouseLeave: (x) => x.currentTarget.style.transform = "scale(1)"
1754
1754
  },
1755
- u
1755
+ p
1756
1756
  )) })
1757
1757
  ] });
1758
1758
  }
1759
- function tn({ trigger: n, children: o, placement: d = "bottom-start", style: l }) {
1760
- const [f, a] = N(!1), [h, u] = N({ top: "100%", left: 0 }), x = oe(null), w = oe(null);
1761
- return _(q, []), ge(x, ae(() => a(!1), [])), /* @__PURE__ */ g("div", { ref: x, className: "dhx", style: { position: "relative", display: "inline-block" }, children: [
1762
- /* @__PURE__ */ t("div", { ref: w, onClick: () => {
1763
- a((i) => {
1764
- if (!i && w.current) {
1765
- const c = w.current.getBoundingClientRect(), m = {
1766
- "bottom-start": { top: c.height + 4, left: 0 },
1767
- "bottom-end": { top: c.height + 4, right: 0, left: "auto" },
1768
- "top-start": { bottom: c.height + 4, top: "auto", left: 0 }
1759
+ function rn({ trigger: n, children: i, placement: d = "bottom-start", style: l }) {
1760
+ const [u, s] = B(!1), [f, p] = B({ top: "100%", left: 0 }), x = le(null), z = le(null);
1761
+ return J(Q, []), xe(x, ae(() => s(!1), [])), /* @__PURE__ */ g("div", { ref: x, className: "dhx", style: { position: "relative", display: "inline-block" }, children: [
1762
+ /* @__PURE__ */ t("div", { ref: z, onClick: () => {
1763
+ s((b) => {
1764
+ if (!b && z.current) {
1765
+ const h = z.current.getBoundingClientRect(), M = {
1766
+ "bottom-start": { top: h.height + 4, left: 0 },
1767
+ "bottom-end": { top: h.height + 4, right: 0, left: "auto" },
1768
+ "top-start": { bottom: h.height + 4, top: "auto", left: 0 }
1769
1769
  };
1770
- u(m[d] || m["bottom-start"]);
1770
+ p(M[d] || M["bottom-start"]);
1771
1771
  }
1772
- return !i;
1772
+ return !b;
1773
1773
  });
1774
1774
  }, children: n }),
1775
- f && /* @__PURE__ */ t("div", { className: "dhx dhx-anim-fade", style: { position: "absolute", ...h, zIndex: 200, background: e.surface, border: `1px solid ${e.border}`, borderRadius: e.rMd, boxShadow: e.shadowLg, ...l }, children: o })
1775
+ u && /* @__PURE__ */ t("div", { className: "dhx dhx-anim-fade", style: { position: "absolute", ...f, zIndex: 200, background: e.surface, border: `1px solid ${e.border}`, borderRadius: e.rMd, boxShadow: e.shadowLg, ...l }, children: i })
1776
1776
  ] });
1777
1777
  }
1778
- function nn({ title: n, children: o, width: d = 480, height: l, closable: f = !0, movable: a = !0, modal: h = !1, defaultOpen: u = !0, footer: x, onClose: w, style: r }) {
1779
- const [i, c] = N(u), [m, S] = N({ x: 0, y: 0 });
1780
- _(q, []);
1781
- const s = St(ae((M, D) => a && S({ x: M, y: D }), [a])), b = () => {
1782
- c(!1), w == null || w();
1778
+ function on({ title: n, children: i, width: d = 480, height: l, closable: u = !0, movable: s = !0, modal: f = !1, defaultOpen: p = !0, footer: x, onClose: z, style: r }) {
1779
+ const [b, h] = B(p), [M, R] = B({ x: 0, y: 0 });
1780
+ J(Q, []);
1781
+ const a = kt(ae((C, L) => s && R({ x: C, y: L }), [s])), k = () => {
1782
+ h(!1), z == null || z();
1783
1783
  };
1784
- return i ? /* @__PURE__ */ g(Ye, { children: [
1785
- h && /* @__PURE__ */ t("div", { style: { position: "fixed", inset: 0, background: "rgba(0,0,0,.45)", zIndex: 900 }, onClick: f ? b : void 0 }),
1786
- /* @__PURE__ */ g("div", { className: "dhx", style: { position: h ? "fixed" : "absolute", left: "50%", top: "50%", transform: `translate(calc(-50% + ${m.x}px), calc(-50% + ${m.y}px))`, width: d, ...l ? { height: l } : {}, background: e.surface, borderRadius: e.rMd, boxShadow: e.shadowLg, zIndex: 901, display: "flex", flexDirection: "column", overflow: "hidden", ...r }, children: [
1787
- /* @__PURE__ */ g("div", { onMouseDown: (M) => s(M, m.x, m.y), style: { display: "flex", alignItems: "center", padding: "12px 16px", borderBottom: `1px solid ${e.border}`, cursor: a ? "grab" : "default", background: e.bg, gap: 8, userSelect: "none" }, children: [
1784
+ return b ? /* @__PURE__ */ g(Ye, { children: [
1785
+ f && /* @__PURE__ */ t("div", { style: { position: "fixed", inset: 0, background: "rgba(0,0,0,.45)", zIndex: 900 }, onClick: u ? k : void 0 }),
1786
+ /* @__PURE__ */ g("div", { className: "dhx", style: { position: f ? "fixed" : "absolute", left: "50%", top: "50%", transform: `translate(calc(-50% + ${M.x}px), calc(-50% + ${M.y}px))`, width: d, ...l ? { height: l } : {}, background: e.surface, borderRadius: e.rMd, boxShadow: e.shadowLg, zIndex: 901, display: "flex", flexDirection: "column", overflow: "hidden", ...r }, children: [
1787
+ /* @__PURE__ */ g("div", { onMouseDown: (C) => a(C, M.x, M.y), style: { display: "flex", alignItems: "center", padding: "12px 16px", borderBottom: `1px solid ${e.border}`, cursor: s ? "grab" : "default", background: e.bg, gap: 8, userSelect: "none" }, children: [
1788
1788
  /* @__PURE__ */ t("span", { style: { flex: 1, fontWeight: 700, fontSize: 15 }, children: n }),
1789
- f && /* @__PURE__ */ t(
1789
+ u && /* @__PURE__ */ t(
1790
1790
  "button",
1791
1791
  {
1792
- onClick: b,
1792
+ onClick: k,
1793
1793
  style: { background: "none", border: "none", cursor: "pointer", width: 28, height: 28, borderRadius: e.r, display: "flex", alignItems: "center", justifyContent: "center", fontSize: 18, color: e.textSec },
1794
- onMouseEnter: (M) => M.currentTarget.style.background = e.border,
1795
- onMouseLeave: (M) => M.currentTarget.style.background = "none",
1794
+ onMouseEnter: (C) => C.currentTarget.style.background = e.border,
1795
+ onMouseLeave: (C) => C.currentTarget.style.background = "none",
1796
1796
  children: "×"
1797
1797
  }
1798
1798
  )
1799
1799
  ] }),
1800
- /* @__PURE__ */ t("div", { className: "dhx-scroll", style: { flex: 1, minHeight: 0, padding: 20, overflowY: "auto" }, children: o }),
1800
+ /* @__PURE__ */ t("div", { className: "dhx-scroll", style: { flex: 1, minHeight: 0, padding: 20, overflowY: "auto" }, children: i }),
1801
1801
  x && /* @__PURE__ */ t("div", { style: { padding: "12px 16px", borderTop: `1px solid ${e.border}`, display: "flex", justifyContent: "flex-end", gap: 8, background: e.bg }, children: x })
1802
1802
  ] })
1803
1803
  ] }) : null;
1804
1804
  }
1805
- const Ke = Qe(null), jt = { success: "✓", error: "✕", warning: "⚠", info: "ℹ" }, Fe = { success: e.success, error: e.danger, warning: e.warning, info: e.primary };
1806
- function rn({ children: n }) {
1807
- const [o, d] = N([]);
1808
- _(q, []);
1809
- const l = ae((h) => d((u) => u.filter((x) => x.id !== h)), []), f = ae((h) => {
1810
- const u = Date.now();
1811
- return d((x) => [...x, { id: u, ...h }]), h.duration !== 0 && setTimeout(() => l(u), h.duration || 4e3), u;
1812
- }, [l]), a = {
1813
- message: f,
1814
- alert: (h, u) => f({ type: "info", title: h, ...u }),
1815
- confirm: (h, u, x) => f({ type: "warning", title: h, confirm: u, ...x })
1805
+ const Ke = Qe(null), jt = { success: "✓", error: "✕", warning: "⚠", info: "ℹ" }, Pe = { success: e.success, error: e.danger, warning: e.warning, info: e.primary };
1806
+ function ln({ children: n }) {
1807
+ const [i, d] = B([]);
1808
+ J(Q, []);
1809
+ const l = ae((f) => d((p) => p.filter((x) => x.id !== f)), []), u = ae((f) => {
1810
+ const p = Date.now();
1811
+ return d((x) => [...x, { id: p, ...f }]), f.duration !== 0 && setTimeout(() => l(p), f.duration || 4e3), p;
1812
+ }, [l]), s = {
1813
+ message: u,
1814
+ alert: (f, p) => u({ type: "info", title: f, ...p }),
1815
+ confirm: (f, p, x) => u({ type: "warning", title: f, confirm: p, ...x })
1816
1816
  };
1817
- return /* @__PURE__ */ g(Ke.Provider, { value: a, children: [
1817
+ return /* @__PURE__ */ g(Ke.Provider, { value: s, children: [
1818
1818
  n,
1819
- /* @__PURE__ */ t("div", { style: { position: "fixed", top: 20, right: 20, zIndex: 9999, display: "flex", flexDirection: "column", gap: 8, pointerEvents: "none" }, children: o.map((h) => {
1820
- const u = h.type || "info";
1821
- return /* @__PURE__ */ g("div", { style: { background: e.surface, border: `1px solid ${e.border}`, borderLeft: `4px solid ${Fe[u]}`, borderRadius: e.r, boxShadow: e.shadowLg, padding: "12px 16px", minWidth: 280, maxWidth: 380, pointerEvents: "all", display: "flex", gap: 10, alignItems: "flex-start", animation: "dhx-toast .3s ease" }, children: [
1822
- /* @__PURE__ */ t("span", { style: { fontSize: 18, color: Fe[u], lineHeight: 1 }, children: jt[u] }),
1819
+ /* @__PURE__ */ t("div", { style: { position: "fixed", top: 20, right: 20, zIndex: 9999, display: "flex", flexDirection: "column", gap: 8, pointerEvents: "none" }, children: i.map((f) => {
1820
+ const p = f.type || "info";
1821
+ return /* @__PURE__ */ g("div", { style: { background: e.surface, border: `1px solid ${e.border}`, borderLeft: `4px solid ${Pe[p]}`, borderRadius: e.r, boxShadow: e.shadowLg, padding: "12px 16px", minWidth: 280, maxWidth: 380, pointerEvents: "all", display: "flex", gap: 10, alignItems: "flex-start", animation: "dhx-toast .3s ease" }, children: [
1822
+ /* @__PURE__ */ t("span", { style: { fontSize: 18, color: Pe[p], lineHeight: 1 }, children: jt[p] }),
1823
1823
  /* @__PURE__ */ g("div", { style: { flex: 1 }, children: [
1824
- h.title && /* @__PURE__ */ t("div", { style: { fontWeight: 600, fontSize: 13, marginBottom: h.text ? 3 : 0 }, children: h.title }),
1825
- h.text && /* @__PURE__ */ t("div", { style: { fontSize: 12, color: e.textSec, lineHeight: 1.5 }, children: h.text }),
1826
- h.confirm && /* @__PURE__ */ g("div", { style: { display: "flex", gap: 6, marginTop: 8 }, children: [
1824
+ f.title && /* @__PURE__ */ t("div", { style: { fontWeight: 600, fontSize: 13, marginBottom: f.text ? 3 : 0 }, children: f.title }),
1825
+ f.text && /* @__PURE__ */ t("div", { style: { fontSize: 12, color: e.textSec, lineHeight: 1.5 }, children: f.text }),
1826
+ f.confirm && /* @__PURE__ */ g("div", { style: { display: "flex", gap: 6, marginTop: 8 }, children: [
1827
1827
  /* @__PURE__ */ t("button", { className: "dhx dhx-btn dhx-btn-primary", style: { height: 26, fontSize: 12 }, onClick: () => {
1828
- h.confirm(!0), l(h.id);
1828
+ f.confirm(!0), l(f.id);
1829
1829
  }, children: "Confirm" }),
1830
1830
  /* @__PURE__ */ t("button", { className: "dhx dhx-btn dhx-btn-secondary", style: { height: 26, fontSize: 12 }, onClick: () => {
1831
- h.confirm(!1), l(h.id);
1831
+ f.confirm(!1), l(f.id);
1832
1832
  }, children: "Cancel" })
1833
1833
  ] })
1834
1834
  ] }),
1835
- /* @__PURE__ */ t("button", { onClick: () => l(h.id), style: { background: "none", border: "none", cursor: "pointer", color: e.textMut, fontSize: 14, lineHeight: 1, padding: 0 }, children: "×" })
1836
- ] }, h.id);
1835
+ /* @__PURE__ */ t("button", { onClick: () => l(f.id), style: { background: "none", border: "none", cursor: "pointer", color: e.textMut, fontSize: 14, lineHeight: 1, padding: 0 }, children: "×" })
1836
+ ] }, f.id);
1837
1837
  }) })
1838
1838
  ] });
1839
1839
  }
1840
- function on() {
1840
+ function sn() {
1841
1841
  const n = Ze(Ke);
1842
1842
  if (!n) throw new Error("useMessage must be used inside <MessageProvider>");
1843
1843
  return n;
1844
1844
  }
1845
- function ln({ data: n = [], template: o, keyNavigation: d = !0, multiselection: l = !1, editable: f = !1, height: a = 400, onSelect: h, onEdit: u, style: x }) {
1846
- const [w, r] = N(/* @__PURE__ */ new Set()), [i, c] = N(null), [m, S] = N(""), [s, b] = N(null);
1847
- _(q, []);
1848
- const M = (R, z) => {
1849
- const C = R.id ?? z;
1850
- r((F) => {
1851
- const p = l ? new Set(F) : /* @__PURE__ */ new Set();
1852
- return p.has(C) ? p.delete(C) : p.add(C), p;
1853
- }), b(z), h == null || h(R);
1854
- }, D = (R, z) => {
1855
- u == null || u({ ...R, value: m }, z), c(null);
1845
+ function an({ data: n = [], template: i, keyNavigation: d = !0, multiselection: l = !1, editable: u = !1, height: s = 400, onSelect: f, onEdit: p, style: x }) {
1846
+ const [z, r] = B(/* @__PURE__ */ new Set()), [b, h] = B(null), [M, R] = B(""), [a, k] = B(null);
1847
+ J(Q, []);
1848
+ const C = (H, $) => {
1849
+ const D = H.id ?? $;
1850
+ r((K) => {
1851
+ const c = l ? new Set(K) : /* @__PURE__ */ new Set();
1852
+ return c.has(D) ? c.delete(D) : c.add(D), c;
1853
+ }), k($), f == null || f(H);
1854
+ }, L = (H, $) => {
1855
+ p == null || p({ ...H, value: M }, $), h(null);
1856
1856
  };
1857
1857
  return /* @__PURE__ */ g(
1858
1858
  "div",
1859
1859
  {
1860
1860
  className: "dhx dhx-scroll",
1861
- style: { height: a, overflowY: "auto", border: `1px solid ${e.border}`, borderRadius: e.r, background: e.surface, ...x },
1861
+ style: { height: s, overflowY: "auto", border: `1px solid ${e.border}`, borderRadius: e.r, background: e.surface, ...x },
1862
1862
  tabIndex: 0,
1863
- onKeyDown: (R) => {
1864
- d && (R.key === "ArrowDown" && b((z) => Math.min((z ?? -1) + 1, n.length - 1)), R.key === "ArrowUp" && b((z) => Math.max((z ?? 1) - 1, 0)));
1863
+ onKeyDown: (H) => {
1864
+ d && (H.key === "ArrowDown" && k(($) => Math.min(($ ?? -1) + 1, n.length - 1)), H.key === "ArrowUp" && k(($) => Math.max(($ ?? 1) - 1, 0)));
1865
1865
  },
1866
1866
  children: [
1867
- n.map((R, z) => {
1868
- const C = R.id ?? z, F = w.has(C), p = s === z;
1867
+ n.map((H, $) => {
1868
+ const D = H.id ?? $, K = z.has(D), c = a === $;
1869
1869
  return /* @__PURE__ */ t(
1870
1870
  "div",
1871
1871
  {
1872
- onClick: () => M(R, z),
1873
- onDoubleClick: () => f && (c(z), S(String(R.value || ""))),
1874
- style: { display: "flex", alignItems: "center", padding: "0 12px", height: 40, cursor: "pointer", fontSize: 13, borderBottom: `1px solid ${e.border}`, background: F ? e.primaryLt : p ? e.bg : e.surface, color: F ? e.primary : e.text, outline: p ? `2px solid ${e.primary}44` : "none", transition: "background .1s" },
1875
- children: i === z ? /* @__PURE__ */ t(
1872
+ onClick: () => C(H, $),
1873
+ onDoubleClick: () => u && (h($), R(String(H.value || ""))),
1874
+ style: { display: "flex", alignItems: "center", padding: "0 12px", height: 40, cursor: "pointer", fontSize: 13, borderBottom: `1px solid ${e.border}`, background: K ? e.primaryLt : c ? e.bg : e.surface, color: K ? e.primary : e.text, outline: c ? `2px solid ${e.primary}44` : "none", transition: "background .1s" },
1875
+ children: b === $ ? /* @__PURE__ */ t(
1876
1876
  "input",
1877
1877
  {
1878
1878
  autoFocus: !0,
1879
1879
  className: "dhx dhx-input",
1880
1880
  style: { height: 28, flex: 1 },
1881
- value: m,
1882
- onChange: (I) => S(I.target.value),
1883
- onBlur: () => D(R, z),
1884
- onKeyDown: (I) => {
1885
- I.key === "Enter" && D(R, z), I.key === "Escape" && c(null);
1881
+ value: M,
1882
+ onChange: (N) => R(N.target.value),
1883
+ onBlur: () => L(H, $),
1884
+ onKeyDown: (N) => {
1885
+ N.key === "Enter" && L(H, $), N.key === "Escape" && h(null);
1886
1886
  },
1887
- onClick: (I) => I.stopPropagation()
1887
+ onClick: (N) => N.stopPropagation()
1888
1888
  }
1889
- ) : o ? /* @__PURE__ */ t("div", { dangerouslySetInnerHTML: { __html: o(R) }, style: { flex: 1 } }) : /* @__PURE__ */ t("span", { style: { flex: 1, overflow: "hidden", textOverflow: "ellipsis", whiteSpace: "nowrap" }, children: String(R.value ?? "") })
1889
+ ) : i ? /* @__PURE__ */ t("div", { dangerouslySetInnerHTML: { __html: i(H) }, style: { flex: 1 } }) : /* @__PURE__ */ t("span", { style: { flex: 1, overflow: "hidden", textOverflow: "ellipsis", whiteSpace: "nowrap" }, children: String(H.value ?? "") })
1890
1890
  },
1891
- String(C)
1891
+ String(D)
1892
1892
  );
1893
1893
  }),
1894
1894
  n.length === 0 && /* @__PURE__ */ t("div", { style: { padding: 24, textAlign: "center", color: e.textMut }, children: "No items" })
@@ -1896,682 +1896,853 @@ function ln({ data: n = [], template: o, keyNavigation: d = !0, multiselection:
1896
1896
  }
1897
1897
  );
1898
1898
  }
1899
- function sn({ data: n = [], template: o, itemsInRow: d = 3, gap: l = 12, multiselection: f = !1, onSelect: a, style: h }) {
1900
- const [u, x] = N(/* @__PURE__ */ new Set());
1901
- _(q, []);
1902
- const w = (r) => {
1903
- const i = r.id ?? String(r.title);
1904
- x((c) => {
1905
- const m = f ? new Set(c) : /* @__PURE__ */ new Set();
1906
- return m.has(i) ? m.delete(i) : m.add(i), m;
1907
- }), a == null || a(r);
1899
+ function dn({ data: n = [], template: i, itemsInRow: d = 3, gap: l = 12, multiselection: u = !1, onSelect: s, style: f }) {
1900
+ const [p, x] = B(/* @__PURE__ */ new Set());
1901
+ J(Q, []);
1902
+ const z = (r) => {
1903
+ const b = r.id ?? String(r.title);
1904
+ x((h) => {
1905
+ const M = u ? new Set(h) : /* @__PURE__ */ new Set();
1906
+ return M.has(b) ? M.delete(b) : M.add(b), M;
1907
+ }), s == null || s(r);
1908
1908
  };
1909
- return /* @__PURE__ */ t("div", { className: "dhx", style: { display: "grid", gridTemplateColumns: `repeat(${d}, 1fr)`, gap: l, padding: l, ...h }, children: n.map((r, i) => {
1910
- const c = r.id ?? i, m = u.has(c);
1909
+ return /* @__PURE__ */ t("div", { className: "dhx", style: { display: "grid", gridTemplateColumns: `repeat(${d}, 1fr)`, gap: l, padding: l, ...f }, children: n.map((r, b) => {
1910
+ const h = r.id ?? b, M = p.has(h);
1911
1911
  return /* @__PURE__ */ t(
1912
1912
  "div",
1913
1913
  {
1914
- onClick: () => w(r),
1915
- style: { background: e.surface, border: `2px solid ${m ? e.primary : e.border}`, borderRadius: e.rMd, overflow: "hidden", cursor: "pointer", transition: "all .15s", boxShadow: m ? `0 0 0 3px ${e.primary}33` : e.shadow, transform: m ? "translateY(-2px)" : "none" },
1916
- onMouseEnter: (S) => {
1917
- S.currentTarget.style.boxShadow = e.shadowLg, S.currentTarget.style.transform = "translateY(-2px)";
1914
+ onClick: () => z(r),
1915
+ style: { background: e.surface, border: `2px solid ${M ? e.primary : e.border}`, borderRadius: e.rMd, overflow: "hidden", cursor: "pointer", transition: "all .15s", boxShadow: M ? `0 0 0 3px ${e.primary}33` : e.shadow, transform: M ? "translateY(-2px)" : "none" },
1916
+ onMouseEnter: (R) => {
1917
+ R.currentTarget.style.boxShadow = e.shadowLg, R.currentTarget.style.transform = "translateY(-2px)";
1918
1918
  },
1919
- onMouseLeave: (S) => {
1920
- S.currentTarget.style.boxShadow = m ? `0 0 0 3px ${e.primary}33` : e.shadow, S.currentTarget.style.transform = m ? "translateY(-2px)" : "none";
1919
+ onMouseLeave: (R) => {
1920
+ R.currentTarget.style.boxShadow = M ? `0 0 0 3px ${e.primary}33` : e.shadow, R.currentTarget.style.transform = M ? "translateY(-2px)" : "none";
1921
1921
  },
1922
- children: o ? /* @__PURE__ */ t("div", { dangerouslySetInnerHTML: { __html: o(r) } }) : /* @__PURE__ */ g("div", { style: { padding: 16 }, children: [
1922
+ children: i ? /* @__PURE__ */ t("div", { dangerouslySetInnerHTML: { __html: i(r) } }) : /* @__PURE__ */ g("div", { style: { padding: 16 }, children: [
1923
1923
  r.img && /* @__PURE__ */ t("img", { src: r.img, alt: r.title || "", style: { width: "100%", borderRadius: e.r, marginBottom: 8, display: "block" } }),
1924
1924
  /* @__PURE__ */ t("div", { style: { fontWeight: 600, fontSize: 14, marginBottom: 4 }, children: r.title || r.value }),
1925
1925
  r.subtitle && /* @__PURE__ */ t("div", { style: { fontSize: 12, color: e.textSec }, children: r.subtitle })
1926
1926
  ] })
1927
1927
  },
1928
- String(c)
1928
+ String(h)
1929
1929
  );
1930
1930
  }) });
1931
1931
  }
1932
- function ze(n) {
1933
- return n.map((o) => ({ ...o, items: o.items ? ze(o.items) : void 0 }));
1932
+ function Me(n) {
1933
+ return n.map((i) => ({ ...i, items: i.items ? Me(i.items) : void 0 }));
1934
1934
  }
1935
- function Me(n, o = {}) {
1935
+ function $e(n, i = {}) {
1936
1936
  return n.forEach((d) => {
1937
- d.opened && (o[d.id] = !0), d.items && Me(d.items, o);
1938
- }), o;
1937
+ d.opened && (i[d.id] = !0), d.items && $e(d.items, i);
1938
+ }), i;
1939
1939
  }
1940
- function _e(n, o) {
1940
+ function _e(n, i) {
1941
1941
  let d = null;
1942
- return [n.filter((f) => f.id === o ? (d = f, !1) : !0).map((f) => {
1943
- if (f.items) {
1944
- const [a, h] = _e(f.items, o);
1945
- return h && (d = h), { ...f, items: a };
1942
+ return [n.filter((u) => u.id === i ? (d = u, !1) : !0).map((u) => {
1943
+ if (u.items) {
1944
+ const [s, f] = _e(u.items, i);
1945
+ return f && (d = f), { ...u, items: s };
1946
1946
  }
1947
- return f;
1947
+ return u;
1948
1948
  }), d];
1949
1949
  }
1950
- function $e(n, o, d, l) {
1950
+ function Ce(n, i, d, l) {
1951
1951
  if (l === "inside")
1952
- return n.map((a) => a.id === o ? { ...a, items: [...a.items || [], d] } : a.items ? { ...a, items: $e(a.items, o, d, l) } : a);
1953
- if (n.some((a) => a.id === o)) {
1954
- const a = [];
1955
- for (const h of n)
1956
- h.id === o ? l === "before" ? (a.push(d), a.push(h)) : (a.push(h), a.push(d)) : a.push(h);
1957
- return a;
1952
+ return n.map((s) => s.id === i ? { ...s, items: [...s.items || [], d] } : s.items ? { ...s, items: Ce(s.items, i, d, l) } : s);
1953
+ if (n.some((s) => s.id === i)) {
1954
+ const s = [];
1955
+ for (const f of n)
1956
+ f.id === i ? l === "before" ? (s.push(d), s.push(f)) : (s.push(f), s.push(d)) : s.push(f);
1957
+ return s;
1958
1958
  }
1959
- return n.map((a) => a.items ? { ...a, items: $e(a.items, o, d, l) } : a);
1959
+ return n.map((s) => s.items ? { ...s, items: Ce(s.items, i, d, l) } : s);
1960
1960
  }
1961
- function Ft(n, o, d) {
1962
- function l(f) {
1963
- var a, h;
1964
- if (f.id === o) {
1965
- const u = (x) => {
1966
- var w;
1967
- return x.id === d || (((w = x.items) == null ? void 0 : w.some(u)) ?? !1);
1961
+ function Pt(n, i, d) {
1962
+ function l(u) {
1963
+ var s, f;
1964
+ if (u.id === i) {
1965
+ const p = (x) => {
1966
+ var z;
1967
+ return x.id === d || (((z = x.items) == null ? void 0 : z.some(p)) ?? !1);
1968
1968
  };
1969
- return ((a = f.items) == null ? void 0 : a.some(u)) ?? !1;
1969
+ return ((s = u.items) == null ? void 0 : s.some(p)) ?? !1;
1970
1970
  }
1971
- return ((h = f.items) == null ? void 0 : h.some(l)) ?? !1;
1971
+ return ((f = u.items) == null ? void 0 : f.some(l)) ?? !1;
1972
1972
  }
1973
1973
  return n.some(l);
1974
1974
  }
1975
- function Ve(n, o, d) {
1975
+ function Ve(n, i, d) {
1976
1976
  return n.map(
1977
- (l) => l.id === o ? { ...l, value: d } : { ...l, items: l.items ? Ve(l.items, o, d) : void 0 }
1977
+ (l) => l.id === i ? { ...l, value: d } : { ...l, items: l.items ? Ve(l.items, i, d) : void 0 }
1978
1978
  );
1979
1979
  }
1980
- function Pt(n, o) {
1981
- var a;
1980
+ function Ft(n, i) {
1981
+ var s;
1982
1982
  let d = 0, l = 0;
1983
- const f = (h) => {
1984
- var u;
1985
- d++, o[h.id] && l++, (u = h.items) == null || u.forEach(f);
1983
+ const u = (f) => {
1984
+ var p;
1985
+ d++, i[f.id] && l++, (p = f.items) == null || p.forEach(u);
1986
1986
  };
1987
- return (a = n.items) == null || a.forEach(f), { total: d, checkedCount: l };
1987
+ return (s = n.items) == null || s.forEach(u), { total: d, checkedCount: l };
1988
1988
  }
1989
- function an({
1989
+ function cn({
1990
1990
  data: n = [],
1991
- checkbox: o = !1,
1991
+ checkbox: i = !1,
1992
1992
  editable: d = !1,
1993
1993
  dragMode: l,
1994
- tooltip: f,
1995
- onSelect: a,
1996
- onCheck: h,
1997
- onChange: u,
1994
+ tooltip: u,
1995
+ onSelect: s,
1996
+ onCheck: f,
1997
+ onChange: p,
1998
1998
  style: x
1999
1999
  }) {
2000
- const [w, r] = N(() => ze(n)), [i, c] = N(() => Me(n)), [m, S] = N(null), [s, b] = N({}), [M, D] = N(null), [R, z] = N(""), [C, F] = N(null), [p, I] = N(null);
2001
- _(q, []), _(() => {
2002
- r(ze(n)), c(($) => ({ ...Me(n), ...$ }));
2000
+ const [z, r] = B(() => Me(n)), [b, h] = B(() => $e(n)), [M, R] = B(null), [a, k] = B({}), [C, L] = B(null), [H, $] = B(""), [D, K] = B(null), [c, N] = B(null);
2001
+ J(Q, []), J(() => {
2002
+ r(Me(n)), h((v) => ({ ...$e(n), ...v }));
2003
2003
  }, [n]);
2004
- const W = ($) => c((j) => ({ ...j, [$]: !j[$] })), v = ($, j) => {
2005
- b((k) => ({ ...k, [$]: j })), h == null || h($, j);
2006
- }, X = () => {
2007
- if (!M) return;
2008
- const $ = M, j = R;
2009
- D(null), r((k) => {
2010
- const P = Ve(k, $, j);
2011
- return u == null || u(P), P;
2004
+ const A = (v) => h((T) => ({ ...T, [v]: !T[v] })), S = (v, T) => {
2005
+ k((m) => ({ ...m, [v]: T })), f == null || f(v, T);
2006
+ }, U = () => {
2007
+ if (!C) return;
2008
+ const v = C, T = H;
2009
+ L(null), r((m) => {
2010
+ const j = Ve(m, v, T);
2011
+ return p == null || p(j), j;
2012
2012
  });
2013
- }, J = ($, j) => {
2014
- $.dataTransfer.effectAllowed = "move", F(j);
2015
- }, se = ($, j) => {
2016
- if (!C || C === j || Ft(w, C, j)) return;
2017
- $.preventDefault();
2018
- const k = $.currentTarget.getBoundingClientRect(), P = $.clientY - k.top, O = k.height, G = P < O * 0.25 ? "before" : P > O * 0.75 ? "after" : "inside";
2019
- I((K) => (K == null ? void 0 : K.id) === j && (K == null ? void 0 : K.pos) === G ? K : { id: j, pos: G });
2020
- }, U = ($, j) => {
2021
- if ($.preventDefault(), !C || !p || C === j) {
2022
- I(null), F(null);
2013
+ }, Z = (v, T) => {
2014
+ v.dataTransfer.effectAllowed = "move", K(T);
2015
+ }, o = (v, T) => {
2016
+ if (!D || D === T || Pt(z, D, T)) return;
2017
+ v.preventDefault();
2018
+ const m = v.currentTarget.getBoundingClientRect(), j = v.clientY - m.top, Y = m.height, G = j < Y * 0.25 ? "before" : j > Y * 0.75 ? "after" : "inside";
2019
+ N((V) => (V == null ? void 0 : V.id) === T && (V == null ? void 0 : V.pos) === G ? V : { id: T, pos: G });
2020
+ }, E = (v, T) => {
2021
+ if (v.preventDefault(), !D || !c || D === T) {
2022
+ N(null), K(null);
2023
2023
  return;
2024
2024
  }
2025
- r((k) => {
2026
- const [P, O] = _e(k, C);
2027
- if (!O) return k;
2028
- const G = $e(P, j, O, p.pos);
2029
- return u == null || u(G), G;
2030
- }), p.pos === "inside" && c((k) => ({ ...k, [j]: !0 })), I(null), F(null);
2031
- }, ie = () => {
2032
- F(null), I(null);
2033
- }, E = ($, j = 0) => {
2025
+ r((m) => {
2026
+ const [j, Y] = _e(m, D);
2027
+ if (!Y) return m;
2028
+ const G = Ce(j, T, Y, c.pos);
2029
+ return p == null || p(G), G;
2030
+ }), c.pos === "inside" && h((m) => ({ ...m, [T]: !0 })), N(null), K(null);
2031
+ }, _ = () => {
2032
+ K(null), N(null);
2033
+ }, w = (v, T = 0) => {
2034
2034
  var ne;
2035
- const k = (((ne = $.items) == null ? void 0 : ne.length) ?? 0) > 0, P = i[$.id], O = m === $.id, G = C === $.id, K = (p == null ? void 0 : p.id) === $.id;
2036
- let V = !!s[$.id], Q = !1;
2037
- if (o && k) {
2038
- const { total: H, checkedCount: de } = Pt($, s);
2039
- de > 0 && de < H ? Q = !0 : H > 0 && de === H && (V = !0);
2035
+ const m = (((ne = v.items) == null ? void 0 : ne.length) ?? 0) > 0, j = b[v.id], Y = M === v.id, G = D === v.id, V = (c == null ? void 0 : c.id) === v.id;
2036
+ let q = !!a[v.id], ee = !1;
2037
+ if (i && m) {
2038
+ const { total: P, checkedCount: de } = Ft(v, a);
2039
+ de > 0 && de < P ? ee = !0 : P > 0 && de === P && (q = !0);
2040
2040
  }
2041
- const Z = K && p.pos !== "inside" ? { boxShadow: p.pos === "before" ? `inset 0 2px 0 0 ${e.primary}` : `inset 0 -2px 0 0 ${e.primary}` } : {}, fe = K && p.pos === "inside" || O ? e.primaryLt : "transparent";
2041
+ const te = V && c.pos !== "inside" ? { boxShadow: c.pos === "before" ? `inset 0 2px 0 0 ${e.primary}` : `inset 0 -2px 0 0 ${e.primary}` } : {}, pe = V && c.pos === "inside" || Y ? e.primaryLt : "transparent";
2042
2042
  return /* @__PURE__ */ g("div", { style: { opacity: G ? 0.4 : 1 }, children: [
2043
2043
  /* @__PURE__ */ g(
2044
2044
  "div",
2045
2045
  {
2046
2046
  draggable: !!l,
2047
- onDragStart: l ? (H) => J(H, $.id) : void 0,
2048
- onDragOver: l ? (H) => se(H, $.id) : void 0,
2049
- onDrop: l ? (H) => U(H, $.id) : void 0,
2050
- onDragEnd: l ? ie : void 0,
2051
- title: f == null ? void 0 : f($),
2047
+ onDragStart: l ? (P) => Z(P, v.id) : void 0,
2048
+ onDragOver: l ? (P) => o(P, v.id) : void 0,
2049
+ onDrop: l ? (P) => E(P, v.id) : void 0,
2050
+ onDragEnd: l ? _ : void 0,
2051
+ title: u == null ? void 0 : u(v),
2052
2052
  onClick: () => {
2053
- S($.id), a == null || a($), k && W($.id);
2053
+ R(v.id), s == null || s(v), m && A(v.id);
2054
2054
  },
2055
2055
  onDoubleClick: () => {
2056
- d && (D($.id), z($.value || ""));
2056
+ d && (L(v.id), $(v.value || ""));
2057
2057
  },
2058
2058
  style: {
2059
2059
  display: "flex",
2060
2060
  alignItems: "center",
2061
2061
  gap: 4,
2062
- padding: `5px 8px 5px ${12 + j * 18}px`,
2062
+ padding: `5px 8px 5px ${12 + T * 18}px`,
2063
2063
  cursor: l ? "grab" : "pointer",
2064
2064
  borderRadius: e.r,
2065
2065
  margin: "1px 4px",
2066
- background: fe,
2067
- color: O ? e.primary : e.text,
2066
+ background: pe,
2067
+ color: Y ? e.primary : e.text,
2068
2068
  userSelect: "none",
2069
2069
  fontSize: 13,
2070
- ...Z
2070
+ ...te
2071
2071
  },
2072
- onMouseEnter: (H) => !O && !K && (H.currentTarget.style.background = e.bg),
2073
- onMouseLeave: (H) => !O && !K && (H.currentTarget.style.background = "transparent"),
2072
+ onMouseEnter: (P) => !Y && !V && (P.currentTarget.style.background = e.bg),
2073
+ onMouseLeave: (P) => !Y && !V && (P.currentTarget.style.background = "transparent"),
2074
2074
  children: [
2075
2075
  /* @__PURE__ */ t(
2076
2076
  "span",
2077
2077
  {
2078
2078
  style: { width: 16, textAlign: "center", fontSize: 11, color: e.textMut, flexShrink: 0 },
2079
- onClick: (H) => {
2080
- H.stopPropagation(), k && W($.id);
2079
+ onClick: (P) => {
2080
+ P.stopPropagation(), m && A(v.id);
2081
2081
  },
2082
- children: k ? P ? "▾" : "▸" : ""
2082
+ children: m ? j ? "▾" : "▸" : ""
2083
2083
  }
2084
2084
  ),
2085
- /* @__PURE__ */ t("span", { style: { fontSize: 15, flexShrink: 0 }, children: k ? P ? "📂" : "📁" : "📄" }),
2086
- o && /* @__PURE__ */ t(
2085
+ /* @__PURE__ */ t("span", { style: { fontSize: 15, flexShrink: 0 }, children: m ? j ? "📂" : "📁" : "📄" }),
2086
+ i && /* @__PURE__ */ t(
2087
2087
  "input",
2088
2088
  {
2089
- ref: (H) => {
2090
- H && (H.indeterminate = Q);
2089
+ ref: (P) => {
2090
+ P && (P.indeterminate = ee);
2091
2091
  },
2092
2092
  type: "checkbox",
2093
- checked: V,
2094
- onChange: (H) => {
2095
- H.stopPropagation(), v($.id, H.target.checked);
2093
+ checked: q,
2094
+ onChange: (P) => {
2095
+ P.stopPropagation(), S(v.id, P.target.checked);
2096
2096
  },
2097
2097
  style: { cursor: "pointer", accentColor: e.primary, flexShrink: 0 },
2098
- onClick: (H) => H.stopPropagation()
2098
+ onClick: (P) => P.stopPropagation()
2099
2099
  }
2100
2100
  ),
2101
- M === $.id ? /* @__PURE__ */ t(
2101
+ C === v.id ? /* @__PURE__ */ t(
2102
2102
  "input",
2103
2103
  {
2104
2104
  autoFocus: !0,
2105
2105
  className: "dhx dhx-input",
2106
2106
  style: { height: 24, fontSize: 12, flex: 1 },
2107
- value: R,
2108
- onChange: (H) => z(H.target.value),
2109
- onBlur: X,
2110
- onKeyDown: (H) => {
2111
- H.key === "Enter" && X(), H.key === "Escape" && D(null);
2107
+ value: H,
2108
+ onChange: (P) => $(P.target.value),
2109
+ onBlur: U,
2110
+ onKeyDown: (P) => {
2111
+ P.key === "Enter" && U(), P.key === "Escape" && L(null);
2112
2112
  },
2113
- onClick: (H) => H.stopPropagation()
2113
+ onClick: (P) => P.stopPropagation()
2114
2114
  }
2115
- ) : /* @__PURE__ */ t("span", { style: { flex: 1 }, children: $.value }),
2116
- $.count !== void 0 && /* @__PURE__ */ g("span", { style: { fontSize: 11, color: e.textMut }, children: [
2115
+ ) : /* @__PURE__ */ t("span", { style: { flex: 1 }, children: v.value }),
2116
+ v.count !== void 0 && /* @__PURE__ */ g("span", { style: { fontSize: 11, color: e.textMut }, children: [
2117
2117
  "(",
2118
- $.count,
2118
+ v.count,
2119
2119
  ")"
2120
2120
  ] })
2121
2121
  ]
2122
2122
  }
2123
2123
  ),
2124
- k && P && /* @__PURE__ */ t("div", { children: $.items.map((H) => E(H, j + 1)) })
2125
- ] }, $.id);
2124
+ m && j && /* @__PURE__ */ t("div", { children: v.items.map((P) => w(P, T + 1)) })
2125
+ ] }, v.id);
2126
2126
  };
2127
2127
  return /* @__PURE__ */ t(
2128
2128
  "div",
2129
2129
  {
2130
2130
  className: "dhx dhx-scroll",
2131
2131
  style: { overflowY: "auto", ...x },
2132
- onDragOver: l ? ($) => $.preventDefault() : void 0,
2133
- onDrop: l ? ($) => {
2134
- $.preventDefault(), I(null), F(null);
2132
+ onDragOver: l ? (v) => v.preventDefault() : void 0,
2133
+ onDrop: l ? (v) => {
2134
+ v.preventDefault(), N(null), K(null);
2135
2135
  } : void 0,
2136
- children: w.map(($) => E($))
2136
+ children: z.map((v) => w(v))
2137
2137
  }
2138
2138
  );
2139
2139
  }
2140
- function dn({ total: n, pageSize: o = 10, page: d, onChange: l, style: f }) {
2141
- const [a, h] = N(d || 1), u = Math.ceil(n / o);
2142
- _(q, []);
2140
+ function un({ total: n, pageSize: i = 10, page: d, onChange: l, style: u }) {
2141
+ const [s, f] = B(d || 1), p = Math.ceil(n / i);
2142
+ J(Q, []);
2143
2143
  const x = (r) => {
2144
- const i = Math.min(Math.max(1, r), u);
2145
- h(i), l == null || l(i);
2146
- }, w = ue(() => {
2144
+ const b = Math.min(Math.max(1, r), p);
2145
+ f(b), l == null || l(b);
2146
+ }, z = ue(() => {
2147
2147
  const r = [];
2148
- for (let c = Math.max(1, a - 2); c <= Math.min(u, a + 2); c++) r.push(c);
2149
- return r[0] > 1 && (r[0] > 2 && r.unshift("..."), r.unshift(1)), r[r.length - 1] < u && (r[r.length - 1] < u - 1 && r.push("..."), r.push(u)), r;
2150
- }, [a, u]);
2151
- return /* @__PURE__ */ g("div", { className: "dhx", style: { display: "flex", alignItems: "center", gap: 4, padding: "8px 12px", ...f }, children: [
2148
+ for (let h = Math.max(1, s - 2); h <= Math.min(p, s + 2); h++) r.push(h);
2149
+ return r[0] > 1 && (r[0] > 2 && r.unshift("..."), r.unshift(1)), r[r.length - 1] < p && (r[r.length - 1] < p - 1 && r.push("..."), r.push(p)), r;
2150
+ }, [s, p]);
2151
+ return /* @__PURE__ */ g("div", { className: "dhx", style: { display: "flex", alignItems: "center", gap: 4, padding: "8px 12px", ...u }, children: [
2152
2152
  /* @__PURE__ */ g("span", { style: { fontSize: 12, color: e.textSec, marginRight: 8 }, children: [
2153
- (a - 1) * o + 1,
2153
+ (s - 1) * i + 1,
2154
2154
  "–",
2155
- Math.min(a * o, n),
2155
+ Math.min(s * i, n),
2156
2156
  " of ",
2157
2157
  n
2158
2158
  ] }),
2159
- [["«", 1], ["‹", a - 1]].map(([r, i]) => /* @__PURE__ */ t("button", { className: "dhx dhx-btn dhx-btn-ghost", style: { height: 30, padding: "0 8px", fontSize: 14 }, disabled: a === 1, onClick: () => x(i), children: r }, r)),
2160
- w.map((r, i) => /* @__PURE__ */ t("button", { onClick: () => typeof r == "number" && x(r), className: `dhx dhx-btn ${r === a ? "dhx-btn-primary" : "dhx-btn-ghost"}`, style: { height: 30, minWidth: 30, padding: "0 8px", fontSize: 13 }, disabled: r === "...", children: r }, i)),
2161
- [["›", a + 1], ["»", u]].map(([r, i]) => /* @__PURE__ */ t("button", { className: "dhx dhx-btn dhx-btn-ghost", style: { height: 30, padding: "0 8px", fontSize: 14 }, disabled: a === u, onClick: () => x(i), children: r }, r))
2159
+ [["«", 1], ["‹", s - 1]].map(([r, b]) => /* @__PURE__ */ t("button", { className: "dhx dhx-btn dhx-btn-ghost", style: { height: 30, padding: "0 8px", fontSize: 14 }, disabled: s === 1, onClick: () => x(b), children: r }, r)),
2160
+ z.map((r, b) => /* @__PURE__ */ t("button", { onClick: () => typeof r == "number" && x(r), className: `dhx dhx-btn ${r === s ? "dhx-btn-primary" : "dhx-btn-ghost"}`, style: { height: 30, minWidth: 30, padding: "0 8px", fontSize: 13 }, disabled: r === "...", children: r }, b)),
2161
+ [["›", s + 1], ["»", p]].map(([r, b]) => /* @__PURE__ */ t("button", { className: "dhx dhx-btn dhx-btn-ghost", style: { height: 30, padding: "0 8px", fontSize: 14 }, disabled: s === p, onClick: () => x(b), children: r }, r))
2162
2162
  ] });
2163
2163
  }
2164
- function cn({ config: n = {}, defaultValues: o = {}, onSubmit: d, style: l }) {
2165
- const [f, a] = N(o), [h, u] = N({}), [x, w] = N(null);
2166
- _(q, []);
2167
- const r = (s, b) => {
2168
- a((M) => ({ ...M, [s]: b })), u((M) => ({ ...M, [s]: null }));
2169
- }, i = (s) => {
2170
- const b = [];
2171
- return s.flat().forEach((M) => {
2172
- !M || typeof M != "object" || !("name" in M) || (b.push(M), M.type === "fieldset" && M.rows && b.push(...i(M.rows)));
2173
- }), b;
2174
- }, c = () => {
2175
- const s = {};
2176
- return i(n.rows || []).forEach((b) => {
2177
- b.required && !f[b.name] && (s[b.name] = `${b.label || b.name} is required`);
2178
- }), u(s), Object.keys(s).length === 0;
2179
- }, m = (s) => {
2180
- const b = f[s.name] ?? s.value ?? "", M = h[s.name], D = s.labelWidth ?? n.labelWidth, R = D !== void 0 || s.labelPosition === "left";
2181
- if (s.type === "fieldset") return /* @__PURE__ */ g("fieldset", { style: { border: `1px solid ${e.border}`, borderRadius: e.r, padding: "12px 16px", marginBottom: 14 }, children: [
2182
- /* @__PURE__ */ t("legend", { style: { fontSize: 12, fontWeight: 700, color: e.textSec, padding: "0 6px" }, children: s.label }),
2183
- (s.rows || []).map((v) => m(v))
2184
- ] }, s.name);
2185
- if (s.type === "spacer") return /* @__PURE__ */ t("div", { style: { height: s.height || 16 } }, s.name);
2186
- const z = D ? { minWidth: D, width: D, flexShrink: 0, paddingTop: 8, boxSizing: "border-box" } : {}, C = s.label ? /* @__PURE__ */ g("label", { className: "dhx dhx-label", style: { display: "flex", gap: 4, ...z }, children: [
2187
- s.label,
2188
- s.required && /* @__PURE__ */ t("span", { style: { color: e.danger }, children: "*" })
2189
- ] }, "lbl") : null, F = M ? /* @__PURE__ */ t("div", { style: { fontSize: 11, color: e.danger, marginTop: 3 }, children: M }) : null, p = s.helpMessage ? /* @__PURE__ */ g("div", { style: { fontSize: 11, color: e.textMut, marginTop: 3 }, children: [
2164
+ function pn({ config: n = {}, defaultValues: i = {}, onSubmit: d, style: l }) {
2165
+ const [u, s] = B(i), [f, p] = B({}), [x, z] = B(null);
2166
+ J(Q, []);
2167
+ const r = (a, k) => {
2168
+ s((C) => ({ ...C, [a]: k })), p((C) => ({ ...C, [a]: null }));
2169
+ }, b = (a) => {
2170
+ const k = [];
2171
+ return a.flat().forEach((C) => {
2172
+ !C || typeof C != "object" || !("name" in C) || (k.push(C), C.type === "fieldset" && C.rows && k.push(...b(C.rows)));
2173
+ }), k;
2174
+ }, h = () => {
2175
+ const a = {};
2176
+ return b(n.rows || []).forEach((k) => {
2177
+ k.required && !u[k.name] && (a[k.name] = `${k.label || k.name} is required`);
2178
+ }), p(a), Object.keys(a).length === 0;
2179
+ }, M = (a) => {
2180
+ const k = u[a.name] ?? a.value ?? "", C = f[a.name], L = a.labelWidth ?? n.labelWidth, H = L !== void 0 || a.labelPosition === "left";
2181
+ if (a.type === "fieldset") return /* @__PURE__ */ g("fieldset", { style: { border: `1px solid ${e.border}`, borderRadius: e.r, padding: "12px 16px", marginBottom: 14 }, children: [
2182
+ /* @__PURE__ */ t("legend", { style: { fontSize: 12, fontWeight: 700, color: e.textSec, padding: "0 6px" }, children: a.label }),
2183
+ (a.rows || []).map((S) => M(S))
2184
+ ] }, a.name);
2185
+ if (a.type === "spacer") return /* @__PURE__ */ t("div", { style: { height: a.height || 16 } }, a.name);
2186
+ const $ = L ? { minWidth: L, width: L, flexShrink: 0, paddingTop: 8, boxSizing: "border-box" } : {}, D = a.label ? /* @__PURE__ */ g("label", { className: "dhx dhx-label", style: { display: "flex", gap: 4, ...$ }, children: [
2187
+ a.label,
2188
+ a.required && /* @__PURE__ */ t("span", { style: { color: e.danger }, children: "*" })
2189
+ ] }, "lbl") : null, K = C ? /* @__PURE__ */ t("div", { style: { fontSize: 11, color: e.danger, marginTop: 3 }, children: C }) : null, c = a.helpMessage ? /* @__PURE__ */ g("div", { style: { fontSize: 11, color: e.textMut, marginTop: 3 }, children: [
2190
2190
  "ⓘ ",
2191
- s.helpMessage
2192
- ] }) : null, I = { key: s.name, className: "dhx-form-group" }, W = (v) => R ? /* @__PURE__ */ g("div", { ...I, style: { display: "flex", alignItems: "flex-start", gap: 8 }, children: [
2193
- C,
2191
+ a.helpMessage
2192
+ ] }) : null, N = { key: a.name, className: "dhx-form-group" }, A = (S) => H ? /* @__PURE__ */ g("div", { ...N, style: { display: "flex", alignItems: "flex-start", gap: 8 }, children: [
2193
+ D,
2194
2194
  /* @__PURE__ */ g("div", { style: { flex: 1, minWidth: 0 }, children: [
2195
- v,
2196
- F,
2197
- p
2195
+ S,
2196
+ K,
2197
+ c
2198
2198
  ] })
2199
- ] }) : /* @__PURE__ */ g("div", { ...I, children: [
2200
- C,
2201
- v,
2202
- F,
2203
- p
2199
+ ] }) : /* @__PURE__ */ g("div", { ...N, children: [
2200
+ D,
2201
+ S,
2202
+ K,
2203
+ c
2204
2204
  ] });
2205
- if (!s.type || s.type === "input") return W(
2205
+ if (!a.type || a.type === "input") return A(
2206
2206
  /* @__PURE__ */ g("div", { className: "dhx-input-wrap", children: [
2207
- s.icon && /* @__PURE__ */ t("span", { className: "dhx-input-icon", children: s.icon }),
2207
+ a.icon && /* @__PURE__ */ t("span", { className: "dhx-input-icon", children: a.icon }),
2208
2208
  /* @__PURE__ */ t(
2209
2209
  "input",
2210
2210
  {
2211
- className: `dhx dhx-input${s.icon ? " dhx-input--with-icon" : ""}`,
2212
- style: { borderColor: M ? e.danger : void 0 },
2213
- type: s.inputType || "text",
2214
- placeholder: s.placeholder,
2215
- value: b,
2216
- onChange: (v) => r(s.name, v.target.value),
2217
- disabled: s.disabled
2211
+ className: `dhx dhx-input${a.icon ? " dhx-input--with-icon" : ""}`,
2212
+ style: { borderColor: C ? e.danger : void 0 },
2213
+ type: a.inputType || "text",
2214
+ placeholder: a.placeholder,
2215
+ value: k,
2216
+ onChange: (S) => r(a.name, S.target.value),
2217
+ disabled: a.disabled
2218
2218
  }
2219
2219
  )
2220
2220
  ] })
2221
2221
  );
2222
- if (s.type === "textarea") return W(
2222
+ if (a.type === "textarea") return A(
2223
2223
  /* @__PURE__ */ t(
2224
2224
  "textarea",
2225
2225
  {
2226
2226
  className: "dhx dhx-input",
2227
2227
  style: { height: 80, resize: "vertical", padding: "8px 10px" },
2228
- placeholder: s.placeholder,
2229
- value: b,
2230
- onChange: (v) => r(s.name, v.target.value)
2228
+ placeholder: a.placeholder,
2229
+ value: k,
2230
+ onChange: (S) => r(a.name, S.target.value)
2231
2231
  }
2232
2232
  )
2233
2233
  );
2234
- if (s.type === "select") return W(
2235
- /* @__PURE__ */ g("select", { className: "dhx dhx-input", value: b, onChange: (v) => r(s.name, v.target.value), style: { cursor: "pointer" }, children: [
2234
+ if (a.type === "select") return A(
2235
+ /* @__PURE__ */ g("select", { className: "dhx dhx-input", value: k, onChange: (S) => r(a.name, S.target.value), style: { cursor: "pointer" }, children: [
2236
2236
  /* @__PURE__ */ t("option", { value: "", children: "— Select —" }),
2237
- (s.options || []).map((v) => /* @__PURE__ */ t("option", { value: v.value, children: v.label || v.value }, v.value))
2237
+ (a.options || []).map((S) => /* @__PURE__ */ t("option", { value: S.value, children: S.label || S.value }, S.value))
2238
2238
  ] })
2239
2239
  );
2240
- if (s.type === "datepicker") return W(
2241
- /* @__PURE__ */ t("input", { type: "date", className: "dhx dhx-input", value: b, onChange: (v) => r(s.name, v.target.value) })
2240
+ if (a.type === "datepicker") return A(
2241
+ /* @__PURE__ */ t("input", { type: "date", className: "dhx dhx-input", value: k, onChange: (S) => r(a.name, S.target.value) })
2242
2242
  );
2243
- if (s.type === "timepicker") {
2244
- const v = f[s.name] ?? { h: 12, m: 0, ampm: "AM" }, X = !!f[s.name], J = X ? `${String(v.h).padStart(2, "0")}:${String(v.m).padStart(2, "0")}${v.ampm ? " " + v.ampm : ""}` : s.placeholder || "Click to select", se = /* @__PURE__ */ g("div", { style: { position: "relative" }, children: [
2243
+ if (a.type === "timepicker") {
2244
+ const S = u[a.name] ?? { h: 12, m: 0, ampm: "AM" }, U = !!u[a.name], Z = U ? `${String(S.h).padStart(2, "0")}:${String(S.m).padStart(2, "0")}${S.ampm ? " " + S.ampm : ""}` : a.placeholder || "Click to select", o = /* @__PURE__ */ g("div", { style: { position: "relative" }, children: [
2245
2245
  /* @__PURE__ */ g(
2246
2246
  "div",
2247
2247
  {
2248
2248
  className: "dhx dhx-input",
2249
2249
  style: { cursor: "pointer", display: "flex", alignItems: "center", justifyContent: "space-between" },
2250
- onClick: () => w(x === s.name ? null : s.name),
2250
+ onClick: () => z(x === a.name ? null : a.name),
2251
2251
  children: [
2252
- /* @__PURE__ */ t("span", { style: { color: X ? e.text : e.textMut }, children: J }),
2252
+ /* @__PURE__ */ t("span", { style: { color: U ? e.text : e.textMut }, children: Z }),
2253
2253
  /* @__PURE__ */ t("span", { style: { fontSize: 13, color: e.textSec }, children: "🕐" })
2254
2254
  ]
2255
2255
  }
2256
2256
  ),
2257
- x === s.name && /* @__PURE__ */ t("div", { style: { position: "absolute", zIndex: 100, top: "calc(100% + 4px)", left: 0 }, children: /* @__PURE__ */ t(At, { value: v, controls: !0, onChange: (U) => {
2258
- r(s.name, U), w(null);
2257
+ x === a.name && /* @__PURE__ */ t("div", { style: { position: "absolute", zIndex: 100, top: "calc(100% + 4px)", left: 0 }, children: /* @__PURE__ */ t(Bt, { value: S, controls: !0, onChange: (E) => {
2258
+ r(a.name, E), z(null);
2259
2259
  } }) })
2260
2260
  ] });
2261
- return W(se);
2261
+ return A(o);
2262
2262
  }
2263
- if (s.type === "colorpicker") return W(
2263
+ if (a.type === "colorpicker") return A(
2264
2264
  /* @__PURE__ */ g("div", { style: { display: "flex", alignItems: "center", gap: 8 }, children: [
2265
2265
  /* @__PURE__ */ t(
2266
2266
  "input",
2267
2267
  {
2268
2268
  type: "color",
2269
- value: b || "#000000",
2270
- onChange: (v) => r(s.name, v.target.value),
2269
+ value: k || "#000000",
2270
+ onChange: (S) => r(a.name, S.target.value),
2271
2271
  style: { width: 36, height: 36, padding: 2, border: `1px solid ${e.border}`, borderRadius: e.r, cursor: "pointer", background: "none" }
2272
2272
  }
2273
2273
  ),
2274
- /* @__PURE__ */ t("span", { style: { fontSize: 12, color: e.textSec, fontFamily: "monospace" }, children: b || "#000000" })
2274
+ /* @__PURE__ */ t("span", { style: { fontSize: 12, color: e.textSec, fontFamily: "monospace" }, children: k || "#000000" })
2275
2275
  ] })
2276
2276
  );
2277
- if (s.type === "text") return W(
2278
- /* @__PURE__ */ t("p", { style: { margin: "6px 0", fontSize: 13, color: e.text }, children: s.value })
2277
+ if (a.type === "text") return A(
2278
+ /* @__PURE__ */ t("p", { style: { margin: "6px 0", fontSize: 13, color: e.text }, children: a.value })
2279
2279
  );
2280
- if (s.type === "checkbox") return /* @__PURE__ */ g("div", { ...I, children: [
2281
- R ? /* @__PURE__ */ g("div", { style: { display: "flex", alignItems: "center", gap: 8 }, children: [
2282
- D && /* @__PURE__ */ t("div", { style: { width: D, flexShrink: 0 } }),
2280
+ if (a.type === "checkbox") return /* @__PURE__ */ g("div", { ...N, children: [
2281
+ H ? /* @__PURE__ */ g("div", { style: { display: "flex", alignItems: "center", gap: 8 }, children: [
2282
+ L && /* @__PURE__ */ t("div", { style: { width: L, flexShrink: 0 } }),
2283
2283
  /* @__PURE__ */ g("label", { style: { display: "flex", alignItems: "center", gap: 8, cursor: "pointer" }, children: [
2284
- /* @__PURE__ */ t("input", { type: "checkbox", checked: !!b, onChange: (v) => r(s.name, v.target.checked), style: { width: 16, height: 16, accentColor: e.primary, cursor: "pointer" } }),
2285
- /* @__PURE__ */ t("span", { style: { fontSize: 13 }, children: s.label })
2284
+ /* @__PURE__ */ t("input", { type: "checkbox", checked: !!k, onChange: (S) => r(a.name, S.target.checked), style: { width: 16, height: 16, accentColor: e.primary, cursor: "pointer" } }),
2285
+ /* @__PURE__ */ t("span", { style: { fontSize: 13 }, children: a.label })
2286
2286
  ] })
2287
2287
  ] }) : /* @__PURE__ */ g("label", { style: { display: "flex", alignItems: "center", gap: 8, cursor: "pointer" }, children: [
2288
- /* @__PURE__ */ t("input", { type: "checkbox", checked: !!b, onChange: (v) => r(s.name, v.target.checked), style: { width: 16, height: 16, accentColor: e.primary, cursor: "pointer" } }),
2289
- /* @__PURE__ */ t("span", { style: { fontSize: 13 }, children: s.label })
2288
+ /* @__PURE__ */ t("input", { type: "checkbox", checked: !!k, onChange: (S) => r(a.name, S.target.checked), style: { width: 16, height: 16, accentColor: e.primary, cursor: "pointer" } }),
2289
+ /* @__PURE__ */ t("span", { style: { fontSize: 13 }, children: a.label })
2290
2290
  ] }),
2291
- p
2291
+ c
2292
2292
  ] });
2293
- if (s.type === "radio") {
2294
- const v = (s.options || []).map((X) => /* @__PURE__ */ g("label", { style: { display: "flex", alignItems: "center", gap: 6, cursor: "pointer", fontSize: 13 }, children: [
2293
+ if (a.type === "radio") {
2294
+ const S = (a.options || []).map((U) => /* @__PURE__ */ g("label", { style: { display: "flex", alignItems: "center", gap: 6, cursor: "pointer", fontSize: 13 }, children: [
2295
2295
  /* @__PURE__ */ t(
2296
2296
  "input",
2297
2297
  {
2298
2298
  type: "radio",
2299
- name: s.name,
2300
- value: X.value,
2301
- checked: b === X.value,
2302
- onChange: () => r(s.name, X.value),
2299
+ name: a.name,
2300
+ value: U.value,
2301
+ checked: k === U.value,
2302
+ onChange: () => r(a.name, U.value),
2303
2303
  style: { accentColor: e.primary, cursor: "pointer" }
2304
2304
  }
2305
2305
  ),
2306
- X.label || X.value
2307
- ] }, X.value));
2308
- return W(
2309
- /* @__PURE__ */ t("div", { style: { display: "flex", gap: 16, flexWrap: "wrap", paddingTop: 8 }, children: v })
2306
+ U.label || U.value
2307
+ ] }, U.value));
2308
+ return A(
2309
+ /* @__PURE__ */ t("div", { style: { display: "flex", gap: 16, flexWrap: "wrap", paddingTop: 8 }, children: S })
2310
2310
  );
2311
2311
  }
2312
- if (s.type === "slider") return R ? /* @__PURE__ */ g("div", { ...I, style: { display: "flex", alignItems: "flex-start", gap: 8 }, children: [
2313
- C,
2312
+ if (a.type === "slider") return H ? /* @__PURE__ */ g("div", { ...N, style: { display: "flex", alignItems: "flex-start", gap: 8 }, children: [
2313
+ D,
2314
2314
  /* @__PURE__ */ g("div", { style: { flex: 1 }, children: [
2315
2315
  /* @__PURE__ */ t(
2316
- He,
2316
+ Ae,
2317
2317
  {
2318
- min: s.min,
2319
- max: s.max,
2320
- step: s.step,
2321
- value: b || s.min,
2322
- range: s.range,
2323
- onChange: (v) => r(s.name, v)
2318
+ min: a.min,
2319
+ max: a.max,
2320
+ step: a.step,
2321
+ value: k || a.min,
2322
+ range: a.range,
2323
+ onChange: (S) => r(a.name, S)
2324
2324
  }
2325
2325
  ),
2326
- p
2326
+ c
2327
2327
  ] })
2328
- ] }) : /* @__PURE__ */ g("div", { ...I, children: [
2328
+ ] }) : /* @__PURE__ */ g("div", { ...N, children: [
2329
2329
  /* @__PURE__ */ t(
2330
- He,
2330
+ Ae,
2331
2331
  {
2332
- label: s.label,
2333
- min: s.min,
2334
- max: s.max,
2335
- step: s.step,
2336
- value: b || s.min,
2337
- range: s.range,
2338
- onChange: (v) => r(s.name, v)
2332
+ label: a.label,
2333
+ min: a.min,
2334
+ max: a.max,
2335
+ step: a.step,
2336
+ value: k || a.min,
2337
+ range: a.range,
2338
+ onChange: (S) => r(a.name, S)
2339
2339
  }
2340
2340
  ),
2341
- p
2341
+ c
2342
2342
  ] });
2343
- if (s.type === "combo") return R ? /* @__PURE__ */ g("div", { ...I, style: { display: "flex", alignItems: "flex-start", gap: 8 }, children: [
2344
- C,
2343
+ if (a.type === "combo") return H ? /* @__PURE__ */ g("div", { ...N, style: { display: "flex", alignItems: "flex-start", gap: 8 }, children: [
2344
+ D,
2345
2345
  /* @__PURE__ */ g("div", { style: { flex: 1 }, children: [
2346
2346
  /* @__PURE__ */ t(
2347
- Be,
2347
+ He,
2348
2348
  {
2349
- data: s.data || [],
2350
- multiselection: s.multiselection,
2351
- placeholder: s.placeholder || "Select...",
2352
- value: b || (s.multiselection ? [] : null),
2353
- onChange: (v) => r(s.name, v)
2349
+ data: a.data || [],
2350
+ multiselection: a.multiselection,
2351
+ placeholder: a.placeholder || "Select...",
2352
+ value: k || (a.multiselection ? [] : null),
2353
+ onChange: (S) => r(a.name, S)
2354
2354
  }
2355
2355
  ),
2356
- F,
2357
- p
2356
+ K,
2357
+ c
2358
2358
  ] })
2359
- ] }) : /* @__PURE__ */ g("div", { ...I, children: [
2359
+ ] }) : /* @__PURE__ */ g("div", { ...N, children: [
2360
2360
  /* @__PURE__ */ t(
2361
- Be,
2361
+ He,
2362
2362
  {
2363
- label: s.label,
2364
- data: s.data || [],
2365
- multiselection: s.multiselection,
2366
- placeholder: s.placeholder || "Select...",
2367
- value: b || (s.multiselection ? [] : null),
2368
- onChange: (v) => r(s.name, v)
2363
+ label: a.label,
2364
+ data: a.data || [],
2365
+ multiselection: a.multiselection,
2366
+ placeholder: a.placeholder || "Select...",
2367
+ value: k || (a.multiselection ? [] : null),
2368
+ onChange: (S) => r(a.name, S)
2369
2369
  }
2370
2370
  ),
2371
- F,
2372
- p
2371
+ K,
2372
+ c
2373
2373
  ] });
2374
- if (s.type === "toggle") {
2375
- const v = !!b, X = v ? s.icon : s.offIcon || s.icon, J = v ? s.text || s.label : s.offText || s.text || s.label;
2376
- return /* @__PURE__ */ g("div", { ...I, children: [
2377
- R && D && /* @__PURE__ */ g("div", { style: { display: "flex", alignItems: "center", gap: 8 }, children: [
2378
- /* @__PURE__ */ t("div", { style: { width: D, flexShrink: 0 } }),
2374
+ if (a.type === "toggle") {
2375
+ const S = !!k, U = S ? a.icon : a.offIcon || a.icon, Z = S ? a.text || a.label : a.offText || a.text || a.label;
2376
+ return /* @__PURE__ */ g("div", { ...N, children: [
2377
+ H && L && /* @__PURE__ */ g("div", { style: { display: "flex", alignItems: "center", gap: 8 }, children: [
2378
+ /* @__PURE__ */ t("div", { style: { width: L, flexShrink: 0 } }),
2379
2379
  /* @__PURE__ */ g("label", { style: { display: "flex", alignItems: "center", gap: 8, cursor: "pointer" }, children: [
2380
- /* @__PURE__ */ t(Pe, { on: v, onClick: () => r(s.name, !b) }),
2381
- X && /* @__PURE__ */ t("span", { style: { fontSize: 16 }, children: X }),
2382
- J && /* @__PURE__ */ t("span", { style: { fontSize: 13 }, children: J })
2380
+ /* @__PURE__ */ t(Fe, { on: S, onClick: () => r(a.name, !k) }),
2381
+ U && /* @__PURE__ */ t("span", { style: { fontSize: 16 }, children: U }),
2382
+ Z && /* @__PURE__ */ t("span", { style: { fontSize: 13 }, children: Z })
2383
2383
  ] })
2384
2384
  ] }),
2385
- !R && /* @__PURE__ */ g("label", { style: { display: "flex", alignItems: "center", gap: 10, cursor: "pointer" }, children: [
2386
- /* @__PURE__ */ t(Pe, { on: v, onClick: () => r(s.name, !b) }),
2387
- X && /* @__PURE__ */ t("span", { style: { fontSize: 16 }, children: X }),
2388
- J && /* @__PURE__ */ t("span", { style: { fontSize: 13 }, children: J })
2385
+ !H && /* @__PURE__ */ g("label", { style: { display: "flex", alignItems: "center", gap: 10, cursor: "pointer" }, children: [
2386
+ /* @__PURE__ */ t(Fe, { on: S, onClick: () => r(a.name, !k) }),
2387
+ U && /* @__PURE__ */ t("span", { style: { fontSize: 16 }, children: U }),
2388
+ Z && /* @__PURE__ */ t("span", { style: { fontSize: 13 }, children: Z })
2389
2389
  ] }),
2390
- p
2390
+ c
2391
2391
  ] });
2392
2392
  }
2393
2393
  return null;
2394
- }, S = (s) => s.map(
2395
- (b, M) => Array.isArray(b) ? /* @__PURE__ */ t("div", { style: { display: "flex", gap: 12, alignItems: "flex-start" }, children: b.map(m) }, M) : m(b)
2394
+ }, R = (a) => a.map(
2395
+ (k, C) => Array.isArray(k) ? /* @__PURE__ */ t("div", { style: { display: "flex", gap: 12, alignItems: "flex-start" }, children: k.map(M) }, C) : M(k)
2396
2396
  );
2397
2397
  return /* @__PURE__ */ g("div", { className: "dhx", style: { padding: n.padding || 0, width: n.width || "100%", ...l }, children: [
2398
- S(n.rows || []),
2398
+ R(n.rows || []),
2399
2399
  (n.buttons || d) && /* @__PURE__ */ g("div", { style: { display: "flex", gap: 8, justifyContent: n.buttonAlign || "flex-start", marginTop: 8 }, children: [
2400
- /* @__PURE__ */ t("button", { className: "dhx dhx-btn dhx-btn-primary", onClick: () => c() && (d == null ? void 0 : d(f)), children: n.submitText || "Submit" }),
2400
+ /* @__PURE__ */ t("button", { className: "dhx dhx-btn dhx-btn-primary", onClick: () => h() && (d == null ? void 0 : d(u)), children: n.submitText || "Submit" }),
2401
2401
  n.resetButton !== !1 && /* @__PURE__ */ t("button", { className: "dhx dhx-btn dhx-btn-secondary", onClick: () => {
2402
- a(o), u({});
2402
+ s(i), p({});
2403
2403
  }, children: n.resetText || "Reset" })
2404
2404
  ] })
2405
2405
  ] });
2406
2406
  }
2407
- function Pe({ on: n, onClick: o }) {
2408
- return /* @__PURE__ */ g("div", { style: { position: "relative", width: 40, height: 22, flexShrink: 0 }, onClick: o, children: [
2407
+ function Fe({ on: n, onClick: i }) {
2408
+ return /* @__PURE__ */ g("div", { style: { position: "relative", width: 40, height: 22, flexShrink: 0 }, onClick: i, children: [
2409
2409
  /* @__PURE__ */ t("div", { style: { width: 40, height: 22, borderRadius: 11, background: n ? e.primary : e.border, transition: "background 0.2s" } }),
2410
2410
  /* @__PURE__ */ t("div", { style: { position: "absolute", top: 3, left: n ? 21 : 3, width: 16, height: 16, borderRadius: "50%", background: "#fff", transition: "left 0.2s", boxShadow: "0 1px 3px rgba(0,0,0,.3)" } })
2411
2411
  ] });
2412
2412
  }
2413
- function De(n) {
2414
- const o = [];
2413
+ function me(n) {
2414
+ const i = [];
2415
2415
  for (const d of n)
2416
- d.type === "block" ? o.push(...De(d.items || [])) : o.push(d);
2417
- return o;
2416
+ d.type === "block" ? i.push(...me(d.items || [])) : i.push(d);
2417
+ return i;
2418
+ }
2419
+ function Ot(n) {
2420
+ return n === "primary" ? e.primary : n === "success" ? e.success : n === "secondary" ? e.borderDk : e.danger;
2421
+ }
2422
+ function Yt(n, i) {
2423
+ switch (n) {
2424
+ case "primary":
2425
+ return { background: e.primary, color: "#fff", borderColor: e.primary };
2426
+ case "danger":
2427
+ return { background: e.danger, color: "#fff", borderColor: e.danger };
2428
+ case "success":
2429
+ return { background: e.success, color: "#fff", borderColor: e.success };
2430
+ case "secondary":
2431
+ return { background: e.bg, color: e.text, borderColor: e.border };
2432
+ default:
2433
+ return i ? { background: e.primaryLt, color: e.primary } : {};
2434
+ }
2418
2435
  }
2419
- function un({ items: n = [], onAction: o, style: d }) {
2420
- _(q, []);
2421
- const [l, f] = N(() => {
2422
- const i = {};
2423
- for (const c of De(n))
2424
- c.id && (i[c.id] = !!c.active);
2425
- return i;
2426
- }), a = De(n), h = (i) => {
2427
- var c;
2428
- if (!i.disabled) {
2429
- if (i.id)
2430
- if (i.group) {
2431
- const m = a.filter((S) => S.group === i.group && S.id);
2432
- f((S) => {
2433
- const s = { ...S };
2434
- for (const b of m) s[b.id] = !1;
2435
- return s[i.id] = !0, s;
2436
+ function hn({
2437
+ items: n = [],
2438
+ css: i,
2439
+ menuCss: d,
2440
+ style: l,
2441
+ onAction: u,
2442
+ onInputChange: s,
2443
+ onInputBlur: f,
2444
+ onInputFocus: p,
2445
+ onOpenMenu: x
2446
+ }) {
2447
+ J(Q, []);
2448
+ const [z, r] = B(() => {
2449
+ const o = {};
2450
+ for (const E of me(n))
2451
+ E.id && (o[E.id] = !!E.active);
2452
+ return o;
2453
+ }), [b, h] = B(null), [M, R] = B(() => {
2454
+ const o = {};
2455
+ for (const E of me(n))
2456
+ E.type === "selectButton" && E.id && E.value && (o[E.id] = E.value);
2457
+ return o;
2458
+ }), a = me(n), k = le(null);
2459
+ xe(k, ae(() => h(null), []));
2460
+ const C = (o) => {
2461
+ var E, _;
2462
+ if (!o.disabled) {
2463
+ if (o.id) {
2464
+ if (o.group) {
2465
+ const w = a.filter((v) => v.group === o.group && v.id);
2466
+ r((v) => {
2467
+ const T = { ...v };
2468
+ for (const m of w) T[m.id] = !1;
2469
+ return T[o.id] = !0, T;
2436
2470
  });
2437
- } else i.twoState && f((m) => ({ ...m, [i.id]: !m[i.id] }));
2438
- (c = i.onClick) == null || c.call(i, i), i.id && (o == null || o(i.id, i));
2471
+ } else o.twoState && r((w) => ({ ...w, [o.id]: !w[o.id] }));
2472
+ if ((E = o.items) != null && E.length) {
2473
+ const w = o.id;
2474
+ h((v) => v === w ? null : w), x == null || x(o.id);
2475
+ return;
2476
+ }
2477
+ }
2478
+ (_ = o.onClick) == null || _.call(o, o), o.id && (u == null || u(o.id, o));
2439
2479
  }
2440
- }, u = (i, c) => {
2441
- var b;
2442
- if (i.hidden) return null;
2443
- const m = i.value ?? i.text, S = i.size === "auto", s = i.id !== void 0 ? l[i.id] ?? !!i.active : !!i.active;
2444
- return i.type === "separator" || i.type === "sep" ? /* @__PURE__ */ t("div", { style: { width: 1, background: e.border, margin: "4px 2px", alignSelf: "stretch" } }, c) : i.type === "input" ? /* @__PURE__ */ g("div", { style: { display: "flex", flexDirection: "column", alignItems: "flex-start", justifyContent: "center", padding: "2px 4px", gap: 2 }, children: [
2445
- i.label && /* @__PURE__ */ t("span", { style: { fontSize: 10, color: e.textMut }, children: i.label }),
2446
- /* @__PURE__ */ g("div", { style: { position: "relative", display: "flex", alignItems: "center" }, children: [
2447
- i.icon && /* @__PURE__ */ t("span", { style: { position: "absolute", left: 6, fontSize: 13, color: e.textMut, pointerEvents: "none", zIndex: 1 }, children: i.icon }),
2448
- /* @__PURE__ */ t(
2449
- "input",
2450
- {
2451
- className: "dhx dhx-input",
2452
- style: { width: i.width || 110, height: 26, fontSize: 12, paddingLeft: i.icon ? 24 : void 0 },
2453
- placeholder: i.placeholder,
2454
- defaultValue: i.value,
2455
- onChange: (M) => {
2456
- var D;
2457
- return (D = i.onChange) == null ? void 0 : D.call(i, M.target.value);
2458
- }
2459
- }
2460
- )
2461
- ] })
2462
- ] }, c) : i.type === "selectButton" ? /* @__PURE__ */ t(
2463
- "select",
2464
- {
2465
- className: "dhx dhx-input",
2466
- style: { height: 26, fontSize: 12, cursor: "pointer", margin: 2, width: i.width },
2467
- defaultValue: i.value,
2468
- onChange: (M) => {
2469
- var D;
2470
- return (D = i.onChange) == null ? void 0 : D.call(i, M.target.value);
2471
- },
2472
- children: (b = i.items) == null ? void 0 : b.map((M) => /* @__PURE__ */ t("option", { value: M.value, children: M.value }, M.value))
2473
- },
2474
- c
2475
- ) : /* @__PURE__ */ g(
2480
+ }, L = ({ count: o, color: E }) => /* @__PURE__ */ t("span", { style: {
2481
+ position: "absolute",
2482
+ top: 2,
2483
+ right: 2,
2484
+ minWidth: 14,
2485
+ height: 14,
2486
+ background: Ot(E),
2487
+ color: "#fff",
2488
+ borderRadius: 7,
2489
+ fontSize: 9,
2490
+ fontWeight: 700,
2491
+ display: "flex",
2492
+ alignItems: "center",
2493
+ justifyContent: "center",
2494
+ padding: "0 2px",
2495
+ pointerEvents: "none"
2496
+ }, children: o > 99 ? "99+" : o }), H = (o, E) => {
2497
+ var ne;
2498
+ const _ = o.id !== void 0 ? z[o.id] ?? !!o.active : !!o.active, w = o.value ?? o.text, v = o.size ?? "medium", T = v === "auto", m = v === "small", j = !!((ne = o.items) != null && ne.length), Y = o.id !== void 0 && b === o.id, G = Yt(o.color, _ && !o.color), V = T ? void 0 : m ? 26 : 32, q = T ? 22 : m ? 13 : 16, ee = [o.tooltip, o.hotkey ? `(${o.hotkey})` : ""].filter(Boolean).join(" "), te = o.circle ? { borderRadius: "50%", padding: T ? "8px" : "0", aspectRatio: "1", justifyContent: "center" } : {}, pe = o.view === "link" ? { background: "transparent", border: "none", textDecoration: "underline", padding: "0 4px" } : o.view === "flat" ? { borderRadius: 0 } : {};
2499
+ return /* @__PURE__ */ g("div", { style: { position: "relative", display: "flex" }, children: [
2500
+ /* @__PURE__ */ g(
2501
+ "button",
2502
+ {
2503
+ title: ee || void 0,
2504
+ disabled: o.disabled,
2505
+ className: "dhx dhx-btn dhx-btn-ghost",
2506
+ style: {
2507
+ flexDirection: T ? "column" : "row",
2508
+ alignSelf: T ? "stretch" : "center",
2509
+ justifyContent: "center",
2510
+ minHeight: T ? 56 : V,
2511
+ height: T ? void 0 : V,
2512
+ padding: T ? "6px 10px" : m ? "0 6px" : "0 8px",
2513
+ gap: 4,
2514
+ position: "relative",
2515
+ background: _ && !o.color ? e.primaryLt : "transparent",
2516
+ color: _ && !o.color ? e.primary : o.disabled ? e.textMut : e.text,
2517
+ opacity: o.disabled ? 0.55 : 1,
2518
+ cursor: o.disabled ? "not-allowed" : "pointer",
2519
+ borderColor: Y ? e.primary : void 0,
2520
+ ...G,
2521
+ ...te,
2522
+ ...pe
2523
+ },
2524
+ onClick: () => C(o),
2525
+ children: [
2526
+ o.loading ? /* @__PURE__ */ t("span", { style: {
2527
+ fontSize: q,
2528
+ lineHeight: 1,
2529
+ flexShrink: 0,
2530
+ display: "inline-block",
2531
+ animation: "dhx-spin 1s linear infinite"
2532
+ }, children: "⟳" }) : o.icon && /* @__PURE__ */ t("span", { style: { fontSize: q, lineHeight: 1, flexShrink: 0 }, children: o.icon }),
2533
+ w && !o.html && /* @__PURE__ */ t("span", { style: {
2534
+ fontSize: T ? 10 : m ? 11 : 12,
2535
+ maxWidth: T ? 64 : void 0,
2536
+ textAlign: T ? "center" : "left",
2537
+ lineHeight: T ? 1.2 : 1,
2538
+ whiteSpace: T ? "normal" : "nowrap"
2539
+ }, children: w }),
2540
+ o.html && /* @__PURE__ */ t("span", { dangerouslySetInnerHTML: { __html: o.html } }),
2541
+ j && /* @__PURE__ */ t("span", { style: { fontSize: 8, opacity: 0.6, marginLeft: 1 }, children: "▼" }),
2542
+ o.hotkey && T && /* @__PURE__ */ t("span", { style: { fontSize: 9, color: e.textMut, lineHeight: 1 }, children: o.hotkey }),
2543
+ o.count !== void 0 && /* @__PURE__ */ t(L, { count: o.count, color: o.countColor })
2544
+ ]
2545
+ }
2546
+ ),
2547
+ j && Y && /* @__PURE__ */ t(
2548
+ ge,
2549
+ {
2550
+ items: o.items,
2551
+ onSelect: (P) => {
2552
+ h(null), P.id && (u == null || u(String(P.id), o));
2553
+ },
2554
+ style: { top: "100%", left: 0, minWidth: 160 }
2555
+ }
2556
+ )
2557
+ ] }, E);
2558
+ }, $ = (o, E) => {
2559
+ const _ = o.size ?? "medium", w = _ === "auto" ? 48 : _ === "small" ? 28 : 36, v = o.id !== void 0 ? z[o.id] ?? !!o.active : !!o.active;
2560
+ return /* @__PURE__ */ t("div", { style: { position: "relative", display: "flex", alignSelf: "center" }, children: /* @__PURE__ */ g(
2476
2561
  "button",
2477
2562
  {
2478
- title: i.tooltip,
2479
- disabled: i.disabled,
2480
- className: "dhx dhx-btn dhx-btn-ghost",
2563
+ title: o.tooltip,
2564
+ disabled: o.disabled,
2481
2565
  style: {
2482
- flexDirection: S ? "column" : "row",
2483
- alignSelf: S ? "stretch" : "center",
2484
- justifyContent: "center",
2485
- minHeight: S ? 48 : 26,
2486
- padding: S ? "6px 10px" : "0 8px",
2487
- gap: S ? 4 : 5,
2488
- position: "relative",
2489
- background: s ? e.primaryLt : "transparent",
2490
- color: s ? e.primary : i.disabled ? e.textMut : e.text,
2491
- opacity: i.disabled ? 0.55 : 1,
2492
- cursor: i.disabled ? "not-allowed" : "pointer"
2566
+ width: w,
2567
+ height: w,
2568
+ padding: 2,
2569
+ border: v ? `2px solid ${e.primary}` : "2px solid transparent",
2570
+ borderRadius: "50%",
2571
+ overflow: "hidden",
2572
+ cursor: o.disabled ? "not-allowed" : "pointer",
2573
+ background: "transparent",
2574
+ flexShrink: 0,
2575
+ opacity: o.disabled ? 0.55 : 1
2493
2576
  },
2494
- onClick: () => h(i),
2577
+ onClick: () => C(o),
2495
2578
  children: [
2496
- i.icon && /* @__PURE__ */ t("span", { style: { fontSize: S ? 22 : 15, lineHeight: 1, flexShrink: 0 }, children: i.icon }),
2497
- m && /* @__PURE__ */ t("span", { style: {
2498
- fontSize: 10,
2499
- maxWidth: S ? 64 : void 0,
2500
- textAlign: S ? "center" : "left",
2501
- lineHeight: 1.2,
2502
- whiteSpace: S ? "normal" : "nowrap"
2503
- }, children: m }),
2504
- i.count !== void 0 && /* @__PURE__ */ t("span", { style: {
2505
- position: "absolute",
2506
- top: 2,
2507
- right: 2,
2508
- minWidth: 14,
2509
- height: 14,
2510
- background: e.danger,
2511
- color: "#fff",
2512
- borderRadius: 7,
2513
- fontSize: 9,
2514
- fontWeight: 700,
2515
- display: "flex",
2516
- alignItems: "center",
2517
- justifyContent: "center",
2518
- padding: "0 2px",
2519
- pointerEvents: "none"
2520
- }, children: i.count })
2579
+ o.src && /* @__PURE__ */ t(
2580
+ "img",
2581
+ {
2582
+ src: o.src,
2583
+ alt: o.value || "",
2584
+ style: { width: "100%", height: "100%", objectFit: "cover", borderRadius: "50%" }
2585
+ }
2586
+ ),
2587
+ o.count !== void 0 && /* @__PURE__ */ t(L, { count: o.count, color: o.countColor })
2521
2588
  ]
2522
- },
2523
- c
2524
- );
2525
- }, x = (i, c) => {
2526
- var m;
2589
+ }
2590
+ ) }, E);
2591
+ }, D = (o, E) => {
2592
+ var T, m;
2593
+ const _ = o.id !== void 0 && b === `sel:${o.id}`, w = (o.id && M[o.id]) ?? o.value ?? ((m = (T = o.items) == null ? void 0 : T[0]) == null ? void 0 : m.value) ?? "", v = (o.items ?? []).map((j) => ({
2594
+ id: j.value,
2595
+ value: j.value,
2596
+ icon: j.icon
2597
+ }));
2598
+ return /* @__PURE__ */ g("div", { style: { position: "relative", alignSelf: "center" }, children: [
2599
+ /* @__PURE__ */ g(
2600
+ "button",
2601
+ {
2602
+ title: o.tooltip,
2603
+ disabled: o.disabled,
2604
+ className: "dhx dhx-btn dhx-btn-ghost",
2605
+ style: {
2606
+ height: 28,
2607
+ gap: 4,
2608
+ padding: "0 8px",
2609
+ opacity: o.disabled ? 0.55 : 1,
2610
+ cursor: o.disabled ? "not-allowed" : "pointer",
2611
+ borderColor: _ ? e.primary : void 0
2612
+ },
2613
+ onClick: () => {
2614
+ if (o.disabled || !o.id) return;
2615
+ const j = `sel:${o.id}`;
2616
+ h((Y) => Y === j ? null : j);
2617
+ },
2618
+ children: [
2619
+ o.icon && /* @__PURE__ */ t("span", { style: { fontSize: 14 }, children: o.icon }),
2620
+ /* @__PURE__ */ t("span", { style: { fontSize: 12 }, children: w }),
2621
+ /* @__PURE__ */ t("span", { style: { fontSize: 8, opacity: 0.6 }, children: "▼" })
2622
+ ]
2623
+ }
2624
+ ),
2625
+ _ && /* @__PURE__ */ t(
2626
+ ge,
2627
+ {
2628
+ items: v,
2629
+ onSelect: (j) => {
2630
+ var G;
2631
+ const Y = String(j.value ?? j.id ?? "");
2632
+ o.id && R((V) => ({ ...V, [o.id]: Y })), h(null), (G = o.onChange) == null || G.call(o, Y), o.id && (u == null || u(o.id, o));
2633
+ },
2634
+ style: { top: "100%", left: 0, minWidth: 100 }
2635
+ }
2636
+ )
2637
+ ] }, E);
2638
+ }, K = (o, E) => /* @__PURE__ */ g("div", { style: { display: "flex", flexDirection: "column", alignItems: "flex-start", justifyContent: "center", padding: "2px 4px", gap: 2 }, children: [
2639
+ o.label && /* @__PURE__ */ t("span", { style: { fontSize: 10, color: e.textMut }, children: o.label }),
2640
+ /* @__PURE__ */ g("div", { style: { position: "relative", display: "flex", alignItems: "center" }, children: [
2641
+ o.icon && /* @__PURE__ */ t("span", { style: { position: "absolute", left: 6, fontSize: 13, color: e.textMut, pointerEvents: "none", zIndex: 1 }, children: o.icon }),
2642
+ /* @__PURE__ */ t(
2643
+ "input",
2644
+ {
2645
+ className: "dhx dhx-input",
2646
+ disabled: o.disabled,
2647
+ style: { width: o.width || 110, height: 26, fontSize: 12, paddingLeft: o.icon ? 24 : void 0 },
2648
+ placeholder: o.placeholder,
2649
+ defaultValue: o.value,
2650
+ onChange: (_) => {
2651
+ var w;
2652
+ (w = o.onChange) == null || w.call(o, _.target.value), o.id && (s == null || s(o.id, _.target.value));
2653
+ },
2654
+ onBlur: (_) => {
2655
+ var w;
2656
+ (w = o.onBlur) == null || w.call(o, _.target.value), o.id && (f == null || f(o.id, _.target.value));
2657
+ },
2658
+ onFocus: (_) => {
2659
+ var w;
2660
+ (w = o.onFocus) == null || w.call(o, _.target.value), o.id && (p == null || p(o.id, _.target.value));
2661
+ }
2662
+ }
2663
+ )
2664
+ ] })
2665
+ ] }, E), c = (o, E) => o.hidden ? null : /* @__PURE__ */ t("div", { title: o.tooltip, style: {
2666
+ padding: "2px 6px",
2667
+ fontSize: 11,
2668
+ color: o.disabled ? e.textMut : e.textSec,
2669
+ display: "flex",
2670
+ alignItems: "center",
2671
+ alignSelf: "center",
2672
+ userSelect: "none",
2673
+ opacity: o.disabled ? 0.5 : 1
2674
+ }, children: o.html ? /* @__PURE__ */ t("span", { dangerouslySetInnerHTML: { __html: o.html } }) : o.value }, E), N = (o, E) => o.hidden ? null : /* @__PURE__ */ t(
2675
+ "div",
2676
+ {
2677
+ style: { display: "flex", alignItems: "center", alignSelf: "center", padding: "0 4px" },
2678
+ dangerouslySetInnerHTML: { __html: o.html ?? "" }
2679
+ },
2680
+ E
2681
+ ), A = (o, E) => o.hidden ? null : o.type === "separator" || o.type === "sep" ? /* @__PURE__ */ t("div", { style: { width: 1, background: e.border, margin: "4px 2px", alignSelf: "stretch" } }, E) : o.type === "spacer" ? /* @__PURE__ */ t("div", { style: { flex: 1 } }, E) : o.type === "title" ? c(o, E) : o.type === "customHTML" ? N(o, E) : o.type === "imageButton" ? $(o, E) : o.type === "input" ? K(o, E) : o.type === "selectButton" ? D(o, E) : H(o, E), S = (o, E, _) => {
2682
+ var v;
2683
+ if (o.hidden) return null;
2684
+ const w = _ || o.disabled;
2527
2685
  return /* @__PURE__ */ t("div", { style: {
2528
2686
  display: "flex",
2529
- flexDirection: i.direction === "col" ? "column" : "row",
2530
- alignItems: i.direction === "col" ? "flex-start" : "center",
2531
- gap: 2
2532
- }, children: (m = i.items) == null ? void 0 : m.map(
2533
- (S, s) => S.type === "block" ? x(S, `${c}-${s}`) : u(S, `${c}-${s}`)
2534
- ) }, c);
2535
- }, w = (i, c) => {
2536
- var S;
2537
- const m = i.title || i.label;
2687
+ flexDirection: o.direction === "col" ? "column" : "row",
2688
+ alignItems: o.direction === "col" ? "flex-start" : "center",
2689
+ gap: 2,
2690
+ opacity: o.disabled && !_ ? 0.55 : 1,
2691
+ pointerEvents: w ? "none" : void 0
2692
+ }, children: (v = o.items) == null ? void 0 : v.map(
2693
+ (T, m) => T.type === "block" ? S(T, `${E}-${m}`, w) : A(T, `${E}-${m}`)
2694
+ ) }, E);
2695
+ }, U = (o, E) => {
2696
+ var w;
2697
+ if (o.hidden) return null;
2698
+ const _ = o.title || o.label;
2538
2699
  return /* @__PURE__ */ g("div", { style: {
2539
2700
  display: "flex",
2540
2701
  flexDirection: "column",
2541
2702
  alignItems: "stretch",
2542
2703
  borderRight: `1px solid ${e.border}`,
2543
2704
  padding: "4px 6px 0",
2544
- minWidth: 40
2705
+ minWidth: 40,
2706
+ opacity: o.disabled ? 0.55 : 1,
2707
+ pointerEvents: o.disabled ? "none" : void 0
2545
2708
  }, children: [
2546
2709
  /* @__PURE__ */ t("div", { style: {
2547
2710
  display: "flex",
2548
- flexDirection: i.direction === "col" ? "column" : "row",
2549
- alignItems: i.direction === "col" ? "stretch" : "center",
2711
+ flexDirection: o.direction === "col" ? "column" : "row",
2712
+ alignItems: o.direction === "col" ? "stretch" : "center",
2550
2713
  gap: 2,
2551
2714
  flex: 1
2552
- }, children: (S = i.items) == null ? void 0 : S.map(
2553
- (s, b) => s.type === "block" ? x(s, b) : u(s, b)
2715
+ }, children: (w = o.items) == null ? void 0 : w.map(
2716
+ (v, T) => v.type === "block" ? S(v, T, o.disabled) : A(v, T)
2554
2717
  ) }),
2555
- m && /* @__PURE__ */ t("div", { style: {
2718
+ _ && /* @__PURE__ */ t("div", { style: {
2556
2719
  fontSize: 10,
2557
2720
  color: e.textMut,
2558
2721
  textAlign: "center",
2559
2722
  padding: "3px 0 4px",
2560
2723
  marginTop: 2,
2561
2724
  borderTop: `1px solid ${e.border}`
2562
- }, children: m })
2563
- ] }, c);
2564
- }, r = (i, c) => i.type === "block" ? w(i, c) : u(i, c);
2565
- return /* @__PURE__ */ t("div", { className: "dhx", style: {
2566
- display: "flex",
2567
- alignItems: "stretch",
2568
- background: e.surface,
2569
- borderBottom: `1px solid ${e.border}`,
2570
- overflowX: "auto",
2571
- gap: 0,
2572
- minHeight: 72,
2573
- ...d
2574
- }, children: n.map(r) });
2725
+ }, children: _ })
2726
+ ] }, E);
2727
+ }, Z = (o, E) => o.type === "block" ? U(o, E) : A(o, E);
2728
+ return /* @__PURE__ */ t(
2729
+ "div",
2730
+ {
2731
+ ref: k,
2732
+ className: ["dhx", i].filter(Boolean).join(" "),
2733
+ style: {
2734
+ display: "flex",
2735
+ alignItems: "stretch",
2736
+ background: e.surface,
2737
+ borderBottom: `1px solid ${e.border}`,
2738
+ overflowX: "auto",
2739
+ gap: 0,
2740
+ minHeight: 72,
2741
+ ...l
2742
+ },
2743
+ children: n.map(Z)
2744
+ }
2745
+ );
2575
2746
  }
2576
2747
  function Oe({ count: n }) {
2577
2748
  return /* @__PURE__ */ t("span", { style: {
@@ -2593,53 +2764,53 @@ function Oe({ count: n }) {
2593
2764
  pointerEvents: "none"
2594
2765
  }, children: n });
2595
2766
  }
2596
- function pn({ logo: n, items: o = [], vertical: d = !1, onAction: l, style: f }) {
2597
- const [a, h] = N(null), [u, x] = N(() => {
2598
- const c = {};
2599
- return o.forEach((m) => {
2600
- m.id && m.twoState && m.active && (c[m.id] = !0);
2601
- }), c;
2602
- }), w = oe(null);
2603
- _(q, []), ge(w, ae(() => h(null), []));
2604
- const r = (c, m) => {
2605
- var S, s;
2606
- if (!c.disabled) {
2607
- if (c.twoState && c.id && x((b) => ({ ...b, [c.id]: !b[c.id] })), (S = c.items) != null && S.length) {
2608
- h((b) => b === m ? null : m);
2767
+ function fn({ logo: n, items: i = [], vertical: d = !1, onAction: l, style: u }) {
2768
+ const [s, f] = B(null), [p, x] = B(() => {
2769
+ const h = {};
2770
+ return i.forEach((M) => {
2771
+ M.id && M.twoState && M.active && (h[M.id] = !0);
2772
+ }), h;
2773
+ }), z = le(null);
2774
+ J(Q, []), xe(z, ae(() => f(null), []));
2775
+ const r = (h, M) => {
2776
+ var R, a;
2777
+ if (!h.disabled) {
2778
+ if (h.twoState && h.id && x((k) => ({ ...k, [h.id]: !k[h.id] })), (R = h.items) != null && R.length) {
2779
+ f((k) => k === M ? null : M);
2609
2780
  return;
2610
2781
  }
2611
- (s = c.onClick) == null || s.call(c, c.id || ""), l == null || l(c.id || "");
2782
+ (a = h.onClick) == null || a.call(h, h.id || ""), l == null || l(h.id || "");
2612
2783
  }
2613
- }, i = (c, m) => {
2614
- var M;
2615
- if (c.hidden) return null;
2616
- if (c.type === "separator") return /* @__PURE__ */ t("div", { style: {
2784
+ }, b = (h, M) => {
2785
+ var C;
2786
+ if (h.hidden) return null;
2787
+ if (h.type === "separator") return /* @__PURE__ */ t("div", { style: {
2617
2788
  [d ? "height" : "width"]: 1,
2618
2789
  background: e.border,
2619
2790
  margin: d ? "4px 8px" : "0 6px",
2620
2791
  alignSelf: "stretch"
2621
- } }, m);
2622
- if (c.type === "spacer") return /* @__PURE__ */ t("div", { style: { flex: 1 } }, m);
2623
- if (c.type === "input") return /* @__PURE__ */ g("div", { style: { position: "relative", display: "flex", alignItems: "center", margin: "0 4px" }, children: [
2624
- c.icon && /* @__PURE__ */ t("span", { style: { position: "absolute", left: 8, color: e.textMut, fontSize: 15, pointerEvents: "none", zIndex: 1 }, children: c.icon }),
2792
+ } }, M);
2793
+ if (h.type === "spacer") return /* @__PURE__ */ t("div", { style: { flex: 1 } }, M);
2794
+ if (h.type === "input") return /* @__PURE__ */ g("div", { style: { position: "relative", display: "flex", alignItems: "center", margin: "0 4px" }, children: [
2795
+ h.icon && /* @__PURE__ */ t("span", { style: { position: "absolute", left: 8, color: e.textMut, fontSize: 15, pointerEvents: "none", zIndex: 1 }, children: h.icon }),
2625
2796
  /* @__PURE__ */ t(
2626
2797
  "input",
2627
2798
  {
2628
2799
  className: "dhx dhx-input",
2629
- style: { width: c.width || 200, height: 28, paddingLeft: c.icon ? 30 : void 0 },
2630
- placeholder: c.placeholder,
2631
- onChange: (D) => {
2632
- var R;
2633
- return (R = c.onChange) == null ? void 0 : R.call(c, D.target.value);
2800
+ style: { width: h.width || 200, height: 28, paddingLeft: h.icon ? 30 : void 0 },
2801
+ placeholder: h.placeholder,
2802
+ onChange: (L) => {
2803
+ var H;
2804
+ return (H = h.onChange) == null ? void 0 : H.call(h, L.target.value);
2634
2805
  }
2635
2806
  }
2636
2807
  )
2637
- ] }, m);
2638
- if (c.type === "imageButton") return /* @__PURE__ */ g(
2808
+ ] }, M);
2809
+ if (h.type === "imageButton") return /* @__PURE__ */ g(
2639
2810
  "button",
2640
2811
  {
2641
- title: c.tooltip,
2642
- disabled: c.disabled,
2812
+ title: h.tooltip,
2813
+ disabled: h.disabled,
2643
2814
  style: {
2644
2815
  position: "relative",
2645
2816
  width: 36,
@@ -2648,26 +2819,26 @@ function pn({ logo: n, items: o = [], vertical: d = !1, onAction: l, style: f })
2648
2819
  border: "none",
2649
2820
  borderRadius: "50%",
2650
2821
  overflow: "hidden",
2651
- cursor: c.disabled ? "not-allowed" : "pointer",
2822
+ cursor: h.disabled ? "not-allowed" : "pointer",
2652
2823
  background: "transparent",
2653
2824
  flexShrink: 0
2654
2825
  },
2655
- onClick: () => r(c, m),
2826
+ onClick: () => r(h, M),
2656
2827
  children: [
2657
- c.src && /* @__PURE__ */ t("img", { src: c.src, alt: c.value || "", style: { width: "100%", height: "100%", objectFit: "cover", borderRadius: "50%" } }),
2658
- c.count !== void 0 && /* @__PURE__ */ t(Oe, { count: c.count })
2828
+ h.src && /* @__PURE__ */ t("img", { src: h.src, alt: h.value || "", style: { width: "100%", height: "100%", objectFit: "cover", borderRadius: "50%" } }),
2829
+ h.count !== void 0 && /* @__PURE__ */ t(Oe, { count: h.count })
2659
2830
  ]
2660
2831
  },
2661
- m
2832
+ M
2662
2833
  );
2663
- const S = !!(c.twoState && c.id && u[c.id]), s = !!((M = c.items) != null && M.length), b = {
2834
+ const R = !!(h.twoState && h.id && p[h.id]), a = !!((C = h.items) != null && C.length), k = {
2664
2835
  position: "relative",
2665
2836
  height: d ? 40 : 36,
2666
2837
  gap: 6,
2667
- background: S ? e.primaryLt : "transparent",
2668
- color: S ? e.primary : c.disabled ? e.textMut : e.text,
2669
- opacity: c.disabled ? 0.55 : 1,
2670
- cursor: c.disabled ? "not-allowed" : "pointer",
2838
+ background: R ? e.primaryLt : "transparent",
2839
+ color: R ? e.primary : h.disabled ? e.textMut : e.text,
2840
+ opacity: h.disabled ? 0.55 : 1,
2841
+ cursor: h.disabled ? "not-allowed" : "pointer",
2671
2842
  ...d ? {
2672
2843
  width: "100%",
2673
2844
  justifyContent: "flex-start",
@@ -2680,35 +2851,35 @@ function pn({ logo: n, items: o = [], vertical: d = !1, onAction: l, style: f })
2680
2851
  "button",
2681
2852
  {
2682
2853
  className: "dhx dhx-btn dhx-btn-ghost",
2683
- title: c.tooltip,
2684
- disabled: c.disabled,
2685
- style: b,
2686
- onClick: () => r(c, m),
2854
+ title: h.tooltip,
2855
+ disabled: h.disabled,
2856
+ style: k,
2857
+ onClick: () => r(h, M),
2687
2858
  children: [
2688
- c.icon && /* @__PURE__ */ t("span", { style: { fontSize: 16, flexShrink: 0 }, children: c.icon }),
2689
- c.value && /* @__PURE__ */ t("span", { style: { fontSize: 13 }, children: c.value }),
2690
- s && /* @__PURE__ */ t("span", { style: { fontSize: 9, opacity: 0.55, marginLeft: 2 }, children: "▼" }),
2691
- c.count !== void 0 && /* @__PURE__ */ t(Oe, { count: c.count })
2859
+ h.icon && /* @__PURE__ */ t("span", { style: { fontSize: 16, flexShrink: 0 }, children: h.icon }),
2860
+ h.value && /* @__PURE__ */ t("span", { style: { fontSize: 13 }, children: h.value }),
2861
+ a && /* @__PURE__ */ t("span", { style: { fontSize: 9, opacity: 0.55, marginLeft: 2 }, children: "▼" }),
2862
+ h.count !== void 0 && /* @__PURE__ */ t(Oe, { count: h.count })
2692
2863
  ]
2693
2864
  }
2694
2865
  ),
2695
- s && a === m && /* @__PURE__ */ t(
2696
- be,
2866
+ a && s === M && /* @__PURE__ */ t(
2867
+ ge,
2697
2868
  {
2698
- items: c.items,
2699
- onSelect: (D) => {
2700
- var R;
2701
- h(null), D.id && ((R = c.onClick) == null || R.call(c, D.id), l == null || l(D.id));
2869
+ items: h.items,
2870
+ onSelect: (L) => {
2871
+ var H;
2872
+ f(null), L.id && ((H = h.onClick) == null || H.call(h, L.id), l == null || l(L.id));
2702
2873
  },
2703
2874
  style: d ? { left: "100%", top: 0 } : { top: "100%" }
2704
2875
  }
2705
2876
  )
2706
- ] }, m);
2877
+ ] }, M);
2707
2878
  };
2708
2879
  return /* @__PURE__ */ g(
2709
2880
  "nav",
2710
2881
  {
2711
- ref: w,
2882
+ ref: z,
2712
2883
  className: "dhx",
2713
2884
  style: {
2714
2885
  display: "flex",
@@ -2720,7 +2891,7 @@ function pn({ logo: n, items: o = [], vertical: d = !1, onAction: l, style: f })
2720
2891
  padding: d ? "8px 0" : "0 12px",
2721
2892
  minHeight: d ? void 0 : 48,
2722
2893
  gap: 2,
2723
- ...f
2894
+ ...u
2724
2895
  },
2725
2896
  children: [
2726
2897
  n && /* @__PURE__ */ t("div", { style: {
@@ -2734,41 +2905,41 @@ function pn({ logo: n, items: o = [], vertical: d = !1, onAction: l, style: f })
2734
2905
  marginBottom: d ? 4 : 0,
2735
2906
  flexShrink: 0
2736
2907
  }, children: n }),
2737
- o.map(i)
2908
+ i.map(b)
2738
2909
  ]
2739
2910
  }
2740
2911
  );
2741
2912
  }
2742
2913
  export {
2743
- _t as Button,
2744
- Zt as Calendar,
2745
- Qt as Chart,
2746
- en as Colorpicker,
2747
- Be as Combobox,
2748
- Xt as ContextMenu,
2749
- sn as DataView,
2750
- cn as Form,
2751
- Ut as Grid,
2752
- Dt as Layout,
2753
- ln as List,
2754
- Vt as Menu,
2755
- be as MenuDropdown,
2914
+ Xt as Button,
2915
+ tn as Calendar,
2916
+ en as Chart,
2917
+ nn as Colorpicker,
2918
+ He as Combobox,
2919
+ Gt as ContextMenu,
2920
+ dn as DataView,
2921
+ pn as Form,
2922
+ Zt as Grid,
2923
+ Ct as Layout,
2924
+ an as List,
2925
+ qt as Menu,
2926
+ ge as MenuDropdown,
2756
2927
  Ke as MessageContext,
2757
- rn as MessageProvider,
2758
- pn as Navbar,
2759
- dn as Pagination,
2760
- tn as Popup,
2761
- un as Ribbon,
2762
- Gt as Sidebar,
2763
- He as Slider,
2764
- Jt as Tabbar,
2765
- At as Timepicker,
2766
- qt as Toolbar,
2767
- an as Tree,
2768
- nn as Window,
2928
+ ln as MessageProvider,
2929
+ fn as Navbar,
2930
+ un as Pagination,
2931
+ rn as Popup,
2932
+ hn as Ribbon,
2933
+ Ut as Sidebar,
2934
+ Ae as Slider,
2935
+ Qt as Tabbar,
2936
+ Bt as Timepicker,
2937
+ Jt as Toolbar,
2938
+ cn as Tree,
2939
+ on as Window,
2769
2940
  e as tokens,
2770
- ge as useClickOutside,
2771
- St as useDrag,
2772
- on as useMessage
2941
+ xe as useClickOutside,
2942
+ kt as useDrag,
2943
+ sn as useMessage
2773
2944
  };
2774
2945
  //# sourceMappingURL=dhx-react-suite.js.map