$params['contract_id'], 'collection_amount' => $params['collection_amount'], 'collection_date' => !empty($params['collection_date']) ? strtotime($params['collection_date']) : 0, 'collection_user' => $params['collection_user'], 'remark' => $params['remark'] ?? '', 'annex' => $params['annex'] ? json_encode($params['annex']) : null, ]); 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/04/13 13:46 */ public static function edit(array $params): bool { Db::startTrans(); try { FinancialCollectionPlan::where('id', $params['id'])->update([ 'contract_id' => $params['contract_id'], 'collection_amount' => $params['collection_amount'], 'collection_date' => !empty($params['collection_date']) ? strtotime($params['collection_date']) : 0, 'collection_user' => $params['collection_user'], 'remark' => $params['remark'] ?? '', 'annex' => $params['annex'] ? json_encode($params['annex']) : null, ]); 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/04/13 13:46 */ public static function delete(array $params): bool { return FinancialCollectionPlan::destroy($params['id']); } /** * @notes 获取财务管理--合同收款计划详情 * @param $params * @return array * @author likeadmin * @date 2024/04/13 13:46 */ public static function detail($params): array { $data = FinancialCollectionPlan::withoutField('create_time,update_time,delete_time')->findOrEmpty($params['id']); $contract = MarketingContract::field('contract_name,contract_type,business_nature,part_a,signed_amount,create_time')->where('id', $data['contract_id'])->findOrEmpty(); $custom = MarketingCustom::field('name')->where('id', $contract['part_a'])->findOrEmpty(); $data['contract_name'] = $contract?->contract_name; $data['contract_type'] = $contract?->contract_type_text; $data['business_nature'] = $contract?->business_nature_text; $data['signed_amount'] = $contract?->signed_amount; $data['signed_date'] = $contract?->create_time; $data['part_a_name'] = $custom?->name; //开票金额 $data['total_invoice_amount'] = FinancialInvoice::where('contract_id', $data['contract_id'])->sum('apply_amount'); //到账金额 $data['total_refund_amount'] = FinancialRefund::where('contract_id', $data['contract_id'])->sum('amount'); //结算金额 $data['total_settlement_amount'] = FinancialSettlement::where('contract_id', $data['contract_id'])->sum('amount'); return $data->toArray(); } }