@jetbrains/ring-ui 4.1.0-beta.9 → 4.1.4

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 (438) 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 +1 -1
  10. package/components/auth/auth.test.js +14 -7
  11. package/components/auth/auth__core.js +64 -33
  12. package/components/auth-dialog/auth-dialog.js +1 -0
  13. package/components/avatar/avatar.css +4 -1
  14. package/components/avatar/avatar.examples.js +3 -2
  15. package/components/avatar/avatar.js +31 -6
  16. package/components/avatar/fallback-avatar.js +136 -0
  17. package/components/avatar-editor-ng/avatar-editor-ng.css +2 -2
  18. package/components/avatar-editor-ng/avatar-editor-ng.js +2 -1
  19. package/components/avatar-editor-ng/{avatar-editor-ng.html → avatar-editor-ng__template.js} +2 -2
  20. package/components/button/button.css +2 -2
  21. package/components/button/button.js +4 -1
  22. package/components/button-group/button-group.js +1 -1
  23. package/components/button-group/caption.js +1 -1
  24. package/components/button-ng/button-ng.js +1 -1
  25. package/components/button-set-ng/button-set-ng.js +3 -1
  26. package/components/checkbox/checkbox.css +1 -1
  27. package/components/code/code.js +1 -1
  28. package/components/confirm/confirm.js +1 -0
  29. package/components/confirm-service/confirm-service.js +5 -5
  30. package/components/content-layout/content-layout.css +1 -1
  31. package/components/data-list/data-list.css +1 -1
  32. package/components/date-picker/date-input.js +5 -4
  33. package/components/date-picker/date-picker.css +34 -22
  34. package/components/date-picker/date-picker.examples.js +1 -1
  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 +5 -2
  42. package/components/dialog/dialog.test.js +1 -1
  43. package/components/dialog/dialog__body-scroll-preventer.js +2 -2
  44. package/components/dialog-ng/dialog-ng.js +7 -8
  45. package/components/dialog-ng/{dialog-ng.html → dialog-ng__template.js} +2 -2
  46. package/components/dropdown/anchor.js +1 -0
  47. package/components/dropdown/dropdown.examples.js +36 -1
  48. package/components/dropdown-menu/dropdown-menu.examples.js +47 -0
  49. package/components/dropdown-menu/dropdown-menu.js +117 -0
  50. package/components/dropdown-menu/dropdown-menu.test.js +76 -0
  51. package/components/error-bubble/error-bubble-legacy.css +1 -1
  52. package/components/error-bubble/error-bubble.css +1 -1
  53. package/components/error-bubble/error-bubble.examples.js +1 -1
  54. package/components/error-page/error-page.css +2 -2
  55. package/components/footer-ng/footer-ng.js +13 -3
  56. package/components/form/form.css +2 -2
  57. package/components/form-ng/form-ng.js +3 -1
  58. package/components/global/global.css +1 -1
  59. package/components/global/theme.js +1 -1
  60. package/components/global/variables.css +8 -1
  61. package/components/grid/grid.css +10 -9
  62. package/components/header/header.css +1 -1
  63. package/components/header/header.examples.js +7 -8
  64. package/components/header/profile.js +10 -11
  65. package/components/http/http.js +1 -1
  66. package/components/icon/icon.css +5 -4
  67. package/components/island/island.css +4 -3
  68. package/components/island-legacy/island-legacy.css +3 -1
  69. package/components/list/list.js +6 -1
  70. package/components/list/list__custom.js +9 -3
  71. package/components/list/list__item.js +8 -2
  72. package/components/list/list__link.js +2 -1
  73. package/components/loader-inline/loader-inline.css +1 -1
  74. package/components/loader-screen/loader-screen.css +1 -1
  75. package/components/message/message.css +1 -1
  76. package/components/message/message.examples.js +8 -5
  77. package/components/pager/pager.js +5 -3
  78. package/components/permissions/permissions.js +1 -1
  79. package/components/progress-bar/progress-bar.css +1 -1
  80. package/components/progress-bar/progress-bar.examples.js +3 -3
  81. package/components/progress-bar/progress-bar.js +5 -2
  82. package/components/progress-bar/progress-bar.test.js +12 -13
  83. package/components/progress-bar-ng/progress-bar-ng.examples.js +3 -3
  84. package/components/query-assist/query-assist.css +13 -3
  85. package/components/query-assist/query-assist.examples.js +3 -1
  86. package/components/query-assist/query-assist.js +56 -12
  87. package/components/query-assist/query-assist.test.js +37 -5
  88. package/components/save-field-ng/save-field-ng.css +0 -3
  89. package/components/save-field-ng/save-field-ng.js +3 -1
  90. package/components/save-field-ng/{save-field-ng.html → save-field-ng__template.js} +2 -2
  91. package/components/select/select.css +12 -7
  92. package/components/select/select.examples.js +13 -0
  93. package/components/select/select.js +30 -43
  94. package/components/select/select.test.js +4 -5
  95. package/components/shortcuts-hint-ng/shortcuts-hint-ng.css +1 -1
  96. package/components/shortcuts-hint-ng/shortcuts-hint-ng.js +1 -1
  97. package/components/shortcuts-hint-ng/{shortcuts-hint-ng.html → shortcuts-hint-ng__template.js} +2 -2
  98. package/components/sidebar/sidebar.css +1 -0
  99. package/components/sidebar-ng/sidebar-ng.js +6 -2
  100. package/components/sidebar-ng/{sidebar-ng__button.html → sidebar-ng__button-template.js} +2 -2
  101. package/components/sidebar-ng/{sidebar-ng.html → sidebar-ng__template.js} +2 -2
  102. package/components/table/row.js +2 -1
  103. package/components/table/table.css +2 -1
  104. package/components/table-legacy/table-legacy.css +2 -2
  105. package/components/table-legacy/table-legacy__toolbar.css +2 -2
  106. package/components/table-legacy-ng/table-legacy-ng.js +38 -5
  107. package/components/table-legacy-ng/table-legacy-ng__pager.js +7 -1
  108. package/components/tabs/collapsible-tab.js +2 -2
  109. package/components/tabs/collapsible-tabs.js +4 -8
  110. package/components/tabs/dumb-tabs.js +1 -0
  111. package/components/tabs/tab-link.js +4 -2
  112. package/components/tabs/tabs.css +27 -0
  113. package/components/tabs-ng/tabs-ng.js +4 -2
  114. package/components/tabs-ng/{tabs-ng.html → tabs-ng__template.js} +6 -2
  115. package/components/tag/tag.css +5 -2
  116. package/components/tag/tag.examples.js +3 -0
  117. package/components/tag/tag.js +19 -16
  118. package/components/tags-input/tag-input.examples.js +1 -1
  119. package/components/tags-input/tags-input.js +5 -2
  120. package/components/template-ng/template-ng.js +1 -1
  121. package/components/tooltip/tooltip.js +7 -2
  122. package/components/user-agreement/user-agreement.css +1 -1
  123. package/components/user-agreement/user-agreement.examples.js +7 -4
  124. package/components/user-agreement/user-agreement.js +1 -0
  125. package/dist/_helpers/_rollupPluginBabelHelpers.js +1 -94
  126. package/dist/_helpers/anchor.js +6 -6
  127. package/dist/_helpers/badge.js +1 -1
  128. package/dist/_helpers/button-group.js +3 -0
  129. package/dist/_helpers/button-set.js +3 -0
  130. package/dist/_helpers/button-toolbar.js +3 -0
  131. package/dist/_helpers/button__classes.js +1 -1
  132. package/dist/_helpers/card.js +6 -8
  133. package/dist/_helpers/checkbox.js +3 -0
  134. package/dist/_helpers/date-picker.js +1 -1
  135. package/dist/_helpers/dialog__body-scroll-preventer.js +3 -2
  136. package/dist/_helpers/error-message.js +3 -0
  137. package/dist/_helpers/footer.js +121 -0
  138. package/dist/_helpers/grid.js +1 -1
  139. package/dist/_helpers/group.js +3 -0
  140. package/dist/_helpers/header.js +1 -1
  141. package/dist/_helpers/icon.js +3 -0
  142. package/dist/_helpers/inject-styles.js +1 -1
  143. package/dist/_helpers/input.js +3 -0
  144. package/dist/_helpers/island.js +1 -1
  145. package/dist/_helpers/link.js +3 -0
  146. package/dist/_helpers/list.js +1 -1
  147. package/dist/_helpers/loader-screen.js +3 -0
  148. package/dist/_helpers/panel.js +3 -0
  149. package/dist/_helpers/query-assist__suggestions.js +1 -1
  150. package/dist/_helpers/radio.js +3 -0
  151. package/dist/_helpers/select__filter.js +6 -8
  152. package/dist/_helpers/services-link.js +6 -8
  153. package/dist/_helpers/sidebar.js +6 -8
  154. package/dist/_helpers/table.js +1 -1
  155. package/dist/_helpers/tabs.js +1 -1
  156. package/dist/_helpers/title.js +1 -1
  157. package/dist/alert/alert.js +15 -9
  158. package/dist/alert/container.js +7 -9
  159. package/dist/alert-service/alert-service.js +24 -13
  160. package/dist/analytics/analytics.js +2 -2
  161. package/dist/analytics/analytics__custom-plugin.js +1 -1
  162. package/dist/analytics/analytics__fus-plugin.js +2 -2
  163. package/dist/analytics/analytics__ga-plugin.js +1 -1
  164. package/dist/analytics/analytics__plugin-utils.js +1 -1
  165. package/dist/analytics-ng/analytics-ng.js +94 -0
  166. package/dist/auth/auth.js +7 -4
  167. package/dist/auth/auth__core.js +86 -48
  168. package/dist/auth/background-flow.js +1 -2
  169. package/dist/auth/down-notification.js +6 -3
  170. package/dist/auth/iframe-flow.js +5 -2
  171. package/dist/auth/landing-entry.js +1 -1
  172. package/dist/auth/landing.js +5 -2
  173. package/dist/auth/request-builder.js +1 -1
  174. package/dist/auth/response-parser.js +1 -1
  175. package/dist/auth/storage.js +3 -2
  176. package/dist/auth/token-validator.js +1 -1
  177. package/dist/auth/window-flow.js +1 -1
  178. package/dist/auth-dialog/auth-dialog.js +5 -3
  179. package/dist/auth-dialog-service/auth-dialog-service.js +6 -5
  180. package/dist/auth-ng/auth-ng.js +203 -0
  181. package/dist/auth-ng/auth-ng.mock.js +33 -0
  182. package/dist/autofocus-ng/autofocus-ng.js +50 -0
  183. package/dist/avatar/avatar.js +36 -30
  184. package/dist/avatar/fallback-avatar.js +141 -0
  185. package/dist/avatar-editor-ng/avatar-editor-ng.js +164 -0
  186. package/dist/avatar-editor-ng/avatar-editor-ng__template.js +30 -0
  187. package/dist/avatar-ng/avatar-ng.js +18 -0
  188. package/dist/badge/badge.js +6 -8
  189. package/dist/badge-ng/badge-ng.js +16 -0
  190. package/dist/breadcrumb-ng/breadcrumb-ng.js +61 -0
  191. package/dist/button/button.js +16 -10
  192. package/dist/button-group/button-group.js +4 -4
  193. package/dist/button-group/caption.js +24 -5
  194. package/dist/button-group-ng/button-group-ng.js +38 -0
  195. package/dist/button-ng/button-ng.js +223 -0
  196. package/dist/button-set/button-set.js +3 -4
  197. package/dist/button-set-ng/button-set-ng.js +19 -0
  198. package/dist/button-toolbar/button-toolbar.js +3 -4
  199. package/dist/button-toolbar-ng/button-toolbar-ng.js +23 -0
  200. package/dist/caret/caret.js +1 -1
  201. package/dist/checkbox/checkbox.js +9 -11
  202. package/dist/checkbox-ng/checkbox-ng.js +55 -0
  203. package/dist/code/code.js +136 -0
  204. package/dist/compiler-ng/compiler-ng.js +53 -0
  205. package/dist/confirm/confirm.js +6 -3
  206. package/dist/confirm-ng/confirm-ng.js +66 -0
  207. package/dist/confirm-service/confirm-service.js +12 -10
  208. package/dist/content-layout/content-layout.js +6 -8
  209. package/dist/contenteditable/contenteditable.js +13 -16
  210. package/dist/data-list/data-list.js +10 -7
  211. package/dist/data-list/data-list.mock.js +2 -2
  212. package/dist/data-list/item.js +5 -3
  213. package/dist/data-list/selection.js +1 -1
  214. package/dist/data-list/title.js +3 -1
  215. package/dist/data-list-ng/data-list-ng.js +59 -0
  216. package/dist/date-picker/consts.js +1 -2
  217. package/dist/date-picker/date-input.js +10 -6
  218. package/dist/date-picker/date-picker.js +38 -29
  219. package/dist/date-picker/date-popup.js +51 -28
  220. package/dist/date-picker/day.js +2 -2
  221. package/dist/date-picker/formats.js +1 -1
  222. package/dist/date-picker/month-names.js +16 -9
  223. package/dist/date-picker/month-slider.js +2 -2
  224. package/dist/date-picker/month.js +13 -7
  225. package/dist/date-picker/months.js +3 -3
  226. package/dist/date-picker/weekdays.js +12 -4
  227. package/dist/date-picker/years.js +2 -2
  228. package/dist/dialog/dialog.js +13 -10
  229. package/dist/dialog/dialog__body-scroll-preventer.js +1 -1
  230. package/dist/dialog-ng/dialog-ng.js +601 -0
  231. package/dist/dialog-ng/dialog-ng__template.js +71 -0
  232. package/dist/docked-panel-ng/docked-panel-ng.js +170 -0
  233. package/dist/dropdown/anchor.js +2 -1
  234. package/dist/dropdown/dropdown.js +8 -10
  235. package/dist/dropdown-menu/dropdown-menu.js +175 -0
  236. package/dist/error-bubble/error-bubble.js +7 -9
  237. package/dist/error-message/error-message.js +4 -4
  238. package/dist/error-message-ng/error-message-ng.js +53 -0
  239. package/dist/footer/footer.js +6 -122
  240. package/dist/footer-ng/footer-ng.js +75 -0
  241. package/dist/form-ng/form-ng.js +169 -0
  242. package/dist/global/angular-component-factory.js +1 -2
  243. package/dist/global/compose.js +1 -1
  244. package/dist/global/composeRefs.js +1 -1
  245. package/dist/global/conic-gradient.js +3 -5
  246. package/dist/global/create-stateful-context.js +1 -1
  247. package/dist/global/data-tests.js +1 -1
  248. package/dist/global/focus-sensor-hoc.js +9 -11
  249. package/dist/global/fuzzy-highlight.js +1 -1
  250. package/dist/global/get-event-key.js +1 -1
  251. package/dist/global/get-uid.js +1 -1
  252. package/dist/global/linear-function.js +1 -2
  253. package/dist/global/listeners.js +1 -1
  254. package/dist/global/memoize.js +1 -1
  255. package/dist/global/normalize-indent.js +1 -1
  256. package/dist/global/promise-with-timeout.js +1 -1
  257. package/dist/global/radial-gradient-mask.js +1 -1
  258. package/dist/global/react-dom-renderer.js +1 -1
  259. package/dist/global/rerender-hoc.js +3 -5
  260. package/dist/global/ring-angular-component.js +1 -1
  261. package/dist/global/schedule-raf.js +1 -1
  262. package/dist/global/sniffer.js +1 -1
  263. package/dist/global/supports-css.js +1 -1
  264. package/dist/global/theme.js +6 -8
  265. package/dist/global/trivial-template-tag.js +1 -1
  266. package/dist/global/variables_dark.js +1 -1
  267. package/dist/grid/col.js +6 -8
  268. package/dist/grid/grid.js +5 -7
  269. package/dist/grid/row.js +6 -8
  270. package/dist/group/group.js +7 -10
  271. package/dist/group-ng/group-ng.js +11 -0
  272. package/dist/header/header.js +29 -26
  273. package/dist/header/logo.js +8 -9
  274. package/dist/header/profile.js +37 -32
  275. package/dist/header/services-link.js +1 -0
  276. package/dist/header/services.js +10 -9
  277. package/dist/header/smart-profile.js +27 -24
  278. package/dist/header/smart-services.js +10 -9
  279. package/dist/header/tray-icon.js +12 -12
  280. package/dist/header/tray.js +6 -8
  281. package/dist/heading/heading.js +9 -12
  282. package/dist/http/http.js +37 -37
  283. package/dist/http/http.mock.js +4 -4
  284. package/dist/hub-source/hub-source.js +1 -1
  285. package/dist/hub-source/hub-source__users-groups.js +1 -1
  286. package/dist/icon/icon.js +8 -8
  287. package/dist/icon/icon__svg.js +81 -6
  288. package/dist/icon/index.js +2 -1
  289. package/dist/icon-ng/icon-ng.js +89 -0
  290. package/dist/input/input.js +9 -12
  291. package/dist/input-ng/input-ng.js +166 -0
  292. package/dist/island/adaptive-island-hoc.js +1 -2
  293. package/dist/island/content.js +6 -8
  294. package/dist/island/header.js +6 -8
  295. package/dist/island/island.js +6 -9
  296. package/dist/island-legacy/content-legacy.js +6 -8
  297. package/dist/island-legacy/header-legacy.js +6 -8
  298. package/dist/island-legacy/island-legacy.js +6 -8
  299. package/dist/island-ng/island-content-ng.js +56 -0
  300. package/dist/island-ng/island-header-ng.js +32 -0
  301. package/dist/island-ng/island-ng-class-fixer.js +9 -0
  302. package/dist/island-ng/island-ng.js +31 -0
  303. package/dist/link/clickableLink.js +6 -8
  304. package/dist/link/link.js +7 -11
  305. package/dist/link-ng/link-ng.js +25 -0
  306. package/dist/list/list.js +25 -13
  307. package/dist/list/list__custom.js +13 -10
  308. package/dist/list/list__hint.js +1 -1
  309. package/dist/list/list__item.js +20 -13
  310. package/dist/list/list__link.js +11 -12
  311. package/dist/list/list__separator.js +1 -1
  312. package/dist/list/list__title.js +1 -1
  313. package/dist/list/list__users-groups-source.js +11 -7
  314. package/dist/loader/loader.js +6 -8
  315. package/dist/loader/loader__core.js +2 -2
  316. package/dist/loader-inline/inject-styles.js +1 -1
  317. package/dist/loader-inline/loader-inline.js +6 -8
  318. package/dist/loader-inline-ng/loader-inline-ng.js +42 -0
  319. package/dist/loader-ng/loader-ng.js +43 -0
  320. package/dist/loader-screen/loader-screen.js +7 -10
  321. package/dist/loader-screen-ng/loader-screen-ng.js +99 -0
  322. package/dist/login-dialog/login-dialog.js +5 -3
  323. package/dist/login-dialog/service.js +7 -5
  324. package/dist/markdown/code.js +30 -0
  325. package/dist/markdown/heading.js +23 -0
  326. package/dist/markdown/link.js +30 -0
  327. package/dist/markdown/markdown.js +73 -0
  328. package/dist/message/message.js +5 -4
  329. package/dist/message-bundle-ng/message-bundle-ng.js +111 -0
  330. package/dist/old-browsers-message/old-browsers-message.js +0 -1
  331. package/dist/old-browsers-message/old-browsers-message__stop.js +0 -1
  332. package/dist/old-browsers-message/white-list.js +4 -5
  333. package/dist/pager/pager.js +18 -9
  334. package/dist/pager-ng/pager-ng.js +96 -0
  335. package/dist/panel/panel.js +7 -10
  336. package/dist/panel-ng/panel-ng.js +16 -0
  337. package/dist/permissions/permissions.js +1 -1
  338. package/dist/permissions/permissions__cache.js +1 -1
  339. package/dist/permissions-ng/permissions-ng.js +274 -0
  340. package/dist/place-under-ng/place-under-ng.js +157 -0
  341. package/dist/popup/popup.js +8 -8
  342. package/dist/popup/popup.target.js +4 -5
  343. package/dist/popup/position.js +1 -2
  344. package/dist/popup-menu/popup-menu.js +21 -14
  345. package/dist/progress-bar/progress-bar.js +12 -10
  346. package/dist/progress-bar-ng/progress-bar-ng.js +15 -0
  347. package/dist/promised-click-ng/promised-click-ng.js +126 -0
  348. package/dist/proxy-attrs/proxy-attrs.js +1 -1
  349. package/dist/query-assist/query-assist.js +97 -28
  350. package/dist/query-assist/query-assist__suggestions.js +5 -1
  351. package/dist/query-assist-ng/query-assist-ng.js +82 -0
  352. package/dist/radio/radio.js +7 -5
  353. package/dist/radio/radio__item.js +10 -15
  354. package/dist/radio-ng/radio-ng.js +63 -0
  355. package/dist/save-field-ng/save-field-ng.js +335 -0
  356. package/dist/save-field-ng/save-field-ng__template.js +34 -0
  357. package/dist/select/select.js +50 -49
  358. package/dist/select/select__filter.js +6 -1
  359. package/dist/select/select__popup.js +8 -3
  360. package/dist/select-ng/select-ng.js +621 -0
  361. package/dist/select-ng/select-ng__lazy.js +150 -0
  362. package/dist/select-ng/select-ng__options.js +145 -0
  363. package/dist/shortcuts/core.js +2 -2
  364. package/dist/shortcuts/shortcuts-hoc.js +6 -8
  365. package/dist/shortcuts/shortcuts.js +6 -6
  366. package/dist/shortcuts-hint-ng/shortcuts-hint-ng.js +120 -0
  367. package/dist/shortcuts-hint-ng/shortcuts-hint-ng__template.js +50 -0
  368. package/dist/shortcuts-ng/shortcuts-ng.js +261 -0
  369. package/dist/sidebar-ng/sidebar-ng.js +111 -0
  370. package/dist/sidebar-ng/sidebar-ng__button-template.js +20 -0
  371. package/dist/sidebar-ng/sidebar-ng__template.js +12 -0
  372. package/dist/storage/storage.js +3 -2
  373. package/dist/storage/storage__fallback.js +1 -1
  374. package/dist/storage/storage__local.js +3 -2
  375. package/dist/style.css +1 -1
  376. package/dist/tab-trap/tab-trap.js +7 -9
  377. package/dist/table/cell.js +2 -2
  378. package/dist/table/disable-hover-hoc.js +2 -2
  379. package/dist/table/header-cell.js +8 -9
  380. package/dist/table/header.js +5 -3
  381. package/dist/table/multitable.js +1 -1
  382. package/dist/table/row-with-focus-sensor.js +5 -3
  383. package/dist/table/row.js +11 -10
  384. package/dist/table/selection-adapter.js +1 -1
  385. package/dist/table/selection-shortcuts-hoc.js +8 -6
  386. package/dist/table/selection.js +1 -1
  387. package/dist/table/smart-table.js +14 -8
  388. package/dist/table/table.js +10 -11
  389. package/dist/table-legacy-ng/table-legacy-ng.js +501 -0
  390. package/dist/table-legacy-ng/table-legacy-ng__pager.js +122 -0
  391. package/dist/table-legacy-ng/table-legacy-ng__selection-navigate-actions.js +123 -0
  392. package/dist/table-legacy-ng/table-legacy-ng__selection.js +179 -0
  393. package/dist/table-legacy-ng/table-legacy-ng__toolbar.js +56 -0
  394. package/dist/table-ng/smart-table-ng.js +65 -0
  395. package/dist/table-ng/table-ng.js +64 -0
  396. package/dist/tabs/collapsible-more.js +9 -6
  397. package/dist/tabs/collapsible-tab.js +7 -7
  398. package/dist/tabs/collapsible-tabs.js +18 -19
  399. package/dist/tabs/dumb-tabs.js +12 -9
  400. package/dist/tabs/smart-tabs.js +11 -9
  401. package/dist/tabs/tab-link.js +13 -7
  402. package/dist/tabs/tab.js +1 -1
  403. package/dist/tabs/tabs.js +5 -1
  404. package/dist/tabs-ng/tabs-ng.js +193 -0
  405. package/dist/tabs-ng/tabs-ng__template.js +40 -0
  406. package/dist/tag/tag.js +20 -14
  407. package/dist/tags-input/tags-input.js +14 -10
  408. package/dist/tags-input-ng/tags-input-ng.js +89 -0
  409. package/dist/tags-list/tags-list.js +8 -9
  410. package/dist/template-ng/template-ng.js +70 -0
  411. package/dist/text/text.js +7 -9
  412. package/dist/theme-ng/theme-ng.js +44 -0
  413. package/dist/title-ng/title-ng.js +114 -0
  414. package/dist/toggle/toggle.js +8 -11
  415. package/dist/toggle-ng/toggle-ng.js +16 -0
  416. package/dist/tooltip/tooltip.js +14 -12
  417. package/dist/tooltip-ng/tooltip-ng.js +98 -0
  418. package/dist/user-agreement/service.js +409 -0
  419. package/dist/user-agreement/toolbox.eula.js +162 -0
  420. package/dist/user-agreement/user-agreement.js +167 -0
  421. package/dist/user-card/card.js +3 -0
  422. package/dist/user-card/smart-user-card-tooltip.js +14 -14
  423. package/dist/user-card/tooltip.js +9 -7
  424. package/dist/user-card/user-card.js +5 -2
  425. package/dist/user-card-ng/user-card-ng.js +59 -0
  426. package/package.json +81 -79
  427. package/webpack.config.js +14 -10
  428. package/components/button-set-ng/button-set-ng.html +0 -1
  429. package/components/footer-ng/footer-ng.html +0 -13
  430. package/components/form-ng/form-ng__error-bubble.html +0 -3
  431. package/components/table-legacy-ng/table-legacy-ng.html +0 -4
  432. package/components/table-legacy-ng/table-legacy-ng__column.html +0 -12
  433. package/components/table-legacy-ng/table-legacy-ng__header.html +0 -4
  434. package/components/table-legacy-ng/table-legacy-ng__pager.html +0 -7
  435. package/components/table-legacy-ng/table-legacy-ng__row.html +0 -12
  436. package/components/table-legacy-ng/table-legacy-ng__title.html +0 -9
  437. package/dist/_helpers/caption.js +0 -25
  438. package/dist/_helpers/icon__svg.js +0 -83
@@ -0,0 +1,89 @@
1
+ import angularComponentFactory from '../global/angular-component-factory.js';
2
+ import TagsInput from '../tags-input/tags-input.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/get-event-key.js';
12
+ import '../select/select.js';
13
+ import '@jetbrains/icons/chevron-10px';
14
+ import '@jetbrains/icons/close';
15
+ import 'deep-equal';
16
+ import '../dropdown/dropdown.js';
17
+ import '../global/data-tests.js';
18
+ import '../_helpers/anchor.js';
19
+ import '../icon/icon.js';
20
+ import 'util-deprecate';
21
+ import '../icon/icon__constants.js';
22
+ import '../_helpers/icon.js';
23
+ import '../icon/icon__svg.js';
24
+ import '../global/memoize.js';
25
+ import '../button/button.js';
26
+ import 'focus-visible';
27
+ import '../global/theme.js';
28
+ import '../link/clickableLink.js';
29
+ import '../_helpers/button__classes.js';
30
+ import '../avatar/avatar.js';
31
+ import '../global/url.js';
32
+ import '../global/dom.js';
33
+ import '../avatar/fallback-avatar.js';
34
+ import '../global/get-uid.js';
35
+ import '../popup/popup.js';
36
+ import '../global/schedule-raf.js';
37
+ import '../shortcuts/shortcuts.js';
38
+ import '../shortcuts/core.js';
39
+ import 'combokeys';
40
+ import '../global/sniffer.js';
41
+ import 'sniffr';
42
+ import '../tab-trap/tab-trap.js';
43
+ import '../popup/position.js';
44
+ import '../popup/popup.consts.js';
45
+ import '../popup/popup.target.js';
46
+ import '../list/list.js';
47
+ import 'react-virtualized/dist/es/List';
48
+ import 'react-virtualized/dist/es/AutoSizer';
49
+ import 'react-virtualized/dist/es/WindowScroller';
50
+ import 'react-virtualized/dist/es/CellMeasurer';
51
+ import 'memoize-one';
52
+ import '../global/create-stateful-context.js';
53
+ import '../list/list__link.js';
54
+ import '../link/link.js';
55
+ import '../_helpers/link.js';
56
+ import '../_helpers/list.js';
57
+ import '../list/list__item.js';
58
+ import '../checkbox/checkbox.js';
59
+ import '@jetbrains/icons/checkmark';
60
+ import '@jetbrains/icons/remove-10px';
61
+ import '../_helpers/checkbox.js';
62
+ import '../list/list__custom.js';
63
+ import '../list/list__title.js';
64
+ import '../list/list__separator.js';
65
+ import '../list/list__hint.js';
66
+ import '../list/consts.js';
67
+ import '../input/input.js';
68
+ import '../_helpers/input.js';
69
+ import '../global/rerender-hoc.js';
70
+ import '../global/fuzzy-highlight.js';
71
+ import '../select/select__popup.js';
72
+ import '@jetbrains/icons/search';
73
+ import '../loader-inline/loader-inline.js';
74
+ import '../_helpers/inject-styles.js';
75
+ import '../global/conic-gradient.js';
76
+ import 'conic-gradient';
77
+ import '../global/supports-css.js';
78
+ import '../global/inject-styles.js';
79
+ import '../global/radial-gradient-mask.js';
80
+ import '../shortcuts/shortcuts-hoc.js';
81
+ import '../tags-list/tags-list.js';
82
+ import '../tag/tag.js';
83
+ import '../caret/caret.js';
84
+ import '../text/text.js';
85
+ import '../_helpers/select__filter.js';
86
+
87
+ var tagsInputNg = angularComponentFactory(TagsInput, 'TagsInput').name;
88
+
89
+ export { tagsInputNg as default };
@@ -1,4 +1,4 @@
1
- import { b as _extends, a as _objectWithoutProperties, _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
1
+ import { _ as _defineProperty, a as _extends } from '../_helpers/_rollupPluginBabelHelpers.js';
2
2
  import React, { Component } from 'react';
3
3
  import PropTypes from 'prop-types';
4
4
  import classNames from 'classnames';
@@ -7,7 +7,8 @@ import '@jetbrains/icons/close';
7
7
  import '../icon/icon.js';
8
8
  import 'util-deprecate';
9
9
  import '../icon/icon__constants.js';
10
- import '../_helpers/icon__svg.js';
10
+ import '../_helpers/icon.js';
11
+ import '../icon/icon__svg.js';
11
12
  import '../global/memoize.js';
12
13
  import '../button/button.js';
13
14
  import 'focus-visible';
@@ -40,8 +41,7 @@ class TagsList extends Component {
40
41
  }
41
42
 
42
43
  render() {
43
- const _this$props = this.props,
44
- {
44
+ const {
45
45
  children,
46
46
  className,
47
47
  customTagComponent,
@@ -50,10 +50,9 @@ class TagsList extends Component {
50
50
  tagClassName,
51
51
  handleRemove,
52
52
  tags,
53
- activeIndex
54
- } = _this$props,
55
- props = _objectWithoutProperties(_this$props, ["children", "className", "customTagComponent", "canNotBeEmpty", "handleClick", "tagClassName", "handleRemove", "tags", "activeIndex"]);
56
-
53
+ activeIndex,
54
+ ...props
55
+ } = this.props;
57
56
  const classes = classNames('ring-js-shortcuts', className);
58
57
  const tagsList = (this.props.tags || []).map((tag, index) => this.renderTag(tag, this.props.activeIndex === index));
59
58
  return /*#__PURE__*/React.createElement("div", _extends({
@@ -91,4 +90,4 @@ _defineProperty(TagsList, "defaultProps", {
91
90
  handleRemove: noop
92
91
  });
93
92
 
94
- export default TagsList;
93
+ export { TagsList as default };
@@ -0,0 +1,70 @@
1
+ import { _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
2
+ import angular from 'angular';
3
+ import RingAngularComponent from '../global/ring-angular-component.js';
4
+
5
+ /**
6
+ * @name Template Ng
7
+ */
8
+
9
+ const angularModule = angular.module('Ring.template', []);
10
+
11
+ class RgTemplateController extends RingAngularComponent {
12
+ constructor() {
13
+ super(...arguments);
14
+
15
+ _defineProperty(this, "currentScope", null);
16
+
17
+ _defineProperty(this, "render", template => {
18
+ const {
19
+ $scope,
20
+ $element,
21
+ $compile
22
+ } = this.$inject;
23
+ this.cleanup();
24
+ this.currentScope = $scope.$new();
25
+ this.currentScope.$evalAsync(() => {
26
+ $element.html(template);
27
+ this.addInnerClass();
28
+ $compile($element.contents())(this.currentScope);
29
+ });
30
+ });
31
+
32
+ _defineProperty(this, "addInnerClass", () => {
33
+ const {
34
+ rgTemplateClass
35
+ } = this.$inject.$attrs;
36
+
37
+ if (rgTemplateClass) {
38
+ this.$inject.$element.contents().addClass(rgTemplateClass);
39
+ }
40
+ });
41
+
42
+ const {
43
+ $scope: _$scope,
44
+ $attrs
45
+ } = this.$inject;
46
+
47
+ _$scope.$watch($attrs.rgTemplate || $attrs.template, this.render);
48
+ }
49
+
50
+ cleanup() {
51
+ if (this.currentScope) {
52
+ this.currentScope.$destroy();
53
+ this.currentScope = null;
54
+ }
55
+ }
56
+
57
+ }
58
+
59
+ RgTemplateController.$inject = [];
60
+
61
+ _defineProperty(RgTemplateController, "$inject", ['$scope', '$element', '$attrs', '$compile']);
62
+
63
+ angularModule.directive('rgTemplate', function rgTemplateDirective() {
64
+ return {
65
+ controller: RgTemplateController
66
+ };
67
+ });
68
+ var RingTemplateNg = angularModule.name;
69
+
70
+ export { RingTemplateNg as default };
package/dist/text/text.js CHANGED
@@ -1,9 +1,9 @@
1
- import { a as _objectWithoutProperties, b as _extends, _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
1
+ import { _ as _defineProperty, a as _extends } from '../_helpers/_rollupPluginBabelHelpers.js';
2
2
  import React, { Component } from 'react';
3
3
  import PropTypes from 'prop-types';
4
4
  import classNames from 'classnames';
5
5
 
6
- var modules_78d1bce6 = {"text":"text_text__bc47c17b","info":"text_info__bc47c17b"};
6
+ var modules_78d1bce6 = {"text":"text_rui_bc47","info":"info_rui_bc47"};
7
7
 
8
8
  /**
9
9
  * @name Text
@@ -11,14 +11,12 @@ var modules_78d1bce6 = {"text":"text_text__bc47c17b","info":"text_info__bc47c17b
11
11
 
12
12
  class Text extends Component {
13
13
  render() {
14
- const _this$props = this.props,
15
- {
14
+ const {
16
15
  children,
17
16
  className,
18
- info
19
- } = _this$props,
20
- restProps = _objectWithoutProperties(_this$props, ["children", "className", "info"]);
21
-
17
+ info,
18
+ ...restProps
19
+ } = this.props;
22
20
  const classes = classNames(modules_78d1bce6.text, className, {
23
21
  [modules_78d1bce6.info]: info
24
22
  });
@@ -35,4 +33,4 @@ _defineProperty(Text, "propTypes", {
35
33
  className: PropTypes.string
36
34
  });
37
35
 
38
- export default Text;
36
+ export { Text as default };
@@ -0,0 +1,44 @@
1
+ import { _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
2
+ import angular from 'angular';
3
+ import RingAngularComponent from '../global/ring-angular-component.js';
4
+
5
+ const angularModule = angular.module('Ring.theme', []);
6
+
7
+ class RingThemeComponent extends RingAngularComponent {
8
+ constructor() {
9
+ super(...arguments);
10
+
11
+ _defineProperty(this, "on", this.$inject.$scope.$on.bind(this.$inject.$scope));
12
+ }
13
+
14
+ $onInit() {
15
+ const {
16
+ $element
17
+ } = this.$inject;
18
+ $element[0].setAttribute('data-test', 'ring-theme');
19
+ }
20
+
21
+ $onChanges(changes) {
22
+ if (changes.theme && changes.theme.currentValue) {
23
+ const {
24
+ $scope
25
+ } = this.$inject;
26
+ $scope.$emit('change', {
27
+ prevTheme: typeof changes.theme.previousValue === 'string' && changes.theme.previousValue,
28
+ currentTheme: changes.theme.currentValue
29
+ });
30
+ }
31
+ }
32
+
33
+ }
34
+
35
+ _defineProperty(RingThemeComponent, "$inject", ['$scope', '$element']);
36
+
37
+ _defineProperty(RingThemeComponent, "bindings", {
38
+ theme: '<'
39
+ });
40
+
41
+ angularModule.component('rgTheme', RingThemeComponent);
42
+ var themeNg = angularModule.name;
43
+
44
+ export { themeNg as default };
@@ -0,0 +1,114 @@
1
+ import angular from 'angular';
2
+
3
+ const angularModule = angular.module('Ring.title', []);
4
+ angularModule.directive('rgPageTitle', function rgPageTitleDirective() {
5
+ return {
6
+ scope: {
7
+ rgPageTitle: '@?',
8
+ noTitle: '@?',
9
+ delimiter: '@'
10
+ },
11
+ controller: ["$rootScope", "$scope", "$element", "$attrs", "pageTitle", "$injector", function controller($rootScope, $scope, $element, $attrs, pageTitle, $injector) {
12
+ const element = $element[0]; // Get title prefix from title element
13
+
14
+ const elementText = element.textContent;
15
+ let offScopeWatch = angular.noop; // Set page title on route change
16
+
17
+ const offRouteWatch = $rootScope.$on('$routeChangeSuccess', (event, current) => {
18
+ //Do nothing if we're being redirected
19
+ if (current.$$route && current.$$route.redirectTo) {
20
+ // eslint-disable-line angular/no-private-call
21
+ return;
22
+ }
23
+
24
+ let routeTitle = current.$$route && current.$$route.title; // eslint-disable-line angular/no-private-call
25
+
26
+ pageTitle.setCurrent($scope.rgPageTitle || elementText); // Use title: false to prevent title change on route
27
+
28
+ if (routeTitle !== false) {
29
+ if (angular.isArray(routeTitle) || angular.isFunction(routeTitle)) {
30
+ //Invoke injector
31
+ routeTitle = $injector.invoke(routeTitle);
32
+ }
33
+
34
+ pageTitle.addElement(routeTitle || $scope.noTitle);
35
+ }
36
+ });
37
+ $scope.$on('$destroy', () => {
38
+ offRouteWatch();
39
+ offScopeWatch();
40
+ });
41
+
42
+ this.$onInit = () => {
43
+ pageTitle.setDelimiter($scope.delimiter);
44
+
45
+ if ($attrs.rgPageTitle) {
46
+ offScopeWatch = $scope.$watch('rgPageTitle', newBaseTitle => {
47
+ pageTitle.setRootElement(newBaseTitle);
48
+ });
49
+ }
50
+ };
51
+ }]
52
+ };
53
+ });
54
+ angularModule.service('pageTitle', ["$interpolate", "$document", function service($interpolate, $document) {
55
+ let delimiter = ' | ';
56
+ let current = $document[0].title;
57
+
58
+ function setTitle(text) {
59
+ current = text && $interpolate(text)();
60
+ updateDocumentTitle(current);
61
+ }
62
+
63
+ function updateDocumentTitle(text) {
64
+ $document[0].title = text;
65
+ }
66
+
67
+ function prepend(element) {
68
+ setTitle(current ? element + delimiter + current : element);
69
+ }
70
+
71
+ function replacePart(element) {
72
+ let replaceIndex = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
73
+ const titleElements = current.split(delimiter);
74
+ titleElements[replaceIndex === -1 ? titleElements.length - 1 : replaceIndex] = element;
75
+ setTitle(titleElements.join(delimiter));
76
+ }
77
+
78
+ this.setDelimiter = newDelimiter => {
79
+ delimiter = newDelimiter || delimiter;
80
+ };
81
+
82
+ this.setCurrent = newBase => {
83
+ current = newBase;
84
+ };
85
+
86
+ this.setText = text => updateDocumentTitle(text);
87
+
88
+ this.addElement = (element, fieldName) => {
89
+ if (element.$promise) {
90
+ element.$promise.then(Data => {
91
+ this.addElement(Data[fieldName || 'name']);
92
+ });
93
+ } else {
94
+ prepend(fieldName ? element[fieldName] : element);
95
+ }
96
+ };
97
+
98
+ this.updateElement = (element, fieldName) => {
99
+ if (element.$promise) {
100
+ element.$promise.then(Data => {
101
+ this.updateElement(Data[fieldName || 'name']);
102
+ });
103
+ } else {
104
+ replacePart(fieldName ? element[fieldName] : element);
105
+ }
106
+ };
107
+
108
+ this.setRootElement = element => {
109
+ replacePart(element, -1);
110
+ };
111
+ }]);
112
+ var titleNg = angularModule.name;
113
+
114
+ export { titleNg as default };
@@ -1,11 +1,11 @@
1
- import { a as _objectWithoutProperties, b as _extends, _ as _defineProperty } 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 { withTheme } from '../global/theme.js';
6
6
  import joinDataTestAttributes from '../global/data-tests.js';
7
7
 
8
- var modules_331c5aa7 = {"unit":"8px","padding":"2px","disabled-line-color":"hsla(0,0%,100%,.9)","duration":".3s","timing-function":"cubic-bezier(.23,1,.32,1)","toggle":"toggle_toggle__ca2e3a7a","switch":"toggle_switch__ca2e3a7a","disabled":"toggle_disabled__ca2e3a7a","label":"toggle_label__ca2e3a7a","leftLabel":"toggle_leftLabel__ca2e3a7a","light":"toggle_light__ca2e3a7a","dark":"toggle_dark__ca2e3a7a","switchWrapper":"toggle_switchWrapper__ca2e3a7a","input":"toggle_input__ca2e3a7a","size20":"toggle_size20__ca2e3a7a","paleSwitch":"toggle_paleSwitch__ca2e3a7a"};
8
+ var modules_331c5aa7 = {"unit":"8px","padding":"2px","disabled-line-color":"hsla(0,0%,100%,.9)","duration":".3s","timing-function":"cubic-bezier(.23,1,.32,1)","toggle":"toggle_rui_ca2e","switch":"switch_rui_ca2e","disabled":"disabled_rui_ca2e","label":"label_rui_ca2e","leftLabel":"leftLabel_rui_ca2e","light":"light_rui_ca2e","dark":"dark_rui_ca2e","switchWrapper":"switchWrapper_rui_ca2e","input":"input_rui_ca2e","size20":"size20_rui_ca2e","paleSwitch":"paleSwitch_rui_ca2e"};
9
9
 
10
10
  const Size = {
11
11
  Size16: modules_331c5aa7.size16,
@@ -17,8 +17,7 @@ const Size = {
17
17
 
18
18
  class Toggle extends PureComponent {
19
19
  render() {
20
- const _this$props = this.props,
21
- {
20
+ const {
22
21
  className,
23
22
  children,
24
23
  disabled,
@@ -28,10 +27,9 @@ class Toggle extends PureComponent {
28
27
  theme,
29
28
  size = Size.Size16,
30
29
  'data-test': dataTest,
31
- onTransitionEnd
32
- } = _this$props,
33
- restProps = _objectWithoutProperties(_this$props, ["className", "children", "disabled", "pale", "title", "leftLabel", "theme", "size", "data-test", "onTransitionEnd"]);
34
-
30
+ onTransitionEnd,
31
+ ...restProps
32
+ } = this.props;
35
33
  const classes = classNames(className, size, modules_331c5aa7.toggle, modules_331c5aa7[theme], disabled && modules_331c5aa7.disabled);
36
34
  return /*#__PURE__*/React.createElement("label", {
37
35
  className: classes,
@@ -74,7 +72,6 @@ _defineProperty(Toggle, "propTypes", {
74
72
  'data-test': PropTypes.string
75
73
  });
76
74
 
77
- var toggle = withTheme()(Toggle);
75
+ var Toggle$1 = withTheme()(Toggle);
78
76
 
79
- export default toggle;
80
- export { Size };
77
+ export { Size, Toggle$1 as default };
@@ -0,0 +1,16 @@
1
+ import angularComponentFactory from '../global/angular-component-factory.js';
2
+ import Toggle from '../toggle/toggle.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
+ import '../global/data-tests.js';
13
+
14
+ var toggleNg = angularComponentFactory(Toggle, 'Toggle').name;
15
+
16
+ export { toggleNg as default };
@@ -1,4 +1,4 @@
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, { Component, createContext } from 'react';
3
3
  import PropTypes from 'prop-types';
4
4
  import Popup from '../popup/popup.js';
@@ -18,7 +18,7 @@ import '../popup/position.js';
18
18
  import '../popup/popup.consts.js';
19
19
  import '../popup/popup.target.js';
20
20
 
21
- var modules_cd5e45a9 = {"unit":"8px","tooltip":"tooltip_tooltip__b9231867"};
21
+ var modules_cd5e45a9 = {"unit":"8px","tooltip":"tooltip_rui_b923"};
22
22
 
23
23
  const scheduleScroll = scheduleRAF();
24
24
  const TooltipContext = /*#__PURE__*/createContext();
@@ -144,17 +144,19 @@ class Tooltip extends Component {
144
144
  }
145
145
 
146
146
  render() {
147
- const _this$props = this.props,
148
- {
147
+ const {
149
148
  children,
150
149
  'data-test': dataTest,
151
150
  title,
152
151
  delay,
153
152
  selfOverflowOnly,
154
- popupProps
155
- } = _this$props,
156
- restProps = _objectWithoutProperties(_this$props, ["children", "data-test", "title", "delay", "selfOverflowOnly", "popupProps"]);
157
-
153
+ popupProps,
154
+ ...restProps
155
+ } = this.props;
156
+ const ariaProps = typeof title === 'string' && !!title ? {
157
+ 'aria-label': title,
158
+ role: 'tooltip'
159
+ } : {};
158
160
  const {
159
161
  onNestedTooltipShow,
160
162
  onNestedTooltipHide
@@ -164,10 +166,10 @@ class Tooltip extends Component {
164
166
  onNestedTooltipShow,
165
167
  onNestedTooltipHide
166
168
  }
167
- }, /*#__PURE__*/React.createElement("span", _extends({}, restProps, {
169
+ }, /*#__PURE__*/React.createElement("span", _extends({}, ariaProps, restProps, {
168
170
  ref: this.containerRef,
169
171
  "data-test": joinDataTestAttributes('ring-tooltip', dataTest),
170
- "data-test-title": title
172
+ "data-test-title": typeof title === 'string' ? title : undefined
171
173
  }), children, /*#__PURE__*/React.createElement(Popup, _extends({
172
174
  trapFocus: false,
173
175
  hidden: !this.state.showPopup || this.state.showNestedPopup,
@@ -187,7 +189,7 @@ _defineProperty(Tooltip, "propTypes", {
187
189
  delay: PropTypes.number,
188
190
  selfOverflowOnly: PropTypes.bool,
189
191
  popupProps: PropTypes.object,
190
- title: PropTypes.oneOfType([PropTypes.string, PropTypes.element]),
192
+ title: PropTypes.node,
191
193
  children: PropTypes.node,
192
194
  'data-test': PropTypes.string
193
195
  });
@@ -202,4 +204,4 @@ _defineProperty(Tooltip, "PopupProps", Popup.PopupProps);
202
204
 
203
205
  _defineProperty(Tooltip, "contextType", TooltipContext);
204
206
 
205
- export default Tooltip;
207
+ export { Tooltip as default };
@@ -0,0 +1,98 @@
1
+ import angular from 'angular';
2
+ import { createElement } from 'react';
3
+ import { render } from 'react-dom';
4
+ import classNames from 'classnames';
5
+ import Popup from '../popup/popup.js';
6
+ import '../_helpers/_rollupPluginBabelHelpers.js';
7
+ import 'prop-types';
8
+ import '../global/get-uid.js';
9
+ import '../global/schedule-raf.js';
10
+ import '../global/dom.js';
11
+ import '../shortcuts/shortcuts.js';
12
+ import '../shortcuts/core.js';
13
+ import 'combokeys';
14
+ import '../global/sniffer.js';
15
+ import 'sniffr';
16
+ import '../global/data-tests.js';
17
+ import '../tab-trap/tab-trap.js';
18
+ import '../popup/position.js';
19
+ import '../popup/popup.consts.js';
20
+ import '../popup/popup.target.js';
21
+
22
+ /**
23
+ * @name Tooltip Ng
24
+ */
25
+
26
+ const OPEN_CLASS = 'ring-tooltip-ng_open';
27
+ const name = angular.module('Ring.tooltip', []);
28
+ name.directive('rgTooltip', ["RgTooltipPopup", function rgTooltipDirective(RgTooltipPopup) {
29
+ return {
30
+ restrict: 'A',
31
+ link: function link(scope, iElement, iAttrs) {
32
+ const element = iElement[0];
33
+
34
+ const getTooltipText = () => {
35
+ try {
36
+ return scope.$eval(iAttrs.rgTooltip);
37
+ } catch (err) {
38
+ return iAttrs.rgTooltip;
39
+ }
40
+ };
41
+
42
+ const popupWrapper = new RgTooltipPopup(element, getTooltipText);
43
+ element.addEventListener('mouseover', () => {
44
+ popupWrapper.displayTooltip(iAttrs.rgTooltipClass);
45
+ element.classList.add(OPEN_CLASS);
46
+ });
47
+ element.addEventListener('mouseout', () => {
48
+ popupWrapper.hideTooltip();
49
+ element.classList.remove(OPEN_CLASS);
50
+ });
51
+ }
52
+ };
53
+ }]);
54
+ name.factory('RgTooltipPopup', function RgTooltipPopupDirective() {
55
+ // eslint-disable-next-line func-names
56
+ return function (anchorElement, textGetter) {
57
+ this.wrapperElement = document.createElement('span');
58
+ this.defaultProps = {
59
+ anchorElement,
60
+ maxHeight: 400,
61
+ attached: false,
62
+ dontCloseOnAnchorClick: true,
63
+ trapFocus: false
64
+ };
65
+
66
+ this.renderPopup = props => {
67
+ this.popup = render( /*#__PURE__*/createElement(Popup, { ...this.defaultProps,
68
+ ...props
69
+ }, this.text), this.wrapperElement);
70
+ };
71
+
72
+ this.displayTooltip = customClass => {
73
+ const text = textGetter();
74
+
75
+ if (!text) {
76
+ return;
77
+ }
78
+
79
+ this.text = text;
80
+ const className = classNames({
81
+ 'ring-tooltip-ng': true
82
+ }, customClass);
83
+ this.renderPopup({
84
+ hidden: false,
85
+ className
86
+ });
87
+ };
88
+
89
+ this.hideTooltip = () => {
90
+ this.renderPopup({
91
+ hidden: true
92
+ });
93
+ };
94
+ };
95
+ });
96
+ var tooltipNg = name.name;
97
+
98
+ export { tooltipNg as default };