@jetbrains/ring-ui 4.2.4 → 4.2.5

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 (315) hide show
  1. package/package.json +2 -2
  2. package/dist/_helpers/_rollupPluginBabelHelpers.js +0 -34
  3. package/dist/_helpers/anchor.js +0 -33
  4. package/dist/_helpers/badge.js +0 -3
  5. package/dist/_helpers/button-group.js +0 -3
  6. package/dist/_helpers/button-set.js +0 -3
  7. package/dist/_helpers/button-toolbar.js +0 -3
  8. package/dist/_helpers/button__classes.js +0 -39
  9. package/dist/_helpers/card.js +0 -75
  10. package/dist/_helpers/checkbox.js +0 -3
  11. package/dist/_helpers/date-picker.js +0 -3
  12. package/dist/_helpers/dialog__body-scroll-preventer.js +0 -58
  13. package/dist/_helpers/error-message.js +0 -3
  14. package/dist/_helpers/footer.js +0 -121
  15. package/dist/_helpers/grid.js +0 -3
  16. package/dist/_helpers/group.js +0 -3
  17. package/dist/_helpers/header.js +0 -3
  18. package/dist/_helpers/icon.js +0 -3
  19. package/dist/_helpers/inject-styles.js +0 -22
  20. package/dist/_helpers/input.js +0 -3
  21. package/dist/_helpers/island.js +0 -3
  22. package/dist/_helpers/link.js +0 -3
  23. package/dist/_helpers/list.js +0 -3
  24. package/dist/_helpers/loader-screen.js +0 -3
  25. package/dist/_helpers/panel.js +0 -3
  26. package/dist/_helpers/query-assist__suggestions.js +0 -95
  27. package/dist/_helpers/radio.js +0 -3
  28. package/dist/_helpers/select__filter.js +0 -77
  29. package/dist/_helpers/services-link.js +0 -40
  30. package/dist/_helpers/sidebar.js +0 -126
  31. package/dist/_helpers/table.js +0 -3
  32. package/dist/_helpers/tabs.js +0 -3
  33. package/dist/_helpers/title.js +0 -100
  34. package/dist/alert/alert.js +0 -262
  35. package/dist/alert/container.js +0 -48
  36. package/dist/alert-service/alert-service.js +0 -173
  37. package/dist/analytics/analytics.js +0 -118
  38. package/dist/analytics/analytics__custom-plugin.js +0 -128
  39. package/dist/analytics/analytics__fus-plugin.js +0 -102
  40. package/dist/analytics/analytics__ga-plugin.js +0 -75
  41. package/dist/analytics/analytics__plugin-utils.js +0 -80
  42. package/dist/analytics-ng/analytics-ng.js +0 -95
  43. package/dist/auth/auth.js +0 -96
  44. package/dist/auth/auth__core.js +0 -1059
  45. package/dist/auth/background-flow.js +0 -123
  46. package/dist/auth/down-notification.js +0 -117
  47. package/dist/auth/iframe-flow.js +0 -153
  48. package/dist/auth/landing-entry.js +0 -5
  49. package/dist/auth/landing.js +0 -90
  50. package/dist/auth/request-builder.js +0 -76
  51. package/dist/auth/response-parser.js +0 -118
  52. package/dist/auth/storage.js +0 -283
  53. package/dist/auth/token-validator.js +0 -178
  54. package/dist/auth/window-flow.js +0 -134
  55. package/dist/auth-dialog/auth-dialog.js +0 -180
  56. package/dist/auth-dialog-service/auth-dialog-service.js +0 -71
  57. package/dist/auth-ng/auth-ng.js +0 -206
  58. package/dist/auth-ng/auth-ng.mock.js +0 -33
  59. package/dist/autofocus-ng/autofocus-ng.js +0 -51
  60. package/dist/avatar/avatar-example-datauri.js +0 -4
  61. package/dist/avatar/avatar.js +0 -163
  62. package/dist/avatar/fallback-avatar.js +0 -142
  63. package/dist/avatar-editor-ng/avatar-editor-ng.js +0 -167
  64. package/dist/avatar-editor-ng/avatar-editor-ng__template.js +0 -3
  65. package/dist/avatar-ng/avatar-ng.js +0 -21
  66. package/dist/badge/badge.js +0 -51
  67. package/dist/badge-ng/badge-ng.js +0 -18
  68. package/dist/breadcrumb-ng/breadcrumb-ng.js +0 -37
  69. package/dist/button/button.js +0 -125
  70. package/dist/button/button__classes.js +0 -5
  71. package/dist/button-group/button-group.js +0 -30
  72. package/dist/button-group/caption.js +0 -24
  73. package/dist/button-group-ng/button-group-ng.js +0 -39
  74. package/dist/button-ng/button-ng.js +0 -217
  75. package/dist/button-set/button-set.js +0 -26
  76. package/dist/button-set-ng/button-set-ng.js +0 -19
  77. package/dist/button-toolbar/button-toolbar.js +0 -29
  78. package/dist/button-toolbar-ng/button-toolbar-ng.js +0 -24
  79. package/dist/caret/caret.js +0 -266
  80. package/dist/checkbox/checkbox.js +0 -110
  81. package/dist/checkbox-ng/checkbox-ng.js +0 -38
  82. package/dist/code/code.js +0 -137
  83. package/dist/compiler-ng/compiler-ng.js +0 -53
  84. package/dist/confirm/confirm.js +0 -127
  85. package/dist/confirm-ng/confirm-ng.js +0 -69
  86. package/dist/confirm-service/confirm-service.js +0 -117
  87. package/dist/content-layout/content-layout.js +0 -66
  88. package/dist/content-layout/sidebar.js +0 -7
  89. package/dist/contenteditable/contenteditable.js +0 -78
  90. package/dist/data-list/data-list.js +0 -208
  91. package/dist/data-list/data-list.mock.js +0 -191
  92. package/dist/data-list/item.js +0 -229
  93. package/dist/data-list/selection.js +0 -102
  94. package/dist/data-list/title.js +0 -20
  95. package/dist/data-list-ng/data-list-ng.js +0 -62
  96. package/dist/date-picker/consts.js +0 -69
  97. package/dist/date-picker/date-input.js +0 -175
  98. package/dist/date-picker/date-picker.js +0 -367
  99. package/dist/date-picker/date-popup.js +0 -483
  100. package/dist/date-picker/day.js +0 -120
  101. package/dist/date-picker/formats.js +0 -3
  102. package/dist/date-picker/month-names.js +0 -100
  103. package/dist/date-picker/month-slider.js +0 -84
  104. package/dist/date-picker/month.js +0 -55
  105. package/dist/date-picker/months.js +0 -122
  106. package/dist/date-picker/weekdays.js +0 -32
  107. package/dist/date-picker/years.js +0 -110
  108. package/dist/dialog/dialog.js +0 -202
  109. package/dist/dialog/dialog__body-scroll-preventer.js +0 -3
  110. package/dist/dialog-ng/dialog-ng.js +0 -604
  111. package/dist/dialog-ng/dialog-ng__template.js +0 -3
  112. package/dist/docked-panel-ng/docked-panel-ng.js +0 -171
  113. package/dist/dropdown/anchor.js +0 -19
  114. package/dist/dropdown/dropdown.js +0 -236
  115. package/dist/dropdown-menu/dropdown-menu.js +0 -177
  116. package/dist/error-bubble/error-bubble.js +0 -59
  117. package/dist/error-message/error-message.js +0 -57
  118. package/dist/error-message-ng/error-message-ng.js +0 -35
  119. package/dist/footer/footer.js +0 -12
  120. package/dist/footer-ng/footer-ng.js +0 -64
  121. package/dist/form-ng/form-ng.js +0 -167
  122. package/dist/global/angular-component-factory.js +0 -84
  123. package/dist/global/compose.js +0 -9
  124. package/dist/global/composeRefs.js +0 -15
  125. package/dist/global/conic-gradient.js +0 -35
  126. package/dist/global/create-stateful-context.js +0 -55
  127. package/dist/global/data-tests.js +0 -24
  128. package/dist/global/dom.js +0 -125
  129. package/dist/global/focus-sensor-hoc.js +0 -146
  130. package/dist/global/fuzzy-highlight.js +0 -67
  131. package/dist/global/get-event-key.js +0 -111
  132. package/dist/global/get-uid.js +0 -15
  133. package/dist/global/inject-styles.js +0 -15
  134. package/dist/global/linear-function.js +0 -17
  135. package/dist/global/listeners.js +0 -44
  136. package/dist/global/memoize.js +0 -20
  137. package/dist/global/normalize-indent.js +0 -30
  138. package/dist/global/promise-with-timeout.js +0 -17
  139. package/dist/global/radial-gradient-mask.js +0 -38
  140. package/dist/global/react-dom-renderer.js +0 -46
  141. package/dist/global/react-render-adapter.js +0 -41
  142. package/dist/global/rerender-hoc.js +0 -55
  143. package/dist/global/ring-angular-component.js +0 -24
  144. package/dist/global/schedule-raf.js +0 -31
  145. package/dist/global/sniffer.js +0 -6
  146. package/dist/global/supports-css.js +0 -22
  147. package/dist/global/theme.js +0 -54
  148. package/dist/global/trivial-template-tag.js +0 -17
  149. package/dist/global/url.js +0 -165
  150. package/dist/global/variables_dark.js +0 -57
  151. package/dist/grid/col.js +0 -60
  152. package/dist/grid/grid.js +0 -33
  153. package/dist/grid/row.js +0 -64
  154. package/dist/group/group.js +0 -31
  155. package/dist/group-ng/group-ng.js +0 -11
  156. package/dist/header/header.js +0 -150
  157. package/dist/header/logo.js +0 -40
  158. package/dist/header/profile.js +0 -219
  159. package/dist/header/services-link.js +0 -12
  160. package/dist/header/services.js +0 -138
  161. package/dist/header/smart-profile.js +0 -233
  162. package/dist/header/smart-services.js +0 -163
  163. package/dist/header/tray-icon.js +0 -47
  164. package/dist/header/tray.js +0 -31
  165. package/dist/heading/heading.js +0 -73
  166. package/dist/http/http.js +0 -218
  167. package/dist/http/http.mock.js +0 -67
  168. package/dist/hub-source/hub-source.js +0 -130
  169. package/dist/hub-source/hub-source__user.js +0 -30
  170. package/dist/hub-source/hub-source__users-groups.js +0 -63
  171. package/dist/icon/icon.js +0 -105
  172. package/dist/icon/icon__constants.js +0 -33
  173. package/dist/icon/icon__svg.js +0 -83
  174. package/dist/icon/index.js +0 -12
  175. package/dist/icon-ng/icon-ng.js +0 -91
  176. package/dist/input/input.js +0 -230
  177. package/dist/input-ng/input-ng.js +0 -111
  178. package/dist/island/adaptive-island-hoc.js +0 -48
  179. package/dist/island/content.js +0 -160
  180. package/dist/island/header.js +0 -84
  181. package/dist/island/island.js +0 -51
  182. package/dist/island-legacy/content-legacy.js +0 -26
  183. package/dist/island-legacy/header-legacy.js +0 -28
  184. package/dist/island-legacy/island-legacy.js +0 -28
  185. package/dist/island-ng/island-content-ng.js +0 -42
  186. package/dist/island-ng/island-header-ng.js +0 -26
  187. package/dist/island-ng/island-ng-class-fixer.js +0 -11
  188. package/dist/island-ng/island-ng.js +0 -25
  189. package/dist/link/clickableLink.js +0 -64
  190. package/dist/link/link.js +0 -115
  191. package/dist/link-ng/link-ng.js +0 -22
  192. package/dist/list/consts.js +0 -26
  193. package/dist/list/list.js +0 -818
  194. package/dist/list/list__custom.js +0 -86
  195. package/dist/list/list__hint.js +0 -26
  196. package/dist/list/list__item.js +0 -206
  197. package/dist/list/list__link.js +0 -65
  198. package/dist/list/list__separator.js +0 -30
  199. package/dist/list/list__title.js +0 -39
  200. package/dist/list/list__users-groups-source.js +0 -130
  201. package/dist/loader/loader.js +0 -71
  202. package/dist/loader/loader__core.js +0 -273
  203. package/dist/loader-inline/inject-styles.js +0 -13
  204. package/dist/loader-inline/loader-inline.js +0 -58
  205. package/dist/loader-inline-ng/loader-inline-ng.js +0 -44
  206. package/dist/loader-ng/loader-ng.js +0 -44
  207. package/dist/loader-screen/loader-screen.js +0 -44
  208. package/dist/loader-screen-ng/loader-screen-ng.js +0 -95
  209. package/dist/login-dialog/login-dialog.js +0 -188
  210. package/dist/login-dialog/service.js +0 -72
  211. package/dist/markdown/code.js +0 -31
  212. package/dist/markdown/heading.js +0 -23
  213. package/dist/markdown/link.js +0 -31
  214. package/dist/markdown/markdown.js +0 -74
  215. package/dist/message/message.js +0 -235
  216. package/dist/message-bundle-ng/message-bundle-ng.js +0 -111
  217. package/dist/old-browsers-message/old-browsers-message.js +0 -101
  218. package/dist/old-browsers-message/old-browsers-message__stop.js +0 -5
  219. package/dist/old-browsers-message/white-list.js +0 -34
  220. package/dist/pager/pager.js +0 -365
  221. package/dist/pager-ng/pager-ng.js +0 -100
  222. package/dist/panel/panel.js +0 -31
  223. package/dist/panel-ng/panel-ng.js +0 -17
  224. package/dist/permissions/permissions.js +0 -200
  225. package/dist/permissions/permissions__cache.js +0 -272
  226. package/dist/permissions-ng/permissions-ng.js +0 -277
  227. package/dist/place-under-ng/place-under-ng.js +0 -158
  228. package/dist/popup/popup.consts.js +0 -41
  229. package/dist/popup/popup.js +0 -396
  230. package/dist/popup/popup.target.js +0 -26
  231. package/dist/popup/position.js +0 -280
  232. package/dist/popup-menu/popup-menu.js +0 -117
  233. package/dist/progress-bar/progress-bar.js +0 -114
  234. package/dist/progress-bar-ng/progress-bar-ng.js +0 -17
  235. package/dist/promised-click-ng/promised-click-ng.js +0 -128
  236. package/dist/proxy-attrs/proxy-attrs.js +0 -21
  237. package/dist/query-assist/query-assist.js +0 -1096
  238. package/dist/query-assist/query-assist__suggestions.js +0 -49
  239. package/dist/query-assist-ng/query-assist-ng.js +0 -86
  240. package/dist/radio/radio.js +0 -42
  241. package/dist/radio/radio__item.js +0 -78
  242. package/dist/radio-ng/radio-ng.js +0 -47
  243. package/dist/save-field-ng/save-field-ng.js +0 -337
  244. package/dist/save-field-ng/save-field-ng__template.js +0 -3
  245. package/dist/select/select.js +0 -1357
  246. package/dist/select/select__filter.js +0 -56
  247. package/dist/select/select__popup.js +0 -553
  248. package/dist/select-ng/select-ng.js +0 -637
  249. package/dist/select-ng/select-ng__lazy.js +0 -169
  250. package/dist/select-ng/select-ng__options.js +0 -145
  251. package/dist/shortcuts/core.js +0 -245
  252. package/dist/shortcuts/shortcut-title.js +0 -51
  253. package/dist/shortcuts/shortcuts-hoc.js +0 -42
  254. package/dist/shortcuts/shortcuts.js +0 -72
  255. package/dist/shortcuts-hint-ng/shortcuts-hint-ng.js +0 -123
  256. package/dist/shortcuts-hint-ng/shortcuts-hint-ng__template.js +0 -3
  257. package/dist/shortcuts-ng/shortcuts-ng.js +0 -262
  258. package/dist/sidebar-ng/sidebar-ng.js +0 -113
  259. package/dist/sidebar-ng/sidebar-ng__button-template.js +0 -3
  260. package/dist/sidebar-ng/sidebar-ng__template.js +0 -3
  261. package/dist/storage/storage.js +0 -59
  262. package/dist/storage/storage__fallback.js +0 -215
  263. package/dist/storage/storage__local.js +0 -154
  264. package/dist/style.css +0 -1
  265. package/dist/tab-trap/tab-trap.js +0 -177
  266. package/dist/table/cell.js +0 -26
  267. package/dist/table/disable-hover-hoc.js +0 -54
  268. package/dist/table/header-cell.js +0 -92
  269. package/dist/table/header.js +0 -193
  270. package/dist/table/multitable.js +0 -141
  271. package/dist/table/row-with-focus-sensor.js +0 -83
  272. package/dist/table/row.js +0 -273
  273. package/dist/table/selection-adapter.js +0 -16
  274. package/dist/table/selection-shortcuts-hoc.js +0 -215
  275. package/dist/table/selection.js +0 -223
  276. package/dist/table/smart-table.js +0 -125
  277. package/dist/table/table.js +0 -406
  278. package/dist/table-legacy-ng/table-legacy-ng.js +0 -468
  279. package/dist/table-legacy-ng/table-legacy-ng__pager.js +0 -120
  280. package/dist/table-legacy-ng/table-legacy-ng__selection-navigate-actions.js +0 -123
  281. package/dist/table-legacy-ng/table-legacy-ng__selection.js +0 -179
  282. package/dist/table-legacy-ng/table-legacy-ng__toolbar.js +0 -57
  283. package/dist/table-ng/smart-table-ng.js +0 -68
  284. package/dist/table-ng/table-ng.js +0 -67
  285. package/dist/tabs/collapsible-more.js +0 -198
  286. package/dist/tabs/collapsible-tab.js +0 -91
  287. package/dist/tabs/collapsible-tabs.js +0 -362
  288. package/dist/tabs/custom-item.js +0 -13
  289. package/dist/tabs/dumb-tabs.js +0 -164
  290. package/dist/tabs/smart-tabs.js +0 -106
  291. package/dist/tabs/tab-link.js +0 -42
  292. package/dist/tabs/tab.js +0 -33
  293. package/dist/tabs/tabs.js +0 -71
  294. package/dist/tabs-ng/tabs-ng.js +0 -194
  295. package/dist/tabs-ng/tabs-ng__template.js +0 -3
  296. package/dist/tag/tag.js +0 -197
  297. package/dist/tags-input/tags-input.js +0 -482
  298. package/dist/tags-input-ng/tags-input-ng.js +0 -93
  299. package/dist/tags-list/tags-list.js +0 -95
  300. package/dist/template-ng/template-ng.js +0 -71
  301. package/dist/text/text.js +0 -36
  302. package/dist/theme-ng/theme-ng.js +0 -45
  303. package/dist/title-ng/title-ng.js +0 -114
  304. package/dist/toggle/toggle.js +0 -78
  305. package/dist/toggle-ng/toggle-ng.js +0 -18
  306. package/dist/tooltip/tooltip.js +0 -209
  307. package/dist/tooltip-ng/tooltip-ng.js +0 -104
  308. package/dist/user-agreement/service.js +0 -412
  309. package/dist/user-agreement/toolbox.eula.js +0 -3
  310. package/dist/user-agreement/user-agreement.js +0 -169
  311. package/dist/user-card/card.js +0 -19
  312. package/dist/user-card/smart-user-card-tooltip.js +0 -114
  313. package/dist/user-card/tooltip.js +0 -95
  314. package/dist/user-card/user-card.js +0 -51
  315. 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 };