findOrEmpty(); if ($taskType->isEmpty()) { self::setError('项目未配置任务类别'); } Db::startTrans(); try { TaskAllocation::where('id', $params['id'])->update([ 'task_type_id' => $taskType['id'], // 任务类别id 'cost_project_id' => $taskType['cost_project_id'], // 项目id 'apptime' => $params['apptime'], 'annex' => $params['annex'] ? json_encode($params['annex']) : null, ]); Db::commit(); // 任务明细 if (!empty($params['task_detail'])) { foreach ($params['task_detail'] as $item) { if (!empty($item['id'])) { $item['task_type_id'] = $taskType['id']; TaskDetailLogic::edit($item); } else { $item['task_allocation_id'] = $params['id']; $item['task_type_id'] = $taskType['id']; TaskDetailLogic::add($item); } } } return true; } catch (\Exception $e) { Db::rollback(); self::setError($e->getMessage()); return false; } } /** * @notes 添加 * @param array $params * @return bool * @author likeadmin * @date 2024/02/22 10:47 */ public static function add(array $params): bool { // 项目id关联任务类别 $projectId = $params['project_id']; // 任务 $taskType = TaskType::where('cost_project_id', $projectId)->findOrEmpty(); if ($taskType->isEmpty()) { self::setError('项目未配置任务类别'); return false; } Db::startTrans(); try { // 任务分配 $taskAllocation = TaskAllocation::create([ 'dataid' => generate_sn(TaskAllocation::class, 'dataid'), 'num' => generate_sn(TaskAllocation::class, 'num'), 'task_type_id' => $taskType['id'], // 任务类别id 'cost_project_id' => $taskType['cost_project_id'], // 项目id 'apptime' => $params['apptime'], 'annex' => $params['annex'] ? json_encode($params['annex']) : null, ]); // 任务明细 if (!empty($params['task_detail'])) { foreach ($params['task_detail'] as $item) { $item['task_allocation_id'] = $taskAllocation->id; $item['task_type_id'] = $taskType['id']; TaskDetailLogic::add($item); } } Db::commit(); return true; } catch (\Exception $e) { Db::rollback(); self::setError($e->getMessage()); return false; } } /** * @notes 删除 * @param array $params * @return bool * @author likeadmin * @date 2024/02/22 10:47 */ public static function delete(array $params): bool { $task_detail = TaskDetail::where('task_allocation_id', 'in', $params['id'])->findOrEmpty(); if (!$task_detail->isEmpty()) { self::setError('此数据关联了任务明细信息,须删除任务明细信息'); return false; } return TaskAllocation::destroy($params['id']); } /** * @notes 获取详情 * @param $params * @return array * @author likeadmin * @date 2024/02/22 10:47 */ public static function detail($params): array { $data = TaskAllocation::with(['taskTypeInfo', 'projectInfo'])->findOrEmpty($params['id'])->toArray(); $contract = MarketingContract::field('project_manager')->where('id', $data['projectInfo']['contract_id'])->findOrEmpty(); $admin = Admin::field('name')->where('id', $contract['project_manager'])->findOrEmpty(); $data['project_director'] = $admin['name']; $data['task_detail'] = TaskDetail::where('task_allocation_id', $data['id'])->select()->each(function ($item) { $taskTypeInfo = TaskType::findOrEmpty($item['task_type_id'])->toArray(); $item['task_name'] = $taskTypeInfo['name']; $item['professional_type_text'] = $item->professional_type_text; $item['task_type_id_text'] = $item->task_type_id_text; })->toArray(); return $data; } }