| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771 | $PBExportHeader$uo_cwork.sruforwardglobal type uo_cwork from nonvisualobjectend typeend forwardglobal type uo_cwork from nonvisualobjectend typeglobal uo_cwork uo_cworktype variablespublic protectedwrite long billid           //计件单自动增量idpublic protectedwrite string billcode       //计件单的唯一编号public protectedwrite datetime opdate       //建立时间,自动public protectedwrite string opemp          //建立人public protectedwrite datetime moddate       //修改时间,自动public protectedwrite string modemp          //修改人public protectedwrite int flag=0            //审核标志public protectedwrite datetime auditingdate //审核时间public protectedwrite string auditingrep    //审核操作员long empid          datetime billdate   decimal amt     long wageid         string reason   string deptidea        string ideadatetime begindatedatetime enddatelong cworkidlong wagemthuo_wage u_wageprivate:boolean it_newbegin=false    //新建标志boolean it_updatebegin=false//修改标志end variablesforward prototypespublic function integer p_reset ()public function integer newbegin (ref string arg_msg)public function integer updatebegin (long arg_billid, ref string arg_msg)public function integer c_auditing (long arg_wageid, long arg_wagemth, ref string arg_msg, boolean arg_ifcommit)public function integer save (ref string arg_msg, boolean arg_ifcommit)public function integer del (long arg_billid, ref string arg_msg)public function integer auditing (long arg_wageid, long arg_wagemth, ref string arg_msg, boolean arg_ifcommit)public function integer add_deptidea (long arg_billid, string arg_newdescppart, ref string arg_msg)public function integer add_idea (long arg_billid, string arg_newdescppart, ref string arg_msg)end prototypespublic function integer p_reset ();//INT p_RESET()//清除对象及其明细billid=0billcode=''opemp=''auditingrep=''flag=0empid=0  amt=0      reason=''wageid=0    cworkid=0  idea=''    deptidea=''it_newbegin=FALSEit_updatebegin=FALSERETURN 1end functionpublic function integer newbegin (ref string arg_msg);p_reset()it_newbegin=TRUEit_updatebegin=FALSEreturn 1end functionpublic function integer updatebegin (long arg_billid, ref string arg_msg);//====================================================================// Function: updatebegin(arg_billid,arg_msg)//--------------------------------------------------------------------// Description: //--------------------------------------------------------------------// Arguments: //		value    	long  	arg_billid		//		reference	string	arg_msg   		//--------------------------------------------------------------------// Returns:  integer//--------------------------------------------------------------------// Author:	yyx		Date: 2003.11.21//--------------------------------------------------------------------// Modify History: //	//====================================================================int rslt = 1if arg_billid <= 0 then	billid = 0	arg_msg = '错误的单据ID'	goto extend ifselectu_gz_cwork.billcode,u_gz_cwork.billdate,u_gz_cwork.wagemth,u_gz_cwork.wageid,u_gz_cwork.empid,u_gz_cwork.amt,u_gz_cwork.reason,u_gz_cwork.deptidea,u_gz_cwork.begindate,u_gz_cwork.enddate,u_gz_cwork.idea,u_gz_cwork.flaginto:billcode,:billdate,:wagemth,:wageid,:empid,:amt,:reason,:deptidea,:begindate,:enddate,:idea,:flagfrom u_gz_cwork where u_gz_cwork.billid = :arg_billid;if sqlca.sqlcode <> 0 then	rslt = 0	if pos(lower(sqlca.SQLErrText),'more than') > 0 then		arg_msg = '查询操作失败,查询数据返回值多于一个'	else		arg_msg = '查询数据操作失败,考勤单(错误单据唯一码)' 	end if	goto extend ifif flag = 1 then	rslt = 0	arg_msg = '单据已经审核,不可以修改'	goto extend ifbillid = arg_billidit_newbegin = falseit_updatebegin = trueext:if  rslt = 0 then p_reset()arg_msg = '考勤单,'+ arg_msgreturn rsltend functionpublic function integer c_auditing (long arg_wageid, long arg_wagemth, ref string arg_msg, boolean arg_ifcommit);long cnt=0,iint rslt=1datetime null_server_dtsetnull(null_server_dt)select count(*) into :cntfrom u_gz_cwork where wagemth=:arg_wagemthand wageid = :arg_wageidand flag = 1;if sqlca.sqlcode<>0 then	rslt=0	arg_msg='查询考勤单失败'	goto extend ifif cnt=0 then 	rslt=0	arg_msg='该月的考勤单未审核,不用撤审!'	goto extend ifselect count(*) into :cnt from u_gz_wagewhere  wagemth=:arg_wagemth and Auditingflag=1;if sqlca.sqlcode<>0 then	rslt=0	arg_msg='查询工资表失败'	goto extend ifif cnt>0 then 	rslt=0	arg_msg='该月的工资表已审核,不能撤审!'	goto extend ifcnt=0select  count(*) into :cnt from u_gz_wageitem where useflag=1 and wageid=:arg_wageid;if sqlca.sqlcode<>0 then	rslt=0	arg_msg='查询工资项目失败'	goto extend if if cnt=0 then	rslt=0	arg_msg='不存在该工资项目'	goto extend ifupdate u_gz_cwork set 	flag=0,	Auditrep='',	Auditdate=:null_server_dtwhere  wagemth=:arg_wagemth and flag=1 and  wageid=:arg_wageid;if sqlca.sqlcode<>0 then	ARG_msg='更新考勤单失败,原因:'+sqlca.sqlerrtext	rslt=0	goto extend if	update u_gz_wagemx set wageamt=0 where wageid=:arg_wageid and wagemth=:arg_wagemth;if sqlca.sqlcode<>0 then	rslt=0	arg_Msg='更新工资表失败!原因:'+sqlca.sqlerrtext	goto extend if 	ext:if rslt=0 then	rollback;elseif  rslt=1 and arg_ifcommit then	commit;end ifarg_msg = '考勤单,'+ arg_msgreturn rsltend functionpublic function integer save (ref string arg_msg, boolean arg_ifcommit);//====================================================================// Function: save(arg_msg,arg_ifcommit)//--------------------------------------------------------------------// Description: //--------------------------------------------------------------------// Arguments: //		reference	string 	arg_msg     		//		value    	boolean	arg_ifcommit		//--------------------------------------------------------------------// Returns:  integer//--------------------------------------------------------------------// Author:	yyx		Date: 2003.11.21//--------------------------------------------------------------------// Modify History: //	//====================================================================integer rslt = 1,cnt = 0,idatetime server_dtlong ls_newidif isnull(empid)	 then empid = 0if isnull(amt)	 then amt = 0if isnull(wageid)	 then wageid = 0if isnull(wagemth)	 then wagemth = 0if isnull(reason)	 then reason = ''if isnull(deptidea)	 then deptidea = ''if isnull(idea)	 then idea = ''if isnull(cworkid)	 then cworkid = 0if it_newbegin = false and it_updatebegin = false then	rslt = 0	arg_msg = "非编辑状态不可以提交"	goto extend ifselect count(*) into :cntfrom u_rs_empinfowhere empid = :empid;if sqlca.sqlcode <> 0 then	arg_msg = '查询人员资料失败'	rslt = 0	goto extend ifif cnt > 1 then	arg_msg = '人员资料重复'	rslt = 0	goto extend if cnt = 0select count(*) into :cntfrom u_gz_cworkitemwhere cworkid = :cworkid;if sqlca.sqlcode <> 0 then	arg_msg = '查询考勤项目资料失败'	rslt = 0	goto extend ifif cnt > 1 then	arg_msg = '考勤项目重复'	rslt = 0	goto extend ifif wagemth = 0 then	arg_msg = '错误的工资月份'	rslt = 0	goto extend ifif amt < 0 then 	arg_msg = '请输入正确的金额'	rslt = 0	goto extend ifselect top 1 getdate() into :server_dt from u_user;//取得系统时间,借用操作员表if sqlca.sqlcode <> 0 then	rslt = 0	arg_msg = "查询操作失败,日期 "	goto extend ifif year(date(billdate)) < 2000 or isnull(billdate) then	rslt = 0	arg_msg = "时间不合理"	goto extend if////////////////////////////////////////////////开始区分:新建/更新 处理if billid = 0 then //新建	ls_newid = f_sys_scidentity(0,"u_gz_cwork","billid",arg_msg,true,sqlca)	if ls_newid <= 0 then		rslt = 0		goto ext	end if			billcode = getid(0,"KQ",date(server_dt),true,sqlca) //取得新单据编号	if billcode = "err" then		billcode = ''		rslt = 0		arg_msg = "无法获取考勤单编号"		goto ext	end if		insert into u_gz_cwork (		billid,		billcode,		billdate,		Wagemth,		wageid,		empid,		amt,		reason,		deptidea,		idea,		begindate,		enddate,		cworkid,		opdate,		opemp)		values ( 		:ls_newid,		:billcode,		:billdate,		:Wagemth,		:wageid,		:empid,		:amt,		:reason,		:deptidea,		:idea,		:begindate,		:enddate,		:cworkid,		:server_dt,		:publ_operator);	if sqlca.sqlcode <> 0 then		rslt = 0		if pos(lower(sqlca.SQLErrText),'pk_u_gz_cwork') > 0 then			arg_msg = '插入操作失败,关键字单据ID重复'		elseif pos(lower(sqlca.SQLErrText),'ix_u_gz_cwork') > 0 then			arg_msg = '插入操作失败,单据编号重复'		else			arg_msg = "因网络或其它原因导致插入操作失败>>"+"~n"+sqlca.sqlerrtext		end if		goto ext	end if		billid = ls_newid	else //////////////////////////////////////////////////更新		update u_gz_cwork		set billdate = :billdate,		wageid = :wageid,		empid = :empid,		amt = :amt,		reason = :reason,		deptidea = :deptidea,		idea = :idea,		moddate = :server_dt,		modemp = :modemp,		begindate = :begindate,		enddate = :enddate,		cworkid = :cworkid,		Wagemth = :Wagemth		where u_gz_cwork.billid = :billid		  and flag = 0;	if sqlca.sqlcode <> 0 or sqlca.sqlnrows <= 0 then		rslt = 0		if pos(lower(sqlca.SQLErrText),'pk_u_gz_cwork') > 0 then			arg_msg = '插入操作失败,关键字单据ID重复'		elseif pos(lower(sqlca.SQLErrText),'ix_u_gz_cwork') > 0 then			arg_msg = '插入操作失败,单据编号重复'		else			arg_msg = "因网络或其它原因导致插入操作失败>>"+"~n"+sqlca.sqlerrtext		end if		goto ext	end if		end ifit_newbegin = falseit_updatebegin = falseext:if rslt = 0 then	rollback;elseif rslt=1 and arg_ifcommit then	commit;end ifarg_msg = '考勤单,'+ arg_msgreturn(rslt)end functionpublic function integer del (long arg_billid, ref string arg_msg);//====================================================================// Function: del(arg_billid,arg_msg)//--------------------------------------------------------------------// Description: //--------------------------------------------------------------------// Arguments: //		value    	long  	arg_billid		//		reference	string	arg_msg   		//--------------------------------------------------------------------// Returns:  integer//--------------------------------------------------------------------// Author:	yyx		Date: 2003.11.21//--------------------------------------------------------------------// Modify History: //	//====================================================================int rslt = 1if arg_billid <= 0 then	rslt = 0	arg_msg = "没有删除对象,操作取消"	goto extend ifif it_newbegin or it_updatebegin then	rslt=0   arg_msg="编辑状态下不可以执行,操作取消"	goto extend ifselect u_gz_cwork.flag	into :flag	from u_gz_cwork	where u_gz_cwork.billid = :arg_billid;if sqlca.sqlcode <> 0  then	rslt = 0	if pos(lower(sqlca.SQLErrText),'more than') > 0 then		arg_msg = '查询操作失败,查询数据返回值多于一个'	else		arg_msg = '查询考勤单操作失败(错误单据唯一码)'	end if	goto extend ifif flag = 1 then	rslt = 0	arg_msg = "单据已经审核,不可以删除"	goto extend ifdelete from u_gz_cwork where u_gz_cwork.billid = :arg_billid;if sqlca.sqlcode <> 0 then	rslt = 0	arg_msg = "删除考勤单操作失败"+"~n"+sqlca.sqlerrtext	goto extend ifcommit;it_newbegin = falseit_updatebegin = falseext:if rslt = 0 then 	rollback;	p_reset()end ifarg_msg = '考勤单,'+ arg_msgreturn (rslt)end functionpublic function integer auditing (long arg_wageid, long arg_wagemth, ref string arg_msg, boolean arg_ifcommit);//====================================================================// Function: auditing()//--------------------------------------------------------------------// Description: //--------------------------------------------------------------------// Arguments: //		value    	long    	arg_wageid  		//		value    	long    	arg_wagemth 		//		value    	datetime	arg_enddate 		//		reference	string  	arg_msg     		//		value    	boolean 	arg_ifcommit		//--------------------------------------------------------------------// Returns:  integer//--------------------------------------------------------------------// Author:	yyx		Date: 2004.10.19//--------------------------------------------------------------------// Modify History: //	//====================================================================long cnt=0,iint rslt=1decimal ls_emp_sumwagedatastore ds_emp_sumwagecnt=0select count(*) into :cntfrom u_gz_cworkwhere  wagemth=:arg_wagemth and wageid = :arg_wageidand flag=1;if sqlca.sqlcode<>0 then	rslt=0	arg_msg='查询考勤单明细失败!'	goto extend ifif cnt>0 then 	rslt=0	arg_msg='该月的考勤单已审核,审核前请先执行撤审!'	goto extend ifcnt=0select  count(*) into :cnt from u_gz_wageitem where useflag=1 and wageid=:arg_wageid;if sqlca.sqlcode<>0 then	rslt=0	arg_msg='查询工资项目失败!'	goto extend if if cnt=0 then	rslt=0	arg_msg='不存在该工资项目!'	goto extend ifds_emp_sumwage=create datastoreds_emp_sumwage.dataobject='dw_emp_sumcworkwage'ds_emp_sumwage.settransobject(sqlca)if ds_emp_sumwage.retrieve(arg_wagemth,arg_wageid)<=0 then 	rslt=0	arg_msg='本月没有考勤单可审核或查询考勤单失败'	goto extend iffor i= 1 to ds_emp_sumwage.rowcount() 		ls_emp_sumwage=0.00	ls_emp_sumwage=ds_emp_sumwage.object.sumwage[i]	if u_wage.f_setwagemxdata(arg_wagemth,ds_emp_sumwage.object.empid[i],arg_wageid,ls_emp_sumwage,arg_msg,false)=0 then 		rslt=0				goto ext	end if		nextupdate u_gz_cwork set 	flag=1,	auditrep=:publ_operator,	Auditdate=getdate()where wagemth = :arg_wagemthand wageid = :arg_wageidand flag = 0;if sqlca.sqlcode<>0 then	ARG_msg='更新考勤单失败,原因>>'+sqlca.sqlerrtext	rslt=0	goto extend if	ext:if rslt=0 then	rollback;elseif rslt=1 and arg_ifcommit then	commit;end ifarg_msg = '考勤单,'+ arg_msgreturn rsltend functionpublic function integer add_deptidea (long arg_billid, string arg_newdescppart, ref string arg_msg);//====================================================================// Function: add_dscrp(arg_billid,arg_newdescppart,arg_msg)//--------------------------------------------------------------------// Description: //--------------------------------------------------------------------// Arguments: //		value    	long  	arg_billid      		//		value    	string	arg_newdescppart		//		reference	string	arg_msg         		//--------------------------------------------------------------------// Returns:  integer //--------------------------------------------------------------------// Author:	yyx		Date: 2003.11.21//--------------------------------------------------------------------// Modify History: //	//====================================================================int rslt = 1arg_newdescppart = trim(arg_newdescppart)if arg_billid <= 0 then	rslt = 0	arg_msg = "没有编辑对象,操作取消"	goto extend if//if it_newbegin or it_updatebegin then//	rslt=0//   arg_msg="编辑状态下不可以执行,操作取消"//	goto ext//end ifselect u_gz_cwork.flag	into :flag	from u_gz_cwork	where u_gz_cwork.billid = :arg_billid;if sqlca.sqlcode <> 0  then	rslt = 0	if pos(lower(sqlca.SQLErrText),'more than') > 0 then		arg_msg = '查询操作失败,查询数据返回值多于一个'	else		arg_msg = '查询考勤单操作失败(错误单据唯一码)'	end if	goto extend ifif flag = 0 then	rslt = 0	arg_msg = "非审核状态下不可用"	goto extend ifupdate u_gz_cwork	set deptidea =  lTRIM(RTRIM(deptidea)) +' '+:arg_newdescppart	where u_gz_cwork.billid = :arg_billid;if sqlca.sqlcode <> 0 then	rollback ;	rslt = 0	arg_msg = "因网络或其它原因导致添加主管部门意见操作失败"+"~n"+sqlca.sqlerrtext	goto extend ifcommit;deptidea = deptidea+' '+arg_newdescppartext:arg_msg = '考勤单,'+ arg_msgreturn (rslt)end functionpublic function integer add_idea (long arg_billid, string arg_newdescppart, ref string arg_msg);Int rslt = 1arg_newdescppart = Trim(arg_newdescppart)IF arg_billid <= 0 THEN	rslt = 0	arg_msg = "没有编辑对象,操作取消"	GOTO extEND IF//if it_newbegin or it_updatebegin then//	rslt=0//   arg_msg="编辑状态下不可以执行,操作取消"//	goto ext//end ifSELECT u_gz_cwork.flag	INTO :flag	FROM u_gz_cwork	Where u_gz_cwork.billid = :arg_billid;IF sqlca.SQLCode <> 0  THEN	rslt = 0	IF Pos(Lower(sqlca.SQLErrText),'more than') > 0 THEN		arg_msg = '查询操作失败,查询数据返回值多于一个'	ELSE		arg_msg = '查询考勤单操作失败(错误单据唯一码)'	END IF	GOTO extEND IFIF flag = 0 THEN	rslt = 0	arg_msg = "非审核状态下不可用"	GOTO extEND IFUPDATE u_gz_cwork	SET idea =  lTRIM(RTRIM(idea)) +' '+:arg_newdescppart	Where u_gz_cwork.billid = :arg_billid;IF sqlca.SQLCode <> 0 THEN	rslt = 0	arg_msg = "因网络或其它原因导致添加批示操作失败"+"~n"+sqlca.SQLErrText	GOTO extEND IFidea = idea+' '+arg_newdescppartext:IF rslt = 0 THEN	arg_msg = '考勤单,'+ arg_msg	ROLLBACK;ELSE	COMMIT;END IFRETURN  rsltend functionon uo_cwork.createcall super::createTriggerEvent( this, "constructor" )end onon uo_cwork.destroyTriggerEvent( this, "destructor" )call super::destroyend onevent constructor; u_wage=create uo_wageend eventevent destructor;DESTROY u_wageend event
 |