From f7c01240b27f0ad97feb9115b238d7a44b4b56b2 Mon Sep 17 00:00:00 2001 From: LiFan <2308045698@qq.com> Date: 星期三, 17 七月 2024 17:06:12 +0800 Subject: [PATCH] update --- jrj/project/business/Company/HrOrgType.cpp | 333 ++++++++++++++++++++++++++----------------------------- 1 files changed, 157 insertions(+), 176 deletions(-) diff --git a/jrj/project/business/Company/HrOrgType.cpp b/jrj/project/business/Company/HrOrgType.cpp index cb4571d..5179465 100644 --- a/jrj/project/business/Company/HrOrgType.cpp +++ b/jrj/project/business/Company/HrOrgType.cpp @@ -1,211 +1,192 @@ #include <wobject/xstring.hpp> #include <xcontrol/xtreeview.hpp> #include <xcontrol/xdwgrid.hpp> +#include <wobject/xdouble.hpp> +#include <xcontrol/xlayersheet.hpp> #include "vbusiness/vframe/listwin.vframe.vbusiness.hpp" #include "viewobject/view.base.hpp" using xml = KXMLDOMDocument; - class __declspec(dllexport) Deduction : public xframe +class __declspec(dllexport) HrOrgType : public xwin +{ +public: + xdwgrid dw_list; + + xnode m_agentNode; //Agent Condition + xstring m_agentCond; //Agent Node +public: + HrOrgType(void* implPtr, HWND hWnd) :xwin(implPtr, hWnd) {} +public: + static HrOrgType* CreateInstance(void* implPtr, void* hWnd) { - 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) + HrOrgType* pWin = new HrOrgType(implPtr, (HWND)hWnd); + return pWin; + } + int SetAgent() + { + xstring xfNodeAgentArea = L"agentarea"; + xnode anode = GetAgentNode(xfNodeAgentArea); + if (m_agentNode) { - Deduction* pWin = new Deduction(implPtr, (HWND)hWnd); - return pWin; + SetAgentNode(anode, m_agentNode); } - int SetAgent() + else { - xstring xfNodeAgentArea = L"agentarea"; - xnode anode = GetAgentNode(xfNodeAgentArea); - if (m_agentNode) + KXMLDOMElement xframeElement = GetElement(); + KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*"); + if (agent) { - SetAgentNode(anode, m_agentNode); + xstring s = agent.xml(); + m_agentNode = SetAgentNode(anode, s); } - 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; + } + return 1; + } + + //焦点激活处理函数 + int OnSetFocus(TEvent* evt, LPARAM param) + { + SetAgent(); + + //重置工具条 + return 1; + } + + int OnSave() + { + HCURSOR hIcon = xutil::SetCursorWait(); + + xml x; + + auto xdoc = x; + dw_list.AcceptText(); + dw_list.DwUpdateAllTo(xdoc);//dw_list.DwUpdateAllTo(xdoc); //dw_list.DwUpdateTo(xdoc); + + xstring val = xdoc.xml(); + xaserverarg args; + args.setNativePointer(args.CreateInstance()); + args.AddArg(L"content", val); + //trace(val); + //return 1; + if (xurl::post(L"OrganizationStruct/update.HrOrgType", args.GetString(), x) != 1) + { + xstring error = x.text(); + trace(error); + xutil::RestoreCursor(hIcon); + return -1; } - int OnRowChanged(TEvent* evt, LPARAM p) - { - DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh; - int row = hdr.row; - SetAgent(); - return 1; - } + xutil::RestoreCursor(hIcon); + MessageBox(GetHWND(), L"保存成功!", L"提示", 0); + return 1; + } - //焦点激活处理函数 - int OnSetFocus(TEvent* evt, LPARAM param) - { - //重置工具条 - SetAgent(); - return 1; - } + int OnRetrieve() + { + HCURSOR hIcon = xutil::SetCursorWait(); + xml x; - //命令发布函数 - 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; - } + xaserverarg arg; - //命令处理事件 - int OnXCommand(TEvent* evt, LPARAM param) + //arg.AddArg(L"guid",L"xxx"); + if (xurl::post(L"OrganizationStruct/list.HrOrgType", arg.GetString(), x) != 1) { - return OnCmdDispatch(evt->xcommand.pStrID); + trace(x.text()); + return -1; } - - xstring GetGuid() + else { - 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.Retrieve(x); dw_list.Redraw(); - return 1; } + xutil::RestoreCursor(hIcon); + return 1; + } - int OnAttachEvent() + 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; + + KXMLDOMElement e = dw_list.GetRowElement(row); + xstring sguid = e.selectSingleNode(L"Code").text(); //e.getAttribute(L"guid"); + xaserverarg arg; + + arg.AddArg(L"guid", sguid); + //trace(sguid); + xml x; + + if (xurl::post(L"OrganizationStruct/delete.HrOrgType", arg.GetString(), x) != 1) { - //绑定工具条点击事件 - 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; + xstring error = x.text(); + trace(error); } - - - int OnRetrieve(xstring InvoiceNo, xstring EntityID) + else { - 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; + dw_list.DeleteRow(row); } + return 1; + } - int onload() - { - SetArg(); - dw_list = GetControl(L"dw_list"); - dw_list.openUrl(L"/sale/view/AR/template/Deduction"); + //命令发布函数 + int OnCmdDispatch(xstring comdid) + { + if (comdid == L"save") OnSave(); + else if (comdid == L"addrow") OnAddrow(); + else if (comdid == L"insertrow") OnInsertrow(); + else if (comdid == L"deleterow") OnDeleteRow(); - dw_list.SetColumnState(L"ID", false); - dw_list.SetColumnState(L"GDNLineID", false); - dw_list.SetColumnState(L"SettlementAdjustID", false); + return 0; + } + //命令处理事件 + int OnXCommand(TEvent* evt, LPARAM param) + { + return OnCmdDispatch(evt->xcommand.pStrID); + } - if (GetWinParam()) - { - xaserverarg arg = GetArg(); - EntityID = arg.GetArgString(L"EntityID"); - InvoiceNo = arg.GetArgString(L"InvoiceNo"); - } - trace(InvoiceNo); - OnRetrieve(InvoiceNo, EntityID); - OnAttachEvent(); - return 1; - } + int OnAttachEvent() + { + //绑定工具条点击事件 + AttachEvent(L"WM_XCOMMAND", (FEvent)&HrOrgType::OnXCommand); + //获取焦点事件,用于重置工具条 + AttachEvent(L"WM_SETFOCUS", (FEvent)&HrOrgType::OnSetFocus); + return 1; + } - int onloaded() - { - SetAgent(); + int OnInitial() + { + SetAgent(); + OnAttachEvent(); + return 1; + } - return 1; - } - }; + int onload() + { + dw_list = new xdwgrid; + dw_list.setNativePointer(GetControl(L"dw_list")); + dw_list.openUrl(L"组织架构.vface/template/HrOrg/orgtype"); + //dw_list.SetSelectionMode(1); + //dw_list.SetReadOnly(true); + + OnInitial(); + OnRetrieve(); + + return 1; + } +}; \ No newline at end of file -- Gitblit v1.9.3