From 69ca48293b089073a494c36faafaee3f0c83e7a4 Mon Sep 17 00:00:00 2001
From: xj qian <qianxj15@sina.com>
Date: 星期五, 28 六月 2024 14:48:08 +0800
Subject: [PATCH] Merge branch 'master' of http://116.62.18.175:6699/r/mis-prj

---
 jrj/project/business/Public/memo.edit.new.cpp              |    0 
 jrj/project/business/SO/Product.FetchNo.cpp                |  336 ++++++++++++++++++++++++++++
 jrj/project/business/HR/AdministrativeDepartmentFolder.cpp |    4 
 jrj/project/business/SO/maint.Document.SO3.v3.cpp          |    2 
 jrj/xframe/vbusiness/vframe/listwin.vframe.vbusiness.hpp   |    4 
 jrj/project/business/Public/message.supplier.cpp           |    0 
 jrj/project/business/SO3.list.cpp                          |    8 
 jrj/ext-jrj/ext-jrj.vcxproj                                |   15 +
 jrj/project/business/Public/message.business.cpp           |    0 
 jrj/ext-jrj/ext-jrj.vcxproj.filters                        |   18 +
 jrj/project/business/SO/Apply.SOItem.cpp                   |  297 ++++++++++++++++++++++++
 11 files changed, 676 insertions(+), 8 deletions(-)

diff --git a/jrj/ext-jrj/ext-jrj.vcxproj b/jrj/ext-jrj/ext-jrj.vcxproj
index 1dba532..085ed5c 100644
--- a/jrj/ext-jrj/ext-jrj.vcxproj
+++ b/jrj/ext-jrj/ext-jrj.vcxproj
@@ -277,6 +277,15 @@
       <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild>
       <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild>
     </ClCompile>
+    <ClCompile Include="..\project\business\Public\memo.edit.new.cpp">
+      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild>
+    </ClCompile>
+    <ClCompile Include="..\project\business\Public\message.business.cpp">
+      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild>
+    </ClCompile>
+    <ClCompile Include="..\project\business\Public\message.supplier.cpp">
+      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild>
+    </ClCompile>
     <ClCompile Include="..\project\business\quote.enquiry.cpp">
       <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild>
     </ClCompile>
@@ -290,6 +299,9 @@
     <ClCompile Include="..\project\business\SO3.maint.cpp">
       <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild>
     </ClCompile>
+    <ClCompile Include="..\project\business\SO\Apply.SOItem.cpp">
+      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild>
+    </ClCompile>
     <ClCompile Include="..\project\business\SO\delivery.base.maint.so.cpp">
       <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild>
       <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild>
@@ -302,6 +314,9 @@
       <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild>
       <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild>
     </ClCompile>
+    <ClCompile Include="..\project\business\SO\Product.FetchNo.cpp">
+      <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild>
+    </ClCompile>
     <ClCompile Include="..\project\business\SO\Product.Select.SO.cpp">
       <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild>
       <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild>
diff --git a/jrj/ext-jrj/ext-jrj.vcxproj.filters b/jrj/ext-jrj/ext-jrj.vcxproj.filters
index 2024dc4..991f934 100644
--- a/jrj/ext-jrj/ext-jrj.vcxproj.filters
+++ b/jrj/ext-jrj/ext-jrj.vcxproj.filters
@@ -61,6 +61,9 @@
     <Filter Include="project\business\HR">
       <UniqueIdentifier>{5f718d5a-c9c4-4438-95e8-b079e44db2aa}</UniqueIdentifier>
     </Filter>
+    <Filter Include="project\business\Public">
+      <UniqueIdentifier>{84061804-77b3-4859-b7b2-60cfa03c9463}</UniqueIdentifier>
+    </Filter>
   </ItemGroup>
   <ItemGroup>
     <ClInclude Include="framework.h">
@@ -386,5 +389,20 @@
     <ClCompile Include="..\project\business\HR\ManpowerFileWindow.cpp">
       <Filter>project\business\HR</Filter>
     </ClCompile>
+    <ClCompile Include="..\project\business\SO\Product.FetchNo.cpp">
+      <Filter>project\business\SO</Filter>
+    </ClCompile>
+    <ClCompile Include="..\project\business\Public\memo.edit.new.cpp">
+      <Filter>project\business\Public</Filter>
+    </ClCompile>
+    <ClCompile Include="..\project\business\Public\message.business.cpp">
+      <Filter>project\business\Public</Filter>
+    </ClCompile>
+    <ClCompile Include="..\project\business\Public\message.supplier.cpp">
+      <Filter>project\business\Public</Filter>
+    </ClCompile>
+    <ClCompile Include="..\project\business\SO\Apply.SOItem.cpp">
+      <Filter>project\business\SO</Filter>
+    </ClCompile>
   </ItemGroup>
 </Project>
\ No newline at end of file
diff --git a/jrj/project/business/HR/AdministrativeDepartmentFolder.cpp b/jrj/project/business/HR/AdministrativeDepartmentFolder.cpp
index 31ca6fa..be01a84 100644
--- a/jrj/project/business/HR/AdministrativeDepartmentFolder.cpp
+++ b/jrj/project/business/HR/AdministrativeDepartmentFolder.cpp
@@ -181,7 +181,9 @@
 			
 			adid = L"";
 			parentid = L"";
-			if (GetWinParam()) {
+			if (GetWinParam()) 
+			{
+				xaserverarg arg=GetArg();
 				parentid = arg.GetArgString(L"parentid");
 				adid = arg.GetArgString(L"adid");
 			}
diff --git a/jrj/project/business/Public/memo.edit.new.cpp b/jrj/project/business/Public/memo.edit.new.cpp
new file mode 100644
index 0000000..f9efb1f
--- /dev/null
+++ b/jrj/project/business/Public/memo.edit.new.cpp
Binary files differ
diff --git a/jrj/project/business/Public/message.business.cpp b/jrj/project/business/Public/message.business.cpp
new file mode 100644
index 0000000..83fd2aa
--- /dev/null
+++ b/jrj/project/business/Public/message.business.cpp
Binary files differ
diff --git a/jrj/project/business/Public/message.supplier.cpp b/jrj/project/business/Public/message.supplier.cpp
new file mode 100644
index 0000000..a1ea747
--- /dev/null
+++ b/jrj/project/business/Public/message.supplier.cpp
Binary files differ
diff --git a/jrj/project/business/SO/Apply.SOItem.cpp b/jrj/project/business/SO/Apply.SOItem.cpp
new file mode 100644
index 0000000..d6d273b
--- /dev/null
+++ b/jrj/project/business/SO/Apply.SOItem.cpp
@@ -0,0 +1,297 @@
+#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) ApplySOItem : public xframe
+	{
+	public:
+		ApplySOItem(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+	public:
+		static ApplySOItem* CreateInstance(void* implPtr, void* hWnd)
+		{
+			ApplySOItem* pWin = new ApplySOItem(implPtr, (HWND)hWnd);
+			return pWin;
+		}
+
+	public:
+		xdwgrid	dw_list;
+		xnode	m_agentNode;	//Agent Condition
+
+		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 ProcessUsedArg(xaserverarg arg)
+		{
+			xstring EntityIDList = L"";
+			int ll_row = dw_list.GetNextSelectRow(1);
+			while (ll_row > 0 && ll_row <= dw_list.GetRowCount())
+			{
+				xstring id = dw_list.GetGuid(ll_row);
+				if (EntityIDList == L"") EntityIDList = id; else EntityIDList += L",L" + id;
+				ll_row = dw_list.GetNextSelectRow(ll_row + 1);
+			}
+			if (EntityIDList != L"") arg.AddArg(L"EntityID", EntityIDList);
+			//alert(EntityIDList);
+			return 1;
+		}
+
+		xstring GetEntityName(int pr)
+		{
+			return L"SaleItem3";
+		}
+
+		xstring GetEntityID(int pr)
+		{
+			int row = dw_list.GetRow();
+			xstring id = dw_list.GetGuid(row);
+			return id;
+		}
+
+		int ViewUpdate(int pr, xstring updateItem, xaserverarg  arg)
+		{
+			if (updateItem == L"del")
+			{
+				int DelRow = dw_list.GetRow();
+				dw_list.DeleteRow(DelRow);
+				return 1;
+			}
+			else if (updateItem == L"setstate")
+			{
+				int row = dw_list.GetRow();
+				if (row < 1) return 1;
+
+				if (arg.GetArgString(L"billstatus") != L"")
+				{
+					xstring billstatus = arg.GetArgString(L"billstatus");
+					xstring statusName = GetBillStatusName(billstatus);
+					dw_list.SetItemString(row, L"ChkState", billstatus);
+					dw_list.SetItemDisplayString(row, L"ChkState", statusName);
+				}
+				dw_list.Redraw();
+			}
+			return 1;
+		}
+
+		//焦点激活处理函数
+		int OnSetFocus(TEvent* evt, LPARAM p)
+		{
+			//重置工具条
+			SetAgent();
+			return 1;
+		}
+
+
+		/*
+		int OnApply()
+		{
+			int row =  dw_list.GetNextSelectRow(1);
+			if(row < 1) return 1;
+
+			while (row>0)
+			{
+				dw_list.SetItemString(row,L"ChkState",L"2");
+				row =  dw_list.GetNextSelectRow(row + 1);
+			}
+			if(OnSave()==1)
+			{
+				xaserverarg arg = new xaserverarg;
+				arg.setNativePointer(arg.CreateInstance());
+				xml x = new xml;
+				x.setNativePointer(x.CreateInstance());
+
+				arg.AddArg(L"FlowID",L"1A83D53D-DD12-4FDB-A274-FA8D5982AB53");
+				arg.AddArg(L"Category",L"PurchesItem3");
+				arg.AddArg(L"Reciever",L"admin");
+				arg.AddArg(L"Status",L"业务审核");
+
+				xaserverarg parg = GetParam();
+				xstring SONo = parg.GetArgString(L"SONo");
+
+				row =  dw_list.GetNextSelectRow(1);
+				while (row>0)
+				{
+					arg.AddArg(L"EntityID",dw_list.GetGuid(row));
+					arg.AddArg(L"EntityNo",dw_list.GetItemString(row,L"GoodsNo"));
+					arg.AddArg(L"Subject",L"请核准订单"+SONo+L"采购数据,货号为"+dw_list.GetItemString(row,L"GoodsNo"));
+
+					if(url::get(L"/sale/data/PurchaseOrder/task/add", arg.GetString(),x)!=1)
+					{
+						xstring error = x.GetXmlDoc().text;
+						alert(error);
+						return -1;
+					}else
+					{
+						trace(x.GetXml());
+					}
+					row =  dw_list.GetNextSelectRow(row + 1);
+				}
+
+				alert(L"提交成功");
+			}
+			return 1;
+		}
+		*/
+		int OnAskGoodsNo()
+		{
+			int rowCount = dw_list.GetRowCount();
+			xstring skunos = L"";
+			xstring GoodsNo1 = dw_list.GetItemString(dw_list.GetRow(), L"GoodsNo");
+			xstring GoodsNo2 = GoodsNo1.mid(0, 1);
+			xstring GoodsNo3 = GoodsNo1.mid(1, 1);
+			xstring GoodsNo4 = GoodsNo1.mid(2, 1);
+
+			for (int i = 1; i <= rowCount; i++)
+			{
+				if (dw_list.GetItemString(i, L"SKUNo") != L"" && dw_list.GetItemString(i, L"GoodsNo") == L"" || GoodsNo1.find(L"N") >= 0
+					|| GoodsNo1.find(L"n") >= 0 || GoodsNo4.isNumber() == false && GoodsNo2.isNumber() == true && GoodsNo3.isNumber() == true)
+				{
+					if (skunos == L"")
+						skunos = dw_list.GetItemString(i, L"SKUNo");
+					else
+						skunos += L",L" + dw_list.GetItemString(i, L"SKUNo");
+				}
+			}
+			xaserverarg arg ;
+			arg.AddArg(L"SKUNoList", skunos);
+			OpenWindow(L"dev:xpage[Product.FetchNo.vx]", arg);
+			return 1;
+		}
+		//命令发布函数
+		int OnCmdDispatch(xstring comdid)
+		{
+			if (comdid == L"xmCancel")
+			{
+				CloseWindow();
+				return 1;
+			}
+			else if (comdid == L"xmAskGoodsNo")
+			{
+				OnAskGoodsNo();
+			}
+			//else if(comdid==L"xmApply") return OnApply();
+			else if (comdid.find(L"action:", 0) >= 0)
+			{
+				xstring GoodsNo = dw_list.GetItemString(dw_list.GetRow(), L"GoodsNo");
+				xstring GoodsNo2 = GoodsNo.mid(0, 2);
+				xstring GoodsNo4 = GoodsNo.mid(2, 1);
+
+				if (GoodsNo == L"")
+				{
+					alert(L"公司货号未指定");
+					return 0;
+				}
+				if (GoodsNo.find(L"N") >= 0 || GoodsNo.find(L"n") >= 0) {
+					alert(L"公司货号带有N");
+					return 0;
+				}
+				if (GoodsNo4 >= L"A" && GoodsNo4 <= L"z" && GoodsNo2 >= L"22" && GoodsNo2 <= L"99")
+				{
+					alert(L"公司货号为新品货号");
+					return 0;
+				}
+				xstring CType = dw_list.GetItemString(dw_list.GetRow(), L"CType");
+
+				if (CType == L"")
+				{
+					alert(L"客户合同附件未上传!");
+					return 0;
+				}
+				int ret = ProcessFlowAction(comdid, 1);
+				return ret;
+			}
+			return 0;
+		}
+
+		//命令处理事件
+		int OnXCommand(TEvent* evt, LPARAM p)
+		{
+			return OnCmdDispatch(evt->xcommand.pStrID);
+		}
+
+		int OnAttachEvent()
+		{
+			//绑定工具条点击事件
+			AttachEvent(L"WM_XCOMMAND", (FEvent)&ApplySOItem::OnXCommand);
+			//获取焦点事件,用于重置工具条
+			//AttachEvent(L"WM_SETFOCUS",OnSetFocus);
+			return 1;
+		}
+
+		int  OnRetrieve()
+		{
+			xml x;
+			xaserverarg arg=GetArg();
+
+			arg.AddArg(L"id", arg.GetArgString(L"EntityNo"));
+			if (getUrl(L"/sale/data/SaleOrder/maint/item", arg.GetString(), x) != 1)
+			{
+				//trace(x.GetXmlDoc().text);
+				return -1;
+			}
+			else
+			{
+				dw_list.Retrieve(x);
+				dw_list.Redraw();
+			}
+			dw_list.SetReadOnly(true);
+			dw_list.SetSelectionMode(3);
+
+			return 1;
+		}
+
+		int onload()
+		{
+			
+
+			dw_list = GetControl(L"dw_list");
+			dw_list.openUrl(L"/sale/view/SaleOrder/template/item");
+			dw_list.SetReadOnly(true);
+			dw_list.SetColumnState(L"EnquiryPriceListID", false);
+			dw_list.SetColumnState(L"ItemID", false);
+			dw_list.SetColumnState(L"LineType", false);
+			dw_list.SetColumnState(L"Assortment", false);
+			dw_list.SetColumnState(L"ClassifyID", false);
+			dw_list.SetColumnState(L"UnitFreight", false);
+			dw_list.SetColumnState(L"CName", false);
+			dw_list.SetColumnState(L"QuoteLineID", false);
+			dw_list.SetColumnState(L"POSupplierID", false);
+			dw_list.SetColumnState(L"Submitter", false);
+			dw_list.SetColumnState(L"ScheduleShipDate", false);
+			OnAttachEvent();
+
+			SetArg();
+			OnRetrieve();
+
+			return 1;
+		}
+
+		int onloaded()
+		{
+			//SetAgent();			
+
+			return 1;
+		}
+	};
\ No newline at end of file
diff --git a/jrj/project/business/SO/Product.FetchNo.cpp b/jrj/project/business/SO/Product.FetchNo.cpp
new file mode 100644
index 0000000..4b837d9
--- /dev/null
+++ b/jrj/project/business/SO/Product.FetchNo.cpp
@@ -0,0 +1,336 @@
+#include <wobject/xstring.hpp>
+#include <xcontrol/xtreeview.hpp>
+#include <xcontrol/xdwgrid.hpp>
+#include <xcontrol/xcell.hpp>
+
+
+#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp"
+#include "viewobject/view.base.hpp"
+
+using xml = KXMLDOMDocument;
+	class  __declspec(dllexport)  ProductFetchNoWin : public xframe
+	{
+	public:
+		xdwgrid	dw_list;
+
+		xnode	m_agentNode;	//Agent Condition
+	public:
+		ProductFetchNoWin(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+	public:
+		static ProductFetchNoWin* CreateInstance(void* implPtr, void* hWnd)
+		{
+			ProductFetchNoWin* pWin = new ProductFetchNoWin(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 OnRowChanged(TEvent* evt, LPARAM p)
+		{
+			DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh;
+			int row = hdr.row;
+
+			/*
+			htmlctrl xs = GetControl(L"html_detail");
+			xstring html = makeHtml(row);
+			xs.SetContent(html);
+			xs.Redraw();
+
+			xstring id = g_xdoc_product.getData(0,L"data/Item",row,L"@guid");
+			OnShowImage(id);
+			*/
+
+			return 1;
+		}
+
+		//焦点激活处理函数
+		int OnSetFocus(TEvent* evt, LPARAM p)
+		{
+			//重置工具条
+			//SetAgent();
+			return 1;
+		}
+
+		int SendNotice()
+		{
+			xaserverarg arg;
+			
+			if (dw_list.GetRowCount() < 1) return 1;
+			xstring Subject = L"编号:" + dw_list.GetItemString(dw_list.GetRow(), L"SKUNo") + L"   品名:" + dw_list.GetItemString(dw_list.GetRow(), L"CName") + L",申请货号";
+			xstring EntityID = dw_list.GetItemString(dw_list.GetRow(), L"SKUID");
+			xstring EntityNo = dw_list.GetItemString(dw_list.GetRow(), L"SKUNo");
+			xstring Category = L"货号申请";
+			xstring Reciever = L"00908";
+			xstring Content = L"";
+			//alert(L"EntityID:"+EntityID);
+			xml x = ViewObject::AddMessage(Category, Reciever, EntityNo, EntityID, Subject, Content);
+			return 1;
+		}
+
+		int OnSubmit()
+		{
+			dw_list = GetControl(L"dw_list");
+			if (dw_list.GetRowCount() < 1) return 0;
+			xml x;
+			
+			dw_list.DwUpdateAllToEx(x);
+			xstring error = L"";
+			xaserverarg arg;
+			
+			arg.AddArg(L"content", x.xml());
+			if (xurl::get(L"/sale/data/ProductLibrary3/update/product/askgoodsno", arg.GetString(), x) != 1)
+			{
+				xstring error = x.text();
+				trace(error);
+			}
+			else
+			{
+				if (error.find(L"error") >= 0)
+					alert(L"提交失败");
+				else
+					alert(L"提交成功!");
+				SendNotice();
+			}
+			return 1;
+		}
+
+		/*
+		xstring makeHtml(int row)
+		{
+			xstring id = g_xdoc_product.getData(0,L"data/Item",row,L"@guid");
+			xml x = GetGoodsPropList(id);
+			xml x1 = GetGoodsPropListEx(id);
+
+			xstring html=L"<html><style> .text{ font-weight:400} .label { font-weight:400;}</style><body style='margin:2;background-color:#ccdccc none #f0f0f0 none'>";
+			html += L"<div ><span style='font-weight:700;width:50;font-size:10pt'  >编号:</span><span  style='width:90;font-size:10pt'>" + dw_list.GetItemString(row,L"SKUNo")+
+						"</span> <span style='font-weight:700;width:50;font-size:10pt' >类项:</span><span  style='width:90;font-size:10pt'>" + dw_list.GetItemString(row,L"RefNo")+
+						"</span></div>";
+			html +=  L"<div ><span style='font-weight:700;width:50;font-size:10pt'  >公司型号:</span><span  style='width:90;font-size:10pt'>" + dw_list.GetItemString(row,L"GoodsNo")+
+						"</span></div>" ;
+			html +=  L"<div ><span style='font-weight:700;width:50;font-size:10pt'  >品名:</span><span  style='width:90;font-size:10pt'>" + dw_list.GetItemString(row,L"CName")+
+						"</span></div>" ;
+			if(dw_list.GetItemString(row,L"CSpec")!=L"")
+				html +=  L"<div ><span style='font-weight:700;width:50;font-size:10pt'  >规格:</span><span  style='width:90;font-size:10pt'>" + dw_list.GetItemString(row,L"CSpec")+
+							"</span></div>" ;
+
+			KXMLDOMNodeList fieldsEx = x1.GetXmlDoc().selectNodes(L"data/field");
+			xstring ls_detail=L"";
+			xstring ls_item =L"";
+			xstring name;
+			xstring label;
+			int len = fieldsEx.length;
+			int i= 0;
+
+			for(i=0;i<len; true)
+			{
+				int cnt  = 0;
+				ls_item = L"";
+				while(cnt < 2)
+				{
+					name = fieldsEx.item(i).selectSingleNode(L"@name").text;
+					label  = fieldsEx.item(i).selectSingleNode(L"@label").text;
+					ls_item += L"<td>" + label + L"</td>" + L"<td style='text-align:center'>" + g_xdoc_product.getData(0,L"data/Item",row,name) + L"</td>" ;
+					cnt++;
+					i++;
+					if(i ==len)break;
+				}
+				ls_detail += L"<tr>" + ls_item + L"</tr>";
+			}
+			html +=  L"<div style='margin-left:8px;margin-right:16px;'>" +
+						+L"<table><colgroup span='1' width='70'/><colgroup span='1' width='120'/><colgroup span='1' width='70'/><colgroup span='1' width='120'/>"
+						+ ls_detail
+						+L"</table>"
+						+L"</div>" ;
+
+			xstring ls_star=L"";
+			KXMLDOMNodeList fields  = x().selectNodes(L"data/field");
+			len = fields.length;
+
+			ls_detail = L"";
+			if(len > 0)
+				html +=  L"<div ><span style='font-weight:700;width:50;font-size:10pt'  >技术要求:</span></div>" ;
+			for(i=0;i<len; true)
+			{
+				ls_item=L"";
+
+				int count = 0;
+				while(count < 2)
+				{
+					name = fields.item(i).selectSingleNode(L"@name").text;
+					label  = fields.item(i).selectSingleNode(L"@label").text;
+					if(name==L"QualityTerm" || name==L"PackTerm" || label==L"质量" || label==L"包装质量" || label==L"技术要求")
+					{
+						i++;
+						if(i >= len)count = 2;
+						continue;
+					}
+					else if(g_xdoc_product.getData(0,L"data/Item",row,name)==L"")
+					{
+						KXMLDOMNodeList options = fields.item(i).selectNodes(L"item");
+						int tlen = options.length;
+						xstring terms = L"" ;
+						for(int k=0; k<tlen; k++)
+						{
+							if(options.item(k).text)
+							{
+								if(k>0) terms += L", L";
+								terms += L"[" + options.item(k).text +L"]";
+							}
+						}
+						ls_star += L"<div ><span style='font-weight:700;width:50;font-size:10pt'  >" + label +L"*:</span><span  style='width:90;font-size:10pt'>" + terms + L"</span></div>" ;
+					}else
+					{
+						ls_item = L"<td>" + label + L"</td>" + L"<td>" + g_xdoc_product.getData(0,L"data/Item",row,name) + L"</td>" ;
+						count++;
+					}
+					i++;
+					if(i >= len)count = 2;
+				}
+				ls_item = L"<tr>" + ls_item + L"</tr>";
+				ls_detail += ls_item;
+			}
+
+			html +=  L"<div style='margin-left:8px;margin-right:16px;'>" +
+						+L"<table><colgroup span='1' width='70'/><colgroup span='1' width='120'/><colgroup span='1' width='70'/><colgroup span='1' width='120'/>"
+						+ ls_detail
+						+L"</table>"
+						+L"</div>" ;
+			if(dw_list.GetItemString(row,L"QualityTerm")!=L"")
+			{
+				html +=  L"<div style='height:12px'/>";
+				html +=  L"<div ><span style='font-weight:700;width:50;font-size:10pt'  >质量:</span></div>" ;
+				html +=  L"<div ><span style='margin-left:8px;margin-right:16px;font-weight:400;font-size:10pt'  >" + dw_list.GetItemString(row,L"QualityTerm") +  L"</span></div>" ;
+			}
+
+			if(dw_list.GetItemString(row,L"PackTerm")!=L"")
+			{
+				html +=  L"<div style='height:12px'/>";
+				html +=  L"<div ><span style='font-weight:700;width:50;font-size:10pt'  >包装质量:</span></div>" ;
+				html +=  L"<div ><span style='margin-left:8px;margin-right:16px;font-weight:400;font-size:10pt' >" + dw_list.GetItemString(row,L"PackTerm") +  L"</span></div>" ;
+			}
+
+			if(g_xdoc_product.getData(0,L"data/Item",row,L"Remark")!=L"")
+			{
+				//html +=  L"<div style='height:12px'/>";
+				html +=  L"<div ><span style='font-weight:700;width:50;font-size:10pt'  >备注:</span></div>" ;
+				html +=  L"<div ><span style='margin-left:8px;margin-right:16px;font-weight:400;font-size:10pt' >" + g_xdoc_product.getData(0,L"data/Item",row,L"Remark") +  L"</span></div>" ;
+			}
+
+			html +=  L"<div style='height:24px'/>";
+
+			//星标项
+			html += ls_star;
+
+
+			html += L"</body></html>";
+			//trace(html);
+			return html;
+		}
+		*/
+
+		//命令发布函数
+		int OnCmdDispatch(xstring comdid)
+		{
+			if (comdid == L"xmSubmit")
+			{
+				return OnSubmit();
+			}
+			if (comdid == L"xmCancel")
+			{
+				CloseWindow();
+				return 1;
+			}
+			return 0;
+		}
+
+		//命令处理事件
+		int OnXCommand(TEvent* evt, LPARAM p)
+		{
+			return OnCmdDispatch(evt->xcommand.pStrID);
+		}
+
+		int OnAttachEvent()
+		{
+			AttachEvent(L"dw_list", L"DWV_ROWFOCUSCHANGED", (FEvent)&ProductFetchNoWin::OnRowChanged);
+			//绑定工具条点击事件
+			AttachEvent(L"WM_XCOMMAND", (FEvent)&ProductFetchNoWin::OnXCommand);
+			//获取焦点事件,用于重置工具条
+			AttachEvent(L"WM_SETFOCUS", (FEvent)&ProductFetchNoWin::OnSetFocus);
+		}
+
+		/*
+		int  OnRetrieve()
+		{
+			xml x = new.xml();
+			x.setNativePointer(xml::CreateInstance());
+			xaserverarg arg = new xaserverarg;
+			arg.setNativePointer(arg.CreateInstance());
+			arg.AddArg(L"xxx",L"xxx");
+			if (getUrl(L"",arg.GetString(),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.SetDataObject(ProductLibraryView::GetMaintListForm3(L"").GetXmlDoc());
+			dw_list.SetColumnState(L"SKUID", false);
+			dw_list.SetColumnState(L"category1", false);
+			dw_list.SetColumnState(L"Submitter1", false);
+
+			if (GetWinParam())
+			{
+				xaserverarg arg;
+				xml x;
+				
+				if (xurl::get(L"/sale/data/ProductLibrary3/data/list/skunolist", arg.GetString(), x) != 1)
+				{
+					xstring error = x.text();
+					trace(error);
+				}
+				else
+				{
+					//alert(x.GetXml());
+					dw_list.Retrieve(x);
+				}
+			}
+			OnAttachEvent();
+			dw_list.SetReadOnly(true);
+
+			return 1;
+		}
+
+		int onloaded()
+		{
+			//SetAgent();			
+
+			return 1;
+		}
+	};
\ No newline at end of file
diff --git a/jrj/project/business/SO/maint.Document.SO3.v3.cpp b/jrj/project/business/SO/maint.Document.SO3.v3.cpp
index e35dd11..321df57 100644
--- a/jrj/project/business/SO/maint.Document.SO3.v3.cpp
+++ b/jrj/project/business/SO/maint.Document.SO3.v3.cpp
@@ -454,7 +454,7 @@
 
 			if (GetWinParam())
 			{
-				xaserverarg arg;
+				xaserverarg arg= GetArg();
 				entityid = arg.GetArgString(L"entityid");
 				Type = arg.GetArgString(L"Type");
 				ApprovalStatus = arg.GetArgString(L"ApprovalStatus");
diff --git a/jrj/project/business/SO3.list.cpp b/jrj/project/business/SO3.list.cpp
index 6056ff2..c75d8cc 100644
--- a/jrj/project/business/SO3.list.cpp
+++ b/jrj/project/business/SO3.list.cpp
@@ -285,12 +285,12 @@
 		return 1;
 	}
 
-	int PreOnCmdDispatch(string comdid)
+	int PreOnCmdDispatch(xstring comdid)
 	{
 		if (comdid == L"action:bill.new")
 		{
-			string s = publiccode::GetUser().id;
-			string no = publiccode::GetUser().no;
+			xstring s = publiccode::GetUser().id;
+			xstring no = publiccode::GetUser().no;
 			if (no != L"00303" && no != L"admin")
 			{
 				KXMLDOMDocument supplier_x = ViewObject::RetrieveData(GetServerUrl(),L"/sale/data/SupplierV3/entity/FindBySaleType", L"id", s);
@@ -306,7 +306,7 @@
 		}
 		if (comdid == L"action:bill.annex")
 		{
-			string deptname = publiccode::GetUser().deptname;
+			xstring deptname = publiccode::GetUser().deptname;
 			if (deptname == L"采购部")
 			{
 				return 1;
diff --git a/jrj/xframe/vbusiness/vframe/listwin.vframe.vbusiness.hpp b/jrj/xframe/vbusiness/vframe/listwin.vframe.vbusiness.hpp
index 72246ac..7d3007d 100644
--- a/jrj/xframe/vbusiness/vframe/listwin.vframe.vbusiness.hpp
+++ b/jrj/xframe/vbusiness/vframe/listwin.vframe.vbusiness.hpp
@@ -406,13 +406,13 @@
 		return 1;
 	}
 
-	virtual int PreOnCmdDispatch(string comdid)
+	virtual int PreOnCmdDispatch(xstring comdid)
 	{
 		//返回0——不在执行以下代码;返回其他——执行以下代码。
 		return 1;
 	}
 
-	virtual int PostOnCmdDispatch(string comdid)
+	virtual int PostOnCmdDispatch(xstring comdid)
 	{
 		//	trace("test");
 		return 1;

--
Gitblit v1.9.3