File: frasqldbrestparamedit.pp

package info (click to toggle)
lazarus 4.0%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 275,760 kB
  • sloc: pascal: 2,341,904; xml: 509,420; makefile: 348,726; cpp: 93,608; sh: 3,387; java: 609; perl: 297; sql: 222; ansic: 137
file content (116 lines) | stat: -rw-r--r-- 2,444 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
unit frasqldbrestparamedit;

{$mode objfpc}{$H+}

interface

uses
  Classes, SysUtils, Forms, Controls, StdCtrls, Spin, ExtCtrls, db,  sqldbschemaedittools, sqldbrestschema;

type

  { TSQLDBRestParameterEditFrame }

  TSQLDBRestParameterEditFrame = class(TBaseEditFrame)
    CBDataType: TComboBox;
    LDefaultValue: TLabel;
    lDatatype: TLabel;
    edtDefaultValue: TEdit;
    EName: TEdit;
    LName: TLabel;
  private
    FParam: TSQLDBRestParam;
    procedure SetParam(AValue: TSQLDBRestParam);
  Protected
    Procedure SetFrameData(aData: TObject); override;
  public
    Constructor Create(aOwner : TComponent); override;
    Function Modified : Boolean; override;
    Procedure SaveData; override;
    Procedure ShowParam;
    Function FrameCaption : String; override;
    Property Param : TSQLDBRestParam Read FParam Write SetParam;
  end;


implementation

uses typinfo;

{$R *.lfm}

{ TSQLDBRestParameterEditFrame }


procedure TSQLDBRestParameterEditFrame.SetParam(AValue: TSQLDBRestParam);
begin
  if FParam=AValue then Exit;
  FParam:=AValue;
  ShowParam;
end;

procedure TSQLDBRestParameterEditFrame.SetFrameData(aData: TObject);
begin
  Param:=aData as TSQLDBRestParam;
end;

constructor TSQLDBRestParameterEditFrame.Create(aOwner: TComponent);

Var
  FT : TFieldType;

begin
  inherited Create(aOwner);
  CBDataType.Items.Clear;
  For FT in TFieldType do
    if FT<>ftUnknown then
      CBDataType.Items.Add(GetEnumName(TypeInfo(TFieldType),Ord(FT)))
end;

function TSQLDBRestParameterEditFrame.Modified: Boolean;

begin
  With FParam do
    begin
    Result:=(Name<>EName.Text) or
            (DefaultValue<>edtDefaultValue.Text) or
            (Ord(DataType)<>(CBDataType.ItemIndex+1));
    end;
end;

procedure TSQLDBRestParameterEditFrame.SaveData;


begin
  With FParam do
    begin
    Name:= EName.Text;
    DefaultValue := edtDefaultValue.Text;
    DataType := TFieldType(CBDataType.ItemIndex+1);
    end;
end;

procedure TSQLDBRestParameterEditFrame.ShowParam;

begin
  With FParam do
    begin
    EName.Text:=Name;
    edtDefaultValue.Text:=DefaultValue;
    CBDataType.ItemIndex:=Ord(DataType)-1;
    end;
end;

function TSQLDBRestParameterEditFrame.FrameCaption: String;
begin
  if FParam=Nil then
    Result:=SUnknownObject
  else
    Result:=FParam.Name;
  Result:=Format(SEditObject,[SParameter,Result]);
  If Assigned(Resource) then
    Result:=SResource+' '+Resource.ResourceName+' - '+Result;
end;

end.