unit U_YWJSInPut; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, cxGraphics, cxCustomData, cxStyles, cxTL, cxMaskEdit, DB, ADODB, cxInplaceContainer, cxDBTL, cxControls, cxTLData, ComCtrls, ToolWin, StdCtrls, cxFilter, cxData, cxDataStorage, cxEdit, cxDBData, DBClient, cxGridCustomTableView, cxGridTableView, cxGridDBTableView, ExtCtrls, cxSplitter, cxGridLevel, cxClasses, cxGridCustomView, cxGrid, cxGridCustomPopupMenu, cxGridPopupMenu, RM_Dataset, RM_System, RM_Common, RM_Class, RM_GridReport, IdBaseComponent, IdComponent, IdTCPConnection, IdTCPClient, IdFTP,ShellAPI,IniFiles, cxCheckBox, cxCalendar, cxButtonEdit, cxTextEdit, cxPC, cxDropDownEdit, BtnEdit, Menus; type TfrmYWJSInPut = class(TForm) ToolBar1: TToolBar; TBClose: TToolButton; ADOQueryTemp: TADOQuery; ADOQueryCmd: TADOQuery; Panel1: TPanel; ToolButton4: TToolButton; Label4: TLabel; Note: TEdit; Label3: TLabel; CRTime: TDateTimePicker; ADOQueryMain: TADOQuery; Label6: TLabel; HSPerson: TBtnEditA; Label12: TLabel; HuiLv: TEdit; Label16: TLabel; Edit4: TEdit; Label17: TLabel; Edit5: TEdit; Label18: TLabel; Edit6: TEdit; Panel2: TPanel; cxGrid2: TcxGrid; Tv2: TcxGridDBTableView; v2Column9: TcxGridDBColumn; v2Column10: TcxGridDBColumn; v2Column2: TcxGridDBColumn; v2Column13: TcxGridDBColumn; v2Column3: TcxGridDBColumn; cxGridLevel1: TcxGridLevel; cxGrid3: TcxGrid; Tv3: TcxGridDBTableView; cxGridDBColumn7: TcxGridDBColumn; cxGridDBColumn8: TcxGridDBColumn; cxGridLevel3: TcxGridLevel; Tv3Column1: TcxGridDBColumn; v3Column1: TcxGridDBColumn; Label1: TLabel; Edit7: TEdit; v2Column4: TcxGridDBColumn; Label5: TLabel; Label2: TLabel; v3Column2: TcxGridDBColumn; v3Column3: TcxGridDBColumn; v3Column5: TcxGridDBColumn; DataSource3: TDataSource; ClientDataSet3: TClientDataSet; HelpNote: TRichEdit; v2Column1: TcxGridDBColumn; v2Column6: TcxGridDBColumn; DataSource2: TDataSource; ClientDataSet2: TClientDataSet; procedure FormDestroy(Sender: TObject); procedure FormClose(Sender: TObject; var Action: TCloseAction); procedure TBCloseClick(Sender: TObject); procedure FormShow(Sender: TObject); procedure ToolButton4Click(Sender: TObject); procedure Tv3CellClick(Sender: TcxCustomGridTableView; ACellViewInfo: TcxGridTableDataCellViewInfo; AButton: TMouseButton; AShift: TShiftState; var AHandled: Boolean); private { Private declarations } FKType:string; procedure InitData(); function SaveData():Boolean; public { Public declarations } FMainId,canshu1:String; end; var frmYWJSInPut: TfrmYWJSInPut; implementation uses U_DataLink,U_ZDYHelp,U_RTFun,U_GSListBankSel,U_KHListSelJJ; {$R *.dfm} procedure TfrmYWJSInPut.InitData(); var FFYFName:String; begin with ADOQueryMain do begin Filtered:=False; Close; SQL.Clear; sql.Add(' select A.*,B.BankNo,B.BankName,B.HuMingJC '); sql.Add(' from YS_Money_CR A'); sql.Add(' left join KH_Sub_Bank B on A.BKNO=B.BKNO'); sql.Add(' left join KH_Main C on B.KHMainId=C.KHMainId'); sql.Add(' where YFID='''+Trim(FMainId)+''''); Open; end; FFYFName:=Trim(ADOQueryMain.fieldbyname('FKType').AsString); SCSHDataNew(ADOQueryMain,Panel1,2); SCSHDataNew(ADOQueryMain,Panel1,0); end; procedure TfrmYWJSInPut.FormDestroy(Sender: TObject); begin frmYWJSInPut:=nil; end; procedure TfrmYWJSInPut.FormClose(Sender: TObject; var Action: TCloseAction); begin Action:=caFree; end; procedure TfrmYWJSInPut.TBCloseClick(Sender: TObject); begin Close; end; procedure TfrmYWJSInPut.FormShow(Sender: TObject); begin CRTime.Date:=SGetServerDate(ADOQueryTemp); if Trim(canshu1)='' then begin HSPerson.Enabled:=False; end else begin HSPerson.Enabled:=True; end; HSPerson.Text:=Trim(DName); { if Trim(FMainId)<>'' then begin InitData(); end; } end; function TfrmYWJSInPut.SaveData():Boolean; var maxId:String; begin try ADOQueryCmd.Connection.BeginTrans; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from YS_Money_CR where YFID='''+Trim(FMainId)+''''); Open; end; FMainId:=Trim(ADOQueryCmd.fieldbyname('YFID').AsString); if Trim(FMainId)='' then begin if GetLSNo(ADOQueryCmd,maxId,'YU','YS_Money_CR',4,1)=False then begin Result:=False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('取最大号失败!','提示',0); Exit; end; end else begin maxId:=FMainId; end; with ADOQueryCmd do begin Close; SQL.Clear; sql.Add('select * from YS_Money_CR where YFID='''+Trim(FMainId)+''''); Open; end; with ADOQueryCmd do begin if Trim(FMainId)='' then begin Append; FieldByName('ChkStatusP').Value:='未审核'; end else begin Edit; end; FieldByName('YFID').Value:=Trim(maxId); FieldByName('Filler').Value:=Trim(DName); FieldByName('CRType').Value:='客户费用管理'; FieldByName('CRFlag').Value:='费用管理'; RTSetsavedata(ADOQueryCmd,'YS_Money_CR',Panel1,2); Post; end; FMainId:=Trim(maxId); ADOQueryCmd.Connection.CommitTrans; Result:=True; except Result:=True; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('操作异常!','提示',0); end; end; procedure TfrmYWJSInPut.ToolButton4Click(Sender: TObject); var FReal:Double; begin ToolBar1.SetFocus; if Application.MessageBox('确定要保存数据吗?','提示',32+4)<>IDYES then Exit; if SaveData() then begin Application.MessageBox('保存成功!','提示',0); ModalResult:=1; end; end; procedure TfrmYWJSInPut.Tv3CellClick(Sender: TcxCustomGridTableView; ACellViewInfo: TcxGridTableDataCellViewInfo; AButton: TMouseButton; AShift: TShiftState; var AHandled: Boolean); begin if ClientDataSet3.IsEmpty then begin HelpNote.Text:=''; end else begin HelpNote.Text:=Trim(ClientDataSet3.fieldbyname('Note').AsString); end; end; end.