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

diff --git a/jrj/project/business/Company/HrJob.cpp b/jrj/project/business/Company/HrJob.cpp
new file mode 100644
index 0000000..4a43c57
--- /dev/null
+++ b/jrj/project/business/Company/HrJob.cpp
@@ -0,0 +1,284 @@
+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 "frame.vl"
+use "treeview.vm"
+
+//unit vclient.vobject tpp
+unit vbusiness.xpage
+[
+	HrJob is extend frame;
+	about HrJob
+		[
+			field:
+			[
+				treeview__		tv_1;
+				xdwgrid__	dw_list;
+				string 	m_type;
+
+				xnode__	m_agentNode;	//Agent Condition
+				string	m_agentCond;	//Agent Node
+			]
+
+				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);
+					}
+					return 1;
+				}
+
+				//焦点激活处理函数
+				int OnSetFocus(ref TEvent evt, int param)
+				{
+					SetAgent();
+
+					//重置工具条
+					return 1;
+				}
+
+				int  OnRetrieve()
+				{
+					string query = "[MSSqlHrJob.xq]";
+					xml__ x = new xml__;
+					x.setNativePointer(x.CreateInstance());
+					xaserverarg__ arg = new xaserverarg__;
+					arg.setNativePointer(arg.CreateInstance());
+					arg.AddArg("type", m_type);
+					//if (xaserver__::ExecXQuery(GetServerUrl(),query,arg.GetString(),x)!=1)
+					if (url::post("OrganizationStruct/list.Job", arg.GetString(), x) != 1)
+					{
+						trace(x.GetXmlDoc().text);
+						return -1;
+					}
+					else
+					{
+						dw_list.openUrl("组织架构.vface/template/HrJob/list");
+						dw_list.Retrieve(x);
+						dw_list.Redraw();
+					}
+					return 1;
+				}
+
+				int OnTreeSelChanged(ref TNotifyEvent evt, int p) {
+					ref NMTREEVIEW nmtv = evt.pnmh;
+					int hItem = nmtv.itemNew.hItem;
+
+					int wid = tv_1.GetId();
+					int hItem = treeview__::GetSelectedItem(wid);
+					int rootItem = treeview__::GetRootItem(wid);
+					if (hItem <= 0 || hItem == rootItem)
+					{
+						m_type = "all";
+					}
+					else
+					{
+						msxml::IXMLDOMElement ele = treeview__::GetItemData(wid, hItem);
+						m_type = ele.SelectSingleNode("@name").text;
+					}
+					OnRetrieve();
+					return 1;
+				}
+
+				int OnCreateTree()
+				{
+					int wid = tv_1.GetId();
+					xml__ x = new xml__;
+					x.setNativePointer(xml__::CreateInstance());
+					x.Load("<Type code='0.0' name='all' guid='' />");
+					msxml::IXMLDOMElement ele = x.GetXmlDoc().SelectSingleNode("Type");
+					int hItem = tv_1.InsertChildItemEx(wid, 0, "工种类型", ele, 15, 4);
+
+					if (url::post("/sale/data/OrganizationStruct/type.Job", "", x) != 1)
+					{
+						trace(x.GetXml());
+						return -1;
+					}
+					//trace(x.GetXml());
+					var list = x.GetXmlDoc().selectNodes("//Type");
+					int i = 0, s = list.length;
+					msxml::IXMLDOMElement e;
+					string sname;
+					if (s > 0)
+					{
+						for (i = 0; i < s; i++)
+						{
+							e = list.item(i);
+							sname = e.SelectSingleNode("@name").text;
+							int curItem = tv_1.InsertChildItemEx(wid, hItem, sname, e, 15, 4);
+						}
+					}
+					return 1;
+				}
+
+				int OnSave()
+				{
+					xml__ x = new xml__;
+					x.setNativePointer(x.CreateInstance());
+					dw_list.AcceptText();
+					dw_list.DwUpdateAllToEx(x.GetXmlDoc());
+
+					string xdata = x.GetXml();
+					trace(x.GetXml());
+					//return 1;
+
+					xaserverarg__ arg = new xaserverarg__;
+					arg.setNativePointer(arg.CreateInstance());
+					arg.AddArg("xdata", xdata);
+
+					string xAction = "[MSSqlHrJobUpdate.xa]";
+					//if(xaserver__::ExecXAction(GetServerUrl(),xAction,arg.GetString())!=1)
+					if (url::post("OrganizationStruct/update.Job", arg.GetString(), x) != 1)
+					{
+						trace(x.GetXmlDoc().documentElement.text);
+						alert("保存失败");
+					}
+					else {
+						alert("保存成功");
+					}
+					return 1;
+				}
+
+				int OnAddRow()
+				{
+					if (m_type == "all")
+					{
+						alert("请先选择工种类型!");
+					}
+					else
+					{
+						int row = dw_list.InsertRow(0);
+						trace(row.toString());
+						dw_list.SetItemString(row, "JobType", m_type);
+						dw_list.SetItemString(row, "Status", "Y");
+					}
+					return 1;
+				}
+
+				int OnInsertRow()
+				{
+					if (m_type == "all")
+					{
+						alert("请先选择工种类型!");
+					}
+					else
+					{
+						int crow = dw_list.GetRow();
+						int row = dw_list.InsertRow(crow);
+						dw_list.SetItemString(row, "JobType", m_type);
+						dw_list.SetItemString(row, "Status", "Y");
+					}
+					return 1;
+				}
+
+				int OnDeleteRow()
+				{
+					int row = dw_list.GetRow();
+					msxml::IXMLDOMElement e = dw_list.GetRowElement(row);
+					string sguid = e.selectSingleNode("@guid").text;
+					string sName = e.selectSingleNode("JobName").text;
+
+					xml__ x = new xml__;
+					x.setNativePointer(x.CreateInstance());
+					xaserverarg__ arg = new xaserverarg__;
+					arg.setNativePointer(arg.CreateInstance());
+					arg.AddArg("guid", sguid);
+					if (url::post("OrganizationStruct/used.Job", arg.GetString(), x) != 1)
+					{
+						trace(x.GetXmlDoc().text);
+						return -1;
+					}
+					else
+					{
+						msxml::IXMLDOMElement ele = x.GetXmlDoc().documentElement;
+						string snums = ele.SelectSingleNode("@num").text;
+						int num = snums.toInt();
+						if (num != 0)
+						{
+							win__::MessageBox(GetHWND(), "工种 " + sName + " 已启用,禁止删除!", "提示", 0);
+							return -1;
+						}
+					}
+					dw_list.DeleteRow(row);
+					return 1;
+				}
+
+				int OnJobType()
+				{
+					xaserverarg__ arg = new xaserverarg__;
+					arg.setNativePointer(arg.CreateInstance());
+					arg.AddArg("id", "工种类型");
+					openUrl("公共设置.vface/worknode/quickcode/config", arg);
+					return 1;
+				}
+
+				//命令发布函数
+				int OnCmdDispatch(string comdid)
+				{
+					if (comdid == "Save")  OnSave();
+					else if (comdid == "AddRow") OnAddRow();
+					else if (comdid == "InsertRow") OnInsertRow();
+					else if (comdid == "DeleteRow") OnDeleteRow();
+					else if (comdid == "JobType") OnJobType();
+					return 0;
+				}
+
+				//命令处理事件
+				int OnXCommand(ref TXCommandEvent evt, int param)
+				{
+					return OnCmdDispatch(evt.pStrID);
+				}
+
+				int OnAttachEvent()
+				{
+					//绑定工具条点击事件
+					AttachEvent("WM_XCOMMAND", OnXCommand);
+					//获取焦点事件,用于重置工具条
+					AttachEvent("WM_SETFOCUS", OnSetFocus);
+					//获得树的选择事件
+					AttachEvent("tv_1", "TVN_SELCHANGED", OnTreeSelChanged);
+				}
+
+				int OnInitial()
+				{
+					SetAgent();
+					OnAttachEvent();
+					return 1;
+				}
+
+				int onload()
+				{
+					m_type = "all";
+					tv_1 = new treeview__;
+					tv_1.setNativePointer(this.GetControl("tv_1"));
+					dw_list = new xdwgrid__;
+					dw_list.setNativePointer(this.GetControl("dw_list"));
+					dw_list.openUrl("组织架构.vface/template/HrJob/list");
+
+					OnInitial();
+					OnCreateTree();
+					int wid = tv_1.GetId();
+					int hItem = treeview__::GetRootItem(wid);
+					tv_1.ExpandItem(wid, hItem);
+					OnRetrieve();
+
+					return 1;
+				}
+			]
+
+		]
+]
\ No newline at end of file

--
Gitblit v1.9.3