storybook 10.1.0-alpha.1 → 10.1.0-alpha.11
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.
- package/dist/_browser-chunks/Color-FTG7SQDA.js +1097 -0
- package/dist/_browser-chunks/WithTooltip-LMROHDUP.js +1651 -0
- package/dist/_browser-chunks/chunk-2FRVAXCZ.js +7 -0
- package/dist/_browser-chunks/chunk-3IAH5M2U.js +171 -0
- package/dist/_browser-chunks/chunk-3OXGAGBE.js +779 -0
- package/dist/_browser-chunks/{chunk-TMDZCWME.js → chunk-3PJE6VLG.js} +1 -3
- package/dist/_browser-chunks/{chunk-VAMFPZY3.js → chunk-45UGUKRX.js} +2 -7
- package/dist/_browser-chunks/chunk-6XWLIJQL.js +11 -0
- package/dist/_browser-chunks/{chunk-FDWKXLBI.js → chunk-74YHFU5B.js} +44 -109
- package/dist/_browser-chunks/{chunk-MM7DTO55.js → chunk-A242L54C.js} +10 -16
- package/dist/_browser-chunks/chunk-AIOS4NGK.js +252 -0
- package/dist/_browser-chunks/chunk-AS2HQEYC.js +14 -0
- package/dist/_browser-chunks/chunk-AXG2BOBL.js +836 -0
- package/dist/_browser-chunks/chunk-BE2DAXKJ.js +2966 -0
- package/dist/_browser-chunks/{chunk-MH6AXFXB.js → chunk-CHUV5WSW.js} +0 -5
- package/dist/_browser-chunks/chunk-EBHB6RPS.js +61 -0
- package/dist/_browser-chunks/chunk-EUVGDK4H.js +93 -0
- package/dist/_browser-chunks/chunk-EZSQOHRI.js +18 -0
- package/dist/_browser-chunks/{chunk-CADGRH3P.js → chunk-FNXWN6IK.js} +3 -8
- package/dist/_browser-chunks/chunk-GFLS4VP3.js +64 -0
- package/dist/_browser-chunks/{chunk-L2D73C6Z.js → chunk-H6XK3RSC.js} +13 -21
- package/dist/_browser-chunks/chunk-IPA5A322.js +71 -0
- package/dist/_browser-chunks/chunk-JP7NCOJX.js +37 -0
- package/dist/_browser-chunks/chunk-KJHJLCBK.js +11 -0
- package/dist/_browser-chunks/chunk-L4RMQ7D7.js +223 -0
- package/dist/_browser-chunks/{chunk-AB7OOPUX.js → chunk-QKODTO7K.js} +0 -5
- package/dist/_browser-chunks/chunk-RP5RXKFU.js +2491 -0
- package/dist/_browser-chunks/chunk-SL75JR6Y.js +9 -0
- package/dist/_browser-chunks/chunk-UD6FQLAF.js +1481 -0
- package/dist/_browser-chunks/chunk-VYJQ7RU5.js +2853 -0
- package/dist/_browser-chunks/chunk-WJYERY3R.js +136 -0
- package/dist/_browser-chunks/chunk-WXP2XJ3O.js +950 -0
- package/dist/_browser-chunks/chunk-X3DUQ5RA.js +47 -0
- package/dist/_browser-chunks/chunk-XJNX76GA.js +85 -0
- package/dist/_browser-chunks/{chunk-F4Q6SGTB.js → chunk-YKE5S47A.js} +177 -399
- package/dist/_browser-chunks/{chunk-SN4J4IQ3.js → chunk-ZUWEVLDX.js} +1 -7
- package/dist/_browser-chunks/{formatter-OMEEQ6HG.js → formatter-QJ4M4OGQ.js} +4 -9
- package/dist/_browser-chunks/{syntaxhighlighter-DK2ODWXH.js → syntaxhighlighter-WKBQ5RC7.js} +707 -1851
- package/dist/_node-chunks/{builder-manager-6UBDPV7P.js → builder-manager-PMPHOSM2.js} +495 -1013
- package/dist/_node-chunks/camelcase-K3IOOFQW.js +18 -0
- package/dist/_node-chunks/{chunk-QNUGJO6L.js → chunk-32NE3UE3.js} +15 -24
- package/dist/_node-chunks/chunk-4GZCFQFG.js +58 -0
- package/dist/_node-chunks/chunk-5QK5MSOI.js +943 -0
- package/dist/_node-chunks/{chunk-3FPF5Y2F.js → chunk-6ZOLETQK.js} +8 -10
- package/dist/_node-chunks/chunk-7I22Y76Z.js +1047 -0
- package/dist/_node-chunks/chunk-AKTRSR3O.js +72 -0
- package/dist/_node-chunks/chunk-BBOP3XCK.js +119 -0
- package/dist/_node-chunks/chunk-C2GQVDWI.js +34 -0
- package/dist/_node-chunks/{chunk-SCTKVDWR.js → chunk-GG2WQZSG.js} +4619 -7350
- package/dist/_node-chunks/chunk-GQJOWVVR.js +3214 -0
- package/dist/_node-chunks/chunk-JCRM2YVK.js +3009 -0
- package/dist/_node-chunks/chunk-KK4AT5F3.js +1029 -0
- package/dist/_node-chunks/chunk-L7MYXJUM.js +1114 -0
- package/dist/_node-chunks/{chunk-LAU7VVPC.js → chunk-LCZO45L7.js} +469 -983
- package/dist/_node-chunks/chunk-LR3QITDI.js +209 -0
- package/dist/_node-chunks/chunk-LXG4DK35.js +3171 -0
- package/dist/_node-chunks/chunk-MJ3WOS6F.js +37 -0
- package/dist/_node-chunks/chunk-PHOZWZZO.js +61 -0
- package/dist/_node-chunks/chunk-QECOQWRJ.js +936 -0
- package/dist/_node-chunks/chunk-QH4V5YDB.js +20 -0
- package/dist/_node-chunks/chunk-R6HWGZWD.js +26 -0
- package/dist/_node-chunks/chunk-SPQXMU2Q.js +759 -0
- package/dist/_node-chunks/chunk-TXZY6V6O.js +1564 -0
- package/dist/_node-chunks/chunk-UGDPX5LE.js +756 -0
- package/dist/_node-chunks/chunk-UY26MQLT.js +603 -0
- package/dist/_node-chunks/chunk-WK3EMYK6.js +61 -0
- package/dist/_node-chunks/{chunk-CJHAP7SE.js → chunk-WLHMN7AP.js} +292 -688
- package/dist/_node-chunks/chunk-XGVLB4UJ.js +54 -0
- package/dist/_node-chunks/{chunk-J7N7PD5Q.js → chunk-YHRFI6BE.js} +87 -227
- package/dist/_node-chunks/chunk-YK4KVMFW.js +18 -0
- package/dist/_node-chunks/chunk-ZZALGOA6.js +4523 -0
- package/dist/_node-chunks/chunk-ZZPBSYA5.js +301 -0
- package/dist/_node-chunks/chunk-ZZSRFAC6.js +45571 -0
- package/dist/_node-chunks/dist-4DWOCZUD.js +121 -0
- package/dist/_node-chunks/globby-AAARUKEU.js +3452 -0
- package/dist/_node-chunks/lib-HEUKGL62.js +366 -0
- package/dist/_node-chunks/mdx-N42X6CFJ-DCVRPS6N.js +14329 -0
- package/dist/_node-chunks/p-limit-F5ZKJ6WZ.js +116 -0
- package/dist/_node-chunks/plugin-7YY7JXCH.js +123 -0
- package/dist/_node-chunks/{plugin-HJLCLGNT.js → plugin-SZP3CW6W.js} +36 -56
- package/dist/_node-chunks/webpack-inject-mocker-runtime-plugin-TGKNDPO6.js +46623 -0
- package/dist/_node-chunks/webpack-mock-plugin-LNTZZFBE.js +92 -0
- package/dist/actions/decorator.js +21 -42
- package/dist/actions/index.js +3 -3
- package/dist/babel/index.d.ts +671 -335
- package/dist/babel/index.js +11 -11
- package/dist/bin/core.js +592 -1546
- package/dist/bin/dispatcher.js +26 -37
- package/dist/bin/loader.js +23 -34
- package/dist/channels/index.js +98 -234
- package/dist/cli/index.js +1966 -5347
- package/dist/client-logger/index.js +31 -61
- package/dist/common/index.d.ts +210 -3
- package/dist/common/index.js +28 -20
- package/dist/components/index.d.ts +472 -280
- package/dist/components/index.js +15992 -75
- package/dist/core-events/index.js +2 -66
- package/dist/core-server/index.js +3837 -7191
- package/dist/core-server/presets/common-manager.css +2 -2
- package/dist/core-server/presets/common-manager.js +2511 -5219
- package/dist/core-server/presets/common-override-preset.js +31 -60
- package/dist/core-server/presets/common-preset.js +434 -924
- package/dist/core-server/presets/webpack/loaders/storybook-mock-transform-loader.js +15 -19
- package/dist/core-server/presets/webpack/loaders/webpack-automock-loader.js +12 -17
- package/dist/csf/index.js +534 -1172
- package/dist/csf-tools/index.d.ts +15 -4
- package/dist/csf-tools/index.js +9 -9
- package/dist/docs-tools/index.js +6 -6
- package/dist/highlight/index.js +2 -2
- package/dist/instrumenter/index.js +199 -415
- package/dist/manager/globals-runtime.js +47968 -56484
- package/dist/manager/globals.js +2 -3
- package/dist/manager/runtime.js +4901 -10318
- package/dist/manager-api/index.d.ts +11 -3
- package/dist/manager-api/index.js +1250 -2397
- package/dist/manager-errors.d.ts +3 -0
- package/dist/manager-errors.js +3 -3
- package/dist/node-logger/index.d.ts +1 -1
- package/dist/node-logger/index.js +1270 -2593
- package/dist/preview/globals.js +2 -3
- package/dist/preview/runtime.js +10767 -22386
- package/dist/preview-api/index.d.ts +67 -68
- package/dist/preview-api/index.js +15 -15
- package/dist/preview-errors.d.ts +3 -0
- package/dist/preview-errors.js +4 -4
- package/dist/router/index.js +347 -899
- package/dist/server-errors.d.ts +3 -0
- package/dist/server-errors.js +10 -10
- package/dist/telemetry/index.js +24 -24
- package/dist/test/index.js +6129 -11914
- package/dist/theming/create.d.ts +4 -2
- package/dist/theming/create.js +4 -4
- package/dist/theming/index.d.ts +3397 -2628
- package/dist/theming/index.js +502 -1091
- package/dist/types/index.d.ts +50 -5
- package/dist/types/index.js +2 -11
- package/dist/viewport/index.js +3 -3
- package/package.json +17 -9
- package/dist/_browser-chunks/Color-7ZNS6F6B.js +0 -1676
- package/dist/_browser-chunks/WithTooltip-SK46ZJ2J.js +0 -13
- package/dist/_browser-chunks/chunk-6A7OIVEL.js +0 -66
- package/dist/_browser-chunks/chunk-B4A3ADP3.js +0 -3816
- package/dist/_browser-chunks/chunk-BOOOPFZF.js +0 -2335
- package/dist/_browser-chunks/chunk-C4XOKMDU.js +0 -270
- package/dist/_browser-chunks/chunk-FSBVR7H5.js +0 -106
- package/dist/_browser-chunks/chunk-FUOHXXZT.js +0 -23
- package/dist/_browser-chunks/chunk-GTKOCWCT.js +0 -17
- package/dist/_browser-chunks/chunk-HHW4FUMO.js +0 -12
- package/dist/_browser-chunks/chunk-I74EUU5O.js +0 -5809
- package/dist/_browser-chunks/chunk-JVSKG4YS.js +0 -4052
- package/dist/_browser-chunks/chunk-LASUB7TL.js +0 -76
- package/dist/_browser-chunks/chunk-LYCSRYYR.js +0 -101
- package/dist/_browser-chunks/chunk-NVV6MIOE.js +0 -243
- package/dist/_browser-chunks/chunk-OBXWFEPB.js +0 -852
- package/dist/_browser-chunks/chunk-OPCDBBL3.js +0 -48
- package/dist/_browser-chunks/chunk-PB6FZ3WE.js +0 -130
- package/dist/_browser-chunks/chunk-RNE2IUTB.js +0 -1300
- package/dist/_browser-chunks/chunk-SYS437NN.js +0 -122
- package/dist/_browser-chunks/chunk-U46RQHA4.js +0 -12
- package/dist/_browser-chunks/chunk-UTNZYD2N.js +0 -311
- package/dist/_browser-chunks/chunk-VUAFL5XK.js +0 -20
- package/dist/_browser-chunks/chunk-W4QKLQSC.js +0 -4182
- package/dist/_browser-chunks/chunk-XDGMHOV7.js +0 -2197
- package/dist/_browser-chunks/chunk-XW6KSYKF.js +0 -16
- package/dist/_browser-chunks/chunk-Y3M7TW6K.js +0 -1041
- package/dist/_browser-chunks/chunk-ZNRFDIVA.js +0 -233
- package/dist/_node-chunks/camelcase-WKJOVNPM.js +0 -18
- package/dist/_node-chunks/chunk-2RIKHYCS.js +0 -304
- package/dist/_node-chunks/chunk-3JCSHYSU.js +0 -1657
- package/dist/_node-chunks/chunk-4GE6Q4MX.js +0 -1531
- package/dist/_node-chunks/chunk-5SEHHENC.js +0 -64656
- package/dist/_node-chunks/chunk-6GD23U64.js +0 -420
- package/dist/_node-chunks/chunk-6OAXYS5T.js +0 -1544
- package/dist/_node-chunks/chunk-7TNUMFKR.js +0 -4741
- package/dist/_node-chunks/chunk-BCDHUXAJ.js +0 -4272
- package/dist/_node-chunks/chunk-BYVQZ2HU.js +0 -220
- package/dist/_node-chunks/chunk-DAMVKHAC.js +0 -101
- package/dist/_node-chunks/chunk-FEOC7OX2.js +0 -1586
- package/dist/_node-chunks/chunk-FY7XZPLY.js +0 -2248
- package/dist/_node-chunks/chunk-GD2FXWDF.js +0 -697
- package/dist/_node-chunks/chunk-HM6B7FE5.js +0 -18
- package/dist/_node-chunks/chunk-HORWITP7.js +0 -90
- package/dist/_node-chunks/chunk-II4AFH3V.js +0 -28
- package/dist/_node-chunks/chunk-MF2PUEWG.js +0 -5029
- package/dist/_node-chunks/chunk-RVE4UTVQ.js +0 -1518
- package/dist/_node-chunks/chunk-TUFWZUTO.js +0 -69
- package/dist/_node-chunks/chunk-TXHNWNH4.js +0 -79
- package/dist/_node-chunks/chunk-ULWNTI6M.js +0 -1198
- package/dist/_node-chunks/chunk-VYRFXLRO.js +0 -6712
- package/dist/_node-chunks/chunk-WNOSTIYP.js +0 -34
- package/dist/_node-chunks/chunk-X67VGZN4.js +0 -1250
- package/dist/_node-chunks/chunk-XCEBYOA4.js +0 -61
- package/dist/_node-chunks/chunk-XW7YMR7I.js +0 -111
- package/dist/_node-chunks/chunk-ZRFYQ46H.js +0 -61
- package/dist/_node-chunks/dist-APCKHSY3.js +0 -175
- package/dist/_node-chunks/globby-TSGXGDA2.js +0 -5222
- package/dist/_node-chunks/lib-DZ5TVIU5.js +0 -518
- package/dist/_node-chunks/mdx-N42X6CFJ-Z6BYQCPN.js +0 -22017
- package/dist/_node-chunks/p-limit-MLJNGG2K.js +0 -168
- package/dist/_node-chunks/plugin-J3JI3ZKJ.js +0 -159
- package/dist/_node-chunks/webpack-inject-mocker-runtime-plugin-3QHNTM5B.js +0 -69102
- package/dist/_node-chunks/webpack-mock-plugin-4Y3MWPJ6.js +0 -124
|
@@ -0,0 +1,301 @@
|
|
|
1
|
+
import CJS_COMPAT_NODE_URL_843v2rliy1 from 'node:url';
|
|
2
|
+
import CJS_COMPAT_NODE_PATH_843v2rliy1 from 'node:path';
|
|
3
|
+
import CJS_COMPAT_NODE_MODULE_843v2rliy1 from "node:module";
|
|
4
|
+
|
|
5
|
+
var __filename = CJS_COMPAT_NODE_URL_843v2rliy1.fileURLToPath(import.meta.url);
|
|
6
|
+
var __dirname = CJS_COMPAT_NODE_PATH_843v2rliy1.dirname(__filename);
|
|
7
|
+
var require = CJS_COMPAT_NODE_MODULE_843v2rliy1.createRequire(import.meta.url);
|
|
8
|
+
|
|
9
|
+
// ------------------------------------------------------------
|
|
10
|
+
// end of CJS compatibility banner, injected by Storybook's esbuild configuration
|
|
11
|
+
// ------------------------------------------------------------
|
|
12
|
+
import {
|
|
13
|
+
basename,
|
|
14
|
+
dirname,
|
|
15
|
+
isAbsolute,
|
|
16
|
+
join,
|
|
17
|
+
normalize,
|
|
18
|
+
resolve
|
|
19
|
+
} from "./chunk-BBOP3XCK.js";
|
|
20
|
+
|
|
21
|
+
// src/core-server/mocking-utils/resolve.ts
|
|
22
|
+
import { readFileSync as readFileSync2, realpathSync } from "node:fs";
|
|
23
|
+
import { createRequire } from "node:module";
|
|
24
|
+
import { findMockRedirect } from "@vitest/mocker/redirect";
|
|
25
|
+
|
|
26
|
+
// ../node_modules/resolve.exports/dist/index.mjs
|
|
27
|
+
function e(e2, n2, r2) {
|
|
28
|
+
throw new Error(r2 ? `No known conditions for "${n2}" specifier in "${e2}" package` : `Missing "${n2}" specifier in "${e2}" package`);
|
|
29
|
+
}
|
|
30
|
+
function n(n2, i, o2, f) {
|
|
31
|
+
let s, u, l = r(n2, o2), c = (function(e2) {
|
|
32
|
+
let n3 = /* @__PURE__ */ new Set(["default", ...e2.conditions || []]);
|
|
33
|
+
return e2.unsafe || n3.add(e2.require ? "require" : "import"), e2.unsafe || n3.add(e2.browser ? "browser" : "node"), n3;
|
|
34
|
+
})(f || {}), a = i[l];
|
|
35
|
+
if (a === void 0) {
|
|
36
|
+
let e2, n3, r2, t3;
|
|
37
|
+
for (t3 in i) n3 && t3.length < n3.length || (t3[t3.length - 1] === "/" && l.startsWith(t3) ? (u = l.substring(t3.length), n3 = t3) : t3.length > 1 && (r2 = t3.indexOf("*", 1), ~r2 && (e2 = RegExp("^" + t3.substring(0, r2) + "(.*)" + t3.substring(1 + r2) + "$").exec(l), e2 && e2[1] && (u = e2[1], n3 = t3))));
|
|
38
|
+
a = i[n3];
|
|
39
|
+
}
|
|
40
|
+
return a || e(n2, l), s = t(a, c), s || e(n2, l, 1), u && (function(e2, n3) {
|
|
41
|
+
let r2, t3 = 0, i2 = e2.length, o3 = /[*]/g, f2 = /[/]$/;
|
|
42
|
+
for (; t3 < i2; t3++) e2[t3] = o3.test(r2 = e2[t3]) ? r2.replace(o3, n3) : f2.test(r2) ? r2 + n3 : r2;
|
|
43
|
+
})(s, u), s;
|
|
44
|
+
}
|
|
45
|
+
function r(e2, n2, r2) {
|
|
46
|
+
if (e2 === n2 || n2 === ".") return ".";
|
|
47
|
+
let t3 = e2 + "/", i = t3.length, o2 = n2.slice(0, i) === t3, f = o2 ? n2.slice(i) : n2;
|
|
48
|
+
return f[0] === "#" ? f : o2 || !r2 ? f.slice(0, 2) === "./" ? f : "./" + f : f;
|
|
49
|
+
}
|
|
50
|
+
function t(e2, n2, r2) {
|
|
51
|
+
if (e2) {
|
|
52
|
+
if (typeof e2 == "string") return r2 && r2.add(e2), [e2];
|
|
53
|
+
let i, o2;
|
|
54
|
+
if (Array.isArray(e2)) {
|
|
55
|
+
for (o2 = r2 || /* @__PURE__ */ new Set(), i = 0; i < e2.length; i++) t(e2[i], n2, o2);
|
|
56
|
+
if (!r2 && o2.size) return [...o2];
|
|
57
|
+
} else for (i in e2) if (n2.has(i)) return t(e2[i], n2, r2);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
function o(e2, r2, t3) {
|
|
61
|
+
let i, o2 = e2.exports;
|
|
62
|
+
if (o2) {
|
|
63
|
+
if (typeof o2 == "string") o2 = { ".": o2 };
|
|
64
|
+
else for (i in o2) {
|
|
65
|
+
i[0] !== "." && (o2 = { ".": o2 });
|
|
66
|
+
break;
|
|
67
|
+
}
|
|
68
|
+
return n(e2.name, o2, r2 || ".", t3);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
// src/core-server/mocking-utils/extract.ts
|
|
73
|
+
import { readFileSync } from "node:fs";
|
|
74
|
+
import { generate, parser, types as t2 } from "storybook/internal/babel";
|
|
75
|
+
import { logger } from "storybook/internal/node-logger";
|
|
76
|
+
import { telemetry } from "storybook/internal/telemetry";
|
|
77
|
+
import { transformSync } from "esbuild";
|
|
78
|
+
|
|
79
|
+
// ../node_modules/estree-walker/src/walker.js
|
|
80
|
+
var WalkerBase = class {
|
|
81
|
+
constructor() {
|
|
82
|
+
this.should_skip = !1, this.should_remove = !1, this.replacement = null, this.context = {
|
|
83
|
+
skip: () => this.should_skip = !0,
|
|
84
|
+
remove: () => this.should_remove = !0,
|
|
85
|
+
replace: (node) => this.replacement = node
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* @template {Node} Parent
|
|
90
|
+
* @param {Parent | null | undefined} parent
|
|
91
|
+
* @param {keyof Parent | null | undefined} prop
|
|
92
|
+
* @param {number | null | undefined} index
|
|
93
|
+
* @param {Node} node
|
|
94
|
+
*/
|
|
95
|
+
replace(parent, prop, index, node) {
|
|
96
|
+
parent && prop && (index != null ? parent[prop][index] = node : parent[prop] = node);
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* @template {Node} Parent
|
|
100
|
+
* @param {Parent | null | undefined} parent
|
|
101
|
+
* @param {keyof Parent | null | undefined} prop
|
|
102
|
+
* @param {number | null | undefined} index
|
|
103
|
+
*/
|
|
104
|
+
remove(parent, prop, index) {
|
|
105
|
+
parent && prop && (index != null ? parent[prop].splice(index, 1) : delete parent[prop]);
|
|
106
|
+
}
|
|
107
|
+
};
|
|
108
|
+
|
|
109
|
+
// ../node_modules/estree-walker/src/sync.js
|
|
110
|
+
var SyncWalker = class extends WalkerBase {
|
|
111
|
+
/**
|
|
112
|
+
*
|
|
113
|
+
* @param {SyncHandler} [enter]
|
|
114
|
+
* @param {SyncHandler} [leave]
|
|
115
|
+
*/
|
|
116
|
+
constructor(enter, leave) {
|
|
117
|
+
super(), this.should_skip = !1, this.should_remove = !1, this.replacement = null, this.context = {
|
|
118
|
+
skip: () => this.should_skip = !0,
|
|
119
|
+
remove: () => this.should_remove = !0,
|
|
120
|
+
replace: (node) => this.replacement = node
|
|
121
|
+
}, this.enter = enter, this.leave = leave;
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* @template {Node} Parent
|
|
125
|
+
* @param {Node} node
|
|
126
|
+
* @param {Parent | null} parent
|
|
127
|
+
* @param {keyof Parent} [prop]
|
|
128
|
+
* @param {number | null} [index]
|
|
129
|
+
* @returns {Node | null}
|
|
130
|
+
*/
|
|
131
|
+
visit(node, parent, prop, index) {
|
|
132
|
+
if (node) {
|
|
133
|
+
if (this.enter) {
|
|
134
|
+
let _should_skip = this.should_skip, _should_remove = this.should_remove, _replacement = this.replacement;
|
|
135
|
+
this.should_skip = !1, this.should_remove = !1, this.replacement = null, this.enter.call(this.context, node, parent, prop, index), this.replacement && (node = this.replacement, this.replace(parent, prop, index, node)), this.should_remove && this.remove(parent, prop, index);
|
|
136
|
+
let skipped = this.should_skip, removed = this.should_remove;
|
|
137
|
+
if (this.should_skip = _should_skip, this.should_remove = _should_remove, this.replacement = _replacement, skipped) return node;
|
|
138
|
+
if (removed) return null;
|
|
139
|
+
}
|
|
140
|
+
let key;
|
|
141
|
+
for (key in node) {
|
|
142
|
+
let value = node[key];
|
|
143
|
+
if (value && typeof value == "object")
|
|
144
|
+
if (Array.isArray(value)) {
|
|
145
|
+
let nodes = (
|
|
146
|
+
/** @type {Array<unknown>} */
|
|
147
|
+
value
|
|
148
|
+
);
|
|
149
|
+
for (let i = 0; i < nodes.length; i += 1) {
|
|
150
|
+
let item = nodes[i];
|
|
151
|
+
isNode(item) && (this.visit(item, node, key, i) || i--);
|
|
152
|
+
}
|
|
153
|
+
} else isNode(value) && this.visit(value, node, key, null);
|
|
154
|
+
}
|
|
155
|
+
if (this.leave) {
|
|
156
|
+
let _replacement = this.replacement, _should_remove = this.should_remove;
|
|
157
|
+
this.replacement = null, this.should_remove = !1, this.leave.call(this.context, node, parent, prop, index), this.replacement && (node = this.replacement, this.replace(parent, prop, index, node)), this.should_remove && this.remove(parent, prop, index);
|
|
158
|
+
let removed = this.should_remove;
|
|
159
|
+
if (this.replacement = _replacement, this.should_remove = _should_remove, removed) return null;
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
return node;
|
|
163
|
+
}
|
|
164
|
+
};
|
|
165
|
+
function isNode(value) {
|
|
166
|
+
return value !== null && typeof value == "object" && "type" in value && typeof value.type == "string";
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
// ../node_modules/estree-walker/src/index.js
|
|
170
|
+
function walk(ast, { enter, leave }) {
|
|
171
|
+
return new SyncWalker(enter, leave).visit(ast, null);
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
// src/core-server/mocking-utils/extract.ts
|
|
175
|
+
var DEFAULT_MODULE_DIRECTORIES = ["/node_modules/"];
|
|
176
|
+
function isModuleDirectory(path) {
|
|
177
|
+
let normalizedPath = normalize(path);
|
|
178
|
+
return DEFAULT_MODULE_DIRECTORIES.some((dir) => normalizedPath.includes(dir));
|
|
179
|
+
}
|
|
180
|
+
var babelParser = (code) => parser.parse(code, {
|
|
181
|
+
sourceType: "module",
|
|
182
|
+
// Enable plugins to handle modern JavaScript features, including TSX.
|
|
183
|
+
plugins: ["typescript", "jsx", "classProperties", "objectRestSpread"],
|
|
184
|
+
errorRecovery: !0
|
|
185
|
+
}).program;
|
|
186
|
+
function rewriteSbMockImportCalls(code) {
|
|
187
|
+
let ast = babelParser(code);
|
|
188
|
+
return walk(ast, {
|
|
189
|
+
enter(node) {
|
|
190
|
+
node.type === "CallExpression" && node.callee.type === "MemberExpression" && node.callee.object.type === "Identifier" && node.callee.object.name === "sb" && node.callee.property.type === "Identifier" && node.callee.property.name === "mock" && node.arguments.length > 0 && node.arguments[0].type === "CallExpression" && node.arguments[0].callee.type === "Import" && node.arguments[0].arguments.length === 1 && node.arguments[0].arguments[0].type === "StringLiteral" && (node.arguments[0] = t2.stringLiteral(node.arguments[0].arguments[0].value));
|
|
191
|
+
}
|
|
192
|
+
}), generate(ast, {}, code);
|
|
193
|
+
}
|
|
194
|
+
function extractMockCalls(options, parse, root) {
|
|
195
|
+
try {
|
|
196
|
+
let hasSpyTrue2 = function(objectExpression) {
|
|
197
|
+
if (!objectExpression || !objectExpression.properties)
|
|
198
|
+
return !1;
|
|
199
|
+
for (let prop of objectExpression.properties)
|
|
200
|
+
if (prop.type === "ObjectProperty" && (prop.key.type === "Identifier" && prop.key.name === "spy" || prop.key.type === "StringLiteral" && prop.key.value === "spy") && prop.value.type === "BooleanLiteral" && prop.value.value === !0)
|
|
201
|
+
return !0;
|
|
202
|
+
return !1;
|
|
203
|
+
};
|
|
204
|
+
var hasSpyTrue = hasSpyTrue2;
|
|
205
|
+
let previewConfigCode = readFileSync(options.previewConfigPath, "utf-8"), { code: jsCode } = transformSync(previewConfigCode, { loader: "tsx", format: "esm" }), ast = parse(jsCode), mocks = [];
|
|
206
|
+
return walk(ast, {
|
|
207
|
+
// @ts-expect-error - Node comes from babel
|
|
208
|
+
async enter(node) {
|
|
209
|
+
if (node.type !== "CallExpression" || node.callee.type !== "MemberExpression" || node.callee.object.type !== "Identifier" || node.callee.object.name !== "sb" || node.callee.property.type !== "Identifier" || node.callee.property.name !== "mock" || node.arguments.length === 0)
|
|
210
|
+
return;
|
|
211
|
+
let path;
|
|
212
|
+
if (node.arguments[0].type === "StringLiteral")
|
|
213
|
+
path = node.arguments[0].value;
|
|
214
|
+
else if (node.arguments[0].type === "CallExpression" && node.arguments[0].callee.type === "Import" && node.arguments[0].arguments[0].type === "StringLiteral")
|
|
215
|
+
path = node.arguments[0].arguments[0].value;
|
|
216
|
+
else
|
|
217
|
+
return;
|
|
218
|
+
let spy = node.arguments.length > 1 && node.arguments[1].type === "ObjectExpression" && hasSpyTrue2(node.arguments[1]), { absolutePath, redirectPath } = resolveMock(path, root, options.previewConfigPath), pathWithoutExtension = path.replace(/\.[^/.]+$/, ""), basenameAbsolutePath = basename(absolutePath), basenamePath = basename(path), pathWithoutExtensionAndBasename = basenameAbsolutePath === basenamePath ? pathWithoutExtension : path;
|
|
219
|
+
mocks.push({
|
|
220
|
+
path: pathWithoutExtensionAndBasename,
|
|
221
|
+
absolutePath,
|
|
222
|
+
redirectPath,
|
|
223
|
+
spy
|
|
224
|
+
});
|
|
225
|
+
}
|
|
226
|
+
}), options.coreOptions?.disableTelemetry || telemetry(
|
|
227
|
+
"mocking",
|
|
228
|
+
{
|
|
229
|
+
modulesMocked: mocks.length,
|
|
230
|
+
modulesSpied: mocks.map((mock) => mock.spy).filter(Boolean).length,
|
|
231
|
+
modulesManuallyMocked: mocks.map((mock) => !!mock.redirectPath).filter(Boolean).length
|
|
232
|
+
},
|
|
233
|
+
{ configDir: options.configDir }
|
|
234
|
+
), mocks;
|
|
235
|
+
} catch (error) {
|
|
236
|
+
return logger.debug("Error extracting mock calls", error), [];
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
|
|
240
|
+
// src/core-server/mocking-utils/resolve.ts
|
|
241
|
+
var require2 = createRequire(import.meta.url);
|
|
242
|
+
function findPackageJson(specifier, basedir) {
|
|
243
|
+
let packageJsonPath = require2.resolve(`${specifier}/package.json`, { paths: [basedir] });
|
|
244
|
+
return {
|
|
245
|
+
path: packageJsonPath,
|
|
246
|
+
data: JSON.parse(readFileSync2(packageJsonPath, "utf-8"))
|
|
247
|
+
};
|
|
248
|
+
}
|
|
249
|
+
function resolveExternalModule(path, root) {
|
|
250
|
+
let parts = path.split("/"), packageName = path.startsWith("@") ? `${parts[0]}/${parts[1]}` : parts[0], entry = `.${path.slice(packageName.length)}`, { path: packageJsonPath, data: pkg } = findPackageJson(packageName, root), packageDir = dirname(packageJsonPath);
|
|
251
|
+
if (pkg.exports) {
|
|
252
|
+
let result = o(pkg, entry, {
|
|
253
|
+
browser: !0
|
|
254
|
+
});
|
|
255
|
+
if (result)
|
|
256
|
+
return join(packageDir, result[0]);
|
|
257
|
+
}
|
|
258
|
+
return require2.resolve(path, { paths: [root] });
|
|
259
|
+
}
|
|
260
|
+
function getIsExternal(path, importer) {
|
|
261
|
+
try {
|
|
262
|
+
return !isAbsolute(path) && isModuleDirectory(require2.resolve(path, { paths: [importer] }));
|
|
263
|
+
} catch {
|
|
264
|
+
return !1;
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
function resolveMock(path, root, importer) {
|
|
268
|
+
let isExternal = getIsExternal(path, root), externalPath = isExternal ? path : null, absolutePath = isExternal ? resolveExternalModule(path, root) : require2.resolve(path, { paths: [dirname(importer)] }), normalizedAbsolutePath = resolve(absolutePath), redirectPath = findMockRedirect(root, normalizedAbsolutePath, externalPath);
|
|
269
|
+
return {
|
|
270
|
+
absolutePath: normalizedAbsolutePath,
|
|
271
|
+
redirectPath
|
|
272
|
+
// will be null if no __mocks__ file is found
|
|
273
|
+
};
|
|
274
|
+
}
|
|
275
|
+
function getRealPath(path, preserveSymlinks) {
|
|
276
|
+
try {
|
|
277
|
+
return preserveSymlinks ? realpathSync(path) : path;
|
|
278
|
+
} catch {
|
|
279
|
+
return path;
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
function resolveWithExtensions(path, from) {
|
|
283
|
+
let extensions = [".js", ".ts", ".tsx", ".mjs", ".cjs", ".svelte", ".vue"];
|
|
284
|
+
for (let extension of extensions)
|
|
285
|
+
try {
|
|
286
|
+
return require2.resolve(path + extension, { paths: [from] });
|
|
287
|
+
} catch {
|
|
288
|
+
continue;
|
|
289
|
+
}
|
|
290
|
+
return require2.resolve(path, { paths: [from] });
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
export {
|
|
294
|
+
resolveExternalModule,
|
|
295
|
+
getIsExternal,
|
|
296
|
+
getRealPath,
|
|
297
|
+
resolveWithExtensions,
|
|
298
|
+
babelParser,
|
|
299
|
+
rewriteSbMockImportCalls,
|
|
300
|
+
extractMockCalls
|
|
301
|
+
};
|