From 7a91c3a1ed37b0332d4ff0ebeae60bd6da3665c0 Mon Sep 17 00:00:00 2001 From: xj qian <qianxj15@sina.com> Date: 星期二, 16 七月 2024 18:28:58 +0800 Subject: [PATCH] Merge branch 'master' of http://116.62.18.175:6699/r/mis-prj --- jrj/project/business/BasicCode/ExchangeRate.cpp | 226 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 226 insertions(+), 0 deletions(-) diff --git a/jrj/project/business/BasicCode/ExchangeRate.cpp b/jrj/project/business/BasicCode/ExchangeRate.cpp new file mode 100644 index 0000000..51e0e26 --- /dev/null +++ b/jrj/project/business/BasicCode/ExchangeRate.cpp @@ -0,0 +1,226 @@ +#include <wobject/xstring.hpp> +#include <xcontrol/xtreeview.hpp> +#include <xcontrol/xdwgrid.hpp> +#include <wobject/xdouble.hpp> +#include <xcontrol/xlayersheet.hpp> +#include <xcontrol/xdatetimepick.hpp> + + +#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp" +#include "viewobject/view.base.hpp" + +using xml = KXMLDOMDocument; + class __declspec(dllexport) ExchangeRateWin : public xframe + { + public: + xdwgrid dw_list; + int hSignWin; + xnode m_agentNode; //Agent Condition + public: + ExchangeRateWin(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {} + public: + static ExchangeRateWin* CreateInstance(void* implPtr, void* hWnd) + { + ExchangeRateWin* pWin = new ExchangeRateWin(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() + { + xml x = new xml; + + dw_list.AcceptText(); + dw_list.DwUpdateAllToEx(x); + xml x0; + x0.loadXML(L"<data/>"); + + KXMLDOMNodeList t = x.selectNodes(L"data/Item[@update.modify='1' or @update.delete ='1']"); + KXMLDOMElement e1= x0.documentElement(); + int len = t.length(); + for(int i=0;i<len;i++) + { + e1.appendChild(t.item(i)); + } + xaserverarg arg ; + arg.AddArg(L"content",x0.xml()); + trace(x0.xml()); + if(xurl::get(L"/sale/data/expense3/update/ExchangeRate", 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 OnCmdDispatch(xstring comdid) + { + if(comdid==L"xmAddRow") + { + xstring sdate = publiccode::GetCurrentDate(); + xstring suserid = publiccode::GetUser().id; + xstring susername = publiccode::GetUser().name; + int row =dw_list.GetRowCount(); + dw_list.InsertRow(0); + dw_list.SetItemString(row+1,L"CreatorID",suserid); + dw_list.SetItemDisplayString(row+1,L"CreatorID",susername); + dw_list.SetItemString(row+1,L"CreateDate",sdate); + return 1; + } + else if(comdid==L"xmDeleteRow") + { + dw_list.DeleteRow(0); + return 1; + } + else if (comdid == L"xmSave") + { + OnSave(); + } + else if (comdid == L"xmRefresh") + { + OnRetrieve(); + } + else if(comdid ==L"ToUpdate") + { + ToUpdate(); + } + + return 0; + } + + + int ToUpdate() + { + xstring Months = dw_list.GetItemString(dw_list.GetRow(),L"Months"); + int MB_OKCANCEL = 1; + int IDOK = 1; + int ret = MessageBox(GetHWND(),L"确认更新"+Months+L"盈亏汇率?",L"提示",MB_OKCANCEL); + if(ret == IDOK) + { + xml x = ViewObject::RetrieveData(L"/sale/data/Expense3/ExchangeRateUpdateEx",L"Months",Months); + xstring status = x.xml(); + if(status.find(L"ok") == 1) + { + alert(L"更新成功"); + }else + { + alert(L"更新失败"); + } + } + return 1; + } + + //触发鼠标离开后tran事件,通过查找某个参数得到对应的列 + int OnBaseItemChanged(TEvent* evt, int p) + { + DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh; + xstring colname=hdr.colname; + xstring value = hdr.data; + + xstring dwname = L"dw_list"; + if(value != L"") + { + KXMLDOMNodeList nlist = GetElement().selectNodes(L"//*[@name='"+dwname+L"']/trans[@for='"+colname+L"']"); + ViewObject::TransData(nlist, dw_list, hdr.row, colname, value); + } + + return 1; + } + + + //命令处理事件 + int OnXCommand(TEvent* evt, LPARAM param) + { + return OnCmdDispatch(evt->xcommand.pStrID); + } + + int OnAttachEvent() + { + //绑定工具条点击事件 + AttachEvent(L"WM_XCOMMAND", (FEvent)&ExchangeRateWin::OnXCommand); + //获取焦点事件,用于重置工具条 + AttachEvent(L"WM_SETFOCUS", (FEvent)&ExchangeRateWin::OnSetFocus); + AttachEvent(L"dw_list",L"DWV_ITEMCHANGED", (FEvent)&ExchangeRateWin::OnBaseItemChanged); + return 1; + } + + + int OnRetrieve() + { + xml x = new xml; + + xaserverarg arg; + + arg.AddArg(L"QueryTxt",xcontrol(GetControl(L"search")).GetText()); + + + if (getUrl(L"/sale/data/Expense3/ExchangeRateList",arg.GetString(),x)!=1) + { + trace(x.text()); + return -1; + }else + { + dw_list.Retrieve(x); + dw_list.Redraw(); + } + return 1; + } + + int onload() + { + dw_list = GetControl(L"dw_list"); + dw_list.openUrl(L"/sale/view/Expense3/ExchangeRate"); + + + OnRetrieve(); + + OnAttachEvent(); + + return 1; + } + + int onloaded() + { + SetAgent(); + return 1; + } + }; \ No newline at end of file -- Gitblit v1.9.3