From 7bc29f841bcba0c303c7a9a631e8334c9f6181d8 Mon Sep 17 00:00:00 2001
From: xj qian <qianxj15@sina.com>
Date: 星期一, 07 四月 2025 17:07:53 +0800
Subject: [PATCH] update

---
 jrj/project/business/Public/ColumnTranView.cpp |  164 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
 jrj/project/business/Expense/Salaryslip.cpp    |    0 
 jrj/ext-jrj/ext-jrj.vcxproj                    |    1 
 jrj/ext-jrj/ext-jrj.vcxproj.filters            |    3 +
 jrj/project/business/Expense/SalaryslipImp.cpp |    0 
 5 files changed, 168 insertions(+), 0 deletions(-)

diff --git a/jrj/ext-jrj/ext-jrj.vcxproj b/jrj/ext-jrj/ext-jrj.vcxproj
index b6a6496..4d12ff3 100644
--- a/jrj/ext-jrj/ext-jrj.vcxproj
+++ b/jrj/ext-jrj/ext-jrj.vcxproj
@@ -867,6 +867,7 @@
     <ClCompile Include="..\project\business\ProductSample\ViewPicturesEx.cpp">
       <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild>
     </ClCompile>
+    <ClCompile Include="..\project\business\Public\ColumnTranView.cpp" />
     <ClCompile Include="..\project\business\Public\GroupManagerList.cpp">
       <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild>
       <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">false</ExcludedFromBuild>
diff --git a/jrj/ext-jrj/ext-jrj.vcxproj.filters b/jrj/ext-jrj/ext-jrj.vcxproj.filters
index 45d3ad8..930edcc 100644
--- a/jrj/ext-jrj/ext-jrj.vcxproj.filters
+++ b/jrj/ext-jrj/ext-jrj.vcxproj.filters
@@ -1622,6 +1622,9 @@
     <ClCompile Include="..\project\business\Expense\SalaryslipImp.cpp">
       <Filter>project\business\Expense</Filter>
     </ClCompile>
+    <ClCompile Include="..\project\business\Public\ColumnTranView.cpp">
+      <Filter>project\business\Public</Filter>
+    </ClCompile>
   </ItemGroup>
   <ItemGroup>
     <None Include="ext-jrj.def">
diff --git a/jrj/project/business/Expense/Salaryslip.cpp b/jrj/project/business/Expense/Salaryslip.cpp
index ce35d3d..1d63416 100644
--- a/jrj/project/business/Expense/Salaryslip.cpp
+++ b/jrj/project/business/Expense/Salaryslip.cpp
Binary files differ
diff --git a/jrj/project/business/Expense/SalaryslipImp.cpp b/jrj/project/business/Expense/SalaryslipImp.cpp
index 0923664..644dd4a 100644
--- a/jrj/project/business/Expense/SalaryslipImp.cpp
+++ b/jrj/project/business/Expense/SalaryslipImp.cpp
Binary files differ
diff --git a/jrj/project/business/Public/ColumnTranView.cpp b/jrj/project/business/Public/ColumnTranView.cpp
new file mode 100644
index 0000000..83d1913
--- /dev/null
+++ b/jrj/project/business/Public/ColumnTranView.cpp
@@ -0,0 +1,164 @@
+#include <wobject/xstring.hpp>
+#include <xcontrol/xtreeview.hpp>
+#include <xcontrol/xdwgrid.hpp>
+
+#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp"
+#include "viewobject/view.base.hpp"
+
+using xml = KXMLDOMDocument;
+	class __declspec(dllexport) ColumnTranView : public xframe
+	{
+	public:
+		xdwgrid	dw_list;
+		xnode	m_agentNode;	//Agent Condition
+		xstring path;
+	public:
+		ColumnTranView(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+	public:
+		static ColumnTranView* CreateInstance(void* implPtr, void* hWnd)
+		{
+			ColumnTranView* pWin = new ColumnTranView(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;
+		}
+
+		//焦点激活处理函数
+		int OnSetFocus(TEvent* evt, LPARAM param)
+		{
+			//重置工具条
+			//SetAgent();
+			return 1;
+		}
+
+
+		//命令发布函数
+		int OnCmdDispatch(xstring comdid)
+		{
+			if (comdid == L"xmAddRow")
+			{
+				dw_list.InsertRow(0);
+				return 1;
+			}
+			else if (comdid == L"xmInsertRow")
+			{
+				dw_list.AcceptText();
+				dw_list.InsertRow(dw_list.GetRow());
+				return 1;
+			}
+			else if (comdid == L"xmDeleteRow")
+			{
+				dw_list.DeleteRow(0);
+			}
+			else if (comdid == L"xmClose")
+			{
+				CloseWindow();
+				return 1;
+			}
+			else if (comdid == L"xmSave")
+			{
+				return OnSave();
+			}
+			return 0;
+		}
+
+		//命令处理事件
+		int OnXCommand(TEvent* evt, LPARAM param)
+		{
+			return OnCmdDispatch(evt->xcommand.pStrID);
+		}
+
+		int OnAttachEvent()
+		{
+			//绑定工具条点击事件
+			AttachEvent(L"WM_XCOMMAND", (FEvent)&ColumnTranView::OnXCommand);
+			//获取焦点事件,用于重置工具条
+			AttachEvent(L"WM_SETFOCUS", (FEvent)&ColumnTranView::OnSetFocus);
+			return 1;
+		}
+
+		int OnSave()
+		{
+			dw_list.AcceptText();
+			xml x;
+			xaserverarg arg;
+			dw_list.DwUpdateAllTo(x);
+			arg.AddArg(L"content", x.xml());
+			arg.AddArg(L"path", path);
+			if (getUrl(L"/sale/data/Thing/content/update", arg.GetString(), x) != 1)
+			{
+				trace(x.text());
+				return -1;
+			}
+			else
+			{
+				alert(x.text());
+			}
+
+			return 1;
+		}
+
+		int  OnRetrieve()
+		{
+			xml x;
+			xaserverarg arg ;
+			arg.AddArg(L"path", path);
+			if (getUrl(L"/sale/data/Thing/content/get", arg.GetString(), x) != 1)
+			{
+				trace(x.text());
+				return -1;
+			}
+			else
+			{
+				dw_list.Retrieve(x);
+				dw_list.Redraw();
+			}
+			return 1;
+		}
+
+		int onload()
+		{
+			xstring path = L"empty";
+			xstring templ = L"/sale/view/Business3/template/transcolumn";
+
+			SetArg();
+			if (GetWinParam())
+			{
+				xaserverarg arg = GetArg();
+				path = arg.GetArgString(L"path");
+				if (arg.GetArgString(L"template") != L"")templ = arg.GetArgString(L"template");
+			}
+			dw_list = GetControl(L"dw_list");
+			dw_list.openUrl(templ);
+
+			OnAttachEvent();
+			OnRetrieve();
+
+			return 1;
+		}
+
+		int onloaded()
+		{
+			//SetAgent();			
+
+			return 1;
+		}
+	};

--
Gitblit v1.9.3