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/Public/UserGroupPersonSelect.cpp |  151 ++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 151 insertions(+), 0 deletions(-)

diff --git a/jrj/project/business/Public/UserGroupPersonSelect.cpp b/jrj/project/business/Public/UserGroupPersonSelect.cpp
new file mode 100644
index 0000000..739febc
--- /dev/null
+++ b/jrj/project/business/Public/UserGroupPersonSelect.cpp
@@ -0,0 +1,151 @@
+#include <wobject/xstring.hpp>
+#include <xcontrol/xtreeview.hpp>
+#include <xcontrol/xdwgrid.hpp>
+
+#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp"
+#include "viewobject/view.base.hpp"
+
+using xml = KXMLDOMDocument;
+	class __declspec(dllexport) UserGroupPersonSelectWin : public xframe
+	{
+	public:
+		xdwgrid	dw_list;
+
+		xnode	m_agentNode;	//Agent Condition
+		xstring	m_sTxt;
+	public:
+		UserGroupPersonSelectWin(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+	public:
+		static UserGroupPersonSelectWin* CreateInstance(void* implPtr, void* hWnd)
+		{
+			UserGroupPersonSelectWin* pWin = new UserGroupPersonSelectWin(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  OnRetrieve()
+		{
+			xcontrol xc = GetControl(L"QueryTxt");
+			m_sTxt = xc.GetText() + L"";
+			xml x;
+			
+			xaserverarg arg;
+			
+			arg.AddArg(L"sTxt", m_sTxt);
+			if (xurl::post(L"OrganizationStruct/select.Person", arg.GetString(), x) != 1)
+			{
+				trace(x.text());
+				return -1;
+			}
+			else
+			{
+				dw_list.Retrieve(x);
+				dw_list.Redraw();
+				dw_list.SetReadOnly(true);
+			}
+			return 1;
+		}
+
+		int OnOK()
+		{
+			xaserverarg arg = GetArg();
+			arg.AddArg(L"comdid", L"xmOk");
+			int row = dw_list.GetNextSelectRow(1);
+			if (row < 1)
+			{
+				alert(L"请选择人员!");
+				return 1;
+			}
+
+			xstring str = L"<root>";
+			while (row > 0 && row <= dw_list.GetRowCount())
+			{
+				KXMLDOMElement e = dw_list.GetRowElement(row);
+				xstring PersonID = e.selectSingleNode(L"PersonID").text() + xstring(L"");
+				xstring Name = e.selectSingleNode(L"Name").text() + xstring(L"");
+				xstring No = e.selectSingleNode(L"EmployeeNo").text() + xstring(L"");
+				str += L"<item PersonID='" + PersonID + L"' Name='" + Name + L"' No='" + No + L"'/>";
+				row = dw_list.GetNextSelectRow(row + 1);
+			}
+			str += L"</root>";
+			arg.AddArg(L"data", str);
+			CloseWindow();
+			return 1;
+		}
+
+		//命令发布函数
+		int OnCmdDispatch(xstring comdid)
+		{
+			if (comdid == L"xmOk")
+				OnOK();
+			else if (comdid == L"query")
+			{
+				OnRetrieve();
+			}
+			else if (comdid == L"xmCancel")
+				CloseWindow();
+			return 0;
+		}
+
+		//命令处理事件
+		int OnXCommand(TEvent* evt, LPARAM param)
+		{
+			return OnCmdDispatch(evt->xcommand.pStrID);
+		}
+
+		int OnAttachEvent()
+		{
+			//绑定工具条点击事件
+			AttachEvent(L"WM_XCOMMAND", (FEvent)&UserGroupPersonSelectWin::OnXCommand);
+			//获取焦点事件,用于重置工具条
+			AttachEvent(L"WM_SETFOCUS", (FEvent)&UserGroupPersonSelectWin::OnSetFocus);
+			return 1;
+		}
+
+		int OnInitial()
+		{
+			//SetAgent();
+			OnAttachEvent();
+			return 1;
+		}
+
+		int onload()
+		{
+			dw_list = GetControl(L"dw_list");
+			dw_list.openUrl(L"组织架构.vface/template/HrEmployee/PersonSel");
+			dw_list.SetSelectionMode(3);
+			dw_list.SetReadOnly(true);
+
+			OnInitial();
+			OnRetrieve();
+
+			return 1;
+		}
+	};

--
Gitblit v1.9.3