@salutejs/plasma-new-hope 0.337.0-canary.2255.18028844305.0 → 0.337.0-canary.2255.18035010233.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 (185) hide show
  1. package/cjs/components/TimePicker/TimePicker.css +93 -0
  2. package/cjs/components/TimePicker/TimePicker.js +732 -0
  3. package/cjs/components/TimePicker/TimePicker.js.map +1 -0
  4. package/cjs/components/TimePicker/TimePicker.styles.js +54 -0
  5. package/cjs/components/TimePicker/TimePicker.styles.js.map +1 -0
  6. package/cjs/components/TimePicker/TimePicker.styles_ar3obv.css +4 -0
  7. package/cjs/components/TimePicker/TimePicker.tokens.js +133 -0
  8. package/cjs/components/TimePicker/TimePicker.tokens.js.map +1 -0
  9. package/cjs/components/TimePicker/hooks/useKeyboardNavigation.js +32 -0
  10. package/cjs/components/TimePicker/hooks/useKeyboardNavigation.js.map +1 -0
  11. package/cjs/components/TimePicker/ui/TimeColumn/TimeColumn.css +7 -0
  12. package/cjs/components/TimePicker/ui/TimeColumn/TimeColumn.js +65 -0
  13. package/cjs/components/TimePicker/ui/TimeColumn/TimeColumn.js.map +1 -0
  14. package/cjs/components/TimePicker/ui/TimeColumn/TimeColumn.styles.js +61 -0
  15. package/cjs/components/TimePicker/ui/TimeColumn/TimeColumn.styles.js.map +1 -0
  16. package/cjs/components/TimePicker/ui/TimeColumn/TimeColumn.styles_juymyb.css +7 -0
  17. package/cjs/components/TimePicker/utils/index.js +139 -0
  18. package/cjs/components/TimePicker/utils/index.js.map +1 -0
  19. package/cjs/components/TimePicker/variations/_disabled/base.js +9 -0
  20. package/cjs/components/TimePicker/variations/_disabled/base.js.map +1 -0
  21. package/cjs/components/TimePicker/variations/_disabled/base_nyid0i.css +1 -0
  22. package/cjs/components/TimePicker/variations/_readonly/base.js +9 -0
  23. package/cjs/components/TimePicker/variations/_readonly/base.js.map +1 -0
  24. package/cjs/components/TimePicker/variations/_readonly/base_zalfas.css +1 -0
  25. package/cjs/components/TimePicker/variations/_size/base.js +9 -0
  26. package/cjs/components/TimePicker/variations/_size/base.js.map +1 -0
  27. package/cjs/components/TimePicker/variations/_size/base_x642ct.css +1 -0
  28. package/cjs/components/TimePicker/variations/_view/base.js +9 -0
  29. package/cjs/components/TimePicker/variations/_view/base.js.map +1 -0
  30. package/cjs/components/TimePicker/variations/_view/base_x642ct.css +1 -0
  31. package/cjs/index.css +17 -0
  32. package/cjs/index.js +6 -0
  33. package/cjs/index.js.map +1 -1
  34. package/emotion/cjs/components/TimePicker/TimePicker.js +916 -0
  35. package/emotion/cjs/components/TimePicker/TimePicker.styles.js +55 -0
  36. package/emotion/cjs/components/TimePicker/TimePicker.tokens.js +142 -0
  37. package/emotion/cjs/components/TimePicker/TimePicker.types.js +4 -0
  38. package/emotion/cjs/components/TimePicker/hooks/useKeyboardNavigation.js +30 -0
  39. package/emotion/cjs/components/TimePicker/index.js +26 -0
  40. package/emotion/cjs/components/TimePicker/ui/TimeColumn/TimeColumn.js +65 -0
  41. package/emotion/cjs/components/TimePicker/ui/TimeColumn/TimeColumn.styles.js +71 -0
  42. package/emotion/cjs/components/TimePicker/ui/TimeColumn/TimeColumn.types.js +4 -0
  43. package/emotion/cjs/components/TimePicker/utils/index.js +152 -0
  44. package/emotion/cjs/components/TimePicker/variations/_disabled/base.js +13 -0
  45. package/emotion/cjs/components/TimePicker/variations/_readonly/base.js +12 -0
  46. package/emotion/cjs/components/TimePicker/variations/_size/base.js +12 -0
  47. package/emotion/cjs/components/TimePicker/variations/_view/base.js +12 -0
  48. package/emotion/cjs/examples/components/Chip/Chip.js +7 -7
  49. package/emotion/cjs/examples/components/Chip/Chip.transparent.config.js +45 -0
  50. package/emotion/cjs/examples/components/Combobox/Combobox.js +15 -0
  51. package/emotion/cjs/examples/components/TimePicker/TimePicker.config.js +35 -0
  52. package/emotion/cjs/examples/components/TimePicker/TimePicker.js +15 -0
  53. package/emotion/cjs/index.js +1 -0
  54. package/emotion/es/components/TimePicker/TimePicker.js +852 -0
  55. package/emotion/es/components/TimePicker/TimePicker.styles.js +27 -0
  56. package/emotion/es/components/TimePicker/TimePicker.tokens.js +124 -0
  57. package/emotion/es/components/TimePicker/TimePicker.types.js +1 -0
  58. package/emotion/es/components/TimePicker/hooks/useKeyboardNavigation.js +20 -0
  59. package/emotion/es/components/TimePicker/index.js +2 -0
  60. package/emotion/es/components/TimePicker/ui/TimeColumn/TimeColumn.js +50 -0
  61. package/emotion/es/components/TimePicker/ui/TimeColumn/TimeColumn.styles.js +33 -0
  62. package/emotion/es/components/TimePicker/ui/TimeColumn/TimeColumn.types.js +1 -0
  63. package/emotion/es/components/TimePicker/utils/index.js +125 -0
  64. package/emotion/es/components/TimePicker/variations/_disabled/base.js +3 -0
  65. package/emotion/es/components/TimePicker/variations/_readonly/base.js +2 -0
  66. package/emotion/es/components/TimePicker/variations/_size/base.js +2 -0
  67. package/emotion/es/components/TimePicker/variations/_view/base.js +2 -0
  68. package/emotion/es/examples/components/Chip/Chip.js +4 -4
  69. package/emotion/es/examples/components/Chip/Chip.transparent.config.js +35 -0
  70. package/emotion/es/examples/components/TimePicker/TimePicker.config.js +25 -0
  71. package/emotion/es/examples/components/TimePicker/TimePicker.js +5 -0
  72. package/emotion/es/index.js +1 -0
  73. package/es/components/TimePicker/TimePicker.css +93 -0
  74. package/es/components/TimePicker/TimePicker.js +722 -0
  75. package/es/components/TimePicker/TimePicker.js.map +1 -0
  76. package/es/components/TimePicker/TimePicker.styles.js +47 -0
  77. package/es/components/TimePicker/TimePicker.styles.js.map +1 -0
  78. package/es/components/TimePicker/TimePicker.styles_ar3obv.css +4 -0
  79. package/es/components/TimePicker/TimePicker.tokens.js +128 -0
  80. package/es/components/TimePicker/TimePicker.tokens.js.map +1 -0
  81. package/es/components/TimePicker/hooks/useKeyboardNavigation.js +28 -0
  82. package/es/components/TimePicker/hooks/useKeyboardNavigation.js.map +1 -0
  83. package/es/components/TimePicker/ui/TimeColumn/TimeColumn.css +7 -0
  84. package/es/components/TimePicker/ui/TimeColumn/TimeColumn.js +56 -0
  85. package/es/components/TimePicker/ui/TimeColumn/TimeColumn.js.map +1 -0
  86. package/es/components/TimePicker/ui/TimeColumn/TimeColumn.styles.js +51 -0
  87. package/es/components/TimePicker/ui/TimeColumn/TimeColumn.styles.js.map +1 -0
  88. package/es/components/TimePicker/ui/TimeColumn/TimeColumn.styles_juymyb.css +7 -0
  89. package/es/components/TimePicker/utils/index.js +131 -0
  90. package/es/components/TimePicker/utils/index.js.map +1 -0
  91. package/es/components/TimePicker/variations/_disabled/base.js +5 -0
  92. package/es/components/TimePicker/variations/_disabled/base.js.map +1 -0
  93. package/es/components/TimePicker/variations/_disabled/base_nyid0i.css +1 -0
  94. package/es/components/TimePicker/variations/_readonly/base.js +5 -0
  95. package/es/components/TimePicker/variations/_readonly/base.js.map +1 -0
  96. package/es/components/TimePicker/variations/_readonly/base_zalfas.css +1 -0
  97. package/es/components/TimePicker/variations/_size/base.js +5 -0
  98. package/es/components/TimePicker/variations/_size/base.js.map +1 -0
  99. package/es/components/TimePicker/variations/_size/base_x642ct.css +1 -0
  100. package/es/components/TimePicker/variations/_view/base.js +5 -0
  101. package/es/components/TimePicker/variations/_view/base.js.map +1 -0
  102. package/es/components/TimePicker/variations/_view/base_x642ct.css +1 -0
  103. package/es/index.css +17 -0
  104. package/es/index.js +2 -0
  105. package/es/index.js.map +1 -1
  106. package/package.json +2 -2
  107. package/styled-components/cjs/components/TimePicker/TimePicker.js +916 -0
  108. package/styled-components/cjs/components/TimePicker/TimePicker.styles.js +258 -0
  109. package/styled-components/cjs/components/TimePicker/TimePicker.tokens.js +142 -0
  110. package/styled-components/cjs/components/TimePicker/TimePicker.types.js +4 -0
  111. package/styled-components/cjs/components/TimePicker/hooks/useKeyboardNavigation.js +30 -0
  112. package/styled-components/cjs/components/TimePicker/index.js +26 -0
  113. package/styled-components/cjs/components/TimePicker/ui/TimeColumn/TimeColumn.js +65 -0
  114. package/styled-components/cjs/components/TimePicker/ui/TimeColumn/TimeColumn.styles.js +112 -0
  115. package/styled-components/cjs/components/TimePicker/ui/TimeColumn/TimeColumn.types.js +4 -0
  116. package/styled-components/cjs/components/TimePicker/utils/index.js +152 -0
  117. package/styled-components/cjs/components/TimePicker/variations/_disabled/base.js +16 -0
  118. package/styled-components/cjs/components/TimePicker/variations/_readonly/base.js +14 -0
  119. package/styled-components/cjs/components/TimePicker/variations/_size/base.js +14 -0
  120. package/styled-components/cjs/components/TimePicker/variations/_view/base.js +14 -0
  121. package/styled-components/cjs/examples/components/Chip/Chip.js +7 -7
  122. package/styled-components/cjs/examples/components/TimePicker/TimePicker.config.js +289 -0
  123. package/styled-components/cjs/examples/components/TimePicker/TimePicker.js +15 -0
  124. package/styled-components/cjs/index.js +1 -0
  125. package/styled-components/es/components/TimePicker/TimePicker.js +852 -0
  126. package/styled-components/es/components/TimePicker/TimePicker.styles.js +195 -0
  127. package/styled-components/es/components/TimePicker/TimePicker.tokens.js +124 -0
  128. package/styled-components/es/components/TimePicker/TimePicker.types.js +1 -0
  129. package/styled-components/es/components/TimePicker/hooks/useKeyboardNavigation.js +20 -0
  130. package/styled-components/es/components/TimePicker/index.js +2 -0
  131. package/styled-components/es/components/TimePicker/ui/TimeColumn/TimeColumn.js +50 -0
  132. package/styled-components/es/components/TimePicker/ui/TimeColumn/TimeColumn.styles.js +74 -0
  133. package/styled-components/es/components/TimePicker/ui/TimeColumn/TimeColumn.types.js +1 -0
  134. package/styled-components/es/components/TimePicker/utils/index.js +125 -0
  135. package/styled-components/es/components/TimePicker/variations/_disabled/base.js +6 -0
  136. package/styled-components/es/components/TimePicker/variations/_readonly/base.js +4 -0
  137. package/styled-components/es/components/TimePicker/variations/_size/base.js +4 -0
  138. package/styled-components/es/components/TimePicker/variations/_view/base.js +4 -0
  139. package/styled-components/es/examples/components/Chip/Chip.js +4 -4
  140. package/styled-components/es/examples/components/TimePicker/TimePicker.config.js +279 -0
  141. package/styled-components/es/examples/components/TimePicker/TimePicker.js +5 -0
  142. package/styled-components/es/index.js +1 -0
  143. package/types/components/TimePicker/TimePicker.d.ts +81 -0
  144. package/types/components/TimePicker/TimePicker.d.ts.map +1 -0
  145. package/types/components/TimePicker/TimePicker.styles.d.ts +303 -0
  146. package/types/components/TimePicker/TimePicker.styles.d.ts.map +1 -0
  147. package/types/components/TimePicker/TimePicker.tokens.d.ts +126 -0
  148. package/types/components/TimePicker/TimePicker.tokens.d.ts.map +1 -0
  149. package/types/components/TimePicker/TimePicker.types.d.ts +139 -0
  150. package/types/components/TimePicker/TimePicker.types.d.ts.map +1 -0
  151. package/types/components/TimePicker/hooks/useKeyboardNavigation.d.ts +14 -0
  152. package/types/components/TimePicker/hooks/useKeyboardNavigation.d.ts.map +1 -0
  153. package/types/components/TimePicker/index.d.ts +4 -0
  154. package/types/components/TimePicker/index.d.ts.map +1 -0
  155. package/types/components/TimePicker/ui/TimeColumn/TimeColumn.d.ts +3 -0
  156. package/types/components/TimePicker/ui/TimeColumn/TimeColumn.d.ts.map +1 -0
  157. package/types/components/TimePicker/ui/TimeColumn/TimeColumn.styles.d.ts +10 -0
  158. package/types/components/TimePicker/ui/TimeColumn/TimeColumn.styles.d.ts.map +1 -0
  159. package/types/components/TimePicker/ui/TimeColumn/TimeColumn.types.d.ts +35 -0
  160. package/types/components/TimePicker/ui/TimeColumn/TimeColumn.types.d.ts.map +1 -0
  161. package/types/components/TimePicker/utils/index.d.ts +20 -0
  162. package/types/components/TimePicker/utils/index.d.ts.map +1 -0
  163. package/types/components/TimePicker/variations/_disabled/base.d.ts +2 -0
  164. package/types/components/TimePicker/variations/_disabled/base.d.ts.map +1 -0
  165. package/types/components/TimePicker/variations/_readonly/base.d.ts +2 -0
  166. package/types/components/TimePicker/variations/_readonly/base.d.ts.map +1 -0
  167. package/types/components/TimePicker/variations/_size/base.d.ts +2 -0
  168. package/types/components/TimePicker/variations/_size/base.d.ts.map +1 -0
  169. package/types/components/TimePicker/variations/_view/base.d.ts +2 -0
  170. package/types/components/TimePicker/variations/_view/base.d.ts.map +1 -0
  171. package/types/examples/components/Chip/Chip.d.ts +2 -2
  172. package/types/examples/components/Chip/Chip.d.ts.map +1 -1
  173. package/types/examples/components/Chip/{Chip.clear.config.d.ts → Chip.transparent.config.d.ts} +1 -1
  174. package/types/examples/components/Chip/Chip.transparent.config.d.ts.map +1 -0
  175. package/types/examples/components/TimePicker/TimePicker.config.d.ts +24 -0
  176. package/types/examples/components/TimePicker/TimePicker.config.d.ts.map +1 -0
  177. package/types/examples/components/TimePicker/TimePicker.d.ts +43 -0
  178. package/types/examples/components/TimePicker/TimePicker.d.ts.map +1 -0
  179. package/types/index.d.ts +1 -0
  180. package/types/index.d.ts.map +1 -1
  181. package/emotion/cjs/examples/components/Chip/Chip.clear.config.js +0 -45
  182. package/emotion/es/examples/components/Chip/Chip.clear.config.js +0 -35
  183. package/types/examples/components/Chip/Chip.clear.config.d.ts.map +0 -1
  184. /package/styled-components/cjs/examples/components/Chip/{Chip.clear.config.js → Chip.transparent.config.js} +0 -0
  185. /package/styled-components/es/examples/components/Chip/{Chip.clear.config.js → Chip.transparent.config.js} +0 -0
@@ -0,0 +1,916 @@
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 timePickerConfig () {
13
+ return timePickerConfig;
14
+ },
15
+ get timePickerRoot () {
16
+ return timePickerRoot;
17
+ }
18
+ });
19
+ var _react = /*#__PURE__*/ _interop_require_wildcard(require("react"));
20
+ var _classnames = /*#__PURE__*/ _interop_require_default(require("classnames"));
21
+ var _utils = require("../../utils");
22
+ var _utils1 = require("./utils");
23
+ var _TimePickerstyles = require("./TimePicker.styles");
24
+ var _TimePickertokens = require("./TimePicker.tokens");
25
+ var _base = require("./variations/_size/base");
26
+ var _base1 = require("./variations/_view/base");
27
+ var _base2 = require("./variations/_disabled/base");
28
+ var _base3 = require("./variations/_readonly/base");
29
+ var _useKeyboardNavigation = require("./hooks/useKeyboardNavigation");
30
+ var _TimeColumn = require("./ui/TimeColumn/TimeColumn");
31
+ function _array_like_to_array(arr, len) {
32
+ if (len == null || len > arr.length) len = arr.length;
33
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
34
+ return arr2;
35
+ }
36
+ function _array_with_holes(arr) {
37
+ if (Array.isArray(arr)) return arr;
38
+ }
39
+ function _array_without_holes(arr) {
40
+ if (Array.isArray(arr)) return _array_like_to_array(arr);
41
+ }
42
+ function _define_property(obj, key, value) {
43
+ if (key in obj) {
44
+ Object.defineProperty(obj, key, {
45
+ value: value,
46
+ enumerable: true,
47
+ configurable: true,
48
+ writable: true
49
+ });
50
+ } else {
51
+ obj[key] = value;
52
+ }
53
+ return obj;
54
+ }
55
+ function _interop_require_default(obj) {
56
+ return obj && obj.__esModule ? obj : {
57
+ default: obj
58
+ };
59
+ }
60
+ function _getRequireWildcardCache(nodeInterop) {
61
+ if (typeof WeakMap !== "function") return null;
62
+ var cacheBabelInterop = new WeakMap();
63
+ var cacheNodeInterop = new WeakMap();
64
+ return (_getRequireWildcardCache = function(nodeInterop) {
65
+ return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
66
+ })(nodeInterop);
67
+ }
68
+ function _interop_require_wildcard(obj, nodeInterop) {
69
+ if (!nodeInterop && obj && obj.__esModule) {
70
+ return obj;
71
+ }
72
+ if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
73
+ return {
74
+ default: obj
75
+ };
76
+ }
77
+ var cache = _getRequireWildcardCache(nodeInterop);
78
+ if (cache && cache.has(obj)) {
79
+ return cache.get(obj);
80
+ }
81
+ var newObj = {
82
+ __proto__: null
83
+ };
84
+ var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
85
+ for(var key in obj){
86
+ if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
87
+ var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
88
+ if (desc && (desc.get || desc.set)) {
89
+ Object.defineProperty(newObj, key, desc);
90
+ } else {
91
+ newObj[key] = obj[key];
92
+ }
93
+ }
94
+ }
95
+ newObj.default = obj;
96
+ if (cache) {
97
+ cache.set(obj, newObj);
98
+ }
99
+ return newObj;
100
+ }
101
+ function _iterable_to_array(iter) {
102
+ if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
103
+ }
104
+ function _iterable_to_array_limit(arr, i) {
105
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
106
+ if (_i == null) return;
107
+ var _arr = [];
108
+ var _n = true;
109
+ var _d = false;
110
+ var _s, _e;
111
+ try {
112
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
113
+ _arr.push(_s.value);
114
+ if (i && _arr.length === i) break;
115
+ }
116
+ } catch (err) {
117
+ _d = true;
118
+ _e = err;
119
+ } finally{
120
+ try {
121
+ if (!_n && _i["return"] != null) _i["return"]();
122
+ } finally{
123
+ if (_d) throw _e;
124
+ }
125
+ }
126
+ return _arr;
127
+ }
128
+ function _non_iterable_rest() {
129
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
130
+ }
131
+ function _non_iterable_spread() {
132
+ throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
133
+ }
134
+ function _object_spread(target) {
135
+ for(var i = 1; i < arguments.length; i++){
136
+ var source = arguments[i] != null ? arguments[i] : {};
137
+ var ownKeys = Object.keys(source);
138
+ if (typeof Object.getOwnPropertySymbols === "function") {
139
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
140
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
141
+ }));
142
+ }
143
+ ownKeys.forEach(function(key) {
144
+ _define_property(target, key, source[key]);
145
+ });
146
+ }
147
+ return target;
148
+ }
149
+ function ownKeys(object, enumerableOnly) {
150
+ var keys = Object.keys(object);
151
+ if (Object.getOwnPropertySymbols) {
152
+ var symbols = Object.getOwnPropertySymbols(object);
153
+ if (enumerableOnly) {
154
+ symbols = symbols.filter(function(sym) {
155
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
156
+ });
157
+ }
158
+ keys.push.apply(keys, symbols);
159
+ }
160
+ return keys;
161
+ }
162
+ function _object_spread_props(target, source) {
163
+ source = source != null ? source : {};
164
+ if (Object.getOwnPropertyDescriptors) {
165
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
166
+ } else {
167
+ ownKeys(Object(source)).forEach(function(key) {
168
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
169
+ });
170
+ }
171
+ return target;
172
+ }
173
+ function _object_without_properties(source, excluded) {
174
+ if (source == null) return {};
175
+ var target = _object_without_properties_loose(source, excluded);
176
+ var key, i;
177
+ if (Object.getOwnPropertySymbols) {
178
+ var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
179
+ for(i = 0; i < sourceSymbolKeys.length; i++){
180
+ key = sourceSymbolKeys[i];
181
+ if (excluded.indexOf(key) >= 0) continue;
182
+ if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
183
+ target[key] = source[key];
184
+ }
185
+ }
186
+ return target;
187
+ }
188
+ function _object_without_properties_loose(source, excluded) {
189
+ if (source == null) return {};
190
+ var target = {};
191
+ var sourceKeys = Object.keys(source);
192
+ var key, i;
193
+ for(i = 0; i < sourceKeys.length; i++){
194
+ key = sourceKeys[i];
195
+ if (excluded.indexOf(key) >= 0) continue;
196
+ target[key] = source[key];
197
+ }
198
+ return target;
199
+ }
200
+ function _sliced_to_array(arr, i) {
201
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
202
+ }
203
+ function _to_consumable_array(arr) {
204
+ return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();
205
+ }
206
+ function _unsupported_iterable_to_array(o, minLen) {
207
+ if (!o) return;
208
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
209
+ var n = Object.prototype.toString.call(o).slice(8, -1);
210
+ if (n === "Object" && o.constructor) n = o.constructor.name;
211
+ if (n === "Map" || n === "Set") return Array.from(n);
212
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
213
+ }
214
+ var timePickerRoot = function(Root) {
215
+ return /*#__PURE__*/ (0, _react.forwardRef)(function(_param, ref) {
216
+ var className = _param.className, _param_opened = _param.opened, opened = _param_opened === void 0 ? false : _param_opened, outerValue = _param.value, label = _param.label, _param_labelPlacement = _param.labelPlacement, labelPlacement = _param_labelPlacement === void 0 ? 'outer' : _param_labelPlacement, keepPlaceholder = _param.keepPlaceholder, _param_required = _param.required, required = _param_required === void 0 ? false : _param_required, _param_requiredPlacement = _param.requiredPlacement, requiredPlacement = _param_requiredPlacement === void 0 ? 'right' : _param_requiredPlacement, _param_hasRequiredIndicator = _param.hasRequiredIndicator, hasRequiredIndicator = _param_hasRequiredIndicator === void 0 ? true : _param_hasRequiredIndicator, placeholder = _param.placeholder, contentLeft = _param.contentLeft, contentRight = _param.contentRight, textBefore = _param.textBefore, textAfter = _param.textAfter, view = _param.view, size = _param.size, _param_disabled = _param.disabled, disabled = _param_disabled === void 0 ? false : _param_disabled, _param_readonly = _param.readonly, readonly = _param_readonly === void 0 ? false : _param_readonly, _param_frame = _param.frame, frame = _param_frame === void 0 ? 'document' : _param_frame, _param_usePortal = _param.usePortal, usePortal = _param_usePortal === void 0 ? false : _param_usePortal, _param_closeOnOverlayClick = _param.closeOnOverlayClick, closeOnOverlayClick = _param_closeOnOverlayClick === void 0 ? true : _param_closeOnOverlayClick, _param_closeOnEsc = _param.closeOnEsc, closeOnEsc = _param_closeOnEsc === void 0 ? true : _param_closeOnEsc, offset = _param.offset, stretched = _param.stretched, _param_dropdownAlign = _param.dropdownAlign, dropdownAlign = _param_dropdownAlign === void 0 ? 'left' : _param_dropdownAlign, dropdownWidth = _param.dropdownWidth, dropdownHeight = _param.dropdownHeight, _param_columnsQuantity = _param.columnsQuantity, columnsQuantity = _param_columnsQuantity === void 0 ? 2 : _param_columnsQuantity, onToggle = _param.onToggle, onFocus = _param.onFocus, onChange = _param.onChange, rest = _object_without_properties(_param, [
217
+ "className",
218
+ "opened",
219
+ "value",
220
+ "label",
221
+ "labelPlacement",
222
+ "keepPlaceholder",
223
+ "required",
224
+ "requiredPlacement",
225
+ "hasRequiredIndicator",
226
+ "placeholder",
227
+ "contentLeft",
228
+ "contentRight",
229
+ "textBefore",
230
+ "textAfter",
231
+ "view",
232
+ "size",
233
+ "disabled",
234
+ "readonly",
235
+ "frame",
236
+ "usePortal",
237
+ "closeOnOverlayClick",
238
+ "closeOnEsc",
239
+ "offset",
240
+ "stretched",
241
+ "dropdownAlign",
242
+ "dropdownWidth",
243
+ "dropdownHeight",
244
+ "columnsQuantity",
245
+ "onToggle",
246
+ "onFocus",
247
+ "onChange"
248
+ ]);
249
+ var inputRef = (0, _react.useRef)(null);
250
+ var timeSelectRootRef = (0, _react.useRef)(null);
251
+ var hoursColumnRef = (0, _react.useRef)(null);
252
+ var minutesColumnRef = (0, _react.useRef)(null);
253
+ var secondsColumnRef = (0, _react.useRef)(null);
254
+ var timeItemRefs = (0, _react.useRef)({});
255
+ var hoursScrollbarRef = (0, _react.useRef)(null);
256
+ var minutesScrollbarRef = (0, _react.useRef)(null);
257
+ var secondsScrollbarRef = (0, _react.useRef)(null);
258
+ var hoursThumbRef = (0, _react.useRef)(null);
259
+ var minutesThumbRef = (0, _react.useRef)(null);
260
+ var secondsThumbRef = (0, _react.useRef)(null);
261
+ var hoursHideTimeoutRef = (0, _react.useRef)(null);
262
+ var minutesHideTimeoutRef = (0, _react.useRef)(null);
263
+ var secondsHideTimeoutRef = (0, _react.useRef)(null);
264
+ var _useState = _sliced_to_array((0, _react.useState)(opened), 2), isInnerOpen = _useState[0], setIsInnerOpen = _useState[1];
265
+ var _useState1 = _sliced_to_array((0, _react.useState)(outerValue || ''), 2), innerTime = _useState1[0], setInnerTime = _useState1[1];
266
+ var _useState2 = _sliced_to_array((0, _react.useState)({
267
+ hours: null,
268
+ minutes: null,
269
+ seconds: null,
270
+ currentColumn: null
271
+ }), 2), activeTime = _useState2[0], setActiveTime = _useState2[1];
272
+ var _useState3 = _sliced_to_array((0, _react.useState)(0), 2), itemHeight = _useState3[0], setItemHeight = _useState3[1];
273
+ var _useState4 = _sliced_to_array((0, _react.useState)(0), 2), gap = _useState4[0], setGap = _useState4[1];
274
+ var _useState5 = _sliced_to_array((0, _react.useState)({
275
+ isVisible: false,
276
+ thumbHeight: 0,
277
+ thumbPosition: 0,
278
+ isDragging: false
279
+ }), 2), hoursScrollbar = _useState5[0], setHoursScrollbar = _useState5[1];
280
+ var _useState6 = _sliced_to_array((0, _react.useState)({
281
+ isVisible: false,
282
+ thumbHeight: 0,
283
+ thumbPosition: 0,
284
+ isDragging: false
285
+ }), 2), minutesScrollbar = _useState6[0], setMinutesScrollbar = _useState6[1];
286
+ var _useState7 = _sliced_to_array((0, _react.useState)({
287
+ isVisible: false,
288
+ thumbHeight: 0,
289
+ thumbPosition: 0,
290
+ isDragging: false
291
+ }), 2), secondsScrollbar = _useState7[0], setSecondsScrollbar = _useState7[1];
292
+ var viewValue = outerValue !== null && outerValue !== void 0 ? outerValue : innerTime;
293
+ var format = columnsQuantity === 3 ? 'HH:mm:ss' : 'HH:mm';
294
+ var hours = (0, _utils1.range)(24);
295
+ var minutes = (0, _utils1.range)(60);
296
+ var seconds = (0, _utils1.range)(60);
297
+ var minScrollbarTrackHeight = 20;
298
+ var calculateScrollbar = (0, _react.useCallback)(function(columnRef) {
299
+ if (!columnRef.current) return {
300
+ thumbHeight: 0,
301
+ thumbPosition: 0
302
+ };
303
+ var _columnRef_current = columnRef.current, scrollTop = _columnRef_current.scrollTop, scrollHeight = _columnRef_current.scrollHeight, clientHeight = _columnRef_current.clientHeight;
304
+ var trackHeight = clientHeight;
305
+ var thumbHeight = Math.max(trackHeight / scrollHeight * trackHeight, minScrollbarTrackHeight);
306
+ var maxScroll = scrollHeight - clientHeight;
307
+ var thumbPosition = maxScroll > 0 ? scrollTop / maxScroll * (trackHeight - thumbHeight) : 0;
308
+ return {
309
+ thumbHeight: thumbHeight,
310
+ thumbPosition: thumbPosition
311
+ };
312
+ }, []);
313
+ var showScrollbarWithDelay = (0, _react.useCallback)(function(setScrollbar, timeoutRef, columnRef) {
314
+ if (timeoutRef.current) {
315
+ clearTimeout(timeoutRef.current);
316
+ }
317
+ updateScrollbar(columnRef, setScrollbar, true);
318
+ timeoutRef.current = setTimeout(function() {
319
+ setScrollbar(function(prev) {
320
+ return _object_spread_props(_object_spread({}, prev), {
321
+ isVisible: false
322
+ });
323
+ });
324
+ timeoutRef.current = null;
325
+ }, 2000);
326
+ }, []);
327
+ var updateScrollbar = (0, _react.useCallback)(function(columnRef, setScrollbar) {
328
+ var show = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : false;
329
+ if (!columnRef.current) return;
330
+ var _calculateScrollbar = calculateScrollbar(columnRef), thumbHeight = _calculateScrollbar.thumbHeight, thumbPosition = _calculateScrollbar.thumbPosition;
331
+ setScrollbar(function(prev) {
332
+ return _object_spread_props(_object_spread({}, prev), {
333
+ thumbHeight: thumbHeight,
334
+ thumbPosition: thumbPosition,
335
+ isVisible: show || prev.isVisible
336
+ });
337
+ });
338
+ }, [
339
+ calculateScrollbar
340
+ ]);
341
+ var handleColumnScroll = (0, _react.useCallback)(function(columnRef, setScrollbar, timeoutRef) {
342
+ showScrollbarWithDelay(setScrollbar, timeoutRef, columnRef);
343
+ }, [
344
+ showScrollbarWithDelay
345
+ ]);
346
+ var createScrollbarDragHandler = (0, _react.useCallback)(function(columnRef, setScrollbar, timeoutRef) {
347
+ return function(e) {
348
+ e.preventDefault();
349
+ var thumb = e.currentTarget;
350
+ var track = thumb.parentElement;
351
+ if (!columnRef.current || !track) return;
352
+ if (timeoutRef.current) {
353
+ clearTimeout(timeoutRef.current);
354
+ timeoutRef.current = null;
355
+ }
356
+ var startY = e.clientY;
357
+ var startThumbPosition = parseFloat(thumb.style.top || '0');
358
+ var trackRect = track.getBoundingClientRect();
359
+ var trackHeight = trackRect.height;
360
+ var thumbHeight = thumb.offsetHeight;
361
+ var _columnRef_current = columnRef.current, scrollHeight = _columnRef_current.scrollHeight, clientHeight = _columnRef_current.clientHeight;
362
+ var maxScroll = scrollHeight - clientHeight;
363
+ var handleMouseMove = function(moveEvent) {
364
+ var deltaY = moveEvent.clientY - startY;
365
+ var newThumbPosition = Math.max(0, Math.min(trackHeight - thumbHeight, startThumbPosition + deltaY));
366
+ var scrollPercentage = newThumbPosition / (trackHeight - thumbHeight);
367
+ var newScrollTop = scrollPercentage * maxScroll;
368
+ if (columnRef.current) {
369
+ columnRef.current.scrollTop = newScrollTop;
370
+ }
371
+ setScrollbar(function(prev) {
372
+ return _object_spread_props(_object_spread({}, prev), {
373
+ thumbPosition: newThumbPosition,
374
+ isDragging: true,
375
+ isVisible: true
376
+ });
377
+ });
378
+ };
379
+ var handleMouseUp = function() {
380
+ document.removeEventListener('mousemove', handleMouseMove);
381
+ document.removeEventListener('mouseup', handleMouseUp);
382
+ setScrollbar(function(prev) {
383
+ return _object_spread_props(_object_spread({}, prev), {
384
+ isDragging: false
385
+ });
386
+ });
387
+ showScrollbarWithDelay(setScrollbar, timeoutRef, columnRef);
388
+ };
389
+ document.addEventListener('mousemove', handleMouseMove);
390
+ document.addEventListener('mouseup', handleMouseUp);
391
+ };
392
+ }, [
393
+ showScrollbarWithDelay
394
+ ]);
395
+ (0, _react.useEffect)(function() {
396
+ return function() {
397
+ [
398
+ hoursHideTimeoutRef,
399
+ minutesHideTimeoutRef,
400
+ secondsHideTimeoutRef
401
+ ].forEach(function(timeoutRef) {
402
+ if (timeoutRef.current) {
403
+ clearTimeout(timeoutRef.current);
404
+ }
405
+ });
406
+ };
407
+ }, []);
408
+ (0, _react.useEffect)(function() {
409
+ if (!isInnerOpen) {
410
+ return;
411
+ }
412
+ setTimeout(function() {
413
+ updateScrollbar(hoursColumnRef, setHoursScrollbar);
414
+ updateScrollbar(minutesColumnRef, setMinutesScrollbar);
415
+ if (columnsQuantity === 3) {
416
+ updateScrollbar(secondsColumnRef, setSecondsScrollbar);
417
+ }
418
+ }, 100);
419
+ }, [
420
+ isInnerOpen,
421
+ columnsQuantity,
422
+ updateScrollbar
423
+ ]);
424
+ (0, _react.useEffect)(function() {
425
+ if (!viewValue) {
426
+ return;
427
+ }
428
+ var timeString = viewValue;
429
+ if (format === 'HH:mm' && viewValue.length > 5) {
430
+ timeString = viewValue.substring(0, 5);
431
+ }
432
+ setInnerTime(viewValue);
433
+ var _timeString_split_map = _sliced_to_array(timeString.split(_utils1.delimiter).map(Number), 3), hh = _timeString_split_map[0], mm = _timeString_split_map[1], ss = _timeString_split_map[2];
434
+ setActiveTime({
435
+ hours: !Number.isNaN(hh) ? hh : null,
436
+ minutes: !Number.isNaN(mm) ? mm : null,
437
+ seconds: format === 'HH:mm:ss' && !Number.isNaN(ss) ? ss : null,
438
+ currentColumn: null
439
+ });
440
+ }, [
441
+ outerValue,
442
+ format
443
+ ]);
444
+ (0, _react.useEffect)(function() {
445
+ if (isInnerOpen && (disabled || readonly)) {
446
+ setIsInnerOpen(false);
447
+ }
448
+ }, [
449
+ disabled,
450
+ readonly
451
+ ]);
452
+ (0, _react.useEffect)(function() {
453
+ if (isInnerOpen && Object.keys(timeItemRefs.current).length > 0) {
454
+ var firstItem = Object.values(timeItemRefs.current)[0];
455
+ if (firstItem) {
456
+ setItemHeight(firstItem.offsetHeight);
457
+ }
458
+ }
459
+ if (isInnerOpen && hoursColumnRef.current) {
460
+ var computedStyle = getComputedStyle(hoursColumnRef.current);
461
+ var gapValue = parseFloat(computedStyle.gap || '0');
462
+ setGap(gapValue);
463
+ }
464
+ }, [
465
+ isInnerOpen
466
+ ]);
467
+ (0, _react.useEffect)(function() {
468
+ if (!isInnerOpen || itemHeight === 0) return;
469
+ var scrollToActiveItem = function(columnRef, index) {
470
+ if (columnRef.current && index !== null) {
471
+ var scrollPosition = index * (itemHeight + gap);
472
+ (0, _utils1.animateScrollTo)(columnRef.current, scrollPosition);
473
+ setTimeout(function() {
474
+ updateScrollbar(columnRef, setHoursScrollbar);
475
+ }, 300);
476
+ }
477
+ };
478
+ scrollToActiveItem(hoursColumnRef, activeTime.hours);
479
+ scrollToActiveItem(minutesColumnRef, activeTime.minutes);
480
+ scrollToActiveItem(secondsColumnRef, activeTime.seconds);
481
+ }, [
482
+ activeTime,
483
+ isInnerOpen,
484
+ itemHeight,
485
+ gap,
486
+ updateScrollbar
487
+ ]);
488
+ (0, _react.useEffect)(function() {
489
+ var hoursColumn = hoursColumnRef.current;
490
+ var minutesColumn = minutesColumnRef.current;
491
+ var secondsColumn = secondsColumnRef.current;
492
+ var handleHoursScroll = function() {
493
+ return handleColumnScroll(hoursColumnRef, setHoursScrollbar, hoursHideTimeoutRef);
494
+ };
495
+ var handleMinutesScroll = function() {
496
+ return handleColumnScroll(minutesColumnRef, setMinutesScrollbar, minutesHideTimeoutRef);
497
+ };
498
+ var handleSecondsScroll = function() {
499
+ return handleColumnScroll(secondsColumnRef, setSecondsScrollbar, secondsHideTimeoutRef);
500
+ };
501
+ if (hoursColumn) {
502
+ hoursColumn.addEventListener('scroll', handleHoursScroll);
503
+ }
504
+ if (minutesColumn) {
505
+ minutesColumn.addEventListener('scroll', handleMinutesScroll);
506
+ }
507
+ if (secondsColumn) {
508
+ secondsColumn.addEventListener('scroll', handleSecondsScroll);
509
+ }
510
+ return function() {
511
+ if (hoursColumn) {
512
+ hoursColumn.removeEventListener('scroll', handleHoursScroll);
513
+ }
514
+ if (minutesColumn) {
515
+ minutesColumn.removeEventListener('scroll', handleMinutesScroll);
516
+ }
517
+ if (secondsColumn) {
518
+ secondsColumn.removeEventListener('scroll', handleSecondsScroll);
519
+ }
520
+ };
521
+ }, [
522
+ isInnerOpen,
523
+ handleColumnScroll
524
+ ]);
525
+ (0, _react.useEffect)(function() {
526
+ var hoursColumn = hoursColumnRef.current;
527
+ var minutesColumn = minutesColumnRef.current;
528
+ var secondsColumn = secondsColumnRef.current;
529
+ var handleHoursMouseEnter = function() {
530
+ return showScrollbarWithDelay(setHoursScrollbar, hoursHideTimeoutRef, hoursColumnRef);
531
+ };
532
+ var handleMinutesMouseEnter = function() {
533
+ return showScrollbarWithDelay(setMinutesScrollbar, minutesHideTimeoutRef, minutesColumnRef);
534
+ };
535
+ var handleSecondsMouseEnter = function() {
536
+ return showScrollbarWithDelay(setSecondsScrollbar, secondsHideTimeoutRef, secondsColumnRef);
537
+ };
538
+ if (hoursColumn) {
539
+ hoursColumn.addEventListener('mouseenter', handleHoursMouseEnter);
540
+ }
541
+ if (minutesColumn) {
542
+ minutesColumn.addEventListener('mouseenter', handleMinutesMouseEnter);
543
+ }
544
+ if (secondsColumn) {
545
+ secondsColumn.addEventListener('mouseenter', handleSecondsMouseEnter);
546
+ }
547
+ return function() {
548
+ if (hoursColumn) {
549
+ hoursColumn.removeEventListener('mouseenter', handleHoursMouseEnter);
550
+ }
551
+ if (minutesColumn) {
552
+ minutesColumn.removeEventListener('mouseenter', handleMinutesMouseEnter);
553
+ }
554
+ if (secondsColumn) {
555
+ secondsColumn.removeEventListener('mouseenter', handleSecondsMouseEnter);
556
+ }
557
+ };
558
+ }, [
559
+ isInnerOpen,
560
+ showScrollbarWithDelay
561
+ ]);
562
+ var handleToggle = function() {
563
+ if (disabled || readonly) return;
564
+ var newState = !isInnerOpen;
565
+ setIsInnerOpen(newState);
566
+ if (newState) {
567
+ setActiveTime(function(prev) {
568
+ return _object_spread_props(_object_spread({}, prev), {
569
+ currentColumn: 'hours'
570
+ });
571
+ });
572
+ }
573
+ onToggle === null || onToggle === void 0 ? void 0 : onToggle(newState);
574
+ };
575
+ var handleCalendarRootClick = function(event) {
576
+ if (disabled || readonly) return;
577
+ if (isInnerOpen && stretched && event.target === (timeSelectRootRef === null || timeSelectRootRef === void 0 ? void 0 : timeSelectRootRef.current)) {
578
+ setIsInnerOpen(false);
579
+ onToggle === null || onToggle === void 0 ? void 0 : onToggle(false);
580
+ }
581
+ };
582
+ var handleTimeItemClick = function(value, column) {
583
+ var isNextColumn = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : true;
584
+ var currentTime = innerTime.split(_utils1.delimiter);
585
+ var newTime = [];
586
+ if (format === 'HH:mm:ss') {
587
+ newTime = _to_consumable_array(currentTime);
588
+ while(newTime.length < 3){
589
+ newTime.push('00');
590
+ }
591
+ } else {
592
+ newTime = _to_consumable_array(currentTime);
593
+ while(newTime.length < 2){
594
+ newTime.push('00');
595
+ }
596
+ newTime = newTime.slice(0, 2);
597
+ }
598
+ switch(column){
599
+ case 'hours':
600
+ newTime[0] = value;
601
+ if (!currentTime[1]) {
602
+ newTime[1] = '00';
603
+ }
604
+ if (format === 'HH:mm:ss' && !currentTime[2]) {
605
+ newTime[2] = '00';
606
+ }
607
+ break;
608
+ case 'minutes':
609
+ newTime[1] = value;
610
+ if (!currentTime[0]) {
611
+ newTime[0] = '00';
612
+ }
613
+ if (format === 'HH:mm:ss' && !currentTime[2]) {
614
+ newTime[2] = '00';
615
+ }
616
+ break;
617
+ case 'seconds':
618
+ if (format === 'HH:mm:ss') {
619
+ newTime[2] = value;
620
+ if (!currentTime[0]) {
621
+ newTime[0] = '00';
622
+ }
623
+ if (!currentTime[1]) {
624
+ newTime[1] = '00';
625
+ }
626
+ }
627
+ break;
628
+ default:
629
+ break;
630
+ }
631
+ var newTimeString = newTime.join(_utils1.delimiter);
632
+ setInnerTime(newTimeString);
633
+ var nextColumn = null;
634
+ if (column === 'hours' && isNextColumn) {
635
+ nextColumn = 'minutes';
636
+ } else if (column === 'minutes' && isNextColumn) {
637
+ nextColumn = format === 'HH:mm:ss' ? 'seconds' : null;
638
+ } else {
639
+ nextColumn = activeTime.currentColumn;
640
+ }
641
+ var newActiveTime = {
642
+ hours: column === 'hours' ? parseInt(value, 10) : activeTime.hours,
643
+ minutes: column === 'minutes' ? parseInt(value, 10) : activeTime.minutes,
644
+ seconds: column === 'seconds' ? parseInt(value, 10) : activeTime.seconds,
645
+ currentColumn: nextColumn
646
+ };
647
+ setActiveTime(newActiveTime);
648
+ onChange === null || onChange === void 0 ? void 0 : onChange({
649
+ value: newTimeString,
650
+ timeValues: {
651
+ hh: parseInt(newTime[0], 10),
652
+ mm: parseInt(newTime[1], 10),
653
+ ss: format === 'HH:mm:ss' ? parseInt(newTime[2] || '0', 10) : null
654
+ }
655
+ });
656
+ };
657
+ var handleInputChange = function(event) {
658
+ var input = event.target.value;
659
+ var cursorPos = event.target.selectionStart;
660
+ var _processTimeInput = (0, _utils1.processTimeInput)(input, format, cursorPos), innerString = _processTimeInput.innerString, values = _processTimeInput.values, newCursorPosition = _processTimeInput.newCursorPosition;
661
+ setInnerTime(innerString);
662
+ setActiveTime(function(prev) {
663
+ return _object_spread_props(_object_spread({}, prev), {
664
+ hours: values.hh,
665
+ minutes: values.mm,
666
+ seconds: values.ss
667
+ });
668
+ });
669
+ if (onChange) {
670
+ onChange(_object_spread_props(_object_spread({}, event), {
671
+ target: _object_spread_props(_object_spread({}, event.target), {
672
+ value: innerString,
673
+ timeValues: values
674
+ })
675
+ }));
676
+ }
677
+ requestAnimationFrame(function() {
678
+ if (inputRef.current) {
679
+ inputRef.current.setSelectionRange(newCursorPosition, newCursorPosition);
680
+ }
681
+ });
682
+ };
683
+ var handleKeyDown = function(event) {
684
+ if (event.key === 'Enter' && !isInnerOpen) {
685
+ event.preventDefault();
686
+ setIsInnerOpen(true);
687
+ setActiveTime(function(prev) {
688
+ return _object_spread_props(_object_spread({}, prev), {
689
+ currentColumn: 'hours'
690
+ });
691
+ });
692
+ onToggle === null || onToggle === void 0 ? void 0 : onToggle(true);
693
+ return;
694
+ }
695
+ if (!isInnerOpen) {
696
+ return;
697
+ }
698
+ var currentColumn = activeTime.currentColumn;
699
+ if (!currentColumn) {
700
+ return;
701
+ }
702
+ var newIndex = null;
703
+ var newColumn = currentColumn;
704
+ if ([
705
+ 'ArrowUp',
706
+ 'ArrowDown',
707
+ 'Enter'
708
+ ].includes(event.key)) {
709
+ event.preventDefault();
710
+ }
711
+ if ([
712
+ 'ArrowRight'
713
+ ].includes(event.key) && currentColumn !== 'seconds') {
714
+ event.preventDefault();
715
+ }
716
+ if ([
717
+ 'ArrowLeft'
718
+ ].includes(event.key) && currentColumn !== 'hours') {
719
+ event.preventDefault();
720
+ }
721
+ switch(event.key){
722
+ case 'ArrowUp':
723
+ var _activeTime_currentColumn;
724
+ newIndex = Math.max(0, ((_activeTime_currentColumn = activeTime[currentColumn]) !== null && _activeTime_currentColumn !== void 0 ? _activeTime_currentColumn : 0) - 1);
725
+ if (newIndex !== null) {
726
+ var value = newIndex.toString().padStart(2, '0');
727
+ handleTimeItemClick(value, currentColumn, false);
728
+ }
729
+ break;
730
+ case 'ArrowDown':
731
+ case 'Tab':
732
+ event.preventDefault();
733
+ var _activeTime_currentColumn1;
734
+ newIndex = Math.min(currentColumn === 'hours' ? 23 : 59, ((_activeTime_currentColumn1 = activeTime[currentColumn]) !== null && _activeTime_currentColumn1 !== void 0 ? _activeTime_currentColumn1 : 0) + 1);
735
+ if (newIndex !== null) {
736
+ var value1 = newIndex.toString().padStart(2, '0');
737
+ handleTimeItemClick(value1, currentColumn, false);
738
+ }
739
+ break;
740
+ case 'ArrowRight':
741
+ case 'Enter':
742
+ if (currentColumn === 'hours') newColumn = 'minutes';
743
+ else if (currentColumn === 'minutes' && format === 'HH:mm:ss') newColumn = 'seconds';
744
+ var _activeTime_newColumn;
745
+ newIndex = (_activeTime_newColumn = activeTime[newColumn]) !== null && _activeTime_newColumn !== void 0 ? _activeTime_newColumn : 0;
746
+ setActiveTime(_object_spread_props(_object_spread({}, activeTime), _define_property({
747
+ currentColumn: newColumn
748
+ }, newColumn, newIndex)));
749
+ if (currentColumn === 'seconds' && format === 'HH:mm:ss' || currentColumn === 'minutes' && format === 'HH:mm') {
750
+ setIsInnerOpen(false);
751
+ }
752
+ break;
753
+ case 'ArrowLeft':
754
+ if (currentColumn === 'minutes') {
755
+ newColumn = 'hours';
756
+ } else if (currentColumn === 'seconds') {
757
+ newColumn = 'minutes';
758
+ }
759
+ var _activeTime_newColumn1;
760
+ newIndex = (_activeTime_newColumn1 = activeTime[newColumn]) !== null && _activeTime_newColumn1 !== void 0 ? _activeTime_newColumn1 : 0;
761
+ setActiveTime(_object_spread_props(_object_spread({}, activeTime), _define_property({
762
+ currentColumn: newColumn
763
+ }, newColumn, newIndex)));
764
+ if (currentColumn === 'hours') {
765
+ setIsInnerOpen(false);
766
+ }
767
+ break;
768
+ // eslint-disable-next-line no-fallthrough
769
+ default:
770
+ }
771
+ };
772
+ var handleTimeItemKeyDown = function(event, column, value) {
773
+ if (event.key === 'Enter') {
774
+ event.preventDefault();
775
+ handleTimeItemClick(value, column);
776
+ }
777
+ };
778
+ var handleOnKeyDown = function(e) {
779
+ onKeyDownNavigation(e);
780
+ handleKeyDown(e);
781
+ };
782
+ var _useKeyNavigation = (0, _useKeyboardNavigation.useKeyNavigation)({
783
+ isCalendarOpen: isInnerOpen,
784
+ format: format,
785
+ maskWithFormat: true,
786
+ delimiter: _utils1.delimiter,
787
+ closeOnEsc: closeOnEsc,
788
+ onToggle: handleToggle
789
+ }), onKeyDownNavigation = _useKeyNavigation.onKeyDown;
790
+ var TimePickerInput = /*#__PURE__*/ _react.default.createElement(_TimePickerstyles.StyledInput, {
791
+ ref: inputRef,
792
+ value: viewValue,
793
+ size: size,
794
+ disabled: disabled,
795
+ readOnly: readonly,
796
+ placeholder: placeholder,
797
+ contentLeft: contentLeft,
798
+ contentRight: contentRight,
799
+ textBefore: textBefore,
800
+ textAfter: textAfter,
801
+ onChange: handleInputChange,
802
+ onFocus: onFocus,
803
+ onKeyDown: handleOnKeyDown,
804
+ required: required,
805
+ requiredPlacement: requiredPlacement,
806
+ hasRequiredIndicator: hasRequiredIndicator,
807
+ label: label,
808
+ labelPlacement: labelPlacement,
809
+ keepPlaceholder: keepPlaceholder
810
+ });
811
+ return /*#__PURE__*/ _react.default.createElement(Root, _object_spread({
812
+ stretched: stretched,
813
+ view: view,
814
+ size: size,
815
+ className: (0, _classnames.default)(_TimePickertokens.classes.timePickerRoot, className, _define_property({}, _TimePickertokens.classes.timePickerstretched, stretched)),
816
+ disabled: disabled,
817
+ readonly: readonly,
818
+ ref: ref
819
+ }, rest), /*#__PURE__*/ _react.default.createElement(_TimePickerstyles.StyledPopover, {
820
+ opened: isInnerOpen,
821
+ usePortal: usePortal,
822
+ frame: frame,
823
+ onToggle: handleToggle,
824
+ offset: offset,
825
+ placement: (0, _utils.getPlacements)(dropdownAlign === 'left' ? 'bottom-start' : 'bottom-end', false),
826
+ trigger: "click",
827
+ closeOnOverlayClick: closeOnOverlayClick,
828
+ isFocusTrapped: false,
829
+ target: TimePickerInput,
830
+ preventOverflow: false,
831
+ align: dropdownAlign
832
+ }, /*#__PURE__*/ _react.default.createElement(Root, {
833
+ ref: timeSelectRootRef,
834
+ view: view,
835
+ size: size,
836
+ disabled: disabled,
837
+ readonly: readonly,
838
+ onClick: handleCalendarRootClick,
839
+ className: dropdownAlign === 'right' ? _TimePickertokens.classes.timePickerPlacementRight : '',
840
+ stretched: stretched
841
+ }, /*#__PURE__*/ _react.default.createElement(_TimePickerstyles.StyledTimePicker, {
842
+ width: dropdownWidth
843
+ }, (0, _TimeColumn.renderTimeColumn)({
844
+ values: hours,
845
+ dropdownHeight: dropdownHeight,
846
+ column: 'hours',
847
+ columnRef: hoursColumnRef,
848
+ scrollbarState: hoursScrollbar,
849
+ setScrollbar: setHoursScrollbar,
850
+ scrollbarRef: hoursScrollbarRef,
851
+ thumbRef: hoursThumbRef,
852
+ timeoutRef: hoursHideTimeoutRef,
853
+ timeItemRefs: timeItemRefs,
854
+ activeTime: activeTime,
855
+ handleTimeItemClick: handleTimeItemClick,
856
+ handleTimeItemKeyDown: handleTimeItemKeyDown,
857
+ createScrollbarDragHandler: createScrollbarDragHandler
858
+ }), (0, _TimeColumn.renderTimeColumn)({
859
+ values: minutes,
860
+ dropdownHeight: dropdownHeight,
861
+ column: 'minutes',
862
+ columnRef: minutesColumnRef,
863
+ scrollbarState: minutesScrollbar,
864
+ setScrollbar: setMinutesScrollbar,
865
+ scrollbarRef: minutesScrollbarRef,
866
+ thumbRef: minutesThumbRef,
867
+ timeoutRef: minutesHideTimeoutRef,
868
+ timeItemRefs: timeItemRefs,
869
+ activeTime: activeTime,
870
+ handleTimeItemClick: handleTimeItemClick,
871
+ handleTimeItemKeyDown: handleTimeItemKeyDown,
872
+ createScrollbarDragHandler: createScrollbarDragHandler
873
+ }), columnsQuantity === 3 && (0, _TimeColumn.renderTimeColumn)({
874
+ values: seconds,
875
+ dropdownHeight: dropdownHeight,
876
+ column: 'seconds',
877
+ columnRef: secondsColumnRef,
878
+ scrollbarState: secondsScrollbar,
879
+ setScrollbar: setSecondsScrollbar,
880
+ scrollbarRef: secondsScrollbarRef,
881
+ thumbRef: secondsThumbRef,
882
+ timeoutRef: secondsHideTimeoutRef,
883
+ timeItemRefs: timeItemRefs,
884
+ activeTime: activeTime,
885
+ handleTimeItemClick: handleTimeItemClick,
886
+ handleTimeItemKeyDown: handleTimeItemKeyDown,
887
+ createScrollbarDragHandler: createScrollbarDragHandler
888
+ })))));
889
+ });
890
+ };
891
+ var timePickerConfig = {
892
+ name: 'TimePicker',
893
+ tag: 'div',
894
+ layout: timePickerRoot,
895
+ base: _TimePickerstyles.base,
896
+ variations: {
897
+ view: {
898
+ css: _base1.base
899
+ },
900
+ size: {
901
+ css: _base.base
902
+ },
903
+ disabled: {
904
+ css: _base2.base,
905
+ attrs: true
906
+ },
907
+ readonly: {
908
+ css: _base3.base,
909
+ attrs: true
910
+ }
911
+ },
912
+ defaults: {
913
+ size: 'm',
914
+ view: 'default'
915
+ }
916
+ };