@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,223 @@
1
+ /**
2
+ * @name Pager
3
+ */
4
+ import React, { PureComponent } from 'react';
5
+ import PropTypes from 'prop-types';
6
+ import classNames from 'classnames';
7
+ import chevronLeftIcon from '@jetbrains/icons/chevron-left';
8
+ import chevronRightIcon from '@jetbrains/icons/chevron-right';
9
+ import Button from '../button/button';
10
+ import ButtonGroup from '../button-group/button-group';
11
+ import ButtonToolbar from '../button-toolbar/button-toolbar';
12
+ import Select from '../select/select';
13
+ import memoize from '../global/memoize';
14
+ import Link from '../link/link';
15
+ import Icon from '../icon/icon';
16
+ import { I18nContext } from '../i18n/i18n-context';
17
+ import style from './pager.css';
18
+ export default class Pager extends PureComponent {
19
+ static defaultProps = {
20
+ currentPage: 1,
21
+ pageSize: 50,
22
+ // eslint-disable-next-line @typescript-eslint/no-magic-numbers
23
+ pageSizes: [20, 50, 100],
24
+ visiblePagesLimit: 7,
25
+ disablePageSizeSelector: false,
26
+ openTotal: false,
27
+ canLoadLastPageWithOpenTotal: false,
28
+ loader: false,
29
+ loaderNavigation: false,
30
+ onPageSizeChange: () => { },
31
+ onLoadPage: () => { }
32
+ };
33
+ static contextType = I18nContext;
34
+ getSelectOptions() {
35
+ const { pageSize, pageSizes } = this.props;
36
+ const { translate } = this.context;
37
+ const data = pageSizes.map(size => ({
38
+ key: size,
39
+ label: `${size} ${this.props.translations?.perPage ?? translate('perPage')}`
40
+ }));
41
+ const selected = data.find(it => it.key === pageSize);
42
+ return { selected, data };
43
+ }
44
+ getTotalPages() {
45
+ const { total, pageSize } = this.props;
46
+ return Math.ceil(total / pageSize);
47
+ }
48
+ handlePageSizeChange = (item) => {
49
+ if (item != null) {
50
+ this.props.onPageSizeChange(item.key);
51
+ }
52
+ };
53
+ handlePrevClick = () => {
54
+ const { currentPage } = this.props;
55
+ if (currentPage !== 1) {
56
+ const prevPage = currentPage - 1;
57
+ this.props.onPageChange?.(prevPage);
58
+ }
59
+ };
60
+ handleNextClick = () => {
61
+ const { currentPage, onLoadPage } = this.props;
62
+ const nextPage = currentPage + 1;
63
+ const total = this.getTotalPages();
64
+ if (currentPage !== total) {
65
+ this.props.onPageChange?.(nextPage);
66
+ }
67
+ else if (this.props.openTotal) {
68
+ onLoadPage(nextPage);
69
+ }
70
+ };
71
+ handlePageChange = memoize((i) => (event) => {
72
+ this.props.onPageChange?.(i, event);
73
+ });
74
+ handleLoadMore = memoize((i) => () => {
75
+ this.props.onLoadPage(i);
76
+ });
77
+ getButton(page, content, key, active) {
78
+ return (<Button href={this.generateHref(page)} key={key} active={active} disabled={this.props.loader && !active && !this.props.loaderNavigation} loader={this.props.loader && active} {...this.getClickProps(this.handlePageChange(page))}>
79
+ {content}
80
+ </Button>);
81
+ }
82
+ getClickProps(onClick) {
83
+ const { hrefFunc, onPageChange } = this.props;
84
+ if (!onPageChange) {
85
+ return {};
86
+ }
87
+ else if (hrefFunc) {
88
+ return { onPlainLeftClick: onClick };
89
+ }
90
+ else {
91
+ return { onClick };
92
+ }
93
+ }
94
+ getPageSizeSelector() {
95
+ const selectOptions = this.getSelectOptions();
96
+ return !this.props.disablePageSizeSelector &&
97
+ (<div data-test="ring-pager-page-size-selector" style={{ float: 'right' }}>
98
+ <Select data={selectOptions.data} selected={selectOptions.selected} onSelect={this.handlePageSizeChange} type={Select.Type.INLINE} disabled={this.props.loader}/>
99
+ </div>);
100
+ }
101
+ getPagerLinks() {
102
+ const { translate } = this.context;
103
+ const prevLinkAvailable = this.props.currentPage !== 1;
104
+ const nextLinkAvailable = this.props.openTotal ||
105
+ this.props.currentPage !== this.getTotalPages();
106
+ const nextIcon = (<Icon glyph={chevronRightIcon} key="icon"/>);
107
+ const prevIcon = (<Icon glyph={chevronLeftIcon} key="icon"/>);
108
+ const prevText = this.props.translations?.previousPage ?? translate('previousPage');
109
+ const nextText = this.props.translations?.nextPage ?? translate('nextPage');
110
+ const nextLinkContent = [<span key="text">{nextText}</span>, nextIcon];
111
+ const prevLinkContent = [prevIcon, <span key="text">{prevText}</span>];
112
+ const prevLinkHref = this.generateHref(this.props.currentPage - 1);
113
+ const nextLinkHref = this.generateHref(this.props.currentPage + 1);
114
+ const disabledLinkClasses = classNames({
115
+ [style.link]: true,
116
+ [style.linkDisabled]: true
117
+ });
118
+ return (<div className={style.links}>
119
+ {prevLinkAvailable && (!this.props.loader || this.props.loaderNavigation)
120
+ ? (<Link href={prevLinkHref} className={style.link} {...this.getClickProps(this.handlePrevClick)}>{prevLinkContent}</Link>)
121
+ : (<span className={disabledLinkClasses}>
122
+ {prevIcon}<span key="text">{prevText}</span>
123
+ </span>)}
124
+
125
+ {nextLinkAvailable && (!this.props.loader || this.props.loaderNavigation)
126
+ ? (<Link href={nextLinkHref} className={style.link} {...this.getClickProps(this.handleNextClick)}>{nextLinkContent}</Link>)
127
+ : (<span className={disabledLinkClasses}>
128
+ <span key="text">{nextText}</span>{nextIcon}
129
+ </span>)}
130
+ </div>);
131
+ }
132
+ generateHref(page) {
133
+ if (this.props.hrefFunc === undefined) {
134
+ return undefined;
135
+ }
136
+ const pageSize = this.props.disablePageSizeSelector ? undefined : this.props.pageSize;
137
+ return this.props.hrefFunc(page, pageSize);
138
+ }
139
+ getPagerContent() {
140
+ const { currentPage, visiblePagesLimit } = this.props;
141
+ const totalPages = this.getTotalPages();
142
+ const { translate } = this.context;
143
+ if (totalPages < this.props.currentPage) {
144
+ this.props.onPageChange?.(totalPages);
145
+ }
146
+ let start = 1;
147
+ let end = totalPages;
148
+ if (totalPages >= visiblePagesLimit) {
149
+ const leftHalfFrameSize = Math.ceil(visiblePagesLimit / 2) - 1;
150
+ const rightHalfFrameSize = visiblePagesLimit - leftHalfFrameSize - 1;
151
+ start = currentPage - leftHalfFrameSize;
152
+ end = currentPage + rightHalfFrameSize;
153
+ if (start < 1) {
154
+ const tail = 1 - start;
155
+ start += tail;
156
+ end += tail;
157
+ }
158
+ if (end > totalPages) {
159
+ const tail = end - totalPages;
160
+ start -= tail;
161
+ end -= tail;
162
+ }
163
+ if (start < 1) {
164
+ start += 1 - start;
165
+ }
166
+ }
167
+ const buttons = [];
168
+ for (let i = start; i <= end; i++) {
169
+ buttons.push(this.getButton(i, i, i, i === currentPage));
170
+ }
171
+ const lastPageButtonAvailable = (end < totalPages && !this.props.openTotal) ||
172
+ (this.props.openTotal && this.props.canLoadLastPageWithOpenTotal);
173
+ return (<div>
174
+ {this.getPagerLinks()}
175
+
176
+ <ButtonToolbar>
177
+ {start > 1 &&
178
+ this.getButton(1, this.props.translations?.firstPage ?? translate('firstPage'))}
179
+
180
+ <ButtonGroup>
181
+ {start > 1 && this.getButton(start - 1, '...')}
182
+
183
+ {buttons}
184
+
185
+ {end < totalPages && this.getButton(end + 1, '...')}
186
+
187
+ {end === totalPages && this.props.openTotal && (<Button href={this.generateHref(end + 1)} disabled={this.props.loader} {...this.getClickProps(this.handleLoadMore(end + 1))}>{'...'}</Button>)}
188
+ </ButtonGroup>
189
+
190
+ {lastPageButtonAvailable && this.getButton(this.props.openTotal ? -1 : totalPages, this.props.translations?.lastPage ?? translate('lastPage'))}
191
+ </ButtonToolbar>
192
+
193
+ {this.getPageSizeSelector()}
194
+
195
+ </div>);
196
+ }
197
+ render() {
198
+ const classes = classNames(style.pager, this.props.className);
199
+ return (<div data-test="ring-pager" className={classes}>
200
+ {this.getTotalPages() > 1 || this.props.openTotal
201
+ ? this.getPagerContent()
202
+ : this.getPageSizeSelector()}
203
+ </div>);
204
+ }
205
+ }
206
+ Pager.propTypes = {
207
+ total: PropTypes.number.isRequired,
208
+ currentPage: PropTypes.number,
209
+ pageSize: PropTypes.number,
210
+ pageSizes: PropTypes.arrayOf(PropTypes.number),
211
+ visiblePagesLimit: PropTypes.number,
212
+ disablePageSizeSelector: PropTypes.bool,
213
+ openTotal: PropTypes.bool,
214
+ canLoadLastPageWithOpenTotal: PropTypes.bool,
215
+ onPageChange: PropTypes.func,
216
+ onPageSizeChange: PropTypes.func,
217
+ onLoadPage: PropTypes.func,
218
+ className: PropTypes.string,
219
+ translations: PropTypes.object,
220
+ loader: PropTypes.bool,
221
+ loaderNavigation: PropTypes.bool,
222
+ hrefFunc: PropTypes.func //function which generates href for all pager's buttons based on pager state passed as a function parameter, either this function or onPageChange should be provided
223
+ };
@@ -0,0 +1,216 @@
1
+ /* stylelint-disable color-no-hex */
2
+
3
+ :global(.ring-palette_color-0) {
4
+ color: #444;
5
+ background-color: transparent;
6
+ }
7
+
8
+ :global(.ring-palette_color-1),
9
+ :global(.ring-palette_tone-0-0) {
10
+ color: #888;
11
+ background-color: #e6e6e6;
12
+ }
13
+
14
+ :global(.ring-palette_color-2),
15
+ :global(.ring-palette_tone-1-0) {
16
+ color: #4da400;
17
+ background-color: #e6f6cf;
18
+ }
19
+
20
+ :global(.ring-palette_color-3),
21
+ :global(.ring-palette_tone-2-0) {
22
+ color: #45818e;
23
+ background-color: #d8f7f3;
24
+ }
25
+
26
+ :global(.ring-palette_color-4),
27
+ :global(.ring-palette_tone-3-0) {
28
+ color: #3d85c6;
29
+ background-color: #e0f1fb;
30
+ }
31
+
32
+ :global(.ring-palette_color-5),
33
+ :global(.ring-palette_tone-4-0) {
34
+ color: #dc5766;
35
+ background-color: #fce5f1;
36
+ }
37
+
38
+ :global(.ring-palette_color-6),
39
+ :global(.ring-palette_tone-5-0) {
40
+ color: #b45f06;
41
+ background-color: #ffee9c;
42
+ }
43
+
44
+ :global(.ring-palette_color-7),
45
+ :global(.ring-palette_tone-6-0) {
46
+ color: #b45f06;
47
+ background-color: #f7e9c1;
48
+ }
49
+
50
+ :global(.ring-palette_color-8),
51
+ :global(.ring-palette_tone-0-1) {
52
+ color: #444;
53
+ background-color: #bababa;
54
+ }
55
+
56
+ :global(.ring-palette_color-9),
57
+ :global(.ring-palette_tone-1-1) {
58
+ color: #444;
59
+ background-color: #b7e281;
60
+ }
61
+
62
+ :global(.ring-palette_color-10),
63
+ :global(.ring-palette_tone-2-1) {
64
+ color: #444;
65
+ background-color: #92e1d5;
66
+ }
67
+
68
+ :global(.ring-palette_color-11),
69
+ :global(.ring-palette_tone-3-1) {
70
+ color: #444;
71
+ background-color: #a6e0fc;
72
+ }
73
+
74
+ :global(.ring-palette_color-12),
75
+ :global(.ring-palette_tone-4-1) {
76
+ color: #444;
77
+ background-color: #ffc8ea;
78
+ }
79
+
80
+ :global(.ring-palette_color-13),
81
+ :global(.ring-palette_tone-5-1) {
82
+ color: #444;
83
+ background-color: #fed74a;
84
+ }
85
+
86
+ :global(.ring-palette_color-14),
87
+ :global(.ring-palette_tone-6-1) {
88
+ color: #444;
89
+ background-color: #e0c378;
90
+ }
91
+
92
+ :global(.ring-palette_color-15),
93
+ :global(.ring-palette_tone-0-2) {
94
+ color: #fff;
95
+ background-color: #878787;
96
+ }
97
+
98
+ :global(.ring-palette_color-16),
99
+ :global(.ring-palette_tone-1-2) {
100
+ color: #fff;
101
+ background-color: #7dbd36;
102
+ }
103
+
104
+ :global(.ring-palette_color-17),
105
+ :global(.ring-palette_tone-2-2) {
106
+ color: #fff;
107
+ background-color: #25beb2;
108
+ }
109
+
110
+ :global(.ring-palette_color-18),
111
+ :global(.ring-palette_tone-3-2) {
112
+ color: #fff;
113
+ background-color: #42a3df;
114
+ }
115
+
116
+ :global(.ring-palette_color-19),
117
+ :global(.ring-palette_tone-4-2) {
118
+ color: #fff;
119
+ background-color: #ff7bc3;
120
+ }
121
+
122
+ :global(.ring-palette_color-20),
123
+ :global(.ring-palette_tone-5-2) {
124
+ color: #fff;
125
+ background-color: #ff7123;
126
+ }
127
+
128
+ :global(.ring-palette_color-21),
129
+ :global(.ring-palette_tone-6-2) {
130
+ color: #fff;
131
+ background-color: #ce6700;
132
+ }
133
+
134
+ :global(.ring-palette_color-22),
135
+ :global(.ring-palette_tone-0-3) {
136
+ color: #fff;
137
+ background-color: #4d4d4d;
138
+ }
139
+
140
+ :global(.ring-palette_color-23),
141
+ :global(.ring-palette_tone-1-3) {
142
+ color: #fff;
143
+ background-color: #409600;
144
+ }
145
+
146
+ :global(.ring-palette_color-24),
147
+ :global(.ring-palette_tone-2-3) {
148
+ color: #fff;
149
+ background-color: #2f9890;
150
+ }
151
+
152
+ :global(.ring-palette_color-25),
153
+ :global(.ring-palette_tone-3-3) {
154
+ color: #fff;
155
+ background-color: #0070e4;
156
+ }
157
+
158
+ :global(.ring-palette_color-26),
159
+ :global(.ring-palette_tone-4-3) {
160
+ color: #fff;
161
+ background-color: #dc0083;
162
+ }
163
+
164
+ :global(.ring-palette_color-27),
165
+ :global(.ring-palette_tone-5-3) {
166
+ color: #fff;
167
+ background-color: #e30000;
168
+ }
169
+
170
+ :global(.ring-palette_color-28),
171
+ :global(.ring-palette_tone-6-3) {
172
+ color: #fff;
173
+ background-color: #8d5100;
174
+ }
175
+
176
+ :global(.ring-palette_color-29),
177
+ :global(.ring-palette_tone-0-4) {
178
+ color: #fff;
179
+ background-color: #1a1a1a;
180
+ }
181
+
182
+ :global(.ring-palette_color-30),
183
+ :global(.ring-palette_tone-1-4) {
184
+ color: #fff;
185
+ background-color: #246512;
186
+ }
187
+
188
+ :global(.ring-palette_color-31),
189
+ :global(.ring-palette_tone-2-4) {
190
+ color: #fff;
191
+ background-color: #00665e;
192
+ }
193
+
194
+ :global(.ring-palette_color-32),
195
+ :global(.ring-palette_tone-3-4) {
196
+ color: #fff;
197
+ background-color: #0050a1;
198
+ }
199
+
200
+ :global(.ring-palette_color-33),
201
+ :global(.ring-palette_tone-4-4) {
202
+ color: #fff;
203
+ background-color: #900052;
204
+ }
205
+
206
+ :global(.ring-palette_color-34),
207
+ :global(.ring-palette_tone-5-4) {
208
+ color: #fff;
209
+ background-color: #8e1600;
210
+ }
211
+
212
+ :global(.ring-palette_color-35),
213
+ :global(.ring-palette_tone-6-4) {
214
+ color: #fff;
215
+ background-color: #553000;
216
+ }
@@ -0,0 +1,20 @@
1
+ @import "../global/variables.css";
2
+
3
+ .panel {
4
+ composes: panel from "../dialog/dialog.css"; /* TODO: Invert dependency using :externals CSS Modules selector */
5
+
6
+ position: relative;
7
+
8
+ margin-top: calc(var(--ring-unit) * 2);
9
+ padding: calc(var(--ring-unit) * 2) calc(var(--ring-unit) * 4) calc(var(--ring-unit) * 4);
10
+
11
+ border-top: 1px solid var(--ring-popup-border-color);
12
+
13
+ &:empty {
14
+ display: none;
15
+ }
16
+
17
+ & > button:not(:last-child) {
18
+ margin-right: var(--ring-unit);
19
+ }
20
+ }
@@ -0,0 +1,12 @@
1
+ import React, { HTMLAttributes, PureComponent } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ /**
4
+ * @name Panel
5
+ */
6
+ export default class Panel extends PureComponent<HTMLAttributes<HTMLElement>> {
7
+ static propTypes: {
8
+ className: PropTypes.Requireable<string>;
9
+ children: PropTypes.Requireable<PropTypes.ReactNodeLike>;
10
+ };
11
+ render(): React.JSX.Element;
12
+ }
@@ -0,0 +1,20 @@
1
+ import React, { PureComponent } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import classNames from 'classnames';
4
+ import styles from './panel.css';
5
+ /**
6
+ * @name Panel
7
+ */
8
+ export default class Panel extends PureComponent {
9
+ static propTypes = {
10
+ className: PropTypes.string,
11
+ children: PropTypes.node
12
+ };
13
+ render() {
14
+ const { className, children, ...props } = this.props;
15
+ const classes = classNames(styles.panel, className);
16
+ return (<div {...props} className={classes}>
17
+ {children}
18
+ </div>);
19
+ }
20
+ }
@@ -0,0 +1,111 @@
1
+ import Auth from '../auth/auth__core';
2
+ import PermissionCache, { Permission } from './permissions__cache';
3
+ export interface PermissionsConfig {
4
+ prefix?: string | null | undefined;
5
+ namesConverter?: ((name: string) => string) | null | undefined;
6
+ services?: readonly string[] | null | undefined;
7
+ datasource?: ((query: string | undefined) => Promise<readonly Permission[] | null | undefined>) | null | undefined;
8
+ }
9
+ interface PermissionsCacheControl {
10
+ NO_CACHE?: boolean | null | undefined;
11
+ NO_STORE?: boolean | null | undefined;
12
+ }
13
+ export interface PermissionsLoadOptions {
14
+ cacheControl?: PermissionsCacheControl | null | undefined;
15
+ }
16
+ /**
17
+ * <code>
18
+ * const permissions = new Permissions(auth, {prefix: 'jetbrains.jetpass.', services: [auth.serviceId]})
19
+ * permissions.load().then(function (p) {
20
+ * const canReadUser = p.has('read-user');
21
+ * ...
22
+ * });
23
+ *
24
+ * permissions.check('read-user').then(function(canReadUser) {
25
+ * ...
26
+ * });
27
+ * </code>
28
+ *
29
+ * @param {Auth} auth instance of well configured Auth object
30
+ * @param {{
31
+ * prefix: string?,
32
+ * namesConverter: function?
33
+ * serviceId: string?
34
+ * }=} config permissions loaded configuration.
35
+ * <code>prefix</code> if provided then this prefix is removed from the permissions names.
36
+ * <code>namesConverter</code> if provided it maps permission names used on server-side to client-side permission names. It is used only if prefix is undefined.
37
+ * <code>serviceId</code> if provided then permissions only for the service are loaded.
38
+ * @constructor
39
+ */
40
+ export default class Permissions {
41
+ /**
42
+ * @const {string}
43
+ */
44
+ static API_PERMISSION_CACHE_PATH: string;
45
+ query: string | undefined;
46
+ namesConverter: ((name: string) => string) | null | undefined;
47
+ private _auth;
48
+ private _datasource;
49
+ _promise: Promise<PermissionCache> | null;
50
+ private _subscribed;
51
+ private _permissionCache;
52
+ constructor(auth: Auth, config?: PermissionsConfig);
53
+ private _defaultDatasource;
54
+ /**
55
+ * Returns function, which cuts off prefix from server-side permission name
56
+ *
57
+ * @param {string} prefix
58
+ * @returns {Function}
59
+ */
60
+ static getDefaultNamesConverter(prefix: string): (storedName: string) => string;
61
+ static getPermissionQuery(services?: readonly string[] | null | undefined): string | undefined;
62
+ set(cachedPermissions?: readonly Permission[] | null | undefined): PermissionCache;
63
+ get(): readonly Permission[] | null | undefined;
64
+ private _setCache;
65
+ private _getCache;
66
+ private _resetCache;
67
+ /**
68
+ * Loads logged-in user permissions.
69
+ * @param {object?} options
70
+ * @return {Promise.<Permissions>} promise that is resolved when the permissions are loaded
71
+ */
72
+ load(options?: PermissionsLoadOptions | null | undefined): Promise<PermissionCache>;
73
+ _loadPermissions(): Promise<readonly Permission[] | null | undefined>;
74
+ /**
75
+ * Reloads permission cache from server
76
+ * @returns {Promise.<Permissions>} promise that is resolved when the permissions are reloaded
77
+ */
78
+ reload(): Promise<PermissionCache>;
79
+ /**
80
+ * Waits till the permission cache is loaded then checks if the current user has the
81
+ * given permissions in the project with the given id.
82
+ *
83
+ * @param {string} permissions space separated list of permissions
84
+ * @param {string=} projectId optional projectId. If absent the method checks
85
+ * if the given permission is granted in any project.
86
+ *
87
+ * @return {Promise.<boolean>}
88
+ */
89
+ check(permissions?: string | null | undefined, projectId?: string | null | undefined): Promise<boolean>;
90
+ /**
91
+ * Binds a property with the name <code>propertyName</code> of the <code>object</code>
92
+ * to a boolean value that is true if user has the permissions and false if she doesn't.
93
+ *
94
+ * @example
95
+ * <code>
96
+ * userPermissions.bindVariable($scope, 'canReadRole', 'role-read')
97
+ * </code>
98
+ *
99
+ * @param {object} object an object which property should be bound
100
+ * @param {string} propertyName a name of a property to bind
101
+ * @param {string} permissions space separated list of permissions
102
+ * @param {string=} projectId optional projectId. If absent the method checks
103
+ * if the given permissions are granted in any project.
104
+ *
105
+ * @return {Promise.<boolean>}
106
+ */
107
+ bindVariable<K extends string>(object: {
108
+ [key in K]?: boolean;
109
+ }, propertyName: K, permissions?: string | null | undefined, projectId?: string | null | undefined): Promise<boolean>;
110
+ }
111
+ export {};