From ca7bfcdac21b765d29d0045308d434dfd038b10c Mon Sep 17 00:00:00 2001 From: xj qian <qianxj15@sina.com> Date: 星期三, 04 九月 2024 16:16:56 +0800 Subject: [PATCH] update jarch --- 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