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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (354) 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/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.js +16 -14
  35. package/components/date-picker/date-popup.js +22 -7
  36. package/components/date-picker/month-names.js +8 -5
  37. package/components/date-picker/month.js +6 -2
  38. package/components/date-picker/weekdays.js +10 -2
  39. package/components/dialog/dialog.examples.js +3 -1
  40. package/components/dialog/dialog.js +5 -2
  41. package/components/dialog/dialog.test.js +1 -1
  42. package/components/dialog/dialog__body-scroll-preventer.js +2 -2
  43. package/components/dialog-ng/dialog-ng.js +7 -8
  44. package/components/dialog-ng/{dialog-ng.html → dialog-ng__template.js} +2 -2
  45. package/components/dropdown/dropdown.examples.js +36 -1
  46. package/components/dropdown-menu/dropdown-menu.examples.js +47 -0
  47. package/components/dropdown-menu/dropdown-menu.js +117 -0
  48. package/components/dropdown-menu/dropdown-menu.test.js +76 -0
  49. package/components/error-bubble/error-bubble-legacy.css +1 -1
  50. package/components/error-bubble/error-bubble.css +1 -1
  51. package/components/error-bubble/error-bubble.examples.js +1 -1
  52. package/components/error-page/error-page.css +2 -2
  53. package/components/footer-ng/footer-ng.js +13 -3
  54. package/components/form/form.css +2 -2
  55. package/components/form-ng/form-ng.js +3 -1
  56. package/components/global/global.css +1 -1
  57. package/components/global/theme.js +1 -1
  58. package/components/global/variables.css +8 -1
  59. package/components/grid/grid.css +10 -9
  60. package/components/header/header.css +1 -1
  61. package/components/header/header.examples.js +7 -8
  62. package/components/header/profile.js +10 -11
  63. package/components/http/http.js +1 -1
  64. package/components/icon/icon.css +5 -4
  65. package/components/island/island.css +4 -3
  66. package/components/island-legacy/island-legacy.css +3 -1
  67. package/components/list/list.js +6 -1
  68. package/components/list/list__custom.js +9 -3
  69. package/components/list/list__item.js +8 -2
  70. package/components/list/list__link.js +2 -1
  71. package/components/loader-inline/loader-inline.css +1 -1
  72. package/components/loader-screen/loader-screen.css +1 -1
  73. package/components/message/message.css +1 -1
  74. package/components/message/message.examples.js +8 -5
  75. package/components/pager/pager.js +5 -3
  76. package/components/permissions/permissions.js +1 -1
  77. package/components/progress-bar/progress-bar.css +1 -1
  78. package/components/progress-bar/progress-bar.examples.js +3 -3
  79. package/components/progress-bar/progress-bar.js +5 -2
  80. package/components/progress-bar/progress-bar.test.js +12 -13
  81. package/components/progress-bar-ng/progress-bar-ng.examples.js +3 -3
  82. package/components/query-assist/query-assist.css +13 -3
  83. package/components/query-assist/query-assist.examples.js +3 -1
  84. package/components/query-assist/query-assist.js +56 -12
  85. package/components/query-assist/query-assist.test.js +37 -5
  86. package/components/save-field-ng/save-field-ng.css +0 -3
  87. package/components/save-field-ng/save-field-ng.js +3 -1
  88. package/components/save-field-ng/{save-field-ng.html → save-field-ng__template.js} +2 -2
  89. package/components/select/select.css +12 -7
  90. package/components/select/select.examples.js +13 -0
  91. package/components/select/select.js +30 -43
  92. package/components/select/select.test.js +4 -5
  93. package/components/shortcuts-hint-ng/shortcuts-hint-ng.css +1 -1
  94. package/components/shortcuts-hint-ng/shortcuts-hint-ng.js +1 -1
  95. package/components/shortcuts-hint-ng/{shortcuts-hint-ng.html → shortcuts-hint-ng__template.js} +2 -2
  96. package/components/sidebar/sidebar.css +1 -0
  97. package/components/sidebar-ng/sidebar-ng.js +6 -2
  98. package/components/sidebar-ng/{sidebar-ng__button.html → sidebar-ng__button-template.js} +2 -2
  99. package/components/sidebar-ng/{sidebar-ng.html → sidebar-ng__template.js} +2 -2
  100. package/components/table/row.js +2 -1
  101. package/components/table/table.css +2 -1
  102. package/components/table-legacy/table-legacy.css +2 -2
  103. package/components/table-legacy/table-legacy__toolbar.css +2 -2
  104. package/components/table-legacy-ng/table-legacy-ng.js +38 -5
  105. package/components/table-legacy-ng/table-legacy-ng__pager.js +7 -1
  106. package/components/tabs/collapsible-tab.js +2 -2
  107. package/components/tabs/collapsible-tabs.js +4 -8
  108. package/components/tabs/tab-link.js +4 -2
  109. package/components/tabs/tabs.css +27 -0
  110. package/components/tabs-ng/tabs-ng.js +4 -2
  111. package/components/tabs-ng/{tabs-ng.html → tabs-ng__template.js} +6 -2
  112. package/components/tag/tag.css +5 -2
  113. package/components/tag/tag.examples.js +3 -0
  114. package/components/tag/tag.js +19 -16
  115. package/components/tags-input/tag-input.examples.js +1 -1
  116. package/components/tags-input/tags-input.js +5 -2
  117. package/components/template-ng/template-ng.js +1 -1
  118. package/components/tooltip/tooltip.js +7 -2
  119. package/components/user-agreement/user-agreement.css +1 -1
  120. package/components/user-agreement/user-agreement.examples.js +7 -4
  121. package/components/user-agreement/user-agreement.js +1 -0
  122. package/package.json +75 -78
  123. package/webpack.config.js +14 -10
  124. package/components/button-set-ng/button-set-ng.html +0 -1
  125. package/components/footer-ng/footer-ng.html +0 -13
  126. package/components/form-ng/form-ng__error-bubble.html +0 -3
  127. package/components/table-legacy-ng/table-legacy-ng.html +0 -4
  128. package/components/table-legacy-ng/table-legacy-ng__column.html +0 -12
  129. package/components/table-legacy-ng/table-legacy-ng__header.html +0 -4
  130. package/components/table-legacy-ng/table-legacy-ng__pager.html +0 -7
  131. package/components/table-legacy-ng/table-legacy-ng__row.html +0 -12
  132. package/components/table-legacy-ng/table-legacy-ng__title.html +0 -9
  133. package/dist/_helpers/_rollupPluginBabelHelpers.js +0 -127
  134. package/dist/_helpers/anchor.js +0 -33
  135. package/dist/_helpers/badge.js +0 -3
  136. package/dist/_helpers/button__classes.js +0 -39
  137. package/dist/_helpers/caption.js +0 -25
  138. package/dist/_helpers/card.js +0 -77
  139. package/dist/_helpers/date-picker.js +0 -3
  140. package/dist/_helpers/dialog__body-scroll-preventer.js +0 -56
  141. package/dist/_helpers/grid.js +0 -3
  142. package/dist/_helpers/header.js +0 -3
  143. package/dist/_helpers/icon__svg.js +0 -83
  144. package/dist/_helpers/inject-styles.js +0 -22
  145. package/dist/_helpers/island.js +0 -3
  146. package/dist/_helpers/list.js +0 -3
  147. package/dist/_helpers/query-assist__suggestions.js +0 -95
  148. package/dist/_helpers/select__filter.js +0 -78
  149. package/dist/_helpers/services-link.js +0 -42
  150. package/dist/_helpers/sidebar.js +0 -127
  151. package/dist/_helpers/table.js +0 -3
  152. package/dist/_helpers/tabs.js +0 -3
  153. package/dist/_helpers/title.js +0 -99
  154. package/dist/alert/alert.js +0 -254
  155. package/dist/alert/container.js +0 -50
  156. package/dist/alert-service/alert-service.js +0 -159
  157. package/dist/analytics/analytics.js +0 -116
  158. package/dist/analytics/analytics__custom-plugin.js +0 -127
  159. package/dist/analytics/analytics__fus-plugin.js +0 -101
  160. package/dist/analytics/analytics__ga-plugin.js +0 -66
  161. package/dist/analytics/analytics__plugin-utils.js +0 -79
  162. package/dist/auth/auth.js +0 -90
  163. package/dist/auth/auth__core.js +0 -987
  164. package/dist/auth/background-flow.js +0 -123
  165. package/dist/auth/down-notification.js +0 -111
  166. package/dist/auth/iframe-flow.js +0 -147
  167. package/dist/auth/landing-entry.js +0 -5
  168. package/dist/auth/landing.js +0 -84
  169. package/dist/auth/request-builder.js +0 -75
  170. package/dist/auth/response-parser.js +0 -117
  171. package/dist/auth/storage.js +0 -279
  172. package/dist/auth/token-validator.js +0 -176
  173. package/dist/auth/window-flow.js +0 -133
  174. package/dist/auth-dialog/auth-dialog.js +0 -132
  175. package/dist/auth-dialog-service/auth-dialog-service.js +0 -67
  176. package/dist/avatar/avatar-example-datauri.js +0 -26
  177. package/dist/avatar/avatar.js +0 -155
  178. package/dist/badge/badge.js +0 -52
  179. package/dist/button/button.js +0 -117
  180. package/dist/button/button__classes.js +0 -5
  181. package/dist/button-group/button-group.js +0 -30
  182. package/dist/button-group/caption.js +0 -5
  183. package/dist/button-set/button-set.js +0 -27
  184. package/dist/button-toolbar/button-toolbar.js +0 -30
  185. package/dist/caret/caret.js +0 -264
  186. package/dist/checkbox/checkbox.js +0 -110
  187. package/dist/confirm/confirm.js +0 -122
  188. package/dist/confirm-service/confirm-service.js +0 -112
  189. package/dist/content-layout/content-layout.js +0 -67
  190. package/dist/content-layout/sidebar.js +0 -6
  191. package/dist/contenteditable/contenteditable.js +0 -81
  192. package/dist/data-list/data-list.js +0 -203
  193. package/dist/data-list/data-list.mock.js +0 -190
  194. package/dist/data-list/item.js +0 -225
  195. package/dist/data-list/selection.js +0 -101
  196. package/dist/data-list/title.js +0 -16
  197. package/dist/date-picker/consts.js +0 -70
  198. package/dist/date-picker/date-input.js +0 -169
  199. package/dist/date-picker/date-picker.js +0 -356
  200. package/dist/date-picker/date-popup.js +0 -459
  201. package/dist/date-picker/day.js +0 -119
  202. package/dist/date-picker/formats.js +0 -3
  203. package/dist/date-picker/month-names.js +0 -92
  204. package/dist/date-picker/month-slider.js +0 -83
  205. package/dist/date-picker/month.js +0 -48
  206. package/dist/date-picker/months.js +0 -121
  207. package/dist/date-picker/weekdays.js +0 -24
  208. package/dist/date-picker/years.js +0 -109
  209. package/dist/dialog/dialog.js +0 -197
  210. package/dist/dialog/dialog__body-scroll-preventer.js +0 -2
  211. package/dist/dropdown/anchor.js +0 -16
  212. package/dist/dropdown/dropdown.js +0 -236
  213. package/dist/error-bubble/error-bubble.js +0 -59
  214. package/dist/error-message/error-message.js +0 -55
  215. package/dist/footer/footer.js +0 -127
  216. package/dist/global/angular-component-factory.js +0 -83
  217. package/dist/global/compose.js +0 -9
  218. package/dist/global/composeRefs.js +0 -15
  219. package/dist/global/conic-gradient.js +0 -37
  220. package/dist/global/create-stateful-context.js +0 -54
  221. package/dist/global/data-tests.js +0 -22
  222. package/dist/global/dom.js +0 -124
  223. package/dist/global/focus-sensor-hoc.js +0 -147
  224. package/dist/global/fuzzy-highlight.js +0 -67
  225. package/dist/global/get-event-key.js +0 -111
  226. package/dist/global/get-uid.js +0 -15
  227. package/dist/global/inject-styles.js +0 -17
  228. package/dist/global/linear-function.js +0 -18
  229. package/dist/global/listeners.js +0 -42
  230. package/dist/global/memoize.js +0 -18
  231. package/dist/global/normalize-indent.js +0 -28
  232. package/dist/global/promise-with-timeout.js +0 -13
  233. package/dist/global/radial-gradient-mask.js +0 -49
  234. package/dist/global/react-dom-renderer.js +0 -45
  235. package/dist/global/rerender-hoc.js +0 -53
  236. package/dist/global/ring-angular-component.js +0 -24
  237. package/dist/global/schedule-raf.js +0 -31
  238. package/dist/global/sniffer.js +0 -6
  239. package/dist/global/supports-css.js +0 -20
  240. package/dist/global/theme.js +0 -56
  241. package/dist/global/trivial-template-tag.js +0 -15
  242. package/dist/global/url.js +0 -163
  243. package/dist/global/variables_dark.js +0 -57
  244. package/dist/grid/col.js +0 -62
  245. package/dist/grid/grid.js +0 -35
  246. package/dist/grid/row.js +0 -66
  247. package/dist/group/group.js +0 -34
  248. package/dist/header/header.js +0 -144
  249. package/dist/header/logo.js +0 -39
  250. package/dist/header/profile.js +0 -212
  251. package/dist/header/services-link.js +0 -10
  252. package/dist/header/services.js +0 -135
  253. package/dist/header/smart-profile.js +0 -227
  254. package/dist/header/smart-services.js +0 -159
  255. package/dist/header/tray-icon.js +0 -45
  256. package/dist/header/tray.js +0 -33
  257. package/dist/heading/heading.js +0 -76
  258. package/dist/http/http.js +0 -216
  259. package/dist/http/http.mock.js +0 -65
  260. package/dist/hub-source/hub-source.js +0 -130
  261. package/dist/hub-source/hub-source__user.js +0 -28
  262. package/dist/hub-source/hub-source__users-groups.js +0 -62
  263. package/dist/icon/icon.js +0 -105
  264. package/dist/icon/icon__constants.js +0 -33
  265. package/dist/icon/icon__svg.js +0 -6
  266. package/dist/icon/index.js +0 -9
  267. package/dist/input/input.js +0 -231
  268. package/dist/island/adaptive-island-hoc.js +0 -48
  269. package/dist/island/content.js +0 -158
  270. package/dist/island/header.js +0 -85
  271. package/dist/island/island.js +0 -53
  272. package/dist/island-legacy/content-legacy.js +0 -28
  273. package/dist/island-legacy/header-legacy.js +0 -30
  274. package/dist/island-legacy/island-legacy.js +0 -30
  275. package/dist/link/clickableLink.js +0 -65
  276. package/dist/link/link.js +0 -118
  277. package/dist/list/consts.js +0 -26
  278. package/dist/list/list.js +0 -800
  279. package/dist/list/list__custom.js +0 -82
  280. package/dist/list/list__hint.js +0 -26
  281. package/dist/list/list__item.js +0 -197
  282. package/dist/list/list__link.js +0 -65
  283. package/dist/list/list__separator.js +0 -30
  284. package/dist/list/list__title.js +0 -39
  285. package/dist/list/list__users-groups-source.js +0 -124
  286. package/dist/loader/loader.js +0 -72
  287. package/dist/loader/loader__core.js +0 -272
  288. package/dist/loader-inline/inject-styles.js +0 -11
  289. package/dist/loader-inline/loader-inline.js +0 -58
  290. package/dist/loader-screen/loader-screen.js +0 -46
  291. package/dist/login-dialog/login-dialog.js +0 -184
  292. package/dist/login-dialog/service.js +0 -67
  293. package/dist/message/message.js +0 -232
  294. package/dist/old-browsers-message/old-browsers-message.js +0 -101
  295. package/dist/old-browsers-message/old-browsers-message__stop.js +0 -5
  296. package/dist/old-browsers-message/white-list.js +0 -34
  297. package/dist/pager/pager.js +0 -352
  298. package/dist/panel/panel.js +0 -34
  299. package/dist/permissions/permissions.js +0 -200
  300. package/dist/permissions/permissions__cache.js +0 -272
  301. package/dist/popup/popup.consts.js +0 -41
  302. package/dist/popup/popup.js +0 -389
  303. package/dist/popup/popup.target.js +0 -27
  304. package/dist/popup/position.js +0 -280
  305. package/dist/popup-menu/popup-menu.js +0 -108
  306. package/dist/progress-bar/progress-bar.js +0 -111
  307. package/dist/proxy-attrs/proxy-attrs.js +0 -19
  308. package/dist/query-assist/query-assist.js +0 -1023
  309. package/dist/query-assist/query-assist__suggestions.js +0 -43
  310. package/dist/radio/radio.js +0 -39
  311. package/dist/radio/radio__item.js +0 -82
  312. package/dist/select/select.js +0 -1335
  313. package/dist/select/select__filter.js +0 -49
  314. package/dist/select/select__popup.js +0 -541
  315. package/dist/shortcuts/core.js +0 -245
  316. package/dist/shortcuts/shortcut-title.js +0 -51
  317. package/dist/shortcuts/shortcuts-hoc.js +0 -43
  318. package/dist/shortcuts/shortcuts.js +0 -72
  319. package/dist/storage/storage.js +0 -55
  320. package/dist/storage/storage__fallback.js +0 -214
  321. package/dist/storage/storage__local.js +0 -150
  322. package/dist/style.css +0 -1
  323. package/dist/tab-trap/tab-trap.js +0 -178
  324. package/dist/table/cell.js +0 -25
  325. package/dist/table/disable-hover-hoc.js +0 -53
  326. package/dist/table/header-cell.js +0 -91
  327. package/dist/table/header.js +0 -189
  328. package/dist/table/multitable.js +0 -140
  329. package/dist/table/row-with-focus-sensor.js +0 -79
  330. package/dist/table/row.js +0 -270
  331. package/dist/table/selection-adapter.js +0 -14
  332. package/dist/table/selection-shortcuts-hoc.js +0 -212
  333. package/dist/table/selection.js +0 -221
  334. package/dist/table/smart-table.js +0 -113
  335. package/dist/table/table.js +0 -405
  336. package/dist/tabs/collapsible-more.js +0 -193
  337. package/dist/tabs/collapsible-tab.js +0 -90
  338. package/dist/tabs/collapsible-tabs.js +0 -361
  339. package/dist/tabs/custom-item.js +0 -13
  340. package/dist/tabs/dumb-tabs.js +0 -159
  341. package/dist/tabs/smart-tabs.js +0 -102
  342. package/dist/tabs/tab-link.js +0 -35
  343. package/dist/tabs/tab.js +0 -32
  344. package/dist/tabs/tabs.js +0 -65
  345. package/dist/tag/tag.js +0 -190
  346. package/dist/tags-input/tags-input.js +0 -474
  347. package/dist/tags-list/tags-list.js +0 -94
  348. package/dist/text/text.js +0 -38
  349. package/dist/toggle/toggle.js +0 -80
  350. package/dist/tooltip/tooltip.js +0 -205
  351. package/dist/user-card/card.js +0 -14
  352. package/dist/user-card/smart-user-card-tooltip.js +0 -112
  353. package/dist/user-card/tooltip.js +0 -91
  354. package/dist/user-card/user-card.js +0 -46
@@ -1,232 +0,0 @@
1
- import { _ as _defineProperty, b as _extends } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import React, { Component } from 'react';
3
- import PropTypes from 'prop-types';
4
- import classNames from 'classnames';
5
- import gift from '@jetbrains/icons/gift';
6
- import Popup from '../popup/popup.js';
7
- import Icon from '../icon/icon.js';
8
- import Button from '../button/button.js';
9
- import 'react-dom';
10
- import '../global/get-uid.js';
11
- import '../global/schedule-raf.js';
12
- import '../global/dom.js';
13
- import '../shortcuts/shortcuts.js';
14
- import '../shortcuts/core.js';
15
- import 'combokeys';
16
- import '../global/sniffer.js';
17
- import 'sniffr';
18
- import '../global/data-tests.js';
19
- import '../tab-trap/tab-trap.js';
20
- import '../popup/position.js';
21
- import '../popup/popup.consts.js';
22
- import '../popup/popup.target.js';
23
- import 'util-deprecate';
24
- import '../icon/icon__constants.js';
25
- import '../_helpers/icon__svg.js';
26
- import '../global/memoize.js';
27
- import 'focus-visible';
28
- import '@jetbrains/icons/chevron-10px';
29
- import '../global/theme.js';
30
- import '../link/clickableLink.js';
31
- import '../_helpers/button__classes.js';
32
-
33
- var modules_8b837449 = {"unit":"8px","padding":"12px","message":"message_message__18608ba2","icon":"message_icon__18608ba2","title":"message_title__18608ba2 global_fontLower__0f8f4370 global_font__0f8f4370","description":"message_description__18608ba2 global_fontSmallerLower__0f8f4370 global_fontSmaller__0f8f4370 global_fontLower__0f8f4370 global_font__0f8f4370","button":"message_button__18608ba2","tail":"message_tail__18608ba2"};
34
-
35
- /**
36
- * @name Message
37
- */
38
-
39
- const {
40
- Directions
41
- } = Popup.PopupProps;
42
- const UNIT = 8;
43
-
44
- const getTailOffsets = offset => ({
45
- [Directions.BOTTOM_RIGHT]: {
46
- top: 0,
47
- left: offset - UNIT,
48
- transform: 'rotate(180deg)'
49
- },
50
- [Directions.BOTTOM_LEFT]: {
51
- top: 0,
52
- right: offset - UNIT,
53
- transform: 'rotate(180deg)'
54
- },
55
- [Directions.BOTTOM_CENTER]: {
56
- top: 0,
57
- left: offset - UNIT,
58
- transform: 'rotate(180deg)'
59
- },
60
- [Directions.TOP_RIGHT]: {
61
- bottom: -UNIT + 1,
62
- left: offset - UNIT
63
- },
64
- [Directions.TOP_LEFT]: {
65
- bottom: -UNIT + 1,
66
- right: offset - UNIT
67
- },
68
- [Directions.TOP_CENTER]: {
69
- bottom: -UNIT + 1,
70
- left: offset - UNIT
71
- },
72
- [Directions.RIGHT_TOP]: {
73
- bottom: offset - UNIT,
74
- left: -UNIT,
75
- transform: 'rotate(90deg)'
76
- },
77
- [Directions.RIGHT_BOTTOM]: {
78
- top: offset,
79
- left: -UNIT,
80
- transform: 'rotate(90deg)'
81
- },
82
- [Directions.RIGHT_CENTER]: {
83
- top: offset,
84
- left: -UNIT,
85
- transform: 'rotate(90deg)'
86
- },
87
- [Directions.LEFT_TOP]: {
88
- bottom: offset - UNIT,
89
- right: -UNIT,
90
- transform: 'rotate(-90deg)'
91
- },
92
- [Directions.LEFT_BOTTOM]: {
93
- top: offset,
94
- right: -UNIT,
95
- transform: 'rotate(-90deg)'
96
- },
97
- [Directions.LEFT_CENTER]: {
98
- top: offset,
99
- right: -UNIT,
100
- transform: 'rotate(-90deg)'
101
- }
102
- });
103
- /**
104
- * Displays a popup containing a message.
105
- */
106
-
107
-
108
- class Message extends Component {
109
- constructor() {
110
- super(...arguments);
111
-
112
- _defineProperty(this, "state", {});
113
-
114
- _defineProperty(this, "_onDirectionChange", direction => this.setState({
115
- direction
116
- }));
117
-
118
- _defineProperty(this, "popupRef", el => {
119
- var _this$popup;
120
-
121
- this.popup = el;
122
- this.node = (_this$popup = this.popup) === null || _this$popup === void 0 ? void 0 : _this$popup.node;
123
- });
124
- }
125
-
126
- getTailOffset() {
127
- var _this$popup2;
128
-
129
- const DEFAULT_OFFSET = 32;
130
- const {
131
- popupProps
132
- } = this.props;
133
-
134
- if (this.props.tailOffset != null) {
135
- return this.props.tailOffset;
136
- }
137
-
138
- const anchor = (popupProps === null || popupProps === void 0 ? void 0 : popupProps.anchorElement) || ((_this$popup2 = this.popup) === null || _this$popup2 === void 0 ? void 0 : _this$popup2.parent);
139
-
140
- if (!anchor) {
141
- return DEFAULT_OFFSET;
142
- }
143
-
144
- const offset = Math.floor(anchor.offsetWidth / 2);
145
- const isOpenedToRight = [Directions.TOP_RIGHT, Directions.BOTTOM_RIGHT].includes(this.state.direction);
146
-
147
- if (popupProps !== null && popupProps !== void 0 && popupProps.left && isOpenedToRight) {
148
- return offset - (popupProps === null || popupProps === void 0 ? void 0 : popupProps.left);
149
- }
150
-
151
- return offset;
152
- }
153
-
154
- render() {
155
- const {
156
- children,
157
- className,
158
- tailClassName,
159
- title,
160
- icon,
161
- popupProps,
162
- buttonProps,
163
- onClose,
164
- onDismiss,
165
- translations
166
- } = this.props;
167
- const classes = classNames(modules_8b837449.message, className);
168
- const tailClasses = classNames(modules_8b837449.tail, tailClassName);
169
- const popupDirections = this.props.direction ? [this.props.direction] : this.props.directions;
170
- const {
171
- direction
172
- } = this.state;
173
- return /*#__PURE__*/React.createElement(Popup, _extends({
174
- ref: this.popupRef,
175
- hidden: false,
176
- directions: popupDirections,
177
- className: classes,
178
- offset: UNIT * 2,
179
- onDirectionChange: this._onDirectionChange
180
- }, popupProps), direction && /*#__PURE__*/React.createElement("div", {
181
- className: tailClasses,
182
- style: getTailOffsets(this.getTailOffset())[direction]
183
- }), icon && /*#__PURE__*/React.createElement(Icon, {
184
- className: modules_8b837449.icon,
185
- glyph: icon
186
- }), /*#__PURE__*/React.createElement("h1", {
187
- "data-test": "rgMessageTitle",
188
- className: modules_8b837449.title
189
- }, title), children && /*#__PURE__*/React.createElement("div", {
190
- className: modules_8b837449.description
191
- }, children), (onClose || buttonProps) && /*#__PURE__*/React.createElement(Button, _extends({
192
- className: modules_8b837449.button,
193
- onClick: onClose,
194
- primary: true
195
- }, buttonProps), translations.gotIt), onDismiss && /*#__PURE__*/React.createElement(Button, {
196
- onClick: onDismiss,
197
- text: true
198
- }, translations.dismiss));
199
- }
200
-
201
- }
202
-
203
- _defineProperty(Message, "propTypes", {
204
- children: PropTypes.node,
205
- className: PropTypes.string,
206
- tailClassName: PropTypes.string,
207
- title: PropTypes.string.isRequired,
208
- icon: PropTypes.oneOfType([PropTypes.string, PropTypes.elementType]),
209
- directions: PropTypes.arrayOf(PropTypes.string),
210
- direction: PropTypes.string,
211
- popupProps: PropTypes.object,
212
- buttonProps: PropTypes.object,
213
- tailOffset: PropTypes.number,
214
- onClose: PropTypes.func,
215
- onDismiss: PropTypes.func,
216
- translations: PropTypes.object
217
- });
218
-
219
- _defineProperty(Message, "defaultProps", {
220
- icon: gift,
221
- directions: [Directions.TOP_RIGHT, Directions.TOP_LEFT, Directions.TOP_CENTER, Directions.BOTTOM_RIGHT, Directions.BOTTOM_LEFT, Directions.BOTTOM_CENTER, Directions.RIGHT_TOP, Directions.RIGHT_BOTTOM, Directions.RIGHT_CENTER, Directions.LEFT_TOP, Directions.LEFT_BOTTOM, Directions.LEFT_CENTER],
222
- translations: {
223
- gotIt: 'Got it',
224
- dismiss: 'Dismiss'
225
- }
226
- });
227
-
228
- _defineProperty(Message, "Directions", Directions);
229
-
230
- _defineProperty(Message, "PopupProps", Popup.PopupProps);
231
-
232
- export default Message;
@@ -1,101 +0,0 @@
1
- import { isBrowserInWhiteList } from './white-list.js';
2
- import '../_helpers/_rollupPluginBabelHelpers.js';
3
- import '../global/sniffer.js';
4
- import 'sniffr';
5
-
6
- /**
7
- * @name Old Browsers Message
8
- */
9
-
10
- /**
11
- The list of versions which are definitely supported. "Browser is unsupported"
12
- won't be displayed for those and higher versions even when a JS error occurs
13
- on application start.
14
- */
15
-
16
- let smileChanges = 0;
17
- const MAX_SMILE_CHANGES = 50;
18
- let previousWindowErrorHandler;
19
-
20
- function changeSmileClickListener(event) {
21
- const eyes = ['O', 'o', '-', '>', '<'];
22
- const target = event.target || event.srcElement;
23
- smileChanges++;
24
-
25
- function rand(min, max) {
26
- return Math.round(Math.random() * (max - min)) + min;
27
- }
28
-
29
- function getRandomEye() {
30
- return eyes[rand(0, eyes.length - 1)];
31
- }
32
-
33
- function getRandomSmile() {
34
- if (smileChanges >= MAX_SMILE_CHANGES) {
35
- return '\\\\ (x_x) //';
36
- }
37
-
38
- return `{{ (${getRandomEye()}_${getRandomEye()}) }}`;
39
- }
40
-
41
- target.innerHTML = getRandomSmile();
42
- }
43
-
44
- function attachSmileClickListener(smileNode) {
45
- if (smileNode.addEventListener) {
46
- smileNode.addEventListener('click', changeSmileClickListener);
47
- } else if (smileNode.attachEvent) {
48
- smileNode.attachEvent('onclick', changeSmileClickListener);
49
- }
50
- }
51
- /**
52
- * Listens to unhandled errors and displays passed node
53
- */
54
-
55
-
56
- function startOldBrowsersDetector(onOldBrowserDetected) {
57
- previousWindowErrorHandler = window.onerror;
58
-
59
- window.onerror = function oldBrowsersMessageShower(errorMsg, url, lineNumber) {
60
- if (onOldBrowserDetected) {
61
- onOldBrowserDetected();
62
- }
63
-
64
- if (previousWindowErrorHandler) {
65
- return previousWindowErrorHandler(errorMsg, url, lineNumber);
66
- }
67
-
68
- return false;
69
- };
70
- }
71
-
72
- function stopOldBrowserDetector() {
73
- window.onerror = previousWindowErrorHandler;
74
- } //Start javascript error detection
75
-
76
-
77
- startOldBrowsersDetector(() => {
78
- const oldBrowsersMessageContainer = document.getElementById('ring-old-browsers-message');
79
- const browserMessage = document.getElementById('ring-old-browsers-message__browser-message');
80
- const errorMessage = document.getElementById('ring-old-browsers-message__error-message');
81
- const smileNode = document.getElementById('ring-old-browsers-message__smile');
82
-
83
- if (isBrowserInWhiteList()) {
84
- browserMessage.style.display = 'none';
85
- errorMessage.style.display = 'block';
86
- } else {
87
- browserMessage.style.display = 'block';
88
- errorMessage.style.display = 'none';
89
- }
90
-
91
- if (oldBrowsersMessageContainer) {
92
- oldBrowsersMessageContainer.hidden = false;
93
- oldBrowsersMessageContainer.style.display = 'block';
94
- }
95
-
96
- if (smileNode) {
97
- attachSmileClickListener(smileNode);
98
- }
99
- });
100
-
101
- export { stopOldBrowserDetector as stop };
@@ -1,5 +0,0 @@
1
- export { stop as default } from './old-browsers-message.js';
2
- import './white-list.js';
3
- import '../_helpers/_rollupPluginBabelHelpers.js';
4
- import '../global/sniffer.js';
5
- import 'sniffr';
@@ -1,34 +0,0 @@
1
- import { c as _objectSpread2 } from '../_helpers/_rollupPluginBabelHelpers.js';
2
- import sniffr from '../global/sniffer.js';
3
- import 'sniffr';
4
-
5
- const MAJOR_VERSION_INDEX = 0;
6
- /**
7
- * SUPPORTED_BROWSERS are defined by Babel plugin, see babel config
8
- */
9
-
10
- /* global SUPPORTED_BROWSERS */
11
-
12
- if (!["and_chr 90", "and_uc 12.12", "chrome 90", "chrome 89", "edge 90", "edge 89", "firefox 87", "ios_saf 14.0-14.4", "op_mini all", "safari 14", "samsung 13.0"]) {
13
- // eslint-disable-next-line no-console
14
- console.warn('Ring UI: no SUPPORTED_BROWSERS passed. Please check babel config.');
15
- }
16
-
17
- const SUPPORTED = ["and_chr 90", "and_uc 12.12", "chrome 90", "chrome 89", "edge 90", "edge 89", "firefox 87", "ios_saf 14.0-14.4", "op_mini all", "safari 14", "samsung 13.0"] || [];
18
- const WHITE_LISTED_BROWSERS = ['chrome', 'firefox', 'safari', 'edge'];
19
- const WHITE_LIST = SUPPORTED.reduce((acc, item) => {
20
- const [, browserName, version] = item.match(/(\S+)\s(\S+)/);
21
-
22
- if (!WHITE_LISTED_BROWSERS.includes(browserName)) {
23
- return acc;
24
- }
25
-
26
- return _objectSpread2(_objectSpread2({}, acc), {}, {
27
- [browserName]: parseInt(version, 10)
28
- });
29
- }, {});
30
- function isBrowserInWhiteList() {
31
- return sniffr.browser.version[MAJOR_VERSION_INDEX] >= WHITE_LIST[sniffr.browser.name];
32
- }
33
-
34
- export { WHITE_LIST, isBrowserInWhiteList };