unit U_YGYPZZChkList_BGYPSQ; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls, ExtCtrls, ComCtrls, ToolWin, cxStyles, cxCustomData, cxGraphics, cxFilter, cxData, cxDataStorage, cxEdit, DB, cxDBData, ADODB, cxGridCustomPopupMenu, cxGridPopupMenu, cxGridLevel, cxClasses, cxControls, cxGridCustomView, cxGridCustomTableView, cxGridTableView, cxGridDBTableView, cxGrid, DBClient, cxCheckBox, cxCalendar, cxSplitter, RM_Dataset, RM_System, RM_Common, RM_Class, RM_GridReport, RM_e_Xls, Menus, cxButtonEdit, cxDropDownEdit, cxPC, ActnMan, ActnColorMaps; type TfrmYGYPZZChkList_BGYPSQ = class(TForm) ToolBar1: TToolBar; TBRafresh: TToolButton; TBFind: TToolButton; TBClose: TToolButton; cxGridPopupMenu1: TcxGridPopupMenu; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ADOQueryTemp: TADOQuery; DataSource1: TDataSource; TBExport: TToolButton; Order_Main: TClientDataSet; TBView: TToolButton; Panel1: TPanel; TBLiZhi: TToolButton; PopupMenu1: TPopupMenu; N2: TMenuItem; N1: TMenuItem; TCXTJ: TToolButton; BegDate: TDateTimePicker; Label3: TLabel; EndDate: TDateTimePicker; cxTabControl1: TcxTabControl; cxGrid1: TcxGrid; Tv1: TcxGridDBTableView; v1Column7: TcxGridDBColumn; v1GangWei: TcxGridDBColumn; cxGrid1Level1: TcxGridLevel; v1BGUnit: TcxGridDBColumn; v1Dept: TcxGridDBColumn; DataSource2: TDataSource; order_Sub: TClientDataSet; Label2: TLabel; v1SQDate: TcxGridDBColumn; v1BGQty: TcxGridDBColumn; TTiJiao: TToolButton; TCXSQ: TToolButton; TDel: TToolButton; cxStyleRepository1: TcxStyleRepository; cxStyle1: TcxStyle; v1BGName: TcxGridDBColumn; v1BGNote: TcxGridDBColumn; v1SQStatus: TcxGridDBColumn; ADOQuery1: TADOQuery; v1Ssel: TcxGridDBColumn; v1SQType: TcxGridDBColumn; Label1: TLabel; BGName: TEdit; Label4: TLabel; SQType: TEdit; procedure FormDestroy(Sender: TObject); procedure FormClose(Sender: TObject; var Action: TCloseAction); procedure FormCreate(Sender: TObject); procedure TBCloseClick(Sender: TObject); procedure TBFindClick(Sender: TObject); procedure TBExportClick(Sender: TObject); procedure TBRafreshClick(Sender: TObject); procedure FormShow(Sender: TObject); procedure CheckBox1Click(Sender: TObject); procedure CheckBox2Click(Sender: TObject); procedure TBViewClick(Sender: TObject); procedure CustomerNoNameChange(Sender: TObject); procedure TBLiZhiClick(Sender: TObject); procedure TCXTJClick(Sender: TObject); procedure cxTabControl1Change(Sender: TObject); procedure Tv1CellDblClick(Sender: TcxCustomGridTableView; ACellViewInfo: TcxGridTableDataCellViewInfo; AButton: TMouseButton; AShift: TShiftState; var AHandled: Boolean); procedure TCXSQClick(Sender: TObject); procedure TTiJiaoClick(Sender: TObject); procedure TDelClick(Sender: TObject); procedure N2Click(Sender: TObject); procedure N1Click(Sender: TObject); procedure BGNameChange(Sender: TObject); private canshu1:string; DQdate:TDateTime; procedure InitGrid(); procedure InitForm(); function DelData():Boolean; procedure setstatus(); { Private declarations } public FFInt,FCloth:Integer; { Public declarations } end; var frmYGYPZZChkList_BGYPSQ: TfrmYGYPZZChkList_BGYPSQ; implementation uses U_DataLink,U_RTFun,U_ZDYHelp, U_YGYPInPut, U_ZDYHelpSel,U_YGYPInput_BGYPDJ; {$R *.dfm} procedure TfrmYGYPZZChkList_BGYPSQ.setstatus(); begin TBLiZhi.Visible:=False; TCXSQ.Visible:=False; TTiJiao.Visible:=False; TCXTJ.Visible:=False; Tdel.Visible:=False; case cxTabControl1.TabIndex of 0:begin TBLiZhi.Visible:=True; TCXSQ.Visible:=True; TTiJiao.Visible:=True; Tdel.Visible:=true; end; 1:begin TCXTJ.Visible:=true; end; 2:begin end; end; end; procedure TfrmYGYPZZChkList_BGYPSQ.FormDestroy(Sender: TObject); begin frmYGYPZZChkList_BGYPSQ:=nil; end; procedure TfrmYGYPZZChkList_BGYPSQ.FormClose(Sender: TObject; var Action: TCloseAction); begin Action:=caFree; end; procedure TfrmYGYPZZChkList_BGYPSQ.FormCreate(Sender: TObject); begin canshu1:=Trim(DParameters1); end; procedure TfrmYGYPZZChkList_BGYPSQ.TBCloseClick(Sender: TObject); begin Close; WriteCxGrid('员工办公列表',Tv1,'OA管理'); end; procedure TfrmYGYPZZChkList_BGYPSQ.InitGrid(); begin try ADOQueryMain.DisableControls; with ADOQueryMain do begin Filtered:=False; Close; sql.Clear; sql.Add('select A.*,B.*,C.* '); sql.Add(' from OA_YG_DangAN_BGYP A '); sql.add(' inner join OA_YG_DangAN_BGYP_Sub B on B.BGMainid=A.BGMainid '); sql.add(' inner join OA_YG_DangAN C on C.YGID=A.YGID '); sql.add(' where 1=1 '); if cxTabControl1.TabIndex<>0 then begin sql.Add(' and A.SQDate>='''+Trim(FormatDateTime('yyyy-MM-dd',BegDate.Date))+''''); sql.Add(' and A.SQDate<='''+Trim(FormatDateTime('yyyy-MM-dd',EndDate.Date+1))+''''); end; if cxTabControl1.TabIndex=0 then begin sql.Add(' and B.SQStatus=''未提交'''); end else if cxTabControl1.TabIndex=1 then begin sql.add(' and (isnull(B.SQStatus,'''')=''已提交'' or isnull(B.SQStatus,'''')=''领用通过'')'); end; if trim(canshu1)<>'高权限' then begin sql.add(' and isnull(C.YGEName,C.YGName)='''+trim(DName)+''' '); end; Open; end; SCreateCDS20(ADOQueryMain,Order_Main); SInitCDSData20(ADOQueryMain,Order_Main); finally ADOQueryMain.EnableControls; end; end; procedure TfrmYGYPZZChkList_BGYPSQ.InitForm(); begin EndDate.Date:=SGetServerDate(ADOQueryTemp); BegDate.Date:=EndDate.Date-7; ReadCxGrid('员工办公列表',Tv1,'OA管理'); setstatus(); InitGrid(); end; procedure TfrmYGYPZZChkList_BGYPSQ.TBFindClick(Sender: TObject); begin if ADOQueryMain.Active=False then Exit; SDofilter(ADOQueryMain,SGetFilters(Panel1,1,2)); SCreateCDS20(ADOQueryMain,Order_Main); SInitCDSData20(ADOQueryMain,Order_Main); end; function TfrmYGYPZZChkList_BGYPSQ.DelData():Boolean; begin try Result:=false; ADOQueryCmd.Connection.BeginTrans; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Delete OA_YG_DangAn where YGId='''+Trim(Order_Main.fieldbyname('YGId').AsString)+''''); ExecSQL; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Delete OA_YG_DangAn_Other where YGId='''+Trim(Order_Main.fieldbyname('YGId').AsString)+''''); ExecSQL; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Delete TP_File where WBId='''+Trim(Order_Main.fieldbyname('YGId').AsString)+''''); sql.Add(' and TFType=''YG'' '); ExecSQL; end; ADOQueryCmd.Connection.CommitTrans; Result:=True; except ADOQueryCmd.Connection.RollbackTrans; Result:=False; Application.MessageBox('数据删除异常!','提示',0); end; end; procedure TfrmYGYPZZChkList_BGYPSQ.TBExportClick(Sender: TObject); begin if ADOQueryMain.IsEmpty then Exit; TcxGridToExcel('员工加薪列表',cxGrid1); end; procedure TfrmYGYPZZChkList_BGYPSQ.TBRafreshClick(Sender: TObject); begin Toolbar1.SetFocus; InitGrid(); end; procedure TfrmYGYPZZChkList_BGYPSQ.FormShow(Sender: TObject); begin InitForm(); end; procedure TfrmYGYPZZChkList_BGYPSQ.CheckBox1Click(Sender: TObject); begin InitGrid(); end; procedure TfrmYGYPZZChkList_BGYPSQ.CheckBox2Click(Sender: TObject); begin TBRafresh.Click; end; procedure TfrmYGYPZZChkList_BGYPSQ.TBViewClick(Sender: TObject); begin if Order_Main.IsEmpty then Exit; frmYGYPInPut_BGYPDJ:=TfrmYGYPInPut_BGYPDJ.create(self); with frmYGYPInPut_BGYPDJ do begin TBSave.Visible:=False; FBGMainID:=trim(Order_Main.fieldbyname('BGMainID').AsString); if showModal=1 then begin end; free; end; initGrid(); end; procedure TfrmYGYPZZChkList_BGYPSQ.CustomerNoNameChange(Sender: TObject); begin if ADOQueryMain.Active=False then Exit; SDofilter(ADOQueryMain,SGetFilters(Panel1,1,2)); SCreateCDS20(ADOQueryMain,Order_Main); SInitCDSData20(ADOQueryMain,Order_Main); end; procedure TfrmYGYPZZChkList_BGYPSQ.TBLiZhiClick(Sender: TObject); begin frmYGYPInPut_BGYPDJ:=TfrmYGYPInPut_BGYPDJ.create(self); with frmYGYPInPut_BGYPDJ do begin FBGMainID:=''; if showModal=1 then begin end; free; end; initGrid(); end; procedure TfrmYGYPZZChkList_BGYPSQ.TCXTJClick(Sender: TObject); begin if Order_Main.IsEmpty then Exit; if Order_Main.Locate('Ssel',True,[])=False then begin application.MessageBox('没有选择数据','提示'); exit; end; if Application.MessageBox('确定要执行撤销操作吗?','提示',32+4)<>IDYES then Exit; with Order_Main do begin first; while not eof do begin if fieldbyname('Ssel').AsBoolean=True then begin if order_Main.FieldByName('SQType').AsString='领用申请' then begin {if Order_Main.FieldByName('SQStatus').AsString<>'已提交' then begin Application.MessageBox('存在已送审单据不能撤销','提示'); exit; end;} end else begin with ADOQueryCmd do begin Close; SQL.Clear; sql.Add('delete from OA_Chk '); sql.Add(' where Mainid='''+Order_Main.fieldbyname('BGSubID').AsString+''''); sql.Add(' and isnull(OAType,'''')=''办公申请'' '); ExecSQL; end; end; with ADOQueryCmd do begin Close; SQL.Clear; sql.Add('Update OA_YG_DangAN_BGYP_Sub Set SQStatus=''未提交'' '); sql.Add(' where BGSubID='''+trim(Order_Main.fieldbyname('BGSubID').AsString)+''''); ExecSQL; end; end; next; end; end; initGrid(); end; procedure TfrmYGYPZZChkList_BGYPSQ.cxTabControl1Change(Sender: TObject); begin setstatus(); InitGrid(); end; procedure TfrmYGYPZZChkList_BGYPSQ.Tv1CellDblClick(Sender: TcxCustomGridTableView; ACellViewInfo: TcxGridTableDataCellViewInfo; AButton: TMouseButton; AShift: TShiftState; var AHandled: Boolean); begin TBView.Click; end; procedure TfrmYGYPZZChkList_BGYPSQ.TCXSQClick(Sender: TObject); begin if Order_Main.IsEmpty then exit; frmYGYPInPut_BGYPDJ:=TfrmYGYPInPut_BGYPDJ.create(self); with frmYGYPInPut_BGYPDJ do begin FBGMainID:=trim(Order_Main.fieldbyname('BGMainID').AsString); if showModal=1 then begin end; free; end; initGrid(); end; procedure TfrmYGYPZZChkList_BGYPSQ.TTiJiaoClick(Sender: TObject); var maxno: string; begin if Order_Main.IsEmpty then exit; if Order_Main.Locate('Ssel',True,[])=False then begin application.MessageBox('没有选择数据','提示'); exit; end; with Order_Main do begin first; while not eof do begin if fieldbyname('Ssel').AsBoolean=true then begin if fieldbyname('BGUnit').AsString='' then begin application.MessageBox('单位不能为空','提示'); exit; end; end; next; end; end; if order_Main.FieldByName('SQType').AsString='领用申请' then begin frmZDYHelpSel:=TfrmZDYHelpSel.Create(Application); with frmZDYHelpSel do begin flag:='LYSQ'; flagname:='审批人'; MainType:=Trim(DName); if ShowModal=1 then begin with ClientDataSet1 do begin first; while not Eof do begin if fieldbyname('Ssel').AsBoolean=True then begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from SY_User where UserName='''+Trim(ClientDataSet1.fieldbyname('ZdyName').AsString)+''''); Open; end; if ADOQueryTemp.IsEmpty then begin Application.MessageBox('审批人定义错误!','提示',0); Exit; end; with Order_Main do begin first; while not eof do begin if fieldbyname('Ssel').AsBoolean=true then begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from OA_Chk where MainId='''+Trim(Order_Main.fieldbyname('BGSubID').AsString)+''''); sql.Add(' and isnull(OAType,'''')=''办公申请'' '); sql.Add(' and isnull(Chker,'''')='''+Trim(ClientDataSet1.fieldbyname('ZdyName').AsString)+''''); Open; end; if ADOQueryTemp.IsEmpty then begin if GetLSNo(ADOQueryCmd,maxno,'BG','OA_Chk',4,1)=False then begin Application.MessageBox('取最大号失败!','提示',0); Exit; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from OA_Chk where 1=2 '); Open; append; FieldByName('CKID').Value:=Trim(maxno); FieldByName('Mainid').Value:=Trim(Order_Main.fieldbyname('BGSubID').AsString); FieldByName('OAType').value:='办公申请'; FieldByName('Chker').Value:=Trim(ClientDataSet1.fieldbyname('ZdyName').AsString); Post; end; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('update OA_YG_DangAN_BGYP_Sub set SQStatus=''已提交'' '); sql.Add('where BGSubID='''+trim(Order_Main.fieldbyname('BGSubID').asstring)+''' '); ExecSQL; end; end; next; end; end; end; Next; end; end; end; Free; end; end else begin frmZDYHelpSel:=TfrmZDYHelpSel.Create(Application); with frmZDYHelpSel do begin flag:='SPR'; flagname:='审批人'; MainType:=Trim(DName); if ShowModal=1 then begin with ClientDataSet1 do begin first; while not Eof do begin if fieldbyname('Ssel').AsBoolean=True then begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from SY_User where UserName='''+Trim(ClientDataSet1.fieldbyname('ZdyName').AsString)+''''); Open; end; if ADOQueryTemp.IsEmpty then begin Application.MessageBox('审批人定义错误!','提示',0); Exit; end; with Order_Main do begin first; while not eof do begin if fieldbyname('Ssel').AsBoolean=true then begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from OA_Chk where MainId='''+Trim(Order_Main.fieldbyname('BGSubID').AsString)+''''); sql.Add(' and isnull(OAType,'''')=''办公申请'' '); sql.Add(' and isnull(Chker,'''')='''+Trim(ClientDataSet1.fieldbyname('ZdyName').AsString)+''''); Open; end; if ADOQueryTemp.IsEmpty then begin if GetLSNo(ADOQueryCmd,maxno,'BG','OA_Chk',4,1)=False then begin Application.MessageBox('取最大号失败!','提示',0); Exit; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from OA_Chk where 1=2 '); Open; append; FieldByName('CKID').Value:=Trim(maxno); FieldByName('Mainid').Value:=Trim(Order_Main.fieldbyname('BGSubID').AsString); FieldByName('OAType').value:='办公申请'; FieldByName('Chker').Value:=Trim(ClientDataSet1.fieldbyname('ZdyName').AsString); Post; end; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('update OA_YG_DangAN_BGYP_Sub set SQStatus=''已送审'' '); sql.Add('where BGSubID='''+trim(Order_Main.fieldbyname('BGSubID').asstring)+''' '); ExecSQL; end; end; next; end; end; end; Next; end; end; end; Free; end; end; InitGrid(); end; procedure TfrmYGYPZZChkList_BGYPSQ.TDelClick(Sender: TObject); begin if Order_Main.IsEmpty then exit; ToolBar1.SetFocus; if application.MessageBox('确定要删除吗','提示',1)=2 then exit; with ADOQueryMain do begin close; sql.Clear; sql.Add('delete from OA_YG_DangAN_BGYP where BGMainID='''+trim(Order_Main.fieldbyname('BGMainID').AsString)+''''); execsql; end; initGrid(); end; procedure TfrmYGYPZZChkList_BGYPSQ.N2Click(Sender: TObject); begin SelOKNo(Order_Main,True); end; procedure TfrmYGYPZZChkList_BGYPSQ.N1Click(Sender: TObject); begin SelOKNo(Order_Main,False); end; procedure TfrmYGYPZZChkList_BGYPSQ.BGNameChange(Sender: TObject); begin SDofilter(ADOQueryMain,SGetFilters(Panel1,1,2)); SCreateCDS20(ADOQueryMain,Order_Main); SInitCDSData20(ADOQueryMain,Order_Main); end; end.