unit U_PayableInput; 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, cxDropDownEdit, BtnEdit, cxLookAndFeels, cxLookAndFeelPainters, cxNavigator, dxSkinsCore, dxSkinsDefaultPainters, dxDateRanges, dxBarBuiltInMenu, U_BaseList, cxContainer, cxCurrencyEdit; type TfrmPayableInput = class(TForm) ToolBar1: TToolBar; TBClose: TToolButton; ADOQueryTemp: TADOQuery; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ToolButton3: TToolButton; ScrollBox1: TScrollBox; Label2: TLabel; Label6: TLabel; Label7: TLabel; F_Code: TEdit; Note: TMemo; Label1: TLabel; F_Name: TEdit; Label8: TLabel; Currency: TComboBox; PayMent: TBtnEditC; OppCoName: TBtnEditC; Label5: TLabel; OurCoName: TBtnEditC; Label9: TLabel; OppParentCoName: TBtnEditC; Amount: TcxCurrencyEdit; Label3: TLabel; Price: TcxCurrencyEdit; Qty: TcxCurrencyEdit; Piece: TcxCurrencyEdit; Label10: TLabel; Label11: TLabel; Label12: TLabel; QtyUnit: TComboBox; Label13: TLabel; Label14: TLabel; F_Width: TEdit; F_GramWeight: TEdit; Label15: TLabel; Label16: TLabel; F_Pattern: TEdit; F_Color: TEdit; Label17: TLabel; F_ColorNo: TEdit; OtherFee: TcxCurrencyEdit; Label4: TLabel; Label20: TLabel; FFTime: TDateTimePicker; Deduction: TcxCurrencyEdit; Label21: TLabel; Label22: TLabel; OrderNo: TBtnEditC; Label23: TLabel; ConNo: TBtnEditC; Label24: TLabel; FFAbstract: TBtnEditC; Label18: TLabel; IsInvoice: TComboBox; procedure FormDestroy(Sender: TObject); procedure FormClose(Sender: TObject; var Action: TCloseAction); procedure TBCloseClick(Sender: TObject); procedure FormShow(Sender: TObject); procedure TBRafreshClick(Sender: TObject); procedure ToolButton3Click(Sender: TObject); procedure PayMentBtnDnClick(Sender: TObject); procedure PayMentBtnUpClick(Sender: TObject); procedure OppCoNameBtnUpClick(Sender: TObject); procedure OppParentCoNameBtnUpClick(Sender: TObject); procedure OurCoNameBtnUpClick(Sender: TObject); procedure QtyExit(Sender: TObject); procedure ScrollBox1Click(Sender: TObject); procedure ConNoBtnUpClick(Sender: TObject); procedure OrderNoBtnUpClick(Sender: TObject); private { Private declarations } procedure InitGrid(); procedure HJJE(); function SaveData(): Boolean; public { Public declarations } FFFID: string; end; var frmPayableInput: TfrmPayableInput; implementation uses U_DataLink, U_RTFun, U_ZDYHelp, U_CompanySel, U_FinTradePlanSel, U_FinTradeSalesContractSel; {$R *.dfm} procedure TfrmPayableInput.HJJE(); var MPrice, MQty, MOtherFee, MDeduction, MAmount: double; begin MPrice := Strtofloatdef(Price.Text, 0); MQty := Strtofloatdef(Qty.Text, 0); MOtherFee := Strtofloatdef(OtherFee.Text, 0); MDeduction := Strtofloatdef(Deduction.Text, 0); MAmount := Strtofloatdef(Amount.Text, 0); if MQty * MPrice >= 0 then begin MAmount := RoundFloat((MQty * MPrice + MOtherFee - MDeduction), 2); end; // Price.Text := FloatToStr(MPrice); // Qty.Text := FloatToStr(MQty); // OtherFee.Text := FloatToStr(MOtherFee); // Deduction.Text := FloatToStr(MDeduction); Amount.Text := FloatToStr(MAmount); end; procedure TfrmPayableInput.InitGrid(); begin try ADOQueryMain.DisableControls; with ADOQueryMain do begin Filtered := False; Close; SQL.Clear; sql.Add(' select * from Finance_Flow where FFID=''' + Trim(FFFID) + ''''); Open; end; if not ADOQueryMain.IsEmpty then begin SCSHData(ADOQueryMain, ScrollBox1, 0); OppCoName.TxtCode := Trim(ADOQueryMain.FieldByName('OppCoNo').AsString); OurCoName.TxtCode := Trim(ADOQueryMain.FieldByName('OurCoNo').AsString); OppParentCoName.TxtCode := Trim(ADOQueryMain.FieldByName('OppParentCoNo').AsString); end else begin FFTime.DateTime := SGetServerDateTime(ADOQueryTemp); end; finally ADOQueryMain.EnableControls; end; end; procedure TfrmPayableInput.OppCoNameBtnUpClick(Sender: TObject); begin try frmCompanySel := TfrmCompanySel.Create(Application); with frmCompanySel do begin FCoType := '��Ӧ��'; if ShowModal = 1 then begin OppCoName.Text := Trim(CDS_1.fieldbyname('CoAbbrName').AsString); OppCoName.TxtCode := Trim(CDS_1.fieldbyname('CoCode').AsString); OppParentCoName.Text := Trim(CDS_1.fieldbyname('CoAbbrName').AsString); OppParentCoName.TxtCode := Trim(CDS_1.fieldbyname('CoCode').AsString); end; end; finally frmCompanySel.Free; end; end; procedure TfrmPayableInput.OppParentCoNameBtnUpClick(Sender: TObject); begin try frmCompanySel := TfrmCompanySel.Create(Application); with frmCompanySel do begin FCoType := '��Ӧ��'; if ShowModal = 1 then begin OppParentCoName.Text := Trim(CDS_1.fieldbyname('CoAbbrName').AsString); OppParentCoName.TxtCode := Trim(CDS_1.fieldbyname('CoCode').AsString); end; end; finally frmCompanySel.Free; end; end; procedure TfrmPayableInput.OrderNoBtnUpClick(Sender: TObject); begin try frmFinTradePlanSel := TfrmFinTradePlanSel.Create(Application); with frmFinTradePlanSel do begin if ShowModal = 1 then begin with frmFinTradePlanSel.CDS_1 do begin self.ConNo.Text := Trim(frmFinTradePlanSel.CDS_1.fieldbyname('ConNo').AsString); self.OrderNo.Text := Trim(frmFinTradePlanSel.CDS_1.fieldbyname('OrderNo').AsString); end; end; end; finally frmFinTradePlanSel.Free; end; end; procedure TfrmPayableInput.OurCoNameBtnUpClick(Sender: TObject); begin try frmCompanySel := TfrmCompanySel.Create(Application); with frmCompanySel do begin FCoType := '��˾'; if ShowModal = 1 then begin OurCoName.Text := Trim(CDS_1.fieldbyname('CoAbbrName').AsString); OurCoName.TxtCode := Trim(CDS_1.fieldbyname('CoCode').AsString); end; end; finally frmCompanySel.Free; end; end; procedure TfrmPayableInput.FormDestroy(Sender: TObject); begin frmPayableInput := nil; end; procedure TfrmPayableInput.PayMentBtnDnClick(Sender: TObject); begin TBtnEditC(Sender).Text := ''; TBtnEditC(Sender).TxtCode := ''; end; procedure TfrmPayableInput.PayMentBtnUpClick(Sender: TObject); var fsj: string; FWZ: Integer; begin fsj := Trim(TEdit(Sender).Hint); FWZ := Pos('/', fsj); try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin MainType := 'Ӧ����'; flag := Copy(fsj, 1, FWZ - 1); flagname := Copy(fsj, FWZ + 1, Length(fsj) - FWZ); if ShowModal = 1 then begin TEdit(Sender).Text := Trim(ClientDataSet1.fieldbyname('ZDYName').AsString); end; end; finally frmZDYHelp.Free; end; end; procedure TfrmPayableInput.QtyExit(Sender: TObject); begin HJJE(); end; procedure TfrmPayableInput.ConNoBtnUpClick(Sender: TObject); begin try frmFinTradeSalesContractSel := TfrmFinTradeSalesContractSel.Create(Application); with frmFinTradeSalesContractSel do begin if ShowModal = 1 then begin self.ConNo.Text := Trim(frmFinTradeSalesContractSel.CDS_1.fieldbyname('ConNo').AsString); end; end; finally frmFinTradeSalesContractSel.Free; end; end; procedure TfrmPayableInput.FormClose(Sender: TObject; var Action: TCloseAction); begin Action := caFree; end; procedure TfrmPayableInput.TBCloseClick(Sender: TObject); begin close; end; procedure TfrmPayableInput.FormShow(Sender: TObject); begin if Trim(FFFID) = '' then begin with ADOQueryTemp do begin Close; SQL.Clear; sql.Add(' select top 1 * from BS_Company where CoType=''��˾'' order by CoCode '); Open; end; OurCoName.Text := Trim(ADOQueryTemp.fieldbyname('CoAbbrName').AsString); OurCoName.TxtCode := Trim(ADOQueryTemp.fieldbyname('CoCode').AsString); end; InitGrid(); end; procedure TfrmPayableInput.TBRafreshClick(Sender: TObject); begin InitGrid(); end; function TfrmPayableInput.SaveData(): Boolean; var MaxId, MaxSubId, FCoCode, FCCID: string; begin try ADOQueryCmd.Connection.BeginTrans; if Trim(FFFID) = '' then begin if not GetLSNo(ADOQueryCmd, MaxId, 'YF', 'Finance_Flow', 4, 1) then raise Exception.Create('ȡ����ʧ�ܣ�'); end else begin MaxId := Trim(FFFID); end; with ADOQueryCmd do begin Close; SQL.Clear; sql.Add('select * from Finance_Flow where FFID=''' + Trim(FFFID) + ''''); Open; end; with ADOQueryCmd do begin if Trim(FFFID) = '' then begin Append; FieldByName('FillId').Value := Trim(DCode); FieldByName('Filler').Value := Trim(DName); FieldByName('FFFlag').Value := 'Ӧ����'; FieldByName('FFType').Value := 'Ӧ����Ǽ�'; FieldByName('status').Value := '0'; FieldByName('FFQtyFlag').Value := 1; end else begin Edit; FieldByName('EditId').Value := Trim(DCode); FieldByName('Editer').Value := Trim(DName); FieldByName('Edittime').Value := SGetServerDateTime(ADOQueryTemp); end; FieldByName('OppCoNo').Value := Trim(OppCoName.TxtCode); FieldByName('OurCoNo').Value := Trim(OurCoName.TxtCode); FieldByName('OppParentCoNo').Value := Trim(OppParentCoName.TxtCode); FieldByName('FFID').Value := Trim(MaxId); RTSetsavedata(ADOQueryCmd, 'Finance_Flow', ScrollBox1, 0); Post; end; ADOQueryCmd.Connection.CommitTrans; FCCID := Trim(MaxSubId); Result := True; except Result := false; ADOQueryCmd.Connection.RollbackTrans; application.MessageBox(PChar(Exception(ExceptObject).Message), '��ʾ��Ϣ', 0); end; end; procedure TfrmPayableInput.ScrollBox1Click(Sender: TObject); begin HJJE(); end; procedure TfrmPayableInput.ToolButton3Click(Sender: TObject); begin ToolBar1.SetFocus; if Trim(OppCoName.Text) = '' then begin Application.MessageBox('�Է���λ����Ϊ��!', '��ʾ', 0); Exit; end; if Trim(OurCoName.Text) = '' then begin Application.MessageBox('�ҷ���λ����Ϊ��!', '��ʾ', 0); Exit; end; if Trim(Currency.Text) = '' then begin Application.MessageBox('���ֲ���Ϊ��!', '��ʾ', 0); Exit; end; if SaveData() then begin Application.MessageBox('����ɹ�!', '��ʾ', 0); ModalResult := 1; end; end; end.