@jetbrains/ring-ui 4.2.4 → 4.2.7

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 (320) hide show
  1. package/components/dialog/dialog.js +4 -2
  2. package/components/list/list.js +20 -11
  3. package/components/table/row.js +12 -7
  4. package/components/table/table.examples.js +1 -0
  5. package/components/table/table.js +3 -1
  6. package/package.json +2 -2
  7. package/dist/_helpers/_rollupPluginBabelHelpers.js +0 -34
  8. package/dist/_helpers/anchor.js +0 -33
  9. package/dist/_helpers/badge.js +0 -3
  10. package/dist/_helpers/button-group.js +0 -3
  11. package/dist/_helpers/button-set.js +0 -3
  12. package/dist/_helpers/button-toolbar.js +0 -3
  13. package/dist/_helpers/button__classes.js +0 -39
  14. package/dist/_helpers/card.js +0 -75
  15. package/dist/_helpers/checkbox.js +0 -3
  16. package/dist/_helpers/date-picker.js +0 -3
  17. package/dist/_helpers/dialog__body-scroll-preventer.js +0 -58
  18. package/dist/_helpers/error-message.js +0 -3
  19. package/dist/_helpers/footer.js +0 -121
  20. package/dist/_helpers/grid.js +0 -3
  21. package/dist/_helpers/group.js +0 -3
  22. package/dist/_helpers/header.js +0 -3
  23. package/dist/_helpers/icon.js +0 -3
  24. package/dist/_helpers/inject-styles.js +0 -22
  25. package/dist/_helpers/input.js +0 -3
  26. package/dist/_helpers/island.js +0 -3
  27. package/dist/_helpers/link.js +0 -3
  28. package/dist/_helpers/list.js +0 -3
  29. package/dist/_helpers/loader-screen.js +0 -3
  30. package/dist/_helpers/panel.js +0 -3
  31. package/dist/_helpers/query-assist__suggestions.js +0 -95
  32. package/dist/_helpers/radio.js +0 -3
  33. package/dist/_helpers/select__filter.js +0 -77
  34. package/dist/_helpers/services-link.js +0 -40
  35. package/dist/_helpers/sidebar.js +0 -126
  36. package/dist/_helpers/table.js +0 -3
  37. package/dist/_helpers/tabs.js +0 -3
  38. package/dist/_helpers/title.js +0 -100
  39. package/dist/alert/alert.js +0 -262
  40. package/dist/alert/container.js +0 -48
  41. package/dist/alert-service/alert-service.js +0 -173
  42. package/dist/analytics/analytics.js +0 -118
  43. package/dist/analytics/analytics__custom-plugin.js +0 -128
  44. package/dist/analytics/analytics__fus-plugin.js +0 -102
  45. package/dist/analytics/analytics__ga-plugin.js +0 -75
  46. package/dist/analytics/analytics__plugin-utils.js +0 -80
  47. package/dist/analytics-ng/analytics-ng.js +0 -95
  48. package/dist/auth/auth.js +0 -96
  49. package/dist/auth/auth__core.js +0 -1059
  50. package/dist/auth/background-flow.js +0 -123
  51. package/dist/auth/down-notification.js +0 -117
  52. package/dist/auth/iframe-flow.js +0 -153
  53. package/dist/auth/landing-entry.js +0 -5
  54. package/dist/auth/landing.js +0 -90
  55. package/dist/auth/request-builder.js +0 -76
  56. package/dist/auth/response-parser.js +0 -118
  57. package/dist/auth/storage.js +0 -283
  58. package/dist/auth/token-validator.js +0 -178
  59. package/dist/auth/window-flow.js +0 -134
  60. package/dist/auth-dialog/auth-dialog.js +0 -180
  61. package/dist/auth-dialog-service/auth-dialog-service.js +0 -71
  62. package/dist/auth-ng/auth-ng.js +0 -206
  63. package/dist/auth-ng/auth-ng.mock.js +0 -33
  64. package/dist/autofocus-ng/autofocus-ng.js +0 -51
  65. package/dist/avatar/avatar-example-datauri.js +0 -4
  66. package/dist/avatar/avatar.js +0 -163
  67. package/dist/avatar/fallback-avatar.js +0 -142
  68. package/dist/avatar-editor-ng/avatar-editor-ng.js +0 -167
  69. package/dist/avatar-editor-ng/avatar-editor-ng__template.js +0 -3
  70. package/dist/avatar-ng/avatar-ng.js +0 -21
  71. package/dist/badge/badge.js +0 -51
  72. package/dist/badge-ng/badge-ng.js +0 -18
  73. package/dist/breadcrumb-ng/breadcrumb-ng.js +0 -37
  74. package/dist/button/button.js +0 -125
  75. package/dist/button/button__classes.js +0 -5
  76. package/dist/button-group/button-group.js +0 -30
  77. package/dist/button-group/caption.js +0 -24
  78. package/dist/button-group-ng/button-group-ng.js +0 -39
  79. package/dist/button-ng/button-ng.js +0 -217
  80. package/dist/button-set/button-set.js +0 -26
  81. package/dist/button-set-ng/button-set-ng.js +0 -19
  82. package/dist/button-toolbar/button-toolbar.js +0 -29
  83. package/dist/button-toolbar-ng/button-toolbar-ng.js +0 -24
  84. package/dist/caret/caret.js +0 -266
  85. package/dist/checkbox/checkbox.js +0 -110
  86. package/dist/checkbox-ng/checkbox-ng.js +0 -38
  87. package/dist/code/code.js +0 -137
  88. package/dist/compiler-ng/compiler-ng.js +0 -53
  89. package/dist/confirm/confirm.js +0 -127
  90. package/dist/confirm-ng/confirm-ng.js +0 -69
  91. package/dist/confirm-service/confirm-service.js +0 -117
  92. package/dist/content-layout/content-layout.js +0 -66
  93. package/dist/content-layout/sidebar.js +0 -7
  94. package/dist/contenteditable/contenteditable.js +0 -78
  95. package/dist/data-list/data-list.js +0 -208
  96. package/dist/data-list/data-list.mock.js +0 -191
  97. package/dist/data-list/item.js +0 -229
  98. package/dist/data-list/selection.js +0 -102
  99. package/dist/data-list/title.js +0 -20
  100. package/dist/data-list-ng/data-list-ng.js +0 -62
  101. package/dist/date-picker/consts.js +0 -69
  102. package/dist/date-picker/date-input.js +0 -175
  103. package/dist/date-picker/date-picker.js +0 -367
  104. package/dist/date-picker/date-popup.js +0 -483
  105. package/dist/date-picker/day.js +0 -120
  106. package/dist/date-picker/formats.js +0 -3
  107. package/dist/date-picker/month-names.js +0 -100
  108. package/dist/date-picker/month-slider.js +0 -84
  109. package/dist/date-picker/month.js +0 -55
  110. package/dist/date-picker/months.js +0 -122
  111. package/dist/date-picker/weekdays.js +0 -32
  112. package/dist/date-picker/years.js +0 -110
  113. package/dist/dialog/dialog.js +0 -202
  114. package/dist/dialog/dialog__body-scroll-preventer.js +0 -3
  115. package/dist/dialog-ng/dialog-ng.js +0 -604
  116. package/dist/dialog-ng/dialog-ng__template.js +0 -3
  117. package/dist/docked-panel-ng/docked-panel-ng.js +0 -171
  118. package/dist/dropdown/anchor.js +0 -19
  119. package/dist/dropdown/dropdown.js +0 -236
  120. package/dist/dropdown-menu/dropdown-menu.js +0 -177
  121. package/dist/error-bubble/error-bubble.js +0 -59
  122. package/dist/error-message/error-message.js +0 -57
  123. package/dist/error-message-ng/error-message-ng.js +0 -35
  124. package/dist/footer/footer.js +0 -12
  125. package/dist/footer-ng/footer-ng.js +0 -64
  126. package/dist/form-ng/form-ng.js +0 -167
  127. package/dist/global/angular-component-factory.js +0 -84
  128. package/dist/global/compose.js +0 -9
  129. package/dist/global/composeRefs.js +0 -15
  130. package/dist/global/conic-gradient.js +0 -35
  131. package/dist/global/create-stateful-context.js +0 -55
  132. package/dist/global/data-tests.js +0 -24
  133. package/dist/global/dom.js +0 -125
  134. package/dist/global/focus-sensor-hoc.js +0 -146
  135. package/dist/global/fuzzy-highlight.js +0 -67
  136. package/dist/global/get-event-key.js +0 -111
  137. package/dist/global/get-uid.js +0 -15
  138. package/dist/global/inject-styles.js +0 -15
  139. package/dist/global/linear-function.js +0 -17
  140. package/dist/global/listeners.js +0 -44
  141. package/dist/global/memoize.js +0 -20
  142. package/dist/global/normalize-indent.js +0 -30
  143. package/dist/global/promise-with-timeout.js +0 -17
  144. package/dist/global/radial-gradient-mask.js +0 -38
  145. package/dist/global/react-dom-renderer.js +0 -46
  146. package/dist/global/react-render-adapter.js +0 -41
  147. package/dist/global/rerender-hoc.js +0 -55
  148. package/dist/global/ring-angular-component.js +0 -24
  149. package/dist/global/schedule-raf.js +0 -31
  150. package/dist/global/sniffer.js +0 -6
  151. package/dist/global/supports-css.js +0 -22
  152. package/dist/global/theme.js +0 -54
  153. package/dist/global/trivial-template-tag.js +0 -17
  154. package/dist/global/url.js +0 -165
  155. package/dist/global/variables_dark.js +0 -57
  156. package/dist/grid/col.js +0 -60
  157. package/dist/grid/grid.js +0 -33
  158. package/dist/grid/row.js +0 -64
  159. package/dist/group/group.js +0 -31
  160. package/dist/group-ng/group-ng.js +0 -11
  161. package/dist/header/header.js +0 -150
  162. package/dist/header/logo.js +0 -40
  163. package/dist/header/profile.js +0 -219
  164. package/dist/header/services-link.js +0 -12
  165. package/dist/header/services.js +0 -138
  166. package/dist/header/smart-profile.js +0 -233
  167. package/dist/header/smart-services.js +0 -163
  168. package/dist/header/tray-icon.js +0 -47
  169. package/dist/header/tray.js +0 -31
  170. package/dist/heading/heading.js +0 -73
  171. package/dist/http/http.js +0 -218
  172. package/dist/http/http.mock.js +0 -67
  173. package/dist/hub-source/hub-source.js +0 -130
  174. package/dist/hub-source/hub-source__user.js +0 -30
  175. package/dist/hub-source/hub-source__users-groups.js +0 -63
  176. package/dist/icon/icon.js +0 -105
  177. package/dist/icon/icon__constants.js +0 -33
  178. package/dist/icon/icon__svg.js +0 -83
  179. package/dist/icon/index.js +0 -12
  180. package/dist/icon-ng/icon-ng.js +0 -91
  181. package/dist/input/input.js +0 -230
  182. package/dist/input-ng/input-ng.js +0 -111
  183. package/dist/island/adaptive-island-hoc.js +0 -48
  184. package/dist/island/content.js +0 -160
  185. package/dist/island/header.js +0 -84
  186. package/dist/island/island.js +0 -51
  187. package/dist/island-legacy/content-legacy.js +0 -26
  188. package/dist/island-legacy/header-legacy.js +0 -28
  189. package/dist/island-legacy/island-legacy.js +0 -28
  190. package/dist/island-ng/island-content-ng.js +0 -42
  191. package/dist/island-ng/island-header-ng.js +0 -26
  192. package/dist/island-ng/island-ng-class-fixer.js +0 -11
  193. package/dist/island-ng/island-ng.js +0 -25
  194. package/dist/link/clickableLink.js +0 -64
  195. package/dist/link/link.js +0 -115
  196. package/dist/link-ng/link-ng.js +0 -22
  197. package/dist/list/consts.js +0 -26
  198. package/dist/list/list.js +0 -818
  199. package/dist/list/list__custom.js +0 -86
  200. package/dist/list/list__hint.js +0 -26
  201. package/dist/list/list__item.js +0 -206
  202. package/dist/list/list__link.js +0 -65
  203. package/dist/list/list__separator.js +0 -30
  204. package/dist/list/list__title.js +0 -39
  205. package/dist/list/list__users-groups-source.js +0 -130
  206. package/dist/loader/loader.js +0 -71
  207. package/dist/loader/loader__core.js +0 -273
  208. package/dist/loader-inline/inject-styles.js +0 -13
  209. package/dist/loader-inline/loader-inline.js +0 -58
  210. package/dist/loader-inline-ng/loader-inline-ng.js +0 -44
  211. package/dist/loader-ng/loader-ng.js +0 -44
  212. package/dist/loader-screen/loader-screen.js +0 -44
  213. package/dist/loader-screen-ng/loader-screen-ng.js +0 -95
  214. package/dist/login-dialog/login-dialog.js +0 -188
  215. package/dist/login-dialog/service.js +0 -72
  216. package/dist/markdown/code.js +0 -31
  217. package/dist/markdown/heading.js +0 -23
  218. package/dist/markdown/link.js +0 -31
  219. package/dist/markdown/markdown.js +0 -74
  220. package/dist/message/message.js +0 -235
  221. package/dist/message-bundle-ng/message-bundle-ng.js +0 -111
  222. package/dist/old-browsers-message/old-browsers-message.js +0 -101
  223. package/dist/old-browsers-message/old-browsers-message__stop.js +0 -5
  224. package/dist/old-browsers-message/white-list.js +0 -34
  225. package/dist/pager/pager.js +0 -365
  226. package/dist/pager-ng/pager-ng.js +0 -100
  227. package/dist/panel/panel.js +0 -31
  228. package/dist/panel-ng/panel-ng.js +0 -17
  229. package/dist/permissions/permissions.js +0 -200
  230. package/dist/permissions/permissions__cache.js +0 -272
  231. package/dist/permissions-ng/permissions-ng.js +0 -277
  232. package/dist/place-under-ng/place-under-ng.js +0 -158
  233. package/dist/popup/popup.consts.js +0 -41
  234. package/dist/popup/popup.js +0 -396
  235. package/dist/popup/popup.target.js +0 -26
  236. package/dist/popup/position.js +0 -280
  237. package/dist/popup-menu/popup-menu.js +0 -117
  238. package/dist/progress-bar/progress-bar.js +0 -114
  239. package/dist/progress-bar-ng/progress-bar-ng.js +0 -17
  240. package/dist/promised-click-ng/promised-click-ng.js +0 -128
  241. package/dist/proxy-attrs/proxy-attrs.js +0 -21
  242. package/dist/query-assist/query-assist.js +0 -1096
  243. package/dist/query-assist/query-assist__suggestions.js +0 -49
  244. package/dist/query-assist-ng/query-assist-ng.js +0 -86
  245. package/dist/radio/radio.js +0 -42
  246. package/dist/radio/radio__item.js +0 -78
  247. package/dist/radio-ng/radio-ng.js +0 -47
  248. package/dist/save-field-ng/save-field-ng.js +0 -337
  249. package/dist/save-field-ng/save-field-ng__template.js +0 -3
  250. package/dist/select/select.js +0 -1357
  251. package/dist/select/select__filter.js +0 -56
  252. package/dist/select/select__popup.js +0 -553
  253. package/dist/select-ng/select-ng.js +0 -637
  254. package/dist/select-ng/select-ng__lazy.js +0 -169
  255. package/dist/select-ng/select-ng__options.js +0 -145
  256. package/dist/shortcuts/core.js +0 -245
  257. package/dist/shortcuts/shortcut-title.js +0 -51
  258. package/dist/shortcuts/shortcuts-hoc.js +0 -42
  259. package/dist/shortcuts/shortcuts.js +0 -72
  260. package/dist/shortcuts-hint-ng/shortcuts-hint-ng.js +0 -123
  261. package/dist/shortcuts-hint-ng/shortcuts-hint-ng__template.js +0 -3
  262. package/dist/shortcuts-ng/shortcuts-ng.js +0 -262
  263. package/dist/sidebar-ng/sidebar-ng.js +0 -113
  264. package/dist/sidebar-ng/sidebar-ng__button-template.js +0 -3
  265. package/dist/sidebar-ng/sidebar-ng__template.js +0 -3
  266. package/dist/storage/storage.js +0 -59
  267. package/dist/storage/storage__fallback.js +0 -215
  268. package/dist/storage/storage__local.js +0 -154
  269. package/dist/style.css +0 -1
  270. package/dist/tab-trap/tab-trap.js +0 -177
  271. package/dist/table/cell.js +0 -26
  272. package/dist/table/disable-hover-hoc.js +0 -54
  273. package/dist/table/header-cell.js +0 -92
  274. package/dist/table/header.js +0 -193
  275. package/dist/table/multitable.js +0 -141
  276. package/dist/table/row-with-focus-sensor.js +0 -83
  277. package/dist/table/row.js +0 -273
  278. package/dist/table/selection-adapter.js +0 -16
  279. package/dist/table/selection-shortcuts-hoc.js +0 -215
  280. package/dist/table/selection.js +0 -223
  281. package/dist/table/smart-table.js +0 -125
  282. package/dist/table/table.js +0 -406
  283. package/dist/table-legacy-ng/table-legacy-ng.js +0 -468
  284. package/dist/table-legacy-ng/table-legacy-ng__pager.js +0 -120
  285. package/dist/table-legacy-ng/table-legacy-ng__selection-navigate-actions.js +0 -123
  286. package/dist/table-legacy-ng/table-legacy-ng__selection.js +0 -179
  287. package/dist/table-legacy-ng/table-legacy-ng__toolbar.js +0 -57
  288. package/dist/table-ng/smart-table-ng.js +0 -68
  289. package/dist/table-ng/table-ng.js +0 -67
  290. package/dist/tabs/collapsible-more.js +0 -198
  291. package/dist/tabs/collapsible-tab.js +0 -91
  292. package/dist/tabs/collapsible-tabs.js +0 -362
  293. package/dist/tabs/custom-item.js +0 -13
  294. package/dist/tabs/dumb-tabs.js +0 -164
  295. package/dist/tabs/smart-tabs.js +0 -106
  296. package/dist/tabs/tab-link.js +0 -42
  297. package/dist/tabs/tab.js +0 -33
  298. package/dist/tabs/tabs.js +0 -71
  299. package/dist/tabs-ng/tabs-ng.js +0 -194
  300. package/dist/tabs-ng/tabs-ng__template.js +0 -3
  301. package/dist/tag/tag.js +0 -197
  302. package/dist/tags-input/tags-input.js +0 -482
  303. package/dist/tags-input-ng/tags-input-ng.js +0 -93
  304. package/dist/tags-list/tags-list.js +0 -95
  305. package/dist/template-ng/template-ng.js +0 -71
  306. package/dist/text/text.js +0 -36
  307. package/dist/theme-ng/theme-ng.js +0 -45
  308. package/dist/title-ng/title-ng.js +0 -114
  309. package/dist/toggle/toggle.js +0 -78
  310. package/dist/toggle-ng/toggle-ng.js +0 -18
  311. package/dist/tooltip/tooltip.js +0 -209
  312. package/dist/tooltip-ng/tooltip-ng.js +0 -104
  313. package/dist/user-agreement/service.js +0 -412
  314. package/dist/user-agreement/toolbox.eula.js +0 -3
  315. package/dist/user-agreement/user-agreement.js +0 -169
  316. package/dist/user-card/card.js +0 -19
  317. package/dist/user-card/smart-user-card-tooltip.js +0 -114
  318. package/dist/user-card/tooltip.js +0 -95
  319. package/dist/user-card/user-card.js +0 -51
  320. package/dist/user-card-ng/user-card-ng.js +0 -62
package/dist/list/list.js DELETED
@@ -1,818 +0,0 @@
1
- import { _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import 'core-js/modules/web.dom-collections.iterator.js';
3
- import React, { Component, cloneElement } from 'react';
4
- import PropTypes from 'prop-types';
5
- import classNames from 'classnames';
6
- import VirtualizedList from 'react-virtualized/dist/es/List';
7
- import AutoSizer from 'react-virtualized/dist/es/AutoSizer';
8
- import WindowScroller from 'react-virtualized/dist/es/WindowScroller';
9
- import { CellMeasurerCache, CellMeasurer } from 'react-virtualized/dist/es/CellMeasurer';
10
- import deprecate from 'util-deprecate';
11
- import memoizeOne from 'memoize-one';
12
- import joinDataTestAttributes from '../global/data-tests.js';
13
- import getUID from '../global/get-uid.js';
14
- import scheduleRAF from '../global/schedule-raf.js';
15
- import memoize from '../global/memoize.js';
16
- import { preventDefault } from '../global/dom.js';
17
- import Shortcuts from '../shortcuts/shortcuts.js';
18
- import createStatefulContext from '../global/create-stateful-context.js';
19
- import ListLink from './list__link.js';
20
- import ListItem from './list__item.js';
21
- import ListCustom from './list__custom.js';
22
- import ListTitle from './list__title.js';
23
- import ListSeparator from './list__separator.js';
24
- import ListHint from './list__hint.js';
25
- import { Type, Dimension, DEFAULT_ITEM_TYPE } from './consts.js';
26
- import { m as modules_3b67a421 } from '../_helpers/list.js';
27
- import '../shortcuts/core.js';
28
- import 'combokeys';
29
- import '../global/sniffer.js';
30
- import 'sniffr';
31
- import '../link/link.js';
32
- import 'focus-visible';
33
- import '../link/clickableLink.js';
34
- import '../_helpers/link.js';
35
- import '../avatar/avatar.js';
36
- import '../global/url.js';
37
- import 'core-js/modules/es.string.replace.js';
38
- import '../avatar/fallback-avatar.js';
39
- import '../checkbox/checkbox.js';
40
- import '@jetbrains/icons/checkmark';
41
- import '@jetbrains/icons/remove-10px';
42
- import '../icon/icon.js';
43
- import '../icon/icon__constants.js';
44
- import '../_helpers/icon.js';
45
- import '../icon/icon__svg.js';
46
- import '../_helpers/checkbox.js';
47
- import '../global/get-event-key.js';
48
-
49
- function noop() {}
50
-
51
- const warnEmptyKey = deprecate(() => {}, 'No key passed for list item with non-string label. It is considered as a bad practice and has been deprecated, please provide a key.');
52
- /**
53
- * @param {Type} listItemType
54
- * @param {Object} item list item
55
- */
56
-
57
- function isItemType(listItemType, item) {
58
- let type = item.rgItemType;
59
-
60
- if (type == null) {
61
- type = DEFAULT_ITEM_TYPE;
62
- }
63
-
64
- return type === listItemType;
65
- }
66
-
67
- const nonActivatableTypes = [Type.SEPARATOR, Type.TITLE, Type.MARGIN];
68
-
69
- function isActivatable(item) {
70
- return item != null && !nonActivatableTypes.includes(item.rgItemType) && !item.disabled;
71
- }
72
-
73
- const shouldActivateFirstItem = props => props.activateFirstItem || props.activateSingleItem && props.data.length === 1;
74
-
75
- const ActiveItemContext = createStatefulContext(undefined, 'ActiveItem');
76
- /**
77
- * @name List
78
- * @constructor
79
- * @extends {ReactComponent}
80
- */
81
-
82
- /**
83
- * Displays a list of items.
84
- */
85
-
86
- class List extends Component {
87
- constructor() {
88
- var _this;
89
-
90
- super(...arguments);
91
- _this = this;
92
-
93
- _defineProperty(this, "state", {
94
- activeIndex: null,
95
- prevActiveIndex: null,
96
- prevData: [],
97
- activeItem: null,
98
- needScrollToActive: false,
99
- scrolling: false,
100
- hasOverflow: false,
101
- disabledHover: false,
102
- scrolledToBottom: false
103
- });
104
-
105
- _defineProperty(this, "hoverHandler", memoize(index => () => this.scheduleHoverListener(() => {
106
- if (this.state.disabledHover) {
107
- return;
108
- }
109
-
110
- if (this.container) {
111
- this.setState({
112
- activeIndex: index,
113
- activeItem: this.props.data[index],
114
- needScrollToActive: false
115
- });
116
- }
117
- })));
118
-
119
- _defineProperty(this, "_activatableItems", false);
120
-
121
- _defineProperty(this, "_bufferSize", 10);
122
-
123
- _defineProperty(this, "sizeCacheKey", index => {
124
- if (index === 0 || index === this.props.data.length + 1) {
125
- return Type.MARGIN;
126
- }
127
-
128
- const item = this.props.data[index - 1];
129
- const isFirst = index === 1;
130
-
131
- switch (item.rgItemType) {
132
- case Type.SEPARATOR:
133
- case Type.TITLE:
134
- return "".concat(item.rgItemType).concat(isFirst ? '_first' : '').concat(item.description ? '_desc' : '');
135
-
136
- case Type.MARGIN:
137
- return Type.MARGIN;
138
-
139
- case Type.CUSTOM:
140
- return "".concat(Type.CUSTOM, "_").concat(item.key);
141
-
142
- case Type.ITEM:
143
- case Type.LINK:
144
- default:
145
- if (item.details) {
146
- return "".concat(Type.ITEM, "_").concat(item.details);
147
- }
148
-
149
- return Type.ITEM;
150
- }
151
- });
152
-
153
- _defineProperty(this, "_cache", new CellMeasurerCache({
154
- defaultHeight: this.defaultItemHeight(),
155
- fixedWidth: true,
156
- keyMapper: this.sizeCacheKey
157
- }));
158
-
159
- _defineProperty(this, "_hasActivatableItems", memoizeOne(items => items.some(isActivatable)));
160
-
161
- _defineProperty(this, "selectHandler", memoize(index => function (event) {
162
- let tryKeepOpen = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
163
- const item = _this.props.data[index];
164
-
165
- if (!_this.props.useMouseUp && item.onClick) {
166
- item.onClick(item, event);
167
- } else if (_this.props.useMouseUp && item.onMouseUp) {
168
- item.onMouseUp(item, event);
169
- }
170
-
171
- if (_this.props.onSelect) {
172
- _this.props.onSelect(item, event, {
173
- tryKeepOpen
174
- });
175
- }
176
- }));
177
-
178
- _defineProperty(this, "checkboxHandler", memoize(index => event => this.selectHandler(index)(event, true)));
179
-
180
- _defineProperty(this, "upHandler", e => {
181
- const {
182
- data,
183
- disableMoveOverflow
184
- } = this.props;
185
- const index = this.state.activeIndex;
186
- let newIndex;
187
-
188
- if (index === null || index === 0) {
189
- if (!disableMoveOverflow) {
190
- newIndex = data.length - 1;
191
- } else {
192
- return;
193
- }
194
- } else {
195
- newIndex = index - 1;
196
- }
197
-
198
- this.moveHandler(newIndex, this.upHandler, e);
199
- });
200
-
201
- _defineProperty(this, "downHandler", e => {
202
- const {
203
- data,
204
- disableMoveOverflow,
205
- disableMoveDownOverflow
206
- } = this.props;
207
- const index = this.state.activeIndex;
208
- let newIndex;
209
-
210
- if (index === null) {
211
- newIndex = 0;
212
- } else if (index + 1 === data.length) {
213
- if (!disableMoveOverflow && !disableMoveDownOverflow) {
214
- newIndex = 0;
215
- } else {
216
- return;
217
- }
218
- } else {
219
- newIndex = index + 1;
220
- }
221
-
222
- this.moveHandler(newIndex, this.downHandler, e);
223
- });
224
-
225
- _defineProperty(this, "homeHandler", e => {
226
- this.moveHandler(0, this.downHandler, e);
227
- });
228
-
229
- _defineProperty(this, "endHandler", e => {
230
- this.moveHandler(this.props.data.length - 1, this.upHandler, e);
231
- });
232
-
233
- _defineProperty(this, "onDocumentMouseMove", () => {
234
- if (this.state.disabledHover) {
235
- this.setState({
236
- disabledHover: false
237
- });
238
- }
239
- });
240
-
241
- _defineProperty(this, "onDocumentKeyDown", e => {
242
- const metaKeys = [16, 17, 18, 19, 20, 91]; // eslint-disable-line no-magic-numbers
243
-
244
- if (!this.state.disabledHover && !metaKeys.includes(e.keyCode)) {
245
- this.setState({
246
- disabledHover: true
247
- });
248
- }
249
- });
250
-
251
- _defineProperty(this, "mouseHandler", () => {
252
- this.setState({
253
- scrolling: false
254
- });
255
- });
256
-
257
- _defineProperty(this, "scrollHandler", () => {
258
- this.setState({
259
- scrolling: true
260
- }, this.scrollEndHandler);
261
- });
262
-
263
- _defineProperty(this, "enterHandler", (event, shortcut) => {
264
- if (this.state.activeIndex !== null) {
265
- const item = this.props.data[this.state.activeIndex];
266
- this.selectHandler(this.state.activeIndex)(event);
267
-
268
- if (item.href && !event.defaultPrevented) {
269
- if (['command+enter', 'ctrl+enter'].includes(shortcut)) {
270
- window.open(item.href, '_blank');
271
- } else if (shortcut === 'shift+enter') {
272
- window.open(item.href);
273
- } else {
274
- window.location.href = item.href;
275
- }
276
- }
277
-
278
- return false; // do not propagate event
279
- } else {
280
- return true; // propagate event to the parent component (e.g., QueryAssist)
281
- }
282
- });
283
-
284
- _defineProperty(this, "clearSelected", () => {
285
- this.setState({
286
- activeIndex: null,
287
- needScrollToActive: false
288
- });
289
- });
290
-
291
- _defineProperty(this, "scrollEndHandler", () => this.scheduleScrollListener(() => {
292
- const innerContainer = this.inner;
293
-
294
- if (innerContainer) {
295
- const maxScrollingPosition = innerContainer.scrollHeight;
296
- const sensitivity = this.defaultItemHeight() / 2;
297
- const currentScrollingPosition = innerContainer.scrollTop + innerContainer.clientHeight + sensitivity;
298
- const scrolledToBottom = maxScrollingPosition > 0 && currentScrollingPosition >= maxScrollingPosition;
299
-
300
- if (!this.unmounted) {
301
- this.setState({
302
- scrolledToBottom
303
- });
304
- }
305
-
306
- if (scrolledToBottom) {
307
- this.props.onScrollToBottom();
308
- }
309
- }
310
- }));
311
-
312
- _defineProperty(this, "checkOverflow", () => {
313
- if (this.inner) {
314
- this.setState({
315
- hasOverflow: this.inner.scrollHeight - this.inner.clientHeight > 1
316
- });
317
- }
318
- });
319
-
320
- _defineProperty(this, "renderItem", _ref => {
321
- let {
322
- index,
323
- style,
324
- isScrolling,
325
- parent,
326
- key
327
- } = _ref;
328
- let itemKey;
329
- let el;
330
- const realIndex = index - 1;
331
- const item = this.props.data[realIndex];
332
- const itemId = this.getId(item); // top and bottom margins
333
-
334
- if (index === 0 || index === this.props.data.length + 1 || item.rgItemType === Type.MARGIN) {
335
- itemKey = key || "".concat(Type.MARGIN, "_").concat(index);
336
- el = /*#__PURE__*/React.createElement("div", {
337
- style: {
338
- height: Dimension.MARGIN
339
- }
340
- });
341
- } else {
342
- // Hack around SelectNG implementation
343
- const {
344
- selectedLabel,
345
- originalModel,
346
- ...cleanedProps
347
- } = item;
348
- const itemProps = Object.assign({
349
- rgItemType: DEFAULT_ITEM_TYPE
350
- }, cleanedProps);
351
-
352
- if (itemProps.url) {
353
- itemProps.href = itemProps.url;
354
- }
355
-
356
- if (itemProps.href) {
357
- itemProps.rgItemType = Type.LINK;
358
- }
359
-
360
- itemKey = key || itemId;
361
- itemProps.hover = realIndex === this.state.activeIndex;
362
-
363
- if (itemProps.hoverClassName != null && itemProps.hover) {
364
- itemProps.className = classNames(itemProps.className, itemProps.hoverClassName);
365
- }
366
-
367
- itemProps.onMouseOver = this.hoverHandler(realIndex);
368
- itemProps.tabIndex = -1;
369
- itemProps.scrolling = isScrolling;
370
- const selectHandler = this.selectHandler(realIndex);
371
-
372
- if (this.props.useMouseUp) {
373
- itemProps.onMouseUp = selectHandler;
374
- } else {
375
- itemProps.onClick = selectHandler;
376
- }
377
-
378
- itemProps.onCheckboxChange = this.checkboxHandler(realIndex);
379
-
380
- if (itemProps.compact == null) {
381
- itemProps.compact = this.props.compact;
382
- }
383
-
384
- let ItemComponent;
385
- const isFirst = index === 1;
386
-
387
- switch (itemProps.rgItemType) {
388
- case Type.SEPARATOR:
389
- ItemComponent = ListSeparator;
390
- itemProps.isFirst = isFirst;
391
- break;
392
-
393
- case Type.LINK:
394
- ItemComponent = ListLink;
395
- this.addItemDataTestToProp(itemProps);
396
- break;
397
-
398
- case Type.ITEM:
399
- ItemComponent = ListItem;
400
- this.addItemDataTestToProp(itemProps);
401
- break;
402
-
403
- case Type.CUSTOM:
404
- ItemComponent = ListCustom;
405
- this.addItemDataTestToProp(itemProps);
406
- break;
407
-
408
- case Type.TITLE:
409
- itemProps.isFirst = isFirst;
410
- ItemComponent = ListTitle;
411
- break;
412
-
413
- default:
414
- throw new Error("Unknown menu element type: ".concat(itemProps.rgItemType));
415
- }
416
-
417
- el = /*#__PURE__*/React.createElement(ItemComponent, itemProps);
418
- }
419
-
420
- return parent ? /*#__PURE__*/React.createElement(CellMeasurer, {
421
- cache: this._cache,
422
- key: itemKey,
423
- parent: parent,
424
- rowIndex: index,
425
- columnIndex: 0
426
- }, _ref2 => {
427
- let {
428
- registerChild
429
- } = _ref2;
430
- return /*#__PURE__*/React.createElement("div", {
431
- ref: registerChild,
432
- style: style,
433
- role: "row",
434
- id: itemId
435
- }, /*#__PURE__*/React.createElement("div", {
436
- role: "cell"
437
- }, el));
438
- }) : /*#__PURE__*/React.createElement("div", {
439
- role: "row",
440
- id: itemId,
441
- key: itemKey
442
- }, /*#__PURE__*/React.createElement("div", {
443
- role: "cell"
444
- }, /*#__PURE__*/cloneElement(el)));
445
- });
446
-
447
- _defineProperty(this, "addItemDataTestToProp", props => {
448
- props['data-test'] = joinDataTestAttributes('ring-list-item', props['data-test']);
449
- return props;
450
- });
451
-
452
- _defineProperty(this, "virtualizedListRef", el => {
453
- this.virtualizedList = el;
454
- });
455
-
456
- _defineProperty(this, "containerRef", el => {
457
- this.container = el;
458
- });
459
-
460
- _defineProperty(this, "id", getUID('list-'));
461
-
462
- _defineProperty(this, "shortcutsScope", this.id);
463
-
464
- _defineProperty(this, "shortcutsMap", {
465
- up: this.upHandler,
466
- down: this.downHandler,
467
- home: this.homeHandler,
468
- end: this.endHandler,
469
- enter: this.enterHandler,
470
- 'meta+enter': this.enterHandler,
471
- 'ctrl+enter': this.enterHandler,
472
- 'command+enter': this.enterHandler,
473
- 'shift+enter': this.enterHandler
474
- });
475
-
476
- this.scheduleScrollListener = scheduleRAF();
477
- this.scheduleHoverListener = scheduleRAF();
478
- }
479
-
480
- static getDerivedStateFromProps(nextProps, prevState) {
481
- const {
482
- prevActiveIndex,
483
- prevData,
484
- activeItem
485
- } = prevState;
486
- const {
487
- data,
488
- activeIndex,
489
- restoreActiveIndex
490
- } = nextProps;
491
- const nextState = {
492
- prevActiveIndex: activeIndex,
493
- prevData: data
494
- };
495
-
496
- if (data !== prevData) {
497
- Object.assign(nextState, {
498
- activeIndex: null,
499
- activeItem: null
500
- });
501
- }
502
-
503
- if (activeIndex != null && activeIndex !== prevActiveIndex && data[activeIndex] != null) {
504
- Object.assign(nextState, {
505
- activeIndex,
506
- activeItem: data[activeIndex],
507
- needScrollToActive: true
508
- });
509
- } else if (data !== prevData && restoreActiveIndex && activeItem != null && activeItem.key != null) {
510
- // Restore active index if there is an item with the same "key" property
511
- const index = data.findIndex(item => item.key === activeItem.key);
512
-
513
- if (index >= 0) {
514
- Object.assign(nextState, {
515
- activeIndex: index,
516
- activeItem: data[index]
517
- });
518
- }
519
- }
520
-
521
- return nextState;
522
- }
523
-
524
- componentDidMount() {
525
- document.addEventListener('mousemove', this.onDocumentMouseMove);
526
- document.addEventListener('keydown', this.onDocumentKeyDown, true);
527
- const {
528
- data,
529
- activeIndex
530
- } = this.props;
531
-
532
- if (activeIndex == null && shouldActivateFirstItem(this.props)) {
533
- const firstActivatableIndex = data.findIndex(isActivatable);
534
-
535
- if (firstActivatableIndex >= 0) {
536
- this.setState({
537
- activeIndex: firstActivatableIndex,
538
- activeItem: data[firstActivatableIndex],
539
- needScrollToActive: true
540
- });
541
- }
542
- }
543
- }
544
-
545
- shouldComponentUpdate(nextProps, nextState) {
546
- return nextProps !== this.props || Object.keys(nextState).some(key => nextState[key] !== this.state[key]);
547
- }
548
-
549
- componentDidUpdate(prevProps) {
550
- if (this.virtualizedList && prevProps.data !== this.props.data) {
551
- this.virtualizedList.recomputeRowHeights();
552
- }
553
-
554
- this.checkOverflow();
555
- }
556
-
557
- componentWillUnmount() {
558
- this.unmounted = true;
559
- document.removeEventListener('mousemove', this.onDocumentMouseMove);
560
- document.removeEventListener('keydown', this.onDocumentKeyDown, true);
561
- }
562
-
563
- hasActivatableItems() {
564
- return this._hasActivatableItems(this.props.data);
565
- }
566
-
567
- moveHandler(index, retryCallback, e) {
568
- let correctedIndex;
569
-
570
- if (this.props.data.length === 0 || !this.hasActivatableItems()) {
571
- return;
572
- } else if (this.props.data.length < index) {
573
- correctedIndex = 0;
574
- } else {
575
- correctedIndex = index;
576
- }
577
-
578
- const item = this.props.data[correctedIndex];
579
- this.setState({
580
- activeIndex: correctedIndex,
581
- activeItem: item,
582
- needScrollToActive: true
583
- }, function onSet() {
584
- if (!isActivatable(item)) {
585
- retryCallback(e);
586
- return;
587
- }
588
-
589
- if (e.key !== 'Home' && e.key !== 'End') {
590
- preventDefault(e);
591
- }
592
- });
593
- }
594
-
595
- getFirst() {
596
- return this.props.data.find(item => item.rgItemType === Type.ITEM || item.rgItemType === Type.CUSTOM);
597
- }
598
-
599
- getSelected() {
600
- return this.props.data[this.state.activeIndex];
601
- }
602
-
603
- defaultItemHeight() {
604
- return this.props.compact ? Dimension.COMPACT_ITEM_HEIGHT : Dimension.ITEM_HEIGHT;
605
- }
606
-
607
- getVisibleListHeight(props) {
608
- return props.maxHeight - this.defaultItemHeight() - Dimension.INNER_PADDING;
609
- }
610
-
611
- _deprecatedGenerateKeyFromContent(itemProps) {
612
- const identificator = itemProps.label || itemProps.description;
613
- const isString = typeof identificator === 'string' || identificator instanceof String;
614
-
615
- if (identificator && !isString) {
616
- warnEmptyKey();
617
- "".concat(itemProps.rgItemType, "_").concat(JSON.stringify(identificator));
618
- }
619
-
620
- return "".concat(itemProps.rgItemType, "_").concat(identificator);
621
- }
622
-
623
- getId(item) {
624
- return item != null ? "".concat(this.id, ":").concat(item.key || this._deprecatedGenerateKeyFromContent(item)) : null;
625
- }
626
-
627
- get inner() {
628
- if (!this._inner) {
629
- this._inner = this.container && this.container.querySelector('.ring-list__i');
630
- }
631
-
632
- return this._inner;
633
- }
634
-
635
- renderVirtualizedInner(_ref3) {
636
- let {
637
- height,
638
- maxHeight,
639
- autoHeight = false,
640
- rowCount,
641
- isScrolling,
642
- onChildScroll = noop,
643
- scrollTop,
644
- registerChild
645
- } = _ref3;
646
- const dirOverride = {
647
- direction: 'auto'
648
- }; // Virtualized sets "direction: ltr" by default https://github.com/bvaughn/react-virtualized/issues/457
649
-
650
- return /*#__PURE__*/React.createElement(AutoSizer, {
651
- disableHeight: true,
652
- onResize: this.props.onResize
653
- }, _ref4 => {
654
- let {
655
- width
656
- } = _ref4;
657
- return /*#__PURE__*/React.createElement("div", {
658
- ref: registerChild
659
- }, /*#__PURE__*/React.createElement(VirtualizedList, {
660
- "aria-label": this.props.ariaLabel,
661
- ref: this.virtualizedListRef,
662
- className: "ring-list__i",
663
- autoHeight: autoHeight,
664
- style: maxHeight ? {
665
- maxHeight,
666
- height: 'auto',
667
- ...dirOverride
668
- } : dirOverride,
669
- autoContainerWidth: true,
670
- height: height,
671
- width: width,
672
- isScrolling: isScrolling,
673
- onScroll: e => {
674
- onChildScroll(e);
675
- this.scrollEndHandler(e);
676
- },
677
- scrollTop: scrollTop,
678
- rowCount: rowCount,
679
- estimatedRowSize: this.defaultItemHeight(),
680
- rowHeight: this._cache.rowHeight,
681
- rowRenderer: this.renderItem,
682
- overscanRowCount: this._bufferSize // ensure rerendering
683
- ,
684
- noop: () => {},
685
- scrollToIndex: !this.props.disableScrollToActive && this.state.needScrollToActive && this.state.activeIndex != null ? this.state.activeIndex + 1 : undefined,
686
- scrollToAlignment: "center",
687
- deferredMeasurementCache: this._cache,
688
- onRowsRendered: this.checkOverflow
689
- }));
690
- });
691
- }
692
-
693
- renderVirtualized(maxHeight, rowCount) {
694
- if (maxHeight) {
695
- return this.renderVirtualizedInner({
696
- height: maxHeight,
697
- maxHeight,
698
- rowCount
699
- });
700
- }
701
-
702
- return /*#__PURE__*/React.createElement(WindowScroller, null, props => this.renderVirtualizedInner({ ...props,
703
- rowCount,
704
- autoHeight: true
705
- }));
706
- }
707
-
708
- renderSimple(maxHeight, rowCount) {
709
- const items = [];
710
-
711
- for (let index = 0; index < rowCount; index++) {
712
- items.push(this.renderItem({
713
- index,
714
- isScrolling: this.state.scrolling
715
- }));
716
- }
717
-
718
- return /*#__PURE__*/React.createElement("div", {
719
- className: classNames('ring-list__i', modules_3b67a421.simpleInner),
720
- onScroll: this.scrollHandler,
721
- onMouseMove: this.mouseHandler
722
- }, /*#__PURE__*/React.createElement("div", {
723
- "aria-label": this.props.ariaLabel,
724
- role: "grid",
725
- style: maxHeight ? {
726
- maxHeight: this.getVisibleListHeight(this.props)
727
- } : null
728
- }, items));
729
- }
730
-
731
- /** @override */
732
- render() {
733
- const hint = this.getSelected() && this.props.hintOnSelection || this.props.hint;
734
- const fadeStyles = hint ? {
735
- bottom: Dimension.ITEM_HEIGHT
736
- } : null;
737
- const rowCount = this.props.data.length + 2;
738
- const maxHeight = this.props.maxHeight && this.getVisibleListHeight(this.props);
739
- const classes = classNames(modules_3b67a421.list, this.props.className);
740
- return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(ActiveItemContext.Updater, {
741
- value: this.getId(this.state.activeItem),
742
- skipUpdate: this.props.hidden || !isActivatable(this.state.activeItem)
743
- }), /*#__PURE__*/React.createElement("div", {
744
- id: this.props.id,
745
- ref: this.containerRef,
746
- className: classes,
747
- onMouseOut: this.props.onMouseOut,
748
- onBlur: this.props.onMouseOut,
749
- onMouseLeave: this.clearSelected,
750
- "data-test": "ring-list"
751
- }, this.props.shortcuts && /*#__PURE__*/React.createElement(Shortcuts, {
752
- map: this.shortcutsMap,
753
- scope: this.shortcutsScope
754
- }), this.props.renderOptimization ? this.renderVirtualized(maxHeight, rowCount) : this.renderSimple(maxHeight, rowCount), this.state.hasOverflow && !this.state.scrolledToBottom && /*#__PURE__*/React.createElement("div", {
755
- className: modules_3b67a421.fade,
756
- style: fadeStyles
757
- }), hint && /*#__PURE__*/React.createElement(ListHint, {
758
- label: hint
759
- })));
760
- }
761
-
762
- }
763
-
764
- _defineProperty(List, "propTypes", {
765
- id: PropTypes.string,
766
- className: PropTypes.string,
767
- hint: PropTypes.node,
768
- hintOnSelection: PropTypes.string,
769
- data: PropTypes.array,
770
- maxHeight: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
771
- activeIndex: PropTypes.number,
772
- restoreActiveIndex: PropTypes.bool,
773
- activateSingleItem: PropTypes.bool,
774
- activateFirstItem: PropTypes.bool,
775
- shortcuts: PropTypes.bool,
776
- onMouseOut: PropTypes.func,
777
- onSelect: PropTypes.func,
778
- onScrollToBottom: PropTypes.func,
779
- onResize: PropTypes.func,
780
- useMouseUp: PropTypes.bool,
781
- visible: PropTypes.bool,
782
- renderOptimization: PropTypes.bool,
783
- disableMoveOverflow: PropTypes.bool,
784
- disableMoveDownOverflow: PropTypes.bool,
785
- compact: PropTypes.bool,
786
- disableScrollToActive: PropTypes.bool,
787
- hidden: PropTypes.bool,
788
- ariaLabel: PropTypes.string
789
- });
790
-
791
- _defineProperty(List, "defaultProps", {
792
- data: [],
793
- restoreActiveIndex: false,
794
- // restore active item using its "key" property
795
- activateSingleItem: false,
796
- // if there is only one item, activate it
797
- activateFirstItem: false,
798
- // if there no active items, activate the first one
799
- onMouseOut: noop,
800
- onSelect: noop,
801
- onScrollToBottom: noop,
802
- onResize: noop,
803
- shortcuts: false,
804
- renderOptimization: true,
805
- disableMoveDownOverflow: false,
806
- ariaLabel: 'List'
807
- });
808
-
809
- _defineProperty(List, "isItemType", isItemType);
810
-
811
- _defineProperty(List, "ListHint", ListHint);
812
-
813
- _defineProperty(List, "ListProps", {
814
- Type,
815
- Dimension
816
- });
817
-
818
- export { ActiveItemContext, List as default };