| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939 | $PBExportHeader$uo_inware_buy.sruforwardglobal type uo_inware_buy from uo_inwareend typeend forwardglobal type uo_inware_buy from uo_inwareend typeglobal uo_inware_buy uo_inware_buytype variablesend variablesforward prototypespublic function integer secauditing (boolean arg_ifcommit, ref string arg_msg)public function integer c_secauditing (boolean arg_ifcommit, ref string arg_msg)public function integer uof_create_buytask (ref string arg_msg, boolean arg_ifcommit)public function integer auditing_end (ref string arg_msg)public function integer c_auditing_chk (ref string arg_msg)public function integer c_auditing_end (ref string arg_msg)public function integer uof_destroy_buytask (ref string arg_msg, boolean arg_ifcommit)public function integer uof_save_dytitle_inwarebuy (long arg_hang, string arg_name, string arg_dwtitlename, string arg_execltitlename, string arg_filtername, ref string arg_msg)public function integer acceptmx (s_inwaremx s_mx, ref string arg_msg)public function integer save (boolean arg_ifcommit, ref string arg_msg)public function integer priceaudit (long arg_scid, long arg_inwareid, boolean arg_ifcommit, ref string arg_msg)public function integer c_priceaudit (long arg_scid, long arg_inwareid, boolean arg_ifcommit, ref string arg_msg)end prototypespublic function integer secauditing (boolean arg_ifcommit, ref string arg_msg);Long rslt = 1,cnt = 0,iString ls_about,ls_dscrpLong ll_moneyiduo_mustpay uo_payuo_pay = Create uo_mustpayDecimal ld_payamt = 0,ld_mstpayamt = 0, ld_otheramt = 0,ld_taxamt,ld_payamt_taxIF inwareid = 0 THEN	rslt = 0	arg_msg = "没有审核对象"	GOTO extEND IFIF flag = 0 THEN	rslt = 0	arg_msg = "单据还没有经过仓库审核"	GOTO extEND IFIF secflag = 1 THEN	rslt = 0	arg_msg = "单据已经过财务审核"	GOTO extEND IFInt li_btypeLong ll_accountsidSELECT btype,accountsid INTO :li_btype,:ll_accountsid	FROM cw_banktype	Where banktypeid = :relint_1 Using commit_transaction;IF commit_transaction.SQLCode <> 0 THEN	rslt = 0	IF Pos(Lower(commit_transaction.SQLErrText),'more than') > 0 THEN		arg_msg = '查询结算方式类型失败,查询数据返回值多于一个'	ELSE		arg_msg = '查询结算方式类型失败,'+ commit_transaction.SQLErrText	END IF	GOTO extEND IFSELECT count(*) INTO :cnt	FROM u_user	Where username = :publ_operator Using commit_transaction ;IF commit_transaction.SQLCode <> 0 THEN	rslt = 0	arg_msg = "查询操作失败,操作员"	GOTO extEND IFIF cnt = 0 THEN 	rslt = 0	arg_msg = "操作员姓名未登记或已取消"	GOTO extEND IFUPDATE u_inware	SET secauditingrep = :publ_operator,	secauditingdate = getdate(),	secflag = 1	WHERE u_inware.inwareid = :inwareid	And flag = 1 And secflag = 0 And scid = :scid Using commit_transaction;	IF commit_transaction.SQLCode <> 0 THEN	rslt = 0	arg_msg = "因网络或其它原因导致财务审核单据操作失败"+"~n"+commit_transaction.SQLErrText	GOTO extELSEIF commit_transaction.SQLNRows = 0 THEN	rslt = 0	arg_msg = "单据正在财务审核,请稍后查询。"	GOTO extEND IFIF sum_uamt <> 0 And dxflag = 0 THEN	Long ll_dft_itemid_pay,ll_dft_itemid_yh, ll_dft_itemid_sj	IF thflag = 1 THEN		IF sys_option_buy_dscrp_sec = 0  THEN			ls_about = inwarecode + "退货款"		ELSE			ls_about = inwarecode + "退货款,备注:"  + Trim(dscrp)		END IF				IF f_get_itemid(5,ll_dft_itemid_pay, arg_msg) = 0 THEN // 采购外协退货项目			rslt = 0			GOTO ext		END IF	ELSE		IF sys_option_buy_dscrp_sec = 0  THEN			ls_about = inwarecode + "应付款"		ELSE			ls_about = inwarecode + "应付款,备注:"  + Trim(dscrp)		END IF				IF f_get_itemid(2,ll_dft_itemid_pay, arg_msg) = 0 THEN //采购外协付款项目			rslt = 0			GOTO ext		END IF	END IF		//财务支持多币种	IF sys_option_msp_multimoney = 0 THEN		SELECT moneyid Into :ll_moneyid From  cw_currency Where native = 1;		IF commit_transaction.SQLCode <> 0 THEN			rslt = 0			arg_msg = '查询本位币失败!'+commit_transaction.SQLErrText			GOTO ext		END IF				sum_bsamt = Round(sum_bsamt , sys_buyamt_round)		ld_mstpayamt = sum_bsamt - sum_bsamt_tax		ld_otheramt = Round(otheramt * mrate, 2)		ld_taxamt = sum_bsamt_tax			ELSE		ll_moneyid = relint_3				sum_uamt = Round(sum_uamt , sys_buyamt_round)		ld_mstpayamt = sum_uamt - sum_uamt_tax		ld_otheramt = otheramt		ld_taxamt = sum_uamt_tax	END IF		IF li_btype = 1 THEN		ld_payamt = ld_mstpayamt - ld_otheramt + ld_taxamt		//ld_payamt_tax = ld_taxamt	ELSE		ld_payamt = 0		//ld_payamt_tax = 0	END IF		//	DateTime plandate	//	SetNull(plandate)	IF uo_pay.add_payrec (scid,sptid,indate,inrep,ld_mstpayamt,ld_mstpayamt,ld_payamt,ls_about,&		inwarecode,relint_1,1,publ_operator,inwareid,0,arg_msg,False,viewdate,ll_accountsid,ll_dft_itemid_pay,ll_moneyid,part) = 0  THEN		rslt = 0		GOTO ext	END IF		IF ld_taxamt <> 0 THEN		ls_about = inwarecode  + "税金" //撤审有用, 应收明细增加有用				IF f_get_itemid(7,ll_dft_itemid_sj, arg_msg) = 0 THEN //采购税金项目			rslt = 0			GOTO ext		END IF				IF uo_pay.add_payrecmx(scid,uo_pay.ref_payid,inwarecode,indate,relint_1,ld_taxamt,ld_payamt_tax,&			publ_operator,ls_about,inrep,3,0,ll_dft_itemid_sj,sptid,arg_msg,False, ll_moneyid,part) = 0 THEN			rslt = 0			GOTO ext		END IF	END IF		IF otheramt <> 0 THEN		ls_about = inwarecode  + sys_option_change_otheramt				IF f_get_itemid(8,ll_dft_itemid_yh, arg_msg) = 0 THEN //采购税金项目			rslt = 0			GOTO ext		END IF				IF uo_pay.add_payrecmx(scid,uo_pay.ref_payid,inwarecode,indate,relint_1,0 - ld_otheramt,0,&			publ_operator,ls_about,inrep,3,0,ll_dft_itemid_yh,sptid,arg_msg,False, ll_moneyid,part) = 0 THEN			rslt = 0			GOTO ext		END IF	END IF				UPDATE u_inware		SET relint_2 = :uo_pay.ref_payid		WHERE u_inware.inwareid = :inwareid		AND scid = :scid		AND flag = 1		And secflag = 1 Using commit_transaction;			IF commit_transaction.SQLCode <> 0 THEN		arg_msg = '更新相关应付帐ID失败'		rslt = 0		GOTO ext	END IF	END IFsecflag = 1ext:IF rslt = 0 THEN	ROLLBACK Using commit_transaction;ELSEIF rslt = 1 And arg_ifcommit THEN	COMMIT Using commit_transaction;END IFDestroy uo_payIF thflag = 0 THEN	arg_msg = '采购进仓单,'+ arg_msgELSE	arg_msg = '采购退货单,'+ arg_msgEND IFRETURN rsltend functionpublic function integer c_secauditing (boolean arg_ifcommit, ref string arg_msg);Long rslt = 1,cnt = 0,iDateTime null_dtuo_mustpay  uo_payuo_pay = Create uo_mustpayString ls_mtrlnameString ls_tmpcodeSetNull(null_dt)IF inwareid = 0 THEN	rslt = 0	arg_msg = "没有撤审对象"	GOTO extEND IFIF it_newbegin Or it_updatebegin THEN	rslt = 0	arg_msg = "编辑状态下不可以执行撤审"	GOTO extEND IFIF cwauditingflag = 1 THEN	rslt = 0	arG_MSG = "该单据已经总账审核,不能进行财务撤审"	GOTO extEND IFIF secflag = 0 THEN	rslt = 0	arg_msg = "该单据财务未审,不能进行财务撤审"	GOTO extEND IFSELECT count(*) INTO :cnt	FROM u_user	Where username = :publ_operator Using commit_transaction ;IF commit_transaction.SQLCode <> 0 THEN	rslt = 0	arg_msg = "查询操作失败,操作员"	GOTO extEND IFIF cnt = 0 THEN	rslt = 0	arg_msg = "操作员姓名未登记或已取消"	GOTO extEND IFUPDATE u_inware	SET secauditingrep = '',	secauditingdate = :null_dt,	secflag = 0,relint_2 = 0	WHERE u_inware.inwareid = :inwareid	And secflag = 1 And scid = :scid  Using commit_transaction;	IF commit_transaction.SQLCode <> 0 THEN	rslt = 0	arg_msg = "因网络或其它原因导致财务审核单据操作失败"+"~n"+commit_transaction.SQLErrText	GOTO extELSEIF commit_transaction.SQLNRows = 0 THEN	rslt = 0	arg_msg = "单据正在财务审核,请稍后查询。"	GOTO extEND IFIF sum_uamt <> 0 And dxflag = 0 THEN	Long ll_payid, ll_listno	String ls_about	Boolean lb_del		ll_payid = relint_2	//====================================================================	// 修改: 检查是否已开供应商付款结算单	//--------------------------------------------------------------------	// 作者:	lwl		日期: 2015年06月04日	SELECT COUNT(0)		INTO :cnt		FROM u_Bmstamtmx INNER JOIN		u_Bmstamt ON u_Bmstamtmx.Baid = u_Bmstamt.Baid		WHERE (u_Bmstamt.billtype = 1)		And (u_Bmstamtmx.takeid = :ll_payid);	IF sqlca.SQLCode <> 0 THEN		rslt = 0		arg_msg = '查询是否已开供应商付款结算单失败,' + sqlca.SQLErrText		GOTO ext	END IF		IF cnt > 0 THEN				SELECT TOP 1 u_Bmstamt.BaCode			INTO :ls_tmpcode			FROM u_Bmstamtmx INNER JOIN			u_Bmstamt ON u_Bmstamtmx.Baid = u_Bmstamt.Baid			WHERE (u_Bmstamt.billtype = 1)			And (u_Bmstamtmx.takeid = :ll_payid);		IF sqlca.SQLCode <> 0 THEN			rslt = 0			arg_msg = '查询已开供应商付款结算单失败,' + sqlca.SQLErrText			GOTO ext		END IF				rslt = 0		arg_msg = '已开供应商付款结算单['+ls_tmpcode+'],不能撤审'		GOTO ext			END IF		//====================================================================	IF otheramt <> 0 THEN		//删优惠		ls_about = inwarecode   + sys_option_change_otheramt				SELECT  listno			INTO  :ll_listno			FROM u_bmstpaymx			WHERE payid = :ll_payid			AND dscrp = :ls_about			And buildtype = 3;		IF sqlca.SQLCode <> 0 THEN			rslt = 0			arg_msg = "查询应付帐"+sys_option_change_otheramt+"金额明细失败,"+sqlca.SQLErrText			GOTO ext		END IF				IF uo_pay.del_payrecmx(3, ll_payid , ll_listno,arg_msg,False) = 0 THEN			rslt = 0			GOTO ext		END IF	END IF		IF sum_uamt_tax <> 0 THEN		//删税金		ls_about = inwarecode  + "税金"				//删已收		SELECT  listno			INTO  :ll_listno			FROM u_bmstpaymx			WHERE payid = :ll_payid			AND dscrp = :ls_about			And buildtype = 3;					IF sqlca.SQLCode <> 0 THEN			rslt = 0			arg_msg = "查询应付帐税金明细失败,"+sqlca.SQLErrText			GOTO ext		END IF				IF uo_pay.del_payrecmx(3, ll_payid , ll_listno,arg_msg,False) = 0 THEN			rslt = 0			GOTO ext		END IF	END IF		IF uo_pay.del_payrec(scid,1,relint_2,sptid,arg_msg,False) = 0 THEN		rslt = 0		GOTO ext	END IFEND IFsecflag = 0ext:IF rslt = 0 THEN	ROLLBACK Using commit_transaction;ELSEIF rslt = 1 And arg_ifcommit THEN	COMMIT Using commit_transaction;END IFDestroy uo_payIF thflag = 0 THEN	arg_msg = '采购进仓单,'+ arg_msgELSE	arg_msg = '采购退货单,'+ arg_msgEND IFRETURN rsltend functionpublic function integer uof_create_buytask (ref string arg_msg, boolean arg_ifcommit);Long rslt = 1, iuo_buytask uo_taskuo_task = Create uo_buytaskuo_task.commit_transaction = commit_transactionIF thflag = 1 And relint_4 = 1 THEN	IF uo_task.newbegin(scid,arg_msg) = 0 THEN //		rslt = 0		GOTO ext	END IF		uo_task.Requiredate = indate //要求完成日期	uo_task.Assign_emp  = inrep //订单负责人	uo_task.Kind   = 0	uo_task.sptid  = sptid	uo_task.dscrp  = dscrp	uo_task.relcode  = inwarecode	uo_task.banktypeid  =  relint_1	uo_task.billtype  = 0	uo_task.moneyid  =  relint_3	uo_task.mrate  = mrate		FOR i = 1 To it_mxbt		IF uo_task.acceptmx(0,&			0,&			'',&			inwaremx[i].mtrlid,&			0 - inwaremx[i].uqty,&			0 - inwaremx[i].addqty,&			inwaremx[i].uprice,&			inwaremx[i].rebate,&			0,&			inwaremx[i].mxdscrp,&			inwaremx[i].mtrlcode,&			arg_msg,&			i,&			indate,&			storageid,&			inwaremx[i].status,&			inwaremx[i].woodcode,&			inwaremx[i].pcode,&			inwaremx[i].unit,&			inwaremx[i].rate,&			0,&			0,&			'',&			'',&			0,0,&			inwaremx[i].plancode,&   			inwaremx[i].mxdscrp2,&			inwaremx[i].mxdscrp3,&			inwaremx[i].mxdscrp4) = 0 THEN  //新加plancode			rslt = 0			GOTO ext		END IF	NEXT		IF uo_task.savesubmit(publ_operator,arg_msg,False) = 0 THEN		rslt = 0		GOTO ext	END IF		Long ll_taskid	Long ll_scid	String ls_taskcode	ll_taskid = uo_task.taskid	ls_taskcode = uo_task.TaskCode	ll_scid = uo_task.scid	IF uo_task.firstpermit(ll_scid,ll_taskid,publ_operator,arg_msg,False) = 0 THEN		rslt = 0		GOTO ext	END IF		UPDATE u_inware		SET relint_5 = :ll_taskid,		part = :ls_taskcode		WHERE u_inware.inwareid = :inwareid		And scid = :scid Using commit_transaction;			IF commit_transaction.SQLCode <> 0 THEN		rslt = 0		arg_msg = "因网络或其它原因导致生成采购订单操作失败"+"~n"+commit_transaction.SQLErrText		GOTO ext	ELSEIF commit_transaction.SQLNRows = 0 THEN		rslt = 0		arg_msg = "单据正在生成采购订单,请稍后查询。"		GOTO ext	END IFEND IFext:Destroy uo_taskIF rslt = 0 THEN	ROLLBACK Using commit_transaction;ELSEIF arg_ifcommit THEN	COMMIT Using commit_transaction;END IFRETURN rsltend functionpublic function integer auditing_end (ref string arg_msg);//uo_inware_buy 重写Long rslt = 1Long iuo_buytask uo_taskuo_task = Create uo_buytaskuo_task.commit_transaction = commit_transactionuo_spt_price uo_sptpriceuo_sptprice = Create uo_spt_price//Long ll_mxsptid = 0//Decimal ld_costFOR i = 1 To it_mxbt	//更新采购订单	IF billtype = 1 And inwaremx[i].relid > 0 THEN		IF uo_task.addmxcmpl(scid,inwaremx[i].relid,inwaremx[i].relprintid,inwaremx[i].buyqty,inwaremx[i].addqty,arg_msg,False) <> 1 THEN			rslt = 0			GOTO ext		END IF				IF uo_task.trycmplbuytask(scid,inwaremx[i].relid,arg_msg,False) = 0 THEN			rslt = 0			GOTO ext		END IF	END IF	//增加采购历史	IF uo_sptprice.uf_update_sptprice(thflag,sptid,inwaremx[i].mtrlid,inwaremx[i].unit,&		inwaremx[i].status,inwaremx[i].woodcode,inwaremx[i].pcode,inwareid,relint_3,&		inwaremx[i].uprice,inwaremx[i].rebate,inwaremx[i].rate,inwaremx[i].price,&		indate,inwarecode,0,inwaremx[i].mxdscrp,inwaremx[i].printid,0,False,arg_msg) = 0 THEN		rslt = 0		GOTO ext	END IF	NEXT//自动生成采购订单审核IF uof_create_buytask(arg_msg, False) = 0 THEN	rslt = 0	GOTO extEND IFext:Destroy uo_buytaskDestroy uo_sptpriceRETURN rsltend functionpublic function integer c_auditing_chk (ref string arg_msg);//uo_inware_buy 重写Long rslt = 1IF secflag = 1 THEN	rslt = 0	arg_msg = "单据已经财务审核"	GOTO extEND IFIF sys_option_hide_ware = 0 THEN	IF billtype = 8 And relid > 0 THEN		rslt = 0		arg_msg = "该进仓单是系统生成(如成本调整单),不能撤审!"		GOTO ext	END IF		IF billtype <> 9 THEN		IF uof_check_warepdb_audit(storageid,arg_msg) = 0 THEN			rslt = 0			GOTO ext		END IF	ELSE		IF Not sysautobuild THEN			IF dscrp  = '盘点表审核自动生成盘盈单' THEN				arg_msg = '系统自动生成的单据不能手动撤审'				rslt = 0				GOTO ext			END IF		END IF	END IFEND IFext:RETURN rsltend functionpublic function integer c_auditing_end (ref string arg_msg);Long rslt = 1Long iuo_buytask  uo_taskuo_task = Create uo_buytaskuo_task.commit_transaction = commit_transactionuo_spt_price uo_sptpriceuo_sptprice = Create uo_spt_priceLong ll_mxsptid = 0Long ll_mtrlwareidFOR i = 1 To it_mxbt		//更新合同完成数量	IF billtype = 1 And inwaremx[i].relid > 0 THEN		IF uo_task.addmxcmpl(scid,inwaremx[i].relid,inwaremx[i].relprintid,0 - inwaremx[i].buyqty,0 - inwaremx[i].addqty,arg_msg,False) <> 1 THEN			rslt = 0			GOTO ext		END IF		IF uo_task.trycmplbuytask(scid,inwaremx[i].relid,arg_msg,False) = 0 THEN			rslt = 0			GOTO ext		END IF	END IF		//清除采购历史	IF uo_sptprice.uf_del_sptprice(thflag,sptid,inwaremx[i].mtrlid,inwaremx[i].unit,inwaremx[i].status,inwaremx[i].woodcode,inwaremx[i].pcode,&		inwareid,inwaremx[i].printid,relint_3,False,arg_msg) = 0 THEN		rslt = 0		GOTO ext	END IFNEXT//自动删除采购订单审核IF uof_destroy_buytask(arg_msg, False) = 0 THEN	rslt = 0	GOTO extEND IF//IF thflag = 1 And relint_4 = 1 THEN//	Long  ll_status//	SELECT  status//		INTO :ll_status//		FROM u_buytask//		Where taskid = :relint_5 And scid = :scid  Using commit_transaction;//	IF commit_transaction.SQLCode = -1 THEN//		rslt = 0//		arg_msg = "查询采购订单操作失败"+"~n"+commit_transaction.SQLErrText//		GOTO ext//	ELSEIF  commit_transaction.SQLCode = 0 THEN//		IF ll_status = 1 Or ll_status = 0 THEN//			IF ll_status = 1 THEN//				IF uo_task.cancelpermit(scid,relint_5,arg_msg,False) = 0 THEN//					rslt = 0//					GOTO ext//				END IF//			END IF//			//			IF uo_task.Cancel(scid,relint_5,arg_msg,False) = 0 THEN//				rslt = 0//				GOTO ext//			END IF//			//		ELSE//			arg_msg = '无法删除该退货单生成的采购订单(' + part + '),请手动删除'//			rslt = -1//		END IF//		//	END IF//	//	UPDATE u_inware//		SET relint_5 = 0,//		part = ''//		WHERE u_inware.inwareid = :inwareid//		And scid = :scid Using commit_transaction;//		//	IF commit_transaction.SQLCode <> 0 THEN//		rslt = 0//		arg_msg = "删除采购订单操作失败"+"~n"+commit_transaction.SQLErrText//		GOTO ext//	ELSEIF commit_transaction.SQLNRows = 0 THEN//		rslt = 0//		arg_msg = "单据正在删除采购订单,请稍后查询。"//		GOTO ext//	END IF//END IFext:Destroy uo_taskDestroy uo_sptpriceRETURN rsltend functionpublic function integer uof_destroy_buytask (ref string arg_msg, boolean arg_ifcommit);Long rslt = 1, iuo_buytask uo_taskuo_task = Create uo_buytaskuo_task.commit_transaction = commit_transactionIF thflag = 1 And relint_4 = 1 THEN	Long  ll_status	SELECT  status		INTO :ll_status		FROM u_buytask		Where taskid = :relint_5 And scid = :scid  Using commit_transaction;	IF commit_transaction.SQLCode = -1 THEN		rslt = 0		arg_msg = "查询采购订单操作失败"+"~n"+commit_transaction.SQLErrText		GOTO ext	ELSEIF  commit_transaction.SQLCode = 0 THEN		IF ll_status = 1 Or ll_status = 0 THEN			IF ll_status = 1 THEN				IF uo_task.cancelpermit(scid,relint_5,arg_msg,False) = 0 THEN					rslt = 0					GOTO ext				END IF			END IF						IF uo_task.Cancel(scid,relint_5,arg_msg,False) = 0 THEN				rslt = 0				GOTO ext			END IF					ELSE			arg_msg = '无法删除该退货单生成的采购订单(' + part + '),请手动删除'			rslt = -1		END IF			END IF		UPDATE u_inware		SET relint_5 = 0,		part = ''		WHERE u_inware.inwareid = :inwareid		And scid = :scid Using commit_transaction;			IF commit_transaction.SQLCode <> 0 THEN		rslt = 0		arg_msg = "删除采购订单操作失败"+"~n"+commit_transaction.SQLErrText		GOTO ext	ELSEIF commit_transaction.SQLNRows = 0 THEN		rslt = 0		arg_msg = "单据正在删除采购订单,请稍后查询。"		GOTO ext	END IFEND IFext:Destroy uo_taskIF rslt = 0 THEN	ROLLBACK Using commit_transaction;ELSEIF arg_ifcommit THEN	COMMIT Using commit_transaction;END IFRETURN rsltend functionpublic function integer uof_save_dytitle_inwarebuy (long arg_hang, string arg_name, string arg_dwtitlename, string arg_execltitlename, string arg_filtername, ref string arg_msg);Long rslt = 1, iif isnull(arg_filtername) then arg_filtername=''UPDATE u_dytitle_inwarebuy	SET hang = :arg_hang,	dwtitlename = :arg_dwtitlename,	execltitlename = :arg_execltitlename,	filtername=:arg_filtername	WHERE name = :arg_name	Using commit_transaction;	IF commit_transaction.SQLCode <> 0 THEN	rslt = 0	arg_msg = "更新明细标题与execl标题对应关系表操作失败"+"~n"+commit_transaction.SQLErrText	GOTO extELSEIF commit_transaction.SQLNRows = 0 THEN	INSERT INTO u_dytitle_inwarebuy(hang,name,dwtitlename,execltitlename,filtername) VALUES (:arg_hang,:arg_name,:arg_dwtitlename,:arg_execltitlename,:arg_filtername)		Using commit_transaction;END IFext:IF rslt = 0 THEN	ROLLBACK Using commit_transaction;ELSE	COMMIT Using commit_transaction;END IFRETURN rsltend functionpublic function integer acceptmx (s_inwaremx s_mx, ref string arg_msg);Long rslt = 1,cnt = 0,ls_iDecimal ld_planprice,ld_cost,ld_dftsptpriceDecimal ld_noauditqty,ld_bootqtyString ls_relcode,ls_unit,ls_saletaskcodeInt li_iflimitpriceDec ld_round = 100uo_spt_price uo_sptpriceuo_sptprice = Create uo_spt_priceIf it_newbegin = False And it_updatebegin = False Then	rslt = 0	arg_msg = "非编辑状态不可以使用,操作取消"	Goto extEnd If//清除空值If IsNull(s_mx.printid) Then s_mx.printid = 0If IsNull(s_mx.mtrlid) Then s_mx.mtrlid = 0If IsNull(s_mx.mtrlcode) Then s_mx.mtrlcode = ''If IsNull(s_mx.plancode) Then s_mx.plancode = ''If IsNull(s_mx.status) Then s_mx.status = ''If IsNull(s_mx.uqty) Then s_mx.uqty = 0If IsNull(s_mx.addqty) Then s_mx.addqty = 0If IsNull(s_mx.packqty) Then s_mx.packqty = 0If IsNull(s_mx.uprice) Then s_mx.uprice = 0If IsNull(s_mx.rebate) Then s_mx.rebate = 0If IsNull(s_mx.mxdscrp) Then s_mx.mxdscrp = ''If IsNull(s_mx.mxdscrp2) Then s_mx.mxdscrp2 = ''If IsNull(s_mx.mxdscrp3) Then s_mx.mxdscrp3 = ''If IsNull(s_mx.mxdscrp4) Then s_mx.mxdscrp4 = ''If IsNull(s_mx.jgprice) Then s_mx.jgprice = 0If IsNull(s_mx.ifrel) Then s_mx.ifrel = 0If IsNull(s_mx.relid) Then s_mx.relid = 0If IsNull(s_mx.relprintid) Then s_mx.relprintid = 0If IsNull(s_mx.mxdscrp) Then s_mx.woodcode = ''If IsNull(s_mx.pcode) Then s_mx.pcode = ''If IsNull(s_mx.sptid) Then s_mx.sptid = 0If IsNull(s_mx.mtrlcuscode) Then s_mx.mtrlcuscode = ''If IsNull(s_mx.unit) Then s_mx.unit = ''If IsNull(s_mx.rate) Then s_mx.rate = 1If s_mx.rate = 0  Then s_mx.rate = 1If IsNull(s_mx.formula) Then s_mx.formula = ''If IsNull(s_mx.waredscrp) Then s_mx.waredscrp = ''If mrate = 0 Then mrate = 1If IsNull(s_mx.tax) Then s_mx.tax = 0If IsNull(s_mx.uamt_tax) Then s_mx.uamt_tax = 0If IsNull(s_mx.buyqty) Then s_mx.buyqty = 0If IsNull(s_mx.uprice_notax) Then s_mx.uprice_notax = 0If  s_mx.uprice_notax = 0  Then	s_mx.uprice_notax =  s_mx.uprice /   (1  +   s_mx.tax)End Ifs_mx.uqty = Round(s_mx.uqty,5)s_mx.addqty = Round(s_mx.addqty,5)If sys_option_outware_if_buyqty = 1 And billtype = 1 Then //采购 , 采购数与进仓数分离Else //不分离	s_mx.buyqty = s_mx.uqtyEnd IfIf s_mx.mtrlid = 0 Or (s_mx.buyqty = 0 And s_mx.uqty = 0 And s_mx.addqty = 0) Then	rslt = 1	Goto extEnd IfIf acceptmx_chk(s_mx, arg_msg) = 0 Then	rslt = 0	Goto extEnd If//检查物料idSelect unit,planprice,iflimitprice	Into :ls_unit,:ld_planprice,:li_iflimitprice	From u_mtrldef	Where u_mtrldef.mtrlid = :s_mx.mtrlid Using commit_transaction ;If commit_transaction.SQLCode <> 0 Then	rslt = 0	arg_msg = "第" + String(s_mx.printid) + "行,查询物料资料信息失败,编码:"+s_mx.mtrlcode	Goto extEnd If//确实有=1的情况//IF ls_unit <> s_mx.unit And s_mx.rate = 1 THEN//	arg_msg = "第" + String(s_mx.printid) + "行,库存单位与采购单位不同,但转换率为1,请检查!"//	rslt = 0//	GOTO ext//END IFIf ls_unit = s_mx.unit And s_mx.rate <> 1 Then	arg_msg = "第" + String(s_mx.printid) + "行,库存单位与采购单位相同,但转换率不为1,请检查!"	rslt = 0	Goto extEnd If//查询采购限价并检查进仓价If billtype = 1 Or billtype = 4 Then	If li_iflimitprice = 1 Then		If uo_sptprice.uf_check_price_save(thflag,sptid,s_mx.mtrlid,s_mx.mtrlcode,s_mx.unit,s_mx.status,s_mx.woodcode,s_mx.pcode,s_mx.uprice * s_mx.rebate,arg_msg) = 0 Then			arg_msg = "第" + String(s_mx.printid) + "行," + arg_msg			rslt = 0			Goto ext		End If	End IfEnd IfInt li_if_cus_mtrlware, li_if_plancode, li_inwaretypeIf sys_option_hide_ware = 0 Then	Select  balctype , if_plancode, inwaretype		Into :li_if_cus_mtrlware, :li_if_plancode, :li_inwaretype		From u_storage		Where storageid = :storageid;	If sqlca.SQLCode <> 0 Then		arg_msg =  "第" + String(s_mx.printid) + "行,查询仓库是否使用客户库存失败"		rslt = 0		Goto ext	End IfEnd If//关于客户库存处理,sptidLong ll_cusidInt li_bhflagIf dxflag = 0 Then	If li_if_cus_mtrlware = 1 Then		If billtype = 3 Then			//特殊情况 20140104			//生产进仓单,按订单进仓的产品,如果订单的客户为 备货客户, 进仓时不按客户库存; 			If s_mx.ifrel > 0 Then				If s_mx.relid = 0 Then					arg_msg = "第" + String(s_mx.printid) + '行,请先择相应的销售订单'					rslt = 0					Goto ext				End If								Select  top 1 cusid Into :ll_cusid					From u_saletaskmx,u_saletask					Where u_saletaskmx.scid = u_saletask.scid					And u_saletaskmx.taskid = u_saletask.taskid					And u_saletaskmx.scid = :scid					And u_saletaskmx.taskid = :s_mx.relid					And u_saletaskmx.printid = :s_mx.relprintid					And u_saletaskmx.mtrlid = :s_mx.mtrlid					Using commit_transaction;				If commit_transaction.SQLCode <> 0 Then					arg_msg = "第" + String(s_mx.printid) + '行,查询销售订单客户资料失败,'+commit_transaction.SQLErrText					rslt = 0					Goto ext				End If				// s_mx.mtrlid 以后有可能是 下级的生产物料!!!!								If IsNull(ll_cusid) Then ll_cusid = 0								If ll_cusid > 0 Then					Select bhflag Into :li_bhflag From u_cust Where cusid = :ll_cusid						Using commit_transaction;					If commit_transaction.SQLCode <> 0 Then						arg_msg = "第" + String(s_mx.printid) + '行,查询销售订单客户资料失败,'+commit_transaction.SQLErrText						rslt = 0						Goto ext					End If				Else					li_bhflag = 0				End If				If IsNull(li_bhflag) Then li_bhflag = 0								If li_bhflag = 1 Then					s_mx.sptid = 0				Else					s_mx.sptid = s_mx.sptid				End If			End If					Else			s_mx.sptid = s_mx.sptid		End If	Else		s_mx.sptid = 0	End IfElse	If li_if_cus_mtrlware <> 1 Then		arg_msg = "仓库没有使用客户库存,不能建立代销单据"		rslt = 0		Goto ext	End If	s_mx.sptid = sptidEnd IfChoose Case billtype	Case 1 //采购		If s_mx.ifrel > 0 Then			If s_mx.relid = 0 Then				arg_msg = "第" + String(s_mx.printid) + "行,请先择相应的订单!"				rslt = 0				Goto ext			End If						Select taskcode ,uqty - consignedqty,				CASE when u_buytask.billtype = 1 THEN u_buytaskmx.relcode ELSE '' End				Into :ls_relcode,:ld_bootqty,:ls_saletaskcode				From u_buytaskmx,u_buytask				Where u_buytaskmx.taskid =  u_buytask.taskid				And u_buytaskmx.scid =  u_buytask.scid				And u_buytaskmx.scid = :scid				And u_buytaskmx.taskid = :s_mx.relid				And u_buytaskmx.printid = :s_mx.relprintid				Using commit_transaction;							If commit_transaction.SQLCode <> 0 Then				arg_msg = "第" + String(s_mx.printid) + "行,查询采购订单是否有订购:"+s_mx.mtrlcode+'失败!'+commit_transaction.SQLErrText				rslt = 0				Goto ext			End If						//查相关销售订单已开单数			ld_noauditqty = 0			Select sum(uqty) Into :ld_noauditqty				From u_inwaremx				Where scid = :scid				And relid = :s_mx.relid				And relprintid = :s_mx.relprintid				And inwareid <> :inwareid;			If sqlca.SQLCode <> 0 Then				arg_msg = "第" + String(s_mx.printid) + "行,查询"+s_mx.mtrlcode+'相关订单单据已开单数失败!'				rslt = 0				Goto ext			End If			If IsNull(ld_noauditqty) Then ld_noauditqty = 0		Else			s_mx.relid = 0			s_mx.relprintid = 0		End If	Case 3 //生产				If s_mx.ifrel > 0 Then			If s_mx.relid = 0 Then				arg_msg = "第" + String(s_mx.printid) + '行,请先择相应的销售订单'				rslt = 0				Goto ext			End If						Select  top 1 taskcode Into :ls_relcode				From u_saletaskmx,u_saletask				Where u_saletaskmx.scid = u_saletask.scid				And u_saletaskmx.taskid = u_saletask.taskid				And u_saletaskmx.scid = :scid				And u_saletaskmx.taskid = :s_mx.relid				And u_saletaskmx.printid = :s_mx.relprintid				And u_saletaskmx.mtrlid = :s_mx.mtrlid				Using commit_transaction;			If commit_transaction.SQLCode <> 0 Then				arg_msg = "第" + String(s_mx.printid) + '行,查询销售订单是否有排产:'+s_mx.mtrlcode+'失败,'+commit_transaction.SQLErrText				rslt = 0				Goto ext			End If		Else			s_mx.relid = 0			s_mx.relprintid = 0		End If	Case 4 //外协		If s_mx.ifrel > 0 Then			If s_mx.relid = 0 Then				arg_msg = "第" + String(s_mx.printid) + '行,请先择相应的外协订单'				rslt = 0				Goto ext			End If						Select u_order_wfjg.taskcode,				CASE when u_order_wfjg.billtype = 1 THEN  u_order_wfjgmx.relcode ELSE '' End				Into :ls_relcode,:ls_saletaskcode				From u_order_wfjgmx,u_order_wfjg				Where u_order_wfjgmx.scid =  u_order_wfjg.scid				And u_order_wfjgmx.wfjgid =  u_order_wfjg.wfjgid				And u_order_wfjgmx.wfjgid = :s_mx.relid				And u_order_wfjgmx.printid = :s_mx.relprintid				And u_order_wfjgmx.mtrlid = :s_mx.mtrlid				And u_order_wfjgmx.status = :s_mx.status				And u_order_wfjgmx.woodcode = :s_mx.woodcode				And u_order_wfjgmx.pcode = :s_mx.pcode				Using commit_transaction;							If commit_transaction.SQLCode <> 0 Then				arg_msg = "第" + String(s_mx.printid) + '行,查询外协订单是否有加工:'+s_mx.mtrlcode+'失败,'+commit_transaction.SQLErrText				rslt = 0				Goto ext			End If		End IfEnd Choose//处理plancodestorage_plancode_flag = 0If li_if_plancode = 0 Then //不使用	s_mx.plancode = ''Else	If thflag <> 1 Then //退货不处理		If li_inwaretype = 1 Then //无(不变)			//inwaremx[it_mxbt].plancode = s_mx.plancode		ElseIf li_inwaretype = 2 Then //价格			s_mx.plancode = String(Round(s_mx.uprice * s_mx.rebate,5))		ElseIf li_inwaretype = 3 Then //订单			If ls_relcode <> '' And billtype = 3 Then				s_mx.plancode = ls_relcode			ElseIf ls_saletaskcode <> '' And (billtype = 1 Or billtype = 4 ) Then				s_mx.plancode = ls_saletaskcode			Else				s_mx.plancode = s_mx.plancode //(不变)			End If		ElseIf li_inwaretype = 5 Then //进仓单号			storage_plancode_flag = 1 //仓库中是否设置了使用 “进仓单号” 作为批号					ElseIf  li_inwaretype = 6 Then //数值						s_mx.plancode = String(s_mx.uqty,'#,##0.####')		ElseIf  li_inwaretype = 7 Then //日期时间顺序						If s_mx.plancode = '' Then				s_mx.plancode = String(Today(), 'yymmddhhmm')	 + '-' + String(s_mx.printid)			End If		End If	End If //退货不处理End If//处理 sptmtrlnameString ls_sptmtrlnameIf billtype = 1 Then	If uo_sptprice.uf_getmtrlname(sptid,s_mx.mtrlid,ls_sptmtrlname,arg_msg) = 0 Then		rslt = 0		Goto ext	End IfElse	ls_sptmtrlname = ""End If//处理价格===============================//取默认报价If billtype = 1 Then	f_get_defsptprice(sptid,s_mx.mtrlid,s_mx.unit,s_mx.status,s_mx.pcode,s_mx.woodcode,ld_dftsptprice)Else	ld_dftsptprice = 0End If//不是自动的单价If sysautobuild = False Then	If s_mx.uprice * s_mx.rebate < 0 Then //检查进仓价		rslt = 0		arg_msg = "第" + String(s_mx.printid) + '行,' + String(s_mx.mtrlcode)+" 单价错误"		Goto ext	End IfEnd IfIf s_mx.tax < 0 Then	rslt = 0	arg_msg = "税率不能为负数"	Goto extEnd If//检查成本价调整单Long ll_mtrlwareidIf sys_option_hide_ware = 0 Then	Select mtrlwareid		Into :ll_mtrlwareid		From u_mtrlware		Where ( mtrlid = :s_mx.mtrlid ) And		( plancode = :s_mx.plancode ) And		( storageid = :storageid ) And		( scid = :scid ) And		( status = :s_mx.status ) And		( sptid = :s_mx.sptid) And		( dxflag = :dxflag) And		( woodcode = :s_mx.woodcode) And		( pcode = :s_mx.pcode) Using commit_transaction;	If commit_transaction.SQLCode  = -1 Then		arg_msg = "第" + String(s_mx.printid) + "行,查询库存信息失败!"		rslt = 0		Goto ext	End If		If IsNull(ll_mtrlwareid) Then ll_mtrlwareid = 0	If ll_mtrlwareid > 0  Then		If Not (billtype = 8 And sptname = '成本价调整单审核自动生成') Then			cnt = 0			Select count(*)				Into :cnt				From u_updatecost,u_updatecostmx				Where u_updatecost.wareid = u_updatecostmx.wareid And				u_updatecost.flag = 0 And				u_updatecostmx.mtrlwareid = :ll_mtrlwareid And				u_updatecost.scid = :scid  Using commit_transaction;			If commit_transaction.SQLCode <> 0 Then				rslt = 0				arg_msg = "第" + String(s_mx.printid) + "行,查询成本价调整单操作失败"				Goto ext			End If			If cnt > 0 Then				rslt = 0				arg_msg = "第" + String(s_mx.printid) + "行," + s_mx.mtrlcode + "已开成本价调整单,请先审核"				Goto ext			End If		End If				//出仓的, 查询成本价			Else			End IfEnd If//s_mx.price = Round(s_mx.enprice * mrate * s_mx.rebate,10) //进仓实价, 本位币,库存单位s_mx.qty =  Round(s_mx.uqty * s_mx.rate, sys_option_unit_dec) //库存单位,进仓数量//写入内容it_mxbt++inwaremx[it_mxbt].mtrlwareid = ll_mtrlwareidinwaremx[it_mxbt].printid = s_mx.printidinwaremx[it_mxbt].mtrlid = s_mx.mtrlidinwaremx[it_mxbt].mtrlcode = s_mx.mtrlcodeinwaremx[it_mxbt].unit = s_mx.unitinwaremx[it_mxbt].rate = s_mx.rateinwaremx[it_mxbt].noauditqty = ld_noauditqtyinwaremx[it_mxbt].bootqty = ld_bootqtyinwaremx[it_mxbt].addqty = s_mx.addqtyinwaremx[it_mxbt].uqty = s_mx.uqtyinwaremx[it_mxbt].qty = s_mx.qtyinwaremx[it_mxbt].buyqty = s_mx.buyqtyinwaremx[it_mxbt].packqty = s_mx.packqtyinwaremx[it_mxbt].uprice = s_mx.uprice //进仓价, 原币, 进仓单位If s_mx.buyqty <> 0 Then	inwaremx[it_mxbt].fprice =  Round((s_mx.uprice * s_mx.buyqty) /(Round(s_mx.buyqty * s_mx.rate,sys_option_unit_dec)) * mrate ,10) //进仓价, 本位币, 库存单位Else	inwaremx[it_mxbt].fprice =  Round(s_mx.uprice * s_mx.rate * mrate,10)End Ifinwaremx[it_mxbt].fprice_notax = inwaremx[it_mxbt].fprice / (1 + s_mx.tax) //不含税价inwaremx[it_mxbt].price = Round(inwaremx[it_mxbt].fprice * s_mx.rebate,10) //进仓实价, 本位币,库存单位inwaremx[it_mxbt].rebate = s_mx.rebateinwaremx[it_mxbt].tax = s_mx.taxIf billtype = 1 Then	ld_round = 10.0 ^ (2 - sys_option_inware_buy_amt_round)	If sys_option_inware_buy_amt_round = 5 Then ld_round = 1000End Ifinwaremx[it_mxbt].uamt = Round(s_mx.buyqty * s_mx.uprice * s_mx.rebate * ld_round, 0) / ld_round //原币,实价含税金额If s_mx.uamt_tax = 0 Then	inwaremx[it_mxbt].uamt_tax = Round((s_mx.buyqty * s_mx.uprice * s_mx.rebate)  * s_mx.tax / (1 + s_mx.tax) * ld_round, 0) / ld_round //原币, 税金Else	inwaremx[it_mxbt].uamt_tax = s_mx.uamt_taxEnd Ifinwaremx[it_mxbt].bsamt = Round(s_mx.buyqty * s_mx.uprice * s_mx.rebate * mrate * ld_round, 0) / ld_round //本位币, 实价含税金额inwaremx[it_mxbt].bsamt_tax = Round((s_mx.buyqty * s_mx.uprice * s_mx.rebate * mrate)  * s_mx.tax / (1 + s_mx.tax) * ld_round, 0) / ld_round //本位币, 税金inwaremx[it_mxbt].planprice = ld_planpriceinwaremx[it_mxbt].jgprice = s_mx.jgpriceinwaremx[it_mxbt].mxdscrp = s_mx.mxdscrpinwaremx[it_mxbt].mxdscrp2 = s_mx.mxdscrp2inwaremx[it_mxbt].mxdscrp3 = s_mx.mxdscrp3inwaremx[it_mxbt].mxdscrp4 = s_mx.mxdscrp4inwaremx[it_mxbt].dxflag = dxflaginwaremx[it_mxbt].relid = s_mx.relidinwaremx[it_mxbt].relprintid = s_mx.relprintidinwaremx[it_mxbt].ifrel = s_mx.ifrelinwaremx[it_mxbt].status = s_mx.statusinwaremx[it_mxbt].woodcode = s_mx.woodcodeinwaremx[it_mxbt].pcode = s_mx.pcodeinwaremx[it_mxbt].relcode = ls_relcodeinwaremx[it_mxbt].mtrlcuscode = s_mx.mtrlcuscodeinwaremx[it_mxbt].dftsptprice = ld_dftsptpriceinwaremx[it_mxbt].formula = s_mx.formulainwaremx[it_mxbt].waredscrp = s_mx.waredscrpinwaremx[it_mxbt].inworkdate = s_mx.inworkdateinwaremx[it_mxbt].plancode = s_mx.plancodeinwaremx[it_mxbt].sptid = s_mx.sptidinwaremx[it_mxbt].sptmtrlname = ls_sptmtrlname //供应商别名inwaremx[it_mxbt].uprice_notax = s_mx.uprice_notax //不含税单价//IF sys_option_buyth_wareamt = 0 THEN//Decimal ld_cost_notaxIf (billtype = 1 And thflag = 1 And sys_option_buyth_wareamt = 0 ) &	Or (s_mx.uqty < 0 And billtype <> 3 And billtype <> 1) Then //采购退货单 或者 非采购/生产进仓	Select cost,cost_notax		Into :ld_cost,:ld_cost_notax		From u_mtrlware		Where scid = :scid		And mtrlid = :s_mx.mtrlid		And storageid = :storageid		And status = :s_mx.status		And plancode = :s_mx.plancode		And woodcode = :s_mx.woodcode		And pcode = :s_mx.pcode		And dxflag = :dxflag		And sptid = :s_mx.sptid;	If sqlca.SQLCode <> 0 Or IsNull(ld_cost) Then ld_cost = 0	If sqlca.SQLCode <> 0 Or IsNull(ld_cost_notax) Then ld_cost_notax = 0		inwaremx[it_mxbt].cost = ld_cost	inwaremx[it_mxbt].cost_notax = ld_cost_notaxElse	inwaremx[it_mxbt].cost = inwaremx[it_mxbt].fprice * s_mx.rebate	inwaremx[it_mxbt].cost_notax = inwaremx[it_mxbt].fprice_notax * s_mx.rebateEnd Ifinwaremx[it_mxbt].costamt = Round(inwaremx[it_mxbt].cost * inwaremx[it_mxbt].qty, 2) //成本金额,库存单位ext:Destroy uo_sptpriceIf rslt = 0 Then	p_clearmx()	arg_msg = billname + ',' + arg_msgEnd IfReturn(rslt)end functionpublic function integer save (boolean arg_ifcommit, ref string arg_msg);Integer rslt = 1,cnt = 0,iDateTime server_dtLong ls_newidString ls_sccodeIF IsNull(relid) THEN relid = 0IF IsNull(storageid) THEN storageid = 0IF IsNull(inrep) THEN inrep = ''IF IsNull(dscrp) THEN dscrp = ''IF IsNull(part) THEN part = ''IF IsNull(sptid) THEN sptid = 0IF IsNull(sptname) THEN sptname = ''IF IsNull(dxflag) THEN dxflag = 0IF IsNull(thflag) THEN thflag = 0IF IsNull(relint_1) THEN relint_1 = 0IF IsNull(relint_2) THEN relint_2 = 0IF IsNull(relint_3) THEN relint_3 = 0IF IsNull(relint_4) THEN relint_4 = 0IF IsNull(relint_5) THEN relint_5 = 0IF IsNull(relstr_1) THEN relstr_1 = ''IF IsNull(relstr_2) THEN relstr_2 = ''IF IsNull(relstr_3) THEN relstr_3 = ''IF IsNull(mrate) THEN mrate = 0IF mrate = 0 THEN mrate = 1IF it_newbegin = False And it_updatebegin = False THEN	rslt = 0	arg_msg = "非编辑状态不可以提交"	GOTO extEND IFSELECT Top 1 getdate() Into :server_dt From u_user Using commit_transaction ;//取得系统时间,借用操作员表IF commit_transaction.SQLCode <> 0 THEN	rslt = 0	arg_msg = "查询操作失败,日期 "	GOTO extEND IFIF save_chk(arg_msg) = 0 THEN	rslt = 0	GOTO extEND IF////////////////////////////////////////////// //开始区分:新建/更新 处理IF inwareid = 0 THEN //新建	ls_newid = f_sys_scidentity(scid,"u_inware","inwareid",arg_msg,if_getid_ture,commit_transaction)	IF ls_newid <= 0 THEN		rslt = 0		GOTO ext	END IF		//取分部代号	IF f_get_sccode(scid,commit_transaction,ls_sccode,arg_msg) = 0 THEN		rslt = 0		GOTO ext	END IF		//取得新单据编号		CHOOSE CASE billtype		CASE 1,2			IF thflag = 0 THEN				inwarecode = getid(scid,ls_sccode + 'CG',Date(server_dt),if_getid_ture,commit_transaction)			ELSE				inwarecode = getid(scid,ls_sccode + 'CT',Date(server_dt),if_getid_ture,commit_transaction)			END IF		CASE 3			inwarecode = getid(scid,ls_sccode + 'CP',Date(server_dt),if_getid_ture,commit_transaction)		CASE 4			IF thflag = 0 THEN				inwarecode = getid(scid,ls_sccode + 'WN',Date(server_dt),if_getid_ture,commit_transaction)			ELSE				inwarecode = getid(scid,ls_sccode + 'WH',Date(server_dt),if_getid_ture,commit_transaction)			END IF		CASE 8			inwarecode = getid(scid,ls_sccode + 'JC',Date(server_dt),if_getid_ture,commit_transaction)		CASE 9			inwarecode = getid(scid,ls_sccode + 'PY',Date(server_dt),if_getid_ture,commit_transaction)		CASE 12			inwarecode = getid(scid,ls_sccode + 'IC',Date(server_dt),if_getid_ture,commit_transaction)		CASE 15			inwarecode = getid(scid,ls_sccode + 'DC',Date(server_dt),if_getid_ture,commit_transaction)		CASE 20			IF thflag = 0 THEN				inwarecode = getid(scid,ls_sccode + 'RI',Date(server_dt),if_getid_ture,commit_transaction)			ELSE				inwarecode = getid(scid,ls_sccode + 'RT',Date(server_dt),if_getid_ture,commit_transaction)			END IF		CASE 22			inwarecode = getid(scid,ls_sccode + 'TI',Date(server_dt),if_getid_ture,commit_transaction)	END CHOOSE		IF inwarecode = "err" THEN		inwarecode = ''		rslt = 0		arg_msg = "无法获取进仓单编号"+"~n"		GOTO ext	END IF		INSERT INTO u_inware (		scid,		inwareid,		inwarecode,		billtype,		relid,		storageid,		indate,		inrep,		part,		dscrp,		sptid,		sptname,		thflag,		dxflag,		otheramt,		opdate,		opemp,		relint_1,		relint_2,		relint_3,		relstr_1,		relstr_2,		relstr_3,		mrate,		relint_4,		relint_5,		viewdate)		VALUES (		:scid,		:ls_newid,		:inwarecode,		:billtype,		:relid,		:storageid,		:indate,		:inrep,		:part,		:dscrp,		:sptid,		:sptname,		:thflag,		:dxflag,		:otheramt,		:server_dt,		:publ_operator,		:relint_1,		:relint_2,		:relint_3,		:relstr_1,		:relstr_2,		:relstr_3,		:mrate,		:relint_4,		:relint_5,		:viewdate) Using commit_transaction ;	IF commit_transaction.SQLCode <> 0 THEN		rslt = 0				IF Pos(Lower(commit_transaction.SQLErrText),'PK_u_inware') > 0 THEN			arg_msg = '插入单据资料失败,关键字ID重复'		ELSEIF Pos(Lower(commit_transaction.SQLErrText),'IX_u_inware') > 0 THEN			arg_msg = '插入单据资料失败,单据编号重复'		ELSE			arg_msg = '插入单据资料失败,'+commit_transaction.SQLErrText		END IF		//arg_msg = "插入操作失败"+"~n"+commit_transaction.SQLErrText		GOTO ext	END IF		//读取新inwareid	inwareid = ls_newid	ELSE //////////////////////////////////////////////// //更新	UPDATE u_inware		SET billtype = :billtype,		relid = :relid,		storageid = :storageid,		indate = :indate,		inrep = :inrep,		part = :part,		dscrp = :dscrp,		sptid = :sptid,		sptname = :sptname,		thflag = :thflag,		dxflag = :dxflag,		otheramt = :otheramt,		moddate = :server_dt,		modemp = :publ_operator,		relint_1 = :relint_1,		relint_2 = :relint_2,		relint_3 = :relint_3,		relstr_1 = :relstr_1,		relstr_2 = :relstr_2,		relstr_3 = :relstr_3,		mrate = :mrate,		relint_4 = :relint_4,		relint_5 = :relint_5,		viewdate = :viewdate		WHERE u_inware.inwareid = :inwareid		AND u_inware.scid = :scid		Using commit_transaction;	IF commit_transaction.SQLCode <> 0 Or commit_transaction.SQLNRows <= 0  THEN		rslt = 0				IF Pos(Lower(commit_transaction.SQLErrText),'PK_u_inware') > 0 THEN			arg_msg = '更新单据资料失败,关键字ID重复'		ELSEIF Pos(Lower(commit_transaction.SQLErrText),'IX_u_inware') > 0 THEN			arg_msg = '更新单据资料失败,单据编号重复'		ELSE			arg_msg = '更新单据资料失败,'+commit_transaction.SQLErrText		END IF						arg_msg = "更新单据操作失败"+"~n"+commit_transaction.SQLErrText		GOTO ext	END IF		IF billtype > 1 Or billtype = 1 And flag = 0 THEN						//删除原有明细		DELETE FROM u_inwaremx			WHERE u_inwaremx.inwareid = :inwareid			And u_inwaremx.scid = :scid Using commit_transaction;					IF commit_transaction.SQLCode <> 0 THEN			rslt = 0			arg_msg = "删除旧有单据明细操作失败"+"~n"			GOTO ext		END IF			ELSE			END IFEND IFIF billtype > 1 Or billtype = 1 And flag = 0 THEN	FOR i = 1 To it_mxbt		IF storage_plancode_flag = 1 THEN //仓库中是否设置了使用 “进仓单号” 作为批号			inwaremx[i].plancode = inwarecode		END IF		INSERT INTO u_inwaremx			(scid,			inwareid,			printid,			mtrlid,			plancode,			status,			qty,			addqty,			packqty,			fprice,			rebate,			price,			planprice,			mxdscrp,			jgprice,			relid,			relprintid,			ifrel,			woodcode,			relcode,			pcode,			sptid_cusid,			cost,			sptmtrlname,			unit,			rate,			uprice,			uqty,			bootqty,			noauditqty,			mtrlcuscode,			dftsptprice,			formula,			waredscrp,			inworkdate,			tax,			buyqty,			uamt,			uamt_tax,			bsamt,			bsamt_tax,			costamt,			uprice_notax,			mxdscrp2,			mxdscrp3,			mxdscrp4,			cost_notax)			VALUES (			:scid,			:inwareid,			:inwaremx[i].printid,			:inwaremx[i].mtrlid,			:inwaremx[i].plancode,			:inwaremx[i].status,			:inwaremx[i].qty,			:inwaremx[i].addqty,			:inwaremx[i].packqty,			:inwaremx[i].fprice,			:inwaremx[i].rebate,			:inwaremx[i].price,			:inwaremx[i].planprice,			:inwaremx[i].mxdscrp,			:inwaremx[i].jgprice,			:inwaremx[i].relid,			:inwaremx[i].relprintid,			:inwaremx[i].ifrel,			:inwaremx[i].woodcode,			:inwaremx[i].relcode,			:inwaremx[i].pcode,			:inwaremx[i].sptid,			:inwaremx[i].cost,			:inwaremx[i].sptmtrlname,			:inwaremx[i].unit,			:inwaremx[i].rate,			:inwaremx[i].uprice,			:inwaremx[i].uqty,			:inwaremx[i].bootqty,			:inwaremx[i].noauditqty,			:inwaremx[i].mtrlcuscode,			:inwaremx[i].dftsptprice,			:inwaremx[i].formula,			:inwaremx[i].waredscrp,			:inwaremx[i].inworkdate,			:inwaremx[i].tax,			:inwaremx[i].buyqty,			:inwaremx[i].uamt,			:inwaremx[i].uamt_tax,			:inwaremx[i].bsamt,			:inwaremx[i].bsamt_tax,			:inwaremx[i].costamt,			:inwaremx[i].uprice_notax,			:inwaremx[i].mxdscrp2,			:inwaremx[i].mxdscrp3,			:inwaremx[i].mxdscrp4,			:inwaremx[i].cost_notax) Using commit_transaction;		IF commit_transaction.SQLCode <> 0 THEN			IF it_newbegin THEN inwareid = 0			rslt = 0						IF Pos(Lower(commit_transaction.SQLErrText),'PK_u_inwaremx') > 0 THEN				arg_msg = '插入单据明细内容失败,关键字ID重复'			ELSEIF Pos(Lower(commit_transaction.SQLErrText),'IX_u_inwaremx') > 0 THEN				arg_msg = '插入单据明细内容失败,三个属性字段重复'			ELSE				arg_msg = '插入单据明细内容失败,'+commit_transaction.SQLErrText			END IF			GOTO ext		END IF	NEXT	ELSE	FOR i = 1 To it_mxbt		UPDATE u_inWAREmx			SET uprice = :inWAREmx[i].uprice,			mxdscrp = :inwaremx[I].mxdscrp,			fprice = :inwaremx[I].fprice,			rebate = :inwaremx[I].rebate,			price = :inwaremx[I].price,			tax = :inwaremx[i].tax,			uamt = :inwaremx[i].uamt,			uamt_tax  = :inwaremx[i].uamt_tax,			bsamt = :inwaremx[i].bsamt,			bsamt_tax = :inwaremx[i].bsamt_tax,			uprice_notax =:inwaremx[i].uprice_notax			WHERE  ( scid = :scid AND			inWAREid = :inwareid AND			printid = :inwaremx[i].printid);		IF commit_transaction.SQLCode <> 0 THEN			rslt = 0			arg_msg = "更新明细价格、备注操作失败"+"~n"			GOTO ext		END IF	NEXTEND IFIF save_end(arg_msg) = 0 THEN	rslt = 0	GOTO extEND IFit_newbegin = Falseit_updatebegin = Falseext:IF rslt = 0 THEN	ROLLBACK Using commit_transaction;	p_clearmx()	arg_msg = billname + ',' + arg_msgELSEIF rslt = 1 And arg_ifcommit THEN	COMMIT Using commit_transaction;END IFRETURN rsltend functionpublic function integer priceaudit (long arg_scid, long arg_inwareid, boolean arg_ifcommit, ref string arg_msg);Long rslt = 1,iIF arg_scid < 0 THEN	rslt = 0	arg_msg = "错误的分部ID"	GOTO extEND IFIF arg_inwareid <= 0 THEN	rslt = 0	arg_msg = "没有确认对象"	GOTO extEND IFif getinfo(arg_scid,arg_inwareid,arg_msg) = 0 then	rslt = 0	goto extend ifIF priceflag = 1 THEN	rslt = 0	arg_msg = "单据已经确认"	GOTO extEND IFUPDATE u_inware	SET priceemp = :publ_operator,	pricedate = getdate(),	priceflag = 1	WHERE u_inware.inwareid = :arg_inwareid	AND priceflag = 0	AND scid = :arg_scid USING commit_transaction;	IF commit_transaction.SQLCode <> 0 THEN	rslt = 0	arg_msg = "因网络或其它原因导致确认单据操作失败"+"~n"+commit_transaction.SQLErrText	GOTO extELSEIF commit_transaction.SQLNRows = 0 THEN	rslt = 0	arg_msg = "单据正在确认,请稍后查询。"+"~n"+commit_transaction.SQLErrText	GOTO extEND IFpriceflag = 1ext:IF rslt = 0 THEN	ROLLBACK USING commit_transaction;ELSEIF rslt = 1 AND arg_ifcommit THEN	COMMIT USING commit_transaction;END IFRETURN rsltend functionpublic function integer c_priceaudit (long arg_scid, long arg_inwareid, boolean arg_ifcommit, ref string arg_msg);Long rslt = 1,iDateTime null_dtSetNull(null_dt) IF arg_scid < 0 THEN	rslt = 0	arg_msg = "错误的分部ID"	GOTO extEND IFIF arg_inwareid <= 0 THEN	rslt = 0	arg_msg = "没有确认对象"	GOTO extEND IFif getinfo(arg_scid,arg_inwareid,arg_msg) = 0 then	rslt = 0	goto extend ifIF priceflag = 0 THEN	rslt = 0	arg_msg = "单据未确认"	GOTO extEND IFUPDATE u_inware	SET priceemp = '',	pricedate = :null_dt,	priceflag = 0	WHERE u_inware.inwareid = :arg_inwareid	AND priceflag = 1	AND scid = :arg_scid USING commit_transaction;	IF commit_transaction.SQLCode <> 0 THEN	rslt = 0	arg_msg = "因网络或其它原因导致确认单据操作失败"+"~n"+commit_transaction.SQLErrText	GOTO extELSEIF commit_transaction.SQLNRows = 0 THEN	rslt = 0	arg_msg = "单据正在确认,请稍后查询。"+"~n"+commit_transaction.SQLErrText	GOTO extEND IFpriceflag = 0ext:IF rslt = 0 THEN	ROLLBACK USING commit_transaction;ELSEIF rslt = 1 AND arg_ifcommit THEN	COMMIT USING commit_transaction;END IFRETURN rsltend functionon uo_inware_buy.createcall super::createend onon uo_inware_buy.destroycall super::destroyend on
 |