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