1 package org
.argeo
.slc
.client
.ui
.dist
.utils
;
3 import java
.text
.DateFormat
;
4 import java
.text
.SimpleDateFormat
;
5 import java
.util
.HashMap
;
8 import javax
.jcr
.PropertyType
;
9 import javax
.jcr
.RepositoryException
;
10 import javax
.jcr
.Value
;
11 import javax
.jcr
.query
.Row
;
13 import org
.apache
.commons
.logging
.Log
;
14 import org
.apache
.commons
.logging
.LogFactory
;
15 import org
.argeo
.ArgeoException
;
16 import org
.argeo
.eclipse
.ui
.GenericTableComparator
;
17 import org
.argeo
.slc
.client
.ui
.dist
.DistConstants
;
18 import org
.argeo
.slc
.jcr
.SlcNames
;
19 import org
.argeo
.slc
.jcr
.SlcTypes
;
20 import org
.eclipse
.jface
.viewers
.ColumnLabelProvider
;
21 import org
.eclipse
.jface
.viewers
.TableViewer
;
22 import org
.eclipse
.jface
.viewers
.TableViewerColumn
;
23 import org
.eclipse
.jface
.viewers
.Viewer
;
24 import org
.eclipse
.swt
.SWT
;
25 import org
.eclipse
.swt
.events
.SelectionAdapter
;
26 import org
.eclipse
.swt
.events
.SelectionEvent
;
27 import org
.eclipse
.swt
.graphics
.Image
;
28 import org
.eclipse
.swt
.widgets
.TableColumn
;
31 * Centralizes and factorizes useful methods to create and manage tables that
32 * display artifacts for both editors and views.
34 public class ArtifactsTableConfigurer
implements SlcNames
, SlcTypes
,
36 private final static Log log
= LogFactory
37 .getLog(ArtifactsTableConfigurer
.class);
38 // Used in the comparator to be able to retrieve the value from a row
39 // knowing the corresponding column index.
40 private Map
<Integer
, String
> indexToName
= new HashMap
<Integer
, String
>();
42 private CurrentTableComparator comparator
;
43 private TableViewer viewer
;
45 protected DateFormat timeFormatter
= new SimpleDateFormat(DATE_TIME_FORMAT
);
48 * Create and initialize the table configurer.
50 public ArtifactsTableConfigurer(TableViewer viewer
,
51 int defaultSortColumnIndex
, int direction
) {
53 comparator
= new CurrentTableComparator(defaultSortColumnIndex
,
57 public GenericTableComparator
getComparator() {
62 * Configure column width and header label depending on the value that will
63 * be displayed in the current column.
65 * @param jcrColumnName
69 public void configureColumn(String jcrColumnName
, TableViewerColumn column
,
73 && getSelectionAdapter(column
.getColumn(), columnIndex
) != null) {
74 column
.getColumn().addSelectionListener(
75 getSelectionAdapter(column
.getColumn(), columnIndex
));
76 indexToName
.put(new Integer(columnIndex
), jcrColumnName
);
78 Object
[] objs
= DistUiHelpers
79 .getLabelAndDefaultValueWidth(jcrColumnName
);
80 column
.getColumn().setWidth((Integer
) objs
[1]);
81 column
.getColumn().setText((String
) objs
[0]);
85 * Might be used by client classes to sort the table with based on selected
92 public SelectionAdapter
getSelectionAdapter(final TableColumn column
,
95 // A comparator must be define
96 if (comparator
== null)
99 SelectionAdapter selectionAdapter
= new SelectionAdapter() {
101 public void widgetSelected(SelectionEvent e
) {
105 comparator
.setColumn(index
);
106 int dir
= viewer
.getTable().getSortDirection();
107 if (viewer
.getTable().getSortColumn() == column
) {
108 dir
= dir
== SWT
.UP ? SWT
.DOWN
: SWT
.UP
;
113 viewer
.getTable().setSortDirection(dir
);
114 viewer
.getTable().setSortColumn(column
);
116 } catch (Exception exc
) {
117 exc
.printStackTrace();
121 return selectionAdapter
;
125 * provides a label provider that returns the content of a specific cell.
126 * Specific treatment is done for some columns when the query returns a code
127 * that must be translated to the corresponding value at display time.
129 public ColumnLabelProvider
getLabelProvider(final String columnName
) {
130 boolean test
= false;
133 return new ColumnLabelProvider() {
134 public String
getText(Object element
) {
138 public Image
getImage(Object element
) {
143 return new ColumnLabelProvider() {
144 public String
getText(Object element
) {
145 Row row
= (Row
) element
;
147 return row
.getValue(columnName
).getString();
148 } catch (RepositoryException e
) {
149 throw new ArgeoException("Cannot display row " + row
, e
);
153 public Image
getImage(Object element
) {
159 /** Implements comparator for various types of Artifact Table row */
160 private class CurrentTableComparator
extends GenericTableComparator
{
162 public CurrentTableComparator(int colIndex
, int direction
) {
163 super(colIndex
, direction
);
167 public int compare(Viewer viewer
, Object e1
, Object e2
) {
170 if (e1
instanceof Row
) {
173 Value v1
= ((Row
) e1
).getValue(indexToName
174 .get(propertyIndex
));
175 Value v2
= ((Row
) e2
).getValue(indexToName
176 .get(propertyIndex
));
178 if (v1
.getType() == PropertyType
.STRING
)
179 rc
= v1
.getString().compareTo(v2
.getString());
180 else if (v1
.getType() == PropertyType
.DATE
)
181 rc
= v1
.getDate().compareTo(v2
.getDate());
183 throw new ArgeoException("comparator for object type "
184 + v1
.getType() + " is not yet implemented");
185 } catch (Exception e
) {
186 throw new ArgeoException("rows cannot be compared ", e
);
189 throw new ArgeoException("Unsupported row type");
190 // If descending order, flip the direction
191 if (direction
== DESCENDING
) {