Nuxt Argon Dashboard Laravel
Frontend version: Argon Dashboard v1.2.0. More info at https://www.creative-tim.com/product/argon-dashboard
What if your frontend came not only with reusable components, but also with a reusable backend? API-driven development is more than just a buzzword and we partnered with UPDIVISION to prove it. Build awesome-looking apps with a flexible architecture across a variety of devices and operating systems with Nuxt Argon Dashboard Laravel.
Download
For the free version of the project you can either
- download the .zip file from the Creative Tim site and extract it or
- make a clone from the Github repository
You will get two project folders: one for the Laravel API project and one for the Nuxt frontend.
Laravel API Setup
Introduction
JSON:API is a specification for how a client should request that resources be fetched or modified, and how a server should respond to those requests. It is designed to minimize both the number of requests and the amount of data transmitted between clients and servers. This efficiency is achieved without compromising readability, flexibility, or discoverability.
Click here to go to the JSON:API docs
Prerequisites
JSON:API backend
The Laravel JSON:API backend project requires a proper multi-threaded web server such as Apache/Nginx environment with PHP, Composer and MySQL.
Do not use php artisan serve
as it will result in stalled requests due to the single-threaded nature of the built-in PHP web server.
We strongly recommend using Laradock for Linux and Mac or Laragon for Windows if possible.
Other options for your local environment:
- Windows: How to install WAMP on Windows
- Linux: How to install LAMP on Linux
- Mac: How to install MAMP on MAC
You will also need to install Composer 2: https://getcomposer.org/doc/00-intro.md
Nuxt Argon frontend
The Nuxt Argon frontend project requires a working local environment with NodeJS version 8.9 or above (8.11.0+ recommended), npm.
Install Node: https://nodejs.org/ (version 8.11.0+ recommended)
Install NPM: https://www.npmjs.com/get-npm
Laravel API Project Installation
- Navigate in your Laravel API project folder: cd your-laravel-json-api-project
- Install project dependencies: composer install
- Create a new .env file: cp .env.example .env
- Add your own database credentials in the .env file in DB_DATABASE, DB_USERNAME, DB_PASSWORD
- Create users table: php artisan migrate --seed
- Generate application key: php artisan key:generate
- Install Laravel Passport: php artisan passport:install
- Add your own mailtrap.io credentials in MAIL_USERNAME and MAIL_PASSWORD in the .env file
Nuxt Argon Dashboard Project Installation
Note: As many packages are deprecated on Node.js v16.x or higher make sure you are using Node.js 14.x(recommended) before strarting this installation.
- Navigate to your Nuxt Argon Dashboard project folder:
cd your-nuxt-argon-dashbord-project
- Install project dependencies:
npm install
- Create a new .env file:
cp .env.example .env
BASE_URL
should contain the URL of your Nuxt Argon Dashboard Project (eg. http://localhost:8080/)API_BASE_URL
should contain the URL of your Laravel JSON:API Project. (eg. http://localhost:3000/api/v1)- Run
npm run dev
to start the application in a local development environment ornpm run build
to build release distributables.
Usage
Register a user or login using admin@jsonapi.com and secret and start testing the theme.
Besides the dashboard and the auth pages this theme also has an edit profile page. All the necessary files are installed out of the box. Keep in mind that all the features can be viewed once you log in using the credentials provided above or by registering your own user.
Dashboard
You can access the dashboard either by using the "Dashboards/Dashboard" link in the left sidebar or by adding /dashboard in the URL.
Login
The login functionality is fully implemented in our theme helping you to start your project in no time. To login into dashboard you just have to add /login in the URL and fill the login form with one of the credentials (user: admin@jsonapi.com and password: secret).
The src\pages\login.vue
is the Vue component which handles the login functinality. You can easily adapt it to your needs.
Login Card
<div class="container mt--9 pb-5">
<div class="row justify-content-center">
<div class="col-lg-5 col-md-7">
<div class="card bg-secondary border-0 mb-0">
<div class="card-header bg-transparent pb-5">
<div class="text-muted text-center mt-2 mb-3">
<small>Sign in with</small>
</div>
<div class="btn-wrapper text-center">
<a href="#" class="btn btn-neutral btn-icon">
<span class="btn-inner--icon"
><img src="~/static/img/icons/common/github.svg"
/></span>
<span class="btn-inner--text">Github</span>
</a>
<a href="#" class="btn btn-neutral btn-icon">
<span class="btn-inner--icon"
><img src="~/static/img/icons/common/google.svg"
/></span>
<span class="btn-inner--text">Google</span>
</a>
</div>
</div>
<div class="card-body px-lg-5 py-lg-5">
<div class="text-center text-muted mb-4">
<small>Or sign in with credentials</small>
</div>
<form class="needs-validation" @submit.prevent="handleSubmit()">
<base-input
alternative
class="mb-3"
name="Email"
prepend-icon="ni ni-email-83"
placeholder="Email"
v-model="form.data.attributes.email"
>
</base-input>
<validation-error :errors="apiValidationErrors.email" />
<base-input
alternative
class="mb-3"
name="Password"
prepend-icon="ni ni-lock-circle-open"
type="password"
placeholder="Password"
v-model="form.data.attributes.password"
>
</base-input>
<validation-error :errors="apiValidationErrors.password" />
<div class="text-center">
<base-button type="primary" native-type="submit" class="my-4"
>Sign in</base-button
>
</div>
</form>
</div>
</div>
<div class="row mt-3">
<div class="col-6">
<router-link to="/password/reset" class="text-light"
><small>Forgot password?</small></router-link
>
</div>
<div class="col-6 text-right">
<router-link to="/register" class="text-light"
><small>Create new account</small></router-link
>
</div>
</div>
</div>
</div>
</div>
Register
The register functionality is fully implemented in our theme helping you to start your project in no time. To register a new user you just have to add /register in the URL or click on register link from login page and fill the register form with user details.
The src\pages\register.vue
is the Vue component which handles the login functinality. You can easily extend it to your needs.
Register card
<div class="container mt--8 pb-5">
<!-- Table -->
<div class="row justify-content-center">
<div class="col-lg-6 col-md-8">
<div class="card bg-secondary border-0">
<div class="card-header bg-transparent pb-5">
<div class="text-muted text-center mt-2 mb-4">
<small>Sign up with</small>
</div>
<div class="text-center">
<a href="#" class="btn btn-neutral btn-icon mr-4">
<span class="btn-inner--icon"
><img src="~/static/img/icons/common/github.svg"
/></span>
<span class="btn-inner--text">Github</span>
</a>
<a href="#" class="btn btn-neutral btn-icon">
<span class="btn-inner--icon"
><img src="~/static/img/icons/common/google.svg"
/></span>
<span class="btn-inner--text">Google</span>
</a>
</div>
</div>
<div class="card-body px-lg-5 py-lg-5">
<div class="text-center text-muted mb-4">
<small>Or sign up with credentials</small>
</div>
<form
role="form"
@submit.prevent="handleRegister"
@keydown.enter="handleRegister"
>
<base-input
alternative
class="mb-3"
prepend-icon="ni ni-hat-3"
placeholder="Name"
name="Name"
v-model="form.data.attributes.name"
>
</base-input>
<validation-error :errors="apiValidationErrors.name" />
<base-input
alternative
class="mb-3"
prepend-icon="ni ni-email-83"
placeholder="Email"
name="Email"
v-model="form.data.attributes.email"
>
</base-input>
<validation-error :errors="apiValidationErrors.email" />
<base-input
alternative
class="mb-3"
prepend-icon="ni ni-lock-circle-open"
placeholder="Password"
type="password"
name="Password"
v-model="form.data.attributes.password"
>
</base-input>
<password
class="mb-3"
v-model="form.data.attributes.password"
:strength-meter-only="true"
@score="showScore"
:showStrengthMeter="false"
/>
<validation-error :errors="apiValidationErrors.password" />
<base-input
alternative
class="mb-3"
prepend-icon="ni ni-lock-circle-open"
placeholder="Confirm Password"
type="password"
name="Password confirmation"
v-model="form.data.attributes.password_confirmation"
>
</base-input>
<validation-error
:errors="apiValidationErrors.password_confirmation"
/>
<div class="text-muted font-italic">
<small
>password strength:
<template v-if="form.data.attributes.scors === 0">
<span class="text-danger font-weight-700">
very weak
</span>
</template>
<template v-if="form.data.attributes.scors === 1">
<span class="text-danger font-weight-700"> weak </span>
</template>
<template v-if="form.data.attributes.scors === 2">
<span class="text-warning font-weight-700"> medium </span>
</template>
<template v-if="form.data.attributes.scors === 3">
<span class="text-success font-weight-700"> strong </span>
</template>
<template v-if="form.data.attributes.scors === 4">
<span class="text-success font-weight-700">
very strong
</span>
</template>
</small>
</div>
<div class="row my-4">
<div class="col-12">
<base-input
:rules="{ required: { allowFalse: false } }"
name="Privacy Policy"
>
<base-checkbox
v-model="form.data.attributes.agree"
name="agree"
>
<span class="text-muted"
>I agree with the
<a href="#!">Terms and conditions</a></span
>
</base-checkbox>
</base-input>
</div>
</div>
<div class="text-center">
<base-button
type="primary"
@click.prevent="handleRegister"
class="my-4"
>Create account</base-button
>
</div>
</form>
</div>
</div>
</div>
</div>
</div>
Profile edit
You have the option to edit the current logged in user's profile information (name, email, profile picture) and password. To access this page, just click the "Examples/User Profile" link in the left sidebar or add /examples/user-profile in the URL.
The src\pages\examples\user-profile
is the folder with Vue components that handle the update of the user information and password.
Edit profile component
<template>
<div class="card">
<div class="card-header">
<h1>Edit Profile</h1>
</div>
<div class="card-body">
<form ref="profile_form" @submit.prevent="onProFeature">
<base-input
label="Name"
prepend-icon="fas fa-user"
placeholder="Your name"
v-model="user.name"
/>
<validation-error :errors="apiValidationErrors.name" />
<base-input
label="Email"
prepend-icon="fas fa-envelope"
placeholder="Email"
v-model="user.email"
/>
<validation-error :errors="apiValidationErrors.email" />
<div class="my-4">
<base-button
type="button"
class="btn btn-sm btn-primary"
native-type="submit"
>
Submit
</base-button>
</div>
</form>
</div>
</div>
</template>
<script>
import BaseInput from "~/components/argon-core/Inputs/BaseInput.vue";
import BaseButton from "~/components/argon-core/BaseButton.vue";
import formMixin from "@/mixins/form-mixin";
import ValidationError from "~/components/ValidationError.vue";
export default {
name: "UserEditCard",
components: {
BaseInput,
BaseButton,
ValidationError,
},
mixins: [formMixin],
props: {
user: Object,
},
methods: {
onProFeature() {
this.$notify({
type: "danger",
message: "This is a PRO feature."
});
},
},
};
</script>
Edit password component
<template>
<div class="card">
<div class="card-header">
<h1>Change Password</h1>
</div>
<div class="card-body">
<form ref="password_form" @submit.prevent="onProFeature">
<base-input
v-model="password"
type="password"
name="new_password"
autocomplete="on"
class="mb-3"
prepend-icon="fa fa-key"
placeholder="New Password"
/>
<validation-error :errors="apiValidationErrors.password" />
<base-input
v-model="password_confirmation"
type="password"
name="confirm_password"
autocomplete="on"
class="mb-3"
prepend-icon="fa fa-key"
placeholder="Confirm Password"
/>
<div class="my-4">
<base-button
type="button"
class="btn btn-sm btn-primary"
native-type="submit"
>
Change Password
</base-button>
</div>
</form>
</div>
</div>
</template>
<script>
import BaseInput from "~/components/argon-core/Inputs/BaseInput.vue";
import BaseButton from "~/components/argon-core/BaseButton.vue";
import formMixin from "@/mixins/form-mixin";
import ValidationError from "~/components/ValidationError.vue";
export default {
name: "UserPasswordCard",
components: {
BaseInput,
BaseButton,
ValidationError,
},
mixins: [formMixin],
props: {
user: Object,
},
data() {
return {
password: null,
password_new: null,
password_confirmation: null,
};
},
methods: {
onProFeature() {
this.$notify({
type: "danger",
message: "This is a PRO feature."
});
},
},
};
</script>
Table of Contents
- Versions
- Demo
- Documentation
- File Structure
- Browser Support
- Resources
- Reporting Issues
- Licensing
- Useful Links
Versions
HTML | Laravel | Nuxt & Laravel |
---|---|---|
Demo
Register | Login | Dashboard |
---|---|---|
Profile Page | Users Page | Tables Page |
---|---|---|
Documentation
The documentation for the Nuxt Argon Dashboard Laravel is hosted at our website.
File Structure
|-- nuxt-argon-dashboard
│ app.html
│ CHANGELOG.md
│ nuxt.config.js
│ package.json
│ polyfills.js
│ README.md
│ yarn.lock
│
├───assets
│ ├───css
│ │ │ style.css
│ │ │
│ │ ├───font-awesome
│ │ └───nucleo
│ └───sass
│ │ argon.scss
│ │
│ ├───core
│ └───custom
│ _components.scss
│ _custom.scss
│ _functions.scss
│ _mixins.scss
│ _transitions.scss
│ _utilities.scss
│ _variables.scss
│ _vendors.scss
│
├───components
│ │ ValidationError.vue
│ │
│ ├───argon-core
│ │ │ Badge.vue
│ │ │ BaseAlert.vue
│ │ │ BaseButton.vue
│ │ │ BaseDropdown.vue
│ │ │ BaseHeader.vue
│ │ │ BasePagination.vue
│ │ │ BaseProgress.vue
│ │ │ CloseButton.vue
│ │ │ index.js
│ │ │ LoadingPanel.vue
│ │ │ Modal.vue
│ │ │ NavbarToggleButton.vue
│ │ │
│ │ ├───Breadcrumb
│ │ │ Breadcrumb.vue
│ │ │ BreadcrumbItem.vue
│ │ │ RouteBreadcrumb.vue
│ │ │
│ │ ├───Cards
│ │ │ Card.vue
│ │ │ StatsCard.vue
│ │ │
│ │ ├───Charts
│ │ │ BarChart.js
│ │ │ config.js
│ │ │ DoughnutChart.js
│ │ │ globalOptionsMixin.js
│ │ │ LineChart.js
│ │ │ optionHelpers.js
│ │ │ PieChart.js
│ │ │
│ │ ├───Collapse
│ │ │ Collapse.vue
│ │ │ CollapseItem.vue
│ │ │
│ │ ├───Feed
│ │ │ Comment.vue
│ │ │
│ │ ├───Inputs
│ │ │ BaseCheckbox.vue
│ │ │ BaseInput.vue
│ │ │ IconCheckbox.vue
│ │ │ TagsInput.vue
│ │ │
│ │ ├───Navbar
│ │ │ BaseNav.vue
│ │ │ NavbarToggleButton.vue
│ │ │
│ │ ├───NotificationPlugin
│ │ │ index.js
│ │ │ Notification.vue
│ │ │ Notifications.vue
│ │ │
│ │ ├───SidebarPlugin
│ │ │ index.js
│ │ │ SideBar.vue
│ │ │ SidebarItem.vue
│ │ │
│ │ └───WorldMap
│ │ AsyncWorldMap.vue
│ │ WorldMap.vue
│ │
│ ├───Dashboard
│ │ └───Cards
│ │ UserEditCard.vue
│ │ UserPasswordCard.vue
│ │
│ ├───feed
│ │ Comment.vue
│ │
│ ├───layouts
│ │ └───argon
│ │ Content.vue
│ │ ContentFooter.vue
│ │ DashboardNavbar.vue
│ │
│ ├───pages
│ │ ├───dashboard
│ │ │ ActivityFeed.vue
│ │ │ LightTable.vue
│ │ │ PageVisitsTable.vue
│ │ │ ProgressTrackList.vue
│ │ │ SocialTrafficTable.vue
│ │ │ UserList.vue
│ │ │
│ │ ├───register
│ │ │ FailedRegistration.vue
│ │ │ SuccessfulRegistration.vue
│ │ │
│ │ └───UserProfile
│ │ UserCard.vue
│ │
│ ├───tables
│ │ │ projects.js
│ │ │ users.js
│ │ │
│ │ ├───PaginatedTables
│ │ │ clientPaginationMixin.js
│ │ │
│ │ └───RegularTables
│ │ DarkTable.vue
│ │ LightTable.vue
│ │ TranslucentTable.vue
│ │
│ └───widgets
│ CreditCard.vue
│ MembersCard.vue
│ PaypalCard.vue
│ ProgressTrackList.vue
│ StatsCards.vue
│ VectorMapCard.vue
│ VisaCard.vue
│
├───layouts
│ AuthLayout.vue
│ DashboardLayout.vue
│ error1.vue
│
├───middleware
│ README.md
│ redirect.js
│
├───mixins
│ form-mixin.js
│ global.js
│
├───pages
│ │ dashboard.vue
│ │ index.vue
│ │ login.vue
│ │ register.vue
│ │
│ ├───components
│ │ icons.vue
│ │ notifications.vue
│ │
│ ├───examples
│ │ ├───user-management
│ │ │ index.vue
│ │ │
│ │ └───user-profile
│ │ index.vue
│ │
│ ├───maps
│ │ google.vue
│ │
│ ├───password
│ │ email.vue
│ │ reset.vue
│ │
│ └───tables
│ regular.vue
│
├───plugins
│ │ axios.js
│ │ elementUi.js
│ │ README.md
│ │
│ └───dashboard
│ │ dashboard-plugin.js
│ │ globalComponents.js
│ │ globalDirectives.js
│ │ JsonApi.js
│ │ world-map.js
│ │
│ └───directives
│ click-outside.js
│
├───services
│ profile-service.js
│ users-service.js
│
├───static
│ │ .nojekyll
│ │ favicon.png
│ │ README.md
│ │ sw.js
│ │
│ └───img
│ │ examples_image.png
│ │ examples_image1.png
│ │ placeholder.jpg
│ │
│ ├───brand
│ │ favicon.png
│ │ green.png
│ │ white.png
│ │
│ ├───icons
│ │ ├───cards
│ │ │ bitcoin.png
│ │ │ mastercard.png
│ │ │ paypal.png
│ │ │ visa.png
│ │ │
│ │ ├───common
│ │ │ github.svg
│ │ │ google.svg
│ │ │
│ │ └───flags
│ │ DE.png
│ │ GB.png
│ │ US.png
│ │
│ └───theme
│ angular.jpg
│ bootstrap.jpg
│ img-1-1000x600.jpg
│ img-1-1000x900.jpg
│ landing-1.png
│ landing-2.png
│ landing-3.png
│ profile-cover.jpg
│ react.jpg
│ sketch.jpg
│ team-1.jpg
│ team-2.jpg
│ team-3.jpg
│ team-4.jpg
│ team-5.jpg
│ vue.jpg
│
├───store
│ index.js
│ profile.js
│ README.md
│ register.js
│ users.js
│
└───util
API_KEY.js
authCustomStrategy.js
throttle.js
Browser Support
At present, we officially aim to support the last two versions of the following browsers:
Resources
- Demo: https://nuxt-argon-dashboard-laravel.creative-tim.com/?ref=nadl-readme
- Download Page: https://www.creative-tim.com/product/nuxt-argon-dashboard-laravel?ref=nadl-readme
- Documentation: https://nuxt-argon-dashboard-laravel.creative-tim.com/documentation?ref=nadl-readme
- License Agreement: https://www.creative-tim.com/license
- Support: https://www.creative-tim.com/contact-us
- Issues: Github Issues Page
- Dashboards:
HTML | Laravel | Nuxt & Laravel |
---|---|---|
Change log
Please see the changelog for more information on what has changed recently.
Credits
Reporting Issues
We use GitHub Issues as the official bug tracker for the Nuxt Argon Dashboard Laravel. Here are some advices for our users that want to report an issue:
- Make sure that you are using the latest version of the Nuxt Argon Dashboard Laravel. Check the CHANGELOG from your dashboard on our website.
- Providing us reproducible steps for the issue will shorten the time it takes for it to be fixed.
- Some issues may be browser specific, so specifying in what browser you encountered the issue might help.
Licensing
- Copyright Creative Tim (https://www.creative-tim.com/?ref=nadl-readme)
- Licensed under MIT (https://github.com/creativetimofficial/nuxt-argon-dashboard-laravel/blob/master/LICENSE.md)
Useful Links
- Tutorials
- Affiliate Program (earn money)
- Blog Creative Tim
- Free Products from Creative Tim
- Premium Products from Creative Tim
- React Products from Creative Tim
- Angular Products from Creative Tim
- VueJS Products from Creative Tim
- More products from Creative Tim
- Check our Bundles here
Social Media
Creative Tim:
Twitter: https://twitter.com/CreativeTim?ref=nadl-readme
Facebook: https://www.facebook.com/CreativeTim?ref=nadl-readme
Dribbble: https://dribbble.com/creativetim?ref=nadl-readme
Instagram: https://www.instagram.com/CreativeTimOfficial?ref=nadl-readme
Updivision:
Twitter: https://twitter.com/updivision?ref=nadl-readme
Facebook: https://www.facebook.com/updivision?ref=nadl-readme
Linkedin: https://www.linkedin.com/company/updivision?ref=nadl-readme
Updivision Blog: https://updivision.com/blog/?ref=nadl-readme