@atlaskit/react-select 0.0.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 (197) hide show
  1. package/CHANGELOG.md +9 -0
  2. package/LICENSE.md +11 -0
  3. package/README.md +10 -0
  4. package/async/package.json +15 -0
  5. package/base/package.json +15 -0
  6. package/creatable/package.json +15 -0
  7. package/dist/cjs/accessibility/helpers.js +34 -0
  8. package/dist/cjs/accessibility/index.js +74 -0
  9. package/dist/cjs/async-creatable.js +27 -0
  10. package/dist/cjs/async.js +30 -0
  11. package/dist/cjs/builtins.js +18 -0
  12. package/dist/cjs/components/containers.js +100 -0
  13. package/dist/cjs/components/control.js +67 -0
  14. package/dist/cjs/components/group.js +79 -0
  15. package/dist/cjs/components/index.js +53 -0
  16. package/dist/cjs/components/indicators.js +214 -0
  17. package/dist/cjs/components/input.js +93 -0
  18. package/dist/cjs/components/internal/a11y-text.js +34 -0
  19. package/dist/cjs/components/internal/dummy-input.js +43 -0
  20. package/dist/cjs/components/internal/index.js +34 -0
  21. package/dist/cjs/components/internal/required-input.js +43 -0
  22. package/dist/cjs/components/internal/scroll-manager.js +57 -0
  23. package/dist/cjs/components/internal/use-scroll-capture.js +132 -0
  24. package/dist/cjs/components/internal/use-scroll-lock.js +149 -0
  25. package/dist/cjs/components/live-region.js +153 -0
  26. package/dist/cjs/components/menu.js +464 -0
  27. package/dist/cjs/components/multi-value.js +129 -0
  28. package/dist/cjs/components/option.js +62 -0
  29. package/dist/cjs/components/placeholder.js +39 -0
  30. package/dist/cjs/components/single-value.js +46 -0
  31. package/dist/cjs/creatable.js +30 -0
  32. package/dist/cjs/diacritics.js +274 -0
  33. package/dist/cjs/filters.js +50 -0
  34. package/dist/cjs/index.js +55 -0
  35. package/dist/cjs/nonce-provider.js +30 -0
  36. package/dist/cjs/select.js +1803 -0
  37. package/dist/cjs/state-manager.js +31 -0
  38. package/dist/cjs/styles.js +66 -0
  39. package/dist/cjs/theme.js +42 -0
  40. package/dist/cjs/types.js +5 -0
  41. package/dist/cjs/use-async.js +156 -0
  42. package/dist/cjs/use-creatable.js +114 -0
  43. package/dist/cjs/use-state-manager.js +83 -0
  44. package/dist/cjs/utils.js +357 -0
  45. package/dist/es2019/accessibility/helpers.js +24 -0
  46. package/dist/es2019/accessibility/index.js +72 -0
  47. package/dist/es2019/async-creatable.js +17 -0
  48. package/dist/es2019/async.js +16 -0
  49. package/dist/es2019/builtins.js +4 -0
  50. package/dist/es2019/components/containers.js +100 -0
  51. package/dist/es2019/components/control.js +62 -0
  52. package/dist/es2019/components/group.js +74 -0
  53. package/dist/es2019/components/index.js +41 -0
  54. package/dist/es2019/components/indicators.js +211 -0
  55. package/dist/es2019/components/input.js +88 -0
  56. package/dist/es2019/components/internal/a11y-text.js +25 -0
  57. package/dist/es2019/components/internal/dummy-input.js +36 -0
  58. package/dist/es2019/components/internal/index.js +4 -0
  59. package/dist/es2019/components/internal/required-input.js +35 -0
  60. package/dist/es2019/components/internal/scroll-manager.js +49 -0
  61. package/dist/es2019/components/internal/use-scroll-capture.js +128 -0
  62. package/dist/es2019/components/internal/use-scroll-lock.js +143 -0
  63. package/dist/es2019/components/live-region.js +151 -0
  64. package/dist/es2019/components/menu.js +466 -0
  65. package/dist/es2019/components/multi-value.js +134 -0
  66. package/dist/es2019/components/option.js +57 -0
  67. package/dist/es2019/components/placeholder.js +34 -0
  68. package/dist/es2019/components/single-value.js +41 -0
  69. package/dist/es2019/creatable.js +15 -0
  70. package/dist/es2019/diacritics.js +264 -0
  71. package/dist/es2019/filters.js +36 -0
  72. package/dist/es2019/index.js +8 -0
  73. package/dist/es2019/nonce-provider.js +19 -0
  74. package/dist/es2019/select.js +1766 -0
  75. package/dist/es2019/state-manager.js +22 -0
  76. package/dist/es2019/styles.js +56 -0
  77. package/dist/es2019/theme.js +36 -0
  78. package/dist/es2019/types.js +1 -0
  79. package/dist/es2019/use-async.js +117 -0
  80. package/dist/es2019/use-creatable.js +81 -0
  81. package/dist/es2019/use-state-manager.js +60 -0
  82. package/dist/es2019/utils.js +309 -0
  83. package/dist/esm/accessibility/helpers.js +24 -0
  84. package/dist/esm/accessibility/index.js +68 -0
  85. package/dist/esm/async-creatable.js +17 -0
  86. package/dist/esm/async.js +16 -0
  87. package/dist/esm/builtins.js +12 -0
  88. package/dist/esm/components/containers.js +96 -0
  89. package/dist/esm/components/control.js +62 -0
  90. package/dist/esm/components/group.js +74 -0
  91. package/dist/esm/components/index.js +43 -0
  92. package/dist/esm/components/indicators.js +209 -0
  93. package/dist/esm/components/input.js +88 -0
  94. package/dist/esm/components/internal/a11y-text.js +27 -0
  95. package/dist/esm/components/internal/dummy-input.js +37 -0
  96. package/dist/esm/components/internal/index.js +4 -0
  97. package/dist/esm/components/internal/required-input.js +36 -0
  98. package/dist/esm/components/internal/scroll-manager.js +49 -0
  99. package/dist/esm/components/internal/use-scroll-capture.js +126 -0
  100. package/dist/esm/components/internal/use-scroll-lock.js +143 -0
  101. package/dist/esm/components/live-region.js +148 -0
  102. package/dist/esm/components/menu.js +460 -0
  103. package/dist/esm/components/multi-value.js +122 -0
  104. package/dist/esm/components/option.js +57 -0
  105. package/dist/esm/components/placeholder.js +34 -0
  106. package/dist/esm/components/single-value.js +41 -0
  107. package/dist/esm/creatable.js +15 -0
  108. package/dist/esm/diacritics.js +268 -0
  109. package/dist/esm/filters.js +43 -0
  110. package/dist/esm/index.js +8 -0
  111. package/dist/esm/nonce-provider.js +20 -0
  112. package/dist/esm/select.js +1794 -0
  113. package/dist/esm/state-manager.js +22 -0
  114. package/dist/esm/styles.js +58 -0
  115. package/dist/esm/theme.js +36 -0
  116. package/dist/esm/types.js +1 -0
  117. package/dist/esm/use-async.js +149 -0
  118. package/dist/esm/use-creatable.js +107 -0
  119. package/dist/esm/use-state-manager.js +76 -0
  120. package/dist/esm/utils.js +328 -0
  121. package/dist/types/accessibility/helpers.d.ts +5 -0
  122. package/dist/types/accessibility/index.d.ts +125 -0
  123. package/dist/types/async-creatable.d.ts +10 -0
  124. package/dist/types/async.d.ts +9 -0
  125. package/dist/types/builtins.d.ts +5 -0
  126. package/dist/types/components/containers.d.ts +50 -0
  127. package/dist/types/components/control.d.ts +33 -0
  128. package/dist/types/components/group.d.ts +53 -0
  129. package/dist/types/components/index.d.ts +73 -0
  130. package/dist/types/components/indicators.d.ts +72 -0
  131. package/dist/types/components/input.d.ts +33 -0
  132. package/dist/types/components/internal/a11y-text.d.ts +8 -0
  133. package/dist/types/components/internal/dummy-input.d.ts +9 -0
  134. package/dist/types/components/internal/index.d.ts +4 -0
  135. package/dist/types/components/internal/required-input.d.ts +10 -0
  136. package/dist/types/components/internal/scroll-manager.d.ts +17 -0
  137. package/dist/types/components/internal/use-scroll-capture.d.ts +12 -0
  138. package/dist/types/components/internal/use-scroll-lock.d.ts +9 -0
  139. package/dist/types/components/live-region.d.ts +24 -0
  140. package/dist/types/components/menu.d.ts +130 -0
  141. package/dist/types/components/multi-value.d.ts +47 -0
  142. package/dist/types/components/option.d.ts +49 -0
  143. package/dist/types/components/placeholder.d.ts +22 -0
  144. package/dist/types/components/single-value.d.ts +28 -0
  145. package/dist/types/creatable.d.ts +10 -0
  146. package/dist/types/diacritics.d.ts +1 -0
  147. package/dist/types/filters.d.ts +15 -0
  148. package/dist/types/index.d.ts +28 -0
  149. package/dist/types/nonce-provider.d.ts +8 -0
  150. package/dist/types/select.d.ts +616 -0
  151. package/dist/types/state-manager.d.ts +17 -0
  152. package/dist/types/styles.d.ts +68 -0
  153. package/dist/types/theme.d.ts +27 -0
  154. package/dist/types/types.d.ts +134 -0
  155. package/dist/types/use-async.d.ts +31 -0
  156. package/dist/types/use-creatable.d.ts +46 -0
  157. package/dist/types/use-state-manager.d.ts +15 -0
  158. package/dist/types/utils.d.ts +44 -0
  159. package/dist/types-ts4.5/accessibility/helpers.d.ts +5 -0
  160. package/dist/types-ts4.5/accessibility/index.d.ts +125 -0
  161. package/dist/types-ts4.5/async-creatable.d.ts +10 -0
  162. package/dist/types-ts4.5/async.d.ts +9 -0
  163. package/dist/types-ts4.5/builtins.d.ts +5 -0
  164. package/dist/types-ts4.5/components/containers.d.ts +50 -0
  165. package/dist/types-ts4.5/components/control.d.ts +33 -0
  166. package/dist/types-ts4.5/components/group.d.ts +53 -0
  167. package/dist/types-ts4.5/components/index.d.ts +73 -0
  168. package/dist/types-ts4.5/components/indicators.d.ts +72 -0
  169. package/dist/types-ts4.5/components/input.d.ts +33 -0
  170. package/dist/types-ts4.5/components/internal/a11y-text.d.ts +8 -0
  171. package/dist/types-ts4.5/components/internal/dummy-input.d.ts +9 -0
  172. package/dist/types-ts4.5/components/internal/index.d.ts +4 -0
  173. package/dist/types-ts4.5/components/internal/required-input.d.ts +10 -0
  174. package/dist/types-ts4.5/components/internal/scroll-manager.d.ts +17 -0
  175. package/dist/types-ts4.5/components/internal/use-scroll-capture.d.ts +12 -0
  176. package/dist/types-ts4.5/components/internal/use-scroll-lock.d.ts +9 -0
  177. package/dist/types-ts4.5/components/live-region.d.ts +24 -0
  178. package/dist/types-ts4.5/components/menu.d.ts +130 -0
  179. package/dist/types-ts4.5/components/multi-value.d.ts +47 -0
  180. package/dist/types-ts4.5/components/option.d.ts +49 -0
  181. package/dist/types-ts4.5/components/placeholder.d.ts +22 -0
  182. package/dist/types-ts4.5/components/single-value.d.ts +28 -0
  183. package/dist/types-ts4.5/creatable.d.ts +10 -0
  184. package/dist/types-ts4.5/diacritics.d.ts +1 -0
  185. package/dist/types-ts4.5/filters.d.ts +15 -0
  186. package/dist/types-ts4.5/index.d.ts +28 -0
  187. package/dist/types-ts4.5/nonce-provider.d.ts +8 -0
  188. package/dist/types-ts4.5/select.d.ts +616 -0
  189. package/dist/types-ts4.5/state-manager.d.ts +17 -0
  190. package/dist/types-ts4.5/styles.d.ts +68 -0
  191. package/dist/types-ts4.5/theme.d.ts +27 -0
  192. package/dist/types-ts4.5/types.d.ts +134 -0
  193. package/dist/types-ts4.5/use-async.d.ts +31 -0
  194. package/dist/types-ts4.5/use-creatable.d.ts +46 -0
  195. package/dist/types-ts4.5/use-state-manager.d.ts +15 -0
  196. package/dist/types-ts4.5/utils.d.ts +44 -0
  197. package/package.json +83 -0
@@ -0,0 +1,22 @@
1
+ import _extends from "@babel/runtime/helpers/extends";
2
+ import React, { forwardRef } from 'react';
3
+ import Select from './select';
4
+ import useStateManager from './use-state-manager';
5
+
6
+ /**
7
+ * __StateManagedSelect__
8
+ *
9
+ * A state managed select {description}.
10
+ *
11
+ * - [Examples](https://atlassian.design/components/{packageName}/examples)
12
+ * - [Code](https://atlassian.design/components/{packageName}/code)
13
+ * - [Usage](https://atlassian.design/components/{packageName}/usage)
14
+ */
15
+
16
+ var StateManagedSelect = /*#__PURE__*/forwardRef(function (props, ref) {
17
+ var baseSelectProps = useStateManager(props);
18
+ return /*#__PURE__*/React.createElement(Select, _extends({
19
+ ref: ref
20
+ }, baseSelectProps));
21
+ });
22
+ export default StateManagedSelect;
@@ -0,0 +1,58 @@
1
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
3
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
4
+ import { containerCSS, indicatorsContainerCSS, valueContainerCSS } from './components/containers';
5
+ import { css as controlCSS } from './components/control';
6
+ import { groupCSS, groupHeadingCSS } from './components/group';
7
+ import { clearIndicatorCSS, dropdownIndicatorCSS, indicatorSeparatorCSS, loadingIndicatorCSS } from './components/indicators';
8
+ import { inputCSS } from './components/input';
9
+ import { loadingMessageCSS, menuCSS, menuListCSS, menuPortalCSS, noOptionsMessageCSS } from './components/menu';
10
+ import { multiValueCSS, multiValueLabelCSS, multiValueRemoveCSS } from './components/multi-value';
11
+ import { optionCSS } from './components/option';
12
+ import { placeholderCSS } from './components/placeholder';
13
+ import { css as singleValueCSS } from './components/single-value';
14
+ export var defaultStyles = {
15
+ clearIndicator: clearIndicatorCSS,
16
+ container: containerCSS,
17
+ control: controlCSS,
18
+ dropdownIndicator: dropdownIndicatorCSS,
19
+ group: groupCSS,
20
+ groupHeading: groupHeadingCSS,
21
+ indicatorsContainer: indicatorsContainerCSS,
22
+ indicatorSeparator: indicatorSeparatorCSS,
23
+ input: inputCSS,
24
+ loadingIndicator: loadingIndicatorCSS,
25
+ loadingMessage: loadingMessageCSS,
26
+ menu: menuCSS,
27
+ menuList: menuListCSS,
28
+ menuPortal: menuPortalCSS,
29
+ multiValue: multiValueCSS,
30
+ multiValueLabel: multiValueLabelCSS,
31
+ multiValueRemove: multiValueRemoveCSS,
32
+ noOptionsMessage: noOptionsMessageCSS,
33
+ option: optionCSS,
34
+ placeholder: placeholderCSS,
35
+ singleValue: singleValueCSS,
36
+ valueContainer: valueContainerCSS
37
+ };
38
+ // Merge Utility
39
+ // Allows consumers to extend a base Select with additional styles
40
+
41
+ export function mergeStyles(source) {
42
+ var target = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
43
+ // initialize with source styles
44
+ var styles = _objectSpread({}, source);
45
+
46
+ // massage in target styles
47
+ Object.keys(target).forEach(function (keyAsString) {
48
+ var key = keyAsString;
49
+ if (source[key]) {
50
+ styles[key] = function (rsCss, props) {
51
+ return target[key](source[key](rsCss, props), props);
52
+ };
53
+ } else {
54
+ styles[key] = target[key];
55
+ }
56
+ });
57
+ return styles;
58
+ }
@@ -0,0 +1,36 @@
1
+ export var colors = {
2
+ primary: '#2684FF',
3
+ primary75: '#4C9AFF',
4
+ primary50: '#B2D4FF',
5
+ primary25: '#DEEBFF',
6
+ danger: '#DE350B',
7
+ dangerLight: '#FFBDAD',
8
+ neutral0: 'hsl(0, 0%, 100%)',
9
+ neutral5: 'hsl(0, 0%, 95%)',
10
+ neutral10: 'hsl(0, 0%, 90%)',
11
+ neutral20: 'hsl(0, 0%, 80%)',
12
+ neutral30: 'hsl(0, 0%, 70%)',
13
+ neutral40: 'hsl(0, 0%, 60%)',
14
+ neutral50: 'hsl(0, 0%, 50%)',
15
+ neutral60: 'hsl(0, 0%, 40%)',
16
+ neutral70: 'hsl(0, 0%, 30%)',
17
+ neutral80: 'hsl(0, 0%, 20%)',
18
+ neutral90: 'hsl(0, 0%, 10%)'
19
+ };
20
+ var borderRadius = 4;
21
+ // Used to calculate consistent margin/padding on elements
22
+ var baseUnit = 4;
23
+ // The minimum height of the control
24
+ var controlHeight = 38;
25
+ // The amount of space between the control and menu */
26
+ var menuGutter = baseUnit * 2;
27
+ export var spacing = {
28
+ baseUnit: baseUnit,
29
+ controlHeight: controlHeight,
30
+ menuGutter: menuGutter
31
+ };
32
+ export var defaultTheme = {
33
+ borderRadius: borderRadius,
34
+ colors: colors,
35
+ spacing: spacing
36
+ };
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,149 @@
1
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
3
+ import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
4
+ var _excluded = ["defaultOptions", "cacheOptions", "loadOptions", "options", "isLoading", "onInputChange", "filterOption"];
5
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
6
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
7
+ import { useCallback, useEffect, useRef, useState } from 'react';
8
+ import { handleInputChange } from './utils';
9
+ // TODO: Fill in the hook {description}.
10
+ /**
11
+ * {description}.
12
+ */
13
+ export default function useAsync(_ref) {
14
+ var _ref$defaultOptions = _ref.defaultOptions,
15
+ propsDefaultOptions = _ref$defaultOptions === void 0 ? false : _ref$defaultOptions,
16
+ _ref$cacheOptions = _ref.cacheOptions,
17
+ cacheOptions = _ref$cacheOptions === void 0 ? false : _ref$cacheOptions,
18
+ propsLoadOptions = _ref.loadOptions,
19
+ propsOptions = _ref.options,
20
+ _ref$isLoading = _ref.isLoading,
21
+ propsIsLoading = _ref$isLoading === void 0 ? false : _ref$isLoading,
22
+ propsOnInputChange = _ref.onInputChange,
23
+ _ref$filterOption = _ref.filterOption,
24
+ filterOption = _ref$filterOption === void 0 ? null : _ref$filterOption,
25
+ restSelectProps = _objectWithoutProperties(_ref, _excluded);
26
+ var propsInputValue = restSelectProps.inputValue;
27
+ var lastRequest = useRef(undefined);
28
+ var mounted = useRef(false);
29
+ var _useState = useState(Array.isArray(propsDefaultOptions) ? propsDefaultOptions : undefined),
30
+ _useState2 = _slicedToArray(_useState, 2),
31
+ defaultOptions = _useState2[0],
32
+ setDefaultOptions = _useState2[1];
33
+ var _useState3 = useState(typeof propsInputValue !== 'undefined' ? propsInputValue : ''),
34
+ _useState4 = _slicedToArray(_useState3, 2),
35
+ stateInputValue = _useState4[0],
36
+ setStateInputValue = _useState4[1];
37
+ var _useState5 = useState(propsDefaultOptions === true),
38
+ _useState6 = _slicedToArray(_useState5, 2),
39
+ isLoading = _useState6[0],
40
+ setIsLoading = _useState6[1];
41
+ var _useState7 = useState(undefined),
42
+ _useState8 = _slicedToArray(_useState7, 2),
43
+ loadedInputValue = _useState8[0],
44
+ setLoadedInputValue = _useState8[1];
45
+ var _useState9 = useState([]),
46
+ _useState10 = _slicedToArray(_useState9, 2),
47
+ loadedOptions = _useState10[0],
48
+ setLoadedOptions = _useState10[1];
49
+ var _useState11 = useState(false),
50
+ _useState12 = _slicedToArray(_useState11, 2),
51
+ passEmptyOptions = _useState12[0],
52
+ setPassEmptyOptions = _useState12[1];
53
+ var _useState13 = useState({}),
54
+ _useState14 = _slicedToArray(_useState13, 2),
55
+ optionsCache = _useState14[0],
56
+ setOptionsCache = _useState14[1];
57
+ var _useState15 = useState(undefined),
58
+ _useState16 = _slicedToArray(_useState15, 2),
59
+ prevDefaultOptions = _useState16[0],
60
+ setPrevDefaultOptions = _useState16[1];
61
+ var _useState17 = useState(undefined),
62
+ _useState18 = _slicedToArray(_useState17, 2),
63
+ prevCacheOptions = _useState18[0],
64
+ setPrevCacheOptions = _useState18[1];
65
+ if (cacheOptions !== prevCacheOptions) {
66
+ setOptionsCache({});
67
+ setPrevCacheOptions(cacheOptions);
68
+ }
69
+ if (propsDefaultOptions !== prevDefaultOptions) {
70
+ setDefaultOptions(Array.isArray(propsDefaultOptions) ? propsDefaultOptions : undefined);
71
+ setPrevDefaultOptions(propsDefaultOptions);
72
+ }
73
+ useEffect(function () {
74
+ mounted.current = true;
75
+ return function () {
76
+ mounted.current = false;
77
+ };
78
+ }, []);
79
+ var loadOptions = useCallback(function (inputValue, callback) {
80
+ if (!propsLoadOptions) {
81
+ return callback();
82
+ }
83
+ var loader = propsLoadOptions(inputValue, callback);
84
+ if (loader && typeof loader.then === 'function') {
85
+ loader.then(callback, function () {
86
+ return callback();
87
+ });
88
+ }
89
+ }, [propsLoadOptions]);
90
+ useEffect(function () {
91
+ if (propsDefaultOptions === true) {
92
+ loadOptions(stateInputValue, function (options) {
93
+ if (!mounted.current) {
94
+ return;
95
+ }
96
+ setDefaultOptions(options || []);
97
+ setIsLoading(!!lastRequest.current);
98
+ });
99
+ }
100
+ // NOTE: this effect is designed to only run when the component mounts,
101
+ // so we don't want to include any hook dependencies
102
+ // eslint-disable-next-line react-hooks/exhaustive-deps
103
+ }, []);
104
+ var onInputChange = useCallback(function (newValue, actionMeta) {
105
+ var inputValue = handleInputChange(newValue, actionMeta, propsOnInputChange);
106
+ if (!inputValue) {
107
+ lastRequest.current = undefined;
108
+ setStateInputValue('');
109
+ setLoadedInputValue('');
110
+ setLoadedOptions([]);
111
+ setIsLoading(false);
112
+ setPassEmptyOptions(false);
113
+ return;
114
+ }
115
+ if (cacheOptions && optionsCache[inputValue]) {
116
+ setStateInputValue(inputValue);
117
+ setLoadedInputValue(inputValue);
118
+ setLoadedOptions(optionsCache[inputValue]);
119
+ setIsLoading(false);
120
+ setPassEmptyOptions(false);
121
+ } else {
122
+ var request = lastRequest.current = {};
123
+ setStateInputValue(inputValue);
124
+ setIsLoading(true);
125
+ setPassEmptyOptions(!loadedInputValue);
126
+ loadOptions(inputValue, function (options) {
127
+ if (!mounted) {
128
+ return;
129
+ }
130
+ if (request !== lastRequest.current) {
131
+ return;
132
+ }
133
+ lastRequest.current = undefined;
134
+ setIsLoading(false);
135
+ setLoadedInputValue(inputValue);
136
+ setLoadedOptions(options || []);
137
+ setPassEmptyOptions(false);
138
+ setOptionsCache(options ? _objectSpread(_objectSpread({}, optionsCache), {}, _defineProperty({}, inputValue, options)) : optionsCache);
139
+ });
140
+ }
141
+ }, [cacheOptions, loadOptions, loadedInputValue, optionsCache, propsOnInputChange]);
142
+ var options = passEmptyOptions ? [] : stateInputValue && loadedInputValue ? loadedOptions : defaultOptions || [];
143
+ return _objectSpread(_objectSpread({}, restSelectProps), {}, {
144
+ options: options,
145
+ isLoading: isLoading || propsIsLoading,
146
+ onInputChange: onInputChange,
147
+ filterOption: filterOption
148
+ });
149
+ }
@@ -0,0 +1,107 @@
1
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
+ import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
3
+ import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
4
+ var _excluded = ["allowCreateWhileLoading", "createOptionPosition", "formatCreateLabel", "isValidNewOption", "getNewOptionData", "onCreateOption", "options", "onChange"];
5
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
6
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
7
+ import { useCallback, useMemo } from 'react';
8
+ import { getOptionLabel as baseGetOptionLabel, getOptionValue as baseGetOptionValue } from './builtins';
9
+ import { cleanValue, valueTernary } from './utils';
10
+ var compareOption = function compareOption() {
11
+ var inputValue = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
12
+ var option = arguments.length > 1 ? arguments[1] : undefined;
13
+ var accessors = arguments.length > 2 ? arguments[2] : undefined;
14
+ var candidate = String(inputValue).toLowerCase();
15
+ var optionValue = String(accessors.getOptionValue(option)).toLowerCase();
16
+ var optionLabel = String(accessors.getOptionLabel(option)).toLowerCase();
17
+ return optionValue === candidate || optionLabel === candidate;
18
+ };
19
+ var builtins = {
20
+ formatCreateLabel: function formatCreateLabel(inputValue) {
21
+ return "Create \"".concat(inputValue, "\"");
22
+ },
23
+ isValidNewOption: function isValidNewOption(inputValue, selectValue, selectOptions, accessors) {
24
+ return !(!inputValue || selectValue.some(function (option) {
25
+ return compareOption(inputValue, option, accessors);
26
+ }) || selectOptions.some(function (option) {
27
+ return compareOption(inputValue, option, accessors);
28
+ }));
29
+ },
30
+ getNewOptionData: function getNewOptionData(inputValue, optionLabel) {
31
+ return {
32
+ label: optionLabel,
33
+ value: inputValue,
34
+ __isNew__: true
35
+ };
36
+ }
37
+ };
38
+
39
+ // TODO: Fill in the hook {description}.
40
+ /**
41
+ * {description}.
42
+ */
43
+ export default function useCreatable(_ref) {
44
+ var _ref$allowCreateWhile = _ref.allowCreateWhileLoading,
45
+ allowCreateWhileLoading = _ref$allowCreateWhile === void 0 ? false : _ref$allowCreateWhile,
46
+ _ref$createOptionPosi = _ref.createOptionPosition,
47
+ createOptionPosition = _ref$createOptionPosi === void 0 ? 'last' : _ref$createOptionPosi,
48
+ _ref$formatCreateLabe = _ref.formatCreateLabel,
49
+ formatCreateLabel = _ref$formatCreateLabe === void 0 ? builtins.formatCreateLabel : _ref$formatCreateLabe,
50
+ _ref$isValidNewOption = _ref.isValidNewOption,
51
+ isValidNewOption = _ref$isValidNewOption === void 0 ? builtins.isValidNewOption : _ref$isValidNewOption,
52
+ _ref$getNewOptionData = _ref.getNewOptionData,
53
+ getNewOptionData = _ref$getNewOptionData === void 0 ? builtins.getNewOptionData : _ref$getNewOptionData,
54
+ onCreateOption = _ref.onCreateOption,
55
+ _ref$options = _ref.options,
56
+ propsOptions = _ref$options === void 0 ? [] : _ref$options,
57
+ propsOnChange = _ref.onChange,
58
+ restSelectProps = _objectWithoutProperties(_ref, _excluded);
59
+ var _restSelectProps$getO = restSelectProps.getOptionValue,
60
+ getOptionValue = _restSelectProps$getO === void 0 ? baseGetOptionValue : _restSelectProps$getO,
61
+ _restSelectProps$getO2 = restSelectProps.getOptionLabel,
62
+ getOptionLabel = _restSelectProps$getO2 === void 0 ? baseGetOptionLabel : _restSelectProps$getO2,
63
+ inputValue = restSelectProps.inputValue,
64
+ isLoading = restSelectProps.isLoading,
65
+ isMulti = restSelectProps.isMulti,
66
+ value = restSelectProps.value,
67
+ name = restSelectProps.name;
68
+ var newOption = useMemo(function () {
69
+ return (
70
+ //@ts-ignore
71
+ isValidNewOption(inputValue, cleanValue(value), propsOptions, {
72
+ getOptionValue: getOptionValue,
73
+ getOptionLabel: getOptionLabel
74
+ }) ? getNewOptionData(inputValue, formatCreateLabel(inputValue)) : undefined
75
+ );
76
+ }, [formatCreateLabel, getNewOptionData, getOptionLabel, getOptionValue, inputValue, isValidNewOption, propsOptions, value]);
77
+ var options = useMemo(function () {
78
+ return (allowCreateWhileLoading || !isLoading) && newOption ? createOptionPosition === 'first' ? [newOption].concat(_toConsumableArray(propsOptions)) : [].concat(_toConsumableArray(propsOptions), [newOption]) : propsOptions;
79
+ }, [allowCreateWhileLoading, createOptionPosition, isLoading, newOption, propsOptions]);
80
+ var onChange = useCallback(function (newValue, actionMeta) {
81
+ if (actionMeta.action !== 'select-option') {
82
+ return propsOnChange(newValue, actionMeta);
83
+ }
84
+ var valueArray = Array.isArray(newValue) ? newValue : [newValue];
85
+ if (valueArray[valueArray.length - 1] === newOption) {
86
+ if (onCreateOption) {
87
+ onCreateOption(inputValue);
88
+ } else {
89
+ var newOptionData = getNewOptionData(inputValue, inputValue);
90
+ var newActionMeta = {
91
+ action: 'create-option',
92
+ name: name,
93
+ option: newOptionData
94
+ };
95
+ propsOnChange(
96
+ //@ts-ignore
97
+ valueTernary(isMulti, [].concat(_toConsumableArray(cleanValue(value)), [newOptionData]), newOptionData), newActionMeta);
98
+ }
99
+ return;
100
+ }
101
+ propsOnChange(newValue, actionMeta);
102
+ }, [getNewOptionData, inputValue, isMulti, name, newOption, onCreateOption, propsOnChange, value]);
103
+ return _objectSpread(_objectSpread({}, restSelectProps), {}, {
104
+ options: options,
105
+ onChange: onChange
106
+ });
107
+ }
@@ -0,0 +1,76 @@
1
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
3
+ import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
4
+ var _excluded = ["defaultInputValue", "defaultMenuIsOpen", "defaultValue", "inputValue", "menuIsOpen", "onChange", "onInputChange", "onMenuClose", "onMenuOpen", "value"];
5
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
6
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
7
+ import { useCallback, useState } from 'react';
8
+ // TODO: Fill in the hook {description}.
9
+ /**
10
+ * {description}.
11
+ */
12
+ export default function useStateManager(_ref) {
13
+ var _ref$defaultInputValu = _ref.defaultInputValue,
14
+ defaultInputValue = _ref$defaultInputValu === void 0 ? '' : _ref$defaultInputValu,
15
+ _ref$defaultMenuIsOpe = _ref.defaultMenuIsOpen,
16
+ defaultMenuIsOpen = _ref$defaultMenuIsOpe === void 0 ? false : _ref$defaultMenuIsOpe,
17
+ _ref$defaultValue = _ref.defaultValue,
18
+ defaultValue = _ref$defaultValue === void 0 ? null : _ref$defaultValue,
19
+ propsInputValue = _ref.inputValue,
20
+ propsMenuIsOpen = _ref.menuIsOpen,
21
+ propsOnChange = _ref.onChange,
22
+ propsOnInputChange = _ref.onInputChange,
23
+ propsOnMenuClose = _ref.onMenuClose,
24
+ propsOnMenuOpen = _ref.onMenuOpen,
25
+ propsValue = _ref.value,
26
+ restSelectProps = _objectWithoutProperties(_ref, _excluded);
27
+ var _useState = useState(propsInputValue !== undefined ? propsInputValue : defaultInputValue),
28
+ _useState2 = _slicedToArray(_useState, 2),
29
+ stateInputValue = _useState2[0],
30
+ setStateInputValue = _useState2[1];
31
+ var _useState3 = useState(propsMenuIsOpen !== undefined ? propsMenuIsOpen : defaultMenuIsOpen),
32
+ _useState4 = _slicedToArray(_useState3, 2),
33
+ stateMenuIsOpen = _useState4[0],
34
+ setStateMenuIsOpen = _useState4[1];
35
+ var _useState5 = useState(propsValue !== undefined ? propsValue : defaultValue),
36
+ _useState6 = _slicedToArray(_useState5, 2),
37
+ stateValue = _useState6[0],
38
+ setStateValue = _useState6[1];
39
+ var onChange = useCallback(function (value, actionMeta) {
40
+ if (typeof propsOnChange === 'function') {
41
+ propsOnChange(value, actionMeta);
42
+ }
43
+ setStateValue(value);
44
+ }, [propsOnChange]);
45
+ var onInputChange = useCallback(function (value, actionMeta) {
46
+ var newValue;
47
+ if (typeof propsOnInputChange === 'function') {
48
+ newValue = propsOnInputChange(value, actionMeta);
49
+ }
50
+ setStateInputValue(newValue !== undefined ? newValue : value);
51
+ }, [propsOnInputChange]);
52
+ var onMenuOpen = useCallback(function () {
53
+ if (typeof propsOnMenuOpen === 'function') {
54
+ propsOnMenuOpen();
55
+ }
56
+ setStateMenuIsOpen(true);
57
+ }, [propsOnMenuOpen]);
58
+ var onMenuClose = useCallback(function () {
59
+ if (typeof propsOnMenuClose === 'function') {
60
+ propsOnMenuClose();
61
+ }
62
+ setStateMenuIsOpen(false);
63
+ }, [propsOnMenuClose]);
64
+ var inputValue = propsInputValue !== undefined ? propsInputValue : stateInputValue;
65
+ var menuIsOpen = propsMenuIsOpen !== undefined ? propsMenuIsOpen : stateMenuIsOpen;
66
+ var value = propsValue !== undefined ? propsValue : stateValue;
67
+ return _objectSpread(_objectSpread({}, restSelectProps), {}, {
68
+ inputValue: inputValue,
69
+ menuIsOpen: menuIsOpen,
70
+ onChange: onChange,
71
+ onInputChange: onInputChange,
72
+ onMenuClose: onMenuClose,
73
+ onMenuOpen: onMenuOpen,
74
+ value: value
75
+ });
76
+ }