@jetbrains/ring-ui 5.1.1 → 5.1.3

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 (753) hide show
  1. package/README.md +1 -6
  2. package/components/alert/alert.d.ts +1 -1
  3. package/components/alert/container.css +3 -0
  4. package/components/alert-service/alert-service.d.ts +2 -2
  5. package/components/analytics/analytics.d.ts +21 -7
  6. package/components/analytics/analytics.js +19 -24
  7. package/components/analytics/analytics__custom-plugin.d.ts +6 -16
  8. package/components/analytics/analytics__custom-plugin.js +12 -52
  9. package/components/analytics/analytics__fus-plugin.d.ts +15 -25
  10. package/components/analytics/analytics__fus-plugin.js +15 -73
  11. package/components/analytics/analytics__ga-plugin.d.ts +13 -3
  12. package/components/analytics/analytics__ga-plugin.js +35 -5
  13. package/components/analytics/analytics__plugin-utils.d.ts +16 -0
  14. package/components/analytics/analytics__plugin-utils.js +26 -1
  15. package/components/auth/auth__core.d.ts +5 -4
  16. package/components/auth/auth__core.js +44 -27
  17. package/components/auth-dialog/auth-dialog.d.ts +2 -2
  18. package/components/auth-dialog/auth-dialog.js +3 -1
  19. package/components/auth-dialog-service/auth-dialog-service.js +4 -1
  20. package/components/avatar/avatar.d.ts +3 -3
  21. package/components/avatar/fallback-avatar.d.ts +2 -2
  22. package/components/avatar/fallback-avatar.js +2 -1
  23. package/components/avatar-editor-ng/avatar-editor-ng.css +1 -1
  24. package/components/badge/badge.d.ts +2 -2
  25. package/components/button/button.css +7 -7
  26. package/components/button/button.d.ts +3 -4
  27. package/components/button/button.js +0 -1
  28. package/components/button-group/button-group.css +2 -2
  29. package/components/button-group/button-group.d.ts +2 -2
  30. package/components/button-group/caption.d.ts +2 -2
  31. package/components/button-ng/button-ng.js +1 -1
  32. package/components/button-ng/{button-ng.examples.js → button-ng.stories.js} +2 -2
  33. package/components/button-set/button-set.d.ts +2 -2
  34. package/components/button-toolbar/button-toolbar.d.ts +2 -2
  35. package/components/checkbox/checkbox.css +2 -2
  36. package/components/checkbox/checkbox.d.ts +2 -2
  37. package/components/code/code.d.ts +1 -1
  38. package/components/confirm/confirm.d.ts +1 -1
  39. package/components/confirm/confirm.js +3 -3
  40. package/components/confirm-ng/{confirm-ng.examples.js → confirm-ng.stories.js} +1 -1
  41. package/components/confirm-service/confirm-service.js +2 -2
  42. package/components/content-layout/content-layout.d.ts +2 -2
  43. package/components/content-layout/sidebar.d.ts +2 -2
  44. package/components/contenteditable/contenteditable.d.ts +3 -3
  45. package/components/control-label/control-label.css +23 -0
  46. package/components/control-label/control-label.d.ts +11 -0
  47. package/components/control-label/control-label.js +22 -0
  48. package/components/data-list/data-list.css +2 -1
  49. package/components/data-list/data-list.d.ts +3 -3
  50. package/components/data-list/data-list.mock.d.ts +2 -2
  51. package/components/data-list/item.d.ts +3 -3
  52. package/components/data-list/title.d.ts +1 -1
  53. package/components/date-picker/consts.d.ts +5 -5
  54. package/components/date-picker/date-input.d.ts +3 -12
  55. package/components/date-picker/date-input.js +9 -15
  56. package/components/date-picker/date-picker.css +1 -1
  57. package/components/date-picker/date-picker.d.ts +8 -6
  58. package/components/date-picker/date-picker.js +9 -15
  59. package/components/date-picker/date-popup.d.ts +1 -1
  60. package/components/date-picker/date-popup.js +2 -1
  61. package/components/date-picker/day.d.ts +2 -2
  62. package/components/date-picker/month-names.d.ts +2 -2
  63. package/components/date-picker/month-names.js +2 -2
  64. package/components/date-picker/month-slider.d.ts +2 -2
  65. package/components/date-picker/month.d.ts +2 -2
  66. package/components/date-picker/months.d.ts +2 -2
  67. package/components/date-picker/months.js +46 -29
  68. package/components/date-picker/weekdays.d.ts +2 -2
  69. package/components/date-picker/years.d.ts +6 -2
  70. package/components/date-picker/years.js +26 -14
  71. package/components/dialog/dialog.css +1 -1
  72. package/components/dialog/dialog.d.ts +4 -16
  73. package/components/dialog/dialog.js +4 -2
  74. package/components/dialog-ng/dialog-ng.js +4 -5
  75. package/components/dialog-ng/{dialog-ng.examples.js → dialog-ng.stories.js} +1 -1
  76. package/components/dropdown/anchor.d.ts +1 -1
  77. package/components/dropdown/dropdown.d.ts +8 -1
  78. package/components/editable-heading/editable-heading.css +20 -7
  79. package/components/editable-heading/editable-heading.d.ts +2 -2
  80. package/components/editable-heading/editable-heading.js +39 -12
  81. package/components/error-bubble/error-bubble.d.ts +2 -2
  82. package/components/error-message/error-message.d.ts +2 -2
  83. package/components/footer/footer.js +1 -0
  84. package/components/form/{form.examples.js → form.stories.js} +1 -0
  85. package/components/global/angular-component-factory.js +13 -7
  86. package/components/global/angular-component-factory.test.js +30 -10
  87. package/components/global/controls-height.d.ts +2 -0
  88. package/components/global/controls-height.js +8 -0
  89. package/components/global/create-stateful-context.d.ts +1 -1
  90. package/components/global/focus-sensor-hoc.d.ts +1 -0
  91. package/components/global/focus-sensor-hoc.js +5 -4
  92. package/components/global/react-dom-renderer.d.ts +4 -4
  93. package/components/global/react-dom-renderer.js +5 -5
  94. package/components/global/react-render-adapter.js +19 -31
  95. package/components/global/ring-angular-component.js +1 -3
  96. package/components/global/ring-angular-component.test.js +2 -1
  97. package/components/global/use-event-callback.d.ts +1 -0
  98. package/components/global/use-event-callback.js +14 -0
  99. package/components/global/variables_dark.css +2 -2
  100. package/components/grid/col.d.ts +2 -2
  101. package/components/grid/grid.d.ts +2 -2
  102. package/components/grid/row.d.ts +2 -2
  103. package/components/group/group.d.ts +2 -2
  104. package/components/header/header.d.ts +2 -2
  105. package/components/header/logo.d.ts +2 -2
  106. package/components/header/profile.d.ts +4 -2
  107. package/components/header/profile.js +15 -11
  108. package/components/header/services-link.d.ts +2 -2
  109. package/components/header/services.d.ts +2 -2
  110. package/components/header/smart-profile.d.ts +2 -2
  111. package/components/header/smart-services.d.ts +2 -2
  112. package/components/header/tray-icon.d.ts +2 -2
  113. package/components/header/tray.d.ts +2 -2
  114. package/components/heading/heading.css +8 -8
  115. package/components/http/http.d.ts +16 -6
  116. package/components/http/http.js +26 -0
  117. package/components/hub-source/hub-source__users-groups.d.ts +1 -1
  118. package/components/i18n/README.md +46 -0
  119. package/components/i18n/i18n-context.d.ts +13 -0
  120. package/components/i18n/i18n-context.js +14 -0
  121. package/components/i18n/i18n.d.ts +59 -0
  122. package/components/i18n/i18n.js +26 -0
  123. package/components/i18n/messages.json +53 -0
  124. package/components/icon/icon.d.ts +3 -3
  125. package/components/icon/icon__svg.d.ts +1 -1
  126. package/components/input/input-legacy.css +3 -3
  127. package/components/input/input.css +8 -21
  128. package/components/input/input.d.ts +7 -1
  129. package/components/input/input.js +18 -14
  130. package/components/input-ng/input-ng.js +3 -2
  131. package/components/input-ng/{input-ng.examples.js → input-ng.stories.js} +3 -1
  132. package/components/input-size/{input-size.examples.js → input-size.stories.js} +1 -0
  133. package/components/island/adaptive-island-hoc.d.ts +2 -2
  134. package/components/island/content.d.ts +1 -1
  135. package/components/island/header.d.ts +2 -2
  136. package/components/island/island.css +1 -1
  137. package/components/island/island.d.ts +3 -3
  138. package/components/island-legacy/content-legacy.d.ts +2 -2
  139. package/components/island-legacy/header-legacy.d.ts +2 -2
  140. package/components/island-legacy/island-legacy.d.ts +2 -2
  141. package/components/island-ng/island-ng.js +3 -3
  142. package/components/link/clickableLink.d.ts +1 -1
  143. package/components/link/link.css +1 -1
  144. package/components/link/link.d.ts +8 -9
  145. package/components/link/link.js +0 -1
  146. package/components/list/consts.js +3 -0
  147. package/components/list/list.css +2 -2
  148. package/components/list/list.d.ts +7 -7
  149. package/components/list/list.js +4 -1
  150. package/components/list/list__custom.d.ts +1 -1
  151. package/components/list/list__hint.d.ts +2 -2
  152. package/components/list/list__item.d.ts +2 -2
  153. package/components/list/list__link.d.ts +2 -2
  154. package/components/list/list__separator.d.ts +2 -2
  155. package/components/list/list__title.d.ts +2 -2
  156. package/components/loader/loader.d.ts +2 -2
  157. package/components/loader-inline/loader-inline.d.ts +2 -2
  158. package/components/loader-ng/loader-ng.js +1 -1
  159. package/components/loader-screen/loader-screen.d.ts +2 -2
  160. package/components/login-dialog/login-dialog.d.ts +2 -2
  161. package/components/login-dialog/service.js +4 -1
  162. package/components/markdown/code.d.ts +2 -2
  163. package/components/markdown/heading.d.ts +2 -2
  164. package/components/markdown/link.d.ts +2 -2
  165. package/components/markdown/markdown.d.ts +2 -2
  166. package/components/message/message.d.ts +3 -7
  167. package/components/message/message.js +17 -16
  168. package/components/pager/pager.d.ts +8 -13
  169. package/components/pager/pager.js +12 -14
  170. package/components/panel/panel.css +1 -1
  171. package/components/panel/panel.d.ts +2 -2
  172. package/components/popup/popup.d.ts +2 -2
  173. package/components/popup/popup.js +1 -1
  174. package/components/popup/position.d.ts +1 -1
  175. package/components/popup/position.js +43 -33
  176. package/components/popup-menu/popup-menu.d.ts +2 -2
  177. package/components/progress-bar/progress-bar.d.ts +2 -2
  178. package/components/promised-click-ng/promised-click-ng.js +1 -1
  179. package/components/query-assist/query-assist.css +16 -11
  180. package/components/query-assist/query-assist.d.ts +3 -7
  181. package/components/query-assist/query-assist.js +50 -31
  182. package/components/query-assist/query-assist__suggestions.d.ts +2 -2
  183. package/components/radio/radio.css +1 -1
  184. package/components/radio/radio.d.ts +1 -1
  185. package/components/radio/radio__item.d.ts +1 -1
  186. package/components/select/select-popup.css +2 -2
  187. package/components/select/select.css +9 -5
  188. package/components/select/select.d.ts +21 -9
  189. package/components/select/select.js +53 -29
  190. package/components/select/select__filter.d.ts +2 -3
  191. package/components/select/select__filter.js +4 -2
  192. package/components/select/select__popup.d.ts +48 -8
  193. package/components/select/select__popup.js +29 -8
  194. package/components/shortcuts/shortcuts-hoc.d.ts +2 -2
  195. package/components/shortcuts/shortcuts.d.ts +1 -1
  196. package/components/shortcuts-hint-ng/shortcuts-hint-ng.js +1 -2
  197. package/components/sidebar-ng/sidebar-ng.js +1 -2
  198. package/components/tab-trap/tab-trap.d.ts +1 -1
  199. package/components/table/cell.d.ts +2 -2
  200. package/components/table/disable-hover-hoc.d.ts +2 -2
  201. package/components/table/header-cell.d.ts +2 -2
  202. package/components/table/header.d.ts +3 -14
  203. package/components/table/header.js +5 -49
  204. package/components/table/multitable.d.ts +2 -2
  205. package/components/table/row-with-focus-sensor.d.ts +1 -1
  206. package/components/table/row.d.ts +2 -1
  207. package/components/table/row.js +4 -3
  208. package/components/table/smart-table.d.ts +3 -1
  209. package/components/table/table.css +9 -26
  210. package/components/table/table.d.ts +6 -4
  211. package/components/table/table.js +5 -3
  212. package/components/table-ng/{table-ng.examples.js → table-ng.stories.js} +1 -1
  213. package/components/tabs/collapsible-more.d.ts +3 -3
  214. package/components/tabs/collapsible-tab.d.ts +1 -1
  215. package/components/tabs/collapsible-tabs.d.ts +2 -2
  216. package/components/tabs/dumb-tabs.d.ts +5 -3
  217. package/components/tabs/dumb-tabs.js +3 -2
  218. package/components/tabs/smart-tabs.d.ts +2 -2
  219. package/components/tabs/tab-link.d.ts +1 -1
  220. package/components/tabs/tab.d.ts +2 -2
  221. package/components/tabs/tab.js +3 -3
  222. package/components/tabs/tabs.css +4 -1
  223. package/components/tag/tag.css +3 -3
  224. package/components/tag/tag.d.ts +5 -5
  225. package/components/tags-input/tags-input.css +1 -1
  226. package/components/tags-input/tags-input.d.ts +11 -4
  227. package/components/tags-input/tags-input.js +11 -8
  228. package/components/tags-list/tags-list.d.ts +2 -2
  229. package/components/template-ng/template-ng.js +1 -2
  230. package/components/text/text.css +12 -0
  231. package/components/text/text.d.ts +8 -2
  232. package/components/text/text.js +12 -2
  233. package/components/toggle/toggle.css +1 -1
  234. package/components/toggle/toggle.d.ts +2 -2
  235. package/components/tooltip/tooltip.d.ts +1 -1
  236. package/components/user-agreement/service.js +4 -1
  237. package/components/user-agreement/user-agreement.d.ts +3 -11
  238. package/components/user-agreement/user-agreement.js +31 -30
  239. package/components/user-card/card.d.ts +22 -21
  240. package/components/user-card/card.js +29 -29
  241. package/components/user-card/smart-user-card-tooltip.d.ts +3 -3
  242. package/components/user-card/tooltip.d.ts +11 -6
  243. package/components/user-card/tooltip.js +1 -1
  244. package/components/user-card/user-card.css +10 -1
  245. package/dist/_helpers/_rollupPluginBabelHelpers.js +614 -1
  246. package/dist/_helpers/anchor.js +7 -8
  247. package/dist/_helpers/badge.js +1 -1
  248. package/dist/_helpers/button-group.js +1 -1
  249. package/dist/_helpers/button-set.js +1 -1
  250. package/dist/_helpers/button-toolbar.js +1 -1
  251. package/dist/_helpers/button__classes.js +17 -29
  252. package/dist/_helpers/card.js +100 -91
  253. package/dist/_helpers/checkbox.js +1 -1
  254. package/dist/_helpers/control-label.js +3 -0
  255. package/dist/_helpers/date-picker.js +1 -1
  256. package/dist/_helpers/dialog__body-scroll-preventer.js +21 -12
  257. package/dist/_helpers/error-message.js +1 -1
  258. package/dist/_helpers/footer.js +31 -35
  259. package/dist/_helpers/grid.js +1 -1
  260. package/dist/_helpers/group.js +1 -1
  261. package/dist/_helpers/header.js +1 -1
  262. package/dist/_helpers/icon.js +1 -1
  263. package/dist/_helpers/input.js +1 -1
  264. package/dist/_helpers/island.js +1 -1
  265. package/dist/_helpers/link.js +1 -1
  266. package/dist/_helpers/list.js +1 -1
  267. package/dist/_helpers/loader-inline.js +1 -1
  268. package/dist/_helpers/loader-screen.js +1 -1
  269. package/dist/_helpers/panel.js +1 -1
  270. package/dist/_helpers/query-assist__suggestions.js +92 -75
  271. package/dist/_helpers/radio.js +1 -1
  272. package/dist/_helpers/select__filter.js +69 -42
  273. package/dist/_helpers/services-link.js +33 -21
  274. package/dist/_helpers/sidebar.js +87 -86
  275. package/dist/_helpers/table.js +1 -1
  276. package/dist/_helpers/tabs.js +1 -1
  277. package/dist/_helpers/theme.js +43 -36
  278. package/dist/_helpers/title.js +66 -56
  279. package/dist/alert/alert.d.ts +1 -1
  280. package/dist/alert/alert.js +164 -127
  281. package/dist/alert/container.js +40 -29
  282. package/dist/alert-service/alert-service.d.ts +2 -2
  283. package/dist/alert-service/alert-service.js +169 -103
  284. package/dist/analytics/analytics.d.ts +21 -7
  285. package/dist/analytics/analytics.js +90 -71
  286. package/dist/analytics/analytics__custom-plugin.d.ts +6 -16
  287. package/dist/analytics/analytics__custom-plugin.js +74 -87
  288. package/dist/analytics/analytics__fus-plugin.d.ts +15 -25
  289. package/dist/analytics/analytics__fus-plugin.js +31 -89
  290. package/dist/analytics/analytics__ga-plugin.d.ts +13 -3
  291. package/dist/analytics/analytics__ga-plugin.js +76 -25
  292. package/dist/analytics/analytics__plugin-utils.d.ts +16 -0
  293. package/dist/analytics/analytics__plugin-utils.js +52 -21
  294. package/dist/auth/auth.js +39 -5
  295. package/dist/auth/auth__core.d.ts +5 -4
  296. package/dist/auth/auth__core.js +1459 -719
  297. package/dist/auth/background-flow.js +125 -84
  298. package/dist/auth/down-notification.js +76 -32
  299. package/dist/auth/iframe-flow.js +129 -69
  300. package/dist/auth/landing.js +93 -31
  301. package/dist/auth/request-builder.js +79 -45
  302. package/dist/auth/response-parser.js +117 -85
  303. package/dist/auth/storage.js +322 -161
  304. package/dist/auth/token-validator.js +239 -128
  305. package/dist/auth/window-flow.js +126 -83
  306. package/dist/auth-dialog/auth-dialog.d.ts +2 -2
  307. package/dist/auth-dialog/auth-dialog.js +152 -94
  308. package/dist/auth-dialog-service/auth-dialog-service.js +36 -10
  309. package/dist/auth-ng/auth-ng.js +73 -35
  310. package/dist/auth-ng/auth-ng.mock.js +6 -6
  311. package/dist/autofocus-ng/autofocus-ng.js +23 -8
  312. package/dist/avatar/avatar-example-datauri.js +1 -23
  313. package/dist/avatar/avatar.d.ts +3 -3
  314. package/dist/avatar/avatar.js +132 -99
  315. package/dist/avatar/fallback-avatar.d.ts +2 -2
  316. package/dist/avatar/fallback-avatar.js +44 -24
  317. package/dist/avatar-editor-ng/avatar-editor-ng.js +57 -25
  318. package/dist/avatar-editor-ng/avatar-editor-ng__template.js +1 -28
  319. package/dist/avatar-ng/avatar-ng.js +22 -0
  320. package/dist/badge/badge.d.ts +2 -2
  321. package/dist/badge/badge.js +34 -26
  322. package/dist/badge-ng/badge-ng.js +12 -0
  323. package/dist/breadcrumb-ng/breadcrumb-ng.js +17 -32
  324. package/dist/button/button.d.ts +3 -4
  325. package/dist/button/button.js +89 -69
  326. package/dist/button/button__classes.js +1 -0
  327. package/dist/button-group/button-group.d.ts +2 -2
  328. package/dist/button-group/button-group.js +31 -15
  329. package/dist/button-group/caption.d.ts +2 -2
  330. package/dist/button-group/caption.js +19 -11
  331. package/dist/button-group-ng/button-group-ng.js +13 -7
  332. package/dist/button-ng/button-ng.js +132 -112
  333. package/dist/button-set/button-set.d.ts +2 -2
  334. package/dist/button-set/button-set.js +29 -15
  335. package/dist/button-set-ng/button-set-ng.js +2 -2
  336. package/dist/button-toolbar/button-toolbar.d.ts +2 -2
  337. package/dist/button-toolbar/button-toolbar.js +28 -14
  338. package/dist/button-toolbar-ng/button-toolbar-ng.js +5 -3
  339. package/dist/caret/caret.js +223 -188
  340. package/dist/checkbox/checkbox.d.ts +2 -2
  341. package/dist/checkbox/checkbox.js +83 -58
  342. package/dist/checkbox-ng/checkbox-ng.js +18 -28
  343. package/dist/clipboard/clipboard-fallback.js +10 -10
  344. package/dist/clipboard/clipboard.js +131 -35
  345. package/dist/code/code.d.ts +1 -1
  346. package/dist/code/code.js +153 -81
  347. package/dist/compiler-ng/compiler-ng.js +18 -15
  348. package/dist/confirm/confirm.d.ts +1 -1
  349. package/dist/confirm/confirm.js +85 -47
  350. package/dist/confirm-ng/confirm-ng.js +34 -6
  351. package/dist/confirm-service/confirm-service.js +67 -44
  352. package/dist/content-layout/content-layout.d.ts +2 -2
  353. package/dist/content-layout/content-layout.js +53 -35
  354. package/dist/content-layout/sidebar.d.ts +2 -2
  355. package/dist/content-layout/sidebar.js +1 -0
  356. package/dist/contenteditable/contenteditable.d.ts +3 -3
  357. package/dist/contenteditable/contenteditable.js +54 -43
  358. package/dist/control-label/control-label.d.ts +11 -0
  359. package/dist/control-label/control-label.js +31 -0
  360. package/dist/data-list/data-list.d.ts +3 -3
  361. package/dist/data-list/data-list.js +164 -114
  362. package/dist/data-list/data-list.mock.d.ts +2 -2
  363. package/dist/data-list/data-list.mock.js +11 -3
  364. package/dist/data-list/item.d.ts +3 -3
  365. package/dist/data-list/item.js +140 -113
  366. package/dist/data-list/selection.js +139 -77
  367. package/dist/data-list/title.d.ts +1 -1
  368. package/dist/data-list/title.js +12 -0
  369. package/dist/data-list-ng/data-list-ng.js +30 -1
  370. package/dist/date-picker/consts.d.ts +5 -5
  371. package/dist/date-picker/consts.js +18 -15
  372. package/dist/date-picker/date-input.d.ts +3 -12
  373. package/dist/date-picker/date-input.js +131 -107
  374. package/dist/date-picker/date-picker.d.ts +8 -6
  375. package/dist/date-picker/date-picker.js +214 -160
  376. package/dist/date-picker/date-popup.d.ts +1 -1
  377. package/dist/date-picker/date-popup.js +340 -297
  378. package/dist/date-picker/day.d.ts +2 -2
  379. package/dist/date-picker/day.js +78 -68
  380. package/dist/date-picker/month-names.d.ts +2 -2
  381. package/dist/date-picker/month-names.js +59 -41
  382. package/dist/date-picker/month-slider.d.ts +2 -2
  383. package/dist/date-picker/month-slider.js +59 -40
  384. package/dist/date-picker/month.d.ts +2 -2
  385. package/dist/date-picker/month.js +21 -15
  386. package/dist/date-picker/months.d.ts +2 -2
  387. package/dist/date-picker/months.js +80 -56
  388. package/dist/date-picker/weekdays.d.ts +2 -2
  389. package/dist/date-picker/weekdays.js +18 -12
  390. package/dist/date-picker/years.d.ts +6 -2
  391. package/dist/date-picker/years.js +102 -66
  392. package/dist/dialog/dialog.d.ts +4 -16
  393. package/dist/dialog/dialog.js +148 -98
  394. package/dist/dialog/dialog__body-scroll-preventer.js +5 -0
  395. package/dist/dialog-ng/dialog-ng.js +404 -291
  396. package/dist/dialog-ng/dialog-ng__template.js +1 -70
  397. package/dist/docked-panel-ng/docked-panel-ng.js +33 -19
  398. package/dist/dropdown/anchor.d.ts +1 -1
  399. package/dist/dropdown/anchor.js +10 -1
  400. package/dist/dropdown/dropdown.d.ts +8 -1
  401. package/dist/dropdown/dropdown.js +158 -130
  402. package/dist/dropdown-menu/dropdown-menu.js +102 -73
  403. package/dist/editable-heading/editable-heading.d.ts +2 -2
  404. package/dist/editable-heading/editable-heading.js +133 -62
  405. package/dist/error-bubble/error-bubble.d.ts +2 -2
  406. package/dist/error-bubble/error-bubble.js +60 -27
  407. package/dist/error-message/error-message.d.ts +2 -2
  408. package/dist/error-message/error-message.js +52 -29
  409. package/dist/error-message-ng/error-message-ng.js +12 -24
  410. package/dist/footer/footer.js +11 -2
  411. package/dist/footer-ng/footer-ng.js +52 -27
  412. package/dist/form-ng/form-ng.js +67 -57
  413. package/dist/global/angular-component-factory.js +78 -50
  414. package/dist/global/compose.js +10 -1
  415. package/dist/global/composeRefs.js +12 -7
  416. package/dist/global/controls-height.d.ts +2 -0
  417. package/dist/global/controls-height.js +10 -2
  418. package/dist/global/create-stateful-context.d.ts +1 -1
  419. package/dist/global/create-stateful-context.js +19 -19
  420. package/dist/global/data-tests.js +15 -7
  421. package/dist/global/dom.js +93 -55
  422. package/dist/global/focus-sensor-hoc.d.ts +1 -0
  423. package/dist/global/focus-sensor-hoc.js +118 -102
  424. package/dist/global/fuzzy-highlight.js +41 -27
  425. package/dist/global/get-event-key.js +8 -8
  426. package/dist/global/get-uid.js +8 -4
  427. package/dist/global/inject-styles.js +15 -10
  428. package/dist/global/linear-function.js +2 -2
  429. package/dist/global/listeners.js +50 -28
  430. package/dist/global/memoize.js +13 -6
  431. package/dist/global/normalize-indent.js +51 -19
  432. package/dist/global/promise-with-timeout.js +8 -6
  433. package/dist/global/prop-types.js +5 -3
  434. package/dist/global/react-dom-renderer.d.ts +4 -4
  435. package/dist/global/react-dom-renderer.js +44 -28
  436. package/dist/global/react-render-adapter.js +21 -15
  437. package/dist/global/rerender-hoc.js +40 -19
  438. package/dist/global/ring-angular-component.js +18 -10
  439. package/dist/global/schedule-raf.js +6 -5
  440. package/dist/global/sniffer.js +1 -1
  441. package/dist/global/theme.js +24 -0
  442. package/dist/global/trivial-template-tag.js +10 -3
  443. package/dist/global/typescript-utils.js +6 -2
  444. package/dist/global/url.js +27 -21
  445. package/dist/global/use-event-callback.d.ts +1 -0
  446. package/dist/global/use-event-callback.js +17 -0
  447. package/dist/grid/col.d.ts +2 -2
  448. package/dist/grid/col.js +42 -23
  449. package/dist/grid/grid.d.ts +2 -2
  450. package/dist/grid/grid.js +32 -13
  451. package/dist/grid/row.d.ts +2 -2
  452. package/dist/grid/row.js +32 -20
  453. package/dist/group/group.d.ts +2 -2
  454. package/dist/group/group.js +23 -13
  455. package/dist/group-ng/group-ng.js +2 -2
  456. package/dist/header/header.d.ts +2 -2
  457. package/dist/header/header.js +75 -25
  458. package/dist/header/logo.d.ts +2 -2
  459. package/dist/header/logo.js +31 -12
  460. package/dist/header/profile.d.ts +4 -2
  461. package/dist/header/profile.js +154 -105
  462. package/dist/header/services-link.d.ts +2 -2
  463. package/dist/header/services-link.js +9 -1
  464. package/dist/header/services.d.ts +2 -2
  465. package/dist/header/services.js +104 -63
  466. package/dist/header/smart-profile.d.ts +2 -2
  467. package/dist/header/smart-profile.js +194 -98
  468. package/dist/header/smart-services.d.ts +2 -2
  469. package/dist/header/smart-services.js +104 -52
  470. package/dist/header/tray-icon.d.ts +2 -2
  471. package/dist/header/tray-icon.js +36 -20
  472. package/dist/header/tray.d.ts +2 -2
  473. package/dist/header/tray.js +30 -17
  474. package/dist/heading/heading.js +26 -27
  475. package/dist/heading-ng/heading-ng.js +10 -0
  476. package/dist/http/http.d.ts +16 -6
  477. package/dist/http/http.js +357 -170
  478. package/dist/http/http.mock.js +105 -50
  479. package/dist/hub-source/hub-source.js +183 -77
  480. package/dist/hub-source/hub-source__user.js +45 -12
  481. package/dist/hub-source/hub-source__users-groups.d.ts +1 -1
  482. package/dist/hub-source/hub-source__users-groups.js +63 -34
  483. package/dist/i18n/i18n-context.d.ts +13 -0
  484. package/dist/i18n/i18n-context.js +28 -0
  485. package/dist/i18n/i18n.d.ts +59 -0
  486. package/dist/i18n/i18n.js +140 -0
  487. package/dist/icon/icon.d.ts +3 -3
  488. package/dist/icon/icon.js +77 -59
  489. package/dist/icon/icon__svg.d.ts +1 -1
  490. package/dist/icon/icon__svg.js +31 -24
  491. package/dist/icon/index.js +9 -0
  492. package/dist/icon-ng/icon-ng.js +27 -16
  493. package/dist/input/input.d.ts +7 -1
  494. package/dist/input/input.js +178 -131
  495. package/dist/input-ng/input-ng.js +77 -99
  496. package/dist/island/adaptive-island-hoc.d.ts +2 -2
  497. package/dist/island/adaptive-island-hoc.js +38 -27
  498. package/dist/island/content.d.ts +1 -1
  499. package/dist/island/content.js +104 -92
  500. package/dist/island/header.d.ts +2 -2
  501. package/dist/island/header.js +60 -47
  502. package/dist/island/island.d.ts +3 -3
  503. package/dist/island/island.js +33 -21
  504. package/dist/island-legacy/content-legacy.d.ts +2 -2
  505. package/dist/island-legacy/content-legacy.js +23 -13
  506. package/dist/island-legacy/header-legacy.d.ts +2 -2
  507. package/dist/island-legacy/header-legacy.js +25 -15
  508. package/dist/island-legacy/island-legacy.d.ts +2 -2
  509. package/dist/island-legacy/island-legacy.js +23 -13
  510. package/dist/island-ng/island-content-ng.js +17 -26
  511. package/dist/island-ng/island-header-ng.js +9 -12
  512. package/dist/island-ng/island-ng-class-fixer.js +3 -0
  513. package/dist/island-ng/island-ng.js +6 -10
  514. package/dist/link/clickableLink.d.ts +1 -1
  515. package/dist/link/clickableLink.js +43 -29
  516. package/dist/link/link.d.ts +8 -9
  517. package/dist/link/link.js +72 -62
  518. package/dist/link-ng/link-ng.js +5 -7
  519. package/dist/list/consts.js +4 -1
  520. package/dist/list/list.d.ts +7 -7
  521. package/dist/list/list.js +499 -402
  522. package/dist/list/list__custom.d.ts +1 -1
  523. package/dist/list/list__custom.js +60 -47
  524. package/dist/list/list__hint.d.ts +2 -2
  525. package/dist/list/list__hint.js +18 -8
  526. package/dist/list/list__item.d.ts +2 -2
  527. package/dist/list/list__item.js +167 -132
  528. package/dist/list/list__link.d.ts +2 -2
  529. package/dist/list/list__link.js +54 -38
  530. package/dist/list/list__separator.d.ts +2 -2
  531. package/dist/list/list__separator.js +24 -14
  532. package/dist/list/list__title.d.ts +2 -2
  533. package/dist/list/list__title.js +32 -22
  534. package/dist/list/list__users-groups-source.js +130 -54
  535. package/dist/loader/loader.d.ts +2 -2
  536. package/dist/loader/loader.js +66 -34
  537. package/dist/loader/loader__core.js +197 -129
  538. package/dist/loader-inline/loader-inline.d.ts +2 -2
  539. package/dist/loader-inline/loader-inline.js +32 -18
  540. package/dist/loader-inline-ng/loader-inline-ng.js +2 -2
  541. package/dist/loader-ng/loader-ng.js +44 -18
  542. package/dist/loader-screen/loader-screen.d.ts +2 -2
  543. package/dist/loader-screen/loader-screen.js +43 -20
  544. package/dist/loader-screen-ng/loader-screen-ng.js +45 -30
  545. package/dist/login-dialog/login-dialog.d.ts +2 -2
  546. package/dist/login-dialog/login-dialog.js +125 -78
  547. package/dist/login-dialog/service.js +39 -10
  548. package/dist/markdown/code.d.ts +2 -2
  549. package/dist/markdown/code.js +30 -9
  550. package/dist/markdown/heading.d.ts +2 -2
  551. package/dist/markdown/heading.js +3 -5
  552. package/dist/markdown/link.d.ts +2 -2
  553. package/dist/markdown/link.js +13 -7
  554. package/dist/markdown/markdown.d.ts +2 -2
  555. package/dist/markdown/markdown.js +67 -35
  556. package/dist/message/message.d.ts +3 -7
  557. package/dist/message/message.js +153 -119
  558. package/dist/message-bundle-ng/message-bundle-ng.js +130 -46
  559. package/dist/old-browsers-message/old-browsers-message.js +19 -11
  560. package/dist/old-browsers-message/old-browsers-message__stop.js +8 -0
  561. package/dist/old-browsers-message/white-list.js +17 -10
  562. package/dist/pager/pager.d.ts +8 -13
  563. package/dist/pager/pager.js +259 -188
  564. package/dist/pager-ng/pager-ng.js +39 -2
  565. package/dist/panel/panel.d.ts +2 -2
  566. package/dist/panel/panel.js +23 -13
  567. package/dist/panel-ng/panel-ng.js +13 -1
  568. package/dist/permissions/permissions.js +166 -122
  569. package/dist/permissions/permissions__cache.js +220 -191
  570. package/dist/permissions-ng/permissions-ng.js +89 -36
  571. package/dist/place-under-ng/place-under-ng.js +67 -45
  572. package/dist/popup/popup.consts.js +1 -1
  573. package/dist/popup/popup.d.ts +2 -2
  574. package/dist/popup/popup.js +299 -236
  575. package/dist/popup/popup.target.js +8 -9
  576. package/dist/popup/position.d.ts +1 -1
  577. package/dist/popup/position.js +175 -154
  578. package/dist/popup-menu/popup-menu.d.ts +2 -2
  579. package/dist/popup-menu/popup-menu.js +80 -42
  580. package/dist/progress-bar/progress-bar.d.ts +2 -2
  581. package/dist/progress-bar/progress-bar.js +66 -52
  582. package/dist/progress-bar-ng/progress-bar-ng.js +10 -0
  583. package/dist/promised-click-ng/promised-click-ng.js +93 -60
  584. package/dist/proxy-attrs/proxy-attrs.js +18 -9
  585. package/dist/query-assist/query-assist.d.ts +3 -7
  586. package/dist/query-assist/query-assist.js +677 -567
  587. package/dist/query-assist/query-assist__suggestions.d.ts +2 -2
  588. package/dist/query-assist/query-assist__suggestions.js +33 -2
  589. package/dist/query-assist-ng/query-assist-ng.js +41 -2
  590. package/dist/radio/radio.d.ts +1 -1
  591. package/dist/radio/radio.js +28 -14
  592. package/dist/radio/radio__item.d.ts +1 -1
  593. package/dist/radio/radio__item.js +60 -44
  594. package/dist/radio-ng/radio-ng.js +14 -25
  595. package/dist/save-field-ng/save-field-ng.js +90 -56
  596. package/dist/save-field-ng/save-field-ng__template.js +1 -32
  597. package/dist/select/select.d.ts +21 -9
  598. package/dist/select/select.js +833 -699
  599. package/dist/select/select__filter.d.ts +2 -3
  600. package/dist/select/select__filter.js +37 -2
  601. package/dist/select/select__popup.d.ts +48 -8
  602. package/dist/select/select__popup.js +430 -293
  603. package/dist/select-ng/select-ng.js +130 -77
  604. package/dist/select-ng/select-ng__lazy.js +104 -51
  605. package/dist/select-ng/select-ng__options.js +93 -68
  606. package/dist/shortcuts/core.js +197 -146
  607. package/dist/shortcuts/shortcut-title.js +11 -6
  608. package/dist/shortcuts/shortcuts-hoc.d.ts +2 -2
  609. package/dist/shortcuts/shortcuts-hoc.js +43 -19
  610. package/dist/shortcuts/shortcuts.d.ts +1 -1
  611. package/dist/shortcuts/shortcuts.js +69 -43
  612. package/dist/shortcuts-hint-ng/shortcuts-hint-ng.js +109 -58
  613. package/dist/shortcuts-hint-ng/shortcuts-hint-ng__template.js +1 -48
  614. package/dist/shortcuts-ng/shortcuts-ng.js +110 -76
  615. package/dist/sidebar-ng/sidebar-ng.js +55 -25
  616. package/dist/sidebar-ng/sidebar-ng__button-template.js +1 -18
  617. package/dist/sidebar-ng/sidebar-ng__template.js +1 -10
  618. package/dist/storage/storage.js +34 -4
  619. package/dist/storage/storage__fallback.js +217 -143
  620. package/dist/storage/storage__local.js +155 -90
  621. package/dist/style.css +1 -1
  622. package/dist/tab-trap/tab-trap.d.ts +1 -1
  623. package/dist/tab-trap/tab-trap.js +117 -84
  624. package/dist/table/cell.d.ts +2 -2
  625. package/dist/table/cell.js +23 -9
  626. package/dist/table/disable-hover-hoc.d.ts +2 -2
  627. package/dist/table/disable-hover-hoc.js +44 -26
  628. package/dist/table/header-cell.d.ts +2 -2
  629. package/dist/table/header-cell.js +74 -54
  630. package/dist/table/header.d.ts +3 -14
  631. package/dist/table/header.js +102 -131
  632. package/dist/table/multitable.d.ts +2 -2
  633. package/dist/table/multitable.js +102 -86
  634. package/dist/table/row-with-focus-sensor.d.ts +1 -1
  635. package/dist/table/row-with-focus-sensor.js +69 -24
  636. package/dist/table/row.d.ts +2 -1
  637. package/dist/table/row.js +191 -155
  638. package/dist/table/selection-adapter.js +3 -1
  639. package/dist/table/selection-shortcuts-hoc.js +132 -131
  640. package/dist/table/selection.js +220 -150
  641. package/dist/table/smart-table.d.ts +3 -1
  642. package/dist/table/smart-table.js +87 -50
  643. package/dist/table/table.d.ts +6 -4
  644. package/dist/table/table.js +311 -247
  645. package/dist/table-legacy-ng/table-legacy-ng.js +120 -103
  646. package/dist/table-legacy-ng/table-legacy-ng__pager.js +46 -12
  647. package/dist/table-legacy-ng/table-legacy-ng__selection-navigate-actions.js +92 -69
  648. package/dist/table-legacy-ng/table-legacy-ng__selection.js +167 -119
  649. package/dist/table-legacy-ng/table-legacy-ng__toolbar.js +35 -21
  650. package/dist/table-ng/smart-table-ng.js +30 -2
  651. package/dist/table-ng/table-ng.js +30 -2
  652. package/dist/tabs/collapsible-more.d.ts +3 -3
  653. package/dist/tabs/collapsible-more.js +92 -56
  654. package/dist/tabs/collapsible-tab.d.ts +1 -1
  655. package/dist/tabs/collapsible-tab.js +45 -39
  656. package/dist/tabs/collapsible-tabs.d.ts +2 -2
  657. package/dist/tabs/collapsible-tabs.js +161 -95
  658. package/dist/tabs/custom-item.js +2 -4
  659. package/dist/tabs/dumb-tabs.d.ts +5 -3
  660. package/dist/tabs/dumb-tabs.js +101 -56
  661. package/dist/tabs/smart-tabs.d.ts +2 -2
  662. package/dist/tabs/smart-tabs.js +70 -25
  663. package/dist/tabs/tab-link.d.ts +1 -1
  664. package/dist/tabs/tab-link.js +29 -20
  665. package/dist/tabs/tab.d.ts +2 -2
  666. package/dist/tabs/tab.js +26 -15
  667. package/dist/tabs/tabs.js +35 -1
  668. package/dist/tabs-ng/tabs-ng.js +38 -24
  669. package/dist/tabs-ng/tabs-ng__template.js +1 -38
  670. package/dist/tag/tag.d.ts +5 -5
  671. package/dist/tag/tag.js +146 -113
  672. package/dist/tags-input/tags-input.d.ts +11 -4
  673. package/dist/tags-input/tags-input.js +330 -220
  674. package/dist/tags-input-ng/tags-input-ng.js +40 -2
  675. package/dist/tags-list/tags-list.d.ts +2 -2
  676. package/dist/tags-list/tags-list.js +61 -38
  677. package/dist/template-ng/template-ng.js +45 -35
  678. package/dist/text/text.d.ts +8 -2
  679. package/dist/text/text.js +38 -17
  680. package/dist/title-ng/title-ng.js +28 -23
  681. package/dist/toggle/toggle.d.ts +2 -2
  682. package/dist/toggle/toggle.js +55 -39
  683. package/dist/toggle-ng/toggle-ng.js +13 -0
  684. package/dist/tooltip/tooltip.d.ts +1 -1
  685. package/dist/tooltip/tooltip.js +145 -102
  686. package/dist/tooltip-ng/tooltip-ng.js +51 -25
  687. package/dist/user-agreement/service.js +411 -259
  688. package/dist/user-agreement/toolbox.eula.js +1 -160
  689. package/dist/user-agreement/user-agreement.d.ts +3 -11
  690. package/dist/user-agreement/user-agreement.js +106 -68
  691. package/dist/user-card/card.d.ts +22 -21
  692. package/dist/user-card/card.js +34 -1
  693. package/dist/user-card/smart-user-card-tooltip.d.ts +3 -3
  694. package/dist/user-card/smart-user-card-tooltip.js +139 -76
  695. package/dist/user-card/tooltip.d.ts +11 -6
  696. package/dist/user-card/tooltip.js +75 -32
  697. package/dist/user-card/user-card.js +34 -1
  698. package/dist/user-card-ng/user-card-ng.js +39 -6
  699. package/package.json +89 -85
  700. package/components/input/input-label.d.ts +0 -10
  701. package/components/input/input-label.js +0 -18
  702. package/components/loader/__mocks__/loader__core.js +0 -5
  703. package/components/old-browsers-message/__mocks__/old-browsers-message.js +0 -1
  704. package/dist/input/input-label.d.ts +0 -10
  705. package/dist/input/input-label.js +0 -27
  706. /package/components/alert-service/{alert-service.examples.css → alert-service.stories.css} +0 -0
  707. /package/components/auth-ng/{auth-ng.examples.js → auth-ng.stories.js} +0 -0
  708. /package/components/autofocus-ng/{autofocus-ng.examples.js → autofocus-ng.stories.js} +0 -0
  709. /package/components/avatar-editor-ng/{avatar-editor-ng.examples.js → avatar-editor-ng.stories.js} +0 -0
  710. /package/components/avatar-ng/{avatar-ng.examples.js → avatar-ng.stories.js} +0 -0
  711. /package/components/badge-ng/{badge-ng.examples.js → badge-ng.stories.js} +0 -0
  712. /package/components/breadcrumb-ng/{breadcrumb-ng.examples.js → breadcrumb-ng.stories.js} +0 -0
  713. /package/components/button-group-ng/{button-group-ng.examples.js → button-group-ng.stories.js} +0 -0
  714. /package/components/button-set-ng/{button-set-ng.examples.js → button-set-ng.stories.js} +0 -0
  715. /package/components/button-toolbar-ng/{button-toolbar-ng.examples.js → button-toolbar-ng.stories.js} +0 -0
  716. /package/components/checkbox-ng/{checkbox-ng.examples.js → checkbox-ng.stories.js} +0 -0
  717. /package/components/compiler-ng/{compiler-ng.examples.js → compiler-ng.stories.js} +0 -0
  718. /package/components/data-list-ng/{data-list-ng.examples.js → data-list-ng.stories.js} +0 -0
  719. /package/components/docked-panel-ng/{docked-panel-ng.examples.js → docked-panel-ng.stories.js} +0 -0
  720. /package/components/error-message-ng/{error-message-ng.examples.js → error-message-ng.stories.js} +0 -0
  721. /package/components/error-page-ng/{error-page-ng.examples.js → error-page-ng.stories.js} +0 -0
  722. /package/components/footer-ng/{footer-ng.examples.js → footer-ng.stories.js} +0 -0
  723. /package/components/form-ng/{form-ng.examples.js → form-ng.stories.js} +0 -0
  724. /package/components/group-ng/{group.examples.js → group.stories.js} +0 -0
  725. /package/components/heading-ng/{heading-ng.examples.js → heading-ng.stories.js} +0 -0
  726. /package/components/icon-ng/{icon-ng.examples.js → icon-ng.stories.js} +0 -0
  727. /package/components/island-ng/{island-ng.examples.js → island-ng.stories.js} +0 -0
  728. /package/components/link-ng/{link-ng.examples.js → link-ng.stories.js} +0 -0
  729. /package/components/list/{list.examples.css → list.stories.css} +0 -0
  730. /package/components/loader-inline-ng/{loader-inline-ng.examples.js → loader-inline-ng.stories.js} +0 -0
  731. /package/components/loader-ng/{loader-ng.examples.js → loader-ng.stories.js} +0 -0
  732. /package/components/loader-screen-ng/{loader-screen-ng.examples.js → loader-screen-ng.stories.js} +0 -0
  733. /package/components/pager-ng/{pager-ng.examples.js → pager-ng.stories.js} +0 -0
  734. /package/components/palette/{palette.examples.js → palette.stories.js} +0 -0
  735. /package/components/permissions-ng/{permissions-ng.examples.js → permissions-ng.stories.js} +0 -0
  736. /package/components/place-under-ng/{place-under-ng.examples.js → place-under-ng.stories.js} +0 -0
  737. /package/components/progress-bar-ng/{progress-bar-ng.examples.js → progress-bar-ng.stories.js} +0 -0
  738. /package/components/promised-click-ng/{promised-click-ng.examples.js → promised-click-ng.stories.js} +0 -0
  739. /package/components/query-assist-ng/{query-assist-ng.examples.js → query-assist-ng.stories.js} +0 -0
  740. /package/components/radio-ng/{radio-ng.examples.js → radio-ng.stories.js} +0 -0
  741. /package/components/save-field-ng/{save-field-ng.examples.js → save-field-ng.stories.js} +0 -0
  742. /package/components/select-ng/{select-ng.examples.js → select-ng.stories.js} +0 -0
  743. /package/components/shortcuts-hint-ng/{shortcuts-hint-ng.examples.js → shortcuts-hint-ng.stories.js} +0 -0
  744. /package/components/sidebar-ng/{sidebar-ng.examples.js → sidebar-ng.stories.js} +0 -0
  745. /package/components/table/{table.examples.json → table.stories.json} +0 -0
  746. /package/components/table-legacy-ng/{table-legacy-ng.examples.js → table-legacy-ng.stories.js} +0 -0
  747. /package/components/tabs-ng/{tabs-ng.examples.js → tabs-ng.stories.js} +0 -0
  748. /package/components/tags-input-ng/{tags-input-ng.examples.js → tags-input-ng.stories.js} +0 -0
  749. /package/components/template-ng/{template-ng.examples.js → template-ng.stories.js} +0 -0
  750. /package/components/title-ng/{title-ng.examples.js → title-ng.stories.js} +0 -0
  751. /package/components/toggle-ng/{toggle-ng.examples.js → toggle-ng.stories.js} +0 -0
  752. /package/components/tooltip-ng/{tooltip-ng.examples.js → tooltip-ng.stories.js} +0 -0
  753. /package/components/user-card-ng/{user-card-ng.examples.js → user-card-ng.stories.js} +0 -0
@@ -15,7 +15,7 @@ export default function focusSensorHOC(ComposedComponent) {
15
15
  focused: this.props.focused
16
16
  };
17
17
  componentDidMount() {
18
- const { props: { autofocus }, node } = this;
18
+ const { props: { autofocus, scrollOnTableFocus }, node } = this;
19
19
  node?.setAttribute('tabindex', '0');
20
20
  if (node != null) {
21
21
  node.style.outline = 'none';
@@ -23,7 +23,7 @@ export default function focusSensorHOC(ComposedComponent) {
23
23
  document.addEventListener('focus', this.onFocusCapture, true);
24
24
  document.addEventListener('blur', this.onBlurCapture, true);
25
25
  if (autofocus) {
26
- node?.focus();
26
+ node?.focus({ preventScroll: !scrollOnTableFocus });
27
27
  }
28
28
  }
29
29
  componentDidUpdate(prevProps) {
@@ -72,13 +72,13 @@ export default function focusSensorHOC(ComposedComponent) {
72
72
  };
73
73
  onFocusRestore = () => {
74
74
  this._skipNextCapture = true;
75
- this.node?.focus();
75
+ this.node?.focus({ preventScroll: !this.props.scrollOnTableFocus });
76
76
  };
77
77
  onFocusReset = () => {
78
78
  this.node?.blur();
79
79
  };
80
80
  render() {
81
- const { autofocus, focused, onFocus, onBlur, innerRef, ...rest } = this.props;
81
+ const { autofocus, focused, onFocus, onBlur, innerRef, scrollOnTableFocus, ...rest } = this.props;
82
82
  return (<ComposedComponent {...rest} innerRef={composeRefs(innerRef, this.onRefUpdate)} focused={this.state.focused} onFocusReset={this.onFocusReset} onFocusRestore={this.onFocusRestore}/>);
83
83
  }
84
84
  }
@@ -94,6 +94,7 @@ export default function focusSensorHOC(ComposedComponent) {
94
94
  ...ComposedComponent.defaultProps,
95
95
  focused: false,
96
96
  autofocus: false,
97
+ scrollOnTableFocus: true,
97
98
  onFocus: () => { },
98
99
  onBlur: () => { }
99
100
  };
@@ -1,16 +1,16 @@
1
- import { Component } from 'react';
1
+ import React, { Component } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  export interface RendererProps {
4
4
  className?: string | undefined;
5
- nodes: readonly Node[];
5
+ nodes: readonly Node[] | NodeList;
6
6
  }
7
7
  export default class Renderer extends Component<RendererProps> {
8
8
  static propTypes: {
9
9
  className: PropTypes.Requireable<string>;
10
- nodes: PropTypes.Requireable<any[]>;
10
+ nodes: PropTypes.Requireable<object>;
11
11
  };
12
12
  componentDidMount(): void;
13
13
  node?: HTMLElement | null;
14
14
  nodeRef: (node: HTMLElement | null) => void;
15
- render(): JSX.Element;
15
+ render(): React.JSX.Element;
16
16
  }
@@ -3,16 +3,16 @@ import PropTypes from 'prop-types';
3
3
  export default class Renderer extends Component {
4
4
  static propTypes = {
5
5
  className: PropTypes.string,
6
- nodes: PropTypes.array
6
+ nodes: PropTypes.oneOfType([PropTypes.array, PropTypes.object])
7
7
  };
8
8
  componentDidMount() {
9
+ const { node } = this;
9
10
  const { nodes } = this.props;
10
- if (!this.node || !nodes || !nodes.length) {
11
+ if (!node || !nodes || !nodes.length) {
11
12
  return;
12
13
  }
13
- const fragment = document.createDocumentFragment();
14
- nodes.forEach(nodeToRender => fragment.appendChild(nodeToRender));
15
- this.node.appendChild(fragment);
14
+ Array.from(this.props.nodes).
15
+ forEach(nodeToRender => node.appendChild(nodeToRender));
16
16
  }
17
17
  node;
18
18
  nodeRef = (node) => {
@@ -1,36 +1,24 @@
1
- // Allows overriding ReactDOM.render when using React 18:
2
- // import * as client from 'react-dom/client'
3
- // import {setClient} from '@jetbrains/ring-ui/components/global/react-render-adapter'
4
- //
5
- // setClient(client)
6
- import {
7
- render as legacyRender,
8
- unmountComponentAtNode as legacyUnmountComponentAtNode,
9
- hydrate as legacyHydrate
10
- } from 'react-dom';
11
-
1
+ /* eslint-disable react/no-deprecated */
2
+ import { render as legacyRender, unmountComponentAtNode as legacyUnmountComponentAtNode, hydrate as legacyHydrate } from 'react-dom';
3
+ /* eslint-enable */
12
4
  /* eslint-disable import/no-mutable-exports */
13
5
  export let render = legacyRender;
14
6
  export let unmountComponentAtNode = legacyUnmountComponentAtNode;
15
7
  export let hydrate = legacyHydrate;
16
- /* eslint-enable */
17
-
18
- export function setClient({createRoot, hydrateRoot}) {
19
- const roots = new WeakMap();
20
-
21
- render = (element, container) => {
22
- let root = roots.get(container);
23
- if (root == null) {
24
- root = createRoot(container);
25
- roots.set(container, root);
26
- }
27
- root.render(element);
28
- };
29
-
30
- unmountComponentAtNode = container => roots.get(container)?.unmount();
31
-
32
- hydrate = (element, container) => {
33
- const root = hydrateRoot(container, element);
34
- roots.set(container, root);
35
- };
8
+ // TODO replace with a noop with warning in 6.0, remove in 7.0
9
+ export function setClient({ createRoot, hydrateRoot }) {
10
+ const roots = new WeakMap();
11
+ render = (element, container) => {
12
+ let root = roots.get(container);
13
+ if (root == null) {
14
+ root = createRoot(container);
15
+ roots.set(container, root);
16
+ }
17
+ root.render(element);
18
+ };
19
+ unmountComponentAtNode = container => roots.get(container)?.unmount();
20
+ hydrate = (element, container) => {
21
+ const root = hydrateRoot(container, element);
22
+ roots.set(container, root);
23
+ };
36
24
  }
@@ -1,6 +1,4 @@
1
1
  export default class RingAngularComponent {
2
- static $inject = [];
3
-
4
2
  static get controller() {
5
3
  return this;
6
4
  }
@@ -8,7 +6,7 @@ export default class RingAngularComponent {
8
6
  $inject = {};
9
7
 
10
8
  constructor(...args) {
11
- this.constructor.$inject.forEach((injectName, i) => {
9
+ (this.constructor.$inject ?? []).forEach((injectName, i) => {
12
10
  this.$inject[injectName] = args[i];
13
11
  });
14
12
  }
@@ -5,8 +5,9 @@ import 'angular-mocks';
5
5
  import RingAngularComponent from './ring-angular-component';
6
6
 
7
7
  class TestComponent extends RingAngularComponent {
8
- static $inject = ['$scope'];
8
+
9
9
  }
10
+ TestComponent.$inject = ['$scope'];
10
11
 
11
12
  const testModule = angular.module('Test', []).component('testComponent', TestComponent).name;
12
13
 
@@ -0,0 +1 @@
1
+ export default function useEventCallback<I extends unknown[], O>(fn: (...args: I) => O): (...args: I) => O;
@@ -0,0 +1,14 @@
1
+ import { useCallback, useLayoutEffect, useRef } from 'react';
2
+ export default function useEventCallback(fn) {
3
+ const ref = useRef();
4
+ useLayoutEffect(() => {
5
+ ref.current = fn;
6
+ });
7
+ return useCallback((...args) => {
8
+ const { current } = ref;
9
+ if (current == null) {
10
+ throw new Error('callback created in useEventCallback can only be called from event handlers');
11
+ }
12
+ return current(...args);
13
+ }, []);
14
+ }
@@ -87,8 +87,8 @@
87
87
  --ring-warning-background-color: rgb(var(--ring-warning-background-components)); /* #593d01 */
88
88
  --ring-added-background-components: 54, 89, 71;
89
89
  --ring-added-background-color: rgb(var(--ring-added-background-components)); /* #365947 */
90
- --ring-disabled-background-components: 54, 54, 54;
91
- --ring-disabled-background-color: rgb(var(--ring-disabled-background-components)); /* #363636 */
90
+ --ring-disabled-background-components: 44, 47, 51;
91
+ --ring-disabled-background-color: rgb(var(--ring-disabled-background-components)); /* #2C2F33 */
92
92
  --ring-disabled-selected-background-components: 44, 47, 51;
93
93
  --ring-disabled-selected-background-color: rgb(var(--ring-disabled-selected-background-components)); /* #2C2F33 */
94
94
  --ring-button-danger-active-components: 38, 8, 10;
@@ -1,4 +1,4 @@
1
- import { Component, ReactNode } from 'react';
1
+ import React, { Component, ReactNode } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  export interface ColProps {
4
4
  children?: ReactNode;
@@ -27,5 +27,5 @@ export default class Col extends Component<ColProps> {
27
27
  className: PropTypes.Requireable<string>;
28
28
  children: PropTypes.Requireable<PropTypes.ReactNodeLike>;
29
29
  };
30
- render(): JSX.Element;
30
+ render(): React.JSX.Element;
31
31
  }
@@ -1,4 +1,4 @@
1
- import { Component, HTMLAttributes } from 'react';
1
+ import React, { Component, HTMLAttributes } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  /**
4
4
  * @name Grid
@@ -8,7 +8,7 @@ export declare class Grid extends Component<HTMLAttributes<HTMLDivElement>> {
8
8
  className: PropTypes.Requireable<string>;
9
9
  children: PropTypes.Requireable<PropTypes.ReactNodeLike>;
10
10
  };
11
- render(): JSX.Element;
11
+ render(): React.JSX.Element;
12
12
  }
13
13
  export { default as Row } from './row';
14
14
  export { default as Col } from './col';
@@ -1,4 +1,4 @@
1
- import { Component, ReactNode } from 'react';
1
+ import React, { Component, ReactNode } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  declare const ModifierType: PropTypes.Requireable<string>;
4
4
  type ModifierType = 'xs' | 'sm' | 'md' | 'lg';
@@ -35,6 +35,6 @@ export default class Row extends Component<RowProps> {
35
35
  className: PropTypes.Requireable<string>;
36
36
  children: PropTypes.Requireable<PropTypes.ReactNodeLike>;
37
37
  };
38
- render(): JSX.Element;
38
+ render(): React.JSX.Element;
39
39
  }
40
40
  export {};
@@ -1,4 +1,4 @@
1
- import { Component, HTMLAttributes } from 'react';
1
+ import React, { Component, HTMLAttributes } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  /**
4
4
  * @name Group
@@ -8,5 +8,5 @@ export default class Group extends Component<HTMLAttributes<HTMLSpanElement>> {
8
8
  children: PropTypes.Requireable<PropTypes.ReactNodeLike>;
9
9
  className: PropTypes.Requireable<string>;
10
10
  };
11
- render(): JSX.Element;
11
+ render(): React.JSX.Element;
12
12
  }
@@ -1,4 +1,4 @@
1
- import { Component, HTMLAttributes } from 'react';
1
+ import React, { Component, HTMLAttributes } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  import Theme from '../global/theme';
4
4
  interface HeaderProps extends HTMLAttributes<HTMLElement> {
@@ -21,7 +21,7 @@ declare class Header extends Component<HeaderProps> {
21
21
  spaced: boolean;
22
22
  theme: Theme;
23
23
  };
24
- render(): JSX.Element;
24
+ render(): React.JSX.Element;
25
25
  }
26
26
  export type HeaderAttrs = JSX.LibraryManagedAttributes<typeof Header, HeaderProps>;
27
27
  export default Header;
@@ -1,4 +1,4 @@
1
- import { PureComponent } from 'react';
1
+ import React, { PureComponent } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  import { IconAttrs, Size } from '../icon/icon';
4
4
  export default class Logo extends PureComponent<IconAttrs> {
@@ -10,5 +10,5 @@ export default class Logo extends PureComponent<IconAttrs> {
10
10
  suppressSizeWarning: boolean;
11
11
  };
12
12
  static Size: typeof Size;
13
- render(): JSX.Element;
13
+ render(): React.JSX.Element;
14
14
  }
@@ -15,7 +15,7 @@ export interface ProfileTranslations {
15
15
  export interface ProfileProps extends Omit<HTMLAttributes<HTMLDivElement>, 'onSelect'> {
16
16
  closeOnSelect: boolean;
17
17
  renderPopupItems: (items: ListDataItem[]) => readonly ListDataItem[];
18
- translations: ProfileTranslations;
18
+ translations?: ProfileTranslations | null | undefined;
19
19
  size: Size;
20
20
  renderGuest: (props: ProfileProps) => ReactNode;
21
21
  hasUpdates?: boolean | null | undefined;
@@ -67,7 +67,9 @@ export default class Profile extends PureComponent<ProfileProps> {
67
67
  renderGuest: PropTypes.Requireable<(...args: any[]) => any>;
68
68
  };
69
69
  static defaultProps: ProfileProps;
70
+ static contextType: React.Context<import("../i18n/i18n-context").I18nContextProps>;
71
+ context: React.ContextType<typeof Profile.contextType>;
70
72
  static Size: typeof Size;
71
- render(): string | number | boolean | JSX.Element | React.ReactFragment | null | undefined;
73
+ render(): string | number | boolean | React.JSX.Element | Iterable<React.ReactNode> | null | undefined;
72
74
  }
73
75
  export type ProfileAttrs = JSX.LibraryManagedAttributes<typeof Profile, ProfileProps>;
@@ -5,6 +5,7 @@ import Avatar, { Size } from '../avatar/avatar';
5
5
  import Button from '../button/button';
6
6
  import DropdownMenu from '../dropdown-menu/dropdown-menu';
7
7
  import PopupMenu from '../popup-menu/popup-menu';
8
+ import { I18nContext } from '../i18n/i18n-context';
8
9
  import { isTruthy } from '../global/typescript-utils';
9
10
  import styles from './header.css';
10
11
  const rgItemType = PopupMenu.ListProps.Type.LINK;
@@ -48,17 +49,20 @@ export default class Profile extends PureComponent {
48
49
  static defaultProps = {
49
50
  closeOnSelect: true,
50
51
  renderPopupItems: items => items,
51
- translations: {},
52
52
  size: Size.Size32,
53
- renderGuest: ({ loading, onLogin, className, translations }) => (<div className={classNames(styles.profileEmpty, className)}>
54
- <Button primary data-test="ring-header-login-button" disabled={loading} loader={loading} onClick={onLogin}>
55
- {translations.login || 'Log in...'}
56
- </Button>
57
- </div>)
53
+ renderGuest: ({ loading, onLogin, className, translations }) => (<I18nContext.Consumer>
54
+ {({ translate }) => (<div className={classNames(styles.profileEmpty, className)}>
55
+ <Button primary data-test="ring-header-login-button" disabled={loading} loader={loading} onClick={onLogin}>
56
+ {translations?.login ?? translate('login')}
57
+ </Button>
58
+ </div>)}
59
+ </I18nContext.Consumer>)
58
60
  };
61
+ static contextType = I18nContext;
59
62
  static Size = Size;
60
63
  render() {
61
64
  const { className, closeOnSelect, hasUpdates, onLogout, user, profileUrl, LinkComponent, onSwitchUser, renderPopupItems, onRevertPostponement, showApplyChangedUser, showLogIn, showLogOut, showSwitchUser, renderGuest, translations, size, round, loading, onLogin, ...props } = this.props;
65
+ const { translate } = this.context;
62
66
  if (!user) {
63
67
  return (<div {...props} className={classNames(styles.profileEmpty, className)}>
64
68
  <Avatar size={size} round={round}/>
@@ -76,32 +80,32 @@ export default class Profile extends PureComponent {
76
80
  const items = [
77
81
  showApplyChangedUser && {
78
82
  rgItemType,
79
- label: translations.applyChangedUser || 'Apply changed user',
83
+ label: translations?.applyChangedUser ?? translate('applyChangedUser'),
80
84
  className: styles.profileMenuItem,
81
85
  onClick: onRevertPostponement
82
86
  },
83
87
  showLogIn && {
84
88
  rgItemType,
85
- label: translations.login || 'Log in',
89
+ label: translations?.login ?? translate('login'),
86
90
  className: styles.profileMenuItem,
87
91
  onClick: onRevertPostponement
88
92
  },
89
93
  {
90
94
  rgItemType: PopupMenu.ListProps.Type.LINK,
91
- label: translations.profile || 'Profile',
95
+ label: translations?.profile ?? translate('profile'),
92
96
  target: '_self',
93
97
  href: profileUrl,
94
98
  LinkComponent
95
99
  },
96
100
  showSwitchUser && {
97
101
  rgItemType,
98
- label: translations.switchUser || 'Switch user',
102
+ label: translations?.switchUser ?? translate('switchUser'),
99
103
  className: styles.profileMenuItem,
100
104
  onClick: onSwitchUser
101
105
  },
102
106
  showLogOut && {
103
107
  rgItemType,
104
- label: translations.logout || 'Log out',
108
+ label: translations?.logout ?? translate('logout'),
105
109
  onClick: onLogout
106
110
  }
107
111
  ].filter(isTruthy);
@@ -1,4 +1,4 @@
1
- import { PureComponent } from 'react';
1
+ import React, { PureComponent } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  import { LinkProps } from '../link/link';
4
4
  export interface Service {
@@ -21,5 +21,5 @@ export default class ServicesLink extends PureComponent<ServicesLinkProps> {
21
21
  name: PropTypes.Requireable<string>;
22
22
  }>>;
23
23
  };
24
- render(): JSX.Element;
24
+ render(): React.JSX.Element;
25
25
  }
@@ -1,4 +1,4 @@
1
- import { HTMLAttributes, PureComponent } from 'react';
1
+ import React, { HTMLAttributes, PureComponent } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  import Theme from '../global/theme';
4
4
  import ServicesLink, { Service } from './services-link';
@@ -29,5 +29,5 @@ export default class Services extends PureComponent<ServicesProps> {
29
29
  };
30
30
  static Link: typeof ServicesLink;
31
31
  serviceIsActive: (service: Service) => boolean;
32
- render(): JSX.Element;
32
+ render(): React.JSX.Element;
33
33
  }
@@ -1,4 +1,4 @@
1
- import { PureComponent } from 'react';
1
+ import React, { PureComponent } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  import Auth, { AuthUser } from '../auth/auth';
4
4
  import { Size } from '../avatar/avatar';
@@ -31,6 +31,6 @@ export default class SmartProfile extends PureComponent<SmartProfileProps, Smart
31
31
  onRevertPostponement: () => void;
32
32
  requestUser(): Promise<void>;
33
33
  checkUserCertificateMismatch(user: AuthUser): void;
34
- render(): JSX.Element;
34
+ render(): React.JSX.Element;
35
35
  }
36
36
  export {};
@@ -1,4 +1,4 @@
1
- import { Component, HTMLAttributes } from 'react';
1
+ import React, { Component, HTMLAttributes } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  import Auth from '../auth/auth';
4
4
  import HTTP from '../http/http';
@@ -21,5 +21,5 @@ export default class SmartServices extends Component<SmartServicesProps> {
21
21
  stopLoading: () => void;
22
22
  getServicesContent: () => void;
23
23
  getServices(fields: string): Promise<any> | undefined;
24
- render(): JSX.Element | null;
24
+ render(): React.JSX.Element | null;
25
25
  }
@@ -1,4 +1,4 @@
1
- import { Component } from 'react';
1
+ import React, { Component } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  import { ButtonAttrs } from '../button/button';
4
4
  import { IconType } from '../icon/icon';
@@ -28,5 +28,5 @@ export default class TrayIcon extends Component<ButtonAttrs & TrayIconSpecificPr
28
28
  children: PropTypes.Requireable<PropTypes.ReactNodeLike>;
29
29
  onClick: PropTypes.Requireable<(...args: any[]) => any>;
30
30
  };
31
- render(): JSX.Element;
31
+ render(): React.JSX.Element;
32
32
  }
@@ -1,9 +1,9 @@
1
- import { Component, HTMLAttributes } from 'react';
1
+ import React, { Component, HTMLAttributes } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  export default class Tray extends Component<HTMLAttributes<HTMLElement>> {
4
4
  static propTypes: {
5
5
  className: PropTypes.Requireable<string>;
6
6
  children: PropTypes.Requireable<PropTypes.ReactNodeLike>;
7
7
  };
8
- render(): JSX.Element;
8
+ render(): React.JSX.Element;
9
9
  }
@@ -9,30 +9,30 @@
9
9
  margin-top: 0;
10
10
  }
11
11
 
12
- @nest h1&, h2& {
12
+ &:is(h1, h2) {
13
13
  margin-bottom: 8px;
14
14
 
15
15
  color: var(--ring-heading-color);
16
16
  }
17
17
 
18
- @nest h1& {
18
+ &:is(h1) {
19
19
  font-size: 24px;
20
20
  line-height: 28px;
21
21
  }
22
22
 
23
- @nest h2& {
23
+ &:is(h2) {
24
24
  font-size: 20px;
25
25
  line-height: 24px;
26
26
  }
27
27
 
28
- @nest h3& {
28
+ &:is(h3) {
29
29
  margin-bottom: 0;
30
30
 
31
- font-size: inherit;
32
- line-height: inherit;
31
+ font-size: 16px;
32
+ line-height: 22px;
33
33
  }
34
34
 
35
- @nest h4& {
35
+ &:is(h4) {
36
36
  margin-bottom: 1px;
37
37
 
38
38
  letter-spacing: 1px;
@@ -40,7 +40,7 @@
40
40
 
41
41
  font-size: 12px;
42
42
  font-weight: normal;
43
- line-height: 16px;
43
+ line-height: 18px;
44
44
  }
45
45
  }
46
46
 
@@ -11,6 +11,7 @@ export declare class HTTPError extends ExtendableError {
11
11
  export declare const CODE: {
12
12
  UNAUTHORIZED: number;
13
13
  };
14
+ type Method<T> = (url: string, params?: RequestParams) => Promise<T>;
14
15
  export interface FetchParams<T = unknown> extends Omit<RequestInit, 'body' | 'headers'> {
15
16
  body?: T;
16
17
  query?: Record<string, unknown> | undefined;
@@ -40,12 +41,21 @@ export default class HTTP implements Partial<HTTPAuth> {
40
41
  private _storeRequestMeta;
41
42
  private _processResponse;
42
43
  private static _isErrorStatus;
43
- fetch: (url: string, params?: FetchParams) => Promise<any>;
44
+ fetch: <T = any>(url: string, params?: FetchParams) => Promise<T>;
44
45
  authorizedFetch(...args: Parameters<HTTP['_performRequest']>): Promise<any>;
45
- request: (url: string, params?: RequestParams) => Promise<any>;
46
+ request: <T = any>(url: string, params?: RequestParams) => Promise<T>;
46
47
  getMetaForResponse: (response: object) => Partial<Response> | undefined;
47
- get: (url: string, params?: RequestParamsWithoutMethod) => Promise<any>;
48
- post: (url: string, params?: RequestParamsWithoutMethod) => Promise<any>;
49
- delete: (url: string, params?: RequestParamsWithoutMethod) => Promise<any>;
50
- put: (url: string, params?: RequestParamsWithoutMethod) => Promise<any>;
48
+ get: <T = any>(url: string, params?: RequestParamsWithoutMethod) => Promise<T>;
49
+ post: <T = any>(url: string, params?: RequestParamsWithoutMethod) => Promise<T>;
50
+ delete: <T = any>(url: string, params?: RequestParamsWithoutMethod) => Promise<T>;
51
+ put: <T = any>(url: string, params?: RequestParamsWithoutMethod) => Promise<T>;
52
+ /**
53
+ * Usage: const {promise, abort} = http.abortify(http.get<{id: string}>)('http://test.com');
54
+ * @param method
55
+ */
56
+ abortify: <T>(method: Method<T>) => (url: string, params?: RequestParams<boolean> | undefined) => {
57
+ promise: Promise<T>;
58
+ abort: () => void;
59
+ };
51
60
  }
61
+ export {};
@@ -123,6 +123,8 @@ export default class HTTP {
123
123
  static _isErrorStatus(status) {
124
124
  return status < STATUS_OK_IF_MORE_THAN || status >= STATUS_BAD_IF_MORE_THAN;
125
125
  }
126
+ // TODO: Replace any to never/unknown in next release and remove eslint-disable
127
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
126
128
  fetch = async (url, params = {}) => {
127
129
  const { body, query = {}, ...fetchConfig } = params;
128
130
  const response = await this._fetch(this._makeRequestUrl(url, query), {
@@ -136,6 +138,8 @@ export default class HTTP {
136
138
  const response = await this._performRequest(...args);
137
139
  return this._processResponse(response);
138
140
  }
141
+ // TODO: Replace any to never/unknown in next release and remove eslint-disable
142
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
139
143
  request = async (url, params) => {
140
144
  let token = await this.requestToken?.();
141
145
  let response = await this._performRequest(url, token, params);
@@ -159,20 +163,42 @@ export default class HTTP {
159
163
  }
160
164
  };
161
165
  getMetaForResponse = (response) => this._requestsMeta.get(response);
166
+ // TODO: Replace any to never/unknown in next release and remove eslint-disable
167
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
162
168
  get = (url, params) => (this.request(url, {
163
169
  ...params,
164
170
  method: 'GET'
165
171
  }));
172
+ // TODO: Replace any to never/unknown in next release and remove eslint-disable
173
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
166
174
  post = (url, params) => (this.request(url, {
167
175
  ...params,
168
176
  method: 'POST'
169
177
  }));
178
+ // TODO: Replace any to never/unknown in next release and remove eslint-disable
179
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
170
180
  delete = (url, params) => (this.request(url, {
171
181
  ...params,
172
182
  method: 'DELETE'
173
183
  }));
184
+ // TODO: Replace any to never/unknown in next release and remove eslint-disable
185
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
174
186
  put = (url, params) => (this.request(url, {
175
187
  ...params,
176
188
  method: 'PUT'
177
189
  }));
190
+ /**
191
+ * Usage: const {promise, abort} = http.abortify(http.get<{id: string}>)('http://test.com');
192
+ * @param method
193
+ */
194
+ abortify = (method) => (...[url, params]) => {
195
+ const ctrl = new AbortController();
196
+ if (params && !('signal' in params)) {
197
+ params.signal = ctrl.signal;
198
+ }
199
+ return {
200
+ promise: method.call(this, url, params),
201
+ abort: () => ctrl.abort()
202
+ };
203
+ };
178
204
  }
@@ -5,7 +5,7 @@ export interface HubSourceUsersGroupsOptions {
5
5
  searchSideThreshold: number;
6
6
  }
7
7
  export interface UserGroup extends Item {
8
- id: number;
8
+ id: string;
9
9
  total?: number;
10
10
  userCount: number;
11
11
  iconUrl?: string;