⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pcedpurchaseprice.pas

📁 详细的ERP设计资料
💻 PAS
字号:
unit PCEdPurchasePrice;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, BaseVoucherEdit, Menus, ActnList, DB, ComCtrls, StdCtrls, Mask,
  DBCtrls, ExtCtrls, ToolWin, Grids, DBGrids, QLDBGrid, ADODB, GEdit,
  QLDBLkp,QLDBFlt;

type
  TPCEdPurchasePriceForm = class(TBaseVoucherEditForm)
    Label1: TLabel;
    Label2: TLabel;
    Label3: TLabel;
    ClientName: TADODataSet;
    GoodName: TADODataSet;
    PackUnit: TADODataSet;
    dsPackUnit: TDataSource;
    DSClientName: TDataSource;
    ClientQLDBLookup: TQLDBLookupComboBox;
    LookupPackUint: TQLDBLookupComboBox;
    TempAds: TADODataSet;
    adsMaster: TADODataSet;
    adsDetail: TADODataSet;
    Label8: TLabel;
    DiscountMode: TAction;
    BriefComboBox: TDBComboBox;
    Label9: TLabel;
    DBEdit1: TDBEdit;
    DBEdit5: TDBEdit;
    adsGoodsSpec: TADODataSet;
    dsGoodsSpec: TDataSource;
    GoalUnit: TADODataSet;
    dsGoalUnit: TDataSource;
    StockQuerry: TAction;
    adsMasterID: TAutoIncField;
    adsMasterCreateDate: TDateTimeField;
    adsMasterCreateUserID: TIntegerField;
    adsMasterRecordState: TStringField;
    adsMasterDate: TDateTimeField;
    adsMasterCode: TStringField;
    adsMasterContractClass: TStringField;
    adsMasterClientID: TIntegerField;
    adsMasterStartDate: TDateTimeField;
    adsMasterExpireDate: TDateTimeField;
    adsMasterMemo: TStringField;
    adsMasterclient: TStringField;
    adsDetailID: TAutoIncField;
    adsDetailMasterID: TIntegerField;
    adsDetailGoodsID: TIntegerField;
    adsDetailSpec: TStringField;
    adsDetailQuantity: TBCDField;
    adsDetailQuantityE: TBCDField;
    adsDetailPackUnitID: TIntegerField;
    adsDetailGoalUnitID: TIntegerField;
    adsDetailPriceClear: TBCDField;
    adsDetailPriceMax: TBCDField;
    adsDetailPriceMin: TBCDField;
    adsDetailpackunit: TStringField;
    adsDetailgoalunit: TStringField;
    adsDetailGoodsName: TStringField;
    PackUintFltAQ: TADODataSet;
    PackUintFltDS: TDataSource;
    adsDetailPriceGoal: TBCDField;
    GoodsIDSelectBtt: TButton;
    adsDetailMemo: TStringField;
    procedure FormClose(Sender: TObject; var Action: TCloseAction);
    procedure FormCreate(Sender: TObject);
    procedure adsDetailGoodsIDChange(Sender: TField);
    procedure LookupPackUintEnter(Sender: TObject);
    procedure FormActivate(Sender: TObject);
    procedure LookupPackUintExit(Sender: TObject);
    procedure GoodsIDSelectBttClick(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
    procedure Open(VoucherID: Integer); override;
    procedure New; override;
  end;

var
  PCEdPurchasePriceForm: TPCEdPurchasePriceForm;

implementation

uses CommonDM, WSUtils, WSSecurity;
{$R *.dfm}
procedure TPCEdPurchasePriceForm.New;
begin
  inherited;
  adsMaster.FieldByName('Date').AsDateTime :=date;
  adsMaster.FieldByName('Code').AsString:=GetMaxCode('Code','PCPurchasePriceMaster ',number);
  adsMaster.FieldByName('CreateUserID').AsInteger :=Guarder.UserID;
end;

procedure TPCEdPurchasePriceForm.Open(VoucherID: Integer);
begin
  inherited Open(VoucherID);
end;


procedure TPCEdPurchasePriceForm.FormClose(Sender: TObject;
  var Action: TCloseAction);
begin
  inherited;
  adsMaster.Close;
  adsDetail.Close;
  ClientName.Close;
  GoodName.Close;
  PackUnit.Close;
  adsGoodsSpec.Close;
end;

procedure TPCEdPurchasePriceForm.FormCreate(Sender: TObject);
begin
  inherited;
  VoucherTableName := 'PCPurchasePrice';
  ClientName.Open;
  GoodName.Open;
  PackUnit.Open;
  TempAds.Close;
  TempAds.CommandText :=' select Distinct ContractClass from PCPurchasePriceMaster ';
  TempAds.Open;
  if TempAds.IsEmpty then BriefComboBox.Items.Add('一般类别')
  else begin
    while not TempAds.Eof do
    begin
      BriefComboBox.Items.Add(TempAds.FieldByName('ContractClass').AsString);
      TempAds.Next;
    end;
  end;
end;

procedure TPCEdPurchasePriceForm.adsDetailGoodsIDChange(Sender: TField);
var SUnitID :integer;
begin
  inherited;
  if (adsDetail.fieldbyname('GoodsID').IsNull) or
     (adsDetail.fieldbyname('GoodsID').AsInteger=0) then exit;
  TempAds.Close;   //取标准单位和基本单价
  TempAds.CommandText :='select UnitID,PricePurchase from DAGoods where Id='
      + QuotedStr(adsDetail.fieldbyname('GoodsID').AsString);
  TempAds.Open;
  if TempAds.FieldByName('UnitID').IsNull then SUnitID :=1
    else SUnitID :=TempAds.FieldByName('UnitID').AsInteger;
  adsDetail.FieldByName('GoalUnitID').AsInteger :=SUnitID;
  adsDetail.FieldByName('PackUnitID').AsInteger :=SUnitID;
  adsDetail.FieldByName('PriceGoal').AsFloat :=TempAds.FieldByName('PricePurchase').AsFloat;
  adsDetail.FieldByName('PriceClear').AsFloat :=TempAds.FieldByName('PricePurchase').AsFloat;
end;

procedure TPCEdPurchasePriceForm.LookupPackUintEnter(Sender: TObject);
var GoodsIDstr :string;
begin
  GoodsIDstr :=adsDetail.fieldbyname('GoodsID').asstring;
  if Trim(GoodsIDstr)='' then  exit;
  LookupPackUint.ListSource := PackUintFltDS;
  PackUintFltAQ.Close;
  PackUintFltAQ.CommandText :=' select ID, Name, ExchangeRate, GoalUnitID,'
      +' IsGoalUnit from MSUnit where RecordState<>'+Quotedstr('删除')
      +' and  GoalUnitID in (select UnitID from DaGoods where ID='
      +GoodsIDstr +' ) order by GoalUnitID,ExchangeRate' ;
  PackUintFltAQ.Open;
end;

procedure TPCEdPurchasePriceForm.FormActivate(Sender: TObject);
begin
  inherited;
  ClientQLDBLookup.SetFocus;
end;

procedure TPCEdPurchasePriceForm.LookupPackUintExit(Sender: TObject);
begin
  LookupPackUint.ListSource := dsPackUnit;
end;

procedure TPCEdPurchasePriceForm.GoodsIDSelectBttClick(Sender: TObject);
var
  FilterDialog: TQLDBFilterDialog;
  GoodsSelectADS :TADODataSet;
begin
  inherited;
  FilterDialog := TQLDBFilterDialog.Create(Self);
  GoodsSelectADS := TADODataSet.Create(nil);
  GoodsSelectADS.Connection := CommonData.acnConnection;

  try
//    GoodsIDSelectBtt.Enabled:=False;
    GoodsSelectADS.Close;
    GoodsSelectADS.CommandText :=
    ' SELECT a.ID, a.Name, b.name GoodsClass,a.UnitID GoalUnitID ' +
    ' FROM DAGoods a '+
    ' LEFT JOIN DAGoodsClass b on b.ID=a.GoodsClassID '+
    ' WHERE a.RecordState<>'+Quotedstr('删除');
    GoodsSelectADS.Open;
    with GoodsSelectADS do
    begin
      Fields[1].DisplayLabel := '商品名称';
      Fields[2].DisplayLabel := '商品类别';
    end;
    FilterDialog.DataSet := GoodsSelectADS;
    FilterDialog.FilterFields := 'Name; GoodsClass';
    if not FilterDialog.Execute then Exit;
    GoodsSelectADS.First;
    adsDetail.last;
    while not GoodsSelectADS.Eof do
    begin
      if adsDetail.Eof then adsDetail.append
        else  adsDetail.Edit;
      adsDetail.FieldByName('GoodsID').AsInteger := GoodsSelectADS.fieldbyname('ID').AsInteger;
      adsDetail.FieldByName('GoalUnitID').AsInteger := GoodsSelectADS.fieldbyname('GoalUnitID').AsInteger;
//      adsDetail.FieldByName('PackUnitID').AsInteger := GoodsSelectADS.fieldbyname('GoalUnitID').AsInteger;
      adsDetail.Post;
      GoodsSelectADS.Next;
      adsDetail.Next;
    end;
//    if not GoodsSelectADS.IsEmpty then  adsDetail.First;
  finally
    FilterDialog.Free;
  end;
end;

end.

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -