@jetbrains/ring-ui-built 6.0.5-beta.0

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