From ed84dae6164bdddda634aa7cf2e04b16e8838717 Mon Sep 17 00:00:00 2001
From: xj qian <qianxj15@sina.com>
Date: 星期四, 11 七月 2024 18:53:05 +0800
Subject: [PATCH] update items
---
jrj/project/business/File/trade.help3.cpp | 232 ++++++++++++
jrj/project/business/File/trade.helpEx.cpp | 245 ++++++++++++
jrj/project/total3/ViewTotalWin.cpp | 6
jrj/project/business/Supplier/Inspection.Supplie.cpp | 0
jrj/ext-jrj/ext-jrj.vcxproj | 7
jrj/project/business/File/trade.document3.cpp | 504 ++++++++++++++++++++++++++
jrj/project/total3/ViewTotalArgWin.cpp | 137 +++++++
jrj/ext-jrj/ext-jrj.vcxproj.filters | 9
jrj/project/business/ProductSample/SampleBarcodePrint.cpp | 0
9 files changed, 1,133 insertions(+), 7 deletions(-)
diff --git a/jrj/ext-jrj/ext-jrj.vcxproj b/jrj/ext-jrj/ext-jrj.vcxproj
index 7a31365..05b668a 100644
--- a/jrj/ext-jrj/ext-jrj.vcxproj
+++ b/jrj/ext-jrj/ext-jrj.vcxproj
@@ -127,7 +127,7 @@
<SubSystem>Windows</SubSystem>
<GenerateDebugInformation>true</GenerateDebugInformation>
<EnableUAC>false</EnableUAC>
- <AdditionalDependencies>xarch.shape.lib;xarch.base.lib;xarch.util.lib;xarch.network.lib;xarch.xframe.lib;xarch.xcontrol.lib;xoffice.xcell.lib;xoffice.xgrid.lib;xoffice.xreport.lib;xoffice.frame.lib;shlwapi.lib;xoffice.xflow.lib;comsuppw.lib;tsclib.lib;%(AdditionalDependencies);$(CoreLibraryDependencies)</AdditionalDependencies>
+ <AdditionalDependencies>xarch.shape.lib;xarch.base.lib;xarch.util.lib;xarch.network.lib;xarch.xframe.lib;xarch.xcontrol.lib;xoffice.xcell.lib;xoffice.xgrid.lib;xoffice.xreport.lib;xoffice.frame.lib;shlwapi.lib;xoffice.xflow.lib;comsuppw.lib;%(AdditionalDependencies);$(CoreLibraryDependencies)</AdditionalDependencies>
<AdditionalLibraryDirectories>D:\xclient64</AdditionalLibraryDirectories>
</Link>
<PostBuildEvent>
@@ -520,7 +520,9 @@
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild>
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">false</ExcludedFromBuild>
</ClCompile>
- <ClCompile Include="..\project\business\ProductSample\OutstoreSample3Win.cpp" />
+ <ClCompile Include="..\project\business\ProductSample\OutstoreSample3Win.cpp">
+ <ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild>
+ </ClCompile>
<ClCompile Include="..\project\business\ProductSample\SampleBarcodePrint.cpp" />
<ClCompile Include="..\project\business\Public\GroupManagerList.cpp">
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild>
@@ -677,6 +679,7 @@
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild>
</ClCompile>
<ClCompile Include="..\project\start.vframe.vbusiness.cpp" />
+ <ClCompile Include="..\project\total3\ViewTotalArgWin.cpp" />
<ClCompile Include="..\project\total3\ViewTotalWin.cpp" />
<ClCompile Include="..\project\tradedocument\DocFileSaveDlg.cpp" />
<ClCompile Include="..\project\tradedocument\DocSelectDlg.cpp" />
diff --git a/jrj/ext-jrj/ext-jrj.vcxproj.filters b/jrj/ext-jrj/ext-jrj.vcxproj.filters
index c78f55b..6fb50d3 100644
--- a/jrj/ext-jrj/ext-jrj.vcxproj.filters
+++ b/jrj/ext-jrj/ext-jrj.vcxproj.filters
@@ -800,9 +800,6 @@
<ClCompile Include="..\project\business\Enquiry\ViewPictures.cpp">
<Filter>project\business\Enquiry</Filter>
</ClCompile>
- <ClCompile Include="..\project\business\QuoteFile.cpp">
- <Filter>婧愭枃浠�</Filter>
- </ClCompile>
<ClCompile Include="..\project\business\ProductSample\InstoreSample3Win.cpp">
<Filter>project\business\ProductSample</Filter>
</ClCompile>
@@ -815,5 +812,11 @@
<ClCompile Include="..\project\business\ProductSample\CheckOut.instore.Sample.cpp">
<Filter>project\business\ProductSample</Filter>
</ClCompile>
+ <ClCompile Include="..\project\total3\ViewTotalArgWin.cpp">
+ <Filter>vbusiness\total</Filter>
+ </ClCompile>
+ <ClCompile Include="..\project\business\QuoteFile.cpp">
+ <Filter>project\business</Filter>
+ </ClCompile>
</ItemGroup>
</Project>
\ No newline at end of file
diff --git a/jrj/project/business/File/trade.document3.cpp b/jrj/project/business/File/trade.document3.cpp
new file mode 100644
index 0000000..f23fbc3
--- /dev/null
+++ b/jrj/project/business/File/trade.document3.cpp
@@ -0,0 +1,504 @@
+#include <wobject/xstring.hpp>
+#include <xcontrol/xtreeview.hpp>
+#include <xcontrol/xdwgrid.hpp>
+#include <xcontrol/xlistview.hpp>
+
+#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp"
+#include "viewobject/view.base.hpp"
+
+using xml = KXMLDOMDocument;
+ class __declspec(dllexport) TDocumentWin : public xframe
+ {
+ public:
+ //xdwgrid dw_list;
+ xtreeview tv_folder;
+ xlistview lv_view;
+ xnode m_agentNode; //Agent Condition
+ int columnCount;
+ public:
+ TDocumentWin(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+ public:
+ static TDocumentWin* CreateInstance(void* implPtr, void* hWnd)
+ {
+ TDocumentWin* pWin = new TDocumentWin(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 OnListViewDoubleClicked(TEvent* evt, LPARAM param)
+ {
+ //重置工具条
+ //SetAgent();
+ return OnDocumentOpen();
+ }
+
+ int OnDocumentOpen()
+ {
+ int LVNI_ALL = 0x0000;
+ int LVNI_FOCUSED = 0x0001;
+ int LVNI_SELECTED = 0x0002;
+ int LVNI_CUT = 0x0004;
+ int LVNI_DROPHILITED = 0x0008;
+
+ int nItem = lv_view.GetNextItem(-1, LVNI_FOCUSED);
+ if (nItem < 0) return 1;
+
+ int LVIF_PARAM = 0x0004;
+
+ lvitem lvItem;
+ lvItem.iItem = nItem;
+ lvItem.iSubItem = 0;
+ lvItem.mask = LVIF_PARAM;
+
+ lv_view.GetItem(lvItem);
+ KXMLDOMElement ele =lvItem.lParam;
+
+ xstring src = ele.getAttribute(L"url");
+ xstring file = L"";
+ if (src.find(L"/file/") > 0) file = src.mid(src.find(L"/file/") + 6, 9999);
+ if (file.find(L"/file/") >= 0) file = file.mid(file.find(L"/file/") + 6, 9999);
+ if (file.find(L"file/") >= 0) file = file.mid(file.find(L"file/") + 5, 9999);
+ if (file == L"") return 1;
+ //alert(file);
+ xstring name = ele.getAttribute(L"caption");
+ /*
+ const xstring d = m_Html.GetData(p.object);
+ if(d == L"") return -1;
+ xstring file = d.mid(0, d.find(L"|##@@|",0));
+ xstring name = d.mid(d.find(L"|##@@|",0)+6, d.length());
+ */
+
+ xaserver::CreateDirectory(L"C:/Temp");
+ xstring str = file.left(2);
+ xstring ext = L"";
+ if (name.find(L".") >= 0) ext = name.mid(name.find(L"."), name.length());
+ xstring sfile = file;// file.left(file.length() - 4);
+ //trace(L"--"+ext +L" " + L"/business/attachment/"+str+L"/"+ file);
+ //int openRet = xaserver::DownLoadFile(GetServerUrl(),L"/business/attachment/"+str+L"/"+ file,name,L"C:/Temp/"+name);
+ int openRet = xaserver::DownLoadFile(GetServerUrl(), L"/business/attachment/" + str + L"/" + file + L".jpg", L"", L"C:/Temp/" + sfile + ext);
+
+ //alert(L"/business/attachment/"+str+L"/"+ file+L".jpg");
+ if (openRet < 0)
+ {
+ alert(L"文件打开失败1!");
+ return -1;
+ }
+ //openRet = win32::ShellExecute(0,L"open",L"C:/Temp/"+name,L"",L"",5);
+ openRet = ShellExecuteW(0, L"open", L"C:/Temp/" + sfile + ext, L"", L"", 5);
+ if (openRet < 32)
+ {
+ alert(L"文件打开失败2!");
+ return -1;
+ }
+
+ return -1;
+ }
+
+ int OnAddAttachment()
+ {
+ xstring sguid = publiccode::GetGuid();
+ xstring sname = sguid;
+ xstring str = sname.mid(0, 2);
+ str = str.toUpper();
+ xstring suri = L"attachment" + str;
+ xstring ret = xaserver::UploadFile(suri, sname + L".jpg", GetHWND(), L"", false);
+ if (ret == L"-1")
+ {
+ alert(L"上传的文件没选择!");
+ return 0;
+ }
+ else
+ {
+ while (ret.find(L"\\", 0) >= 0)
+ ret = ret.mid(ret.find(L"\\", 0) + 1, 9999);
+
+
+ HTREEITEM h = tv_folder.GetSelectedItem();
+ KXMLDOMElement ele = tv_folder.GetItemData(h);
+ xstring myurl = ele.getAttribute(L"url");
+ //alert(myurl);
+
+ xml x ;
+
+ xaserverarg args;
+ args.setNativePointer(args.CreateInstance());
+ args.AddArg(L"myurl", myurl);
+ args.AddArg(L"name", ret);
+ args.AddArg(L"filepath", sname);
+ args.AddArg(L"fileext", L"");
+ args.AddArg(L"filesource", ret);
+
+ xml x1 = ViewObject::RetrieveData(L"/sale/data/TDocument3/attachment/GetFileFormat", L"Name", ret);
+ KXMLDOMNodeList items = x1.selectNodes(L"data/Item");
+ KXMLDOMNode t = items.item(0);
+ xstring FileFormat = L"";
+ if (t.selectSingleNode(L"FileFormat"))FileFormat = t.selectSingleNode(L"FileFormat").text();
+ if (FileFormat != L"pdf" && FileFormat != L"PDF" && FileFormat != L"mp4" && FileFormat != L"avi" && FileFormat != L"wmv" && FileFormat != L"mpg"
+ && FileFormat != L"mpeg" && FileFormat != L"mov" && FileFormat != L"rm" && FileFormat != L"ram" && FileFormat != L"swf" && FileFormat != L"flv")
+ {
+ alert(L"文件格式错误,请上传PDF文档或者视频!");
+ return 0;
+ }
+
+ if (xurl::get(L"/sale/data/TDocument3/attachment/add", args.GetString(), x) != 1)
+ {
+ alert(L"保存出错了!");
+ return 0;
+ }
+ else
+ {
+ alert(x.text());
+ //OnRetrieve();
+ }
+ }
+ return 0;
+ }
+
+ int OnDeleteFile()
+ {
+ int LVNI_ALL = 0x0000;
+ int LVNI_FOCUSED = 0x0001;
+ int LVNI_SELECTED = 0x0002;
+ int LVNI_CUT = 0x0004;
+ int LVNI_DROPHILITED = 0x0008;
+
+ int nItem = lv_view.GetNextItem(-1, LVNI_FOCUSED);
+ if (nItem < 0) return 1;
+
+ int LVIF_PARAM = 0x0004;
+
+ lvitem lvItem;
+ lvItem.iItem = nItem;
+ lvItem.iSubItem = 0;
+ lvItem.mask = LVIF_PARAM;
+
+ lv_view.GetItem(lvItem);
+ KXMLDOMElement ele = lvItem.lParam ;
+
+ xstring src = ele.getAttribute(L"url");
+ xstring file = L"";
+ if (src.find(L"/file/") > 0) file = src.mid(src.find(L"/file/") + 6, 9999);
+ if (file.find(L"/file/") >= 0) file = file.mid(file.find(L"/file/") + 6, 9999);
+ if (file.find(L"file/") >= 0) file = file.mid(file.find(L"file/") + 5, 9999);
+ if (file == L"") return 1;
+
+ xstring name = ele.getAttribute(L"caption");
+ if (MessageBox(GetHWND(), L"确定要删除文件" + name + L"?", L"提示", 1) == 2)
+ return 0;
+
+ xaserverarg arg ;
+
+ arg.AddArg(L"filepath", file);
+ xml x ;
+ if (xurl::get(L"/sale/data/TDocument3/file/delete", arg.GetString(), x) != 1)
+ {
+ alert(L"删除出错了!");
+ return 1;
+ }
+ else
+ {
+ //alert(x.GetXmlDoc().text);
+ lv_view.DeleteItem(nItem);
+ }
+
+ return 1;
+ }
+
+ //命令发布函数
+ int OnCmdDispatch(xstring comdid)
+ {
+ xstring userno = publiccode::GetUser().no;
+ HTREEITEM h = tv_folder.GetSelectedItem();
+ KXMLDOMElement ele = tv_folder.GetItemData(h);
+ xstring caption = ele.getAttribute(L"caption");
+
+ if (comdid == L"xmUpload")
+ {
+
+ /* if(caption ==L"采购部" || caption ==L"跟单部" || caption ==L"业务部" ||caption ==L"公司共享" )
+ {
+
+ if(userno ==L"admin" || userno ==L"00301" || userno ==L"00601" || userno ==L"00701" )
+ {
+ OnAddAttachment();
+ }
+ }*/
+ /* if(caption ==L"业务部优秀案例" || caption ==L"采购部优秀案例" )
+ {*/
+
+ if (userno == L"admin" || userno == L"00301" || userno == L"00601" || userno == L"00701" || userno == L"00102" || userno == L"00201")
+ {
+ OnAddAttachment();
+ }
+ //}
+ return 1;
+ }
+ if (comdid == L"xmOpen")
+ {
+ return OnDocumentOpen();
+ }
+ if (comdid == L"xmDelete")
+ {
+ /*if(caption ==L"采购部" || caption ==L"跟单部" || caption ==L"外销部" ||caption ==L"公司共享" )
+ {
+
+ if(userno ==L"admin" || userno ==L"00301" || userno ==L"00601" || userno ==L"00701" )
+ {
+ OnDeleteFile();
+ }
+ }
+ if(caption ==L"业务部优秀案例" || caption ==L"采购部优秀案例" )
+ {*/
+
+
+ if (userno == L"admin" || userno == L"00301" || userno == L"00601" || userno == L"00701" || userno == L"00102" || userno == L"00201")
+ {
+ OnDeleteFile();
+ }
+ //}
+ return 1;
+ }
+ if (comdid == L"xmSearch")
+ {
+ OnRetrieve();
+ return 1;
+ }
+
+ return 0;
+ }
+
+ int OnRetrieve()
+ {
+ xstring urlEx = L"";
+ xcontrol xc = GetControl(L"frame:sle_search");
+ xstring Search = xc.GetText();
+ HTREEITEM h = tv_folder.GetSelectedItem();
+ KXMLDOMElement ele = tv_folder.GetItemData(h);
+ urlEx = ele.getAttribute(L"url");
+
+ trace(Search + L"******" + urlEx);
+ if (urlEx == L"")
+ {
+ alert(L"选择文件目录!");
+ return 1;
+ }
+ else
+ {
+ xaserverarg arg ;
+
+ arg.AddArg(L"url", urlEx);
+ arg.AddArg(L"Search", Search);
+
+ OpenWindow(L"dev:xpage[trade.helpEx.vx]", arg);
+ return 1;
+ }
+
+ return 1;
+ }
+
+ //命令处理事件
+ int OnXCommand(TEvent* evt, LPARAM p)
+ {
+ return OnCmdDispatch(evt->xcommand.pStrID);
+ }
+
+ int OnAttachEvent()
+ {
+ //绑定工具条点击事件
+ AttachEvent(L"WM_XCOMMAND", (FEvent)&TDocumentWin::OnXCommand);
+ //获取焦点事件,用于重置工具条
+ AttachEvent(L"WM_SETFOCUS", (FEvent)&TDocumentWin::OnSetFocus);
+ return 1;
+ }
+
+ int createSubTree(HTREEITEM h, KXMLDOMElement ele)
+ {
+ KXMLDOMNodeList nlist = ele.selectNodes(L"folder");
+ int i;
+ int s = nlist.length();
+ if (s > 0)
+ {
+ for (i = 0; i < s; i++)
+ {
+ KXMLDOMElement e = nlist.item(i);
+ xstring name = e.getAttribute(L"caption");
+ HTREEITEM hw = tv_folder.InsertChildItem(h, name, e, 15);
+ createSubTree(hw, e);
+ }
+ }
+ return 1;
+ }
+
+ int OnCreateTree()
+ {
+ xml x;
+ if (xurl::get(L"/sale/data/TDocument3/folder/root", L"", x) != 1)
+ {
+ return -1;
+ }
+ else
+ {
+ KXMLDOMNodeList nlist = x.selectNodes(L"folders/folder");
+ int len = nlist.length();
+
+ if (len > 0)
+ {
+ int i;
+ for (i = 0; i < len; i++)
+ {
+ KXMLDOMElement e = nlist.item(i);
+ xstring name = e.getAttribute(L"caption");
+ HTREEITEM h = tv_folder.InsertChildItem(0, name, e, 17);
+ createSubTree(h, e);
+ if (len == 1) tv_folder.ExpandItem(h);
+ }
+ tv_folder.ExpandItem(0);
+ }
+ }
+ return 1;
+ }
+
+
+ //树选择
+ int OnTreeSelChanged(TEvent* evt, LPARAM p)
+ {
+
+ lv_view.DeleteItemAll();
+
+
+ HTREEITEM h = tv_folder.GetSelectedItem();
+ KXMLDOMElement ele = tv_folder.GetItemData(h);
+
+
+ xstring name;
+ KXMLDOMElement e;
+ KXMLDOMNodeList nlist = ele.selectNodes(L"folder");
+
+ int i;
+ int s = nlist.length();
+ if (s > 0)
+ {
+ for (i = 0; i < s; i++)
+ {
+ e = nlist.item(i);
+ name = e.getAttribute(L"caption");
+ lv_view.InsertItemEx(0, name, 0,e);
+ }
+ }
+
+ xstring src = ele.getAttribute(L"url");
+ trace(L"\r\n" + src);
+ xml x = ViewObject::RetrieveData(L"/sale/data/TDocument3/folder/list", L"src", src);
+ if (x)
+ {
+ //alert(x.GetXml());
+ ele = x.documentElement();
+ nlist = ele.selectNodes(L"*");
+ s = nlist.length();
+ if (s > 0)
+ {
+ for (i = 0; i < s; i++)
+ {
+ e = nlist.item(i);
+ name = e.getAttribute(L"caption");
+ //lv_view.InsertItemEx(lv_view.GetId(),0,name,14,cast(e as int));
+ int nItem = lv_view.InsertItemEx(0, name, 23, e );
+
+ lv_view.SetItemText(nItem, 1, e.getAttribute(L"Creator"));
+ lv_view.SetItemText(nItem, 2, e.getAttribute(L"CreateDate"));
+
+ }
+ }
+ }
+ lv_view.Redraw();
+
+ return 1;
+ }
+
+ int SetListViewHeaderColumn(xstring Url)
+ {
+ const int LVCFMT_LEFT = 0;
+ for (int i = 0; i < 3; i++) lv_view.DeleteColumn(1);
+ //if(Url==L"")
+ //{
+ lv_view.InsertColumn(0, L"创建日期", LVCFMT_LEFT, 80, 0);
+ lv_view.InsertColumn(0, L"创建人员", LVCFMT_LEFT, 80, 0);
+ lv_view.InsertColumn(0, L"名称", 0, 180, 0);
+ columnCount = 3;
+ //}
+ return 1;
+ }
+
+ /*
+ 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.GetXmlDoc().text);
+ return -1;
+ }else
+ {
+ //dw_list.Retrieve(x);
+ //dw_list.Redraw();
+ }
+ return 1;
+ }
+ */
+
+ int onload()
+ {
+ tv_folder = GetControl(L"tv_folder");
+ lv_view = GetControl(L"lv_view");
+
+ columnCount = 0;
+ SetListViewHeaderColumn(L"");
+
+ AttachEvent(L"tv_folder", L"TVN_SELCHANGED", (FEvent)&TDocumentWin::OnTreeSelChanged);
+ AttachEvent(L"lv_view", L"NM_DBLCLK", (FEvent)&TDocumentWin::OnListViewDoubleClicked);
+
+ OnCreateTree();
+ OnAttachEvent();
+
+ tv_folder.ExpandItem(tv_folder.GetRootItem());
+ return 1;
+ }
+
+ int onloaded()
+ {
+ SetAgent();
+
+ return 1;
+ }
+ };
diff --git a/jrj/project/business/File/trade.help3.cpp b/jrj/project/business/File/trade.help3.cpp
new file mode 100644
index 0000000..3f7ca6e
--- /dev/null
+++ b/jrj/project/business/File/trade.help3.cpp
@@ -0,0 +1,232 @@
+#include <wobject/xstring.hpp>
+#include <xcontrol/xtreeview.hpp>
+#include <xcontrol/xdwgrid.hpp>
+#include <xcontrol/xlistview.hpp>
+
+#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp"
+#include "viewobject/view.base.hpp"
+
+using xml = KXMLDOMDocument;
+ class __declspec(dllexport) HelpDocWin : public xframe
+ {
+ public:
+ //xdwgrid dw_list;
+ xlistview lv_view;
+ xnode m_agentNode; //Agent Condition
+ int columnCount;
+ public:
+ HelpDocWin(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+ public:
+ static HelpDocWin* CreateInstance(void* implPtr, void* hWnd)
+ {
+ HelpDocWin* pWin = new HelpDocWin(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 OnListViewDoubleClicked(TEvent* evt, LPARAM param)
+ {
+ //重置工具条
+ //SetAgent();
+ OnDocumentOpen();
+ CloseWindow();
+ return 1;
+ }
+
+ int OnDocumentOpen()
+ {
+ int LVNI_ALL = 0x0000;
+ int LVNI_FOCUSED = 0x0001;
+ int LVNI_SELECTED = 0x0002;
+ int LVNI_CUT = 0x0004;
+ int LVNI_DROPHILITED = 0x0008;
+
+ int nItem = lv_view.GetNextItem(-1, LVNI_FOCUSED);
+ if (nItem < 0) return 1;
+
+ int LVIF_PARAM = 0x0004;
+
+ lvitem lvItem;
+ lvItem.iItem = nItem;
+ lvItem.iSubItem = 0;
+ lvItem.mask = LVIF_PARAM;
+
+ lv_view.GetItem(lvItem);
+ KXMLDOMElement ele = lvItem.lParam;
+
+ xstring src = ele.getAttribute(L"url");
+ xstring file = L"";
+ if (src.find(L"/file/") > 0) file = src.mid(src.find(L"/file/") + 6, 9999);
+ if (file.find(L"/file/") >= 0) file = file.mid(file.find(L"/file/") + 6, 9999);
+ if (file.find(L"file/") >= 0) file = file.mid(file.find(L"file/") + 5, 9999);
+ if (file == L"") return 1;
+ //alert(file);
+ xstring name = ele.getAttribute(L"caption");
+ /*
+ const xstring d = m_Html.GetData(p.object);
+ if(d == L"") return -1;
+ xstring file = d.mid(0, d.find(L"|##@@|",0));
+ xstring name = d.mid(d.find(L"|##@@|",0)+6, d.length());
+ */
+
+ xaserver::CreateDirectory(L"C:/Temp");
+ xstring str = file.left(2);
+ xstring ext = L"";
+ if (name.find(L".") >= 0) ext = name.mid(name.find(L"."), name.length());
+ xstring sfile = file;// file.left(file.length() - 4);
+ //trace(L"--"+ext +L" " + L"/business/attachment/"+str+L"/"+ file);
+ //int openRet = xaserver::DownLoadFile(GetServerUrl(),L"/business/attachment/"+str+L"/"+ file,name,L"C:/Temp/"+name);
+ int openRet = xaserver::DownLoadFile(GetServerUrl(), L"/business/attachment/" + str + L"/" + file + L".jpg", L"", L"C:/Temp/" + sfile + ext);
+
+ //alert(L"/business/attachment/"+str+L"/"+ file+L".jpg");
+ if (openRet < 0)
+ {
+ alert(L"文件打开失败1!");
+ return -1;
+ }
+ //openRet = win32::ShellExecute(0,L"open",L"C:/Temp/"+name,L"",L"",5);
+ openRet =ShellExecuteW(0, L"open", L"C:/Temp/" + sfile + ext, L"", L"", 5);
+ if (openRet < 32)
+ {
+ alert(L"文件打开失败2!");
+ return -1;
+ }
+
+ return -1;
+ }
+
+
+ //命令发布函数
+ int OnCmdDispatch(xstring comdid)
+ {
+ return 0;
+ }
+
+ //命令处理事件
+ int OnXCommand(TEvent* evt, LPARAM p)
+ {
+ return OnCmdDispatch(evt->xcommand.pStrID);
+ }
+
+ int OnAttachEvent()
+ {
+ //绑定工具条点击事件
+ AttachEvent(L"WM_XCOMMAND", (FEvent)&HelpDocWin::OnXCommand);
+ //获取焦点事件,用于重置工具条
+ AttachEvent(L"WM_SETFOCUS", (FEvent)&HelpDocWin::OnSetFocus);
+ return 1;
+ }
+
+ /*
+ 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.GetXmlDoc().text);
+ return -1;
+ }else
+ {
+ //dw_list.Retrieve(x);
+ //dw_list.Redraw();
+ }
+ return 1;
+ }
+ */
+
+ int SetListViewHeaderColumn(xstring Url)
+ {
+ const int LVCFMT_LEFT = 0;
+ for (int i = 0; i < 3; i++) lv_view.DeleteColumn(1);
+ //if(Url==L"")
+ //{
+ lv_view.InsertColumn(0, L"创建日期", LVCFMT_LEFT, 80, 0);
+ lv_view.InsertColumn(0, L"创建人员", LVCFMT_LEFT, 80, 0);
+ lv_view.InsertColumn(0, L"名称", 0, 180, 0);
+ columnCount = 3;
+ //}
+ return 1;
+ }
+
+ int Retrieve()
+ {
+ xstring src = L"object/knowledge";
+ //xstring src=L"data/SettleExchange";
+ xml x = ViewObject::RetrieveData(L"/sale/data/TDocument3/FolderListHelp");
+ if (x)
+ {
+ //alert(x.GetXml());
+ KXMLDOMElement ele = x.documentElement();
+ KXMLDOMNodeList nlist = ele.selectNodes(L"*");
+ int s = nlist.length();
+ if (s > 0)
+ {
+ for (int i = 0; i < s; i++)
+ {
+ KXMLDOMElement e = nlist.item(i);
+ xstring name = e.getAttribute(L"caption");
+ int nItem = lv_view.InsertItemEx(0, name, 14, e );
+
+ lv_view.SetItemText(nItem, 1, e.getAttribute(L"Creator"));
+ lv_view.SetItemText(nItem, 2, e.getAttribute(L"CreateDate"));
+
+ }
+ }
+ }
+ return 1;
+ }
+
+ int onload()
+ {
+ //dw_list = GetControl(L"xxx");
+ //dw_list.openUrl(L"xxx");
+ lv_view = GetControl(L"lv_view");
+
+ columnCount = 0;
+ SetListViewHeaderColumn(L"");
+
+ AttachEvent(L"lv_view", L"NM_DBLCLK", (FEvent)&HelpDocWin::OnListViewDoubleClicked);
+
+ Retrieve();
+
+ return 1;
+ }
+
+ int onloaded()
+ {
+ SetAgent();
+
+ return 1;
+ }
+ };
diff --git a/jrj/project/business/File/trade.helpEx.cpp b/jrj/project/business/File/trade.helpEx.cpp
new file mode 100644
index 0000000..3ca48a5
--- /dev/null
+++ b/jrj/project/business/File/trade.helpEx.cpp
@@ -0,0 +1,245 @@
+#include <wobject/xstring.hpp>
+#include <xcontrol/xtreeview.hpp>
+#include <xcontrol/xdwgrid.hpp>
+#include <xcontrol/xlistview.hpp>
+
+#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp"
+#include "viewobject/view.base.hpp"
+
+using xml = KXMLDOMDocument;
+ class __declspec(dllexport) HelpDocExWin : public xframe
+ {
+ public:
+ //xdwgrid dw_list;
+ xlistview lv_view;
+ xnode m_agentNode; //Agent Condition
+ int columnCount;
+
+ xstring urlEx;
+ xstring Search;
+
+ public:
+ HelpDocExWin(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+ public:
+ static HelpDocExWin* CreateInstance(void* implPtr, void* hWnd)
+ {
+ HelpDocExWin* pWin = new HelpDocExWin(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 OnListViewDoubleClicked(TEvent* evt, LPARAM param)
+ {
+ //重置工具条
+ //SetAgent();
+ OnDocumentOpen();
+ CloseWindow();
+ return 1;
+ }
+
+ int OnDocumentOpen()
+ {
+ int LVNI_ALL = 0x0000;
+ int LVNI_FOCUSED = 0x0001;
+ int LVNI_SELECTED = 0x0002;
+ int LVNI_CUT = 0x0004;
+ int LVNI_DROPHILITED = 0x0008;
+
+ int nItem = lv_view.GetNextItem( -1, LVNI_FOCUSED);
+ if (nItem < 0) return 1;
+
+ int LVIF_PARAM = 0x0004;
+
+ lvitem lvItem;
+ lvItem.iItem = nItem;
+ lvItem.iSubItem = 0;
+ lvItem.mask = LVIF_PARAM;
+
+ lv_view.GetItem( lvItem);
+ KXMLDOMElement ele = lvItem.lParam;
+
+ xstring src = ele.getAttribute(L"url");
+ xstring file = L"";
+ if (src.find(L"/file/") > 0) file = src.mid(src.find(L"/file/") + 6, 9999);
+ if (file.find(L"/file/") >= 0) file = file.mid(file.find(L"/file/") + 6, 9999);
+ if (file.find(L"file/") >= 0) file = file.mid(file.find(L"file/") + 5, 9999);
+ if (file == L"") return 1;
+ //alert(file);
+ xstring name = ele.getAttribute(L"caption");
+ /*
+ const xstring d = m_Html.GetData(p.object);
+ if(d == L"") return -1;
+ xstring file = d.mid(0, d.find(L"|##@@|",0));
+ xstring name = d.mid(d.find(L"|##@@|",0)+6, d.length());
+ */
+
+ xaserver::CreateDirectory(L"C:/Temp");
+ xstring str = file.left(2);
+ xstring ext = L"";
+ if (name.find(L".") >= 0) ext = name.mid(name.find(L"."), name.length());
+ xstring sfile = file;// file.left(file.length() - 4);
+ //trace(L"--"+ext +L" " + L"/business/attachment/"+str+L"/"+ file);
+ //int openRet = xaserver::DownLoadFile(GetServerUrl(),L"/business/attachment/"+str+L"/"+ file,name,L"C:/Temp/"+name);
+ int openRet = xaserver::DownLoadFile(GetServerUrl(), L"/business/attachment/" + str + L"/" + file + L".jpg", L"", L"C:/Temp/" + sfile + ext);
+
+ //alert(L"/business/attachment/"+str+L"/"+ file+L".jpg");
+ if (openRet < 0)
+ {
+ alert(L"文件打开失败1!");
+ return -1;
+ }
+ //openRet = win32::ShellExecute(0,L"open",L"C:/Temp/"+name,L"",L"",5);
+ openRet = ShellExecuteW(0, L"open", L"C:/Temp/" + sfile + ext, L"", L"", 5);
+ if (openRet < 32)
+ {
+ alert(L"文件打开失败2!");
+ return -1;
+ }
+
+ return -1;
+ }
+
+ //命令发布函数
+ int OnCmdDispatch(xstring comdid)
+ {
+ return 0;
+ }
+
+ //命令处理事件
+ int OnXCommand(TEvent* evt, LPARAM p)
+ {
+ return OnCmdDispatch(evt->xcommand.pStrID);
+ }
+
+ int OnAttachEvent()
+ {
+ //绑定工具条点击事件
+ AttachEvent(L"WM_XCOMMAND", (FEvent)&HelpDocExWin::OnXCommand);
+ //获取焦点事件,用于重置工具条
+ AttachEvent(L"WM_SETFOCUS", (FEvent)&HelpDocExWin::OnSetFocus);
+ return 1;
+ }
+
+ /*
+ 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.GetXmlDoc().text);
+ return -1;
+ }else
+ {
+ //dw_list.Retrieve(x);
+ //dw_list.Redraw();
+ }
+ return 1;
+ }
+ */
+
+ int SetListViewHeaderColumn(xstring Url)
+ {
+ const int LVCFMT_LEFT = 0;
+ for (int i = 0; i < 3; i++) lv_view.DeleteColumn( 1);
+ //if(Url==L"")
+ //{
+ lv_view.InsertColumn( 0, L"创建日期", LVCFMT_LEFT, 80, 0);
+ lv_view.InsertColumn( 0, L"创建人员", LVCFMT_LEFT, 80, 0);
+ lv_view.InsertColumn( 0, L"名称", 0, 180, 0);
+ columnCount = 3;
+ //}
+ return 1;
+ }
+
+ int Retrieve(xstring urlEx, xstring Search)
+ {
+ xstring src = L"object/knowledge";
+ //xstring src=L"data/SettleExchange";
+ xml x = ViewObject::RetrieveData(L"/sale/data/TDocument3/FolderListHelpEx", L"urlEx", urlEx, L"SearchEx", Search);
+ if (x)
+ {
+ //alert(x.GetXml());
+ KXMLDOMElement ele = x.documentElement();
+ KXMLDOMNodeList nlist = ele.selectNodes(L"*");
+ int s = nlist.length();
+ if (s > 0)
+ {
+ for (int i = 0; i < s; i++)
+ {
+ KXMLDOMElement e = nlist.item(i);
+ xstring name = e.getAttribute(L"caption");
+ int nItem = lv_view.InsertItemEx( 0, name, 14, e);
+
+ lv_view.SetItemText( nItem, 1, e.getAttribute(L"Creator"));
+ lv_view.SetItemText( nItem, 2, e.getAttribute(L"CreateDate"));
+
+ }
+ }
+ }
+ return 1;
+ }
+
+ int onload()
+ {
+ SetArg();
+ //dw_list = GetControl(L"xxx");
+ //dw_list.openUrl(L"xxx");
+ lv_view = GetControl(L"lv_view");
+
+ columnCount = 0;
+ SetListViewHeaderColumn(L"");
+
+ AttachEvent(L"lv_view", L"NM_DBLCLK", (FEvent)&HelpDocExWin::OnListViewDoubleClicked);
+
+
+ if (GetWinParam())
+ {
+ xaserverarg arg = GetArg();
+
+ urlEx = arg.GetArgString(L"url");
+ Search = arg.GetArgString(L"Search");
+ Retrieve(urlEx, Search);
+ }
+ //Retrieve(urlEx,Search);
+
+ return 1;
+ }
+
+ int onloaded()
+ {
+ SetAgent();
+
+ return 1;
+ }
+ };
\ No newline at end of file
diff --git a/jrj/project/business/ProductSample/SampleBarcodePrint.cpp b/jrj/project/business/ProductSample/SampleBarcodePrint.cpp
index c5fa8f3..b0f6e9b 100644
--- a/jrj/project/business/ProductSample/SampleBarcodePrint.cpp
+++ b/jrj/project/business/ProductSample/SampleBarcodePrint.cpp
Binary files differ
diff --git a/jrj/project/business/Supplier/Inspection.Supplie.cpp b/jrj/project/business/Supplier/Inspection.Supplie.cpp
index 10a131b..ea3431c 100644
--- a/jrj/project/business/Supplier/Inspection.Supplie.cpp
+++ b/jrj/project/business/Supplier/Inspection.Supplie.cpp
Binary files differ
diff --git a/jrj/project/total3/ViewTotalArgWin.cpp b/jrj/project/total3/ViewTotalArgWin.cpp
new file mode 100644
index 0000000..91be15a
--- /dev/null
+++ b/jrj/project/total3/ViewTotalArgWin.cpp
@@ -0,0 +1,137 @@
+#include <wobject/xstring.hpp>
+#include <xcontrol/xtreeview.hpp>
+#include <xcontrol/xdwgrid.hpp>
+
+#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp"
+#include "viewobject/view.base.hpp"
+#include "vbusiness/vframe/frame.vframe.vbusiness.hpp"
+
+
+using xml = KXMLDOMDocument;
+ class __declspec(dllexport) ViewTotalArgWin : public xframe
+ {
+ public:
+ xdwtable dw_arg;
+ xaserverarg arg;
+ xnode m_agentNode; //Agent Condition
+ public:
+ ViewTotalArgWin(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {}
+ public:
+ static ViewTotalArgWin* CreateInstance(void* implPtr, void* hWnd)
+ {
+ ViewTotalArgWin* pWin = new ViewTotalArgWin(implPtr, (HWND)hWnd);
+ return pWin;
+ }
+ /*int SetAgent()
+ {
+ string xfNodeAgentArea = L"agentarea";
+ xnode anode = GetAgentNode(xfNodeAgentArea);
+ if(m_agentNode)
+ {
+ SetAgentNodeContent (anode,m_agentNode);
+ }
+ else
+ {
+ msxml::IXMLDOMElement xframeElement = GetElement();
+ msxml::IXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/"+xfNodeAgentArea+L"[1]/*");
+ if(agent)
+ {
+ string s = agent.xml;
+ m_agentNode = SetAgentNodeContent (anode,s);
+ }
+ }
+ return 1;
+ }*/
+
+ //焦点激活处理函数
+ int OnSetFocus(TEvent * evt, int param)
+ {
+ //重置工具条
+ //SetAgent();
+ return 1;
+ }
+
+ //命令发布函数
+ int OnCmdDispatch(string comdid)
+ {
+ if (comdid == L"xmOk")
+ {
+ xml x;
+
+ dw_arg.AcceptText();
+ dw_arg.DwUpdateAllTo(x);
+ //trace(L"--------" + x.xml());
+ arg.AddArg(L"arg", x.xml());
+ arg.AddArg(L"action", L"ok");
+ CloseWindow();
+
+ return 1;
+ }
+ else if (comdid == L"xmCancel")
+ {
+ arg.AddArg(L"action", L"cancel");
+ CloseWindow();
+ return 1;
+ }
+ return 0;
+ }
+
+ //命令处理事件
+ int OnXCommand(TEvent* evt, int param)
+ {
+ return OnCmdDispatch(evt->xcommand.pStrID);
+ }
+
+ int OnAttachEvent()
+ {
+ //绑定工具条点击事件
+ AttachEvent(L"WM_XCOMMAND", (FEvent)&ViewTotalArgWin::OnXCommand);
+ //获取焦点事件,用于重置工具条
+ AttachEvent(L"WM_SETFOCUS", (FEvent)&ViewTotalArgWin::OnSetFocus);
+ return 1;
+ }
+
+ int onload()
+ {
+ SetArg();
+ dw_arg = GetControl(L"dw_arg");
+
+ if (GetWinParam())
+ {
+ arg = GetArg();
+ string dw = arg.GetArgString(L"argurl");
+ dw_arg.openUrl(dw);
+
+ dw_arg.SetColHeaderHeight(0);
+ dw_arg.SetRowSelectorWidth(0);
+ dw_arg.SetHScrollState(false);
+ dw_arg.SetVScrollState(false);
+
+ string d = arg.GetArgString(L"arg");
+ if (d != L"")
+ {
+ xml x ;
+
+ x.loadXML(d);
+ dw_arg.Retrieve(x);
+ }
+ }
+ dw_arg.SetEditUpperMode(true);
+ dw_arg.SetItemString(1, L"QuoteSuccess/type", L"是");
+ dw_arg.SetItemString(1, L"ApprovalStatusName", L"6");
+ dw_arg.SetItemDisplayString(1, L"ApprovalStatusName", L"已审核");
+ dw_arg.SetItemString(1, L"GDN.ETD/type", L"日期范围");
+ dw_arg.SetItemString(1, L"QuoteSuccess/type", L"是");
+
+ OnAttachEvent();
+
+ return 1;
+ }
+
+ int onloaded()
+ {
+ //SetAgent();
+
+ return 1;
+ }
+ };
\ No newline at end of file
diff --git a/jrj/project/total3/ViewTotalWin.cpp b/jrj/project/total3/ViewTotalWin.cpp
index e8e4699..a94ff6b 100644
--- a/jrj/project/total3/ViewTotalWin.cpp
+++ b/jrj/project/total3/ViewTotalWin.cpp
@@ -15,11 +15,13 @@
{
public:
ViewTotalWin(void* implPtr, HWND hWnd) :xwin(implPtr, hWnd) {}
+public:
static ViewTotalWin* CreateInstance(void* implPtr, void* hWnd)
{
- return new ViewTotalWin(implPtr, (HWND)hWnd);
+ ViewTotalWin* pWin = new ViewTotalWin(implPtr, (HWND)hWnd);
+ return pWin;
}
-
+public:
xdwgrid dw_list;
xoffice dw_office;
xcell dw_cell;
--
Gitblit v1.9.3