Viewing file: RuleMakeCommand.php (2.07 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
namespace Nwidart\Modules\Commands;
use Illuminate\Support\Str; use Nwidart\Modules\Support\Config\GenerateConfigReader; use Nwidart\Modules\Support\Stub; use Nwidart\Modules\Traits\ModuleCommandTrait; use Symfony\Component\Console\Input\InputArgument;
class RuleMakeCommand extends GeneratorCommand { use ModuleCommandTrait;
/** * The name of argument name. * * @var string */ protected $argumentName = 'name';
/** * The console command name. * * @var string */ protected $name = 'module:make-rule';
/** * The console command description. * * @var string */ protected $description = 'Create a new validation rule for the specified module.';
public function getDefaultNamespace() : string { $module = $this->laravel['modules'];
return $module->config('paths.generator.rules.namespace') ?: $module->config('paths.generator.rules.path', 'Rules'); }
/** * Get the console command arguments. * * @return array */ protected function getArguments() { return [ ['name', InputArgument::REQUIRED, 'The name of the rule class.'], ['module', InputArgument::OPTIONAL, 'The name of module will be used.'], ]; }
/** * @return mixed */ protected function getTemplateContents() { $module = $this->laravel['modules']->findOrFail($this->getModuleName());
return (new Stub('/rule.stub', [ 'NAMESPACE' => $this->getClassNamespace($module), 'CLASS' => $this->getFileName(), ]))->render(); }
/** * @return mixed */ protected function getDestinationFilePath() { $path = $this->laravel['modules']->getModulePath($this->getModuleName());
$rulePath = GenerateConfigReader::read('rules');
return $path . $rulePath->getPath() . '/' . $this->getFileName() . '.php'; }
/** * @return string */ private function getFileName() { return Str::studly($this->argument('name')); } }
|