Search in sources :

Example 1 with NatureOfTransaction

use of com.axelor.apps.stock.db.NatureOfTransaction in project axelor-open-suite by axelor.

the class DeclarationOfExchangesExporterGoods method exportLineToCsv.

protected String[] exportLineToCsv(StockMoveLine stockMoveLine, int lineNum) throws AxelorException {
    String[] data = new String[columnHeadersList.size()];
    StockMove stockMove = stockMoveLine.getStockMove();
    String customsCode = stockMoveLine.getCustomsCode();
    Product product = stockMoveLine.getProduct();
    if (StringUtils.isBlank(customsCode)) {
        if (product == null) {
            customsCode = I18n.get("Product is missing.");
        }
        if (product != null && product.getCustomsCodeNomenclature() != null) {
            customsCode = product.getCustomsCodeNomenclature().getCode();
        }
        if (StringUtils.isBlank(customsCode)) {
            customsCode = String.format(I18n.get("Customs code nomenclature is missing on product %s."), product.getCode());
        }
    }
    BigDecimal fiscalValue = stockMoveLine.getCompanyUnitPriceUntaxed().multiply(stockMoveLine.getRealQty()).setScale(0, RoundingMode.HALF_UP);
    // Only positive fiscal value should be take into account
    if (fiscalValue.compareTo(BigDecimal.ZERO) <= 0) {
        return new String[0];
    }
    Regime regime = stockMoveLine.getRegime();
    if (regime == null) {
        if (stockMove.getTypeSelect() == StockMoveRepository.TYPE_OUTGOING) {
            regime = Regime.EXONERATED_SHIPMENT_AND_TRANSFER;
        } else if (stockMove.getTypeSelect() == StockMoveRepository.TYPE_INCOMING) {
            regime = Regime.INTRACOMMUNITY_ACQUISITION_TAXABLE_IN_FRANCE;
        }
    }
    BigDecimal totalNetMass = stockMoveLine.getTotalNetMass().setScale(0, RoundingMode.HALF_UP);
    BigInteger supplementaryUnit = stockMoveLine.getRealQty().setScale(0, RoundingMode.CEILING).toBigInteger();
    NatureOfTransaction natTrans = stockMoveLine.getNatureOfTransaction();
    if (natTrans == null) {
        natTrans = stockMove.getIsReversion() ? NatureOfTransaction.RETURN_OF_GOODS : NatureOfTransaction.FIRM_PURCHASE_OR_SALE;
    }
    ModeOfTransport modeOfTransport = stockMove.getModeOfTransport();
    if (modeOfTransport == null) {
        modeOfTransport = ModeOfTransport.CONSIGNMENTS_BY_POST;
    }
    String srcDstCountry;
    String dept;
    try {
        Address partnerAddress = stockMoveToolService.getPartnerAddress(stockMoveLine.getStockMove());
        srcDstCountry = partnerAddress.getAddressL7Country().getAlpha2Code();
    } catch (AxelorException e) {
        srcDstCountry = e.getMessage();
    }
    try {
        Address companyAddress = stockMoveToolService.getCompanyAddress(stockMoveLine.getStockMove());
        dept = companyAddress.getCity().getDepartment().getCode();
    } catch (AxelorException e) {
        dept = e.getMessage();
    }
    String countryOrigCode;
    if (stockMoveLine.getCountryOfOrigin() != null) {
        countryOrigCode = stockMoveLine.getCountryOfOrigin().getAlpha2Code();
    } else {
        if (stockMove.getTypeSelect() == StockMoveRepository.TYPE_INCOMING) {
            countryOrigCode = srcDstCountry;
        } else {
            countryOrigCode = "";
        }
    }
    String taxNbr;
    if (stockMove.getTypeSelect() == StockMoveRepository.TYPE_OUTGOING && stockMoveLine.getRegime() != Regime.OTHER_EXPEDITIONS) {
        if (stockMove.getPartner() == null) {
            taxNbr = String.format(I18n.get("Partner is missing on stock move %s."), stockMove.getName());
        } else if (StringUtils.isBlank(stockMove.getPartner().getTaxNbr())) {
            taxNbr = String.format(I18n.get("Tax number is missing on partner %s."), stockMove.getPartner().getName());
        } else {
            taxNbr = stockMove.getPartner().getTaxNbr();
        }
    } else {
        taxNbr = "";
    }
    String partnerSeq = "";
    if (stockMove.getPartner() != null) {
        partnerSeq = stockMove.getPartner().getPartnerSeq();
    }
    String productCode = "";
    String productName = "";
    if (product != null) {
        productCode = product.getCode();
        productName = product.getName();
    }
    String invoiceId = "";
    Set<Invoice> invoiceSet = stockMove.getInvoiceSet();
    if (invoiceSet != null) {
        for (Invoice invoice : invoiceSet) {
            if (invoice.getStatusSelect() == InvoiceRepository.STATUS_VENTILATED) {
                invoiceId += invoice.getInvoiceId() + "|";
            }
        }
        if (invoiceId != null && !invoiceId.isEmpty()) {
            invoiceId = invoiceId.substring(0, invoiceId.length() - 1);
        }
    }
    data[columnHeadersList.indexOf(LINE_NUM)] = String.valueOf(lineNum);
    data[columnHeadersList.indexOf(NOMENCLATURE)] = customsCode;
    data[columnHeadersList.indexOf(SRC_DST_COUNTRY)] = srcDstCountry;
    data[columnHeadersList.indexOf(FISC_VAL)] = String.valueOf(fiscalValue);
    data[columnHeadersList.indexOf(REGIME)] = String.valueOf(regime.getValue());
    data[columnHeadersList.indexOf(MASS)] = String.valueOf(totalNetMass);
    data[columnHeadersList.indexOf(UNITS)] = String.valueOf(supplementaryUnit);
    data[columnHeadersList.indexOf(NAT_TRANS)] = String.valueOf(natTrans.getValue());
    data[columnHeadersList.indexOf(TRANSP)] = String.valueOf(modeOfTransport.getValue());
    data[columnHeadersList.indexOf(DEPT)] = dept;
    data[columnHeadersList.indexOf(COUNTRY_ORIG)] = countryOrigCode;
    data[columnHeadersList.indexOf(ACQUIRER)] = taxNbr;
    data[columnHeadersList.indexOf(PRODUCT_CODE)] = productCode;
    data[columnHeadersList.indexOf(PRODUCT_NAME)] = productName;
    data[columnHeadersList.indexOf(PARTNER_SEQ)] = partnerSeq;
    data[columnHeadersList.indexOf(INVOICE)] = invoiceId;
    return data;
}
Also used : Regime(com.axelor.apps.stock.db.Regime) AxelorException(com.axelor.exception.AxelorException) StockMove(com.axelor.apps.stock.db.StockMove) Invoice(com.axelor.apps.account.db.Invoice) Address(com.axelor.apps.base.db.Address) Product(com.axelor.apps.base.db.Product) NatureOfTransaction(com.axelor.apps.stock.db.NatureOfTransaction) BigDecimal(java.math.BigDecimal) ModeOfTransport(com.axelor.apps.stock.db.ModeOfTransport) BigInteger(java.math.BigInteger)

Aggregations

Invoice (com.axelor.apps.account.db.Invoice)1 Address (com.axelor.apps.base.db.Address)1 Product (com.axelor.apps.base.db.Product)1 ModeOfTransport (com.axelor.apps.stock.db.ModeOfTransport)1 NatureOfTransaction (com.axelor.apps.stock.db.NatureOfTransaction)1 Regime (com.axelor.apps.stock.db.Regime)1 StockMove (com.axelor.apps.stock.db.StockMove)1 AxelorException (com.axelor.exception.AxelorException)1 BigDecimal (java.math.BigDecimal)1 BigInteger (java.math.BigInteger)1