Skip to content

Commit

Permalink
feat(nextjs): Standalone projects now default to src
Browse files Browse the repository at this point in the history
  • Loading branch information
ndcunningham committed Jan 15, 2024
1 parent c7c5a6d commit 5aed0ea
Show file tree
Hide file tree
Showing 27 changed files with 166 additions and 56 deletions.
6 changes: 6 additions & 0 deletions docs/generated/cli/create-nx-workspace.md
Original file line number Diff line number Diff line change
Expand Up @@ -119,6 +119,12 @@ Type: `boolean`

Enable the App Router for Next.js

### nextSrcDir

Type: `boolean`

Generate a 'src/' directory for Next.js

### nxCloud

Type: `boolean`
Expand Down
6 changes: 6 additions & 0 deletions docs/generated/packages/next/generators/application.json
Original file line number Diff line number Diff line change
Expand Up @@ -124,6 +124,12 @@
"description": "Enable the App Router for this project.",
"x-prompt": "Would you like to use the App Router (recommended)?"
},
"src": {
"type": "boolean",
"default": true,
"description": "Generate a `src` directory for the project.",
"x-prompt": "Would you like to use `src/` directory?"
},
"rootProject": {
"description": "Create an application at the root of the workspace.",
"type": "boolean",
Expand Down
6 changes: 6 additions & 0 deletions docs/generated/packages/nx/documents/create-nx-workspace.md
Original file line number Diff line number Diff line change
Expand Up @@ -119,6 +119,12 @@ Type: `boolean`

Enable the App Router for Next.js

### nextSrcDir

Type: `boolean`

Generate a 'src/' directory for Next.js

### nxCloud

Type: `boolean`
Expand Down
5 changes: 5 additions & 0 deletions docs/generated/packages/workspace/generators/new.json
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,11 @@
"type": "boolean",
"default": true
},
"nextSrcDir": {
"description": "Generate a `src` directory for this project.",
"type": "boolean",
"default": true
},
"e2eTestRunner": {
"description": "The tool to use for running e2e tests.",
"type": "string",
Expand Down
5 changes: 5 additions & 0 deletions docs/generated/packages/workspace/generators/preset.json
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,11 @@
"type": "boolean",
"default": true
},
"nextSrcDir": {
"description": "Generate a `src` directory for this project.",
"type": "boolean",
"default": true
},
"e2eTestRunner": {
"description": "The tool to use for running e2e tests.",
"type": "string",
Expand Down
2 changes: 1 addition & 1 deletion e2e/next-core/src/next-pcv3.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ describe('@nx/next/plugin', () => {
});
});

afterAll(() => cleanupProject());
// afterAll(() => cleanupProject());

it('nx.json should contain plugin configuration', () => {
const nxJson = readJson('nx.json');
Expand Down
6 changes: 3 additions & 3 deletions e2e/next-core/src/next-structure.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ describe('Next.js Apps Libs', () => {
const buildableLib = uniq('buildablelib');

runCLI(
`generate @nx/next:app ${appName} --no-interactive --style=css --appDir=false --src=false`
`generate @nx/next:app ${appName} --no-interactive --style=css --appDir=false`
);
runCLI(`generate @nx/next:lib ${nextLib} --no-interactive`);
runCLI(`generate @nx/js:lib ${jsLib} --no-interactive`);
Expand Down Expand Up @@ -100,11 +100,11 @@ describe('Next.js Apps Libs', () => {
`
);

const mainPath = `packages/${appName}/pages/index.tsx`;
const mainPath = `packages/${appName}/src/pages/index.tsx`;
const content = readFile(mainPath);

updateFile(
`packages/${appName}/pages/api/hello.ts`,
`packages/${appName}/src/pages/api/hello.ts`,
`
import { jsLibAsync } from '@${proj}/${jsLib}';
Expand Down
6 changes: 3 additions & 3 deletions e2e/next-core/src/next.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ describe('Next.js Applications', () => {

// check files are generated without the layout directory ("apps/") and
// using the project name as the directory when no directory is provided
checkFilesExist(`${appName}/app/page.tsx`);
checkFilesExist(`${appName}/src/app/page.tsx`);
// check build works
expect(runCLI(`build ${appName}`)).toContain(
`Successfully ran target build for project ${appName}`
Expand Down Expand Up @@ -179,7 +179,7 @@ describe('Next.js Applications', () => {
`generate @nx/next:app ${appName} --no-interactive --js --appDir=false`
);

checkFilesExist(`apps/${appName}/pages/index.js`);
checkFilesExist(`apps/${appName}/src/pages/index.js`);

await checkApp(appName, {
checkUnitTest: true,
Expand All @@ -195,7 +195,7 @@ describe('Next.js Applications', () => {
`generate @nx/next:lib ${libName} --no-interactive --style=none --js`
);

const mainPath = `apps/${appName}/pages/index.js`;
const mainPath = `apps/${appName}/src/pages/index.js`;
updateFile(
mainPath,
`import '@${proj}/${libName}';\n` + readFile(mainPath)
Expand Down
4 changes: 3 additions & 1 deletion e2e/next-extensions/src/next-component-tests.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,9 @@ function addBabelSupport(path: string) {
}

function createAppWithCt(appName: string) {
runCLI(`generate @nx/next:app ${appName} --no-interactive --appDir=false`);
runCLI(
`generate @nx/next:app ${appName} --no-interactive --appDir=false --src=false`
);
runCLI(
`generate @nx/next:component button --project=${appName} --directory=components --flat --no-interactive`
);
Expand Down
2 changes: 1 addition & 1 deletion e2e/next-extensions/src/next-styles.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ describe('Next.js Styles', () => {
const lessApp = uniq('app');

runCLI(
`generate @nx/next:app ${lessApp} --no-interactive --style=less --appDir=false`
`generate @nx/next:app ${lessApp} --no-interactive --style=less --appDir=false --src=false`
);

await checkApp(lessApp, {
Expand Down
6 changes: 6 additions & 0 deletions e2e/utils/create-project-utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -229,6 +229,7 @@ export function runCreateWorkspace(
standaloneApi,
docker,
nextAppDir,
nextSrcDir,
e2eTestRunner,
ssr,
framework,
Expand All @@ -247,6 +248,7 @@ export function runCreateWorkspace(
routing?: boolean;
docker?: boolean;
nextAppDir?: boolean;
nextSrcDir?: boolean;
e2eTestRunner?: 'cypress' | 'playwright' | 'jest' | 'detox' | 'none';
ssr?: boolean;
framework?: string;
Expand Down Expand Up @@ -275,6 +277,10 @@ export function runCreateWorkspace(
command += ` --nextAppDir=${nextAppDir}`;
}

if (nextSrcDir !== undefined) {
command += ` --nextSrcDir=${nextSrcDir}`;
}

if (docker !== undefined) {
command += ` --docker=${docker}`;
}
Expand Down
9 changes: 6 additions & 3 deletions e2e/workspace-create/src/create-nx-workspace.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -223,11 +223,12 @@ describe('create-nx-workspace', () => {
style: 'css',
appName,
nextAppDir: false,
nextSrcDir: true,
packageManager,
e2eTestRunner: 'none',
});

checkFilesExist(`apps/${appName}/pages/index.tsx`);
checkFilesExist(`apps/${appName}/src/pages/index.tsx`);

expectNoAngularDevkit();
expectCodeIsFormatted();
Expand All @@ -240,12 +241,13 @@ describe('create-nx-workspace', () => {
preset: 'nextjs-standalone',
style: 'css',
nextAppDir: true,
nextSrcDir: true,
appName,
packageManager,
e2eTestRunner: 'none',
});

checkFilesExist('app/page.tsx');
checkFilesExist('src/app/page.tsx');

expectNoAngularDevkit();
expectCodeIsFormatted();
Expand All @@ -258,12 +260,13 @@ describe('create-nx-workspace', () => {
preset: 'nextjs-standalone',
style: 'css',
nextAppDir: false,
nextSrcDir: true,
appName,
packageManager,
e2eTestRunner: 'none',
});

checkFilesExist('pages/index.tsx');
checkFilesExist('src/pages/index.tsx');

expectNoAngularDevkit();
expectCodeIsFormatted();
Expand Down
40 changes: 39 additions & 1 deletion packages/create-nx-workspace/bin/create-nx-workspace.ts
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ interface ReactArguments extends BaseArguments {
style: string;
bundler: 'webpack' | 'vite' | 'rspack';
nextAppDir: boolean;
nextSrcDir: boolean;
e2eTestRunner: 'none' | 'cypress' | 'playwright';
}

Expand Down Expand Up @@ -164,6 +165,10 @@ export const commandsObject: yargs.Argv<Arguments> = yargs
describe: chalk.dim`Enable the App Router for Next.js`,
type: 'boolean',
})
.option('nextSrcDir', {
describe: chalk.dim`Generate a 'src/' directory for Next.js`,
type: 'boolean',
})
.option('e2eTestRunner', {
describe: chalk.dim`Test runner to use for end to end (E2E) tests.`,
choices: ['cypress', 'playwright', 'none'],
Expand Down Expand Up @@ -512,6 +517,7 @@ async function determineReactOptions(
let bundler: undefined | 'webpack' | 'vite' | 'rspack' = undefined;
let e2eTestRunner: undefined | 'none' | 'cypress' | 'playwright' = undefined;
let nextAppDir = false;
let nextSrcDir = false;

if (parsedArgs.preset && parsedArgs.preset !== Preset.React) {
preset = parsedArgs.preset;
Expand Down Expand Up @@ -563,6 +569,7 @@ async function determineReactOptions(
e2eTestRunner = await determineE2eTestRunner(parsedArgs);
} else if (preset === Preset.NextJs || preset === Preset.NextJsStandalone) {
nextAppDir = await determineNextAppDir(parsedArgs);
nextSrcDir = await determineNextSrcDir(parsedArgs);
e2eTestRunner = await determineE2eTestRunner(parsedArgs);
}

Expand Down Expand Up @@ -614,7 +621,15 @@ async function determineReactOptions(
style = reply.style;
}

return { preset, style, appName, bundler, nextAppDir, e2eTestRunner };
return {
preset,
style,
appName,
bundler,
nextAppDir,
nextSrcDir,
e2eTestRunner,
};
}

async function determineVueOptions(
Expand Down Expand Up @@ -1066,6 +1081,29 @@ async function determineNextAppDir(
return reply.nextAppDir === 'Yes';
}

async function determineNextSrcDir(
parsedArgs: yargs.Arguments<ReactArguments>
): Promise<boolean> {
if (parsedArgs.nextSrcDir !== undefined) return parsedArgs.nextSrcDir;
const reply = await enquirer.prompt<{ nextSrcDir: 'Yes' | 'No' }>([
{
name: 'nextSrcDir',
message: 'Would you like to use the src/ directory?',
type: 'autocomplete',
choices: [
{
name: 'Yes',
},
{
name: 'No',
},
],
initial: 'Yes' as any,
},
]);
return reply.nextSrcDir === 'Yes';
}

async function determineVueFramework(
parsedArgs: yargs.Arguments<VueArguments>
): Promise<'none' | 'nuxt'> {
Expand Down
Loading

0 comments on commit 5aed0ea

Please sign in to comment.