mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-08 07:13:34 +08:00
38 lines
1.0 KiB
TypeScript
38 lines
1.0 KiB
TypeScript
import detectFreePort from 'detect-port';
|
|
|
|
import type { Task } from '../task';
|
|
import { exec } from '../utils/exec';
|
|
|
|
export const PORT = process.env.STORYBOOK_SERVE_PORT
|
|
? parseInt(process.env.STORYBOOK_SERVE_PORT, 10)
|
|
: 6006;
|
|
|
|
export const dev: Task = {
|
|
description: 'Run the sandbox in development mode',
|
|
service: true,
|
|
dependsOn: ['sandbox'],
|
|
async ready() {
|
|
return (await detectFreePort(PORT)) !== PORT;
|
|
},
|
|
async run({ sandboxDir, codeDir, selectedTask }, { dryRun, debug }) {
|
|
const controller = new AbortController();
|
|
const devCommand = `yarn storybook --port ${PORT}${selectedTask === 'dev' ? '' : ' --ci'}`;
|
|
|
|
exec(
|
|
devCommand,
|
|
{ cwd: sandboxDir },
|
|
{ dryRun, debug, signal: controller.signal as AbortSignal }
|
|
).catch((err) => {
|
|
// If aborted, we want to make sure the rejection is handled.
|
|
if (!err.killed) throw err;
|
|
});
|
|
await exec(
|
|
`yarn wait-on http://localhost:${PORT}/iframe.html`,
|
|
{ cwd: codeDir },
|
|
{ dryRun, debug }
|
|
);
|
|
|
|
return controller;
|
|
},
|
|
};
|