Compare commits
No commits in common. '133e16b610eaa28d381c629c483438d95c37a23f' and '0b6df835fc890a3784debcb139fd7d792f7b65c3' have entirely different histories.
133e16b610
...
0b6df835fc
102 changed files with 2 additions and 2432 deletions
@ -1,56 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace Modules\Api\Http\Controllers; |
||||
|
||||
use App\Http\Controllers\Controller; |
||||
use Illuminate\Http\Request; |
||||
|
||||
class ApiController extends Controller |
||||
{ |
||||
/** |
||||
* Display a listing of the resource. |
||||
*/ |
||||
public function index() |
||||
{ |
||||
return view('api::index'); |
||||
} |
||||
|
||||
/** |
||||
* Show the form for creating a new resource. |
||||
*/ |
||||
public function create() |
||||
{ |
||||
return view('api::create'); |
||||
} |
||||
|
||||
/** |
||||
* Store a newly created resource in storage. |
||||
*/ |
||||
public function store(Request $request) {} |
||||
|
||||
/** |
||||
* Show the specified resource. |
||||
*/ |
||||
public function show($id) |
||||
{ |
||||
return view('api::show'); |
||||
} |
||||
|
||||
/** |
||||
* Show the form for editing the specified resource. |
||||
*/ |
||||
public function edit($id) |
||||
{ |
||||
return view('api::edit'); |
||||
} |
||||
|
||||
/** |
||||
* Update the specified resource in storage. |
||||
*/ |
||||
public function update(Request $request, $id) {} |
||||
|
||||
/** |
||||
* Remove the specified resource from storage. |
||||
*/ |
||||
public function destroy($id) {} |
||||
} |
@ -1,154 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace Modules\Api\Providers; |
||||
|
||||
use Illuminate\Support\Facades\Blade; |
||||
use Illuminate\Support\ServiceProvider; |
||||
use Nwidart\Modules\Traits\PathNamespace; |
||||
use RecursiveDirectoryIterator; |
||||
use RecursiveIteratorIterator; |
||||
|
||||
class ApiServiceProvider extends ServiceProvider |
||||
{ |
||||
use PathNamespace; |
||||
|
||||
protected string $name = 'Api'; |
||||
|
||||
protected string $nameLower = 'api'; |
||||
|
||||
/** |
||||
* Boot the application events. |
||||
*/ |
||||
public function boot(): void |
||||
{ |
||||
$this->registerCommands(); |
||||
$this->registerCommandSchedules(); |
||||
$this->registerTranslations(); |
||||
$this->registerConfig(); |
||||
$this->registerViews(); |
||||
$this->loadMigrationsFrom(module_path($this->name, 'database/migrations')); |
||||
} |
||||
|
||||
/** |
||||
* Register the service provider. |
||||
*/ |
||||
public function register(): void |
||||
{ |
||||
$this->app->register(EventServiceProvider::class); |
||||
$this->app->register(RouteServiceProvider::class); |
||||
} |
||||
|
||||
/** |
||||
* Register commands in the format of Command::class |
||||
*/ |
||||
protected function registerCommands(): void |
||||
{ |
||||
// $this->commands([]); |
||||
} |
||||
|
||||
/** |
||||
* Register command Schedules. |
||||
*/ |
||||
protected function registerCommandSchedules(): void |
||||
{ |
||||
// $this->app->booted(function () { |
||||
// $schedule = $this->app->make(Schedule::class); |
||||
// $schedule->command('inspire')->hourly(); |
||||
// }); |
||||
} |
||||
|
||||
/** |
||||
* Register translations. |
||||
*/ |
||||
public function registerTranslations(): void |
||||
{ |
||||
$langPath = resource_path('lang/modules/'.$this->nameLower); |
||||
|
||||
if (is_dir($langPath)) { |
||||
$this->loadTranslationsFrom($langPath, $this->nameLower); |
||||
$this->loadJsonTranslationsFrom($langPath); |
||||
} else { |
||||
$this->loadTranslationsFrom(module_path($this->name, 'lang'), $this->nameLower); |
||||
$this->loadJsonTranslationsFrom(module_path($this->name, 'lang')); |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* Register config. |
||||
*/ |
||||
protected function registerConfig(): void |
||||
{ |
||||
$configPath = module_path($this->name, config('modules.paths.generator.config.path')); |
||||
|
||||
if (is_dir($configPath)) { |
||||
$iterator = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($configPath)); |
||||
|
||||
foreach ($iterator as $file) { |
||||
if ($file->isFile() && $file->getExtension() === 'php') { |
||||
$config = str_replace($configPath.DIRECTORY_SEPARATOR, '', $file->getPathname()); |
||||
$config_key = str_replace([DIRECTORY_SEPARATOR, '.php'], ['.', ''], $config); |
||||
$segments = explode('.', $this->nameLower.'.'.$config_key); |
||||
|
||||
// Remove duplicated adjacent segments |
||||
$normalized = []; |
||||
foreach ($segments as $segment) { |
||||
if (end($normalized) !== $segment) { |
||||
$normalized[] = $segment; |
||||
} |
||||
} |
||||
|
||||
$key = ($config === 'config.php') ? $this->nameLower : implode('.', $normalized); |
||||
|
||||
$this->publishes([$file->getPathname() => config_path($config)], 'config'); |
||||
$this->merge_config_from($file->getPathname(), $key); |
||||
} |
||||
} |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* Merge config from the given path recursively. |
||||
*/ |
||||
protected function merge_config_from(string $path, string $key): void |
||||
{ |
||||
$existing = config($key, []); |
||||
$module_config = require $path; |
||||
|
||||
config([$key => array_replace_recursive($existing, $module_config)]); |
||||
} |
||||
|
||||
/** |
||||
* Register views. |
||||
*/ |
||||
public function registerViews(): void |
||||
{ |
||||
$viewPath = resource_path('views/modules/'.$this->nameLower); |
||||
$sourcePath = module_path($this->name, 'resources/views'); |
||||
|
||||
$this->publishes([$sourcePath => $viewPath], ['views', $this->nameLower.'-module-views']); |
||||
|
||||
$this->loadViewsFrom(array_merge($this->getPublishableViewPaths(), [$sourcePath]), $this->nameLower); |
||||
|
||||
Blade::componentNamespace(config('modules.namespace').'\\' . $this->name . '\\View\\Components', $this->nameLower); |
||||
} |
||||
|
||||
/** |
||||
* Get the services provided by the provider. |
||||
*/ |
||||
public function provides(): array |
||||
{ |
||||
return []; |
||||
} |
||||
|
||||
private function getPublishableViewPaths(): array |
||||
{ |
||||
$paths = []; |
||||
foreach (config('view.paths') as $path) { |
||||
if (is_dir($path.'/modules/'.$this->nameLower)) { |
||||
$paths[] = $path.'/modules/'.$this->nameLower; |
||||
} |
||||
} |
||||
|
||||
return $paths; |
||||
} |
||||
} |
@ -1,27 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace Modules\Api\Providers; |
||||
|
||||
use Illuminate\Foundation\Support\Providers\EventServiceProvider as ServiceProvider; |
||||
|
||||
class EventServiceProvider extends ServiceProvider |
||||
{ |
||||
/** |
||||
* The event handler mappings for the application. |
||||
* |
||||
* @var array<string, array<int, string>> |
||||
*/ |
||||
protected $listen = []; |
||||
|
||||
/** |
||||
* Indicates if events should be discovered. |
||||
* |
||||
* @var bool |
||||
*/ |
||||
protected static $shouldDiscoverEvents = true; |
||||
|
||||
/** |
||||
* Configure the proper event listeners for email verification. |
||||
*/ |
||||
protected function configureEmailVerification(): void {} |
||||
} |
@ -1,50 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace Modules\Api\Providers; |
||||
|
||||
use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider; |
||||
use Illuminate\Support\Facades\Route; |
||||
|
||||
class RouteServiceProvider extends ServiceProvider |
||||
{ |
||||
protected string $name = 'Api'; |
||||
|
||||
/** |
||||
* Called before routes are registered. |
||||
* |
||||
* Register any model bindings or pattern based filters. |
||||
*/ |
||||
public function boot(): void |
||||
{ |
||||
parent::boot(); |
||||
} |
||||
|
||||
/** |
||||
* Define the routes for the application. |
||||
*/ |
||||
public function map(): void |
||||
{ |
||||
$this->mapApiRoutes(); |
||||
$this->mapWebRoutes(); |
||||
} |
||||
|
||||
/** |
||||
* Define the "web" routes for the application. |
||||
* |
||||
* These routes all receive session state, CSRF protection, etc. |
||||
*/ |
||||
protected function mapWebRoutes(): void |
||||
{ |
||||
Route::middleware('web')->group(module_path($this->name, '/routes/web.php')); |
||||
} |
||||
|
||||
/** |
||||
* Define the "api" routes for the application. |
||||
* |
||||
* These routes are typically stateless. |
||||
*/ |
||||
protected function mapApiRoutes(): void |
||||
{ |
||||
Route::middleware('api')->prefix('api')->name('api.')->group(module_path($this->name, '/routes/api.php')); |
||||
} |
||||
} |
@ -1,30 +0,0 @@ |
||||
{ |
||||
"name": "nwidart/api", |
||||
"description": "", |
||||
"authors": [ |
||||
{ |
||||
"name": "Nicolas Widart", |
||||
"email": "n.widart@gmail.com" |
||||
} |
||||
], |
||||
"extra": { |
||||
"laravel": { |
||||
"providers": [], |
||||
"aliases": { |
||||
|
||||
} |
||||
} |
||||
}, |
||||
"autoload": { |
||||
"psr-4": { |
||||
"Modules\\Api\\": "app/", |
||||
"Modules\\Api\\Database\\Factories\\": "database/factories/", |
||||
"Modules\\Api\\Database\\Seeders\\": "database/seeders/" |
||||
} |
||||
}, |
||||
"autoload-dev": { |
||||
"psr-4": { |
||||
"Modules\\Api\\Tests\\": "tests/" |
||||
} |
||||
} |
||||
} |
@ -1,5 +0,0 @@ |
||||
<?php |
||||
|
||||
return [ |
||||
'name' => 'Api', |
||||
]; |
@ -1,16 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace Modules\Api\Database\Seeders; |
||||
|
||||
use Illuminate\Database\Seeder; |
||||
|
||||
class ApiDatabaseSeeder extends Seeder |
||||
{ |
||||
/** |
||||
* Run the database seeds. |
||||
*/ |
||||
public function run(): void |
||||
{ |
||||
// $this->call([]); |
||||
} |
||||
} |
@ -1,16 +0,0 @@ |
||||
{ |
||||
"name": "modules/api", |
||||
"description": "", |
||||
"type": "module", |
||||
"autoload": { |
||||
"psr-4": { |
||||
"Modules\\Api\\": "app/" |
||||
} |
||||
}, |
||||
"extra": { |
||||
"laravel": { |
||||
"providers": [] |
||||
} |
||||
}, |
||||
"require": {} |
||||
} |
@ -1,15 +0,0 @@ |
||||
{ |
||||
"private": true, |
||||
"type": "module", |
||||
"scripts": { |
||||
"dev": "vite", |
||||
"build": "vite build" |
||||
}, |
||||
"devDependencies": { |
||||
"axios": "^1.1.2", |
||||
"laravel-vite-plugin": "^0.7.5", |
||||
"sass": "^1.69.5", |
||||
"postcss": "^8.3.7", |
||||
"vite": "^4.0.0" |
||||
} |
||||
} |
@ -1,29 +0,0 @@ |
||||
<!DOCTYPE html> |
||||
<html lang="{{ str_replace('_', '-', app()->getLocale()) }}"> |
||||
|
||||
<head> |
||||
<meta charset="utf-8"> |
||||
<meta name="viewport" content="width=device-width, initial-scale=1"> |
||||
<meta name="csrf-token" content="{{ csrf_token() }}"> |
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge"> |
||||
|
||||
<title>Api Module - {{ config('app.name', 'Laravel') }}</title> |
||||
|
||||
<meta name="description" content="{{ $description ?? '' }}"> |
||||
<meta name="keywords" content="{{ $keywords ?? '' }}"> |
||||
<meta name="author" content="{{ $author ?? '' }}"> |
||||
|
||||
<!-- Fonts --> |
||||
<link rel="preconnect" href="https://fonts.bunny.net"> |
||||
<link href="https://fonts.bunny.net/css?family=figtree:400,500,600&display=swap" rel="stylesheet" /> |
||||
|
||||
{{-- Vite CSS --}} |
||||
{{-- {{ module_vite('build-api', 'resources/assets/sass/app.scss') }} --}} |
||||
</head> |
||||
|
||||
<body> |
||||
{{ $slot }} |
||||
|
||||
{{-- Vite JS --}} |
||||
{{-- {{ module_vite('build-api', 'resources/assets/js/app.js') }} --}} |
||||
</body> |
@ -1,5 +0,0 @@ |
||||
<x-api::layouts.master> |
||||
<h1>Hello World</h1> |
||||
|
||||
<p>Module: {!! config('api.name') !!}</p> |
||||
</x-api::layouts.master> |
@ -1,8 +0,0 @@ |
||||
<?php |
||||
|
||||
use Illuminate\Support\Facades\Route; |
||||
use Modules\Api\Http\Controllers\ApiController; |
||||
|
||||
Route::middleware(['auth:sanctum'])->prefix('v1')->group(function () { |
||||
Route::apiResource('apis', ApiController::class)->names('api'); |
||||
}); |
@ -1,8 +0,0 @@ |
||||
<?php |
||||
|
||||
use Illuminate\Support\Facades\Route; |
||||
use Modules\Api\Http\Controllers\ApiController; |
||||
|
||||
Route::middleware(['auth', 'verified'])->group(function () { |
||||
Route::resource('apis', ApiController::class)->names('api'); |
||||
}); |
@ -1,57 +0,0 @@ |
||||
import { defineConfig } from 'vite'; |
||||
import laravel from 'laravel-vite-plugin'; |
||||
import { readdirSync, statSync } from 'fs'; |
||||
import { join,relative,dirname } from 'path'; |
||||
import { fileURLToPath } from 'url'; |
||||
|
||||
export default defineConfig({ |
||||
build: { |
||||
outDir: '../../public/build-api', |
||||
emptyOutDir: true, |
||||
manifest: true, |
||||
}, |
||||
plugins: [ |
||||
laravel({ |
||||
publicDirectory: '../../public', |
||||
buildDirectory: 'build-api', |
||||
input: [ |
||||
__dirname + '/resources/assets/sass/app.scss', |
||||
__dirname + '/resources/assets/js/app.js' |
||||
], |
||||
refresh: true, |
||||
}), |
||||
], |
||||
}); |
||||
// Scen all resources for assets file. Return array
|
||||
//function getFilePaths(dir) {
|
||||
// const filePaths = [];
|
||||
//
|
||||
// function walkDirectory(currentPath) {
|
||||
// const files = readdirSync(currentPath);
|
||||
// for (const file of files) {
|
||||
// const filePath = join(currentPath, file);
|
||||
// const stats = statSync(filePath);
|
||||
// if (stats.isFile() && !file.startsWith('.')) {
|
||||
// const relativePath = 'Modules/Api/'+relative(__dirname, filePath);
|
||||
// filePaths.push(relativePath);
|
||||
// } else if (stats.isDirectory()) {
|
||||
// walkDirectory(filePath);
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
//
|
||||
// walkDirectory(dir);
|
||||
// return filePaths;
|
||||
//}
|
||||
|
||||
//const __filename = fileURLToPath(import.meta.url);
|
||||
//const __dirname = dirname(__filename);
|
||||
|
||||
//const assetsDir = join(__dirname, 'resources/assets');
|
||||
//export const paths = getFilePaths(assetsDir);
|
||||
|
||||
|
||||
//export const paths = [
|
||||
// 'Modules/Api/resources/assets/sass/app.scss',
|
||||
// 'Modules/Api/resources/assets/js/app.js',
|
||||
//];
|
@ -1,298 +0,0 @@ |
||||
<?php |
||||
|
||||
use Nwidart\Modules\Activators\FileActivator; |
||||
use Nwidart\Modules\Providers\ConsoleServiceProvider; |
||||
|
||||
return [ |
||||
|
||||
/* |
||||
|-------------------------------------------------------------------------- |
||||
| Module Namespace |
||||
|-------------------------------------------------------------------------- |
||||
| |
||||
| Default module namespace. |
||||
| |
||||
*/ |
||||
'namespace' => 'Modules', |
||||
|
||||
/* |
||||
|-------------------------------------------------------------------------- |
||||
| Module Stubs |
||||
|-------------------------------------------------------------------------- |
||||
| |
||||
| Default module stubs. |
||||
| |
||||
*/ |
||||
'stubs' => [ |
||||
'enabled' => false, |
||||
'path' => base_path('vendor/nwidart/laravel-modules/src/Commands/stubs'), |
||||
'files' => [ |
||||
'routes/web' => 'routes/web.php', |
||||
'routes/api' => 'routes/api.php', |
||||
'views/index' => 'resources/views/index.blade.php', |
||||
'views/master' => 'resources/views/components/layouts/master.blade.php', |
||||
'scaffold/config' => 'config/config.php', |
||||
'composer' => 'composer.json', |
||||
'assets/js/app' => 'resources/assets/js/app.js', |
||||
'assets/sass/app' => 'resources/assets/sass/app.scss', |
||||
'vite' => 'vite.config.js', |
||||
'package' => 'package.json', |
||||
], |
||||
'replacements' => [ |
||||
/** |
||||
* Define custom replacements for each section. |
||||
* You can specify a closure for dynamic values. |
||||
* |
||||
* Example: |
||||
* |
||||
* 'composer' => [ |
||||
* 'CUSTOM_KEY' => fn (\Nwidart\Modules\Generators\ModuleGenerator $generator) => $generator->getModule()->getLowerName() . '-module', |
||||
* 'CUSTOM_KEY2' => fn () => 'custom text', |
||||
* 'LOWER_NAME', |
||||
* 'STUDLY_NAME', |
||||
* // ... |
||||
* ], |
||||
* |
||||
* Note: Keys should be in UPPERCASE. |
||||
*/ |
||||
'routes/web' => ['LOWER_NAME', 'STUDLY_NAME', 'PLURAL_LOWER_NAME', 'KEBAB_NAME', 'MODULE_NAMESPACE', 'CONTROLLER_NAMESPACE'], |
||||
'routes/api' => ['LOWER_NAME', 'STUDLY_NAME', 'PLURAL_LOWER_NAME', 'KEBAB_NAME', 'MODULE_NAMESPACE', 'CONTROLLER_NAMESPACE'], |
||||
'vite' => ['LOWER_NAME', 'STUDLY_NAME', 'KEBAB_NAME'], |
||||
'json' => ['LOWER_NAME', 'STUDLY_NAME', 'KEBAB_NAME', 'MODULE_NAMESPACE', 'PROVIDER_NAMESPACE'], |
||||
'views/index' => ['LOWER_NAME'], |
||||
'views/master' => ['LOWER_NAME', 'STUDLY_NAME', 'KEBAB_NAME'], |
||||
'scaffold/config' => ['STUDLY_NAME'], |
||||
'composer' => [ |
||||
'LOWER_NAME', |
||||
'STUDLY_NAME', |
||||
'VENDOR', |
||||
'AUTHOR_NAME', |
||||
'AUTHOR_EMAIL', |
||||
'MODULE_NAMESPACE', |
||||
'PROVIDER_NAMESPACE', |
||||
'APP_FOLDER_NAME', |
||||
], |
||||
], |
||||
'gitkeep' => true, |
||||
], |
||||
'paths' => [ |
||||
/* |
||||
|-------------------------------------------------------------------------- |
||||
| Modules path |
||||
|-------------------------------------------------------------------------- |
||||
| |
||||
| This path is used to save the generated module. |
||||
| This path will also be added automatically to the list of scanned folders. |
||||
| |
||||
*/ |
||||
'modules' => base_path('Modules'), |
||||
|
||||
/* |
||||
|-------------------------------------------------------------------------- |
||||
| Modules assets path |
||||
|-------------------------------------------------------------------------- |
||||
| |
||||
| Here you may update the modules' assets path. |
||||
| |
||||
*/ |
||||
'assets' => public_path('modules'), |
||||
|
||||
/* |
||||
|-------------------------------------------------------------------------- |
||||
| The migrations' path |
||||
|-------------------------------------------------------------------------- |
||||
| |
||||
| Where you run the 'module:publish-migration' command, where do you publish the |
||||
| the migration files? |
||||
| |
||||
*/ |
||||
'migration' => base_path('database/migrations'), |
||||
|
||||
/* |
||||
|-------------------------------------------------------------------------- |
||||
| The app path |
||||
|-------------------------------------------------------------------------- |
||||
| |
||||
| app folder name |
||||
| for example can change it to 'src' or 'App' |
||||
*/ |
||||
'app_folder' => 'app/', |
||||
|
||||
/* |
||||
|-------------------------------------------------------------------------- |
||||
| Generator path |
||||
|-------------------------------------------------------------------------- |
||||
| Customise the paths where the folders will be generated. |
||||
| Setting the generate key to false will not generate that folder |
||||
*/ |
||||
'generator' => [ |
||||
// app/ |
||||
'actions' => ['path' => 'app/Actions', 'generate' => false], |
||||
'casts' => ['path' => 'app/Casts', 'generate' => false], |
||||
'channels' => ['path' => 'app/Broadcasting', 'generate' => false], |
||||
'class' => ['path' => 'app/Classes', 'generate' => false], |
||||
'command' => ['path' => 'app/Console', 'generate' => false], |
||||
'component-class' => ['path' => 'app/View/Components', 'generate' => false], |
||||
'emails' => ['path' => 'app/Emails', 'generate' => false], |
||||
'event' => ['path' => 'app/Events', 'generate' => false], |
||||
'enums' => ['path' => 'app/Enums', 'generate' => false], |
||||
'exceptions' => ['path' => 'app/Exceptions', 'generate' => false], |
||||
'jobs' => ['path' => 'app/Jobs', 'generate' => false], |
||||
'helpers' => ['path' => 'app/Helpers', 'generate' => false], |
||||
'interfaces' => ['path' => 'app/Interfaces', 'generate' => false], |
||||
'listener' => ['path' => 'app/Listeners', 'generate' => false], |
||||
'model' => ['path' => 'app/Models', 'generate' => false], |
||||
'notifications' => ['path' => 'app/Notifications', 'generate' => false], |
||||
'observer' => ['path' => 'app/Observers', 'generate' => false], |
||||
'policies' => ['path' => 'app/Policies', 'generate' => false], |
||||
'provider' => ['path' => 'app/Providers', 'generate' => true], |
||||
'repository' => ['path' => 'app/Repositories', 'generate' => false], |
||||
'resource' => ['path' => 'app/Transformers', 'generate' => false], |
||||
'route-provider' => ['path' => 'app/Providers', 'generate' => true], |
||||
'rules' => ['path' => 'app/Rules', 'generate' => false], |
||||
'services' => ['path' => 'app/Services', 'generate' => false], |
||||
'scopes' => ['path' => 'app/Models/Scopes', 'generate' => false], |
||||
'traits' => ['path' => 'app/Traits', 'generate' => false], |
||||
|
||||
// app/Http/ |
||||
'controller' => ['path' => 'app/Http/Controllers', 'generate' => true], |
||||
'filter' => ['path' => 'app/Http/Middleware', 'generate' => false], |
||||
'request' => ['path' => 'app/Http/Requests', 'generate' => false], |
||||
|
||||
// config/ |
||||
'config' => ['path' => 'config', 'generate' => true], |
||||
|
||||
// database/ |
||||
'factory' => ['path' => 'database/factories', 'generate' => true], |
||||
'migration' => ['path' => 'database/migrations', 'generate' => true], |
||||
'seeder' => ['path' => 'database/seeders', 'generate' => true], |
||||
|
||||
// lang/ |
||||
'lang' => ['path' => 'lang', 'generate' => false], |
||||
|
||||
// resource/ |
||||
'assets' => ['path' => 'resources/assets', 'generate' => true], |
||||
'component-view' => ['path' => 'resources/views/components', 'generate' => false], |
||||
'views' => ['path' => 'resources/views', 'generate' => true], |
||||
|
||||
// routes/ |
||||
'routes' => ['path' => 'routes', 'generate' => true], |
||||
|
||||
// tests/ |
||||
'test-feature' => ['path' => 'tests/Feature', 'generate' => true], |
||||
'test-unit' => ['path' => 'tests/Unit', 'generate' => true], |
||||
], |
||||
], |
||||
|
||||
/* |
||||
|-------------------------------------------------------------------------- |
||||
| Auto Discover of Modules |
||||
|-------------------------------------------------------------------------- |
||||
| |
||||
| Here you configure auto discover of module |
||||
| This is useful for simplify module providers. |
||||
| |
||||
*/ |
||||
'auto-discover' => [ |
||||
/* |
||||
|-------------------------------------------------------------------------- |
||||
| Migrations |
||||
|-------------------------------------------------------------------------- |
||||
| |
||||
| This option for register migration automatically. |
||||
| |
||||
*/ |
||||
'migrations' => true, |
||||
|
||||
/* |
||||
|-------------------------------------------------------------------------- |
||||
| Translations |
||||
|-------------------------------------------------------------------------- |
||||
| |
||||
| This option for register lang file automatically. |
||||
| |
||||
*/ |
||||
'translations' => false, |
||||
|
||||
], |
||||
|
||||
/* |
||||
|-------------------------------------------------------------------------- |
||||
| Package commands |
||||
|-------------------------------------------------------------------------- |
||||
| |
||||
| Here you can define which commands will be visible and used in your |
||||
| application. You can add your own commands to merge section. |
||||
| |
||||
*/ |
||||
'commands' => ConsoleServiceProvider::defaultCommands() |
||||
->merge([ |
||||
// New commands go here |
||||
])->toArray(), |
||||
|
||||
/* |
||||
|-------------------------------------------------------------------------- |
||||
| Scan Path |
||||
|-------------------------------------------------------------------------- |
||||
| |
||||
| Here you define which folder will be scanned. By default will scan vendor |
||||
| directory. This is useful if you host the package in packagist website. |
||||
| |
||||
*/ |
||||
'scan' => [ |
||||
'enabled' => false, |
||||
'paths' => [ |
||||
base_path('vendor/*/*'), |
||||
], |
||||
], |
||||
|
||||
/* |
||||
|-------------------------------------------------------------------------- |
||||
| Composer File Template |
||||
|-------------------------------------------------------------------------- |
||||
| |
||||
| Here is the config for the composer.json file, generated by this package |
||||
| |
||||
*/ |
||||
'composer' => [ |
||||
'vendor' => env('MODULE_VENDOR', 'nwidart'), |
||||
'author' => [ |
||||
'name' => env('MODULE_AUTHOR_NAME', 'Nicolas Widart'), |
||||
'email' => env('MODULE_AUTHOR_EMAIL', 'n.widart@gmail.com'), |
||||
], |
||||
'composer-output' => false, |
||||
], |
||||
|
||||
/* |
||||
|-------------------------------------------------------------------------- |
||||
| Choose what laravel-modules will register as custom namespaces. |
||||
| Setting one to false will require you to register that part |
||||
| in your own Service Provider class. |
||||
|-------------------------------------------------------------------------- |
||||
*/ |
||||
'register' => [ |
||||
'translations' => true, |
||||
/** |
||||
* load files on boot or register method |
||||
*/ |
||||
'files' => 'register', |
||||
], |
||||
|
||||
/* |
||||
|-------------------------------------------------------------------------- |
||||
| Activators |
||||
|-------------------------------------------------------------------------- |
||||
| |
||||
| You can define new types of activators here, file, database, etc. The only |
||||
| required parameter is 'class'. |
||||
| The file activator will store the activation status in storage/installed_modules |
||||
*/ |
||||
'activators' => [ |
||||
'file' => [ |
||||
'class' => FileActivator::class, |
||||
'statuses-file' => base_path('modules_statuses.json'), |
||||
], |
||||
], |
||||
|
||||
'activator' => 'file', |
||||
]; |
@ -1,3 +0,0 @@ |
||||
{ |
||||
"Api": true |
||||
} |
@ -1,8 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
class $CLASS$ |
||||
{ |
||||
public function __invoke() {} |
||||
} |
@ -1,8 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
class $CLASS$ |
||||
{ |
||||
public function handle() {} |
||||
} |
@ -1,25 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
use Illuminate\Contracts\Database\Eloquent\CastsAttributes; |
||||
use Illuminate\Database\Eloquent\Model; |
||||
|
||||
class $CLASS$ implements CastsAttributes |
||||
{ |
||||
/** |
||||
* Cast the given value. |
||||
*/ |
||||
public function get(Model $model, string $key, mixed $value, array $attributes): mixed |
||||
{ |
||||
return $value; |
||||
} |
||||
|
||||
/** |
||||
* Prepare the given value for storage. |
||||
*/ |
||||
public function set(Model $model, string $key, mixed $value, array $attributes): mixed |
||||
{ |
||||
return $value; |
||||
} |
||||
} |
@ -1,16 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
class $CLASS$ |
||||
{ |
||||
/** |
||||
* Create a new channel instance. |
||||
*/ |
||||
public function __construct() {} |
||||
|
||||
/** |
||||
* Authenticate the user's access to the channel. |
||||
*/ |
||||
public function join(Operator $user): array|bool {} |
||||
} |
@ -1,8 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
class $CLASS$ |
||||
{ |
||||
public function __invoke() {} |
||||
} |
@ -1,8 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
class $CLASS$ |
||||
{ |
||||
public function __construct() {} |
||||
} |
@ -1,53 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Console\Command; |
||||
use Symfony\Component\Console\Input\InputOption; |
||||
use Symfony\Component\Console\Input\InputArgument; |
||||
|
||||
class $CLASS$ extends Command |
||||
{ |
||||
/** |
||||
* The name and signature of the console command. |
||||
*/ |
||||
protected $signature = '$COMMAND_NAME$'; |
||||
|
||||
/** |
||||
* The console command description. |
||||
*/ |
||||
protected $description = 'Command description.'; |
||||
|
||||
/** |
||||
* Create a new command instance. |
||||
*/ |
||||
public function __construct() |
||||
{ |
||||
parent::__construct(); |
||||
} |
||||
|
||||
/** |
||||
* Execute the console command. |
||||
*/ |
||||
public function handle() {} |
||||
|
||||
/** |
||||
* Get the console command arguments. |
||||
*/ |
||||
protected function getArguments(): array |
||||
{ |
||||
return [ |
||||
['example', InputArgument::REQUIRED, 'An example argument.'], |
||||
]; |
||||
} |
||||
|
||||
/** |
||||
* Get the console command options. |
||||
*/ |
||||
protected function getOptions(): array |
||||
{ |
||||
return [ |
||||
['example', null, InputOption::VALUE_OPTIONAL, 'An example option.', null], |
||||
]; |
||||
} |
||||
} |
@ -1,22 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\View\Component; |
||||
use Illuminate\View\View; |
||||
|
||||
class $CLASS$ extends Component |
||||
{ |
||||
/** |
||||
* Create a new component instance. |
||||
*/ |
||||
public function __construct() {} |
||||
|
||||
/** |
||||
* Get the view/contents that represent the component. |
||||
*/ |
||||
public function render(): View|string |
||||
{ |
||||
return view('$LOWER_NAME$::$COMPONENT_NAME$'); |
||||
} |
||||
} |
@ -1,3 +0,0 @@ |
||||
<div> |
||||
<!-- $QUOTE$ --> |
||||
</div> |
@ -1,30 +0,0 @@ |
||||
{ |
||||
"name": "$VENDOR$/$LOWER_NAME$", |
||||
"description": "", |
||||
"authors": [ |
||||
{ |
||||
"name": "$AUTHOR_NAME$", |
||||
"email": "$AUTHOR_EMAIL$" |
||||
} |
||||
], |
||||
"extra": { |
||||
"laravel": { |
||||
"providers": [], |
||||
"aliases": { |
||||
|
||||
} |
||||
} |
||||
}, |
||||
"autoload": { |
||||
"psr-4": { |
||||
"$MODULE_NAMESPACE$\\$STUDLY_NAME$\\": "$APP_FOLDER_NAME$", |
||||
"$MODULE_NAMESPACE$\\$STUDLY_NAME$\\Database\\Factories\\": "database/factories/", |
||||
"$MODULE_NAMESPACE$\\$STUDLY_NAME$\\Database\\Seeders\\": "database/seeders/" |
||||
} |
||||
}, |
||||
"autoload-dev": { |
||||
"psr-4": { |
||||
"$MODULE_NAMESPACE$\\$STUDLY_NAME$\\Tests\\": "tests/" |
||||
} |
||||
} |
||||
} |
@ -1,59 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
use App\Http\Controllers\Controller; |
||||
use Illuminate\Http\Request; |
||||
|
||||
class $CLASS$ extends Controller |
||||
{ |
||||
/** |
||||
* Display a listing of the resource. |
||||
*/ |
||||
public function index() |
||||
{ |
||||
// |
||||
|
||||
return response()->json([]); |
||||
} |
||||
|
||||
/** |
||||
* Store a newly created resource in storage. |
||||
*/ |
||||
public function store(Request $request) |
||||
{ |
||||
// |
||||
|
||||
return response()->json([]); |
||||
} |
||||
|
||||
/** |
||||
* Show the specified resource. |
||||
*/ |
||||
public function show($id) |
||||
{ |
||||
// |
||||
|
||||
return response()->json([]); |
||||
} |
||||
|
||||
/** |
||||
* Update the specified resource in storage. |
||||
*/ |
||||
public function update(Request $request, $id) |
||||
{ |
||||
// |
||||
|
||||
return response()->json([]); |
||||
} |
||||
|
||||
/** |
||||
* Remove the specified resource from storage. |
||||
*/ |
||||
public function destroy($id) |
||||
{ |
||||
// |
||||
|
||||
return response()->json([]); |
||||
} |
||||
} |
@ -1,7 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
use Illuminate\Routing\Controller; |
||||
|
||||
class $CLASS$ extends Controller {} |
@ -1,17 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
use App\Http\Controllers\Controller; |
||||
use Illuminate\Http\Request; |
||||
|
||||
class $CLASS$ extends Controller |
||||
{ |
||||
/** |
||||
* Handle the incoming request. |
||||
*/ |
||||
public function __invoke(Request $request) |
||||
{ |
||||
return response()->json([]); |
||||
} |
||||
} |
@ -1,56 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
use App\Http\Controllers\Controller; |
||||
use Illuminate\Http\Request; |
||||
|
||||
class $CLASS$ extends Controller |
||||
{ |
||||
/** |
||||
* Display a listing of the resource. |
||||
*/ |
||||
public function index() |
||||
{ |
||||
return view('$LOWER_NAME$::index'); |
||||
} |
||||
|
||||
/** |
||||
* Show the form for creating a new resource. |
||||
*/ |
||||
public function create() |
||||
{ |
||||
return view('$LOWER_NAME$::create'); |
||||
} |
||||
|
||||
/** |
||||
* Store a newly created resource in storage. |
||||
*/ |
||||
public function store(Request $request) {} |
||||
|
||||
/** |
||||
* Show the specified resource. |
||||
*/ |
||||
public function show($id) |
||||
{ |
||||
return view('$LOWER_NAME$::show'); |
||||
} |
||||
|
||||
/** |
||||
* Show the form for editing the specified resource. |
||||
*/ |
||||
public function edit($id) |
||||
{ |
||||
return view('$LOWER_NAME$::edit'); |
||||
} |
||||
|
||||
/** |
||||
* Update the specified resource in storage. |
||||
*/ |
||||
public function update(Request $request, $id) {} |
||||
|
||||
/** |
||||
* Remove the specified resource from storage. |
||||
*/ |
||||
public function destroy($id) {} |
||||
} |
@ -1,5 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
enum $CLASS$ {} |
@ -1,27 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Foundation\Support\Providers\EventServiceProvider as ServiceProvider; |
||||
|
||||
class $CLASS$ extends ServiceProvider |
||||
{ |
||||
/** |
||||
* The event handler mappings for the application. |
||||
* |
||||
* @var array<string, array<int, string>> |
||||
*/ |
||||
protected $listen = []; |
||||
|
||||
/** |
||||
* Indicates if events should be discovered. |
||||
* |
||||
* @var bool |
||||
*/ |
||||
protected static $shouldDiscoverEvents = true; |
||||
|
||||
/** |
||||
* Configure the proper event listeners for email verification. |
||||
*/ |
||||
protected function configureEmailVerification(): void {} |
||||
} |
@ -1,31 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Broadcasting\Channel; |
||||
use Illuminate\Broadcasting\InteractsWithSockets; |
||||
use Illuminate\Broadcasting\PresenceChannel; |
||||
use Illuminate\Broadcasting\PrivateChannel; |
||||
use Illuminate\Contracts\Broadcasting\ShouldBroadcast; |
||||
use Illuminate\Foundation\Events\Dispatchable; |
||||
use Illuminate\Queue\SerializesModels; |
||||
|
||||
class $CLASS$ |
||||
{ |
||||
use Dispatchable, InteractsWithSockets, SerializesModels; |
||||
|
||||
/** |
||||
* Create a new event instance. |
||||
*/ |
||||
public function __construct() {} |
||||
|
||||
/** |
||||
* Get the channels the event should be broadcast on. |
||||
*/ |
||||
public function broadcastOn(): array |
||||
{ |
||||
return [ |
||||
new PrivateChannel('channel-name'), |
||||
]; |
||||
} |
||||
} |
@ -1,20 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
use Exception; |
||||
use Illuminate\Http\Request; |
||||
use Illuminate\Http\Response; |
||||
|
||||
class $CLASS$ extends Exception |
||||
{ |
||||
/** |
||||
* Report the exception. |
||||
*/ |
||||
public function report(): void {} |
||||
|
||||
/** |
||||
* Render the exception as an HTTP response. |
||||
*/ |
||||
public function render(Request $request): Response {} |
||||
} |
@ -1,15 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
use Exception; |
||||
use Illuminate\Http\Request; |
||||
use Illuminate\Http\Response; |
||||
|
||||
class $CLASS$ extends Exception |
||||
{ |
||||
/** |
||||
* Render the exception as an HTTP response. |
||||
*/ |
||||
public function render(Request $request): Response {} |
||||
} |
@ -1,13 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
use Exception; |
||||
|
||||
class $CLASS$ extends Exception |
||||
{ |
||||
/** |
||||
* Report the exception. |
||||
*/ |
||||
public function report(): void {} |
||||
} |
@ -1,7 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
use Exception; |
||||
|
||||
class $CLASS$ extends Exception {} |
@ -1,22 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Database\Eloquent\Factories\Factory; |
||||
|
||||
class $NAME$Factory extends Factory |
||||
{ |
||||
/** |
||||
* The name of the factory's corresponding model. |
||||
*/ |
||||
protected $model = \$MODEL_NAMESPACE$\$NAME$::class; |
||||
|
||||
/** |
||||
* Define the model's default state. |
||||
*/ |
||||
public function definition(): array |
||||
{ |
||||
return []; |
||||
} |
||||
} |
||||
|
@ -1,8 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
class $CLASS$ |
||||
{ |
||||
public function __invoke() {} |
||||
} |
@ -1,8 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
class $CLASS$ |
||||
{ |
||||
public function handle() {} |
||||
} |
@ -1,5 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
interface $CLASS$ {} |
@ -1,24 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Bus\Queueable; |
||||
use Illuminate\Queue\SerializesModels; |
||||
use Illuminate\Queue\InteractsWithQueue; |
||||
use Illuminate\Contracts\Queue\ShouldQueue; |
||||
use Illuminate\Foundation\Bus\Dispatchable; |
||||
|
||||
class $CLASS$ implements ShouldQueue |
||||
{ |
||||
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels; |
||||
|
||||
/** |
||||
* Create a new job instance. |
||||
*/ |
||||
public function __construct() {} |
||||
|
||||
/** |
||||
* Execute the job. |
||||
*/ |
||||
public function handle(): void {} |
||||
} |
@ -1,21 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Bus\Queueable; |
||||
use Illuminate\Foundation\Bus\Dispatchable; |
||||
|
||||
class $CLASS$ implements ShouldQueue |
||||
{ |
||||
use Dispatchable, Queueable; |
||||
|
||||
/** |
||||
* Create a new job instance. |
||||
*/ |
||||
public function __construct() {} |
||||
|
||||
/** |
||||
* Execute the job. |
||||
*/ |
||||
public function handle(): void {} |
||||
} |
@ -1,11 +0,0 @@ |
||||
{ |
||||
"name": "$STUDLY_NAME$", |
||||
"alias": "$LOWER_NAME$", |
||||
"description": "", |
||||
"keywords": [], |
||||
"priority": 0, |
||||
"providers": [ |
||||
"$MODULE_NAMESPACE$\\$STUDLY_NAME$\\$PROVIDER_NAMESPACE$\\$STUDLY_NAME$ServiceProvider" |
||||
], |
||||
"files": [] |
||||
} |
@ -1,19 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Queue\InteractsWithQueue; |
||||
use Illuminate\Contracts\Queue\ShouldQueue; |
||||
|
||||
class $CLASS$ |
||||
{ |
||||
/** |
||||
* Create the event listener. |
||||
*/ |
||||
public function __construct() {} |
||||
|
||||
/** |
||||
* Handle the event. |
||||
*/ |
||||
public function handle($event): void {} |
||||
} |
@ -1,21 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Queue\InteractsWithQueue; |
||||
use Illuminate\Contracts\Queue\ShouldQueue; |
||||
|
||||
class $CLASS$ implements ShouldQueue |
||||
{ |
||||
use InteractsWithQueue; |
||||
|
||||
/** |
||||
* Create the event listener |
||||
*/ |
||||
public function __construct() {} |
||||
|
||||
/** |
||||
* Handle the event. |
||||
*/ |
||||
public function handle($event): void {} |
||||
} |
@ -1,22 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use $EVENTNAME$; |
||||
use Illuminate\Queue\InteractsWithQueue; |
||||
use Illuminate\Contracts\Queue\ShouldQueue; |
||||
|
||||
class $CLASS$ implements ShouldQueue |
||||
{ |
||||
use InteractsWithQueue; |
||||
|
||||
/** |
||||
* Create the event listener. |
||||
*/ |
||||
public function __construct() {} |
||||
|
||||
/** |
||||
* Handle the event. |
||||
*/ |
||||
public function handle($SHORTEVENTNAME$ $event): void {} |
||||
} |
@ -1,20 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use $EVENTNAME$; |
||||
use Illuminate\Queue\InteractsWithQueue; |
||||
use Illuminate\Contracts\Queue\ShouldQueue; |
||||
|
||||
class $CLASS$ |
||||
{ |
||||
/** |
||||
* Create the event listener. |
||||
*/ |
||||
public function __construct() {} |
||||
|
||||
/** |
||||
* Handle the event. |
||||
*/ |
||||
public function handle($SHORTEVENTNAME$ $event): void {} |
||||
} |
@ -1,26 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Bus\Queueable; |
||||
use Illuminate\Mail\Mailable; |
||||
use Illuminate\Queue\SerializesModels; |
||||
use Illuminate\Contracts\Queue\ShouldQueue; |
||||
|
||||
class $CLASS$ extends Mailable |
||||
{ |
||||
use Queueable, SerializesModels; |
||||
|
||||
/** |
||||
* Create a new message instance. |
||||
*/ |
||||
public function __construct() {} |
||||
|
||||
/** |
||||
* Build the message. |
||||
*/ |
||||
public function build(): self |
||||
{ |
||||
return $this->view('view.name'); |
||||
} |
||||
} |
@ -1,17 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Closure; |
||||
use Illuminate\Http\Request; |
||||
|
||||
class $CLASS$ |
||||
{ |
||||
/** |
||||
* Handle an incoming request. |
||||
*/ |
||||
public function handle(Request $request, Closure $next) |
||||
{ |
||||
return $next($request); |
||||
} |
||||
} |
@ -1,28 +0,0 @@ |
||||
<?php |
||||
|
||||
use Illuminate\Database\Migrations\Migration; |
||||
use Illuminate\Database\Schema\Blueprint; |
||||
use Illuminate\Support\Facades\Schema; |
||||
|
||||
return new class extends Migration |
||||
{ |
||||
/** |
||||
* Run the migrations. |
||||
*/ |
||||
public function up(): void |
||||
{ |
||||
Schema::table('$TABLE$', function (Blueprint $table) { |
||||
$FIELDS_UP$ |
||||
}); |
||||
} |
||||
|
||||
/** |
||||
* Reverse the migrations. |
||||
*/ |
||||
public function down(): void |
||||
{ |
||||
Schema::table('$TABLE$', function (Blueprint $table) { |
||||
$FIELDS_DOWN$ |
||||
}); |
||||
} |
||||
}; |
@ -1,28 +0,0 @@ |
||||
<?php |
||||
|
||||
use Illuminate\Database\Migrations\Migration; |
||||
use Illuminate\Database\Schema\Blueprint; |
||||
use Illuminate\Support\Facades\Schema; |
||||
|
||||
return new class extends Migration |
||||
{ |
||||
/** |
||||
* Run the migrations. |
||||
*/ |
||||
public function up(): void |
||||
{ |
||||
Schema::create('$TABLE$', function (Blueprint $table) { |
||||
$table->id(); |
||||
$FIELDS$ |
||||
$table->timestamps(); |
||||
}); |
||||
} |
||||
|
||||
/** |
||||
* Reverse the migrations. |
||||
*/ |
||||
public function down(): void |
||||
{ |
||||
Schema::dropIfExists('$TABLE$'); |
||||
} |
||||
}; |
@ -1,28 +0,0 @@ |
||||
<?php |
||||
|
||||
use Illuminate\Database\Migrations\Migration; |
||||
use Illuminate\Database\Schema\Blueprint; |
||||
use Illuminate\Support\Facades\Schema; |
||||
|
||||
return new class extends Migration |
||||
{ |
||||
/** |
||||
* Run the migrations. |
||||
*/ |
||||
public function up(): void |
||||
{ |
||||
Schema::table('$TABLE$', function (Blueprint $table) { |
||||
$FIELDS_UP$ |
||||
}); |
||||
} |
||||
|
||||
/** |
||||
* Reverse the migrations. |
||||
*/ |
||||
public function down(): void |
||||
{ |
||||
Schema::table('$TABLE$', function (Blueprint $table) { |
||||
$FIELDS_DOWN$ |
||||
}); |
||||
} |
||||
}; |
@ -1,28 +0,0 @@ |
||||
<?php |
||||
|
||||
use Illuminate\Database\Migrations\Migration; |
||||
use Illuminate\Database\Schema\Blueprint; |
||||
use Illuminate\Support\Facades\Schema; |
||||
|
||||
return new class extends Migration |
||||
{ |
||||
/** |
||||
* Run the migrations. |
||||
*/ |
||||
public function up(): void |
||||
{ |
||||
Schema::dropIfExists('$TABLE$'); |
||||
} |
||||
|
||||
/** |
||||
* Reverse the migrations. |
||||
*/ |
||||
public function down(): void |
||||
{ |
||||
Schema::create('$TABLE$', function (Blueprint $table) { |
||||
$table->id(); |
||||
$FIELDS$ |
||||
$table->timestamps(); |
||||
}); |
||||
} |
||||
}; |
@ -1,18 +0,0 @@ |
||||
<?php |
||||
|
||||
use Illuminate\Database\Migrations\Migration; |
||||
use Illuminate\Database\Schema\Blueprint; |
||||
use Illuminate\Support\Facades\Schema; |
||||
|
||||
return new class extends Migration |
||||
{ |
||||
/** |
||||
* Run the migrations. |
||||
*/ |
||||
public function up(): void {} |
||||
|
||||
/** |
||||
* Reverse the migrations. |
||||
*/ |
||||
public function down(): void {} |
||||
}; |
@ -1,22 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Database\Eloquent\Model; |
||||
use Illuminate\Database\Eloquent\Factories\HasFactory; |
||||
// use $MODULE_NAMESPACE$\$MODULE$\Database\Factories\$NAME$Factory; |
||||
|
||||
class $CLASS$ extends Model |
||||
{ |
||||
use HasFactory; |
||||
|
||||
/** |
||||
* The attributes that are mass assignable. |
||||
*/ |
||||
protected $fillable = $FILLABLE$; |
||||
|
||||
// protected static function newFactory(): $NAME$Factory |
||||
// { |
||||
// // return $NAME$Factory::new(); |
||||
// } |
||||
} |
@ -1,45 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Bus\Queueable; |
||||
use Illuminate\Notifications\Notification; |
||||
use Illuminate\Contracts\Queue\ShouldQueue; |
||||
use Illuminate\Notifications\Messages\MailMessage; |
||||
|
||||
class $CLASS$ extends Notification |
||||
{ |
||||
use Queueable; |
||||
|
||||
/** |
||||
* Create a new notification instance. |
||||
*/ |
||||
public function __construct() {} |
||||
|
||||
/** |
||||
* Get the notification's delivery channels. |
||||
*/ |
||||
public function via($notifiable): array |
||||
{ |
||||
return ['mail']; |
||||
} |
||||
|
||||
/** |
||||
* Get the mail representation of the notification. |
||||
*/ |
||||
public function toMail($notifiable): MailMessage |
||||
{ |
||||
return (new MailMessage) |
||||
->line('The introduction to the notification.') |
||||
->action('Notification Action', 'https://laravel.com') |
||||
->line('Thank you for using our application!'); |
||||
} |
||||
|
||||
/** |
||||
* Get the array representation of the notification. |
||||
*/ |
||||
public function toArray($notifiable): array |
||||
{ |
||||
return []; |
||||
} |
||||
} |
@ -1,33 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use $MODEL_NAMESPACE$\$NAME$; |
||||
|
||||
class $NAME$Observer |
||||
{ |
||||
/** |
||||
* Handle the $NAME$ "created" event. |
||||
*/ |
||||
public function created($NAME$ $NAME_VARIABLE$): void {} |
||||
|
||||
/** |
||||
* Handle the $NAME$ "updated" event. |
||||
*/ |
||||
public function updated($NAME$ $NAME_VARIABLE$): void {} |
||||
|
||||
/** |
||||
* Handle the $NAME$ "deleted" event. |
||||
*/ |
||||
public function deleted($NAME$ $NAME_VARIABLE$): void {} |
||||
|
||||
/** |
||||
* Handle the $NAME$ "restored" event. |
||||
*/ |
||||
public function restored($NAME$ $NAME_VARIABLE$): void {} |
||||
|
||||
/** |
||||
* Handle the $NAME$ "force deleted" event. |
||||
*/ |
||||
public function forceDeleted($NAME$ $NAME_VARIABLE$): void {} |
||||
} |
@ -1,15 +0,0 @@ |
||||
{ |
||||
"private": true, |
||||
"type": "module", |
||||
"scripts": { |
||||
"dev": "vite", |
||||
"build": "vite build" |
||||
}, |
||||
"devDependencies": { |
||||
"axios": "^1.1.2", |
||||
"laravel-vite-plugin": "^0.7.5", |
||||
"sass": "^1.69.5", |
||||
"postcss": "^8.3.7", |
||||
"vite": "^4.0.0" |
||||
} |
||||
} |
@ -1,15 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Auth\Access\HandlesAuthorization; |
||||
|
||||
class $CLASS$ |
||||
{ |
||||
use HandlesAuthorization; |
||||
|
||||
/** |
||||
* Create a new policy instance. |
||||
*/ |
||||
public function __construct() {} |
||||
} |
@ -1,21 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Support\ServiceProvider; |
||||
|
||||
class $CLASS$ extends ServiceProvider |
||||
{ |
||||
/** |
||||
* Register the service provider. |
||||
*/ |
||||
public function register(): void {} |
||||
|
||||
/** |
||||
* Get the services provided by the provider. |
||||
*/ |
||||
public function provides(): array |
||||
{ |
||||
return []; |
||||
} |
||||
} |
@ -1,8 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
class $CLASS$ |
||||
{ |
||||
public function __invoke() {} |
||||
} |
@ -1,8 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
class $CLASS$ |
||||
{ |
||||
public function handle() {} |
||||
} |
@ -1,24 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Foundation\Http\FormRequest; |
||||
|
||||
class $CLASS$ extends FormRequest |
||||
{ |
||||
/** |
||||
* Get the validation rules that apply to the request. |
||||
*/ |
||||
public function rules(): array |
||||
{ |
||||
return []; |
||||
} |
||||
|
||||
/** |
||||
* Determine if the user is authorized to make this request. |
||||
*/ |
||||
public function authorize(): bool |
||||
{ |
||||
return true; |
||||
} |
||||
} |
@ -1,17 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Http\Request; |
||||
use Illuminate\Http\Resources\Json\ResourceCollection; |
||||
|
||||
class $CLASS$ extends ResourceCollection |
||||
{ |
||||
/** |
||||
* Transform the resource collection into an array. |
||||
*/ |
||||
public function toArray(Request $request): array |
||||
{ |
||||
return parent::toArray($request); |
||||
} |
||||
} |
@ -1,17 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Http\Request; |
||||
use Illuminate\Http\Resources\Json\JsonResource; |
||||
|
||||
class $CLASS$ extends JsonResource |
||||
{ |
||||
/** |
||||
* Transform the resource into an array. |
||||
*/ |
||||
public function toArray(Request $request): array |
||||
{ |
||||
return parent::toArray($request); |
||||
} |
||||
} |
@ -1,50 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider; |
||||
use Illuminate\Support\Facades\Route; |
||||
|
||||
class $CLASS$ extends ServiceProvider |
||||
{ |
||||
protected string $name = '$MODULE$'; |
||||
|
||||
/** |
||||
* Called before routes are registered. |
||||
* |
||||
* Register any model bindings or pattern based filters. |
||||
*/ |
||||
public function boot(): void |
||||
{ |
||||
parent::boot(); |
||||
} |
||||
|
||||
/** |
||||
* Define the routes for the application. |
||||
*/ |
||||
public function map(): void |
||||
{ |
||||
$this->mapApiRoutes(); |
||||
$this->mapWebRoutes(); |
||||
} |
||||
|
||||
/** |
||||
* Define the "web" routes for the application. |
||||
* |
||||
* These routes all receive session state, CSRF protection, etc. |
||||
*/ |
||||
protected function mapWebRoutes(): void |
||||
{ |
||||
Route::middleware('web')->group(module_path($this->name, '$WEB_ROUTES_PATH$')); |
||||
} |
||||
|
||||
/** |
||||
* Define the "api" routes for the application. |
||||
* |
||||
* These routes are typically stateless. |
||||
*/ |
||||
protected function mapApiRoutes(): void |
||||
{ |
||||
Route::middleware('api')->prefix('api')->name('api.')->group(module_path($this->name, '$API_ROUTES_PATH$')); |
||||
} |
||||
} |
@ -1,8 +0,0 @@ |
||||
<?php |
||||
|
||||
use Illuminate\Support\Facades\Route; |
||||
use $MODULE_NAMESPACE$\$STUDLY_NAME$\$CONTROLLER_NAMESPACE$\$STUDLY_NAME$Controller; |
||||
|
||||
Route::middleware(['auth:sanctum'])->prefix('v1')->group(function () { |
||||
Route::apiResource('$PLURAL_LOWER_NAME$', $STUDLY_NAME$Controller::class)->names('$LOWER_NAME$'); |
||||
}); |
@ -1,8 +0,0 @@ |
||||
<?php |
||||
|
||||
use Illuminate\Support\Facades\Route; |
||||
use $MODULE_NAMESPACE$\$STUDLY_NAME$\$CONTROLLER_NAMESPACE$\$STUDLY_NAME$Controller; |
||||
|
||||
Route::middleware(['auth', 'verified'])->group(function () { |
||||
Route::resource('$PLURAL_LOWER_NAME$', $STUDLY_NAME$Controller::class)->names('$LOWER_NAME$'); |
||||
}); |
@ -1,19 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Closure; |
||||
use Illuminate\Contracts\Validation\ValidationRule; |
||||
|
||||
class $CLASS$ implements ValidationRule |
||||
{ |
||||
/** |
||||
* Indicates whether the rule should be implicit. |
||||
*/ |
||||
public bool $implicit = true; |
||||
|
||||
/** |
||||
* Run the validation rule. |
||||
*/ |
||||
public function validate(string $attribute, mixed $value, Closure $fail): void {} |
||||
} |
@ -1,14 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Closure; |
||||
use Illuminate\Contracts\Validation\ValidationRule; |
||||
|
||||
class $CLASS$ implements ValidationRule |
||||
{ |
||||
/** |
||||
* Run the validation rule. |
||||
*/ |
||||
public function validate(string $attribute, mixed $value, Closure $fail): void {} |
||||
} |
@ -1,5 +0,0 @@ |
||||
<?php |
||||
|
||||
return [ |
||||
'name' => '$STUDLY_NAME$', |
||||
]; |
@ -1,154 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Support\Facades\Blade; |
||||
use Illuminate\Support\ServiceProvider; |
||||
use Nwidart\Modules\Traits\PathNamespace; |
||||
use RecursiveDirectoryIterator; |
||||
use RecursiveIteratorIterator; |
||||
|
||||
class $CLASS$ extends ServiceProvider |
||||
{ |
||||
use PathNamespace; |
||||
|
||||
protected string $name = '$MODULE$'; |
||||
|
||||
protected string $nameLower = '$LOWER_NAME$'; |
||||
|
||||
/** |
||||
* Boot the application events. |
||||
*/ |
||||
public function boot(): void |
||||
{ |
||||
$this->registerCommands(); |
||||
$this->registerCommandSchedules(); |
||||
$this->registerTranslations(); |
||||
$this->registerConfig(); |
||||
$this->registerViews(); |
||||
$this->loadMigrationsFrom(module_path($this->name, '$MIGRATIONS_PATH$')); |
||||
} |
||||
|
||||
/** |
||||
* Register the service provider. |
||||
*/ |
||||
public function register(): void |
||||
{ |
||||
$this->app->register(EventServiceProvider::class); |
||||
$this->app->register(RouteServiceProvider::class); |
||||
} |
||||
|
||||
/** |
||||
* Register commands in the format of Command::class |
||||
*/ |
||||
protected function registerCommands(): void |
||||
{ |
||||
// $this->commands([]); |
||||
} |
||||
|
||||
/** |
||||
* Register command Schedules. |
||||
*/ |
||||
protected function registerCommandSchedules(): void |
||||
{ |
||||
// $this->app->booted(function () { |
||||
// $schedule = $this->app->make(Schedule::class); |
||||
// $schedule->command('inspire')->hourly(); |
||||
// }); |
||||
} |
||||
|
||||
/** |
||||
* Register translations. |
||||
*/ |
||||
public function registerTranslations(): void |
||||
{ |
||||
$langPath = resource_path('lang/modules/'.$this->nameLower); |
||||
|
||||
if (is_dir($langPath)) { |
||||
$this->loadTranslationsFrom($langPath, $this->nameLower); |
||||
$this->loadJsonTranslationsFrom($langPath); |
||||
} else { |
||||
$this->loadTranslationsFrom(module_path($this->name, '$PATH_LANG$'), $this->nameLower); |
||||
$this->loadJsonTranslationsFrom(module_path($this->name, '$PATH_LANG$')); |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* Register config. |
||||
*/ |
||||
protected function registerConfig(): void |
||||
{ |
||||
$configPath = module_path($this->name, config('modules.paths.generator.config.path')); |
||||
|
||||
if (is_dir($configPath)) { |
||||
$iterator = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($configPath)); |
||||
|
||||
foreach ($iterator as $file) { |
||||
if ($file->isFile() && $file->getExtension() === 'php') { |
||||
$config = str_replace($configPath.DIRECTORY_SEPARATOR, '', $file->getPathname()); |
||||
$config_key = str_replace([DIRECTORY_SEPARATOR, '.php'], ['.', ''], $config); |
||||
$segments = explode('.', $this->nameLower.'.'.$config_key); |
||||
|
||||
// Remove duplicated adjacent segments |
||||
$normalized = []; |
||||
foreach ($segments as $segment) { |
||||
if (end($normalized) !== $segment) { |
||||
$normalized[] = $segment; |
||||
} |
||||
} |
||||
|
||||
$key = ($config === 'config.php') ? $this->nameLower : implode('.', $normalized); |
||||
|
||||
$this->publishes([$file->getPathname() => config_path($config)], 'config'); |
||||
$this->merge_config_from($file->getPathname(), $key); |
||||
} |
||||
} |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* Merge config from the given path recursively. |
||||
*/ |
||||
protected function merge_config_from(string $path, string $key): void |
||||
{ |
||||
$existing = config($key, []); |
||||
$module_config = require $path; |
||||
|
||||
config([$key => array_replace_recursive($existing, $module_config)]); |
||||
} |
||||
|
||||
/** |
||||
* Register views. |
||||
*/ |
||||
public function registerViews(): void |
||||
{ |
||||
$viewPath = resource_path('views/modules/'.$this->nameLower); |
||||
$sourcePath = module_path($this->name, '$PATH_VIEWS$'); |
||||
|
||||
$this->publishes([$sourcePath => $viewPath], ['views', $this->nameLower.'-module-views']); |
||||
|
||||
$this->loadViewsFrom(array_merge($this->getPublishableViewPaths(), [$sourcePath]), $this->nameLower); |
||||
|
||||
Blade::componentNamespace(config('modules.namespace').'\\' . $this->name . '\\View\\Components', $this->nameLower); |
||||
} |
||||
|
||||
/** |
||||
* Get the services provided by the provider. |
||||
*/ |
||||
public function provides(): array |
||||
{ |
||||
return []; |
||||
} |
||||
|
||||
private function getPublishableViewPaths(): array |
||||
{ |
||||
$paths = []; |
||||
foreach (config('view.paths') as $path) { |
||||
if (is_dir($path.'/modules/'.$this->nameLower)) { |
||||
$paths[] = $path.'/modules/'.$this->nameLower; |
||||
} |
||||
} |
||||
|
||||
return $paths; |
||||
} |
||||
} |
@ -1,15 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
use Illuminate\Database\Eloquent\Builder; |
||||
use Illuminate\Database\Eloquent\Model; |
||||
use Illuminate\Database\Eloquent\Scope; |
||||
|
||||
class $CLASS$ implements Scope |
||||
{ |
||||
/** |
||||
* Apply the scope to a given Eloquent query builder. |
||||
*/ |
||||
public function apply(Builder $builder, Model $model): void {} |
||||
} |
@ -1,16 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Illuminate\Database\Seeder; |
||||
|
||||
class $NAME$ extends Seeder |
||||
{ |
||||
/** |
||||
* Run the database seeds. |
||||
*/ |
||||
public function run(): void |
||||
{ |
||||
// $this->call([]); |
||||
} |
||||
} |
@ -1,8 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
class $CLASS$ |
||||
{ |
||||
public function __invoke() {} |
||||
} |
@ -1,8 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
class $CLASS$ |
||||
{ |
||||
public function handle() {} |
||||
} |
@ -1,18 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Tests\TestCase; |
||||
|
||||
class $CLASS$ extends TestCase |
||||
{ |
||||
/** |
||||
* A basic test example. |
||||
*/ |
||||
public function test_the_application_returns_a_successful_response(): void |
||||
{ |
||||
$response = $this->get('/'); |
||||
|
||||
$response->assertStatus(200); |
||||
} |
||||
} |
@ -1,16 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $NAMESPACE$; |
||||
|
||||
use Tests\TestCase; |
||||
|
||||
class $CLASS$ extends TestCase |
||||
{ |
||||
/** |
||||
* A basic test example. |
||||
*/ |
||||
public function test_that_true_is_true(): void |
||||
{ |
||||
$this->assertTrue(true); |
||||
} |
||||
} |
@ -1,5 +0,0 @@ |
||||
<?php |
||||
|
||||
namespace $CLASS_NAMESPACE$; |
||||
|
||||
trait $CLASS$ {} |
@ -1,3 +0,0 @@ |
||||
<div> |
||||
<!-- $QUOTE$ --> |
||||
</div> |
@ -1,5 +0,0 @@ |
||||
<x-$LOWER_NAME$::layouts.master> |
||||
<h1>Hello World</h1> |
||||
|
||||
<p>Module: {!! config('$LOWER_NAME$.name') !!}</p> |
||||
</x-$LOWER_NAME$::layouts.master> |
@ -1,29 +0,0 @@ |
||||
<!DOCTYPE html> |
||||
<html lang="{{ str_replace('_', '-', app()->getLocale()) }}"> |
||||
|
||||
<head> |
||||
<meta charset="utf-8"> |
||||
<meta name="viewport" content="width=device-width, initial-scale=1"> |
||||
<meta name="csrf-token" content="{{ csrf_token() }}"> |
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge"> |
||||
|
||||
<title>$STUDLY_NAME$ Module - {{ config('app.name', 'Laravel') }}</title> |
||||
|
||||
<meta name="description" content="{{ $description ?? '' }}"> |
||||
<meta name="keywords" content="{{ $keywords ?? '' }}"> |
||||
<meta name="author" content="{{ $author ?? '' }}"> |
||||
|
||||
<!-- Fonts --> |
||||
<link rel="preconnect" href="https://fonts.bunny.net"> |
||||
<link href="https://fonts.bunny.net/css?family=figtree:400,500,600&display=swap" rel="stylesheet" /> |
||||
|
||||
{{-- Vite CSS --}} |
||||
{{-- {{ module_vite('build-$LOWER_NAME$', 'resources/assets/sass/app.scss') }} --}} |
||||
</head> |
||||
|
||||
<body> |
||||
{{ $slot }} |
||||
|
||||
{{-- Vite JS --}} |
||||
{{-- {{ module_vite('build-$LOWER_NAME$', 'resources/assets/js/app.js') }} --}} |
||||
</body> |
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in new issue