2
0
Fork 0

[svn r311] updated x4o for null value bug, and made sure exception come more to the front

This commit is contained in:
willemc 2008-01-02 22:39:30 +01:00
parent 6a2813f43d
commit 2cc86c0bfc
13 changed files with 71 additions and 34 deletions

Binary file not shown.

View file

@ -26,6 +26,9 @@
package com.idcanet.vasc.core.column; package com.idcanet.vasc.core.column;
import com.idcanet.x4o.element.ElementParameterException;
import com.idcanet.x4o.element.ElementParameterNotFoundException;
/** /**
* *
* @author Willem Cazander * @author Willem Cazander
@ -33,7 +36,7 @@ package com.idcanet.vasc.core.column;
*/ */
public interface VascColumnValue { public interface VascColumnValue {
public Object getValue(VascTableColumn column,Object record) throws Exception; public Object getValue(VascTableColumn column,Object record) throws ElementParameterException,ElementParameterNotFoundException;
public void setValue(VascTableColumn column,Object record,Object value) throws Exception; public void setValue(VascTableColumn column,Object record,Object value) throws ElementParameterException,ElementParameterNotFoundException;
} }

View file

@ -27,6 +27,8 @@
package com.idcanet.vasc.core.ui; package com.idcanet.vasc.core.ui;
import com.idcanet.vasc.core.column.VascTableColumn; import com.idcanet.vasc.core.column.VascTableColumn;
import com.idcanet.x4o.element.ElementParameterException;
import com.idcanet.x4o.element.ElementParameterNotFoundException;
/** /**
@ -46,7 +48,7 @@ public class VascColumnValueModelListener implements VascValueModelListener {
setBean(bean); setBean(bean);
} }
public void valueUpdate(VascValueModel model) throws Exception { public void valueUpdate(VascValueModel model) throws ElementParameterException,ElementParameterNotFoundException {
vascTableColumn.getVascColumnValue().setValue(vascTableColumn, bean, model.getValue()); vascTableColumn.getVascColumnValue().setValue(vascTableColumn, bean, model.getValue());
} }

View file

@ -30,6 +30,8 @@ import java.util.ArrayList;
import java.util.List; import java.util.List;
import com.idcanet.vasc.core.VascTable; import com.idcanet.vasc.core.VascTable;
import com.idcanet.x4o.element.ElementParameterException;
import com.idcanet.x4o.element.ElementParameterNotFoundException;
/** /**
@ -41,24 +43,20 @@ public class VascValueModel {
private Object value = null; private Object value = null;
private List<VascValueModelListener> listeners = null; private List<VascValueModelListener> listeners = null;
private VascTable table = null; //private VascTable table = null;
public VascValueModel(VascTable table) { public VascValueModel(VascTable table) {
listeners = new ArrayList<VascValueModelListener>(2); listeners = new ArrayList<VascValueModelListener>(2);
this.table=table; //this.table=table;
} }
public Object getValue() { public Object getValue() {
return value; return value;
} }
public void setValue(Object value) { public void setValue(Object value) throws ElementParameterException,ElementParameterNotFoundException {
this.value = value; this.value = value;
try {
fireListeners(); fireListeners();
} catch (Exception e) {
table.getVascTableController().handleException(e, table);
}
} }
public void addListener(VascValueModelListener l) { public void addListener(VascValueModelListener l) {
@ -67,7 +65,7 @@ public class VascValueModel {
public void removeListener(VascValueModelListener l) { public void removeListener(VascValueModelListener l) {
listeners.remove(l); listeners.remove(l);
} }
private void fireListeners() throws Exception { private void fireListeners() throws ElementParameterException,ElementParameterNotFoundException {
for (VascValueModelListener l:listeners) { for (VascValueModelListener l:listeners) {
l.valueUpdate(this); l.valueUpdate(this);
} }

View file

@ -28,6 +28,9 @@ package com.idcanet.vasc.core.ui;
import java.util.EventListener; import java.util.EventListener;
import com.idcanet.x4o.element.ElementParameterException;
import com.idcanet.x4o.element.ElementParameterNotFoundException;
/** /**
* *
@ -36,5 +39,5 @@ import java.util.EventListener;
*/ */
public interface VascValueModelListener extends EventListener { public interface VascValueModelListener extends EventListener {
public void valueUpdate(VascValueModel model) throws Exception; public void valueUpdate(VascValueModel model) throws ElementParameterException,ElementParameterNotFoundException;
} }

View file

@ -28,6 +28,8 @@ package com.idcanet.vasc.impl.column;
import com.idcanet.vasc.core.column.VascColumnValue; import com.idcanet.vasc.core.column.VascColumnValue;
import com.idcanet.vasc.core.column.VascTableColumn; import com.idcanet.vasc.core.column.VascTableColumn;
import com.idcanet.x4o.element.ElementParameterException;
import com.idcanet.x4o.element.ElementParameterNotFoundException;
import com.idcanet.x4o.impl.DefaultElementParameterHelper; import com.idcanet.x4o.impl.DefaultElementParameterHelper;
/** /**
@ -52,7 +54,7 @@ public class BeanPropertyVascColumnValue implements VascColumnValue {
/** /**
* @see com.idcanet.vasc.core.column.VascColumnValue#getValue(com.idcanet.vasc.core.column.VascTableColumn, java.lang.Object) * @see com.idcanet.vasc.core.column.VascColumnValue#getValue(com.idcanet.vasc.core.column.VascTableColumn, java.lang.Object)
*/ */
public Object getValue(VascTableColumn column,Object record) throws Exception { public Object getValue(VascTableColumn column,Object record) throws ElementParameterException,ElementParameterNotFoundException {
if(getProperty()==null) { if(getProperty()==null) {
return null; return null;
} }
@ -65,7 +67,7 @@ public class BeanPropertyVascColumnValue implements VascColumnValue {
/** /**
* @see com.idcanet.vasc.core.column.VascColumnValue#setValue(com.idcanet.vasc.core.column.VascTableColumn, java.lang.Object, java.lang.Object) * @see com.idcanet.vasc.core.column.VascColumnValue#setValue(com.idcanet.vasc.core.column.VascTableColumn, java.lang.Object, java.lang.Object)
*/ */
public void setValue(VascTableColumn column, Object record,Object value) throws Exception { public void setValue(VascTableColumn column, Object record,Object value) throws ElementParameterException,ElementParameterNotFoundException {
if(getProperty()==null) { if(getProperty()==null) {
return; return;
} }

View file

@ -28,6 +28,8 @@ package com.idcanet.vasc.impl.column;
import com.idcanet.vasc.core.column.VascColumnValue; import com.idcanet.vasc.core.column.VascColumnValue;
import com.idcanet.vasc.core.column.VascTableColumn; import com.idcanet.vasc.core.column.VascTableColumn;
import com.idcanet.x4o.element.ElementParameterException;
import com.idcanet.x4o.element.ElementParameterNotFoundException;
/** /**
* *
@ -39,14 +41,14 @@ public class NullVascColumnValue implements VascColumnValue {
/** /**
* @see com.idcanet.vasc.core.column.VascColumnValue#getValue(com.idcanet.vasc.core.column.VascTableColumn, java.lang.Object) * @see com.idcanet.vasc.core.column.VascColumnValue#getValue(com.idcanet.vasc.core.column.VascTableColumn, java.lang.Object)
*/ */
public Object getValue(VascTableColumn column, Object record) throws Exception { public Object getValue(VascTableColumn column, Object record) throws ElementParameterException,ElementParameterNotFoundException {
return null; return null;
} }
/** /**
* @see com.idcanet.vasc.core.column.VascColumnValue#setValue(com.idcanet.vasc.core.column.VascTableColumn, java.lang.Object, java.lang.Object) * @see com.idcanet.vasc.core.column.VascColumnValue#setValue(com.idcanet.vasc.core.column.VascTableColumn, java.lang.Object, java.lang.Object)
*/ */
public void setValue(VascTableColumn column, Object record, Object value) throws Exception { public void setValue(VascTableColumn column, Object record, Object value) throws ElementParameterException,ElementParameterNotFoundException {
} }

View file

@ -494,6 +494,7 @@ public class SwingVascViewRenderer implements VascViewRenderer {
return; return;
} }
try { try {
// TODO: fix this
table.getVascViewRenderer().renderEdit(o); table.getVascViewRenderer().renderEdit(o);
} catch (Exception ee) { } catch (Exception ee) {
table.getVascTableController().handleException(ee, table); table.getVascTableController().handleException(ee, table);

View file

@ -58,7 +58,7 @@ public class SwingColorChooser extends AbstractVascUIComponent {
JButton colorButton = new JButton("Color"); JButton colorButton = new JButton("Color");
orgBackgroundColor = colorButton.getBackground(); orgBackgroundColor = colorButton.getBackground();
((JComponent)gui).add(colorButton); ((JComponent)gui).add(colorButton);
colorButton.addActionListener(new SelectActionListener3(model,org.getHexSwingEncoding())); colorButton.addActionListener(new SelectActionListener3(model,org.getHexSwingEncoding(),table));
return colorButton; return colorButton;
} }
@ -91,9 +91,11 @@ class SelectActionListener3 implements ActionListener {
private VascValueModel model; private VascValueModel model;
private boolean hexEncoding = false; private boolean hexEncoding = false;
public SelectActionListener3(VascValueModel model,boolean hexEncoding) { private VascTable table = null;
public SelectActionListener3(VascValueModel model,boolean hexEncoding,VascTable table) {
this.model=model; this.model=model;
this.hexEncoding=hexEncoding; this.hexEncoding=hexEncoding;
this.table=table;
} }
/** /**
@ -106,7 +108,11 @@ class SelectActionListener3 implements ActionListener {
cur = Color.YELLOW; cur = Color.YELLOW;
} }
Color newColor = JColorChooser.showDialog(null,"Choose a color...",cur); Color newColor = JColorChooser.showDialog(null,"Choose a color...",cur);
try {
model.setValue(newColor); model.setValue(newColor);
} catch (Exception ee) {
table.getVascTableController().handleException(ee, table);
}
} else { } else {
String cur = (String)model.getValue(); String cur = (String)model.getValue();
Color c = Color.YELLOW; Color c = Color.YELLOW;
@ -118,7 +124,7 @@ class SelectActionListener3 implements ActionListener {
String newColorString = "#"+Integer.toHexString( newColor.getRGB() & 0x00ffffff ); String newColorString = "#"+Integer.toHexString( newColor.getRGB() & 0x00ffffff );
model.setValue(newColorString); model.setValue(newColorString);
} catch (Exception ee) { } catch (Exception ee) {
table.getVascTableController().handleException(ee, table);
} }
} }
} }

View file

@ -55,7 +55,7 @@ public class SwingDate extends AbstractVascUIComponent {
orgBackgroundColor = datePicker.getBackground(); orgBackgroundColor = datePicker.getBackground();
datePicker.setDate((Date)model.getValue()); datePicker.setDate((Date)model.getValue());
((JComponent)gui).add(datePicker); ((JComponent)gui).add(datePicker);
datePicker.addActionListener(new SelectActionListener2(model)); datePicker.addActionListener(new SelectActionListener2(model,table));
return datePicker; return datePicker;
} }
@ -87,8 +87,10 @@ public class SwingDate extends AbstractVascUIComponent {
class SelectActionListener2 implements ActionListener { class SelectActionListener2 implements ActionListener {
private VascValueModel model; private VascValueModel model;
public SelectActionListener2(VascValueModel model) { private VascTable table = null;
public SelectActionListener2(VascValueModel model,VascTable table) {
this.model=model; this.model=model;
this.table=table;
} }
/** /**
@ -96,6 +98,10 @@ class SelectActionListener2 implements ActionListener {
*/ */
public void actionPerformed(ActionEvent e) { public void actionPerformed(ActionEvent e) {
Date value = ((DatePicker)e.getSource()).getDate(); Date value = ((DatePicker)e.getSource()).getDate();
try {
model.setValue(value); model.setValue(value);
} catch (Exception ee) {
table.getVascTableController().handleException(ee, table);
}
} }
} }

View file

@ -54,7 +54,7 @@ public class SwingList extends AbstractVascUIComponent {
private JComboBox comboBox = null; private JComboBox comboBox = null;
private Color orgBackgroundColor = null; private Color orgBackgroundColor = null;
public Object createComponent(VascTable table,final VascValueModel model,Object gui) throws Exception { public Object createComponent(final VascTable table,final VascValueModel model,Object gui) throws Exception {
VascList l = (VascList)getWrapper(); VascList l = (VascList)getWrapper();
if (l.getVascSelectItemModel()==null) { if (l.getVascSelectItemModel()==null) {
comboBox = new JComboBox(); comboBox = new JComboBox();
@ -67,7 +67,11 @@ public class SwingList extends AbstractVascUIComponent {
comboBox.addActionListener(new ActionListener() { comboBox.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) { public void actionPerformed(ActionEvent e) {
VascSelectItem i = (VascSelectItem)((JComboBox)e.getSource()).getSelectedItem(); VascSelectItem i = (VascSelectItem)((JComboBox)e.getSource()).getSelectedItem();
try {
model.setValue(i.getValue()); model.setValue(i.getValue());
} catch (Exception ee) {
table.getVascTableController().handleException(ee, table);
}
} }
}); });

View file

@ -53,7 +53,7 @@ public class SwingTextField extends AbstractVascUIComponent {
orgBackgroundColor = textField.getBackground(); orgBackgroundColor = textField.getBackground();
textField.setText(""+model.getValue()); textField.setText(""+model.getValue());
((JComponent)gui).add(textField); ((JComponent)gui).add(textField);
textField.getDocument().addDocumentListener(new TextListener(model,table)); textField.getDocument().addDocumentListener(new TextListener(model,table,this));
return textField; return textField;
} }
@ -86,11 +86,13 @@ public class SwingTextField extends AbstractVascUIComponent {
class TextListener implements DocumentListener { class TextListener implements DocumentListener {
private VascValueModel model = null; private VascValueModel model = null;
private VascTable table = null; //private VascTable table = null;
private SwingTextField textField = null;
public TextListener(VascValueModel model,VascTable table) { public TextListener(VascValueModel model,VascTable table,SwingTextField textField) {
this.model=model; this.model=model;
this.table=table; //this.table=table;
this.textField=textField;
} }
/** /**
@ -118,8 +120,10 @@ class TextListener implements DocumentListener {
try { try {
String value = event.getDocument().getText(0, event.getDocument().getLength()); String value = event.getDocument().getText(0, event.getDocument().getLength());
model.setValue(value); model.setValue(value);
textField.setErrorText(null);
} catch (Exception ee) { } catch (Exception ee) {
table.getVascTableController().handleException(ee, table); textField.setErrorText(ee.getLocalizedMessage());
//table.getVascTableController().handleException(ee, table);
} }
} }
} }

View file

@ -54,7 +54,7 @@ public class SwingToggle extends AbstractVascUIComponent {
orgBackgroundColor = checkBox.getBackground(); orgBackgroundColor = checkBox.getBackground();
checkBox.setSelected((Boolean)model.getValue()); checkBox.setSelected((Boolean)model.getValue());
((JComponent)gui).add(checkBox); ((JComponent)gui).add(checkBox);
checkBox.addActionListener(new SelectActionListener(model)); checkBox.addActionListener(new SelectActionListener(model,table));
return checkBox; return checkBox;
} }
@ -86,8 +86,10 @@ public class SwingToggle extends AbstractVascUIComponent {
class SelectActionListener implements ActionListener { class SelectActionListener implements ActionListener {
private VascValueModel model; private VascValueModel model;
public SelectActionListener(VascValueModel model) { private VascTable table = null;
public SelectActionListener(VascValueModel model,VascTable table) {
this.model=model; this.model=model;
this.table=table;
} }
/** /**
@ -95,6 +97,10 @@ class SelectActionListener implements ActionListener {
*/ */
public void actionPerformed(ActionEvent e) { public void actionPerformed(ActionEvent e) {
boolean value = ((JCheckBox)e.getSource()).isSelected(); boolean value = ((JCheckBox)e.getSource()).isSelected();
try {
model.setValue(value); model.setValue(value);
} catch (Exception ee) {
table.getVascTableController().handleException(ee, table);
}
} }
} }