From 858d5b84cb2f9311d6e00d90c6f9527e2e6f57b4 Mon Sep 17 00:00:00 2001
From: lifan <2308045698@qq.com>
Date: 星期四, 04 九月 2025 17:50:13 +0800
Subject: [PATCH] update

---
 jrj/project/printview/Template.Print.Dialog.cpp | 1102 +++++++++++++++++++++++++++------------------------------
 1 files changed, 525 insertions(+), 577 deletions(-)

diff --git a/jrj/project/printview/Template.Print.Dialog.cpp b/jrj/project/printview/Template.Print.Dialog.cpp
index a243a8b..6d5f4ee 100644
--- a/jrj/project/printview/Template.Print.Dialog.cpp
+++ b/jrj/project/printview/Template.Print.Dialog.cpp
@@ -1,595 +1,543 @@
-class TemplatePrintDialog : public responsewin
+#include <wobject/xstring.hpp>
+#include <xcontrol/xtreeview.hpp>
+#include <xcontrol/xdwgrid.hpp>
+#include <xcontrol/xlayersheet.hpp>
+
+#include "vbusiness/vframe/maint.vframe.vbusiness.hpp"
+#include "vbusiness/vframe/responsewin.vframe.vbusiness.hpp"
+#include "viewobject/view.base.hpp"
+
+using xml = KXMLDOMDocument;
+
+DeclWinObject_(TemplatePrintDialog, responsewin)
 {
-		xaserverarg arg_param;
-		string m_EntityName;
-		string m_EntityID;
-		string m_EntityNo;
-		string m_Dir;
-		string m_filePath;
-		string strNode;
-		xdwgrid  dw_list;
-		xdwgrid  dw_doclist;
-		xole ole_1;
-		bool bupdate;
+	CreateWinObject_(TemplatePrintDialog, responsewin)
 
-		int OnHtml()
-		{
-			string s1="<catalog>"+
-			 "   <book id='bk101'>"+
-			 "     <author>Gambardella, Matthew</author>"+
-			 "     <title>XML Developer's Guide</title>"+
-			 "     <genre>Computer</genre>"+
-			 "     <price>44.95</price>"+
-			 "     <publish_date>2000-10-01</publish_date>"+
-			 "     <description>An in-depth look at creating applications "+
-			 "     with XML.</description>"+
-			 "  </book>"+
-			 "  <book id='bk102'>"+
-			 "     <author>Ralls, Kim</author>"+
-			 "     <title>Midnight Rain</title>"+
-			 "     <genre>Fantasy</genre>"+
-			 "     <price>5.95</price>"+
-			 "     <publish_date>2000-12-16</publish_date>"+
-			 "     <description>A former architect battles corporate zombies, "+
-			 "     an evil sorceress, and her own childhood to become queen "+
-			 "     of the world.</description>"+
-			 "  </book>"+
-			 "  </catalog>";
-			xml x = new xml;
-			x.setNativePointer(xml::CreateInstance());
-			x.LoadXml(s1);
-//trace(x.GetXml());
+public:
+	xaserverarg arg_param;
+	xstring m_EntityName;
+	xstring m_EntityID;
+	xstring m_EntityNo;
+	xstring m_Dir;
+	xstring m_filePath;
+	xstring strNode;
+	xdwgrid	dw_list;
+	xdwgrid	dw_doclist;
+	bool bupdate;
 
-			//string s2="<?xml version='1.0'?>"+
-			string s2=
-			"<xsl:stylesheet version='1.0'"+
-			"                xmlns:xsl='http://www.w3.org/1999/XSL/Transform' >"+
-			"<xsl:output method='xml' indent='yes'/>"+
-			"<xsl:template match='catalog'>"+
-			"<HTML>"+
-			" <HEAD>"+
-			"   <TITLE>Books catalog - listing for Books.xml</TITLE>"+
-			" </HEAD>"+
-			" <BODY><FONT FACE='Verdana'>"+
-			" <H3>My Books Catalog</H3>"+
-			" <TABLE CELLPADDING='5' CELLSPACING='2'>"+
-			"   <xsl:for-each select='book'>"+
-			"   <TR>"+
-			"      <TD ALIGN='LEFT'><FONT SIZE='2'><B>ID:</B>&#160;&#160;<xsl:value-of select='@id'/><BR/>"+
-			"      <B>Author:</B>&#160;&#160;<xsl:value-of select='author'/><BR/>"+
-			"      <B>Title:</B>&#160;&#160;<xsl:value-of select='title'/><BR/>"+
-			"      <B>Genre:</B>&#160;&#160;<xsl:value-of select='genre'/><BR/>"+
-			"      <B>Price:</B>&#160;&#160;<xsl:value-of select='price'/><BR/>"+
-			"      <B>Published on:</B>&#160;&#160;<xsl:value-of select='publish_date'/><BR/>"+
-			"      <B>Description:</B>&#160;&#160;<xsl:value-of select='description'/></FONT></TD>"+
-			"   </TR>"+
-			"   </xsl:for-each>"+
-			"</TABLE>"+
-			"</FONT>"+
-			"</BODY>"+
-			"</HTML>"+
-			"</xsl:template>"+
-			"</xsl:stylesheet>" ;
-			xml xsl = new xml;
-			xsl.setNativePointer(xml::CreateInstance());
-			xsl.LoadXml(s2);
-//trace(xsl.GetXml());
-
-			string strHtml = x.GetXmlDoc().transformNode(xsl.GetXmlDoc());
-			//strHtml = str.mid(21,99999);
-			ole_1.LoadHtml(strHtml);
-			//html_1.SetContent(strHtml);
-			//alert(strHtml);
-
-			return 0;
-		}
-		
-		int OnRetrieve()
-		{
-			string username = publiccode::GetUser().name;
-			if(username != "admin" && m_Dir != username )
-			{
-				bupdate = false;
-			}else
-			{
-				bupdate = true;
-			}
-			xml x = new xml;
-			x.setNativePointer(xml::CreateInstance());
-			xaserverarg arg = new xaserverarg;
-			arg.setNativePointer(arg.CreateInstance());	
-			arg.AddArg("Entity",m_EntityName);			
-			arg.AddArg("Dir",m_Dir);
-			dw_list.Reset();
-			if (url::get("/sale/data/SysPrintTemplate/listDialog",arg.GetString(),x) != 1)
-			{
-				trace(x.GetXmlDoc().text);
-				return -1;
-			}else	
-			{
-				string s = x.GetXml();
-				dw_list.Retrieve(x);
-			}
-			dw_list.Redraw();
-			//dw_list.SetReadOnly(true);
-			if (dw_list.GetRowCount()>0)
-				dw_list.SelectRow(1,true);
-			return 1;
-		}
-		
-		int OnNewTempl()
-		{
-			OpenWindow("dev:xpage[Maint.Template.Print.vx]");
-			return 1;
-		}
-				
-		int OnMaintTempl()
-		{
-			int row =  dw_list.GetRow();
-			if(row<0 || row>dw_list.GetRowCount()) 
-			{
-				alert("请选择要维护的模板!");
-				return 1;
-			}
-			else
-			{
-				msxml::IXMLDOMElement ele = dw_list.GetRowElement(row);	
-				string sguid = ele.selectSingleNode("ID").text;
-				string sTemplName = ele.selectSingleNode("TemplName").text;
-				//string sFile = m_filePath + sguid+".xsl";	
-				string sFile = m_filePath + ele.selectSingleNode("urlPath").text;
-				arg_param.AddArg("xsl",sFile); 
-				arg_param.AddArg("return","cancel");
-				
-				OpenWindow("dev:xpage[Maint.Template.Print.vx]",cast(arg_param.GetString() as int));
-				CloseWindow();
-			
-			}			
-			return 1;
-		}
-				
-		int OnAddDir()
-		{
-			return 0;
-		}
-		int OnAddTempl()
-		{
-			if (m_Dir=="")
-			{
-				alert("请选择模板目录!");
-				return 0;
-			}
-			string sguid = publiccode::GetGuid();
-			string sname= sguid +".xsl";
-			string suri= "rpttemplate"+"\\"+m_EntityName; //rpttemplate\SO
-			//suri = "supplier00";
-			string ret = xaserver::UploadFile(suri, sname, this.GetHWND(),"",false);
-			if (ret == "-1")
-			{
-				alert("上传的文件没选择!");
-				return 1;
-			}
-			else
-			{
-				xml x=new xml;
-				x.setNativePointer(xml::CreateInstance());				
-				xaserverarg args = new xaserverarg;
-				args.setNativePointer(args.CreateInstance());		
-				args.AddArg("sID",sguid);			
-				args.AddArg("sEntity",m_EntityName);			
-				args.AddArg("sDir",m_Dir);
-				args.AddArg("urlPath", sname);
-				//alert(m_Dir);
-				while(ret.find("\\",0)>=0)
-					ret = ret.mid(ret.find("\\",0) + 1,9999);
-				
-				args.AddArg("sTemplName",ret);			
-				//trace(args.GetString());
-				if (url::get("/sale/data/SysPrintTemplate/Save",args.GetString(),x) != 1)
-				{
-					trace("error:"+x.GetXml());
-					alert("保存出错了!");
-					return 1;
-				}						
-				else
-				{	
-					alert("上传模板成功!");
-					OnRetrieve();
-				}				
-			}
-			return 1;
-		}
-				
-		int OnDelTempl()
-		{
-				
-			int row =  dw_list.GetRow();
-			if(row<0 || row>dw_list.GetRowCount()) 
-			{
-				alert("请选择要删除的模板!");
-				return 0;
-			}
-			else
-			{
-				if (win32::MessageBox(GetHWND(),"确定要删除选中的模板?","提示",1) == 2)  
-					return 0;					
-				msxml::IXMLDOMElement ele = dw_list.GetRowElement(row);			
-				string sguid = ele.selectSingleNode("ID").text;
-				xml x=new xml;
-				x.setNativePointer(xml::CreateInstance());				
-				xaserverarg args = new xaserverarg;
-				args.setNativePointer(args.CreateInstance());		
-				args.AddArg("sID",sguid);		
-				if (url::get("/sale/data/SysPrintTemplate/Delete",args.GetString(),x) != 1)
-				{
-					trace("error:"+x.GetXml());
-					alert("删除出错了!");
-					return 0;
-				}						
-				else
-				{	
-					alert("删除成功!");
-					OnRetrieve();
-				}
-			}
-				
-			return 0;
-		}
-		
-		int OnDocListDoubleClicked(ref TNotifyEvent evt,int p)
-		{
-			int  hCursor = xutil::SetCursorWait();
-			OnOpenDocument();
-			xutil::RestoreCursor(hCursor);
-			return 1;
-		}	
-				
-		int OnDoubleClicked(ref TNotifyEvent evt,int p)
-		{
-			int  hCursor = xutil::SetCursorWait();
-			OnOk();
-			xutil::RestoreCursor(hCursor);
-			return 1;
-		}	
-
-		int OnOpenDocument()
-		{
-			if(dw_doclist.GetRowCount() < 1) return 1;
-			string documentid = dw_doclist.GetRowElement(dw_doclist.GetRow()).getAttribute("guid");
-			//string billid = dw_docList
-			arg_param.AddArg("DocumentID",documentid);
-			arg_param.AddArg("return","ok");
-			arg_param.AddArg("action","open");
-			CloseWindow();
-			return 1;
-		}
-				
-		int OnOk()
-		{
-			int row =  dw_list.GetRow();
-			if(row<0 || row>dw_list.GetRowCount()) 
-			{
-				alert("请选择要打印的模板!");
-				return 1;
-			}
-			else
-			{
-				msxml::IXMLDOMElement ele = dw_list.GetRowElement(row);	
-				trace("\r\n---------------");
-				trace(ele.xml);
-			
-				string sguid = ele.selectSingleNode("ID").text;
-				string pre = "";
-				if(ele.selectSingleNode("TemplPre")) pre = ele.selectSingleNode("TemplPre").text;
-				string sTemplName = ele.selectSingleNode("TemplName").text;
-				//string sFile = m_filePath + sguid+".xsl";	
-				trace(sTemplName);
-				string sFile = m_filePath + ele.selectSingleNode("urlPath").text;
-				arg_param.AddArg("xsl",sFile); 
-				arg_param.AddArg("return","ok");
-				arg_param.AddArg("template-name",sTemplName);
-				arg_param.AddArg("template-guid",sguid);
-				arg_param.AddArg("template-pre",pre);
-				arg_param.AddArg("action","new");
-				trace(arg_param.GetString());
-				CloseWindow();
-				/*xaserver::CreateDirectory("C:/Temp");
-				int openRet = xaserver::DownLoadFile(GetServerUrl(),m_filePath+file,sTemplName,"C:/Temp/"+sTemplName);
-				if(openRet < 0)
-				{
-					alert("文件打开失败!");
-					return 0;
-				}
-				
-				int GENERIC_READ = 0x80000000;
-				int GENERIC_WRITE = 0x40000000;
-				int FILE_SHARE_READ = 0x00000001;
-				int FILE_SHARE_WRITE = 0x00000002;
-				int OPEN_EXISTING = 3;
-				int FILE_ATTRIBUTE_ARCHIVE =0x00000020;
-				int hFile = xwin::CreateFile("C:/Temp/"+sTemplName,GENERIC_READ|GENERIC_WRITE,FILE_SHARE_READ|FILE_SHARE_WRITE,0,OPEN_EXISTING,0,0);
-				if (hFile >0)
-				{
-					//int GMEM_MOVEABLE=0x0002;
-					//int GMEM_ZEROINIT=0x0040;
-					//int MEMSIZE;
-					//int hMemory = GlobalAlloc(GMEM_MOVEABLE|GMEM_ZEROINIT,MEMSIZE);
-					//int pMemory = GlobalLock(hMemory);
-					//int SizeReadWrite;
-					//xwin::ReadFile(hFile,pMemory,MEMSIZE - 1,SizeReadWrite,0);
-					int filesize = xwin::GetFileSize(hFile,0); 
-				trace("filesize = %d",filesize);
-					string buffer = "".space(filesize+1);
-					int readsize = new int;
-					xwin::ReadFile(hFile,buffer,filesize,readsize,0); 
-					trace(buffer);
-					xwin::CloseHandle(hFile);
-					//GlobalUnlock(pMemory);
-					//GlobalFree(hMemory);
-				}	*/			
-				/*openRet = xwin::ShellExecute(0,"open","C:/Temp/"+sTemplName,"","",5);	
-				if(openRet < 32)
-				{
-					alert("文件打开失败2!");
-					return 0;
-				}*/			
-			}			
-			return 0;
-		}
-
-		int OnSave()
-		{
-			dw_list.AcceptText();
-			xml x = new xml;
-			x.setNativePointer(xml::CreateInstance());
-			dw_list.DwUpdateAllToEx(x.GetXmlDoc());
-			
-			xaserverarg arg = new xaserverarg;
-			arg.setNativePointer(xaserverarg::CreateInstance());
-			arg.AddArg("content",x.GetXml());
-			
-			if (url::get("/sale/data/SysPrintTemplate/updateinfo",arg.GetString(),x) != 1)
-			{
-				trace("error:"+x.GetXml());
-				alert("保存出错了!");
-				return 1;
-			}						
-			else
-			{	
-				dw_list.ResetUpdateStatus();
-				alert("保存成功!");
-			}				
-
-			return 1;
-		}
-		
-		int PreOnCmdDispatch(string comdid)
-		{
-			//返回0——不在执行以下代码;返回其他——执行以下代码。
-			if(comdid.left(8) == "xmPanel:"){
-				string no = comdid.mid(8, 99);
-				//int id = no.toInt();
-
-				xml x = new xml;
-				x.setNativePointer(xml::CreateInstance());
-				x.LoadXml(strNode);
-				msxml::IXMLDOMDocument doc= x.GetXmlDoc();
-				msxml::IXMLDOMElement e = doc.documentElement;
-				string slable =e.selectSingleNode("//xtoolbutton[@name='"+comdid+"']/@caption").text;
-				m_Dir = slable;
-				OnRetrieve();
-			
-				return 1;
-			}
-			if (comdid=="xmAddDir") return OnAddDir();
-			if (comdid=="xmAddTempl" && bupdate) return OnAddTempl();
-			if (comdid=="xmDelTempl" && bupdate) return OnDelTempl();
-			if (comdid=="xmMaintTempl" && bupdate) return OnMaintTempl();
-			if (comdid=="xmNewTempl" && bupdate) return OnNewTempl();
-			if (comdid=="xmHtml") return OnHtml();
-			if (comdid=="xmOk") return OnOk();
-			if (comdid=="xmSave") return OnSave();
-			if(comdid=="xmOpen") return OnOpenDocument();
-			else if (comdid=="xmCancel") 
-			{
-				arg_param.AddArg("return","cancel");
-				CloseWindow();
-				return 1;
-			}
-			return 0;
-		}
-			
-		
-		int PostOnAttachEvent()
-		{
-			//AttachEvent("dw_list","DWV_ROWFOCUSCHANGED",OnRowChanged);	
-			//AttachEvent("dw_list","DWV_CLICKED",OnClicked);	
-			//AttachEvent("dw_list","DWV_RCLICKED",OnRClicked);	
-			//AttachEvent("dw_list","DWV_ITEMCHANGED",OnItemChanged);	
-			//AttachEvent("dw_list","DWV_CHILDCONTENT",OnChildContent);	
-			AttachEvent("dw_doclist","DWV_DOUBLECLICKED",OnDocListDoubleClicked);	
-			AttachEvent("dw_list","DWV_DOUBLECLICKED",OnDoubleClicked);	
-			return 1;	
-		}
-
-		int SetAgent()
-		{	
-			PUser puser = new PUser;
-			puser =  publiccode::GetUser();
-			string susername = puser.name;
-			if (susername !="admin")
-			{
-				string xfNodeAgentArea  = "DirButton";
-				xnode anode = GetAgentNode(xfNodeAgentArea);
-				msxml::IXMLDOMElement xframeElement =  GetElement();
-				string tools="<vbox name='DirButton' height='48' />";
-				SetAgentNodeContent(anode, tools);
-			}
-			return 1;
-		}
-		
-		int CreateDir()
-		{
-			PUser puser = new PUser;
-			puser =  publiccode::GetUser();
-			string susername = puser.name;
-			xml x = new xml;
-			x.setNativePointer(xml::CreateInstance());
-			xaserverarg arg = new xaserverarg;
-			arg.setNativePointer(arg.CreateInstance());	
-			arg.AddArg("EntityName",m_EntityName,""); 
-			arg.AddArg("EntityID",m_EntityID,""); 
-			arg.AddArg("susername",susername,""); //
-			if (url::get("/sale/data/SysPrintTemplate/Dir",arg.GetString(),x) != 1)
-			{
-				trace(x.GetXmlDoc().text);
-				return -1;
-			}else	
-			{
-				string s = x.GetXml();
-			}
-			msxml::IXMLDOMNodeList  nlist = x.GetXmlDoc().selectNodes("//Entity");
-			int i;
-			int nlen = nlist.length;
-			string toolStr = "<vbox name='Dir'>";
-			string deptName= publiccode::GetUser().deptname;
-			if(deptName=="跟单部" && m_EntityName=="GDN3"){
-				for(i=2;	i<nlen;	i++)
-				{
-					msxml::IXMLDOMElement e1 = nlist.item(i);
-					string sDir1 = e1.selectSingleNode("@Dir").text;
-					string str1 = "<xtoolbutton image='15' caption='"+sDir1+"' height='24' name='xmPanel:"+i.toString()+"' style='background-color:none #ceecce none #ffffff'/>";
-			
-					toolStr += str1;
-					if (i==2) 
-						m_Dir = sDir1;
-				}
-			}else if(deptName.find("业务")>=0 && m_EntityName=="GDN3"  )
-			{
-				for(i=1;	i<2;	i++)
-				{
-					msxml::IXMLDOMElement e2 = nlist.item(i);
-					string sDir2 = e2.selectSingleNode("@Dir").text;
-					string str2 = "<xtoolbutton image='15' caption='"+sDir2+"' height='24' name='xmPanel:"+i.toString()+"' style='background-color:none #ceecce none #ffffff'/>";
-					
-					toolStr += str2;
-					if (i==1) 
-						m_Dir = sDir2;
-				}
-				for(i=4;	i<nlen;	i++)
-				{
-					msxml::IXMLDOMElement e3 = nlist.item(i);
-					string sDir3 = e3.selectSingleNode("@Dir").text;
-					string str3 = "<xtoolbutton image='15' caption='"+sDir3+"' height='24' name='xmPanel:"+i.toString()+"' style='background-color:none #ceecce none #ffffff'/>";
-					
-					toolStr += str3;
-				}
-			}else{
-				for(i=0;	i<nlen;	i++)
-				{
-					msxml::IXMLDOMElement e = nlist.item(i);
-					string sDir = e.selectSingleNode("@Dir").text;
-					string str = "<xtoolbutton image='15' caption='"+sDir+"' height='24' name='xmPanel:"+i.toString()+"' style='background-color:none #ceecce none #ffffff'/>";
-					
-					toolStr += str;
-					if (i==0) 
-						m_Dir = sDir;
-				}
-			}	
-				
-			toolStr += "</vbox>";
-			strNode = toolStr;
-			//trace(toolStr);
-			xnode anode = GetAgentNode("Dir");
-			xwin::SetAgentNodeContent(anode,toolStr) ;
-			
-			OnRetrieve();
-			return 1;
-		}
-			
-		int OnInit()
-		{ 		
-			SetAgent();
-			dw_list = this.GetControl("dw_list");
-			dw_list.openUrl("/sale/view/view.base/template/PrintView/listDialog");
-			dw_list.SetReadOnly(true);
-			dw_list.SetSelectionMode(4);
-			dw_list.SetColumnState("ID",false);
-
-			dw_doclist = GetControl("dw_doclist");
-			dw_doclist.openUrl("/sale/view/GDN/template/doclist");
-
-			string sUrl = GetServerUrl();
-			sUrl = sUrl.mid(0, sUrl.length() - 19);
-			m_filePath = "/business/rpttemplate";
-			arg_param = new xaserverarg;
-			if (GetParam())
-			{
-				int p = GetParam();
-				arg_param.setNativePointer(p);
-				m_EntityName = arg_param.GetArgString("EntityName");
-				m_EntityID = arg_param.GetArgString("EntityID");
-				m_EntityNo = arg_param.GetArgString("EntityNo");
-			
-				xaserverarg arg = new xaserverarg;
-				arg.setNativePointer(xaserverarg::CreateInstance());
-				arg.AddArg("EntityName", m_EntityName);
-				arg.AddArg("EntityID", m_EntityID);
-				arg.AddArg("EntityNo", m_EntityNo);
-				xml x =new xml;
-				x.setNativePointer(xml::CreateInstance());
-				if(url::get("/sale/data/DocumentList3/bill/doclist", arg.GetString(),x)!=1)
-				{
-					string error = x.GetXmlDoc().text;
-					trace(error);
-				}else
-				{
-					dw_doclist.Retrieve(x);
-					dw_doclist.SetReadOnly(true);
-				}
-			}
-			else
-			{
-				arg_param.setNativePointer(arg_param.CreateInstance());	
-				m_EntityName = "SO";
-				m_EntityID ="00000000-0000-0000-0000-000000000000";
-			}
-
-			m_Dir = "";
-			m_filePath = m_filePath + "/" + m_EntityName+"/";
-			//trace(m_filePath);
-			
-			CreateDir();
-			
-			return 1;
-		}
-
-	int onload()
+public:
+	int OnRetrieve()
 	{
-		responsewin::onload();
-		
-		/*if (GetParam())
+		xstring username = publiccode::GetUser().name;
+		if (username != L"admin" && m_Dir != username)
 		{
-			string action = arg_param.GetArgString("action");
-			if(action=="open" || (action=="" && dw_doclist.GetRowCount() > 0))
-				SwitchLayer("sheet2","frame");
+			bupdate = false;
 		}
-		*/
+		else
+		{
+			bupdate = true;
+		}
+		xml x;
+
+		xaserverarg arg;
+
+		arg.AddArg(L"Entity", m_EntityName);
+		arg.AddArg(L"Dir", m_Dir);
+		dw_list.Reset();
+		if (xurl::get(L"/sale/data/SysPrintTemplate/listDialog", arg.GetString(), x) != 1)
+		{
+			trace(x.text());
+			return -1;
+		}
+		else
+		{
+			xstring s = x.xml();
+			dw_list.Retrieve(x);
+		}
+		dw_list.Redraw();
+		//dw_list.SetReadOnly(true);
+		if (dw_list.GetRowCount() > 0)
+			dw_list.SelectRow(1, true);
+		return 1;
+	}
+
+	int OnNewTempl()
+	{
+		OpenWindow(L"dev:xpage[Maint.Template.Print.vx]");
+		return 1;
+	}
+
+	int OnMaintTempl()
+	{
+		int row = dw_list.GetRow();
+		if (row<0 || row>dw_list.GetRowCount())
+		{
+			alert(L"请选择要维护的模板!");
+			return 1;
+		}
+		else
+		{
+			KXMLDOMElement ele = dw_list.GetRowElement(row);
+			xstring sguid = ele.selectSingleNode(L"ID").text();
+			xstring sTemplName = ele.selectSingleNode(L"TemplName").text();
+			//xstring sFile = m_filePath + sguid+L".xsl";
+			xstring sFile = ele.selectSingleNode(L"urlPath").text();
+			if (sFile.left(1) == L"/")
+			{
+				sFile = L"/business/rpttemplate" + sFile;
+			}else
+				sFile = m_filePath + sFile;
+
+			arg_param.AddArg(L"xsl", sFile);
+			arg_param.AddArg(L"return", L"cancel");
+
+			OpenWindow(L"dev:xpage[Maint.Template.Print.vx]", arg_param);
+			CloseWindow();
+
+		}
+		return 1;
+	}
+
+	int OnAddDir()
+	{
+		return 0;
+	}
+	int OnAddTempl()
+	{
+		if (m_Dir == L"")
+		{
+			alert(L"请选择模板目录!");
+			return 0;
+		}
+		xstring sguid = publiccode::GetGuid();
+		xstring sname = sguid + L".xsl";
+		xstring entityName = m_EntityName;
+		xstring entitys = L",CD,GDN3,PO,PurchaseOrder,Quote,Quote1,SaleOrder,VATNotify,";
+		if(entitys.find(entityName) < 0)
+			entityName = L"SaleOrder";
+		xstring suri = L"rpttemplate\\" + entityName; //rpttemplate\SO
+		//suri = L"supplier00";
+		xstring ret = xaserver::UploadFile(suri, sname, GetHWND(), L"", false);
+		if (ret == L"-1")
+		{
+			alert(L"上传的文件没选择!");
+			return 1;
+		}
+		else
+		{
+			xml x;
+			xaserverarg args;
+			args.AddArg(L"sID", sguid);
+			args.AddArg(L"sEntity", m_EntityName);
+			args.AddArg(L"sDir", m_Dir);
+			args.AddArg(L"urlPath", sname);
+			if (entityName != m_EntityName)
+				args.AddArg(L"urlPath", L"/SaleOrder/" + sname);
+			else
+				args.AddArg(L"urlPath", sname);
+
+			//alert(m_Dir);
+			while (ret.find(L"\\", 0) >= 0)
+				ret = ret.mid(ret.find(L"\\", 0) + 1, 9999);
+
+			args.AddArg(L"sTemplName", ret);
+			//trace(args.GetString());
+			if (xurl::get(L"/sale/data/SysPrintTemplate/Save", args.GetString(), x) != 1)
+			{
+				trace((xstring)L"error:" + x.xml());
+				alert(L"保存出错了!");
+				return 1;
+			}
+			else
+			{
+				alert(L"上传模板成功!");
+				OnRetrieve();
+			}
+		}
+		return 1;
+	}
+
+	int OnDelTempl()
+	{
+
+		int row = dw_list.GetRow();
+		if (row<0 || row>dw_list.GetRowCount())
+		{
+			alert(L"请选择要删除的模板!");
+			return 0;
+		}
+		else
+		{
+			if (MessageBox(GetHWND(), L"确定要删除选中的模板?", L"提示", 1) == 2)
+				return 0;
+			KXMLDOMElement ele = dw_list.GetRowElement(row);
+			xstring sguid = ele.selectSingleNode(L"ID").text();
+			xml x;
+			xaserverarg args;
+			args.AddArg(L"sID", sguid);
+			if (xurl::get(L"/sale/data/SysPrintTemplate/Delete", args.GetString(), x) != 1)
+			{
+				trace((xstring)L"error:" + x.xml());
+				alert(L"删除出错了!");
+				return 0;
+			}
+			else
+			{
+				alert(L"删除成功!");
+				OnRetrieve();
+			}
+		}
+
+		return 0;
+	}
+
+	int OnDocListDoubleClicked(TEvent * evt, int p)
+	{
+		HCURSOR  hCursor = xutil::SetCursorWait();
+		OnOpenDocument();
+		xutil::RestoreCursor(hCursor);
+		return 1;
+	}
+
+	int OnDoubleClicked(TEvent * evt, int p)
+	{
+		HCURSOR hCursor = xutil::SetCursorWait();
+		OnOk();
+		xutil::RestoreCursor(hCursor);
+		return 1;
+	}
+
+	int OnOpenDocument()
+	{
+		if (dw_doclist.GetRowCount() < 1) return 1;
+		xstring documentid = dw_doclist.GetRowElement(dw_doclist.GetRow()).getAttribute(L"guid");
+		//xstring billid = dw_docList
+		arg_param.AddArg(L"DocumentID", documentid);
+		arg_param.AddArg(L"return", L"ok");
+		arg_param.AddArg(L"action", L"open");
+		CloseWindow();
+		return 1;
+	}
+
+	int OnOk()
+	{
+		int row = dw_list.GetRow();
+		if (row<0 || row>dw_list.GetRowCount())
+		{
+			alert(L"请选择要打印的模板!");
+			return 1;
+		}
+		else
+		{
+			KXMLDOMElement ele = dw_list.GetRowElement(row);
+			trace(L"\r\n---------------");
+			trace(ele.xml());
+
+			xstring sguid = ele.selectSingleNode(L"ID").text();
+			xstring pre = L"";
+			if (ele.selectSingleNode(L"TemplPre")) pre = ele.selectSingleNode(L"TemplPre").text();
+			xstring sTemplName = ele.selectSingleNode(L"TemplName").text();
+			//xstring sFile = m_filePath + sguid+L".xsl";	
+			trace(sTemplName);
+			xstring sFile = ele.selectSingleNode(L"urlPath").text();
+			if (sFile.left(1) == L"/")
+			{
+				sFile = L"/business/rpttemplate" + sFile;
+			}
+			else
+				sFile = m_filePath + sFile;
+
+			arg_param.AddArg(L"xsl", sFile);
+			arg_param.AddArg(L"return", L"ok");
+			arg_param.AddArg(L"template-name", sTemplName);
+			arg_param.AddArg(L"template-guid", sguid);
+			arg_param.AddArg(L"template-pre", pre);
+			arg_param.AddArg(L"action", L"new");
+			trace(arg_param.GetString());
+			CloseWindow();
+			/*xaserver::CreateDirectory(L"C:/Temp");
+			int openRet = xaserver::DownLoadFile(GetServerUrl(),m_filePath+file,sTemplName,L"C:/Temp/"+sTemplName);
+			if(openRet < 0)
+			{
+				alert(L"文件打开失败!");
+				return 0;
+			}
+
+			int GENERIC_READ = 0x80000000;
+			int GENERIC_WRITE = 0x40000000;
+			int FILE_SHARE_READ = 0x00000001;
+			int FILE_SHARE_WRITE = 0x00000002;
+			int OPEN_EXISTING = 3;
+			int FILE_ATTRIBUTE_ARCHIVE =0x00000020;
+			int hFile = xwin::CreateFile(L"C:/Temp/"+sTemplName,GENERIC_READ|GENERIC_WRITE,FILE_SHARE_READ|FILE_SHARE_WRITE,0,OPEN_EXISTING,0,0);
+			if (hFile >0)
+			{
+				//int GMEM_MOVEABLE=0x0002;
+				//int GMEM_ZEROINIT=0x0040;
+				//int MEMSIZE;
+				//int hMemory = GlobalAlloc(GMEM_MOVEABLE|GMEM_ZEROINIT,MEMSIZE);
+				//int pMemory = GlobalLock(hMemory);
+				//int SizeReadWrite;
+				//xwin::ReadFile(hFile,pMemory,MEMSIZE - 1,SizeReadWrite,0);
+				int filesize = xwin::GetFileSize(hFile,0);
+			trace(L"filesize = %d",filesize);
+				xstring buffer = L"".space(filesize+1);
+				int readsize = new int;
+				xwin::ReadFile(hFile,buffer,filesize,readsize,0);
+				trace(buffer);
+				xwin::CloseHandle(hFile);
+				//GlobalUnlock(pMemory);
+				//GlobalFree(hMemory);
+			}	*/
+			/*openRet = xwin::ShellExecute(0,L"open",L"C:/Temp/"+sTemplName,L"",L"",5);
+			if(openRet < 32)
+			{
+				alert(L"文件打开失败2!");
+				return 0;
+			}*/
+		}
+		return 0;
+	}
+
+	int OnSave()
+	{
+		dw_list.AcceptText();
+		xml x;
+
+		dw_list.DwUpdateAllToEx(x);
+
+		xaserverarg arg;
+		
+		arg.AddArg(L"content", x.xml());
+
+		if (xurl::get(L"/sale/data/SysPrintTemplate/updateinfo", arg.GetString(), x) != 1)
+		{
+			trace((xstring)L"error:" + x.xml());
+			alert(L"保存出错了!");
+			return 1;
+		}
+		else
+		{
+			dw_list.ResetUpdateStatus();
+			alert(L"保存成功!");
+		}
 
 		return 1;
 	}
-	
-	int onloaded()
+
+	int PreOnCmdDispatch(xstring comdid)
 	{
-		//responsewin::onload();
+		//返回0——不在执行以下代码;返回其他——执行以下代码。
+		if (comdid.left(8) == L"xmPanel:") {
+			xstring no = comdid.mid(8, 99);
+			//int id = no.toInt();
+
+			xml x;
+
+			x.loadXML(strNode);
+			KXMLDOMDocument doc = x;
+			KXMLDOMElement e = doc.documentElement();
+			xstring slable = e.selectSingleNode(L"//xtoolbutton[@name='" + comdid + L"']/@caption").text();
+			m_Dir = slable;
+			OnRetrieve();
+
+			return 1;
+		}
+		if (comdid == L"xmAddDir") return OnAddDir();
+		if (comdid == L"xmAddTempl" && bupdate) return OnAddTempl();
+		if (comdid == L"xmDelTempl" && bupdate) return OnDelTempl();
+		if (comdid == L"xmMaintTempl" && bupdate) return OnMaintTempl();
+		if (comdid == L"xmNewTempl" && bupdate) return OnNewTempl();
+		//if (comdid==L"xmHtml") return OnHtml();
+		if (comdid == L"xmOk") return OnOk();
+		if (comdid == L"xmSave") return OnSave();
+		if (comdid == L"xmOpen") return OnOpenDocument();
+		else if (comdid == L"xmCancel")
+		{
+			arg_param.AddArg(L"return", L"cancel");
+			CloseWindow();
+			return 1;
+		}
+		return 0;
+	}
+
+
+	int PostOnAttachEvent()
+	{
+		//AttachEvent(L"dw_list",L"DWV_ROWFOCUSCHANGED",OnRowChanged);	
+		//AttachEvent(L"dw_list",L"DWV_CLICKED",OnClicked);	
+		//AttachEvent(L"dw_list",L"DWV_RCLICKED",OnRClicked);	
+		//AttachEvent(L"dw_list",L"DWV_ITEMCHANGED",OnItemChanged);	
+		//AttachEvent(L"dw_list",L"DWV_CHILDCONTENT",OnChildContent);	
+		AttachEvent(L"dw_doclist", L"DWV_DOUBLECLICKED", (FEvent)&TemplatePrintDialog::OnDocListDoubleClicked);
+		AttachEvent(L"dw_list", L"DWV_DOUBLECLICKED", (FEvent)&TemplatePrintDialog::OnDoubleClicked);
+		return 1;
+	}
+
+	int SetAgent()
+	{
+		PUser& puser = publiccode::GetUser();
+		xstring susername = puser.name;
+		if (susername != L"admin")
+		{
+			xstring xfNodeAgentArea = L"DirButton";
+			xnode anode = GetAgentNode(xfNodeAgentArea);
+			KXMLDOMElement xframeElement = GetElement();
+			xstring tools = L"<vbox name='DirButton' height='48' />";
+			SetAgentNode(anode, tools);
+		}
+		return 1;
+	}
+
+	int CreateDir()
+	{
+		PUser& puser = publiccode::GetUser();
+		xstring susername = puser.name;
+		xml x;
+
+		xaserverarg arg;
 		
+		arg.AddArg(L"EntityName", m_EntityName, L"");
+		arg.AddArg(L"EntityID", m_EntityID, L"");
+		arg.AddArg(L"susername", susername, L""); //
+		if (xurl::get(L"/sale/data/SysPrintTemplate/Dir", arg.GetString(), x) != 1)
+		{
+			trace(x.text());
+			return -1;
+		}
+		else
+		{
+			xstring s = x.xml();
+		}
+		KXMLDOMNodeList  nlist = x.selectNodes(L"//Entity");
+		int i;
+		int nlen = nlist.length();
+		xstring toolStr = L"<vbox name='Dir'>";
+		xstring deptName = publiccode::GetUser().deptname;
+		if (deptName == L"订单操作部" && m_EntityName == L"GDN3") {
+			for (i = 2; i < nlen; i++)
+			{
+				KXMLDOMElement e1 = nlist.item(i);
+				xstring sDir1 = e1.selectSingleNode(L"@Dir").text();
+				xstring str1 = L"<xtoolbutton image='15' caption='" + sDir1 + L"' height='24' name='xmPanel:" + xstring(i) + L"' style='background-color:none #ceecce none #ffffff'/>";
+
+				toolStr += str1;
+				if (i == 2)
+					m_Dir = sDir1;
+			}
+		}
+		else if (deptName.find(L"业务") >= 0 && m_EntityName == L"GDN3")
+		{
+			for (i = 1; i < 2; i++)
+			{
+				KXMLDOMElement e2 = nlist.item(i);
+				xstring sDir2 = e2.selectSingleNode(L"@Dir").text();
+				xstring str2 = L"<xtoolbutton image='15' caption='" + sDir2 + L"' height='24' name='xmPanel:" + xstring(i) + L"' style='background-color:none #ceecce none #ffffff'/>";
+
+				toolStr += str2;
+				if (i == 1)
+					m_Dir = sDir2;
+			}
+			for (i = 4; i < nlen; i++)
+			{
+				KXMLDOMElement e3 = nlist.item(i);
+				xstring sDir3 = e3.selectSingleNode(L"@Dir").text();
+				xstring str3 = L"<xtoolbutton image='15' caption='" + sDir3 + L"' height='24' name='xmPanel:" + xstring(i) + L"' style='background-color:none #ceecce none #ffffff'/>";
+
+				toolStr += str3;
+			}
+		}
+		else {
+			for (i = 0; i < nlen; i++)
+			{
+				KXMLDOMElement e = nlist.item(i);
+				xstring sDir = e.selectSingleNode(L"@Dir").text();
+				xstring str = L"<xtoolbutton image='15' caption='" + sDir + L"' height='24' name='xmPanel:" + xstring(i) + L"' style='background-color:none #ceecce none #ffffff'/>";
+
+				toolStr += str;
+				if (i == 0)
+					m_Dir = sDir;
+			}
+		}
+
+		toolStr += L"</vbox>";
+		strNode = toolStr;
+		//trace(toolStr);
+		xnode anode = GetAgentNode(L"Dir");
+		xwin::SetAgentNode(anode, toolStr);
+
+		OnRetrieve();
+		return 1;
+	}
+
+	int OnInit()
+	{
+		SetAgent();
+		dw_list = GetControl(L"dw_list");
+		dw_list.openUrl(L"/sale/view/view.base/template/PrintView/listDialog");
+		dw_list.SetReadOnly(true);
+		dw_list.SetSelectionMode(4);
+		dw_list.SetColumnState(L"ID", false);
+
+		dw_doclist = GetControl(L"dw_doclist");
+		dw_doclist.openUrl(L"/sale/view/GDN/template/doclist");
+
+		xstring sUrl = GetServerUrl();
+		sUrl = sUrl.mid(0, sUrl.length() - 19);
+		m_filePath = L"/business/rpttemplate";
+		arg_param;
+		if (GetWinParam())
+		{
+			arg_param = GetArg();
+			m_EntityName = arg_param.GetArgString(L"EntityName");
+			m_EntityID = arg_param.GetArgString(L"EntityID");
+			m_EntityNo = arg_param.GetArgString(L"EntityNo");
+
+			xaserverarg arg;
+			arg.AddArg(L"EntityName", m_EntityName);
+			arg.AddArg(L"EntityID", m_EntityID);
+			arg.AddArg(L"EntityNo", m_EntityNo);
+			xml x ;
+
+			if (xurl::get(L"/sale/data/DocumentList3/bill/doclist", arg.GetString(), x) != 1)
+			{
+				xstring error = x.text();
+				trace(error);
+			}
+			else
+			{
+				dw_doclist.Retrieve(x);
+				dw_doclist.SetReadOnly(true);
+			}
+		}
+		else
+		{
+			
+			m_EntityName = L"SO";
+			m_EntityID = L"00000000-0000-0000-0000-000000000000";
+		}
+
+		m_Dir = L"";
+		m_filePath = m_filePath + L"/" + m_EntityName + L"/";
+		//trace(m_filePath);
+
+		CreateDir();
+
+		return 1;
+	}
+
+	int onload()
+	{
+		SetArg();
+		responsewin::onload();
 		/*if (GetParam())
 		{
-			string action = arg_param.GetArgString("action");
-			if(action=="open" || (action=="" && dw_doclist.GetRowCount() > 0))
-				SwitchLayer("sheet2","frame");
+			xstring action = arg_param.GetArgString(L"action");
+			if(action==L"open" || (action==L"" && dw_doclist.GetRowCount() > 0))
+				SwitchLayer(L"sheet2",L"frame");
 		}
 		*/
+
 		return 1;
 	}
 };
\ No newline at end of file

--
Gitblit v1.9.3