1 | import "core-js/modules/es.symbol.js";
|
2 | import "core-js/modules/es.symbol.description.js";
|
3 | import "core-js/modules/es.symbol.iterator.js";
|
4 | import "core-js/modules/es.array.iterator.js";
|
5 | import "core-js/modules/es.string.iterator.js";
|
6 | import "core-js/modules/web.dom-collections.iterator.js";
|
7 | import "core-js/modules/es.array.from.js";
|
8 | import "core-js/modules/es.array.slice.js";
|
9 | var _excluded = ["name"],
|
10 | _excluded2 = ["width", "height"];
|
11 |
|
12 | function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
13 |
|
14 | function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
15 |
|
16 | function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
17 |
|
18 | function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
19 |
|
20 | function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
21 |
|
22 | function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_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; }
|
23 |
|
24 | function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
25 |
|
26 | import "core-js/modules/es.array.concat.js";
|
27 | import "core-js/modules/es.array.map.js";
|
28 | import "core-js/modules/es.object.entries.js";
|
29 | import "core-js/modules/es.function.name.js";
|
30 | import "core-js/modules/es.object.assign.js";
|
31 | import "core-js/modules/es.array.filter.js";
|
32 | import "core-js/modules/es.object.to-string.js";
|
33 | import "core-js/modules/es.string.bold.js";
|
34 | import "core-js/modules/es.array.find.js";
|
35 | import "core-js/modules/es.object.keys.js";
|
36 | import "core-js/modules/es.regexp.exec.js";
|
37 | import "core-js/modules/es.string.replace.js";
|
38 |
|
39 | function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
40 |
|
41 | function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
42 |
|
43 | function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
44 |
|
45 | function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
46 |
|
47 | function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
48 |
|
49 | function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
50 |
|
51 |
|
52 | import React, { Fragment, useEffect, useRef, memo } from 'react';
|
53 | import memoize from 'memoizerific';
|
54 | import { styled, Global, withTheme } from '@storybook/theming';
|
55 | import { Icons, IconButton, WithTooltip, TooltipLinkList } from '@storybook/components';
|
56 | import { useStorybookApi, useParameter, useAddonState } from '@storybook/api';
|
57 | import { registerShortcuts } from './shortcuts';
|
58 | import { PARAM_KEY, ADDON_ID } from './constants';
|
59 | import { MINIMAL_VIEWPORTS } from './defaults';
|
60 | var toList = memoize(50)(function (items) {
|
61 | return [].concat(baseViewports, _toConsumableArray(Object.entries(items).map(function (_ref2) {
|
62 | var _ref3 = _slicedToArray(_ref2, 2),
|
63 | id = _ref3[0],
|
64 | _ref = _ref3[1];
|
65 |
|
66 | var name = _ref.name,
|
67 | rest = _objectWithoutProperties(_ref, _excluded);
|
68 |
|
69 | return Object.assign({}, rest, {
|
70 | id: id,
|
71 | title: name
|
72 | });
|
73 | })));
|
74 | });
|
75 | var responsiveViewport = {
|
76 | id: 'reset',
|
77 | title: 'Reset viewport',
|
78 | styles: null,
|
79 | type: 'other'
|
80 | };
|
81 | var baseViewports = [responsiveViewport];
|
82 | var toLinks = memoize(50)(function (list, active, set, state, close) {
|
83 | return list.map(function (i) {
|
84 | switch (i.id) {
|
85 | case responsiveViewport.id:
|
86 | {
|
87 | if (active.id === i.id) {
|
88 | return null;
|
89 | }
|
90 | }
|
91 |
|
92 | default:
|
93 | {
|
94 | return Object.assign({}, i, {
|
95 | onClick: function onClick() {
|
96 | set(Object.assign({}, state, {
|
97 | selected: i.id
|
98 | }));
|
99 | close();
|
100 | }
|
101 | });
|
102 | }
|
103 | }
|
104 | }).filter(Boolean);
|
105 | });
|
106 | var iframeId = 'storybook-preview-iframe';
|
107 | var wrapperId = 'storybook-preview-wrapper';
|
108 |
|
109 | var flip = function flip(_ref4) {
|
110 | var width = _ref4.width,
|
111 | height = _ref4.height,
|
112 | styles = _objectWithoutProperties(_ref4, _excluded2);
|
113 |
|
114 | return Object.assign({}, styles, {
|
115 | height: width,
|
116 | width: height
|
117 | });
|
118 | };
|
119 |
|
120 | var ActiveViewportSize = styled.div(function () {
|
121 | return {
|
122 | display: 'inline-flex'
|
123 | };
|
124 | });
|
125 | var ActiveViewportLabel = styled.div(function (_ref5) {
|
126 | var theme = _ref5.theme;
|
127 | return {
|
128 | display: 'inline-block',
|
129 | textDecoration: 'none',
|
130 | padding: 10,
|
131 | fontWeight: theme.typography.weight.bold,
|
132 | fontSize: theme.typography.size.s2 - 1,
|
133 | lineHeight: '1',
|
134 | height: 40,
|
135 | border: 'none',
|
136 | borderTop: '3px solid transparent',
|
137 | borderBottom: '3px solid transparent',
|
138 | background: 'transparent'
|
139 | };
|
140 | });
|
141 | var IconButtonWithLabel = styled(IconButton)(function () {
|
142 | return {
|
143 | display: 'inline-flex',
|
144 | alignItems: 'center'
|
145 | };
|
146 | });
|
147 | var IconButtonLabel = styled.div(function (_ref6) {
|
148 | var theme = _ref6.theme;
|
149 | return {
|
150 | fontSize: theme.typography.size.s2 - 1,
|
151 | marginLeft: 10
|
152 | };
|
153 | });
|
154 |
|
155 | var getStyles = function getStyles(prevStyles, styles, isRotated) {
|
156 | if (styles === null) {
|
157 | return null;
|
158 | }
|
159 |
|
160 | var result = typeof styles === 'function' ? styles(prevStyles) : styles;
|
161 | return isRotated ? flip(result) : result;
|
162 | };
|
163 |
|
164 | export var ViewportTool = memo(withTheme(function (_ref7) {
|
165 | var _ref9;
|
166 |
|
167 | var theme = _ref7.theme;
|
168 |
|
169 | var _useParameter = useParameter(PARAM_KEY, {}),
|
170 | _useParameter$viewpor = _useParameter.viewports,
|
171 | viewports = _useParameter$viewpor === void 0 ? MINIMAL_VIEWPORTS : _useParameter$viewpor,
|
172 | _useParameter$default = _useParameter.defaultViewport,
|
173 | defaultViewport = _useParameter$default === void 0 ? responsiveViewport.id : _useParameter$default,
|
174 | disable = _useParameter.disable;
|
175 |
|
176 | var _useAddonState = useAddonState(ADDON_ID, {
|
177 | selected: defaultViewport,
|
178 | isRotated: false
|
179 | }),
|
180 | _useAddonState2 = _slicedToArray(_useAddonState, 2),
|
181 | state = _useAddonState2[0],
|
182 | setState = _useAddonState2[1];
|
183 |
|
184 | var list = toList(viewports);
|
185 | var api = useStorybookApi();
|
186 |
|
187 | if (!list.find(function (i) {
|
188 | return i.id === defaultViewport;
|
189 | })) {
|
190 |
|
191 | console.warn("Cannot find \"defaultViewport\" of \"".concat(defaultViewport, "\" in addon-viewport configs, please check the \"viewports\" setting in the configuration."));
|
192 | }
|
193 |
|
194 | useEffect(function () {
|
195 | registerShortcuts(api, setState, Object.keys(viewports));
|
196 | }, [viewports]);
|
197 | useEffect(function () {
|
198 | setState({
|
199 | selected: defaultViewport || (viewports[state.selected] ? state.selected : responsiveViewport.id),
|
200 | isRotated: state.isRotated
|
201 | });
|
202 | }, [defaultViewport]);
|
203 | var selected = state.selected,
|
204 | isRotated = state.isRotated;
|
205 | var item = list.find(function (i) {
|
206 | return i.id === selected;
|
207 | }) || list.find(function (i) {
|
208 | return i.id === defaultViewport;
|
209 | }) || list.find(function (i) {
|
210 | return i.default;
|
211 | }) || responsiveViewport;
|
212 | var ref = useRef();
|
213 | var styles = getStyles(ref.current, item.styles, isRotated);
|
214 | useEffect(function () {
|
215 | ref.current = styles;
|
216 | }, [item]);
|
217 |
|
218 | if (disable || Object.entries(viewports).length === 0) {
|
219 | return null;
|
220 | }
|
221 |
|
222 | return React.createElement(Fragment, null, React.createElement(WithTooltip, {
|
223 | placement: "top",
|
224 | trigger: "click",
|
225 | tooltip: function tooltip(_ref8) {
|
226 | var onHide = _ref8.onHide;
|
227 | return React.createElement(TooltipLinkList, {
|
228 | links: toLinks(list, item, setState, state, onHide)
|
229 | });
|
230 | },
|
231 | closeOnClick: true
|
232 | }, React.createElement(IconButtonWithLabel, {
|
233 | key: "viewport",
|
234 | title: "Change the size of the preview",
|
235 | active: !!styles,
|
236 | onDoubleClick: function onDoubleClick() {
|
237 | setState(Object.assign({}, state, {
|
238 | selected: responsiveViewport.id
|
239 | }));
|
240 | }
|
241 | }, React.createElement(Icons, {
|
242 | icon: "grow"
|
243 | }), styles ? React.createElement(IconButtonLabel, null, isRotated ? "".concat(item.title, " (L)") : "".concat(item.title, " (P)")) : null)), styles ? React.createElement(ActiveViewportSize, null, React.createElement(Global, {
|
244 | styles: (_ref9 = {}, _defineProperty(_ref9, "#".concat(iframeId), Object.assign({
|
245 | margin: "auto",
|
246 | transition: 'width .3s, height .3s',
|
247 | position: 'relative',
|
248 | border: "1px solid black",
|
249 | boxShadow: '0 0 100px 100vw rgba(0,0,0,0.5)'
|
250 | }, styles)), _defineProperty(_ref9, "#".concat(wrapperId), {
|
251 | padding: theme.layoutMargin,
|
252 | alignContent: 'center',
|
253 | alignItems: 'center',
|
254 | justifyContent: 'center',
|
255 | justifyItems: 'center',
|
256 | overflow: 'auto',
|
257 | display: 'grid',
|
258 | gridTemplateColumns: '100%',
|
259 | gridTemplateRows: '100%'
|
260 | }), _ref9)
|
261 | }), React.createElement(ActiveViewportLabel, {
|
262 | title: "Viewport width"
|
263 | }, styles.width.replace('px', '')), React.createElement(IconButton, {
|
264 | key: "viewport-rotate",
|
265 | title: "Rotate viewport",
|
266 | onClick: function onClick() {
|
267 | setState(Object.assign({}, state, {
|
268 | isRotated: !isRotated
|
269 | }));
|
270 | }
|
271 | }, React.createElement(Icons, {
|
272 | icon: "transfer"
|
273 | })), React.createElement(ActiveViewportLabel, {
|
274 | title: "Viewport height"
|
275 | }, styles.height.replace('px', ''))) : null);
|
276 | })); |
\ | No newline at end of file |