| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238 |
- <?php
- namespace App\Http\Controllers;
- use App\Components\AsyncResponse;
- use App\Facilitator;
- use App\DischargeTask;
- use App\Filters\DischargeTaskFilters;
- use App\Http\Requests\DischargeTask\DischargeTaskRequest;
- use App\Imports\DischargeTaskCostEntryImport;
- use App\Imports\DischargeTaskImport;
- use App\Owner;
- use App\Role;
- use App\Services\DischargeTaskService;
- use App\Services\OwnerService;
- use App\Services\UserService;
- use App\Warehouse;
- use Illuminate\Http\Request;
- use Illuminate\Support\Facades\Auth;
- use Illuminate\Support\Facades\Cache;
- use Illuminate\Support\Facades\Gate;
- use Maatwebsite\Excel\Facades\Excel;
- use Oursdreams\Export\Export;
- class DischargeTaskController extends Controller
- {
- use AsyncResponse;
- public function index(Request $request, DischargeTaskFilters $filters)
- {
- if (!Gate::allows('人事管理-卸货-查询')) {
- return redirect(url('/'));
- }
- if (Gate::allows('人事管理-卸货-货主可见全部')) {
- $owners = Owner::query()->get();
- $dischargeTasks = DischargeTask::query()->with(['facilitator', 'owner', 'warehouse'])->filter($filters)->orderByDesc('income_at')->paginate($request['paginate'] ?? 50);
- } else {
- $owners = app(OwnerService::class)->getAuthorizedOwners();
- $dischargeTasks = DischargeTask::query()->with(['facilitator', 'owner', 'warehouse'])->filter($filters)->whereIn('owner_id', data_get($owners, '*.id'))->orderByDesc('income_at')->paginate($request['paginate'] ?? 50);
- }
- $roles = Role::query()->where('name','like','人事%')->get();
- $personnel = app(UserService::class)->hasRoles(Auth::user(),$roles);
- $personnel = $personnel ? 'true' : 'false';
- if(in_array(Auth::user()["name"],config("users.superAdmin"))){
- $personnel = 'true';
- }
- $warehouses = Warehouse::query()->select('id', 'name')->get();
- $facilitators = Facilitator::query()->select('name', 'id')->get();
- return view('personnel.discharge.task.index', compact('dischargeTasks', 'owners', 'facilitators', 'warehouses','personnel'));
- }
- // 结算报表
- public function statementIndex(Request $request, DischargeTaskFilters $filters)
- {
- if (!Gate::allows('人事管理-卸货-结算报表-查询')) {
- return redirect(url('/'));
- }
- $dischargeStatements = DischargeTask::query()->with('facilitator')->filter($filters)->orderByDesc('income_at')->paginate($request['paginate'] ?? 50);
- $owners = app(OwnerService::class)->getAuthorizedOwners();
- $facilitators = Facilitator::query()->select('name', 'id')->get();
- return view('personnel.discharge.statement.index', compact('dischargeStatements', 'owners', 'facilitators'));
- }
- // async 创建
- public function storeApi(DischargeTaskRequest $request)
- {
- $this->gate('人事管理-卸货-创建');
- $result = app('DischargeTaskService')->createTask($request->all());
- if ($result['success']) $this->success($result['data']);
- $this->error('任务创建异常,刷新当前页面重试');
- }
- // async 编辑
- public function updateApi(DischargeTaskRequest $request)
- {
- $this->gate('人事管理-卸货-编辑');
- $dischargeTask = DischargeTask::query()->where('id', $request['id'])->first();
- $result = app('DischargeTaskService')->updateDischargeTask($dischargeTask, $request->all());
- if ($result['success']) $this->success($result['data']);
- else $this->error($result['message'] ?? '操作异常,请刷新页面重试');
- }
- // 修改任务服务商
- public function updateTaskFacilitatorApi(DischargeTaskRequest $request)
- {
- $this->gate('人事管理-卸货-编辑');
- /** @var DischargeTask $dischargeTask */
- $dischargeTask = DischargeTask::query()->where('id', $request['id'])->first();
- if (!$dischargeTask) $this->error('没有找对应的卸货任务');
- $result = app('DischargeTaskService')->updateTaskFacilitator($dischargeTask, $request->all());
- if ($result['success']) $this->success($result['data']);
- else $this->error($result['message'] ?? '操作异常,请刷新页面重试');
- }
- // async 删除
- public function destroyApi(DischargeTaskRequest $request)
- {
- $this->gate('人事管理-卸货-删除');
- /** @var DischargeTask $dischargeTask */
- $dischargeTask = DischargeTask::query()->where('id', $request['id'])->first();
- $result = app('DischargeTaskService')->deleteDischargeTask($dischargeTask);
- if ($result['success']) $this->success();
- else $this->error($result['message']);
- }
- // 执行任务
- public function executingTaskApi(DischargeTaskRequest $request)
- {
- $this->gate('人事管理-卸货-编辑');
- $dischargeTask = DischargeTask::query()->where('id', $request['id'])->first();
- $result = app('DischargeTaskService')->updateTaskProvider($dischargeTask, $request->all());
- if ($result['success']) $this->success($result['data']);
- $this->error($result['message'] ?? '操作异常,请刷新页面重试');
- }
- // 卸货任务下载
- public function export(Request $request, DischargeTaskFilters $filters)
- {
- $this->gate('人事管理-卸货-查询');
- if (Gate::allows('人事管理-卸货-货主可见全部')) {
- $dischargeTasks = DischargeTask::query()->with(['Facilitator', 'owner'])->filter($filters)->orderByDesc('id')->get();
- } else {
- $owners = app(OwnerService::class)->getAuthorizedOwners();
- $dischargeTasks = DischargeTask::query()->with(['Facilitator', 'owner'])->filter($filters)->whereIn('owner_id', data_get($owners, '*.id'))->orderByDesc('id')->get();
- }
- $row = ['日期','仓库', '客户名称', '作业名称','入库单号', '数量', '单位', '单价', '收费', '状态', '备注'];
- $json = app('DischargeTaskService')->getJson($dischargeTasks);
- return Export::make($row, $json, "卸货任务");
- }
- // 结算报表下载
- public function exportStatements(Request $request, DischargeTaskFilters $filters)
- {
- $this->gate('人事管理-卸货-结算报表-查询');
- $dischargeTasks = DischargeTask::query()->with(['facilitator', 'owner', 'warehouse'])->filter($filters)->orderByDesc('income_at')->get();
- $row = ['日期', '客户名称', '仓库', '作业名称', '入库单号', '数量', '单位', '收入单价', '收入合计', '装卸队', '数量', '单位', '支出单价', '支出合计', '状态', '收入备注', '支出备注'];
- $json = app('DischargeTaskService')->getStatementsJson($dischargeTasks);
- return Export::make($row, $json, "卸货结算报表");
- }
- public function receipt(Request $request)
- {
- $task = DischargeTask::query()->with(['facilitator', 'owner', 'warehouse'])->where('id', $request['id'])->first();
- $task->type = DischargeTask::types[$task->type];
- return view('personnel.discharge.task.receipt', compact('task'));
- }
- public function importApi(Request $request): array
- {
- $this->gate('人事管理-卸货-创建');
- $extension = $request->file()['file']->getClientOriginalExtension();
- if (!in_array($extension, ['xlsx', 'xlsm', 'xltx', 'xltm', 'xls', 'xlt', 'ods', 'ots', 'slk', 'xml', 'gnumeric', 'htm', 'html', 'csv', 'tsv']))
- return ['success' => false, 'message' => '请检查导入文件是否符合要求'];
- $extension[0] = strtoupper($extension[0]);
- try {
- Excel::import(new DischargeTaskImport(), $request->file()['file']->path(), null, $extension);
- } catch (\Exception $e) {
- return ['success' => false, 'message' => ['请检查导入文件是否符合要求']];
- }
- $exception=Cache::get('exception');
- if ($exception) {
- return ['success' => false, 'errors' => $exception];
- }
- return ['success' => true];
- }
- public function constEntryImportApi(Request $request): array
- {
- $this->gate('人事管理-卸货-成本录入');
- $extension = $request->file()['file']->getClientOriginalExtension();
- $flag = !in_array($extension, ['xlsx', 'xlsm', 'xltx', 'xltm', 'xls', 'xlt', 'ods', 'ots', 'slk', 'xml', 'gnumeric', 'htm', 'html', 'csv', 'tsv']);
- if ($flag){
- return ['success' => false, 'message' => '请检查导入文件是否符合要求'];
- }
- $extension[0] = strtoupper($extension[0]);
- try {
- Excel::import(new DischargeTaskCostEntryImport(), $request->file()['file']->path(), null, $extension);
- } catch (\Exception $e) {
- return ['success' => false, 'message' => ['请检查导入文件是否符合要求']];
- }
- $exception=Cache::get('exception');
- $numbers=Cache::get('numbers');
- if ($exception) return ['success' => false, 'errors' => $exception,'message' => $numbers];
- return ['success' => true];
- }
- public function show(DischargeTask $dischargeTask)
- {
- }
- public function edit(DischargeTask $dischargeTask)
- {
- }
- public function update(Request $request, DischargeTask $dischargeTask)
- {
- }
- public function store(Request $request)
- {
- }
- public function create()
- {
- }
- public function destroy(DischargeTask $dischargeTask)
- {
- }
- }
|