From a4d2315ee4ca3f6177b4fb2526bed2feff3d89be Mon Sep 17 00:00:00 2001 From: lifan <2308045698@qq.com> Date: 星期三, 22 十月 2025 16:52:58 +0800 Subject: [PATCH] update --- jrj/project/business/Company/HrOrgType.cpp | 333 ++++++++++++++++++++++++++++--------------------------- 1 files changed, 169 insertions(+), 164 deletions(-) diff --git a/jrj/project/business/Company/HrOrgType.cpp b/jrj/project/business/Company/HrOrgType.cpp index 59517b6..60551d9 100644 --- a/jrj/project/business/Company/HrOrgType.cpp +++ b/jrj/project/business/Company/HrOrgType.cpp @@ -1,186 +1,191 @@ -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: +#include <wobject/xstring.hpp> +#include <xcontrol/xtreeview.hpp> +#include <xcontrol/xdwgrid.hpp> +#include <wobject/xdouble.hpp> +#include <xcontrol/xlayersheet.hpp> - method: - [ - xdwgrid__ dw_list; +#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp" +#include "viewobject/view.base.hpp" - 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; - } +using xml = KXMLDOMDocument; +class __declspec(dllexport) HrOrgType : public xwin +{ +public: + xdwgrid dw_list; - //焦点激活处理函数 - int OnSetFocus(ref TEvent evt, int p) - { - SetAgent(); + 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) + { + HrOrgType* pWin = new HrOrgType(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; + } - //重置工具条 - return 1; - } + //焦点激活处理函数 + int OnSetFocus(TEvent* evt, LPARAM param) + { + SetAgent(); - int OnSave() - { - int hIcon = xutil__::SetCursorWait(); + //重置工具条 + return 1; + } - 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); + int OnSave() + { + HCURSOR hIcon = xutil::SetCursorWait(); - 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; - } + xml x; - xutil__::RestoreCursor(hIcon); - win__::MessageBox(GetHWND(), "保存成功!", "提示", 0); - return 1; - } + auto xdoc = x; + dw_list.AcceptText(); + dw_list.DwUpdateAllTo(xdoc);//dw_list.DwUpdateAllTo(xdoc); //dw_list.DwUpdateTo(xdoc); - 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; - } + xstring val = xdoc.xml(); + xaserverarg args; + 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 OnAddrow() - { - dw_list.InsertRow(0); - return 1; - } + xutil::RestoreCursor(hIcon); + MessageBox(GetHWND(), L"保存成功!", L"提示", 0); + return 1; + } - int OnInsertrow() - { - int row = dw_list.GetRow(); - if (row < 1) return 0; - dw_list.InsertRow(row); - return 1; - } + int OnRetrieve() + { + HCURSOR hIcon = xutil::SetCursorWait(); + xml x; - int OnDeleteRow() - { - int row = dw_list.GetRow(); - if (row < 1) return 0; + xaserverarg arg; - 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; - } + //arg.AddArg(L"guid",L"xxx"); + if (xurl::post(L"OrganizationStruct/list.HrOrgType", arg.GetString(), x) != 1) + { + trace(x.text()); + return -1; + } + else + { + dw_list.Retrieve(x); + dw_list.Redraw(); + } + xutil::RestoreCursor(hIcon); + 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(); + int OnAddrow() + { + dw_list.InsertRow(0); + return 1; + } - return 0; - } + int OnInsertrow() + { + int row = dw_list.GetRow(); + if (row < 1) return 0; + dw_list.InsertRow(row); + return 1; + } - //命令处理事件 - int OnXCommand(ref TXCommandEvent evt, int p) - { - return OnCmdDispatch(evt.pStrID); - } + int OnDeleteRow() + { + int row = dw_list.GetRow(); + if (row < 1) return 0; - int OnAttachEvent() - { - //绑定工具条点击事件 - AttachEvent("WM_XCOMMAND", OnXCommand); - //获取焦点事件,用于重置工具条 - AttachEvent("WM_SETFOCUS", OnSetFocus); - } + KXMLDOMElement e = dw_list.GetRowElement(row); + xstring sguid = e.selectSingleNode(L"Code").text(); //e.getAttribute(L"guid"); + xaserverarg arg; - int OnInitial() - { - SetAgent(); - OnAttachEvent(); - return 1; - } + arg.AddArg(L"guid", sguid); + //trace(sguid); + xml x; - 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); + if (xurl::post(L"OrganizationStruct/delete.HrOrgType", arg.GetString(), x) != 1) + { + xstring error = x.text(); + trace(error); + } + else + { + dw_list.DeleteRow(row); + } + return 1; + } - OnInitial(); - OnRetrieve(); + //命令发布函数 + 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(); - return 1; - } - ] + return 0; + } - ] -] \ No newline at end of file + //命令处理事件 + int OnXCommand(TEvent* evt, LPARAM param) + { + return OnCmdDispatch(evt->xcommand.pStrID); + } + + int OnAttachEvent() + { + //绑定工具条点击事件 + AttachEvent(L"WM_XCOMMAND", (FEvent)&HrOrgType::OnXCommand); + //获取焦点事件,用于重置工具条 + AttachEvent(L"WM_SETFOCUS", (FEvent)&HrOrgType::OnSetFocus); + return 1; + } + + int OnInitial() + { + SetAgent(); + OnAttachEvent(); + 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