[svn r235] added made first swt query working..
This commit is contained in:
parent
d62b09bd3b
commit
5e425bd032
Binary file not shown.
|
@ -33,5 +33,5 @@ package com.idcanet.vasc.core.column;
|
||||||
*/
|
*/
|
||||||
public interface VascColumnValue {
|
public interface VascColumnValue {
|
||||||
|
|
||||||
public Object getValue(VascTableColumn column);
|
public Object getValue(VascTableColumn column,Object record);
|
||||||
}
|
}
|
|
@ -28,6 +28,7 @@ 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.impl.DefaultElementParameterHelper;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -45,14 +46,20 @@ public class BeanPropertyVascColumnValue implements VascColumnValue {
|
||||||
setProperty(property);
|
setProperty(property);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Object getValue(VascTableColumn column) {
|
public Object getValue(VascTableColumn column,Object record) {
|
||||||
if(getProperty()==null) {
|
if(getProperty()==null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
if(getProperty().equals("")) {
|
if(getProperty().equals("")) {
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
return getProperty();
|
DefaultElementParameterHelper helper = new DefaultElementParameterHelper();
|
||||||
|
try {
|
||||||
|
return helper.getParameter(record, getProperty());
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
return "Err";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -36,7 +36,7 @@ import com.idcanet.vasc.core.column.VascTableColumn;
|
||||||
*/
|
*/
|
||||||
public class NullVascColumnValue implements VascColumnValue {
|
public class NullVascColumnValue implements VascColumnValue {
|
||||||
|
|
||||||
public Object getValue(VascTableColumn column) {
|
public Object getValue(VascTableColumn column,Object record) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -29,9 +29,11 @@ package com.idcanet.vasc.impl.serv5;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
|
|
||||||
|
import org.hibernate.Query;
|
||||||
|
|
||||||
import com.idcanet.serv5.services.hibernate3.Hibernate3Factory;
|
import com.idcanet.serv5.services.hibernate3.Hibernate3Factory;
|
||||||
import com.idcanet.vasc.core.VascDataSource;
|
import com.idcanet.vasc.core.VascDataSource;
|
||||||
import com.idcanet.xtes.xpql.query.Query;
|
import com.idcanet.xtes.xpql.query.QueryParameterValue;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@ -49,37 +51,20 @@ public class Serv5HibernateVascDataSource implements VascDataSource {
|
||||||
setSession(session);
|
setSession(session);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<Object> executeQuery(Query query) throws Exception {
|
public List<Object> executeQuery(com.idcanet.xtes.xpql.query.Query query) throws Exception {
|
||||||
try {
|
try {
|
||||||
/*
|
Query q = Hibernate3Factory.getSession(getSession()).createQuery(query.toPreparedSQL(query));
|
||||||
Query q = Hibernate3Factory.getSession("flowstats").createQuery(query.toString());
|
|
||||||
q.setMaxResults(crudTable.getQueryLimit());
|
|
||||||
if(crudTable.getViewOnly()) {
|
|
||||||
q.setReadOnly(true);
|
|
||||||
}
|
|
||||||
for(CrudParameterOption para:crudTable.getQueryParameterOptions().values()) {
|
|
||||||
if(para.getValueHolder().getValue()==null) {
|
|
||||||
logger.finer("Value is null of parameter: "+para.getName());
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
Object value = para.getValueHolder().getValue();
|
|
||||||
logger.finer("Setting parameter: "+para.getName()+" with: "+value);
|
|
||||||
if(para.getValueProperty()!=null) {
|
|
||||||
q.setParameter(para.getName(),BeanUtils.getValue(value,BeanUtils.getPropertyDescriptor(value,para.getValueProperty())));
|
|
||||||
} else {
|
|
||||||
q.setParameter(para.getName(),value);
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
logger.log(Level.WARNING,e.getMessage(),e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
List<QueryParameterValue> values = query.getOrderQueryParameterValues();
|
||||||
|
int i = 0;
|
||||||
|
for (QueryParameterValue value:values) {
|
||||||
|
q.setParameter(i,value.getValue());
|
||||||
|
i++;
|
||||||
|
}
|
||||||
List data = q.list();
|
List data = q.list();
|
||||||
logger.info("Query returned: "+data.size()+" of: "+crudTable.getQueryName());
|
//logger.info("Query returned: "+data.size()+" of: "+crudTable.getQueryName());
|
||||||
crudTable.getSelectionInList().setList(data);
|
return data;
|
||||||
*/
|
|
||||||
return null;
|
|
||||||
} finally {
|
} finally {
|
||||||
Hibernate3Factory.getSession("flowstats").close(); // close session in threads
|
Hibernate3Factory.getSession("flowstats").close(); // close session in threads
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,10 +31,15 @@ import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.logging.Logger;
|
import java.util.logging.Logger;
|
||||||
|
|
||||||
|
import org.eclipse.jface.viewers.ILabelProviderListener;
|
||||||
|
import org.eclipse.jface.viewers.IStructuredContentProvider;
|
||||||
|
import org.eclipse.jface.viewers.ITableLabelProvider;
|
||||||
import org.eclipse.jface.viewers.TableViewer;
|
import org.eclipse.jface.viewers.TableViewer;
|
||||||
|
import org.eclipse.jface.viewers.Viewer;
|
||||||
import org.eclipse.swt.SWT;
|
import org.eclipse.swt.SWT;
|
||||||
import org.eclipse.swt.graphics.Color;
|
import org.eclipse.swt.graphics.Color;
|
||||||
import org.eclipse.swt.graphics.Font;
|
import org.eclipse.swt.graphics.Font;
|
||||||
|
import org.eclipse.swt.graphics.Image;
|
||||||
import org.eclipse.swt.layout.GridData;
|
import org.eclipse.swt.layout.GridData;
|
||||||
import org.eclipse.swt.layout.GridLayout;
|
import org.eclipse.swt.layout.GridLayout;
|
||||||
import org.eclipse.swt.widgets.Button;
|
import org.eclipse.swt.widgets.Button;
|
||||||
|
@ -51,10 +56,6 @@ import com.idcanet.vasc.core.VascViewRenderer;
|
||||||
import com.idcanet.vasc.core.actions.RowVascAction;
|
import com.idcanet.vasc.core.actions.RowVascAction;
|
||||||
import com.idcanet.vasc.core.column.VascTableColumn;
|
import com.idcanet.vasc.core.column.VascTableColumn;
|
||||||
|
|
||||||
import fr.jayasoft.binding.jface.adapter.JFaceComponentFactory;
|
|
||||||
import fr.jayasoft.binding.jface.utils.table.AbstractColumn;
|
|
||||||
import fr.jayasoft.binding.jface.utils.table.PropertyColumn;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author Willem Cazander
|
* @author Willem Cazander
|
||||||
|
@ -72,6 +73,14 @@ public class SwtVascViewRenderer implements VascViewRenderer {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void renderView(VascTable table) {
|
public void renderView(VascTable table) {
|
||||||
|
|
||||||
|
try {
|
||||||
|
table.setTableData(table.getVascDataSource().executeQuery(table.getQuery()));
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
this.table=table;
|
this.table=table;
|
||||||
GridLayout layout = new GridLayout();
|
GridLayout layout = new GridLayout();
|
||||||
layout.marginHeight = 0;
|
layout.marginHeight = 0;
|
||||||
|
@ -143,12 +152,29 @@ public class SwtVascViewRenderer implements VascViewRenderer {
|
||||||
public void createBody(Composite body) {
|
public void createBody(Composite body) {
|
||||||
logger.finer("Creating body");
|
logger.finer("Creating body");
|
||||||
|
|
||||||
final TableViewer tableViewer = JFaceComponentFactory.createTableViewer(body,table.getSelectionInList(),getTableColumns(crudTable),false);
|
//final TableViewer tableViewer = JFaceComponentFactory.createTableViewer(body,table.getSelectionInList(),getTableColumns(crudTable),false);
|
||||||
|
// Create the table viewer to display the players
|
||||||
|
final TableViewer tableViewer = new TableViewer(body);
|
||||||
final Table table2 = tableViewer.getTable();
|
final Table table2 = tableViewer.getTable();
|
||||||
table2.setLayoutData(new GridData(GridData.FILL_BOTH));
|
table2.setLayoutData(new GridData(GridData.FILL_BOTH));
|
||||||
table2.setHeaderVisible(true);
|
table2.setHeaderVisible(true);
|
||||||
table2.setLinesVisible(true);
|
table2.setLinesVisible(true);
|
||||||
|
|
||||||
|
// Set the content and label providers
|
||||||
|
tableViewer.setContentProvider(new ListConverterContentProvider());
|
||||||
|
tableViewer.setLabelProvider(new DefaultLabelProvider(table));
|
||||||
|
//tv.setSorter(new PlayerViewerSorter());
|
||||||
|
tableViewer.setInput(table);
|
||||||
|
|
||||||
|
for(VascTableColumn c:table.getTableColumns()) {
|
||||||
|
TableColumn tc = new TableColumn(table2, SWT.LEFT);
|
||||||
|
tc.setText(c.getName());
|
||||||
|
tc.setToolTipText(c.getToolTip());
|
||||||
|
tc.setMoveable(false);
|
||||||
|
tc.setResizable(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//Add sort indicator and sort data when column selected
|
//Add sort indicator and sort data when column selected
|
||||||
Listener sortListener = new Listener() {
|
Listener sortListener = new Listener() {
|
||||||
public void handleEvent(Event e) {
|
public void handleEvent(Event e) {
|
||||||
|
@ -200,6 +226,7 @@ public class SwtVascViewRenderer implements VascViewRenderer {
|
||||||
logger.fine("Table with columns created: "+table2.getColumnCount());
|
logger.fine("Table with columns created: "+table2.getColumnCount());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
private static AbstractColumn[] getTableColumns(VascTable crudTable) {
|
private static AbstractColumn[] getTableColumns(VascTable crudTable) {
|
||||||
AbstractColumn[] cols = new AbstractColumn[crudTable.getCrudTableColumns().size()];
|
AbstractColumn[] cols = new AbstractColumn[crudTable.getCrudTableColumns().size()];
|
||||||
int i=0;
|
int i=0;
|
||||||
|
@ -212,7 +239,7 @@ public class SwtVascViewRenderer implements VascViewRenderer {
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
return cols;
|
return cols;
|
||||||
}
|
}*/
|
||||||
|
|
||||||
public void createFooter(Composite footer) {
|
public void createFooter(Composite footer) {
|
||||||
logger.finest("Creating footer");
|
logger.finest("Creating footer");
|
||||||
|
@ -232,5 +259,86 @@ public class SwtVascViewRenderer implements VascViewRenderer {
|
||||||
* Is called when all createPartControl is done with creating Parts
|
* Is called when all createPartControl is done with creating Parts
|
||||||
*/
|
*/
|
||||||
public void partCreated() {
|
public void partCreated() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class DefaultLabelProvider implements ITableLabelProvider {
|
||||||
|
|
||||||
|
private VascTable table = null;
|
||||||
|
|
||||||
|
public DefaultLabelProvider(VascTable table) {
|
||||||
|
this.table=table;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see org.eclipse.jface.viewers.ITableLabelProvider#getColumnImage(java.lang.Object, int)
|
||||||
|
*/
|
||||||
|
public Image getColumnImage(Object arg0, int arg1) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see org.eclipse.jface.viewers.ITableLabelProvider#getColumnText(java.lang.Object, int)
|
||||||
|
*/
|
||||||
|
public String getColumnText(Object bean, int columnNumber) {
|
||||||
|
System.out.println("Rending column; "+columnNumber+" bean: "+bean);
|
||||||
|
VascTableColumn vtc = table.getTableColumns().get(columnNumber);
|
||||||
|
if (vtc.getColumnRenderer()!=null) {
|
||||||
|
//do iets
|
||||||
|
return "RENDER";
|
||||||
|
} else {
|
||||||
|
return ""+vtc.getVascColumnValue().getValue(vtc,bean);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see org.eclipse.jface.viewers.IBaseLabelProvider#addListener(org.eclipse.jface.viewers.ILabelProviderListener)
|
||||||
|
*/
|
||||||
|
public void addListener(ILabelProviderListener arg0) {
|
||||||
|
}
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see org.eclipse.jface.viewers.IBaseLabelProvider#dispose()
|
||||||
|
*/
|
||||||
|
public void dispose() {
|
||||||
|
}
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see org.eclipse.jface.viewers.IBaseLabelProvider#isLabelProperty(java.lang.Object, java.lang.String)
|
||||||
|
*/
|
||||||
|
public boolean isLabelProperty(Object arg0, String arg1) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see org.eclipse.jface.viewers.IBaseLabelProvider#removeListener(org.eclipse.jface.viewers.ILabelProviderListener)
|
||||||
|
*/
|
||||||
|
public void removeListener(ILabelProviderListener arg0) {
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class ListConverterContentProvider implements IStructuredContentProvider {
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see org.eclipse.jface.viewers.IStructuredContentProvider#getElements(java.lang.Object)
|
||||||
|
*/
|
||||||
|
public Object[] getElements(Object obj) {
|
||||||
|
return ((VascTable)obj).getTableData().toArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see org.eclipse.jface.viewers.IContentProvider#dispose()
|
||||||
|
*/
|
||||||
|
public void dispose() {
|
||||||
|
}
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see org.eclipse.jface.viewers.IContentProvider#inputChanged(org.eclipse.jface.viewers.Viewer, java.lang.Object, java.lang.Object)
|
||||||
|
*/
|
||||||
|
public void inputChanged(Viewer arg0, Object arg1, Object arg2) {
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -67,15 +67,21 @@ public class SimpleTest extends TestCase {
|
||||||
|
|
||||||
public void testAll() throws Exception {
|
public void testAll() throws Exception {
|
||||||
|
|
||||||
|
// get GUI
|
||||||
Display display = new Display();
|
Display display = new Display();
|
||||||
Shell shell = new Shell(display);
|
Shell shell = new Shell(display);
|
||||||
shell.setText("Hello, world!");
|
shell.setText("Hello, world!");
|
||||||
|
|
||||||
|
// define query
|
||||||
XTESParser parser = new XTESParser();
|
XTESParser parser = new XTESParser();
|
||||||
parser.parseResource("/META-INF/xtes/tests.xml");
|
parser.parseResource("/META-INF/xtes/tests.xml");
|
||||||
TemplateStore store = XTESParser.getTemplateStore(parser.getElementContext());
|
TemplateStore store = XTESParser.getTemplateStore(parser.getElementContext());
|
||||||
Query query = store.getQuery("testUsers2");
|
Query query = store.getQuery("testUsers2");
|
||||||
|
|
||||||
|
// define redering
|
||||||
|
SwtVascViewRenderer render = new SwtVascViewRenderer(shell);
|
||||||
|
|
||||||
|
// config table
|
||||||
VascTable table = new VascTable();
|
VascTable table = new VascTable();
|
||||||
table.setName("Testje");
|
table.setName("Testje");
|
||||||
table.setHeaderName("TableHeader");
|
table.setHeaderName("TableHeader");
|
||||||
|
@ -84,7 +90,7 @@ public class SimpleTest extends TestCase {
|
||||||
table.setHelpId("someKey");
|
table.setHelpId("someKey");
|
||||||
table.setVascDataSource(new Serv5HibernateVascDataSource("flowstats"));
|
table.setVascDataSource(new Serv5HibernateVascDataSource("flowstats"));
|
||||||
table.setVascTextValue(new DefaultVascTextValue());
|
table.setVascTextValue(new DefaultVascTextValue());
|
||||||
table.setVascViewRenderer(new SwtVascViewRenderer(shell));
|
table.setVascViewRenderer(render);
|
||||||
table.setQuery(query);
|
table.setQuery(query);
|
||||||
table.setVascRecordCreator(new BeanVascRecordCreator());
|
table.setVascRecordCreator(new BeanVascRecordCreator());
|
||||||
|
|
||||||
|
@ -99,9 +105,10 @@ public class SimpleTest extends TestCase {
|
||||||
column.setVascColumnValue(new BeanPropertyVascColumnValue("someValue"));
|
column.setVascColumnValue(new BeanPropertyVascColumnValue("someValue"));
|
||||||
table.addTableColumns(column);
|
table.addTableColumns(column);
|
||||||
|
|
||||||
|
// render
|
||||||
table.getV
|
render.renderView(table);
|
||||||
|
|
||||||
|
// view
|
||||||
shell.open();
|
shell.open();
|
||||||
// Set up the event loop.
|
// Set up the event loop.
|
||||||
while (!shell.isDisposed()) {
|
while (!shell.isDisposed()) {
|
||||||
|
|
Loading…
Reference in a new issue