xj qian
2024-07-05 6e93e717799723de98287f5a036ab34367bd08cd
jrj/project/business/VATNotify/simple.maint.vatnotify.cpp
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,882 @@
#include <wobject/xstring.hpp>
#include <xcontrol/xtreeview.hpp>
#include <xcontrol/xdwgrid.hpp>
#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp"
#include "viewobject/view.base.hpp"
using xml = KXMLDOMDocument;
   class __declspec(dllexport) simplemaintvatnotifyWin : public xframe
   {
   public:
      xdwtable   dw_profit;
      xdwgrid      dw_item;
      xdwgrid      dw_fob;
      xstring      InvNo;
      xstring      CurInvNo;
      xnode   m_agentNode;   //Agent Condition
   public:
      simplemaintvatnotifyWin(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
   public:
      static simplemaintvatnotifyWin* CreateInstance(void* implPtr, void* hWnd)
      {
         simplemaintvatnotifyWin* pWin = new simplemaintvatnotifyWin(implPtr, (HWND)hWnd);
         return pWin;
      }
      int SetAgent()
      {
         xstring xfNodeAgentArea = L"agentarea";
         xnode anode = GetAgentNode(xfNodeAgentArea);
         if (m_agentNode)
         {
            SetAgentNode(anode, m_agentNode);
         }
         else
         {
            KXMLDOMElement xframeElement = GetElement();
            KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*");
            if (agent)
            {
               xstring s = agent.xml();
               m_agentNode = SetAgentNode(anode, s);
            }
         }
         return 1;
      }
      xstring  GetEntityData(int pr)
      {
         xml x ;
         dw_item.AcceptText();
         dw_item.DwUpdateAllToEx(x);
         return x.xml();
      }
      //焦点激活处理函数
      int OnSetFocus(TEvent* evt, LPARAM param)
      {
         //重置工具条
         SetAgent();
         return 1;
      }
      int OnPrint()
      {
         xaserverarg& arg = *new xaserverarg;
         arg.AddArg(L"EntityName", L"VATNotify");
         arg.AddArg(L"EntityID", L"", L"");
         xstring InvoiceNo = dw_item.GetItemString(dw_item.GetRow(), L"NInvoiceNo");
         if (InvoiceNo == L"") InvoiceNo = dw_item.GetItemString(dw_item.GetRow(), L"InvoiceNo");
         xstring SupplierID = dw_item.GetItemString(dw_item.GetRow(), L"SupplierID");
         arg.AddArg(L"EntityNo", InvoiceNo, L"");
         arg.AddArg(L"SupplierID", SupplierID);
         arg.AddArg(L"VATNotifyID", L"");
         openUrl(L"/sale/view/view.base/xpage/Template/PrintViewEx", &arg);
         return 1;
      }
      int OnPrintItem()
      {
         xaserverarg& arg = *new xaserverarg;
         arg.AddArg(L"EntityName", L"VATNotify", L"");
         arg.AddArg(L"EntityID", L"", L"");
         xstring InvoiceNo = dw_item.GetItemString(dw_item.GetRow(), L"NInvoiceNo");
         if (InvoiceNo == L"") InvoiceNo = dw_item.GetItemString(dw_item.GetRow(), L"InvoiceNo");
         xstring SupplierID = dw_item.GetItemString(dw_item.GetRow(), L"SupplierID");
         arg.AddArg(L"EntityNo", InvoiceNo, L"");
         arg.AddArg(L"SupplierID", SupplierID);
         arg.AddArg(L"VATNotifyID", dw_item.GetGuid(dw_item.GetRow()));
         trace(InvoiceNo + L"====L" + dw_item.GetGuid(dw_item.GetRow()));
         openUrl(L"/sale/view/view.base/xpage/Template/PrintViewEx", &arg);
         return 1;
      }
      int allbill() {
         int MB_OKCANCEL = 1;
         int IDOK = 1;
         int ret =MessageBox(GetHWND(), L"全数开票?", L"提示", MB_OKCANCEL);
         if (ret != IDOK) return 1;
         dw_item.AcceptText();
         for (int ll_row = 1; ll_row <= dw_item.GetRowCount(); ll_row++)
         {
            xstring ls_dtlno = dw_item.GetItemString(ll_row, L"InvoiceNo");
            dw_item.SetItemString(ll_row, L"NInvoiceNo", ls_dtlno);
            dw_item.SetItemString(ll_row, L"NAmount", dw_item.GetItemString(ll_row, L"Amount"));
            xstring sdate = publiccode::GetCurrentDate();
            dw_item.SetItemString(ll_row, L"NotifyDate", sdate);
            dw_item.ItemChangeTo(ll_row, L"NAmount", dw_item.GetItemString(ll_row, L"Amount"));
         }
         dw_item.Redraw();
         return 1;
      }
      int allbillno() {
         int MB_OKCANCEL = 1;
         int IDOK = 1;
         int ret =MessageBox(GetHWND(), L"全数不开票?", L"提示", MB_OKCANCEL);
         if (ret != IDOK) return 1;
         dw_item.AcceptText();
         for (int ll_row = 1; ll_row <= dw_item.GetRowCount(); ll_row++)
         {
            xstring ls_dtlno = dw_item.GetItemString(ll_row, L"InvoiceNo");
            dw_item.ItemChangeTo(ll_row, L"NAmount", dw_item.GetItemString(ll_row, L""));
            dw_item.ItemChangeTo(ll_row, L"NQuantity", dw_item.GetItemString(ll_row, L""));
            dw_item.SetItemString(ll_row, L"NQtyUnit", L"");
            dw_item.SetItemString(ll_row, L"NotifyDate", L"");
            dw_item.SetItemString(ll_row, L"NClassifyID", L"");
            dw_item.SetItemDisplayString(ll_row, L"NClassifyID", L"");
            dw_item.SetItemString(ll_row, L"NName", L"");
            dw_item.SetItemString(ll_row, L"NInvoiceNo", L"");
         }
         dw_item.Redraw();
         return 1;
      }
      int onebill()
      {
         int ll_row = dw_item.GetNextSelectRow(1);
         if (ll_row < 1) return 1;
         int MB_OKCANCEL = 1;
         int IDOK = 1;
         int ret =MessageBox(GetHWND(), L"确认开票吗?", L"提示", MB_OKCANCEL);
         if (ret != IDOK) return 1;
         dw_item.AcceptText();
         while (ll_row > 0 && ll_row <= dw_item.GetRowCount())
         {
            xstring ls_dtlno = dw_item.GetItemString(ll_row, L"InvoiceNo");
            dw_item.SetItemString(ll_row, L"NInvoiceNo", ls_dtlno);
            //dw_item.SetItemString(ll_row,L"NAmount",dw_item.GetItemString(ll_row,L"Amount"));
            xstring sdate = publiccode::GetCurrentDate();
            dw_item.SetItemString(ll_row, L"NotifyDate", sdate);
            dw_item.ItemChangeTo(ll_row, L"NAmount", dw_item.GetItemString(ll_row, L"Amount"));
            ll_row = dw_item.GetNextSelectRow(ll_row + 1);
         }
         dw_item.Redraw();
         return 1;
      }
      int onebillno() {
         int ll_row = dw_item.GetNextSelectRow(1);
         if (ll_row < 1) return 1;
         int MB_OKCANCEL = 1;
         int IDOK = 1;
         int ret = MessageBox(GetHWND(), L"确认不予开票吗?", L"提示", MB_OKCANCEL);
         if (ret != IDOK) return 1;
         dw_item.AcceptText();
         while (ll_row > 0 && ll_row <= dw_item.GetRowCount())
         {
            xstring ls_dtlno = dw_item.GetItemString(ll_row, L"InvoiceNo");
            dw_item.ItemChangeTo(ll_row, L"NAmount", dw_item.GetItemString(ll_row, L""));
            dw_item.ItemChangeTo(ll_row, L"NQuantity", dw_item.GetItemString(ll_row, L""));
            dw_item.SetItemString(ll_row, L"NotifyDate", L"");
            dw_item.SetItemString(ll_row, L"NClassifyID", L"");
            dw_item.SetItemDisplayString(ll_row, L"NClassifyID", L"");
            dw_item.SetItemString(ll_row, L"NQtyUnit", L"");
            dw_item.SetItemString(ll_row, L"NName", L"");
            dw_item.SetItemString(ll_row, L"NInvoiceNo", L"");
            ll_row = dw_item.GetNextSelectRow(ll_row + 1);
         }
         dw_item.Redraw();
         return 1;
      }
      int CalcRate()
      {
         for (int row = 1; row <= dw_fob.GetRowCount(); row++)
         {
            xstring InvoiceNo = dw_fob.GetItemString(row, L"InvoiceNo");
            xstring ClassifyID = dw_fob.GetItemString(row, L"ClassifyID");
            double sumAmt = GetSumAmount(InvoiceNo, ClassifyID);
            double sumQty = GetSumQuantity(InvoiceNo, ClassifyID);
            double fobAmt = dw_fob.GetItemDouble(row, L"FobAmt");
            double rate = sumAmt / fobAmt;
            double LimitAmt = fobAmt * rate;
            dw_fob.SetItemDouble(row, L"Rate", rate);
            dw_fob.SetItemDouble(row, L"LimitAmt", LimitAmt);
            dw_fob.SetItemDouble(row, L"RestAmt", LimitAmt - sumAmt);
         }
         RecalcProfitData();
         dw_fob.Redraw();
         return 1;
      }
      int onimport() {
         //OpenWindow(L"dev:xpage[import.vatnotify.vx]",0);
         return 1;
      }
      int OnFobItemChanged(TEvent* evt, LPARAM p)
      {
         DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
         xstring colname = hdr.colname;
         xstring value = hdr.data;
         int row = hdr.row;
         if (colname == L"Rate" || colname == L"FobAmt")
         {
            xstring InvoiceNo = dw_fob.GetItemString(row, L"InvoiceNo");
            xstring ClassifyID = dw_fob.GetItemString(row, L"ClassifyID");
            double sumAmt = GetSumAmount(InvoiceNo, ClassifyID);
            double sumQty = GetSumQuantity(InvoiceNo, ClassifyID);
            double fobAmt = dw_fob.GetItemDouble(row, L"FobAmt");
            double rate = dw_fob.GetItemDouble(row, L"Rate");
            double LimitAmt = fobAmt * rate;
            dw_fob.SetItemDouble(row, L"LimitAmt", LimitAmt);
            dw_fob.SetItemDouble(row, L"RestAmt", LimitAmt - sumAmt);
            dw_fob.Redraw();
            RecalcProfitData();
            return 1;
         }
         return 1;
      }
      int OnItemChanged(TEvent* evt, LPARAM p)
      {
         DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
         xstring colname = hdr.colname;
         xstring value = hdr.data;
         int row = hdr.row;
         xstring ClassifyID = dw_item.GetItemString(row, L"NClassifyID");
         if (ClassifyID == L"") ClassifyID = dw_item.GetItemString(row, L"ClassifyID");
         xstring InvoiceNo = dw_item.GetItemString(row, L"NInvoiceNo");
         if (InvoiceNo == L"") InvoiceNo = dw_item.GetItemString(row, L"InvoiceNo");
         int ll_find = FobLookup(ClassifyID);
         //trace(L"\r\n"+ ll_find.toString()+L":"+ ClassifyID);
         if (colname == L"NAmount")
         {
            if (ll_find > 0)
            {
               //xstring qtyUnit = dw_fob.GetItemString(ll_find,L"CQtyUnit");
               xstring qtyUnit = dw_fob.GetItemString(ll_find, L"QtyUnit");
               double limitAmt = dw_fob.GetItemDouble(ll_find, L"LimitAmt");
               double CQuantity = dw_fob.GetItemDouble(ll_find, L"CQuantity");
               double sumAmt = GetSumAmount(InvoiceNo, ClassifyID);
               double amt = dw_item.GetItemDouble(row, L"NAmount");
               //double qty = CQuantity * amt /limitAmt;
               double qty = dw_item.GetItemDouble(row, L"Quantity");
               if (qtyUnit.trim() != L"千克")
               {
                  int d = xstring(qty).toInt();
                  xstring s = xstring(d);
                  qty = s.toDouble();
               }
               else
               {
                  dw_item.SetItemDouble(row, L"NQuantity", qty);
                  xstring sqty = dw_item.GetItemString(row, L"NQuantity");
                  qty = sqty.toDouble();
               }
               double restAmt = limitAmt - sumAmt;
               dw_fob.SetItemDouble(ll_find, L"RestAmt", restAmt);
               dw_item.ItemChangeTo(row, L"NQuantity", xstring(qty));
               dw_fob.Redraw();
            }
            return 1;
         }
         else if (colname == L"NQuantity")
         {
            if (ll_find > 0)
            {
               double CQuantity1 = dw_fob.GetItemDouble(ll_find, L"CQuantity");
               double sumQty = GetSumQuantity(InvoiceNo, ClassifyID);
               double restQuantity = CQuantity1 - sumQty;
               dw_fob.SetItemDouble(ll_find, L"RestQty", restQuantity);
               xstring qtyUnit2 = dw_fob.GetItemString(ll_find, L"QtyUnit");
               dw_item.SetItemString(row, L"NQtyUnit", qtyUnit2);
               dw_fob.Redraw();
            }
            return 1;
         }
         else if (colname == L"NInvoiceNo")
         {
            row = dw_item.GetRow();
            InvoiceNo = dw_item.GetItemString(row, L"NInvoiceNo");
            if (InvoiceNo == L"") InvoiceNo = dw_item.GetItemString(row, L"InvoiceNo");
            RetrieveFob(InvoiceNo);
            RetrieveProfit(InvoiceNo);
            return 1;
         }
         else if (colname == L"NClassifyID")
         {
            xstring NQuantity = dw_item.GetItemString(dw_item.GetRow(), L"NQuantity");
            if (NQuantity != L"") dw_item.ItemChangeTo(dw_item.GetRow(), L"NQuantity", NQuantity);
            xstring NAmount = dw_item.GetItemString(dw_item.GetRow(), L"NAmount");
            if (NAmount != L"") dw_item.ItemChangeTo(dw_item.GetRow(), L"NAmount", NAmount);
            xstring sdate = publiccode::GetCurrentDate();
            dw_item.SetItemString(dw_item.GetRow(), L"NotifyDate", sdate);
            //xstring qtyUnit1 = dw_fob.GetItemString(ll_find,L"CQtyUnit");
            xstring qtyUnit1 = dw_fob.GetItemString(ll_find, L"QtyUnit");
            dw_item.SetItemString(dw_item.GetRow(), L"NQtyUnit", qtyUnit1);
            dw_item.SetItemString(dw_item.GetRow(), L"VATRefundRate", dw_fob.GetItemString(ll_find, L"VATRefundRate"));
            dw_item.Redraw();
            return 1;
         }
         /*
               if dwo.name='notifycname' then
         if trim(data)='' then
            this.setItem(row,'notifycustid','')
         else
            //cwd
            if pos(data,'"') > 0 then
               ll_find = dw_3.find(L"cname='"+data+L"'",0,dw_3.rowCount())
            else
               ll_find = dw_3.find('cname=L"'+data+'"',0,dw_3.rowCount())
            end if
            //end
      //      ll_find = dw_3.find('cname=L"'+data+'"',0,dw_3.rowCount())
            if ll_find > 0 then
               this.setItem(row,'notifycustid',dw_3.getItemString(ll_find,'custid'))
               this.setItem(row,'custunit',dw_3.getItemString(ll_find,'custunit'))
               decimal ld_rate
               ls_custid = dw_3.getItemString(ll_find,'custid')
               select retax into :ld_rate from code_t_custom where code_s = :ls_custid;
               this.setitem(row,'retax',ld_rate)
            end if
         end if
         if not isnull(this.getItemDecimal(row,'notifybuyamt')) then
            dwoex = this.object.notifybuyamt
            this.event itemchanged(row,dwoex,xstring(this.getItemDecimal(row,'notifybuyamt')))
         end if
         if not isnull(this.getItemDecimal(row,'notifycustqty')) then
            dwoex = this.object.notifycustqty
            this.event itemchanged(row,dwoex,xstring(this.getItemDecimal(row,'notifycustqty')))
         end if
         dw_1.setitem( dw_1.getrow(), 'notifydate',today())
         */
         return 1;
      }
      double GetSumAmountExcept(xstring InvoiceNo, xstring ClassifyID, xstring InvoiceNoExcept)
      {
         xml x ;
         xaserverarg arg = ViewObject::MakeArg();
         arg.AddArg(L"ClassifyID", ClassifyID);
         arg.AddArg(L"InvoiceNo", InvoiceNo);
         arg.AddArg(L"InvoiceExcept", InvoiceNoExcept);
         if (xurl::get(L"/sale/data/VATNotify/entity/suminfo", arg.GetString(), x) != 1)
         {
            xstring error = x.text();
            alert(L"err:" + error);
            return 0.0;
         }
         KXMLDOMNode n = x.selectSingleNode(L"data/Item/amt");
         if (!n) return 0.0;
         xstring str = n.text();
         return str.toDouble();
      }
      double GetSumQuantityExcept(xstring InvoiceNo, xstring ClassifyID, xstring InvoiceNoExcept)
      {
         xml x ;
         xaserverarg arg = ViewObject::MakeArg();
         arg.AddArg(L"ClassifyID", ClassifyID);
         arg.AddArg(L"InvoiceNo", InvoiceNo);
         arg.AddArg(L"InvoiceExcept", InvoiceNoExcept);
         if (xurl::get(L"/sale/data/VATNotify/entity/suminfo", arg.GetString(), x) != 1)
         {
            xstring error = x.text();
            alert(L"err:" + error);
            return 0.0;
         }
         KXMLDOMNode n = x.selectSingleNode(L"data/Item/qty");
         if (!n) return 0.0;
         xstring str = n.text();
         return str.toDouble();
      }
      double GetSumAmount(xstring InvoiceNo, xstring ClassifyID)
      {
         double amt = 0;
         xstring InvoiceNoExcept = dw_item.GetItemString(1, L"InvoiceNo");
         if (InvoiceNoExcept != L"") amt = GetSumAmountExcept(InvoiceNo, ClassifyID, InvoiceNoExcept);
         for (int ll_row = 1; ll_row <= dw_item.GetRowCount(); ll_row++)
         {
            xstring ls_dtlno = dw_item.GetItemString(ll_row, L"NInvoiceNo");
            if (ls_dtlno == L"") ls_dtlno = dw_item.GetItemString(ll_row, L"InvoiceNo");
            if (InvoiceNo == ls_dtlno)
            {
               xstring classifyID = dw_item.GetItemString(ll_row, L"NClassifyID");
               if (classifyID == L"")  classifyID = dw_item.GetItemString(ll_row, L"ClassifyID");
               if (classifyID == ClassifyID)
                  amt += dw_item.GetItemDouble(ll_row, L"NAmount");
            }
         }
         return amt;
      }
      int RecalcProfitData()
      {
         double fobAmt = GetSumFobAmt();
         double limitAmt = GetSumLimitAmount();
         double RefundAmt = GetSumRefund();
         double goodsAmt = limitAmt - RefundAmt;
         double freight = dw_profit.GetItemDouble(1, L"Freight");
         double comm = dw_profit.GetItemDouble(1, L"Comm");
         double    netAmount = fobAmt - freight - comm;
         double exchCost = (limitAmt - RefundAmt) / fobAmt;
         dw_profit.SetItemDouble(1, L"NetAmount", netAmount);
         dw_profit.SetItemDouble(1, L"SaleAmount", fobAmt);
         dw_profit.SetItemDouble(1, L"SaleCost", goodsAmt);
         dw_profit.SetItemDouble(1, L"Drawback", RefundAmt);
         dw_profit.SetItemDouble(1, L"ExchCost", exchCost);
         dw_profit.Redraw();
         return 1;
      }
      double GetSumLimitAmount()
      {
         double amt = 0;
         for (int ll_row = 1; ll_row <= dw_fob.GetRowCount(); ll_row++)
         {
            amt += dw_fob.GetItemDouble(ll_row, L"LimitAmt");
         }
         return amt;
      }
      double GetSumRefund()
      {
         double amt = 0;
         for (int ll_row = 1; ll_row <= dw_fob.GetRowCount(); ll_row++)
         {
            double rate = dw_fob.GetItemDouble(ll_row, L"VATRate");
            double refundRate = dw_fob.GetItemDouble(ll_row, L"VATRefundRate");
            double d = dw_fob.GetItemDouble(ll_row, L"LimitAmt");
            double val = d / (100.0 + rate) * refundRate;
            amt += val;
         }
         return amt;
      }
      double GetSumFobAmt()
      {
         double amt = 0;
         for (int ll_row = 1; ll_row <= dw_fob.GetRowCount(); ll_row++)
         {
            amt += dw_fob.GetItemDouble(ll_row, L"FobAmt");
         }
         return amt;
      }
      double GetSumQuantity(xstring InvoiceNo, xstring ClassifyID)
      {
         double qty = 0;
         xstring InvoiceNoExcept = dw_item.GetItemString(1, L"InvoiceNo");
         if (InvoiceNoExcept != L"") qty = GetSumQuantityExcept(InvoiceNo, ClassifyID, InvoiceNoExcept);
         for (int ll_row = 1; ll_row <= dw_item.GetRowCount(); ll_row++)
         {
            xstring ls_dtlno = dw_item.GetItemString(ll_row, L"NInvoiceNo");
            if (ls_dtlno == L"") ls_dtlno = dw_item.GetItemString(ll_row, L"InvoiceNo");
            if (InvoiceNo == ls_dtlno)
            {
               xstring classifyID = dw_item.GetItemString(ll_row, L"NClassifyID");
               if (classifyID == L"")  classifyID = dw_item.GetItemString(ll_row, L"ClassifyID");
               if (classifyID == ClassifyID)
               {
                  qty += dw_item.GetItemDouble(ll_row, L"NQuantity");
               }
            }
         }
         return qty;
      }
      int FobLookup(xstring ClassifyID)
      {
         for (int ll_row = 1; ll_row <= dw_fob.GetRowCount(); ll_row++)
         {
            if (dw_fob.GetItemString(ll_row, L"ClassifyID") == ClassifyID) return ll_row;
         }
         return -1;
      }
      int addother() {
         return 1;
      }
      int deleteother() {
         return 1;
      }
      //命令发布函数
      int OnCmdDispatch(xstring comdid)
      {
         if (comdid == L"save") {
            return OnSave();
         }
         else if (comdid == L"xmParse")
            return OnParse();
         else if (comdid == L"allbill") {
            return allbill();
         }
         else if (comdid == L"allbillno") {
            return allbillno();
         }
         else if (comdid == L"onebill") {
            return onebill();
         }
         else if (comdid == L"onebillno") {
            return onebillno();
         }
         else if (comdid == L"import") {
            return onimport();
         }
         else if (comdid == L"addother") {
            return addother();
         }
         else if (comdid == L"deleteother") {
            return deleteother();
         }
         else if (comdid == L"xmPrint") {
            return OnPrint();
         }
         else if (comdid == L"xmPrintItem") {
            return OnPrintItem();
         }
         else if (comdid == L"xmCalcRate") {
            return CalcRate();
         }
         return 0;
      }
      int OnRowChanged(TEvent* evt, LPARAM p)
      {
         DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
         int row = hdr.row;
         xstring InvoiceNo = dw_item.GetItemString(row, L"NInvoiceNo");
         if (InvoiceNo == L"") InvoiceNo = dw_item.GetItemString(row, L"InvoiceNo");
         if (InvoiceNo != CurInvNo)
         {
            CurInvNo = InvoiceNo;
            RetrieveFob(InvoiceNo);
            RetrieveProfit(InvoiceNo);
            RecalcProfitData();
         }
         return 1;
      }
      int OnParse()
      {
         xaserverarg arg;
         OpenWindow(L"dev:xpage[VATNotifyParse.vx]", arg);
         if (arg.GetArgString(L"process") == L"ok")
         {
            int row = dw_item.GetRow();
            int row1 = dw_item.InsertRow(0);
            dw_item.SetItemString(row1, L"SupplierID", dw_item.GetItemString(row, L"SupplierID"));
            dw_item.SetItemDisplayString(row1, L"SupplierID", dw_item.GetItemDisplayString(row, L"SupplierID"));
            dw_item.SetItemString(row1, L"Amount", arg.GetArgString(L"Amount"));
            dw_item.SetItemString(row1, L"Quantity", arg.GetArgString(L"Quantity"));
            dw_item.SetItemString(row1, L"CQuantity", arg.GetArgString(L"CustQuantity"));
            dw_item.SetItemString(row1, L"ClassifyID", dw_item.GetItemString(row, L"ClassifyID"));
            dw_item.SetItemDisplayString(row1, L"ClassifyID", dw_item.GetItemDisplayString(row, L"ClassifyID"));
         }
         return 1;
      }
      //命令处理事件
      int OnXCommand(TEvent* evt, LPARAM param)
      {
         return OnCmdDispatch(evt->xcommand.pStrID);
      }
      int OnSave()
      {
         xml x ;
         dw_item.AcceptText();
         dw_item.DwUpdateAllToEx(x);
         xaserverarg arg = ViewObject::MakeArg();
         arg.AddArg(L"content", x.xml());
         //trace(x.xml);
         //return 1;
         if (xurl::get(L"/sale/data/VATNotify/base/update", arg.GetString(), x) != 1)
         {
            xstring error = x.text();
            alert(L"err:" + error);
            return 1;
         }
         xstring str = x.documentElement().getAttribute(L"text");
         if (str == L"true")
         {
            dw_item.ResetUpdateStatus();
         }
         else
         {
            alert(L"保存失败1!");
            return 1;
         }
         dw_fob.AcceptText();
         xml x1 ;
         dw_fob.DwUpdateAllToEx(x1);
         arg.AddArg(L"content", x1.xml());
         int MB_OKCANCEL = 1;
         int IDOK = 1;
         /*
         for(int ll_row=1;   ll_row <= dw_fob.GetRowCount(); ll_row++)
         {
            xstring RestQty = dw_fob.GetItemString(ll_row,L"RestQty");
            //xstring ClassifyID=dw_fob.GetItemString(ll_row,L"CName");
            if(RestQty !=L"0.00" ){
               //xstring qty =RestQty;
               int ret = win32::MessageBox(GetHWND(),L" å­˜åœ¨ç»“存数量不为0的物品,确认保存吗?",L"提示",MB_OKCANCEL);
               if(ret !=IDOK) return 1;
            }
         }
         */
         //return 0;
         if (xurl::get(L"/sale/data/VATNotify/fob/update", arg.GetString(), x1) != 1)
         {
            xstring error1 = x1.text();
            alert(L"err:" + error1);
            return 1;
         }
         str = x1.documentElement().getAttribute(L"text");
         if (str == L"true")
         {
            dw_fob.ResetUpdateStatus();
            alert(L"保存成功!");
         }
         else
         {
            alert(L"保存失败2!");
            return 1;
         }
         return 1;
      }
      int OnAttachEvent()
      {
         //绑定工具条点击事件
         AttachEvent(L"WM_XCOMMAND", (FEvent)&simplemaintvatnotifyWin::OnXCommand);
         //获取焦点事件,用于重置工具条
         AttachEvent(L"WM_SETFOCUS", (FEvent)&simplemaintvatnotifyWin::OnSetFocus);
         AttachEvent(L"dw_item", L"DWV_ITEMCHANGED", (FEvent)&simplemaintvatnotifyWin::OnItemChanged);
         AttachEvent(L"dw_fob", L"DWV_ITEMCHANGED", (FEvent)&simplemaintvatnotifyWin::OnFobItemChanged);
         AttachEvent(L"dw_item", L"DWV_ROWFOCUSCHANGED", (FEvent)&simplemaintvatnotifyWin::OnRowChanged);
         AttachEvent(L"dw_item", L"DWV_ASKDATA", (FEvent)&simplemaintvatnotifyWin::OnAskDataItem);
         AttachCloseWindow();
         return 1;
      }
      int RetrieveFob(xstring InvoiceNo, bool start = false)
      {
         if (!start)
         {
            dw_fob.Filter(L"InvoiceNo", InvoiceNo);
            dw_fob.Redraw();
            if (dw_fob.GetRowCount() > 0) return 1;
         }
         //start = true;
         xml x ;
         xaserverarg arg;
         arg.AddArg(L"invoiceno", InvoiceNo);
         if (getUrl(L"/sale/data/VATNotify/entity/fob", arg.GetString(), x) != 1)
         {
            trace(x.text());
            return -1;
         }
         else
         {
            //trace(x.xml);
            if (start)
            {
               dw_fob.Retrieve(x);
               dw_fob.Redraw();
            }
            else
            {
               xml x1 ;
               dw_fob.DwUpdateAllToEx(x1);
               KXMLDOMElement docElement = x1.documentElement();
               if (docElement)
               {
                  KXMLDOMNodeList lst = x.selectNodes(L"data/Item");
                  int n = lst.length();
                  for (int i = 0; i < n; i++)
                  {
                     KXMLDOMElement e = lst.item(i);
                     docElement.appendChild(e);
                     e.Release();
                  }
                  docElement.Release();
                  lst.Release();
                  dw_fob.Retrieve(x1);
               }
               else
               {
                  dw_fob.Retrieve(x);
               }
               dw_fob.Filter(L"InvoiceNo", InvoiceNo);
               dw_fob.Redraw();
            }
         }
         return 1;
      }
      int RetrieveProfit(xstring InvoiceNo)
      {
         xml x ;
         xaserverarg arg;
         arg.AddArg(L"invoiceno", InvoiceNo);
         if (getUrl(L"/sale/data/VATNotify/entity/profit", arg.GetString(), x) != 1)
         {
            trace(x.text());
            return -1;
         }
         else
         {
            dw_profit.Retrieve(x);
            dw_profit.Redraw();
         }
         return 1;
      }
      int  OnRetrieve()
      {
         HCURSOR  hCursor = xutil::SetCursorWait();
         xml x ;
         xaserverarg arg;
         if (GetWinParam())
         {
            int pArg = GetArg();
         }
         else
         {
            xutil::RestoreCursor(hCursor);
            return 1;
         }
         if (getUrl(L"/sale/data/VATNotify/entity/base", arg.GetString(), x) != 1)
         {
            trace(x.text());
            xutil::RestoreCursor(hCursor);
            return -1;
         }
         else
         {
            dw_item.Retrieve(x);
            dw_item.Redraw();
            dw_item.SetSelectionMode(1);
         }
         if (dw_item.GetRowCount() > 0)
         {
            xstring InvoiceNo = dw_item.GetItemString(1, L"NInvoiceNo");
            if (InvoiceNo == L"") InvoiceNo = dw_item.GetItemString(1, L"InvoiceNo");
            CurInvNo = InvoiceNo;
            RetrieveFob(InvoiceNo);
            RetrieveProfit(InvoiceNo);
            RecalcProfitData();
         }
         xutil::RestoreCursor(hCursor);
         return 1;
      }
      //base AskData
      int OnAskDataItem(TEvent* evt, LPARAM p)
      {
         DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
         int row = hdr.row;
         xstring x = hdr.colname;
         if (x == L"userInvoiceNo") //下拉
         {
            xstring sInvoiceNo = dw_item.GetItemString(row, L"NInvoiceNo");
            hdr.data = sInvoiceNo;
         }
         return 1;
      }
      int onload()
      {
         dw_item = GetControl(L"dw_item");
         dw_item.openUrl(L"/sale/view/VATNotify/template/VATNotify/item");
         dw_item.SetColumnState(L"InvoiceNo", false);
         dw_item.SetColumnState(L"CName", false);
         //dw_item.SetColumnState(L"CreatorID",false);
         //dw_item.SetColumnState(L"CreateDate",false);
         dw_item.SetColumnState(L"VATRate", false);
         dw_item.SetColumnState(L"VATRefundRate", false);
         dw_item.SetColumnState(L"IsFinish", false);
         dw_item.SetColumnState(L"Type", false);
         dw_item.SetColumnState(L"QtyUnitName", false);
         dw_item.SetColumnState(L"QtyUnit", false);
         dw_item.SetColumnState(L"CQtyUnit", false);
         dw_fob = GetControl(L"dw_fob");
         dw_fob.openUrl(L"/sale/view/VATNotify/template/VATNotify/fob");
         dw_profit = GetControl(L"dw_profit");
         dw_profit.openUrl(L"/sale/view/VATNotify/template/VATNotify/profit");
         dw_profit.SetColHeaderHeight(0);
         dw_profit.SetRowSelectorWidth(0);
         dw_profit.SetHScrollState(false);
         dw_profit.SetVScrollState(false);
         InvNo = L"";
         CurInvNo = L"";
         xaserverarg arg;
         if (GetWinParam())
         {
            int pArg = GetArg();
            InvNo = arg.GetArgString(L"invoiceno");
            SetWindowText(GetHWND(), InvNo);
         }
         CurInvNo = InvNo;
         OnRetrieve();
         OnAttachEvent();
         return 1;
      }
      int onloaded()
      {
         SetAgent();
         return 1;
      }
   };