@veloxts/cli 0.4.2 → 0.4.4

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.
Files changed (87) hide show
  1. package/dist/cli.js +4 -0
  2. package/dist/cli.js.map +1 -1
  3. package/dist/commands/db.d.ts +12 -0
  4. package/dist/commands/db.d.ts.map +1 -0
  5. package/dist/commands/db.js +18 -0
  6. package/dist/commands/db.js.map +1 -0
  7. package/dist/commands/dev.d.ts.map +1 -1
  8. package/dist/commands/dev.js +29 -3
  9. package/dist/commands/dev.js.map +1 -1
  10. package/dist/commands/procedures.d.ts +12 -0
  11. package/dist/commands/procedures.d.ts.map +1 -0
  12. package/dist/commands/procedures.js +153 -0
  13. package/dist/commands/procedures.js.map +1 -0
  14. package/dist/dev/hmr-runner.d.ts +52 -0
  15. package/dist/dev/hmr-runner.d.ts.map +1 -0
  16. package/dist/dev/hmr-runner.js +153 -0
  17. package/dist/dev/hmr-runner.js.map +1 -0
  18. package/dist/dev/index.d.ts +6 -0
  19. package/dist/dev/index.d.ts.map +1 -0
  20. package/dist/dev/index.js +6 -0
  21. package/dist/dev/index.js.map +1 -0
  22. package/dist/dev/watch-config.d.ts +32 -0
  23. package/dist/dev/watch-config.d.ts.map +1 -0
  24. package/dist/dev/watch-config.js +74 -0
  25. package/dist/dev/watch-config.js.map +1 -0
  26. package/dist/generators/generators/factory.d.ts +36 -0
  27. package/dist/generators/generators/factory.d.ts.map +1 -0
  28. package/dist/generators/generators/factory.js +85 -0
  29. package/dist/generators/generators/factory.js.map +1 -0
  30. package/dist/generators/generators/index.d.ts +2 -0
  31. package/dist/generators/generators/index.d.ts.map +1 -1
  32. package/dist/generators/generators/index.js +8 -0
  33. package/dist/generators/generators/index.js.map +1 -1
  34. package/dist/generators/generators/seeder.d.ts +36 -0
  35. package/dist/generators/generators/seeder.d.ts.map +1 -0
  36. package/dist/generators/generators/seeder.js +99 -0
  37. package/dist/generators/generators/seeder.js.map +1 -0
  38. package/dist/generators/templates/factory.d.ts +26 -0
  39. package/dist/generators/templates/factory.d.ts.map +1 -0
  40. package/dist/generators/templates/factory.js +125 -0
  41. package/dist/generators/templates/factory.js.map +1 -0
  42. package/dist/generators/templates/seeder.d.ts +34 -0
  43. package/dist/generators/templates/seeder.d.ts.map +1 -0
  44. package/dist/generators/templates/seeder.js +129 -0
  45. package/dist/generators/templates/seeder.js.map +1 -0
  46. package/dist/index.d.ts +5 -0
  47. package/dist/index.d.ts.map +1 -1
  48. package/dist/index.js +5 -0
  49. package/dist/index.js.map +1 -1
  50. package/dist/seeding/commands/seed.d.ts +11 -0
  51. package/dist/seeding/commands/seed.d.ts.map +1 -0
  52. package/dist/seeding/commands/seed.js +268 -0
  53. package/dist/seeding/commands/seed.js.map +1 -0
  54. package/dist/seeding/errors.d.ts +119 -0
  55. package/dist/seeding/errors.d.ts.map +1 -0
  56. package/dist/seeding/errors.js +191 -0
  57. package/dist/seeding/errors.js.map +1 -0
  58. package/dist/seeding/factory.d.ts +162 -0
  59. package/dist/seeding/factory.d.ts.map +1 -0
  60. package/dist/seeding/factory.js +250 -0
  61. package/dist/seeding/factory.js.map +1 -0
  62. package/dist/seeding/index.d.ts +31 -0
  63. package/dist/seeding/index.d.ts.map +1 -0
  64. package/dist/seeding/index.js +41 -0
  65. package/dist/seeding/index.js.map +1 -0
  66. package/dist/seeding/loader.d.ts +41 -0
  67. package/dist/seeding/loader.d.ts.map +1 -0
  68. package/dist/seeding/loader.js +210 -0
  69. package/dist/seeding/loader.js.map +1 -0
  70. package/dist/seeding/registry.d.ts +116 -0
  71. package/dist/seeding/registry.d.ts.map +1 -0
  72. package/dist/seeding/registry.js +298 -0
  73. package/dist/seeding/registry.js.map +1 -0
  74. package/dist/seeding/runner.d.ts +88 -0
  75. package/dist/seeding/runner.d.ts.map +1 -0
  76. package/dist/seeding/runner.js +254 -0
  77. package/dist/seeding/runner.js.map +1 -0
  78. package/dist/seeding/types.d.ts +247 -0
  79. package/dist/seeding/types.d.ts.map +1 -0
  80. package/dist/seeding/types.js +7 -0
  81. package/dist/seeding/types.js.map +1 -0
  82. package/dist/utils/output.d.ts +12 -0
  83. package/dist/utils/output.d.ts.map +1 -1
  84. package/dist/utils/output.js +21 -0
  85. package/dist/utils/output.js.map +1 -1
  86. package/package.json +18 -17
  87. package/LICENSE +0 -21
@@ -0,0 +1,74 @@
1
+ /**
2
+ * Watch Configuration for Development Server
3
+ *
4
+ * Defines file patterns to ignore during development to prevent
5
+ * unnecessary restarts and improve developer experience.
6
+ */
7
+ /**
8
+ * Default patterns to ignore when watching for file changes.
9
+ * These patterns match files that should not trigger a restart.
10
+ */
11
+ export const DEFAULT_WATCH_IGNORE = [
12
+ // Dependencies
13
+ '**/node_modules/**',
14
+ // Test files
15
+ '**/*.test.ts',
16
+ '**/*.test.tsx',
17
+ '**/*.spec.ts',
18
+ '**/*.spec.tsx',
19
+ '**/__tests__/**',
20
+ '**/__mocks__/**',
21
+ // Type declarations (don't affect runtime)
22
+ '**/*.d.ts',
23
+ // Build artifacts
24
+ '**/dist/**',
25
+ '**/build/**',
26
+ '**/*.tsbuildinfo',
27
+ // Coverage and reports
28
+ '**/coverage/**',
29
+ // Version control
30
+ '**/.git/**',
31
+ // Generated files (e.g., Prisma client)
32
+ '**/generated/**',
33
+ // Documentation
34
+ '**/*.md',
35
+ '**/docs/**',
36
+ // Config files that don't affect runtime
37
+ '**/tsconfig*.json',
38
+ '**/biome.json',
39
+ '**/.eslintrc*',
40
+ '**/.prettierrc*',
41
+ ];
42
+ /**
43
+ * Build command line arguments for tsx watch
44
+ */
45
+ export function buildWatchArgs(options) {
46
+ const args = ['tsx', 'watch'];
47
+ // Add clear screen option
48
+ if (options.clearScreen) {
49
+ args.push('--clear-screen=true');
50
+ }
51
+ // Add ignore patterns
52
+ const ignorePatterns = options.ignore ?? DEFAULT_WATCH_IGNORE;
53
+ for (const pattern of ignorePatterns) {
54
+ args.push('--ignore', pattern);
55
+ }
56
+ // Add entry point
57
+ args.push(options.entry);
58
+ return args;
59
+ }
60
+ /**
61
+ * Get the essential ignore patterns (minimal set for fastest filtering)
62
+ * Used when full ignore list causes performance issues
63
+ */
64
+ export function getEssentialIgnorePatterns() {
65
+ return [
66
+ '**/node_modules/**',
67
+ '**/*.test.ts',
68
+ '**/*.spec.ts',
69
+ '**/*.d.ts',
70
+ '**/dist/**',
71
+ '**/__tests__/**',
72
+ ];
73
+ }
74
+ //# sourceMappingURL=watch-config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"watch-config.js","sourceRoot":"","sources":["../../src/dev/watch-config.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH;;;GAGG;AACH,MAAM,CAAC,MAAM,oBAAoB,GAAsB;IACrD,eAAe;IACf,oBAAoB;IAEpB,aAAa;IACb,cAAc;IACd,eAAe;IACf,cAAc;IACd,eAAe;IACf,iBAAiB;IACjB,iBAAiB;IAEjB,2CAA2C;IAC3C,WAAW;IAEX,kBAAkB;IAClB,YAAY;IACZ,aAAa;IACb,kBAAkB;IAElB,uBAAuB;IACvB,gBAAgB;IAEhB,kBAAkB;IAClB,YAAY;IAEZ,wCAAwC;IACxC,iBAAiB;IAEjB,gBAAgB;IAChB,SAAS;IACT,YAAY;IAEZ,yCAAyC;IACzC,mBAAmB;IACnB,eAAe;IACf,eAAe;IACf,iBAAiB;CAClB,CAAC;AAcF;;GAEG;AACH,MAAM,UAAU,cAAc,CAAC,OAAqB;IAClD,MAAM,IAAI,GAAG,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;IAE9B,0BAA0B;IAC1B,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;IACnC,CAAC;IAED,sBAAsB;IACtB,MAAM,cAAc,GAAG,OAAO,CAAC,MAAM,IAAI,oBAAoB,CAAC;IAC9D,KAAK,MAAM,OAAO,IAAI,cAAc,EAAE,CAAC;QACrC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;IACjC,CAAC;IAED,kBAAkB;IAClB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IAEzB,OAAO,IAAI,CAAC;AACd,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,0BAA0B;IACxC,OAAO;QACL,oBAAoB;QACpB,cAAc;QACd,cAAc;QACd,WAAW;QACX,YAAY;QACZ,iBAAiB;KAClB,CAAC;AACJ,CAAC"}
@@ -0,0 +1,36 @@
1
+ /**
2
+ * Factory Generator
3
+ *
4
+ * Generates factory files for VeloxTS applications.
5
+ *
6
+ * Usage:
7
+ * velox generate factory <name> [options]
8
+ * velox g f <name> [options]
9
+ *
10
+ * Examples:
11
+ * velox generate factory user # Creates UserFactory
12
+ * velox g f post # Creates PostFactory
13
+ */
14
+ import { BaseGenerator } from '../base.js';
15
+ import { type FactoryOptions } from '../templates/factory.js';
16
+ import type { GeneratorConfig, GeneratorMetadata, GeneratorOption, GeneratorOutput } from '../types.js';
17
+ /**
18
+ * Factory generator - creates factory files for generating fake data
19
+ */
20
+ export declare class FactoryGenerator extends BaseGenerator<FactoryOptions> {
21
+ readonly metadata: GeneratorMetadata;
22
+ readonly options: ReadonlyArray<GeneratorOption>;
23
+ /**
24
+ * Validate and transform raw options
25
+ */
26
+ validateOptions(raw: Record<string, unknown>): FactoryOptions;
27
+ /**
28
+ * Generate factory files
29
+ */
30
+ generate(config: GeneratorConfig<FactoryOptions>): Promise<GeneratorOutput>;
31
+ }
32
+ /**
33
+ * Create a new factory generator instance
34
+ */
35
+ export declare function createFactoryGenerator(): FactoryGenerator;
36
+ //# sourceMappingURL=factory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../../src/generators/generators/factory.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,EACL,KAAK,cAAc,EAIpB,MAAM,yBAAyB,CAAC;AACjC,OAAO,KAAK,EAEV,eAAe,EACf,iBAAiB,EACjB,eAAe,EACf,eAAe,EAChB,MAAM,aAAa,CAAC;AAMrB;;GAEG;AACH,qBAAa,gBAAiB,SAAQ,aAAa,CAAC,cAAc,CAAC;IACjE,QAAQ,CAAC,QAAQ,EAAE,iBAAiB,CAgBlC;IAEF,QAAQ,CAAC,OAAO,EAAE,aAAa,CAAC,eAAe,CAAC,CAO9C;IAEF;;OAEG;IACH,eAAe,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,cAAc;IAM7D;;OAEG;IACG,QAAQ,CAAC,MAAM,EAAE,eAAe,CAAC,cAAc,CAAC,GAAG,OAAO,CAAC,eAAe,CAAC;CAoBlF;AAMD;;GAEG;AACH,wBAAgB,sBAAsB,IAAI,gBAAgB,CAEzD"}
@@ -0,0 +1,85 @@
1
+ /**
2
+ * Factory Generator
3
+ *
4
+ * Generates factory files for VeloxTS applications.
5
+ *
6
+ * Usage:
7
+ * velox generate factory <name> [options]
8
+ * velox g f <name> [options]
9
+ *
10
+ * Examples:
11
+ * velox generate factory user # Creates UserFactory
12
+ * velox g f post # Creates PostFactory
13
+ */
14
+ import { BaseGenerator } from '../base.js';
15
+ import { factoryTemplate, getFactoryInstructions, getFactoryPath, } from '../templates/factory.js';
16
+ // ============================================================================
17
+ // Generator Implementation
18
+ // ============================================================================
19
+ /**
20
+ * Factory generator - creates factory files for generating fake data
21
+ */
22
+ export class FactoryGenerator extends BaseGenerator {
23
+ metadata = {
24
+ name: 'factory',
25
+ description: 'Generate a model factory for fake data generation',
26
+ longDescription: `
27
+ Generate a VeloxTS factory file for creating model instances with fake data.
28
+
29
+ Factories are stored in src/database/factories/ and extend BaseFactory.
30
+ They use @faker-js/faker to generate realistic test data and support
31
+ named states for common variations (e.g., admin, verified).
32
+
33
+ Examples:
34
+ velox generate factory user # Creates UserFactory.ts
35
+ velox g f post # Creates PostFactory.ts
36
+ `,
37
+ aliases: ['f', 'fac'],
38
+ category: 'database',
39
+ };
40
+ options = [
41
+ {
42
+ name: 'model',
43
+ short: 'm',
44
+ description: 'Path to model file for type inference (optional)',
45
+ type: 'string',
46
+ },
47
+ ];
48
+ /**
49
+ * Validate and transform raw options
50
+ */
51
+ validateOptions(raw) {
52
+ return {
53
+ model: raw.model,
54
+ };
55
+ }
56
+ /**
57
+ * Generate factory files
58
+ */
59
+ async generate(config) {
60
+ const context = this.createContext(config);
61
+ const { entity } = context;
62
+ // Generate factory file
63
+ const content = factoryTemplate(context);
64
+ const file = {
65
+ path: getFactoryPath(entity.pascal),
66
+ content,
67
+ };
68
+ // Generate post-creation instructions
69
+ const postInstructions = getFactoryInstructions(entity.pascal);
70
+ return {
71
+ files: [file],
72
+ postInstructions,
73
+ };
74
+ }
75
+ }
76
+ // ============================================================================
77
+ // Export
78
+ // ============================================================================
79
+ /**
80
+ * Create a new factory generator instance
81
+ */
82
+ export function createFactoryGenerator() {
83
+ return new FactoryGenerator();
84
+ }
85
+ //# sourceMappingURL=factory.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"factory.js","sourceRoot":"","sources":["../../../src/generators/generators/factory.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,EAEL,eAAe,EACf,sBAAsB,EACtB,cAAc,GACf,MAAM,yBAAyB,CAAC;AASjC,+EAA+E;AAC/E,2BAA2B;AAC3B,+EAA+E;AAE/E;;GAEG;AACH,MAAM,OAAO,gBAAiB,SAAQ,aAA6B;IACxD,QAAQ,GAAsB;QACrC,IAAI,EAAE,SAAS;QACf,WAAW,EAAE,mDAAmD;QAChE,eAAe,EAAE;;;;;;;;;;CAUpB;QACG,OAAO,EAAE,CAAC,GAAG,EAAE,KAAK,CAAC;QACrB,QAAQ,EAAE,UAAU;KACrB,CAAC;IAEO,OAAO,GAAmC;QACjD;YACE,IAAI,EAAE,OAAO;YACb,KAAK,EAAE,GAAG;YACV,WAAW,EAAE,kDAAkD;YAC/D,IAAI,EAAE,QAAQ;SACf;KACF,CAAC;IAEF;;OAEG;IACH,eAAe,CAAC,GAA4B;QAC1C,OAAO;YACL,KAAK,EAAE,GAAG,CAAC,KAA2B;SACvC,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,QAAQ,CAAC,MAAuC;QACpD,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAC3C,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC;QAE3B,wBAAwB;QACxB,MAAM,OAAO,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC;QAEzC,MAAM,IAAI,GAAkB;YAC1B,IAAI,EAAE,cAAc,CAAC,MAAM,CAAC,MAAM,CAAC;YACnC,OAAO;SACR,CAAC;QAEF,sCAAsC;QACtC,MAAM,gBAAgB,GAAG,sBAAsB,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAE/D,OAAO;YACL,KAAK,EAAE,CAAC,IAAI,CAAC;YACb,gBAAgB;SACjB,CAAC;IACJ,CAAC;CACF;AAED,+EAA+E;AAC/E,SAAS;AACT,+EAA+E;AAE/E;;GAEG;AACH,MAAM,UAAU,sBAAsB;IACpC,OAAO,IAAI,gBAAgB,EAAE,CAAC;AAChC,CAAC"}
@@ -3,11 +3,13 @@
3
3
  *
4
4
  * Re-exports all built-in generators and provides auto-registration.
5
5
  */
6
+ export { createFactoryGenerator, FactoryGenerator } from './factory.js';
6
7
  export { createMigrationGenerator, MigrationGenerator } from './migration.js';
7
8
  export { createModelGenerator, ModelGenerator } from './model.js';
8
9
  export { createProcedureGenerator, ProcedureGenerator } from './procedure.js';
9
10
  export { createResourceGenerator, ResourceGenerator } from './resource.js';
10
11
  export { createSchemaGenerator, SchemaGenerator } from './schema.js';
12
+ export { createSeederGenerator, SeederGenerator } from './seeder.js';
11
13
  export { createTestGenerator, TestGenerator } from './test.js';
12
14
  /**
13
15
  * Register all built-in generators with the global registry.
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/generators/generators/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAcH,OAAO,EAAE,wBAAwB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAC9E,OAAO,EAAE,oBAAoB,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAClE,OAAO,EAAE,wBAAwB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAC9E,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAC3E,OAAO,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AACrE,OAAO,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAM/D;;;GAGG;AACH,wBAAgB,yBAAyB,IAAI,IAAI,CAkBhD"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/generators/generators/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAgBH,OAAO,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AACxE,OAAO,EAAE,wBAAwB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAC9E,OAAO,EAAE,oBAAoB,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAClE,OAAO,EAAE,wBAAwB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAC9E,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAC3E,OAAO,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AACrE,OAAO,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AACrE,OAAO,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAM/D;;;GAGG;AACH,wBAAgB,yBAAyB,IAAI,IAAI,CAwBhD"}
@@ -4,20 +4,24 @@
4
4
  * Re-exports all built-in generators and provides auto-registration.
5
5
  */
6
6
  import { registerGenerator } from '../registry.js';
7
+ import { createFactoryGenerator } from './factory.js';
7
8
  import { createMigrationGenerator } from './migration.js';
8
9
  import { createModelGenerator } from './model.js';
9
10
  import { createProcedureGenerator } from './procedure.js';
10
11
  import { createResourceGenerator } from './resource.js';
11
12
  import { createSchemaGenerator } from './schema.js';
13
+ import { createSeederGenerator } from './seeder.js';
12
14
  import { createTestGenerator } from './test.js';
13
15
  // ============================================================================
14
16
  // Generator Exports
15
17
  // ============================================================================
18
+ export { createFactoryGenerator, FactoryGenerator } from './factory.js';
16
19
  export { createMigrationGenerator, MigrationGenerator } from './migration.js';
17
20
  export { createModelGenerator, ModelGenerator } from './model.js';
18
21
  export { createProcedureGenerator, ProcedureGenerator } from './procedure.js';
19
22
  export { createResourceGenerator, ResourceGenerator } from './resource.js';
20
23
  export { createSchemaGenerator, SchemaGenerator } from './schema.js';
24
+ export { createSeederGenerator, SeederGenerator } from './seeder.js';
21
25
  export { createTestGenerator, TestGenerator } from './test.js';
22
26
  // ============================================================================
23
27
  // Auto-Registration
@@ -39,5 +43,9 @@ export function registerBuiltinGenerators() {
39
43
  registerGenerator(createTestGenerator());
40
44
  // Register resource generator (full stack)
41
45
  registerGenerator(createResourceGenerator());
46
+ // Register seeder generator
47
+ registerGenerator(createSeederGenerator());
48
+ // Register factory generator
49
+ registerGenerator(createFactoryGenerator());
42
50
  }
43
51
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/generators/generators/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,wBAAwB,EAAE,MAAM,gBAAgB,CAAC;AAC1D,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAClD,OAAO,EAAE,wBAAwB,EAAE,MAAM,gBAAgB,CAAC;AAC1D,OAAO,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AACxD,OAAO,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AACpD,OAAO,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC;AAEhD,+EAA+E;AAC/E,oBAAoB;AACpB,+EAA+E;AAE/E,OAAO,EAAE,wBAAwB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAC9E,OAAO,EAAE,oBAAoB,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAClE,OAAO,EAAE,wBAAwB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAC9E,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAC3E,OAAO,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AACrE,OAAO,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAE/D,+EAA+E;AAC/E,oBAAoB;AACpB,+EAA+E;AAE/E;;;GAGG;AACH,MAAM,UAAU,yBAAyB;IACvC,+BAA+B;IAC/B,iBAAiB,CAAC,wBAAwB,EAAE,CAAC,CAAC;IAE9C,2BAA2B;IAC3B,iBAAiB,CAAC,oBAAoB,EAAE,CAAC,CAAC;IAE1C,+BAA+B;IAC/B,iBAAiB,CAAC,wBAAwB,EAAE,CAAC,CAAC;IAE9C,4BAA4B;IAC5B,iBAAiB,CAAC,qBAAqB,EAAE,CAAC,CAAC;IAE3C,0BAA0B;IAC1B,iBAAiB,CAAC,mBAAmB,EAAE,CAAC,CAAC;IAEzC,2CAA2C;IAC3C,iBAAiB,CAAC,uBAAuB,EAAE,CAAC,CAAC;AAC/C,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/generators/generators/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,sBAAsB,EAAE,MAAM,cAAc,CAAC;AACtD,OAAO,EAAE,wBAAwB,EAAE,MAAM,gBAAgB,CAAC;AAC1D,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAClD,OAAO,EAAE,wBAAwB,EAAE,MAAM,gBAAgB,CAAC;AAC1D,OAAO,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AACxD,OAAO,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AACpD,OAAO,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AACpD,OAAO,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC;AAEhD,+EAA+E;AAC/E,oBAAoB;AACpB,+EAA+E;AAE/E,OAAO,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AACxE,OAAO,EAAE,wBAAwB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAC9E,OAAO,EAAE,oBAAoB,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAClE,OAAO,EAAE,wBAAwB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAC9E,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAC3E,OAAO,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AACrE,OAAO,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AACrE,OAAO,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAE/D,+EAA+E;AAC/E,oBAAoB;AACpB,+EAA+E;AAE/E;;;GAGG;AACH,MAAM,UAAU,yBAAyB;IACvC,+BAA+B;IAC/B,iBAAiB,CAAC,wBAAwB,EAAE,CAAC,CAAC;IAE9C,2BAA2B;IAC3B,iBAAiB,CAAC,oBAAoB,EAAE,CAAC,CAAC;IAE1C,+BAA+B;IAC/B,iBAAiB,CAAC,wBAAwB,EAAE,CAAC,CAAC;IAE9C,4BAA4B;IAC5B,iBAAiB,CAAC,qBAAqB,EAAE,CAAC,CAAC;IAE3C,0BAA0B;IAC1B,iBAAiB,CAAC,mBAAmB,EAAE,CAAC,CAAC;IAEzC,2CAA2C;IAC3C,iBAAiB,CAAC,uBAAuB,EAAE,CAAC,CAAC;IAE7C,4BAA4B;IAC5B,iBAAiB,CAAC,qBAAqB,EAAE,CAAC,CAAC;IAE3C,6BAA6B;IAC7B,iBAAiB,CAAC,sBAAsB,EAAE,CAAC,CAAC;AAC9C,CAAC"}
@@ -0,0 +1,36 @@
1
+ /**
2
+ * Seeder Generator
3
+ *
4
+ * Generates seeder files for VeloxTS applications.
5
+ *
6
+ * Usage:
7
+ * velox generate seeder <name> [options]
8
+ * velox g s <name> [options]
9
+ *
10
+ * Examples:
11
+ * velox generate seeder user # Creates UserSeeder
12
+ * velox generate seeder post --factory # Also creates PostFactory
13
+ */
14
+ import { BaseGenerator } from '../base.js';
15
+ import { type SeederOptions } from '../templates/seeder.js';
16
+ import type { GeneratorConfig, GeneratorMetadata, GeneratorOption, GeneratorOutput } from '../types.js';
17
+ /**
18
+ * Seeder generator - creates seeder files for database seeding
19
+ */
20
+ export declare class SeederGenerator extends BaseGenerator<SeederOptions> {
21
+ readonly metadata: GeneratorMetadata;
22
+ readonly options: ReadonlyArray<GeneratorOption>;
23
+ /**
24
+ * Validate and transform raw options
25
+ */
26
+ validateOptions(raw: Record<string, unknown>): SeederOptions;
27
+ /**
28
+ * Generate seeder files
29
+ */
30
+ generate(config: GeneratorConfig<SeederOptions>): Promise<GeneratorOutput>;
31
+ }
32
+ /**
33
+ * Create a new seeder generator instance
34
+ */
35
+ export declare function createSeederGenerator(): SeederGenerator;
36
+ //# sourceMappingURL=seeder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"seeder.d.ts","sourceRoot":"","sources":["../../../src/generators/generators/seeder.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAE3C,OAAO,EAGL,KAAK,aAAa,EAEnB,MAAM,wBAAwB,CAAC;AAChC,OAAO,KAAK,EAEV,eAAe,EACf,iBAAiB,EACjB,eAAe,EACf,eAAe,EAChB,MAAM,aAAa,CAAC;AAMrB;;GAEG;AACH,qBAAa,eAAgB,SAAQ,aAAa,CAAC,aAAa,CAAC;IAC/D,QAAQ,CAAC,QAAQ,EAAE,iBAAiB,CAelC;IAEF,QAAQ,CAAC,OAAO,EAAE,aAAa,CAAC,eAAe,CAAC,CAQ9C;IAEF;;OAEG;IACH,eAAe,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,aAAa;IAM5D;;OAEG;IACG,QAAQ,CAAC,MAAM,EAAE,eAAe,CAAC,aAAa,CAAC,GAAG,OAAO,CAAC,eAAe,CAAC;CAiCjF;AAMD;;GAEG;AACH,wBAAgB,qBAAqB,IAAI,eAAe,CAEvD"}
@@ -0,0 +1,99 @@
1
+ /**
2
+ * Seeder Generator
3
+ *
4
+ * Generates seeder files for VeloxTS applications.
5
+ *
6
+ * Usage:
7
+ * velox generate seeder <name> [options]
8
+ * velox g s <name> [options]
9
+ *
10
+ * Examples:
11
+ * velox generate seeder user # Creates UserSeeder
12
+ * velox generate seeder post --factory # Also creates PostFactory
13
+ */
14
+ import { BaseGenerator } from '../base.js';
15
+ import { factoryTemplate, getFactoryPath } from '../templates/factory.js';
16
+ import { getSeederInstructions, getSeederPath, seederTemplate, } from '../templates/seeder.js';
17
+ // ============================================================================
18
+ // Generator Implementation
19
+ // ============================================================================
20
+ /**
21
+ * Seeder generator - creates seeder files for database seeding
22
+ */
23
+ export class SeederGenerator extends BaseGenerator {
24
+ metadata = {
25
+ name: 'seeder',
26
+ description: 'Generate a database seeder file',
27
+ longDescription: `
28
+ Generate a VeloxTS seeder file for populating the database with initial or test data.
29
+
30
+ Seeders are stored in src/database/seeders/ and implement the Seeder interface.
31
+ They can have dependencies on other seeders and are executed in the correct order.
32
+
33
+ Examples:
34
+ velox generate seeder user # Creates UserSeeder.ts
35
+ velox generate seeder post --factory # Creates PostSeeder.ts and PostFactory.ts
36
+ `,
37
+ aliases: ['s', 'seed'],
38
+ category: 'database',
39
+ };
40
+ options = [
41
+ {
42
+ name: 'factory',
43
+ short: 'f',
44
+ description: 'Also generate a factory for this model',
45
+ type: 'boolean',
46
+ default: false,
47
+ },
48
+ ];
49
+ /**
50
+ * Validate and transform raw options
51
+ */
52
+ validateOptions(raw) {
53
+ return {
54
+ factory: Boolean(raw.factory ?? false),
55
+ };
56
+ }
57
+ /**
58
+ * Generate seeder files
59
+ */
60
+ async generate(config) {
61
+ const context = this.createContext(config);
62
+ const { entity, options } = context;
63
+ const files = [];
64
+ // Generate seeder file
65
+ const seederContent = seederTemplate(context);
66
+ files.push({
67
+ path: getSeederPath(entity.pascal),
68
+ content: seederContent,
69
+ });
70
+ // Generate factory if requested
71
+ if (options.factory) {
72
+ const factoryContent = factoryTemplate({
73
+ entity: context.entity,
74
+ project: context.project,
75
+ options: {},
76
+ });
77
+ files.push({
78
+ path: getFactoryPath(entity.pascal),
79
+ content: factoryContent,
80
+ });
81
+ }
82
+ // Generate post-creation instructions
83
+ const postInstructions = getSeederInstructions(entity.pascal, Boolean(options.factory));
84
+ return {
85
+ files,
86
+ postInstructions,
87
+ };
88
+ }
89
+ }
90
+ // ============================================================================
91
+ // Export
92
+ // ============================================================================
93
+ /**
94
+ * Create a new seeder generator instance
95
+ */
96
+ export function createSeederGenerator() {
97
+ return new SeederGenerator();
98
+ }
99
+ //# sourceMappingURL=seeder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"seeder.js","sourceRoot":"","sources":["../../../src/generators/generators/seeder.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAC1E,OAAO,EACL,qBAAqB,EACrB,aAAa,EAEb,cAAc,GACf,MAAM,wBAAwB,CAAC;AAShC,+EAA+E;AAC/E,2BAA2B;AAC3B,+EAA+E;AAE/E;;GAEG;AACH,MAAM,OAAO,eAAgB,SAAQ,aAA4B;IACtD,QAAQ,GAAsB;QACrC,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,iCAAiC;QAC9C,eAAe,EAAE;;;;;;;;;CASpB;QACG,OAAO,EAAE,CAAC,GAAG,EAAE,MAAM,CAAC;QACtB,QAAQ,EAAE,UAAU;KACrB,CAAC;IAEO,OAAO,GAAmC;QACjD;YACE,IAAI,EAAE,SAAS;YACf,KAAK,EAAE,GAAG;YACV,WAAW,EAAE,wCAAwC;YACrD,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,KAAK;SACf;KACF,CAAC;IAEF;;OAEG;IACH,eAAe,CAAC,GAA4B;QAC1C,OAAO;YACL,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,OAAO,IAAI,KAAK,CAAC;SACvC,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,QAAQ,CAAC,MAAsC;QACnD,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAC3C,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;QACpC,MAAM,KAAK,GAAoB,EAAE,CAAC;QAElC,uBAAuB;QACvB,MAAM,aAAa,GAAG,cAAc,CAAC,OAAO,CAAC,CAAC;QAC9C,KAAK,CAAC,IAAI,CAAC;YACT,IAAI,EAAE,aAAa,CAAC,MAAM,CAAC,MAAM,CAAC;YAClC,OAAO,EAAE,aAAa;SACvB,CAAC,CAAC;QAEH,gCAAgC;QAChC,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;YACpB,MAAM,cAAc,GAAG,eAAe,CAAC;gBACrC,MAAM,EAAE,OAAO,CAAC,MAAM;gBACtB,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,OAAO,EAAE,EAAE;aACZ,CAAC,CAAC;YACH,KAAK,CAAC,IAAI,CAAC;gBACT,IAAI,EAAE,cAAc,CAAC,MAAM,CAAC,MAAM,CAAC;gBACnC,OAAO,EAAE,cAAc;aACxB,CAAC,CAAC;QACL,CAAC;QAED,sCAAsC;QACtC,MAAM,gBAAgB,GAAG,qBAAqB,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC;QAExF,OAAO;YACL,KAAK;YACL,gBAAgB;SACjB,CAAC;IACJ,CAAC;CACF;AAED,+EAA+E;AAC/E,SAAS;AACT,+EAA+E;AAE/E;;GAEG;AACH,MAAM,UAAU,qBAAqB;IACnC,OAAO,IAAI,eAAe,EAAE,CAAC;AAC/B,CAAC"}
@@ -0,0 +1,26 @@
1
+ /**
2
+ * Factory Templates
3
+ *
4
+ * Template functions for generating factory files.
5
+ */
6
+ import type { TemplateContext } from '../types.js';
7
+ /**
8
+ * Options for factory generation
9
+ */
10
+ export interface FactoryOptions {
11
+ /** Include a model type import hint */
12
+ model?: string;
13
+ }
14
+ /**
15
+ * Get the path for a factory file
16
+ */
17
+ export declare function getFactoryPath(pascalName: string): string;
18
+ /**
19
+ * Generate factory file content
20
+ */
21
+ export declare function factoryTemplate(context: TemplateContext<FactoryOptions>): string;
22
+ /**
23
+ * Get post-generation instructions
24
+ */
25
+ export declare function getFactoryInstructions(pascalName: string): string;
26
+ //# sourceMappingURL=factory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../../src/generators/templates/factory.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAMnD;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,uCAAuC;IACvC,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAMD;;GAEG;AACH,wBAAgB,cAAc,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM,CAEzD;AAMD;;GAEG;AACH,wBAAgB,eAAe,CAAC,OAAO,EAAE,eAAe,CAAC,cAAc,CAAC,GAAG,MAAM,CAgFhF;AAMD;;GAEG;AACH,wBAAgB,sBAAsB,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM,CAiBjE"}
@@ -0,0 +1,125 @@
1
+ /**
2
+ * Factory Templates
3
+ *
4
+ * Template functions for generating factory files.
5
+ */
6
+ // ============================================================================
7
+ // Path Helpers
8
+ // ============================================================================
9
+ /**
10
+ * Get the path for a factory file
11
+ */
12
+ export function getFactoryPath(pascalName) {
13
+ return `src/database/factories/${pascalName}Factory.ts`;
14
+ }
15
+ // ============================================================================
16
+ // Templates
17
+ // ============================================================================
18
+ /**
19
+ * Generate factory file content
20
+ */
21
+ export function factoryTemplate(context) {
22
+ const { entity } = context;
23
+ return `/**
24
+ * ${entity.pascal}Factory
25
+ *
26
+ * Factory for generating ${entity.pascal} model instances with fake data.
27
+ *
28
+ * Usage:
29
+ * const user = await factory.get(${entity.pascal}Factory).create();
30
+ * const users = await factory.get(${entity.pascal}Factory).createMany(10);
31
+ * const admin = await factory.get(${entity.pascal}Factory).state('admin').create();
32
+ */
33
+
34
+ import { BaseFactory, type PrismaClientLike } from '@veloxts/cli';
35
+ import { faker } from '@faker-js/faker';
36
+
37
+ // ============================================================================
38
+ // Types
39
+ // ============================================================================
40
+
41
+ /**
42
+ * Input type for creating a ${entity.pascal}.
43
+ * Adjust these fields to match your Prisma model.
44
+ */
45
+ export interface ${entity.pascal}Input {
46
+ // TODO: Add fields that match your Prisma ${entity.pascal} model
47
+ // Example fields:
48
+ // id?: string;
49
+ // name: string;
50
+ // email: string;
51
+ // createdAt?: Date;
52
+ }
53
+
54
+ // ============================================================================
55
+ // Factory
56
+ // ============================================================================
57
+
58
+ export class ${entity.pascal}Factory extends BaseFactory<${entity.pascal}Input> {
59
+ readonly modelName = '${entity.camel}';
60
+
61
+ constructor(prisma: PrismaClientLike) {
62
+ super(prisma);
63
+
64
+ // Register named states for variations
65
+ // Example: admin state
66
+ // this.registerState('admin', (attrs) => ({
67
+ // ...attrs,
68
+ // role: 'admin',
69
+ // }));
70
+ }
71
+
72
+ /**
73
+ * Define default attributes for a ${entity.pascal}.
74
+ * Uses faker to generate realistic fake data.
75
+ */
76
+ definition(): ${entity.pascal}Input {
77
+ return {
78
+ // TODO: Generate fake data for your model
79
+ // Example:
80
+ // name: faker.person.fullName(),
81
+ // email: faker.internet.email(),
82
+ };
83
+ }
84
+
85
+ // ============================================================================
86
+ // Named States (Convenience Methods)
87
+ // ============================================================================
88
+
89
+ // Example: Create an admin ${entity.camel}
90
+ // admin(): this {
91
+ // return this.state('admin') as this;
92
+ // }
93
+
94
+ // Example: Create a verified ${entity.camel}
95
+ // verified(): this {
96
+ // return this.state('verified') as this;
97
+ // }
98
+ }
99
+ `;
100
+ }
101
+ // ============================================================================
102
+ // Instructions
103
+ // ============================================================================
104
+ /**
105
+ * Get post-generation instructions
106
+ */
107
+ export function getFactoryInstructions(pascalName) {
108
+ return `
109
+ ${pascalName}Factory created successfully!
110
+
111
+ Next steps:
112
+ 1. Update ${pascalName}Input interface to match your Prisma model
113
+ 2. Fill in the definition() method with faker data
114
+ 3. Add named states for common variations (admin, verified, etc.)
115
+
116
+ Usage in seeders:
117
+ await ctx.factory.get(${pascalName}Factory).create();
118
+ await ctx.factory.get(${pascalName}Factory).createMany(10);
119
+ await ctx.factory.get(${pascalName}Factory).state('admin').create();
120
+
121
+ Note: Make sure @faker-js/faker is installed:
122
+ npm install @faker-js/faker
123
+ `;
124
+ }
125
+ //# sourceMappingURL=factory.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"factory.js","sourceRoot":"","sources":["../../../src/generators/templates/factory.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAgBH,+EAA+E;AAC/E,eAAe;AACf,+EAA+E;AAE/E;;GAEG;AACH,MAAM,UAAU,cAAc,CAAC,UAAkB;IAC/C,OAAO,0BAA0B,UAAU,YAAY,CAAC;AAC1D,CAAC;AAED,+EAA+E;AAC/E,YAAY;AACZ,+EAA+E;AAE/E;;GAEG;AACH,MAAM,UAAU,eAAe,CAAC,OAAwC;IACtE,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC;IAE3B,OAAO;KACJ,MAAM,CAAC,MAAM;;4BAEU,MAAM,CAAC,MAAM;;;sCAGH,MAAM,CAAC,MAAM;uCACZ,MAAM,CAAC,MAAM;uCACb,MAAM,CAAC,MAAM;;;;;;;;;;;+BAWrB,MAAM,CAAC,MAAM;;;mBAGzB,MAAM,CAAC,MAAM;+CACe,MAAM,CAAC,MAAM;;;;;;;;;;;;eAY7C,MAAM,CAAC,MAAM,+BAA+B,MAAM,CAAC,MAAM;0BAC9C,MAAM,CAAC,KAAK;;;;;;;;;;;;;;uCAcC,MAAM,CAAC,MAAM;;;kBAGlC,MAAM,CAAC,MAAM;;;;;;;;;;;;;gCAaC,MAAM,CAAC,KAAK;;;;;kCAKV,MAAM,CAAC,KAAK;;;;;CAK7C,CAAC;AACF,CAAC;AAED,+EAA+E;AAC/E,eAAe;AACf,+EAA+E;AAE/E;;GAEG;AACH,MAAM,UAAU,sBAAsB,CAAC,UAAkB;IACvD,OAAO;EACP,UAAU;;;cAGE,UAAU;;;;;0BAKE,UAAU;0BACV,UAAU;0BACV,UAAU;;;;CAInC,CAAC;AACF,CAAC"}
@@ -0,0 +1,34 @@
1
+ /**
2
+ * Seeder Templates
3
+ *
4
+ * Template functions for generating seeder files.
5
+ */
6
+ import type { TemplateContext } from '../types.js';
7
+ /**
8
+ * Options for seeder generation
9
+ */
10
+ export interface SeederOptions {
11
+ /** Also generate a factory for this model */
12
+ factory?: boolean;
13
+ }
14
+ /**
15
+ * Get the path for a seeder file
16
+ */
17
+ export declare function getSeederPath(pascalName: string): string;
18
+ /**
19
+ * Get the path for the DatabaseSeeder entry point
20
+ */
21
+ export declare function getDatabaseSeederPath(): string;
22
+ /**
23
+ * Generate seeder file content
24
+ */
25
+ export declare function seederTemplate(context: TemplateContext<SeederOptions>): string;
26
+ /**
27
+ * Generate DatabaseSeeder entry point
28
+ */
29
+ export declare function databaseSeederTemplate(seederNames: string[]): string;
30
+ /**
31
+ * Get post-generation instructions
32
+ */
33
+ export declare function getSeederInstructions(pascalName: string, hasFactory: boolean): string;
34
+ //# sourceMappingURL=seeder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"seeder.d.ts","sourceRoot":"","sources":["../../../src/generators/templates/seeder.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAMnD;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,6CAA6C;IAC7C,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAMD;;GAEG;AACH,wBAAgB,aAAa,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM,CAExD;AAED;;GAEG;AACH,wBAAgB,qBAAqB,IAAI,MAAM,CAE9C;AAMD;;GAEG;AACH,wBAAgB,cAAc,CAAC,OAAO,EAAE,eAAe,CAAC,aAAa,CAAC,GAAG,MAAM,CAmD9E;AAED;;GAEG;AACH,wBAAgB,sBAAsB,CAAC,WAAW,EAAE,MAAM,EAAE,GAAG,MAAM,CA0BpE;AAMD;;GAEG;AACH,wBAAgB,qBAAqB,CAAC,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,OAAO,GAAG,MAAM,CAoBrF"}