creevey 0.8.0-beta.0 → 0.8.0

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 (199) hide show
  1. package/CHANGELOG.md +30 -7
  2. package/README.md +9 -1
  3. package/addon/README.md +3 -0
  4. package/addon/package.json +4 -0
  5. package/docs/config.md +29 -26
  6. package/jest.config.js +6 -0
  7. package/lib/cjs/client/addon/Manager.js +122 -271
  8. package/lib/cjs/client/addon/components/Addon.js +17 -38
  9. package/lib/cjs/client/addon/components/Icons.js +11 -7
  10. package/lib/cjs/client/addon/components/Panel.js +17 -13
  11. package/lib/cjs/client/addon/components/TestSelect.js +11 -9
  12. package/lib/cjs/client/addon/components/Tools.js +21 -40
  13. package/lib/cjs/client/addon/decorator.js +1 -1
  14. package/lib/cjs/client/addon/index.js +31 -0
  15. package/lib/cjs/client/addon/preset.ie11.js +74 -0
  16. package/lib/cjs/client/addon/preset.js +13 -31
  17. package/lib/cjs/client/addon/readyForCapture.js +12 -0
  18. package/lib/cjs/client/addon/register.js +46 -70
  19. package/lib/cjs/client/addon/utils.js +6 -2
  20. package/lib/cjs/client/addon/withCreevey.js +221 -155
  21. package/lib/cjs/client/shared/components/ImagesView/BlendView.js +26 -24
  22. package/lib/cjs/client/shared/components/ImagesView/ImagesView.js +22 -18
  23. package/lib/cjs/client/shared/components/ImagesView/SideBySideView.js +44 -66
  24. package/lib/cjs/client/shared/components/ImagesView/SlideView.js +38 -50
  25. package/lib/cjs/client/shared/components/ImagesView/SwapView.js +26 -45
  26. package/lib/cjs/client/shared/components/ImagesView/index.js +9 -9
  27. package/lib/cjs/client/shared/components/PageFooter/PageFooter.js +12 -8
  28. package/lib/cjs/client/shared/components/PageFooter/Paging.js +14 -18
  29. package/lib/cjs/client/shared/components/PageHeader/ImagePreview.js +22 -18
  30. package/lib/cjs/client/shared/components/PageHeader/PageHeader.js +42 -67
  31. package/lib/cjs/client/shared/components/ResultsPage.js +39 -69
  32. package/lib/cjs/client/shared/creeveyClientApi.js +55 -82
  33. package/lib/cjs/client/shared/helpers.js +140 -211
  34. package/lib/cjs/client/shared/viewMode.js +5 -5
  35. package/lib/cjs/client/web/142.js +2 -0
  36. package/lib/cjs/client/web/142.js.LICENSE.txt +12 -0
  37. package/lib/cjs/client/web/32.js +1 -0
  38. package/lib/cjs/client/web/551.js +1 -0
  39. package/lib/cjs/client/web/566.js +2 -0
  40. package/lib/cjs/client/web/566.js.LICENSE.txt +31 -0
  41. package/lib/cjs/client/web/691.js +2 -0
  42. package/lib/cjs/client/web/691.js.LICENSE.txt +8 -0
  43. package/lib/cjs/client/web/725.js +1 -0
  44. package/lib/cjs/client/web/main.js +2 -38
  45. package/lib/cjs/client/web/main.js.LICENSE.txt +49 -0
  46. package/lib/cjs/creevey.js +3 -5
  47. package/lib/cjs/index.js +10 -15
  48. package/lib/cjs/server/config.js +5 -4
  49. package/lib/cjs/server/docker.js +3 -7
  50. package/lib/cjs/server/extract.js +7 -4
  51. package/lib/cjs/server/index.js +3 -5
  52. package/lib/cjs/server/loaders/babel/creevey-plugin.js +1 -3
  53. package/lib/cjs/server/loaders/babel/helpers.js +13 -23
  54. package/lib/cjs/server/loaders/babel/register.js +2 -4
  55. package/lib/cjs/server/loaders/webpack/compile.js +34 -51
  56. package/lib/cjs/server/loaders/webpack/creevey-loader.js +20 -22
  57. package/lib/cjs/server/loaders/webpack/dummy-hmr.js +2 -7
  58. package/lib/cjs/server/loaders/webpack/mdx-loader.js +2 -2
  59. package/lib/cjs/server/loaders/webpack/start.js +1 -1
  60. package/lib/cjs/server/logger.js +2 -1
  61. package/lib/cjs/server/master/index.js +4 -4
  62. package/lib/cjs/server/master/master.js +1 -0
  63. package/lib/cjs/server/master/pool.js +38 -47
  64. package/lib/cjs/server/master/runner.js +53 -66
  65. package/lib/cjs/server/master/server.js +78 -4
  66. package/lib/cjs/server/messages.js +128 -18
  67. package/lib/cjs/server/selenium/browser.js +129 -55
  68. package/lib/cjs/server/selenium/selenoid.js +5 -7
  69. package/lib/cjs/server/stories.js +58 -72
  70. package/lib/cjs/server/storybook/entry.js +7 -22
  71. package/lib/cjs/server/storybook/helpers.js +20 -27
  72. package/lib/cjs/server/storybook/providers/browser.js +74 -0
  73. package/lib/cjs/server/storybook/{nodejs-provider.js → providers/nodejs.js} +37 -20
  74. package/lib/cjs/server/update.js +1 -5
  75. package/lib/cjs/server/utils.js +26 -35
  76. package/lib/cjs/server/worker/helpers.js +2 -6
  77. package/lib/cjs/server/worker/reporter.js +8 -20
  78. package/lib/cjs/server/worker/worker.js +21 -19
  79. package/lib/cjs/shared/index.js +101 -0
  80. package/lib/cjs/shared/serializeRegExp.js +42 -0
  81. package/lib/cjs/types.js +11 -6
  82. package/lib/esm/client/addon/Manager.js +122 -271
  83. package/lib/esm/client/addon/components/Addon.js +15 -34
  84. package/lib/esm/client/addon/components/Icons.js +10 -6
  85. package/lib/esm/client/addon/components/Panel.js +17 -13
  86. package/lib/esm/client/addon/components/TestSelect.js +11 -9
  87. package/lib/esm/client/addon/components/Tools.js +19 -36
  88. package/lib/esm/client/addon/decorator.js +1 -1
  89. package/lib/esm/client/addon/index.js +2 -0
  90. package/lib/esm/client/addon/preset.ie11.js +59 -0
  91. package/lib/esm/client/addon/preset.js +12 -26
  92. package/lib/esm/client/addon/readyForCapture.js +5 -0
  93. package/lib/esm/client/addon/register.js +42 -66
  94. package/lib/esm/client/addon/utils.js +3 -2
  95. package/lib/esm/client/addon/withCreevey.js +209 -156
  96. package/lib/esm/client/shared/components/ImagesView/BlendView.js +23 -20
  97. package/lib/esm/client/shared/components/ImagesView/ImagesView.js +21 -17
  98. package/lib/esm/client/shared/components/ImagesView/SideBySideView.js +42 -63
  99. package/lib/esm/client/shared/components/ImagesView/SlideView.js +36 -47
  100. package/lib/esm/client/shared/components/ImagesView/SwapView.js +24 -42
  101. package/lib/esm/client/shared/components/PageFooter/PageFooter.js +12 -8
  102. package/lib/esm/client/shared/components/PageFooter/Paging.js +14 -18
  103. package/lib/esm/client/shared/components/PageHeader/ImagePreview.js +22 -18
  104. package/lib/esm/client/shared/components/PageHeader/PageHeader.js +37 -60
  105. package/lib/esm/client/shared/components/ResultsPage.js +36 -64
  106. package/lib/esm/client/shared/creeveyClientApi.js +57 -84
  107. package/lib/esm/client/shared/helpers.js +124 -195
  108. package/lib/esm/client/shared/viewMode.js +4 -4
  109. package/lib/esm/creevey.js +3 -5
  110. package/lib/esm/index.js +2 -3
  111. package/lib/esm/server/config.js +4 -5
  112. package/lib/esm/server/docker.js +2 -2
  113. package/lib/esm/server/extract.js +6 -4
  114. package/lib/esm/server/index.js +3 -4
  115. package/lib/esm/server/loaders/babel/creevey-plugin.js +1 -3
  116. package/lib/esm/server/loaders/babel/helpers.js +12 -22
  117. package/lib/esm/server/loaders/babel/register.js +3 -5
  118. package/lib/esm/server/loaders/webpack/compile.js +35 -52
  119. package/lib/esm/server/loaders/webpack/creevey-loader.js +9 -10
  120. package/lib/esm/server/loaders/webpack/dummy-hmr.js +2 -6
  121. package/lib/esm/server/loaders/webpack/mdx-loader.js +2 -2
  122. package/lib/esm/server/loaders/webpack/start.js +1 -1
  123. package/lib/esm/server/master/index.js +4 -4
  124. package/lib/esm/server/master/master.js +1 -0
  125. package/lib/esm/server/master/pool.js +38 -49
  126. package/lib/esm/server/master/runner.js +53 -66
  127. package/lib/esm/server/master/server.js +76 -6
  128. package/lib/esm/server/messages.js +118 -14
  129. package/lib/esm/server/selenium/browser.js +126 -57
  130. package/lib/esm/server/selenium/selenoid.js +4 -6
  131. package/lib/esm/server/stories.js +58 -70
  132. package/lib/esm/server/storybook/entry.js +5 -22
  133. package/lib/esm/server/storybook/helpers.js +11 -20
  134. package/lib/esm/server/storybook/providers/browser.js +60 -0
  135. package/lib/esm/server/storybook/{nodejs-provider.js → providers/nodejs.js} +35 -19
  136. package/lib/esm/server/update.js +1 -5
  137. package/lib/esm/server/utils.js +18 -31
  138. package/lib/esm/server/worker/helpers.js +2 -6
  139. package/lib/esm/server/worker/reporter.js +8 -20
  140. package/lib/esm/server/worker/worker.js +22 -20
  141. package/lib/esm/shared/index.js +78 -0
  142. package/lib/esm/shared/serializeRegExp.js +24 -0
  143. package/lib/esm/types.js +3 -0
  144. package/lib/types/client/addon/Manager.d.ts +2 -2
  145. package/lib/types/client/addon/components/TestSelect.d.ts +0 -1
  146. package/lib/types/client/addon/index.d.ts +2 -0
  147. package/lib/types/client/addon/preset.d.ts +2 -1
  148. package/lib/types/client/addon/preset.ie11.d.ts +10 -0
  149. package/lib/types/client/addon/readyForCapture.d.ts +6 -0
  150. package/lib/types/client/addon/utils.d.ts +1 -0
  151. package/lib/types/client/addon/withCreevey.d.ts +13 -2
  152. package/lib/types/client/shared/components/ImagesView/BlendView.d.ts +1 -1
  153. package/lib/types/client/shared/components/ImagesView/ImagesView.d.ts +0 -1
  154. package/lib/types/client/shared/components/ImagesView/SideBySideView.d.ts +1 -1
  155. package/lib/types/client/shared/components/ImagesView/SlideView.d.ts +1 -1
  156. package/lib/types/client/shared/components/ImagesView/SwapView.d.ts +1 -1
  157. package/lib/types/client/shared/components/PageFooter/PageFooter.d.ts +0 -1
  158. package/lib/types/client/shared/components/PageFooter/Paging.d.ts +0 -1
  159. package/lib/types/client/shared/components/PageHeader/ImagePreview.d.ts +1 -1
  160. package/lib/types/client/shared/components/PageHeader/PageHeader.d.ts +0 -1
  161. package/lib/types/client/shared/components/ResultsPage.d.ts +1 -1
  162. package/lib/types/client/web/CreeveyApp.d.ts +0 -1
  163. package/lib/types/client/web/CreeveyLoader.d.ts +1 -2
  164. package/lib/types/client/web/CreeveyView/SideBar/Checkbox.d.ts +1 -1
  165. package/lib/types/client/web/CreeveyView/SideBar/SideBarHeader.d.ts +0 -1
  166. package/lib/types/client/web/CreeveyView/SideBar/SuiteLink.d.ts +6 -6
  167. package/lib/types/client/web/CreeveyView/SideBar/TestLink.d.ts +0 -1
  168. package/lib/types/client/web/CreeveyView/SideBar/TestStatusIcon.d.ts +1 -1
  169. package/lib/types/client/web/CreeveyView/SideBar/TestsStatus.d.ts +1 -1
  170. package/lib/types/index.d.ts +0 -1
  171. package/lib/types/server/loaders/babel/register.d.ts +1 -1
  172. package/lib/types/server/loaders/webpack/creevey-loader.d.ts +4 -2
  173. package/lib/types/server/logger.d.ts +6 -2
  174. package/lib/types/server/master/master.d.ts +1 -0
  175. package/lib/types/server/master/pool.d.ts +1 -0
  176. package/lib/types/server/master/server.d.ts +1 -1
  177. package/lib/types/server/messages.d.ts +17 -6
  178. package/lib/types/server/selenium/browser.d.ts +5 -2
  179. package/lib/types/server/stories.d.ts +2 -2
  180. package/lib/types/server/storybook/entry.d.ts +2 -3
  181. package/lib/types/server/storybook/helpers.d.ts +1 -1
  182. package/lib/types/server/storybook/providers/browser.d.ts +4 -0
  183. package/lib/types/server/storybook/providers/nodejs.d.ts +9 -0
  184. package/lib/types/server/utils.d.ts +5 -1
  185. package/lib/types/server/worker/helpers.d.ts +2 -1
  186. package/lib/types/shared/index.d.ts +7 -0
  187. package/lib/types/shared/serializeRegExp.d.ts +9 -0
  188. package/lib/types/types.d.ts +32 -5
  189. package/package.json +120 -103
  190. package/preset/ie11.js +5 -0
  191. package/{preset.js → preset/index.js} +2 -2
  192. package/types/mdx.d.ts +3 -2
  193. package/types/mocha.d.ts +1 -0
  194. package/lib/cjs/client/web/1.js +0 -13
  195. package/lib/cjs/client/web/2.js +0 -1
  196. package/lib/cjs/shared.js +0 -35
  197. package/lib/esm/shared.js +0 -22
  198. package/lib/types/server/storybook/nodejs-provider.d.ts +0 -5
  199. package/lib/types/shared.d.ts +0 -4
@@ -2,8 +2,10 @@ import { Button, Icons, TooltipLinkList, WithTooltip } from '@storybook/componen
2
2
  import { styled } from '@storybook/theming';
3
3
  import React from 'react';
4
4
  import { getEmojiByTestStatus } from '../utils';
5
- var LinkIconContainer = styled.span(function (_ref) {
6
- var theme = _ref.theme;
5
+ const LinkIconContainer = styled.span(_ref => {
6
+ let {
7
+ theme
8
+ } = _ref;
7
9
  return {
8
10
  display: 'inline-block',
9
11
  width: '20px',
@@ -14,24 +16,24 @@ var LinkIconContainer = styled.span(function (_ref) {
14
16
  export default function TestSelect(props) {
15
17
  var _props$tests$find$tes, _props$tests$find;
16
18
 
17
- var testName = (_props$tests$find$tes = (_props$tests$find = props.tests.find(function (x) {
18
- return x.id === props.selectedTestId;
19
- })) === null || _props$tests$find === void 0 ? void 0 : _props$tests$find.testName) !== null && _props$tests$find$tes !== void 0 ? _props$tests$find$tes : '';
19
+ const testName = (_props$tests$find$tes = (_props$tests$find = props.tests.find(x => x.id === props.selectedTestId)) === null || _props$tests$find === void 0 ? void 0 : _props$tests$find.testName) !== null && _props$tests$find$tes !== void 0 ? _props$tests$find$tes : '';
20
20
  return /*#__PURE__*/React.createElement(WithTooltip, {
21
21
  trigger: "click",
22
22
  placement: "bottom",
23
23
  closeOnClick: true,
24
- tooltip: function tooltip(_ref2) {
25
- var onHide = _ref2.onHide;
24
+ tooltip: _ref2 => {
25
+ let {
26
+ onHide
27
+ } = _ref2;
26
28
  return /*#__PURE__*/React.createElement(TooltipLinkList, {
27
- links: props.tests.map(function (x) {
29
+ links: props.tests.map(x => {
28
30
  var _x$testName;
29
31
 
30
32
  return {
31
33
  id: x.id,
32
34
  title: (_x$testName = x.testName) !== null && _x$testName !== void 0 ? _x$testName : '',
33
35
  active: props.selectedTestId === x.id,
34
- onClick: function onClick() {
36
+ onClick: () => {
35
37
  props.onChangeTest(x.id);
36
38
  onHide();
37
39
  },
@@ -1,15 +1,3 @@
1
- function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
2
-
3
- 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."); }
4
-
5
- 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); }
6
-
7
- 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; }
8
-
9
- 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; }
10
-
11
- function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
12
-
13
1
  import React, { Fragment, useState, useEffect } from 'react';
14
2
  import { IconButton, Icons, Separator } from '@storybook/components';
15
3
  import { ForwardIcon, NextIcon } from './Icons';
@@ -17,7 +5,7 @@ import { stringify } from 'qs';
17
5
  import { styled } from '@storybook/theming';
18
6
  import { isDefined } from '../../../types';
19
7
  import { getTestPath, useForceUpdate } from '../../shared/helpers';
20
- var Button = styled(IconButton)({
8
+ const Button = styled(IconButton)({
21
9
  '&:disabled': {
22
10
  opacity: 0.5,
23
11
  cursor: 'default'
@@ -26,30 +14,25 @@ var Button = styled(IconButton)({
26
14
  color: 'inherit'
27
15
  }
28
16
  });
29
- export var Tools = function Tools(_ref) {
30
- var manager = _ref.manager;
31
-
32
- var _useState = useState(),
33
- _useState2 = _slicedToArray(_useState, 2),
34
- buttonClicked = _useState2[0],
35
- setButtonClicked = _useState2[1];
36
-
37
- var _useState3 = useState(manager.status.isRunning),
38
- _useState4 = _slicedToArray(_useState3, 2),
39
- isRunning = _useState4[0],
40
- setRunning = _useState4[1];
41
-
42
- var forceUpdate = useForceUpdate();
43
- var test = manager.getCurrentTest();
44
- useEffect(function () {
45
- var unsubscribe = manager.onChangeTest(function () {
17
+ export const Tools = _ref => {
18
+ let {
19
+ manager
20
+ } = _ref;
21
+ const [buttonClicked, setButtonClicked] = useState();
22
+ const [isRunning, setRunning] = useState(manager.status.isRunning);
23
+ const forceUpdate = useForceUpdate();
24
+ const test = manager.getCurrentTest();
25
+ useEffect(() => {
26
+ const unsubscribe = manager.onChangeTest(() => {
46
27
  forceUpdate();
47
28
  });
48
29
  return unsubscribe;
49
30
  }, [manager, forceUpdate]);
50
- useEffect(function () {
51
- var unsubscribe = manager.onUpdateStatus(function (_ref2) {
52
- var isRunning = _ref2.isRunning;
31
+ useEffect(() => {
32
+ const unsubscribe = manager.onUpdateStatus(_ref2 => {
33
+ let {
34
+ isRunning
35
+ } = _ref2;
53
36
  if (isDefined(isRunning)) setRunning(isRunning);
54
37
  });
55
38
  return unsubscribe;
@@ -57,14 +40,14 @@ export var Tools = function Tools(_ref) {
57
40
  if (!test) return null;
58
41
 
59
42
  function renderButton(type, title, onClick, icon) {
60
- var handleClick = function handleClick() {
43
+ const handleClick = () => {
61
44
  setButtonClicked(type);
62
45
  onClick();
63
46
  };
64
47
 
65
- var disabled = isRunning && buttonClicked != null && buttonClicked !== type;
48
+ const disabled = isRunning && buttonClicked != null && buttonClicked !== type;
66
49
  return /*#__PURE__*/React.createElement(Button, {
67
- onClick: function onClick() {
50
+ onClick: () => {
68
51
  isRunning ? manager.onStop() : handleClick();
69
52
  },
70
53
  title: disabled ? '' : title,
@@ -1,2 +1,2 @@
1
1
  import { withCreevey } from './withCreevey';
2
- export var decorators = [withCreevey()];
2
+ export const decorators = [withCreevey()];
@@ -0,0 +1,2 @@
1
+ export * from './withCreevey';
2
+ export * from './readyForCapture';
@@ -0,0 +1,59 @@
1
+ const ie11Preset = ['@babel/preset-env', {
2
+ targets: {
3
+ ie: '11'
4
+ }
5
+ }];
6
+ export const babel = config => {
7
+ const {
8
+ presets = []
9
+ } = config;
10
+ return { ...config,
11
+ presets: [...(presets || []), ie11Preset]
12
+ };
13
+ };
14
+ const nodeModulesThatNeedToBeParsedBecauseTheyExposeES6 = ['creevey', '@testing-library'];
15
+ const include = new RegExp("[\\\\/](".concat(nodeModulesThatNeedToBeParsedBecauseTheyExposeES6.join('|'), ")"));
16
+ const es6Loader = {
17
+ test: /\.js$/,
18
+ use: [{
19
+ loader: require.resolve('babel-loader'),
20
+ options: {
21
+ presets: [ie11Preset]
22
+ }
23
+ }],
24
+ include
25
+ };
26
+ export const managerWebpack = function () {
27
+ var _webpackConfig$module, _webpackConfig$module2;
28
+
29
+ let webpackConfig = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
30
+ return { ...webpackConfig,
31
+ module: { ...webpackConfig.module,
32
+ rules: [...((_webpackConfig$module = (_webpackConfig$module2 = webpackConfig.module) === null || _webpackConfig$module2 === void 0 ? void 0 : _webpackConfig$module2.rules) !== null && _webpackConfig$module !== void 0 ? _webpackConfig$module : []), es6Loader]
33
+ }
34
+ };
35
+ };
36
+ export const webpack = function () {
37
+ var _webpackConfig$module3, _webpackConfig$module4;
38
+
39
+ let webpackConfig = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
40
+ const {
41
+ entry
42
+ } = webpackConfig;
43
+ const polyfills = [require.resolve('whatwg-fetch')];
44
+
45
+ if (Array.isArray(entry)) {
46
+ polyfills.forEach(polyfill => {
47
+ if (!entry.includes(polyfill)) {
48
+ entry.unshift(polyfill);
49
+ }
50
+ });
51
+ }
52
+
53
+ return { ...webpackConfig,
54
+ entry,
55
+ module: { ...webpackConfig.module,
56
+ rules: [...((_webpackConfig$module3 = (_webpackConfig$module4 = webpackConfig.module) === null || _webpackConfig$module4 === void 0 ? void 0 : _webpackConfig$module4.rules) !== null && _webpackConfig$module3 !== void 0 ? _webpackConfig$module3 : []), es6Loader]
57
+ }
58
+ };
59
+ };
@@ -1,33 +1,21 @@
1
- function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
2
-
3
- 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."); }
4
-
5
- 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); }
6
-
7
- function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
8
-
9
- function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
10
-
11
- 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; }
12
-
13
1
  import path from 'path';
14
2
  import { exec } from 'shelljs';
15
3
  import { DefinePlugin as FallbackDefinePlugin } from 'webpack';
16
- import { isStorybookVersionLessThan, resolveFromStorybookCore, resolveFromStorybookCoreServer } from '../../server/storybook/helpers';
4
+ import { resolveFromStorybookCoreServer } from '../../server/storybook/helpers';
17
5
  export function config() {
18
- var entry = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
19
- return [].concat(_toConsumableArray(entry), [require.resolve('./decorator')]);
6
+ let entry = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
7
+ return [...entry, require.resolve('./decorator')];
20
8
  }
21
9
  export function managerEntries() {
22
- var entry = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
23
- return [].concat(_toConsumableArray(entry), [require.resolve('./register')]);
10
+ let entry = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
11
+ return [...entry, require.resolve('./register')];
24
12
  }
25
13
  export function managerWebpack(config, options) {
26
14
  var _options$presets$appl, _options$presets;
27
15
 
28
16
  // TODO How to execute with non-webpack bundlers
29
- if (options.configType == 'PRODUCTION' && !isStorybookVersionLessThan(6, 2) && options.skipExtract != true) {
30
- var args = [];
17
+ if (options.configType == 'PRODUCTION' && options.skipExtract != true) {
18
+ const args = [];
31
19
  if (options.creeveyPreExtract) args.push("--require \"".concat(options.creeveyPreExtract, "\""));
32
20
  args.push(path.join(__dirname, '../../cli'));
33
21
  args.push("--extract \"".concat(options.outputDir, "\""));
@@ -37,16 +25,14 @@ export function managerWebpack(config, options) {
37
25
  });
38
26
  }
39
27
 
40
- return ((_options$presets$appl = (_options$presets = options.presets) === null || _options$presets === void 0 ? void 0 : _options$presets.apply('webpackInstance')) !== null && _options$presets$appl !== void 0 ? _options$presets$appl : Promise.resolve(undefined)).then(function (webpack) {
41
- return webpack !== null && webpack !== void 0 ? webpack : import(isStorybookVersionLessThan(6, 2) ? resolveFromStorybookCore('webpack') : resolveFromStorybookCoreServer('webpack'));
42
- }).then(function (webpack) {
28
+ return ((_options$presets$appl = (_options$presets = options.presets) === null || _options$presets === void 0 ? void 0 : _options$presets.apply('webpackInstance')) !== null && _options$presets$appl !== void 0 ? _options$presets$appl : Promise.resolve(undefined)).then(webpack => webpack !== null && webpack !== void 0 ? webpack : import(resolveFromStorybookCoreServer('webpack'))).then(webpack => {
43
29
  var _config$plugins, _options$creeveyPort;
44
30
 
45
- var _ref = webpack !== null && webpack !== void 0 ? webpack : {},
46
- _ref$DefinePlugin = _ref.DefinePlugin,
47
- DefinePlugin = _ref$DefinePlugin === void 0 ? FallbackDefinePlugin : _ref$DefinePlugin;
48
-
31
+ const {
32
+ DefinePlugin = FallbackDefinePlugin
33
+ } = webpack !== null && webpack !== void 0 ? webpack : {};
49
34
  (_config$plugins = config.plugins) === null || _config$plugins === void 0 ? void 0 : _config$plugins.push(new DefinePlugin({
35
+ __CREEVEY_SERVER_HOST__: options.creeveyHost,
50
36
  __CREEVEY_SERVER_PORT__: (_options$creeveyPort = options.creeveyPort) !== null && _options$creeveyPort !== void 0 ? _options$creeveyPort : 3000,
51
37
  __CREEVEY_CLIENT_PORT__: options.clientPort
52
38
  }));
@@ -0,0 +1,5 @@
1
+ export function readyForCapture() {
2
+ var _window$__CREEVEY_SET, _window;
3
+
4
+ (_window$__CREEVEY_SET = (_window = window).__CREEVEY_SET_READY_FOR_CAPTURE__) === null || _window$__CREEVEY_SET === void 0 ? void 0 : _window$__CREEVEY_SET.call(_window);
5
+ }
@@ -1,75 +1,51 @@
1
- function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
2
-
3
- function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
4
-
5
1
  import { addons, types } from '@storybook/addons';
6
2
  import React from 'react';
7
3
  import { Addon } from './components/Addon';
8
4
  import { Tools } from './components/Tools';
9
5
  import { CreeveyManager } from './Manager';
10
- export var ADDON_ID = 'creevey';
11
- addons.register(ADDON_ID, function (api) {
6
+ export const ADDON_ID = 'creevey';
7
+ addons.register(ADDON_ID, api => {
12
8
  void registerCreeveyPanels(api);
13
9
  });
14
- export function registerCreeveyPanels(_x) {
15
- return _registerCreeveyPanels.apply(this, arguments);
16
- }
17
-
18
- function _registerCreeveyPanels() {
19
- _registerCreeveyPanels = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(storybookApi) {
20
- var manager, browsers;
21
- return regeneratorRuntime.wrap(function _callee$(_context) {
22
- while (1) {
23
- switch (_context.prev = _context.next) {
24
- case 0:
25
- manager = new CreeveyManager(storybookApi);
26
- addons.addPanel("".concat(ADDON_ID, "/panel/run"), {
27
- title: "Creevey/Run",
28
- match: function match(_ref) {
29
- var viewMode = _ref.viewMode;
30
- return !!(viewMode && /^story$/.exec(viewMode));
31
- },
32
- type: types.TOOL,
33
- // eslint-disable-next-line react/display-name
34
- render: function render() {
35
- return /*#__PURE__*/React.createElement(Tools, {
36
- manager: manager
37
- });
38
- }
39
- });
40
- _context.next = 4;
41
- return manager.initAll();
42
-
43
- case 4:
44
- browsers = manager.getBrowsers();
45
- browsers.forEach(function (browser) {
46
- var panelId = "".concat(ADDON_ID, "/panel/").concat(browser);
47
- var title = manager.getTabTitle(browser);
48
- addons.addPanel(panelId, {
49
- title: title,
50
- type: types.PANEL,
51
- paramKey: browser,
52
- // NOTE key = PANEL_ID needs to correct render button in addons panel
53
- // eslint-disable-next-line react/display-name
54
- render: function render(_ref2) {
55
- var active = _ref2.active,
56
- key = _ref2.key;
57
- return /*#__PURE__*/React.createElement(Addon, {
58
- active: active,
59
- key: key,
60
- manager: manager,
61
- browser: browser
62
- });
63
- }
64
- });
65
- });
66
-
67
- case 6:
68
- case "end":
69
- return _context.stop();
70
- }
10
+ export async function registerCreeveyPanels(storybookApi) {
11
+ const manager = new CreeveyManager(storybookApi);
12
+ addons.addPanel("".concat(ADDON_ID, "/panel/run"), {
13
+ title: "Creevey/Run",
14
+ match: _ref => {
15
+ let {
16
+ viewMode
17
+ } = _ref;
18
+ return !!(viewMode && /^story$/.exec(viewMode));
19
+ },
20
+ type: types.TOOL,
21
+ // eslint-disable-next-line react/display-name
22
+ render: () => /*#__PURE__*/React.createElement(Tools, {
23
+ manager
24
+ })
25
+ });
26
+ await manager.initAll();
27
+ const browsers = manager.getBrowsers();
28
+ browsers.forEach(browser => {
29
+ const panelId = "".concat(ADDON_ID, "/panel/").concat(browser);
30
+ const title = manager.getTabTitle(browser);
31
+ addons.addPanel(panelId, {
32
+ title,
33
+ type: types.PANEL,
34
+ paramKey: browser,
35
+ // NOTE key = PANEL_ID needs to correct render button in addons panel
36
+ // eslint-disable-next-line react/display-name
37
+ render: _ref2 => {
38
+ let {
39
+ active,
40
+ key
41
+ } = _ref2;
42
+ return /*#__PURE__*/React.createElement(Addon, {
43
+ active,
44
+ key,
45
+ manager,
46
+ browser
47
+ });
71
48
  }
72
- }, _callee);
73
- }));
74
- return _registerCreeveyPanels.apply(this, arguments);
49
+ });
50
+ });
75
51
  }
@@ -1,5 +1,5 @@
1
1
  export function getEmojiByTestStatus(status) {
2
- var skip = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
2
+ let skip = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
3
3
 
4
4
  switch (status) {
5
5
  case 'failed':
@@ -28,4 +28,5 @@ export function getEmojiByTestStatus(status) {
28
28
  return '';
29
29
  }
30
30
  }
31
- }
31
+ }
32
+ export const isInternetExplorer = navigator.userAgent.includes('Trident/');