forked from fenisoft/fenixsql
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathfsselectfields.pas
More file actions
120 lines (99 loc) · 2.94 KB
/
fsselectfields.pas
File metadata and controls
120 lines (99 loc) · 2.94 KB
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
117
118
119
120
unit fsselectfields;
{$mode objfpc}{$H+}
interface
uses
Classes, SysUtils, FileUtil, Forms, Controls, Graphics, Dialogs, ButtonPanel,
CheckLst, StdCtrls, Menus, ActnList;
type
{ TSelectFieldsForm }
TSelectFieldsForm = class(TForm)
MenuItem1: TMenuItem;
MenuItem2: TMenuItem;
SelectAllAction: TAction;
UnSelectAllAction: TAction;
ActionList1: TActionList;
ButtonPanel1: TButtonPanel;
FieldsCheckList: TCheckListBox;
PopupMenu1: TPopupMenu;
procedure FieldsCheckListClickCheck(Sender: TObject);
procedure UnSelectAllActionExecute(Sender: TObject);
procedure FormShow(Sender: TObject);
procedure SelectAllActionExecute(Sender: TObject);
private
{ private declarations }
FTableName: string;
procedure LoadList;
function CheckChecked: boolean;
public
property TableName: string read FTableName write FTableName;
end;
function GetFieldsFromTable(const ATableName: string; AFields: TStringList): boolean;
implementation
{$R *.lfm}
uses fsdm;
function GetFieldsFromTable(const ATableName: string; AFields: TStringList): boolean;
var
SelectFieldsForm: TSelectFieldsForm;
i: integer;
begin
Result := False;
SelectFieldsForm := TSelectFieldsForm.Create(nil);
SelectFieldsForm.TableName := ATableName;
try
if SelectFieldsForm.ShowModal = mrOk then
begin
for i := 0 to SelectFieldsForm.FieldsCheckList.Items.Count - 1 do
if SelectFieldsForm.FieldsCheckList.Checked[i] then
AFields.Add(SelectFieldsForm.FieldsCheckList.Items.Strings[i]);
end;
finally
SelectFieldsForm.Free;
end;
end;
procedure TSelectFieldsForm.FormShow(Sender: TObject);
begin
LoadList;
end;
procedure TSelectFieldsForm.UnSelectAllActionExecute(Sender: TObject);
begin
FieldsCheckList.CheckAll(cbUnchecked);
ButtonPanel1.OKButton.Enabled := False;
end;
procedure TSelectFieldsForm.FieldsCheckListClickCheck(Sender: TObject);
begin
ButtonPanel1.OKButton.Enabled := CheckChecked;
end;
procedure TSelectFieldsForm.SelectAllActionExecute(Sender: TObject);
begin
FieldsCheckList.CheckAll(cbChecked);
ButtonPanel1.OKButton.Enabled := True;
end;
procedure TSelectFieldsForm.LoadList;
var
i: integer;
begin
if not MainDataModule.BrowserTr.InTransaction then
MainDataModule.BrowserTr.StartTransaction;
MainDataModule.BrowserQry.SQL.Text := 'select * from ' + FTableName;
MainDataModule.BrowserQry.Prepare;
for i := 0 to MainDataModule.BrowserQry.FieldCount - 1 do
begin
FieldsCheckList.Items.Add(MainDataModule.BrowserQry.FieldName(i));
FieldsCheckList.Checked[i] := True;
end;
end;
function TSelectFieldsForm.CheckChecked: boolean;
var
i: integer;
begin
Result := False;
for i := 0 to FieldsCheckList.Items.Count - 1 do
begin
if FieldsCheckList.Checked[i] then
begin
Result := True;
Break;
end;
end;
end;
end.