@jetbrains/ring-ui 4.1.0-beta.4 → 4.1.2

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 (455) 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/alert.test.js +21 -48
  6. package/components/alert/container.css +1 -1
  7. package/components/alert/container.test.js +3 -13
  8. package/components/alert-service/alert-service.examples.css +18 -0
  9. package/components/alert-service/alert-service.examples.js +21 -0
  10. package/components/alert-service/alert-service.js +10 -3
  11. package/components/analytics/analytics__fus-plugin.js +3 -3
  12. package/components/analytics/analytics__ga-plugin.js +2 -2
  13. package/components/auth/auth.test.js +14 -7
  14. package/components/auth/auth__core.js +64 -33
  15. package/components/auth-dialog/auth-dialog.css +2 -3
  16. package/components/auth-dialog/auth-dialog.js +4 -1
  17. package/components/auth-dialog/auth-dialog.test.js +3 -19
  18. package/components/avatar/avatar.css +4 -1
  19. package/components/avatar/avatar.examples.js +3 -2
  20. package/components/avatar/avatar.js +34 -6
  21. package/components/avatar/avatar.test.js +20 -17
  22. package/components/avatar/fallback-avatar.js +136 -0
  23. package/components/avatar-editor-ng/avatar-editor-ng.css +2 -2
  24. package/components/avatar-editor-ng/avatar-editor-ng.js +2 -1
  25. package/components/avatar-editor-ng/{avatar-editor-ng.html → avatar-editor-ng__template.js} +2 -2
  26. package/components/badge/badge.test.js +13 -20
  27. package/components/button/button.css +2 -2
  28. package/components/button/button.js +4 -1
  29. package/components/button/button.test.js +32 -33
  30. package/components/button-group/button-group.js +1 -1
  31. package/components/button-group/caption.js +1 -1
  32. package/components/button-ng/button-ng.js +1 -1
  33. package/components/button-set-ng/button-set-ng.js +3 -1
  34. package/components/checkbox/checkbox.css +1 -1
  35. package/components/code/code.js +2 -5
  36. package/components/confirm/confirm.js +1 -0
  37. package/components/confirm-service/confirm-service.js +5 -5
  38. package/components/content-layout/content-layout.css +1 -1
  39. package/components/data-list/data-list.css +1 -1
  40. package/components/date-picker/date-input.js +5 -4
  41. package/components/date-picker/date-picker.css +34 -22
  42. package/components/date-picker/date-picker.js +16 -14
  43. package/components/date-picker/date-popup.js +22 -7
  44. package/components/date-picker/month-names.js +8 -5
  45. package/components/date-picker/month.js +6 -2
  46. package/components/date-picker/weekdays.js +10 -2
  47. package/components/dialog/dialog.examples.js +3 -1
  48. package/components/dialog/dialog.js +10 -5
  49. package/components/dialog/dialog.test.js +1 -1
  50. package/components/dialog/dialog__body-scroll-preventer.js +51 -31
  51. package/components/dialog-ng/dialog-ng.js +10 -10
  52. package/components/dialog-ng/{dialog-ng.html → dialog-ng__template.js} +2 -2
  53. package/components/dropdown/dropdown.examples.js +36 -1
  54. package/components/dropdown/dropdown.test.js +2 -2
  55. package/components/dropdown-menu/dropdown-menu.examples.js +47 -0
  56. package/components/dropdown-menu/dropdown-menu.js +117 -0
  57. package/components/dropdown-menu/dropdown-menu.test.js +76 -0
  58. package/components/error-bubble/error-bubble-legacy.css +1 -1
  59. package/components/error-bubble/error-bubble.css +1 -1
  60. package/components/error-bubble/error-bubble.examples.js +1 -1
  61. package/components/error-page/error-page.css +2 -2
  62. package/components/footer-ng/footer-ng.js +13 -3
  63. package/components/form/form.css +2 -2
  64. package/components/form-ng/form-ng.js +3 -1
  65. package/components/global/global.css +1 -1
  66. package/components/global/theme.js +1 -1
  67. package/components/global/variables.css +8 -1
  68. package/components/grid/grid.css +10 -9
  69. package/components/header/header.css +1 -1
  70. package/components/header/header.examples.js +7 -8
  71. package/components/header/profile.js +10 -11
  72. package/components/http/http.js +1 -1
  73. package/components/icon/icon.css +5 -4
  74. package/components/input/input-legacy.css +7 -7
  75. package/components/island/header.js +2 -2
  76. package/components/island/island.css +8 -3
  77. package/components/island-legacy/island-legacy.css +3 -1
  78. package/components/list/list.js +6 -1
  79. package/components/list/list__custom.js +9 -3
  80. package/components/list/list__item.js +8 -2
  81. package/components/list/list__link.js +2 -1
  82. package/components/loader-inline/loader-inline.css +1 -1
  83. package/components/loader-screen/loader-screen.css +1 -1
  84. package/components/message/message.css +1 -1
  85. package/components/message/message.examples.js +8 -7
  86. package/components/pager/pager.js +5 -3
  87. package/components/permissions/permissions.js +1 -1
  88. package/components/popup/popup.js +1 -1
  89. package/components/popup/popup.test.js +15 -13
  90. package/components/progress-bar/progress-bar.css +1 -1
  91. package/components/progress-bar/progress-bar.examples.js +3 -3
  92. package/components/progress-bar/progress-bar.js +5 -2
  93. package/components/progress-bar/progress-bar.test.js +12 -13
  94. package/components/progress-bar-ng/progress-bar-ng.examples.js +3 -3
  95. package/components/query-assist/query-assist.css +13 -3
  96. package/components/query-assist/query-assist.examples.js +3 -4
  97. package/components/query-assist/query-assist.js +56 -12
  98. package/components/query-assist/query-assist.test.js +37 -5
  99. package/components/save-field-ng/save-field-ng.css +0 -3
  100. package/components/save-field-ng/save-field-ng.js +3 -1
  101. package/components/save-field-ng/{save-field-ng.html → save-field-ng__template.js} +2 -2
  102. package/components/select/select.css +12 -7
  103. package/components/select/select.examples.js +13 -0
  104. package/components/select/select.js +30 -43
  105. package/components/select/select.test.js +4 -5
  106. package/components/select/select__popup.js +1 -0
  107. package/components/shortcuts-hint-ng/shortcuts-hint-ng.css +1 -1
  108. package/components/shortcuts-hint-ng/shortcuts-hint-ng.js +1 -1
  109. package/components/shortcuts-hint-ng/{shortcuts-hint-ng.html → shortcuts-hint-ng__template.js} +2 -2
  110. package/components/sidebar/sidebar.css +1 -0
  111. package/components/sidebar-ng/sidebar-ng.js +6 -2
  112. package/components/sidebar-ng/{sidebar-ng__button.html → sidebar-ng__button-template.js} +2 -2
  113. package/components/sidebar-ng/{sidebar-ng.html → sidebar-ng__template.js} +2 -2
  114. package/components/table/header.js +9 -1
  115. package/components/table/row.js +2 -1
  116. package/components/table/table.css +2 -1
  117. package/components/table-legacy/table-legacy.css +2 -2
  118. package/components/table-legacy/table-legacy__toolbar.css +2 -2
  119. package/components/table-legacy-ng/table-legacy-ng.js +38 -5
  120. package/components/table-legacy-ng/table-legacy-ng__pager.js +7 -1
  121. package/components/tabs/collapsible-tab.js +2 -2
  122. package/components/tabs/collapsible-tabs.js +5 -9
  123. package/components/tabs/tab-link.js +4 -2
  124. package/components/tabs/tabs.css +32 -5
  125. package/components/tabs-ng/tabs-ng.js +4 -2
  126. package/components/tabs-ng/{tabs-ng.html → tabs-ng__template.js} +6 -2
  127. package/components/tag/tag.css +5 -2
  128. package/components/tag/tag.examples.js +3 -0
  129. package/components/tag/tag.js +19 -16
  130. package/components/tags-input/tag-input.examples.js +1 -1
  131. package/components/tags-input/tags-input.js +5 -2
  132. package/components/template-ng/template-ng.js +1 -1
  133. package/components/tooltip/tooltip.js +7 -2
  134. package/components/user-agreement/user-agreement.css +1 -5
  135. package/components/user-agreement/user-agreement.examples.js +7 -6
  136. package/components/user-agreement/user-agreement.js +11 -3
  137. package/dist/_helpers/_rollupPluginBabelHelpers.js +1 -90
  138. package/dist/_helpers/anchor.js +6 -7
  139. package/dist/_helpers/badge.js +1 -1
  140. package/dist/_helpers/button-group.js +3 -0
  141. package/dist/_helpers/button-set.js +3 -0
  142. package/dist/_helpers/button-toolbar.js +3 -0
  143. package/dist/_helpers/button__classes.js +16 -15
  144. package/dist/_helpers/card.js +6 -8
  145. package/dist/_helpers/checkbox.js +3 -0
  146. package/dist/_helpers/date-picker.js +1 -1
  147. package/dist/_helpers/dialog__body-scroll-preventer.js +49 -32
  148. package/dist/_helpers/error-message.js +3 -0
  149. package/dist/_helpers/footer.js +121 -0
  150. package/dist/_helpers/grid.js +1 -1
  151. package/dist/_helpers/group.js +3 -0
  152. package/dist/_helpers/header.js +1 -1
  153. package/dist/_helpers/icon.js +3 -0
  154. package/dist/_helpers/inject-styles.js +1 -1
  155. package/dist/_helpers/input.js +3 -0
  156. package/dist/_helpers/island.js +1 -1
  157. package/dist/_helpers/link.js +3 -0
  158. package/dist/_helpers/list.js +1 -1
  159. package/dist/_helpers/loader-screen.js +3 -0
  160. package/dist/_helpers/panel.js +3 -0
  161. package/dist/_helpers/query-assist__suggestions.js +1 -1
  162. package/dist/_helpers/radio.js +3 -0
  163. package/dist/_helpers/select__filter.js +8 -10
  164. package/dist/_helpers/services-link.js +6 -8
  165. package/dist/_helpers/sidebar.js +17 -17
  166. package/dist/_helpers/table.js +1 -1
  167. package/dist/_helpers/tabs.js +1 -1
  168. package/dist/_helpers/title.js +3 -3
  169. package/dist/alert/alert.js +20 -9
  170. package/dist/alert/container.js +7 -9
  171. package/dist/alert-service/alert-service.js +26 -13
  172. package/dist/analytics/analytics.js +2 -2
  173. package/dist/analytics/analytics__custom-plugin.js +1 -1
  174. package/dist/analytics/analytics__fus-plugin.js +13 -11
  175. package/dist/analytics/analytics__ga-plugin.js +3 -3
  176. package/dist/analytics/analytics__plugin-utils.js +1 -1
  177. package/dist/analytics-ng/analytics-ng.js +94 -0
  178. package/dist/auth/auth.js +7 -4
  179. package/dist/auth/auth__core.js +106 -63
  180. package/dist/auth/background-flow.js +1 -2
  181. package/dist/auth/down-notification.js +19 -12
  182. package/dist/auth/iframe-flow.js +5 -2
  183. package/dist/auth/landing-entry.js +1 -1
  184. package/dist/auth/landing.js +5 -2
  185. package/dist/auth/request-builder.js +1 -1
  186. package/dist/auth/response-parser.js +3 -2
  187. package/dist/auth/storage.js +5 -3
  188. package/dist/auth/token-validator.js +6 -5
  189. package/dist/auth/window-flow.js +1 -1
  190. package/dist/auth-dialog/auth-dialog.js +9 -6
  191. package/dist/auth-dialog-service/auth-dialog-service.js +9 -6
  192. package/dist/auth-ng/auth-ng.js +203 -0
  193. package/dist/auth-ng/auth-ng.mock.js +33 -0
  194. package/dist/autofocus-ng/autofocus-ng.js +50 -0
  195. package/dist/avatar/avatar.js +41 -32
  196. package/dist/avatar/fallback-avatar.js +141 -0
  197. package/dist/avatar-editor-ng/avatar-editor-ng.js +164 -0
  198. package/dist/avatar-editor-ng/avatar-editor-ng__template.js +30 -0
  199. package/dist/avatar-ng/avatar-ng.js +18 -0
  200. package/dist/badge/badge.js +6 -8
  201. package/dist/badge-ng/badge-ng.js +16 -0
  202. package/dist/breadcrumb-ng/breadcrumb-ng.js +61 -0
  203. package/dist/button/button.js +16 -10
  204. package/dist/button-group/button-group.js +4 -4
  205. package/dist/button-group/caption.js +24 -5
  206. package/dist/button-group-ng/button-group-ng.js +38 -0
  207. package/dist/button-ng/button-ng.js +223 -0
  208. package/dist/button-set/button-set.js +3 -4
  209. package/dist/button-set-ng/button-set-ng.js +19 -0
  210. package/dist/button-toolbar/button-toolbar.js +3 -4
  211. package/dist/button-toolbar-ng/button-toolbar-ng.js +23 -0
  212. package/dist/caret/caret.js +4 -2
  213. package/dist/checkbox/checkbox.js +11 -13
  214. package/dist/checkbox-ng/checkbox-ng.js +55 -0
  215. package/dist/code/code.js +136 -0
  216. package/dist/compiler-ng/compiler-ng.js +53 -0
  217. package/dist/confirm/confirm.js +8 -5
  218. package/dist/confirm-ng/confirm-ng.js +66 -0
  219. package/dist/confirm-service/confirm-service.js +21 -18
  220. package/dist/content-layout/content-layout.js +8 -10
  221. package/dist/contenteditable/contenteditable.js +14 -17
  222. package/dist/data-list/data-list.js +12 -9
  223. package/dist/data-list/data-list.mock.js +2 -2
  224. package/dist/data-list/item.js +7 -5
  225. package/dist/data-list/selection.js +7 -3
  226. package/dist/data-list/title.js +3 -1
  227. package/dist/data-list-ng/data-list-ng.js +59 -0
  228. package/dist/date-picker/consts.js +1 -2
  229. package/dist/date-picker/date-input.js +17 -12
  230. package/dist/date-picker/date-picker.js +41 -32
  231. package/dist/date-picker/date-popup.js +51 -28
  232. package/dist/date-picker/day.js +4 -4
  233. package/dist/date-picker/formats.js +1 -1
  234. package/dist/date-picker/month-names.js +18 -11
  235. package/dist/date-picker/month-slider.js +4 -4
  236. package/dist/date-picker/month.js +13 -7
  237. package/dist/date-picker/months.js +3 -3
  238. package/dist/date-picker/weekdays.js +12 -4
  239. package/dist/date-picker/years.js +4 -4
  240. package/dist/dialog/dialog.js +21 -16
  241. package/dist/dialog/dialog__body-scroll-preventer.js +1 -1
  242. package/dist/dialog-ng/dialog-ng.js +601 -0
  243. package/dist/dialog-ng/dialog-ng__template.js +71 -0
  244. package/dist/docked-panel-ng/docked-panel-ng.js +170 -0
  245. package/dist/dropdown/anchor.js +2 -1
  246. package/dist/dropdown/dropdown.js +22 -18
  247. package/dist/dropdown-menu/dropdown-menu.js +175 -0
  248. package/dist/error-bubble/error-bubble.js +7 -9
  249. package/dist/error-message/error-message.js +4 -4
  250. package/dist/error-message-ng/error-message-ng.js +53 -0
  251. package/dist/footer/footer.js +6 -119
  252. package/dist/footer-ng/footer-ng.js +75 -0
  253. package/dist/form-ng/form-ng.js +169 -0
  254. package/dist/global/angular-component-factory.js +6 -4
  255. package/dist/global/compose.js +8 -2
  256. package/dist/global/composeRefs.js +13 -7
  257. package/dist/global/conic-gradient.js +13 -12
  258. package/dist/global/create-stateful-context.js +12 -9
  259. package/dist/global/data-tests.js +10 -3
  260. package/dist/global/dom.js +12 -5
  261. package/dist/global/focus-sensor-hoc.js +20 -19
  262. package/dist/global/fuzzy-highlight.js +10 -6
  263. package/dist/global/get-event-key.js +1 -1
  264. package/dist/global/get-uid.js +1 -1
  265. package/dist/global/inject-styles.js +4 -1
  266. package/dist/global/linear-function.js +1 -2
  267. package/dist/global/listeners.js +1 -1
  268. package/dist/global/memoize.js +3 -2
  269. package/dist/global/normalize-indent.js +1 -1
  270. package/dist/global/promise-with-timeout.js +5 -4
  271. package/dist/global/radial-gradient-mask.js +6 -3
  272. package/dist/global/react-dom-renderer.js +3 -3
  273. package/dist/global/rerender-hoc.js +14 -12
  274. package/dist/global/ring-angular-component.js +6 -2
  275. package/dist/global/schedule-raf.js +1 -1
  276. package/dist/global/sniffer.js +1 -1
  277. package/dist/global/supports-css.js +1 -1
  278. package/dist/global/theme.js +27 -26
  279. package/dist/global/trivial-template-tag.js +6 -2
  280. package/dist/global/url.js +3 -1
  281. package/dist/global/variables_dark.js +1 -1
  282. package/dist/grid/col.js +6 -8
  283. package/dist/grid/grid.js +5 -7
  284. package/dist/grid/row.js +6 -8
  285. package/dist/group/group.js +7 -10
  286. package/dist/group-ng/group-ng.js +11 -0
  287. package/dist/header/header.js +29 -26
  288. package/dist/header/logo.js +8 -9
  289. package/dist/header/profile.js +54 -46
  290. package/dist/header/services-link.js +1 -0
  291. package/dist/header/services.js +23 -19
  292. package/dist/header/smart-profile.js +29 -26
  293. package/dist/header/smart-services.js +12 -11
  294. package/dist/header/tray-icon.js +12 -12
  295. package/dist/header/tray.js +6 -8
  296. package/dist/heading/heading.js +10 -13
  297. package/dist/http/http.js +53 -44
  298. package/dist/http/http.mock.js +4 -4
  299. package/dist/hub-source/hub-source.js +1 -1
  300. package/dist/hub-source/hub-source__user.js +4 -2
  301. package/dist/hub-source/hub-source__users-groups.js +5 -3
  302. package/dist/icon/icon.js +8 -8
  303. package/dist/icon/icon__svg.js +81 -6
  304. package/dist/icon/index.js +2 -1
  305. package/dist/icon-ng/icon-ng.js +89 -0
  306. package/dist/input/input.js +11 -14
  307. package/dist/input-ng/input-ng.js +166 -0
  308. package/dist/island/adaptive-island-hoc.js +10 -9
  309. package/dist/island/content.js +8 -10
  310. package/dist/island/header.js +7 -9
  311. package/dist/island/island.js +6 -9
  312. package/dist/island-legacy/content-legacy.js +6 -8
  313. package/dist/island-legacy/header-legacy.js +6 -8
  314. package/dist/island-legacy/island-legacy.js +6 -8
  315. package/dist/island-ng/island-content-ng.js +56 -0
  316. package/dist/island-ng/island-header-ng.js +32 -0
  317. package/dist/island-ng/island-ng-class-fixer.js +9 -0
  318. package/dist/island-ng/island-ng.js +31 -0
  319. package/dist/link/clickableLink.js +8 -10
  320. package/dist/link/link.js +12 -15
  321. package/dist/link-ng/link-ng.js +25 -0
  322. package/dist/list/list.js +100 -76
  323. package/dist/list/list__custom.js +15 -12
  324. package/dist/list/list__hint.js +1 -1
  325. package/dist/list/list__item.js +22 -15
  326. package/dist/list/list__link.js +11 -12
  327. package/dist/list/list__separator.js +1 -1
  328. package/dist/list/list__title.js +1 -1
  329. package/dist/list/list__users-groups-source.js +13 -8
  330. package/dist/loader/loader.js +8 -10
  331. package/dist/loader/loader__core.js +9 -8
  332. package/dist/loader-inline/inject-styles.js +1 -1
  333. package/dist/loader-inline/loader-inline.js +6 -8
  334. package/dist/loader-inline-ng/loader-inline-ng.js +42 -0
  335. package/dist/loader-ng/loader-ng.js +43 -0
  336. package/dist/loader-screen/loader-screen.js +7 -10
  337. package/dist/loader-screen-ng/loader-screen-ng.js +99 -0
  338. package/dist/login-dialog/login-dialog.js +7 -5
  339. package/dist/login-dialog/service.js +9 -6
  340. package/dist/markdown/code.js +30 -0
  341. package/dist/markdown/heading.js +23 -0
  342. package/dist/markdown/link.js +30 -0
  343. package/dist/markdown/markdown.js +73 -0
  344. package/dist/message/message.js +7 -6
  345. package/dist/message-bundle-ng/message-bundle-ng.js +111 -0
  346. package/dist/old-browsers-message/old-browsers-message.js +0 -1
  347. package/dist/old-browsers-message/old-browsers-message__stop.js +0 -1
  348. package/dist/old-browsers-message/white-list.js +4 -5
  349. package/dist/pager/pager.js +20 -11
  350. package/dist/pager-ng/pager-ng.js +96 -0
  351. package/dist/panel/panel.js +7 -10
  352. package/dist/panel-ng/panel-ng.js +16 -0
  353. package/dist/permissions/permissions.js +4 -2
  354. package/dist/permissions/permissions__cache.js +1 -1
  355. package/dist/permissions-ng/permissions-ng.js +274 -0
  356. package/dist/place-under-ng/place-under-ng.js +157 -0
  357. package/dist/popup/popup.js +11 -11
  358. package/dist/popup/popup.target.js +4 -5
  359. package/dist/popup/position.js +18 -16
  360. package/dist/popup-menu/popup-menu.js +23 -16
  361. package/dist/progress-bar/progress-bar.js +14 -12
  362. package/dist/progress-bar-ng/progress-bar-ng.js +15 -0
  363. package/dist/promised-click-ng/promised-click-ng.js +126 -0
  364. package/dist/proxy-attrs/proxy-attrs.js +1 -1
  365. package/dist/query-assist/query-assist.js +156 -76
  366. package/dist/query-assist/query-assist__suggestions.js +5 -1
  367. package/dist/query-assist-ng/query-assist-ng.js +82 -0
  368. package/dist/radio/radio.js +9 -7
  369. package/dist/radio/radio__item.js +13 -18
  370. package/dist/radio-ng/radio-ng.js +63 -0
  371. package/dist/save-field-ng/save-field-ng.js +335 -0
  372. package/dist/save-field-ng/save-field-ng__template.js +34 -0
  373. package/dist/select/select.js +118 -95
  374. package/dist/select/select__filter.js +6 -1
  375. package/dist/select/select__popup.js +12 -6
  376. package/dist/select-ng/select-ng.js +621 -0
  377. package/dist/select-ng/select-ng__lazy.js +150 -0
  378. package/dist/select-ng/select-ng__options.js +145 -0
  379. package/dist/shortcuts/core.js +7 -4
  380. package/dist/shortcuts/shortcuts-hoc.js +8 -10
  381. package/dist/shortcuts/shortcuts.js +6 -6
  382. package/dist/shortcuts-hint-ng/shortcuts-hint-ng.js +120 -0
  383. package/dist/shortcuts-hint-ng/shortcuts-hint-ng__template.js +50 -0
  384. package/dist/shortcuts-ng/shortcuts-ng.js +261 -0
  385. package/dist/sidebar-ng/sidebar-ng.js +111 -0
  386. package/dist/sidebar-ng/sidebar-ng__button-template.js +20 -0
  387. package/dist/sidebar-ng/sidebar-ng__template.js +12 -0
  388. package/dist/storage/storage.js +3 -2
  389. package/dist/storage/storage__fallback.js +3 -2
  390. package/dist/storage/storage__local.js +5 -3
  391. package/dist/style.css +1 -1
  392. package/dist/tab-trap/tab-trap.js +15 -13
  393. package/dist/table/cell.js +2 -2
  394. package/dist/table/disable-hover-hoc.js +4 -4
  395. package/dist/table/header-cell.js +10 -11
  396. package/dist/table/header.js +19 -12
  397. package/dist/table/multitable.js +33 -25
  398. package/dist/table/row-with-focus-sensor.js +7 -5
  399. package/dist/table/row.js +17 -15
  400. package/dist/table/selection-adapter.js +1 -1
  401. package/dist/table/selection-shortcuts-hoc.js +10 -8
  402. package/dist/table/selection.js +25 -17
  403. package/dist/table/smart-table.js +16 -10
  404. package/dist/table/table.js +38 -33
  405. package/dist/table-legacy-ng/table-legacy-ng.js +501 -0
  406. package/dist/table-legacy-ng/table-legacy-ng__pager.js +122 -0
  407. package/dist/table-legacy-ng/table-legacy-ng__selection-navigate-actions.js +123 -0
  408. package/dist/table-legacy-ng/table-legacy-ng__selection.js +179 -0
  409. package/dist/table-legacy-ng/table-legacy-ng__toolbar.js +56 -0
  410. package/dist/table-ng/smart-table-ng.js +65 -0
  411. package/dist/table-ng/table-ng.js +64 -0
  412. package/dist/tabs/collapsible-more.js +37 -30
  413. package/dist/tabs/collapsible-tab.js +16 -14
  414. package/dist/tabs/collapsible-tabs.js +83 -80
  415. package/dist/tabs/custom-item.js +6 -3
  416. package/dist/tabs/dumb-tabs.js +19 -14
  417. package/dist/tabs/smart-tabs.js +13 -11
  418. package/dist/tabs/tab-link.js +13 -7
  419. package/dist/tabs/tab.js +1 -1
  420. package/dist/tabs/tabs.js +5 -1
  421. package/dist/tabs-ng/tabs-ng.js +193 -0
  422. package/dist/tabs-ng/tabs-ng__template.js +40 -0
  423. package/dist/tag/tag.js +22 -16
  424. package/dist/tags-input/tags-input.js +48 -36
  425. package/dist/tags-input-ng/tags-input-ng.js +89 -0
  426. package/dist/tags-list/tags-list.js +8 -9
  427. package/dist/template-ng/template-ng.js +70 -0
  428. package/dist/text/text.js +7 -9
  429. package/dist/theme-ng/theme-ng.js +44 -0
  430. package/dist/title-ng/title-ng.js +114 -0
  431. package/dist/toggle/toggle.js +8 -11
  432. package/dist/toggle-ng/toggle-ng.js +16 -0
  433. package/dist/tooltip/tooltip.js +16 -14
  434. package/dist/tooltip-ng/tooltip-ng.js +98 -0
  435. package/dist/user-agreement/service.js +409 -0
  436. package/dist/user-agreement/toolbox.eula.js +162 -0
  437. package/dist/user-agreement/user-agreement.js +167 -0
  438. package/dist/user-card/card.js +3 -0
  439. package/dist/user-card/smart-user-card-tooltip.js +16 -16
  440. package/dist/user-card/tooltip.js +9 -7
  441. package/dist/user-card/user-card.js +5 -2
  442. package/dist/user-card-ng/user-card-ng.js +59 -0
  443. package/package.json +83 -81
  444. package/webpack.config.js +14 -10
  445. package/components/button-set-ng/button-set-ng.html +0 -1
  446. package/components/footer-ng/footer-ng.html +0 -13
  447. package/components/form-ng/form-ng__error-bubble.html +0 -3
  448. package/components/table-legacy-ng/table-legacy-ng.html +0 -4
  449. package/components/table-legacy-ng/table-legacy-ng__column.html +0 -12
  450. package/components/table-legacy-ng/table-legacy-ng__header.html +0 -4
  451. package/components/table-legacy-ng/table-legacy-ng__pager.html +0 -7
  452. package/components/table-legacy-ng/table-legacy-ng__row.html +0 -12
  453. package/components/table-legacy-ng/table-legacy-ng__title.html +0 -9
  454. package/dist/_helpers/caption.js +0 -25
  455. package/dist/_helpers/icon__svg.js +0 -83
package/CHANGELOG.md CHANGED
@@ -1,3 +1,16 @@
1
+ ## [4.1.0]
2
+
3
+ ### Pre-built version
4
+
5
+ Ring UI now comes with pre-built version in `@jetbrains/ring-ui/dist` directory.
6
+ This addresses the following issues:
7
+
8
+ * does not require using specific bundler (WebPack) anymore
9
+ * does not require dealing with Ring UI building configuration
10
+ * decreases your project build time
11
+
12
+ See "README.md" for quick start with pre-built version
13
+
1
14
  ## [4.0.0]
2
15
 
3
16
  ### BREAKING CHANGES
package/README.md CHANGED
@@ -7,27 +7,28 @@ This collection of UI components aims to provide all the necessary building bloc
7
7
 
8
8
  ## Installation
9
9
 
10
- There are three ways of installing and using RingUI. Choose **one** that suits your needs best:
10
+ `npm install @jetbrains/ring-ui`
11
11
 
12
12
  ### Quick start (importing components as ES modules)
13
13
 
14
14
  The easiest way is to import necessary components as ES modules:
15
- ```javascript
16
- import Icon from "@jetbrains/ring-ui/dist/icon"
17
- import Logo from "@jetbrains/ring-ui/dist/logo"
18
- import Input from "@jetbrains/ring-ui/dist/input"
19
- import Select from "@jetbrains/ring-ui/dist/select"
20
- import Toggle from "@jetbrains/ring-ui/dist/toggle"
21
- import { Tabs, Tab } from "@jetbrains/ring-ui/dist/tabs"
15
+ ```js
16
+ // You need to import RingUI styles once
17
+ import '@jetbrains/ring-ui/dist/style.css';
22
18
 
23
- import "@jetbrains/ring-ui/dist/style.css"
19
+ import alertService from '@jetbrains/ring-ui/dist/alert-service/alert-service';
20
+ import Button from '@jetbrains/ring-ui/dist/button/button';
24
21
 
25
22
  ...
26
23
 
27
- <Select
28
- className="select-field"
29
- size="FULL"
30
- />
24
+ export const Demo = () => {
25
+ return (
26
+ <Button onClick={() => alertService.successMessage('Hello world')}>
27
+ Click me
28
+ </Button>
29
+ );
30
+ };
31
+
31
32
  ```
32
33
 
33
34
  The bundle size will depend on the amount of components you imported.
@@ -43,9 +44,10 @@ The bundle size will depend on the amount of components you imported.
43
44
  - `npm run build` to build a production bundle
44
45
  - `npm run create-component` to create a new component template with styles and tests
45
46
 
46
- ### Webpack injection
47
+ ### Building Ring UI from source via Webpack
47
48
 
48
- In case boilerplate generators are not your thing and you prefer to understand the inner workings a bit better.
49
+ In case you have complex build, and you want to compile RingUI sources together with your sources
50
+ in a same build process, you can use the following configuration:
49
51
 
50
52
  1. Install Ring UI with `npm install @jetbrains/ring-ui --save-exact`
51
53
 
package/babel.config.js CHANGED
@@ -1,4 +1,5 @@
1
1
  const browserslist = require('browserslist');
2
+ const deprecate = require('util-deprecate');
2
3
 
3
4
  const coreJsVersion = process.env.RING_UI_COREJS_VERSION ||
4
5
  require('core-js/package.json').version;
@@ -9,8 +10,8 @@ module.exports = function config(api) {
9
10
  api.cache(true);
10
11
 
11
12
  if (isDeprecatedCoreJS) {
12
- // eslint-disable-next-line no-console
13
- console.log(`Compiling Ring UI with deprecated Core JS version "${coreJsVersion}". Consider updating to 3rd.`);
13
+ // TODO remove in 5.0
14
+ deprecate(() => null, `Compiling Ring UI with deprecated Core JS version "${coreJsVersion}". Consider updating to 3rd.`)();
14
15
  }
15
16
 
16
17
  return {
@@ -82,6 +82,7 @@ export default class Alert extends PureComponent {
82
82
  children: PropTypes.node,
83
83
  className: PropTypes.string,
84
84
  captionClassName: PropTypes.string,
85
+ closeButtonClassName: PropTypes.string,
85
86
  'data-test': PropTypes.string
86
87
  };
87
88
 
@@ -121,12 +122,17 @@ export default class Alert extends PureComponent {
121
122
  static Type = Type;
122
123
 
123
124
  closeRequest = (...args) => {
125
+ this.startCloseAnimation();
126
+ return this.props.onCloseRequest(...args);
127
+ };
128
+
129
+ startCloseAnimation = () => {
124
130
  const height = getRect(this.node).height;
125
131
  this.setState({height});
126
- return this.props.onCloseRequest(...args);
127
132
  };
128
133
 
129
134
  _close() {
135
+ this.startCloseAnimation();
130
136
  setTimeout(() => {
131
137
  this.props.onClose();
132
138
  }, ANIMATION_TIME);
@@ -189,7 +195,7 @@ export default class Alert extends PureComponent {
189
195
  };
190
196
 
191
197
  render() {
192
- const {type, inline, isClosing, isShaking,
198
+ const {type, inline, isClosing, isShaking, closeButtonClassName,
193
199
  showWithAnimation, className, 'data-test': dataTest} = this.props;
194
200
 
195
201
  const classes = classNames(className, {
@@ -218,7 +224,7 @@ export default class Alert extends PureComponent {
218
224
  ? (
219
225
  <button
220
226
  type="button"
221
- className={styles.close}
227
+ className={classNames(styles.close, closeButtonClassName)}
222
228
  data-test="alert-close"
223
229
  aria-label="close alert"
224
230
  onClick={this.closeRequest}
@@ -1,86 +1,59 @@
1
1
  import React from 'react';
2
- import {shallow, mount, render} from 'enzyme';
2
+ import {render, screen} from '@testing-library/react';
3
+ import userEvent from '@testing-library/user-event';
3
4
 
4
5
  import Alert from './alert';
5
6
  import styles from './alert.css';
6
7
 
8
+ const TIMEOUT = 100;
7
9
  const TICK = 500;
8
10
 
9
11
  describe('Alert', () => {
10
- const mountAlert = props => mount(<Alert {...props}/>);
11
- const shallowAlert = props => shallow(<Alert {...props}/>);
12
- const renderAlert = props => render(<Alert {...props}/>);
13
-
14
- let clock;
15
- beforeEach(() => {
16
- clock = sandbox.useFakeTimers({toFake: ['setTimeout']});
17
- });
18
-
19
- it('should render', () => {
20
- mountAlert({}).should.have.type(Alert);
21
- });
22
-
23
12
  it('should render text', () => {
24
- const alertComponent = renderAlert({
25
- children: 'Test message',
26
- type: Alert.Type.MESSAGE
27
- });
28
- alertComponent.should.have.text('Test message');
13
+ render(<Alert type={Alert.Type.MESSAGE}>{'Test message'}</Alert>);
14
+ screen.getByText('Test message').should.exist;
29
15
  });
30
16
 
31
17
  it('should transfer className', () => {
32
- shallowAlert({className: 'foo'}).should.have.className('foo');
18
+ render(<Alert className="foo"/>);
19
+ screen.getByTestId('alert').should.have.class('foo');
33
20
  });
34
21
 
35
22
  it('should render component', () => {
36
- const alertComponent = renderAlert({
37
- children: <div>{'foo'}</div>,
38
- type: Alert.Type.MESSAGE
39
- });
40
- alertComponent.should.have.text('foo');
23
+ render(<Alert type={Alert.Type.MESSAGE}><div>{'foo'}</div></Alert>);
24
+ screen.getByText('foo').should.exist;
41
25
  });
42
26
 
43
27
  it('should render an error', () => {
44
- const alertComponent = shallowAlert({
45
- children: 'Test',
46
- type: Alert.Type.ERROR
47
- });
48
- alertComponent.should.have.className(styles.error);
28
+ render(<Alert type={Alert.Type.ERROR}>{'Test'}</Alert>);
29
+ screen.getByTestId('alert').should.have.class(styles.error);
49
30
  });
50
31
 
51
32
  it('should be closeable if by default', () => {
52
- const alertComponent = shallowAlert({children: 'Test element'});
33
+ render(<Alert>{'Test element'}</Alert>);
53
34
 
54
- alertComponent.should.have.descendants('button[data-test="alert-close"]');
35
+ screen.getByRole('button', {name: 'close alert'}).should.exist;
55
36
  });
56
37
 
57
38
  it('should be not closeable if defined', () => {
58
- const alertComponent = shallowAlert({
59
- children: 'Test element',
60
- closeable: false
61
- });
39
+ render(<Alert closeable={false}>{'Test element'}</Alert>);
62
40
 
63
- alertComponent.should.not.have.descendants('button[data-test="alert-close"]');
41
+ should.not.exist(screen.queryByRole('button', {name: 'close alert'}));
64
42
  });
65
43
 
66
44
  it('should call onCloseRequest on click by close button', () => {
67
45
  const closeSpy = sandbox.spy();
68
- const alertComponent = shallowAlert({
69
- children: 'Test element',
70
- onCloseRequest: closeSpy
71
- });
72
- const closeElement = alertComponent.find('button[data-test="alert-close"]');
73
- closeElement.simulate('click');
46
+ render(<Alert onCloseRequest={closeSpy}>{'Test element'}</Alert>);
47
+ const closeElement = screen.queryByRole('button', {name: 'close alert'});
48
+ userEvent.click(closeElement);
74
49
  closeSpy.should.have.been.called;
75
50
  });
76
51
 
77
52
  it('should call onCloseRequest on timeout', () => {
53
+ const clock = sandbox.useFakeTimers({toFake: ['setTimeout']});
78
54
  const closeSpy = sandbox.spy();
79
- mountAlert({
80
- children: 'Test element',
81
- timeout: 100,
82
- onCloseRequest: closeSpy
83
- });
55
+ render(<Alert timeout={TIMEOUT} onCloseRequest={closeSpy}>{'Test element'}</Alert>);
56
+
84
57
  clock.tick(TICK);
85
58
 
86
59
  closeSpy.should.have.been.called;
@@ -1,7 +1,7 @@
1
1
  @import "../global/variables.css";
2
2
 
3
3
  @value unit from "../global/global.css";
4
- @value alert from './alert.css';
4
+ @value alert from "./alert.css";
5
5
 
6
6
  .alertContainer {
7
7
  position: fixed;
@@ -1,22 +1,12 @@
1
1
  import React from 'react';
2
- import {mount} from 'enzyme';
2
+ import {render, screen} from '@testing-library/react';
3
3
 
4
4
  import Alert from './alert';
5
5
  import AlertContainer from './container';
6
6
 
7
7
  describe('Alert Container', () => {
8
- const children = <Alert>{'Test'}</Alert>;
9
-
10
- const mountAlertContainer = props => mount(
11
- <AlertContainer {...props}>{children}</AlertContainer>
12
- );
13
-
14
- it('should render alert container component', () => {
15
- mountAlertContainer().should.have.type(AlertContainer);
16
- });
17
-
18
8
  it('should render alert container to body', () => {
19
- mountAlertContainer();
20
- document.body.should.contain('*[data-test="alert-container"]');
9
+ render(<AlertContainer><Alert>{'Test'}</Alert></AlertContainer>);
10
+ screen.getByTestId('alert-container').should.exist;
21
11
  });
22
12
  });
@@ -0,0 +1,18 @@
1
+ @import "../global/variables.css";
2
+
3
+ @value unit from "../global/global.css";
4
+ @value animation-duration: 300ms;
5
+ @value animation-easing: ease-out;
6
+
7
+ .customAlert {
8
+ background: var(--ring-main-color);
9
+ }
10
+
11
+ .closeButton,
12
+ .closeButton:hover {
13
+ color: var(--ring-dark-text-color);
14
+ }
15
+
16
+ .closeButton:hover {
17
+ opacity: 0.8;
18
+ }
@@ -2,6 +2,8 @@ import React from 'react';
2
2
 
3
3
  import reactDecorator from '../../.storybook/react-decorator';
4
4
 
5
+ import styles from './alert-service.examples.css';
6
+
5
7
  import Button from '@jetbrains/ring-ui/components/button/button';
6
8
  import ButtonToolbar from '@jetbrains/ring-ui/components/button-toolbar/button-toolbar';
7
9
 
@@ -26,6 +28,7 @@ export const alertService = () => {
26
28
  setTimeout(() => {
27
29
  alert.message('A initial message', MSG_TIMEOUT);
28
30
  alert.error('Error message');
31
+ this.showCustomMessage();
29
32
  });
30
33
  }
31
34
 
@@ -33,6 +36,21 @@ export const alertService = () => {
33
36
  alert._getShowingAlerts().forEach(item => alert.removeWithoutAnimation(item.key));
34
37
  }
35
38
 
39
+ showCustomMessage = () => {
40
+ this.lastKey = alert.addAlert(
41
+ <div className={styles.customAlert}>
42
+ <h1>Hello!</h1>
43
+ <p>{'This is a custom message'}</p>
44
+ </div>,
45
+ null,
46
+ 0,
47
+ {
48
+ className: styles.customAlert,
49
+ closeButtonClassName: styles.closeButton
50
+ }
51
+ );
52
+ };
53
+
36
54
  showError = () => {
37
55
  this.lastKey = alert.error('Something wrong happened');
38
56
  };
@@ -59,6 +77,9 @@ export const alertService = () => {
59
77
  <Button onClick={this.showMessage} primary>
60
78
  Show message
61
79
  </Button>
80
+ <Button onClick={this.showCustomMessage}>
81
+ Show custom message
82
+ </Button>
62
83
  <Button onClick={this.showRandomWarning}>Show warning</Button>
63
84
  <Button onClick={this.removeLastAlert}>Remove last alert</Button>
64
85
  </ButtonToolbar>
@@ -76,7 +76,8 @@ class AlertService {
76
76
  }, ANIMATION_TIME);
77
77
  }
78
78
 
79
- addAlert(message, type, timeout = this.defaultTimeout, restOptions = {}) {
79
+ addAlert(message, type, timeout = this.defaultTimeout, options = {}) {
80
+ const {onCloseRequest, onClose, ...restOptions} = options;
80
81
  const sameAlert = this.findSameAlert(message, type);
81
82
  if (sameAlert) {
82
83
  sameAlert.isShaking = true;
@@ -91,8 +92,14 @@ class AlertService {
91
92
  type,
92
93
  timeout,
93
94
  isClosing: false,
94
- onCloseRequest: () => this.startAlertClosing(alert),
95
- onClose: () => this.removeWithoutAnimation(alert.key),
95
+ onCloseRequest: () => {
96
+ onCloseRequest && onCloseRequest();
97
+ this.startAlertClosing(alert);
98
+ },
99
+ onClose: () => {
100
+ onClose && onClose();
101
+ this.removeWithoutAnimation(alert.key);
102
+ },
96
103
  ...restOptions
97
104
  };
98
105
 
@@ -24,9 +24,9 @@ export default class AnalyticsFUSPlugin {
24
24
  return;
25
25
  }
26
26
  ((i, s, o, g, r) => {
27
- i[r] = i[r] || (() => {
27
+ i[r] = i[r] || function addArgumentsToQueueForWaitingTheScriptLoading() {
28
28
  (i[r].query = i[r].query || []).push(arguments);
29
- });
29
+ };
30
30
  const script = document.createElement(o);
31
31
  script.async = true;
32
32
  script.src = g;
@@ -39,7 +39,7 @@ export default class AnalyticsFUSPlugin {
39
39
  recorderVersion,
40
40
  productCode: productId,
41
41
  productBuild,
42
- internal: true,
42
+ internal: isDevelopment,
43
43
  groups,
44
44
  useForSubdomains: true
45
45
  });
@@ -10,9 +10,9 @@ export default class AnalyticsGAPlugin {
10
10
  }
11
11
  ((i, s, o, g, r) => {
12
12
  i.GoogleAnalyticsObject = r;
13
- i[r] = i[r] || (() => {
13
+ i[r] = i[r] || function addArgumentsToQueueForWaitingTheScriptLoading() {
14
14
  (i[r].q = i[r].q || []).push(arguments);
15
- });
15
+ };
16
16
  i[r].l = 1 * new Date();
17
17
  const a = s.createElement(o);
18
18
  const m = s.getElementsByTagName(o)[0];
@@ -203,7 +203,8 @@ describe('Auth', () => {
203
203
  redirectUri: 'http://localhost:8080/hub',
204
204
  clientId: '1-1-1-1-1',
205
205
  scope: ['0-0-0-0-0', 'youtrack'],
206
- optionalScopes: ['youtrack']
206
+ optionalScopes: ['youtrack'],
207
+ waitForRedirectTimeout: 0
207
208
  });
208
209
  try {
209
210
  await auth.init();
@@ -226,7 +227,8 @@ describe('Auth', () => {
226
227
  auth = new Auth({
227
228
  serverUri: '',
228
229
  redirect: true,
229
- cleanHash: true
230
+ cleanHash: true,
231
+ waitForRedirectTimeout: 0
230
232
  });
231
233
 
232
234
  try {
@@ -245,7 +247,8 @@ describe('Auth', () => {
245
247
  auth = new Auth({
246
248
  serverUri: '',
247
249
  redirect: true,
248
- cleanHash: true
250
+ cleanHash: true,
251
+ waitForRedirectTimeout: 0
249
252
  });
250
253
 
251
254
  try {
@@ -265,7 +268,8 @@ describe('Auth', () => {
265
268
  auth = new Auth({
266
269
  serverUri: '',
267
270
  redirect: true,
268
- cleanHash: false
271
+ cleanHash: false,
272
+ waitForRedirectTimeout: 0
269
273
  });
270
274
 
271
275
  try {
@@ -284,7 +288,8 @@ describe('Auth', () => {
284
288
  serverUri: '',
285
289
  redirect: true,
286
290
  redirectUri: 'http://localhost:8080/hub',
287
- requestCredentials: 'skip'
291
+ requestCredentials: 'skip',
292
+ waitForRedirectTimeout: 0
288
293
  });
289
294
  try {
290
295
  await auth.init();
@@ -313,7 +318,8 @@ describe('Auth', () => {
313
318
  redirectUri: 'http://localhost:8080/hub',
314
319
  clientId: '1-1-1-1-1',
315
320
  scope: ['0-0-0-0-0', 'youtrack'],
316
- optionalScopes: ['youtrack']
321
+ optionalScopes: ['youtrack'],
322
+ waitForRedirectTimeout: 0
317
323
  });
318
324
 
319
325
  auth._storage._tokenStorage = auth._storage._stateStorage =
@@ -330,7 +336,8 @@ describe('Auth', () => {
330
336
  auth._storage.saveToken({
331
337
  accessToken: 'token',
332
338
  expires: TokenValidator._epoch() + HOUR,
333
- scopes: ['0-0-0-0-0']
339
+ scopes: ['0-0-0-0-0'],
340
+ waitForRedirectTimeout: 0
334
341
  });
335
342
  });
336
343
 
@@ -14,6 +14,7 @@ export const DEFAULT_EXPIRES_TIMEOUT = 40 * 60;
14
14
  export const DEFAULT_BACKGROUND_TIMEOUT = 10 * 1000;
15
15
  const DEFAULT_BACKEND_CHECK_TIMEOUT = 10 * 1000;
16
16
  const BACKGROUND_REDIRECT_TIMEOUT = 20 * 1000;
17
+ const DEFAULT_WAIT_FOR_REDIRECT_TIMEOUT = 5 * 1000;
17
18
  /* eslint-enable no-magic-numbers */
18
19
 
19
20
  export const USER_CHANGED_EVENT = 'userChange';
@@ -46,6 +47,7 @@ const DEFAULT_CONFIG = {
46
47
  onBackendDown: () => {},
47
48
 
48
49
  defaultExpiresIn: DEFAULT_EXPIRES_TIMEOUT,
50
+ waitForRedirectTimeout: DEFAULT_WAIT_FOR_REDIRECT_TIMEOUT,
49
51
  translations: {
50
52
  login: 'Log in',
51
53
  loginTo: 'Log in to %serviceName%',
@@ -231,7 +233,7 @@ export default class Auth {
231
233
  * that should be restored after returning back from auth server.
232
234
  */
233
235
  async init() {
234
- this._storage.onTokenChange(token => {
236
+ this._storage.onTokenChange(async token => {
235
237
  const isGuest = this.user ? this.user.guest : false;
236
238
 
237
239
  if (isGuest && !token) {
@@ -241,7 +243,13 @@ export default class Auth {
241
243
  if (!token) {
242
244
  this.logout();
243
245
  } else {
244
- this._detectUserChange(token.accessToken);
246
+ try {
247
+ await this._detectUserChange(token.accessToken);
248
+ } catch (error) {
249
+ if (this._canShowDialogs()) {
250
+ this._showAuthDialog({nonInteractive: true, error});
251
+ }
252
+ }
245
253
  }
246
254
  });
247
255
 
@@ -305,6 +313,11 @@ export default class Auth {
305
313
  const authRequest = await this._requestBuilder.prepareAuthRequest();
306
314
  this._redirectCurrentPage(authRequest.url);
307
315
 
316
+ // HUB-10867 Since we already redirecting the page, there is no actual need to throw an error
317
+ // and scare user with flashing error
318
+ // But let's keep it just in case redirect was not successful
319
+ await new Promise(resolve => setTimeout(resolve, this.config.waitForRedirectTimeout));
320
+
308
321
  throw error;
309
322
  }
310
323
 
@@ -466,35 +479,31 @@ export default class Auth {
466
479
  async _detectUserChange(accessToken) {
467
480
  const windowWasOpen = this._isLoginWindowOpen;
468
481
 
469
- try {
470
- const user = await this.getUser(accessToken);
471
- const onApply = () => {
472
- this.user = user;
473
- this.listeners.trigger(USER_CHANGED_EVENT, user);
474
- };
482
+ const user = await this.getUser(accessToken);
483
+ const onApply = () => {
484
+ this.user = user;
485
+ this.listeners.trigger(USER_CHANGED_EVENT, user);
486
+ };
475
487
 
476
- if (user && this.user && this.user.id !== user.id) {
477
- if (!this._canShowDialogs() || this.user.guest || windowWasOpen) {
478
- onApply();
479
- return;
480
- }
481
- if (user.guest) {
482
- this._showAuthDialog({nonInteractive: true});
483
- return;
484
- }
488
+ if (user && this.user && this.user.id !== user.id) {
489
+ if (!this._canShowDialogs() || this.user.guest || windowWasOpen) {
490
+ onApply();
491
+ return;
492
+ }
493
+ if (user.guest) {
494
+ this._showAuthDialog({nonInteractive: true});
495
+ return;
496
+ }
485
497
 
486
- await this._showUserChangedDialog({
487
- newUser: user,
488
- onApply,
489
- onPostpone: () => {
490
- this.listeners.trigger(USER_CHANGE_POSTPONED_EVENT);
491
- this.config.onPostponeChangedUser(this.user, user);
492
- }
493
- });
498
+ await this._showUserChangedDialog({
499
+ newUser: user,
500
+ onApply,
501
+ onPostpone: () => {
502
+ this.listeners.trigger(USER_CHANGE_POSTPONED_EVENT);
503
+ this.config.onPostponeChangedUser(this.user, user);
504
+ }
505
+ });
494
506
 
495
- }
496
- } catch (e) {
497
- // noop
498
507
  }
499
508
  }
500
509
 
@@ -554,7 +563,7 @@ export default class Auth {
554
563
  loginToCaption: translations.loginTo,
555
564
  confirmLabel: translations.login,
556
565
  cancelLabel: cancelable ? translations.cancel : translations.postpone,
557
- errorMessage: error && error.toString ? error.toString() : null,
566
+ errorMessage: this._extractErrorMessage(error, true),
558
567
  onConfirm,
559
568
  onCancel
560
569
  });
@@ -601,6 +610,29 @@ export default class Auth {
601
610
  });
602
611
  }
603
612
 
613
+ _extractErrorMessage(error, logError = false) {
614
+ if (!error) {
615
+ return null;
616
+ }
617
+ if (logError) {
618
+ // eslint-disable-next-line no-console
619
+ console.error('RingUI Auth error', error);
620
+ }
621
+
622
+ try {
623
+ // We've got some error from this list
624
+ // https://www.jetbrains.com/help/youtrack/devportal/OAuth-2.0-Errors.html
625
+ if (error.code && typeof error.code.code === 'string') {
626
+ const readableCode = error.code.code.split('_').join(' ');
627
+ return `Authorization error: ${readableCode}`;
628
+ }
629
+ } catch {
630
+ // noop
631
+ }
632
+
633
+ return error.toString ? error.toString() : null;
634
+ }
635
+
604
636
  _showBackendDownDialog(backendError) {
605
637
  const {onBackendDown, translations} = this.config;
606
638
  const REPEAT_TIMEOUT = 5000;
@@ -711,11 +743,10 @@ export default class Auth {
711
743
  }
712
744
 
713
745
  async switchUser() {
714
- if (this.config.embeddedLogin) {
715
- await this._runEmbeddedLogin();
746
+ if (!this.config.embeddedLogin) {
747
+ throw new Error('Auth: switchUser only supported for "embeddedLogin" mode');
716
748
  }
717
-
718
- throw new Error('Auth: switchUser only supported for "embeddedLogin" mode');
749
+ await this._runEmbeddedLogin();
719
750
  }
720
751
 
721
752
  /**
@@ -28,14 +28,13 @@
28
28
  margin-top: calc(unit * 4);
29
29
  }
30
30
 
31
- .title {
31
+ .title.title {
32
+ margin-top: 0;
32
33
  margin-bottom: unit;
33
34
 
34
35
  text-align: center;
35
36
 
36
- font-size: 24px;
37
37
  font-weight: 100;
38
- line-height: 28px;
39
38
  }
40
39
 
41
40
  .logo {