From 1b1a2e68cfd02074fc3300a0cc0fa40888a92f10 Mon Sep 17 00:00:00 2001 From: LiFan <2308045698@qq.com> Date: 星期一, 15 七月 2024 11:57:06 +0800 Subject: [PATCH] update --- jrj/project/business/Company/HrOrgMaint.cpp | 443 +++++++++++++++++++++++++++++++------------------------ 1 files changed, 249 insertions(+), 194 deletions(-) diff --git a/jrj/project/business/Company/HrOrgMaint.cpp b/jrj/project/business/Company/HrOrgMaint.cpp index cb4571d..1989e32 100644 --- a/jrj/project/business/Company/HrOrgMaint.cpp +++ b/jrj/project/business/Company/HrOrgMaint.cpp @@ -1,211 +1,266 @@ -#include <wobject/xstring.hpp> -#include <xcontrol/xtreeview.hpp> -#include <xcontrol/xdwgrid.hpp> +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: -#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp" -#include "viewobject/view.base.hpp" + method: + [ + xdwtable__ dw_detail; + string m_operate; + string m_sguid; + string m_tvOrgID; + string m_tvOrgName; + string m_tvRootOrgID; + string m_tvRootOrgName; -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) + xnode__ m_agentNode; //Agent Condition + string m_agentCond; //Agent Node + int SetAgent() { - xstring s = agent.xml(); - m_agentNode = SetAgentNode(anode, s); + 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; } - } - return 1; - } - int OnRowChanged(TEvent* evt, LPARAM p) - { - DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh; - int row = hdr.row; - SetAgent(); - return 1; - } + //焦点激活处理函数 + int OnSetFocus(ref TEvent evt, int p) + { + SetAgent(); - //焦点激活处理函数 - int OnSetFocus(TEvent* evt, LPARAM param) - { - //重置工具条 - SetAgent(); - return 1; - } + //重置工具条 + 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 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 OnXCommand(TEvent* evt, LPARAM param) - { - return OnCmdDispatch(evt->xcommand.pStrID); - } + 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; + } - xstring GetGuid() - { - return publiccode::GetGuid(); - } + 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 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 OnCmdDispatch(string comdid) + { + if (comdid == "New") OnNew(); + if (comdid == "Save") OnSave(); + if (comdid == "xmOk") OnSave(); + if (comdid == "xmCancel") CloseWindow(); + return 0; + } - 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 OnXCommand(ref TXCommandEvent evt, int p) + { + return OnCmdDispatch(evt.pStrID); + } - 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 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 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); + int OnInitial() + { + SetAgent(); + OnAttachEvent(); + return 1; + } - //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() + { + dw_detail = new xdwtable__; + dw_detail.setNativePointer(this.GetControl("dw_detail")); + dw_detail.openUrl("组织架构.vface/template/HrOrg/detail"); + OnInitial(); - int onload() - { - SetArg(); - dw_list = GetControl(L"dw_list"); - dw_list.openUrl(L"/sale/view/AR/template/Deduction"); + 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; + } + ] - 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; - } - }; + ] +] \ No newline at end of file -- Gitblit v1.9.3