From 549b3fa73926b4c35043545921dba68d011c6f92 Mon Sep 17 00:00:00 2001 From: LiFan <2308045698@qq.com> Date: 星期五, 05 七月 2024 14:48:43 +0800 Subject: [PATCH] update --- jrj/project/business/Public/GroupManagerList.cpp | 249 ++++++++++++++++++++++++++++++++++++++++--------- 1 files changed, 204 insertions(+), 45 deletions(-) diff --git a/jrj/project/business/Public/GroupManagerList.cpp b/jrj/project/business/Public/GroupManagerList.cpp index 1898a28..bb5c66c 100644 --- a/jrj/project/business/Public/GroupManagerList.cpp +++ b/jrj/project/business/Public/GroupManagerList.cpp @@ -1,90 +1,249 @@ -class SearchDlg : public xframe - { - xnode m_agentNode; //Agent Condition +#include <wobject/xstring.hpp> +#include <xcontrol/xtreeview.hpp> +#include <xcontrol/xdwgrid.hpp> - xcontrol sle_1; - +#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp" +#include "viewobject/view.base.hpp" + +using xml = KXMLDOMDocument; + class __declspec(dllexport) GroupManagerList : public xframe + { + public: + xdwgrid dw_list; + xnode m_agentNode; //Agent Condition + xtreeview tv_folder; + public: + GroupManagerList(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {} + public: + static GroupManagerList* CreateInstance(void* implPtr, void* hWnd) + { + GroupManagerList* pWin = new GroupManagerList(implPtr, (HWND)hWnd); + return pWin; + } int SetAgent() { - string xfNodeAgentArea = "agentarea"; + xstring xfNodeAgentArea = L"agentarea"; xnode anode = GetAgentNode(xfNodeAgentArea); - if(m_agentNode) + if (m_agentNode) { - SetAgentNodeContent (anode,m_agentNode); + SetAgentNode(anode, m_agentNode); } else { - msxml::IXMLDOMElement xframeElement = GetElement(); - msxml::IXMLDOMElement agent = xframeElement.selectSingleNode("agent/"+xfNodeAgentArea+"[1]/*"); - if(agent) + KXMLDOMElement xframeElement = GetElement(); + KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*"); + if (agent) { - string s = agent.xml; - m_agentNode = SetAgentNodeContent (anode,s); + xstring s = agent.xml(); + m_agentNode = SetAgentNode(anode, s); } } return 1; } //焦点激活处理函数 - int OnSetFocus(ref TEvent evt,int param) + int OnSetFocus(TEvent* evt, LPARAM param) { //重置工具条 - //SetAgent(); + SetAgent(); return 1; } - - int OnOk() + + int createSubTree(int wid, HTREEITEM h, KXMLDOMElement ele) { - if(GetParam()) + + KXMLDOMNodeList nlist = ele.selectNodes(L"item"); + int i; + int s = nlist.length(); + if (s > 0) + for (i = 0; i < s; i++) + { + KXMLDOMElement e = nlist.item(i); + xstring name = e.selectSingleNode(L"@name").text(); + HTREEITEM hw = xtreeview::InsertChildItem(wid, h, name,e , 15); + createSubTree(wid, hw, e); + } + return 1; + } + + int OnCreateTree() + { + int wid = tv_folder.GetId(); + while (xtreeview::GetRootItem(wid) > 0) + xtreeview::DeleteItem(wid, xtreeview::GetRootItem(wid)); + + xml x; + x; + + xaserverarg arg; + + if (xurl::get(L"/sale/data/UserGroup/tree", L"", x) != 1) { - xaserverarg arg = GetParam(); - arg.AddArg("text",GetControl("sl_search").GetText()); - CloseWindow(); + alert(x.text()); + return -1; } + + KXMLDOMNodeList nlist = x.selectNodes(L"root/item"); + int len = nlist.length(); + if (len > 0) + { + int i; + for (i = 0; i < len; i++) + { + KXMLDOMElement e = nlist.item(i); + xstring name = e.selectSingleNode(L"@name").text(); + int h = xtreeview::InsertChildItem(wid, 0, name, trust(e as int), 15); + createSubTree(wid, h, e); + xtreeview::ExpandItem(wid, h); + } + xtreeview::ExpandItem(wid, 0); + } + + return 1; + } + + //树选择 + int OnTreeSelChanged(TEvent* evt, LPARAM p) + { + + NMTREEVIEW& nmtv = *(NMTREEVIEW*)evt->notify.pnmh; + HTREEITEM hItem = nmtv.itemNew.hItem; + + KXMLDOMElement e = xtreeview::GetItemData(tv_folder.GetId(), sItem); + xstring UserGroupID = e.selectSingleNode(L"@guid").text(); + OnRetrieve(UserGroupID); return 1; } //命令发布函数 - int OnCmdDispatch(string comdid) + int OnCmdDispatch(xstring comdid) { - if(comdid=="xmCancel") + if (comdid == L"xmAdd") { - CloseWindow(); + OpenWindow(L"dev:xpage[UserGroupMaint.vx]", 0); return 1; } - else if(comdid=="xmOk") return OnOk(); + if (comdid == L"xmSave") + { + return OnSave(); + } + if (comdid == L"xmMemberAdd") + { + HTREEITEM hItem = tv_folder.GetSelectedItem(); + if (hItem < 0) return 1; + KXMLDOMElement e = tv_folder.GetItemData(hItem); + + xaserverarg arg; + + + OpenWindow(L"dev:xpage[UserGroupPersonSelect.vx]", arg); + if (arg.GetArgString(L"comdid") == L"xmOk") + { + + xstring data = arg.GetArgString(L"data"); + xml x; + + x.loadXML(data); + KXMLDOMNodeList nodes = x.selectNodes(L"/root/item"); + int len = nodes.length(); + for (int i = 0; i < len; i++) + { + dw_list.InsertRow(0); + int row = dw_list.GetRowCount(); + KXMLDOMElement ele = nodes.item(i); + dw_list.SetItemString(row, L"No", ele.getAttribute(L"No")); + dw_list.SetItemString(row, L"Name", ele.getAttribute(L"Name")); + dw_list.SetItemString(row, L"PersonID", ele.getAttribute(L"PersonID")); + dw_list.SetItemString(row, L"UserGroupID", e.getAttribute(L"guid")); + } + dw_list.Redraw(); + } + return 1; + } return 0; } - - //命令处理事件 - int OnXCommand(ref TXCommandEvent evt,int param) + + int OnSave() { - return OnCmdDispatch(evt.pStrID); + xml x; + + dw_list.DwUpdateAllToEx(x); + xaserverarg arg; + + arg.AddArg(L"content", x.xml()); + + if (xurl::get(L"/sale/data/UserGroup/update", arg.GetString(), x) != 1) + { + xstring error = x.text(); + alert(L"err:" + error); + return 1; + } + else + { + alert(x.xml()); + dw_list.ResetUpdateStatus(); + } + + return 1; } - + + //命令处理事件 + int OnXCommand(TEvent* evt, LPARAM param) + { + return OnCmdDispatch(evt->xcommand.pStrID); + } + int OnAttachEvent() { //绑定工具条点击事件 - AttachEvent("WM_XCOMMAND",OnXCommand); + AttachEvent(L"WM_XCOMMAND", (FEvent)&GroupManagerList::OnXCommand); //获取焦点事件,用于重置工具条 - AttachEvent("WM_SETFOCUS",OnSetFocus); + AttachEvent(L"WM_SETFOCUS", (FEvent)&GroupManagerList::OnSetFocus); + AttachEvent(L"tv_folder", L"TVN_SELCHANGED", (FEvent)&GroupManagerList::OnTreeSelChanged); //树选择 } - - int onload() + + + int OnRetrieve(xstring UserGroupID) { - sle_1 = GetControl("sl_search"); - int x = win32::GetWindowLong(sle_1.GetId(), -16); //GWL_STYLE - x = x+ 0x0008; - win32::SetWindowLong(sle_1.GetId(), -16,x);//sle_1是编辑窗口控件 + dw_list.Reset(); + xml x; - OnAttachEvent(); - if(GetParam()) + xaserverarg arg; + + arg.AddArg(L"UserGroupID", UserGroupID); + if (getUrl(L"/sale/data/UserGroup/member", arg.GetString(), x) != 1) { - xaserverarg arg = GetParam(); - GetControl("sl_search").SetText(arg.GetArgString("text")); + trace(x.text()); + return -1; } - + else + { + dw_list.Retrieve(x); + dw_list.SetReadOnly(true); + dw_list.Redraw(); + } return 1; } - - }; \ No newline at end of file + + int onload() + { + dw_list = GetControl(L"dw_list"); + dw_list.openUrl(L"/sale/view/UserGroup/template/member"); + tv_folder = GetControl(L"tv_folder"); + dw_list.SetReadOnly(true); + dw_list.SetColumnState(L"UserGroupID", false); + dw_list.SetColumnState(L"PersonID", false); + + OnCreateTree(); + OnAttachEvent(); + + return 1; + } + + int onloaded() + { + SetAgent(); + + return 1; + } + }; -- Gitblit v1.9.3