/
UFrmPrincipal.pas
executable file
·195 lines (146 loc) · 4.25 KB
/
UFrmPrincipal.pas
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
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
unit UFrmPrincipal;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, StdCtrls, ComCtrls, PRFWK_Utilidades, PRFWK_Conexao, PRFWK_Modelo,
MD_Membro, DAO_Membro;
type
TFrmPrincipal = class(TForm)
lvItens: TListView;
Label1: TLabel;
edNome: TEdit;
Button1: TButton;
Button2: TButton;
Button3: TButton;
procedure inicializar();
procedure FormCreate(Sender: TObject);
procedure FormClose(Sender: TObject; var Action: TCloseAction);
procedure carregarGrid();
procedure adicionarItem();
procedure alterarItem();
procedure excluirItem();
procedure Button1Click(Sender: TObject);
procedure Button3Click(Sender: TObject);
procedure Button2Click(Sender: TObject);
private
{ Private declarations }
public
gDAO_Membro : TDAO_Membro;
gMembro : TMD_Membro;
end;
var
FrmPrincipal: TFrmPrincipal;
gConexao : TPRFWK_Conexao;
implementation
{$R *.dfm}
procedure TFrmPrincipal.adicionarItem;
begin
gMembro := TMD_Membro.Create;
try
gMembro.nome := edNome.Text;
gConexao.beginTransaction;
gDAO_Membro.inserir(gMembro);
gConexao.commit;
except on E: Exception do
gConexao.rollback;
end;
gMembro.Free;
carregarGrid;
end;
procedure TFrmPrincipal.alterarItem;
begin
if (lvItens.ItemIndex > -1) then
begin
gMembro := TMD_Membro.Create;
gMembro.ID := StrToInt(lvItens.Items[lvItens.ItemIndex].Caption);
gMembro := gDAO_Membro.obter(gMembro) as TMD_Membro;
if (gMembro <> nil) then
begin
gMembro.nome := edNome.Text;
gConexao.beginTransaction;
gDAO_Membro.alterar(gMembro);
gConexao.commit;
gMembro.Free;
end;
carregarGrid();
end;
end;
procedure TFrmPrincipal.Button1Click(Sender: TObject);
begin
adicionarItem();
end;
procedure TFrmPrincipal.Button2Click(Sender: TObject);
begin
excluirItem();
end;
procedure TFrmPrincipal.Button3Click(Sender: TObject);
begin
alterarItem();
end;
procedure TFrmPrincipal.carregarGrid;
var
lMembroAUX : TList;
x : Integer;
lMembro : TMD_Membro;
lListItem : TListItem;
begin
lMembroAUX := gDAO_Membro.obterOrdemNome();
lvItens.Clear();
if lMembroAUX <> nil then
begin
for x := 0 to lMembroAUX.Count - 1 do
begin
lMembro := lMembroAUX[x];
//adiciona produto ao grid de produtos
lListItem := lvItens.Items.Add();
lListItem.Caption := IntToStr(lMembro.ID);
lListItem.SubItems.Text := lMembro.nome;
lMembro.Free;
end;
end;
end;
procedure TFrmPrincipal.excluirItem;
begin
if (lvItens.ItemIndex > -1) then
begin
gMembro := TMD_Membro.Create;
gMembro.ID := StrToInt(lvItens.Items[lvItens.ItemIndex].Caption);
gMembro := gDAO_Membro.obter(gMembro) as TMD_Membro;
if (gMembro <> nil) then
begin
gConexao.beginTransaction;
gDAO_Membro.excluir(gMembro);
gConexao.commit;
gMembro.Free;
end;
carregarGrid();
end;
end;
procedure TFrmPrincipal.FormClose(Sender: TObject; var Action: TCloseAction);
begin
gDAO_Membro.Free;
end;
procedure TFrmPrincipal.FormCreate(Sender: TObject);
begin
inicializar();
gDAO_Membro := TDAO_Membro.Create;
carregarGrid();
end;
procedure TFrmPrincipal.inicializar;
var
lTemp : String;
begin
//título
lTemp := PRFWK_Utilidades.TPRFWK_Utilidades.obterInstancia().obterConfiguracao('APLICACAO', 'titulo', '');
self.Caption := lTemp;
//conexão
//TSqlConnection ou TAdoConnection
gConexao := TPRFWK_Conexao.Create;
gConexao.vendorlib := PRFWK_Utilidades.TPRFWK_Utilidades.obterInstancia().obterConfiguracao('CONEXAO', 'vendorlib', '');
gConexao.libraryName := PRFWK_Utilidades.TPRFWK_Utilidades.obterInstancia().obterConfiguracao('CONEXAO', 'libraryname', '');
gConexao.criarConexao( PRFWK_Utilidades.TPRFWK_Utilidades.obterInstancia().obterConfiguracao('CONEXAO', 'driver', ''),
PRFWK_Utilidades.TPRFWK_Utilidades.obterInstancia().obterConfiguracao('CONEXAO', 'nomeconexao', '')
);
gConexao.conectar;
end;
end.