From 549b3fa73926b4c35043545921dba68d011c6f92 Mon Sep 17 00:00:00 2001
From: LiFan <2308045698@qq.com>
Date: 星期五, 05 七月 2024 14:48:43 +0800
Subject: [PATCH] update

---
 jrj/project/business/Public/UserGroupShareEx.cpp |  154 ++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 108 insertions(+), 46 deletions(-)

diff --git a/jrj/project/business/Public/UserGroupShareEx.cpp b/jrj/project/business/Public/UserGroupShareEx.cpp
index 1898a28..b5c2461 100644
--- a/jrj/project/business/Public/UserGroupShareEx.cpp
+++ b/jrj/project/business/Public/UserGroupShareEx.cpp
@@ -1,90 +1,152 @@
-class SearchDlg :  public xframe
-	{
-		xnode	m_agentNode;	//Agent Condition
+#include <wobject/xstring.hpp>
+#include <xcontrol/xtreeview.hpp>
+#include <xcontrol/xdwgrid.hpp>
 
-		xcontrol sle_1;
-	
+#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp"
+#include "viewobject/view.base.hpp"
+
+using xml = KXMLDOMDocument;
+	class __declspec(dllexport) UserGroupShareExWin : public xframe
+	{
+	public:
+		xdwgrid	dw_list;
+		xnode	m_agentNode;	//Agent Condition
+	public:
+		UserGroupShareExWin(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+	public:
+		static UserGroupShareExWin* CreateInstance(void* implPtr, void* hWnd)
+		{
+			UserGroupShareExWin* pWin = new UserGroupShareExWin(implPtr, (HWND)hWnd);
+			return pWin;
+		}
 		int SetAgent()
 		{
-			string xfNodeAgentArea  = "agentarea";
+			xstring xfNodeAgentArea = L"agentarea";
 			xnode anode = GetAgentNode(xfNodeAgentArea);
-			if(m_agentNode)
+			if (m_agentNode)
 			{
-				SetAgentNodeContent (anode,m_agentNode);
+				SetAgentNode(anode, m_agentNode);
 			}
 			else
 			{
-				msxml::IXMLDOMElement xframeElement =  GetElement();
-				msxml::IXMLDOMElement agent = xframeElement.selectSingleNode("agent/"+xfNodeAgentArea+"[1]/*");
-				if(agent)
+				KXMLDOMElement xframeElement = GetElement();
+				KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*");
+				if (agent)
 				{
-					string s = agent.xml;
-					m_agentNode =  SetAgentNodeContent (anode,s);
+					xstring s = agent.xml();
+					m_agentNode = SetAgentNode(anode, s);
 				}
 			}
 			return 1;
 		}
 
 		//焦点激活处理函数
-		int OnSetFocus(ref TEvent evt,int param)
+		int OnSetFocus(TEvent* evt, LPARAM param)
 		{
 			//重置工具条
 			//SetAgent();
 			return 1;
 		}
-				
-		int OnOk()
+		int OnOK()
 		{
-			if(GetParam())
-			{
-				xaserverarg arg = GetParam();
-				arg.AddArg("text",GetControl("sl_search").GetText());
-				CloseWindow();
-			}
+			xaserverarg arg = GetArg();
+			arg.AddArg(L"process", L"ok");
+
+			xml x = xml::Make();
+			dw_list.DwUpdateAllToEx(x);
+			arg.AddArg(L"result", x.xml());
+			x.Free();
+			CloseWindow();
 			return 1;
 		}
-
 		//命令发布函数
-		int OnCmdDispatch(string comdid)
+		int OnCmdDispatch(xstring comdid)
 		{
-			if(comdid=="xmCancel")
+			if (comdid == L"xmCancel")
 			{
 				CloseWindow();
 				return 1;
 			}
-			else if(comdid=="xmOk") return OnOk();
+			if (comdid == L"xmOK") return OnOK();
+			if (comdid == L"xmMemberAdd" || comdid == L"xmAdd")
+			{
+				xaserverarg arg;
+				
+				xaserverarg parg = GetArg();
+				if (comdid == L"xmMemberAdd")
+					OpenWindow(L"dev:xpage[UserGroupPersonSelect.vx]",arg);
+				else
+					OpenWindow(L"dev:xpage[UserGroupSelect.vx]", arg);
+				if (arg.GetArgString(L"comdid") == L"xmOk")
+				{
+					xstring data = arg.GetArgString(L"data");
+					xml x;
+					
+					x.loadXML(data);
+					KXMLDOMNodeList nodes = x.selectNodes(L"/root/item");
+					int len = nodes.length();
+					for (int i = 0; i < len; i++)
+					{
+						dw_list.InsertRow(0);
+						int row = dw_list.GetRowCount();
+						KXMLDOMElement ele = nodes.item(i);
+
+						dw_list.SetItemString(row, L"Name", ele.getAttribute(L"Name"));
+
+						if (comdid == L"xmMemberAdd")
+						{
+							dw_list.SetItemString(row, L"No", ele.getAttribute(L"No"));
+							dw_list.SetItemString(row, L"PersonID", ele.getAttribute(L"PersonID"));
+						}
+						else
+						{
+							xstring no = ele.getAttribute(L"NO");
+							dw_list.SetItemString(row, L"No", L"[" + no + L"]");
+							dw_list.SetItemString(row, L"UserGroupID", ele.getAttribute(L"UserGroupID"));
+						}
+					}
+					dw_list.Redraw();
+				}
+				return 1;
+			}
+			if (comdid == L"xmDelete")
+			{
+				dw_list.DeleteRow(0);
+				return 1;
+			}
 			return 0;
 		}
-		
+
 		//命令处理事件
-		int OnXCommand(ref TXCommandEvent evt,int param)
+		int OnXCommand(TEvent* evt, LPARAM param)
 		{
-			return OnCmdDispatch(evt.pStrID);
+			return OnCmdDispatch(evt->xcommand.pStrID);
 		}
-		
+
 		int OnAttachEvent()
 		{
 			//绑定工具条点击事件
-			AttachEvent("WM_XCOMMAND",OnXCommand);
+			AttachEvent(L"WM_XCOMMAND", (FEvent)&UserGroupShareExWin::OnXCommand);
 			//获取焦点事件,用于重置工具条
-			AttachEvent("WM_SETFOCUS",OnSetFocus);
+			AttachEvent(L"WM_SETFOCUS", (FEvent)&UserGroupShareExWin::OnSetFocus);
 		}
-	
+
 		int onload()
 		{
-			sle_1 = GetControl("sl_search");
-			int x = win32::GetWindowLong(sle_1.GetId(), -16); //GWL_STYLE
-			x = x+ 0x0008;
-			win32::SetWindowLong(sle_1.GetId(), -16,x);//sle_1是编辑窗口控件
-			
+			dw_list = GetControl(L"dw_list");
+			dw_list.openUrl(L"/sale/view/UserGroup/template/entityusergrouplist");
+			dw_list.SetReadOnly(true);
+
+			dw_list.SetColumnState(L"UserGroupID", false);
+			dw_list.SetColumnState(L"EntityID", false);
+			dw_list.SetColumnState(L"EntityName", false);
+			dw_list.SetColumnState(L"PersonID", false);
+
 			OnAttachEvent();
-			if(GetParam())
-			{
-				xaserverarg arg = GetParam();
-				GetControl("sl_search").SetText(arg.GetArgString("text"));
-			}
-			
+
+			//SetAgent();	
+
 			return 1;
 		}
-		
-	};
\ No newline at end of file
+
+	};

--
Gitblit v1.9.3