From 871adf001724fb4af2552ab4f580939b9bbc2dda Mon Sep 17 00:00:00 2001 From: LiFan <2308045698@qq.com> Date: 星期一, 15 七月 2024 16:34:56 +0800 Subject: [PATCH] update Company --- jrj/project/business/Company/HrEmployeex.cpp | 319 +++++++++++++++++++++++++++-------------------------- 1 files changed, 163 insertions(+), 156 deletions(-) diff --git a/jrj/project/business/Company/HrEmployeex.cpp b/jrj/project/business/Company/HrEmployeex.cpp index 0b1c5ef..38feb04 100644 --- a/jrj/project/business/Company/HrEmployeex.cpp +++ b/jrj/project/business/Company/HrEmployeex.cpp @@ -1,47 +1,54 @@ -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; - ] +#include <wobject/xstring.hpp> +#include <xcontrol/xtreeview.hpp> +#include <xcontrol/xdwgrid.hpp> +#include <wobject/xdouble.hpp> +#include <xcontrol/xlayersheet.hpp> - 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); - } - } +#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp" +#include "viewobject/view.base.hpp" + +using xml = KXMLDOMDocument; + +class __declspec(dllexport) HrEmployeex : public xwin +{ +public: + xtreeview tv_org; + xdwtable dw_1; + xnode m_agentNode; + xstring is_orgid; + xstring is_orgname; + xstring is_inflag; + xdwtable dw_empmaint; +public: + HrEmployeex(void* implPtr, HWND hWnd) :xwin(implPtr, hWnd) {} +public: + static HrEmployeex* CreateInstance(void* implPtr, void* hWnd) + { + HrEmployeex* pWin = new HrEmployeex(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 OnSetFocus(ref TEvent evt, int p) + int OnSetFocus(TEvent* evt, LPARAM param) { SetAgent(); //重置工具条 @@ -50,60 +57,60 @@ int OnSave() { - int hIcon = xutil__::SetCursorWait(); + HCURSOR hIcon = xutil::SetCursorWait(); - string val; - xml__ x = new xml__; - x.setNativePointer(x.CreateInstance()); - var xdoc = x.GetXmlDoc(); + xstring val; + xml x; + + var xdoc = x; 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) + xaserverarg args; + + args.AddArg(L"content", val); + xml x1; + + if (xurl::post(L"OrganizationStruct/update.Employee", args.GetString(), x1) != 1) { - string error = x1.GetXmlDoc().text; + xstring error = x1.text(); trace(error); } else { - win__::MessageBox(GetHWND(), "保存成功!", "提示", 0); + MessageBox(GetHWND(), L"保存成功!", L"提示", 0); } - xutil__::RestoreCursor(hIcon); + xutil::RestoreCursor(hIcon); return 1; } - int OnRetrieve(string ls_orgid) + int OnRetrieve(xstring ls_orgid) { - xml__ x = new xml__; - x.setNativePointer(x.CreateInstance()); - xaserverarg__ arg = new xaserverarg__; - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg("OrgID", ls_orgid); + xml x; + + xaserverarg arg; + + arg.AddArg(L"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) + //if (xaserver::ExecXQuery(GetServerUrl(),L"[MSSqlHrEmployee.xq]",arg.GetString(),x) == 1) + if (xurl::get(L"OrganizationStruct/detail.Employee", arg.GetString(), x) == 1) { - dw_1.openUrl("组织架构.vface/template/HrEmployee/detail"); + dw_1.openUrl(L"组织架构.vface/template/HrEmployee/detail"); dw_1.Retrieve(x); dw_1.Redraw(); } return 1; } - int OnTreeSelChanged(ref TXCommandEvent evt, int p) + int OnTreeSelChanged(TEvent* 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; + //int wid = tv_org.GetId(); + HTREEITEM hitem = tv_org.GetSelectedItem(); + KXMLDOMElement ele = tv_org.GetItemData(hitem); + xstring ls_orgid = ele.selectSingleNode(L"@guid").text(); is_orgid = ls_orgid; //trace(is_orgid); OnRetrieve(ls_orgid); @@ -112,20 +119,20 @@ int OnAddRow() { - xdwtable__ dw = new xdwtable__; + xdwtable dw = new xdwtable; dw.setNativePointer(dw_1.GetCurTable()); - string dw_n = dw.GetDwName(); - if (dw_n == "HrEmployee") + xstring dw_n = dw.GetDwName(); + if (dw_n == L"HrEmployee") dw.InsertRow(0); return 1; } int OnInsertRow() { - xdwtable__ dw = new xdwtable__; + xdwtable dw = new xdwtable; dw.setNativePointer(dw_1.GetCurTable()); - string dw_n = dw.GetDwName(); - if (dw_n == "HrEmployee") + xstring dw_n = dw.GetDwName(); + if (dw_n == L"HrEmployee") { int row = dw.GetRow(); dw.InsertRow(row); @@ -135,10 +142,10 @@ int OnDeleteRow() { - xdwtable__ dw = new xdwtable__; + xdwtable dw = new xdwtable; dw.setNativePointer(dw_1.GetCurTable()); - string dw_n = dw.GetDwName(); - if (dw_n == "HrEmployee") + xstring dw_n = dw.GetDwName(); + if (dw_n == L"HrEmployee") { int row = dw.GetRow(); dw.DeleteRow(row); @@ -146,116 +153,119 @@ 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"); + int OnChildContent(TEvent* evt, LPARAM p) + { + DWNMHDR& dwhdr = *(DWNMHDR*)evt->notify.pnmh; + xstring col = dwhdr.colname; + if (col != L"") { + xml x; + + xaserverarg arg; + + xstring query; + query = L"[IResourceMSSql.xq]"; + if (col == L"PositionID") { + arg.AddArg(L"ResourceType", L"HrPosition"); } - else if (col == "PersonID") { - arg.AddArg("ResourceType", "HrPerson"); + else if (col == L"PersonID") { + arg.AddArg(L"ResourceType", L"HrPerson"); } - else if (col == "OrgID") { - arg.AddArg("ResourceType", "HrOrg"); + else if (col == L"OrgID") { + arg.AddArg(L"ResourceType", L"HrOrg"); } - else if (col == "JobID") { - arg.AddArg("ResourceType", "HrJob"); + else if (col == L"JobID") { + arg.AddArg(L"ResourceType", L"HrJob"); } - if (xaserver__::ExecXQuery(GetServerUrl(), query, arg.GetString(), x) == 1) - dwhdr.data = x.GetXml(); + if (xaserver::ExecXQuery(GetServerUrl(), query, arg.GetString(), x) == 1) + dwhdr.data = x.xml(); //trace(x.GetXml()); } return 1; } - int OnItemChanged(ref TNotifyEvent evt, int p) + int OnItemChanged(TEvent* evt, LPARAM p) { - int HCursor = xutil__::SetCursorWait(); + DWNMHDR& dwhdr = *(DWNMHDR*)evt->notify.pnmh; + HCURSOR 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") + xstring col = dwhdr.colname; + xstring data = dwhdr.data; + trace(xstring(row)); + if (col == L"PositionID") { - xdwtable__ dw_HrEmployee = new xdwtable__; - dw_HrEmployee.setNativePointer(dw_1.FindDwTable("HrEmployee")); - string sPositionID = dw_HrEmployee.GetItemString(row, "PositionID"); + xdwtable dw_HrEmployee = new xdwtable; + dw_HrEmployee.setNativePointer(dw_1.FindDwTable(L"HrEmployee")); + xstring sPositionID = dw_HrEmployee.GetItemString(row, L"PositionID"); - if (sPositionID == "" || sPositionID == nil) + if (sPositionID == L"") 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"); + xml x; + + xaserverarg arg; + + arg.AddArg(L"guid", sPositionID); + arg.AddArg(L"type", L"GetOrgIDJobID"); //trace(arg.GetString()); - if (url::get("OrganizationStruct/GetOrgIDJobID", arg.GetString(), x) != 1) + if (xurl::get(L"OrganizationStruct/GetOrgIDJobID", arg.GetString(), x) != 1) { - trace(x.GetXmlDoc().text); + trace(x.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); + KXMLDOMDocument xdoc = x; + //IXMLDOMNodeList nlist = xdoc.getElementsByTagName(L"OrgID"); + KXMLDOMElement e = xdoc.documentElement(); + xstring sOrgID = e.selectSingleNode(L"@OrgID").text(); + xstring sOrgName = e.selectSingleNode(L"@OrgName").text(); + xstring sJobID = e.selectSingleNode(L"@JobID").text(); + xstring sJobName = e.selectSingleNode(L"@JobName").text(); + dw_HrEmployee.SetItemString(row, L"OrgID", sOrgID); + dw_HrEmployee.SetItemDisplayString(row, L"OrgID", sOrgName); + dw_HrEmployee.SetItemString(row, L"JobID", sJobID); + dw_HrEmployee.SetItemDisplayString(row, L"JobID", sJobName); } } - xutil__::RestoreCursor(HCursor); + xutil::RestoreCursor(HCursor); return 0; } int OnImportData() { - openUrl("组织架构.vface/xpage/Hr/HrPersonSel", this); + openUrl(L"组织架构.vface/xpage/Hr/HrPersonSel", this); return 1; } //命令发布函数 - int OnCmdDispatch(string comdid) + int OnCmdDispatch(xstring 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(); + if (comdid == L"AddRow") return OnAddRow(); + else if (comdid == L"InsertRow") return OnInsertRow(); + else if (comdid == L"DeleteRow") return OnDeleteRow(); + else if (comdid == L"Save") return OnSave(); + else if (comdid == L"ImportData") return OnImportData(); return 0; } //命令处理事件 - int OnXCommand(ref TXCommandEvent evt, int p) + int OnXCommand(TEvent* evt, LPARAM param) { - return OnCmdDispatch(evt.pStrID); + return OnCmdDispatch(evt->xcommand.pStrID); } int OnAttachEvent() { //绑定工具条点击事件 - AttachEvent("WM_XCOMMAND", OnXCommand); + AttachEvent(L"WM_XCOMMAND", (FEvent)&HrEmployeex::OnXCommand); //获取焦点事件,用于重置工具条 - AttachEvent("WM_SETFOCUS", OnSetFocus); + AttachEvent(L"WM_SETFOCUS", (FEvent)&HrEmployeex::OnSetFocus); //获得树的选择事件 - AttachEvent("tv_org", "TVN_SELCHANGED", OnTreeSelChanged); + AttachEvent(L"tv_org", L"TVN_SELCHANGED", (FEvent)&HrEmployeex::OnTreeSelChanged); //下拉框 提供内容 - AttachEvent("dw_1", "DWV_CHILDCONTENT", OnChildContent); - AttachEvent("dw_1", "DWV_ITEMCHANGED", OnItemChanged); + AttachEvent(L"dw_1", L"DWV_CHILDCONTENT", (FEvent)&HrEmployeex::OnChildContent); + AttachEvent(L"dw_1", L"DWV_ITEMCHANGED", (FEvent)&HrEmployeex::OnItemChanged); + return 1; } int OnInitial() @@ -268,19 +278,16 @@ 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"); + tv_org = new treeview; + tv_org.setNativePointer(GetControl(L"tv_org")); + dw_1 = new xdwtable; + dw_1.setNativePointer(GetControl(L"dw_1")); + dw_1.openUrl(L"组织架构.vface/template/HrEmployee/detail"); OnInitial(); - int wid = tv_org.GetId(); - int root = treeview__::GetRootItem(wid); - treeview__::ExpandItem(wid, root); + //int wid = tv_org.GetId(); + HTREEITEM root = tv_org.GetRootItem(); + tv_org.ExpandItem( root); return 1; } - ] - - ] -] \ No newline at end of file +}; \ No newline at end of file -- Gitblit v1.9.3