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