creevey 0.9.0-beta.2 → 0.9.0-non-webpack.1

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 (236) hide show
  1. package/AUTHORS +15 -15
  2. package/CHANGELOG.md +1275 -1275
  3. package/LICENSE +21 -21
  4. package/README.md +7 -0
  5. package/addon/README.md +3 -0
  6. package/addon/package.json +4 -0
  7. package/docs/config.md +212 -212
  8. package/docs/grid.md +10 -10
  9. package/docs/tests.md +63 -63
  10. package/jest.config.js +6 -0
  11. package/lib/cjs/client/addon/Manager.js +123 -271
  12. package/lib/cjs/client/addon/components/Addon.js +17 -38
  13. package/lib/cjs/client/addon/components/Icons.js +12 -8
  14. package/lib/cjs/client/addon/components/Panel.js +17 -13
  15. package/lib/cjs/client/addon/components/TestSelect.js +11 -9
  16. package/lib/cjs/client/addon/components/Tools.js +21 -40
  17. package/lib/cjs/client/addon/decorator.js +1 -1
  18. package/lib/cjs/client/addon/index.js +31 -0
  19. package/lib/cjs/client/addon/preset.js +13 -32
  20. package/lib/cjs/client/addon/register.js +46 -70
  21. package/lib/cjs/client/addon/utils.js +1 -1
  22. package/lib/cjs/client/addon/withCreevey.js +164 -344
  23. package/lib/cjs/client/shared/components/ImagesView/BlendView.js +23 -21
  24. package/lib/cjs/client/shared/components/ImagesView/ImagesView.js +22 -18
  25. package/lib/cjs/client/shared/components/ImagesView/SideBySideView.js +42 -64
  26. package/lib/cjs/client/shared/components/ImagesView/SlideView.js +35 -48
  27. package/lib/cjs/client/shared/components/ImagesView/SwapView.js +24 -43
  28. package/lib/cjs/client/shared/components/ImagesView/index.js +9 -9
  29. package/lib/cjs/client/shared/components/PageFooter/PageFooter.js +12 -8
  30. package/lib/cjs/client/shared/components/PageFooter/Paging.js +14 -18
  31. package/lib/cjs/client/shared/components/PageHeader/ImagePreview.js +22 -18
  32. package/lib/cjs/client/shared/components/PageHeader/PageHeader.js +42 -67
  33. package/lib/cjs/client/shared/components/ResultsPage.js +39 -69
  34. package/lib/cjs/client/shared/creeveyClientApi.js +55 -82
  35. package/lib/cjs/client/shared/helpers.js +143 -214
  36. package/lib/cjs/client/shared/viewMode.js +5 -5
  37. package/lib/cjs/client/web/142.js +2 -0
  38. package/lib/cjs/client/web/142.js.LICENSE.txt +12 -0
  39. package/lib/cjs/client/web/32.js +1 -0
  40. package/lib/cjs/client/web/551.js +1 -0
  41. package/lib/cjs/client/web/566.js +2 -0
  42. package/lib/cjs/client/web/566.js.LICENSE.txt +31 -0
  43. package/lib/cjs/client/web/691.js +2 -0
  44. package/lib/cjs/client/web/691.js.LICENSE.txt +8 -0
  45. package/lib/cjs/client/web/725.js +1 -0
  46. package/lib/cjs/client/web/index.html +19 -19
  47. package/lib/cjs/client/web/main.js +2 -38
  48. package/lib/cjs/client/web/main.js.LICENSE.txt +49 -0
  49. package/lib/cjs/creevey.js +3 -5
  50. package/lib/cjs/index.js +4 -4
  51. package/lib/cjs/server/config.js +1 -1
  52. package/lib/cjs/server/docker.js +3 -7
  53. package/lib/cjs/server/index.js +1 -1
  54. package/lib/cjs/server/loaders/babel/creevey-plugin.js +1 -3
  55. package/lib/cjs/server/loaders/babel/helpers.js +13 -23
  56. package/lib/cjs/server/loaders/babel/register.js +1 -3
  57. package/lib/cjs/server/loaders/webpack/compile.js +31 -24
  58. package/lib/cjs/server/loaders/webpack/creevey-loader.js +10 -5
  59. package/lib/cjs/server/loaders/webpack/dummy-hmr.js +2 -7
  60. package/lib/cjs/server/loaders/webpack/mdx-loader.js +1 -1
  61. package/lib/cjs/server/loaders/webpack/start.js +1 -1
  62. package/lib/cjs/server/logger.js +2 -1
  63. package/lib/cjs/server/master/index.js +2 -2
  64. package/lib/cjs/server/master/pool.js +9 -18
  65. package/lib/cjs/server/master/runner.js +53 -66
  66. package/lib/cjs/server/master/server.js +2 -2
  67. package/lib/cjs/server/messages.js +8 -10
  68. package/lib/cjs/server/selenium/browser.js +23 -31
  69. package/lib/cjs/server/selenium/selenoid.js +5 -7
  70. package/lib/cjs/server/stories.js +9 -20
  71. package/lib/cjs/server/storybook/entry.js +5 -3
  72. package/lib/cjs/server/storybook/helpers.js +15 -21
  73. package/lib/cjs/server/storybook/providers/browser.js +5 -9
  74. package/lib/cjs/server/storybook/providers/nodejs.js +4 -4
  75. package/lib/cjs/server/update.js +1 -5
  76. package/lib/cjs/server/utils.js +13 -15
  77. package/lib/cjs/server/worker/reporter.js +8 -20
  78. package/lib/cjs/server/worker/worker.js +6 -16
  79. package/lib/cjs/shared/index.js +101 -0
  80. package/lib/cjs/shared/serializeRegExp.js +42 -0
  81. package/lib/cjs/types.js +6 -6
  82. package/lib/esm/client/addon/Manager.js +123 -271
  83. package/lib/esm/client/addon/components/Addon.js +15 -34
  84. package/lib/esm/client/addon/components/Icons.js +11 -7
  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.js +10 -25
  91. package/lib/esm/client/addon/register.js +42 -66
  92. package/lib/esm/client/addon/utils.js +1 -1
  93. package/lib/esm/client/addon/withCreevey.js +157 -341
  94. package/lib/esm/client/shared/components/ImagesView/BlendView.js +21 -17
  95. package/lib/esm/client/shared/components/ImagesView/ImagesView.js +21 -17
  96. package/lib/esm/client/shared/components/ImagesView/SideBySideView.js +40 -60
  97. package/lib/esm/client/shared/components/ImagesView/SlideView.js +33 -44
  98. package/lib/esm/client/shared/components/ImagesView/SwapView.js +22 -39
  99. package/lib/esm/client/shared/components/PageFooter/PageFooter.js +12 -8
  100. package/lib/esm/client/shared/components/PageFooter/Paging.js +14 -18
  101. package/lib/esm/client/shared/components/PageHeader/ImagePreview.js +22 -18
  102. package/lib/esm/client/shared/components/PageHeader/PageHeader.js +37 -60
  103. package/lib/esm/client/shared/components/ResultsPage.js +36 -64
  104. package/lib/esm/client/shared/creeveyClientApi.js +57 -84
  105. package/lib/esm/client/shared/helpers.js +127 -198
  106. package/lib/esm/client/shared/viewMode.js +4 -4
  107. package/lib/esm/creevey.js +3 -5
  108. package/lib/esm/index.js +1 -3
  109. package/lib/esm/server/docker.js +2 -2
  110. package/lib/esm/server/index.js +1 -1
  111. package/lib/esm/server/loaders/babel/creevey-plugin.js +1 -3
  112. package/lib/esm/server/loaders/babel/helpers.js +12 -22
  113. package/lib/esm/server/loaders/babel/register.js +1 -3
  114. package/lib/esm/server/loaders/webpack/compile.js +31 -24
  115. package/lib/esm/server/loaders/webpack/creevey-loader.js +9 -4
  116. package/lib/esm/server/loaders/webpack/dummy-hmr.js +2 -6
  117. package/lib/esm/server/loaders/webpack/start.js +1 -1
  118. package/lib/esm/server/master/index.js +2 -2
  119. package/lib/esm/server/master/pool.js +7 -18
  120. package/lib/esm/server/master/runner.js +53 -66
  121. package/lib/esm/server/master/server.js +2 -2
  122. package/lib/esm/server/messages.js +3 -5
  123. package/lib/esm/server/selenium/browser.js +20 -28
  124. package/lib/esm/server/selenium/selenoid.js +4 -6
  125. package/lib/esm/server/stories.js +9 -20
  126. package/lib/esm/server/storybook/entry.js +4 -2
  127. package/lib/esm/server/storybook/helpers.js +7 -15
  128. package/lib/esm/server/storybook/providers/browser.js +4 -5
  129. package/lib/esm/server/storybook/providers/nodejs.js +3 -3
  130. package/lib/esm/server/update.js +1 -5
  131. package/lib/esm/server/utils.js +5 -9
  132. package/lib/esm/server/worker/reporter.js +8 -20
  133. package/lib/esm/server/worker/worker.js +6 -16
  134. package/lib/esm/shared/index.js +78 -0
  135. package/lib/esm/shared/serializeRegExp.js +24 -0
  136. package/lib/types/cli.d.ts +1 -1
  137. package/lib/types/client/addon/Manager.d.ts +37 -37
  138. package/lib/types/client/addon/components/Addon.d.ts +8 -8
  139. package/lib/types/client/addon/components/Icons.d.ts +7 -7
  140. package/lib/types/client/addon/components/Panel.d.ts +9 -9
  141. package/lib/types/client/addon/components/TestSelect.d.ts +8 -9
  142. package/lib/types/client/addon/components/Tools.d.ts +6 -6
  143. package/lib/types/client/addon/decorator.d.ts +1 -1
  144. package/lib/types/client/addon/index.d.ts +2 -0
  145. package/lib/types/client/addon/preset.d.ts +23 -24
  146. package/lib/types/client/addon/readyForCapture.d.ts +6 -6
  147. package/lib/types/client/addon/register.d.ts +3 -3
  148. package/lib/types/client/addon/utils.d.ts +2 -2
  149. package/lib/types/client/addon/withCreevey.d.ts +24 -24
  150. package/lib/types/client/shared/components/ImagesView/BlendView.d.ts +3 -3
  151. package/lib/types/client/shared/components/ImagesView/ImagesView.d.ts +24 -25
  152. package/lib/types/client/shared/components/ImagesView/SideBySideView.d.ts +3 -3
  153. package/lib/types/client/shared/components/ImagesView/SlideView.d.ts +3 -3
  154. package/lib/types/client/shared/components/ImagesView/SwapView.d.ts +3 -3
  155. package/lib/types/client/shared/components/ImagesView/index.d.ts +5 -5
  156. package/lib/types/client/shared/components/PageFooter/PageFooter.d.ts +8 -9
  157. package/lib/types/client/shared/components/PageFooter/Paging.d.ts +7 -8
  158. package/lib/types/client/shared/components/PageHeader/ImagePreview.d.ts +12 -12
  159. package/lib/types/client/shared/components/PageHeader/PageHeader.d.ts +16 -17
  160. package/lib/types/client/shared/components/ResultsPage.d.ts +18 -18
  161. package/lib/types/client/shared/creeveyClientApi.d.ts +9 -9
  162. package/lib/types/client/shared/helpers.d.ts +46 -46
  163. package/lib/types/client/shared/viewMode.d.ts +4 -4
  164. package/lib/types/client/web/CreeveyApp.d.ts +11 -12
  165. package/lib/types/client/web/CreeveyContext.d.ts +11 -11
  166. package/lib/types/client/web/CreeveyLoader.d.ts +2 -3
  167. package/lib/types/client/web/CreeveyView/SideBar/Checkbox.d.ts +19 -19
  168. package/lib/types/client/web/CreeveyView/SideBar/Search.d.ts +6 -6
  169. package/lib/types/client/web/CreeveyView/SideBar/SideBar.d.ts +14 -14
  170. package/lib/types/client/web/CreeveyView/SideBar/SideBarHeader.d.ts +12 -13
  171. package/lib/types/client/web/CreeveyView/SideBar/SuiteLink.d.ts +33 -33
  172. package/lib/types/client/web/CreeveyView/SideBar/TestLink.d.ts +7 -8
  173. package/lib/types/client/web/CreeveyView/SideBar/TestStatusIcon.d.ts +10 -10
  174. package/lib/types/client/web/CreeveyView/SideBar/TestsStatus.d.ts +9 -9
  175. package/lib/types/client/web/CreeveyView/SideBar/Toggle.d.ts +6 -6
  176. package/lib/types/client/web/CreeveyView/SideBar/index.d.ts +1 -1
  177. package/lib/types/client/web/KeyboardEventsContext.d.ts +13 -13
  178. package/lib/types/client/web/index.d.ts +4 -4
  179. package/lib/types/creevey.d.ts +1 -1
  180. package/lib/types/index.d.ts +0 -1
  181. package/lib/types/server/config.d.ts +4 -4
  182. package/lib/types/server/docker.d.ts +7 -7
  183. package/lib/types/server/extract.d.ts +2 -2
  184. package/lib/types/server/index.d.ts +2 -2
  185. package/lib/types/server/loaders/babel/creevey-plugin.d.ts +1 -1
  186. package/lib/types/server/loaders/babel/helpers.d.ts +19 -19
  187. package/lib/types/server/loaders/babel/register.d.ts +5 -5
  188. package/lib/types/server/loaders/hooks/mdx.d.ts +1 -1
  189. package/lib/types/server/loaders/hooks/svelte.d.ts +1 -1
  190. package/lib/types/server/loaders/webpack/compile.d.ts +2 -2
  191. package/lib/types/server/loaders/webpack/creevey-loader.d.ts +4 -2
  192. package/lib/types/server/loaders/webpack/dummy-hmr.d.ts +10 -10
  193. package/lib/types/server/loaders/webpack/mdx-loader.d.ts +6 -6
  194. package/lib/types/server/loaders/webpack/start.d.ts +1 -1
  195. package/lib/types/server/logger.d.ts +10 -6
  196. package/lib/types/server/master/api.d.ts +7 -7
  197. package/lib/types/server/master/index.d.ts +3 -3
  198. package/lib/types/server/master/master.d.ts +7 -7
  199. package/lib/types/server/master/pool.d.ts +31 -31
  200. package/lib/types/server/master/runner.d.ts +26 -26
  201. package/lib/types/server/master/server.d.ts +2 -2
  202. package/lib/types/server/messages.d.ts +27 -27
  203. package/lib/types/server/selenium/browser.d.ts +17 -17
  204. package/lib/types/server/selenium/index.d.ts +2 -2
  205. package/lib/types/server/selenium/selenoid.d.ts +3 -3
  206. package/lib/types/server/stories.d.ts +8 -8
  207. package/lib/types/server/storybook/entry.d.ts +18 -18
  208. package/lib/types/server/storybook/helpers.d.ts +24 -24
  209. package/lib/types/server/storybook/providers/browser.d.ts +4 -4
  210. package/lib/types/server/storybook/providers/hybrid.d.ts +4 -4
  211. package/lib/types/server/storybook/providers/nodejs.d.ts +9 -9
  212. package/lib/types/server/testsFiles/parser.d.ts +12 -12
  213. package/lib/types/server/testsFiles/register.d.ts +2 -2
  214. package/lib/types/server/update.d.ts +2 -2
  215. package/lib/types/server/utils.d.ts +20 -20
  216. package/lib/types/server/worker/chai-image.d.ts +6 -6
  217. package/lib/types/server/worker/helpers.d.ts +8 -8
  218. package/lib/types/server/worker/index.d.ts +1 -1
  219. package/lib/types/server/worker/reporter.d.ts +8 -8
  220. package/lib/types/server/worker/worker.d.ts +4 -4
  221. package/lib/types/{shared.d.ts → shared/index.d.ts} +7 -16
  222. package/lib/types/shared/serializeRegExp.d.ts +9 -0
  223. package/lib/types/types.d.ts +490 -489
  224. package/package.json +115 -102
  225. package/preset.js +9 -9
  226. package/types/babel__register.d.ts +1 -1
  227. package/types/chai.d.ts +12 -12
  228. package/types/event-source-polyfill.d.ts +6 -6
  229. package/types/mdx.d.ts +3 -2
  230. package/types/mocha.d.ts +20 -20
  231. package/types/png.d.ts +4 -4
  232. package/lib/cjs/client/web/1.js +0 -13
  233. package/lib/cjs/client/web/2.js +0 -1
  234. package/lib/cjs/shared.js +0 -124
  235. package/lib/esm/shared.js +0 -93
  236. package/storybook-static/stories.json +0 -21
@@ -4,31 +4,35 @@ import { ResultsPage } from '../../shared/components/ResultsPage';
4
4
  import { styled } from '@storybook/theming';
5
5
  import { getTestPath } from '../../shared/helpers';
6
6
  import TestSelect from './TestSelect';
7
- var Wrapper = styled.div(function (_ref) {
8
- var isRunning = _ref.isRunning;
7
+ const Wrapper = styled.div(_ref => {
8
+ let {
9
+ isRunning
10
+ } = _ref;
9
11
  return {
10
12
  opacity: isRunning ? 0.5 : 1,
11
13
  height: '100%'
12
14
  };
13
15
  });
14
- var TestSelectContainer = styled.div(function (_ref2) {
15
- var theme = _ref2.theme;
16
+ const TestSelectContainer = styled.div(_ref2 => {
17
+ let {
18
+ theme
19
+ } = _ref2;
16
20
  return {
17
21
  padding: '8px',
18
22
  border: "1px solid ".concat(theme.appBorderColor)
19
23
  };
20
24
  });
21
- export var Panel = function Panel(_ref3) {
25
+ export const Panel = _ref3 => {
22
26
  var _result$results, _result$results$lengt, _result$results2;
23
27
 
24
- var tests = _ref3.tests,
25
- selectedTestId = _ref3.selectedTestId,
26
- onChangeTest = _ref3.onChangeTest,
27
- onImageApprove = _ref3.onImageApprove;
28
- var result = tests.find(function (x) {
29
- return x.id === selectedTestId;
30
- });
31
- var isRunning = (result === null || result === void 0 ? void 0 : result.status) === 'running';
28
+ let {
29
+ tests,
30
+ selectedTestId,
31
+ onChangeTest,
32
+ onImageApprove
33
+ } = _ref3;
34
+ const result = tests.find(x => x.id === selectedTestId);
35
+ const isRunning = (result === null || result === void 0 ? void 0 : result.status) === 'running';
32
36
  return /*#__PURE__*/React.createElement("div", null, tests.length > 1 && /*#__PURE__*/React.createElement(TestSelectContainer, null, /*#__PURE__*/React.createElement(TestSelect, {
33
37
  tests: tests,
34
38
  selectedTestId: selectedTestId,
@@ -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';
@@ -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
4
  import { isStorybookVersionLessThan, resolveFromStorybookCore, 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
- export function managerWebpack(config, options) {
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
17
  if (options.configType == 'PRODUCTION' && !isStorybookVersionLessThan(6, 2) && options.skipExtract != true) {
30
- var args = [];
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,15 +25,12 @@ 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(isStorybookVersionLessThan(6, 2) ? resolveFromStorybookCore('webpack') : 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({
50
35
  __CREEVEY_SERVER_HOST__: options.creeveyHost,
51
36
  __CREEVEY_SERVER_PORT__: (_options$creeveyPort = options.creeveyPort) !== null && _options$creeveyPort !== void 0 ? _options$creeveyPort : 3000,
@@ -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':