@peculiar/react-components 0.0.2-alpha.267 → 0.0.2-alpha.271

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 (83) hide show
  1. package/dist/cjs/Autocomplete/autocomplete.js +258 -0
  2. package/dist/cjs/Autocomplete/autocomplete.js.map +1 -0
  3. package/dist/cjs/Autocomplete/index.js +6 -0
  4. package/dist/cjs/Autocomplete/index.js.map +1 -0
  5. package/dist/cjs/Chip/chip.js +60 -13
  6. package/dist/cjs/Chip/chip.js.map +1 -1
  7. package/dist/cjs/Modal/modal.js +3 -3
  8. package/dist/cjs/Modal/modal.js.map +1 -1
  9. package/dist/cjs/hooks/index.js +5 -1
  10. package/dist/cjs/hooks/index.js.map +1 -1
  11. package/dist/cjs/hooks/use_autocomplete.js +345 -0
  12. package/dist/cjs/hooks/use_autocomplete.js.map +1 -0
  13. package/dist/cjs/hooks/use_event_callback.js +44 -0
  14. package/dist/cjs/hooks/use_event_callback.js.map +1 -0
  15. package/dist/cjs/index.js +1 -1
  16. package/dist/esm/Autocomplete/autocomplete.js +251 -0
  17. package/dist/esm/Autocomplete/autocomplete.js.map +1 -0
  18. package/dist/esm/Autocomplete/index.js +2 -0
  19. package/dist/esm/Autocomplete/index.js.map +1 -0
  20. package/dist/esm/Chip/chip.js +60 -13
  21. package/dist/esm/Chip/chip.js.map +1 -1
  22. package/dist/esm/Modal/modal.js +3 -3
  23. package/dist/esm/Modal/modal.js.map +1 -1
  24. package/dist/esm/hooks/index.js +2 -0
  25. package/dist/esm/hooks/index.js.map +1 -1
  26. package/dist/esm/hooks/use_autocomplete.js +338 -0
  27. package/dist/esm/hooks/use_autocomplete.js.map +1 -0
  28. package/dist/esm/hooks/use_event_callback.js +21 -0
  29. package/dist/esm/hooks/use_event_callback.js.map +1 -0
  30. package/dist/esm/index.js +1 -1
  31. package/dist/esnext/Autocomplete/autocomplete.js +255 -0
  32. package/dist/esnext/Autocomplete/autocomplete.js.map +1 -0
  33. package/dist/esnext/Autocomplete/index.js +2 -0
  34. package/dist/esnext/Autocomplete/index.js.map +1 -0
  35. package/dist/esnext/Chip/chip.js +74 -7
  36. package/dist/esnext/Chip/chip.js.map +1 -1
  37. package/dist/esnext/Modal/modal.js +3 -3
  38. package/dist/esnext/Modal/modal.js.map +1 -1
  39. package/dist/esnext/hooks/index.js +2 -0
  40. package/dist/esnext/hooks/index.js.map +1 -1
  41. package/dist/esnext/hooks/use_autocomplete.js +333 -0
  42. package/dist/esnext/hooks/use_autocomplete.js.map +1 -0
  43. package/dist/esnext/hooks/use_event_callback.js +16 -0
  44. package/dist/esnext/hooks/use_event_callback.js.map +1 -0
  45. package/dist/esnext/index.js +1 -1
  46. package/dist/types/Autocomplete/autocomplete.d.ts +86 -0
  47. package/dist/types/Autocomplete/index.d.ts +1 -0
  48. package/dist/types/Chip/chip.d.ts +15 -1
  49. package/dist/types/Modal/modal.d.ts +1 -1
  50. package/dist/types/Popover/popover.d.ts +1 -1
  51. package/dist/types/hooks/index.d.ts +2 -0
  52. package/dist/types/hooks/use_autocomplete.d.ts +91 -0
  53. package/dist/types/hooks/use_event_callback.d.ts +4 -0
  54. package/dist/types/index.d.ts +1 -1
  55. package/package.json +3 -3
  56. package/dist/cjs/ComboBox/combo_box.js +0 -262
  57. package/dist/cjs/ComboBox/combo_box.js.map +0 -1
  58. package/dist/cjs/ComboBox/index.js +0 -6
  59. package/dist/cjs/ComboBox/index.js.map +0 -1
  60. package/dist/cjs/SelectPicker/index.js +0 -6
  61. package/dist/cjs/SelectPicker/index.js.map +0 -1
  62. package/dist/cjs/SelectPicker/select_picker.js +0 -429
  63. package/dist/cjs/SelectPicker/select_picker.js.map +0 -1
  64. package/dist/esm/ComboBox/combo_box.js +0 -240
  65. package/dist/esm/ComboBox/combo_box.js.map +0 -1
  66. package/dist/esm/ComboBox/index.js +0 -2
  67. package/dist/esm/ComboBox/index.js.map +0 -1
  68. package/dist/esm/SelectPicker/index.js +0 -2
  69. package/dist/esm/SelectPicker/index.js.map +0 -1
  70. package/dist/esm/SelectPicker/select_picker.js +0 -422
  71. package/dist/esm/SelectPicker/select_picker.js.map +0 -1
  72. package/dist/esnext/ComboBox/combo_box.js +0 -214
  73. package/dist/esnext/ComboBox/combo_box.js.map +0 -1
  74. package/dist/esnext/ComboBox/index.js +0 -2
  75. package/dist/esnext/ComboBox/index.js.map +0 -1
  76. package/dist/esnext/SelectPicker/index.js +0 -2
  77. package/dist/esnext/SelectPicker/index.js.map +0 -1
  78. package/dist/esnext/SelectPicker/select_picker.js +0 -418
  79. package/dist/esnext/SelectPicker/select_picker.js.map +0 -1
  80. package/dist/types/ComboBox/combo_box.d.ts +0 -19
  81. package/dist/types/ComboBox/index.d.ts +0 -1
  82. package/dist/types/SelectPicker/index.d.ts +0 -1
  83. package/dist/types/SelectPicker/select_picker.d.ts +0 -89
@@ -1,2 +0,0 @@
1
- export { ComboBox } from './combo_box';
2
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/ComboBox/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAA2B,MAAM,aAAa,CAAC"}
@@ -1,2 +0,0 @@
1
- export { SelectPicker } from './select_picker';
2
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/SelectPicker/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC"}
@@ -1,418 +0,0 @@
1
- import React from 'react';
2
- import { Popover } from '../Popover';
3
- import { TextField } from '../TextField';
4
- import { Typography } from '../Typography';
5
- import { Box } from '../Box';
6
- import { Button } from '../Button';
7
- import { ArrowDropDownIcon, PlusIcon } from '../icons';
8
- import { useControllableState } from '../hooks';
9
- import { cx, css } from '../styles';
10
- const defaultFilterOptions = (options, value, getOptionLabel) => {
11
- if (!options || !options.length) {
12
- return [];
13
- }
14
- return options.filter((option) => {
15
- const labelValue = getOptionLabel(option).trim().toLowerCase();
16
- const searchValue = value.trim().toLowerCase();
17
- return labelValue.includes(searchValue);
18
- });
19
- };
20
- /**
21
- * Styles.
22
- */
23
- const stylesRoot = () => css({
24
- label: 'SelectPicker-root',
25
- position: 'relative',
26
- });
27
- const stylesInput = () => css({
28
- label: 'SelectPicker-input',
29
- outline: 'none',
30
- boxSizing: 'border-box',
31
- width: '100%',
32
- borderRadius: '4px',
33
- padding: '0 calc(var(--pv-size-base-2) + 24px) 0 var(--pv-size-base-2)',
34
- backgroundColor: 'var(--pv-color-gray-1)',
35
- borderStyle: 'solid',
36
- borderWidth: '1px',
37
- borderColor: 'var(--pv-color-gray-8)',
38
- transition: 'background-color 200ms, color 200ms, border-color 200ms',
39
- appearance: 'none',
40
- userSelect: 'none',
41
- textAlign: 'left',
42
- cursor: 'pointer',
43
- '&:hover': {
44
- backgroundColor: 'var(--pv-color-gray-3)',
45
- borderColor: 'var(--pv-color-gray-7)',
46
- },
47
- '&:disabled': {
48
- cursor: 'not-allowed',
49
- backgroundColor: 'var(--pv-color-gray-1)',
50
- borderColor: 'var(--pv-color-gray-5)',
51
- color: 'var(--pv-color-gray-7)',
52
- },
53
- '&:not(:disabled)': {
54
- '&:focus': {
55
- backgroundColor: 'var(--pv-color-secondary-tint-5)',
56
- borderColor: 'var(--pv-color-secondary-tint-3)',
57
- },
58
- },
59
- });
60
- const stylesInputSizeSmall = () => css({
61
- label: 'small',
62
- height: 'var(--pv-size-base-6)',
63
- });
64
- const stylesInputSizeMedium = () => css({
65
- label: 'medium',
66
- height: 'var(--pv-size-base-7)',
67
- });
68
- const stylesInputSizeLarge = () => css({
69
- label: 'large',
70
- height: 'var(--pv-size-base-8)',
71
- });
72
- const stylesNativeInput = () => css({
73
- label: 'SelectPicker-native-input',
74
- bottom: 0,
75
- left: 0,
76
- height: '100%',
77
- position: 'absolute',
78
- opacity: 0,
79
- pointerEvents: 'none',
80
- width: '100%',
81
- boxSizing: 'border-box',
82
- });
83
- const stylesInputSearch = () => css({
84
- label: 'SelectPicker-input-search',
85
- padding: 'var(--pv-size-base-2)',
86
- });
87
- const stylesPopper = () => css({
88
- label: 'SelectPicker-popper',
89
- width: 300,
90
- });
91
- const stylesListBox = () => css({
92
- label: 'SelectPicker-listbox',
93
- maxHeight: '36vh',
94
- overflowY: 'auto',
95
- margin: 0,
96
- listStyleType: 'none',
97
- position: 'relative',
98
- padding: '10px 0',
99
- });
100
- const stylesListBoxState = () => css({
101
- label: 'SelectPicker-listbox-state',
102
- padding: 'var(--pv-size-base-3) var(--pv-size-base-2)',
103
- });
104
- const stylesOption = () => css({
105
- label: 'SelectPicker-option',
106
- padding: '0px var(--pv-size-base-2)',
107
- fontFamily: 'inherit',
108
- outline: 'none',
109
- width: '100%',
110
- height: 'var(--pv-size-base-7)',
111
- textDecoration: 'none',
112
- userSelect: 'none',
113
- cursor: 'pointer',
114
- transition: 'background-color 200ms',
115
- backgroundColor: 'transparent',
116
- border: 'none',
117
- color: 'var(--pv-color-black)',
118
- boxSizing: 'border-box',
119
- display: 'flex',
120
- textAlign: 'left',
121
- alignItems: 'center',
122
- justifyContent: 'flex-start',
123
- '&:hover': {
124
- backgroundColor: 'var(--pv-color-gray-3)',
125
- },
126
- '&[data-focused="true"]': {
127
- backgroundColor: 'var(--pv-color-gray-4)',
128
- },
129
- '&[aria-selected="true"]': {
130
- backgroundColor: 'var(--pv-color-gray-5)',
131
- },
132
- });
133
- const stylesInputArrowIcon = () => css({
134
- label: 'SelectPicker-arrow-icon',
135
- position: 'absolute',
136
- right: '0px',
137
- top: 'calc(50% - 12px)',
138
- pointerEvents: 'none',
139
- margin: '0px var(--pv-size-base)',
140
- color: 'var(--pv-color-gray-10)',
141
- });
142
- const stylesInputArrowIconDisabled = () => css({
143
- label: 'disabled',
144
- color: 'var(--pv-color-gray-7)',
145
- });
146
- const stylesButtonCreateNew = () => css({
147
- label: 'SelectPicker-button-create',
148
- width: '100%',
149
- borderRadius: 0,
150
- justifyContent: 'left',
151
- padding: '0px var(--pv-size-base-2)',
152
- });
153
- /**
154
- *
155
- */
156
- export const SelectPicker = (props) => {
157
- const { options, getOptionLabel, disabled, loading, loadingText, noOptionsText, defaultValue, value: valueProp, id, placeholder, placeholderSearch, name, required, size, createNewText, allowCreateNew, onCreateNew, filterOptions = defaultFilterOptions, onChange, onOpen, } = props;
158
- const [open, setOpen] = React.useState(false);
159
- const [searchValue, setSearchValue] = React.useState('');
160
- const rootRef = React.useRef(null);
161
- const listboxRef = React.useRef(null);
162
- const highlightedIndexRef = React.useRef(-1);
163
- const [value, setValue] = useControllableState({
164
- value: valueProp,
165
- defaultValue,
166
- });
167
- const filteredOptions = open
168
- ? filterOptions(options, searchValue, getOptionLabel)
169
- : [];
170
- const handleClose = () => {
171
- setOpen(false);
172
- setSearchValue('');
173
- };
174
- const handleInputClick = () => {
175
- setOpen(true);
176
- if (onOpen) {
177
- onOpen();
178
- }
179
- };
180
- const selectNewValue = (event, option) => {
181
- setValue(option);
182
- handleClose();
183
- if (onChange) {
184
- onChange(event, option);
185
- }
186
- };
187
- const handleOptionClick = (event) => {
188
- const index = Number(event.currentTarget.getAttribute('data-option-index'));
189
- selectNewValue(event, filteredOptions[index]);
190
- };
191
- const handleAddNewClick = () => {
192
- handleClose();
193
- if (onCreateNew) {
194
- onCreateNew();
195
- }
196
- };
197
- function validOptionIndex(index, direction) {
198
- if (!listboxRef.current || index === -1) {
199
- return -1;
200
- }
201
- let nextFocus = index;
202
- while (true) {
203
- // Out of range
204
- if ((direction === 'next' && nextFocus === filteredOptions.length)
205
- || (direction === 'previous' && nextFocus === -1)) {
206
- return -1;
207
- }
208
- const option = listboxRef.current.querySelector(`[data-option-index="${nextFocus}"]`);
209
- if ((option && !option.hasAttribute('tabindex'))) {
210
- // Move to the next element.
211
- nextFocus += direction === 'next' ? 1 : -1;
212
- }
213
- else {
214
- return nextFocus;
215
- }
216
- }
217
- }
218
- const setHighlightedIndex = (index, reason = 'auto') => {
219
- highlightedIndexRef.current = index;
220
- const listboxNode = listboxRef.current;
221
- if (!listboxNode) {
222
- return;
223
- }
224
- const prevOptionNode = listboxNode.querySelector('[role="option"][data-focused="true"]');
225
- if (prevOptionNode) {
226
- prevOptionNode.setAttribute('data-focused', 'false');
227
- }
228
- // No results.
229
- if (!listboxNode) {
230
- return;
231
- }
232
- if (index === -1) {
233
- listboxNode.scrollTop = 0;
234
- return;
235
- }
236
- const nextOptionNode = listboxNode.querySelector(`[data-option-index="${index}"]`);
237
- if (!nextOptionNode) {
238
- return;
239
- }
240
- nextOptionNode.setAttribute('data-focused', 'true');
241
- // Scroll active descendant into view.
242
- if (listboxNode.scrollHeight > listboxNode.clientHeight && reason !== 'mouse') {
243
- const scrollBottom = listboxNode.clientHeight + listboxNode.scrollTop;
244
- const elementBottom = nextOptionNode.offsetTop + nextOptionNode.offsetHeight;
245
- if (elementBottom > scrollBottom) {
246
- listboxNode.scrollTop = elementBottom - listboxNode.clientHeight;
247
- }
248
- else if (nextOptionNode.offsetTop - nextOptionNode.offsetHeight * 0 < listboxNode.scrollTop) {
249
- listboxNode.scrollTop = nextOptionNode.offsetTop - nextOptionNode.offsetHeight * 0;
250
- }
251
- }
252
- };
253
- const changeHighlightedIndex = (diff, direction = 'next', reason = 'auto') => {
254
- if (!open) {
255
- return;
256
- }
257
- const getNextIndex = () => {
258
- const maxIndex = filteredOptions.length - 1;
259
- if (diff === 'reset') {
260
- return -1;
261
- }
262
- if (diff === 'start') {
263
- return 0;
264
- }
265
- if (diff === 'end') {
266
- return maxIndex;
267
- }
268
- const newIndex = highlightedIndexRef.current + diff;
269
- if (newIndex < 0) {
270
- if (newIndex === -1) {
271
- return -1;
272
- }
273
- if ((highlightedIndexRef.current !== -1) || Math.abs(diff) > 1) {
274
- return 0;
275
- }
276
- return maxIndex;
277
- }
278
- if (newIndex > maxIndex) {
279
- if (newIndex === maxIndex + 1) {
280
- return -1;
281
- }
282
- if (Math.abs(diff) > 1) {
283
- return maxIndex;
284
- }
285
- return 0;
286
- }
287
- return newIndex;
288
- };
289
- const nextIndex = validOptionIndex(getNextIndex(), direction);
290
- setHighlightedIndex(nextIndex, reason);
291
- };
292
- const syncHighlightedIndex = React.useCallback(() => {
293
- if (!open) {
294
- return;
295
- }
296
- if (filteredOptions.length === 0 || value == null) {
297
- changeHighlightedIndex('reset');
298
- return;
299
- }
300
- if (!listboxRef.current) {
301
- return;
302
- }
303
- if (value != null) {
304
- const optionIndex = filteredOptions.findIndex((optionItem) => optionItem === value);
305
- if (optionIndex === -1) {
306
- changeHighlightedIndex('reset');
307
- }
308
- else {
309
- setHighlightedIndex(optionIndex);
310
- }
311
- return;
312
- }
313
- // Prevent the highlighted index to leak outside the boundaries.
314
- if (highlightedIndexRef.current >= filteredOptions.length - 1) {
315
- setHighlightedIndex(filteredOptions.length - 1);
316
- return;
317
- }
318
- setHighlightedIndex(highlightedIndexRef.current);
319
- }, [
320
- filteredOptions.length,
321
- value,
322
- open,
323
- searchValue,
324
- ]);
325
- const handleListboxRef = (node) => {
326
- listboxRef.current = node;
327
- if (!node) {
328
- return;
329
- }
330
- syncHighlightedIndex();
331
- };
332
- const handleInputSearchChange = (event) => {
333
- setSearchValue(event.target.value);
334
- };
335
- const handleInputSearchKeyDown = (event) => {
336
- // Wait until IME is settled.
337
- if (event.which !== 229) {
338
- switch (event.key) {
339
- case 'ArrowDown':
340
- // Prevent cursor move
341
- event.preventDefault();
342
- changeHighlightedIndex(1, 'next', 'keyboard');
343
- break;
344
- case 'ArrowUp':
345
- // Prevent cursor move
346
- event.preventDefault();
347
- changeHighlightedIndex(-1, 'previous', 'keyboard');
348
- break;
349
- case 'Enter':
350
- // Avoid early form validation, let the end-users continue filling the form.
351
- event.preventDefault();
352
- if (highlightedIndexRef.current !== -1 && open) {
353
- const option = filteredOptions[highlightedIndexRef.current];
354
- selectNewValue(event, option);
355
- }
356
- break;
357
- default:
358
- }
359
- }
360
- };
361
- React.useEffect(() => {
362
- syncHighlightedIndex();
363
- }, [syncHighlightedIndex]);
364
- const renderListBoxState = (text) => (React.createElement("div", { className: cx(stylesListBoxState()) }, typeof text === 'string' ? (React.createElement(Typography, { variant: "b2", color: "gray-10" }, text)) : text));
365
- const renderPopoverContent = () => {
366
- if (loading) {
367
- return renderListBoxState(loadingText);
368
- }
369
- if (!filteredOptions.length) {
370
- return renderListBoxState(noOptionsText);
371
- }
372
- return (React.createElement("ul", { role: "listbox", tabIndex: -1, ref: handleListboxRef, className: stylesListBox() }, filteredOptions.map((option, index) => {
373
- const optionLabel = getOptionLabel(option);
374
- const selected = option === value;
375
- return (
376
- // eslint-disable-next-line jsx-a11y/click-events-have-key-events
377
- React.createElement("li", {
378
- // eslint-disable-next-line react/no-array-index-key
379
- key: index, role: "option", tabIndex: -1, onClick: handleOptionClick, "aria-selected": selected, "data-option-index": index, className: stylesOption() },
380
- React.createElement(Typography, { variant: "b3", color: "inherit", noWrap: true }, optionLabel)));
381
- })));
382
- };
383
- return (React.createElement(React.Fragment, null,
384
- React.createElement("div", { className: stylesRoot() },
385
- React.createElement(Typography, { noWrap: true, component: "button", variant: "c1", "aria-haspopup": "listbox", "aria-expanded": open, onClick: handleInputClick, ref: rootRef, color: value ? 'black' : 'gray-9', className: cx({
386
- [stylesInput()]: true,
387
- [stylesInputSizeSmall()]: size === 'small',
388
- [stylesInputSizeMedium()]: size === 'medium',
389
- [stylesInputSizeLarge()]: size === 'large',
390
- }),
391
- // @ts-ignore
392
- type: "button",
393
- // @ts-ignore
394
- disabled: disabled }, value ? getOptionLabel(value) : placeholder),
395
- React.createElement("input", { type: "text", value: JSON.stringify(value) || '', tabIndex: -1, "aria-hidden": "true", className: stylesNativeInput(), autoComplete: "off", id: id, name: name, required: required, onChange: () => { }, disabled: disabled }),
396
- React.createElement(ArrowDropDownIcon, { className: cx({
397
- [stylesInputArrowIcon()]: true,
398
- [stylesInputArrowIconDisabled()]: disabled,
399
- }), "aria-hidden": true })),
400
- React.createElement(Popover, { open: open, anchorEl: rootRef.current, onClose: handleClose, placement: "bottom-start", className: stylesPopper(), allowUseSameWidth: true },
401
- React.createElement(Box, { borderColor: "gray-3", borderPosition: "bottom", borderStyle: "solid", borderWidth: 1 },
402
- React.createElement(TextField, { type: "search", onChange: handleInputSearchChange, onKeyDown: handleInputSearchKeyDown, value: searchValue, placeholder: placeholderSearch, className: stylesInputSearch() })),
403
- renderPopoverContent(),
404
- allowCreateNew && (React.createElement(Box, { borderColor: "gray-3", borderPosition: "top", borderStyle: "solid", borderWidth: 1 },
405
- React.createElement(Button, { color: "secondary", className: stylesButtonCreateNew(), textVariant: "b3", onClick: handleAddNewClick, startIcon: React.createElement(PlusIcon, null) }, createNewText))))));
406
- };
407
- // @ts-ignore
408
- SelectPicker.defaultProps = {
409
- disabled: false,
410
- loading: false,
411
- loadingText: 'Loading...',
412
- noOptionsText: 'No options',
413
- createNewText: 'Create new',
414
- placeholderSearch: 'Search',
415
- size: 'medium',
416
- allowCreateNew: false,
417
- };
418
- //# sourceMappingURL=select_picker.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"select_picker.js","sourceRoot":"","sources":["../../../src/SelectPicker/select_picker.tsx"],"names":[],"mappings":"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"}
@@ -1,19 +0,0 @@
1
- import * as React from 'react';
2
- export declare type ComboBoxChangeEventType = React.ChangeEvent<{
3
- value: string[];
4
- name?: string;
5
- }>;
6
- declare type OptionType = {
7
- value: string;
8
- label: string;
9
- disabled?: boolean;
10
- };
11
- declare type BaseProps = {
12
- options: OptionType[];
13
- name?: string;
14
- defaultValue?: string[];
15
- onChange?: (event: ComboBoxChangeEventType) => void;
16
- label?: string;
17
- };
18
- export declare const ComboBox: React.ForwardRefExoticComponent<BaseProps & Omit<React.HTMLAttributes<HTMLDivElement>, "children" | "onChange"> & React.RefAttributes<HTMLDivElement>>;
19
- export {};
@@ -1 +0,0 @@
1
- export { ComboBox, ComboBoxChangeEventType } from './combo_box';
@@ -1 +0,0 @@
1
- export { SelectPicker } from './select_picker';
@@ -1,89 +0,0 @@
1
- import React from 'react';
2
- declare type FilterOptionsType = <T>(options: ReadonlyArray<T>, value: string, getOptionLabel: (option: T) => string) => ReadonlyArray<T>;
3
- export declare type SelectPickerProps<T> = {
4
- /**
5
- * Array of options.
6
- */
7
- options: ReadonlyArray<T>;
8
- /**
9
- * Used to determine the string value for a given option. It's used to fill the input.
10
- */
11
- getOptionLabel: (option: T) => string;
12
- /**
13
- * If `true`, the component is disabled.
14
- */
15
- disabled?: boolean;
16
- /**
17
- * If `true`, the component is in a loading state.
18
- */
19
- loading?: boolean;
20
- /**
21
- * Text to display when in a loading state.
22
- */
23
- loadingText?: React.ReactNode;
24
- /**
25
- * Text to display when there are no options.
26
- */
27
- noOptionsText?: React.ReactNode;
28
- /**
29
- * The default value. Use when the component is not controlled.
30
- */
31
- defaultValue?: T;
32
- /**
33
- * The value of the select.
34
- */
35
- value?: T;
36
- /**
37
- * The id of the `input` element.
38
- */
39
- id?: string;
40
- /**
41
- * The short hint displayed in the `input` before the user enters a value.
42
- */
43
- placeholder?: string;
44
- /**
45
- * The short hint displayed in the search `input` before the user enters a value.
46
- */
47
- placeholderSearch?: string;
48
- /**
49
- * Name attribute of the `input` element.
50
- */
51
- name?: string;
52
- /**
53
- * If `true`, the `input` element is required.
54
- */
55
- required?: boolean;
56
- /**
57
- * The size of the input.
58
- */
59
- size?: ('small' | 'medium' | 'large');
60
- /**
61
- * Text to display when in the create `button` element.
62
- */
63
- createNewText?: string;
64
- /**
65
- * If `true`, the create `button` element will be shown.
66
- */
67
- allowCreateNew?: boolean;
68
- /**
69
- * Callback fired when the create `button` clicked.
70
- */
71
- onCreateNew?: () => void;
72
- /**
73
- * A filter function that determines the options that are eligible.
74
- */
75
- filterOptions?: FilterOptionsType;
76
- /**
77
- * Callback fired when the popup requests to be opened.
78
- */
79
- onOpen?: () => void;
80
- /**
81
- * Callback fired when the value changes.
82
- */
83
- onChange?: (event: React.SyntheticEvent, value: T) => void;
84
- };
85
- /**
86
- *
87
- */
88
- export declare const SelectPicker: <T>(props: SelectPickerProps<T>) => JSX.Element;
89
- export {};