From a4d2315ee4ca3f6177b4fb2526bed2feff3d89be Mon Sep 17 00:00:00 2001
From: lifan <2308045698@qq.com>
Date: 星期三, 22 十月 2025 16:52:58 +0800
Subject: [PATCH] update
---
jrj/project/business/AP/APNew3.warizd.cpp | 1099 ++++++++++++++++++++++++++++++++-------------------------
1 files changed, 611 insertions(+), 488 deletions(-)
diff --git a/jrj/project/business/AP/APNew3.warizd.cpp b/jrj/project/business/AP/APNew3.warizd.cpp
index 6c3d5bb..d6a2c6f 100644
--- a/jrj/project/business/AP/APNew3.warizd.cpp
+++ b/jrj/project/business/AP/APNew3.warizd.cpp
@@ -1,542 +1,665 @@
#include <wobject/xstring.hpp>
#include <xcontrol/xtreeview.hpp>
#include <xcontrol/xdwgrid.hpp>
+#include <wobject/xdouble.hpp>
+#include <xcontrol/xlayersheet.hpp>
#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp"
#include "viewobject/view.base.hpp"
using xml = KXMLDOMDocument;
-class __declspec(dllexport) listSupplierv3 : public listwin
-{
-public:
- xdwgrid dw_goods;
- xtreeview tv_1;
- xcombobox ddlb_1;
- int changeddlb;
- xstring TypeWork;
- xstring GoodsUrl;
- xstring m_sType; //type
- xstring m_sTypeTxt; //选中树的data
- // xstring m_searchtxt;
- int PIndex;
- xnode m_agentNode; //Agent Condition
- xstring m_agentCond; //Agent Node
-
-public:
- listSupplierv3(void* implPtr, HWND hWnd) :listwin(implPtr, hWnd) {}
-public:
- static listSupplierv3* CreateInstance(void* implPtr, void* hWnd)
+ class __declspec(dllexport) APNewWarizd3 : public xframe
{
- listSupplierv3* pWin = new listSupplierv3(implPtr, (HWND)hWnd);
- return pWin;
- }
- int OnRetrieve()
- {
- xml x;
+ public:
+ xdwgrid dw_1;
+ xdwgrid dw_2;
+ xdwgrid dw_3;
+ xdwgrid dw_4;
+ xdwgrid dw_5;
+ xdwgrid dw_6;
+ xdwgrid dw_101;
+ xdwgrid dw_102;
+ bool bstart;
+ xlayersheet m_layer;
+ xnode m_agentNode; //Agent Condition
+ xstring searchStr;
- xaserverarg arg;
- arg.AddArg(L"pageindex", xstring(PIndex)); //第几页
- arg.AddArg(L"pagenumber", xstring(listwin::m_pageNumber)); //每页数量
- arg.AddArg(L"QueryTxt", listwin::m_QueryTxt);
- arg.AddArg(L"sType", m_sType);
- arg.AddArg(L"sTypeTxt", m_sTypeTxt);
- trace(arg.GetString());
- //alert(L"xxxx");
- if (getUrl(GetServerUrl(), L"/sale/data/" + GetEntityName(1) + L"/entity/list", arg.GetString(), x) != 1)
+ public:
+ APNewWarizd3(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+ public:
+ static APNewWarizd3* CreateInstance(void* implPtr, void* hWnd)
{
- return -1;
+ APNewWarizd3* pWin = new APNewWarizd3(implPtr, (HWND)hWnd);
+ return pWin;
}
- else
+ int SetAgent()
{
- KXMLDOMElement e = x.documentElement();
- if (listwin::dw_pages && e.selectSingleNode(L"@TotalPage"))
+ xstring xfNodeAgentArea = L"agentarea";
+ xnode anode = GetAgentNode(xfNodeAgentArea);
+ if (m_agentNode)
{
- xstring s = e.selectSingleNode(L"@TotalPage").text(); //总数量
- listwin::dw_pages.SetMaxPage(s.toInt());
+ SetAgentNode(anode, m_agentNode);
}
- //alert(x.GetXml());
- dw_list.Retrieve(x);
- dw_list.Redraw();
- dw_list.SetReadOnly(true);
- }
- return 1;
- }
-
- int SetEntityData(xaserverarg arg)
- {
- xstring strQueryTxt = arg.GetArgString(L"QueryTxt");
- xml x;
-
- arg.AddArg(L"sType", m_sType);
- arg.AddArg(L"sTypeTxt", m_sTypeTxt);
- trace(arg.GetString());
- if (getUrl(GetServerUrl(), L"/sale/data/" + GetEntityName(1) + L"/entity/list", arg.GetString(), x) != 1)
- {
- alert(x.text());
-
- return -1;
- }
- else
- {
- KXMLDOMElement e = x.documentElement();
- if (listwin::dw_pages && e.selectSingleNode(L"@TotalPage"))
+ else
{
-
- xstring s = e.selectSingleNode(L"@TotalPage").text(); //总数量
- listwin::dw_pages.SetMaxPage(s.toInt());
+ KXMLDOMElement xframeElement = GetElement();
+ KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*");
+ if (agent)
+ {
+ xstring s = agent.xml();
+ m_agentNode = SetAgentNode(anode, s);
+ }
}
- //trace(x.GetXml());
- listwin::dw_list.Retrieve(x);
- listwin::dw_list.Redraw();
- listwin::dw_list.SetReadOnly(true);
+ return 1;
}
- return 1;
- }
-
- int OnChangePages(TEvent* evt, LPARAM p)
- {
- PAGENMHDR* h = (PAGENMHDR*)evt->notify.pnmh;
- int c = h->cur;
- HCURSOR hCursor = xutil::SetCursorWait();
- OnRetrieve();
- PIndex = c;
- xutil::RestoreCursor(hCursor);
- return 1;
-
-
- }
-
- int ViewUpdate(int pr, xstring updateItem, xaserverarg arg)
- {
- if (updateItem == L"refresh")
+ int OnDoubleClicked(TEvent* evt, LPARAM p)
{
- //trace(L"sd");
- xdwpages zz = GetControl(L"pages");
- int h = zz.SetCurPage(1);
- //trace(h);
- OnRetrieve();
- }
- return 1;
- }
+ dw_1.AcceptText();
+ dw_2.AcceptText();
- //树选择
- int OnTreeSelChanged(TEvent evt, LPARAM p)
- {
- if (changeddlb != 1)
+ HCURSOR hCursor = xutil::SetCursorWait();
+ int col = dw_1.GetColumn();
+ dw_1.ItemChangeTo(dw_1.GetRow(), L"PayAmount", dw_1.GetItemString(dw_1.GetRow(), L"Balance"));
+ dw_1.Redraw();
+ xutil::RestoreCursor(hCursor);
+ return 1;
+ }
+
+ int OnDoubleClickedOne(TEvent* evt, LPARAM p)
{
- //alert(L"1");
+ DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
+ xstring colname = hdr.colname;
+ xstring value = hdr.data;
- HTREEITEM h = tv_1.GetSelectedItem();
- KXMLDOMElement& e = *(KXMLDOMElement*)tv_1.GetItemData(h);
+ double Amount = dw_3.GetItemDouble(hdr.row, L"Amount");
+ double PayedAmount = dw_3.GetItemDouble(hdr.row, L"PayedAmount");
- xstring t = e.selectSingleNode(L"@type").text();
- m_sType = t + L"";
- xstring txt = e.selectSingleNode(L"@code").text();
- if (txt == L"")
- txt = e.selectSingleNode(L"@name").text();
- m_sTypeTxt = txt + L"";
-
- //alert(m_sTypeTxt);
-
- PIndex = 1;
- OnRetrieve();
- }
- return 1;
- }
-
- int createSubTree(HTREEITEM h, KXMLDOMElement ele)
- {
- KXMLDOMNodeList nlist = ele.selectNodes(L"item");
- int i;
- int s = nlist.length();
- if (s > 0)
- for (i = 0; i < s; i++)
+ if (colname == L"PrePayAmount" || colname == L"Amount")
{
-
- KXMLDOMElement* e = new KXMLDOMElement(nlist.item(i));
- xstring name = e->selectSingleNode(L"@name").text();
- HTREEITEM hw = tv_1.InsertChildItem(h, name, (LPARAM)e, 15);
- createSubTree(hw, *e);
+ double Amount1 = dw_3.GetItemDouble(hdr.row, L"Amount");
+ double PrePayAmount = dw_3.GetItemDouble(hdr.row, L"PrePayAmount");
+ dw_3.SetItemDouble(hdr.row, L"PayedAmount", xdouble(Amount - PrePayAmount).round(2));
}
- return 1;
- }
-
- int OnCreateTree(xstring sType)
- {
-
- while (tv_1.GetRootItem())
- tv_1.DeleteItem(tv_1.GetRootItem());
-
- xml x;
-
- xaserverarg arg;
-
- arg.AddArg(L"sType", sType);
- //Tree.pref.supplier.xq
- //getUrl(GetEntityName(1)+L"/entity/list",arg.GetString(),x);
- //if (xaserver::ExecXQuery(GetServerUrl(),L"[Tree.pref.supplier.xq]",arg.GetString(),x)!=1)
- if (getUrl(GetServerUrl(), L"/sale/data/" + GetEntityName(1) + L"/pref/list/tree", arg.GetString(), x) != 1)
- {
- trace(x.text());
- return -1;
+ return 1;
}
- else
+
+
+ //焦点激活处理函数
+ int OnSetFocus(TEvent* evt, LPARAM param)
{
- KXMLDOMNodeList nlist = x.selectNodes(L"root/item");
- int len = nlist.length();
- if (len > 0)
+ //重置工具条
+ //SetAgent();
+ return 1;
+ }
+
+ int ProcessBase(xdwgrid dw_obj)
+ {
+ xstring SupplierID;
+ for (int i = 1; i <= dw_obj.GetRowCount(); i++)
{
- int i;
+ bool inserted = false;
+ SupplierID = dw_obj.GetItemString(i, L"SupplierID");
+ int row = 1;
+ /*for(row = 1; row <= dw_3.GetRowCount(); row++)
+ {
+ if( SupplierID == dw_3.GetItemString(row,L"SupplierID")) break;
+ }
+ if(row > dw_3.GetRowCount())
+ {*/
+ row = dw_3.InsertRow(0);
+ inserted = true;
+ /*}*/
+ if (inserted)
+ {
+ xstring sdate = publiccode::GetCurrentDate();
+ dw_3.SetItemString(row, L"APDate", sdate);
+
+ dw_3.SetItemString(row, L"CreateDate", sdate);
+ dw_3.SetItemString(row, L"PayedDate", sdate);
+ xstring suserid = publiccode::GetUser().id;
+ xstring susername = publiccode::GetUser().name;
+ dw_3.SetItemString(row, L"CreatorID", suserid);
+ dw_3.SetItemDisplayString(row, L"CreatorID", susername);
+ dw_3.SetItemDouble(row, L"PayedAmount", dw_obj.GetItemDouble(i, L"PayedAmount"));
+ dw_3.SetItemDouble(row, L"PrePayAmount", dw_obj.GetItemDouble(i, L"PrePayAmount"));
+ dw_3.SetItemDouble(row, L"Amount", dw_obj.GetItemDouble(i, L"Amount"));
+
+ dw_3.SetItemString(row, L"APType", L"000"); /*货款*/
+ dw_3.SetItemString(row, L"SupplierID", dw_obj.GetItemString(i, L"SupplierID"));
+ dw_3.SetItemDisplayString(row, L"SupplierID", dw_obj.GetItemDisplayString(i, L"SupplierID"));
+ dw_3.SetItemString(row, L"APSupplierID", dw_obj.GetItemString(i, L"APSupplierID"));
+ dw_3.SetItemDisplayString(row, L"APSupplierID", dw_obj.GetItemDisplayString(i, L"APSupplierID"));
+ dw_3.SetItemDisplayString(row, L"SalespersonID", dw_obj.GetItemDisplayString(i, L"SalespersonID"));
+ dw_3.SetItemString(row, L"SalespersonID", dw_obj.GetItemString(i, L"SalespersonID"));
+ dw_3.SetItemString(row, L"OrgName", dw_obj.GetItemString(i, L"OrgName"));
+ dw_3.SetItemString(row, L"InvoiceNo", dw_obj.GetItemString(i, L"NInvoiceNo"));
+ xstring APID = publiccode::GetGuid();
+ dw_3.SetItemString(row, L"APID", APID);
+ }
+ else
+ {
+ double amt = 0.0;
+ amt = dw_3.GetItemDouble(row, L"PayedAmount");
+ amt += dw_obj.GetItemDouble(i, L"PayedAmount");
+ dw_3.SetItemDouble(row, L"PayedAmount", amt);
+
+ amt = dw_3.GetItemDouble(row, L"PrePayAmount");
+ amt += dw_obj.GetItemDouble(i, L"PrePayAmount");
+ dw_3.SetItemDouble(row, L"PrePayAmount", amt);
+
+ amt = dw_3.GetItemDouble(row, L"Amount");
+ amt += dw_obj.GetItemDouble(i, L"Amount");
+ dw_3.SetItemDouble(row, L"Amount", amt);
+ }
+ dw_obj.SetItemString(i, L"APID", dw_3.GetItemString(row, L"APID"));
+ }
+ dw_3.Redraw();
+
+ return 1;
+ }
+
+ int OnTabSelectedSheet(TEvent* evt, LPARAM p)
+ {
+ int index = m_layer.GetSheetIndex();
+ if (index == 1)
+ {
+ dw_1.AcceptText();
+
+ dw_4.Reset();
+ dw_3.Reset();
+ dw_6.Reset();
+
+ xml x ;
+
+ x.loadXML(L"<data/>");
+
+ xml x1 ;
+
+ dw_2.DwUpdateAllToEx(x1);
+ xstring SupplierID = L"";
+ int i = 0;
+ int row = 0;
+ for (i = 1; i <= dw_1.GetRowCount(); i++)
+ {
+ xstring Amount = dw_1.GetItemString(i, L"PayAmount");
+ xstring PrePayAmount = dw_1.GetItemString(i, L"PrePayAmount");
+ SupplierID = dw_1.GetItemString(i, L"VATSupplierID");
+ xstring VATInvoiceID = dw_1.GetItemString(i, L"VATInvoiceID");
+ if (Amount != L"" && Amount.toInt() != 0)
+ {
+ int row = dw_4.InsertRow(0);
+ dw_4.SetItemString(row, L"InvoiceNo", dw_1.GetItemString(i, L"InvoiceNo"));
+ dw_4.SetItemString(row, L"NInvoiceNo", dw_1.GetItemString(i, L"NInvoiceNo"));
+ dw_4.SetItemString(row, L"VATNo", dw_1.GetItemString(i, L"VATNo"));
+
+ dw_4.SetItemString(row, L"Amount", dw_1.GetItemString(i, L"PayAmount"));
+ dw_4.SetItemString(row, L"PrePayAmount", dw_1.GetItemString(i, L"PrePayAmount"));
+ dw_4.SetItemString(row, L"PayedAmount", dw_1.GetItemString(i, L"APAmount"));
+
+ dw_4.SetItemString(row, L"CurrencyCode", L"RMB");
+ dw_4.SetItemString(row, L"SupplierID", dw_1.GetItemString(i, L"SupplierID"));
+ dw_4.SetItemDisplayString(row, L"SupplierID", dw_1.GetItemDisplayString(i, L"SupplierID"));
+ dw_4.SetItemString(row, L"APSupplierID", dw_1.GetItemString(i, L"VATSupplierID"));
+ dw_4.SetItemDisplayString(row, L"APSupplierID", dw_1.GetItemDisplayString(i, L"VATSupplierID"));
+ dw_4.SetItemString(row, L"VATInvoiceID", VATInvoiceID);
+
+ dw_4.SetItemDisplayString(row, L"SalespersonID", dw_1.GetItemDisplayString(i, L"SalespersonID"));
+ dw_4.SetItemString(row, L"SalespersonID", dw_1.GetItemString(i, L"SalespersonID"));
+ dw_4.SetItemString(row, L"OrgName", dw_1.GetItemString(i, L"OrgName"));
+
+ xstring APLineID = publiccode::GetGuid();
+ dw_4.SetItemString(row, L"APLineID", APLineID);
+ }
+ }
+ ProcessBase(dw_4);
+ for (i = 1; i <= dw_6.GetRowCount(); i++)
+ {
+ SupplierID = dw_6.GetItemString(i, L"SupplierID");
+ for (row = 1; row <= dw_3.GetRowCount(); row++)
+ {
+ if (SupplierID == dw_3.GetItemString(row, L"SupplierID"))
+ {
+ dw_6.SetItemString(i, L"APID", dw_3.GetItemString(row, L"APID"));
+ break;
+ }
+ }
+ }
+
+ KXMLDOMNodeList nodes = x1.selectNodes(L"data/Item[DisAmountCurrent != '']");
+ int len = nodes.length();
for (i = 0; i < len; i++)
{
-
- KXMLDOMElement* e = new KXMLDOMElement(nlist.item(i));
- xstring name = e->selectSingleNode(L"@name").text();
- HTREEITEM hw = tv_1.InsertChildItem(0, name, (LPARAM)e, 15);
-
- createSubTree(hw, *e);
- tv_1.ExpandItem(hw);
+ KXMLDOMNode n = nodes.item(i);
+ x.documentElement().appendChild(n);
}
- tv_1.ExpandItem(0);
+ dw_5.Retrieve(x);
+ dw_5.Redraw();
+ dw_5.SetReadOnly(true);
}
+ return 1;
}
- return 1;
- }
+ int ResetDataForContinue()
+ {
+ dw_1.Reset();
+ dw_2.Reset();
+ dw_3.Reset();
+ dw_4.Reset();
+ dw_5.Reset();
+ dw_6.Reset();
- //xcombobox下拉
- int OnSelectDdlb(TEvent evt, LPARAM p)
- {
- changeddlb = 1;
+ return 1;
+ }
- int CB_GETCURSEL = 0x0147;
- int nIndex = SendMessageW(ddlb_1.GetHWND(), CB_GETCURSEL, 0, 0);
- KXMLDOMElement e = ddlb_1.GetElement();//GetitemData(wid,nIndex);//ddlb_1.GetElement();
- KXMLDOMElement e2 = e.selectSingleNode(L"item[" + xstring((nIndex + 1)) + L"]");
- xstring text = e2.selectSingleNode(L"@element").text();
- OnCreateTree(text);
- changeddlb = 0;
- return 1;
- }
+ int OnSave(bool continueAdd)
+ {
+ dw_3.AcceptText();
+ dw_4.AcceptText();
- int OnDeleteRow()
- {
- int row = listwin::dw_list.GetNextSelectRow(1);
- if (row < 1) {
- row = listwin::dw_list.GetRow();
- if (row < 1) {
- //win::MessageBox(GetHWND(),L"请选中要删除的行!",L"提示",0);
+ xstring error;
+ xstring str;
+ xml x ;
+ xml x1 ;
+ xml x2 ;
+ xaserverarg arg;
+ xaserverarg arg1;
+ xaserverarg arg2;
+
+ dw_3.DwUpdateAllToEx(x);
+ arg.AddArg(L"content", x.xml());
+
+ if (xurl::get(L"/sale/data/AP/update", arg.GetString(), x) != 1)
+ {
+ error = x.text();
+ alert(L"err:" + error);
+ return 1;
+ }
+ str = x.documentElement().getAttribute(L"text");
+ if (str != L"true")
+ {
+ alert(L"保存失败1!");
+ return 1;
+ }
+
+ dw_4.DwUpdateAllToEx(x1);
+ arg1.AddArg(L"content", x1.xml());
+
+ if (xurl::get(L"/sale/data/AP/update", arg1.GetString(), x1) != 1)
+ {
+ error = x1.text();
+ alert(L"err:" + error);
+ return 1;
+ }
+ str = x1.documentElement().getAttribute(L"text");
+ if (str != L"true")
+ {
+ alert(L"保存失败2!");
+ return 1;
+ }
+
+ if (dw_6.GetRowCount() > 0)
+ {
+ dw_6.DwUpdateAllToEx(x2);
+ arg2.AddArg(L"content", x2.xml());
+
+ if (xurl::get(L"/sale/data/AP/update", arg2.GetString(), x2) != 1)
+ {
+ error = x2.text();
+ alert(L"err:" + error);
+ return 1;
+ }
+ str = x2.documentElement().getAttribute(L"text");
+ if (str != L"true")
+ {
+ alert(L"保存失败3!");
+ return 1;
+ }
+ }
+
+ dw_3.ResetUpdateStatus();
+ dw_4.ResetUpdateStatus();
+ dw_6.ResetUpdateStatus();
+
+ if (!continueAdd)
+ {
+ alert(L"保存成功!");
+ CloseWindow();
+ }
+ else
+ {
+ ResetDataForContinue();
+ m_layer.SelectSheet(0);
+ }
+
+ return 1;
+ }
+
+ //命令发布函数
+ int OnCmdDispatch(xstring comdid)
+ {
+ int index;
+ if (comdid == L"xmPrev")
+ {
+ index = m_layer.GetSheetIndex();
+ index--;
+ m_layer.SelectSheet(index);
+ }
+ else if (comdid == L"xmNext")
+ {
+ index = m_layer.GetSheetIndex();
+ index++;
+ if (index == 1)
+ {
+ xcontrol(GetControl(L"sle_filter")).SetText(L"");
+ xstring str = L"";
+ if (str != searchStr)
+ {
+ searchStr = str;
+ dw_1.Filter(L"VATSupplierID", searchStr);
+ }
+ }
+ m_layer.SelectSheet(index);
+ return 1;
+ }
+ else if (comdid == L"xmCancel")
+ {
+ CloseWindow();
+ return 1;
+ }
+ else if (comdid == L"xmOk")
+ {
+ return OnSave(false);
+ }
+ else if (comdid == L"xmOkEx")
+ {
+ return OnSave(true);
+ }
+ else if (comdid == L"xmFilter") return OnFilter();
+ else if (comdid == L"xmQuery")
+ {
+
+ index = m_layer.GetSheetIndex();
+ index++;
+ OnRetrieve();
+
+ if (dw_1.GetRowCount() > 0)
+ {
+ OnPrepayRetrieve(1, bstart);
+ dw_2.Redraw();
+ }
+
+ return 1;
+ }
+ return 0;
+ }
+
+
+ int OnItemChanged(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"PayAmount")
+ {
+ double amt = dw_1.GetItemDouble(row, L"PayAmount");
+ dw_1.SetItemDouble(row, L"APAmount", amt);
+ dw_1.Redraw();
+ }
+ if (colname == L"APAmount")
+ {
+ double APAmount = dw_1.GetItemDouble(row, L"APAmount");
+ dw_1.SetItemDouble(row, L"PayAmount", APAmount);
+ dw_1.Redraw();
+ }
+ return 1;
+ }
+
+ //命令处理事件
+ int OnXCommand(TEvent* evt, LPARAM param)
+ {
+ return OnCmdDispatch(evt->xcommand.pStrID);
+ }
+
+ int OnRowChanged(TEvent* evt, LPARAM p)
+ {
+ DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
+ int row = hdr.row;
+
+ OnPrepayRetrieve(row, bstart);
+ xml x = ViewObject::RetrieveData(GetServerUrl(), L"/sale/data/AP/list/invoice/supplier", L"InvoiceNo", dw_1.GetItemString(row, L"InvoiceNo"),
+ L"SupplierID", dw_1.GetItemString(row, L"SupplierID"));
+ if (x) dw_101.Retrieve(x);
+
+ dw_2.Redraw();
+
+ return 1;
+ }
+
+ int OnItemAskStyle(TEvent* evt, LPARAM p)
+ {
+ int DMS_CSSSTYLE = 0x8;
+ DWASKSTYLENMHDR& hdr = *(DWASKSTYLENMHDR*)evt->notify.pnmh;
+ int row = hdr.row;
+ int col = hdr.col;
+ xstring colname = hdr.colname;
+
+ int rows = dw_1.GetRowCount();
+ if (row < 1 || row > rows)
+ {
+ return 1;
+ }
+
+ if (colname == L"NInvoiceNo")
+ {
+ xstring NInvoiceNo = dw_1.GetItemString(row, L"NInvoiceNo");
+ xstring InvoiceNo = dw_1.GetItemString(row, L"InvoiceNo");
+ if (NInvoiceNo != InvoiceNo)
+ {
+ hdr.mask = DMS_CSSSTYLE;
+ hdr.pCssStyle = (LPTSTR)L"color:#ff0000";
+ }
+ }
+ return 1;
+ }
+
+ int OnAttachEvent()
+ {
+ //绑定工具条点击事件
+ AttachEvent(L"WM_XCOMMAND", (FEvent)&APNewWarizd3::OnXCommand);
+ //获取焦点事件,用于重置工具条
+ AttachEvent(L"WM_SETFOCUS", (FEvent)&APNewWarizd3::OnSetFocus);
+ AttachEvent(L"dw_1", L"DWV_DOUBLECLICKED", (FEvent)&APNewWarizd3::OnDoubleClicked);//行双击
+ AttachEvent(L"dw_1", L"DWV_ITEMCHANGED", (FEvent)&APNewWarizd3::OnItemChanged);
+ AttachEvent(L"tab_1", L"LYSN_SELECTEDSHEET", (FEvent)&APNewWarizd3::OnTabSelectedSheet);
+ AttachEvent(L"dw_1", L"DWV_ROWFOCUSCHANGED", (FEvent)&APNewWarizd3::OnRowChanged);
+ AttachEvent(L"dw_1", L"DWV_ASKSTYLE", (FEvent)&APNewWarizd3::OnItemAskStyle);
+ return 1;
+ }
+
+ int OnPrepayRetrieve(int row, bool start = false)
+ {
+ xstring supplier = dw_1.GetItemString(row, L"VATSupplierID");
+
+ xml x ;
+
+ xaserverarg arg;
+
+ arg.AddArg(L"SupplierID", supplier);
+ arg.AddArg(L"InvoiceNo", dw_1.GetItemString(row, L"InvoiceNo"));
+ if (getUrl(L"/sale/data/AP/prepaychecklistex", arg.GetString(), x) != 1)
+ {
+ trace(x.text());
return -1;
}
- }
-
- KXMLDOMElement e = listwin::dw_list.GetRowElement(row);
- //xstring sguid = e.SelectSingleNode(L"@guid").text;
- //xstring sName = e.selectSingleNode(L"Name").text+L"";
- xstring sguid = dw_list.GetItemString(dw_list.GetRow(), L"SupplierID");
- xstring sName = dw_list.GetItemString(dw_list.GetRow(), L"Name");
- int MB_YESNO = 0x00000004;
- int IDYES = 6;
- if (MessageBoxW(GetHWND(), L"确认要删除供应商 " + sName + L" 的信息吗?", L"提示", MB_YESNO) != IDYES) return 1;
- xml x;
-
- xaserverarg arg;
- arg.setNativePointer(arg.CreateInstance());
- arg.AddArg(L"guid", sguid);
- arg.AddArg(L"EntityID", sguid);
- // trace(sguid);
- if (xurl::post(GetServerUrl(), L"/sale/data/" + GetEntityName(1) + L"/entity/delete", arg.GetString(), x) != 1)
- {
- xstring error = x.text();
- trace(error);
- }
- else
- {
- KXMLDOMElement msg = x.selectNodes(L"process").item(0);
- xstring success = msg.selectSingleNode(L"@finished").text();
- if (success == L"0")
+ else
{
- alert(msg.selectSingleNode(L"@errInfo").text());
+ dw_2.Retrieve(x);
+ dw_2.Redraw();
+ }
+ return 1;
+ }
+
+ int OnPrepayRetrieve0(int row, bool start = false)
+ {
+ xstring supplier = dw_1.GetItemString(row, L"VATSupplierID");
+ xstring VATInvoiceID = dw_1.GetItemString(row, L"VATInvoiceID");
+ xstring filterStr = supplier + L"||" + VATInvoiceID;
+ if (!start)
+ {
+ dw_2.Filter(L"FilterColumn", filterStr);
+ dw_2.Redraw();
+ if (dw_2.GetRowCount() > 0) return 1;
+ }
+
+ xml x ;
+
+ xaserverarg arg;
+
+ arg.AddArg(L"SupplierID", supplier);
+ if (getUrl(L"/sale/data/AP/prepaychecklist", arg.GetString(), x) != 1)
+ {
+ trace(x.text());
+ return -1;
}
else
{
- MessageBoxW(GetHWND(), L"删除成功!", L"提示", 0);
- listwin::dw_list.DeleteRow(row);
- }
- }
- return 1;
- }
-
- int OnRowChangedEx(TEvent* evt, LPARAM p)
- {
- DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
- int row = hdr.row;
- //if(row < 1 or row > dw_list.GetRowCount()) return 1;
- KXMLDOMElement ele = listwin::dw_list.GetRowElement(row);
- xstring entity = ele.selectSingleNode(L"SupplierID").text();
- xml x;
-
- xaserverarg arg;
- arg.setNativePointer(arg.CreateInstance());
- arg.AddArg(L"EntityID", entity);
-
-
- xstring no1 = publiccode::GetUser().no;
- if (no1 != L"00201")
- {
-
- if (TypeWork.find(L"采购") >= 0)
- {
- GoodsUrl = L"/sale/data/SupplierV3/entity/supplieritemEx";
- }
- else
- {
- GoodsUrl = L"/sale/data/SupplierV3/entity/supplieritem";
- }
- }
- else
- {
- GoodsUrl = L"/sale/data/SupplierV3/entity/supplieritem";
- }
- if (getUrl(GetServerUrl(), GoodsUrl, arg.GetString(), x) != 1)
- {
- trace(x.text());
- return -1;
- }
- else
- {
- dw_goods.Retrieve(x);
- dw_goods.Redraw();
- dw_goods.SetReadOnly(true);
- }
- SetAgent(L"list", entity);
- return 1;
- }
-
- int GridSearch()
- {
- //alert(L"你好");
-#if 0
-
- xstring m_config = L"view.Supplier.v3.config";
- xdwgrid dw = listwin::dw_list;
- xaserverarg& arg = *new xaserverarg;
- arg.setNativePointer(arg.CreateInstance());
- xstring str = TFile::node(m_config, L"config", L"search");
- if (str != L"") {
- arg.AddArg(L"sheet", str);
- }
- else
- arg.AddArg(L"sheet", L"dev:sheet[Supplier.v3.tpl/list]");
- arg.AddArg(L"search", listwin::m_QueryTxt);
- openUrl(L"view.dlg.vface/xpage/grid/column/search", &arg);
- xstring ok = arg.GetArgString(L"return");
- if (ok == L"ok") {
- xstring txt = arg.GetArgString(L"search");
- if (txt != L"") {
- listwin::m_QueryTxt = txt;
- //trace(txt);
- OnRetrieve();
- }
- }
-#endif
- return 0;
- }
-
- int OnSelectAllRow()
- {
- int rows = listwin::dw_list.GetRowCount();
- if (rows < 1) return -1;
- listwin::dw_list.SelectRow(1, rows, true);
- listwin::dw_list.Redraw();
- return 1;
- }
-
- int OnRClick(TEvent evt, LPARAM p)
- {
- return 1;
- }
- int OnLogOff()
- {
- return 1;
- }
- int OnChecked()
- {
- xstring partyno = dw_list.GetItemString(dw_list.GetRow(), L"PartyNo");
- if (partyno.find(L"N") < 0)
- {
- alert(L"已经是正式供应商");
- return 0;
- }
- xstring entityid = GetEntityID(dw_list.GetRow());
- int MB_OKCANCEL = 1;
- int IDOK = 1;
- int ret = MessageBoxW(GetHWND(), L"是否转成正式供应商?", L"提示", MB_OKCANCEL);
- if (ret == IDOK)
- {
- xml x = ViewObject::RetrieveData(GetServerUrl(), L"/sale/data/SupplierV3/entity/updateno", L"entityid", entityid);
-
- if (xstring(x.xml()).find(L"success") > 0)
- {
- alert(L"处理成功");
- OnRetrieve();
- }
- }
- return 1;
- }
- int PreOnCmdDispatch(xstring comdid)
- {
- //alert(comdid);
-
- if (comdid.find(L"action:LogOff", 0) >= 0) return OnLogOff();
- if (comdid.find(L"action:bill.delete", 0) >= 0)
- {
- OnDeleteRow();
- return 0;
- }
- if (comdid == L"action:search1") return GridSearch();
- if (comdid == L"action:bill.refresh")
- {
- return OnRetrieve();
- }
- if (comdid == L"action:bill.xmSaveAs")
- {
- xstring userno = publiccode::GetUser().no;
- if (userno == L"00701" || userno == L"00601" || userno == L"admin")
- {
- dw_list.SaveAs(L"");
- }
- return 1;
- }
- if (comdid == L"action:bill.Annex")
- {
- xaserverarg& arg = *new xaserverarg;
- arg.setNativePointer(arg.CreateInstance());
- arg.AddArg(L"entityid", dw_list.GetItemString(dw_list.GetRow(), L"SupplierID"));
- arg.AddArg(L"ApplyStatus", dw_list.GetItemString(dw_list.GetRow(), L"ApplyStatus"));
-
- OpenWindow(L"dev:xpage[maint.Document.Supplier.v3.vx]", (LPARAM)&arg);
- return 1;
- }
- if (comdid == L"action:bill.AnnexEx")
- {
- xaserverarg& arg4 = *new xaserverarg;
- arg4.setNativePointer(arg4.CreateInstance());
- arg4.AddArg(L"entityid", dw_list.GetItemString(dw_list.GetRow(), L"SupplierID"));
- //arg4.AddArg(L"ApplyStatus",dw_list.GetItemString(dw_list.GetRow(),L"ApplyStatus"));
-
- //OpenWindow(L"dev:xpage[maint.Document.Customer.v3.vx]", p4);
- OpenWindow(L"dev:xpage[maint.Document.SupplierSD.v3.vx]", (LPARAM)&arg4);
- return 1;
- }
- if (comdid == L"action:bill.checked")
- return OnChecked();
- // if(comdid==L"action:bill.import") return OnImport();
- // if(comdid.find(L"action:",0)>=0) return ProcessFlowAction(comdid,1);
- //if(comdid==L"search") return GridSearch(L"view.dlg.vface/xpage/grid/column/edit");
- //if(comdid==L"showall") return ShowAll();
-
- return 1;
- }
-
-
- int PostOnAttachEvent()
- {
- //获得树的选择事件
- AttachEvent(L"tv_1", L"TVN_SELCHANGED", (FEvent)&listSupplierv3::OnTreeSelChanged);
- AttachEvent(L"cbx_1", L"CBN_SELCHANGE", (FEvent)&listSupplierv3::OnSelectDdlb);
- AttachEvent(L"pages", L"PAGE_CLICK", (FEvent)&listSupplierv3::OnChangePages);
- AttachEvent(L"dw_list", L"DWV_RCLICKED", (FEvent)&listSupplierv3::OnRClick);//鼠标右键
- //AttachEvent(L"dw_list", L"DWV_DOUBLECLICKED", (FEvent)&listSupplierv3::OnDoubleClicked);
-
- return 1;
- }
-
- int onload()
- {
- PIndex = 1;
- listwin::m_QueryTxt = L""; //查询条件
- m_sType = L""; //type
- m_sTypeTxt = L""; //选中树的data
-
- listwin::onload();
-
- tv_1 = GetControl(L"tv_1");
- ddlb_1 = GetControl(L"cbx_1");
-
- changeddlb = 0;
- OnCreateTree(L"GoodsCates");
- dw_list.SetColumnState(L"SupplierID", false);
- dw_list.SetColumnState(L"userNo", false);
- dw_list.SetColumnState(L"YearEstablished", false);
- dw_list.SetColumnState(L"LegalPerson", false);
- dw_list.SetColumnState(L"ThirdPartyReport", false);
- dw_list.SetColumnState(L"bAddress", false);
- dw_list.SetColumnState(L"PayType", false);
- dw_list.SetColumnState(L"PicPath", false);
- dw_list.SetColumnState(L"SDID", false);
- dw_list.SetColumnState(L"AdvantageProduct", false);
- //dw_list.SetColumnState(L"ApplyStatus",false);
-
- dw_goods = GetControl(L"dw_goods");
- dw_goods.openUrl(GetServerUrl(), L"/sale/view/SupplierV3/template/supplier/supplieritem");
-
- if (publiccode::GetUser().name != L"admin")
- {
- xstring s = publiccode::GetUser().id;
-
- xml supplier_x = ViewObject::RetrieveData(GetServerUrl(), L"/sale/data/SupplierV3/entity/FindBySaleType", L"id", s);
- if (supplier_x)
- {
- TypeWork = supplier_x.text();
-
- if (TypeWork.find(L"采购") >= 0)
+ if (start)
{
-
- dw_list.SetColumnState(L"DateEx", false);
- dw_list.SetColumnState(L"DateExS", false);
- dw_list.SetColumnState(L"Name", false);
- dw_list.SetColumnState(L"ProvinceCode", false);
- dw_list.SetColumnState(L"City", false);
- dw_list.SetColumnState(L"District", false);
- dw_list.SetColumnState(L"Address", false);
- dw_list.SetColumnState(L"CName", false);
- dw_list.SetColumnState(L"TEL", false);
- dw_list.SetColumnState(L"Mob", false);
- dw_list.SetColumnState(L"AreaCode", false);
- dw_list.SetColumnState(L"Fax", false);
- dw_goods.SetColumnState(L"Price", false);
- dw_goods.SetColumnState(L"PackRMBPrice", false);
- dw_goods.SetColumnState(L"PartRMBPrice", false);
- dw_goods.SetColumnState(L"PaperRMBPrice", false);
- dw_goods.SetColumnState(L"ETD", false);
- dw_goods.SetColumnState(L"InvoiceNo", false);
-
+ dw_2.Retrieve(x);
+ dw_2.Redraw();
+ bstart = false;
+ }
+ else
+ {
+ xml x1 ;
+
+ dw_2.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);
+ KXMLDOMElement fe = x1.createElement(L"FilterColumn");
+ fe.settext(filterStr);
+ e.appendChild(fe);
+ }
+ dw_2.Retrieve(x1);
+ }
+ else
+ {
+ dw_2.Retrieve(x);
+ }
+ dw_2.Filter(L"FilterColumn", filterStr);
+ dw_2.Redraw();
}
}
-
+ return 1;
}
- return 1;
- }
+ int OnRetrieve()
+ {
+ HCURSOR hCursor = xutil::SetCursorWait();
+ xml x ;
+
+ xaserverarg arg;
+
+ arg.AddArg(L"QueryTxt", xcontrol(GetControl(L"sle_search")).GetText());
- int onloaded()
- {
- AttachEvent(L"dw_list", L"DWV_ROWFOCUSCHANGED", (FEvent)&listSupplierv3::OnRowChangedEx);
+ xcombobox cbx_type = GetControl(L"cbx_ship");
+ int h = cbx_type.GetCurSel();
+ if (h < 0) return 1;
+ xstring str = (string)cbx_type.GetItemData(h);
+ arg.AddArg(L"ShipDays", str);
- listwin::onloaded();
- xstring EntityID;
- int row = dw_list.GetRow();
- if (row<0 || row>dw_list.GetRowCount()) return 1;
- KXMLDOMElement ele = dw_list.GetRowElement(row);
- xstring id = listwin::m_configDoc.selectSingleNode(L"//entity/EntityID[1]").text();
- if (ele.selectSingleNode(id))
- EntityID = ele.selectSingleNode(id).text();
- listwin::SetAgent(L"list", EntityID);
- return 1;
- }
+ if (getUrl(L"/sale/data/AP/list101", arg.GetString(), x) != 1)
+ {
+ trace(x.text());
+ xutil::RestoreCursor(hCursor);
+ return -1;
+ }
+ else
+ {
+
+ dw_1.Retrieve(x);
+ dw_1.Redraw();
+ }
+ bstart = true;
+ xutil::RestoreCursor(hCursor);
+ return 1;
+ }
-};
\ No newline at end of file
+ int OnFilter()
+ {
+ xstring str = xcontrol(GetControl(L"sle_filter")).GetText();
+ if (str != searchStr)
+ {
+ searchStr = str;
+ dw_1.Filter(L"*", searchStr);
+
+ if (dw_1.GetRowCount() > 0)
+ {
+ OnPrepayRetrieve(1, bstart);
+ dw_2.Redraw();
+ }
+ return 1;
+ }
+ return 1;
+ }
+
+ int onload()
+ {
+ m_layer = GetControl(L"tab_1");
+ dw_1 = GetControl(L"dw_1");
+ dw_1.openUrl(L"/sale/view/AP/template/ImportList100");
+ dw_1.SetAskStyle(true);
+
+ dw_1.SetColumnState(L"VATNo", false);
+ dw_1.SetColumnState(L"APAmount", false);
+ dw_1.SetColumnState(L"PrePayAmount", false);
+ dw_1.SetColumnState(L"PrePayBalance", false);
+ dw_1.SetColumnState(L"VATDate", false);
+ dw_1.SetColumnState(L"InvoiceNo", false);
+ dw_1.SetColumnState(L"SupplierID", false);
+
+ dw_2 = GetControl(L"dw_2");
+ dw_2.openUrl(L"/sale/view/AP/template/ImportList2");
+ dw_2.SetColumnState(L"Balance", false);
+ dw_2.SetColumnState(L"DisAmountCurrent", false);
+ dw_2.SetColumnState(L"DisAmount", false);
+
+ dw_101 = GetControl(L"dw_101");
+ dw_101.openUrl(L"/sale/view/AP/template/AP/List1");
+ dw_102 = GetControl(L"dw_102");
+ dw_102.openUrl(L"/sale/view/AP/template/AP/List1");
+
+ dw_3 = GetControl(L"dw_3");
+ dw_3.openUrl(L"/sale/view/AP/template/ImportList3");
+ dw_4 = GetControl(L"dw_4");
+ dw_4.openUrl(L"/sale/view/AP/template/ImportList4");
+
+ dw_5 = GetControl(L"dw_5");
+ dw_5.openUrl(L"/sale/view/AP/template/ImportList5");
+ dw_6 = GetControl(L"dw_6");
+ dw_6.openUrl(L"/sale/view/AP/template/ImportList6");
+
+ OnAttachEvent();
+ searchStr = L"";
+ bstart = true;
+
+ return 1;
+ }
+
+ int onloaded()
+ {
+ return 1;
+ }
+ };
--
Gitblit v1.9.3