diff --git a/Modules/Expense/Config/.gitkeep b/Modules/Expense/Config/.gitkeep new file mode 100644 index 00000000..e69de29b diff --git a/Modules/Expense/Config/config.php b/Modules/Expense/Config/config.php new file mode 100644 index 00000000..31207b7c --- /dev/null +++ b/Modules/Expense/Config/config.php @@ -0,0 +1,5 @@ + 'Expense' +]; diff --git a/Modules/Expense/Console/.gitkeep b/Modules/Expense/Console/.gitkeep new file mode 100644 index 00000000..e69de29b diff --git a/Modules/Expense/Database/Migrations/.gitkeep b/Modules/Expense/Database/Migrations/.gitkeep new file mode 100644 index 00000000..e69de29b diff --git a/Modules/Expense/Database/Seeders/.gitkeep b/Modules/Expense/Database/Seeders/.gitkeep new file mode 100644 index 00000000..e69de29b diff --git a/Modules/Expense/Database/Seeders/ExpenseDatabaseSeeder.php b/Modules/Expense/Database/Seeders/ExpenseDatabaseSeeder.php new file mode 100644 index 00000000..4396768e --- /dev/null +++ b/Modules/Expense/Database/Seeders/ExpenseDatabaseSeeder.php @@ -0,0 +1,21 @@ +call("OthersTableSeeder"); + } +} diff --git a/Modules/Expense/Database/factories/.gitkeep b/Modules/Expense/Database/factories/.gitkeep new file mode 100644 index 00000000..e69de29b diff --git a/Modules/Expense/Entities/.gitkeep b/Modules/Expense/Entities/.gitkeep new file mode 100644 index 00000000..e69de29b diff --git a/Modules/Expense/Http/Controllers/.gitkeep b/Modules/Expense/Http/Controllers/.gitkeep new file mode 100644 index 00000000..e69de29b diff --git a/Modules/Expense/Http/Controllers/ExpenseController.php b/Modules/Expense/Http/Controllers/ExpenseController.php new file mode 100644 index 00000000..f7886473 --- /dev/null +++ b/Modules/Expense/Http/Controllers/ExpenseController.php @@ -0,0 +1,79 @@ +registerTranslations(); + $this->registerConfig(); + $this->registerViews(); + $this->loadMigrationsFrom(module_path($this->moduleName, 'Database/Migrations')); + } + + /** + * Register the service provider. + * + * @return void + */ + public function register() + { + $this->app->register(RouteServiceProvider::class); + } + + /** + * Register config. + * + * @return void + */ + protected function registerConfig() + { + $this->publishes([ + module_path($this->moduleName, 'Config/config.php') => config_path($this->moduleNameLower . '.php'), + ], 'config'); + $this->mergeConfigFrom( + module_path($this->moduleName, 'Config/config.php'), $this->moduleNameLower + ); + } + + /** + * Register views. + * + * @return void + */ + public function registerViews() + { + $viewPath = resource_path('views/modules/' . $this->moduleNameLower); + + $sourcePath = module_path($this->moduleName, 'Resources/views'); + + $this->publishes([ + $sourcePath => $viewPath + ], ['views', $this->moduleNameLower . '-module-views']); + + $this->loadViewsFrom(array_merge($this->getPublishableViewPaths(), [$sourcePath]), $this->moduleNameLower); + } + + /** + * Register translations. + * + * @return void + */ + public function registerTranslations() + { + $langPath = resource_path('lang/modules/' . $this->moduleNameLower); + + if (is_dir($langPath)) { + $this->loadTranslationsFrom($langPath, $this->moduleNameLower); + } else { + $this->loadTranslationsFrom(module_path($this->moduleName, 'Resources/lang'), $this->moduleNameLower); + } + } + + /** + * Get the services provided by the provider. + * + * @return array + */ + public function provides() + { + return []; + } + + private function getPublishableViewPaths(): array + { + $paths = []; + foreach (\Config::get('view.paths') as $path) { + if (is_dir($path . '/modules/' . $this->moduleNameLower)) { + $paths[] = $path . '/modules/' . $this->moduleNameLower; + } + } + return $paths; + } +} diff --git a/Modules/Expense/Providers/RouteServiceProvider.php b/Modules/Expense/Providers/RouteServiceProvider.php new file mode 100644 index 00000000..15097093 --- /dev/null +++ b/Modules/Expense/Providers/RouteServiceProvider.php @@ -0,0 +1,69 @@ +mapApiRoutes(); + + $this->mapWebRoutes(); + } + + /** + * Define the "web" routes for the application. + * + * These routes all receive session state, CSRF protection, etc. + * + * @return void + */ + protected function mapWebRoutes() + { + Route::middleware('web') + ->namespace($this->moduleNamespace) + ->group(module_path('Expense', '/Routes/web.php')); + } + + /** + * Define the "api" routes for the application. + * + * These routes are typically stateless. + * + * @return void + */ + protected function mapApiRoutes() + { + Route::prefix('api') + ->middleware('api') + ->namespace($this->moduleNamespace) + ->group(module_path('Expense', '/Routes/api.php')); + } +} diff --git a/Modules/Expense/Resources/assets/.gitkeep b/Modules/Expense/Resources/assets/.gitkeep new file mode 100644 index 00000000..e69de29b diff --git a/Modules/Expense/Resources/assets/js/app.js b/Modules/Expense/Resources/assets/js/app.js new file mode 100644 index 00000000..e69de29b diff --git a/Modules/Expense/Resources/assets/sass/app.scss b/Modules/Expense/Resources/assets/sass/app.scss new file mode 100644 index 00000000..e69de29b diff --git a/Modules/Expense/Resources/lang/.gitkeep b/Modules/Expense/Resources/lang/.gitkeep new file mode 100644 index 00000000..e69de29b diff --git a/Modules/Expense/Resources/views/.gitkeep b/Modules/Expense/Resources/views/.gitkeep new file mode 100644 index 00000000..e69de29b diff --git a/Modules/Expense/Resources/views/index.blade.php b/Modules/Expense/Resources/views/index.blade.php new file mode 100644 index 00000000..7b782e98 --- /dev/null +++ b/Modules/Expense/Resources/views/index.blade.php @@ -0,0 +1,9 @@ +@extends('expense::layouts.master') + +@section('content') +
+ This view is loaded from module: {!! config('expense.name') !!} +
+@endsection diff --git a/Modules/Expense/Resources/views/layouts/master.blade.php b/Modules/Expense/Resources/views/layouts/master.blade.php new file mode 100644 index 00000000..eb0367d3 --- /dev/null +++ b/Modules/Expense/Resources/views/layouts/master.blade.php @@ -0,0 +1,19 @@ + + + + + + +