From 4988c8950db8640eaeb2498b51aca2dfed2c685b Mon Sep 17 00:00:00 2001 From: xj qian <qianxj15@sina.com> Date: 星期一, 15 七月 2024 12:10:15 +0800 Subject: [PATCH] Merge branch 'master' of http://116.62.18.175:6699/r/mis-prj --- jrj/project/business/Company/CompanyMaint.cpp | 403 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 403 insertions(+), 0 deletions(-) diff --git a/jrj/project/business/Company/CompanyMaint.cpp b/jrj/project/business/Company/CompanyMaint.cpp new file mode 100644 index 0000000..0ade828 --- /dev/null +++ b/jrj/project/business/Company/CompanyMaint.cpp @@ -0,0 +1,403 @@ +use "win.vl" +use "treeview.vm" +use "dev:vm[xdwgrid.vm]" +use "dev:vm[xdwtable.vm]" +use "pref.vl" +use "dev:vm[xml.vm]" +use "dev:vm[xaserverarg.vm]" +use "dev:vm[xaserver.vm]" +use "dev:vm[xutil.vm]" +use "dev:vm[pagecontrol.vm]" +use "maint.vl" +use "publiccode.vl" + +unit vbusiness.xpage +[ + CompanyMaint is extend maint; + about CompanyMaint + [ + control: + + method: + [ + pagecontrol__ m_layer; + xdwtable__ dw_detail; + xdwtable__ dw_bank; + string m_operate; + string m_sguid; + + xnode__ m_agentNode; //Agent Condition + string m_agentCond; //Agent Node + int SetAgent() + { + string xfNodeAgentArea = "agentarea"; + xnode__ anode = new xnode__; + anode.setNativePointer(GetAgentNode(xfNodeAgentArea)); + var xframeElement = GetElement(); + var agent = xframeElement.selectSingleNode("agent/" + xfNodeAgentArea + "[1]/*"); + if (agent) + { + string s = agent.xml; + SetAgentNodeContent(anode, s); + } + return 1; + } + + //焦点激活处理函数 + int OnSetFocus(ref TEvent evt, int param) + { + SetAgent(); + + //重置工具条 + return 1; + } + + int OnPreSave() + { + xdwtable__ dw = new xdwtable__; + dw.setNativePointer(dw_detail.FindDwTable("CompanyInfo", 0)); + string sPartyNo = dw.GetItemString(1, "PartyNo", 0); + if (sPartyNo == "" || sPartyNo == nil) + { + string sGetNo = publiccode::GetIdentityNo(""); + dw.SetItemString(1, "PartyNo", sGetNo); + //alert("公司编号为空!"); + //return -1; + } + string sPartyName = dw.GetItemString(1, "Name", 0); + if (sPartyName == "" || sPartyName == nil) + { + alert("公司名称为空!"); + return -1; + } + + string suserid = publiccode::GetUserInfo().id; + string sdate = publiccode::GetCurDate(); + dw.SetItemString(1, "ModifierID", suserid); + dw.SetItemString(1, "ModifyDate", sdate); + + dw.setNativePointer(dw_bank.FindDwTable("item", 0)); + if (dw) + { + string sno; + string sname, + string status; + int i; + int row = dw.GetRowCount(); + for (i = 1; i <= row; i++) + { + status = dw.GetItemString(i, "Status", 0) + ""; + if (status == "" || status == nil) + { + dw.SetItemString(i, "Status", "Y"); + //alert("第"+i.toString()+"行状态为空"); + //return -1; + } + /* + sno=dw.GetItemString(i,"BankAccountNo",0)+""; + sname=dw.GetItemString(i,"BankName",0)+""; + status=dw.GetItemString(i,"Status",0)+""; + if (sno=="" || sno==nil) + { + if(sname !="" && sname != nil) + { + alert("第"+i.toString()+"行银行编号为空"); + return -1; + } + } + + if (sname=="" || sname==nil) + { + if(sno !="" && sno != nil) + { + alert("第"+i.toString()+"行银行名称为空"); + return -1; + } + } + else + { + if (status=="" || status==nil) + { + dw.SetItemString(i,"Status","Y"); + //alert("第"+i.toString()+"行状态为空"); + //return -1; + } + } + */ + } + } + return 1; + } + + int OnSave() + { + dw_detail.AcceptText(); + dw_bank.AcceptText(); + int rec; + rec = OnPreSave(); + if (rec == -1) + return -1; + + int hIcon = xutil__::SetCursorWait(); + + string val, val2; + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + var xdoc = x.GetXmlDoc(); + dw_detail.DwUpdateAllTo(xdoc); + //val = xdoc.xml ; + dw_bank.DwUpdateAllTo(xdoc); + val = xdoc.xml; + trace(val); + xaserverarg__ args = new xaserverarg__; + args.setNativePointer(args.CreateInstance()); + args.AddArg("content", val); + args.AddArg("dbmap", "CompanyInfo.dbmap"); + //trace(m_EntityValueEx); + xml__ x1 = new xml__; + x1.setNativePointer(x1.CreateInstance()); + if (url::post("OrganizationStruct/update.companyinfoex", args.GetString(), x1) != 1) + //if (xaserver__::ExecXAction("","[update.CompanyInfoEx.xa]",args.GetString(),x1) !=1) + { + string error = x1.GetXmlDoc().text; + trace(error); + } + else + { + trace(x1.GetXml()); + if (x1.GetXmlDoc().selectSingleNode("error")) + { + alert("保存出错2!"); + return 0; + } + win__::MessageBox(GetHWND(), "保存成功!", "提示", 0); + } + xutil__::RestoreCursor(hIcon); + dw_detail.ResetUpdateStatus(); + dw_bank.ResetUpdateStatus(); + var xdoc2 = x.GetXmlDoc(); + dw_detail.DwUpdateAllTo(xdoc2); + val = xdoc.xml; + trace(val); + return 1; + } + + int OnItemChanged(ref TNotifyEvent evt, int p) + { + ref DWNMHDR dwhdr = evt.pnmh; + int row = dwhdr.row; + string col = dwhdr.colname; + string data = dwhdr.data; + if (col == "Name") + { + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("Name", data); + } + + return 1; + } + + int OnChildContent(ref TNotifyEvent evt, int p) + { + ref DWNMHDR dwhdr = evt.pnmh; + string col = dwhdr.colname; + if (col != "") { + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + string query; + query = "[IResourceMSSql.xq]"; + if (col == "TradeType") { + arg.AddArg("ResourceType", "TradeType");//贸易方式 + } + if (xaserver__::ExecXQuery(GetServerUrl(), query, arg.GetString(), x) == 1) + dwhdr.data = x.GetXml(); + //trace(x.GetXml()); + } + return 1; + } + + int OnAddRow() + { + int h = m_layer.GetSheetIndex(); + if (h == 1) + { + xdwtable__ dw = new xdwtable__; + dw.setNativePointer(dw_bank.GetCurTable()); + string dw_n = dw.GetDwName(); + if (dw_n == "item") + { + int row = dw.InsertRow(0); + dw.SetItemString(row, "Status", "Y"); + } + } + return 1; + } + + int OnInsertRow() + { + int h = m_layer.GetSheetIndex(); + if (h == 1) + { + xdwtable__ dw = new xdwtable__; + dw.setNativePointer(dw_bank.GetCurTable()); + string dw_n = dw.GetDwName(); + if (dw_n == "item") + { + int row = dw.GetRow(); + int crow = dw.InsertRow(row); + dw.SetItemString(crow, "Status", "Y"); + } + } + return 1; + } + + int OnDeleteRow() + { + int h = m_layer.GetSheetIndex(); + if (h == 1) + { + xdwtable__ dw = new xdwtable__; + dw.setNativePointer(dw_bank.GetCurTable()); + string dw_n = dw.GetDwName(); + if (dw_n == "item") + { + int row = dw.GetRow(); + dw.DeleteRow(row); + } + } + return 1; + } + + //命令发布函数 + int OnCmdDispatch(string comdid) + { + if (comdid == "Save") OnSave(); + else if (comdid == "AddRow") OnAddRow(); + else if (comdid == "InsertRow") OnInsertRow(); + else if (comdid == "DeleteRow") OnDeleteRow(); + return 0; + } + + //命令处理事件 + int OnXCommand(ref TXCommandEvent evt, int param) + { + return OnCmdDispatch(evt.pStrID); + } + + int OnAttachEvent() + { + //绑定工具条点击事件 + AttachEvent("WM_XCOMMAND", OnXCommand); + //获取焦点事件,用于重置工具条 + AttachEvent("WM_SETFOCUS", OnSetFocus); + //下拉框 提供内容 + AttachEvent("dw_detail", "DWV_CHILDCONTENT", OnChildContent); + AttachEvent("dw_detail", "DWV_ITEMCHANGED", OnItemChanged); + } + + int OnRetrieve() + { + xml__ x = new xml__; + x.setNativePointer(x.CreateInstance()); + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg.AddArg("guid", m_sguid); + //trace(m_sguid); + //if (url::get("OrganizationStruct/detail.CompanyInfo",arg.GetString(),x) != 1) + if (url::post("OrganizationStruct/detail.CompanyInfo", arg.GetString(), x) != 1) + { + trace(x.GetXmlDoc().text); + return -1; + } + else + { + dw_detail.Retrieve(x); + dw_detail.Redraw(); + dw_bank.Retrieve(x); + dw_bank.Redraw(); + //trace(x.GetXml()); + } + + return 1; + } + + int OnInitial() + { + SetAgent(); + + xaserverarg__ arg = new xaserverarg__; + arg.setNativePointer(arg.CreateInstance()); + arg = this.GetParam(); + if (arg) + { + m_operate = arg.GetArgString("operate"); + m_sguid = arg.GetArgString("guid"); + } + /*if ( m_sguid == "" || m_sguid == nil) + { + m_sguid = win__::GetGuid(); + trace(m_sguid); + }*/ + + OnAttachEvent(); + + return 1; + } + + int onload() + { + m_layer = new pagecontrol__; + m_layer.setNativePointer(this.GetControl("cTab")); + + dw_detail = new xdwtable__; + dw_detail.setNativePointer(this.GetControl("dw_detail")); + dw_detail.openUrl("组织架构.vface/template/company/detail"); + dw_detail.SetColHeaderHeight(0); + dw_detail.SetRowSelectorWidth(0); + dw_bank = new xdwtable__; + dw_bank.setNativePointer(this.GetControl("dw_bank")); + dw_bank.openUrl("组织架构.vface/template/company/bank"); + + OnInitial(); + if (m_sguid != "") { + OnRetrieve(); + } + else { + xdwtable__ dw = new xdwtable__; + dw.setNativePointer(dw_detail.FindDwTable("CompanyInfo", 0)); + dw.SetItemString(1, "Status", "1"); + dw.SetItemString(1, "InternalFlag", "Y"); + dw.SetItemString(1, "Type", "0"); + string suserid = publiccode::GetUserInfo().id; + /*string susername = publiccode::GetUserInfo().name; + string sdate = publiccode::GetCurDate(); + dw.SetItemString(1,"CreatorID",suserid); + dw.SetItemDisplayString(1,"CreatorID",susername); + dw.SetItemString(1,"CreateDate",sdate);*/ + + dw.setNativePointer(dw_detail.FindDwTable("address", 0)); + dw.SetItemString(1, "IdentifyAddressFlag", "Y"); + dw.SetItemString(1, "Status", "1"); + dw.setNativePointer(dw_detail.FindDwTable("Regist", 0)); + dw.SetItemString(1, "IdentifyAddressFlag", "N"); + dw.SetItemString(1, "Status", "1"); + + dw.setNativePointer(dw_bank.FindDwTable("item", 0)); + if (dw) { + //msxml::IXMLDOMElement ele = dw.GetElement(); + //trace(ele.xml); + //dw.SetItemString(1,"Status","Y"); + } + } + return 1; + } + + ] + + ] +] \ No newline at end of file -- Gitblit v1.9.3