@jetbrains/ring-ui 4.1.1 → 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 (314) hide show
  1. package/dist/_helpers/_rollupPluginBabelHelpers.js +34 -0
  2. package/dist/_helpers/anchor.js +32 -0
  3. package/dist/_helpers/badge.js +3 -0
  4. package/dist/_helpers/button-group.js +3 -0
  5. package/dist/_helpers/button-set.js +3 -0
  6. package/dist/_helpers/button-toolbar.js +3 -0
  7. package/dist/_helpers/button__classes.js +39 -0
  8. package/dist/_helpers/card.js +75 -0
  9. package/dist/_helpers/checkbox.js +3 -0
  10. package/dist/_helpers/date-picker.js +3 -0
  11. package/dist/_helpers/dialog__body-scroll-preventer.js +57 -0
  12. package/dist/_helpers/error-message.js +3 -0
  13. package/dist/_helpers/footer.js +121 -0
  14. package/dist/_helpers/grid.js +3 -0
  15. package/dist/_helpers/group.js +3 -0
  16. package/dist/_helpers/header.js +3 -0
  17. package/dist/_helpers/icon.js +3 -0
  18. package/dist/_helpers/inject-styles.js +22 -0
  19. package/dist/_helpers/input.js +3 -0
  20. package/dist/_helpers/island.js +3 -0
  21. package/dist/_helpers/link.js +3 -0
  22. package/dist/_helpers/list.js +3 -0
  23. package/dist/_helpers/loader-screen.js +3 -0
  24. package/dist/_helpers/panel.js +3 -0
  25. package/dist/_helpers/query-assist__suggestions.js +95 -0
  26. package/dist/_helpers/radio.js +3 -0
  27. package/dist/_helpers/select__filter.js +76 -0
  28. package/dist/_helpers/services-link.js +40 -0
  29. package/dist/_helpers/sidebar.js +125 -0
  30. package/dist/_helpers/table.js +3 -0
  31. package/dist/_helpers/tabs.js +3 -0
  32. package/dist/_helpers/title.js +99 -0
  33. package/dist/alert/alert.js +260 -0
  34. package/dist/alert/container.js +48 -0
  35. package/dist/alert-service/alert-service.js +170 -0
  36. package/dist/analytics/analytics.js +116 -0
  37. package/dist/analytics/analytics__custom-plugin.js +127 -0
  38. package/dist/analytics/analytics__fus-plugin.js +101 -0
  39. package/dist/analytics/analytics__ga-plugin.js +66 -0
  40. package/dist/analytics/analytics__plugin-utils.js +79 -0
  41. package/dist/analytics-ng/analytics-ng.js +94 -0
  42. package/dist/auth/auth.js +93 -0
  43. package/dist/auth/auth__core.js +1025 -0
  44. package/dist/auth/background-flow.js +122 -0
  45. package/dist/auth/down-notification.js +114 -0
  46. package/dist/auth/iframe-flow.js +150 -0
  47. package/dist/auth/landing-entry.js +5 -0
  48. package/dist/auth/landing.js +87 -0
  49. package/dist/auth/request-builder.js +75 -0
  50. package/dist/auth/response-parser.js +117 -0
  51. package/dist/auth/storage.js +280 -0
  52. package/dist/auth/token-validator.js +176 -0
  53. package/dist/auth/window-flow.js +133 -0
  54. package/dist/auth-dialog/auth-dialog.js +134 -0
  55. package/dist/auth-dialog-service/auth-dialog-service.js +68 -0
  56. package/dist/auth-ng/auth-ng.js +203 -0
  57. package/dist/auth-ng/auth-ng.mock.js +33 -0
  58. package/dist/autofocus-ng/autofocus-ng.js +50 -0
  59. package/dist/avatar/avatar-example-datauri.js +26 -0
  60. package/dist/avatar/avatar.js +161 -0
  61. package/dist/avatar/fallback-avatar.js +141 -0
  62. package/dist/avatar-editor-ng/avatar-editor-ng.js +164 -0
  63. package/dist/avatar-editor-ng/avatar-editor-ng__template.js +30 -0
  64. package/dist/avatar-ng/avatar-ng.js +18 -0
  65. package/dist/badge/badge.js +50 -0
  66. package/dist/badge-ng/badge-ng.js +16 -0
  67. package/dist/breadcrumb-ng/breadcrumb-ng.js +61 -0
  68. package/dist/button/button.js +123 -0
  69. package/dist/button/button__classes.js +5 -0
  70. package/dist/button-group/button-group.js +30 -0
  71. package/dist/button-group/caption.js +24 -0
  72. package/dist/button-group-ng/button-group-ng.js +38 -0
  73. package/dist/button-ng/button-ng.js +223 -0
  74. package/dist/button-set/button-set.js +26 -0
  75. package/dist/button-set-ng/button-set-ng.js +19 -0
  76. package/dist/button-toolbar/button-toolbar.js +29 -0
  77. package/dist/button-toolbar-ng/button-toolbar-ng.js +23 -0
  78. package/dist/caret/caret.js +264 -0
  79. package/dist/checkbox/checkbox.js +108 -0
  80. package/dist/checkbox-ng/checkbox-ng.js +55 -0
  81. package/dist/code/code.js +136 -0
  82. package/dist/compiler-ng/compiler-ng.js +53 -0
  83. package/dist/confirm/confirm.js +125 -0
  84. package/dist/confirm-ng/confirm-ng.js +66 -0
  85. package/dist/confirm-service/confirm-service.js +114 -0
  86. package/dist/content-layout/content-layout.js +65 -0
  87. package/dist/content-layout/sidebar.js +6 -0
  88. package/dist/contenteditable/contenteditable.js +78 -0
  89. package/dist/data-list/data-list.js +206 -0
  90. package/dist/data-list/data-list.mock.js +190 -0
  91. package/dist/data-list/item.js +227 -0
  92. package/dist/data-list/selection.js +101 -0
  93. package/dist/data-list/title.js +18 -0
  94. package/dist/data-list-ng/data-list-ng.js +59 -0
  95. package/dist/date-picker/consts.js +69 -0
  96. package/dist/date-picker/date-input.js +173 -0
  97. package/dist/date-picker/date-picker.js +365 -0
  98. package/dist/date-picker/date-popup.js +482 -0
  99. package/dist/date-picker/day.js +119 -0
  100. package/dist/date-picker/formats.js +3 -0
  101. package/dist/date-picker/month-names.js +99 -0
  102. package/dist/date-picker/month-slider.js +83 -0
  103. package/dist/date-picker/month.js +54 -0
  104. package/dist/date-picker/months.js +121 -0
  105. package/dist/date-picker/weekdays.js +32 -0
  106. package/dist/date-picker/years.js +109 -0
  107. package/dist/dialog/dialog.js +200 -0
  108. package/dist/dialog/dialog__body-scroll-preventer.js +2 -0
  109. package/dist/dialog-ng/dialog-ng.js +601 -0
  110. package/dist/dialog-ng/dialog-ng__template.js +71 -0
  111. package/dist/docked-panel-ng/docked-panel-ng.js +170 -0
  112. package/dist/dropdown/anchor.js +17 -0
  113. package/dist/dropdown/dropdown.js +234 -0
  114. package/dist/dropdown-menu/dropdown-menu.js +175 -0
  115. package/dist/error-bubble/error-bubble.js +57 -0
  116. package/dist/error-message/error-message.js +55 -0
  117. package/dist/error-message-ng/error-message-ng.js +53 -0
  118. package/dist/footer/footer.js +11 -0
  119. package/dist/footer-ng/footer-ng.js +75 -0
  120. package/dist/form-ng/form-ng.js +169 -0
  121. package/dist/global/angular-component-factory.js +82 -0
  122. package/dist/global/compose.js +9 -0
  123. package/dist/global/composeRefs.js +15 -0
  124. package/dist/global/conic-gradient.js +35 -0
  125. package/dist/global/create-stateful-context.js +54 -0
  126. package/dist/global/data-tests.js +22 -0
  127. package/dist/global/dom.js +124 -0
  128. package/dist/global/focus-sensor-hoc.js +145 -0
  129. package/dist/global/fuzzy-highlight.js +67 -0
  130. package/dist/global/get-event-key.js +111 -0
  131. package/dist/global/get-uid.js +15 -0
  132. package/dist/global/inject-styles.js +17 -0
  133. package/dist/global/linear-function.js +17 -0
  134. package/dist/global/listeners.js +42 -0
  135. package/dist/global/memoize.js +18 -0
  136. package/dist/global/normalize-indent.js +28 -0
  137. package/dist/global/promise-with-timeout.js +13 -0
  138. package/dist/global/radial-gradient-mask.js +49 -0
  139. package/dist/global/react-dom-renderer.js +45 -0
  140. package/dist/global/rerender-hoc.js +51 -0
  141. package/dist/global/ring-angular-component.js +24 -0
  142. package/dist/global/schedule-raf.js +31 -0
  143. package/dist/global/sniffer.js +6 -0
  144. package/dist/global/supports-css.js +20 -0
  145. package/dist/global/theme.js +54 -0
  146. package/dist/global/trivial-template-tag.js +15 -0
  147. package/dist/global/url.js +163 -0
  148. package/dist/global/variables_dark.js +57 -0
  149. package/dist/grid/col.js +60 -0
  150. package/dist/grid/grid.js +33 -0
  151. package/dist/grid/row.js +64 -0
  152. package/dist/group/group.js +31 -0
  153. package/dist/group-ng/group-ng.js +11 -0
  154. package/dist/header/header.js +147 -0
  155. package/dist/header/logo.js +38 -0
  156. package/dist/header/profile.js +217 -0
  157. package/dist/header/services-link.js +11 -0
  158. package/dist/header/services.js +136 -0
  159. package/dist/header/smart-profile.js +230 -0
  160. package/dist/header/smart-services.js +160 -0
  161. package/dist/header/tray-icon.js +45 -0
  162. package/dist/header/tray.js +31 -0
  163. package/dist/heading/heading.js +73 -0
  164. package/dist/http/http.js +216 -0
  165. package/dist/http/http.mock.js +65 -0
  166. package/dist/hub-source/hub-source.js +130 -0
  167. package/dist/hub-source/hub-source__user.js +28 -0
  168. package/dist/hub-source/hub-source__users-groups.js +62 -0
  169. package/dist/icon/icon.js +105 -0
  170. package/dist/icon/icon__constants.js +33 -0
  171. package/dist/icon/icon__svg.js +81 -0
  172. package/dist/icon/index.js +10 -0
  173. package/dist/icon-ng/icon-ng.js +89 -0
  174. package/dist/input/input.js +228 -0
  175. package/dist/input-ng/input-ng.js +166 -0
  176. package/dist/island/adaptive-island-hoc.js +47 -0
  177. package/dist/island/content.js +156 -0
  178. package/dist/island/header.js +83 -0
  179. package/dist/island/island.js +50 -0
  180. package/dist/island-legacy/content-legacy.js +26 -0
  181. package/dist/island-legacy/header-legacy.js +28 -0
  182. package/dist/island-legacy/island-legacy.js +28 -0
  183. package/dist/island-ng/island-content-ng.js +56 -0
  184. package/dist/island-ng/island-header-ng.js +32 -0
  185. package/dist/island-ng/island-ng-class-fixer.js +9 -0
  186. package/dist/island-ng/island-ng.js +31 -0
  187. package/dist/link/clickableLink.js +63 -0
  188. package/dist/link/link.js +114 -0
  189. package/dist/link-ng/link-ng.js +25 -0
  190. package/dist/list/consts.js +26 -0
  191. package/dist/list/list.js +812 -0
  192. package/dist/list/list__custom.js +85 -0
  193. package/dist/list/list__hint.js +26 -0
  194. package/dist/list/list__item.js +204 -0
  195. package/dist/list/list__link.js +64 -0
  196. package/dist/list/list__separator.js +30 -0
  197. package/dist/list/list__title.js +39 -0
  198. package/dist/list/list__users-groups-source.js +128 -0
  199. package/dist/loader/loader.js +70 -0
  200. package/dist/loader/loader__core.js +272 -0
  201. package/dist/loader-inline/inject-styles.js +11 -0
  202. package/dist/loader-inline/loader-inline.js +56 -0
  203. package/dist/loader-inline-ng/loader-inline-ng.js +42 -0
  204. package/dist/loader-ng/loader-ng.js +43 -0
  205. package/dist/loader-screen/loader-screen.js +43 -0
  206. package/dist/loader-screen-ng/loader-screen-ng.js +99 -0
  207. package/dist/login-dialog/login-dialog.js +186 -0
  208. package/dist/login-dialog/service.js +69 -0
  209. package/dist/markdown/code.js +30 -0
  210. package/dist/markdown/heading.js +23 -0
  211. package/dist/markdown/link.js +30 -0
  212. package/dist/markdown/markdown.js +73 -0
  213. package/dist/message/message.js +233 -0
  214. package/dist/message-bundle-ng/message-bundle-ng.js +111 -0
  215. package/dist/old-browsers-message/old-browsers-message.js +100 -0
  216. package/dist/old-browsers-message/old-browsers-message__stop.js +4 -0
  217. package/dist/old-browsers-message/white-list.js +33 -0
  218. package/dist/pager/pager.js +361 -0
  219. package/dist/pager-ng/pager-ng.js +96 -0
  220. package/dist/panel/panel.js +31 -0
  221. package/dist/panel-ng/panel-ng.js +16 -0
  222. package/dist/permissions/permissions.js +200 -0
  223. package/dist/permissions/permissions__cache.js +272 -0
  224. package/dist/permissions-ng/permissions-ng.js +274 -0
  225. package/dist/place-under-ng/place-under-ng.js +157 -0
  226. package/dist/popup/popup.consts.js +41 -0
  227. package/dist/popup/popup.js +389 -0
  228. package/dist/popup/popup.target.js +26 -0
  229. package/dist/popup/position.js +279 -0
  230. package/dist/popup-menu/popup-menu.js +115 -0
  231. package/dist/progress-bar/progress-bar.js +113 -0
  232. package/dist/progress-bar-ng/progress-bar-ng.js +15 -0
  233. package/dist/promised-click-ng/promised-click-ng.js +126 -0
  234. package/dist/proxy-attrs/proxy-attrs.js +19 -0
  235. package/dist/query-assist/query-assist.js +1092 -0
  236. package/dist/query-assist/query-assist__suggestions.js +47 -0
  237. package/dist/query-assist-ng/query-assist-ng.js +82 -0
  238. package/dist/radio/radio.js +41 -0
  239. package/dist/radio/radio__item.js +77 -0
  240. package/dist/radio-ng/radio-ng.js +63 -0
  241. package/dist/save-field-ng/save-field-ng.js +335 -0
  242. package/dist/save-field-ng/save-field-ng__template.js +34 -0
  243. package/dist/select/select.js +1336 -0
  244. package/dist/select/select__filter.js +54 -0
  245. package/dist/select/select__popup.js +546 -0
  246. package/dist/select-ng/select-ng.js +621 -0
  247. package/dist/select-ng/select-ng__lazy.js +150 -0
  248. package/dist/select-ng/select-ng__options.js +145 -0
  249. package/dist/shortcuts/core.js +245 -0
  250. package/dist/shortcuts/shortcut-title.js +51 -0
  251. package/dist/shortcuts/shortcuts-hoc.js +41 -0
  252. package/dist/shortcuts/shortcuts.js +72 -0
  253. package/dist/shortcuts-hint-ng/shortcuts-hint-ng.js +120 -0
  254. package/dist/shortcuts-hint-ng/shortcuts-hint-ng__template.js +50 -0
  255. package/dist/shortcuts-ng/shortcuts-ng.js +261 -0
  256. package/dist/sidebar-ng/sidebar-ng.js +111 -0
  257. package/dist/sidebar-ng/sidebar-ng__button-template.js +20 -0
  258. package/dist/sidebar-ng/sidebar-ng__template.js +12 -0
  259. package/dist/storage/storage.js +56 -0
  260. package/dist/storage/storage__fallback.js +214 -0
  261. package/dist/storage/storage__local.js +151 -0
  262. package/dist/style.css +1 -0
  263. package/dist/tab-trap/tab-trap.js +176 -0
  264. package/dist/table/cell.js +25 -0
  265. package/dist/table/disable-hover-hoc.js +53 -0
  266. package/dist/table/header-cell.js +90 -0
  267. package/dist/table/header.js +191 -0
  268. package/dist/table/multitable.js +140 -0
  269. package/dist/table/row-with-focus-sensor.js +81 -0
  270. package/dist/table/row.js +271 -0
  271. package/dist/table/selection-adapter.js +14 -0
  272. package/dist/table/selection-shortcuts-hoc.js +214 -0
  273. package/dist/table/selection.js +221 -0
  274. package/dist/table/smart-table.js +119 -0
  275. package/dist/table/table.js +404 -0
  276. package/dist/table-legacy-ng/table-legacy-ng.js +501 -0
  277. package/dist/table-legacy-ng/table-legacy-ng__pager.js +122 -0
  278. package/dist/table-legacy-ng/table-legacy-ng__selection-navigate-actions.js +123 -0
  279. package/dist/table-legacy-ng/table-legacy-ng__selection.js +179 -0
  280. package/dist/table-legacy-ng/table-legacy-ng__toolbar.js +56 -0
  281. package/dist/table-ng/smart-table-ng.js +65 -0
  282. package/dist/table-ng/table-ng.js +64 -0
  283. package/dist/tabs/collapsible-more.js +196 -0
  284. package/dist/tabs/collapsible-tab.js +90 -0
  285. package/dist/tabs/collapsible-tabs.js +360 -0
  286. package/dist/tabs/custom-item.js +13 -0
  287. package/dist/tabs/dumb-tabs.js +161 -0
  288. package/dist/tabs/smart-tabs.js +104 -0
  289. package/dist/tabs/tab-link.js +41 -0
  290. package/dist/tabs/tab.js +32 -0
  291. package/dist/tabs/tabs.js +69 -0
  292. package/dist/tabs-ng/tabs-ng.js +193 -0
  293. package/dist/tabs-ng/tabs-ng__template.js +40 -0
  294. package/dist/tag/tag.js +196 -0
  295. package/dist/tags-input/tags-input.js +478 -0
  296. package/dist/tags-input-ng/tags-input-ng.js +89 -0
  297. package/dist/tags-list/tags-list.js +93 -0
  298. package/dist/template-ng/template-ng.js +70 -0
  299. package/dist/text/text.js +36 -0
  300. package/dist/theme-ng/theme-ng.js +44 -0
  301. package/dist/title-ng/title-ng.js +114 -0
  302. package/dist/toggle/toggle.js +77 -0
  303. package/dist/toggle-ng/toggle-ng.js +16 -0
  304. package/dist/tooltip/tooltip.js +207 -0
  305. package/dist/tooltip-ng/tooltip-ng.js +98 -0
  306. package/dist/user-agreement/service.js +409 -0
  307. package/dist/user-agreement/toolbox.eula.js +162 -0
  308. package/dist/user-agreement/user-agreement.js +167 -0
  309. package/dist/user-card/card.js +17 -0
  310. package/dist/user-card/smart-user-card-tooltip.js +112 -0
  311. package/dist/user-card/tooltip.js +93 -0
  312. package/dist/user-card/user-card.js +49 -0
  313. package/dist/user-card-ng/user-card-ng.js +59 -0
  314. package/package.json +2 -2
@@ -0,0 +1,389 @@
1
+ import { _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
2
+ import React, { PureComponent } from 'react';
3
+ import { createPortal } from 'react-dom';
4
+ import PropTypes from 'prop-types';
5
+ import classNames from 'classnames';
6
+ import getUID from '../global/get-uid.js';
7
+ import scheduleRAF from '../global/schedule-raf.js';
8
+ import { Listeners, getStyles } from '../global/dom.js';
9
+ import Shortcuts from '../shortcuts/shortcuts.js';
10
+ import joinDataTestAttributes from '../global/data-tests.js';
11
+ import TabTrap from '../tab-trap/tab-trap.js';
12
+ import position, { positionPropKeys } from './position.js';
13
+ import { Display, DEFAULT_DIRECTIONS, Directions, Dimension, MinWidth, MaxHeight } from './popup.consts.js';
14
+ import { PopupTargetContext, PopupTarget } from './popup.target.js';
15
+ export { PopupTarget, PopupTargetContext } from './popup.target.js';
16
+ import '../shortcuts/core.js';
17
+ import 'combokeys';
18
+ import '../global/sniffer.js';
19
+ import 'sniffr';
20
+
21
+ var modules_2f69e2e2 = {"popup":"popup_rui_d157 font_rui_750f","hidden":"hidden_rui_d157","showing":"showing_rui_d157","attached":"attached_rui_d157"};
22
+
23
+ const stop = e => e.stopPropagation();
24
+
25
+ const getPopupContainer = target => typeof target === 'string' ? document.querySelector(`[data-portaltarget=${target}]`) : target;
26
+ /**
27
+ * @constructor
28
+ * @name Popup
29
+ * @extends {ReactComponent}
30
+ */
31
+
32
+ class Popup extends PureComponent {
33
+ constructor() {
34
+ super(...arguments);
35
+
36
+ _defineProperty(this, "state", {
37
+ display: Display.SHOWING
38
+ });
39
+
40
+ _defineProperty(this, "listeners", new Listeners());
41
+
42
+ _defineProperty(this, "redrawScheduler", scheduleRAF(true));
43
+
44
+ _defineProperty(this, "uid", getUID('popup-'));
45
+
46
+ _defineProperty(this, "calculateDisplay", prevState => ({ ...prevState,
47
+ display: this.props.hidden ? Display.SHOWING : Display.SHOWN
48
+ }));
49
+
50
+ _defineProperty(this, "portalRef", el => {
51
+ this.node = el;
52
+ this.parent = el && el.parentElement;
53
+
54
+ if (el && this.getContainer()) {
55
+ this._redraw();
56
+ }
57
+ });
58
+
59
+ _defineProperty(this, "popupRef", el => {
60
+ this.popup = el;
61
+
62
+ this._redraw();
63
+ });
64
+
65
+ _defineProperty(this, "containerRef", el => {
66
+ this.container = el;
67
+ });
68
+
69
+ _defineProperty(this, "_updateDirection", newDirection => {
70
+ if (this.state.direction !== newDirection) {
71
+ this.setState({
72
+ direction: newDirection
73
+ });
74
+
75
+ if (this.props.onDirectionChange) {
76
+ this.props.onDirectionChange(newDirection);
77
+ }
78
+ }
79
+ });
80
+
81
+ _defineProperty(this, "_updatePosition", () => {
82
+ if (this.popup) {
83
+ this.popup.style.position = 'absolute';
84
+
85
+ if (this.isVisible()) {
86
+ const {
87
+ styles: style,
88
+ direction
89
+ } = this.position();
90
+ Object.keys(style).forEach(key => {
91
+ const value = style[key];
92
+
93
+ if (typeof value === 'number') {
94
+ this.popup.style[key] = `${value}px`;
95
+ } else {
96
+ this.popup.style[key] = value.toString();
97
+ }
98
+ });
99
+
100
+ this._updateDirection(direction);
101
+ }
102
+
103
+ this.setState(this.calculateDisplay);
104
+ }
105
+ });
106
+
107
+ _defineProperty(this, "_redraw", () => {
108
+ if (this.isVisible()) {
109
+ this.redrawScheduler(this._updatePosition);
110
+ }
111
+ });
112
+
113
+ _defineProperty(this, "_onEscPress", evt => {
114
+ this.props.onEscPress(evt);
115
+
116
+ this._onCloseAttempt(evt, true);
117
+ });
118
+
119
+ _defineProperty(this, "_onDocumentClick", evt => {
120
+ if (this.container && this.container.contains(evt.target) || !this._listenersEnabled || this.props.dontCloseOnAnchorClick && this._getAnchor() && this._getAnchor().contains(evt.target)) {
121
+ return;
122
+ }
123
+
124
+ this.props.onOutsideClick(evt);
125
+
126
+ this._onCloseAttempt(evt, false);
127
+ });
128
+
129
+ _defineProperty(this, "shortcutsScope", this.uid);
130
+
131
+ _defineProperty(this, "shortcutsMap", {
132
+ esc: this._onEscPress
133
+ });
134
+ }
135
+
136
+ componentDidMount() {
137
+ if (!this.props.client) {
138
+ // eslint-disable-next-line react/no-did-mount-set-state
139
+ this.setState({
140
+ client: true
141
+ });
142
+ }
143
+
144
+ if (!this.props.hidden) {
145
+ this._setListenersEnabled(true);
146
+ }
147
+ }
148
+
149
+ componentDidUpdate(prevProps, prevState) {
150
+ const {
151
+ hidden
152
+ } = this.props;
153
+
154
+ if (this.props !== prevProps) {
155
+ if (prevProps.hidden !== hidden) {
156
+ this._setListenersEnabled(!hidden);
157
+ }
158
+
159
+ this._redraw();
160
+ }
161
+
162
+ if (this.props.onShow && !hidden && this.state.display === Display.SHOWN && (prevProps.hidden || prevState.display !== Display.SHOWN)) {
163
+ this.props.onShow();
164
+ }
165
+ }
166
+
167
+ componentWillUnmount() {
168
+ this._setListenersEnabled(false);
169
+
170
+ this.popup = null;
171
+ }
172
+
173
+ shouldUseShortcuts() {
174
+ const {
175
+ shortcuts,
176
+ hidden
177
+ } = this.props;
178
+ return shortcuts && !hidden;
179
+ }
180
+
181
+ getContainer() {
182
+ const target = this.props.target || this.ringPopupTarget;
183
+ return target && getPopupContainer(target);
184
+ }
185
+
186
+ position() {
187
+ const positionProps = positionPropKeys.reduce((acc, key) => {
188
+ acc[key] = this.props[key];
189
+ return acc;
190
+ }, {});
191
+ const container = this.getContainer();
192
+ return position({
193
+ popup: this.popup,
194
+ container: container && getStyles(container).position !== 'static' ? container : null,
195
+ anchor: this._getAnchor(),
196
+ ...positionProps
197
+ });
198
+ }
199
+
200
+ _getAnchor() {
201
+ return this.props.anchorElement || this.parent;
202
+ }
203
+ /**
204
+ * @param {boolean} enable
205
+ * @private
206
+ */
207
+
208
+
209
+ _setListenersEnabled(enable) {
210
+ if (enable && !this._listenersEnabled) {
211
+ setTimeout(() => {
212
+ this._listenersEnabled = true;
213
+ this.listeners.add(window, 'resize', this._redraw);
214
+ this.listeners.add(window, 'scroll', this._redraw);
215
+ this.listeners.add(document, 'pointerdown', this._onDocumentClick, true);
216
+
217
+ let el = this._getAnchor();
218
+
219
+ while (el) {
220
+ this.listeners.add(el, 'scroll', this._redraw);
221
+ el = el.parentElement;
222
+ }
223
+ }, 0);
224
+ return;
225
+ }
226
+
227
+ if (!enable && this._listenersEnabled) {
228
+ this.listeners.removeAll();
229
+ this._listenersEnabled = false;
230
+ }
231
+ }
232
+ /**
233
+ * Returns visibility state
234
+ * @return {boolean}
235
+ */
236
+
237
+
238
+ isVisible() {
239
+ return !this.props.hidden;
240
+ }
241
+
242
+ _onCloseAttempt(evt, isEsc) {
243
+ this.props.onCloseAttempt(evt, isEsc);
244
+ }
245
+
246
+ getInternalContent() {
247
+ const {
248
+ trapFocus,
249
+ autoFocusFirst,
250
+ children
251
+ } = this.props;
252
+ return trapFocus ? /*#__PURE__*/React.createElement(TabTrap, {
253
+ autoFocusFirst: autoFocusFirst,
254
+ focusBackOnExit: true
255
+ }, children) : children;
256
+ }
257
+
258
+ render() {
259
+ const {
260
+ className,
261
+ style,
262
+ hidden,
263
+ attached,
264
+ keepMounted,
265
+ client,
266
+ onMouseDown,
267
+ onMouseUp,
268
+ onMouseOver,
269
+ onMouseOut,
270
+ onContextMenu,
271
+ 'data-test': dataTest
272
+ } = this.props;
273
+ const showing = this.state.display === Display.SHOWING;
274
+ const classes = classNames(className, modules_2f69e2e2.popup, {
275
+ [modules_2f69e2e2.attached]: attached,
276
+ [modules_2f69e2e2.hidden]: hidden,
277
+ [modules_2f69e2e2.showing]: showing
278
+ });
279
+ const direction = (this.state.direction || '').toLowerCase().replace(/[_]/g, '-');
280
+ return /*#__PURE__*/React.createElement(PopupTargetContext.Consumer, null, value => {
281
+ this.ringPopupTarget = value;
282
+ return /*#__PURE__*/React.createElement("span", {
283
+ // prevent bubbling through portal
284
+ onClick: stop // This handler only blocks bubbling through React portal
285
+ ,
286
+ role: "presentation",
287
+ ref: this.portalRef
288
+ }, this.shouldUseShortcuts() && /*#__PURE__*/React.createElement(Shortcuts, {
289
+ map: this.shortcutsMap,
290
+ scope: this.shortcutsScope
291
+ }), (client || this.state.client) && (keepMounted || !hidden) && /*#__PURE__*/createPortal( /*#__PURE__*/React.createElement(PopupTarget, {
292
+ id: this.uid,
293
+ ref: this.containerRef,
294
+ onMouseOver: onMouseOver,
295
+ onFocus: onMouseOver,
296
+ onMouseOut: onMouseOut,
297
+ onBlur: onMouseOut,
298
+ onContextMenu: onContextMenu
299
+ }, /*#__PURE__*/React.createElement("div", {
300
+ "data-test": joinDataTestAttributes('ring-popup', dataTest),
301
+ "data-test-shown": !hidden && !showing,
302
+ "data-test-direction": direction,
303
+ ref: this.popupRef,
304
+ className: classes,
305
+ style: style,
306
+ onMouseDown: onMouseDown,
307
+ onMouseUp: onMouseUp // mouse handlers are used to track clicking on inner elements
308
+ ,
309
+ role: "presentation"
310
+ }, this.getInternalContent())), this.getContainer() || document.body));
311
+ });
312
+ }
313
+
314
+ }
315
+
316
+ _defineProperty(Popup, "propTypes", {
317
+ anchorElement: PropTypes.instanceOf(Node),
318
+ target: PropTypes.oneOfType([PropTypes.string, PropTypes.instanceOf(Element)]),
319
+ className: PropTypes.string,
320
+ style: PropTypes.object,
321
+ hidden: PropTypes.bool.isRequired,
322
+ onOutsideClick: PropTypes.func,
323
+ onEscPress: PropTypes.func,
324
+ // onCloseAttempt is a common callback for ESC pressing and outside clicking.
325
+ // Use it if you don't need different behaviors for this cases.
326
+ onCloseAttempt: PropTypes.func,
327
+ children: PropTypes.node.isRequired,
328
+ dontCloseOnAnchorClick: PropTypes.bool,
329
+ shortcuts: PropTypes.bool,
330
+ keepMounted: PropTypes.bool,
331
+ // pass this prop to preserve the popup's DOM state while hidden
332
+ 'data-test': PropTypes.string,
333
+ client: PropTypes.bool,
334
+ // true means that it's never used in SSR
335
+ directions: PropTypes.arrayOf(PropTypes.string),
336
+ autoPositioning: PropTypes.bool,
337
+ autoCorrectTopOverflow: PropTypes.bool,
338
+ left: PropTypes.number,
339
+ top: PropTypes.number,
340
+ maxHeight: PropTypes.number,
341
+ minWidth: PropTypes.number,
342
+ sidePadding: PropTypes.number,
343
+ attached: PropTypes.bool,
344
+ // Popup adjacent to an input, without upper border and shadow
345
+ onMouseDown: PropTypes.func,
346
+ onMouseUp: PropTypes.func,
347
+ onMouseOver: PropTypes.func,
348
+ onMouseOut: PropTypes.func,
349
+ onContextMenu: PropTypes.func,
350
+ onDirectionChange: PropTypes.func,
351
+ onShow: PropTypes.func,
352
+ // set to true whenever popup contains focusable and scrollable content
353
+ trapFocus: PropTypes.bool,
354
+ autoFocusFirst: PropTypes.bool
355
+ });
356
+
357
+ _defineProperty(Popup, "defaultProps", {
358
+ shortcuts: true,
359
+ hidden: false,
360
+
361
+ onOutsideClick() {},
362
+
363
+ onEscPress() {},
364
+
365
+ onCloseAttempt() {},
366
+
367
+ dontCloseOnAnchorClick: false,
368
+ keepMounted: false,
369
+ directions: DEFAULT_DIRECTIONS,
370
+ autoPositioning: true,
371
+ autoCorrectTopOverflow: true,
372
+ left: 0,
373
+ top: 0,
374
+ offset: 0,
375
+ sidePadding: 8,
376
+ attached: false,
377
+ trapFocus: false,
378
+ autoFocusFirst: false,
379
+ legacy: false
380
+ });
381
+
382
+ _defineProperty(Popup, "PopupProps", {
383
+ Directions,
384
+ Dimension,
385
+ MinWidth,
386
+ MaxHeight
387
+ });
388
+
389
+ export { Popup as default, getPopupContainer };
@@ -0,0 +1,26 @@
1
+ import { a as _extends } from '../_helpers/_rollupPluginBabelHelpers.js';
2
+ import React, { createContext, forwardRef } from 'react';
3
+ import PropTypes from 'prop-types';
4
+
5
+ const PopupTargetContext = /*#__PURE__*/createContext();
6
+ const PopupTarget = /*#__PURE__*/forwardRef(function PopupTarget(_ref, ref) {
7
+ let {
8
+ id,
9
+ children,
10
+ ...restProps
11
+ } = _ref;
12
+ const isFunctionChild = typeof children === 'function';
13
+ const target = /*#__PURE__*/React.createElement("div", _extends({}, restProps, {
14
+ "data-portaltarget": id,
15
+ ref: ref
16
+ }), !isFunctionChild && children);
17
+ return /*#__PURE__*/React.createElement(PopupTargetContext.Provider, {
18
+ value: id
19
+ }, isFunctionChild ? children(target) : target);
20
+ });
21
+ PopupTarget.propTypes = {
22
+ id: PropTypes.string.isRequired,
23
+ children: PropTypes.oneOfType([PropTypes.node, PropTypes.func])
24
+ };
25
+
26
+ export { PopupTarget, PopupTargetContext };
@@ -0,0 +1,279 @@
1
+ import { getRect, isMounted, getDocumentScrollTop, getDocumentScrollLeft, getWindowHeight } from '../global/dom.js';
2
+ import { Directions, MaxHeight, Dimension, MinWidth } from './popup.consts.js';
3
+ export { Dimension, Directions, MaxHeight, MinWidth } from './popup.consts.js';
4
+ import '../_helpers/_rollupPluginBabelHelpers.js';
5
+
6
+ function getScrollingCoordinates(container) {
7
+ if (container !== null) {
8
+ return {
9
+ top: container.scrollTop,
10
+ left: container.scrollLeft
11
+ };
12
+ }
13
+
14
+ return {
15
+ top: getDocumentScrollTop(),
16
+ left: getDocumentScrollLeft()
17
+ };
18
+ }
19
+
20
+ function getPositionStyles(popup, anchorRect, anchorLeft, anchorTop, offset) {
21
+ const popupWidth = popup.clientWidth;
22
+ const popupHeight = popup.clientHeight;
23
+ const anchorBottom = anchorTop + anchorRect.height;
24
+ const anchorRight = anchorLeft + anchorRect.width;
25
+ const popupLeft = anchorLeft - popupWidth;
26
+ const popupTop = anchorTop - popupHeight;
27
+ const popupRightToLeft = anchorRight - popupWidth;
28
+ const popupHorizontalCenter = anchorLeft + anchorRect.width / 2 - popupWidth / 2;
29
+ const popupVerticalCenter = anchorTop + anchorRect.height / 2 - popupHeight / 2;
30
+ const popupBottomToTop = anchorBottom - popupHeight;
31
+ return {
32
+ [Directions.BOTTOM_RIGHT]: {
33
+ left: anchorLeft,
34
+ top: anchorBottom + offset
35
+ },
36
+ [Directions.BOTTOM_LEFT]: {
37
+ left: popupRightToLeft,
38
+ top: anchorBottom + offset
39
+ },
40
+ [Directions.BOTTOM_CENTER]: {
41
+ left: popupHorizontalCenter,
42
+ top: anchorBottom + offset
43
+ },
44
+ [Directions.TOP_RIGHT]: {
45
+ left: anchorLeft,
46
+ top: popupTop - offset
47
+ },
48
+ [Directions.TOP_LEFT]: {
49
+ left: popupRightToLeft,
50
+ top: popupTop - offset
51
+ },
52
+ [Directions.TOP_CENTER]: {
53
+ left: popupHorizontalCenter,
54
+ top: popupTop - offset
55
+ },
56
+ [Directions.LEFT_BOTTOM]: {
57
+ left: popupLeft - offset,
58
+ top: anchorTop
59
+ },
60
+ [Directions.LEFT_TOP]: {
61
+ left: popupLeft - offset,
62
+ top: popupBottomToTop
63
+ },
64
+ [Directions.LEFT_CENTER]: {
65
+ left: popupLeft - offset,
66
+ top: popupVerticalCenter
67
+ },
68
+ [Directions.RIGHT_BOTTOM]: {
69
+ left: anchorRight + offset,
70
+ top: anchorTop
71
+ },
72
+ [Directions.RIGHT_TOP]: {
73
+ left: anchorRight + offset,
74
+ top: popupBottomToTop
75
+ },
76
+ [Directions.RIGHT_CENTER]: {
77
+ left: anchorRight + offset,
78
+ top: popupVerticalCenter
79
+ }
80
+ };
81
+ }
82
+
83
+ function verticalOverflow(styles, scrollingCoordinates, attrs) {
84
+ const containerHeight = attrs.container !== null ? attrs.container.clientHeight : getWindowHeight();
85
+ const viewportMinX = scrollingCoordinates.top + attrs.sidePadding;
86
+ const viewportMaxX = scrollingCoordinates.top + containerHeight - attrs.sidePadding;
87
+ const topOverflow = Math.max(viewportMinX - styles.top, 0);
88
+ const popupHeight = attrs.popup.clientHeight;
89
+ const verticalDiff = styles.top + popupHeight - viewportMaxX;
90
+ const bottomOverflow = Math.max(verticalDiff, 0);
91
+ return topOverflow + bottomOverflow;
92
+ }
93
+
94
+ function horizontalOverflow(styles, scrollingCoordinates, attrs) {
95
+ const containerWidth = attrs.container !== null ? attrs.container.clientWidth : window.innerWidth;
96
+ const viewportMinY = scrollingCoordinates.left + attrs.sidePadding;
97
+ const viewportMaxY = scrollingCoordinates.left + containerWidth - attrs.sidePadding;
98
+ const leftOverflow = Math.max(viewportMinY - styles.left, 0);
99
+ const popupWidth = attrs.popup.clientWidth;
100
+ const horizontalDiff = styles.left + popupWidth - viewportMaxY;
101
+ const rightOverflow = Math.max(horizontalDiff, 0);
102
+ return leftOverflow + rightOverflow;
103
+ }
104
+
105
+ const positionPropKeys = ['directions', 'autoPositioning', 'autoCorrectTopOverflow', 'sidePadding', 'top', 'left', 'offset', 'maxHeight', 'minWidth'];
106
+ const defaultcontainerRect = {
107
+ top: 0,
108
+ left: 0
109
+ };
110
+
111
+ function handleTopOffScreen(_ref) {
112
+ let {
113
+ sidePadding,
114
+ styles,
115
+ anchorRect,
116
+ maxHeight,
117
+ popupScrollHeight,
118
+ direction,
119
+ scroll
120
+ } = _ref;
121
+ const BORDER_COMPENSATION = 1;
122
+ const {
123
+ TOP_LEFT,
124
+ TOP_RIGHT,
125
+ TOP_CENTER,
126
+ RIGHT_TOP,
127
+ LEFT_TOP
128
+ } = Directions;
129
+ const openedToTop = [TOP_LEFT, TOP_RIGHT, TOP_CENTER, RIGHT_TOP, LEFT_TOP].includes(direction);
130
+
131
+ if (!openedToTop) {
132
+ return styles;
133
+ }
134
+
135
+ const isAttachedToAnchorTop = [TOP_LEFT, TOP_CENTER, TOP_RIGHT].includes(direction);
136
+ const attachingPointY = isAttachedToAnchorTop ? anchorRect.top : anchorRect.bottom;
137
+ const effectiveHeight = maxHeight ? Math.min(popupScrollHeight, maxHeight) : popupScrollHeight;
138
+ const hypotheticalTop = attachingPointY - effectiveHeight;
139
+
140
+ if (hypotheticalTop <= sidePadding) {
141
+ styles.top = sidePadding + scroll.top;
142
+ styles.maxHeight = attachingPointY - sidePadding + BORDER_COMPENSATION;
143
+ }
144
+
145
+ return styles;
146
+ }
147
+
148
+ function maxHeightForDirection(direction, anchorNode, containerNode) {
149
+ const container = containerNode || document.documentElement;
150
+ const domRect = anchorNode.getBoundingClientRect();
151
+ const containerRect = container.getBoundingClientRect();
152
+ const topMaxHeight = Math.max(domRect.top - containerRect.top, 0);
153
+ const containerHeight = Math.max(containerRect.height, // XXX
154
+ // If container is the document element
155
+ // then we check client height too because we may have situation when
156
+ // "height" from "getBoundingClientRect" less then "clientHeight".
157
+ container === document.documentElement ? container.clientHeight : 0);
158
+ const bottomMaxHeight = Math.max(containerHeight - (topMaxHeight + domRect.height), 0);
159
+
160
+ switch (direction) {
161
+ case Directions.TOP_LEFT:
162
+ case Directions.TOP_CENTER:
163
+ case Directions.TOP_RIGHT:
164
+ return topMaxHeight;
165
+
166
+ case Directions.BOTTOM_LEFT:
167
+ case Directions.BOTTOM_CENTER:
168
+ case Directions.BOTTOM_RIGHT:
169
+ return bottomMaxHeight;
170
+
171
+ case Directions.LEFT_BOTTOM:
172
+ case Directions.RIGHT_BOTTOM:
173
+ return domRect.height + bottomMaxHeight;
174
+
175
+ case Directions.LEFT_TOP:
176
+ case Directions.RIGHT_TOP:
177
+ return domRect.height + topMaxHeight;
178
+
179
+ case Directions.RIGHT_CENTER:
180
+ case Directions.LEFT_CENTER:
181
+ return domRect.height / 2 + Math.min(bottomMaxHeight / 2, topMaxHeight / 2);
182
+
183
+ default:
184
+ return null;
185
+ }
186
+ }
187
+ function position(attrs) {
188
+ const {
189
+ popup,
190
+ anchor,
191
+ container,
192
+ directions,
193
+ autoPositioning,
194
+ sidePadding,
195
+ top,
196
+ left,
197
+ offset,
198
+ maxHeight,
199
+ minWidth,
200
+ autoCorrectTopOverflow = true
201
+ } = attrs;
202
+ let styles = {
203
+ top: 0,
204
+ left: 0
205
+ };
206
+ let chosenDirection = null;
207
+ const containerRect = container !== null ? getRect(container) : defaultcontainerRect;
208
+ const defaultAnchor = container !== null ? container : document.body;
209
+ const anchorRect = getRect(isMounted(anchor) ? anchor : defaultAnchor);
210
+ const scroll = getScrollingCoordinates(container);
211
+ const anchorLeft = anchorRect.left + scroll.left + left - containerRect.left;
212
+ const anchorTop = anchorRect.top + scroll.top + top - containerRect.top;
213
+
214
+ if (popup) {
215
+ const directionsMatrix = getPositionStyles(popup, anchorRect, anchorLeft, anchorTop, offset);
216
+
217
+ if (!autoPositioning || directions.length === 1) {
218
+ styles = directionsMatrix[directions[0]];
219
+ chosenDirection = directions[0];
220
+ } else {
221
+ const sortedByIncreasingOverflow = directions. // Fall back to the first option
222
+ concat(directions[0]).filter(direction => directionsMatrix[direction]).map(direction => ({
223
+ styles: directionsMatrix[direction],
224
+ direction
225
+ })).sort((_ref2, _ref3) => {
226
+ let {
227
+ styles: stylesA
228
+ } = _ref2;
229
+ let {
230
+ styles: stylesB
231
+ } = _ref3;
232
+ const overflowA = verticalOverflow(stylesA, scroll, attrs) + horizontalOverflow(stylesA, scroll, attrs);
233
+ const overflowB = verticalOverflow(stylesB, scroll, attrs) + horizontalOverflow(stylesB, scroll, attrs);
234
+ return overflowA - overflowB;
235
+ });
236
+ styles = sortedByIncreasingOverflow[0].styles;
237
+ chosenDirection = sortedByIncreasingOverflow[0].direction;
238
+ } // because of the anchor negative margin top and left also may become negative
239
+
240
+
241
+ ['left', 'top'].forEach(key => {
242
+ if (styles[key] < 0) {
243
+ styles[key] = 0;
244
+ }
245
+ });
246
+ }
247
+
248
+ if (maxHeight === MaxHeight.SCREEN || maxHeight === 'screen') {
249
+ // this feature works properly only when direction is BOTTOM_* or *_BOTTOM
250
+ styles.maxHeight = window.innerHeight + scroll.top - styles.top - Dimension.MARGIN;
251
+ } else if (maxHeight) {
252
+ styles.maxHeight = maxHeight;
253
+ }
254
+
255
+ if (autoCorrectTopOverflow) {
256
+ styles = handleTopOffScreen({
257
+ sidePadding,
258
+ styles,
259
+ anchorRect,
260
+ maxHeight,
261
+ direction: chosenDirection,
262
+ popupScrollHeight: popup.scrollHeight,
263
+ scroll
264
+ });
265
+ }
266
+
267
+ if (minWidth === MinWidth.TARGET || minWidth === 'target') {
268
+ styles.minWidth = anchorRect.width;
269
+ } else if (minWidth) {
270
+ styles.minWidth = anchorRect.width < minWidth ? minWidth : anchorRect.width;
271
+ }
272
+
273
+ return {
274
+ styles,
275
+ direction: chosenDirection
276
+ };
277
+ }
278
+
279
+ export { position as default, maxHeightForDirection, positionPropKeys };