/**
  * 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);
  }