@jetbrains/ring-ui 4.2.3 → 4.2.6

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