D7myYunxiang/云翔财务(Money.dll)/U_YWJSChk.pas

319 lines
8.0 KiB
ObjectPascal
Raw Permalink Normal View History

2025-01-20 13:04:03 +08:00
unit U_YWJSChk;
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
TfrmYWJSChk = 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;
cxGrid1: TcxGrid;
Tv1: TcxGridDBTableView;
cxGridDBColumn1: TcxGridDBColumn;
cxGridDBColumn2: TcxGridDBColumn;
cxGridLevel2: TcxGridLevel;
cxGrid2: TcxGrid;
Tv2: TcxGridDBTableView;
v2Column5: TcxGridDBColumn;
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;
v0Column1: TcxGridDBColumn;
v0Column2: TcxGridDBColumn;
v0Column3: TcxGridDBColumn;
Label1: TLabel;
Edit7: TEdit;
v2Column4: TcxGridDBColumn;
Label5: TLabel;
PopupMenu1: TPopupMenu;
N1: TMenuItem;
Label2: TLabel;
ClientDataSet1: TClientDataSet;
DataSource1: TDataSource;
v1Column1: TcxGridDBColumn;
v3Column2: TcxGridDBColumn;
v3Column3: TcxGridDBColumn;
v3Column4: TcxGridDBColumn;
v3Column5: TcxGridDBColumn;
DataSource3: TDataSource;
ClientDataSet3: TClientDataSet;
HelpNote: TRichEdit;
procedure FormDestroy(Sender: TObject);
procedure FormClose(Sender: TObject; var Action: TCloseAction);
procedure TBCloseClick(Sender: TObject);
procedure FormShow(Sender: TObject);
procedure ToolButton4Click(Sender: TObject);
procedure N1Click(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
frmYWJSChk: TfrmYWJSChk;
implementation
uses
U_DataLink,U_ZDYHelp,U_RTFun,U_GSListBankSel,U_KHListSelJJ;
{$R *.dfm}
procedure TfrmYWJSChk.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 TfrmYWJSChk.FormDestroy(Sender: TObject);
begin
frmYWJSChk:=nil;
end;
procedure TfrmYWJSChk.FormClose(Sender: TObject; var Action: TCloseAction);
begin
Action:=caFree;
end;
procedure TfrmYWJSChk.TBCloseClick(Sender: TObject);
begin
Close;
end;
procedure TfrmYWJSChk.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 TfrmYWJSChk.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(<><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʧ<EFBFBD>ܣ<EFBFBD>','<27><>ʾ',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:=<><CEB4><EFBFBD><EFBFBD>';
end else
begin
Edit;
end;
FieldByName('YFID').Value:=Trim(maxId);
FieldByName('Filler').Value:=Trim(DName);
FieldByName('CRType').Value:='<27>ͻ<EFBFBD><CDBB><EFBFBD><EFBFBD>ù<EFBFBD><C3B9><EFBFBD>';
FieldByName('CRFlag').Value:='<27><><EFBFBD>ù<EFBFBD><C3B9><EFBFBD>';
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('<27><><EFBFBD><EFBFBD><EFBFBD>쳣!','<27><>ʾ',0);
end;
end;
procedure TfrmYWJSChk.ToolButton4Click(Sender: TObject);
var
FReal:Double;
begin
ToolBar1.SetFocus;
if Application.MessageBox(<><C8B7>Ҫ<EFBFBD><D2AA><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>','<27><>ʾ',32+4)<>IDYES then Exit;
if SaveData() then
begin
Application.MessageBox('<27><><EFBFBD><EFBFBD><EFBFBD>ɹ<EFBFBD>!','<27><>ʾ',0);
ModalResult:=1;
end;
end;
procedure TfrmYWJSChk.N1Click(Sender: TObject);
var
Freal:Double;
FBegdate,FEndDate:String;
begin
if Trim(HuiLv.Text)='' then
begin
Application.MessageBox('<27><><EFBFBD>ʲ<EFBFBD><CAB2><EFBFBD>Ϊ<EFBFBD><CEAA>!','<27><>ʾ',0);
Exit;
end;
if TryStrToFloat(HuiLv.Text,Freal)=False then
begin
Application.MessageBox('<27><><EFBFBD>ʷǷ<CAB7><C7B7><EFBFBD><EFBFBD><EFBFBD>!','<27><>ʾ',0);
Exit;
end;
with ADOQueryTemp do
begin
Close;
sql.Clear;
sql.Add('select Top 1* from YW_HS_CR where HSPerson='''+Trim(DName)+''' and QtyFlag=1 ');
sql.Add('order by CRDate desc ');
Open;
end;
if ADOQueryTemp.IsEmpty=False then
begin
FBegdate:='2020-01-01';
end else
begin
FBegdate:=Trim(FormatDateTime('yyyy-MM-dd',ADOQueryTemp.fieldbyname('CRDate').AsDateTime+1));
end;
with ADOQueryTemp do
begin
Close;
sql.Clear;
sql.Add('exec P_KH_QK :FBegDate,:DName,:HuiLv');
Parameters.ParamByName('FBegDate').Value:=FBegdate;
Parameters.ParamByName('DName').Value:=Trim(DName);
Parameters.ParamByName('HuiLv').Value:=StrToFloat(HuiLv.Text);
open;
end;
SCreateCDS20(ADOQueryTemp,ClientDataSet1);
SInitCDSData20(ADOQueryTemp,ClientDataSet1);
with ADOQueryTemp do
begin
Close;
sql.Clear;
sql.Add('exec P_KH_ChongHong :FBegDate,:DName,:HuiLv');
Parameters.ParamByName('FBegDate').Value:=FBegdate;
Parameters.ParamByName('DName').Value:=Trim(DName);
Parameters.ParamByName('HuiLv').Value:=StrToFloat(HuiLv.Text);
open;
end;
SCreateCDS20(ADOQueryTemp,ClientDataSet3);
SInitCDSData20(ADOQueryTemp,ClientDataSet3);
end;
procedure TfrmYWJSChk.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.