@jetbrains/ring-ui 4.1.0-beta.13 → 4.1.0-beta.17

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 (382) hide show
  1. package/CHANGELOG.md +13 -0
  2. package/README.md +14 -13
  3. package/components/alert/container.css +1 -1
  4. package/components/auth/auth.test.js +14 -7
  5. package/components/auth/auth__core.js +12 -6
  6. package/components/avatar/avatar.css +4 -1
  7. package/components/avatar/avatar.examples.js +3 -2
  8. package/components/avatar/avatar.js +31 -6
  9. package/components/avatar/fallback-avatar.js +136 -0
  10. package/components/avatar-editor-ng/avatar-editor-ng.css +2 -2
  11. package/components/avatar-editor-ng/avatar-editor-ng.js +2 -1
  12. package/components/avatar-editor-ng/{avatar-editor-ng.html → avatar-editor-ng__template.js} +2 -2
  13. package/components/button/button.css +2 -2
  14. package/components/button-group/button-group.js +1 -1
  15. package/components/button-group/caption.js +1 -1
  16. package/components/button-ng/button-ng.js +1 -1
  17. package/components/button-set-ng/button-set-ng.js +3 -1
  18. package/components/checkbox/checkbox.css +1 -1
  19. package/components/code/code.js +1 -1
  20. package/components/content-layout/content-layout.css +1 -1
  21. package/components/data-list/data-list.css +1 -1
  22. package/components/date-picker/date-input.js +5 -4
  23. package/components/date-picker/date-picker.css +10 -6
  24. package/components/date-picker/date-picker.js +16 -14
  25. package/components/date-picker/date-popup.js +8 -4
  26. package/components/date-picker/month-names.js +8 -5
  27. package/components/date-picker/month.js +6 -2
  28. package/components/date-picker/weekdays.js +10 -2
  29. package/components/dialog-ng/dialog-ng.js +6 -7
  30. package/components/dialog-ng/{dialog-ng.html → dialog-ng__template.js} +2 -2
  31. package/components/dropdown/dropdown.examples.js +36 -1
  32. package/components/dropdown-menu/dropdown-menu.examples.js +47 -0
  33. package/components/dropdown-menu/dropdown-menu.js +117 -0
  34. package/components/dropdown-menu/dropdown-menu.test.js +76 -0
  35. package/components/error-bubble/error-bubble-legacy.css +1 -1
  36. package/components/error-bubble/error-bubble.css +1 -1
  37. package/components/error-page/error-page.css +2 -2
  38. package/components/footer-ng/footer-ng.js +13 -3
  39. package/components/form/form.css +2 -2
  40. package/components/form-ng/form-ng.js +3 -1
  41. package/components/global/global.css +1 -1
  42. package/components/global/variables.css +8 -1
  43. package/components/grid/grid.css +10 -9
  44. package/components/header/header.css +1 -1
  45. package/components/header/header.examples.js +7 -8
  46. package/components/header/profile.js +10 -11
  47. package/components/http/http.js +1 -1
  48. package/components/icon/icon.css +5 -4
  49. package/components/island/island.css +4 -3
  50. package/components/island-legacy/island-legacy.css +3 -1
  51. package/components/list/list.js +6 -1
  52. package/components/list/list__custom.js +9 -3
  53. package/components/list/list__item.js +8 -2
  54. package/components/loader-inline/loader-inline.css +1 -1
  55. package/components/loader-screen/loader-screen.css +1 -1
  56. package/components/message/message.css +1 -1
  57. package/components/pager/pager.js +5 -3
  58. package/components/permissions/permissions.js +1 -1
  59. package/components/progress-bar/progress-bar.css +1 -1
  60. package/components/query-assist/query-assist.css +1 -1
  61. package/components/save-field-ng/save-field-ng.js +3 -1
  62. package/components/save-field-ng/{save-field-ng.html → save-field-ng__template.js} +2 -2
  63. package/components/select/select.css +4 -0
  64. package/components/select/select.examples.js +13 -0
  65. package/components/select/select.js +6 -6
  66. package/components/shortcuts-hint-ng/shortcuts-hint-ng.css +1 -1
  67. package/components/shortcuts-hint-ng/shortcuts-hint-ng.js +1 -1
  68. package/components/shortcuts-hint-ng/{shortcuts-hint-ng.html → shortcuts-hint-ng__template.js} +2 -2
  69. package/components/sidebar/sidebar.css +1 -0
  70. package/components/sidebar-ng/sidebar-ng.js +6 -2
  71. package/components/sidebar-ng/{sidebar-ng__button.html → sidebar-ng__button-template.js} +2 -2
  72. package/components/sidebar-ng/{sidebar-ng.html → sidebar-ng__template.js} +2 -2
  73. package/components/table/table.css +2 -1
  74. package/components/table-legacy/table-legacy.css +2 -2
  75. package/components/table-legacy-ng/table-legacy-ng.js +38 -5
  76. package/components/table-legacy-ng/table-legacy-ng__pager.js +7 -1
  77. package/components/tabs-ng/tabs-ng.js +3 -1
  78. package/components/tabs-ng/{tabs-ng.html → tabs-ng__template.js} +2 -2
  79. package/components/tag/tag.css +5 -2
  80. package/components/tags-input/tags-input.js +5 -2
  81. package/components/template-ng/template-ng.js +1 -1
  82. package/components/tooltip/tooltip.js +7 -2
  83. package/components/user-agreement/user-agreement.css +1 -1
  84. package/dist/_helpers/button-group.js +3 -0
  85. package/dist/_helpers/button-set.js +3 -0
  86. package/dist/_helpers/button-toolbar.js +3 -0
  87. package/dist/_helpers/button__classes.js +1 -1
  88. package/dist/_helpers/checkbox.js +3 -0
  89. package/dist/_helpers/date-picker.js +1 -1
  90. package/dist/_helpers/error-message.js +3 -0
  91. package/dist/_helpers/footer.js +121 -0
  92. package/dist/_helpers/grid.js +1 -1
  93. package/dist/_helpers/group.js +3 -0
  94. package/dist/_helpers/header.js +1 -1
  95. package/dist/_helpers/icon.js +3 -0
  96. package/dist/_helpers/inject-styles.js +1 -1
  97. package/dist/_helpers/input.js +3 -0
  98. package/dist/_helpers/island.js +1 -1
  99. package/dist/_helpers/link.js +3 -0
  100. package/dist/_helpers/loader-screen.js +3 -0
  101. package/dist/_helpers/panel.js +3 -0
  102. package/dist/_helpers/query-assist__suggestions.js +1 -1
  103. package/dist/_helpers/radio.js +3 -0
  104. package/dist/_helpers/sidebar.js +1 -1
  105. package/dist/_helpers/table.js +1 -1
  106. package/dist/_helpers/tabs.js +1 -1
  107. package/dist/_helpers/title.js +1 -1
  108. package/dist/alert/alert.js +3 -3
  109. package/dist/alert/container.js +2 -2
  110. package/dist/alert-service/alert-service.js +3 -2
  111. package/dist/analytics/analytics.js +2 -2
  112. package/dist/analytics/analytics__custom-plugin.js +1 -1
  113. package/dist/analytics/analytics__fus-plugin.js +1 -1
  114. package/dist/analytics/analytics__ga-plugin.js +1 -1
  115. package/dist/analytics/analytics__plugin-utils.js +1 -1
  116. package/dist/analytics-ng/analytics-ng.js +94 -0
  117. package/dist/auth/auth.js +4 -1
  118. package/dist/auth/auth__core.js +15 -9
  119. package/dist/auth/background-flow.js +1 -2
  120. package/dist/auth/down-notification.js +5 -2
  121. package/dist/auth/iframe-flow.js +5 -2
  122. package/dist/auth/landing-entry.js +1 -1
  123. package/dist/auth/landing.js +5 -2
  124. package/dist/auth/request-builder.js +1 -1
  125. package/dist/auth/response-parser.js +1 -1
  126. package/dist/auth/storage.js +3 -2
  127. package/dist/auth/token-validator.js +1 -1
  128. package/dist/auth/window-flow.js +1 -1
  129. package/dist/auth-dialog/auth-dialog.js +4 -3
  130. package/dist/auth-dialog-service/auth-dialog-service.js +3 -2
  131. package/dist/auth-ng/auth-ng.js +203 -0
  132. package/dist/auth-ng/auth-ng.mock.js +33 -0
  133. package/dist/autofocus-ng/autofocus-ng.js +50 -0
  134. package/dist/avatar/avatar.js +19 -7
  135. package/dist/avatar/fallback-avatar.js +141 -0
  136. package/dist/avatar-editor-ng/avatar-editor-ng.js +164 -0
  137. package/dist/avatar-editor-ng/avatar-editor-ng__template.js +30 -0
  138. package/dist/avatar-ng/avatar-ng.js +18 -0
  139. package/dist/badge/badge.js +1 -1
  140. package/dist/badge-ng/badge-ng.js +16 -0
  141. package/dist/breadcrumb-ng/breadcrumb-ng.js +61 -0
  142. package/dist/button/button.js +3 -2
  143. package/dist/button-group/button-group.js +3 -3
  144. package/dist/button-group/caption.js +24 -5
  145. package/dist/button-group-ng/button-group-ng.js +38 -0
  146. package/dist/button-ng/button-ng.js +223 -0
  147. package/dist/button-set/button-set.js +2 -3
  148. package/dist/button-set-ng/button-set-ng.js +19 -0
  149. package/dist/button-toolbar/button-toolbar.js +2 -3
  150. package/dist/button-toolbar-ng/button-toolbar-ng.js +23 -0
  151. package/dist/caret/caret.js +1 -1
  152. package/dist/checkbox/checkbox.js +4 -4
  153. package/dist/checkbox-ng/checkbox-ng.js +55 -0
  154. package/dist/code/code.js +136 -0
  155. package/dist/compiler-ng/compiler-ng.js +53 -0
  156. package/dist/confirm/confirm.js +4 -2
  157. package/dist/confirm-ng/confirm-ng.js +66 -0
  158. package/dist/confirm-service/confirm-service.js +4 -3
  159. package/dist/content-layout/content-layout.js +1 -1
  160. package/dist/contenteditable/contenteditable.js +1 -1
  161. package/dist/data-list/data-list.js +6 -3
  162. package/dist/data-list/data-list.mock.js +2 -2
  163. package/dist/data-list/item.js +5 -3
  164. package/dist/data-list/selection.js +1 -1
  165. package/dist/data-list/title.js +3 -1
  166. package/dist/data-list-ng/data-list-ng.js +59 -0
  167. package/dist/date-picker/consts.js +1 -2
  168. package/dist/date-picker/date-input.js +10 -6
  169. package/dist/date-picker/date-picker.js +28 -16
  170. package/dist/date-picker/date-popup.js +20 -9
  171. package/dist/date-picker/day.js +1 -1
  172. package/dist/date-picker/formats.js +1 -1
  173. package/dist/date-picker/month-names.js +14 -7
  174. package/dist/date-picker/month-slider.js +1 -1
  175. package/dist/date-picker/month.js +12 -6
  176. package/dist/date-picker/months.js +1 -1
  177. package/dist/date-picker/weekdays.js +12 -4
  178. package/dist/date-picker/years.js +1 -1
  179. package/dist/dialog/dialog.js +3 -2
  180. package/dist/dialog-ng/dialog-ng.js +601 -0
  181. package/dist/dialog-ng/dialog-ng__template.js +71 -0
  182. package/dist/docked-panel-ng/docked-panel-ng.js +170 -0
  183. package/dist/dropdown/anchor.js +2 -1
  184. package/dist/dropdown/dropdown.js +3 -2
  185. package/dist/dropdown-menu/dropdown-menu.js +175 -0
  186. package/dist/error-bubble/error-bubble.js +2 -2
  187. package/dist/error-message/error-message.js +4 -4
  188. package/dist/error-message-ng/error-message-ng.js +53 -0
  189. package/dist/footer/footer.js +6 -122
  190. package/dist/footer-ng/footer-ng.js +75 -0
  191. package/dist/form-ng/form-ng.js +169 -0
  192. package/dist/global/angular-component-factory.js +1 -2
  193. package/dist/global/compose.js +1 -1
  194. package/dist/global/composeRefs.js +1 -1
  195. package/dist/global/conic-gradient.js +1 -2
  196. package/dist/global/create-stateful-context.js +1 -1
  197. package/dist/global/data-tests.js +1 -1
  198. package/dist/global/focus-sensor-hoc.js +1 -1
  199. package/dist/global/fuzzy-highlight.js +1 -1
  200. package/dist/global/get-event-key.js +1 -1
  201. package/dist/global/get-uid.js +1 -1
  202. package/dist/global/linear-function.js +1 -2
  203. package/dist/global/listeners.js +1 -1
  204. package/dist/global/memoize.js +1 -1
  205. package/dist/global/normalize-indent.js +1 -1
  206. package/dist/global/promise-with-timeout.js +1 -1
  207. package/dist/global/radial-gradient-mask.js +1 -1
  208. package/dist/global/react-dom-renderer.js +1 -1
  209. package/dist/global/rerender-hoc.js +1 -1
  210. package/dist/global/ring-angular-component.js +1 -1
  211. package/dist/global/schedule-raf.js +1 -1
  212. package/dist/global/sniffer.js +1 -1
  213. package/dist/global/supports-css.js +1 -1
  214. package/dist/global/theme.js +1 -2
  215. package/dist/global/trivial-template-tag.js +1 -1
  216. package/dist/global/variables_dark.js +1 -1
  217. package/dist/grid/col.js +1 -1
  218. package/dist/grid/row.js +1 -1
  219. package/dist/group/group.js +2 -3
  220. package/dist/group-ng/group-ng.js +11 -0
  221. package/dist/header/header.js +24 -19
  222. package/dist/header/logo.js +3 -2
  223. package/dist/header/profile.js +31 -25
  224. package/dist/header/services-link.js +1 -0
  225. package/dist/header/services.js +4 -2
  226. package/dist/header/smart-profile.js +22 -16
  227. package/dist/header/smart-services.js +5 -2
  228. package/dist/header/tray-icon.js +3 -2
  229. package/dist/header/tray.js +1 -1
  230. package/dist/heading/heading.js +2 -3
  231. package/dist/http/http.js +1 -2
  232. package/dist/http/http.mock.js +1 -1
  233. package/dist/hub-source/hub-source.js +1 -1
  234. package/dist/hub-source/hub-source__users-groups.js +1 -1
  235. package/dist/icon/icon.js +3 -2
  236. package/dist/icon/icon__svg.js +81 -6
  237. package/dist/icon/index.js +2 -1
  238. package/dist/icon-ng/icon-ng.js +89 -0
  239. package/dist/input/input.js +4 -5
  240. package/dist/input-ng/input-ng.js +166 -0
  241. package/dist/island/adaptive-island-hoc.js +1 -2
  242. package/dist/island/content.js +1 -1
  243. package/dist/island/header.js +1 -1
  244. package/dist/island/island.js +1 -2
  245. package/dist/island-legacy/content-legacy.js +1 -1
  246. package/dist/island-legacy/header-legacy.js +1 -1
  247. package/dist/island-legacy/island-legacy.js +1 -1
  248. package/dist/island-ng/island-content-ng.js +56 -0
  249. package/dist/island-ng/island-header-ng.js +32 -0
  250. package/dist/island-ng/island-ng-class-fixer.js +9 -0
  251. package/dist/island-ng/island-ng.js +31 -0
  252. package/dist/link/clickableLink.js +1 -1
  253. package/dist/link/link.js +2 -4
  254. package/dist/link-ng/link-ng.js +25 -0
  255. package/dist/list/list.js +13 -5
  256. package/dist/list/list__custom.js +8 -3
  257. package/dist/list/list__hint.js +1 -1
  258. package/dist/list/list__item.js +15 -6
  259. package/dist/list/list__link.js +2 -1
  260. package/dist/list/list__separator.js +1 -1
  261. package/dist/list/list__title.js +1 -1
  262. package/dist/list/list__users-groups-source.js +6 -2
  263. package/dist/loader/loader.js +1 -1
  264. package/dist/loader/loader__core.js +1 -1
  265. package/dist/loader-inline/loader-inline.js +1 -1
  266. package/dist/loader-inline-ng/loader-inline-ng.js +42 -0
  267. package/dist/loader-ng/loader-ng.js +43 -0
  268. package/dist/loader-screen/loader-screen.js +2 -3
  269. package/dist/loader-screen-ng/loader-screen-ng.js +99 -0
  270. package/dist/login-dialog/login-dialog.js +4 -2
  271. package/dist/login-dialog/service.js +4 -2
  272. package/dist/markdown/code.js +30 -0
  273. package/dist/markdown/heading.js +23 -0
  274. package/dist/markdown/link.js +30 -0
  275. package/dist/markdown/markdown.js +73 -0
  276. package/dist/message/message.js +4 -3
  277. package/dist/message-bundle-ng/message-bundle-ng.js +111 -0
  278. package/dist/pager/pager.js +16 -7
  279. package/dist/pager-ng/pager-ng.js +96 -0
  280. package/dist/panel/panel.js +2 -3
  281. package/dist/panel-ng/panel-ng.js +16 -0
  282. package/dist/permissions/permissions.js +1 -1
  283. package/dist/permissions/permissions__cache.js +1 -1
  284. package/dist/permissions-ng/permissions-ng.js +274 -0
  285. package/dist/place-under-ng/place-under-ng.js +157 -0
  286. package/dist/popup/popup.js +2 -3
  287. package/dist/popup/position.js +1 -2
  288. package/dist/popup-menu/popup-menu.js +6 -3
  289. package/dist/progress-bar/progress-bar.js +2 -2
  290. package/dist/progress-bar-ng/progress-bar-ng.js +15 -0
  291. package/dist/promised-click-ng/promised-click-ng.js +126 -0
  292. package/dist/proxy-attrs/proxy-attrs.js +1 -1
  293. package/dist/query-assist/query-assist.js +6 -3
  294. package/dist/query-assist/query-assist__suggestions.js +5 -1
  295. package/dist/query-assist-ng/query-assist-ng.js +82 -0
  296. package/dist/radio/radio.js +2 -1
  297. package/dist/radio/radio__item.js +2 -4
  298. package/dist/radio-ng/radio-ng.js +63 -0
  299. package/dist/save-field-ng/save-field-ng.js +335 -0
  300. package/dist/save-field-ng/save-field-ng__template.js +34 -0
  301. package/dist/select/select.js +13 -11
  302. package/dist/select/select__filter.js +6 -1
  303. package/dist/select/select__popup.js +7 -2
  304. package/dist/select-ng/select-ng.js +621 -0
  305. package/dist/select-ng/select-ng__lazy.js +150 -0
  306. package/dist/select-ng/select-ng__options.js +145 -0
  307. package/dist/shortcuts/core.js +2 -2
  308. package/dist/shortcuts/shortcuts-hoc.js +1 -1
  309. package/dist/shortcuts/shortcuts.js +6 -6
  310. package/dist/shortcuts-hint-ng/shortcuts-hint-ng.js +120 -0
  311. package/dist/shortcuts-hint-ng/shortcuts-hint-ng__template.js +50 -0
  312. package/dist/shortcuts-ng/shortcuts-ng.js +261 -0
  313. package/dist/sidebar-ng/sidebar-ng.js +111 -0
  314. package/dist/sidebar-ng/sidebar-ng__button-template.js +20 -0
  315. package/dist/sidebar-ng/sidebar-ng__template.js +12 -0
  316. package/dist/storage/storage.js +3 -2
  317. package/dist/storage/storage__fallback.js +1 -1
  318. package/dist/storage/storage__local.js +3 -2
  319. package/dist/style.css +1 -1
  320. package/dist/tab-trap/tab-trap.js +1 -2
  321. package/dist/table/cell.js +1 -1
  322. package/dist/table/disable-hover-hoc.js +1 -1
  323. package/dist/table/header-cell.js +3 -2
  324. package/dist/table/header.js +4 -2
  325. package/dist/table/multitable.js +1 -1
  326. package/dist/table/row-with-focus-sensor.js +4 -2
  327. package/dist/table/row.js +4 -2
  328. package/dist/table/selection-adapter.js +1 -1
  329. package/dist/table/selection-shortcuts-hoc.js +1 -1
  330. package/dist/table/selection.js +1 -1
  331. package/dist/table/smart-table.js +4 -2
  332. package/dist/table/table.js +4 -3
  333. package/dist/table-legacy-ng/table-legacy-ng.js +501 -0
  334. package/dist/table-legacy-ng/table-legacy-ng__pager.js +122 -0
  335. package/dist/table-legacy-ng/table-legacy-ng__selection-navigate-actions.js +123 -0
  336. package/dist/table-legacy-ng/table-legacy-ng__selection.js +179 -0
  337. package/dist/table-legacy-ng/table-legacy-ng__toolbar.js +56 -0
  338. package/dist/table-ng/smart-table-ng.js +65 -0
  339. package/dist/table-ng/table-ng.js +64 -0
  340. package/dist/tabs/collapsible-more.js +5 -1
  341. package/dist/tabs/collapsible-tab.js +2 -1
  342. package/dist/tabs/collapsible-tabs.js +6 -3
  343. package/dist/tabs/dumb-tabs.js +6 -2
  344. package/dist/tabs/smart-tabs.js +6 -2
  345. package/dist/tabs/tab-link.js +2 -1
  346. package/dist/tabs/tab.js +1 -1
  347. package/dist/tabs/tabs.js +5 -1
  348. package/dist/tabs-ng/tabs-ng.js +193 -0
  349. package/dist/tabs-ng/tabs-ng__template.js +40 -0
  350. package/dist/tag/tag.js +4 -3
  351. package/dist/tags-input/tags-input.js +12 -8
  352. package/dist/tags-input-ng/tags-input-ng.js +89 -0
  353. package/dist/tags-list/tags-list.js +3 -2
  354. package/dist/template-ng/template-ng.js +70 -0
  355. package/dist/text/text.js +1 -1
  356. package/dist/theme-ng/theme-ng.js +44 -0
  357. package/dist/title-ng/title-ng.js +114 -0
  358. package/dist/toggle/toggle.js +2 -3
  359. package/dist/toggle-ng/toggle-ng.js +16 -0
  360. package/dist/tooltip/tooltip.js +8 -4
  361. package/dist/tooltip-ng/tooltip-ng.js +98 -0
  362. package/dist/user-agreement/service.js +409 -0
  363. package/dist/user-agreement/toolbox.eula.js +162 -0
  364. package/dist/user-agreement/user-agreement.js +167 -0
  365. package/dist/user-card/card.js +3 -0
  366. package/dist/user-card/smart-user-card-tooltip.js +5 -2
  367. package/dist/user-card/tooltip.js +5 -2
  368. package/dist/user-card/user-card.js +5 -2
  369. package/dist/user-card-ng/user-card-ng.js +59 -0
  370. package/package.json +62 -64
  371. package/webpack.config.js +10 -8
  372. package/components/button-set-ng/button-set-ng.html +0 -1
  373. package/components/footer-ng/footer-ng.html +0 -13
  374. package/components/form-ng/form-ng__error-bubble.html +0 -3
  375. package/components/table-legacy-ng/table-legacy-ng.html +0 -4
  376. package/components/table-legacy-ng/table-legacy-ng__column.html +0 -12
  377. package/components/table-legacy-ng/table-legacy-ng__header.html +0 -4
  378. package/components/table-legacy-ng/table-legacy-ng__pager.html +0 -7
  379. package/components/table-legacy-ng/table-legacy-ng__row.html +0 -12
  380. package/components/table-legacy-ng/table-legacy-ng__title.html +0 -9
  381. package/dist/_helpers/caption.js +0 -25
  382. package/dist/_helpers/icon__svg.js +0 -82
@@ -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 };
@@ -4,8 +4,10 @@ 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_avatar__0937d271","subavatar":"avatar_subavatar__0937d271","empty":"avatar_empty__0937d271"};
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,
@@ -50,6 +53,8 @@ class Avatar extends PureComponent {
50
53
  round,
51
54
  subavatar,
52
55
  subavatarSize,
56
+ username,
57
+ skipParams,
53
58
  ...restProps
54
59
  } = this.props;
55
60
  const sizeString = `${size}px`;
@@ -71,14 +76,20 @@ class Avatar extends PureComponent {
71
76
  if (!url || this.state.errorUrl === url) {
72
77
  return /*#__PURE__*/React.createElement("span", _extends({}, restProps, {
73
78
  "data-test": "avatar",
74
- 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
+ }),
75
82
  style: styleObj
83
+ }), username != null && /*#__PURE__*/React.createElement(FallbackAvatar, {
84
+ size: size,
85
+ round: round,
86
+ username: username
76
87
  }));
77
88
  }
78
89
 
79
90
  let src = url;
80
91
 
81
- if (!isDataURI(url)) {
92
+ if (!skipParams && !isDataURI(url)) {
82
93
  const [urlStart, query] = url.split('?');
83
94
  const queryParams = { ...parseQueryString(query),
84
95
  dpr,
@@ -95,7 +106,7 @@ class Avatar extends PureComponent {
95
106
  dpr,
96
107
  subavatarSizeString
97
108
  };
98
- subavatarSrc = encodeURL(urlStart, queryParams);
109
+ subavatarSrc = skipParams ? subavatar : encodeURL(urlStart, queryParams);
99
110
  return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement("img", _extends({}, restProps, {
100
111
  onError: this.handleError,
101
112
  onLoad: this.handleSuccess,
@@ -135,7 +146,9 @@ _defineProperty(Avatar, "propTypes", {
135
146
  url: PropTypes.string,
136
147
  round: PropTypes.bool,
137
148
  subavatar: PropTypes.string,
138
- subavatarSize: PropTypes.number
149
+ subavatarSize: PropTypes.number,
150
+ username: PropTypes.string,
151
+ skipParams: PropTypes.bool
139
152
  });
140
153
 
141
154
  _defineProperty(Avatar, "defaultProps", {
@@ -145,5 +158,4 @@ _defineProperty(Avatar, "defaultProps", {
145
158
  style: {}
146
159
  });
147
160
 
148
- export default Avatar;
149
- 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 };
@@ -0,0 +1,164 @@
1
+ import angular from 'angular';
2
+ import pencilIcon from '@jetbrains/icons/pencil';
3
+ import MessageBundle from '../message-bundle-ng/message-bundle-ng.js';
4
+ import alertService from '../alert-service/alert-service.js';
5
+ import IconNG from '../icon-ng/icon-ng.js';
6
+ import template from './avatar-editor-ng__template.js';
7
+ import '../_helpers/_rollupPluginBabelHelpers.js';
8
+ import 'react';
9
+ import 'react-dom';
10
+ import '../global/get-uid.js';
11
+ import '../alert/alert.js';
12
+ import 'classnames';
13
+ import 'prop-types';
14
+ import '@jetbrains/icons/exception';
15
+ import '@jetbrains/icons/checkmark';
16
+ import '@jetbrains/icons/warning';
17
+ import '@jetbrains/icons/close';
18
+ import '../icon/icon.js';
19
+ import 'util-deprecate';
20
+ import '../icon/icon__constants.js';
21
+ import '../_helpers/icon.js';
22
+ import '../icon/icon__svg.js';
23
+ import '../global/memoize.js';
24
+ import '../loader-inline/loader-inline.js';
25
+ import '../global/theme.js';
26
+ import '../global/data-tests.js';
27
+ import '../_helpers/inject-styles.js';
28
+ import '../global/conic-gradient.js';
29
+ import 'conic-gradient';
30
+ import '../global/supports-css.js';
31
+ import '../global/inject-styles.js';
32
+ import '../global/radial-gradient-mask.js';
33
+ import '../global/dom.js';
34
+ import '../alert/container.js';
35
+ import '../template-ng/template-ng.js';
36
+ import '../global/ring-angular-component.js';
37
+
38
+ const angularModule = angular.module('Ring.avatar-editor', [MessageBundle, IconNG]);
39
+ /**
40
+ * @name Avatar Editor Ng
41
+ */
42
+
43
+ function rgAvatarEditor() {
44
+ return {
45
+ restrict: 'E',
46
+ scope: {
47
+ model: '=ngModel',
48
+ onSelect: '&',
49
+ default: '@',
50
+ ngDisabled: '=',
51
+ showDeleteButton: '=?',
52
+ showAddButton: '=?',
53
+ deleteLabel: '@',
54
+ addMessage: '@'
55
+ },
56
+ template,
57
+ transclude: true,
58
+ controller: ['$scope', '$attrs', 'RingMessageBundle', function controller($scope, $attrs, RingMessageBundle) {
59
+ let fileInput;
60
+ $scope.editIcon = pencilIcon;
61
+ $scope.showAddButton = 'showAddButton' in $scope ? $scope.showAddButton : true;
62
+ $scope.showDeleteButton = 'showDeleteButton' in $scope ? $scope.showDeleteButton : true;
63
+
64
+ if ('controls' in $attrs) {
65
+ $scope.controlled = true;
66
+ }
67
+
68
+ function createFileLoadListener(file) {
69
+ return readEvent => {
70
+ const data = readEvent.target.result;
71
+ const result = $scope.onSelect({
72
+ name: file.name,
73
+ data
74
+ });
75
+
76
+ if (result && result.then) {
77
+ result.then(() => {
78
+ $scope.model = data;
79
+ });
80
+ } else if (result !== false) {
81
+ $scope.$apply(() => {
82
+ $scope.model = data;
83
+ });
84
+ }
85
+ };
86
+ }
87
+
88
+ this.registerFileInput = input => {
89
+ fileInput = input;
90
+ fileInput.addEventListener('change', e => {
91
+ let imageFileSelected = false;
92
+
93
+ for (let i = 0; i < e.target.files.length; i++) {
94
+ const file = e.target.files[i];
95
+
96
+ if (file.type.indexOf('image/') === 0) {
97
+ imageFileSelected = true;
98
+ const reader = new FileReader();
99
+ reader.onload = createFileLoadListener(file);
100
+ reader.readAsDataURL(file);
101
+ break;
102
+ }
103
+ }
104
+
105
+ if (e.target.files.length && !imageFileSelected) {
106
+ alertService.error(RingMessageBundle.avatareditor_noselected());
107
+ }
108
+ });
109
+ };
110
+
111
+ $scope.controls = {};
112
+
113
+ function onClick(e) {
114
+ e.stopPropagation();
115
+ }
116
+
117
+ $scope.controls.select = () => {
118
+ if (!FileReader) {
119
+ alertService.error(RingMessageBundle.avatareditor_nosupport());
120
+ } else {
121
+ fileInput.addEventListener('click', onClick);
122
+ fileInput.dispatchEvent(new MouseEvent('click'));
123
+ fileInput.removeEventListener('click', onClick);
124
+ }
125
+ };
126
+
127
+ $scope.controls.remove = () => {
128
+ const data = '';
129
+ const result = $scope.onSelect({
130
+ name: data,
131
+ data
132
+ });
133
+
134
+ if (result && result.then) {
135
+ result.then(() => {
136
+ $scope.model = data;
137
+ });
138
+ } else if (result !== false) {
139
+ $scope.model = data;
140
+ }
141
+ };
142
+
143
+ $scope.getDeleteLabel = () => $scope.deleteLabel || RingMessageBundle.avatareditor_delete();
144
+
145
+ $scope.getAddMessage = () => $scope.addMessage || RingMessageBundle.avatareditor_add();
146
+ }]
147
+ };
148
+ }
149
+
150
+ function rgAvatarEditorFileInput() {
151
+ return {
152
+ restrict: 'A',
153
+ require: '^rgAvatarEditor',
154
+ link: function link(scope, iElement, iAttrs, avatarEditorCtrl) {
155
+ avatarEditorCtrl.registerFileInput(iElement[0]);
156
+ }
157
+ };
158
+ }
159
+
160
+ angularModule.directive('rgAvatarEditor', rgAvatarEditor);
161
+ angularModule.directive('rgAvatarEditorFileInput', rgAvatarEditorFileInput);
162
+ var avatarEditorNg = angularModule.name;
163
+
164
+ export { avatarEditorNg as default };
@@ -0,0 +1,30 @@
1
+ var template = `<div>
2
+ <div ng-click="!ngDisabled && controls.select()" class="ring-avatar-editor__frame" ng-class="{
3
+ 'ring-avatar-editor_controlled': controlled,
4
+ 'ring-avatar-editor': !ngDisabled
5
+ }" ng-show="model || default">
6
+ <img alt="Avatar" class="ring-avatar-editor__img" ng-src="{{ model }}" ng-show="model">
7
+ <img alt="Default avatar" class="ring-avatar-editor__img" ng-src="{{ default }}"
8
+ ng-show="!model && default" ng-click="!ngDisabled && controls.select()">
9
+ <rg-icon glyph="{{editIcon}}" size="16" class="ring-avatar-editor__icon" ng-if="!ngDisabled"></rg-icon>
10
+ </div>
11
+ <input class="ring-avatar-editor__file-input" rg-avatar-editor-file-input type="file" ng-model="fileInput" accept="image/*" ng-if="!ngDisabled">
12
+
13
+ <rg-button
14
+ delayed="true"
15
+ ng-disabled="ngDisabled"
16
+ ng-if="showAddButton && !model && !default"
17
+ ng-click="controls.select()"
18
+ >{{ getAddMessage() }}</rg-button>
19
+
20
+ <rg-button
21
+ ng-if="showDeleteButton&& model && !ngDisabled"
22
+ danger="true"
23
+ class="ring-avatar-editor__remove"
24
+ ng-click="controls.remove()"
25
+ >
26
+ <span translate>{{ getDeleteLabel() }}</span>
27
+ </rg-button>
28
+ </div>`;
29
+
30
+ export { template as default };