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/HRPerson.cpp | 275 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 275 insertions(+), 0 deletions(-) diff --git a/jrj/project/business/Company/HRPerson.cpp b/jrj/project/business/Company/HRPerson.cpp new file mode 100644 index 0000000..7b3e668 --- /dev/null +++ b/jrj/project/business/Company/HRPerson.cpp @@ -0,0 +1,275 @@ +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; + + 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; + } + + //焦点激活处理函数 + int OnSetFocus(ref TEvent evt,int p) + { + SetAgent(); + + //重置工具条 + return 1; + } + + //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; + } + + 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(); + } + // if (dw_list.GetRowCount() >0) + // OnRowFocusChanged(); + 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 OnUpdateAssignmentView() + { + xml__ x1 = new xml__; + x1.setNativePointer(x1.CreateInstance()); + if (url::post("OrganizationStruct/update.Assignmentview","",x1) != 1) + { + string error = x1.GetXmlDoc().text; + trace(error); + return 1; + } + else + { + trace(x1.GetXml()); + win__::MessageBox(GetHWND(),"更新成功!","提示",0); + } + return 1; + } + + //命令发布函数 + int OnCmdDispatch(string comdid) + { + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + msxml::IXMLDOMElement e; + string sPersonID; + string sName; + if (comdid =="AddPerson") + { + arg.AddArg("operate","new0"); + arg.AddArg("guid",""); + openUrl("组织架构.vface/xpage/Hr/HrPersonMaint", arg); + } + 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) + { + return OnCmdDispatch(evt.pStrID); + } + + int OnAttachEvent() + { + //绑定工具条点击事件 + AttachEvent("WM_XCOMMAND",OnXCommand); + //获取焦点事件,用于重置工具条 + AttachEvent("WM_SETFOCUS",OnSetFocus); + AttachEvent("dw_list","DWV_CLICKED",OnRowFocusChanged); + AttachEvent("dw_list","DWV_DOUBLECLICKED",OnDoubleClicked); + } + + int OnInitial() + { + SetAgent(); + + 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); + + 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(); + + OnRetrieve(); + + return 1; + } + ] + + ] +] \ No newline at end of file -- Gitblit v1.9.3