@1money/component-ui 0.0.67 → 0.0.68

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 (110) hide show
  1. package/es/business/Filter/Account/Account.d.ts +2 -0
  2. package/es/business/Filter/Account/Account.js +289 -0
  3. package/es/business/Filter/Account/index.d.ts +2 -0
  4. package/es/business/Filter/Account/index.js +3 -0
  5. package/es/business/Filter/Account/interface.d.ts +83 -0
  6. package/es/business/Filter/Account/interface.js +2 -0
  7. package/es/business/Filter/Account/style/Account.css +84 -0
  8. package/es/business/Filter/Account/style/css.js +2 -0
  9. package/es/business/Filter/Account/style/index.d.ts +1 -0
  10. package/es/business/Filter/Account/style/index.js +2 -0
  11. package/es/business/Filter/Asset/Asset.d.ts +2 -0
  12. package/es/business/Filter/Asset/Asset.js +306 -0
  13. package/es/business/Filter/Asset/index.d.ts +2 -0
  14. package/es/business/Filter/Asset/index.js +3 -0
  15. package/es/business/Filter/Asset/interface.d.ts +90 -0
  16. package/es/business/Filter/Asset/interface.js +2 -0
  17. package/es/business/Filter/Asset/style/Asset.css +96 -0
  18. package/es/business/Filter/Asset/style/css.js +2 -0
  19. package/es/business/Filter/Asset/style/index.d.ts +1 -0
  20. package/es/business/Filter/Asset/style/index.js +2 -0
  21. package/es/business/Filter/DateRange/DateRange.d.ts +2 -0
  22. package/es/business/Filter/DateRange/DateRange.js +393 -0
  23. package/es/business/Filter/DateRange/index.d.ts +2 -0
  24. package/es/business/Filter/DateRange/index.js +3 -0
  25. package/es/business/Filter/DateRange/interface.d.ts +68 -0
  26. package/es/business/Filter/DateRange/interface.js +9 -0
  27. package/es/business/Filter/DateRange/style/DateRange.css +85 -0
  28. package/es/business/Filter/DateRange/style/css.js +2 -0
  29. package/es/business/Filter/DateRange/style/index.d.ts +1 -0
  30. package/es/business/Filter/DateRange/style/index.js +2 -0
  31. package/es/business/Filter/Option/Option.d.ts +2 -0
  32. package/es/business/Filter/Option/Option.js +264 -0
  33. package/es/business/Filter/Option/index.d.ts +2 -0
  34. package/es/business/Filter/Option/index.js +3 -0
  35. package/es/business/Filter/Option/interface.d.ts +81 -0
  36. package/es/business/Filter/Option/interface.js +2 -0
  37. package/es/business/Filter/Option/style/Option.css +72 -0
  38. package/es/business/Filter/Option/style/css.js +2 -0
  39. package/es/business/Filter/Option/style/index.d.ts +1 -0
  40. package/es/business/Filter/Option/style/index.js +2 -0
  41. package/es/business/Filter/index.d.ts +4 -0
  42. package/es/business/Filter/index.js +5 -0
  43. package/es/business/Select/Asset/AssetSelect.js +49 -27
  44. package/es/business/Select/Asset/interface.d.ts +16 -1
  45. package/es/business/Select/Asset/style/AssetSelect.css +5 -0
  46. package/es/business/Select/Network/NetworkSelect.js +79 -13
  47. package/es/business/Select/Network/interface.d.ts +43 -9
  48. package/es/business/Select/Network/interface.js +9 -2
  49. package/es/business/Select/Network/style/NetworkSelect.css +10 -0
  50. package/es/business/index.d.ts +1 -0
  51. package/es/business/index.js +2 -1
  52. package/es/components/Select/Select.js +3 -2
  53. package/es/components/Select/interface.d.ts +2 -0
  54. package/es/index.css +1 -1
  55. package/lib/business/Filter/Account/Account.d.ts +2 -0
  56. package/lib/business/Filter/Account/Account.js +296 -0
  57. package/lib/business/Filter/Account/index.d.ts +2 -0
  58. package/lib/business/Filter/Account/index.js +28 -0
  59. package/lib/business/Filter/Account/interface.d.ts +83 -0
  60. package/lib/business/Filter/Account/interface.js +6 -0
  61. package/lib/business/Filter/Account/style/Account.css +84 -0
  62. package/lib/business/Filter/Account/style/css.js +4 -0
  63. package/lib/business/Filter/Account/style/index.d.ts +1 -0
  64. package/lib/business/Filter/Account/style/index.js +4 -0
  65. package/lib/business/Filter/Asset/Asset.d.ts +2 -0
  66. package/lib/business/Filter/Asset/Asset.js +313 -0
  67. package/lib/business/Filter/Asset/index.d.ts +2 -0
  68. package/lib/business/Filter/Asset/index.js +28 -0
  69. package/lib/business/Filter/Asset/interface.d.ts +90 -0
  70. package/lib/business/Filter/Asset/interface.js +6 -0
  71. package/lib/business/Filter/Asset/style/Asset.css +96 -0
  72. package/lib/business/Filter/Asset/style/css.js +4 -0
  73. package/lib/business/Filter/Asset/style/index.d.ts +1 -0
  74. package/lib/business/Filter/Asset/style/index.js +4 -0
  75. package/lib/business/Filter/DateRange/DateRange.d.ts +2 -0
  76. package/lib/business/Filter/DateRange/DateRange.js +400 -0
  77. package/lib/business/Filter/DateRange/index.d.ts +2 -0
  78. package/lib/business/Filter/DateRange/index.js +28 -0
  79. package/lib/business/Filter/DateRange/interface.d.ts +68 -0
  80. package/lib/business/Filter/DateRange/interface.js +15 -0
  81. package/lib/business/Filter/DateRange/style/DateRange.css +85 -0
  82. package/lib/business/Filter/DateRange/style/css.js +4 -0
  83. package/lib/business/Filter/DateRange/style/index.d.ts +1 -0
  84. package/lib/business/Filter/DateRange/style/index.js +4 -0
  85. package/lib/business/Filter/Option/Option.d.ts +2 -0
  86. package/lib/business/Filter/Option/Option.js +271 -0
  87. package/lib/business/Filter/Option/index.d.ts +2 -0
  88. package/lib/business/Filter/Option/index.js +28 -0
  89. package/lib/business/Filter/Option/interface.d.ts +81 -0
  90. package/lib/business/Filter/Option/interface.js +6 -0
  91. package/lib/business/Filter/Option/style/Option.css +72 -0
  92. package/lib/business/Filter/Option/style/css.js +4 -0
  93. package/lib/business/Filter/Option/style/index.d.ts +1 -0
  94. package/lib/business/Filter/Option/style/index.js +4 -0
  95. package/lib/business/Filter/index.d.ts +4 -0
  96. package/lib/business/Filter/index.js +50 -0
  97. package/lib/business/Select/Asset/AssetSelect.js +49 -27
  98. package/lib/business/Select/Asset/interface.d.ts +16 -1
  99. package/lib/business/Select/Asset/style/AssetSelect.css +5 -0
  100. package/lib/business/Select/Network/NetworkSelect.js +80 -13
  101. package/lib/business/Select/Network/interface.d.ts +43 -9
  102. package/lib/business/Select/Network/interface.js +10 -1
  103. package/lib/business/Select/Network/style/NetworkSelect.css +10 -0
  104. package/lib/business/index.d.ts +1 -0
  105. package/lib/business/index.js +12 -1
  106. package/lib/components/Select/Select.js +3 -2
  107. package/lib/components/Select/interface.d.ts +2 -0
  108. package/lib/index.css +1 -1
  109. package/package.json +26 -1
  110. package/scripts/mcp-server/index.generated.json +8 -0
@@ -0,0 +1,306 @@
1
+ import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
2
+ var __rest = this && this.__rest || function (s, e) {
3
+ var t = {};
4
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
6
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
7
+ }
8
+ return t;
9
+ };
10
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
11
+ import { memo, useCallback, useImperativeHandle, useMemo, useState } from 'react';
12
+ import { Button } from '../../../components/Button';
13
+ import { Checkbox } from '../../../components/Checkbox';
14
+ import { Empty } from '../../../components/Empty';
15
+ import { Flex } from '../../../components/Flex';
16
+ import { Icons } from '../../../components/Icons';
17
+ import { Select } from '../../../components/Select';
18
+ import { TypographyBody, TypographyLabel } from '../../../components/Typography';
19
+ import { joinCls } from '../../../utils/classnames';
20
+ var WRAP_CLS = 'om-asset-filter';
21
+ // The panel is portaled to <body>, so panel-scoped overrides are keyed off this
22
+ // class (passed as `panelClassName`) rather than the trigger root.
23
+ var PANEL_CLS = "".concat(WRAP_CLS, "-panel");
24
+ var GROUP_LABEL_CLS = "".concat(WRAP_CLS, "__group-label");
25
+ var ICON_CLS = "".concat(WRAP_CLS, "-icon");
26
+ var ICON_SIZE = 24;
27
+ var FIAT_GROUP = 'Cash';
28
+ var CRYPTO_GROUP = 'Stablecoins';
29
+ var RESET_LABEL = 'Reset';
30
+ var APPLY_LABEL = 'Apply';
31
+ var DEFAULT_ALL_LABEL = 'All assets';
32
+ var DEFAULT_PLACEHOLDER = 'Asset';
33
+ var DEFAULT_SEARCH_PLACEHOLDER = 'Search';
34
+ var DEFAULT_EMPTY = _jsx(Empty, {
35
+ variant: 'fill',
36
+ icon: _jsx(Icons, {
37
+ name: 'search',
38
+ size: 16,
39
+ color: 'currentColor'
40
+ }),
41
+ title: 'No results',
42
+ description: 'Try a different name or adjust your search filters.',
43
+ style: {
44
+ padding: 0
45
+ }
46
+ });
47
+ var MORE_SUFFIX = function MORE_SUFFIX(count) {
48
+ return "+ ".concat(count, " more");
49
+ };
50
+ var FULL_WIDTH_STYLE = {
51
+ flex: 1
52
+ };
53
+ var toOption = function toOption(item) {
54
+ return {
55
+ label: item.assetName,
56
+ value: item.assetName,
57
+ iconUrl: item.assetIconUrl,
58
+ // Match the symbol and the full name regardless of what the row renders.
59
+ searchText: [item.assetName, item.assetDesc].filter(Boolean).join(' ')
60
+ };
61
+ };
62
+ // Fiat assets bucket under "Cash", the rest under "Stablecoins". Empty groups
63
+ // are dropped so a fiat-only (or crypto-only) list shows a single heading.
64
+ var toGroupedData = function toGroupedData(items) {
65
+ var fiat = items.filter(function (item) {
66
+ return item.isFiat;
67
+ }).map(toOption);
68
+ var crypto = items.filter(function (item) {
69
+ return !item.isFiat;
70
+ }).map(toOption);
71
+ var data = [];
72
+ if (fiat.length) data.push({
73
+ key: FIAT_GROUP,
74
+ label: FIAT_GROUP,
75
+ options: fiat
76
+ });
77
+ if (crypto.length) data.push({
78
+ key: CRYPTO_GROUP,
79
+ label: CRYPTO_GROUP,
80
+ options: crypto
81
+ });
82
+ return data;
83
+ };
84
+ var AssetFilterBase = function AssetFilterBase(_a) {
85
+ var ref = _a.ref,
86
+ className = _a.className,
87
+ _a$size = _a.size,
88
+ size = _a$size === void 0 ? 'small' : _a$size,
89
+ label = _a.label,
90
+ _a$placeholder = _a.placeholder,
91
+ placeholder = _a$placeholder === void 0 ? DEFAULT_PLACEHOLDER : _a$placeholder,
92
+ data = _a.data,
93
+ _a$allLabel = _a.allLabel,
94
+ allLabel = _a$allLabel === void 0 ? DEFAULT_ALL_LABEL : _a$allLabel,
95
+ _a$search = _a.search,
96
+ search = _a$search === void 0 ? true : _a$search,
97
+ _a$searchPlaceholder = _a.searchPlaceholder,
98
+ searchPlaceholder = _a$searchPlaceholder === void 0 ? DEFAULT_SEARCH_PLACEHOLDER : _a$searchPlaceholder,
99
+ _a$searchEmpty = _a.searchEmpty,
100
+ searchEmpty = _a$searchEmpty === void 0 ? DEFAULT_EMPTY : _a$searchEmpty,
101
+ onApply = _a.onApply,
102
+ onReset = _a.onReset,
103
+ rest = __rest(_a, ["ref", "className", "size", "label", "placeholder", "data", "allLabel", "search", "searchPlaceholder", "searchEmpty", "onApply", "onReset"]);
104
+ var groupedData = useMemo(function () {
105
+ return toGroupedData(data);
106
+ }, [data]);
107
+ var allValues = useMemo(function () {
108
+ return data.map(function (item) {
109
+ return item.assetName;
110
+ });
111
+ }, [data]);
112
+ var optionByValue = useMemo(function () {
113
+ var map = new Map();
114
+ data.forEach(function (item) {
115
+ return map.set(item.assetName, toOption(item));
116
+ });
117
+ return map;
118
+ }, [data]);
119
+ var _useState = useState(false),
120
+ _useState2 = _slicedToArray(_useState, 2),
121
+ open = _useState2[0],
122
+ setOpen = _useState2[1];
123
+ var _useState3 = useState(''),
124
+ _useState4 = _slicedToArray(_useState3, 2),
125
+ keyword = _useState4[0],
126
+ setKeyword = _useState4[1];
127
+ // `temp` is the in-panel draft; `committed` is the last Applied selection.
128
+ // Only Apply promotes `temp` → `committed` and notifies the parent. With an
129
+ // "All assets" row, "all selected" is represented by an empty array.
130
+ var _useState5 = useState([]),
131
+ _useState6 = _slicedToArray(_useState5, 2),
132
+ temp = _useState6[0],
133
+ setTemp = _useState6[1];
134
+ var _useState7 = useState([]),
135
+ _useState8 = _slicedToArray(_useState7, 2),
136
+ committed = _useState8[0],
137
+ setCommitted = _useState8[1];
138
+ // The "All assets" row is checked exactly when nothing specific is selected.
139
+ var allChecked = temp.length === 0;
140
+ // While searching, the "All assets" row is meaningless — hide it so a
141
+ // no-match search shows the empty state instead of a lone "All assets".
142
+ var searching = search && keyword.trim().length > 0;
143
+ var filterOption = useCallback(function (searchValue, option) {
144
+ var term = searchValue.trim().toLowerCase();
145
+ if (!term) return true;
146
+ var mapped = option;
147
+ return typeof mapped.searchText === 'string' ? mapped.searchText.toLowerCase().includes(term) : false;
148
+ }, []);
149
+ useImperativeHandle(ref, function () {
150
+ return {
151
+ clear: function clear() {
152
+ setTemp([]);
153
+ setCommitted([]);
154
+ },
155
+ reset: function reset() {
156
+ setTemp([]);
157
+ setCommitted([]);
158
+ onReset === null || onReset === void 0 ? void 0 : onReset([]);
159
+ }
160
+ };
161
+ }, [onReset]);
162
+ var handleSelectChange = useCallback(function (next) {
163
+ var nextValues = (Array.isArray(next) ? next : []).map(String);
164
+ // Selecting every concrete asset collapses to "all" ([]), matching the
165
+ // backend convention that empty == no filter.
166
+ var collapse = nextValues.length === allValues.length;
167
+ setTemp(collapse ? [] : nextValues);
168
+ }, [allValues]);
169
+ var handleAllClick = useCallback(function () {
170
+ // The "All assets" row is exclusive: turning it on clears specific picks.
171
+ setTemp([]);
172
+ }, []);
173
+ var handleApply = useCallback(function () {
174
+ setCommitted(temp);
175
+ onApply(temp);
176
+ setOpen(false);
177
+ }, [temp, onApply]);
178
+ var handleReset = useCallback(function () {
179
+ setTemp([]);
180
+ setCommitted([]);
181
+ onReset === null || onReset === void 0 ? void 0 : onReset([]);
182
+ }, [onReset]);
183
+ var handleOpenChange = useCallback(function (nextOpen) {
184
+ setOpen(nextOpen);
185
+ if (nextOpen) return;
186
+ // Closing without Apply discards the draft.
187
+ setTemp(committed);
188
+ setKeyword('');
189
+ }, [committed]);
190
+ var renderRow = useCallback(function (option, checked) {
191
+ var text = typeof option.label === 'string' ? option.label : '';
192
+ return _jsxs(Flex, {
193
+ align: 'center',
194
+ justify: 'space-between',
195
+ gap: 8,
196
+ className: "".concat(WRAP_CLS, "__row"),
197
+ children: [_jsxs(Flex, {
198
+ align: 'center',
199
+ gap: 8,
200
+ className: "".concat(WRAP_CLS, "__row-main"),
201
+ children: [option.iconUrl && _jsx("img", {
202
+ src: option.iconUrl,
203
+ alt: text,
204
+ width: ICON_SIZE,
205
+ height: ICON_SIZE,
206
+ className: ICON_CLS
207
+ }), _jsx(TypographyLabel, {
208
+ size: 'md',
209
+ className: "".concat(WRAP_CLS, "__row-name"),
210
+ children: option.label
211
+ })]
212
+ }), _jsx(Checkbox, {
213
+ checked: checked,
214
+ readOnly: true,
215
+ className: "".concat(WRAP_CLS, "__row-check")
216
+ })]
217
+ });
218
+ }, []);
219
+ // The trigger reflects the COMMITTED selection only — `temp` is the in-panel
220
+ // draft and must not leak into the trigger before Apply. An empty `committed`
221
+ // means "All assets". `renderValue` short-circuits Select's own placeholder
222
+ // handling, so the empty state must return the "All assets" text explicitly.
223
+ var renderValue = useCallback(function () {
224
+ if (committed.length === 0) {
225
+ // "All assets" is the default filter value, not an empty placeholder. The
226
+ // trigger's empty `value` makes Select wrap this in its grey placeholder
227
+ // class, so force the default dark text to match DateRange.
228
+ return _jsx(TypographyBody, {
229
+ size: 'md',
230
+ color: 'default',
231
+ className: "".concat(WRAP_CLS, "__value"),
232
+ children: allLabel
233
+ });
234
+ }
235
+ var first = optionByValue.get(committed[0]);
236
+ var firstLabel = first ? first.label : committed[0];
237
+ var extra = committed.length - 1;
238
+ return _jsxs(TypographyBody, {
239
+ size: 'md',
240
+ className: "".concat(WRAP_CLS, "__value"),
241
+ children: [_jsx("span", {
242
+ className: "".concat(WRAP_CLS, "__value-label"),
243
+ children: firstLabel
244
+ }), extra > 0 && _jsx("span", {
245
+ className: "".concat(WRAP_CLS, "__value-more"),
246
+ children: MORE_SUFFIX(extra)
247
+ })]
248
+ });
249
+ }, [allLabel, committed, optionByValue]);
250
+ return _jsx(Select, Object.assign({}, rest, {
251
+ multiple: true,
252
+ size: size,
253
+ label: label,
254
+ placeholder: placeholder,
255
+ className: joinCls(WRAP_CLS, className),
256
+ panelClassName: PANEL_CLS,
257
+ groupLabelClassName: GROUP_LABEL_CLS,
258
+ value: temp,
259
+ open: open,
260
+ onOpenChange: handleOpenChange,
261
+ onChange: handleSelectChange,
262
+ searchable: search,
263
+ searchPlaceholder: searchPlaceholder,
264
+ searchValue: keyword,
265
+ onSearchChange: setKeyword,
266
+ filterOption: filterOption,
267
+ options: groupedData,
268
+ panelHeader: searching ? undefined : _jsxs("button", {
269
+ type: 'button',
270
+ className: joinCls("".concat(WRAP_CLS, "__all"), allChecked && "".concat(WRAP_CLS, "__all--checked")),
271
+ onClick: handleAllClick,
272
+ children: [_jsx(TypographyLabel, {
273
+ size: 'md',
274
+ children: allLabel
275
+ }), _jsx(Checkbox, {
276
+ checked: allChecked,
277
+ readOnly: true,
278
+ className: "".concat(WRAP_CLS, "__row-check")
279
+ })]
280
+ }),
281
+ emptyContent: searchEmpty,
282
+ renderValue: renderValue,
283
+ renderOption: function renderOption(option, meta) {
284
+ return renderRow(option, meta.selected);
285
+ },
286
+ panelFooter: _jsxs(Flex, {
287
+ gap: 8,
288
+ className: "".concat(WRAP_CLS, "__footer"),
289
+ children: [_jsx(Button, {
290
+ color: 'grey',
291
+ size: 'small',
292
+ style: FULL_WIDTH_STYLE,
293
+ onClick: handleReset,
294
+ children: RESET_LABEL
295
+ }), _jsx(Button, {
296
+ color: 'primary',
297
+ size: 'small',
298
+ style: FULL_WIDTH_STYLE,
299
+ onClick: handleApply,
300
+ children: APPLY_LABEL
301
+ })]
302
+ })
303
+ }));
304
+ };
305
+ export var AssetFilter = /*#__PURE__*/memo(AssetFilterBase);
306
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJ1c2luZXNzL0ZpbHRlci9Bc3NldC9Bc3NldC5qcyIsImJ1c2luZXNzL0ZpbHRlci9zcmMvYnVzaW5lc3MvRmlsdGVyL0Fzc2V0L0Fzc2V0LnRzeCJdLCJuYW1lcyI6WyJfX3Jlc3QiLCJzIiwiZSIsInQiLCJwIiwiT2JqZWN0IiwicHJvdG90eXBlIiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwiaW5kZXhPZiIsImdldE93blByb3BlcnR5U3ltYm9scyIsImkiLCJsZW5ndGgiLCJwcm9wZXJ0eUlzRW51bWVyYWJsZSIsImpzeCIsIl9qc3giLCJqc3hzIiwiX2pzeHMiLCJtZW1vIiwidXNlQ2FsbGJhY2siLCJ1c2VJbXBlcmF0aXZlSGFuZGxlIiwidXNlTWVtbyIsInVzZVN0YXRlIiwiQnV0dG9uIiwiQ2hlY2tib3giLCJFbXB0eSIsIkZsZXgiLCJJY29ucyIsIlNlbGVjdCIsIlR5cG9ncmFwaHlCb2R5IiwiVHlwb2dyYXBoeUxhYmVsIiwiam9pbkNscyIsIldSQVBfQ0xTIiwiUEFORUxfQ0xTIiwiY29uY2F0IiwiR1JPVVBfTEFCRUxfQ0xTIiwiSUNPTl9DTFMiLCJJQ09OX1NJWkUiLCJGSUFUX0dST1VQIiwiQ1JZUFRPX0dST1VQIiwiUkVTRVRfTEFCRUwiLCJBUFBMWV9MQUJFTCIsIkRFRkFVTFRfQUxMX0xBQkVMIiwiREVGQVVMVF9QTEFDRUhPTERFUiIsIkRFRkFVTFRfU0VBUkNIX1BMQUNFSE9MREVSIiwiREVGQVVMVF9FTVBUWSIsInZhcmlhbnQiLCJpY29uIiwibmFtZSIsInNpemUiLCJjb2xvciIsInRpdGxlIiwiZGVzY3JpcHRpb24iLCJzdHlsZSIsInBhZGRpbmciLCJNT1JFX1NVRkZJWCIsImNvdW50IiwiRlVMTF9XSURUSF9TVFlMRSIsImZsZXgiLCJ0b09wdGlvbiIsIml0ZW0iLCJsYWJlbCIsImFzc2V0TmFtZSIsInZhbHVlIiwiaWNvblVybCIsImFzc2V0SWNvblVybCIsInNlYXJjaFRleHQiLCJhc3NldERlc2MiLCJmaWx0ZXIiLCJCb29sZWFuIiwiam9pbiIsInRvR3JvdXBlZERhdGEiLCJpdGVtcyIsImZpYXQiLCJpc0ZpYXQiLCJtYXAiLCJjcnlwdG8iLCJkYXRhIiwicHVzaCIsImtleSIsIm9wdGlvbnMiLCJBc3NldEZpbHRlckJhc2UiLCJfYSIsInJlZiIsImNsYXNzTmFtZSIsIl9hJHNpemUiLCJfYSRwbGFjZWhvbGRlciIsInBsYWNlaG9sZGVyIiwiX2EkYWxsTGFiZWwiLCJhbGxMYWJlbCIsIl9hJHNlYXJjaCIsInNlYXJjaCIsIl9hJHNlYXJjaFBsYWNlaG9sZGVyIiwic2VhcmNoUGxhY2Vob2xkZXIiLCJfYSRzZWFyY2hFbXB0eSIsInNlYXJjaEVtcHR5Iiwib25BcHBseSIsIm9uUmVzZXQiLCJyZXN0IiwiZ3JvdXBlZERhdGEiLCJhbGxWYWx1ZXMiLCJvcHRpb25CeVZhbHVlIiwiTWFwIiwiZm9yRWFjaCIsInNldCIsIl91c2VTdGF0ZSIsIl91c2VTdGF0ZTIiLCJfc2xpY2VkVG9BcnJheSIsIm9wZW4iLCJzZXRPcGVuIiwiX3VzZVN0YXRlMyIsIl91c2VTdGF0ZTQiLCJrZXl3b3JkIiwic2V0S2V5d29yZCIsIl91c2VTdGF0ZTUiLCJfdXNlU3RhdGU2IiwidGVtcCIsInNldFRlbXAiLCJfdXNlU3RhdGU3IiwiX3VzZVN0YXRlOCIsImNvbW1pdHRlZCIsInNldENvbW1pdHRlZCIsImFsbENoZWNrZWQiLCJzZWFyY2hpbmciLCJ0cmltIiwiZmlsdGVyT3B0aW9uIiwic2VhcmNoVmFsdWUiLCJvcHRpb24iLCJ0ZXJtIiwidG9Mb3dlckNhc2UiLCJtYXBwZWQiLCJpbmNsdWRlcyIsImNsZWFyIiwicmVzZXQiLCJoYW5kbGVTZWxlY3RDaGFuZ2UiLCJuZXh0IiwibmV4dFZhbHVlcyIsIkFycmF5IiwiaXNBcnJheSIsIlN0cmluZyIsImNvbGxhcHNlIiwiaGFuZGxlQWxsQ2xpY2siLCJoYW5kbGVBcHBseSIsImhhbmRsZVJlc2V0IiwiaGFuZGxlT3BlbkNoYW5nZSIsIm5leHRPcGVuIiwicmVuZGVyUm93IiwiY2hlY2tlZCIsInRleHQiLCJhbGlnbiIsImp1c3RpZnkiLCJnYXAiLCJjaGlsZHJlbiIsInNyYyIsImFsdCIsIndpZHRoIiwiaGVpZ2h0IiwicmVhZE9ubHkiLCJyZW5kZXJWYWx1ZSIsImZpcnN0IiwiZ2V0IiwiZmlyc3RMYWJlbCIsImV4dHJhIiwiYXNzaWduIiwibXVsdGlwbGUiLCJwYW5lbENsYXNzTmFtZSIsImdyb3VwTGFiZWxDbGFzc05hbWUiLCJvbk9wZW5DaGFuZ2UiLCJvbkNoYW5nZSIsInNlYXJjaGFibGUiLCJvblNlYXJjaENoYW5nZSIsInBhbmVsSGVhZGVyIiwidW5kZWZpbmVkIiwidHlwZSIsIm9uQ2xpY2siLCJlbXB0eUNvbnRlbnQiLCJyZW5kZXJPcHRpb24iLCJtZXRhIiwic2VsZWN0ZWQiLCJwYW5lbEZvb3RlciIsIkFzc2V0RmlsdGVyIl0sIm1hcHBpbmdzIjoiO0FBQUEsSUFBSUEsTUFBTSxHQUFJLElBQUksSUFBSSxJQUFJLENBQUNBLE1BQU0sSUFBSyxVQUFVQyxDQUFDLEVBQUVDLENBQUMsRUFBRTtFQUNsRCxJQUFJQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0VBQ1YsS0FBSyxJQUFJQyxDQUFDLElBQUlILENBQUMsRUFBRSxJQUFJSSxNQUFNLENBQUNDLFNBQVMsQ0FBQ0MsY0FBYyxDQUFDQyxJQUFJLENBQUNQLENBQUMsRUFBRUcsQ0FBQyxDQUFDLElBQUlGLENBQUMsQ0FBQ08sT0FBTyxDQUFDTCxDQUFDLENBQUMsR0FBRyxDQUFDLEVBQy9FRCxDQUFDLENBQUNDLENBQUMsQ0FBQyxHQUFHSCxDQUFDLENBQUNHLENBQUMsQ0FBQztFQUNmLElBQUlILENBQUMsSUFBSSxJQUFJLElBQUksT0FBT0ksTUFBTSxDQUFDSyxxQkFBcUIsS0FBSyxVQUFVLEVBQy9ELEtBQUssSUFBSUMsQ0FBQyxHQUFHLENBQUMsRUFBRVAsQ0FBQyxHQUFHQyxNQUFNLENBQUNLLHFCQUFxQixDQUFDVCxDQUFDLENBQUMsRUFBRVUsQ0FBQyxHQUFHUCxDQUFDLENBQUNRLE1BQU0sRUFBRUQsQ0FBQyxFQUFFLEVBQUU7SUFDcEUsSUFBSVQsQ0FBQyxDQUFDTyxPQUFPLENBQUNMLENBQUMsQ0FBQ08sQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLElBQUlOLE1BQU0sQ0FBQ0MsU0FBUyxDQUFDTyxvQkFBb0IsQ0FBQ0wsSUFBSSxDQUFDUCxDQUFDLEVBQUVHLENBQUMsQ0FBQ08sQ0FBQyxDQUFDLENBQUMsRUFDMUVSLENBQUMsQ0FBQ0MsQ0FBQyxDQUFDTyxDQUFDLENBQUMsQ0FBQyxHQUFHVixDQUFDLENBQUNHLENBQUMsQ0FBQ08sQ0FBQyxDQUFDLENBQUM7RUFDekI7RUFDSixPQUFPUixDQUFDO0FBQ1osQ0FBQztBQUNELFNBQVNXLEdBQUcsSUFBSUMsSUFBSSxFQUFFQyxJQUFJLElBQUlDLEtBQUssUUFBUSxtQkFBbUI7QUNYOUQsU0FBU0MsSUFBSSxFQUFFQyxXQUFXLEVBQUVDLG1CQUFtQixFQUFFQyxPQUFPLEVBQUVDLFFBQVEsUUFBUSxPQUFPO0FBQ2pGLFNBQVNDLE1BQU0sUUFBUSw0QkFBNEI7QUFDbkQsU0FBU0MsUUFBUSxRQUFRLDhCQUE4QjtBQUN2RCxTQUFTQyxLQUFLLFFBQVEsMkJBQTJCO0FBQ2pELFNBQVNDLElBQUksUUFBUSwwQkFBMEI7QUFDL0MsU0FBU0MsS0FBSyxRQUFRLDJCQUEyQjtBQUNqRCxTQUFTQyxNQUFNLFFBQVEsNEJBQTRCO0FBQ25ELFNBQVNDLGNBQWMsRUFBRUMsZUFBZSxRQUFRLGdDQUFnQztBQUNoRixTQUFTQyxPQUFPLFFBQVEsMkJBQTJCO0FBS25ELElBQU1DLFFBQVEsR0FBRyxpQkFBaUI7QUFDbEM7QUFDQTtBQUNBLElBQU1DLFNBQVMsTUFBQUMsTUFBQSxDQUFNRixRQUFRLFdBQVE7QUFDckMsSUFBTUcsZUFBZSxNQUFBRCxNQUFBLENBQU1GLFFBQVEsa0JBQWU7QUFDbEQsSUFBTUksUUFBUSxNQUFBRixNQUFBLENBQU1GLFFBQVEsVUFBTztBQUNuQyxJQUFNSyxTQUFTLEdBQUcsRUFBRTtBQUNwQixJQUFNQyxVQUFVLEdBQUcsTUFBTTtBQUN6QixJQUFNQyxZQUFZLEdBQUcsYUFBYTtBQUNsQyxJQUFNQyxXQUFXLEdBQUcsT0FBTztBQUMzQixJQUFNQyxXQUFXLEdBQUcsT0FBTztBQUMzQixJQUFNQyxpQkFBaUIsR0FBRyxZQUFZO0FBQ3RDLElBQU1DLG1CQUFtQixHQUFHLE9BQU87QUFDbkMsSUFBTUMsMEJBQTBCLEdBQUcsUUFBUTtBQUMzQyxJQUFNQyxhQUFhLEdBQ2pCOUIsSUFBQSxDQUFDVSxLQUFLLEVBQUE7RUFDSnFCLE9BQU8sRUFBQyxNQUFNO0VBQ2RDLElBQUksRUFBRWhDLElBQUEsQ0FBQ1ksS0FBSyxFQUFBO0lBQUNxQixJQUFJLEVBQUMsUUFBUTtJQUFDQyxJQUFJLEVBQUUsRUFBRTtJQUFFQyxLQUFLLEVBQUM7RUFBYyxDQUFBLENBQUc7RUFDNURDLEtBQUssRUFBQyxZQUFZO0VBQ2xCQyxXQUFXLEVBQUMscURBQXFEO0VBQ2pFQyxLQUFLLEVBQUU7SUFBRUMsT0FBTyxFQUFFO0VBQUM7QUFBRSxDQUFBLENBRXhCO0FBQ0QsSUFBTUMsV0FBVyxHQUFHLFNBQWRBLFdBQVdBLENBQUlDLEtBQWE7RUFBQSxZQUFBdEIsTUFBQSxDQUFVc0IsS0FBSztBQUFBLENBQU87QUFDeEQsSUFBTUMsZ0JBQWdCLEdBQUc7RUFBRUMsSUFBSSxFQUFFO0FBQUMsQ0FBVztBQVM3QyxJQUFNQyxRQUFRLEdBQUcsU0FBWEEsUUFBUUEsQ0FBSUMsSUFBcUI7RUFBQSxPQUFvQjtJQUN6REMsS0FBSyxFQUFFRCxJQUFJLENBQUNFLFNBQVM7SUFDckJDLEtBQUssRUFBRUgsSUFBSSxDQUFDRSxTQUFTO0lBQ3JCRSxPQUFPLEVBQUVKLElBQUksQ0FBQ0ssWUFBWTtJQUMxQjtJQUNBQyxVQUFVLEVBQUUsQ0FBQ04sSUFBSSxDQUFDRSxTQUFTLEVBQUVGLElBQUksQ0FBQ08sU0FBUyxDQUFDLENBQUNDLE1BQU0sQ0FBQ0MsT0FBTyxDQUFDLENBQUNDLElBQUksQ0FBQyxHQUFHO0VEUHZFLENDUUM7QUFBQSxDQUFDO0FBRUY7QUFDQTtBQUNBLElBQU1DLGFBQWEsR0FBRyxTQUFoQkEsYUFBYUEsQ0FBSUMsS0FBd0IsRUFBd0I7RUFDckUsSUFBTUMsSUFBSSxHQUFHRCxLQUFLLENBQUNKLE1BQU0sQ0FBQyxVQUFDUixJQUFJO0lBQUEsT0FBS0EsSUFBSSxDQUFDYyxNQUFNO0VBQUEsRUFBQyxDQUFDQyxHQUFHLENBQUNoQixRQUFRLENBQUM7RUFDOUQsSUFBTWlCLE1BQU0sR0FBR0osS0FBSyxDQUFDSixNQUFNLENBQUMsVUFBQ1IsSUFBSTtJQUFBLE9BQUssQ0FBQ0EsSUFBSSxDQUFDYyxNQUFNO0VBQUEsRUFBQyxDQUFDQyxHQUFHLENBQUNoQixRQUFRLENBQUM7RUFDakUsSUFBTWtCLElBQUksR0FBdUIsRUFBRTtFQUNuQyxJQUFJSixJQUFJLENBQUM3RCxNQUFNLEVBQUVpRSxJQUFJLENBQUNDLElBQUksQ0FBQztJQUFFQyxHQUFHLEVBQUV6QyxVQUFVO0lBQUV1QixLQUFLLEVBQUV2QixVQUFVO0lBQUUwQyxPQUFPLEVBQUVQO0VBQUksQ0FBRSxDQUFDO0VBQ2pGLElBQUlHLE1BQU0sQ0FBQ2hFLE1BQU0sRUFBRWlFLElBQUksQ0FBQ0MsSUFBSSxDQUFDO0lBQUVDLEdBQUcsRUFBRXhDLFlBQVk7SUFBRXNCLEtBQUssRUFBRXRCLFlBQVk7SUFBRXlDLE9BQU8sRUFBRUo7RUFBTSxDQUFFLENBQUM7RUFDekYsT0FBT0MsSUFBSTtBQUNiLENBQUM7QUFFRCxJQUFNSSxlQUFlLEdBQXlCLFNBQXhDQSxlQUFlQSxDQUEwQkMsRUFjOUMsRUFBSTtFRHJCRCxJQ1FGQyxHQUFHLEdBV0lELEVBRVIsQ0FiQ0MsR0FBRztJQUNIQyxTQUFTLEdBVUZGLEVBRVIsQ0FaQ0UsU0FBUztJQUFBQyxPQUFBLEdBVUZILEVBRVIsQ0FYQ2pDLElBQUk7SUFBSkEsSUFBSSxHQUFBb0MsT0FBQSxjQUFHLE9BQU8sR0FBQUEsT0FBQTtJQUNkeEIsS0FBSyxHQVFFcUIsRUFFUixDQVZDckIsS0FBSztJQUFBeUIsY0FBQSxHQVFFSixFQUVSLENBVENLLFdBQVc7SUFBWEEsV0FBVyxHQUFBRCxjQUFBLGNBQUczQyxtQkFBbUIsR0FBQTJDLGNBQUE7SUFDakNULElBQUksR0FNR0ssRUFFUixDQVJDTCxJQUFJO0lBQUFXLFdBQUEsR0FNR04sRUFFUixDQVBDTyxRQUFRO0lBQVJBLFFBQVEsR0FBQUQsV0FBQSxjQUFHOUMsaUJBQWlCLEdBQUE4QyxXQUFBO0lBQUFFLFNBQUEsR0FLckJSLEVBRVIsQ0FOQ1MsTUFBTTtJQUFOQSxNQUFNLEdBQUFELFNBQUEsY0FBRyxJQUFJLEdBQUFBLFNBQUE7SUFBQUUsb0JBQUEsR0FJTlYsRUFFUixDQUxDVyxpQkFBaUI7SUFBakJBLGlCQUFpQixHQUFBRCxvQkFBQSxjQUFHaEQsMEJBQTBCLEdBQUFnRCxvQkFBQTtJQUFBRSxjQUFBLEdBR3ZDWixFQUVSLENBSkNhLFdBQVc7SUFBWEEsV0FBVyxHQUFBRCxjQUFBLGNBQUdqRCxhQUFhLEdBQUFpRCxjQUFBO0lBQzNCRSxPQUFPLEdBQ0FkLEVBRVIsQ0FIQ2MsT0FBTztJQUNQQyxPQUFPLEdBQUFmLEVBRVIsQ0FGQ2UsT0FBTztJQUNKQyxJQUFJLEdBQUFsRyxNQUFBLENBQUFrRixFQUFBLEVBYnNDLENBQUEsS0FBQSxFQUFBLFdBQUEsRUFBQSxNQUFBLEVBQUEsT0FBQSxFQUFBLGFBQUEsRUFBQSxNQUFBLEVBQUEsVUFBQSxFQUFBLFFBQUEsRUFBQSxtQkFBQSxFQUFBLGFBQUEsRUFBQSxTQUFBLEVBQUEsU0FBQSxDQWM5QyxDQURRO0VBRVAsSUFBTWlCLFdBQVcsR0FBRzlFLE9BQU8sQ0FBQztJQUFBLE9BQU1rRCxhQUFhLENBQUNNLElBQUksQ0FBQztFQUFBLEdBQUUsQ0FBQ0EsSUFBSSxDQUFDLENBQUM7RUFDOUQsSUFBTXVCLFNBQVMsR0FBRy9FLE9BQU8sQ0FBQztJQUFBLE9BQU13RCxJQUFJLENBQUNGLEdBQUcsQ0FBQyxVQUFDZixJQUFJO01BQUEsT0FBS0EsSUFBSSxDQUFDRSxTQUFTO0lBQUEsRUFBQztFQUFBLEdBQUUsQ0FBQ2UsSUFBSSxDQUFDLENBQUM7RUFDM0UsSUFBTXdCLGFBQWEsR0FBR2hGLE9BQU8sQ0FBQyxZQUFLO0lBQ2pDLElBQU1zRCxHQUFHLEdBQUcsSUFBSTJCLEdBQUcsQ0FBQSxDQUF3QjtJQUMzQ3pCLElBQUksQ0FBQzBCLE9BQU8sQ0FBQyxVQUFDM0MsSUFBSTtNQUFBLE9BQUtlLEdBQUcsQ0FBQzZCLEdBQUcsQ0FBQzVDLElBQUksQ0FBQ0UsU0FBUyxFQUFFSCxRQUFRLENBQUNDLElBQUksQ0FBQyxDQUFDO0lBQUEsRUFBQztJQUMvRCxPQUFPZSxHQUFHO0VBQ1osQ0FBQyxFQUFFLENBQUNFLElBQUksQ0FBQyxDQUFDO0VBRVYsSUFBQTRCLFNBQUEsR0FBd0JuRixRQUFRLENBQUMsS0FBSyxDQUFDO0lBQUFvRixVQUFBLEdBQUFDLGNBQUEsQ0FBQUYsU0FBQTtJQUFoQ0csSUFBSSxHQUFBRixVQUFBO0lBQUVHLE9BQU8sR0FBQUgsVUFBQTtFQUNwQixJQUFBSSxVQUFBLEdBQThCeEYsUUFBUSxDQUFDLEVBQUUsQ0FBQztJQUFBeUYsVUFBQSxHQUFBSixjQUFBLENBQUFHLFVBQUE7SUFBbkNFLE9BQU8sR0FBQUQsVUFBQTtJQUFFRSxVQUFVLEdBQUFGLFVBQUE7RUFDMUI7RUFDQTtFQUNBO0VBQ0EsSUFBQUcsVUFBQSxHQUF3QjVGLFFBQVEsQ0FBVyxFQUFFLENBQUM7SUFBQTZGLFVBQUEsR0FBQVIsY0FBQSxDQUFBTyxVQUFBO0lBQXZDRSxJQUFJLEdBQUFELFVBQUE7SUFBRUUsT0FBTyxHQUFBRixVQUFBO0VBQ3BCLElBQUFHLFVBQUEsR0FBa0NoRyxRQUFRLENBQVcsRUFBRSxDQUFDO0lBQUFpRyxVQUFBLEdBQUFaLGNBQUEsQ0FBQVcsVUFBQTtJQUFqREUsU0FBUyxHQUFBRCxVQUFBO0lBQUVFLFlBQVksR0FBQUYsVUFBQTtFQUU5QjtFQUNBLElBQU1HLFVBQVUsR0FBR04sSUFBSSxDQUFDeEcsTUFBTSxLQUFLLENBQUM7RUFDcEM7RUFDQTtFQUNBLElBQU0rRyxTQUFTLEdBQUdoQyxNQUFNLElBQUlxQixPQUFPLENBQUNZLElBQUksQ0FBQSxDQUFFLENBQUNoSCxNQUFNLEdBQUcsQ0FBQztFQUVyRCxJQUFNaUgsWUFBWSxHQUFHMUcsV0FBVyxDQUFDLFVBQUMyRyxXQUFtQixFQUFFQyxNQUFvQixFQUFJO0lBQzdFLElBQU1DLElBQUksR0FBR0YsV0FBVyxDQUFDRixJQUFJLENBQUEsQ0FBRSxDQUFDSyxXQUFXLENBQUEsQ0FBRTtJQUM3QyxJQUFJLENBQUNELElBQUksRUFBRSxPQUFPLElBQUk7SUFDdEIsSUFBTUUsTUFBTSxHQUFHSCxNQUFzQjtJQUNyQyxPQUFPLE9BQU9HLE1BQU0sQ0FBQ2hFLFVBQVUsS0FBSyxRQUFRLEdBQ3hDZ0UsTUFBTSxDQUFDaEUsVUFBVSxDQUFDK0QsV0FBVyxDQUFBLENBQUUsQ0FBQ0UsUUFBUSxDQUFDSCxJQUFJLENBQUMsR0FDOUMsS0FBSztFQUNYLENBQUMsRUFBRSxFQUFFLENBQUM7RUFFTjVHLG1CQUFtQixDQUNqQitELEdBQUcsRUFDSDtJQUFBLE9BQU87TUFDTGlELEtBQUssRUFBRSxTQUFQQSxLQUFLQSxDQUFBLEVBQU87UUFDVmYsT0FBTyxDQUFDLEVBQUUsQ0FBQztRQUNYSSxZQUFZLENBQUMsRUFBRSxDQUFDO01BQ2xCLENBQUM7TUFDRFksS0FBSyxFQUFFLFNBQVBBLEtBQUtBLENBQUEsRUFBTztRQUNWaEIsT0FBTyxDQUFDLEVBQUUsQ0FBQztRQUNYSSxZQUFZLENBQUMsRUFBRSxDQUFDO1FBQ2hCeEIsT0FBTyxLQUFBLElBQUEsSUFBUEEsT0FBTyxLQUFBLEtBQUEsQ0FBQSxHQUFBLEtBQUEsQ0FBQSxHQUFQQSxPQUFPLENBQUcsRUFBRSxDQUFDO01BQ2Y7SUR6QkYsQ0MwQkM7RUFBQSxDQUFDLEVBQ0YsQ0FBQ0EsT0FBTyxDQUFDLENBQ1Y7RUFFRCxJQUFNcUMsa0JBQWtCLEdBQUduSCxXQUFXLENBQ3BDLFVBQUNvSCxJQUFpQixFQUFJO0lBQ3BCLElBQU1DLFVBQVUsR0FBRyxDQUFDQyxLQUFLLENBQUNDLE9BQU8sQ0FBQ0gsSUFBSSxDQUFDLEdBQUdBLElBQUksR0FBRyxFQUFFLEVBQUU1RCxHQUFHLENBQUNnRSxNQUFNLENBQUM7SUFDaEU7SUFDQTtJQUNBLElBQU1DLFFBQVEsR0FBR0osVUFBVSxDQUFDNUgsTUFBTSxLQUFLd0YsU0FBUyxDQUFDeEYsTUFBTTtJQUN2RHlHLE9BQU8sQ0FBQ3VCLFFBQVEsR0FBRyxFQUFFLEdBQUdKLFVBQVUsQ0FBQztFQUNyQyxDQUFDLEVBQ0QsQ0FBQ3BDLFNBQVMsQ0FBQyxDQUNaO0VBRUQsSUFBTXlDLGNBQWMsR0FBRzFILFdBQVcsQ0FBQyxZQUFLO0lBQ3RDO0lBQ0FrRyxPQUFPLENBQUMsRUFBRSxDQUFDO0VBQ2IsQ0FBQyxFQUFFLEVBQUUsQ0FBQztFQUVOLElBQU15QixXQUFXLEdBQUczSCxXQUFXLENBQUMsWUFBSztJQUNuQ3NHLFlBQVksQ0FBQ0wsSUFBSSxDQUFDO0lBQ2xCcEIsT0FBTyxDQUFDb0IsSUFBSSxDQUFDO0lBQ2JQLE9BQU8sQ0FBQyxLQUFLLENBQUM7RUFDaEIsQ0FBQyxFQUFFLENBQUNPLElBQUksRUFBRXBCLE9BQU8sQ0FBQyxDQUFDO0VBRW5CLElBQU0rQyxXQUFXLEdBQUc1SCxXQUFXLENBQUMsWUFBSztJQUNuQ2tHLE9BQU8sQ0FBQyxFQUFFLENBQUM7SUFDWEksWUFBWSxDQUFDLEVBQUUsQ0FBQztJQUNoQnhCLE9BQU8sS0FBQSxJQUFBLElBQVBBLE9BQU8sS0FBQSxLQUFBLENBQUEsR0FBQSxLQUFBLENBQUEsR0FBUEEsT0FBTyxDQUFHLEVBQUUsQ0FBQztFQUNmLENBQUMsRUFBRSxDQUFDQSxPQUFPLENBQUMsQ0FBQztFQUViLElBQU0rQyxnQkFBZ0IsR0FBRzdILFdBQVcsQ0FDbEMsVUFBQzhILFFBQWlCLEVBQUk7SUFDcEJwQyxPQUFPLENBQUNvQyxRQUFRLENBQUM7SUFDakIsSUFBSUEsUUFBUSxFQUFFO0lBQ2Q7SUFDQTVCLE9BQU8sQ0FBQ0csU0FBUyxDQUFDO0lBQ2xCUCxVQUFVLENBQUMsRUFBRSxDQUFDO0VBQ2hCLENBQUMsRUFDRCxDQUFDTyxTQUFTLENBQUMsQ0FDWjtFQUVELElBQU0wQixTQUFTLEdBQUcvSCxXQUFXLENBQUMsVUFBQzRHLE1BQW9CLEVBQUVvQixPQUFnQixFQUFJO0lBQ3ZFLElBQU1DLElBQUksR0FBRyxPQUFPckIsTUFBTSxDQUFDbEUsS0FBSyxLQUFLLFFBQVEsR0FBR2tFLE1BQU0sQ0FBQ2xFLEtBQUssR0FBRyxFQUFFO0lBQ2pFLE9BQ0U1QyxLQUFBLENBQUNTLElBQUksRUFBQTtNQUFDMkgsS0FBSyxFQUFDLFFBQVE7TUFBQ0MsT0FBTyxFQUFDLGVBQWU7TUFBQ0MsR0FBRyxFQUFFLENBQUM7TUFBRW5FLFNBQVMsS0FBQWxELE1BQUEsQ0FBS0YsUUFBUSxVQUFPO01BQUF3SCxRQUFBLEVBQUEsQ0FDaEZ2SSxLQUFBLENBQUNTLElBQUksRUFBQTtRQUFDMkgsS0FBSyxFQUFDLFFBQVE7UUFBQ0UsR0FBRyxFQUFFLENBQUM7UUFBRW5FLFNBQVMsS0FBQWxELE1BQUEsQ0FBS0YsUUFBUSxlQUFZO1FBQUF3SCxRQUFBLEVBQUEsQ0FDNUR6QixNQUFNLENBQUMvRCxPQUFPLElBQ2JqRCxJQUFBLENBQUEsS0FBQSxFQUFBO1VBQ0UwSSxHQUFHLEVBQUUxQixNQUFNLENBQUMvRCxPQUFPO1VBQ25CMEYsR0FBRyxFQUFFTixJQUFJO1VBQ1RPLEtBQUssRUFBRXRILFNBQVM7VUFDaEJ1SCxNQUFNLEVBQUV2SCxTQUFTO1VBQ2pCK0MsU0FBUyxFQUFFaEQ7UUFBUSxDQUFBLENBRXRCLEVBQ0RyQixJQUFBLENBQUNlLGVBQWUsRUFBQTtVQUFDbUIsSUFBSSxFQUFDLElBQUk7VUFBQ21DLFNBQVMsS0FBQWxELE1BQUEsQ0FBS0YsUUFBUSxlQUFZO1VBQUF3SCxRQUFBLEVBQzFEekIsTUFBTSxDQUFDbEU7UUFBSyxDQUFBLENBQ0c7TUFBQSxDQUFBLENBQ2IsRUFDUDlDLElBQUEsQ0FBQ1MsUUFBUSxFQUFBO1FBQUMySCxPQUFPLEVBQUVBLE9BQU87UUFBRVUsUUFBUSxFQUFBLElBQUE7UUFBQ3pFLFNBQVMsS0FBQWxELE1BQUEsQ0FBS0YsUUFBUTtNQUFhLENBQUEsQ0FBSTtJQUFBLENBQUEsQ0FDdkU7RUFFWCxDQUFDLEVBQUUsRUFBRSxDQUFDO0VBRU47RUFDQTtFQUNBO0VBQ0E7RUFDQSxJQUFNOEgsV0FBVyxHQUFHM0ksV0FBVyxDQUFDLFlBQUs7SUFDbkMsSUFBSXFHLFNBQVMsQ0FBQzVHLE1BQU0sS0FBSyxDQUFDLEVBQUU7TUFDMUI7TUFDQTtNQUNBO01BQ0EsT0FDRUcsSUFBQSxDQUFDYyxjQUFjLEVBQUE7UUFBQ29CLElBQUksRUFBQyxJQUFJO1FBQUNDLEtBQUssRUFBQyxTQUFTO1FBQUNrQyxTQUFTLEtBQUFsRCxNQUFBLENBQUtGLFFBQVEsWUFBUztRQUFBd0gsUUFBQSxFQUN0RS9EO01BQVEsQ0FBQSxDQUNNO0lBRXJCO0lBQ0EsSUFBTXNFLEtBQUssR0FBRzFELGFBQWEsQ0FBQzJELEdBQUcsQ0FBQ3hDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM3QyxJQUFNeUMsVUFBVSxHQUFHRixLQUFLLEdBQUdBLEtBQUssQ0FBQ2xHLEtBQUssR0FBRzJELFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFDckQsSUFBTTBDLEtBQUssR0FBRzFDLFNBQVMsQ0FBQzVHLE1BQU0sR0FBRyxDQUFDO0lBQ2xDLE9BQ0VLLEtBQUEsQ0FBQ1ksY0FBYyxFQUFBO01BQUNvQixJQUFJLEVBQUMsSUFBSTtNQUFDbUMsU0FBUyxLQUFBbEQsTUFBQSxDQUFLRixRQUFRLFlBQVM7TUFBQXdILFFBQUEsRUFBQSxDQUN2RHpJLElBQUEsQ0FBQSxNQUFBLEVBQUE7UUFBTXFFLFNBQVMsS0FBQWxELE1BQUEsQ0FBS0YsUUFBUSxrQkFBZTtRQUFBd0gsUUFBQSxFQUFHUztNQUFVLENBQUEsQ0FBUSxFQUMvREMsS0FBSyxHQUFHLENBQUMsSUFBSW5KLElBQUEsQ0FBQSxNQUFBLEVBQUE7UUFBTXFFLFNBQVMsS0FBQWxELE1BQUEsQ0FBS0YsUUFBUSxpQkFBYztRQUFBd0gsUUFBQSxFQUFHakcsV0FBVyxDQUFDMkcsS0FBSztNQUFDLENBQUEsQ0FBUTtJQUFBLENBQUEsQ0FDdEU7RUFFckIsQ0FBQyxFQUFFLENBQUN6RSxRQUFRLEVBQUUrQixTQUFTLEVBQUVuQixhQUFhLENBQUMsQ0FBQztFQUV4QyxPQUNFdEYsSUFBQSxDQUFDYSxNQUFNLEVBQUF2QixNQUFBLENBQUE4SixNQUFBLENBQUEsQ0FBQSxDQUFBLEVBQ0RqRSxJQUFJLEVBQUE7SUFDUmtFLFFBQVEsRUFBQSxJQUFBO0lBQ1JuSCxJQUFJLEVBQUVBLElBQUk7SUFDVlksS0FBSyxFQUFFQSxLQUFLO0lBQ1owQixXQUFXLEVBQUVBLFdBQVc7SUFDeEJILFNBQVMsRUFBRXJELE9BQU8sQ0FBQ0MsUUFBUSxFQUFFb0QsU0FBUyxDQUFDO0lBQ3ZDaUYsY0FBYyxFQUFFcEksU0FBUztJQUN6QnFJLG1CQUFtQixFQUFFbkksZUFBZTtJQUNwQzRCLEtBQUssRUFBRXFELElBQUk7SUFDWFIsSUFBSSxFQUFFQSxJQUFJO0lBQ1YyRCxZQUFZLEVBQUV2QixnQkFBZ0I7SUFDOUJ3QixRQUFRLEVBQUVsQyxrQkFBa0I7SUFDNUJtQyxVQUFVLEVBQUU5RSxNQUFNO0lBQ2xCRSxpQkFBaUIsRUFBRUEsaUJBQWlCO0lBQ3BDaUMsV0FBVyxFQUFFZCxPQUFPO0lBQ3BCMEQsY0FBYyxFQUFFekQsVUFBVTtJQUMxQlksWUFBWSxFQUFFQSxZQUFZO0lBQzFCN0MsT0FBTyxFQUFFbUIsV0FBVztJQUNwQndFLFdBQVcsRUFDVGhELFNBQVMsR0FBR2lELFNBQVMsR0FDbkIzSixLQUFBLENBQUEsUUFBQSxFQUFBO01BQ0U0SixJQUFJLEVBQUMsUUFBUTtNQUNiekYsU0FBUyxFQUFFckQsT0FBTyxJQUFBRyxNQUFBLENBQUlGLFFBQVEsWUFBUzBGLFVBQVUsT0FBQXhGLE1BQUEsQ0FBT0YsUUFBUSxtQkFBZ0IsQ0FBQztNQUNqRjhJLE9BQU8sRUFBRWpDLGNBQWM7TUFBQVcsUUFBQSxFQUFBLENBRXZCekksSUFBQSxDQUFDZSxlQUFlLEVBQUE7UUFBQ21CLElBQUksRUFBQyxJQUFJO1FBQUF1RyxRQUFBLEVBQUUvRDtNQUFRLENBQUEsQ0FBbUIsRUFDdkQxRSxJQUFBLENBQUNTLFFBQVEsRUFBQTtRQUFDMkgsT0FBTyxFQUFFekIsVUFBVTtRQUFFbUMsUUFBUSxFQUFBLElBQUE7UUFBQ3pFLFNBQVMsS0FBQWxELE1BQUEsQ0FBS0YsUUFBUTtNQUFhLENBQUEsQ0FBSTtJQUFBLENBQUEsQ0FFbEY7SUFFSCtJLFlBQVksRUFBRWhGLFdBQVc7SUFDekIrRCxXQUFXLEVBQUVBLFdBQVc7SUFDeEJrQixZQUFZLEVBQUUsU0FBZEEsWUFBWUEsQ0FBR2pELE1BQU0sRUFBRWtELElBQUk7TUFBQSxPQUFLL0IsU0FBUyxDQUFDbkIsTUFBc0IsRUFBRWtELElBQUksQ0FBQ0MsUUFBUSxDQUFDO0lBQUE7SUFDaEZDLFdBQVcsRUFDVGxLLEtBQUEsQ0FBQ1MsSUFBSSxFQUFBO01BQUM2SCxHQUFHLEVBQUUsQ0FBQztNQUFFbkUsU0FBUyxLQUFBbEQsTUFBQSxDQUFLRixRQUFRLGFBQVU7TUFBQXdILFFBQUEsRUFBQSxDQUM1Q3pJLElBQUEsQ0FBQ1EsTUFBTSxFQUFBO1FBQUMyQixLQUFLLEVBQUMsTUFBTTtRQUFDRCxJQUFJLEVBQUMsT0FBTztRQUFDSSxLQUFLLEVBQUVJLGdCQUFnQjtRQUFFcUgsT0FBTyxFQUFFL0IsV0FBVztRQUFBUyxRQUFBLEVBQzVFaEg7TUFBVyxDQUFBLENBQ0wsRUFDVHpCLElBQUEsQ0FBQ1EsTUFBTSxFQUFBO1FBQUMyQixLQUFLLEVBQUMsU0FBUztRQUFDRCxJQUFJLEVBQUMsT0FBTztRQUFDSSxLQUFLLEVBQUVJLGdCQUFnQjtRQUFFcUgsT0FBTyxFQUFFaEMsV0FBVztRQUFBVSxRQUFBLEVBQy9FL0c7TUFBVyxDQUFBLENBQ0w7SUFBQSxDQUFBO0VBQ0osQ0FBQSxDQUFBLENBRVQ7QUFFTixDQUFDO0FBRUQsT0FBTyxJQUFNMkksV0FBVyxnQkFBR2xLLElBQUksQ0FBQytELGVBQWUsQ0FBQyIsImZpbGUiOiJidXNpbmVzcy9GaWx0ZXIvQXNzZXQvQXNzZXQuanMiLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgX19yZXN0ID0gKHRoaXMgJiYgdGhpcy5fX3Jlc3QpIHx8IGZ1bmN0aW9uIChzLCBlKSB7XG4gICAgdmFyIHQgPSB7fTtcbiAgICBmb3IgKHZhciBwIGluIHMpIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwocywgcCkgJiYgZS5pbmRleE9mKHApIDwgMClcbiAgICAgICAgdFtwXSA9IHNbcF07XG4gICAgaWYgKHMgIT0gbnVsbCAmJiB0eXBlb2YgT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scyA9PT0gXCJmdW5jdGlvblwiKVxuICAgICAgICBmb3IgKHZhciBpID0gMCwgcCA9IE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMocyk7IGkgPCBwLmxlbmd0aDsgaSsrKSB7XG4gICAgICAgICAgICBpZiAoZS5pbmRleE9mKHBbaV0pIDwgMCAmJiBPYmplY3QucHJvdG90eXBlLnByb3BlcnR5SXNFbnVtZXJhYmxlLmNhbGwocywgcFtpXSkpXG4gICAgICAgICAgICAgICAgdFtwW2ldXSA9IHNbcFtpXV07XG4gICAgICAgIH1cbiAgICByZXR1cm4gdDtcbn07XG5pbXBvcnQgeyBqc3ggYXMgX2pzeCwganN4cyBhcyBfanN4cyB9IGZyb20gXCJyZWFjdC9qc3gtcnVudGltZVwiO1xuaW1wb3J0IHsgbWVtbywgdXNlQ2FsbGJhY2ssIHVzZUltcGVyYXRpdmVIYW5kbGUsIHVzZU1lbW8sIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgQnV0dG9uIH0gZnJvbSAnLi4vLi4vLi4vY29tcG9uZW50cy9CdXR0b24nO1xuaW1wb3J0IHsgQ2hlY2tib3ggfSBmcm9tICcuLi8uLi8uLi9jb21wb25lbnRzL0NoZWNrYm94JztcbmltcG9ydCB7IEVtcHR5IH0gZnJvbSAnLi4vLi4vLi4vY29tcG9uZW50cy9FbXB0eSc7XG5pbXBvcnQgeyBGbGV4IH0gZnJvbSAnLi4vLi4vLi4vY29tcG9uZW50cy9GbGV4JztcbmltcG9ydCB7IEljb25zIH0gZnJvbSAnLi4vLi4vLi4vY29tcG9uZW50cy9JY29ucyc7XG5pbXBvcnQgeyBTZWxlY3QgfSBmcm9tICcuLi8uLi8uLi9jb21wb25lbnRzL1NlbGVjdCc7XG5pbXBvcnQgeyBUeXBvZ3JhcGh5Qm9keSwgVHlwb2dyYXBoeUxhYmVsIH0gZnJvbSAnLi4vLi4vLi4vY29tcG9uZW50cy9UeXBvZ3JhcGh5JztcbmltcG9ydCB7IGpvaW5DbHMgfSBmcm9tICcuLi8uLi8uLi91dGlscy9jbGFzc25hbWVzJztcbmNvbnN0IFdSQVBfQ0xTID0gJ29tLWFzc2V0LWZpbHRlcic7XG4vLyBUaGUgcGFuZWwgaXMgcG9ydGFsZWQgdG8gPGJvZHk+LCBzbyBwYW5lbC1zY29wZWQgb3ZlcnJpZGVzIGFyZSBrZXllZCBvZmYgdGhpc1xuLy8gY2xhc3MgKHBhc3NlZCBhcyBgcGFuZWxDbGFzc05hbWVgKSByYXRoZXIgdGhhbiB0aGUgdHJpZ2dlciByb290LlxuY29uc3QgUEFORUxfQ0xTID0gYCR7V1JBUF9DTFN9LXBhbmVsYDtcbmNvbnN0IEdST1VQX0xBQkVMX0NMUyA9IGAke1dSQVBfQ0xTfV9fZ3JvdXAtbGFiZWxgO1xuY29uc3QgSUNPTl9DTFMgPSBgJHtXUkFQX0NMU30taWNvbmA7XG5jb25zdCBJQ09OX1NJWkUgPSAyNDtcbmNvbnN0IEZJQVRfR1JPVVAgPSAnQ2FzaCc7XG5jb25zdCBDUllQVE9fR1JPVVAgPSAnU3RhYmxlY29pbnMnO1xuY29uc3QgUkVTRVRfTEFCRUwgPSAnUmVzZXQnO1xuY29uc3QgQVBQTFlfTEFCRUwgPSAnQXBwbHknO1xuY29uc3QgREVGQVVMVF9BTExfTEFCRUwgPSAnQWxsIGFzc2V0cyc7XG5jb25zdCBERUZBVUxUX1BMQUNFSE9MREVSID0gJ0Fzc2V0JztcbmNvbnN0IERFRkFVTFRfU0VBUkNIX1BMQUNFSE9MREVSID0gJ1NlYXJjaCc7XG5jb25zdCBERUZBVUxUX0VNUFRZID0gKF9qc3goRW1wdHksIHsgdmFyaWFudDogJ2ZpbGwnLCBpY29uOiBfanN4KEljb25zLCB7IG5hbWU6ICdzZWFyY2gnLCBzaXplOiAxNiwgY29sb3I6ICdjdXJyZW50Q29sb3InIH0pLCB0aXRsZTogJ05vIHJlc3VsdHMnLCBkZXNjcmlwdGlvbjogJ1RyeSBhIGRpZmZlcmVudCBuYW1lIG9yIGFkanVzdCB5b3VyIHNlYXJjaCBmaWx0ZXJzLicsIHN0eWxlOiB7IHBhZGRpbmc6IDAgfSB9KSk7XG5jb25zdCBNT1JFX1NVRkZJWCA9IChjb3VudCkgPT4gYCsgJHtjb3VudH0gbW9yZWA7XG5jb25zdCBGVUxMX1dJRFRIX1NUWUxFID0geyBmbGV4OiAxIH07XG5jb25zdCB0b09wdGlvbiA9IChpdGVtKSA9PiAoe1xuICAgIGxhYmVsOiBpdGVtLmFzc2V0TmFtZSxcbiAgICB2YWx1ZTogaXRlbS5hc3NldE5hbWUsXG4gICAgaWNvblVybDogaXRlbS5hc3NldEljb25VcmwsXG4gICAgLy8gTWF0Y2ggdGhlIHN5bWJvbCBhbmQgdGhlIGZ1bGwgbmFtZSByZWdhcmRsZXNzIG9mIHdoYXQgdGhlIHJvdyByZW5kZXJzLlxuICAgIHNlYXJjaFRleHQ6IFtpdGVtLmFzc2V0TmFtZSwgaXRlbS5hc3NldERlc2NdLmZpbHRlcihCb29sZWFuKS5qb2luKCcgJyksXG59KTtcbi8vIEZpYXQgYXNzZXRzIGJ1Y2tldCB1bmRlciBcIkNhc2hcIiwgdGhlIHJlc3QgdW5kZXIgXCJTdGFibGVjb2luc1wiLiBFbXB0eSBncm91cHNcbi8vIGFyZSBkcm9wcGVkIHNvIGEgZmlhdC1vbmx5IChvciBjcnlwdG8tb25seSkgbGlzdCBzaG93cyBhIHNpbmdsZSBoZWFkaW5nLlxuY29uc3QgdG9Hcm91cGVkRGF0YSA9IChpdGVtcykgPT4ge1xuICAgIGNvbnN0IGZpYXQgPSBpdGVtcy5maWx0ZXIoKGl0ZW0pID0+IGl0ZW0uaXNGaWF0KS5tYXAodG9PcHRpb24pO1xuICAgIGNvbnN0IGNyeXB0byA9IGl0ZW1zLmZpbHRlcigoaXRlbSkgPT4gIWl0ZW0uaXNGaWF0KS5tYXAodG9PcHRpb24pO1xuICAgIGNvbnN0IGRhdGEgPSBbXTtcbiAgICBpZiAoZmlhdC5sZW5ndGgpXG4gICAgICAgIGRhdGEucHVzaCh7IGtleTogRklBVF9HUk9VUCwgbGFiZWw6IEZJQVRfR1JPVVAsIG9wdGlvbnM6IGZpYXQgfSk7XG4gICAgaWYgKGNyeXB0by5sZW5ndGgpXG4gICAgICAgIGRhdGEucHVzaCh7IGtleTogQ1JZUFRPX0dST1VQLCBsYWJlbDogQ1JZUFRPX0dST1VQLCBvcHRpb25zOiBjcnlwdG8gfSk7XG4gICAgcmV0dXJuIGRhdGE7XG59O1xuY29uc3QgQXNzZXRGaWx0ZXJCYXNlID0gKF9hKSA9PiB7XG4gICAgdmFyIHsgcmVmLCBjbGFzc05hbWUsIHNpemUgPSAnc21hbGwnLCBsYWJlbCwgcGxhY2Vob2xkZXIgPSBERUZBVUxUX1BMQUNFSE9MREVSLCBkYXRhLCBhbGxMYWJlbCA9IERFRkFVTFRfQUxMX0xBQkVMLCBzZWFyY2ggPSB0cnVlLCBzZWFyY2hQbGFjZWhvbGRlciA9IERFRkFVTFRfU0VBUkNIX1BMQUNFSE9MREVSLCBzZWFyY2hFbXB0eSA9IERFRkFVTFRfRU1QVFksIG9uQXBwbHksIG9uUmVzZXQgfSA9IF9hLCByZXN0ID0gX19yZXN0KF9hLCBbXCJyZWZcIiwgXCJjbGFzc05hbWVcIiwgXCJzaXplXCIsIFwibGFiZWxcIiwgXCJwbGFjZWhvbGRlclwiLCBcImRhdGFcIiwgXCJhbGxMYWJlbFwiLCBcInNlYXJjaFwiLCBcInNlYXJjaFBsYWNlaG9sZGVyXCIsIFwic2VhcmNoRW1wdHlcIiwgXCJvbkFwcGx5XCIsIFwib25SZXNldFwiXSk7XG4gICAgY29uc3QgZ3JvdXBlZERhdGEgPSB1c2VNZW1vKCgpID0+IHRvR3JvdXBlZERhdGEoZGF0YSksIFtkYXRhXSk7XG4gICAgY29uc3QgYWxsVmFsdWVzID0gdXNlTWVtbygoKSA9PiBkYXRhLm1hcCgoaXRlbSkgPT4gaXRlbS5hc3NldE5hbWUpLCBbZGF0YV0pO1xuICAgIGNvbnN0IG9wdGlvbkJ5VmFsdWUgPSB1c2VNZW1vKCgpID0+IHtcbiAgICAgICAgY29uc3QgbWFwID0gbmV3IE1hcCgpO1xuICAgICAgICBkYXRhLmZvckVhY2goKGl0ZW0pID0+IG1hcC5zZXQoaXRlbS5hc3NldE5hbWUsIHRvT3B0aW9uKGl0ZW0pKSk7XG4gICAgICAgIHJldHVybiBtYXA7XG4gICAgfSwgW2RhdGFdKTtcbiAgICBjb25zdCBbb3Blbiwgc2V0T3Blbl0gPSB1c2VTdGF0ZShmYWxzZSk7XG4gICAgY29uc3QgW2tleXdvcmQsIHNldEtleXdvcmRdID0gdXNlU3RhdGUoJycpO1xuICAgIC8vIGB0ZW1wYCBpcyB0aGUgaW4tcGFuZWwgZHJhZnQ7IGBjb21taXR0ZWRgIGlzIHRoZSBsYXN0IEFwcGxpZWQgc2VsZWN0aW9uLlxuICAgIC8vIE9ubHkgQXBwbHkgcHJvbW90ZXMgYHRlbXBgIOKGkiBgY29tbWl0dGVkYCBhbmQgbm90aWZpZXMgdGhlIHBhcmVudC4gV2l0aCBhblxuICAgIC8vIFwiQWxsIGFzc2V0c1wiIHJvdywgXCJhbGwgc2VsZWN0ZWRcIiBpcyByZXByZXNlbnRlZCBieSBhbiBlbXB0eSBhcnJheS5cbiAgICBjb25zdCBbdGVtcCwgc2V0VGVtcF0gPSB1c2VTdGF0ZShbXSk7XG4gICAgY29uc3QgW2NvbW1pdHRlZCwgc2V0Q29tbWl0dGVkXSA9IHVzZVN0YXRlKFtdKTtcbiAgICAvLyBUaGUgXCJBbGwgYXNzZXRzXCIgcm93IGlzIGNoZWNrZWQgZXhhY3RseSB3aGVuIG5vdGhpbmcgc3BlY2lmaWMgaXMgc2VsZWN0ZWQuXG4gICAgY29uc3QgYWxsQ2hlY2tlZCA9IHRlbXAubGVuZ3RoID09PSAwO1xuICAgIC8vIFdoaWxlIHNlYXJjaGluZywgdGhlIFwiQWxsIGFzc2V0c1wiIHJvdyBpcyBtZWFuaW5nbGVzcyDigJQgaGlkZSBpdCBzbyBhXG4gICAgLy8gbm8tbWF0Y2ggc2VhcmNoIHNob3dzIHRoZSBlbXB0eSBzdGF0ZSBpbnN0ZWFkIG9mIGEgbG9uZSBcIkFsbCBhc3NldHNcIi5cbiAgICBjb25zdCBzZWFyY2hpbmcgPSBzZWFyY2ggJiYga2V5d29yZC50cmltKCkubGVuZ3RoID4gMDtcbiAgICBjb25zdCBmaWx0ZXJPcHRpb24gPSB1c2VDYWxsYmFjaygoc2VhcmNoVmFsdWUsIG9wdGlvbikgPT4ge1xuICAgICAgICBjb25zdCB0ZXJtID0gc2VhcmNoVmFsdWUudHJpbSgpLnRvTG93ZXJDYXNlKCk7XG4gICAgICAgIGlmICghdGVybSlcbiAgICAgICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgICBjb25zdCBtYXBwZWQgPSBvcHRpb247XG4gICAgICAgIHJldHVybiB0eXBlb2YgbWFwcGVkLnNlYXJjaFRleHQgPT09ICdzdHJpbmcnXG4gICAgICAgICAgICA/IG1hcHBlZC5zZWFyY2hUZXh0LnRvTG93ZXJDYXNlKCkuaW5jbHVkZXModGVybSlcbiAgICAgICAgICAgIDogZmFsc2U7XG4gICAgfSwgW10pO1xuICAgIHVzZUltcGVyYXRpdmVIYW5kbGUocmVmLCAoKSA9PiAoe1xuICAgICAgICBjbGVhcjogKCkgPT4ge1xuICAgICAgICAgICAgc2V0VGVtcChbXSk7XG4gICAgICAgICAgICBzZXRDb21taXR0ZWQoW10pO1xuICAgICAgICB9LFxuICAgICAgICByZXNldDogKCkgPT4ge1xuICAgICAgICAgICAgc2V0VGVtcChbXSk7XG4gICAgICAgICAgICBzZXRDb21taXR0ZWQoW10pO1xuICAgICAgICAgICAgb25SZXNldCA9PT0gbnVsbCB8fCBvblJlc2V0ID09PSB2b2lkIDAgPyB2b2lkIDAgOiBvblJlc2V0KFtdKTtcbiAgICAgICAgfSxcbiAgICB9KSwgW29uUmVzZXRdKTtcbiAgICBjb25zdCBoYW5kbGVTZWxlY3RDaGFuZ2UgPSB1c2VDYWxsYmFjaygobmV4dCkgPT4ge1xuICAgICAgICBjb25zdCBuZXh0VmFsdWVzID0gKEFycmF5LmlzQXJyYXkobmV4dCkgPyBuZXh0IDogW10pLm1hcChTdHJpbmcpO1xuICAgICAgICAvLyBTZWxlY3RpbmcgZXZlcnkgY29uY3JldGUgYXNzZXQgY29sbGFwc2VzIHRvIFwiYWxsXCIgKFtdKSwgbWF0Y2hpbmcgdGhlXG4gICAgICAgIC8vIGJhY2tlbmQgY29udmVudGlvbiB0aGF0IGVtcHR5ID09IG5vIGZpbHRlci5cbiAgICAgICAgY29uc3QgY29sbGFwc2UgPSBuZXh0VmFsdWVzLmxlbmd0aCA9PT0gYWxsVmFsdWVzLmxlbmd0aDtcbiAgICAgICAgc2V0VGVtcChjb2xsYXBzZSA/IFtdIDogbmV4dFZhbHVlcyk7XG4gICAgfSwgW2FsbFZhbHVlc10pO1xuICAgIGNvbnN0IGhhbmRsZUFsbENsaWNrID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgICAgICAvLyBUaGUgXCJBbGwgYXNzZXRzXCIgcm93IGlzIGV4Y2x1c2l2ZTogdHVybmluZyBpdCBvbiBjbGVhcnMgc3BlY2lmaWMgcGlja3MuXG4gICAgICAgIHNldFRlbXAoW10pO1xuICAgIH0sIFtdKTtcbiAgICBjb25zdCBoYW5kbGVBcHBseSA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICAgICAgc2V0Q29tbWl0dGVkKHRlbXApO1xuICAgICAgICBvbkFwcGx5KHRlbXApO1xuICAgICAgICBzZXRPcGVuKGZhbHNlKTtcbiAgICB9LCBbdGVtcCwgb25BcHBseV0pO1xuICAgIGNvbnN0IGhhbmRsZVJlc2V0ID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgICAgICBzZXRUZW1wKFtdKTtcbiAgICAgICAgc2V0Q29tbWl0dGVkKFtdKTtcbiAgICAgICAgb25SZXNldCA9PT0gbnVsbCB8fCBvblJlc2V0ID09PSB2b2lkIDAgPyB2b2lkIDAgOiBvblJlc2V0KFtdKTtcbiAgICB9LCBbb25SZXNldF0pO1xuICAgIGNvbnN0IGhhbmRsZU9wZW5DaGFuZ2UgPSB1c2VDYWxsYmFjaygobmV4dE9wZW4pID0+IHtcbiAgICAgICAgc2V0T3BlbihuZXh0T3Blbik7XG4gICAgICAgIGlmIChuZXh0T3BlbilcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgLy8gQ2xvc2luZyB3aXRob3V0IEFwcGx5IGRpc2NhcmRzIHRoZSBkcmFmdC5cbiAgICAgICAgc2V0VGVtcChjb21taXR0ZWQpO1xuICAgICAgICBzZXRLZXl3b3JkKCcnKTtcbiAgICB9LCBbY29tbWl0dGVkXSk7XG4gICAgY29uc3QgcmVuZGVyUm93ID0gdXNlQ2FsbGJhY2soKG9wdGlvbiwgY2hlY2tlZCkgPT4ge1xuICAgICAgICBjb25zdCB0ZXh0ID0gdHlwZW9mIG9wdGlvbi5sYWJlbCA9PT0gJ3N0cmluZycgPyBvcHRpb24ubGFiZWwgOiAnJztcbiAgICAgICAgcmV0dXJuIChfanN4cyhGbGV4LCB7IGFsaWduOiAnY2VudGVyJywganVzdGlmeTogJ3NwYWNlLWJldHdlZW4nLCBnYXA6IDgsIGNsYXNzTmFtZTogYCR7V1JBUF9DTFN9X19yb3dgLCBjaGlsZHJlbjogW19qc3hzKEZsZXgsIHsgYWxpZ246ICdjZW50ZXInLCBnYXA6IDgsIGNsYXNzTmFtZTogYCR7V1JBUF9DTFN9X19yb3ctbWFpbmAsIGNoaWxkcmVuOiBbb3B0aW9uLmljb25VcmwgJiYgKF9qc3goXCJpbWdcIiwgeyBzcmM6IG9wdGlvbi5pY29uVXJsLCBhbHQ6IHRleHQsIHdpZHRoOiBJQ09OX1NJWkUsIGhlaWdodDogSUNPTl9TSVpFLCBjbGFzc05hbWU6IElDT05fQ0xTIH0pKSwgX2pzeChUeXBvZ3JhcGh5TGFiZWwsIHsgc2l6ZTogJ21kJywgY2xhc3NOYW1lOiBgJHtXUkFQX0NMU31fX3Jvdy1uYW1lYCwgY2hpbGRyZW46IG9wdGlvbi5sYWJlbCB9KV0gfSksIF9qc3goQ2hlY2tib3gsIHsgY2hlY2tlZDogY2hlY2tlZCwgcmVhZE9ubHk6IHRydWUsIGNsYXNzTmFtZTogYCR7V1JBUF9DTFN9X19yb3ctY2hlY2tgIH0pXSB9KSk7XG4gICAgfSwgW10pO1xuICAgIC8vIFRoZSB0cmlnZ2VyIHJlZmxlY3RzIHRoZSBDT01NSVRURUQgc2VsZWN0aW9uIG9ubHkg4oCUIGB0ZW1wYCBpcyB0aGUgaW4tcGFuZWxcbiAgICAvLyBkcmFmdCBhbmQgbXVzdCBub3QgbGVhayBpbnRvIHRoZSB0cmlnZ2VyIGJlZm9yZSBBcHBseS4gQW4gZW1wdHkgYGNvbW1pdHRlZGBcbiAgICAvLyBtZWFucyBcIkFsbCBhc3NldHNcIi4gYHJlbmRlclZhbHVlYCBzaG9ydC1jaXJjdWl0cyBTZWxlY3QncyBvd24gcGxhY2Vob2xkZXJcbiAgICAvLyBoYW5kbGluZywgc28gdGhlIGVtcHR5IHN0YXRlIG11c3QgcmV0dXJuIHRoZSBcIkFsbCBhc3NldHNcIiB0ZXh0IGV4cGxpY2l0bHkuXG4gICAgY29uc3QgcmVuZGVyVmFsdWUgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgICAgIGlmIChjb21taXR0ZWQubGVuZ3RoID09PSAwKSB7XG4gICAgICAgICAgICAvLyBcIkFsbCBhc3NldHNcIiBpcyB0aGUgZGVmYXVsdCBmaWx0ZXIgdmFsdWUsIG5vdCBhbiBlbXB0eSBwbGFjZWhvbGRlci4gVGhlXG4gICAgICAgICAgICAvLyB0cmlnZ2VyJ3MgZW1wdHkgYHZhbHVlYCBtYWtlcyBTZWxlY3Qgd3JhcCB0aGlzIGluIGl0cyBncmV5IHBsYWNlaG9sZGVyXG4gICAgICAgICAgICAvLyBjbGFzcywgc28gZm9yY2UgdGhlIGRlZmF1bHQgZGFyayB0ZXh0IHRvIG1hdGNoIERhdGVSYW5nZS5cbiAgICAgICAgICAgIHJldHVybiAoX2pzeChUeXBvZ3JhcGh5Qm9keSwgeyBzaXplOiAnbWQnLCBjb2xvcjogJ2RlZmF1bHQnLCBjbGFzc05hbWU6IGAke1dSQVBfQ0xTfV9fdmFsdWVgLCBjaGlsZHJlbjogYWxsTGFiZWwgfSkpO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IGZpcnN0ID0gb3B0aW9uQnlWYWx1ZS5nZXQoY29tbWl0dGVkWzBdKTtcbiAgICAgICAgY29uc3QgZmlyc3RMYWJlbCA9IGZpcnN0ID8gZmlyc3QubGFiZWwgOiBjb21taXR0ZWRbMF07XG4gICAgICAgIGNvbnN0IGV4dHJhID0gY29tbWl0dGVkLmxlbmd0aCAtIDE7XG4gICAgICAgIHJldHVybiAoX2pzeHMoVHlwb2dyYXBoeUJvZHksIHsgc2l6ZTogJ21kJywgY2xhc3NOYW1lOiBgJHtXUkFQX0NMU31fX3ZhbHVlYCwgY2hpbGRyZW46IFtfanN4KFwic3BhblwiLCB7IGNsYXNzTmFtZTogYCR7V1JBUF9DTFN9X192YWx1ZS1sYWJlbGAsIGNoaWxkcmVuOiBmaXJzdExhYmVsIH0pLCBleHRyYSA+IDAgJiYgX2pzeChcInNwYW5cIiwgeyBjbGFzc05hbWU6IGAke1dSQVBfQ0xTfV9fdmFsdWUtbW9yZWAsIGNoaWxkcmVuOiBNT1JFX1NVRkZJWChleHRyYSkgfSldIH0pKTtcbiAgICB9LCBbYWxsTGFiZWwsIGNvbW1pdHRlZCwgb3B0aW9uQnlWYWx1ZV0pO1xuICAgIHJldHVybiAoX2pzeChTZWxlY3QsIE9iamVjdC5hc3NpZ24oe30sIHJlc3QsIHsgbXVsdGlwbGU6IHRydWUsIHNpemU6IHNpemUsIGxhYmVsOiBsYWJlbCwgcGxhY2Vob2xkZXI6IHBsYWNlaG9sZGVyLCBjbGFzc05hbWU6IGpvaW5DbHMoV1JBUF9DTFMsIGNsYXNzTmFtZSksIHBhbmVsQ2xhc3NOYW1lOiBQQU5FTF9DTFMsIGdyb3VwTGFiZWxDbGFzc05hbWU6IEdST1VQX0xBQkVMX0NMUywgdmFsdWU6IHRlbXAsIG9wZW46IG9wZW4sIG9uT3BlbkNoYW5nZTogaGFuZGxlT3BlbkNoYW5nZSwgb25DaGFuZ2U6IGhhbmRsZVNlbGVjdENoYW5nZSwgc2VhcmNoYWJsZTogc2VhcmNoLCBzZWFyY2hQbGFjZWhvbGRlcjogc2VhcmNoUGxhY2Vob2xkZXIsIHNlYXJjaFZhbHVlOiBrZXl3b3JkLCBvblNlYXJjaENoYW5nZTogc2V0S2V5d29yZCwgZmlsdGVyT3B0aW9uOiBmaWx0ZXJPcHRpb24sIG9wdGlvbnM6IGdyb3VwZWREYXRhLCBwYW5lbEhlYWRlcjogc2VhcmNoaW5nID8gdW5kZWZpbmVkIDogKF9qc3hzKFwiYnV0dG9uXCIsIHsgdHlwZTogJ2J1dHRvbicsIGNsYXNzTmFtZTogam9pbkNscyhgJHtXUkFQX0NMU31fX2FsbGAsIGFsbENoZWNrZWQgJiYgYCR7V1JBUF9DTFN9X19hbGwtLWNoZWNrZWRgKSwgb25DbGljazogaGFuZGxlQWxsQ2xpY2ssIGNoaWxkcmVuOiBbX2pzeChUeXBvZ3JhcGh5TGFiZWwsIHsgc2l6ZTogJ21kJywgY2hpbGRyZW46IGFsbExhYmVsIH0pLCBfanN4KENoZWNrYm94LCB7IGNoZWNrZWQ6IGFsbENoZWNrZWQsIHJlYWRPbmx5OiB0cnVlLCBjbGFzc05hbWU6IGAke1dSQVBfQ0xTfV9fcm93LWNoZWNrYCB9KV0gfSkpLCBlbXB0eUNvbnRlbnQ6IHNlYXJjaEVtcHR5LCByZW5kZXJWYWx1ZTogcmVuZGVyVmFsdWUsIHJlbmRlck9wdGlvbjogKG9wdGlvbiwgbWV0YSkgPT4gcmVuZGVyUm93KG9wdGlvbiwgbWV0YS5zZWxlY3RlZCksIHBhbmVsRm9vdGVyOiBfanN4cyhGbGV4LCB7IGdhcDogOCwgY2xhc3NOYW1lOiBgJHtXUkFQX0NMU31fX2Zvb3RlcmAsIGNoaWxkcmVuOiBbX2pzeChCdXR0b24sIHsgY29sb3I6ICdncmV5Jywgc2l6ZTogJ3NtYWxsJywgc3R5bGU6IEZVTExfV0lEVEhfU1RZTEUsIG9uQ2xpY2s6IGhhbmRsZVJlc2V0LCBjaGlsZHJlbjogUkVTRVRfTEFCRUwgfSksIF9qc3goQnV0dG9uLCB7IGNvbG9yOiAncHJpbWFyeScsIHNpemU6ICdzbWFsbCcsIHN0eWxlOiBGVUxMX1dJRFRIX1NUWUxFLCBvbkNsaWNrOiBoYW5kbGVBcHBseSwgY2hpbGRyZW46IEFQUExZX0xBQkVMIH0pXSB9KSB9KSkpO1xufTtcbmV4cG9ydCBjb25zdCBBc3NldEZpbHRlciA9IG1lbW8oQXNzZXRGaWx0ZXJCYXNlKTsiLG51bGxdLCJzb3VyY2VSb290IjoiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjIn0=
@@ -0,0 +1,2 @@
1
+ export { AssetFilter } from './Asset';
2
+ export * from './interface';
@@ -0,0 +1,3 @@
1
+ export { AssetFilter } from './Asset';
2
+ export * from './interface';
3
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJ1c2luZXNzL0ZpbHRlci9zcmMvYnVzaW5lc3MvRmlsdGVyL0Fzc2V0L2luZGV4LnRzIl0sIm5hbWVzIjpbIkFzc2V0RmlsdGVyIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxXQUFXLFFBQVEsU0FBUztBQUNyQyxjQUFjLGFBQWEiLCJmaWxlIjoiYnVzaW5lc3MvRmlsdGVyL0Fzc2V0L2luZGV4LmpzIiwic291cmNlc0NvbnRlbnQiOltudWxsXSwic291cmNlUm9vdCI6Ii4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYyJ9
@@ -0,0 +1,90 @@
1
+ import type { ReactNode, RefObject } from 'react';
2
+ import type { SelectProps, SelectSize } from "../../../components/Select";
3
+ /**
4
+ * A single asset as returned by 1money's asset list endpoint
5
+ * (`/assets` → `data[i]`). The filter reads only the display fields below;
6
+ * other payload fields (`networkName`, `sortOrder`, …) are ignored.
7
+ */
8
+ export interface AssetFilterItem {
9
+ /** Asset symbol — bound to the filter value, e.g. `"USDC"` / `"USD"`. */
10
+ assetName: string;
11
+ /**
12
+ * Full asset name, e.g. `"Circle USD Coin"`. Not rendered, but matched by the
13
+ * search box alongside `assetName`.
14
+ */
15
+ assetDesc?: string;
16
+ /** Public URL of the round asset icon (rendered with `<img>`). */
17
+ assetIconUrl?: string;
18
+ /**
19
+ * Whether the asset is a fiat currency. Drives the group heading: fiat rows
20
+ * bucket under "Cash", the rest under "Stablecoins".
21
+ */
22
+ isFiat?: boolean;
23
+ }
24
+ /** Imperative handle exposed via `ref` for parent-driven reset/clear. */
25
+ export interface AssetFilterHandler {
26
+ /** Wipe the selection to empty (no rows checked) without firing callbacks. */
27
+ clear: () => void;
28
+ /** Restore the initial "All assets" state and fire `onReset`. */
29
+ reset: () => void;
30
+ }
31
+ export interface AssetFilterProps extends Omit<SelectProps, 'ref' | 'options' | 'multiple' | 'value' | 'defaultValue' | 'onChange' | 'searchable' | 'searchValue' | 'defaultSearchValue' | 'onSearchChange' | 'filterOption' | 'renderOption' | 'renderOptionContent' | 'renderValue' | 'panelHeader' | 'panelFooter' | 'emptyContent' | 'open' | 'defaultOpen' | 'onOpenChange' | 'allowDeselect' | 'maxVisibleValues' | 'size' | 'onReset'> {
32
+ ref?: RefObject<AssetFilterHandler | null>;
33
+ /**
34
+ * Trigger size. Mirrors the host filter row sizing.
35
+ * @default 'small'
36
+ */
37
+ size?: SelectSize;
38
+ /** Optional field label rendered above the trigger. */
39
+ label?: ReactNode;
40
+ /**
41
+ * Trigger placeholder shown before any selection.
42
+ * @default 'Asset'
43
+ */
44
+ placeholder?: string;
45
+ /**
46
+ * The raw asset list (`data`). The component groups it into "Cash" (fiat) and
47
+ * "Stablecoins" (the rest), each row showing the asset icon + symbol.
48
+ *
49
+ * @example
50
+ * ```ts
51
+ * const assets: AssetFilterItem[] = [
52
+ * { assetName: 'USD', assetDesc: 'United States Dollar', assetIconUrl: '…', isFiat: true },
53
+ * { assetName: 'USDC', assetDesc: 'Circle USD Coin', assetIconUrl: '…', isFiat: false },
54
+ * ];
55
+ * <AssetFilter data={assets} onApply={setAssetNames} />
56
+ * ```
57
+ */
58
+ data: AssetFilterItem[];
59
+ /**
60
+ * Text for the leading "select all" row. Selecting it clears every specific
61
+ * pick; `onApply` then receives `[]` (translate to "no asset filter").
62
+ * @default 'All assets'
63
+ */
64
+ allLabel?: string;
65
+ /**
66
+ * Show a search box above the list (matches the asset symbol and full name).
67
+ * Pass `search={false}` to hide it.
68
+ * @default true
69
+ */
70
+ search?: boolean;
71
+ /**
72
+ * Search-box placeholder. The box matches the asset symbol and full name.
73
+ * @default 'Search'
74
+ */
75
+ searchPlaceholder?: string;
76
+ /**
77
+ * Content shown when the search yields no matching asset. Defaults to an
78
+ * `<Empty icon='search' title='No results' />`.
79
+ */
80
+ searchEmpty?: ReactNode;
81
+ /**
82
+ * Fired when the user commits the selection via the panel's Apply button.
83
+ * Receives the selected asset symbols, or `[]` for "All assets" — the
84
+ * component never injects an `'all'` sentinel, so translate `[]` to whatever
85
+ * your API expects at the call site.
86
+ */
87
+ onApply: (values: string[]) => void;
88
+ /** Fired when the user clears the selection via the panel's Reset button. */
89
+ onReset?: (values: string[]) => void;
90
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVzaW5lc3MvRmlsdGVyL0Fzc2V0L2ludGVyZmFjZS5qcyIsIm5hbWVzIjpbXSwic291cmNlUm9vdCI6Ii4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYyIsInNvdXJjZXMiOlsiYnVzaW5lc3MvRmlsdGVyL0Fzc2V0L2ludGVyZmFjZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQge307Il0sIm1hcHBpbmdzIjoiQUFBQSIsImlnbm9yZUxpc3QiOltdfQ==
@@ -0,0 +1,96 @@
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-asset-filter__value {
24
+ display: inline-flex;
25
+ align-items: center;
26
+ width: 100%;
27
+ overflow: hidden;
28
+ line-height: 18px;
29
+ }
30
+ .om-asset-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-asset-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-asset-filter-panel .om-component-ui-select-panel-header {
44
+ margin-bottom: var(--om-spacing-050, 2px);
45
+ }
46
+ .om-asset-filter-panel .om-asset-filter__group-label {
47
+ padding-top: var(--om-spacing-200, 8px);
48
+ padding-bottom: var(--om-spacing-050, 2px);
49
+ }
50
+ .om-asset-filter-panel .om-asset-filter__group-label [class*=om-component-ui-typography] {
51
+ font-size: var(--om-body-sm-font-size);
52
+ font-family: var(--om-body-sm-font-family);
53
+ line-height: var(--om-body-sm-line-height);
54
+ letter-spacing: var(--om-body-sm-letter-spacing);
55
+ font-weight: var(--om-body-sm-strong-font-weight);
56
+ color: var(--om-text-default-tertiary, #646465);
57
+ }
58
+ .om-asset-filter-panel .om-asset-filter__row {
59
+ width: 100%;
60
+ }
61
+ .om-asset-filter-panel .om-asset-filter__row-main {
62
+ min-width: 0;
63
+ }
64
+ .om-asset-filter-panel .om-asset-filter__row-name {
65
+ min-width: 0;
66
+ overflow: hidden;
67
+ white-space: nowrap;
68
+ text-overflow: ellipsis;
69
+ }
70
+ .om-asset-filter-panel .om-asset-filter__row-check {
71
+ flex: 0 0 auto;
72
+ pointer-events: none;
73
+ }
74
+ .om-asset-filter-panel .om-asset-filter__all {
75
+ display: flex;
76
+ align-items: center;
77
+ justify-content: space-between;
78
+ width: 100%;
79
+ padding: var(--om-spacing-200, 8px);
80
+ border: none;
81
+ background: transparent;
82
+ border-radius: var(--om-radius-200, 8px);
83
+ cursor: pointer;
84
+ }
85
+ .om-asset-filter-panel .om-asset-filter__all:hover, .om-asset-filter-panel .om-asset-filter__all--checked {
86
+ background: var(--om-bg-default-secondary, #f8f8f8);
87
+ }
88
+
89
+ .om-asset-filter-icon {
90
+ flex: 0 0 auto;
91
+ width: 24px;
92
+ height: 24px;
93
+ -o-object-fit: cover;
94
+ object-fit: cover;
95
+ border-radius: var(--om-radius-full, 9999px);
96
+ }
@@ -0,0 +1,2 @@
1
+ import './Asset.css';
2
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJ1c2luZXNzL0ZpbHRlci9Bc3NldC9zcmMvYnVzaW5lc3MvRmlsdGVyL0Fzc2V0L3N0eWxlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sY0FBYyIsImZpbGUiOiJidXNpbmVzcy9GaWx0ZXIvQXNzZXQvc3R5bGUvY3NzLmpzIiwic291cmNlc0NvbnRlbnQiOltudWxsXSwic291cmNlUm9vdCI6Ii4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYyJ9
@@ -0,0 +1 @@
1
+ import './Asset.css';
@@ -0,0 +1,2 @@
1
+ import './Asset.css';
2
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJ1c2luZXNzL0ZpbHRlci9Bc3NldC9zcmMvYnVzaW5lc3MvRmlsdGVyL0Fzc2V0L3N0eWxlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sY0FBYyIsImZpbGUiOiJidXNpbmVzcy9GaWx0ZXIvQXNzZXQvc3R5bGUvaW5kZXguanMiLCJzb3VyY2VzQ29udGVudCI6W251bGxdLCJzb3VyY2VSb290IjoiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjIn0=
@@ -0,0 +1,2 @@
1
+ import type { DateRangeFilterProps } from './interface';
2
+ export declare const DateRangeFilter: import("react").NamedExoticComponent<DateRangeFilterProps>;