A basic authentication starter kit using Laravel, Intertia.js, and PrimeVue. An equivalent to using Laravel Breeze, but with the added benefit of all the PrimeVue components at your disposal.
Do you need a separate Vue SPA front-end instead of using Inertia.js? Consider using the Vue SPA w/ PrimeVue & Laravel Breeze API Starter Kit instead.
- Same auth structure and features as Laravel Breeze with User Profile page
- Need an admin panel? There's a branch for that.
- Need SSR support? There's a branch for that.
- Pre-configured Auto Import PrimeVue components
- Wrapper components for PrimeVue's
Breadcrumb
,Menu
,MenuBar
, &PanelMenu
utilizing Inertia'sLink
component - Light/Dark mode toggle
usePaginatedData()
&useLazyDataTable()
composables for use with PrimeVue'sDataTable
component for easy pagination/filtering/sorting (example usage infeature/admin-panel
branch)- Easily customizable theming
- Configured to use TypeScript (not required)
This starter kit provides a light/dark mode toggle by default, and custom theme functionality provided by the powerful PrimeVue V4 theming system, using styled mode and custom design token values.
The starting point for customizing your theme will be the resources/js/theme-preset.js
module file. To quickly change the look and feel of your site, swap the primary values with a different set of colors, change the surface colorScheme
values (slate, gray, neutral, etc.), or completely change the preset theme (Aura used by default).
Please reference the PrimeVue Styled Mode Docs to fully understand how this system works, and how to further customize your theme to make it your own.
If you have used a previous version of this project using PrimeVue V3, you'll know that PrimeFlex was used instead of Tailwind CSS for utility class styling. With V4 however, the PrimeTek team has officially suggested Moving from PrimeFlex to Tailwind CSS.
For this reason PrimeFlex has been removed, and Tailwind has been added into the project, along with the tailwindcss-primeui plugin. CSS layers have also been implemented so the Tailwind utilities can override the PrimeVue component styling when needed.
This starter kit is configured to use Docker Compose for local development with just a few extra steps, powered by images & configuration from Laravel Sail. With this setup, you do not need PHP, Composer, PostgreSQL or Node.js installed on your machine to get up and running with this project.
-
In a new directory (outside of your Laravel project) create a
docker-compose.yml
file to create a reverse proxy container using Traefik. You can clone/reference this example implementation. -
Step into the directory containing the new compose file, and spin up the Traefik container:
docker compose up -d
-
Update Laravel app
.env
# Use any desired domain ending with .localhost # Match with value used in docker-compose.local.yml APP_URL=http://primevue-inertia.localhost DB_CONNECTION=pgsql DB_HOST=pgsql # name of service DB_PORT=5432 DB_DATABASE=laravel DB_USERNAME=sail DB_PASSWORD=password # Update port values as needed when running multiple projects APP_PORT=8000 VITE_PORT=5173 FORWARD_DB_PORT=5432
-
Build the Laravel app container using one of the following techniques:
- Build manually using docker compose CLI (like above)
- Use Laravel Sail
- Build as a VS Code Dev Container using the
Dev Containers: Reopen in Container
command
If you wish to add additional services, or swap out PostgreSQL with an alternative database, you can reference the Laravel Sail stubs and update the docker-compose.local.yml
file as needed.