@hitachivantara/uikit-react-core 5.15.0 → 5.17.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (136) hide show
  1. package/dist/cjs/components/ActionBar/ActionBar.cjs +8 -7
  2. package/dist/cjs/components/ActionBar/ActionBar.cjs.map +1 -1
  3. package/dist/cjs/components/ActionBar/ActionBar.styles.cjs +16 -17
  4. package/dist/cjs/components/ActionBar/ActionBar.styles.cjs.map +1 -1
  5. package/dist/cjs/components/Pagination/Pagination.cjs +46 -45
  6. package/dist/cjs/components/Pagination/Pagination.cjs.map +1 -1
  7. package/dist/cjs/components/Pagination/Pagination.styles.cjs +98 -160
  8. package/dist/cjs/components/Pagination/Pagination.styles.cjs.map +1 -1
  9. package/dist/cjs/components/Pagination/Select.cjs +2 -1
  10. package/dist/cjs/components/Pagination/Select.cjs.map +1 -1
  11. package/dist/cjs/components/QueryBuilder/ConfirmationDialog/ConfirmationDialog.cjs +30 -33
  12. package/dist/cjs/components/QueryBuilder/ConfirmationDialog/ConfirmationDialog.cjs.map +1 -1
  13. package/dist/cjs/components/QueryBuilder/ConfirmationDialog/ConfirmationDialog.styles.cjs +14 -0
  14. package/dist/cjs/components/QueryBuilder/ConfirmationDialog/ConfirmationDialog.styles.cjs.map +1 -0
  15. package/dist/cjs/components/QueryBuilder/QueryBuilder.cjs +6 -6
  16. package/dist/cjs/components/QueryBuilder/QueryBuilder.cjs.map +1 -1
  17. package/dist/cjs/components/QueryBuilder/{RuleGroup/RuleGroup.styles.cjs → QueryBuilder.styles.cjs} +48 -29
  18. package/dist/cjs/components/QueryBuilder/QueryBuilder.styles.cjs.map +1 -0
  19. package/dist/cjs/components/QueryBuilder/Rule/Rule.cjs +60 -61
  20. package/dist/cjs/components/QueryBuilder/Rule/Rule.cjs.map +1 -1
  21. package/dist/cjs/components/QueryBuilder/Rule/Rule.styles.cjs +10 -5
  22. package/dist/cjs/components/QueryBuilder/Rule/Rule.styles.cjs.map +1 -1
  23. package/dist/cjs/components/QueryBuilder/Rule/Value/DateTimeValue/DateTimeValue.cjs +253 -0
  24. package/dist/cjs/components/QueryBuilder/Rule/Value/DateTimeValue/DateTimeValue.cjs.map +1 -0
  25. package/dist/cjs/components/QueryBuilder/Rule/Value/DateTimeValue/DateTimeValue.styles.cjs +40 -0
  26. package/dist/cjs/components/QueryBuilder/Rule/Value/DateTimeValue/DateTimeValue.styles.cjs.map +1 -0
  27. package/dist/cjs/components/QueryBuilder/Rule/Value/DateTimeValue/utils.cjs +37 -0
  28. package/dist/cjs/components/QueryBuilder/Rule/Value/DateTimeValue/utils.cjs.map +1 -0
  29. package/dist/cjs/components/QueryBuilder/Rule/Value/NumericValue/Numeric.styles.cjs +10 -6
  30. package/dist/cjs/components/QueryBuilder/Rule/Value/NumericValue/Numeric.styles.cjs.map +1 -1
  31. package/dist/cjs/components/QueryBuilder/Rule/Value/NumericValue/NumericValue.cjs +76 -82
  32. package/dist/cjs/components/QueryBuilder/Rule/Value/NumericValue/NumericValue.cjs.map +1 -1
  33. package/dist/cjs/components/QueryBuilder/Rule/Value/TextValue/TextValue.cjs +33 -37
  34. package/dist/cjs/components/QueryBuilder/Rule/Value/TextValue/TextValue.cjs.map +1 -1
  35. package/dist/cjs/components/QueryBuilder/Rule/Value/TextValue/TextValue.styles.cjs +8 -3
  36. package/dist/cjs/components/QueryBuilder/Rule/Value/TextValue/TextValue.styles.cjs.map +1 -1
  37. package/dist/cjs/components/QueryBuilder/Rule/Value/Value.cjs +8 -5
  38. package/dist/cjs/components/QueryBuilder/Rule/Value/Value.cjs.map +1 -1
  39. package/dist/cjs/components/QueryBuilder/RuleGroup/RuleGroup.cjs +155 -166
  40. package/dist/cjs/components/QueryBuilder/RuleGroup/RuleGroup.cjs.map +1 -1
  41. package/dist/cjs/components/TimePicker/Placeholder.cjs +70 -0
  42. package/dist/cjs/components/TimePicker/Placeholder.cjs.map +1 -0
  43. package/dist/cjs/components/TimePicker/TimePicker.cjs +212 -0
  44. package/dist/cjs/components/TimePicker/TimePicker.cjs.map +1 -0
  45. package/dist/cjs/components/TimePicker/TimePicker.styles.cjs +53 -0
  46. package/dist/cjs/components/TimePicker/TimePicker.styles.cjs.map +1 -0
  47. package/dist/cjs/components/TimePicker/Unit/Unit.cjs +72 -0
  48. package/dist/cjs/components/TimePicker/Unit/Unit.cjs.map +1 -0
  49. package/dist/cjs/components/TimePicker/Unit/Unit.styles.cjs +56 -0
  50. package/dist/cjs/components/TimePicker/Unit/Unit.styles.cjs.map +1 -0
  51. package/dist/cjs/index.cjs +10 -6
  52. package/dist/cjs/index.cjs.map +1 -1
  53. package/dist/cjs/utils/classes.cjs +4 -3
  54. package/dist/cjs/utils/classes.cjs.map +1 -1
  55. package/dist/esm/components/ActionBar/ActionBar.js +11 -9
  56. package/dist/esm/components/ActionBar/ActionBar.js.map +1 -1
  57. package/dist/esm/components/ActionBar/ActionBar.styles.js +16 -15
  58. package/dist/esm/components/ActionBar/ActionBar.styles.js.map +1 -1
  59. package/dist/esm/components/Pagination/Pagination.js +50 -48
  60. package/dist/esm/components/Pagination/Pagination.js.map +1 -1
  61. package/dist/esm/components/Pagination/Pagination.styles.js +98 -158
  62. package/dist/esm/components/Pagination/Pagination.styles.js.map +1 -1
  63. package/dist/esm/components/Pagination/Select.js +2 -1
  64. package/dist/esm/components/Pagination/Select.js.map +1 -1
  65. package/dist/esm/components/QueryBuilder/ConfirmationDialog/ConfirmationDialog.js +31 -34
  66. package/dist/esm/components/QueryBuilder/ConfirmationDialog/ConfirmationDialog.js.map +1 -1
  67. package/dist/esm/components/QueryBuilder/ConfirmationDialog/ConfirmationDialog.styles.js +14 -0
  68. package/dist/esm/components/QueryBuilder/ConfirmationDialog/ConfirmationDialog.styles.js.map +1 -0
  69. package/dist/esm/components/QueryBuilder/QueryBuilder.js +6 -6
  70. package/dist/esm/components/QueryBuilder/QueryBuilder.js.map +1 -1
  71. package/dist/esm/components/QueryBuilder/{RuleGroup/RuleGroup.styles.js → QueryBuilder.styles.js} +48 -29
  72. package/dist/esm/components/QueryBuilder/QueryBuilder.styles.js.map +1 -0
  73. package/dist/esm/components/QueryBuilder/Rule/Rule.js +61 -62
  74. package/dist/esm/components/QueryBuilder/Rule/Rule.js.map +1 -1
  75. package/dist/esm/components/QueryBuilder/Rule/Rule.styles.js +10 -5
  76. package/dist/esm/components/QueryBuilder/Rule/Rule.styles.js.map +1 -1
  77. package/dist/esm/components/QueryBuilder/Rule/Value/DateTimeValue/DateTimeValue.js +250 -0
  78. package/dist/esm/components/QueryBuilder/Rule/Value/DateTimeValue/DateTimeValue.js.map +1 -0
  79. package/dist/esm/components/QueryBuilder/Rule/Value/DateTimeValue/DateTimeValue.styles.js +40 -0
  80. package/dist/esm/components/QueryBuilder/Rule/Value/DateTimeValue/DateTimeValue.styles.js.map +1 -0
  81. package/dist/esm/components/QueryBuilder/Rule/Value/DateTimeValue/utils.js +35 -0
  82. package/dist/esm/components/QueryBuilder/Rule/Value/DateTimeValue/utils.js.map +1 -0
  83. package/dist/esm/components/QueryBuilder/Rule/Value/NumericValue/Numeric.styles.js +10 -6
  84. package/dist/esm/components/QueryBuilder/Rule/Value/NumericValue/Numeric.styles.js.map +1 -1
  85. package/dist/esm/components/QueryBuilder/Rule/Value/NumericValue/NumericValue.js +78 -84
  86. package/dist/esm/components/QueryBuilder/Rule/Value/NumericValue/NumericValue.js.map +1 -1
  87. package/dist/esm/components/QueryBuilder/Rule/Value/TextValue/TextValue.js +34 -38
  88. package/dist/esm/components/QueryBuilder/Rule/Value/TextValue/TextValue.js.map +1 -1
  89. package/dist/esm/components/QueryBuilder/Rule/Value/TextValue/TextValue.styles.js +8 -3
  90. package/dist/esm/components/QueryBuilder/Rule/Value/TextValue/TextValue.styles.js.map +1 -1
  91. package/dist/esm/components/QueryBuilder/Rule/Value/Value.js +7 -4
  92. package/dist/esm/components/QueryBuilder/Rule/Value/Value.js.map +1 -1
  93. package/dist/esm/components/QueryBuilder/RuleGroup/RuleGroup.js +157 -168
  94. package/dist/esm/components/QueryBuilder/RuleGroup/RuleGroup.js.map +1 -1
  95. package/dist/esm/components/TimePicker/Placeholder.js +70 -0
  96. package/dist/esm/components/TimePicker/Placeholder.js.map +1 -0
  97. package/dist/esm/components/TimePicker/TimePicker.js +213 -0
  98. package/dist/esm/components/TimePicker/TimePicker.js.map +1 -0
  99. package/dist/esm/components/TimePicker/TimePicker.styles.js +53 -0
  100. package/dist/esm/components/TimePicker/TimePicker.styles.js.map +1 -0
  101. package/dist/esm/components/TimePicker/Unit/Unit.js +72 -0
  102. package/dist/esm/components/TimePicker/Unit/Unit.js.map +1 -0
  103. package/dist/esm/components/TimePicker/Unit/Unit.styles.js +56 -0
  104. package/dist/esm/components/TimePicker/Unit/Unit.styles.js.map +1 -0
  105. package/dist/esm/index.js +238 -234
  106. package/dist/esm/index.js.map +1 -1
  107. package/dist/esm/utils/classes.js +4 -3
  108. package/dist/esm/utils/classes.js.map +1 -1
  109. package/dist/types/index.d.ts +194 -82
  110. package/package.json +5 -5
  111. package/dist/cjs/components/ActionBar/actionBarClasses.cjs +0 -8
  112. package/dist/cjs/components/ActionBar/actionBarClasses.cjs.map +0 -1
  113. package/dist/cjs/components/Pagination/paginationClasses.cjs +0 -8
  114. package/dist/cjs/components/Pagination/paginationClasses.cjs.map +0 -1
  115. package/dist/cjs/components/QueryBuilder/Rule/Value/NumericValue/numericValueClasses.cjs +0 -8
  116. package/dist/cjs/components/QueryBuilder/Rule/Value/NumericValue/numericValueClasses.cjs.map +0 -1
  117. package/dist/cjs/components/QueryBuilder/Rule/Value/TextValue/textValueClasses.cjs +0 -8
  118. package/dist/cjs/components/QueryBuilder/Rule/Value/TextValue/textValueClasses.cjs.map +0 -1
  119. package/dist/cjs/components/QueryBuilder/Rule/ruleClasses.cjs +0 -8
  120. package/dist/cjs/components/QueryBuilder/Rule/ruleClasses.cjs.map +0 -1
  121. package/dist/cjs/components/QueryBuilder/RuleGroup/RuleGroup.styles.cjs.map +0 -1
  122. package/dist/cjs/components/QueryBuilder/queryBuilderClasses.cjs +0 -8
  123. package/dist/cjs/components/QueryBuilder/queryBuilderClasses.cjs.map +0 -1
  124. package/dist/esm/components/ActionBar/actionBarClasses.js +0 -8
  125. package/dist/esm/components/ActionBar/actionBarClasses.js.map +0 -1
  126. package/dist/esm/components/Pagination/paginationClasses.js +0 -8
  127. package/dist/esm/components/Pagination/paginationClasses.js.map +0 -1
  128. package/dist/esm/components/QueryBuilder/Rule/Value/NumericValue/numericValueClasses.js +0 -8
  129. package/dist/esm/components/QueryBuilder/Rule/Value/NumericValue/numericValueClasses.js.map +0 -1
  130. package/dist/esm/components/QueryBuilder/Rule/Value/TextValue/textValueClasses.js +0 -8
  131. package/dist/esm/components/QueryBuilder/Rule/Value/TextValue/textValueClasses.js.map +0 -1
  132. package/dist/esm/components/QueryBuilder/Rule/ruleClasses.js +0 -8
  133. package/dist/esm/components/QueryBuilder/Rule/ruleClasses.js.map +0 -1
  134. package/dist/esm/components/QueryBuilder/RuleGroup/RuleGroup.styles.js.map +0 -1
  135. package/dist/esm/components/QueryBuilder/queryBuilderClasses.js +0 -8
  136. package/dist/esm/components/QueryBuilder/queryBuilderClasses.js.map +0 -1
@@ -0,0 +1,253 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const React = require("react");
4
+ const uniqueId = require("lodash/uniqueId");
5
+ const dayjs = require("dayjs");
6
+ const material = require("@mui/material");
7
+ const Context = require("../../../Context.cjs");
8
+ const utils = require("./utils.cjs");
9
+ const DateTimeValue_styles = require("./DateTimeValue.styles.cjs");
10
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
11
+ const DatePicker = require("../../../../DatePicker/DatePicker.cjs");
12
+ const TimePicker = require("../../../../TimePicker/TimePicker.cjs");
13
+ const WarningText = require("../../../../Forms/WarningText/WarningText.cjs");
14
+ const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
15
+ const uniqueId__default = /* @__PURE__ */ _interopDefault(uniqueId);
16
+ const dayjs__default = /* @__PURE__ */ _interopDefault(dayjs);
17
+ function valueIsRange(operator) {
18
+ return operator === "range";
19
+ }
20
+ const DateTimeValue = ({
21
+ id,
22
+ operator,
23
+ value: valueProp = {},
24
+ initialTouched = false
25
+ }) => {
26
+ var _a, _b, _c, _d;
27
+ const {
28
+ classes,
29
+ cx
30
+ } = DateTimeValue_styles.useClasses();
31
+ const theme = material.useTheme();
32
+ const isMdDown = material.useMediaQuery(theme.breakpoints.down("md"));
33
+ const isRange = valueIsRange(operator);
34
+ const context = React.useContext(Context.QueryBuilderContext);
35
+ const {
36
+ labels,
37
+ dispatchAction,
38
+ readOnly
39
+ } = context;
40
+ const elementId = uniqueId__default.default(`datetime${id}`);
41
+ const [touchedDate, setTouchedDate] = React.useState(initialTouched);
42
+ const [touchedTime, setTouchedTime] = React.useState(initialTouched);
43
+ const [touchedEndDate, setTouchedEndDate] = React.useState(initialTouched);
44
+ const [touchedEndTime, setTouchedEndTime] = React.useState(initialTouched);
45
+ const onDateChange = React.useCallback((data) => {
46
+ var _a2, _b2;
47
+ setTouchedDate(true);
48
+ let date;
49
+ if (data != null) {
50
+ date = dayjs__default.default(data).format("YYYY-MM-DD");
51
+ }
52
+ const oldValue = !isRange ? valueProp == null ? void 0 : valueProp.date : (_a2 = valueProp == null ? void 0 : valueProp.start) == null ? void 0 : _a2.date;
53
+ if (date !== oldValue) {
54
+ let value;
55
+ if (!isRange) {
56
+ value = {
57
+ date,
58
+ time: valueProp == null ? void 0 : valueProp.time
59
+ };
60
+ } else {
61
+ value = {
62
+ start: {
63
+ date,
64
+ time: (_b2 = valueProp == null ? void 0 : valueProp.start) == null ? void 0 : _b2.time
65
+ },
66
+ end: valueProp == null ? void 0 : valueProp.end
67
+ };
68
+ }
69
+ dispatchAction({
70
+ type: "set-value",
71
+ id,
72
+ value
73
+ });
74
+ }
75
+ }, [dispatchAction, id, isRange, valueProp]);
76
+ const onTimeChange = React.useCallback((data) => {
77
+ var _a2, _b2;
78
+ setTouchedTime(true);
79
+ let time;
80
+ if (data != null) {
81
+ time = `${utils.padTime(data.hours)}:${utils.padTime(data.minutes)}:${utils.padTime(data.seconds)}`;
82
+ }
83
+ const oldValue = !isRange ? valueProp == null ? void 0 : valueProp.time : (_a2 = valueProp == null ? void 0 : valueProp.start) == null ? void 0 : _a2.time;
84
+ if (time !== oldValue) {
85
+ let value;
86
+ if (!isRange) {
87
+ value = {
88
+ date: valueProp == null ? void 0 : valueProp.date,
89
+ time
90
+ };
91
+ } else {
92
+ value = {
93
+ start: {
94
+ date: (_b2 = valueProp == null ? void 0 : valueProp.start) == null ? void 0 : _b2.date,
95
+ time
96
+ },
97
+ end: valueProp == null ? void 0 : valueProp.end
98
+ };
99
+ }
100
+ dispatchAction({
101
+ type: "set-value",
102
+ id,
103
+ value
104
+ });
105
+ }
106
+ }, [dispatchAction, id, isRange, valueProp]);
107
+ const onEndDateChange = React.useCallback((data) => {
108
+ var _a2, _b2;
109
+ setTouchedEndDate(true);
110
+ let date;
111
+ if (data != null) {
112
+ date = dayjs__default.default(data).format("YYYY-MM-DD");
113
+ }
114
+ if (date !== ((_a2 = valueProp == null ? void 0 : valueProp.end) == null ? void 0 : _a2.date)) {
115
+ const value = {
116
+ start: valueProp == null ? void 0 : valueProp.start,
117
+ end: {
118
+ date,
119
+ time: (_b2 = valueProp == null ? void 0 : valueProp.end) == null ? void 0 : _b2.time
120
+ }
121
+ };
122
+ dispatchAction({
123
+ type: "set-value",
124
+ id,
125
+ value
126
+ });
127
+ }
128
+ }, [dispatchAction, id, valueProp]);
129
+ const onEndTimeChange = React.useCallback((data) => {
130
+ var _a2, _b2;
131
+ setTouchedEndTime(true);
132
+ let time;
133
+ if (data != null) {
134
+ time = `${utils.padTime(data.hours)}:${utils.padTime(data.minutes)}:${utils.padTime(data.seconds)}`;
135
+ }
136
+ if (time !== ((_a2 = valueProp == null ? void 0 : valueProp.end) == null ? void 0 : _a2.time)) {
137
+ const value = {
138
+ start: valueProp == null ? void 0 : valueProp.start,
139
+ end: {
140
+ date: (_b2 = valueProp == null ? void 0 : valueProp.end) == null ? void 0 : _b2.date,
141
+ time
142
+ }
143
+ };
144
+ dispatchAction({
145
+ type: "set-value",
146
+ id,
147
+ value
148
+ });
149
+ }
150
+ }, [dispatchAction, id, valueProp]);
151
+ const startDate = isRange ? (_a = valueProp == null ? void 0 : valueProp.start) == null ? void 0 : _a.date : valueProp == null ? void 0 : valueProp.date;
152
+ const datePickerValue = React.useMemo(() => utils.parseDate(startDate), [startDate]);
153
+ const datePickerStatus = datePickerValue != null ? "valid" : "invalid";
154
+ const startTime = (isRange ? (_b = valueProp == null ? void 0 : valueProp.start) == null ? void 0 : _b.time : valueProp == null ? void 0 : valueProp.time) ?? "";
155
+ const timePickerValue = React.useMemo(() => utils.parseTime(startTime), [startTime]);
156
+ const timePickerStatus = timePickerValue != null ? "valid" : "invalid";
157
+ const endDate = isRange ? (_c = valueProp == null ? void 0 : valueProp.end) == null ? void 0 : _c.date : null;
158
+ const endDatePickerValue = React.useMemo(() => utils.parseDate(endDate), [endDate]);
159
+ const endTime = isRange ? (_d = valueProp == null ? void 0 : valueProp.end) == null ? void 0 : _d.time : null;
160
+ const endTimePickerValue = React.useMemo(() => utils.parseTime(endTime), [endTime]);
161
+ const dateStatus = !touchedDate ? "standBy" : datePickerStatus;
162
+ const timeStatus = !touchedTime ? "standBy" : timePickerStatus;
163
+ const endDateIsBefore = startDate != null && endDate != null && endDate < startDate;
164
+ const endTimeIsBeforeOrSame = startDate != null && endDate != null && endDate === startDate && startTime != null && endTime != null && endTime <= startTime;
165
+ const endDateTimeIsBefore = endDateIsBefore || endTimeIsBeforeOrSame;
166
+ const endDatePickerStatus = endDatePickerValue == null || endDateTimeIsBefore ? "invalid" : "valid";
167
+ const endDateStatus = !touchedEndDate ? "standBy" : endDatePickerStatus;
168
+ const endTimePickerStatus = endTimePickerValue == null || endDateTimeIsBefore ? "invalid" : "valid";
169
+ const endTimeStatus = !touchedEndTime ? "standBy" : endTimePickerStatus;
170
+ return /* @__PURE__ */ jsxRuntime.jsxs("div", {
171
+ className: classes.root,
172
+ children: [/* @__PURE__ */ jsxRuntime.jsxs("div", {
173
+ className: cx(classes.row, classes.horizontal, {
174
+ [classes.isMdDown]: isMdDown
175
+ }),
176
+ children: [/* @__PURE__ */ jsxRuntime.jsx(DatePicker.HvDatePicker, {
177
+ className: classes.datePicker,
178
+ name: `${elementId}-date`,
179
+ required: true,
180
+ status: dateStatus,
181
+ statusMessage: labels.rule.value.datetime.validation.required,
182
+ label: isRange ? labels.rule.value.datetime.startDateLabel : labels.rule.value.datetime.dateLabel,
183
+ placeholder: isRange ? labels.rule.value.datetime.startDatePlaceholder : labels.rule.value.datetime.datePlaceholder,
184
+ value: datePickerValue,
185
+ onChange: onDateChange,
186
+ readOnly
187
+ }), /* @__PURE__ */ jsxRuntime.jsx(TimePicker.HvTimePicker, {
188
+ className: classes.timePicker,
189
+ timeFormat: "24",
190
+ name: `${elementId}-time`,
191
+ required: true,
192
+ status: timeStatus,
193
+ statusMessage: labels.rule.value.datetime.validation.required,
194
+ label: isRange ? labels.rule.value.datetime.startTimeLabel : labels.rule.value.datetime.timeLabel,
195
+ placeholder: isRange ? labels.rule.value.datetime.startTimePlaceholder : labels.rule.value.datetime.timePlaceholder,
196
+ value: timePickerValue || void 0,
197
+ onChange: onTimeChange,
198
+ onToggle: (_evt, open) => {
199
+ if (!open && !touchedTime) {
200
+ setTouchedTime(true);
201
+ }
202
+ },
203
+ readOnly
204
+ })]
205
+ }), isRange && /* @__PURE__ */ jsxRuntime.jsxs("div", {
206
+ className: cx(classes.row, classes.vertical),
207
+ children: [/* @__PURE__ */ jsxRuntime.jsxs("div", {
208
+ className: cx(classes.horizontal, {
209
+ [classes.isMdDown]: isMdDown
210
+ }),
211
+ children: [/* @__PURE__ */ jsxRuntime.jsx(DatePicker.HvDatePicker, {
212
+ className: classes.datePicker,
213
+ name: `${elementId}-endDate`,
214
+ required: true,
215
+ status: endDateStatus,
216
+ statusMessage: labels.rule.value.datetime.validation.required,
217
+ "aria-errormessage": endDateTimeIsBefore ? `${elementId}-combined-error` : void 0,
218
+ label: labels.rule.value.datetime.endDateLabel,
219
+ placeholder: labels.rule.value.datetime.endDatePlaceholder,
220
+ value: endDatePickerValue,
221
+ onChange: onEndDateChange,
222
+ readOnly
223
+ }), /* @__PURE__ */ jsxRuntime.jsx(TimePicker.HvTimePicker, {
224
+ className: classes.timePicker,
225
+ timeFormat: "24",
226
+ name: `${elementId}-endTime`,
227
+ required: true,
228
+ status: endTimeStatus,
229
+ statusMessage: labels.rule.value.datetime.validation.required,
230
+ "aria-errormessage": endDateTimeIsBefore ? `${elementId}-combined-error` : void 0,
231
+ label: labels.rule.value.datetime.endTimeLabel,
232
+ placeholder: labels.rule.value.datetime.endTimePlaceholder,
233
+ value: endTimePickerValue || void 0,
234
+ onChange: onEndTimeChange,
235
+ onToggle: (_evt, open) => {
236
+ if (!open && !touchedEndTime) {
237
+ setTouchedEndTime(true);
238
+ }
239
+ },
240
+ readOnly
241
+ })]
242
+ }), /* @__PURE__ */ jsxRuntime.jsx(WarningText.HvWarningText, {
243
+ disableBorder: true,
244
+ id: `${elementId}-combined-error`,
245
+ isVisible: endDateTimeIsBefore,
246
+ children: labels.rule.value.datetime.validation.invalidInterval
247
+ })]
248
+ })]
249
+ });
250
+ };
251
+ React.memo(DateTimeValue);
252
+ exports.DateTimeValue = DateTimeValue;
253
+ //# sourceMappingURL=DateTimeValue.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DateTimeValue.cjs","sources":["../../../../../../../src/components/QueryBuilder/Rule/Value/DateTimeValue/DateTimeValue.tsx"],"sourcesContent":["import { memo, useCallback, useContext, useMemo, useState } from \"react\";\n\nimport uniqueId from \"lodash/uniqueId\";\n\nimport dayjs from \"dayjs\";\n\nimport { useMediaQuery, useTheme } from \"@mui/material\";\n\nimport { HvDatePicker, HvTimePicker, HvWarningText } from \"@core/components\";\n\nimport { QueryBuilderContext } from \"../../../Context\";\nimport { padTime, parseDate, parseTime } from \"./utils\";\nimport { useClasses } from \"./DateTimeValue.styles\";\n\nfunction valueIsRange(operator) {\n return operator === \"range\";\n}\n\nexport interface DateTimeValueProps {\n id: number;\n operator: string;\n value: any;\n initialTouched: boolean;\n}\n\nexport const DateTimeValue = ({\n id,\n operator,\n value: valueProp = {},\n initialTouched = false,\n}: DateTimeValueProps) => {\n const { classes, cx } = useClasses();\n\n const theme = useTheme();\n const isMdDown = useMediaQuery(theme.breakpoints.down(\"md\"));\n\n const isRange = valueIsRange(operator);\n\n const context = useContext(QueryBuilderContext);\n const { labels, dispatchAction, readOnly } = context;\n\n const elementId = uniqueId(`datetime${id}`);\n\n const [touchedDate, setTouchedDate] = useState(initialTouched);\n const [touchedTime, setTouchedTime] = useState(initialTouched);\n const [touchedEndDate, setTouchedEndDate] = useState(initialTouched);\n const [touchedEndTime, setTouchedEndTime] = useState(initialTouched);\n\n const onDateChange = useCallback(\n (data) => {\n setTouchedDate(true);\n\n let date;\n if (data != null) {\n date = dayjs(data).format(\"YYYY-MM-DD\");\n }\n\n const oldValue = !isRange ? valueProp?.date : valueProp?.start?.date;\n\n if (date !== oldValue) {\n let value;\n if (!isRange) {\n value = {\n date,\n time: valueProp?.time,\n };\n } else {\n value = {\n start: {\n date,\n time: valueProp?.start?.time,\n },\n end: valueProp?.end,\n };\n }\n\n dispatchAction({\n type: \"set-value\",\n id,\n value,\n });\n }\n },\n [dispatchAction, id, isRange, valueProp]\n );\n\n const onTimeChange = useCallback(\n (data) => {\n setTouchedTime(true);\n\n let time;\n if (data != null) {\n time = `${padTime(data.hours)}:${padTime(data.minutes)}:${padTime(\n data.seconds\n )}`;\n }\n\n const oldValue = !isRange ? valueProp?.time : valueProp?.start?.time;\n\n if (time !== oldValue) {\n let value;\n if (!isRange) {\n value = {\n date: valueProp?.date,\n time,\n };\n } else {\n value = {\n start: {\n date: valueProp?.start?.date,\n time,\n },\n end: valueProp?.end,\n };\n }\n\n dispatchAction({\n type: \"set-value\",\n id,\n value,\n });\n }\n },\n [dispatchAction, id, isRange, valueProp]\n );\n\n const onEndDateChange = useCallback(\n (data) => {\n setTouchedEndDate(true);\n\n let date;\n if (data != null) {\n date = dayjs(data).format(\"YYYY-MM-DD\");\n }\n\n if (date !== valueProp?.end?.date) {\n const value = {\n start: valueProp?.start,\n end: {\n date,\n time: valueProp?.end?.time,\n },\n };\n\n dispatchAction({\n type: \"set-value\",\n id,\n value,\n });\n }\n },\n [dispatchAction, id, valueProp]\n );\n\n const onEndTimeChange = useCallback(\n (data) => {\n setTouchedEndTime(true);\n\n let time;\n if (data != null) {\n time = `${padTime(data.hours)}:${padTime(data.minutes)}:${padTime(\n data.seconds\n )}`;\n }\n\n if (time !== valueProp?.end?.time) {\n const value = {\n start: valueProp?.start,\n end: {\n date: valueProp?.end?.date,\n time,\n },\n };\n\n dispatchAction({\n type: \"set-value\",\n id,\n value,\n });\n }\n },\n [dispatchAction, id, valueProp]\n );\n\n const startDate = isRange ? valueProp?.start?.date : valueProp?.date;\n const datePickerValue = useMemo(() => parseDate(startDate), [startDate]);\n const datePickerStatus = datePickerValue != null ? \"valid\" : \"invalid\";\n\n const startTime = (isRange ? valueProp?.start?.time : valueProp?.time) ?? \"\";\n const timePickerValue = useMemo(() => parseTime(startTime), [startTime]);\n const timePickerStatus = timePickerValue != null ? \"valid\" : \"invalid\";\n\n const endDate = isRange ? valueProp?.end?.date : null;\n const endDatePickerValue = useMemo(() => parseDate(endDate), [endDate]);\n\n const endTime = isRange ? valueProp?.end?.time : null;\n const endTimePickerValue = useMemo(() => parseTime(endTime), [endTime]);\n\n const dateStatus = !touchedDate ? \"standBy\" : datePickerStatus;\n const timeStatus = !touchedTime ? \"standBy\" : timePickerStatus;\n\n const endDateIsBefore =\n startDate != null && endDate != null && endDate < startDate;\n\n const endTimeIsBeforeOrSame =\n startDate != null &&\n endDate != null &&\n endDate === startDate &&\n startTime != null &&\n endTime != null &&\n endTime <= startTime;\n\n const endDateTimeIsBefore = endDateIsBefore || endTimeIsBeforeOrSame;\n\n const endDatePickerStatus =\n endDatePickerValue == null || endDateTimeIsBefore ? \"invalid\" : \"valid\";\n const endDateStatus = !touchedEndDate ? \"standBy\" : endDatePickerStatus;\n\n const endTimePickerStatus =\n endTimePickerValue == null || endDateTimeIsBefore ? \"invalid\" : \"valid\";\n const endTimeStatus = !touchedEndTime ? \"standBy\" : endTimePickerStatus;\n\n return (\n <div className={classes.root}>\n <div\n className={cx(classes.row, classes.horizontal, {\n [classes.isMdDown]: isMdDown,\n })}\n >\n <HvDatePicker\n className={classes.datePicker}\n name={`${elementId}-date`}\n required\n status={dateStatus}\n statusMessage={labels.rule.value.datetime.validation.required}\n label={\n isRange\n ? labels.rule.value.datetime.startDateLabel\n : labels.rule.value.datetime.dateLabel\n }\n placeholder={\n isRange\n ? labels.rule.value.datetime.startDatePlaceholder\n : labels.rule.value.datetime.datePlaceholder\n }\n value={datePickerValue}\n onChange={onDateChange}\n readOnly={readOnly}\n />\n <HvTimePicker\n className={classes.timePicker}\n timeFormat=\"24\"\n name={`${elementId}-time`}\n required\n status={timeStatus}\n statusMessage={labels.rule.value.datetime.validation.required}\n label={\n isRange\n ? labels.rule.value.datetime.startTimeLabel\n : labels.rule.value.datetime.timeLabel\n }\n placeholder={\n isRange\n ? labels.rule.value.datetime.startTimePlaceholder\n : labels.rule.value.datetime.timePlaceholder\n }\n value={timePickerValue || undefined}\n onChange={onTimeChange}\n onToggle={(_evt, open) => {\n if (!open && !touchedTime) {\n setTouchedTime(true);\n }\n }}\n readOnly={readOnly}\n />\n </div>\n {isRange && (\n <div className={cx(classes.row, classes.vertical)}>\n <div\n className={cx(classes.horizontal, {\n [classes.isMdDown]: isMdDown,\n })}\n >\n <HvDatePicker\n className={classes.datePicker}\n name={`${elementId}-endDate`}\n required\n status={endDateStatus}\n statusMessage={labels.rule.value.datetime.validation.required}\n aria-errormessage={\n endDateTimeIsBefore ? `${elementId}-combined-error` : undefined\n }\n label={labels.rule.value.datetime.endDateLabel}\n placeholder={labels.rule.value.datetime.endDatePlaceholder}\n value={endDatePickerValue}\n onChange={onEndDateChange}\n readOnly={readOnly}\n />\n <HvTimePicker\n className={classes.timePicker}\n timeFormat=\"24\"\n name={`${elementId}-endTime`}\n required\n status={endTimeStatus}\n statusMessage={labels.rule.value.datetime.validation.required}\n aria-errormessage={\n endDateTimeIsBefore ? `${elementId}-combined-error` : undefined\n }\n label={labels.rule.value.datetime.endTimeLabel}\n placeholder={labels.rule.value.datetime.endTimePlaceholder}\n value={endTimePickerValue || undefined}\n onChange={onEndTimeChange}\n onToggle={(_evt, open) => {\n if (!open && !touchedEndTime) {\n setTouchedEndTime(true);\n }\n }}\n readOnly={readOnly}\n />\n </div>\n <HvWarningText\n disableBorder\n id={`${elementId}-combined-error`}\n isVisible={endDateTimeIsBefore}\n >\n {labels.rule.value.datetime.validation.invalidInterval}\n </HvWarningText>\n </div>\n )}\n </div>\n );\n};\n\nexport default memo(DateTimeValue);\n"],"names":["valueIsRange","operator","DateTimeValue","id","value","valueProp","initialTouched","classes","cx","useClasses","theme","useTheme","isMdDown","useMediaQuery","breakpoints","down","isRange","context","useContext","QueryBuilderContext","labels","dispatchAction","readOnly","elementId","uniqueId","touchedDate","setTouchedDate","useState","touchedTime","setTouchedTime","touchedEndDate","setTouchedEndDate","touchedEndTime","setTouchedEndTime","onDateChange","useCallback","data","date","dayjs","format","oldValue","start","time","end","type","onTimeChange","padTime","hours","minutes","seconds","onEndDateChange","onEndTimeChange","startDate","datePickerValue","useMemo","parseDate","datePickerStatus","startTime","timePickerValue","parseTime","timePickerStatus","endDate","endDatePickerValue","endTime","endTimePickerValue","dateStatus","timeStatus","endDateIsBefore","endTimeIsBeforeOrSame","endDateTimeIsBefore","endDatePickerStatus","endDateStatus","endTimePickerStatus","endTimeStatus","className","root","children","_jsxs","row","horizontal","_jsx","HvDatePicker","datePicker","name","required","status","statusMessage","rule","datetime","validation","label","startDateLabel","dateLabel","placeholder","startDatePlaceholder","datePlaceholder","onChange","HvTimePicker","timePicker","timeFormat","startTimeLabel","timeLabel","startTimePlaceholder","timePlaceholder","undefined","onToggle","_evt","open","vertical","endDateLabel","endDatePlaceholder","endTimeLabel","endTimePlaceholder","HvWarningText","disableBorder","isVisible","invalidInterval","memo"],"mappings":"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"}
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const uikitStyles = require("@hitachivantara/uikit-styles");
4
+ const classes = require("../../../../../utils/classes.cjs");
5
+ const {
6
+ useClasses,
7
+ staticClasses
8
+ } = classes.createClasses("HvQueryBuilder-DateTimeValue", {
9
+ root: {
10
+ display: "flex",
11
+ flexDirection: "column"
12
+ },
13
+ row: {
14
+ minHeight: 94
15
+ },
16
+ vertical: {
17
+ display: "flex",
18
+ flexDirection: "column"
19
+ },
20
+ horizontal: {
21
+ display: "flex",
22
+ "& > div:not(:last-child)": {
23
+ marginRight: uikitStyles.theme.space.md
24
+ }
25
+ },
26
+ isMdDown: {
27
+ "& > div:not(:last-child)": {
28
+ marginRight: `calc(${uikitStyles.theme.space.md} / 2)`
29
+ }
30
+ },
31
+ datePicker: {
32
+ flex: "0 1 300px"
33
+ },
34
+ timePicker: {
35
+ flex: "0 1 220px"
36
+ }
37
+ });
38
+ exports.staticClasses = staticClasses;
39
+ exports.useClasses = useClasses;
40
+ //# sourceMappingURL=DateTimeValue.styles.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DateTimeValue.styles.cjs","sources":["../../../../../../../src/components/QueryBuilder/Rule/Value/DateTimeValue/DateTimeValue.styles.tsx"],"sourcesContent":["import { theme } from \"@hitachivantara/uikit-styles\";\nimport { createClasses } from \"@core/utils\";\n\nexport const { useClasses, staticClasses } = createClasses(\n \"HvQueryBuilder-DateTimeValue\",\n {\n root: {\n display: \"flex\",\n flexDirection: \"column\",\n },\n row: {\n minHeight: 94,\n },\n vertical: {\n display: \"flex\",\n flexDirection: \"column\",\n },\n horizontal: {\n display: \"flex\",\n\n \"& > div:not(:last-child)\": {\n marginRight: theme.space.md,\n },\n },\n isMdDown: {\n \"& > div:not(:last-child)\": {\n marginRight: `calc(${theme.space.md} / 2)`,\n },\n },\n datePicker: {\n flex: \"0 1 300px\",\n },\n timePicker: {\n flex: \"0 1 220px\",\n },\n }\n);\n"],"names":["useClasses","staticClasses","createClasses","root","display","flexDirection","row","minHeight","vertical","horizontal","marginRight","theme","space","md","isMdDown","datePicker","flex","timePicker"],"mappings":";;;;AAGa,MAAA;AAAA,EAAEA;AAAAA,EAAYC;AAAc,IAAIC,QAAAA,cAC3C,gCACA;AAAA,EACEC,MAAM;AAAA,IACJC,SAAS;AAAA,IACTC,eAAe;AAAA,EACjB;AAAA,EACAC,KAAK;AAAA,IACHC,WAAW;AAAA,EACb;AAAA,EACAC,UAAU;AAAA,IACRJ,SAAS;AAAA,IACTC,eAAe;AAAA,EACjB;AAAA,EACAI,YAAY;AAAA,IACVL,SAAS;AAAA,IAET,4BAA4B;AAAA,MAC1BM,aAAaC,YAAAA,MAAMC,MAAMC;AAAAA,IAC3B;AAAA,EACF;AAAA,EACAC,UAAU;AAAA,IACR,4BAA4B;AAAA,MAC1BJ,aAAc,QAAOC,YAAAA,MAAMC,MAAMC;AAAAA,IACnC;AAAA,EACF;AAAA,EACAE,YAAY;AAAA,IACVC,MAAM;AAAA,EACR;AAAA,EACAC,YAAY;AAAA,IACVD,MAAM;AAAA,EACR;AACF,CACF;;;"}
@@ -0,0 +1,37 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const dayjs = require("dayjs");
4
+ const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
5
+ const dayjs__default = /* @__PURE__ */ _interopDefault(dayjs);
6
+ const padTime = (value) => {
7
+ if (!value || value < 0) {
8
+ return "00";
9
+ }
10
+ if (value < 10 && value.toString().length === 1) {
11
+ return `0${value.toString()}`;
12
+ }
13
+ return value.toString();
14
+ };
15
+ const parseDate = (date) => {
16
+ if (date != null) {
17
+ return dayjs__default.default(date).toDate();
18
+ }
19
+ return void 0;
20
+ };
21
+ const parseTime = (time) => {
22
+ if (time != null) {
23
+ const parts = time.split(":");
24
+ if (parts.length === 3) {
25
+ return {
26
+ hours: Number.parseInt(parts[0], 10),
27
+ minutes: Number.parseInt(parts[1], 10),
28
+ seconds: Number.parseInt(parts[2], 10)
29
+ };
30
+ }
31
+ }
32
+ return null;
33
+ };
34
+ exports.padTime = padTime;
35
+ exports.parseDate = parseDate;
36
+ exports.parseTime = parseTime;
37
+ //# sourceMappingURL=utils.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.cjs","sources":["../../../../../../../src/components/QueryBuilder/Rule/Value/DateTimeValue/utils.tsx"],"sourcesContent":["import dayjs from \"dayjs\";\n\n/**\n * Pads the unit time values so that they always have two digits\n * @param {Number} value - unit time value\n * @returns The unit time value with two digits\n */\nexport const padTime = (value) => {\n if (!value || value < 0) {\n return \"00\";\n }\n if (value < 10 && value.toString().length === 1) {\n return `0${value.toString()}`;\n }\n\n return value.toString();\n};\n\nexport const parseDate = (date) => {\n if (date != null) {\n return dayjs(date).toDate();\n }\n\n return undefined;\n};\n\nexport const parseTime = (time) => {\n if (time != null) {\n const parts = time.split(\":\");\n\n if (parts.length === 3) {\n return {\n hours: Number.parseInt(parts[0], 10),\n minutes: Number.parseInt(parts[1], 10),\n seconds: Number.parseInt(parts[2], 10),\n };\n }\n }\n\n return null;\n};\n"],"names":["padTime","value","toString","length","parseDate","date","dayjs","toDate","undefined","parseTime","time","parts","split","hours","Number","parseInt","minutes","seconds"],"mappings":";;;;;AAOO,MAAMA,UAAWC,CAAU,UAAA;AAC5B,MAAA,CAACA,SAASA,QAAQ,GAAG;AAChB,WAAA;AAAA,EACT;AACA,MAAIA,QAAQ,MAAMA,MAAMC,SAAS,EAAEC,WAAW,GAAG;AACvC,WAAA,IAAGF,MAAMC,SAAS;AAAA,EAC5B;AAEA,SAAOD,MAAMC;AACf;AAEO,MAAME,YAAaC,CAAS,SAAA;AACjC,MAAIA,QAAQ,MAAM;AACTC,WAAAA,uBAAMD,IAAI,EAAEE;EACrB;AAEOC,SAAAA;AACT;AAEO,MAAMC,YAAaC,CAAS,SAAA;AACjC,MAAIA,QAAQ,MAAM;AACVC,UAAAA,QAAQD,KAAKE,MAAM,GAAG;AAExBD,QAAAA,MAAMR,WAAW,GAAG;AACf,aAAA;AAAA,QACLU,OAAOC,OAAOC,SAASJ,MAAM,CAAC,GAAG,EAAE;AAAA,QACnCK,SAASF,OAAOC,SAASJ,MAAM,CAAC,GAAG,EAAE;AAAA,QACrCM,SAASH,OAAOC,SAASJ,MAAM,CAAC,GAAG,EAAE;AAAA,MAAA;AAAA,IAEzC;AAAA,EACF;AAEO,SAAA;AACT;;;;"}
@@ -1,8 +1,11 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const uikitStyles = require("@hitachivantara/uikit-styles");
4
- const numericValueClasses = require("./numericValueClasses.cjs");
5
- const styles = {
4
+ const classes = require("../../../../../utils/classes.cjs");
5
+ const {
6
+ useClasses,
7
+ staticClasses
8
+ } = classes.createClasses("HvQueryBuilder-NumericValue", {
6
9
  root: {
7
10
  display: "flex",
8
11
  flexGrow: 1
@@ -18,7 +21,7 @@ const styles = {
18
21
  rangeContainer: {
19
22
  display: "flex",
20
23
  flexGrow: 1,
21
- [`& > .${numericValueClasses.default.inputContainer}:not(:last-child)`]: {
24
+ "& > $inputContainer:not(:last-child)": {
22
25
  marginRight: uikitStyles.theme.space.md
23
26
  }
24
27
  },
@@ -26,10 +29,11 @@ const styles = {
26
29
  flexGrow: 1
27
30
  },
28
31
  isMdDown: {
29
- [`& > .${numericValueClasses.default.inputContainer}:not(:last-child)`]: {
32
+ "& > $inputContainer:not(:last-child)": {
30
33
  marginRight: `calc(${uikitStyles.theme.space.md} / 2)`
31
34
  }
32
35
  }
33
- };
34
- exports.styles = styles;
36
+ });
37
+ exports.staticClasses = staticClasses;
38
+ exports.useClasses = useClasses;
35
39
  //# sourceMappingURL=Numeric.styles.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"Numeric.styles.cjs","sources":["../../../../../../../src/components/QueryBuilder/Rule/Value/NumericValue/Numeric.styles.tsx"],"sourcesContent":["import { CSSInterpolation } from \"@emotion/serialize\";\nimport { theme } from \"@hitachivantara/uikit-styles\";\nimport numericValueClasses, {\n HvNumericValueClasses,\n} from \"./numericValueClasses\";\n\nexport const styles: Partial<\n Record<keyof HvNumericValueClasses, CSSInterpolation>\n> = {\n root: {\n display: \"flex\",\n flexGrow: 1,\n },\n label: {\n paddingBottom: \"6px\",\n },\n inputContainer: {\n display: \"flex\",\n alignItems: \"baseline\",\n flexGrow: 1,\n },\n rangeContainer: {\n display: \"flex\",\n flexGrow: 1,\n\n [`& > .${numericValueClasses.inputContainer}:not(:last-child)`]: {\n marginRight: theme.space.md,\n },\n },\n input: {\n flexGrow: 1,\n },\n isMdDown: {\n [`& > .${numericValueClasses.inputContainer}:not(:last-child)`]: {\n marginRight: `calc(${theme.space.md} / 2)`,\n },\n },\n};\n"],"names":["styles","root","display","flexGrow","label","paddingBottom","inputContainer","alignItems","rangeContainer","numericValueClasses","marginRight","theme","space","md","input","isMdDown"],"mappings":";;;;AAMO,MAAMA,SAET;AAAA,EACFC,MAAM;AAAA,IACJC,SAAS;AAAA,IACTC,UAAU;AAAA,EACZ;AAAA,EACAC,OAAO;AAAA,IACLC,eAAe;AAAA,EACjB;AAAA,EACAC,gBAAgB;AAAA,IACdJ,SAAS;AAAA,IACTK,YAAY;AAAA,IACZJ,UAAU;AAAA,EACZ;AAAA,EACAK,gBAAgB;AAAA,IACdN,SAAS;AAAA,IACTC,UAAU;AAAA,IAEV,CAAE,QAAOM,oBAAAA,QAAoBH,iCAAiC,GAAG;AAAA,MAC/DI,aAAaC,YAAAA,MAAMC,MAAMC;AAAAA,IAC3B;AAAA,EACF;AAAA,EACAC,OAAO;AAAA,IACLX,UAAU;AAAA,EACZ;AAAA,EACAY,UAAU;AAAA,IACR,CAAE,QAAON,oBAAAA,QAAoBH,iCAAiC,GAAG;AAAA,MAC/DI,aAAc,QAAOC,YAAAA,MAAMC,MAAMC;AAAAA,IACnC;AAAA,EACF;AACF;;"}
1
+ {"version":3,"file":"Numeric.styles.cjs","sources":["../../../../../../../src/components/QueryBuilder/Rule/Value/NumericValue/Numeric.styles.tsx"],"sourcesContent":["import { theme } from \"@hitachivantara/uikit-styles\";\nimport { createClasses } from \"@core/utils\";\n\nexport const { useClasses, staticClasses } = createClasses(\n \"HvQueryBuilder-NumericValue\",\n {\n root: {\n display: \"flex\",\n flexGrow: 1,\n },\n label: {\n paddingBottom: \"6px\",\n },\n inputContainer: {\n display: \"flex\",\n alignItems: \"baseline\",\n flexGrow: 1,\n },\n rangeContainer: {\n display: \"flex\",\n flexGrow: 1,\n\n \"& > $inputContainer:not(:last-child)\": {\n marginRight: theme.space.md,\n },\n },\n input: {\n flexGrow: 1,\n },\n isMdDown: {\n \"& > $inputContainer:not(:last-child)\": {\n marginRight: `calc(${theme.space.md} / 2)`,\n },\n },\n }\n);\n"],"names":["useClasses","staticClasses","createClasses","root","display","flexGrow","label","paddingBottom","inputContainer","alignItems","rangeContainer","marginRight","theme","space","md","input","isMdDown"],"mappings":";;;;AAGa,MAAA;AAAA,EAAEA;AAAAA,EAAYC;AAAc,IAAIC,QAAAA,cAC3C,+BACA;AAAA,EACEC,MAAM;AAAA,IACJC,SAAS;AAAA,IACTC,UAAU;AAAA,EACZ;AAAA,EACAC,OAAO;AAAA,IACLC,eAAe;AAAA,EACjB;AAAA,EACAC,gBAAgB;AAAA,IACdJ,SAAS;AAAA,IACTK,YAAY;AAAA,IACZJ,UAAU;AAAA,EACZ;AAAA,EACAK,gBAAgB;AAAA,IACdN,SAAS;AAAA,IACTC,UAAU;AAAA,IAEV,wCAAwC;AAAA,MACtCM,aAAaC,YAAAA,MAAMC,MAAMC;AAAAA,IAC3B;AAAA,EACF;AAAA,EACAC,OAAO;AAAA,IACLV,UAAU;AAAA,EACZ;AAAA,EACAW,UAAU;AAAA,IACR,wCAAwC;AAAA,MACtCL,aAAc,QAAOC,YAAAA,MAAMC,MAAMC;AAAAA,IACnC;AAAA,EACF;AACF,CACF;;;"}
@@ -3,11 +3,9 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const React = require("react");
4
4
  const uniqueId = require("lodash/uniqueId");
5
5
  const isEmpty = require("lodash/isEmpty");
6
- const react = require("@emotion/react");
7
6
  const material = require("@mui/material");
8
7
  const Context = require("../../../Context.cjs");
9
8
  const Numeric_styles = require("./Numeric.styles.cjs");
10
- const numericValueClasses = require("./numericValueClasses.cjs");
11
9
  const jsxRuntime = require("@emotion/react/jsx-runtime");
12
10
  const Input = require("../../../../Input/Input.cjs");
13
11
  const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
@@ -20,6 +18,10 @@ const NumericValue = ({
20
18
  initialTouched = false
21
19
  }) => {
22
20
  var _a, _b;
21
+ const {
22
+ classes,
23
+ cx
24
+ } = Numeric_styles.useClasses();
23
25
  const isRange = operator === "range";
24
26
  const context = React.useContext(Context.QueryBuilderContext);
25
27
  const {
@@ -92,85 +94,21 @@ const NumericValue = ({
92
94
  }
93
95
  const numericStatus = numericValidation != null ? "invalid" : "valid";
94
96
  const rightStatus = rightValidation != null ? "invalid" : "valid";
95
- const renderRangeInputs = (rangeValue) => /* @__PURE__ */ jsxRuntime.jsx(react.ClassNames, {
96
- children: ({
97
- css,
98
- cx
99
- }) => {
100
- var _a2, _b2;
101
- return /* @__PURE__ */ jsxRuntime.jsxs("div", {
102
- className: cx(numericValueClasses.default.rangeContainer, css(Numeric_styles.styles.rangeContainer), isMdDown ? cx(numericValueClasses.default.isMdDown, css(Numeric_styles.styles.isMdDown)) : ""),
103
- children: [/* @__PURE__ */ jsxRuntime.jsx("div", {
104
- className: cx(numericValueClasses.default.inputContainer, css(Numeric_styles.styles.inputContainer)),
105
- children: /* @__PURE__ */ jsxRuntime.jsx(Input.HvInput, {
106
- label: labels.rule.value.numeric.range.leftLabel,
107
- className: cx(numericValueClasses.default.input, css(Numeric_styles.styles.input)),
108
- id: `${elementId}-numeric-from`,
109
- name: `${elementId}-numeric-from`,
110
- value: ((_a2 = rangeValue == null ? void 0 : rangeValue.from) == null ? void 0 : _a2.toString()) || "",
111
- onChange: (event, data) => onRangeValueChange(event, data),
112
- onBlur: () => {
113
- setTouchedNumeric(true);
114
- },
115
- onKeyDown: (e) => {
116
- if (e.key === "Enter") {
117
- e.preventDefault();
118
- }
119
- },
120
- status: !touchedNumeric ? "standBy" : numericStatus,
121
- statusMessage: numericValidation ? labels.rule.value.numeric.validation[numericValidation] : "",
122
- required: true,
123
- inputProps: {
124
- autoComplete: "off"
125
- },
126
- placeholder: labels.rule.value.numeric.placeholder,
127
- readOnly
128
- })
129
- }), /* @__PURE__ */ jsxRuntime.jsx("div", {
130
- className: cx(numericValueClasses.default.inputContainer, css(Numeric_styles.styles.inputContainer)),
131
- children: /* @__PURE__ */ jsxRuntime.jsx(Input.HvInput, {
132
- label: labels.rule.value.numeric.range.rightLabel,
133
- className: cx(numericValueClasses.default.input, css(Numeric_styles.styles.input)),
134
- id: `${elementId}-numeric-to`,
135
- name: `${elementId}-numeric-to`,
136
- value: ((_b2 = rangeValue == null ? void 0 : rangeValue.to) == null ? void 0 : _b2.toString()) || "",
137
- onChange: (event, data) => onRangeValueChange(event, data, false),
138
- onBlur: () => {
139
- setTouchedNumericTo(true);
140
- },
141
- onKeyDown: (e) => {
142
- if (e.key === "Enter") {
143
- e.preventDefault();
144
- }
145
- },
146
- status: !touchedNumericTo ? "standBy" : rightStatus,
147
- statusMessage: rightValidation ? labels.rule.value.numeric.validation[rightValidation] : "",
148
- required: true,
149
- inputProps: {
150
- autoComplete: "off"
151
- },
152
- placeholder: labels.rule.value.numeric.placeholder,
153
- readOnly
154
- })
155
- })]
156
- });
157
- }
158
- });
159
- return /* @__PURE__ */ jsxRuntime.jsx(react.ClassNames, {
160
- children: ({
161
- css,
162
- cx
163
- }) => /* @__PURE__ */ jsxRuntime.jsxs("div", {
164
- className: cx(numericValueClasses.default.root, css(Numeric_styles.styles.root)),
165
- children: [isRange && renderRangeInputs(value || {}), !isRange && /* @__PURE__ */ jsxRuntime.jsx("div", {
166
- className: cx(numericValueClasses.default.inputContainer, css(Numeric_styles.styles.inputContainer)),
97
+ const renderRangeInputs = (rangeValue) => {
98
+ var _a2, _b2;
99
+ return /* @__PURE__ */ jsxRuntime.jsxs("div", {
100
+ className: cx(classes.rangeContainer, {
101
+ [classes.isMdDown]: isMdDown
102
+ }),
103
+ children: [/* @__PURE__ */ jsxRuntime.jsx("div", {
104
+ className: classes.inputContainer,
167
105
  children: /* @__PURE__ */ jsxRuntime.jsx(Input.HvInput, {
168
- label: labels.rule.value.numeric.label,
169
- className: cx(numericValueClasses.default.input, css(Numeric_styles.styles.input)),
170
- id: `${elementId}-numeric`,
171
- name: `${elementId}-numeric`,
172
- value: value ? value.toString() : "",
173
- onChange: onSingleValueChange,
106
+ label: labels.rule.value.numeric.range.leftLabel,
107
+ className: classes.input,
108
+ id: `${elementId}-numeric-from`,
109
+ name: `${elementId}-numeric-from`,
110
+ value: ((_a2 = rangeValue == null ? void 0 : rangeValue.from) == null ? void 0 : _a2.toString()) || "",
111
+ onChange: (event, data) => onRangeValueChange(event, data),
174
112
  onBlur: () => {
175
113
  setTouchedNumeric(true);
176
114
  },
@@ -180,16 +118,72 @@ const NumericValue = ({
180
118
  }
181
119
  },
182
120
  status: !touchedNumeric ? "standBy" : numericStatus,
121
+ statusMessage: numericValidation ? labels.rule.value.numeric.validation[numericValidation] : "",
122
+ required: true,
123
+ inputProps: {
124
+ autoComplete: "off"
125
+ },
126
+ placeholder: labels.rule.value.numeric.placeholder,
127
+ readOnly
128
+ })
129
+ }), /* @__PURE__ */ jsxRuntime.jsx("div", {
130
+ className: classes.inputContainer,
131
+ children: /* @__PURE__ */ jsxRuntime.jsx(Input.HvInput, {
132
+ label: labels.rule.value.numeric.range.rightLabel,
133
+ className: classes.input,
134
+ id: `${elementId}-numeric-to`,
135
+ name: `${elementId}-numeric-to`,
136
+ value: ((_b2 = rangeValue == null ? void 0 : rangeValue.to) == null ? void 0 : _b2.toString()) || "",
137
+ onChange: (event, data) => onRangeValueChange(event, data, false),
138
+ onBlur: () => {
139
+ setTouchedNumericTo(true);
140
+ },
141
+ onKeyDown: (e) => {
142
+ if (e.key === "Enter") {
143
+ e.preventDefault();
144
+ }
145
+ },
146
+ status: !touchedNumericTo ? "standBy" : rightStatus,
147
+ statusMessage: rightValidation ? labels.rule.value.numeric.validation[rightValidation] : "",
183
148
  required: true,
184
149
  inputProps: {
185
150
  autoComplete: "off"
186
151
  },
187
152
  placeholder: labels.rule.value.numeric.placeholder,
188
- statusMessage: numericValidation ? labels.rule.value.numeric.validation[numericValidation] : "",
189
153
  readOnly
190
154
  })
191
155
  })]
192
- })
156
+ });
157
+ };
158
+ return /* @__PURE__ */ jsxRuntime.jsxs("div", {
159
+ className: classes.root,
160
+ children: [isRange && renderRangeInputs(value || {}), !isRange && /* @__PURE__ */ jsxRuntime.jsx("div", {
161
+ className: classes.inputContainer,
162
+ children: /* @__PURE__ */ jsxRuntime.jsx(Input.HvInput, {
163
+ label: labels.rule.value.numeric.label,
164
+ className: classes.input,
165
+ id: `${elementId}-numeric`,
166
+ name: `${elementId}-numeric`,
167
+ value: value ? value.toString() : "",
168
+ onChange: onSingleValueChange,
169
+ onBlur: () => {
170
+ setTouchedNumeric(true);
171
+ },
172
+ onKeyDown: (e) => {
173
+ if (e.key === "Enter") {
174
+ e.preventDefault();
175
+ }
176
+ },
177
+ status: !touchedNumeric ? "standBy" : numericStatus,
178
+ required: true,
179
+ inputProps: {
180
+ autoComplete: "off"
181
+ },
182
+ placeholder: labels.rule.value.numeric.placeholder,
183
+ statusMessage: numericValidation ? labels.rule.value.numeric.validation[numericValidation] : "",
184
+ readOnly
185
+ })
186
+ })]
193
187
  });
194
188
  };
195
189
  React.memo(NumericValue);