From a4d2315ee4ca3f6177b4fb2526bed2feff3d89be Mon Sep 17 00:00:00 2001
From: lifan <2308045698@qq.com>
Date: 星期三, 22 十月 2025 16:52:58 +0800
Subject: [PATCH] update

---
 jrj/project/business/Company/HrOrgMaint.cpp |  504 ++++++++++++++++++++++++++++---------------------------
 1 files changed, 256 insertions(+), 248 deletions(-)

diff --git a/jrj/project/business/Company/HrOrgMaint.cpp b/jrj/project/business/Company/HrOrgMaint.cpp
index 1989e32..467694a 100644
--- a/jrj/project/business/Company/HrOrgMaint.cpp
+++ b/jrj/project/business/Company/HrOrgMaint.cpp
@@ -1,266 +1,274 @@
-use "win.vl"
-use "treeview.vm"
-use "dev:vm[xdwgrid.vm]"
-use "dev:vm[xdwtable.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 "list.vl"
-unit vbusiness.xpage
-[
-	HrOrgMaint is extend list;
-	about HrOrgMaint
-		[
-			control:
+#include <wobject/xstring.hpp>
+#include <xcontrol/xtreeview.hpp>
+#include <xcontrol/xdwgrid.hpp>
+#include <wobject/xdouble.hpp>
+#include <xcontrol/xlayersheet.hpp>
 
-		method:
-			[
-				xdwtable__	dw_detail;
-				string		m_operate;
-				string		m_sguid;
-				string		m_tvOrgID;
-				string		m_tvOrgName;
-				string		m_tvRootOrgID;
-				string		m_tvRootOrgName;
+#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp"
+#include "viewobject/view.base.hpp"
 
-				xnode__	m_agentNode;	//Agent Condition
-				string	m_agentCond;	//Agent Node	
-				int SetAgent()
-				{
-					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;
-				}
+using xml = KXMLDOMDocument;
+class __declspec(dllexport) HrOrgMaint : public xwin
+{
+public:
 
-				//焦点激活处理函数
-				int OnSetFocus(ref TEvent evt, int p)
-				{
-					SetAgent();
+	xdwtable	dw_detail;
+	xstring		m_operate;
+	xstring		m_sguid;
+	xstring		m_tvOrgID;
+	xstring		m_tvOrgName;
+	xstring		m_tvRootOrgID;
+	xstring		m_tvRootOrgName;
 
-					//重置工具条
-					return 1;
-				}
+	xnode	m_agentNode;	//Agent Condition
+	xstring	m_agentCond;	//Agent Node	
+public:
+	HrOrgMaint(void* implPtr, HWND hWnd) :xwin(implPtr, hWnd) {}
+public:
+	static HrOrgMaint* CreateInstance(void* implPtr, void* hWnd)
+	{
+		HrOrgMaint* pWin = new HrOrgMaint(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  OnRetrieve()
-				{
-					xml__ x = new xml__;
-					x.setNativePointer(x.CreateInstance());
-					xaserverarg__ arg = new xaserverarg__;
-					arg.setNativePointer(arg.CreateInstance());
-					arg.AddArg("guid", m_sguid);
-					if (url::get("OrganizationStruct/detail.HrOrg", arg.GetString(), x) != 1)
-					{
-						trace(x.GetXmlDoc().text);
-						return -1;
-					}
-					else
-					{
-						trace(x.GetXml());
-						dw_detail.Retrieve(x);
-						dw_detail.Redraw();
-					}
-					return 1;
-				}
+	//焦点激活处理函数
+	int OnSetFocus(TEvent* evt, LPARAM param)
+	{
+		SetAgent();
 
-				int OnSave()
-				{
-					int hIcon = xutil__::SetCursorWait();
-					//dw_detail.AcceptText();					
-					string val;
-					xml__ x = new xml__;
-					x.setNativePointer(x.CreateInstance());
-					var xdoc = x.GetXmlDoc();
-					dw_detail.DwUpdateAllTo(xdoc);
-					val = xdoc.xml;
-					//trace(val);
-					//return 1;
-					xaserverarg__ args = new xaserverarg__;
-					args.setNativePointer(args.CreateInstance());
-					args.AddArg("content", val);
-					//trace(val);
-					xml__ x1 = new xml__;
-					x1.setNativePointer(x1.CreateInstance());
-					if (url::post("OrganizationStruct/update.HrOrg", args.GetString(), x1) != 1)
-					{
-						string error = x1.GetXmlDoc().text;
-						trace(error);
-					}
-					else
-					{
-						win__::MessageBox(GetHWND(), "保存成功!", "提示", 0);
-					}
-					dw_detail.ResetUpdateStatus();
-					xutil__::RestoreCursor(hIcon);
-					return 1;
-				}
+		//重置工具条
+		return 1;
+	}
 
-				int OnNew()
-				{
-					dw_detail.openUrl("组织架构.vface/template/HrOrg/detail");
-					if (m_operate == "new0")
-					{
-						dw_detail.SetItemString(1, "ParentOrgID", m_tvOrgID);
-						dw_detail.SetItemDisplayString(1, "ParentOrgID", m_tvOrgName);
-					}
-					dw_detail.SetItemString(1, "Status", "Y");
-					//dw_detail.SetItemDisplayString(1,"Status","有效");
-					return 1;
-				}
+	int  OnRetrieve()
+	{
+		xml x;
 
-				//命令发布函数
-				int OnCmdDispatch(string comdid)
-				{
-					if (comdid == "New") OnNew();
-					if (comdid == "Save") OnSave();
-					if (comdid == "xmOk") OnSave();
-					if (comdid == "xmCancel") CloseWindow();
-					return 0;
-				}
+		xaserverarg arg;
 
-				//命令处理事件
-				int OnXCommand(ref TXCommandEvent evt, int p)
-				{
-					return OnCmdDispatch(evt.pStrID);
-				}
+		arg.AddArg(L"guid", m_sguid);
+		if (xurl::get(L"OrganizationStruct/detail.HrOrg", arg.GetString(), x) != 1)
+		{
+			trace(x.text());
+			return -1;
+		}
+		else
+		{
+			trace(x.xml());
+			dw_detail.Retrieve(x);
+			dw_detail.Redraw();
+		}
+		return 1;
+	}
 
-				int OnChildContent(ref TNotifyEvent evt, int p)
-				{
-					ref DWNMHDR dwhdr = evt.pnmh;
-					string col = dwhdr.colname;
-					if (col != "") {
-						xml__ x = new xml__;
-						x.setNativePointer(x.CreateInstance());
-						xaserverarg__ arg = new xaserverarg__;
-						arg.setNativePointer(arg.CreateInstance());
-						string query;
-						query = "[IResourceMSSql.xq]";
-						if (col == "OrgTypeID") {
-							arg.AddArg("ResourceType", "HrOrgType");//组织类型	
-						}
-						else if (col == "OrgAddress000") {
-							arg.AddArg("ResourceType", "HR_Address");//组织地址	
-						}
-						else if (col == "CompanyID") {
-							arg.AddArg("ResourceType", "CompanyInfo");//所属法人	
-						}
-						else if (col == "OrgProLine") {
-							arg.AddArg("ResourceType", "OrgProLine");//产品线
-						}
-						if (xaserver__::ExecXQuery(GetServerUrl(), query, arg.GetString(), x) == 1)
-							dwhdr.data = x.GetXml();
-						//trace(x.GetXml());
-					}
-					return 1;
-				}
-				int OnClicked(ref TNotifyEvent evt, int p)
-				{
-					ref DWNMHDR  hdr = evt.pnmh;
+	int OnSave()
+	{
+		HCURSOR hIcon = xutil::SetCursorWait();
+		//dw_detail.AcceptText();					
+		xstring val;
+		xml x;
 
-					xaserverarg__ arg = new xaserverarg__;
-					arg.setNativePointer(arg.CreateInstance());
+		auto xdoc = x;
+		dw_detail.DwUpdateAllTo(xdoc);
+		val = xdoc.xml();
+		//trace(val);
+		//return 1;
+		xaserverarg args;
+		
+		args.AddArg(L"content", val);
+		//trace(val);
+		xml x1;
 
-					string colname = hdr.colname;
-					if (colname == "ParentOrgID")
-					{
-						openUrl("组织架构.vface/xpage/HrOrg/Chart", arg);
-						//trace(arg.GetString());
-						string comdid = arg.GetArgString("comdid");
-						if (comdid == "xmOk")
-						{
-							string OrgName = arg.GetArgString("OrgName");
-							string OrgID = arg.GetArgString("OrgId");
-							dw_detail.SetItemDisplayString(1, "ParentOrgID", OrgName);
-							dw_detail.SetItemString(1, "ParentOrgID", OrgID);
-							dw_detail.Redraw();
-						}
-					}
-					if (colname == "LeaderID")
-					{
-						openUrl("组织架构.vface/xpage/hremployee/select", arg);
-						comdid = arg.GetArgString("comdid");
-						if (comdid == "xmOk")
-						{
-							string sPersonID = arg.GetArgString("sPersonID");
-							//trace(sPersonID);
-							string sPersonName = arg.GetArgString("sPersonName");
-							dw_detail.SetItemDisplayString(1, colname, sPersonName);
-							dw_detail.SetItemString(1, colname, sPersonID);
-							dw_detail.Redraw();
-						}
-					}
-					return 1;
-				}
+		if (xurl::post(L"OrganizationStruct/update.HrOrg", args.GetString(), x1) != 1)
+		{
+			xstring error = x1.text();
+			trace(error);
+		}
+		else
+		{
+			MessageBox(GetHWND(), L"保存成功!", L"提示", 0);
+		}
+		dw_detail.ResetUpdateStatus();
+		xutil::RestoreCursor(hIcon);
+		return 1;
+	}
 
-				int OnAttachEvent()
-				{
-					//绑定工具条点击事件
-					AttachEvent("WM_XCOMMAND", OnXCommand);
-					//获取焦点事件,用于重置工具条
-					AttachEvent("WM_SETFOCUS", OnSetFocus);
-					//下拉框  提供内容
-					AttachEvent("dw_detail", "DWV_CHILDCONTENT", OnChildContent);
-					AttachEvent("dw_detail", "DWV_ITEMFOCUSCHANGED", OnClicked);
-				}
+	int OnNew()
+	{
+		dw_detail.openUrl(L"组织架构.vface/template/HrOrg/detail");
+		if (m_operate == L"new0")
+		{
+			dw_detail.SetItemString(1, L"ParentOrgID", m_tvOrgID);
+			dw_detail.SetItemDisplayString(1, L"ParentOrgID", m_tvOrgName);
+		}
+		dw_detail.SetItemString(1, L"Status", L"Y");
+		//dw_detail.SetItemDisplayString(1,L"Status",L"有效");
+		return 1;
+	}
+
+	//命令发布函数
+	int OnCmdDispatch(xstring comdid)
+	{
+		if (comdid == L"New") OnNew();
+		if (comdid == L"Save") OnSave();
+		if (comdid == L"xmOk") OnSave();
+		if (comdid == L"xmCancel") CloseWindow();
+		return 0;
+	}
+
+	//命令处理事件
+	int OnXCommand(TEvent* evt, LPARAM param)
+	{
+		return OnCmdDispatch(evt->xcommand.pStrID);
+	}
+
+	int OnChildContent(TEvent* evt, LPARAM p)
+	{
+		DWNMHDR& dwhdr = *(DWNMHDR*)evt->notify.pnmh;
+		xstring col = dwhdr.colname;
+		if (col != L"") {
+			xml x;
+
+			xaserverarg arg;
+
+			xstring query;
+			query = L"[IResourceMSSql.xq]";
+			if (col == L"OrgTypeID") {
+				arg.AddArg(L"ResourceType", L"HrOrgType");//组织类型	
+			}
+			else if (col == L"OrgAddress000") {
+				arg.AddArg(L"ResourceType", L"HR_Address");//组织地址	
+			}
+			else if (col == L"CompanyID") {
+				arg.AddArg(L"ResourceType", L"CompanyInfo");//所属法人	
+			}
+			else if (col == L"OrgProLine") {
+				arg.AddArg(L"ResourceType", L"OrgProLine");//产品线
+			}
+			if (xaserver::ExecXQuery(GetServerUrl(), query, arg.GetString(), x) == 1)
+				dwhdr.data = x.xml();
+			//trace(x.GetXml());
+		}
+		return 1;
+	}
+	int OnClicked(TEvent* evt, LPARAM p)
+	{
+		DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
+
+		xaserverarg& arg = *new xaserverarg;
 
 
-				int OnInitial()
-				{
-					SetAgent();
-					OnAttachEvent();
-					return 1;
-				}
+		xstring colname = hdr.colname;
+		if (colname == L"ParentOrgID")
+		{
+			openUrl(L"组织架构.vface/xpage/HrOrg/Chart", &arg);
+			//trace(arg.GetString());
+			xstring comdid = arg.GetArgString(L"comdid");
+			if (comdid == L"xmOk")
+			{
+				xstring OrgName = arg.GetArgString(L"OrgName");
+				xstring OrgID = arg.GetArgString(L"OrgId");
+				dw_detail.SetItemDisplayString(1, L"ParentOrgID", OrgName);
+				dw_detail.SetItemString(1, L"ParentOrgID", OrgID);
+				dw_detail.Redraw();
+			}
+		}
+		if (colname == L"LeaderID")
+		{
+			openUrl(L"组织架构.vface/xpage/hremployee/select", &arg);
+			xstring comdid = arg.GetArgString(L"comdid");
+			if (comdid == L"xmOk")
+			{
+				xstring sPersonID = arg.GetArgString(L"sPersonID");
+				//trace(sPersonID);
+				xstring sPersonName = arg.GetArgString(L"sPersonName");
+				dw_detail.SetItemDisplayString(1, colname.c_str(), sPersonName);
+				dw_detail.SetItemString(1, colname.c_str(), sPersonID);
+				dw_detail.Redraw();
+			}
+		}
+		return 1;
+	}
 
-				int onload()
-				{
-					dw_detail = new xdwtable__;
-					dw_detail.setNativePointer(this.GetControl("dw_detail"));
-					dw_detail.openUrl("组织架构.vface/template/HrOrg/detail");
-					OnInitial();
+	int OnAttachEvent()
+	{
+		//绑定工具条点击事件
+		AttachEvent(L"WM_XCOMMAND", (FEvent)&HrOrgMaint::OnXCommand);
+		//获取焦点事件,用于重置工具条
+		AttachEvent(L"WM_SETFOCUS", (FEvent)&HrOrgMaint::OnSetFocus);
+		//下拉框  提供内容
+		AttachEvent(L"dw_detail", L"DWV_CHILDCONTENT", (FEvent)&HrOrgMaint::OnChildContent);
+		AttachEvent(L"dw_detail", L"DWV_ITEMFOCUSCHANGED", (FEvent)&HrOrgMaint::OnClicked);
+		return 1;
+	}
 
-					xaserverarg__ arg = new xaserverarg__;
-					arg.setNativePointer(arg.CreateInstance());
-					arg = this.GetParam();
-					if (arg)
-					{
-						m_operate = arg.GetArgString("operate");
-						m_sguid = arg.GetArgString("guid");
-						m_tvOrgID = arg.GetArgString("tvOrgID");//组织树的ID
-						m_tvOrgName = arg.GetArgString("tvOrgName");//组织树的Name
-						m_tvRootOrgID = arg.GetArgString("tvRootOrgID");//组织树的ID
-						m_tvRootOrgName = arg.GetArgString("tvRootOrgName");//组织树的Name
-						//alert(m_tvRootOrgName);
-					}
-					/*if ( m_sguid == "" || m_sguid == nil)
-					{
-						m_sguid = win__::GetGuid();//错误
-						trace(m_sguid);
-					}*/
-					if (m_sguid != "") {
-						OnRetrieve();
-					};
-					if (m_operate == "new0")
-					{
-						//trace(m_tvOrgID);
-						dw_detail.SetItemString(1, "ParentOrgID", m_tvOrgID);
-						dw_detail.SetItemDisplayString(1, "ParentOrgID", m_tvOrgName);
-						dw_detail.SetItemString(1, "CompanyID", m_tvRootOrgID);
-						dw_detail.SetItemDisplayString(1, "CompanyID", m_tvRootOrgName);
-						dw_detail.SetItemString(1, "Status", "Y");
-						//dw_detail.SetItemDisplayString(1,"Status","有效");
-					}
-					return 1;
-				}
-			]
 
-		]
-]
\ No newline at end of file
+	int OnInitial()
+	{
+		SetAgent();
+		OnAttachEvent();
+		return 1;
+	}
+
+	int onload()
+	{
+		SetArg();
+		dw_detail = new xdwtable;
+		dw_detail.setNativePointer(GetControl(L"dw_detail"));
+		dw_detail.openUrl(L"组织架构.vface/template/HrOrg/detail");
+		OnInitial();
+
+		xaserverarg arg;
+
+		arg = GetArg();
+		if (arg)
+		{
+			m_operate = arg.GetArgString(L"operate");
+			m_sguid = arg.GetArgString(L"guid");
+			m_tvOrgID = arg.GetArgString(L"tvOrgID");//组织树的ID
+			m_tvOrgName = arg.GetArgString(L"tvOrgName");//组织树的Name
+			m_tvRootOrgID = arg.GetArgString(L"tvRootOrgID");//组织树的ID
+			m_tvRootOrgName = arg.GetArgString(L"tvRootOrgName");//组织树的Name
+			//alert(m_tvRootOrgName);
+		}
+		/*if ( m_sguid == L"" || m_sguid == nil)
+		{
+			m_sguid = GetGuid();//错误
+			trace(m_sguid);
+		}*/
+		if (m_sguid != L"") {
+			OnRetrieve();
+		};
+		if (m_operate == L"new0")
+		{
+			//trace(m_tvOrgID);
+			dw_detail.SetItemString(1, L"ParentOrgID", m_tvOrgID);
+			dw_detail.SetItemDisplayString(1, L"ParentOrgID", m_tvOrgName);
+			dw_detail.SetItemString(1, L"CompanyID", m_tvRootOrgID);
+			dw_detail.SetItemDisplayString(1, L"CompanyID", m_tvRootOrgName);
+			dw_detail.SetItemString(1, L"Status", L"Y");
+			//dw_detail.SetItemDisplayString(1,L"Status",L"有效");
+		}
+		return 1;
+	}
+};
\ No newline at end of file

--
Gitblit v1.9.3