option('model'); return $model ? $this->replaceModel($stub, $model) : $stub; } /** * Get the stub file for the generator. * * @return string */ protected function getStub() { return $this->option('model') ? __DIR__.'/stubs/observer.stub' : __DIR__.'/stubs/observer.plain.stub'; } /** * Replace the model for the given stub. * * @param string $stub * @param string $model * @return string */ protected function replaceModel($stub, $model) { $model = str_replace('/', '\\', $model); $namespaceModel = $this->laravel->getNamespace().$model; if (Str::startsWith($model, '\\')) { $stub = str_replace('NamespacedDummyModel', trim($model, '\\'), $stub); } else { $stub = str_replace('NamespacedDummyModel', $namespaceModel, $stub); } $stub = str_replace( "use {$namespaceModel};\nuse {$namespaceModel};", "use {$namespaceModel};", $stub ); $model = class_basename(trim($model, '\\')); $stub = str_replace('DocDummyModel', Str::snake($model, ' '), $stub); $stub = str_replace('DummyModel', $model, $stub); return str_replace('dummyModel', Str::camel($model), $stub); } /** * Get the default namespace for the class. * * @param string $rootNamespace * @return string */ protected function getDefaultNamespace($rootNamespace) { return $rootNamespace.'\Observers'; } /** * Get the console command arguments. * * @return array */ protected function getOptions() { return [ ['model', 'm', InputOption::VALUE_OPTIONAL, 'The model that the observer applies to.'], ]; } }