@jetbrains/ring-ui-built 6.0.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 (441) hide show
  1. package/LICENSE.txt +202 -0
  2. package/README.md +103 -0
  3. package/components/_helpers/_rollupPluginBabelHelpers.js +648 -0
  4. package/components/_helpers/anchor.js +31 -0
  5. package/components/_helpers/badge.js +3 -0
  6. package/components/_helpers/button__classes.js +34 -0
  7. package/components/_helpers/caption.js +31 -0
  8. package/components/_helpers/card.js +132 -0
  9. package/components/_helpers/date-picker.js +3 -0
  10. package/components/_helpers/dialog__body-scroll-preventer.js +54 -0
  11. package/components/_helpers/grid.js +3 -0
  12. package/components/_helpers/header.js +3 -0
  13. package/components/_helpers/heading.js +3 -0
  14. package/components/_helpers/icon__svg.js +75 -0
  15. package/components/_helpers/input.js +235 -0
  16. package/components/_helpers/island.js +3 -0
  17. package/components/_helpers/link.js +3 -0
  18. package/components/_helpers/list.js +3 -0
  19. package/components/_helpers/query-assist__suggestions.js +102 -0
  20. package/components/_helpers/select__filter.js +94 -0
  21. package/components/_helpers/services-link.js +48 -0
  22. package/components/_helpers/sidebar.js +123 -0
  23. package/components/_helpers/tab-link.js +34 -0
  24. package/components/_helpers/table.js +3 -0
  25. package/components/_helpers/theme.js +95 -0
  26. package/components/_helpers/title.js +103 -0
  27. package/components/alert/alert.d.ts +113 -0
  28. package/components/alert/alert.js +294 -0
  29. package/components/alert/container.d.ts +15 -0
  30. package/components/alert/container.js +52 -0
  31. package/components/alert-service/alert-service.d.ts +36 -0
  32. package/components/alert-service/alert-service.js +220 -0
  33. package/components/analytics/analytics.d.ts +18 -0
  34. package/components/analytics/analytics.js +31 -0
  35. package/components/analytics/analytics__custom-plugin.d.ts +28 -0
  36. package/components/analytics/analytics__custom-plugin.js +89 -0
  37. package/components/auth/auth.d.ts +3 -0
  38. package/components/auth/auth.js +133 -0
  39. package/components/auth/auth__core.d.ts +236 -0
  40. package/components/auth/auth__core.js +1653 -0
  41. package/components/auth/background-flow.d.ts +31 -0
  42. package/components/auth/background-flow.js +147 -0
  43. package/components/auth/down-notification.d.ts +15 -0
  44. package/components/auth/down-notification.js +157 -0
  45. package/components/auth/iframe-flow.d.ts +20 -0
  46. package/components/auth/iframe-flow.js +196 -0
  47. package/components/auth/request-builder.d.ts +48 -0
  48. package/components/auth/request-builder.js +104 -0
  49. package/components/auth/response-parser.d.ts +70 -0
  50. package/components/auth/response-parser.js +138 -0
  51. package/components/auth/storage.d.ts +112 -0
  52. package/components/auth/storage.js +429 -0
  53. package/components/auth/token-validator.d.ts +93 -0
  54. package/components/auth/token-validator.js +269 -0
  55. package/components/auth/window-flow.d.ts +26 -0
  56. package/components/auth/window-flow.js +154 -0
  57. package/components/auth-dialog/auth-dialog.d.ts +60 -0
  58. package/components/auth-dialog/auth-dialog.js +221 -0
  59. package/components/auth-dialog-service/auth-dialog-service.d.ts +6 -0
  60. package/components/auth-dialog-service/auth-dialog-service.js +92 -0
  61. package/components/avatar/avatar-example-datauri.d.ts +1 -0
  62. package/components/avatar/avatar-example-datauri.js +4 -0
  63. package/components/avatar/avatar.d.ts +52 -0
  64. package/components/avatar/avatar.js +183 -0
  65. package/components/avatar/fallback-avatar.d.ts +17 -0
  66. package/components/avatar/fallback-avatar.js +151 -0
  67. package/components/badge/badge.d.ts +24 -0
  68. package/components/badge/badge.js +59 -0
  69. package/components/button/button.d.ts +67 -0
  70. package/components/button/button.js +131 -0
  71. package/components/button/button__classes.d.ts +2 -0
  72. package/components/button/button__classes.js +2 -0
  73. package/components/button-group/button-group.d.ts +18 -0
  74. package/components/button-group/button-group.js +48 -0
  75. package/components/button-group/caption.d.ts +8 -0
  76. package/components/button-group/caption.js +5 -0
  77. package/components/button-set/button-set.d.ts +16 -0
  78. package/components/button-set/button-set.js +47 -0
  79. package/components/button-toolbar/button-toolbar.d.ts +16 -0
  80. package/components/button-toolbar/button-toolbar.js +46 -0
  81. package/components/caret/caret.d.ts +66 -0
  82. package/components/caret/caret.js +259 -0
  83. package/components/checkbox/checkbox.d.ts +45 -0
  84. package/components/checkbox/checkbox.js +130 -0
  85. package/components/clipboard/clipboard-fallback.d.ts +2 -0
  86. package/components/clipboard/clipboard-fallback.js +42 -0
  87. package/components/clipboard/clipboard.d.ts +5 -0
  88. package/components/clipboard/clipboard.js +185 -0
  89. package/components/code/code.d.ts +44 -0
  90. package/components/code/code.js +191 -0
  91. package/components/confirm/confirm.d.ts +48 -0
  92. package/components/confirm/confirm.js +153 -0
  93. package/components/confirm-service/confirm-service.d.ts +21 -0
  94. package/components/confirm-service/confirm-service.js +141 -0
  95. package/components/content-layout/content-layout.d.ts +26 -0
  96. package/components/content-layout/content-layout.js +79 -0
  97. package/components/content-layout/sidebar.d.ts +31 -0
  98. package/components/content-layout/sidebar.js +7 -0
  99. package/components/contenteditable/contenteditable.d.ts +47 -0
  100. package/components/contenteditable/contenteditable.js +84 -0
  101. package/components/control-label/control-label.d.ts +11 -0
  102. package/components/control-label/control-label.js +36 -0
  103. package/components/data-list/data-list.d.ts +85 -0
  104. package/components/data-list/data-list.js +251 -0
  105. package/components/data-list/data-list.mock.d.ts +16 -0
  106. package/components/data-list/data-list.mock.js +192 -0
  107. package/components/data-list/item.d.ts +50 -0
  108. package/components/data-list/item.js +235 -0
  109. package/components/data-list/selection.d.ts +16 -0
  110. package/components/data-list/selection.js +148 -0
  111. package/components/data-list/title.d.ts +26 -0
  112. package/components/data-list/title.js +28 -0
  113. package/components/date-picker/consts.d.ts +98 -0
  114. package/components/date-picker/consts.js +46 -0
  115. package/components/date-picker/date-input.d.ts +47 -0
  116. package/components/date-picker/date-input.js +177 -0
  117. package/components/date-picker/date-picker.d.ts +77 -0
  118. package/components/date-picker/date-picker.js +404 -0
  119. package/components/date-picker/date-popup.d.ts +55 -0
  120. package/components/date-picker/date-popup.js +488 -0
  121. package/components/date-picker/day.d.ts +30 -0
  122. package/components/date-picker/day.js +133 -0
  123. package/components/date-picker/formats.d.ts +2 -0
  124. package/components/date-picker/formats.js +3 -0
  125. package/components/date-picker/month-names.d.ts +13 -0
  126. package/components/date-picker/month-names.js +110 -0
  127. package/components/date-picker/month-slider.d.ts +29 -0
  128. package/components/date-picker/month-slider.js +93 -0
  129. package/components/date-picker/month.d.ts +14 -0
  130. package/components/date-picker/month.js +58 -0
  131. package/components/date-picker/months.d.ts +11 -0
  132. package/components/date-picker/months.js +133 -0
  133. package/components/date-picker/weekdays.d.ts +13 -0
  134. package/components/date-picker/weekdays.js +39 -0
  135. package/components/date-picker/years.d.ts +25 -0
  136. package/components/date-picker/years.js +134 -0
  137. package/components/dialog/dialog.d.ts +64 -0
  138. package/components/dialog/dialog.js +240 -0
  139. package/components/dialog/dialog__body-scroll-preventer.d.ts +9 -0
  140. package/components/dialog/dialog__body-scroll-preventer.js +6 -0
  141. package/components/dropdown/anchor.d.ts +11 -0
  142. package/components/dropdown/anchor.js +24 -0
  143. package/components/dropdown/dropdown.d.ts +87 -0
  144. package/components/dropdown/dropdown.js +247 -0
  145. package/components/dropdown-menu/dropdown-menu.d.ts +36 -0
  146. package/components/dropdown-menu/dropdown-menu.js +199 -0
  147. package/components/editable-heading/editable-heading.d.ts +32 -0
  148. package/components/editable-heading/editable-heading.js +276 -0
  149. package/components/error-bubble/error-bubble.d.ts +18 -0
  150. package/components/error-bubble/error-bubble.js +88 -0
  151. package/components/error-message/error-message.d.ts +27 -0
  152. package/components/error-message/error-message.js +78 -0
  153. package/components/footer/footer.d.ts +28 -0
  154. package/components/footer/footer.js +118 -0
  155. package/components/global/compose.d.ts +7 -0
  156. package/components/global/compose.js +17 -0
  157. package/components/global/composeRefs.d.ts +3 -0
  158. package/components/global/composeRefs.js +19 -0
  159. package/components/global/controls-height.d.ts +9 -0
  160. package/components/global/controls-height.js +19 -0
  161. package/components/global/create-stateful-context.d.ts +27 -0
  162. package/components/global/create-stateful-context.js +49 -0
  163. package/components/global/data-tests.d.ts +3 -0
  164. package/components/global/data-tests.js +30 -0
  165. package/components/global/dom.d.ts +37 -0
  166. package/components/global/dom.js +151 -0
  167. package/components/global/focus-sensor-hoc.d.ts +19 -0
  168. package/components/global/focus-sensor-hoc.js +165 -0
  169. package/components/global/fuzzy-highlight.d.ts +11 -0
  170. package/components/global/fuzzy-highlight.js +90 -0
  171. package/components/global/get-event-key.d.ts +2 -0
  172. package/components/global/get-event-key.js +101 -0
  173. package/components/global/get-uid.d.ts +1 -0
  174. package/components/global/get-uid.js +22 -0
  175. package/components/global/inject-styles.d.ts +3 -0
  176. package/components/global/inject-styles.js +22 -0
  177. package/components/global/linear-function.d.ts +6 -0
  178. package/components/global/linear-function.js +15 -0
  179. package/components/global/listeners.d.ts +8 -0
  180. package/components/global/listeners.js +58 -0
  181. package/components/global/memoize.d.ts +1 -0
  182. package/components/global/memoize.js +23 -0
  183. package/components/global/normalize-indent.d.ts +1 -0
  184. package/components/global/normalize-indent.js +60 -0
  185. package/components/global/promise-with-timeout.d.ts +5 -0
  186. package/components/global/promise-with-timeout.js +19 -0
  187. package/components/global/prop-types.d.ts +4 -0
  188. package/components/global/prop-types.js +9 -0
  189. package/components/global/react-dom-renderer.d.ts +16 -0
  190. package/components/global/react-dom-renderer.js +54 -0
  191. package/components/global/react-render-adapter.d.ts +1 -0
  192. package/components/global/react-render-adapter.js +6 -0
  193. package/components/global/rerender-hoc.d.ts +10 -0
  194. package/components/global/rerender-hoc.js +46 -0
  195. package/components/global/schedule-raf.d.ts +1 -0
  196. package/components/global/schedule-raf.js +28 -0
  197. package/components/global/sniffer.d.ts +3 -0
  198. package/components/global/sniffer.js +6 -0
  199. package/components/global/theme.d.ts +21 -0
  200. package/components/global/theme.js +42 -0
  201. package/components/global/trivial-template-tag.d.ts +1 -0
  202. package/components/global/trivial-template-tag.js +21 -0
  203. package/components/global/typescript-utils.d.ts +2 -0
  204. package/components/global/typescript-utils.js +8 -0
  205. package/components/global/url.d.ts +57 -0
  206. package/components/global/url.js +142 -0
  207. package/components/global/use-event-callback.d.ts +1 -0
  208. package/components/global/use-event-callback.js +17 -0
  209. package/components/global/variables.d.ts +89 -0
  210. package/components/global/variables.js +1 -0
  211. package/components/grid/col.d.ts +31 -0
  212. package/components/grid/col.js +80 -0
  213. package/components/grid/grid.d.ts +14 -0
  214. package/components/grid/grid.js +46 -0
  215. package/components/grid/row.d.ts +40 -0
  216. package/components/grid/row.js +75 -0
  217. package/components/group/group.d.ts +12 -0
  218. package/components/group/group.js +39 -0
  219. package/components/header/header.d.ts +34 -0
  220. package/components/header/header.js +189 -0
  221. package/components/header/logo.d.ts +14 -0
  222. package/components/header/logo.js +51 -0
  223. package/components/header/profile.d.ts +75 -0
  224. package/components/header/profile.js +258 -0
  225. package/components/header/services-link.d.ts +25 -0
  226. package/components/header/services-link.js +13 -0
  227. package/components/header/services.d.ts +33 -0
  228. package/components/header/services.js +174 -0
  229. package/components/header/smart-profile.d.ts +36 -0
  230. package/components/header/smart-profile.js +303 -0
  231. package/components/header/smart-services.d.ts +26 -0
  232. package/components/header/smart-services.js +192 -0
  233. package/components/header/tray-icon.d.ts +32 -0
  234. package/components/header/tray-icon.js +57 -0
  235. package/components/header/tray.d.ts +9 -0
  236. package/components/header/tray.js +41 -0
  237. package/components/heading/heading.d.ts +25 -0
  238. package/components/heading/heading.js +69 -0
  239. package/components/http/http.d.ts +61 -0
  240. package/components/http/http.js +386 -0
  241. package/components/http/http.mock.d.ts +20 -0
  242. package/components/http/http.mock.js +113 -0
  243. package/components/hub-source/hub-source.d.ts +44 -0
  244. package/components/hub-source/hub-source.js +217 -0
  245. package/components/hub-source/hub-source__user.d.ts +4 -0
  246. package/components/hub-source/hub-source__user.js +60 -0
  247. package/components/hub-source/hub-source__users-groups.d.ts +24 -0
  248. package/components/hub-source/hub-source__users-groups.js +86 -0
  249. package/components/i18n/i18n-context.d.ts +13 -0
  250. package/components/i18n/i18n-context.js +27 -0
  251. package/components/i18n/i18n.d.ts +59 -0
  252. package/components/i18n/i18n.js +139 -0
  253. package/components/icon/icon.d.ts +43 -0
  254. package/components/icon/icon.js +109 -0
  255. package/components/icon/icon__constants.d.ts +30 -0
  256. package/components/icon/icon__constants.js +34 -0
  257. package/components/icon/icon__svg.d.ts +15 -0
  258. package/components/icon/icon__svg.js +14 -0
  259. package/components/icon/index.d.ts +2 -0
  260. package/components/icon/index.js +17 -0
  261. package/components/input/input.d.ts +77 -0
  262. package/components/input/input.js +35 -0
  263. package/components/island/adaptive-island-hoc.d.ts +61 -0
  264. package/components/island/adaptive-island-hoc.js +53 -0
  265. package/components/island/content.d.ts +43 -0
  266. package/components/island/content.js +151 -0
  267. package/components/island/header.d.ts +8 -0
  268. package/components/island/header.js +100 -0
  269. package/components/island/island.d.ts +78 -0
  270. package/components/island/island.js +60 -0
  271. package/components/island-legacy/content-legacy.d.ts +10 -0
  272. package/components/island-legacy/content-legacy.js +34 -0
  273. package/components/island-legacy/header-legacy.d.ts +10 -0
  274. package/components/island-legacy/header-legacy.js +36 -0
  275. package/components/island-legacy/island-legacy.d.ts +12 -0
  276. package/components/island-legacy/island-legacy.js +36 -0
  277. package/components/link/clickableLink.d.ts +20 -0
  278. package/components/link/clickableLink.js +69 -0
  279. package/components/link/link.d.ts +138 -0
  280. package/components/link/link.js +86 -0
  281. package/components/list/consts.d.ts +77 -0
  282. package/components/list/consts.js +27 -0
  283. package/components/list/list.d.ts +205 -0
  284. package/components/list/list.js +802 -0
  285. package/components/list/list__custom.d.ts +6 -0
  286. package/components/list/list__custom.js +92 -0
  287. package/components/list/list__hint.d.ts +15 -0
  288. package/components/list/list__hint.js +33 -0
  289. package/components/list/list__item.d.ts +8 -0
  290. package/components/list/list__item.js +237 -0
  291. package/components/list/list__link.d.ts +9 -0
  292. package/components/list/list__link.js +76 -0
  293. package/components/list/list__separator.d.ts +5 -0
  294. package/components/list/list__separator.js +39 -0
  295. package/components/list/list__title.d.ts +5 -0
  296. package/components/list/list__title.js +48 -0
  297. package/components/list/list__users-groups-source.d.ts +27 -0
  298. package/components/list/list__users-groups-source.js +195 -0
  299. package/components/loader/loader.d.ts +28 -0
  300. package/components/loader/loader.js +93 -0
  301. package/components/loader/loader__core.d.ts +75 -0
  302. package/components/loader/loader__core.js +327 -0
  303. package/components/loader-inline/loader-inline.d.ts +18 -0
  304. package/components/loader-inline/loader-inline.js +50 -0
  305. package/components/loader-screen/loader-screen.d.ts +17 -0
  306. package/components/loader-screen/loader-screen.js +64 -0
  307. package/components/login-dialog/login-dialog.d.ts +47 -0
  308. package/components/login-dialog/login-dialog.js +216 -0
  309. package/components/login-dialog/service.d.ts +2 -0
  310. package/components/login-dialog/service.js +98 -0
  311. package/components/markdown/markdown.d.ts +12 -0
  312. package/components/markdown/markdown.js +43 -0
  313. package/components/message/message.d.ts +55 -0
  314. package/components/message/message.js +267 -0
  315. package/components/old-browsers-message/old-browsers-message.d.ts +2 -0
  316. package/components/old-browsers-message/old-browsers-message.js +92 -0
  317. package/components/old-browsers-message/old-browsers-message__stop.d.ts +1 -0
  318. package/components/old-browsers-message/old-browsers-message__stop.js +11 -0
  319. package/components/old-browsers-message/white-list.d.ts +2 -0
  320. package/components/old-browsers-message/white-list.js +37 -0
  321. package/components/pager/pager.d.ts +78 -0
  322. package/components/pager/pager.js +390 -0
  323. package/components/panel/panel.d.ts +12 -0
  324. package/components/panel/panel.js +39 -0
  325. package/components/permissions/permissions.d.ts +111 -0
  326. package/components/permissions/permissions.js +221 -0
  327. package/components/permissions/permissions__cache.d.ts +93 -0
  328. package/components/permissions/permissions__cache.js +257 -0
  329. package/components/popup/popup.consts.d.ts +37 -0
  330. package/components/popup/popup.consts.js +44 -0
  331. package/components/popup/popup.d.ts +147 -0
  332. package/components/popup/popup.js +424 -0
  333. package/components/popup/popup.target.d.ts +7 -0
  334. package/components/popup/popup.target.js +24 -0
  335. package/components/popup/position.d.ts +30 -0
  336. package/components/popup/position.js +271 -0
  337. package/components/popup-menu/popup-menu.d.ts +80 -0
  338. package/components/popup-menu/popup-menu.js +141 -0
  339. package/components/progress-bar/progress-bar.d.ts +64 -0
  340. package/components/progress-bar/progress-bar.js +120 -0
  341. package/components/query-assist/query-assist.d.ts +306 -0
  342. package/components/query-assist/query-assist.js +1098 -0
  343. package/components/query-assist/query-assist__suggestions.d.ts +29 -0
  344. package/components/query-assist/query-assist__suggestions.js +75 -0
  345. package/components/radio/radio.d.ts +18 -0
  346. package/components/radio/radio.js +48 -0
  347. package/components/radio/radio__item.d.ts +28 -0
  348. package/components/radio/radio__item.js +88 -0
  349. package/components/select/select.d.ts +276 -0
  350. package/components/select/select.js +1310 -0
  351. package/components/select/select__filter.d.ts +19 -0
  352. package/components/select/select__filter.js +85 -0
  353. package/components/select/select__popup.d.ts +166 -0
  354. package/components/select/select__popup.js +631 -0
  355. package/components/shortcuts/core.d.ts +74 -0
  356. package/components/shortcuts/core.js +249 -0
  357. package/components/shortcuts/shortcut-title.d.ts +1 -0
  358. package/components/shortcuts/shortcut-title.js +56 -0
  359. package/components/shortcuts/shortcuts-hoc.d.ts +65 -0
  360. package/components/shortcuts/shortcuts-hoc.js +61 -0
  361. package/components/shortcuts/shortcuts.d.ts +28 -0
  362. package/components/shortcuts/shortcuts.js +92 -0
  363. package/components/storage/storage.d.ts +18 -0
  364. package/components/storage/storage.js +92 -0
  365. package/components/storage/storage__fallback.d.ts +79 -0
  366. package/components/storage/storage__fallback.js +254 -0
  367. package/components/storage/storage__local.d.ts +38 -0
  368. package/components/storage/storage__local.js +217 -0
  369. package/components/style.css +1 -0
  370. package/components/tab-trap/tab-trap.d.ts +43 -0
  371. package/components/tab-trap/tab-trap.js +180 -0
  372. package/components/table/cell.d.ts +13 -0
  373. package/components/table/cell.js +37 -0
  374. package/components/table/disable-hover-hoc.d.ts +64 -0
  375. package/components/table/disable-hover-hoc.js +62 -0
  376. package/components/table/header-cell.d.ts +43 -0
  377. package/components/table/header-cell.js +109 -0
  378. package/components/table/header.d.ts +56 -0
  379. package/components/table/header.js +151 -0
  380. package/components/table/multitable.d.ts +25 -0
  381. package/components/table/multitable.js +140 -0
  382. package/components/table/row-with-focus-sensor.d.ts +18 -0
  383. package/components/table/row-with-focus-sensor.js +117 -0
  384. package/components/table/row.d.ts +59 -0
  385. package/components/table/row.js +299 -0
  386. package/components/table/selection-adapter.d.ts +5 -0
  387. package/components/table/selection-adapter.js +14 -0
  388. package/components/table/selection-shortcuts-hoc.d.ts +17 -0
  389. package/components/table/selection-shortcuts-hoc.js +205 -0
  390. package/components/table/selection.d.ts +47 -0
  391. package/components/table/selection.js +257 -0
  392. package/components/table/smart-table.d.ts +64 -0
  393. package/components/table/smart-table.js +149 -0
  394. package/components/table/table.d.ts +159 -0
  395. package/components/table/table.js +463 -0
  396. package/components/tabs/collapsible-more.d.ts +29 -0
  397. package/components/tabs/collapsible-more.js +222 -0
  398. package/components/tabs/collapsible-tab.d.ts +16 -0
  399. package/components/tabs/collapsible-tab.js +88 -0
  400. package/components/tabs/collapsible-tabs.d.ts +43 -0
  401. package/components/tabs/collapsible-tabs.js +354 -0
  402. package/components/tabs/custom-item.d.ts +9 -0
  403. package/components/tabs/custom-item.js +11 -0
  404. package/components/tabs/dumb-tabs.d.ts +35 -0
  405. package/components/tabs/dumb-tabs.js +189 -0
  406. package/components/tabs/smart-tabs.d.ts +20 -0
  407. package/components/tabs/smart-tabs.js +141 -0
  408. package/components/tabs/tab-link.d.ts +18 -0
  409. package/components/tabs/tab-link.js +13 -0
  410. package/components/tabs/tab.d.ts +27 -0
  411. package/components/tabs/tab.js +41 -0
  412. package/components/tabs/tabs.d.ts +7 -0
  413. package/components/tabs/tabs.js +99 -0
  414. package/components/tag/tag.d.ts +64 -0
  415. package/components/tag/tag.js +213 -0
  416. package/components/tags-input/tags-input.d.ts +138 -0
  417. package/components/tags-input/tags-input.js +534 -0
  418. package/components/tags-list/tags-list.d.ts +46 -0
  419. package/components/tags-list/tags-list.js +102 -0
  420. package/components/text/text.d.ts +23 -0
  421. package/components/text/text.js +57 -0
  422. package/components/toggle/toggle.d.ts +39 -0
  423. package/components/toggle/toggle.js +86 -0
  424. package/components/tooltip/tooltip.d.ts +65 -0
  425. package/components/tooltip/tooltip.js +229 -0
  426. package/components/user-agreement/service.d.ts +69 -0
  427. package/components/user-agreement/service.js +487 -0
  428. package/components/user-agreement/toolbox.eula.d.ts +2 -0
  429. package/components/user-agreement/toolbox.eula.js +3 -0
  430. package/components/user-agreement/user-agreement.d.ts +60 -0
  431. package/components/user-agreement/user-agreement.js +172 -0
  432. package/components/user-card/card.d.ts +70 -0
  433. package/components/user-card/card.js +80 -0
  434. package/components/user-card/smart-user-card-tooltip.d.ts +20 -0
  435. package/components/user-card/smart-user-card-tooltip.js +172 -0
  436. package/components/user-card/tooltip.d.ts +36 -0
  437. package/components/user-card/tooltip.js +144 -0
  438. package/components/user-card/user-card.d.ts +11 -0
  439. package/components/user-card/user-card.js +85 -0
  440. package/package.json +118 -0
  441. package/typings.d.ts +43 -0
@@ -0,0 +1,138 @@
1
+ import React, { PureComponent, SyntheticEvent, ReactNode, ComponentType } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import Select, { SelectItem } from '../select/select';
4
+ import { TagType } from '../tags-list/tags-list';
5
+ import Caret from '../caret/caret';
6
+ import { Size } from '../input/input';
7
+ import { ControlsHeight } from '../global/controls-height';
8
+ import { Filter } from '../select/select__popup';
9
+ import { TagAttrs } from '../tag/tag';
10
+ import { LabelType } from '../control-label/control-label';
11
+ declare function noop(): void;
12
+ export interface ToggleTagParams {
13
+ tag: TagType;
14
+ }
15
+ export interface TagsInputRequestParams {
16
+ query: string;
17
+ }
18
+ export interface TagsInputProps {
19
+ dataSource: (params: TagsInputRequestParams) => readonly SelectItem[] | Promise<readonly SelectItem[]>;
20
+ onAddTag: (params: ToggleTagParams) => void;
21
+ onRemoveTag: (params: ToggleTagParams) => void;
22
+ customTagComponent: ComponentType<TagAttrs>;
23
+ maxPopupHeight: number;
24
+ minPopupWidth: number;
25
+ canNotBeEmpty: boolean;
26
+ disabled: boolean;
27
+ autoOpen: boolean;
28
+ renderOptimization: boolean;
29
+ allowAddNewTags: boolean;
30
+ filter: boolean | Filter;
31
+ placeholder: string;
32
+ className?: string | null | undefined;
33
+ tags?: readonly TagType[] | null | undefined;
34
+ loadingMessage?: string | undefined;
35
+ notFoundMessage?: string | undefined;
36
+ hint?: ReactNode | null | undefined;
37
+ size: Size;
38
+ height?: ControlsHeight | undefined;
39
+ label?: ReactNode;
40
+ labelType?: LabelType;
41
+ id?: string | undefined;
42
+ }
43
+ interface TagsInputState {
44
+ tags: TagType[];
45
+ prevTags: TagType[] | null;
46
+ suggestions: SelectItem[];
47
+ loading: boolean;
48
+ focused: boolean;
49
+ query: string;
50
+ activeIndex: number | null | undefined;
51
+ }
52
+ export default class TagsInput extends PureComponent<TagsInputProps, TagsInputState> {
53
+ static propTypes: {
54
+ className: PropTypes.Requireable<string>;
55
+ tags: PropTypes.Requireable<any[]>;
56
+ /**
57
+ * Datasource should return array(or promise) of suggestions.
58
+ * Each suggestion should contain key and label fields.
59
+ * DataSource should handle caching and response racing (when later request
60
+ * responded earlier) by himself.
61
+ */
62
+ dataSource: PropTypes.Requireable<(...args: any[]) => any>;
63
+ onAddTag: PropTypes.Requireable<(...args: any[]) => any>;
64
+ onRemoveTag: PropTypes.Requireable<(...args: any[]) => any>;
65
+ customTagComponent: PropTypes.Requireable<React.Component<unknown, unknown, unknown>>;
66
+ maxPopupHeight: PropTypes.Requireable<number>;
67
+ minPopupWidth: PropTypes.Requireable<number>;
68
+ placeholder: PropTypes.Requireable<string>;
69
+ canNotBeEmpty: PropTypes.Requireable<boolean>;
70
+ disabled: PropTypes.Requireable<boolean>;
71
+ autoOpen: PropTypes.Requireable<boolean>;
72
+ renderOptimization: PropTypes.Requireable<boolean>;
73
+ filter: PropTypes.Requireable<NonNullable<boolean | PropTypes.InferProps<{
74
+ fn: PropTypes.Requireable<(...args: any[]) => any>;
75
+ }> | null | undefined>>;
76
+ size: PropTypes.Requireable<string>;
77
+ height: PropTypes.Requireable<string>;
78
+ label: PropTypes.Requireable<PropTypes.ReactNodeLike>;
79
+ loadingMessage: PropTypes.Requireable<string>;
80
+ notFoundMessage: PropTypes.Requireable<string>;
81
+ hint: PropTypes.Requireable<PropTypes.ReactNodeLike>;
82
+ allowAddNewTags: PropTypes.Requireable<boolean>;
83
+ };
84
+ static defaultProps: {
85
+ dataSource: typeof noop;
86
+ onAddTag: typeof noop;
87
+ onRemoveTag: typeof noop;
88
+ customTagComponent: null;
89
+ maxPopupHeight: number;
90
+ minPopupWidth: number;
91
+ canNotBeEmpty: boolean;
92
+ disabled: boolean;
93
+ autoOpen: boolean;
94
+ renderOptimization: boolean;
95
+ allowAddNewTags: boolean;
96
+ filter: {
97
+ fn: () => boolean;
98
+ };
99
+ placeholder: string;
100
+ size: Size;
101
+ };
102
+ constructor(props: TagsInputProps);
103
+ state: TagsInputState;
104
+ static getDerivedStateFromProps({ tags }: TagsInputProps, { prevTags }: TagsInputState): {
105
+ prevTags: readonly TagType[] | null | undefined;
106
+ };
107
+ componentDidMount(): void;
108
+ static ngModelStateField: string;
109
+ ngModelStateField: string;
110
+ static contextType: React.Context<ControlsHeight>;
111
+ id: string;
112
+ node?: HTMLElement | null;
113
+ nodeRef: (node: HTMLElement | null) => void;
114
+ input?: HTMLInputElement | null;
115
+ caret?: Caret;
116
+ getInputNode(): HTMLInputElement | null | undefined;
117
+ setActiveIndex(activeIndex?: number | null): void;
118
+ focusInput: () => void;
119
+ focus: () => void;
120
+ addTag: (tag: TagType | null) => void;
121
+ onRemoveTag(tagToRemove: TagType): Promise<void | TagType[]>;
122
+ clickHandler: (event: SyntheticEvent) => void;
123
+ filterExistingTags: (suggestions: readonly SelectItem[]) => SelectItem[];
124
+ loadSuggestions: (query?: string) => void;
125
+ private _focusHandler;
126
+ private _blurHandler;
127
+ selectTag: (moveForward?: boolean) => void;
128
+ handleKeyDown: (event: React.KeyboardEvent) => boolean;
129
+ handleClick: (arg: TagType) => () => void;
130
+ handleRemove: (arg: TagType) => () => Promise<void | TagType[]>;
131
+ handleTagCreation: (label: string) => void;
132
+ select?: Select | null;
133
+ selectRef: (el: Select | null) => void;
134
+ render(): React.JSX.Element;
135
+ }
136
+ export declare const RerenderableTagsInput: React.ForwardRefExoticComponent<TagsInputProps & React.RefAttributes<TagsInput>>;
137
+ export type TagsInputAttrs = JSX.LibraryManagedAttributes<typeof TagsInput, TagsInputProps>;
138
+ export {};
@@ -0,0 +1,534 @@
1
+ import { _ as _defineProperty, a as _inherits, b as _createSuper, c as _classCallCheck, k as _assertThisInitialized, h as _asyncToGenerator, d as _createClass, i as _regeneratorRuntime } from '../_helpers/_rollupPluginBabelHelpers.js';
2
+ import 'core-js/modules/es.array.filter.js';
3
+ import 'core-js/modules/es.object.to-string.js';
4
+ import 'core-js/modules/es.array.concat.js';
5
+ import 'core-js/modules/es.array.iterator.js';
6
+ import 'core-js/modules/es.map.js';
7
+ import 'core-js/modules/web.dom-collections.iterator.js';
8
+ import 'core-js/modules/es.array.map.js';
9
+ import 'core-js/modules/es.array.index-of.js';
10
+ import 'core-js/modules/es.promise.js';
11
+ import 'core-js/modules/es.object.assign.js';
12
+ import React, { Component, PureComponent } from 'react';
13
+ import PropTypes from 'prop-types';
14
+ import classNames from 'classnames';
15
+ import getEventKey from '../global/get-event-key.js';
16
+ import Select from '../select/select.js';
17
+ import TagsList from '../tags-list/tags-list.js';
18
+ import Caret from '../caret/caret.js';
19
+ import memoize from '../global/memoize.js';
20
+ import rerenderHOC from '../global/rerender-hoc.js';
21
+ import { S as Size, m as modules_88cfaf40 } from '../_helpers/input.js';
22
+ import { ControlsHeightContext } from '../global/controls-height.js';
23
+ import getUID from '../global/get-uid.js';
24
+ import { ControlLabel } from '../control-label/control-label.js';
25
+ import 'core-js/modules/es.array.reduce.js';
26
+ import 'core-js/modules/es.string.trim.js';
27
+ import 'core-js/modules/es.regexp.exec.js';
28
+ import 'core-js/modules/es.array.find.js';
29
+ import 'core-js/modules/es.string.replace.js';
30
+ import 'core-js/modules/web.dom-collections.for-each.js';
31
+ import 'core-js/modules/es.array.slice.js';
32
+ import 'core-js/modules/es.object.values.js';
33
+ import '@jetbrains/icons/chevron-down';
34
+ import '@jetbrains/icons/close-12px';
35
+ import 'deep-equal';
36
+ import '../dropdown/dropdown.js';
37
+ import '../global/data-tests.js';
38
+ import 'core-js/modules/es.object.entries.js';
39
+ import '../global/typescript-utils.js';
40
+ import '../_helpers/anchor.js';
41
+ import '@jetbrains/icons/chevron-10px';
42
+ import '../icon/icon.js';
43
+ import 'util-deprecate';
44
+ import '../icon/icon__constants.js';
45
+ import '../_helpers/icon__svg.js';
46
+ import 'core-js/modules/es.string.starts-with.js';
47
+ import '../button/button.js';
48
+ import '../link/clickableLink.js';
49
+ import '../_helpers/button__classes.js';
50
+ import 'core-js/modules/es.weak-map.js';
51
+ import '../avatar/avatar.js';
52
+ import '../global/url.js';
53
+ import 'core-js/modules/es.string.match.js';
54
+ import '../global/dom.js';
55
+ import 'core-js/modules/es.string.split.js';
56
+ import 'core-js/modules/es.set.js';
57
+ import '../avatar/fallback-avatar.js';
58
+ import 'core-js/modules/es.array.from.js';
59
+ import 'core-js/modules/es.regexp.to-string.js';
60
+ import '../popup/popup.js';
61
+ import 'react-dom';
62
+ import '../global/schedule-raf.js';
63
+ import '../shortcuts/shortcuts.js';
64
+ import '../shortcuts/core.js';
65
+ import 'core-js/modules/es.array.includes.js';
66
+ import 'core-js/modules/es.string.includes.js';
67
+ import 'core-js/modules/es.array.splice.js';
68
+ import 'core-js/modules/es.array.find-index.js';
69
+ import 'combokeys';
70
+ import '../global/sniffer.js';
71
+ import 'sniffr';
72
+ import '../tab-trap/tab-trap.js';
73
+ import '../popup/position.js';
74
+ import 'core-js/modules/es.array.sort.js';
75
+ import '../popup/popup.consts.js';
76
+ import '../popup/popup.target.js';
77
+ import '../list/list.js';
78
+ import 'core-js/modules/es.symbol.js';
79
+ import 'core-js/modules/es.symbol.description.js';
80
+ import 'react-virtualized/dist/es/List';
81
+ import 'react-virtualized/dist/es/AutoSizer';
82
+ import 'react-virtualized/dist/es/WindowScroller';
83
+ import 'react-virtualized/dist/es/CellMeasurer';
84
+ import 'memoize-one';
85
+ import '../global/create-stateful-context.js';
86
+ import '../list/list__link.js';
87
+ import '../link/link.js';
88
+ import '../_helpers/link.js';
89
+ import '../_helpers/list.js';
90
+ import '../list/list__item.js';
91
+ import '../checkbox/checkbox.js';
92
+ import '@jetbrains/icons/checkmark-14px';
93
+ import '@jetbrains/icons/remove-14px';
94
+ import '../global/prop-types.js';
95
+ import '../global/composeRefs.js';
96
+ import '../list/list__custom.js';
97
+ import '../list/list__title.js';
98
+ import '../list/list__separator.js';
99
+ import '../list/list__hint.js';
100
+ import '../list/consts.js';
101
+ import '../global/fuzzy-highlight.js';
102
+ import '../i18n/i18n-context.js';
103
+ import '../i18n/i18n.js';
104
+ import '../select/select__popup.js';
105
+ import '@jetbrains/icons/search';
106
+ import '../loader-inline/loader-inline.js';
107
+ import '../shortcuts/shortcuts-hoc.js';
108
+ import '../text/text.js';
109
+ import '../_helpers/select__filter.js';
110
+ import '../tag/tag.js';
111
+
112
+ var modules_5aa8aaf3 = {"outerContainer":"outerContainer_rui_e356","container":"container_rui_e356","input":"input_rui_e356","light":"light_rui_2ac4","tagsInput":"tagsInput_rui_1a67","tagsInputDisabled":"tagsInputDisabled_rui_1a67","tagsInputFocused":"tagsInputFocused_rui_1a67","tagsList":"tagsList_rui_1a67","tagsSelect":"tagsSelect_rui_1a67"};
113
+
114
+ function noop() {}
115
+ /**
116
+ * @name Tags Input
117
+ */
118
+ var POPUP_VERTICAL_SHIFT = 2;
119
+ var TagsInput = /*#__PURE__*/function (_PureComponent) {
120
+ _inherits(TagsInput, _PureComponent);
121
+ var _super = _createSuper(TagsInput);
122
+ function TagsInput(props) {
123
+ var _this;
124
+ _classCallCheck(this, TagsInput);
125
+ _this = _super.call(this, props);
126
+ _defineProperty(_assertThisInitialized(_this), "state", {
127
+ tags: [],
128
+ prevTags: null,
129
+ suggestions: [],
130
+ loading: true,
131
+ focused: false,
132
+ query: '',
133
+ activeIndex: 0
134
+ });
135
+ _defineProperty(_assertThisInitialized(_this), "ngModelStateField", void 0);
136
+ _defineProperty(_assertThisInitialized(_this), "id", _this.props.id || getUID('ring-tags-list-'));
137
+ _defineProperty(_assertThisInitialized(_this), "node", void 0);
138
+ _defineProperty(_assertThisInitialized(_this), "nodeRef", function (node) {
139
+ _this.node = node;
140
+ });
141
+ _defineProperty(_assertThisInitialized(_this), "input", void 0);
142
+ _defineProperty(_assertThisInitialized(_this), "caret", void 0);
143
+ _defineProperty(_assertThisInitialized(_this), "focusInput", function () {
144
+ var _this$getInputNode;
145
+ (_this$getInputNode = _this.getInputNode()) === null || _this$getInputNode === void 0 || _this$getInputNode.focus();
146
+ });
147
+ _defineProperty(_assertThisInitialized(_this), "focus", function () {
148
+ _this.focusInput();
149
+ });
150
+ _defineProperty(_assertThisInitialized(_this), "addTag", function (tag) {
151
+ var _this$select, _this$select2;
152
+ if (tag == null) {
153
+ return;
154
+ }
155
+ var isUniqueTag = _this.state.tags.filter(function (item) {
156
+ return tag.key === item.key;
157
+ }).length === 0;
158
+ (_this$select = _this.select) === null || _this$select === void 0 || _this$select.clear();
159
+ (_this$select2 = _this.select) === null || _this$select2 === void 0 || _this$select2.filterValue('');
160
+ if (isUniqueTag) {
161
+ _this.setState(function (prevState) {
162
+ return {
163
+ tags: prevState.tags.concat([tag])
164
+ };
165
+ });
166
+ _this.props.onAddTag({
167
+ tag
168
+ });
169
+ _this.setActiveIndex();
170
+ }
171
+ });
172
+ _defineProperty(_assertThisInitialized(_this), "clickHandler", function (event) {
173
+ var _this$select3;
174
+ if (event.target !== _this.node && event.target.parentElement !== _this.node) {
175
+ return;
176
+ }
177
+ (_this$select3 = _this.select) === null || _this$select3 === void 0 || _this$select3._clickHandler();
178
+ });
179
+ _defineProperty(_assertThisInitialized(_this), "filterExistingTags", function (suggestions) {
180
+ var tagsMap = new Map(_this.state.tags.map(function (tag) {
181
+ return [tag.key, tag];
182
+ }));
183
+ return suggestions.filter(function (suggestion) {
184
+ return !tagsMap.has(suggestion.key);
185
+ });
186
+ });
187
+ _defineProperty(_assertThisInitialized(_this), "loadSuggestions", function () {
188
+ var query = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
189
+ return _this.setState({
190
+ loading: true,
191
+ query
192
+ }, /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
193
+ var suggestionsResult, allSuggestions, suggestions;
194
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
195
+ while (1) switch (_context.prev = _context.next) {
196
+ case 0:
197
+ _context.prev = 0;
198
+ suggestionsResult = _this.props.dataSource({
199
+ query
200
+ });
201
+ if (!Array.isArray(suggestionsResult)) {
202
+ _context.next = 6;
203
+ break;
204
+ }
205
+ _context.t0 = suggestionsResult;
206
+ _context.next = 9;
207
+ break;
208
+ case 6:
209
+ _context.next = 8;
210
+ return suggestionsResult;
211
+ case 8:
212
+ _context.t0 = _context.sent;
213
+ case 9:
214
+ allSuggestions = _context.t0;
215
+ suggestions = _this.filterExistingTags(allSuggestions);
216
+ if (_this.node && query === _this.state.query) {
217
+ _this.setState({
218
+ suggestions,
219
+ loading: false
220
+ });
221
+ }
222
+ _context.next = 17;
223
+ break;
224
+ case 14:
225
+ _context.prev = 14;
226
+ _context.t1 = _context["catch"](0);
227
+ _this.setState({
228
+ loading: false
229
+ });
230
+ case 17:
231
+ case "end":
232
+ return _context.stop();
233
+ }
234
+ }, _callee, null, [[0, 14]]);
235
+ })));
236
+ });
237
+ _defineProperty(_assertThisInitialized(_this), "_focusHandler", function () {
238
+ _this.setActiveIndex(null);
239
+ _this.setState({
240
+ focused: true
241
+ });
242
+ });
243
+ _defineProperty(_assertThisInitialized(_this), "_blurHandler", function () {
244
+ _this.setState({
245
+ focused: false
246
+ });
247
+ });
248
+ _defineProperty(_assertThisInitialized(_this), "selectTag", function (moveForward) {
249
+ var activeIndex = typeof _this.state.activeIndex === 'number' ? _this.state.activeIndex : _this.state.tags.length + 1;
250
+ var newActiveIndex = activeIndex + (moveForward ? 1 : -1);
251
+ if (newActiveIndex >= _this.state.tags.length) {
252
+ newActiveIndex = _this.state.tags.length - 1;
253
+ } else if (newActiveIndex < 0) {
254
+ newActiveIndex = 0;
255
+ }
256
+ if (_this.state.activeIndex !== newActiveIndex) {
257
+ _this.setActiveIndex(newActiveIndex);
258
+ }
259
+ });
260
+ _defineProperty(_assertThisInitialized(_this), "handleKeyDown", function (event) {
261
+ var _this$select4;
262
+ var key = getEventKey(event);
263
+ var isInputFocused = function isInputFocused() {
264
+ var _this$getInputNode$ta, _this$getInputNode2;
265
+ return event.target instanceof Element && event.target.matches((_this$getInputNode$ta = (_this$getInputNode2 = _this.getInputNode()) === null || _this$getInputNode2 === void 0 ? void 0 : _this$getInputNode2.tagName) !== null && _this$getInputNode$ta !== void 0 ? _this$getInputNode$ta : '');
266
+ };
267
+ if (key === ' ' && _this.props.allowAddNewTags) {
268
+ var _this$getInputNode3;
269
+ event.stopPropagation();
270
+ var value = (_this$getInputNode3 = _this.getInputNode()) === null || _this$getInputNode3 === void 0 ? void 0 : _this$getInputNode3.value;
271
+ if (value != null && value !== '') {
272
+ _this.handleTagCreation(value);
273
+ }
274
+ return true;
275
+ }
276
+ if ((_this$select4 = _this.select) !== null && _this$select4 !== void 0 && (_this$select4 = _this$select4._popup) !== null && _this$select4 !== void 0 && _this$select4.isVisible()) {
277
+ return true;
278
+ }
279
+ if (key === 'ArrowLeft') {
280
+ if (_this.getInputNode() && _this.caret != null && Number(_this.caret.getPosition()) > 0) {
281
+ return true;
282
+ }
283
+ _this.selectTag();
284
+ return false;
285
+ }
286
+ if (key === 'ArrowRight' && !isInputFocused()) {
287
+ if (_this.state.activeIndex === _this.state.tags.length - 1) {
288
+ if (!_this.props.disabled) {
289
+ var _this$getInputNode4;
290
+ (_this$getInputNode4 = _this.getInputNode()) === null || _this$getInputNode4 === void 0 || _this$getInputNode4.focus();
291
+ _this.setActiveIndex();
292
+ }
293
+ } else {
294
+ _this.selectTag(true);
295
+ }
296
+ return false;
297
+ }
298
+ if (!_this.props.disabled) {
299
+ var _this$getInputNode5;
300
+ if (key === 'Backspace' && !((_this$getInputNode5 = _this.getInputNode()) !== null && _this$getInputNode5 !== void 0 && _this$getInputNode5.value)) {
301
+ var _this$select5;
302
+ event.preventDefault();
303
+ var tagsLength = _this.state.tags.length;
304
+ (_this$select5 = _this.select) === null || _this$select5 === void 0 || _this$select5._hidePopup(true); // otherwise confirmation may be overlapped by popup
305
+ _this.onRemoveTag(_this.state.tags[tagsLength - 1]);
306
+ return false;
307
+ }
308
+ if ((key === 'Delete' || key === 'Backspace') && _this.state.activeIndex != null && _this.state.tags[_this.state.activeIndex]) {
309
+ _this.onRemoveTag(_this.state.tags[_this.state.activeIndex]).then(function () {
310
+ return _this.selectTag(true);
311
+ });
312
+ return false;
313
+ }
314
+ }
315
+ return true;
316
+ });
317
+ _defineProperty(_assertThisInitialized(_this), "handleClick", memoize(function (tag) {
318
+ return function () {
319
+ _this.setActiveIndex(_this.state.tags.indexOf(tag));
320
+ };
321
+ }));
322
+ _defineProperty(_assertThisInitialized(_this), "handleRemove", memoize(function (tag) {
323
+ return function () {
324
+ return _this.onRemoveTag(tag);
325
+ };
326
+ }));
327
+ _defineProperty(_assertThisInitialized(_this), "handleTagCreation", function (label) {
328
+ _this.addTag({
329
+ key: label,
330
+ label
331
+ });
332
+ });
333
+ _defineProperty(_assertThisInitialized(_this), "select", void 0);
334
+ _defineProperty(_assertThisInitialized(_this), "selectRef", function (el) {
335
+ _this.select = el;
336
+ });
337
+ _this.ngModelStateField = TagsInput.ngModelStateField;
338
+ return _this;
339
+ }
340
+ _createClass(TagsInput, [{
341
+ key: "componentDidMount",
342
+ value: function componentDidMount() {
343
+ if (this.props.autoOpen && !this.props.disabled) {
344
+ var _this$select6;
345
+ this.focusInput();
346
+ this.loadSuggestions();
347
+ (_this$select6 = this.select) === null || _this$select6 === void 0 || _this$select6._showPopup();
348
+ }
349
+ }
350
+ }, {
351
+ key: "getInputNode",
352
+ value: function getInputNode() {
353
+ if (!this.input) {
354
+ var _this$select7;
355
+ this.input = (_this$select7 = this.select) === null || _this$select7 === void 0 ? void 0 : _this$select7.filter;
356
+ if (this.input) {
357
+ this.caret = new Caret(this.input);
358
+ }
359
+ }
360
+ return this.input;
361
+ }
362
+ }, {
363
+ key: "setActiveIndex",
364
+ value: function setActiveIndex(activeIndex) {
365
+ this.setState({
366
+ activeIndex
367
+ });
368
+ }
369
+ }, {
370
+ key: "onRemoveTag",
371
+ value: function onRemoveTag(tagToRemove) {
372
+ var _this2 = this;
373
+ return Promise.resolve(this.props.onRemoveTag({
374
+ tag: tagToRemove
375
+ })).then(function () {
376
+ var tags = _this2.state.tags.filter(function (tag) {
377
+ return tag !== tagToRemove;
378
+ });
379
+ if (_this2.node) {
380
+ _this2.setState({
381
+ tags
382
+ });
383
+ _this2.focusInput();
384
+ }
385
+ return tags;
386
+ }, this.focusInput);
387
+ }
388
+ }, {
389
+ key: "render",
390
+ value: function render() {
391
+ var _this$state = this.state,
392
+ focused = _this$state.focused,
393
+ tags = _this$state.tags,
394
+ activeIndex = _this$state.activeIndex;
395
+ var _this$props = this.props,
396
+ disabled = _this$props.disabled,
397
+ canNotBeEmpty = _this$props.canNotBeEmpty,
398
+ allowAddNewTags = _this$props.allowAddNewTags,
399
+ filter = _this$props.filter,
400
+ size = _this$props.size,
401
+ labelType = _this$props.labelType,
402
+ _this$props$height = _this$props.height,
403
+ height = _this$props$height === void 0 ? this.context : _this$props$height,
404
+ label = _this$props.label;
405
+ var classes = classNames(modules_5aa8aaf3.tagsInput, [modules_88cfaf40["size".concat(size)]], [modules_88cfaf40["height".concat(height)]], {
406
+ [modules_5aa8aaf3.tagsInputDisabled]: disabled,
407
+ [modules_5aa8aaf3.tagsInputFocused]: focused
408
+ }, this.props.className);
409
+ return /*#__PURE__*/React.createElement("div", {
410
+ // it transfers focus to input
411
+ role: "presentation",
412
+ className: classes,
413
+ onKeyDown: this.handleKeyDown,
414
+ onClick: this.clickHandler,
415
+ ref: this.nodeRef
416
+ }, label && /*#__PURE__*/React.createElement(ControlLabel, {
417
+ htmlFor: this.id,
418
+ disabled: disabled,
419
+ type: labelType
420
+ }, label), /*#__PURE__*/React.createElement(TagsList, {
421
+ tags: tags,
422
+ activeIndex: activeIndex,
423
+ disabled: disabled,
424
+ canNotBeEmpty: canNotBeEmpty,
425
+ handleRemove: this.handleRemove,
426
+ className: modules_5aa8aaf3.tagsList,
427
+ tagClassName: modules_5aa8aaf3.tag,
428
+ handleClick: this.handleClick,
429
+ customTagComponent: this.props.customTagComponent
430
+ }, /*#__PURE__*/React.createElement(Select, {
431
+ id: this.id,
432
+ ref: this.selectRef,
433
+ size: Select.Size.AUTO,
434
+ type: Select.Type.INPUT_WITHOUT_CONTROLS,
435
+ inputPlaceholder: this.props.placeholder,
436
+ data: this.state.suggestions,
437
+ className: classNames(modules_5aa8aaf3.tagsSelect),
438
+ onSelect: this.addTag,
439
+ onFocus: this._focusHandler,
440
+ onBlur: this._blurHandler,
441
+ renderOptimization: this.props.renderOptimization,
442
+ add: allowAddNewTags ? {
443
+ prefix: 'Add new tag'
444
+ } : undefined,
445
+ onAdd: allowAddNewTags ? this.handleTagCreation : undefined,
446
+ filter: filter,
447
+ maxHeight: this.props.maxPopupHeight,
448
+ minWidth: this.props.minPopupWidth,
449
+ top: POPUP_VERTICAL_SHIFT,
450
+ loading: this.state.loading,
451
+ onFilter: this.loadSuggestions,
452
+ onBeforeOpen: this.loadSuggestions,
453
+ onKeyDown: this.handleKeyDown,
454
+ disabled: this.props.disabled,
455
+ loadingMessage: this.props.loadingMessage,
456
+ notFoundMessage: this.props.notFoundMessage,
457
+ hint: this.props.hint
458
+ })));
459
+ }
460
+ }], [{
461
+ key: "getDerivedStateFromProps",
462
+ value: function getDerivedStateFromProps(_ref2, _ref3) {
463
+ var tags = _ref2.tags;
464
+ var prevTags = _ref3.prevTags;
465
+ var nextState = {
466
+ prevTags: tags
467
+ };
468
+ if (tags != null && tags !== prevTags) {
469
+ Object.assign(nextState, {
470
+ tags,
471
+ activeIndex: tags.length
472
+ });
473
+ }
474
+ return nextState;
475
+ }
476
+ }]);
477
+ return TagsInput;
478
+ }(PureComponent);
479
+ _defineProperty(TagsInput, "propTypes", {
480
+ className: PropTypes.string,
481
+ tags: PropTypes.array,
482
+ /**
483
+ * Datasource should return array(or promise) of suggestions.
484
+ * Each suggestion should contain key and label fields.
485
+ * DataSource should handle caching and response racing (when later request
486
+ * responded earlier) by himself.
487
+ */
488
+ dataSource: PropTypes.func,
489
+ onAddTag: PropTypes.func,
490
+ onRemoveTag: PropTypes.func,
491
+ customTagComponent: PropTypes.instanceOf(Component),
492
+ maxPopupHeight: PropTypes.number,
493
+ minPopupWidth: PropTypes.number,
494
+ placeholder: PropTypes.string,
495
+ canNotBeEmpty: PropTypes.bool,
496
+ disabled: PropTypes.bool,
497
+ autoOpen: PropTypes.bool,
498
+ renderOptimization: PropTypes.bool,
499
+ filter: PropTypes.oneOfType([PropTypes.bool, PropTypes.shape({
500
+ fn: PropTypes.func
501
+ })]),
502
+ size: PropTypes.string,
503
+ height: PropTypes.string,
504
+ label: PropTypes.node,
505
+ loadingMessage: PropTypes.string,
506
+ notFoundMessage: PropTypes.string,
507
+ hint: PropTypes.node,
508
+ allowAddNewTags: PropTypes.bool
509
+ });
510
+ _defineProperty(TagsInput, "defaultProps", {
511
+ dataSource: noop,
512
+ onAddTag: noop,
513
+ onRemoveTag: noop,
514
+ customTagComponent: null,
515
+ maxPopupHeight: 500,
516
+ minPopupWidth: 360,
517
+ canNotBeEmpty: false,
518
+ disabled: false,
519
+ autoOpen: false,
520
+ renderOptimization: true,
521
+ allowAddNewTags: false,
522
+ filter: {
523
+ fn: function fn() {
524
+ return true;
525
+ }
526
+ },
527
+ placeholder: 'Select an option',
528
+ size: Size.M
529
+ });
530
+ _defineProperty(TagsInput, "ngModelStateField", 'tags');
531
+ _defineProperty(TagsInput, "contextType", ControlsHeightContext);
532
+ var RerenderableTagsInput = rerenderHOC(TagsInput);
533
+
534
+ export { RerenderableTagsInput, TagsInput as default };