@jetbrains/ring-ui 5.1.1 → 5.1.3

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 (753) hide show
  1. package/README.md +1 -6
  2. package/components/alert/alert.d.ts +1 -1
  3. package/components/alert/container.css +3 -0
  4. package/components/alert-service/alert-service.d.ts +2 -2
  5. package/components/analytics/analytics.d.ts +21 -7
  6. package/components/analytics/analytics.js +19 -24
  7. package/components/analytics/analytics__custom-plugin.d.ts +6 -16
  8. package/components/analytics/analytics__custom-plugin.js +12 -52
  9. package/components/analytics/analytics__fus-plugin.d.ts +15 -25
  10. package/components/analytics/analytics__fus-plugin.js +15 -73
  11. package/components/analytics/analytics__ga-plugin.d.ts +13 -3
  12. package/components/analytics/analytics__ga-plugin.js +35 -5
  13. package/components/analytics/analytics__plugin-utils.d.ts +16 -0
  14. package/components/analytics/analytics__plugin-utils.js +26 -1
  15. package/components/auth/auth__core.d.ts +5 -4
  16. package/components/auth/auth__core.js +44 -27
  17. package/components/auth-dialog/auth-dialog.d.ts +2 -2
  18. package/components/auth-dialog/auth-dialog.js +3 -1
  19. package/components/auth-dialog-service/auth-dialog-service.js +4 -1
  20. package/components/avatar/avatar.d.ts +3 -3
  21. package/components/avatar/fallback-avatar.d.ts +2 -2
  22. package/components/avatar/fallback-avatar.js +2 -1
  23. package/components/avatar-editor-ng/avatar-editor-ng.css +1 -1
  24. package/components/badge/badge.d.ts +2 -2
  25. package/components/button/button.css +7 -7
  26. package/components/button/button.d.ts +3 -4
  27. package/components/button/button.js +0 -1
  28. package/components/button-group/button-group.css +2 -2
  29. package/components/button-group/button-group.d.ts +2 -2
  30. package/components/button-group/caption.d.ts +2 -2
  31. package/components/button-ng/button-ng.js +1 -1
  32. package/components/button-ng/{button-ng.examples.js → button-ng.stories.js} +2 -2
  33. package/components/button-set/button-set.d.ts +2 -2
  34. package/components/button-toolbar/button-toolbar.d.ts +2 -2
  35. package/components/checkbox/checkbox.css +2 -2
  36. package/components/checkbox/checkbox.d.ts +2 -2
  37. package/components/code/code.d.ts +1 -1
  38. package/components/confirm/confirm.d.ts +1 -1
  39. package/components/confirm/confirm.js +3 -3
  40. package/components/confirm-ng/{confirm-ng.examples.js → confirm-ng.stories.js} +1 -1
  41. package/components/confirm-service/confirm-service.js +2 -2
  42. package/components/content-layout/content-layout.d.ts +2 -2
  43. package/components/content-layout/sidebar.d.ts +2 -2
  44. package/components/contenteditable/contenteditable.d.ts +3 -3
  45. package/components/control-label/control-label.css +23 -0
  46. package/components/control-label/control-label.d.ts +11 -0
  47. package/components/control-label/control-label.js +22 -0
  48. package/components/data-list/data-list.css +2 -1
  49. package/components/data-list/data-list.d.ts +3 -3
  50. package/components/data-list/data-list.mock.d.ts +2 -2
  51. package/components/data-list/item.d.ts +3 -3
  52. package/components/data-list/title.d.ts +1 -1
  53. package/components/date-picker/consts.d.ts +5 -5
  54. package/components/date-picker/date-input.d.ts +3 -12
  55. package/components/date-picker/date-input.js +9 -15
  56. package/components/date-picker/date-picker.css +1 -1
  57. package/components/date-picker/date-picker.d.ts +8 -6
  58. package/components/date-picker/date-picker.js +9 -15
  59. package/components/date-picker/date-popup.d.ts +1 -1
  60. package/components/date-picker/date-popup.js +2 -1
  61. package/components/date-picker/day.d.ts +2 -2
  62. package/components/date-picker/month-names.d.ts +2 -2
  63. package/components/date-picker/month-names.js +2 -2
  64. package/components/date-picker/month-slider.d.ts +2 -2
  65. package/components/date-picker/month.d.ts +2 -2
  66. package/components/date-picker/months.d.ts +2 -2
  67. package/components/date-picker/months.js +46 -29
  68. package/components/date-picker/weekdays.d.ts +2 -2
  69. package/components/date-picker/years.d.ts +6 -2
  70. package/components/date-picker/years.js +26 -14
  71. package/components/dialog/dialog.css +1 -1
  72. package/components/dialog/dialog.d.ts +4 -16
  73. package/components/dialog/dialog.js +4 -2
  74. package/components/dialog-ng/dialog-ng.js +4 -5
  75. package/components/dialog-ng/{dialog-ng.examples.js → dialog-ng.stories.js} +1 -1
  76. package/components/dropdown/anchor.d.ts +1 -1
  77. package/components/dropdown/dropdown.d.ts +8 -1
  78. package/components/editable-heading/editable-heading.css +20 -7
  79. package/components/editable-heading/editable-heading.d.ts +2 -2
  80. package/components/editable-heading/editable-heading.js +39 -12
  81. package/components/error-bubble/error-bubble.d.ts +2 -2
  82. package/components/error-message/error-message.d.ts +2 -2
  83. package/components/footer/footer.js +1 -0
  84. package/components/form/{form.examples.js → form.stories.js} +1 -0
  85. package/components/global/angular-component-factory.js +13 -7
  86. package/components/global/angular-component-factory.test.js +30 -10
  87. package/components/global/controls-height.d.ts +2 -0
  88. package/components/global/controls-height.js +8 -0
  89. package/components/global/create-stateful-context.d.ts +1 -1
  90. package/components/global/focus-sensor-hoc.d.ts +1 -0
  91. package/components/global/focus-sensor-hoc.js +5 -4
  92. package/components/global/react-dom-renderer.d.ts +4 -4
  93. package/components/global/react-dom-renderer.js +5 -5
  94. package/components/global/react-render-adapter.js +19 -31
  95. package/components/global/ring-angular-component.js +1 -3
  96. package/components/global/ring-angular-component.test.js +2 -1
  97. package/components/global/use-event-callback.d.ts +1 -0
  98. package/components/global/use-event-callback.js +14 -0
  99. package/components/global/variables_dark.css +2 -2
  100. package/components/grid/col.d.ts +2 -2
  101. package/components/grid/grid.d.ts +2 -2
  102. package/components/grid/row.d.ts +2 -2
  103. package/components/group/group.d.ts +2 -2
  104. package/components/header/header.d.ts +2 -2
  105. package/components/header/logo.d.ts +2 -2
  106. package/components/header/profile.d.ts +4 -2
  107. package/components/header/profile.js +15 -11
  108. package/components/header/services-link.d.ts +2 -2
  109. package/components/header/services.d.ts +2 -2
  110. package/components/header/smart-profile.d.ts +2 -2
  111. package/components/header/smart-services.d.ts +2 -2
  112. package/components/header/tray-icon.d.ts +2 -2
  113. package/components/header/tray.d.ts +2 -2
  114. package/components/heading/heading.css +8 -8
  115. package/components/http/http.d.ts +16 -6
  116. package/components/http/http.js +26 -0
  117. package/components/hub-source/hub-source__users-groups.d.ts +1 -1
  118. package/components/i18n/README.md +46 -0
  119. package/components/i18n/i18n-context.d.ts +13 -0
  120. package/components/i18n/i18n-context.js +14 -0
  121. package/components/i18n/i18n.d.ts +59 -0
  122. package/components/i18n/i18n.js +26 -0
  123. package/components/i18n/messages.json +53 -0
  124. package/components/icon/icon.d.ts +3 -3
  125. package/components/icon/icon__svg.d.ts +1 -1
  126. package/components/input/input-legacy.css +3 -3
  127. package/components/input/input.css +8 -21
  128. package/components/input/input.d.ts +7 -1
  129. package/components/input/input.js +18 -14
  130. package/components/input-ng/input-ng.js +3 -2
  131. package/components/input-ng/{input-ng.examples.js → input-ng.stories.js} +3 -1
  132. package/components/input-size/{input-size.examples.js → input-size.stories.js} +1 -0
  133. package/components/island/adaptive-island-hoc.d.ts +2 -2
  134. package/components/island/content.d.ts +1 -1
  135. package/components/island/header.d.ts +2 -2
  136. package/components/island/island.css +1 -1
  137. package/components/island/island.d.ts +3 -3
  138. package/components/island-legacy/content-legacy.d.ts +2 -2
  139. package/components/island-legacy/header-legacy.d.ts +2 -2
  140. package/components/island-legacy/island-legacy.d.ts +2 -2
  141. package/components/island-ng/island-ng.js +3 -3
  142. package/components/link/clickableLink.d.ts +1 -1
  143. package/components/link/link.css +1 -1
  144. package/components/link/link.d.ts +8 -9
  145. package/components/link/link.js +0 -1
  146. package/components/list/consts.js +3 -0
  147. package/components/list/list.css +2 -2
  148. package/components/list/list.d.ts +7 -7
  149. package/components/list/list.js +4 -1
  150. package/components/list/list__custom.d.ts +1 -1
  151. package/components/list/list__hint.d.ts +2 -2
  152. package/components/list/list__item.d.ts +2 -2
  153. package/components/list/list__link.d.ts +2 -2
  154. package/components/list/list__separator.d.ts +2 -2
  155. package/components/list/list__title.d.ts +2 -2
  156. package/components/loader/loader.d.ts +2 -2
  157. package/components/loader-inline/loader-inline.d.ts +2 -2
  158. package/components/loader-ng/loader-ng.js +1 -1
  159. package/components/loader-screen/loader-screen.d.ts +2 -2
  160. package/components/login-dialog/login-dialog.d.ts +2 -2
  161. package/components/login-dialog/service.js +4 -1
  162. package/components/markdown/code.d.ts +2 -2
  163. package/components/markdown/heading.d.ts +2 -2
  164. package/components/markdown/link.d.ts +2 -2
  165. package/components/markdown/markdown.d.ts +2 -2
  166. package/components/message/message.d.ts +3 -7
  167. package/components/message/message.js +17 -16
  168. package/components/pager/pager.d.ts +8 -13
  169. package/components/pager/pager.js +12 -14
  170. package/components/panel/panel.css +1 -1
  171. package/components/panel/panel.d.ts +2 -2
  172. package/components/popup/popup.d.ts +2 -2
  173. package/components/popup/popup.js +1 -1
  174. package/components/popup/position.d.ts +1 -1
  175. package/components/popup/position.js +43 -33
  176. package/components/popup-menu/popup-menu.d.ts +2 -2
  177. package/components/progress-bar/progress-bar.d.ts +2 -2
  178. package/components/promised-click-ng/promised-click-ng.js +1 -1
  179. package/components/query-assist/query-assist.css +16 -11
  180. package/components/query-assist/query-assist.d.ts +3 -7
  181. package/components/query-assist/query-assist.js +50 -31
  182. package/components/query-assist/query-assist__suggestions.d.ts +2 -2
  183. package/components/radio/radio.css +1 -1
  184. package/components/radio/radio.d.ts +1 -1
  185. package/components/radio/radio__item.d.ts +1 -1
  186. package/components/select/select-popup.css +2 -2
  187. package/components/select/select.css +9 -5
  188. package/components/select/select.d.ts +21 -9
  189. package/components/select/select.js +53 -29
  190. package/components/select/select__filter.d.ts +2 -3
  191. package/components/select/select__filter.js +4 -2
  192. package/components/select/select__popup.d.ts +48 -8
  193. package/components/select/select__popup.js +29 -8
  194. package/components/shortcuts/shortcuts-hoc.d.ts +2 -2
  195. package/components/shortcuts/shortcuts.d.ts +1 -1
  196. package/components/shortcuts-hint-ng/shortcuts-hint-ng.js +1 -2
  197. package/components/sidebar-ng/sidebar-ng.js +1 -2
  198. package/components/tab-trap/tab-trap.d.ts +1 -1
  199. package/components/table/cell.d.ts +2 -2
  200. package/components/table/disable-hover-hoc.d.ts +2 -2
  201. package/components/table/header-cell.d.ts +2 -2
  202. package/components/table/header.d.ts +3 -14
  203. package/components/table/header.js +5 -49
  204. package/components/table/multitable.d.ts +2 -2
  205. package/components/table/row-with-focus-sensor.d.ts +1 -1
  206. package/components/table/row.d.ts +2 -1
  207. package/components/table/row.js +4 -3
  208. package/components/table/smart-table.d.ts +3 -1
  209. package/components/table/table.css +9 -26
  210. package/components/table/table.d.ts +6 -4
  211. package/components/table/table.js +5 -3
  212. package/components/table-ng/{table-ng.examples.js → table-ng.stories.js} +1 -1
  213. package/components/tabs/collapsible-more.d.ts +3 -3
  214. package/components/tabs/collapsible-tab.d.ts +1 -1
  215. package/components/tabs/collapsible-tabs.d.ts +2 -2
  216. package/components/tabs/dumb-tabs.d.ts +5 -3
  217. package/components/tabs/dumb-tabs.js +3 -2
  218. package/components/tabs/smart-tabs.d.ts +2 -2
  219. package/components/tabs/tab-link.d.ts +1 -1
  220. package/components/tabs/tab.d.ts +2 -2
  221. package/components/tabs/tab.js +3 -3
  222. package/components/tabs/tabs.css +4 -1
  223. package/components/tag/tag.css +3 -3
  224. package/components/tag/tag.d.ts +5 -5
  225. package/components/tags-input/tags-input.css +1 -1
  226. package/components/tags-input/tags-input.d.ts +11 -4
  227. package/components/tags-input/tags-input.js +11 -8
  228. package/components/tags-list/tags-list.d.ts +2 -2
  229. package/components/template-ng/template-ng.js +1 -2
  230. package/components/text/text.css +12 -0
  231. package/components/text/text.d.ts +8 -2
  232. package/components/text/text.js +12 -2
  233. package/components/toggle/toggle.css +1 -1
  234. package/components/toggle/toggle.d.ts +2 -2
  235. package/components/tooltip/tooltip.d.ts +1 -1
  236. package/components/user-agreement/service.js +4 -1
  237. package/components/user-agreement/user-agreement.d.ts +3 -11
  238. package/components/user-agreement/user-agreement.js +31 -30
  239. package/components/user-card/card.d.ts +22 -21
  240. package/components/user-card/card.js +29 -29
  241. package/components/user-card/smart-user-card-tooltip.d.ts +3 -3
  242. package/components/user-card/tooltip.d.ts +11 -6
  243. package/components/user-card/tooltip.js +1 -1
  244. package/components/user-card/user-card.css +10 -1
  245. package/dist/_helpers/_rollupPluginBabelHelpers.js +614 -1
  246. package/dist/_helpers/anchor.js +7 -8
  247. package/dist/_helpers/badge.js +1 -1
  248. package/dist/_helpers/button-group.js +1 -1
  249. package/dist/_helpers/button-set.js +1 -1
  250. package/dist/_helpers/button-toolbar.js +1 -1
  251. package/dist/_helpers/button__classes.js +17 -29
  252. package/dist/_helpers/card.js +100 -91
  253. package/dist/_helpers/checkbox.js +1 -1
  254. package/dist/_helpers/control-label.js +3 -0
  255. package/dist/_helpers/date-picker.js +1 -1
  256. package/dist/_helpers/dialog__body-scroll-preventer.js +21 -12
  257. package/dist/_helpers/error-message.js +1 -1
  258. package/dist/_helpers/footer.js +31 -35
  259. package/dist/_helpers/grid.js +1 -1
  260. package/dist/_helpers/group.js +1 -1
  261. package/dist/_helpers/header.js +1 -1
  262. package/dist/_helpers/icon.js +1 -1
  263. package/dist/_helpers/input.js +1 -1
  264. package/dist/_helpers/island.js +1 -1
  265. package/dist/_helpers/link.js +1 -1
  266. package/dist/_helpers/list.js +1 -1
  267. package/dist/_helpers/loader-inline.js +1 -1
  268. package/dist/_helpers/loader-screen.js +1 -1
  269. package/dist/_helpers/panel.js +1 -1
  270. package/dist/_helpers/query-assist__suggestions.js +92 -75
  271. package/dist/_helpers/radio.js +1 -1
  272. package/dist/_helpers/select__filter.js +69 -42
  273. package/dist/_helpers/services-link.js +33 -21
  274. package/dist/_helpers/sidebar.js +87 -86
  275. package/dist/_helpers/table.js +1 -1
  276. package/dist/_helpers/tabs.js +1 -1
  277. package/dist/_helpers/theme.js +43 -36
  278. package/dist/_helpers/title.js +66 -56
  279. package/dist/alert/alert.d.ts +1 -1
  280. package/dist/alert/alert.js +164 -127
  281. package/dist/alert/container.js +40 -29
  282. package/dist/alert-service/alert-service.d.ts +2 -2
  283. package/dist/alert-service/alert-service.js +169 -103
  284. package/dist/analytics/analytics.d.ts +21 -7
  285. package/dist/analytics/analytics.js +90 -71
  286. package/dist/analytics/analytics__custom-plugin.d.ts +6 -16
  287. package/dist/analytics/analytics__custom-plugin.js +74 -87
  288. package/dist/analytics/analytics__fus-plugin.d.ts +15 -25
  289. package/dist/analytics/analytics__fus-plugin.js +31 -89
  290. package/dist/analytics/analytics__ga-plugin.d.ts +13 -3
  291. package/dist/analytics/analytics__ga-plugin.js +76 -25
  292. package/dist/analytics/analytics__plugin-utils.d.ts +16 -0
  293. package/dist/analytics/analytics__plugin-utils.js +52 -21
  294. package/dist/auth/auth.js +39 -5
  295. package/dist/auth/auth__core.d.ts +5 -4
  296. package/dist/auth/auth__core.js +1459 -719
  297. package/dist/auth/background-flow.js +125 -84
  298. package/dist/auth/down-notification.js +76 -32
  299. package/dist/auth/iframe-flow.js +129 -69
  300. package/dist/auth/landing.js +93 -31
  301. package/dist/auth/request-builder.js +79 -45
  302. package/dist/auth/response-parser.js +117 -85
  303. package/dist/auth/storage.js +322 -161
  304. package/dist/auth/token-validator.js +239 -128
  305. package/dist/auth/window-flow.js +126 -83
  306. package/dist/auth-dialog/auth-dialog.d.ts +2 -2
  307. package/dist/auth-dialog/auth-dialog.js +152 -94
  308. package/dist/auth-dialog-service/auth-dialog-service.js +36 -10
  309. package/dist/auth-ng/auth-ng.js +73 -35
  310. package/dist/auth-ng/auth-ng.mock.js +6 -6
  311. package/dist/autofocus-ng/autofocus-ng.js +23 -8
  312. package/dist/avatar/avatar-example-datauri.js +1 -23
  313. package/dist/avatar/avatar.d.ts +3 -3
  314. package/dist/avatar/avatar.js +132 -99
  315. package/dist/avatar/fallback-avatar.d.ts +2 -2
  316. package/dist/avatar/fallback-avatar.js +44 -24
  317. package/dist/avatar-editor-ng/avatar-editor-ng.js +57 -25
  318. package/dist/avatar-editor-ng/avatar-editor-ng__template.js +1 -28
  319. package/dist/avatar-ng/avatar-ng.js +22 -0
  320. package/dist/badge/badge.d.ts +2 -2
  321. package/dist/badge/badge.js +34 -26
  322. package/dist/badge-ng/badge-ng.js +12 -0
  323. package/dist/breadcrumb-ng/breadcrumb-ng.js +17 -32
  324. package/dist/button/button.d.ts +3 -4
  325. package/dist/button/button.js +89 -69
  326. package/dist/button/button__classes.js +1 -0
  327. package/dist/button-group/button-group.d.ts +2 -2
  328. package/dist/button-group/button-group.js +31 -15
  329. package/dist/button-group/caption.d.ts +2 -2
  330. package/dist/button-group/caption.js +19 -11
  331. package/dist/button-group-ng/button-group-ng.js +13 -7
  332. package/dist/button-ng/button-ng.js +132 -112
  333. package/dist/button-set/button-set.d.ts +2 -2
  334. package/dist/button-set/button-set.js +29 -15
  335. package/dist/button-set-ng/button-set-ng.js +2 -2
  336. package/dist/button-toolbar/button-toolbar.d.ts +2 -2
  337. package/dist/button-toolbar/button-toolbar.js +28 -14
  338. package/dist/button-toolbar-ng/button-toolbar-ng.js +5 -3
  339. package/dist/caret/caret.js +223 -188
  340. package/dist/checkbox/checkbox.d.ts +2 -2
  341. package/dist/checkbox/checkbox.js +83 -58
  342. package/dist/checkbox-ng/checkbox-ng.js +18 -28
  343. package/dist/clipboard/clipboard-fallback.js +10 -10
  344. package/dist/clipboard/clipboard.js +131 -35
  345. package/dist/code/code.d.ts +1 -1
  346. package/dist/code/code.js +153 -81
  347. package/dist/compiler-ng/compiler-ng.js +18 -15
  348. package/dist/confirm/confirm.d.ts +1 -1
  349. package/dist/confirm/confirm.js +85 -47
  350. package/dist/confirm-ng/confirm-ng.js +34 -6
  351. package/dist/confirm-service/confirm-service.js +67 -44
  352. package/dist/content-layout/content-layout.d.ts +2 -2
  353. package/dist/content-layout/content-layout.js +53 -35
  354. package/dist/content-layout/sidebar.d.ts +2 -2
  355. package/dist/content-layout/sidebar.js +1 -0
  356. package/dist/contenteditable/contenteditable.d.ts +3 -3
  357. package/dist/contenteditable/contenteditable.js +54 -43
  358. package/dist/control-label/control-label.d.ts +11 -0
  359. package/dist/control-label/control-label.js +31 -0
  360. package/dist/data-list/data-list.d.ts +3 -3
  361. package/dist/data-list/data-list.js +164 -114
  362. package/dist/data-list/data-list.mock.d.ts +2 -2
  363. package/dist/data-list/data-list.mock.js +11 -3
  364. package/dist/data-list/item.d.ts +3 -3
  365. package/dist/data-list/item.js +140 -113
  366. package/dist/data-list/selection.js +139 -77
  367. package/dist/data-list/title.d.ts +1 -1
  368. package/dist/data-list/title.js +12 -0
  369. package/dist/data-list-ng/data-list-ng.js +30 -1
  370. package/dist/date-picker/consts.d.ts +5 -5
  371. package/dist/date-picker/consts.js +18 -15
  372. package/dist/date-picker/date-input.d.ts +3 -12
  373. package/dist/date-picker/date-input.js +131 -107
  374. package/dist/date-picker/date-picker.d.ts +8 -6
  375. package/dist/date-picker/date-picker.js +214 -160
  376. package/dist/date-picker/date-popup.d.ts +1 -1
  377. package/dist/date-picker/date-popup.js +340 -297
  378. package/dist/date-picker/day.d.ts +2 -2
  379. package/dist/date-picker/day.js +78 -68
  380. package/dist/date-picker/month-names.d.ts +2 -2
  381. package/dist/date-picker/month-names.js +59 -41
  382. package/dist/date-picker/month-slider.d.ts +2 -2
  383. package/dist/date-picker/month-slider.js +59 -40
  384. package/dist/date-picker/month.d.ts +2 -2
  385. package/dist/date-picker/month.js +21 -15
  386. package/dist/date-picker/months.d.ts +2 -2
  387. package/dist/date-picker/months.js +80 -56
  388. package/dist/date-picker/weekdays.d.ts +2 -2
  389. package/dist/date-picker/weekdays.js +18 -12
  390. package/dist/date-picker/years.d.ts +6 -2
  391. package/dist/date-picker/years.js +102 -66
  392. package/dist/dialog/dialog.d.ts +4 -16
  393. package/dist/dialog/dialog.js +148 -98
  394. package/dist/dialog/dialog__body-scroll-preventer.js +5 -0
  395. package/dist/dialog-ng/dialog-ng.js +404 -291
  396. package/dist/dialog-ng/dialog-ng__template.js +1 -70
  397. package/dist/docked-panel-ng/docked-panel-ng.js +33 -19
  398. package/dist/dropdown/anchor.d.ts +1 -1
  399. package/dist/dropdown/anchor.js +10 -1
  400. package/dist/dropdown/dropdown.d.ts +8 -1
  401. package/dist/dropdown/dropdown.js +158 -130
  402. package/dist/dropdown-menu/dropdown-menu.js +102 -73
  403. package/dist/editable-heading/editable-heading.d.ts +2 -2
  404. package/dist/editable-heading/editable-heading.js +133 -62
  405. package/dist/error-bubble/error-bubble.d.ts +2 -2
  406. package/dist/error-bubble/error-bubble.js +60 -27
  407. package/dist/error-message/error-message.d.ts +2 -2
  408. package/dist/error-message/error-message.js +52 -29
  409. package/dist/error-message-ng/error-message-ng.js +12 -24
  410. package/dist/footer/footer.js +11 -2
  411. package/dist/footer-ng/footer-ng.js +52 -27
  412. package/dist/form-ng/form-ng.js +67 -57
  413. package/dist/global/angular-component-factory.js +78 -50
  414. package/dist/global/compose.js +10 -1
  415. package/dist/global/composeRefs.js +12 -7
  416. package/dist/global/controls-height.d.ts +2 -0
  417. package/dist/global/controls-height.js +10 -2
  418. package/dist/global/create-stateful-context.d.ts +1 -1
  419. package/dist/global/create-stateful-context.js +19 -19
  420. package/dist/global/data-tests.js +15 -7
  421. package/dist/global/dom.js +93 -55
  422. package/dist/global/focus-sensor-hoc.d.ts +1 -0
  423. package/dist/global/focus-sensor-hoc.js +118 -102
  424. package/dist/global/fuzzy-highlight.js +41 -27
  425. package/dist/global/get-event-key.js +8 -8
  426. package/dist/global/get-uid.js +8 -4
  427. package/dist/global/inject-styles.js +15 -10
  428. package/dist/global/linear-function.js +2 -2
  429. package/dist/global/listeners.js +50 -28
  430. package/dist/global/memoize.js +13 -6
  431. package/dist/global/normalize-indent.js +51 -19
  432. package/dist/global/promise-with-timeout.js +8 -6
  433. package/dist/global/prop-types.js +5 -3
  434. package/dist/global/react-dom-renderer.d.ts +4 -4
  435. package/dist/global/react-dom-renderer.js +44 -28
  436. package/dist/global/react-render-adapter.js +21 -15
  437. package/dist/global/rerender-hoc.js +40 -19
  438. package/dist/global/ring-angular-component.js +18 -10
  439. package/dist/global/schedule-raf.js +6 -5
  440. package/dist/global/sniffer.js +1 -1
  441. package/dist/global/theme.js +24 -0
  442. package/dist/global/trivial-template-tag.js +10 -3
  443. package/dist/global/typescript-utils.js +6 -2
  444. package/dist/global/url.js +27 -21
  445. package/dist/global/use-event-callback.d.ts +1 -0
  446. package/dist/global/use-event-callback.js +17 -0
  447. package/dist/grid/col.d.ts +2 -2
  448. package/dist/grid/col.js +42 -23
  449. package/dist/grid/grid.d.ts +2 -2
  450. package/dist/grid/grid.js +32 -13
  451. package/dist/grid/row.d.ts +2 -2
  452. package/dist/grid/row.js +32 -20
  453. package/dist/group/group.d.ts +2 -2
  454. package/dist/group/group.js +23 -13
  455. package/dist/group-ng/group-ng.js +2 -2
  456. package/dist/header/header.d.ts +2 -2
  457. package/dist/header/header.js +75 -25
  458. package/dist/header/logo.d.ts +2 -2
  459. package/dist/header/logo.js +31 -12
  460. package/dist/header/profile.d.ts +4 -2
  461. package/dist/header/profile.js +154 -105
  462. package/dist/header/services-link.d.ts +2 -2
  463. package/dist/header/services-link.js +9 -1
  464. package/dist/header/services.d.ts +2 -2
  465. package/dist/header/services.js +104 -63
  466. package/dist/header/smart-profile.d.ts +2 -2
  467. package/dist/header/smart-profile.js +194 -98
  468. package/dist/header/smart-services.d.ts +2 -2
  469. package/dist/header/smart-services.js +104 -52
  470. package/dist/header/tray-icon.d.ts +2 -2
  471. package/dist/header/tray-icon.js +36 -20
  472. package/dist/header/tray.d.ts +2 -2
  473. package/dist/header/tray.js +30 -17
  474. package/dist/heading/heading.js +26 -27
  475. package/dist/heading-ng/heading-ng.js +10 -0
  476. package/dist/http/http.d.ts +16 -6
  477. package/dist/http/http.js +357 -170
  478. package/dist/http/http.mock.js +105 -50
  479. package/dist/hub-source/hub-source.js +183 -77
  480. package/dist/hub-source/hub-source__user.js +45 -12
  481. package/dist/hub-source/hub-source__users-groups.d.ts +1 -1
  482. package/dist/hub-source/hub-source__users-groups.js +63 -34
  483. package/dist/i18n/i18n-context.d.ts +13 -0
  484. package/dist/i18n/i18n-context.js +28 -0
  485. package/dist/i18n/i18n.d.ts +59 -0
  486. package/dist/i18n/i18n.js +140 -0
  487. package/dist/icon/icon.d.ts +3 -3
  488. package/dist/icon/icon.js +77 -59
  489. package/dist/icon/icon__svg.d.ts +1 -1
  490. package/dist/icon/icon__svg.js +31 -24
  491. package/dist/icon/index.js +9 -0
  492. package/dist/icon-ng/icon-ng.js +27 -16
  493. package/dist/input/input.d.ts +7 -1
  494. package/dist/input/input.js +178 -131
  495. package/dist/input-ng/input-ng.js +77 -99
  496. package/dist/island/adaptive-island-hoc.d.ts +2 -2
  497. package/dist/island/adaptive-island-hoc.js +38 -27
  498. package/dist/island/content.d.ts +1 -1
  499. package/dist/island/content.js +104 -92
  500. package/dist/island/header.d.ts +2 -2
  501. package/dist/island/header.js +60 -47
  502. package/dist/island/island.d.ts +3 -3
  503. package/dist/island/island.js +33 -21
  504. package/dist/island-legacy/content-legacy.d.ts +2 -2
  505. package/dist/island-legacy/content-legacy.js +23 -13
  506. package/dist/island-legacy/header-legacy.d.ts +2 -2
  507. package/dist/island-legacy/header-legacy.js +25 -15
  508. package/dist/island-legacy/island-legacy.d.ts +2 -2
  509. package/dist/island-legacy/island-legacy.js +23 -13
  510. package/dist/island-ng/island-content-ng.js +17 -26
  511. package/dist/island-ng/island-header-ng.js +9 -12
  512. package/dist/island-ng/island-ng-class-fixer.js +3 -0
  513. package/dist/island-ng/island-ng.js +6 -10
  514. package/dist/link/clickableLink.d.ts +1 -1
  515. package/dist/link/clickableLink.js +43 -29
  516. package/dist/link/link.d.ts +8 -9
  517. package/dist/link/link.js +72 -62
  518. package/dist/link-ng/link-ng.js +5 -7
  519. package/dist/list/consts.js +4 -1
  520. package/dist/list/list.d.ts +7 -7
  521. package/dist/list/list.js +499 -402
  522. package/dist/list/list__custom.d.ts +1 -1
  523. package/dist/list/list__custom.js +60 -47
  524. package/dist/list/list__hint.d.ts +2 -2
  525. package/dist/list/list__hint.js +18 -8
  526. package/dist/list/list__item.d.ts +2 -2
  527. package/dist/list/list__item.js +167 -132
  528. package/dist/list/list__link.d.ts +2 -2
  529. package/dist/list/list__link.js +54 -38
  530. package/dist/list/list__separator.d.ts +2 -2
  531. package/dist/list/list__separator.js +24 -14
  532. package/dist/list/list__title.d.ts +2 -2
  533. package/dist/list/list__title.js +32 -22
  534. package/dist/list/list__users-groups-source.js +130 -54
  535. package/dist/loader/loader.d.ts +2 -2
  536. package/dist/loader/loader.js +66 -34
  537. package/dist/loader/loader__core.js +197 -129
  538. package/dist/loader-inline/loader-inline.d.ts +2 -2
  539. package/dist/loader-inline/loader-inline.js +32 -18
  540. package/dist/loader-inline-ng/loader-inline-ng.js +2 -2
  541. package/dist/loader-ng/loader-ng.js +44 -18
  542. package/dist/loader-screen/loader-screen.d.ts +2 -2
  543. package/dist/loader-screen/loader-screen.js +43 -20
  544. package/dist/loader-screen-ng/loader-screen-ng.js +45 -30
  545. package/dist/login-dialog/login-dialog.d.ts +2 -2
  546. package/dist/login-dialog/login-dialog.js +125 -78
  547. package/dist/login-dialog/service.js +39 -10
  548. package/dist/markdown/code.d.ts +2 -2
  549. package/dist/markdown/code.js +30 -9
  550. package/dist/markdown/heading.d.ts +2 -2
  551. package/dist/markdown/heading.js +3 -5
  552. package/dist/markdown/link.d.ts +2 -2
  553. package/dist/markdown/link.js +13 -7
  554. package/dist/markdown/markdown.d.ts +2 -2
  555. package/dist/markdown/markdown.js +67 -35
  556. package/dist/message/message.d.ts +3 -7
  557. package/dist/message/message.js +153 -119
  558. package/dist/message-bundle-ng/message-bundle-ng.js +130 -46
  559. package/dist/old-browsers-message/old-browsers-message.js +19 -11
  560. package/dist/old-browsers-message/old-browsers-message__stop.js +8 -0
  561. package/dist/old-browsers-message/white-list.js +17 -10
  562. package/dist/pager/pager.d.ts +8 -13
  563. package/dist/pager/pager.js +259 -188
  564. package/dist/pager-ng/pager-ng.js +39 -2
  565. package/dist/panel/panel.d.ts +2 -2
  566. package/dist/panel/panel.js +23 -13
  567. package/dist/panel-ng/panel-ng.js +13 -1
  568. package/dist/permissions/permissions.js +166 -122
  569. package/dist/permissions/permissions__cache.js +220 -191
  570. package/dist/permissions-ng/permissions-ng.js +89 -36
  571. package/dist/place-under-ng/place-under-ng.js +67 -45
  572. package/dist/popup/popup.consts.js +1 -1
  573. package/dist/popup/popup.d.ts +2 -2
  574. package/dist/popup/popup.js +299 -236
  575. package/dist/popup/popup.target.js +8 -9
  576. package/dist/popup/position.d.ts +1 -1
  577. package/dist/popup/position.js +175 -154
  578. package/dist/popup-menu/popup-menu.d.ts +2 -2
  579. package/dist/popup-menu/popup-menu.js +80 -42
  580. package/dist/progress-bar/progress-bar.d.ts +2 -2
  581. package/dist/progress-bar/progress-bar.js +66 -52
  582. package/dist/progress-bar-ng/progress-bar-ng.js +10 -0
  583. package/dist/promised-click-ng/promised-click-ng.js +93 -60
  584. package/dist/proxy-attrs/proxy-attrs.js +18 -9
  585. package/dist/query-assist/query-assist.d.ts +3 -7
  586. package/dist/query-assist/query-assist.js +677 -567
  587. package/dist/query-assist/query-assist__suggestions.d.ts +2 -2
  588. package/dist/query-assist/query-assist__suggestions.js +33 -2
  589. package/dist/query-assist-ng/query-assist-ng.js +41 -2
  590. package/dist/radio/radio.d.ts +1 -1
  591. package/dist/radio/radio.js +28 -14
  592. package/dist/radio/radio__item.d.ts +1 -1
  593. package/dist/radio/radio__item.js +60 -44
  594. package/dist/radio-ng/radio-ng.js +14 -25
  595. package/dist/save-field-ng/save-field-ng.js +90 -56
  596. package/dist/save-field-ng/save-field-ng__template.js +1 -32
  597. package/dist/select/select.d.ts +21 -9
  598. package/dist/select/select.js +833 -699
  599. package/dist/select/select__filter.d.ts +2 -3
  600. package/dist/select/select__filter.js +37 -2
  601. package/dist/select/select__popup.d.ts +48 -8
  602. package/dist/select/select__popup.js +430 -293
  603. package/dist/select-ng/select-ng.js +130 -77
  604. package/dist/select-ng/select-ng__lazy.js +104 -51
  605. package/dist/select-ng/select-ng__options.js +93 -68
  606. package/dist/shortcuts/core.js +197 -146
  607. package/dist/shortcuts/shortcut-title.js +11 -6
  608. package/dist/shortcuts/shortcuts-hoc.d.ts +2 -2
  609. package/dist/shortcuts/shortcuts-hoc.js +43 -19
  610. package/dist/shortcuts/shortcuts.d.ts +1 -1
  611. package/dist/shortcuts/shortcuts.js +69 -43
  612. package/dist/shortcuts-hint-ng/shortcuts-hint-ng.js +109 -58
  613. package/dist/shortcuts-hint-ng/shortcuts-hint-ng__template.js +1 -48
  614. package/dist/shortcuts-ng/shortcuts-ng.js +110 -76
  615. package/dist/sidebar-ng/sidebar-ng.js +55 -25
  616. package/dist/sidebar-ng/sidebar-ng__button-template.js +1 -18
  617. package/dist/sidebar-ng/sidebar-ng__template.js +1 -10
  618. package/dist/storage/storage.js +34 -4
  619. package/dist/storage/storage__fallback.js +217 -143
  620. package/dist/storage/storage__local.js +155 -90
  621. package/dist/style.css +1 -1
  622. package/dist/tab-trap/tab-trap.d.ts +1 -1
  623. package/dist/tab-trap/tab-trap.js +117 -84
  624. package/dist/table/cell.d.ts +2 -2
  625. package/dist/table/cell.js +23 -9
  626. package/dist/table/disable-hover-hoc.d.ts +2 -2
  627. package/dist/table/disable-hover-hoc.js +44 -26
  628. package/dist/table/header-cell.d.ts +2 -2
  629. package/dist/table/header-cell.js +74 -54
  630. package/dist/table/header.d.ts +3 -14
  631. package/dist/table/header.js +102 -131
  632. package/dist/table/multitable.d.ts +2 -2
  633. package/dist/table/multitable.js +102 -86
  634. package/dist/table/row-with-focus-sensor.d.ts +1 -1
  635. package/dist/table/row-with-focus-sensor.js +69 -24
  636. package/dist/table/row.d.ts +2 -1
  637. package/dist/table/row.js +191 -155
  638. package/dist/table/selection-adapter.js +3 -1
  639. package/dist/table/selection-shortcuts-hoc.js +132 -131
  640. package/dist/table/selection.js +220 -150
  641. package/dist/table/smart-table.d.ts +3 -1
  642. package/dist/table/smart-table.js +87 -50
  643. package/dist/table/table.d.ts +6 -4
  644. package/dist/table/table.js +311 -247
  645. package/dist/table-legacy-ng/table-legacy-ng.js +120 -103
  646. package/dist/table-legacy-ng/table-legacy-ng__pager.js +46 -12
  647. package/dist/table-legacy-ng/table-legacy-ng__selection-navigate-actions.js +92 -69
  648. package/dist/table-legacy-ng/table-legacy-ng__selection.js +167 -119
  649. package/dist/table-legacy-ng/table-legacy-ng__toolbar.js +35 -21
  650. package/dist/table-ng/smart-table-ng.js +30 -2
  651. package/dist/table-ng/table-ng.js +30 -2
  652. package/dist/tabs/collapsible-more.d.ts +3 -3
  653. package/dist/tabs/collapsible-more.js +92 -56
  654. package/dist/tabs/collapsible-tab.d.ts +1 -1
  655. package/dist/tabs/collapsible-tab.js +45 -39
  656. package/dist/tabs/collapsible-tabs.d.ts +2 -2
  657. package/dist/tabs/collapsible-tabs.js +161 -95
  658. package/dist/tabs/custom-item.js +2 -4
  659. package/dist/tabs/dumb-tabs.d.ts +5 -3
  660. package/dist/tabs/dumb-tabs.js +101 -56
  661. package/dist/tabs/smart-tabs.d.ts +2 -2
  662. package/dist/tabs/smart-tabs.js +70 -25
  663. package/dist/tabs/tab-link.d.ts +1 -1
  664. package/dist/tabs/tab-link.js +29 -20
  665. package/dist/tabs/tab.d.ts +2 -2
  666. package/dist/tabs/tab.js +26 -15
  667. package/dist/tabs/tabs.js +35 -1
  668. package/dist/tabs-ng/tabs-ng.js +38 -24
  669. package/dist/tabs-ng/tabs-ng__template.js +1 -38
  670. package/dist/tag/tag.d.ts +5 -5
  671. package/dist/tag/tag.js +146 -113
  672. package/dist/tags-input/tags-input.d.ts +11 -4
  673. package/dist/tags-input/tags-input.js +330 -220
  674. package/dist/tags-input-ng/tags-input-ng.js +40 -2
  675. package/dist/tags-list/tags-list.d.ts +2 -2
  676. package/dist/tags-list/tags-list.js +61 -38
  677. package/dist/template-ng/template-ng.js +45 -35
  678. package/dist/text/text.d.ts +8 -2
  679. package/dist/text/text.js +38 -17
  680. package/dist/title-ng/title-ng.js +28 -23
  681. package/dist/toggle/toggle.d.ts +2 -2
  682. package/dist/toggle/toggle.js +55 -39
  683. package/dist/toggle-ng/toggle-ng.js +13 -0
  684. package/dist/tooltip/tooltip.d.ts +1 -1
  685. package/dist/tooltip/tooltip.js +145 -102
  686. package/dist/tooltip-ng/tooltip-ng.js +51 -25
  687. package/dist/user-agreement/service.js +411 -259
  688. package/dist/user-agreement/toolbox.eula.js +1 -160
  689. package/dist/user-agreement/user-agreement.d.ts +3 -11
  690. package/dist/user-agreement/user-agreement.js +106 -68
  691. package/dist/user-card/card.d.ts +22 -21
  692. package/dist/user-card/card.js +34 -1
  693. package/dist/user-card/smart-user-card-tooltip.d.ts +3 -3
  694. package/dist/user-card/smart-user-card-tooltip.js +139 -76
  695. package/dist/user-card/tooltip.d.ts +11 -6
  696. package/dist/user-card/tooltip.js +75 -32
  697. package/dist/user-card/user-card.js +34 -1
  698. package/dist/user-card-ng/user-card-ng.js +39 -6
  699. package/package.json +89 -85
  700. package/components/input/input-label.d.ts +0 -10
  701. package/components/input/input-label.js +0 -18
  702. package/components/loader/__mocks__/loader__core.js +0 -5
  703. package/components/old-browsers-message/__mocks__/old-browsers-message.js +0 -1
  704. package/dist/input/input-label.d.ts +0 -10
  705. package/dist/input/input-label.js +0 -27
  706. /package/components/alert-service/{alert-service.examples.css → alert-service.stories.css} +0 -0
  707. /package/components/auth-ng/{auth-ng.examples.js → auth-ng.stories.js} +0 -0
  708. /package/components/autofocus-ng/{autofocus-ng.examples.js → autofocus-ng.stories.js} +0 -0
  709. /package/components/avatar-editor-ng/{avatar-editor-ng.examples.js → avatar-editor-ng.stories.js} +0 -0
  710. /package/components/avatar-ng/{avatar-ng.examples.js → avatar-ng.stories.js} +0 -0
  711. /package/components/badge-ng/{badge-ng.examples.js → badge-ng.stories.js} +0 -0
  712. /package/components/breadcrumb-ng/{breadcrumb-ng.examples.js → breadcrumb-ng.stories.js} +0 -0
  713. /package/components/button-group-ng/{button-group-ng.examples.js → button-group-ng.stories.js} +0 -0
  714. /package/components/button-set-ng/{button-set-ng.examples.js → button-set-ng.stories.js} +0 -0
  715. /package/components/button-toolbar-ng/{button-toolbar-ng.examples.js → button-toolbar-ng.stories.js} +0 -0
  716. /package/components/checkbox-ng/{checkbox-ng.examples.js → checkbox-ng.stories.js} +0 -0
  717. /package/components/compiler-ng/{compiler-ng.examples.js → compiler-ng.stories.js} +0 -0
  718. /package/components/data-list-ng/{data-list-ng.examples.js → data-list-ng.stories.js} +0 -0
  719. /package/components/docked-panel-ng/{docked-panel-ng.examples.js → docked-panel-ng.stories.js} +0 -0
  720. /package/components/error-message-ng/{error-message-ng.examples.js → error-message-ng.stories.js} +0 -0
  721. /package/components/error-page-ng/{error-page-ng.examples.js → error-page-ng.stories.js} +0 -0
  722. /package/components/footer-ng/{footer-ng.examples.js → footer-ng.stories.js} +0 -0
  723. /package/components/form-ng/{form-ng.examples.js → form-ng.stories.js} +0 -0
  724. /package/components/group-ng/{group.examples.js → group.stories.js} +0 -0
  725. /package/components/heading-ng/{heading-ng.examples.js → heading-ng.stories.js} +0 -0
  726. /package/components/icon-ng/{icon-ng.examples.js → icon-ng.stories.js} +0 -0
  727. /package/components/island-ng/{island-ng.examples.js → island-ng.stories.js} +0 -0
  728. /package/components/link-ng/{link-ng.examples.js → link-ng.stories.js} +0 -0
  729. /package/components/list/{list.examples.css → list.stories.css} +0 -0
  730. /package/components/loader-inline-ng/{loader-inline-ng.examples.js → loader-inline-ng.stories.js} +0 -0
  731. /package/components/loader-ng/{loader-ng.examples.js → loader-ng.stories.js} +0 -0
  732. /package/components/loader-screen-ng/{loader-screen-ng.examples.js → loader-screen-ng.stories.js} +0 -0
  733. /package/components/pager-ng/{pager-ng.examples.js → pager-ng.stories.js} +0 -0
  734. /package/components/palette/{palette.examples.js → palette.stories.js} +0 -0
  735. /package/components/permissions-ng/{permissions-ng.examples.js → permissions-ng.stories.js} +0 -0
  736. /package/components/place-under-ng/{place-under-ng.examples.js → place-under-ng.stories.js} +0 -0
  737. /package/components/progress-bar-ng/{progress-bar-ng.examples.js → progress-bar-ng.stories.js} +0 -0
  738. /package/components/promised-click-ng/{promised-click-ng.examples.js → promised-click-ng.stories.js} +0 -0
  739. /package/components/query-assist-ng/{query-assist-ng.examples.js → query-assist-ng.stories.js} +0 -0
  740. /package/components/radio-ng/{radio-ng.examples.js → radio-ng.stories.js} +0 -0
  741. /package/components/save-field-ng/{save-field-ng.examples.js → save-field-ng.stories.js} +0 -0
  742. /package/components/select-ng/{select-ng.examples.js → select-ng.stories.js} +0 -0
  743. /package/components/shortcuts-hint-ng/{shortcuts-hint-ng.examples.js → shortcuts-hint-ng.stories.js} +0 -0
  744. /package/components/sidebar-ng/{sidebar-ng.examples.js → sidebar-ng.stories.js} +0 -0
  745. /package/components/table/{table.examples.json → table.stories.json} +0 -0
  746. /package/components/table-legacy-ng/{table-legacy-ng.examples.js → table-legacy-ng.stories.js} +0 -0
  747. /package/components/tabs-ng/{tabs-ng.examples.js → tabs-ng.stories.js} +0 -0
  748. /package/components/tags-input-ng/{tags-input-ng.examples.js → tags-input-ng.stories.js} +0 -0
  749. /package/components/template-ng/{template-ng.examples.js → template-ng.stories.js} +0 -0
  750. /package/components/title-ng/{title-ng.examples.js → title-ng.stories.js} +0 -0
  751. /package/components/toggle-ng/{toggle-ng.examples.js → toggle-ng.stories.js} +0 -0
  752. /package/components/tooltip-ng/{tooltip-ng.examples.js → tooltip-ng.stories.js} +0 -0
  753. /package/components/user-card-ng/{user-card-ng.examples.js → user-card-ng.stories.js} +0 -0
@@ -1,4 +1,12 @@
1
- import { _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
1
+ import { _ as _defineProperty, a as _inherits, b as _createSuper, c as _classCallCheck, k as _assertThisInitialized, d as _createClass, l as _typeof } from '../_helpers/_rollupPluginBabelHelpers.js';
2
+ import 'core-js/modules/es.array.concat.js';
3
+ import 'core-js/modules/es.array.filter.js';
4
+ import 'core-js/modules/es.object.to-string.js';
5
+ import 'core-js/modules/es.array.index-of.js';
6
+ import 'core-js/modules/es.array.reduce.js';
7
+ import 'core-js/modules/es.number.constructor.js';
8
+ import 'core-js/modules/es.array.slice.js';
9
+ import 'core-js/modules/es.object.keys.js';
2
10
  import React, { PureComponent } from 'react';
3
11
  import classNames from 'classnames';
4
12
  import searchIcon from '@jetbrains/icons/search';
@@ -20,20 +28,40 @@ import Shortcuts from '../shortcuts/shortcuts.js';
20
28
  import { Button } from '../button/button.js';
21
29
  import Text from '../text/text.js';
22
30
  import { ControlsHeight } from '../global/controls-height.js';
31
+ import { refObject } from '../global/prop-types.js';
32
+ import composeRefs from '../global/composeRefs.js';
23
33
  import { DEFAULT_DIRECTIONS } from '../popup/popup.consts.js';
24
34
  import { S as SelectFilter, m as modules_b607bec2 } from '../_helpers/select__filter.js';
25
35
  import 'util-deprecate';
26
36
  import '../icon/icon__constants.js';
27
37
  import '../_helpers/icon.js';
28
38
  import '../icon/icon__svg.js';
39
+ import 'core-js/modules/es.regexp.exec.js';
40
+ import 'core-js/modules/es.string.replace.js';
41
+ import 'core-js/modules/es.string.starts-with.js';
42
+ import 'core-js/modules/es.array.iterator.js';
43
+ import 'core-js/modules/es.map.js';
44
+ import 'core-js/modules/es.string.iterator.js';
45
+ import 'core-js/modules/web.dom-collections.iterator.js';
46
+ import 'core-js/modules/es.weak-map.js';
47
+ import 'core-js/modules/web.dom-collections.for-each.js';
48
+ import 'core-js/modules/es.object.entries.js';
49
+ import 'core-js/modules/es.regexp.to-string.js';
29
50
  import 'react-dom';
30
51
  import '../global/schedule-raf.js';
31
52
  import '../global/data-tests.js';
32
53
  import '../tab-trap/tab-trap.js';
33
- import '../shortcuts/core.js';
34
- import 'combokeys';
35
- import '../global/sniffer.js';
36
- import 'sniffr';
54
+ import 'core-js/modules/es.array.includes.js';
55
+ import 'core-js/modules/es.string.includes.js';
56
+ import 'core-js/modules/es.array.sort.js';
57
+ import 'core-js/modules/es.array.map.js';
58
+ import 'core-js/modules/es.object.assign.js';
59
+ import 'core-js/modules/es.string.split.js';
60
+ import 'core-js/modules/es.set.js';
61
+ import 'core-js/modules/es.symbol.js';
62
+ import 'core-js/modules/es.symbol.description.js';
63
+ import 'core-js/modules/es.array.find-index.js';
64
+ import 'core-js/modules/es.array.find.js';
37
65
  import 'react-virtualized/dist/es/List';
38
66
  import 'react-virtualized/dist/es/AutoSizer';
39
67
  import 'react-virtualized/dist/es/WindowScroller';
@@ -41,19 +69,18 @@ import 'react-virtualized/dist/es/CellMeasurer';
41
69
  import '../global/create-stateful-context.js';
42
70
  import '../list/list__link.js';
43
71
  import '../link/link.js';
44
- import 'focus-visible';
45
72
  import '../link/clickableLink.js';
46
73
  import '../_helpers/link.js';
47
74
  import '../_helpers/list.js';
48
75
  import '../list/list__item.js';
49
76
  import '../avatar/avatar.js';
50
77
  import '../global/url.js';
78
+ import 'core-js/modules/es.string.match.js';
51
79
  import '../avatar/fallback-avatar.js';
80
+ import 'core-js/modules/es.array.from.js';
52
81
  import '../checkbox/checkbox.js';
53
82
  import '@jetbrains/icons/checkmark-14px';
54
83
  import '@jetbrains/icons/remove-14px';
55
- import '../global/prop-types.js';
56
- import '../global/composeRefs.js';
57
84
  import '../_helpers/checkbox.js';
58
85
  import '../list/list__custom.js';
59
86
  import '../global/get-event-key.js';
@@ -61,53 +88,70 @@ import '../list/list__title.js';
61
88
  import '../list/list__separator.js';
62
89
  import '../list/list__hint.js';
63
90
  import '../list/consts.js';
91
+ import '../shortcuts/core.js';
92
+ import 'core-js/modules/es.array.splice.js';
93
+ import 'combokeys';
94
+ import '../global/sniffer.js';
95
+ import 'sniffr';
64
96
  import '../_helpers/loader-inline.js';
65
97
  import '../tag/tag.js';
66
98
  import '@jetbrains/icons/close-12px';
67
99
  import '@jetbrains/icons/chevron-10px';
68
100
  import '../_helpers/button__classes.js';
69
101
  import '../input/input.js';
102
+ import 'core-js/modules/es.object.values.js';
103
+ import '../i18n/i18n-context.js';
104
+ import '../i18n/i18n.js';
105
+ import '../control-label/control-label.js';
106
+ import '../_helpers/control-label.js';
70
107
  import '../_helpers/input.js';
71
- import '../input/input-label.js';
72
108
 
73
- const FILTER_HEIGHT = 35;
74
- const TOOLBAR_HEIGHT = 49;
109
+ var FILTER_HEIGHT = 35;
110
+ var TOOLBAR_HEIGHT = 49;
75
111
  function noop() {}
76
- const FilterWithShortcuts = shortcutsHOC(SelectFilter);
77
- class SelectPopup extends PureComponent {
78
- constructor() {
79
- super(...arguments);
80
- _defineProperty(this, "state", {
112
+ var FilterWithShortcuts = shortcutsHOC(SelectFilter);
113
+ var SelectPopup = /*#__PURE__*/function (_PureComponent) {
114
+ _inherits(SelectPopup, _PureComponent);
115
+ var _super = _createSuper(SelectPopup);
116
+ function SelectPopup() {
117
+ var _this;
118
+ _classCallCheck(this, SelectPopup);
119
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
120
+ args[_key] = arguments[_key];
121
+ }
122
+ _this = _super.call.apply(_super, [this].concat(args));
123
+ _defineProperty(_assertThisInitialized(_this), "state", {
81
124
  popupFilterShortcutsOptions: {
82
125
  modal: true,
83
126
  disabled: true
84
127
  },
85
128
  tagsActiveIndex: null
86
129
  });
87
- _defineProperty(this, "isClickingPopup", false);
88
- _defineProperty(this, "filter", void 0);
89
- _defineProperty(this, "caret", void 0);
90
- _defineProperty(this, "onFilterFocus", () => {
91
- this._togglePopupFilterShortcuts(false);
92
- this.setState({
130
+ _defineProperty(_assertThisInitialized(_this), "isClickingPopup", false);
131
+ // This flag is set to true while an item in the popup is being clicked
132
+ _defineProperty(_assertThisInitialized(_this), "filter", void 0);
133
+ _defineProperty(_assertThisInitialized(_this), "caret", void 0);
134
+ _defineProperty(_assertThisInitialized(_this), "onFilterFocus", function () {
135
+ _this._togglePopupFilterShortcuts(false);
136
+ _this.setState({
93
137
  tagsActiveIndex: null
94
138
  });
95
139
  });
96
- _defineProperty(this, "popupFilterOnBlur", () => {
97
- if (this.state.tagsActiveIndex === null) {
98
- this._togglePopupFilterShortcuts(true);
140
+ _defineProperty(_assertThisInitialized(_this), "popupFilterOnBlur", function () {
141
+ if (_this.state.tagsActiveIndex === null) {
142
+ _this._togglePopupFilterShortcuts(true);
99
143
  }
100
144
  });
101
- _defineProperty(this, "mouseDownHandler", () => {
102
- this.isClickingPopup = true;
145
+ _defineProperty(_assertThisInitialized(_this), "mouseDownHandler", function () {
146
+ _this.isClickingPopup = true;
103
147
  });
104
- _defineProperty(this, "mouseUpHandler", () => {
105
- this.isClickingPopup = false;
148
+ _defineProperty(_assertThisInitialized(_this), "mouseUpHandler", function () {
149
+ _this.isClickingPopup = false;
106
150
  });
107
- _defineProperty(this, "popup", void 0);
108
- _defineProperty(this, "onListSelect", (selected, event, opts) => {
109
- const getSelectItemEvent = () => {
110
- const customEvent = document.createEvent('Event');
151
+ _defineProperty(_assertThisInitialized(_this), "popup", void 0);
152
+ _defineProperty(_assertThisInitialized(_this), "onListSelect", function (selected, event, opts) {
153
+ var getSelectItemEvent = function getSelectItemEvent() {
154
+ var customEvent = document.createEvent('Event');
111
155
  customEvent.initEvent('select', true, false);
112
156
  if (event && 'persist' in event) {
113
157
  event.persist();
@@ -115,320 +159,408 @@ class SelectPopup extends PureComponent {
115
159
  customEvent.originalEvent = event;
116
160
  return customEvent;
117
161
  };
118
- this.props.onSelect(selected, getSelectItemEvent(), opts);
162
+ _this.props.onSelect(selected, getSelectItemEvent(), opts);
119
163
  });
120
- _defineProperty(this, "tabPress", event => {
121
- this.props.onCloseAttempt(event, true);
164
+ _defineProperty(_assertThisInitialized(_this), "tabPress", function (event) {
165
+ _this.props.onCloseAttempt(event, true);
122
166
  });
123
- _defineProperty(this, "onClickHandler", () => this.filter?.focus());
124
- _defineProperty(this, "handleRemoveTag", memoize(tag => event => this.removeTag(tag, event)));
125
- _defineProperty(this, "handleTagClick", memoize(tag => () => {
126
- if (Array.isArray(this.props.selected)) {
127
- this.setState({
128
- tagsActiveIndex: this.props.selected.indexOf(tag)
129
- });
130
- }
167
+ _defineProperty(_assertThisInitialized(_this), "onClickHandler", function () {
168
+ var _this$filter;
169
+ return (_this$filter = _this.filter) === null || _this$filter === void 0 ? void 0 : _this$filter.focus();
170
+ });
171
+ _defineProperty(_assertThisInitialized(_this), "handleRemoveTag", memoize(function (tag) {
172
+ return function (event) {
173
+ return _this.removeTag(tag, event);
174
+ };
175
+ }));
176
+ _defineProperty(_assertThisInitialized(_this), "handleTagClick", memoize(function (tag) {
177
+ return function () {
178
+ if (Array.isArray(_this.props.selected)) {
179
+ _this.setState({
180
+ tagsActiveIndex: _this.props.selected.indexOf(tag)
181
+ });
182
+ }
183
+ };
131
184
  }));
132
- _defineProperty(this, "handleListResize", () => {
133
- this.forceUpdate();
185
+ _defineProperty(_assertThisInitialized(_this), "handleListResize", function () {
186
+ _this.forceUpdate();
134
187
  });
135
- _defineProperty(this, "handleSelectAll", () => {
136
- if (Array.isArray(this.props.selected)) {
137
- this.props.onSelectAll(this.props.data.filter(item => !item.disabled).length !== this.props.selected.length);
188
+ _defineProperty(_assertThisInitialized(_this), "handleSelectAll", function () {
189
+ if (Array.isArray(_this.props.selected)) {
190
+ _this.props.onSelectAll(_this.props.data.filter(function (item) {
191
+ return !item.disabled;
192
+ }).length !== _this.props.selected.length);
138
193
  }
139
194
  });
140
- _defineProperty(this, "getSelectAll", () => {
141
- const multiple = this.props.multiple;
142
- const activeFilters = this.props.data.filter(item => !item.disabled);
143
- return Array.isArray(this.props.selected) && /*#__PURE__*/React.createElement("div", {
195
+ _defineProperty(_assertThisInitialized(_this), "getSelectAll", function () {
196
+ var _multiple$renderSelec;
197
+ var multiple = _this.props.multiple;
198
+ var activeFilters = _this.props.data.filter(function (item) {
199
+ return !item.disabled;
200
+ });
201
+ return Array.isArray(_this.props.selected) && /*#__PURE__*/React.createElement("div", {
144
202
  className: modules_b607bec2.selectAll
145
203
  }, activeFilters.length === 0 ? /*#__PURE__*/React.createElement("span", null) : /*#__PURE__*/React.createElement(Button, {
146
204
  text: true,
147
205
  inline: true,
148
- onClick: this.handleSelectAll
149
- }, activeFilters.length !== this.props.selected.length ? multiple.selectAllLabel || 'Select all' : multiple.deselectAllLabel || 'Deselect all'), multiple.renderSelectedItemsDescription?.(this.props.selected, activeFilters.length) || /*#__PURE__*/React.createElement(Text, {
206
+ onClick: _this.handleSelectAll
207
+ }, activeFilters.length !== _this.props.selected.length ? multiple.selectAllLabel || 'Select all' : multiple.deselectAllLabel || 'Deselect all'), ((_multiple$renderSelec = multiple.renderSelectedItemsDescription) === null || _multiple$renderSelec === void 0 ? void 0 : _multiple$renderSelec.call(multiple, _this.props.selected, activeFilters.length)) || /*#__PURE__*/React.createElement(Text, {
150
208
  info: true
151
- }, `${this.props.selected.length} selected`));
209
+ }, "".concat(_this.props.selected.length, " selected")));
152
210
  });
153
- _defineProperty(this, "_adjustListMaxHeight", memoizeOne((hidden, userDefinedMaxHeight, ringPopupTarget) => {
211
+ // Cache the value because this method is called
212
+ // inside `render` function which can be called N times
213
+ // and should be fast as possible.
214
+ // Cache invalidates each time hidden or userDefinedMaxHeight changes
215
+ _defineProperty(_assertThisInitialized(_this), "_adjustListMaxHeight", memoizeOne(function (hidden, userDefinedMaxHeight, ringPopupTarget) {
154
216
  if (hidden) {
155
217
  return userDefinedMaxHeight;
156
218
  }
157
219
  // Calculate list's maximum height that can't
158
220
  // get beyond the screen
159
221
  // @see RG-1838, JT-48358
160
- const minMaxHeight = 100;
161
- const directions = this.props.directions || DEFAULT_DIRECTIONS;
222
+ var minMaxHeight = 100;
223
+ var directions = _this.props.directions || DEFAULT_DIRECTIONS;
162
224
  // Note:
163
225
  // Create a method which'll be called only when the popup opens and before
164
226
  // render the list would be a better way
165
- const anchorNode = this.props.anchorElement;
166
- const containerNode = getPopupContainer(ringPopupTarget) || document.documentElement;
167
- return anchorNode != null ? Math.min(directions.reduce((maxHeight, direction) => {
227
+ var anchorNode = _this.props.anchorElement;
228
+ var containerNode = getPopupContainer(ringPopupTarget) || document.documentElement;
229
+ return anchorNode != null ? Math.min(directions.reduce(function (maxHeight, direction) {
168
230
  var _maxHeightForDirectio;
169
- return Math.max(maxHeight, (_maxHeightForDirectio = maxHeightForDirection(direction, anchorNode, getStyles(containerNode).position !== 'static' ? containerNode : undefined)) !== null && _maxHeightForDirectio !== void 0 ? _maxHeightForDirectio : 0);
231
+ return Math.max(maxHeight, (_maxHeightForDirectio = maxHeightForDirection(direction, anchorNode, getStyles(containerNode).position !== 'static' ? containerNode : null)) !== null && _maxHeightForDirectio !== void 0 ? _maxHeightForDirectio : 0);
170
232
  }, minMaxHeight), userDefinedMaxHeight) : userDefinedMaxHeight;
171
233
  }));
172
- _defineProperty(this, "popupRef", el => {
173
- this.popup = el;
234
+ _defineProperty(_assertThisInitialized(_this), "popupRef", function (el) {
235
+ _this.popup = el;
174
236
  });
175
- _defineProperty(this, "list", void 0);
176
- _defineProperty(this, "listRef", el => {
177
- this.list = el;
237
+ _defineProperty(_assertThisInitialized(_this), "list", void 0);
238
+ _defineProperty(_assertThisInitialized(_this), "listRef", function (el) {
239
+ _this.list = el;
178
240
  });
179
- _defineProperty(this, "filterRef", el => {
180
- this.filter = el;
181
- this.caret = el && new Caret(el);
241
+ _defineProperty(_assertThisInitialized(_this), "filterRef", function (el) {
242
+ _this.filter = el;
243
+ _this.caret = el && new Caret(el);
182
244
  });
183
- _defineProperty(this, "shortcutsScope", getUID('select-popup-'));
184
- _defineProperty(this, "shortcutsMap", {
185
- tab: this.tabPress
245
+ _defineProperty(_assertThisInitialized(_this), "shortcutsScope", getUID('select-popup-'));
246
+ _defineProperty(_assertThisInitialized(_this), "shortcutsMap", {
247
+ tab: _this.tabPress
186
248
  });
187
- _defineProperty(this, "popupFilterShortcutsMap", {
188
- up: event => this.list && this.list.upHandler(event),
189
- down: event => this.list && this.list.downHandler(event),
190
- home: event => this.list && this.list.homeHandler(event),
191
- end: event => this.list && this.list.endHandler(event),
192
- enter: event => this.list ? this.list.enterHandler(event) : this.props.onEmptyPopupEnter(event),
193
- esc: event => this.props.onCloseAttempt(event, true),
194
- tab: event => this.tabPress(event),
195
- backspace: event => this.handleBackspace(event),
196
- del: () => this.removeSelectedTag(),
197
- left: event => this.handleNavigation(event, true),
198
- right: event => this.handleNavigation(event)
249
+ _defineProperty(_assertThisInitialized(_this), "popupFilterShortcutsMap", {
250
+ up: function up(event) {
251
+ return _this.list && _this.list.upHandler(event);
252
+ },
253
+ down: function down(event) {
254
+ return _this.list && _this.list.downHandler(event);
255
+ },
256
+ home: function home(event) {
257
+ return _this.list && _this.list.homeHandler(event);
258
+ },
259
+ end: function end(event) {
260
+ return _this.list && _this.list.endHandler(event);
261
+ },
262
+ enter: function enter(event) {
263
+ return _this.list ? _this.list.enterHandler(event) : _this.props.onEmptyPopupEnter(event);
264
+ },
265
+ esc: function esc(event) {
266
+ return _this.props.onCloseAttempt(event, true);
267
+ },
268
+ tab: function tab(event) {
269
+ return _this.tabPress(event);
270
+ },
271
+ backspace: function backspace(event) {
272
+ return _this.handleBackspace(event);
273
+ },
274
+ del: function del() {
275
+ return _this.removeSelectedTag();
276
+ },
277
+ left: function left(event) {
278
+ return _this.handleNavigation(event, true);
279
+ },
280
+ right: function right(event) {
281
+ return _this.handleNavigation(event);
282
+ }
199
283
  });
284
+ return _this;
200
285
  }
201
- componentDidMount() {
202
- window.document.addEventListener('mouseup', this.mouseUpHandler);
203
- }
204
- componentWillUnmount() {
205
- window.document.removeEventListener('mouseup', this.mouseUpHandler);
206
- }
207
- focusFilter() {
208
- setTimeout(() => this.filter?.focus());
209
- }
210
- isEventTargetFilter(event) {
211
- return event.target instanceof Element && event.target.matches('input,textarea');
212
- }
213
- handleNavigation(event, navigateLeft) {
214
- if (this.isEventTargetFilter(event) && this.caret != null && this.caret.getPosition() > 0 || !Array.isArray(this.props.selected)) {
215
- return;
286
+ _createClass(SelectPopup, [{
287
+ key: "componentDidMount",
288
+ value: function componentDidMount() {
289
+ window.document.addEventListener('mouseup', this.mouseUpHandler);
216
290
  }
217
- let newIndex = null;
218
- if (navigateLeft) {
219
- newIndex = this.state.tagsActiveIndex === null ? this.props.selected.length - 1 : this.state.tagsActiveIndex - 1;
220
- } else if (this.state.tagsActiveIndex !== null) {
221
- newIndex = this.state.tagsActiveIndex + 1;
291
+ }, {
292
+ key: "componentWillUnmount",
293
+ value: function componentWillUnmount() {
294
+ window.document.removeEventListener('mouseup', this.mouseUpHandler);
222
295
  }
223
- if (newIndex !== null && (newIndex >= this.props.selected.length || newIndex < 0)) {
224
- newIndex = null;
225
- this.focusFilter();
296
+ }, {
297
+ key: "focusFilter",
298
+ value: function focusFilter() {
299
+ var _this2 = this;
300
+ setTimeout(function () {
301
+ var _this2$filter;
302
+ return (_this2$filter = _this2.filter) === null || _this2$filter === void 0 ? void 0 : _this2$filter.focus();
303
+ });
226
304
  }
227
- this.setState({
228
- tagsActiveIndex: newIndex
229
- });
230
- }
231
- removeTag(tag, event) {
232
- if (!Array.isArray(this.props.selected)) {
233
- return;
305
+ }, {
306
+ key: "isEventTargetFilter",
307
+ value: function isEventTargetFilter(event) {
308
+ return event.target instanceof Element && event.target.matches('input,textarea');
234
309
  }
235
- const _tag = tag || this.props.selected.slice(0)[this.props.selected.length - 1];
236
- if (_tag) {
237
- this.onListSelect(_tag, event, {
238
- tryKeepOpen: true
239
- });
310
+ }, {
311
+ key: "handleNavigation",
312
+ value: function handleNavigation(event, navigateLeft) {
313
+ if (this.isEventTargetFilter(event) && this.caret != null && Number(this.caret.getPosition()) > 0 || !Array.isArray(this.props.selected)) {
314
+ return;
315
+ }
316
+ var newIndex = null;
317
+ if (navigateLeft) {
318
+ newIndex = this.state.tagsActiveIndex === null ? this.props.selected.length - 1 : this.state.tagsActiveIndex - 1;
319
+ } else if (this.state.tagsActiveIndex !== null) {
320
+ newIndex = this.state.tagsActiveIndex + 1;
321
+ }
322
+ if (newIndex !== null && (newIndex >= this.props.selected.length || newIndex < 0)) {
323
+ newIndex = null;
324
+ this.focusFilter();
325
+ }
240
326
  this.setState({
241
- tagsActiveIndex: null
327
+ tagsActiveIndex: newIndex
242
328
  });
243
- this.focusFilter();
244
329
  }
245
- }
246
- removeSelectedTag() {
247
- if (Array.isArray(this.props.selected) && this.state.tagsActiveIndex != null) {
248
- this.removeTag(this.props.selected[this.state.tagsActiveIndex]);
249
- return false;
330
+ }, {
331
+ key: "removeTag",
332
+ value: function removeTag(tag, event) {
333
+ if (!Array.isArray(this.props.selected)) {
334
+ return;
335
+ }
336
+ var _tag = tag || this.props.selected.slice(0)[this.props.selected.length - 1];
337
+ if (_tag) {
338
+ this.onListSelect(_tag, event, {
339
+ tryKeepOpen: true
340
+ });
341
+ this.setState({
342
+ tagsActiveIndex: null
343
+ });
344
+ this.focusFilter();
345
+ }
250
346
  }
251
- return true;
252
- }
253
- handleBackspace(event) {
254
- if (!this.props.tags) {
347
+ }, {
348
+ key: "removeSelectedTag",
349
+ value: function removeSelectedTag() {
350
+ if (Array.isArray(this.props.selected) && this.state.tagsActiveIndex != null) {
351
+ this.removeTag(this.props.selected[this.state.tagsActiveIndex]);
352
+ return false;
353
+ }
255
354
  return true;
256
355
  }
257
- if (!this.isEventTargetFilter(event)) {
258
- this.removeSelectedTag();
259
- return false;
356
+ }, {
357
+ key: "handleBackspace",
358
+ value: function handleBackspace(event) {
359
+ if (!this.props.tags) {
360
+ return true;
361
+ }
362
+ if (!this.isEventTargetFilter(event)) {
363
+ this.removeSelectedTag();
364
+ return false;
365
+ }
366
+ if ((event.target instanceof HTMLInputElement || event.target instanceof HTMLTextAreaElement) && !event.target.value) {
367
+ this.removeTag();
368
+ return false;
369
+ }
370
+ return true;
260
371
  }
261
- if ((event.target instanceof HTMLInputElement || event.target instanceof HTMLTextAreaElement) && !event.target.value) {
262
- this.removeTag();
263
- return false;
372
+ }, {
373
+ key: "_togglePopupFilterShortcuts",
374
+ value: function _togglePopupFilterShortcuts(shortcutsDisabled) {
375
+ this.setState({
376
+ popupFilterShortcutsOptions: {
377
+ modal: true,
378
+ disabled: shortcutsDisabled
379
+ }
380
+ });
264
381
  }
265
- return true;
266
- }
267
- _togglePopupFilterShortcuts(shortcutsDisabled) {
268
- this.setState({
269
- popupFilterShortcutsOptions: {
270
- modal: true,
271
- disabled: shortcutsDisabled
272
- }
273
- });
274
- }
275
- isVisible() {
276
- return this.popup && this.popup.isVisible();
277
- }
278
- getFilter() {
279
- if (this.props.filter || this.props.tags) {
280
- return /*#__PURE__*/React.createElement("div", {
281
- className: modules_b607bec2.filterWrapper,
282
- "data-test": "ring-select-popup-filter"
283
- }, !this.props.tags && /*#__PURE__*/React.createElement(Icon, {
284
- glyph: searchIcon,
285
- className: modules_b607bec2.filterIcon,
286
- "data-test-custom": "ring-select-popup-filter-icon"
287
- }), /*#__PURE__*/React.createElement(FilterWithShortcuts, {
288
- rgShortcutsOptions: this.state.popupFilterShortcutsOptions,
289
- rgShortcutsMap: this.popupFilterShortcutsMap,
290
- value: this.props.filterValue,
291
- inputRef: this.filterRef,
292
- onBlur: this.popupFilterOnBlur,
293
- onFocus: this.onFilterFocus,
294
- className: "ring-js-shortcuts",
295
- inputClassName: classNames({
296
- [modules_b607bec2.filterWithTagsInput]: this.props.tags
297
- }),
298
- placeholder: typeof this.props.filter === 'object' ? this.props.filter.placeholder : undefined,
299
- height: this.props.tags ? ControlsHeight.S : ControlsHeight.L,
300
- onChange: this.props.onFilter,
301
- onClick: this.onClickHandler,
302
- onClear: this.props.tags ? undefined : this.props.onClear,
303
- "data-test-custom": "ring-select-popup-filter-input",
304
- listId: this.props.listId,
305
- enableShortcuts: Object.keys(this.popupFilterShortcutsMap)
306
- }));
382
+ }, {
383
+ key: "isVisible",
384
+ value: function isVisible() {
385
+ return this.popup && this.popup.isVisible();
307
386
  }
308
- return null;
309
- }
310
- getTags() {
311
- return Array.isArray(this.props.selected) && /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(TagsList, {
312
- tags: this.props.selected,
313
- activeIndex: this.state.tagsActiveIndex,
314
- handleRemove: this.handleRemoveTag,
315
- handleClick: this.handleTagClick,
316
- disabled: this.props.disabled
317
- }));
318
- }
319
- getFilterWithTags() {
320
- if (this.props.tags) {
321
- const classes = classNames([modules_b607bec2.filterWithTags, {
322
- [modules_b607bec2.filterWithTagsFocused]: !this.state.popupFilterShortcutsOptions.disabled
323
- }]);
324
- return /*#__PURE__*/React.createElement("div", {
325
- className: classes
326
- }, this.getTags(), this.getFilter());
387
+ }, {
388
+ key: "getFilter",
389
+ value: function getFilter() {
390
+ if (this.props.filter || this.props.tags) {
391
+ var _this$props$filterIco;
392
+ return /*#__PURE__*/React.createElement("div", {
393
+ className: modules_b607bec2.filterWrapper,
394
+ "data-test": "ring-select-popup-filter"
395
+ }, !this.props.tags && /*#__PURE__*/React.createElement(Icon, {
396
+ glyph: (_this$props$filterIco = this.props.filterIcon) !== null && _this$props$filterIco !== void 0 ? _this$props$filterIco : searchIcon,
397
+ className: modules_b607bec2.filterIcon,
398
+ "data-test-custom": "ring-select-popup-filter-icon"
399
+ }), /*#__PURE__*/React.createElement(FilterWithShortcuts, {
400
+ rgShortcutsOptions: this.state.popupFilterShortcutsOptions,
401
+ rgShortcutsMap: this.popupFilterShortcutsMap,
402
+ value: this.props.filterValue,
403
+ inputRef: composeRefs(this.filterRef, this.props.filterRef),
404
+ onBlur: this.popupFilterOnBlur,
405
+ onFocus: this.onFilterFocus,
406
+ className: "ring-js-shortcuts",
407
+ inputClassName: classNames(_defineProperty({}, modules_b607bec2.filterWithTagsInput, this.props.tags)),
408
+ placeholder: _typeof(this.props.filter) === 'object' ? this.props.filter.placeholder : undefined,
409
+ height: this.props.tags ? ControlsHeight.S : ControlsHeight.L,
410
+ onChange: this.props.onFilter,
411
+ onClick: this.onClickHandler,
412
+ onClear: this.props.tags ? undefined : this.props.onClear,
413
+ "data-test-custom": "ring-select-popup-filter-input",
414
+ listId: this.props.listId,
415
+ enableShortcuts: Object.keys(this.popupFilterShortcutsMap)
416
+ }));
417
+ }
418
+ return null;
327
419
  }
328
- return this.getFilter();
329
- }
330
- getBottomLine() {
331
- const {
332
- loading,
333
- message
334
- } = this.props;
335
- return (loading || message) && /*#__PURE__*/React.createElement("div", {
336
- className: modules_b607bec2.bottomLine
337
- }, loading && /*#__PURE__*/React.createElement(LoaderInline, null), message && /*#__PURE__*/React.createElement("div", {
338
- className: modules_b607bec2.message
339
- }, message));
340
- }
341
- getList(ringPopupTarget) {
342
- if (this.props.data.length) {
343
- let {
344
- maxHeight
345
- } = this.props;
346
- if (this.props.anchorElement) {
347
- maxHeight = this._adjustListMaxHeight(this.props.hidden, maxHeight, ringPopupTarget);
420
+ }, {
421
+ key: "getCustomTag",
422
+ value: function getCustomTag(tags) {
423
+ if (tags !== null && typeof tags !== 'boolean') {
424
+ return tags.customTagComponent;
348
425
  }
349
- if (this.props.filter) {
350
- maxHeight -= FILTER_HEIGHT;
426
+ return undefined;
427
+ }
428
+ }, {
429
+ key: "getTags",
430
+ value: function getTags() {
431
+ return Array.isArray(this.props.selected) && /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(TagsList, {
432
+ tags: this.props.selected,
433
+ activeIndex: this.state.tagsActiveIndex,
434
+ handleRemove: this.handleRemoveTag,
435
+ handleClick: this.handleTagClick,
436
+ disabled: this.props.disabled,
437
+ customTagComponent: this.getCustomTag(this.props.tags)
438
+ }));
439
+ }
440
+ }, {
441
+ key: "getFilterWithTags",
442
+ value: function getFilterWithTags() {
443
+ if (this.props.tags) {
444
+ var classes = classNames([modules_b607bec2.filterWithTags, _defineProperty({}, modules_b607bec2.filterWithTagsFocused, !this.state.popupFilterShortcutsOptions.disabled)]);
445
+ return /*#__PURE__*/React.createElement("div", {
446
+ className: classes
447
+ }, this.getTags(), this.getFilter());
351
448
  }
352
- if (this.props.toolbar) {
353
- maxHeight -= TOOLBAR_HEIGHT;
449
+ return this.getFilter();
450
+ }
451
+ }, {
452
+ key: "getBottomLine",
453
+ value: function getBottomLine() {
454
+ var _this$props = this.props,
455
+ loading = _this$props.loading,
456
+ message = _this$props.message;
457
+ return (loading || message) && /*#__PURE__*/React.createElement("div", {
458
+ className: modules_b607bec2.bottomLine
459
+ }, loading && /*#__PURE__*/React.createElement(LoaderInline, null), message && /*#__PURE__*/React.createElement("div", {
460
+ className: modules_b607bec2.message
461
+ }, message));
462
+ }
463
+ }, {
464
+ key: "getList",
465
+ value: function getList(ringPopupTarget) {
466
+ if (this.props.data.length) {
467
+ var maxHeight = this.props.maxHeight;
468
+ if (this.props.anchorElement) {
469
+ maxHeight = this._adjustListMaxHeight(this.props.hidden, maxHeight, ringPopupTarget);
470
+ }
471
+ if (this.props.filter) {
472
+ maxHeight -= FILTER_HEIGHT;
473
+ }
474
+ if (this.props.toolbar) {
475
+ maxHeight -= TOOLBAR_HEIGHT;
476
+ }
477
+ return /*#__PURE__*/React.createElement(List, {
478
+ id: this.props.listId,
479
+ maxHeight: maxHeight,
480
+ data: this.props.data,
481
+ activeIndex: this.props.activeIndex,
482
+ ref: this.listRef,
483
+ restoreActiveIndex: true,
484
+ activateFirstItem: true,
485
+ onSelect: this.onListSelect,
486
+ onResize: this.handleListResize,
487
+ onScrollToBottom: this.props.onLoadMore,
488
+ hidden: this.props.hidden,
489
+ shortcuts: !this.props.hidden,
490
+ disableMoveOverflow: this.props.disableMoveOverflow,
491
+ disableMoveDownOverflow: this.props.loading,
492
+ disableScrollToActive: this.props.disableScrollToActive,
493
+ compact: this.props.compact,
494
+ renderOptimization: this.props.renderOptimization
495
+ });
354
496
  }
355
- return /*#__PURE__*/React.createElement(List, {
356
- id: this.props.listId,
357
- maxHeight: maxHeight,
358
- data: this.props.data,
359
- activeIndex: this.props.activeIndex,
360
- ref: this.listRef,
361
- restoreActiveIndex: true,
362
- activateFirstItem: true,
363
- onSelect: this.onListSelect,
364
- onResize: this.handleListResize,
365
- onScrollToBottom: this.props.onLoadMore,
366
- hidden: this.props.hidden,
367
- shortcuts: !this.props.hidden,
368
- disableMoveOverflow: this.props.disableMoveOverflow,
369
- disableMoveDownOverflow: this.props.loading,
370
- disableScrollToActive: this.props.disableScrollToActive,
371
- compact: this.props.compact,
372
- renderOptimization: this.props.renderOptimization
497
+ return null;
498
+ }
499
+ }, {
500
+ key: "render",
501
+ value: function render() {
502
+ var _this3 = this;
503
+ var _this$props2 = this.props,
504
+ toolbar = _this$props2.toolbar,
505
+ topbar = _this$props2.topbar,
506
+ className = _this$props2.className,
507
+ multiple = _this$props2.multiple,
508
+ hidden = _this$props2.hidden,
509
+ isInputMode = _this$props2.isInputMode,
510
+ anchorElement = _this$props2.anchorElement,
511
+ minWidth = _this$props2.minWidth,
512
+ onCloseAttempt = _this$props2.onCloseAttempt,
513
+ onOutsideClick = _this$props2.onOutsideClick,
514
+ directions = _this$props2.directions,
515
+ top = _this$props2.top,
516
+ left = _this$props2.left,
517
+ style = _this$props2.style,
518
+ dir = _this$props2.dir,
519
+ filter = _this$props2.filter;
520
+ var classes = classNames(modules_b607bec2.popup, className);
521
+ return /*#__PURE__*/React.createElement(PopupTargetContext.Consumer, null, function (ringPopupTarget) {
522
+ var filterWithTags = _this3.getFilterWithTags();
523
+ var selectAll = multiple && _typeof(multiple) === 'object' && !multiple.limit && multiple.selectAll && _this3.getSelectAll();
524
+ var list = _this3.getList(_this3.props.ringPopupTarget || ringPopupTarget);
525
+ var bottomLine = _this3.getBottomLine();
526
+ var hasContent = filterWithTags || selectAll || list || bottomLine || toolbar || topbar;
527
+ return /*#__PURE__*/React.createElement(Popup, {
528
+ trapFocus: false,
529
+ ref: _this3.popupRef,
530
+ hidden: hidden || !hasContent,
531
+ attached: isInputMode,
532
+ className: classes,
533
+ dontCloseOnAnchorClick: true,
534
+ anchorElement: anchorElement,
535
+ minWidth: minWidth,
536
+ onCloseAttempt: onCloseAttempt,
537
+ onOutsideClick: onOutsideClick,
538
+ directions: directions,
539
+ top: top,
540
+ left: left,
541
+ onMouseDown: _this3.mouseDownHandler,
542
+ target: _this3.props.ringPopupTarget,
543
+ autoCorrectTopOverflow: false,
544
+ style: style
545
+ }, /*#__PURE__*/React.createElement("div", {
546
+ dir: dir
547
+ }, !hidden && filter && /*#__PURE__*/React.createElement(Shortcuts, {
548
+ map: _this3.shortcutsMap,
549
+ scope: _this3.shortcutsScope
550
+ }), topbar, hidden ? /*#__PURE__*/React.createElement("div", null) : filterWithTags, selectAll, list, bottomLine, toolbar));
373
551
  });
374
552
  }
375
- return null;
376
- }
377
- render() {
378
- const {
379
- toolbar,
380
- className,
381
- multiple,
382
- hidden,
383
- isInputMode,
384
- anchorElement,
385
- minWidth,
386
- onCloseAttempt,
387
- directions,
388
- top,
389
- left,
390
- style,
391
- dir,
392
- filter
393
- } = this.props;
394
- const classes = classNames(modules_b607bec2.popup, className);
395
- return /*#__PURE__*/React.createElement(PopupTargetContext.Consumer, null, ringPopupTarget => {
396
- const filterWithTags = this.getFilterWithTags();
397
- const selectAll = multiple && typeof multiple === 'object' && !multiple.limit && multiple.selectAll && this.getSelectAll();
398
- const list = this.getList(this.props.ringPopupTarget || ringPopupTarget);
399
- const bottomLine = this.getBottomLine();
400
- const hasContent = filterWithTags || selectAll || list || bottomLine || toolbar;
401
- return /*#__PURE__*/React.createElement(Popup, {
402
- trapFocus: false,
403
- ref: this.popupRef,
404
- hidden: hidden || !hasContent,
405
- attached: isInputMode,
406
- className: classes,
407
- dontCloseOnAnchorClick: true,
408
- anchorElement: anchorElement,
409
- minWidth: minWidth,
410
- onCloseAttempt: onCloseAttempt,
411
- directions: directions,
412
- top: top,
413
- left: left,
414
- onMouseDown: this.mouseDownHandler,
415
- target: this.props.ringPopupTarget,
416
- autoCorrectTopOverflow: false,
417
- style: style
418
- }, /*#__PURE__*/React.createElement("div", {
419
- dir: dir
420
- }, !hidden && filter && /*#__PURE__*/React.createElement(Shortcuts, {
421
- map: this.shortcutsMap,
422
- scope: this.shortcutsScope
423
- }), hidden ? /*#__PURE__*/React.createElement("div", null) : filterWithTags, selectAll, list, bottomLine, toolbar));
424
- });
425
- }
426
- }
553
+ }]);
554
+ return SelectPopup;
555
+ }(PureComponent);
427
556
  _defineProperty(SelectPopup, "defaultProps", {
428
557
  data: [],
429
558
  activeIndex: null,
430
559
  toolbar: null,
560
+ topbar: null,
431
561
  filter: false,
562
+ filterIcon: null,
563
+ filterRef: noop,
432
564
  multiple: false,
433
565
  message: null,
434
566
  anchorElement: null,
@@ -437,6 +569,7 @@ _defineProperty(SelectPopup, "defaultProps", {
437
569
  loading: false,
438
570
  onSelect: noop,
439
571
  onCloseAttempt: noop,
572
+ onOutsideClick: noop,
440
573
  onFilter: noop,
441
574
  onClear: noop,
442
575
  onLoadMore: noop,
@@ -462,6 +595,8 @@ SelectPopup.propTypes = {
462
595
  placeholder: PropTypes.string
463
596
  })]),
464
597
  filterValue: PropTypes.string,
598
+ filterIcon: PropTypes.oneOfType([PropTypes.string, PropTypes.elementType]),
599
+ filterRef: PropTypes.oneOfType([PropTypes.func, refObject(PropTypes.instanceOf(HTMLInputElement))]),
465
600
  hidden: PropTypes.bool,
466
601
  isInputMode: PropTypes.bool,
467
602
  listId: PropTypes.string,
@@ -477,6 +612,7 @@ SelectPopup.propTypes = {
477
612
  loading: PropTypes.bool,
478
613
  onClear: PropTypes.func,
479
614
  onCloseAttempt: PropTypes.func,
615
+ onOutsideClick: PropTypes.func,
480
616
  onEmptyPopupEnter: PropTypes.func,
481
617
  onFilter: PropTypes.func,
482
618
  onLoadMore: PropTypes.func,
@@ -488,6 +624,7 @@ SelectPopup.propTypes = {
488
624
  style: PropTypes.object,
489
625
  tags: PropTypes.object,
490
626
  toolbar: PropTypes.node,
627
+ topbar: PropTypes.node,
491
628
  top: PropTypes.number
492
629
  };
493
630