dhx-react-suite 1.1.9 → 1.2.0

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