From b1d01ea6fa62ce12c2e592b3315186f6b3c8359d Mon Sep 17 00:00:00 2001
From: xj qian <qianxj15@sina.com>
Date: 星期三, 17 七月 2024 15:20:38 +0800
Subject: [PATCH] Merge branch 'master' of http://116.62.18.175:6699/r/mis-prj

---
 jrj/project/business/SystemSettings/FlowTermSelect.cpp |  176 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 176 insertions(+), 0 deletions(-)

diff --git a/jrj/project/business/SystemSettings/FlowTermSelect.cpp b/jrj/project/business/SystemSettings/FlowTermSelect.cpp
new file mode 100644
index 0000000..ce9d2bb
--- /dev/null
+++ b/jrj/project/business/SystemSettings/FlowTermSelect.cpp
@@ -0,0 +1,176 @@
+#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) FlowTermSelect :  public xframe
+	{
+	public:
+		xdwgrid	dw_list;
+		xstring stype;
+		xstring sdata;
+		xstring flowid;
+		xstring datacolumn;
+		xstring displaycolumn;
+	
+		xnode	m_agentNode;	//Agent Condition
+	public:
+		FlowTermSelect(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+	public:
+		static FlowTermSelect* CreateInstance(void* implPtr, void* hWnd)
+		{
+			FlowTermSelect* pWin = new FlowTermSelect(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 OnOK(xstring comdid)
+		{
+			xaserverarg arg ;		
+			arg = GetArg();
+
+			arg.AddArg(L"comdid",comdid);	
+
+			int row = dw_list.GetNextSelectRow(1);
+			if(row < 1 && dw_list.GetRowCount()==1) row = 1;
+			if (row<1)
+			{
+				alert(L"请选择项!");
+				return 1;
+			}	
+			
+			while (row>0)
+			{			
+				KXMLDOMElement e = dw_list.GetRowElement(row);
+				xstring data = e.selectSingleNode(datacolumn).text()+(xstring)L"";
+				xstring display = e.selectSingleNode(displaycolumn).text()+ (xstring)L"";
+				arg.AddArg(L"data",data);
+				arg.AddArg(L"display",display);						
+				row = dw_list.GetNextSelectRow(row + 1);
+			}
+			CloseWindow();
+			return 1;
+		}
+				
+		//命令发布函数
+		int OnCmdDispatch(xstring comdid)
+		{
+			if (comdid==L"xmOk")
+			{
+				OnOK(comdid);
+				return 1;
+			}
+			else 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)&FlowTermSelect::OnXCommand);
+			//获取焦点事件,用于重置工具条
+			AttachEvent(L"WM_SETFOCUS", (FEvent)&FlowTermSelect::OnSetFocus);
+			return 1;
+		}
+		
+		int  OnRetrieve()
+		{
+			xml x ;
+			
+			xaserverarg arg ;
+			;	
+			
+			arg.AddArg(L"stype",stype);
+			arg.AddArg(L"sdata",sdata);
+			arg.AddArg(L"flowID",flowid);
+
+			if (getUrl(L"/sale/data/Flow3/retrieve/flowex",arg.GetString(),x)!=1)
+			{
+				trace(x.text());
+				return -1;
+			}else	
+			{
+				dw_list.Retrieve(x);
+				dw_list.Redraw();
+				dw_list.SetReadOnly(true);
+			}
+			return 1;
+		}
+		
+		int onload()
+		{
+			SetArg();
+			dw_list = GetControl(L"dw_list");
+			//dw_list.openUrl(L"xxx");
+			if(GetWinParam())
+			{
+				xaserverarg arg = GetArg();
+				stype = arg.GetArgString(L"stype");
+				sdata = arg.GetArgString(L"sdata");
+				flowid = arg.GetArgString(L"flowid");
+			
+				datacolumn = arg.GetArgString(L"datacolumn");
+				displaycolumn = arg.GetArgString(L"displaycolumn");
+			
+				xstring dwname = arg.GetArgString(L"dwname");
+				dw_list.openUrl(dwname);
+				OnRetrieve();
+				dw_list.SetSelectionMode(1);
+			}
+		
+			OnAttachEvent();	
+			
+			return 1;
+		}
+		
+		int onloaded()
+		{
+			//SetAgent();			
+			
+			return 1;
+		}		
+	};
\ No newline at end of file

--
Gitblit v1.9.3