@jetbrains/ring-ui 4.1.0-beta.4 → 4.1.2

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 (455) hide show
  1. package/CHANGELOG.md +13 -0
  2. package/README.md +17 -15
  3. package/babel.config.js +3 -2
  4. package/components/alert/alert.js +9 -3
  5. package/components/alert/alert.test.js +21 -48
  6. package/components/alert/container.css +1 -1
  7. package/components/alert/container.test.js +3 -13
  8. package/components/alert-service/alert-service.examples.css +18 -0
  9. package/components/alert-service/alert-service.examples.js +21 -0
  10. package/components/alert-service/alert-service.js +10 -3
  11. package/components/analytics/analytics__fus-plugin.js +3 -3
  12. package/components/analytics/analytics__ga-plugin.js +2 -2
  13. package/components/auth/auth.test.js +14 -7
  14. package/components/auth/auth__core.js +64 -33
  15. package/components/auth-dialog/auth-dialog.css +2 -3
  16. package/components/auth-dialog/auth-dialog.js +4 -1
  17. package/components/auth-dialog/auth-dialog.test.js +3 -19
  18. package/components/avatar/avatar.css +4 -1
  19. package/components/avatar/avatar.examples.js +3 -2
  20. package/components/avatar/avatar.js +34 -6
  21. package/components/avatar/avatar.test.js +20 -17
  22. package/components/avatar/fallback-avatar.js +136 -0
  23. package/components/avatar-editor-ng/avatar-editor-ng.css +2 -2
  24. package/components/avatar-editor-ng/avatar-editor-ng.js +2 -1
  25. package/components/avatar-editor-ng/{avatar-editor-ng.html → avatar-editor-ng__template.js} +2 -2
  26. package/components/badge/badge.test.js +13 -20
  27. package/components/button/button.css +2 -2
  28. package/components/button/button.js +4 -1
  29. package/components/button/button.test.js +32 -33
  30. package/components/button-group/button-group.js +1 -1
  31. package/components/button-group/caption.js +1 -1
  32. package/components/button-ng/button-ng.js +1 -1
  33. package/components/button-set-ng/button-set-ng.js +3 -1
  34. package/components/checkbox/checkbox.css +1 -1
  35. package/components/code/code.js +2 -5
  36. package/components/confirm/confirm.js +1 -0
  37. package/components/confirm-service/confirm-service.js +5 -5
  38. package/components/content-layout/content-layout.css +1 -1
  39. package/components/data-list/data-list.css +1 -1
  40. package/components/date-picker/date-input.js +5 -4
  41. package/components/date-picker/date-picker.css +34 -22
  42. package/components/date-picker/date-picker.js +16 -14
  43. package/components/date-picker/date-popup.js +22 -7
  44. package/components/date-picker/month-names.js +8 -5
  45. package/components/date-picker/month.js +6 -2
  46. package/components/date-picker/weekdays.js +10 -2
  47. package/components/dialog/dialog.examples.js +3 -1
  48. package/components/dialog/dialog.js +10 -5
  49. package/components/dialog/dialog.test.js +1 -1
  50. package/components/dialog/dialog__body-scroll-preventer.js +51 -31
  51. package/components/dialog-ng/dialog-ng.js +10 -10
  52. package/components/dialog-ng/{dialog-ng.html → dialog-ng__template.js} +2 -2
  53. package/components/dropdown/dropdown.examples.js +36 -1
  54. package/components/dropdown/dropdown.test.js +2 -2
  55. package/components/dropdown-menu/dropdown-menu.examples.js +47 -0
  56. package/components/dropdown-menu/dropdown-menu.js +117 -0
  57. package/components/dropdown-menu/dropdown-menu.test.js +76 -0
  58. package/components/error-bubble/error-bubble-legacy.css +1 -1
  59. package/components/error-bubble/error-bubble.css +1 -1
  60. package/components/error-bubble/error-bubble.examples.js +1 -1
  61. package/components/error-page/error-page.css +2 -2
  62. package/components/footer-ng/footer-ng.js +13 -3
  63. package/components/form/form.css +2 -2
  64. package/components/form-ng/form-ng.js +3 -1
  65. package/components/global/global.css +1 -1
  66. package/components/global/theme.js +1 -1
  67. package/components/global/variables.css +8 -1
  68. package/components/grid/grid.css +10 -9
  69. package/components/header/header.css +1 -1
  70. package/components/header/header.examples.js +7 -8
  71. package/components/header/profile.js +10 -11
  72. package/components/http/http.js +1 -1
  73. package/components/icon/icon.css +5 -4
  74. package/components/input/input-legacy.css +7 -7
  75. package/components/island/header.js +2 -2
  76. package/components/island/island.css +8 -3
  77. package/components/island-legacy/island-legacy.css +3 -1
  78. package/components/list/list.js +6 -1
  79. package/components/list/list__custom.js +9 -3
  80. package/components/list/list__item.js +8 -2
  81. package/components/list/list__link.js +2 -1
  82. package/components/loader-inline/loader-inline.css +1 -1
  83. package/components/loader-screen/loader-screen.css +1 -1
  84. package/components/message/message.css +1 -1
  85. package/components/message/message.examples.js +8 -7
  86. package/components/pager/pager.js +5 -3
  87. package/components/permissions/permissions.js +1 -1
  88. package/components/popup/popup.js +1 -1
  89. package/components/popup/popup.test.js +15 -13
  90. package/components/progress-bar/progress-bar.css +1 -1
  91. package/components/progress-bar/progress-bar.examples.js +3 -3
  92. package/components/progress-bar/progress-bar.js +5 -2
  93. package/components/progress-bar/progress-bar.test.js +12 -13
  94. package/components/progress-bar-ng/progress-bar-ng.examples.js +3 -3
  95. package/components/query-assist/query-assist.css +13 -3
  96. package/components/query-assist/query-assist.examples.js +3 -4
  97. package/components/query-assist/query-assist.js +56 -12
  98. package/components/query-assist/query-assist.test.js +37 -5
  99. package/components/save-field-ng/save-field-ng.css +0 -3
  100. package/components/save-field-ng/save-field-ng.js +3 -1
  101. package/components/save-field-ng/{save-field-ng.html → save-field-ng__template.js} +2 -2
  102. package/components/select/select.css +12 -7
  103. package/components/select/select.examples.js +13 -0
  104. package/components/select/select.js +30 -43
  105. package/components/select/select.test.js +4 -5
  106. package/components/select/select__popup.js +1 -0
  107. package/components/shortcuts-hint-ng/shortcuts-hint-ng.css +1 -1
  108. package/components/shortcuts-hint-ng/shortcuts-hint-ng.js +1 -1
  109. package/components/shortcuts-hint-ng/{shortcuts-hint-ng.html → shortcuts-hint-ng__template.js} +2 -2
  110. package/components/sidebar/sidebar.css +1 -0
  111. package/components/sidebar-ng/sidebar-ng.js +6 -2
  112. package/components/sidebar-ng/{sidebar-ng__button.html → sidebar-ng__button-template.js} +2 -2
  113. package/components/sidebar-ng/{sidebar-ng.html → sidebar-ng__template.js} +2 -2
  114. package/components/table/header.js +9 -1
  115. package/components/table/row.js +2 -1
  116. package/components/table/table.css +2 -1
  117. package/components/table-legacy/table-legacy.css +2 -2
  118. package/components/table-legacy/table-legacy__toolbar.css +2 -2
  119. package/components/table-legacy-ng/table-legacy-ng.js +38 -5
  120. package/components/table-legacy-ng/table-legacy-ng__pager.js +7 -1
  121. package/components/tabs/collapsible-tab.js +2 -2
  122. package/components/tabs/collapsible-tabs.js +5 -9
  123. package/components/tabs/tab-link.js +4 -2
  124. package/components/tabs/tabs.css +32 -5
  125. package/components/tabs-ng/tabs-ng.js +4 -2
  126. package/components/tabs-ng/{tabs-ng.html → tabs-ng__template.js} +6 -2
  127. package/components/tag/tag.css +5 -2
  128. package/components/tag/tag.examples.js +3 -0
  129. package/components/tag/tag.js +19 -16
  130. package/components/tags-input/tag-input.examples.js +1 -1
  131. package/components/tags-input/tags-input.js +5 -2
  132. package/components/template-ng/template-ng.js +1 -1
  133. package/components/tooltip/tooltip.js +7 -2
  134. package/components/user-agreement/user-agreement.css +1 -5
  135. package/components/user-agreement/user-agreement.examples.js +7 -6
  136. package/components/user-agreement/user-agreement.js +11 -3
  137. package/dist/_helpers/_rollupPluginBabelHelpers.js +1 -90
  138. package/dist/_helpers/anchor.js +6 -7
  139. package/dist/_helpers/badge.js +1 -1
  140. package/dist/_helpers/button-group.js +3 -0
  141. package/dist/_helpers/button-set.js +3 -0
  142. package/dist/_helpers/button-toolbar.js +3 -0
  143. package/dist/_helpers/button__classes.js +16 -15
  144. package/dist/_helpers/card.js +6 -8
  145. package/dist/_helpers/checkbox.js +3 -0
  146. package/dist/_helpers/date-picker.js +1 -1
  147. package/dist/_helpers/dialog__body-scroll-preventer.js +49 -32
  148. package/dist/_helpers/error-message.js +3 -0
  149. package/dist/_helpers/footer.js +121 -0
  150. package/dist/_helpers/grid.js +1 -1
  151. package/dist/_helpers/group.js +3 -0
  152. package/dist/_helpers/header.js +1 -1
  153. package/dist/_helpers/icon.js +3 -0
  154. package/dist/_helpers/inject-styles.js +1 -1
  155. package/dist/_helpers/input.js +3 -0
  156. package/dist/_helpers/island.js +1 -1
  157. package/dist/_helpers/link.js +3 -0
  158. package/dist/_helpers/list.js +1 -1
  159. package/dist/_helpers/loader-screen.js +3 -0
  160. package/dist/_helpers/panel.js +3 -0
  161. package/dist/_helpers/query-assist__suggestions.js +1 -1
  162. package/dist/_helpers/radio.js +3 -0
  163. package/dist/_helpers/select__filter.js +8 -10
  164. package/dist/_helpers/services-link.js +6 -8
  165. package/dist/_helpers/sidebar.js +17 -17
  166. package/dist/_helpers/table.js +1 -1
  167. package/dist/_helpers/tabs.js +1 -1
  168. package/dist/_helpers/title.js +3 -3
  169. package/dist/alert/alert.js +20 -9
  170. package/dist/alert/container.js +7 -9
  171. package/dist/alert-service/alert-service.js +26 -13
  172. package/dist/analytics/analytics.js +2 -2
  173. package/dist/analytics/analytics__custom-plugin.js +1 -1
  174. package/dist/analytics/analytics__fus-plugin.js +13 -11
  175. package/dist/analytics/analytics__ga-plugin.js +3 -3
  176. package/dist/analytics/analytics__plugin-utils.js +1 -1
  177. package/dist/analytics-ng/analytics-ng.js +94 -0
  178. package/dist/auth/auth.js +7 -4
  179. package/dist/auth/auth__core.js +106 -63
  180. package/dist/auth/background-flow.js +1 -2
  181. package/dist/auth/down-notification.js +19 -12
  182. package/dist/auth/iframe-flow.js +5 -2
  183. package/dist/auth/landing-entry.js +1 -1
  184. package/dist/auth/landing.js +5 -2
  185. package/dist/auth/request-builder.js +1 -1
  186. package/dist/auth/response-parser.js +3 -2
  187. package/dist/auth/storage.js +5 -3
  188. package/dist/auth/token-validator.js +6 -5
  189. package/dist/auth/window-flow.js +1 -1
  190. package/dist/auth-dialog/auth-dialog.js +9 -6
  191. package/dist/auth-dialog-service/auth-dialog-service.js +9 -6
  192. package/dist/auth-ng/auth-ng.js +203 -0
  193. package/dist/auth-ng/auth-ng.mock.js +33 -0
  194. package/dist/autofocus-ng/autofocus-ng.js +50 -0
  195. package/dist/avatar/avatar.js +41 -32
  196. package/dist/avatar/fallback-avatar.js +141 -0
  197. package/dist/avatar-editor-ng/avatar-editor-ng.js +164 -0
  198. package/dist/avatar-editor-ng/avatar-editor-ng__template.js +30 -0
  199. package/dist/avatar-ng/avatar-ng.js +18 -0
  200. package/dist/badge/badge.js +6 -8
  201. package/dist/badge-ng/badge-ng.js +16 -0
  202. package/dist/breadcrumb-ng/breadcrumb-ng.js +61 -0
  203. package/dist/button/button.js +16 -10
  204. package/dist/button-group/button-group.js +4 -4
  205. package/dist/button-group/caption.js +24 -5
  206. package/dist/button-group-ng/button-group-ng.js +38 -0
  207. package/dist/button-ng/button-ng.js +223 -0
  208. package/dist/button-set/button-set.js +3 -4
  209. package/dist/button-set-ng/button-set-ng.js +19 -0
  210. package/dist/button-toolbar/button-toolbar.js +3 -4
  211. package/dist/button-toolbar-ng/button-toolbar-ng.js +23 -0
  212. package/dist/caret/caret.js +4 -2
  213. package/dist/checkbox/checkbox.js +11 -13
  214. package/dist/checkbox-ng/checkbox-ng.js +55 -0
  215. package/dist/code/code.js +136 -0
  216. package/dist/compiler-ng/compiler-ng.js +53 -0
  217. package/dist/confirm/confirm.js +8 -5
  218. package/dist/confirm-ng/confirm-ng.js +66 -0
  219. package/dist/confirm-service/confirm-service.js +21 -18
  220. package/dist/content-layout/content-layout.js +8 -10
  221. package/dist/contenteditable/contenteditable.js +14 -17
  222. package/dist/data-list/data-list.js +12 -9
  223. package/dist/data-list/data-list.mock.js +2 -2
  224. package/dist/data-list/item.js +7 -5
  225. package/dist/data-list/selection.js +7 -3
  226. package/dist/data-list/title.js +3 -1
  227. package/dist/data-list-ng/data-list-ng.js +59 -0
  228. package/dist/date-picker/consts.js +1 -2
  229. package/dist/date-picker/date-input.js +17 -12
  230. package/dist/date-picker/date-picker.js +41 -32
  231. package/dist/date-picker/date-popup.js +51 -28
  232. package/dist/date-picker/day.js +4 -4
  233. package/dist/date-picker/formats.js +1 -1
  234. package/dist/date-picker/month-names.js +18 -11
  235. package/dist/date-picker/month-slider.js +4 -4
  236. package/dist/date-picker/month.js +13 -7
  237. package/dist/date-picker/months.js +3 -3
  238. package/dist/date-picker/weekdays.js +12 -4
  239. package/dist/date-picker/years.js +4 -4
  240. package/dist/dialog/dialog.js +21 -16
  241. package/dist/dialog/dialog__body-scroll-preventer.js +1 -1
  242. package/dist/dialog-ng/dialog-ng.js +601 -0
  243. package/dist/dialog-ng/dialog-ng__template.js +71 -0
  244. package/dist/docked-panel-ng/docked-panel-ng.js +170 -0
  245. package/dist/dropdown/anchor.js +2 -1
  246. package/dist/dropdown/dropdown.js +22 -18
  247. package/dist/dropdown-menu/dropdown-menu.js +175 -0
  248. package/dist/error-bubble/error-bubble.js +7 -9
  249. package/dist/error-message/error-message.js +4 -4
  250. package/dist/error-message-ng/error-message-ng.js +53 -0
  251. package/dist/footer/footer.js +6 -119
  252. package/dist/footer-ng/footer-ng.js +75 -0
  253. package/dist/form-ng/form-ng.js +169 -0
  254. package/dist/global/angular-component-factory.js +6 -4
  255. package/dist/global/compose.js +8 -2
  256. package/dist/global/composeRefs.js +13 -7
  257. package/dist/global/conic-gradient.js +13 -12
  258. package/dist/global/create-stateful-context.js +12 -9
  259. package/dist/global/data-tests.js +10 -3
  260. package/dist/global/dom.js +12 -5
  261. package/dist/global/focus-sensor-hoc.js +20 -19
  262. package/dist/global/fuzzy-highlight.js +10 -6
  263. package/dist/global/get-event-key.js +1 -1
  264. package/dist/global/get-uid.js +1 -1
  265. package/dist/global/inject-styles.js +4 -1
  266. package/dist/global/linear-function.js +1 -2
  267. package/dist/global/listeners.js +1 -1
  268. package/dist/global/memoize.js +3 -2
  269. package/dist/global/normalize-indent.js +1 -1
  270. package/dist/global/promise-with-timeout.js +5 -4
  271. package/dist/global/radial-gradient-mask.js +6 -3
  272. package/dist/global/react-dom-renderer.js +3 -3
  273. package/dist/global/rerender-hoc.js +14 -12
  274. package/dist/global/ring-angular-component.js +6 -2
  275. package/dist/global/schedule-raf.js +1 -1
  276. package/dist/global/sniffer.js +1 -1
  277. package/dist/global/supports-css.js +1 -1
  278. package/dist/global/theme.js +27 -26
  279. package/dist/global/trivial-template-tag.js +6 -2
  280. package/dist/global/url.js +3 -1
  281. package/dist/global/variables_dark.js +1 -1
  282. package/dist/grid/col.js +6 -8
  283. package/dist/grid/grid.js +5 -7
  284. package/dist/grid/row.js +6 -8
  285. package/dist/group/group.js +7 -10
  286. package/dist/group-ng/group-ng.js +11 -0
  287. package/dist/header/header.js +29 -26
  288. package/dist/header/logo.js +8 -9
  289. package/dist/header/profile.js +54 -46
  290. package/dist/header/services-link.js +1 -0
  291. package/dist/header/services.js +23 -19
  292. package/dist/header/smart-profile.js +29 -26
  293. package/dist/header/smart-services.js +12 -11
  294. package/dist/header/tray-icon.js +12 -12
  295. package/dist/header/tray.js +6 -8
  296. package/dist/heading/heading.js +10 -13
  297. package/dist/http/http.js +53 -44
  298. package/dist/http/http.mock.js +4 -4
  299. package/dist/hub-source/hub-source.js +1 -1
  300. package/dist/hub-source/hub-source__user.js +4 -2
  301. package/dist/hub-source/hub-source__users-groups.js +5 -3
  302. package/dist/icon/icon.js +8 -8
  303. package/dist/icon/icon__svg.js +81 -6
  304. package/dist/icon/index.js +2 -1
  305. package/dist/icon-ng/icon-ng.js +89 -0
  306. package/dist/input/input.js +11 -14
  307. package/dist/input-ng/input-ng.js +166 -0
  308. package/dist/island/adaptive-island-hoc.js +10 -9
  309. package/dist/island/content.js +8 -10
  310. package/dist/island/header.js +7 -9
  311. package/dist/island/island.js +6 -9
  312. package/dist/island-legacy/content-legacy.js +6 -8
  313. package/dist/island-legacy/header-legacy.js +6 -8
  314. package/dist/island-legacy/island-legacy.js +6 -8
  315. package/dist/island-ng/island-content-ng.js +56 -0
  316. package/dist/island-ng/island-header-ng.js +32 -0
  317. package/dist/island-ng/island-ng-class-fixer.js +9 -0
  318. package/dist/island-ng/island-ng.js +31 -0
  319. package/dist/link/clickableLink.js +8 -10
  320. package/dist/link/link.js +12 -15
  321. package/dist/link-ng/link-ng.js +25 -0
  322. package/dist/list/list.js +100 -76
  323. package/dist/list/list__custom.js +15 -12
  324. package/dist/list/list__hint.js +1 -1
  325. package/dist/list/list__item.js +22 -15
  326. package/dist/list/list__link.js +11 -12
  327. package/dist/list/list__separator.js +1 -1
  328. package/dist/list/list__title.js +1 -1
  329. package/dist/list/list__users-groups-source.js +13 -8
  330. package/dist/loader/loader.js +8 -10
  331. package/dist/loader/loader__core.js +9 -8
  332. package/dist/loader-inline/inject-styles.js +1 -1
  333. package/dist/loader-inline/loader-inline.js +6 -8
  334. package/dist/loader-inline-ng/loader-inline-ng.js +42 -0
  335. package/dist/loader-ng/loader-ng.js +43 -0
  336. package/dist/loader-screen/loader-screen.js +7 -10
  337. package/dist/loader-screen-ng/loader-screen-ng.js +99 -0
  338. package/dist/login-dialog/login-dialog.js +7 -5
  339. package/dist/login-dialog/service.js +9 -6
  340. package/dist/markdown/code.js +30 -0
  341. package/dist/markdown/heading.js +23 -0
  342. package/dist/markdown/link.js +30 -0
  343. package/dist/markdown/markdown.js +73 -0
  344. package/dist/message/message.js +7 -6
  345. package/dist/message-bundle-ng/message-bundle-ng.js +111 -0
  346. package/dist/old-browsers-message/old-browsers-message.js +0 -1
  347. package/dist/old-browsers-message/old-browsers-message__stop.js +0 -1
  348. package/dist/old-browsers-message/white-list.js +4 -5
  349. package/dist/pager/pager.js +20 -11
  350. package/dist/pager-ng/pager-ng.js +96 -0
  351. package/dist/panel/panel.js +7 -10
  352. package/dist/panel-ng/panel-ng.js +16 -0
  353. package/dist/permissions/permissions.js +4 -2
  354. package/dist/permissions/permissions__cache.js +1 -1
  355. package/dist/permissions-ng/permissions-ng.js +274 -0
  356. package/dist/place-under-ng/place-under-ng.js +157 -0
  357. package/dist/popup/popup.js +11 -11
  358. package/dist/popup/popup.target.js +4 -5
  359. package/dist/popup/position.js +18 -16
  360. package/dist/popup-menu/popup-menu.js +23 -16
  361. package/dist/progress-bar/progress-bar.js +14 -12
  362. package/dist/progress-bar-ng/progress-bar-ng.js +15 -0
  363. package/dist/promised-click-ng/promised-click-ng.js +126 -0
  364. package/dist/proxy-attrs/proxy-attrs.js +1 -1
  365. package/dist/query-assist/query-assist.js +156 -76
  366. package/dist/query-assist/query-assist__suggestions.js +5 -1
  367. package/dist/query-assist-ng/query-assist-ng.js +82 -0
  368. package/dist/radio/radio.js +9 -7
  369. package/dist/radio/radio__item.js +13 -18
  370. package/dist/radio-ng/radio-ng.js +63 -0
  371. package/dist/save-field-ng/save-field-ng.js +335 -0
  372. package/dist/save-field-ng/save-field-ng__template.js +34 -0
  373. package/dist/select/select.js +118 -95
  374. package/dist/select/select__filter.js +6 -1
  375. package/dist/select/select__popup.js +12 -6
  376. package/dist/select-ng/select-ng.js +621 -0
  377. package/dist/select-ng/select-ng__lazy.js +150 -0
  378. package/dist/select-ng/select-ng__options.js +145 -0
  379. package/dist/shortcuts/core.js +7 -4
  380. package/dist/shortcuts/shortcuts-hoc.js +8 -10
  381. package/dist/shortcuts/shortcuts.js +6 -6
  382. package/dist/shortcuts-hint-ng/shortcuts-hint-ng.js +120 -0
  383. package/dist/shortcuts-hint-ng/shortcuts-hint-ng__template.js +50 -0
  384. package/dist/shortcuts-ng/shortcuts-ng.js +261 -0
  385. package/dist/sidebar-ng/sidebar-ng.js +111 -0
  386. package/dist/sidebar-ng/sidebar-ng__button-template.js +20 -0
  387. package/dist/sidebar-ng/sidebar-ng__template.js +12 -0
  388. package/dist/storage/storage.js +3 -2
  389. package/dist/storage/storage__fallback.js +3 -2
  390. package/dist/storage/storage__local.js +5 -3
  391. package/dist/style.css +1 -1
  392. package/dist/tab-trap/tab-trap.js +15 -13
  393. package/dist/table/cell.js +2 -2
  394. package/dist/table/disable-hover-hoc.js +4 -4
  395. package/dist/table/header-cell.js +10 -11
  396. package/dist/table/header.js +19 -12
  397. package/dist/table/multitable.js +33 -25
  398. package/dist/table/row-with-focus-sensor.js +7 -5
  399. package/dist/table/row.js +17 -15
  400. package/dist/table/selection-adapter.js +1 -1
  401. package/dist/table/selection-shortcuts-hoc.js +10 -8
  402. package/dist/table/selection.js +25 -17
  403. package/dist/table/smart-table.js +16 -10
  404. package/dist/table/table.js +38 -33
  405. package/dist/table-legacy-ng/table-legacy-ng.js +501 -0
  406. package/dist/table-legacy-ng/table-legacy-ng__pager.js +122 -0
  407. package/dist/table-legacy-ng/table-legacy-ng__selection-navigate-actions.js +123 -0
  408. package/dist/table-legacy-ng/table-legacy-ng__selection.js +179 -0
  409. package/dist/table-legacy-ng/table-legacy-ng__toolbar.js +56 -0
  410. package/dist/table-ng/smart-table-ng.js +65 -0
  411. package/dist/table-ng/table-ng.js +64 -0
  412. package/dist/tabs/collapsible-more.js +37 -30
  413. package/dist/tabs/collapsible-tab.js +16 -14
  414. package/dist/tabs/collapsible-tabs.js +83 -80
  415. package/dist/tabs/custom-item.js +6 -3
  416. package/dist/tabs/dumb-tabs.js +19 -14
  417. package/dist/tabs/smart-tabs.js +13 -11
  418. package/dist/tabs/tab-link.js +13 -7
  419. package/dist/tabs/tab.js +1 -1
  420. package/dist/tabs/tabs.js +5 -1
  421. package/dist/tabs-ng/tabs-ng.js +193 -0
  422. package/dist/tabs-ng/tabs-ng__template.js +40 -0
  423. package/dist/tag/tag.js +22 -16
  424. package/dist/tags-input/tags-input.js +48 -36
  425. package/dist/tags-input-ng/tags-input-ng.js +89 -0
  426. package/dist/tags-list/tags-list.js +8 -9
  427. package/dist/template-ng/template-ng.js +70 -0
  428. package/dist/text/text.js +7 -9
  429. package/dist/theme-ng/theme-ng.js +44 -0
  430. package/dist/title-ng/title-ng.js +114 -0
  431. package/dist/toggle/toggle.js +8 -11
  432. package/dist/toggle-ng/toggle-ng.js +16 -0
  433. package/dist/tooltip/tooltip.js +16 -14
  434. package/dist/tooltip-ng/tooltip-ng.js +98 -0
  435. package/dist/user-agreement/service.js +409 -0
  436. package/dist/user-agreement/toolbox.eula.js +162 -0
  437. package/dist/user-agreement/user-agreement.js +167 -0
  438. package/dist/user-card/card.js +3 -0
  439. package/dist/user-card/smart-user-card-tooltip.js +16 -16
  440. package/dist/user-card/tooltip.js +9 -7
  441. package/dist/user-card/user-card.js +5 -2
  442. package/dist/user-card-ng/user-card-ng.js +59 -0
  443. package/package.json +83 -81
  444. package/webpack.config.js +14 -10
  445. package/components/button-set-ng/button-set-ng.html +0 -1
  446. package/components/footer-ng/footer-ng.html +0 -13
  447. package/components/form-ng/form-ng__error-bubble.html +0 -3
  448. package/components/table-legacy-ng/table-legacy-ng.html +0 -4
  449. package/components/table-legacy-ng/table-legacy-ng__column.html +0 -12
  450. package/components/table-legacy-ng/table-legacy-ng__header.html +0 -4
  451. package/components/table-legacy-ng/table-legacy-ng__pager.html +0 -7
  452. package/components/table-legacy-ng/table-legacy-ng__row.html +0 -12
  453. package/components/table-legacy-ng/table-legacy-ng__title.html +0 -9
  454. package/dist/_helpers/caption.js +0 -25
  455. package/dist/_helpers/icon__svg.js +0 -83
@@ -0,0 +1,157 @@
1
+ import angular from 'angular';
2
+ import debounce from 'just-debounce-it';
3
+ import createResizeDetector from 'element-resize-detector';
4
+ import { getDocumentScrollTop } from '../global/dom.js';
5
+ import '../_helpers/_rollupPluginBabelHelpers.js';
6
+
7
+ const resizeDetector = createResizeDetector();
8
+ const angularModule = angular.module('Ring.place-under', []);
9
+ angularModule.directive('rgPlaceUnder', // eslint-disable-next-line angular/di-unused
10
+ ["$window", "getClosestElementWithCommonParent", "rgPlaceUnderHelper", function rgPlaceUnderDirective($window, getClosestElementWithCommonParent, rgPlaceUnderHelper) {
11
+ return {
12
+ restrict: 'A',
13
+ link: function link(scope, iElement, iAttrs) {
14
+ const element = iElement[0];
15
+ const synchronizer = rgPlaceUnderHelper.createPositionSynchronizer(element, iAttrs, scope);
16
+
17
+ function startSyncing(placeUnderSelector) {
18
+ if (placeUnderSelector) {
19
+ scope.$evalAsync(() => {
20
+ const syncWith = getClosestElementWithCommonParent(element, placeUnderSelector);
21
+
22
+ if (syncWith) {
23
+ synchronizer.syncPositionWith(syncWith);
24
+ } else {
25
+ throw new Error('rgPlaceUnder cannot find element to sync with.');
26
+ }
27
+ });
28
+ }
29
+ }
30
+
31
+ iAttrs.$observe('rgPlaceUnder', startSyncing);
32
+ }
33
+ };
34
+ }]);
35
+ angularModule.factory('getClosestElementWithCommonParent', function getClosestElementWithCommonParentFactory() {
36
+ return function getClosestElementWithCommonParent(currentElement, selector) {
37
+ const parent = currentElement.parentNode;
38
+
39
+ if (parent) {
40
+ return parent.querySelector(selector) || getClosestElementWithCommonParent(parent, selector);
41
+ } else {
42
+ return null;
43
+ }
44
+ };
45
+ });
46
+ angularModule.factory('rgPlaceUnderHelper', ["$window", $window => {
47
+ const DEBOUNCE_INTERVAL = 10;
48
+ const AFTER_SCROLL_RECHECK_INTERVAL = 50;
49
+ const HEIGHT_CHECK_INTERVAL = 50;
50
+ return {
51
+ DEBOUNCE_INTERVAL,
52
+ AFTER_SCROLL_RECHECK_INTERVAL,
53
+ HEIGHT_CHECK_INTERVAL,
54
+ createPositionSynchronizer: (element, iAttrs, scope) => {
55
+ const topOffset = parseInt(iAttrs.placeTopOffset, 10) || 0;
56
+ const syncHeight = iAttrs.syncHeight;
57
+ let syncBottom = [];
58
+ let removeScrollListener = [];
59
+
60
+ if (iAttrs.syncBottom) {
61
+ syncBottom = iAttrs.syncBottom.split(',');
62
+ }
63
+
64
+ function waitForNonZeroHeight(elementToCheck) {
65
+ return new Promise(resolve => {
66
+ function checkElementHeight() {
67
+ if (elementToCheck.offsetHeight === 0) {
68
+ $window.setTimeout(checkElementHeight, HEIGHT_CHECK_INTERVAL);
69
+ } else {
70
+ resolve();
71
+ }
72
+ }
73
+
74
+ checkElementHeight();
75
+ });
76
+ }
77
+
78
+ function onScroll(syncElement) {
79
+ const documentScrollTop = getDocumentScrollTop();
80
+ const documentOffsetHeight = $window.document.documentElement && $window.document.documentElement.offsetHeight || $window.document.body.offsetHeight;
81
+ const syncedElementHeight = syncElement.offsetHeight;
82
+ const syncedElementOffsetTop = syncElement.getBoundingClientRect().top + documentScrollTop;
83
+ const bottom = syncedElementOffsetTop + syncedElementHeight;
84
+ const margin = Math.max(bottom - documentScrollTop, syncedElementHeight);
85
+ element.style.marginTop = `${margin + topOffset}px`;
86
+
87
+ if (syncHeight) {
88
+ /**
89
+ * Decrease height by margin value to make scroll work properly
90
+ */
91
+ let bottomOffset = 0;
92
+
93
+ if (syncBottom.length) {
94
+ for (let i = 0; i < syncBottom.length; i++) {
95
+ const syncBottomParams = syncBottom[i].split(';');
96
+ const elem = $window.document.querySelector(syncBottomParams[0]);
97
+ const extraMargin = syncBottomParams[1] ? parseInt(syncBottomParams[1], 10) : 0;
98
+
99
+ if (elem) {
100
+ const boundingRect = elem.getBoundingClientRect();
101
+
102
+ if (boundingRect.top === 0) {
103
+ continue;
104
+ }
105
+
106
+ const marginTop = parseInt($window.getComputedStyle(elem).getPropertyValue('margin-top'), 10);
107
+ bottomOffset = documentOffsetHeight - boundingRect.top + marginTop + extraMargin;
108
+
109
+ if (bottomOffset < 0) {
110
+ bottomOffset = 0;
111
+ }
112
+
113
+ break;
114
+ }
115
+ }
116
+ }
117
+
118
+ element.style.height = `calc(100% - ${parseInt(element.style.marginTop, 10) + bottomOffset}px)`;
119
+ }
120
+ }
121
+
122
+ function removeScrollListeners() {
123
+ removeScrollListener.map(cb => cb());
124
+ removeScrollListener = [];
125
+ }
126
+
127
+ function syncPositionWith(syncElement) {
128
+ removeScrollListeners();
129
+ const afterScrollFinishRecheck = debounce(() => this.onScroll(syncElement), AFTER_SCROLL_RECHECK_INTERVAL);
130
+ const sidebarScrollListener = debounce(() => {
131
+ this.onScroll(syncElement);
132
+ afterScrollFinishRecheck();
133
+ }, DEBOUNCE_INTERVAL);
134
+ this.waitForNonZeroHeight(syncElement).then(sidebarScrollListener);
135
+ $window.addEventListener('scroll', sidebarScrollListener);
136
+ removeScrollListener.push(() => {
137
+ $window.removeEventListener('scroll', sidebarScrollListener);
138
+ });
139
+ removeScrollListener.push(scope.$watch('show', sidebarScrollListener));
140
+ removeScrollListener.push(scope.$on('rgPlaceUnder:sync', sidebarScrollListener));
141
+ const elementToHeightListening = iAttrs.listenToHeightChange ? $window.document.querySelector(iAttrs.listenToHeightChange) : $window.document.body;
142
+ resizeDetector.listenTo(elementToHeightListening, sidebarScrollListener);
143
+ removeScrollListener.push(() => resizeDetector.removeAllListeners(elementToHeightListening));
144
+ }
145
+
146
+ scope.$on('$destroy', removeScrollListeners);
147
+ return {
148
+ waitForNonZeroHeight,
149
+ onScroll,
150
+ syncPositionWith
151
+ };
152
+ }
153
+ };
154
+ }]);
155
+ var PlaceUnder = angularModule.name;
156
+
157
+ export { PlaceUnder as default };
@@ -1,4 +1,4 @@
1
- import { _ as _defineProperty, c as _objectSpread2 } from '../_helpers/_rollupPluginBabelHelpers.js';
1
+ import { _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
2
2
  import React, { PureComponent } from 'react';
3
3
  import { createPortal } from 'react-dom';
4
4
  import PropTypes from 'prop-types';
@@ -18,7 +18,7 @@ import 'combokeys';
18
18
  import '../global/sniffer.js';
19
19
  import 'sniffr';
20
20
 
21
- var modules_2f69e2e2 = {"popup":"popup_popup__d157c5ca global_font__0f8f4370","hidden":"popup_hidden__d157c5ca","showing":"popup_showing__d157c5ca","attached":"popup_attached__d157c5ca"};
21
+ var modules_2f69e2e2 = {"popup":"popup_rui_d157 font_rui_750f","hidden":"hidden_rui_d157","showing":"showing_rui_d157","attached":"attached_rui_d157"};
22
22
 
23
23
  const stop = e => e.stopPropagation();
24
24
 
@@ -30,8 +30,8 @@ const getPopupContainer = target => typeof target === 'string' ? document.queryS
30
30
  */
31
31
 
32
32
  class Popup extends PureComponent {
33
- constructor(...args) {
34
- super(...args);
33
+ constructor() {
34
+ super(...arguments);
35
35
 
36
36
  _defineProperty(this, "state", {
37
37
  display: Display.SHOWING
@@ -43,7 +43,7 @@ class Popup extends PureComponent {
43
43
 
44
44
  _defineProperty(this, "uid", getUID('popup-'));
45
45
 
46
- _defineProperty(this, "calculateDisplay", prevState => _objectSpread2(_objectSpread2({}, prevState), {}, {
46
+ _defineProperty(this, "calculateDisplay", prevState => ({ ...prevState,
47
47
  display: this.props.hidden ? Display.SHOWING : Display.SHOWN
48
48
  }));
49
49
 
@@ -189,11 +189,12 @@ class Popup extends PureComponent {
189
189
  return acc;
190
190
  }, {});
191
191
  const container = this.getContainer();
192
- return position(_objectSpread2({
192
+ return position({
193
193
  popup: this.popup,
194
194
  container: container && getStyles(container).position !== 'static' ? container : null,
195
- anchor: this._getAnchor()
196
- }, positionProps));
195
+ anchor: this._getAnchor(),
196
+ ...positionProps
197
+ });
197
198
  }
198
199
 
199
200
  _getAnchor() {
@@ -211,7 +212,7 @@ class Popup extends PureComponent {
211
212
  this._listenersEnabled = true;
212
213
  this.listeners.add(window, 'resize', this._redraw);
213
214
  this.listeners.add(window, 'scroll', this._redraw);
214
- this.listeners.add(document, 'click', this._onDocumentClick, true);
215
+ this.listeners.add(document, 'pointerdown', this._onDocumentClick, true);
215
216
 
216
217
  let el = this._getAnchor();
217
218
 
@@ -385,5 +386,4 @@ _defineProperty(Popup, "PopupProps", {
385
386
  MaxHeight
386
387
  });
387
388
 
388
- export default Popup;
389
- export { getPopupContainer };
389
+ export { Popup as default, getPopupContainer };
@@ -1,4 +1,4 @@
1
- import { a as _objectWithoutProperties, b as _extends } from '../_helpers/_rollupPluginBabelHelpers.js';
1
+ import { a as _extends } from '../_helpers/_rollupPluginBabelHelpers.js';
2
2
  import React, { createContext, forwardRef } from 'react';
3
3
  import PropTypes from 'prop-types';
4
4
 
@@ -6,10 +6,9 @@ const PopupTargetContext = /*#__PURE__*/createContext();
6
6
  const PopupTarget = /*#__PURE__*/forwardRef(function PopupTarget(_ref, ref) {
7
7
  let {
8
8
  id,
9
- children
10
- } = _ref,
11
- restProps = _objectWithoutProperties(_ref, ["id", "children"]);
12
-
9
+ children,
10
+ ...restProps
11
+ } = _ref;
13
12
  const isFunctionChild = typeof children === 'function';
14
13
  const target = /*#__PURE__*/React.createElement("div", _extends({}, restProps, {
15
14
  "data-portaltarget": id,
@@ -108,15 +108,16 @@ const defaultcontainerRect = {
108
108
  left: 0
109
109
  };
110
110
 
111
- function handleTopOffScreen({
112
- sidePadding,
113
- styles,
114
- anchorRect,
115
- maxHeight,
116
- popupScrollHeight,
117
- direction,
118
- scroll
119
- }) {
111
+ function handleTopOffScreen(_ref) {
112
+ let {
113
+ sidePadding,
114
+ styles,
115
+ anchorRect,
116
+ maxHeight,
117
+ popupScrollHeight,
118
+ direction,
119
+ scroll
120
+ } = _ref;
120
121
  const BORDER_COMPENSATION = 1;
121
122
  const {
122
123
  TOP_LEFT,
@@ -221,11 +222,13 @@ function position(attrs) {
221
222
  concat(directions[0]).filter(direction => directionsMatrix[direction]).map(direction => ({
222
223
  styles: directionsMatrix[direction],
223
224
  direction
224
- })).sort(({
225
- styles: stylesA
226
- }, {
227
- styles: stylesB
228
- }) => {
225
+ })).sort((_ref2, _ref3) => {
226
+ let {
227
+ styles: stylesA
228
+ } = _ref2;
229
+ let {
230
+ styles: stylesB
231
+ } = _ref3;
229
232
  const overflowA = verticalOverflow(stylesA, scroll, attrs) + horizontalOverflow(stylesA, scroll, attrs);
230
233
  const overflowB = verticalOverflow(stylesB, scroll, attrs) + horizontalOverflow(stylesB, scroll, attrs);
231
234
  return overflowA - overflowB;
@@ -273,5 +276,4 @@ function position(attrs) {
273
276
  };
274
277
  }
275
278
 
276
- export default position;
277
- export { maxHeightForDirection, positionPropKeys };
279
+ export { position as default, maxHeightForDirection, positionPropKeys };
@@ -1,4 +1,4 @@
1
- import { _ as _defineProperty, a as _objectWithoutProperties, b as _extends, c as _objectSpread2 } from '../_helpers/_rollupPluginBabelHelpers.js';
1
+ import { _ as _defineProperty, a as _extends } from '../_helpers/_rollupPluginBabelHelpers.js';
2
2
  import React from 'react';
3
3
  import PropTypes from 'prop-types';
4
4
  import Popup from '../popup/popup.js';
@@ -30,16 +30,20 @@ import '../list/list__link.js';
30
30
  import '../link/link.js';
31
31
  import 'focus-visible';
32
32
  import '../link/clickableLink.js';
33
+ import '../_helpers/link.js';
33
34
  import '../_helpers/list.js';
34
35
  import '../list/list__item.js';
35
36
  import '../avatar/avatar.js';
36
37
  import '../global/url.js';
38
+ import '../avatar/fallback-avatar.js';
37
39
  import '../checkbox/checkbox.js';
38
40
  import '@jetbrains/icons/checkmark';
39
41
  import '@jetbrains/icons/remove-10px';
40
42
  import '../icon/icon.js';
41
43
  import '../icon/icon__constants.js';
42
- import '../_helpers/icon__svg.js';
44
+ import '../_helpers/icon.js';
45
+ import '../icon/icon__svg.js';
46
+ import '../_helpers/checkbox.js';
43
47
  import '../list/list__custom.js';
44
48
  import '../global/get-event-key.js';
45
49
  import '../list/list__title.js';
@@ -47,16 +51,17 @@ import '../list/list__separator.js';
47
51
  import '../list/list__hint.js';
48
52
  import '../list/consts.js';
49
53
 
50
- const _ref = Popup.propTypes || {},
51
- popupPropTypes = _objectWithoutProperties(_ref, ["children"]);
54
+ const {
55
+ children,
56
+ ...popupPropTypes
57
+ } = Popup.propTypes || {};
52
58
  /**
53
59
  * @name Popup Menu
54
60
  */
55
61
 
56
-
57
62
  class PopupMenu extends Popup {
58
- constructor(...args) {
59
- super(...args);
63
+ constructor() {
64
+ super(...arguments);
60
65
 
61
66
  _defineProperty(this, "onSelect", (item, event) => {
62
67
  if (this.props.closeOnSelect) {
@@ -73,9 +78,10 @@ class PopupMenu extends Popup {
73
78
 
74
79
  /** @override */
75
80
  getInternalContent() {
76
- const _this$props = this.props,
77
- props = _objectWithoutProperties(_this$props, ["className"]);
78
-
81
+ const {
82
+ className,
83
+ ...props
84
+ } = this.props;
79
85
  return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(List, _extends({
80
86
  ref: this.listRef
81
87
  }, props, {
@@ -91,18 +97,19 @@ _defineProperty(PopupMenu, "isItemType", List.isItemType);
91
97
 
92
98
  _defineProperty(PopupMenu, "ListProps", List.ListProps);
93
99
 
94
- _defineProperty(PopupMenu, "propTypes", _objectSpread2(_objectSpread2(_objectSpread2({}, popupPropTypes), List.propTypes), {}, {
100
+ _defineProperty(PopupMenu, "propTypes", { ...popupPropTypes,
101
+ ...List.propTypes,
95
102
  closeOnSelect: PropTypes.bool
96
- }));
103
+ });
97
104
 
98
- _defineProperty(PopupMenu, "defaultProps", _objectSpread2(_objectSpread2(_objectSpread2({}, List.defaultProps), Popup.defaultProps), {}, {
105
+ _defineProperty(PopupMenu, "defaultProps", { ...List.defaultProps,
106
+ ...Popup.defaultProps,
99
107
  renderOptimization: false,
100
108
  closeOnSelect: false
101
- }));
109
+ });
102
110
 
103
111
  const {
104
112
  ListProps
105
113
  } = List;
106
114
 
107
- export default PopupMenu;
108
- export { ListProps };
115
+ export { ListProps, PopupMenu as default };
@@ -1,18 +1,18 @@
1
- import { _ as _defineProperty, a as _objectWithoutProperties, 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 Theme from '../global/theme.js';
6
6
 
7
- var modules_fb7af416 = {"unit":"8px","light":"progressBar_light__9afa5539","progressBar":"progressBar_progressBar__9afa5539","dark":"progressBar_dark__9afa5539","line":"progressBar_line__9afa5539","globalMode":"progressBar_globalMode__9afa5539","progress-bar":"progressBar_progressBar__9afa5539"};
7
+ var modules_fb7af416 = {"unit":"8px","light":"light_rui_320b","progressBar":"progressBar_rui_320b","dark":"dark_rui_320b","line":"line_rui_320b","globalMode":"globalMode_rui_320b","progress-bar":"progressBar_rui_320b"};
8
8
 
9
9
  /**
10
10
  * @name Progress Bar
11
11
  */
12
12
 
13
13
  class ProgressBar extends PureComponent {
14
- constructor(...args) {
15
- super(...args);
14
+ constructor() {
15
+ super(...arguments);
16
16
 
17
17
  _defineProperty(this, "progressbarWrapperRef", el => {
18
18
  this.progressbarWrapper = el;
@@ -36,16 +36,15 @@ class ProgressBar extends PureComponent {
36
36
  }
37
37
 
38
38
  render() {
39
- const _this$props = this.props,
40
- {
39
+ const {
41
40
  theme,
42
41
  className,
43
42
  global,
44
43
  max,
45
- value
46
- } = _this$props,
47
- otherProps = _objectWithoutProperties(_this$props, ["theme", "className", "global", "max", "value"]);
48
-
44
+ value,
45
+ label,
46
+ ...otherProps
47
+ } = this.props;
49
48
  const width = value ? `${ProgressBar.toPercent(value, max)}%` : null;
50
49
  const classes = classNames(modules_fb7af416.progressBar, className, {
51
50
  [modules_fb7af416.light]: theme === Theme.LIGHT,
@@ -59,6 +58,7 @@ class ProgressBar extends PureComponent {
59
58
  className: modules_fb7af416.line,
60
59
  ref: this.progressbarRef,
61
60
  role: "progressbar",
61
+ "aria-label": label,
62
62
  "aria-valuenow": value,
63
63
  "aria-valuemin": 0,
64
64
  "aria-valuemax": max,
@@ -71,6 +71,7 @@ class ProgressBar extends PureComponent {
71
71
  }
72
72
 
73
73
  _defineProperty(ProgressBar, "propTypes", {
74
+ label: PropTypes.string,
74
75
  theme: PropTypes.string,
75
76
 
76
77
  /**
@@ -105,7 +106,8 @@ _defineProperty(ProgressBar, "propTypes", {
105
106
  _defineProperty(ProgressBar, "defaultProps", {
106
107
  max: 1.0,
107
108
  value: 0,
108
- theme: Theme.LIGHT
109
+ theme: Theme.LIGHT,
110
+ label: 'Progress'
109
111
  });
110
112
 
111
- export default ProgressBar;
113
+ export { ProgressBar as default };
@@ -0,0 +1,15 @@
1
+ import angularComponentFactory from '../global/angular-component-factory.js';
2
+ import ProgressBar from '../progress-bar/progress-bar.js';
3
+ import '../_helpers/_rollupPluginBabelHelpers.js';
4
+ import 'angular';
5
+ import 'react';
6
+ import 'react-dom';
7
+ import '../global/ring-angular-component.js';
8
+ import '../global/react-dom-renderer.js';
9
+ import 'prop-types';
10
+ import 'classnames';
11
+ import '../global/theme.js';
12
+
13
+ var progressBarNg = angularComponentFactory(ProgressBar, 'ProgressBar').name;
14
+
15
+ export { progressBarNg as default };
@@ -0,0 +1,126 @@
1
+ import { _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
2
+ import angular from 'angular';
3
+ import { m as modules_e81895c9 } from '../_helpers/button__classes.js';
4
+ import { applyMethodToClasses } from '../global/dom.js';
5
+ import RingAngularComponent from '../global/ring-angular-component.js';
6
+ import { LOADER_BACKGROUND_SELECTOR } from '../button-ng/button-ng.js';
7
+ import 'classnames';
8
+ import '../global/theme.js';
9
+ import 'react';
10
+ import '../icon-ng/icon-ng.js';
11
+ import '../icon/icon__constants.js';
12
+ import '../template-ng/template-ng.js';
13
+ import '../_helpers/icon.js';
14
+
15
+ /**
16
+ * @name Promised Click Ng
17
+ */
18
+
19
+ const angularModule = angular.module('Ring.promised-click', []);
20
+ const DEFAULT_MODE = 'active';
21
+
22
+ class PromisedClickController extends RingAngularComponent {
23
+ constructor() {
24
+ super(...arguments);
25
+ const {
26
+ $scope,
27
+ $element,
28
+ $attrs,
29
+ $parse
30
+ } = this.$inject;
31
+ this.element = $element[0];
32
+ this.active = false;
33
+
34
+ if ($attrs.rgPromisedClick) {
35
+ this.onClick(e => $parse($attrs.rgPromisedClick)($scope, {
36
+ event: e
37
+ }));
38
+ }
39
+
40
+ let currentMode = null;
41
+
42
+ this.toggleActive = enable => {
43
+ if (currentMode === 'loader') {
44
+ applyMethodToClasses(enable ? 'add' : 'remove')(this.element.classList, modules_e81895c9.loader);
45
+ const loaderNode = this.element.querySelector(LOADER_BACKGROUND_SELECTOR);
46
+
47
+ if (loaderNode) {
48
+ applyMethodToClasses(enable ? 'add' : 'remove')(this.element.querySelector(LOADER_BACKGROUND_SELECTOR).classList, modules_e81895c9.loaderBackground);
49
+ }
50
+ } else if (currentMode === 'active') {
51
+ applyMethodToClasses(enable ? 'add' : 'remove')(this.element.classList, modules_e81895c9.active);
52
+ }
53
+ };
54
+
55
+ const setModeParams = mode => {
56
+ currentMode = mode;
57
+ };
58
+
59
+ setModeParams($attrs.promisedMode || DEFAULT_MODE);
60
+
61
+ if ($attrs.promisedMode && $attrs.promisedMode.indexOf('{{') !== -1) {
62
+ $attrs.$observe('promisedMode', newMode => {
63
+ if (newMode !== currentMode) {
64
+ this.toggleActive(false);
65
+ setModeParams(newMode);
66
+ }
67
+ });
68
+ }
69
+ }
70
+
71
+ onClick(callback) {
72
+ this.element.addEventListener('click', e => {
73
+ if (this.active) {
74
+ e.preventDefault();
75
+ } else {
76
+ this.process(callback, e);
77
+ }
78
+ });
79
+ }
80
+
81
+ process(callback, e) {
82
+ const {
83
+ $scope
84
+ } = this.$inject;
85
+ this.promise = callback(e);
86
+
87
+ if (this.promise) {
88
+ this.activate();
89
+ } // Do not use $evalAsync here. This code should be invoked in the same animation frame
90
+ // otherwise a button may be "pressed" twice – by click and with class change.
91
+
92
+
93
+ if (!$scope.$root.$$phase) {
94
+ // eslint-disable-line angular/no-private-call
95
+ $scope.$apply();
96
+ }
97
+ }
98
+
99
+ activate() {
100
+ this.active = true;
101
+ this.toggleActive(true);
102
+
103
+ const done = () => {
104
+ this.active = false;
105
+ this.toggleActive(false);
106
+ };
107
+
108
+ this.promise.then(done, done);
109
+ }
110
+
111
+ }
112
+
113
+ PromisedClickController.$inject = [];
114
+
115
+ _defineProperty(PromisedClickController, "$inject", ['$scope', '$element', '$attrs', '$parse']);
116
+
117
+ function rgPromisedClickDirective() {
118
+ return {
119
+ controller: PromisedClickController
120
+ };
121
+ }
122
+
123
+ angularModule.directive('rgPromisedClick', rgPromisedClickDirective);
124
+ var PromisedClick = angularModule.name;
125
+
126
+ export { PromisedClick as default };
@@ -16,4 +16,4 @@ function proxyAttrs(template, attrsWhitelist) {
16
16
  };
17
17
  }
18
18
 
19
- export default proxyAttrs;
19
+ export { proxyAttrs as default };