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/HR_Address.cpp | 211 ++ jrj/project/business/Company/HrPersonMaint.cpp | 371 ++++ jrj/project/business/Company/HrEmployeex.cpp | 286 +++ jrj/project/business/GDN/CustomCodeNew.cpp | 0 jrj/project/business/Company/HrOrgType.cpp | 186 ++ jrj/project/business/Company/HrJob.cpp | 284 +++ jrj/project/business/Company/HrOrgChart.cpp | 142 + jrj/project/business/Company/HrPersonAdd.cpp | 155 + jrj/project/business/GDN/po.paper.cpp | 0 jrj/ext-jrj/ext-jrj.vcxproj.filters | 75 jrj/project/business/Company/HrEmployee.cpp | 390 +++++ jrj/project/business/Company/HRPerson.cpp | 275 +++ jrj/project/business/Company/HrOrg.cpp | 487 ++++++ jrj/project/business/GDN/AdvanceChargeList.cpp | 0 jrj/project/business/Company/CompanyMaint.cpp | 403 +++++ jrj/project/business/Company/HrPosition.cpp | 271 +++ jrj/project/business/PO/business4.cpp | 0 jrj/project/business/Company/HrOrgMaint.cpp | 266 +++ jrj/project/business/GDN/list.SOTrace3.cpp | 0 jrj/project/business/PO/PO.BatchPrecess.polist.cpp | 0 jrj/project/business/Company/CompanyList.cpp | 214 ++ jrj/project/business/Company/HrPositionAdd.cpp | 230 ++ jrj/project/business/GDN/tracer.so.cpp | 0 jrj/project/business/Company/HrEmployeeAdd.cpp | 193 ++ jrj/ext-jrj/ext-jrj.vcxproj | 58 jrj/project/business/Company/HrPersonSel.cpp | 154 + 26 files changed, 4,648 insertions(+), 3 deletions(-) diff --git a/jrj/ext-jrj/ext-jrj.vcxproj b/jrj/ext-jrj/ext-jrj.vcxproj index 21e6709..7ec233d 100644 --- a/jrj/ext-jrj/ext-jrj.vcxproj +++ b/jrj/ext-jrj/ext-jrj.vcxproj @@ -287,6 +287,57 @@ <ClCompile Include="..\project\business\AR\maint.SettlementExchange.cpp"> <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild> </ClCompile> + <ClCompile Include="..\project\business\Company\CompanyList.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> + <ClCompile Include="..\project\business\Company\CompanyMaint.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrEmployee.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrEmployeeAdd.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrEmployeex.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrJob.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrOrg.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrOrgChart.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrOrgMaint.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrOrgType.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> + <ClCompile Include="..\project\business\Company\HRPerson.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrPersonAdd.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrPersonMaint.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrPersonSel.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrPosition.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrPositionAdd.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> + <ClCompile Include="..\project\business\Company\HR_Address.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> <ClCompile Include="..\project\business\Customer3.list.cpp"> <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild> </ClCompile> @@ -430,6 +481,10 @@ <ClCompile Include="..\project\business\GDN3.maint.cpp"> <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild> </ClCompile> + <ClCompile Include="..\project\business\GDN\AdvanceChargeList.cpp" /> + <ClCompile Include="..\project\business\GDN\CustomCodeNew.cpp"> + <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild> + </ClCompile> <ClCompile Include="..\project\business\GDN\GDNDelay.cpp"> <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild> </ClCompile> @@ -440,6 +495,8 @@ <ClCompile Include="..\project\business\GDN\GDNSourcePriceMaint.cpp"> <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild> </ClCompile> + <ClCompile Include="..\project\business\GDN\list.SOTrace3.cpp" /> + <ClCompile Include="..\project\business\GDN\po.paper.cpp" /> <ClCompile Include="..\project\business\GDN\select.item.po.cpp"> <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild> <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> @@ -448,6 +505,7 @@ <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild> <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild> </ClCompile> + <ClCompile Include="..\project\business\GDN\tracer.so.cpp" /> <ClCompile Include="..\project\business\HR\AdministrativeDepartment.cpp"> <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild> <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">false</ExcludedFromBuild> diff --git a/jrj/ext-jrj/ext-jrj.vcxproj.filters b/jrj/ext-jrj/ext-jrj.vcxproj.filters index 7638a8b..ed3be24 100644 --- a/jrj/ext-jrj/ext-jrj.vcxproj.filters +++ b/jrj/ext-jrj/ext-jrj.vcxproj.filters @@ -112,6 +112,9 @@ <Filter Include="project\business\ProductSample"> <UniqueIdentifier>{4e706812-0c60-49af-ae6c-3f9e18a2cd65}</UniqueIdentifier> </Filter> + <Filter Include="project\business\Company"> + <UniqueIdentifier>{84413ffb-b8a4-4dfe-a715-ef03dec8f2ef}</UniqueIdentifier> + </Filter> </ItemGroup> <ItemGroup> <ClInclude Include="framework.h"> @@ -668,9 +671,6 @@ <ClCompile Include="..\project\analysis\DataVanalysisWin.cpp"> <Filter>vbusiness\analysis</Filter> </ClCompile> - <ClCompile Include="..\project\total3\ViewExTotalWin.cpp"> - <Filter>vbusiness\total</Filter> - </ClCompile> <ClCompile Include="..\project\tradedocument\DocFileSaveDlg.cpp"> <Filter>vbusiness\tradedocument</Filter> </ClCompile> @@ -839,5 +839,74 @@ <ClCompile Include="..\project\total3\viewex.total2.cpp"> <Filter>vbusiness\total</Filter> </ClCompile> + <ClCompile Include="..\project\business\GDN\CustomCodeNew.cpp"> + <Filter>project\business\GDN</Filter> + </ClCompile> + <ClCompile Include="..\project\business\GDN\po.paper.cpp"> + <Filter>project\business\GDN</Filter> + </ClCompile> + <ClCompile Include="..\project\business\GDN\tracer.so.cpp"> + <Filter>project\business\GDN</Filter> + </ClCompile> + <ClCompile Include="..\project\business\GDN\AdvanceChargeList.cpp"> + <Filter>project\business\AP</Filter> + </ClCompile> + <ClCompile Include="..\project\business\GDN\list.SOTrace3.cpp"> + <Filter>project\business\SO</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\CompanyList.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\CompanyMaint.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\HR_Address.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrEmployee.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrEmployeeAdd.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrEmployeex.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrJob.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrOrg.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrOrgChart.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrOrgMaint.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrOrgType.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\HRPerson.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrPersonAdd.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrPersonMaint.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrPersonSel.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrPosition.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\business\Company\HrPositionAdd.cpp"> + <Filter>project\business\Company</Filter> + </ClCompile> + <ClCompile Include="..\project\total3\ViewTotalWin.cpp"> + <Filter>vbusiness\total</Filter> + </ClCompile> </ItemGroup> </Project> \ No newline at end of file diff --git a/jrj/project/business/Company/CompanyList.cpp b/jrj/project/business/Company/CompanyList.cpp new file mode 100644 index 0000000..e862ca8 --- /dev/null +++ b/jrj/project/business/Company/CompanyList.cpp @@ -0,0 +1,214 @@ +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 +[ + CompanyList is extend list; + about CompanyList + [ + control: + + method: + [ + xdwgrid__ dw_list; + 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; + } + + int OnRetrieve() + { + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + //arg.AddArg("sType",c_type); + if (url::get("OrganizationStruct/list.CompanyInfo", arg.GetString(), x) != 1) + { + trace(x.GetXmlDoc().text); + return -1; + } + else + { + //trace(x.GetXml()); + dw_list.Retrieve(x); + dw_list.Redraw(); + } + dw_list.SetReadOnly(true); + 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); + //trace(row.toString()); + //win__::OpenWindow("dev:xpage[CompanyMaint.vx]",arg); + openUrl("组织架构.vface/xpage/CompanyInfo/maint", arg); + return 1; + } + + //命令发布函数 + int OnCmdDispatch(string comdid) + { + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + msxml::IXMLDOMElement e; + string sguid; + string sName; + + if (comdid == "AddRow") + { + arg.AddArg("operate", "new0"); + arg.AddArg("guid", ""); + //win__::OpenWindow("dev:xpage[CompanyMaint.vx]",arg); + openUrl("组织架构.vface/xpage/CompanyInfo/maint", arg); + } + else if (comdid == "ModifyRow") + { + 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); + sguid = e.SelectSingleNode("@guid").text; + arg.AddArg("operate", "modify"); + arg.AddArg("guid", sguid); + //win__::OpenWindow("dev:xpage[CompanyMaint.vx]",arg); + openUrl("组织架构.vface/xpage/CompanyInfo/maint", arg); + } + else if (comdid == "DeleteRow") + { + 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); + + sguid = 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", sguid); + trace(sguid); + xml__ x1 = new xml__; + x1.setNativePointer(x1.CreateInstance()); + if (url::post("OrganizationStruct/delete.CompanyInfo", arg.GetString(), x1) != 1) + { + string error = x1.GetXmlDoc().text; + trace(error); + } + else + { + win__::MessageBox(GetHWND(), "删除成功!", "提示", 0); + dw_list.DeleteRow(row); + } + + } + else if (comdid == "Refresh") + { + OnRetrieve(); + } + return 0; + } + + //命令处理事件 + int OnXCommand(ref TXCommandEvent evt, int p) + { + return OnCmdDispatch(evt.pStrID); + } + + int OnAttachEvent() + { + //绑定工具条点击事件 + AttachEvent("WM_XCOMMAND", OnXCommand); + //获取焦点事件,用于重置工具条 + AttachEvent("WM_SETFOCUS", OnSetFocus); + //双击 + AttachEvent("dw_list", "DWV_DOUBLECLICKED", OnDoubleClicked); + } + + int OnInitial() + { + SetAgent(); + OnAttachEvent(); + + return 1; + } + + int onload() + { + dw_list = new xdwgrid__; + dw_list.setNativePointer(this.GetControl("dw_list")); + + //xaserverarg__ args = new xaserverarg__; + //args.setNativePointer(args.CreateInstance()); + //args.AddArg("type","CompanyList"); + //dw_list.SetDataObject(GetServerUrl(),pref::getPref("HumanResource/GetHrObject",args.GetString())); + dw_list.openUrl("组织架构.vface/template/company/list"); + dw_list.SetSelectionMode(1); + dw_list.SetReadOnly(true); + + OnInitial(); + OnRetrieve(); + + return 1; + } + + ] + + ] +] \ No newline at end of file diff --git a/jrj/project/business/Company/CompanyMaint.cpp b/jrj/project/business/Company/CompanyMaint.cpp new file mode 100644 index 0000000..0ade828 --- /dev/null +++ b/jrj/project/business/Company/CompanyMaint.cpp @@ -0,0 +1,403 @@ +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 "dev:vm[pagecontrol.vm]" +use "maint.vl" +use "publiccode.vl" + +unit vbusiness.xpage +[ + CompanyMaint is extend maint; + about CompanyMaint + [ + control: + + method: + [ + pagecontrol__ m_layer; + xdwtable__ dw_detail; + xdwtable__ dw_bank; + string m_operate; + string m_sguid; + + 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 param) + { + SetAgent(); + + //重置工具条 + return 1; + } + + int OnPreSave() + { + xdwtable__ dw = new xdwtable__; + dw.setNativePointer(dw_detail.FindDwTable("CompanyInfo", 0)); + string sPartyNo = dw.GetItemString(1, "PartyNo", 0); + if (sPartyNo == "" || sPartyNo == nil) + { + string sGetNo = publiccode::GetIdentityNo(""); + dw.SetItemString(1, "PartyNo", sGetNo); + //alert("公司编号为空!"); + //return -1; + } + string sPartyName = dw.GetItemString(1, "Name", 0); + if (sPartyName == "" || sPartyName == nil) + { + alert("公司名称为空!"); + return -1; + } + + string suserid = publiccode::GetUserInfo().id; + string sdate = publiccode::GetCurDate(); + dw.SetItemString(1, "ModifierID", suserid); + dw.SetItemString(1, "ModifyDate", sdate); + + dw.setNativePointer(dw_bank.FindDwTable("item", 0)); + if (dw) + { + string sno; + string sname, + string status; + int i; + int row = dw.GetRowCount(); + for (i = 1; i <= row; i++) + { + status = dw.GetItemString(i, "Status", 0) + ""; + if (status == "" || status == nil) + { + dw.SetItemString(i, "Status", "Y"); + //alert("第"+i.toString()+"行状态为空"); + //return -1; + } + /* + sno=dw.GetItemString(i,"BankAccountNo",0)+""; + sname=dw.GetItemString(i,"BankName",0)+""; + status=dw.GetItemString(i,"Status",0)+""; + if (sno=="" || sno==nil) + { + if(sname !="" && sname != nil) + { + alert("第"+i.toString()+"行银行编号为空"); + return -1; + } + } + + if (sname=="" || sname==nil) + { + if(sno !="" && sno != nil) + { + alert("第"+i.toString()+"行银行名称为空"); + return -1; + } + } + else + { + if (status=="" || status==nil) + { + dw.SetItemString(i,"Status","Y"); + //alert("第"+i.toString()+"行状态为空"); + //return -1; + } + } + */ + } + } + return 1; + } + + int OnSave() + { + dw_detail.AcceptText(); + dw_bank.AcceptText(); + int rec; + rec = OnPreSave(); + if (rec == -1) + return -1; + + int hIcon = xutil__::SetCursorWait(); + + string val, val2; + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + var xdoc = x.GetXmlDoc(); + dw_detail.DwUpdateAllTo(xdoc); + //val = xdoc.xml ; + dw_bank.DwUpdateAllTo(xdoc); + val = xdoc.xml; + trace(val); + xaserverarg__ args = new xaserverarg__; + args.setNativePointer(args.CreateInstance()); + args.AddArg("content", val); + args.AddArg("dbmap", "CompanyInfo.dbmap"); + //trace(m_EntityValueEx); + xml__ x1 = new xml__; + x1.setNativePointer(x1.CreateInstance()); + if (url::post("OrganizationStruct/update.companyinfoex", args.GetString(), x1) != 1) + //if (xaserver__::ExecXAction("","[update.CompanyInfoEx.xa]",args.GetString(),x1) !=1) + { + string error = x1.GetXmlDoc().text; + trace(error); + } + else + { + trace(x1.GetXml()); + if (x1.GetXmlDoc().selectSingleNode("error")) + { + alert("保存出错2!"); + return 0; + } + win__::MessageBox(GetHWND(), "保存成功!", "提示", 0); + } + xutil__::RestoreCursor(hIcon); + dw_detail.ResetUpdateStatus(); + dw_bank.ResetUpdateStatus(); + var xdoc2 = x.GetXmlDoc(); + dw_detail.DwUpdateAllTo(xdoc2); + val = xdoc.xml; + trace(val); + return 1; + } + + int OnItemChanged(ref TNotifyEvent evt, int p) + { + ref DWNMHDR dwhdr = evt.pnmh; + int row = dwhdr.row; + string col = dwhdr.colname; + string data = dwhdr.data; + if (col == "Name") + { + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("Name", data); + } + + 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 == "TradeType") { + arg.AddArg("ResourceType", "TradeType");//贸易方式 + } + if (xaserver__::ExecXQuery(GetServerUrl(), query, arg.GetString(), x) == 1) + dwhdr.data = x.GetXml(); + //trace(x.GetXml()); + } + return 1; + } + + int OnAddRow() + { + int h = m_layer.GetSheetIndex(); + if (h == 1) + { + xdwtable__ dw = new xdwtable__; + dw.setNativePointer(dw_bank.GetCurTable()); + string dw_n = dw.GetDwName(); + if (dw_n == "item") + { + int row = dw.InsertRow(0); + dw.SetItemString(row, "Status", "Y"); + } + } + return 1; + } + + int OnInsertRow() + { + int h = m_layer.GetSheetIndex(); + if (h == 1) + { + xdwtable__ dw = new xdwtable__; + dw.setNativePointer(dw_bank.GetCurTable()); + string dw_n = dw.GetDwName(); + if (dw_n == "item") + { + int row = dw.GetRow(); + int crow = dw.InsertRow(row); + dw.SetItemString(crow, "Status", "Y"); + } + } + return 1; + } + + int OnDeleteRow() + { + int h = m_layer.GetSheetIndex(); + if (h == 1) + { + xdwtable__ dw = new xdwtable__; + dw.setNativePointer(dw_bank.GetCurTable()); + string dw_n = dw.GetDwName(); + if (dw_n == "item") + { + int row = dw.GetRow(); + dw.DeleteRow(row); + } + } + 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(); + 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_detail", "DWV_CHILDCONTENT", OnChildContent); + AttachEvent("dw_detail", "DWV_ITEMCHANGED", OnItemChanged); + } + + int OnRetrieve() + { + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("guid", m_sguid); + //trace(m_sguid); + //if (url::get("OrganizationStruct/detail.CompanyInfo",arg.GetString(),x) != 1) + if (url::post("OrganizationStruct/detail.CompanyInfo", arg.GetString(), x) != 1) + { + trace(x.GetXmlDoc().text); + return -1; + } + else + { + dw_detail.Retrieve(x); + dw_detail.Redraw(); + dw_bank.Retrieve(x); + dw_bank.Redraw(); + //trace(x.GetXml()); + } + + return 1; + } + + int OnInitial() + { + SetAgent(); + + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg = this.GetParam(); + if (arg) + { + m_operate = arg.GetArgString("operate"); + m_sguid = arg.GetArgString("guid"); + } + /*if ( m_sguid == "" || m_sguid == nil) + { + m_sguid = win__::GetGuid(); + trace(m_sguid); + }*/ + + OnAttachEvent(); + + return 1; + } + + int onload() + { + m_layer = new pagecontrol__; + m_layer.setNativePointer(this.GetControl("cTab")); + + dw_detail = new xdwtable__; + dw_detail.setNativePointer(this.GetControl("dw_detail")); + dw_detail.openUrl("组织架构.vface/template/company/detail"); + dw_detail.SetColHeaderHeight(0); + dw_detail.SetRowSelectorWidth(0); + dw_bank = new xdwtable__; + dw_bank.setNativePointer(this.GetControl("dw_bank")); + dw_bank.openUrl("组织架构.vface/template/company/bank"); + + OnInitial(); + if (m_sguid != "") { + OnRetrieve(); + } + else { + xdwtable__ dw = new xdwtable__; + dw.setNativePointer(dw_detail.FindDwTable("CompanyInfo", 0)); + dw.SetItemString(1, "Status", "1"); + dw.SetItemString(1, "InternalFlag", "Y"); + dw.SetItemString(1, "Type", "0"); + string suserid = publiccode::GetUserInfo().id; + /*string susername = publiccode::GetUserInfo().name; + string sdate = publiccode::GetCurDate(); + dw.SetItemString(1,"CreatorID",suserid); + dw.SetItemDisplayString(1,"CreatorID",susername); + dw.SetItemString(1,"CreateDate",sdate);*/ + + dw.setNativePointer(dw_detail.FindDwTable("address", 0)); + dw.SetItemString(1, "IdentifyAddressFlag", "Y"); + dw.SetItemString(1, "Status", "1"); + dw.setNativePointer(dw_detail.FindDwTable("Regist", 0)); + dw.SetItemString(1, "IdentifyAddressFlag", "N"); + dw.SetItemString(1, "Status", "1"); + + dw.setNativePointer(dw_bank.FindDwTable("item", 0)); + if (dw) { + //msxml::IXMLDOMElement ele = dw.GetElement(); + //trace(ele.xml); + //dw.SetItemString(1,"Status","Y"); + } + } + return 1; + } + + ] + + ] +] \ No newline at end of file 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 diff --git a/jrj/project/business/Company/HR_Address.cpp b/jrj/project/business/Company/HR_Address.cpp new file mode 100644 index 0000000..cb4571d --- /dev/null +++ b/jrj/project/business/Company/HR_Address.cpp @@ -0,0 +1,211 @@ +#include <wobject/xstring.hpp> +#include <xcontrol/xtreeview.hpp> +#include <xcontrol/xdwgrid.hpp> + +#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp" +#include "viewobject/view.base.hpp" + +using xml = KXMLDOMDocument; + class __declspec(dllexport) Deduction : public xframe + { + public: + xdwgrid dw_list; + xstring EntityID; + xstring InvoiceNo; + + xnode m_agentNode; //Agent Condition + + public: + Deduction(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {} + public: + static Deduction* CreateInstance(void* implPtr, void* hWnd) + { + Deduction* pWin = new Deduction(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 OnRowChanged(TEvent* evt, LPARAM p) + { + DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh; + int row = hdr.row; + SetAgent(); + return 1; + } + + //焦点激活处理函数 + int OnSetFocus(TEvent* evt, LPARAM param) + { + //重置工具条 + SetAgent(); + return 1; + } + + //命令发布函数 + int OnCmdDispatch(xstring comdid) + { + if (comdid == L"xmSave") + { + OnSave(); + return 1; + } + if (comdid == L"xmSearch") + { + OnRetrieve(InvoiceNo, EntityID); + return 1; + } + if (comdid == L"xmClose") + { + CloseWindow(); + return 1; + } + return 0; + } + + //命令处理事件 + int OnXCommand(TEvent* evt, LPARAM param) + { + return OnCmdDispatch(evt->xcommand.pStrID); + } + + xstring GetGuid() + { + return publiccode::GetGuid(); + } + + int OnSave() + { + xml x; + + dw_list.AcceptText(); + dw_list.DwUpdateAllToEx(x); + xaserverarg arg ; + + arg.AddArg(L"content", x.xml()); + trace(x.xml()); + if (xurl::get(L"/sale/data/AR/update/ARDeduction", arg.GetString(), x) != 1) + { + xstring error = x.text(); + alert(L"err:" + error); + return 1; + } + xstring str = x.documentElement().getAttribute(L"text"); + if (str == L"true") + { + dw_list.ResetUpdateStatus(); + alert(L"保存成功!"); + } + else + { + alert(L"保存失败!"); + } + return 1; + } + + int OnItemChanged(TEvent* evt, LPARAM p) + { + DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh; + xstring colname = hdr.colname; + xstring value = hdr.data; + int row = hdr.row; + xstring dwname = L"dw_list"; + if (colname == L"DeductionAmount") + { + dw_list.SetItemString(row, L"SettlementAdjustID", EntityID); + xstring id = publiccode::GetGuid(); + KXMLDOMElement ele = dw_list.GetRowElement(row); + ele.setAttribute(L"guid", id); + //dw_list.SetGuid(row,id); + //alert(ele.xml); + //alert(dw_list.GetGuid(row)); + } + dw_list.Redraw(); + return 1; + } + + int OnAttachEvent() + { + //绑定工具条点击事件 + AttachEvent(L"WM_XCOMMAND", (FEvent)&Deduction::OnXCommand); + //获取焦点事件,用于重置工具条 + AttachEvent(L"WM_SETFOCUS", (FEvent)&Deduction::OnSetFocus); + AttachEvent(L"dw_list", L"DWV_ROWFOCUSCHANGED", (FEvent)&Deduction::OnRowChanged); + AttachEvent(L"dw_list", L"DWV_ITEMCHANGED", (FEvent)&Deduction::OnItemChanged); + return 1; + } + + + int OnRetrieve(xstring InvoiceNo, xstring EntityID) + { + xml x; + + xaserverarg arg ; + + arg.AddArg(L"InvoiceNo", InvoiceNo); + arg.AddArg(L"InvoiceNoEx", xcontrol(GetControl(L"search")).GetText()); + arg.AddArg(L"EntityID", EntityID); + + //trace(GetControl(L"search").GetText()); + if (getUrl(L"/sale/data/AR/DeductionList", arg.GetString(), x) != 1) + { + trace(x.text()); + return -1; + } + else + { + dw_list.Retrieve(x); + dw_list.Redraw(); + } + dw_list.SetSelectionMode(1); + return 1; + } + + int onload() + { + SetArg(); + dw_list = GetControl(L"dw_list"); + dw_list.openUrl(L"/sale/view/AR/template/Deduction"); + + dw_list.SetColumnState(L"ID", false); + dw_list.SetColumnState(L"GDNLineID", false); + dw_list.SetColumnState(L"SettlementAdjustID", false); + + + if (GetWinParam()) + { + xaserverarg arg = GetArg(); + EntityID = arg.GetArgString(L"EntityID"); + InvoiceNo = arg.GetArgString(L"InvoiceNo"); + } + trace(InvoiceNo); + OnRetrieve(InvoiceNo, EntityID); + OnAttachEvent(); + return 1; + } + + int onloaded() + { + SetAgent(); + + return 1; + } + }; diff --git a/jrj/project/business/Company/HrEmployee.cpp b/jrj/project/business/Company/HrEmployee.cpp new file mode 100644 index 0000000..bc48927 --- /dev/null +++ b/jrj/project/business/Company/HrEmployee.cpp @@ -0,0 +1,390 @@ +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 +[ + HrEmployee is extend list; + about HrEmployee + [ + field: + [ + treeview__ tv_org; + xdwgrid__ dw_emp; + + string is_orgid + string is_orgname; + string is_inflag; + xdwtable__ dw_empmaint; + 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); + } + } + //焦点激活处理函数 + int OnSetFocus(ref TEvent evt, int p) + { + SetAgent(); + //重置工具条 + 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/list.Employee", arg.GetString(), x) == 1) + { + dw_emp.Retrieve(x); + dw_emp.Redraw(); + } + //trace(x.GetXml()); + return 1; + } + + int OnSave() + { + int hIcon = xutil__::SetCursorWait(); + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + dw_emp.AcceptText(); + dw_emp.DwUpdateAllToEx(x.GetXmlDoc()); + + string val = x.GetXml(); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("content", val); + //trace(x.GetXml()); + //return 1; + if (url::post("OrganizationStruct/update.Employee", arg.GetString(), x) != 1) + { + trace(x.GetXmlDoc().documentElement.text); + alert("保存失败"); + } + else { + dw_emp.ResetUpdateStatus(); + alert("保存成功"); + } + trace(x.GetXml()); + xutil__::RestoreCursor(hIcon); + return 1; + } + + int OnSubTree(string id, int parentitem) + { + int wid = tv_org.GetId(); + if (treeview__::GetChildItem(wid, parentitem) > 0) return 1; + xml__ x = new xml__; + x.setNativePointer(xml__::CreateInstance()); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("sguid", id); + if (url::post("/sale/data/OrganizationStruct/tree.child.OrgChart", arg.GetString(), x) != 1) + { + trace(x.GetXml()); + return -1; + } + //trace(x.GetXml()); + var list = x.GetXmlDoc().selectNodes("//item"); + int i = 0, s = list.length; + msxml::IXMLDOMElement xitem; + string sName; + string sguid; + string stype; + if (s > 0) + { + for (i = 0; i < s; i++) + { + xitem = list.item(i); + sName = xitem.SelectSingleNode("name").text; + sguid = xitem.SelectSingleNode("id").text; + stype = xitem.SelectSingleNode("typ").text; + //int curItem = tv_org.InsertChildItemEx(wid,parentitem,sName,xitem,15,4); + int curItem = 0; + if (stype == "Org") + { + curItem = tv_org.InsertChildItemEx(wid, parentitem, sName, xitem, 15, 4); + tv_org.SetItemChild1(wid, curItem, 1); + } + else + { + curItem = tv_org.InsertChildItemEx(wid, parentitem, sName, xitem, 21, 21); + } + //OnSubTree(sguid,curItem); + } + } + return 1; + } + + int OnCreateTree(string id, int parentitem) + { + //while (tv_1.GetRootItem()>0) + // tv_1.DeleteItem(tv_1.GetRootItem()); + int wid = tv_org.GetId(); + xml__ x = new xml__; + x.setNativePointer(xml__::CreateInstance()); + x.LoadXml("<item><id>" + id + "</id><no/><name>宁波家尔佳</name><typ>Org</typ></item>"); + //msxml::IXMLDOMDocument root = x.GetXmlDoc(); + //msxml::IXMLDOMElement RDoc = x.GetXmlDoc().documentElement; + //msxml::IXMLDOMElement ele = RDoc.SelectSingleNode("//Org"); + msxml::IXMLDOMElement ele = x.GetXmlDoc().SelectSingleNode("//item"); + int hItem = treeview__::InsertChildItemEx(wid, 0, "宁波家尔佳", ele, 15, 4); + treeview__::SetItemChild1(wid, hItem, 1); + return 1; + + /*xaserverarg__ arg=new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("sguid",id); + if(url::post("/sale/data/OrganizationStruct/tree.child.OrgChart",arg.GetString(),x)!=1) + { + trace(x.GetXml()); + return -1; + } + //trace(x.GetXml()); + var list=x.GetXmlDoc().selectNodes("//item"); + int i=0,s=list.length; + msxml::IXMLDOMElement xitem; + string sName; + string sguid; + if (s >0) + { + for (i=0;i<s;i++) + { + xitem= list.item(i); + sName = xitem.SelectSingleNode("@name").text; + sguid = xitem.SelectSingleNode("@id").text; + int curItem = tv_org.InsertChildItemEx(wid,hItem,sName,xitem,15,4); + tv_org.SetItemChild1(wid,curItem,1); + //OnSubTree(sguid,curItem); + } + } + return 1;*/ + } + + int OnTreeExpanding(ref TNotifyEvent evt, int p) + { + ref NMTREEVIEW nmtv = evt.pnmh; + int sitem = nmtv.itemNew.hItem; + + int hCursor = xutil__::SetCursorWait(); + //string id = treeview__::GetItemData(tv_org.GetId(), sitem); + msxml::IXMLDOMElement ele = treeview__::GetItemData(tv_org.GetId(), sitem); + string id = ele.SelectSingleNode("id").text; + OnSubTree(id, sitem); + xutil__::RestoreCursor(hCursor); + 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); + if (ele) + { + string ls_orgid = ele.SelectSingleNode("id").text; + is_orgid = ls_orgid; + OnRetrieve(ls_orgid); + } + return 1; + } + + int OnAddRow() + { + int wid = tv_org.GetId(); + int hitem = treeview__::GetSelectedItem(wid); + if (!hitem) + { + alert("请选择岗位!"); + return 0; + } + else + { + msxml::IXMLDOMElement ele = treeview__::GetItemData(wid, hitem); + string stype = ele.SelectSingleNode("typ").text; + if (stype != "Pos") + { + alert("请选择岗位!"); + return 0; + } + } + + OpenWindow("dev:xpage[HrEmployeeAdd.vx]", this); + //openUrl("组织架构.vface/xpage/Hr/HrEmployeeAdd", this); + return 1; + } + + int OnModifyRow() + { + int row = dw_emp.GetNextSelectRow(1); + if (row < 1) + { + row = dw_emp.GetRow(); + if (row < 1) + { + win__::MessageBox(GetHWND(), "请选中要修改的任职信息行!", "提示", 0); + return -1; + } + } + int wid = dw_emp.GetId(); + msxml::IXMLDOMElement e = dw_emp.GetRowElement(row); + string sPersonID = e.selectSingleNode("PersonID").text; + //trace(e.xml); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("operate", "modify"); + arg.AddArg("guid", sPersonID); + //xwin::OpenWindow("dev:xpage[HrPersonMaint.xpage]",arg); + openUrl("组织架构.vface/xpage/Hr/HrPersonMaint", arg); + return 1; + } + + int OnDeleteRow() + { + int ll_row = dw_emp.GetNextSelectRow(1); + if (ll_row < 1) + { + ll_row = dw_emp.GetRow(); + if (ll_row < 1) + { + win__::MessageBox(GetHWND(), "请选中要删除的任职信息行!", "提示", 0); + return -1; + } + } + string sName = dw_emp.GetItemDisplayString(ll_row, "PersonID", 0); + if (win__::MessageBox(GetHWND(), "确定删除" + sName + "任职信息吗?", "提示", 1) != 1) + return 0; + + msxml::IXMLDOMElement ele = dw_emp.GetRowElement(ll_row); + string empid = ele.selectSingleNode("@guid").text; + + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + xaserverarg__ args = new xaserverarg__; + args.setNativePointer(args.CreateInstance()); + args.AddArg("guid", empid); + //if(xaserver__::ExecXAction(GetServerUrl(),"[MSSqlHrEmployeeDel.xq]",args.GetString(),x) !=1) + if (url::post("OrganizationStruct/delete.Employee", args.GetString(), x) != 1) + { + string error = x.GetXmlDoc().text; + trace(error); + } + else + { + dw_emp.DeleteRow(ll_row); + } + + return 1; + } + + int SetText() + { + win__::SetWindowText(GetHWND(), "所属组织:" + is_orgname + " 操作状态:" + is_inflag); + return 1; + } + + //xgridex双击 + int OnDoubleClicked(ref TNotifyEvent evt, int p) + { + ref DWNMHDR hdr = evt.pnmh; + int row = hdr.row; + if (row < 1 || row > dw_emp.GetRowCount()) + return 1; + msxml::IXMLDOMElement e = dw_emp.GetRowElement(row); + string sPersonID = e.selectSingleNode("PersonID").text; + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("operate", "modify"); + arg.AddArg("guid", sPersonID); + //xwin::OpenWindow("dev:xpage[HrPersonMaint.xpage]",arg); + openUrl("组织架构.vface/xpage/Hr/HrPersonMaint", arg); + return 1; + } + + //命令发布函数 + int OnCmdDispatch(string comdid) + { + if (comdid == "Save") return OnSave(); + else if (comdid == "AddRow") return OnAddRow(); + else if (comdid == "ModifyRow") return OnModifyRow(); + else if (comdid == "DeleteRow") return OnDeleteRow(); + else if (comdid == "Refresh") return OnRetrieve(is_orgid); + /*else if(comdid =="adjustorg") return OnAdjustOrg();*/ + + 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("tv_org", "TVN_ITEMEXPANDING", OnTreeExpanding); + AttachEvent("dw_emp", "DWV_DOUBLECLICKED", OnDoubleClicked); + } + + int OnInitial() + { + m_agentNode = new xnode__; + SetAgent(); + OnAttachEvent(); + + return 1; + } + + int onload() + { + tv_org = new treeview__; + tv_org.setNativePointer(this.GetControl("tv_org")); + dw_emp = new xdwgrid__; + dw_emp.setNativePointer(this.GetControl("dw_emp")); + dw_emp.openUrl("组织架构.vface/template/HrEmployee/list"); + //dw_emp.SetReadOnly(true); + //dw_emp.SetSelectionMode(1); + + OnInitial(); + OnCreateTree("00000000-0000-0000-0000-000000000000", 0); + int wid = tv_org.GetId(); + int root = treeview__::GetRootItem(wid); + treeview__::ExpandItem(wid, root); + return 1; + } + ] + + ] +] \ No newline at end of file diff --git a/jrj/project/business/Company/HrEmployeeAdd.cpp b/jrj/project/business/Company/HrEmployeeAdd.cpp new file mode 100644 index 0000000..32d7ae0 --- /dev/null +++ b/jrj/project/business/Company/HrEmployeeAdd.cpp @@ -0,0 +1,193 @@ +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" +use "dev:code[HrEmployee.vx]" +use "publiccode.vl" + +//unit vclient.vobject tpp +unit vbusiness.xpage +[ + HrEmployeeAdd is extend frame; + about HrEmployeeAdd + [ + field: + [ + HrEmployee lw_obj; + xdwgrid__ dw_list; + + xnode__ m_agentNode; //Agent Condition + string m_agentCond; //Agent Node + string m_sTxt; + ] + + 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() + { + control__ xc = new control__; + xc.setNativePointer(this.GetControl("QueryTxt")); + m_sTxt = xc.GetText() + ""; + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("sTxt", m_sTxt); + if (url::post("OrganizationStruct/select.Employee", arg.GetString(), x) != 1) + { + trace(x.GetXmlDoc().text); + return -1; + } + else + { + dw_list.Retrieve(x); + dw_list.Redraw(); + dw_list.SetReadOnly(true); + } + return 1; + } + + int OnOK() + { + if (GetParam()) + { + lw_obj = new HrEmployee; + lw_obj.setNativePointer(GetParam()); + lw_obj = GetParam(); + } + else + return 0; + + int row = dw_list.GetNextSelectRow(1); + if (row < 1) + { + alert("请选择人员!"); + return 1; + } + + string sPositionID, sPositionName; + string sOrgID, sOrgName; + string sJobID, sJobName; + int wid = lw_obj.tv_org.GetId(); + int hitem = treeview__::GetSelectedItem(wid); + msxml::IXMLDOMElement ele = treeview__::GetItemData(wid, hitem); + if (ele) + { + sPositionID = ele.SelectSingleNode("id").text; + sPositionName = ele.SelectSingleNode("name").text; + sOrgID = ele.SelectSingleNode("OrgID").text; + sOrgName = ele.SelectSingleNode("OrgName").text; + sJobID = ele.SelectSingleNode("JobID").text; + sJobName = ele.SelectSingleNode("JobName").text; + } + + while (row > 0) + { + msxml::IXMLDOMElement e = dw_list.GetRowElement(row); + string sEmployeeNo = e.selectSingleNode("EmployeeNo").text + ""; + string sPersonID = e.selectSingleNode("PersonID").text + ""; + string sPersonName = e.selectSingleNode("Name").text + ""; + + int nRow = lw_obj.dw_emp.InsertRow(0); + lw_obj.dw_emp.SetItemString(nRow, "EmployeeNo", sEmployeeNo); + lw_obj.dw_emp.SetItemString(nRow, "PersonID", sPersonID); + lw_obj.dw_emp.SetItemDisplayString(nRow, "PersonID", sPersonName); + + lw_obj.dw_emp.SetItemString(nRow, "PositionID", sPositionID); + lw_obj.dw_emp.SetItemDisplayString(nRow, "PositionID", sPositionName); + lw_obj.dw_emp.SetItemString(nRow, "OrgID", sOrgID); + lw_obj.dw_emp.SetItemDisplayString(nRow, "OrgID", sOrgName); + lw_obj.dw_emp.SetItemString(nRow, "JobID", sJobID); + lw_obj.dw_emp.SetItemDisplayString(nRow, "JobID", sJobName); + + lw_obj.dw_emp.SetItemString(nRow, "Status", "Y"); + lw_obj.dw_emp.SetItemDisplayString(nRow, "Status", "有效"); + string sdate = publiccode::GetCurDate() + ""; + lw_obj.dw_emp.SetItemString(nRow, "StartDate", sdate + ""); + lw_obj.dw_emp.SetItemString(nRow, "EndDate", "2050-12-31"); + + row = dw_list.GetNextSelectRow(row + 1); + } + CloseWindow(); + return 1; + } + + //命令发布函数 + int OnCmdDispatch(string comdid) + { + if (comdid == "xmOk") + OnOK(); + else if (comdid == "query") + OnRetrieve(); + else if (comdid == "xmCancel") + CloseWindow(); + return 0; + } + + //命令处理事件 + int OnXCommand(ref TXCommandEvent evt, int param) + { + return OnCmdDispatch(evt.pStrID); + } + + int OnAttachEvent() + { + //绑定工具条点击事件 + AttachEvent("WM_XCOMMAND", OnXCommand); + //获取焦点事件,用于重置工具条 + AttachEvent("WM_SETFOCUS", OnSetFocus); + } + + int OnInitial() + { + SetAgent(); + OnAttachEvent(); + return 1; + } + + int onload() + { + dw_list = new xdwgrid__; + dw_list.setNativePointer(this.GetControl("dw_list")); + dw_list.openUrl("组织架构.vface/template/HrEmployee/PersonSel"); + dw_list.SetSelectionMode(3); //3 + dw_list.SetReadOnly(true); + + OnInitial(); + OnRetrieve(); + + return 1; + } + ] + + ] +] \ No newline at end of file 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 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 diff --git a/jrj/project/business/Company/HrOrg.cpp b/jrj/project/business/Company/HrOrg.cpp new file mode 100644 index 0000000..0d8a459 --- /dev/null +++ b/jrj/project/business/Company/HrOrg.cpp @@ -0,0 +1,487 @@ +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 +[ + HrOrg is extend list; + about HrOrg + [ + control: + + method: + [ + xdwgrid__ dw_list; + treeview__ tv_org; + string sOrgID; + string sOrgName; + + string sRootOrgID; + string sRootOrgName; + + 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 OnRetrieve() + { + int hIcon = xutil__::SetCursorWait(); + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("guid", sOrgID); + if (url::get("OrganizationStruct/list.HrOrg", arg.GetString(), x) != 1) + { + trace(x.GetXmlDoc().text); + return -1; + } + else + { + dw_list.Retrieve(x); + dw_list.Redraw(); + } + dw_list.SetReadOnly(true); + xutil__::RestoreCursor(hIcon); + return 1; + } + + //焦点激活处理函数 + int OnSetFocus(ref TEvent evt, int p) + { + SetAgent(); + //OnRetrieve(); + //重置工具条 + return 1; + } + + int OnCreateTree(string sguid, int parentitem) + { + int wid = tv_org.GetId(); + xml__ x = new xml__; + x.setNativePointer(xml__::CreateInstance()); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("sguid", sguid); + if (url::post("/sale/data/OrganizationStruct/tree.child.OrgChart", arg.GetString(), x) != 1) + { + trace(x.GetXml()); + return -1; + } + //trace(x.GetXml()); + var list = x.GetXmlDoc().selectNodes("//Org"); + int i = 0, s = list.length; + msxml::IXMLDOMElement xitem; + string sname; + string sguid; + if (s > 0) + { + for (i = 0; i < s; i++) + { + xitem = list.item(s - i - 1); + sname = xitem.SelectSingleNode("OrgName").text; + sguid = xitem.SelectSingleNode("@guid").text; + int curItem = tv_org.InsertChildItemEx(wid, parentitem, sname, xitem, 15, 4); + OnCreateTree(sguid, curItem); + /*string id = xitem.selectSingleNode("ModuleID").text; + string Name=""; + if(xitem.selectSingleNode("ModuleName")) Name=xitem.selectSingleNode("ModuleName").text; + string image = 15; + if(xitem.selectSingleNode("ModuelImage")) image=xitem.selectSingleNode("ModuelImage").text; + int curItem=treeview__::InsertItem(tv_menu.GetId(), parentItem,0,Name,id,image.toInt()); + string child=xitem.selectSingleNode("@child").text;//item.getAttribute("HasChild"); + if (child != "0") + treeview__::SetItemChild1(tv_menu.GetId(), curItem,1);*/ + } + } + return 1; + } + + int OnTreeExpanding(ref TNotifyEvent evt, int p) + { + ref NMTREEVIEW nmtv = evt.pnmh; + int sitem = nmtv.itemNew.hItem; + + string id = treeview__::GetItemData(tv_org.GetId(), sitem); + int hCursor = xutil__::SetCursorWait(); + OnCreateTree(id, sitem); + xutil__::RestoreCursor(hCursor); + return 1; + } + + //树点击事件 + int OnTreeSelecded(ref TNotifyEvent evt, int p) + { + ref NMTREEVIEW nmtv = evt.pnmh; + int hItem = nmtv.itemNew.hItem; + int wid = tv_org.GetId(); + int hitem = treeview__::GetSelectedItem(wid); + msxml::IXMLDOMElement ele = treeview__::GetItemData(wid, hitem); + + int hroot = treeview__::GetParentItem(wid, hitem); + int hparent = treeview__::GetParentItem(wid, hroot); + if (!hparent) + { + hparent = hroot; + hroot = hitem; + } + bool found = false; + if (hparent) found = true; + while (treeview__::GetParentItem(wid, hparent)) + { + hroot = hparent; + hparent = treeview__::GetParentItem(wid, hroot); + } + if (found) + { + msxml::IXMLDOMElement ele1 = treeview__::GetItemData(wid, hroot); + //trace(ele1.xml); + //sRootOrgID = ele1.SelectSingleNode("CompanyID").text; + //sRootOrgName = ele1.selectSingleNode("CompanyID/@_displaystring").text; + } + + string ls_orgid = ele.SelectSingleNode("@guid").text; + sOrgID = ls_orgid + ""; + //trace(sOrgID); + sOrgName = ele.selectSingleNode("OrgName").text; + OnRetrieve(); + return 1; + } + + int OnTreeMoveNode(ref TNotifyEvent evt, int p) + { + ref TVNNMHDR nmtv = evt.pnmh; + int xfrom = nmtv.FromItem; + int xto = nmtv.ToItem; + + int ret = win__::MessageBox(this.GetHWND(), "确定移动组织节点?", "提示:", 1); + //trace(ret); + int wid = tv_org.GetId(); + if (ret == 2) + { + treeview__::DeleteItem(wid, xto); + return -1; + } + + //string fid = treeview__::GetItemData(wid, xfrom); + //string tid = treeview__::GetItemData(wid, xto); + int xtop = treeview__::GetParentItem(wid, xto); + msxml::IXMLDOMElement ef = treeview__::GetItemData(wid, xfrom); + msxml::IXMLDOMElement et = treeview__::GetItemData(wid, xtop); + string fid = ef.SelectSingleNode("@guid").text;//ef.xml; + string tid = et.SelectSingleNode("@guid").text;//et.xml; + xml__ x = new xml__; + x.setNativePointer(xml__::CreateInstance()); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("from", fid); + arg.AddArg("to", tid); + //trace(et.xml); + //return 1; + if (url::post("OrganizationStruct/move.update.HrOrg", arg.GetString(), x) != 1) + { + trace("error:" + x.GetXml()); + alert("移动组织节点出错!"); + treeview__::DeleteItem(wid, xto); + return 0; + } + treeview__::DeleteItem(wid, xfrom); + 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); + arg.AddArg("tvOrgID", sOrgID); + arg.AddArg("tvOrgName", sOrgName); + arg.AddArg("tvRootOrgID", sRootOrgID); + arg.AddArg("tvRootOrgName", sRootOrgName); + //trace(row.toString()); + //win__::OpenWindow("dev:xpage[HrOrgMaint.xpage]",arg); + openUrl("组织架构.vface/xpage/HrOrg/maint", arg); + return 1; + } + + int AddRow() + { + /*int wid = tv_org.GetId(); + int hitem=treeview__::GetSelectedItem(wid); + int root=treeview__::GetRootItem(wid); + if (hitem == root) + { + win32::MessageBox(GetHWND(),"根组织!","提示",0); + return -1; + }*/ + //int row = dw_list.GetNextSelectRow(1); + //IXMLDOMElement e = dw_list.GetRowElement(row); + //string sguid = e.getAttribute("guid"); + + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("operate", "new0"); + arg.AddArg("guid", ""); + arg.AddArg("tvOrgID", sOrgID); + arg.AddArg("tvOrgName", sOrgName); + arg.AddArg("tvRootOrgID", sRootOrgID); + arg.AddArg("tvRootOrgName", sRootOrgName); + openUrl("组织架构.vface/xpage/HrOrg/maint", arg); + return 1; + } + + int ModifyRow() + { + int row = dw_list.GetNextSelectRow(1); + if (row < 1) + { + row = dw_list.GetRow(); + if (row < 1) + { + win__::MessageBox(GetHWND(), "请选中要修改的组织数据行!", "提示", 0); + 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); + arg.AddArg("tvOrgID", sOrgID); + arg.AddArg("tvOrgName", sOrgName); + arg.AddArg("tvRootOrgID", sRootOrgID); + arg.AddArg("tvRootOrgName", sRootOrgName); + openUrl("组织架构.vface/xpage/HrOrg/maint", arg); + return 1; + } + + int OnDeleteItem(string sguid) + { + int wid = tv_org.GetId(); + int hitem = treeview__::GetSelectedItem(wid); + int ditem = treeview__::GetChildItem(wid, hitem); + msxml::IXMLDOMElement e = treeview__::GetItemData(wid, ditem); + if (e) + { + string dguid = e.SelectSingleNode("@guid").text; + while (dguid != sguid) + { + ditem = treeview__::GetNextItem(wid, ditem); + e = treeview__::GetItemData(wid, ditem); + dguid = e.SelectSingleNode("@guid").text; + } + treeview__::DeleteItem(wid, ditem); + } + return 1; + } + int DeleteRow() + { + int row = dw_list.GetNextSelectRow(1); + if (row < 1) + { + row = dw_list.GetRow(); + if (row < 1) + { + //win__::MessageBox(GetHWND(),"请选中要删除的组织数据行!","提示",0); + return -1; + } + } + msxml::IXMLDOMElement e = dw_list.GetRowElement(row); + string sguid = e.SelectSingleNode("@guid").text; + string sName = e.selectSingleNode("OrgName").text; + sName += ""; + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("guid", sguid); + if (url::get("OrganizationStruct/child.OrgNums", 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; + } + } + + int MB_YESNO = 0x00000004; + int IDYES = 6; + if (win__::MessageBox(GetHWND(), "确认要删除组织 " + sName + " 的信息吗?", "提示", MB_YESNO) != IDYES) return 1; + arg.AddArg("guid", sguid); + //trace(sguid); + xml__ x1 = new xml__; + x1.setNativePointer(x1.CreateInstance()); + if (url::post("/sale/data/OrganizationStruct/delete.HrOrg", arg.GetString(), x1) != 1) + { + string error = x1.GetXmlDoc().text; + trace(error); + } + else + { + //win32::MessageBox(GetHWND(),"删除成功!","提示",0); + dw_list.DeleteRow(row); + OnDeleteItem(sguid); + } + return 1; + } + + int Productlinemaint() + { + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("id", "产品线"); + openUrl("公共设置.vface/worknode/quickcode/config", arg); + //openUrl("下拉窗口.vface/xpage/hremployee/select", arg); + + return 1; + } + int setTree() + { + string str = "<vbox name='tree' >"; + str += "<xtree name='tv_org' imagelist='0' drag='true'>"; + str += "<treeitem src='xquery:[OrgChart.hr.xq]' src1='xquery:[OrgStructureRetrieve.xq]' xcaption='OrgName' xroot='/root' xpath='Org' xchildpath='Org' image='15' loop='yes' xdata='.'/>"; + str += "</xtree></vbox>"; + string xfNodeAgentArea = "tree"; + xnode__ anode = new xnode__; + anode.setNativePointer(GetAgentNode(xfNodeAgentArea)); + SetAgentNodeContent(anode, str); + tv_org = new treeview__; + tv_org.setNativePointer(this.GetControl("tv_org")); + AttachEvent("tv_org", "TVN_SELCHANGED", OnTreeSelecded); + int root = treeview__::GetRootItem(tv_org.GetId()); + if (root > 0) + { + treeview__::ExpandItemEx(tv_org.GetId(), root); + } + return 1; + } + //命令发布函数 + int OnCmdDispatch(string comdid) + { + if (comdid == "AddRow") { return AddRow(); } + else if (comdid == "ModifyRow") { return ModifyRow(); } + else if (comdid == "DeleteRow") { return DeleteRow(); } + else if (comdid == "OrgType") + { + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("id", "组织类型"); + openUrl("公共设置.vface/worknode/quickcode/config", arg); + //openUrl("组织架构.vface/xpage/HrOrg/type"); + } + else if (comdid == "Refresh") + { + OnRetrieve(); + setTree(); + AttachEvent("tv_org", "TVN_ENDDRAG", OnTreeMoveNode); + } + else if (comdid == "Productlinemaint") + { + Productlinemaint(); + } + 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", OnTreeSelecded); + AttachEvent("tv_org", "TVN_ITEMEXPANDING", OnTreeExpanding); + AttachEvent("tv_org", "TVN_ENDDRAG", OnTreeMoveNode); + //双击 + AttachEvent("dw_list", "DWV_DOUBLECLICKED", OnDoubleClicked); + } + + int OnInitial() + { + SetAgent(); + + OnAttachEvent(); + + return 1; + } + + int onload() + { + tv_org = new treeview__; + tv_org.setNativePointer(this.GetControl("tv_org")); + dw_list = new xdwgrid__; + dw_list.setNativePointer(this.GetControl("dw_list")); + dw_list.openUrl("组织架构.vface/template/HrOrg/list"); + dw_list.SetSelectionMode(1); + dw_list.SetReadOnly(true); + dw_list.SetColumnState("OrgPlat", false); + dw_list.SetColumnState("OrgComLeader", false); + dw_list.SetColumnState("OrgSupLeader", false); + dw_list.SetColumnState("OrgProLine", false); + + + OnInitial(); + + //OnCreateTree("00000000-0000-0000-0000-000000000000", 0); + int root = treeview__::GetRootItem(tv_org.GetId()); + if (root > 0) + { + treeview__::ExpandItemEx(tv_org.GetId(), root); + msxml::IXMLDOMElement ele = treeview__::GetItemData(tv_org.GetId(), root); + if (ele) + { + string ls_orgid = ele.SelectSingleNode("@guid").text; + sOrgID = ls_orgid + ""; + sOrgName = ele.selectSingleNode("OrgName").text; + OnRetrieve(); + } + } + + return 1; + } + ] + + ] +] \ No newline at end of file diff --git a/jrj/project/business/Company/HrOrgChart.cpp b/jrj/project/business/Company/HrOrgChart.cpp new file mode 100644 index 0000000..0522905 --- /dev/null +++ b/jrj/project/business/Company/HrOrgChart.cpp @@ -0,0 +1,142 @@ +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]" + +unit vbusiness.xpage +[ + HrOrgChart is extend win__; + about HrOrgChart + [ + control: + + method: + [ + treeview__ tv_org; + xdwtable__ dw_parent; + int m_bCanDestroy; + + xnode__ m_agentNode; //Agent Condition + string m_agentCond; //Agent Node + + int OnTreeSelChanged(ref TNotifyEvent evt, int p) + { + ref NMTREEVIEW nmtv = evt.pnmh; + int hitem = nmtv.itemNew.hItem; + if (hitem == 0) + hitem = treeview__::GetRootItem(tv_org.GetId()); + string label = treeview__::GetItemLabel(tv_org.GetId(), hitem); + string pUnit; + pUnit = treeview__::GetItemLabel(tv_org.GetId(), hitem) + "\\"; + int pitem = treeview__::GetParentItem(tv_org.GetId(), hitem); + while (pitem > 0) + { + pUnit = treeview__::GetItemLabel(tv_org.GetId(), pitem) + "\\" + pUnit; + pitem = treeview__::GetParentItem(tv_org.GetId(), pitem); + } + msxml::IXMLDOMElement ele = treeview__::GetItemData(tv_org.GetId(), hitem); + string guid = ele.SelectSingleNode("@guid").text; + + //CloseWindow(); + return 1; + } + + int OnActive(ref TEvent evt, int p) + { + /*int WA_INACTIVE = 0; + int WA_ACTIVE = 1; + int WA_CLICKACTIVE = 2; + int lw = evt.wParam & 0xffff; + if( lw ==WA_INACTIVE && m_bCanDestroy==1 ) + { + win__::CloseWindow(); + return 1; + } + if(lw !=WA_INACTIVE)m_bCanDestroy = 1; + return 1;*/ + } + + //焦点激活处理函数 + int OnSetFocus(ref TEvent evt, int p) + { + return 1; + } + + int OnOK(string comdid) + { + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg = win__::GetParam(); + arg.AddArg("comdid", comdid); + int hitem = treeview__::GetSelectedItem(tv_org.GetId()); + if (hitem > 0) + { + msxml::IXMLDOMElement ele = treeview__::GetItemData(tv_org.GetId(), hitem); + string guid = ele.SelectSingleNode("@guid").text; + string label = ele.selectSingleNode("OrgName").text; + arg.AddArg("OrgName", label); + arg.AddArg("OrgId", guid); + win__::CloseWindow(); + } + else + win__::MessageBox(GetHWND(), "请选择组织!", "提示", 0); + return 1; + } + + //命令发布函数 + int OnCmdDispatch(string comdid) + { + int hCursor = xutil__::SetCursorWait(); + if (comdid == "xmOk") + OnOK(comdid); + else if (comdid == "xmCancel") + CloseWindow(); + xutil__::RestoreCursor(hCursor); + 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("WM_ACTIVATE",OnActive); + } + + int OnInitial() + { + OnAttachEvent(); + + return 1; + } + + int onload() + { + m_bCanDestroy = 1; + tv_org = new treeview__; + tv_org.setNativePointer(this.GetControl("tv_org")); + OnInitial(); + + int root = treeview__::GetRootItem(tv_org.GetId()); + treeview__::ExpandItemEx(tv_org.GetId(), root); + + + return 1; + } + ] + + ] +] \ No newline at end of file diff --git a/jrj/project/business/Company/HrOrgMaint.cpp b/jrj/project/business/Company/HrOrgMaint.cpp new file mode 100644 index 0000000..1989e32 --- /dev/null +++ b/jrj/project/business/Company/HrOrgMaint.cpp @@ -0,0 +1,266 @@ +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: + + method: + [ + xdwtable__ dw_detail; + string m_operate; + string m_sguid; + string m_tvOrgID; + string m_tvOrgName; + string m_tvRootOrgID; + string m_tvRootOrgName; + + 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; + } + + 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 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; + } + + 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 OnCmdDispatch(string comdid) + { + if (comdid == "New") OnNew(); + if (comdid == "Save") OnSave(); + if (comdid == "xmOk") OnSave(); + if (comdid == "xmCancel") CloseWindow(); + return 0; + } + + //命令处理事件 + int OnXCommand(ref TXCommandEvent evt, int p) + { + return OnCmdDispatch(evt.pStrID); + } + + 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; + + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + + 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; + } + + int OnAttachEvent() + { + //绑定工具条点击事件 + AttachEvent("WM_XCOMMAND", OnXCommand); + //获取焦点事件,用于重置工具条 + AttachEvent("WM_SETFOCUS", OnSetFocus); + //下拉框 提供内容 + AttachEvent("dw_detail", "DWV_CHILDCONTENT", OnChildContent); + AttachEvent("dw_detail", "DWV_ITEMFOCUSCHANGED", OnClicked); + } + + + int OnInitial() + { + SetAgent(); + OnAttachEvent(); + return 1; + } + + int onload() + { + dw_detail = new xdwtable__; + dw_detail.setNativePointer(this.GetControl("dw_detail")); + dw_detail.openUrl("组织架构.vface/template/HrOrg/detail"); + OnInitial(); + + 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 diff --git a/jrj/project/business/Company/HrOrgType.cpp b/jrj/project/business/Company/HrOrgType.cpp new file mode 100644 index 0000000..59517b6 --- /dev/null +++ b/jrj/project/business/Company/HrOrgType.cpp @@ -0,0 +1,186 @@ +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 +[ + HrOrgType is extend list; + about HrOrgType + [ + control: + + method: + [ + xdwgrid__ dw_list; + + 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; + } + + int OnSave() + { + int hIcon = xutil__::SetCursorWait(); + + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + var xdoc = x.GetXmlDoc(); + dw_list.AcceptText(); + dw_list.DwUpdateAllTo(xdoc);//dw_list.DwUpdateAllTo(xdoc); //dw_list.DwUpdateTo(xdoc); + + string val = xdoc.xml; + xaserverarg__ args = new xaserverarg__; + args.setNativePointer(args.CreateInstance()); + args.AddArg("content", val); + //trace(val); + //return 1; + if (url::post("OrganizationStruct/update.HrOrgType", args.GetString(), x) != 1) + { + string error = x.GetXmlDoc().text; + trace(error); + xutil__::RestoreCursor(hIcon); + return -1; + } + + xutil__::RestoreCursor(hIcon); + win__::MessageBox(GetHWND(), "保存成功!", "提示", 0); + return 1; + } + + int OnRetrieve() + { + int hIcon = xutil__::SetCursorWait(); + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + //arg.AddArg("guid","xxx"); + if (url::post("OrganizationStruct/list.HrOrgType", arg.GetString(), x) != 1) + { + trace(x.GetXmlDoc().text); + return -1; + } + else + { + dw_list.Retrieve(x); + dw_list.Redraw(); + } + xutil__::RestoreCursor(hIcon); + return 1; + } + + int OnAddrow() + { + dw_list.InsertRow(0); + return 1; + } + + int OnInsertrow() + { + int row = dw_list.GetRow(); + if (row < 1) return 0; + dw_list.InsertRow(row); + return 1; + } + + int OnDeleteRow() + { + int row = dw_list.GetRow(); + if (row < 1) return 0; + + msxml::IXMLDOMElement e = dw_list.GetRowElement(row); + string sguid = e.selectSingleNode("Code").text; //e.getAttribute("guid"); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("guid", sguid); + //trace(sguid); + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + if (url::post("OrganizationStruct/delete.HrOrgType", arg.GetString(), x) != 1) + { + string error = x.GetXmlDoc().text; + trace(error); + } + else + { + dw_list.DeleteRow(row); + } + 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(); + + return 0; + } + + //命令处理事件 + int OnXCommand(ref TXCommandEvent evt, int p) + { + return OnCmdDispatch(evt.pStrID); + } + + int OnAttachEvent() + { + //绑定工具条点击事件 + AttachEvent("WM_XCOMMAND", OnXCommand); + //获取焦点事件,用于重置工具条 + AttachEvent("WM_SETFOCUS", OnSetFocus); + } + + int OnInitial() + { + SetAgent(); + OnAttachEvent(); + return 1; + } + + int onload() + { + dw_list = new xdwgrid__; + dw_list.setNativePointer(this.GetControl("dw_list")); + dw_list.openUrl("组织架构.vface/template/HrOrg/orgtype"); + //dw_list.SetSelectionMode(1); + //dw_list.SetReadOnly(true); + + OnInitial(); + OnRetrieve(); + + return 1; + } + ] + + ] +] \ No newline at end of file diff --git a/jrj/project/business/Company/HrPersonAdd.cpp b/jrj/project/business/Company/HrPersonAdd.cpp new file mode 100644 index 0000000..93fa835 --- /dev/null +++ b/jrj/project/business/Company/HrPersonAdd.cpp @@ -0,0 +1,155 @@ +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" +use "dev:code[HrEmployee.vx]" +use "publiccode.vl" + +//unit vclient.vobject tpp +unit vbusiness.xpage +[ + HrPersonAdd is extend frame; + about HrPersonAdd + [ + field: + [ + HrEmployee lw_obj; + xdwgrid__ dw_list; + + xnode__ m_agentNode; //Agent Condition + string m_agentCond; //Agent Node + string m_sTxt; + ] + + 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() + { + control__ xc = new control__; + xc.setNativePointer(this.GetControl("QueryTxt")); + m_sTxt = xc.GetText() + ""; + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("sTxt", m_sTxt); + if (url::post("OrganizationStruct/select.Person", arg.GetString(), x) != 1) + { + trace(x.GetXmlDoc().text); + return -1; + } + else + { + dw_list.Retrieve(x); + dw_list.Redraw(); + dw_list.SetReadOnly(true); + } + return 1; + } + + int OnOK(string comdid) + { + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg = win__::GetParam(); + arg.AddArg("comdid", comdid); + + int row = dw_list.GetNextSelectRow(1); + if (row < 1) + { + alert("请选择人员!"); + return 1; + } + + while (row > 0) + { + msxml::IXMLDOMElement e = dw_list.GetRowElement(row); + string sPersonID = e.selectSingleNode("PersonID").text + ""; + string sPersonName = e.selectSingleNode("Name").text + ""; + arg.AddArg("sPersonID", sPersonID); + arg.AddArg("sPersonName", sPersonName); + row = dw_list.GetNextSelectRow(row + 1); + } + CloseWindow(); + return 1; + } + + //命令发布函数 + int OnCmdDispatch(string comdid) + { + if (comdid == "xmOk") + OnOK(comdid); + else if (comdid == "query") + OnRetrieve(); + else if (comdid == "xmCancel") + CloseWindow(); + return 0; + } + + //命令处理事件 + int OnXCommand(ref TXCommandEvent evt, int param) + { + return OnCmdDispatch(evt.pStrID); + } + + int OnAttachEvent() + { + //绑定工具条点击事件 + AttachEvent("WM_XCOMMAND", OnXCommand); + //获取焦点事件,用于重置工具条 + AttachEvent("WM_SETFOCUS", OnSetFocus); + } + + int OnInitial() + { + SetAgent(); + OnAttachEvent(); + return 1; + } + + int onload() + { + dw_list = new xdwgrid__; + dw_list.setNativePointer(this.GetControl("dw_list")); + dw_list.openUrl("组织架构.vface/template/HrEmployee/PersonSel"); + dw_list.SetSelectionMode(4); //3 + dw_list.SetReadOnly(true); + + OnInitial(); + OnRetrieve(); + + return 1; + } + ] + + ] +] \ No newline at end of file diff --git a/jrj/project/business/Company/HrPersonMaint.cpp b/jrj/project/business/Company/HrPersonMaint.cpp new file mode 100644 index 0000000..b5252a8 --- /dev/null +++ b/jrj/project/business/Company/HrPersonMaint.cpp @@ -0,0 +1,371 @@ +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 "publiccode.vl" + +//unit vclient.vobject tpp +unit vbusiness.xpage +[ + HrPersonMaint is extend frame; + about HrPersonMaint + [ + control: + + method: + [ + xdwtable__ dw_1; + string m_operate; + string m_sguid; + + 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; + } + + 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); + xaserverarg__ args = new xaserverarg__; + args.setNativePointer(args.CreateInstance()); + args.AddArg("content", val); + //trace(m_EntityValueEx); + //trace(val); + xml__ x1 = new xml__; + x1.setNativePointer(x1.CreateInstance()); + if (url::post("OrganizationStruct/update.HrPerson", args.GetString(), x1) != 1) + { + string error = x1.GetXmlDoc().text; + trace(error); + return 1; + } + else + { + trace(x1.GetXml()); + win__::MessageBox(GetHWND(), "保存成功!", "提示", 0); + } + dw_1.ResetUpdateStatus(); + xutil__::RestoreCursor(hIcon); + 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 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) + { + if (comdid == "Save") OnSave(); + else if (comdid == "AddRow") OnAddRow(); + else if (comdid == "InsertRow") OnInsertRow(); + else if (comdid == "DeleteRow") OnDeleteRow(); + else if (comdid == "Close") CloseWindow(); + else if (comdid == "UpdateAssignmentView") + OnUpdateAssignmentView(); + return 0; + } + + 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"); + } + 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 == "Name") + { + string Name = dw_1.GetItemString(1, "Name", 0); + + xml__ xs = new xml__; + xs.setNativePointer(xs.CreateInstance()); + xaserverarg__ args = new xaserverarg__; + args.setNativePointer(args.CreateInstance()); + args.AddArg("Name", Name); + if (url::get("/sale/data/ManpowerFile/GetUserName", args.GetString(), xs) != 1) + { + trace(xs.GetXmlDoc().text); + return -1; + } + else + { + msxml::IXMLDOMNodeList items = xs.GetXmlDoc().selectNodes("data/Item"); + int len = items.length; + if (len != 0) + { + msxml::IXMLDOMNode t = items.item(0); + + string english_name = ""; + string sex = ""; + string sexex = ""; + string birth_date = ""; + string contact = ""; + string induction_time = ""; + string household_register = ""; + string EmailAddress = ""; + if (t.selectSingleNode("english_name")) english_name = t.selectSingleNode("english_name").text; + if (t.selectSingleNode("sex")) sex = t.selectSingleNode("sexex").text; + if (t.selectSingleNode("sexex")) sexex = t.selectSingleNode("sexex").text; + if (t.selectSingleNode("birth_date")) birth_date = t.selectSingleNode("birth_date").text; + if (t.selectSingleNode("contact")) contact = t.selectSingleNode("contact").text; + if (t.selectSingleNode("induction_time")) induction_time = t.selectSingleNode("induction_time").text; + if (t.selectSingleNode("household_register")) household_register = t.selectSingleNode("household_register").text; + if (t.selectSingleNode("EmailAddress")) EmailAddress = t.selectSingleNode("EmailAddress").text; + + dw_1.SetItemString(1, "NickName", english_name); + dw_1.SetItemDisplayString(1, "Gender", sexex); + dw_1.SetItemString(1, "Gender", sex); + dw_1.SetItemString(1, "Birthday", birth_date); + dw_1.SetItemString(1, "Mobile", contact); + dw_1.SetItemString(1, "HireDate", induction_time); + dw_1.SetItemString(1, "BirthPlace", household_register); + dw_1.SetItemString(1, "Email", EmailAddress); + } + } + + } + 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 sJobID = e.SelectSingleNode("@JobID").text; + dw_HrEmployee.SetItemString(row, "OrgID", sOrgID); + dw_HrEmployee.SetItemString(row, "JobID", sJobID); + string sdate = publiccode::GetCurDate() + ""; + dw_HrEmployee.SetItemString(row, "StartDate", sdate + ""); + dw_HrEmployee.SetItemString(row, "EndDate", "2050-12-31"); + } + } + + xutil__::RestoreCursor(HCursor); + + return 0; + } + + //命令处理事件 + int OnXCommand(ref TXCommandEvent evt, int p) + { + return OnCmdDispatch(evt.pStrID); + } + + int OnAttachEvent() + { + //绑定工具条点击事件 + AttachEvent("WM_XCOMMAND", OnXCommand); + //获取焦点事件,用于重置工具条 + AttachEvent("WM_SETFOCUS", OnSetFocus); + //下拉框 提供内容 + AttachEvent("dw_detail", "DWV_CHILDCONTENT", OnChildContent); + //内容改变 + AttachEvent("dw_detail", "DWV_ITEMCHANGED", OnItemChanged); + // + //AttachEvent("dw_detail","DWV_ITEMFOCUSCHANGED",OnItemFocusChanged); + } + + 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.HrPerson", arg.GetString(), x) != 1) + { + trace(x.GetXmlDoc().text); + return -1; + } + else + { + dw_1.Retrieve(x); + dw_1.Redraw(); + //trace(x.GetXml()); + } + + return 1; + } + + int OnInitial() + { + SetAgent(); + + OnAttachEvent(); + + return 1; + } + + int onload() + { + + dw_1 = new xdwtable__; + dw_1.setNativePointer(this.GetControl("dw_detail")); + dw_1.openUrl("组织架构.vface/template/HrPerson/maint"); + OnInitial(); + + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg = this.GetParam(); + if (arg) + { + m_operate = arg.GetArgString("operate"); + m_sguid = arg.GetArgString("guid"); + } + + /*if ( m_sguid == "" || m_sguid == nil) + { + string val; + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + var xdoc = x.GetXmlDoc(); + dw_1.DwUpdateTo(xdoc); + val = xdoc.xml ; + + xml__ xx = new xml__; + xx.setNativePointer(xx.CreateInstance()); + xx.loadXML(val); + msxml::IXMLDOMElement e; + e = xx.GetXmlDoc().selectSingleNode("HrPerson"); + if (e) + { + string sguid = e.getAttribute("guid"); + m_sguid = sguid; + } + //trace(m_sguid); + }*/ + if (m_sguid != "") + OnRetrieve(); + return 1; + } + ] + + ] +] \ No newline at end of file diff --git a/jrj/project/business/Company/HrPersonSel.cpp b/jrj/project/business/Company/HrPersonSel.cpp new file mode 100644 index 0000000..ce87a12 --- /dev/null +++ b/jrj/project/business/Company/HrPersonSel.cpp @@ -0,0 +1,154 @@ +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" +use "dev:code[HrEmployeex.vx]" +use "publiccode.vl" + +//unit vclient.vobject tpp +unit vbusiness.xpage +[ + HrPersonSel is extend frame; + about HrPersonSel + [ + field: + [ + HrEmployeex lw_obj; + xdwgrid__ dw_list; + + xnode__ m_agentNode; //Agent Condition + string m_agentCond; //Agent Node + string m_sTxt; + ] + + 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() + { + control__ xc = new control__; + xc.setNativePointer(this.GetControl("QueryTxt")); + m_sTxt = xc.GetText() + ""; + string query = "[MSSqlHrJob.xq]"; + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("sTxt", m_sTxt); + //if (xaserver__::ExecXQuery(GetServerUrl(),query,arg.GetString(),x)!=1 + if (url::post("OrganizationStruct/select.Employee", arg.GetString(), x) != 1) + { + trace(x.GetXmlDoc().text); + return -1; + } + else + { + dw_list.Retrieve(x); + dw_list.Redraw(); + dw_list.SetReadOnly(true); + } + return 1; + } + + int OnOK() + { + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg = win__::GetParam(); + arg.AddArg("comdid", "xmOk"); + int row = dw_list.GetNextSelectRow(1); + if (row < 1) + { + alert("请选择人员!"); + return 1; + } + msxml::IXMLDOMElement e = dw_list.GetRowElement(row); + trace(e.xml); + string EmployeeID = e.selectSingleNode("EmployeeID").text + ""; + string Name = e.selectSingleNode("Name").text + ""; + arg.AddArg("EmployeeID", EmployeeID); + arg.AddArg("Name", Name); + CloseWindow(); + return 1; + } + + //命令发布函数 + int OnCmdDispatch(string comdid) + { + if (comdid == "xmOk") + OnOK(); + else if (comdid == "query") + { + OnRetrieve(); + } + else if (comdid == "xmCancel") + CloseWindow(); + return 0; + } + + //命令处理事件 + int OnXCommand(ref TXCommandEvent evt, int param) + { + return OnCmdDispatch(evt.pStrID); + } + + int OnAttachEvent() + { + //绑定工具条点击事件 + AttachEvent("WM_XCOMMAND", OnXCommand); + //获取焦点事件,用于重置工具条 + AttachEvent("WM_SETFOCUS", OnSetFocus); + } + + int OnInitial() + { + SetAgent(); + OnAttachEvent(); + return 1; + } + + int onload() + { + dw_list = new xdwgrid__; + dw_list.setNativePointer(this.GetControl("dw_list")); + dw_list.openUrl("组织架构.vface/template/HrEmployee/PersonSel"); + dw_list.SetSelectionMode(3); //3 + dw_list.SetReadOnly(true); + + OnInitial(); + OnRetrieve(); + + return 1; + } + ] + + ] +] \ No newline at end of file diff --git a/jrj/project/business/Company/HrPosition.cpp b/jrj/project/business/Company/HrPosition.cpp new file mode 100644 index 0000000..3acacfb --- /dev/null +++ b/jrj/project/business/Company/HrPosition.cpp @@ -0,0 +1,271 @@ +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 +[ + HrPosition is extend frame; + about HrPosition + [ + field: + [ + treeview__ tv_org; + xdwgrid__ dw_list; + string sOrgID; + string sOrgName; + + 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 ls_orgid) + { + string query = "[MSSqlHrPosition.xq]"; + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("orgID", ls_orgid); + //if (xaserver__::ExecXQuery(GetServerUrl(),query,arg.GetString(),x)!=1) + if (url::post("OrganizationStruct/list.Position", arg.GetString(), x) != 1) + { + trace(x.GetXmlDoc().text); + return -1; + } + else + { + //trace(x.GetXml()); + //dw_list.openUrl("组织架构.vface/template/HrPosition/list"); + dw_list.Retrieve(x); + dw_list.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; + sOrgID = ls_orgid + ""; + sOrgName = ele.selectSingleNode("OrgName").text; + OnRetrieve(ls_orgid); + return 1; + } + + int OnSave() + { + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + dw_list.AcceptText(); + dw_list.DwUpdateAllToEx(x.GetXmlDoc()); + + string xdata = x.GetXml(); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("xdata", xdata); + //trace(x.GetXml()); + //return 1; + + //string xAction="[MSSqlHrPositionUpdate.xa]"; + //if(xaserver__::ExecXAction(GetServerUrl(),xAction,arg.GetString())!=1) + if (url::post("OrganizationStruct/update.Position", arg.GetString(), x) != 1) + { + trace(x.GetXmlDoc().documentElement.text); + alert("保存失败1"); + } + else + { + dw_list.ResetUpdateStatus(); + alert("保存成功"); + } + return 1; + } + + int OnAddRow() + { + int wid = tv_org.GetId(); + int hitem = treeview__::GetSelectedItem(wid); + if (!hitem) + { + alert("请选择组织架构!"); + return 0; + } + //openUrl("组织架构.vface/xpage/Hr/HrPositionAdd", this); + OpenWindow("dev:xpage[HrPositionAdd.vx]", this); + return 1; + } + + int OnInsertRow() + { + int row = dw_list.GetRow(); + dw_list.InsertRow(row); + return 1; + } + + int OnDeleteRow() + { + int row = dw_list.GetRow(); + if (row > 0) + { + string sPositionName = dw_list.GetItemString(row, "PositionName", 0); + int del_flog = win__::MessageBox(0, "确定要删除选中的岗位 " + sPositionName + " 吗?", "提示", 4); + if (del_flog == 7) { return 0; } + //判断HrEmployee里面是否存在该岗位 + //string sPositionID = dw_list.GetItemString(row,"PositionID",0); + msxml::IXMLDOMElement e = dw_list.GetRowElement(row); + string sPositionID = e.selectSingleNode("@guid").text; + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + xaserverarg__ args = new xaserverarg__; + args.setNativePointer(args.CreateInstance()); + args.AddArg("guid", sPositionID); + //if(xaserver__::ExecXQuery(GetServerUrl(),"[HrpositionSel.xq]",args.GetString(),x)!=1) + if (url::post("OrganizationStruct/select.Position", args.GetString(), x) != 1) + { + trace(x.GetXml()); + return 0; + } + var doc = x.GetXmlDoc(); + string cnt = doc.text; + int ll_cnt = cnt.toInt(); + if (ll_cnt == 0) //判断HrEmploee里面是否存在该岗位 + { + args.ClearArgs(); + //xaserverarg__ Args = new xaserverarg__; + //Args.setNativePointer(Args.CreateInstance()); + args.AddArg("guid", sPositionID); + //if(xaserver__::ExecXAction(GetServerUrl(),"[HrPositionDel.xa]",Args.GetString(),x)!=1) + if (url::post("OrganizationStruct/delete.Position", args.GetString(), x) != 1) + { + trace(x.GetXmlDoc().documentElement.text); + alert("删除失败"); + } + else { + dw_list.DeleteRow(row); + alert("删除成功"); + } + } + else + { + alert("其他地方已经使用该岗位,不允许删除!"); + return 0; + } + } + return 1; + } + + int OnChildContent(ref TNotifyEvent evt, int param) { + 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 == "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 OnCmdDispatch(string comdid) + { + if (comdid == "Save") OnSave(); + else if (comdid == "AddRow") OnAddRow(); + else if (comdid == "InsertRow") OnInsertRow(); + else if (comdid == "DeleteRow") OnDeleteRow(); + 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_org", "TVN_SELCHANGED", OnTreeSelChanged); + //AttachEvent("dw_list","DWV_CHILDCONTENT",OnChildContent); + //AttachEvent("dw_list","DWV_ITEMCHANGED",OnItemChanged); + } + + int OnInitial() + { + SetAgent(); + OnAttachEvent(); + return 1; + } + + int onload() + { + tv_org = new treeview__; + tv_org.setNativePointer(this.GetControl("tv_org")); + dw_list = new xdwgrid__; + dw_list.setNativePointer(this.GetControl("dw_list")); + dw_list.openUrl("组织架构.vface/template/HrPosition/list"); + + OnInitial(); + + int wid = tv_org.GetId(); + int root = treeview__::GetRootItem(wid); + treeview__::ExpandItem(wid, root); + //OnRetrieve(); + + return 1; + } + ] + + ] +] \ No newline at end of file diff --git a/jrj/project/business/Company/HrPositionAdd.cpp b/jrj/project/business/Company/HrPositionAdd.cpp new file mode 100644 index 0000000..f5c822c --- /dev/null +++ b/jrj/project/business/Company/HrPositionAdd.cpp @@ -0,0 +1,230 @@ +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" +use "dev:code[HrPosition.vx]" +use "HrPosition.vx" + +//unit vclient.vobject tpp +unit vbusiness.xpage +[ + HrPositionAdd is extend frame; + about HrPositionAdd + [ + field: + [ + HrPosition lw_obj; + xdwgrid__ dw_list; + treeview__ tv_1; + 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.Retrieve(x); + dw_list.Redraw(); + dw_list.SetReadOnly(true); + } + 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 name='all'/>"); + 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 OnOK() + { + if (GetParam()) + { + lw_obj = new HrPosition; + lw_obj.setNativePointer(GetParam()); + lw_obj = GetParam(); + } + else + return 0; + + int row = dw_list.GetNextSelectRow(1); + if (row < 1) + { + alert("请选择工种!"); + return 1; + } + //treeview__ tv_org = new treeview__; + //tv_org.setNativePointer(lw_obj.tv_org); + int wid = lw_obj.tv_org.GetId(); + int hitem = treeview__::GetSelectedItem(wid); + msxml::IXMLDOMElement ele = treeview__::GetItemData(wid, hitem); + string sOrgID = ele.selectSingleNode("@guid").text; + string sOrgName = ele.selectSingleNode("OrgName").text; + while (row > 0) + { + msxml::IXMLDOMElement e = dw_list.GetRowElement(row); + string sJobID = e.selectSingleNode("@guid").text + ""; + string sJobName = e.selectSingleNode("JobName").text + ""; + + int nRow = lw_obj.dw_list.InsertRow(0); + lw_obj.dw_list.SetItemString(nRow, "JobID", sJobID); + lw_obj.dw_list.SetItemDisplayString(nRow, "JobID", sJobName); + lw_obj.dw_list.SetItemString(nRow, "Status", "Y"); + lw_obj.dw_list.SetItemDisplayString(nRow, "Status", "有效"); + lw_obj.dw_list.SetItemString(nRow, "OrgID", sOrgID); + lw_obj.dw_list.SetItemDisplayString(nRow, "OrgID", sOrgName); + lw_obj.dw_list.SetItemString(nRow, "PositionName", sOrgName + sJobName); + row = dw_list.GetNextSelectRow(row + 1); + } + CloseWindow(); + return 1; + } + + //命令发布函数 + int OnCmdDispatch(string comdid) + { + if (comdid == "xmOk") + OnOK(); + else if (comdid == "xmCancel") + CloseWindow(); + 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"); + dw_list.SetSelectionMode(3); //3 + dw_list.SetReadOnly(true); + + 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 diff --git a/jrj/project/business/GDN/AdvanceChargeList.cpp b/jrj/project/business/GDN/AdvanceChargeList.cpp new file mode 100644 index 0000000..d6d6ed0 --- /dev/null +++ b/jrj/project/business/GDN/AdvanceChargeList.cpp Binary files differ diff --git a/jrj/project/business/GDN/CustomCodeNew.cpp b/jrj/project/business/GDN/CustomCodeNew.cpp new file mode 100644 index 0000000..110e378 --- /dev/null +++ b/jrj/project/business/GDN/CustomCodeNew.cpp Binary files differ diff --git a/jrj/project/business/GDN/list.SOTrace3.cpp b/jrj/project/business/GDN/list.SOTrace3.cpp new file mode 100644 index 0000000..3bf447a --- /dev/null +++ b/jrj/project/business/GDN/list.SOTrace3.cpp Binary files differ diff --git a/jrj/project/business/GDN/po.paper.cpp b/jrj/project/business/GDN/po.paper.cpp new file mode 100644 index 0000000..be8b312 --- /dev/null +++ b/jrj/project/business/GDN/po.paper.cpp Binary files differ diff --git a/jrj/project/business/GDN/tracer.so.cpp b/jrj/project/business/GDN/tracer.so.cpp new file mode 100644 index 0000000..8c22d3c --- /dev/null +++ b/jrj/project/business/GDN/tracer.so.cpp Binary files differ diff --git a/jrj/project/business/PO/PO.BatchPrecess.polist.cpp b/jrj/project/business/PO/PO.BatchPrecess.polist.cpp index ec6452d..44c40a7 100644 --- a/jrj/project/business/PO/PO.BatchPrecess.polist.cpp +++ b/jrj/project/business/PO/PO.BatchPrecess.polist.cpp Binary files differ diff --git a/jrj/project/business/PO/business4.cpp b/jrj/project/business/PO/business4.cpp index 19e55b7..0a4b53f 100644 --- a/jrj/project/business/PO/business4.cpp +++ b/jrj/project/business/PO/business4.cpp Binary files differ -- Gitblit v1.9.3