Package org.jallinone.purchases.documents.java

Examples of org.jallinone.purchases.documents.java.DetailPurchaseDocVO


      supplierController.addLookupListener(new LookupListener() {

        public void codeValidated(boolean validated) {}

        public void codeChanged(ValueObject parentVO,Collection parentChangedAttributes) {
          DetailPurchaseDocVO vo = (DetailPurchaseDocVO)form.getVOModel().getValueObject();
          if (vo.getSupplierCodePUR01()==null || vo.getSupplierCodePUR01().equals("")) {
            // remove supplier pricelist code and currency code...
            vo.setPricelistCodePur03DOC06(null);
            vo.setPricelistDescriptionDOC06(null);
            vo.setCurrencyCodeReg03DOC06(null);
          }
          else {
            GridParams gridParams = new GridParams();
            gridParams.getOtherGridParams().put(ApplicationConsts.COMPANY_CODE_SYS01,vo.getCompanyCodeSys01DOC06());
            gridParams.getOtherGridParams().put(ApplicationConsts.PROGRESSIVE_REG04,vo.getProgressiveReg04DOC06());

            Response res = ClientUtils.getData("loadSupplierPricelists",gridParams);
            if (!res.isError()) {
              java.util.List rows = ((VOListResponse)res).getRows();
              if (rows.size()>0) {
                SupplierPricelistVO pricelistVO = (SupplierPricelistVO)rows.get(0);
                controlPricelistCode.setValue(pricelistVO.getPricelistCodePUR03());
                pricelistController.forceValidate();
              }
            }
          }
        }

        public void beforeLookupAction(ValueObject parentVO) {}

        public void forceValidate() {}

      });


      // pricelist lookup...
      pricelistDataLocator.setGridMethodName("loadSupplierPricelists");
      pricelistDataLocator.setValidationMethodName("validateSupplierPricelistCode");

      controlPricelistCode.setLookupController(pricelistController);
      pricelistController.setLookupDataLocator(pricelistDataLocator);
      pricelistController.setForm(form);
      pricelistController.setFrameTitle("supplierPricelists");
      pricelistController.setLookupValueObjectClassName("org.jallinone.purchases.pricelist.java.SupplierPricelistVO");
      pricelistController.addLookup2ParentLink("pricelistCodePUR03","pricelistCodePur03DOC06");
      pricelistController.addLookup2ParentLink("descriptionSYS10", "pricelistDescriptionDOC06");
      pricelistController.addLookup2ParentLink("currencyCodeReg03PUR03","currencyCodeReg03DOC06");
      pricelistController.setAllColumnVisible(false);
      pricelistController.setVisibleColumn("pricelistCodePUR03", true);
      pricelistController.setVisibleColumn("descriptionSYS10", true);
      pricelistController.setVisibleColumn("currencyCodeReg03PUR03", true);
      pricelistController.setPreferredWidthColumn("descriptionSYS10", 250);
      pricelistController.setFramePreferedSize(new Dimension(420,500));
      pricelistController.addLookupListener(new LookupListener() {

        public void codeValidated(boolean validated) {}

        public void codeChanged(ValueObject parentVO,Collection parentChangedAttributes) {}

        public void beforeLookupAction(ValueObject parentVO) {

          // retrieve function identifier...
          Container c = PurchaseSupplierHeadPanel.this.getParent();
          while (c != null && ! (c instanceof Form)) {
            c = c.getParent();
          }
          if (c != null) {
            Form form = (Form)c;
            DetailPurchaseDocVO vo = (DetailPurchaseDocVO)form.getVOModel().getValueObject();
            pricelistDataLocator.getLookupFrameParams().put(ApplicationConsts.COMPANY_CODE_SYS01,vo.getCompanyCodeSys01DOC06());
            pricelistDataLocator.getLookupFrameParams().put(ApplicationConsts.PROGRESSIVE_REG04,vo.getProgressiveReg04DOC06());
            pricelistDataLocator.getLookupValidationParameters().put(ApplicationConsts.COMPANY_CODE_SYS01,vo.getCompanyCodeSys01DOC06());
            pricelistDataLocator.getLookupValidationParameters().put(ApplicationConsts.PROGRESSIVE_REG04,vo.getProgressiveReg04DOC06());
          }
        }

        public void forceValidate() {}

      });


      // payment lookup...
      payDataLocator.setGridMethodName("loadPayments");
      payDataLocator.setValidationMethodName("validatePaymentCode");

      controlPaymentCode.setLookupController(payController);
      controlPaymentCode.setControllerMethodName("getPaymentsList");
      payController.setForm(form);
      payController.setLookupDataLocator(payDataLocator);
      payController.setFrameTitle("payments");
      payController.setLookupValueObjectClassName("org.jallinone.registers.payments.java.PaymentVO");
      payController.addLookup2ParentLink("paymentCodeREG10", "paymentCodeReg10DOC06");
      payController.addLookup2ParentLink("descriptionSYS10","paymentDescriptionDOC06");
      payController.setAllColumnVisible(false);
      payController.setVisibleColumn("paymentCodeREG10", true);
      payController.setVisibleColumn("descriptionSYS10", true);
      payController.setPreferredWidthColumn("descriptionSYS10", 250);
      payController.setFramePreferedSize(new Dimension(350,500));
      payController.addLookupListener(new LookupListener() {

        public void beforeLookupAction(org.openswing.swing.message.receive.java.ValueObject parentVO) {
          DetailPurchaseDocVO vo = (DetailPurchaseDocVO)form.getVOModel().getValueObject();
          payDataLocator.getLookupValidationParameters().put(ApplicationConsts.COMPANY_CODE_SYS01,vo.getCompanyCodeSys01DOC06());
          payDataLocator.getLookupFrameParams().put(ApplicationConsts.COMPANY_CODE_SYS01,vo.getCompanyCodeSys01DOC06());
        }

        public void codeChanged(org.openswing.swing.message.receive.java.ValueObject parentVO,Collection parentChangedAttributes) {  }

        public void codeValidated(boolean validated) { }
View Full Code Here


       vatRegisterAction.setConn(conn); // use same transaction...
       userParamAction.setConn(conn); // use same transaction...


       // retrieve document header...
       DetailPurchaseDocVO docVO =docAction.loadPurchaseDoc(pk,serverLanguageId,username,new ArrayList());

       // retrieve company currency code and currency conversion factor...
       String companyCurrencyCode = CurrencyConversionUtils.getCompanyCurrencyCode(docVO.getCompanyCodeSys01DOC06(),conn);
       BigDecimal conv = CurrencyConversionUtils.getConversionFactor(docVO.getDocDateDOC06(),docVO.getCurrencyCodeReg03DOC06(),companyCurrencyCode,conn);

       // retrieve document item rows...
       GridParams gridParams = new GridParams();
       gridParams.getOtherGridParams().put(ApplicationConsts.PURCHASE_DOC_PK,pk);
       Response res = rowsAction.loadPurchaseDocRows(variant1Descriptions,variant2Descriptions,variant3Descriptions,variant4Descriptions,variant5Descriptions,gridParams,serverLanguageId,username);
       if (res.isError())
         throw new Exception(res.getErrorMessage());
       java.util.List rows = ((VOListResponse)res).getRows();

       // check if this document is a purchase invoice and has a linked purchase order document:
       // if this is the case, then the linked document will be updated...
       if ((docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_INVOICE_FROM_DN_DOC_TYPE) ||
           docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_INVOICE_FROM_PD_DOC_TYPE)) &&
           docVO.getDocNumberDoc06DOC06()!=null
       ) {
         PurchaseDocPK refPK = new PurchaseDocPK(
             docVO.getCompanyCodeSys01Doc06DOC06(),
             docVO.getDocTypeDoc06DOC06(),
             docVO.getDocYearDoc06DOC06(),
             docVO.getDocNumberDoc06DOC06()
         );

         // retrieve ref. document item rows...
         GridPurchaseDocRowVO vo = null;
         DetailPurchaseDocRowVO refDetailVO = null;
         BigDecimal qty = null;
         BigDecimal invoiceQty = null;
         String docType = null;
         BigDecimal docYear = null;
         BigDecimal docNumber = null;
         BigDecimal rowNumber = null;
         for(int i=0;i<rows.size();i++) {
           vo = (GridPurchaseDocRowVO)rows.get(i);
           refDetailVO = rowAction.loadPurchaseDocRow(
               variant1Descriptions,variant2Descriptions,variant3Descriptions,variant4Descriptions,variant5Descriptions,
               new PurchaseDocRowPK(
                   docVO.getCompanyCodeSys01Doc06DOC06(),
                   docVO.getDocTypeDoc06DOC06(),
                   docVO.getDocYearDoc06DOC06(),
                   docVO.getDocNumberDoc06DOC06(),
                   vo.getItemCodeItm01DOC07(),
                   vo.getVariantTypeItm06DOC07(),
                   vo.getVariantCodeItm11DOC07(),
                   vo.getVariantTypeItm07DOC07(),
                   vo.getVariantCodeItm12DOC07(),
                   vo.getVariantTypeItm08DOC07(),
                   vo.getVariantCodeItm13DOC07(),
                   vo.getVariantTypeItm09DOC07(),
                   vo.getVariantCodeItm14DOC07(),
                   vo.getVariantTypeItm10DOC07(),
                   vo.getVariantCodeItm15DOC07()
               ),
               serverLanguageId,username
           );
           refDetailVO.setInvoiceQtyDOC07(
               refDetailVO.getInvoiceQtyDOC07().add(vo.getQtyDOC07()).setScale(docVO.getDecimalsREG03().intValue(),BigDecimal.ROUND_HALF_UP)
           );
           if (refDetailVO.getInvoiceQtyDOC07().doubleValue()>refDetailVO.getQtyDOC07().doubleValue())
             refDetailVO.setInvoiceQtyDOC07( refDetailVO.getQtyDOC07() );

           // update ref. item row...
           pstmt = conn.prepareStatement(
               "update DOC07_PURCHASE_ITEMS set INVOICE_QTY=?,LAST_UPDATE_USER=?,LAST_UPDATE_DATE=?  where "+
                   "COMPANY_CODE_SYS01=? and DOC_TYPE=? and DOC_YEAR=? and DOC_NUMBER=? and ITEM_CODE_ITM01=? and "+
                   "VARIANT_TYPE_ITM06=? and VARIANT_CODE_ITM11=? and "+
                   "VARIANT_TYPE_ITM07=? and VARIANT_CODE_ITM12=? and "+
                   "VARIANT_TYPE_ITM08=? and VARIANT_CODE_ITM13=? and "+
                   "VARIANT_TYPE_ITM09=? and VARIANT_CODE_ITM14=? and "+
                   "VARIANT_TYPE_ITM10=? and VARIANT_CODE_ITM15=? "
           );
           pstmt.setBigDecimal(1,refDetailVO.getInvoiceQtyDOC07());
           pstmt.setString(2,username);
           pstmt.setTimestamp(3,new java.sql.Timestamp(System.currentTimeMillis()));
           pstmt.setString(4,refDetailVO.getCompanyCodeSys01DOC07());
           pstmt.setString(5,refDetailVO.getDocTypeDOC07());
           pstmt.setBigDecimal(6,refDetailVO.getDocYearDOC07());
           pstmt.setBigDecimal(7,refDetailVO.getDocNumberDOC07());
           pstmt.setString(8,refDetailVO.getItemCodeItm01DOC07());

           pstmt.setString(9,refDetailVO.getVariantTypeItm06DOC07());
           pstmt.setString(10,refDetailVO.getVariantCodeItm11DOC07());
           pstmt.setString(11,refDetailVO.getVariantTypeItm07DOC07());
           pstmt.setString(12,refDetailVO.getVariantCodeItm12DOC07());
           pstmt.setString(13,refDetailVO.getVariantTypeItm08DOC07());
           pstmt.setString(14,refDetailVO.getVariantCodeItm13DOC07());
           pstmt.setString(15,refDetailVO.getVariantTypeItm09DOC07());
           pstmt.setString(16,refDetailVO.getVariantCodeItm14DOC07());
           pstmt.setString(17,refDetailVO.getVariantTypeItm10DOC07());
           pstmt.setString(18,refDetailVO.getVariantCodeItm15DOC07());

           pstmt.execute();
           pstmt.close();

           // update ref. item row in the in delivery note...
           pstmt2 = conn.prepareStatement(
               "select QTY,INVOICE_QTY,DOC_TYPE,DOC_YEAR,DOC_NUMBER,ROW_NUMBER from DOC09_IN_DELIVERY_NOTE_ITEMS where "+
               "COMPANY_CODE_SYS01=? and DOC_TYPE_DOC06=? and DOC_YEAR_DOC06=? and DOC_NUMBER_DOC06=? and ITEM_CODE_ITM01=? and INVOICE_QTY<QTY and "+
               "VARIANT_TYPE_ITM06=? and VARIANT_CODE_ITM11=? and "+
               "VARIANT_TYPE_ITM07=? and VARIANT_CODE_ITM12=? and "+
               "VARIANT_TYPE_ITM08=? and VARIANT_CODE_ITM13=? and "+
               "VARIANT_TYPE_ITM09=? and VARIANT_CODE_ITM14=? and "+
               "VARIANT_TYPE_ITM10=? and VARIANT_CODE_ITM15=? "
           );
           qty = null;
           invoiceQty = null;

           pstmt2.setString(1,refDetailVO.getCompanyCodeSys01DOC07());
           pstmt2.setString(2,refDetailVO.getDocTypeDOC07());
           pstmt2.setBigDecimal(3,refDetailVO.getDocYearDOC07());
           pstmt2.setBigDecimal(4,refDetailVO.getDocNumberDOC07());
           pstmt2.setString(5,refDetailVO.getItemCodeItm01DOC07());

           pstmt2.setString(6,refDetailVO.getVariantTypeItm06DOC07());
           pstmt2.setString(7,refDetailVO.getVariantCodeItm11DOC07());
           pstmt2.setString(8,refDetailVO.getVariantTypeItm07DOC07());
           pstmt2.setString(9,refDetailVO.getVariantCodeItm12DOC07());
           pstmt2.setString(10,refDetailVO.getVariantTypeItm08DOC07());
           pstmt2.setString(11,refDetailVO.getVariantCodeItm13DOC07());
           pstmt2.setString(12,refDetailVO.getVariantTypeItm09DOC07());
           pstmt2.setString(13,refDetailVO.getVariantCodeItm14DOC07());
           pstmt2.setString(14,refDetailVO.getVariantTypeItm10DOC07());
           pstmt2.setString(15,refDetailVO.getVariantCodeItm15DOC07());

           rset = pstmt2.executeQuery();

           // it only updates one row, that matches the where clause...
           if(rset.next()) {
             qty = rset.getBigDecimal(1);
             invoiceQty = rset.getBigDecimal(2);
             docType = rset.getString(3);
             docYear = rset.getBigDecimal(4);
             docNumber = rset.getBigDecimal(5);
             rowNumber = rset.getBigDecimal(6);
           }
           rset.close();
           pstmt2.close();

           if (qty!=null && invoiceQty!=null) {
             if (invoiceQty.doubleValue()+vo.getQtyDOC07().doubleValue()<=qty.doubleValue())
               qty = invoiceQty.add(vo.getQtyDOC07());

             pstmt = conn.prepareStatement(
                 "update DOC09_IN_DELIVERY_NOTE_ITEMS set INVOICE_QTY=?,LAST_UPDATE_USER=?,LAST_UPDATE_DATE=?  where "+
                 "COMPANY_CODE_SYS01=? and DOC_TYPE_DOC06=? and DOC_YEAR_DOC06=? and DOC_NUMBER_DOC06=? and ITEM_CODE_ITM01=? and "+
                 "DOC_TYPE=? and DOC_YEAR=? and DOC_NUMBER=? and ROW_NUMBER=? and "+
                 "VARIANT_TYPE_ITM06=? and VARIANT_CODE_ITM11=? and "+
                 "VARIANT_TYPE_ITM07=? and VARIANT_CODE_ITM12=? and "+
                 "VARIANT_TYPE_ITM08=? and VARIANT_CODE_ITM13=? and "+
                 "VARIANT_TYPE_ITM09=? and VARIANT_CODE_ITM14=? and "+
                 "VARIANT_TYPE_ITM10=? and VARIANT_CODE_ITM15=? "
             );
             pstmt.setBigDecimal(1,qty);
             pstmt.setString(2,username);
             pstmt.setTimestamp(3,new java.sql.Timestamp(System.currentTimeMillis()));
             pstmt.setString(4,refDetailVO.getCompanyCodeSys01DOC07());
             pstmt.setString(5,refDetailVO.getDocTypeDOC07());
             pstmt.setBigDecimal(6,refDetailVO.getDocYearDOC07());
             pstmt.setBigDecimal(7,refDetailVO.getDocNumberDOC07());
             pstmt.setString(8,refDetailVO.getItemCodeItm01DOC07());
             pstmt.setString(9,docType);
             pstmt.setBigDecimal(10,docYear);
             pstmt.setBigDecimal(11,docNumber);
             pstmt.setBigDecimal(12,rowNumber);

             pstmt.setString(13,refDetailVO.getVariantTypeItm06DOC07());
             pstmt.setString(14,refDetailVO.getVariantCodeItm11DOC07());
             pstmt.setString(15,refDetailVO.getVariantTypeItm07DOC07());
             pstmt.setString(16,refDetailVO.getVariantCodeItm12DOC07());
             pstmt.setString(17,refDetailVO.getVariantTypeItm08DOC07());
             pstmt.setString(18,refDetailVO.getVariantCodeItm13DOC07());
             pstmt.setString(19,refDetailVO.getVariantTypeItm09DOC07());
             pstmt.setString(20,refDetailVO.getVariantCodeItm14DOC07());
             pstmt.setString(21,refDetailVO.getVariantTypeItm10DOC07());
             pstmt.setString(22,refDetailVO.getVariantCodeItm15DOC07());

             pstmt.execute();
             pstmt.close();
           }
         }

         // check if linked document can be closed...
         boolean canCloseLinkedDoc = true;
         pstmt = conn.prepareStatement(
             "select QTY from DOC07_PURCHASE_ITEMS where COMPANY_CODE_SYS01=? and DOC_TYPE=? and DOC_YEAR=? and DOC_NUMBER=? and QTY-INVOICE_QTY>0"
         );
         pstmt.setString(1,refPK.getCompanyCodeSys01DOC06());
         pstmt.setString(2,refPK.getDocTypeDOC06());
         pstmt.setBigDecimal(3,refPK.getDocYearDOC06());
         pstmt.setBigDecimal(4,refPK.getDocNumberDOC06());
         rset = pstmt.executeQuery();
         if (rset.next())
           canCloseLinkedDoc = false;
         rset.close();
         pstmt.close();

         if (canCloseLinkedDoc) {
           // the linked document can be closed...
           pstmt = conn.prepareStatement("update DOC06_PURCHASE set DOC_STATE=?,LAST_UPDATE_USER=?,LAST_UPDATE_DATE=?  where COMPANY_CODE_SYS01=? and DOC_TYPE=? and DOC_YEAR=? and DOC_NUMBER=?");
           pstmt.setString(1,ApplicationConsts.CLOSED);
           pstmt.setString(2,username);
           pstmt.setTimestamp(3,new java.sql.Timestamp(System.currentTimeMillis()));
           pstmt.setString(4,refPK.getCompanyCodeSys01DOC06());
           pstmt.setString(5,refPK.getDocTypeDOC06());
           pstmt.setBigDecimal(6,refPK.getDocYearDOC06());
           pstmt.setBigDecimal(7,refPK.getDocNumberDOC06());
           pstmt.execute();
         }

       }


       int docSequenceDOC06 = docVO.getDocSequenceDOC06().intValue();

/*
       if (docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_INVOICE_DOC_TYPE) ||
           docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_INVOICE_FROM_DN_DOC_TYPE) ||
           docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_INVOICE_FROM_PD_DOC_TYPE)) {
         // invoice...
         pstmt = conn.prepareStatement(
             "select max(DOC_SEQUENCE) from DOC06_PURCHASE where COMPANY_CODE_SYS01=? and DOC_TYPE in (?,?,?) and DOC_YEAR=? and DOC_SEQUENCE is not null"
         );
         pstmt.setString(1,pk.getCompanyCodeSys01DOC06());
         pstmt.setString(2,ApplicationConsts.PURCHASE_INVOICE_DOC_TYPE);
         pstmt.setString(3,ApplicationConsts.PURCHASE_INVOICE_FROM_DN_DOC_TYPE);
         pstmt.setString(4,ApplicationConsts.PURCHASE_INVOICE_FROM_PD_DOC_TYPE);
         pstmt.setBigDecimal(5,pk.getDocYearDOC06());

         rset = pstmt.executeQuery();
          int docSequenceDOC06 = 1;
          if (rset.next())
           docSequenceDOC06 = rset.getInt(1)+1;
         rset.close();
         pstmt.close();
         docVO.setDocSequenceDOC06(new BigDecimal(docSequenceDOC06));

       }
       else {
*/


       // generate progressive for doc. sequence for purchase order...
       if (docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_ORDER_DOC_TYPE)) {

         // other sale document (e.g. debiting note)...
         pstmt = conn.prepareStatement(
             "select max(DOC_SEQUENCE) from DOC06_PURCHASE where COMPANY_CODE_SYS01=? and DOC_TYPE=? and DOC_YEAR=? and DOC_SEQUENCE is not null"
         );
         pstmt.setString(1,pk.getCompanyCodeSys01DOC06());
         pstmt.setString(2,pk.getDocTypeDOC06());
         pstmt.setBigDecimal(3,pk.getDocYearDOC06());

         rset = pstmt.executeQuery();
         docSequenceDOC06 = 1;
         if (rset.next())
           docSequenceDOC06 = rset.getInt(1)+1;
         rset.close();
         pstmt.close();
         docVO.setDocSequenceDOC06(new BigDecimal(docSequenceDOC06));
       }


       // retrieve payment instalments...
       ArrayList companiesList = new ArrayList();
       companiesList.add(docVO.getCompanyCodeSys01DOC06());
       res = payAction.validatePaymentCode(new LookupValidationParams(docVO.getPaymentCodeReg10DOC06(),new HashMap()),serverLanguageId,username,new ArrayList(),companiesList);
       if (res.isError()) {
         throw new Exception(res.getErrorMessage());
       }
       PaymentVO payVO = (PaymentVO)((VOListResponse)res).getRows().get(0);

       gridParams = new GridParams();
       gridParams.getOtherGridParams().put(ApplicationConsts.COMPANY_CODE_SYS01,docVO.getCompanyCodeSys01DOC06());
       gridParams.getOtherGridParams().put(ApplicationConsts.PAYMENT_CODE_REG10,docVO.getPaymentCodeReg10DOC06());
       res = payAction.loadPaymentInstalments(gridParams,serverLanguageId,username);
       if (res.isError()) {
         throw new Exception(res.getErrorMessage());
       }
       rows = ((VOListResponse)res).getRows();

/*
       // create expirations in DOC19 ONLY if:
       // - there are more than one instalment OR
       // - there is only one instalment and this instalment has more than 0 instalment days
       if (rows.size()>1 || (rows.size()==1 && ((PaymentInstalmentVO)rows.get(0)).getInstalmentDaysREG17().intValue()>0 )) {
*/

      HashMap map = new HashMap();
      map.put(ApplicationConsts.COMPANY_CODE_SYS01,docVO.getCompanyCodeSys01DOC06());
      map.put(ApplicationConsts.PARAM_CODE,ApplicationConsts.ROUNDING_COSTS_CODE);
      res = userParamAction.loadUserParam(map,serverLanguageId,username);
      if (res.isError()) {
        throw new Exception(res.getErrorMessage());
      }
      String roundingAccountCode = ((VOResponse)res).getVo().toString();


      // create ALWAYS expirations in DOC19...
       PaymentInstalmentVO inVO = null;
       pstmt = conn.prepareStatement(
           "insert into DOC19_EXPIRATIONS(COMPANY_CODE_SYS01,DOC_TYPE,DOC_YEAR,DOC_NUMBER,DOC_SEQUENCE,PROGRESSIVE,"+
           "DOC_DATE,EXPIRATION_DATE,NAME_1,NAME_2,VALUE,DESCRIPTION,CUSTOMER_SUPPLIER_CODE,PROGRESSIVE_REG04,CURRENCY_CODE_REG03,"+
           "PAYMENT_TYPE_CODE_REG11,PAYED,REAL_PAYMENT_TYPE_CODE_REG11,PAYED_DATE,PAYED_VALUE,REAL_ACCOUNT_CODE_ACC02,ROUNDING_ACCOUNT_CODE_ACC02,ALREADY_PAYED,CREATE_USER,CREATE_DATE) "+
           "values(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)"
       );

       long startTime = docVO.getDocDateDOC06().getTime(); // invoice date...
       if (payVO.getStartDayREG10().equals(ApplicationConsts.START_DAY_END_MONTH)) {
         Calendar cal = Calendar.getInstance();
         cal.setTimeInMillis(startTime);
         if (cal.get(cal.MONTH)==10 || cal.get(cal.MONTH)==3 || cal.get(cal.MONTH)==5 || cal.get(cal.MONTH)==8)
           cal.set(cal.DAY_OF_MONTH,30);
         else if (cal.get(cal.MONTH)==1) {
           if (cal.get(cal.YEAR)%4==0)
             cal.set(cal.DAY_OF_MONTH,29);
           else
             cal.set(cal.DAY_OF_MONTH,28);
         } else
           cal.set(cal.DAY_OF_MONTH,31);
         startTime = cal.getTime().getTime();
       }
       BigDecimal amount = null;
       for(int i=0;i<rows.size();i++) {
         inVO = (PaymentInstalmentVO)rows.get(i);
         pstmt.setString(1,docVO.getCompanyCodeSys01DOC06());
         pstmt.setString(2,docVO.getDocTypeDOC06());
         pstmt.setBigDecimal(3,docVO.getDocYearDOC06());
         pstmt.setBigDecimal(4,docVO.getDocNumberDOC06());
         pstmt.setBigDecimal(5,docVO.getDocSequenceDOC06());
         pstmt.setBigDecimal(6,CompanyProgressiveUtils.getInternalProgressive(docVO.getCompanyCodeSys01DOC06(),"DOC19_EXPIRATIONS","PROGRESSIVE",conn));
         pstmt.setDate(7,docVO.getDocDateDOC06());
         pstmt.setDate(8,new java.sql.Date(startTime + inVO.getInstalmentDaysREG17().longValue()*86400*1000)); // expiration date
         pstmt.setString(9,docVO.getName_1REG04());
         pstmt.setString(10,docVO.getName_2REG04());

         if (docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_DEBIT_NOTE_DOC_TYPE))
           amount = docVO.getTotalDOC06().multiply(inVO.getPercentageREG17()).divide(new BigDecimal(-100),BigDecimal.ROUND_HALF_UP).setScale(docVO.getDecimalsREG03().intValue(),BigDecimal.ROUND_HALF_UP); // value
         else
           amount = docVO.getTotalDOC06().multiply(inVO.getPercentageREG17()).divide(new BigDecimal(100),BigDecimal.ROUND_HALF_UP).setScale(docVO.getDecimalsREG03().intValue(),BigDecimal.ROUND_HALF_UP); // value

         pstmt.setBigDecimal(11,CurrencyConversionUtils.convertCurrencyToCurrency(amount,conv));

         if (docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_DEBIT_NOTE_DOC_TYPE))
           pstmt.setString(12,t1+" "+docVO.getDocSequenceDOC06()+"/"+docVO.getDocYearDOC06()+" - "+t2+" "+t3+" "+(i+1)+" - "+inVO.getPaymentTypeDescriptionSYS10()); // description
         else
           pstmt.setString(12,t4+" "+docVO.getDocSequenceDOC06()+"/"+docVO.getDocYearDOC06()+" - "+t2+" "+t3+" "+(i+1)+" - "+inVO.getPaymentTypeDescriptionSYS10()); // description

         pstmt.setString(13,docVO.getSupplierCodePUR01());
         pstmt.setBigDecimal(14,docVO.getProgressiveReg04DOC06());
         pstmt.setString(15,companyCurrencyCode);
         pstmt.setString(16,payVO.getPaymentTypeCodeReg11REG10());
         pstmt.setString(17,"N");
         pstmt.setString(18,null);
         pstmt.setDate(19,null);
         pstmt.setBigDecimal(20,null);
         pstmt.setString(21,payVO.getAccountCodeAcc02REG11());
         pstmt.setString(22,roundingAccountCode);
         pstmt.setBigDecimal(23,new BigDecimal(0));
         pstmt.setString(24,username);
         pstmt.setTimestamp(25,new java.sql.Timestamp(System.currentTimeMillis()));

         pstmt.execute();
       }
       pstmt.close();
//       }


       // change doc state to close...
       pstmt = conn.prepareStatement("update DOC06_PURCHASE set DOC_STATE=?,LAST_UPDATE_USER=?,LAST_UPDATE_DATE=?  where COMPANY_CODE_SYS01=? and DOC_TYPE=? and DOC_YEAR=? and DOC_NUMBER=?");
       pstmt.setString(1,ApplicationConsts.CLOSED);
       pstmt.setString(2,username);
       pstmt.setTimestamp(3,new java.sql.Timestamp(System.currentTimeMillis()));
       pstmt.setString(4,pk.getCompanyCodeSys01DOC06());
       pstmt.setString(5,pk.getDocTypeDOC06());
       pstmt.setBigDecimal(6,pk.getDocYearDOC06());
       pstmt.setBigDecimal(7,pk.getDocNumberDOC06());
       pstmt.execute();



       // check if this document is a purchase invoice or a debiting note and has a linked purchase order document:
       // if this is the case, then the linked document will be updated...
       if (docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_INVOICE_FROM_DN_DOC_TYPE) ||
           docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_INVOICE_FROM_PD_DOC_TYPE) ||
           docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_INVOICE_DOC_TYPE) ||
           docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_DEBIT_NOTE_DOC_TYPE)
       ) {
         JournalHeaderVO jhVO = new JournalHeaderVO();
         jhVO.setCompanyCodeSys01ACC05(docVO.getCompanyCodeSys01DOC06());
         jhVO.setAccountingMotiveCodeAcc03ACC05(ApplicationConsts.MOTIVE_PURCHASE_INVOICE);
         jhVO.setItemDateACC05(new java.sql.Date(System.currentTimeMillis()));
         jhVO.setItemYearACC05(new BigDecimal(Calendar.getInstance().get(Calendar.YEAR)));

         if (docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_DEBIT_NOTE_DOC_TYPE))
           jhVO.setDescriptionACC05(
               t5+" "+docVO.getDocSequenceDOC06()+"/"+docVO.getDocYearDOC06()+" - "+
               t6+" "+docVO.getName_1REG04()+" "+(docVO.getName_2REG04()==null?"":docVO.getName_2REG04())
           );
         else
           jhVO.setDescriptionACC05(
               t7+" "+docVO.getDocSequenceDOC06()+"/"+docVO.getDocYearDOC06()+" - "+
               t6+" "+docVO.getName_1REG04()+" "+(docVO.getName_2REG04()==null?"":docVO.getName_2REG04())
           );

         // determine account codes defined for the current customer...
         pstmt = conn.prepareStatement(
             "select DEBIT_ACCOUNT_CODE_ACC02,COSTS_ACCOUNT_CODE_ACC02 from PUR01_SUPPLIERS where COMPANY_CODE_SYS01=? and PROGRESSIVE_REG04=?"
         );
         pstmt.setString(1,pk.getCompanyCodeSys01DOC06());
         pstmt.setBigDecimal(2,docVO.getProgressiveReg04DOC06());
         rset = pstmt.executeQuery();
         if (!rset.next()) {
           rset.close();
           throw new Exception("supplier not found");
         }
         String debitAccountCodeAcc02 = rset.getString(1);
         String costsAccountCodeAcc02 = rset.getString(2);
         rset.close();
         pstmt.close();

         // determine account code defined for vat in sale vat register...
         pstmt = conn.prepareStatement(
             "select ACCOUNT_CODE_ACC02 from ACC04_VAT_REGISTERS where COMPANY_CODE_SYS01=? and REGISTER_CODE=?"
         );
         pstmt.setString(1,pk.getCompanyCodeSys01DOC06());
         pstmt.setString(2,ApplicationConsts.VAT_REGISTER_PURCHASE);
         rset = pstmt.executeQuery();
         if (!rset.next()) {
           rset.close();
           throw new Exception("vat register not found");
         }
         String vatAccountCodeAcc02 = rset.getString(1);
         rset.close();
         pstmt.close();

         // calculate taxable income rows, grouped by vat code...
         res = taxableIncomeAction.calcTaxableIncomes(docVO,serverLanguageId,username);
         if (res.isError()) {
           throw new Exception(res.getErrorMessage());
         }

         // add taxable income rows to the accounting item...
         java.util.List taxableIncomes = ((VOListResponse)res).getRows();
         TaxableIncomeVO tVO = null;
         JournalRowVO jrVO = null;
         BigDecimal totalVat = new BigDecimal(0);
         Hashtable vats = new Hashtable(); // collections of: vat code,VatRowVO
         VatRowVO vatVO = null;
         for(int i=0;i<taxableIncomes.size();i++) {
           tVO = (TaxableIncomeVO)taxableIncomes.get(i);
           totalVat = totalVat.add(tVO.getVatValue());
           jrVO = new JournalRowVO();
           jrVO.setCompanyCodeSys01ACC06(jhVO.getCompanyCodeSys01ACC05());
           jrVO.setAccountCodeAcc02ACC06(costsAccountCodeAcc02);
           jrVO.setAccountCodeACC06(costsAccountCodeAcc02);
           jrVO.setAccountCodeTypeACC06(ApplicationConsts.ACCOUNT_TYPE_ACCOUNT);

           if (docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_DEBIT_NOTE_DOC_TYPE))
             jrVO.setDebitAmountACC06(tVO.getTaxableIncome().negate());
           else
             jrVO.setDebitAmountACC06(tVO.getTaxableIncome());
           jrVO.setDebitAmountACC06(CurrencyConversionUtils.convertCurrencyToCurrency(jrVO.getDebitAmountACC06(),conv));

           jrVO.setDescriptionACC06("");
           jrVO.setItemYearAcc05ACC06(jhVO.getItemYearACC05());
           jrVO.setProgressiveAcc05ACC06(jhVO.getProgressiveACC05());
           jhVO.addJournalRow(jrVO);

           // prepare vat row for sale vat register...
           vatVO = (VatRowVO)vats.get(tVO.getVatCode());
           if (vatVO==null) {
             vatVO = new VatRowVO();
             vatVO.setCompanyCodeSys01ACC07(docVO.getCompanyCodeSys01DOC06());
             vatVO.setRegisterCodeAcc04ACC07(ApplicationConsts.VAT_REGISTER_PURCHASE);
             vatVO.setTaxableIncomeACC07(tVO.getTaxableIncome());
             vatVO.setTaxableIncomeACC07(CurrencyConversionUtils.convertCurrencyToCurrency(vatVO.getTaxableIncomeACC07(),conv));
             vatVO.setVatCodeACC07(tVO.getVatCode());
             vatVO.setVatDateACC07(new java.sql.Date(System.currentTimeMillis()));
             vatVO.setVatDescriptionACC07(tVO.getVatDescription());

             if (docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_DEBIT_NOTE_DOC_TYPE))
               vatVO.setVatValueACC07(tVO.getVatValue().negate());
             else
               vatVO.setVatValueACC07(tVO.getVatValue());
             vatVO.setVatValueACC07(CurrencyConversionUtils.convertCurrencyToCurrency(vatVO.getVatValueACC07(),conv));

             vatVO.setVatYearACC07(new BigDecimal(Calendar.getInstance().get(Calendar.YEAR)));
           }
           else {
             vatVO.setTaxableIncomeACC07(vatVO.getTaxableIncomeACC07().add(tVO.getTaxableIncome()));
             vatVO.setTaxableIncomeACC07(CurrencyConversionUtils.convertCurrencyToCurrency(vatVO.getTaxableIncomeACC07(),conv));
             if (docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_DEBIT_NOTE_DOC_TYPE))
               vatVO.setVatValueACC07(vatVO.getVatValueACC07().add(tVO.getVatValue()).negate());
             else
               vatVO.setVatValueACC07(vatVO.getVatValueACC07().add(tVO.getVatValue()));
             vatVO.setVatValueACC07(CurrencyConversionUtils.convertCurrencyToCurrency(vatVO.getVatValueACC07(),conv));
           }
           vats.put(tVO.getVatCode(),vatVO);
         }

         // add total vat value to the accounting item...
         jrVO = new JournalRowVO();
         jrVO.setCompanyCodeSys01ACC06(jhVO.getCompanyCodeSys01ACC05());
         jrVO.setAccountCodeAcc02ACC06(vatAccountCodeAcc02);
         jrVO.setAccountCodeACC06(vatAccountCodeAcc02);
         jrVO.setAccountCodeTypeACC06(ApplicationConsts.ACCOUNT_TYPE_ACCOUNT);

         if (docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_DEBIT_NOTE_DOC_TYPE))
           jrVO.setDebitAmountACC06(totalVat.negate());
         else
           jrVO.setDebitAmountACC06(totalVat);
         jrVO.setDebitAmountACC06(CurrencyConversionUtils.convertCurrencyToCurrency(jrVO.getDebitAmountACC06(),conv));

         jrVO.setDescriptionACC06("");
         jrVO.setItemYearAcc05ACC06(jhVO.getItemYearACC05());
         jrVO.setProgressiveAcc05ACC06(jhVO.getProgressiveACC05());
         jhVO.addJournalRow(jrVO);

         // add total debit value to the accounting item...
         jrVO = new JournalRowVO();
         jrVO.setCompanyCodeSys01ACC06(jhVO.getCompanyCodeSys01ACC05());
         jrVO.setAccountCodeAcc02ACC06(debitAccountCodeAcc02);
         jrVO.setAccountCodeACC06(docVO.getSupplierCodePUR01());
         jrVO.setAccountCodeTypeACC06(ApplicationConsts.ACCOUNT_TYPE_SUPPLIER);

         if (docVO.getDocTypeDOC06().equals(ApplicationConsts.PURCHASE_DEBIT_NOTE_DOC_TYPE))
           jrVO.setCreditAmountACC06(docVO.getTotalDOC06().negate());
         else
           jrVO.setCreditAmountACC06(docVO.getTotalDOC06());
         jrVO.setCreditAmountACC06(CurrencyConversionUtils.convertCurrencyToCurrency(jrVO.getCreditAmountACC06(),conv));

         jrVO.setDescriptionACC06("");
         jrVO.setItemYearAcc05ACC06(jhVO.getItemYearACC05());
         jrVO.setProgressiveAcc05ACC06(jhVO.getProgressiveACC05());
View Full Code Here

    Response res = ClientUtils.getData(
        "createInvoiceFromInDelivNotes",
        new PurchaseInvoiceFromDelivNotesVO((DetailPurchaseDocVO)newPersistentObject,rows)
    );
    if (!res.isError()) {
      DetailPurchaseDocVO vo = (DetailPurchaseDocVO)((VOResponse)res).getVo();
      pk = new PurchaseDocPK(
          vo.getCompanyCodeSys01DOC06(),
          vo.getDocTypeDOC06(),
          vo.getDocYearDOC06(),
          vo.getDocNumberDOC06()
      );

    }
    return res;
  }
View Full Code Here

  public void afterInsertData() {
    if (parentFrame!=null) {
      parentFrame.getGrid().reloadCurrentBlockOfData();
    }

    DetailPurchaseDocVO vo = (DetailPurchaseDocVO)frame.getHeaderFormPanel().getVOModel().getValueObject();
    frame.updateCurrencySettings(vo);

    frame.getRowsPanel().setParentVO(vo);
    frame.getRowsPanel().getGrid().getOtherGridParams().put(ApplicationConsts.PURCHASE_DOC_PK,pk);
    frame.getRowsPanel().getGrid().reloadData();
View Full Code Here

   * @param persistentObject value object to delete
   * @return an ErrorResponse value object in case of errors, VOResponse if the operation is successfully completed
   */
  public Response deleteRecord(ValueObject persistentObject) throws Exception {
    ArrayList pks = new ArrayList();
    DetailPurchaseDocVO vo = (DetailPurchaseDocVO)persistentObject;

    pks.add(pk);
    Response res = ClientUtils.getData("deletePurchaseDocs",pks);
    if (!res.isError()) {
      if (parentFrame!=null) {
View Full Code Here

   * Callback method called by the Form panel when the Form is set to INSERT mode.
   * The method can pre-set some v.o. attributes, so that some input controls will have a predefined value associated.
   * @param persistentObject new value object
   */
  public void createPersistentObject(ValueObject persistentObject) throws Exception {
    DetailPurchaseDocVO vo = (DetailPurchaseDocVO)persistentObject;
    Calendar cal = Calendar.getInstance();
    vo.setDocYearDOC06(new BigDecimal(cal.get(cal.YEAR)));
    vo.setDocDateDOC06(new java.sql.Date(System.currentTimeMillis()));
    vo.setDocTypeDOC06(ApplicationConsts.PURCHASE_INVOICE_FROM_DN_DOC_TYPE);
    vo.setDocStateDOC06(ApplicationConsts.OPENED);


  }
View Full Code Here

   * @return <code>true</code> allows to go to EDIT mode, <code>false</code> the mode change is interrupted
   */
  public boolean beforeEditData(Form form) {
    if (!super.beforeEditData(form))
      return false;
    DetailPurchaseDocVO vo = (DetailPurchaseDocVO)frame.getHeaderFormPanel().getVOModel().getValueObject();
    return !vo.getDocStateDOC06().equals(ApplicationConsts.CLOSED);
  }
View Full Code Here

   * @return <code>true</code> allows the deleting to continue, <code>false</code> the deleting is interrupted
   */
  public boolean beforeDeleteData(Form form) {
    if (!super.beforeDeleteData(form))
      return false;
    DetailPurchaseDocVO vo = (DetailPurchaseDocVO)frame.getHeaderFormPanel().getVOModel().getValueObject();
    return !vo.getDocStateDOC06().equals(ApplicationConsts.CLOSED);
  }
View Full Code Here

   * Callback method called when the Form mode is changed.
   * @param currentMode current Form mode
   */
  public void modeChanged(int currentMode) {
    if (currentMode==Consts.INSERT) {
      DetailPurchaseDocVO vo = (DetailPurchaseDocVO)frame.getHeaderFormPanel().getVOModel().getValueObject();
      if (vo.getWarehouseCodeWar01DOC06()!=null)
        frame.getWarePanel().getWareController().forceValidate();
    }
  }
View Full Code Here

            ,GridBagConstraints.NORTHWEST, GridBagConstraints.NONE, new Insets(5, 5, 5, 5), 0, 0));
  }


  private void recalculateTotals() {
    DetailPurchaseDocVO vo = (DetailPurchaseDocVO)parentForm.getVOModel().getValueObject();
    Response res = ClientUtils.getData("getPurchaseDocTotals",vo);
    if (res.isError()) {
      JOptionPane.showMessageDialog(
          ClientUtils.getParentFrame(this),
          ClientSettings.getInstance().getResources().getResource("Error while loading data")+":\n"+res.getErrorMessage(),
          ClientSettings.getInstance().getResources().getResource("Loading Data Error"),
          JOptionPane.ERROR_MESSAGE
      );
    }
    else {
      DetailPurchaseDocVO newVO = (DetailPurchaseDocVO)((VOResponse)res).getVo();
      vo.setTotalDOC06(newVO.getTotalDOC06());
      vo.setTaxableIncomeDOC06(newVO.getTaxableIncomeDOC06());
      vo.setTotalVatDOC06(newVO.getTotalVatDOC06());
      parentForm.pull();
    }
  }
View Full Code Here

TOP

Related Classes of org.jallinone.purchases.documents.java.DetailPurchaseDocVO

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.