generated from liutk/owl-admin-base
admin 合同管理
parent
7d45208cef
commit
d62f0c8055
|
|
@ -0,0 +1,98 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Admin\Controllers;
|
||||||
|
|
||||||
|
use App\Admin\Services\AgreementService;
|
||||||
|
use Slowlyo\OwlAdmin\Renderers\Form;
|
||||||
|
use Slowlyo\OwlAdmin\Renderers\Page;
|
||||||
|
use Slowlyo\OwlAdmin\Admin;
|
||||||
|
use App\Enums\EmployeeStatus;
|
||||||
|
use App\Models\Agreement;
|
||||||
|
use Illuminate\Support\{Arr};
|
||||||
|
use Illuminate\Support\Facades\{Storage};
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 合同管理
|
||||||
|
*/
|
||||||
|
class AgreementController extends AdminController
|
||||||
|
{
|
||||||
|
protected string $serviceName = AgreementService::class;
|
||||||
|
|
||||||
|
public function list(): Page
|
||||||
|
{
|
||||||
|
$user = Admin::user();
|
||||||
|
$crud = $this->baseCRUD()
|
||||||
|
->tableLayout('fixed')
|
||||||
|
->headerToolbar([
|
||||||
|
$this->createTypeButton('drawer', 'xl')->visible($user->can('admin.agreement.create')),
|
||||||
|
...$this->baseHeaderToolBar(),
|
||||||
|
])
|
||||||
|
->bulkActions([])
|
||||||
|
->columns([
|
||||||
|
amisMake()->TableColumn()->name('id')->label(__('agreement.id')),
|
||||||
|
amisMake()->TableColumn()->name('name')->label(__('agreement.name')),
|
||||||
|
amisMake()->TableColumn()->name('employee.name')->label(__('agreement.employee_id')),
|
||||||
|
amisMake()->TableColumn()->name('created_at')->label(__('agreement.created_at')),
|
||||||
|
amisMake()->Operation()->label(__('admin.actions'))->buttons([
|
||||||
|
$this->rowShowTypeButton('drawer', 'xl')->visible($user->can('admin.agreement.view')),
|
||||||
|
$this->rowEditTypeButton('drawer', 'xl')->visible($user->can('admin.agreement.update')),
|
||||||
|
$this->rowDeleteButton()->visible($user->can('admin.agreement.delete')),
|
||||||
|
amisMake()->AjaxAction()
|
||||||
|
->level('link')
|
||||||
|
->label('打包下载')
|
||||||
|
->api('post:'.admin_url('agreement/download?id=${id}'))
|
||||||
|
->visible($user->can('admin.agreement.download')),
|
||||||
|
]),
|
||||||
|
]);
|
||||||
|
|
||||||
|
return $this->baseList($crud);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function form(): Form
|
||||||
|
{
|
||||||
|
return $this->baseForm()->body([
|
||||||
|
amisMake()->TextControl()->name('name')->label(__('agreement.name'))->required(),
|
||||||
|
amisMake()->SelectControl()->name('employee_id')->label(__('agreement.employee_id'))
|
||||||
|
->source(admin_url('api/employees?_all=1&store_id_gt=0&employee_status='.EmployeeStatus::Online->value))
|
||||||
|
->labelField('name')
|
||||||
|
->valueField('id')
|
||||||
|
->searchable()
|
||||||
|
->required(),
|
||||||
|
amisMake()->ImageControl()->name('images')->label(__('agreement.images'))
|
||||||
|
->multiple()
|
||||||
|
->draggable()
|
||||||
|
->joinValues(false),
|
||||||
|
amisMake()->TextControl()->name('remarks')->label(__('agreement.remarks')),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function detail(): Form
|
||||||
|
{
|
||||||
|
return $this->baseDetail()->title('')->body(amisMake()->Property()->items([
|
||||||
|
['label' => __('agreement.name'), 'content' => '${name}'],
|
||||||
|
['label' => __('agreement.employee_id'), 'content' => '${employee.name}'],
|
||||||
|
['label' => __('agreement.created_at'), 'content' => '${created_at}'],
|
||||||
|
['label' => __('agreement.remarks'), 'content' => '${remarks}', 'span' => 3],
|
||||||
|
['label' => __('agreement.images'), 'content' => amisMake()->Images()->name('images')->enlargeAble(), 'span' => 3],
|
||||||
|
]));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function download(Request $request)
|
||||||
|
{
|
||||||
|
$id = $request->input('id');
|
||||||
|
$images = Agreement::whereIn('id', is_array($id) ? $id : explode(',', $id))->pluck('images');
|
||||||
|
$list = Arr::flatten($images);
|
||||||
|
$baseUrl = Storage::url('');
|
||||||
|
$zip = new \ZipArchive();
|
||||||
|
$filename = time().'.zip';
|
||||||
|
$zip->open($filename, \ZipArchive::CREATE | \ZipArchive::OVERWRITE);
|
||||||
|
foreach($list as $item) {
|
||||||
|
$path = str_replace($baseUrl, '', $item);
|
||||||
|
$info = pathinfo($path);
|
||||||
|
$zip->addFile(Storage::path($path), data_get($info, 'basename'));
|
||||||
|
}
|
||||||
|
$zip->close();
|
||||||
|
return response()->download($filename)->deleteFileAfterSend();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,35 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Admin\Filters;
|
||||||
|
|
||||||
|
use Carbon\Carbon;
|
||||||
|
use EloquentFilter\ModelFilter;
|
||||||
|
|
||||||
|
class AgreementFilter extends ModelFilter
|
||||||
|
{
|
||||||
|
protected $drop_id = false;
|
||||||
|
|
||||||
|
public $relations = [
|
||||||
|
'employee' => [
|
||||||
|
'employee_name' => 'name',
|
||||||
|
'employee_search' => 'search',
|
||||||
|
],
|
||||||
|
'invitor' => [
|
||||||
|
'invitor_name' => 'name',
|
||||||
|
'invitor_search' => 'search',
|
||||||
|
],
|
||||||
|
];
|
||||||
|
|
||||||
|
public function employeeId($key)
|
||||||
|
{
|
||||||
|
$this->where('employee_id', $key);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function dateRange($dates)
|
||||||
|
{
|
||||||
|
$dates = explode(',', $dates);
|
||||||
|
$start = Carbon::createFromTimestamp(data_get($dates, 0, time()))->startOfDay();
|
||||||
|
$end = Carbon::createFromTimestamp(data_get($dates, 1, time()))->endOfDay();
|
||||||
|
$this->whereBetween('created_at', [$start, $end]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,46 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Admin\Services;
|
||||||
|
|
||||||
|
use App\Admin\Filters\AgreementFilter;
|
||||||
|
use App\Models\Agreement;
|
||||||
|
use Illuminate\Support\Facades\{Validator, Storage};
|
||||||
|
use Illuminate\Support\Str;
|
||||||
|
|
||||||
|
class AgreementService extends BaseService
|
||||||
|
{
|
||||||
|
protected array $withRelationships = ['employee'];
|
||||||
|
|
||||||
|
protected string $modelName = Agreement::class;
|
||||||
|
|
||||||
|
protected string $modelFilterName = AgreementFilter::class;
|
||||||
|
|
||||||
|
public function resloveData($data, $model = null)
|
||||||
|
{
|
||||||
|
if (isset($data['images'])) {
|
||||||
|
$images = [];
|
||||||
|
foreach ($data['images'] as $value) {
|
||||||
|
$image = is_array($value) ? data_get($value, 'value') : $value;
|
||||||
|
$url = Str::startsWith($image, ['http://', 'https://']) ? $image : Storage::url($image);
|
||||||
|
array_push($images, $url);
|
||||||
|
}
|
||||||
|
$data['images'] = $images;
|
||||||
|
}
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function validate($data, $model = null)
|
||||||
|
{
|
||||||
|
$createRules = [
|
||||||
|
'employee_id' => ['required'],
|
||||||
|
'name' => ['required'],
|
||||||
|
];
|
||||||
|
$updateRules = [];
|
||||||
|
$validator = Validator::make($data, $model ? $updateRules : $createRules);
|
||||||
|
if ($validator->fails()) {
|
||||||
|
return $validator->errors()->first();
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -27,6 +27,7 @@ use App\Admin\Controllers\System\AdminRoleController;
|
||||||
use App\Admin\Controllers\System\AdminUserController;
|
use App\Admin\Controllers\System\AdminUserController;
|
||||||
use App\Admin\Controllers\System\KeywordController;
|
use App\Admin\Controllers\System\KeywordController;
|
||||||
use App\Admin\Controllers\System\WorkflowController;
|
use App\Admin\Controllers\System\WorkflowController;
|
||||||
|
use App\Admin\Controllers\AgreementController;
|
||||||
use Illuminate\Routing\Router;
|
use Illuminate\Routing\Router;
|
||||||
use Illuminate\Support\Facades\Route;
|
use Illuminate\Support\Facades\Route;
|
||||||
|
|
||||||
|
|
@ -180,6 +181,9 @@ Route::group([
|
||||||
|
|
||||||
$router->resource('ads', \App\Admin\Controllers\AdController::class);
|
$router->resource('ads', \App\Admin\Controllers\AdController::class);
|
||||||
|
|
||||||
|
$router->post('agreement/download', [AgreementController::class, 'download'])->name('agreement.download');
|
||||||
|
$router->resource('agreement', AgreementController::class);
|
||||||
|
|
||||||
//修改上传
|
//修改上传
|
||||||
$router->post('upload_file', [\App\Admin\Controllers\IndexController::class, 'uploadFile']);
|
$router->post('upload_file', [\App\Admin\Controllers\IndexController::class, 'uploadFile']);
|
||||||
$router->post('upload_image', [\App\Admin\Controllers\IndexController::class, 'uploadImage']);
|
$router->post('upload_image', [\App\Admin\Controllers\IndexController::class, 'uploadImage']);
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,32 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Models;
|
||||||
|
|
||||||
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||||
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
use App\Traits\HasDateTimeFormatter;
|
||||||
|
use EloquentFilter\Filterable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 合同
|
||||||
|
*/
|
||||||
|
class Agreement extends Model
|
||||||
|
{
|
||||||
|
use HasDateTimeFormatter, Filterable;
|
||||||
|
|
||||||
|
protected $fillable = ['name', 'employee_id', 'images', 'remarks'];
|
||||||
|
|
||||||
|
protected $casts = [
|
||||||
|
'images' => 'json',
|
||||||
|
];
|
||||||
|
|
||||||
|
public function modelFilter()
|
||||||
|
{
|
||||||
|
return \App\Admin\Filters\AgreementFilter::class;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function employee()
|
||||||
|
{
|
||||||
|
return $this->belongsTo(Employee::class, 'employee_id');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,33 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use Illuminate\Database\Schema\Blueprint;
|
||||||
|
use Illuminate\Support\Facades\Schema;
|
||||||
|
|
||||||
|
return new class extends Migration
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the migrations.
|
||||||
|
*/
|
||||||
|
public function up(): void
|
||||||
|
{
|
||||||
|
Schema::create('agreements', function (Blueprint $table) {
|
||||||
|
$table->id();
|
||||||
|
$table->string('name')->comment('名称');
|
||||||
|
$table->foreignId('employee_id')->comment('上传人');
|
||||||
|
$table->json('images')->nullable()->comment('图片列表');
|
||||||
|
$table->string('remarks')->nullable()->comment('备注');
|
||||||
|
$table->timestamps();
|
||||||
|
|
||||||
|
$table->comment('合同');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*/
|
||||||
|
public function down(): void
|
||||||
|
{
|
||||||
|
Schema::dropIfExists('agreements');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
@ -250,6 +250,16 @@ class AdminPermissionSeeder extends Seeder
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
|
|
||||||
|
'agreement' => [
|
||||||
|
'name' => '合同管理',
|
||||||
|
'icon' => '',
|
||||||
|
'uri' => '/agreement',
|
||||||
|
'resource' => true,
|
||||||
|
'children' => [
|
||||||
|
'download' => '打包下载',
|
||||||
|
]
|
||||||
|
],
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
| 系统管理
|
| 系统管理
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,12 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
return [
|
||||||
|
'id' => 'ID',
|
||||||
|
'created_at' => '创建时间',
|
||||||
|
'updated_at' => '更新时间',
|
||||||
|
|
||||||
|
'name' => '名称',
|
||||||
|
'employee_id' => '上传人',
|
||||||
|
'images' => '合同图片',
|
||||||
|
'remarks' => '备注',
|
||||||
|
];
|
||||||
Loading…
Reference in New Issue