@jetbrains/ring-ui 4.1.0-beta.8 → 4.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (440) hide show
  1. package/CHANGELOG.md +13 -0
  2. package/README.md +22 -16
  3. package/babel.config.js +3 -2
  4. package/components/alert/alert.js +9 -3
  5. package/components/alert/container.css +1 -1
  6. package/components/alert-service/alert-service.examples.css +18 -0
  7. package/components/alert-service/alert-service.examples.js +21 -0
  8. package/components/alert-service/alert-service.js +10 -3
  9. package/components/analytics/analytics__fus-plugin.js +3 -3
  10. package/components/analytics/analytics__ga-plugin.js +2 -2
  11. package/components/auth/auth.test.js +14 -7
  12. package/components/auth/auth__core.js +64 -33
  13. package/components/auth-dialog/auth-dialog.js +1 -0
  14. package/components/avatar/avatar.css +4 -1
  15. package/components/avatar/avatar.examples.js +3 -2
  16. package/components/avatar/avatar.js +31 -6
  17. package/components/avatar/fallback-avatar.js +136 -0
  18. package/components/avatar-editor-ng/avatar-editor-ng.css +2 -2
  19. package/components/avatar-editor-ng/avatar-editor-ng.js +2 -1
  20. package/components/avatar-editor-ng/{avatar-editor-ng.html → avatar-editor-ng__template.js} +2 -2
  21. package/components/button/button.css +2 -2
  22. package/components/button/button.js +4 -1
  23. package/components/button-group/button-group.js +1 -1
  24. package/components/button-group/caption.js +1 -1
  25. package/components/button-ng/button-ng.js +1 -1
  26. package/components/button-set-ng/button-set-ng.js +3 -1
  27. package/components/checkbox/checkbox.css +1 -1
  28. package/components/code/code.js +2 -5
  29. package/components/confirm/confirm.js +1 -0
  30. package/components/confirm-service/confirm-service.js +5 -5
  31. package/components/content-layout/content-layout.css +1 -1
  32. package/components/data-list/data-list.css +1 -1
  33. package/components/date-picker/date-input.js +5 -4
  34. package/components/date-picker/date-picker.css +34 -22
  35. package/components/date-picker/date-picker.js +16 -14
  36. package/components/date-picker/date-popup.js +22 -7
  37. package/components/date-picker/month-names.js +8 -5
  38. package/components/date-picker/month.js +6 -2
  39. package/components/date-picker/weekdays.js +10 -2
  40. package/components/dialog/dialog.examples.js +3 -1
  41. package/components/dialog/dialog.js +10 -5
  42. package/components/dialog/dialog.test.js +1 -1
  43. package/components/dialog/dialog__body-scroll-preventer.js +51 -31
  44. package/components/dialog-ng/dialog-ng.js +10 -10
  45. package/components/dialog-ng/{dialog-ng.html → dialog-ng__template.js} +2 -2
  46. package/components/dropdown/dropdown.examples.js +36 -1
  47. package/components/dropdown-menu/dropdown-menu.examples.js +47 -0
  48. package/components/dropdown-menu/dropdown-menu.js +117 -0
  49. package/components/dropdown-menu/dropdown-menu.test.js +76 -0
  50. package/components/error-bubble/error-bubble-legacy.css +1 -1
  51. package/components/error-bubble/error-bubble.css +1 -1
  52. package/components/error-bubble/error-bubble.examples.js +1 -1
  53. package/components/error-page/error-page.css +2 -2
  54. package/components/footer-ng/footer-ng.js +13 -3
  55. package/components/form/form.css +2 -2
  56. package/components/form-ng/form-ng.js +3 -1
  57. package/components/global/global.css +1 -1
  58. package/components/global/theme.js +1 -1
  59. package/components/global/variables.css +8 -1
  60. package/components/grid/grid.css +10 -9
  61. package/components/header/header.css +1 -1
  62. package/components/header/header.examples.js +7 -8
  63. package/components/header/profile.js +10 -11
  64. package/components/http/http.js +1 -1
  65. package/components/icon/icon.css +5 -4
  66. package/components/input/input-legacy.css +7 -7
  67. package/components/island/header.js +2 -2
  68. package/components/island/island.css +8 -3
  69. package/components/island-legacy/island-legacy.css +3 -1
  70. package/components/list/list.js +6 -1
  71. package/components/list/list__custom.js +9 -3
  72. package/components/list/list__item.js +8 -2
  73. package/components/list/list__link.js +2 -1
  74. package/components/loader-inline/loader-inline.css +1 -1
  75. package/components/loader-screen/loader-screen.css +1 -1
  76. package/components/message/message.css +1 -1
  77. package/components/message/message.examples.js +8 -7
  78. package/components/pager/pager.js +5 -3
  79. package/components/permissions/permissions.js +1 -1
  80. package/components/progress-bar/progress-bar.css +1 -1
  81. package/components/progress-bar/progress-bar.examples.js +3 -3
  82. package/components/progress-bar/progress-bar.js +5 -2
  83. package/components/progress-bar/progress-bar.test.js +12 -13
  84. package/components/progress-bar-ng/progress-bar-ng.examples.js +3 -3
  85. package/components/query-assist/query-assist.css +13 -3
  86. package/components/query-assist/query-assist.examples.js +3 -4
  87. package/components/query-assist/query-assist.js +56 -12
  88. package/components/query-assist/query-assist.test.js +37 -5
  89. package/components/save-field-ng/save-field-ng.css +0 -3
  90. package/components/save-field-ng/save-field-ng.js +3 -1
  91. package/components/save-field-ng/{save-field-ng.html → save-field-ng__template.js} +2 -2
  92. package/components/select/select.css +12 -7
  93. package/components/select/select.examples.js +13 -0
  94. package/components/select/select.js +30 -43
  95. package/components/select/select.test.js +4 -5
  96. package/components/shortcuts-hint-ng/shortcuts-hint-ng.css +1 -1
  97. package/components/shortcuts-hint-ng/shortcuts-hint-ng.js +1 -1
  98. package/components/shortcuts-hint-ng/{shortcuts-hint-ng.html → shortcuts-hint-ng__template.js} +2 -2
  99. package/components/sidebar/sidebar.css +1 -0
  100. package/components/sidebar-ng/sidebar-ng.js +6 -2
  101. package/components/sidebar-ng/{sidebar-ng__button.html → sidebar-ng__button-template.js} +2 -2
  102. package/components/sidebar-ng/{sidebar-ng.html → sidebar-ng__template.js} +2 -2
  103. package/components/table/header.js +9 -1
  104. package/components/table/row.js +2 -1
  105. package/components/table/table.css +2 -1
  106. package/components/table-legacy/table-legacy.css +2 -2
  107. package/components/table-legacy/table-legacy__toolbar.css +2 -2
  108. package/components/table-legacy-ng/table-legacy-ng.js +38 -5
  109. package/components/table-legacy-ng/table-legacy-ng__pager.js +7 -1
  110. package/components/tabs/collapsible-tab.js +2 -2
  111. package/components/tabs/collapsible-tabs.js +5 -9
  112. package/components/tabs/dumb-tabs.js +1 -0
  113. package/components/tabs/tab-link.js +4 -2
  114. package/components/tabs/tabs.css +32 -5
  115. package/components/tabs-ng/tabs-ng.js +4 -2
  116. package/components/tabs-ng/{tabs-ng.html → tabs-ng__template.js} +6 -2
  117. package/components/tag/tag.css +5 -2
  118. package/components/tag/tag.examples.js +3 -0
  119. package/components/tag/tag.js +19 -16
  120. package/components/tags-input/tag-input.examples.js +1 -1
  121. package/components/tags-input/tags-input.js +5 -2
  122. package/components/template-ng/template-ng.js +1 -1
  123. package/components/tooltip/tooltip.js +7 -2
  124. package/components/user-agreement/user-agreement.css +1 -5
  125. package/components/user-agreement/user-agreement.examples.js +7 -6
  126. package/components/user-agreement/user-agreement.js +11 -3
  127. package/dist/_helpers/_rollupPluginBabelHelpers.js +1 -94
  128. package/dist/_helpers/anchor.js +5 -6
  129. package/dist/_helpers/badge.js +1 -1
  130. package/dist/_helpers/button-group.js +3 -0
  131. package/dist/_helpers/button-set.js +3 -0
  132. package/dist/_helpers/button-toolbar.js +3 -0
  133. package/dist/_helpers/button__classes.js +1 -1
  134. package/dist/_helpers/card.js +6 -8
  135. package/dist/_helpers/checkbox.js +3 -0
  136. package/dist/_helpers/date-picker.js +1 -1
  137. package/dist/_helpers/dialog__body-scroll-preventer.js +49 -32
  138. package/dist/_helpers/error-message.js +3 -0
  139. package/dist/_helpers/footer.js +121 -0
  140. package/dist/_helpers/grid.js +1 -1
  141. package/dist/_helpers/group.js +3 -0
  142. package/dist/_helpers/header.js +1 -1
  143. package/dist/_helpers/icon.js +3 -0
  144. package/dist/_helpers/inject-styles.js +1 -1
  145. package/dist/_helpers/input.js +3 -0
  146. package/dist/_helpers/island.js +1 -1
  147. package/dist/_helpers/link.js +3 -0
  148. package/dist/_helpers/list.js +1 -1
  149. package/dist/_helpers/loader-screen.js +3 -0
  150. package/dist/_helpers/panel.js +3 -0
  151. package/dist/_helpers/query-assist__suggestions.js +1 -1
  152. package/dist/_helpers/radio.js +3 -0
  153. package/dist/_helpers/select__filter.js +6 -8
  154. package/dist/_helpers/services-link.js +6 -8
  155. package/dist/_helpers/sidebar.js +6 -8
  156. package/dist/_helpers/table.js +1 -1
  157. package/dist/_helpers/tabs.js +1 -1
  158. package/dist/_helpers/title.js +1 -1
  159. package/dist/alert/alert.js +15 -9
  160. package/dist/alert/container.js +7 -9
  161. package/dist/alert-service/alert-service.js +24 -13
  162. package/dist/analytics/analytics.js +2 -2
  163. package/dist/analytics/analytics__custom-plugin.js +1 -1
  164. package/dist/analytics/analytics__fus-plugin.js +4 -4
  165. package/dist/analytics/analytics__ga-plugin.js +3 -3
  166. package/dist/analytics/analytics__plugin-utils.js +1 -1
  167. package/dist/analytics-ng/analytics-ng.js +94 -0
  168. package/dist/auth/auth.js +7 -4
  169. package/dist/auth/auth__core.js +86 -48
  170. package/dist/auth/background-flow.js +1 -2
  171. package/dist/auth/down-notification.js +6 -3
  172. package/dist/auth/iframe-flow.js +5 -2
  173. package/dist/auth/landing-entry.js +1 -1
  174. package/dist/auth/landing.js +5 -2
  175. package/dist/auth/request-builder.js +1 -1
  176. package/dist/auth/response-parser.js +1 -1
  177. package/dist/auth/storage.js +3 -2
  178. package/dist/auth/token-validator.js +1 -1
  179. package/dist/auth/window-flow.js +1 -1
  180. package/dist/auth-dialog/auth-dialog.js +5 -3
  181. package/dist/auth-dialog-service/auth-dialog-service.js +6 -5
  182. package/dist/auth-ng/auth-ng.js +203 -0
  183. package/dist/auth-ng/auth-ng.mock.js +33 -0
  184. package/dist/autofocus-ng/autofocus-ng.js +50 -0
  185. package/dist/avatar/avatar.js +36 -30
  186. package/dist/avatar/fallback-avatar.js +141 -0
  187. package/dist/avatar-editor-ng/avatar-editor-ng.js +164 -0
  188. package/dist/avatar-editor-ng/avatar-editor-ng__template.js +30 -0
  189. package/dist/avatar-ng/avatar-ng.js +18 -0
  190. package/dist/badge/badge.js +6 -8
  191. package/dist/badge-ng/badge-ng.js +16 -0
  192. package/dist/breadcrumb-ng/breadcrumb-ng.js +61 -0
  193. package/dist/button/button.js +16 -10
  194. package/dist/button-group/button-group.js +4 -4
  195. package/dist/button-group/caption.js +24 -5
  196. package/dist/button-group-ng/button-group-ng.js +38 -0
  197. package/dist/button-ng/button-ng.js +223 -0
  198. package/dist/button-set/button-set.js +3 -4
  199. package/dist/button-set-ng/button-set-ng.js +19 -0
  200. package/dist/button-toolbar/button-toolbar.js +3 -4
  201. package/dist/button-toolbar-ng/button-toolbar-ng.js +23 -0
  202. package/dist/caret/caret.js +1 -1
  203. package/dist/checkbox/checkbox.js +9 -11
  204. package/dist/checkbox-ng/checkbox-ng.js +55 -0
  205. package/dist/code/code.js +136 -0
  206. package/dist/compiler-ng/compiler-ng.js +53 -0
  207. package/dist/confirm/confirm.js +6 -3
  208. package/dist/confirm-ng/confirm-ng.js +66 -0
  209. package/dist/confirm-service/confirm-service.js +12 -10
  210. package/dist/content-layout/content-layout.js +6 -8
  211. package/dist/contenteditable/contenteditable.js +13 -16
  212. package/dist/data-list/data-list.js +10 -7
  213. package/dist/data-list/data-list.mock.js +2 -2
  214. package/dist/data-list/item.js +5 -3
  215. package/dist/data-list/selection.js +1 -1
  216. package/dist/data-list/title.js +3 -1
  217. package/dist/data-list-ng/data-list-ng.js +59 -0
  218. package/dist/date-picker/consts.js +1 -2
  219. package/dist/date-picker/date-input.js +10 -6
  220. package/dist/date-picker/date-picker.js +38 -29
  221. package/dist/date-picker/date-popup.js +51 -28
  222. package/dist/date-picker/day.js +2 -2
  223. package/dist/date-picker/formats.js +1 -1
  224. package/dist/date-picker/month-names.js +16 -9
  225. package/dist/date-picker/month-slider.js +2 -2
  226. package/dist/date-picker/month.js +13 -7
  227. package/dist/date-picker/months.js +3 -3
  228. package/dist/date-picker/weekdays.js +12 -4
  229. package/dist/date-picker/years.js +2 -2
  230. package/dist/dialog/dialog.js +19 -14
  231. package/dist/dialog/dialog__body-scroll-preventer.js +1 -1
  232. package/dist/dialog-ng/dialog-ng.js +601 -0
  233. package/dist/dialog-ng/dialog-ng__template.js +71 -0
  234. package/dist/docked-panel-ng/docked-panel-ng.js +170 -0
  235. package/dist/dropdown/anchor.js +2 -1
  236. package/dist/dropdown/dropdown.js +8 -10
  237. package/dist/dropdown-menu/dropdown-menu.js +175 -0
  238. package/dist/error-bubble/error-bubble.js +7 -9
  239. package/dist/error-message/error-message.js +4 -4
  240. package/dist/error-message-ng/error-message-ng.js +53 -0
  241. package/dist/footer/footer.js +6 -122
  242. package/dist/footer-ng/footer-ng.js +75 -0
  243. package/dist/form-ng/form-ng.js +169 -0
  244. package/dist/global/angular-component-factory.js +1 -2
  245. package/dist/global/compose.js +1 -1
  246. package/dist/global/composeRefs.js +1 -1
  247. package/dist/global/conic-gradient.js +3 -5
  248. package/dist/global/create-stateful-context.js +1 -1
  249. package/dist/global/data-tests.js +1 -1
  250. package/dist/global/focus-sensor-hoc.js +9 -11
  251. package/dist/global/fuzzy-highlight.js +1 -1
  252. package/dist/global/get-event-key.js +1 -1
  253. package/dist/global/get-uid.js +1 -1
  254. package/dist/global/linear-function.js +1 -2
  255. package/dist/global/listeners.js +1 -1
  256. package/dist/global/memoize.js +1 -1
  257. package/dist/global/normalize-indent.js +1 -1
  258. package/dist/global/promise-with-timeout.js +1 -1
  259. package/dist/global/radial-gradient-mask.js +1 -1
  260. package/dist/global/react-dom-renderer.js +1 -1
  261. package/dist/global/rerender-hoc.js +3 -5
  262. package/dist/global/ring-angular-component.js +1 -1
  263. package/dist/global/schedule-raf.js +1 -1
  264. package/dist/global/sniffer.js +1 -1
  265. package/dist/global/supports-css.js +1 -1
  266. package/dist/global/theme.js +6 -8
  267. package/dist/global/trivial-template-tag.js +1 -1
  268. package/dist/global/variables_dark.js +1 -1
  269. package/dist/grid/col.js +6 -8
  270. package/dist/grid/grid.js +5 -7
  271. package/dist/grid/row.js +6 -8
  272. package/dist/group/group.js +7 -10
  273. package/dist/group-ng/group-ng.js +11 -0
  274. package/dist/header/header.js +29 -26
  275. package/dist/header/logo.js +8 -9
  276. package/dist/header/profile.js +37 -32
  277. package/dist/header/services-link.js +1 -0
  278. package/dist/header/services.js +10 -9
  279. package/dist/header/smart-profile.js +27 -24
  280. package/dist/header/smart-services.js +10 -9
  281. package/dist/header/tray-icon.js +12 -12
  282. package/dist/header/tray.js +6 -8
  283. package/dist/heading/heading.js +9 -12
  284. package/dist/http/http.js +37 -37
  285. package/dist/http/http.mock.js +4 -4
  286. package/dist/hub-source/hub-source.js +1 -1
  287. package/dist/hub-source/hub-source__users-groups.js +1 -1
  288. package/dist/icon/icon.js +8 -8
  289. package/dist/icon/icon__svg.js +81 -6
  290. package/dist/icon/index.js +2 -1
  291. package/dist/icon-ng/icon-ng.js +89 -0
  292. package/dist/input/input.js +9 -12
  293. package/dist/input-ng/input-ng.js +166 -0
  294. package/dist/island/adaptive-island-hoc.js +1 -2
  295. package/dist/island/content.js +6 -8
  296. package/dist/island/header.js +7 -9
  297. package/dist/island/island.js +6 -9
  298. package/dist/island-legacy/content-legacy.js +6 -8
  299. package/dist/island-legacy/header-legacy.js +6 -8
  300. package/dist/island-legacy/island-legacy.js +6 -8
  301. package/dist/island-ng/island-content-ng.js +56 -0
  302. package/dist/island-ng/island-header-ng.js +32 -0
  303. package/dist/island-ng/island-ng-class-fixer.js +9 -0
  304. package/dist/island-ng/island-ng.js +31 -0
  305. package/dist/link/clickableLink.js +6 -8
  306. package/dist/link/link.js +7 -11
  307. package/dist/link-ng/link-ng.js +25 -0
  308. package/dist/list/list.js +25 -13
  309. package/dist/list/list__custom.js +13 -10
  310. package/dist/list/list__hint.js +1 -1
  311. package/dist/list/list__item.js +20 -13
  312. package/dist/list/list__link.js +11 -12
  313. package/dist/list/list__separator.js +1 -1
  314. package/dist/list/list__title.js +1 -1
  315. package/dist/list/list__users-groups-source.js +11 -7
  316. package/dist/loader/loader.js +6 -8
  317. package/dist/loader/loader__core.js +2 -2
  318. package/dist/loader-inline/inject-styles.js +1 -1
  319. package/dist/loader-inline/loader-inline.js +6 -8
  320. package/dist/loader-inline-ng/loader-inline-ng.js +42 -0
  321. package/dist/loader-ng/loader-ng.js +43 -0
  322. package/dist/loader-screen/loader-screen.js +7 -10
  323. package/dist/loader-screen-ng/loader-screen-ng.js +99 -0
  324. package/dist/login-dialog/login-dialog.js +5 -3
  325. package/dist/login-dialog/service.js +7 -5
  326. package/dist/markdown/code.js +30 -0
  327. package/dist/markdown/heading.js +23 -0
  328. package/dist/markdown/link.js +30 -0
  329. package/dist/markdown/markdown.js +73 -0
  330. package/dist/message/message.js +5 -4
  331. package/dist/message-bundle-ng/message-bundle-ng.js +111 -0
  332. package/dist/old-browsers-message/old-browsers-message.js +0 -1
  333. package/dist/old-browsers-message/old-browsers-message__stop.js +0 -1
  334. package/dist/old-browsers-message/white-list.js +4 -5
  335. package/dist/pager/pager.js +18 -9
  336. package/dist/pager-ng/pager-ng.js +96 -0
  337. package/dist/panel/panel.js +7 -10
  338. package/dist/panel-ng/panel-ng.js +16 -0
  339. package/dist/permissions/permissions.js +1 -1
  340. package/dist/permissions/permissions__cache.js +1 -1
  341. package/dist/permissions-ng/permissions-ng.js +274 -0
  342. package/dist/place-under-ng/place-under-ng.js +157 -0
  343. package/dist/popup/popup.js +8 -8
  344. package/dist/popup/popup.target.js +4 -5
  345. package/dist/popup/position.js +1 -2
  346. package/dist/popup-menu/popup-menu.js +21 -14
  347. package/dist/progress-bar/progress-bar.js +12 -10
  348. package/dist/progress-bar-ng/progress-bar-ng.js +15 -0
  349. package/dist/promised-click-ng/promised-click-ng.js +126 -0
  350. package/dist/proxy-attrs/proxy-attrs.js +1 -1
  351. package/dist/query-assist/query-assist.js +97 -28
  352. package/dist/query-assist/query-assist__suggestions.js +5 -1
  353. package/dist/query-assist-ng/query-assist-ng.js +82 -0
  354. package/dist/radio/radio.js +7 -5
  355. package/dist/radio/radio__item.js +10 -15
  356. package/dist/radio-ng/radio-ng.js +63 -0
  357. package/dist/save-field-ng/save-field-ng.js +335 -0
  358. package/dist/save-field-ng/save-field-ng__template.js +34 -0
  359. package/dist/select/select.js +50 -49
  360. package/dist/select/select__filter.js +6 -1
  361. package/dist/select/select__popup.js +8 -3
  362. package/dist/select-ng/select-ng.js +621 -0
  363. package/dist/select-ng/select-ng__lazy.js +150 -0
  364. package/dist/select-ng/select-ng__options.js +145 -0
  365. package/dist/shortcuts/core.js +2 -2
  366. package/dist/shortcuts/shortcuts-hoc.js +6 -8
  367. package/dist/shortcuts/shortcuts.js +6 -6
  368. package/dist/shortcuts-hint-ng/shortcuts-hint-ng.js +120 -0
  369. package/dist/shortcuts-hint-ng/shortcuts-hint-ng__template.js +50 -0
  370. package/dist/shortcuts-ng/shortcuts-ng.js +261 -0
  371. package/dist/sidebar-ng/sidebar-ng.js +111 -0
  372. package/dist/sidebar-ng/sidebar-ng__button-template.js +20 -0
  373. package/dist/sidebar-ng/sidebar-ng__template.js +12 -0
  374. package/dist/storage/storage.js +3 -2
  375. package/dist/storage/storage__fallback.js +1 -1
  376. package/dist/storage/storage__local.js +3 -2
  377. package/dist/style.css +1 -1
  378. package/dist/tab-trap/tab-trap.js +7 -9
  379. package/dist/table/cell.js +2 -2
  380. package/dist/table/disable-hover-hoc.js +2 -2
  381. package/dist/table/header-cell.js +8 -9
  382. package/dist/table/header.js +10 -6
  383. package/dist/table/multitable.js +1 -1
  384. package/dist/table/row-with-focus-sensor.js +5 -3
  385. package/dist/table/row.js +11 -10
  386. package/dist/table/selection-adapter.js +1 -1
  387. package/dist/table/selection-shortcuts-hoc.js +8 -6
  388. package/dist/table/selection.js +1 -1
  389. package/dist/table/smart-table.js +14 -8
  390. package/dist/table/table.js +10 -11
  391. package/dist/table-legacy-ng/table-legacy-ng.js +501 -0
  392. package/dist/table-legacy-ng/table-legacy-ng__pager.js +122 -0
  393. package/dist/table-legacy-ng/table-legacy-ng__selection-navigate-actions.js +123 -0
  394. package/dist/table-legacy-ng/table-legacy-ng__selection.js +179 -0
  395. package/dist/table-legacy-ng/table-legacy-ng__toolbar.js +56 -0
  396. package/dist/table-ng/smart-table-ng.js +65 -0
  397. package/dist/table-ng/table-ng.js +64 -0
  398. package/dist/tabs/collapsible-more.js +9 -6
  399. package/dist/tabs/collapsible-tab.js +7 -7
  400. package/dist/tabs/collapsible-tabs.js +19 -20
  401. package/dist/tabs/dumb-tabs.js +12 -9
  402. package/dist/tabs/smart-tabs.js +11 -9
  403. package/dist/tabs/tab-link.js +13 -7
  404. package/dist/tabs/tab.js +1 -1
  405. package/dist/tabs/tabs.js +5 -1
  406. package/dist/tabs-ng/tabs-ng.js +193 -0
  407. package/dist/tabs-ng/tabs-ng__template.js +40 -0
  408. package/dist/tag/tag.js +20 -14
  409. package/dist/tags-input/tags-input.js +14 -10
  410. package/dist/tags-input-ng/tags-input-ng.js +89 -0
  411. package/dist/tags-list/tags-list.js +8 -9
  412. package/dist/template-ng/template-ng.js +70 -0
  413. package/dist/text/text.js +7 -9
  414. package/dist/theme-ng/theme-ng.js +44 -0
  415. package/dist/title-ng/title-ng.js +114 -0
  416. package/dist/toggle/toggle.js +8 -11
  417. package/dist/toggle-ng/toggle-ng.js +16 -0
  418. package/dist/tooltip/tooltip.js +14 -12
  419. package/dist/tooltip-ng/tooltip-ng.js +98 -0
  420. package/dist/user-agreement/service.js +409 -0
  421. package/dist/user-agreement/toolbox.eula.js +162 -0
  422. package/dist/user-agreement/user-agreement.js +167 -0
  423. package/dist/user-card/card.js +3 -0
  424. package/dist/user-card/smart-user-card-tooltip.js +14 -14
  425. package/dist/user-card/tooltip.js +9 -7
  426. package/dist/user-card/user-card.js +5 -2
  427. package/dist/user-card-ng/user-card-ng.js +59 -0
  428. package/package.json +84 -82
  429. package/webpack.config.js +14 -10
  430. package/components/button-set-ng/button-set-ng.html +0 -1
  431. package/components/footer-ng/footer-ng.html +0 -13
  432. package/components/form-ng/form-ng__error-bubble.html +0 -3
  433. package/components/table-legacy-ng/table-legacy-ng.html +0 -4
  434. package/components/table-legacy-ng/table-legacy-ng__column.html +0 -12
  435. package/components/table-legacy-ng/table-legacy-ng__header.html +0 -4
  436. package/components/table-legacy-ng/table-legacy-ng__pager.html +0 -7
  437. package/components/table-legacy-ng/table-legacy-ng__row.html +0 -12
  438. package/components/table-legacy-ng/table-legacy-ng__title.html +0 -9
  439. package/dist/_helpers/caption.js +0 -25
  440. package/dist/_helpers/icon__svg.js +0 -83
@@ -15,7 +15,8 @@ import '@jetbrains/icons/close';
15
15
  import '../icon/icon.js';
16
16
  import 'util-deprecate';
17
17
  import '../icon/icon__constants.js';
18
- import '../_helpers/icon__svg.js';
18
+ import '../_helpers/icon.js';
19
+ import '../icon/icon__svg.js';
19
20
  import '../global/memoize.js';
20
21
  import '../loader-inline/loader-inline.js';
21
22
  import '../global/theme.js';
@@ -276,4 +277,4 @@ class AuthStorage {
276
277
 
277
278
  }
278
279
 
279
- export default AuthStorage;
280
+ export { AuthStorage as default };
@@ -173,4 +173,4 @@ _defineProperty(TokenValidator, "TokenValidationError", class TokenValidationErr
173
173
 
174
174
  });
175
175
 
176
- export default TokenValidator;
176
+ export { TokenValidator as default };
@@ -130,4 +130,4 @@ class WindowFlow {
130
130
 
131
131
  }
132
132
 
133
- export default WindowFlow;
133
+ export { WindowFlow as default };
@@ -30,7 +30,8 @@ import '@jetbrains/icons/chevron-10px';
30
30
  import '../icon/icon.js';
31
31
  import 'util-deprecate';
32
32
  import '../icon/icon__constants.js';
33
- import '../_helpers/icon__svg.js';
33
+ import '../_helpers/icon.js';
34
+ import '../icon/icon__svg.js';
34
35
  import '../global/memoize.js';
35
36
  import '../global/theme.js';
36
37
  import '../link/clickableLink.js';
@@ -38,7 +39,7 @@ import '../_helpers/button__classes.js';
38
39
  import 'element-resize-detector';
39
40
  import '../global/schedule-raf.js';
40
41
 
41
- var modules_ae521deb = {"unit":"8px","dialog":"authDialog_dialog__eba2bba5","content":"authDialog_content__eba2bba5 global_font__0f8f4370","button":"authDialog_button__eba2bba5","firstButton":"authDialog_firstButton__eba2bba5 authDialog_button__eba2bba5","title":"authDialog_title__eba2bba5","logo":"authDialog_logo__eba2bba5","error":"authDialog_error__eba2bba5"};
42
+ var modules_ae521deb = {"unit":"8px","dialog":"dialog_rui_eba2","content":"content_rui_eba2 font_rui_750f","button":"button_rui_eba2","firstButton":"firstButton_rui_eba2 button_rui_eba2","title":"title_rui_eba2","logo":"logo_rui_eba2","error":"error_rui_eba2"};
42
43
 
43
44
  /**
44
45
  * @name Auth Dialog
@@ -72,6 +73,7 @@ class AuthDialog extends Component {
72
73
  const defaultTitle = serviceName ? loginToCaption : loginCaption;
73
74
  const title = (this.props.title || defaultTitle).replace('%serviceName%', serviceName);
74
75
  return /*#__PURE__*/React.createElement(Dialog, {
76
+ label: title,
75
77
  "data-test": "ring-auth-dialog",
76
78
  className: className,
77
79
  contentClassName: classNames(className, modules_ae521deb.dialog),
@@ -129,4 +131,4 @@ _defineProperty(AuthDialog, "defaultProps", {
129
131
  onCancel: () => {}
130
132
  });
131
133
 
132
- export default AuthDialog;
134
+ export { AuthDialog as default };
@@ -1,7 +1,7 @@
1
- import { c as _objectSpread2 } from '../_helpers/_rollupPluginBabelHelpers.js';
2
1
  import React from 'react';
3
2
  import { render } from 'react-dom';
4
3
  import AuthDialog from '../auth-dialog/auth-dialog.js';
4
+ import '../_helpers/_rollupPluginBabelHelpers.js';
5
5
  import 'prop-types';
6
6
  import 'classnames';
7
7
  import '../island/island.js';
@@ -29,7 +29,8 @@ import '@jetbrains/icons/chevron-10px';
29
29
  import '../icon/icon.js';
30
30
  import 'util-deprecate';
31
31
  import '../icon/icon__constants.js';
32
- import '../_helpers/icon__svg.js';
32
+ import '../_helpers/icon.js';
33
+ import '../icon/icon__svg.js';
33
34
  import '../global/memoize.js';
34
35
  import '../global/theme.js';
35
36
  import '../link/clickableLink.js';
@@ -54,9 +55,9 @@ function renderAuthDialog(props) {
54
55
 
55
56
  function showAuthDialog() {
56
57
  let props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
57
- renderAuthDialog(_objectSpread2(_objectSpread2({}, props), {}, {
58
+ renderAuthDialog({ ...props,
58
59
  show: true
59
- }));
60
+ });
60
61
  return () => {
61
62
  renderAuthDialog({
62
63
  show: false
@@ -64,4 +65,4 @@ function showAuthDialog() {
64
65
  };
65
66
  }
66
67
 
67
- export default showAuthDialog;
68
+ export { showAuthDialog as default };
@@ -0,0 +1,203 @@
1
+ import angular from 'angular';
2
+ import '../auth/auth.js';
3
+ import Auth from '../auth/auth__core.js';
4
+ import '../auth/window-flow.js';
5
+ import '../_helpers/_rollupPluginBabelHelpers.js';
6
+ import '../auth/response-parser.js';
7
+ import 'es6-error';
8
+ import '../global/url.js';
9
+ import '../auth/down-notification.js';
10
+ import 'react';
11
+ import 'prop-types';
12
+ import '../alert-service/alert-service.js';
13
+ import 'react-dom';
14
+ import '../global/get-uid.js';
15
+ import '../alert/alert.js';
16
+ import 'classnames';
17
+ import '@jetbrains/icons/exception';
18
+ import '@jetbrains/icons/checkmark';
19
+ import '@jetbrains/icons/warning';
20
+ import '@jetbrains/icons/close';
21
+ import '../icon/icon.js';
22
+ import 'util-deprecate';
23
+ import '../icon/icon__constants.js';
24
+ import '../_helpers/icon.js';
25
+ import '../icon/icon__svg.js';
26
+ import '../global/memoize.js';
27
+ import '../loader-inline/loader-inline.js';
28
+ import '../global/theme.js';
29
+ import '../global/data-tests.js';
30
+ import '../_helpers/inject-styles.js';
31
+ import '../global/conic-gradient.js';
32
+ import 'conic-gradient';
33
+ import '../global/supports-css.js';
34
+ import '../global/inject-styles.js';
35
+ import '../global/radial-gradient-mask.js';
36
+ import '../global/dom.js';
37
+ import '../alert/container.js';
38
+ import '../link/link.js';
39
+ import 'focus-visible';
40
+ import '../link/clickableLink.js';
41
+ import '../_helpers/link.js';
42
+ import '../group/group.js';
43
+ import '../_helpers/group.js';
44
+ import '../global/listeners.js';
45
+ import '../http/http.js';
46
+ import '../global/promise-with-timeout.js';
47
+ import '../auth/storage.js';
48
+ import '../storage/storage.js';
49
+ import '../storage/storage__local.js';
50
+ import '../storage/storage__fallback.js';
51
+ import 'deep-equal';
52
+ import '../auth/request-builder.js';
53
+ import 'simply-uuid';
54
+ import '../auth/background-flow.js';
55
+ import '../auth/token-validator.js';
56
+
57
+ /**
58
+ * @name Auth Ng
59
+ */
60
+
61
+ const angularModule = angular.module('Ring.auth', []);
62
+ angularModule.provider('auth', ["$httpProvider", function provider($httpProvider) {
63
+ /**
64
+ * @type Auth
65
+ */
66
+ let auth;
67
+ /**
68
+ * @type {{cleanHash: boolean}} config
69
+ */
70
+
71
+ const defaultConfig = {
72
+ cleanHash: false //prevents infinite redirect on angular>1.2.26
73
+
74
+ };
75
+
76
+ this.init = authInstance => {
77
+ auth = authInstance;
78
+ };
79
+ /**
80
+ * @param {{
81
+ * serverUri: string,
82
+ * redirectUri: string?,
83
+ * clientId: string?,
84
+ * scope: string[]?,
85
+ * cleanHash: boolean?
86
+ * }} config
87
+ */
88
+
89
+
90
+ this.config = config => {
91
+ const configCopy = angular.extend({}, defaultConfig, config);
92
+ auth = new Auth(configCopy);
93
+ };
94
+
95
+ $httpProvider.interceptors.push(['$q', '$injector', 'auth', ($q, $injector, authInstance) => {
96
+ function urlEndsWith(config, suffix) {
97
+ return config && config.url && config.url.indexOf(suffix) === config.url.length - suffix.length;
98
+ }
99
+
100
+ return {
101
+ request(config) {
102
+ if (!authInstance || urlEndsWith(config, '.html') || config && config.noAuthorization) {
103
+ // Don't intercept angular template requests
104
+ return config;
105
+ }
106
+
107
+ return authInstance.promise.then(() => authInstance.auth.requestToken()).then(accessToken => {
108
+ if (accessToken) {
109
+ config.headers.Authorization = `Bearer ${accessToken}`;
110
+ }
111
+
112
+ return config;
113
+ });
114
+ },
115
+
116
+ responseError(rejection) {
117
+ if (authInstance && !urlEndsWith(rejection.config, '.html') && rejection.data != null && Auth.shouldRefreshToken(rejection.data.error)) {
118
+ // Use $injector to avoid circular dependency
119
+ const $http = $injector.get('$http');
120
+ const {
121
+ data,
122
+ method,
123
+ params,
124
+ url
125
+ } = rejection.config;
126
+ return authInstance.auth.forceTokenUpdate().then(() => $http({
127
+ data,
128
+ method,
129
+ params,
130
+ url
131
+ }));
132
+ }
133
+
134
+ return $q.reject(rejection);
135
+ }
136
+
137
+ };
138
+ }]);
139
+ this.$get = ["$injector", "$log", "$sniffer", function get($injector, $log, $sniffer) {
140
+ // Do not try to init anything without config
141
+ if (!auth) {
142
+ $log.warn('Auth wasn\'t initialized');
143
+ return null;
144
+ }
145
+
146
+ if (auth.config.reloadOnUserChange === false) {
147
+ auth.addListener('userChange', () => {
148
+ const $route = $injector.get('$route');
149
+ $route.reload();
150
+ });
151
+ }
152
+ /**
153
+ * @type {Promise.<string>}
154
+ */
155
+
156
+
157
+ const authInitPromise = auth.init();
158
+ /**
159
+ * @param {string?} restoreLocationURL
160
+ */
161
+
162
+ function restoreLocation(restoreLocationURL) {
163
+ if (restoreLocationURL) {
164
+ const bases = document.getElementsByTagName('base');
165
+ let baseURI = auth.config.redirectUri;
166
+
167
+ if (bases.length > 0) {
168
+ baseURI = bases[0].href;
169
+ }
170
+
171
+ if (restoreLocationURL.indexOf(baseURI) === 0) {
172
+ const $location = $injector.get('$location');
173
+ let relativeURI = restoreLocationURL.substr(baseURI.length); // We have to turn url with hash to simple relative url in HashbangInHtml5 mode
174
+ // And there is no other and documented way to detect that mode
175
+ // @see http://stackoverflow.com/a/16678065
176
+
177
+ if ($location.$$html5 && !$sniffer.history) {
178
+ // eslint-disable-line angular/no-private-call
179
+ relativeURI = relativeURI.replace(/^#\//, '');
180
+ }
181
+
182
+ $location.url(relativeURI).replace();
183
+ }
184
+ }
185
+ }
186
+
187
+ authInitPromise.then(restoreLocation, e => {
188
+ if (!e.authRedirect) {
189
+ $log.error(e);
190
+ }
191
+ });
192
+ return {
193
+ auth,
194
+ requestUser: auth.requestUser.bind(auth),
195
+ clientId: auth.config.clientId,
196
+ logout: auth.logout.bind(auth),
197
+ promise: authInitPromise
198
+ };
199
+ }];
200
+ }]);
201
+ var authNg = angularModule.name;
202
+
203
+ export { authNg as default };
@@ -0,0 +1,33 @@
1
+ /**
2
+ * TODO(maksimrv): Remove this code
3
+ * It is currently required because permissions do not work without auth,
4
+ * but we can't stub the correct auth component and should mock all providers.
5
+ */
6
+ function AuthProviderMock() {
7
+ this.$get = ['$q', function get($q) {
8
+ const promise = $q.resolve([]);
9
+ return {
10
+ auth: {
11
+ addListener() {},
12
+
13
+ getAPIPath() {
14
+ return '/';
15
+ },
16
+
17
+ requestToken() {
18
+ return promise;
19
+ },
20
+
21
+ http: {
22
+ get() {
23
+ return promise;
24
+ }
25
+
26
+ }
27
+ },
28
+ promise
29
+ };
30
+ }];
31
+ }
32
+
33
+ export { AuthProviderMock as default };
@@ -0,0 +1,50 @@
1
+ import angular from 'angular';
2
+ import { FOCUSABLE_ELEMENTS } from '../tab-trap/tab-trap.js';
3
+ import '../_helpers/_rollupPluginBabelHelpers.js';
4
+ import 'react';
5
+ import 'prop-types';
6
+ import '../global/dom.js';
7
+
8
+ const angularModule = angular.module('Ring.autofocus', []);
9
+ const RING_SELECT_SELECTOR = '[data-test=ring-select__focus]';
10
+ const RING_SELECT = 'rg-select';
11
+ angularModule.directive('rgAutofocus', function rgAutofocusDirective() {
12
+ /**
13
+ * Focuses on element itself if it has "focus" method.
14
+ * Searches and focuses on select's button or input if element is rg-select
15
+ * @param element
16
+ */
17
+ function focusOnElement(element) {
18
+ if (!element) {
19
+ return;
20
+ }
21
+
22
+ if (element.hasAttribute(RING_SELECT) || element.tagName.toLowerCase() === RING_SELECT) {
23
+ focusOnElement(element.querySelector(RING_SELECT_SELECTOR));
24
+ return;
25
+ }
26
+
27
+ if (element.matches(FOCUSABLE_ELEMENTS) && element.focus) {
28
+ element.focus();
29
+ return;
30
+ }
31
+
32
+ const focusableChild = element.querySelector(FOCUSABLE_ELEMENTS);
33
+
34
+ if (focusableChild && focusableChild.focus) {
35
+ focusableChild.focus();
36
+ }
37
+ }
38
+
39
+ return (scope, iElement, iAttrs) => {
40
+ const element = iElement[0];
41
+ scope.$watch(iAttrs.rgAutofocus, newValue => {
42
+ if (newValue) {
43
+ scope.$evalAsync(() => focusOnElement(element));
44
+ }
45
+ });
46
+ };
47
+ });
48
+ var autofocusNg = angularModule.name;
49
+
50
+ export { autofocusNg as default };
@@ -1,11 +1,13 @@
1
- import { _ as _defineProperty, a as _objectWithoutProperties, c as _objectSpread2, b as _extends } from '../_helpers/_rollupPluginBabelHelpers.js';
1
+ import { _ as _defineProperty, a as _extends } from '../_helpers/_rollupPluginBabelHelpers.js';
2
2
  import React, { PureComponent } from 'react';
3
3
  import PropTypes from 'prop-types';
4
4
  import classNames from 'classnames';
5
5
  import { isDataURI, parseQueryString, encodeURL } from '../global/url.js';
6
6
  import { getPixelRatio } from '../global/dom.js';
7
+ import FallbackAvatar from './fallback-avatar.js';
8
+ import '../global/get-uid.js';
7
9
 
8
- var modules_61ca8c75 = {"avatar":"avatar_avatar__fcab4239","subavatar":"avatar_subavatar__fcab4239","empty":"avatar_empty__fcab4239"};
10
+ var modules_61ca8c75 = {"avatar":"avatar_rui_0937","subavatar":"subavatar_rui_0937","empty":"empty_rui_0937"};
9
11
 
10
12
  /**
11
13
  * @name Avatar
@@ -15,6 +17,7 @@ const Size = {
15
17
  Size18: 18,
16
18
  Size20: 20,
17
19
  Size24: 24,
20
+ Size28: 28,
18
21
  Size32: 32,
19
22
  Size40: 40,
20
23
  Size48: 48,
@@ -42,52 +45,56 @@ class Avatar extends PureComponent {
42
45
  }
43
46
 
44
47
  render() {
45
- const _this$props = this.props,
46
- {
48
+ const {
47
49
  size,
48
50
  url,
49
51
  dpr,
50
52
  style,
51
53
  round,
52
54
  subavatar,
53
- subavatarSize
54
- } = _this$props,
55
- restProps = _objectWithoutProperties(_this$props, ["size", "url", "dpr", "style", "round", "subavatar", "subavatarSize"]);
56
-
55
+ subavatarSize,
56
+ username,
57
+ skipParams,
58
+ ...restProps
59
+ } = this.props;
57
60
  const sizeString = `${size}px`;
58
61
  const subavatarSizeString = `${subavatarSize}px`;
59
62
  const borderRadius = size <= Size.Size18 ? 'var(--ring-border-radius-small)' : 'var(--ring-border-radius)';
60
-
61
- const styleObj = _objectSpread2({
63
+ const styleObj = {
62
64
  borderRadius: round ? '50%' : borderRadius,
63
65
  height: sizeString,
64
- width: sizeString
65
- }, style);
66
-
67
- const styleObjGroup = _objectSpread2({
66
+ width: sizeString,
67
+ ...style
68
+ };
69
+ const styleObjGroup = {
68
70
  borderRadius: '2px',
69
71
  height: subavatarSizeString,
70
- width: subavatarSizeString
71
- }, style);
72
+ width: subavatarSizeString,
73
+ ...style
74
+ };
72
75
 
73
76
  if (!url || this.state.errorUrl === url) {
74
77
  return /*#__PURE__*/React.createElement("span", _extends({}, restProps, {
75
78
  "data-test": "avatar",
76
- className: classNames(modules_61ca8c75.avatar, modules_61ca8c75.empty, this.props.className),
79
+ className: classNames(modules_61ca8c75.avatar, this.props.className, {
80
+ [modules_61ca8c75.empty]: username == null
81
+ }),
77
82
  style: styleObj
83
+ }), username != null && /*#__PURE__*/React.createElement(FallbackAvatar, {
84
+ size: size,
85
+ round: round,
86
+ username: username
78
87
  }));
79
88
  }
80
89
 
81
90
  let src = url;
82
91
 
83
- if (!isDataURI(url)) {
92
+ if (!skipParams && !isDataURI(url)) {
84
93
  const [urlStart, query] = url.split('?');
85
-
86
- const queryParams = _objectSpread2(_objectSpread2({}, parseQueryString(query)), {}, {
94
+ const queryParams = { ...parseQueryString(query),
87
95
  dpr,
88
96
  size
89
- });
90
-
97
+ };
91
98
  src = encodeURL(urlStart, queryParams);
92
99
  }
93
100
 
@@ -95,13 +102,11 @@ class Avatar extends PureComponent {
95
102
 
96
103
  if (subavatar && !isDataURI(subavatar)) {
97
104
  const [urlStart, query] = subavatar.split('?');
98
-
99
- const queryParams = _objectSpread2(_objectSpread2({}, parseQueryString(query)), {}, {
105
+ const queryParams = { ...parseQueryString(query),
100
106
  dpr,
101
107
  subavatarSizeString
102
- });
103
-
104
- subavatarSrc = encodeURL(urlStart, queryParams);
108
+ };
109
+ subavatarSrc = skipParams ? subavatar : encodeURL(urlStart, queryParams);
105
110
  return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement("img", _extends({}, restProps, {
106
111
  onError: this.handleError,
107
112
  onLoad: this.handleSuccess,
@@ -141,7 +146,9 @@ _defineProperty(Avatar, "propTypes", {
141
146
  url: PropTypes.string,
142
147
  round: PropTypes.bool,
143
148
  subavatar: PropTypes.string,
144
- subavatarSize: PropTypes.number
149
+ subavatarSize: PropTypes.number,
150
+ username: PropTypes.string,
151
+ skipParams: PropTypes.bool
145
152
  });
146
153
 
147
154
  _defineProperty(Avatar, "defaultProps", {
@@ -151,5 +158,4 @@ _defineProperty(Avatar, "defaultProps", {
151
158
  style: {}
152
159
  });
153
160
 
154
- export default Avatar;
155
- export { Size };
161
+ export { Size, Avatar as default };
@@ -0,0 +1,141 @@
1
+ import React, { useMemo } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import getUID from '../global/get-uid.js';
4
+
5
+ const colorPairs = [['#60A800', '#D5CA00'], ['#21D370', '#03E9E1'], ['#3BA1FF', '#36E97D'], ['#00C243', '#00FFFF'], ['#4BE098', '#627FFF'], ['#168BFA', '#26F7C7'], ['#9D4CFF', '#39D3C3'], ['#0A81F6', '#0ACFF6'], ['#765AF8', '#5A91F8'], ['#9E54FF', '#0ACFF6'], ['#B345F1', '#669DFF'], ['#765AF8', '#C059EE'], ['#9039D0', '#C239D0'], ['#9F2AFF', '#FD56FD'], ['#AB3AF2', '#E40568'], ['#9F2AFF', '#E9A80B'], ['#D50F6B', '#E73AE8'], ['#ED5502', '#E73AE8'], ['#ED358C', '#DBED18'], ['#ED358C', '#F9902E'], ['#FF7500', '#FFCA00']];
6
+ const Sizes = {
7
+ 18: {
8
+ radius: 2,
9
+ text: {
10
+ x: 9,
11
+ y: 13
12
+ },
13
+ fontSize: '11px',
14
+ textAnchor: 'middle'
15
+ },
16
+ 24: {
17
+ radius: 3,
18
+ text: {
19
+ x: 2,
20
+ y: 13
21
+ },
22
+ fontSize: '11px',
23
+ underscore: {
24
+ x: 3,
25
+ y: 17
26
+ }
27
+ },
28
+ 32: {
29
+ radius: 3,
30
+ text: {
31
+ x: 3,
32
+ y: 17
33
+ },
34
+ fontSize: '13px',
35
+ letterSpacing: 1,
36
+ underscore: {
37
+ x: 4,
38
+ y: 22
39
+ }
40
+ },
41
+ 40: {
42
+ radius: 3,
43
+ text: {
44
+ x: 5,
45
+ y: 19
46
+ },
47
+ fontSize: '15px',
48
+ letterSpacing: 1,
49
+ underscore: {
50
+ x: 6,
51
+ y: 28
52
+ }
53
+ }
54
+ };
55
+ const sizeKeys = Object.keys(Sizes).map(Number);
56
+
57
+ function extractLetters(name) {
58
+ const names = name.split(/[\s._]+/).filter(Boolean);
59
+
60
+ if (names.length >= 2) {
61
+ return names[0][0].toUpperCase() + names[1][0].toUpperCase();
62
+ } else if (names.length === 1) {
63
+ if (names[0].length >= 2) {
64
+ return names[0].slice(0, 2).toUpperCase();
65
+ } else {
66
+ return `${names[0][0].toUpperCase()}X`;
67
+ }
68
+ } else {
69
+ return 'XX';
70
+ }
71
+ } // https://gist.github.com/hyamamoto/fd435505d29ebfa3d9716fd2be8d42f0#gistcomment-2775538
72
+
73
+
74
+ const BASE = 32;
75
+
76
+ function hashCode(s) {
77
+ let h = 0;
78
+
79
+ for (let i = 0; i < s.length; i++) {
80
+ h = Math.imul(BASE - 1, h) + s.charCodeAt(i) | 0;
81
+ }
82
+
83
+ return h;
84
+ }
85
+
86
+ function FallbackAvatar(_ref) {
87
+ let {
88
+ username,
89
+ size,
90
+ round
91
+ } = _ref;
92
+ const hash = Math.abs(hashCode(username.toLowerCase()));
93
+ const [fromColor, toColor] = colorPairs[hash % colorPairs.length];
94
+ const possibleSizeKeys = sizeKeys.filter(key => key >= size);
95
+ const sizeKey = possibleSizeKeys.length > 0 ? Math.min(...possibleSizeKeys) : Math.max(...sizeKeys);
96
+ const sizes = Sizes[sizeKey];
97
+ const radius = round ? '50%' : sizes.radius;
98
+ const gradientId = useMemo(() => getUID('gradient-'), []);
99
+ return /*#__PURE__*/React.createElement("svg", {
100
+ viewBox: `0 0 ${sizeKey} ${sizeKey}`,
101
+ xmlns: "http://www.w3.org/2000/svg"
102
+ }, /*#__PURE__*/React.createElement("defs", null, /*#__PURE__*/React.createElement("linearGradient", {
103
+ id: gradientId,
104
+ x1: "0",
105
+ y1: "0",
106
+ x2: "0",
107
+ y2: "1"
108
+ }, /*#__PURE__*/React.createElement("stop", {
109
+ stopColor: fromColor,
110
+ offset: "0"
111
+ }), /*#__PURE__*/React.createElement("stop", {
112
+ stopColor: toColor,
113
+ offset: "1"
114
+ }))), /*#__PURE__*/React.createElement("g", null, /*#__PURE__*/React.createElement("rect", {
115
+ fill: `url(#${gradientId})`,
116
+ x: "0",
117
+ y: "0",
118
+ width: sizeKey,
119
+ height: sizeKey,
120
+ rx: radius,
121
+ ry: radius
122
+ }), /*#__PURE__*/React.createElement("text", {
123
+ x: sizes.text.x,
124
+ y: sizes.text.y,
125
+ fontFamily: "Arial, Helvetica, sans-serif",
126
+ fontSize: sizes.fontSize,
127
+ letterSpacing: sizes.letterSpacing,
128
+ fill: "#FFFFFF",
129
+ textAnchor: sizes.textAnchor
130
+ }, /*#__PURE__*/React.createElement("tspan", null, extractLetters(username)), sizes.underscore && /*#__PURE__*/React.createElement("tspan", {
131
+ x: sizes.underscore.x,
132
+ y: sizes.underscore.y
133
+ }, '_'))));
134
+ }
135
+ FallbackAvatar.propTypes = {
136
+ username: PropTypes.string.isRequired,
137
+ size: PropTypes.number.isRequired,
138
+ round: PropTypes.bool
139
+ };
140
+
141
+ export { FallbackAvatar as default };