UNPKG

@athenna/database

Version:

The Athenna database handler for SQL/NoSQL.

67 lines (66 loc) 2.86 kB
/** * @athenna/database * * (c) João Lenon <lenon@athenna.io> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; import { sep } from 'node:path'; import { Path, String } from '@athenna/common'; import { BaseCommand, Argument } from '@athenna/artisan'; export class MakeMigrationCommand extends BaseCommand { static signature() { return 'make:migration'; } static description() { return 'Make a new migration file.'; } async handle() { this.logger.simple('({bold,green} [ MAKING MIGRATION ])\n'); const nameUp = this.name.toUpperCase(); const nameCamel = String.toCamelCase(this.name); const namePlural = String.pluralize(this.name); const namePascal = String.toPascalCase(this.name); const namePluralCamel = String.toCamelCase(String.pluralize(this.name)); const namePluralPascal = String.toPascalCase(String.pluralize(this.name)); const destination = Config.get('rc.commands.make:migration.destination', Path.migrations()); const tableName = String.pluralize(namePascal .replace('Migration', '') .replace('Migrations', '') .toLowerCase()); let [date, time] = new Date().toISOString().split('T'); date = date.replace(/-/g, '_'); time = time.split('.')[0].replace(/:/g, ''); const file = await this.generator .fileName(`${sep}${date}_${time}_create_${tableName}_table`) .destination(destination) .properties({ nameUp, nameCamel, namePlural, namePascal, namePluralCamel, namePluralPascal, tableName }) .template('migration') .make(); this.logger.success(`Migration ({yellow} "${file.name}") successfully created.`); } } __decorate([ Argument({ description: 'The migration name.' }), __metadata("design:type", String) ], MakeMigrationCommand.prototype, "name", void 0);