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/HrEmployeex.cpp | 286 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 286 insertions(+), 0 deletions(-)
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
--
Gitblit v1.9.3