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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (354) hide show
  1. package/CHANGELOG.md +13 -0
  2. package/README.md +17 -15
  3. package/babel.config.js +3 -2
  4. package/components/alert/alert.js +9 -3
  5. package/components/alert/container.css +1 -1
  6. package/components/alert-service/alert-service.examples.css +18 -0
  7. package/components/alert-service/alert-service.examples.js +21 -0
  8. package/components/alert-service/alert-service.js +10 -3
  9. package/components/analytics/analytics__fus-plugin.js +1 -1
  10. package/components/auth/auth.test.js +14 -7
  11. package/components/auth/auth__core.js +64 -33
  12. package/components/auth-dialog/auth-dialog.js +1 -0
  13. package/components/avatar/avatar.css +4 -1
  14. package/components/avatar/avatar.examples.js +3 -2
  15. package/components/avatar/avatar.js +31 -6
  16. package/components/avatar/fallback-avatar.js +136 -0
  17. package/components/avatar-editor-ng/avatar-editor-ng.css +2 -2
  18. package/components/avatar-editor-ng/avatar-editor-ng.js +2 -1
  19. package/components/avatar-editor-ng/{avatar-editor-ng.html → avatar-editor-ng__template.js} +2 -2
  20. package/components/button/button.css +2 -2
  21. package/components/button/button.js +4 -1
  22. package/components/button-group/button-group.js +1 -1
  23. package/components/button-group/caption.js +1 -1
  24. package/components/button-ng/button-ng.js +1 -1
  25. package/components/button-set-ng/button-set-ng.js +3 -1
  26. package/components/checkbox/checkbox.css +1 -1
  27. package/components/code/code.js +1 -1
  28. package/components/confirm/confirm.js +1 -0
  29. package/components/confirm-service/confirm-service.js +5 -5
  30. package/components/content-layout/content-layout.css +1 -1
  31. package/components/data-list/data-list.css +1 -1
  32. package/components/date-picker/date-input.js +5 -4
  33. package/components/date-picker/date-picker.css +34 -22
  34. package/components/date-picker/date-picker.js +16 -14
  35. package/components/date-picker/date-popup.js +22 -7
  36. package/components/date-picker/month-names.js +8 -5
  37. package/components/date-picker/month.js +6 -2
  38. package/components/date-picker/weekdays.js +10 -2
  39. package/components/dialog/dialog.examples.js +3 -1
  40. package/components/dialog/dialog.js +5 -2
  41. package/components/dialog/dialog.test.js +1 -1
  42. package/components/dialog/dialog__body-scroll-preventer.js +2 -2
  43. package/components/dialog-ng/dialog-ng.js +7 -8
  44. package/components/dialog-ng/{dialog-ng.html → dialog-ng__template.js} +2 -2
  45. package/components/dropdown/dropdown.examples.js +36 -1
  46. package/components/dropdown-menu/dropdown-menu.examples.js +47 -0
  47. package/components/dropdown-menu/dropdown-menu.js +117 -0
  48. package/components/dropdown-menu/dropdown-menu.test.js +76 -0
  49. package/components/error-bubble/error-bubble-legacy.css +1 -1
  50. package/components/error-bubble/error-bubble.css +1 -1
  51. package/components/error-bubble/error-bubble.examples.js +1 -1
  52. package/components/error-page/error-page.css +2 -2
  53. package/components/footer-ng/footer-ng.js +13 -3
  54. package/components/form/form.css +2 -2
  55. package/components/form-ng/form-ng.js +3 -1
  56. package/components/global/global.css +1 -1
  57. package/components/global/theme.js +1 -1
  58. package/components/global/variables.css +8 -1
  59. package/components/grid/grid.css +10 -9
  60. package/components/header/header.css +1 -1
  61. package/components/header/header.examples.js +7 -8
  62. package/components/header/profile.js +10 -11
  63. package/components/http/http.js +1 -1
  64. package/components/icon/icon.css +5 -4
  65. package/components/island/island.css +4 -3
  66. package/components/island-legacy/island-legacy.css +3 -1
  67. package/components/list/list.js +6 -1
  68. package/components/list/list__custom.js +9 -3
  69. package/components/list/list__item.js +8 -2
  70. package/components/list/list__link.js +2 -1
  71. package/components/loader-inline/loader-inline.css +1 -1
  72. package/components/loader-screen/loader-screen.css +1 -1
  73. package/components/message/message.css +1 -1
  74. package/components/message/message.examples.js +8 -5
  75. package/components/pager/pager.js +5 -3
  76. package/components/permissions/permissions.js +1 -1
  77. package/components/progress-bar/progress-bar.css +1 -1
  78. package/components/progress-bar/progress-bar.examples.js +3 -3
  79. package/components/progress-bar/progress-bar.js +5 -2
  80. package/components/progress-bar/progress-bar.test.js +12 -13
  81. package/components/progress-bar-ng/progress-bar-ng.examples.js +3 -3
  82. package/components/query-assist/query-assist.css +13 -3
  83. package/components/query-assist/query-assist.examples.js +3 -1
  84. package/components/query-assist/query-assist.js +56 -12
  85. package/components/query-assist/query-assist.test.js +37 -5
  86. package/components/save-field-ng/save-field-ng.css +0 -3
  87. package/components/save-field-ng/save-field-ng.js +3 -1
  88. package/components/save-field-ng/{save-field-ng.html → save-field-ng__template.js} +2 -2
  89. package/components/select/select.css +12 -7
  90. package/components/select/select.examples.js +13 -0
  91. package/components/select/select.js +30 -43
  92. package/components/select/select.test.js +4 -5
  93. package/components/shortcuts-hint-ng/shortcuts-hint-ng.css +1 -1
  94. package/components/shortcuts-hint-ng/shortcuts-hint-ng.js +1 -1
  95. package/components/shortcuts-hint-ng/{shortcuts-hint-ng.html → shortcuts-hint-ng__template.js} +2 -2
  96. package/components/sidebar/sidebar.css +1 -0
  97. package/components/sidebar-ng/sidebar-ng.js +6 -2
  98. package/components/sidebar-ng/{sidebar-ng__button.html → sidebar-ng__button-template.js} +2 -2
  99. package/components/sidebar-ng/{sidebar-ng.html → sidebar-ng__template.js} +2 -2
  100. package/components/table/row.js +2 -1
  101. package/components/table/table.css +2 -1
  102. package/components/table-legacy/table-legacy.css +2 -2
  103. package/components/table-legacy/table-legacy__toolbar.css +2 -2
  104. package/components/table-legacy-ng/table-legacy-ng.js +38 -5
  105. package/components/table-legacy-ng/table-legacy-ng__pager.js +7 -1
  106. package/components/tabs/collapsible-tab.js +2 -2
  107. package/components/tabs/collapsible-tabs.js +4 -8
  108. package/components/tabs/tab-link.js +4 -2
  109. package/components/tabs/tabs.css +27 -0
  110. package/components/tabs-ng/tabs-ng.js +4 -2
  111. package/components/tabs-ng/{tabs-ng.html → tabs-ng__template.js} +6 -2
  112. package/components/tag/tag.css +5 -2
  113. package/components/tag/tag.examples.js +3 -0
  114. package/components/tag/tag.js +19 -16
  115. package/components/tags-input/tag-input.examples.js +1 -1
  116. package/components/tags-input/tags-input.js +5 -2
  117. package/components/template-ng/template-ng.js +1 -1
  118. package/components/tooltip/tooltip.js +7 -2
  119. package/components/user-agreement/user-agreement.css +1 -1
  120. package/components/user-agreement/user-agreement.examples.js +7 -4
  121. package/components/user-agreement/user-agreement.js +1 -0
  122. package/package.json +75 -78
  123. package/webpack.config.js +14 -10
  124. package/components/button-set-ng/button-set-ng.html +0 -1
  125. package/components/footer-ng/footer-ng.html +0 -13
  126. package/components/form-ng/form-ng__error-bubble.html +0 -3
  127. package/components/table-legacy-ng/table-legacy-ng.html +0 -4
  128. package/components/table-legacy-ng/table-legacy-ng__column.html +0 -12
  129. package/components/table-legacy-ng/table-legacy-ng__header.html +0 -4
  130. package/components/table-legacy-ng/table-legacy-ng__pager.html +0 -7
  131. package/components/table-legacy-ng/table-legacy-ng__row.html +0 -12
  132. package/components/table-legacy-ng/table-legacy-ng__title.html +0 -9
  133. package/dist/_helpers/_rollupPluginBabelHelpers.js +0 -127
  134. package/dist/_helpers/anchor.js +0 -33
  135. package/dist/_helpers/badge.js +0 -3
  136. package/dist/_helpers/button__classes.js +0 -39
  137. package/dist/_helpers/caption.js +0 -25
  138. package/dist/_helpers/card.js +0 -77
  139. package/dist/_helpers/date-picker.js +0 -3
  140. package/dist/_helpers/dialog__body-scroll-preventer.js +0 -56
  141. package/dist/_helpers/grid.js +0 -3
  142. package/dist/_helpers/header.js +0 -3
  143. package/dist/_helpers/icon__svg.js +0 -83
  144. package/dist/_helpers/inject-styles.js +0 -22
  145. package/dist/_helpers/island.js +0 -3
  146. package/dist/_helpers/list.js +0 -3
  147. package/dist/_helpers/query-assist__suggestions.js +0 -95
  148. package/dist/_helpers/select__filter.js +0 -78
  149. package/dist/_helpers/services-link.js +0 -42
  150. package/dist/_helpers/sidebar.js +0 -127
  151. package/dist/_helpers/table.js +0 -3
  152. package/dist/_helpers/tabs.js +0 -3
  153. package/dist/_helpers/title.js +0 -99
  154. package/dist/alert/alert.js +0 -254
  155. package/dist/alert/container.js +0 -50
  156. package/dist/alert-service/alert-service.js +0 -159
  157. package/dist/analytics/analytics.js +0 -116
  158. package/dist/analytics/analytics__custom-plugin.js +0 -127
  159. package/dist/analytics/analytics__fus-plugin.js +0 -101
  160. package/dist/analytics/analytics__ga-plugin.js +0 -66
  161. package/dist/analytics/analytics__plugin-utils.js +0 -79
  162. package/dist/auth/auth.js +0 -90
  163. package/dist/auth/auth__core.js +0 -987
  164. package/dist/auth/background-flow.js +0 -123
  165. package/dist/auth/down-notification.js +0 -111
  166. package/dist/auth/iframe-flow.js +0 -147
  167. package/dist/auth/landing-entry.js +0 -5
  168. package/dist/auth/landing.js +0 -84
  169. package/dist/auth/request-builder.js +0 -75
  170. package/dist/auth/response-parser.js +0 -117
  171. package/dist/auth/storage.js +0 -279
  172. package/dist/auth/token-validator.js +0 -176
  173. package/dist/auth/window-flow.js +0 -133
  174. package/dist/auth-dialog/auth-dialog.js +0 -132
  175. package/dist/auth-dialog-service/auth-dialog-service.js +0 -67
  176. package/dist/avatar/avatar-example-datauri.js +0 -26
  177. package/dist/avatar/avatar.js +0 -155
  178. package/dist/badge/badge.js +0 -52
  179. package/dist/button/button.js +0 -117
  180. package/dist/button/button__classes.js +0 -5
  181. package/dist/button-group/button-group.js +0 -30
  182. package/dist/button-group/caption.js +0 -5
  183. package/dist/button-set/button-set.js +0 -27
  184. package/dist/button-toolbar/button-toolbar.js +0 -30
  185. package/dist/caret/caret.js +0 -264
  186. package/dist/checkbox/checkbox.js +0 -110
  187. package/dist/confirm/confirm.js +0 -122
  188. package/dist/confirm-service/confirm-service.js +0 -112
  189. package/dist/content-layout/content-layout.js +0 -67
  190. package/dist/content-layout/sidebar.js +0 -6
  191. package/dist/contenteditable/contenteditable.js +0 -81
  192. package/dist/data-list/data-list.js +0 -203
  193. package/dist/data-list/data-list.mock.js +0 -190
  194. package/dist/data-list/item.js +0 -225
  195. package/dist/data-list/selection.js +0 -101
  196. package/dist/data-list/title.js +0 -16
  197. package/dist/date-picker/consts.js +0 -70
  198. package/dist/date-picker/date-input.js +0 -169
  199. package/dist/date-picker/date-picker.js +0 -356
  200. package/dist/date-picker/date-popup.js +0 -459
  201. package/dist/date-picker/day.js +0 -119
  202. package/dist/date-picker/formats.js +0 -3
  203. package/dist/date-picker/month-names.js +0 -92
  204. package/dist/date-picker/month-slider.js +0 -83
  205. package/dist/date-picker/month.js +0 -48
  206. package/dist/date-picker/months.js +0 -121
  207. package/dist/date-picker/weekdays.js +0 -24
  208. package/dist/date-picker/years.js +0 -109
  209. package/dist/dialog/dialog.js +0 -197
  210. package/dist/dialog/dialog__body-scroll-preventer.js +0 -2
  211. package/dist/dropdown/anchor.js +0 -16
  212. package/dist/dropdown/dropdown.js +0 -236
  213. package/dist/error-bubble/error-bubble.js +0 -59
  214. package/dist/error-message/error-message.js +0 -55
  215. package/dist/footer/footer.js +0 -127
  216. package/dist/global/angular-component-factory.js +0 -83
  217. package/dist/global/compose.js +0 -9
  218. package/dist/global/composeRefs.js +0 -15
  219. package/dist/global/conic-gradient.js +0 -37
  220. package/dist/global/create-stateful-context.js +0 -54
  221. package/dist/global/data-tests.js +0 -22
  222. package/dist/global/dom.js +0 -124
  223. package/dist/global/focus-sensor-hoc.js +0 -147
  224. package/dist/global/fuzzy-highlight.js +0 -67
  225. package/dist/global/get-event-key.js +0 -111
  226. package/dist/global/get-uid.js +0 -15
  227. package/dist/global/inject-styles.js +0 -17
  228. package/dist/global/linear-function.js +0 -18
  229. package/dist/global/listeners.js +0 -42
  230. package/dist/global/memoize.js +0 -18
  231. package/dist/global/normalize-indent.js +0 -28
  232. package/dist/global/promise-with-timeout.js +0 -13
  233. package/dist/global/radial-gradient-mask.js +0 -49
  234. package/dist/global/react-dom-renderer.js +0 -45
  235. package/dist/global/rerender-hoc.js +0 -53
  236. package/dist/global/ring-angular-component.js +0 -24
  237. package/dist/global/schedule-raf.js +0 -31
  238. package/dist/global/sniffer.js +0 -6
  239. package/dist/global/supports-css.js +0 -20
  240. package/dist/global/theme.js +0 -56
  241. package/dist/global/trivial-template-tag.js +0 -15
  242. package/dist/global/url.js +0 -163
  243. package/dist/global/variables_dark.js +0 -57
  244. package/dist/grid/col.js +0 -62
  245. package/dist/grid/grid.js +0 -35
  246. package/dist/grid/row.js +0 -66
  247. package/dist/group/group.js +0 -34
  248. package/dist/header/header.js +0 -144
  249. package/dist/header/logo.js +0 -39
  250. package/dist/header/profile.js +0 -212
  251. package/dist/header/services-link.js +0 -10
  252. package/dist/header/services.js +0 -135
  253. package/dist/header/smart-profile.js +0 -227
  254. package/dist/header/smart-services.js +0 -159
  255. package/dist/header/tray-icon.js +0 -45
  256. package/dist/header/tray.js +0 -33
  257. package/dist/heading/heading.js +0 -76
  258. package/dist/http/http.js +0 -216
  259. package/dist/http/http.mock.js +0 -65
  260. package/dist/hub-source/hub-source.js +0 -130
  261. package/dist/hub-source/hub-source__user.js +0 -28
  262. package/dist/hub-source/hub-source__users-groups.js +0 -62
  263. package/dist/icon/icon.js +0 -105
  264. package/dist/icon/icon__constants.js +0 -33
  265. package/dist/icon/icon__svg.js +0 -6
  266. package/dist/icon/index.js +0 -9
  267. package/dist/input/input.js +0 -231
  268. package/dist/island/adaptive-island-hoc.js +0 -48
  269. package/dist/island/content.js +0 -158
  270. package/dist/island/header.js +0 -85
  271. package/dist/island/island.js +0 -53
  272. package/dist/island-legacy/content-legacy.js +0 -28
  273. package/dist/island-legacy/header-legacy.js +0 -30
  274. package/dist/island-legacy/island-legacy.js +0 -30
  275. package/dist/link/clickableLink.js +0 -65
  276. package/dist/link/link.js +0 -118
  277. package/dist/list/consts.js +0 -26
  278. package/dist/list/list.js +0 -800
  279. package/dist/list/list__custom.js +0 -82
  280. package/dist/list/list__hint.js +0 -26
  281. package/dist/list/list__item.js +0 -197
  282. package/dist/list/list__link.js +0 -65
  283. package/dist/list/list__separator.js +0 -30
  284. package/dist/list/list__title.js +0 -39
  285. package/dist/list/list__users-groups-source.js +0 -124
  286. package/dist/loader/loader.js +0 -72
  287. package/dist/loader/loader__core.js +0 -272
  288. package/dist/loader-inline/inject-styles.js +0 -11
  289. package/dist/loader-inline/loader-inline.js +0 -58
  290. package/dist/loader-screen/loader-screen.js +0 -46
  291. package/dist/login-dialog/login-dialog.js +0 -184
  292. package/dist/login-dialog/service.js +0 -67
  293. package/dist/message/message.js +0 -232
  294. package/dist/old-browsers-message/old-browsers-message.js +0 -101
  295. package/dist/old-browsers-message/old-browsers-message__stop.js +0 -5
  296. package/dist/old-browsers-message/white-list.js +0 -34
  297. package/dist/pager/pager.js +0 -352
  298. package/dist/panel/panel.js +0 -34
  299. package/dist/permissions/permissions.js +0 -200
  300. package/dist/permissions/permissions__cache.js +0 -272
  301. package/dist/popup/popup.consts.js +0 -41
  302. package/dist/popup/popup.js +0 -389
  303. package/dist/popup/popup.target.js +0 -27
  304. package/dist/popup/position.js +0 -280
  305. package/dist/popup-menu/popup-menu.js +0 -108
  306. package/dist/progress-bar/progress-bar.js +0 -111
  307. package/dist/proxy-attrs/proxy-attrs.js +0 -19
  308. package/dist/query-assist/query-assist.js +0 -1023
  309. package/dist/query-assist/query-assist__suggestions.js +0 -43
  310. package/dist/radio/radio.js +0 -39
  311. package/dist/radio/radio__item.js +0 -82
  312. package/dist/select/select.js +0 -1335
  313. package/dist/select/select__filter.js +0 -49
  314. package/dist/select/select__popup.js +0 -541
  315. package/dist/shortcuts/core.js +0 -245
  316. package/dist/shortcuts/shortcut-title.js +0 -51
  317. package/dist/shortcuts/shortcuts-hoc.js +0 -43
  318. package/dist/shortcuts/shortcuts.js +0 -72
  319. package/dist/storage/storage.js +0 -55
  320. package/dist/storage/storage__fallback.js +0 -214
  321. package/dist/storage/storage__local.js +0 -150
  322. package/dist/style.css +0 -1
  323. package/dist/tab-trap/tab-trap.js +0 -178
  324. package/dist/table/cell.js +0 -25
  325. package/dist/table/disable-hover-hoc.js +0 -53
  326. package/dist/table/header-cell.js +0 -91
  327. package/dist/table/header.js +0 -189
  328. package/dist/table/multitable.js +0 -140
  329. package/dist/table/row-with-focus-sensor.js +0 -79
  330. package/dist/table/row.js +0 -270
  331. package/dist/table/selection-adapter.js +0 -14
  332. package/dist/table/selection-shortcuts-hoc.js +0 -212
  333. package/dist/table/selection.js +0 -221
  334. package/dist/table/smart-table.js +0 -113
  335. package/dist/table/table.js +0 -405
  336. package/dist/tabs/collapsible-more.js +0 -193
  337. package/dist/tabs/collapsible-tab.js +0 -90
  338. package/dist/tabs/collapsible-tabs.js +0 -361
  339. package/dist/tabs/custom-item.js +0 -13
  340. package/dist/tabs/dumb-tabs.js +0 -159
  341. package/dist/tabs/smart-tabs.js +0 -102
  342. package/dist/tabs/tab-link.js +0 -35
  343. package/dist/tabs/tab.js +0 -32
  344. package/dist/tabs/tabs.js +0 -65
  345. package/dist/tag/tag.js +0 -190
  346. package/dist/tags-input/tags-input.js +0 -474
  347. package/dist/tags-list/tags-list.js +0 -94
  348. package/dist/text/text.js +0 -38
  349. package/dist/toggle/toggle.js +0 -80
  350. package/dist/tooltip/tooltip.js +0 -205
  351. package/dist/user-card/card.js +0 -14
  352. package/dist/user-card/smart-user-card-tooltip.js +0 -112
  353. package/dist/user-card/tooltip.js +0 -91
  354. package/dist/user-card/user-card.js +0 -46
@@ -1,474 +0,0 @@
1
- import { _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import React, { PureComponent, Component } from 'react';
3
- import PropTypes from 'prop-types';
4
- import classNames from 'classnames';
5
- import getEventKey from '../global/get-event-key.js';
6
- import Select from '../select/select.js';
7
- import TagsList from '../tags-list/tags-list.js';
8
- import Caret from '../caret/caret.js';
9
- import memoize from '../global/memoize.js';
10
- import rerenderHOC from '../global/rerender-hoc.js';
11
- import '@jetbrains/icons/chevron-10px';
12
- import '@jetbrains/icons/close';
13
- import 'deep-equal';
14
- import '../dropdown/dropdown.js';
15
- import '../global/data-tests.js';
16
- import '../_helpers/anchor.js';
17
- import '../icon/icon.js';
18
- import 'util-deprecate';
19
- import '../icon/icon__constants.js';
20
- import '../_helpers/icon__svg.js';
21
- import '../button/button.js';
22
- import 'focus-visible';
23
- import '../global/theme.js';
24
- import '../link/clickableLink.js';
25
- import '../_helpers/button__classes.js';
26
- import '../avatar/avatar.js';
27
- import '../global/url.js';
28
- import '../global/dom.js';
29
- import '../popup/popup.js';
30
- import 'react-dom';
31
- import '../global/get-uid.js';
32
- import '../global/schedule-raf.js';
33
- import '../shortcuts/shortcuts.js';
34
- import '../shortcuts/core.js';
35
- import 'combokeys';
36
- import '../global/sniffer.js';
37
- import 'sniffr';
38
- import '../tab-trap/tab-trap.js';
39
- import '../popup/position.js';
40
- import '../popup/popup.consts.js';
41
- import '../popup/popup.target.js';
42
- import '../list/list.js';
43
- import 'react-virtualized/dist/es/List';
44
- import 'react-virtualized/dist/es/AutoSizer';
45
- import 'react-virtualized/dist/es/WindowScroller';
46
- import 'react-virtualized/dist/es/CellMeasurer';
47
- import 'memoize-one';
48
- import '../global/create-stateful-context.js';
49
- import '../list/list__link.js';
50
- import '../link/link.js';
51
- import '../_helpers/list.js';
52
- import '../list/list__item.js';
53
- import '../checkbox/checkbox.js';
54
- import '@jetbrains/icons/checkmark';
55
- import '@jetbrains/icons/remove-10px';
56
- import '../list/list__custom.js';
57
- import '../list/list__title.js';
58
- import '../list/list__separator.js';
59
- import '../list/list__hint.js';
60
- import '../list/consts.js';
61
- import '../input/input.js';
62
- import '../global/fuzzy-highlight.js';
63
- import '../select/select__popup.js';
64
- import '@jetbrains/icons/search';
65
- import '../loader-inline/loader-inline.js';
66
- import '../_helpers/inject-styles.js';
67
- import '../global/conic-gradient.js';
68
- import 'conic-gradient';
69
- import '../global/supports-css.js';
70
- import '../global/inject-styles.js';
71
- import '../global/radial-gradient-mask.js';
72
- import '../shortcuts/shortcuts-hoc.js';
73
- import '../text/text.js';
74
- import '../_helpers/select__filter.js';
75
- import '../tag/tag.js';
76
-
77
- var modules_5aa8aaf3 = {"tagsInput":"tagsInput_tagsInput__3bf16b19","tagsInputLegacyMode":"tagsInput_tagsInputLegacyMode__3bf16b19","tagsList":"tagsInput_tagsList__3bf16b19","tag":"tagsInput_tag__3bf16b19","tagsInputDisabled":"tagsInput_tagsInputDisabled__3bf16b19","underline":"tagsInput_underline__3bf16b19","tagsInputFocused":"tagsInput_tagsInputFocused__3bf16b19","tagsSelect":"tagsInput_tagsSelect__3bf16b19","focusUnderline":"tagsInput_focusUnderline__3bf16b19"};
78
-
79
- function noop() {}
80
- /**
81
- * @name Tags Input
82
- */
83
-
84
-
85
- const POPUP_VERTICAL_SHIFT = 2;
86
- class TagsInput extends PureComponent {
87
- constructor() {
88
- var _this;
89
-
90
- super(...arguments);
91
- _this = this;
92
-
93
- _defineProperty(this, "state", {
94
- tags: [],
95
- prevTags: null,
96
- suggestions: [],
97
- loading: true,
98
- focused: false,
99
- query: '',
100
- activeIndex: 0
101
- });
102
-
103
- _defineProperty(this, "nodeRef", node => {
104
- this.node = node;
105
- });
106
-
107
- _defineProperty(this, "ngModelStateField", TagsInput.ngModelStateField);
108
-
109
- _defineProperty(this, "focusInput", () => {
110
- this.getInputNode().focus();
111
- });
112
-
113
- _defineProperty(this, "addTag", tag => {
114
- const isUniqueTag = this.state.tags.filter(item => tag.key === item.key).length === 0;
115
- this.select.clear();
116
- this.select.filterValue('');
117
-
118
- if (isUniqueTag) {
119
- this.setState(prevState => ({
120
- tags: prevState.tags.concat([tag])
121
- }));
122
- this.props.onAddTag({
123
- tag
124
- });
125
- this.setActiveIndex();
126
- }
127
- });
128
-
129
- _defineProperty(this, "clickHandler", event => {
130
- if (event.target !== this.node) {
131
- return;
132
- }
133
-
134
- this.loadSuggestions(this.getInputNode().value);
135
- this.focusInput();
136
- });
137
-
138
- _defineProperty(this, "filterExistingTags", suggestions => {
139
- const tagsMap = new Map(this.state.tags.map(tag => [tag.key, tag]));
140
- return suggestions.filter(suggestion => !tagsMap.has(suggestion.key));
141
- });
142
-
143
- _defineProperty(this, "loadSuggestions", function () {
144
- let query = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
145
- return _this.setState({
146
- loading: true,
147
- query
148
- }, async () => {
149
- try {
150
- let allSuggestions = _this.props.dataSource({
151
- query
152
- });
153
-
154
- if (typeof allSuggestions.then === 'function') {
155
- allSuggestions = await allSuggestions;
156
- }
157
-
158
- const suggestions = _this.filterExistingTags(allSuggestions);
159
-
160
- if (_this.node && query === _this.state.query) {
161
- _this.setState({
162
- suggestions,
163
- loading: false
164
- });
165
- }
166
- } catch (e) {
167
- _this.setState({
168
- loading: false
169
- });
170
- }
171
- });
172
- });
173
-
174
- _defineProperty(this, "_focusHandler", () => {
175
- this.setActiveIndex(null);
176
- this.setState({
177
- focused: true
178
- });
179
- });
180
-
181
- _defineProperty(this, "_blurHandler", () => {
182
- this.setState({
183
- focused: false
184
- });
185
- });
186
-
187
- _defineProperty(this, "selectTag", moveForward => {
188
- const activeIndex = typeof this.state.activeIndex === 'number' ? this.state.activeIndex : this.state.tags.length + 1;
189
- let newActiveIndex = activeIndex + (moveForward ? 1 : -1);
190
-
191
- if (newActiveIndex >= this.state.tags.length) {
192
- newActiveIndex = this.state.tags.length - 1;
193
- } else if (newActiveIndex < 0) {
194
- newActiveIndex = 0;
195
- }
196
-
197
- if (this.state.activeIndex !== newActiveIndex) {
198
- this.setActiveIndex(newActiveIndex);
199
- }
200
- });
201
-
202
- _defineProperty(this, "handleKeyDown", event => {
203
- const key = getEventKey(event);
204
-
205
- const isInputFocused = () => event.target.matches(this.getInputNode().tagName);
206
-
207
- if (key === ' ' && this.props.allowAddNewTags) {
208
- event.stopPropagation();
209
- const value = this.getInputNode().value;
210
-
211
- if (value !== '') {
212
- this.handleTagCreation(value);
213
- }
214
-
215
- return true;
216
- }
217
-
218
- if (this.select._popup.isVisible()) {
219
- return true;
220
- }
221
-
222
- if (key === 'ArrowLeft') {
223
- if (this.getInputNode() && this.caret.getPosition() > 0) {
224
- return true;
225
- }
226
-
227
- this.selectTag();
228
- return false;
229
- }
230
-
231
- if (key === 'ArrowRight' && !isInputFocused()) {
232
- if (this.state.activeIndex === this.state.tags.length - 1) {
233
- if (!this.props.disabled) {
234
- this.getInputNode().focus();
235
- this.setActiveIndex();
236
- }
237
- } else {
238
- this.selectTag(true);
239
- }
240
-
241
- return false;
242
- }
243
-
244
- if (!this.props.disabled) {
245
- if (key === 'Backspace' && !this.getInputNode().value) {
246
- event.preventDefault();
247
- const tagsLength = this.state.tags.length;
248
-
249
- this.select._hidePopup(true); // otherwise confirmation may be overlapped by popup
250
-
251
-
252
- this.onRemoveTag(this.state.tags[tagsLength - 1]);
253
- return false;
254
- }
255
-
256
- if ((key === 'Delete' || key === 'Backspace') && this.state.tags[this.state.activeIndex]) {
257
- this.onRemoveTag(this.state.tags[this.state.activeIndex]).then(() => this.selectTag(true));
258
- return false;
259
- }
260
- }
261
-
262
- return true;
263
- });
264
-
265
- _defineProperty(this, "handleClick", memoize(tag => () => {
266
- this.setActiveIndex(this.state.tags.indexOf(tag));
267
- }));
268
-
269
- _defineProperty(this, "handleRemove", memoize(tag => () => this.onRemoveTag(tag)));
270
-
271
- _defineProperty(this, "handleTagCreation", label => {
272
- this.addTag({
273
- key: label,
274
- label
275
- });
276
- });
277
-
278
- _defineProperty(this, "selectRef", el => {
279
- this.select = el;
280
- });
281
- }
282
-
283
- static getDerivedStateFromProps(_ref, _ref2) {
284
- let {
285
- tags
286
- } = _ref;
287
- let {
288
- prevTags
289
- } = _ref2;
290
- const nextState = {
291
- prevTags: tags
292
- };
293
-
294
- if (tags != null && tags !== prevTags) {
295
- Object.assign(nextState, {
296
- tags,
297
- activeIndex: tags.length
298
- });
299
- }
300
-
301
- return nextState;
302
- }
303
-
304
- componentDidMount() {
305
- if (this.props.autoOpen && !this.props.disabled) {
306
- this.focusInput();
307
- this.loadSuggestions();
308
-
309
- this.select._showPopup();
310
- }
311
- }
312
-
313
- getInputNode() {
314
- if (!this.input) {
315
- this.input = this.select.filter;
316
- this.caret = new Caret(this.input);
317
- }
318
-
319
- return this.input;
320
- }
321
-
322
- setActiveIndex(activeIndex) {
323
- this.setState({
324
- activeIndex
325
- });
326
- }
327
-
328
- onRemoveTag(tagToRemove) {
329
- return Promise.resolve(this.props.onRemoveTag({
330
- tag: tagToRemove
331
- })).then(() => {
332
- const tags = this.state.tags.filter(tag => tag !== tagToRemove);
333
-
334
- if (this.node) {
335
- this.setState({
336
- tags
337
- });
338
- this.focusInput();
339
- }
340
-
341
- return tags;
342
- }, this.focusInput);
343
- }
344
-
345
- render() {
346
- const {
347
- focused,
348
- tags,
349
- activeIndex
350
- } = this.state;
351
- const {
352
- legacyMode,
353
- disabled,
354
- canNotBeEmpty,
355
- allowAddNewTags,
356
- filter
357
- } = this.props;
358
- const classes = classNames(modules_5aa8aaf3.tagsInput, {
359
- [modules_5aa8aaf3.tagsInputDisabled]: disabled,
360
- [modules_5aa8aaf3.tagsInputFocused]: focused,
361
- [modules_5aa8aaf3.tagsInputLegacyMode]: legacyMode
362
- }, this.props.className);
363
- return /*#__PURE__*/React.createElement("div", {
364
- // it transfers focus to input
365
- role: "presentation",
366
- className: classes,
367
- onKeyDown: this.handleKeyDown,
368
- onClick: this.clickHandler,
369
- ref: this.nodeRef
370
- }, /*#__PURE__*/React.createElement(TagsList, {
371
- tags: tags,
372
- activeIndex: activeIndex,
373
- disabled: disabled,
374
- canNotBeEmpty: canNotBeEmpty,
375
- handleRemove: this.handleRemove,
376
- className: modules_5aa8aaf3.tagsList,
377
- tagClassName: modules_5aa8aaf3.tag,
378
- handleClick: this.handleClick
379
- }, /*#__PURE__*/React.createElement(Select, {
380
- ref: this.selectRef,
381
- size: Select.Size.AUTO,
382
- type: Select.Type.INPUT_WITHOUT_CONTROLS,
383
- inputPlaceholder: this.props.placeholder,
384
- data: this.state.suggestions,
385
- className: classNames(modules_5aa8aaf3.tagsSelect),
386
- onSelect: this.addTag,
387
- onFocus: this._focusHandler,
388
- onBlur: this._blurHandler,
389
- renderOptimization: this.props.renderOptimization,
390
- add: allowAddNewTags ? {
391
- prefix: 'Add new tag'
392
- } : undefined,
393
- onAdd: allowAddNewTags ? this.handleTagCreation : undefined,
394
- filter: filter,
395
- maxHeight: this.props.maxPopupHeight,
396
- minWidth: this.props.minPopupWidth,
397
- top: POPUP_VERTICAL_SHIFT,
398
- loading: this.state.loading,
399
- onFilter: this.loadSuggestions,
400
- onBeforeOpen: this.loadSuggestions,
401
- onKeyDown: this.handleKeyDown,
402
- disabled: this.props.disabled,
403
- loadingMessage: this.props.loadingMessage,
404
- notFoundMessage: this.props.notFoundMessage
405
- })), !legacyMode && /*#__PURE__*/React.createElement("div", {
406
- className: modules_5aa8aaf3.underline
407
- }), !legacyMode && /*#__PURE__*/React.createElement("div", {
408
- className: modules_5aa8aaf3.focusUnderline
409
- }));
410
- }
411
-
412
- }
413
-
414
- _defineProperty(TagsInput, "propTypes", {
415
- className: PropTypes.string,
416
- tags: PropTypes.array,
417
-
418
- /**
419
- * Datasource should return array(or promise) of suggestions.
420
- * Each suggestion should contain key and label fields.
421
- * DataSource should handle caching and response racing (when later request
422
- * responded earlier) by himself.
423
- */
424
- dataSource: PropTypes.func,
425
- onAddTag: PropTypes.func,
426
- onRemoveTag: PropTypes.func,
427
- customTagComponent: (props, propName, componentName) => {
428
- if (props[propName] && !props[propName].prototype instanceof Component) {
429
- return new Error(`Invalid prop ${propName} supplied to ${componentName}. Validation failed.`);
430
- }
431
-
432
- return null;
433
- },
434
- maxPopupHeight: PropTypes.number,
435
- minPopupWidth: PropTypes.number,
436
- placeholder: PropTypes.string,
437
- canNotBeEmpty: PropTypes.bool,
438
- disabled: PropTypes.bool,
439
- autoOpen: PropTypes.bool,
440
- renderOptimization: PropTypes.bool,
441
- legacyMode: PropTypes.bool,
442
- filter: PropTypes.oneOfType([PropTypes.bool, PropTypes.shape({
443
- fn: PropTypes.func
444
- })]),
445
- loadingMessage: PropTypes.string,
446
- notFoundMessage: PropTypes.string,
447
- allowAddNewTags: PropTypes.bool
448
- });
449
-
450
- _defineProperty(TagsInput, "defaultProps", {
451
- dataSource: noop,
452
- onAddTag: noop,
453
- onRemoveTag: noop,
454
- customTagComponent: null,
455
- maxPopupHeight: 500,
456
- minPopupWidth: 360,
457
- canNotBeEmpty: false,
458
- disabled: false,
459
- autoOpen: false,
460
- renderOptimization: true,
461
- legacyMode: false,
462
- allowAddNewTags: false,
463
- filter: {
464
- fn: () => true
465
- },
466
- placeholder: 'Select an option'
467
- });
468
-
469
- _defineProperty(TagsInput, "ngModelStateField", 'tags');
470
-
471
- const RerenderableTagsInput = rerenderHOC(TagsInput);
472
-
473
- export default TagsInput;
474
- export { RerenderableTagsInput };
@@ -1,94 +0,0 @@
1
- import { b as _extends, a as _objectWithoutProperties, _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import React, { Component } from 'react';
3
- import PropTypes from 'prop-types';
4
- import classNames from 'classnames';
5
- import Tag from '../tag/tag.js';
6
- import '@jetbrains/icons/close';
7
- import '../icon/icon.js';
8
- import 'util-deprecate';
9
- import '../icon/icon__constants.js';
10
- import '../_helpers/icon__svg.js';
11
- import '../global/memoize.js';
12
- import '../button/button.js';
13
- import 'focus-visible';
14
- import '@jetbrains/icons/chevron-10px';
15
- import '../global/theme.js';
16
- import '../link/clickableLink.js';
17
- import '../_helpers/button__classes.js';
18
-
19
- function noop() {}
20
- /**
21
- * @name Tags List
22
- */
23
-
24
-
25
- class TagsList extends Component {
26
- renderTag(tag, focusTag) {
27
- const TagComponent = this.props.customTagComponent || Tag;
28
- const readOnly = this.props.disabled || tag.readOnly || this.props.canNotBeEmpty && this.props.tags.length === 1;
29
- const {
30
- tagClassName
31
- } = this.props;
32
- return /*#__PURE__*/React.createElement(TagComponent, _extends({}, tag, {
33
- readOnly: readOnly,
34
- disabled: this.props.disabled || tag.disabled,
35
- focused: focusTag,
36
- onClick: this.props.handleClick(tag),
37
- onRemove: this.props.handleRemove(tag),
38
- className: tagClassName
39
- }), tag.label);
40
- }
41
-
42
- render() {
43
- const _this$props = this.props,
44
- {
45
- children,
46
- className,
47
- customTagComponent,
48
- canNotBeEmpty,
49
- handleClick,
50
- tagClassName,
51
- handleRemove,
52
- tags,
53
- activeIndex
54
- } = _this$props,
55
- props = _objectWithoutProperties(_this$props, ["children", "className", "customTagComponent", "canNotBeEmpty", "handleClick", "tagClassName", "handleRemove", "tags", "activeIndex"]);
56
-
57
- const classes = classNames('ring-js-shortcuts', className);
58
- const tagsList = (this.props.tags || []).map((tag, index) => this.renderTag(tag, this.props.activeIndex === index));
59
- return /*#__PURE__*/React.createElement("div", _extends({
60
- "data-test": "ring-tags-list",
61
- className: classes
62
- }, props), tagsList, children);
63
- }
64
-
65
- }
66
-
67
- _defineProperty(TagsList, "propTypes", {
68
- children: PropTypes.node,
69
- tags: PropTypes.array,
70
- customTagComponent: (props, propName, componentName) => {
71
- if (props[propName] && !props[propName].prototype instanceof Component) {
72
- return new Error(`Invalid prop ${propName} supplied to ${componentName}. Validation failed.`);
73
- }
74
-
75
- return null;
76
- },
77
- activeIndex: PropTypes.number,
78
- canNotBeEmpty: PropTypes.bool,
79
- disabled: PropTypes.bool,
80
- handleClick: PropTypes.func,
81
- handleRemove: PropTypes.func,
82
- className: PropTypes.string,
83
- tagClassName: PropTypes.string
84
- });
85
-
86
- _defineProperty(TagsList, "defaultProps", {
87
- customTagComponent: null,
88
- canNotBeEmpty: false,
89
- disabled: false,
90
- handleClick: noop,
91
- handleRemove: noop
92
- });
93
-
94
- export default TagsList;
package/dist/text/text.js DELETED
@@ -1,38 +0,0 @@
1
- import { a as _objectWithoutProperties, b as _extends, _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import React, { Component } from 'react';
3
- import PropTypes from 'prop-types';
4
- import classNames from 'classnames';
5
-
6
- var modules_78d1bce6 = {"text":"text_text__bc47c17b","info":"text_info__bc47c17b"};
7
-
8
- /**
9
- * @name Text
10
- */
11
-
12
- class Text extends Component {
13
- render() {
14
- const _this$props = this.props,
15
- {
16
- children,
17
- className,
18
- info
19
- } = _this$props,
20
- restProps = _objectWithoutProperties(_this$props, ["children", "className", "info"]);
21
-
22
- const classes = classNames(modules_78d1bce6.text, className, {
23
- [modules_78d1bce6.info]: info
24
- });
25
- return /*#__PURE__*/React.createElement("span", _extends({
26
- className: classes
27
- }, restProps), children);
28
- }
29
-
30
- }
31
-
32
- _defineProperty(Text, "propTypes", {
33
- children: PropTypes.node,
34
- info: PropTypes.bool,
35
- className: PropTypes.string
36
- });
37
-
38
- export default Text;
@@ -1,80 +0,0 @@
1
- import { a as _objectWithoutProperties, b as _extends, _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import React, { PureComponent } from 'react';
3
- import PropTypes from 'prop-types';
4
- import classNames from 'classnames';
5
- import { withTheme } from '../global/theme.js';
6
- import joinDataTestAttributes from '../global/data-tests.js';
7
-
8
- var modules_331c5aa7 = {"unit":"8px","padding":"2px","disabled-line-color":"hsla(0,0%,100%,.9)","duration":".3s","timing-function":"cubic-bezier(.23,1,.32,1)","toggle":"toggle_toggle__ca2e3a7a","switch":"toggle_switch__ca2e3a7a","disabled":"toggle_disabled__ca2e3a7a","label":"toggle_label__ca2e3a7a","leftLabel":"toggle_leftLabel__ca2e3a7a","light":"toggle_light__ca2e3a7a","dark":"toggle_dark__ca2e3a7a","switchWrapper":"toggle_switchWrapper__ca2e3a7a","input":"toggle_input__ca2e3a7a","size20":"toggle_size20__ca2e3a7a","paleSwitch":"toggle_paleSwitch__ca2e3a7a"};
9
-
10
- const Size = {
11
- Size16: modules_331c5aa7.size16,
12
- Size20: modules_331c5aa7.size20
13
- };
14
- /**
15
- * @name Toggle
16
- */
17
-
18
- class Toggle extends PureComponent {
19
- render() {
20
- const _this$props = this.props,
21
- {
22
- className,
23
- children,
24
- disabled,
25
- pale,
26
- title,
27
- leftLabel,
28
- theme,
29
- size = Size.Size16,
30
- 'data-test': dataTest,
31
- onTransitionEnd
32
- } = _this$props,
33
- restProps = _objectWithoutProperties(_this$props, ["className", "children", "disabled", "pale", "title", "leftLabel", "theme", "size", "data-test", "onTransitionEnd"]);
34
-
35
- const classes = classNames(className, size, modules_331c5aa7.toggle, modules_331c5aa7[theme], disabled && modules_331c5aa7.disabled);
36
- return /*#__PURE__*/React.createElement("label", {
37
- className: classes,
38
- title: title,
39
- "data-test": joinDataTestAttributes('ring-toggle', dataTest)
40
- }, leftLabel && /*#__PURE__*/React.createElement("span", {
41
- className: modules_331c5aa7.leftLabel
42
- }, leftLabel), /*#__PURE__*/React.createElement("span", {
43
- className: modules_331c5aa7.switchWrapper
44
- }, /*#__PURE__*/React.createElement("input", _extends({
45
- "data-test": "ring-toggle-input"
46
- }, restProps, {
47
- type: "checkbox",
48
- disabled: disabled,
49
- className: modules_331c5aa7.input
50
- })), /*#__PURE__*/React.createElement("span", {
51
- className: classNames(modules_331c5aa7.switch, pale && modules_331c5aa7.paleSwitch),
52
- onTransitionEnd: onTransitionEnd
53
- })), children && /*#__PURE__*/React.createElement("span", {
54
- className: modules_331c5aa7.label
55
- }, children));
56
- }
57
-
58
- }
59
-
60
- _defineProperty(Toggle, "propTypes", {
61
- children: PropTypes.node,
62
- name: PropTypes.string,
63
- className: PropTypes.string,
64
- title: PropTypes.string,
65
- leftLabel: PropTypes.node,
66
- defaultChecked: PropTypes.bool,
67
- checked: PropTypes.bool,
68
- disabled: PropTypes.bool,
69
- pale: PropTypes.bool,
70
- onChange: PropTypes.func,
71
- onTransitionEnd: PropTypes.func,
72
- theme: PropTypes.string,
73
- size: PropTypes.oneOf(Object.values(Size)),
74
- 'data-test': PropTypes.string
75
- });
76
-
77
- var toggle = withTheme()(Toggle);
78
-
79
- export default toggle;
80
- export { Size };