Use cursor mode in the query that gets data for the list view.
[online-glom:gwt-glom.git] / TODO
1 Here's a list of TODO items / ideas in no particular order.
2
3
4 Improvements to LayoutListView:
5
6 * Implement column width size as specified in the glom file.
7
8 * Add support for LayoutItem_Text, LayoutItem_Button and LayoutItem_Image items.
9
10 * Make width of the CellTable used for the LayoutList consistent between the
11   tables so that the UI doesn't appear to jump around. One way to do this is to
12   find the width of the largest table and enlarge the column widths
13   proportionally in the smaller tables. Of course this will not respect the
14   column widths specified in the glom file. Another option is to pad the smaller
15   tables with empty columns at the end so that the line under the headers extends to
16   the end of the largest table. Some experimentation is required to see which option
17   is the best.
18
19 * Only the cell backgrounds are coloured which leaves a gap between the cells that
20   isn't coloured. I need to figure out a way to set 'style=background-colour:'
21   on the whole column rather than just the cell.
22
23 * Use ColumnInfo rpc object to send text background and foreground colours
24   instead of sending this information for each cell.
25
26
27 Improvements to LayoutDetailsView:
28
29 * This hasn't been started yet.
30
31
32 Currency formatting:
33
34 The default Java currency formatting uses the currency symbol (€, $, etc) for
35 the the currency used in the specified country and the currency code (EUR, USD,
36 etc) for currencies used outside of the specified country. For example, when
37 using en_CA (English Canada) with CAD (Canadian Dollars), the number 5.89 is
38 represented as "$5.89". With EUR, the same number is represented as "EUR5.89"
39 which is not what is expected. We should get either "€5.89" or "EUR 5.89".
40 Obviously Java is just replacing the currency symbol with the currency code for
41 currencies outside of the specified country. This might be a bug in Java which
42 should be reported to the openjdk project if required. Regardless if it's a bug
43 or not, it should be possible to work around this by using custom formatting
44 strings when we implement a preference for setting locale.
45
46
47 Servlet:
48
49 * Test memory usage before and after we execute the query that would result in
50   a large ResultSet.  We need to ensure that the JDBC driver is in fact
51   returning a cursor based result set that has a low memory footprint. Check
52   the difference between this value before and after the query:
53
54   Runtime.getRuntime().totalMemory() - Runtime.getRuntime().freeMemory()
55
56   See the TODO item about this in
57   src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java.
58
59 * Create a memory and time efficient way to get the row count. Right now the
60   ResultSet is not being returned in cursor mode because we're using
61   TYPE_SCROLL_INSENSITIVE to able to seek to the last record of the ResultSet.
62   The PostgreSQL JDBC driver doesn't support moving around in the ResultSet
63   when in cursor mode.  Here's the relevant PostgreSQL documentation:
64
65   http://jdbc.postgresql.org/documentation/83/query.html#query-with-cursor
66
67   An option might be to do a SELECT COUNT query using a method in libglom or a
68   custom method in java-libglom to build the query.
69
70   See: https://bugzilla.gnome.org/show_bug.cgi?id=645110