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/Public/UserGroupShareEx.cpp | 164 ++++++++++++++++++++++++++++++++++++++----------------
1 files changed, 114 insertions(+), 50 deletions(-)
diff --git a/jrj/project/business/Public/UserGroupShareEx.cpp b/jrj/project/business/Public/UserGroupShareEx.cpp
index 1898a28..6e253ed 100644
--- a/jrj/project/business/Public/UserGroupShareEx.cpp
+++ b/jrj/project/business/Public/UserGroupShareEx.cpp
@@ -1,90 +1,154 @@
-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) UserGroupShareExWin : public xframe
+ {
+ public:
+ xdwgrid dw_list;
+ xnode m_agentNode; //Agent Condition
+ public:
+ UserGroupShareExWin(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+ public:
+ static UserGroupShareExWin* CreateInstance(void* implPtr, void* hWnd)
+ {
+ UserGroupShareExWin* pWin = new UserGroupShareExWin(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();
return 1;
}
-
- int OnOk()
+ int OnOK()
{
- if(GetParam())
- {
- xaserverarg arg = GetParam();
- arg.AddArg("text",GetControl("sl_search").GetText());
- CloseWindow();
- }
+ xaserverarg arg = GetArg();
+ arg.AddArg(L"process", L"ok");
+
+ xml x;
+ dw_list.DwUpdateAllToEx(x);
+ arg.AddArg(L"result", x.xml());
+
+ CloseWindow();
return 1;
}
-
//命令发布函数
- int OnCmdDispatch(string comdid)
+ int OnCmdDispatch(xstring comdid)
{
- if(comdid=="xmCancel")
+ if (comdid == L"xmCancel")
{
CloseWindow();
return 1;
}
- else if(comdid=="xmOk") return OnOk();
+ if (comdid == L"xmOK") return OnOK();
+ if (comdid == L"xmMemberAdd" || comdid == L"xmAdd")
+ {
+ xaserverarg arg;
+
+ xaserverarg parg = GetArg();
+ if (comdid == L"xmMemberAdd")
+ OpenWindow(L"dev:xpage[UserGroupPersonSelect.vx]",arg);
+ else
+ OpenWindow(L"dev:xpage[UserGroupSelect.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"Name", ele.getAttribute(L"Name"));
+
+ if (comdid == L"xmMemberAdd")
+ {
+ dw_list.SetItemString(row, L"No", ele.getAttribute(L"No"));
+ dw_list.SetItemString(row, L"PersonID", ele.getAttribute(L"PersonID"));
+ }
+ else
+ {
+ xstring no = ele.getAttribute(L"NO");
+ dw_list.SetItemString(row, L"No", L"[" + no + L"]");
+ dw_list.SetItemString(row, L"UserGroupID", ele.getAttribute(L"UserGroupID"));
+ }
+ }
+ dw_list.Redraw();
+ }
+ return 1;
+ }
+ if (comdid == L"xmDelete")
+ {
+ dw_list.DeleteRow(0);
+ return 1;
+ }
return 0;
}
-
+
//命令处理事件
- int OnXCommand(ref TXCommandEvent evt,int param)
+ 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)&UserGroupShareExWin::OnXCommand);
//获取焦点事件,用于重置工具条
- AttachEvent("WM_SETFOCUS",OnSetFocus);
- }
-
- int onload()
- {
- 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是编辑窗口控件
-
- OnAttachEvent();
- if(GetParam())
- {
- xaserverarg arg = GetParam();
- GetControl("sl_search").SetText(arg.GetArgString("text"));
- }
-
+ AttachEvent(L"WM_SETFOCUS", (FEvent)&UserGroupShareExWin::OnSetFocus);
return 1;
}
-
- };
\ No newline at end of file
+
+ int onload()
+ {
+ SetArg();
+ dw_list = GetControl(L"dw_list");
+ dw_list.openUrl(L"/sale/view/UserGroup/template/entityusergrouplist");
+ dw_list.SetReadOnly(true);
+
+ dw_list.SetColumnState(L"UserGroupID", false);
+ dw_list.SetColumnState(L"EntityID", false);
+ dw_list.SetColumnState(L"EntityName", false);
+ dw_list.SetColumnState(L"PersonID", false);
+
+ OnAttachEvent();
+
+ //SetAgent();
+
+ return 1;
+ }
+
+ };
--
Gitblit v1.9.3