nabil12ful/store-data-requests

通过请求字段 HTML 表单将数据存储到数据库中,按模型操作

v1.5 2023-03-28 12:10 UTC

This package is auto-updated.

Last update: 2024-09-28 15:08:27 UTC


README

支持 laravel v8+

从(表单请求字段)通过模型存储到数据库中

安装

composer require nabil12ful/store-data-requests

要发布

php artisan vendor:publish --provider="Nabil\StoreDataRequestsServiceProvider"

用法

php artisan make:controller UserController -r

或者

php artisan make:controller UserController -m User

在控制器生成后更改此信息 & 恭喜 😄

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
|    +--- 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

要使用验证

通过创建请求验证

php artisan make:request UserStoreRequest
public function store(UserStoreRequest $request): RedirectResponse
{
	StoreDataRequests::model($this->model)->make($request, $this->columns)->store($this->uploadPath);
}

或者使用

首先更改列数组

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',
];

然后使用 storeValidatedupdateValidated 方法

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);
    }
}

在更新时

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);
    }
}

删除记录

如果您想通过删除记录从上传路径中删除文件,请输入路径参数

StoreDataRequests::model($this->model)->delete(decrypt($id), $this->uploadPath);

在我们的简单控制器中使用我们的服务

首先在您的控制器文件中导入我们的插件

use Nabil\StoreDataRequests;

然后写入此代码以创建新记录

public function store(Request $request)
{
	StoreDataRequests::model('Prodect')->make($request, ['title','description'])->store();
}

或者写入此代码以在数据库模型中更新旧记录

public function update(Request $request, $id)
{
	StoreDataRequests::model('Prodect')->make($request, ['title','description'])->update($id);
}

使用插入数据上传文件

使用

StoreDataRequests::model('Prodect')->make($request, ['title','description'], ['image'])->store('path/to/upload');

或者更新包含文件的

StoreDataRequests::model('Prodect')->make($request, ['title','description'], ['image'])->update($id, 'path/to/upload');

感谢 Eng/Sameh Mohamed

由 Eng/Nabil Hamada 使用 ❤️ 制作