@salutejs/plasma-new-hope 0.339.0-canary.2292.18716856420.0 → 0.339.0-canary.2292.18779534490.0

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 (228) hide show
  1. package/cjs/components/Calendar/hooks/useKeyNavigation.js +3 -0
  2. package/cjs/components/Calendar/hooks/useKeyNavigation.js.map +1 -1
  3. package/cjs/components/Pagination/Pagination.css +19 -0
  4. package/cjs/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.css +19 -0
  5. package/cjs/components/Select/Select.css +19 -0
  6. package/cjs/components/Select/Select.js +44 -9
  7. package/cjs/components/Select/Select.js.map +1 -1
  8. package/cjs/components/Select/Select.tokens.js +2 -0
  9. package/cjs/components/Select/Select.tokens.js.map +1 -1
  10. package/cjs/components/Select/hooks/useKeyboardNavigation.js +185 -1
  11. package/cjs/components/Select/hooks/useKeyboardNavigation.js.map +1 -1
  12. package/cjs/components/Select/hooks/usePathMaps.js +7 -3
  13. package/cjs/components/Select/hooks/usePathMaps.js.map +1 -1
  14. package/cjs/components/Select/reducers/treePathReducer.js +87 -0
  15. package/cjs/components/Select/reducers/treePathReducer.js.map +1 -0
  16. package/cjs/components/Select/ui/TreeList/TreeList.css +57 -0
  17. package/cjs/components/Select/ui/TreeList/TreeList.js +96 -0
  18. package/cjs/components/Select/ui/TreeList/TreeList.js.map +1 -0
  19. package/cjs/components/Select/ui/TreeList/TreeList.styles.js +30 -0
  20. package/cjs/components/Select/ui/TreeList/TreeList.styles.js.map +1 -0
  21. package/cjs/components/Select/ui/TreeList/TreeList.styles_1t38mek.css +2 -0
  22. package/cjs/components/Select/ui/TreeList/ui/Item/Item.css +54 -0
  23. package/cjs/components/Select/ui/TreeList/ui/Item/Item.js +130 -0
  24. package/cjs/components/Select/ui/TreeList/ui/Item/Item.js.map +1 -0
  25. package/cjs/components/Select/ui/TreeList/ui/Item/Item.styles.js +214 -0
  26. package/cjs/components/Select/ui/TreeList/ui/Item/Item.styles.js.map +1 -0
  27. package/cjs/components/Select/ui/TreeList/ui/Item/Item.styles_i0dby2.css +15 -0
  28. package/cjs/components/Table/Table.css +19 -0
  29. package/cjs/components/Table/ui/Cell/Cell.css +19 -0
  30. package/cjs/components/Table/ui/EditableCell/EditableCell.css +19 -0
  31. package/cjs/components/Table/ui/HeadCell/HeadCell.css +19 -0
  32. package/cjs/components/Table/ui/HeadCell/ui/Filter/Filter.css +19 -0
  33. package/cjs/components/TextArea/TextArea.js +3 -2
  34. package/cjs/components/TextArea/TextArea.js.map +1 -1
  35. package/cjs/components/TextField/TextField.js +3 -2
  36. package/cjs/components/TextField/TextField.js.map +1 -1
  37. package/cjs/components/Tree/utils/traverseTree.js +2 -23
  38. package/cjs/components/Tree/utils/traverseTree.js.map +1 -1
  39. package/cjs/index.css +19 -0
  40. package/cjs/index.js +2 -0
  41. package/cjs/index.js.map +1 -1
  42. package/cjs/utils/deepCopy.js +30 -0
  43. package/cjs/utils/deepCopy.js.map +1 -0
  44. package/cjs/utils/index.js.map +1 -1
  45. package/emotion/cjs/components/Calendar/hooks/useKeyNavigation.js +3 -0
  46. package/emotion/cjs/components/Select/Select.js +33 -6
  47. package/emotion/cjs/components/Select/Select.tokens.js +2 -0
  48. package/emotion/cjs/components/Select/hooks/useKeyboardNavigation.js +166 -0
  49. package/emotion/cjs/components/Select/hooks/usePathMaps.js +35 -3
  50. package/emotion/cjs/components/Select/reducers/index.js +1 -0
  51. package/emotion/cjs/components/Select/reducers/treePathReducer.js +98 -0
  52. package/emotion/cjs/components/Select/ui/TreeList/TreeList.js +126 -0
  53. package/emotion/cjs/components/Select/ui/TreeList/TreeList.styles.js +36 -0
  54. package/emotion/cjs/components/Select/ui/TreeList/TreeList.types.js +4 -0
  55. package/emotion/cjs/components/Select/ui/TreeList/ui/Item/Item.js +150 -0
  56. package/emotion/cjs/components/Select/ui/TreeList/ui/Item/Item.styles.js +186 -0
  57. package/emotion/cjs/components/Select/ui/TreeList/ui/Item/Item.types.js +4 -0
  58. package/emotion/cjs/components/Select/ui/index.js +1 -0
  59. package/emotion/cjs/components/TextArea/TextArea.js +3 -3
  60. package/emotion/cjs/components/TextField/TextField.js +3 -3
  61. package/emotion/cjs/components/Tree/utils/traverseTree.js +2 -60
  62. package/emotion/cjs/examples/components/Select/Select.config.js +24 -24
  63. package/emotion/cjs/utils/deepCopy.js +82 -0
  64. package/emotion/cjs/utils/index.js +4 -0
  65. package/emotion/es/components/Calendar/hooks/useKeyNavigation.js +3 -0
  66. package/emotion/es/components/Select/Select.js +35 -8
  67. package/emotion/es/components/Select/Select.tokens.js +2 -0
  68. package/emotion/es/components/Select/hooks/useKeyboardNavigation.js +166 -0
  69. package/emotion/es/components/Select/hooks/usePathMaps.js +36 -4
  70. package/emotion/es/components/Select/reducers/index.js +1 -0
  71. package/emotion/es/components/Select/reducers/treePathReducer.js +81 -0
  72. package/emotion/es/components/Select/ui/TreeList/TreeList.js +75 -0
  73. package/emotion/es/components/Select/ui/TreeList/TreeList.styles.js +13 -0
  74. package/emotion/es/components/Select/ui/TreeList/TreeList.types.js +1 -0
  75. package/emotion/es/components/Select/ui/TreeList/ui/Item/Item.js +99 -0
  76. package/emotion/es/components/Select/ui/TreeList/ui/Item/Item.styles.js +122 -0
  77. package/emotion/es/components/Select/ui/TreeList/ui/Item/Item.types.js +1 -0
  78. package/emotion/es/components/Select/ui/index.js +1 -0
  79. package/emotion/es/components/TextArea/TextArea.js +3 -3
  80. package/emotion/es/components/TextField/TextField.js +3 -3
  81. package/emotion/es/components/Tree/utils/traverseTree.js +1 -59
  82. package/emotion/es/examples/components/Select/Select.config.js +24 -24
  83. package/emotion/es/utils/deepCopy.js +72 -0
  84. package/emotion/es/utils/index.js +1 -0
  85. package/es/components/Calendar/hooks/useKeyNavigation.js +3 -0
  86. package/es/components/Calendar/hooks/useKeyNavigation.js.map +1 -1
  87. package/es/components/Pagination/Pagination.css +19 -0
  88. package/es/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.css +19 -0
  89. package/es/components/Select/Select.css +19 -0
  90. package/es/components/Select/Select.js +44 -9
  91. package/es/components/Select/Select.js.map +1 -1
  92. package/es/components/Select/Select.tokens.js +2 -0
  93. package/es/components/Select/Select.tokens.js.map +1 -1
  94. package/es/components/Select/hooks/useKeyboardNavigation.js +185 -1
  95. package/es/components/Select/hooks/useKeyboardNavigation.js.map +1 -1
  96. package/es/components/Select/hooks/usePathMaps.js +7 -3
  97. package/es/components/Select/hooks/usePathMaps.js.map +1 -1
  98. package/es/components/Select/reducers/treePathReducer.js +82 -0
  99. package/es/components/Select/reducers/treePathReducer.js.map +1 -0
  100. package/es/components/Select/ui/TreeList/TreeList.css +57 -0
  101. package/es/components/Select/ui/TreeList/TreeList.js +88 -0
  102. package/es/components/Select/ui/TreeList/TreeList.js.map +1 -0
  103. package/es/components/Select/ui/TreeList/TreeList.styles.js +25 -0
  104. package/es/components/Select/ui/TreeList/TreeList.styles.js.map +1 -0
  105. package/es/components/Select/ui/TreeList/TreeList.styles_1t38mek.css +2 -0
  106. package/es/components/Select/ui/TreeList/ui/Item/Item.css +54 -0
  107. package/es/components/Select/ui/TreeList/ui/Item/Item.js +122 -0
  108. package/es/components/Select/ui/TreeList/ui/Item/Item.js.map +1 -0
  109. package/es/components/Select/ui/TreeList/ui/Item/Item.styles.js +196 -0
  110. package/es/components/Select/ui/TreeList/ui/Item/Item.styles.js.map +1 -0
  111. package/es/components/Select/ui/TreeList/ui/Item/Item.styles_i0dby2.css +15 -0
  112. package/es/components/Table/Table.css +19 -0
  113. package/es/components/Table/ui/Cell/Cell.css +19 -0
  114. package/es/components/Table/ui/EditableCell/EditableCell.css +19 -0
  115. package/es/components/Table/ui/HeadCell/HeadCell.css +19 -0
  116. package/es/components/Table/ui/HeadCell/ui/Filter/Filter.css +19 -0
  117. package/es/components/TextArea/TextArea.js +3 -2
  118. package/es/components/TextArea/TextArea.js.map +1 -1
  119. package/es/components/TextField/TextField.js +3 -2
  120. package/es/components/TextField/TextField.js.map +1 -1
  121. package/es/components/Tree/utils/traverseTree.js +2 -23
  122. package/es/components/Tree/utils/traverseTree.js.map +1 -1
  123. package/es/index.css +19 -0
  124. package/es/index.js +1 -0
  125. package/es/index.js.map +1 -1
  126. package/es/utils/deepCopy.js +26 -0
  127. package/es/utils/deepCopy.js.map +1 -0
  128. package/es/utils/index.js.map +1 -1
  129. package/package.json +4 -4
  130. package/styled-components/cjs/components/Calendar/hooks/useKeyNavigation.js +3 -0
  131. package/styled-components/cjs/components/Select/Select.js +33 -6
  132. package/styled-components/cjs/components/Select/Select.tokens.js +2 -0
  133. package/styled-components/cjs/components/Select/hooks/useKeyboardNavigation.js +166 -0
  134. package/styled-components/cjs/components/Select/hooks/usePathMaps.js +35 -3
  135. package/styled-components/cjs/components/Select/reducers/index.js +1 -0
  136. package/styled-components/cjs/components/Select/reducers/treePathReducer.js +98 -0
  137. package/styled-components/cjs/components/Select/ui/TreeList/TreeList.js +126 -0
  138. package/styled-components/cjs/components/Select/ui/TreeList/TreeList.styles.js +50 -0
  139. package/styled-components/cjs/components/Select/ui/TreeList/TreeList.types.js +4 -0
  140. package/styled-components/cjs/components/Select/ui/TreeList/ui/Item/Item.js +150 -0
  141. package/styled-components/cjs/components/Select/ui/TreeList/ui/Item/Item.styles.js +300 -0
  142. package/styled-components/cjs/components/Select/ui/TreeList/ui/Item/Item.types.js +4 -0
  143. package/styled-components/cjs/components/Select/ui/index.js +1 -0
  144. package/styled-components/cjs/components/TextArea/TextArea.js +2 -2
  145. package/styled-components/cjs/components/TextField/TextField.js +2 -2
  146. package/styled-components/cjs/components/Tree/utils/traverseTree.js +2 -60
  147. package/styled-components/cjs/examples/components/Select/Select.config.js +12 -4
  148. package/styled-components/cjs/utils/deepCopy.js +82 -0
  149. package/styled-components/cjs/utils/index.js +4 -0
  150. package/styled-components/es/components/Calendar/hooks/useKeyNavigation.js +3 -0
  151. package/styled-components/es/components/Select/Select.js +35 -8
  152. package/styled-components/es/components/Select/Select.tokens.js +2 -0
  153. package/styled-components/es/components/Select/hooks/useKeyboardNavigation.js +166 -0
  154. package/styled-components/es/components/Select/hooks/usePathMaps.js +36 -4
  155. package/styled-components/es/components/Select/reducers/index.js +1 -0
  156. package/styled-components/es/components/Select/reducers/treePathReducer.js +81 -0
  157. package/styled-components/es/components/Select/ui/TreeList/TreeList.js +75 -0
  158. package/styled-components/es/components/Select/ui/TreeList/TreeList.styles.js +27 -0
  159. package/styled-components/es/components/Select/ui/TreeList/TreeList.types.js +1 -0
  160. package/styled-components/es/components/Select/ui/TreeList/ui/Item/Item.js +99 -0
  161. package/styled-components/es/components/Select/ui/TreeList/ui/Item/Item.styles.js +236 -0
  162. package/styled-components/es/components/Select/ui/TreeList/ui/Item/Item.types.js +1 -0
  163. package/styled-components/es/components/Select/ui/index.js +1 -0
  164. package/styled-components/es/components/TextArea/TextArea.js +2 -2
  165. package/styled-components/es/components/TextField/TextField.js +2 -2
  166. package/styled-components/es/components/Tree/utils/traverseTree.js +1 -59
  167. package/styled-components/es/examples/components/Select/Select.config.js +12 -4
  168. package/styled-components/es/utils/deepCopy.js +72 -0
  169. package/styled-components/es/utils/index.js +1 -0
  170. package/types/components/Autocomplete/ui/TextField/TextField.styles.d.ts.map +1 -1
  171. package/types/components/Calendar/hooks/useKeyNavigation.d.ts.map +1 -1
  172. package/types/components/Combobox/ComboboxNew/ui/Target/Target.styles.d.ts.map +1 -1
  173. package/types/components/DatePicker/SingleDate/SingleDate.styles.d.ts.map +1 -1
  174. package/types/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.styles.d.ts +12 -0
  175. package/types/components/Pagination/ui/PaginationSelectPerPage/PaginationSelectPerPage.styles.d.ts.map +1 -1
  176. package/types/components/Range/Range.styles.d.ts.map +1 -1
  177. package/types/components/Select/Select.d.ts.map +1 -1
  178. package/types/components/Select/Select.tokens.d.ts +2 -0
  179. package/types/components/Select/Select.tokens.d.ts.map +1 -1
  180. package/types/components/Select/Select.types.d.ts +26 -2
  181. package/types/components/Select/Select.types.d.ts.map +1 -1
  182. package/types/components/Select/hooks/useKeyboardNavigation.d.ts +6 -2
  183. package/types/components/Select/hooks/useKeyboardNavigation.d.ts.map +1 -1
  184. package/types/components/Select/hooks/usePathMaps.d.ts +2 -1
  185. package/types/components/Select/hooks/usePathMaps.d.ts.map +1 -1
  186. package/types/components/Select/reducers/index.d.ts +1 -0
  187. package/types/components/Select/reducers/index.d.ts.map +1 -1
  188. package/types/components/Select/reducers/treePathReducer.d.ts +14 -0
  189. package/types/components/Select/reducers/treePathReducer.d.ts.map +1 -0
  190. package/types/components/Select/ui/Target/ui/Textfield/Textfield.styles.d.ts.map +1 -1
  191. package/types/components/Select/ui/TreeList/TreeList.d.ts +4 -0
  192. package/types/components/Select/ui/TreeList/TreeList.d.ts.map +1 -0
  193. package/types/components/Select/ui/TreeList/TreeList.styles.d.ts +6 -0
  194. package/types/components/Select/ui/TreeList/TreeList.styles.d.ts.map +1 -0
  195. package/types/components/Select/ui/TreeList/TreeList.types.d.ts +11 -0
  196. package/types/components/Select/ui/TreeList/TreeList.types.d.ts.map +1 -0
  197. package/types/components/Select/ui/TreeList/ui/Item/Item.d.ts +4 -0
  198. package/types/components/Select/ui/TreeList/ui/Item/Item.d.ts.map +1 -0
  199. package/types/components/Select/ui/TreeList/ui/Item/Item.styles.d.ts +64 -0
  200. package/types/components/Select/ui/TreeList/ui/Item/Item.styles.d.ts.map +1 -0
  201. package/types/components/Select/ui/TreeList/ui/Item/Item.types.d.ts +14 -0
  202. package/types/components/Select/ui/TreeList/ui/Item/Item.types.d.ts.map +1 -0
  203. package/types/components/Select/ui/index.d.ts +1 -0
  204. package/types/components/Select/ui/index.d.ts.map +1 -1
  205. package/types/components/Slider/components/Double/Double.styles.d.ts.map +1 -1
  206. package/types/components/Table/ui/HeadCell/ui/Filter/Filter.styles.d.ts +12 -0
  207. package/types/components/Table/ui/HeadCell/ui/Filter/Filter.styles.d.ts.map +1 -1
  208. package/types/components/TextArea/TextArea.d.ts.map +1 -1
  209. package/types/components/TextArea/TextArea.types.d.ts +4 -0
  210. package/types/components/TextArea/TextArea.types.d.ts.map +1 -1
  211. package/types/components/TextField/TextField.d.ts.map +1 -1
  212. package/types/components/TextField/TextField.types.d.ts +4 -0
  213. package/types/components/TextField/TextField.types.d.ts.map +1 -1
  214. package/types/components/TimePicker/TimePicker.styles.d.ts.map +1 -1
  215. package/types/components/Tree/utils/traverseTree.d.ts.map +1 -1
  216. package/types/examples/components/Autocomplete/Autocomplete.d.ts.map +1 -1
  217. package/types/examples/components/Mask/Mask.d.ts.map +1 -1
  218. package/types/examples/components/NumberFormat/NumberFormat.d.ts.map +1 -1
  219. package/types/examples/components/Select/Select.config.d.ts.map +1 -1
  220. package/types/examples/components/Select/Select.d.ts +12 -0
  221. package/types/examples/components/Select/Select.d.ts.map +1 -1
  222. package/types/examples/components/TextArea/TextArea.d.ts +8 -0
  223. package/types/examples/components/TextArea/TextArea.d.ts.map +1 -1
  224. package/types/examples/components/TextField/TextField.d.ts.map +1 -1
  225. package/types/utils/deepCopy.d.ts +2 -0
  226. package/types/utils/deepCopy.d.ts.map +1 -0
  227. package/types/utils/index.d.ts +1 -0
  228. package/types/utils/index.d.ts.map +1 -1
@@ -0,0 +1,98 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ function _export(target, all) {
6
+ for(var name in all)Object.defineProperty(target, name, {
7
+ enumerable: true,
8
+ get: Object.getOwnPropertyDescriptor(all, name).get
9
+ });
10
+ }
11
+ _export(exports, {
12
+ get keyExists () {
13
+ return keyExists;
14
+ },
15
+ get treePathReducer () {
16
+ return treePathReducer;
17
+ }
18
+ });
19
+ var _utils = require("../../../utils");
20
+ function _type_of(obj) {
21
+ "@swc/helpers - typeof";
22
+ return obj && typeof Symbol !== "undefined" && obj.constructor === Symbol ? "symbol" : typeof obj;
23
+ }
24
+ var keyExists = function(obj, path) {
25
+ if ((typeof obj === "undefined" ? "undefined" : _type_of(obj)) !== 'object' || obj === null || !Array.isArray(path)) {
26
+ return false;
27
+ }
28
+ var current = obj;
29
+ for(var i = 0; i < path.length; i++){
30
+ var key = path[i];
31
+ if (current === null || (typeof current === "undefined" ? "undefined" : _type_of(current)) !== 'object' || !(key in current)) {
32
+ return false;
33
+ }
34
+ current = current[key];
35
+ }
36
+ return true;
37
+ };
38
+ function createObjectAtPath(obj, path) {
39
+ if ((typeof obj === "undefined" ? "undefined" : _type_of(obj)) !== 'object' || obj === null) {
40
+ return;
41
+ }
42
+ var current = obj;
43
+ for(var i = 0; i < path.length; i++){
44
+ var key = path[i];
45
+ if (i === path.length - 1) {
46
+ current[key] = {};
47
+ break;
48
+ }
49
+ if (current[key] === undefined || current[key] === null) {
50
+ current[key] = {};
51
+ }
52
+ current = current[key];
53
+ }
54
+ return obj;
55
+ }
56
+ function removeObjectAtPath(obj, path) {
57
+ if (path.length === 0) {
58
+ return obj;
59
+ }
60
+ var current = obj;
61
+ for(var i = 0; i < path.length; i++){
62
+ var key = path[i];
63
+ if (current === null || (typeof current === "undefined" ? "undefined" : _type_of(current)) !== 'object' || !(key in current)) {
64
+ return obj;
65
+ }
66
+ if (i === path.length - 1) {
67
+ delete current[key];
68
+ break;
69
+ }
70
+ current = current[key];
71
+ }
72
+ return obj;
73
+ }
74
+ function treePathReducer(state, action) {
75
+ switch(action.type){
76
+ case 'reset':
77
+ {
78
+ return {};
79
+ }
80
+ case 'toggled_level':
81
+ {
82
+ var stateCopy = (0, _utils.deepCopy)(state);
83
+ var isTargetLevelOpened = keyExists(stateCopy, action.value);
84
+ if (isTargetLevelOpened) {
85
+ // нужно закрыть текущий уровень
86
+ removeObjectAtPath(stateCopy, action.value);
87
+ } else {
88
+ // нужно открыть требуемый уровень
89
+ createObjectAtPath(stateCopy, action.value);
90
+ }
91
+ return stateCopy;
92
+ }
93
+ default:
94
+ {
95
+ return state;
96
+ }
97
+ }
98
+ }
@@ -0,0 +1,126 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "TreeList", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return TreeList;
9
+ }
10
+ });
11
+ var _react = /*#__PURE__*/ _interop_require_wildcard(require("react"));
12
+ var _reactvirtual = require("@tanstack/react-virtual");
13
+ var _utils = require("../../../../utils");
14
+ var _Item = require("./ui/Item/Item");
15
+ var _TreeListstyles = require("./TreeList.styles");
16
+ function _getRequireWildcardCache(nodeInterop) {
17
+ if (typeof WeakMap !== "function") return null;
18
+ var cacheBabelInterop = new WeakMap();
19
+ var cacheNodeInterop = new WeakMap();
20
+ return (_getRequireWildcardCache = function(nodeInterop) {
21
+ return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
22
+ })(nodeInterop);
23
+ }
24
+ function _interop_require_wildcard(obj, nodeInterop) {
25
+ if (!nodeInterop && obj && obj.__esModule) {
26
+ return obj;
27
+ }
28
+ if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
29
+ return {
30
+ default: obj
31
+ };
32
+ }
33
+ var cache = _getRequireWildcardCache(nodeInterop);
34
+ if (cache && cache.has(obj)) {
35
+ return cache.get(obj);
36
+ }
37
+ var newObj = {
38
+ __proto__: null
39
+ };
40
+ var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
41
+ for(var key in obj){
42
+ if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
43
+ var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
44
+ if (desc && (desc.get || desc.set)) {
45
+ Object.defineProperty(newObj, key, desc);
46
+ } else {
47
+ newObj[key] = obj[key];
48
+ }
49
+ }
50
+ }
51
+ newObj.default = obj;
52
+ if (cache) {
53
+ cache.set(obj, newObj);
54
+ }
55
+ return newObj;
56
+ }
57
+ var TreeList = function(param) {
58
+ var items = param.items, listMaxHeight = param.listMaxHeight, onScroll = param.onScroll, virtual = param.virtual, beforeList = param.beforeList, afterList = param.afterList;
59
+ if (virtual) {
60
+ return /*#__PURE__*/ _react.default.createElement(VirtualTreeList, {
61
+ items: items,
62
+ listMaxHeight: listMaxHeight,
63
+ onScroll: onScroll,
64
+ beforeList: beforeList,
65
+ afterList: afterList
66
+ });
67
+ }
68
+ return /*#__PURE__*/ _react.default.createElement(_TreeListstyles.ListWrapper, null, /*#__PURE__*/ _react.default.createElement(_TreeListstyles.ScrollContainer, {
69
+ listMaxHeight: listMaxHeight,
70
+ onScroll: onScroll
71
+ }, beforeList, items === null || items === void 0 ? void 0 : items.map(function(item, index) {
72
+ return /*#__PURE__*/ _react.default.createElement(_Item.Item, {
73
+ key: index,
74
+ index: index,
75
+ item: item
76
+ });
77
+ }), afterList));
78
+ };
79
+ var VirtualTreeList = function(param) {
80
+ var _param_items = param.items, items = _param_items === void 0 ? [] : _param_items, listMaxHeight = param.listMaxHeight, onScroll = param.onScroll, beforeList = param.beforeList, afterList = param.afterList;
81
+ var _virtualItems_;
82
+ var parentRef = (0, _react.useRef)(null);
83
+ var virtualizer = (0, _reactvirtual.useVirtualizer)({
84
+ count: items.length,
85
+ getScrollElement: function() {
86
+ return parentRef.current;
87
+ },
88
+ estimateSize: function() {
89
+ return 48;
90
+ }
91
+ });
92
+ var virtualItems = virtualizer.getVirtualItems();
93
+ var _virtualItems__start;
94
+ return /*#__PURE__*/ _react.default.createElement(_TreeListstyles.ListWrapper, null, beforeList, /*#__PURE__*/ _react.default.createElement("div", {
95
+ ref: parentRef,
96
+ style: {
97
+ height: 'auto',
98
+ maxHeight: (0, _utils.getHeightAsNumber)(listMaxHeight),
99
+ overflowY: 'auto'
100
+ },
101
+ onScroll: onScroll
102
+ }, /*#__PURE__*/ _react.default.createElement("div", {
103
+ style: {
104
+ height: virtualizer.getTotalSize(),
105
+ width: '100%',
106
+ position: 'relative'
107
+ }
108
+ }, /*#__PURE__*/ _react.default.createElement("div", {
109
+ style: {
110
+ position: 'absolute',
111
+ top: 0,
112
+ left: 0,
113
+ width: '100%',
114
+ transform: "translateY(".concat((_virtualItems__start = (_virtualItems_ = virtualItems[0]) === null || _virtualItems_ === void 0 ? void 0 : _virtualItems_.start) !== null && _virtualItems__start !== void 0 ? _virtualItems__start : 0, "px)")
115
+ }
116
+ }, virtualItems.map(function(virtualRow) {
117
+ return /*#__PURE__*/ _react.default.createElement("div", {
118
+ key: virtualRow.key,
119
+ "data-index": virtualRow.index,
120
+ ref: virtualizer.measureElement
121
+ }, /*#__PURE__*/ _react.default.createElement(_Item.Item, {
122
+ item: items[virtualRow.index],
123
+ index: virtualRow.index
124
+ }));
125
+ })))), afterList);
126
+ };
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ function _export(target, all) {
6
+ for(var name in all)Object.defineProperty(target, name, {
7
+ enumerable: true,
8
+ get: Object.getOwnPropertyDescriptor(all, name).get
9
+ });
10
+ }
11
+ _export(exports, {
12
+ get ListWrapper () {
13
+ return ListWrapper;
14
+ },
15
+ get ScrollContainer () {
16
+ return ScrollContainer;
17
+ }
18
+ });
19
+ var _styledcomponents = /*#__PURE__*/ _interop_require_default(require("styled-components"));
20
+ var _Selecttokens = require("../../Select.tokens");
21
+ function _interop_require_default(obj) {
22
+ return obj && obj.__esModule ? obj : {
23
+ default: obj
24
+ };
25
+ }
26
+ var ListWrapper = _styledcomponents.default.div.withConfig({
27
+ displayName: "TreeList.styles__ListWrapper",
28
+ componentId: "sc-2a5707f5-0"
29
+ })([
30
+ "width:100%;padding:calc(var(",
31
+ ") + var(",
32
+ ",0rem));border-radius:var(",
33
+ ");box-sizing:border-box;background:var(",
34
+ ");box-shadow:",
35
+ ",inset 0 0 0 var(",
36
+ ",0rem) var(",
37
+ ",transparent);"
38
+ ], _Selecttokens.tokens.padding, _Selecttokens.tokens.dropdownBorderWidth, _Selecttokens.tokens.borderRadius, _Selecttokens.constants.background, _Selecttokens.constants.boxShadow, _Selecttokens.tokens.dropdownBorderWidth, _Selecttokens.tokens.dropdownBorderColor);
39
+ var ScrollContainer = _styledcomponents.default.div.withConfig({
40
+ displayName: "TreeList.styles__ScrollContainer",
41
+ componentId: "sc-2a5707f5-1"
42
+ })([
43
+ "max-height:",
44
+ ";overflow-x:hidden;overflow-y:auto;border-radius:calc(var(",
45
+ ") - 0.125rem - var(",
46
+ ",0rem));"
47
+ ], function(param) {
48
+ var listMaxHeight = param.listMaxHeight;
49
+ return listMaxHeight || 'auto';
50
+ }, _Selecttokens.tokens.borderRadius, _Selecttokens.tokens.dropdownBorderWidth);
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
@@ -0,0 +1,150 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "Item", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return Item;
9
+ }
10
+ });
11
+ var _react = /*#__PURE__*/ _interop_require_wildcard(require("react"));
12
+ var _Selecttokens = require("../../../../Select.tokens");
13
+ var _utils = require("../../../../utils");
14
+ var _treePathReducer = require("../../../../reducers/treePathReducer");
15
+ var _Selectcontext = require("../../../../Select.context");
16
+ var _Itemstyles = require("./Item.styles");
17
+ function _getRequireWildcardCache(nodeInterop) {
18
+ if (typeof WeakMap !== "function") return null;
19
+ var cacheBabelInterop = new WeakMap();
20
+ var cacheNodeInterop = new WeakMap();
21
+ return (_getRequireWildcardCache = function(nodeInterop) {
22
+ return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
23
+ })(nodeInterop);
24
+ }
25
+ function _interop_require_wildcard(obj, nodeInterop) {
26
+ if (!nodeInterop && obj && obj.__esModule) {
27
+ return obj;
28
+ }
29
+ if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
30
+ return {
31
+ default: obj
32
+ };
33
+ }
34
+ var cache = _getRequireWildcardCache(nodeInterop);
35
+ if (cache && cache.has(obj)) {
36
+ return cache.get(obj);
37
+ }
38
+ var newObj = {
39
+ __proto__: null
40
+ };
41
+ var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
42
+ for(var key in obj){
43
+ if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
44
+ var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
45
+ if (desc && (desc.get || desc.set)) {
46
+ Object.defineProperty(newObj, key, desc);
47
+ } else {
48
+ newObj[key] = obj[key];
49
+ }
50
+ }
51
+ }
52
+ newObj.default = obj;
53
+ if (cache) {
54
+ cache.set(obj, newObj);
55
+ }
56
+ return newObj;
57
+ }
58
+ var Item = function(param) {
59
+ var item = param.item, index = param.index;
60
+ var _valueToPathMap_get, _item_items;
61
+ var label = item.label, value = item.value, disabled = item.disabled, isDisabled = item.isDisabled, contentLeft = item.contentLeft, contentRight = item.contentRight;
62
+ var isLeaf = !(item === null || item === void 0 ? void 0 : item.items);
63
+ var _useContext = (0, _react.useContext)(_Selectcontext.Context), checked = _useContext.checked, multiselect = _useContext.multiselect, size = _useContext.size, variant = _useContext.variant, renderItem = _useContext.renderItem, // eslint-disable-next-line @typescript-eslint/ban-ts-comment
64
+ // @ts-ignore
65
+ _checkboxAppearance = _useContext._checkboxAppearance, focusedPath = _useContext.focusedPath, treePath = _useContext.treePath, dispatchTreePath = _useContext.dispatchTreePath, arrowPlacement = _useContext.arrowPlacement, handleItemClick = _useContext.handleItemClick, handleCheckboxChange = _useContext.handleCheckboxChange, valueToPathMap = _useContext.valueToPathMap;
66
+ var itemDisabled = Boolean(disabled || isDisabled);
67
+ var currentItemDepth = (((_valueToPathMap_get = valueToPathMap.get(item.value.toString())) === null || _valueToPathMap_get === void 0 ? void 0 : _valueToPathMap_get.length) || 0) - 1;
68
+ var isCurrentLevelOpened = (0, _treePathReducer.keyExists)(treePath, valueToPathMap.get(value.toString()) || []);
69
+ var withArrowInverse = isCurrentLevelOpened ? _Selecttokens.classes.arrowInverse : undefined;
70
+ var focusedClass = currentItemDepth === focusedPath.length - 1 && index === (focusedPath === null || focusedPath === void 0 ? void 0 : focusedPath[currentItemDepth]) ? _Selecttokens.classes.dropdownItemIsFocused : undefined;
71
+ var handleClick = function(e) {
72
+ if (!isLeaf) {
73
+ dispatchTreePath({
74
+ type: 'toggled_level',
75
+ value: valueToPathMap.get(value.toString()) || []
76
+ });
77
+ }
78
+ if (handleItemClick) {
79
+ handleItemClick(item, e);
80
+ }
81
+ };
82
+ var handleChange = function(e) {
83
+ if (itemDisabled) return;
84
+ e.stopPropagation();
85
+ handleCheckboxChange(item);
86
+ };
87
+ return /*#__PURE__*/ _react.default.createElement(_Itemstyles.ItemWrapper, null, /*#__PURE__*/ _react.default.createElement(_Itemstyles.Wrapper, {
88
+ className: focusedClass,
89
+ onClick: handleClick,
90
+ variant: variant,
91
+ role: "treeitem"
92
+ }, /*#__PURE__*/ _react.default.createElement(_Itemstyles.Offset, {
93
+ depth: currentItemDepth
94
+ }), arrowPlacement === 'left' && /*#__PURE__*/ _react.default.createElement(_Itemstyles.DisclosureIconWrapper, {
95
+ visibility: isLeaf ? 'hidden' : 'visible'
96
+ }, /*#__PURE__*/ _react.default.createElement(_Itemstyles.StyledArrowLeft, {
97
+ size: (0, _utils.sizeToIconSize)(size, variant),
98
+ color: "inherit",
99
+ className: withArrowInverse
100
+ })), multiselect && /*#__PURE__*/ _react.default.createElement(_Itemstyles.IconWrapper, {
101
+ variant: variant
102
+ }, /*#__PURE__*/ _react.default.createElement(_Itemstyles.StyledCheckboxWrapper, {
103
+ onClick: function(e) {
104
+ return e.stopPropagation();
105
+ }
106
+ }, /*#__PURE__*/ _react.default.createElement(_Itemstyles.StyledCheckbox, {
107
+ disabled: itemDisabled,
108
+ checked: Boolean(checked.get(item.value)),
109
+ indeterminate: checked.get(item.value) === 'indeterminate',
110
+ onChange: handleChange,
111
+ appearance: _checkboxAppearance !== null && _checkboxAppearance !== void 0 ? _checkboxAppearance : 'default'
112
+ }))), !multiselect && arrowPlacement === 'right' && /*#__PURE__*/ _react.default.createElement(_Itemstyles.IconWrapper, {
113
+ variant: variant
114
+ }, checked.get(item.value) === 'dot' && /*#__PURE__*/ _react.default.createElement(_Itemstyles.StyledIndicator, {
115
+ size: "s",
116
+ view: "default"
117
+ }), checked.get(item.value) === 'done' && /*#__PURE__*/ _react.default.createElement(_Itemstyles.StyledIconDone, {
118
+ size: (0, _utils.sizeToIconSize)(size, variant),
119
+ color: "inherit"
120
+ })), renderItem ? /*#__PURE__*/ _react.default.createElement(_Itemstyles.StyledText, null, renderItem(item)) : /*#__PURE__*/ _react.default.createElement(_Itemstyles.StyledWrapper, {
121
+ disabled: itemDisabled
122
+ }, /*#__PURE__*/ _react.default.createElement(_Itemstyles.StyledCell, {
123
+ contentLeft: contentLeft,
124
+ contentRight: contentRight,
125
+ // TODO: #1548
126
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
127
+ // @ts-ignore
128
+ title: /*#__PURE__*/ _react.default.createElement("span", null, label)
129
+ })), !multiselect && arrowPlacement === 'left' && /*#__PURE__*/ _react.default.createElement(_Itemstyles.IconWrapper, {
130
+ variant: variant
131
+ }, checked.get(item.value) === 'dot' && /*#__PURE__*/ _react.default.createElement(_Itemstyles.StyledIndicator, {
132
+ size: "s",
133
+ view: "default"
134
+ }), checked.get(item.value) === 'done' && /*#__PURE__*/ _react.default.createElement(_Itemstyles.StyledIconDone, {
135
+ size: (0, _utils.sizeToIconSize)(size, variant),
136
+ color: "inherit"
137
+ })), arrowPlacement === 'right' && /*#__PURE__*/ _react.default.createElement(_Itemstyles.DisclosureIconWrapper, {
138
+ visibility: isLeaf ? 'hidden' : 'visible'
139
+ }, /*#__PURE__*/ _react.default.createElement(_Itemstyles.StyledArrowRight, {
140
+ size: (0, _utils.sizeToIconSize)(size, variant),
141
+ color: "inherit",
142
+ className: withArrowInverse
143
+ }))), !isLeaf && isCurrentLevelOpened && /*#__PURE__*/ _react.default.createElement(_Itemstyles.ChildItems, null, (_item_items = item.items) === null || _item_items === void 0 ? void 0 : _item_items.map(function(item, index) {
144
+ return /*#__PURE__*/ _react.default.createElement(Item, {
145
+ item: item,
146
+ index: index,
147
+ key: index
148
+ });
149
+ })));
150
+ };