@jetbrains/ring-ui-built 6.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (441) hide show
  1. package/LICENSE.txt +202 -0
  2. package/README.md +103 -0
  3. package/components/_helpers/_rollupPluginBabelHelpers.js +648 -0
  4. package/components/_helpers/anchor.js +31 -0
  5. package/components/_helpers/badge.js +3 -0
  6. package/components/_helpers/button__classes.js +34 -0
  7. package/components/_helpers/caption.js +31 -0
  8. package/components/_helpers/card.js +132 -0
  9. package/components/_helpers/date-picker.js +3 -0
  10. package/components/_helpers/dialog__body-scroll-preventer.js +54 -0
  11. package/components/_helpers/grid.js +3 -0
  12. package/components/_helpers/header.js +3 -0
  13. package/components/_helpers/heading.js +3 -0
  14. package/components/_helpers/icon__svg.js +75 -0
  15. package/components/_helpers/input.js +235 -0
  16. package/components/_helpers/island.js +3 -0
  17. package/components/_helpers/link.js +3 -0
  18. package/components/_helpers/list.js +3 -0
  19. package/components/_helpers/query-assist__suggestions.js +102 -0
  20. package/components/_helpers/select__filter.js +94 -0
  21. package/components/_helpers/services-link.js +48 -0
  22. package/components/_helpers/sidebar.js +123 -0
  23. package/components/_helpers/tab-link.js +34 -0
  24. package/components/_helpers/table.js +3 -0
  25. package/components/_helpers/theme.js +95 -0
  26. package/components/_helpers/title.js +103 -0
  27. package/components/alert/alert.d.ts +113 -0
  28. package/components/alert/alert.js +294 -0
  29. package/components/alert/container.d.ts +15 -0
  30. package/components/alert/container.js +52 -0
  31. package/components/alert-service/alert-service.d.ts +36 -0
  32. package/components/alert-service/alert-service.js +220 -0
  33. package/components/analytics/analytics.d.ts +18 -0
  34. package/components/analytics/analytics.js +31 -0
  35. package/components/analytics/analytics__custom-plugin.d.ts +28 -0
  36. package/components/analytics/analytics__custom-plugin.js +89 -0
  37. package/components/auth/auth.d.ts +3 -0
  38. package/components/auth/auth.js +133 -0
  39. package/components/auth/auth__core.d.ts +236 -0
  40. package/components/auth/auth__core.js +1653 -0
  41. package/components/auth/background-flow.d.ts +31 -0
  42. package/components/auth/background-flow.js +147 -0
  43. package/components/auth/down-notification.d.ts +15 -0
  44. package/components/auth/down-notification.js +157 -0
  45. package/components/auth/iframe-flow.d.ts +20 -0
  46. package/components/auth/iframe-flow.js +196 -0
  47. package/components/auth/request-builder.d.ts +48 -0
  48. package/components/auth/request-builder.js +104 -0
  49. package/components/auth/response-parser.d.ts +70 -0
  50. package/components/auth/response-parser.js +138 -0
  51. package/components/auth/storage.d.ts +112 -0
  52. package/components/auth/storage.js +429 -0
  53. package/components/auth/token-validator.d.ts +93 -0
  54. package/components/auth/token-validator.js +269 -0
  55. package/components/auth/window-flow.d.ts +26 -0
  56. package/components/auth/window-flow.js +154 -0
  57. package/components/auth-dialog/auth-dialog.d.ts +60 -0
  58. package/components/auth-dialog/auth-dialog.js +221 -0
  59. package/components/auth-dialog-service/auth-dialog-service.d.ts +6 -0
  60. package/components/auth-dialog-service/auth-dialog-service.js +92 -0
  61. package/components/avatar/avatar-example-datauri.d.ts +1 -0
  62. package/components/avatar/avatar-example-datauri.js +4 -0
  63. package/components/avatar/avatar.d.ts +52 -0
  64. package/components/avatar/avatar.js +183 -0
  65. package/components/avatar/fallback-avatar.d.ts +17 -0
  66. package/components/avatar/fallback-avatar.js +151 -0
  67. package/components/badge/badge.d.ts +24 -0
  68. package/components/badge/badge.js +59 -0
  69. package/components/button/button.d.ts +67 -0
  70. package/components/button/button.js +131 -0
  71. package/components/button/button__classes.d.ts +2 -0
  72. package/components/button/button__classes.js +2 -0
  73. package/components/button-group/button-group.d.ts +18 -0
  74. package/components/button-group/button-group.js +48 -0
  75. package/components/button-group/caption.d.ts +8 -0
  76. package/components/button-group/caption.js +5 -0
  77. package/components/button-set/button-set.d.ts +16 -0
  78. package/components/button-set/button-set.js +47 -0
  79. package/components/button-toolbar/button-toolbar.d.ts +16 -0
  80. package/components/button-toolbar/button-toolbar.js +46 -0
  81. package/components/caret/caret.d.ts +66 -0
  82. package/components/caret/caret.js +259 -0
  83. package/components/checkbox/checkbox.d.ts +45 -0
  84. package/components/checkbox/checkbox.js +130 -0
  85. package/components/clipboard/clipboard-fallback.d.ts +2 -0
  86. package/components/clipboard/clipboard-fallback.js +42 -0
  87. package/components/clipboard/clipboard.d.ts +5 -0
  88. package/components/clipboard/clipboard.js +185 -0
  89. package/components/code/code.d.ts +44 -0
  90. package/components/code/code.js +191 -0
  91. package/components/confirm/confirm.d.ts +48 -0
  92. package/components/confirm/confirm.js +153 -0
  93. package/components/confirm-service/confirm-service.d.ts +21 -0
  94. package/components/confirm-service/confirm-service.js +141 -0
  95. package/components/content-layout/content-layout.d.ts +26 -0
  96. package/components/content-layout/content-layout.js +79 -0
  97. package/components/content-layout/sidebar.d.ts +31 -0
  98. package/components/content-layout/sidebar.js +7 -0
  99. package/components/contenteditable/contenteditable.d.ts +47 -0
  100. package/components/contenteditable/contenteditable.js +84 -0
  101. package/components/control-label/control-label.d.ts +11 -0
  102. package/components/control-label/control-label.js +36 -0
  103. package/components/data-list/data-list.d.ts +85 -0
  104. package/components/data-list/data-list.js +251 -0
  105. package/components/data-list/data-list.mock.d.ts +16 -0
  106. package/components/data-list/data-list.mock.js +192 -0
  107. package/components/data-list/item.d.ts +50 -0
  108. package/components/data-list/item.js +235 -0
  109. package/components/data-list/selection.d.ts +16 -0
  110. package/components/data-list/selection.js +148 -0
  111. package/components/data-list/title.d.ts +26 -0
  112. package/components/data-list/title.js +28 -0
  113. package/components/date-picker/consts.d.ts +98 -0
  114. package/components/date-picker/consts.js +46 -0
  115. package/components/date-picker/date-input.d.ts +47 -0
  116. package/components/date-picker/date-input.js +177 -0
  117. package/components/date-picker/date-picker.d.ts +77 -0
  118. package/components/date-picker/date-picker.js +404 -0
  119. package/components/date-picker/date-popup.d.ts +55 -0
  120. package/components/date-picker/date-popup.js +488 -0
  121. package/components/date-picker/day.d.ts +30 -0
  122. package/components/date-picker/day.js +133 -0
  123. package/components/date-picker/formats.d.ts +2 -0
  124. package/components/date-picker/formats.js +3 -0
  125. package/components/date-picker/month-names.d.ts +13 -0
  126. package/components/date-picker/month-names.js +110 -0
  127. package/components/date-picker/month-slider.d.ts +29 -0
  128. package/components/date-picker/month-slider.js +93 -0
  129. package/components/date-picker/month.d.ts +14 -0
  130. package/components/date-picker/month.js +58 -0
  131. package/components/date-picker/months.d.ts +11 -0
  132. package/components/date-picker/months.js +133 -0
  133. package/components/date-picker/weekdays.d.ts +13 -0
  134. package/components/date-picker/weekdays.js +39 -0
  135. package/components/date-picker/years.d.ts +25 -0
  136. package/components/date-picker/years.js +134 -0
  137. package/components/dialog/dialog.d.ts +64 -0
  138. package/components/dialog/dialog.js +240 -0
  139. package/components/dialog/dialog__body-scroll-preventer.d.ts +9 -0
  140. package/components/dialog/dialog__body-scroll-preventer.js +6 -0
  141. package/components/dropdown/anchor.d.ts +11 -0
  142. package/components/dropdown/anchor.js +24 -0
  143. package/components/dropdown/dropdown.d.ts +87 -0
  144. package/components/dropdown/dropdown.js +247 -0
  145. package/components/dropdown-menu/dropdown-menu.d.ts +36 -0
  146. package/components/dropdown-menu/dropdown-menu.js +199 -0
  147. package/components/editable-heading/editable-heading.d.ts +32 -0
  148. package/components/editable-heading/editable-heading.js +276 -0
  149. package/components/error-bubble/error-bubble.d.ts +18 -0
  150. package/components/error-bubble/error-bubble.js +88 -0
  151. package/components/error-message/error-message.d.ts +27 -0
  152. package/components/error-message/error-message.js +78 -0
  153. package/components/footer/footer.d.ts +28 -0
  154. package/components/footer/footer.js +118 -0
  155. package/components/global/compose.d.ts +7 -0
  156. package/components/global/compose.js +17 -0
  157. package/components/global/composeRefs.d.ts +3 -0
  158. package/components/global/composeRefs.js +19 -0
  159. package/components/global/controls-height.d.ts +9 -0
  160. package/components/global/controls-height.js +19 -0
  161. package/components/global/create-stateful-context.d.ts +27 -0
  162. package/components/global/create-stateful-context.js +49 -0
  163. package/components/global/data-tests.d.ts +3 -0
  164. package/components/global/data-tests.js +30 -0
  165. package/components/global/dom.d.ts +37 -0
  166. package/components/global/dom.js +151 -0
  167. package/components/global/focus-sensor-hoc.d.ts +19 -0
  168. package/components/global/focus-sensor-hoc.js +165 -0
  169. package/components/global/fuzzy-highlight.d.ts +11 -0
  170. package/components/global/fuzzy-highlight.js +90 -0
  171. package/components/global/get-event-key.d.ts +2 -0
  172. package/components/global/get-event-key.js +101 -0
  173. package/components/global/get-uid.d.ts +1 -0
  174. package/components/global/get-uid.js +22 -0
  175. package/components/global/inject-styles.d.ts +3 -0
  176. package/components/global/inject-styles.js +22 -0
  177. package/components/global/linear-function.d.ts +6 -0
  178. package/components/global/linear-function.js +15 -0
  179. package/components/global/listeners.d.ts +8 -0
  180. package/components/global/listeners.js +58 -0
  181. package/components/global/memoize.d.ts +1 -0
  182. package/components/global/memoize.js +23 -0
  183. package/components/global/normalize-indent.d.ts +1 -0
  184. package/components/global/normalize-indent.js +60 -0
  185. package/components/global/promise-with-timeout.d.ts +5 -0
  186. package/components/global/promise-with-timeout.js +19 -0
  187. package/components/global/prop-types.d.ts +4 -0
  188. package/components/global/prop-types.js +9 -0
  189. package/components/global/react-dom-renderer.d.ts +16 -0
  190. package/components/global/react-dom-renderer.js +54 -0
  191. package/components/global/react-render-adapter.d.ts +1 -0
  192. package/components/global/react-render-adapter.js +6 -0
  193. package/components/global/rerender-hoc.d.ts +10 -0
  194. package/components/global/rerender-hoc.js +46 -0
  195. package/components/global/schedule-raf.d.ts +1 -0
  196. package/components/global/schedule-raf.js +28 -0
  197. package/components/global/sniffer.d.ts +3 -0
  198. package/components/global/sniffer.js +6 -0
  199. package/components/global/theme.d.ts +21 -0
  200. package/components/global/theme.js +42 -0
  201. package/components/global/trivial-template-tag.d.ts +1 -0
  202. package/components/global/trivial-template-tag.js +21 -0
  203. package/components/global/typescript-utils.d.ts +2 -0
  204. package/components/global/typescript-utils.js +8 -0
  205. package/components/global/url.d.ts +57 -0
  206. package/components/global/url.js +142 -0
  207. package/components/global/use-event-callback.d.ts +1 -0
  208. package/components/global/use-event-callback.js +17 -0
  209. package/components/global/variables.d.ts +89 -0
  210. package/components/global/variables.js +1 -0
  211. package/components/grid/col.d.ts +31 -0
  212. package/components/grid/col.js +80 -0
  213. package/components/grid/grid.d.ts +14 -0
  214. package/components/grid/grid.js +46 -0
  215. package/components/grid/row.d.ts +40 -0
  216. package/components/grid/row.js +75 -0
  217. package/components/group/group.d.ts +12 -0
  218. package/components/group/group.js +39 -0
  219. package/components/header/header.d.ts +34 -0
  220. package/components/header/header.js +189 -0
  221. package/components/header/logo.d.ts +14 -0
  222. package/components/header/logo.js +51 -0
  223. package/components/header/profile.d.ts +75 -0
  224. package/components/header/profile.js +258 -0
  225. package/components/header/services-link.d.ts +25 -0
  226. package/components/header/services-link.js +13 -0
  227. package/components/header/services.d.ts +33 -0
  228. package/components/header/services.js +174 -0
  229. package/components/header/smart-profile.d.ts +36 -0
  230. package/components/header/smart-profile.js +303 -0
  231. package/components/header/smart-services.d.ts +26 -0
  232. package/components/header/smart-services.js +192 -0
  233. package/components/header/tray-icon.d.ts +32 -0
  234. package/components/header/tray-icon.js +57 -0
  235. package/components/header/tray.d.ts +9 -0
  236. package/components/header/tray.js +41 -0
  237. package/components/heading/heading.d.ts +25 -0
  238. package/components/heading/heading.js +69 -0
  239. package/components/http/http.d.ts +61 -0
  240. package/components/http/http.js +386 -0
  241. package/components/http/http.mock.d.ts +20 -0
  242. package/components/http/http.mock.js +113 -0
  243. package/components/hub-source/hub-source.d.ts +44 -0
  244. package/components/hub-source/hub-source.js +217 -0
  245. package/components/hub-source/hub-source__user.d.ts +4 -0
  246. package/components/hub-source/hub-source__user.js +60 -0
  247. package/components/hub-source/hub-source__users-groups.d.ts +24 -0
  248. package/components/hub-source/hub-source__users-groups.js +86 -0
  249. package/components/i18n/i18n-context.d.ts +13 -0
  250. package/components/i18n/i18n-context.js +27 -0
  251. package/components/i18n/i18n.d.ts +59 -0
  252. package/components/i18n/i18n.js +139 -0
  253. package/components/icon/icon.d.ts +43 -0
  254. package/components/icon/icon.js +109 -0
  255. package/components/icon/icon__constants.d.ts +30 -0
  256. package/components/icon/icon__constants.js +34 -0
  257. package/components/icon/icon__svg.d.ts +15 -0
  258. package/components/icon/icon__svg.js +14 -0
  259. package/components/icon/index.d.ts +2 -0
  260. package/components/icon/index.js +17 -0
  261. package/components/input/input.d.ts +77 -0
  262. package/components/input/input.js +35 -0
  263. package/components/island/adaptive-island-hoc.d.ts +61 -0
  264. package/components/island/adaptive-island-hoc.js +53 -0
  265. package/components/island/content.d.ts +43 -0
  266. package/components/island/content.js +151 -0
  267. package/components/island/header.d.ts +8 -0
  268. package/components/island/header.js +100 -0
  269. package/components/island/island.d.ts +78 -0
  270. package/components/island/island.js +60 -0
  271. package/components/island-legacy/content-legacy.d.ts +10 -0
  272. package/components/island-legacy/content-legacy.js +34 -0
  273. package/components/island-legacy/header-legacy.d.ts +10 -0
  274. package/components/island-legacy/header-legacy.js +36 -0
  275. package/components/island-legacy/island-legacy.d.ts +12 -0
  276. package/components/island-legacy/island-legacy.js +36 -0
  277. package/components/link/clickableLink.d.ts +20 -0
  278. package/components/link/clickableLink.js +69 -0
  279. package/components/link/link.d.ts +138 -0
  280. package/components/link/link.js +86 -0
  281. package/components/list/consts.d.ts +77 -0
  282. package/components/list/consts.js +27 -0
  283. package/components/list/list.d.ts +205 -0
  284. package/components/list/list.js +802 -0
  285. package/components/list/list__custom.d.ts +6 -0
  286. package/components/list/list__custom.js +92 -0
  287. package/components/list/list__hint.d.ts +15 -0
  288. package/components/list/list__hint.js +33 -0
  289. package/components/list/list__item.d.ts +8 -0
  290. package/components/list/list__item.js +237 -0
  291. package/components/list/list__link.d.ts +9 -0
  292. package/components/list/list__link.js +76 -0
  293. package/components/list/list__separator.d.ts +5 -0
  294. package/components/list/list__separator.js +39 -0
  295. package/components/list/list__title.d.ts +5 -0
  296. package/components/list/list__title.js +48 -0
  297. package/components/list/list__users-groups-source.d.ts +27 -0
  298. package/components/list/list__users-groups-source.js +195 -0
  299. package/components/loader/loader.d.ts +28 -0
  300. package/components/loader/loader.js +93 -0
  301. package/components/loader/loader__core.d.ts +75 -0
  302. package/components/loader/loader__core.js +327 -0
  303. package/components/loader-inline/loader-inline.d.ts +18 -0
  304. package/components/loader-inline/loader-inline.js +50 -0
  305. package/components/loader-screen/loader-screen.d.ts +17 -0
  306. package/components/loader-screen/loader-screen.js +64 -0
  307. package/components/login-dialog/login-dialog.d.ts +47 -0
  308. package/components/login-dialog/login-dialog.js +216 -0
  309. package/components/login-dialog/service.d.ts +2 -0
  310. package/components/login-dialog/service.js +98 -0
  311. package/components/markdown/markdown.d.ts +12 -0
  312. package/components/markdown/markdown.js +43 -0
  313. package/components/message/message.d.ts +55 -0
  314. package/components/message/message.js +267 -0
  315. package/components/old-browsers-message/old-browsers-message.d.ts +2 -0
  316. package/components/old-browsers-message/old-browsers-message.js +92 -0
  317. package/components/old-browsers-message/old-browsers-message__stop.d.ts +1 -0
  318. package/components/old-browsers-message/old-browsers-message__stop.js +11 -0
  319. package/components/old-browsers-message/white-list.d.ts +2 -0
  320. package/components/old-browsers-message/white-list.js +37 -0
  321. package/components/pager/pager.d.ts +78 -0
  322. package/components/pager/pager.js +390 -0
  323. package/components/panel/panel.d.ts +12 -0
  324. package/components/panel/panel.js +39 -0
  325. package/components/permissions/permissions.d.ts +111 -0
  326. package/components/permissions/permissions.js +221 -0
  327. package/components/permissions/permissions__cache.d.ts +93 -0
  328. package/components/permissions/permissions__cache.js +257 -0
  329. package/components/popup/popup.consts.d.ts +37 -0
  330. package/components/popup/popup.consts.js +44 -0
  331. package/components/popup/popup.d.ts +147 -0
  332. package/components/popup/popup.js +424 -0
  333. package/components/popup/popup.target.d.ts +7 -0
  334. package/components/popup/popup.target.js +24 -0
  335. package/components/popup/position.d.ts +30 -0
  336. package/components/popup/position.js +271 -0
  337. package/components/popup-menu/popup-menu.d.ts +80 -0
  338. package/components/popup-menu/popup-menu.js +141 -0
  339. package/components/progress-bar/progress-bar.d.ts +64 -0
  340. package/components/progress-bar/progress-bar.js +120 -0
  341. package/components/query-assist/query-assist.d.ts +306 -0
  342. package/components/query-assist/query-assist.js +1098 -0
  343. package/components/query-assist/query-assist__suggestions.d.ts +29 -0
  344. package/components/query-assist/query-assist__suggestions.js +75 -0
  345. package/components/radio/radio.d.ts +18 -0
  346. package/components/radio/radio.js +48 -0
  347. package/components/radio/radio__item.d.ts +28 -0
  348. package/components/radio/radio__item.js +88 -0
  349. package/components/select/select.d.ts +276 -0
  350. package/components/select/select.js +1310 -0
  351. package/components/select/select__filter.d.ts +19 -0
  352. package/components/select/select__filter.js +85 -0
  353. package/components/select/select__popup.d.ts +166 -0
  354. package/components/select/select__popup.js +631 -0
  355. package/components/shortcuts/core.d.ts +74 -0
  356. package/components/shortcuts/core.js +249 -0
  357. package/components/shortcuts/shortcut-title.d.ts +1 -0
  358. package/components/shortcuts/shortcut-title.js +56 -0
  359. package/components/shortcuts/shortcuts-hoc.d.ts +65 -0
  360. package/components/shortcuts/shortcuts-hoc.js +61 -0
  361. package/components/shortcuts/shortcuts.d.ts +28 -0
  362. package/components/shortcuts/shortcuts.js +92 -0
  363. package/components/storage/storage.d.ts +18 -0
  364. package/components/storage/storage.js +92 -0
  365. package/components/storage/storage__fallback.d.ts +79 -0
  366. package/components/storage/storage__fallback.js +254 -0
  367. package/components/storage/storage__local.d.ts +38 -0
  368. package/components/storage/storage__local.js +217 -0
  369. package/components/style.css +1 -0
  370. package/components/tab-trap/tab-trap.d.ts +43 -0
  371. package/components/tab-trap/tab-trap.js +180 -0
  372. package/components/table/cell.d.ts +13 -0
  373. package/components/table/cell.js +37 -0
  374. package/components/table/disable-hover-hoc.d.ts +64 -0
  375. package/components/table/disable-hover-hoc.js +62 -0
  376. package/components/table/header-cell.d.ts +43 -0
  377. package/components/table/header-cell.js +109 -0
  378. package/components/table/header.d.ts +56 -0
  379. package/components/table/header.js +151 -0
  380. package/components/table/multitable.d.ts +25 -0
  381. package/components/table/multitable.js +140 -0
  382. package/components/table/row-with-focus-sensor.d.ts +18 -0
  383. package/components/table/row-with-focus-sensor.js +117 -0
  384. package/components/table/row.d.ts +59 -0
  385. package/components/table/row.js +299 -0
  386. package/components/table/selection-adapter.d.ts +5 -0
  387. package/components/table/selection-adapter.js +14 -0
  388. package/components/table/selection-shortcuts-hoc.d.ts +17 -0
  389. package/components/table/selection-shortcuts-hoc.js +205 -0
  390. package/components/table/selection.d.ts +47 -0
  391. package/components/table/selection.js +257 -0
  392. package/components/table/smart-table.d.ts +64 -0
  393. package/components/table/smart-table.js +149 -0
  394. package/components/table/table.d.ts +159 -0
  395. package/components/table/table.js +463 -0
  396. package/components/tabs/collapsible-more.d.ts +29 -0
  397. package/components/tabs/collapsible-more.js +222 -0
  398. package/components/tabs/collapsible-tab.d.ts +16 -0
  399. package/components/tabs/collapsible-tab.js +88 -0
  400. package/components/tabs/collapsible-tabs.d.ts +43 -0
  401. package/components/tabs/collapsible-tabs.js +354 -0
  402. package/components/tabs/custom-item.d.ts +9 -0
  403. package/components/tabs/custom-item.js +11 -0
  404. package/components/tabs/dumb-tabs.d.ts +35 -0
  405. package/components/tabs/dumb-tabs.js +189 -0
  406. package/components/tabs/smart-tabs.d.ts +20 -0
  407. package/components/tabs/smart-tabs.js +141 -0
  408. package/components/tabs/tab-link.d.ts +18 -0
  409. package/components/tabs/tab-link.js +13 -0
  410. package/components/tabs/tab.d.ts +27 -0
  411. package/components/tabs/tab.js +41 -0
  412. package/components/tabs/tabs.d.ts +7 -0
  413. package/components/tabs/tabs.js +99 -0
  414. package/components/tag/tag.d.ts +64 -0
  415. package/components/tag/tag.js +213 -0
  416. package/components/tags-input/tags-input.d.ts +138 -0
  417. package/components/tags-input/tags-input.js +534 -0
  418. package/components/tags-list/tags-list.d.ts +46 -0
  419. package/components/tags-list/tags-list.js +102 -0
  420. package/components/text/text.d.ts +23 -0
  421. package/components/text/text.js +57 -0
  422. package/components/toggle/toggle.d.ts +39 -0
  423. package/components/toggle/toggle.js +86 -0
  424. package/components/tooltip/tooltip.d.ts +65 -0
  425. package/components/tooltip/tooltip.js +229 -0
  426. package/components/user-agreement/service.d.ts +69 -0
  427. package/components/user-agreement/service.js +487 -0
  428. package/components/user-agreement/toolbox.eula.d.ts +2 -0
  429. package/components/user-agreement/toolbox.eula.js +3 -0
  430. package/components/user-agreement/user-agreement.d.ts +60 -0
  431. package/components/user-agreement/user-agreement.js +172 -0
  432. package/components/user-card/card.d.ts +70 -0
  433. package/components/user-card/card.js +80 -0
  434. package/components/user-card/smart-user-card-tooltip.d.ts +20 -0
  435. package/components/user-card/smart-user-card-tooltip.js +172 -0
  436. package/components/user-card/tooltip.d.ts +36 -0
  437. package/components/user-card/tooltip.js +144 -0
  438. package/components/user-card/user-card.d.ts +11 -0
  439. package/components/user-card/user-card.js +85 -0
  440. package/package.json +118 -0
  441. package/typings.d.ts +43 -0
@@ -0,0 +1,109 @@
1
+ import { _ as _defineProperty, a as _inherits, b as _createSuper, c as _classCallCheck, d as _createClass, e as _objectWithoutProperties, f as _extends } from '../_helpers/_rollupPluginBabelHelpers.js';
2
+ import React, { PureComponent } from 'react';
3
+ import PropTypes from 'prop-types';
4
+ import classNames from 'classnames';
5
+ import deprecate from 'util-deprecate';
6
+ import { Color, Size } from './icon__constants.js';
7
+ import { m as modules_29747b80, I as IconSVG } from '../_helpers/icon__svg.js';
8
+ import 'core-js/modules/es.regexp.exec.js';
9
+ import 'core-js/modules/es.string.replace.js';
10
+ import 'core-js/modules/es.string.starts-with.js';
11
+ import '../global/memoize.js';
12
+ import 'core-js/modules/es.array.iterator.js';
13
+ import 'core-js/modules/es.map.js';
14
+ import 'core-js/modules/es.object.to-string.js';
15
+ import 'core-js/modules/web.dom-collections.iterator.js';
16
+ import 'core-js/modules/es.weak-map.js';
17
+
18
+ var _excluded = ["className", "size", "color", "loading", "glyph", "width", "height", "suppressSizeWarning"];
19
+ var _warnSize = deprecate(function () {}, "`size`, `width` and `height` props are not recommended to use in Ring UI `Icon` component. The intrinsic sizes of SVG icon (`width` and `height` SVG attributes) are used instead.\n\nWe strongly recommend to use icons handcrafted for particular sizes. If your icon doesn't exist in the desired size, please ask your designer to draw one. \"Responsive\" checkmark should be unchecked when exporting icon.'");
20
+ var Icon = /*#__PURE__*/function (_PureComponent) {
21
+ _inherits(Icon, _PureComponent);
22
+ var _super = _createSuper(Icon);
23
+ function Icon() {
24
+ _classCallCheck(this, Icon);
25
+ return _super.apply(this, arguments);
26
+ }
27
+ _createClass(Icon, [{
28
+ key: "warnSize",
29
+ value: function warnSize() {
30
+ if (this.props.suppressSizeWarning) {
31
+ return;
32
+ }
33
+ _warnSize();
34
+ }
35
+ }, {
36
+ key: "getStyle",
37
+ value: function getStyle() {
38
+ var _this$props = this.props,
39
+ size = _this$props.size,
40
+ width = _this$props.width,
41
+ height = _this$props.height;
42
+ if (width || height) {
43
+ this.warnSize();
44
+ return {
45
+ width,
46
+ height
47
+ };
48
+ }
49
+ if (size) {
50
+ this.warnSize();
51
+ return {
52
+ width: size,
53
+ height: size
54
+ };
55
+ }
56
+ return undefined;
57
+ }
58
+ }, {
59
+ key: "render",
60
+ value: function render() {
61
+ var _this$props2 = this.props,
62
+ className = _this$props2.className;
63
+ _this$props2.size;
64
+ var color = _this$props2.color,
65
+ loading = _this$props2.loading,
66
+ Glyph = _this$props2.glyph;
67
+ _this$props2.width;
68
+ _this$props2.height;
69
+ _this$props2.suppressSizeWarning;
70
+ var restProps = _objectWithoutProperties(_this$props2, _excluded);
71
+ if (!Glyph) {
72
+ return null;
73
+ }
74
+ var classes = classNames(modules_29747b80.icon, {
75
+ [modules_29747b80[color]]: !!color,
76
+ [modules_29747b80.loading]: loading
77
+ }, className);
78
+ return /*#__PURE__*/React.createElement("span", _extends({}, restProps, {
79
+ className: classes
80
+ }), typeof Glyph === 'string' ? /*#__PURE__*/React.createElement(IconSVG, {
81
+ src: Glyph,
82
+ style: this.getStyle()
83
+ }) : /*#__PURE__*/React.createElement(Glyph, {
84
+ className: modules_29747b80.glyph,
85
+ style: this.getStyle()
86
+ }));
87
+ }
88
+ }]);
89
+ return Icon;
90
+ }(PureComponent);
91
+ _defineProperty(Icon, "propTypes", {
92
+ className: PropTypes.string,
93
+ color: PropTypes.string,
94
+ glyph: PropTypes.oneOfType([PropTypes.string, PropTypes.elementType]).isRequired,
95
+ height: PropTypes.number,
96
+ size: PropTypes.number,
97
+ width: PropTypes.number,
98
+ loading: PropTypes.bool,
99
+ suppressSizeWarning: PropTypes.bool
100
+ });
101
+ _defineProperty(Icon, "defaultProps", {
102
+ className: '',
103
+ color: Color.DEFAULT,
104
+ glyph: ''
105
+ });
106
+ _defineProperty(Icon, "Color", Color);
107
+ _defineProperty(Icon, "Size", Size);
108
+
109
+ export { Color, Size, Icon as default };
@@ -0,0 +1,30 @@
1
+ /**
2
+ * Commonly used icon colors.
3
+ * @enum {string}
4
+ */
5
+ export declare enum Color {
6
+ BLUE = "blue",
7
+ DEFAULT = "",
8
+ GRAY = "gray",
9
+ GREEN = "green",
10
+ MAGENTA = "magenta",
11
+ RED = "red",
12
+ WHITE = "white"
13
+ }
14
+ /**
15
+ * @enum {number}
16
+ */
17
+ export declare enum Size {
18
+ Size12 = 12,
19
+ Size14 = 14,
20
+ Size16 = 16,
21
+ Size18 = 18,
22
+ Size20 = 20,
23
+ Size24 = 24,
24
+ Size32 = 32,
25
+ Size40 = 40,
26
+ Size48 = 48,
27
+ Size64 = 64,
28
+ Size96 = 96,
29
+ Size128 = 128
30
+ }
@@ -0,0 +1,34 @@
1
+ /**
2
+ * Commonly used icon colors.
3
+ * @enum {string}
4
+ */
5
+ var Color;
6
+ (function (Color) {
7
+ Color["BLUE"] = "blue";
8
+ Color["DEFAULT"] = "";
9
+ Color["GRAY"] = "gray";
10
+ Color["GREEN"] = "green";
11
+ Color["MAGENTA"] = "magenta";
12
+ Color["RED"] = "red";
13
+ Color["WHITE"] = "white";
14
+ })(Color || (Color = {}));
15
+ /**
16
+ * @enum {number}
17
+ */
18
+ var Size;
19
+ (function (Size) {
20
+ Size[Size["Size12"] = 12] = "Size12";
21
+ Size[Size["Size14"] = 14] = "Size14";
22
+ Size[Size["Size16"] = 16] = "Size16";
23
+ Size[Size["Size18"] = 18] = "Size18";
24
+ Size[Size["Size20"] = 20] = "Size20";
25
+ Size[Size["Size24"] = 24] = "Size24";
26
+ Size[Size["Size32"] = 32] = "Size32";
27
+ Size[Size["Size40"] = 40] = "Size40";
28
+ Size[Size["Size48"] = 48] = "Size48";
29
+ Size[Size["Size64"] = 64] = "Size64";
30
+ Size[Size["Size96"] = 96] = "Size96";
31
+ Size[Size["Size128"] = 128] = "Size128";
32
+ })(Size || (Size = {}));
33
+
34
+ export { Color, Size };
@@ -0,0 +1,15 @@
1
+ import React, { SVGAttributes } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ export interface IconSVGProps extends SVGAttributes<SVGSVGElement> {
4
+ src: string;
5
+ }
6
+ declare function IconSVG({ src, className, ...rest }: IconSVGProps): React.JSX.Element;
7
+ declare namespace IconSVG {
8
+ var propTypes: {
9
+ className: PropTypes.Requireable<string>;
10
+ src: PropTypes.Validator<string>;
11
+ style: PropTypes.Requireable<object>;
12
+ };
13
+ }
14
+ declare const _default: React.MemoExoticComponent<typeof IconSVG>;
15
+ export default _default;
@@ -0,0 +1,14 @@
1
+ import '../_helpers/_rollupPluginBabelHelpers.js';
2
+ import 'core-js/modules/es.regexp.exec.js';
3
+ import 'core-js/modules/es.string.replace.js';
4
+ import 'core-js/modules/es.string.starts-with.js';
5
+ import 'react';
6
+ import 'classnames';
7
+ import 'prop-types';
8
+ import '../global/memoize.js';
9
+ export { I as default } from '../_helpers/icon__svg.js';
10
+ import 'core-js/modules/es.array.iterator.js';
11
+ import 'core-js/modules/es.map.js';
12
+ import 'core-js/modules/es.object.to-string.js';
13
+ import 'core-js/modules/web.dom-collections.iterator.js';
14
+ import 'core-js/modules/es.weak-map.js';
@@ -0,0 +1,2 @@
1
+ export { default } from './icon';
2
+ export * from './icon';
@@ -0,0 +1,17 @@
1
+ export { default } from './icon.js';
2
+ export { Color, Size } from './icon__constants.js';
3
+ import '../_helpers/_rollupPluginBabelHelpers.js';
4
+ import 'react';
5
+ import 'prop-types';
6
+ import 'classnames';
7
+ import 'util-deprecate';
8
+ import '../_helpers/icon__svg.js';
9
+ import 'core-js/modules/es.regexp.exec.js';
10
+ import 'core-js/modules/es.string.replace.js';
11
+ import 'core-js/modules/es.string.starts-with.js';
12
+ import '../global/memoize.js';
13
+ import 'core-js/modules/es.array.iterator.js';
14
+ import 'core-js/modules/es.map.js';
15
+ import 'core-js/modules/es.object.to-string.js';
16
+ import 'core-js/modules/web.dom-collections.iterator.js';
17
+ import 'core-js/modules/es.weak-map.js';
@@ -0,0 +1,77 @@
1
+ import React, { PureComponent, Ref, ComponentType, InputHTMLAttributes, TextareaHTMLAttributes, ReactNode } from 'react';
2
+ import { ControlsHeight } from '../global/controls-height';
3
+ import { LabelType } from '../control-label/control-label';
4
+ declare function noop(): void;
5
+ /**
6
+ * @name Input
7
+ */
8
+ declare enum Size {
9
+ AUTO = "Auto",
10
+ S = "S",
11
+ M = "M",
12
+ L = "L",
13
+ FULL = "FULL"
14
+ }
15
+ export interface InputTranslations {
16
+ clear: string;
17
+ }
18
+ export interface InputBaseProps {
19
+ size: Size;
20
+ enableShortcuts: boolean | string[];
21
+ children?: string | undefined;
22
+ inputClassName?: string | null | undefined;
23
+ label?: ReactNode;
24
+ labelType?: LabelType;
25
+ active?: boolean | null | undefined;
26
+ error?: ReactNode | null | undefined;
27
+ borderless?: boolean | null | undefined;
28
+ onClear?: ((e: React.MouseEvent<HTMLButtonElement>) => void) | null | undefined;
29
+ loading?: boolean | null | undefined;
30
+ icon?: string | ComponentType | null | undefined;
31
+ height?: ControlsHeight | undefined;
32
+ afterInput?: ReactNode;
33
+ translations?: InputTranslations | null | undefined;
34
+ }
35
+ type Override<D, S> = Omit<D, keyof S> & S;
36
+ export type InputSpecificProps = Override<InputHTMLAttributes<HTMLInputElement>, InputBaseProps> & {
37
+ multiline?: false | undefined;
38
+ inputRef: Ref<HTMLInputElement>;
39
+ };
40
+ type TextAreaSpecificProps = Override<TextareaHTMLAttributes<HTMLTextAreaElement>, InputBaseProps> & {
41
+ multiline: true;
42
+ inputRef: Ref<HTMLTextAreaElement>;
43
+ };
44
+ export type InputProps = InputSpecificProps | TextAreaSpecificProps;
45
+ export declare class Input extends PureComponent<InputProps> {
46
+ static defaultProps: {
47
+ size: Size;
48
+ onChange: typeof noop;
49
+ inputRef: typeof noop;
50
+ enableShortcuts: string[];
51
+ };
52
+ state: {
53
+ empty: boolean;
54
+ };
55
+ componentDidMount(): void;
56
+ componentDidUpdate(): void;
57
+ componentWillUnmount(): void;
58
+ static contextType: React.Context<ControlsHeight>;
59
+ frame?: number;
60
+ input?: HTMLInputElement | HTMLTextAreaElement | null;
61
+ id: string;
62
+ getId(): string;
63
+ checkValue(): void;
64
+ stretch(el: HTMLElement | null | undefined): void;
65
+ adapt(): void;
66
+ inputRef: (el: HTMLInputElement | HTMLTextAreaElement | null) => void;
67
+ clear: (e: React.MouseEvent<HTMLButtonElement>) => void;
68
+ handleInputChange: (e: React.ChangeEvent<HTMLInputElement>) => void;
69
+ handleTextareaChange: (e: React.ChangeEvent<HTMLTextAreaElement>) => void;
70
+ render(): React.JSX.Element;
71
+ }
72
+ export type ContainerProps<P extends InputProps> = JSX.LibraryManagedAttributes<typeof Input, P>;
73
+ export type InputSpecificAttrs = ContainerProps<InputSpecificProps>;
74
+ export type TextAreaSpecificAttrs = ContainerProps<TextAreaSpecificProps>;
75
+ export type InputAttrs = InputSpecificAttrs | TextAreaSpecificAttrs;
76
+ export default Input;
77
+ export { Size };
@@ -0,0 +1,35 @@
1
+ import '../_helpers/_rollupPluginBabelHelpers.js';
2
+ import 'core-js/modules/es.array.concat.js';
3
+ import 'core-js/modules/es.object.values.js';
4
+ import 'react';
5
+ import 'prop-types';
6
+ import 'classnames';
7
+ import '@jetbrains/icons/close-12px';
8
+ import '../global/prop-types.js';
9
+ import '../button/button.js';
10
+ import '../global/get-uid.js';
11
+ import '../icon/icon.js';
12
+ import '../i18n/i18n-context.js';
13
+ import '../global/composeRefs.js';
14
+ import '../global/controls-height.js';
15
+ import '../control-label/control-label.js';
16
+ export { I as Input, S as Size, I as default } from '../_helpers/input.js';
17
+ import '@jetbrains/icons/chevron-10px';
18
+ import '../link/clickableLink.js';
19
+ import '../_helpers/button__classes.js';
20
+ import '../icon/icon__constants.js';
21
+ import 'util-deprecate';
22
+ import '../_helpers/icon__svg.js';
23
+ import 'core-js/modules/es.regexp.exec.js';
24
+ import 'core-js/modules/es.string.replace.js';
25
+ import 'core-js/modules/es.string.starts-with.js';
26
+ import '../global/memoize.js';
27
+ import 'core-js/modules/es.array.iterator.js';
28
+ import 'core-js/modules/es.map.js';
29
+ import 'core-js/modules/es.object.to-string.js';
30
+ import 'core-js/modules/web.dom-collections.iterator.js';
31
+ import 'core-js/modules/es.weak-map.js';
32
+ import 'core-js/modules/es.regexp.to-string.js';
33
+ import '../i18n/i18n.js';
34
+ import 'core-js/modules/es.set.js';
35
+ import 'core-js/modules/web.dom-collections.for-each.js';
@@ -0,0 +1,61 @@
1
+ import React, { ComponentType } from 'react';
2
+ export declare const PhaseContext: React.Context<number | null>;
3
+ type ScrollHandler = (element: Element) => void;
4
+ export declare const ScrollHandlerContext: React.Context<ScrollHandler | null>;
5
+ export default function adaptiveIslandHOC<P>(ComposedComponent: ComponentType<P>): {
6
+ new (props: P | Readonly<P>): {
7
+ state: {
8
+ phase: null;
9
+ };
10
+ onContentScroll: ({ scrollTop, scrollHeight, clientHeight }: Element) => void;
11
+ render(): React.JSX.Element;
12
+ context: unknown;
13
+ setState<K extends never>(state: {} | ((prevState: Readonly<{}>, props: Readonly<P>) => {} | Pick<{}, K> | null) | Pick<{}, K> | null, callback?: (() => void) | undefined): void;
14
+ forceUpdate(callback?: (() => void) | undefined): void;
15
+ readonly props: Readonly<P>;
16
+ refs: {
17
+ [key: string]: React.ReactInstance;
18
+ };
19
+ componentDidMount?(): void;
20
+ shouldComponentUpdate?(nextProps: Readonly<P>, nextState: Readonly<{}>, nextContext: any): boolean;
21
+ componentWillUnmount?(): void;
22
+ componentDidCatch?(error: Error, errorInfo: React.ErrorInfo): void;
23
+ getSnapshotBeforeUpdate?(prevProps: Readonly<P>, prevState: Readonly<{}>): any;
24
+ componentDidUpdate?(prevProps: Readonly<P>, prevState: Readonly<{}>, snapshot?: any): void;
25
+ componentWillMount?(): void;
26
+ UNSAFE_componentWillMount?(): void;
27
+ componentWillReceiveProps?(nextProps: Readonly<P>, nextContext: any): void;
28
+ UNSAFE_componentWillReceiveProps?(nextProps: Readonly<P>, nextContext: any): void;
29
+ componentWillUpdate?(nextProps: Readonly<P>, nextState: Readonly<{}>, nextContext: any): void;
30
+ UNSAFE_componentWillUpdate?(nextProps: Readonly<P>, nextState: Readonly<{}>, nextContext: any): void;
31
+ };
32
+ new (props: P, context: any): {
33
+ state: {
34
+ phase: null;
35
+ };
36
+ onContentScroll: ({ scrollTop, scrollHeight, clientHeight }: Element) => void;
37
+ render(): React.JSX.Element;
38
+ context: unknown;
39
+ setState<K extends never>(state: {} | ((prevState: Readonly<{}>, props: Readonly<P>) => {} | Pick<{}, K> | null) | Pick<{}, K> | null, callback?: (() => void) | undefined): void;
40
+ forceUpdate(callback?: (() => void) | undefined): void;
41
+ readonly props: Readonly<P>;
42
+ refs: {
43
+ [key: string]: React.ReactInstance;
44
+ };
45
+ componentDidMount?(): void;
46
+ shouldComponentUpdate?(nextProps: Readonly<P>, nextState: Readonly<{}>, nextContext: any): boolean;
47
+ componentWillUnmount?(): void;
48
+ componentDidCatch?(error: Error, errorInfo: React.ErrorInfo): void;
49
+ getSnapshotBeforeUpdate?(prevProps: Readonly<P>, prevState: Readonly<{}>): any;
50
+ componentDidUpdate?(prevProps: Readonly<P>, prevState: Readonly<{}>, snapshot?: any): void;
51
+ componentWillMount?(): void;
52
+ UNSAFE_componentWillMount?(): void;
53
+ componentWillReceiveProps?(nextProps: Readonly<P>, nextContext: any): void;
54
+ UNSAFE_componentWillReceiveProps?(nextProps: Readonly<P>, nextContext: any): void;
55
+ componentWillUpdate?(nextProps: Readonly<P>, nextState: Readonly<{}>, nextContext: any): void;
56
+ UNSAFE_componentWillUpdate?(nextProps: Readonly<P>, nextState: Readonly<{}>, nextContext: any): void;
57
+ };
58
+ propTypes: React.WeakValidationMap<P> | undefined;
59
+ contextType?: React.Context<any> | undefined;
60
+ };
61
+ export {};
@@ -0,0 +1,53 @@
1
+ import { _ as _defineProperty, a as _inherits, b as _createSuper, c as _classCallCheck, k as _assertThisInitialized, d as _createClass } from '../_helpers/_rollupPluginBabelHelpers.js';
2
+ import 'core-js/modules/es.array.concat.js';
3
+ import React, { createContext, Component } from 'react';
4
+ import { interpolateLinear } from '../global/linear-function.js';
5
+
6
+ var TITLE_RESIZE_END = 20;
7
+ var TITLE_RESIZE_THRESHOLD = 36;
8
+ var PhaseContext = /*#__PURE__*/createContext(null);
9
+ var ScrollHandlerContext = /*#__PURE__*/createContext(null);
10
+ function adaptiveIslandHOC(ComposedComponent) {
11
+ var _class;
12
+ return _class = /*#__PURE__*/function (_Component) {
13
+ _inherits(AdaptiveIsland, _Component);
14
+ var _super = _createSuper(AdaptiveIsland);
15
+ function AdaptiveIsland() {
16
+ var _this;
17
+ _classCallCheck(this, AdaptiveIsland);
18
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
19
+ args[_key] = arguments[_key];
20
+ }
21
+ _this = _super.call.apply(_super, [this].concat(args));
22
+ _defineProperty(_assertThisInitialized(_this), "state", {
23
+ phase: null
24
+ });
25
+ _defineProperty(_assertThisInitialized(_this), "onContentScroll", function (_ref) {
26
+ var _this$state$phase;
27
+ var scrollTop = _ref.scrollTop,
28
+ scrollHeight = _ref.scrollHeight,
29
+ clientHeight = _ref.clientHeight;
30
+ if (scrollHeight - clientHeight >= interpolateLinear(TITLE_RESIZE_THRESHOLD, TITLE_RESIZE_END, (_this$state$phase = _this.state.phase) !== null && _this$state$phase !== void 0 ? _this$state$phase : 0)) {
31
+ var phase = Math.min(1, scrollTop / TITLE_RESIZE_END);
32
+ _this.setState({
33
+ phase
34
+ });
35
+ }
36
+ });
37
+ return _this;
38
+ }
39
+ _createClass(AdaptiveIsland, [{
40
+ key: "render",
41
+ value: function render() {
42
+ return /*#__PURE__*/React.createElement(PhaseContext.Provider, {
43
+ value: this.state.phase
44
+ }, /*#__PURE__*/React.createElement(ScrollHandlerContext.Provider, {
45
+ value: this.onContentScroll
46
+ }, /*#__PURE__*/React.createElement(ComposedComponent, this.props)));
47
+ }
48
+ }]);
49
+ return AdaptiveIsland;
50
+ }(Component), _defineProperty(_class, "propTypes", ComposedComponent.propTypes), _class;
51
+ }
52
+
53
+ export { PhaseContext, ScrollHandlerContext, adaptiveIslandHOC as default };
@@ -0,0 +1,43 @@
1
+ import React, { Component, HTMLAttributes } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import createResizeDetector from 'element-resize-detector';
4
+ export interface IslandContentProps extends Omit<HTMLAttributes<HTMLElement>, 'onScroll'> {
5
+ fade?: boolean | null | undefined;
6
+ onScrollToBottom?: (() => void) | null | undefined;
7
+ scrollableWrapperClassName?: string | null | undefined;
8
+ }
9
+ export interface IslandContentInnerProps extends IslandContentProps {
10
+ onScroll: (node: HTMLElement) => void;
11
+ bottomBorder: boolean;
12
+ }
13
+ declare class Content extends Component<IslandContentInnerProps> {
14
+ static propTypes: {
15
+ children: PropTypes.Requireable<PropTypes.ReactNodeLike>;
16
+ className: PropTypes.Requireable<string>;
17
+ scrollableWrapperClassName: PropTypes.Requireable<string>;
18
+ fade: PropTypes.Requireable<boolean>;
19
+ bottomBorder: PropTypes.Requireable<boolean>;
20
+ onScroll: PropTypes.Requireable<(...args: any[]) => any>;
21
+ onScrollToBottom: PropTypes.Requireable<(...args: any[]) => any>;
22
+ };
23
+ static defaultProps: {
24
+ fade: boolean;
25
+ bottomBorder: boolean;
26
+ onScroll: () => void;
27
+ onScrollToBottom: () => void;
28
+ };
29
+ state: {
30
+ scrolledToTop: boolean;
31
+ scrolledToBottom: boolean;
32
+ };
33
+ componentWillUnmount(): void;
34
+ resizeDetector: createResizeDetector.Erd;
35
+ wrapperNode?: HTMLElement | null;
36
+ setWrapper: (node: HTMLElement | null) => void;
37
+ calculateScrollPosition: () => void;
38
+ scrollableNode?: HTMLElement | null;
39
+ setScrollableNodeAndCalculatePosition: (node: HTMLElement | null) => void;
40
+ render(): React.JSX.Element;
41
+ }
42
+ declare const ContentWrapper: React.ForwardRefExoticComponent<IslandContentProps & React.RefAttributes<Content>>;
43
+ export default ContentWrapper;
@@ -0,0 +1,151 @@
1
+ import { _ as _defineProperty, a as _inherits, b as _createSuper, c as _classCallCheck, k as _assertThisInitialized, d as _createClass, e as _objectWithoutProperties, f as _extends } from '../_helpers/_rollupPluginBabelHelpers.js';
2
+ import 'core-js/modules/es.array.concat.js';
3
+ import React, { Component, forwardRef } from 'react';
4
+ import PropTypes from 'prop-types';
5
+ import classNames from 'classnames';
6
+ import createResizeDetector from 'element-resize-detector';
7
+ import scheduleRAF from '../global/schedule-raf.js';
8
+ import { m as modules_e6a056e1 } from '../_helpers/island.js';
9
+ import { ScrollHandlerContext } from './adaptive-island-hoc.js';
10
+ import '../global/linear-function.js';
11
+
12
+ var _excluded = ["children", "className", "bottomBorder", "scrollableWrapperClassName", "onScroll", "onScrollToBottom", "fade"];
13
+ var scheduleScrollAction = scheduleRAF();
14
+ var noop = function noop() {};
15
+ var END_DISTANCE = 16;
16
+ var Content = /*#__PURE__*/function (_Component) {
17
+ _inherits(Content, _Component);
18
+ var _super = _createSuper(Content);
19
+ function Content() {
20
+ var _this;
21
+ _classCallCheck(this, Content);
22
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
23
+ args[_key] = arguments[_key];
24
+ }
25
+ _this = _super.call.apply(_super, [this].concat(args));
26
+ _defineProperty(_assertThisInitialized(_this), "state", {
27
+ scrolledToTop: true,
28
+ scrolledToBottom: false
29
+ });
30
+ _defineProperty(_assertThisInitialized(_this), "resizeDetector", createResizeDetector({
31
+ strategy: 'scroll'
32
+ }));
33
+ _defineProperty(_assertThisInitialized(_this), "wrapperNode", void 0);
34
+ _defineProperty(_assertThisInitialized(_this), "setWrapper", function (node) {
35
+ if (!node) {
36
+ return;
37
+ }
38
+ _this.wrapperNode = node;
39
+ _this.resizeDetector.listenTo(node, _this.calculateScrollPosition);
40
+ });
41
+ _defineProperty(_assertThisInitialized(_this), "calculateScrollPosition", function () {
42
+ return scheduleScrollAction(function () {
43
+ var _assertThisInitialize = _assertThisInitialized(_this),
44
+ scrollableNode = _assertThisInitialize.scrollableNode;
45
+ if (!scrollableNode) {
46
+ return;
47
+ }
48
+ _this.props.onScroll(scrollableNode);
49
+ var scrollTop = scrollableNode.scrollTop,
50
+ scrollHeight = scrollableNode.scrollHeight,
51
+ offsetHeight = scrollableNode.offsetHeight;
52
+ var scrolledToTop = scrollTop === 0;
53
+ var scrolledToBottom = offsetHeight + scrollTop >= scrollHeight - END_DISTANCE;
54
+ if (scrolledToBottom) {
55
+ var _this$props$onScrollT, _this$props;
56
+ (_this$props$onScrollT = (_this$props = _this.props).onScrollToBottom) === null || _this$props$onScrollT === void 0 || _this$props$onScrollT.call(_this$props);
57
+ }
58
+ _this.setState({
59
+ scrolledToTop,
60
+ scrolledToBottom
61
+ });
62
+ });
63
+ });
64
+ _defineProperty(_assertThisInitialized(_this), "scrollableNode", void 0);
65
+ _defineProperty(_assertThisInitialized(_this), "setScrollableNodeAndCalculatePosition", function (node) {
66
+ if (!node) {
67
+ return;
68
+ }
69
+ _this.scrollableNode = node;
70
+ _this.calculateScrollPosition();
71
+ });
72
+ return _this;
73
+ }
74
+ _createClass(Content, [{
75
+ key: "componentWillUnmount",
76
+ value: function componentWillUnmount() {
77
+ this.scrollableNode = null;
78
+ if (!this.wrapperNode) {
79
+ return;
80
+ }
81
+ this.resizeDetector.removeAllListeners(this.wrapperNode);
82
+ }
83
+ }, {
84
+ key: "render",
85
+ value: function render() {
86
+ var _this$props2 = this.props,
87
+ children = _this$props2.children,
88
+ className = _this$props2.className,
89
+ bottomBorder = _this$props2.bottomBorder,
90
+ scrollableWrapperClassName = _this$props2.scrollableWrapperClassName;
91
+ _this$props2.onScroll;
92
+ _this$props2.onScrollToBottom;
93
+ var fade = _this$props2.fade,
94
+ restProps = _objectWithoutProperties(_this$props2, _excluded);
95
+ var _this$state = this.state,
96
+ scrolledToTop = _this$state.scrolledToTop,
97
+ scrolledToBottom = _this$state.scrolledToBottom;
98
+ var classes = classNames(modules_e6a056e1.content, className, {
99
+ [modules_e6a056e1.contentWithTopFade]: fade && !scrolledToTop,
100
+ [modules_e6a056e1.contentWithBottomFade]: fade && !scrolledToBottom,
101
+ [modules_e6a056e1.withTransparentBottomBorder]: bottomBorder,
102
+ [modules_e6a056e1.withBottomBorder]: bottomBorder && !scrolledToBottom
103
+ });
104
+ var scrollableWrapperClasses = classNames(modules_e6a056e1.scrollableWrapper, scrollableWrapperClassName);
105
+ return /*#__PURE__*/React.createElement("div", _extends({}, restProps, {
106
+ "data-test": "ring-island-content",
107
+ className: classes
108
+ }), /*#__PURE__*/React.createElement("div", {
109
+ // it has to be focusable because it can be scrollable
110
+ // eslint-disable-next-line jsx-a11y/no-noninteractive-tabindex
111
+ tabIndex: 0,
112
+ "data-scrollable-container": true,
113
+ className: scrollableWrapperClasses,
114
+ ref: this.setScrollableNodeAndCalculatePosition,
115
+ onScroll: fade ? this.calculateScrollPosition : noop
116
+ }, fade && /*#__PURE__*/React.createElement("div", {
117
+ ref: this.setWrapper
118
+ }, children), !fade && children));
119
+ }
120
+ }]);
121
+ return Content;
122
+ }(Component);
123
+ _defineProperty(Content, "propTypes", {
124
+ children: PropTypes.node,
125
+ className: PropTypes.string,
126
+ scrollableWrapperClassName: PropTypes.string,
127
+ fade: PropTypes.bool,
128
+ bottomBorder: PropTypes.bool,
129
+ onScroll: PropTypes.func,
130
+ onScrollToBottom: PropTypes.func
131
+ });
132
+ _defineProperty(Content, "defaultProps", {
133
+ fade: true,
134
+ bottomBorder: false,
135
+ onScroll: noop,
136
+ onScrollToBottom: noop
137
+ });
138
+ var ContentWrapper = /*#__PURE__*/forwardRef(function (props, ref) {
139
+ return /*#__PURE__*/React.createElement(ScrollHandlerContext.Consumer, null, function (onScroll) {
140
+ var addProps = onScroll != null ? {
141
+ onScroll,
142
+ bottomBorder: true
143
+ } : {};
144
+ return /*#__PURE__*/React.createElement(Content, _extends({}, props, addProps, {
145
+ ref: ref
146
+ }));
147
+ });
148
+ });
149
+ ContentWrapper.displayName = 'ContentWrapper';
150
+
151
+ export { ContentWrapper as default };
@@ -0,0 +1,8 @@
1
+ import React, { HTMLAttributes } from 'react';
2
+ export interface IslandHeaderProps extends HTMLAttributes<HTMLElement> {
3
+ wrapWithTitle?: boolean | undefined;
4
+ border?: boolean | null | undefined;
5
+ phase?: number | undefined;
6
+ }
7
+ declare const HeaderWrapper: (props: IslandHeaderProps) => React.JSX.Element;
8
+ export default HeaderWrapper;