From 6e93e717799723de98287f5a036ab34367bd08cd Mon Sep 17 00:00:00 2001 From: xj qian <qianxj15@sina.com> Date: 星期五, 05 七月 2024 17:15:44 +0800 Subject: [PATCH] update some --- jrj/project/business/AR/maint.SettlementExchange.cpp | 246 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 246 insertions(+), 0 deletions(-) diff --git a/jrj/project/business/AR/maint.SettlementExchange.cpp b/jrj/project/business/AR/maint.SettlementExchange.cpp new file mode 100644 index 0000000..9182934 --- /dev/null +++ b/jrj/project/business/AR/maint.SettlementExchange.cpp @@ -0,0 +1,246 @@ +#include <wobject/xstring.hpp> +#include <xcontrol/xtreeview.hpp> +#include <xcontrol/xdwgrid.hpp> +#include <wobject/xdouble.hpp> + +#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp" +#include "viewobject/view.base.hpp" + +using xml = KXMLDOMDocument; + class __declspec(dllexport) SettlementExchangeEdit : public xframe + { + public: + xdwtable dw_base; + + xnode m_agentNode; //Agent Condition + HWND hObject; + bool updated; + + public: + SettlementExchangeEdit(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {} + public: + static SettlementExchangeEdit* CreateInstance(void* implPtr, void* hWnd) + { + SettlementExchangeEdit* pWin = new SettlementExchangeEdit(implPtr, (HWND)hWnd); + return pWin; + } + + int SetAgent() + { + xstring xfNodeAgentArea = L"agentarea"; + xnode anode = GetAgentNode(xfNodeAgentArea); + if (m_agentNode) + { + SetAgentNode(anode, m_agentNode); + } + else + { + KXMLDOMElement xframeElement = GetElement(); + KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*"); + if (agent) + { + xstring s = agent.xml(); + m_agentNode = SetAgentNode(anode, s); + } + } + return 1; + } + + //焦点激活处理函数 + int OnSetFocus(TEvent* evt, LPARAM param) + { + //重置工具条 + SetAgent(); + return 1; + } + int OnSave(bool dlg = true) + { + xml x; + + dw_base.AcceptText(); + dw_base.DwUpdateAllTo(x); + xaserverarg arg ; + + arg.AddArg(L"content", x.xml()); + //alert(x.xml()); + if (xurl::get(L"/sale/data/AR/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(); + dw_base.Redraw(); + updated = true; + if (dlg)alert(L"保存成功!"); + + //SendMessage(hObject,0x401,L"xmSignEx:"+dw_base.GetGuid(1),0); + SendMessage(hObject, 0x401, (LPARAM)L"xmRefresh", 0); + //CloseWindow(); + } + else + { + alert(L"保存失败!"); + return -1; + } + return 1; + } + //命令发布函数 + int OnCmdDispatch(xstring comdid) + { + if (comdid == L"xmClose") + { + if (updated) + SendMessage(hObject, 0x401, (LPARAM)L"xmRefresh", 0); + CloseWindow(); + return 1; + } + else if (comdid == L"xmSave") + { + OnSave(); + return 1; + } + else if (comdid == L"xmSign") + { + return OnSign(); + } + + return 0; + } + + int OnSign() + { + xaserverarg arg ; + arg.setNativePointer(arg.CreateInstance()); + + xml x; + + dw_base.AcceptText(); + dw_base.DwUpdateAllTo(x); + if (x.selectSingleNode(L"//*[@update.modify='1']")) + if (OnSave(false) == -1) return 1; + + if (dw_base.GetGuid(1) == L"") + { + alert(L"请先保存,在签收!"); + return 1; + } + + OnRetrieve(dw_base.GetGuid(1)); + + if (dw_base.GetItemString(1, L"CustomerID") == L"") + { + alert(L"客户不允许未空!"); + return 1; + } + arg.AddArg(L"CustomerID", dw_base.GetItemString(1, L"CustomerID")); + arg.AddArg(L"SEID", dw_base.GetGuid(1)); + SendMessage(hObject, 0x401, L"xmSignEx:" + dw_base.GetGuid(1), 0); + return 1; + } + + int OnItemChanged(TEvent* evt, LPARAM p) + { + DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh; + xstring colname = hdr.colname; + xstring value = hdr.data; + + xstring dwname = L"dw_base"; + + if (colname == L"Amount" || colname == L"ForeignBankDeduction" || colname == L"BankDeduction" || colname == L"BankRMBDeduction") + { + double Amount = dw_base.GetItemDouble(hdr.row, L"Amount"); + double ForeignBankDeduction = dw_base.GetItemDouble(hdr.row, L"ForeignBankDeduction"); + double BankDeduction = dw_base.GetItemDouble(hdr.row, L"BankDeduction"); + double CustomerCapitalExpense = dw_base.GetItemDouble(hdr.row, L"CustomerCapitalExpense"); + double PressureExchangeRate = dw_base.GetItemDouble(hdr.row, L"PressureExchangeRate"); + //double BankRMBDeduction = dw_base.GetItemDouble(hdr.row,L"BankRMBDeduction"); + dw_base.SetItemDouble(hdr.row, L"AmountEx", xdouble((Amount + ForeignBankDeduction + BankDeduction + CustomerCapitalExpense)).round(2)); + } + return 1; + } + + //命令处理事件 + int OnXCommand(TEvent* evt, LPARAM param) + { + return OnCmdDispatch(evt->xcommand.pStrID); + } + + int OnAttachEvent() + { + //绑定工具条点击事件 + AttachEvent(L"WM_XCOMMAND", (FEvent)&SettlementExchangeEdit::OnXCommand); + //获取焦点事件,用于重置工具条 + AttachEvent(L"WM_SETFOCUS", (FEvent)&SettlementExchangeEdit::OnSetFocus); + AttachEvent(L"dw_base", L"DWV_ITEMCHANGED", (FEvent)&SettlementExchangeEdit::OnItemChanged); + return 1; + } + + + int OnRetrieve(xstring SettlementExchangeID) + { + xml x; + + xaserverarg arg ; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg(L"SEID", SettlementExchangeID); + + if (getUrl(L"/sale/data/AR/se/getsebyid", arg.GetString(), x) != 1) + { + 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/AR/template/SEMaint"); + dw_base.SetColHeaderHeight(0); + dw_base.SetRowSelectorWidth(0); + dw_base.SetHScrollState(false); + dw_base.SetVScrollState(false); + xstring SettlementExchangeID = L""; + hObject = 0; + if (GetWinParam()) + { + xaserverarg arg =GetArg(); + SettlementExchangeID = arg.GetArgString(L"SettlementExchangeID"); + hObject = arg.GetArgString(L"HWND").toInt(); + } + if (SettlementExchangeID != L"") + { + //alert(SettlementExchangeID); + OnRetrieve(SettlementExchangeID); + } + else + { + xstring suserid = publiccode::GetUser().id; + xstring susername = publiccode::GetUser().name; + xstring sdate = publiccode::GetCurrentDate(); + dw_base.SetItemString(1, L"SEDate", sdate); + dw_base.SetItemString(1, L"CreateDate", sdate); + dw_base.SetItemString(1, L"CurrencyCode", L"USD"); + dw_base.SetItemString(1, L"CreatorID", suserid); + dw_base.SetItemDisplayString(1, L"CreatorID", susername); + } + OnAttachEvent(); + updated = false; + return 1; + } + + int onloaded() + { + SetAgent(); + + return 1; + } + }; -- Gitblit v1.9.3