creevey 0.8.1-sb7.0 → 0.8.1-sb7.2

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 (235) hide show
  1. package/lib/cjs/cli.js +5 -0
  2. package/lib/cjs/client/addon/Manager.js +264 -0
  3. package/lib/cjs/client/addon/components/Addon.js +55 -0
  4. package/lib/cjs/client/addon/components/Icons.js +46 -0
  5. package/lib/cjs/client/addon/components/Panel.js +72 -0
  6. package/lib/cjs/client/addon/components/TestSelect.js +65 -0
  7. package/lib/cjs/client/addon/components/Tools.js +97 -0
  8. package/lib/cjs/client/addon/decorator.js +11 -0
  9. package/lib/cjs/client/addon/index.js +31 -0
  10. package/lib/cjs/client/addon/preset.ie11.js +74 -0
  11. package/lib/cjs/client/addon/preset.js +62 -0
  12. package/lib/cjs/client/addon/readyForCapture.js +12 -0
  13. package/lib/cjs/client/addon/register.js +74 -0
  14. package/lib/cjs/client/addon/utils.js +42 -0
  15. package/lib/cjs/client/addon/withCreevey.js +354 -0
  16. package/lib/cjs/client/shared/components/ImagesView/BlendView.js +87 -0
  17. package/lib/cjs/client/shared/components/ImagesView/ImagesView.js +92 -0
  18. package/lib/cjs/client/shared/components/ImagesView/SideBySideView.js +154 -0
  19. package/lib/cjs/client/shared/components/ImagesView/SlideView.js +166 -0
  20. package/lib/cjs/client/shared/components/ImagesView/SwapView.js +91 -0
  21. package/lib/cjs/client/shared/components/ImagesView/index.js +45 -0
  22. package/lib/cjs/client/shared/components/PageFooter/PageFooter.js +50 -0
  23. package/lib/cjs/client/shared/components/PageFooter/Paging.js +94 -0
  24. package/lib/cjs/client/shared/components/PageHeader/ImagePreview.js +82 -0
  25. package/lib/cjs/client/shared/components/PageHeader/PageHeader.js +119 -0
  26. package/lib/cjs/client/shared/components/ResultsPage.js +143 -0
  27. package/lib/cjs/client/shared/creeveyClientApi.js +76 -0
  28. package/lib/cjs/client/shared/helpers.js +411 -0
  29. package/lib/cjs/client/shared/viewMode.js +17 -0
  30. package/lib/cjs/client/web/19.js +1 -0
  31. package/lib/cjs/client/web/632.js +43 -0
  32. package/lib/cjs/client/web/794.js +1 -0
  33. package/lib/cjs/client/web/index.html +19 -0
  34. package/lib/cjs/client/web/main.js +79 -0
  35. package/lib/cjs/client/web/main.js.LICENSE.txt +34 -0
  36. package/lib/cjs/creevey.js +69 -0
  37. package/lib/cjs/index.js +39 -0
  38. package/lib/cjs/server/config.js +93 -0
  39. package/lib/cjs/server/docker.js +146 -0
  40. package/lib/cjs/server/extract.js +46 -0
  41. package/lib/cjs/server/index.js +83 -0
  42. package/lib/cjs/server/loaders/babel/creevey-plugin.js +86 -0
  43. package/lib/cjs/server/loaders/babel/helpers.js +469 -0
  44. package/lib/cjs/server/loaders/babel/register.js +124 -0
  45. package/lib/cjs/server/loaders/hooks/mdx.js +30 -0
  46. package/lib/cjs/server/loaders/hooks/svelte.js +65 -0
  47. package/lib/cjs/server/loaders/webpack/compile.js +269 -0
  48. package/lib/cjs/server/loaders/webpack/creevey-loader.js +172 -0
  49. package/lib/cjs/server/loaders/webpack/dummy-hmr.js +39 -0
  50. package/lib/cjs/server/loaders/webpack/mdx-loader.js +72 -0
  51. package/lib/cjs/server/loaders/webpack/start.js +41 -0
  52. package/lib/cjs/server/logger.js +48 -0
  53. package/lib/cjs/server/master/api.js +71 -0
  54. package/lib/cjs/server/master/index.js +152 -0
  55. package/lib/cjs/server/master/master.js +57 -0
  56. package/lib/cjs/server/master/pool.js +197 -0
  57. package/lib/cjs/server/master/runner.js +281 -0
  58. package/lib/cjs/server/master/server.js +131 -0
  59. package/lib/cjs/server/messages.js +264 -0
  60. package/lib/cjs/server/selenium/browser.js +667 -0
  61. package/lib/cjs/server/selenium/index.js +31 -0
  62. package/lib/cjs/server/selenium/selenoid.js +172 -0
  63. package/lib/cjs/server/stories.js +155 -0
  64. package/lib/cjs/server/storybook/entry.js +55 -0
  65. package/lib/cjs/server/storybook/helpers.js +158 -0
  66. package/lib/cjs/server/storybook/providers/browser.js +76 -0
  67. package/lib/cjs/server/storybook/providers/nodejs.js +239 -0
  68. package/lib/cjs/server/update.js +79 -0
  69. package/lib/cjs/server/utils.js +169 -0
  70. package/lib/cjs/server/worker/chai-image.js +142 -0
  71. package/lib/cjs/server/worker/helpers.js +69 -0
  72. package/lib/cjs/server/worker/index.js +15 -0
  73. package/lib/cjs/server/worker/reporter.js +108 -0
  74. package/lib/cjs/server/worker/worker.js +268 -0
  75. package/lib/cjs/shared/index.js +103 -0
  76. package/lib/cjs/shared/serializeRegExp.js +42 -0
  77. package/lib/cjs/types.js +77 -0
  78. package/lib/esm/cli.js +4 -0
  79. package/lib/esm/client/addon/Manager.js +252 -0
  80. package/lib/esm/client/addon/components/Addon.js +39 -0
  81. package/lib/esm/client/addon/components/Icons.js +31 -0
  82. package/lib/esm/client/addon/components/Panel.js +53 -0
  83. package/lib/esm/client/addon/components/TestSelect.js +51 -0
  84. package/lib/esm/client/addon/components/Tools.js +76 -0
  85. package/lib/esm/client/addon/decorator.js +2 -0
  86. package/lib/esm/client/addon/index.js +2 -0
  87. package/lib/esm/client/addon/preset.ie11.js +59 -0
  88. package/lib/esm/client/addon/preset.js +41 -0
  89. package/lib/esm/client/addon/readyForCapture.js +5 -0
  90. package/lib/esm/client/addon/register.js +53 -0
  91. package/lib/esm/client/addon/utils.js +32 -0
  92. package/lib/esm/client/addon/withCreevey.js +327 -0
  93. package/lib/esm/client/shared/components/ImagesView/BlendView.js +67 -0
  94. package/lib/esm/client/shared/components/ImagesView/ImagesView.js +69 -0
  95. package/lib/esm/client/shared/components/ImagesView/SideBySideView.js +131 -0
  96. package/lib/esm/client/shared/components/ImagesView/SlideView.js +143 -0
  97. package/lib/esm/client/shared/components/ImagesView/SwapView.js +71 -0
  98. package/lib/esm/client/shared/components/ImagesView/index.js +5 -0
  99. package/lib/esm/client/shared/components/PageFooter/PageFooter.js +36 -0
  100. package/lib/esm/client/shared/components/PageFooter/Paging.js +80 -0
  101. package/lib/esm/client/shared/components/PageHeader/ImagePreview.js +68 -0
  102. package/lib/esm/client/shared/components/PageHeader/PageHeader.js +97 -0
  103. package/lib/esm/client/shared/components/ResultsPage.js +115 -0
  104. package/lib/esm/client/shared/creeveyClientApi.js +67 -0
  105. package/lib/esm/client/shared/helpers.js +353 -0
  106. package/lib/esm/client/shared/viewMode.js +6 -0
  107. package/lib/esm/creevey.js +54 -0
  108. package/lib/esm/index.js +3 -0
  109. package/lib/esm/server/config.js +70 -0
  110. package/lib/esm/server/docker.js +123 -0
  111. package/lib/esm/server/extract.js +32 -0
  112. package/lib/esm/server/index.js +64 -0
  113. package/lib/esm/server/loaders/babel/creevey-plugin.js +72 -0
  114. package/lib/esm/server/loaders/babel/helpers.js +452 -0
  115. package/lib/esm/server/loaders/babel/register.js +103 -0
  116. package/lib/esm/server/loaders/hooks/mdx.js +15 -0
  117. package/lib/esm/server/loaders/hooks/svelte.js +49 -0
  118. package/lib/esm/server/loaders/webpack/compile.js +246 -0
  119. package/lib/esm/server/loaders/webpack/creevey-loader.js +152 -0
  120. package/lib/esm/server/loaders/webpack/dummy-hmr.js +32 -0
  121. package/lib/esm/server/loaders/webpack/mdx-loader.js +58 -0
  122. package/lib/esm/server/loaders/webpack/start.js +27 -0
  123. package/lib/esm/server/logger.js +20 -0
  124. package/lib/esm/server/master/api.js +60 -0
  125. package/lib/esm/server/master/index.js +131 -0
  126. package/lib/esm/server/master/master.js +38 -0
  127. package/lib/esm/server/master/pool.js +176 -0
  128. package/lib/esm/server/master/runner.js +259 -0
  129. package/lib/esm/server/master/server.js +107 -0
  130. package/lib/esm/server/messages.js +232 -0
  131. package/lib/esm/server/selenium/browser.js +634 -0
  132. package/lib/esm/server/selenium/index.js +2 -0
  133. package/lib/esm/server/selenium/selenoid.js +149 -0
  134. package/lib/esm/server/stories.js +137 -0
  135. package/lib/esm/server/storybook/entry.js +29 -0
  136. package/lib/esm/server/storybook/helpers.js +99 -0
  137. package/lib/esm/server/storybook/providers/browser.js +60 -0
  138. package/lib/esm/server/storybook/providers/nodejs.js +219 -0
  139. package/lib/esm/server/update.js +61 -0
  140. package/lib/esm/server/utils.js +128 -0
  141. package/lib/esm/server/worker/chai-image.js +130 -0
  142. package/lib/esm/server/worker/helpers.js +60 -0
  143. package/lib/esm/server/worker/index.js +1 -0
  144. package/lib/esm/server/worker/reporter.js +86 -0
  145. package/lib/esm/server/worker/worker.js +238 -0
  146. package/lib/esm/shared/index.js +80 -0
  147. package/lib/esm/shared/serializeRegExp.js +24 -0
  148. package/lib/esm/types.js +46 -0
  149. package/lib/types/cli.d.ts +1 -0
  150. package/lib/types/client/addon/Manager.d.ts +37 -0
  151. package/lib/types/client/addon/components/Addon.d.ts +9 -0
  152. package/lib/types/client/addon/components/Icons.d.ts +8 -0
  153. package/lib/types/client/addon/components/Panel.d.ts +10 -0
  154. package/lib/types/client/addon/components/TestSelect.d.ts +9 -0
  155. package/lib/types/client/addon/components/Tools.d.ts +7 -0
  156. package/lib/types/client/addon/decorator.d.ts +1 -0
  157. package/lib/types/client/addon/index.d.ts +2 -0
  158. package/lib/types/client/addon/preset.d.ts +23 -0
  159. package/lib/types/client/addon/preset.ie11.d.ts +10 -0
  160. package/lib/types/client/addon/readyForCapture.d.ts +6 -0
  161. package/lib/types/client/addon/register.d.ts +3 -0
  162. package/lib/types/client/addon/utils.d.ts +3 -0
  163. package/lib/types/client/addon/withCreevey.d.ts +24 -0
  164. package/lib/types/client/shared/components/ImagesView/BlendView.d.ts +5 -0
  165. package/lib/types/client/shared/components/ImagesView/ImagesView.d.ts +25 -0
  166. package/lib/types/client/shared/components/ImagesView/SideBySideView.d.ts +5 -0
  167. package/lib/types/client/shared/components/ImagesView/SlideView.d.ts +5 -0
  168. package/lib/types/client/shared/components/ImagesView/SwapView.d.ts +5 -0
  169. package/lib/types/client/shared/components/ImagesView/index.d.ts +5 -0
  170. package/lib/types/client/shared/components/PageFooter/PageFooter.d.ts +9 -0
  171. package/lib/types/client/shared/components/PageFooter/Paging.d.ts +8 -0
  172. package/lib/types/client/shared/components/PageHeader/ImagePreview.d.ts +14 -0
  173. package/lib/types/client/shared/components/PageHeader/PageHeader.d.ts +17 -0
  174. package/lib/types/client/shared/components/ResultsPage.d.ts +20 -0
  175. package/lib/types/client/shared/creeveyClientApi.d.ts +9 -0
  176. package/lib/types/client/shared/helpers.d.ts +46 -0
  177. package/lib/types/client/shared/viewMode.d.ts +4 -0
  178. package/lib/types/client/web/CreeveyApp.d.ts +12 -0
  179. package/lib/types/client/web/CreeveyContext.d.ts +11 -0
  180. package/lib/types/client/web/CreeveyLoader.d.ts +3 -0
  181. package/lib/types/client/web/CreeveyView/SideBar/Checkbox.d.ts +22 -0
  182. package/lib/types/client/web/CreeveyView/SideBar/Search.d.ts +7 -0
  183. package/lib/types/client/web/CreeveyView/SideBar/SideBar.d.ts +14 -0
  184. package/lib/types/client/web/CreeveyView/SideBar/SideBarHeader.d.ts +13 -0
  185. package/lib/types/client/web/CreeveyView/SideBar/SuiteLink.d.ts +38 -0
  186. package/lib/types/client/web/CreeveyView/SideBar/TestLink.d.ts +8 -0
  187. package/lib/types/client/web/CreeveyView/SideBar/TestStatusIcon.d.ts +12 -0
  188. package/lib/types/client/web/CreeveyView/SideBar/TestsStatus.d.ts +11 -0
  189. package/lib/types/client/web/CreeveyView/SideBar/Toggle.d.ts +7 -0
  190. package/lib/types/client/web/CreeveyView/SideBar/index.d.ts +1 -0
  191. package/lib/types/client/web/KeyboardEventsContext.d.ts +13 -0
  192. package/lib/types/client/web/index.d.ts +4 -0
  193. package/lib/types/creevey.d.ts +1 -0
  194. package/lib/types/index.d.ts +2 -0
  195. package/lib/types/server/config.d.ts +4 -0
  196. package/lib/types/server/docker.d.ts +7 -0
  197. package/lib/types/server/extract.d.ts +2 -0
  198. package/lib/types/server/index.d.ts +2 -0
  199. package/lib/types/server/loaders/babel/creevey-plugin.d.ts +1 -0
  200. package/lib/types/server/loaders/babel/helpers.d.ts +19 -0
  201. package/lib/types/server/loaders/babel/register.d.ts +5 -0
  202. package/lib/types/server/loaders/hooks/mdx.d.ts +1 -0
  203. package/lib/types/server/loaders/hooks/svelte.d.ts +1 -0
  204. package/lib/types/server/loaders/webpack/compile.d.ts +2 -0
  205. package/lib/types/server/loaders/webpack/creevey-loader.d.ts +4 -0
  206. package/lib/types/server/loaders/webpack/dummy-hmr.d.ts +10 -0
  207. package/lib/types/server/loaders/webpack/mdx-loader.d.ts +6 -0
  208. package/lib/types/server/loaders/webpack/start.d.ts +1 -0
  209. package/lib/types/server/logger.d.ts +10 -0
  210. package/lib/types/server/master/api.d.ts +7 -0
  211. package/lib/types/server/master/index.d.ts +3 -0
  212. package/lib/types/server/master/master.d.ts +7 -0
  213. package/lib/types/server/master/pool.d.ts +31 -0
  214. package/lib/types/server/master/runner.d.ts +26 -0
  215. package/lib/types/server/master/server.d.ts +2 -0
  216. package/lib/types/server/messages.d.ts +29 -0
  217. package/lib/types/server/selenium/browser.d.ts +19 -0
  218. package/lib/types/server/selenium/index.d.ts +2 -0
  219. package/lib/types/server/selenium/selenoid.d.ts +3 -0
  220. package/lib/types/server/stories.d.ts +8 -0
  221. package/lib/types/server/storybook/entry.d.ts +16 -0
  222. package/lib/types/server/storybook/helpers.d.ts +24 -0
  223. package/lib/types/server/storybook/providers/browser.d.ts +2 -0
  224. package/lib/types/server/storybook/providers/nodejs.d.ts +6 -0
  225. package/lib/types/server/update.d.ts +2 -0
  226. package/lib/types/server/utils.d.ts +23 -0
  227. package/lib/types/server/worker/chai-image.d.ts +6 -0
  228. package/lib/types/server/worker/helpers.d.ts +8 -0
  229. package/lib/types/server/worker/index.d.ts +1 -0
  230. package/lib/types/server/worker/reporter.d.ts +8 -0
  231. package/lib/types/server/worker/worker.d.ts +4 -0
  232. package/lib/types/shared/index.d.ts +7 -0
  233. package/lib/types/shared/serializeRegExp.d.ts +9 -0
  234. package/lib/types/types.d.ts +486 -0
  235. package/package.json +1 -1
package/lib/cjs/cli.js ADDED
@@ -0,0 +1,5 @@
1
+ #!/usr/bin/env node
2
+ // eslint-disable-next-line node/shebang
3
+ "use strict";
4
+
5
+ require('./creevey');
@@ -0,0 +1,264 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.CreeveyManager = void 0;
7
+
8
+ var _coreEvents = require("@storybook/core-events");
9
+
10
+ var _shared = require("../../shared");
11
+
12
+ var _types = require("../../types");
13
+
14
+ var _creeveyClientApi = require("../shared/creeveyClientApi");
15
+
16
+ var _helpers = require("../shared/helpers");
17
+
18
+ var _register = require("./register");
19
+
20
+ var _utils = require("./utils");
21
+
22
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
23
+
24
+ class CreeveyManager {
25
+ constructor(storybookApi) {
26
+ this.storybookApi = storybookApi;
27
+
28
+ _defineProperty(this, "storyId", '');
29
+
30
+ _defineProperty(this, "activeBrowser", '');
31
+
32
+ _defineProperty(this, "selectedTestId", '');
33
+
34
+ _defineProperty(this, "status", {
35
+ isRunning: false,
36
+ tests: {},
37
+ browsers: []
38
+ });
39
+
40
+ _defineProperty(this, "creeveyApi", null);
41
+
42
+ _defineProperty(this, "stories", {});
43
+
44
+ _defineProperty(this, "updateStatusListeners", []);
45
+
46
+ _defineProperty(this, "changeTestListeners", []);
47
+
48
+ _defineProperty(this, "initAll", async () => {
49
+ this.storybookApi.on(_coreEvents.STORY_RENDERED, this.onStoryRendered);
50
+ this.storybookApi.on(_coreEvents.SET_STORIES, this.onSetStories);
51
+ this.creeveyApi = await (0, _creeveyClientApi.initCreeveyClientApi)();
52
+ this.creeveyApi.onUpdate(this.handleCreeveyUpdate);
53
+ this.status = await this.creeveyApi.status;
54
+ });
55
+
56
+ _defineProperty(this, "handleCreeveyUpdate", update => {
57
+ const {
58
+ tests,
59
+ removedTests = [],
60
+ isRunning
61
+ } = update;
62
+
63
+ if ((0, _types.isDefined)(isRunning)) {
64
+ this.status.isRunning = isRunning;
65
+ }
66
+
67
+ if ((0, _types.isDefined)(tests)) {
68
+ const prevTests = this.status.tests;
69
+ const prevStories = this.stories || {};
70
+ Object.values(tests).filter(_types.isDefined).forEach(update => {
71
+ const {
72
+ id,
73
+ skip,
74
+ status,
75
+ results,
76
+ approved,
77
+ storyId
78
+ } = update;
79
+ const test = prevTests[id];
80
+
81
+ if (!test) {
82
+ return prevTests[id] = update;
83
+ }
84
+
85
+ if ((0, _types.isDefined)(skip)) test.skip = skip;
86
+
87
+ if ((0, _types.isDefined)(status)) {
88
+ test.status = status;
89
+
90
+ if ((0, _types.isDefined)(storyId) && (0, _types.isDefined)(prevStories[storyId])) {
91
+ const story = prevStories[storyId];
92
+ const storyStatus = this.getStoryTests(storyId);
93
+ const oldStatus = storyStatus.map(x => x.id === id ? status : x.status).reduce((oldStatus, newStatus) => (0, _helpers.calcStatus)(oldStatus, newStatus), undefined);
94
+ story.name = this.addStatusToStoryName(story.name, (0, _helpers.calcStatus)(oldStatus, status), skip || false);
95
+ }
96
+ }
97
+
98
+ if ((0, _types.isDefined)(results)) test.results ? test.results.push(...results) : test.results = results;
99
+
100
+ if ((0, _types.isDefined)(approved)) {
101
+ Object.entries(approved).forEach(_ref => {
102
+ let [image, retry] = _ref;
103
+ return retry !== undefined && test && ((test.approved = (test === null || test === void 0 ? void 0 : test.approved) || {})[image] = retry);
104
+ });
105
+ }
106
+ });
107
+ removedTests.forEach(_ref2 => {
108
+ let {
109
+ id
110
+ } = _ref2;
111
+ return delete prevTests[id];
112
+ });
113
+ this.status.tests = prevTests;
114
+ this.stories = prevStories;
115
+ this.setPanelsTitle();
116
+ void this.storybookApi.setStories(this.stories);
117
+ }
118
+
119
+ this.updateStatusListeners.forEach(x => x(update));
120
+ });
121
+
122
+ _defineProperty(this, "getCurrentTest", () => {
123
+ return this.status.tests[this.selectedTestId];
124
+ });
125
+
126
+ _defineProperty(this, "onStoryRendered", storyId => {
127
+ if (this.storyId === '') void this.addStatusesToSideBar();
128
+
129
+ if (this.storyId !== storyId) {
130
+ var _this$getTestsByStory, _this$getTestsByStory2;
131
+
132
+ this.storyId = storyId;
133
+ this.selectedTestId = (_this$getTestsByStory = (_this$getTestsByStory2 = this.getTestsByStoryIdAndBrowser(this.activeBrowser)[0]) === null || _this$getTestsByStory2 === void 0 ? void 0 : _this$getTestsByStory2.id) !== null && _this$getTestsByStory !== void 0 ? _this$getTestsByStory : '';
134
+ this.setPanelsTitle();
135
+ this.changeTestListeners.forEach(x => x(this.selectedTestId));
136
+ }
137
+ });
138
+
139
+ _defineProperty(this, "onStart", () => {
140
+ var _this$creeveyApi;
141
+
142
+ (_this$creeveyApi = this.creeveyApi) === null || _this$creeveyApi === void 0 ? void 0 : _this$creeveyApi.start([this.selectedTestId]);
143
+ });
144
+
145
+ _defineProperty(this, "onStop", () => {
146
+ var _this$creeveyApi2;
147
+
148
+ (_this$creeveyApi2 = this.creeveyApi) === null || _this$creeveyApi2 === void 0 ? void 0 : _this$creeveyApi2.stop();
149
+ });
150
+
151
+ _defineProperty(this, "onImageApprove", (id, retry, image) => {
152
+ var _this$creeveyApi3;
153
+
154
+ return (_this$creeveyApi3 = this.creeveyApi) === null || _this$creeveyApi3 === void 0 ? void 0 : _this$creeveyApi3.approve(id, retry, image);
155
+ });
156
+
157
+ _defineProperty(this, "onStartAllStoryTests", () => {
158
+ var _this$creeveyApi4;
159
+
160
+ const ids = Object.values(this.status.tests).filter(_types.isDefined).filter(x => x.storyId === this.storyId).map(x => x.id);
161
+ (_this$creeveyApi4 = this.creeveyApi) === null || _this$creeveyApi4 === void 0 ? void 0 : _this$creeveyApi4.start(ids);
162
+ });
163
+
164
+ _defineProperty(this, "onStartAllTests", () => {
165
+ var _this$creeveyApi5;
166
+
167
+ const ids = Object.values(this.status.tests).filter(_types.isDefined).map(x => x.id);
168
+ (_this$creeveyApi5 = this.creeveyApi) === null || _this$creeveyApi5 === void 0 ? void 0 : _this$creeveyApi5.start(ids);
169
+ });
170
+
171
+ _defineProperty(this, "onSetStories", data => {
172
+ const stories = data.v ? (0, _shared.denormalizeStoryParameters)(data) : data.stories;
173
+ this.stories = stories;
174
+ });
175
+
176
+ _defineProperty(this, "setActiveBrowser", browser => {
177
+ var _this$getTestsByStory3, _this$getTestsByStory4;
178
+
179
+ this.activeBrowser = browser;
180
+ this.selectedTestId = (_this$getTestsByStory3 = (_this$getTestsByStory4 = this.getTestsByStoryIdAndBrowser(this.activeBrowser)[0]) === null || _this$getTestsByStory4 === void 0 ? void 0 : _this$getTestsByStory4.id) !== null && _this$getTestsByStory3 !== void 0 ? _this$getTestsByStory3 : '';
181
+ this.changeTestListeners.forEach(x => x(this.selectedTestId));
182
+ });
183
+
184
+ _defineProperty(this, "setSelectedTestId", testId => {
185
+ this.selectedTestId = testId;
186
+ this.changeTestListeners.forEach(x => x(this.selectedTestId));
187
+ });
188
+
189
+ _defineProperty(this, "getStoryTests", storyId => {
190
+ if (!this.status || !this.status.tests) return [];
191
+ return Object.values(this.status.tests).filter(result => (result === null || result === void 0 ? void 0 : result.storyId) === storyId).filter(_types.isDefined);
192
+ });
193
+
194
+ _defineProperty(this, "getBrowsers", () => {
195
+ return this.status.browsers;
196
+ });
197
+
198
+ _defineProperty(this, "getTestsByStoryIdAndBrowser", browser => {
199
+ return Object.values(this.status.tests).filter(x => (x === null || x === void 0 ? void 0 : x.browser) === browser && x.storyId === this.storyId).filter(_types.isDefined);
200
+ });
201
+
202
+ _defineProperty(this, "getTabTitle", browser => {
203
+ const tests = this.getTestsByStoryIdAndBrowser(browser);
204
+ const browserStatus = tests.map(x => x && x.status).reduce((oldStatus, newStatus) => (0, _helpers.calcStatus)(oldStatus, newStatus), undefined);
205
+ const browserSkip = tests.length > 0 ? tests.every(x => x && x.skip) : false;
206
+ const emojiStatus = (0, _utils.getEmojiByTestStatus)(browserStatus, browserSkip);
207
+ return "".concat(emojiStatus ? "".concat(emojiStatus, " ") : '', "Creevey/").concat(browser);
208
+ });
209
+
210
+ _defineProperty(this, "setPanelsTitle", () => {
211
+ var _this$storybookApi;
212
+
213
+ const panels = (_this$storybookApi = this.storybookApi) === null || _this$storybookApi === void 0 ? void 0 : _this$storybookApi.getPanels();
214
+ if (!panels) return;
215
+ let firstPanelBrowser = this.activeBrowser;
216
+
217
+ for (const p in panels) {
218
+ var _panel$id;
219
+
220
+ const panel = panels[p];
221
+
222
+ if (((_panel$id = panel.id) === null || _panel$id === void 0 ? void 0 : _panel$id.indexOf(_register.ADDON_ID)) === 0 && panel.paramKey) {
223
+ panel.title = this.getTabTitle(panel.paramKey);
224
+ if (!firstPanelBrowser) firstPanelBrowser = panel.paramKey;
225
+ }
226
+ }
227
+
228
+ this.storybookApi.setSelectedPanel("".concat(_register.ADDON_ID, "/panel/").concat(firstPanelBrowser));
229
+ });
230
+
231
+ this.storybookApi = storybookApi;
232
+ }
233
+
234
+ onUpdateStatus(listener) {
235
+ this.updateStatusListeners.push(listener);
236
+ return () => void (this.updateStatusListeners = this.updateStatusListeners.filter(x => x != listener));
237
+ }
238
+
239
+ onChangeTest(listener) {
240
+ this.changeTestListeners.push(listener);
241
+ return () => void (this.changeTestListeners = this.changeTestListeners.filter(x => x != listener));
242
+ }
243
+
244
+ async addStatusesToSideBar() {
245
+ if (!Object.keys(this.stories).length) return;
246
+ const stories = this.stories;
247
+ Object.keys(this.stories).forEach(storyId => {
248
+ const storyStatus = this.getStoryTests(storyId);
249
+ const status = storyStatus.map(x => x.status).reduce((oldStatus, newStatus) => (0, _helpers.calcStatus)(oldStatus, newStatus), undefined);
250
+ const skip = storyStatus.length > 0 ? storyStatus.every(x => x.skip) : false;
251
+ this.stories[storyId].name = this.addStatusToStoryName(stories[storyId].name, status, skip);
252
+ });
253
+ await this.storybookApi.setStories(this.stories);
254
+ }
255
+
256
+ addStatusToStoryName(name, status, skip) {
257
+ name = name.replace(/^(❌|✔|🟡|🕗|⏸) /, '');
258
+ const emojiStatus = (0, _utils.getEmojiByTestStatus)(status, skip);
259
+ return "".concat(emojiStatus ? "".concat(emojiStatus, " ") : '', " ").concat(name);
260
+ }
261
+
262
+ }
263
+
264
+ exports.CreeveyManager = CreeveyManager;
@@ -0,0 +1,55 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.Addon = void 0;
7
+
8
+ var _components = require("@storybook/components");
9
+
10
+ var _react = _interopRequireWildcard(require("react"));
11
+
12
+ var _Panel = require("./Panel");
13
+
14
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
15
+
16
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
17
+
18
+ const Addon = _ref => {
19
+ let {
20
+ active,
21
+ browser,
22
+ manager
23
+ } = _ref;
24
+ const [tests, setTests] = (0, _react.useState)([]);
25
+ const [selectedTestId, setSelectedTestId] = (0, _react.useState)(manager.selectedTestId);
26
+ (0, _react.useEffect)(() => {
27
+ if (active) {
28
+ manager.setActiveBrowser(browser);
29
+ const browserTests = manager.getTestsByStoryIdAndBrowser(manager.activeBrowser);
30
+ setTests(browserTests);
31
+ }
32
+ }, [active, browser, manager]);
33
+ (0, _react.useEffect)(() => {
34
+ const unsubscribe = manager.onChangeTest(testId => {
35
+ setSelectedTestId(testId);
36
+ const status = manager.getTestsByStoryIdAndBrowser(manager.activeBrowser);
37
+ setTests(status);
38
+ });
39
+ return unsubscribe;
40
+ }, [manager]);
41
+ (0, _react.useEffect)(() => {
42
+ const unsubscribe = manager.onUpdateStatus(() => {
43
+ setTests(manager.getTestsByStoryIdAndBrowser(manager.activeBrowser));
44
+ });
45
+ return unsubscribe;
46
+ }, [manager, browser]);
47
+ return active ? tests.length ? /*#__PURE__*/_react.default.createElement(_Panel.Panel, {
48
+ tests: tests,
49
+ selectedTestId: selectedTestId,
50
+ onChangeTest: manager.setSelectedTestId,
51
+ onImageApprove: manager.onImageApprove
52
+ }) : /*#__PURE__*/_react.default.createElement(_components.Placeholder, null, "No test results") : null;
53
+ };
54
+
55
+ exports.Addon = Addon;
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.NextIcon = exports.ForwardIcon = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
11
+
12
+ const NextIcon = _ref => {
13
+ let {
14
+ width,
15
+ height
16
+ } = _ref;
17
+ return /*#__PURE__*/_react.default.createElement("svg", {
18
+ version: "1.1",
19
+ width: width,
20
+ height: height,
21
+ viewBox: "0 0 306 306"
22
+ }, /*#__PURE__*/_react.default.createElement("path", {
23
+ d: "M0,306l216.75-153L0,0V306z M255,0v306h51V0H255z",
24
+ fill: "currentColor"
25
+ }));
26
+ };
27
+
28
+ exports.NextIcon = NextIcon;
29
+
30
+ const ForwardIcon = _ref2 => {
31
+ let {
32
+ width,
33
+ height
34
+ } = _ref2;
35
+ return /*#__PURE__*/_react.default.createElement("svg", {
36
+ version: "1.1",
37
+ width: width,
38
+ height: height,
39
+ viewBox: "0 0 512 512"
40
+ }, /*#__PURE__*/_react.default.createElement("path", {
41
+ fill: "currentColor",
42
+ d: "M460.9,246.8l-209-164.2c-7.8-6.1-19.2-0.6-19.2,9.2v328.4c0,9.8,11.4,15.3,19.2,9.2l209-164.2c5.1-4,6-11.4,2-16.5 C462.4,248,461.7,247.3,460.9,246.8L460.9,246.8z M228.2,246.8L19.2,82.5C11.4,76.4,0,82,0,91.8v328.4c0,9.8,11.4,15.3,19.2,9.2 l209-164.2c3-2.3,4.5-5.8,4.5-9.2C232.7,252.6,231.2,249.1,228.2,246.8z M507.3,64h-37.2c-2.5,0-4.7,2-4.7,4.4v375.3 c0,2.4,2.1,4.4,4.7,4.4h37.2c2.5,0,4.7-2,4.7-4.4V68.4C512,66,509.9,64,507.3,64z"
43
+ }));
44
+ };
45
+
46
+ exports.ForwardIcon = ForwardIcon;
@@ -0,0 +1,72 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.Panel = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _components = require("@storybook/components");
11
+
12
+ var _ResultsPage = require("../../shared/components/ResultsPage");
13
+
14
+ var _theming = require("@storybook/theming");
15
+
16
+ var _helpers = require("../../shared/helpers");
17
+
18
+ var _TestSelect = _interopRequireDefault(require("./TestSelect"));
19
+
20
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
21
+
22
+ const Wrapper = _theming.styled.div(_ref => {
23
+ let {
24
+ isRunning
25
+ } = _ref;
26
+ return {
27
+ opacity: isRunning ? 0.5 : 1,
28
+ height: '100%'
29
+ };
30
+ });
31
+
32
+ const TestSelectContainer = _theming.styled.div(_ref2 => {
33
+ let {
34
+ theme
35
+ } = _ref2;
36
+ return {
37
+ padding: '8px',
38
+ border: "1px solid ".concat(theme.appBorderColor)
39
+ };
40
+ });
41
+
42
+ const Panel = _ref3 => {
43
+ var _result$results, _result$results$lengt, _result$results2;
44
+
45
+ let {
46
+ tests,
47
+ selectedTestId,
48
+ onChangeTest,
49
+ onImageApprove
50
+ } = _ref3;
51
+ const result = tests.find(x => x.id === selectedTestId);
52
+ const isRunning = (result === null || result === void 0 ? void 0 : result.status) === 'running';
53
+ return /*#__PURE__*/_react.default.createElement("div", null, tests.length > 1 && /*#__PURE__*/_react.default.createElement(TestSelectContainer, null, /*#__PURE__*/_react.default.createElement(_TestSelect.default, {
54
+ tests: tests,
55
+ selectedTestId: selectedTestId,
56
+ onChangeTest: onChangeTest
57
+ })), isRunning && /*#__PURE__*/_react.default.createElement(_components.Loader, null), result !== null && result !== void 0 && (_result$results = result.results) !== null && _result$results !== void 0 && _result$results.length ? /*#__PURE__*/_react.default.createElement(Wrapper, {
58
+ isRunning: isRunning
59
+ }, /*#__PURE__*/_react.default.createElement(_ResultsPage.ResultsPage, {
60
+ height: '100%',
61
+ key: "".concat(result.id, "_").concat((_result$results$lengt = (_result$results2 = result.results) === null || _result$results2 === void 0 ? void 0 : _result$results2.length) !== null && _result$results$lengt !== void 0 ? _result$results$lengt : 0) // TODO
62
+ ,
63
+ id: result.id,
64
+ path: (0, _helpers.getTestPath)(result) // TODO Memo?
65
+ ,
66
+ results: result.results,
67
+ approved: result.approved,
68
+ onImageApprove: onImageApprove
69
+ })) : null);
70
+ };
71
+
72
+ exports.Panel = Panel;
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = TestSelect;
7
+
8
+ var _components = require("@storybook/components");
9
+
10
+ var _theming = require("@storybook/theming");
11
+
12
+ var _react = _interopRequireDefault(require("react"));
13
+
14
+ var _utils = require("../utils");
15
+
16
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
+
18
+ const LinkIconContainer = _theming.styled.span(_ref => {
19
+ let {
20
+ theme
21
+ } = _ref;
22
+ return {
23
+ display: 'inline-block',
24
+ width: '20px',
25
+ color: theme.color.defaultText,
26
+ textAlign: 'center'
27
+ };
28
+ });
29
+
30
+ function TestSelect(props) {
31
+ var _props$tests$find$tes, _props$tests$find;
32
+
33
+ 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 : '';
34
+ return /*#__PURE__*/_react.default.createElement(_components.WithTooltip, {
35
+ trigger: "click",
36
+ placement: "bottom",
37
+ closeOnClick: true,
38
+ tooltip: _ref2 => {
39
+ let {
40
+ onHide
41
+ } = _ref2;
42
+ return /*#__PURE__*/_react.default.createElement(_components.TooltipLinkList, {
43
+ links: props.tests.map(x => {
44
+ var _x$testName;
45
+
46
+ return {
47
+ id: x.id,
48
+ title: (_x$testName = x.testName) !== null && _x$testName !== void 0 ? _x$testName : '',
49
+ active: props.selectedTestId === x.id,
50
+ onClick: () => {
51
+ props.onChangeTest(x.id);
52
+ onHide();
53
+ },
54
+ left: /*#__PURE__*/_react.default.createElement(LinkIconContainer, null, (0, _utils.getEmojiByTestStatus)(x.status, x.skip))
55
+ };
56
+ })
57
+ });
58
+ }
59
+ }, /*#__PURE__*/_react.default.createElement(_components.Button, {
60
+ outline: true,
61
+ small: true
62
+ }, /*#__PURE__*/_react.default.createElement(_components.Icons, {
63
+ icon: "menu"
64
+ }), testName));
65
+ }
@@ -0,0 +1,97 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.Tools = void 0;
7
+
8
+ var _react = _interopRequireWildcard(require("react"));
9
+
10
+ var _components = require("@storybook/components");
11
+
12
+ var _Icons = require("./Icons");
13
+
14
+ var _qs = require("qs");
15
+
16
+ var _theming = require("@storybook/theming");
17
+
18
+ var _types = require("../../../types");
19
+
20
+ var _helpers = require("../../shared/helpers");
21
+
22
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
23
+
24
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
25
+
26
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
27
+ //@ts-nocheck
28
+ const Button = (0, _theming.styled)(_components.IconButton)({
29
+ '&:disabled': {
30
+ opacity: 0.5,
31
+ cursor: 'default'
32
+ },
33
+ '&:disabled:hover': {
34
+ color: 'inherit'
35
+ }
36
+ });
37
+
38
+ const Tools = _ref => {
39
+ let {
40
+ manager
41
+ } = _ref;
42
+ const [buttonClicked, setButtonClicked] = (0, _react.useState)();
43
+ const [isRunning, setRunning] = (0, _react.useState)(manager.status.isRunning);
44
+ const forceUpdate = (0, _helpers.useForceUpdate)();
45
+ const test = manager.getCurrentTest();
46
+ (0, _react.useEffect)(() => {
47
+ const unsubscribe = manager.onChangeTest(() => {
48
+ forceUpdate();
49
+ });
50
+ return unsubscribe;
51
+ }, [manager, forceUpdate]);
52
+ (0, _react.useEffect)(() => {
53
+ const unsubscribe = manager.onUpdateStatus(_ref2 => {
54
+ let {
55
+ isRunning
56
+ } = _ref2;
57
+ if ((0, _types.isDefined)(isRunning)) setRunning(isRunning);
58
+ });
59
+ return unsubscribe;
60
+ }, [manager]);
61
+ if (!test) return null;
62
+
63
+ function renderButton(type, title, onClick, icon) {
64
+ const handleClick = () => {
65
+ setButtonClicked(type);
66
+ onClick();
67
+ };
68
+
69
+ const disabled = isRunning && buttonClicked != null && buttonClicked !== type;
70
+ return /*#__PURE__*/_react.default.createElement(Button, {
71
+ onClick: () => {
72
+ isRunning ? manager.onStop() : handleClick();
73
+ },
74
+ title: disabled ? '' : title,
75
+ disabled: disabled
76
+ }, buttonClicked === type && isRunning ? /*#__PURE__*/_react.default.createElement(_components.Icons, {
77
+ icon: 'stop'
78
+ }) : icon);
79
+ }
80
+
81
+ return /*#__PURE__*/_react.default.createElement(_react.Fragment, null, /*#__PURE__*/_react.default.createElement(_components.IconButton, {
82
+ href: "http://localhost:".concat(__CREEVEY_CLIENT_PORT__ || __CREEVEY_SERVER_PORT__, "/?").concat((0, _qs.stringify)({
83
+ testPath: (0, _helpers.getTestPath)(test)
84
+ })),
85
+ target: "_blank",
86
+ title: "Show in Creevey UI"
87
+ }, /*#__PURE__*/_react.default.createElement(_components.Icons, {
88
+ icon: "sharealt"
89
+ })), /*#__PURE__*/_react.default.createElement(_components.Separator, null), renderButton('RunAll', 'Run all', manager.onStartAllTests, /*#__PURE__*/_react.default.createElement(_Icons.ForwardIcon, null)), renderButton('RunStoryTests', 'Run all story tests', manager.onStartAllStoryTests, /*#__PURE__*/_react.default.createElement(_Icons.NextIcon, {
90
+ width: 15,
91
+ height: 11
92
+ })), renderButton('RunTest', 'Run', manager.onStart, /*#__PURE__*/_react.default.createElement(_components.Icons, {
93
+ icon: "play"
94
+ })));
95
+ };
96
+
97
+ exports.Tools = Tools;
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.decorators = void 0;
7
+
8
+ var _withCreevey = require("./withCreevey");
9
+
10
+ const decorators = [(0, _withCreevey.withCreevey)()];
11
+ exports.decorators = decorators;
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+
7
+ var _withCreevey = require("./withCreevey");
8
+
9
+ Object.keys(_withCreevey).forEach(function (key) {
10
+ if (key === "default" || key === "__esModule") return;
11
+ if (key in exports && exports[key] === _withCreevey[key]) return;
12
+ Object.defineProperty(exports, key, {
13
+ enumerable: true,
14
+ get: function () {
15
+ return _withCreevey[key];
16
+ }
17
+ });
18
+ });
19
+
20
+ var _readyForCapture = require("./readyForCapture");
21
+
22
+ Object.keys(_readyForCapture).forEach(function (key) {
23
+ if (key === "default" || key === "__esModule") return;
24
+ if (key in exports && exports[key] === _readyForCapture[key]) return;
25
+ Object.defineProperty(exports, key, {
26
+ enumerable: true,
27
+ get: function () {
28
+ return _readyForCapture[key];
29
+ }
30
+ });
31
+ });