Dcat Admin 批量操作/批量审批功能(弹窗)实现

本文介绍了如何在Dcat Admin中实现批量审批功能。用户选择行后,点击批量审批按钮,弹窗显示,输入审批意见并选择通过或退回,最后提交。主要涉及批量审批按钮的添加、弹窗及数据处理文件的创建,以及相应的动作文件编写。
摘要由CSDN通过智能技术生成

功能:选择行,点击批量审批按钮,触发弹窗,输入审批意见,选择通过或退回,提交。如下图展示:

 

主要分三部分:1、添加批量审批按钮 2、弹窗及提交后的数据处理文件  3.动作文件

一、弹窗及提交后的数据处理文件

建立Batchspform.php文件,位置看命名空间

<?php

namespace App\Admin\Forms;

use Dcat\Admin\Traits\LazyWidget;
use Dcat\Admin\Widgets\Form;
use Dcat\Admin\Contracts\LazyRenderable;
use App\Models\HrOvertime; 
use App\Models\HrUsersp; 
use App\Models\Hrop; 
class Batchspform extends Form implements LazyRenderable
{
    /**
     * Handle the form request.
     *
     * @param array $input
     *
     * @return mixed
     */
    use LazyWidget;
    public function handle(array $input)
    {
     
  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用 dcat admin 和 maatwebsite/excel 导入数据的步骤如下: 1. 安装 maatwebsite/excel 依赖包,可以使用 composer 命令进行安装: ``` composer require maatwebsite/excel ``` 2. 在 dcat admin 中创建一个数据表,并在该表对应的 Model 中添加 `use Maatwebsite\Excel\Concerns\ToModel;` 和 `use Maatwebsite\Excel\Concerns\WithHeadingRow;` 引用。 3. 创建一个实现 `ToModel` 接口的类,该类负责将 Excel 中的数据转换为 Model 实例。例如: ```php <?php namespace App\Imports; use App\Models\User; use Maatwebsite\Excel\Concerns\ToModel; use Maatwebsite\Excel\Concerns\WithHeadingRow; class UsersImport implements ToModel, WithHeadingRow { public function model(array $row) { return new User([ 'name' => $row['name'], 'email' => $row['email'], 'password' => bcrypt($row['password']), ]); } } ``` 4. 在 dcat admin 中创建一个导入数据的页面,并对页面进行配置,如下所示: ```php use App\Imports\UsersImport; use Maatwebsite\Excel\Facades\Excel; // ... $form->file('import_file', '导入文件'); // ... $form->footer(function ($footer) { $footer->disableReset(); $footer->disableSubmit(); $footer->addButton('导入', [ 'class' => 'btn btn-primary', 'onclick' => <<<JS var formData = new FormData(); formData.append('import_file', $('#import_file')[0].files[0]); $.ajax({ url: '{$this->getResource()}/import', headers: { 'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content') }, data: formData, type: 'POST', cache: false, contentType: false, processData: false, success: function (data) { Dcat.success(data.message); }, error: function (xhr, textStatus, errorThrown) { Dcat.error(xhr.responseJSON.message || '操作失败'); } }); JS, ]); }); ``` 5. 在控制器中添加导入数据的方法: ```php public function import(Request $request) { $file = $request->file('import_file'); Excel::import(new UsersImport, $file); return response()->json([ 'message' => '导入成功', ]); } ``` 以上就是使用 dcat admin 和 maatwebsite/excel 导入数据的基本步骤。需要注意的是,以上代码仅作为参考,具体实现可能会有所不同,具体实现应根据实际情况进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值