Project Description: WMWISE Laravel Test
Project Overview: Create a CRUD application for clients following the specified instructions using Laravel 11.
Requirements:
- Fields for clients: name, address, phone, country (selectable from database).
- Country information should be fetched from the database.
- Client information should be stored in a database.
- Use Laravel Requests for request validation (optional).
- Send an email when a client is created using events and mailables (optional).
Development Stack:
- Backend: Laravel 11
- Frontend: Blade files, Alpine.js, Vue.js, or Inertia.js (choose according to comfort).
- Use English language for all code, including tables, columns, and codebase.
Steps:
- Set up Laravel environment.
- Create migrations for clients and countries tables with English names and columns.
- Implement CRUD operations for clients.
- Use Laravel Requests for request validation (optional).
- Implement email notification using events and mailables (optional).
- Create frontend views using Blade files with chosen frontend framework (Alpine.js, Vue.js, or Inertia.js).
- Test and validate functionality.
- Upload the project to GitHub.
- Grant access to GitHub repository to karenecv and kcardenas.
- Send the repository link to mtorres@wmwise.com and kcardenas@wmwise.com.
Expected Completion Time: The assigned task should be completed within 4 days after receiving this email.
Before you begin, make sure you have the following installed:
- PHP >= 7.4
- Composer
- Node.js and NPM -Git
-
Clone the repository:
git clone https://github.com/miusarname2/laravel-test-CRUD.git
-
Install PHP and JavaScript dependencies:
composer install
-
Copy the
.env.example
file to.env
and configure the environment variables. -
Generate the application key:
php artisan key:generate
-
Database Configuration:
-
If you wish to change the database configuration, update the
.env
file with your database credentials. -
Connect to your database to manually add countries using the following SQL insertions as examples:
INSERT INTO countries (created_at, name, updated_at) VALUES (NOW(), 'Argentina', NOW());
INSERT INTO countries (created_at, name, updated_at) VALUES (NOW(), 'Brazil', NOW());
INSERT INTO countries (created_at, name, updated_at) VALUES (NOW(), 'Canada', NOW());
INSERT INTO countries (created_at, name, updated_at) VALUES (NOW(), 'China', NOW());
INSERT INTO countries (created_at, name, updated_at) VALUES (NOW(), 'France', NOW());
INSERT INTO countries (created_at, name, updated_at) VALUES (NOW(), 'Germany', NOW());
-
If you do not want to do inserts, the database environment variables are configured to connect to a cloud database service.
-
-
Run the migrations:
php artisan migrate
-
Start the server:
php artisan serve
You can now access your application at http://localhost:8000.
To use the application, follow the following steps:
- Access the URL http://localhost:8000.
- The available routes are:
/clients
: Shows a panel with all clients, with options to edit and delete./clients/create
: Allows you to create a new client./clients/<client_id>/edit
: Allows you to edit an existing client.
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class Client extends Model
{
protected $fillable = ['name', 'address', 'phone', 'country_id'];
public function country()
{
return $this->belongsTo(Countries::class);
}
}
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class Countries extends Model
{
protected $fillable = ['name'];
public function clients()
{
return $this->hasMany(Client::class);
}
}
Laravel is a web application framework with expressive, elegant syntax. We believe development must be an enjoyable and creative experience to be truly fulfilling. Laravel takes the pain out of development by easing common tasks used in many web projects, such as:
- Simple, fast routing engine.
- Powerful dependency injection container.
- Multiple back-ends for session and cache storage.
- Expressive, intuitive database ORM.
- Database agnostic schema migrations.
- Robust background job processing.
- Real-time event broadcasting.
Laravel is accessible, powerful, and provides tools required for large, robust applications.
Laravel has the most extensive and thorough documentation and video tutorial library of all modern web application frameworks, making it a breeze to get started with the framework.
You may also try the Laravel Bootcamp, where you will be guided through building a modern Laravel application from scratch.
If you don't feel like reading, Laracasts can help. Laracasts contains over 2000 video tutorials on a range of topics including Laravel, modern PHP, unit testing, and JavaScript. Boost your skills by digging into our comprehensive video library.
We would like to extend our thanks to the following sponsors for funding Laravel development. If you are interested in becoming a sponsor, please visit the Laravel Patreon page.
- Vehikl
- Tighten Co.
- Kirschbaum Development Group
- 64 Robots
- Cubet Techno Labs
- Cyber-Duck
- Many
- Webdock, Fast VPS Hosting
- DevSquad
- Curotec
- OP.GG
- WebReinvent
- Lendio
Thank you for considering contributing to the Laravel framework! The contribution guide can be found in the Laravel documentation.
In order to ensure that the Laravel community is welcoming to all, please review and abide by the Code of Conduct.
If you discover a security vulnerability within Laravel, please send an e-mail to Taylor Otwell via taylor@laravel.com. All security vulnerabilities will be promptly addressed.
The Laravel framework is open-sourced software licensed under the MIT license.