From 03ef0b51103c735077c784c7df81ae2bcc1599ab Mon Sep 17 00:00:00 2001
From: LiFan <2308045698@qq.com>
Date: 星期四, 13 二月 2025 18:33:56 +0800
Subject: [PATCH] update

---
 jrj/project/business/Company/HRPerson.cpp |  501 ++++++++++++++++++++++++++++---------------------------
 1 files changed, 253 insertions(+), 248 deletions(-)

diff --git a/jrj/project/business/Company/HRPerson.cpp b/jrj/project/business/Company/HRPerson.cpp
index 7b3e668..1d3883f 100644
--- a/jrj/project/business/Company/HRPerson.cpp
+++ b/jrj/project/business/Company/HRPerson.cpp
@@ -1,275 +1,280 @@
-use "win.vl"
-use "dev:vm[xdwgrid.vm]"
-use "pref.vl"
-use "dev:vm[xml.vm]"
-use "dev:vm[xaserverarg.vm]"
-use "dev:vm[xaserver.vm]"
-use "dev:vm[xutil.vm]"
-use "frame.vl"
-//unit vclient.vobject tpp
-unit vbusiness.xpage
-[
-	HrPerson is extend frame;
-	about HrPerson
-	[
-		control:
-		
-		method:
-		[
-			xdwgrid__	dw_list;
-			xdwgrid__	dw_HrEmployee;
-			string		m_sTxt;
+#include <wobject/xstring.hpp>
+#include <xcontrol/xtreeview.hpp>
+#include <xcontrol/xdwgrid.hpp>
+#include <wobject/xdouble.hpp>
+#include <xcontrol/xlayersheet.hpp>
 
-			xnode__	m_agentNode;	//Agent Condition
-			string	m_agentCond;	//Agent Node
-			int SetAgent()
+#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp"
+#include "viewobject/view.base.hpp"
+
+using xml = KXMLDOMDocument;
+class __declspec(dllexport) HrPerson : public xframe
+{
+public:
+	xdwgrid	dw_list;
+	xdwgrid	dw_HrEmployee;
+	xstring		m_sTxt;
+
+	xnode	m_agentNode;	//Agent Condition
+	xstring	m_agentCond;	//Agent Node
+public:
+	HrPerson(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+public:
+	static HrPerson* CreateInstance(void* implPtr, void* hWnd)
+	{
+		HrPerson* pWin = new HrPerson(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)
 			{
-				string xfNodeAgentArea  = "agentarea";
-				xnode__ anode = new xnode__;
-				anode.setNativePointer(GetAgentNode(xfNodeAgentArea));
-				var xframeElement =  GetElement();
-				var agent = xframeElement.selectSingleNode("agent/"+xfNodeAgentArea+"[1]/*");
-				if(agent)
-				{
-					string s = agent.xml;
-					SetAgentNodeContent (anode,s);
-				}
-				return 1;
+				xstring s = agent.xml();
+				m_agentNode = SetAgentNode(anode, s);
 			}
+		}
+		return 1;
+	}
+	//焦点激活处理函数
+	int OnSetFocus(TEvent* evt, LPARAM param)
+	{
+		SetAgent();
 
-			//焦点激活处理函数
-			int OnSetFocus(ref TEvent evt,int p)
-			{
-				SetAgent();
+		//重置工具条
+		return 1;
+	}
 
-				//重置工具条
-				return 1;
-			}
+	//xgridex双击
+	int OnDoubleClicked(TEvent* evt, int p)
+	{
+		DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
+		int row = hdr.row;
+		if (row < 1 || row > dw_list.GetRowCount())
+			return 1;
+		KXMLDOMElement e = dw_list.GetRowElement(row);
+		xstring sguid = e.selectSingleNode(L"@guid").text();
+		xaserverarg& arg = *new xaserverarg;
 
-			//xgridex双击
-			int OnDoubleClicked(ref TNotifyEvent evt,int p)
-			{
-				ref DWNMHDR  hdr = evt.pnmh;
-				int row = hdr.row;
-				if(row < 1 || row > dw_list.GetRowCount()) 
-					return 1;
-				msxml::IXMLDOMElement e = dw_list.GetRowElement(row);
-				string sguid =  e.SelectSingleNode("@guid").text;
-				xaserverarg__ arg = new xaserverarg__; 
-				arg.setNativePointer(arg.CreateInstance());	
-				arg.AddArg("operate","modify");
-				arg.AddArg("guid",sguid);
-				//trace(sguid);
-				//xwin::OpenWindow("dev:xpage[HrPersonMaint.xpage]",arg);
-				openUrl("组织架构.vface/xpage/Hr/HrPersonMaint", arg);		
-				return 1;
-			}
-			//行改变
-			int OnRowFocusChanged(ref TNotifyEvent evt,int p)
-			{
-				ref DWNMHDR  hdr = evt.pnmh;
-				int row = hdr.row;
-				if(row < 1 || row > dw_list.GetRowCount()) 
-					return 1;
-				msxml::IXMLDOMElement e = dw_list.GetRowElement(row);
-				string sPersonID =  e.SelectSingleNode("@guid").text;
-				xml__ x = new xml__;
-				x.setNativePointer(x.CreateInstance());
-				xaserverarg__ arg = new xaserverarg__;
-				arg.setNativePointer(arg.CreateInstance());	
-				arg.AddArg("guid",sPersonID);
-				
-				if (url::get("OrganizationStruct/Person.HrEmployee",arg.GetString(),x) != 1)
-				{
-					trace(x.GetXmlDoc().text);
-					return -1;
-				}else	
-				{
-					dw_HrEmployee.Retrieve(x);
-					dw_HrEmployee.Redraw();
-				}
-				
-				return 1;
-			}
+		arg.AddArg(L"operate", L"modify");
+		arg.AddArg(L"guid", sguid);
+		//trace(sguid);
+		//xwin::OpenWindow(L"dev:xpage[HrPersonMaint.xpage]",arg);
+		openUrl(L"组织架构.vface/xpage/Hr/HrPersonMaint", &arg);
+		return 1;
+	}
+	//行改变
+	int OnRowFocusChanged(TEvent* evt, int p)
+	{
+		DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
+		int row = hdr.row;
+		if (row < 1 || row > dw_list.GetRowCount())
+			return 1;
+		KXMLDOMElement e = dw_list.GetRowElement(row);
+		xstring sPersonID = e.selectSingleNode(L"@guid").text();
+		xml x;
 
-			int  OnRetrieve()
-			{
-				xml__ x = new xml__;
-				x.setNativePointer(x.CreateInstance());
-				xaserverarg__ arg = new xaserverarg__;
-				arg.setNativePointer(arg.CreateInstance());
-				arg.AddArg("sTxt",m_sTxt);
-				if (url::get("OrganizationStruct/list.HrPerson",arg.GetString(),x) != 1)
-				{
-					trace(x.GetXmlDoc().text);
-					return -1;
-				}
-				else	
-				{
-					dw_list.Retrieve(x);
-					dw_list.Redraw();
-				}
+		xaserverarg arg;
+
+		arg.AddArg(L"guid", sPersonID);
+
+		if (xurl::get(L"OrganizationStruct/Person.HrEmployee", arg.GetString(), x) != 1)
+		{
+			trace(x.text());
+			return -1;
+		}
+		else
+		{
+			dw_HrEmployee.Retrieve(x);
+			dw_HrEmployee.Redraw();
+		}
+
+		return 1;
+	}
+
+	int  OnRetrieve()
+	{
+		xml x;
+
+		xaserverarg arg;
+
+		arg.AddArg(L"sTxt", m_sTxt);
+		if (xurl::get(L"OrganizationStruct/list.HrPerson", arg.GetString(), x) != 1)
+		{
+			trace(x.text());
+			return -1;
+		}
+		else
+		{
+			dw_list.Retrieve(x);
+			dw_list.Redraw();
+		}
 		//		if (dw_list.GetRowCount() >0)
 		//			OnRowFocusChanged();
-				dw_list.SetReadOnly(true);
-				return 1;
-			}
+		dw_list.SetReadOnly(true);
+		return 1;
+	}
 
-			int OnSearch()
-			{
-				control__ xc = new control__;
-				xc.setNativePointer(this.GetControl("QueryTxt"));		
-				m_sTxt= xc.GetText();
-				OnRetrieve();
-				return 1;
-			}
+	int OnSearch()
+	{
+		xcontrol xc = GetControl(L"QueryTxt");
+		m_sTxt = xc.GetText();
+		OnRetrieve();
+		return 1;
+	}
 
-			int OnUpdateAssignmentView()
+	int OnUpdateAssignmentView()
+	{
+		xml x1;
+		if (xurl::post(L"OrganizationStruct/update.Assignmentview", L"", x1) != 1)
+		{
+			xstring error = x1.text();
+			trace(error);
+			return 1;
+		}
+		else
+		{
+			trace(x1.xml());
+			MessageBox(GetHWND(), L"更新成功!", L"提示", 0);
+		}
+		return 1;
+	}
+
+	//命令发布函数
+	int OnCmdDispatch(xstring comdid)
+	{
+		xaserverarg& arg = *new xaserverarg;
+
+		KXMLDOMElement e;
+		xstring sPersonID;
+		xstring sName;
+		if (comdid == L"AddPerson")
+		{
+			arg.AddArg(L"operate", L"new0");
+			arg.AddArg(L"guid", L"");
+			openUrl(L"组织架构.vface/xpage/Hr/HrPersonMaint", &arg);
+		}
+		else if (comdid == L"UpdateAssignmentView")
+			OnUpdateAssignmentView();
+		else if (comdid == L"ModifyPerson")
+		{
+			int row = dw_list.GetNextSelectRow(1);
+			if (row < 1)
 			{
-				xml__ x1 = new xml__;
-				x1.setNativePointer(x1.CreateInstance());
-				if (url::post("OrganizationStruct/update.Assignmentview","",x1) != 1)
+				row = dw_list.GetRow();
+				if (row < 1)
 				{
-					string error = x1.GetXmlDoc().text;
-					trace(error);
-					return 1;
-				}	
-				else
-				{
-					trace(x1.GetXml());
-					win__::MessageBox(GetHWND(),"更新成功!","提示",0);			
+					MessageBox(GetHWND(), L"请选中要修改的人员行!", L"提示", 0);
+					return -1;
 				}
-				return 1;
 			}
-				
-			//命令发布函数
-			int OnCmdDispatch(string comdid)
+			e = dw_list.GetRowElement(row);
+			sPersonID = e.selectSingleNode(L"@guid").text();
+			arg.AddArg(L"operate", L"modify");
+			arg.AddArg(L"guid", sPersonID);
+			openUrl(L"组织架构.vface/xpage/Hr/HrPersonMaint", &arg);
+		}
+		else if (comdid == L"DeletePerson")
+		{
+			int row = dw_list.GetNextSelectRow(1);
+			if (row < 1)
 			{
-				xaserverarg__ arg = new xaserverarg__; 
-				arg.setNativePointer(arg.CreateInstance());
-				msxml::IXMLDOMElement e;	
-				string sPersonID;
-				string sName;				
-				if (comdid =="AddPerson") 
+				row = dw_list.GetRow();
+				if (row < 1)
 				{
-					arg.AddArg("operate","new0");
-					arg.AddArg("guid","");
-					openUrl("组织架构.vface/xpage/Hr/HrPersonMaint", arg);			
+					MessageBox(GetHWND(), L"请选中要删除的人员行!", L"提示", 0);
+					return -1;
 				}
-				else if(comdid=="UpdateAssignmentView")
-					OnUpdateAssignmentView();
-				else if (comdid =="ModifyPerson")
-				{
-					int row = dw_list.GetNextSelectRow(1);
-					if (row < 1)
-					{
-						row = dw_list.GetRow();
-						if (row < 1) 
-						{
-							win__::MessageBox(GetHWND(),"请选中要修改的人员行!","提示",0);
-							return -1;
-						}
-					}
-					e = dw_list.GetRowElement(row);
-					sPersonID = e.SelectSingleNode("@guid").text;
-					arg.AddArg("operate","modify");
-					arg.AddArg("guid",sPersonID);
-					openUrl("组织架构.vface/xpage/Hr/HrPersonMaint", arg);		
-				}
-				else if (comdid =="DeletePerson")
-				{
-					int row = dw_list.GetNextSelectRow(1);
-					if (row < 1)
-					{
-						row = dw_list.GetRow();
-						if (row < 1) 
-						{
-							win__::MessageBox(GetHWND(),"请选中要删除的人员行!","提示",0);
-							return -1;
-						}
-					}
-
-					e = dw_list.GetRowElement(row);
-					sPersonID =  e.SelectSingleNode("@guid").text;
-					sName = e.selectSingleNode("Name").text;					
-					sName += "";
-					int  MB_YESNO = 0x00000004;
-					int  IDYES =  6;			
-					if(win__::MessageBox(GetHWND(),"确认要删除 "+sName+" 的信息吗?","提示",MB_YESNO)!=IDYES) return 1;
-
-
-					arg.AddArg("guid",sPersonID);
-
-					
-					xml__ x1 = new xml__;
-					x1.setNativePointer(x1.CreateInstance());
-					if (url::post("OrganizationStruct/delete.HrPerson",arg.GetString(),x1) != 1)
-					{
-						string error = x1.GetXmlDoc().text;
-						trace(error);
-					}
-					else
-					{
-						//win32::MessageBox(GetHWND(),"删除成功!","提示",0);
-						dw_list.DeleteRow(row);
-					}
-				}
-				else if (comdid =="Refresh")
-				{
-					OnRetrieve();
-				}					
-				else if (comdid =="search" || comdid=="query")
-				{
-					OnSearch();
-				}					
-				return 0;
 			}
-			
-			//命令处理事件
-			int OnXCommand(ref TXCommandEvent evt,int param)
+
+			e = dw_list.GetRowElement(row);
+			sPersonID = e.selectSingleNode(L"@guid").text();
+			sName = e.selectSingleNode(L"Name").text();
+			sName += L"";
+			int  MB_YESNO = 0x00000004;
+			int  IDYES = 6;
+			if (MessageBox(GetHWND(), L"确认要删除 " + sName + L" 的信息吗?", L"提示", MB_YESNO) != IDYES) return 1;
+
+
+			arg.AddArg(L"guid", sPersonID);
+
+
+			xml x1;
+
+			if (xurl::post(L"OrganizationStruct/delete.HrPerson", arg.GetString(), x1) != 1)
 			{
-				return OnCmdDispatch(evt.pStrID);
+				xstring error = x1.text();
+				trace(error);
 			}
-			
-			int OnAttachEvent()
+			else
 			{
-				//绑定工具条点击事件
-				AttachEvent("WM_XCOMMAND",OnXCommand);
-				//获取焦点事件,用于重置工具条
-				AttachEvent("WM_SETFOCUS",OnSetFocus);
-				AttachEvent("dw_list","DWV_CLICKED",OnRowFocusChanged);
-				AttachEvent("dw_list","DWV_DOUBLECLICKED",OnDoubleClicked);
+				//win32::MessageBox(GetHWND(),L"删除成功!",L"提示",0);
+				dw_list.DeleteRow(row);
 			}
+		}
+		else if (comdid == L"Refresh")
+		{
+			OnRetrieve();
+		}
+		else if (comdid == L"search" || comdid == L"query")
+		{
+			OnSearch();
+		}
+		return 0;
+	}
 
-			int OnInitial()
-			{
-				SetAgent();
+	//命令处理事件
+	int OnXCommand(TEvent* evt, LPARAM param)
+	{
+		return OnCmdDispatch(evt->xcommand.pStrID);
+	}
 
-				OnAttachEvent();
-				
-				return 1;
-			}
-			
-			int onload()
-			{
-				m_sTxt="";
-				dw_list =  new xdwgrid__;
-				dw_list.setNativePointer(this.GetControl("dw_list"));						
-				dw_list.openUrl("组织架构.vface/template/HrPerson/list");					
-				dw_list.SetReadOnly(true);
-				dw_list.SetSelectionMode(1);
+	int OnAttachEvent()
+	{
+		//绑定工具条点击事件
+		AttachEvent(L"WM_XCOMMAND", (FEvent)&HrPerson::OnXCommand);
+		//获取焦点事件,用于重置工具条
+		AttachEvent(L"WM_SETFOCUS", (FEvent)&HrPerson::OnSetFocus);
+		AttachEvent(L"dw_list", L"DWV_CLICKED", (FEvent)&HrPerson::OnRowFocusChanged);
+		AttachEvent(L"dw_list", L"DWV_DOUBLECLICKED", (FEvent)&HrPerson::OnDoubleClicked);
+		return 1;
+	}
 
-				dw_HrEmployee =  new xdwgrid__;
-				dw_HrEmployee.setNativePointer(this.GetControl("dw_HrEmployee"));						
-				dw_HrEmployee.openUrl("组织架构.vface/template/HrPerson/listemp");		
-				//dw_HrEmployee.openUrl("组织架构.vface/template/HrEmployee/list");		
-				OnInitial();
+	int OnInitial()
+	{
+		SetAgent();
 
-				OnRetrieve();
-				
-				return 1;
-			}
-		]
-		
-	]
-]
\ No newline at end of file
+		OnAttachEvent();
+
+		return 1;
+	}
+
+	int onload()
+	{
+		m_sTxt = L"";
+		dw_list = new xdwgrid;
+		dw_list.setNativePointer(GetControl(L"dw_list"));
+		dw_list.openUrl(L"组织架构.vface/template/HrPerson/list");
+		dw_list.SetReadOnly(true);
+		dw_list.SetSelectionMode(1);
+
+		dw_HrEmployee = new xdwgrid;
+		dw_HrEmployee.setNativePointer(GetControl(L"dw_HrEmployee"));
+		dw_HrEmployee.openUrl(L"组织架构.vface/template/HrPerson/listemp");
+		//dw_HrEmployee.openUrl(L"组织架构.vface/template/HrEmployee/list");		
+		OnInitial();
+
+		OnRetrieve();
+
+		return 1;
+	}
+};
\ No newline at end of file

--
Gitblit v1.9.3