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.