1 | "use strict";
|
2 |
|
3 | function _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 |
|
5 | Object.defineProperty(exports, "__esModule", {
|
6 | value: true
|
7 | });
|
8 | exports.default = SnackbarElement;
|
9 |
|
10 | var React = _interopRequireWildcard(require("react"));
|
11 |
|
12 | var _index = require("../button/index.js");
|
13 |
|
14 | var _overrides = require("../helpers/overrides.js");
|
15 |
|
16 | var _index2 = require("../styles/index.js");
|
17 |
|
18 | var _styledComponents = require("./styled-components.js");
|
19 |
|
20 | function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
|
21 |
|
22 | function _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 |
|
24 | function _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 |
|
26 | function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); }
|
27 |
|
28 | function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance"); }
|
29 |
|
30 | function _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 |
|
32 | function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
33 |
|
34 | var 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 |
|
74 | function 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;
|
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 |