nabil12ful / store-data-requests
Store data to DB by model from requests fields html form
v1.5
2023-03-28 12:10 UTC
Requires
- laravel/framework: ^8.0|^9.0|^10.0
- yoeunes/toastr: ^2.3
README
Support laravel v8+
Store data to database from (Form Requsts Fields) by Model
Installation
composer require nabil12ful/store-data-requests
To publish
php artisan vendor:publish --provider="Nabil\StoreDataRequestsServiceProvider"
Usage
php artisan make:controller UserController -r
Or
php artisan make:controller UserController -m User
Change this info after controller generation & Congratolations 😄
protected $model = \App\Models\User::class; protected $folderBlade = 'backend.user'; // View folder name OR path protected $uploadPath = 'upload/user'; protected $columns = [ // table columns & fields name 'name', 'email', ]; protected $mediaColumns = [ // columns name have a media files like [Image, Pdf, Doc, etc...] 'image' ];
Views Folder
+--- views | +--- backend | | +--- user | | | +--- index.blade.php | | | +--- create.blade.php | | | +--- edit.blade.php | | | +--- show.blade.php | | +--- product | | | +--- index.blade.php | | | +--- create.blade.php | | | +--- edit.blade.php | | | +--- show.blade.php | | +--- index.blade.php
To use Vaildation
Create request validation by
php artisan make:request UserStoreRequest
public function store(UserStoreRequest $request): RedirectResponse { StoreDataRequests::model($this->model)->make($request, $this->columns)->store($this->uploadPath); }
Or use
First change columns array like:
protected $columns = [ // table columns & fields name with rules 'name' => 'required|string|min:5', 'email' => 'required|email', ]; protected $mediaColumns = [ // table columns & fields name has files with rules 'image' => 'required|image', ];
And use storeValidated
, updateValidated
methods
public function store(Request $request) { $result = StoreDataRequests::model($this->model)->make($request, $this->columns)->storeValidated('upload/users'); if(isset($result->id)) { toastr()->success('The data has been stored successfully', 'Success'); return redirect()->back(); }else{ return back()->withInput()->withErrors($result); } }
On update
public function update($id, Request $request) { $result = StoreDataRequests::model($this->model)->make($request, $this->columns, $this->mediaColumns)->updateHasFilesValidate($id, $this->uploadPath); if(!$result) { toastr()->success('The data has been updated successfully', 'Success'); return redirect()->back(); }else{ return back()->withInput()->withErrors($result); } }
Delete records
Enter path Param If you want to delete files from uploads path with delete a record:
StoreDataRequests::model($this->model)->delete(decrypt($id), $this->uploadPath);
Use our service in simple Controller
First import our plugin in your Controller file
use Nabil\StoreDataRequests;
And write this code to create a new record:
public function store(Request $request) { StoreDataRequests::model('Prodect')->make($request, ['title','description'])->store(); }
Or write this code to update old record in Database model:
public function update(Request $request, $id) { StoreDataRequests::model('Prodect')->make($request, ['title','description'])->update($id); }
Upload files with insert data
use:
StoreDataRequests::model('Prodect')->make($request, ['title','description'], ['image'])->store('path/to/upload');
or update has file:
StoreDataRequests::model('Prodect')->make($request, ['title','description'], ['image'])->update($id, 'path/to/upload');