76 lines
1.8 KiB
TypeScript
76 lines
1.8 KiB
TypeScript
import { spawn } from 'child_process'
|
|
import path from 'path'
|
|
|
|
import type { Payload } from '../../packages/payload/src'
|
|
|
|
const installNodeModules = async (args: { payload: Payload }): Promise<void> => {
|
|
const { payload } = args
|
|
|
|
let installing = false
|
|
|
|
return new Promise(function (resolve) {
|
|
// Install the node modules for the Next.js app
|
|
const installation = spawn('yarn', ['install'], {
|
|
cwd: path.resolve(__dirname, './next-app'),
|
|
})
|
|
|
|
installation.stdout.on('data', (data) => {
|
|
if (!installing) {
|
|
payload.logger.info('Installing Next.js...')
|
|
installing = true
|
|
}
|
|
|
|
payload.logger.info(data.toString())
|
|
})
|
|
|
|
installation.stderr.on('data', (data) => {
|
|
payload.logger.error(data.toString())
|
|
})
|
|
|
|
installation.on('exit', () => {
|
|
payload.logger.info('Done')
|
|
resolve()
|
|
})
|
|
})
|
|
}
|
|
|
|
const bootNextApp = async (args: { payload: Payload }): Promise<void> => {
|
|
const { payload } = args
|
|
|
|
let started = false
|
|
|
|
return new Promise(function (resolve, reject) {
|
|
// Boot up the Next.js app
|
|
const app = spawn('yarn', ['dev'], {
|
|
cwd: path.resolve(__dirname, './next-app'),
|
|
})
|
|
|
|
app.stdout.on('data', (data) => {
|
|
if (!started) {
|
|
payload.logger.info('Starting Next.js...')
|
|
started = true
|
|
}
|
|
|
|
payload.logger.info(data.toString())
|
|
|
|
if (data.toString().includes('Ready in')) {
|
|
resolve()
|
|
}
|
|
})
|
|
|
|
app.stderr.on('data', (data) => {
|
|
payload.logger.error(data.toString())
|
|
})
|
|
|
|
app.on('exit', (code) => {
|
|
payload.logger.info(`Next.js exited with code ${code}`)
|
|
reject()
|
|
})
|
|
})
|
|
}
|
|
|
|
export const startLivePreviewDemo = async (args: { payload: Payload }): Promise<void> => {
|
|
await installNodeModules(args)
|
|
await bootNextApp(args)
|
|
}
|