@skbkontur/react-ui 5.3.1 → 5.3.2

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 (135) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/package.json +1 -6
  3. package/cjs/components/Autocomplete/Autocomplete.md +0 -113
  4. package/cjs/components/Button/Button.md +0 -261
  5. package/cjs/components/Calendar/Calendar.md +0 -276
  6. package/cjs/components/Calendar/CalendarDay.md +0 -70
  7. package/cjs/components/Center/Center.md +0 -26
  8. package/cjs/components/Checkbox/Checkbox.md +0 -171
  9. package/cjs/components/ComboBox/ComboBox.md +0 -574
  10. package/cjs/components/CurrencyInput/CurrencyInput.md +0 -39
  11. package/cjs/components/CurrencyLabel/CurrencyLabel.md +0 -29
  12. package/cjs/components/DateInput/DateInput.md +0 -111
  13. package/cjs/components/DatePicker/DatePicker.md +0 -368
  14. package/cjs/components/Dropdown/Dropdown.md +0 -45
  15. package/cjs/components/DropdownMenu/DropdownMenu.md +0 -290
  16. package/cjs/components/FileUploader/FileUploader.md +0 -131
  17. package/cjs/components/FxInput/FxInput.md +0 -31
  18. package/cjs/components/Gapped/Gapped.md +0 -44
  19. package/cjs/components/GlobalLoader/GlobalLoader.md +0 -97
  20. package/cjs/components/Group/Group.md +0 -19
  21. package/cjs/components/Hint/Hint.md +0 -86
  22. package/cjs/components/Input/Input.md +0 -86
  23. package/cjs/components/Kebab/Kebab.md +0 -306
  24. package/cjs/components/Link/Link.md +0 -182
  25. package/cjs/components/Loader/Loader.md +0 -33
  26. package/cjs/components/MaskedInput/MaskedInput.md +0 -114
  27. package/cjs/components/MenuFooter/MenuFooter.md +0 -27
  28. package/cjs/components/MenuHeader/MenuHeader.md +0 -35
  29. package/cjs/components/MenuItem/MenuItem.md +0 -139
  30. package/cjs/components/MenuSeparator/MenuSeparator.md +0 -14
  31. package/cjs/components/MiniModal/MiniModal.md +0 -231
  32. package/cjs/components/Modal/Modal.md +0 -56
  33. package/cjs/components/Paging/Paging.md +0 -57
  34. package/cjs/components/PasswordInput/PasswordInput.md +0 -29
  35. package/cjs/components/Radio/Radio.md +0 -57
  36. package/cjs/components/RadioGroup/RadioGroup.md +0 -44
  37. package/cjs/components/ResponsiveLayout/ResponsiveLayout.md +0 -75
  38. package/cjs/components/ScrollContainer/ScrollContainer.md +0 -224
  39. package/cjs/components/Select/Select.md +0 -113
  40. package/cjs/components/SidePage/SidePage.md +0 -65
  41. package/cjs/components/SingleToast/SingleToast.md +0 -36
  42. package/cjs/components/Spinner/Spinner.md +0 -36
  43. package/cjs/components/Sticky/Sticky.md +0 -28
  44. package/cjs/components/Switcher/Switcher.md +0 -111
  45. package/cjs/components/Tabs/Tab.md +0 -73
  46. package/cjs/components/Tabs/Tabs.md +0 -54
  47. package/cjs/components/Textarea/Textarea.md +0 -58
  48. package/cjs/components/Toast/Toast.md +0 -69
  49. package/cjs/components/Toggle/Toggle.md +0 -110
  50. package/cjs/components/Token/Token.md +0 -48
  51. package/cjs/components/TokenInput/TokenInput.md +0 -277
  52. package/cjs/components/Tooltip/Tooltip.md +0 -322
  53. package/cjs/components/TooltipMenu/TooltipMenu.md +0 -241
  54. package/cjs/internal/DataTids/DATATIDS.md +0 -12
  55. package/cjs/internal/DataTids/DataTids.d.ts +0 -12
  56. package/cjs/internal/DataTids/DataTids.js +0 -50
  57. package/cjs/internal/DataTids/DataTids.js.map +0 -1
  58. package/cjs/internal/DataTids/DataTids.styles.d.ts +0 -7
  59. package/cjs/internal/DataTids/DataTids.styles.js +0 -42
  60. package/cjs/internal/DataTids/DataTids.styles.js.map +0 -1
  61. package/cjs/internal/DataTids/componentsDataTids.d.ts +0 -5
  62. package/cjs/internal/DataTids/componentsDataTids.js +0 -15
  63. package/cjs/internal/DataTids/componentsDataTids.js.map +0 -1
  64. package/cjs/internal/ThemePlayground/Playground.md +0 -7
  65. package/cjs/lib/featureFlagsContext/FEATUREFLAGSCONTEXT.md +0 -64
  66. package/cjs/lib/locale/LOCALECONTEXT.md +0 -222
  67. package/cjs/lib/theming/ThemeContext.md +0 -265
  68. package/components/Autocomplete/Autocomplete.md +0 -113
  69. package/components/Button/Button.md +0 -261
  70. package/components/Calendar/Calendar.md +0 -276
  71. package/components/Calendar/CalendarDay.md +0 -70
  72. package/components/Center/Center.md +0 -26
  73. package/components/Checkbox/Checkbox.md +0 -171
  74. package/components/ComboBox/ComboBox.md +0 -574
  75. package/components/CurrencyInput/CurrencyInput.md +0 -39
  76. package/components/CurrencyLabel/CurrencyLabel.md +0 -29
  77. package/components/DateInput/DateInput.md +0 -111
  78. package/components/DatePicker/DatePicker.md +0 -368
  79. package/components/Dropdown/Dropdown.md +0 -45
  80. package/components/DropdownMenu/DropdownMenu.md +0 -290
  81. package/components/FileUploader/FileUploader.md +0 -131
  82. package/components/FxInput/FxInput.md +0 -31
  83. package/components/Gapped/Gapped.md +0 -44
  84. package/components/GlobalLoader/GlobalLoader.md +0 -97
  85. package/components/Group/Group.md +0 -19
  86. package/components/Hint/Hint.md +0 -86
  87. package/components/Input/Input.md +0 -86
  88. package/components/Kebab/Kebab.md +0 -306
  89. package/components/Link/Link.md +0 -182
  90. package/components/Loader/Loader.md +0 -33
  91. package/components/MaskedInput/MaskedInput.md +0 -114
  92. package/components/MenuFooter/MenuFooter.md +0 -27
  93. package/components/MenuHeader/MenuHeader.md +0 -35
  94. package/components/MenuItem/MenuItem.md +0 -139
  95. package/components/MenuSeparator/MenuSeparator.md +0 -14
  96. package/components/MiniModal/MiniModal.md +0 -231
  97. package/components/Modal/Modal.md +0 -56
  98. package/components/Paging/Paging.md +0 -57
  99. package/components/PasswordInput/PasswordInput.md +0 -29
  100. package/components/Radio/Radio.md +0 -57
  101. package/components/RadioGroup/RadioGroup.md +0 -44
  102. package/components/ResponsiveLayout/ResponsiveLayout.md +0 -75
  103. package/components/ScrollContainer/ScrollContainer.md +0 -224
  104. package/components/Select/Select.md +0 -113
  105. package/components/SidePage/SidePage.md +0 -65
  106. package/components/SingleToast/SingleToast.md +0 -36
  107. package/components/Spinner/Spinner.md +0 -36
  108. package/components/Sticky/Sticky.md +0 -28
  109. package/components/Switcher/Switcher.md +0 -111
  110. package/components/Tabs/Tab.md +0 -73
  111. package/components/Tabs/Tabs.md +0 -54
  112. package/components/Textarea/Textarea.md +0 -58
  113. package/components/Toast/Toast.md +0 -69
  114. package/components/Toggle/Toggle.md +0 -110
  115. package/components/Token/Token.md +0 -48
  116. package/components/TokenInput/TokenInput.md +0 -277
  117. package/components/Tooltip/Tooltip.md +0 -322
  118. package/components/TooltipMenu/TooltipMenu.md +0 -241
  119. package/internal/DataTids/DATATIDS.md +0 -12
  120. package/internal/DataTids/DataTids/DataTids.js +0 -69
  121. package/internal/DataTids/DataTids/DataTids.js.map +0 -1
  122. package/internal/DataTids/DataTids/package.json +0 -6
  123. package/internal/DataTids/DataTids.d.ts +0 -12
  124. package/internal/DataTids/DataTids.styles/DataTids.styles.js +0 -20
  125. package/internal/DataTids/DataTids.styles/DataTids.styles.js.map +0 -1
  126. package/internal/DataTids/DataTids.styles/package.json +0 -6
  127. package/internal/DataTids/DataTids.styles.d.ts +0 -7
  128. package/internal/DataTids/componentsDataTids/componentsDataTids.js +0 -12
  129. package/internal/DataTids/componentsDataTids/componentsDataTids.js.map +0 -1
  130. package/internal/DataTids/componentsDataTids/package.json +0 -6
  131. package/internal/DataTids/componentsDataTids.d.ts +0 -5
  132. package/internal/ThemePlayground/Playground.md +0 -7
  133. package/lib/featureFlagsContext/FEATUREFLAGSCONTEXT.md +0 -64
  134. package/lib/locale/LOCALECONTEXT.md +0 -222
  135. package/lib/theming/ThemeContext.md +0 -265
@@ -1,574 +0,0 @@
1
- ### Комбобокс с валидацией
2
-
3
- ```jsx harmony
4
- import { Tooltip } from '@skbkontur/react-ui';
5
-
6
- const delay = time => args => new Promise(resolve => setTimeout(resolve, time, args));
7
-
8
- let maybeReject = x => (Math.random() * 3 < 1 ? Promise.reject() : Promise.resolve(x));
9
-
10
- let getItems = q =>
11
- Promise.resolve(
12
- [
13
- { value: 1, label: 'First' },
14
- { value: 2, label: 'Second' },
15
- { value: 3, label: 'Third' },
16
- { value: 4, label: 'Fourth' },
17
- { value: 5, label: 'Fifth' },
18
- { value: 6, label: 'Sixth' },
19
- ].filter(x => x.label.toLowerCase().includes(q.toLowerCase()) || x.value.toString(10) === q),
20
- )
21
- .then(delay(500))
22
- .then(maybeReject);
23
-
24
- const [selected, setSelected] = React.useState({ value: 3, label: 'Third' });
25
- const [error, setError] = React.useState(false);
26
-
27
- let handleValueChange = value => {
28
- setSelected(value);
29
- setError(false);
30
- };
31
-
32
- let handleUnexpectedInput = () => {
33
- setSelected(null);
34
- setError(true);
35
- };
36
-
37
- let handleFocus = () => setError(false);
38
-
39
- <Tooltip closeButton={false} render={() => 'Item must be selected!'} trigger={error ? 'opened' : 'closed'}>
40
- <ComboBox
41
- error={error}
42
- getItems={getItems}
43
- onValueChange={handleValueChange}
44
- onFocus={handleFocus}
45
- onUnexpectedInput={handleUnexpectedInput}
46
- placeholder="Enter number"
47
- value={selected}
48
- />
49
- </Tooltip>;
50
- ```
51
-
52
- ### Очистка комбобокса
53
- Очистить значение в `ComboBox`'е можно с помощью пустой строки, `null` или `undefined`
54
- ```jsx harmony
55
- import { Group, ComboBox, Button } from '@skbkontur/react-ui';
56
-
57
- const [value, setValue] = React.useState({ value: 2, label: 'Second' });
58
-
59
- const getItems = q => {
60
- return Promise.resolve(
61
- [
62
- { value: 1, label: 'First' },
63
- { value: 2, label: 'Second' },
64
- { value: 3, label: 'Third' },
65
- { value: 4, label: 'Fourth' },
66
- { value: 5, label: 'Fifth' },
67
- { value: 6, label: 'Sixth' },
68
- ].filter(x => x.label.toLowerCase().includes(q.toLowerCase()) || x.value.toString(10) === q),
69
- )
70
- };
71
-
72
- <Group>
73
- <ComboBox
74
- getItems={getItems}
75
- onValueChange={setValue}
76
- placeholder="Введите число"
77
- value={value}
78
- />
79
- <Button onClick={() => setValue(null)}>Null</Button>
80
- <Button onClick={() => setValue(undefined)}>Undefined</Button>
81
- <Button onClick={() => setValue('')}>Пустая строка</Button>
82
- </Group>
83
- ```
84
-
85
- ### ComboBox with popular values, complex menu items and total count message
86
-
87
- ```jsx harmony
88
- import { getCities } from '@skbkontur/react-ui/components/ComboBox/__mocks__/getCities';
89
- import { Gapped, MenuSeparator } from '@skbkontur/react-ui';
90
- import {MenuFooter} from "@skbkontur/react-ui/components/MenuFooter";
91
-
92
- let popularItems = [
93
- { Id: 956, City: 'Махачкала' },
94
- { Id: 4974, City: 'Верхняя-Пышма' },
95
- { Id: 4980, City: 'Екатеринбург' },
96
- ];
97
-
98
- const [value, setValue] = React.useState(null);
99
-
100
- let mapCity = ({ Id, City }) => ({
101
- value: Id,
102
- label: City,
103
- });
104
-
105
- let hasSelectedItem = itemsSets => itemsSets.some(items => items.find(item => value.value === item.Id));
106
-
107
- let shouldInsertSelectedItem = (query, items) => value && !query && !hasSelectedItem([items, popularItems]);
108
-
109
- let getPopularItems = query => (query ? [] : popularItems.map(mapCity));
110
- let renderSeparator = query => (query ? [] : <MenuSeparator />);
111
- let getSelectedItem = (query, items) => (!shouldInsertSelectedItem(query, items) ? [] : value);
112
-
113
- let prepareItems = (query, items) =>
114
- (!shouldInsertSelectedItem(query, items) ? items : items.slice(0, -1)).map(mapCity);
115
-
116
- let renderTotalCount = (foundCount, totalCount) =>
117
- foundCount < totalCount ? (
118
- <MenuFooter>
119
- Показано {foundCount} из {totalCount} найденных городов.
120
- </MenuFooter>
121
- ) : (
122
- []
123
- );
124
-
125
- let getItems = query =>
126
- getCities(query).then(({ foundItems, totalCount }) =>
127
- [].concat(
128
- getPopularItems(query),
129
- renderSeparator(query),
130
- getSelectedItem(query, foundItems),
131
- prepareItems(query, foundItems),
132
- renderTotalCount(foundItems.length, totalCount),
133
- ),
134
- );
135
-
136
- let renderItem = item => (
137
- <Gapped>
138
- <div style={{ width: 40 }}>{item.value}</div>
139
- <div style={{ width: 210, whiteSpace: 'normal' }}>{item.label}</div>
140
- </Gapped>
141
- );
142
-
143
- <ComboBox
144
- onValueChange={setValue}
145
- getItems={getItems}
146
- placeholder="Начните вводить название"
147
- value={value}
148
- renderItem={renderItem}
149
- />;
150
- ```
151
-
152
- ### Переопределение `renderValue`, `renderItem` и `itemWrapper`
153
-
154
- ```jsx harmony
155
- import { CheckAIcon16Regular } from '@skbkontur/icons/icons/CheckAIcon/CheckAIcon16Regular';
156
- import { Tooltip } from '@skbkontur/react-ui';
157
-
158
- const delay = time => args => new Promise(resolve => setTimeout(resolve, time, args));
159
-
160
- const getItems = q =>
161
- Promise.resolve(
162
- [
163
- { approved: true, value: 1, label: 'Леонид Долецкий', email: 'first@skbkontur.ru' },
164
- { approved: true, value: 2, label: 'Владислав Нашкодивший', email: 'second@skbkontur.ru' },
165
- { approved: false, value: 3, label: 'Розенкранц Харитонов', email: 'third@skbkontur.ru' },
166
- { approved: false, value: 4, label: 'Надежда Дубова', email: 'fourth@skbkontur.ru' },
167
- { approved: true, value: 5, label: 'Владислав Сташкеевич', email: 'fifth@skbkontur.ru' },
168
- { approved: true, value: 6, label: 'Василиса Александровна Поволоцкая', email: 'sixth@skbkontur.ru' },
169
- ].filter(x => x.label.toLowerCase().includes(q.toLowerCase()) || x.value.toString(10) === q),
170
- ).then(delay(500));
171
-
172
- const [selected, setSelected] = React.useState({
173
- approved: false,
174
- value: 3,
175
- label: 'Розенкранц Харитонов',
176
- email: 'third@skbkontur.ru',
177
- });
178
- const [error, setError] = React.useState(false);
179
-
180
- const handleValueChange = value => {
181
- setSelected(value);
182
- setError(false);
183
- };
184
-
185
- const handleUnexpectedInput = () => {
186
- setSelected(null);
187
- setError(true);
188
- };
189
-
190
- const handleFocus = () => setError(false);
191
-
192
- const customRenderItem = item => (
193
- <div
194
- style={{
195
- display: 'flex',
196
- }}
197
- >
198
- <div
199
- style={{
200
- width: '55%',
201
- display: 'flex',
202
- }}
203
- >
204
- <span
205
- style={{
206
- minWidth: '20px',
207
- }}
208
- >
209
- {item.approved ? <CheckAIcon16Regular size={14} /> : null}
210
- </span>
211
- <span
212
- style={{
213
- flexGrow: '1',
214
- }}
215
- >
216
- {item.label}
217
- </span>
218
- </div>
219
- <div
220
- style={{
221
- opacity: '0.6',
222
- paddingLeft: '10px',
223
- boxSizing: 'border-box',
224
- }}
225
- >
226
- {item.email}
227
- </div>
228
- </div>
229
- );
230
-
231
- const customItemWrapper = item => {
232
- if (item.value === 3) {
233
- return (props) => <div {...props} />;
234
- }
235
-
236
- return (props) => <button {...props} />
237
- }
238
-
239
- const customRenderValue = item => (
240
- <div
241
- style={{
242
- display: 'flex',
243
- }}
244
- >
245
- <div
246
- style={{
247
- width: '55%',
248
- overflow: 'hidden',
249
- textOverflow: 'ellipsis'
250
- }}
251
- >
252
- {item.label}
253
- </div>
254
- <div
255
- style={{
256
- opacity: '0.6',
257
- paddingLeft: '10px',
258
- boxSizing: 'border-box',
259
- }}
260
- >
261
- {item.email}
262
- </div>
263
- </div>
264
- );
265
-
266
- <Tooltip closeButton={false} render={() => 'Item must be selected!'} trigger={error ? 'opened' : 'closed'}>
267
- <ComboBox
268
- error={error}
269
- getItems={getItems}
270
- onValueChange={handleValueChange}
271
- onFocus={handleFocus}
272
- onUnexpectedInput={handleUnexpectedInput}
273
- placeholder="Enter number"
274
- value={selected}
275
- renderItem={customRenderItem}
276
- itemWrapper={customItemWrapper}
277
- renderValue={customRenderValue}
278
- width="400px"
279
- />
280
- </Tooltip>;
281
- ```
282
-
283
- ### Подсветка результата поиска
284
-
285
- ```jsx harmony
286
- import { Tooltip } from '@skbkontur/react-ui';
287
-
288
- const delay = time => args => new Promise(resolve => setTimeout(resolve, time, args));
289
-
290
- const getItems = query =>
291
- Promise.resolve(
292
- [
293
- { value: 1, label: 'First' },
294
- { value: 2, label: 'Second' },
295
- { value: 3, label: 'Third' },
296
- { value: 4, label: 'Fourth' },
297
- { value: 5, label: 'Fifth' },
298
- { value: 6, label: 'Sixth' },
299
- ]
300
- .filter(x => x.label.toLowerCase().includes(query.toLowerCase()) || x.value.toString(10) === query)
301
- .map(({ label, ...rest }) => {
302
- const start = label.toLowerCase().indexOf(query.toLowerCase());
303
- const end = start + query.length;
304
-
305
- return {
306
- ...rest,
307
- label,
308
- highlightedLabel:
309
- start >= 0 ? (
310
- <span>
311
- {label.substring(0, start)}
312
- <strong
313
- style={{
314
- fontSize: '1.1em',
315
- }}
316
- >
317
- {label.substring(start, end)}
318
- </strong>
319
- {label.substring(end)}
320
- </span>
321
- ) : null,
322
- };
323
- }),
324
- ).then(delay(500));
325
-
326
- const [selected, setSelected] = React.useState({ value: 3, label: 'Third' });
327
- const [error, setError] = React.useState(false);
328
-
329
- let handleValueChange = value => {
330
- setSelected(value);
331
- setError(false);
332
- };
333
-
334
- let handleUnexpectedInput = () => {
335
- setSelected(null);
336
- setError(true);
337
- };
338
-
339
- let handleFocus = () => setError(false);
340
-
341
- const renderItem = item => {
342
- if (item.highlightedLabel) {
343
- return item.highlightedLabel;
344
- }
345
-
346
- return item.label;
347
- };
348
-
349
- <Tooltip closeButton={false} render={() => 'Item must be selected!'} trigger={error ? 'opened' : 'closed'}>
350
- <ComboBox
351
- error={error}
352
- getItems={getItems}
353
- onValueChange={handleValueChange}
354
- onFocus={handleFocus}
355
- onUnexpectedInput={handleUnexpectedInput}
356
- placeholder="Enter number"
357
- value={selected}
358
- renderItem={renderItem}
359
- />
360
- </Tooltip>;
361
- ```
362
-
363
- ### Добавление элементов в меню
364
-
365
- ```jsx harmony
366
- import { MenuItem } from '@skbkontur/react-ui';
367
-
368
- const delay = time => args => new Promise(resolve => setTimeout(resolve, time, args));
369
-
370
- class ComboboxExample extends React.Component {
371
- constructor(props) {
372
- super(props);
373
-
374
- this.state = {
375
- items: [
376
- { value: 1, label: 'First' },
377
- { value: 2, label: 'Second' },
378
- { value: 3, label: 'Third' },
379
- { value: 4, label: 'Fourth' },
380
- { value: 5, label: 'Fifth' },
381
- { value: 6, label: 'Sixth' },
382
- ],
383
- query: '',
384
- selected: { value: 3, label: 'Third' },
385
- error: false,
386
- shouldRenderAddButton: false,
387
- };
388
-
389
- this.comboBoxElement = null;
390
-
391
- this.getItems = this.getItems.bind(this);
392
- this.handleValueChange = this.handleValueChange.bind(this);
393
- this.handleFocus = this.handleFocus.bind(this);
394
- this.handleInputValueChange = this.handleInputValueChange.bind(this);
395
- this.renderAddButton = this.renderAddButton.bind(this);
396
- this.refComboBox = this.refComboBox.bind(this);
397
- this.addItem = this.addItem.bind(this);
398
- }
399
-
400
- render() {
401
- return (
402
- <ComboBox
403
- error={this.state.error}
404
- getItems={this.getItems}
405
- onValueChange={this.handleValueChange}
406
- onFocus={this.handleFocus}
407
- placeholder="Enter number"
408
- value={this.state.selected}
409
- onInputValueChange={this.handleInputValueChange}
410
- renderAddButton={this.renderAddButton}
411
- ref={this.refComboBox}
412
- />
413
- );
414
- }
415
-
416
- getItems(q) {
417
- return Promise.resolve(
418
- this.state.items.filter(x => x.label.toLowerCase().includes(q.toLowerCase()) || x.value.toString(10) === q),
419
- ).then(delay(500));
420
- }
421
-
422
- handleInputValueChange(query) {
423
- const isItemExists = this.state.items.find(x => x.label.toLowerCase() == query.toLowerCase());
424
- this.setState({ query, shouldRenderAddButton: !isItemExists });
425
- }
426
-
427
- handleValueChange(value) {
428
- this.setState({ selected: value, error: false, shouldRenderAddButton: false });
429
- }
430
-
431
- handleFocus() {
432
- this.setState({ error: false });
433
- }
434
-
435
- renderAddButton() {
436
- if (!this.state.shouldRenderAddButton) {
437
- return null;
438
- }
439
- return (
440
- <MenuItem link onClick={this.addItem}>
441
- + Добавить "{this.state.query}"
442
- </MenuItem>
443
- );
444
- }
445
-
446
- refComboBox(element) {
447
- this.comboBoxElement = element;
448
- }
449
-
450
- addItem() {
451
- this.setState(currentState => {
452
- const newItem = {
453
- value: Math.max(...currentState.items.map(({ value }) => value)) + 1,
454
- label: currentState.query,
455
- };
456
-
457
- return {
458
- items: [...currentState.items, newItem],
459
- selected: newItem,
460
- error: false,
461
- shouldRenderAddButton: false,
462
- };
463
- });
464
- }
465
- }
466
-
467
- <ComboboxExample />;
468
- ```
469
-
470
- ### Сброс контрола
471
- Если нужно сбросить контрол без изменения `value`, то можно использовать метод `reset`.
472
-
473
- ```jsx harmony
474
- import { Button } from '@skbkontur/react-ui';
475
-
476
- const [selected, setSelected] = React.useState({ value: 1, label: "First" });
477
- const ref = React.useRef(null);
478
-
479
- const handleReset = () => {
480
- if (ref.current) {
481
- ref.current.reset();
482
- }
483
- };
484
-
485
- const getItems = (q) =>
486
- Promise.resolve(
487
- [
488
- { value: 1, label: "First" },
489
- { value: 2, label: "Second" },
490
- { value: 3, label: "Third" }
491
- ].filter(
492
- (x) =>
493
- x.label.toLowerCase().includes(q.toLowerCase()) ||
494
- x.value.toString(10) === q
495
- )
496
- );
497
-
498
- <div>
499
- <ComboBox
500
- ref={ref}
501
- getItems={getItems}
502
- onValueChange={setSelected}
503
- placeholder="Enter number"
504
- value={selected}
505
- />
506
- <Button onClick={handleReset}>Reset</Button>
507
- </div>
508
-
509
- ```
510
-
511
- ### Локали по умолчанию
512
-
513
- ```typescript static
514
- interface ComboBoxLocale {
515
- notFound?: string;
516
- errorNetworkButton?: string;
517
- errorNetworkMessage?: string;
518
- }
519
-
520
- const ru_RU = {
521
- notFound: 'Не найдено',
522
- errorNetworkButton: 'Обновить',
523
- errorNetworkMessage: 'Что-то пошло не так. Проверьте соединение с интернетом и попробуйте еще раз',
524
- };
525
-
526
- const en_GB = {
527
- notFound: 'Not found',
528
- errorNetworkButton: 'Refresh',
529
- errorNetworkMessage: 'Something went wrong. Check your internet connection and try again',
530
- };
531
- ```
532
-
533
- ### Размер
534
- ```jsx harmony
535
- import { Gapped } from '@skbkontur/react-ui';
536
-
537
- const getItems = q => {
538
- return Promise.resolve(
539
- [
540
- { value: 1, label: 'Маленький' },
541
- { value: 2, label: 'Средний' },
542
- { value: 3, label: 'Большой' },
543
- ].filter(x => x.label.toLowerCase().includes(q.toLowerCase()) || x.value.toString(10) === q),
544
- )
545
- };
546
-
547
- const [valueSmall, setValueSmall] = React.useState('Маленький');
548
- const [valueMedium, setValueMedium] = React.useState('Средний');
549
- const [valueLarge, setValueLarge] = React.useState('Большой');
550
-
551
- <Gapped vertical>
552
- <ComboBox
553
- getItems={getItems}
554
- onValueChange={setValueSmall}
555
- placeholder="Введите число"
556
- value={valueSmall}
557
- size={'small'}
558
- />
559
- <ComboBox
560
- getItems={getItems}
561
- onValueChange={setValueMedium}
562
- placeholder="Введите число"
563
- value={valueMedium}
564
- size={'medium'}
565
- />
566
- <ComboBox
567
- getItems={getItems}
568
- onValueChange={setValueLarge}
569
- placeholder="Введите число"
570
- value={valueLarge}
571
- size={'large'}
572
- />
573
- </Gapped>
574
- ```
@@ -1,39 +0,0 @@
1
- ### Базовый пример
2
- ```jsx harmony
3
- const [value, setValue] = React.useState();
4
-
5
- <CurrencyInput value={value} fractionDigits={3} onValueChange={setValue} />
6
- ```
7
-
8
- ### Очистка значения
9
- Очистить значение в `CurrencyInput` можно с помощью `null` или `undefined`
10
- ```jsx harmony
11
- import { Button, Group } from '@skbkontur/react-ui';
12
-
13
- const [value, setValue] = React.useState();
14
-
15
- <Group>
16
- <CurrencyInput value={value} onValueChange={setValue} />
17
- <Button onClick={() => setValue(null)}>Null</Button>
18
- <Button onClick={() => setValue(undefined)}>Undefined</Button>
19
- </Group>
20
- ```
21
-
22
- ### fractionDigits={15}
23
-
24
- ```jsx harmony
25
- const [value, setValue] = React.useState();
26
-
27
- <CurrencyInput value={value} fractionDigits={15} onValueChange={setValue} />
28
- ```
29
-
30
- ---
31
-
32
- ### <a name="/CurrencyInput?id=why15" href="#/CurrencyInput?id=why15">Почему 15?</a>
33
-
34
- Максимальное безопасное целочисленное значение - `9007199254740991` (16 цифр).
35
- Убрав один разряд, мы получим "новое" максимальное безопасное значение - **`999999999999999` (15 цифр)**.
36
-
37
- При этом десятичный резделитель может находиться в любом месте. Если целая часть равна `0`, то она не учитывается.
38
-
39
- _Детали можно почитать здесь - <a href="https://developer.mozilla.org/ru/docs/Web/JavaScript/Reference/Global_Objects/Number/MAX_SAFE_INTEGER">MDN web docs</a>_
@@ -1,29 +0,0 @@
1
- ### To render rubles
2
-
3
- ```jsx
4
- <CurrencyLabel value={12356.1} currencySymbol={'₽'} />
5
- ```
6
-
7
- ### ...or dollars
8
-
9
- ```jsx
10
- <CurrencyLabel value={12356.1} currencySymbol={'$'} />
11
- ```
12
-
13
- ### ...or nothing
14
-
15
- ```jsx
16
- <CurrencyLabel value={12356.1} />
17
- ```
18
-
19
- ### Count of fraction digits can be changed
20
-
21
- ```jsx
22
- <CurrencyLabel value={3562001.1} fractionDigits={3} currencySymbol={'₽'} />
23
- ```
24
-
25
- ### Can hide trailing zeros
26
-
27
- ```jsx
28
- <CurrencyLabel value={356.167} fractionDigits={5} hideTrailingZeros />
29
- ```