diff --git a/src/Commands/ModuleMakeFilamentThemeCommand.php b/src/Commands/ModuleMakeFilamentThemeCommand.php index b47c908b..c7f03e6b 100644 --- a/src/Commands/ModuleMakeFilamentThemeCommand.php +++ b/src/Commands/ModuleMakeFilamentThemeCommand.php @@ -40,7 +40,7 @@ public function handle(): int 'yarn' => 'yarn add', default => "{$pm} install", }; - $cdCommand = 'cd '.$module->getPath(); + $cdCommand = 'cd ' . $module->getPath(); exec("$cdCommand && {$installCommand} tailwindcss @tailwindcss/forms @tailwindcss/typography postcss postcss-nesting autoprefixer --save-dev"); @@ -66,9 +66,9 @@ public function handle(): int 'viewPathPrefix' => $viewPathPrefix, ]); - $this->components->info('Filament theme [resources/css/filament/theme.css] and [resources/css/filament/tailwind.config.js] created successfully in '.$module->getStudlyName().' module.'); + $this->components->info('Filament theme [resources/css/filament/theme.css] and [resources/css/filament/tailwind.config.js] created successfully in ' . $module->getStudlyName() . ' module.'); - $buildDirectory = 'build-'.$module->getLowerName(); + $buildDirectory = 'build-' . $module->getLowerName(); $moduleStudlyName = $module->getStudlyName(); if (empty(glob($module->getExtraPath('vite.config.*s')))) { @@ -76,7 +76,7 @@ public function handle(): int $this->components->bulletList([ "It looks like you don't have Vite installed in your module. Please use your asset bundling system of choice to compile `resources/css/filament/theme.css` into `public/$buildDirectory/css/filament/theme.css`.", "If you're not currently using a bundler, we recommend using Vite. Alternatively, you can use the Tailwind CLI with the following command inside the $moduleStudlyName module:", - 'npx tailwindcss --input ./resources/css/filament/theme.css --output ./public/'.$buildDirectory.'/css/filament/theme.css --config ./resources/css/filament/tailwind.config.js --minify', + 'npx tailwindcss --input ./resources/css/filament/theme.css --output ./public/' . $buildDirectory . '/css/filament/theme.css --config ./resources/css/filament/tailwind.config.js --minify', "Make sure to register the theme in the {$moduleStudlyName} module plugin under the afterRegister() function using `->theme(asset('css/filament/theme.css'))`", ]); @@ -103,7 +103,7 @@ public function handle(): int protected function getDefaultStubPath(): string { - return __DIR__.'/stubs'; + return __DIR__ . '/stubs'; } private function getModule(): Module diff --git a/src/Concerns/ModuleFilamentPlugin.php b/src/Concerns/ModuleFilamentPlugin.php index a18868fb..abb5214e 100644 --- a/src/Concerns/ModuleFilamentPlugin.php +++ b/src/Concerns/ModuleFilamentPlugin.php @@ -19,15 +19,15 @@ public function register(Panel $panel): void $module = $this->getModule(); $useClusters = config('filament-modules.clusters.enabled', false); $panel->discoverPages( - in: $module->appPath('Filament'.DIRECTORY_SEPARATOR.'Pages'), + in: $module->appPath('Filament' . DIRECTORY_SEPARATOR . 'Pages'), for: $module->appNamespace('\\Filament\\Pages') ); $panel->discoverResources( - in: $module->appPath('Filament'.DIRECTORY_SEPARATOR.'Resources'), + in: $module->appPath('Filament' . DIRECTORY_SEPARATOR . 'Resources'), for: $module->appNamespace('\\Filament\\Resources') ); $panel->discoverWidgets( - in: $module->appPath('Filament'.DIRECTORY_SEPARATOR.'Widgets'), + in: $module->appPath('Filament' . DIRECTORY_SEPARATOR . 'Widgets'), for: $module->appNamespace('\\Filament\\Widgets') ); @@ -37,7 +37,7 @@ public function register(Panel $panel): void ); if ($useClusters) { - $path = $module->appPath('Filament'.DIRECTORY_SEPARATOR.'Clusters'); + $path = $module->appPath('Filament' . DIRECTORY_SEPARATOR . 'Clusters'); $namespace = $module->appNamespace('\\Filament\\Clusters'); $panel->discoverClusters( in: $path, diff --git a/src/Modules.php b/src/Modules.php index 9579993e..5480dae0 100644 --- a/src/Modules.php +++ b/src/Modules.php @@ -18,14 +18,15 @@ public function getModule(string $name): \Nwidart\Modules\Module public function convertPathToNamespace(string $fullPath): string { - $base = str(trim(config('modules.paths.modules', base_path('Modules')), '/')); - $relative = str($fullPath)->afterLast($base)->replaceFirst('/app/', '/'); + $base = str(trim(config('modules.paths.modules', base_path('Modules')), DIRECTORY_SEPARATOR . '/')); + $relative = str($fullPath)->afterLast($base)->replaceFirst(DIRECTORY_SEPARATOR . 'app' . DIRECTORY_SEPARATOR, DIRECTORY_SEPARATOR); return str($relative) - ->ltrim('/') - ->prepend('/') + ->ltrim(DIRECTORY_SEPARATOR . '/') + ->prepend(DIRECTORY_SEPARATOR . '/') ->prepend(config('modules.namespace', 'Modules')) ->replace(DIRECTORY_SEPARATOR, '\\') + ->replace('\\\\', '\\') ->rtrim('.php') ->explode(DIRECTORY_SEPARATOR) ->map(fn ($piece) => str($piece)->studly()->toString()) diff --git a/src/ModulesServiceProvider.php b/src/ModulesServiceProvider.php index ca117581..9583169b 100644 --- a/src/ModulesServiceProvider.php +++ b/src/ModulesServiceProvider.php @@ -64,17 +64,18 @@ public function packageRegistered(): void public function attemptToRegisterModuleProviders(): void { // It is necessary to register them here to avoid late registration (after Panels have already been booted) - $providers = glob(config('modules.paths.modules').'/*/*/Providers/*ServiceProvider.php'); + $providers = glob(config('modules.paths.modules') . '/*/*/Providers/*ServiceProvider.php'); foreach ($providers as $provider) { $namespace = FilamentModules::convertPathToNamespace($provider); $module = str($namespace)->before('\Providers\\')->afterLast('\\')->toString(); $className = str($namespace)->afterLast('\\')->toString(); - if (str($className)->startsWith($module)){ + if (str($className)->startsWith($module)) { // register the module service provider $this->app->register($namespace); } } } + public function packageBooted(): void { $this->attemptToRegisterModuleProviders(); @@ -94,7 +95,7 @@ public function packageBooted(): void // Handle Stubs if (app()->runningInConsole()) { - foreach (app(Filesystem::class)->files(__DIR__.'/../stubs/') as $file) { + foreach (app(Filesystem::class)->files(__DIR__ . '/../stubs/') as $file) { $this->publishes([ $file->getRealPath() => base_path("stubs/modules/{$file->getFilename()}"), ], 'modules-stubs'); @@ -187,44 +188,44 @@ protected function registerModuleMacros(): void $relativeNamespace = str_replace('App\\', '', $relativeNamespace); $relativeNamespace = str_replace('App', '', $relativeNamespace); $relativeNamespace = trim($relativeNamespace, '\\'); - $relativeNamespace = '\\'.$relativeNamespace; + $relativeNamespace = '\\' . $relativeNamespace; return $this->namespace($relativeNamespace); }); Module::macro('appPath', function (string $relativePath = '') { $appPath = $this->getExtraPath('app'); - return $appPath.($relativePath ? DIRECTORY_SEPARATOR.$relativePath : ''); + return $appPath . ($relativePath ? DIRECTORY_SEPARATOR . $relativePath : ''); }); Module::macro('databasePath', function (string $relativePath = '') { $appPath = $this->getExtraPath('database'); - return $appPath.($relativePath ? DIRECTORY_SEPARATOR.$relativePath : ''); + return $appPath . ($relativePath ? DIRECTORY_SEPARATOR . $relativePath : ''); }); Module::macro('resourcesPath', function (string $relativePath = '') { $appPath = $this->getExtraPath('resources'); - return $appPath.($relativePath ? DIRECTORY_SEPARATOR.$relativePath : ''); + return $appPath . ($relativePath ? DIRECTORY_SEPARATOR . $relativePath : ''); }); Module::macro('migrationsPath', function (string $relativePath = '') { $appPath = $this->databasePath('migrations'); - return $appPath.($relativePath ? DIRECTORY_SEPARATOR.$relativePath : ''); + return $appPath . ($relativePath ? DIRECTORY_SEPARATOR . $relativePath : ''); }); Module::macro('seedersPath', function (string $relativePath = '') { $appPath = $this->databasePath('seeders'); - return $appPath.($relativePath ? DIRECTORY_SEPARATOR.$relativePath : ''); + return $appPath . ($relativePath ? DIRECTORY_SEPARATOR . $relativePath : ''); }); Module::macro('factoriesPath', function (string $relativePath = '') { $appPath = $this->databasePath('factories'); - return $appPath.($relativePath ? DIRECTORY_SEPARATOR.$relativePath : ''); + return $appPath . ($relativePath ? DIRECTORY_SEPARATOR . $relativePath : ''); }); } }