From 7a91c3a1ed37b0332d4ff0ebeae60bd6da3665c0 Mon Sep 17 00:00:00 2001
From: xj qian <qianxj15@sina.com>
Date: 星期二, 16 七月 2024 18:28:58 +0800
Subject: [PATCH] Merge branch 'master' of http://116.62.18.175:6699/r/mis-prj

---
 jrj/project/business/BasicCode/FreightExpenseType.cpp |  176 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 176 insertions(+), 0 deletions(-)

diff --git a/jrj/project/business/BasicCode/FreightExpenseType.cpp b/jrj/project/business/BasicCode/FreightExpenseType.cpp
new file mode 100644
index 0000000..b04754c
--- /dev/null
+++ b/jrj/project/business/BasicCode/FreightExpenseType.cpp
@@ -0,0 +1,176 @@
+#include <wobject/xstring.hpp>
+#include <xcontrol/xtreeview.hpp>
+#include <xcontrol/xdwgrid.hpp>
+#include <wobject/xdouble.hpp>
+#include <xcontrol/xlayersheet.hpp>
+#include <xcontrol/xdatetimepick.hpp>
+
+
+#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp"
+#include "viewobject/view.base.hpp"
+
+using xml = KXMLDOMDocument;
+	class __declspec(dllexport) FreightExpenseTypeWin :  public xframe
+	{
+	public:
+		xdwgrid	dw_list;
+		xnode	m_agentNode;	//Agent Condition
+		int	 	seqno;
+	public:
+		FreightExpenseTypeWin(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+	public:
+		static FreightExpenseTypeWin* CreateInstance(void* implPtr, void* hWnd)
+		{
+			FreightExpenseTypeWin* pWin = new FreightExpenseTypeWin(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 CalcSeqNo()
+		{
+			seqno = -1;
+			for(int i=1; i<dw_list.GetRowCount();i++)
+			{
+				xstring val = dw_list.GetItemString(i,L"FieldName");
+				if(val.find(L"OtherFee")==0) continue;
+				if(val.find(L"Other")==0)
+				{
+					xstring no = val.mid(5,99999);
+					if(no.toInt()>seqno) seqno = no.toInt();
+				}
+			}
+			return seqno;
+		}
+				
+		//焦点激活处理函数
+		int OnSetFocus(TEvent* evt, LPARAM param)
+		{
+			//重置工具条
+			SetAgent();
+			return 1;
+		}
+		
+		int OnSave()
+		{
+			dw_list.AcceptText();
+			xml x= new xml;
+			
+			dw_list.DwUpdateAllToEx(x);
+			
+			xaserverarg arg;
+			arg.setNativePointer(xaserverarg::CreateInstance());
+			arg.AddArg(L"content",x.xml());
+			
+			//trace(x.xml());
+			
+			if(xurl::get(L"/sale/data/LogisticsCode/entity/freightexpensetype/update", arg.GetString(),x)!=1)
+			{
+				xstring error = x.text();
+				alert(L"err:"+error);
+				return 1;
+			}
+			//alert(x.xml());
+			xstring str = x.documentElement().getAttribute(L"text");
+			trace(x.xml());
+			if(str == L"true")
+			{
+				dw_list.ResetUpdateStatus();
+				alert(L"保存成功!"); 
+			}else 
+			{
+				alert(L"保存失败!");
+			}
+			return 1;
+		}
+				
+		//命令发布函数
+		int OnCmdDispatch(xstring comdid)
+		{
+			if(comdid==L"xmAddRow")
+			{
+				dw_list.InsertRow(0);
+				if(seqno==-1) CalcSeqNo();
+				seqno++;
+				dw_list.SetItemString(dw_list.GetRowCount(),L"FieldName", L"Other"+xstring(seqno));
+				return 1;
+			}
+			else if(comdid==L"xmDeleteRow")
+			{
+				dw_list.DeleteRow(0);
+				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)&FreightExpenseTypeWin::OnXCommand);
+			//获取焦点事件,用于重置工具条
+			AttachEvent(L"WM_SETFOCUS", (FEvent)&FreightExpenseTypeWin::OnSetFocus);
+			return 1;
+		}
+		
+		int  OnRetrieve()
+		{
+			xml x = new xml;
+			
+			if (getUrl(L"/sale/data/LogisticsCode/entity/freightexpensetype/list",L"",x)!=1)
+			{
+				trace(x.text());
+				return -1;
+			}else	
+			{
+				dw_list.Retrieve(x);
+				dw_list.Redraw();
+			}
+			return 1;
+		}
+		
+		int onload()
+		{
+			dw_list = GetControl(L"dw_list");
+			dw_list.openUrl(L"/sale/view/LogisticsCode/template/freightexpensetype/list");
+			dw_list.SetColumnState(L"ID",false);
+			OnAttachEvent();	
+			seqno = -1;
+			
+			return 1;
+		}
+		
+		int onloaded()
+		{
+			SetAgent();			
+			OnRetrieve();
+			return 1;
+		}		
+	};
\ No newline at end of file

--
Gitblit v1.9.3