4e850b76c46c24fd703aa0196bd2a2977a7f04db
[phpeclipse.git] / archive / net.sourceforge.phpeclipse.quantum.sql / src / com / quantum / wizards / PHPInsertRowPage.java
1 package com.quantum.wizards;
2
3 import java.text.MessageFormat;
4
5 import org.eclipse.jface.preference.IPreferenceStore;
6 import org.eclipse.jface.wizard.WizardPage;
7 import org.eclipse.swt.SWT;
8 import org.eclipse.swt.events.ModifyEvent;
9 import org.eclipse.swt.events.ModifyListener;
10 import org.eclipse.swt.layout.GridData;
11 import org.eclipse.swt.layout.GridLayout;
12 import org.eclipse.swt.widgets.Composite;
13 import org.eclipse.swt.widgets.Label;
14 import org.eclipse.swt.widgets.Text;
15
16 import com.quantum.QuantumPlugin;
17 import com.quantum.sql.TableRow;
18 import com.quantum.view.PHPSourceConsole;
19 import com.quantum.view.tableview.TableAdapter;
20
21 public class PHPInsertRowPage extends WizardPage implements SQLPage {
22   TableRow row;
23   String[] columnNames;
24   Text[] values;
25   Label query;
26   private final static boolean DEBUG = false;
27   private IPreferenceStore fStore;
28
29   public PHPInsertRowPage(String pageName) {
30     super(pageName);
31   }
32
33   public void init(TableRow row, TableAdapter adapter) {
34     this.row = row;
35   }
36
37   public void createControl(Composite parent) {
38     if (DEBUG) {
39       System.out.println("page create control");
40     }
41     fStore = QuantumPlugin.getDefault().getPreferenceStore();
42     Composite container = new Composite(parent, SWT.NULL);
43     GridLayout layout = new GridLayout();
44     container.setLayout(layout);
45     int layoutColumns = 2;
46     layout.numColumns = layoutColumns;
47
48     if (DEBUG) {
49       if (row == null) {
50         System.out.println("Row is null");
51       }
52       if (row.getColumnNames() == null) {
53         System.out.println("Columns are null");
54       }
55       if (row.getTableData() == null) {
56         System.out.println("Data is null");
57       }
58     }
59
60     columnNames = row.getColumnNames();
61     String[] data = row.getTableData();
62     if (DEBUG) {
63       for (int i = 0; i < row.getColumnCount(); i++) {
64         System.out.println("data = " + i + "=" + data[i]);
65         System.out.println("column = " + i + "=" + columnNames[i]);
66       }
67     }
68     values = new Text[row.getColumnCount()];
69     Label temp = new Label(container, SWT.NULL);
70     temp.setText("Column Name");
71     temp = new Label(container, SWT.NULL);
72     temp.setText("Value");
73     for (int i = 0; i < row.getColumnCount(); i++) {
74       Label label = new Label(container, SWT.NULL);
75       label.setText(columnNames[i]);
76       values[i] = new Text(container, SWT.BORDER | SWT.SINGLE);
77       GridData fullHorizontal = new GridData();
78       fullHorizontal.horizontalAlignment = GridData.FILL;
79       values[i].setLayoutData(fullHorizontal);
80
81       //values[i].setText(data[i]);
82       values[i].addModifyListener(new ModifyListener() {
83         public void modifyText(ModifyEvent e) {
84           updateQuery();
85         }
86       });
87     }
88     query = new Label(container, SWT.WRAP);
89     GridData gridData = new GridData();
90     gridData.horizontalSpan = layoutColumns;
91     gridData.horizontalAlignment = GridData.FILL;
92     gridData.verticalAlignment = GridData.FILL;
93     gridData.grabExcessHorizontalSpace = true;
94     gridData.grabExcessVerticalSpace = true;
95     query.setLayoutData(gridData);
96
97     setControl(container);
98     updateQuery();
99
100     setPageComplete(true);
101   }
102   public void updateQuery() {
103     if (DEBUG) {
104       System.out.println("Updating insert query");
105     }
106     StringBuffer fieldClause = new StringBuffer();
107
108     StringBuffer valuesClause = new StringBuffer();
109     String text;
110     boolean first = false;
111     for (int i = 0; i < columnNames.length; i++) {
112       text = values[i].getText();
113       if (!text.equals("")) {
114         if (first) {
115           valuesClause.append(", ");
116           fieldClause.append(", ");
117         }
118         valuesClause.append("'" + values[i].getText() + "'");
119         fieldClause.append(columnNames[i]);
120         first = true;
121       }
122     }
123     //    if (valuesClause.length() > 1) {
124     //      valuesClause.deleteCharAt(valuesClause.length() - 1);
125     //      valuesClause.deleteCharAt(valuesClause.length() - 1);
126     //    }
127     String[] arguments = { row.getTable(), fieldClause.toString(), valuesClause.toString()};
128     MessageFormat form = new MessageFormat(fStore.getString("phpeclipse.sql.insert.template"));
129
130     String query = form.format(arguments);
131
132     //    String query = "$results = mysql_query(\"INSERT INTO " + row.getTable() + " (";
133     //    query += fieldClause.toString() + ") ";
134     //    query += " VALUES (" + valuesClause.toString();
135     //    query += ")\");";
136     this.query.setText(query);
137   }
138   public boolean performFinish() {
139     PHPSourceConsole console = PHPSourceConsole.getInstance();
140     console.clear();
141     console.print(query.getText());
142     return true;
143   }
144 }