@1money/component-ui 0.0.79 → 0.0.81

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 (101) hide show
  1. package/es/business/Filter/Account/Account.js +72 -210
  2. package/es/business/Filter/Account/interface.d.ts +3 -2
  3. package/es/business/Filter/Account/style/Account.css +2 -42
  4. package/es/business/Filter/Account/style/css.js +3 -1
  5. package/es/business/Filter/Account/style/index.d.ts +2 -0
  6. package/es/business/Filter/Account/style/index.js +3 -1
  7. package/es/business/Filter/Asset/Asset.js +67 -210
  8. package/es/business/Filter/Asset/interface.d.ts +3 -2
  9. package/es/business/Filter/Asset/style/Asset.css +3 -44
  10. package/es/business/Filter/Asset/style/css.js +2 -1
  11. package/es/business/Filter/Asset/style/index.d.ts +1 -0
  12. package/es/business/Filter/Asset/style/index.js +2 -1
  13. package/es/business/Filter/DateRange/DateRange.js +12 -8
  14. package/es/business/Filter/DateRange/interface.d.ts +0 -5
  15. package/es/business/Filter/DateRange/style/DateRange.css +10 -5
  16. package/es/business/Filter/Option/Option.js +51 -194
  17. package/es/business/Filter/Option/interface.d.ts +3 -2
  18. package/es/business/Filter/Option/style/Option.css +1 -63
  19. package/es/business/Filter/Option/style/css.js +2 -1
  20. package/es/business/Filter/Option/style/index.d.ts +1 -0
  21. package/es/business/Filter/Option/style/index.js +2 -1
  22. package/es/components/Filter/Filter.d.ts +2 -0
  23. package/es/components/Filter/Filter.js +266 -0
  24. package/es/components/Filter/index.d.ts +4 -0
  25. package/es/components/Filter/index.js +5 -0
  26. package/es/components/Filter/interface.d.ts +67 -0
  27. package/es/components/Filter/interface.js +2 -0
  28. package/es/components/Filter/style/Filter.css +95 -0
  29. package/es/components/Filter/style/css.js +8 -0
  30. package/es/components/Filter/style/index.d.ts +7 -0
  31. package/es/components/Filter/style/index.js +8 -0
  32. package/es/components/Input/Amount/Amount.js +7 -4
  33. package/es/components/Input/Input/Input.css +13 -0
  34. package/es/components/Input/Search/Search.js +3 -2
  35. package/es/components/Input/constants.d.ts +1 -1
  36. package/es/components/Input/constants.js +4 -3
  37. package/es/components/Pagination/constants.js +3 -2
  38. package/es/components/Pagination/style/Pagination.css +10 -8
  39. package/es/components/Select/Select.js +2 -2
  40. package/es/components/Select/SelectCustom.js +2 -2
  41. package/es/components/Select/SelectSearchControl.js +2 -2
  42. package/es/components/Select/constants.js +3 -2
  43. package/es/components/Select/interface.d.ts +1 -1
  44. package/es/components/Select/interface.js +2 -2
  45. package/es/components/Select/style/Select.css +13 -6
  46. package/es/components/Select/utils.js +8 -3
  47. package/es/index.css +1 -1
  48. package/es/index.d.ts +2 -0
  49. package/es/index.js +2 -1
  50. package/lib/business/Filter/Account/Account.js +70 -209
  51. package/lib/business/Filter/Account/interface.d.ts +3 -2
  52. package/lib/business/Filter/Account/style/Account.css +2 -42
  53. package/lib/business/Filter/Account/style/css.js +3 -1
  54. package/lib/business/Filter/Account/style/index.d.ts +2 -0
  55. package/lib/business/Filter/Account/style/index.js +3 -1
  56. package/lib/business/Filter/Asset/Asset.js +65 -209
  57. package/lib/business/Filter/Asset/interface.d.ts +3 -2
  58. package/lib/business/Filter/Asset/style/Asset.css +3 -44
  59. package/lib/business/Filter/Asset/style/css.js +2 -1
  60. package/lib/business/Filter/Asset/style/index.d.ts +1 -0
  61. package/lib/business/Filter/Asset/style/index.js +2 -1
  62. package/lib/business/Filter/DateRange/DateRange.js +12 -8
  63. package/lib/business/Filter/DateRange/interface.d.ts +0 -5
  64. package/lib/business/Filter/DateRange/style/DateRange.css +10 -5
  65. package/lib/business/Filter/Option/Option.js +49 -193
  66. package/lib/business/Filter/Option/interface.d.ts +3 -2
  67. package/lib/business/Filter/Option/style/Option.css +1 -63
  68. package/lib/business/Filter/Option/style/css.js +2 -1
  69. package/lib/business/Filter/Option/style/index.d.ts +1 -0
  70. package/lib/business/Filter/Option/style/index.js +2 -1
  71. package/lib/components/Filter/Filter.d.ts +2 -0
  72. package/lib/components/Filter/Filter.js +273 -0
  73. package/lib/components/Filter/index.d.ts +4 -0
  74. package/lib/components/Filter/index.js +30 -0
  75. package/lib/components/Filter/interface.d.ts +67 -0
  76. package/lib/components/Filter/interface.js +6 -0
  77. package/lib/components/Filter/style/Filter.css +95 -0
  78. package/lib/components/Filter/style/css.js +10 -0
  79. package/lib/components/Filter/style/index.d.ts +7 -0
  80. package/lib/components/Filter/style/index.js +10 -0
  81. package/lib/components/Input/Amount/Amount.js +7 -4
  82. package/lib/components/Input/Input/Input.css +13 -0
  83. package/lib/components/Input/Search/Search.js +3 -2
  84. package/lib/components/Input/constants.d.ts +1 -1
  85. package/lib/components/Input/constants.js +4 -3
  86. package/lib/components/Pagination/constants.js +3 -2
  87. package/lib/components/Pagination/style/Pagination.css +10 -8
  88. package/lib/components/Select/Select.js +2 -2
  89. package/lib/components/Select/SelectCustom.js +2 -2
  90. package/lib/components/Select/SelectSearchControl.js +2 -2
  91. package/lib/components/Select/constants.js +3 -2
  92. package/lib/components/Select/interface.d.ts +1 -1
  93. package/lib/components/Select/interface.js +2 -2
  94. package/lib/components/Select/style/Select.css +13 -6
  95. package/lib/components/Select/utils.js +8 -3
  96. package/lib/index.css +1 -1
  97. package/lib/index.d.ts +2 -0
  98. package/lib/index.js +8 -1
  99. package/package.json +6 -1
  100. package/scripts/mcp-server/examples.generated.json +42 -24
  101. package/scripts/mcp-server/index.generated.json +72 -4
@@ -0,0 +1,273 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.Filter = void 0;
8
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
9
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
10
+ var _jsxRuntime = require("react/jsx-runtime");
11
+ var _react = require("react");
12
+ var _Button = require("../Button");
13
+ var _Checkbox = require("../Checkbox");
14
+ var _Empty = require("../Empty");
15
+ var _Flex = require("../Flex");
16
+ var _Icons = require("../Icons");
17
+ var _Select = require("../Select");
18
+ var _Typography = require("../Typography");
19
+ var _classnames = require("../../utils/classnames");
20
+ var __rest = void 0 && (void 0).__rest || function (s, e) {
21
+ var t = {};
22
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
23
+ if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
24
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
25
+ }
26
+ return t;
27
+ };
28
+ var WRAP_CLS = 'om-filter';
29
+ // The panel is portaled to <body>, so panel-scoped overrides are keyed off this
30
+ // class (passed as `panelClassName`) rather than the trigger root.
31
+ var PANEL_CLS = "".concat(WRAP_CLS, "-panel");
32
+ var RESET_LABEL = 'Reset';
33
+ var APPLY_LABEL = 'Apply';
34
+ var DEFAULT_ALL_LABEL = 'All';
35
+ var DEFAULT_SEARCH_PLACEHOLDER = 'Search';
36
+ var DEFAULT_EMPTY = (0, _jsxRuntime.jsx)(_Empty.Empty, {
37
+ variant: 'fill',
38
+ icon: (0, _jsxRuntime.jsx)(_Icons.Icons, {
39
+ name: 'search',
40
+ size: 16,
41
+ color: 'currentColor'
42
+ }),
43
+ // Figma empty-state text is Body Small (12px); Empty's string path would
44
+ // render Title sm / Body md (14px), so pass 12px nodes explicitly.
45
+ title: (0, _jsxRuntime.jsx)(_Typography.TypographyBody, {
46
+ size: 'sm',
47
+ strong: true,
48
+ color: 'neutral-secondary',
49
+ children: "No results"
50
+ }),
51
+ description: (0, _jsxRuntime.jsx)(_Typography.TypographyBody, {
52
+ size: 'sm',
53
+ color: 'neutral-secondary',
54
+ children: "Try a different name or adjust your search filters."
55
+ }),
56
+ style: {
57
+ padding: 0
58
+ }
59
+ });
60
+ var MORE_SUFFIX = function MORE_SUFFIX(count) {
61
+ return "+ ".concat(count, " more");
62
+ };
63
+ var FULL_WIDTH_STYLE = {
64
+ flex: 1
65
+ };
66
+ var isGroup = function isGroup(item) {
67
+ return !!item && (0, _typeof2["default"])(item) === 'object' && Array.isArray(item.options);
68
+ };
69
+ // Flatten flat/grouped options into a single ordered option list — used for the
70
+ // value→label lookup and the "every option selected" count.
71
+ var flattenOptions = function flattenOptions(data) {
72
+ return data.flatMap(function (item) {
73
+ return isGroup(item) ? item.options : [item];
74
+ });
75
+ };
76
+ var FilterBase = function FilterBase(_a) {
77
+ var ref = _a.ref,
78
+ className = _a.className,
79
+ panelClassName = _a.panelClassName,
80
+ _a$size = _a.size,
81
+ size = _a$size === void 0 ? 'extra-small' : _a$size,
82
+ label = _a.label,
83
+ placeholder = _a.placeholder,
84
+ options = _a.options,
85
+ _a$allLabel = _a.allLabel,
86
+ allLabel = _a$allLabel === void 0 ? DEFAULT_ALL_LABEL : _a$allLabel,
87
+ _a$search = _a.search,
88
+ search = _a$search === void 0 ? true : _a$search,
89
+ _a$searchPlaceholder = _a.searchPlaceholder,
90
+ searchPlaceholder = _a$searchPlaceholder === void 0 ? DEFAULT_SEARCH_PLACEHOLDER : _a$searchPlaceholder,
91
+ filterOption = _a.filterOption,
92
+ _a$emptyContent = _a.emptyContent,
93
+ emptyContent = _a$emptyContent === void 0 ? DEFAULT_EMPTY : _a$emptyContent,
94
+ renderRow = _a.renderRow,
95
+ onApply = _a.onApply,
96
+ onReset = _a.onReset,
97
+ rest = __rest(_a, ["ref", "className", "panelClassName", "size", "label", "placeholder", "options", "allLabel", "search", "searchPlaceholder", "filterOption", "emptyContent", "renderRow", "onApply", "onReset"]);
98
+ var flatOptions = (0, _react.useMemo)(function () {
99
+ return flattenOptions(options);
100
+ }, [options]);
101
+ var allValues = (0, _react.useMemo)(function () {
102
+ return flatOptions.map(function (option) {
103
+ return String(option.value);
104
+ });
105
+ }, [flatOptions]);
106
+ var optionByValue = (0, _react.useMemo)(function () {
107
+ var map = new Map();
108
+ flatOptions.forEach(function (option) {
109
+ return map.set(String(option.value), option);
110
+ });
111
+ return map;
112
+ }, [flatOptions]);
113
+ var _useState = (0, _react.useState)(false),
114
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
115
+ open = _useState2[0],
116
+ setOpen = _useState2[1];
117
+ var _useState3 = (0, _react.useState)(''),
118
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
119
+ keyword = _useState4[0],
120
+ setKeyword = _useState4[1];
121
+ // `temp` is the in-panel draft; `committed` is the last Applied selection.
122
+ // Only Apply promotes `temp` → `committed` and notifies the parent. With an
123
+ // "All" row, "all selected" is represented by an empty array.
124
+ var _useState5 = (0, _react.useState)([]),
125
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
126
+ temp = _useState6[0],
127
+ setTemp = _useState6[1];
128
+ var _useState7 = (0, _react.useState)([]),
129
+ _useState8 = (0, _slicedToArray2["default"])(_useState7, 2),
130
+ committed = _useState8[0],
131
+ setCommitted = _useState8[1];
132
+ // The "All" row is checked exactly when nothing specific is selected.
133
+ var allChecked = temp.length === 0;
134
+ // While searching, the "All" row is meaningless — hide it so a no-match search
135
+ // shows the empty state instead of a lone "All" row.
136
+ var searching = search && keyword.trim().length > 0;
137
+ var defaultFilterOption = (0, _react.useCallback)(function (searchValue, option) {
138
+ var term = searchValue.trim().toLowerCase();
139
+ if (!term) return true;
140
+ return typeof option.searchText === 'string' ? option.searchText.toLowerCase().includes(term) : false;
141
+ }, []);
142
+ (0, _react.useImperativeHandle)(ref, function () {
143
+ return {
144
+ clear: function clear() {
145
+ setTemp([]);
146
+ setCommitted([]);
147
+ },
148
+ reset: function reset() {
149
+ setTemp([]);
150
+ setCommitted([]);
151
+ onReset === null || onReset === void 0 ? void 0 : onReset([]);
152
+ }
153
+ };
154
+ }, [onReset]);
155
+ var handleSelectChange = (0, _react.useCallback)(function (next) {
156
+ var nextValues = (Array.isArray(next) ? next : []).map(String);
157
+ // Selecting every concrete option collapses to "all" ([]), matching the
158
+ // backend convention that empty == no filter.
159
+ var collapse = nextValues.length === allValues.length;
160
+ setTemp(collapse ? [] : nextValues);
161
+ }, [allValues]);
162
+ var handleAllClick = (0, _react.useCallback)(function () {
163
+ // The "All" row is exclusive: turning it on clears specific picks.
164
+ setTemp([]);
165
+ }, []);
166
+ var handleApply = (0, _react.useCallback)(function () {
167
+ setCommitted(temp);
168
+ onApply(temp);
169
+ setOpen(false);
170
+ }, [temp, onApply]);
171
+ var handleReset = (0, _react.useCallback)(function () {
172
+ setTemp([]);
173
+ setCommitted([]);
174
+ onReset === null || onReset === void 0 ? void 0 : onReset([]);
175
+ }, [onReset]);
176
+ var handleOpenChange = (0, _react.useCallback)(function (nextOpen) {
177
+ setOpen(nextOpen);
178
+ if (nextOpen) return;
179
+ // Closing without Apply discards the draft.
180
+ setTemp(committed);
181
+ setKeyword('');
182
+ }, [committed]);
183
+ // The trigger reflects the COMMITTED selection only — `temp` is the in-panel
184
+ // draft and must not leak into the trigger before Apply. An empty `committed`
185
+ // means "all" (the `allLabel`). `renderValue` short-circuits Select's own
186
+ // placeholder handling, so the empty state must return `allLabel` explicitly.
187
+ var renderValue = (0, _react.useCallback)(function () {
188
+ if (committed.length === 0) {
189
+ // `allLabel` is the default filter value, not an empty placeholder. The
190
+ // trigger's empty `value` makes Select wrap this in its grey placeholder
191
+ // class, so force the default dark text to match DateRange.
192
+ return (0, _jsxRuntime.jsx)(_Typography.TypographyBody, {
193
+ size: 'md',
194
+ color: 'default',
195
+ className: "".concat(WRAP_CLS, "__value"),
196
+ children: (0, _jsxRuntime.jsx)("span", {
197
+ className: "".concat(WRAP_CLS, "__value-label"),
198
+ children: allLabel
199
+ })
200
+ });
201
+ }
202
+ var first = optionByValue.get(committed[0]);
203
+ var firstLabel = first ? first.label : committed[0];
204
+ var extra = committed.length - 1;
205
+ return (0, _jsxRuntime.jsxs)(_Typography.TypographyBody, {
206
+ size: 'md',
207
+ className: "".concat(WRAP_CLS, "__value"),
208
+ children: [(0, _jsxRuntime.jsx)("span", {
209
+ className: "".concat(WRAP_CLS, "__value-label"),
210
+ children: firstLabel
211
+ }), extra > 0 && (0, _jsxRuntime.jsx)("span", {
212
+ className: "".concat(WRAP_CLS, "__value-more"),
213
+ children: MORE_SUFFIX(extra)
214
+ })]
215
+ });
216
+ }, [allLabel, committed, optionByValue]);
217
+ return (0, _jsxRuntime.jsx)(_Select.Select, Object.assign({}, rest, {
218
+ multiple: true,
219
+ size: size,
220
+ label: label,
221
+ placeholder: placeholder,
222
+ className: (0, _classnames.joinCls)(WRAP_CLS, className),
223
+ panelClassName: (0, _classnames.joinCls)(PANEL_CLS, panelClassName),
224
+ value: temp,
225
+ open: open,
226
+ onOpenChange: handleOpenChange,
227
+ onChange: handleSelectChange,
228
+ searchable: search,
229
+ searchPlaceholder: searchPlaceholder,
230
+ searchValue: keyword,
231
+ onSearchChange: setKeyword,
232
+ filterOption: filterOption !== null && filterOption !== void 0 ? filterOption : defaultFilterOption,
233
+ options: options,
234
+ panelHeader: searching ? undefined : (0, _jsxRuntime.jsxs)("button", {
235
+ type: 'button',
236
+ className: (0, _classnames.joinCls)("".concat(WRAP_CLS, "__all"), allChecked && "".concat(WRAP_CLS, "__all--checked")),
237
+ onClick: handleAllClick,
238
+ children: [(0, _jsxRuntime.jsx)(_Typography.TypographyBody, {
239
+ size: 'sm',
240
+ strong: true,
241
+ children: allLabel
242
+ }), (0, _jsxRuntime.jsx)(_Checkbox.Checkbox, {
243
+ checked: allChecked,
244
+ readOnly: true,
245
+ className: "".concat(WRAP_CLS, "__row-check")
246
+ })]
247
+ }),
248
+ emptyContent: emptyContent,
249
+ renderValue: renderValue,
250
+ renderOption: function renderOption(option, meta) {
251
+ return renderRow(option, meta.selected);
252
+ },
253
+ panelFooter: (0, _jsxRuntime.jsxs)(_Flex.Flex, {
254
+ gap: 8,
255
+ className: "".concat(WRAP_CLS, "__footer"),
256
+ children: [(0, _jsxRuntime.jsx)(_Button.Button, {
257
+ color: 'grey',
258
+ size: 'small',
259
+ style: FULL_WIDTH_STYLE,
260
+ onClick: handleReset,
261
+ children: RESET_LABEL
262
+ }), (0, _jsxRuntime.jsx)(_Button.Button, {
263
+ color: 'primary',
264
+ size: 'small',
265
+ style: FULL_WIDTH_STYLE,
266
+ onClick: handleApply,
267
+ children: APPLY_LABEL
268
+ })]
269
+ })
270
+ }));
271
+ };
272
+ var Filter = exports.Filter = /*#__PURE__*/(0, _react.memo)(FilterBase);
273
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvRmlsdGVyL0ZpbHRlci5qcyIsImNvbXBvbmVudHMvc3JjL2NvbXBvbmVudHMvRmlsdGVyL0ZpbHRlci50c3giXSwibmFtZXMiOlsiX2pzeFJ1bnRpbWUiLCJyZXF1aXJlIiwiX3JlYWN0IiwiX0J1dHRvbiIsIl9DaGVja2JveCIsIl9FbXB0eSIsIl9GbGV4IiwiX0ljb25zIiwiX1NlbGVjdCIsIl9UeXBvZ3JhcGh5IiwiX2NsYXNzbmFtZXMiLCJfX3Jlc3QiLCJzIiwiZSIsInQiLCJwIiwiT2JqZWN0IiwicHJvdG90eXBlIiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwiaW5kZXhPZiIsImdldE93blByb3BlcnR5U3ltYm9scyIsImkiLCJsZW5ndGgiLCJwcm9wZXJ0eUlzRW51bWVyYWJsZSIsIldSQVBfQ0xTIiwiUEFORUxfQ0xTIiwiY29uY2F0IiwiUkVTRVRfTEFCRUwiLCJBUFBMWV9MQUJFTCIsIkRFRkFVTFRfQUxMX0xBQkVMIiwiREVGQVVMVF9TRUFSQ0hfUExBQ0VIT0xERVIiLCJERUZBVUxUX0VNUFRZIiwiX2pzeCIsIkVtcHR5IiwidmFyaWFudCIsImljb24iLCJJY29ucyIsIm5hbWUiLCJzaXplIiwiY29sb3IiLCJ0aXRsZSIsIlR5cG9ncmFwaHlCb2R5Iiwic3Ryb25nIiwiY2hpbGRyZW4iLCJkZXNjcmlwdGlvbiIsInN0eWxlIiwicGFkZGluZyIsIk1PUkVfU1VGRklYIiwiY291bnQiLCJGVUxMX1dJRFRIX1NUWUxFIiwiZmxleCIsImlzR3JvdXAiLCJpdGVtIiwiX3R5cGVvZjIiLCJBcnJheSIsImlzQXJyYXkiLCJvcHRpb25zIiwiZmxhdHRlbk9wdGlvbnMiLCJkYXRhIiwiZmxhdE1hcCIsIkZpbHRlckJhc2UiLCJfYSIsInJlZiIsImNsYXNzTmFtZSIsInBhbmVsQ2xhc3NOYW1lIiwiX2Ekc2l6ZSIsImxhYmVsIiwicGxhY2Vob2xkZXIiLCJfYSRhbGxMYWJlbCIsImFsbExhYmVsIiwiX2Ekc2VhcmNoIiwic2VhcmNoIiwiX2Ekc2VhcmNoUGxhY2Vob2xkZXIiLCJzZWFyY2hQbGFjZWhvbGRlciIsImZpbHRlck9wdGlvbiIsIl9hJGVtcHR5Q29udGVudCIsImVtcHR5Q29udGVudCIsInJlbmRlclJvdyIsIm9uQXBwbHkiLCJvblJlc2V0IiwicmVzdCIsImZsYXRPcHRpb25zIiwidXNlTWVtbyIsImFsbFZhbHVlcyIsIm1hcCIsIm9wdGlvbiIsIlN0cmluZyIsInZhbHVlIiwib3B0aW9uQnlWYWx1ZSIsIk1hcCIsImZvckVhY2giLCJzZXQiLCJfdXNlU3RhdGUiLCJ1c2VTdGF0ZSIsIl91c2VTdGF0ZTIiLCJfc2xpY2VkVG9BcnJheTIiLCJvcGVuIiwic2V0T3BlbiIsIl91c2VTdGF0ZTMiLCJfdXNlU3RhdGU0Iiwia2V5d29yZCIsInNldEtleXdvcmQiLCJfdXNlU3RhdGU1IiwiX3VzZVN0YXRlNiIsInRlbXAiLCJzZXRUZW1wIiwiX3VzZVN0YXRlNyIsIl91c2VTdGF0ZTgiLCJjb21taXR0ZWQiLCJzZXRDb21taXR0ZWQiLCJhbGxDaGVja2VkIiwic2VhcmNoaW5nIiwidHJpbSIsImRlZmF1bHRGaWx0ZXJPcHRpb24iLCJ1c2VDYWxsYmFjayIsInNlYXJjaFZhbHVlIiwidGVybSIsInRvTG93ZXJDYXNlIiwic2VhcmNoVGV4dCIsImluY2x1ZGVzIiwidXNlSW1wZXJhdGl2ZUhhbmRsZSIsImNsZWFyIiwicmVzZXQiLCJoYW5kbGVTZWxlY3RDaGFuZ2UiLCJuZXh0IiwibmV4dFZhbHVlcyIsImNvbGxhcHNlIiwiaGFuZGxlQWxsQ2xpY2siLCJoYW5kbGVBcHBseSIsImhhbmRsZVJlc2V0IiwiaGFuZGxlT3BlbkNoYW5nZSIsIm5leHRPcGVuIiwicmVuZGVyVmFsdWUiLCJmaXJzdCIsImdldCIsImZpcnN0TGFiZWwiLCJleHRyYSIsIl9qc3hzIiwiU2VsZWN0IiwiYXNzaWduIiwibXVsdGlwbGUiLCJqb2luQ2xzIiwib25PcGVuQ2hhbmdlIiwib25DaGFuZ2UiLCJzZWFyY2hhYmxlIiwib25TZWFyY2hDaGFuZ2UiLCJwYW5lbEhlYWRlciIsInVuZGVmaW5lZCIsInR5cGUiLCJvbkNsaWNrIiwiQ2hlY2tib3giLCJjaGVja2VkIiwicmVhZE9ubHkiLCJyZW5kZXJPcHRpb24iLCJtZXRhIiwic2VsZWN0ZWQiLCJwYW5lbEZvb3RlciIsIkZsZXgiLCJnYXAiLCJCdXR0b24iLCJGaWx0ZXIiLCJleHBvcnRzIiwibWVtbyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBV0EsSUFBQUEsV0FBQSxHQUFBQyxPQUFBO0FDWEEsSUFBQUMsTUFBQSxHQUFBRCxPQUFBO0FBQ0EsSUFBQUUsT0FBQSxHQUFBRixPQUFBO0FBQ0EsSUFBQUcsU0FBQSxHQUFBSCxPQUFBO0FBQ0EsSUFBQUksTUFBQSxHQUFBSixPQUFBO0FBQ0EsSUFBQUssS0FBQSxHQUFBTCxPQUFBO0FBQ0EsSUFBQU0sTUFBQSxHQUFBTixPQUFBO0FBQ0EsSUFBQU8sT0FBQSxHQUFBUCxPQUFBO0FBQ0EsSUFBQVEsV0FBQSxHQUFBUixPQUFBO0FBQ0EsSUFBQVMsV0FBQSxHQUFBVCxPQUFBO0FEUkEsSUFBSVUsTUFBTSxHQUFJLFVBQVEsU0FBS0EsTUFBTSxJQUFLLFVBQVVDLENBQUMsRUFBRUMsQ0FBQyxFQUFFO0VBQ2xELElBQUlDLENBQUMsR0FBRyxDQUFDLENBQUM7RUFDVixLQUFLLElBQUlDLENBQUMsSUFBSUgsQ0FBQyxFQUFFLElBQUlJLE1BQU0sQ0FBQ0MsU0FBUyxDQUFDQyxjQUFjLENBQUNDLElBQUksQ0FBQ1AsQ0FBQyxFQUFFRyxDQUFDLENBQUMsSUFBSUYsQ0FBQyxDQUFDTyxPQUFPLENBQUNMLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFDL0VELENBQUMsQ0FBQ0MsQ0FBQyxDQUFDLEdBQUdILENBQUMsQ0FBQ0csQ0FBQyxDQUFDO0VBQ2YsSUFBSUgsQ0FBQyxJQUFJLElBQUksSUFBSSxPQUFPSSxNQUFNLENBQUNLLHFCQUFxQixLQUFLLFVBQVUsRUFDL0QsS0FBSyxJQUFJQyxDQUFDLEdBQUcsQ0FBQyxFQUFFUCxDQUFDLEdBQUdDLE1BQU0sQ0FBQ0sscUJB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QjtNQUFXLENBQUEsQ0FDTCxFQUNULElBQUFLLGVBQUEsRUFBQytILGNBQU0sRUFBQTtRQUFDeEgsS0FBSyxFQUFDLFNBQVM7UUFBQ0QsSUFBSSxFQUFDLE9BQU87UUFBQ08sS0FBSyxFQUFFSSxnQkFBZ0I7UUFBRW9HLE9BQU8sRUFBRXJCLFdBQVc7UUFBQXJGLFFBQUEsRUFDL0VmO01BQVcsQ0FBQSxDQUNMO0lBQUEsQ0FBQTtFQUNKLENBQUEsQ0FBQSxDQUVUO0FBRU4sQ0FBQztBQUVNLElBQU1vSSxNQUFNLEdBQUFDLE9BQUEsQ0FBQUQsTUFBQSxnQkFBRyxJQUFBRSxXQUFJLEVBQUN0RyxVQUFVLENBQUMiLCJmaWxlIjoiY29tcG9uZW50cy9GaWx0ZXIvRmlsdGVyLmpzIiwic291cmNlc0NvbnRlbnQiOlsidmFyIF9fcmVzdCA9ICh0aGlzICYmIHRoaXMuX19yZXN0KSB8fCBmdW5jdGlvbiAocywgZSkge1xuICAgIHZhciB0ID0ge307XG4gICAgZm9yICh2YXIgcCBpbiBzKSBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKHMsIHApICYmIGUuaW5kZXhPZihwKSA8IDApXG4gICAgICAgIHRbcF0gPSBzW3BdO1xuICAgIGlmIChzICE9IG51bGwgJiYgdHlwZW9mIE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMgPT09IFwiZnVuY3Rpb25cIilcbiAgICAgICAgZm9yICh2YXIgaSA9IDAsIHAgPSBPYmplY3QuZ2V0T3duUHJvcGVydHlTeW1ib2xzKHMpOyBpIDwgcC5sZW5ndGg7IGkrKykge1xuICAgICAgICAgICAgaWYgKGUuaW5kZXhPZihwW2ldKSA8IDAgJiYgT2JqZWN0LnByb3RvdHlwZS5wcm9wZXJ0eUlzRW51bWVyYWJsZS5jYWxsKHMsIHBbaV0pKVxuICAgICAgICAgICAgICAgIHRbcFtpXV0gPSBzW3BbaV1dO1xuICAgICAgICB9XG4gICAgcmV0dXJuIHQ7XG59O1xuaW1wb3J0IHsganN4IGFzIF9qc3gsIGpzeHMgYXMgX2pzeHMgfSBmcm9tIFwicmVhY3QvanN4LXJ1bnRpbWVcIjtcbmltcG9ydCB7IG1lbW8sIHVzZUNhbGxiYWNrLCB1c2VJbXBlcmF0aXZlSGFuZGxlLCB1c2VNZW1vLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IEJ1dHRvbiB9IGZyb20gJy4uL0J1dHRvbic7XG5pbXBvcnQgeyBDaGVja2JveCB9IGZyb20gJy4uL0NoZWNrYm94JztcbmltcG9ydCB7IEVtcHR5IH0gZnJvbSAnLi4vRW1wdHknO1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uL0ZsZXgnO1xuaW1wb3J0IHsgSWNvbnMgfSBmcm9tICcuLi9JY29ucyc7XG5pbXBvcnQgeyBTZWxlY3QgfSBmcm9tICcuLi9TZWxlY3QnO1xuaW1wb3J0IHsgVHlwb2dyYXBoeUJvZHkgfSBmcm9tICcuLi9UeXBvZ3JhcGh5JztcbmltcG9ydCB7IGpvaW5DbHMgfSBmcm9tICcuLi8uLi91dGlscy9jbGFzc25hbWVzJztcbmNvbnN0IFdSQVBfQ0xTID0gJ29tLWZpbHRlcic7XG4vLyBUaGUgcGFuZWwgaXMgcG9ydGFsZWQgdG8gPGJvZHk+LCBzbyBwYW5lbC1zY29wZWQgb3ZlcnJpZGVzIGFyZSBrZXllZCBvZmYgdGhpc1xuLy8gY2xhc3MgKHBhc3NlZCBhcyBgcGFuZWxDbGFzc05hbWVgKSByYXRoZXIgdGhhbiB0aGUgdHJpZ2dlciByb290LlxuY29uc3QgUEFORUxfQ0xTID0gYCR7V1JBUF9DTFN9LXBhbmVsYDtcbmNvbnN0IFJFU0VUX0xBQkVMID0gJ1Jlc2V0JztcbmNvbnN0IEFQUExZX0xBQkVMID0gJ0FwcGx5JztcbmNvbnN0IERFRkFVTFRfQUxMX0xBQkVMID0gJ0FsbCc7XG5jb25zdCBERUZBVUxUX1NFQVJDSF9QTEFDRUhPTERFUiA9ICdTZWFyY2gnO1xuY29uc3QgREVGQVVMVF9FTVBUWSA9IChfanN4KEVtcHR5LCB7IHZhcmlhbnQ6ICdmaWxsJywgaWNvbjogX2pzeChJY29ucywgeyBuYW1lOiAnc2VhcmNoJywgc2l6ZTogMTYsIGNvbG9yOiAnY3VycmVudENvbG9yJyB9KSwgXG4gICAgLy8gRmlnbWEgZW1wdHktc3RhdGUgdGV4dCBpcyBCb2R5IFNtYWxsICgxMnB4KTsgRW1wdHkncyBzdHJpbmcgcGF0aCB3b3VsZFxuICAgIC8vIHJlbmRlciBUaXRsZSBzbSAvIEJvZHkgbWQgKDE0cHgpLCBzbyBwYXNzIDEycHggbm9kZXMgZXhwbGljaXRseS5cbiAgICB0aXRsZTogX2pzeChUeXBvZ3JhcGh5Qm9keSwgeyBzaXplOiAnc20nLCBzdHJvbmc6IHRydWUsIGNvbG9yOiAnbmV1dHJhbC1zZWNvbmRhcnknLCBjaGlsZHJlbjogXCJObyByZXN1bHRzXCIgfSksIGRlc2NyaXB0aW9uOiBfanN4KFR5cG9ncmFwaHlCb2R5LCB7IHNpemU6ICdzbScsIGNvbG9yOiAnbmV1dHJhbC1zZWNvbmRhcnknLCBjaGlsZHJlbjogXCJUcnkgYSBkaWZmZXJlbnQgbmFtZSBvciBhZGp1c3QgeW91ciBzZWFyY2ggZmlsdGVycy5cIiB9KSwgc3R5bGU6IHsgcGFkZGluZzogMCB9IH0pKTtcbmNvbnN0IE1PUkVfU1VGRklYID0gKGNvdW50KSA9PiBgKyAke2NvdW50fSBtb3JlYDtcbmNvbnN0IEZVTExfV0lEVEhfU1RZTEUgPSB7IGZsZXg6IDEgfTtcbmNvbnN0IGlzR3JvdXAgPSAoaXRlbSkgPT4gISFpdGVtICYmIHR5cGVvZiBpdGVtID09PSAnb2JqZWN0JyAmJiBBcnJheS5pc0FycmF5KGl0ZW0ub3B0aW9ucyk7XG4vLyBGbGF0dGVuIGZsYXQvZ3JvdXBlZCBvcHRpb25zIGludG8gYSBzaW5nbGUgb3JkZXJlZCBvcHRpb24gbGlzdCDigJQgdXNlZCBmb3IgdGhlXG4vLyB2YWx1ZeKGkmxhYmVsIGxvb2t1cCBhbmQgdGhlIFwiZXZlcnkgb3B0aW9uIHNlbGVjdGVkXCIgY291bnQuXG5jb25zdCBmbGF0dGVuT3B0aW9ucyA9IChkYXRhKSA9PiBkYXRhLmZsYXRNYXAoKGl0ZW0pID0+IChpc0dyb3VwKGl0ZW0pID8gaXRlbS5vcHRpb25zIDogW2l0ZW1dKSk7XG5jb25zdCBGaWx0ZXJCYXNlID0gKF9hKSA9PiB7XG4gICAgdmFyIHsgcmVmLCBjbGFzc05hbWUsIHBhbmVsQ2xhc3NOYW1lLCBzaXplID0gJ2V4dHJhLXNtYWxsJywgbGFiZWwsIHBsYWNlaG9sZGVyLCBvcHRpb25zLCBhbGxMYWJlbCA9IERFRkFVTFRfQUxMX0xBQkVMLCBzZWFyY2ggPSB0cnVlLCBzZWFyY2hQbGFjZWhvbGRlciA9IERFRkFVTFRfU0VBUkNIX1BMQUNFSE9MREVSLCBmaWx0ZXJPcHRpb24sIGVtcHR5Q29udGVudCA9IERFRkFVTFRfRU1QVFksIHJlbmRlclJvdywgb25BcHBseSwgb25SZXNldCB9ID0gX2EsIHJlc3QgPSBfX3Jlc3QoX2EsIFtcInJlZlwiLCBcImNsYXNzTmFtZVwiLCBcInBhbmVsQ2xhc3NOYW1lXCIsIFwic2l6ZVwiLCBcImxhYmVsXCIsIFwicGxhY2Vob2xkZXJcIiwgXCJvcHRpb25zXCIsIFwiYWxsTGFiZWxcIiwgXCJzZWFyY2hcIiwgXCJzZWFyY2hQbGFjZWhvbGRlclwiLCBcImZpbHRlck9wdGlvblwiLCBcImVtcHR5Q29udGVudFwiLCBcInJlbmRlclJvd1wiLCBcIm9uQXBwbHlcIiwgXCJvblJlc2V0XCJdKTtcbiAgICBjb25zdCBmbGF0T3B0aW9ucyA9IHVzZU1lbW8oKCkgPT4gZmxhdHRlbk9wdGlvbnMob3B0aW9ucyksIFtvcHRpb25zXSk7XG4gICAgY29uc3QgYWxsVmFsdWVzID0gdXNlTWVtbygoKSA9PiBmbGF0T3B0aW9ucy5tYXAoKG9wdGlvbikgPT4gU3RyaW5nKG9wdGlvbi52YWx1ZSkpLCBbZmxhdE9wdGlvbnNdKTtcbiAgICBjb25zdCBvcHRpb25CeVZhbHVlID0gdXNlTWVtbygoKSA9PiB7XG4gICAgICAgIGNvbnN0IG1hcCA9IG5ldyBNYXAoKTtcbiAgICAgICAgZmxhdE9wdGlvbnMuZm9yRWFjaCgob3B0aW9uKSA9PiBtYXAuc2V0KFN0cmluZyhvcHRpb24udmFsdWUpLCBvcHRpb24pKTtcbiAgICAgICAgcmV0dXJuIG1hcDtcbiAgICB9LCBbZmxhdE9wdGlvbnNdKTtcbiAgICBjb25zdCBbb3Blbiwgc2V0T3Blbl0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gICAgY29uc3QgW2tleXdvcmQsIHNldEtleXdvcmRdID0gdXNlU3RhdGUoJycpO1xuICAgIC8vIGB0ZW1wYCBpcyB0aGUgaW4tcGFuZWwgZHJhZnQ7IGBjb21taXR0ZWRgIGlzIHRoZSBsYXN0IEFwcGxpZWQgc2VsZWN0aW9uLlxuICAgIC8vIE9ubHkgQXBwbHkgcHJvbW90ZXMgYHRlbXBgIOKGkiBgY29tbWl0dGVkYCBhbmQgbm90aWZpZXMgdGhlIHBhcmVudC4gV2l0aCBhblxuICAgIC8vIFwiQWxsXCIgcm93LCBcImFsbCBzZWxlY3RlZFwiIGlzIHJlcHJlc2VudGVkIGJ5IGFuIGVtcHR5IGFycmF5LlxuICAgIGNvbnN0IFt0ZW1wLCBzZXRUZW1wXSA9IHVzZVN0YXRlKFtdKTtcbiAgICBjb25zdCBbY29tbWl0dGVkLCBzZXRDb21taXR0ZWRdID0gdXNlU3RhdGUoW10pO1xuICAgIC8vIFRoZSBcIkFsbFwiIHJvdyBpcyBjaGVja2VkIGV4YWN0bHkgd2hlbiBub3RoaW5nIHNwZWNpZmljIGlzIHNlbGVjdGVkLlxuICAgIGNvbnN0IGFsbENoZWNrZWQgPSB0ZW1wLmxlbmd0aCA9PT0gMDtcbiAgICAvLyBXaGlsZSBzZWFyY2hpbmcsIHRoZSBcIkFsbFwiIHJvdyBpcyBtZWFuaW5nbGVzcyDigJQgaGlkZSBpdCBzbyBhIG5vLW1hdGNoIHNlYXJjaFxuICAgIC8vIHNob3dzIHRoZSBlbXB0eSBzdGF0ZSBpbnN0ZWFkIG9mIGEgbG9uZSBcIkFsbFwiIHJvdy5cbiAgICBjb25zdCBzZWFyY2hpbmcgPSBzZWFyY2ggJiYga2V5d29yZC50cmltKCkubGVuZ3RoID4gMDtcbiAgICBjb25zdCBkZWZhdWx0RmlsdGVyT3B0aW9uID0gdXNlQ2FsbGJhY2soKHNlYXJjaFZhbHVlLCBvcHRpb24pID0+IHtcbiAgICAgICAgY29uc3QgdGVybSA9IHNlYXJjaFZhbHVlLnRyaW0oKS50b0xvd2VyQ2FzZSgpO1xuICAgICAgICBpZiAoIXRlcm0pXG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgcmV0dXJuIHR5cGVvZiBvcHRpb24uc2VhcmNoVGV4dCA9PT0gJ3N0cmluZydcbiAgICAgICAgICAgID8gb3B0aW9uLnNlYXJjaFRleHQudG9Mb3dlckNhc2UoKS5pbmNsdWRlcyh0ZXJtKVxuICAgICAgICAgICAgOiBmYWxzZTtcbiAgICB9LCBbXSk7XG4gICAgdXNlSW1wZXJhdGl2ZUhhbmRsZShyZWYsICgpID0+ICh7XG4gICAgICAgIGNsZWFyOiAoKSA9PiB7XG4gICAgICAgICAgICBzZXRUZW1wKFtdKTtcbiAgICAgICAgICAgIHNldENvbW1pdHRlZChbXSk7XG4gICAgICAgIH0sXG4gICAgICAgIHJlc2V0OiAoKSA9PiB7XG4gICAgICAgICAgICBzZXRUZW1wKFtdKTtcbiAgICAgICAgICAgIHNldENvbW1pdHRlZChbXSk7XG4gICAgICAgICAgICBvblJlc2V0ID09PSBudWxsIHx8IG9uUmVzZXQgPT09IHZvaWQgMCA/IHZvaWQgMCA6IG9uUmVzZXQoW10pO1xuICAgICAgICB9LFxuICAgIH0pLCBbb25SZXNldF0pO1xuICAgIGNvbnN0IGhhbmRsZVNlbGVjdENoYW5nZSA9IHVzZUNhbGxiYWNrKChuZXh0KSA9PiB7XG4gICAgICAgIGNvbnN0IG5leHRWYWx1ZXMgPSAoQXJyYXkuaXNBcnJheShuZXh0KSA/IG5leHQgOiBbXSkubWFwKFN0cmluZyk7XG4gICAgICAgIC8vIFNlbGVjdGluZyBldmVyeSBjb25jcmV0ZSBvcHRpb24gY29sbGFwc2VzIHRvIFwiYWxsXCIgKFtdKSwgbWF0Y2hpbmcgdGhlXG4gICAgICAgIC8vIGJhY2tlbmQgY29udmVudGlvbiB0aGF0IGVtcHR5ID09IG5vIGZpbHRlci5cbiAgICAgICAgY29uc3QgY29sbGFwc2UgPSBuZXh0VmFsdWVzLmxlbmd0aCA9PT0gYWxsVmFsdWVzLmxlbmd0aDtcbiAgICAgICAgc2V0VGVtcChjb2xsYXBzZSA/IFtdIDogbmV4dFZhbHVlcyk7XG4gICAgfSwgW2FsbFZhbHVlc10pO1xuICAgIGNvbnN0IGhhbmRsZUFsbENsaWNrID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgICAgICAvLyBUaGUgXCJBbGxcIiByb3cgaXMgZXhjbHVzaXZlOiB0dXJuaW5nIGl0IG9uIGNsZWFycyBzcGVjaWZpYyBwaWNrcy5cbiAgICAgICAgc2V0VGVtcChbXSk7XG4gICAgfSwgW10pO1xuICAgIGNvbnN0IGhhbmRsZUFwcGx5ID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgICAgICBzZXRDb21taXR0ZWQodGVtcCk7XG4gICAgICAgIG9uQXBwbHkodGVtcCk7XG4gICAgICAgIHNldE9wZW4oZmFsc2UpO1xuICAgIH0sIFt0ZW1wLCBvbkFwcGx5XSk7XG4gICAgY29uc3QgaGFuZGxlUmVzZXQgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgICAgIHNldFRlbXAoW10pO1xuICAgICAgICBzZXRDb21taXR0ZWQoW10pO1xuICAgICAgICBvblJlc2V0ID09PSBudWxsIHx8IG9uUmVzZXQgPT09IHZvaWQgMCA/IHZvaWQgMCA6IG9uUmVzZXQoW10pO1xuICAgIH0sIFtvblJlc2V0XSk7XG4gICAgY29uc3QgaGFuZGxlT3BlbkNoYW5nZSA9IHVzZUNhbGxiYWNrKChuZXh0T3BlbikgPT4ge1xuICAgICAgICBzZXRPcGVuKG5leHRPcGVuKTtcbiAgICAgICAgaWYgKG5leHRPcGVuKVxuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAvLyBDbG9zaW5nIHdpdGhvdXQgQXBwbHkgZGlzY2FyZHMgdGhlIGRyYWZ0LlxuICAgICAgICBzZXRUZW1wKGNvbW1pdHRlZCk7XG4gICAgICAgIHNldEtleXdvcmQoJycpO1xuICAgIH0sIFtjb21taXR0ZWRdKTtcbiAgICAvLyBUaGUgdHJpZ2dlciByZWZsZWN0cyB0aGUgQ09NTUlUVEVEIHNlbGVjdGlvbiBvbmx5IOKAlCBgdGVtcGAgaXMgdGhlIGluLXBhbmVsXG4gICAgLy8gZHJhZnQgYW5kIG11c3Qgbm90IGxlYWsgaW50byB0aGUgdHJpZ2dlciBiZWZvcmUgQXBwbHkuIEFuIGVtcHR5IGBjb21taXR0ZWRgXG4gICAgLy8gbWVhbnMgXCJhbGxcIiAodGhlIGBhbGxMYWJlbGApLiBgcmVuZGVyVmFsdWVgIHNob3J0LWNpcmN1aXRzIFNlbGVjdCdzIG93blxuICAgIC8vIHBsYWNlaG9sZGVyIGhhbmRsaW5nLCBzbyB0aGUgZW1wdHkgc3RhdGUgbXVzdCByZXR1cm4gYGFsbExhYmVsYCBleHBsaWNpdGx5LlxuICAgIGNvbnN0IHJlbmRlclZhbHVlID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgICAgICBpZiAoY29tbWl0dGVkLmxlbmd0aCA9PT0gMCkge1xuICAgICAgICAgICAgLy8gYGFsbExhYmVsYCBpcyB0aGUgZGVmYXVsdCBmaWx0ZXIgdmFsdWUsIG5vdCBhbiBlbXB0eSBwbGFjZWhvbGRlci4gVGhlXG4gICAgICAgICAgICAvLyB0cmlnZ2VyJ3MgZW1wdHkgYHZhbHVlYCBtYWtlcyBTZWxlY3Qgd3JhcCB0aGlzIGluIGl0cyBncmV5IHBsYWNlaG9sZGVyXG4gICAgICAgICAgICAvLyBjbGFzcywgc28gZm9yY2UgdGhlIGRlZmF1bHQgZGFyayB0ZXh0IHRvIG1hdGNoIERhdGVSYW5nZS5cbiAgICAgICAgICAgIHJldHVybiAoX2pzeChUeXBvZ3JhcGh5Qm9keSwgeyBzaXplOiAnbWQnLCBjb2xvcjogJ2RlZmF1bHQnLCBjbGFzc05hbWU6IGAke1dSQVBfQ0xTfV9fdmFsdWVgLCBjaGlsZHJlbjogX2pzeChcInNwYW5cIiwgeyBjbGFzc05hbWU6IGAke1dSQVBfQ0xTfV9fdmFsdWUtbGFiZWxgLCBjaGlsZHJlbjogYWxsTGFiZWwgfSkgfSkpO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IGZpcnN0ID0gb3B0aW9uQnlWYWx1ZS5nZXQoY29tbWl0dGVkWzBdKTtcbiAgICAgICAgY29uc3QgZmlyc3RMYWJlbCA9IGZpcnN0ID8gZmlyc3QubGFiZWwgOiBjb21taXR0ZWRbMF07XG4gICAgICAgIGNvbnN0IGV4dHJhID0gY29tbWl0dGVkLmxlbmd0aCAtIDE7XG4gICAgICAgIHJldHVybiAoX2pzeHMoVHlwb2dyYXBoeUJvZHksIHsgc2l6ZTogJ21kJywgY2xhc3NOYW1lOiBgJHtXUkFQX0NMU31fX3ZhbHVlYCwgY2hpbGRyZW46IFtfanN4KFwic3BhblwiLCB7IGNsYXNzTmFtZTogYCR7V1JBUF9DTFN9X192YWx1ZS1sYWJlbGAsIGNoaWxkcmVuOiBmaXJzdExhYmVsIH0pLCBleHRyYSA+IDAgJiYgX2pzeChcInNwYW5cIiwgeyBjbGFzc05hbWU6IGAke1dSQVBfQ0xTfV9fdmFsdWUtbW9yZWAsIGNoaWxkcmVuOiBNT1JFX1NVRkZJWChleHRyYSkgfSldIH0pKTtcbiAgICB9LCBbYWxsTGFiZWwsIGNvbW1pdHRlZCwgb3B0aW9uQnlWYWx1ZV0pO1xuICAgIHJldHVybiAoX2pzeChTZWxlY3QsIE9iamVjdC5hc3NpZ24oe30sIHJlc3QsIHsgbXVsdGlwbGU6IHRydWUsIHNpemU6IHNpemUsIGxhYmVsOiBsYWJlbCwgcGxhY2Vob2xkZXI6IHBsYWNlaG9sZGVyLCBjbGFzc05hbWU6IGpvaW5DbHMoV1JBUF9DTFMsIGNsYXNzTmFtZSksIHBhbmVsQ2xhc3NOYW1lOiBqb2luQ2xzKFBBTkVMX0NMUywgcGFuZWxDbGFzc05hbWUpLCB2YWx1ZTogdGVtcCwgb3Blbjogb3Blbiwgb25PcGVuQ2hhbmdlOiBoYW5kbGVPcGVuQ2hhbmdlLCBvbkNoYW5nZTogaGFuZGxlU2VsZWN0Q2hhbmdlLCBzZWFyY2hhYmxlOiBzZWFyY2gsIHNlYXJjaFBsYWNlaG9sZGVyOiBzZWFyY2hQbGFjZWhvbGRlciwgc2VhcmNoVmFsdWU6IGtleXdvcmQsIG9uU2VhcmNoQ2hhbmdlOiBzZXRLZXl3b3JkLCBmaWx0ZXJPcHRpb246IGZpbHRlck9wdGlvbiAhPT0gbnVsbCAmJiBmaWx0ZXJPcHRpb24gIT09IHZvaWQgMCA/IGZpbHRlck9wdGlvbiA6IGRlZmF1bHRGaWx0ZXJPcHRpb24sIG9wdGlvbnM6IG9wdGlvbnMsIHBhbmVsSGVhZGVyOiBzZWFyY2hpbmcgPyB1bmRlZmluZWQgOiAoX2pzeHMoXCJidXR0b25cIiwgeyB0eXBlOiAnYnV0dG9uJywgY2xhc3NOYW1lOiBqb2luQ2xzKGAke1dSQVBfQ0xTfV9fYWxsYCwgYWxsQ2hlY2tlZCAmJiBgJHtXUkFQX0NMU31fX2FsbC0tY2hlY2tlZGApLCBvbkNsaWNrOiBoYW5kbGVBbGxDbGljaywgY2hpbGRyZW46IFtfanN4KFR5cG9ncmFwaHlCb2R5LCB7IHNpemU6ICdzbScsIHN0cm9uZzogdHJ1ZSwgY2hpbGRyZW46IGFsbExhYmVsIH0pLCBfanN4KENoZWNrYm94LCB7IGNoZWNrZWQ6IGFsbENoZWNrZWQsIHJlYWRPbmx5OiB0cnVlLCBjbGFzc05hbWU6IGAke1dSQVBfQ0xTfV9fcm93LWNoZWNrYCB9KV0gfSkpLCBlbXB0eUNvbnRlbnQ6IGVtcHR5Q29udGVudCwgcmVuZGVyVmFsdWU6IHJlbmRlclZhbHVlLCByZW5kZXJPcHRpb246IChvcHRpb24sIG1ldGEpID0+IHJlbmRlclJvdyhvcHRpb24sIG1ldGEuc2VsZWN0ZWQpLCBwYW5lbEZvb3RlcjogX2pzeHMoRmxleCwgeyBnYXA6IDgsIGNsYXNzTmFtZTogYCR7V1JBUF9DTFN9X19mb290ZXJgLCBjaGlsZHJlbjogW19qc3goQnV0dG9uLCB7IGNvbG9yOiAnZ3JleScsIHNpemU6ICdzbWFsbCcsIHN0eWxlOiBGVUxMX1dJRFRIX1NUWUxFLCBvbkNsaWNrOiBoYW5kbGVSZXNldCwgY2hpbGRyZW46IFJFU0VUX0xBQkVMIH0pLCBfanN4KEJ1dHRvbiwgeyBjb2xvcjogJ3ByaW1hcnknLCBzaXplOiAnc21hbGwnLCBzdHlsZTogRlVMTF9XSURUSF9TVFlMRSwgb25DbGljazogaGFuZGxlQXBwbHksIGNoaWxkcmVuOiBBUFBMWV9MQUJFTCB9KV0gfSkgfSkpKTtcbn07XG5leHBvcnQgY29uc3QgRmlsdGVyID0gbWVtbyhGaWx0ZXJCYXNlKTsiLG51bGxdLCJzb3VyY2VSb290IjoiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjIn0=
@@ -0,0 +1,4 @@
1
+ import { Filter } from './Filter';
2
+ export { Filter };
3
+ export default Filter;
4
+ export * from './interface';
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ var _exportNames = {
7
+ Filter: true
8
+ };
9
+ Object.defineProperty(exports, "Filter", {
10
+ enumerable: true,
11
+ get: function get() {
12
+ return _Filter.Filter;
13
+ }
14
+ });
15
+ exports["default"] = void 0;
16
+ var _Filter = require("./Filter");
17
+ var _interface = require("./interface");
18
+ Object.keys(_interface).forEach(function (key) {
19
+ if (key === "default" || key === "__esModule") return;
20
+ if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
21
+ if (key in exports && exports[key] === _interface[key]) return;
22
+ Object.defineProperty(exports, key, {
23
+ enumerable: true,
24
+ get: function get() {
25
+ return _interface[key];
26
+ }
27
+ });
28
+ });
29
+ var _default = exports["default"] = _Filter.Filter;
30
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvc3JjL2NvbXBvbmVudHMvRmlsdGVyL2luZGV4LnRzIl0sIm5hbWVzIjpbIl9GaWx0ZXIiLCJyZXF1aXJlIiwiX2ludGVyZmFjZSIsIk9iamVjdCIsImtleXMiLCJmb3JFYWNoIiwia2V5IiwicHJvdG90eXBlIiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwiX2V4cG9ydE5hbWVzIiwiZXhwb3J0cyIsImRlZmluZVByb3BlcnR5IiwiZW51bWVyYWJsZSIsImdldCIsIl9kZWZhdWx0IiwiRmlsdGVyIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7QUFBQSxJQUFBQSxPQUFBLEdBQUFDLE9BQUE7QUFJQSxJQUFBQyxVQUFBLEdBQUFELE9BQUE7QUFBQUUsTUFBQSxDQUFBQyxJQUFBLENBQUFGLFVBQUEsRUFBQUcsT0FBQSxXQUFBQyxHQUFBO0VBQUEsSUFBQUEsR0FBQSxrQkFBQUEsR0FBQTtFQUFBLElBQUFILE1BQUEsQ0FBQUksU0FBQSxDQUFBQyxjQUFBLENBQUFDLElBQUEsQ0FBQUMsWUFBQSxFQUFBSixHQUFBO0VBQUEsSUFBQUEsR0FBQSxJQUFBSyxPQUFBLElBQUFBLE9BQUEsQ0FBQUwsR0FBQSxNQUFBSixVQUFBLENBQUFJLEdBQUE7RUFBQUgsTUFBQSxDQUFBUyxjQUFBLENBQUFELE9BQUEsRUFBQUwsR0FBQTtJQUFBTyxVQUFBO0lBQUFDLEdBQUEsV0FBQUEsSUFBQTtNQUFBLE9BQUFaLFVBQUEsQ0FBQUksR0FBQTtJQUFBO0VBQUE7QUFBQTtBQUE0QixJQUFBUyxRQUFBLEdBQUFKLE9BQUEsY0FEYkssY0FBTSIsImZpbGUiOiJjb21wb25lbnRzL0ZpbHRlci9pbmRleC5qcyIsInNvdXJjZXNDb250ZW50IjpbbnVsbF0sInNvdXJjZVJvb3QiOiIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMifQ==
@@ -0,0 +1,67 @@
1
+ import type { ReactNode, RefObject } from 'react';
2
+ import type { SelectOption, SelectOptionData, SelectProps, SelectSize } from "../Select";
3
+ /** Imperative handle exposed via `ref` for parent-driven reset/clear. */
4
+ export interface FilterHandler {
5
+ /** Wipe the selection to empty (the "All" state) without firing callbacks. */
6
+ clear: () => void;
7
+ /** Restore the "All" state and fire `onReset`. */
8
+ reset: () => void;
9
+ }
10
+ /**
11
+ * A multi-select dropdown filter with an exclusive "All" row, a draft/commit
12
+ * model (edits apply only on the panel's Apply button), and a fixed 32px
13
+ * trigger. Wraps {@link Select}; consumers supply `options` + a `renderRow`.
14
+ *
15
+ * "All selected" is represented by an EMPTY array — selecting every concrete
16
+ * option, or the "All" row, collapses to `[]`. `onApply`/`onReset` receive `[]`
17
+ * for "no filter"; translate it to whatever your API expects at the call site.
18
+ */
19
+ export interface FilterProps extends Omit<SelectProps, 'ref' | 'options' | 'multiple' | 'value' | 'defaultValue' | 'onChange' | 'searchable' | 'searchValue' | 'defaultSearchValue' | 'onSearchChange' | 'renderOption' | 'renderOptionContent' | 'renderValue' | 'panelHeader' | 'panelFooter' | 'open' | 'defaultOpen' | 'onOpenChange' | 'allowDeselect' | 'maxVisibleValues' | 'size' | 'onReset'> {
20
+ ref?: RefObject<FilterHandler | null>;
21
+ /**
22
+ * Trigger size. Defaults to the native `Select` `extra-small` (32px) size;
23
+ * override with `'small'` / `'large'` for a taller trigger.
24
+ * @default 'extra-small'
25
+ */
26
+ size?: SelectSize;
27
+ /** Optional field label rendered above the trigger. */
28
+ label?: ReactNode;
29
+ /** Trigger placeholder. Usually unused — an empty selection shows {@link allLabel}. */
30
+ placeholder?: ReactNode;
31
+ /**
32
+ * The selectable rows, flat or grouped — passed straight to `Select`. Every
33
+ * option `value` MUST be a string (it is echoed back through `onApply`).
34
+ */
35
+ options: SelectOptionData[];
36
+ /**
37
+ * Label for the leading exclusive "All" row, e.g. `"All accounts"`. Selecting
38
+ * it clears every specific pick; the trigger shows this text when nothing is
39
+ * committed.
40
+ * @default 'All'
41
+ */
42
+ allLabel?: ReactNode;
43
+ /**
44
+ * Show a search box above the list. The default `filterOption` matches each
45
+ * option's `searchText`; override via `filterOption` for custom logic.
46
+ * @default true
47
+ */
48
+ search?: boolean;
49
+ /**
50
+ * Placeholder for the search box.
51
+ * @default 'Search'
52
+ */
53
+ searchPlaceholder?: string;
54
+ /** Custom search predicate. Defaults to a case-insensitive `searchText` match. */
55
+ filterOption?: SelectProps['filterOption'];
56
+ /** Content shown when no options match. Defaults to an `<Empty>` "No results". */
57
+ emptyContent?: ReactNode;
58
+ /**
59
+ * Render one option row. Receives the (flattened) option and its checked
60
+ * state; return the full row including its trailing checkbox.
61
+ */
62
+ renderRow: (option: SelectOption, checked: boolean) => ReactNode;
63
+ /** Fired when the user commits via Apply. `[]` means "all". */
64
+ onApply: (values: string[]) => void;
65
+ /** Fired when the user clears via Reset. Always receives `[]`. */
66
+ onReset?: (values: string[]) => void;
67
+ }
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy9GaWx0ZXIvaW50ZXJmYWNlLmpzIiwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjIiwic291cmNlcyI6WyJjb21wb25lbnRzL0ZpbHRlci9pbnRlcmZhY2UuanMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHt9OyJdLCJtYXBwaW5ncyI6IiIsImlnbm9yZUxpc3QiOltdfQ==
@@ -0,0 +1,95 @@
1
+ /**
2
+ * Retrieves the spacing value for a given token key.
3
+ *
4
+ * @param {string} $key - The spacing token key (e.g., '100', '200').
5
+ * @return {length|null} The computed spacing value or null if the key is invalid.
6
+ * @example
7
+ * .element {
8
+ * padding: om-spacing-token('200'); // Returns 8px if $om-sys-spacing-unit is 4px
9
+ * }
10
+ */
11
+ /**
12
+ * Computes the spacing value based on a token key or a direct length value.
13
+ *
14
+ * @param {string|length} $value - The spacing token key (e.g., '100') or a direct length value (e.g., '16px').
15
+ * @return {length} The computed spacing value.
16
+ * @example
17
+ * .element {
18
+ * margin: om-spacing-value('300'); // Returns 12px if $om-sys-spacing-unit is 4px
19
+ * padding: om-spacing-value(16px); // Returns 16px
20
+ * gap: om-spacing-value(2); // Returns 8px if $om-sys-spacing-unit is 4px
21
+ * }
22
+ */
23
+ .om-filter__value {
24
+ display: inline-flex;
25
+ align-items: center;
26
+ width: 100%;
27
+ overflow: hidden;
28
+ line-height: 18px;
29
+ }
30
+ .om-filter__value-label {
31
+ flex: 0 1 auto;
32
+ min-width: 0;
33
+ overflow: hidden;
34
+ white-space: nowrap;
35
+ text-overflow: ellipsis;
36
+ }
37
+ .om-filter__value-more {
38
+ flex: 0 0 auto;
39
+ margin-left: var(--om-spacing-100, 4px);
40
+ color: var(--om-text-default-tertiary, #646465);
41
+ }
42
+
43
+ .om-filter-panel {
44
+ min-width: 240px;
45
+ }
46
+ .om-filter-panel .om-component-ui-select-search {
47
+ margin-bottom: var(--om-spacing-100, 4px);
48
+ }
49
+ .om-filter-panel .om-component-ui-select-search-small {
50
+ box-sizing: border-box;
51
+ min-height: 0;
52
+ height: var(--om-component-height-sm, 32px);
53
+ padding: 0 var(--om-spacing-300, 12px);
54
+ }
55
+ .om-filter-panel .om-component-ui-select-search-input-small {
56
+ font-size: var(--om-body-sm-font-size);
57
+ font-family: var(--om-body-sm-font-family);
58
+ line-height: var(--om-body-sm-line-height);
59
+ letter-spacing: var(--om-body-sm-letter-spacing);
60
+ font-weight: var(--om-body-sm-font-weight);
61
+ }
62
+ .om-filter-panel .om-component-ui-select-panel-body,
63
+ .om-filter-panel .om-component-ui-select-group {
64
+ gap: var(--om-spacing-100, 4px);
65
+ }
66
+ .om-filter-panel .om-component-ui-select-option {
67
+ min-height: 34px;
68
+ margin: 0;
69
+ padding: 6px var(--om-spacing-300, 12px);
70
+ }
71
+ .om-filter-panel .om-component-ui-select-panel-header {
72
+ margin-bottom: 0;
73
+ }
74
+ .om-filter-panel .om-component-ui-checkbox-input:checked + .om-component-ui-checkbox-box::after {
75
+ border-color: var(--om-icon-on-neutral, #fff);
76
+ }
77
+ .om-filter-panel .om-filter__all {
78
+ display: flex;
79
+ align-items: center;
80
+ justify-content: space-between;
81
+ width: 100%;
82
+ min-height: 34px;
83
+ padding: 6px var(--om-spacing-300, 12px);
84
+ border: none;
85
+ background: transparent;
86
+ border-radius: var(--om-radius-200, 8px);
87
+ cursor: pointer;
88
+ }
89
+ .om-filter-panel .om-filter__all:hover, .om-filter-panel .om-filter__all--checked {
90
+ background: var(--om-bg-default-secondary, #f8f8f8);
91
+ }
92
+ .om-filter-panel .om-filter__row-check {
93
+ flex: 0 0 auto;
94
+ pointer-events: none;
95
+ }
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+
3
+ require("../../Select/style/css");
4
+ require("../../Button/style/css");
5
+ require("../../Checkbox/style/css");
6
+ require("../../Empty/style/css");
7
+ require("../../Icons/style/css");
8
+ require("../../Typography/style/css");
9
+ require("./Filter.css");
10
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvRmlsdGVyL3NyYy9jb21wb25lbnRzL0ZpbHRlci9zdHlsZS9pbmRleC50cyJdLCJuYW1lcyI6WyJyZXF1aXJlIl0sIm1hcHBpbmdzIjoiOztBQUFBQSxPQUFBO0FBQ0FBLE9BQUE7QUFDQUEsT0FBQTtBQUNBQSxPQUFBO0FBQ0FBLE9BQUE7QUFDQUEsT0FBQTtBQUNBQSxPQUFBIiwiZmlsZSI6ImNvbXBvbmVudHMvRmlsdGVyL3N0eWxlL2Nzcy5qcyIsInNvdXJjZXNDb250ZW50IjpbbnVsbF0sInNvdXJjZVJvb3QiOiIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMifQ==
@@ -0,0 +1,7 @@
1
+ import "../../Select/style";
2
+ import "../../Button/style";
3
+ import "../../Checkbox/style";
4
+ import "../../Empty/style";
5
+ import "../../Icons/style";
6
+ import "../../Typography/style";
7
+ import './Filter.css';
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+
3
+ require("../../Select/style");
4
+ require("../../Button/style");
5
+ require("../../Checkbox/style");
6
+ require("../../Empty/style");
7
+ require("../../Icons/style");
8
+ require("../../Typography/style");
9
+ require("./Filter.css");
10
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvRmlsdGVyL3NyYy9jb21wb25lbnRzL0ZpbHRlci9zdHlsZS9pbmRleC50cyJdLCJuYW1lcyI6WyJyZXF1aXJlIl0sIm1hcHBpbmdzIjoiOztBQUFBQSxPQUFBO0FBQ0FBLE9BQUE7QUFDQUEsT0FBQTtBQUNBQSxPQUFBO0FBQ0FBLE9BQUE7QUFDQUEsT0FBQTtBQUNBQSxPQUFBIiwiZmlsZSI6ImNvbXBvbmVudHMvRmlsdGVyL3N0eWxlL2luZGV4LmpzIiwic291cmNlc0NvbnRlbnQiOltudWxsXSwic291cmNlUm9vdCI6Ii4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYyJ9