@vuu-ui/vuu-table-extras 0.8.4-debug → 0.8.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/cjs/index.js CHANGED
@@ -1,3212 +1,2 @@
1
- "use strict";
2
- var __create = Object.create;
3
- var __defProp = Object.defineProperty;
4
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
- var __getOwnPropNames = Object.getOwnPropertyNames;
6
- var __getProtoOf = Object.getPrototypeOf;
7
- var __hasOwnProp = Object.prototype.hasOwnProperty;
8
- var __export = (target, all) => {
9
- for (var name in all)
10
- __defProp(target, name, { get: all[name], enumerable: true });
11
- };
12
- var __copyProps = (to, from, except, desc) => {
13
- if (from && typeof from === "object" || typeof from === "function") {
14
- for (let key of __getOwnPropNames(from))
15
- if (!__hasOwnProp.call(to, key) && key !== except)
16
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
- }
18
- return to;
19
- };
20
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
- // If the importer is in node compatibility mode or this is not an ESM
22
- // file that has been converted to a CommonJS file using a Babel-
23
- // compatible transform (i.e. "__esModule" has not been set), then set
24
- // "default" to the CommonJS "module.exports" for node compatibility.
25
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
- mod
27
- ));
28
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
- var __accessCheck = (obj, member, msg) => {
30
- if (!member.has(obj))
31
- throw TypeError("Cannot " + msg);
32
- };
33
- var __privateGet = (obj, member, getter) => {
34
- __accessCheck(obj, member, "read from private field");
35
- return getter ? getter.call(obj) : member.get(obj);
36
- };
37
- var __privateAdd = (obj, member, value) => {
38
- if (member.has(obj))
39
- throw TypeError("Cannot add the same private member more than once");
40
- member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
41
- };
42
- var __privateSet = (obj, member, value, setter) => {
43
- __accessCheck(obj, member, "write to private field");
44
- setter ? setter.call(obj, value) : member.set(obj, value);
45
- return value;
46
- };
47
-
48
- // src/index.ts
49
- var src_exports = {};
50
- __export(src_exports, {
51
- ColumnExpressionInput: () => ColumnExpressionInput,
52
- ColumnNamedTerms: () => ColumnNamedTerms,
53
- ColumnSettingsPanel: () => ColumnSettingsPanel2,
54
- DataSourceStats: () => DataSourceStats,
55
- DatagridSettingsPanel: () => DatagridSettingsPanel,
56
- columnExpressionLanguageSupport: () => columnExpressionLanguageSupport,
57
- isCompleteExpression: () => isCompleteExpression,
58
- isCompleteRelationalExpression: () => isCompleteRelationalExpression,
59
- lastNamedChild: () => lastNamedChild,
60
- useColumnExpressionEditor: () => useColumnExpressionEditor,
61
- useColumnExpressionSuggestionProvider: () => useColumnExpressionSuggestionProvider,
62
- walkTree: () => walkTree
63
- });
64
- module.exports = __toCommonJS(src_exports);
65
-
66
- // src/cell-renderers/background-cell/BackgroundCell.tsx
67
- var import_vuu_utils2 = require("@vuu-ui/vuu-utils");
68
- var import_classnames = __toESM(require("classnames"), 1);
69
-
70
- // src/cell-renderers/background-cell/useDirection.ts
71
- var import_vuu_utils = require("@vuu-ui/vuu-utils");
72
- var import_react = require("react");
73
- var INITIAL_VALUE = [void 0, void 0, void 0, void 0];
74
- function useDirection(key, value, column) {
75
- var _a;
76
- const ref = (0, import_react.useRef)();
77
- const [prevKey, prevValue, prevColumn, prevDirection] = ref.current || INITIAL_VALUE;
78
- const { type: dataType } = column;
79
- const decimals = (0, import_vuu_utils.isTypeDescriptor)(dataType) ? (_a = dataType.formatting) == null ? void 0 : _a.decimals : void 0;
80
- const direction = key === prevKey && (0, import_vuu_utils.isValidNumber)(value) && (0, import_vuu_utils.isValidNumber)(prevValue) && column === prevColumn ? (0, import_vuu_utils.getMovingValueDirection)(value, prevDirection, prevValue, decimals) : "";
81
- (0, import_react.useEffect)(() => {
82
- ref.current = [key, value, column, direction];
83
- });
84
- return direction;
85
- }
86
-
87
- // src/cell-renderers/background-cell/BackgroundCell.tsx
88
- var import_jsx_runtime = require("react/jsx-runtime");
89
- var CHAR_ARROW_UP = String.fromCharCode(11014);
90
- var CHAR_ARROW_DOWN = String.fromCharCode(11015);
91
- var { KEY } = import_vuu_utils2.metadataKeys;
92
- var classBase = "vuuBackgroundCell";
93
- var FlashStyle = {
94
- ArrowOnly: "arrow",
95
- BackgroundOnly: "bg-only",
96
- ArrowBackground: "arrow-bg"
97
- };
98
- var getFlashStyle = (colType) => {
99
- if ((0, import_vuu_utils2.isTypeDescriptor)(colType) && colType.renderer) {
100
- if ("flashStyle" in colType.renderer) {
101
- return colType.renderer["flashStyle"];
102
- }
103
- }
104
- return FlashStyle.BackgroundOnly;
105
- };
106
- var BackgroundCell = ({ column, row }) => {
107
- const { key, type, valueFormatter } = column;
108
- const value = row[key];
109
- const flashStyle = getFlashStyle(type);
110
- const direction = useDirection(row[KEY], value, column);
111
- const arrow = flashStyle === FlashStyle.ArrowOnly || flashStyle === FlashStyle.ArrowBackground ? direction === import_vuu_utils2.UP1 || direction === import_vuu_utils2.UP2 ? CHAR_ARROW_UP : direction === import_vuu_utils2.DOWN1 || direction === import_vuu_utils2.DOWN2 ? CHAR_ARROW_DOWN : null : null;
112
- const dirClass = direction ? ` ` + direction : "";
113
- const className = (0, import_classnames.default)(classBase, dirClass, {
114
- [`${classBase}-arrowOnly`]: flashStyle === FlashStyle.ArrowOnly,
115
- [`${classBase}-arrowBackground`]: flashStyle === FlashStyle.ArrowBackground
116
- });
117
- return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { className, tabIndex: -1, children: [
118
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: `${classBase}-flasher`, children: arrow }),
119
- valueFormatter(row[column.key])
120
- ] });
121
- };
122
- (0, import_vuu_utils2.registerComponent)("background", BackgroundCell, "cell-renderer", {
123
- serverDataType: ["long", "int", "double"]
124
- });
125
-
126
- // src/cell-renderers/progress-cell/ProgressCell.tsx
127
- var import_vuu_utils3 = require("@vuu-ui/vuu-utils");
128
- var import_classnames2 = __toESM(require("classnames"), 1);
129
- var import_jsx_runtime2 = require("react/jsx-runtime");
130
- var classBase2 = "vuuProgressCell";
131
- var ProgressCell = ({ column, columnMap, row }) => {
132
- const { type } = column;
133
- const value = row[column.key];
134
- let showProgress = false;
135
- let percentage = 0;
136
- if ((0, import_vuu_utils3.isTypeDescriptor)(type) && (0, import_vuu_utils3.isColumnTypeRenderer)(type.renderer)) {
137
- const { associatedField } = type.renderer;
138
- const associatedValue = row[columnMap[associatedField]];
139
- if (typeof value === "number" && typeof associatedValue === "number") {
140
- percentage = Math.min(Math.round(value / associatedValue * 100), 100);
141
- showProgress = isFinite(percentage);
142
- } else {
143
- const floatValue = parseFloat(value);
144
- if (Number.isFinite(floatValue)) {
145
- const floatOtherValue = parseFloat(associatedValue);
146
- if (Number.isFinite(floatOtherValue)) {
147
- percentage = Math.min(
148
- Math.round(floatValue / floatOtherValue * 100),
149
- 100
150
- );
151
- showProgress = isFinite(percentage);
152
- }
153
- }
154
- }
155
- }
156
- const className = (0, import_classnames2.default)(classBase2, {});
157
- return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { className, tabIndex: -1, children: [
158
- showProgress ? /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("span", { className: `${classBase2}-track`, children: [
159
- /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("span", { className: `${classBase2}-bg` }),
160
- /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
161
- "span",
162
- {
163
- className: `${classBase2}-bar`,
164
- style: { "--progress-bar-pct": `-${100 - percentage}%` }
165
- }
166
- )
167
- ] }) : null,
168
- /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("span", { className: `${classBase2}-text`, children: `${percentage} %` })
169
- ] });
170
- };
171
- (0, import_vuu_utils3.registerComponent)("vuu.progress", ProgressCell, "cell-renderer", {
172
- serverDataType: ["long", "int", "double"]
173
- });
174
-
175
- // src/column-expression-input/useColumnExpressionEditor.ts
176
- var import_vuu_codemirror5 = require("@vuu-ui/vuu-codemirror");
177
- var import_vuu_utils4 = require("@vuu-ui/vuu-utils");
178
- var import_react3 = require("react");
179
-
180
- // src/column-expression-input/column-language-parser/ColumnExpressionLanguage.ts
181
- var import_vuu_codemirror = require("@vuu-ui/vuu-codemirror");
182
-
183
- // src/column-expression-input/column-language-parser/generated/column-parser.js
184
- var import_lr = require("@lezer/lr");
185
- var parser = import_lr.LRParser.deserialize({
186
- version: 14,
187
- states: "&fOVQPOOO!SQPO'#C^OVQPO'#CcQ!pQPOOO#OQPO'#CkO#TQPO'#CrOOQO'#Cy'#CyO#YQPO,58}OVQPO,59QOVQPO,59QOVQPO,59VOVQPO'#CtOOQO,59^,59^OOQO1G.i1G.iOOQO1G.l1G.lO#kQPO1G.lO$fQPO'#CmO%WQQO1G.qOOQO'#C{'#C{O%cQPO,59`OOQO'#Cn'#CnO%wQPO,59XOVQPO,59ZOVQPO,59[OVQPO7+$]OVQPO'#CuO&`QPO1G.zOOQO1G.z1G.zO&hQQO'#C^O&rQQO1G.sO'ZQQO1G.uOOQO1G.v1G.vO'fQPO<<GwO'wQPO,59aOOQO-E6s-E6sOOQO7+$f7+$fOVQPOAN=cO(]QQO1G.lO(tQPOG22}OOQOLD(iLD(iO%wQPO,59QO%wQPO,59Q",
188
- stateData: ")[~OlOS~ORUOSUOTUOUUOWQO`SOnPO~OWgXZQX[QX]QX^QXeQX~OjQXXQXpQXqQXrQXsQXtQXuQX~PnOZWO[WO]XO^XO~OWYO~OWZO~OX]OZWO[WO]XO^XO~OZWO[WO]Yi^YijYiXYipYiqYirYisYitYiuYieYi~OZWO[WO]XO^XOpdOqdOrdOsdOtdOudO~OehOvfOwgO~OXkOZWO[WO]XO^XOeiO~ORUOSUOTUOUUOWQO`SOnlO~OXsOeiO~OvQXwQX~PnOZxO[xO]yO^yOeaivaiwai~OwgOecivci~OZWO[WO]XO^XOetO~OZWO[WO]XO^XOXiaeia~OZxO[xO]Yi^YieYivYiwYi~OXwOZWO[WO]XO^XO~O`UTn~",
189
- goto: "#spPPqPPPPqPPqPPPPqP!R!W!R!RPq!Z!k!nPPP!tP#jmUOQWXYZefghitxyVbYfgRe`mTOQWXYZefghitxyR[TQjcRrjQROQVQS^WxQ_XU`YfgQcZQmeQphQqiQuyRvtQaYQnfRog",
190
- nodeNames: "\u26A0 ColumnDefinitionExpression Column Number String True False ParenthesizedExpression OpenBrace CloseBrace ArithmeticExpression Divide Times Plus Minus ConditionalExpression If RelationalExpression RelationalOperator AndCondition OrCondition Comma CallExpression Function ArgList",
191
- maxTerm: 39,
192
- skippedNodes: [0],
193
- repeatNodeCount: 1,
194
- tokenData: ".^~RnXY#PYZ#P]^#Ppq#Pqr#brs#mxy$eyz$jz{$o{|$t|}$y}!O%O!O!P%T!P!Q%c!Q![%h!^!_%s!_!`&Q!`!a&V!c!}&d#R#S&d#T#U&u#U#Y&d#Y#Z(Y#Z#]&d#]#^*j#^#c&d#c#d+f#d#h&d#h#i,b#i#o&d~#USl~XY#PYZ#P]^#Ppq#P~#eP!_!`#h~#mOu~~#pWOX#mZ]#m^r#mrs$Ys#O#m#P;'S#m;'S;=`$_<%lO#m~$_OS~~$bP;=`<%l#m~$jOW~~$oOX~~$tO[~~$yO]~~%OOe~~%TO^~~%WP!Q![%Z~%`PR~!Q![%Z~%hOZ~~%mQR~!O!P%Z!Q![%h~%xPr~!_!`%{~&QOt~~&VOp~~&[Pq~!_!`&_~&dOs~P&iSnP!Q![&d!c!}&d#R#S&d#T#o&dR&zUnP!Q![&d!c!}&d#R#S&d#T#b&d#b#c'^#c#o&dR'cUnP!Q![&d!c!}&d#R#S&d#T#W&d#W#X'u#X#o&dR'|SvQnP!Q![&d!c!}&d#R#S&d#T#o&d~(_TnP!Q![&d!c!}&d#R#S&d#T#U(n#U#o&d~(sUnP!Q![&d!c!}&d#R#S&d#T#`&d#`#a)V#a#o&d~)[UnP!Q![&d!c!}&d#R#S&d#T#g&d#g#h)n#h#o&d~)sUnP!Q![&d!c!}&d#R#S&d#T#X&d#X#Y*V#Y#o&d~*^SU~nP!Q![&d!c!}&d#R#S&d#T#o&d~*oUnP!Q![&d!c!}&d#R#S&d#T#Y&d#Y#Z+R#Z#o&d~+YS`~nP!Q![&d!c!}&d#R#S&d#T#o&dR+kUnP!Q![&d!c!}&d#R#S&d#T#f&d#f#g+}#g#o&dR,USwQnP!Q![&d!c!}&d#R#S&d#T#o&d~,gUnP!Q![&d!c!}&d#R#S&d#T#f&d#f#g,y#g#o&d~-OUnP!Q![&d!c!}&d#R#S&d#T#i&d#i#j-b#j#o&d~-gUnP!Q![&d!c!}&d#R#S&d#T#X&d#X#Y-y#Y#o&d~.QST~nP!Q![&d!c!}&d#R#S&d#T#o&d",
195
- tokenizers: [0, 1],
196
- topRules: { "ColumnDefinitionExpression": [0, 1] },
197
- tokenPrec: 375
198
- });
199
-
200
- // src/column-expression-input/column-language-parser/ColumnExpressionLanguage.ts
201
- var columnExpressionLanguage = import_vuu_codemirror.LRLanguage.define({
202
- name: "VuuColumnExpression",
203
- parser: parser.configure({
204
- props: [
205
- (0, import_vuu_codemirror.styleTags)({
206
- Function: import_vuu_codemirror.tags.variableName,
207
- String: import_vuu_codemirror.tags.string,
208
- Or: import_vuu_codemirror.tags.emphasis,
209
- Operator: import_vuu_codemirror.tags.operator
210
- })
211
- ]
212
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
213
- })
214
- });
215
- var columnExpressionLanguageSupport = () => {
216
- return new import_vuu_codemirror.LanguageSupport(
217
- columnExpressionLanguage
218
- /*, [exampleCompletion]*/
219
- );
220
- };
221
-
222
- // src/column-expression-input/column-language-parser/ColumnExpressionTreeWalker.ts
223
- var LiteralExpressionImpl = class {
224
- constructor(value) {
225
- this.value = value;
226
- switch (typeof value) {
227
- case "boolean":
228
- this.type = "booleanLiteralExpression";
229
- break;
230
- case "number":
231
- this.type = "numericLiteralExpression";
232
- break;
233
- default:
234
- this.type = "stringLiteralExpression";
235
- }
236
- }
237
- toJSON() {
238
- return {
239
- type: this.type,
240
- value: this.value
241
- };
242
- }
243
- };
244
- var ColumnExpressionImpl = class {
245
- constructor(columnName) {
246
- this.type = "colExpression";
247
- this.column = columnName;
248
- }
249
- toJSON() {
250
- return {
251
- type: this.type,
252
- column: this.column
253
- };
254
- }
255
- };
256
- var _expressions, _op;
257
- var ArithmeticExpressionImpl = class {
258
- constructor(op = "unknown") {
259
- __privateAdd(this, _expressions, [
260
- { type: "unknown" },
261
- { type: "unknown" }
262
- ]);
263
- __privateAdd(this, _op, void 0);
264
- this.type = "arithmeticExpression";
265
- __privateSet(this, _op, op);
266
- }
267
- get op() {
268
- return __privateGet(this, _op);
269
- }
270
- set op(op) {
271
- __privateSet(this, _op, op);
272
- }
273
- get expressions() {
274
- return __privateGet(this, _expressions);
275
- }
276
- toJSON() {
277
- return {
278
- type: this.type,
279
- op: __privateGet(this, _op),
280
- expressions: __privateGet(this, _expressions)
281
- };
282
- }
283
- };
284
- _expressions = new WeakMap();
285
- _op = new WeakMap();
286
- var _expressions2;
287
- var CallExpressionImpl = class {
288
- constructor(functionName) {
289
- __privateAdd(this, _expressions2, []);
290
- this.type = "callExpression";
291
- this.functionName = functionName;
292
- }
293
- get expressions() {
294
- return __privateGet(this, _expressions2);
295
- }
296
- get arguments() {
297
- return __privateGet(this, _expressions2);
298
- }
299
- toJSON() {
300
- return {
301
- type: this.type,
302
- functionName: this.functionName,
303
- arguments: __privateGet(this, _expressions2).map((e) => {
304
- var _a;
305
- return (_a = e.toJSON) == null ? void 0 : _a.call(e);
306
- })
307
- };
308
- }
309
- };
310
- _expressions2 = new WeakMap();
311
- var _expressions3, _op2;
312
- var RelationalExpressionImpl = class {
313
- constructor() {
314
- __privateAdd(this, _expressions3, [
315
- { type: "unknown" },
316
- { type: "unknown" }
317
- ]);
318
- __privateAdd(this, _op2, "unknown");
319
- this.type = "relationalExpression";
320
- }
321
- get op() {
322
- return __privateGet(this, _op2);
323
- }
324
- set op(op) {
325
- __privateSet(this, _op2, op);
326
- }
327
- get expressions() {
328
- return __privateGet(this, _expressions3);
329
- }
330
- toJSON() {
331
- return {
332
- type: this.type,
333
- op: __privateGet(this, _op2),
334
- expressions: __privateGet(this, _expressions3)
335
- };
336
- }
337
- };
338
- _expressions3 = new WeakMap();
339
- _op2 = new WeakMap();
340
- var _expressions4, _op3;
341
- var BooleanConditionImp = class {
342
- constructor(booleanOperator) {
343
- __privateAdd(this, _expressions4, [
344
- { type: "unknown" },
345
- { type: "unknown" }
346
- ]);
347
- __privateAdd(this, _op3, void 0);
348
- this.type = "booleanCondition";
349
- __privateSet(this, _op3, booleanOperator);
350
- }
351
- get op() {
352
- return __privateGet(this, _op3);
353
- }
354
- get expressions() {
355
- return __privateGet(this, _expressions4);
356
- }
357
- toJSON() {
358
- return {
359
- type: this.type,
360
- op: __privateGet(this, _op3),
361
- expressions: __privateGet(this, _expressions4).map((e) => {
362
- var _a;
363
- return (_a = e.toJSON) == null ? void 0 : _a.call(e);
364
- })
365
- };
366
- }
367
- };
368
- _expressions4 = new WeakMap();
369
- _op3 = new WeakMap();
370
- var _expressions5;
371
- var ConditionalExpressionImpl = class {
372
- constructor(booleanOperator) {
373
- __privateAdd(this, _expressions5, void 0);
374
- this.type = "conditionalExpression";
375
- __privateSet(this, _expressions5, [
376
- booleanOperator ? new BooleanConditionImp(booleanOperator) : new RelationalExpressionImpl(),
377
- { type: "unknown" },
378
- { type: "unknown" }
379
- ]);
380
- }
381
- get expressions() {
382
- return __privateGet(this, _expressions5);
383
- }
384
- get condition() {
385
- return __privateGet(this, _expressions5)[0];
386
- }
387
- get truthyExpression() {
388
- return __privateGet(this, _expressions5)[1];
389
- }
390
- set truthyExpression(expression) {
391
- __privateGet(this, _expressions5)[1] = expression;
392
- }
393
- get falsyExpression() {
394
- return __privateGet(this, _expressions5)[2];
395
- }
396
- set falsyExpression(expression) {
397
- __privateGet(this, _expressions5)[2] = expression;
398
- }
399
- toJSON() {
400
- var _a, _b, _c, _d, _e;
401
- return {
402
- type: this.type,
403
- condition: (_b = (_a = this.condition).toJSON) == null ? void 0 : _b.call(_a),
404
- truthyExpression: this.truthyExpression,
405
- falsyExpression: (_e = (_d = (_c = this.falsyExpression) == null ? void 0 : _c.toJSON) == null ? void 0 : _d.call(_c)) != null ? _e : this.falsyExpression
406
- };
407
- }
408
- };
409
- _expressions5 = new WeakMap();
410
- var isUnknown = (e) => e.type === "unknown";
411
- var isArithmeticExpression = (expression) => expression.type === "arithmeticExpression";
412
- var isCallExpression = (expression) => expression.type === "callExpression";
413
- var isConditionalExpression = (expression) => expression.type === "conditionalExpression";
414
- var isCondition = (expression) => expression.type === "relationalExpression" || expression.type === "booleanCondition";
415
- var isBooleanCondition = (expression) => expression.type === "booleanCondition";
416
- var isRelationalExpression = (expression) => (expression == null ? void 0 : expression.type) === "relationalExpression";
417
- var firstIncompleteExpression = (expression) => {
418
- if (isUnknown(expression)) {
419
- return expression;
420
- } else if (isRelationalExpression(expression)) {
421
- const [operand1, operand2] = expression.expressions;
422
- if (expressionIsIncomplete(operand1)) {
423
- return firstIncompleteExpression(operand1);
424
- } else if (expression.op === "unknown") {
425
- return expression;
426
- } else if (expressionIsIncomplete(operand2)) {
427
- return firstIncompleteExpression(operand2);
428
- }
429
- } else if (isCondition(expression)) {
430
- const { expressions = [] } = expression;
431
- for (const e of expressions) {
432
- if (expressionIsIncomplete(e)) {
433
- return firstIncompleteExpression(e);
434
- }
435
- }
436
- } else if (isConditionalExpression(expression)) {
437
- const { condition, truthyExpression, falsyExpression } = expression;
438
- if (expressionIsIncomplete(condition)) {
439
- return firstIncompleteExpression(condition);
440
- } else if (expressionIsIncomplete(truthyExpression)) {
441
- return firstIncompleteExpression(truthyExpression);
442
- } else if (expressionIsIncomplete(falsyExpression)) {
443
- return firstIncompleteExpression(falsyExpression);
444
- }
445
- } else if (isArithmeticExpression(expression)) {
446
- const { expressions = [] } = expression;
447
- for (const e of expressions) {
448
- if (expressionIsIncomplete(e)) {
449
- return firstIncompleteExpression(e);
450
- }
451
- }
452
- }
453
- };
454
- var replaceUnknownExpression = (incompleteExpression, unknownExpression, expression) => {
455
- const { expressions = [] } = incompleteExpression;
456
- if (expressions.includes(unknownExpression)) {
457
- const pos = expressions.indexOf(unknownExpression);
458
- expressions.splice(pos, 1, expression);
459
- return true;
460
- } else {
461
- for (const e of expressions) {
462
- if (replaceUnknownExpression(e, unknownExpression, expression)) {
463
- return true;
464
- }
465
- }
466
- }
467
- return false;
468
- };
469
- var expressionIsIncomplete = (expression) => {
470
- if (isUnknown(expression)) {
471
- return true;
472
- } else if (isConditionalExpression(expression)) {
473
- return expressionIsIncomplete(expression.condition) || expressionIsIncomplete(expression.truthyExpression) || expressionIsIncomplete(expression.falsyExpression);
474
- } else if (isRelationalExpression(expression) || isBooleanCondition(expression)) {
475
- return expression.op === void 0 || expression.expressions.some((e) => expressionIsIncomplete(e));
476
- }
477
- return false;
478
- };
479
- var addExpression = (expression, subExpression) => {
480
- const targetExpression = firstIncompleteExpression(expression);
481
- if (targetExpression) {
482
- if (targetExpression.expressions) {
483
- targetExpression.expressions.push(subExpression);
484
- } else {
485
- console.warn("don't know how to treat targetExpression");
486
- }
487
- } else {
488
- console.error("no target expression found");
489
- }
490
- };
491
- var _expression, _callStack;
492
- var ColumnExpression = class {
493
- constructor() {
494
- __privateAdd(this, _expression, void 0);
495
- __privateAdd(this, _callStack, []);
496
- }
497
- setCondition(booleanOperator) {
498
- if (__privateGet(this, _expression) === void 0) {
499
- this.addExpression(new ConditionalExpressionImpl(booleanOperator));
500
- } else if (isConditionalExpression(__privateGet(this, _expression))) {
501
- if (expressionIsIncomplete(__privateGet(this, _expression).condition)) {
502
- const condition = booleanOperator ? new BooleanConditionImp(booleanOperator) : new RelationalExpressionImpl();
503
- this.addExpression(condition);
504
- } else if (isUnknown(__privateGet(this, _expression).truthyExpression)) {
505
- __privateGet(this, _expression).truthyExpression = new ConditionalExpressionImpl(
506
- booleanOperator
507
- );
508
- } else if (expressionIsIncomplete(__privateGet(this, _expression).truthyExpression)) {
509
- const condition = booleanOperator ? new BooleanConditionImp(booleanOperator) : new RelationalExpressionImpl();
510
- this.addExpression(condition);
511
- } else if (isUnknown(__privateGet(this, _expression).falsyExpression)) {
512
- __privateGet(this, _expression).falsyExpression = new ConditionalExpressionImpl(
513
- booleanOperator
514
- );
515
- } else if (expressionIsIncomplete(__privateGet(this, _expression).falsyExpression)) {
516
- const condition = booleanOperator ? new BooleanConditionImp(booleanOperator) : new RelationalExpressionImpl();
517
- this.addExpression(condition);
518
- }
519
- } else {
520
- console.error("setCondition called unexpectedly");
521
- }
522
- }
523
- addExpression(expression) {
524
- if (__privateGet(this, _callStack).length > 0) {
525
- const currentCallExpression = __privateGet(this, _callStack).at(-1);
526
- currentCallExpression == null ? void 0 : currentCallExpression.arguments.push(expression);
527
- } else if (__privateGet(this, _expression) === void 0) {
528
- __privateSet(this, _expression, expression);
529
- } else if (isArithmeticExpression(__privateGet(this, _expression))) {
530
- const targetExpression = firstIncompleteExpression(__privateGet(this, _expression));
531
- if (targetExpression && isUnknown(targetExpression)) {
532
- replaceUnknownExpression(
533
- __privateGet(this, _expression),
534
- targetExpression,
535
- expression
536
- );
537
- }
538
- } else if (isConditionalExpression(__privateGet(this, _expression))) {
539
- if (expressionIsIncomplete(__privateGet(this, _expression))) {
540
- const targetExpression = firstIncompleteExpression(__privateGet(this, _expression));
541
- if (targetExpression && isUnknown(targetExpression)) {
542
- replaceUnknownExpression(
543
- __privateGet(this, _expression),
544
- targetExpression,
545
- expression
546
- );
547
- } else if (targetExpression) {
548
- addExpression(targetExpression, expression);
549
- }
550
- }
551
- }
552
- }
553
- setFunction(functionName) {
554
- const callExpression = new CallExpressionImpl(functionName);
555
- this.addExpression(callExpression);
556
- __privateGet(this, _callStack).push(callExpression);
557
- }
558
- setColumn(columnName) {
559
- this.addExpression(new ColumnExpressionImpl(columnName));
560
- }
561
- setArithmeticOp(value) {
562
- const op = value;
563
- const expression = __privateGet(this, _expression);
564
- if (isArithmeticExpression(expression)) {
565
- expression.op = op;
566
- }
567
- }
568
- setRelationalOperator(value) {
569
- const op = value;
570
- if (__privateGet(this, _expression) && isConditionalExpression(__privateGet(this, _expression))) {
571
- const targetExpression = firstIncompleteExpression(__privateGet(this, _expression));
572
- if (isRelationalExpression(targetExpression)) {
573
- targetExpression.op = op;
574
- } else {
575
- console.error(`no target expression found (op = ${value})`);
576
- }
577
- }
578
- }
579
- setValue(value) {
580
- const literalExpression = new LiteralExpressionImpl(value);
581
- if (__privateGet(this, _expression) === void 0) {
582
- __privateSet(this, _expression, literalExpression);
583
- } else if (isArithmeticExpression(__privateGet(this, _expression))) {
584
- this.addExpression(literalExpression);
585
- } else if (isCallExpression(__privateGet(this, _expression))) {
586
- __privateGet(this, _expression).arguments.push(literalExpression);
587
- } else if (isConditionalExpression(__privateGet(this, _expression))) {
588
- if (expressionIsIncomplete(__privateGet(this, _expression))) {
589
- const targetExpression = firstIncompleteExpression(__privateGet(this, _expression));
590
- if (targetExpression && isUnknown(targetExpression)) {
591
- replaceUnknownExpression(
592
- __privateGet(this, _expression),
593
- targetExpression,
594
- literalExpression
595
- );
596
- } else if (targetExpression) {
597
- addExpression(targetExpression, literalExpression);
598
- }
599
- } else {
600
- console.log("what do we do with value, in a complete expression");
601
- }
602
- }
603
- }
604
- closeBrace() {
605
- __privateGet(this, _callStack).pop();
606
- }
607
- get expression() {
608
- return __privateGet(this, _expression);
609
- }
610
- toJSON() {
611
- var _a;
612
- return (_a = __privateGet(this, _expression)) == null ? void 0 : _a.toJSON();
613
- }
614
- };
615
- _expression = new WeakMap();
616
- _callStack = new WeakMap();
617
- var walkTree = (tree, source) => {
618
- const columnExpression = new ColumnExpression();
619
- const cursor = tree.cursor();
620
- do {
621
- const { name, from, to } = cursor;
622
- switch (name) {
623
- case "AndCondition":
624
- columnExpression.setCondition("and");
625
- break;
626
- case "OrCondition":
627
- columnExpression.setCondition("or");
628
- break;
629
- case "RelationalExpression":
630
- columnExpression.setCondition();
631
- break;
632
- case "ArithmeticExpression":
633
- columnExpression.addExpression(new ArithmeticExpressionImpl());
634
- break;
635
- case "Column":
636
- {
637
- const columnName = source.substring(from, to);
638
- columnExpression.setColumn(columnName);
639
- }
640
- break;
641
- case "Function":
642
- {
643
- const functionName = source.substring(from, to);
644
- columnExpression.setFunction(functionName);
645
- }
646
- break;
647
- case "Times":
648
- case "Divide":
649
- case "Plus":
650
- case "Minus":
651
- {
652
- const op = source.substring(from, to);
653
- columnExpression.setArithmeticOp(op);
654
- }
655
- break;
656
- case "RelationalOperator":
657
- {
658
- const op = source.substring(from, to);
659
- columnExpression.setRelationalOperator(op);
660
- }
661
- break;
662
- case "False":
663
- case "True":
664
- {
665
- const value = source.substring(from, to);
666
- columnExpression.setValue(value === "true" ? true : false);
667
- }
668
- break;
669
- case "String":
670
- columnExpression.setValue(source.substring(from + 1, to - 1));
671
- break;
672
- case "Number":
673
- columnExpression.setValue(parseFloat(source.substring(from, to)));
674
- break;
675
- case "CloseBrace":
676
- columnExpression.closeBrace();
677
- break;
678
- default:
679
- }
680
- } while (cursor.next());
681
- return columnExpression.toJSON();
682
- };
683
-
684
- // src/column-expression-input/column-language-parser/column-expression-parse-utils.ts
685
- var strictParser = parser.configure({ strict: true });
686
- var RelationalOperands = ["Number", "String"];
687
- var ColumnNamedTerms = [
688
- ...RelationalOperands,
689
- "AndCondition",
690
- "ArithmeticExpression",
691
- "BooleanOperator",
692
- "RelationalOperatorOperator",
693
- "CallExpression",
694
- "CloseBrace",
695
- "Column",
696
- "Comma",
697
- "ConditionalExpression",
698
- "Divide",
699
- "Equal",
700
- "If",
701
- "Minus",
702
- "OpenBrace",
703
- "OrCondition",
704
- "ParenthesizedExpression",
705
- "Plus",
706
- "RelationalExpression",
707
- "RelationalOperator",
708
- "Times"
709
- ];
710
- var isCompleteExpression = (src) => {
711
- try {
712
- strictParser.parse(src);
713
- return true;
714
- } catch (err) {
715
- return false;
716
- }
717
- };
718
- var lastNamedChild = (node) => {
719
- let { lastChild } = node;
720
- while (lastChild && !ColumnNamedTerms.includes(lastChild.name)) {
721
- lastChild = lastChild.prevSibling;
722
- console.log(lastChild == null ? void 0 : lastChild.name);
723
- }
724
- return lastChild;
725
- };
726
- var isCompleteRelationalExpression = (node) => {
727
- if ((node == null ? void 0 : node.name) === "RelationalExpression") {
728
- const { firstChild } = node;
729
- const lastChild = lastNamedChild(node);
730
- if ((firstChild == null ? void 0 : firstChild.name) === "Column" && typeof (lastChild == null ? void 0 : lastChild.name) === "string" && RelationalOperands.includes(lastChild.name)) {
731
- return true;
732
- }
733
- }
734
- return false;
735
- };
736
-
737
- // src/column-expression-input/highlighting.ts
738
- var import_vuu_codemirror2 = require("@vuu-ui/vuu-codemirror");
739
- var myHighlightStyle = import_vuu_codemirror2.HighlightStyle.define([
740
- { tag: import_vuu_codemirror2.tags.variableName, color: "var(--vuuFilterEditor-variableColor)" },
741
- { tag: import_vuu_codemirror2.tags.comment, color: "green", fontStyle: "italic" }
742
- ]);
743
- var vuuHighlighting = (0, import_vuu_codemirror2.syntaxHighlighting)(myHighlightStyle);
744
-
745
- // src/column-expression-input/theme.ts
746
- var import_vuu_codemirror3 = require("@vuu-ui/vuu-codemirror");
747
- var vuuTheme = import_vuu_codemirror3.EditorView.theme(
748
- {
749
- "&": {
750
- border: "solid 1px var(--salt-container-primary-borderColor)",
751
- color: "var(--vuuFilterEditor-color)",
752
- backgroundColor: "var(--vuuFilterEditor-background)"
753
- },
754
- ".cm-content": {
755
- caretColor: "var(--vuuFilterEditor-cursorColor)"
756
- },
757
- "&.cm-focused .cm-cursor": {
758
- borderLeftColor: "var(--vuuFilterEditor-cursorColor)"
759
- },
760
- "&.cm-focused .cm-selectionBackground, ::selection": {
761
- backgroundColor: "var(--vuuFilterEditor-selectionBackground)"
762
- },
763
- ".cm-selectionBackground, ::selection": {
764
- backgroundColor: "var(--vuuFilterEditor-selectionBackground)"
765
- },
766
- ".cm-scroller": {
767
- fontFamily: "var(--vuuFilterEditor-fontFamily)"
768
- },
769
- ".cm-tooltip": {
770
- background: "var(--vuuFilterEditor-tooltipBackground)",
771
- border: "var(--vuuFilterEditor-tooltipBorder)",
772
- boxShadow: "var(--vuuFilterEditor-tooltipElevation)",
773
- "&.cm-tooltip-autocomplete > ul": {
774
- fontFamily: "var(--vuuFilterEditor-fontFamily)",
775
- fontSize: "var(--vuuFilterEditor-fontSize)",
776
- maxHeight: "240px"
777
- },
778
- "&.cm-tooltip-autocomplete > ul > li": {
779
- height: "var(--vuuFilterEditor-suggestion-height)",
780
- padding: "0 3px",
781
- lineHeight: "var(--vuuFilterEditor-suggestion-height)"
782
- },
783
- "&.cm-tooltip-autocomplete li[aria-selected]": {
784
- background: "var(--vuuFilterEditor-suggestion-selectedBackground)",
785
- color: "var(--vuuFilterEditor-suggestion-selectedColor)"
786
- },
787
- "&.cm-tooltip-autocomplete li .cm-completionDetail": {
788
- color: "var(--vuuFilterEditor-suggestion-detailColor)"
789
- }
790
- }
791
- },
792
- { dark: false }
793
- );
794
-
795
- // src/column-expression-input/useColumnAutoComplete.ts
796
- var import_vuu_codemirror4 = require("@vuu-ui/vuu-codemirror");
797
- var import_react2 = require("react");
798
- var applyPrefix = (completions, prefix) => prefix ? completions.map((completion) => {
799
- var _a;
800
- return {
801
- ...completion,
802
- apply: typeof completion.apply === "function" ? completion.apply : `${prefix}${(_a = completion.apply) != null ? _a : completion.label}`
803
- };
804
- }) : completions;
805
- var isOperator = (node) => node === void 0 ? false : ["Times", "Divide", "Plus", "Minus"].includes(node.name);
806
- var getLastChild = (node, context) => {
807
- var _a;
808
- let { lastChild: childNode } = node;
809
- const { pos } = context;
810
- while (childNode) {
811
- const isBeforeCursor = childNode.from < pos;
812
- if (isBeforeCursor && ColumnNamedTerms.includes(childNode.name)) {
813
- if (childNode.name === "ParenthesizedExpression") {
814
- const expression = (_a = childNode.firstChild) == null ? void 0 : _a.nextSibling;
815
- if (expression) {
816
- childNode = expression;
817
- }
818
- }
819
- return childNode;
820
- } else {
821
- childNode = childNode.prevSibling;
822
- }
823
- }
824
- };
825
- var getFunctionName = (node, state) => {
826
- var _a;
827
- if (node.name === "ArgList") {
828
- const functionNode = node.prevSibling;
829
- if (functionNode) {
830
- return (0, import_vuu_codemirror4.getValue)(functionNode, state);
831
- }
832
- } else if (node.name === "OpenBrace") {
833
- const maybeFunction = (_a = node.parent) == null ? void 0 : _a.prevSibling;
834
- if ((maybeFunction == null ? void 0 : maybeFunction.name) === "Function") {
835
- return (0, import_vuu_codemirror4.getValue)(maybeFunction, state);
836
- }
837
- }
838
- };
839
- var getRelationalOperator = (node, state) => {
840
- if (node.name === "RelationalExpression") {
841
- const lastNode = lastNamedChild(node);
842
- if ((lastNode == null ? void 0 : lastNode.name) === "RelationalOperator") {
843
- return (0, import_vuu_codemirror4.getValue)(lastNode, state);
844
- }
845
- } else {
846
- const prevNode = node.prevSibling;
847
- if ((prevNode == null ? void 0 : prevNode.name) === "RelationalOperator") {
848
- return (0, import_vuu_codemirror4.getValue)(prevNode, state);
849
- }
850
- }
851
- };
852
- var getColumnName = (node, state) => {
853
- var _a;
854
- if (node.name === "RelationalExpression") {
855
- if (((_a = node.firstChild) == null ? void 0 : _a.name) === "Column") {
856
- return (0, import_vuu_codemirror4.getValue)(node.firstChild, state);
857
- }
858
- } else {
859
- const prevNode = node.prevSibling;
860
- if ((prevNode == null ? void 0 : prevNode.name) === "Column") {
861
- return (0, import_vuu_codemirror4.getValue)(prevNode, state);
862
- } else if ((prevNode == null ? void 0 : prevNode.name) === "RelationalOperator") {
863
- return getColumnName(prevNode, state);
864
- }
865
- }
866
- };
867
- var makeSuggestions = async (context, suggestionProvider, suggestionType, optionalArgs = {}) => {
868
- const options = await suggestionProvider.getSuggestions(
869
- suggestionType,
870
- optionalArgs
871
- );
872
- const { startsWith = "" } = optionalArgs;
873
- return { from: context.pos - startsWith.length, options };
874
- };
875
- var handleConditionalExpression = (node, context, suggestionProvider, maybeComplete, onSubmit) => {
876
- const lastChild = getLastChild(node, context);
877
- console.log(`conditional expression last child ${lastChild == null ? void 0 : lastChild.name}`);
878
- switch (lastChild == null ? void 0 : lastChild.name) {
879
- case "If":
880
- return makeSuggestions(context, suggestionProvider, "expression", {
881
- prefix: "( "
882
- });
883
- case "OpenBrace":
884
- return makeSuggestions(context, suggestionProvider, "expression");
885
- case "Condition":
886
- return makeSuggestions(context, suggestionProvider, "expression", {
887
- prefix: ", "
888
- });
889
- case "CloseBrace":
890
- if (maybeComplete) {
891
- const options = [
892
- {
893
- apply: () => {
894
- onSubmit == null ? void 0 : onSubmit();
895
- },
896
- label: "Save Expression",
897
- boost: 10
898
- }
899
- ];
900
- return { from: context.pos, options };
901
- }
902
- }
903
- };
904
- var promptToSave = (context, onSubmit) => {
905
- const options = [
906
- {
907
- apply: () => {
908
- onSubmit == null ? void 0 : onSubmit();
909
- },
910
- label: "Save Expression",
911
- boost: 10
912
- }
913
- ];
914
- return { from: context.pos, options };
915
- };
916
- var useColumnAutoComplete = (suggestionProvider, onSubmit) => {
917
- const makeSuggestions2 = (0, import_react2.useCallback)(
918
- async (context, suggestionType, optionalArgs = {}) => {
919
- const options = await suggestionProvider.getSuggestions(
920
- suggestionType,
921
- optionalArgs
922
- );
923
- const { startsWith = "" } = optionalArgs;
924
- return { from: context.pos - startsWith.length, options };
925
- },
926
- [suggestionProvider]
927
- );
928
- return (0, import_react2.useCallback)(
929
- async (context) => {
930
- var _a, _b;
931
- const { state, pos } = context;
932
- const word = (_a = context.matchBefore(/\w*/)) != null ? _a : {
933
- from: 0,
934
- to: 0,
935
- text: void 0
936
- };
937
- const tree = (0, import_vuu_codemirror4.syntaxTree)(state);
938
- const nodeBefore = tree.resolveInner(pos, -1);
939
- const text = state.doc.toString();
940
- const maybeComplete = isCompleteExpression(text);
941
- console.log({ nodeBeforeName: nodeBefore.name });
942
- switch (nodeBefore.name) {
943
- case "If": {
944
- console.log(`conditional expression If`);
945
- return makeSuggestions2(context, "expression", { prefix: "( " });
946
- }
947
- case "Condition":
948
- {
949
- const lastChild = getLastChild(nodeBefore, context);
950
- if ((lastChild == null ? void 0 : lastChild.name) === "Column") {
951
- const prevChild = (0, import_vuu_codemirror4.getPreviousNode)(lastChild);
952
- if ((prevChild == null ? void 0 : prevChild.name) !== "RelationalOperator") {
953
- return makeSuggestions2(context, "condition-operator", {
954
- columnName: (0, import_vuu_codemirror4.getValue)(lastChild, state)
955
- });
956
- }
957
- console.log(
958
- `Condition last child Column, prev child ${prevChild == null ? void 0 : prevChild.name}`
959
- );
960
- } else if ((lastChild == null ? void 0 : lastChild.name) === "RelationalOperator") {
961
- return makeSuggestions2(context, "expression");
962
- }
963
- console.log(`condition last child ${lastChild == null ? void 0 : lastChild.name}`);
964
- }
965
- break;
966
- case "ConditionalExpression":
967
- return handleConditionalExpression(
968
- nodeBefore,
969
- context,
970
- suggestionProvider
971
- );
972
- case "RelationalExpression":
973
- {
974
- if (isCompleteRelationalExpression(nodeBefore)) {
975
- return {
976
- from: context.pos,
977
- options: import_vuu_codemirror4.booleanJoinSuggestions.concat({
978
- label: ", <truthy expression>, <falsy expression>",
979
- apply: ", "
980
- })
981
- };
982
- } else {
983
- const operator = getRelationalOperator(nodeBefore, state);
984
- const columnName = getColumnName(nodeBefore, state);
985
- if (!operator) {
986
- const options = await suggestionProvider.getSuggestions(
987
- "condition-operator",
988
- {
989
- columnName
990
- }
991
- );
992
- return { from: context.pos, options };
993
- } else {
994
- return makeSuggestions2(context, "expression");
995
- }
996
- }
997
- }
998
- break;
999
- case "RelationalOperator":
1000
- return makeSuggestions2(context, "expression");
1001
- case "String":
1002
- {
1003
- const operator = getRelationalOperator(
1004
- nodeBefore,
1005
- state
1006
- );
1007
- const columnName = getColumnName(nodeBefore, state);
1008
- const { from, to } = nodeBefore;
1009
- if (to - from === 2 && context.pos === from + 1) {
1010
- if (columnName && operator) {
1011
- return makeSuggestions2(context, "columnValue", {
1012
- columnName,
1013
- operator,
1014
- startsWith: word.text
1015
- });
1016
- }
1017
- } else if (to - from > 2 && context.pos === to) {
1018
- return makeSuggestions2(context, "expression", {
1019
- prefix: ", "
1020
- });
1021
- }
1022
- console.log(
1023
- `we have a string, column is ${columnName} ${from} ${to}`
1024
- );
1025
- }
1026
- break;
1027
- case "ArithmeticExpression":
1028
- {
1029
- const lastChild = getLastChild(nodeBefore, context);
1030
- if ((lastChild == null ? void 0 : lastChild.name) === "Column") {
1031
- return makeSuggestions2(context, "expression");
1032
- } else if (isOperator(lastChild)) {
1033
- const operator = lastChild.name;
1034
- return makeSuggestions2(context, "column", { operator });
1035
- }
1036
- }
1037
- break;
1038
- case "OpenBrace":
1039
- {
1040
- const functionName = getFunctionName(nodeBefore, state);
1041
- return makeSuggestions2(context, "expression", { functionName });
1042
- }
1043
- break;
1044
- case "ArgList": {
1045
- const functionName = getFunctionName(nodeBefore, state);
1046
- const lastArgument = getLastChild(nodeBefore, context);
1047
- const prefix = (lastArgument == null ? void 0 : lastArgument.name) === "OpenBrace" ? void 0 : ",";
1048
- let options = await suggestionProvider.getSuggestions("expression", {
1049
- functionName
1050
- });
1051
- options = prefix ? applyPrefix(options, ", ") : options;
1052
- if ((lastArgument == null ? void 0 : lastArgument.name) !== "OpenBrace" && (lastArgument == null ? void 0 : lastArgument.name) !== "Comma") {
1053
- options = [
1054
- {
1055
- apply: ") ",
1056
- boost: 10,
1057
- label: "Done - no more arguments"
1058
- }
1059
- ].concat(options);
1060
- }
1061
- return { from: context.pos, options };
1062
- }
1063
- case "Equal":
1064
- if (text.trim() === "=") {
1065
- return makeSuggestions2(context, "expression");
1066
- }
1067
- break;
1068
- case "ParenthesizedExpression":
1069
- case "ColumnDefinitionExpression":
1070
- if (context.pos === 0) {
1071
- return makeSuggestions2(context, "expression");
1072
- } else {
1073
- const lastChild = getLastChild(nodeBefore, context);
1074
- if ((lastChild == null ? void 0 : lastChild.name) === "Column") {
1075
- if (maybeComplete) {
1076
- const options = [
1077
- {
1078
- apply: () => {
1079
- onSubmit.current();
1080
- },
1081
- label: "Save Expression",
1082
- boost: 10
1083
- }
1084
- ];
1085
- const columnName = (0, import_vuu_codemirror4.getValue)(lastChild, state);
1086
- const columnOptions = await suggestionProvider.getSuggestions("operator", {
1087
- columnName
1088
- });
1089
- return {
1090
- from: context.pos,
1091
- options: options.concat(columnOptions)
1092
- };
1093
- }
1094
- } else if ((lastChild == null ? void 0 : lastChild.name) === "CallExpression") {
1095
- if (maybeComplete) {
1096
- const options = [
1097
- {
1098
- apply: () => {
1099
- onSubmit.current();
1100
- },
1101
- label: "Save Expression",
1102
- boost: 10
1103
- }
1104
- ];
1105
- return {
1106
- from: context.pos,
1107
- options
1108
- };
1109
- }
1110
- } else if ((lastChild == null ? void 0 : lastChild.name) === "ArithmeticExpression") {
1111
- if (maybeComplete) {
1112
- let options = [
1113
- {
1114
- apply: () => {
1115
- onSubmit.current();
1116
- },
1117
- label: "Save Expression",
1118
- boost: 10
1119
- }
1120
- ];
1121
- const lastExpressionChild = getLastChild(lastChild, context);
1122
- if ((lastExpressionChild == null ? void 0 : lastExpressionChild.name) === "Column") {
1123
- const columnName = (0, import_vuu_codemirror4.getValue)(lastExpressionChild, state);
1124
- const suggestions = await suggestionProvider.getSuggestions(
1125
- "operator",
1126
- { columnName }
1127
- );
1128
- options = options.concat(suggestions);
1129
- }
1130
- return {
1131
- from: context.pos,
1132
- options
1133
- };
1134
- }
1135
- } else if ((lastChild == null ? void 0 : lastChild.name) === "ConditionalExpression") {
1136
- return handleConditionalExpression(
1137
- lastChild,
1138
- context,
1139
- suggestionProvider,
1140
- maybeComplete,
1141
- onSubmit.current
1142
- );
1143
- }
1144
- break;
1145
- }
1146
- case "Column":
1147
- {
1148
- const isPartialMatch = await suggestionProvider.isPartialMatch(
1149
- "expression",
1150
- void 0,
1151
- word.text
1152
- );
1153
- if (isPartialMatch) {
1154
- return makeSuggestions2(context, "expression", {
1155
- startsWith: word.text
1156
- });
1157
- }
1158
- }
1159
- break;
1160
- case "Comma":
1161
- {
1162
- const parentNode = (0, import_vuu_codemirror4.getNamedParentNode)(nodeBefore);
1163
- if ((parentNode == null ? void 0 : parentNode.name) === "ConditionalExpression") {
1164
- return makeSuggestions2(context, "expression");
1165
- }
1166
- }
1167
- break;
1168
- case "CloseBrace":
1169
- {
1170
- const parentNode = (0, import_vuu_codemirror4.getNamedParentNode)(nodeBefore);
1171
- if ((parentNode == null ? void 0 : parentNode.name) === "ConditionalExpression") {
1172
- return handleConditionalExpression(
1173
- parentNode,
1174
- context,
1175
- suggestionProvider,
1176
- maybeComplete,
1177
- onSubmit.current
1178
- );
1179
- } else if ((parentNode == null ? void 0 : parentNode.name) === "ArgList") {
1180
- if (maybeComplete) {
1181
- return promptToSave(context, onSubmit.current);
1182
- }
1183
- }
1184
- console.log(
1185
- `does closebrace denote an ARgList or a parenthetised expression ? ${parentNode}`
1186
- );
1187
- }
1188
- break;
1189
- default: {
1190
- if (((_b = nodeBefore == null ? void 0 : nodeBefore.prevSibling) == null ? void 0 : _b.name) === "FilterClause") {
1191
- console.log("looks like we ight be a or|and operator");
1192
- }
1193
- }
1194
- }
1195
- },
1196
- [makeSuggestions2, onSubmit, suggestionProvider]
1197
- );
1198
- };
1199
-
1200
- // src/column-expression-input/useColumnExpressionEditor.ts
1201
- var getView = (ref) => {
1202
- if (ref.current == void 0) {
1203
- throw Error("EditorView not defined");
1204
- }
1205
- return ref.current;
1206
- };
1207
- var getOptionClass = () => {
1208
- return "vuuSuggestion";
1209
- };
1210
- var noop = () => console.log("noooop");
1211
- var hasExpressionType = (completion) => "expressionType" in completion;
1212
- var injectOptionContent = (completion) => {
1213
- if (hasExpressionType(completion)) {
1214
- const div = (0, import_vuu_utils4.createEl)("div", "expression-type-container");
1215
- const span = (0, import_vuu_utils4.createEl)("span", "expression-type", completion.expressionType);
1216
- div.appendChild(span);
1217
- return div;
1218
- } else {
1219
- return null;
1220
- }
1221
- };
1222
- var useColumnExpressionEditor = ({
1223
- onChange,
1224
- onSubmitExpression,
1225
- suggestionProvider
1226
- }) => {
1227
- const editorRef = (0, import_react3.useRef)(null);
1228
- const onSubmit = (0, import_react3.useRef)(noop);
1229
- const viewRef = (0, import_react3.useRef)();
1230
- const completionFn = useColumnAutoComplete(suggestionProvider, onSubmit);
1231
- const [createState, clearInput] = (0, import_react3.useMemo)(() => {
1232
- const parseExpression = () => {
1233
- const view = getView(viewRef);
1234
- const source = view.state.doc.toString();
1235
- const tree = (0, import_vuu_codemirror5.ensureSyntaxTree)(view.state, view.state.doc.length, 5e3);
1236
- if (tree) {
1237
- const expression = walkTree(tree, source);
1238
- return [source, expression];
1239
- } else {
1240
- return ["", void 0];
1241
- }
1242
- };
1243
- const clearInput2 = () => {
1244
- getView(viewRef).setState(createState2());
1245
- };
1246
- const submitExpressionAndClearInput = () => {
1247
- const [source, expression] = parseExpression();
1248
- onSubmitExpression == null ? void 0 : onSubmitExpression(source, expression);
1249
- clearInput2();
1250
- };
1251
- const submitFilter = (key) => {
1252
- return import_vuu_codemirror5.keymap.of([
1253
- {
1254
- key,
1255
- run() {
1256
- submitExpressionAndClearInput();
1257
- return true;
1258
- }
1259
- }
1260
- ]);
1261
- };
1262
- const showSuggestions = (key) => {
1263
- return import_vuu_codemirror5.keymap.of([
1264
- {
1265
- key,
1266
- run() {
1267
- (0, import_vuu_codemirror5.startCompletion)(getView(viewRef));
1268
- return true;
1269
- }
1270
- }
1271
- ]);
1272
- };
1273
- const createState2 = () => import_vuu_codemirror5.EditorState.create({
1274
- doc: "",
1275
- extensions: [
1276
- import_vuu_codemirror5.minimalSetup,
1277
- (0, import_vuu_codemirror5.autocompletion)({
1278
- addToOptions: [
1279
- {
1280
- render: injectOptionContent,
1281
- position: 70
1282
- }
1283
- ],
1284
- override: [completionFn],
1285
- optionClass: getOptionClass
1286
- }),
1287
- columnExpressionLanguageSupport(),
1288
- import_vuu_codemirror5.keymap.of(import_vuu_codemirror5.defaultKeymap),
1289
- submitFilter("Ctrl-Enter"),
1290
- showSuggestions("ArrowDown"),
1291
- import_vuu_codemirror5.EditorView.updateListener.of((v) => {
1292
- const view = getView(viewRef);
1293
- if (v.docChanged) {
1294
- (0, import_vuu_codemirror5.startCompletion)(view);
1295
- const source = view.state.doc.toString();
1296
- onChange == null ? void 0 : onChange(source, void 0);
1297
- }
1298
- }),
1299
- // Enforces single line view
1300
- // EditorState.transactionFilter.of((tr) =>
1301
- // tr.newDoc.lines > 1 ? [] : tr
1302
- // ),
1303
- vuuTheme,
1304
- vuuHighlighting
1305
- ]
1306
- });
1307
- onSubmit.current = () => {
1308
- submitExpressionAndClearInput();
1309
- setTimeout(() => {
1310
- getView(viewRef).focus();
1311
- }, 100);
1312
- };
1313
- return [createState2, clearInput2];
1314
- }, [completionFn, onChange, onSubmitExpression]);
1315
- (0, import_react3.useEffect)(() => {
1316
- if (!editorRef.current) {
1317
- throw Error("editor not in dom");
1318
- }
1319
- viewRef.current = new import_vuu_codemirror5.EditorView({
1320
- state: createState(),
1321
- parent: editorRef.current
1322
- });
1323
- return () => {
1324
- var _a;
1325
- (_a = viewRef.current) == null ? void 0 : _a.destroy();
1326
- };
1327
- }, [completionFn, createState]);
1328
- return { editorRef, clearInput };
1329
- };
1330
-
1331
- // src/column-expression-input/ColumnExpressionInput.tsx
1332
- var import_jsx_runtime3 = require("react/jsx-runtime");
1333
- var classBase3 = "vuuColumnExpressionInput";
1334
- var ColumnExpressionInput = ({
1335
- onChange,
1336
- onSubmitExpression,
1337
- suggestionProvider
1338
- }) => {
1339
- const { editorRef } = useColumnExpressionEditor({
1340
- onChange,
1341
- onSubmitExpression,
1342
- suggestionProvider
1343
- });
1344
- return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)("div", { className: `${classBase3}`, ref: editorRef });
1345
- };
1346
-
1347
- // src/column-expression-input/useColumnExpressionSuggestionProvider.ts
1348
- var import_vuu_codemirror6 = require("@vuu-ui/vuu-codemirror");
1349
- var import_vuu_data_react = require("@vuu-ui/vuu-data-react");
1350
- var import_vuu_utils6 = require("@vuu-ui/vuu-utils");
1351
- var import_react4 = require("react");
1352
-
1353
- // src/column-expression-input/column-function-descriptors.ts
1354
- var columnFunctionDescriptors = [
1355
- /**
1356
- * concatenate()
1357
- */
1358
- {
1359
- accepts: "string",
1360
- description: "Returns multiple string values as a single joined string. Arguments may be string literal values, string columns or other string expressions. Non string arguments may also be included, these will be converted to strings.",
1361
- example: {
1362
- expression: 'concatenate("example", "-test")',
1363
- result: '"example-test"'
1364
- },
1365
- name: "concatenate",
1366
- params: {
1367
- description: "( string, string, [ string* ] )"
1368
- },
1369
- type: "string"
1370
- },
1371
- /**
1372
- * contains()
1373
- */
1374
- {
1375
- accepts: ["string", "string"],
1376
- description: "Tests a string value to determine whether it contains a given substring. Accepts two arguments: source text and target substring. Returns true if <source text> contains one or more occurrences of <target subscring>",
1377
- example: {
1378
- expression: 'contains("Royal Bank of Scotland", "bank")',
1379
- result: "true"
1380
- },
1381
- name: "contains",
1382
- params: {
1383
- description: "( string )"
1384
- },
1385
- type: "boolean"
1386
- },
1387
- /**
1388
- * left()
1389
- */
1390
- {
1391
- accepts: ["string", "number"],
1392
- description: "Returns the leftmost <number> characters from <string>. First argument may be a string literal, string column or other string expression.",
1393
- example: {
1394
- expression: 'left("USD Benchmark Report", 3)',
1395
- result: '"USD"'
1396
- },
1397
- name: "left",
1398
- params: {
1399
- count: 2,
1400
- description: "( string, number )"
1401
- },
1402
- type: "string"
1403
- },
1404
- /**
1405
- * len()
1406
- */
1407
- {
1408
- accepts: "string",
1409
- description: "Returns the number of characters in <string>. Argument may be a string literal, string column or other string expression.",
1410
- example: {
1411
- expression: 'len("example")',
1412
- result: "7"
1413
- },
1414
- name: "len",
1415
- params: {
1416
- description: "(string)"
1417
- },
1418
- type: "number"
1419
- },
1420
- /**
1421
- * lower()
1422
- */
1423
- {
1424
- accepts: "string",
1425
- description: "Convert a string value to lowercase. Argument may be a string column or other string expression.",
1426
- example: {
1427
- expression: 'lower("examPLE")',
1428
- result: '"example"'
1429
- },
1430
- name: "lower",
1431
- params: {
1432
- description: "( string )"
1433
- },
1434
- type: "string"
1435
- },
1436
- /**
1437
- * upper()
1438
- */
1439
- {
1440
- accepts: "string",
1441
- description: "Convert a string value to uppercase. Argument may be a string column or other string expression.",
1442
- example: {
1443
- expression: 'upper("example")',
1444
- result: '"EXAMPLE"'
1445
- },
1446
- name: "upper",
1447
- params: {
1448
- description: "( string )"
1449
- },
1450
- type: "string"
1451
- },
1452
- /**
1453
- * right()
1454
- */
1455
- {
1456
- accepts: ["string", "number"],
1457
- description: "Returns the rightmost <number> characters from <string>. First argument may be a string literal, string column or other string expression.",
1458
- example: {
1459
- expression: "blah",
1460
- result: "blah"
1461
- },
1462
- name: "right",
1463
- params: {
1464
- description: "( string )"
1465
- },
1466
- type: "string"
1467
- },
1468
- /**
1469
- * replace()
1470
- */
1471
- {
1472
- accepts: ["string", "string", "string"],
1473
- description: "Replace characters within a string. Accepts three arguments: source text, text to replace and replacement text. Returns a copy of <source text> with any occurrences of <text to replace> replaced by <replacement text>",
1474
- example: {
1475
- expression: "blah",
1476
- result: "blah"
1477
- },
1478
- name: "replace",
1479
- params: {
1480
- description: "( string )"
1481
- },
1482
- type: "string"
1483
- },
1484
- /**
1485
- * text()
1486
- */
1487
- {
1488
- accepts: "number",
1489
- description: "Converts a number to a string.",
1490
- example: {
1491
- expression: "blah",
1492
- result: "blah"
1493
- },
1494
- name: "text",
1495
- params: {
1496
- description: "( string )"
1497
- },
1498
- type: "string"
1499
- },
1500
- /**
1501
- * starts()
1502
- */
1503
- {
1504
- accepts: "string",
1505
- description: "Tests a string value to determine whether it starts with a given substring. Accepts two arguments: source text and target substring. Returns true if <source text> starts with <target subscring>.",
1506
- example: {
1507
- expression: "blah",
1508
- result: "blah"
1509
- },
1510
- name: "starts",
1511
- params: {
1512
- description: "( string )"
1513
- },
1514
- type: "boolean"
1515
- },
1516
- /**
1517
- * starts()
1518
- */
1519
- {
1520
- accepts: "string",
1521
- description: "Tests a string value to determine whether it ends with a given substring. Accepts two arguments: source text and target substring. Returns true if <source text> ends with <target subscring>.",
1522
- example: {
1523
- expression: "blah",
1524
- result: "blah"
1525
- },
1526
- name: "ends",
1527
- params: {
1528
- description: "( string )"
1529
- },
1530
- type: "boolean"
1531
- },
1532
- {
1533
- accepts: "number",
1534
- description: "blah",
1535
- example: {
1536
- expression: "blah",
1537
- result: "blah"
1538
- },
1539
- name: "min",
1540
- params: {
1541
- description: "( string )"
1542
- },
1543
- type: "number"
1544
- },
1545
- {
1546
- accepts: "number",
1547
- description: "blah",
1548
- example: {
1549
- expression: "blah",
1550
- result: "blah"
1551
- },
1552
- name: "max",
1553
- params: {
1554
- description: "( string )"
1555
- },
1556
- type: "number"
1557
- },
1558
- {
1559
- accepts: "number",
1560
- description: "blah",
1561
- example: {
1562
- expression: "blah",
1563
- result: "blah"
1564
- },
1565
- name: "sum",
1566
- params: {
1567
- description: "( string )"
1568
- },
1569
- type: "number"
1570
- },
1571
- {
1572
- accepts: "number",
1573
- description: "blah",
1574
- example: {
1575
- expression: "blah",
1576
- result: "blah"
1577
- },
1578
- name: "round",
1579
- params: {
1580
- description: "( string )"
1581
- },
1582
- type: "number"
1583
- },
1584
- {
1585
- accepts: "any",
1586
- description: "blah",
1587
- example: {
1588
- expression: "blah",
1589
- result: "blah"
1590
- },
1591
- name: "or",
1592
- params: {
1593
- description: "( string )"
1594
- },
1595
- type: "boolean"
1596
- },
1597
- {
1598
- accepts: "any",
1599
- description: "blah",
1600
- example: {
1601
- expression: "blah",
1602
- result: "blah"
1603
- },
1604
- name: "and",
1605
- params: {
1606
- description: "( string )"
1607
- },
1608
- type: "boolean"
1609
- },
1610
- {
1611
- accepts: "any",
1612
- description: "Return one of two possible result values, depending on the evaluation of a filter expression. If <filterExpression> resolves to true, result is <expression1>, otherwise <expression2>. ",
1613
- example: {
1614
- expression: "blah",
1615
- result: "blah"
1616
- },
1617
- name: "if",
1618
- params: {
1619
- description: "( filterExpression, expression1, expression 2)"
1620
- },
1621
- type: "variable"
1622
- }
1623
- ];
1624
-
1625
- // src/column-expression-input/functionDocInfo.ts
1626
- var import_vuu_utils5 = require("@vuu-ui/vuu-utils");
1627
- var functionDocInfo = ({
1628
- name,
1629
- description,
1630
- example,
1631
- params,
1632
- type
1633
- }) => {
1634
- const rootElement = (0, import_vuu_utils5.createEl)("div", "vuuFunctionDoc");
1635
- const headingElement = (0, import_vuu_utils5.createEl)("div", "function-heading");
1636
- const nameElement = (0, import_vuu_utils5.createEl)("span", "function-name", name);
1637
- const paramElement = (0, import_vuu_utils5.createEl)("span", "param-list", params.description);
1638
- const typeElement = (0, import_vuu_utils5.createEl)("span", "function-type", type);
1639
- headingElement.appendChild(nameElement);
1640
- headingElement.appendChild(paramElement);
1641
- headingElement.appendChild(typeElement);
1642
- const child2 = (0, import_vuu_utils5.createEl)("p", void 0, description);
1643
- rootElement.appendChild(headingElement);
1644
- rootElement.appendChild(child2);
1645
- if (example) {
1646
- const exampleElement = (0, import_vuu_utils5.createEl)("div", "example-container", "Example:");
1647
- const expressionElement = (0, import_vuu_utils5.createEl)(
1648
- "div",
1649
- "example-expression",
1650
- example.expression
1651
- );
1652
- const resultElement = (0, import_vuu_utils5.createEl)("div", "example-result", example.result);
1653
- exampleElement.appendChild(expressionElement);
1654
- exampleElement.appendChild(resultElement);
1655
- rootElement.appendChild(exampleElement);
1656
- }
1657
- return rootElement;
1658
- };
1659
-
1660
- // src/column-expression-input/useColumnExpressionSuggestionProvider.ts
1661
- var NO_OPERATORS = [];
1662
- var withApplySpace = (suggestions) => suggestions.map((suggestion) => {
1663
- var _a;
1664
- return {
1665
- ...suggestion,
1666
- apply: ((_a = suggestion.apply) != null ? _a : suggestion.label) + " "
1667
- };
1668
- });
1669
- var getValidColumns = (columns, { functionName, operator }) => {
1670
- if (operator) {
1671
- return columns.filter(import_vuu_utils6.isNumericColumn);
1672
- } else if (functionName) {
1673
- const fn = columnFunctionDescriptors.find((f) => f.name === functionName);
1674
- if (fn) {
1675
- switch (fn.accepts) {
1676
- case "string":
1677
- return columns.filter(import_vuu_utils6.isTextColumn);
1678
- case "number":
1679
- return columns.filter(import_vuu_utils6.isNumericColumn);
1680
- default:
1681
- return columns;
1682
- }
1683
- }
1684
- }
1685
- return columns;
1686
- };
1687
- var getColumns = (columns, options) => {
1688
- const validColumns = getValidColumns(columns, options);
1689
- return validColumns.map((column) => {
1690
- var _a;
1691
- const label = (_a = column.label) != null ? _a : column.name;
1692
- return {
1693
- apply: options.prefix ? `${options.prefix}${label}` : label,
1694
- label,
1695
- boost: 5,
1696
- type: "column",
1697
- expressionType: column.serverDataType
1698
- };
1699
- });
1700
- };
1701
- var arithmeticOperators = [
1702
- { apply: "* ", boost: 2, label: "*", type: "operator" },
1703
- { apply: "/ ", boost: 2, label: "/", type: "operator" },
1704
- { apply: "+ ", boost: 2, label: "+", type: "operator" },
1705
- { apply: "- ", boost: 2, label: "-", type: "operator" }
1706
- ];
1707
- var getOperators = (column) => {
1708
- if (column === void 0 || (0, import_vuu_utils6.isNumericColumn)(column)) {
1709
- return arithmeticOperators;
1710
- } else {
1711
- return NO_OPERATORS;
1712
- }
1713
- };
1714
- var getConditionOperators = (column) => {
1715
- switch (column.serverDataType) {
1716
- case "string":
1717
- case "char":
1718
- return withApplySpace(
1719
- import_vuu_codemirror6.stringOperators
1720
- /*, startsWith*/
1721
- );
1722
- case "int":
1723
- case "long":
1724
- case "double":
1725
- return withApplySpace(import_vuu_codemirror6.numericOperators);
1726
- }
1727
- };
1728
- var toFunctionCompletion = (functionDescriptor) => ({
1729
- apply: `${functionDescriptor.name}( `,
1730
- boost: 2,
1731
- expressionType: functionDescriptor.type,
1732
- info: () => functionDocInfo(functionDescriptor),
1733
- label: functionDescriptor.name,
1734
- type: "function"
1735
- });
1736
- var getAcceptedTypes = (fn) => {
1737
- if (fn) {
1738
- if (typeof fn.accepts === "string") {
1739
- return fn.accepts;
1740
- } else if (Array.isArray(fn.accepts)) {
1741
- if (fn.accepts.every((s) => s === "string")) {
1742
- return "string";
1743
- } else {
1744
- return "any";
1745
- }
1746
- }
1747
- }
1748
- return "any";
1749
- };
1750
- var functions = columnFunctionDescriptors.map(toFunctionCompletion);
1751
- var getFunctions = ({ functionName }) => {
1752
- if (functionName) {
1753
- const fn = columnFunctionDescriptors.find((f) => f.name === functionName);
1754
- const acceptedTypes = getAcceptedTypes(fn);
1755
- if (fn) {
1756
- switch (acceptedTypes) {
1757
- case "string":
1758
- return columnFunctionDescriptors.filter((f) => f.type === "string" || f.type === "variable").map(toFunctionCompletion);
1759
- case "number":
1760
- return columnFunctionDescriptors.filter((f) => f.type === "number" || f.type === "variable").map(toFunctionCompletion);
1761
- default:
1762
- }
1763
- }
1764
- }
1765
- return functions;
1766
- };
1767
- var NONE = {};
1768
- var useColumnExpressionSuggestionProvider = ({
1769
- columns,
1770
- table
1771
- }) => {
1772
- const findColumn = (0, import_react4.useCallback)(
1773
- (name) => name ? columns.find((col) => col.name === name) : void 0,
1774
- [columns]
1775
- );
1776
- const latestSuggestionsRef = (0, import_react4.useRef)();
1777
- const getTypeaheadSuggestions = (0, import_vuu_data_react.useTypeaheadSuggestions)();
1778
- const getSuggestions = (0, import_react4.useCallback)(
1779
- async (suggestionType, options = NONE) => {
1780
- const { columnName, functionName, operator, prefix } = options;
1781
- switch (suggestionType) {
1782
- case "expression": {
1783
- const suggestions = await withApplySpace(
1784
- getColumns(columns, { functionName, prefix })
1785
- ).concat(getFunctions(options));
1786
- return latestSuggestionsRef.current = suggestions;
1787
- }
1788
- case "column": {
1789
- const suggestions = await getColumns(columns, options);
1790
- return latestSuggestionsRef.current = withApplySpace(suggestions);
1791
- }
1792
- case "operator": {
1793
- const suggestions = await getOperators(findColumn(columnName));
1794
- return latestSuggestionsRef.current = withApplySpace(suggestions);
1795
- }
1796
- case "relational-operator": {
1797
- const suggestions = await (0, import_vuu_codemirror6.getRelationalOperators)(
1798
- findColumn(columnName)
1799
- );
1800
- return latestSuggestionsRef.current = withApplySpace(suggestions);
1801
- }
1802
- case "condition-operator":
1803
- {
1804
- const column = findColumn(columnName);
1805
- if (column) {
1806
- const suggestions = await getConditionOperators(column);
1807
- if (suggestions) {
1808
- return latestSuggestionsRef.current = withApplySpace(suggestions);
1809
- }
1810
- }
1811
- }
1812
- break;
1813
- case "columnValue":
1814
- if (columnName && operator) {
1815
- const params = (0, import_vuu_data_react.getTypeaheadParams)(
1816
- table,
1817
- columnName
1818
- /*, startsWith*/
1819
- );
1820
- const suggestions = await getTypeaheadSuggestions(params);
1821
- latestSuggestionsRef.current = (0, import_vuu_codemirror6.toSuggestions)(suggestions, {
1822
- suffix: ""
1823
- });
1824
- latestSuggestionsRef.current.forEach((suggestion) => {
1825
- suggestion.apply = (view, completion, from) => {
1826
- const annotation = new import_vuu_codemirror6.AnnotationType();
1827
- const cursorPos = from + completion.label.length + 1;
1828
- view.dispatch({
1829
- changes: { from, insert: completion.label },
1830
- selection: { anchor: cursorPos, head: cursorPos },
1831
- annotations: annotation.of(completion)
1832
- });
1833
- };
1834
- });
1835
- return latestSuggestionsRef.current;
1836
- }
1837
- break;
1838
- }
1839
- return [];
1840
- },
1841
- [columns, findColumn, getTypeaheadSuggestions, table]
1842
- );
1843
- const isPartialMatch = (0, import_react4.useCallback)(
1844
- async (valueType, columnName, pattern) => {
1845
- const { current: latestSuggestions } = latestSuggestionsRef;
1846
- let maybe = false;
1847
- const suggestions = latestSuggestions || await getSuggestions(valueType, { columnName });
1848
- if (pattern && suggestions) {
1849
- for (const option of suggestions) {
1850
- if (option.label === pattern) {
1851
- return false;
1852
- } else if (option.label.startsWith(pattern)) {
1853
- maybe = true;
1854
- }
1855
- }
1856
- }
1857
- return maybe;
1858
- },
1859
- [getSuggestions]
1860
- );
1861
- return {
1862
- getSuggestions,
1863
- isPartialMatch
1864
- };
1865
- };
1866
-
1867
- // src/datagrid-configuration-ui/settings-panel/DatagridSettingsPanel.tsx
1868
- var import_core7 = require("@salt-ds/core");
1869
- var import_classnames6 = __toESM(require("classnames"), 1);
1870
- var import_react12 = require("react");
1871
-
1872
- // src/datagrid-configuration-ui/column-picker/ColumnPicker.tsx
1873
- var import_salt_lab2 = require("@heswell/salt-lab");
1874
- var import_core = require("@salt-ds/core");
1875
- var import_react5 = require("react");
1876
-
1877
- // src/datagrid-configuration-ui/column-picker/ColumnListItem.tsx
1878
- var import_salt_lab = require("@heswell/salt-lab");
1879
- var import_classnames3 = __toESM(require("classnames"), 1);
1880
- var import_jsx_runtime4 = require("react/jsx-runtime");
1881
- var classBase4 = "vuuColumnListItem";
1882
- var ColumnListItem = ({
1883
- className: classNameProp,
1884
- item,
1885
- label,
1886
- style: styleProp,
1887
- ...restProps
1888
- }) => {
1889
- const className = (0, import_classnames3.default)(classBase4, classNameProp, {
1890
- [`${classBase4}-calculated`]: item == null ? void 0 : item.expression,
1891
- [`${classBase4}-hidden`]: item == null ? void 0 : item.hidden
1892
- });
1893
- return /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)(import_salt_lab.ListItem, { className, ...restProps, children: [
1894
- /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("span", { className: `${classBase4}-iconType` }),
1895
- /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("label", { className: `${classBase4}-label`, children: label }),
1896
- /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("span", { className: `${classBase4}-iconHidden` })
1897
- ] });
1898
- };
1899
-
1900
- // src/datagrid-configuration-ui/column-picker/ColumnPicker.tsx
1901
- var import_jsx_runtime5 = require("react/jsx-runtime");
1902
- var classBase5 = "vuuColumnPicker";
1903
- var removeSelectedColumns = (availableColumns, selectedColumns) => {
1904
- return availableColumns.filter(
1905
- (column) => selectedColumns.find((col) => col.name === column.name) == null
1906
- );
1907
- };
1908
- var ColumnPicker = ({
1909
- availableColumns,
1910
- id: idProp,
1911
- dispatchColumnAction: dispatch,
1912
- onAddCalculatedColumnClick,
1913
- onSelectionChange,
1914
- chosenColumns,
1915
- selectedColumn
1916
- }) => {
1917
- const [selected1, setSelected1] = (0, import_react5.useState)([]);
1918
- const id = (0, import_core.useIdMemo)(idProp);
1919
- const unusedColumns = removeSelectedColumns(availableColumns, chosenColumns);
1920
- const addColumn2 = (0, import_react5.useCallback)(() => {
1921
- if (selected1.length > 0) {
1922
- setSelected1([]);
1923
- dispatch({ type: "addColumn", columns: selected1 });
1924
- }
1925
- }, [dispatch, selected1]);
1926
- const removeColumn2 = (0, import_react5.useCallback)(
1927
- () => selectedColumn && dispatch({ type: "removeColumn", column: selectedColumn }),
1928
- [selectedColumn, dispatch]
1929
- );
1930
- const moveColumnUp = (0, import_react5.useCallback)(
1931
- () => selectedColumn && dispatch({ type: "moveColumn", column: selectedColumn, moveBy: -1 }),
1932
- [dispatch, selectedColumn]
1933
- );
1934
- const moveColumnDown = (0, import_react5.useCallback)(
1935
- () => selectedColumn && dispatch({ type: "moveColumn", column: selectedColumn, moveBy: 1 }),
1936
- [dispatch, selectedColumn]
1937
- );
1938
- const handleSelectionChange1 = (0, import_react5.useCallback)(
1939
- (evt, selected) => setSelected1(selected),
1940
- []
1941
- );
1942
- const handleSelectionChange2 = (0, import_react5.useCallback)(
1943
- (evt, selected) => onSelectionChange == null ? void 0 : onSelectionChange(selected),
1944
- [onSelectionChange]
1945
- );
1946
- const handleDrop = (0, import_react5.useCallback)(
1947
- (moveFrom, moveTo) => {
1948
- dispatch({ type: "moveColumn", moveFrom, moveTo });
1949
- },
1950
- [dispatch]
1951
- );
1952
- return /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: classBase5, id, children: [
1953
- /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: `${classBase5}-listColumn`, children: [
1954
- /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("label", { htmlFor: `available-${id}`, children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_core.Text, { as: "h4", children: "Available Columns" }) }),
1955
- /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
1956
- "div",
1957
- {
1958
- className: `${classBase5}-listContainer`,
1959
- style: { flex: 1, overflow: "hidden" },
1960
- children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
1961
- import_salt_lab2.List,
1962
- {
1963
- borderless: true,
1964
- checkable: false,
1965
- height: "100%",
1966
- id: `available-${id}`,
1967
- itemHeight: 24,
1968
- itemToString: (item) => item.name,
1969
- onSelectionChange: handleSelectionChange1,
1970
- selected: selected1,
1971
- selectionStrategy: "extended",
1972
- source: unusedColumns
1973
- }
1974
- )
1975
- }
1976
- ),
1977
- /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
1978
- "div",
1979
- {
1980
- style: {
1981
- display: "flex",
1982
- alignItems: "center",
1983
- flex: "0 0 32px",
1984
- marginTop: "var(--salt-size-basis-unit)"
1985
- },
1986
- children: /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(import_core.Button, { onClick: addColumn2, disabled: selected1.length === 0, children: [
1987
- "Show",
1988
- /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("span", { "data-icon": "arrow-thin-right", style: { marginLeft: 8 } })
1989
- ] })
1990
- }
1991
- )
1992
- ] }),
1993
- /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: `${classBase5}-listColumn`, children: [
1994
- /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("label", { htmlFor: `selected-${id}`, children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_core.Text, { as: "h4", children: "Included Columns" }) }),
1995
- /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
1996
- "div",
1997
- {
1998
- className: `${classBase5}-listContainer`,
1999
- style: { flex: 1, overflow: "hidden" },
2000
- children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
2001
- import_salt_lab2.List,
2002
- {
2003
- ListItem: ColumnListItem,
2004
- allowDragDrop: true,
2005
- borderless: true,
2006
- height: "100%",
2007
- id: `selected-${id}`,
2008
- itemHeight: 24,
2009
- itemToString: (item) => item.name,
2010
- onMoveListItem: handleDrop,
2011
- onSelectionChange: handleSelectionChange2,
2012
- selected: selectedColumn,
2013
- style: { flex: 1 },
2014
- source: chosenColumns
2015
- }
2016
- )
2017
- }
2018
- ),
2019
- /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(
2020
- "div",
2021
- {
2022
- style: {
2023
- alignItems: "center",
2024
- flex: "0 0 32px",
2025
- display: "flex",
2026
- gap: 6,
2027
- marginTop: "var(--salt-size-basis-unit)"
2028
- },
2029
- children: [
2030
- /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(import_core.Button, { onClick: removeColumn2, disabled: selectedColumn === null, children: [
2031
- /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("span", { "data-icon": "arrow-thin-left", style: { marginRight: 8 } }),
2032
- "Hide"
2033
- ] }),
2034
- /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
2035
- import_core.Button,
2036
- {
2037
- "aria-label": "Move column up",
2038
- onClick: moveColumnUp,
2039
- disabled: selectedColumn === null || (chosenColumns == null ? void 0 : chosenColumns.indexOf(selectedColumn)) === 0,
2040
- style: { width: 28 },
2041
- children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("span", { "data-icon": "arrow-thin-up" })
2042
- }
2043
- ),
2044
- /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
2045
- import_core.Button,
2046
- {
2047
- "aria-label": "Move column down",
2048
- onClick: moveColumnDown,
2049
- disabled: selectedColumn === null || chosenColumns.indexOf(selectedColumn) === chosenColumns.length - 1,
2050
- style: { width: 28 },
2051
- children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("span", { "data-icon": "arrow-thin-down" })
2052
- }
2053
- ),
2054
- /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
2055
- import_core.Button,
2056
- {
2057
- "aria-label": "Add calculated column",
2058
- className: `${classBase5}-addCalculatedColumn`,
2059
- onClick: onAddCalculatedColumnClick,
2060
- variant: "primary",
2061
- children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("span", { "data-icon": "add" })
2062
- }
2063
- )
2064
- ]
2065
- }
2066
- )
2067
- ] })
2068
- ] });
2069
- };
2070
-
2071
- // src/datagrid-configuration-ui/column-settings-panel/ColumnSettingsPanel.tsx
2072
- var import_vuu_layout = require("@vuu-ui/vuu-layout");
2073
- var import_salt_lab5 = require("@heswell/salt-lab");
2074
- var import_core4 = require("@salt-ds/core");
2075
- var import_classnames5 = __toESM(require("classnames"), 1);
2076
- var import_react8 = require("react");
2077
-
2078
- // src/datagrid-configuration-ui/column-type-panel/ColumnTypePanel.tsx
2079
- var import_vuu_utils7 = require("@vuu-ui/vuu-utils");
2080
- var import_salt_lab4 = require("@heswell/salt-lab");
2081
- var import_core3 = require("@salt-ds/core");
2082
- var import_classnames4 = __toESM(require("classnames"), 1);
2083
- var import_react7 = require("react");
2084
-
2085
- // src/datagrid-configuration-ui/column-type-panel/NumericColumnPanel.tsx
2086
- var import_salt_lab3 = require("@heswell/salt-lab");
2087
- var import_core2 = require("@salt-ds/core");
2088
- var import_react6 = require("react");
2089
- var import_jsx_runtime6 = require("react/jsx-runtime");
2090
- var defaultValues = {
2091
- alignOnDecimals: false,
2092
- decimals: 4,
2093
- zeroPad: false
2094
- };
2095
- var getColumnValues = (columnType, gridDefaultValues) => {
2096
- const columnValue = typeof columnType === "object" && columnType.formatting ? columnType.formatting : {};
2097
- const properties = ["alignOnDecimals", "decimals", "zeroPad"];
2098
- return properties.reduce((configValues, property) => {
2099
- if (columnValue[property] !== void 0) {
2100
- return {
2101
- ...configValues,
2102
- [property]: columnValue[property]
2103
- };
2104
- } else if ((gridDefaultValues == null ? void 0 : gridDefaultValues[property]) !== void 0) {
2105
- return {
2106
- ...configValues,
2107
- [property]: gridDefaultValues[property]
2108
- };
2109
- }
2110
- return configValues;
2111
- }, defaultValues);
2112
- };
2113
- var NumericColumnPanel = ({
2114
- column,
2115
- dispatchColumnAction
2116
- }) => {
2117
- const { decimals, alignOnDecimals, zeroPad } = getColumnValues(column == null ? void 0 : column.type);
2118
- const dispatchUpdate = (0, import_react6.useCallback)(
2119
- (values) => dispatchColumnAction({
2120
- type: "updateColumnTypeFormatting",
2121
- column,
2122
- ...values
2123
- }),
2124
- [column, dispatchColumnAction]
2125
- );
2126
- const handleChangeDecimals = (0, import_react6.useCallback)(
2127
- (value) => dispatchUpdate({ decimals: parseInt(value.toString(), 10) }),
2128
- [dispatchUpdate]
2129
- );
2130
- const handleChangeAlignOnDecimals = (0, import_react6.useCallback)(
2131
- (evt, value) => dispatchUpdate({ alignOnDecimals: value }),
2132
- [dispatchUpdate]
2133
- );
2134
- const handleChangeZeroPad = (0, import_react6.useCallback)(
2135
- (evt, value) => dispatchUpdate({ zeroPad: value }),
2136
- [dispatchUpdate]
2137
- );
2138
- switch (column.serverDataType) {
2139
- case "double":
2140
- return /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(import_jsx_runtime6.Fragment, { children: [
2141
- /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(import_salt_lab3.FormField, { label: "No of Decimals", labelPlacement: "top", children: /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(import_salt_lab3.StepperInput, { value: decimals, onChange: handleChangeDecimals }) }),
2142
- /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
2143
- import_salt_lab3.Switch,
2144
- {
2145
- checked: alignOnDecimals,
2146
- label: "Align on decimals",
2147
- LabelProps: { className: "vuuColumnPanelSwitch" },
2148
- onChange: handleChangeAlignOnDecimals
2149
- }
2150
- ),
2151
- /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
2152
- import_salt_lab3.Switch,
2153
- {
2154
- checked: zeroPad,
2155
- label: "Zero pad",
2156
- LabelProps: { className: "vuuColumnPanelSwitch" },
2157
- onChange: handleChangeZeroPad
2158
- }
2159
- )
2160
- ] });
2161
- case "long":
2162
- case "int":
2163
- return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(import_jsx_runtime6.Fragment, { children: /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(import_core2.Text, { children: "Work in progress" }) });
2164
- default:
2165
- return null;
2166
- }
2167
- };
2168
-
2169
- // src/datagrid-configuration-ui/column-type-panel/StringColumnPanel.tsx
2170
- var import_jsx_runtime7 = require("react/jsx-runtime");
2171
- var StringColumnPanel = ({
2172
- column,
2173
- dispatchColumnAction
2174
- }) => {
2175
- console.log({ column, dispatchColumnAction });
2176
- return /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(import_jsx_runtime7.Fragment, { children: "what" });
2177
- };
2178
-
2179
- // src/datagrid-configuration-ui/column-type-panel/ColumnTypePanel.tsx
2180
- var import_jsx_runtime8 = require("react/jsx-runtime");
2181
- var classBase6 = "vuuColumnTypePanel";
2182
- var integerCellRenderers = ["Default Renderer (int, long)"];
2183
- var doubleCellRenderers = ["Default Renderer (double)"];
2184
- var stringCellRenderers = ["Default Renderer (string)"];
2185
- var getAvailableCellRenderers = (column) => {
2186
- const customCellRenderers = (0, import_vuu_utils7.getRegisteredCellRenderers)(column.serverDataType);
2187
- const customRendererNames = customCellRenderers.map((r) => r.name);
2188
- console.log({ customRendererNames });
2189
- switch (column.serverDataType) {
2190
- case "char":
2191
- case "string":
2192
- return stringCellRenderers;
2193
- case "int":
2194
- case "long":
2195
- return integerCellRenderers;
2196
- case "double":
2197
- return doubleCellRenderers.concat(customRendererNames);
2198
- default:
2199
- return stringCellRenderers;
2200
- }
2201
- };
2202
- var ColumnTypePanel = ({
2203
- className,
2204
- column,
2205
- dispatchColumnAction,
2206
- ...props
2207
- }) => {
2208
- const content = (0, import_react7.useMemo)(() => {
2209
- switch (column.serverDataType) {
2210
- case "double":
2211
- case "int":
2212
- case "long":
2213
- return /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
2214
- NumericColumnPanel,
2215
- {
2216
- column,
2217
- dispatchColumnAction
2218
- }
2219
- );
2220
- default:
2221
- return /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
2222
- StringColumnPanel,
2223
- {
2224
- column,
2225
- dispatchColumnAction
2226
- }
2227
- );
2228
- }
2229
- }, [column, dispatchColumnAction]);
2230
- const { serverDataType = "string" } = column;
2231
- const availableRenderers = getAvailableCellRenderers(column);
2232
- return /* @__PURE__ */ (0, import_jsx_runtime8.jsxs)(import_jsx_runtime8.Fragment, { children: [
2233
- /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
2234
- import_salt_lab4.Dropdown,
2235
- {
2236
- className: (0, import_classnames4.default)(`${classBase6}-renderer`),
2237
- fullWidth: true,
2238
- selected: availableRenderers[0],
2239
- source: availableRenderers
2240
- }
2241
- ),
2242
- /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
2243
- import_core3.Panel,
2244
- {
2245
- ...props,
2246
- className: (0, import_classnames4.default)(classBase6, className, `${classBase6}-${serverDataType}`),
2247
- children: content
2248
- }
2249
- )
2250
- ] });
2251
- };
2252
-
2253
- // src/datagrid-configuration-ui/column-settings-panel/ColumnSettingsPanel.tsx
2254
- var import_jsx_runtime9 = require("react/jsx-runtime");
2255
- var classBase7 = "vuuColumnSettingsPanel";
2256
- var tabstripProps = {
2257
- className: "salt-density-high"
2258
- };
2259
- var NullActivationIndicator = () => null;
2260
- var ColumnSettingsPanel = ({
2261
- column,
2262
- dispatchColumnAction,
2263
- style: styleProp,
2264
- ...props
2265
- }) => {
2266
- var _a, _b, _c, _d;
2267
- const [activeTab, setActiveTab] = (0, import_react8.useState)(0);
2268
- const dispatchUpdate = (0, import_react8.useCallback)(
2269
- (values) => dispatchColumnAction({
2270
- type: "updateColumnProp",
2271
- column,
2272
- ...values
2273
- }),
2274
- [column, dispatchColumnAction]
2275
- );
2276
- const handleChangeAlign = (0, import_react8.useCallback)(
2277
- (evt) => dispatchUpdate({ align: evt.target.value }),
2278
- [dispatchUpdate]
2279
- );
2280
- const handleChangePin = (0, import_react8.useCallback)(
2281
- (evt) => dispatchUpdate({ pin: evt.target.value }),
2282
- [dispatchUpdate]
2283
- );
2284
- const handleChangeHidden = (0, import_react8.useCallback)(
2285
- (evt, value) => dispatchUpdate({ hidden: value }),
2286
- [dispatchUpdate]
2287
- );
2288
- const handleChangeLabel = (0, import_react8.useCallback)(
2289
- (evt, value) => dispatchUpdate({ label: value }),
2290
- [dispatchUpdate]
2291
- );
2292
- const handleChangeWidth = (0, import_react8.useCallback)(
2293
- (value) => dispatchUpdate({ width: parseInt(value.toString(), 10) }),
2294
- [dispatchUpdate]
2295
- );
2296
- return /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)(
2297
- "div",
2298
- {
2299
- className: classBase7,
2300
- ...props,
2301
- style: {
2302
- ...styleProp
2303
- },
2304
- children: [
2305
- /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_core4.Text, { as: "h4", children: "Column Settings" }),
2306
- /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)(
2307
- import_vuu_layout.Stack,
2308
- {
2309
- active: activeTab,
2310
- showTabs: true,
2311
- className: (0, import_classnames5.default)(`${classBase7}-columnTabs`),
2312
- onTabSelectionChanged: setActiveTab,
2313
- TabstripProps: tabstripProps,
2314
- children: [
2315
- /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)(import_core4.Panel, { title: "Column", children: [
2316
- /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_salt_lab5.FormField, { label: "Hidden", labelPlacement: "left", children: /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
2317
- import_salt_lab5.Checkbox,
2318
- {
2319
- checked: column.hidden === true,
2320
- onChange: handleChangeHidden
2321
- }
2322
- ) }),
2323
- /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_salt_lab5.FormField, { label: "Label", labelPlacement: "left", children: /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
2324
- import_salt_lab5.Input,
2325
- {
2326
- value: (_a = column.label) != null ? _a : column.name,
2327
- onChange: handleChangeLabel
2328
- }
2329
- ) }),
2330
- /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_salt_lab5.FormField, { label: "Width", labelPlacement: "left", children: /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
2331
- import_salt_lab5.StepperInput,
2332
- {
2333
- value: (_b = column.width) != null ? _b : 100,
2334
- onChange: handleChangeWidth
2335
- }
2336
- ) }),
2337
- /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
2338
- import_salt_lab5.FormField,
2339
- {
2340
- label: "Align",
2341
- labelPlacement: "left",
2342
- ActivationIndicatorComponent: NullActivationIndicator,
2343
- children: /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)(
2344
- import_salt_lab5.RadioButtonGroup,
2345
- {
2346
- "aria-label": "Column Align",
2347
- value: (_c = column.align) != null ? _c : "left",
2348
- legend: "Align",
2349
- onChange: handleChangeAlign,
2350
- children: [
2351
- /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_salt_lab5.RadioButton, { label: "Left", value: "left" }),
2352
- /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_salt_lab5.RadioButton, { label: "Right", value: "right" })
2353
- ]
2354
- }
2355
- )
2356
- }
2357
- ),
2358
- /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
2359
- import_salt_lab5.FormField,
2360
- {
2361
- label: "Pin Column",
2362
- labelPlacement: "left",
2363
- ActivationIndicatorComponent: NullActivationIndicator,
2364
- children: /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)(
2365
- import_salt_lab5.RadioButtonGroup,
2366
- {
2367
- "aria-label": "Pin Column",
2368
- value: (_d = column.pin) != null ? _d : "",
2369
- legend: "Pin Column",
2370
- onChange: handleChangePin,
2371
- children: [
2372
- /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_salt_lab5.RadioButton, { label: "Do not pin", value: "" }),
2373
- /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_salt_lab5.RadioButton, { label: "Left", value: "left" }),
2374
- /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_salt_lab5.RadioButton, { label: "Right", value: "right" })
2375
- ]
2376
- }
2377
- )
2378
- }
2379
- )
2380
- ] }),
2381
- /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
2382
- ColumnTypePanel,
2383
- {
2384
- column,
2385
- dispatchColumnAction,
2386
- title: "Data Cell"
2387
- }
2388
- ),
2389
- /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)(import_core4.Panel, { title: "Vuu", variant: "secondary", children: [
2390
- /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
2391
- import_salt_lab5.FormField,
2392
- {
2393
- label: "Name",
2394
- labelPlacement: "top",
2395
- readOnly: true,
2396
- variant: "secondary",
2397
- children: /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_salt_lab5.Input, { value: column.name })
2398
- }
2399
- ),
2400
- /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
2401
- import_salt_lab5.FormField,
2402
- {
2403
- label: "Vuu type",
2404
- labelPlacement: "top",
2405
- readOnly: true,
2406
- variant: "secondary",
2407
- children: /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_salt_lab5.Input, { value: column.serverDataType })
2408
- }
2409
- )
2410
- ] })
2411
- ]
2412
- }
2413
- )
2414
- ]
2415
- }
2416
- );
2417
- };
2418
-
2419
- // src/datagrid-configuration-ui/settings-panel/GridSettingsPanel.tsx
2420
- var import_salt_lab6 = require("@heswell/salt-lab");
2421
- var import_core5 = require("@salt-ds/core");
2422
- var import_react9 = require("react");
2423
- var import_jsx_runtime10 = require("react/jsx-runtime");
2424
- var classBase8 = "vuuGridSettingsPanel";
2425
- var NullActivationIndicator2 = () => null;
2426
- var GridSettingsPanel = ({
2427
- config,
2428
- dispatchColumnAction,
2429
- style: styleProp,
2430
- ...props
2431
- }) => {
2432
- var _a;
2433
- const dispatchUpdate = (0, import_react9.useCallback)(
2434
- (values) => dispatchColumnAction({
2435
- type: "updateGridSettings",
2436
- ...values
2437
- }),
2438
- [dispatchColumnAction]
2439
- );
2440
- const handleChangeLabelFormatting = (0, import_react9.useCallback)(
2441
- (evt) => dispatchUpdate({
2442
- columnFormatHeader: evt.target.value
2443
- }),
2444
- [dispatchUpdate]
2445
- );
2446
- const handleChangeWidth = (0, import_react9.useCallback)(
2447
- (value) => dispatchUpdate({ columnDefaultWidth: parseInt(value.toString(), 10) }),
2448
- [dispatchUpdate]
2449
- );
2450
- return /* @__PURE__ */ (0, import_jsx_runtime10.jsxs)(
2451
- "div",
2452
- {
2453
- className: classBase8,
2454
- ...props,
2455
- style: {
2456
- ...styleProp
2457
- },
2458
- children: [
2459
- /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(import_core5.Text, { as: "h4", children: "Grid Settings" }),
2460
- /* @__PURE__ */ (0, import_jsx_runtime10.jsxs)(import_core5.Panel, { children: [
2461
- /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(
2462
- import_salt_lab6.FormField,
2463
- {
2464
- label: "Format column labels",
2465
- labelPlacement: "left",
2466
- ActivationIndicatorComponent: NullActivationIndicator2,
2467
- children: /* @__PURE__ */ (0, import_jsx_runtime10.jsxs)(
2468
- import_salt_lab6.RadioButtonGroup,
2469
- {
2470
- "aria-label": "Format column labels",
2471
- value: config.columnFormatHeader,
2472
- legend: "Format column labels",
2473
- onChange: handleChangeLabelFormatting,
2474
- children: [
2475
- /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(import_salt_lab6.RadioButton, { label: "No Formatting", value: void 0 }),
2476
- /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(import_salt_lab6.RadioButton, { label: "Capitalize", value: "capitalize" }),
2477
- /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(import_salt_lab6.RadioButton, { label: "Uppercase", value: "uppercase" })
2478
- ]
2479
- }
2480
- )
2481
- }
2482
- ),
2483
- /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(import_salt_lab6.FormField, { label: "Default Column Width", labelPlacement: "left", children: /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(
2484
- import_salt_lab6.StepperInput,
2485
- {
2486
- value: (_a = config.columnDefaultWidth) != null ? _a : 100,
2487
- onChange: handleChangeWidth
2488
- }
2489
- ) })
2490
- ] })
2491
- ]
2492
- }
2493
- );
2494
- };
2495
-
2496
- // src/datagrid-configuration-ui/settings-panel/useGridSettings.ts
2497
- var import_react10 = require("react");
2498
- var import_salt_lab7 = require("@heswell/salt-lab");
2499
- var import_vuu_utils8 = require("@vuu-ui/vuu-utils");
2500
- var gridSettingsReducer = (state, action) => {
2501
- console.log(`gridSettingsReducer ${action.type}`);
2502
- switch (action.type) {
2503
- case "addColumn":
2504
- return addColumn(state, action);
2505
- case "addCalculatedColumn":
2506
- return addCalculatedColumn(state, action);
2507
- case "moveColumn":
2508
- return moveColumn(state, action);
2509
- case "removeColumn":
2510
- return removeColumn(state, action);
2511
- case "updateColumn":
2512
- return state;
2513
- case "updateColumnProp":
2514
- return updateColumnProp(state, action);
2515
- case "updateGridSettings":
2516
- return updateGridSettings(state, action);
2517
- case "updateColumnTypeFormatting":
2518
- return updateColumnTypeFormatting(state, action);
2519
- default:
2520
- return state;
2521
- }
2522
- };
2523
- var useGridSettings = (config) => {
2524
- const [state, dispatchColumnAction] = (0, import_react10.useReducer)(
2525
- gridSettingsReducer,
2526
- config
2527
- );
2528
- return {
2529
- gridSettings: state,
2530
- dispatchColumnAction
2531
- };
2532
- };
2533
- function addColumn(state, { column, columns, index = -1 }) {
2534
- const { columns: stateColumns } = state;
2535
- if (index === -1) {
2536
- if (Array.isArray(columns)) {
2537
- return { ...state, columns: stateColumns.concat(columns) };
2538
- } else if (column) {
2539
- return { ...state, columns: stateColumns.concat(column) };
2540
- }
2541
- }
2542
- return state;
2543
- }
2544
- function addCalculatedColumn(state, { columnName, columnType, expression }) {
2545
- const { columns: stateColumns } = state;
2546
- const calculatedColumn = {
2547
- name: columnName,
2548
- expression,
2549
- serverDataType: columnType
2550
- };
2551
- return { ...state, columns: stateColumns.concat(calculatedColumn) };
2552
- }
2553
- function removeColumn(state, { column }) {
2554
- const { columns: stateColumns } = state;
2555
- return {
2556
- ...state,
2557
- columns: stateColumns.filter((col) => col.name !== column.name)
2558
- };
2559
- }
2560
- function moveColumn(state, { column, moveBy, moveFrom, moveTo }) {
2561
- const { columns: stateColumns } = state;
2562
- if (column && typeof moveBy === "number") {
2563
- const idx = stateColumns.indexOf(column);
2564
- const newColumns = stateColumns.slice();
2565
- const [movedColumns] = newColumns.splice(idx, 1);
2566
- newColumns.splice(idx + moveBy, 0, movedColumns);
2567
- return {
2568
- ...state,
2569
- columns: newColumns
2570
- };
2571
- } else if (typeof moveFrom === "number" && typeof moveTo === "number") {
2572
- return {
2573
- ...state,
2574
- columns: (0, import_salt_lab7.moveItem)(stateColumns, moveFrom, moveTo)
2575
- };
2576
- } else {
2577
- return state;
2578
- }
2579
- }
2580
- function updateColumnProp(state, { align, column, hidden, label, width }) {
2581
- let { columns: stateColumns } = state;
2582
- if (align === "left" || align === "right") {
2583
- stateColumns = replaceColumn(stateColumns, { ...column, align });
2584
- }
2585
- if (typeof hidden === "boolean") {
2586
- stateColumns = replaceColumn(stateColumns, { ...column, hidden });
2587
- }
2588
- if (typeof label === "string") {
2589
- stateColumns = replaceColumn(stateColumns, { ...column, label });
2590
- }
2591
- if (typeof width === "number") {
2592
- stateColumns = replaceColumn(stateColumns, { ...column, width });
2593
- }
2594
- return {
2595
- ...state,
2596
- columns: stateColumns
2597
- };
2598
- }
2599
- function updateGridSettings(state, { columnFormatHeader }) {
2600
- return {
2601
- ...state,
2602
- columnFormatHeader: columnFormatHeader != null ? columnFormatHeader : state.columnFormatHeader
2603
- };
2604
- }
2605
- function updateColumnTypeFormatting(state, {
2606
- alignOnDecimals,
2607
- column,
2608
- decimals,
2609
- zeroPad
2610
- }) {
2611
- const { columns: stateColumns } = state;
2612
- const targetColumn = stateColumns.find((col) => col.name === column.name);
2613
- if (targetColumn) {
2614
- const {
2615
- serverDataType = "string",
2616
- type: columnType = (0, import_vuu_utils8.fromServerDataType)(serverDataType)
2617
- } = column;
2618
- const type = typeof columnType === "string" ? {
2619
- name: columnType
2620
- } : {
2621
- ...columnType
2622
- };
2623
- if (typeof alignOnDecimals === "boolean") {
2624
- type.formatting = {
2625
- ...type.formatting,
2626
- alignOnDecimals
2627
- };
2628
- }
2629
- if (typeof decimals === "number") {
2630
- type.formatting = {
2631
- ...type.formatting,
2632
- decimals
2633
- };
2634
- }
2635
- if (typeof zeroPad === "boolean") {
2636
- type.formatting = {
2637
- ...type.formatting,
2638
- zeroPad
2639
- };
2640
- }
2641
- return {
2642
- ...state,
2643
- columns: replaceColumn(stateColumns, { ...column, type })
2644
- };
2645
- } else {
2646
- return state;
2647
- }
2648
- }
2649
- function replaceColumn(columns, column) {
2650
- return columns.map((col) => col.name === column.name ? column : col);
2651
- }
2652
-
2653
- // src/datagrid-configuration-ui/settings-panel/DatagridSettingsPanel.tsx
2654
- var import_vuu_layout2 = require("@vuu-ui/vuu-layout");
2655
-
2656
- // src/datagrid-configuration-ui/calculated-column-panel/CalculatedColumnPanel.tsx
2657
- var import_salt_lab8 = require("@heswell/salt-lab");
2658
- var import_core6 = require("@salt-ds/core");
2659
- var import_react11 = require("react");
2660
- var import_jsx_runtime11 = require("react/jsx-runtime");
2661
- var CalculatedColumnPanel = ({
2662
- columns,
2663
- dispatchColumnAction,
2664
- table
2665
- }) => {
2666
- const [columnName, setColumnName] = (0, import_react11.useState)("");
2667
- const [, setExpression] = (0, import_react11.useState)();
2668
- const sourceRef = (0, import_react11.useRef)("");
2669
- const suggestionProvider = useColumnExpressionSuggestionProvider({
2670
- columns,
2671
- table
2672
- });
2673
- const handleChangeName = (0, import_react11.useCallback)(
2674
- (evt) => {
2675
- const { value } = evt.target;
2676
- setColumnName(value);
2677
- },
2678
- []
2679
- );
2680
- const handleChangeExpression = (0, import_react11.useCallback)((source) => {
2681
- sourceRef.current = source;
2682
- }, []);
2683
- const handleSubmitExpression = (0, import_react11.useCallback)(
2684
- (source, expression) => {
2685
- console.log({ source });
2686
- setExpression(expression);
2687
- },
2688
- []
2689
- );
2690
- const handleSave = (0, import_react11.useCallback)(() => {
2691
- if (sourceRef.current) {
2692
- console.log(
2693
- `save expression ${JSON.stringify(sourceRef.current, null, 2)}`
2694
- );
2695
- dispatchColumnAction({
2696
- type: "addCalculatedColumn",
2697
- columnName,
2698
- expression: sourceRef.current,
2699
- columnType: "string"
2700
- });
2701
- }
2702
- }, [columnName, dispatchColumnAction]);
2703
- return /* @__PURE__ */ (0, import_jsx_runtime11.jsxs)(import_core6.Panel, { className: "vuuCalculatedColumnPanel", title: "Define Computed Column", children: [
2704
- /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(import_core6.Text, { styleAs: "h4", children: "Define Computed Column" }),
2705
- /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(import_salt_lab8.FormField, { label: "Column Name", labelPlacement: "left", children: /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(import_salt_lab8.Input, { value: columnName, onChange: handleChangeName }) }),
2706
- /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(
2707
- ColumnExpressionInput,
2708
- {
2709
- onChange: handleChangeExpression,
2710
- onSubmitExpression: handleSubmitExpression,
2711
- suggestionProvider
2712
- }
2713
- ),
2714
- /* @__PURE__ */ (0, import_jsx_runtime11.jsx)("div", { style: { marginTop: 12 }, children: /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(import_core6.Button, { onClick: handleSave, children: "Add Column" }) })
2715
- ] });
2716
- };
2717
-
2718
- // src/datagrid-configuration-ui/settings-panel/DatagridSettingsPanel.tsx
2719
- var import_jsx_runtime12 = require("react/jsx-runtime");
2720
- var classBase9 = "vuuDatagridSettingsPanel";
2721
- var getTabLabel = () => void 0;
2722
- var icons = [
2723
- "table-settings",
2724
- "column-chooser",
2725
- "column-settings",
2726
- "define-column"
2727
- ];
2728
- var getTabIcon = (component, tabIndex) => icons[tabIndex];
2729
- var DatagridSettingsPanel = ({
2730
- availableColumns,
2731
- className,
2732
- gridConfig,
2733
- onCancel,
2734
- onConfigChange,
2735
- ...props
2736
- }) => {
2737
- var _a;
2738
- console.log(`DatagridSettingsPanel render`);
2739
- const [selectedTabIndex, setSelectedTabIndex] = (0, import_react12.useState)(0);
2740
- const { gridSettings, dispatchColumnAction } = useGridSettings(gridConfig);
2741
- const [selectedColumnName, setSelectedColumnName] = (0, import_react12.useState)(
2742
- null
2743
- );
2744
- const handleColumnSelected = (0, import_react12.useCallback)(
2745
- (selected) => {
2746
- setSelectedColumnName(selected ? selected.name : null);
2747
- },
2748
- []
2749
- );
2750
- const handleApply = (0, import_react12.useCallback)(
2751
- (evt, closePanel = false) => {
2752
- console.log(`1) DataGridSettingsPanel fire onConfigChange`);
2753
- onConfigChange == null ? void 0 : onConfigChange(gridSettings, closePanel);
2754
- },
2755
- [gridSettings, onConfigChange]
2756
- );
2757
- const handleTabSelectionChanged = (0, import_react12.useCallback)((selectedTabIndex2) => {
2758
- setSelectedTabIndex(selectedTabIndex2);
2759
- }, []);
2760
- const handleSave = (0, import_react12.useCallback)(
2761
- (evt) => handleApply(evt, true),
2762
- [handleApply]
2763
- );
2764
- const selectedColumn = selectedColumnName === null ? null : (_a = gridSettings.columns.find((col) => col.name === selectedColumnName)) != null ? _a : null;
2765
- const tabstripProps3 = {
2766
- activeTabIndex: selectedTabIndex,
2767
- enableRenameTab: false,
2768
- orientation: "vertical"
2769
- };
2770
- const handleAddCalculatedColumn = (0, import_react12.useCallback)(
2771
- () => setSelectedTabIndex(3),
2772
- []
2773
- );
2774
- const panelShift = selectedTabIndex === 2 ? "right" : void 0;
2775
- return /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)("div", { ...props, className: (0, import_classnames6.default)(classBase9, className), children: [
2776
- /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)(
2777
- import_vuu_layout2.Stack,
2778
- {
2779
- TabstripProps: tabstripProps3,
2780
- className: `${classBase9}-stack`,
2781
- getTabIcon,
2782
- getTabLabel,
2783
- active: selectedTabIndex === 2 ? 1 : selectedTabIndex,
2784
- onTabSelectionChanged: handleTabSelectionChanged,
2785
- showTabs: true,
2786
- children: [
2787
- /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(
2788
- GridSettingsPanel,
2789
- {
2790
- config: gridSettings,
2791
- dispatchColumnAction
2792
- }
2793
- ),
2794
- /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)("div", { className: `${classBase9}-columnPanels`, "data-align": panelShift, children: [
2795
- /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(
2796
- ColumnPicker,
2797
- {
2798
- availableColumns,
2799
- chosenColumns: gridSettings.columns,
2800
- dispatchColumnAction,
2801
- onSelectionChange: handleColumnSelected,
2802
- onAddCalculatedColumnClick: handleAddCalculatedColumn,
2803
- selectedColumn
2804
- }
2805
- ),
2806
- selectedColumn === null ? /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_core7.Panel, { className: "vuuColumnSettingsPanel", children: "Select a column" }) : /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(
2807
- ColumnSettingsPanel,
2808
- {
2809
- column: selectedColumn,
2810
- dispatchColumnAction,
2811
- style: { background: "white", flex: "1 0 150px" }
2812
- }
2813
- )
2814
- ] }),
2815
- /* @__PURE__ */ (0, import_jsx_runtime12.jsx)("div", { title: "Column Settings", children: "Column Settings" }),
2816
- /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(
2817
- CalculatedColumnPanel,
2818
- {
2819
- columns: gridSettings.columns,
2820
- dispatchColumnAction,
2821
- table: { module: "SIMUL", table: "instruments" }
2822
- }
2823
- )
2824
- ]
2825
- }
2826
- ),
2827
- /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)("div", { className: `${classBase9}-buttonBar`, children: [
2828
- /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_core7.Button, { onClick: onCancel, children: "Cancel" }),
2829
- /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_core7.Button, { onClick: handleApply, children: "Apply" }),
2830
- /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_core7.Button, { onClick: handleSave, children: "Save" })
2831
- ] })
2832
- ] });
2833
- };
2834
-
2835
- // src/datasource-stats/DatasourceStats.tsx
2836
- var import_react13 = require("react");
2837
- var import_classnames7 = __toESM(require("classnames"), 1);
2838
- var import_jsx_runtime13 = require("react/jsx-runtime");
2839
- var classBase10 = "vuuDatasourceStats";
2840
- var numberFormatter = new Intl.NumberFormat();
2841
- var DataSourceStats = ({
2842
- className: classNameProp,
2843
- dataSource
2844
- }) => {
2845
- const [range, setRange] = (0, import_react13.useState)(dataSource.range);
2846
- const [size, setSize] = (0, import_react13.useState)(dataSource.size);
2847
- (0, import_react13.useEffect)(() => {
2848
- setSize(dataSource.size);
2849
- dataSource.on("resize", setSize);
2850
- dataSource.on("range", setRange);
2851
- }, [dataSource]);
2852
- const className = (0, import_classnames7.default)(classBase10, classNameProp);
2853
- const from = numberFormatter.format(range.from);
2854
- const to = numberFormatter.format(range.to - 1);
2855
- const value = numberFormatter.format(size);
2856
- return /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)("div", { className, children: [
2857
- /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("span", { children: "Showing rows" }),
2858
- /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("span", { className: `${classBase10}-range`, children: from }),
2859
- /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("span", { className: `${classBase10}-range`, children: to }),
2860
- /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("span", { children: "of" }),
2861
- /* @__PURE__ */ (0, import_jsx_runtime13.jsx)("span", { className: `${classBase10}-size`, children: value })
2862
- ] });
2863
- };
2864
-
2865
- // src/table-settings/column-settings-panel/ColumnSettingsPanel.tsx
2866
- var import_vuu_layout3 = require("@vuu-ui/vuu-layout");
2867
- var import_salt_lab11 = require("@heswell/salt-lab");
2868
- var import_core10 = require("@salt-ds/core");
2869
- var import_classnames9 = __toESM(require("classnames"), 1);
2870
- var import_react16 = require("react");
2871
-
2872
- // src/table-settings/column-type-panel/ColumnTypePanel.tsx
2873
- var import_vuu_utils9 = require("@vuu-ui/vuu-utils");
2874
- var import_salt_lab10 = require("@heswell/salt-lab");
2875
- var import_core9 = require("@salt-ds/core");
2876
- var import_classnames8 = __toESM(require("classnames"), 1);
2877
- var import_react15 = require("react");
2878
-
2879
- // src/table-settings/column-type-panel/NumericColumnPanel.tsx
2880
- var import_salt_lab9 = require("@heswell/salt-lab");
2881
- var import_core8 = require("@salt-ds/core");
2882
- var import_react14 = require("react");
2883
- var import_jsx_runtime14 = require("react/jsx-runtime");
2884
- var defaultValues2 = {
2885
- alignOnDecimals: false,
2886
- decimals: 4,
2887
- zeroPad: false
2888
- };
2889
- var getColumnValues2 = (columnType, gridDefaultValues) => {
2890
- const columnValue = typeof columnType === "object" && columnType.formatting ? columnType.formatting : {};
2891
- const properties = ["alignOnDecimals", "decimals", "zeroPad"];
2892
- return properties.reduce((configValues, property) => {
2893
- if (columnValue[property] !== void 0) {
2894
- return {
2895
- ...configValues,
2896
- [property]: columnValue[property]
2897
- };
2898
- } else if ((gridDefaultValues == null ? void 0 : gridDefaultValues[property]) !== void 0) {
2899
- return {
2900
- ...configValues,
2901
- [property]: gridDefaultValues[property]
2902
- };
2903
- }
2904
- return configValues;
2905
- }, defaultValues2);
2906
- };
2907
- var NumericColumnPanel2 = ({
2908
- column,
2909
- dispatchColumnAction
2910
- }) => {
2911
- const { decimals, alignOnDecimals, zeroPad } = getColumnValues2(column == null ? void 0 : column.type);
2912
- const dispatchUpdate = (0, import_react14.useCallback)(
2913
- (values) => dispatchColumnAction({
2914
- type: "updateColumnTypeFormatting",
2915
- column,
2916
- ...values
2917
- }),
2918
- [column, dispatchColumnAction]
2919
- );
2920
- const handleChangeDecimals = (0, import_react14.useCallback)(
2921
- (value) => dispatchUpdate({ decimals: parseInt(value.toString(), 10) }),
2922
- [dispatchUpdate]
2923
- );
2924
- const handleChangeAlignOnDecimals = (0, import_react14.useCallback)(
2925
- (evt, value) => dispatchUpdate({ alignOnDecimals: value }),
2926
- [dispatchUpdate]
2927
- );
2928
- const handleChangeZeroPad = (0, import_react14.useCallback)(
2929
- (evt, value) => dispatchUpdate({ zeroPad: value }),
2930
- [dispatchUpdate]
2931
- );
2932
- switch (column.serverDataType) {
2933
- case "double":
2934
- return /* @__PURE__ */ (0, import_jsx_runtime14.jsxs)(import_jsx_runtime14.Fragment, { children: [
2935
- /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(import_salt_lab9.FormField, { label: "No of Decimals", labelPlacement: "top", children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(import_salt_lab9.StepperInput, { value: decimals, onChange: handleChangeDecimals }) }),
2936
- /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(
2937
- import_salt_lab9.Switch,
2938
- {
2939
- checked: alignOnDecimals,
2940
- label: "Align on decimals",
2941
- LabelProps: { className: "vuuColumnPanelSwitch" },
2942
- onChange: handleChangeAlignOnDecimals
2943
- }
2944
- ),
2945
- /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(
2946
- import_salt_lab9.Switch,
2947
- {
2948
- checked: zeroPad,
2949
- label: "Zero pad",
2950
- LabelProps: { className: "vuuColumnPanelSwitch" },
2951
- onChange: handleChangeZeroPad
2952
- }
2953
- )
2954
- ] });
2955
- case "long":
2956
- case "int":
2957
- return /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(import_jsx_runtime14.Fragment, { children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(import_core8.Text, { children: "Work in progress" }) });
2958
- default:
2959
- return null;
2960
- }
2961
- };
2962
-
2963
- // src/table-settings/column-type-panel/StringColumnPanel.tsx
2964
- var import_jsx_runtime15 = require("react/jsx-runtime");
2965
- var StringColumnPanel2 = ({
2966
- column,
2967
- dispatchColumnAction
2968
- }) => {
2969
- console.log(column, dispatchColumnAction);
2970
- return /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(import_jsx_runtime15.Fragment, { children: "what" });
2971
- };
2972
-
2973
- // src/table-settings/column-type-panel/ColumnTypePanel.tsx
2974
- var import_jsx_runtime16 = require("react/jsx-runtime");
2975
- var classBase11 = "vuuColumnTypePanel";
2976
- var integerCellRenderers2 = ["Default Renderer (int, long)"];
2977
- var doubleCellRenderers2 = ["Default Renderer (double)"];
2978
- var stringCellRenderers2 = ["Default Renderer (string)"];
2979
- var getAvailableCellRenderers2 = (column) => {
2980
- const customCellRenderers = (0, import_vuu_utils9.getRegisteredCellRenderers)(column.serverDataType);
2981
- const customRendererNames = customCellRenderers.map((r) => r.name);
2982
- console.log({ customRendererNames });
2983
- switch (column.serverDataType) {
2984
- case "char":
2985
- case "string":
2986
- return stringCellRenderers2;
2987
- case "int":
2988
- case "long":
2989
- return integerCellRenderers2;
2990
- case "double":
2991
- return doubleCellRenderers2.concat(customRendererNames);
2992
- default:
2993
- return stringCellRenderers2;
2994
- }
2995
- };
2996
- var ColumnTypePanel2 = ({
2997
- className,
2998
- column,
2999
- dispatchColumnAction,
3000
- ...props
3001
- }) => {
3002
- const content = (0, import_react15.useMemo)(() => {
3003
- switch (column.serverDataType) {
3004
- case "double":
3005
- case "int":
3006
- case "long":
3007
- return /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
3008
- NumericColumnPanel2,
3009
- {
3010
- column,
3011
- dispatchColumnAction
3012
- }
3013
- );
3014
- default:
3015
- return /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
3016
- StringColumnPanel2,
3017
- {
3018
- column,
3019
- dispatchColumnAction
3020
- }
3021
- );
3022
- }
3023
- }, [column, dispatchColumnAction]);
3024
- const { serverDataType = "string" } = column;
3025
- const availableRenderers = getAvailableCellRenderers2(column);
3026
- return /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)(import_jsx_runtime16.Fragment, { children: [
3027
- /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
3028
- import_salt_lab10.Dropdown,
3029
- {
3030
- className: (0, import_classnames8.default)(`${classBase11}-renderer`),
3031
- fullWidth: true,
3032
- selected: availableRenderers[0],
3033
- source: availableRenderers
3034
- }
3035
- ),
3036
- /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
3037
- import_core9.Panel,
3038
- {
3039
- ...props,
3040
- className: (0, import_classnames8.default)(classBase11, className, `${classBase11}-${serverDataType}`),
3041
- children: content
3042
- }
3043
- )
3044
- ] });
3045
- };
3046
-
3047
- // src/table-settings/column-settings-panel/ColumnSettingsPanel.tsx
3048
- var import_jsx_runtime17 = require("react/jsx-runtime");
3049
- var classBase12 = "vuuColumnSettingsPanel";
3050
- var tabstripProps2 = {
3051
- className: "salt-density-high"
3052
- };
3053
- var NullActivationIndicator3 = () => null;
3054
- var ColumnSettingsPanel2 = ({
3055
- column,
3056
- dispatchColumnAction,
3057
- style: styleProp,
3058
- ...props
3059
- }) => {
3060
- var _a, _b, _c, _d;
3061
- const [activeTab, setActiveTab] = (0, import_react16.useState)(0);
3062
- const dispatchUpdate = (0, import_react16.useCallback)(
3063
- (values) => dispatchColumnAction({
3064
- type: "updateColumnProp",
3065
- column,
3066
- ...values
3067
- }),
3068
- [column, dispatchColumnAction]
3069
- );
3070
- const handleChangeAlign = (0, import_react16.useCallback)(
3071
- (evt) => dispatchUpdate({ align: evt.target.value }),
3072
- [dispatchUpdate]
3073
- );
3074
- const handleChangePin = (0, import_react16.useCallback)(
3075
- (evt) => dispatchUpdate({ pin: evt.target.value }),
3076
- [dispatchUpdate]
3077
- );
3078
- const handleChangeHidden = (0, import_react16.useCallback)(
3079
- (evt, value) => dispatchUpdate({ hidden: value }),
3080
- [dispatchUpdate]
3081
- );
3082
- const handleChangeLabel = (0, import_react16.useCallback)(
3083
- (evt, value) => dispatchUpdate({ label: value }),
3084
- [dispatchUpdate]
3085
- );
3086
- const handleChangeWidth = (0, import_react16.useCallback)(
3087
- (value) => dispatchUpdate({ width: parseInt(value.toString(), 10) }),
3088
- [dispatchUpdate]
3089
- );
3090
- return /* @__PURE__ */ (0, import_jsx_runtime17.jsxs)(
3091
- "div",
3092
- {
3093
- className: classBase12,
3094
- ...props,
3095
- style: {
3096
- ...styleProp
3097
- },
3098
- children: [
3099
- /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(import_core10.Text, { as: "h4", children: "Column Settings" }),
3100
- /* @__PURE__ */ (0, import_jsx_runtime17.jsxs)(
3101
- import_vuu_layout3.Stack,
3102
- {
3103
- active: activeTab,
3104
- showTabs: true,
3105
- className: (0, import_classnames9.default)(`${classBase12}-columnTabs`),
3106
- onTabSelectionChanged: setActiveTab,
3107
- TabstripProps: tabstripProps2,
3108
- children: [
3109
- /* @__PURE__ */ (0, import_jsx_runtime17.jsxs)(import_core10.Panel, { title: "Column", children: [
3110
- /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(import_salt_lab11.FormField, { label: "Hidden", labelPlacement: "left", children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
3111
- import_salt_lab11.Checkbox,
3112
- {
3113
- checked: column.hidden === true,
3114
- onChange: handleChangeHidden
3115
- }
3116
- ) }),
3117
- /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(import_salt_lab11.FormField, { label: "Label", labelPlacement: "left", children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
3118
- import_salt_lab11.Input,
3119
- {
3120
- value: (_a = column.label) != null ? _a : column.name,
3121
- onChange: handleChangeLabel
3122
- }
3123
- ) }),
3124
- /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(import_salt_lab11.FormField, { label: "Width", labelPlacement: "left", children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
3125
- import_salt_lab11.StepperInput,
3126
- {
3127
- value: (_b = column.width) != null ? _b : 100,
3128
- onChange: handleChangeWidth
3129
- }
3130
- ) }),
3131
- /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
3132
- import_salt_lab11.FormField,
3133
- {
3134
- label: "Align",
3135
- labelPlacement: "left",
3136
- ActivationIndicatorComponent: NullActivationIndicator3,
3137
- children: /* @__PURE__ */ (0, import_jsx_runtime17.jsxs)(
3138
- import_salt_lab11.RadioButtonGroup,
3139
- {
3140
- "aria-label": "Column Align",
3141
- value: (_c = column.align) != null ? _c : "left",
3142
- legend: "Align",
3143
- onChange: handleChangeAlign,
3144
- children: [
3145
- /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(import_salt_lab11.RadioButton, { label: "Left", value: "left" }),
3146
- /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(import_salt_lab11.RadioButton, { label: "Right", value: "right" })
3147
- ]
3148
- }
3149
- )
3150
- }
3151
- ),
3152
- /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
3153
- import_salt_lab11.FormField,
3154
- {
3155
- label: "Pin Column",
3156
- labelPlacement: "left",
3157
- ActivationIndicatorComponent: NullActivationIndicator3,
3158
- children: /* @__PURE__ */ (0, import_jsx_runtime17.jsxs)(
3159
- import_salt_lab11.RadioButtonGroup,
3160
- {
3161
- "aria-label": "Pin Column",
3162
- value: (_d = column.pin) != null ? _d : "",
3163
- legend: "Pin Column",
3164
- onChange: handleChangePin,
3165
- children: [
3166
- /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(import_salt_lab11.RadioButton, { label: "Do not pin", value: "" }),
3167
- /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(import_salt_lab11.RadioButton, { label: "Left", value: "left" }),
3168
- /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(import_salt_lab11.RadioButton, { label: "Right", value: "right" })
3169
- ]
3170
- }
3171
- )
3172
- }
3173
- )
3174
- ] }),
3175
- /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
3176
- ColumnTypePanel2,
3177
- {
3178
- column,
3179
- dispatchColumnAction,
3180
- title: "Data Cell"
3181
- }
3182
- ),
3183
- /* @__PURE__ */ (0, import_jsx_runtime17.jsxs)(import_core10.Panel, { title: "Vuu", variant: "secondary", children: [
3184
- /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
3185
- import_salt_lab11.FormField,
3186
- {
3187
- label: "Name",
3188
- labelPlacement: "top",
3189
- readOnly: true,
3190
- variant: "secondary",
3191
- children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(import_salt_lab11.Input, { value: column.name })
3192
- }
3193
- ),
3194
- /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(
3195
- import_salt_lab11.FormField,
3196
- {
3197
- label: "Vuu type",
3198
- labelPlacement: "top",
3199
- readOnly: true,
3200
- variant: "secondary",
3201
- children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(import_salt_lab11.Input, { value: column.serverDataType })
3202
- }
3203
- )
3204
- ] })
3205
- ]
3206
- }
3207
- )
3208
- ]
3209
- }
3210
- );
3211
- };
1
+ "use strict";var Qt=Object.create;var Ge=Object.defineProperty;var Lt=Object.getOwnPropertyDescriptor;var It=Object.getOwnPropertyNames;var Bt=Object.getPrototypeOf,$t=Object.prototype.hasOwnProperty;var Mt=(e,n)=>{for(var t in n)Ge(e,t,{get:n[t],enumerable:!0})},An=(e,n,t,o)=>{if(n&&typeof n=="object"||typeof n=="function")for(let i of It(n))!$t.call(e,i)&&i!==t&&Ge(e,i,{get:()=>n[i],enumerable:!(o=Lt(n,i))||o.enumerable});return e};var Y=(e,n,t)=>(t=e!=null?Qt(Bt(e)):{},An(n||!e||!e.__esModule?Ge(t,"default",{value:e,enumerable:!0}):t,e)),Ut=e=>An(Ge({},"__esModule",{value:!0}),e);var Nn=(e,n,t)=>{if(!n.has(e))throw TypeError("Cannot "+t)};var u=(e,n,t)=>(Nn(e,n,"read from private field"),t?t.call(e):n.get(e)),L=(e,n,t)=>{if(n.has(e))throw TypeError("Cannot add the same private member more than once");n instanceof WeakSet?n.add(e):n.set(e,t)},j=(e,n,t,o)=>(Nn(e,n,"write to private field"),o?o.call(e,t):n.set(e,t),t);var zo={};Mt(zo,{ColumnExpressionInput:()=>En,ColumnNamedTerms:()=>Ze,ColumnSettingsPanel:()=>Yo,DataSourceStats:()=>Mo,DatagridSettingsPanel:()=>$o,columnExpressionLanguageSupport:()=>rn,isCompleteExpression:()=>dn,isCompleteRelationalExpression:()=>gn,lastNamedChild:()=>Je,useColumnExpressionEditor:()=>yn,useColumnExpressionSuggestionProvider:()=>On,walkTree:()=>mn});module.exports=Ut(zo);var A=require("@vuu-ui/vuu-utils"),Fn=Y(require("classnames"),1);var te=require("@vuu-ui/vuu-utils"),We=require("react"),Gt=[void 0,void 0,void 0,void 0];function kn(e,n,t){var x;let o=(0,We.useRef)(),[i,r,s,p]=o.current||Gt,{type:l}=t,c=(0,te.isTypeDescriptor)(l)?(x=l.formatting)==null?void 0:x.decimals:void 0,g=e===i&&(0,te.isValidNumber)(n)&&(0,te.isValidNumber)(r)&&t===s?(0,te.getMovingValueDirection)(n,p,r,c):"";return(0,We.useEffect)(()=>{o.current=[e,n,t,g]}),g}var Xe=require("react/jsx-runtime"),Wt=String.fromCharCode(11014),Ht=String.fromCharCode(11015),{KEY:Xt}=A.metadataKeys,He="vuuBackgroundCell",we={ArrowOnly:"arrow",BackgroundOnly:"bg-only",ArrowBackground:"arrow-bg"},Vt=e=>(0,A.isTypeDescriptor)(e)&&e.renderer&&"flashStyle"in e.renderer?e.renderer.flashStyle:we.BackgroundOnly,Yt=({column:e,row:n})=>{let{key:t,type:o,valueFormatter:i}=e,r=n[t],s=Vt(o),p=kn(n[Xt],r,e),l=s===we.ArrowOnly||s===we.ArrowBackground?p===A.UP1||p===A.UP2?Wt:p===A.DOWN1||p===A.DOWN2?Ht:null:null,c=p?" "+p:"",g=(0,Fn.default)(He,c,{[`${He}-arrowOnly`]:s===we.ArrowOnly,[`${He}-arrowBackground`]:s===we.ArrowBackground});return(0,Xe.jsxs)("div",{className:g,tabIndex:-1,children:[(0,Xe.jsx)("div",{className:`${He}-flasher`,children:l}),i(n[e.key])]})};(0,A.registerComponent)("background",Yt,"cell-renderer",{serverDataType:["long","int","double"]});var ue=require("@vuu-ui/vuu-utils"),Qn=Y(require("classnames"),1);var oe=require("react/jsx-runtime"),Re="vuuProgressCell",zt=({column:e,columnMap:n,row:t})=>{let{type:o}=e,i=t[e.key],r=!1,s=0;if((0,ue.isTypeDescriptor)(o)&&(0,ue.isColumnTypeRenderer)(o.renderer)){let{associatedField:l}=o.renderer,c=t[n[l]];if(typeof i=="number"&&typeof c=="number")s=Math.min(Math.round(i/c*100),100),r=isFinite(s);else{let g=parseFloat(i);if(Number.isFinite(g)){let x=parseFloat(c);Number.isFinite(x)&&(s=Math.min(Math.round(g/x*100),100),r=isFinite(s))}}}let p=(0,Qn.default)(Re,{});return(0,oe.jsxs)("div",{className:p,tabIndex:-1,children:[r?(0,oe.jsxs)("span",{className:`${Re}-track`,children:[(0,oe.jsx)("span",{className:`${Re}-bg`}),(0,oe.jsx)("span",{className:`${Re}-bar`,style:{"--progress-bar-pct":`-${100-s}%`}})]}):null,(0,oe.jsx)("span",{className:`${Re}-text`,children:`${s} %`})]})};(0,ue.registerComponent)("vuu.progress",zt,"cell-renderer",{serverDataType:["long","int","double"]});var S=require("@vuu-ui/vuu-codemirror"),bn=require("@vuu-ui/vuu-utils"),ee=require("react");var I=require("@vuu-ui/vuu-codemirror");var Ln=require("@lezer/lr"),Ve=Ln.LRParser.deserialize({version:14,states:"&fOVQPOOO!SQPO'#C^OVQPO'#CcQ!pQPOOO#OQPO'#CkO#TQPO'#CrOOQO'#Cy'#CyO#YQPO,58}OVQPO,59QOVQPO,59QOVQPO,59VOVQPO'#CtOOQO,59^,59^OOQO1G.i1G.iOOQO1G.l1G.lO#kQPO1G.lO$fQPO'#CmO%WQQO1G.qOOQO'#C{'#C{O%cQPO,59`OOQO'#Cn'#CnO%wQPO,59XOVQPO,59ZOVQPO,59[OVQPO7+$]OVQPO'#CuO&`QPO1G.zOOQO1G.z1G.zO&hQQO'#C^O&rQQO1G.sO'ZQQO1G.uOOQO1G.v1G.vO'fQPO<<GwO'wQPO,59aOOQO-E6s-E6sOOQO7+$f7+$fOVQPOAN=cO(]QQO1G.lO(tQPOG22}OOQOLD(iLD(iO%wQPO,59QO%wQPO,59Q",stateData:")[~OlOS~ORUOSUOTUOUUOWQO`SOnPO~OWgXZQX[QX]QX^QXeQX~OjQXXQXpQXqQXrQXsQXtQXuQX~PnOZWO[WO]XO^XO~OWYO~OWZO~OX]OZWO[WO]XO^XO~OZWO[WO]Yi^YijYiXYipYiqYirYisYitYiuYieYi~OZWO[WO]XO^XOpdOqdOrdOsdOtdOudO~OehOvfOwgO~OXkOZWO[WO]XO^XOeiO~ORUOSUOTUOUUOWQO`SOnlO~OXsOeiO~OvQXwQX~PnOZxO[xO]yO^yOeaivaiwai~OwgOecivci~OZWO[WO]XO^XOetO~OZWO[WO]XO^XOXiaeia~OZxO[xO]Yi^YieYivYiwYi~OXwOZWO[WO]XO^XO~O`UTn~",goto:"#spPPqPPPPqPPqPPPPqP!R!W!R!RPq!Z!k!nPPP!tP#jmUOQWXYZefghitxyVbYfgRe`mTOQWXYZefghitxyR[TQjcRrjQROQVQS^WxQ_XU`YfgQcZQmeQphQqiQuyRvtQaYQnfRog",nodeNames:"\u26A0 ColumnDefinitionExpression Column Number String True False ParenthesizedExpression OpenBrace CloseBrace ArithmeticExpression Divide Times Plus Minus ConditionalExpression If RelationalExpression RelationalOperator AndCondition OrCondition Comma CallExpression Function ArgList",maxTerm:39,skippedNodes:[0],repeatNodeCount:1,tokenData:".^~RnXY#PYZ#P]^#Ppq#Pqr#brs#mxy$eyz$jz{$o{|$t|}$y}!O%O!O!P%T!P!Q%c!Q![%h!^!_%s!_!`&Q!`!a&V!c!}&d#R#S&d#T#U&u#U#Y&d#Y#Z(Y#Z#]&d#]#^*j#^#c&d#c#d+f#d#h&d#h#i,b#i#o&d~#USl~XY#PYZ#P]^#Ppq#P~#eP!_!`#h~#mOu~~#pWOX#mZ]#m^r#mrs$Ys#O#m#P;'S#m;'S;=`$_<%lO#m~$_OS~~$bP;=`<%l#m~$jOW~~$oOX~~$tO[~~$yO]~~%OOe~~%TO^~~%WP!Q![%Z~%`PR~!Q![%Z~%hOZ~~%mQR~!O!P%Z!Q![%h~%xPr~!_!`%{~&QOt~~&VOp~~&[Pq~!_!`&_~&dOs~P&iSnP!Q![&d!c!}&d#R#S&d#T#o&dR&zUnP!Q![&d!c!}&d#R#S&d#T#b&d#b#c'^#c#o&dR'cUnP!Q![&d!c!}&d#R#S&d#T#W&d#W#X'u#X#o&dR'|SvQnP!Q![&d!c!}&d#R#S&d#T#o&d~(_TnP!Q![&d!c!}&d#R#S&d#T#U(n#U#o&d~(sUnP!Q![&d!c!}&d#R#S&d#T#`&d#`#a)V#a#o&d~)[UnP!Q![&d!c!}&d#R#S&d#T#g&d#g#h)n#h#o&d~)sUnP!Q![&d!c!}&d#R#S&d#T#X&d#X#Y*V#Y#o&d~*^SU~nP!Q![&d!c!}&d#R#S&d#T#o&d~*oUnP!Q![&d!c!}&d#R#S&d#T#Y&d#Y#Z+R#Z#o&d~+YS`~nP!Q![&d!c!}&d#R#S&d#T#o&dR+kUnP!Q![&d!c!}&d#R#S&d#T#f&d#f#g+}#g#o&dR,USwQnP!Q![&d!c!}&d#R#S&d#T#o&d~,gUnP!Q![&d!c!}&d#R#S&d#T#f&d#f#g,y#g#o&d~-OUnP!Q![&d!c!}&d#R#S&d#T#i&d#i#j-b#j#o&d~-gUnP!Q![&d!c!}&d#R#S&d#T#X&d#X#Y-y#Y#o&d~.QST~nP!Q![&d!c!}&d#R#S&d#T#o&d",tokenizers:[0,1],topRules:{ColumnDefinitionExpression:[0,1]},tokenPrec:375});var Zt=I.LRLanguage.define({name:"VuuColumnExpression",parser:Ve.configure({props:[(0,I.styleTags)({Function:I.tags.variableName,String:I.tags.string,Or:I.tags.emphasis,Operator:I.tags.operator})]})}),rn=()=>new I.LanguageSupport(Zt);var sn=class{constructor(n){switch(this.value=n,typeof n){case"boolean":this.type="booleanLiteralExpression";break;case"number":this.type="numericLiteralExpression";break;default:this.type="stringLiteralExpression"}}toJSON(){return{type:this.type,value:this.value}}},an=class{constructor(n){this.type="colExpression";this.column=n}toJSON(){return{type:this.type,column:this.column}}},Ne,se,ln=class{constructor(n="unknown"){L(this,Ne,[{type:"unknown"},{type:"unknown"}]);L(this,se,void 0);this.type="arithmeticExpression";j(this,se,n)}get op(){return u(this,se)}set op(n){j(this,se,n)}get expressions(){return u(this,Ne)}toJSON(){return{type:this.type,op:u(this,se),expressions:u(this,Ne)}}};Ne=new WeakMap,se=new WeakMap;var fe,pn=class{constructor(n){L(this,fe,[]);this.type="callExpression";this.functionName=n}get expressions(){return u(this,fe)}get arguments(){return u(this,fe)}toJSON(){return{type:this.type,functionName:this.functionName,arguments:u(this,fe).map(n=>{var t;return(t=n.toJSON)==null?void 0:t.call(n)})}}};fe=new WeakMap;var ke,Ce,de=class{constructor(){L(this,ke,[{type:"unknown"},{type:"unknown"}]);L(this,Ce,"unknown");this.type="relationalExpression"}get op(){return u(this,Ce)}set op(n){j(this,Ce,n)}get expressions(){return u(this,ke)}toJSON(){return{type:this.type,op:u(this,Ce),expressions:u(this,ke)}}};ke=new WeakMap,Ce=new WeakMap;var Fe,xe,ge=class{constructor(n){L(this,Fe,[{type:"unknown"},{type:"unknown"}]);L(this,xe,void 0);this.type="booleanCondition";j(this,xe,n)}get op(){return u(this,xe)}get expressions(){return u(this,Fe)}toJSON(){return{type:this.type,op:u(this,xe),expressions:u(this,Fe).map(n=>{var t;return(t=n.toJSON)==null?void 0:t.call(n)})}}};Fe=new WeakMap,xe=new WeakMap;var M,Ae=class{constructor(n){L(this,M,void 0);this.type="conditionalExpression";j(this,M,[n?new ge(n):new de,{type:"unknown"},{type:"unknown"}])}get expressions(){return u(this,M)}get condition(){return u(this,M)[0]}get truthyExpression(){return u(this,M)[1]}set truthyExpression(n){u(this,M)[1]=n}get falsyExpression(){return u(this,M)[2]}set falsyExpression(n){u(this,M)[2]=n}toJSON(){var n,t,o,i,r;return{type:this.type,condition:(t=(n=this.condition).toJSON)==null?void 0:t.call(n),truthyExpression:this.truthyExpression,falsyExpression:(r=(i=(o=this.falsyExpression)==null?void 0:o.toJSON)==null?void 0:i.call(o))!=null?r:this.falsyExpression}}};M=new WeakMap;var re=e=>e.type==="unknown",Ye=e=>e.type==="arithmeticExpression",Jt=e=>e.type==="callExpression",me=e=>e.type==="conditionalExpression",qt=e=>e.type==="relationalExpression"||e.type==="booleanCondition";var _t=e=>e.type==="booleanCondition",un=e=>(e==null?void 0:e.type)==="relationalExpression";var N=e=>{if(re(e))return e;if(un(e)){let[n,t]=e.expressions;if(D(n))return N(n);if(e.op==="unknown")return e;if(D(t))return N(t)}else if(qt(e)){let{expressions:n=[]}=e;for(let t of n)if(D(t))return N(t)}else if(me(e)){let{condition:n,truthyExpression:t,falsyExpression:o}=e;if(D(n))return N(n);if(D(t))return N(t);if(D(o))return N(o)}else if(Ye(e)){let{expressions:n=[]}=e;for(let t of n)if(D(t))return N(t)}},ze=(e,n,t)=>{let{expressions:o=[]}=e;if(o.includes(n)){let i=o.indexOf(n);return o.splice(i,1,t),!0}else for(let i of o)if(ze(i,n,t))return!0;return!1},D=e=>re(e)?!0:me(e)?D(e.condition)||D(e.truthyExpression)||D(e.falsyExpression):un(e)||_t(e)?e.op===void 0||e.expressions.some(n=>D(n)):!1,In=(e,n)=>{let t=N(e);t?t.expressions?t.expressions.push(n):console.warn("don't know how to treat targetExpression"):console.error("no target expression found")},C,ie,cn=class{constructor(){L(this,C,void 0);L(this,ie,[])}setCondition(n){if(u(this,C)===void 0)this.addExpression(new Ae(n));else if(me(u(this,C))){if(D(u(this,C).condition)){let t=n?new ge(n):new de;this.addExpression(t)}else if(re(u(this,C).truthyExpression))u(this,C).truthyExpression=new Ae(n);else if(D(u(this,C).truthyExpression)){let t=n?new ge(n):new de;this.addExpression(t)}else if(re(u(this,C).falsyExpression))u(this,C).falsyExpression=new Ae(n);else if(D(u(this,C).falsyExpression)){let t=n?new ge(n):new de;this.addExpression(t)}}else console.error("setCondition called unexpectedly")}addExpression(n){if(u(this,ie).length>0){let t=u(this,ie).at(-1);t==null||t.arguments.push(n)}else if(u(this,C)===void 0)j(this,C,n);else if(Ye(u(this,C))){let t=N(u(this,C));t&&re(t)&&ze(u(this,C),t,n)}else if(me(u(this,C))&&D(u(this,C))){let t=N(u(this,C));t&&re(t)?ze(u(this,C),t,n):t&&In(t,n)}}setFunction(n){let t=new pn(n);this.addExpression(t),u(this,ie).push(t)}setColumn(n){this.addExpression(new an(n))}setArithmeticOp(n){let t=n,o=u(this,C);Ye(o)&&(o.op=t)}setRelationalOperator(n){let t=n;if(u(this,C)&&me(u(this,C))){let o=N(u(this,C));un(o)?o.op=t:console.error(`no target expression found (op = ${n})`)}}setValue(n){let t=new sn(n);if(u(this,C)===void 0)j(this,C,t);else if(Ye(u(this,C)))this.addExpression(t);else if(Jt(u(this,C)))u(this,C).arguments.push(t);else if(me(u(this,C)))if(D(u(this,C))){let o=N(u(this,C));o&&re(o)?ze(u(this,C),o,t):o&&In(o,t)}else console.log("what do we do with value, in a complete expression")}closeBrace(){u(this,ie).pop()}get expression(){return u(this,C)}toJSON(){var n;return(n=u(this,C))==null?void 0:n.toJSON()}};C=new WeakMap,ie=new WeakMap;var mn=(e,n)=>{let t=new cn,o=e.cursor();do{let{name:i,from:r,to:s}=o;switch(i){case"AndCondition":t.setCondition("and");break;case"OrCondition":t.setCondition("or");break;case"RelationalExpression":t.setCondition();break;case"ArithmeticExpression":t.addExpression(new ln);break;case"Column":{let p=n.substring(r,s);t.setColumn(p)}break;case"Function":{let p=n.substring(r,s);t.setFunction(p)}break;case"Times":case"Divide":case"Plus":case"Minus":{let p=n.substring(r,s);t.setArithmeticOp(p)}break;case"RelationalOperator":{let p=n.substring(r,s);t.setRelationalOperator(p)}break;case"False":case"True":{let p=n.substring(r,s);t.setValue(p==="true")}break;case"String":t.setValue(n.substring(r+1,s-1));break;case"Number":t.setValue(parseFloat(n.substring(r,s)));break;case"CloseBrace":t.closeBrace();break;default:}}while(o.next());return t.toJSON()};var Kt=Ve.configure({strict:!0}),Bn=["Number","String"],Ze=[...Bn,"AndCondition","ArithmeticExpression","BooleanOperator","RelationalOperatorOperator","CallExpression","CloseBrace","Column","Comma","ConditionalExpression","Divide","Equal","If","Minus","OpenBrace","OrCondition","ParenthesizedExpression","Plus","RelationalExpression","RelationalOperator","Times"],dn=e=>{try{return Kt.parse(e),!0}catch{return!1}},Je=e=>{let{lastChild:n}=e;for(;n&&!Ze.includes(n.name);)n=n.prevSibling,console.log(n==null?void 0:n.name);return n},gn=e=>{if((e==null?void 0:e.name)==="RelationalExpression"){let{firstChild:n}=e,t=Je(e);if((n==null?void 0:n.name)==="Column"&&typeof(t==null?void 0:t.name)=="string"&&Bn.includes(t.name))return!0}return!1};var ae=require("@vuu-ui/vuu-codemirror"),jt=ae.HighlightStyle.define([{tag:ae.tags.variableName,color:"var(--vuuFilterEditor-variableColor)"},{tag:ae.tags.comment,color:"green",fontStyle:"italic"}]),$n=(0,ae.syntaxHighlighting)(jt);var Mn=require("@vuu-ui/vuu-codemirror"),Un=Mn.EditorView.theme({"&":{border:"solid 1px var(--salt-container-primary-borderColor)",color:"var(--vuuFilterEditor-color)",backgroundColor:"var(--vuuFilterEditor-background)"},".cm-content":{caretColor:"var(--vuuFilterEditor-cursorColor)"},"&.cm-focused .cm-cursor":{borderLeftColor:"var(--vuuFilterEditor-cursorColor)"},"&.cm-focused .cm-selectionBackground, ::selection":{backgroundColor:"var(--vuuFilterEditor-selectionBackground)"},".cm-selectionBackground, ::selection":{backgroundColor:"var(--vuuFilterEditor-selectionBackground)"},".cm-scroller":{fontFamily:"var(--vuuFilterEditor-fontFamily)"},".cm-tooltip":{background:"var(--vuuFilterEditor-tooltipBackground)",border:"var(--vuuFilterEditor-tooltipBorder)",boxShadow:"var(--vuuFilterEditor-tooltipElevation)","&.cm-tooltip-autocomplete > ul":{fontFamily:"var(--vuuFilterEditor-fontFamily)",fontSize:"var(--vuuFilterEditor-fontSize)",maxHeight:"240px"},"&.cm-tooltip-autocomplete > ul > li":{height:"var(--vuuFilterEditor-suggestion-height)",padding:"0 3px",lineHeight:"var(--vuuFilterEditor-suggestion-height)"},"&.cm-tooltip-autocomplete li[aria-selected]":{background:"var(--vuuFilterEditor-suggestion-selectedBackground)",color:"var(--vuuFilterEditor-suggestion-selectedColor)"},"&.cm-tooltip-autocomplete li .cm-completionDetail":{color:"var(--vuuFilterEditor-suggestion-detailColor)"}}},{dark:!1});var T=require("@vuu-ui/vuu-codemirror"),xn=require("react");var eo=(e,n)=>n?e.map(t=>{var o;return{...t,apply:typeof t.apply=="function"?t.apply:`${n}${(o=t.apply)!=null?o:t.label}`}}):e,no=e=>e===void 0?!1:["Times","Divide","Plus","Minus"].includes(e.name),he=(e,n)=>{var i;let{lastChild:t}=e,{pos:o}=n;for(;t;)if(t.from<o&&Ze.includes(t.name)){if(t.name==="ParenthesizedExpression"){let s=(i=t.firstChild)==null?void 0:i.nextSibling;s&&(t=s)}return t}else t=t.prevSibling},Gn=(e,n)=>{var t;if(e.name==="ArgList"){let o=e.prevSibling;if(o)return(0,T.getValue)(o,n)}else if(e.name==="OpenBrace"){let o=(t=e.parent)==null?void 0:t.prevSibling;if((o==null?void 0:o.name)==="Function")return(0,T.getValue)(o,n)}},Wn=(e,n)=>{if(e.name==="RelationalExpression"){let t=Je(e);if((t==null?void 0:t.name)==="RelationalOperator")return(0,T.getValue)(t,n)}else{let t=e.prevSibling;if((t==null?void 0:t.name)==="RelationalOperator")return(0,T.getValue)(t,n)}},hn=(e,n)=>{var t;if(e.name==="RelationalExpression"){if(((t=e.firstChild)==null?void 0:t.name)==="Column")return(0,T.getValue)(e.firstChild,n)}else{let o=e.prevSibling;if((o==null?void 0:o.name)==="Column")return(0,T.getValue)(o,n);if((o==null?void 0:o.name)==="RelationalOperator")return hn(o,n)}},fn=async(e,n,t,o={})=>{let i=await n.getSuggestions(t,o),{startsWith:r=""}=o;return{from:e.pos-r.length,options:i}},Cn=(e,n,t,o,i)=>{let r=he(e,n);switch(console.log(`conditional expression last child ${r==null?void 0:r.name}`),r==null?void 0:r.name){case"If":return fn(n,t,"expression",{prefix:"( "});case"OpenBrace":return fn(n,t,"expression");case"Condition":return fn(n,t,"expression",{prefix:", "});case"CloseBrace":if(o){let s=[{apply:()=>{i==null||i()},label:"Save Expression",boost:10}];return{from:n.pos,options:s}}}},to=(e,n)=>{let t=[{apply:()=>{n==null||n()},label:"Save Expression",boost:10}];return{from:e.pos,options:t}},Hn=(e,n)=>{let t=(0,xn.useCallback)(async(o,i,r={})=>{let s=await e.getSuggestions(i,r),{startsWith:p=""}=r;return{from:o.pos-p.length,options:s}},[e]);return(0,xn.useCallback)(async o=>{var x,h;let{state:i,pos:r}=o,s=(x=o.matchBefore(/\w*/))!=null?x:{from:0,to:0,text:void 0},l=(0,T.syntaxTree)(i).resolveInner(r,-1),c=i.doc.toString(),g=dn(c);switch(console.log({nodeBeforeName:l.name}),l.name){case"If":return console.log("conditional expression If"),t(o,"expression",{prefix:"( "});case"Condition":{let a=he(l,o);if((a==null?void 0:a.name)==="Column"){let d=(0,T.getPreviousNode)(a);if((d==null?void 0:d.name)!=="RelationalOperator")return t(o,"condition-operator",{columnName:(0,T.getValue)(a,i)});console.log(`Condition last child Column, prev child ${d==null?void 0:d.name}`)}else if((a==null?void 0:a.name)==="RelationalOperator")return t(o,"expression");console.log(`condition last child ${a==null?void 0:a.name}`)}break;case"ConditionalExpression":return Cn(l,o,e);case"RelationalExpression":{if(gn(l))return{from:o.pos,options:T.booleanJoinSuggestions.concat({label:", <truthy expression>, <falsy expression>",apply:", "})};{let a=Wn(l,i),d=hn(l,i);if(a)return t(o,"expression");{let f=await e.getSuggestions("condition-operator",{columnName:d});return{from:o.pos,options:f}}}}break;case"RelationalOperator":return t(o,"expression");case"String":{let a=Wn(l,i),d=hn(l,i),{from:f,to:m}=l;if(m-f===2&&o.pos===f+1){if(d&&a)return t(o,"columnValue",{columnName:d,operator:a,startsWith:s.text})}else if(m-f>2&&o.pos===m)return t(o,"expression",{prefix:", "});console.log(`we have a string, column is ${d} ${f} ${m}`)}break;case"ArithmeticExpression":{let a=he(l,o);if((a==null?void 0:a.name)==="Column")return t(o,"expression");if(no(a)){let d=a.name;return t(o,"column",{operator:d})}}break;case"OpenBrace":{let a=Gn(l,i);return t(o,"expression",{functionName:a})}break;case"ArgList":{let a=Gn(l,i),d=he(l,o),f=(d==null?void 0:d.name)==="OpenBrace"?void 0:",",m=await e.getSuggestions("expression",{functionName:a});return m=f?eo(m,", "):m,(d==null?void 0:d.name)!=="OpenBrace"&&(d==null?void 0:d.name)!=="Comma"&&(m=[{apply:") ",boost:10,label:"Done - no more arguments"}].concat(m)),{from:o.pos,options:m}}case"Equal":if(c.trim()==="=")return t(o,"expression");break;case"ParenthesizedExpression":case"ColumnDefinitionExpression":if(o.pos===0)return t(o,"expression");{let a=he(l,o);if((a==null?void 0:a.name)==="Column"){if(g){let d=[{apply:()=>{n.current()},label:"Save Expression",boost:10}],f=(0,T.getValue)(a,i),m=await e.getSuggestions("operator",{columnName:f});return{from:o.pos,options:d.concat(m)}}}else if((a==null?void 0:a.name)==="CallExpression"){if(g){let d=[{apply:()=>{n.current()},label:"Save Expression",boost:10}];return{from:o.pos,options:d}}}else if((a==null?void 0:a.name)==="ArithmeticExpression"){if(g){let d=[{apply:()=>{n.current()},label:"Save Expression",boost:10}],f=he(a,o);if((f==null?void 0:f.name)==="Column"){let m=(0,T.getValue)(f,i),P=await e.getSuggestions("operator",{columnName:m});d=d.concat(P)}return{from:o.pos,options:d}}}else if((a==null?void 0:a.name)==="ConditionalExpression")return Cn(a,o,e,g,n.current);break}case"Column":if(await e.isPartialMatch("expression",void 0,s.text))return t(o,"expression",{startsWith:s.text});break;case"Comma":{let a=(0,T.getNamedParentNode)(l);if((a==null?void 0:a.name)==="ConditionalExpression")return t(o,"expression")}break;case"CloseBrace":{let a=(0,T.getNamedParentNode)(l);if((a==null?void 0:a.name)==="ConditionalExpression")return Cn(a,o,e,g,n.current);if((a==null?void 0:a.name)==="ArgList"&&g)return to(o,n.current);console.log(`does closebrace denote an ARgList or a parenthetised expression ? ${a}`)}break;default:((h=l==null?void 0:l.prevSibling)==null?void 0:h.name)==="FilterClause"&&console.log("looks like we ight be a or|and operator")}},[t,n,e])};var Qe=e=>{if(e.current==null)throw Error("EditorView not defined");return e.current},oo=()=>"vuuSuggestion",ro=()=>console.log("noooop"),so=e=>"expressionType"in e,io=e=>{if(so(e)){let n=(0,bn.createEl)("div","expression-type-container"),t=(0,bn.createEl)("span","expression-type",e.expressionType);return n.appendChild(t),n}else return null},yn=({onChange:e,onSubmitExpression:n,suggestionProvider:t})=>{let o=(0,ee.useRef)(null),i=(0,ee.useRef)(ro),r=(0,ee.useRef)(),s=Hn(t,i),[p,l]=(0,ee.useMemo)(()=>{let c=()=>{let f=Qe(r),m=f.state.doc.toString(),P=(0,S.ensureSyntaxTree)(f.state,f.state.doc.length,5e3);if(P){let R=mn(P,m);return[m,R]}else return["",void 0]},g=()=>{Qe(r).setState(d())},x=()=>{let[f,m]=c();n==null||n(f,m),g()},h=f=>S.keymap.of([{key:f,run(){return x(),!0}}]),a=f=>S.keymap.of([{key:f,run(){return(0,S.startCompletion)(Qe(r)),!0}}]),d=()=>S.EditorState.create({doc:"",extensions:[S.minimalSetup,(0,S.autocompletion)({addToOptions:[{render:io,position:70}],override:[s],optionClass:oo}),rn(),S.keymap.of(S.defaultKeymap),h("Ctrl-Enter"),a("ArrowDown"),S.EditorView.updateListener.of(f=>{let m=Qe(r);if(f.docChanged){(0,S.startCompletion)(m);let P=m.state.doc.toString();e==null||e(P,void 0)}}),Un,$n]});return i.current=()=>{x(),setTimeout(()=>{Qe(r).focus()},100)},[d,g]},[s,e,n]);return(0,ee.useEffect)(()=>{if(!o.current)throw Error("editor not in dom");return r.current=new S.EditorView({state:p(),parent:o.current}),()=>{var c;(c=r.current)==null||c.destroy()}},[s,p]),{editorRef:o,clearInput:l}};var Xn=require("react/jsx-runtime"),ao="vuuColumnExpressionInput",En=({onChange:e,onSubmitExpression:n,suggestionProvider:t})=>{let{editorRef:o}=yn({onChange:e,onSubmitExpression:n,suggestionProvider:t});return(0,Xn.jsx)("div",{className:`${ao}`,ref:o})};var G=require("@vuu-ui/vuu-codemirror"),qe=require("@vuu-ui/vuu-data-react"),Ee=require("@vuu-ui/vuu-utils"),ye=require("react");var be=[{accepts:"string",description:"Returns multiple string values as a single joined string. Arguments may be string literal values, string columns or other string expressions. Non string arguments may also be included, these will be converted to strings.",example:{expression:'concatenate("example", "-test")',result:'"example-test"'},name:"concatenate",params:{description:"( string, string, [ string* ] )"},type:"string"},{accepts:["string","string"],description:"Tests a string value to determine whether it contains a given substring. Accepts two arguments: source text and target substring. Returns true if <source text> contains one or more occurrences of <target subscring>",example:{expression:'contains("Royal Bank of Scotland", "bank")',result:"true"},name:"contains",params:{description:"( string )"},type:"boolean"},{accepts:["string","number"],description:"Returns the leftmost <number> characters from <string>. First argument may be a string literal, string column or other string expression.",example:{expression:'left("USD Benchmark Report", 3)',result:'"USD"'},name:"left",params:{count:2,description:"( string, number )"},type:"string"},{accepts:"string",description:"Returns the number of characters in <string>. Argument may be a string literal, string column or other string expression.",example:{expression:'len("example")',result:"7"},name:"len",params:{description:"(string)"},type:"number"},{accepts:"string",description:"Convert a string value to lowercase. Argument may be a string column or other string expression.",example:{expression:'lower("examPLE")',result:'"example"'},name:"lower",params:{description:"( string )"},type:"string"},{accepts:"string",description:"Convert a string value to uppercase. Argument may be a string column or other string expression.",example:{expression:'upper("example")',result:'"EXAMPLE"'},name:"upper",params:{description:"( string )"},type:"string"},{accepts:["string","number"],description:"Returns the rightmost <number> characters from <string>. First argument may be a string literal, string column or other string expression.",example:{expression:"blah",result:"blah"},name:"right",params:{description:"( string )"},type:"string"},{accepts:["string","string","string"],description:"Replace characters within a string. Accepts three arguments: source text, text to replace and replacement text. Returns a copy of <source text> with any occurrences of <text to replace> replaced by <replacement text>",example:{expression:"blah",result:"blah"},name:"replace",params:{description:"( string )"},type:"string"},{accepts:"number",description:"Converts a number to a string.",example:{expression:"blah",result:"blah"},name:"text",params:{description:"( string )"},type:"string"},{accepts:"string",description:"Tests a string value to determine whether it starts with a given substring. Accepts two arguments: source text and target substring. Returns true if <source text> starts with <target subscring>.",example:{expression:"blah",result:"blah"},name:"starts",params:{description:"( string )"},type:"boolean"},{accepts:"string",description:"Tests a string value to determine whether it ends with a given substring. Accepts two arguments: source text and target substring. Returns true if <source text> ends with <target subscring>.",example:{expression:"blah",result:"blah"},name:"ends",params:{description:"( string )"},type:"boolean"},{accepts:"number",description:"blah",example:{expression:"blah",result:"blah"},name:"min",params:{description:"( string )"},type:"number"},{accepts:"number",description:"blah",example:{expression:"blah",result:"blah"},name:"max",params:{description:"( string )"},type:"number"},{accepts:"number",description:"blah",example:{expression:"blah",result:"blah"},name:"sum",params:{description:"( string )"},type:"number"},{accepts:"number",description:"blah",example:{expression:"blah",result:"blah"},name:"round",params:{description:"( string )"},type:"number"},{accepts:"any",description:"blah",example:{expression:"blah",result:"blah"},name:"or",params:{description:"( string )"},type:"boolean"},{accepts:"any",description:"blah",example:{expression:"blah",result:"blah"},name:"and",params:{description:"( string )"},type:"boolean"},{accepts:"any",description:"Return one of two possible result values, depending on the evaluation of a filter expression. If <filterExpression> resolves to true, result is <expression1>, otherwise <expression2>. ",example:{expression:"blah",result:"blah"},name:"if",params:{description:"( filterExpression, expression1, expression 2)"},type:"variable"}];var U=require("@vuu-ui/vuu-utils"),Vn=({name:e,description:n,example:t,params:o,type:i})=>{let r=(0,U.createEl)("div","vuuFunctionDoc"),s=(0,U.createEl)("div","function-heading"),p=(0,U.createEl)("span","function-name",e),l=(0,U.createEl)("span","param-list",o.description),c=(0,U.createEl)("span","function-type",i);s.appendChild(p),s.appendChild(l),s.appendChild(c);let g=(0,U.createEl)("p",void 0,n);if(r.appendChild(s),r.appendChild(g),t){let x=(0,U.createEl)("div","example-container","Example:"),h=(0,U.createEl)("div","example-expression",t.expression),a=(0,U.createEl)("div","example-result",t.result);x.appendChild(h),x.appendChild(a),r.appendChild(x)}return r};var lo=[],le=e=>e.map(n=>{var t;return{...n,apply:((t=n.apply)!=null?t:n.label)+" "}}),po=(e,{functionName:n,operator:t})=>{if(t)return e.filter(Ee.isNumericColumn);if(n){let o=be.find(i=>i.name===n);if(o)switch(o.accepts){case"string":return e.filter(Ee.isTextColumn);case"number":return e.filter(Ee.isNumericColumn);default:return e}}return e},Yn=(e,n)=>po(e,n).map(o=>{var r;let i=(r=o.label)!=null?r:o.name;return{apply:n.prefix?`${n.prefix}${i}`:i,label:i,boost:5,type:"column",expressionType:o.serverDataType}}),co=[{apply:"* ",boost:2,label:"*",type:"operator"},{apply:"/ ",boost:2,label:"/",type:"operator"},{apply:"+ ",boost:2,label:"+",type:"operator"},{apply:"- ",boost:2,label:"-",type:"operator"}],uo=e=>e===void 0||(0,Ee.isNumericColumn)(e)?co:lo,mo=e=>{switch(e.serverDataType){case"string":case"char":return le(G.stringOperators);case"int":case"long":case"double":return le(G.numericOperators)}},vn=e=>({apply:`${e.name}( `,boost:2,expressionType:e.type,info:()=>Vn(e),label:e.name,type:"function"}),go=e=>{if(e){if(typeof e.accepts=="string")return e.accepts;if(Array.isArray(e.accepts))return e.accepts.every(n=>n==="string")?"string":"any"}return"any"},fo=be.map(vn),Co=({functionName:e})=>{if(e){let n=be.find(o=>o.name===e),t=go(n);if(n)switch(t){case"string":return be.filter(o=>o.type==="string"||o.type==="variable").map(vn);case"number":return be.filter(o=>o.type==="number"||o.type==="variable").map(vn);default:}}return fo},xo={},On=({columns:e,table:n})=>{let t=(0,ye.useCallback)(p=>p?e.find(l=>l.name===p):void 0,[e]),o=(0,ye.useRef)(),i=(0,qe.useTypeaheadSuggestions)(),r=(0,ye.useCallback)(async(p,l=xo)=>{let{columnName:c,functionName:g,operator:x,prefix:h}=l;switch(p){case"expression":{let a=await le(Yn(e,{functionName:g,prefix:h})).concat(Co(l));return o.current=a}case"column":{let a=await Yn(e,l);return o.current=le(a)}case"operator":{let a=await uo(t(c));return o.current=le(a)}case"relational-operator":{let a=await(0,G.getRelationalOperators)(t(c));return o.current=le(a)}case"condition-operator":{let a=t(c);if(a){let d=await mo(a);if(d)return o.current=le(d)}}break;case"columnValue":if(c&&x){let a=(0,qe.getTypeaheadParams)(n,c),d=await i(a);return o.current=(0,G.toSuggestions)(d,{suffix:""}),o.current.forEach(f=>{f.apply=(m,P,R)=>{let X=new G.AnnotationType,De=R+P.label.length+1;m.dispatch({changes:{from:R,insert:P.label},selection:{anchor:De,head:De},annotations:X.of(P)})}}),o.current}break}return[]},[e,t,i,n]),s=(0,ye.useCallback)(async(p,l,c)=>{let{current:g}=o,x=!1,h=g||await r(p,{columnName:l});if(c&&h)for(let a of h){if(a.label===c)return!1;a.label.startsWith(c)&&(x=!0)}return x},[r]);return{getSuggestions:r,isPartialMatch:s}};var Te=require("@salt-ds/core"),xt=Y(require("classnames"),1),q=require("react");var Pn=require("@heswell/salt-lab"),B=require("@salt-ds/core"),W=require("react");var zn=require("@heswell/salt-lab"),Zn=Y(require("classnames"),1);var Oe=require("react/jsx-runtime"),ve="vuuColumnListItem",Jn=({className:e,item:n,label:t,style:o,...i})=>{let r=(0,Zn.default)(ve,e,{[`${ve}-calculated`]:n==null?void 0:n.expression,[`${ve}-hidden`]:n==null?void 0:n.hidden});return(0,Oe.jsxs)(zn.ListItem,{className:r,...i,children:[(0,Oe.jsx)("span",{className:`${ve}-iconType`}),(0,Oe.jsx)("label",{className:`${ve}-label`,children:t}),(0,Oe.jsx)("span",{className:`${ve}-iconHidden`})]})};var E=require("react/jsx-runtime"),Pe="vuuColumnPicker",ho=(e,n)=>e.filter(t=>n.find(o=>o.name===t.name)==null),qn=({availableColumns:e,id:n,dispatchColumnAction:t,onAddCalculatedColumnClick:o,onSelectionChange:i,chosenColumns:r,selectedColumn:s})=>{let[p,l]=(0,W.useState)([]),c=(0,B.useIdMemo)(n),g=ho(e,r),x=(0,W.useCallback)(()=>{p.length>0&&(l([]),t({type:"addColumn",columns:p}))},[t,p]),h=(0,W.useCallback)(()=>s&&t({type:"removeColumn",column:s}),[s,t]),a=(0,W.useCallback)(()=>s&&t({type:"moveColumn",column:s,moveBy:-1}),[t,s]),d=(0,W.useCallback)(()=>s&&t({type:"moveColumn",column:s,moveBy:1}),[t,s]),f=(0,W.useCallback)((R,X)=>l(X),[]),m=(0,W.useCallback)((R,X)=>i==null?void 0:i(X),[i]),P=(0,W.useCallback)((R,X)=>{t({type:"moveColumn",moveFrom:R,moveTo:X})},[t]);return(0,E.jsxs)("div",{className:Pe,id:c,children:[(0,E.jsxs)("div",{className:`${Pe}-listColumn`,children:[(0,E.jsx)("label",{htmlFor:`available-${c}`,children:(0,E.jsx)(B.Text,{as:"h4",children:"Available Columns"})}),(0,E.jsx)("div",{className:`${Pe}-listContainer`,style:{flex:1,overflow:"hidden"},children:(0,E.jsx)(Pn.List,{borderless:!0,checkable:!1,height:"100%",id:`available-${c}`,itemHeight:24,itemToString:R=>R.name,onSelectionChange:f,selected:p,selectionStrategy:"extended",source:g})}),(0,E.jsx)("div",{style:{display:"flex",alignItems:"center",flex:"0 0 32px",marginTop:"var(--salt-size-basis-unit)"},children:(0,E.jsxs)(B.Button,{onClick:x,disabled:p.length===0,children:["Show",(0,E.jsx)("span",{"data-icon":"arrow-thin-right",style:{marginLeft:8}})]})})]}),(0,E.jsxs)("div",{className:`${Pe}-listColumn`,children:[(0,E.jsx)("label",{htmlFor:`selected-${c}`,children:(0,E.jsx)(B.Text,{as:"h4",children:"Included Columns"})}),(0,E.jsx)("div",{className:`${Pe}-listContainer`,style:{flex:1,overflow:"hidden"},children:(0,E.jsx)(Pn.List,{ListItem:Jn,allowDragDrop:!0,borderless:!0,height:"100%",id:`selected-${c}`,itemHeight:24,itemToString:R=>R.name,onMoveListItem:P,onSelectionChange:m,selected:s,style:{flex:1},source:r})}),(0,E.jsxs)("div",{style:{alignItems:"center",flex:"0 0 32px",display:"flex",gap:6,marginTop:"var(--salt-size-basis-unit)"},children:[(0,E.jsxs)(B.Button,{onClick:h,disabled:s===null,children:[(0,E.jsx)("span",{"data-icon":"arrow-thin-left",style:{marginRight:8}}),"Hide"]}),(0,E.jsx)(B.Button,{"aria-label":"Move column up",onClick:a,disabled:s===null||(r==null?void 0:r.indexOf(s))===0,style:{width:28},children:(0,E.jsx)("span",{"data-icon":"arrow-thin-up"})}),(0,E.jsx)(B.Button,{"aria-label":"Move column down",onClick:d,disabled:s===null||r.indexOf(s)===r.length-1,style:{width:28},children:(0,E.jsx)("span",{"data-icon":"arrow-thin-down"})}),(0,E.jsx)(B.Button,{"aria-label":"Add calculated column",className:`${Pe}-addCalculatedColumn`,onClick:o,variant:"primary",children:(0,E.jsx)("span",{"data-icon":"add"})})]})]})]})};var lt=require("@vuu-ui/vuu-layout"),v=require("@heswell/salt-lab"),Ie=require("@salt-ds/core"),pt=Y(require("classnames"),1),Z=require("react");var nt=require("@vuu-ui/vuu-utils"),tt=require("@heswell/salt-lab"),ot=require("@salt-ds/core"),Tn=Y(require("classnames"),1),rt=require("react");var pe=require("@heswell/salt-lab"),_n=require("@salt-ds/core"),Le=require("react");var k=require("react/jsx-runtime"),bo={alignOnDecimals:!1,decimals:4,zeroPad:!1},yo=(e,n)=>{let t=typeof e=="object"&&e.formatting?e.formatting:{};return["alignOnDecimals","decimals","zeroPad"].reduce((i,r)=>t[r]!==void 0?{...i,[r]:t[r]}:(n==null?void 0:n[r])!==void 0?{...i,[r]:n[r]}:i,bo)},Kn=({column:e,dispatchColumnAction:n})=>{let{decimals:t,alignOnDecimals:o,zeroPad:i}=yo(e==null?void 0:e.type),r=(0,Le.useCallback)(c=>n({type:"updateColumnTypeFormatting",column:e,...c}),[e,n]),s=(0,Le.useCallback)(c=>r({decimals:parseInt(c.toString(),10)}),[r]),p=(0,Le.useCallback)((c,g)=>r({alignOnDecimals:g}),[r]),l=(0,Le.useCallback)((c,g)=>r({zeroPad:g}),[r]);switch(e.serverDataType){case"double":return(0,k.jsxs)(k.Fragment,{children:[(0,k.jsx)(pe.FormField,{label:"No of Decimals",labelPlacement:"top",children:(0,k.jsx)(pe.StepperInput,{value:t,onChange:s})}),(0,k.jsx)(pe.Switch,{checked:o,label:"Align on decimals",LabelProps:{className:"vuuColumnPanelSwitch"},onChange:p}),(0,k.jsx)(pe.Switch,{checked:i,label:"Zero pad",LabelProps:{className:"vuuColumnPanelSwitch"},onChange:l})]});case"long":case"int":return(0,k.jsx)(k.Fragment,{children:(0,k.jsx)(_n.Text,{children:"Work in progress"})});default:return null}};var _e=require("react/jsx-runtime"),jn=({column:e,dispatchColumnAction:n})=>(console.log({column:e,dispatchColumnAction:n}),(0,_e.jsx)(_e.Fragment,{children:"what"}));var z=require("react/jsx-runtime"),Sn="vuuColumnTypePanel",Eo=["Default Renderer (int, long)"],vo=["Default Renderer (double)"],et=["Default Renderer (string)"],Oo=e=>{let t=(0,nt.getRegisteredCellRenderers)(e.serverDataType).map(o=>o.name);switch(console.log({customRendererNames:t}),e.serverDataType){case"char":case"string":return et;case"int":case"long":return Eo;case"double":return vo.concat(t);default:return et}},st=({className:e,column:n,dispatchColumnAction:t,...o})=>{let i=(0,rt.useMemo)(()=>{switch(n.serverDataType){case"double":case"int":case"long":return(0,z.jsx)(Kn,{column:n,dispatchColumnAction:t});default:return(0,z.jsx)(jn,{column:n,dispatchColumnAction:t})}},[n,t]),{serverDataType:r="string"}=n,s=Oo(n);return(0,z.jsxs)(z.Fragment,{children:[(0,z.jsx)(tt.Dropdown,{className:(0,Tn.default)(`${Sn}-renderer`),fullWidth:!0,selected:s[0],source:s}),(0,z.jsx)(ot.Panel,{...o,className:(0,Tn.default)(Sn,e,`${Sn}-${r}`),children:i})]})};var b=require("react/jsx-runtime"),it="vuuColumnSettingsPanel",Po={className:"salt-density-high"},at=()=>null,ct=({column:e,dispatchColumnAction:n,style:t,...o})=>{var h,a,d,f;let[i,r]=(0,Z.useState)(0),s=(0,Z.useCallback)(m=>n({type:"updateColumnProp",column:e,...m}),[e,n]),p=(0,Z.useCallback)(m=>s({align:m.target.value}),[s]),l=(0,Z.useCallback)(m=>s({pin:m.target.value}),[s]),c=(0,Z.useCallback)((m,P)=>s({hidden:P}),[s]),g=(0,Z.useCallback)((m,P)=>s({label:P}),[s]),x=(0,Z.useCallback)(m=>s({width:parseInt(m.toString(),10)}),[s]);return(0,b.jsxs)("div",{className:it,...o,style:{...t},children:[(0,b.jsx)(Ie.Text,{as:"h4",children:"Column Settings"}),(0,b.jsxs)(lt.Stack,{active:i,showTabs:!0,className:(0,pt.default)(`${it}-columnTabs`),onTabSelectionChanged:r,TabstripProps:Po,children:[(0,b.jsxs)(Ie.Panel,{title:"Column",children:[(0,b.jsx)(v.FormField,{label:"Hidden",labelPlacement:"left",children:(0,b.jsx)(v.Checkbox,{checked:e.hidden===!0,onChange:c})}),(0,b.jsx)(v.FormField,{label:"Label",labelPlacement:"left",children:(0,b.jsx)(v.Input,{value:(h=e.label)!=null?h:e.name,onChange:g})}),(0,b.jsx)(v.FormField,{label:"Width",labelPlacement:"left",children:(0,b.jsx)(v.StepperInput,{value:(a=e.width)!=null?a:100,onChange:x})}),(0,b.jsx)(v.FormField,{label:"Align",labelPlacement:"left",ActivationIndicatorComponent:at,children:(0,b.jsxs)(v.RadioButtonGroup,{"aria-label":"Column Align",value:(d=e.align)!=null?d:"left",legend:"Align",onChange:p,children:[(0,b.jsx)(v.RadioButton,{label:"Left",value:"left"}),(0,b.jsx)(v.RadioButton,{label:"Right",value:"right"})]})}),(0,b.jsx)(v.FormField,{label:"Pin Column",labelPlacement:"left",ActivationIndicatorComponent:at,children:(0,b.jsxs)(v.RadioButtonGroup,{"aria-label":"Pin Column",value:(f=e.pin)!=null?f:"",legend:"Pin Column",onChange:l,children:[(0,b.jsx)(v.RadioButton,{label:"Do not pin",value:""}),(0,b.jsx)(v.RadioButton,{label:"Left",value:"left"}),(0,b.jsx)(v.RadioButton,{label:"Right",value:"right"})]})})]}),(0,b.jsx)(st,{column:e,dispatchColumnAction:n,title:"Data Cell"}),(0,b.jsxs)(Ie.Panel,{title:"Vuu",variant:"secondary",children:[(0,b.jsx)(v.FormField,{label:"Name",labelPlacement:"top",readOnly:!0,variant:"secondary",children:(0,b.jsx)(v.Input,{value:e.name})}),(0,b.jsx)(v.FormField,{label:"Vuu type",labelPlacement:"top",readOnly:!0,variant:"secondary",children:(0,b.jsx)(v.Input,{value:e.serverDataType})})]})]})]})};var $=require("@heswell/salt-lab"),je=require("@salt-ds/core"),Ke=require("react");var F=require("react/jsx-runtime"),So="vuuGridSettingsPanel",To=()=>null,ut=({config:e,dispatchColumnAction:n,style:t,...o})=>{var p;let i=(0,Ke.useCallback)(l=>n({type:"updateGridSettings",...l}),[n]),r=(0,Ke.useCallback)(l=>i({columnFormatHeader:l.target.value}),[i]),s=(0,Ke.useCallback)(l=>i({columnDefaultWidth:parseInt(l.toString(),10)}),[i]);return(0,F.jsxs)("div",{className:So,...o,style:{...t},children:[(0,F.jsx)(je.Text,{as:"h4",children:"Grid Settings"}),(0,F.jsxs)(je.Panel,{children:[(0,F.jsx)($.FormField,{label:"Format column labels",labelPlacement:"left",ActivationIndicatorComponent:To,children:(0,F.jsxs)($.RadioButtonGroup,{"aria-label":"Format column labels",value:e.columnFormatHeader,legend:"Format column labels",onChange:r,children:[(0,F.jsx)($.RadioButton,{label:"No Formatting",value:void 0}),(0,F.jsx)($.RadioButton,{label:"Capitalize",value:"capitalize"}),(0,F.jsx)($.RadioButton,{label:"Uppercase",value:"uppercase"})]})}),(0,F.jsx)($.FormField,{label:"Default Column Width",labelPlacement:"left",children:(0,F.jsx)($.StepperInput,{value:(p=e.columnDefaultWidth)!=null?p:100,onChange:s})})]})]})};var mt=require("react"),dt=require("@heswell/salt-lab"),gt=require("@vuu-ui/vuu-utils"),Do=(e,n)=>{switch(console.log(`gridSettingsReducer ${n.type}`),n.type){case"addColumn":return wo(e,n);case"addCalculatedColumn":return Ro(e,n);case"moveColumn":return No(e,n);case"removeColumn":return Ao(e,n);case"updateColumn":return e;case"updateColumnProp":return ko(e,n);case"updateGridSettings":return Fo(e,n);case"updateColumnTypeFormatting":return Qo(e,n);default:return e}},ft=e=>{let[n,t]=(0,mt.useReducer)(Do,e);return{gridSettings:n,dispatchColumnAction:t}};function wo(e,{column:n,columns:t,index:o=-1}){let{columns:i}=e;if(o===-1){if(Array.isArray(t))return{...e,columns:i.concat(t)};if(n)return{...e,columns:i.concat(n)}}return e}function Ro(e,{columnName:n,columnType:t,expression:o}){let{columns:i}=e,r={name:n,expression:o,serverDataType:t};return{...e,columns:i.concat(r)}}function Ao(e,{column:n}){let{columns:t}=e;return{...e,columns:t.filter(o=>o.name!==n.name)}}function No(e,{column:n,moveBy:t,moveFrom:o,moveTo:i}){let{columns:r}=e;if(n&&typeof t=="number"){let s=r.indexOf(n),p=r.slice(),[l]=p.splice(s,1);return p.splice(s+t,0,l),{...e,columns:p}}else return typeof o=="number"&&typeof i=="number"?{...e,columns:(0,dt.moveItem)(r,o,i)}:e}function ko(e,{align:n,column:t,hidden:o,label:i,width:r}){let{columns:s}=e;return(n==="left"||n==="right")&&(s=Be(s,{...t,align:n})),typeof o=="boolean"&&(s=Be(s,{...t,hidden:o})),typeof i=="string"&&(s=Be(s,{...t,label:i})),typeof r=="number"&&(s=Be(s,{...t,width:r})),{...e,columns:s}}function Fo(e,{columnFormatHeader:n}){return{...e,columnFormatHeader:n!=null?n:e.columnFormatHeader}}function Qo(e,{alignOnDecimals:n,column:t,decimals:o,zeroPad:i}){let{columns:r}=e;if(r.find(p=>p.name===t.name)){let{serverDataType:p="string",type:l=(0,gt.fromServerDataType)(p)}=t,c=typeof l=="string"?{name:l}:{...l};return typeof n=="boolean"&&(c.formatting={...c.formatting,alignOnDecimals:n}),typeof o=="number"&&(c.formatting={...c.formatting,decimals:o}),typeof i=="boolean"&&(c.formatting={...c.formatting,zeroPad:i}),{...e,columns:Be(r,{...t,type:c})}}else return e}function Be(e,n){return e.map(t=>t.name===n.name?n:t)}var ht=require("@vuu-ui/vuu-layout");var en=require("@heswell/salt-lab"),Se=require("@salt-ds/core"),H=require("react");var J=require("react/jsx-runtime"),Ct=({columns:e,dispatchColumnAction:n,table:t})=>{let[o,i]=(0,H.useState)(""),[,r]=(0,H.useState)(),s=(0,H.useRef)(""),p=On({columns:e,table:t}),l=(0,H.useCallback)(h=>{let{value:a}=h.target;i(a)},[]),c=(0,H.useCallback)(h=>{s.current=h},[]),g=(0,H.useCallback)((h,a)=>{console.log({source:h}),r(a)},[]),x=(0,H.useCallback)(()=>{s.current&&(console.log(`save expression ${JSON.stringify(s.current,null,2)}`),n({type:"addCalculatedColumn",columnName:o,expression:s.current,columnType:"string"}))},[o,n]);return(0,J.jsxs)(Se.Panel,{className:"vuuCalculatedColumnPanel",title:"Define Computed Column",children:[(0,J.jsx)(Se.Text,{styleAs:"h4",children:"Define Computed Column"}),(0,J.jsx)(en.FormField,{label:"Column Name",labelPlacement:"left",children:(0,J.jsx)(en.Input,{value:o,onChange:l})}),(0,J.jsx)(En,{onChange:c,onSubmitExpression:g,suggestionProvider:p}),(0,J.jsx)("div",{style:{marginTop:12},children:(0,J.jsx)(Se.Button,{onClick:x,children:"Add Column"})})]})};var w=require("react/jsx-runtime"),nn="vuuDatagridSettingsPanel",Lo=()=>{},Io=["table-settings","column-chooser","column-settings","define-column"],Bo=(e,n)=>Io[n],$o=({availableColumns:e,className:n,gridConfig:t,onCancel:o,onConfigChange:i,...r})=>{var De;console.log("DatagridSettingsPanel render");let[s,p]=(0,q.useState)(0),{gridSettings:l,dispatchColumnAction:c}=ft(t),[g,x]=(0,q.useState)(null),h=(0,q.useCallback)(V=>{x(V?V.name:null)},[]),a=(0,q.useCallback)((V,Ft=!1)=>{console.log("1) DataGridSettingsPanel fire onConfigChange"),i==null||i(l,Ft)},[l,i]),d=(0,q.useCallback)(V=>{p(V)},[]),f=(0,q.useCallback)(V=>a(V,!0),[a]),m=g===null?null:(De=l.columns.find(V=>V.name===g))!=null?De:null,P={activeTabIndex:s,enableRenameTab:!1,orientation:"vertical"},R=(0,q.useCallback)(()=>p(3),[]),X=s===2?"right":void 0;return(0,w.jsxs)("div",{...r,className:(0,xt.default)(nn,n),children:[(0,w.jsxs)(ht.Stack,{TabstripProps:P,className:`${nn}-stack`,getTabIcon:Bo,getTabLabel:Lo,active:s===2?1:s,onTabSelectionChanged:d,showTabs:!0,children:[(0,w.jsx)(ut,{config:l,dispatchColumnAction:c}),(0,w.jsxs)("div",{className:`${nn}-columnPanels`,"data-align":X,children:[(0,w.jsx)(qn,{availableColumns:e,chosenColumns:l.columns,dispatchColumnAction:c,onSelectionChange:h,onAddCalculatedColumnClick:R,selectedColumn:m}),m===null?(0,w.jsx)(Te.Panel,{className:"vuuColumnSettingsPanel",children:"Select a column"}):(0,w.jsx)(ct,{column:m,dispatchColumnAction:c,style:{background:"white",flex:"1 0 150px"}})]}),(0,w.jsx)("div",{title:"Column Settings",children:"Column Settings"}),(0,w.jsx)(Ct,{columns:l.columns,dispatchColumnAction:c,table:{module:"SIMUL",table:"instruments"}})]}),(0,w.jsxs)("div",{className:`${nn}-buttonBar`,children:[(0,w.jsx)(Te.Button,{onClick:o,children:"Cancel"}),(0,w.jsx)(Te.Button,{onClick:a,children:"Apply"}),(0,w.jsx)(Te.Button,{onClick:f,children:"Save"})]})]})};var $e=require("react"),bt=Y(require("classnames"),1);var ne=require("react/jsx-runtime"),tn="vuuDatasourceStats",Dn=new Intl.NumberFormat,Mo=({className:e,dataSource:n})=>{let[t,o]=(0,$e.useState)(n.range),[i,r]=(0,$e.useState)(n.size);(0,$e.useEffect)(()=>{r(n.size),n.on("resize",r),n.on("range",o)},[n]);let s=(0,bt.default)(tn,e),p=Dn.format(t.from),l=Dn.format(t.to-1),c=Dn.format(i);return(0,ne.jsxs)("div",{className:s,children:[(0,ne.jsx)("span",{children:"Showing rows"}),(0,ne.jsx)("span",{className:`${tn}-range`,children:p}),(0,ne.jsx)("span",{className:`${tn}-range`,children:l}),(0,ne.jsx)("span",{children:"of"}),(0,ne.jsx)("span",{className:`${tn}-size`,children:c})]})};var Nt=require("@vuu-ui/vuu-layout"),O=require("@heswell/salt-lab"),Ue=require("@salt-ds/core"),kt=Y(require("classnames"),1),K=require("react");var Pt=require("@vuu-ui/vuu-utils"),St=require("@heswell/salt-lab"),Tt=require("@salt-ds/core"),Rn=Y(require("classnames"),1),Dt=require("react");var ce=require("@heswell/salt-lab"),yt=require("@salt-ds/core"),Me=require("react");var Q=require("react/jsx-runtime"),Uo={alignOnDecimals:!1,decimals:4,zeroPad:!1},Go=(e,n)=>{let t=typeof e=="object"&&e.formatting?e.formatting:{};return["alignOnDecimals","decimals","zeroPad"].reduce((i,r)=>t[r]!==void 0?{...i,[r]:t[r]}:(n==null?void 0:n[r])!==void 0?{...i,[r]:n[r]}:i,Uo)},Et=({column:e,dispatchColumnAction:n})=>{let{decimals:t,alignOnDecimals:o,zeroPad:i}=Go(e==null?void 0:e.type),r=(0,Me.useCallback)(c=>n({type:"updateColumnTypeFormatting",column:e,...c}),[e,n]),s=(0,Me.useCallback)(c=>r({decimals:parseInt(c.toString(),10)}),[r]),p=(0,Me.useCallback)((c,g)=>r({alignOnDecimals:g}),[r]),l=(0,Me.useCallback)((c,g)=>r({zeroPad:g}),[r]);switch(e.serverDataType){case"double":return(0,Q.jsxs)(Q.Fragment,{children:[(0,Q.jsx)(ce.FormField,{label:"No of Decimals",labelPlacement:"top",children:(0,Q.jsx)(ce.StepperInput,{value:t,onChange:s})}),(0,Q.jsx)(ce.Switch,{checked:o,label:"Align on decimals",LabelProps:{className:"vuuColumnPanelSwitch"},onChange:p}),(0,Q.jsx)(ce.Switch,{checked:i,label:"Zero pad",LabelProps:{className:"vuuColumnPanelSwitch"},onChange:l})]});case"long":case"int":return(0,Q.jsx)(Q.Fragment,{children:(0,Q.jsx)(yt.Text,{children:"Work in progress"})});default:return null}};var on=require("react/jsx-runtime"),vt=({column:e,dispatchColumnAction:n})=>(console.log(e,n),(0,on.jsx)(on.Fragment,{children:"what"}));var _=require("react/jsx-runtime"),wn="vuuColumnTypePanel",Wo=["Default Renderer (int, long)"],Ho=["Default Renderer (double)"],Ot=["Default Renderer (string)"],Xo=e=>{let t=(0,Pt.getRegisteredCellRenderers)(e.serverDataType).map(o=>o.name);switch(console.log({customRendererNames:t}),e.serverDataType){case"char":case"string":return Ot;case"int":case"long":return Wo;case"double":return Ho.concat(t);default:return Ot}},wt=({className:e,column:n,dispatchColumnAction:t,...o})=>{let i=(0,Dt.useMemo)(()=>{switch(n.serverDataType){case"double":case"int":case"long":return(0,_.jsx)(Et,{column:n,dispatchColumnAction:t});default:return(0,_.jsx)(vt,{column:n,dispatchColumnAction:t})}},[n,t]),{serverDataType:r="string"}=n,s=Xo(n);return(0,_.jsxs)(_.Fragment,{children:[(0,_.jsx)(St.Dropdown,{className:(0,Rn.default)(`${wn}-renderer`),fullWidth:!0,selected:s[0],source:s}),(0,_.jsx)(Tt.Panel,{...o,className:(0,Rn.default)(wn,e,`${wn}-${r}`),children:i})]})};var y=require("react/jsx-runtime"),Rt="vuuColumnSettingsPanel",Vo={className:"salt-density-high"},At=()=>null,Yo=({column:e,dispatchColumnAction:n,style:t,...o})=>{var h,a,d,f;let[i,r]=(0,K.useState)(0),s=(0,K.useCallback)(m=>n({type:"updateColumnProp",column:e,...m}),[e,n]),p=(0,K.useCallback)(m=>s({align:m.target.value}),[s]),l=(0,K.useCallback)(m=>s({pin:m.target.value}),[s]),c=(0,K.useCallback)((m,P)=>s({hidden:P}),[s]),g=(0,K.useCallback)((m,P)=>s({label:P}),[s]),x=(0,K.useCallback)(m=>s({width:parseInt(m.toString(),10)}),[s]);return(0,y.jsxs)("div",{className:Rt,...o,style:{...t},children:[(0,y.jsx)(Ue.Text,{as:"h4",children:"Column Settings"}),(0,y.jsxs)(Nt.Stack,{active:i,showTabs:!0,className:(0,kt.default)(`${Rt}-columnTabs`),onTabSelectionChanged:r,TabstripProps:Vo,children:[(0,y.jsxs)(Ue.Panel,{title:"Column",children:[(0,y.jsx)(O.FormField,{label:"Hidden",labelPlacement:"left",children:(0,y.jsx)(O.Checkbox,{checked:e.hidden===!0,onChange:c})}),(0,y.jsx)(O.FormField,{label:"Label",labelPlacement:"left",children:(0,y.jsx)(O.Input,{value:(h=e.label)!=null?h:e.name,onChange:g})}),(0,y.jsx)(O.FormField,{label:"Width",labelPlacement:"left",children:(0,y.jsx)(O.StepperInput,{value:(a=e.width)!=null?a:100,onChange:x})}),(0,y.jsx)(O.FormField,{label:"Align",labelPlacement:"left",ActivationIndicatorComponent:At,children:(0,y.jsxs)(O.RadioButtonGroup,{"aria-label":"Column Align",value:(d=e.align)!=null?d:"left",legend:"Align",onChange:p,children:[(0,y.jsx)(O.RadioButton,{label:"Left",value:"left"}),(0,y.jsx)(O.RadioButton,{label:"Right",value:"right"})]})}),(0,y.jsx)(O.FormField,{label:"Pin Column",labelPlacement:"left",ActivationIndicatorComponent:At,children:(0,y.jsxs)(O.RadioButtonGroup,{"aria-label":"Pin Column",value:(f=e.pin)!=null?f:"",legend:"Pin Column",onChange:l,children:[(0,y.jsx)(O.RadioButton,{label:"Do not pin",value:""}),(0,y.jsx)(O.RadioButton,{label:"Left",value:"left"}),(0,y.jsx)(O.RadioButton,{label:"Right",value:"right"})]})})]}),(0,y.jsx)(wt,{column:e,dispatchColumnAction:n,title:"Data Cell"}),(0,y.jsxs)(Ue.Panel,{title:"Vuu",variant:"secondary",children:[(0,y.jsx)(O.FormField,{label:"Name",labelPlacement:"top",readOnly:!0,variant:"secondary",children:(0,y.jsx)(O.Input,{value:e.name})}),(0,y.jsx)(O.FormField,{label:"Vuu type",labelPlacement:"top",readOnly:!0,variant:"secondary",children:(0,y.jsx)(O.Input,{value:e.serverDataType})})]})]})]})};
3212
2
  //# sourceMappingURL=index.js.map