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

📄 edorders.pas

📁 Delphi利用MVC开发的典型例子
💻 PAS
字号:
unit EDOrders;

{ See the comments in MAIN.PAS for information about this project }

interface

uses
  SysUtils, Windows, Messages, Classes, Graphics, Controls,
  Dialogs, Forms, StdCtrls, DBGrids, DBCtrls, DBTables, DB,
  Buttons, Grids, DBLookup, ExtCtrls, Mask, patterns;

type
  TEdOrderForm = class(TForm)
    HeaderPanel: TPanel;
    ShipToAdd1Edit: TDBEdit;
    ShipToAdd2Edit: TDBEdit;
    CustAdd1Edit: TDBEdit;
    CustAdd2Edit: TDBEdit;
    ShipToCompanyEdit: TDBEdit;
    CustCityEdit: TDBEdit;
    CustStateEdit: TDBEdit;
    CustZipEdit: TDBEdit;
    ShipToCityEdit: TDBEdit;
    ShipToStateEdit: TDBEdit;
    ShipToZipEdit: TDBEdit;
    ModeIndicator: TLabel;
    POEdit: TDBEdit;
    TermsCombo: TDBComboBox;
    PaymentCombo: TDBComboBox;
    ShipViaCombo: TDBComboBox;
    Speedbar: TPanel;
    DBNavBtns: TDBNavigator;
    SaleDateEdit: TDBEdit;
    DBEditBtns: TDBNavigator;
    ActiveSource: TDataSource;
    ItemsGrid: TDBGrid;
    AmountPaidEdit: TDBEdit;
    TotalEdit: TDBEdit;
    TaxTotalEdit: TDBEdit;
    FreightEdit: TDBEdit;
    AmountDueEdit: TDBEdit;
    TaxRateEdit: TDBEdit;
    CloseBtn: TButton;
    CancelBtn: TButton;
    PostBtn: TButton;
    PopupCalBtn: TSpeedButton;
    Image1: TImage;
    PrintBtn: TSpeedButton;
    SoldByCombo: TDBLookupComboBox;
    Bevel1: TBevel;
    CompanyCombo: TDBLookupComboBox;
    DBText1: TDBText;
    CustNoEdit: TDBEdit;
    procedure ItemsGridEnter(Sender: TObject);
    procedure ActiveSourceStateChange(Sender: TObject);
    procedure ItemsGridExit(Sender: TObject);
    procedure CancelBtnClick(Sender: TObject);
    procedure PostBtnClick(Sender: TObject);
    procedure PickPartNo(Sender: TObject);
    procedure PickDate(Sender: TObject);
    procedure PrintBtnClick(Sender: TObject);
    procedure SaleDateEditKeyPress(Sender: TObject; var Key: Char);
    procedure OrdersSourceStateChange(Sender: TObject);
    procedure FormCloseQuery(Sender: TObject; var CanClose: Boolean);
    procedure SoldByComboKeyPress(Sender: TObject; var Key: Char);
  private
    procedure Enter;
    procedure Edit(OrderNo: Double);
  end;

  TControllerOrder = class(TController)
  protected
    procedure DoCommand(Command: string; const args: string=''); override;
  public
  end;


var
  EdOrderForm: TEdOrderForm;

implementation

uses DataMod, SrchDlg, Pickdate, commandlist;

{$R *.DFM}

const
  DatasetStates: array[TDataSetState] of string =
  ('Not active', 'Browsing', 'Editing', 'Inserting', '', '', '', '', '', '', '', '', '');
  HelpTopicEdit = 2;
  HelpTopicBrowse = 3;


procedure TControllerOrder.DoCommand(Command: string; const args: string='');
begin
  if command = CMD_BTN_NEWORDER then
    EdOrderForm.Enter
  else if Command = CMD_EDIT_ORDER then
    EdOrderForm.Edit(StrToFloat(args));
end;

{ ======================= Public Methods ======================= }
//this two functions became private now after using emvc

procedure TEdOrderForm.Enter;
begin
  TMastData.getInstance.OrdersSource.OnStateChange := OrdersSourceStateChange;
  try
    TMastData.getInstance.Orders.Open;
    TMastData.getInstance.Orders.Insert;
    ShowModal;
  finally
    TMastData.getInstance.OrdersSource.OnStateChange := nil;
  end;
end;

procedure TEdOrderForm.Edit(OrderNo: Double);
begin
  TMastData.getInstance.OrdersSource.OnStateChange := OrdersSourceStateChange;
  try
    TMastData.getInstance.Orders.Open;
    TMastData.getInstance.Orders.Locate('OrderNo', OrderNo, []);
    ShowModal;
    TMastData.getInstance.OrdByCustSrc.DataSet.refresh;
  finally
    TMastData.getInstance.OrdersSource.OnStateChange := nil;
  end;
end;

{ ======================  Event Handlers  ====================== }

{ These two methods enable the navigators to service both the Orders
  and Items tables by switching the ActiveSource between them. }

procedure TEdOrderForm.ItemsGridEnter(Sender: TObject);
begin
  ActiveSource.Dataset := TMastData.getInstance.Items;
end;

procedure TEdOrderForm.ItemsGridExit(Sender: TObject);
begin
  ActiveSource.Dataset := TMastData.getInstance.Orders;
end;

{ Update the mode indicator when the state of the "Active" datasource
  (Orders or Items) changes }

procedure TEdOrderForm.ActiveSourceStateChange(Sender: TObject);
begin
  with ActiveSource do
  begin
    if Dataset <> nil then ModeIndicator.Caption :=
      Format('[%S: %S]', [Dataset.Name, DatasetStates[State]]);
    if State in [dsEdit, dsInsert] then
    begin
      HelpContext := HelpTopicEdit;
      ModeIndicator.Font.Color := clRed;
    end
    else
    begin
      HelpContext := HelpTopicBrowse;
      ModeIndicator.Font.Color := clBlue;
    end;
  end;
end;

{ Enable or disable buttons as needed when the state of the orders table changes}

procedure TEdOrderForm.OrdersSourceStateChange(Sender: TObject);
begin
  PostBtn.Enabled := TMastData.getInstance.Orders.State in dsEditModes;
  CancelBtn.Enabled := PostBtn.Enabled;
  CloseBtn.Enabled := TMastData.getInstance.Orders.State = dsBrowse;
end;

{ Browse a calendar to pick an invoice date }

procedure TEdOrderForm.PickDate(Sender: TObject);
begin
  with TBrDateForm.getInstance do
  begin
    Date := TMastData.getInstance.OrdersSaleDate.Value; { start with current date }
    if ShowModal = mrOk then
    begin
      TMastData.getInstance.Orders.Edit;
      TMastData.getInstance.OrdersSaleDate.Value := Date;
      SaleDateEdit.SelectAll;
    end;
  end;
end;

{ Ctrl+Enter in the SaleDate edit control brings up PickDate dialog }

procedure TEdOrderForm.SaleDateEditKeyPress(Sender: TObject; var Key: Char);
begin
  if Key = ^J then
  begin
    PickDate(Sender);
    Key := #0;
  end;
end;

{ Clicking on the PartNo button in the grid brings up PickPartNo dialog }

procedure TEdOrderForm.PickPartNo(Sender: TObject);
begin
  if ItemsGrid.SelectedField = TMastData.getInstance.ItemsPartNo then { PartNo column only }
  begin
    if TMastData.getInstance.ItemsPartNo.Value <> 0 then
      TSearchDlg.getInstance.PartNo := TMastData.getInstance.ItemsPartNo.Value; { start with current PartNo }
    if TSearchDlg.getInstance.ShowModalParts = mrOk then
    begin
      TMastData.getInstance.Items.Edit;
      TMastData.getInstance.ItemsPartNo.Value := TSearchDlg.getInstance.PartNo;
    end;
  end;
end;

{ Begins a series of cascading Before and After post events }

procedure TEdOrderForm.PostBtnClick(Sender: TObject);
begin
  TMastData.getInstance.Orders.Post;
end;

{ Cancels insert or edit on the Orders table }

procedure TEdOrderForm.CancelBtnClick(Sender: TObject);
begin
  TMastData.getInstance.OrdersAfterCancel(TMastData.getInstance.Orders);
end;

{ Prints snapshot of the form. An invoice report is available via the Main window }

procedure TEdOrderForm.PrintBtnClick(Sender: TObject);
begin
  if Confirm('Print image of this form window?') then Print;
end;

procedure TEdOrderForm.FormCloseQuery(Sender: TObject;
  var CanClose: Boolean);
begin
  CanClose := TMastData.getInstance.DataSetApplyUpdates(TMastData.getInstance.Orders, ModalResult = mrOK);
end;

procedure TEdOrderForm.SoldByComboKeyPress(Sender: TObject; var Key: Char);
begin
  if not (Key in [#13, #27]) then
    Key := #0;
end;

initialization
  ControlCenter.RegController(TControllerOrder.Create);
  EdOrderForm := TEdOrderForm.create(application);

end.

⌨️ 快捷键说明

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