$params['supplier_id'] ?? 0, 'approve_id' => $params['approve_id'] ?? 0, 'project_id' => $params['project_id'] ?? 0, 'contract_no' => $params['contract_no'] ?? '', 'supplier_contract_no' => $params['supplier_contract_no'] ?? '', 'contract_type' => $params['contract_type'] ?? 0, 'signing_date' => strtotime($params['signing_date']), 'pay_type' => $params['pay_type'] ?? 0, 'account_period' => $params['account_period'] ?? 0, 'amount' => $params['amount'] ?? 0, 'amount_excluding_tax' => $params['amount_excluding_tax'] ?? 0, 'amount_daxie' => $params['amount_daxie'] ?? '', 'retention_money_rate' => $params['retention_money_rate'] ?? '', 'retention_money' => $params['retention_money'] ?? 0, 'remark' => $params['remark'] ?? '', 'annex' => $params['annex'] ?? '' ]); foreach ($params['material'] ?? [] as $item) { ProcurementContractDetail::create([ 'procurement_contract_id' => $procurementContract->id, 'material_procurement_application_id' => $item['material_procurement_application_id'] ?? 0, 'num' => $item['num'] ?? 0, 'unit_price_including_tax' => $item['unit_price_including_tax'] ?? 0, 'tax_rate' => $item['tax_rate'] ?? 0, 'amount_excluding_tax' => $item['amount_excluding_tax'] ?? 0, 'amount_including_tax' => $item['amount_including_tax'] ?? 0, ]); } Db::commit(); return true; } catch (\Exception $e) { Db::rollback(); self::setError($e->getMessage()); return false; } } /** * @notes 编辑采购合同 * @param array $params * @return bool * @author likeadmin * @date 2023/12/04 22:08 */ public static function edit(array $params): bool { Db::startTrans(); try { ProcurementContract::where('id', $params['id'])->update([ 'supplier_id' => $params['supplier_id'] ?? 0, 'approve_id' => $params['approve_id'] ?? 0, 'project_id' => $params['project_id'] ?? 0, 'contract_no' => $params['contract_no'] ?? '', 'supplier_contract_no' => $params['supplier_contract_no'] ?? '', 'contract_type' => $params['contract_type'] ?? 0, 'signing_date' => strtotime($params['signing_date']), 'pay_type' => $params['pay_type'] ?? 0, 'account_period' => $params['account_period'] ?? 0, 'amount' => $params['amount'] ?? 0, 'amount_excluding_tax' => $params['amount_excluding_tax'] ?? 0, 'amount_daxie' => $params['amount_daxie'] ?? '', 'retention_money_rate' => $params['retention_money_rate'] ?? '', 'retention_money' => $params['retention_money'] ?? 0, 'remark' => $params['remark'] ?? '', 'annex' => $params['annex'] ?? '' ]); ProcurementContractDetail::where('procurement_contract_id', $params['id'])->update(['delete_time' =>time()]); foreach ($params['material'] ?? [] as $item) { ProcurementContractDetail::create([ 'procurement_contract_id' => $params['id'], 'material_procurement_application_id' => $item['material_procurement_application_id'] ?? 0, 'num' => $item['num'] ?? 0, 'unit_price_including_tax' => $item['unit_price_including_tax'] ?? 0, 'tax_rate' => $item['tax_rate'] ?? 0, 'amount_excluding_tax' => $item['amount_excluding_tax'] ?? 0, 'amount_including_tax' => $item['amount_including_tax'] ?? 0, ]); } Db::commit(); return true; } catch (\Exception $e) { Db::rollback(); self::setError($e->getMessage()); return false; } } /** * @notes 删除采购合同 * @param array $params * @return bool * @author likeadmin * @date 2023/12/04 22:08 */ public static function delete(array $params): bool { return ProcurementContract::destroy($params['id']); } /** * @notes 获取采购合同详情 * @param $params * @return array * @author likeadmin * @date 2023/12/04 22:08 */ public static function detail($params): array { $procurementContract = ProcurementContract::findOrEmpty($params['id']); $procurementContract->custom = null; if (!empty($procurementContract->project->custom_id)) { $procurementContract->custom = Custom::findOrEmpty($procurementContract->project->custom_id); } $procurementContract->project = $procurementContract->project; $procurementContract->material = $procurementContract->material; return $procurementContract->toArray(); } }