From 6a4764ee747fff45d89ef48f98873d6409e4f85e Mon Sep 17 00:00:00 2001 From: LiFan <2308045698@qq.com> Date: 星期二, 16 七月 2024 17:22:23 +0800 Subject: [PATCH] update --- jrj/project/business/BasicCode/QuickCode_Tree.cpp | 1314 ++++++++++++++++++++++++++++++----------------------------- 1 files changed, 660 insertions(+), 654 deletions(-) diff --git a/jrj/project/business/BasicCode/QuickCode_Tree.cpp b/jrj/project/business/BasicCode/QuickCode_Tree.cpp index cd40c87..b8b99b0 100644 --- a/jrj/project/business/BasicCode/QuickCode_Tree.cpp +++ b/jrj/project/business/BasicCode/QuickCode_Tree.cpp @@ -1,690 +1,696 @@ -use"lang.vl" -use "win.vl" -use "dev:vm[xml.vm]" -use "treeview.vm" -use "dev:vm[xaserverarg.vm]" -use "dev:vm[xaserver.vm]" -use "dev:vm[xdwgrid.vm]" -use "dev:vm[xdwtable.vm]" -use "dev:vm[xutil.vm]" -use "file.vl" -use "list.vl" -unit vbusiness.vpage -[ - QuickCode_Tree is extend list; - about QuickCode_Tree - [ - field: - - method: - [ - xdwgrid__ dw_list; - treeview__ tv_1; - string m_config; - string m_agent; - string m_id; - string m_dbmap; - string treexquery; - string c_type; - msxml::IXMLDOMDocument m_configDoc; - string kpstr; - string strtpl; - string m_QueryTxt; - int alert(string str) +#include <wobject/xstring.hpp> +#include <xcontrol/xtreeview.hpp> +#include <xcontrol/xdwgrid.hpp> +#include <wobject/xdouble.hpp> +#include <xcontrol/xlayersheet.hpp> + +#include "vbusiness/vframe/listwin.vframe.vbusiness.hpp" +#include "viewobject/view.base.hpp" + +using xml = KXMLDOMDocument; +class __declspec(dllexport) QuickCode_Tree : public xwin +{ +public: + xdwgrid dw_list; + xtreeview tv_1; + xstring m_config; + xstring m_agent; + xstring m_id; + xstring m_dbmap; + xstring treexquery; + xstring c_type; + KXMLDOMDocument m_configDoc; + xstring kpstr; + xstring strtpl; + xstring m_QueryTxt; + xnode m_agentNode; +public: + QuickCode_Tree(void* implPtr, HWND hWnd) :xwin(implPtr, hWnd) {} +public: + static QuickCode_Tree* CreateInstance(void* implPtr, void* hWnd) + { + QuickCode_Tree* pWin = new QuickCode_Tree(implPtr, (HWND)hWnd); + return pWin; + } + int alert(xstring str) + { + TApp::alert(this, str); + //win::MessageBox(GetHWND(),str,L"提示:",0); + return 0; + } + 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) { - TApp::alert(this,str); - //win__::MessageBox(this.GetHWND(),str,"提示:",0); + xstring s = agent.xml(); + m_agentNode = SetAgentNode(anode, s); + } + } + return 1; + } + int OnRetrieve() + { + dw_list.AcceptText(); + xml x; + + xaserverarg arg; + + arg.AddArg(L"id", m_id); + arg.AddArg(L"sType", c_type); + arg.AddArg(L"QueryTxt", m_QueryTxt); + //trace(arg.GetString()); + /*if (TDataSet::exec(m_config, L"query1", arg.GetString(),x) != 1) + { + trace(x.text()); + return -1; + }*/ + if (xurl::get(L"QuickCode/entity/listaddtree", arg.GetString(), x) != 1) + { + trace(x.text()); + return -1; + } + //trace(x.xml()); + if (x.xml() == L"") + { + xml xx; + xx.loadXML(L"<root/>"); + dw_list.Retrieve(xx); + dw_list.Redraw(); + } + else + { + dw_list.Retrieve(x); + dw_list.Redraw(); + } + + return 1; + } + int OnTreeSelChanged(TEvent* evt, LPARAM p) + { + NMTREEVIEW& nmtv = *(NMTREEVIEW*)evt->notify.pnmh; + HTREEITEM hItem = nmtv.itemNew.hItem; + + + HTREEITEM hitem = tv_1.GetSelectedItem(); + //c_type=dw_type.GetItemLabel(hitem); + //如果是跟节点 + HTREEITEM roothitem = tv_1.GetRootItem(); + if (hitem == roothitem) { + c_type = L""; + } + else + { + c_type = tv_1.GetItemLabel(hitem); + + } + OnRetrieve(); + return 1; + } + int adduomfolder() + { + xaserverarg arg; + + arg.AddArg(L"note", L"新增"); + arg.AddArg(L"m_id", m_id); + //win::OpenWindow(L"dev:xpage[AddUomGroup.vx]",arg); + openUrl(L"公共设置.vface/xpage/quickcode/AddGroup", arg); + xstring ok = arg.GetArgString(L"return"); + if (ok == L"ok") { + xstring GroupName = arg.GetArgString(L"GroupName"); + xml xx; + + xaserverarg args; + + args.AddArg(L"GroupName", GroupName); + args.AddArg(L"OldGroupName", L""); + args.AddArg(L"m_id", m_id); + /*if(TFile::exec(m_config,L"updateuomtype",args,xx)!=1) + { + trace(L"error:"+xx.xml()); + alert(L"保存出错!"); + return 0; + }*/ + if (xurl::get(L"QuickCode/pref/quickcode_tree.updateGroup", args.GetString(), xx) != 1) + { + trace(L"error:" + (xstring)xx.xml()); + alert(L"保存出错!"); return 0; } - int SetAgent() + else { - string xfNodeAgentArea = "agentarea"; - xnode__ anode = new xnode__; - anode.setNativePointer(GetAgentNode(xfNodeAgentArea)); - var xframeElement = win__::GetElement(); - var agent = xframeElement.selectSingleNode("agent/"+xfNodeAgentArea+"[1]"); - if(agent) + xstring vv = xx.documentElement().text(); + xml x; + + x.loadXML(L"<row GroupName='" + GroupName + L"'/>"); + HTREEITEM root = tv_1.GetRootItem(); + if (vv == L"OK") { - string s = agent.xml+""; - SetAgentNodeContent (anode,s); + tv_1.InsertChildItem(root, GroupName, x.documentElement(), 15); } - return 1; + } - int OnRetrieve() - { - dw_list.AcceptText(); - xml__ x=new xml__; - x.setNativePointer(xml__::CreateInstance()); - xaserverarg__ arg=new xaserverarg__; - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg("id",m_id); - arg.AddArg("sType",c_type); - arg.AddArg("QueryTxt", m_QueryTxt ); - //trace(arg.GetString()); - /*if (TDataSet::exec(m_config, "query1", arg.GetString(),x) != 1) + } + return 1; + } + int modifyuomfolder() + { + + HTREEITEM h = tv_1.GetSelectedItem(); + if (!h) + { + alert(L"请选择需要修改的组名"); + return 0; + } + HTREEITEM roothitem = tv_1.GetRootItem(); + if (h == roothitem) + { + alert(L"不能修改根节点名称!"); + } + else + { + KXMLDOMElement e = tv_1.GetItemData(h); + trace(e.xml()); + //xstring OldGroupName= e.SelectSingleNode(L"@GroupName").text(); + xstring OldGroupName = tv_1.GetItemLabel(h); + xaserverarg arg; + + arg.AddArg(L"note", L"修改"); + arg.AddArg(L"m_id", m_id); + arg.AddArg(L"GroupName", OldGroupName); + OpenWindow(L"dev:xpage[AddUomGroup.vx]", arg); + xstring ok = arg.GetArgString(L"return"); + if (ok == L"ok") { + xstring NewGroupName = arg.GetArgString(L"GroupName"); + xml xx; + + xaserverarg args; + + args.AddArg(L"GroupName", NewGroupName); + args.AddArg(L"OldGroupName", OldGroupName); + args.AddArg(L"m_id", m_id); + /*if(TFile::exec(m_config,L"updateuomtype",args,xx)!=1) { - trace(x.GetXmlDoc().text); - return -1; + trace(L"error:"+xx.xml()); + alert(L"保存出错!"); + return 0; }*/ - if (url::get("QuickCode/entity/listaddtree",arg.GetString(),x) != 1) + if (xurl::get(L"QuickCode/pref/quickcode_tree.updateGroup", args.GetString(), xx) != 1) { - trace(x.GetXmlDoc().text); - return -1; - } - //trace(x.GetXml()); - if(x.GetXml()=="") - { - xml__ xx=new xml__; - xx.setNativePointer(xml__::CreateInstance()); - xx.LoadXml("<root/>"); - dw_list.Retrieve(xx); - dw_list.Redraw(); + trace(L"error:" + (xstring)xx.xml()); + alert(L"保存出错!"); + return 0; } else - { - dw_list.Retrieve(x); - dw_list.Redraw(); - } + { + trace(xx.xml()); + xstring vv = xx.documentElement().text(); + if (vv == L"OK") + { + tv_1.SetItemLabel(h, NewGroupName); + } - return 1; - } - int OnTreeSelChanged(ref TNotifyEvent evt,int p) + } + } + } + return 1; + } + int deluomfolder() + { + + HTREEITEM hitem = tv_1.GetSelectedItem(); + if (!hitem) + { + alert(L"请选择需要删除的组名"); + return 0; + } + else + { + + int s = dw_list.GetRowCount(); + if (s > 0) { - ref NMTREEVIEW nmtv = evt.pnmh; - int hItem = nmtv.itemNew.hItem; - - int wid = tv_1.GetId(); - int hitem=treeview__::GetSelectedItem(wid); - //c_type=dw_type.GetItemLabel(hitem); - //如果是跟节点 - int roothitem=treeview__::GetRootItem(wid); - if(hitem == roothitem){ - c_type=""; - } - else + alert(L"该分组下面存在数据,不能删除!"); + return 0; + } + HTREEITEM roothitem = tv_1.GetRootItem(); + if (hitem == roothitem) + { + alert(L"不能删除根节点!"); + } + else + { + //缺少判断删除的条件 + xstring GroupName = tv_1.GetItemLabel(hitem); + if (MessageBox(GetHWND(), L"确定删除组名:" + GroupName + L" 吗?", L"提示", 1) == 1) { - c_type = treeview__::GetItemLabel(wid,hitem); + xml xx; + xaserverarg arg; + + arg.AddArg(L"GroupName", GroupName); + arg.AddArg(L"m_id", m_id); + trace(GroupName); + trace(m_id); + /*if (xaserver::ExecXAction(GetServerUrl(),L"[delete.type.FND_UOM.xa]",arg.GetString()) == 1) + { + tv_1.DeleteItem(wid,hitem); + //OnTreeSelChanged(); + }*/ + if (xurl::get(L"QuickCode/pref/quickcode_tree.deleteGroup", arg.GetString(), xx) == 1) + { + tv_1.DeleteItem(hitem); + } + else + alert(L"删除失败!"); } + } + } + return 1; + } + xdwgrid getDW() + { + return dw_list; + } + int GridSearch() + { + xml x; + + xaserver::LoadUrl(L"", L"dev:vface[公共设置.vface]", L"", x); + //trace(x.xml()); + //trace(strtpl); + xstring aa = strtpl; + var doc = x; + var n = doc.selectSingleNode(L"//resource[@url='" + aa + L"']/@src"); + //trace(n.text()); + + xaserverarg arg; + + arg.AddArg(L"sheet", n.text()); + arg.AddArg(L"search", list::m_QueryTxt); + openUrl(L"view.dlg.vface/xpage/grid/column/search", arg); + xstring ok = arg.GetArgString(L"return"); + if (ok == L"ok") { + xstring txt = arg.GetArgString(L"search"); + if (txt != L"") { + m_QueryTxt = txt; + //trace(txt); OnRetrieve(); - return 1; } - int adduomfolder() - { - xaserverarg__ arg = new xaserverarg__; - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg("note","新增"); - arg.AddArg("m_id",m_id); - //win__::OpenWindow("dev:xpage[AddUomGroup.vx]",arg); - openUrl("公共设置.vface/xpage/quickcode/AddGroup", arg); - string ok = arg.GetArgString("return"); - if(ok == "ok"){ - string GroupName = arg.GetArgString("GroupName"); - xml__ xx=new xml__; - xx.setNativePointer(xml__::CreateInstance()); - xaserverarg__ args = new xaserverarg__; - args.setNativePointer(args.CreateInstance()); - args.AddArg("GroupName",GroupName); - args.AddArg("OldGroupName",""); - args.AddArg("m_id",m_id); - /*if(TFile::exec(m_config,"updateuomtype",args,xx)!=1) - { - trace("error:"+xx.GetXml()); - alert("保存出错!"); - return 0; - }*/ - if (url::get("QuickCode/pref/quickcode_tree.updateGroup",args.GetString(),xx) != 1) - { - trace("error:"+xx.GetXml()); - alert("保存出错!"); - return 0; - } - else - { - string vv=xx.GetXmlDoc().documentElement.text; - xml__ x=new xml__; - x.setNativePointer(xml__::CreateInstance()); - x.LoadXml("<row GroupName='"+GroupName+"'/>"); - int root = treeview__::GetRootItem(tv_1.GetId()); - if(vv=="OK") - { - treeview__::InsertChildItem(tv_1.GetId(), root, GroupName,x.GetXmlDoc().documentElement, 15); - } - - } - } - return 1; - } - int modifyuomfolder() - { - int wid = tv_1.GetId(); - int h = treeview__::GetSelectedItem(wid); - if (h<1) - { - alert("请选择需要修改的组名"); - return 0; - } - int roothitem=treeview__::GetRootItem(wid); - if(h==roothitem) - { - alert("不能修改根节点名称!"); - } - else - { - msxml::IXMLDOMElement e = treeview__::GetItemData(wid,h); - trace(e.xml); - //string OldGroupName= e.SelectSingleNode("@GroupName").text; - string OldGroupName= treeview__::GetItemLabel(wid,h); - xaserverarg__ arg = new xaserverarg__; - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg("note","修改"); - arg.AddArg("m_id",m_id); - arg.AddArg("GroupName",OldGroupName); - win__::OpenWindow("dev:xpage[AddUomGroup.vx]",arg); - string ok = arg.GetArgString("return"); - if(ok == "ok"){ - string NewGroupName = arg.GetArgString("GroupName"); - xml__ xx=new xml__; - xx.setNativePointer(xml__::CreateInstance()); - xaserverarg__ args = new xaserverarg__; - args.setNativePointer(args.CreateInstance()); - args.AddArg("GroupName",NewGroupName); - args.AddArg("OldGroupName",OldGroupName); - args.AddArg("m_id",m_id); - /*if(TFile::exec(m_config,"updateuomtype",args,xx)!=1) - { - trace("error:"+xx.GetXml()); - alert("保存出错!"); - return 0; - }*/ - if (url::get("QuickCode/pref/quickcode_tree.updateGroup",args.GetString(),xx)!=1) - { - trace("error:"+xx.GetXml()); - alert("保存出错!"); - return 0; - } - else - { - trace(xx.GetXml()); - string vv=xx.GetXmlDoc().documentElement.text; - if(vv=="OK") - { - treeview__::SetItemLabel(tv_1.GetId(), h,NewGroupName); - } + } + return 0; + } + int OnCmdDispatch(xstring comdid) + { + HCURSOR hCursor = xutil::SetCursorWait(); + xdwgrid dw = getDW(); + if (comdid == L"save") { + dw_list.AcceptText(); + xml x; - } - } - } - return 1; - } - int deluomfolder() - { - - int wid = tv_1.GetId(); - int hitem=treeview__::GetSelectedItem(wid); - if (hitem<1) - { - alert("请选择需要删除的组名"); - return 0; - } - else - { + xaserverarg arg; - int s=dw_list.GetRowCount(); - if (s>0) - { - alert("该分组下面存在数据,不能删除!"); - return 0; - } - int roothitem=treeview__::GetRootItem(wid); - if(hitem==roothitem) - { - alert("不能删除根节点!"); - } - else - { - //缺少判断删除的条件 - string GroupName =treeview__::GetItemLabel(wid,hitem); - if(win__::MessageBox(GetHWND(),"确定删除组名:"+GroupName+" 吗?","提示",1)==1) - { - xml__ xx=new xml__; - xx.setNativePointer(xml__::CreateInstance()); - xaserverarg__ arg = new xaserverarg__; - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg("GroupName",GroupName); - arg.AddArg("m_id",m_id); - trace(GroupName); - trace(m_id); - /*if (xaserver__::ExecXAction(GetServerUrl(),"[delete.type.FND_UOM.xa]",arg.GetString()) == 1) - { - treeview__::DeleteItem(wid,hitem); - //OnTreeSelChanged(); - }*/ - if (url::get("QuickCode/pref/quickcode_tree.deleteGroup",arg.GetString(),xx)== 1) - { - treeview__::DeleteItem(wid,hitem); - } - else - alert("删除失败!"); - } - } - } - return 1; - } - xdwgrid__ getDW() + dw_list.DwUpdateAllToEx(x); + KXMLDOMElement e = x.documentElement(); + e.setAttribute(L"id", m_id); + //arg.AddArg(L"id",m_id); + //trace(m_id); + //trace(m_dbmap); + if (m_id == L"开票银行") { - return dw_list; + xml kp; + + kp.loadXML(L"<root></root>"); + KXMLDOMElement ele = kp.documentElement(); + var list = e.selectNodes(L"item[@update.modify='1' or @update.delete='1' ]"); + int j; + int k = list.length; + for (j = 0; j < k; j++) + { + KXMLDOMElement ele1 = list.item(j); + ele.appendChild(ele1); + } + kpstr = ele.xml(); + trace(ele.xml()); } - int GridSearch() + if (m_id == L"开票银行") { - xml__ x = new xml__; - x.setNativePointer(xml__ ::CreateInstance()); - xaserver__::LoadUrl("","dev:vface[公共设置.vface]","",x); - //trace(x.GetXml()); - //trace(strtpl); - string aa=strtpl; - var doc = x.GetXmlDoc(); - var n = doc.selectSingleNode("//resource[@url='"+aa+"']/@src"); - //trace(n.text); - - xaserverarg__ arg=new xaserverarg__; - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg("sheet",n.text); - arg.AddArg("search",list::m_QueryTxt); - openUrl("view.dlg.vface/xpage/grid/column/search", arg); - string ok = arg.GetArgString("return"); - if(ok == "ok"){ - string txt = arg.GetArgString("search"); - if(txt != ""){ - m_QueryTxt = txt; - //trace(txt); - OnRetrieve(); - } - } + arg.AddArg(L"content", kpstr); + } + else + { + arg.AddArg(L"content", e.xml()); + } + arg.AddArg(L"dbmap", m_dbmap); + /*if(TFile::exec(m_config,L"save",arg,x)!=1) + { + trace(L"error:"+x.xml()); + alert(L"保存出错!"); return 0; - } - int OnCmdDispatch(string comdid) + }*/ + trace(m_dbmap + L"\r\n" + e.xml()); + if (xurl::get(L"QuickCode/pref/quickcode.save", arg.GetString(), x) != 1) { - int hCursor = xutil__::SetCursorWait(); - xdwgrid__ dw=getDW(); - if(comdid == "save"){ - dw_list.AcceptText(); - xml__ x=new xml__; - x.setNativePointer(xml__::CreateInstance()); - xaserverarg__ arg=new xaserverarg__; - arg.setNativePointer(arg.CreateInstance()); - dw_list.DwUpdateAllToEx(x.GetXmlDoc()); - msxml::IXMLDOMElement e= x.GetXmlDoc().documentElement; - e.SetAttribute("id", m_id); - //arg.AddArg("id",m_id); - //trace(m_id); - //trace(m_dbmap); - if(m_id=="开票银行") - { - xml__ kp = new xml__; - kp.setNativePointer(xml__::CreateInstance()); - kp.LoadXml("<root></root>"); - msxml::IXMLDOMElement ele= kp.GetXmlDoc().documentElement; - var list = e.SelectNodes("item[@update.modify='1' or @update.delete='1' ]"); - int j; - int k = list.length; - for (j=0; j<k; j++) - { - msxml::IXMLDOMElement ele1 = list.item(j); - ele.appendChild(ele1); - } - kpstr=ele.xml; - trace(ele.xml); - } - if(m_id=="开票银行") - { - arg.AddArg("content",kpstr); - } - else - { - arg.AddArg("content",e.xml); - } - arg.AddArg("dbmap", m_dbmap); - /*if(TFile::exec(m_config,"save",arg,x)!=1) - { - trace("error:"+x.GetXml()); - alert("保存出错!"); - return 0; - }*/ - trace(m_dbmap+"\r\n"+e.xml); - if (url::get("QuickCode/pref/quickcode.save",arg.GetString(),x) != 1) - { - string error = x.GetXmlDoc().text; - trace(error); - } - //trace(arg.GetString()); - if(x.GetXmlDoc().selectSingleNode("error")) - { - alert("保存出错2!"); - return 0; - } - dw_list.ResetUpdateStatus(); - alert("保存成功!"); - } - else if(comdid=="add"){ - dw.InsertRow(0); - int rows = dw.GetRowCount(); - dw.SetItemString(rows,"GroupName",c_type); - dw.SetItemString(rows,"BankName",c_type); - } - else if(comdid=="insert"){ - int row = dw.GetRow(); - if(row<1 || row>dw.GetRowCount()) return 0; - dw.InsertRow(row); - - dw.SetItemString(row,"GroupName",c_type); - } - else if(comdid == "delet"){ - dw_list.AcceptText(); - int row2 = dw.GetRow(); - if(row2<1 || row2>dw.GetRowCount()) return 0; - dw.DeleteRow(row2); - } - else if (comdid=="adduomfolder") - adduomfolder(); - else if (comdid=="modifyuomfolder") - modifyuomfolder(); - else if (comdid=="deluomfolder") - deluomfolder(); - else if (comdid=="search") - GridSearch(); - xutil__::RestoreCursor(hCursor); + xstring error = x.text(); + trace(error); + } + //trace(arg.GetString()); + if (x.selectSingleNode(L"error")) + { + alert(L"保存出错2!"); return 0; } - int OnXCommand(ref TXCommandEvent evt,int p) - { - return OnCmdDispatch(""+evt.pStrID); - } - int OnSetFocus(ref TNotifyEvent evt,int p){ - SetAgent(); - tv_1 = new treeview__; - tv_1.setNativePointer(this.GetControl("tv_1")); - int wid = tv_1.GetId(); - int root = treeview__::GetRootItem(wid); - treeview__::ExpandItem(wid,root); - return 1; - } - int OnDoubleClicked(ref TNotifyEvent evt,int p) - { - ref DWNMHDR hdr = evt.pnmh; - int row = hdr.row; - if(row<1 || row > dw_list.GetRowCount() ) return 0; - - xaserverarg__ arg = new xaserverarg__; - arg.setNativePointer(arg.CreateInstance()); - //string str = hdr.data; - string colname=hdr.colname; - string str = dw_list.GetItemString(row, colname); - arg.AddArg("value",str); - openUrl("/sale/view/view.dlg/xpage/memo/edit", arg); - string comdid = arg.GetArgString("comdid"); - if(comdid=="xmOK") - { - string value = arg.GetArgString("value"); - dw_list.SetItemString(row,colname,value); - dw_list.Redraw(); - } - - return 1; - } - int ItemOutput() - { - string d = xaserver__::GetCurrentDate(); - d = d.left(10) +""; - dw_list.SaveAs(d); - return 1; - } - int OnSelectAllRow() - { - int rows = this.dw_list.GetRowCount(); - if(rows < 1) return -1; - this.dw_list.SelectRow(1, rows, true); - this.dw_list.Redraw(); - return 1; - } - int OnRowCopy() - { - int rows = this.dw_list.GetRowCount(); - if(rows < 1) return -1; - int cols = this.dw_list.GetColumnCount(); - string str = ""; - int row = this.dw_list.GetNextSelectRow(1); - int i; - while(row > 0) - { - string tmp1 = ""; - for(i=1; i<cols; i++) - { - int w = this.dw_list.GetColumnWidth(i); - if(w < 5) continue; - string tmp; - if(this.dw_list.GetItemDisplayString(row, i + 1)) - tmp = this.dw_list.GetItemDisplayString(row, i + 1); - else - tmp = this.dw_list.GetItemString(row, i + 1); - tmp1 += tmp + "\t"; - } - str += tmp1 + "\r\n"; - row = this.dw_list.GetNextSelectRow(row + 1); - } - this.dw_list.SetDataToClip(str); - return 1; - } - int OnColCopy(string col) - { - int rows = this.dw_list.GetRowCount(); - if(rows < 1) return -1; - string str = ""; - int row = this.dw_list.GetNextSelectRow(1); - while(row > 0) - { - string tmp; - if(this.dw_list.GetItemDisplayString(row, col)) - tmp = this.dw_list.GetItemDisplayString(row,col); - else - tmp = this.dw_list.GetItemString(row, col); - str += tmp + "\r\n"; - row = this.dw_list.GetNextSelectRow(row + 1); - } - this.dw_list.SetDataToClip(str); - - return 1; - } - int OnRClick(ref TNotifyEvent evt,int p) - { - ref DWNMHDR hdr = evt.pnmh; - int row = hdr.row; - - int m = win__::CreatePopupMenu(); - int MF_STRING = 0x00000000; - int MF_DISABLED = 0x00000002; - int TPM_RIGHTBUTTON = 0x0002; - int TPM_RETURNCMD = 0x0100; - int MF_CHECKED = 0x8; - int MF_SEPARATOR = 0x0800; - win__::AppendMenu(m,MF_STRING, 1, "复制行"); - win__::AppendMenu(m,MF_STRING, 101, "复制列"); - win__::AppendMenu(m,MF_SEPARATOR, -1, ""); - win__::AppendMenu(m,MF_STRING, 2, "全选"); - win__::AppendMenu(m,MF_SEPARATOR, -1, ""); - win__::AppendMenu(m,MF_STRING, 4, "导出到Excel"); - win__::AppendMenu(m,MF_SEPARATOR, -1, ""); - win__::AppendMenu(m,MF_STRING, 6, "显示列设置"); - xrect xr; - xpoint pt; - win__::GetCursorPos(pt); - int ret=win__::TrackPopupMenu(m, TPM_RIGHTBUTTON | TPM_RETURNCMD, pt.x, pt.y, 0, this.GetHWND(), xr); - - //trace(ret); - int hCursor = xutil__::SetCursorWait(); - if(ret == 1) {OnRowCopy();} - else if(ret == 101) { - string colname=hdr.colname; - if(colname != "") - OnColCopy(colname); - } - else if(ret == 2) {OnSelectAllRow();} - else if(ret == 4) {ItemOutput();} - else if(ret == 6) {} - xutil__::RestoreCursor(hCursor); - - return 1; - } - int OnAttachEvent() - { - //获取焦点事件,用于重置工具条 - AttachEvent("WM_SETFOCUS",OnSetFocus); - //绑定工具条点击事件 - AttachEvent("WM_XCOMMAND",OnXCommand); - //获得树的选择事件 - AttachEvent("tv_1", "TVN_SELCHANGED",OnTreeSelChanged); - AttachEvent("dw_list","DWV_DOUBLECLICKED",OnDoubleClicked);//行双击 - AttachEvent("dw_list","DWV_RCLICKED",OnRClick);//鼠标右键 - } + dw_list.ResetUpdateStatus(); + alert(L"保存成功!"); + } + else if (comdid == L"add") { + dw.InsertRow(0); + int rows = dw.GetRowCount(); + dw.SetItemString(rows, L"GroupName", c_type); + dw.SetItemString(rows, L"BankName", c_type); + } + else if (comdid == L"insert") { + int row = dw.GetRow(); + if (row<1 || row>dw.GetRowCount()) return 0; + dw.InsertRow(row); - - string jxParam(string p, string n) + dw.SetItemString(row, L"GroupName", c_type); + } + else if (comdid == L"delet") { + dw_list.AcceptText(); + int row2 = dw.GetRow(); + if (row2<1 || row2>dw.GetRowCount()) return 0; + dw.DeleteRow(row2); + } + else if (comdid == L"adduomfolder") + adduomfolder(); + else if (comdid == L"modifyuomfolder") + modifyuomfolder(); + else if (comdid == L"deluomfolder") + deluomfolder(); + else if (comdid == L"search") + GridSearch(); + xutil::RestoreCursor(hCursor); + return 0; + } + int OnXCommand(TEvent* evt, LPARAM param) + { + return OnCmdDispatch(evt->xcommand.pStrID); + } + int OnSetFocus(TEvent* evt, LPARAM p) + { + SetAgent(); + tv_1 = new treeview; + tv_1.setNativePointer(GetControl(L"tv_1")); + + HTREEITEM root = tv_1.GetRootItem(); + tv_1.ExpandItem(root); + return 1; + } + int OnDoubleClicked(TEvent* evt, LPARAM p) + { + DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh; + int row = hdr.row; + if (row<1 || row > dw_list.GetRowCount()) return 0; + + xaserverarg arg; + + //xstring str = hdr.data; + xstring colname = hdr.colname; + xstring str = dw_list.GetItemString(row, colname); + arg.AddArg(L"value", str); + openUrl(L"/sale/view/view.dlg/xpage/memo/edit", arg); + xstring comdid = arg.GetArgString(L"comdid"); + if (comdid == L"xmOK") + { + xstring value = arg.GetArgString(L"value"); + dw_list.SetItemString(row, colname, value); + dw_list.Redraw(); + } + + return 1; + } + int ItemOutput() + { + xstring d = xaserver::GetCurrentDate(); + d = d.left(10) + L""; + dw_list.SaveAs(d); + return 1; + } + int OnSelectAllRow() + { + int rows = dw_list.GetRowCount(); + if (rows < 1) return -1; + dw_list.SelectRow(1, rows, true); + dw_list.Redraw(); + return 1; + } + int OnRowCopy() + { + int rows = dw_list.GetRowCount(); + if (rows < 1) return -1; + int cols = dw_list.GetColumnCount(); + xstring str = L""; + int row = dw_list.GetNextSelectRow(1); + int i; + while (row > 0) + { + xstring tmp1 = L""; + for (i = 1; i < cols; i++) { - if(p != "") - { - p +="&"; - int i = 1; - while (p.find("=",0)>0) - { - string name = p.mid(0, p.find("=",0)); - string value = p.mid(p.find("=",0) + 1, p.find("&",0) - p.find("=",0) - 1); - if(name==n) return ""+value; - i += 1; - p = p.mid(p.find("&",0) + 1, p.length()); - } - } - return ""; + int w = dw_list.GetColumnWidth(i); + if (w < 5) continue; + xstring tmp; + if (dw_list.GetItemDisplayString(row, i + 1)) + tmp = dw_list.GetItemDisplayString(row, i + 1); + else + tmp = dw_list.GetItemString(row, i + 1); + tmp1 += tmp + L"\t"; } - int getURLParam() + str += tmp1 + L"\r\n"; + row = dw_list.GetNextSelectRow(row + 1); + } + dw_list.SetDataToClip(str); + return 1; + } + int OnColCopy(xstring col) + { + int rows = dw_list.GetRowCount(); + if (rows < 1) return -1; + xstring str = L""; + int row = dw_list.GetNextSelectRow(1); + while (row > 0) + { + xstring tmp; + if (dw_list.GetItemDisplayString(row, col)) + tmp = dw_list.GetItemDisplayString(row, col); + else + tmp = dw_list.GetItemString(row, col); + str += tmp + L"\r\n"; + row = dw_list.GetNextSelectRow(row + 1); + } + dw_list.SetDataToClip(str); + + return 1; + } + int OnRClick(TEvent* evt, LPARAM p) + { + DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh; + int row = hdr.row; + + int m = win::CreatePopupMenu(); + int MF_STRING = 0x00000000; + int MF_DISABLED = 0x00000002; + int TPM_RIGHTBUTTON = 0x0002; + int TPM_RETURNCMD = 0x0100; + int MF_CHECKED = 0x8; + int MF_SEPARATOR = 0x0800; + win::AppendMenu(m, MF_STRING, 1, L"复制行"); + win::AppendMenu(m, MF_STRING, 101, L"复制列"); + win::AppendMenu(m, MF_SEPARATOR, -1, L""); + win::AppendMenu(m, MF_STRING, 2, L"全选"); + win::AppendMenu(m, MF_SEPARATOR, -1, L""); + win::AppendMenu(m, MF_STRING, 4, L"导出到Excel"); + win::AppendMenu(m, MF_SEPARATOR, -1, L""); + win::AppendMenu(m, MF_STRING, 6, L"显示列设置"); + xrect xr; + xpoint pt; + win::GetCursorPos(pt); + int ret = win::TrackPopupMenu(m, TPM_RIGHTBUTTON | TPM_RETURNCMD, pt.x, pt.y, 0, GetHWND(), xr); + + //trace(ret); + HCURSOR hCursor = xutil::SetCursorWait(); + if (ret == 1) { OnRowCopy(); } + else if (ret == 101) { + xstring colname = hdr.colname; + if (colname != L"") + OnColCopy(colname); + } + else if (ret == 2) { OnSelectAllRow(); } + else if (ret == 4) { ItemOutput(); } + else if (ret == 6) {} + xutil::RestoreCursor(hCursor); + + return 1; + } + int OnAttachEvent() + { + //获取焦点事件,用于重置工具条 + AttachEvent(L"WM_SETFOCUS", (FEvent)&QuickCode_Tree::OnSetFocus); + //绑定工具条点击事件 + AttachEvent(L"WM_XCOMMAND", (FEvent)&QuickCode_Tree::OnXCommand); + //获得树的选择事件 + AttachEvent(L"tv_1", L"TVN_SELCHANGED", (FEvent)&QuickCode_Tree::OnTreeSelChanged); + AttachEvent(L"dw_list", L"DWV_DOUBLECLICKED", (FEvent)&QuickCode_Tree::OnDoubleClicked);//行双击 + AttachEvent(L"dw_list", L"DWV_RCLICKED", (FEvent)&QuickCode_Tree::OnRClick);//鼠标右键 + return 1; + } + + + xstring jxParam(xstring p, xstring n) + { + if (p != L"") + { + p += L"&"; + int i = 1; + while (p.find(L"=L", 0) > 0) { - if(GetParam()) - { - xpage__ xp=new xpage__; - xp.setNativePointer(this.GetXPage()); - string aurl = xp.GetWkUrl(); - xaserverarg__ arg; - if(aurl && aurl.find("native=true",0)>0) - { - int p = this.GetParam(); - arg = new xaserverarg__; - arg.setNativePointer(p); - } - else - { - arg = GetParam(); - } - string config = arg.GetArgString("config"); - xml__ x = new xml__; - x.setNativePointer(xml__::CreateInstance()); - if(config == "") - { - string configXml = arg.GetArgString("configxml"); - x.LoadXml(configXml); - } - else - { - getUrl(config, "", x); - } - m_configDoc = x.GetXmlDoc(); - - } - - return 1; - } - int loaded() - { - getURLParam(); - msxml::IXMLDOMDocument ee=m_configDoc; - string id=m_id; - var n = ee.selectSingleNode("//list/dwview[@type='dwgrid'][@id='"+id+"']"); - if(n) - { - msxml::IXMLDOMElement e = n; - //trace(e.xml); - string vface = m_configDoc.selectSingleNode("//vface[1]").text; - string dwname = "";//e.selectsingleNode("@name").text; - string tpl = "";//e.selectsingleNode("@url").text; - string dbmap = ""; - string strtreexquery=""; - if(e.selectSingleNode("@name")) dwname = e.selectSingleNode("@name").text; - if(e.selectSingleNode("@url")) tpl = e.selectSingleNode("@url").text; - if(e.selectSingleNode("@dbmap")) dbmap = e.selectSingleNode("@dbmap").text; - if(e.selectSingleNode("@treexquery")) strtreexquery = e.selectSingleNode("@treexquery").text; - m_dbmap = dbmap; - treexquery = strtreexquery; - //trace(vface +"/"+ tpl); - //trace(selectmode); - dw_list = new xdwgrid__; - dw_list.setNativePointer(GetControl(dwname)); - dw_list.openUrl(vface +"/"+ tpl); - strtpl=tpl; - trace(tpl); - - } - } - int onload() + xstring name = p.mid(0, p.find(L"=L", 0)); + xstring value = p.mid(p.find(L"=L", 0) + 1, p.find(L"&", 0) - p.find(L"=L", 0) - 1); + if (name == n) return L"" + value; + i += 1; + p = p.mid(p.find(L"&", 0) + 1, p.length()); + } + } + return L""; + } + int getURLParam() + { + if (GetWinParam()) + { + xpage xp = new xpage; + xp.setNativePointer(GetXPage()); + xstring aurl = xp.GetWkUrl(); + xaserverarg arg; + if (aurl && aurl.find(L"native=true", 0) > 0) { + int p = GetParam(); + arg; + arg.setNativePointer(p); + } + else + { + arg = GetParam(); + } + xstring config = arg.GetArgString(L"config"); + xml x; + if (config == L"") + { + xstring configXml = arg.GetArgString(L"configxml"); + x.loadXML(configXml); + } + else + { + getUrl(config, L"", x); + } + m_configDoc = x; + + } + + return 1; + } + int loaded() + { + getURLParam(); + KXMLDOMDocument ee = m_configDoc; + xstring id = m_id; + var n = ee.selectSingleNode(L"//list/dwview[@type='dwgrid'][@id='" + id + L"']"); + if (n) + { + KXMLDOMElement e = n; + //trace(e.xml); + xstring vface = m_configDoc.selectSingleNode(L"//vface[1]").text(); + xstring dwname = L"";//e.selectsingleNode(L"@name").text(); + xstring tpl = L"";//e.selectsingleNode(L"@url").text(); + xstring dbmap = L""; + xstring strtreexquery = L""; + if (e.selectSingleNode(L"@name")) dwname = e.selectSingleNode(L"@name").text(); + if (e.selectSingleNode(L"@url")) tpl = e.selectSingleNode(L"@url").text(); + if (e.selectSingleNode(L"@dbmap")) dbmap = e.selectSingleNode(L"@dbmap").text(); + if (e.selectSingleNode(L"@treexquery")) strtreexquery = e.selectSingleNode(L"@treexquery").text(); + m_dbmap = dbmap; + treexquery = strtreexquery; + //trace(vface +L"/"+ tpl); + //trace(selectmode); + dw_list = new xdwgrid; + dw_list.setNativePointer(GetControl(dwname)); + dw_list.openUrl(vface + L"/" + tpl); + strtpl = tpl; + trace(tpl); + + } + } + int onload() + { + + SetArg(); + m_config = L"QuickCode.config"; + m_agent = L""; + dw_list = new xdwtable; + dw_list.setNativePointer(GetControl(L"dw_list")); + if (GetWinParam()) + { + xaserverarg arg = GetArg(); + //trace(arg.GetString()); + xstring id = arg.GetArgString(L"id"); + if (id == L"") return 0; + m_id = id; + loaded(); + + /*xstring tpl = arg.GetArgString(L"tpl"); + if(tpl == L"") + tpl = L"QuickCode.tpl/QuickCode"; + dw_list.SetDataObject(GetServerUrl(),L"dev:sheet["+tpl+L"]"); + //dw_list.SetColHeaderHeight(0); + //dw_list.SetRowSelectorWidth(0); + xstring dbmap = arg.GetArgString(L"dbmap"); + if(dbmap == L"") + dbmap = L"QuickCode.dbmap"; + m_dbmap = dbmap; + xstring txquery=arg.GetArgString(L"treexquery"); + treexquery=txquery; + xstring title = arg.GetArgString(L"title"); + if(title != L"") + win::SetWindowText(GetHWND(),title);*/ + OnRetrieve(); + } + SetAgent(); + xstring aa = treexquery; + xstring xfNodeAgentArea2 = L"treeagent"; + xnode tnode = new xnode; + tnode.setNativePointer(GetAgentNode(xfNodeAgentArea2)); + xstring stree = L"<vbox><xtree name='tv_1' imagelist='0'>"; + stree += L"<treeitem src='xquery:[" + aa + L"]' xcaption='@GroupName' xroot='/root' xpath='row' xchildpath='row' image='15' loop='yes' xdata='.'/>"; + stree += L"</xtree></vbox>"; + SetAgentNode(tnode, stree); + + tv_1 = new treeview; + tv_1.setNativePointer(GetControl(L"tv_1")); - m_config = "QuickCode.config"; - m_agent = ""; - dw_list = new xdwtable__; - dw_list.setNativePointer(GetControl("dw_list")); - if(this.GetParam()) - { - xaserverarg__ arg = this.GetParam(); - //trace(arg.GetString()); - string id = arg.GetArgString("id"); - if(id == "") return 0; - m_id = id; - loaded(); - - /*string tpl = arg.GetArgString("tpl"); - if(tpl == "") - tpl = "QuickCode.tpl/QuickCode"; - dw_list.SetDataObject(GetServerUrl(),"dev:sheet["+tpl+"]"); - //dw_list.SetColHeaderHeight(0); - //dw_list.SetRowSelectorWidth(0); - string dbmap = arg.GetArgString("dbmap"); - if(dbmap == "") - dbmap = "QuickCode.dbmap"; - m_dbmap = dbmap; - string txquery=arg.GetArgString("treexquery"); - treexquery=txquery; - string title = arg.GetArgString("title"); - if(title != "") - win__::SetWindowText(this.GetHWND(),title);*/ - OnRetrieve(); - } - SetAgent(); - string aa=treexquery; - string xfNodeAgentArea2 = "treeagent"; - xnode__ tnode = new xnode__; - tnode.setNativePointer(GetAgentNode(xfNodeAgentArea2)); - string stree="<vbox><xtree name='tv_1' imagelist='0'>"; - stree +="<treeitem src='xquery:["+aa+"]' xcaption='@GroupName' xroot='/root' xpath='row' xchildpath='row' image='15' loop='yes' xdata='.'/>"; - stree +="</xtree></vbox>"; - SetAgentNodeContent (tnode,stree); + HTREEITEM root = tv_1.GetRootItem(); + tv_1.ExpandItem( root); + OnAttachEvent(); - tv_1 = new treeview__; - tv_1.setNativePointer(this.GetControl("tv_1")); - int wid = tv_1.GetId(); - int root = treeview__::GetRootItem(wid); - treeview__::ExpandItem(wid,root); - OnAttachEvent(); - - return 1; - } - ] - ] -] \ No newline at end of file + return 1; + } +}; \ No newline at end of file -- Gitblit v1.9.3