@jetbrains/ring-ui 6.0.6-beta.0 → 6.0.6

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 (510) hide show
  1. package/README.md +1 -1
  2. package/components/alert/alert.css +146 -0
  3. package/components/alert/alert.d.ts +113 -0
  4. package/components/alert/alert.js +186 -0
  5. package/components/alert/container.css +26 -0
  6. package/components/alert/container.d.ts +15 -0
  7. package/components/alert/container.js +30 -0
  8. package/components/alert-service/alert-service.d.ts +36 -0
  9. package/components/alert-service/alert-service.js +108 -0
  10. package/components/alert-service/alert-service.stories.css +17 -0
  11. package/components/analytics/analytics.d.ts +18 -0
  12. package/components/analytics/analytics.js +18 -0
  13. package/components/analytics/analytics__custom-plugin.d.ts +28 -0
  14. package/components/analytics/analytics__custom-plugin.js +58 -0
  15. package/components/auth/auth.d.ts +3 -0
  16. package/components/auth/auth.js +42 -0
  17. package/components/auth/auth__core.d.ts +236 -0
  18. package/components/auth/auth__core.js +834 -0
  19. package/components/auth/background-flow.d.ts +31 -0
  20. package/components/auth/background-flow.js +97 -0
  21. package/components/auth/down-notification.css +15 -0
  22. package/components/auth/down-notification.d.ts +15 -0
  23. package/components/auth/down-notification.js +52 -0
  24. package/components/auth/iframe-flow.d.ts +20 -0
  25. package/components/auth/iframe-flow.js +81 -0
  26. package/components/auth/request-builder.d.ts +48 -0
  27. package/components/auth/request-builder.js +64 -0
  28. package/components/auth/response-parser.d.ts +70 -0
  29. package/components/auth/response-parser.js +99 -0
  30. package/components/auth/storage.d.ts +112 -0
  31. package/components/auth/storage.js +224 -0
  32. package/components/auth/token-validator.d.ts +93 -0
  33. package/components/auth/token-validator.js +169 -0
  34. package/components/auth/window-flow.d.ts +26 -0
  35. package/components/auth/window-flow.js +102 -0
  36. package/components/auth-dialog/auth-dialog.css +54 -0
  37. package/components/auth-dialog/auth-dialog.d.ts +60 -0
  38. package/components/auth-dialog/auth-dialog.js +93 -0
  39. package/components/auth-dialog-service/auth-dialog-service.d.ts +6 -0
  40. package/components/auth-dialog-service/auth-dialog-service.js +26 -0
  41. package/components/avatar/avatar-example-datauri.d.ts +1 -0
  42. package/components/avatar/avatar-example-datauri.js +24 -0
  43. package/components/avatar/avatar.css +27 -0
  44. package/components/avatar/avatar.d.ts +52 -0
  45. package/components/avatar/avatar.js +98 -0
  46. package/components/avatar/fallback-avatar.d.ts +17 -0
  47. package/components/avatar/fallback-avatar.js +113 -0
  48. package/components/badge/badge.css +42 -0
  49. package/components/badge/badge.d.ts +24 -0
  50. package/components/badge/badge.js +35 -0
  51. package/components/button/button.css +397 -0
  52. package/components/button/button.d.ts +67 -0
  53. package/components/button/button.js +70 -0
  54. package/components/button/button__classes.d.ts +2 -0
  55. package/components/button/button__classes.js +18 -0
  56. package/components/button-group/button-group.css +236 -0
  57. package/components/button-group/button-group.d.ts +18 -0
  58. package/components/button-group/button-group.js +21 -0
  59. package/components/button-group/caption.d.ts +8 -0
  60. package/components/button-group/caption.js +14 -0
  61. package/components/button-set/button-set.css +21 -0
  62. package/components/button-set/button-set.d.ts +16 -0
  63. package/components/button-set/button-set.js +22 -0
  64. package/components/button-toolbar/button-toolbar.css +25 -0
  65. package/components/button-toolbar/button-toolbar.d.ts +16 -0
  66. package/components/button-toolbar/button-toolbar.js +20 -0
  67. package/components/caret/caret.d.ts +66 -0
  68. package/components/caret/caret.js +216 -0
  69. package/components/checkbox/checkbox.css +146 -0
  70. package/components/checkbox/checkbox.d.ts +45 -0
  71. package/components/checkbox/checkbox.js +72 -0
  72. package/components/clipboard/clipboard-fallback.d.ts +2 -0
  73. package/components/clipboard/clipboard-fallback.js +44 -0
  74. package/components/clipboard/clipboard.d.ts +5 -0
  75. package/components/clipboard/clipboard.js +41 -0
  76. package/components/code/code.css +29 -0
  77. package/components/code/code.d.ts +44 -0
  78. package/components/code/code.js +94 -0
  79. package/components/code/highlight.css +112 -0
  80. package/components/collapse/collapse-content.d.ts +11 -0
  81. package/components/collapse/collapse-content.js +72 -0
  82. package/components/collapse/collapse-context.d.ts +10 -0
  83. package/components/collapse/collapse-context.js +10 -0
  84. package/components/collapse/collapse-control.d.ts +11 -0
  85. package/components/collapse/collapse-control.js +22 -0
  86. package/components/collapse/collapse.css +40 -0
  87. package/components/collapse/collapse.d.ts +12 -0
  88. package/components/collapse/collapse.js +26 -0
  89. package/components/collapse/collapse.stories.css +25 -0
  90. package/components/collapse/consts.d.ts +4 -0
  91. package/components/collapse/consts.js +4 -0
  92. package/components/collapse/utils.d.ts +1 -0
  93. package/components/collapse/utils.js +1 -0
  94. package/components/confirm/confirm.css +7 -0
  95. package/components/confirm/confirm.d.ts +48 -0
  96. package/components/confirm/confirm.js +59 -0
  97. package/components/confirm-service/confirm-service.d.ts +21 -0
  98. package/components/confirm-service/confirm-service.js +52 -0
  99. package/components/content-layout/content-layout.css +108 -0
  100. package/components/content-layout/content-layout.d.ts +26 -0
  101. package/components/content-layout/content-layout.js +45 -0
  102. package/components/content-layout/sidebar.d.ts +31 -0
  103. package/components/content-layout/sidebar.js +76 -0
  104. package/components/contenteditable/contenteditable.d.ts +47 -0
  105. package/components/contenteditable/contenteditable.js +47 -0
  106. package/components/control-label/control-label.css +23 -0
  107. package/components/control-label/control-label.d.ts +11 -0
  108. package/components/control-label/control-label.js +22 -0
  109. package/components/data-list/data-list.css +97 -0
  110. package/components/data-list/data-list.d.ts +85 -0
  111. package/components/data-list/data-list.js +119 -0
  112. package/components/data-list/data-list.mock.d.ts +16 -0
  113. package/components/data-list/data-list.mock.js +207 -0
  114. package/components/data-list/item.d.ts +50 -0
  115. package/components/data-list/item.js +114 -0
  116. package/components/data-list/selection.d.ts +16 -0
  117. package/components/data-list/selection.js +81 -0
  118. package/components/data-list/title.d.ts +26 -0
  119. package/components/data-list/title.js +65 -0
  120. package/components/date-picker/consts.d.ts +98 -0
  121. package/components/date-picker/consts.js +44 -0
  122. package/components/date-picker/date-input.d.ts +47 -0
  123. package/components/date-picker/date-input.js +91 -0
  124. package/components/date-picker/date-picker.css +602 -0
  125. package/components/date-picker/date-picker.d.ts +77 -0
  126. package/components/date-picker/date-picker.js +218 -0
  127. package/components/date-picker/date-popup.d.ts +55 -0
  128. package/components/date-picker/date-popup.js +347 -0
  129. package/components/date-picker/day.d.ts +30 -0
  130. package/components/date-picker/day.js +88 -0
  131. package/components/date-picker/formats.d.ts +2 -0
  132. package/components/date-picker/formats.js +1 -0
  133. package/components/date-picker/month-names.d.ts +13 -0
  134. package/components/date-picker/month-names.js +62 -0
  135. package/components/date-picker/month-slider.d.ts +29 -0
  136. package/components/date-picker/month-slider.js +56 -0
  137. package/components/date-picker/month.d.ts +14 -0
  138. package/components/date-picker/month.js +33 -0
  139. package/components/date-picker/months.d.ts +11 -0
  140. package/components/date-picker/months.js +101 -0
  141. package/components/date-picker/weekdays.d.ts +13 -0
  142. package/components/date-picker/weekdays.js +24 -0
  143. package/components/date-picker/years.d.ts +25 -0
  144. package/components/date-picker/years.js +87 -0
  145. package/components/dialog/dialog.css +137 -0
  146. package/components/dialog/dialog.d.ts +64 -0
  147. package/components/dialog/dialog.js +128 -0
  148. package/components/dialog/dialog__body-scroll-preventer.d.ts +9 -0
  149. package/components/dialog/dialog__body-scroll-preventer.js +43 -0
  150. package/components/dropdown/anchor.d.ts +11 -0
  151. package/components/dropdown/anchor.js +16 -0
  152. package/components/dropdown/dropdown.css +18 -0
  153. package/components/dropdown/dropdown.d.ts +87 -0
  154. package/components/dropdown/dropdown.js +159 -0
  155. package/components/dropdown-menu/dropdown-menu.d.ts +36 -0
  156. package/components/dropdown-menu/dropdown-menu.js +56 -0
  157. package/components/editable-heading/editable-heading.css +198 -0
  158. package/components/editable-heading/editable-heading.d.ts +32 -0
  159. package/components/editable-heading/editable-heading.js +141 -0
  160. package/components/error-bubble/error-bubble-legacy.css +77 -0
  161. package/components/error-bubble/error-bubble.css +54 -0
  162. package/components/error-bubble/error-bubble.d.ts +18 -0
  163. package/components/error-bubble/error-bubble.js +28 -0
  164. package/components/error-message/error-message.css +37 -0
  165. package/components/error-message/error-message.d.ts +27 -0
  166. package/components/error-message/error-message.js +37 -0
  167. package/components/error-page/error-page.css +24 -0
  168. package/components/error-page/error-page.gif +0 -0
  169. package/components/footer/footer.css +83 -0
  170. package/components/footer/footer.d.ts +28 -0
  171. package/components/footer/footer.js +97 -0
  172. package/components/form/form.css +266 -0
  173. package/components/form/form.stories.js +138 -0
  174. package/components/global/compose.d.ts +7 -0
  175. package/components/global/compose.js +4 -0
  176. package/components/global/composeRefs.d.ts +3 -0
  177. package/components/global/composeRefs.js +8 -0
  178. package/components/global/controls-height.d.ts +9 -0
  179. package/components/global/controls-height.js +16 -0
  180. package/components/global/create-stateful-context.d.ts +27 -0
  181. package/components/global/create-stateful-context.js +38 -0
  182. package/components/global/data-tests.d.ts +3 -0
  183. package/components/global/data-tests.js +17 -0
  184. package/components/global/dom.d.ts +37 -0
  185. package/components/global/dom.js +83 -0
  186. package/components/global/focus-sensor-hoc.d.ts +19 -0
  187. package/components/global/focus-sensor-hoc.js +102 -0
  188. package/components/global/fuzzy-highlight.d.ts +11 -0
  189. package/components/global/fuzzy-highlight.js +58 -0
  190. package/components/global/get-event-key.d.ts +2 -0
  191. package/components/global/get-event-key.js +100 -0
  192. package/components/global/get-uid.d.ts +1 -0
  193. package/components/global/get-uid.js +16 -0
  194. package/components/global/global.css +101 -0
  195. package/components/global/inject-styles.d.ts +3 -0
  196. package/components/global/inject-styles.js +12 -0
  197. package/components/global/linear-function.d.ts +6 -0
  198. package/components/global/linear-function.js +13 -0
  199. package/components/global/listeners.d.ts +8 -0
  200. package/components/global/listeners.js +27 -0
  201. package/components/global/memoize.d.ts +1 -0
  202. package/components/global/memoize.js +15 -0
  203. package/components/global/normalize-indent.d.ts +1 -0
  204. package/components/global/normalize-indent.js +30 -0
  205. package/components/global/promise-with-timeout.d.ts +5 -0
  206. package/components/global/promise-with-timeout.js +11 -0
  207. package/components/global/prop-types.d.ts +4 -0
  208. package/components/global/prop-types.js +4 -0
  209. package/components/global/react-dom-renderer.d.ts +16 -0
  210. package/components/global/react-dom-renderer.js +25 -0
  211. package/components/global/react-render-adapter.d.ts +1 -0
  212. package/components/global/react-render-adapter.js +3 -0
  213. package/components/global/rerender-hoc.d.ts +10 -0
  214. package/components/global/rerender-hoc.js +14 -0
  215. package/components/global/schedule-raf.d.ts +1 -0
  216. package/components/global/schedule-raf.js +27 -0
  217. package/components/global/sniffer.d.ts +3 -0
  218. package/components/global/sniffer.js +4 -0
  219. package/components/global/theme.d.ts +21 -0
  220. package/components/global/theme.js +70 -0
  221. package/components/global/trivial-template-tag.d.ts +1 -0
  222. package/components/global/trivial-template-tag.js +9 -0
  223. package/components/global/typescript-utils.d.ts +2 -0
  224. package/components/global/typescript-utils.js +2 -0
  225. package/components/global/url.d.ts +57 -0
  226. package/components/global/url.js +136 -0
  227. package/components/global/use-event-callback.d.ts +1 -0
  228. package/components/global/use-event-callback.js +14 -0
  229. package/components/global/variables.css +179 -0
  230. package/components/global/variables.d.ts +89 -0
  231. package/components/global/variables.js +1 -0
  232. package/components/global/variables_dark.css +132 -0
  233. package/components/grid/col.d.ts +31 -0
  234. package/components/grid/col.js +49 -0
  235. package/components/grid/grid.css +915 -0
  236. package/components/grid/grid.d.ts +14 -0
  237. package/components/grid/grid.js +22 -0
  238. package/components/grid/row.d.ts +40 -0
  239. package/components/grid/row.js +51 -0
  240. package/components/group/group.css +7 -0
  241. package/components/group/group.d.ts +12 -0
  242. package/components/group/group.js +20 -0
  243. package/components/header/header.css +169 -0
  244. package/components/header/header.d.ts +34 -0
  245. package/components/header/header.js +46 -0
  246. package/components/header/logo.d.ts +14 -0
  247. package/components/header/logo.js +22 -0
  248. package/components/header/profile.d.ts +75 -0
  249. package/components/header/profile.js +119 -0
  250. package/components/header/services-link.d.ts +25 -0
  251. package/components/header/services-link.js +26 -0
  252. package/components/header/services.css +97 -0
  253. package/components/header/services.d.ts +33 -0
  254. package/components/header/services.js +62 -0
  255. package/components/header/smart-profile.d.ts +36 -0
  256. package/components/header/smart-profile.js +86 -0
  257. package/components/header/smart-services.d.ts +26 -0
  258. package/components/header/smart-services.js +49 -0
  259. package/components/header/tray-icon.d.ts +32 -0
  260. package/components/header/tray-icon.js +20 -0
  261. package/components/header/tray.d.ts +9 -0
  262. package/components/header/tray.js +18 -0
  263. package/components/heading/heading.css +68 -0
  264. package/components/heading/heading.d.ts +25 -0
  265. package/components/heading/heading.js +52 -0
  266. package/components/http/http.d.ts +61 -0
  267. package/components/http/http.js +192 -0
  268. package/components/http/http.mock.d.ts +20 -0
  269. package/components/http/http.mock.js +52 -0
  270. package/components/hub-source/hub-source.d.ts +44 -0
  271. package/components/hub-source/hub-source.js +107 -0
  272. package/components/hub-source/hub-source__user.d.ts +4 -0
  273. package/components/hub-source/hub-source__user.js +20 -0
  274. package/components/hub-source/hub-source__users-groups.d.ts +24 -0
  275. package/components/hub-source/hub-source__users-groups.js +53 -0
  276. package/components/i18n/README.md +46 -0
  277. package/components/i18n/i18n-context.d.ts +13 -0
  278. package/components/i18n/i18n-context.js +14 -0
  279. package/components/i18n/i18n.d.ts +59 -0
  280. package/components/i18n/i18n.js +26 -0
  281. package/components/i18n/messages.json +53 -0
  282. package/components/icon/icon.css +100 -0
  283. package/components/icon/icon.d.ts +43 -0
  284. package/components/icon/icon.js +69 -0
  285. package/components/icon/icon__constants.d.ts +30 -0
  286. package/components/icon/icon__constants.js +32 -0
  287. package/components/icon/icon__svg.d.ts +15 -0
  288. package/components/icon/icon__svg.js +58 -0
  289. package/components/icon/index.d.ts +2 -0
  290. package/components/icon/index.js +2 -0
  291. package/components/input/input-legacy.css +123 -0
  292. package/components/input/input.css +194 -0
  293. package/components/input/input.d.ts +77 -0
  294. package/components/input/input.js +165 -0
  295. package/components/input-size/input-size.css +82 -0
  296. package/components/input-size/input-size.stories.js +73 -0
  297. package/components/island/adaptive-island-hoc.d.ts +61 -0
  298. package/components/island/adaptive-island-hoc.js +28 -0
  299. package/components/island/content.d.ts +43 -0
  300. package/components/island/content.js +100 -0
  301. package/components/island/header.d.ts +8 -0
  302. package/components/island/header.js +78 -0
  303. package/components/island/island.css +131 -0
  304. package/components/island/island.d.ts +78 -0
  305. package/components/island/island.js +31 -0
  306. package/components/island-legacy/content-legacy.d.ts +10 -0
  307. package/components/island-legacy/content-legacy.js +17 -0
  308. package/components/island-legacy/header-legacy.d.ts +10 -0
  309. package/components/island-legacy/header-legacy.js +19 -0
  310. package/components/island-legacy/island-legacy.css +98 -0
  311. package/components/island-legacy/island-legacy.d.ts +12 -0
  312. package/components/island-legacy/island-legacy.js +19 -0
  313. package/components/line/line.css +14 -0
  314. package/components/link/clickableLink.d.ts +20 -0
  315. package/components/link/clickableLink.js +33 -0
  316. package/components/link/link.css +64 -0
  317. package/components/link/link.d.ts +138 -0
  318. package/components/link/link.js +44 -0
  319. package/components/list/consts.d.ts +77 -0
  320. package/components/list/consts.js +25 -0
  321. package/components/list/list.css +298 -0
  322. package/components/list/list.d.ts +205 -0
  323. package/components/list/list.js +590 -0
  324. package/components/list/list.stories.css +3 -0
  325. package/components/list/list__custom.d.ts +6 -0
  326. package/components/list/list__custom.js +52 -0
  327. package/components/list/list__hint.d.ts +15 -0
  328. package/components/list/list__hint.js +16 -0
  329. package/components/list/list__item.d.ts +8 -0
  330. package/components/list/list__item.js +130 -0
  331. package/components/list/list__link.d.ts +9 -0
  332. package/components/list/list__link.js +43 -0
  333. package/components/list/list__separator.d.ts +5 -0
  334. package/components/list/list__separator.js +21 -0
  335. package/components/list/list__title.d.ts +5 -0
  336. package/components/list/list__title.js +28 -0
  337. package/components/list/list__users-groups-source.d.ts +27 -0
  338. package/components/list/list__users-groups-source.js +74 -0
  339. package/components/loader/loader.css +27 -0
  340. package/components/loader/loader.d.ts +28 -0
  341. package/components/loader/loader.js +44 -0
  342. package/components/loader/loader__core.d.ts +75 -0
  343. package/components/loader/loader__core.js +219 -0
  344. package/components/loader-inline/loader-inline.css +73 -0
  345. package/components/loader-inline/loader-inline.d.ts +18 -0
  346. package/components/loader-inline/loader-inline.js +27 -0
  347. package/components/loader-screen/loader-screen.css +29 -0
  348. package/components/loader-screen/loader-screen.d.ts +17 -0
  349. package/components/loader-screen/loader-screen.js +25 -0
  350. package/components/login-dialog/login-dialog.css +23 -0
  351. package/components/login-dialog/login-dialog.d.ts +47 -0
  352. package/components/login-dialog/login-dialog.js +84 -0
  353. package/components/login-dialog/service.d.ts +2 -0
  354. package/components/login-dialog/service.js +24 -0
  355. package/components/markdown/markdown.css +126 -0
  356. package/components/markdown/markdown.d.ts +12 -0
  357. package/components/markdown/markdown.js +25 -0
  358. package/components/message/message.css +61 -0
  359. package/components/message/message.d.ts +55 -0
  360. package/components/message/message.js +129 -0
  361. package/components/old-browsers-message/old-browsers-message.css +26 -0
  362. package/components/old-browsers-message/old-browsers-message.d.ts +2 -0
  363. package/components/old-browsers-message/old-browsers-message.js +83 -0
  364. package/components/old-browsers-message/old-browsers-message__stop.d.ts +1 -0
  365. package/components/old-browsers-message/old-browsers-message__stop.js +2 -0
  366. package/components/old-browsers-message/white-list.d.ts +2 -0
  367. package/components/old-browsers-message/white-list.js +25 -0
  368. package/components/pager/pager.css +19 -0
  369. package/components/pager/pager.d.ts +78 -0
  370. package/components/pager/pager.js +223 -0
  371. package/components/palette/palette.css +216 -0
  372. package/components/panel/panel.css +20 -0
  373. package/components/panel/panel.d.ts +12 -0
  374. package/components/panel/panel.js +20 -0
  375. package/components/permissions/permissions.d.ts +111 -0
  376. package/components/permissions/permissions.js +177 -0
  377. package/components/permissions/permissions__cache.d.ts +93 -0
  378. package/components/permissions/permissions__cache.js +228 -0
  379. package/components/popup/popup.consts.d.ts +37 -0
  380. package/components/popup/popup.consts.js +45 -0
  381. package/components/popup/popup.css +34 -0
  382. package/components/popup/popup.d.ts +147 -0
  383. package/components/popup/popup.js +312 -0
  384. package/components/popup/popup.target.d.ts +7 -0
  385. package/components/popup/popup.target.js +15 -0
  386. package/components/popup/position.d.ts +30 -0
  387. package/components/popup/position.js +202 -0
  388. package/components/popup-menu/popup-menu.d.ts +80 -0
  389. package/components/popup-menu/popup-menu.js +41 -0
  390. package/components/progress-bar/progress-bar.css +82 -0
  391. package/components/progress-bar/progress-bar.d.ts +64 -0
  392. package/components/progress-bar/progress-bar.js +76 -0
  393. package/components/query-assist/query-assist.css +275 -0
  394. package/components/query-assist/query-assist.d.ts +306 -0
  395. package/components/query-assist/query-assist.js +847 -0
  396. package/components/query-assist/query-assist__suggestions.d.ts +29 -0
  397. package/components/query-assist/query-assist__suggestions.js +60 -0
  398. package/components/radio/radio.css +122 -0
  399. package/components/radio/radio.d.ts +18 -0
  400. package/components/radio/radio.js +27 -0
  401. package/components/radio/radio__item.d.ts +28 -0
  402. package/components/radio/radio__item.js +41 -0
  403. package/components/select/select-popup.css +103 -0
  404. package/components/select/select.css +235 -0
  405. package/components/select/select.d.ts +276 -0
  406. package/components/select/select.js +957 -0
  407. package/components/select/select__filter.d.ts +19 -0
  408. package/components/select/select__filter.js +49 -0
  409. package/components/select/select__popup.d.ts +166 -0
  410. package/components/select/select__popup.js +408 -0
  411. package/components/shortcuts/core.d.ts +74 -0
  412. package/components/shortcuts/core.js +191 -0
  413. package/components/shortcuts/shortcut-title.d.ts +1 -0
  414. package/components/shortcuts/shortcut-title.js +50 -0
  415. package/components/shortcuts/shortcuts-hoc.d.ts +65 -0
  416. package/components/shortcuts/shortcuts-hoc.js +19 -0
  417. package/components/shortcuts/shortcuts.d.ts +28 -0
  418. package/components/shortcuts/shortcuts.js +50 -0
  419. package/components/sidebar/sidebar.css +157 -0
  420. package/components/storage/storage.d.ts +18 -0
  421. package/components/storage/storage.js +22 -0
  422. package/components/storage/storage__fallback.d.ts +79 -0
  423. package/components/storage/storage__fallback.js +181 -0
  424. package/components/storage/storage__local.d.ts +38 -0
  425. package/components/storage/storage__local.js +119 -0
  426. package/components/tab-trap/tab-trap.css +6 -0
  427. package/components/tab-trap/tab-trap.d.ts +43 -0
  428. package/components/tab-trap/tab-trap.js +125 -0
  429. package/components/table/cell.d.ts +13 -0
  430. package/components/table/cell.js +16 -0
  431. package/components/table/disable-hover-hoc.d.ts +64 -0
  432. package/components/table/disable-hover-hoc.js +32 -0
  433. package/components/table/header-cell.d.ts +43 -0
  434. package/components/table/header-cell.js +56 -0
  435. package/components/table/header.d.ts +56 -0
  436. package/components/table/header.js +67 -0
  437. package/components/table/multitable.d.ts +25 -0
  438. package/components/table/multitable.js +81 -0
  439. package/components/table/row-with-focus-sensor.d.ts +18 -0
  440. package/components/table/row-with-focus-sensor.js +25 -0
  441. package/components/table/row.d.ts +59 -0
  442. package/components/table/row.js +154 -0
  443. package/components/table/selection-adapter.d.ts +5 -0
  444. package/components/table/selection-adapter.js +10 -0
  445. package/components/table/selection-shortcuts-hoc.d.ts +17 -0
  446. package/components/table/selection-shortcuts-hoc.js +146 -0
  447. package/components/table/selection.d.ts +47 -0
  448. package/components/table/selection.js +150 -0
  449. package/components/table/smart-table.d.ts +64 -0
  450. package/components/table/smart-table.js +40 -0
  451. package/components/table/table.css +259 -0
  452. package/components/table/table.d.ts +159 -0
  453. package/components/table/table.examples2.json +19 -0
  454. package/components/table/table.js +231 -0
  455. package/components/table/table.stories.json +45 -0
  456. package/components/table-legacy/table-legacy.css +346 -0
  457. package/components/table-legacy/table-legacy__toolbar.css +25 -0
  458. package/components/tabs/collapsible-more.d.ts +29 -0
  459. package/components/tabs/collapsible-more.js +97 -0
  460. package/components/tabs/collapsible-tab.d.ts +16 -0
  461. package/components/tabs/collapsible-tab.js +34 -0
  462. package/components/tabs/collapsible-tabs.d.ts +43 -0
  463. package/components/tabs/collapsible-tabs.js +196 -0
  464. package/components/tabs/custom-item.d.ts +9 -0
  465. package/components/tabs/custom-item.js +5 -0
  466. package/components/tabs/dumb-tabs.d.ts +35 -0
  467. package/components/tabs/dumb-tabs.js +56 -0
  468. package/components/tabs/smart-tabs.d.ts +20 -0
  469. package/components/tabs/smart-tabs.js +25 -0
  470. package/components/tabs/tab-link.d.ts +18 -0
  471. package/components/tabs/tab-link.js +24 -0
  472. package/components/tabs/tab.d.ts +27 -0
  473. package/components/tabs/tab.js +19 -0
  474. package/components/tabs/tabs.css +223 -0
  475. package/components/tabs/tabs.d.ts +7 -0
  476. package/components/tabs/tabs.js +7 -0
  477. package/components/tag/tag.css +184 -0
  478. package/components/tag/tag.d.ts +64 -0
  479. package/components/tag/tag.js +130 -0
  480. package/components/tags-input/tags-input.css +100 -0
  481. package/components/tags-input/tags-input.d.ts +138 -0
  482. package/components/tags-input/tags-input.js +275 -0
  483. package/components/tags-list/tags-list.d.ts +46 -0
  484. package/components/tags-list/tags-list.js +45 -0
  485. package/components/text/text.css +21 -0
  486. package/components/text/text.d.ts +23 -0
  487. package/components/text/text.js +31 -0
  488. package/components/toggle/toggle.css +198 -0
  489. package/components/toggle/toggle.d.ts +39 -0
  490. package/components/toggle/toggle.js +46 -0
  491. package/components/tooltip/tooltip.css +17 -0
  492. package/components/tooltip/tooltip.d.ts +65 -0
  493. package/components/tooltip/tooltip.js +126 -0
  494. package/components/user-agreement/service.d.ts +69 -0
  495. package/components/user-agreement/service.js +242 -0
  496. package/components/user-agreement/toolbox.eula.d.ts +2 -0
  497. package/components/user-agreement/toolbox.eula.js +160 -0
  498. package/components/user-agreement/user-agreement.css +29 -0
  499. package/components/user-agreement/user-agreement.d.ts +60 -0
  500. package/components/user-agreement/user-agreement.js +80 -0
  501. package/components/user-card/card.d.ts +70 -0
  502. package/components/user-card/card.js +89 -0
  503. package/components/user-card/smart-user-card-tooltip.d.ts +20 -0
  504. package/components/user-card/smart-user-card-tooltip.js +47 -0
  505. package/components/user-card/tooltip.d.ts +36 -0
  506. package/components/user-card/tooltip.js +43 -0
  507. package/components/user-card/user-card.css +123 -0
  508. package/components/user-card/user-card.d.ts +11 -0
  509. package/components/user-card/user-card.js +11 -0
  510. package/package.json +61 -61
@@ -0,0 +1,834 @@
1
+ import { fixUrl, getAbsoluteBaseURL } from '../global/url';
2
+ import Listeners from '../global/listeners';
3
+ import HTTP from '../http/http';
4
+ import promiseWithTimeout from '../global/promise-with-timeout';
5
+ import { getTranslations, getTranslationsWithFallback, translate } from '../i18n/i18n';
6
+ import AuthStorage from './storage';
7
+ import AuthResponseParser from './response-parser';
8
+ import AuthRequestBuilder from './request-builder';
9
+ import BackgroundFlow from './background-flow';
10
+ import TokenValidator from './token-validator';
11
+ /* eslint-disable @typescript-eslint/no-magic-numbers */
12
+ export const DEFAULT_EXPIRES_TIMEOUT = 40 * 60;
13
+ export const DEFAULT_BACKGROUND_TIMEOUT = 10 * 1000;
14
+ const DEFAULT_BACKEND_CHECK_TIMEOUT = 10 * 1000;
15
+ const BACKGROUND_REDIRECT_TIMEOUT = 20 * 1000;
16
+ const DEFAULT_WAIT_FOR_REDIRECT_TIMEOUT = 5 * 1000;
17
+ /* eslint-enable @typescript-eslint/no-magic-numbers */
18
+ export const USER_CHANGED_EVENT = 'userChange';
19
+ export const DOMAIN_USER_CHANGED_EVENT = 'domainUser';
20
+ export const LOGOUT_EVENT = 'logout';
21
+ export const LOGOUT_POSTPONED_EVENT = 'logoutPostponed';
22
+ export const USER_CHANGE_POSTPONED_EVENT = 'changePostponed';
23
+ function noop() { }
24
+ const DEFAULT_CONFIG = {
25
+ cacheCurrentUser: false,
26
+ reloadOnUserChange: true,
27
+ embeddedLogin: false,
28
+ EmbeddedLoginFlow: null,
29
+ clientId: '0-0-0-0-0',
30
+ redirectUri: getAbsoluteBaseURL(),
31
+ redirect: false,
32
+ requestCredentials: 'default',
33
+ backgroundRefreshTimeout: null,
34
+ scope: [],
35
+ userFields: ['guest', 'id', 'name', 'login', 'profile/avatar/url'],
36
+ cleanHash: true,
37
+ onLogout: noop,
38
+ onPostponeChangedUser: () => { },
39
+ onPostponeLogout: () => { },
40
+ enableBackendStatusCheck: true,
41
+ backendCheckTimeout: DEFAULT_BACKEND_CHECK_TIMEOUT,
42
+ checkBackendIsUp: () => Promise.resolve(null),
43
+ onBackendDown: () => () => { },
44
+ defaultExpiresIn: DEFAULT_EXPIRES_TIMEOUT,
45
+ waitForRedirectTimeout: DEFAULT_WAIT_FOR_REDIRECT_TIMEOUT,
46
+ translations: null
47
+ };
48
+ export default class Auth {
49
+ static DEFAULT_CONFIG = DEFAULT_CONFIG;
50
+ static API_PATH = 'api/rest/';
51
+ static API_AUTH_PATH = 'oauth2/auth';
52
+ static API_PROFILE_PATH = 'users/me';
53
+ static CLOSE_BACKEND_DOWN_MESSAGE = 'backend-check-succeeded';
54
+ static CLOSE_WINDOW_MESSAGE = 'close-login-window';
55
+ static shouldRefreshToken = TokenValidator.shouldRefreshToken;
56
+ static storageIsUnavailable = !navigator.cookieEnabled;
57
+ config;
58
+ listeners = new Listeners();
59
+ http;
60
+ _service = {};
61
+ _storage = null;
62
+ _responseParser = new AuthResponseParser();
63
+ _requestBuilder = null;
64
+ _backgroundFlow;
65
+ _embeddedFlow = null;
66
+ _tokenValidator = null;
67
+ _postponed = false;
68
+ _backendCheckPromise = null;
69
+ _authDialogService = undefined;
70
+ _domainStorage;
71
+ user = null;
72
+ _initDeferred;
73
+ _isLoginWindowOpen;
74
+ constructor(config) {
75
+ if (!config) {
76
+ throw new Error('Config is required');
77
+ }
78
+ if (config.serverUri == null) {
79
+ throw new Error('\"serverUri\" property is required');
80
+ }
81
+ const unsupportedParams = ['redirect_uri', 'request_credentials', 'client_id'].filter(param => config.hasOwnProperty(param));
82
+ if (unsupportedParams.length !== 0) {
83
+ throw new Error(`The following parameters are no longer supported: ${unsupportedParams.join(', ')}. Please change them from snake_case to camelCase.`);
84
+ }
85
+ config.userFields = config.userFields || [];
86
+ this.config = { ...Auth.DEFAULT_CONFIG, ...config };
87
+ const { clientId, redirect, redirectUri, requestCredentials, scope } = this.config;
88
+ const serverUriLength = this.config.serverUri.length;
89
+ if (serverUriLength > 0 && this.config.serverUri.charAt(serverUriLength - 1) !== '/') {
90
+ this.config.serverUri += '/';
91
+ }
92
+ this.config.userParams = {
93
+ query: {
94
+ fields: [...new Set(Auth.DEFAULT_CONFIG.userFields.concat(config.userFields))].join()
95
+ }
96
+ };
97
+ if (!scope.includes(Auth.DEFAULT_CONFIG.clientId)) {
98
+ scope.push(Auth.DEFAULT_CONFIG.clientId);
99
+ }
100
+ this._storage = new AuthStorage({
101
+ messagePrefix: `${clientId}-message-`,
102
+ stateKeyPrefix: `${clientId}-states-`,
103
+ tokenKey: `${clientId}-token`,
104
+ userKey: `${clientId}-user-`
105
+ });
106
+ this._domainStorage = new AuthStorage({ messagePrefix: 'domain-message-' });
107
+ this._requestBuilder = new AuthRequestBuilder({
108
+ authorization: this.config.serverUri + Auth.API_PATH + Auth.API_AUTH_PATH,
109
+ clientId,
110
+ redirect,
111
+ redirectUri,
112
+ requestCredentials,
113
+ scopes: scope
114
+ }, this._storage);
115
+ let { backgroundRefreshTimeout } = this.config;
116
+ if (!backgroundRefreshTimeout) {
117
+ backgroundRefreshTimeout = this.config.embeddedLogin
118
+ ? DEFAULT_BACKGROUND_TIMEOUT
119
+ : BACKGROUND_REDIRECT_TIMEOUT;
120
+ }
121
+ this._backgroundFlow = new BackgroundFlow(this._requestBuilder, this._storage, backgroundRefreshTimeout);
122
+ if (this.config.EmbeddedLoginFlow) {
123
+ this._embeddedFlow = new this.config.EmbeddedLoginFlow(this._requestBuilder, this._storage, this.config.translations ?? getTranslationsWithFallback());
124
+ }
125
+ const API_BASE = this.config.serverUri + Auth.API_PATH;
126
+ const fetchConfig = config.fetchCredentials
127
+ ? { credentials: config.fetchCredentials }
128
+ : undefined;
129
+ this.http = new HTTP(this, API_BASE, fetchConfig);
130
+ const getUser = async (token) => {
131
+ const user = await this.getUser(token);
132
+ this.user = user;
133
+ return user;
134
+ };
135
+ this._tokenValidator = new TokenValidator(this.config, getUser, this._storage);
136
+ if (this.config.onLogout) {
137
+ this.addListener(LOGOUT_EVENT, this.config.onLogout);
138
+ }
139
+ if (this.config.reloadOnUserChange) {
140
+ this.addListener(USER_CHANGED_EVENT, () => this._reloadCurrentPage());
141
+ }
142
+ this.addListener(LOGOUT_POSTPONED_EVENT, () => this._setPostponed(true));
143
+ this.addListener(USER_CHANGE_POSTPONED_EVENT, () => this._setPostponed(true));
144
+ this.addListener(USER_CHANGED_EVENT, () => this._setPostponed(false));
145
+ this.addListener(USER_CHANGED_EVENT, (user) => {
146
+ if (user) {
147
+ this._updateDomainUser(user.id);
148
+ }
149
+ });
150
+ if (this.config.cacheCurrentUser) {
151
+ this.addListener(LOGOUT_EVENT, () => this._storage?.wipeCachedCurrentUser());
152
+ this.addListener(USER_CHANGED_EVENT, () => this._storage?.onUserChanged());
153
+ }
154
+ this._createInitDeferred();
155
+ this.setUpPreconnect(config.serverUri);
156
+ }
157
+ _setPostponed(postponed = false) {
158
+ this._postponed = postponed;
159
+ }
160
+ _updateDomainUser(userID) {
161
+ this._domainStorage.sendMessage(DOMAIN_USER_CHANGED_EVENT, {
162
+ userID,
163
+ serviceID: this.config.clientId
164
+ });
165
+ }
166
+ addListener(event, handler) {
167
+ this.listeners.add(event, handler);
168
+ }
169
+ removeListener(event, handler) {
170
+ this.listeners.remove(event, handler);
171
+ }
172
+ setAuthDialogService(authDialogService) {
173
+ this._authDialogService = authDialogService;
174
+ }
175
+ setCurrentService(service) {
176
+ this._service = service;
177
+ }
178
+ _createInitDeferred() {
179
+ const deferred = {};
180
+ deferred.promise = new Promise((resolve, reject) => {
181
+ deferred.resolve = resolve;
182
+ deferred.reject = reject;
183
+ });
184
+ this._initDeferred = deferred;
185
+ }
186
+ /**
187
+ * @return {Promise.<string>} absolute URL promise that is resolved to a URL
188
+ * that should be restored after returning back from auth server.
189
+ */
190
+ async init() {
191
+ this._storage?.onTokenChange(async (token) => {
192
+ const isGuest = this.user ? this.user.guest : false;
193
+ if (isGuest && !token) {
194
+ return;
195
+ }
196
+ if (!token) {
197
+ this.logout();
198
+ }
199
+ else {
200
+ try {
201
+ await this._detectUserChange(token.accessToken);
202
+ }
203
+ catch (error) {
204
+ if (!(error instanceof Error)) {
205
+ throw error;
206
+ }
207
+ if (this._canShowDialogs()) {
208
+ this._showAuthDialog({ nonInteractive: true, error });
209
+ }
210
+ }
211
+ }
212
+ });
213
+ this._domainStorage.onMessage(DOMAIN_USER_CHANGED_EVENT, (message) => {
214
+ const { userID, serviceID } = message || {};
215
+ if (serviceID === this.config.clientId) {
216
+ return;
217
+ }
218
+ if (this.user && userID === this.user.id) {
219
+ return;
220
+ }
221
+ this.forceTokenUpdate();
222
+ });
223
+ let state;
224
+ try {
225
+ // Look for token or error in hash
226
+ state = await this._checkForAuthResponse();
227
+ }
228
+ catch (error) {
229
+ return error instanceof Error ? this.handleInitError(error) : undefined;
230
+ }
231
+ // Return endless promise in the background to avoid service start
232
+ if (state && state.nonRedirect) {
233
+ return new Promise(noop);
234
+ }
235
+ try {
236
+ // Check if there is a valid token
237
+ await this._tokenValidator?.validateToken();
238
+ // Checking if there is a message left by another app on this domain
239
+ const message = await this._domainStorage._messagesStorage.get(`domain-message-${DOMAIN_USER_CHANGED_EVENT}`);
240
+ if (message) {
241
+ const { userID, serviceID } = message;
242
+ if (serviceID !== this.config.clientId && (!userID || this.user?.id !== userID)) {
243
+ this.forceTokenUpdate();
244
+ }
245
+ }
246
+ // Access token appears to be valid.
247
+ // We may resolve restoreLocation URL now
248
+ if (!state) {
249
+ // Check if we have requested to restore state anyway
250
+ state = await this._checkForStateRestoration();
251
+ }
252
+ this._initDeferred?.resolve?.(state && state.restoreLocation);
253
+ return state?.restoreLocation;
254
+ }
255
+ catch (error) {
256
+ if (Auth.storageIsUnavailable) {
257
+ this._initDeferred?.resolve?.(); // No way to handle if cookies are disabled
258
+ await this.requestUser(); // Someone may expect user to be loaded as a part of token validation
259
+ return null;
260
+ }
261
+ return error instanceof Error ? this.handleInitValidationError(error) : undefined;
262
+ }
263
+ }
264
+ async sendRedirect(error) {
265
+ const authRequest = await this._requestBuilder?.prepareAuthRequest();
266
+ if (authRequest != null) {
267
+ this._redirectCurrentPage(authRequest.url);
268
+ }
269
+ // HUB-10867 Since we already redirecting the page, there is no actual need to throw an error
270
+ // and scare user with flashing error
271
+ // But let's keep it just in case redirect was not successful
272
+ await new Promise(resolve => setTimeout(resolve, this.config.waitForRedirectTimeout));
273
+ throw error;
274
+ }
275
+ async handleInitError(error) {
276
+ if ('stateId' in error && error.stateId) {
277
+ try {
278
+ const state = await this._storage?.getState(error.stateId);
279
+ if (state && state.nonRedirect) {
280
+ state.error = error;
281
+ this._storage?.saveState(error.stateId, state);
282
+ // Return endless promise in the background to avoid service start
283
+ return new Promise(noop);
284
+ }
285
+ }
286
+ catch (e) {
287
+ // Throw the original error instead below
288
+ }
289
+ }
290
+ throw error;
291
+ }
292
+ async handleInitValidationError(error) {
293
+ if ('cause' in error && error.cause instanceof Error && error.cause?.message === 'invalid_client') {
294
+ // eslint-disable-next-line no-console
295
+ console.error('RingUI Auth: invalid client detected. Logging out', error);
296
+ await this.logout();
297
+ return undefined;
298
+ }
299
+ // Redirect flow
300
+ if ('authRedirect' in error && error.authRedirect && this.config.redirect) {
301
+ return this.sendRedirect(error);
302
+ }
303
+ // Background flow
304
+ if ('authRedirect' in error && error.authRedirect && !this.config.redirect) {
305
+ try {
306
+ await this._backgroundFlow?.authorize();
307
+ await this._tokenValidator?.validateToken();
308
+ this._initDeferred?.resolve?.();
309
+ return undefined;
310
+ }
311
+ catch (validationError) {
312
+ // Fallback to redirect flow
313
+ return validationError instanceof Error ? this.sendRedirect(validationError) : undefined;
314
+ }
315
+ }
316
+ this._initDeferred?.reject?.(error);
317
+ throw error;
318
+ }
319
+ /**
320
+ * Get token from local storage or request it if necessary.
321
+ * Can redirect to login page.
322
+ * @return {Promise.<string>}
323
+ */
324
+ async requestToken() {
325
+ if (this._postponed) {
326
+ throw new Error('You should log in to be able to make requests');
327
+ }
328
+ try {
329
+ await this._initDeferred?.promise;
330
+ if (Auth.storageIsUnavailable) {
331
+ return null; // Forever guest if storage is unavailable
332
+ }
333
+ return await this._tokenValidator?.validateTokenLocally() ?? null;
334
+ }
335
+ catch (e) {
336
+ return this.forceTokenUpdate();
337
+ }
338
+ }
339
+ /**
340
+ * Get new token in the background or redirect to the login page.
341
+ * @return {Promise.<string>}
342
+ */
343
+ async forceTokenUpdate() {
344
+ try {
345
+ if (!this._backendCheckPromise) {
346
+ this._backendCheckPromise = this._checkBackendsStatusesIfEnabled();
347
+ }
348
+ await this._backendCheckPromise;
349
+ }
350
+ catch (e) {
351
+ throw new Error('Cannot refresh token: backend is not available. Postponed by user.');
352
+ }
353
+ finally {
354
+ this._backendCheckPromise = null;
355
+ }
356
+ try {
357
+ return await this._backgroundFlow?.authorize() ?? null;
358
+ }
359
+ catch (error) {
360
+ if (!(error instanceof Error)) {
361
+ return null;
362
+ }
363
+ if (this._canShowDialogs()) {
364
+ return new Promise(resolve => {
365
+ const onTryAgain = async () => {
366
+ try {
367
+ const result = await this._backgroundFlow?.authorize();
368
+ resolve(result ?? null);
369
+ }
370
+ catch (retryError) {
371
+ if (retryError instanceof Error) {
372
+ this._showAuthDialog({
373
+ nonInteractive: true,
374
+ error: retryError,
375
+ onTryAgain
376
+ });
377
+ }
378
+ throw retryError;
379
+ }
380
+ };
381
+ this._showAuthDialog({
382
+ nonInteractive: true,
383
+ error: error,
384
+ onTryAgain
385
+ });
386
+ });
387
+ }
388
+ else {
389
+ const authRequest = await this._requestBuilder?.prepareAuthRequest();
390
+ if (authRequest != null) {
391
+ this._redirectCurrentPage(authRequest.url);
392
+ }
393
+ }
394
+ throw new TokenValidator.TokenValidationError(error.message);
395
+ }
396
+ }
397
+ async loadCurrentService() {
398
+ if (this._service.serviceName) {
399
+ return;
400
+ }
401
+ try {
402
+ const { serviceName, iconUrl: serviceImage } = await this.http.get(`oauth2/interactive/login/settings?client_id=${this.config.clientId}`) || {};
403
+ this.setCurrentService({ serviceImage, serviceName });
404
+ }
405
+ catch (e) {
406
+ // noop
407
+ }
408
+ }
409
+ getAPIPath() {
410
+ return this.config.serverUri + Auth.API_PATH;
411
+ }
412
+ /**
413
+ * @return {Promise.<object>}
414
+ */
415
+ getUser(accessToken) {
416
+ if (this.config.cacheCurrentUser) {
417
+ return this._storage?.getCachedUser(() => this.http.authorizedFetch(Auth.API_PROFILE_PATH, accessToken, this.config.userParams));
418
+ }
419
+ else {
420
+ return this.http.authorizedFetch(Auth.API_PROFILE_PATH, accessToken, this.config.userParams);
421
+ }
422
+ }
423
+ /**
424
+ * @return {Promise.<object>}
425
+ */
426
+ async requestUser() {
427
+ if (this.user) {
428
+ return this.user;
429
+ }
430
+ const accessToken = await this.requestToken();
431
+ // If user was fetched during token request
432
+ if (this.user) {
433
+ return this.user;
434
+ }
435
+ const user = await this.getUser(accessToken);
436
+ this.user = user;
437
+ return user;
438
+ }
439
+ async updateUser() {
440
+ this._setPostponed(false);
441
+ const accessToken = await this.requestToken();
442
+ this._storage?.wipeCachedCurrentUser();
443
+ const user = await this.getUser(accessToken);
444
+ this.user = user;
445
+ this.listeners.trigger(USER_CHANGED_EVENT, user);
446
+ }
447
+ async _detectUserChange(accessToken) {
448
+ const windowWasOpen = this._isLoginWindowOpen;
449
+ const user = await this.getUser(accessToken);
450
+ const onApply = () => {
451
+ this.user = user;
452
+ this.listeners.trigger(USER_CHANGED_EVENT, user);
453
+ };
454
+ if (user && this.user && this.user.id !== user.id) {
455
+ if (!this._canShowDialogs() || this.user.guest || windowWasOpen) {
456
+ onApply();
457
+ return;
458
+ }
459
+ if (user.guest) {
460
+ this._showAuthDialog({ nonInteractive: true });
461
+ return;
462
+ }
463
+ await this._showUserChangedDialog({
464
+ newUser: user,
465
+ onApply,
466
+ onPostpone: () => {
467
+ this.listeners.trigger(USER_CHANGE_POSTPONED_EVENT);
468
+ this.config.onPostponeChangedUser(this.user, user);
469
+ }
470
+ });
471
+ }
472
+ }
473
+ _beforeLogout(params) {
474
+ if (this._canShowDialogs()) {
475
+ this._showAuthDialog(params);
476
+ return;
477
+ }
478
+ this.logout();
479
+ }
480
+ _showAuthDialog({ nonInteractive, error, canCancel, onTryAgain } = {}) {
481
+ const { embeddedLogin, onPostponeLogout, translations } = this.config;
482
+ const cancelable = this.user?.guest || canCancel;
483
+ const actualTranslations = translations ?? getTranslations();
484
+ this._createInitDeferred();
485
+ const closeDialog = () => {
486
+ /* eslint-disable @typescript-eslint/no-use-before-define */
487
+ stopTokenListening?.();
488
+ stopMessageListening?.();
489
+ hide?.();
490
+ /* eslint-enable @typescript-eslint/no-use-before-define */
491
+ };
492
+ const onConfirm = () => {
493
+ if (!embeddedLogin) {
494
+ closeDialog();
495
+ this.logout();
496
+ return;
497
+ }
498
+ this._runEmbeddedLogin();
499
+ };
500
+ const onCancel = () => {
501
+ this._embeddedFlow?.stop();
502
+ this._storage?.sendMessage(Auth.CLOSE_WINDOW_MESSAGE, Date.now());
503
+ closeDialog();
504
+ if (!cancelable) {
505
+ this._initDeferred?.resolve?.();
506
+ this.listeners.trigger(LOGOUT_POSTPONED_EVENT);
507
+ onPostponeLogout();
508
+ return;
509
+ }
510
+ if (this.user?.guest && nonInteractive) {
511
+ this.forceTokenUpdate();
512
+ }
513
+ else {
514
+ this._initDeferred?.resolve?.();
515
+ }
516
+ };
517
+ const onTryAgainClick = async () => {
518
+ await onTryAgain?.();
519
+ closeDialog();
520
+ };
521
+ const hide = this._authDialogService?.({
522
+ ...this._service,
523
+ loginCaption: actualTranslations.login,
524
+ loginToCaption: actualTranslations.loginTo,
525
+ confirmLabel: actualTranslations.login,
526
+ tryAgainLabel: actualTranslations.tryAgainLabel,
527
+ cancelLabel: cancelable ? actualTranslations.cancel : actualTranslations.postpone,
528
+ errorMessage: this._extractErrorMessage(error, true),
529
+ onConfirm,
530
+ onCancel,
531
+ onTryAgain: onTryAgain ? onTryAgainClick : undefined
532
+ });
533
+ const stopTokenListening = this._storage?.onTokenChange(token => {
534
+ if (token) {
535
+ closeDialog();
536
+ this._initDeferred?.resolve?.();
537
+ }
538
+ });
539
+ const stopMessageListening = this._storage?.onMessage(Auth.CLOSE_WINDOW_MESSAGE, () => this._embeddedFlow?.stop());
540
+ }
541
+ _showUserChangedDialog({ newUser, onApply, onPostpone }) {
542
+ const { translations } = this.config;
543
+ this._createInitDeferred();
544
+ const done = () => {
545
+ this._initDeferred?.resolve?.();
546
+ // eslint-disable-next-line @typescript-eslint/no-use-before-define
547
+ hide?.();
548
+ };
549
+ const hide = this._authDialogService?.({
550
+ ...this._service,
551
+ title: translations?.youHaveLoggedInAs ?? translate('youHaveLoggedInAs').
552
+ replace('%userName%', newUser.name ?? '').
553
+ replace('{{userName}}', newUser.name ?? ''),
554
+ loginCaption: translations?.login ?? translate('login'),
555
+ loginToCaption: translations?.loginTo ?? translate('loginTo'),
556
+ confirmLabel: translations?.applyChange ?? translate('applyChange'),
557
+ tryAgainLabel: translations?.tryAgainLabel ?? translate('tryAgainLabel'),
558
+ cancelLabel: translations?.postpone ?? translate('postpone'),
559
+ onConfirm: () => {
560
+ done();
561
+ onApply();
562
+ },
563
+ onCancel: () => {
564
+ done();
565
+ onPostpone();
566
+ }
567
+ });
568
+ }
569
+ _extractErrorMessage(error, logError = false) {
570
+ if (!error) {
571
+ return null;
572
+ }
573
+ if (logError) {
574
+ // eslint-disable-next-line no-console
575
+ console.error('RingUI Auth error', error);
576
+ }
577
+ try {
578
+ // We've got some error from this list
579
+ // https://www.jetbrains.com/help/youtrack/devportal/OAuth-2.0-Errors.html
580
+ if ('code' in error && error.code && typeof error.code === 'object' && 'code' in error.code && typeof error.code.code === 'string') {
581
+ const readableCode = error.code.code.split('_').join(' ');
582
+ return `Authorization error: ${readableCode}`;
583
+ }
584
+ }
585
+ catch {
586
+ // noop
587
+ }
588
+ return error.toString ? error.toString() : null;
589
+ }
590
+ _showBackendDownDialog(backendError) {
591
+ const { onBackendDown, translations } = this.config;
592
+ const REPEAT_TIMEOUT = 5000;
593
+ let timerId;
594
+ return new Promise((resolve, reject) => {
595
+ const done = () => {
596
+ /* eslint-disable @typescript-eslint/no-use-before-define */
597
+ hide();
598
+ window.removeEventListener('online', onCheckAgain);
599
+ stopListeningCloseMessage?.();
600
+ /* eslint-enable @typescript-eslint/no-use-before-define */
601
+ this._storage?.sendMessage(Auth.CLOSE_BACKEND_DOWN_MESSAGE, Date.now());
602
+ clearTimeout(timerId);
603
+ };
604
+ const stopListeningCloseMessage = this._storage?.onMessage(Auth.CLOSE_BACKEND_DOWN_MESSAGE, () => {
605
+ stopListeningCloseMessage?.();
606
+ done();
607
+ resolve();
608
+ });
609
+ const onCheckAgain = async () => {
610
+ await this._checkBackendsAreUp();
611
+ done();
612
+ resolve();
613
+ };
614
+ const onPostpone = () => {
615
+ done();
616
+ reject(new Error('Auth(@jetbrains/ring-ui): postponed by user'));
617
+ };
618
+ const hide = onBackendDown({
619
+ onCheckAgain, onPostpone, backendError,
620
+ translations: translations ?? getTranslationsWithFallback()
621
+ });
622
+ window.addEventListener('online', onCheckAgain);
623
+ function networkWatchdog() {
624
+ if (navigator && navigator.onLine) {
625
+ onCheckAgain();
626
+ }
627
+ timerId = window.setTimeout(networkWatchdog, REPEAT_TIMEOUT);
628
+ }
629
+ timerId = window.setTimeout(networkWatchdog, REPEAT_TIMEOUT);
630
+ });
631
+ }
632
+ /**
633
+ * Wipe accessToken and redirect to auth page with required authorization
634
+ */
635
+ async logout(extraParams) {
636
+ const requestParams = {
637
+ // eslint-disable-next-line camelcase
638
+ request_credentials: 'required',
639
+ ...extraParams
640
+ };
641
+ await this._checkBackendsStatusesIfEnabled();
642
+ await this.listeners.trigger('logout');
643
+ this._updateDomainUser(null);
644
+ await this._storage?.wipeToken();
645
+ const authRequest = await this._requestBuilder?.prepareAuthRequest(requestParams);
646
+ if (authRequest != null) {
647
+ this._redirectCurrentPage(authRequest.url);
648
+ }
649
+ }
650
+ async _runEmbeddedLogin() {
651
+ this._storage?.sendMessage(Auth.CLOSE_WINDOW_MESSAGE, Date.now());
652
+ try {
653
+ this._isLoginWindowOpen = true;
654
+ return await this._embeddedFlow?.authorize();
655
+ }
656
+ catch (e) {
657
+ throw e;
658
+ }
659
+ finally {
660
+ this._isLoginWindowOpen = false;
661
+ }
662
+ }
663
+ /**
664
+ * Wipe accessToken and redirect to auth page to obtain authorization data
665
+ * if user is logged in or log her in otherwise
666
+ */
667
+ async login() {
668
+ if (this.config.embeddedLogin) {
669
+ await this._runEmbeddedLogin();
670
+ return;
671
+ }
672
+ await this._checkBackendsStatusesIfEnabled();
673
+ try {
674
+ const accessToken = await this._backgroundFlow?.authorize();
675
+ const user = await this.getUser(accessToken);
676
+ if (user.guest) {
677
+ this._beforeLogout();
678
+ }
679
+ else {
680
+ this.user = user;
681
+ this.listeners.trigger(USER_CHANGED_EVENT, user);
682
+ }
683
+ }
684
+ catch (e) {
685
+ this._beforeLogout();
686
+ }
687
+ }
688
+ async switchUser() {
689
+ if (!this.config.embeddedLogin) {
690
+ throw new Error('Auth: switchUser only supported for "embeddedLogin" mode');
691
+ }
692
+ await this._runEmbeddedLogin();
693
+ }
694
+ _makeStateFromResponse(authResponse) {
695
+ const { state } = authResponse;
696
+ if (!state) {
697
+ return {};
698
+ }
699
+ const { scope: defaultScope } = this.config;
700
+ try {
701
+ const urlFromState = new URL(state); // checking if state contains valid URL on same origin, see HUB-11514
702
+ if (urlFromState.origin !== window.location.origin) {
703
+ return {};
704
+ }
705
+ return {
706
+ restoreLocation: state,
707
+ created: Date.now(),
708
+ scopes: defaultScope
709
+ };
710
+ }
711
+ catch (e) {
712
+ return {};
713
+ }
714
+ }
715
+ /**
716
+ * Check if the hash contains an access token.
717
+ * If it does, extract the state, compare with
718
+ * config, and store the auth response for later use.
719
+ *
720
+ * @return {Promise} promise that is resolved to restoreLocation URL, or rejected
721
+ * @private
722
+ */
723
+ async _checkForAuthResponse() {
724
+ // getAuthResponseURL may throw an exception
725
+ const authResponse = this._responseParser.getAuthResponseFromURL();
726
+ const { scope: defaultScope, defaultExpiresIn, cleanHash } = this.config;
727
+ if (authResponse && cleanHash) {
728
+ this.setHash('');
729
+ }
730
+ if (!authResponse) {
731
+ return undefined;
732
+ }
733
+ const { state: stateId, scope, expiresIn, accessToken } = authResponse;
734
+ const newState = await (stateId && this._storage?.getState(stateId)) ||
735
+ this._makeStateFromResponse(authResponse);
736
+ const scopes = scope ? scope.split(' ') : newState.scopes || defaultScope || [];
737
+ const effectiveExpiresIn = expiresIn ? parseInt(expiresIn, 10) : defaultExpiresIn;
738
+ const expires = TokenValidator._epoch() + effectiveExpiresIn;
739
+ if (accessToken != null) {
740
+ await this._storage?.saveToken({ accessToken, scopes, expires, lifeTime: effectiveExpiresIn });
741
+ }
742
+ return newState;
743
+ }
744
+ async _checkForStateRestoration() {
745
+ const authResponse = this._responseParser._authResponse;
746
+ if (authResponse && this.config.cleanHash) {
747
+ this.setHash('');
748
+ }
749
+ const stateId = authResponse?.restoreAuthState;
750
+ return await (stateId && this._storage?.getState(stateId)) || {};
751
+ }
752
+ _checkBackendsAreUp() {
753
+ const abortCtrl = new AbortController();
754
+ const { backendCheckTimeout } = this.config;
755
+ return Promise.all([
756
+ promiseWithTimeout(this.http.fetch('settings/public?fields=id', { signal: abortCtrl.signal }), backendCheckTimeout, {
757
+ error: new Error('The authorization server is taking too long to respond. Please try again later.'),
758
+ onTimeout: () => abortCtrl.abort()
759
+ }),
760
+ this.config.checkBackendIsUp()
761
+ ]).catch(err => {
762
+ if (err instanceof TypeError) {
763
+ throw new TypeError('Could not connect to the server due to network error. Please check your connection and try again.');
764
+ }
765
+ throw err;
766
+ });
767
+ }
768
+ async _checkBackendsStatusesIfEnabled() {
769
+ if (!this.config.enableBackendStatusCheck) {
770
+ return;
771
+ }
772
+ try {
773
+ await this._checkBackendsAreUp();
774
+ }
775
+ catch (backendDownErr) {
776
+ if (backendDownErr instanceof Error) {
777
+ await this._showBackendDownDialog(backendDownErr);
778
+ }
779
+ }
780
+ }
781
+ /**
782
+ * Adds preconnect tag to help browser to establish connection to URL.
783
+ * See https://w3c.github.io/resource-hints/
784
+ * @param url Url to preconnect to.
785
+ */
786
+ setUpPreconnect(url) {
787
+ const linkNode = document.createElement('link');
788
+ linkNode.rel = 'preconnect';
789
+ linkNode.href = url;
790
+ linkNode.pr = '1.0';
791
+ linkNode.crossOrigin = 'use-credentials';
792
+ document.head.appendChild(linkNode);
793
+ }
794
+ /**
795
+ * Redirects current page to the given URL
796
+ * @param {string} url
797
+ * @private
798
+ */
799
+ _redirectCurrentPage(url) {
800
+ if (process.env.NODE_ENV !== 'test') {
801
+ window.location.href = fixUrl(url);
802
+ }
803
+ }
804
+ /**
805
+ * Reloads current page
806
+ */
807
+ _reloadCurrentPage() {
808
+ this._redirectCurrentPage(window.location.href);
809
+ }
810
+ _canShowDialogs() {
811
+ return this.config.embeddedLogin && this._authDialogService;
812
+ }
813
+ /**
814
+ * Sets the location hash
815
+ * @param {string} hash
816
+ */
817
+ setHash(hash) {
818
+ if (history.replaceState) {
819
+ // NB! History.replaceState is used here, because Firefox saves
820
+ // a record in history.
821
+ // NB! URL to redirect is formed manually because baseURI could be messed up,
822
+ // in which case it's not obvious where redirect will lead.
823
+ const cleanedUrl = [
824
+ window.location.pathname,
825
+ window.location.search
826
+ ].join('');
827
+ const hashIfExist = hash ? `#${hash}` : '';
828
+ history.replaceState(undefined, '', `${cleanedUrl}${hashIfExist}`);
829
+ }
830
+ else {
831
+ window.location.hash = hash;
832
+ }
833
+ }
834
+ }