-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDynamicRegForm.java
More file actions
304 lines (281 loc) · 13.6 KB
/
DynamicRegForm.java
File metadata and controls
304 lines (281 loc) · 13.6 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
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
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
import javax.swing.*;
import javax.swing.table.DefaultTableModel;
import java.awt.event.*;
import java.sql.ResultSet;
@SuppressWarnings("serial")
public class DynamicRegForm extends RegistrationFormGUI{
String gender = "";
ResultSet rst,rstLast;
Object[][] data;
int serialNo;
String SHOW = "Show";
RegistrationFormGUI formGUIObject;
// Defining Constructor
DynamicRegForm(){
nameField.addKeyListener(new KeyAdapter() {
public void keyTyped(KeyEvent e) {
if(nameField.getText().length()>=15)
e.consume();
}
});
male.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
gender = "Male";
}
});
female.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
gender = "Female";
}
});
addressField.addKeyListener(new KeyAdapter() {
public void keyTyped(KeyEvent e) {
if(addressField.getText().length()>50)
e.consume();
}
});
contactField.addKeyListener(new KeyAdapter() {
public void keyTyped(KeyEvent e) {
char c = e.getKeyChar();
if (!((c >= '0') && (c <= '9') ||
(c == KeyEvent.VK_BACK_SPACE) ||
(c == KeyEvent.VK_DELETE))) {
// getToolkit().beep();
e.consume();
}
if(contactField.getText().length()>9)
e.consume();
}
});
exitButton.addActionListener(new ActionListener(){
public void actionPerformed(ActionEvent arg0) {
try{
con.close();
System.exit(0);
}catch(Exception ex){
System.out.println(ex.getMessage());
}
}
});
registerButton.addActionListener(new AbstractAction(SHOW){
public void actionPerformed(ActionEvent ae){
try{
if (ae.getSource() == registerButton) {
if (nameField.getText().equals(""))
JOptionPane.showMessageDialog(idField,
"Please provide Name_Field");
else if(addressField.getText().equals(""))
JOptionPane.showMessageDialog(idField,
"Please provide Address_Field");
else if(contactField.getText().equals(""))
JOptionPane.showMessageDialog(idField, "Please provide Contact_Field");
else if(gender.equals(""))
JOptionPane.showMessageDialog(idField, "Please select Gender");
else {
//Fetching column values from Database
preStatement.setString(1,nameField.getText());
preStatement.setString(2,gender);
preStatement.setString(3,addressField.getText());
preStatement.setString(4,contactField.getText());
//Executing MySQL Update Query
int i = preStatement.executeUpdate();
if(i==1){
JOptionPane.showMessageDialog(panel,
"Successfully Registered");
}
// showing last row
rstLast = stmt.executeQuery("select *from regForm");
rstLast.last();
String string = serialNo++ +",
"+String.valueOf(rstLast.getLong(1))+",
"+rstLast.getString(2)+",
"+rstLast.getString(3)+",
"+rstLast.getString(4)+",
"+rstLast.getString(5);
Object[] row = null;
row = string.split(",");
model.addRow(row);
panel.revalidate();
// fields are blank
blankFields();
}
}
}catch(Exception ex){
System.out.println(ex.getMessage());
}
}
});
updateButton.addActionListener(new AbstractAction(SHOW){
public void actionPerformed(ActionEvent e){
if (nameField.getText().equals(""))
JOptionPane.showMessageDialog(idField,
"Please provide Name_Field");
else if(addressField.getText().equals(""))
JOptionPane.showMessageDialog(idField,
"Please provide Address_Field");
else if(contactField.getText().equals(""))
JOptionPane.showMessageDialog(idField,
"Please provide Contact_Field");
else if(gender.equals(""))
JOptionPane.showMessageDialog(idField,
"Please select Gender");
else {
int r = table.getSelectedRow();
try{
if(r>=0){
if(male.isSelected())
gender = male.getText();
else
gender = female.getText();
String id = (String)table.getModel().
getValueAt(r,1);
updatePreStmt = con.prepareStatement(
"update regForm set name=?,
gender=?,address=?,contact=?
where id="+id);
updatePreStmt.setString(1,nameField.getText());
updatePreStmt.setString(2,gender);
updatePreStmt.setString(3,addressField.getText());
updatePreStmt.setString(4,contactField.getText());
int i = updatePreStmt.executeUpdate();
if(i==1){
table.setValueAt(nameField.getText(),r,2);
table.setValueAt(gender, r, 3);
table.setValueAt(addressField.getText(),r,4);
table.setValueAt(contactField.getText(), r, 5);
}
else JOptionPane.showMessageDialog(panel,
"ID does't Exists in Database");
}
}catch(Exception ex){
System.out.println("Update section: "+
ex.getMessage());
}
}
}
});
//Registering Anonymous Listener Class
deleteButton.addActionListener(new AbstractAction(SHOW){
public void actionPerformed(ActionEvent e){
try{
//Getting Selected Row No
int r = table.getSelectedRow();
if(r>=0){
if (JOptionPane.showConfirmDialog(panel,
"Are you sure want to Delete this 'RECORD' ?","WARNING",
JOptionPane.YES_NO_OPTION) == JOptionPane.YES_OPTION){
String id = (String)table.getModel().getValueAt(r,1);
// Executing MySQL Update Command
int i = stmt.executeUpdate("delete from regForm
where id="+id);
if(i==1){
model.removeRow(r);
// fields are blank
blankFields();
registerButton.setEnabled(true);
deleteButton.setEnabled(false);
updateButton.setEnabled(false);
}
}
}
}catch(Exception ex){
System.out.println(ex.getMessage());
}
}
});
//Registering Anonymous Listener Class
resetButton.addActionListener(new ActionListener(){
public void actionPerformed(ActionEvent arg0) {
// calling method resetFields()
resetFields();
registerButton.setEnabled(true);
updateButton.setEnabled(false);
deleteButton.setEnabled(false);
resetButton.setEnabled(false);
}
});
// Registering Anonymous Listener Class
refresh.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent arg0) {
//calling refresh() method
refreshTable();
}
});
//Registering Anonymous Listener Class
table.addMouseListener(new MouseListener(){
public void mouseClicked(MouseEvent arg0){
//Getting Selected Row No
int r = table.getSelectedRow();
if(r>=0){
deleteButton.setEnabled(true);
updateButton.setEnabled(true);
resetButton.setEnabled(true);
registerButton.setEnabled(false);
//Fetching records from Table on Fields
idField.setText(""+table.getModel().getValueAt(r,1));
nameField.setText(""+table.getModel().getValueAt(r,2));
if(table.getModel().getValueAt(r,3).equals("Male"))
male.setSelected(true);
else
female.setSelected(true);
addressField.setText(""+table.getModel().getValueAt(r,4));
contactField.setText(""+table.getModel().getValueAt(r,5));
}
}
// @Override
public void mouseReleased(MouseEvent arg0) {}
// @Override
public void mousePressed(MouseEvent arg0) {}
// @Override
public void mouseExited(MouseEvent arg0) {}
// @Override
public void mouseEntered(MouseEvent arg0) {}
});
// Displaying rows into the Frame table
addRows();
}
// addRows method
private void addRows(){
try{
Object[] row = null;
//Generating Serial No
serialNo=1;
rst = stmt.executeQuery("select *from regForm");
while(rst.next()){
String string = serialNo++ +","+String.valueOf(rst.getLong(1))+",
"+rst.getString(2)+","+rst.getString(3)+",
"+rst.getString(4)+","+rst.getString(5);
row = string.split(",");
// Adding records in table model
model.addRow(row);
}
panel.revalidate();
}catch(Exception ex){ System.out.println(ex.getMessage()); }
}
private void resetFields(){
//calling method blankfields()
blankFields();
}
// refresh method
private void refreshTable(){
// removing all the rows of the table
DefaultTableModel dm = (DefaultTableModel)table.getModel();
dm.getDataVector().removeAllElements();
System.out.println("Refresh Table");
//calling method addRows
addRows();
}
private void blankFields(){
// fields will be blank
idField.setText("");
nameField.setText("");
gender = "";
bg.clearSelection();
addressField.setText("");
contactField.setText("");
}
// main() method
public static void main(String[] args) {
new DynamicRegForm();
}
}