create-payload-app 1.0.0 → 3.0.0-alpha.50

Sign up to get free protection for your applications and to get access to all the features.
Files changed (91) hide show
  1. package/README.md +1 -1
  2. package/dist/index.d.ts +2 -0
  3. package/dist/index.d.ts.map +1 -0
  4. package/dist/index.js +3 -3
  5. package/dist/index.js.map +1 -0
  6. package/dist/lib/configure-payload-config.d.ts +11 -0
  7. package/dist/lib/configure-payload-config.d.ts.map +1 -0
  8. package/dist/lib/configure-payload-config.js +15 -53
  9. package/dist/lib/configure-payload-config.js.map +1 -0
  10. package/dist/lib/create-project.d.ts +14 -0
  11. package/dist/lib/create-project.d.ts.map +1 -0
  12. package/dist/lib/create-project.js +84 -24
  13. package/dist/lib/create-project.js.map +1 -0
  14. package/dist/lib/create-project.spec.d.ts +2 -0
  15. package/dist/lib/create-project.spec.d.ts.map +1 -0
  16. package/dist/lib/create-project.spec.js +30 -75
  17. package/dist/lib/create-project.spec.js.map +1 -0
  18. package/dist/lib/generate-secret.d.ts +2 -0
  19. package/dist/lib/generate-secret.d.ts.map +1 -0
  20. package/dist/lib/generate-secret.js +1 -1
  21. package/dist/lib/generate-secret.js.map +1 -0
  22. package/dist/lib/init-next.d.ts +29 -0
  23. package/dist/lib/init-next.d.ts.map +1 -0
  24. package/dist/lib/init-next.js +285 -0
  25. package/dist/lib/init-next.js.map +1 -0
  26. package/dist/lib/packages.d.ts +9 -0
  27. package/dist/lib/packages.d.ts.map +1 -0
  28. package/dist/lib/packages.js +8 -52
  29. package/dist/lib/packages.js.map +1 -0
  30. package/dist/lib/parse-project-name.d.ts +3 -0
  31. package/dist/lib/parse-project-name.d.ts.map +1 -0
  32. package/dist/lib/parse-project-name.js +53 -12
  33. package/dist/lib/parse-project-name.js.map +1 -0
  34. package/dist/lib/parse-template.d.ts +3 -0
  35. package/dist/lib/parse-template.d.ts.map +1 -0
  36. package/dist/lib/parse-template.js +50 -20
  37. package/dist/lib/parse-template.js.map +1 -0
  38. package/dist/lib/select-db.d.ts +3 -0
  39. package/dist/lib/select-db.d.ts.map +1 -0
  40. package/dist/lib/select-db.js +72 -31
  41. package/dist/lib/select-db.js.map +1 -0
  42. package/dist/lib/templates.d.ts +4 -0
  43. package/dist/lib/templates.d.ts.map +1 -0
  44. package/dist/lib/templates.js +17 -11
  45. package/dist/lib/templates.js.map +1 -0
  46. package/dist/lib/wrap-next-config.d.ts +12 -0
  47. package/dist/lib/wrap-next-config.d.ts.map +1 -0
  48. package/dist/lib/wrap-next-config.js +110 -0
  49. package/dist/lib/wrap-next-config.js.map +1 -0
  50. package/dist/lib/wrap-next-config.spec.d.ts +2 -0
  51. package/dist/lib/wrap-next-config.spec.d.ts.map +1 -0
  52. package/dist/lib/wrap-next-config.spec.js +98 -0
  53. package/dist/lib/wrap-next-config.spec.js.map +1 -0
  54. package/dist/lib/write-env-file.d.ts +10 -0
  55. package/dist/lib/write-env-file.d.ts.map +1 -0
  56. package/dist/lib/write-env-file.js +9 -6
  57. package/dist/lib/write-env-file.js.map +1 -0
  58. package/dist/main.d.ts +7 -0
  59. package/dist/main.d.ts.map +1 -0
  60. package/dist/main.js +176 -60
  61. package/dist/main.js.map +1 -0
  62. package/dist/scripts/pack-template-files.d.ts +2 -0
  63. package/dist/scripts/pack-template-files.d.ts.map +1 -0
  64. package/dist/scripts/pack-template-files.js +43 -0
  65. package/dist/scripts/pack-template-files.js.map +1 -0
  66. package/dist/template/src/app/(payload)/admin/[[...segments]]/page.tsx +17 -0
  67. package/dist/template/src/app/(payload)/api/[...slug]/route.ts +9 -0
  68. package/dist/template/src/app/(payload)/api/graphql/route.ts +6 -0
  69. package/dist/template/src/app/(payload)/api/graphql-playground/route.ts +6 -0
  70. package/dist/template/src/app/(payload)/custom.scss +0 -0
  71. package/dist/template/src/app/(payload)/layout.tsx +16 -0
  72. package/dist/template/src/app/my-route/route.ts +14 -0
  73. package/dist/template/src/collections/Users.ts +13 -0
  74. package/dist/template/src/payload.config.ts +38 -0
  75. package/dist/types.d.ts +55 -0
  76. package/dist/types.d.ts.map +1 -0
  77. package/dist/types.js +1 -1
  78. package/dist/types.js.map +1 -0
  79. package/dist/utils/copy-recursive-sync.d.ts +5 -0
  80. package/dist/utils/copy-recursive-sync.d.ts.map +1 -0
  81. package/dist/utils/copy-recursive-sync.js +34 -0
  82. package/dist/utils/copy-recursive-sync.js.map +1 -0
  83. package/dist/utils/log.d.ts +6 -0
  84. package/dist/utils/log.d.ts.map +1 -0
  85. package/dist/utils/log.js +62 -15
  86. package/dist/utils/log.js.map +1 -0
  87. package/dist/utils/messages.d.ts +11 -0
  88. package/dist/utils/messages.d.ts.map +1 -0
  89. package/dist/utils/messages.js +47 -16
  90. package/dist/utils/messages.js.map +1 -0
  91. package/package.json +27 -10
package/README.md CHANGED
@@ -10,7 +10,7 @@ CLI for easily starting new Payload project
10
10
 
11
11
  $ npx create-payload-app
12
12
  $ npx create-payload-app my-project
13
- $ npx create-payload-app -n my-project -t blog
13
+ $ npx create-payload-app -n my-project -t website
14
14
 
15
15
  OPTIONS
16
16
 
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":""}
package/dist/index.js CHANGED
@@ -2,11 +2,11 @@
2
2
  Object.defineProperty(exports, "__esModule", {
3
3
  value: true
4
4
  });
5
- const _main = require("./main");
6
- const _log = require("./utils/log");
5
+ const _main = require("./main.js");
6
+ const _log = require("./utils/log.js");
7
7
  async function main() {
8
8
  await new _main.Main().init();
9
9
  }
10
10
  main().catch((e)=>(0, _log.error)(`An error has occurred: ${e instanceof Error ? e.message : e}`));
11
11
 
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNYWluIH0gZnJvbSAnLi9tYWluJ1xuaW1wb3J0IHsgZXJyb3IgfSBmcm9tICcuL3V0aWxzL2xvZydcblxuYXN5bmMgZnVuY3Rpb24gbWFpbigpOiBQcm9taXNlPHZvaWQ+IHtcbiAgYXdhaXQgbmV3IE1haW4oKS5pbml0KClcbn1cblxubWFpbigpLmNhdGNoKChlKSA9PiBlcnJvcihgQW4gZXJyb3IgaGFzIG9jY3VycmVkOiAke2UgaW5zdGFuY2VvZiBFcnJvciA/IGUubWVzc2FnZSA6IGV9YCkpXG4iXSwibmFtZXMiOlsibWFpbiIsIk1haW4iLCJpbml0IiwiY2F0Y2giLCJlIiwiZXJyb3IiLCJFcnJvciIsIm1lc3NhZ2UiXSwibWFwcGluZ3MiOiI7Ozs7c0JBQXFCO3FCQUNDO0FBRXRCLGVBQWVBO0lBQ2IsTUFBTSxJQUFJQyxVQUFJLEdBQUdDLElBQUk7QUFDdkI7QUFFQUYsT0FBT0csS0FBSyxDQUFDLENBQUNDLElBQU1DLElBQUFBLFVBQUssRUFBQyxDQUFDLHVCQUF1QixFQUFFRCxhQUFhRSxRQUFRRixFQUFFRyxPQUFPLEdBQUdILEVBQUUsQ0FBQyJ9
12
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/index.ts"],"sourcesContent":["import { Main } from './main.js'\nimport { error } from './utils/log.js'\n\nasync function main(): Promise<void> {\n await new Main().init()\n}\n\nmain().catch((e) => error(`An error has occurred: ${e instanceof Error ? e.message : e}`))\n"],"names":["main","Main","init","catch","e","error","Error","message"],"mappings":";;;;sBAAqB;qBACC;AAEtB,eAAeA;IACb,MAAM,IAAIC,UAAI,GAAGC,IAAI;AACvB;AAEAF,OAAOG,KAAK,CAAC,CAACC,IAAMC,IAAAA,UAAK,EAAC,CAAC,uBAAuB,EAAED,aAAaE,QAAQF,EAAEG,OAAO,GAAGH,EAAE,CAAC"}
@@ -0,0 +1,11 @@
1
+ import type { DbDetails } from '../types.js';
2
+ /** Update payload config with necessary imports and adapters */
3
+ export declare function configurePayloadConfig(args: {
4
+ dbDetails: DbDetails | undefined;
5
+ projectDirOrConfigPath: {
6
+ payloadConfigPath: string;
7
+ } | {
8
+ projectDir: string;
9
+ };
10
+ }): Promise<void>;
11
+ //# sourceMappingURL=configure-payload-config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"configure-payload-config.d.ts","sourceRoot":"","sources":["../../src/lib/configure-payload-config.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AAK5C,gEAAgE;AAChE,wBAAsB,sBAAsB,CAAC,IAAI,EAAE;IACjD,SAAS,EAAE,SAAS,GAAG,SAAS,CAAA;IAChC,sBAAsB,EAAE;QAAE,iBAAiB,EAAE,MAAM,CAAA;KAAE,GAAG;QAAE,UAAU,EAAE,MAAM,CAAA;KAAE,CAAA;CAC/E,GAAG,OAAO,CAAC,IAAI,CAAC,CA6DhB"}
@@ -9,9 +9,9 @@ Object.defineProperty(exports, "configurePayloadConfig", {
9
9
  }
10
10
  });
11
11
  const _fsextra = /*#__PURE__*/ _interop_require_default(require("fs-extra"));
12
- const _path = /*#__PURE__*/ _interop_require_default(require("path"));
13
- const _log = require("../utils/log");
14
- const _packages = require("./packages");
12
+ const _globby = /*#__PURE__*/ _interop_require_default(require("globby"));
13
+ const _log = require("../utils/log.js");
14
+ const _packages = require("./packages.js");
15
15
  function _interop_require_default(obj) {
16
16
  return obj && obj.__esModule ? obj : {
17
17
  default: obj
@@ -21,67 +21,29 @@ async function configurePayloadConfig(args) {
21
21
  if (!args.dbDetails) {
22
22
  return;
23
23
  }
24
- // Update package.json
25
- const packageJsonPath = _path.default.resolve(args.projectDir, 'package.json');
26
24
  try {
27
- const packageObj = await _fsextra.default.readJson(packageJsonPath);
28
- packageObj.dependencies['payload'] = '^2.0.0';
29
- const dbPackage = _packages.dbPackages[args.dbDetails.type];
30
- const bundlerPackage = _packages.bundlerPackages['webpack'];
31
- const editorPackage = _packages.editorPackages['slate'];
32
- // Delete all other db adapters
33
- Object.values(_packages.dbPackages).forEach((p)=>{
34
- if (p.packageName !== dbPackage.packageName) {
35
- delete packageObj.dependencies[p.packageName];
36
- }
37
- });
38
- packageObj.dependencies[dbPackage.packageName] = dbPackage.version;
39
- packageObj.dependencies[bundlerPackage.packageName] = bundlerPackage.version;
40
- packageObj.dependencies[editorPackage.packageName] = editorPackage.version;
41
- await _fsextra.default.writeJson(packageJsonPath, packageObj, {
42
- spaces: 2
43
- });
44
- } catch (err) {
45
- (0, _log.warning)('Unable to update name in package.json');
46
- }
47
- try {
48
- const possiblePaths = [
49
- _path.default.resolve(args.projectDir, 'src/payload.config.ts'),
50
- _path.default.resolve(args.projectDir, 'src/payload/payload.config.ts')
51
- ];
52
25
  let payloadConfigPath;
53
- possiblePaths.forEach((p)=>{
54
- if (_fsextra.default.pathExistsSync(p) && !payloadConfigPath) {
55
- payloadConfigPath = p;
56
- }
57
- });
26
+ if (!('payloadConfigPath' in args.projectDirOrConfigPath)) {
27
+ payloadConfigPath = (await (0, _globby.default)('**/payload.config.ts', {
28
+ absolute: true,
29
+ cwd: args.projectDirOrConfigPath.projectDir
30
+ }))?.[0];
31
+ } else {
32
+ payloadConfigPath = args.projectDirOrConfigPath.payloadConfigPath;
33
+ }
58
34
  if (!payloadConfigPath) {
59
- (0, _log.warning)('Unable to update payload.config.ts with plugins');
35
+ (0, _log.warning)('Unable to update payload.config.ts with plugins. Could not find payload.config.ts.');
60
36
  return;
61
37
  }
62
38
  const configContent = _fsextra.default.readFileSync(payloadConfigPath, 'utf-8');
63
39
  const configLines = configContent.split('\n');
64
- const dbReplacement = _packages.dbPackages[args.dbDetails.type];
65
- const bundlerReplacement = _packages.bundlerPackages['webpack'];
66
- const editorReplacement = _packages.editorPackages['slate'];
40
+ const dbReplacement = _packages.dbReplacements[args.dbDetails.type];
67
41
  let dbConfigStartLineIndex;
68
42
  let dbConfigEndLineIndex;
69
43
  configLines.forEach((l, i)=>{
70
44
  if (l.includes('// database-adapter-import')) {
71
45
  configLines[i] = dbReplacement.importReplacement;
72
46
  }
73
- if (l.includes('// bundler-import')) {
74
- configLines[i] = bundlerReplacement.importReplacement;
75
- }
76
- if (l.includes('// bundler-config')) {
77
- configLines[i] = bundlerReplacement.configReplacement;
78
- }
79
- if (l.includes('// editor-import')) {
80
- configLines[i] = editorReplacement.importReplacement;
81
- }
82
- if (l.includes('// editor-config')) {
83
- configLines[i] = editorReplacement.configReplacement;
84
- }
85
47
  if (l.includes('// database-adapter-config-start')) {
86
48
  dbConfigStartLineIndex = i;
87
49
  }
@@ -97,8 +59,8 @@ async function configurePayloadConfig(args) {
97
59
  }
98
60
  _fsextra.default.writeFileSync(payloadConfigPath, configLines.join('\n'));
99
61
  } catch (err) {
100
- (0, _log.warning)('Unable to update payload.config.ts with plugins');
62
+ (0, _log.warning)(`Unable to update payload.config.ts with plugins: ${err instanceof Error ? err.message : ''}`);
101
63
  }
102
64
  }
103
65
 
104
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/lib/configure-payload-config.ts"],"sourcesContent":["import fse from 'fs-extra'\nimport path from 'path'\n\nimport type { DbDetails } from '../types'\n\nimport { warning } from '../utils/log'\nimport { bundlerPackages, dbPackages, editorPackages } from './packages'\n\n/** Update payload config with necessary imports and adapters */\nexport async function configurePayloadConfig(args: {\n  dbDetails: DbDetails | undefined\n  projectDir: string\n}): Promise<void> {\n  if (!args.dbDetails) {\n    return\n  }\n\n  // Update package.json\n  const packageJsonPath = path.resolve(args.projectDir, 'package.json')\n  try {\n    const packageObj = await fse.readJson(packageJsonPath)\n\n    packageObj.dependencies['payload'] = '^2.0.0'\n\n    const dbPackage = dbPackages[args.dbDetails.type]\n    const bundlerPackage = bundlerPackages['webpack']\n    const editorPackage = editorPackages['slate']\n\n    // Delete all other db adapters\n    Object.values(dbPackages).forEach((p) => {\n      if (p.packageName !== dbPackage.packageName) {\n        delete packageObj.dependencies[p.packageName]\n      }\n    })\n\n    packageObj.dependencies[dbPackage.packageName] = dbPackage.version\n    packageObj.dependencies[bundlerPackage.packageName] = bundlerPackage.version\n    packageObj.dependencies[editorPackage.packageName] = editorPackage.version\n\n    await fse.writeJson(packageJsonPath, packageObj, { spaces: 2 })\n  } catch (err: unknown) {\n    warning('Unable to update name in package.json')\n  }\n\n  try {\n    const possiblePaths = [\n      path.resolve(args.projectDir, 'src/payload.config.ts'),\n      path.resolve(args.projectDir, 'src/payload/payload.config.ts'),\n    ]\n\n    let payloadConfigPath: string | undefined\n\n    possiblePaths.forEach((p) => {\n      if (fse.pathExistsSync(p) && !payloadConfigPath) {\n        payloadConfigPath = p\n      }\n    })\n\n    if (!payloadConfigPath) {\n      warning('Unable to update payload.config.ts with plugins')\n      return\n    }\n\n    const configContent = fse.readFileSync(payloadConfigPath, 'utf-8')\n    const configLines = configContent.split('\\n')\n\n    const dbReplacement = dbPackages[args.dbDetails.type]\n    const bundlerReplacement = bundlerPackages['webpack']\n    const editorReplacement = editorPackages['slate']\n\n    let dbConfigStartLineIndex: number | undefined\n    let dbConfigEndLineIndex: number | undefined\n\n    configLines.forEach((l, i) => {\n      if (l.includes('// database-adapter-import')) {\n        configLines[i] = dbReplacement.importReplacement\n      }\n      if (l.includes('// bundler-import')) {\n        configLines[i] = bundlerReplacement.importReplacement\n      }\n\n      if (l.includes('// bundler-config')) {\n        configLines[i] = bundlerReplacement.configReplacement\n      }\n\n      if (l.includes('// editor-import')) {\n        configLines[i] = editorReplacement.importReplacement\n      }\n\n      if (l.includes('// editor-config')) {\n        configLines[i] = editorReplacement.configReplacement\n      }\n\n      if (l.includes('// database-adapter-config-start')) {\n        dbConfigStartLineIndex = i\n      }\n      if (l.includes('// database-adapter-config-end')) {\n        dbConfigEndLineIndex = i\n      }\n    })\n\n    if (!dbConfigStartLineIndex || !dbConfigEndLineIndex) {\n      warning('Unable to update payload.config.ts with database adapter import')\n    } else {\n      // Replaces lines between `// database-adapter-config-start` and `// database-adapter-config-end`\n      configLines.splice(\n        dbConfigStartLineIndex,\n        dbConfigEndLineIndex - dbConfigStartLineIndex + 1,\n        ...dbReplacement.configReplacement,\n      )\n    }\n\n    fse.writeFileSync(payloadConfigPath, configLines.join('\\n'))\n  } catch (err: unknown) {\n    warning('Unable to update payload.config.ts with plugins')\n  }\n}\n"],"names":["configurePayloadConfig","args","dbDetails","packageJsonPath","path","resolve","projectDir","packageObj","fse","readJson","dependencies","dbPackage","dbPackages","type","bundlerPackage","bundlerPackages","editorPackage","editorPackages","Object","values","forEach","p","packageName","version","writeJson","spaces","err","warning","possiblePaths","payloadConfigPath","pathExistsSync","configContent","readFileSync","configLines","split","dbReplacement","bundlerReplacement","editorReplacement","dbConfigStartLineIndex","dbConfigEndLineIndex","l","i","includes","importReplacement","configReplacement","splice","writeFileSync","join"],"mappings":"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"}
66
+ //# sourceMappingURL=configure-payload-config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/lib/configure-payload-config.ts"],"sourcesContent":["import fse from 'fs-extra'\nimport globby from 'globby'\n\nimport type { DbDetails } from '../types.js'\n\nimport { warning } from '../utils/log.js'\nimport { dbReplacements } from './packages.js'\n\n/** Update payload config with necessary imports and adapters */\nexport async function configurePayloadConfig(args: {\n dbDetails: DbDetails | undefined\n projectDirOrConfigPath: { payloadConfigPath: string } | { projectDir: string }\n}): Promise<void> {\n if (!args.dbDetails) {\n return\n }\n\n try {\n let payloadConfigPath: string | undefined\n if (!('payloadConfigPath' in args.projectDirOrConfigPath)) {\n payloadConfigPath = (\n await globby('**/payload.config.ts', {\n absolute: true,\n cwd: args.projectDirOrConfigPath.projectDir,\n })\n )?.[0]\n } else {\n payloadConfigPath = args.projectDirOrConfigPath.payloadConfigPath\n }\n\n if (!payloadConfigPath) {\n warning('Unable to update payload.config.ts with plugins. Could not find payload.config.ts.')\n return\n }\n\n const configContent = fse.readFileSync(payloadConfigPath, 'utf-8')\n const configLines = configContent.split('\\n')\n\n const dbReplacement = dbReplacements[args.dbDetails.type]\n\n let dbConfigStartLineIndex: number | undefined\n let dbConfigEndLineIndex: number | undefined\n\n configLines.forEach((l, i) => {\n if (l.includes('// database-adapter-import')) {\n configLines[i] = dbReplacement.importReplacement\n }\n\n if (l.includes('// database-adapter-config-start')) {\n dbConfigStartLineIndex = i\n }\n if (l.includes('// database-adapter-config-end')) {\n dbConfigEndLineIndex = i\n }\n })\n\n if (!dbConfigStartLineIndex || !dbConfigEndLineIndex) {\n warning('Unable to update payload.config.ts with database adapter import')\n } else {\n // Replaces lines between `// database-adapter-config-start` and `// database-adapter-config-end`\n configLines.splice(\n dbConfigStartLineIndex,\n dbConfigEndLineIndex - dbConfigStartLineIndex + 1,\n ...dbReplacement.configReplacement,\n )\n }\n\n fse.writeFileSync(payloadConfigPath, configLines.join('\\n'))\n } catch (err: unknown) {\n warning(\n `Unable to update payload.config.ts with plugins: ${err instanceof Error ? err.message : ''}`,\n )\n }\n}\n"],"names":["configurePayloadConfig","args","dbDetails","payloadConfigPath","projectDirOrConfigPath","globby","absolute","cwd","projectDir","warning","configContent","fse","readFileSync","configLines","split","dbReplacement","dbReplacements","type","dbConfigStartLineIndex","dbConfigEndLineIndex","forEach","l","i","includes","importReplacement","splice","configReplacement","writeFileSync","join","err","Error","message"],"mappings":";;;;+BASsBA;;;eAAAA;;;gEATN;+DACG;qBAIK;0BACO;;;;;;AAGxB,eAAeA,uBAAuBC,IAG5C;IACC,IAAI,CAACA,KAAKC,SAAS,EAAE;QACnB;IACF;IAEA,IAAI;QACF,IAAIC;QACJ,IAAI,CAAE,CAAA,uBAAuBF,KAAKG,sBAAsB,AAAD,GAAI;YACzDD,oBACE,CAAA,MAAME,IAAAA,eAAM,EAAC,wBAAwB;gBACnCC,UAAU;gBACVC,KAAKN,KAAKG,sBAAsB,CAACI,UAAU;YAC7C,EAAC,GACA,CAAC,EAAE;QACR,OAAO;YACLL,oBAAoBF,KAAKG,sBAAsB,CAACD,iBAAiB;QACnE;QAEA,IAAI,CAACA,mBAAmB;YACtBM,IAAAA,YAAO,EAAC;YACR;QACF;QAEA,MAAMC,gBAAgBC,gBAAG,CAACC,YAAY,CAACT,mBAAmB;QAC1D,MAAMU,cAAcH,cAAcI,KAAK,CAAC;QAExC,MAAMC,gBAAgBC,wBAAc,CAACf,KAAKC,SAAS,CAACe,IAAI,CAAC;QAEzD,IAAIC;QACJ,IAAIC;QAEJN,YAAYO,OAAO,CAAC,CAACC,GAAGC;YACtB,IAAID,EAAEE,QAAQ,CAAC,+BAA+B;gBAC5CV,WAAW,CAACS,EAAE,GAAGP,cAAcS,iBAAiB;YAClD;YAEA,IAAIH,EAAEE,QAAQ,CAAC,qCAAqC;gBAClDL,yBAAyBI;YAC3B;YACA,IAAID,EAAEE,QAAQ,CAAC,mCAAmC;gBAChDJ,uBAAuBG;YACzB;QACF;QAEA,IAAI,CAACJ,0BAA0B,CAACC,sBAAsB;YACpDV,IAAAA,YAAO,EAAC;QACV,OAAO;YACL,iGAAiG;YACjGI,YAAYY,MAAM,CAChBP,wBACAC,uBAAuBD,yBAAyB,MAC7CH,cAAcW,iBAAiB;QAEtC;QAEAf,gBAAG,CAACgB,aAAa,CAACxB,mBAAmBU,YAAYe,IAAI,CAAC;IACxD,EAAE,OAAOC,KAAc;QACrBpB,IAAAA,YAAO,EACL,CAAC,iDAAiD,EAAEoB,eAAeC,QAAQD,IAAIE,OAAO,GAAG,GAAG,CAAC;IAEjG;AACF"}
@@ -0,0 +1,14 @@
1
+ import type { CliArgs, DbDetails, PackageManager, ProjectTemplate } from '../types.js';
2
+ export declare function createProject(args: {
3
+ cliArgs: CliArgs;
4
+ dbDetails?: DbDetails;
5
+ packageManager: PackageManager;
6
+ projectDir: string;
7
+ projectName: string;
8
+ template: ProjectTemplate;
9
+ }): Promise<void>;
10
+ export declare function updatePackageJSON(args: {
11
+ projectDir: string;
12
+ projectName: string;
13
+ }): Promise<void>;
14
+ //# sourceMappingURL=create-project.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create-project.d.ts","sourceRoot":"","sources":["../../src/lib/create-project.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,aAAa,CAAA;AA2CtF,wBAAsB,aAAa,CAAC,IAAI,EAAE;IACxC,OAAO,EAAE,OAAO,CAAA;IAChB,SAAS,CAAC,EAAE,SAAS,CAAA;IACrB,cAAc,EAAE,cAAc,CAAA;IAC9B,UAAU,EAAE,MAAM,CAAA;IAClB,WAAW,EAAE,MAAM,CAAA;IACnB,QAAQ,EAAE,eAAe,CAAA;CAC1B,GAAG,OAAO,CAAC,IAAI,CAAC,CAoDhB;AAED,wBAAsB,iBAAiB,CAAC,IAAI,EAAE;IAC5C,UAAU,EAAE,MAAM,CAAA;IAClB,WAAW,EAAE,MAAM,CAAA;CACpB,GAAG,OAAO,CAAC,IAAI,CAAC,CAUhB"}
@@ -16,19 +16,63 @@ _export(exports, {
16
16
  return updatePackageJSON;
17
17
  }
18
18
  });
19
+ const _prompts = /*#__PURE__*/ _interop_require_wildcard(require("@clack/prompts"));
19
20
  const _chalk = /*#__PURE__*/ _interop_require_default(require("chalk"));
20
21
  const _degit = /*#__PURE__*/ _interop_require_default(require("degit"));
21
22
  const _execa = /*#__PURE__*/ _interop_require_default(require("execa"));
22
23
  const _fsextra = /*#__PURE__*/ _interop_require_default(require("fs-extra"));
23
- const _ora = /*#__PURE__*/ _interop_require_default(require("ora"));
24
+ const _nodeurl = require("node:url");
24
25
  const _path = /*#__PURE__*/ _interop_require_default(require("path"));
25
- const _log = require("../utils/log");
26
- const _configurepayloadconfig = require("./configure-payload-config");
26
+ const _log = require("../utils/log.js");
27
+ const _configurepayloadconfig = require("./configure-payload-config.js");
27
28
  function _interop_require_default(obj) {
28
29
  return obj && obj.__esModule ? obj : {
29
30
  default: obj
30
31
  };
31
32
  }
33
+ function _getRequireWildcardCache(nodeInterop) {
34
+ if (typeof WeakMap !== "function") return null;
35
+ var cacheBabelInterop = new WeakMap();
36
+ var cacheNodeInterop = new WeakMap();
37
+ return (_getRequireWildcardCache = function(nodeInterop) {
38
+ return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
39
+ })(nodeInterop);
40
+ }
41
+ function _interop_require_wildcard(obj, nodeInterop) {
42
+ if (!nodeInterop && obj && obj.__esModule) {
43
+ return obj;
44
+ }
45
+ if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
46
+ return {
47
+ default: obj
48
+ };
49
+ }
50
+ var cache = _getRequireWildcardCache(nodeInterop);
51
+ if (cache && cache.has(obj)) {
52
+ return cache.get(obj);
53
+ }
54
+ var newObj = {
55
+ __proto__: null
56
+ };
57
+ var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
58
+ for(var key in obj){
59
+ if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
60
+ var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
61
+ if (desc && (desc.get || desc.set)) {
62
+ Object.defineProperty(newObj, key, desc);
63
+ } else {
64
+ newObj[key] = obj[key];
65
+ }
66
+ }
67
+ }
68
+ newObj.default = obj;
69
+ if (cache) {
70
+ cache.set(obj, newObj);
71
+ }
72
+ return newObj;
73
+ }
74
+ const filename = (0, _nodeurl.fileURLToPath)(require("url").pathToFileURL(__filename).toString());
75
+ const dirname = _path.default.dirname(filename);
32
76
  async function createOrFindProjectDir(projectDir) {
33
77
  const pathExists = await _fsextra.default.pathExists(projectDir);
34
78
  if (!pathExists) {
@@ -52,46 +96,62 @@ async function installDeps(args) {
52
96
  });
53
97
  return true;
54
98
  } catch (err) {
55
- console.log({
56
- err
57
- });
99
+ (0, _log.error)(`Error installing dependencies${err instanceof Error ? `: ${err.message}` : ''}.`);
58
100
  return false;
59
101
  }
60
102
  }
61
103
  async function createProject(args) {
62
104
  const { cliArgs, dbDetails, packageManager, projectDir, projectName, template } = args;
105
+ if (cliArgs['--dry-run']) {
106
+ (0, _log.debug)(`Dry run: Creating project in ${_chalk.default.green(projectDir)}`);
107
+ return;
108
+ }
63
109
  await createOrFindProjectDir(projectDir);
64
- console.log(`\n Creating project in ${_chalk.default.green(_path.default.resolve(projectDir))}\n`);
65
- if ('url' in template) {
66
- const emitter = (0, _degit.default)(template.url);
110
+ if (cliArgs['--local-template']) {
111
+ // Copy template from local path. For development purposes.
112
+ const localTemplate = _path.default.resolve(dirname, '../../../../templates/', cliArgs['--local-template']);
113
+ await _fsextra.default.copy(localTemplate, projectDir);
114
+ } else if ('url' in template) {
115
+ let templateUrl = template.url;
116
+ if (cliArgs['--template-branch']) {
117
+ templateUrl = `${template.url}#${cliArgs['--template-branch']}`;
118
+ (0, _log.debug)(`Using template url: ${templateUrl}`);
119
+ }
120
+ const emitter = (0, _degit.default)(templateUrl);
67
121
  await emitter.clone(projectDir);
68
122
  }
69
- const spinner = (0, _ora.default)('Checking latest Payload version...').start();
123
+ const spinner = _prompts.spinner();
124
+ spinner.start('Checking latest Payload version...');
70
125
  await updatePackageJSON({
71
126
  projectDir,
72
127
  projectName
73
128
  });
129
+ spinner.message('Configuring Payload...');
74
130
  await (0, _configurepayloadconfig.configurePayloadConfig)({
75
131
  dbDetails,
76
- projectDir
132
+ projectDirOrConfigPath: {
133
+ projectDir
134
+ }
77
135
  });
78
136
  // Remove yarn.lock file. This is only desired in Payload Cloud.
79
137
  const lockPath = _path.default.resolve(projectDir, 'yarn.lock');
80
138
  if (_fsextra.default.existsSync(lockPath)) {
81
139
  await _fsextra.default.remove(lockPath);
82
140
  }
83
- spinner.text = 'Installing dependencies...';
84
- const result = await installDeps({
85
- cliArgs,
86
- packageManager,
87
- projectDir
88
- });
89
- spinner.stop();
90
- spinner.clear();
91
- if (result) {
92
- (0, _log.success)('Dependencies installed');
141
+ if (!cliArgs['--no-deps']) {
142
+ spinner.message('Installing dependencies...');
143
+ const result = await installDeps({
144
+ cliArgs,
145
+ packageManager,
146
+ projectDir
147
+ });
148
+ if (result) {
149
+ spinner.stop('Successfully installed Payload and dependencies');
150
+ } else {
151
+ spinner.stop('Error installing dependencies', 1);
152
+ }
93
153
  } else {
94
- (0, _log.error)('Error installing dependencies');
154
+ spinner.stop('Dependency installation skipped');
95
155
  }
96
156
  }
97
157
  async function updatePackageJSON(args) {
@@ -104,8 +164,8 @@ async function updatePackageJSON(args) {
104
164
  spaces: 2
105
165
  });
106
166
  } catch (err) {
107
- (0, _log.warning)('Unable to update name in package.json');
167
+ (0, _log.warning)(`Unable to update name in package.json. ${err instanceof Error ? err.message : ''}`);
108
168
  }
109
169
  }
110
170
 
111
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvY3JlYXRlLXByb2plY3QudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGNoYWxrIGZyb20gJ2NoYWxrJ1xuaW1wb3J0IGRlZ2l0IGZyb20gJ2RlZ2l0J1xuaW1wb3J0IGV4ZWNhIGZyb20gJ2V4ZWNhJ1xuaW1wb3J0IGZzZSBmcm9tICdmcy1leHRyYSdcbmltcG9ydCBvcmEgZnJvbSAnb3JhJ1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCdcblxuaW1wb3J0IHR5cGUgeyBDbGlBcmdzLCBEYkRldGFpbHMsIFBhY2thZ2VNYW5hZ2VyLCBQcm9qZWN0VGVtcGxhdGUgfSBmcm9tICcuLi90eXBlcydcblxuaW1wb3J0IHsgZXJyb3IsIHN1Y2Nlc3MsIHdhcm5pbmcgfSBmcm9tICcuLi91dGlscy9sb2cnXG5pbXBvcnQgeyBjb25maWd1cmVQYXlsb2FkQ29uZmlnIH0gZnJvbSAnLi9jb25maWd1cmUtcGF5bG9hZC1jb25maWcnXG5cbmFzeW5jIGZ1bmN0aW9uIGNyZWF0ZU9yRmluZFByb2plY3REaXIocHJvamVjdERpcjogc3RyaW5nKTogUHJvbWlzZTx2b2lkPiB7XG4gIGNvbnN0IHBhdGhFeGlzdHMgPSBhd2FpdCBmc2UucGF0aEV4aXN0cyhwcm9qZWN0RGlyKVxuICBpZiAoIXBhdGhFeGlzdHMpIHtcbiAgICBhd2FpdCBmc2UubWtkaXIocHJvamVjdERpcilcbiAgfVxufVxuXG5hc3luYyBmdW5jdGlvbiBpbnN0YWxsRGVwcyhhcmdzOiB7XG4gIGNsaUFyZ3M6IENsaUFyZ3NcbiAgcGFja2FnZU1hbmFnZXI6IFBhY2thZ2VNYW5hZ2VyXG4gIHByb2plY3REaXI6IHN0cmluZ1xufSk6IFByb21pc2U8Ym9vbGVhbj4ge1xuICBjb25zdCB7IGNsaUFyZ3MsIHBhY2thZ2VNYW5hZ2VyLCBwcm9qZWN0RGlyIH0gPSBhcmdzXG4gIGlmIChjbGlBcmdzWyctLW5vLWRlcHMnXSkge1xuICAgIHJldHVybiB0cnVlXG4gIH1cbiAgbGV0IGluc3RhbGxDbWQgPSAnbnBtIGluc3RhbGwgLS1sZWdhY3ktcGVlci1kZXBzJ1xuXG4gIGlmIChwYWNrYWdlTWFuYWdlciA9PT0gJ3lhcm4nKSB7XG4gICAgaW5zdGFsbENtZCA9ICd5YXJuJ1xuICB9IGVsc2UgaWYgKHBhY2thZ2VNYW5hZ2VyID09PSAncG5wbScpIHtcbiAgICBpbnN0YWxsQ21kID0gJ3BucG0gaW5zdGFsbCdcbiAgfVxuXG4gIHRyeSB7XG4gICAgYXdhaXQgZXhlY2EuY29tbWFuZChpbnN0YWxsQ21kLCB7XG4gICAgICBjd2Q6IHBhdGgucmVzb2x2ZShwcm9qZWN0RGlyKSxcbiAgICB9KVxuICAgIHJldHVybiB0cnVlXG4gIH0gY2F0Y2ggKGVycjogdW5rbm93bikge1xuICAgIGNvbnNvbGUubG9nKHsgZXJyIH0pXG4gICAgcmV0dXJuIGZhbHNlXG4gIH1cbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGNyZWF0ZVByb2plY3QoYXJnczoge1xuICBjbGlBcmdzOiBDbGlBcmdzXG4gIGRiRGV0YWlscz86IERiRGV0YWlsc1xuICBwYWNrYWdlTWFuYWdlcjogUGFja2FnZU1hbmFnZXJcbiAgcHJvamVjdERpcjogc3RyaW5nXG4gIHByb2plY3ROYW1lOiBzdHJpbmdcbiAgdGVtcGxhdGU6IFByb2plY3RUZW1wbGF0ZVxufSk6IFByb21pc2U8dm9pZD4ge1xuICBjb25zdCB7IGNsaUFyZ3MsIGRiRGV0YWlscywgcGFja2FnZU1hbmFnZXIsIHByb2plY3REaXIsIHByb2plY3ROYW1lLCB0ZW1wbGF0ZSB9ID0gYXJnc1xuXG4gIGF3YWl0IGNyZWF0ZU9yRmluZFByb2plY3REaXIocHJvamVjdERpcilcblxuICBjb25zb2xlLmxvZyhgXFxuICBDcmVhdGluZyBwcm9qZWN0IGluICR7Y2hhbGsuZ3JlZW4ocGF0aC5yZXNvbHZlKHByb2plY3REaXIpKX1cXG5gKVxuXG4gIGlmICgndXJsJyBpbiB0ZW1wbGF0ZSkge1xuICAgIGNvbnN0IGVtaXR0ZXIgPSBkZWdpdCh0ZW1wbGF0ZS51cmwpXG4gICAgYXdhaXQgZW1pdHRlci5jbG9uZShwcm9qZWN0RGlyKVxuICB9XG5cbiAgY29uc3Qgc3Bpbm5lciA9IG9yYSgnQ2hlY2tpbmcgbGF0ZXN0IFBheWxvYWQgdmVyc2lvbi4uLicpLnN0YXJ0KClcblxuICBhd2FpdCB1cGRhdGVQYWNrYWdlSlNPTih7IHByb2plY3REaXIsIHByb2plY3ROYW1lIH0pXG4gIGF3YWl0IGNvbmZpZ3VyZVBheWxvYWRDb25maWcoeyBkYkRldGFpbHMsIHByb2plY3REaXIgfSlcblxuICAvLyBSZW1vdmUgeWFybi5sb2NrIGZpbGUuIFRoaXMgaXMgb25seSBkZXNpcmVkIGluIFBheWxvYWQgQ2xvdWQuXG4gIGNvbnN0IGxvY2tQYXRoID0gcGF0aC5yZXNvbHZlKHByb2plY3REaXIsICd5YXJuLmxvY2snKVxuICBpZiAoZnNlLmV4aXN0c1N5bmMobG9ja1BhdGgpKSB7XG4gICAgYXdhaXQgZnNlLnJlbW92ZShsb2NrUGF0aClcbiAgfVxuXG4gIHNwaW5uZXIudGV4dCA9ICdJbnN0YWxsaW5nIGRlcGVuZGVuY2llcy4uLidcbiAgY29uc3QgcmVzdWx0ID0gYXdhaXQgaW5zdGFsbERlcHMoeyBjbGlBcmdzLCBwYWNrYWdlTWFuYWdlciwgcHJvamVjdERpciB9KVxuICBzcGlubmVyLnN0b3AoKVxuICBzcGlubmVyLmNsZWFyKClcbiAgaWYgKHJlc3VsdCkge1xuICAgIHN1Y2Nlc3MoJ0RlcGVuZGVuY2llcyBpbnN0YWxsZWQnKVxuICB9IGVsc2Uge1xuICAgIGVycm9yKCdFcnJvciBpbnN0YWxsaW5nIGRlcGVuZGVuY2llcycpXG4gIH1cbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHVwZGF0ZVBhY2thZ2VKU09OKGFyZ3M6IHtcbiAgcHJvamVjdERpcjogc3RyaW5nXG4gIHByb2plY3ROYW1lOiBzdHJpbmdcbn0pOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uc3QgeyBwcm9qZWN0RGlyLCBwcm9qZWN0TmFtZSB9ID0gYXJnc1xuICBjb25zdCBwYWNrYWdlSnNvblBhdGggPSBwYXRoLnJlc29sdmUocHJvamVjdERpciwgJ3BhY2thZ2UuanNvbicpXG4gIHRyeSB7XG4gICAgY29uc3QgcGFja2FnZU9iaiA9IGF3YWl0IGZzZS5yZWFkSnNvbihwYWNrYWdlSnNvblBhdGgpXG4gICAgcGFja2FnZU9iai5uYW1lID0gcHJvamVjdE5hbWVcbiAgICBhd2FpdCBmc2Uud3JpdGVKc29uKHBhY2thZ2VKc29uUGF0aCwgcGFja2FnZU9iaiwgeyBzcGFjZXM6IDIgfSlcbiAgfSBjYXRjaCAoZXJyOiB1bmtub3duKSB7XG4gICAgd2FybmluZygnVW5hYmxlIHRvIHVwZGF0ZSBuYW1lIGluIHBhY2thZ2UuanNvbicpXG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJjcmVhdGVQcm9qZWN0IiwidXBkYXRlUGFja2FnZUpTT04iLCJjcmVhdGVPckZpbmRQcm9qZWN0RGlyIiwicHJvamVjdERpciIsInBhdGhFeGlzdHMiLCJmc2UiLCJta2RpciIsImluc3RhbGxEZXBzIiwiYXJncyIsImNsaUFyZ3MiLCJwYWNrYWdlTWFuYWdlciIsImluc3RhbGxDbWQiLCJleGVjYSIsImNvbW1hbmQiLCJjd2QiLCJwYXRoIiwicmVzb2x2ZSIsImVyciIsImNvbnNvbGUiLCJsb2ciLCJkYkRldGFpbHMiLCJwcm9qZWN0TmFtZSIsInRlbXBsYXRlIiwiY2hhbGsiLCJncmVlbiIsImVtaXR0ZXIiLCJkZWdpdCIsInVybCIsImNsb25lIiwic3Bpbm5lciIsIm9yYSIsInN0YXJ0IiwiY29uZmlndXJlUGF5bG9hZENvbmZpZyIsImxvY2tQYXRoIiwiZXhpc3RzU3luYyIsInJlbW92ZSIsInRleHQiLCJyZXN1bHQiLCJzdG9wIiwiY2xlYXIiLCJzdWNjZXNzIiwiZXJyb3IiLCJwYWNrYWdlSnNvblBhdGgiLCJwYWNrYWdlT2JqIiwicmVhZEpzb24iLCJuYW1lIiwid3JpdGVKc29uIiwic3BhY2VzIiwid2FybmluZyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7SUErQ3NCQSxhQUFhO2VBQWJBOztJQXlDQUMsaUJBQWlCO2VBQWpC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
171
+ //# sourceMappingURL=create-project.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/lib/create-project.ts"],"sourcesContent":["import * as p from '@clack/prompts'\nimport chalk from 'chalk'\nimport degit from 'degit'\nimport execa from 'execa'\nimport fse from 'fs-extra'\nimport { fileURLToPath } from 'node:url'\nimport path from 'path'\n\nimport type { CliArgs, DbDetails, PackageManager, ProjectTemplate } from '../types.js'\n\nimport { debug, error, warning } from '../utils/log.js'\nimport { configurePayloadConfig } from './configure-payload-config.js'\n\nconst filename = fileURLToPath(import.meta.url)\nconst dirname = path.dirname(filename)\n\nasync function createOrFindProjectDir(projectDir: string): Promise<void> {\n const pathExists = await fse.pathExists(projectDir)\n if (!pathExists) {\n await fse.mkdir(projectDir)\n }\n}\n\nasync function installDeps(args: {\n cliArgs: CliArgs\n packageManager: PackageManager\n projectDir: string\n}): Promise<boolean> {\n const { cliArgs, packageManager, projectDir } = args\n if (cliArgs['--no-deps']) {\n return true\n }\n let installCmd = 'npm install --legacy-peer-deps'\n\n if (packageManager === 'yarn') {\n installCmd = 'yarn'\n } else if (packageManager === 'pnpm') {\n installCmd = 'pnpm install'\n }\n\n try {\n await execa.command(installCmd, {\n cwd: path.resolve(projectDir),\n })\n return true\n } catch (err: unknown) {\n error(`Error installing dependencies${err instanceof Error ? `: ${err.message}` : ''}.`)\n return false\n }\n}\n\nexport async function createProject(args: {\n cliArgs: CliArgs\n dbDetails?: DbDetails\n packageManager: PackageManager\n projectDir: string\n projectName: string\n template: ProjectTemplate\n}): Promise<void> {\n const { cliArgs, dbDetails, packageManager, projectDir, projectName, template } = args\n\n if (cliArgs['--dry-run']) {\n debug(`Dry run: Creating project in ${chalk.green(projectDir)}`)\n return\n }\n\n await createOrFindProjectDir(projectDir)\n\n if (cliArgs['--local-template']) {\n // Copy template from local path. For development purposes.\n const localTemplate = path.resolve(\n dirname,\n '../../../../templates/',\n cliArgs['--local-template'],\n )\n await fse.copy(localTemplate, projectDir)\n } else if ('url' in template) {\n let templateUrl = template.url\n if (cliArgs['--template-branch']) {\n templateUrl = `${template.url}#${cliArgs['--template-branch']}`\n debug(`Using template url: ${templateUrl}`)\n }\n const emitter = degit(templateUrl)\n await emitter.clone(projectDir)\n }\n\n const spinner = p.spinner()\n spinner.start('Checking latest Payload version...')\n\n await updatePackageJSON({ projectDir, projectName })\n spinner.message('Configuring Payload...')\n await configurePayloadConfig({ dbDetails, projectDirOrConfigPath: { projectDir } })\n\n // Remove yarn.lock file. This is only desired in Payload Cloud.\n const lockPath = path.resolve(projectDir, 'yarn.lock')\n if (fse.existsSync(lockPath)) {\n await fse.remove(lockPath)\n }\n\n if (!cliArgs['--no-deps']) {\n spinner.message('Installing dependencies...')\n const result = await installDeps({ cliArgs, packageManager, projectDir })\n if (result) {\n spinner.stop('Successfully installed Payload and dependencies')\n } else {\n spinner.stop('Error installing dependencies', 1)\n }\n } else {\n spinner.stop('Dependency installation skipped')\n }\n}\n\nexport async function updatePackageJSON(args: {\n projectDir: string\n projectName: string\n}): Promise<void> {\n const { projectDir, projectName } = args\n const packageJsonPath = path.resolve(projectDir, 'package.json')\n try {\n const packageObj = await fse.readJson(packageJsonPath)\n packageObj.name = projectName\n await fse.writeJson(packageJsonPath, packageObj, { spaces: 2 })\n } catch (err: unknown) {\n warning(`Unable to update name in package.json. ${err instanceof Error ? err.message : ''}`)\n }\n}\n"],"names":["createProject","updatePackageJSON","filename","fileURLToPath","dirname","path","createOrFindProjectDir","projectDir","pathExists","fse","mkdir","installDeps","args","cliArgs","packageManager","installCmd","execa","command","cwd","resolve","err","error","Error","message","dbDetails","projectName","template","debug","chalk","green","localTemplate","copy","templateUrl","url","emitter","degit","clone","spinner","p","start","configurePayloadConfig","projectDirOrConfigPath","lockPath","existsSync","remove","result","stop","packageJsonPath","packageObj","readJson","name","writeJson","spaces","warning"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=create-project.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create-project.spec.d.ts","sourceRoot":"","sources":["../../src/lib/create-project.spec.ts"],"names":[],"mappings":""}
@@ -4,15 +4,19 @@ Object.defineProperty(exports, "__esModule", {
4
4
  });
5
5
  const _fsextra = /*#__PURE__*/ _interop_require_default(require("fs-extra"));
6
6
  const _path = /*#__PURE__*/ _interop_require_default(require("path"));
7
- const _createproject = require("./create-project");
8
- const _packages = require("./packages");
9
- const _templates = require("./templates");
7
+ const _createproject = require("./create-project.js");
8
+ const _nodeurl = require("node:url");
9
+ const _packages = require("./packages.js");
10
+ const _templates = require("./templates.js");
11
+ const _globby = /*#__PURE__*/ _interop_require_default(require("globby"));
10
12
  function _interop_require_default(obj) {
11
13
  return obj && obj.__esModule ? obj : {
12
14
  default: obj
13
15
  };
14
16
  }
15
- const projectDir = _path.default.resolve(__dirname, './tmp');
17
+ const filename = (0, _nodeurl.fileURLToPath)(require("url").pathToFileURL(__filename).toString());
18
+ const dirname = _path.default.dirname(filename);
19
+ const projectDir = _path.default.resolve(dirname, './tmp');
16
20
  describe('createProject', ()=>{
17
21
  beforeAll(()=>{
18
22
  console.log = jest.fn();
@@ -38,29 +42,10 @@ describe('createProject', ()=>{
38
42
  'project-name'
39
43
  ],
40
44
  '--db': 'mongodb',
45
+ '--local-template': 'blank',
41
46
  '--no-deps': true
42
47
  };
43
48
  const packageManager = 'yarn';
44
- it('creates starter project', async ()=>{
45
- const projectName = 'starter-project';
46
- const template = {
47
- name: 'blank',
48
- type: 'starter',
49
- url: 'https://github.com/payloadcms/payload/templates/blank',
50
- description: 'Blank Template'
51
- };
52
- await (0, _createproject.createProject)({
53
- cliArgs: args,
54
- projectName,
55
- projectDir,
56
- template,
57
- packageManager
58
- });
59
- const packageJsonPath = _path.default.resolve(projectDir, 'package.json');
60
- const packageJson = _fsextra.default.readJsonSync(packageJsonPath);
61
- // Check package name and description
62
- expect(packageJson.name).toEqual(projectName);
63
- });
64
49
  it('creates plugin template', async ()=>{
65
50
  const projectName = 'plugin';
66
51
  const template = {
@@ -81,69 +66,47 @@ describe('createProject', ()=>{
81
66
  // Check package name and description
82
67
  expect(packageJson.name).toEqual(projectName);
83
68
  });
84
- describe('db adapters and bundlers', ()=>{
69
+ describe('creates project from template', ()=>{
85
70
  const templates = (0, _templates.getValidTemplates)();
86
71
  it.each([
87
72
  [
88
- 'blank',
89
- 'mongodb',
90
- 'webpack'
91
- ],
92
- [
93
- 'blank',
94
- 'postgres',
95
- 'webpack'
96
- ],
97
- [
98
- 'website',
99
- 'mongodb',
100
- 'webpack'
73
+ 'blank-3.0',
74
+ 'mongodb'
101
75
  ],
102
76
  [
103
- 'website',
104
- 'postgres',
105
- 'webpack'
106
- ],
107
- [
108
- 'ecommerce',
109
- 'mongodb',
110
- 'webpack'
111
- ],
112
- [
113
- 'ecommerce',
114
- 'postgres',
115
- 'webpack'
77
+ 'blank-3.0',
78
+ 'postgres'
116
79
  ]
117
- ])('update config and deps: %s, %s, %s', async (templateName, db, bundler)=>{
80
+ ])('update config and deps: %s, %s', async (templateName, db)=>{
118
81
  const projectName = 'starter-project';
119
82
  const template = templates.find((t)=>t.name === templateName);
83
+ const cliArgs = {
84
+ ...args,
85
+ '--db': db,
86
+ '--local-template': templateName
87
+ };
120
88
  await (0, _createproject.createProject)({
121
- cliArgs: args,
89
+ cliArgs,
122
90
  projectName,
123
91
  projectDir,
124
- template,
92
+ template: template,
125
93
  packageManager,
126
94
  dbDetails: {
127
95
  dbUri: `${db}://localhost:27017/create-project-test`,
128
96
  type: db
129
97
  }
130
98
  });
131
- const dbReplacement = _packages.dbPackages[db];
132
- const bundlerReplacement = _packages.bundlerPackages[bundler];
133
- const editorReplacement = _packages.editorPackages['slate'];
99
+ const dbReplacement = _packages.dbReplacements[db];
134
100
  const packageJsonPath = _path.default.resolve(projectDir, 'package.json');
135
101
  const packageJson = _fsextra.default.readJsonSync(packageJsonPath);
136
- // Check deps
137
- expect(packageJson.dependencies['payload']).toEqual('^2.0.0');
138
- expect(packageJson.dependencies[dbReplacement.packageName]).toEqual(dbReplacement.version);
139
102
  // Should only have one db adapter
140
103
  expect(Object.keys(packageJson.dependencies).filter((n)=>n.startsWith('@payloadcms/db-'))).toHaveLength(1);
141
- expect(packageJson.dependencies[bundlerReplacement.packageName]).toEqual(bundlerReplacement.version);
142
- expect(packageJson.dependencies[editorReplacement.packageName]).toEqual(editorReplacement.version);
143
- let payloadConfigPath = _path.default.resolve(projectDir, 'src/payload.config.ts');
144
- // Website and ecommerce templates have payload.config.ts in src/payload
145
- if (!_fsextra.default.existsSync(payloadConfigPath)) {
146
- payloadConfigPath = _path.default.resolve(projectDir, 'src/payload/payload.config.ts');
104
+ const payloadConfigPath = (await (0, _globby.default)('**/payload.config.ts', {
105
+ absolute: true,
106
+ cwd: projectDir
107
+ }))?.[0];
108
+ if (!payloadConfigPath) {
109
+ throw new Error(`Could not find payload.config.ts inside ${projectDir}`);
147
110
  }
148
111
  const content = _fsextra.default.readFileSync(payloadConfigPath, 'utf-8');
149
112
  // Check payload.config.ts
@@ -152,17 +115,9 @@ describe('createProject', ()=>{
152
115
  expect(content).not.toContain('// database-adapter-config-start');
153
116
  expect(content).not.toContain('// database-adapter-config-end');
154
117
  expect(content).toContain(dbReplacement.configReplacement.join('\n'));
155
- expect(content).not.toContain('// bundler-config-import');
156
- expect(content).toContain(bundlerReplacement.importReplacement);
157
- expect(content).not.toContain('// bundler-config');
158
- expect(content).toContain(bundlerReplacement.configReplacement);
159
118
  });
160
119
  });
161
120
  });
162
- describe('Templates', ()=>{
163
- it.todo('Verify that all templates are valid');
164
- // Loop through all templates.ts that should have replacement comments, and verify that they are present
165
- });
166
121
  });
167
122
 
168
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/lib/create-project.spec.ts"],"sourcesContent":["import fse from 'fs-extra'\nimport path from 'path'\nimport type { BundlerType, CliArgs, DbType, ProjectTemplate } from '../types'\nimport { createProject } from './create-project'\nimport { bundlerPackages, dbPackages, editorPackages } from './packages'\nimport exp from 'constants'\nimport { getValidTemplates } from './templates'\n\nconst projectDir = path.resolve(__dirname, './tmp')\ndescribe('createProject', () => {\n  beforeAll(() => {\n    console.log = jest.fn()\n  })\n\n  beforeEach(() => {\n    if (fse.existsSync(projectDir)) {\n      fse.rmdirSync(projectDir, { recursive: true })\n    }\n  })\n  afterEach(() => {\n    if (fse.existsSync(projectDir)) {\n      fse.rmSync(projectDir, { recursive: true })\n    }\n  })\n\n  describe('#createProject', () => {\n    // eslint-disable-next-line @typescript-eslint/consistent-type-assertions\n    const args = {\n      _: ['project-name'],\n      '--db': 'mongodb',\n      '--no-deps': true,\n    } as CliArgs\n    const packageManager = 'yarn'\n\n    it('creates starter project', async () => {\n      const projectName = 'starter-project'\n      const template: ProjectTemplate = {\n        name: 'blank',\n        type: 'starter',\n        url: 'https://github.com/payloadcms/payload/templates/blank',\n        description: 'Blank Template',\n      }\n      await createProject({\n        cliArgs: args,\n        projectName,\n        projectDir,\n        template,\n        packageManager,\n      })\n\n      const packageJsonPath = path.resolve(projectDir, 'package.json')\n      const packageJson = fse.readJsonSync(packageJsonPath)\n\n      // Check package name and description\n      expect(packageJson.name).toEqual(projectName)\n    })\n\n    it('creates plugin template', async () => {\n      const projectName = 'plugin'\n      const template: ProjectTemplate = {\n        name: 'plugin',\n        type: 'plugin',\n        url: 'https://github.com/payloadcms/payload-plugin-template',\n        description: 'Template for creating a Payload plugin',\n      }\n      await createProject({\n        cliArgs: args,\n        projectName,\n        projectDir,\n        template,\n        packageManager,\n      })\n\n      const packageJsonPath = path.resolve(projectDir, 'package.json')\n      const packageJson = fse.readJsonSync(packageJsonPath)\n\n      // Check package name and description\n      expect(packageJson.name).toEqual(projectName)\n    })\n\n    describe('db adapters and bundlers', () => {\n      const templates = getValidTemplates()\n\n      it.each([\n        ['blank', 'mongodb', 'webpack'],\n        ['blank', 'postgres', 'webpack'],\n        ['website', 'mongodb', 'webpack'],\n        ['website', 'postgres', 'webpack'],\n        ['ecommerce', 'mongodb', 'webpack'],\n        ['ecommerce', 'postgres', 'webpack'],\n      ])('update config and deps: %s, %s, %s', async (templateName, db, bundler) => {\n        const projectName = 'starter-project'\n\n        const template = templates.find((t) => t.name === templateName)\n\n        await createProject({\n          cliArgs: args,\n          projectName,\n          projectDir,\n          template,\n          packageManager,\n          dbDetails: {\n            dbUri: `${db}://localhost:27017/create-project-test`,\n            type: db as DbType,\n          },\n        })\n\n        const dbReplacement = dbPackages[db as DbType]\n        const bundlerReplacement = bundlerPackages[bundler as BundlerType]\n        const editorReplacement = editorPackages['slate']\n\n        const packageJsonPath = path.resolve(projectDir, 'package.json')\n        const packageJson = fse.readJsonSync(packageJsonPath)\n\n        // Check deps\n        expect(packageJson.dependencies['payload']).toEqual('^2.0.0')\n        expect(packageJson.dependencies[dbReplacement.packageName]).toEqual(dbReplacement.version)\n\n        // Should only have one db adapter\n        expect(\n          Object.keys(packageJson.dependencies).filter((n) => n.startsWith('@payloadcms/db-')),\n        ).toHaveLength(1)\n\n        expect(packageJson.dependencies[bundlerReplacement.packageName]).toEqual(\n          bundlerReplacement.version,\n        )\n        expect(packageJson.dependencies[editorReplacement.packageName]).toEqual(\n          editorReplacement.version,\n        )\n\n        let payloadConfigPath = path.resolve(projectDir, 'src/payload.config.ts')\n\n        // Website and ecommerce templates have payload.config.ts in src/payload\n        if (!fse.existsSync(payloadConfigPath)) {\n          payloadConfigPath = path.resolve(projectDir, 'src/payload/payload.config.ts')\n        }\n        const content = fse.readFileSync(payloadConfigPath, 'utf-8')\n\n        // Check payload.config.ts\n        expect(content).not.toContain('// database-adapter-import')\n        expect(content).toContain(dbReplacement.importReplacement)\n\n        expect(content).not.toContain('// database-adapter-config-start')\n        expect(content).not.toContain('// database-adapter-config-end')\n        expect(content).toContain(dbReplacement.configReplacement.join('\\n'))\n\n        expect(content).not.toContain('// bundler-config-import')\n        expect(content).toContain(bundlerReplacement.importReplacement)\n\n        expect(content).not.toContain('// bundler-config')\n        expect(content).toContain(bundlerReplacement.configReplacement)\n      })\n    })\n  })\n\n  describe('Templates', () => {\n    it.todo('Verify that all templates are valid')\n    // Loop through all templates.ts that should have replacement comments, and verify that they are present\n  })\n})\n"],"names":["projectDir","path","resolve","__dirname","describe","beforeAll","console","log","jest","fn","beforeEach","fse","existsSync","rmdirSync","recursive","afterEach","rmSync","args","_","packageManager","it","projectName","template","name","type","url","description","createProject","cliArgs","packageJsonPath","packageJson","readJsonSync","expect","toEqual","templates","getValidTemplates","each","templateName","db","bundler","find","t","dbDetails","dbUri","dbReplacement","dbPackages","bundlerReplacement","bundlerPackages","editorReplacement","editorPackages","dependencies","packageName","version","Object","keys","filter","n","startsWith","toHaveLength","payloadConfigPath","content","readFileSync","not","toContain","importReplacement","configReplacement","join","todo"],"mappings":";;;;gEAAgB;6DACC;+BAEa;0BAC8B;2BAE1B;;;;;;AAElC,MAAMA,aAAaC,aAAI,CAACC,OAAO,CAACC,WAAW;AAC3CC,SAAS,iBAAiB;IACxBC,UAAU;QACRC,QAAQC,GAAG,GAAGC,KAAKC,EAAE;IACvB;IAEAC,WAAW;QACT,IAAIC,gBAAG,CAACC,UAAU,CAACZ,aAAa;YAC9BW,gBAAG,CAACE,SAAS,CAACb,YAAY;gBAAEc,WAAW;YAAK;QAC9C;IACF;IACAC,UAAU;QACR,IAAIJ,gBAAG,CAACC,UAAU,CAACZ,aAAa;YAC9BW,gBAAG,CAACK,MAAM,CAAChB,YAAY;gBAAEc,WAAW;YAAK;QAC3C;IACF;IAEAV,SAAS,kBAAkB;QACzB,yEAAyE;QACzE,MAAMa,OAAO;YACXC,GAAG;gBAAC;aAAe;YACnB,QAAQ;YACR,aAAa;QACf;QACA,MAAMC,iBAAiB;QAEvBC,GAAG,2BAA2B;YAC5B,MAAMC,cAAc;YACpB,MAAMC,WAA4B;gBAChCC,MAAM;gBACNC,MAAM;gBACNC,KAAK;gBACLC,aAAa;YACf;YACA,MAAMC,IAAAA,4BAAa,EAAC;gBAClBC,SAASX;gBACTI;gBACArB;gBACAsB;gBACAH;YACF;YAEA,MAAMU,kBAAkB5B,aAAI,CAACC,OAAO,CAACF,YAAY;YACjD,MAAM8B,cAAcnB,gBAAG,CAACoB,YAAY,CAACF;YAErC,qCAAqC;YACrCG,OAAOF,YAAYP,IAAI,EAAEU,OAAO,CAACZ;QACnC;QAEAD,GAAG,2BAA2B;YAC5B,MAAMC,cAAc;YACpB,MAAMC,WAA4B;gBAChCC,MAAM;gBACNC,MAAM;gBACNC,KAAK;gBACLC,aAAa;YACf;YACA,MAAMC,IAAAA,4BAAa,EAAC;gBAClBC,SAASX;gBACTI;gBACArB;gBACAsB;gBACAH;YACF;YAEA,MAAMU,kBAAkB5B,aAAI,CAACC,OAAO,CAACF,YAAY;YACjD,MAAM8B,cAAcnB,gBAAG,CAACoB,YAAY,CAACF;YAErC,qCAAqC;YACrCG,OAAOF,YAAYP,IAAI,EAAEU,OAAO,CAACZ;QACnC;QAEAjB,SAAS,4BAA4B;YACnC,MAAM8B,YAAYC,IAAAA,4BAAiB;YAEnCf,GAAGgB,IAAI,CAAC;gBACN;oBAAC;oBAAS;oBAAW;iBAAU;gBAC/B;oBAAC;oBAAS;oBAAY;iBAAU;gBAChC;oBAAC;oBAAW;oBAAW;iBAAU;gBACjC;oBAAC;oBAAW;oBAAY;iBAAU;gBAClC;oBAAC;oBAAa;oBAAW;iBAAU;gBACnC;oBAAC;oBAAa;oBAAY;iBAAU;aACrC,EAAE,sCAAsC,OAAOC,cAAcC,IAAIC;gBAChE,MAAMlB,cAAc;gBAEpB,MAAMC,WAAWY,UAAUM,IAAI,CAAC,CAACC,IAAMA,EAAElB,IAAI,KAAKc;gBAElD,MAAMV,IAAAA,4BAAa,EAAC;oBAClBC,SAASX;oBACTI;oBACArB;oBACAsB;oBACAH;oBACAuB,WAAW;wBACTC,OAAO,CAAC,EAAEL,GAAG,sCAAsC,CAAC;wBACpDd,MAAMc;oBACR;gBACF;gBAEA,MAAMM,gBAAgBC,oBAAU,CAACP,GAAa;gBAC9C,MAAMQ,qBAAqBC,yBAAe,CAACR,QAAuB;gBAClE,MAAMS,oBAAoBC,wBAAc,CAAC,QAAQ;gBAEjD,MAAMpB,kBAAkB5B,aAAI,CAACC,OAAO,CAACF,YAAY;gBACjD,MAAM8B,cAAcnB,gBAAG,CAACoB,YAAY,CAACF;gBAErC,aAAa;gBACbG,OAAOF,YAAYoB,YAAY,CAAC,UAAU,EAAEjB,OAAO,CAAC;gBACpDD,OAAOF,YAAYoB,YAAY,CAACN,cAAcO,WAAW,CAAC,EAAElB,OAAO,CAACW,cAAcQ,OAAO;gBAEzF,kCAAkC;gBAClCpB,OACEqB,OAAOC,IAAI,CAACxB,YAAYoB,YAAY,EAAEK,MAAM,CAAC,CAACC,IAAMA,EAAEC,UAAU,CAAC,qBACjEC,YAAY,CAAC;gBAEf1B,OAAOF,YAAYoB,YAAY,CAACJ,mBAAmBK,WAAW,CAAC,EAAElB,OAAO,CACtEa,mBAAmBM,OAAO;gBAE5BpB,OAAOF,YAAYoB,YAAY,CAACF,kBAAkBG,WAAW,CAAC,EAAElB,OAAO,CACrEe,kBAAkBI,OAAO;gBAG3B,IAAIO,oBAAoB1D,aAAI,CAACC,OAAO,CAACF,YAAY;gBAEjD,wEAAwE;gBACxE,IAAI,CAACW,gBAAG,CAACC,UAAU,CAAC+C,oBAAoB;oBACtCA,oBAAoB1D,aAAI,CAACC,OAAO,CAACF,YAAY;gBAC/C;gBACA,MAAM4D,UAAUjD,gBAAG,CAACkD,YAAY,CAACF,mBAAmB;gBAEpD,0BAA0B;gBAC1B3B,OAAO4B,SAASE,GAAG,CAACC,SAAS,CAAC;gBAC9B/B,OAAO4B,SAASG,SAAS,CAACnB,cAAcoB,iBAAiB;gBAEzDhC,OAAO4B,SAASE,GAAG,CAACC,SAAS,CAAC;gBAC9B/B,OAAO4B,SAASE,GAAG,CAACC,SAAS,CAAC;gBAC9B/B,OAAO4B,SAASG,SAAS,CAACnB,cAAcqB,iBAAiB,CAACC,IAAI,CAAC;gBAE/DlC,OAAO4B,SAASE,GAAG,CAACC,SAAS,CAAC;gBAC9B/B,OAAO4B,SAASG,SAAS,CAACjB,mBAAmBkB,iBAAiB;gBAE9DhC,OAAO4B,SAASE,GAAG,CAACC,SAAS,CAAC;gBAC9B/B,OAAO4B,SAASG,SAAS,CAACjB,mBAAmBmB,iBAAiB;YAChE;QACF;IACF;IAEA7D,SAAS,aAAa;QACpBgB,GAAG+C,IAAI,CAAC;IACR,wGAAwG;IAC1G;AACF"}
123
+ //# sourceMappingURL=create-project.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/lib/create-project.spec.ts"],"sourcesContent":["import fse from 'fs-extra'\nimport path from 'path'\nimport type { CliArgs, DbType, ProjectTemplate } from '../types.js'\nimport { createProject } from './create-project.js'\nimport { fileURLToPath } from 'node:url'\nimport { dbReplacements } from './packages.js'\nimport { getValidTemplates } from './templates.js'\nimport globby from 'globby'\n\nconst filename = fileURLToPath(import.meta.url)\nconst dirname = path.dirname(filename)\n\nconst projectDir = path.resolve(dirname, './tmp')\ndescribe('createProject', () => {\n beforeAll(() => {\n console.log = jest.fn()\n })\n\n beforeEach(() => {\n if (fse.existsSync(projectDir)) {\n fse.rmdirSync(projectDir, { recursive: true })\n }\n })\n afterEach(() => {\n if (fse.existsSync(projectDir)) {\n fse.rmSync(projectDir, { recursive: true })\n }\n })\n\n describe('#createProject', () => {\n // eslint-disable-next-line @typescript-eslint/consistent-type-assertions\n const args = {\n _: ['project-name'],\n '--db': 'mongodb',\n '--local-template': 'blank',\n '--no-deps': true,\n } as CliArgs\n const packageManager = 'yarn'\n\n it('creates plugin template', async () => {\n const projectName = 'plugin'\n const template: ProjectTemplate = {\n name: 'plugin',\n type: 'plugin',\n url: 'https://github.com/payloadcms/payload-plugin-template',\n description: 'Template for creating a Payload plugin',\n }\n await createProject({\n cliArgs: args,\n projectName,\n projectDir,\n template,\n packageManager,\n })\n\n const packageJsonPath = path.resolve(projectDir, 'package.json')\n const packageJson = fse.readJsonSync(packageJsonPath)\n\n // Check package name and description\n expect(packageJson.name).toEqual(projectName)\n })\n\n describe('creates project from template', () => {\n const templates = getValidTemplates()\n\n it.each([\n ['blank-3.0', 'mongodb'],\n ['blank-3.0', 'postgres'],\n\n // TODO: Re-enable these once 3.0 is stable and templates updated\n // ['website', 'mongodb'],\n // ['website', 'postgres'],\n // ['ecommerce', 'mongodb'],\n // ['ecommerce', 'postgres'],\n ])('update config and deps: %s, %s', async (templateName, db) => {\n const projectName = 'starter-project'\n\n const template = templates.find((t) => t.name === templateName)\n\n const cliArgs = {\n ...args,\n '--db': db,\n '--local-template': templateName,\n } as CliArgs\n\n await createProject({\n cliArgs,\n projectName,\n projectDir,\n template: template as ProjectTemplate,\n packageManager,\n dbDetails: {\n dbUri: `${db}://localhost:27017/create-project-test`,\n type: db as DbType,\n },\n })\n\n const dbReplacement = dbReplacements[db as DbType]\n\n const packageJsonPath = path.resolve(projectDir, 'package.json')\n const packageJson = fse.readJsonSync(packageJsonPath)\n\n // Should only have one db adapter\n expect(\n Object.keys(packageJson.dependencies).filter((n) => n.startsWith('@payloadcms/db-')),\n ).toHaveLength(1)\n\n const payloadConfigPath = (\n await globby('**/payload.config.ts', {\n absolute: true,\n cwd: projectDir,\n })\n )?.[0]\n\n if (!payloadConfigPath) {\n throw new Error(`Could not find payload.config.ts inside ${projectDir}`)\n }\n\n const content = fse.readFileSync(payloadConfigPath, 'utf-8')\n\n // Check payload.config.ts\n expect(content).not.toContain('// database-adapter-import')\n expect(content).toContain(dbReplacement.importReplacement)\n\n expect(content).not.toContain('// database-adapter-config-start')\n expect(content).not.toContain('// database-adapter-config-end')\n expect(content).toContain(dbReplacement.configReplacement.join('\\n'))\n })\n })\n })\n})\n"],"names":["filename","fileURLToPath","dirname","path","projectDir","resolve","describe","beforeAll","console","log","jest","fn","beforeEach","fse","existsSync","rmdirSync","recursive","afterEach","rmSync","args","_","packageManager","it","projectName","template","name","type","url","description","createProject","cliArgs","packageJsonPath","packageJson","readJsonSync","expect","toEqual","templates","getValidTemplates","each","templateName","db","find","t","dbDetails","dbUri","dbReplacement","dbReplacements","Object","keys","dependencies","filter","n","startsWith","toHaveLength","payloadConfigPath","globby","absolute","cwd","Error","content","readFileSync","not","toContain","importReplacement","configReplacement","join"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function generateSecret(): string;
2
+ //# sourceMappingURL=generate-secret.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-secret.d.ts","sourceRoot":"","sources":["../../src/lib/generate-secret.ts"],"names":[],"mappings":"AAEA,wBAAgB,cAAc,IAAI,MAAM,CAEvC"}