@jetbrains/ring-ui 4.1.0-beta.9 → 4.1.1

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 (354) hide show
  1. package/CHANGELOG.md +13 -0
  2. package/README.md +17 -15
  3. package/babel.config.js +3 -2
  4. package/components/alert/alert.js +9 -3
  5. package/components/alert/container.css +1 -1
  6. package/components/alert-service/alert-service.examples.css +18 -0
  7. package/components/alert-service/alert-service.examples.js +21 -0
  8. package/components/alert-service/alert-service.js +10 -3
  9. package/components/analytics/analytics__fus-plugin.js +1 -1
  10. package/components/auth/auth.test.js +14 -7
  11. package/components/auth/auth__core.js +64 -33
  12. package/components/auth-dialog/auth-dialog.js +1 -0
  13. package/components/avatar/avatar.css +4 -1
  14. package/components/avatar/avatar.examples.js +3 -2
  15. package/components/avatar/avatar.js +31 -6
  16. package/components/avatar/fallback-avatar.js +136 -0
  17. package/components/avatar-editor-ng/avatar-editor-ng.css +2 -2
  18. package/components/avatar-editor-ng/avatar-editor-ng.js +2 -1
  19. package/components/avatar-editor-ng/{avatar-editor-ng.html → avatar-editor-ng__template.js} +2 -2
  20. package/components/button/button.css +2 -2
  21. package/components/button/button.js +4 -1
  22. package/components/button-group/button-group.js +1 -1
  23. package/components/button-group/caption.js +1 -1
  24. package/components/button-ng/button-ng.js +1 -1
  25. package/components/button-set-ng/button-set-ng.js +3 -1
  26. package/components/checkbox/checkbox.css +1 -1
  27. package/components/code/code.js +1 -1
  28. package/components/confirm/confirm.js +1 -0
  29. package/components/confirm-service/confirm-service.js +5 -5
  30. package/components/content-layout/content-layout.css +1 -1
  31. package/components/data-list/data-list.css +1 -1
  32. package/components/date-picker/date-input.js +5 -4
  33. package/components/date-picker/date-picker.css +34 -22
  34. package/components/date-picker/date-picker.js +16 -14
  35. package/components/date-picker/date-popup.js +22 -7
  36. package/components/date-picker/month-names.js +8 -5
  37. package/components/date-picker/month.js +6 -2
  38. package/components/date-picker/weekdays.js +10 -2
  39. package/components/dialog/dialog.examples.js +3 -1
  40. package/components/dialog/dialog.js +5 -2
  41. package/components/dialog/dialog.test.js +1 -1
  42. package/components/dialog/dialog__body-scroll-preventer.js +2 -2
  43. package/components/dialog-ng/dialog-ng.js +7 -8
  44. package/components/dialog-ng/{dialog-ng.html → dialog-ng__template.js} +2 -2
  45. package/components/dropdown/dropdown.examples.js +36 -1
  46. package/components/dropdown-menu/dropdown-menu.examples.js +47 -0
  47. package/components/dropdown-menu/dropdown-menu.js +117 -0
  48. package/components/dropdown-menu/dropdown-menu.test.js +76 -0
  49. package/components/error-bubble/error-bubble-legacy.css +1 -1
  50. package/components/error-bubble/error-bubble.css +1 -1
  51. package/components/error-bubble/error-bubble.examples.js +1 -1
  52. package/components/error-page/error-page.css +2 -2
  53. package/components/footer-ng/footer-ng.js +13 -3
  54. package/components/form/form.css +2 -2
  55. package/components/form-ng/form-ng.js +3 -1
  56. package/components/global/global.css +1 -1
  57. package/components/global/theme.js +1 -1
  58. package/components/global/variables.css +8 -1
  59. package/components/grid/grid.css +10 -9
  60. package/components/header/header.css +1 -1
  61. package/components/header/header.examples.js +7 -8
  62. package/components/header/profile.js +10 -11
  63. package/components/http/http.js +1 -1
  64. package/components/icon/icon.css +5 -4
  65. package/components/island/island.css +4 -3
  66. package/components/island-legacy/island-legacy.css +3 -1
  67. package/components/list/list.js +6 -1
  68. package/components/list/list__custom.js +9 -3
  69. package/components/list/list__item.js +8 -2
  70. package/components/list/list__link.js +2 -1
  71. package/components/loader-inline/loader-inline.css +1 -1
  72. package/components/loader-screen/loader-screen.css +1 -1
  73. package/components/message/message.css +1 -1
  74. package/components/message/message.examples.js +8 -5
  75. package/components/pager/pager.js +5 -3
  76. package/components/permissions/permissions.js +1 -1
  77. package/components/progress-bar/progress-bar.css +1 -1
  78. package/components/progress-bar/progress-bar.examples.js +3 -3
  79. package/components/progress-bar/progress-bar.js +5 -2
  80. package/components/progress-bar/progress-bar.test.js +12 -13
  81. package/components/progress-bar-ng/progress-bar-ng.examples.js +3 -3
  82. package/components/query-assist/query-assist.css +13 -3
  83. package/components/query-assist/query-assist.examples.js +3 -1
  84. package/components/query-assist/query-assist.js +56 -12
  85. package/components/query-assist/query-assist.test.js +37 -5
  86. package/components/save-field-ng/save-field-ng.css +0 -3
  87. package/components/save-field-ng/save-field-ng.js +3 -1
  88. package/components/save-field-ng/{save-field-ng.html → save-field-ng__template.js} +2 -2
  89. package/components/select/select.css +12 -7
  90. package/components/select/select.examples.js +13 -0
  91. package/components/select/select.js +30 -43
  92. package/components/select/select.test.js +4 -5
  93. package/components/shortcuts-hint-ng/shortcuts-hint-ng.css +1 -1
  94. package/components/shortcuts-hint-ng/shortcuts-hint-ng.js +1 -1
  95. package/components/shortcuts-hint-ng/{shortcuts-hint-ng.html → shortcuts-hint-ng__template.js} +2 -2
  96. package/components/sidebar/sidebar.css +1 -0
  97. package/components/sidebar-ng/sidebar-ng.js +6 -2
  98. package/components/sidebar-ng/{sidebar-ng__button.html → sidebar-ng__button-template.js} +2 -2
  99. package/components/sidebar-ng/{sidebar-ng.html → sidebar-ng__template.js} +2 -2
  100. package/components/table/row.js +2 -1
  101. package/components/table/table.css +2 -1
  102. package/components/table-legacy/table-legacy.css +2 -2
  103. package/components/table-legacy/table-legacy__toolbar.css +2 -2
  104. package/components/table-legacy-ng/table-legacy-ng.js +38 -5
  105. package/components/table-legacy-ng/table-legacy-ng__pager.js +7 -1
  106. package/components/tabs/collapsible-tab.js +2 -2
  107. package/components/tabs/collapsible-tabs.js +4 -8
  108. package/components/tabs/tab-link.js +4 -2
  109. package/components/tabs/tabs.css +27 -0
  110. package/components/tabs-ng/tabs-ng.js +4 -2
  111. package/components/tabs-ng/{tabs-ng.html → tabs-ng__template.js} +6 -2
  112. package/components/tag/tag.css +5 -2
  113. package/components/tag/tag.examples.js +3 -0
  114. package/components/tag/tag.js +19 -16
  115. package/components/tags-input/tag-input.examples.js +1 -1
  116. package/components/tags-input/tags-input.js +5 -2
  117. package/components/template-ng/template-ng.js +1 -1
  118. package/components/tooltip/tooltip.js +7 -2
  119. package/components/user-agreement/user-agreement.css +1 -1
  120. package/components/user-agreement/user-agreement.examples.js +7 -4
  121. package/components/user-agreement/user-agreement.js +1 -0
  122. package/package.json +75 -78
  123. package/webpack.config.js +14 -10
  124. package/components/button-set-ng/button-set-ng.html +0 -1
  125. package/components/footer-ng/footer-ng.html +0 -13
  126. package/components/form-ng/form-ng__error-bubble.html +0 -3
  127. package/components/table-legacy-ng/table-legacy-ng.html +0 -4
  128. package/components/table-legacy-ng/table-legacy-ng__column.html +0 -12
  129. package/components/table-legacy-ng/table-legacy-ng__header.html +0 -4
  130. package/components/table-legacy-ng/table-legacy-ng__pager.html +0 -7
  131. package/components/table-legacy-ng/table-legacy-ng__row.html +0 -12
  132. package/components/table-legacy-ng/table-legacy-ng__title.html +0 -9
  133. package/dist/_helpers/_rollupPluginBabelHelpers.js +0 -127
  134. package/dist/_helpers/anchor.js +0 -33
  135. package/dist/_helpers/badge.js +0 -3
  136. package/dist/_helpers/button__classes.js +0 -39
  137. package/dist/_helpers/caption.js +0 -25
  138. package/dist/_helpers/card.js +0 -77
  139. package/dist/_helpers/date-picker.js +0 -3
  140. package/dist/_helpers/dialog__body-scroll-preventer.js +0 -56
  141. package/dist/_helpers/grid.js +0 -3
  142. package/dist/_helpers/header.js +0 -3
  143. package/dist/_helpers/icon__svg.js +0 -83
  144. package/dist/_helpers/inject-styles.js +0 -22
  145. package/dist/_helpers/island.js +0 -3
  146. package/dist/_helpers/list.js +0 -3
  147. package/dist/_helpers/query-assist__suggestions.js +0 -95
  148. package/dist/_helpers/select__filter.js +0 -78
  149. package/dist/_helpers/services-link.js +0 -42
  150. package/dist/_helpers/sidebar.js +0 -127
  151. package/dist/_helpers/table.js +0 -3
  152. package/dist/_helpers/tabs.js +0 -3
  153. package/dist/_helpers/title.js +0 -99
  154. package/dist/alert/alert.js +0 -254
  155. package/dist/alert/container.js +0 -50
  156. package/dist/alert-service/alert-service.js +0 -159
  157. package/dist/analytics/analytics.js +0 -116
  158. package/dist/analytics/analytics__custom-plugin.js +0 -127
  159. package/dist/analytics/analytics__fus-plugin.js +0 -101
  160. package/dist/analytics/analytics__ga-plugin.js +0 -66
  161. package/dist/analytics/analytics__plugin-utils.js +0 -79
  162. package/dist/auth/auth.js +0 -90
  163. package/dist/auth/auth__core.js +0 -987
  164. package/dist/auth/background-flow.js +0 -123
  165. package/dist/auth/down-notification.js +0 -111
  166. package/dist/auth/iframe-flow.js +0 -147
  167. package/dist/auth/landing-entry.js +0 -5
  168. package/dist/auth/landing.js +0 -84
  169. package/dist/auth/request-builder.js +0 -75
  170. package/dist/auth/response-parser.js +0 -117
  171. package/dist/auth/storage.js +0 -279
  172. package/dist/auth/token-validator.js +0 -176
  173. package/dist/auth/window-flow.js +0 -133
  174. package/dist/auth-dialog/auth-dialog.js +0 -132
  175. package/dist/auth-dialog-service/auth-dialog-service.js +0 -67
  176. package/dist/avatar/avatar-example-datauri.js +0 -26
  177. package/dist/avatar/avatar.js +0 -155
  178. package/dist/badge/badge.js +0 -52
  179. package/dist/button/button.js +0 -117
  180. package/dist/button/button__classes.js +0 -5
  181. package/dist/button-group/button-group.js +0 -30
  182. package/dist/button-group/caption.js +0 -5
  183. package/dist/button-set/button-set.js +0 -27
  184. package/dist/button-toolbar/button-toolbar.js +0 -30
  185. package/dist/caret/caret.js +0 -264
  186. package/dist/checkbox/checkbox.js +0 -110
  187. package/dist/confirm/confirm.js +0 -122
  188. package/dist/confirm-service/confirm-service.js +0 -112
  189. package/dist/content-layout/content-layout.js +0 -67
  190. package/dist/content-layout/sidebar.js +0 -6
  191. package/dist/contenteditable/contenteditable.js +0 -81
  192. package/dist/data-list/data-list.js +0 -203
  193. package/dist/data-list/data-list.mock.js +0 -190
  194. package/dist/data-list/item.js +0 -225
  195. package/dist/data-list/selection.js +0 -101
  196. package/dist/data-list/title.js +0 -16
  197. package/dist/date-picker/consts.js +0 -70
  198. package/dist/date-picker/date-input.js +0 -169
  199. package/dist/date-picker/date-picker.js +0 -356
  200. package/dist/date-picker/date-popup.js +0 -459
  201. package/dist/date-picker/day.js +0 -119
  202. package/dist/date-picker/formats.js +0 -3
  203. package/dist/date-picker/month-names.js +0 -92
  204. package/dist/date-picker/month-slider.js +0 -83
  205. package/dist/date-picker/month.js +0 -48
  206. package/dist/date-picker/months.js +0 -121
  207. package/dist/date-picker/weekdays.js +0 -24
  208. package/dist/date-picker/years.js +0 -109
  209. package/dist/dialog/dialog.js +0 -197
  210. package/dist/dialog/dialog__body-scroll-preventer.js +0 -2
  211. package/dist/dropdown/anchor.js +0 -16
  212. package/dist/dropdown/dropdown.js +0 -236
  213. package/dist/error-bubble/error-bubble.js +0 -59
  214. package/dist/error-message/error-message.js +0 -55
  215. package/dist/footer/footer.js +0 -127
  216. package/dist/global/angular-component-factory.js +0 -83
  217. package/dist/global/compose.js +0 -9
  218. package/dist/global/composeRefs.js +0 -15
  219. package/dist/global/conic-gradient.js +0 -37
  220. package/dist/global/create-stateful-context.js +0 -54
  221. package/dist/global/data-tests.js +0 -22
  222. package/dist/global/dom.js +0 -124
  223. package/dist/global/focus-sensor-hoc.js +0 -147
  224. package/dist/global/fuzzy-highlight.js +0 -67
  225. package/dist/global/get-event-key.js +0 -111
  226. package/dist/global/get-uid.js +0 -15
  227. package/dist/global/inject-styles.js +0 -17
  228. package/dist/global/linear-function.js +0 -18
  229. package/dist/global/listeners.js +0 -42
  230. package/dist/global/memoize.js +0 -18
  231. package/dist/global/normalize-indent.js +0 -28
  232. package/dist/global/promise-with-timeout.js +0 -13
  233. package/dist/global/radial-gradient-mask.js +0 -49
  234. package/dist/global/react-dom-renderer.js +0 -45
  235. package/dist/global/rerender-hoc.js +0 -53
  236. package/dist/global/ring-angular-component.js +0 -24
  237. package/dist/global/schedule-raf.js +0 -31
  238. package/dist/global/sniffer.js +0 -6
  239. package/dist/global/supports-css.js +0 -20
  240. package/dist/global/theme.js +0 -56
  241. package/dist/global/trivial-template-tag.js +0 -15
  242. package/dist/global/url.js +0 -163
  243. package/dist/global/variables_dark.js +0 -57
  244. package/dist/grid/col.js +0 -62
  245. package/dist/grid/grid.js +0 -35
  246. package/dist/grid/row.js +0 -66
  247. package/dist/group/group.js +0 -34
  248. package/dist/header/header.js +0 -144
  249. package/dist/header/logo.js +0 -39
  250. package/dist/header/profile.js +0 -212
  251. package/dist/header/services-link.js +0 -10
  252. package/dist/header/services.js +0 -135
  253. package/dist/header/smart-profile.js +0 -227
  254. package/dist/header/smart-services.js +0 -159
  255. package/dist/header/tray-icon.js +0 -45
  256. package/dist/header/tray.js +0 -33
  257. package/dist/heading/heading.js +0 -76
  258. package/dist/http/http.js +0 -216
  259. package/dist/http/http.mock.js +0 -65
  260. package/dist/hub-source/hub-source.js +0 -130
  261. package/dist/hub-source/hub-source__user.js +0 -28
  262. package/dist/hub-source/hub-source__users-groups.js +0 -62
  263. package/dist/icon/icon.js +0 -105
  264. package/dist/icon/icon__constants.js +0 -33
  265. package/dist/icon/icon__svg.js +0 -6
  266. package/dist/icon/index.js +0 -9
  267. package/dist/input/input.js +0 -231
  268. package/dist/island/adaptive-island-hoc.js +0 -48
  269. package/dist/island/content.js +0 -158
  270. package/dist/island/header.js +0 -85
  271. package/dist/island/island.js +0 -53
  272. package/dist/island-legacy/content-legacy.js +0 -28
  273. package/dist/island-legacy/header-legacy.js +0 -30
  274. package/dist/island-legacy/island-legacy.js +0 -30
  275. package/dist/link/clickableLink.js +0 -65
  276. package/dist/link/link.js +0 -118
  277. package/dist/list/consts.js +0 -26
  278. package/dist/list/list.js +0 -800
  279. package/dist/list/list__custom.js +0 -82
  280. package/dist/list/list__hint.js +0 -26
  281. package/dist/list/list__item.js +0 -197
  282. package/dist/list/list__link.js +0 -65
  283. package/dist/list/list__separator.js +0 -30
  284. package/dist/list/list__title.js +0 -39
  285. package/dist/list/list__users-groups-source.js +0 -124
  286. package/dist/loader/loader.js +0 -72
  287. package/dist/loader/loader__core.js +0 -272
  288. package/dist/loader-inline/inject-styles.js +0 -11
  289. package/dist/loader-inline/loader-inline.js +0 -58
  290. package/dist/loader-screen/loader-screen.js +0 -46
  291. package/dist/login-dialog/login-dialog.js +0 -184
  292. package/dist/login-dialog/service.js +0 -67
  293. package/dist/message/message.js +0 -232
  294. package/dist/old-browsers-message/old-browsers-message.js +0 -101
  295. package/dist/old-browsers-message/old-browsers-message__stop.js +0 -5
  296. package/dist/old-browsers-message/white-list.js +0 -34
  297. package/dist/pager/pager.js +0 -352
  298. package/dist/panel/panel.js +0 -34
  299. package/dist/permissions/permissions.js +0 -200
  300. package/dist/permissions/permissions__cache.js +0 -272
  301. package/dist/popup/popup.consts.js +0 -41
  302. package/dist/popup/popup.js +0 -389
  303. package/dist/popup/popup.target.js +0 -27
  304. package/dist/popup/position.js +0 -280
  305. package/dist/popup-menu/popup-menu.js +0 -108
  306. package/dist/progress-bar/progress-bar.js +0 -111
  307. package/dist/proxy-attrs/proxy-attrs.js +0 -19
  308. package/dist/query-assist/query-assist.js +0 -1023
  309. package/dist/query-assist/query-assist__suggestions.js +0 -43
  310. package/dist/radio/radio.js +0 -39
  311. package/dist/radio/radio__item.js +0 -82
  312. package/dist/select/select.js +0 -1335
  313. package/dist/select/select__filter.js +0 -49
  314. package/dist/select/select__popup.js +0 -541
  315. package/dist/shortcuts/core.js +0 -245
  316. package/dist/shortcuts/shortcut-title.js +0 -51
  317. package/dist/shortcuts/shortcuts-hoc.js +0 -43
  318. package/dist/shortcuts/shortcuts.js +0 -72
  319. package/dist/storage/storage.js +0 -55
  320. package/dist/storage/storage__fallback.js +0 -214
  321. package/dist/storage/storage__local.js +0 -150
  322. package/dist/style.css +0 -1
  323. package/dist/tab-trap/tab-trap.js +0 -178
  324. package/dist/table/cell.js +0 -25
  325. package/dist/table/disable-hover-hoc.js +0 -53
  326. package/dist/table/header-cell.js +0 -91
  327. package/dist/table/header.js +0 -189
  328. package/dist/table/multitable.js +0 -140
  329. package/dist/table/row-with-focus-sensor.js +0 -79
  330. package/dist/table/row.js +0 -270
  331. package/dist/table/selection-adapter.js +0 -14
  332. package/dist/table/selection-shortcuts-hoc.js +0 -212
  333. package/dist/table/selection.js +0 -221
  334. package/dist/table/smart-table.js +0 -113
  335. package/dist/table/table.js +0 -405
  336. package/dist/tabs/collapsible-more.js +0 -193
  337. package/dist/tabs/collapsible-tab.js +0 -90
  338. package/dist/tabs/collapsible-tabs.js +0 -361
  339. package/dist/tabs/custom-item.js +0 -13
  340. package/dist/tabs/dumb-tabs.js +0 -159
  341. package/dist/tabs/smart-tabs.js +0 -102
  342. package/dist/tabs/tab-link.js +0 -35
  343. package/dist/tabs/tab.js +0 -32
  344. package/dist/tabs/tabs.js +0 -65
  345. package/dist/tag/tag.js +0 -190
  346. package/dist/tags-input/tags-input.js +0 -474
  347. package/dist/tags-list/tags-list.js +0 -94
  348. package/dist/text/text.js +0 -38
  349. package/dist/toggle/toggle.js +0 -80
  350. package/dist/tooltip/tooltip.js +0 -205
  351. package/dist/user-card/card.js +0 -14
  352. package/dist/user-card/smart-user-card-tooltip.js +0 -112
  353. package/dist/user-card/tooltip.js +0 -91
  354. package/dist/user-card/user-card.js +0 -46
@@ -1,49 +0,0 @@
1
- import '../_helpers/_rollupPluginBabelHelpers.js';
2
- import 'react';
3
- import 'prop-types';
4
- import 'classnames';
5
- import '../input/input.js';
6
- import '../global/sniffer.js';
7
- import '../list/list.js';
8
- export { S as default } from '../_helpers/select__filter.js';
9
- import '@jetbrains/icons/close';
10
- import '../global/theme.js';
11
- import '../button/button.js';
12
- import 'focus-visible';
13
- import '@jetbrains/icons/chevron-10px';
14
- import '../icon/icon.js';
15
- import 'util-deprecate';
16
- import '../icon/icon__constants.js';
17
- import '../_helpers/icon__svg.js';
18
- import '../global/memoize.js';
19
- import '../link/clickableLink.js';
20
- import '../_helpers/button__classes.js';
21
- import '../global/get-uid.js';
22
- import 'sniffr';
23
- import 'react-virtualized/dist/es/List';
24
- import 'react-virtualized/dist/es/AutoSizer';
25
- import 'react-virtualized/dist/es/WindowScroller';
26
- import 'react-virtualized/dist/es/CellMeasurer';
27
- import 'memoize-one';
28
- import '../global/data-tests.js';
29
- import '../global/schedule-raf.js';
30
- import '../global/dom.js';
31
- import '../shortcuts/shortcuts.js';
32
- import '../shortcuts/core.js';
33
- import 'combokeys';
34
- import '../global/create-stateful-context.js';
35
- import '../list/list__link.js';
36
- import '../link/link.js';
37
- import '../_helpers/list.js';
38
- import '../list/list__item.js';
39
- import '../avatar/avatar.js';
40
- import '../global/url.js';
41
- import '../checkbox/checkbox.js';
42
- import '@jetbrains/icons/checkmark';
43
- import '@jetbrains/icons/remove-10px';
44
- import '../list/list__custom.js';
45
- import '../global/get-event-key.js';
46
- import '../list/list__title.js';
47
- import '../list/list__separator.js';
48
- import '../list/list__hint.js';
49
- import '../list/consts.js';
@@ -1,541 +0,0 @@
1
- import { _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import React, { PureComponent } from 'react';
3
- import classNames from 'classnames';
4
- import searchIcon from '@jetbrains/icons/search';
5
- import memoizeOne from 'memoize-one';
6
- import PropTypes from 'prop-types';
7
- import Icon from '../icon/icon.js';
8
- import Popup, { getPopupContainer } from '../popup/popup.js';
9
- import { maxHeightForDirection } from '../popup/position.js';
10
- import { PopupTargetContext } from '../popup/popup.target.js';
11
- import List from '../list/list.js';
12
- import LoaderInline from '../loader-inline/loader-inline.js';
13
- import shortcutsHOC from '../shortcuts/shortcuts-hoc.js';
14
- import { getStyles } from '../global/dom.js';
15
- import getUID from '../global/get-uid.js';
16
- import memoize from '../global/memoize.js';
17
- import TagsList from '../tags-list/tags-list.js';
18
- import Caret from '../caret/caret.js';
19
- import Shortcuts from '../shortcuts/shortcuts.js';
20
- import Button from '../button/button.js';
21
- import Text from '../text/text.js';
22
- import { DEFAULT_DIRECTIONS } from '../popup/popup.consts.js';
23
- import { m as modules_b607bec2, S as SelectFilter } from '../_helpers/select__filter.js';
24
- import 'util-deprecate';
25
- import '../icon/icon__constants.js';
26
- import '../_helpers/icon__svg.js';
27
- import 'react-dom';
28
- import '../global/schedule-raf.js';
29
- import '../global/data-tests.js';
30
- import '../tab-trap/tab-trap.js';
31
- import '../shortcuts/core.js';
32
- import 'combokeys';
33
- import '../global/sniffer.js';
34
- import 'sniffr';
35
- import 'react-virtualized/dist/es/List';
36
- import 'react-virtualized/dist/es/AutoSizer';
37
- import 'react-virtualized/dist/es/WindowScroller';
38
- import 'react-virtualized/dist/es/CellMeasurer';
39
- import '../global/create-stateful-context.js';
40
- import '../list/list__link.js';
41
- import '../link/link.js';
42
- import 'focus-visible';
43
- import '../link/clickableLink.js';
44
- import '../_helpers/list.js';
45
- import '../list/list__item.js';
46
- import '../avatar/avatar.js';
47
- import '../global/url.js';
48
- import '../checkbox/checkbox.js';
49
- import '@jetbrains/icons/checkmark';
50
- import '@jetbrains/icons/remove-10px';
51
- import '../list/list__custom.js';
52
- import '../global/get-event-key.js';
53
- import '../list/list__title.js';
54
- import '../list/list__separator.js';
55
- import '../list/list__hint.js';
56
- import '../list/consts.js';
57
- import '../global/theme.js';
58
- import '../_helpers/inject-styles.js';
59
- import '../global/conic-gradient.js';
60
- import 'conic-gradient';
61
- import '../global/supports-css.js';
62
- import '../global/inject-styles.js';
63
- import '../global/radial-gradient-mask.js';
64
- import '../tag/tag.js';
65
- import '@jetbrains/icons/close';
66
- import '@jetbrains/icons/chevron-10px';
67
- import '../_helpers/button__classes.js';
68
- import '../input/input.js';
69
-
70
- const INPUT_MARGIN_COMPENSATION = -14;
71
- const FILTER_HEIGHT = 35;
72
- const TOOLBAR_HEIGHT = 49;
73
-
74
- function noop() {}
75
-
76
- const FilterWithShortcuts = shortcutsHOC(SelectFilter);
77
- class SelectPopup extends PureComponent {
78
- constructor() {
79
- super(...arguments);
80
-
81
- _defineProperty(this, "state", {
82
- popupFilterShortcutsOptions: {
83
- modal: true,
84
- disabled: true
85
- },
86
- tagsActiveIndex: null
87
- });
88
-
89
- _defineProperty(this, "isClickingPopup", false);
90
-
91
- _defineProperty(this, "onFilterFocus", () => {
92
- this._togglePopupFilterShortcuts(false);
93
-
94
- this.setState({
95
- tagsActiveIndex: null
96
- });
97
- });
98
-
99
- _defineProperty(this, "popupFilterOnBlur", () => {
100
- if (this.state.tagsActiveIndex === null) {
101
- this._togglePopupFilterShortcuts(true);
102
- }
103
- });
104
-
105
- _defineProperty(this, "mouseDownHandler", () => {
106
- this.isClickingPopup = true;
107
- });
108
-
109
- _defineProperty(this, "mouseUpHandler", () => {
110
- this.isClickingPopup = false;
111
- });
112
-
113
- _defineProperty(this, "onListSelect", (selected, event, opts) => {
114
- const getSelectItemEvent = () => {
115
- let customEvent;
116
-
117
- if (document.createEvent) {
118
- customEvent = document.createEvent('Event');
119
- customEvent.initEvent('select', true, false);
120
- }
121
-
122
- if (event && event.persist) {
123
- event.persist();
124
- }
125
-
126
- customEvent.originalEvent = event;
127
- return customEvent;
128
- };
129
-
130
- this.props.onSelect(selected, getSelectItemEvent(), opts);
131
- });
132
-
133
- _defineProperty(this, "tabPress", event => {
134
- this.props.onCloseAttempt(event, true);
135
- });
136
-
137
- _defineProperty(this, "onClickHandler", () => this.filter.focus());
138
-
139
- _defineProperty(this, "handleRemoveTag", memoize(tag => event => this.removeTag(tag, event)));
140
-
141
- _defineProperty(this, "handleTagClick", memoize(tag => () => {
142
- this.setState({
143
- tagsActiveIndex: this.props.selected.indexOf(tag)
144
- });
145
- }));
146
-
147
- _defineProperty(this, "handleListResize", () => {
148
- this.forceUpdate();
149
- });
150
-
151
- _defineProperty(this, "handleSelectAll", () => this.props.onSelectAll(this.props.data.filter(item => !item.disabled).length !== this.props.selected.length));
152
-
153
- _defineProperty(this, "getSelectAll", () => {
154
- const activeFilters = this.props.data.filter(item => !item.disabled);
155
- return /*#__PURE__*/React.createElement("div", {
156
- className: modules_b607bec2.selectAll
157
- }, activeFilters.length === 0 ? /*#__PURE__*/React.createElement("span", null) : /*#__PURE__*/React.createElement(Button, {
158
- text: true,
159
- inline: true,
160
- onClick: this.handleSelectAll
161
- }, activeFilters.length !== this.props.selected.length ? 'Select all' : 'Deselect all'), /*#__PURE__*/React.createElement(Text, {
162
- info: true
163
- }, `${this.props.selected.length} selected`));
164
- });
165
-
166
- _defineProperty(this, "_adjustListMaxHeight", memoizeOne((hidden, userDefinedMaxHeight, ringPopupTarget) => {
167
- if (hidden) {
168
- return userDefinedMaxHeight;
169
- } // Calculate list's maximum height that can't
170
- // get beyond the screen
171
- // @see RG-1838, JT-48358
172
-
173
-
174
- const minMaxHeight = 100;
175
- const directions = this.props.directions || DEFAULT_DIRECTIONS; // Note:
176
- // Create a method which'll be called only when the popup opens and before
177
- // render the list would be a better way
178
-
179
- const anchorNode = this.props.anchorElement;
180
- const containerNode = getPopupContainer(ringPopupTarget) || document.documentElement;
181
- return Math.min(directions.reduce((maxHeight, direction) => Math.max(maxHeight, maxHeightForDirection(direction, anchorNode, getStyles(containerNode).position !== 'static' ? containerNode : null)), minMaxHeight), userDefinedMaxHeight);
182
- }));
183
-
184
- _defineProperty(this, "popupRef", el => {
185
- this.popup = el;
186
- });
187
-
188
- _defineProperty(this, "listRef", el => {
189
- this.list = el;
190
- });
191
-
192
- _defineProperty(this, "filterRef", el => {
193
- this.filter = el;
194
- this.caret = new Caret(this.filter);
195
- });
196
-
197
- _defineProperty(this, "shortcutsScope", getUID('select-popup-'));
198
-
199
- _defineProperty(this, "shortcutsMap", {
200
- tab: this.tabPress
201
- });
202
-
203
- _defineProperty(this, "popupFilterShortcuts", {
204
- map: {
205
- up: event => this.list && this.list.upHandler(event),
206
- down: event => this.list && this.list.downHandler(event),
207
- home: event => this.list && this.list.homeHandler(event),
208
- end: event => this.list && this.list.endHandler(event),
209
- enter: event => this.list ? this.list.enterHandler(event) : this.props.onEmptyPopupEnter(event),
210
- esc: event => this.props.onCloseAttempt(event, true),
211
- tab: event => this.tabPress(event),
212
- backspace: event => this.handleBackspace(event),
213
- del: () => this.removeSelectedTag(),
214
- left: () => this.handleNavigation(true),
215
- right: () => this.handleNavigation()
216
- }
217
- });
218
- }
219
-
220
- componentDidMount() {
221
- window.document.addEventListener('mouseup', this.mouseUpHandler);
222
- }
223
-
224
- componentWillUnmount() {
225
- window.document.removeEventListener('mouseup', this.mouseUpHandler);
226
- }
227
-
228
- // This flag is set to true while an item in the popup is being clicked
229
- focusFilter() {
230
- setTimeout(() => this.filter.focus());
231
- }
232
-
233
- isEventTargetFilter(event) {
234
- return event.target && event.target.matches('input,textarea');
235
- }
236
-
237
- handleNavigation(navigateLeft) {
238
- if (this.isEventTargetFilter(event) && this.caret.getPosition() > 0) {
239
- return;
240
- }
241
-
242
- let newIndex = null;
243
-
244
- if (navigateLeft) {
245
- newIndex = this.state.tagsActiveIndex === null ? this.props.selected.length - 1 : this.state.tagsActiveIndex - 1;
246
- } else if (this.state.tagsActiveIndex !== null) {
247
- newIndex = this.state.tagsActiveIndex + 1;
248
- }
249
-
250
- if (newIndex !== null && (newIndex >= this.props.selected.length || newIndex < 0)) {
251
- newIndex = null;
252
- this.focusFilter();
253
- }
254
-
255
- this.setState({
256
- tagsActiveIndex: newIndex
257
- });
258
- }
259
-
260
- removeTag(tag, event) {
261
- const _tag = tag || this.props.selected.slice(0)[this.props.selected.length - 1];
262
-
263
- if (_tag) {
264
- this.onListSelect(_tag, event, {
265
- tryKeepOpen: true
266
- });
267
- this.setState({
268
- tagsActiveIndex: null
269
- });
270
- this.focusFilter();
271
- }
272
- }
273
-
274
- removeSelectedTag() {
275
- if (this.state.tagsActiveIndex != null) {
276
- this.removeTag(this.props.selected[this.state.tagsActiveIndex]);
277
- return false;
278
- }
279
-
280
- return true;
281
- }
282
-
283
- handleBackspace(event) {
284
- if (!this.props.tags) {
285
- return true;
286
- }
287
-
288
- if (!this.isEventTargetFilter(event)) {
289
- this.removeSelectedTag();
290
- return false;
291
- }
292
-
293
- if (!event.target.value) {
294
- this.removeTag();
295
- return false;
296
- }
297
-
298
- return true;
299
- }
300
-
301
- _togglePopupFilterShortcuts(shortcutsDisabled) {
302
- this.setState({
303
- popupFilterShortcutsOptions: {
304
- modal: true,
305
- disabled: shortcutsDisabled
306
- }
307
- });
308
- }
309
-
310
- isVisible() {
311
- return this.popup && this.popup.isVisible();
312
- }
313
-
314
- getFilter() {
315
- if (this.props.filter || this.props.tags) {
316
- return /*#__PURE__*/React.createElement("div", {
317
- className: modules_b607bec2.filterWrapper,
318
- "data-test": "ring-select-popup-filter"
319
- }, /*#__PURE__*/React.createElement(Icon, {
320
- glyph: searchIcon,
321
- className: modules_b607bec2.filterIcon,
322
- "data-test-custom": "ring-select-popup-filter-icon"
323
- }), /*#__PURE__*/React.createElement(FilterWithShortcuts, {
324
- rgShortcutsOptions: this.state.popupFilterShortcutsOptions,
325
- rgShortcutsMap: this.popupFilterShortcuts.map,
326
- value: this.props.filterValue,
327
- inputRef: this.filterRef,
328
- onBlur: this.popupFilterOnBlur,
329
- onFocus: this.onFilterFocus,
330
- className: "ring-js-shortcuts",
331
- placeholder: this.props.filter.placeholder,
332
- onChange: this.props.onFilter,
333
- onClick: this.onClickHandler,
334
- onClear: this.props.onClear,
335
- "data-test-custom": "ring-select-popup-filter-input",
336
- listId: this.props.listId,
337
- enableShortcuts: Object.keys(this.popupFilterShortcuts.map)
338
- }));
339
- }
340
-
341
- return null;
342
- }
343
-
344
- getTags() {
345
- return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(TagsList, {
346
- tags: this.props.selected,
347
- activeIndex: this.state.tagsActiveIndex,
348
- handleRemove: this.handleRemoveTag,
349
- handleClick: this.handleTagClick,
350
- disabled: this.props.disabled
351
- }));
352
- }
353
-
354
- getFilterWithTags() {
355
- if (this.props.tags) {
356
- const classes = classNames([modules_b607bec2.filterWithTags, {
357
- [modules_b607bec2.filterWithTagsFocused]: !this.state.popupFilterShortcutsOptions.disabled
358
- }]);
359
- return /*#__PURE__*/React.createElement("div", {
360
- className: classes
361
- }, this.getTags(), this.getFilter());
362
- }
363
-
364
- return this.getFilter();
365
- }
366
-
367
- getBottomLine() {
368
- const {
369
- loading,
370
- message
371
- } = this.props;
372
- return (loading || message) && /*#__PURE__*/React.createElement("div", {
373
- className: modules_b607bec2.bottomLine
374
- }, loading && /*#__PURE__*/React.createElement(LoaderInline, null), message && /*#__PURE__*/React.createElement("div", {
375
- className: modules_b607bec2.message
376
- }, message));
377
- }
378
-
379
- getList(ringPopupTarget) {
380
- if (this.props.data.length) {
381
- let {
382
- maxHeight
383
- } = this.props;
384
-
385
- if (this.props.anchorElement) {
386
- maxHeight = this._adjustListMaxHeight(this.props.hidden, maxHeight, ringPopupTarget);
387
- }
388
-
389
- if (this.props.filter) {
390
- maxHeight -= FILTER_HEIGHT;
391
- }
392
-
393
- if (this.props.toolbar) {
394
- maxHeight -= TOOLBAR_HEIGHT;
395
- }
396
-
397
- return /*#__PURE__*/React.createElement(List, {
398
- id: this.props.listId,
399
- maxHeight: maxHeight,
400
- data: this.props.data,
401
- activeIndex: this.props.activeIndex,
402
- ref: this.listRef,
403
- restoreActiveIndex: true,
404
- activateFirstItem: true,
405
- onSelect: this.onListSelect,
406
- onResize: this.handleListResize,
407
- onScrollToBottom: this.props.onLoadMore,
408
- hidden: this.props.hidden,
409
- shortcuts: !this.props.hidden,
410
- disableMoveOverflow: this.props.disableMoveOverflow,
411
- disableMoveDownOverflow: this.props.loading,
412
- disableScrollToActive: this.props.disableScrollToActive,
413
- compact: this.props.compact,
414
- renderOptimization: this.props.renderOptimization
415
- });
416
- }
417
-
418
- return null;
419
- }
420
-
421
- render() {
422
- const {
423
- toolbar,
424
- className,
425
- multiple,
426
- hidden,
427
- isInputMode,
428
- anchorElement,
429
- minWidth,
430
- onCloseAttempt,
431
- directions,
432
- top,
433
- left,
434
- style,
435
- dir,
436
- filter
437
- } = this.props;
438
- const classes = classNames(modules_b607bec2.popup, className);
439
- return /*#__PURE__*/React.createElement(PopupTargetContext.Consumer, null, ringPopupTarget => {
440
- const filterWithTags = this.getFilterWithTags();
441
- const selectAll = multiple && !multiple.limit && multiple.selectAll && this.getSelectAll();
442
- const list = this.getList(this.props.ringPopupTarget || ringPopupTarget);
443
- const bottomLine = this.getBottomLine();
444
- const hasContent = filterWithTags || selectAll || list || bottomLine || toolbar;
445
- return /*#__PURE__*/React.createElement(Popup, {
446
- trapFocus: false,
447
- ref: this.popupRef,
448
- hidden: hidden || !hasContent,
449
- attached: isInputMode,
450
- className: classes,
451
- dontCloseOnAnchorClick: true,
452
- anchorElement: anchorElement,
453
- minWidth: minWidth,
454
- onCloseAttempt: onCloseAttempt,
455
- directions: directions,
456
- top: top || (isInputMode ? INPUT_MARGIN_COMPENSATION : null),
457
- left: left,
458
- onMouseDown: this.mouseDownHandler,
459
- target: this.props.ringPopupTarget,
460
- autoCorrectTopOverflow: false,
461
- style: style
462
- }, /*#__PURE__*/React.createElement("div", {
463
- dir: dir
464
- }, !hidden && filter && /*#__PURE__*/React.createElement(Shortcuts, {
465
- map: this.shortcutsMap,
466
- scope: this.shortcutsScope
467
- }), hidden ? /*#__PURE__*/React.createElement("div", null) : filterWithTags, selectAll, list, bottomLine, toolbar));
468
- });
469
- }
470
-
471
- }
472
-
473
- _defineProperty(SelectPopup, "propTypes", {
474
- activeIndex: PropTypes.number,
475
- anchorElement: PropTypes.instanceOf(HTMLElement),
476
- className: PropTypes.string,
477
- compact: PropTypes.bool,
478
- data: PropTypes.array,
479
- dir: PropTypes.oneOf(['ltr', 'rtl']),
480
- directions: PropTypes.array,
481
- disabled: PropTypes.bool,
482
- disableMoveOverflow: PropTypes.bool,
483
- disableScrollToActive: PropTypes.bool,
484
- filter: PropTypes.oneOfType([PropTypes.bool, PropTypes.shape({
485
- value: PropTypes.string,
486
- placeholder: PropTypes.string
487
- })]),
488
- filterValue: PropTypes.string,
489
- hidden: PropTypes.bool,
490
- isInputMode: PropTypes.bool,
491
- listId: PropTypes.string,
492
- maxHeight: PropTypes.number,
493
- message: PropTypes.string,
494
- minWidth: PropTypes.number,
495
- multiple: PropTypes.oneOfType([PropTypes.bool, PropTypes.shape({
496
- label: PropTypes.string,
497
- limit: PropTypes.number,
498
- selectAll: PropTypes.bool
499
- })]),
500
- left: PropTypes.bool,
501
- loading: PropTypes.bool,
502
- onClear: PropTypes.func,
503
- onCloseAttempt: PropTypes.func,
504
- onEmptyPopupEnter: PropTypes.func,
505
- onFilter: PropTypes.func,
506
- onLoadMore: PropTypes.func,
507
- onSelect: PropTypes.func,
508
- onSelectAll: PropTypes.func,
509
- renderOptimization: PropTypes.bool,
510
- ringPopupTarget: PropTypes.string,
511
- selected: PropTypes.oneOfType([PropTypes.object, PropTypes.array]),
512
- style: PropTypes.object,
513
- tags: PropTypes.object,
514
- toolbar: PropTypes.node,
515
- top: PropTypes.number
516
- });
517
-
518
- _defineProperty(SelectPopup, "defaultProps", {
519
- data: [],
520
- activeIndex: null,
521
- toolbar: null,
522
- filter: false,
523
- multiple: false,
524
- message: null,
525
- anchorElement: null,
526
- maxHeight: 600,
527
- minWidth: 240,
528
- loading: false,
529
- onSelect: noop,
530
- onCloseAttempt: noop,
531
- onFilter: noop,
532
- onClear: noop,
533
- onLoadMore: noop,
534
- selected: [],
535
- tags: null,
536
- ringPopupTarget: null,
537
- onSelectAll: noop,
538
- onEmptyPopupEnter: noop
539
- });
540
-
541
- export default SelectPopup;