| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294 | unit DealPayPlanFrm;interfaceuses  sdDB,  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,  Dialogs, StdCtrls, ExtCtrls, ComCtrls, JimPages;type  TDealPayPlanForm = class(TForm)    lblTitle: TLabel;    lblDealPayName: TLabel;    lblTitle2: TLabel;    btnOk: TButton;    btnCancel: TButton;    lblPlanType: TLabel;    rbIsPlanPhase: TRadioButton;    rbIsPlanPrice: TRadioButton;    lblResultPre: TLabel;    lblResult: TLabel;    lblResultPost: TLabel;    gbPhase: TGroupBox;    leDeadlinePhase: TLabeledEdit;    udDeadlinePhase: TUpDown;    gbPrice: TGroupBox;    rbAddGatherTotalPrice: TRadioButton;    rbAddDealTotalPrice: TRadioButton;    rbAddQCTotalPrice: TRadioButton;    lePDFormula: TLabeledEdit;    rbIsPlanNon: TRadioButton;    lblEquar: TLabel;    lblPriceDeadline: TLabel;    procedure btnOkClick(Sender: TObject);    procedure rbIsPlanNonClick(Sender: TObject);    procedure rbAddGatherTotalPriceClick(Sender: TObject);    procedure udDeadlinePhaseClick(Sender: TObject; Button: TUDBtnType);    procedure leDeadlinePhaseKeyPress(Sender: TObject; var Key: Char);    procedure leDeadlinePhaseChange(Sender: TObject);    procedure lePDFormulaExit(Sender: TObject);  private    FDealPayRec: TsdDataRecord;    FProjectData: TObject;    FPlanType: Integer;    FPlanSubType: Integer;    //FFormulaSet: t    procedure InitForm;    procedure AssignResult;    procedure SetPlanType(const Value: Integer);    procedure SetPlanSubType(const Value: Integer);    function GetPhaseDeadline: Integer;    procedure SetPhaseDeadline(const Value: Integer);    function GetPriceDeadline: Double;    procedure SetPriceDeadline(const Value: Double);    function GetPDFormula: string;    procedure SetPDFormula(const Value: string);    function GetLimitPrice: Double;    function GetPlanSubTypeName: string;  public    constructor Create(ADealPayRec: TsdDataRecord; AProjectData: TObject);    destructor Destroy; override;    procedure SavePlanInfos;    property PlanType: Integer read FPlanType write SetPlanType;    property PlanSubType: Integer read FPlanSubType write SetPlanSubType;    property PlanSubTypeName: string read GetPlanSubTypeName;    property PhaseDeadline: Integer read GetPhaseDeadline write SetPhaseDeadline;    property PriceDeadline: Double read GetPriceDeadline write SetPriceDeadline;    property PDFormula: string read GetPDFormula write SetPDFormula;    property LimitPrice: Double read GetLimitPrice;  end;implementationuses  UtilMethods, ProjectData, BillsDm, DealPaymentDm, ZhAPI;{$R *.dfm}{ TDealPayPlanForm }constructor TDealPayPlanForm.Create(ADealPayRec: TsdDataRecord; AProjectData: TObject);begin  inherited Create(nil);  FDealPayRec := ADealPayRec;  FProjectData := AProjectData;  InitForm;end;destructor TDealPayPlanForm.Destroy;begin  inherited;end;procedure TDealPayPlanForm.InitForm;begin  lblDealPayName.Caption := FDealPayRec.ValueByName('Name').AsString;  lblTitle2.Left := lblDealPayName.Left + lblDealPayName.Width + 6;  PlanType := FDealPayRec.ValueByName('PlanType').AsInteger;  if PlanType = 1 then    PhaseDeadline := FDealPayRec.ValueByName('PlanDeadline').AsInteger  else if PlanType = 2 then  begin    PlanSubType := FDealPayRec.ValueByName('PlanSubType').AsInteger;    PriceDeadline := FDealPayRec.ValueByName('PlanDeadline').AsFloat;    PDFormula := FDealPayRec.ValueByName('PDFormula').AsString;  end;end;procedure TDealPayPlanForm.SavePlanInfos;begin  FDealPayRec.ValueByName('PlanType').AsInteger := PlanType;  if PlanType = 0 then  begin    FDealPayRec.ValueByName('PlanSubType').AsInteger := 0;    FDealPayRec.ValueByName('PlanDeadline').AsFloat := 0;    FDealPayRec.ValueByName('PDFormula').AsString := '';  end  else if PlanType = 1 then  begin    FDealPayRec.ValueByName('PlanSubType').AsInteger := 0;    FDealPayRec.ValueByName('PlanDeadline').AsInteger := PhaseDeadline;    FDealPayRec.ValueByName('PDFormula').AsString := '';  end  else  begin    FDealPayRec.ValueByName('PlanSubType').AsInteger := PlanSubType;    FDealPayRec.ValueByName('PlanDeadline').AsFloat := PriceDeadline;    FDealPayRec.ValueByName('PDFormula').AsString := PDFormula;  end;end;procedure TDealPayPlanForm.SetPriceDeadline(const Value: Double);begin  lblPriceDeadline.Caption := FloatToStr(Value);end;procedure TDealPayPlanForm.SetPlanSubType(const Value: Integer);begin  FPlanSubType := Value;  rbAddGatherTotalPrice.Checked := FPlanSubType = 0;  rbAddDealTotalPrice.Checked := FPlanSubType = 1;  rbAddQCTotalPrice.Checked := FPlanSubType = 2;  AssignResult;end;procedure TDealPayPlanForm.SetPlanType(const Value: Integer);begin  FPlanType := Value;  rbIsPlanNon.Checked := FPlanType = 0;  rbIsPlanPhase.Checked := FPlanType = 1;  rbIsPlanPrice.Checked := FPlanType = 2;  gbPhase.Enabled := rbIsPlanPhase.Checked;  if gbPhase.Enabled then    gbPhase.Font.Color := clBlack  else    gbPhase.Font.Color := clGray;  gbPrice.Enabled := rbIsPlanPrice.Checked;  if gbPrice.Enabled then    gbPrice.Font.Color := clBlack  else    gbPrice.Font.Color := clGray;  AssignResult;end;procedure TDealPayPlanForm.SetPhaseDeadline(const Value: Integer);begin  udDeadlinePhase.Position := Value;end;procedure TDealPayPlanForm.btnOkClick(Sender: TObject);begin  if (PlanType = 2) and (PriceDeadline < LimitPrice) then    ErrorMessage(Format('当前“%s”已计量至%f,限制金额应大于该值!', [PlanSubTypeName, LimitPrice]))  else    ModalResult := mrOk;end;function TDealPayPlanForm.GetPhaseDeadline: Integer;begin  Result := udDeadlinePhase.Position;end;function TDealPayPlanForm.GetPriceDeadline: Double;begin  Result := StrToFloat(lblPriceDeadline.Caption);end;function TDealPayPlanForm.GetPDFormula: string;begin  Result := lePDFormula.Text;end;procedure TDealPayPlanForm.SetPDFormula(const Value: string);begin  lePDFormula.Text := Value;end;function TDealPayPlanForm.GetLimitPrice: Double;begin  with TProjectData(FProjectData).BillsData do  begin    case PlanSubType of      0: Result := Settlement[4];      1: Result := Settlement[1];      2: Result := Settlement[2] + Settlement[3];    end;  end;end;procedure TDealPayPlanForm.rbIsPlanNonClick(Sender: TObject);begin  if PlanType <> TRadioButton(Sender).Tag then    PlanType := TRadioButton(Sender).Tag;end;procedure TDealPayPlanForm.rbAddGatherTotalPriceClick(Sender: TObject);begin  if PlanSubType <> TRadioButton(Sender).Tag then    PlanSubType := TRadioButton(Sender).Tag;end;procedure TDealPayPlanForm.AssignResult;  procedure CalcPriceDeadline;  begin    if CheckStringNull(PDFormula) then      PriceDeadline := 0    else if CheckNumeric(PDFormula) then      PriceDeadline := StrToFloatDef(PDFormula, 0)    else if Pos('bqwc', PDFormula) > 0 then    begin      ErrorMessage('不可使用“本期完成计量”计算基数!');      PriceDeadline := 0;    end    else      PriceDeadline := TProjectData(FProjectData).DealPaymentData.PayFormula.Calculate(PDFormula);  end;  function GetResult: String;  begin    case PlanType of      0: Result := '无';      1: Result := Format('当 计量期数 > %d 时,', [PhaseDeadline]);      2: Result := Format('当 %s > %f 时', [PlanSubTypeName, PriceDeadline]);    end;  end;begin  if PlanType = 2 then    CalcPriceDeadline;  lblResult.Caption := GetResult;  lblResultPost.Visible := PlanType <> 0;end;function TDealPayPlanForm.GetPlanSubTypeName: string;begin  case PlanSubType of    0: Result := '累计完成计量金额';    1: Result := '累计合同计量金额';    2: Result := '累计变更计量金额';  end;end;procedure TDealPayPlanForm.udDeadlinePhaseClick(Sender: TObject;  Button: TUDBtnType);begin  AssignResult;end;procedure TDealPayPlanForm.leDeadlinePhaseKeyPress(Sender: TObject;  var Key: Char);begin  if Key = #13 then    btnOk.SetFocus;end;procedure TDealPayPlanForm.leDeadlinePhaseChange(Sender: TObject);begin  AssignResult;end;procedure TDealPayPlanForm.lePDFormulaExit(Sender: TObject);begin  AssignResult;end;end.
 |