
Laravel Themer package: add multi-theme support for Laravel application
This Laravel Themer package adds multi-theme support to your Laravel application. It also provides a simple authentication scaffolding and presets for Bootstrap, Tailwind, Vue, and React as a starting point for building a Laravel application.
In my opinion, this Laravel Themer package is a better alternative to the official laravel/ui
& laravel/breeze
packages because of the following features:
- Any number of themes
- Fallback theme support (WordPress style); It allows creating a child theme to extend any theme
- Provides authentication scaffolding similar to
laravel/ui
&laravel/breeze
- Exports all auth controllers, tests, and other files similar to
laravel/breeze
- Provides frontend presets for Bootstrap, Tailwind, Vue 2, Vue 3, and React
If you don’t want to use this package’s auth scaffolding, instead, you want to use Laravel Fortify, no problem with that. You can use Laravel Themer with Fortify as well. Laravel Fortify is a frontend agnostic authentication backend for Laravel, and it does not provide views or frontend presets. So, use Fortify for backend authentication and Laravel Themer for your views, presets, and for multi-theme support.
Video Tutorial
Installation
Install via composer
composer require qirolab/laravel-themer
Publish a configuration file:
php artisan vendor:publish --provider="QirolabThemeThemeServiceProvider" --tag="config"
Creating a theme
Use the following command to create a theme:
php artisan make:theme
Middleware to set a theme
Register ThemeMiddleware
in appHttpKernel.php
:
protected $routeMiddleware = [
// ...
'theme' => QirolabThemeMiddlewareThemeMiddleware::class,
];
Examples for middleware usage:
Route::get('/dashboard', 'DashboardController@index')
->middleware('theme:dashboard-theme');
Theme methods:
// Set active theme
Theme::set('theme-name');
// Get current active theme
Theme::active();
// Get current parent theme
Theme::parent();
// Clear theme. So, no theme will be active
Theme::clear();
// Get theme path
Theme::path($path="views");
// output:
// /app-root-path/themes/active-theme/views
Theme::path($path="views", $themeName="admin");
// output:
// /app-root-path/themes/admin/views
Theme::getViewPaths();
// Output:
// [
// '/app-root-path/themes/admin/views',
// '/app-root-path/resources/views'
// ]
webpack.mix.js
Configuration
After creating a new theme, it creates a separate webpack.mix.js
file for that theme. So, to compile the theme’s webpack.mix.js
file it should be included in the app’s webpack.mix.js
that is located in the root path.
// add this in the root `webpack.mix.js`
require(`${__dirname}/themes/theme-name/webpack.mix.js`);
In the case of multiple themes, If you add multiple webpack.mix.js
of different themes. Then webpack
may not compile these correctly. So, you should modify the root webpack.mix.js
with the following code:
let theme = process.env.npm_config_theme;
if(theme) {
require(`${__dirname}/themes/${theme}/webpack.mix.js`);
} else {
// default theme to compile if theme is not specified
require(`${__dirname}/themes/theme-name/webpack.mix.js`);
}
Now, you can use the following command to compile assets for a particular theme:
npm run dev --theme=theme-name
Credit: Source link