UNPKG

9.77 kBJavaScriptView Raw
1"use strict";
2
3function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
4
5Object.defineProperty(exports, "__esModule", {
6 value: true
7});
8exports.default = SnackbarElement;
9
10var React = _interopRequireWildcard(require("react"));
11
12var _index = require("../button/index.js");
13
14var _overrides = require("../helpers/overrides.js");
15
16var _index2 = require("../styles/index.js");
17
18var _styledComponents = require("./styled-components.js");
19
20function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
21
22function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
23
24function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
25
26function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); }
27
28function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance"); }
29
30function _iterableToArrayLimit(arr, i) { if (!(Symbol.iterator in Object(arr) || Object.prototype.toString.call(arr) === "[object Arguments]")) { return; } var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
31
32function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
33
34var ActionButton = React.forwardRef(function (_ref, ref) {
35 var onClick = _ref.onClick,
36 message = _ref.message,
37 _ref$overrides = _ref.overrides,
38 overrides = _ref$overrides === void 0 ? {} : _ref$overrides;
39
40 var _useStyletron = (0, _index2.useStyletron)(),
41 _useStyletron2 = _slicedToArray(_useStyletron, 2),
42 theme = _useStyletron2[1];
43
44 var _getOverrides = (0, _overrides.getOverrides)(overrides.ActionButtonContainer, _styledComponents.StyledActionButtonContainer),
45 _getOverrides2 = _slicedToArray(_getOverrides, 2),
46 ActionButtonContainer = _getOverrides2[0],
47 actionButtonContainerProps = _getOverrides2[1];
48
49 return React.createElement(ActionButtonContainer, actionButtonContainerProps, React.createElement(_index.Button, {
50 ref: ref,
51 overrides: {
52 BaseButton: {
53 style: {
54 color: theme.colors.contentInversePrimary,
55 marginRight: theme.direction === 'rtl' ? null : theme.sizing.scale100,
56 marginLeft: theme.direction === 'rtl' ? theme.sizing.scale100 : null,
57 width: '100%',
58 whiteSpace: 'nowrap',
59 ':hover': {
60 backgroundColor: theme.colors.borderInverseTransparent
61 },
62 ':active': {
63 backgroundColor: theme.colors.backgroundInverseSecondary
64 }
65 }
66 }
67 },
68 kind: _index.KIND.tertiary,
69 onClick: onClick,
70 shape: _index.SHAPE.pill
71 }, message));
72});
73
74function SnackbarElement(_ref2) {
75 var actionMessage = _ref2.actionMessage,
76 actionOnClick = _ref2.actionOnClick,
77 _ref2$focus = _ref2.focus,
78 focus = _ref2$focus === void 0 ? true : _ref2$focus,
79 message = _ref2.message,
80 _ref2$overrides = _ref2.overrides,
81 overrides = _ref2$overrides === void 0 ? {} : _ref2$overrides,
82 progress = _ref2.progress,
83 StartEnhancer = _ref2.startEnhancer;
84
85 var _useStyletron3 = (0, _index2.useStyletron)(),
86 _useStyletron4 = _slicedToArray(_useStyletron3, 1),
87 css = _useStyletron4[0];
88
89 var rootRef = React.useRef(null);
90
91 var _React$useState = React.useState(0),
92 _React$useState2 = _slicedToArray(_React$useState, 2),
93 rootWidth = _React$useState2[0],
94 setRootWidth = _React$useState2[1];
95
96 React.useEffect(function () {
97 if (typeof document !== 'undefined') {
98 var observer = new window.ResizeObserver(function (_ref3) {
99 var _ref4 = _slicedToArray(_ref3, 1),
100 entry = _ref4[0];
101
102 return setRootWidth(entry.contentRect.width);
103 });
104
105 if (rootRef.current) {
106 observer.observe(rootRef.current);
107 }
108
109 return function () {
110 return observer.disconnect();
111 };
112 }
113 }, []);
114 var actionMeasureRef = React.useRef(null);
115
116 var _React$useState3 = React.useState(0),
117 _React$useState4 = _slicedToArray(_React$useState3, 2),
118 actionMeasureWidth = _React$useState4[0],
119 setActionMeasureWidth = _React$useState4[1];
120
121 React.useEffect(function () {
122 if (typeof document !== 'undefined') {
123 var observer = new window.ResizeObserver(function (_ref5) {
124 var _ref6 = _slicedToArray(_ref5, 1),
125 entry = _ref6[0];
126
127 return setActionMeasureWidth(entry.contentRect.width);
128 });
129
130 if (actionMeasureRef.current) {
131 observer.observe(actionMeasureRef.current);
132 }
133
134 return function () {
135 return observer.disconnect();
136 };
137 }
138 }, [actionMeasureRef.current]);
139 var wrapActionButton = actionMeasureWidth > rootWidth / 2;
140
141 var _getOverrides3 = (0, _overrides.getOverrides)(overrides.Root, _styledComponents.StyledRoot),
142 _getOverrides4 = _slicedToArray(_getOverrides3, 2),
143 Root = _getOverrides4[0],
144 rootProps = _getOverrides4[1];
145
146 var _getOverrides5 = (0, _overrides.getOverrides)(overrides.Content, _styledComponents.StyledContent),
147 _getOverrides6 = _slicedToArray(_getOverrides5, 2),
148 Content = _getOverrides6[0],
149 contentProps = _getOverrides6[1];
150
151 var _getOverrides7 = (0, _overrides.getOverrides)(overrides.StartEnhancerContainer, _styledComponents.StyledStartEnhancerContainer),
152 _getOverrides8 = _slicedToArray(_getOverrides7, 2),
153 StartEnhancerContainer = _getOverrides8[0],
154 startEnhancerContainerProps = _getOverrides8[1];
155
156 var _getOverrides9 = (0, _overrides.getOverrides)(overrides.Spinner, _styledComponents.StyledSpinner),
157 _getOverrides10 = _slicedToArray(_getOverrides9, 2),
158 Spinner = _getOverrides10[0],
159 spinnerProps = _getOverrides10[1];
160
161 var _getOverrides11 = (0, _overrides.getOverrides)(overrides.Message, _styledComponents.StyledMessage),
162 _getOverrides12 = _slicedToArray(_getOverrides11, 2),
163 Message = _getOverrides12[0],
164 messageProps = _getOverrides12[1];
165
166 var _getOverrides13 = (0, _overrides.getOverrides)(overrides.WrapActionButtonContainer, _styledComponents.StyledWrapActionButtonContainer),
167 _getOverrides14 = _slicedToArray(_getOverrides13, 2),
168 WrapActionButtonContainer = _getOverrides14[0],
169 wrapActionButtonContainerProps = _getOverrides14[1];
170
171 var prevFocusRef = React.useRef(null);
172 var actionButtonRef = React.useRef(null);
173 React.useEffect(function () {
174 if (typeof document !== 'undefined') {
175 if (focus && actionButtonRef.current) {
176 prevFocusRef.current = document.activeElement; // $FlowFixMe
177
178 actionButtonRef.current.focus();
179 }
180
181 return function () {
182 if (prevFocusRef.current) {
183 prevFocusRef.current.focus();
184 }
185 };
186 }
187 }, [focus]);
188 return React.createElement(React.Fragment, null, actionMessage && React.createElement("div", {
189 className: css({
190 position: 'absolute',
191 left: '-10000px',
192 top: '-10000px'
193 })
194 }, React.createElement(ActionButton, {
195 ref: actionMeasureRef,
196 message: actionMessage,
197 onClick: actionOnClick,
198 overrides: overrides
199 })), React.createElement(Root, _extends({
200 ref: rootRef
201 }, rootProps), React.createElement(Content, contentProps, (Boolean(StartEnhancer) || progress) && React.createElement(StartEnhancerContainer, startEnhancerContainerProps, StartEnhancer !== null && StartEnhancer !== undefined ? React.createElement(StartEnhancer, {
202 size: 24
203 }) : React.createElement(Spinner, _extends({
204 $height: 24,
205 $width: 24
206 }, spinnerProps))), React.createElement(Message, _extends({
207 $hasSuffix: Boolean(actionMessage)
208 }, messageProps), message), actionMessage && !wrapActionButton && React.createElement(ActionButton, {
209 ref: actionButtonRef,
210 message: actionMessage,
211 onClick: actionOnClick,
212 overrides: overrides
213 })), actionMessage && wrapActionButton && React.createElement(WrapActionButtonContainer, wrapActionButtonContainerProps, React.createElement(ActionButton, {
214 ref: actionButtonRef,
215 message: actionMessage,
216 onClick: actionOnClick,
217 overrides: overrides
218 }))));
219}
\No newline at end of file