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