laravel-vue-spa-blog
laravel-vue-spa-blog copied to clipboard
A Single page application blog built with Laravel and Vue Js
Laravel and Vue Single Page Application Blog
This application can be used as starter kit if you want to get started building an single page application with Laravel and VueJS. This is a blog using feature like administration, creating and editing posts, commenting, searching posts and many other feature which can be found in most web applications.
Technologies
Frontend
- VueJS - A JavaScript framework for building great user interfaces.
- Bootstrap 4 - Bootstrap is the most used CSS framework.
- Vuex - A state management library for VueJS applications and serves as a central store for the application.
Backend
- PHP 7.2
- SQLite3 for development and MySQL for production.
- PHPUnit for unit tests.
- Laravel - A PHP Full stack framework
- Tymon/Jwt-auth - A library used in laravel for Json Web Token authentication
Features
- CRUD (create / read / update / delete) on posts
- CRUD (create / read / update / delete ) on post categories
- Image upload for post cover
- Creating comments on post page
- Pagination on posts listing
- Searching on posts
- Authentication for the admin
- Application ready for production
Prerequisites
- PHP 7.2
- SQLite3
- Git
- Composer
Getting Started
-
Clone the project from Github
$ git clone https://github.com/juvpengele/laravel-vue-spa-blog $ cd laravel-vue-spa-blog laravel-vue-spa-blog$
-
Install the packages for laravel:
laravel-vue-spa-blog$ composer install
-
Create the database:
laravel-vue-spa-blog$ touch database/database.sqlite
-
Create the .env file :
laravel-vue-spa-blog$ cp .env.example .env
-
Generate the encryption key for Laravel :
laravel-vue-spa-blog$ php artisan key:generate
-
Add database information :
laravel-vue-spa-blog$ vim .env
-
Change the DB_CONNECTION to put sqlite :
DB_CONNECTION=sqlite
-
Load sample records:
laravel-vue-spa-blog$ php artisan migrate --seed
-
Run the Laravel Server in development mode
laravel-vue-spa-blog$ php artisan serve
-
Start client in development mode. You should be able to go to
http://localhost:8000
-
To access to the administration panel, there is a link in the bottom of the page or go to
http://localhost:8000/login
Next step
- [ ] Create Laravel and React Single Page Application Forum
Screens
Listing posts
data:image/s3,"s3://crabby-images/36d27/36d27779ffcdc9fcc0108c6e05021a3f3d6be0dd" alt="Listing posts"
Single Post page
data:image/s3,"s3://crabby-images/37821/378215400e111619b3d1b07c6dcbcb119e4761bc" alt="Post page"
Creating comments
data:image/s3,"s3://crabby-images/3d8b8/3d8b802367f315d77cddf9b35947fc9a86d9c254" alt="Creating comments"
Login page
data:image/s3,"s3://crabby-images/2da05/2da051cc07eb6fb6d5fc8dd014d0efd6b84ac660" alt="Post page"
Create a post page (administration)
data:image/s3,"s3://crabby-images/b7940/b79403e13ac697b2f103a9d283ebc33603c9af27" alt="Post page"
License
MIT ©