creevey 0.9.0-beta.0 → 0.9.0-beta.10

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 (203) hide show
  1. package/CHANGELOG.md +51 -0
  2. package/README.md +9 -1
  3. package/addon/README.md +3 -0
  4. package/addon/package.json +5 -0
  5. package/docs/config.md +29 -26
  6. package/jest.config.js +6 -0
  7. package/lib/cjs/client/addon/Manager.js +122 -270
  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 +22 -41
  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 +4 -68
  17. package/lib/cjs/client/addon/preset.sb7.js +19 -0
  18. package/lib/cjs/client/addon/preview.js +14 -0
  19. package/lib/cjs/client/addon/register.js +46 -70
  20. package/lib/cjs/client/addon/utils.js +6 -2
  21. package/lib/cjs/client/addon/withCreevey.js +161 -366
  22. package/lib/cjs/client/shared/components/ImagesView/BlendView.js +23 -21
  23. package/lib/cjs/client/shared/components/ImagesView/ImagesView.js +22 -18
  24. package/lib/cjs/client/shared/components/ImagesView/SideBySideView.js +42 -64
  25. package/lib/cjs/client/shared/components/ImagesView/SlideView.js +35 -48
  26. package/lib/cjs/client/shared/components/ImagesView/SwapView.js +24 -43
  27. package/lib/cjs/client/shared/components/ImagesView/index.js +9 -9
  28. package/lib/cjs/client/shared/components/PageFooter/PageFooter.js +12 -8
  29. package/lib/cjs/client/shared/components/PageFooter/Paging.js +14 -18
  30. package/lib/cjs/client/shared/components/PageHeader/ImagePreview.js +22 -18
  31. package/lib/cjs/client/shared/components/PageHeader/PageHeader.js +42 -67
  32. package/lib/cjs/client/shared/components/ResultsPage.js +39 -69
  33. package/lib/cjs/client/shared/creeveyClientApi.js +55 -82
  34. package/lib/cjs/client/shared/helpers.js +139 -210
  35. package/lib/cjs/client/shared/viewMode.js +5 -5
  36. package/lib/cjs/client/web/142.js +2 -0
  37. package/lib/cjs/client/web/142.js.LICENSE.txt +12 -0
  38. package/lib/cjs/client/web/32.js +1 -0
  39. package/lib/cjs/client/web/551.js +1 -0
  40. package/lib/cjs/client/web/566.js +2 -0
  41. package/lib/cjs/client/web/566.js.LICENSE.txt +31 -0
  42. package/lib/cjs/client/web/691.js +2 -0
  43. package/lib/cjs/client/web/691.js.LICENSE.txt +8 -0
  44. package/lib/cjs/client/web/725.js +1 -0
  45. package/lib/cjs/client/web/main.js +2 -38
  46. package/lib/cjs/client/web/main.js.LICENSE.txt +49 -0
  47. package/lib/cjs/creevey.js +3 -5
  48. package/lib/cjs/index.js +5 -5
  49. package/lib/cjs/server/config.js +3 -5
  50. package/lib/cjs/server/docker.js +3 -7
  51. package/lib/cjs/server/extract.js +1 -5
  52. package/lib/cjs/server/index.js +1 -1
  53. package/lib/cjs/server/loaders/babel/creevey-plugin.js +1 -3
  54. package/lib/cjs/server/loaders/babel/helpers.js +13 -23
  55. package/lib/cjs/server/loaders/babel/register.js +2 -4
  56. package/lib/cjs/server/loaders/webpack/compile.js +34 -51
  57. package/lib/cjs/server/loaders/webpack/creevey-loader.js +20 -22
  58. package/lib/cjs/server/loaders/webpack/dummy-hmr.js +2 -7
  59. package/lib/cjs/server/loaders/webpack/mdx-loader.js +2 -2
  60. package/lib/cjs/server/loaders/webpack/start.js +1 -1
  61. package/lib/cjs/server/logger.js +2 -1
  62. package/lib/cjs/server/master/index.js +2 -2
  63. package/lib/cjs/server/master/pool.js +9 -18
  64. package/lib/cjs/server/master/runner.js +53 -66
  65. package/lib/cjs/server/master/server.js +5 -3
  66. package/lib/cjs/server/messages.js +8 -10
  67. package/lib/cjs/server/selenium/browser.js +58 -70
  68. package/lib/cjs/server/selenium/selenoid.js +5 -7
  69. package/lib/cjs/server/stories.js +16 -33
  70. package/lib/cjs/server/storybook/entry.js +7 -22
  71. package/lib/cjs/server/storybook/helpers.js +21 -28
  72. package/lib/cjs/server/storybook/providers/browser.js +10 -14
  73. package/lib/cjs/server/storybook/providers/hybrid.js +17 -14
  74. package/lib/cjs/server/storybook/providers/nodejs.js +12 -12
  75. package/lib/cjs/server/{parser.js → testsFiles/parser.js} +1 -14
  76. package/lib/cjs/server/testsFiles/register.js +44 -0
  77. package/lib/cjs/server/update.js +1 -5
  78. package/lib/cjs/server/utils.js +27 -36
  79. package/lib/cjs/server/worker/reporter.js +8 -20
  80. package/lib/cjs/server/worker/worker.js +9 -19
  81. package/lib/cjs/shared/index.js +101 -0
  82. package/lib/cjs/shared/serializeRegExp.js +42 -0
  83. package/lib/cjs/types.js +7 -6
  84. package/lib/esm/client/addon/Manager.js +122 -270
  85. package/lib/esm/client/addon/components/Addon.js +15 -34
  86. package/lib/esm/client/addon/components/Icons.js +10 -6
  87. package/lib/esm/client/addon/components/Panel.js +17 -13
  88. package/lib/esm/client/addon/components/TestSelect.js +11 -9
  89. package/lib/esm/client/addon/components/Tools.js +20 -37
  90. package/lib/esm/client/addon/decorator.js +1 -1
  91. package/lib/esm/client/addon/index.js +2 -0
  92. package/lib/esm/client/addon/preset.ie11.js +59 -0
  93. package/lib/esm/client/addon/preset.js +4 -52
  94. package/lib/esm/client/addon/preset.sb7.js +8 -0
  95. package/lib/esm/client/addon/preview.js +5 -0
  96. package/lib/esm/client/addon/register.js +42 -66
  97. package/lib/esm/client/addon/utils.js +3 -2
  98. package/lib/esm/client/addon/withCreevey.js +156 -363
  99. package/lib/esm/client/shared/components/ImagesView/BlendView.js +21 -17
  100. package/lib/esm/client/shared/components/ImagesView/ImagesView.js +21 -17
  101. package/lib/esm/client/shared/components/ImagesView/SideBySideView.js +40 -60
  102. package/lib/esm/client/shared/components/ImagesView/SlideView.js +33 -44
  103. package/lib/esm/client/shared/components/ImagesView/SwapView.js +22 -39
  104. package/lib/esm/client/shared/components/PageFooter/PageFooter.js +12 -8
  105. package/lib/esm/client/shared/components/PageFooter/Paging.js +14 -18
  106. package/lib/esm/client/shared/components/PageHeader/ImagePreview.js +22 -18
  107. package/lib/esm/client/shared/components/PageHeader/PageHeader.js +37 -60
  108. package/lib/esm/client/shared/components/ResultsPage.js +36 -64
  109. package/lib/esm/client/shared/creeveyClientApi.js +57 -84
  110. package/lib/esm/client/shared/helpers.js +123 -194
  111. package/lib/esm/client/shared/viewMode.js +4 -4
  112. package/lib/esm/creevey.js +3 -5
  113. package/lib/esm/index.js +2 -4
  114. package/lib/esm/server/config.js +3 -5
  115. package/lib/esm/server/docker.js +2 -2
  116. package/lib/esm/server/extract.js +1 -3
  117. package/lib/esm/server/index.js +1 -1
  118. package/lib/esm/server/loaders/babel/creevey-plugin.js +1 -3
  119. package/lib/esm/server/loaders/babel/helpers.js +12 -22
  120. package/lib/esm/server/loaders/babel/register.js +3 -5
  121. package/lib/esm/server/loaders/webpack/compile.js +35 -52
  122. package/lib/esm/server/loaders/webpack/creevey-loader.js +9 -10
  123. package/lib/esm/server/loaders/webpack/dummy-hmr.js +2 -6
  124. package/lib/esm/server/loaders/webpack/mdx-loader.js +2 -2
  125. package/lib/esm/server/loaders/webpack/start.js +1 -1
  126. package/lib/esm/server/master/index.js +2 -2
  127. package/lib/esm/server/master/pool.js +7 -18
  128. package/lib/esm/server/master/runner.js +53 -66
  129. package/lib/esm/server/master/server.js +5 -3
  130. package/lib/esm/server/messages.js +3 -5
  131. package/lib/esm/server/selenium/browser.js +54 -66
  132. package/lib/esm/server/selenium/selenoid.js +4 -6
  133. package/lib/esm/server/stories.js +16 -32
  134. package/lib/esm/server/storybook/entry.js +5 -22
  135. package/lib/esm/server/storybook/helpers.js +12 -21
  136. package/lib/esm/server/storybook/providers/browser.js +6 -9
  137. package/lib/esm/server/storybook/providers/hybrid.js +10 -13
  138. package/lib/esm/server/storybook/providers/nodejs.js +10 -11
  139. package/lib/esm/server/{parser.js → testsFiles/parser.js} +1 -14
  140. package/lib/esm/server/testsFiles/register.js +31 -0
  141. package/lib/esm/server/update.js +1 -5
  142. package/lib/esm/server/utils.js +18 -31
  143. package/lib/esm/server/worker/reporter.js +8 -20
  144. package/lib/esm/server/worker/worker.js +9 -19
  145. package/lib/esm/shared/index.js +78 -0
  146. package/lib/esm/shared/serializeRegExp.js +24 -0
  147. package/lib/esm/types.js +1 -0
  148. package/lib/types/client/addon/Manager.d.ts +2 -2
  149. package/lib/types/client/addon/components/TestSelect.d.ts +0 -1
  150. package/lib/types/client/addon/index.d.ts +2 -0
  151. package/lib/types/client/addon/preset.d.ts +0 -22
  152. package/lib/types/client/addon/preset.ie11.d.ts +10 -0
  153. package/lib/types/client/addon/preset.sb7.d.ts +2 -0
  154. package/lib/types/client/addon/preview.d.ts +4 -0
  155. package/lib/types/client/addon/utils.d.ts +1 -0
  156. package/lib/types/client/addon/withCreevey.d.ts +1 -1
  157. package/lib/types/client/shared/components/ImagesView/BlendView.d.ts +1 -1
  158. package/lib/types/client/shared/components/ImagesView/ImagesView.d.ts +0 -1
  159. package/lib/types/client/shared/components/ImagesView/SideBySideView.d.ts +1 -1
  160. package/lib/types/client/shared/components/ImagesView/SlideView.d.ts +1 -1
  161. package/lib/types/client/shared/components/ImagesView/SwapView.d.ts +1 -1
  162. package/lib/types/client/shared/components/PageFooter/PageFooter.d.ts +0 -1
  163. package/lib/types/client/shared/components/PageFooter/Paging.d.ts +0 -1
  164. package/lib/types/client/shared/components/PageHeader/ImagePreview.d.ts +1 -1
  165. package/lib/types/client/shared/components/PageHeader/PageHeader.d.ts +0 -1
  166. package/lib/types/client/shared/components/ResultsPage.d.ts +1 -1
  167. package/lib/types/client/web/CreeveyApp.d.ts +0 -1
  168. package/lib/types/client/web/CreeveyLoader.d.ts +1 -2
  169. package/lib/types/client/web/CreeveyView/SideBar/Checkbox.d.ts +1 -1
  170. package/lib/types/client/web/CreeveyView/SideBar/SideBarHeader.d.ts +0 -1
  171. package/lib/types/client/web/CreeveyView/SideBar/SuiteLink.d.ts +4 -4
  172. package/lib/types/client/web/CreeveyView/SideBar/TestLink.d.ts +0 -1
  173. package/lib/types/client/web/CreeveyView/SideBar/TestStatusIcon.d.ts +1 -1
  174. package/lib/types/client/web/CreeveyView/SideBar/TestsStatus.d.ts +1 -1
  175. package/lib/types/index.d.ts +4 -2
  176. package/lib/types/server/config.d.ts +1 -1
  177. package/lib/types/server/loaders/babel/register.d.ts +1 -1
  178. package/lib/types/server/loaders/webpack/creevey-loader.d.ts +4 -2
  179. package/lib/types/server/logger.d.ts +6 -2
  180. package/lib/types/server/messages.d.ts +13 -12
  181. package/lib/types/server/selenium/browser.d.ts +5 -3
  182. package/lib/types/server/storybook/entry.d.ts +2 -3
  183. package/lib/types/server/storybook/helpers.d.ts +1 -1
  184. package/lib/types/server/storybook/providers/browser.d.ts +2 -4
  185. package/lib/types/server/storybook/providers/hybrid.d.ts +2 -4
  186. package/lib/types/server/storybook/providers/nodejs.d.ts +3 -3
  187. package/lib/types/server/{parser.d.ts → testsFiles/parser.d.ts} +1 -1
  188. package/lib/types/server/testsFiles/register.d.ts +2 -0
  189. package/lib/types/server/utils.d.ts +5 -1
  190. package/lib/types/{shared.d.ts → shared/index.d.ts} +1 -10
  191. package/lib/types/shared/serializeRegExp.d.ts +9 -0
  192. package/lib/types/types.d.ts +7 -9
  193. package/package.json +119 -102
  194. package/preset/ie11.js +5 -0
  195. package/{preset.js → preset/index.js} +2 -2
  196. package/preset/sb7.js +5 -0
  197. package/types/global.d.ts +5 -0
  198. package/types/mdx.d.ts +3 -2
  199. package/lib/cjs/client/web/1.js +0 -13
  200. package/lib/cjs/client/web/2.js +0 -1
  201. package/lib/cjs/shared.js +0 -107
  202. package/lib/esm/shared.js +0 -76
  203. package/storybook-static/stories.json +0 -21
@@ -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,
@@ -75,7 +58,7 @@ export var Tools = function Tools(_ref) {
75
58
  }
76
59
 
77
60
  return /*#__PURE__*/React.createElement(Fragment, null, /*#__PURE__*/React.createElement(IconButton, {
78
- href: "http://localhost:".concat(__CREEVEY_CLIENT_PORT__ || __CREEVEY_SERVER_PORT__, "/?").concat(stringify({
61
+ href: "http://localhost:".concat(__CREEVEY_CLIENT_PORT__ || __CREEVEY_SERVER_PORT__ || 3000, "/?").concat(stringify({
79
62
  testPath: getTestPath(test)
80
63
  })),
81
64
  target: "_blank",
@@ -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,56 +1,8 @@
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
- import path from 'path';
14
- import { exec } from 'shelljs';
15
- import { DefinePlugin as FallbackDefinePlugin } from 'webpack';
16
- import { isStorybookVersionLessThan, resolveFromStorybookCore, resolveFromStorybookCoreServer } from '../../server/storybook/helpers';
17
1
  export function config() {
18
- var entry = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
19
- return [].concat(_toConsumableArray(entry), [require.resolve('./decorator')]);
2
+ let entry = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
3
+ return [...entry, require.resolve('./decorator')];
20
4
  }
21
5
  export function managerEntries() {
22
- var entry = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
23
- return [].concat(_toConsumableArray(entry), [require.resolve('./register')]);
24
- }
25
- export function managerWebpack(config, options) {
26
- var _options$presets$appl, _options$presets;
27
-
28
- // TODO How to execute with non-webpack bundlers
29
- if (options.configType == 'PRODUCTION' && !isStorybookVersionLessThan(6, 2) && options.skipExtract != true) {
30
- var args = [];
31
- if (options.creeveyPreExtract) args.push("--require \"".concat(options.creeveyPreExtract, "\""));
32
- args.push(path.join(__dirname, '../../cli'));
33
- args.push("--extract \"".concat(options.outputDir, "\""));
34
- if (options.creeveyConfigPath) args.push("--config \"".concat(options.creeveyConfigPath, "\""));
35
- exec("node ".concat(args.join(' ')), {
36
- async: true
37
- });
38
- }
39
-
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) {
43
- var _config$plugins, _options$creeveyPort;
44
-
45
- var _ref = webpack !== null && webpack !== void 0 ? webpack : {},
46
- _ref$DefinePlugin = _ref.DefinePlugin,
47
- DefinePlugin = _ref$DefinePlugin === void 0 ? FallbackDefinePlugin : _ref$DefinePlugin;
48
-
49
- (_config$plugins = config.plugins) === null || _config$plugins === void 0 ? void 0 : _config$plugins.push(new DefinePlugin({
50
- __CREEVEY_SERVER_HOST__: options.creeveyHost,
51
- __CREEVEY_SERVER_PORT__: (_options$creeveyPort = options.creeveyPort) !== null && _options$creeveyPort !== void 0 ? _options$creeveyPort : 3000,
52
- __CREEVEY_CLIENT_PORT__: options.clientPort
53
- }));
54
- return config;
55
- });
6
+ let entry = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
7
+ return [...entry, require.resolve('./register')];
56
8
  }
@@ -0,0 +1,8 @@
1
+ export const previewAnnotations = function () {
2
+ let entry = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
3
+ return [...entry, require.resolve('./preview')];
4
+ };
5
+ export function managerEntries() {
6
+ let entry = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
7
+ return [...entry, require.resolve('./register')];
8
+ }
@@ -0,0 +1,5 @@
1
+ import { withCreevey } from './withCreevey';
2
+ const preview = {
3
+ decorators: [withCreevey()]
4
+ };
5
+ export default preview;
@@ -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/');