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

---
 jrj/project/business/Company/HrEmployeex.cpp |  286 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 286 insertions(+), 0 deletions(-)

diff --git a/jrj/project/business/Company/HrEmployeex.cpp b/jrj/project/business/Company/HrEmployeex.cpp
new file mode 100644
index 0000000..0b1c5ef
--- /dev/null
+++ b/jrj/project/business/Company/HrEmployeex.cpp
@@ -0,0 +1,286 @@
+use "win.vl"
+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"
+use "treeview.vm"
+//unit vclient.vobject tpp
+unit vbusiness.xpage
+[
+	HrEmployeex is extend list;
+	about HrEmployeex
+		[
+			field:
+			[
+				treeview__		tv_org;
+				xdwtable__      dw_1;
+				xnode__	m_agentNode;
+				string		is_orgid
+					string 		is_orgname;
+				string		is_inflag;
+				xdwtable__    dw_empmaint;
+			]
+
+				method:
+			[
+				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);
+					}
+				}
+				//焦点激活处理函数
+				int OnSetFocus(ref TEvent evt, int p)
+				{
+					SetAgent();
+					//重置工具条
+					return 1;
+				}
+
+				int OnSave()
+				{
+					int hIcon = xutil__::SetCursorWait();
+
+					string val;
+					xml__ x = new xml__;
+					x.setNativePointer(x.CreateInstance());
+					var xdoc = x.GetXmlDoc();
+					dw_1.AcceptText();
+					dw_1.DwUpdateAllTo(xdoc);
+					val = xdoc.xml;
+					//trace(val);
+					//return 1;
+					xaserverarg__ args = new xaserverarg__;
+					args.setNativePointer(args.CreateInstance());
+					args.AddArg("content", val);
+					xml__ x1 = new xml__;
+					x1.setNativePointer(x1.CreateInstance());
+					if (url::post("OrganizationStruct/update.Employee", args.GetString(), x1) != 1)
+					{
+						string error = x1.GetXmlDoc().text;
+						trace(error);
+					}
+					else
+					{
+						win__::MessageBox(GetHWND(), "保存成功!", "提示", 0);
+					}
+
+					xutil__::RestoreCursor(hIcon);
+					return 1;
+				}
+
+				int OnRetrieve(string ls_orgid)
+				{
+					xml__ x = new xml__;
+					x.setNativePointer(x.CreateInstance());
+					xaserverarg__ arg = new xaserverarg__;
+					arg.setNativePointer(arg.CreateInstance());
+					arg.AddArg("OrgID", ls_orgid);
+					//trace(ls_orgid);
+					//if (xaserver__::ExecXQuery(GetServerUrl(),"[MSSqlHrEmployee.xq]",arg.GetString(),x) == 1)
+					if (url::get("OrganizationStruct/detail.Employee", arg.GetString(), x) == 1)
+					{
+						dw_1.openUrl("组织架构.vface/template/HrEmployee/detail");
+						dw_1.Retrieve(x);
+						dw_1.Redraw();
+					}
+					return 1;
+				}
+
+				int OnTreeSelChanged(ref TXCommandEvent evt, int p)
+				{
+					int wid = tv_org.GetId();
+					int hitem = treeview__::GetSelectedItem(wid);
+					msxml::IXMLDOMElement ele = treeview__::GetItemData(wid, hitem);
+					string ls_orgid = ele.SelectSingleNode("@guid").text;
+					is_orgid = ls_orgid;
+					//trace(is_orgid);
+					OnRetrieve(ls_orgid);
+					return 1;
+				}
+
+				int  OnAddRow()
+				{
+					xdwtable__ dw = new xdwtable__;
+					dw.setNativePointer(dw_1.GetCurTable());
+					string dw_n = dw.GetDwName();
+					if (dw_n == "HrEmployee")
+						dw.InsertRow(0);
+					return 1;
+				}
+
+				int OnInsertRow()
+				{
+					xdwtable__ dw = new xdwtable__;
+					dw.setNativePointer(dw_1.GetCurTable());
+					string dw_n = dw.GetDwName();
+					if (dw_n == "HrEmployee")
+					{
+						int row = dw.GetRow();
+						dw.InsertRow(row);
+					}
+					return 1;
+				}
+
+				int OnDeleteRow()
+				{
+					xdwtable__ dw = new xdwtable__;
+					dw.setNativePointer(dw_1.GetCurTable());
+					string dw_n = dw.GetDwName();
+					if (dw_n == "HrEmployee")
+					{
+						int row = dw.GetRow();
+						dw.DeleteRow(row);
+					}
+					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 == "PositionID") {
+							arg.AddArg("ResourceType", "HrPosition");
+						}
+						else if (col == "PersonID") {
+							arg.AddArg("ResourceType", "HrPerson");
+						}
+						else if (col == "OrgID") {
+							arg.AddArg("ResourceType", "HrOrg");
+						}
+						else if (col == "JobID") {
+							arg.AddArg("ResourceType", "HrJob");
+						}
+						if (xaserver__::ExecXQuery(GetServerUrl(), query, arg.GetString(), x) == 1)
+							dwhdr.data = x.GetXml();
+						//trace(x.GetXml());
+					}
+					return 1;
+				}
+
+				int OnItemChanged(ref TNotifyEvent evt, int p)
+				{
+					int HCursor = xutil__::SetCursorWait();
+
+					ref DWNMHDR dwhdr = evt.pnmh;
+					int row = dwhdr.row;
+					string col = dwhdr.colname;
+					string data = dwhdr.data;
+					trace(row);
+					if (col == "PositionID")
+					{
+						xdwtable__ dw_HrEmployee = new xdwtable__;
+						dw_HrEmployee.setNativePointer(dw_1.FindDwTable("HrEmployee"));
+						string sPositionID = dw_HrEmployee.GetItemString(row, "PositionID");
+
+						if (sPositionID == "" || sPositionID == nil)
+							return 1;
+						xml__ x = new xml__;
+						x.setNativePointer(x.CreateInstance());
+						xaserverarg__ arg = new xaserverarg__;
+						arg.setNativePointer(arg.CreateInstance());
+						arg.AddArg("guid", sPositionID);
+						arg.AddArg("type", "GetOrgIDJobID");
+						//trace(arg.GetString());
+						if (url::get("OrganizationStruct/GetOrgIDJobID", arg.GetString(), x) != 1)
+						{
+							trace(x.GetXmlDoc().text);
+							return -1;
+						}
+						else
+						{
+							msxml::IXMLDOMDocument xdoc = x.GetXmlDoc();
+							//IXMLDOMNodeList nlist = xdoc.getElementsByTagName("OrgID");
+							msxml::IXMLDOMElement e = xdoc.documentElement;
+							string sOrgID = e.SelectSingleNode("@OrgID").text;
+							string sOrgName = e.SelectSingleNode("@OrgName").text;
+							string sJobID = e.SelectSingleNode("@JobID").text;
+							string sJobName = e.SelectSingleNode("@JobName").text;
+							dw_HrEmployee.SetItemString(row, "OrgID", sOrgID);
+							dw_HrEmployee.SetItemDisplayString(row, "OrgID", sOrgName);
+							dw_HrEmployee.SetItemString(row, "JobID", sJobID);
+							dw_HrEmployee.SetItemDisplayString(row, "JobID", sJobName);
+						}
+					}
+					xutil__::RestoreCursor(HCursor);
+					return 0;
+				}
+
+				int OnImportData()
+				{
+					openUrl("组织架构.vface/xpage/Hr/HrPersonSel", this);
+					return 1;
+				}
+				//命令发布函数
+				int OnCmdDispatch(string comdid)
+				{
+					if (comdid == "AddRow") return OnAddRow();
+					else if (comdid == "InsertRow") return OnInsertRow();
+					else if (comdid == "DeleteRow") return OnDeleteRow();
+					else if (comdid == "Save") return OnSave();
+					else if (comdid == "ImportData") return OnImportData();
+					return 0;
+				}
+
+				//命令处理事件
+				int OnXCommand(ref TXCommandEvent evt, int p)
+				{
+					return OnCmdDispatch(evt.pStrID);
+				}
+
+				int OnAttachEvent()
+				{
+					//绑定工具条点击事件
+					AttachEvent("WM_XCOMMAND", OnXCommand);
+					//获取焦点事件,用于重置工具条
+					AttachEvent("WM_SETFOCUS", OnSetFocus);
+					//获得树的选择事件
+					AttachEvent("tv_org", "TVN_SELCHANGED", OnTreeSelChanged);
+					//下拉框  提供内容
+					AttachEvent("dw_1", "DWV_CHILDCONTENT", OnChildContent);
+					AttachEvent("dw_1", "DWV_ITEMCHANGED", OnItemChanged);
+				}
+
+				int OnInitial()
+				{
+					SetAgent();
+					OnAttachEvent();
+
+					return 1;
+				}
+
+				int onload()
+				{
+					tv_org = new treeview__;
+					tv_org.setNativePointer(this.GetControl("tv_org"));
+					dw_1 = new xdwtable__;
+					dw_1.setNativePointer(this.GetControl("dw_1"));
+					dw_1.openUrl("组织架构.vface/template/HrEmployee/detail");
+
+					OnInitial();
+					int wid = tv_org.GetId();
+					int root = treeview__::GetRootItem(wid);
+					treeview__::ExpandItem(wid, root);
+					return 1;
+				}
+			]
+
+		]
+]
\ No newline at end of file

--
Gitblit v1.9.3