From 9e409d6e1e2cb1d35cf26f3fd2bd9048c624280f Mon Sep 17 00:00:00 2001
From: LiFan <2308045698@qq.com>
Date: 星期五, 05 七月 2024 11:29:43 +0800
Subject: [PATCH] update AP
---
jrj/project/business/AP/APBank.cpp | 603 ---
jrj/project/business/AP/APNew3.warizd.cpp | 1100 ++++---
jrj/project/business/AP/maint.ap.cpp | 772 +---
jrj/project/business/VATNotify/list.vatnotify.cpp | 811 ++---
jrj/project/business/VATNotify/maint.papercard.vatnotify.cpp | 1261 +++++---
jrj/project/business/VATNotify/simple.maint.vatnotify.cpp | 1351 +++++---
jrj/project/business/VATNotify/VATNotifyParse.cpp | 616 ---
jrj/project/business/VATNotify/update.vatnotify.cpp | 818 ++---
jrj/project/business/AP/Select.AP.cpp | 627 ---
jrj/project/business/AP/list.ap.cpp | 946 +++---
10 files changed, 3,907 insertions(+), 4,998 deletions(-)
diff --git a/jrj/project/business/AP/APBank.cpp b/jrj/project/business/AP/APBank.cpp
index 6c3d5bb..496b944 100644
--- a/jrj/project/business/AP/APBank.cpp
+++ b/jrj/project/business/AP/APBank.cpp
@@ -6,537 +6,126 @@
#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) APListBankMaint : public xframe
{
- listSupplierv3* pWin = new listSupplierv3(implPtr, (HWND)hWnd);
- return pWin;
- }
- int OnRetrieve()
- {
- xml x;
+ public:
+ xdwtable dw_base;
- 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)
+ xnode m_agentNode; //Agent Condition
+
+ public:
+ APListBankMaint(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+ public:
+ static APListBankMaint* CreateInstance(void* implPtr, void* hWnd)
{
- return -1;
+ APListBankMaint* pWin = new APListBankMaint(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());
- }
- //trace(x.GetXml());
- listwin::dw_list.Retrieve(x);
- listwin::dw_list.Redraw();
- listwin::dw_list.SetReadOnly(true);
- }
-
- 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")
- {
- //trace(L"sd");
- xdwpages zz = GetControl(L"pages");
- int h = zz.SetCurPage(1);
- //trace(h);
- OnRetrieve();
- }
- return 1;
- }
-
- //树选择
- int OnTreeSelChanged(TEvent evt, LPARAM p)
- {
- if (changeddlb != 1)
- {
- //alert(L"1");
-
- HTREEITEM h = tv_1.GetSelectedItem();
- KXMLDOMElement& e = *(KXMLDOMElement*)tv_1.GetItemData(h);
-
- 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++)
- {
-
- 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);
- }
- 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;
- }
- else
- {
- KXMLDOMNodeList nlist = x.selectNodes(L"root/item");
- int len = nlist.length();
- if (len > 0)
- {
- int i;
- for (i = 0; i < len; i++)
+ KXMLDOMElement xframeElement = GetElement();
+ KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*");
+ if (agent)
{
-
- 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);
+ xstring s = agent.xml();
+ m_agentNode = SetAgentNode(anode, s);
}
- tv_1.ExpandItem(0);
}
+ return 1;
}
- return 1;
- }
+ //焦点激活处理函数
+ int OnSetFocus(TEvent* evt, LPARAM param)
+ {
+ //重置工具条
+ SetAgent();
+ return 1;
+ }
- //xcombobox下拉
- int OnSelectDdlb(TEvent evt, LPARAM p)
- {
- changeddlb = 1;
+ //命令发布函数
+ int OnCmdDispatch(xstring comdid)
+ {
+ if (comdid == L"xmCancel")
+ {
+ CloseWindow();
+ return 1;
+ }
+ if (comdid == L"xmOK")
+ {
+ xaserverarg arg = GetArg();
+ dw_base.AcceptText();
+ arg.AddArg(L"PayedTerm", dw_base.GetItemString(1, L"PayedTerm"));
+ arg.AddArg(L"PayedBank", dw_base.GetItemString(1, L"PayedBank"));
+ arg.AddArg(L"PayedBankNo", dw_base.GetItemString(1, L"PayedBankNo"));
+ arg.AddArg(L"result", L"ok");
+ CloseWindow();
+ return 1;
+ }
+ return 0;
+ }
- 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 OnXCommand(TEvent* evt, LPARAM param)
+ {
+ return OnCmdDispatch(evt->xcommand.pStrID);
+ }
- 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);
+ int OnAttachEvent()
+ {
+ //绑定工具条点击事件
+ AttachEvent(L"WM_XCOMMAND", (FEvent)&APListBankMaint::OnXCommand);
+ //获取焦点事件,用于重置工具条
+ AttachEvent(L"WM_SETFOCUS", (FEvent)&APListBankMaint::OnSetFocus);
+ }
+
+ /*
+ int OnRetrieve()
+ {
+ xml x ;
+
+ xaserverarg ;
+
+ arg.AddArg(L"xxx",L"xxx");
+ if (getUrl(L"",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());
- }
- 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"");
+ //dw_list.Retrieve(x);
+ //dw_list.Redraw();
}
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);
+ int onload()
+ {
+ dw_base = GetControl(L"dw_base");
+ dw_base.openUrl(L"/sale/view/AP/template/PayBank");
+
+ dw_base.SetColHeaderHeight(0);
+ dw_base.SetRowSelectorWidth(0);
+ dw_base.SetHScrollState(false);
+ dw_base.SetVScrollState(false);
+
+ OnAttachEvent();
+
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);
+ int onloaded()
+ {
+ SetAgent();
+
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)
- {
-
- 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);
-
- }
- }
-
- }
-
- return 1;
- }
-
- int onloaded()
- {
- AttachEvent(L"dw_list", L"DWV_ROWFOCUSCHANGED", (FEvent)&listSupplierv3::OnRowChangedEx);
-
- 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;
- }
-
-};
\ No newline at end of file
+ };
diff --git a/jrj/project/business/AP/APNew3.warizd.cpp b/jrj/project/business/AP/APNew3.warizd.cpp
index 6c3d5bb..3858b6e 100644
--- a/jrj/project/business/AP/APNew3.warizd.cpp
+++ b/jrj/project/business/AP/APNew3.warizd.cpp
@@ -6,537 +6,661 @@
#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", (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 = win32::GetLocalDate();
+ 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)
+ {
+ 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(L"/sale/data/AP/list/invoice/supplier", L"InvoiceNo", dw_1.GetItemString(row, L"InvoiceNo"),
+ "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.cssstyle = 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.text = filterStr;
+ e.appendChild(fe);
+ fe.Release();
+ e.Release();
+ }
+ docElement.Release();
+ lst.Release();
+ 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", 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 = xcombobox::GetCurSel(cbx_type.GetId());
+ if (h < 0) return 1;
+ xstring str = xcombobox::GetItemData(cbx_type.GetId());
+ arg.AddArg(L"ShipDays", str);
+ trace(str);
+ 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;
+ }
- 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;
- }
+ int OnFilter()
+ {
+ xstring str = GetControl(L"sle_filter").GetText();
+ if (str != searchStr)
+ {
+ searchStr = str;
+ dw_1.Filter(L"*", searchStr);
-};
\ No newline at end of file
+ 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;
+ }
+ };
diff --git a/jrj/project/business/AP/Select.AP.cpp b/jrj/project/business/AP/Select.AP.cpp
index 6c3d5bb..5ed3e2f 100644
--- a/jrj/project/business/AP/Select.AP.cpp
+++ b/jrj/project/business/AP/Select.AP.cpp
@@ -6,537 +6,130 @@
#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) APSelectDlg : public xframe
{
- listSupplierv3* pWin = new listSupplierv3(implPtr, (HWND)hWnd);
- return pWin;
- }
- int OnRetrieve()
- {
- xml x;
+ public:
+ xdwgrid dw_list;
+ xcontrol query;
- 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)
+ xnode m_agentNode; //Agent Condition
+
+ public:
+ APSelectDlg(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+ public:
+ static APSelectDlg* CreateInstance(void* implPtr, void* hWnd)
{
- return -1;
+ APSelectDlg* pWin = new APSelectDlg(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);
+ 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;
+ }
+
+ //焦点激活处理函数
+ int OnSetFocus(TEvent* evt, LPARAM param)
+ {
+ //重置工具条
+ SetAgent();
+ return 1;
+ }
+ int onOk()
+ {
+ xaserverarg arg = GetArg();
+ arg.AddArg(L"items", L"");
+ KXMLDOMElement ele = dw_list.GetRowElement(dw_list.GetRow());
+ arg.AddArg(L"items", L"<data>" + xstring(ele.xml()) + L"</data>");
+ CloseWindow();
+ return 1;
+ }
+ //命令发布函数
+ int OnCmdDispatch(xstring comdid)
+ {
+ if (comdid == L"xmCancel")
+ {
+ CloseWindow();
+ return 1;
+ }
+ else if (comdid == L"xmQuery")
+ {
+ RetrieveData();
+ return 1;
+ }
+ else if (comdid == L"xmOk")
+ {
+ onOk();
+ return 1;
+ }
+ return 0;
+ }
+
+ //命令处理事件
+ int OnXCommand(TEvent* evt, LPARAM param)
+ {
+ return OnCmdDispatch(evt->xcommand.pStrID);
+ }
+
+ int OnAttachEvent()
+ {
+ //绑定工具条点击事件
+ AttachEvent(L"WM_XCOMMAND", (FEvent)&APSelectDlg::OnXCommand);
+ //获取焦点事件,用于重置工具条
+ AttachEvent(L"WM_SETFOCUS", (FEvent)&APSelectDlg::OnSetFocus);
+ AttachEvent(L"dw_list", L"DWV_DOUBLECLICKED", (FEvent)&APSelectDlg::onOk);
+ }
+
+ int RetrieveData()
+ {
+ xstring keyword = query.GetText();
+ trace(keyword);
+ xml x = ViewObject::RetrieveData(L"/sale/data/PurchaseOrder/po/searchadvance", L"PONo", keyword);
+ if (x)
+ 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"))
- {
-
- xstring s = e.selectSingleNode(L"@TotalPage").text(); //总数量
- listwin::dw_pages.SetMaxPage(s.toInt());
- }
- //trace(x.GetXml());
- listwin::dw_list.Retrieve(x);
- listwin::dw_list.Redraw();
- listwin::dw_list.SetReadOnly(true);
- }
-
- 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")
- {
- //trace(L"sd");
- xdwpages zz = GetControl(L"pages");
- int h = zz.SetCurPage(1);
- //trace(h);
- OnRetrieve();
- }
- return 1;
- }
-
- //树选择
- int OnTreeSelChanged(TEvent evt, LPARAM p)
- {
- if (changeddlb != 1)
- {
- //alert(L"1");
-
- HTREEITEM h = tv_1.GetSelectedItem();
- KXMLDOMElement& e = *(KXMLDOMElement*)tv_1.GetItemData(h);
-
- 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++)
- {
-
- 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);
- }
- 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;
- }
- else
- {
- KXMLDOMNodeList nlist = x.selectNodes(L"root/item");
- int len = nlist.length();
- if (len > 0)
- {
- int i;
- 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);
- }
- tv_1.ExpandItem(0);
- }
- }
-
- return 1;
- }
-
- //xcombobox下拉
- int OnSelectDdlb(TEvent evt, LPARAM p)
- {
- changeddlb = 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 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);
- 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")
- {
- alert(msg.selectSingleNode(L"@errInfo").text());
- }
- 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")
+
+ int onload()
{
- 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)
+ dw_list = GetControl(L"dw_list");
+ dw_list.openUrl(L"/sale/view/PurchaseOrder/template/purchaseorder/POAdvance");
+ OnAttachEvent();
+ dw_list.SetColumnState(L"POID", false);
+ dw_list.SetColumnState(L"PartyID", false);
+ xaserverarg arg = GetArg();
+ xstring PONo;
+ if (arg)
{
- TypeWork = supplier_x.text();
-
- if (TypeWork.find(L"采购") >= 0)
- {
-
- 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);
-
- }
+ PONo = arg.GetArgString(L"PONo");
}
-
+ query = GetControl(L"sle_search");
+ query.SetText(PONo);
+ RetrieveData();
+ return 1;
}
- return 1;
- }
+ int onloaded()
+ {
+ SetAgent();
- int onloaded()
- {
- AttachEvent(L"dw_list", L"DWV_ROWFOCUSCHANGED", (FEvent)&listSupplierv3::OnRowChangedEx);
-
- 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;
- }
-
-};
\ No newline at end of file
+ return 1;
+ }
+ };
diff --git a/jrj/project/business/AP/list.ap.cpp b/jrj/project/business/AP/list.ap.cpp
index 6c3d5bb..3d185f7 100644
--- a/jrj/project/business/AP/list.ap.cpp
+++ b/jrj/project/business/AP/list.ap.cpp
@@ -6,537 +6,509 @@
#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) ListAP : public xframe
{
- listSupplierv3* pWin = new listSupplierv3(implPtr, (HWND)hWnd);
- return pWin;
- }
- int OnRetrieve()
- {
- xml x;
+ public:
+ xstring apType;
+ xstring DatePicker;
+ xstring DatePickerOne;
+ xdwgrid dw_list;
+ xdwtable dw_arg;
+ xnode m_agentNode; //Agent Condition
- 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:
+ ListAP(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+ public:
+ static ListAP* CreateInstance(void* implPtr, void* hWnd)
{
- return -1;
+ ListAP* pWin = new ListAP(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());
- }
- //trace(x.GetXml());
- listwin::dw_list.Retrieve(x);
- listwin::dw_list.Redraw();
- listwin::dw_list.SetReadOnly(true);
- }
-
- 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")
- {
- //trace(L"sd");
- xdwpages zz = GetControl(L"pages");
- int h = zz.SetCurPage(1);
- //trace(h);
- OnRetrieve();
- }
- return 1;
- }
-
- //树选择
- int OnTreeSelChanged(TEvent evt, LPARAM p)
- {
- if (changeddlb != 1)
- {
- //alert(L"1");
-
- HTREEITEM h = tv_1.GetSelectedItem();
- KXMLDOMElement& e = *(KXMLDOMElement*)tv_1.GetItemData(h);
-
- 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++)
- {
-
- 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);
- }
- 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;
- }
- else
- {
- KXMLDOMNodeList nlist = x.selectNodes(L"root/item");
- int len = nlist.length();
- if (len > 0)
- {
- int i;
- for (i = 0; i < len; i++)
+ KXMLDOMElement xframeElement = GetElement();
+ KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*");
+ if (agent)
{
-
- 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);
+ xstring s = agent.xml();
+ m_agentNode = SetAgentNode(anode, s);
}
- tv_1.ExpandItem(0);
}
+ return 1;
}
- return 1;
- }
-
- //xcombobox下拉
- int OnSelectDdlb(TEvent evt, LPARAM p)
- {
- changeddlb = 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 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);
- 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)
+ //焦点激活处理函数
+ int OnSetFocus(TEvent* evt, LPARAM param)
{
- xstring error = x.text();
- trace(error);
+ //重置工具条
+ SetAgent();
+ return 1;
}
- else
+
+ xstring GetPayType()
{
- KXMLDOMElement msg = x.selectNodes(L"process").item(0);
- xstring success = msg.selectSingleNode(L"@finished").text();
- if (success == L"0")
+ xcombobox cbx_type = GetControl(L"cbx_type");
+ int h = xcombobox::GetCurSel(cbx_type.GetId());
+ if (h < 0) return "";
+ return xcombobox::GetLBText(cbx_type.GetId(), h);
+ }
+
+ xstring GetEntityName(int pr)
+ {
+ return L"AP3";
+ }
+
+ xstring GetEntityIDName(int /*param*/ pr)
+ {
+ return L"APID";
+ }
+
+ xstring GetEntityID(int /*param*/ pr)
+ {
+ return dw_list.GetItemString(dw_list.GetRow(), L"APID");
+ }
+
+ int ViewUpdate(int pr, xstring updateItem, xaserverarg arg)
+ {
+ if (updateItem == L"del")
{
- alert(msg.selectSingleNode(L"@errInfo").text());
+ int DelRow = dw_list.GetRow();
+ dw_list.DeleteRow(DelRow);
+ return 1;
}
- else
+ return 1;
+ }
+
+ int OnBank()
+ {
+ xaserverarg arg;
+
+ OpenWindow(L"dev:xpage[APBank.vx]", arg);
+ if (arg.GetArgString(L"result") == L"ok")
{
- MessageBoxW(GetHWND(), L"删除成功!", L"提示", 0);
- listwin::dw_list.DeleteRow(row);
+ int ll_row = dw_list.GetNextSelectRow(1);
+ dw_list.AcceptText();
+
+ while (ll_row > 0 && ll_row <= dw_list.GetRowCount())
+ {
+ dw_list.SetItemString(ll_row, L"PayedTerm", arg.GetArgString(L"PayedTerm"));
+ dw_list.SetItemString(ll_row, L"PayedBank", arg.GetArgString(L"PayedBank"));
+ dw_list.SetItemString(ll_row, L"PayedBankNo", arg.GetArgString(L"PayedBankNo"));
+ ll_row = dw_list.GetNextSelectRow(ll_row + 1);
+ }
+ dw_list.Redraw();
+ return 1;
}
+ else return 1;
}
- 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")
+ //命令发布函数
+ int OnCmdDispatch(xstring comdid)
{
-
- if (TypeWork.find(L"采购") >= 0)
+ if (comdid == L"xmBank") return OnBank();
+ if (comdid == L"xmSave") return OnSave();
+ if (comdid == L"xmAnalysis") return OnAnalysis();
+ if (comdid == L"xmRefresh" || comdid == L"xmSearch")
{
- GoodsUrl = L"/sale/data/SupplierV3/entity/supplieritemEx";
+ xstring payTypeOne = GetPayType();
+ if (payTypeOne == L"已付货款" || payTypeOne == L"待付货款")
+ {
+ return OnRetrieveEx(apType, DatePicker);
+ }
+ else if (payTypeOne == L"预付货款")
+ {
+ apType = L"001";
+ return OnRetrieveEx(apType, DatePicker);
+ }
+ else if (payTypeOne == L"预付货款(已冲)L")
+ {
+ apType = L"001";
+ return OnRetrieveEx1(apType, DatePickerOne);
+ }
+
}
- else
+ if (comdid == L"xmAddRow")
{
- GoodsUrl = L"/sale/data/SupplierV3/entity/supplieritem";
+ xstring payType = GetPayType();
+ if (payType == L"已付货款" || payType == L"待付货款")
+ OpenWindow(L"dev:xpage[APNew3.warizd.vx]");
+ else if (payType == L"预付货款" || payType == L"预付货款(已冲)L")
+ {
+ xaserverarg arg1;
+
+ arg1.AddArg(L"APType", apType);
+
+ OpenWindow(L"dev:xpage[maint.ap.vx]", arg1);
+ }
+ return 1;
}
- }
- 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")
+ if (comdid == L"xmSaveAs")
{
dw_list.SaveAs(L"");
+ return 1;
+ }
+ if (comdid == L"xmModifyRow")
+ {
+
+ int row = dw_list.GetRow();
+ if (row < 1) return 1;
+ KXMLDOMElement ele = dw_list.GetRowElement(row);
+ xstring APID = ele.selectSingleNode(L"APID").text();
+ ele.Release();
+ xaserverarg arg;
+
+ arg.AddArg(L"APID", APID);
+ arg.AddArg(L"APType", apType);
+
+ OpenWindow(L"dev:xpage[maint.ap.vx]", pa);
+ return 1;
+ }
+ if (comdid.find(L"action:", 0) >= 0)
+ {
+ xstring payType1 = GetPayType();
+ if (payType1 == L"已付货款" || payType1 == L"预付货款") ProcessFlowAction(comdid, 1);
+ }
+ return 0;
+ }
+
+ int OnDoubleClicked(TEvent* evt, LPARAM p)
+ {
+ return OnCmdDispatch(L"xmModifyRow");
+ }
+
+ int OnCombboChanged(TEvent* evt, int lParam)
+ {
+ xstring id = L"";
+ xstring name = L"";
+ int h = xcombobox::GetCurSel(evt.hCtrl);
+ if (h > -1)
+ {
+ xstring txt = xcombobox::GetLBText(evt.hCtrl, h);
+ apType = L"---";
+ if (txt == L"已付货款")
+ {
+ dw_list.openUrl(L"/sale/view/AP/template/AP/list1");
+ apType = L"000";
+ OnRetrieveEx(apType, DatePicker);
+ }
+ else if (txt == L"待付货款")
+ {
+ dw_list.openUrl(L"/sale/view/AP/template/AP/list2");
+ OnRetrieveEx(apType, DatePicker);
+ }
+ else if (txt == L"预付货款")
+ {
+ dw_list.openUrl(L"/sale/view/AP/template/AP/list3");
+ apType = L"001";
+ OnRetrieveEx(apType, DatePicker);
+ }
+ else if (txt == L"预付货款(已冲)L")
+ {
+ dw_list.openUrl(L"/sale/view/AP/template/AP/list3");
+ apType = L"001";
+ OnRetrieveEx1(apType, DatePickerOne);
+ }
+
+ dw_list.SetColumnState(L"APID", false);
+
}
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;
+ //命令处理事件
+ int OnXCommand(TEvent* evt, LPARAM param)
+ {
+ return OnCmdDispatch(evt->xcommand.pStrID);
}
- if (comdid == L"action:bill.AnnexEx")
+
+ int OnItemChanged(TEvent* evt, LPARAM p)
{
- 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)
+ //if(datareading) return 0;
+ HCURSOR HCursor = xutil::SetCursorWait();
+ DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
+ int row = hdr.row;
+ xstring col = hdr.colname;
+ xstring data = hdr.data;
+ xstring ETD = L"";
+ if (col == L"InvoiceNo")
{
- TypeWork = supplier_x.text();
-
- if (TypeWork.find(L"采购") >= 0)
+ if (dw_list.GetItemString(row, L"InvoiceNo") != L"")
{
+ xml x12 = ViewObject::RetrieveData(L"/sale/data/AP/GetInvoiceNoEx", L"InvoiceNo", dw_list.GetItemString(row, L"InvoiceNo"));
+ if (x12)
+ {
+ xstring COUNT = x12.text();
+ if (COUNT != L"")
+ {
+ alert(COUNT);
+ dw_list.SetItemString(row, L"InvoiceNo", L"");
+ dw_list.SetItemString(row, L"NotifyInvoiceNo", L"");
+ dw_list.SetItemString(row, L"GDNDate", L"");
+ dw_list.Redraw();
+ return 1;
+ }
+ }
- 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);
+ xml x11 = ViewObject::RetrieveData(L"/sale/data/AP/GetInvoiceNo", L"InvoiceNo", dw_list.GetItemString(row, L"InvoiceNo"));
+ if (x11)
+ {
+ ETD = x11.text();
+ }
+ dw_list.SetItemString(row, L"NotifyInvoiceNo", dw_list.GetItemString(row, L"InvoiceNo"));
+ dw_list.SetItemString(row, L"GDNDate", ETD);
+ dw_list.Redraw();
+ return 1;
+ }
+ else
+ {
+ dw_list.SetItemString(row, L"NotifyInvoiceNo", L"");
+ dw_list.SetItemString(row, L"GDNDate", L"");
+ dw_list.Redraw();
}
}
+ return 1;
}
- return 1;
- }
+ int OnAttachEvent()
+ {
+ //绑定工具条点击事件
+ AttachEvent(L"WM_XCOMMAND", (FEvent)&ListAP::OnXCommand);
+ //获取焦点事件,用于重置工具条
+ AttachEvent(L"WM_SETFOCUS", (FEvent)&ListAP::OnSetFocus);
+ AttachEvent(L"cbx_type", L"CBN_SELCHANGE", (FEvent)&ListAP::OnCombboChanged);//属性组切换list中列的数量变化
+ AttachEvent(L"dw_list", L"DWV_DOUBLECLICKED", (FEvent)&ListAP::OnDoubleClicked);//行双击
+ AttachEvent(L"cbx_state", L"CBN_SELCHANGE", (FEvent)&ListAP::OnDatePicker);
+ AttachEvent(L"dw_list", L"DWV_ITEMCHANGED", (FEvent)&ListAP::OnItemChanged);
+ }
- int onloaded()
- {
- AttachEvent(L"dw_list", L"DWV_ROWFOCUSCHANGED", (FEvent)&listSupplierv3::OnRowChangedEx);
+ int OnDatePicker(TEvent* evt, int lParam)
+ {
+ xstring payTypeTwo = GetPayType();
+ if (payTypeTwo == L"已付货款" || payTypeTwo == L"待付货款")
+ {
+ int h = xcombobox::GetCurSel(evt.hCtrl);
+ if (h > -1)
+ {
+ xstring txt = xcombobox::GetLBText(evt.hCtrl, h);
+ if (txt == L"出运日期")
+ {
+ apType = L"000";
+ DatePicker = L"GDNDate";
+ OnRetrieveEx(apType, DatePicker);
+ }
+ else if (txt == L"请款日期")
+ {
+ apType = L"000";
+ DatePicker = L"APDate";
+ OnRetrieveEx(apType, DatePicker);
+ }
+ else if (txt == L"付款日期")
+ {
+ apType = L"000";
+ DatePicker = L"PayedDate";
+ OnRetrieveEx(apType, DatePicker);
+ }
+ }
+ }
+ else if (payTypeTwo == L"预付货款")
+ {
+ int h1 = xcombobox::GetCurSel(evt.hCtrl);
+ if (h1 > -1)
+ {
+ xstring txt1 = xcombobox::GetLBText(evt.hCtrl, h1);
+ if (txt1 == L"出运日期")
+ {
+ apType = L"001";
+ DatePicker = L"GDNDate";
+ OnRetrieveEx(apType, DatePicker);
+ }
+ else if (txt1 == L"请款日期")
+ {
+ apType = L"001";
+ DatePicker = L"APDate";
+ OnRetrieveEx(apType, DatePicker);
+ }
+ else if (txt1 == L"付款日期")
+ {
+ apType = L"001";
+ DatePicker = L"PayedDate";
+ OnRetrieveEx(apType, DatePicker);
+ }
+ }
+ }
+ else if (payTypeTwo == L"预付货款(已冲)L")
+ {
+ int h2 = xcombobox::GetCurSel(evt.hCtrl);
+ if (h2 > -1)
+ {
+ xstring txt2 = xcombobox::GetLBText(evt.hCtrl, h2);
+ if (txt2 == L"出运日期")
+ {
+ apType = L"001";
+ DatePickerOne = L"GDNDate";
+ OnRetrieveEx1(apType, DatePickerOne);
+ }
+ else if (txt2 == L"请款日期")
+ {
+ apType = L"001";
+ DatePickerOne = L"APDate";
+ OnRetrieveEx1(apType, DatePickerOne);
+ }
+ else if (txt2 == L"付款日期")
+ {
+ apType = L"001";
+ DatePickerOne = L"PayedDate";
+ OnRetrieveEx1(apType, DatePickerOne);
+ }
+ }
+ }
+ return 1;
+ }
- 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;
- }
+ int OnSave()
+ {
+ xml x ;
+
+ dw_list.DwUpdateAllToEx(x);
+ xaserverarg arg;
+
+ arg.AddArg(L"content", x.xml());
+ //trace(x.xml);
+ if (xurl::get(L"/sale/data/AP/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_list.ResetUpdateStatus();
+ alert(L"保存成功!");
+ }
+ else
+ {
+ alert(L"保存失败!");
+ }
+ return 1;
+ }
-};
\ No newline at end of file
+ int OnRetrieveEx1(xstring APType, xstring DatePickerOne)
+ {
+ xml x ;
+
+ xaserverarg arg;
+
+ arg.AddArg(L"QueryTxt", GetControl(L"sle_search").GetText());
+ arg.AddArg(L"APType", APType);
+ arg.AddArg(L"QueryArg", GetQueryArg());
+ arg.AddArg(L"DatePicker", DatePickerOne);
+
+ trace(GetQueryArg());
+ if (getUrl(L"/sale/data/AP/list9", arg.GetString(), x) != 1)
+ {
+ trace(x.text());
+ return -1;
+ }
+ else
+ {
+ dw_list.Retrieve(x);
+ dw_list.Redraw();
+ dw_list.SetReadOnly(true);
+ dw_list.SetSelectionMode(1);
+ }
+ return 1;
+ }
+
+ xstring GetQueryArg()
+ {
+ dw_arg.AcceptText();
+ xml x ;
+
+ dw_arg.DwUpdateAllTo(x);
+
+ return x.xml();
+ }
+
+ int OnRetrieveEx(xstring APType, xstring DatePicker)
+ {
+ xml x ;
+
+ xaserverarg arg;
+
+ arg.AddArg(L"QueryTxt", GetControl(L"sle_search").GetText());
+ arg.AddArg(L"APType", APType);
+ arg.AddArg(L"QueryArg", GetQueryArg());
+ arg.AddArg(L"DatePicker", DatePicker);
+
+ trace(GetQueryArg());
+ if (getUrl(L"/sale/data/AP/list", arg.GetString(), x) != 1)
+ {
+ trace(x.text());
+ return -1;
+ }
+ else
+ {
+ //trace(L"xml=L"+x.xml);
+ dw_list.Retrieve(x);
+ dw_list.Redraw();
+ //dw_list.SetReadOnly(true);
+ dw_list.SetSelectionMode(1);
+ }
+ return 1;
+ }
+
+ int OnAnalysis()
+ {
+ HCURSOR hCursor = xutil::SetCursorWait();
+ xstring str = dw_list.DataAnalysis(L"");
+ xaserverarg arg;
+
+ arg.AddArg(L"html", str);
+ int obj = cast(dw_list as int);
+ arg.AddArg(L"obj", obj.toString());
+ OpenWindow(L"dev:xpage[data.vanalysis.vx]", arg);
+ xutil::RestoreCursor(hCursor);
+ return 1;
+ }
+
+ int onload()
+ {
+ dw_list = GetControl(L"dw_list");
+ dw_list.openUrl(L"/sale/view/AP/template/AP/list1");
+ dw_list.SetColumnState(L"APID", false);
+ dw_list.SetColumnState(L"SupplierID", false);
+ dw_list.SetColumnState(L"VATNo", false);
+
+ dw_arg = GetControl(L"dw_arg");
+ dw_arg.openUrl(L"/sale/view/AR/template/queryarg");
+ dw_arg.SetColHeaderHeight(0);
+ dw_arg.SetRowSelectorWidth(0);
+ dw_arg.SetHScrollState(false);
+ dw_arg.SetVScrollState(false);
+ dw_arg.SetItemString(1, L"DateType", L"本月");
+
+ OnAttachEvent();
+ apType = L"000";
+ OnRetrieveEx(apType, DatePicker);
+
+ return 1;
+ }
+
+ int onloaded()
+ {
+ SetAgent();
+
+ return 1;
+ }
+ };
diff --git a/jrj/project/business/AP/maint.ap.cpp b/jrj/project/business/AP/maint.ap.cpp
index 6c3d5bb..02e4f58 100644
--- a/jrj/project/business/AP/maint.ap.cpp
+++ b/jrj/project/business/AP/maint.ap.cpp
@@ -6,537 +6,299 @@
#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) MaintAP : public xframe
{
- listSupplierv3* pWin = new listSupplierv3(implPtr, (HWND)hWnd);
- return pWin;
- }
- int OnRetrieve()
- {
- xml x;
-
- 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:
+ xstring APID;
+ xstring APType;
+ xdwtable dw_base;
+ xnode m_agentNode; //Agent Condition
+ int hObject = 0;
+ public:
+ MaintAP(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+ public:
+ static MaintAP* CreateInstance(void* implPtr, void* hWnd)
{
- return -1;
+ MaintAP* pWin = new MaintAP(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());
- }
- //trace(x.GetXml());
- listwin::dw_list.Retrieve(x);
- listwin::dw_list.Redraw();
- listwin::dw_list.SetReadOnly(true);
- }
-
- 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")
- {
- //trace(L"sd");
- xdwpages zz = GetControl(L"pages");
- int h = zz.SetCurPage(1);
- //trace(h);
- OnRetrieve();
- }
- return 1;
- }
-
- //树选择
- int OnTreeSelChanged(TEvent evt, LPARAM p)
- {
- if (changeddlb != 1)
- {
- //alert(L"1");
-
- HTREEITEM h = tv_1.GetSelectedItem();
- KXMLDOMElement& e = *(KXMLDOMElement*)tv_1.GetItemData(h);
-
- 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++)
- {
-
- 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);
- }
- 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;
- }
- else
- {
- KXMLDOMNodeList nlist = x.selectNodes(L"root/item");
- int len = nlist.length();
- if (len > 0)
- {
- int i;
- for (i = 0; i < len; i++)
+ KXMLDOMElement xframeElement = GetElement();
+ KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*");
+ if (agent)
{
-
- 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);
+ xstring s = agent.xml();
+ m_agentNode = SetAgentNode(anode, s);
}
- tv_1.ExpandItem(0);
}
+ return 1;
}
- return 1;
- }
+ //焦点激活处理函数
+ int OnSetFocus(TEvent* evt, LPARAM param)
+ {
+ //重置工具条
+ SetAgent();
+ return 1;
+ }
+ int updateAdvance()
+ {
+ xstring AdvanceID = dw_base.GetItemString(1, L"AdvanceID");
+ xstring ChargeOffState = L"Y";
+ xstring ChargeOffDate = dw_base.GetItemString(1, L"APDate");
+ xstring PayedAmount = dw_base.GetItemString(1, L"PayedAmount");
+ xstring val = L"<data><PO><item guid='" + AdvanceID + L"' update.modify='1'>" +
+ "<ChargeOffState update.modify='1'>" + ChargeOffState + L"</ChargeOffState>" +
+ "<ChargeOffMoney update.modify='1'>" + PayedAmount + L"</ChargeOffMoney>" +
+ "<ChargeOffDate update.modify='1'>" + ChargeOffDate + L"</ChargeOffDate></item></PO></data>";
+ xaserverarg arg;
+
+ arg.AddArg(L"content", val);
+ xml x ;
+
+ if (xurl::get(L"/sale/data/PurchaseOrder/update/polistex", arg.GetString(), x) != 1)
+ {
+ xstring error = x.text();
+ //alert(error);
+ return 0;
+ }
+ return 1;
+ }
- //xcombobox下拉
- int OnSelectDdlb(TEvent evt, LPARAM p)
- {
- changeddlb = 1;
+ int OnSave()
+ {
+ xstring APNo = dw_base.GetItemString(1, L"APNo");
+ xml x ;
+ if (APNo == L"")
+ {
+ x = ViewObject::RetrieveData(L"/sale/data/AP/MakeAPNo");
+ APNo = x.text();
+ dw_base.SetItemString(1, L"APNo", APNo);
+ }
+ xstring AdvanceID = dw_base.GetItemString(1, L"AdvanceID");
+ xstring OrigSysID = dw_base.GetItemString(1, L"OrigSysID");
+ xstring APType1 = dw_base.GetItemString(1, L"APType");
+ if (APType1 != L"000")
+ {
+ if (AdvanceID == L"" && OrigSysID != L"") {
+ alert(L"请转入");
+ return 0;
+ }
+ }
- 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;
- }
+
+ dw_base.AcceptText();
+ dw_base.DwUpdateAllTo(x);
+ xaserverarg arg;
+
+ arg.AddArg(L"content", x.xml());
- 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);
+ if (xurl::get(L"/sale/data/AP/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_base.ResetUpdateStatus();
+ updateAdvance();
+ alert(L"保存成功!");
+ SendMessage(hObject, 0x401, L"xmRefresh", 0);
+ CloseWindow();
+ }
+ else
+ {
+ alert(L"保存失败!");
+ }
+ 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 dwname = L"dw_base";
+ xstring ETD = L"";
+
+ if (value == L"") return 1;
+ if (colname == L"SupplierID")
+ {
+ dw_base.SetItemString(1, L"APSupplierID", dw_base.GetItemString(1, L"SupplierID"));
+ dw_base.SetItemDisplayString(1, L"APSupplierID", dw_base.GetItemDisplayString(1, L"SupplierID"));
+ }
+ if (colname == L"Amount")
+ {
+ dw_base.SetItemString(1, L"PayedAmount", dw_base.GetItemString(1, L"Amount"));
+ }
+ if (colname == L"InvoiceNo")
+ {
+ dw_base.SetItemString(1, L"NotifyInvoiceNo", dw_base.GetItemString(1, L"InvoiceNo"));
+
+ xml x11 = ViewObject::RetrieveData(L"/sale/data/AP/GetInvoiceNo", L"InvoiceNo", dw_base.GetItemString(1, L"InvoiceNo"));
+ if (x11)
+ {
+ ETD = x11.text();
+ }
+ dw_base.SetItemString(1, L"GDNDate", ETD);
+ }
+
+ return 1;
+
+ }
+ int OnImport()
+ {
+ xaserverarg arg1;
+
+ arg1.AddArg(L"PONo", dw_base.GetItemString(1, L"PONo"));
+ OpenWindow(L"dev:xpage[Select.AP.vx]", arg1);
+ xstring str = arg1.GetArgString(L"items");
+ if (str != L"")
+ {
+ xml x ;
+
+ x.loadXML(str);
+ KXMLDOMNodeList items = x.selectNodes(L"data/item");
+ KXMLDOMNode t = items.item(0);
+ KXMLDOMNodeList items1 = x.selectNodes(L"data");
+ KXMLDOMNode t1 = items1.item(0);
+ if (t1.selectSingleNode(L"item/@guid"))dw_base.SetItemString(1, L"AdvanceID", t1.selectSingleNode(L"item/@guid").text());
+ if (t.selectSingleNode(L"PONo"))dw_base.SetItemString(1, L"PONo", t.selectSingleNode(L"PONo").text());
+ if (t.selectSingleNode(L"OrgName"))dw_base.SetItemString(1, L"OrgName", t.selectSingleNode(L"OrgName").text());
+ if (t.selectSingleNode(L"SalespersonID/@_displaystring"))dw_base.SetItemDisplayString(1, L"SalespersonID", t.selectSingleNode(L"SalespersonID/@_displaystring").text());
+ if (t.selectSingleNode(L"SalespersonID"))dw_base.SetItemString(1, L"SalespersonID", t.selectSingleNode(L"SalespersonID").text());
+ if (t.selectSingleNode(L"AdvancedMoney"))dw_base.SetItemString(1, L"Amount", t.selectSingleNode(L"AdvancedMoney").text());
+ if (t.selectSingleNode(L"AdvancedMoney"))dw_base.SetItemString(1, L"PayedAmount", t.selectSingleNode(L"AdvancedMoney").text());
+ if (t.selectSingleNode(L"PartyID"))dw_base.SetItemString(1, L"SupplierID", t.selectSingleNode(L"PartyID").text());
+ if (t.selectSingleNode(L"PartyID"))dw_base.SetItemString(1, L"APSupplierID", t.selectSingleNode(L"PartyID").text());
+ if (t.selectSingleNode(L"ShortName"))dw_base.SetItemDisplayString(1, L"APSupplierID", t.selectSingleNode(L"ShortName").text());
+ if (t.selectSingleNode(L"ShortName"))dw_base.SetItemDisplayString(1, L"SupplierID", t.selectSingleNode(L"ShortName").text());
+ if (t.selectSingleNode(L"SONo"))dw_base.SetItemString(1, L"SONO", t.selectSingleNode(L"SONo").text());
+
+ if (t.selectSingleNode(L"POAmount"))dw_base.SetItemString(1, L"POAmount", t.selectSingleNode(L"POAmount").text());
+ }
+ return 1;
+ }
+ //命令发布函数
+ int OnCmdDispatch(xstring comdid)
+ {
+ if (comdid == L"xmImport")
+ {
+ OnImport();
+ return 1;
+ }
+ else if (comdid == L"xmClose")
+ {
+ CloseWindow();
+ return 1;
+ }
+ else if (comdid == L"xmSave")
+ {
+ return OnSave();
+ }
+ return 0;
+ }
+
+ //命令处理事件
+ int OnXCommand(TEvent* evt, LPARAM param)
+ {
+ return OnCmdDispatch(evt->xcommand.pStrID);
+ }
+
+ int OnAttachEvent()
+ {
+ //绑定工具条点击事件
+ AttachEvent(L"WM_XCOMMAND", (FEvent)&MaintAP::OnXCommand);
+ AttachEvent(L"dw_base", L"DWV_ITEMCHANGED", (FEvent)&MaintAP::OnItemChanged);
+ //获取焦点事件,用于重置工具条
+ AttachEvent(L"WM_SETFOCUS", (FEvent)&MaintAP::OnSetFocus);
+ }
+
+ int OnRetrieve()
+ {
+ xml x ;
+
+ xaserverarg arg;
+
+ arg.AddArg(L"EntityID", APID);
+ if (getUrl(L"/sale/data/AP/base", 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_base.Retrieve(x);
+ dw_base.Redraw();
+ }
+ return 1;
+ }
+
+ int onload()
+ {
+ APID = L"";
+ APType = L"";
+ if (GetWinParam())
+ {
+ xaserverarg arg=GetArg();
+
+ APID = arg.GetArgString(L"APID");
+ APType = arg.GetArgString(L"APType");
+ }
+ dw_base = GetControl(L"dw_base");
+ dw_base.openUrl(L"/sale/view/AP/template/Base1");
+ dw_base.SetColHeaderHeight(0);
+ dw_base.SetRowSelectorWidth(0);
+ dw_base.SetHScrollState(false);
+ dw_base.SetVScrollState(false);
+
+ OnAttachEvent();
+
+ if (APID != L"")
+ {
+ OnRetrieve();
}
else
{
- MessageBoxW(GetHWND(), L"删除成功!", L"提示", 0);
- listwin::dw_list.DeleteRow(row);
+ xstring sdate = publiccode::GetCurrentDate();
+ dw_base.SetItemString(1, L"APDate", sdate);
+ dw_base.SetItemString(1, L"PayedDate", sdate);
+ dw_base.SetItemString(1, L"CreateDate", sdate);
+ xstring suserid = publiccode::GetUser().id;
+ xstring susername = publiccode::GetUser().name;
+ dw_base.SetItemString(1, L"CreatorID", suserid);
+ dw_base.SetItemDisplayString(1, L"CreatorID", susername);
+ dw_base.SetItemString(1, L"APType", L"001");
+ dw_base.SetItemDisplayString(1, L"APType", L"预付款");
+ dw_base.SetItemString(1, L"ApprovalStatus", L"6");
+
}
- }
- 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)
+ for (int m = 1; m <= dw_base.GetColumnCount(); m++)
{
- 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"");
+ xstring col = dw_base.GetColumnName(m);
+ if (col == L"OrgName" || col == L"APNo")
+ dw_base.SetColumnProp(col, L"cellprotect", L"1");
}
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);
+ int onloaded()
+ {
+ SetAgent();
+
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)
- {
-
- 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);
-
- }
- }
-
- }
-
- return 1;
- }
-
- int onloaded()
- {
- AttachEvent(L"dw_list", L"DWV_ROWFOCUSCHANGED", (FEvent)&listSupplierv3::OnRowChangedEx);
-
- 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;
- }
-
-};
\ No newline at end of file
+ };
diff --git a/jrj/project/business/VATNotify/VATNotifyParse.cpp b/jrj/project/business/VATNotify/VATNotifyParse.cpp
index 6c3d5bb..466f9f4 100644
--- a/jrj/project/business/VATNotify/VATNotifyParse.cpp
+++ b/jrj/project/business/VATNotify/VATNotifyParse.cpp
@@ -6,537 +6,127 @@
#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) VATNotifyParse : public xframe
{
- listSupplierv3* pWin = new listSupplierv3(implPtr, (HWND)hWnd);
- return pWin;
- }
- int OnRetrieve()
- {
- xml x;
+ public:
+ xdwtable dw_base;
+ xnode m_agentNode; //Agent Condition
- 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:
+ VATNotifyParse(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+ public:
+ static VATNotifyParse* CreateInstance(void* implPtr, void* hWnd)
{
- return -1;
+ VATNotifyParse* pWin = new VATNotifyParse(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());
- }
- //trace(x.GetXml());
- listwin::dw_list.Retrieve(x);
- listwin::dw_list.Redraw();
- listwin::dw_list.SetReadOnly(true);
- }
-
- 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")
- {
- //trace(L"sd");
- xdwpages zz = GetControl(L"pages");
- int h = zz.SetCurPage(1);
- //trace(h);
- OnRetrieve();
- }
- return 1;
- }
-
- //树选择
- int OnTreeSelChanged(TEvent evt, LPARAM p)
- {
- if (changeddlb != 1)
- {
- //alert(L"1");
-
- HTREEITEM h = tv_1.GetSelectedItem();
- KXMLDOMElement& e = *(KXMLDOMElement*)tv_1.GetItemData(h);
-
- 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++)
- {
-
- 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);
- }
- 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;
- }
- else
- {
- KXMLDOMNodeList nlist = x.selectNodes(L"root/item");
- int len = nlist.length();
- if (len > 0)
- {
- int i;
- for (i = 0; i < len; i++)
+ KXMLDOMElement xframeElement = GetElement();
+ KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*");
+ if (agent)
{
-
- 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);
+ xstring s = agent.xml();
+ m_agentNode = SetAgentNode(anode, s);
}
- tv_1.ExpandItem(0);
- }
- }
-
- return 1;
- }
-
- //xcombobox下拉
- int OnSelectDdlb(TEvent evt, LPARAM p)
- {
- changeddlb = 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 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);
- 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")
- {
- alert(msg.selectSingleNode(L"@errInfo").text());
- }
- 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")
+
+ //焦点激活处理函数
+ int OnSetFocus(TEvent* evt, LPARAM param)
{
- xaserverarg& arg = *new xaserverarg;
+ //重置工具条
+ //SetAgent();
+ return 1;
+ }
+
+ int OnOk()
+ {
+
+ xaserverarg arg = GetArg();
+ arg.AddArg(L"process", L"ok");
+ arg.AddArg(L"Quantity", dw_base.GetItemString(1, L"Quantity"));
+ arg.AddArg(L"CustQuantity", dw_base.GetItemString(1, L"CustQuantity"));
+ arg.AddArg(L"Amount", dw_base.GetItemString(1, L"Amount"));
+ CloseWindow();
+ return 1;
+ }
+ //命令发布函数
+ int OnCmdDispatch(xstring comdid)
+ {
+ if (comdid == L"xmOk") return OnOk();
+ if (comdid == L"xmCancel")
+ {
+ CloseWindow();
+ return 1;
+ }
+ return 0;
+ }
+
+ //命令处理事件
+ int OnXCommand(TEvent* evt, LPARAM param)
+ {
+ return OnCmdDispatch(evt->xcommand.pStrID);
+ }
+
+
+ int OnAttachEvent()
+ {
+ //绑定工具条点击事件
+ AttachEvent(L"WM_XCOMMAND", (FEvent)&VATNotifyParse::OnXCommand);
+ //获取焦点事件,用于重置工具条
+ AttachEvent(L"WM_SETFOCUS", (FEvent)&VATNotifyParse::OnSetFocus);
+ }
+
+ /*
+ int OnRetrieve()
+ {
+ xml x ;
+
+ 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)
+ arg.AddArg(L"xxx",L"xxx");
+ if (getUrl(L"",arg.GetString(),x)!=1)
{
- TypeWork = supplier_x.text();
-
- if (TypeWork.find(L"采购") >= 0)
- {
-
- 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);
-
- }
+ trace(x.text());
+ return -1;
+ }else
+ {
+ //dw_base.Retrieve(x);
+ //dw_base.Redraw();
}
+ return 1;
+ }
+ */
+ int onload()
+ {
+ dw_base = GetControl(L"dw_base");
+ dw_base.openUrl(L"/sale/view/VATNotify/template/VATNotify/ParseNumber");
+
+ dw_base.SetColHeaderHeight(0);
+ dw_base.SetRowSelectorWidth(0);
+ dw_base.SetHScrollState(false);
+ dw_base.SetVScrollState(false);
+
+ OnAttachEvent();
+
+ return 1;
}
- return 1;
- }
+ int onloaded()
+ {
+ //SetAgent();
- int onloaded()
- {
- AttachEvent(L"dw_list", L"DWV_ROWFOCUSCHANGED", (FEvent)&listSupplierv3::OnRowChangedEx);
-
- 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;
- }
-
-};
\ No newline at end of file
+ return 1;
+ }
+ };
diff --git a/jrj/project/business/VATNotify/list.vatnotify.cpp b/jrj/project/business/VATNotify/list.vatnotify.cpp
index 6c3d5bb..28986e4 100644
--- a/jrj/project/business/VATNotify/list.vatnotify.cpp
+++ b/jrj/project/business/VATNotify/list.vatnotify.cpp
@@ -6,537 +6,404 @@
#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) listvatnotifyWin : public xframe
{
- listSupplierv3* pWin = new listSupplierv3(implPtr, (HWND)hWnd);
- return pWin;
- }
- int OnRetrieve()
- {
- xml x;
+ public:
+ xdwgrid dw_list;
+ xdwpages dw_pages;
+ xdwtable dw_arg;
- 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)
+ xnode m_agentNode; //Agent Condition
+
+ int m_pageindex;
+ int m_pagenumber;
+ xstring m_QueryTxt;
+ xstring DatePicker;
+
+ public:
+ listvatnotifyWin(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+ public:
+ static listvatnotifyWin* CreateInstance(void* implPtr, void* hWnd)
{
- return -1;
+ listvatnotifyWin* pWin = new listvatnotifyWin(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());
- }
- //trace(x.GetXml());
- listwin::dw_list.Retrieve(x);
- listwin::dw_list.Redraw();
- listwin::dw_list.SetReadOnly(true);
- }
-
- 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")
- {
- //trace(L"sd");
- xdwpages zz = GetControl(L"pages");
- int h = zz.SetCurPage(1);
- //trace(h);
- OnRetrieve();
- }
- return 1;
- }
-
- //树选择
- int OnTreeSelChanged(TEvent evt, LPARAM p)
- {
- if (changeddlb != 1)
- {
- //alert(L"1");
-
- HTREEITEM h = tv_1.GetSelectedItem();
- KXMLDOMElement& e = *(KXMLDOMElement*)tv_1.GetItemData(h);
-
- 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++)
- {
-
- 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);
- }
- 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;
- }
- else
- {
- KXMLDOMNodeList nlist = x.selectNodes(L"root/item");
- int len = nlist.length();
- if (len > 0)
- {
- int i;
- for (i = 0; i < len; i++)
+ KXMLDOMElement xframeElement = GetElement();
+ KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*");
+ if (agent)
{
-
- 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);
+ xstring s = agent.xml();
+ m_agentNode = SetAgentNode(anode, s);
}
- tv_1.ExpandItem(0);
}
+ return 1;
}
- return 1;
- }
-
- //xcombobox下拉
- int OnSelectDdlb(TEvent evt, LPARAM p)
- {
- changeddlb = 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 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);
- 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)
+ //焦点激活处理函数
+ int OnSetFocus(TEvent* evt, LPARAM param)
{
- xstring error = x.text();
- trace(error);
+ //重置工具条
+ SetAgent();
+ return 1;
}
- else
+
+ int OnDWClick(TEvent* evt, LPARAM p)
{
- KXMLDOMElement msg = x.selectNodes(L"process").item(0);
- xstring success = msg.selectSingleNode(L"@finished").text();
- if (success == L"0")
+ DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
+ xstring value = hdr.data;
+ xstring colname = hdr.colname;
+ int row = hdr.row;
+
+ if (row < 1) return 1;
+
+ xaserverarg arg;
+ if (colname == L"SONo")
{
- alert(msg.selectSingleNode(L"@errInfo").text());
+ xstring SONo = dw_list.GetItemString(row, colname);
+ ;
+
+ arg.AddArg(L"EntityNo", SONo);
+ arg.AddArg(L"ReadOnly", L"true");
+ OpenWindow(L"dev:xpage[base.maint.so.vx]", arg);
}
- else
+ if (colname == L"InvoiceNo")
{
- MessageBoxW(GetHWND(), L"删除成功!", L"提示", 0);
- listwin::dw_list.DeleteRow(row);
+ xstring InvoiceNo = dw_list.GetItemString(row, colname);
+ ;
+
+ arg.AddArg(L"EntityNo", InvoiceNo);
+ arg.AddArg(L"ReadOnly", L"true");
+ OpenWindow(L"dev:xpage[maintex.GDN3.vx]", arg);
}
+ return 1;
}
- 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")
+ int OnPrint()
{
+ xaserverarg arg;
+
+ arg.AddArg(L"EntityName", L"VATNotify");
+ arg.AddArg(L"EntityID", L"", L"");
+ xstring InvoiceNo = dw_list.GetItemString(dw_list.GetRow(), L"NInvoiceNo");
+ if (InvoiceNo == L"") InvoiceNo = dw_list.GetItemString(dw_list.GetRow(), L"InvoiceNo");
- if (TypeWork.find(L"采购") >= 0)
+ xstring NInvoiceNoEx = dw_list.GetItemString(dw_list.GetRow(), L"NInvoiceNo");
+ xstring InvoiceNoEx = dw_list.GetItemString(dw_list.GetRow(), L"InvoiceNo");
+ if (NInvoiceNoEx != InvoiceNoEx)
{
- GoodsUrl = L"/sale/data/SupplierV3/entity/supplieritemEx";
+ NInvoiceNoEx = InvoiceNoEx;
}
- else
+ xstring SupplierID = dw_list.GetItemString(dw_list.GetRow(), L"SupplierID");
+ arg.AddArg(L"EntityNo", InvoiceNo, L"");
+ arg.AddArg(L"EntityNoEx", NInvoiceNoEx, L"");
+ arg.AddArg(L"SupplierID", SupplierID);
+ arg.AddArg(L"VATNotifyID", L"");
+ trace(InvoiceNo + L"==1" + NInvoiceNoEx + L"==2" + SupplierID + L"==3" + dw_list.GetGuid(dw_list.GetRow()));
+
+ openUrl(L"/sale/view/view.base/xpage/Template/PrintViewEx", arg);
+ return 1;
+ }
+
+ int OnPrintItem()
+ {
+ xaserverarg arg;
+
+ arg.AddArg(L"EntityName", L"VATNotify");
+ arg.AddArg(L"EntityID", L"", L"");
+ xstring InvoiceNo = dw_list.GetItemString(dw_list.GetRow(), L"NInvoiceNo");
+ if (InvoiceNo == L"") InvoiceNo = dw_list.GetItemString(dw_list.GetRow(), L"InvoiceNo");
+
+ xstring NInvoiceNoEx = dw_list.GetItemString(dw_list.GetRow(), L"NInvoiceNo");
+ xstring InvoiceNoEx = dw_list.GetItemString(dw_list.GetRow(), L"InvoiceNo");
+ if (NInvoiceNoEx != InvoiceNoEx)
{
- GoodsUrl = L"/sale/data/SupplierV3/entity/supplieritem";
+ NInvoiceNoEx = InvoiceNoEx;
}
+ xstring SupplierID = dw_list.GetItemString(dw_list.GetRow(), L"SupplierID");
+ arg.AddArg(L"EntityNo", InvoiceNo, L"");
+ arg.AddArg(L"EntityNoEx", NInvoiceNoEx, L"");
+ arg.AddArg(L"SupplierID", SupplierID);
+ arg.AddArg(L"VATNotifyID", dw_list.GetGuid(dw_list.GetRow()));
+ trace(L"=====L" + InvoiceNo + L"=====L" + SupplierID + L"=====L" + dw_list.GetGuid(dw_list.GetRow()));
+
+ openUrl(L"/sale/view/view.base/xpage/Template/PrintViewEx", p);
+ return 1;
}
- 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);
+ int OnOpen() {
+ int row = dw_list.GetRow();
+ if (row < 1) return 0;
+ KXMLDOMElement ele = dw_list.GetRowElement(row);
+ xstring entityid = ele.selectSingleNode(L"InvoiceNo").text();
+ xaserverarg arg;
+
+ arg.AddArg(L"invoiceno", entityid);
+
+ OpenWindow(L"dev:xpage[simple.maint.vatnotify.vx]", arg);
+ return 1;
}
- 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();
- }
+
+ int OnPapercardOpen() {
+ int row = dw_list.GetRow();
+ if (row < 1) return 0;
+ KXMLDOMElement ele = dw_list.GetRowElement(row);
+ xstring entityid = ele.selectSingleNode(L"InvoiceNo").text();
+ xstring classifyID = ele.selectSingleNode(L"ClassifyID").text();
+ xstring supplierID = ele.selectSingleNode(L"SupplierID").text();
+ xstring cname = ele.selectSingleNode(L"CName").text();
+
+ xaserverarg arg;
+
+ arg.AddArg(L"invoiceno", entityid);
+ arg.AddArg(L"ClassifyID", classifyID);
+ arg.AddArg(L"SupplierID", supplierID);
+ arg.AddArg(L"CName", cname);
+
+ OpenWindow(L"dev:xpage[maint.papercard.vatnotify.vx]", p);
+ return 1;
}
-#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 OnModify() {
+ int row = dw_list.GetRow();
+ if (row < 1) return 0;
+ KXMLDOMElement ele = dw_list.GetRowElement(row);
+ xstring entityid = ele.selectSingleNode(L"InvoiceNo").text();
+ xaserverarg arg;
+
+ arg.AddArg(L"invoiceno", entityid);
+
+ OpenWindow(L"dev:xpage[update.vatnotify.vx]", arg);
+ 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)
+ int Onfinish() {
+
+ return 1;
+ }
+
+ int OnDeleteRow()
{
- 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)
+ if (dw_list.GetRow() < 1) return 1;
+ int row = dw_list.GetRow();
+ xstring InvoiceNo = dw_list.GetItemString(row, L"InvoiceNo");
+ int res = MessageBox(GetHWND(), L"是否确认删除" + InvoiceNo + L"的开票通知?", L"提示", 4);
+ if (res == 6)
{
- alert(L"处理成功");
- OnRetrieve();
+ xml x = ViewObject::RetrieveData(L"/sale/data/VATNotify/entity/delete", L"invoiceno", InvoiceNo);
+ if (!x)
+ {
+ alert(L"删除错误");
+ return 1;
+ }
+ //dw_list.DeleteRow(row);
+ alert(x.text());
+ OnRetrieve(DatePicker);
}
- }
- 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;
+ return 1;
}
- if (comdid == L"action:search1") return GridSearch();
- if (comdid == L"action:bill.refresh")
+
+ //命令发布函数
+ int OnCmdDispatch(xstring comdid)
{
- return OnRetrieve();
- }
- if (comdid == L"action:bill.xmSaveAs")
- {
- xstring userno = publiccode::GetUser().no;
- if (userno == L"00701" || userno == L"00601" || userno == L"admin")
+ if (comdid == L"xm:import") {
+ OpenWindow(L"dev:xpage[import.vatnotify.vx]", 0);
+ }
+ if (comdid == L"action:bill.open") {
+ OnOpen();
+ }
+ else if (comdid == L"xm:notify") {
+ OnOpen();
+ }
+ else if (comdid == L"xm:papercardnotify") {
+ OnPapercardOpen();
+ }
+ else if (comdid == L"xm:modify") {
+ OnModify();
+ }
+ else if (comdid == L"xm:finish") {
+ Onfinish();
+ }
+ else if (comdid == L"xm:ratecalc") {
+
+ }
+ else if (comdid == L"find")
+ {
+ m_QueryTxt = GetControl(L"txt").GetText();
+ return OnRetrieve(DatePicker);
+ }
+ else if (comdid == L"xmRefresh")
+ {
+ return OnRetrieve(DatePicker);
+ }
+ else if (comdid == L"xmDeleteRow")
+ {
+ return OnDeleteRow();
+ }
+ else if (comdid == L"xmPrint") {
+ return OnPrint();
+ }
+ else if (comdid == L"xmPrintItem") {
+ return OnPrintItem();
+ }
+ else if (comdid == L"xmSaveAs")
{
dw_list.SaveAs(L"");
+ return 1;
}
- return 1;
+ return 0;
}
- 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;
+ //命令处理事件
+ int OnXCommand(TEvent* evt, LPARAM param)
+ {
+ return OnCmdDispatch(evt->xcommand.pStrID);
}
- 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;
+ int OnAttachEvent()
+ {
+ //绑定工具条点击事件
+ AttachEvent(L"WM_XCOMMAND", (FEvent)&listvatnotifyWin::OnXCommand);
+ //获取焦点事件,用于重置工具条
+ AttachEvent(L"WM_SETFOCUS", (FEvent)&listvatnotifyWin::OnSetFocus);
+ AttachEvent(L"dw_list", L"DWV_CLICKED", (FEvent)&listvatnotifyWin::OnDWClick);
+ AttachEvent(L"cbx_state", L"CBN_SELCHANGE", (FEvent)&listvatnotifyWin::OnDatePicker);
}
- 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")
+ int OnDatePicker(TEvent* evt, int lParam)
{
- xstring s = publiccode::GetUser().id;
+
+ DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
- xml supplier_x = ViewObject::RetrieveData(GetServerUrl(), L"/sale/data/SupplierV3/entity/FindBySaleType", L"id", s);
- if (supplier_x)
+ int h = xcombobox::GetCurSel(evt.hCtrl);
+ if (h > -1)
{
- TypeWork = supplier_x.text();
-
- if (TypeWork.find(L"采购") >= 0)
+ xstring txt = xcombobox::GetLBText(evt.hCtrl, h);
+ if (txt == L"通知日期")
{
- 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);
+ DatePicker = L"NotifyDate";
+ OnRetrieve(DatePicker);
+ }
+ else if (txt == L"出运日期")
+ {
+ DatePicker = L"ETD";
+ OnRetrieve(DatePicker);
}
}
-
+ return 1;
}
- return 1;
- }
- int onloaded()
- {
- AttachEvent(L"dw_list", L"DWV_ROWFOCUSCHANGED", (FEvent)&listSupplierv3::OnRowChangedEx);
+ xstring GetQueryArg()
+ {
+ dw_arg.AcceptText();
+ xml x ;
+
+ dw_arg.DwUpdateAllTo(x);
+ return x.xml();
+ }
- 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;
- }
+ int OnRetrieve(xstring DatePicker)
+ {
+ HCURSOR hCursor = xutil::SetCursorWait();
+ xml x ;
+
+ xaserverarg arg;
+
+ arg.AddArg(L"pageindex", xstring(m_pageindex));
+ arg.AddArg(L"pagenumber", xstring(m_pagenumber));
+ arg.AddArg(L"QueryTxt", m_QueryTxt);
+ arg.AddArg(L"QueryArg", GetQueryArg());
+ arg.AddArg(L"DatePicker", DatePicker);
+ if (getUrl(L"/sale/data/VATNotify/entity/listOne", arg.GetString(), x) != 1)
+ {
+ trace(x.text());
+ xutil::RestoreCursor(hCursor);
+ return -1;
+ }
+ else
+ {
+ //trace(x.xml);
+ KXMLDOMElement ele = x.documentElement();
+ if (dw_pages.ptr_native_)
+ {
+ if (ele.selectSingleNode(L"@TotalPage"))
+ {
+ xstring s = ele.selectSingleNode(L"@TotalPage").text(); //总数量
+ dw_pages.SetMaxPage(s.toInt());
+ }
+ }
+ dw_list.Retrieve(x);
+ dw_list.Redraw();
+ dw_list.SetReadOnly(true);
+ }
+ xutil::RestoreCursor(hCursor);
+ return 1;
+ }
-};
\ No newline at end of file
+ int OnChangePages(TEvent* evt, LPARAM p)
+ {
+ PAGENMHDR& h = *(PAGENMHDR*)evt->notify.pnmh;
+ int c = h.cur;
+ HCURSOR hCursor = xutil::SetCursorWait();
+ m_pageindex = c;
+ OnRetrieve(DatePicker);
+ xutil::RestoreCursor(hCursor);
+ return 1;
+ }
+
+ int OnDoubleClicked(TEvent* evt, LPARAM p)
+ {
+ HCURSOR hCursor = xutil::SetCursorWait();
+ OnCmdDispatch(L"action:bill.open");
+ xutil::RestoreCursor(hCursor);
+ return 1;
+ }
+
+ int onload()
+ {
+ dw_list = GetControl(L"dw_list");
+ dw_list.openUrl(L"/sale/view/VATNotify/template/VATNotify/list");
+ dw_arg = GetControl(L"dw_arg");
+ dw_arg.openUrl(L"/sale/view/AR/template/queryarg");
+ dw_arg.SetColHeaderHeight(0);
+ dw_arg.SetRowSelectorWidth(0);
+ dw_arg.SetHScrollState(false);
+ dw_arg.SetVScrollState(false);
+ dw_arg.SetItemString(1, L"DateType", L"本月");
+ //dw_arg.SetItemString(1,L"DateType",L"");
+ AttachEvent(L"dw_list", L"DWV_DOUBLECLICKED", (FEvent)&listvatnotifyWin::OnDoubleClicked);//行双击
+ dw_pages = GetControl(L"pages");
+ AttachEvent(L"pages", L"PAGE_CLICK", (FEvent)&listvatnotifyWin::OnChangePages);
+
+
+ OnAttachEvent();
+
+ return 1;
+ }
+
+ int onloaded()
+ {
+ SetAgent();
+
+ m_pageindex = 1;
+ m_pagenumber = 10000;
+ m_QueryTxt = L"";
+
+ //OnRetrieve();
+
+ return 1;
+ }
+ };
diff --git a/jrj/project/business/VATNotify/maint.papercard.vatnotify.cpp b/jrj/project/business/VATNotify/maint.papercard.vatnotify.cpp
index 6c3d5bb..d942af0 100644
--- a/jrj/project/business/VATNotify/maint.papercard.vatnotify.cpp
+++ b/jrj/project/business/VATNotify/maint.papercard.vatnotify.cpp
@@ -6,537 +6,786 @@
#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) maintpapercardvatnotifyWin : public xframe
{
- listSupplierv3* pWin = new listSupplierv3(implPtr, (HWND)hWnd);
- return pWin;
- }
- int OnRetrieve()
- {
- xml x;
+ public:
+ xdwtable dw_profit;
+ xdwtable dw_arg;
+ xdwgrid dw_item;
+ xdwgrid dw_fob;
+ xstring InvNo;
+ xstring CurInvNo;
+ xnode m_agentNode; //Agent Condition
- 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:
+ maintpapercardvatnotifyWin(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+ public:
+ static maintpapercardvatnotifyWin* CreateInstance(void* implPtr, void* hWnd)
{
- return -1;
+ maintpapercardvatnotifyWin* pWin = new maintpapercardvatnotifyWin(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());
- }
- //trace(x.GetXml());
- listwin::dw_list.Retrieve(x);
- listwin::dw_list.Redraw();
- listwin::dw_list.SetReadOnly(true);
- }
-
- 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")
- {
- //trace(L"sd");
- xdwpages zz = GetControl(L"pages");
- int h = zz.SetCurPage(1);
- //trace(h);
- OnRetrieve();
- }
- return 1;
- }
-
- //树选择
- int OnTreeSelChanged(TEvent evt, LPARAM p)
- {
- if (changeddlb != 1)
- {
- //alert(L"1");
-
- HTREEITEM h = tv_1.GetSelectedItem();
- KXMLDOMElement& e = *(KXMLDOMElement*)tv_1.GetItemData(h);
-
- 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++)
- {
-
- 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);
- }
- 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;
- }
- else
- {
- KXMLDOMNodeList nlist = x.selectNodes(L"root/item");
- int len = nlist.length();
- if (len > 0)
- {
- int i;
- for (i = 0; i < len; i++)
+ KXMLDOMElement xframeElement = GetElement();
+ KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*");
+ if (agent)
{
-
- 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);
+ xstring s = agent.xml();
+ m_agentNode = SetAgentNode(anode, s);
}
- tv_1.ExpandItem(0);
}
+ return 1;
}
- return 1;
- }
+ //焦点激活处理函数
+ int OnSetFocus(TEvent* evt, LPARAM param)
+ {
+ //重置工具条
+ SetAgent();
+ return 1;
+ }
- //xcombobox下拉
- int OnSelectDdlb(TEvent evt, LPARAM p)
- {
- changeddlb = 1;
+ int OnPrint()
+ {
+ xaserverarg arg;
+
+ arg.AddArg(L"EntityName", L"VATNotify", L"");
+ arg.AddArg(L"EntityID", L"", L"");
+ arg.AddArg(L"EntityNo", dw_item.GetItemString(1, L"InvoiceNo"), L"");
+
+ openUrl(L"/sale/view/view.base/xpage/Template/PrintViewEx", p);
+ 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 OnPrintItem()
+ {
+ xaserverarg arg;
+
+ arg.AddArg(L"EntityName", L"VATNotify", L"");
+ arg.AddArg(L"EntityID", L"", L"");
+ arg.AddArg(L"EntityNo", dw_item.GetItemString(1, L"InvoiceNo"), L"");
+
+ openUrl(L"/sale/view/view.base/xpage/Template/PrintViewEx", p);
+ return 1;
+ }
- 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);
+
+
+ int onebill()
+ {
+ if (!GetWinParam()) return 1;
+
+ 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();
+
+ xaserverarg arg;
+
+ int pArg = GetArg();
+
+
+ xstring ls_dtlno = arg.GetArgString(L"invoiceno");
+ RetrieveFob(ls_dtlno);
+ RetrieveProfit(ls_dtlno);
+ while (ll_row > 0 && ll_row <= dw_item.GetRowCount())
+ {
+ dw_item.SetItemString(ll_row, L"NInvoiceNo", ls_dtlno);
+ xstring sdate = publiccode::GetCurrentDate();
+
+ dw_item.SetItemDisplayString(ll_row, L"NClassifyID", arg.GetArgString(L"CName"));
+ dw_item.SetItemString(ll_row, L"NClassifyID", arg.GetArgString(L"ClassifyID"));
+
+ int ll_find = FobLookup(arg.GetArgString(L"ClassifyID"));
+ xstring qtyUnit1 = dw_fob.GetItemString(ll_find, L"CQtyUnit");
+ dw_item.SetItemString(ll_row, L"CQtyUnit", qtyUnit1);
+ dw_item.SetItemString(ll_row, L"VATRefundRate", dw_fob.GetItemString(ll_find, L"VATRefundRate"));
+
+ 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 = win32::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",L"");
+ dw_item.SetItemString(ll_row,L"NAmount",L"");
+ dw_item.SetItemString(ll_row,L"NotifyDate",L"");
+ dw_item.SetItemString(ll_row,L"NClassifyID",L"");
+ dw_item.SetItemString(ll_row,L"NName",L"");
+ 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""));
+ ll_row = dw_item.GetNextSelectRow(ll_row + 1);
+ }
+ dw_item.Redraw();
+ */
+
+ 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.SetItemString(ll_row, L"NName", L"");
+ dw_item.SetItemDisplayString(ll_row, L"NClassifyID", 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 OnArgChanged(TEvent* evt, LPARAM p)
+ {
+ DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
+ xstring colname = hdr.colname;
+ xstring value = hdr.data;
+ int row = hdr.row;
+ xstring SupplierID = dw_arg.GetItemString(1, L"SupplierID");
+ if (SupplierID != L"")
+ {
+ if (GetWinParam())
+ {
+ xaserverarg arg;
+
+ int pArg = GetArg();
+
+ arg.AddArg(L"SupplierID", SupplierID);
+ OnRetrieve();
+ }
+ }
+
+ 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);
+ if (colname == L"NAmount")
+ {
+ if (ll_find > 0)
+ {
+ xstring qtyUnit = dw_fob.GetItemString(ll_find, L"CQtyUnit");
+ 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;
+ if (qtyUnit.trim() != L"千克")
+ {
+ int d = xstring(qty).toInt();
+ xstring s = xstring(d);
+ qty = s.toDouble();
+ }
+ double restAmt = limitAmt - sumAmt;
+ dw_fob.SetItemDouble(ll_find, L"RestAmt", restAmt);
+ dw_item.ItemChangeTo(row, L"NQuantity", xstring(qty));
+ dw_item.Redraw();
+ 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);
+ 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(row, L"NQuantity");
+ if (NQuantity != L"") dw_item.ItemChangeTo(row, L"NQuantity", NQuantity);
+ xstring NAmount = dw_item.GetItemString(row, L"NAmount");
+ if (NAmount != L"") dw_item.ItemChangeTo(row, L"NAmount", NAmount);
+ xstring sdate = publiccode::GetCurrentDate();
+ dw_item.SetItemString(row, L"NotifyDate", sdate);
+
+ xstring qtyUnit1 = dw_fob.GetItemString(ll_find, L"CQtyUnit");
+ dw_item.SetItemString(row, L"CQtyUnit", qtyUnit1);
+ dw_item.SetItemString(row, L"VATRefundRate", dw_fob.GetItemString(ll_find, L"VATRefundRate"));
+ dw_item.Redraw();
+ return 1;
+ }
+ 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;
+ }
+
+ 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 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;
+ }
+
+ 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"onebill") {
+ return onebill();
+ }
+ else if (comdid == L"onebillno") {
+ return onebillno();
+ }
+ 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 OnXCommand(TEvent* evt, LPARAM param)
+ {
+ return OnCmdDispatch(evt->xcommand.pStrID);
+ }
+
+ int OnSave()
+ {
+ xml x ;
+
+ dw_item.AcceptText();
+ dw_item.DwUpdateAllToEx(x);
+
+ xml x0 = ViewObject::MakeXml();
+ x0.loadXML(L"<root/>");
+
+ KXMLDOMNodeList t = x.selectNodes(L"root/item[@update.modify]");
+ KXMLDOMElement e1 = x0.documentElement();
+ int len = t.length();
+ for (int i = 0; i < len; i++)
+ {
+ e1.appendChild(t.item(i));
+ }
+ xaserverarg arg = ViewObject::MakeArg();
+ arg.AddArg(L"content", x0.xml());
+
+ //trace(x.xml);
+ //return 1;
+ if (xurl::get(L"/sale/data/VATNotify/base/update", arg.GetString(), x0) != 1)
+ {
+ xstring error = x0.text();
+ alert(L"err:" + error);
+ return 1;
+ }
+ xstring str = x0.documentElement().getAttribute(L"text");
+ if (str == L"true")
+ {
+ dw_item.ResetUpdateStatus();
+ alert(L"保存成功!");
+ }
+ else
+ {
+ alert(L"保存失败1!");
+ return 1;
+ }
+
+ dw_fob.AcceptText();
+ xml x1 ;
+
+ dw_fob.DwUpdateAllToEx(x1);
+ arg.AddArg(L"content", x1.xml());
+ 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)&maintpapercardvatnotifyWin::OnXCommand);
+ //获取焦点事件,用于重置工具条
+ AttachEvent(L"WM_SETFOCUS", (FEvent)&maintpapercardvatnotifyWin::OnSetFocus);
+ AttachEvent(L"dw_item", L"DWV_ITEMCHANGED", (FEvent)&maintpapercardvatnotifyWin::OnItemChanged);
+ AttachEvent(L"dw_arg", L"DWV_ITEMCHANGED", (FEvent)&maintpapercardvatnotifyWin::OnArgChanged);
+ AttachEvent(L"dw_fob", L"DWV_ITEMCHANGED", (FEvent)&maintpapercardvatnotifyWin::OnFobItemChanged);
+ AttachEvent(L"dw_item", L"DWV_ROWFOCUSCHANGED", (FEvent)&maintpapercardvatnotifyWin::OnRowChanged);
+ AttachEvent(L"dw_item", L"DWV_ASKDATA", (FEvent)&maintpapercardvatnotifyWin::OnAskDataItem);
+ }
+
+ 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;
}
- }
-
- 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")
- {
- alert(msg.selectSingleNode(L"@errInfo").text());
- }
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)
+ //trace(x.xml);
+ 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_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;
}
- 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 onloaded()
- {
- AttachEvent(L"dw_list", L"DWV_ROWFOCUSCHANGED", (FEvent)&listSupplierv3::OnRowChangedEx);
+ int OnRetrieve()
+ {
+ xml x ;
+
+ xaserverarg arg;
+
- 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 (GetWinParam())
+ {
+ int pArg = GetArg();
+
+ }
+ else
+ return 1;
+ if (getUrl(L"/sale/data/VATNotify/entity/papercard", arg.GetString(), x) != 1)
+ {
+ trace(x.text());
+ return -1;
+ }
+ else
+ {
+ dw_item.Retrieve(x);
+ dw_item.Redraw();
+ dw_item.SetSelectionMode(3);
+ }
+ if (dw_item.GetRowCount() > 0)
+ {
+ //xstring InvoiceNo = dw_item.GetItemString(1,L"NInvoiceNo");
+ //if(InvoiceNo==L"") InvoiceNo = dw_item.GetItemString(1,L"InvoiceNo");
+ xstring InvoiceNo = arg.GetArgString(L"invoiceno");
+ CurInvNo = InvoiceNo;
+ RetrieveFob(InvoiceNo);
+ RetrieveProfit(InvoiceNo);
+ RecalcProfitData();
+ }
-};
\ No newline at end of file
+ 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"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_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;
+
+ dw_arg = GetControl(L"dw_arg");
+ dw_arg.openUrl(L"/sale/view/VATNotify/template/VATNotify/PaperCardArg");
+ dw_arg.SetColHeaderHeight(0);
+ dw_arg.SetRowSelectorWidth(0);
+ dw_arg.SetHScrollState(false);
+ dw_arg.SetVScrollState(false);
+
+ OnRetrieve();
+ OnAttachEvent();
+
+ return 1;
+ }
+
+ int onloaded()
+ {
+ SetAgent();
+
+ return 1;
+ }
+ };
diff --git a/jrj/project/business/VATNotify/simple.maint.vatnotify.cpp b/jrj/project/business/VATNotify/simple.maint.vatnotify.cpp
index 6c3d5bb..f60c9b4 100644
--- a/jrj/project/business/VATNotify/simple.maint.vatnotify.cpp
+++ b/jrj/project/business/VATNotify/simple.maint.vatnotify.cpp
@@ -6,537 +6,876 @@
#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) simplemaintvatnotifyWin : public xframe
{
- listSupplierv3* pWin = new listSupplierv3(implPtr, (HWND)hWnd);
- return pWin;
- }
- int OnRetrieve()
- {
- xml x;
+ public:
+ xdwtable dw_profit;
+ xdwgrid dw_item;
+ xdwgrid dw_fob;
+ xstring InvNo;
+ xstring CurInvNo;
+ xnode m_agentNode; //Agent Condition
- 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:
+ simplemaintvatnotifyWin(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+ public:
+ static simplemaintvatnotifyWin* CreateInstance(void* implPtr, void* hWnd)
{
- return -1;
+ simplemaintvatnotifyWin* pWin = new simplemaintvatnotifyWin(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());
- }
- //trace(x.GetXml());
- listwin::dw_list.Retrieve(x);
- listwin::dw_list.Redraw();
- listwin::dw_list.SetReadOnly(true);
- }
-
- 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")
- {
- //trace(L"sd");
- xdwpages zz = GetControl(L"pages");
- int h = zz.SetCurPage(1);
- //trace(h);
- OnRetrieve();
- }
- return 1;
- }
-
- //树选择
- int OnTreeSelChanged(TEvent evt, LPARAM p)
- {
- if (changeddlb != 1)
- {
- //alert(L"1");
-
- HTREEITEM h = tv_1.GetSelectedItem();
- KXMLDOMElement& e = *(KXMLDOMElement*)tv_1.GetItemData(h);
-
- 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++)
- {
-
- 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);
- }
- 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;
- }
- else
- {
- KXMLDOMNodeList nlist = x.selectNodes(L"root/item");
- int len = nlist.length();
- if (len > 0)
- {
- int i;
- for (i = 0; i < len; i++)
+ KXMLDOMElement xframeElement = GetElement();
+ KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*");
+ if (agent)
{
-
- 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);
+ xstring s = agent.xml();
+ m_agentNode = SetAgentNode(anode, s);
}
- tv_1.ExpandItem(0);
}
+ return 1;
}
- return 1;
- }
+ xstring GetEntityData(int pr)
+ {
+ xml x ;
+ dw_item.AcceptText();
+ dw_item.DwUpdateAllToEx(x);
+ return x.xml();
+ }
- //xcombobox下拉
- int OnSelectDdlb(TEvent evt, LPARAM p)
- {
- changeddlb = 1;
+ //焦点激活处理函数
+ int OnSetFocus(TEvent* evt, LPARAM param)
+ {
+ //重置工具条
+ SetAgent();
+ 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 OnPrint()
+ {
+ xaserverarg arg;
+
+ 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 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);
+ int OnPrintItem()
+ {
+ xaserverarg arg;
+
+ 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", p);
+ 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();
+ }
+
+ 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;
}
- }
-
- 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")
- {
- alert(msg.selectSingleNode(L"@errInfo").text());
- }
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)
+ //trace(x.xml);
+ 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_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;
}
- 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 onloaded()
- {
- AttachEvent(L"dw_list", L"DWV_ROWFOCUSCHANGED", (FEvent)&listSupplierv3::OnRowChangedEx);
+ int OnRetrieve()
+ {
+ HCURSOR hCursor = xutil::SetCursorWait();
- 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;
- }
-};
\ No newline at end of file
+ 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;
+ }
+ };
diff --git a/jrj/project/business/VATNotify/update.vatnotify.cpp b/jrj/project/business/VATNotify/update.vatnotify.cpp
index 6c3d5bb..c7d5e60 100644
--- a/jrj/project/business/VATNotify/update.vatnotify.cpp
+++ b/jrj/project/business/VATNotify/update.vatnotify.cpp
@@ -6,537 +6,361 @@
#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) UpdateVatNotifyWin : public xframe
{
- listSupplierv3* pWin = new listSupplierv3(implPtr, (HWND)hWnd);
- return pWin;
- }
- int OnRetrieve()
- {
- xml x;
+ public:
+ xdwgrid dw_list;
+ xdwgrid dw_item;
+ xdwgrid dw_goods;
+ xnode m_agentNode; //Agent Condition
- 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:
+ UpdateVatNotifyWin(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+ public:
+ static UpdateVatNotifyWin* CreateInstance(void* implPtr, void* hWnd)
{
- return -1;
+ UpdateVatNotifyWin* pWin = new UpdateVatNotifyWin(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());
- }
- //trace(x.GetXml());
- listwin::dw_list.Retrieve(x);
- listwin::dw_list.Redraw();
- listwin::dw_list.SetReadOnly(true);
- }
-
- 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")
- {
- //trace(L"sd");
- xdwpages zz = GetControl(L"pages");
- int h = zz.SetCurPage(1);
- //trace(h);
- OnRetrieve();
- }
- return 1;
- }
-
- //树选择
- int OnTreeSelChanged(TEvent evt, LPARAM p)
- {
- if (changeddlb != 1)
- {
- //alert(L"1");
-
- HTREEITEM h = tv_1.GetSelectedItem();
- KXMLDOMElement& e = *(KXMLDOMElement*)tv_1.GetItemData(h);
-
- 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++)
- {
-
- 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);
- }
- 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;
- }
- else
- {
- KXMLDOMNodeList nlist = x.selectNodes(L"root/item");
- int len = nlist.length();
- if (len > 0)
- {
- int i;
- for (i = 0; i < len; i++)
+ KXMLDOMElement xframeElement = GetElement();
+ KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*");
+ if (agent)
{
-
- 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);
+ xstring s = agent.xml();
+ m_agentNode = SetAgentNode(anode, s);
}
- tv_1.ExpandItem(0);
}
+ return 1;
}
- return 1;
- }
+ //焦点激活处理函数
+ int OnSetFocus(TEvent* evt, LPARAM param)
+ {
+ //重置工具条
+ //SetAgent();
+ return 1;
+ }
- //xcombobox下拉
- int OnSelectDdlb(TEvent evt, LPARAM p)
- {
- changeddlb = 1;
+ int OnSave()
+ {
+ xml x ;
+
+ dw_list.AcceptText();
+ dw_list.DwUpdateAllToEx(x);
+ xaserverarg arg = ViewObject::MakeArg();
+ arg.AddArg(L"content", x.xml());
- 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;
- }
+ 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_list.ResetUpdateStatus();
+ alert(L"保存成功!");
+ }
+ else
+ {
+ alert(L"保存失败!");
+ }
+ return 1;
+ }
- 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);
+ //命令发布函数
+ int OnCmdDispatch(xstring comdid)
+ {
+ if (comdid == L"xmReplaceRow")
+ {
+ return OnReplaceRow();
+ }
+ if (comdid == L"xmReplaceSupplier")
+ {
+ return OnReplaceSupplier();
+ }
+ else if (comdid == L"xmAddRow")
+ {
+ return OnAddRow();
+ }
+ else if (comdid == L"xmSave")
+ {
+ return OnSave();
+ }
+ else if (comdid == L"xmDeleteRow")
+ {
+ return OnDeleteRow();
+ }
+ if (comdid == L"xmClose")
+ {
+ CloseWindow();
+ return 1;
+ }
+ return 0;
+ }
+
+ int OnDeleteRow()
+ {
+ if (dw_list.GetRowCount() == dw_item.GetRowCount())
+ {
+ int res = MessageBox(GetHWND(), L"你可以用替换完成相应的操作,还继续删除吗?", L"提示", 4);
+ if (res != 6) return 1;
+ }
+ else
+ {
+ int res1 = MessageBox(GetHWND(), L"确认删除对应的行?", L"提示", 4);
+ if (res1 != 6) return 1;
+ }
+ dw_list.DeleteRow(0);
+ dw_list.Redraw();
+ return 1;
+ }
+
+ int OnAddRow()
+ {
+ if (dw_item.GetRow() < 1) return 1;
+ int ll_row1 = dw_item.GetRow();
+ dw_list.InsertRow(0);
+ int ll_row = dw_list.GetRowCount();
+
+ KXMLDOMElement e = dw_item.GetRowElement(ll_row1);
+ dw_list.SetItemString(ll_row, L"SupplierID", dw_item.GetItemString(ll_row1, L"SupplierID"));
+ dw_list.SetItemDisplayString(ll_row, L"SupplierID", dw_item.GetItemDisplayString(ll_row1, L"SupplierID"));
+ dw_list.SetItemString(ll_row, L"CQuantity", dw_item.GetItemString(ll_row1, L"CustQuantity"));
+ dw_list.SetItemString(ll_row, L"Amount", dw_item.GetItemString(ll_row1, L"Amount"));
+ dw_list.SetItemString(ll_row, L"ClassifyID", dw_item.GetItemString(ll_row1, L"ClassifyID"));
+ dw_list.SetItemDisplayString(ll_row, L"ClassifyID", dw_item.GetItemDisplayString(ll_row1, L"ClassifyID"));
+ dw_list.SetItemString(ll_row, L"CName", dw_item.GetItemDisplayString(ll_row1, L"ClassifyID"));
+ if (e.selectSingleNode(L"Quantity")) dw_list.SetItemString(ll_row, L"Quantity", e.selectSingleNode(L"Quantity").text());
+ if (e.selectSingleNode(L"CreatorID")) dw_list.SetItemString(ll_row, L"CreatorID", e.selectSingleNode(L"CreatorID").text());
+ if (e.selectSingleNode(L"CreateDate")) dw_list.SetItemString(ll_row, L"CreateDate", e.selectSingleNode(L"CreateDate").text());
+ if (e.selectSingleNode(L"ModifierID")) dw_list.SetItemString(ll_row, L"ModifierID", e.selectSingleNode(L"ModifierID").text());
+ if (e.selectSingleNode(L"ModifyDate")) dw_list.SetItemString(ll_row, L"ModifyDate", e.selectSingleNode(L"ModifyDate").text());
+ if (e.selectSingleNode(L"VATRate")) dw_list.SetItemString(ll_row, L"VATRate", e.selectSingleNode(L"VATRate").text());
+ if (e.selectSingleNode(L"VATRefundRate")) dw_list.SetItemString(ll_row, L"VATRefundRate", e.selectSingleNode(L"VATRefundRate").text());
+ if (e.selectSingleNode(L"CustomUOM")) dw_list.SetItemString(ll_row, L"CQtyUnit", e.selectSingleNode(L"CustomUOM").text());
+ if (e.selectSingleNode(L"IsFinish")) dw_list.SetItemString(ll_row, L"IsFinish", e.selectSingleNode(L"IsFinish").text());
+ if (e.selectSingleNode(L"Type")) dw_list.SetItemString(ll_row, L"Type", e.selectSingleNode(L"Type").text());
+ if (e.selectSingleNode(L"InvoiceNo")) dw_list.SetItemString(ll_row, L"InvoiceNo", e.selectSingleNode(L"InvoiceNo").text());
+ dw_list.Redraw();
+ dw_item.SetItemString(ll_row1, L"Relation", xstring(ll_row));
+ dw_item.Redraw();
+ return 1;
+ }
+
+ int OnReplaceSupplier()
+ {
+ int ll_row = dw_list.GetRow();
+ int ll_row1 = dw_item.GetRow();
+
+ if (ll_row < 1 || ll_row1 < 1)
+ {
+ alert(L"没有操作!");
+ return 1;
+ }
+ xstring SupplierID1 = dw_item.GetItemString(ll_row1, L"SupplierID");
+ dw_list.SetItemString(ll_row, L"SupplierID", SupplierID1);
+ dw_list.SetItemDisplayString(ll_row, L"SupplierID", dw_item.GetItemDisplayString(ll_row1, L"SupplierID"));
+ dw_list.Redraw();
+ return 1;
+ }
+
+ int OnReplaceRow()
+ {
+ int ll_row = dw_list.GetRow();
+ int ll_row1 = dw_item.GetRow();
+ if (ll_row < 1 || ll_row1 < 1)
+ {
+ alert(L"没有操作!");
+ return 1;
+ }
+
+ bool updateSupplier = false;
+ bool updatePrice = false;
+ bool updateClassifyID = false;
+ xstring SupplierID = dw_list.GetItemString(ll_row, L"SupplierID");
+ xstring CQuantity = dw_list.GetItemString(ll_row, L"CQuantity");
+ xstring Amount = dw_list.GetItemString(ll_row, L"Amount");
+ xstring ClassifyID = dw_list.GetItemString(ll_row, L"ClassifyID");
+
+ xstring SupplierID1 = dw_item.GetItemString(ll_row1, L"SupplierID");
+ xstring CQuantity1 = dw_item.GetItemString(ll_row1, L"CustQuantity");
+ xstring Amount1 = dw_item.GetItemString(ll_row1, L"Amount");
+ xstring ClassifyID1 = dw_item.GetItemString(ll_row1, L"ClassifyID");
+
+ if (SupplierID != SupplierID1) updateSupplier = true;
+ if (CQuantity != CQuantity1) updatePrice = true;
+ if (Amount != Amount1) updatePrice = true;
+ if (ClassifyID != ClassifyID1) updateClassifyID = true;
+
+ if (updateSupplier && updatePrice && updateClassifyID)
+ {
+ int res = MessageBox(GetHWND(), L"上下数据报关品名、价格、工厂全不一致,是否要强制替换?", L"提示", 4);
+ if (res != 6) return 1;
+ }
+ if (updateSupplier)
+ {
+ dw_list.SetItemString(ll_row, L"SupplierID", SupplierID1);
+ dw_list.SetItemDisplayString(ll_row, L"SupplierID", dw_item.GetItemDisplayString(ll_row1, L"SupplierID"));
+ }
+ if (updatePrice)
+ {
+ dw_list.SetItemString(ll_row, L"CQuantity", CQuantity1);
+ dw_list.SetItemString(ll_row, L"Amount", Amount1);
+ }
+ if (updateClassifyID)
+ {
+ dw_list.SetItemString(ll_row, L"ClassifyID", ClassifyID);
+ dw_list.SetItemDisplayString(ll_row, L"ClassifyID", dw_item.GetItemDisplayString(ll_row1, L"ClassifyID"));
+ dw_list.SetItemString(ll_row, L"CName", dw_item.GetItemDisplayString(ll_row1, L"ClassifyID"));
+ }
+ dw_list.Redraw();
+ dw_item.SetItemString(ll_row1, L"Relation",xstring(ll_row));
+ dw_item.Redraw();
+ return 1;
+ }
+
+ //命令处理事件
+ int OnXCommand(TEvent* evt, LPARAM param)
+ {
+ return OnCmdDispatch(evt->xcommand.pStrID);
+ }
+
+ int OnAttachEvent()
+ {
+ //绑定工具条点击事件
+ AttachEvent(L"WM_XCOMMAND", (FEvent)&UpdateVatNotifyWin::OnXCommand);
+ //获取焦点事件,用于重置工具条
+ AttachEvent(L"WM_SETFOCUS", (FEvent)&UpdateVatNotifyWin::OnSetFocus);
+ AttachEvent(L"dw_item", L"DWV_ROWFOCUSCHANGED", (FEvent)&UpdateVatNotifyWin::OnRowChanged);
+
+ }
+
+ int RetrieveCustomSource(xstring classifyID, xstring supplierID)
+ {
+ xml x ;
+
+ xaserverarg arg ;
+
+ if (GetWinParam())
+ {
+ int pArg = GetArg();
+
+ }
+ else
+ arg.AddArg(L"invoiceno", L"15HDLD0720");
+
+ arg.AddArg(L"ClassifyID", classifyID);
+ arg.AddArg(L"SupplierID", supplierID);
+ if (getUrl(L"/sale/data/VATNotify/pref/CustomSource", 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_goods.Retrieve(x);
+ dw_goods.Redraw();
+ }
+ }
+
+ int OnRowChanged(TEvent* evt, LPARAM p)
+ {
+ DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
+ int row = hdr.row;
+
+ if (row < 1) return 1;
+ KXMLDOMElement e = dw_item.GetRowElement(row);
+ xstring classifyID = e.selectSingleNode(L"ClassifyID").text();
+ xstring supplierID = e.selectSingleNode(L"SupplierID").text();
+ e.Release();
+ RetrieveCustomSource(classifyID, supplierID);
+
+ return 1;
+ }
+
+ int OnRetrieve()
+ {
+ xml x ;
+
+ xaserverarg arg;
+
+ if (GetWinParam())
+ {
+ int pArg = GetArg();
+
+ }
+ else
+ arg.AddArg(L"invoiceno", L"15HDLD0720");
+ if (getUrl(L"/sale/data/VATNotify/entity/base/miss", arg.GetString(), x) != 1)
+ {
+ trace(x.text());
+ //return -1;
}
else
{
- MessageBoxW(GetHWND(), L"删除成功!", L"提示", 0);
- listwin::dw_list.DeleteRow(row);
+ //alert(x.xml);
+ dw_list.Retrieve(x);
+ dw_list.Redraw();
}
- }
- 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)
+ if (getUrl(L"/sale/data/VATNotify/pref/GdnInvoice", arg.GetString(), x) != 1)
{
- GoodsUrl = L"/sale/data/SupplierV3/entity/supplieritemEx";
+ trace(x.text());
+ return -1;
}
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)
+ dw_item.Retrieve(x);
+ dw_item.Redraw();
+ dw_item.SetReadOnly(true);
+ if (dw_item.GetRowCount() > 0)
{
-
- 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);
-
+ KXMLDOMElement e = dw_item.GetRowElement(1);
+ xstring classifyID = e.selectSingleNode(L"ClassifyID").text();
+ xstring supplierID = e.selectSingleNode(L"SupplierID").text();
+ e.Release();
+ trace(L"!" + classifyID + L" " + supplierID);
+ RetrieveCustomSource(classifyID, supplierID);
}
}
+ return 1;
}
- return 1;
- }
+ int onload()
+ {
+ dw_list = GetControl(L"dw_list");
+ dw_list.openUrl(L"/sale/view/VATNotify/template/VATNotify/item");
+ dw_item = GetControl(L"dw_item");
+ dw_item.openUrl(L"/sale/view/VATNotify/template/VATNotify/DItem");
+ dw_goods = GetControl(L"dw_goods");
+ dw_goods.openUrl(L"/sale/view/VATNotify/template/VATNotify/DItem1");
- int onloaded()
- {
- AttachEvent(L"dw_list", L"DWV_ROWFOCUSCHANGED", (FEvent)&listSupplierv3::OnRowChangedEx);
- 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;
- }
+ OnRetrieve();
+ OnAttachEvent();
-};
\ No newline at end of file
+ return 1;
+ }
+
+ int onloaded()
+ {
+ //SetAgent();
+
+ return 1;
+ }
+ };
--
Gitblit v1.9.3