/** * Méthode permettant de construire un log affichant une liste d'échéance * * @param paymentScheduleLineList * @return */ public String toStringPaymentScheduleLineList(List<PaymentScheduleLine> paymentScheduleLineList) { String list = " (nb = "; list += paymentScheduleLineList.size(); list += " ) : "; for (PaymentScheduleLine paymentScheduleLine : paymentScheduleLineList) { list += paymentScheduleLine.getName(); list += ", "; } return list; }
/** * Y a t'il d'autres échéance a exporter pour le même payeur ? * * @param pslList : une liste d'échéance * @param psl * @return */ public boolean hasOtherPaymentScheduleLine( List<PaymentScheduleLine> pslList, PaymentScheduleLine psl) { int i = 0; for (PaymentScheduleLine paymentScheduleLine : pslList) { paymentScheduleLine = paymentScheduleLineRepo.find(paymentScheduleLine.getId()); if (psl.getPaymentSchedule().equals(paymentScheduleLine.getPaymentSchedule())) { i++; } } return i > 1; }
/** * Méthode permettant de retrouver l'échéance rejetée qui à impliquer la création de la nouvelle * échéance * * @param paymentScheduleLine La nouvelle échéance */ public PaymentScheduleLine getPaymentScheduleLineRejectOrigin( PaymentScheduleLine paymentScheduleLine) { return paymentScheduleLineRepo .all() .filter( "self.paymentSchedule = ?1 AND self.scheduleLineSeq = ?2 AND self.statusSelect = ?3 ORDER BY self.rejectDate DESC", paymentScheduleLine.getPaymentSchedule(), paymentScheduleLine.getScheduleLineSeq(), PaymentScheduleLineRepository.STATUS_CLOSED) .fetchOne(); }
public boolean isDebitBlocking(PaymentScheduleLine paymentScheduleLine) { PaymentSchedule paymentSchedule = paymentScheduleLine.getPaymentSchedule(); return blockingService.isDebitBlockingBlocking( paymentSchedule.getPartner(), paymentSchedule.getCompany()); }
/** * Procédure permettant d'assigner un numéro de prélèvement à l'échéance à prélever Si plusieurs * échéance d'un même échéancier sont à prélever, alors on utilise un objet de gestion de * prélèvement encadrant l'ensemble des échéances en question Sinon on assigne simplement un * numéro de prélèvement à l'échéance * * @param paymentScheduleLineList Une liste d'échéance à prélever * @param paymentScheduleLine L'échéance traité * @param company Une société * @param journal Un journal (prélèvement mensu masse ou grand compte) * @throws AxelorException */ public void setDebitNumber( List<PaymentScheduleLine> paymentScheduleLineList, PaymentScheduleLine paymentScheduleLine, Company company) throws AxelorException { if (hasOtherPaymentScheduleLine(paymentScheduleLineList, paymentScheduleLine)) { DirectDebitManagement directDebitManagement = this.getDirectDebitManagement(paymentScheduleLineList, paymentScheduleLine); if (directDebitManagement == null) { directDebitManagement = this.createDirectDebitManagement(this.getDirectDebitSequence(company), company); } paymentScheduleLine.setDirectDebitManagement(directDebitManagement); directDebitManagement.getPaymentScheduleLineList().add(paymentScheduleLine); } else { paymentScheduleLine.setDebitNumber(this.getDirectDebitSequence(company)); } }
/** * Procédure permettant de récupérer l'objet de gestion déjà créé lors du prélèvement d'une autre * échéance * * @param pslList La liste d'échéance à prélever * @param psl L'échéance à prélever * @return L'objet de gestion trouvé */ public DirectDebitManagement getDirectDebitManagement( List<PaymentScheduleLine> pslList, PaymentScheduleLine psl) { for (PaymentScheduleLine paymentScheduleLine : pslList) { paymentScheduleLine = paymentScheduleLineRepo.find(paymentScheduleLine.getId()); if (psl.getPaymentSchedule().equals(paymentScheduleLine.getPaymentSchedule())) { if (paymentScheduleLine.getDirectDebitManagement() != null) { return paymentScheduleLine.getDirectDebitManagement(); } } } return null; }
@Transactional(rollbackOn = {AxelorException.class, Exception.class}) public PaymentScheduleLine generateExportMensu( PaymentScheduleLine paymentScheduleLine, List<PaymentScheduleLine> paymentScheduleLineList, Company company) throws AxelorException { PaymentSchedule paymentSchedule = paymentScheduleLine.getPaymentSchedule(); this.testBankDetails(paymentSchedule); AccountConfig accountConfig = company.getAccountConfig(); Account account = accountConfig.getCustomerAccount(); PaymentMode paymentMode = accountConfig.getDirectDebitPaymentMode(); BigDecimal amount = paymentScheduleLine.getInTaxAmount(); Partner partner = paymentSchedule.getPartner(); Move move = moveService .getMoveCreateService() .createMove( paymentModeService.getPaymentModeJournal(paymentMode, company), company, null, partner, paymentMode); this.setDebitNumber(paymentScheduleLineList, paymentScheduleLine, company); MoveLine moveLine = moveLineRepo.save( moveLineServices.createMoveLine( move, partner, account, amount, false, today, 1, paymentScheduleLine.getName())); move.addMoveLineListItem(moveLine); if (paymentScheduleLine.getFromReject()) { // lettrage avec le rejet PaymentScheduleLine rejectedPaymentScheduleLine = this.getPaymentScheduleLineRejectOrigin(paymentScheduleLine); if (rejectedPaymentScheduleLine.getRejectMoveLine() != null && rejectedPaymentScheduleLine .getRejectMoveLine() .getAmountRemaining() .compareTo(BigDecimal.ZERO) == 1) { reconcileService.reconcile(rejectedPaymentScheduleLine.getRejectMoveLine(), moveLine); } } else { // Lettrage du paiement avec les factures d'échéances this.reconcileDirectDebit(moveLine, paymentSchedule); } move.addMoveLineListItem( moveLineServices.createMoveLine( move, partner, paymentModeService.getCompanyAccount(paymentMode, company), amount, true, today, 2, null)); this.validateMove(move); paymentScheduleLine.setDirectDebitAmount(amount); paymentScheduleLine.setInTaxAmountPaid(amount); paymentScheduleLine.setAdvanceOrPaymentMove(moveRepo.find(move.getId())); paymentScheduleLine.setAdvanceMoveLine(moveLine); paymentScheduleLine.setStatusSelect(PaymentScheduleLineRepository.STATUS_VALIDATED); return paymentScheduleLineRepo.save(paymentScheduleLine); }