$params['project_id'], 'material_entry_id' => $params['material_entry_id'], 'code' => data_unique_code('JZQY'), 'sampling_date' => !empty($params['sampling_date']) ? strtotime($params['sampling_date']) : 0, 'witness' => $params['witness'], 'sampler' => $params['sampler'], 'annex' => $params['annex'] ? json_encode($params['annex']) : null, 'create_user' => $params['create_user'], 'create_time' => !empty($params['create_time']) ? strtotime($params['create_time']) : time(), ]); if (!empty($params['sampling_detail'])) { foreach ($params['sampling_detail'] as $v) { SupervisionWitnessSamplingDetail::create([ 'witness_sampling_id' => $res->id, 'material_entry_detail_id' => $v['material_entry_detail_id'], 'num' => $v['num'] ]); } } 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/29 09:22 */ public static function edit(array $params): bool { Db::startTrans(); try { SupervisionWitnessSampling::where('id', $params['id'])->update([ 'project_id' => $params['project_id'], 'material_entry_id' => $params['material_entry_id'], 'sampling_date' => !empty($params['sampling_date']) ? strtotime($params['sampling_date']) : 0, 'witness' => $params['witness'], 'sampler' => $params['sampler'], 'annex' => $params['annex'] ? json_encode($params['annex']) : null, 'create_user' => $params['create_user'], 'create_time' => !empty($params['create_time']) ? strtotime($params['create_time']) : time(), 'update_time' => time() ]); if (!empty($params['sampling_detail'])) { foreach ($params['sampling_detail'] as $v) { if (!empty($v['id'])) { SupervisionWitnessSamplingDetail::where('id', $v['id'])->update([ 'witness_sampling_id' => $params['id'], 'material_entry_detail_id' => $v['material_entry_detail_id'], 'num' => $v['num'], 'update_time' => time() ]); } else { SupervisionWitnessSamplingDetail::create([ 'witness_sampling_id' => $params['id'], 'material_entry_detail_id' => $v['material_entry_detail_id'], 'num' => $v['num'] ]); } } } 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/29 09:22 */ public static function delete(array $params): bool { $witness_sampling_detail = SupervisionWitnessSamplingDetail::where('witness_sampling_id', 'in', $params['id'])->findOrEmpty(); if (!$witness_sampling_detail->isEmpty()) { self::setError('当前数据下存在材料信息内容,请先删除材料信息内容'); return false; } return SupervisionWitnessSampling::destroy($params['id']); } /** * @notes 获取工程监理--见证取样详情 * @param $params * @return array * @author likeadmin * @date 2024/02/29 09:22 */ public static function detail($params): array { $data = SupervisionWitnessSampling::withoutField('update_time,delete_time')->findOrEmpty($params['id']); $project = SupervisionProject::field('project_name')->where('id', $data['project_id'])->findOrEmpty(); $material_entry = SupervisionMaterialEntry::field('theme,company_id,enter_time')->where('id', $data['material_entry_id'])->findOrEmpty(); $company = SupervisionParticipatingUnits::field('unit_name')->where('id', $material_entry['company_id'])->findOrEmpty(); $admin = Admin::where('id', 'in', [$data['witness'], $data['sampler']])->column('name', 'id'); $data['project_name'] = $project['project_name']; $data['company_name'] = $company['unit_name']; $data['material_entry_name'] = $material_entry['theme']; $data['enter_time'] = $material_entry['enter_time']; $data['witness_name'] = $admin[$data['witness']] ?? ''; $data['sampler_name'] = $admin[$data['sampler']] ?? ''; return $data->toArray(); } }