From a4d2315ee4ca3f6177b4fb2526bed2feff3d89be Mon Sep 17 00:00:00 2001 From: lifan <2308045698@qq.com> Date: 星期三, 22 十月 2025 16:52:58 +0800 Subject: [PATCH] update --- jrj/project/business/Enquiry/Enquiry.maint.cpp | 1979 +++++++++++++++++++++++++++++++++++++++++++++-------------- 1 files changed, 1,487 insertions(+), 492 deletions(-) diff --git a/jrj/project/business/Enquiry/Enquiry.maint.cpp b/jrj/project/business/Enquiry/Enquiry.maint.cpp index 6c3d5bb..d2f3136 100644 --- a/jrj/project/business/Enquiry/Enquiry.maint.cpp +++ b/jrj/project/business/Enquiry/Enquiry.maint.cpp @@ -1,542 +1,1537 @@ #include <wobject/xstring.hpp> #include <xcontrol/xtreeview.hpp> #include <xcontrol/xdwgrid.hpp> +#include <wobject/xdouble.hpp> +#include <xcontrol/xlayersheet.hpp> +#include <xcontrol/xdatetimepick.hpp> +#include <xcontrol/ximageview.hpp> #include "vbusiness/vframe/listwin.vframe.vbusiness.hpp" #include "viewobject/view.base.hpp" +#include "viewobject/enquiry.view.hpp" +#include "viewobject/quote.view.hpp" using xml = KXMLDOMDocument; -class __declspec(dllexport) listSupplierv3 : public listwin -{ -public: - xdwgrid dw_goods; - xtreeview tv_1; - xcombobox ddlb_1; - int changeddlb; - xstring TypeWork; - xstring GoodsUrl; - xstring m_sType; //type - xstring m_sTypeTxt; //选中树的data - // xstring m_searchtxt; - int PIndex; - xnode m_agentNode; //Agent Condition - xstring m_agentCond; //Agent Node - -public: - listSupplierv3(void* implPtr, HWND hWnd) :listwin(implPtr, hWnd) {} -public: - static listSupplierv3* CreateInstance(void* implPtr, void* hWnd) + class __declspec(dllexport) EnquiryMaintView : public xframe { - listSupplierv3* pWin = new listSupplierv3(implPtr, (HWND)hWnd); - return pWin; - } - int OnRetrieve() - { - xml x; + public: + xdwgrid dw_goods; + xdwtable dw_base; - xaserverarg arg; - arg.AddArg(L"pageindex", xstring(PIndex)); //第几页 - arg.AddArg(L"pagenumber", xstring(listwin::m_pageNumber)); //每页数量 - arg.AddArg(L"QueryTxt", listwin::m_QueryTxt); - arg.AddArg(L"sType", m_sType); - arg.AddArg(L"sTypeTxt", m_sTypeTxt); - trace(arg.GetString()); - //alert(L"xxxx"); - if (getUrl(GetServerUrl(), L"/sale/data/" + GetEntityName(1) + L"/entity/list", arg.GetString(), x) != 1) + xnode m_agentNode; //Agent Condition + xstring sheetname; + public: + EnquiryMaintView(void* implPtr, HWND hWnd) :xframe(implPtr, hWnd) {} + public: + static EnquiryMaintView* CreateInstance(void* implPtr, void* hWnd) { - return -1; + EnquiryMaintView* pWin = new EnquiryMaintView(implPtr, (HWND)hWnd); + return pWin; } - else + int SetAgent() { - KXMLDOMElement e = x.documentElement(); - if (listwin::dw_pages && e.selectSingleNode(L"@TotalPage")) + xstring xfNodeAgentArea = L"agentarea"; + xnode anode = GetAgentNode(xfNodeAgentArea); + if (m_agentNode) { - xstring s = e.selectSingleNode(L"@TotalPage").text(); //总数量 - listwin::dw_pages.SetMaxPage(s.toInt()); + SetAgentNode(anode, m_agentNode); } - //alert(x.GetXml()); - dw_list.Retrieve(x); - dw_list.Redraw(); - dw_list.SetReadOnly(true); - } - return 1; - } - - int SetEntityData(xaserverarg arg) - { - xstring strQueryTxt = arg.GetArgString(L"QueryTxt"); - xml x; - - arg.AddArg(L"sType", m_sType); - arg.AddArg(L"sTypeTxt", m_sTypeTxt); - trace(arg.GetString()); - if (getUrl(GetServerUrl(), L"/sale/data/" + GetEntityName(1) + L"/entity/list", arg.GetString(), x) != 1) - { - alert(x.text()); - - return -1; - } - else - { - KXMLDOMElement e = x.documentElement(); - if (listwin::dw_pages && e.selectSingleNode(L"@TotalPage")) + else { - - xstring s = e.selectSingleNode(L"@TotalPage").text(); //总数量 - listwin::dw_pages.SetMaxPage(s.toInt()); - } - //trace(x.GetXml()); - listwin::dw_list.Retrieve(x); - listwin::dw_list.Redraw(); - listwin::dw_list.SetReadOnly(true); - } - - return 1; - } - - int OnChangePages(TEvent* evt, LPARAM p) - { - PAGENMHDR* h = (PAGENMHDR*)evt->notify.pnmh; - int c = h->cur; - - - HCURSOR hCursor = xutil::SetCursorWait(); - OnRetrieve(); - PIndex = c; - xutil::RestoreCursor(hCursor); - return 1; - - - } - - int ViewUpdate(int pr, xstring updateItem, xaserverarg arg) - { - if (updateItem == L"refresh") - { - //trace(L"sd"); - xdwpages zz = GetControl(L"pages"); - int h = zz.SetCurPage(1); - //trace(h); - OnRetrieve(); - } - return 1; - } - - //树选择 - int OnTreeSelChanged(TEvent evt, LPARAM p) - { - if (changeddlb != 1) - { - //alert(L"1"); - - HTREEITEM h = tv_1.GetSelectedItem(); - KXMLDOMElement& e = *(KXMLDOMElement*)tv_1.GetItemData(h); - - xstring t = e.selectSingleNode(L"@type").text(); - m_sType = t + L""; - xstring txt = e.selectSingleNode(L"@code").text(); - if (txt == L"") - txt = e.selectSingleNode(L"@name").text(); - m_sTypeTxt = txt + L""; - - //alert(m_sTypeTxt); - - PIndex = 1; - OnRetrieve(); - } - return 1; - } - - int createSubTree(HTREEITEM h, KXMLDOMElement ele) - { - KXMLDOMNodeList nlist = ele.selectNodes(L"item"); - int i; - int s = nlist.length(); - if (s > 0) - for (i = 0; i < s; i++) - { - - KXMLDOMElement* e = new KXMLDOMElement(nlist.item(i)); - xstring name = e->selectSingleNode(L"@name").text(); - HTREEITEM hw = tv_1.InsertChildItem(h, name, (LPARAM)e, 15); - createSubTree(hw, *e); - } - return 1; - } - - int OnCreateTree(xstring sType) - { - - while (tv_1.GetRootItem()) - tv_1.DeleteItem(tv_1.GetRootItem()); - - xml x; - - xaserverarg arg; - - arg.AddArg(L"sType", sType); - //Tree.pref.supplier.xq - //getUrl(GetEntityName(1)+L"/entity/list",arg.GetString(),x); - //if (xaserver::ExecXQuery(GetServerUrl(),L"[Tree.pref.supplier.xq]",arg.GetString(),x)!=1) - if (getUrl(GetServerUrl(), L"/sale/data/" + GetEntityName(1) + L"/pref/list/tree", arg.GetString(), x) != 1) - { - trace(x.text()); - return -1; - } - else - { - KXMLDOMNodeList nlist = x.selectNodes(L"root/item"); - int len = nlist.length(); - if (len > 0) - { - int i; - for (i = 0; i < len; i++) + KXMLDOMElement xframeElement = GetElement(); + KXMLDOMElement agent = xframeElement.selectSingleNode(L"agent/" + xfNodeAgentArea + L"[1]/*"); + if (agent) { - - KXMLDOMElement* e = new KXMLDOMElement(nlist.item(i)); - xstring name = e->selectSingleNode(L"@name").text(); - HTREEITEM hw = tv_1.InsertChildItem(0, name, (LPARAM)e, 15); - - createSubTree(hw, *e); - tv_1.ExpandItem(hw); + xstring s = agent.xml(); + m_agentNode = SetAgentNode(anode, s); } - tv_1.ExpandItem(0); } + return 1; } - return 1; - } + //焦点激活处理函数 + int OnSetFocus(TEvent* evt, LPARAM param) + { + //重置工具条 + SetAgent(); + return 1; + } - //xcombobox下拉 - int OnSelectDdlb(TEvent evt, LPARAM p) - { - changeddlb = 1; + xstring GetEntityData(LPARAM pr) + { + dw_base.AcceptText(); + dw_goods.AcceptText(); + if (dw_base.GetItemString(1, L"EnquiryNo") == L"") + { + xstring EnquiryNo = EnquiryView::MakeBillNo(); + dw_base.SetItemString(1, L"EnquiryNo", EnquiryNo); + } - int CB_GETCURSEL = 0x0147; - int nIndex = SendMessageW(ddlb_1.GetHWND(), CB_GETCURSEL, 0, 0); - KXMLDOMElement e = ddlb_1.GetElement();//GetitemData(wid,nIndex);//ddlb_1.GetElement(); - KXMLDOMElement e2 = e.selectSingleNode(L"item[" + xstring((nIndex + 1)) + L"]"); - xstring text = e2.selectSingleNode(L"@element").text(); - OnCreateTree(text); - changeddlb = 0; - return 1; - } + xml x ; + + xaserverarg arg; + + dw_goods.DwUpdateAllToEx(x); + dw_base.DwUpdateAllTo(x); + return x.xml(); + } - int OnDeleteRow() - { - int row = listwin::dw_list.GetNextSelectRow(1); - if (row < 1) { - row = listwin::dw_list.GetRow(); - if (row < 1) { - //win::MessageBox(GetHWND(),L"请选中要删除的行!",L"提示",0); + int SetSeqNo(xdwgrid dw_obj, xstring SeqNoColumn, int nRow) + { + if (nRow > 1) + { + int SeqNo = dw_goods.GetItemInt(nRow - 1, SeqNoColumn); + if (SeqNo != 0) SeqNo += 10; else SeqNo = nRow * 10; + dw_obj.SetItemInt(nRow, SeqNoColumn, SeqNo); + } + else + dw_obj.SetItemInt(nRow, SeqNoColumn, 10); + return 1; + } + + int Adjust() + { + xstring str; + for (int i = 1; i <= dw_goods.GetRowCount(); i++) + { + str = dw_goods.GetItemString(i, L"SupplierID"); + if (dw_goods.GetItemString(i, L"ItemID") != L"") + if (str == L"") + { + if (i > 1) + { + if (dw_goods.GetItemString(i - 1, L"SupplierID") != L"") + { + dw_goods.SetItemDisplayString(i, L"SupplierID", dw_goods.GetItemDisplayString(i - 1, L"SupplierID")); + dw_goods.ItemChangeTo(i, L"SupplierID", dw_goods.GetItemString(i - 1, L"SupplierID")); + } + } + } + } + return 1; + } + + int OnSave() + { + dw_base.AcceptText(); + dw_goods.AcceptText(); + if (dw_base.GetItemString(1, L"Remark") != L"保存") + { + + + if (dw_base.GetItemString(1, L"ValidDay") == L"") + { + alert(L"请输入有效期!"); + return 1; + } + /*if(dw_base.GetItemString(1,L"SupplierID")==L"") + { + alert(L"供应商为空!"); + return 1; + }*/ + if (dw_base.GetItemString(1, L"Source") == L"") + { + alert(L"请输入询价类别!"); + return 1; + } + xstring Packing = L""; + xstring Packings = L""; + Adjust(); + for (int i = 1; i <= dw_goods.GetRowCount(); i++) + { + if (dw_goods.GetItemString(i, L"ItemMiniQty") == L"") + { + alert(L"请输入起订量!"); + return 1; + } + if (dw_goods.GetItemString(i, L"Picture") == L"") + { + alert(L"请 " + xstring(i) + L"行,上传产品图片!"); + return 1; + } + if (dw_goods.GetItemString(i, L"POPrice") == L"" || dw_goods.GetItemString(i, L"POPrice") == L".000") + { + alert(L"请输入采购价!"); + return 1; + } + if (dw_goods.GetItemString(i, L"PriceType") == L"") + { + alert(L"请输入价格类型!"); + return 1; + } + + if (dw_goods.GetItemString(i, L"SampleFee") == L"") + { + alert(L"请输入打样费!"); + return 1; + } + if (dw_goods.GetItemString(i, L"TestFee") == L"") + { + alert(L"请输入测试费!"); + return 1; + } + if (dw_goods.GetItemString(i, L"ModelFee") == L"") + { + alert(L"请输入模具费!"); + return 1; + } + if (dw_goods.GetItemString(i, L"VolumeDesc") == L"") + { + alert(L"请输入包装尺码!"); + return 1; + } + if (dw_goods.GetItemString(i, L"WarehousingReason") == L"") + { + alert(L"请输入入库理由!"); + return 1; + } + + /*if(dw_goods.GetItemString(i,L"Packing") !=L"") + { + Packing = dw_goods.GetItemString(i,L"Packing"); + if(Packings==L"") + Packings = Packing; + else if(Packings.find(Packing) < 0) Packings+=L","+Packing; + }*/ + if (dw_goods.GetItemString(i, L"Packing") == L"") + { + alert(L"请输包装方式!"); + return 1; + } + else + { + xml xx = ViewObject::RetrieveData(L"/sale/data/Enquiry/GetPacking", L"str", dw_goods.GetItemString(i, L"Packing")); + xstring Results = xx.text(); + int ResultsInt = Results.toInt(); + if (ResultsInt == 0) + { + alert(L"第" + xstring(i) + L"行包装方式错误,请重新选择!"); + return 1; + } + } + } + + if (dw_base.GetItemString(1, L"EnquiryNo") == L"") + { + xstring EnquiryNo = EnquiryView::MakeBillNo(); + dw_base.SetItemString(1, L"EnquiryNo", EnquiryNo); + } + + trace(L"********" + Packings + L"*********"); + } + + xml x ; + + xaserverarg arg; + + dw_goods.DwUpdateAllToEx(x); + dw_base.DwUpdateAllTo(x); + + //alert(x.xml()); + + xstring error = L""; + arg.AddArg(L"content", x.xml()); + if (xurl::get(L"/sale/data/Enquiry/update", arg.GetString(), x) != 1) + { + error = x.text(); + alert(error); + } + else + { + xstring str = x.documentElement().getAttribute(L"text"); + if (str == L"true") + { + dw_goods.ResetUpdateStatus(); + dw_base.ResetUpdateStatus(); + UpdateEnquiryLineID(); + + xaserverarg arg_; + + //trace(L"\r\nSource:"+arg_.GetArgString(L"Source")); + if (arg_.GetArgString(L"Source") == L"quote") + InsertEnquiryPriceList(); + else if (arg_.GetArgString(L"Source") == L"pricebill") + InsertEnquiryPriceListByEnquiryID(); + + alert(L"保存成功!"); + HWND hWnd = 0; + if (arg_.GetArgString(L"Source") == L"pricebill") + { + if (arg_.GetArgString(L"hWnd") != L"") + { + hWnd = (HWND)arg_.GetParam(L"hWnd"); + PostMessage(hWnd, 0x401, (LPARAM)L"xmRefresh", 0); + } + } + if (arg_.GetArgString(L"Source") == L"") + { + if (arg_.GetArgString(L"hWnd") != L"") + { + hWnd = (HWND)arg_.GetParam(L"hWnd"); + PostMessage(hWnd, 0x401, (LPARAM)L"xmReresh", 0); + } + } + } + else + { + alert(L"保存失败!"); + } + } + if (x) + return 1; + } + + int InsertEnquiryPriceListByEnquiryID() + { + //trace(L"\r\nInsertEnquiryPriceListByEnquiryID Start!"); + xml x = ViewObject::RetrieveData(L"/sale/data/Enquiry/InsertEnquiryPriceListByEnquiryID", L"EnquiryID", dw_base.GetGuid(1)); + //trace(L"\r\nInsertEnquiryPriceListByEnquiryID:" + dw_base.GetGuid(1)+L" "+ x.xml()); + return 1; + } + + int InsertEnquiryPriceList() + { + xaserverarg arg; + + xstring EntityIDList = arg.GetArgString(L"EntityIDList"); + xml x = ViewObject::RetrieveData(L"/sale/data/Enquiry/InsertEnquiryPriceList", L"ItemList", EntityIDList); + xml x1 = ViewObject::RetrieveData(L"/sale/data/Enquiry/Update/UpdateQuoteLine", L"ItemList", EntityIDList); + + return 1; + } + + + int UpdateEnquiryLineID() + { + xaserverarg arg; + + int row = dw_base.GetRow(); + if (row < 1) return 0; + + xstring EnquiryID = dw_base.GetGuid(1); + + xml x = ViewObject::RetrieveData(L"/sale/data/Enquiry/Update/UpdateEnquiryLineID", L"EnquiryID", EnquiryID); + return 1; + } + + int OnSave1() + { + dw_base.AcceptText(); + dw_goods.AcceptText(); + if (dw_base.GetItemString(1, L"EnquiryNo") == L"") + { + xstring EnquiryNo = EnquiryView::MakeBillNo(); + dw_base.SetItemString(1, L"EnquiryNo", EnquiryNo); + } + + if (dw_base.GetItemString(1, L"ValidDay") == L"") + { + alert(L"请输入有效期!"); + return 1; + } + + if (dw_base.GetItemString(1, L"Source") == L"") + { + alert(L"请输入询价类别!"); + return 1; + } + xstring Packing = L""; + xstring Packings = L""; + for (int i = 1; i <= dw_goods.GetRowCount(); i++) + { + if (dw_goods.GetItemString(i, L"ItemMiniQty") == L"") + { + alert(L"请输入起订量!"); + return 1; + } + if (dw_goods.GetItemString(i, L"Picture") == L"") + { + alert(L"请 " + xstring(i) + L"行,上传产品图片!"); + return 1; + } + if (dw_goods.GetItemString(i, L"POPrice") == L"" || dw_goods.GetItemString(i, L"POPrice") == L".000") + { + alert(L"请输入采购价!"); + return 1; + } + if (dw_goods.GetItemString(i, L"PriceType") == L"") + { + alert(L"请输入价格类型!"); + return 1; + } + + if (dw_goods.GetItemString(i, L"SampleFee") == L"") + { + alert(L"请输入打样费!"); + return 1; + } + if (dw_goods.GetItemString(i, L"TestFee") == L"") + { + alert(L"请输入测试费!"); + return 1; + } + if (dw_goods.GetItemString(i, L"ModelFee") == L"") + { + alert(L"请输入模具费!"); + return 1; + } + if (dw_goods.GetItemString(i, L"VolumeDesc") == L"") + { + alert(L"请输入包装尺码!"); + return 1; + } + if (dw_goods.GetItemString(i, L"WarehousingReason") == L"") + { + alert(L"请输入入库理由!"); + return 1; + } + + + if (dw_goods.GetItemString(i, L"Packing") != L"") + { + Packing = dw_goods.GetItemString(i, L"Packing"); + if (Packings == L"") + Packings = Packing; + else if (Packings.find(Packing) < 0) Packings += L"," + Packing; + } + } + + trace(L"********" + Packings + L"*********"); + xml x ; + + xaserverarg arg; + + dw_base.DwUpdateAllTo(x); + KXMLDOMElement ele = x.documentElement(); + + xml x1 ; + dw_goods.DwUpdateAllToEx(x1); + KXMLDOMNodeList items = x1.selectNodes(L"Enquiry/Item"); + int len = items.length(); + bool processed = false; + KXMLDOMNode child; + KXMLDOMNode nodeColumn; + KXMLDOMElement eleItem; + KXMLDOMElement eleColumn; + xstring guid; + for (int k = 0; k < len; k++) + { + KXMLDOMElement e = items.item(k); + /*processed = false; + KXMLDOMNode col = e.selectSingleNode(L"QuoteNo"); + if(col) + { + if(col.text !=L"") + { + child = e.cloneNode(-1); + ele.appendChild(child); + child.release(); + processed = true; + } + col.release(); + } + if(!processed) + {*/ + xstring itemNew = e.getAttribute(L"update.new"); + xstring itemDelete = e.getAttribute(L"update.delete"); + xstring itemModify = e.getAttribute(L"update.modify"); + if (itemDelete == L"1") + { + eleItem = x.createElement(L"Item"); + eleItem.setAttribute(L"update.modify", L"1"); + guid = e.getAttribute(L"guid"); + eleItem.setAttribute(L"guid", guid); + + eleColumn = x.createElement(L"LineType"); + eleColumn.setAttribute(L"update.modify", L"1"); //delete + eleColumn.settext(L"1"); + eleItem.appendChild(eleColumn); + ele.appendChild(eleItem); + processed = true; + } + else if (itemModify == L"1") + { + if (itemNew != L"1") + { + //update origin row + eleItem = x.createElement(L"Item"); + eleItem.setAttribute(L"update.modify", L"1"); + guid = e.getAttribute(L"guid"); + eleItem.setAttribute(L"guid", guid); + + eleColumn = x.createElement(L"RealEnquiryLineID"); + eleColumn.setAttribute(L"update.modify", L"1"); + guid = publiccode::GetGuid(); + eleColumn.settext(guid); + eleItem.appendChild(eleColumn); + + eleColumn = x.createElement(L"LineType"); + eleColumn.setAttribute(L"update.modify", L"1"); + eleColumn.settext(L"1"); //modify + eleItem.appendChild(eleColumn); + ele.appendChild(eleItem); + + //insert new row + eleItem = e.cloneNode(-1); + eleItem.setAttribute(L"update.modify", L"1"); + eleItem.setAttribute(L"update.new", L"1"); + eleItem.setAttribute(L"guid", publiccode::GetGuid()); + + eleColumn = x.createElement(L"LineType"); + eleColumn.setAttribute(L"update.modify", L"1"); + eleColumn.settext(L"0"); //normal + eleItem.appendChild(eleColumn); + + nodeColumn = e.selectSingleNode(L"ModifyDate"); + if (!nodeColumn) + eleColumn = x.createElement(L"ModifyDate"); + else + eleColumn = nodeColumn; + eleColumn.settext(publiccode::GetCurrentDate()); + eleItem.appendChild(eleColumn); + + ele.appendChild(eleItem); + } + else + { + guid = e.getAttribute(L"guid"); + child = e.cloneNode(-1); + child.selectSingleNode(L"RealEnquiryLineID").settext(guid); + child.selectSingleNode(L"RelEnquiryLineID").settext(guid); + ele.appendChild(child); + //trace(child.xml); + } + } + //} + } + + xstring error = L""; + arg.AddArg(L"content", x.xml()); + if (xurl::get(L"/sale/data/Enquiry/update", arg.GetString(), x) != 1) + { + error = x.text(); + alert(error); + } + else + { + xstring str = x.documentElement().getAttribute(L"text"); + if (str == L"true") + { + alert(L"保存成功!"); + //dw_goods.ResetUpdateStatus(); + //dw_base.ResetUpdateStatus(); + OnRetrieve(dw_base.GetItemString(1, L"EnquiryNo")); + } + else + { + alert(L"保存失败!"); + } + } + if (x) + + return 1; + } + + int ImportProductByText(xstring str) + { + xstring CustomerID = dw_base.GetItemString(1, L"CustomerID"); + //trace(L"Customer:"+CustomerID); + xml x; + if (CustomerID == L"") + x = QuoteView::LookupProductsByText(str); + else + x = QuoteView::LookupProductsByText(str, CustomerID); + + if (!x) return 1; + KXMLDOMNodeList items = x.selectNodes(L"/Items/Item"); + //trace(L"********" + x.xml() + L"********"); + int len = items.length(); + if (str.find(L" ") < 0 && len > 0) len = 1; + for (int i = 0; i < len; i++) + { + KXMLDOMElement e = items.item(i); + dw_goods.InsertRow(0); + int nRow = dw_goods.GetRowCount(); + SetSeqNo(dw_goods, L"SeqNo", nRow); + dw_goods.SetItemString(nRow, L"UOMCode", L"007"); + dw_goods.SetItemDisplayString(nRow, L"UOMCode", L"PCS"); + dw_goods.SetItemString(nRow, L"KOPCode", L"120"); + dw_goods.SetItemDisplayString(nRow, L"KOPCode", L"CTNS"); + dw_goods.SetItemString(nRow, L"SKUNo", e.getAttribute(L"SKUNo")); + dw_goods.SetItemString(nRow, L"ItemID", e.getAttribute(L"SKUID")); + //dw_goods.SetItemString(nRow,L"ItemName",e.getAttribute(L"EName")); + dw_goods.SetItemString(nRow, L"ItemName", e.getAttribute(L"CName")); + dw_goods.SetItemString(nRow, L"GoodsNo", e.getAttribute(L"GoodsNo")); + dw_goods.SetItemString(nRow, L"CustomerItemNo", e.getAttribute(L"CustomerItemNo")); + dw_goods.SetItemString(nRow, L"Packing", e.getAttribute(L"Packing")); + dw_goods.SetItemString(nRow, L"VolumeDesc", e.getAttribute(L"VolumeDesc")); + dw_goods.SetItemString(nRow, L"PackingRate", e.getAttribute(L"QtyPerPkg")); + dw_goods.SetItemString(nRow, L"InnerQty", e.getAttribute(L"InnerQty")); + dw_goods.SetItemString(nRow, L"VATRefundRate", e.getAttribute(L"VATRefundRate")); + dw_goods.SetItemString(nRow, L"VATRate", e.getAttribute(L"VATRate")); + dw_goods.SetItemString(nRow, L"HSCode", e.getAttribute(L"HSCode")); + //trace(L"+++++L"+e.getAttribute(L"Picture")+L"+++++L"); + dw_goods.SetItemString(nRow, L"Picture", e.getAttribute(L"Picture")); + + if (dw_goods.GetItemString(nRow, L"VolumeDesc") != L"" && + dw_goods.GetItemString(nRow, L"Packages") != L"") + { + int qty = EvalQtyPerFCL45H(nRow); + dw_goods.SetItemString(nRow, L"Packages45H", xstring(qty)); + dw_goods.SetItemDouble(nRow, L"TransportationFee", 5000.0 / qty); + } + /* + dw_goods.SetItemString(nRow,L"NwPerPkg",e.getAttribute(L"NwPerPkg")); + dw_goods.SetItemString(nRow,L"GwPerPkg",e.getAttribute(L"GwPerPkg")); + dw_goods.SetItemString(nRow,L"QTYPerPk",e.getAttribute(L"QTYPerPk")); + dw_goods.SetItemString(nRow,L"InnerQty",e.getAttribute(L"InnerQty")); + */ + } + + int row = dw_goods.GetRow(); + if (row >= 1) + { + ximageview im = GetControl(L"im1"); + im.Reset(); + xstring skuno = dw_goods.GetItemString(row, L"SKUNo"); + OnShowImage(skuno, row); + im.Redraw(); + } + return 1; + } + + double EvalCost(int row) + { + double cost = 0.0; + cost += dw_goods.GetItemDouble(row, L"POPrice"); + cost += dw_goods.GetItemDouble(row, L"PaperCardPrice"); + cost += dw_goods.GetItemDouble(row, L"TransportationFee"); + cost += dw_goods.GetItemDouble(row, L"OtherFee"); + cost += dw_goods.GetItemDouble(row, L"ManagementFee"); + return cost; + } + + double EvalRefund(int row) + { + double VATRefundRate = dw_goods.GetItemDouble(row, L"VATRefundRate"); + double VATRefund = dw_goods.GetItemDouble(row, L"POPrice") * VATRefundRate / 117.0; + VATRefund += dw_goods.GetItemDouble(row, L"PaperCardPrice") * 13.0 / 117.0; + return VATRefund; + } + + int EvalQtyPerFCL45H(int row) + { + double vol = EvalVol(dw_goods.GetItemString(row, L"VolumeDesc")); + double packages = dw_goods.GetItemDouble(row, L"Packages"); + return xdouble((packages * 67.0 / vol)).toInt(); + } + double EvalUnitProfit(int row) + { + double ExchangeRate = dw_base.GetItemDouble(1, L"ExchangeRate"); + double FobUnitPrice = dw_goods.GetItemDouble(row, L"FobUnitPrice"); + double UnitCost = dw_goods.GetItemDouble(row, L"UnitCost"); + double VATRefund = dw_goods.GetItemDouble(row, L"VATRefund"); + return ExchangeRate * FobUnitPrice - UnitCost + VATRefund; + } + + double EvalProfitRate(int row) + { + double UnitProfit = EvalUnitProfit(row); + double UnitCost = dw_goods.GetItemDouble(row, L"UnitCost"); + return UnitProfit / UnitCost; + } + double EvalSaleProfitRate(int row) + { + double UnitProfit = EvalUnitProfit(row); + double FobUnitPrice = dw_goods.GetItemDouble(row, L"FobUnitPrice"); + return UnitProfit / FobUnitPrice; + } + + double EvalExchangeCostRate(int row) + { + double FobUnitPrice = dw_goods.GetItemDouble(row, L"FobUnitPrice"); + double UnitCost = dw_goods.GetItemDouble(row, L"UnitCost"); + double VATRefund = dw_goods.GetItemDouble(row, L"VATRefund"); + return (UnitCost - VATRefund) / FobUnitPrice; + } + + double EvalTransportationFee(int row) + { + double vol = EvalVol(dw_goods.GetItemString(row, L"VolumeDesc")); + double packages = dw_goods.GetItemDouble(row, L"Packages"); + return 80 * vol / packages; + } + + double EvalVol(xstring value) + { + double vol = 1.0; + xstring volstr = value; + int pos1 = volstr.find(L"*"); + int pos2 = volstr.find(L"X"); + int pos3 = volstr.find(L"x"); + int pos = pos1; + //trace(L"pos: "+ pos.toString() + L"pos1: "+ pos1.toString() + L"pos2: "+ pos2.toString() +L"pos3: "+ pos3.toString()); + if (pos2 > 0 && pos == -1) pos = pos2; + if (pos2 >= 0 && pos2 < pos) pos = pos2; + //trace(L"pos: "+ pos.toString() + L"pos1: "+ pos1.toString() + L"pos2: "+ pos2.toString() +L"pos3: "+ pos3.toString()); + if (pos3 > 0 && pos == -1) pos = pos3; + if (pos3 >= 0 && pos3 < pos) pos = pos3; + //trace(L"pos: "+ pos.toString() + L"pos1: "+ pos1.toString() + L"pos2: "+ pos2.toString() +L"pos3: "+ pos3.toString()); + while (pos >= 0) + { + xstring tm = volstr.left(pos); + volstr = volstr.mid(pos + 1, 9999); + vol *= tm.toDouble(); + + pos1 = volstr.find(L"*"); + pos2 = volstr.find(L"X"); + pos3 = volstr.find(L"x"); + pos = pos1; + if (pos2 > 0 && pos == -1) pos = pos2; + if (pos2 >= 0 && pos2 < pos) pos = pos2; + if (pos3 > 0 && pos == -1) pos = pos3; + if (pos3 >= 0 && pos3 < pos) pos = pos3; + } + if (volstr != L"") vol *= volstr.toDouble(); + return vol / 1000000.0; + } + + int OnShare() + { + xaserverarg arg; + + arg.AddArg(L"EntityID", dw_base.GetGuid(1)); + //arg.AddArg(L"EntityName", GetEntityName(0)); + arg.AddArg(L"EntityName", L"Enquiry3"); + + OpenWindow(L"dev:xpage[UserGroupShare.vx]",arg ); + return 1; + } + + int OnItemChanged(TEvent* evt, int p) + { + DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh; + xstring colname = hdr.colname; + xstring value = hdr.data; + int row = hdr.row; + + double VATRefund = 0.0; + double VATRefundRate = 0.0; + if ((colname == L"GoodsNo" || colname == L"CustomerItemNo") && value != L"") + { + if (colname == L"CustomerItemNo") + { + if (dw_goods.GetItemString(row, L"GoodsNo") != L"") return 1; + } + xml x; + xstring CustomerID = dw_base.GetItemString(1, L"CustomerID"); + xstring sval = value; + if (colname == L"GoodsNo") + { + if (CustomerID != L"") + sval = L"gs:" + value; + else + sval = value; + } + if (colname == L"CustomerItemNo") + /*sval=L"cs:"+value; + if(CustomerID !=L"") + x = QuoteView::LookupProductsByText(sval,CustomerID ); + else + x = QuoteView::LookupProductsByText(sval);*/ + sval = value; + x = ViewObject::RetrieveData(L"/sale/data/Quote/LookGDN", L"str", sval); + if (!x) return 1; + KXMLDOMNodeList items = x.selectNodes(L"/Items/Item"); + trace(x.xml()); + int len = items.length(); + if (len == 0) + { + if (colname == L"GoodsNo") + { + alert(L"没有此公司型号!"); + dw_goods.SetItemString(dw_goods.GetRow(), L"GoodsNo", L""); + } + return 1; + } + if (len >= 1) + { + KXMLDOMElement e = items.item(0); + int nRow = dw_goods.GetRow(); + dw_goods.SetItemString(nRow, L"SKUNo", e.getAttribute(L"SKUNo")); + dw_goods.SetItemString(nRow, L"ItemID", e.getAttribute(L"SKUID")); + dw_goods.SetItemString(nRow, L"ItemName", e.getAttribute(L"CName")); + if (colname == L"CustomerItemNo")dw_goods.SetItemString(nRow, L"GoodsNo", e.getAttribute(L"GoodsNo")); + if (colname == L"GoodsNo")dw_goods.SetItemString(nRow, L"CustomerItemNo", e.getAttribute(L"CustomerItemNo")); + dw_goods.SetItemString(nRow, L"Packing", e.getAttribute(L"Packing")); + dw_goods.SetItemString(nRow, L"InnerQty", e.getAttribute(L"InnerQty")); + dw_goods.SetItemString(nRow, L"PackingRate", e.getAttribute(L"PackingRate")); + dw_goods.SetItemString(nRow, L"VolumeDesc", e.getAttribute(L"VolumeDesc")); + dw_goods.SetItemString(nRow, L"Packages", e.getAttribute(L"QTYPerPkg")); + dw_goods.SetItemString(nRow, L"SupplierID", e.getAttribute(L"SupplierID")); + dw_goods.SetItemDisplayString(nRow, L"SupplierID", e.getAttribute(L"SupplierID1")); + dw_goods.SetItemString(nRow, L"POCreatorID", e.getAttribute(L"POCreatorID")); + dw_goods.SetItemDisplayString(nRow, L"POCreatorID", e.getAttribute(L"POCreatorID1")); + dw_goods.SetItemString(nRow, L"Picture", e.getAttribute(L"Picture")); + + if (dw_goods.GetItemString(nRow, L"VolumeDesc") != L"" && + dw_goods.GetItemString(nRow, L"Packages") != L"") + { + int qty1 = EvalQtyPerFCL45H(nRow); + dw_goods.SetItemString(nRow, L"Packages45H", xstring(qty1)); + dw_goods.SetItemDouble(nRow, L"TransportationFee", 5000.0 / qty1); + } + dw_goods.Redraw(); + } + } + + else if (colname == L"POPrice" || colname == L"PaperCardPrice" || colname == L"TransportationFee" || + colname == L"OtherFee" || colname == L"ManagementFee") + { + dw_goods.SetItemDouble(row, L"UnitCost", EvalCost(row)); + + if ((colname == L"POPrice" || colname == L"PaperCardPrice") && dw_goods.GetItemString(row, L"VATRefundRate") != L"") + { + dw_goods.SetItemDouble(row, L"VATRefund", EvalRefund(row)); + } + } + else if (colname == L"VATRefundRate" && value != L"") + { + dw_goods.SetItemDouble(row, L"VATRefund", EvalRefund(row)); + } + else if (colname == L"VolumeDesc" || colname == L"Packages") + { + if (dw_goods.GetItemString(row, L"VolumeDesc") != L"" && + dw_goods.GetItemString(row, L"Packages") != L"") + { + int qty = EvalQtyPerFCL45H(row); + dw_goods.SetItemString(row, L"Packages45H", xstring(qty)); + dw_goods.SetItemDouble(row, L"TransportationFee", EvalTransportationFee(row)); + dw_goods.SetItemDouble(row, L"UnitCost", EvalCost(row)); + } + } + else if (colname == L"FobUnitPrice") + { + xstring CurrencyCode = dw_base.GetItemString(1, L"CurrencyCode"); + xstring expRate = L""; + xstring exchRate = L""; + + xml x0 = ViewObject::RetrieveData(L"/sale/data/GDN3/profit/param", L"item", L"dcomp_amt"); + if (x0.selectSingleNode(L"root/item/@value")) + expRate = x0.selectSingleNode(L"root/item/@value").text(); + x0 = ViewObject::RetrieveData(L"/sale/data/GDN3/profit/param", L"item", L"cryrate"); + if (x0.selectSingleNode(L"root/item/@value")) + exchRate = x0.selectSingleNode(L"root/item/@value").text(); + double r1 = exchRate.toDouble(); + double r2 = expRate.toDouble(); + double val = value.toDouble(); + if (CurrencyCode == L"RMB" || CurrencyCode == L"CNY") + { + if (exchRate != L"") + { + double ManagementFee = (val / r1) * r2; + double OtherFee = (val / r1) * 0.2; + dw_goods.SetItemDouble(row, L"ManagementFee", ManagementFee); + dw_goods.SetItemDouble(row, L"OtherFee", OtherFee); + } + } + else + { + dw_goods.SetItemDouble(row, L"ManagementFee", val * 0.15); + dw_goods.SetItemDouble(row, L"OtherFee", val * 0.2); + } + dw_goods.SetItemDouble(row, L"UnitCost", EvalCost(row)); + } + if (dw_goods.GetItemString(row, L"FobUnitPrice") != L"" && + dw_goods.GetItemString(row, L"POPrice") != L"" && + dw_goods.GetItemString(row, L"VolumeDesc") != L"" && + dw_goods.GetItemString(row, L"Packages") != L"") + { + dw_goods.SetItemDouble(row, L"UnitProfit", EvalUnitProfit(row)); + dw_goods.SetItemDouble(row, L"ProfitRate", EvalProfitRate(row)); + dw_goods.SetItemDouble(row, L"SaleProfitRate", EvalSaleProfitRate(row)); + dw_goods.SetItemDouble(row, L"ExchangeCostRate", EvalExchangeCostRate(row)); + } + + dw_goods.SetItemString(row, L"ModifyDate", publiccode::GetCurrentDate()); + dw_goods.Redraw(); + + return 1; + } + + int OnBaseItemChanged(TEvent* evt, int p) + { + DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh; + xstring colname = hdr.colname; + xstring value = hdr.data; + + xstring dwname = L"dw_base"; + if (value != L"") + { + //trace(L"\r\nsupplierid:"+value); + KXMLDOMNodeList nlist = GetElement().selectNodes(L"//*[@name='" + dwname + L"']/trans[@for='" + colname + L"']"); + ViewObject::TransData(nlist, dw_base, hdr.row, colname, value); + } + if (colname == L"ExchangeRate") + { + if (dw_goods.GetRowCount() > 0) + { + for (int i = 1; i <= dw_goods.GetRowCount(); i++) + { + dw_goods.SetItemDouble(i, L"UnitProfit", EvalUnitProfit(i)); + dw_goods.SetItemDouble(i, L"ProfitRate", EvalProfitRate(i)); + dw_goods.SetItemDouble(i, L"SaleProfitRate", EvalSaleProfitRate(i)); + dw_goods.SetItemDouble(i, L"ExchangeCostRate", EvalExchangeCostRate(i)); + } + } + dw_goods.Redraw(); + } + + return 1; + } + + int OnPriceEval() + { + OpenWindow(L"dev:xpage[eval.Enquiry3.vx]", (LPARAM)&dw_goods); + return 1; + } + + + int OnRowChanged(TEvent* evt, int p) + { + DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh; + int row = hdr.row; + + ximageview im = GetControl(L"im1"); + im.Reset(); + xstring skuno = dw_goods.GetItemString(row, L"SKUNo"); + OnShowImage(skuno, row); + im.Redraw(); + + return 1; + } + + int OnShowImage() + { + int rowCount = dw_goods.GetRowCount(); + xstring skunos; + for (int i = 1; i <= rowCount; i++) + { + xstring skuno = dw_goods.GetItemString(i, L"SKUNo"); + if (i == 1) + skunos = skuno; + else + skunos += L"," + skuno; + } + + xaserverarg arg_pic; + + arg_pic.AddArg(L"SKUNoList", skunos); + arg_pic.SetParam(L"ParentWindow", GetHWND()); + arg_pic.AddArg(L"OpenFlag", L"1"); + OpenWindow(L"dev:xpage[SKU.PictureView.Product3.vx]",arg_pic); + + return 1; + } + + int OnShowImage(xstring skuno, int row) + { + ximageview im = GetControl(L"im1"); + + xml xp ; + + xaserverarg arg_pic; + + arg_pic.AddArg(L"SKUNo", skuno); + + xstring res = L"/sale/data/ProductLibrary3/pref/picture/imagelistSKUNo"; + xstring customerID = dw_base.GetItemString(1, L"CustomerID"); + xstring customerItemNo = dw_goods.GetItemString(row, L"CustomerItemNo"); + KXMLDOMNodeList nlistp; + int lenp = 0; + int ip = 0; + KXMLDOMElement xitem ; + xstring picname = L""; + xstring goodno = L""; + if (customerItemNo != L"") + { + //trace(customerID+L":"+customerItemNo); + res = L"/sale/data/ProductLibrary3/pref/picture/customer/imagelistSKUNo"; + arg_pic.AddArg(L"CustomerID", customerID); + arg_pic.AddArg(L"CustomerItemNo", customerItemNo); + } + + bool hasIamge = false; + if (xurl::get(res, arg_pic.GetString(), xp) != 1) + { + //trace(xp.xml()); + return 1; + } + else + { + //trace(xp.xml()); + nlistp = xp.selectNodes(L"ImageList/image"); + lenp = nlistp.length(); + for (ip = 0; ip < lenp; ip++) + { + hasIamge = true; + xitem = nlistp.item(ip); + picname = xitem.selectSingleNode(L"PicPath").text(); + goodno = xitem.selectSingleNode(L"GoodsNo").text(); + if (picname == L"/business/products/Thumbs//") + picname = L"/business/products/Thumbs/00/00000000-0000-0000-0000-000000000000.jpg"; + im.AddImages(picname, goodno); + } + } + if (!hasIamge) + { + res = L"/sale/data/ProductLibrary3/pref/picture/imagelistSKUNo"; + if (xurl::get(res, arg_pic.GetString(), xp) != 1) + { + //trace(xp.xml()); + return 1; + } + else + { + nlistp = xp.selectNodes(L"ImageList/image"); + lenp = nlistp.length(); + for (ip = 0; ip < lenp; ip++) + { + xitem = nlistp.item(ip); + picname = xitem.selectSingleNode(L"PicPath").text(); + goodno = xitem.selectSingleNode(L"GoodsNo").text(); + if (picname == L"/business/products/Thumbs//") + picname = L"/business/products/Thumbs/00/00000000-0000-0000-0000-000000000000.jpg"; + im.AddImages(picname, goodno); + } + } + } + return 1; + } + + + int OnPrint() + { + if (dw_base.GetItemString(1, L"EnquiryNo") == L"") + { + alert(L"请先保存数据!"); + return 1; + } + xaserverarg& arg = *new xaserverarg; + + arg.AddArg(L"EntityName", L"Enquiry", L""); + arg.AddArg(L"EntityID", dw_base.GetItemString(1, L"EnquiryID"), L""); + arg.AddArg(L"EntityNo", dw_base.GetItemString(1, L"EnquiryNo"), L""); + + openUrl(L"/sale/view/view.base/xpage/Template/PrintViewEx", &arg); + return 1; + } + + int ReSeqNo(xstring SeqNoColumn) + { + for (int i = 1; i <= dw_goods.GetRowCount(); i++) + { + dw_goods.SetItemString(i, SeqNoColumn, xstring((i * 10))); + } + dw_goods.Redraw(); + return 1; + } + + int OnAskGoodsNo() + { + int rowCount = dw_goods.GetRowCount(); + xstring skunos = L""; + + for (int i = 1; i <= rowCount; i++) + { + if (dw_goods.GetItemString(i, L"SKUNo") != L"" && dw_goods.GetItemString(i, L"GoodsNo") == L"" && dw_goods.GetItemString(i, L"Submitter") == L"") + { + if (skunos == L"") + skunos = dw_goods.GetItemString(i, L"SKUNo"); + else + skunos += L"," + dw_goods.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"xmNewProduct") + { + //xaserverarg arg; + // + openUrl(L"/sale/view/Enquiry3/xpage/quick/newestproduct"); + return 1; + } + else if (comdid == L"xmPrint") return OnPrint(); + else if (comdid == L"xmImage") + return OnShowImage(); + else if (comdid == L"xmShare") + return OnShare(); + else if (comdid == L"xmImportProduct") + { + xstring str = xcontrol(GetControl(L"goods")).GetText(); + str = str.trim(); + if (str == L"") + { + xaserverarg arg1; + + arg1.SetParam(L"HWND", GetHWND()); + arg1.AddArg(L"CustomerID", dw_base.GetItemString(1, L"CustomerID")); + OpenWindow(L"dev:xpage[Entity.Product.Select.vx]",arg1); + int row = dw_goods.GetRow(); + if (row >= 1) + { + ximageview im = GetControl(L"im1"); + im.Reset(); + xstring skuno = dw_goods.GetItemString(row, L"SKUNo"); + OnShowImage(skuno, row); + im.Redraw(); + } + } + else + ImportProductByText(str); + return 1; + } + else if (comdid == L"xmSave") + { + OnSave(); + return 1; + } + else if (comdid == L"xmPriceEval") + return OnPriceEval(); + else if (comdid == L"xmOpen") + { + xaserverarg arg; + + OpenWindow(L"dev:xpage[SOEnquiry.list.vx]",arg); + if (arg.GetArgString(L"id") != L"") return OnRetrieve(arg.GetArgString(L"id")); + return 1; + } + else if (comdid == L"xmDeleteRow") + { + if (dw_goods.GetItemString(dw_goods.GetRow(), L"QuoteNo") != L"") + { + alert(L"产品已被应用,不能删除"); + return 1; + } + dw_goods.DeleteRow(0); + return 1; + } + else if (comdid == L"xmBOMSchema") + { + OpenWindow(L"dev:xpage[ProductSchema.vx]", 0); + return 1; + } + else if (comdid == L"xmProductDesc") + { + xaserverarg arg2=GetArg(); + + int row2 = dw_goods.GetRow(); + if (row2 < 1) return 0; + xstring str2 = dw_goods.GetItemString(row2, L"ProductDesc"); + arg2.AddArg(L"value", str2); + OpenWindow(L"dev:xpage[memo.edit.new.vx]", arg2); + + if (arg2.GetArgString(L"comdid") == L"xmOK") + { + str2 = arg2.GetArgString(L"value"); + dw_goods.AcceptText(); + dw_goods.SetItemString(row2, L"ProductDesc", str2); + dw_goods.Redraw(); + } + return 1; + } + else if (comdid == L"xmReSeqNo") + { + if (MessageBox(GetHWND(), L"是否重置序号!", L"提示1", 1) == 2) + return 1; + return ReSeqNo(L"SeqNo"); + } + else if (comdid == L"xmAddRow") + { + int nRow = dw_goods.InsertRow(0); + SetSeqNo(dw_goods, L"SeqNo", nRow); + dw_goods.SetItemString(nRow, L"UOMCode", L"007"); + dw_goods.SetItemDisplayString(nRow, L"UOMCode", L"PCS"); + dw_goods.SetItemString(nRow, L"KOPCode", L"120"); + dw_goods.SetItemDisplayString(nRow, L"KOPCode", L"CTNS"); + + xaserverarg arg3; + + int row3 = dw_goods.GetRow(); + if (row3 < 1) return 0; + dw_goods.SetItemString(nRow, L"SKUNo", dw_goods.GetItemString(row3, L"SKUNo")); + dw_goods.SetItemString(nRow, L"ItemID", dw_goods.GetItemString(row3, L"ItemID")); + return 1; + } + else if (comdid == L"xmClose") + { + CloseWindow(); + return 1; + } + else if (comdid.find(L"ImportXml:", 0) == 0) + { + xstring strImport = comdid.mid(((xstring)L"ImportXml:").length(), 9999); + + ImportProductByText(strImport); + return 1; + } + else if (comdid == L"xmAskGoodsNo") + { + return OnAskGoodsNo(); + } + return 0; + } + + int OnImgDBClicked(TEvent* evt, LPARAM pr) + { + IMGNNMHDR& nmtv = *(IMGNNMHDR*)evt->notify.pnmh; + xstring src = nmtv.path; + /*if(src.length() > 60) + src = src.right(44); + else + src=src.mid(src.find(L"Thumbs", 0)+6, 50); + */ + xaserverarg& arg = *new xaserverarg; + + //arg.AddArg(L"src",L"/business/products/chanpin"+src); + arg.AddArg(L"src", src); + + //win::OpenWindow(L"dev:xpage[BigPicture.vx]",arg); + + int h = openUrl(L"/sale/view/ProductLibrary/xpage/bigpictureview", &arg); + return 1; + /* + xwin x = new xwin; + x.setNativePointer(h); + m_winHwnd = x.GetHWND(); + + xstring sh = doc.xml(); + int p = cast(sh as int); + win32::SendMessage(m_winHwnd, 0x401, p, 0); + */ + return 1; + } + + //命令处理事件 + int OnXCommand(TEvent* evt, LPARAM param) + { + return OnCmdDispatch(evt->xcommand.pStrID); + } + + int OnItemAskStyle(TEvent* evt, int p) + { + DWASKSTYLENMHDR& hdr = *(DWASKSTYLENMHDR*)evt->notify.pnmh; + int DMS_CSSSTYLE = 0x8; + int row = hdr.row; + int col = hdr.col; + xstring colname = hdr.colname; + + int rows = dw_goods.GetRowCount(); + if (row < 1 || row > rows) + { + return 1; + } + if (colname == L"POPrice") + { + if (dw_goods.GetItemTipString(row, colname) != L"") + { + hdr.mask = DMS_CSSSTYLE; + hdr.pCssStyle = (LPTSTR)L"color:#cc0000"; + } + } + return 1; + } + int OnAttachEvent() + { + //绑定工具条点击事件 + AttachEvent(L"WM_XCOMMAND", (FEvent)&EnquiryMaintView::OnXCommand); + //获取焦点事件,用于重置工具条 + AttachEvent(L"WM_SETFOCUS", (FEvent)&EnquiryMaintView::OnSetFocus); + AttachEvent(L"dw_goods", L"DWV_ITEMCHANGED", (FEvent)&EnquiryMaintView::OnItemChanged); + AttachEvent(L"dw_base", L"DWV_ITEMCHANGED", (FEvent)&EnquiryMaintView::OnBaseItemChanged); + AttachEvent(L"im1", L"IMG_LDBCLICK", (FEvent)&EnquiryMaintView::OnImgDBClicked); + AttachEvent(L"dw_goods", L"DWV_ROWFOCUSCHANGED", (FEvent)&EnquiryMaintView::OnRowChanged); + AttachCloseWindow(); + AttachEvent(L"dw_goods", L"DWV_ASKSTYLE", (FEvent)&EnquiryMaintView::OnItemAskStyle); + + return 1; + } + + int OnRetrieve(xstring id) + { + xml x ; + + xaserverarg arg; + + arg.AddArg(L"id", id); + if (getUrl(L"/sale/data/Enquiry/maint", arg.GetString(), x) != 1) + { + alert(x.text()); return -1; } - } - - KXMLDOMElement e = listwin::dw_list.GetRowElement(row); - //xstring sguid = e.SelectSingleNode(L"@guid").text; - //xstring sName = e.selectSingleNode(L"Name").text+L""; - xstring sguid = dw_list.GetItemString(dw_list.GetRow(), L"SupplierID"); - xstring sName = dw_list.GetItemString(dw_list.GetRow(), L"Name"); - int MB_YESNO = 0x00000004; - int IDYES = 6; - if (MessageBoxW(GetHWND(), L"确认要删除供应商 " + sName + L" 的信息吗?", L"提示", MB_YESNO) != IDYES) return 1; - xml x; - - xaserverarg arg; - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg(L"guid", sguid); - arg.AddArg(L"EntityID", sguid); - // trace(sguid); - if (xurl::post(GetServerUrl(), L"/sale/data/" + GetEntityName(1) + L"/entity/delete", arg.GetString(), x) != 1) - { - xstring error = x.text(); - trace(error); - } - else - { - KXMLDOMElement msg = x.selectNodes(L"process").item(0); - xstring success = msg.selectSingleNode(L"@finished").text(); - if (success == L"0") + else { - alert(msg.selectSingleNode(L"@errInfo").text()); + //alert(x.xml()); + dw_base.Retrieve(x); + dw_goods.Retrieve(x); + dw_base.Redraw(); + dw_goods.Redraw(); + + if (dw_goods.GetRowCount() > 0) + { + ximageview im = GetControl(L"im1"); + im.Reset(); + xstring skuno = dw_goods.GetItemString(1, L"SKUNo"); + OnShowImage(skuno, 1); + im.Redraw(); + } + + //x.LoadXml(L"<Enquiry/>"); + //dw_base.RetrieveDiff(x); + //dw_goods.RetrieveDiff(x); + + //dw_goods.SetItemTipString(1,L"POPrice",L"21.4 2018/07/08\r\n23.4 2018/07/12"); + } + return 1; + } + + int Oncopy(xstring EnquiryID, xstring ItemID) + { + xaserverarg arg; + + + + dw_base.SetItemString(1, L"ValidDay", arg.GetArgString(L"ValidDay")); + dw_base.SetItemString(1, L"SONo", arg.GetArgString(L"SONo")); + dw_base.SetItemString(1, L"Remark", arg.GetArgString(L"Remark")); + dw_base.SetItemString(1, L"Source", arg.GetArgString(L"Source")); + dw_base.SetItemString(1, L"PayTerm", arg.GetArgString(L"PayTerm")); + dw_base.SetItemString(1, L"SupplierID", arg.GetArgString(L"SupplierID")); + dw_base.SetItemDisplayString(1, L"SupplierID", arg.GetArgString(L"SupplierID/@_displaystring")); + dw_base.SetItemString(1, L"CustomerContactName", arg.GetArgString(L"CustomerContactName")); + dw_base.SetItemString(1, L"ContactTel", arg.GetArgString(L"ContactTel")); + + xstring sdate = publiccode::GetCurrentDate(); + dw_base.SetItemString(1, L"EnquiryDate", sdate); + xstring suserid = publiccode::GetUser().id; + xstring susername = publiccode::GetUser().name; + dw_base.SetItemString(1, L"SalespersonID", suserid); + dw_base.SetItemDisplayString(1, L"SalespersonID", susername); + dw_base.SetItemString(1, L"CompanyID", L"E9E3C542-062C-4957-B8F4-9B92C3E351FC"); + dw_base.SetItemDisplayString(1, L"CompanyID", L"宁波家尔佳进出口有限公司"); + + //xml x = QuoteView::Oncopy(EnquiryID,ItemID); + + xml x = ViewObject::RetrieveData(L"/sale/data/Enquiry/Oncopy", L"EnquiryID", EnquiryID, L"ItemID", ItemID); + if (!x) return 1; + //alert(x.xml()); + KXMLDOMNodeList items = x.selectNodes(L"/Enquiry/Item"); + int len = items.length(); + for (int i = 0; i < len; i++) + { + + KXMLDOMElement e = items.item(i); + dw_goods.InsertRow(i); + + int nRow = dw_goods.GetRow(); + + SetSeqNo(dw_goods, L"SeqNo", nRow); + dw_goods.SetItemString(nRow, L"UOMCode", L"007"); + dw_goods.SetItemDisplayString(nRow, L"UOMCode", L"PCS"); + dw_goods.SetItemString(nRow, L"KOPCode", L"120"); + dw_goods.SetItemDisplayString(nRow, L"KOPCode", L"CTNS"); + if (e.selectSingleNode(L"ItemName"))dw_goods.SetItemString(nRow, L"ItemName", e.selectSingleNode(L"ItemName").text()); + if (e.selectSingleNode(L"GoodsNo"))dw_goods.SetItemString(nRow, L"GoodsNo", e.selectSingleNode(L"GoodsNo").text()); + if (e.selectSingleNode(L"SKUNo"))dw_goods.SetItemString(nRow, L"SKUNo", e.selectSingleNode(L"SKUNo").text()); + if (e.selectSingleNode(L"ItemMiniQty"))dw_goods.SetItemString(nRow, L"ItemMiniQty", e.selectSingleNode(L"ItemMiniQty").text()); + if (e.selectSingleNode(L"Picture"))dw_goods.SetItemString(nRow, L"Picture", e.selectSingleNode(L"Picture").text()); + if (e.selectSingleNode(L"ItemID"))dw_goods.SetItemString(nRow, L"ItemID", e.selectSingleNode(L"ItemID").text()); + if (e.selectSingleNode(L"ProductDesc"))dw_goods.SetItemString(nRow, L"ProductDesc", e.selectSingleNode(L"ProductDesc").text()); + if (e.selectSingleNode(L"Packing"))dw_goods.SetItemString(nRow, L"Packing", e.selectSingleNode(L"Packing").text()); + if (e.selectSingleNode(L"POPrice"))dw_goods.SetItemString(nRow, L"POPrice", e.selectSingleNode(L"POPrice").text()); + if (e.selectSingleNode(L"PriceType"))dw_goods.SetItemString(nRow, L"PriceType", e.selectSingleNode(L"PriceType").text()); + if (e.selectSingleNode(L"InnerQty"))dw_goods.SetItemString(nRow, L"InnerQty", e.selectSingleNode(L"InnerQty").text()); + if (e.selectSingleNode(L"PackingRate"))dw_goods.SetItemString(nRow, L"PackingRate", e.selectSingleNode(L"PackingRate").text()); + if (e.selectSingleNode(L"VolumeDesc"))dw_goods.SetItemString(nRow, L"VolumeDesc", e.selectSingleNode(L"VolumeDesc").text()); + if (e.selectSingleNode(L"SampleFee"))dw_goods.SetItemString(nRow, L"SampleFee", e.selectSingleNode(L"SampleFee").text()); + if (e.selectSingleNode(L"TestFee"))dw_goods.SetItemString(nRow, L"TestFee", e.selectSingleNode(L"TestFee").text()); + if (e.selectSingleNode(L"ModelFee"))dw_goods.SetItemString(nRow, L"ModelFee", e.selectSingleNode(L"ModelFee").text()); + if (e.selectSingleNode(L"BOMPartNo"))dw_goods.SetItemString(nRow, L"BOMPartNo", e.selectSingleNode(L"BOMPartNo").text()); + if (e.selectSingleNode(L"ModifyDate"))dw_goods.SetItemString(nRow, L"ModifyDate", e.selectSingleNode(L"ModifyDate").text()); + + if (e.selectSingleNode(L"EnquiryDate"))dw_goods.SetItemString(nRow, L"EnquiryDate", e.selectSingleNode(L"EnquiryDate").text()); + if (e.selectSingleNode(L"EnquiryPriceListID"))dw_goods.SetItemString(nRow, L"EnquiryPriceListID", e.selectSingleNode(L"EnquiryPriceListID").text()); + if (e.selectSingleNode(L"RelEnquiryLineID"))dw_goods.SetItemString(nRow, L"RelEnquiryLineID", e.selectSingleNode(L"RelEnquiryLineID").text()); + if (e.selectSingleNode(L"PirorEnquiryLineID"))dw_goods.SetItemString(nRow, L"PirorEnquiryLineID", e.selectSingleNode(L"PirorEnquiryLineID").text()); + if (e.selectSingleNode(L"RealEnquiryLineID"))dw_goods.SetItemString(nRow, L"RealEnquiryLineID", e.selectSingleNode(L"RealEnquiryLineID").text()); + if (e.selectSingleNode(L"category"))dw_goods.SetItemString(nRow, L"category", e.selectSingleNode(L"category").text()); + + + if (dw_goods.GetItemString(nRow, L"VolumeDesc") != L"" && + dw_goods.GetItemString(nRow, L"Packages") != L"") + { + int qty = EvalQtyPerFCL45H(nRow); + dw_goods.SetItemString(nRow, L"Packages45H", xstring(qty)); + dw_goods.SetItemDouble(nRow, L"TransportationFee", 5000.0 / qty); + } + + } + return 1; + } + int OnInit() + { + //公司抬头、报价人、报价日期 + xstring sdate = publiccode::GetCurrentDate(); + dw_base.SetItemString(1, L"EnquiryDate", sdate); + xstring suserid = publiccode::GetUser().id; + xstring susername = publiccode::GetUser().name; + dw_base.SetItemString(1, L"SalespersonID", suserid); + dw_base.SetItemDisplayString(1, L"SalespersonID", susername); + dw_base.SetItemString(1, L"CompanyID", L"E9E3C542-062C-4957-B8F4-9B92C3E351FC"); + dw_base.SetItemDisplayString(1, L"CompanyID", L"宁波家尔佳进出口有限公司"); + return 1; + } + + /* + pricebill: one of enquiry pricebill quote pricebill + */ + int RetrieveItemList(xstring items, xstring pricebill = L"") + { + xml x ; + + xaserverarg arg; + + arg.AddArg(L"ItemList", items); + //alert(items); + xstring dataurl = L"/sale/data/Enquiry/maint/items"; + if (pricebill == L"pricebill") dataurl = L"/sale/data/Enquiry/maint/pricelist/items"; + if (pricebill == L"quote") dataurl = L"/sale/data/Enquiry/FetchItemListByQuoteItemID"; + if (getUrl(dataurl, arg.GetString(), x) != 1) + { + alert(x.text()); + return -1; } else { - MessageBoxW(GetHWND(), L"删除成功!", L"提示", 0); - listwin::dw_list.DeleteRow(row); - } - } - return 1; - } - int OnRowChangedEx(TEvent* evt, LPARAM p) - { - DWNMHDR& hdr = *(DWNMHDR*)evt->notify.pnmh; - int row = hdr.row; - //if(row < 1 or row > dw_list.GetRowCount()) return 1; - KXMLDOMElement ele = listwin::dw_list.GetRowElement(row); - xstring entity = ele.selectSingleNode(L"SupplierID").text(); - xml x; - - xaserverarg arg; - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg(L"EntityID", entity); + //trace(L"*****" + x.xml() + L"*****"); + dw_goods.Retrieve(x); + dw_goods.Redraw(); + ReSeqNo(L"SeqNo"); - xstring no1 = publiccode::GetUser().no; - if (no1 != L"00201") - { - - if (TypeWork.find(L"采购") >= 0) - { - GoodsUrl = L"/sale/data/SupplierV3/entity/supplieritemEx"; - } - else - { - GoodsUrl = L"/sale/data/SupplierV3/entity/supplieritem"; - } - } - else - { - GoodsUrl = L"/sale/data/SupplierV3/entity/supplieritem"; - } - if (getUrl(GetServerUrl(), GoodsUrl, arg.GetString(), x) != 1) - { - trace(x.text()); - return -1; - } - else - { - dw_goods.Retrieve(x); - dw_goods.Redraw(); - dw_goods.SetReadOnly(true); - } - SetAgent(L"list", entity); - return 1; - } - - int GridSearch() - { - //alert(L"你好"); -#if 0 - - xstring m_config = L"view.Supplier.v3.config"; - xdwgrid dw = listwin::dw_list; - xaserverarg& arg = *new xaserverarg; - arg.setNativePointer(arg.CreateInstance()); - xstring str = TFile::node(m_config, L"config", L"search"); - if (str != L"") { - arg.AddArg(L"sheet", str); - } - else - arg.AddArg(L"sheet", L"dev:sheet[Supplier.v3.tpl/list]"); - arg.AddArg(L"search", listwin::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"") { - listwin::m_QueryTxt = txt; - //trace(txt); - OnRetrieve(); - } - } -#endif - return 0; - } - - int OnSelectAllRow() - { - int rows = listwin::dw_list.GetRowCount(); - if (rows < 1) return -1; - listwin::dw_list.SelectRow(1, rows, true); - listwin::dw_list.Redraw(); - return 1; - } - - int OnRClick(TEvent evt, LPARAM p) - { - return 1; - } - int OnLogOff() - { - return 1; - } - int OnChecked() - { - xstring partyno = dw_list.GetItemString(dw_list.GetRow(), L"PartyNo"); - if (partyno.find(L"N") < 0) - { - alert(L"已经是正式供应商"); - return 0; - } - xstring entityid = GetEntityID(dw_list.GetRow()); - int MB_OKCANCEL = 1; - int IDOK = 1; - int ret = MessageBoxW(GetHWND(), L"是否转成正式供应商?", L"提示", MB_OKCANCEL); - if (ret == IDOK) - { - xml x = ViewObject::RetrieveData(GetServerUrl(), L"/sale/data/SupplierV3/entity/updateno", L"entityid", entityid); - - if (xstring(x.xml()).find(L"success") > 0) - { - alert(L"处理成功"); - OnRetrieve(); - } - } - return 1; - } - int PreOnCmdDispatch(xstring comdid) - { - //alert(comdid); - - if (comdid.find(L"action:LogOff", 0) >= 0) return OnLogOff(); - if (comdid.find(L"action:bill.delete", 0) >= 0) - { - OnDeleteRow(); - return 0; - } - if (comdid == L"action:search1") return GridSearch(); - if (comdid == L"action:bill.refresh") - { - return OnRetrieve(); - } - if (comdid == L"action:bill.xmSaveAs") - { - xstring userno = publiccode::GetUser().no; - if (userno == L"00701" || userno == L"00601" || userno == L"admin") - { - dw_list.SaveAs(L""); + if (dw_goods.GetRowCount() > 0) + { + if (dw_goods.GetItemString(1, L"customerno")) + { + dw_base.SetItemString(1, L"CustomerNo", dw_goods.GetItemString(1, L"customerno")); + } + ximageview im = GetControl(L"im1"); + im.Reset(); + xstring skuno = dw_goods.GetItemString(1, L"SKUNo"); + OnShowImage(skuno, 1); + im.Redraw(); + } } return 1; } - if (comdid == L"action:bill.Annex") + + int onload() { - xaserverarg& arg = *new xaserverarg; - arg.setNativePointer(arg.CreateInstance()); - arg.AddArg(L"entityid", dw_list.GetItemString(dw_list.GetRow(), L"SupplierID")); - arg.AddArg(L"ApplyStatus", dw_list.GetItemString(dw_list.GetRow(), L"ApplyStatus")); + SetArg(); + dw_goods = GetControl(L"dw_goods"); + //dw_goods .openUrl(L"/sale/view/Enquiry3/template/goods"); + dw_goods.openUrl(L"/sale/view/Enquiry3/template/item/pricelist"); + dw_goods.SetColumnState(L"ItemID", false); + //dw_goods.SetColumnState(L"Picture",false); + dw_goods.SetColumnState(L"category", false); + dw_goods.SetColumnState(L"RealEnquiryLineID", false); + dw_goods.SetColumnState(L"RelEnquiryLineID", false); + dw_goods.SetColumnState(L"BOMPartNo", false); - OpenWindow(L"dev:xpage[maint.Document.Supplier.v3.vx]", (LPARAM)&arg); - return 1; - } - if (comdid == L"action:bill.AnnexEx") - { - xaserverarg& arg4 = *new xaserverarg; - arg4.setNativePointer(arg4.CreateInstance()); - arg4.AddArg(L"entityid", dw_list.GetItemString(dw_list.GetRow(), L"SupplierID")); - //arg4.AddArg(L"ApplyStatus",dw_list.GetItemString(dw_list.GetRow(),L"ApplyStatus")); + dw_base = GetControl(L"dw_base"); - //OpenWindow(L"dev:xpage[maint.Document.Customer.v3.vx]", p4); - OpenWindow(L"dev:xpage[maint.Document.SupplierSD.v3.vx]", (LPARAM)&arg4); - return 1; - } - if (comdid == L"action:bill.checked") - return OnChecked(); - // if(comdid==L"action:bill.import") return OnImport(); - // if(comdid.find(L"action:",0)>=0) return ProcessFlowAction(comdid,1); - //if(comdid==L"search") return GridSearch(L"view.dlg.vface/xpage/grid/column/edit"); - //if(comdid==L"showall") return ShowAll(); - - return 1; - } - - - int PostOnAttachEvent() - { - //获得树的选择事件 - AttachEvent(L"tv_1", L"TVN_SELCHANGED", (FEvent)&listSupplierv3::OnTreeSelChanged); - AttachEvent(L"cbx_1", L"CBN_SELCHANGE", (FEvent)&listSupplierv3::OnSelectDdlb); - AttachEvent(L"pages", L"PAGE_CLICK", (FEvent)&listSupplierv3::OnChangePages); - AttachEvent(L"dw_list", L"DWV_RCLICKED", (FEvent)&listSupplierv3::OnRClick);//鼠标右键 - //AttachEvent(L"dw_list", L"DWV_DOUBLECLICKED", (FEvent)&listSupplierv3::OnDoubleClicked); - - return 1; - } - - int onload() - { - PIndex = 1; - listwin::m_QueryTxt = L""; //查询条件 - m_sType = L""; //type - m_sTypeTxt = L""; //选中树的data - - listwin::onload(); - - tv_1 = GetControl(L"tv_1"); - ddlb_1 = GetControl(L"cbx_1"); - - changeddlb = 0; - OnCreateTree(L"GoodsCates"); - dw_list.SetColumnState(L"SupplierID", false); - dw_list.SetColumnState(L"userNo", false); - dw_list.SetColumnState(L"YearEstablished", false); - dw_list.SetColumnState(L"LegalPerson", false); - dw_list.SetColumnState(L"ThirdPartyReport", false); - dw_list.SetColumnState(L"bAddress", false); - dw_list.SetColumnState(L"PayType", false); - dw_list.SetColumnState(L"PicPath", false); - dw_list.SetColumnState(L"SDID", false); - dw_list.SetColumnState(L"AdvantageProduct", false); - //dw_list.SetColumnState(L"ApplyStatus",false); - - dw_goods = GetControl(L"dw_goods"); - dw_goods.openUrl(GetServerUrl(), L"/sale/view/SupplierV3/template/supplier/supplieritem"); - - if (publiccode::GetUser().name != L"admin") - { - xstring s = publiccode::GetUser().id; - - xml supplier_x = ViewObject::RetrieveData(GetServerUrl(), L"/sale/data/SupplierV3/entity/FindBySaleType", L"id", s); - if (supplier_x) + if (GetWinParam()) { - TypeWork = supplier_x.text(); + xaserverarg arg=GetArg(); + - if (TypeWork.find(L"采购") >= 0) + sheetname = arg.GetArgString(L"sheetname"); + if (sheetname == L"tab_list2") + { + dw_base.openUrl(L"/sale/view/Enquiry3/template/base2"); + //dw_base.SetItemString(1,L"Source",L"客户询价"); + dw_goods.SetColumnState(L"SupplierID", true); + } + else { - dw_list.SetColumnState(L"DateEx", false); - dw_list.SetColumnState(L"DateExS", false); - dw_list.SetColumnState(L"Name", false); - dw_list.SetColumnState(L"ProvinceCode", false); - dw_list.SetColumnState(L"City", false); - dw_list.SetColumnState(L"District", false); - dw_list.SetColumnState(L"Address", false); - dw_list.SetColumnState(L"CName", false); - dw_list.SetColumnState(L"TEL", false); - dw_list.SetColumnState(L"Mob", false); - dw_list.SetColumnState(L"AreaCode", false); - dw_list.SetColumnState(L"Fax", false); - dw_goods.SetColumnState(L"Price", false); - dw_goods.SetColumnState(L"PackRMBPrice", false); - dw_goods.SetColumnState(L"PartRMBPrice", false); - dw_goods.SetColumnState(L"PaperRMBPrice", false); - dw_goods.SetColumnState(L"ETD", false); - dw_goods.SetColumnState(L"InvoiceNo", false); + dw_base.openUrl(L"/sale/view/Enquiry3/template/base"); + //dw_base.SetItemString(1,L"Source",L"客户询价"); + dw_goods.SetColumnState(L"SupplierID", false); + } + dw_base.SetColHeaderHeight(0); + dw_base.SetRowSelectorWidth(0); + dw_base.SetHScrollState(false); + dw_base.SetVScrollState(false); + + xstring EnquiryNo = arg.GetArgString(L"EnquiryNo"); + xstring EnquiryID = arg.GetArgString(L"EnquiryID"); + xstring ItemID = arg.GetArgString(L"ItemID"); + if (EnquiryNo == L"") EnquiryNo = arg.GetArgString(L"EntityNo"); + if (EnquiryNo != L"") + { + OnRetrieve(EnquiryNo); + + } + else if (EnquiryID != L"") { + Oncopy(EnquiryID, ItemID); + } + else + { + OnInit(); + + if (arg.GetArgString(L"CustomerID") != L"") + { + dw_base.SetItemDisplayString(1, L"SupplierID", arg.GetArgString(L"CustomerName")); + dw_base.ItemChangeTo(1, L"SupplierID", arg.GetArgString(L"CustomerID")); + xstring dwname = L"dw_base"; + xstring colname = L"SupplierID"; + xstring value = arg.GetArgString(L"CustomerID"); + KXMLDOMNodeList nlist = GetElement().selectNodes(L"//*[@name='" + dwname + L"']/trans[@for='" + colname + L"']"); + ViewObject::TransData(nlist, dw_base, 1, colname, value); + } + + if (arg.GetArgString(L"EntityIDList") != L"") + { + RetrieveItemList(arg.GetArgString(L"EntityIDList"), arg.GetArgString(L"Source")); + } } } + else + OnInit(); + OnAttachEvent(); + + dw_base.SetEditUpperMode(true); + dw_goods.SetEditUpperMode(true); + dw_goods.SetAskStyle(true); + + return 1; } - return 1; - } + int onloaded() + { + SetAgent(); - int onloaded() - { - AttachEvent(L"dw_list", L"DWV_ROWFOCUSCHANGED", (FEvent)&listSupplierv3::OnRowChangedEx); - - listwin::onloaded(); - xstring EntityID; - int row = dw_list.GetRow(); - if (row<0 || row>dw_list.GetRowCount()) return 1; - KXMLDOMElement ele = dw_list.GetRowElement(row); - xstring id = listwin::m_configDoc.selectSingleNode(L"//entity/EntityID[1]").text(); - if (ele.selectSingleNode(id)) - EntityID = ele.selectSingleNode(id).text(); - listwin::SetAgent(L"list", EntityID); - return 1; - } - -}; \ No newline at end of file + return 1; + } + }; -- Gitblit v1.9.3