@1money/component-ui 0.0.78 → 0.0.80
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/business/Filter/Account/Account.js +71 -209
- package/es/business/Filter/Account/style/Account.css +2 -42
- package/es/business/Filter/Account/style/css.js +3 -1
- package/es/business/Filter/Account/style/index.d.ts +2 -0
- package/es/business/Filter/Account/style/index.js +3 -1
- package/es/business/Filter/Asset/Asset.js +66 -209
- package/es/business/Filter/Asset/style/Asset.css +3 -44
- package/es/business/Filter/Asset/style/css.js +2 -1
- package/es/business/Filter/Asset/style/index.d.ts +1 -0
- package/es/business/Filter/Asset/style/index.js +2 -1
- package/es/business/Filter/DateRange/DateRange.js +13 -8
- package/es/business/Filter/DateRange/interface.d.ts +0 -5
- package/es/business/Filter/DateRange/style/DateRange.css +15 -5
- package/es/business/Filter/Option/Option.js +50 -193
- package/es/business/Filter/Option/style/Option.css +1 -63
- package/es/business/Filter/Option/style/css.js +2 -1
- package/es/business/Filter/Option/style/index.d.ts +1 -0
- package/es/business/Filter/Option/style/index.js +2 -1
- package/es/components/Button/Button.js +17 -15
- package/es/components/Button/constants.d.ts +0 -1
- package/es/components/Button/constants.js +1 -2
- package/es/components/Button/interface.d.ts +7 -0
- package/es/components/Dialog/Dialog.js +54 -208
- package/es/components/Dialog/DialogContent.d.ts +16 -0
- package/es/components/Dialog/DialogContent.js +72 -0
- package/es/components/Dialog/DialogControls.d.ts +27 -0
- package/es/components/Dialog/DialogControls.js +65 -0
- package/es/components/Dialog/className.d.ts +12 -0
- package/es/components/Dialog/className.js +16 -0
- package/es/components/Dialog/hooks.d.ts +5 -0
- package/es/components/Dialog/hooks.js +69 -0
- package/es/components/Dialog/style/Dialog.css +2 -11
- package/es/components/Dialog/types.d.ts +1 -0
- package/es/components/Dialog/types.js +2 -0
- package/es/components/Filter/Filter.d.ts +2 -0
- package/es/components/Filter/Filter.js +266 -0
- package/es/components/Filter/index.d.ts +4 -0
- package/es/components/Filter/index.js +5 -0
- package/es/components/Filter/interface.d.ts +67 -0
- package/es/components/Filter/interface.js +2 -0
- package/es/components/Filter/style/Filter.css +100 -0
- package/es/components/Filter/style/css.js +8 -0
- package/es/components/Filter/style/index.d.ts +7 -0
- package/es/components/Filter/style/index.js +8 -0
- package/es/components/Pagination/constants.js +3 -2
- package/es/components/Pagination/style/Pagination.css +10 -8
- package/es/components/Select/style/Select.css +2 -1
- package/es/index.css +1 -1
- package/es/index.d.ts +2 -0
- package/es/index.js +2 -1
- package/lib/business/Filter/Account/Account.js +69 -208
- package/lib/business/Filter/Account/style/Account.css +2 -42
- package/lib/business/Filter/Account/style/css.js +3 -1
- package/lib/business/Filter/Account/style/index.d.ts +2 -0
- package/lib/business/Filter/Account/style/index.js +3 -1
- package/lib/business/Filter/Asset/Asset.js +64 -208
- package/lib/business/Filter/Asset/style/Asset.css +3 -44
- package/lib/business/Filter/Asset/style/css.js +2 -1
- package/lib/business/Filter/Asset/style/index.d.ts +1 -0
- package/lib/business/Filter/Asset/style/index.js +2 -1
- package/lib/business/Filter/DateRange/DateRange.js +13 -8
- package/lib/business/Filter/DateRange/interface.d.ts +0 -5
- package/lib/business/Filter/DateRange/style/DateRange.css +15 -5
- package/lib/business/Filter/Option/Option.js +48 -192
- package/lib/business/Filter/Option/style/Option.css +1 -63
- package/lib/business/Filter/Option/style/css.js +2 -1
- package/lib/business/Filter/Option/style/index.d.ts +1 -0
- package/lib/business/Filter/Option/style/index.js +2 -1
- package/lib/components/Button/Button.js +17 -15
- package/lib/components/Button/constants.d.ts +0 -1
- package/lib/components/Button/constants.js +2 -3
- package/lib/components/Button/interface.d.ts +7 -0
- package/lib/components/Dialog/Dialog.js +56 -210
- package/lib/components/Dialog/DialogContent.d.ts +16 -0
- package/lib/components/Dialog/DialogContent.js +78 -0
- package/lib/components/Dialog/DialogControls.d.ts +27 -0
- package/lib/components/Dialog/DialogControls.js +72 -0
- package/lib/components/Dialog/className.d.ts +12 -0
- package/lib/components/Dialog/className.js +23 -0
- package/lib/components/Dialog/hooks.d.ts +5 -0
- package/lib/components/Dialog/hooks.js +75 -0
- package/lib/components/Dialog/style/Dialog.css +2 -11
- package/lib/components/Dialog/types.d.ts +1 -0
- package/lib/components/Dialog/types.js +6 -0
- package/lib/components/Filter/Filter.d.ts +2 -0
- package/lib/components/Filter/Filter.js +273 -0
- package/lib/components/Filter/index.d.ts +4 -0
- package/lib/components/Filter/index.js +30 -0
- package/lib/components/Filter/interface.d.ts +67 -0
- package/lib/components/Filter/interface.js +6 -0
- package/lib/components/Filter/style/Filter.css +100 -0
- package/lib/components/Filter/style/css.js +10 -0
- package/lib/components/Filter/style/index.d.ts +7 -0
- package/lib/components/Filter/style/index.js +10 -0
- package/lib/components/Pagination/constants.js +3 -2
- package/lib/components/Pagination/style/Pagination.css +10 -8
- package/lib/components/Select/style/Select.css +2 -1
- package/lib/index.css +1 -1
- package/lib/index.d.ts +2 -0
- package/lib/index.js +8 -1
- package/package.json +6 -1
- package/scripts/mcp-server/examples.generated.json +18 -0
- package/scripts/mcp-server/index.generated.json +68 -0
|
@@ -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 ? '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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O01BQVcsQ0FBQSxDQUNMLEVBQ1QsSUFBQUssZUFBQSxFQUFDK0gsY0FBTSxFQUFBO1FBQUN4SCxLQUFLLEVBQUMsU0FBUztRQUFDRCxJQUFJLEVBQUMsT0FBTztRQUFDTyxLQUFLLEVBQUVJLGdCQUFnQjtRQUFFb0csT0FBTyxFQUFFckIsV0FBVztRQUFBckYsUUFBQSxFQUMvRWY7TUFBVyxDQUFBLENBQ0w7SUFBQSxDQUFBO0VBQ0osQ0FBQSxDQUFBLENBRVQ7QUFFTixDQUFDO0FBRU0sSUFBTW9JLE1BQU0sR0FBQUMsT0FBQSxDQUFBRCxNQUFBLGdCQUFHLElBQUFFLFdBQUksRUFBQ3RHLFVBQVUsQ0FBQyIsImZpbGUiOiJjb21wb25lbnRzL0ZpbHRlci9GaWx0ZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgX19yZXN0ID0gKHRoaXMgJiYgdGhpcy5fX3Jlc3QpIHx8IGZ1bmN0aW9uIChzLCBlKSB7XG4gICAgdmFyIHQgPSB7fTtcbiAgICBmb3IgKHZhciBwIGluIHMpIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwocywgcCkgJiYgZS5pbmRleE9mKHApIDwgMClcbiAgICAgICAgdFtwXSA9IHNbcF07XG4gICAgaWYgKHMgIT0gbnVsbCAmJiB0eXBlb2YgT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scyA9PT0gXCJmdW5jdGlvblwiKVxuICAgICAgICBmb3IgKHZhciBpID0gMCwgcCA9IE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMocyk7IGkgPCBwLmxlbmd0aDsgaSsrKSB7XG4gICAgICAgICAgICBpZiAoZS5pbmRleE9mKHBbaV0pIDwgMCAmJiBPYmplY3QucHJvdG90eXBlLnByb3BlcnR5SXNFbnVtZXJhYmxlLmNhbGwocywgcFtpXSkpXG4gICAgICAgICAgICAgICAgdFtwW2ldXSA9IHNbcFtpXV07XG4gICAgICAgIH1cbiAgICByZXR1cm4gdDtcbn07XG5pbXBvcnQgeyBqc3ggYXMgX2pzeCwganN4cyBhcyBfanN4cyB9IGZyb20gXCJyZWFjdC9qc3gtcnVudGltZVwiO1xuaW1wb3J0IHsgbWVtbywgdXNlQ2FsbGJhY2ssIHVzZUltcGVyYXRpdmVIYW5kbGUsIHVzZU1lbW8sIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgQnV0dG9uIH0gZnJvbSAnLi4vQnV0dG9uJztcbmltcG9ydCB7IENoZWNrYm94IH0gZnJvbSAnLi4vQ2hlY2tib3gnO1xuaW1wb3J0IHsgRW1wdHkgfSBmcm9tICcuLi9FbXB0eSc7XG5pbXBvcnQgeyBGbGV4IH0gZnJvbSAnLi4vRmxleCc7XG5pbXBvcnQgeyBJY29ucyB9IGZyb20gJy4uL0ljb25zJztcbmltcG9ydCB7IFNlbGVjdCB9IGZyb20gJy4uL1NlbGVjdCc7XG5pbXBvcnQgeyBUeXBvZ3JhcGh5Qm9keSB9IGZyb20gJy4uL1R5cG9ncmFwaHknO1xuaW1wb3J0IHsgam9pbkNscyB9IGZyb20gJy4uLy4uL3V0aWxzL2NsYXNzbmFtZXMnO1xuY29uc3QgV1JBUF9DTFMgPSAnb20tZmlsdGVyJztcbi8vIFRoZSBwYW5lbCBpcyBwb3J0YWxlZCB0byA8Ym9keT4sIHNvIHBhbmVsLXNjb3BlZCBvdmVycmlkZXMgYXJlIGtleWVkIG9mZiB0aGlzXG4vLyBjbGFzcyAocGFzc2VkIGFzIGBwYW5lbENsYXNzTmFtZWApIHJhdGhlciB0aGFuIHRoZSB0cmlnZ2VyIHJvb3QuXG5jb25zdCBQQU5FTF9DTFMgPSBgJHtXUkFQX0NMU30tcGFuZWxgO1xuY29uc3QgUkVTRVRfTEFCRUwgPSAnUmVzZXQnO1xuY29uc3QgQVBQTFlfTEFCRUwgPSAnQXBwbHknO1xuY29uc3QgREVGQVVMVF9BTExfTEFCRUwgPSAnQWxsJztcbmNvbnN0IERFRkFVTFRfU0VBUkNIX1BMQUNFSE9MREVSID0gJ1NlYXJjaCc7XG5jb25zdCBERUZBVUxUX0VNUFRZID0gKF9qc3goRW1wdHksIHsgdmFyaWFudDogJ2ZpbGwnLCBpY29uOiBfanN4KEljb25zLCB7IG5hbWU6ICdzZWFyY2gnLCBzaXplOiAxNiwgY29sb3I6ICdjdXJyZW50Q29sb3InIH0pLCBcbiAgICAvLyBGaWdtYSBlbXB0eS1zdGF0ZSB0ZXh0IGlzIEJvZHkgU21hbGwgKDEycHgpOyBFbXB0eSdzIHN0cmluZyBwYXRoIHdvdWxkXG4gICAgLy8gcmVuZGVyIFRpdGxlIHNtIC8gQm9keSBtZCAoMTRweCksIHNvIHBhc3MgMTJweCBub2RlcyBleHBsaWNpdGx5LlxuICAgIHRpdGxlOiBfanN4KFR5cG9ncmFwaHlCb2R5LCB7IHNpemU6ICdzbScsIHN0cm9uZzogdHJ1ZSwgY29sb3I6ICduZXV0cmFsLXNlY29uZGFyeScsIGNoaWxkcmVuOiBcIk5vIHJlc3VsdHNcIiB9KSwgZGVzY3JpcHRpb246IF9qc3goVHlwb2dyYXBoeUJvZHksIHsgc2l6ZTogJ3NtJywgY29sb3I6ICduZXV0cmFsLXNlY29uZGFyeScsIGNoaWxkcmVuOiBcIlRyeSBhIGRpZmZlcmVudCBuYW1lIG9yIGFkanVzdCB5b3VyIHNlYXJjaCBmaWx0ZXJzLlwiIH0pLCBzdHlsZTogeyBwYWRkaW5nOiAwIH0gfSkpO1xuY29uc3QgTU9SRV9TVUZGSVggPSAoY291bnQpID0+IGArICR7Y291bnR9IG1vcmVgO1xuY29uc3QgRlVMTF9XSURUSF9TVFlMRSA9IHsgZmxleDogMSB9O1xuY29uc3QgaXNHcm91cCA9IChpdGVtKSA9PiAhIWl0ZW0gJiYgdHlwZW9mIGl0ZW0gPT09ICdvYmplY3QnICYmIEFycmF5LmlzQXJyYXkoaXRlbS5vcHRpb25zKTtcbi8vIEZsYXR0ZW4gZmxhdC9ncm91cGVkIG9wdGlvbnMgaW50byBhIHNpbmdsZSBvcmRlcmVkIG9wdGlvbiBsaXN0IOKAlCB1c2VkIGZvciB0aGVcbi8vIHZhbHVl4oaSbGFiZWwgbG9va3VwIGFuZCB0aGUgXCJldmVyeSBvcHRpb24gc2VsZWN0ZWRcIiBjb3VudC5cbmNvbnN0IGZsYXR0ZW5PcHRpb25zID0gKGRhdGEpID0+IGRhdGEuZmxhdE1hcCgoaXRlbSkgPT4gKGlzR3JvdXAoaXRlbSkgPyBpdGVtLm9wdGlvbnMgOiBbaXRlbV0pKTtcbmNvbnN0IEZpbHRlckJhc2UgPSAoX2EpID0+IHtcbiAgICB2YXIgeyByZWYsIGNsYXNzTmFtZSwgcGFuZWxDbGFzc05hbWUsIHNpemUgPSAnc21hbGwnLCBsYWJlbCwgcGxhY2Vob2xkZXIsIG9wdGlvbnMsIGFsbExhYmVsID0gREVGQVVMVF9BTExfTEFCRUwsIHNlYXJjaCA9IHRydWUsIHNlYXJjaFBsYWNlaG9sZGVyID0gREVGQVVMVF9TRUFSQ0hfUExBQ0VIT0xERVIsIGZpbHRlck9wdGlvbiwgZW1wdHlDb250ZW50ID0gREVGQVVMVF9FTVBUWSwgcmVuZGVyUm93LCBvbkFwcGx5LCBvblJlc2V0IH0gPSBfYSwgcmVzdCA9IF9fcmVzdChfYSwgW1wicmVmXCIsIFwiY2xhc3NOYW1lXCIsIFwicGFuZWxDbGFzc05hbWVcIiwgXCJzaXplXCIsIFwibGFiZWxcIiwgXCJwbGFjZWhvbGRlclwiLCBcIm9wdGlvbnNcIiwgXCJhbGxMYWJlbFwiLCBcInNlYXJjaFwiLCBcInNlYXJjaFBsYWNlaG9sZGVyXCIsIFwiZmlsdGVyT3B0aW9uXCIsIFwiZW1wdHlDb250ZW50XCIsIFwicmVuZGVyUm93XCIsIFwib25BcHBseVwiLCBcIm9uUmVzZXRcIl0pO1xuICAgIGNvbnN0IGZsYXRPcHRpb25zID0gdXNlTWVtbygoKSA9PiBmbGF0dGVuT3B0aW9ucyhvcHRpb25zKSwgW29wdGlvbnNdKTtcbiAgICBjb25zdCBhbGxWYWx1ZXMgPSB1c2VNZW1vKCgpID0+IGZsYXRPcHRpb25zLm1hcCgob3B0aW9uKSA9PiBTdHJpbmcob3B0aW9uLnZhbHVlKSksIFtmbGF0T3B0aW9uc10pO1xuICAgIGNvbnN0IG9wdGlvbkJ5VmFsdWUgPSB1c2VNZW1vKCgpID0+IHtcbiAgICAgICAgY29uc3QgbWFwID0gbmV3IE1hcCgpO1xuICAgICAgICBmbGF0T3B0aW9ucy5mb3JFYWNoKChvcHRpb24pID0+IG1hcC5zZXQoU3RyaW5nKG9wdGlvbi52YWx1ZSksIG9wdGlvbikpO1xuICAgICAgICByZXR1cm4gbWFwO1xuICAgIH0sIFtmbGF0T3B0aW9uc10pO1xuICAgIGNvbnN0IFtvcGVuLCBzZXRPcGVuXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgICBjb25zdCBba2V5d29yZCwgc2V0S2V5d29yZF0gPSB1c2VTdGF0ZSgnJyk7XG4gICAgLy8gYHRlbXBgIGlzIHRoZSBpbi1wYW5lbCBkcmFmdDsgYGNvbW1pdHRlZGAgaXMgdGhlIGxhc3QgQXBwbGllZCBzZWxlY3Rpb24uXG4gICAgLy8gT25seSBBcHBseSBwcm9tb3RlcyBgdGVtcGAg4oaSIGBjb21taXR0ZWRgIGFuZCBub3RpZmllcyB0aGUgcGFyZW50LiBXaXRoIGFuXG4gICAgLy8gXCJBbGxcIiByb3csIFwiYWxsIHNlbGVjdGVkXCIgaXMgcmVwcmVzZW50ZWQgYnkgYW4gZW1wdHkgYXJyYXkuXG4gICAgY29uc3QgW3RlbXAsIHNldFRlbXBdID0gdXNlU3RhdGUoW10pO1xuICAgIGNvbnN0IFtjb21taXR0ZWQsIHNldENvbW1pdHRlZF0gPSB1c2VTdGF0ZShbXSk7XG4gICAgLy8gVGhlIFwiQWxsXCIgcm93IGlzIGNoZWNrZWQgZXhhY3RseSB3aGVuIG5vdGhpbmcgc3BlY2lmaWMgaXMgc2VsZWN0ZWQuXG4gICAgY29uc3QgYWxsQ2hlY2tlZCA9IHRlbXAubGVuZ3RoID09PSAwO1xuICAgIC8vIFdoaWxlIHNlYXJjaGluZywgdGhlIFwiQWxsXCIgcm93IGlzIG1lYW5pbmdsZXNzIOKAlCBoaWRlIGl0IHNvIGEgbm8tbWF0Y2ggc2VhcmNoXG4gICAgLy8gc2hvd3MgdGhlIGVtcHR5IHN0YXRlIGluc3RlYWQgb2YgYSBsb25lIFwiQWxsXCIgcm93LlxuICAgIGNvbnN0IHNlYXJjaGluZyA9IHNlYXJjaCAmJiBrZXl3b3JkLnRyaW0oKS5sZW5ndGggPiAwO1xuICAgIGNvbnN0IGRlZmF1bHRGaWx0ZXJPcHRpb24gPSB1c2VDYWxsYmFjaygoc2VhcmNoVmFsdWUsIG9wdGlvbikgPT4ge1xuICAgICAgICBjb25zdCB0ZXJtID0gc2VhcmNoVmFsdWUudHJpbSgpLnRvTG93ZXJDYXNlKCk7XG4gICAgICAgIGlmICghdGVybSlcbiAgICAgICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgICByZXR1cm4gdHlwZW9mIG9wdGlvbi5zZWFyY2hUZXh0ID09PSAnc3RyaW5nJ1xuICAgICAgICAgICAgPyBvcHRpb24uc2VhcmNoVGV4dC50b0xvd2VyQ2FzZSgpLmluY2x1ZGVzKHRlcm0pXG4gICAgICAgICAgICA6IGZhbHNlO1xuICAgIH0sIFtdKTtcbiAgICB1c2VJbXBlcmF0aXZlSGFuZGxlKHJlZiwgKCkgPT4gKHtcbiAgICAgICAgY2xlYXI6ICgpID0+IHtcbiAgICAgICAgICAgIHNldFRlbXAoW10pO1xuICAgICAgICAgICAgc2V0Q29tbWl0dGVkKFtdKTtcbiAgICAgICAgfSxcbiAgICAgICAgcmVzZXQ6ICgpID0+IHtcbiAgICAgICAgICAgIHNldFRlbXAoW10pO1xuICAgICAgICAgICAgc2V0Q29tbWl0dGVkKFtdKTtcbiAgICAgICAgICAgIG9uUmVzZXQgPT09IG51bGwgfHwgb25SZXNldCA9PT0gdm9pZCAwID8gdm9pZCAwIDogb25SZXNldChbXSk7XG4gICAgICAgIH0sXG4gICAgfSksIFtvblJlc2V0XSk7XG4gICAgY29uc3QgaGFuZGxlU2VsZWN0Q2hhbmdlID0gdXNlQ2FsbGJhY2soKG5leHQpID0+IHtcbiAgICAgICAgY29uc3QgbmV4dFZhbHVlcyA9IChBcnJheS5pc0FycmF5KG5leHQpID8gbmV4dCA6IFtdKS5tYXAoU3RyaW5nKTtcbiAgICAgICAgLy8gU2VsZWN0aW5nIGV2ZXJ5IGNvbmNyZXRlIG9wdGlvbiBjb2xsYXBzZXMgdG8gXCJhbGxcIiAoW10pLCBtYXRjaGluZyB0aGVcbiAgICAgICAgLy8gYmFja2VuZCBjb252ZW50aW9uIHRoYXQgZW1wdHkgPT0gbm8gZmlsdGVyLlxuICAgICAgICBjb25zdCBjb2xsYXBzZSA9IG5leHRWYWx1ZXMubGVuZ3RoID09PSBhbGxWYWx1ZXMubGVuZ3RoO1xuICAgICAgICBzZXRUZW1wKGNvbGxhcHNlID8gW10gOiBuZXh0VmFsdWVzKTtcbiAgICB9LCBbYWxsVmFsdWVzXSk7XG4gICAgY29uc3QgaGFuZGxlQWxsQ2xpY2sgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgICAgIC8vIFRoZSBcIkFsbFwiIHJvdyBpcyBleGNsdXNpdmU6IHR1cm5pbmcgaXQgb24gY2xlYXJzIHNwZWNpZmljIHBpY2tzLlxuICAgICAgICBzZXRUZW1wKFtdKTtcbiAgICB9LCBbXSk7XG4gICAgY29uc3QgaGFuZGxlQXBwbHkgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgICAgIHNldENvbW1pdHRlZCh0ZW1wKTtcbiAgICAgICAgb25BcHBseSh0ZW1wKTtcbiAgICAgICAgc2V0T3BlbihmYWxzZSk7XG4gICAgfSwgW3RlbXAsIG9uQXBwbHldKTtcbiAgICBjb25zdCBoYW5kbGVSZXNldCA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICAgICAgc2V0VGVtcChbXSk7XG4gICAgICAgIHNldENvbW1pdHRlZChbXSk7XG4gICAgICAgIG9uUmVzZXQgPT09IG51bGwgfHwgb25SZXNldCA9PT0gdm9pZCAwID8gdm9pZCAwIDogb25SZXNldChbXSk7XG4gICAgfSwgW29uUmVzZXRdKTtcbiAgICBjb25zdCBoYW5kbGVPcGVuQ2hhbmdlID0gdXNlQ2FsbGJhY2soKG5leHRPcGVuKSA9PiB7XG4gICAgICAgIHNldE9wZW4obmV4dE9wZW4pO1xuICAgICAgICBpZiAobmV4dE9wZW4pXG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIC8vIENsb3Npbmcgd2l0aG91dCBBcHBseSBkaXNjYXJkcyB0aGUgZHJhZnQuXG4gICAgICAgIHNldFRlbXAoY29tbWl0dGVkKTtcbiAgICAgICAgc2V0S2V5d29yZCgnJyk7XG4gICAgfSwgW2NvbW1pdHRlZF0pO1xuICAgIC8vIFRoZSB0cmlnZ2VyIHJlZmxlY3RzIHRoZSBDT01NSVRURUQgc2VsZWN0aW9uIG9ubHkg4oCUIGB0ZW1wYCBpcyB0aGUgaW4tcGFuZWxcbiAgICAvLyBkcmFmdCBhbmQgbXVzdCBub3QgbGVhayBpbnRvIHRoZSB0cmlnZ2VyIGJlZm9yZSBBcHBseS4gQW4gZW1wdHkgYGNvbW1pdHRlZGBcbiAgICAvLyBtZWFucyBcImFsbFwiICh0aGUgYGFsbExhYmVsYCkuIGByZW5kZXJWYWx1ZWAgc2hvcnQtY2lyY3VpdHMgU2VsZWN0J3Mgb3duXG4gICAgLy8gcGxhY2Vob2xkZXIgaGFuZGxpbmcsIHNvIHRoZSBlbXB0eSBzdGF0ZSBtdXN0IHJldHVybiBgYWxsTGFiZWxgIGV4cGxpY2l0bHkuXG4gICAgY29uc3QgcmVuZGVyVmFsdWUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgICAgIGlmIChjb21taXR0ZWQubGVuZ3RoID09PSAwKSB7XG4gICAgICAgICAgICAvLyBgYWxsTGFiZWxgIGlzIHRoZSBkZWZhdWx0IGZpbHRlciB2YWx1ZSwgbm90IGFuIGVtcHR5IHBsYWNlaG9sZGVyLiBUaGVcbiAgICAgICAgICAgIC8vIHRyaWdnZXIncyBlbXB0eSBgdmFsdWVgIG1ha2VzIFNlbGVjdCB3cmFwIHRoaXMgaW4gaXRzIGdyZXkgcGxhY2Vob2xkZXJcbiAgICAgICAgICAgIC8vIGNsYXNzLCBzbyBmb3JjZSB0aGUgZGVmYXVsdCBkYXJrIHRleHQgdG8gbWF0Y2ggRGF0ZVJhbmdlLlxuICAgICAgICAgICAgcmV0dXJuIChfanN4KFR5cG9ncmFwaHlCb2R5LCB7IHNpemU6ICdtZCcsIGNvbG9yOiAnZGVmYXVsdCcsIGNsYXNzTmFtZTogYCR7V1JBUF9DTFN9X192YWx1ZWAsIGNoaWxkcmVuOiBfanN4KFwic3BhblwiLCB7IGNsYXNzTmFtZTogYCR7V1JBUF9DTFN9X192YWx1ZS1sYWJlbGAsIGNoaWxkcmVuOiBhbGxMYWJlbCB9KSB9KSk7XG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgZmlyc3QgPSBvcHRpb25CeVZhbHVlLmdldChjb21taXR0ZWRbMF0pO1xuICAgICAgICBjb25zdCBmaXJzdExhYmVsID0gZmlyc3QgPyBmaXJzdC5sYWJlbCA6IGNvbW1pdHRlZFswXTtcbiAgICAgICAgY29uc3QgZXh0cmEgPSBjb21taXR0ZWQubGVuZ3RoIC0gMTtcbiAgICAgICAgcmV0dXJuIChfanN4cyhUeXBvZ3JhcGh5Qm9keSwgeyBzaXplOiAnbWQnLCBjbGFzc05hbWU6IGAke1dSQVBfQ0xTfV9fdmFsdWVgLCBjaGlsZHJlbjogW19qc3goXCJzcGFuXCIsIHsgY2xhc3NOYW1lOiBgJHtXUkFQX0NMU31fX3ZhbHVlLWxhYmVsYCwgY2hpbGRyZW46IGZpcnN0TGFiZWwgfSksIGV4dHJhID4gMCAmJiBfanN4KFwic3BhblwiLCB7IGNsYXNzTmFtZTogYCR7V1JBUF9DTFN9X192YWx1ZS1tb3JlYCwgY2hpbGRyZW46IE1PUkVfU1VGRklYKGV4dHJhKSB9KV0gfSkpO1xuICAgIH0sIFthbGxMYWJlbCwgY29tbWl0dGVkLCBvcHRpb25CeVZhbHVlXSk7XG4gICAgcmV0dXJuIChfanN4KFNlbGVjdCwgT2JqZWN0LmFzc2lnbih7fSwgcmVzdCwgeyBtdWx0aXBsZTogdHJ1ZSwgc2l6ZTogc2l6ZSwgbGFiZWw6IGxhYmVsLCBwbGFjZWhvbGRlcjogcGxhY2Vob2xkZXIsIGNsYXNzTmFtZTogam9pbkNscyhXUkFQX0NMUywgY2xhc3NOYW1lKSwgcGFuZWxDbGFzc05hbWU6IGpvaW5DbHMoUEFORUxfQ0xTLCBwYW5lbENsYXNzTmFtZSksIHZhbHVlOiB0ZW1wLCBvcGVuOiBvcGVuLCBvbk9wZW5DaGFuZ2U6IGhhbmRsZU9wZW5DaGFuZ2UsIG9uQ2hhbmdlOiBoYW5kbGVTZWxlY3RDaGFuZ2UsIHNlYXJjaGFibGU6IHNlYXJjaCwgc2VhcmNoUGxhY2Vob2xkZXI6IHNlYXJjaFBsYWNlaG9sZGVyLCBzZWFyY2hWYWx1ZToga2V5d29yZCwgb25TZWFyY2hDaGFuZ2U6IHNldEtleXdvcmQsIGZpbHRlck9wdGlvbjogZmlsdGVyT3B0aW9uICE9PSBudWxsICYmIGZpbHRlck9wdGlvbiAhPT0gdm9pZCAwID8gZmlsdGVyT3B0aW9uIDogZGVmYXVsdEZpbHRlck9wdGlvbiwgb3B0aW9uczogb3B0aW9ucywgcGFuZWxIZWFkZXI6IHNlYXJjaGluZyA/IHVuZGVmaW5lZCA6IChfanN4cyhcImJ1dHRvblwiLCB7IHR5cGU6ICdidXR0b24nLCBjbGFzc05hbWU6IGpvaW5DbHMoYCR7V1JBUF9DTFN9X19hbGxgLCBhbGxDaGVja2VkICYmIGAke1dSQVBfQ0xTfV9fYWxsLS1jaGVja2VkYCksIG9uQ2xpY2s6IGhhbmRsZUFsbENsaWNrLCBjaGlsZHJlbjogW19qc3goVHlwb2dyYXBoeUJvZHksIHsgc2l6ZTogJ3NtJywgc3Ryb25nOiB0cnVlLCBjaGlsZHJlbjogYWxsTGFiZWwgfSksIF9qc3goQ2hlY2tib3gsIHsgY2hlY2tlZDogYWxsQ2hlY2tlZCwgcmVhZE9ubHk6IHRydWUsIGNsYXNzTmFtZTogYCR7V1JBUF9DTFN9X19yb3ctY2hlY2tgIH0pXSB9KSksIGVtcHR5Q29udGVudDogZW1wdHlDb250ZW50LCByZW5kZXJWYWx1ZTogcmVuZGVyVmFsdWUsIHJlbmRlck9wdGlvbjogKG9wdGlvbiwgbWV0YSkgPT4gcmVuZGVyUm93KG9wdGlvbiwgbWV0YS5zZWxlY3RlZCksIHBhbmVsRm9vdGVyOiBfanN4cyhGbGV4LCB7IGdhcDogOCwgY2xhc3NOYW1lOiBgJHtXUkFQX0NMU31fX2Zvb3RlcmAsIGNoaWxkcmVuOiBbX2pzeChCdXR0b24sIHsgY29sb3I6ICdncmV5Jywgc2l6ZTogJ3NtYWxsJywgc3R5bGU6IEZVTExfV0lEVEhfU1RZTEUsIG9uQ2xpY2s6IGhhbmRsZVJlc2V0LCBjaGlsZHJlbjogUkVTRVRfTEFCRUwgfSksIF9qc3goQnV0dG9uLCB7IGNvbG9yOiAncHJpbWFyeScsIHNpemU6ICdzbWFsbCcsIHN0eWxlOiBGVUxMX1dJRFRIX1NUWUxFLCBvbkNsaWNrOiBoYW5kbGVBcHBseSwgY2hpbGRyZW46IEFQUExZX0xBQkVMIH0pXSB9KSB9KSkpO1xufTtcbmV4cG9ydCBjb25zdCBGaWx0ZXIgPSBtZW1vKEZpbHRlckJhc2UpOyIsbnVsbF0sInNvdXJjZVJvb3QiOiIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMifQ==
|
|
@@ -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. `Filter` always renders a 32px trigger via scoped styles;
|
|
23
|
+
* this prop is forwarded to `Select` for typography/state parity.
|
|
24
|
+
* @default '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,100 @@
|
|
|
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 .om-component-ui-select-trigger-small {
|
|
24
|
+
min-height: var(--om-component-height-sm, 32px);
|
|
25
|
+
height: var(--om-component-height-sm, 32px);
|
|
26
|
+
padding: var(--om-spacing-200, 8px) var(--om-spacing-300, 12px);
|
|
27
|
+
}
|
|
28
|
+
.om-filter__value {
|
|
29
|
+
display: inline-flex;
|
|
30
|
+
align-items: center;
|
|
31
|
+
width: 100%;
|
|
32
|
+
overflow: hidden;
|
|
33
|
+
line-height: 18px;
|
|
34
|
+
}
|
|
35
|
+
.om-filter__value-label {
|
|
36
|
+
flex: 0 1 auto;
|
|
37
|
+
min-width: 0;
|
|
38
|
+
overflow: hidden;
|
|
39
|
+
white-space: nowrap;
|
|
40
|
+
text-overflow: ellipsis;
|
|
41
|
+
}
|
|
42
|
+
.om-filter__value-more {
|
|
43
|
+
flex: 0 0 auto;
|
|
44
|
+
margin-left: var(--om-spacing-100, 4px);
|
|
45
|
+
color: var(--om-text-default-tertiary, #646465);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
.om-filter-panel {
|
|
49
|
+
min-width: 240px;
|
|
50
|
+
}
|
|
51
|
+
.om-filter-panel .om-component-ui-select-search {
|
|
52
|
+
margin-bottom: var(--om-spacing-100, 4px);
|
|
53
|
+
}
|
|
54
|
+
.om-filter-panel .om-component-ui-select-search-small {
|
|
55
|
+
box-sizing: border-box;
|
|
56
|
+
min-height: 0;
|
|
57
|
+
height: var(--om-component-height-sm, 32px);
|
|
58
|
+
padding: 0 var(--om-spacing-300, 12px);
|
|
59
|
+
}
|
|
60
|
+
.om-filter-panel .om-component-ui-select-search-input-small {
|
|
61
|
+
font-size: var(--om-body-sm-font-size);
|
|
62
|
+
font-family: var(--om-body-sm-font-family);
|
|
63
|
+
line-height: var(--om-body-sm-line-height);
|
|
64
|
+
letter-spacing: var(--om-body-sm-letter-spacing);
|
|
65
|
+
font-weight: var(--om-body-sm-font-weight);
|
|
66
|
+
}
|
|
67
|
+
.om-filter-panel .om-component-ui-select-panel-body,
|
|
68
|
+
.om-filter-panel .om-component-ui-select-group {
|
|
69
|
+
gap: var(--om-spacing-100, 4px);
|
|
70
|
+
}
|
|
71
|
+
.om-filter-panel .om-component-ui-select-option {
|
|
72
|
+
min-height: 34px;
|
|
73
|
+
margin: 0;
|
|
74
|
+
padding: 6px var(--om-spacing-300, 12px);
|
|
75
|
+
}
|
|
76
|
+
.om-filter-panel .om-component-ui-select-panel-header {
|
|
77
|
+
margin-bottom: 0;
|
|
78
|
+
}
|
|
79
|
+
.om-filter-panel .om-component-ui-checkbox-input:checked + .om-component-ui-checkbox-box::after {
|
|
80
|
+
border-color: var(--om-icon-on-neutral, #fff);
|
|
81
|
+
}
|
|
82
|
+
.om-filter-panel .om-filter__all {
|
|
83
|
+
display: flex;
|
|
84
|
+
align-items: center;
|
|
85
|
+
justify-content: space-between;
|
|
86
|
+
width: 100%;
|
|
87
|
+
min-height: 34px;
|
|
88
|
+
padding: 6px var(--om-spacing-300, 12px);
|
|
89
|
+
border: none;
|
|
90
|
+
background: transparent;
|
|
91
|
+
border-radius: var(--om-radius-200, 8px);
|
|
92
|
+
cursor: pointer;
|
|
93
|
+
}
|
|
94
|
+
.om-filter-panel .om-filter__all:hover, .om-filter-panel .om-filter__all--checked {
|
|
95
|
+
background: var(--om-bg-default-secondary, #f8f8f8);
|
|
96
|
+
}
|
|
97
|
+
.om-filter-panel .om-filter__row-check {
|
|
98
|
+
flex: 0 0 auto;
|
|
99
|
+
pointer-events: none;
|
|
100
|
+
}
|
|
@@ -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,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
|
|
@@ -51,7 +51,8 @@ var PAGINATION_SLOT = exports.PAGINATION_SLOT = {
|
|
|
51
51
|
icon: 'icon'
|
|
52
52
|
};
|
|
53
53
|
// --- Typography ---
|
|
54
|
-
|
|
54
|
+
// Figma "Single Line/Body Small" — 12px / 500 weight (strong) / 16 line-height.
|
|
55
|
+
var PAGINATION_TEXT_SIZE = exports.PAGINATION_TEXT_SIZE = 'sm';
|
|
55
56
|
// --- Gap thresholds used when inserting ellipsis ---
|
|
56
57
|
var PAGINATION_GAP_FILL_THRESHOLD = exports.PAGINATION_GAP_FILL_THRESHOLD = 2;
|
|
57
58
|
// --- Key prefixes ---
|
|
@@ -59,4 +60,4 @@ var PAGINATION_KEY_PREFIX = exports.PAGINATION_KEY_PREFIX = {
|
|
|
59
60
|
page: 'page',
|
|
60
61
|
ellipsis: 'ellipsis'
|
|
61
62
|
};
|
|
62
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
|
63
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvc3JjL2NvbXBvbmVudHMvUGFnaW5hdGlvbi9jb25zdGFudHMudHMiLCJjb21wb25lbnRzL1BhZ2luYXRpb24vY29uc3RhbnRzLmpzIl0sIm5hbWVzIjpbIlBBR0lOQVRJT05fQ09NUE9ORU5UX05BTUUiLCJleHBvcnRzIiwiUEFHSU5BVElPTl9ERUZBVUxUX1BSRUZJWCIsIlBBR0lOQVRJT05fSVRFTV9UWVBFIiwicHJldmlvdXMiLCJwYWdlIiwiZWxsaXBzaXMiLCJuZXh0IiwiUEFHSU5BVElPTl9FTExJUFNJU19QT1NJVElPTiIsInN0YXJ0IiwiZW5kIiwiUEFHSU5BVElPTl9ERUZBVUxUX0NVUlJFTlQiLCJQQUdJTkFUSU9OX0RFRkFVTFRfUEFHRV9TSVpFIiwiUEFHSU5BVElPTl9ERUZBVUxUX1RPVEFMIiwiUEFHSU5BVElPTl9ERUZBVUxUX0JPVU5EQVJZX0NPVU5UIiwiUEFHSU5BVElPTl9ERUZBVUxUX01JRERMRV9QQUdFX0NPVU5UIiwiUEFHSU5BVElPTl9DT05UUk9MX0lDT05fU0laRSIsIlBBR0lOQVRJT05fQ09OVFJPTF9JQ09OX0NPTE9SIiwiUEFHSU5BVElPTl9FTExJUFNJU19URVhUIiwiUEFHSU5BVElPTl9DT05UUk9MX1RFWFQiLCJfZGVmaW5lUHJvcGVydHkyIiwiUEFHSU5BVElPTl9DT05UUk9MX0lDT04iLCJQQUdJTkFUSU9OX1RFWFRfQ09MT1IiLCJjdXJyZW50IiwiZGlzYWJsZWQiLCJQQUdJTkFUSU9OX1NMT1QiLCJsaXN0IiwiaXRlbSIsIml0ZW1FbGxpcHNpcyIsImJ1dHRvbiIsImJ1dHRvblBhZ2UiLCJidXR0b25Db250cm9sIiwiYnV0dG9uQ3VycmVudCIsImJ1dHRvbkRpc2FibGVkIiwiaWNvbiIsIlBBR0lOQVRJT05fVEVYVF9TSVpFIiwiUEFHSU5BVElPTl9HQVBfRklMTF9USFJFU0hPTEQiLCJQQUdJTkFUSU9OX0tFWV9QUkVGSVgiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBR08sSUFBTUEseUJBQXlCLEdBQUFDLE9BQUEsQ0FBQUQseUJBQUEsR0FBRyxZQUFZO0FBQzlDLElBQU1FLHlCQUF5QixHQUFBRCxPQUFBLENBQUFDLHlCQUFBLEdBQUcsWUFBWTtBQUVyRDtBQUNPLElBQU1DLG9CQUFvQixHQUFBRixPQUFBLENBQUFFLG9CQUFBLEdBQUc7RUFDbENDLFFBQVEsRUFBRSxVQUFVO0VBQ3BCQyxJQUFJLEVBQUUsTUFBTTtFQUNaQyxRQUFRLEVBQUUsVUFBVTtFQUNwQkMsSUFBSSxFQUFFO0FDSFIsQ0RJdUQ7QUFFdkQ7QUFDTyxJQUFNQyw0QkFBNEIsR0FBQVAsT0FBQSxDQUFBTyw0QkFBQSxHQUFHO0VBQzFDQyxLQUFLLEVBQUUsT0FBTztFQUNkQyxHQUFHLEVBQUU7QUNKUCxDREtVO0FBRVY7QUFDTyxJQUFNQywwQkFBMEIsR0FBQVYsT0FBQSxDQUFBVSwwQkFBQSxHQUFHLENBQUM7QUFDcEMsSUFBTUMsNEJBQTRCLEdBQUFYLE9BQUEsQ0FBQVcsNEJBQUEsR0FBRyxFQUFFO0FBQ3ZDLElBQU1DLHdCQUF3QixHQUFBWixPQUFBLENBQUFZLHdCQUFBLEdBQUcsQ0FBQztBQUNsQyxJQUFNQyxpQ0FBaUMsR0FBQWIsT0FBQSxDQUFBYSxpQ0FBQSxHQUFHLENBQUM7QUFDM0MsSUFBTUMsb0NBQW9DLEdBQUFkLE9BQUEsQ0FBQWMsb0NBQUEsR0FBRyxDQUFDO0FBRXJEO0FBQ08sSUFBTUMsNEJBQTRCLEdBQUFmLE9BQUEsQ0FBQWUsNEJBQUEsR0FBRyxFQUFFO0FBQ3ZDLElBQU1DLDZCQUE2QixHQUFBaEIsT0FBQSxDQUFBZ0IsNkJBQUEsR0FBRyxjQUFjO0FBQ3BELElBQU1DLHdCQUF3QixHQUFBakIsT0FBQSxDQUFBaUIsd0JBQUEsR0FBRyxLQUFLO0FBRXRDLElBQU1DLHVCQUF1QixHQUFBbEIsT0FBQSxDQUFBa0IsdUJBQUEsT0FBQUMsZ0JBQUEsaUJBQUFBLGdCQUFBLGlCQUNqQ2pCLG9CQUFvQixDQUFDQyxRQUFRLEVBQUcsVUFBVSxHQUMxQ0Qsb0JBQW9CLENBQUNJLElBQUksRUFBRyxNQUFNLENBQzNCO0FBRUgsSUFBTWMsdUJBQXVCLEdBQUFwQixPQUFBLENBQUFvQix1QkFBQSxPQUFBRCxnQkFBQSxpQkFBQUEsZ0JBQUEsaUJBQ2pDakIsb0JBQW9CLENBQUNDLFFBQVEsRUFBRyxhQUFhLEdBQzdDRCxvQkFBb0IsQ0FBQ0ksSUFBSSxFQUFHLGNBQWMsQ0FDbkM7QUFFSCxJQUFNZSxxQkFBcUIsR0FBQXJCLE9BQUEsQ0FBQXFCLHFCQUFBLEdBQUc7RUFDbkMsV0FBUyxTQUFTO0VBQ2xCQyxPQUFPLEVBQUUsWUFBWTtFQUNyQkMsUUFBUSxFQUFFO0FDVFosQ0RVZ0Y7QUFFaEY7QUFDTyxJQUFNQyxlQUFlLEdBQUF4QixPQUFBLENBQUF3QixlQUFBLEdBQUc7RUFDN0JDLElBQUksRUFBRSxNQUFNO0VBQ1pDLElBQUksRUFBRSxNQUFNO0VBQ1pDLFlBQVksRUFBRSxlQUFlO0VBQzdCQyxNQUFNLEVBQUUsUUFBUTtFQUNoQkMsVUFBVSxFQUFFLGFBQWE7RUFDekJDLGFBQWEsRUFBRSxnQkFBZ0I7RUFDL0JDLGFBQWEsRUFBRSxnQkFBZ0I7RUFDL0JDLGNBQWMsRUFBRSxpQkFBaUI7RUFDakMzQixRQUFRLEVBQUUsVUFBVTtFQUNwQjRCLElBQUksRUFBRTtBQ1ZSLENEV1U7QUFFVjtBQUNBO0FBQ08sSUFBTUMsb0JBQW9CLEdBQUFsQyxPQUFBLENBQUFrQyxvQkFBQSxHQUF1QixJQUFJO0FBRTVEO0FBQ08sSUFBTUMsNkJBQTZCLEdBQUFuQyxPQUFBLENBQUFtQyw2QkFBQSxHQUFHLENBQUM7QUFFOUM7QUFDTyxJQUFNQyxxQkFBcUIsR0FBQXBDLE9BQUEsQ0FBQW9DLHFCQUFBLEdBQUc7RUFDbkNoQyxJQUFJLEVBQUUsTUFBTTtFQUNaQyxRQUFRLEVBQUU7QUNiWixDRGNVIiwiZmlsZSI6ImNvbXBvbmVudHMvUGFnaW5hdGlvbi9jb25zdGFudHMuanMiLCJzb3VyY2VzQ29udGVudCI6W251bGwsImV4cG9ydCBjb25zdCBQQUdJTkFUSU9OX0NPTVBPTkVOVF9OQU1FID0gJ1BhZ2luYXRpb24nO1xuZXhwb3J0IGNvbnN0IFBBR0lOQVRJT05fREVGQVVMVF9QUkVGSVggPSAncGFnaW5hdGlvbic7XG4vLyAtLS0gSXRlbSB0eXBlcyAtLS1cbmV4cG9ydCBjb25zdCBQQUdJTkFUSU9OX0lURU1fVFlQRSA9IHtcbiAgICBwcmV2aW91czogJ3ByZXZpb3VzJyxcbiAgICBwYWdlOiAncGFnZScsXG4gICAgZWxsaXBzaXM6ICdlbGxpcHNpcycsXG4gICAgbmV4dDogJ25leHQnLFxufTtcbi8vIC0tLSBFbGxpcHNpcyBwb3NpdGlvbiAtLS1cbmV4cG9ydCBjb25zdCBQQUdJTkFUSU9OX0VMTElQU0lTX1BPU0lUSU9OID0ge1xuICAgIHN0YXJ0OiAnc3RhcnQnLFxuICAgIGVuZDogJ2VuZCcsXG59O1xuLy8gLS0tIERlZmF1bHRzIC0tLVxuZXhwb3J0IGNvbnN0IFBBR0lOQVRJT05fREVGQVVMVF9DVVJSRU5UID0gMTtcbmV4cG9ydCBjb25zdCBQQUdJTkFUSU9OX0RFRkFVTFRfUEFHRV9TSVpFID0gMTA7XG5leHBvcnQgY29uc3QgUEFHSU5BVElPTl9ERUZBVUxUX1RPVEFMID0gMDtcbmV4cG9ydCBjb25zdCBQQUdJTkFUSU9OX0RFRkFVTFRfQk9VTkRBUllfQ09VTlQgPSAxO1xuZXhwb3J0IGNvbnN0IFBBR0lOQVRJT05fREVGQVVMVF9NSURETEVfUEFHRV9DT1VOVCA9IDM7XG4vLyAtLS0gVUkgLS0tXG5leHBvcnQgY29uc3QgUEFHSU5BVElPTl9DT05UUk9MX0lDT05fU0laRSA9IDE2O1xuZXhwb3J0IGNvbnN0IFBBR0lOQVRJT05fQ09OVFJPTF9JQ09OX0NPTE9SID0gJ2N1cnJlbnRDb2xvcic7XG5leHBvcnQgY29uc3QgUEFHSU5BVElPTl9FTExJUFNJU19URVhUID0gJy4uLic7XG5leHBvcnQgY29uc3QgUEFHSU5BVElPTl9DT05UUk9MX1RFWFQgPSB7XG4gICAgW1BBR0lOQVRJT05fSVRFTV9UWVBFLnByZXZpb3VzXTogJ1ByZXZpb3VzJyxcbiAgICBbUEFHSU5BVElPTl9JVEVNX1RZUEUubmV4dF06ICdOZXh0Jyxcbn07XG5leHBvcnQgY29uc3QgUEFHSU5BVElPTl9DT05UUk9MX0lDT04gPSB7XG4gICAgW1BBR0lOQVRJT05fSVRFTV9UWVBFLnByZXZpb3VzXTogJ2NoZXZyb25MZWZ0JyxcbiAgICBbUEFHSU5BVElPTl9JVEVNX1RZUEUubmV4dF06ICdjaGV2cm9uUmlnaHQnLFxufTtcbmV4cG9ydCBjb25zdCBQQUdJTkFUSU9OX1RFWFRfQ09MT1IgPSB7XG4gICAgZGVmYXVsdDogJ2RlZmF1bHQnLFxuICAgIGN1cnJlbnQ6ICdvbi1uZXV0cmFsJyxcbiAgICBkaXNhYmxlZDogJ2Rpc2FibGVkJyxcbn07XG4vLyAtLS0gQkVNIG1vZGlmaWVycyAtLS1cbmV4cG9ydCBjb25zdCBQQUdJTkFUSU9OX1NMT1QgPSB7XG4gICAgbGlzdDogJ2xpc3QnLFxuICAgIGl0ZW06ICdpdGVtJyxcbiAgICBpdGVtRWxsaXBzaXM6ICdpdGVtLWVsbGlwc2lzJyxcbiAgICBidXR0b246ICdidXR0b24nLFxuICAgIGJ1dHRvblBhZ2U6ICdidXR0b24tcGFnZScsXG4gICAgYnV0dG9uQ29udHJvbDogJ2J1dHRvbi1jb250cm9sJyxcbiAgICBidXR0b25DdXJyZW50OiAnYnV0dG9uLWN1cnJlbnQnLFxuICAgIGJ1dHRvbkRpc2FibGVkOiAnYnV0dG9uLWRpc2FibGVkJyxcbiAgICBlbGxpcHNpczogJ2VsbGlwc2lzJyxcbiAgICBpY29uOiAnaWNvbicsXG59O1xuLy8gLS0tIFR5cG9ncmFwaHkgLS0tXG4vLyBGaWdtYSBcIlNpbmdsZSBMaW5lL0JvZHkgU21hbGxcIiDigJQgMTJweCAvIDUwMCB3ZWlnaHQgKHN0cm9uZykgLyAxNiBsaW5lLWhlaWdodC5cbmV4cG9ydCBjb25zdCBQQUdJTkFUSU9OX1RFWFRfU0laRSA9ICdzbSc7XG4vLyAtLS0gR2FwIHRocmVzaG9sZHMgdXNlZCB3aGVuIGluc2VydGluZyBlbGxpcHNpcyAtLS1cbmV4cG9ydCBjb25zdCBQQUdJTkFUSU9OX0dBUF9GSUxMX1RIUkVTSE9MRCA9IDI7XG4vLyAtLS0gS2V5IHByZWZpeGVzIC0tLVxuZXhwb3J0IGNvbnN0IFBBR0lOQVRJT05fS0VZX1BSRUZJWCA9IHtcbiAgICBwYWdlOiAncGFnZScsXG4gICAgZWxsaXBzaXM6ICdlbGxpcHNpcycsXG59OyJdLCJzb3VyY2VSb290IjoiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjIn0=
|