tests: SelfHoster: selfHost(): Close the test connection.
[online-glom:gwt-glom.git] / ChangeLog
1 2012-07-20  Murray Cumming  <murrayc@murrayc.com>
2
3         tests: SelfHoster: selfHost(): Close the test connection.
4
5         * src/test/java/org/glom/web/server/SelfHoster.java: selfHost():
6         When we check that the connection works, close the connection. This seems
7         to not be closed automatically otherwise.
8
9 2012-07-20  Murray Cumming  <murrayc@murrayc.com>
10
11         Use slf4j-simple to see JDBC errors.
12
13         * pom.xml: Depend on slf4j-simple so we can see errors from JDBC.
14
15 2012-07-19  Murray Cumming  <murrayc@murrayc.com>
16
17         SelfHoster.discoverFirstFreePort(): Close the socket.
18
19         * src/test/java/org/glom/web/server/SelfHoster.java:
20         discoverFirstFreePort(): Close the socket. Eclipse Juno warns about this.
21
22 2012-07-19  Murray Cumming  <murrayc@murrayc.com>
23
24         Avoid another code warning in Eclipse Juno.
25
26         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
27         Do instanceof checks on the FileUtils.listFiles() result and its 
28         items.
29
30 2012-07-13  Murray Cumming  <murrayc@murrayc.com>
31
32         Avoid some code warnings in Eclipse Juno
33
34         * src/main/java/org/glom/web/server/libglom/Document.java:
35         getNodeTextChildAsValue(), setNodeTextChildAsValue(): Handle the invalid type.
36         * src/test/java/org/glom/web/server/SelfHoster.java
37         createTextFile(): Make sure that the FileOutputStream is closed.
38
39 2012-06-22  Murray Cumming  <murrayc@murrayc.com>
40
41         Added OnlineGlomPropertiesTest.
42
43         * src/main/java/org/glom/web/server/OnlineGlomProperties.java:
44         Make sure we never return a null string.
45         * src/test/java/org/glom/web/server/OnlineGlomPropertiesTest.java:
46         Added tests of the OnlineGlomProperties API, using our sample file.
47
48 2012-06-20  Murray Cumming  <murrayc@murrayc.com>
49
50         Make OnlineGlomProperties be a normal class.
51
52         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
53         Move OnlineGlomProperties into its own file to be a regular class:
54         * src/main/java/org/glom/web/server/OnlineGlomProperties.java:
55         This makes testing simpler.
56
57 2012-06-15  Murray Cumming  <murrayc@murrayc.com>
58
59         OnlineGlomServiceImpl.init(): Move some code into a new method.
60
61         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
62         Create addDocument().
63
64 2012-06-15  Murray Cumming  <murrayc@murrayc.com>
65
66         OnlineGlomServiceImpl.OnlineGlomProperties: Improve getKey().
67
68         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
69         OnlineGlomProperties.getKey(): Make this more robust by moving the
70         check for *.*.filename to here.
71
72 2012-06-15  Murray Cumming  <murrayc@murrayc.com>
73
74         OnlineGlomServiceImpl: Improve the OnlineGlomProperties class.
75
76         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java
77         init(): Move knowledge of the config file format into the 
78         OnlineGlomProperties inner class.
79
80 2012-06-15  Murray Cumming  <murrayc@murrayc.com>
81
82         SelfHostExampleTest: Make sure we cleanup on failure.
83
84         * src/test/java/org/glom/web/server/SelfHostExampleTest.java: Move
85         the use of cleanup() to a tearDown() JUnit method.
86
87 2012-06-12  Murray Cumming  <murrayc@murrayc.com>
88
89         ConfiguredDocument: Add a primary key to portals at least once.
90
91         * src/main/java/org/glom/web/server/ConfiguredDocument.java
92         updatePortalsExtras): Fix a typo so that we add the primary key
93         column at least once.
94         This is a fix for the previous commit:
95         ConfiguredDocument: Do not add a primary key to portals each time.
96
97 2012-06-08  Murray Cumming  <murrayc@murrayc.com>
98
99         SelfHoster: Avoid some compiler warnings.
100
101         * src/test/java/org/glom/web/server/SelfHoster.java
102         executeCommandLineAndWait():
103         executeCommandLineAndWaitUntilSecondCommandReturnsSuccess(): Comment out
104         the now-unused streams for stdout and stderr from the command Processes.
105         These are not used because readln() hangs while waiting for a new line,
106         where there may be no next line. The commented out code is still there
107         to help us figure out how to do this properly.
108
109 2012-06-08  Murray Cumming  <murrayc@murrayc.com>
110
111         LayoutItemPortalDeepCloneTest: Test something to avoid warnings.
112
113         * src/test/java/org/glom/web/server/libglom/LayoutItemPortalDeepCloneTest.java:
114         Make this actually test the cloning again, though it is not very useful
115         now that we do not use the part that had a problem with cloning before.
116
117 2012-06-08  Murray Cumming  <murrayc@murrayc.com>
118
119         SelfHoster: Keep trying pg_ctl after starting postgres.
120
121         * src/test/java/org/glom/web/server/SelfHoster.java
122         executeCommandLineAndWaitUntilSecondCommandReturnsSuccess():
123         Try pg_ctl repeatedly (for ever) until it succeeds, as we do in 
124         regular Glom. This seems mad but it seems to work because the first
125         command would fail if pg_ctl would eventually fail.
126
127 2012-06-08  Murray Cumming  <murrayc@murrayc.com>
128
129         SelfHoster: Wait until the server is really ready.
130
131         * src/test/java/org/glom/web/server/SelfHoster.java
132         selfHost(): Attempt the connection after starting the server, retrying 
133         a few times if necessary, so that the server is really ready already when
134         we return from this method.
135         The regular Glom code does this too because pg_ctl reports success too soon.
136
137 2012-06-08  Murray Cumming  <murrayc@murrayc.com>
138
139         ConfiguredDocument: Do not add a primary key to portals each time.
140
141         * src/main/java/org/glom/web/server/ConfiguredDocument.java
142         updatePortalsExtras(): Only add an extra primary key field if there is 
143         none, to avoid adding one each time we retrieve the details layout from the
144         layouts cache.
145         This should fix bug #676986 (Ben Konrath) 
146
147 2012-05-25  Murray Cumming  <murrayc@murrayc.com>
148
149         Document.load(): Support version 7 documents. 
150
151         * src/main/java/org/glom/web/server/libglom/Document.java: Load the 
152         database_title attribute if the title attribute is not there.
153         Bug #676737
154
155 2012-05-24  Ben Konrath  <ben@bagu.org>
156
157         Add configuration for auto-generating mvn:i18n from with Eclipse.
158
159         * pom.xml: Add PluginExecution configuration for gwt-maven-plugin.
160
161 2012-05-24  Murray Cumming  <murrayc@murrayc.com>
162
163         Update translations, adding French.
164
165         * src/main/java/org/glom/web/OnlineGlom.gwt.xml:
166         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_fr.properties:
167         Add a French translation, using the translation from Glom.
168
169         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_cs.properties:
170         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_es.properties:
171         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_sl.properties:
172         Update these based on the translations from Glom.
173
174 2012-05-24  Murray Cumming  <murrayc@murrayc.com>
175
176         SelfHoster: Add some debug println messages to help when things fail.
177
178         * src/test/java/org/glom/web/server/SelfHoster.java: Add several
179         System.out.println() lines.
180
181 2012-05-23  Murray Cumming  <murrayc@murrayc.com>
182
183         Tests: SelfHoster: Check other paths for PostgreSQL command-line tools.
184
185         * src/test/java/org/glom/web/server/SelfHoster.java:
186         getPathToPostgresExecutable(): Try some common paths (as on Ubuntu, for 
187         instance) instead of just /usr/bin (as on Fedora). Check the result when 
188         using this method.
189
190 2012-05-23  Murray Cumming  <murrayc@murrayc.com>
191
192         Remove LayoutItemPortal.get/setNavigationTable().
193         
194         * src/main/java/org/glom/web/shared/libglom/layout/LayoutItemPortal.java:
195         Remove get/setNavigationTable(), which is only a cache, because it is not
196         used, and does not need to be used, because that decision should be made on
197         the server.
198         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
199         updatePortalsExtras():
200         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
201         getNavigationRecord():
202         * src/test/java/org/glom/web/server/libglom/LayoutItemPortalDeepCloneTest.java:
203         Adapted.
204
205 2012-05-21  Murray Cumming  <murrayc@murrayc.com>
206
207         Initial self-hosting for tests.
208
209         * pom.xml: Change the scope for log4j, to hopefully make it 
210         available to the test code which uses it indirectly via jOOQ.
211         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Allow
212         self-hosting, though we only use it for testing.
213
214         * src/main/java/org/glom/web/server/libglom/Document.java:
215         example rows: Use a map instead of a list for each row of values,
216         so we know what field they are for, instead of relying on the sequence
217         being correct. This is not very efficient, but it does not really need 
218         to be.
219         * src/test/java/org/glom/web/server/libglom/DocumentTest.java
220         testReadTableExampleRows(): Adapted.
221
222         * src/main/java/org/glom/web/shared/DataItem.java: Added getValue()
223         that returns an Object, for generic use. Note that Object seems to be 
224         the implicit base even of double.
225         * src/main/java/org/glom/web/shared/libglom/Field.java: Add getSqlType(),
226         for use in CREATE TABLE SQL queries.
227         * src/test/java/org/glom/web/server/SelfHoster.java: Add this class 
228         to do self-hosting of PostgreSQL databases via its command-line 
229         utilities, based on Glom's C++ code in test_selfhosting_utils.cc and
230         backends/postgres_self.cc. This is incomplete - it needs more 
231         warnings about failures and it needs to clean up properly when things
232         fail.
233         * src/test/java/org/glom/web/server/SelfHostExampleTest.java: A simple 
234         test of this new class.
235
236 2012-05-21  Murray Cumming  <murrayc@murrayc.com>
237
238         Document: loading example data: Handle exceptions.
239
240         * src/main/java/org/glom/web/server/libglom/Document.java:
241         DateFormat.parse() and Double.valueOf() can throw exceptions, though
242         Eclipse did not warn about that.
243
244 2012-05-20  Murray Cumming  <murrayc@murrayc.com>
245
246         Document: load(), save(): Handle the example rows.
247
248         * src/main/java/org/glom/web/shared/DataItem.java: Add get/setDate() 
249         and get/setImage().
250         * src/main/java/org/glom/web/server/libglom/Document.java:
251         load(), save(): Load and save the example rows, though the date, time
252         and image types are not handled properly yet.
253         * src/test/java/org/glom/web/server/libglom/DocumentTest.java:
254         Add testReadTableExampleRows() just to check that something is read.
255
256 2012-05-20  Murray Cumming  <murrayc@murrayc.com>
257
258         Document: Add save().
259
260         * src/main/java/org/glom/web/shared/libglom/Translatable.java:
261         Added getTranslationsMap() for use while saving.
262         * src/main/java/org/glom/web/shared/libglom/layout/LayoutItemField.java:
263         Adedd getUseDefaultFormatting() for use while saving.
264         * src/main/java/org/glom/web/server/libglom/Document.java: Added save()
265         and several private methods that it uses.
266
267         This will be useful while testing via self-hosting.
268         It is not complete, but should be complete enough for testing.
269
270 2012-05-17  Murray Cumming  <murrayc@murrayc.com>
271
272         OnlineGlomService: Simplify the getList/RelatedViewData() methods.
273
274         * src/main/java/org/glom/web/client/OnlineGlomService.java
275         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java
276         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java
277         Remove getSortedListViewData() and getSortedRelatedListData(), adding
278         the sort column index and ascending bool to the regular method.
279         Instead, a sort column index of -1 now means no sort.
280         This is less explicit, but it's fairly simple, reduces the amount of 
281         code, and makes the OnlineGlomService API slightly smaller.
282         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
283         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
284         getDataProvider():
285         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
286         getListViewData(), getRelatedListData():
287         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
288         getListViewData(), getRelatedListData():
289         * src/main/java/org/glom/web/server/database/ListDBAccess.java:
290         getListData():
291         * src/main/java/org/glom/web/server/database/ListViewDBAccess.java:
292         getData():
293         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
294         getData(): Adapted.
295
296 1.21.9.2:
297
298 2012-05-16  Murray Cumming  <murrayc@murrayc.com>
299
300         Use translations for top-level groups too.
301
302         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
303         updateTitlesForLocale(): Use the translation for the group 
304         as well as for child items.
305
306 1.21.9.1:
307
308 Just recompiled to fix a problem in the released .tar.gz file.
309
310 1.21.9:
311
312 2012-05-15  Murray Cumming  <murrayc@murrayc.com>
313
314         Corrections to navigation to related records.
315         
316         * src/main/java/org/glom/web/client/OnlineGlomService.java:
317         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
318         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
319         getRelatedListData(), getSortedRelatedListData)(), getRelatedListRowCount(),
320         getSuitableRecordToViewDetails(): Take a LayoutItemPortal instead of a 
321         relationship name, because the relationship name is not necessarily unique 
322         on the layout.
323         TOOD: This is inefficient, because it passes the whole list of 
324         child field items back to the server, but it is more correct, and happens
325         to fix a bug with the primary key being lost after a few navigations.
326         There is probably a chance to make this more efficient anyway in some 
327         more basic way.
328         
329         * src/main/java/org/glom/web/client/activity/DetailsActivity.java
330         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.jav
331         * src/main/java/org/glom/web/server/ConfiguredDocument.java
332         * src/main/java/org/glom/web/server/database/DBAccess.java
333         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
334         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
335         Adapted.
336
337 2012-05-15  Murray Cumming  <murrayc@murrayc.com>
338
339         Fix the use of translations.
340
341         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
342         Add updateTitlesForLocale().
343         getValidListViewLayoutGroup(), getDetailsLayoutGroup():
344         Call it to discard unwanted translations and to make getTitle() return
345         the wanted translation wihout the need for the client code to specify a locale.
346         * src/main/java/org/glom/web/shared/libglom/Translatable.java:
347         getTitle(): Fallback to the original title, as libglom does.
348
349 2012-05-15  Murray Cumming  <murrayc@murrayc.com>
350
351         Document: Correctly report the number of available translation locales.
352
353         * src/main/java/org/glom/web/server/libglom/Document.java: Fill
354         the available locale IDs list.
355         * src/test/java/org/glom/web/server/libglom/DocumentTest.java:
356         testLocales: Test this.
357
358 2012-05-15  Murray Cumming  <murrayc@murrayc.com>
359
360         SqlUtils: Use camelCase.
361
362         * src/main/java/org/glom/web/server/SqlUtils.java: Use camelCase.
363         * src/main/java/org/glom/web/server/database/DetailsDBAccess.java:
364         * src/main/java/org/glom/web/server/database/ListViewDBAccess.java:
365         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
366         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
367         * src/main/java/org/glom/web/server/ReportGenerator.java: Adapt.
368
369 2012-05-15  Murray Cumming  <murrayc@murrayc.com>
370
371         Use jOOQ's tableByName() and fieldByName.
372
373         * pom.xml: Use jOOQ 2.3.1 to get the new API.
374         * src/main/java/org/glom/web/server/SqlUtils.java:
375         build_sql_select_step_with_where_clause(), .createField(),
376         builder_add_join(): Use Factory.tableByName() and Factory.fieldByName()
377         so we can get correct quoting and escaping. Thanks to Lukas Eder for 
378         adding this, and other things, to jOOQ.
379
380 2012-05-15  Murray Cumming  <murrayc@murrayc.com>
381
382         SqlUtils: Remove the Connection parameters.
383
384         * src/main/java/org/glom/web/server/SqlUtils.java:
385         build_sql_select_with_key(), build_sql_select_with_where_clause(),
386         createSelect(), build_sql_select_step_with_where_clause(),
387         build_sql_count_select_with_where_clause(),
388         build_sql_select_count_rows(): Remove the Connection parameter because
389         jOOQ does not actually need a connectionwhen it is just used to build 
390         a SQL string:
391         https://groups.google.com/forum/#!topic/jooq-user/tIwobFOR2iM
392
393         * src/main/java/org/glom/web/server/ReportGenerator.java:
394         generateReport():
395         * src/main/java/org/glom/web/server/database/DetailsDBAccess.java:
396         getData():
397         * src/main/java/org/glom/web/server/database/ListDBAccess.java:
398         Constructor, getListData(), getResultSizeOfSQLQuery():
399         * src/main/java/org/glom/web/server/database/ListViewDBAccess.java:
400         getSelectQuery(), getCountQuery():
401         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
402         getSelectQuery(), getCountQuery():
403         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
404         getNavigationRecord(): Adapted.
405
406 2012-05-14  Murray Cumming  <murrayc@murrayc.com>
407
408         Fix quick find.
409
410         * src/main/java/org/glom/web/server/SqlUtils.java:
411         get_find_where_clause_quick(): Use a comparison of 
412         lowercase values, instead of a simple equals. Regular Glom
413         uses the PostgreSQL ILIKE operator but jOOQ does not 
414         support that just yet, though it will soon.
415
416 2012-05-14  Murray Cumming  <murrayc@murrayc.com>
417
418         TableToViewDetails: Use a real serialization ID.
419
420         * src/main/java/org/glom/web/shared/libglom/layout/TableToViewDetails.java:
421         Though this does not fix the serialization problem.
422
423 2012-05-12  Murray Cumming  <murrayc@murrayc.com>
424
425         Added LayoutItemPortalDeepCloneTest.
426
427 2012-05-11  Murray Cumming  <murrayc@murrayc.com>
428
429         Make navigation work again.
430
431         * src/main/java/org/glom/web/server/libglom/Document.java:
432         Add getLayoutItemFieldShouldHaveNavigation().
433         * src/main/java/org/glom/web/shared/libglom/layout/LayoutItemField.java:
434         Replace get/setAddNavigation() with the partly-existing 
435         get/setNavigationTableName(), with an empty string being no navigation,
436         because this is simpler. Use the new 
437         Document.getLayoutItemFieldShouldHaveNavigation() method to set this.
438         
439         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
440         Add updateFieldsExtras() and call setNavigationTableName in it.
441         getDetailsLayoutGroup(), 
442         * src/main/java/org/glom/web/client/activity/DetailsActivity.java
443         createLayout(): Adapted.
444         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java
445         Constructor: Adapted.
446
447         * src/main/java/org/glom/web/shared/libglom/layout/LayoutItemPortal.java:
448         Replace get/setAddNavigation() with get/setNavigation(), returning a
449         TableToViewDetails class with both the table name and UsesRelationship,
450         because both are need. The previous code used java-libglom's output 
451         variable (strangely, via sharedptr) to return both, but we cannot really
452         do that in Java.
453         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
454         getNavigationRecord(): Adapt. However, we cannot actually use the cache
455         here because it somehow gets set to null during deepCopy(). I must test this.
456         * src/test/java/org/glom/web/server/libglom/DocumentTest.java
457         testGetSuitableTableToViewDetails(): Adapted.
458         
459         TODO: Find out why deepClone() is not quite working.
460         
461 2012-05-11  Murray Cumming  <murrayc@murrayc.com>
462
463         DBAccess: Simplify the retrievel of full field details.
464
465         * src/main/java/org/glom/web/server/database/DBAccess.java
466         getFieldsToShowForSQLQueryAddGroup(). This might be unnecessary anyway,
467         because the Document loading should have done this.
468
469 2012-05-11  Murray Cumming  <murrayc@murrayc.com>
470
471         Document: Correct loading of doubly-related layout fields.
472
473         * src/main/java/org/glom/web/server/libglom/Document.java:
474         loadUsesRelationship(): Actually set the related relationship, instead
475         of only setting it if it's not found.
476
477 2012-05-09  Murray Cumming  <murrayc@murrayc.com>
478
479         Replace all appearances of Colour with color.
480
481         Because US English is dominant.
482
483 2012-05-09  Murray Cumming  <murrayc@murrayc.com>
484
485         Use colors in HTML format, solving a warning about an unused function.
486
487         * src/main/java/org/glom/web/shared/libglom/NumericFormat.java
488         * src/main/java/org/glom/web/shared/libglom/layout/Formatting.java:
489         Add *asHTMLColor() versions of methods.
490         TODO: However, we should create and cache the results on the server.
491         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java
492         * src/main/java/org/glom/web/client/ui/list/ListTable.java
493         * src/main/java/org/glom/web/server/ConfiguredDocument.java
494         * src/test/java/org/glom/web/server/libglom/DocumentTest.java:
495         Use the asHTMLcolor() versions.
496
497 2012-05-09  Murray Cumming  <murrayc@murrayc.com>
498
499         ListViewTable: Constructor: Take the table name as a parameter.
500
501         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
502         Constructor: Take the tableName, and set the member variable, because
503         we use it here.
504         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
505         setCellTable(): Pass the table name.
506         This makes navigation to non-default tables work again. I don't know 
507         why it worked before in the master branch.
508
509 2012-05-07  Murray Cumming  <murrayc@murrayc.com>
510
511         ConfiguredDocument: Restore correct addition of hidden primary key items.
512
513         * src/main/java/org/glom/web/client/ui/list/ListTable.java
514         (ListTable.createCellTable): Uncomment out the check for the hidden
515         primary key.
516         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Only
517         add primary key items for top-level lists and portals, as before, 
518         instead of adding them to each group.
519         * src/main/java/org/glom/web/shared/libglom/layout/LayoutGroup.java:
520         Actually implement the extra methods such as setHiddenPrimaryKey() and
521         comment that these are used only for top-level list groups and in portals.
522         This strangeness suggests even more that this should not be squeezed
523         into the LayoutGroup class.
524
525 2012-05-07  Murray Cumming  <murrayc@murrayc.com>
526
527         Fix Formatting loading.
528
529         * src/main/java/org/glom/web/shared/libglom/layout/LayoutItemField.java:
530         getFormattingUsed(): Remove the duplicate Formatting member variable
531         in favour of the one from the base class.
532         * src/main/java/org/glom/web/shared/libglom/layout/LayoutItemWithFormatting.java:
533         Initialize a new Formatting instead of using null by default, so we 
534         have some defaults, instead of having to initialize one later just to 
535         get the same defaults. This also makes loading of formatting from the
536         document work, because that expected a non-null.
537
538 2012-05-07  Murray Cumming  <murrayc@murrayc.com>
539
540         RelatedListTable: Make sure that the tableName is set.
541
542         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
543         Constructor: Take the tableName so it is available later. Otherwise, 
544         the server assumes that we mean the default table and cannot find the
545         relationship in it.
546         * src/main/java/org/glom/web/client/activity/DetailsActivity.java
547         setData(): Pass the tableName to the RelatedListTable constructor.
548
549 2012-05-07  Murray Cumming  <murrayc@murrayc.com>
550
551         Add some checks.
552
553         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
554         RelatedListNavigationButtonCell.onEnterKeyDown(), setData():
555         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
556         getDataProvider():
557         * src/main/java/org/glom/web/client/ui/list/ListTable.java:
558         addColumn():
559         * src/main/java/org/glom/web/server/database/DBAccess.java:
560         convertResultSetToDTO(), getPortal():
561         * src/main/java/org/glom/web/server/database/ListDBAccess.java
562         getListData():
563         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
564         Add checks for null objects and out of range access, with log messages to
565         give hints so we can fix these properly.
566
567 2012-05-07  Murray Cumming  <murrayc@murrayc.com>
568
569         Portals: some corrections.
570
571         * src/main/java/org/glom/web/client/activity/DetailsActivity.java
572         setData():
573         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
574         constructor: Use getRelationshipNameUsed() instead of getName(), because
575         that is what is meant.
576         * src/main/java/org/glom/web/shared/libglom/layout/LayoutItemPortal.java:
577         getFromField(): Fix a typo, to get the field name, not the table name.
578         * src/main/java/org/glom/web/server/database/DBAccess.java:
579         getPortal(): Fix a typo that stopped this from working.
580
581 2012-05-07  Murray Cumming  <murrayc@murrayc.com>
582
583         LayoutItemPortal: Also override getTitleOriginal().
584
585         * src/main/java/org/glom/web/shared/libglom/layout/LayoutItemPortal.java:
586         This lets the base getTitle() with no parameters work.
587         TODO: Test this properly.
588
589 2012-05-06  Murray Cumming  <murrayc@murrayc.com>
590
591         LayoutItemPortal: getTitle*(): Use the relationship title.
592
593 2012-05-06  Murray Cumming  <murrayc@murrayc.com>
594
595         LayoutItemField: Fix loading of custom titles.
596
597         * src/main/java/org/glom/web/server/libglom/Document.java
598         loadDataLayoutItemField(): The title, if any, instead of the field 
599         title, is stored in a title_custom node. Load it from there.
600         * src/main/java/org/glom/web/shared/libglom/CustomTitle.java: Add this
601         class.
602         * src/main/java/org/glom/web/shared/libglom/layout/LayoutItemField:
603         Add getCustomTitle() and use it, instead of super.getTitle*(), in the
604         getTitle*() overrides.
605         * src/test/java/org/glom/web/server/libglom/LayoutItemFieldTest.java:
606         Adapt.
607
608 2012-05-06  Murray Cumming  <murrayc@murrayc.com>
609
610         LayoutItemField: Fall back to field titles, so some are really shown.
611
612         * src/main/java/org/glom/web/shared/libglom/layout/LayoutItemField.java:
613         Override getTitleOriginal() and getTitle(), as in java-libglom.
614         * src/test/java/org/glom/web/server/libglom/LayoutItemFieldTest.java:
615         Test this behaviour.
616
617 2012-05-06  Murray Cumming  <murrayc@murrayc.com>
618
619         Correct use of setExpectedResultSize().
620
621         * src/main/java/org/glom/web/server/ConfiguredDocument.java
622         getValidListViewLayoutGroup(), getDetailsLayoutGroup():
623         Use setExpectedResultSize only on top-level groups (for instance, the
624         list layout) or on child portals (in details views).
625         Use the correct table name for portals to avoid SQL errors.
626         Update the expected counts when returning cached layouts.
627
628 2012-05-06  Murray Cumming  <murrayc@murrayc.com>
629
630         Document: Interpret no group column count as 1.
631
632         * src/main/java/org/glom/web/server/libglom/Document.java: Use a sane
633         default, though we now check for this in the UI code anyway.
634
635 2012-05-06  Murray Cumming  <murrayc@murrayc.com>
636
637         More null checks.
638
639 2012-05-06  Murray Cumming  <murrayc@murrayc.com>
640
641         Translatable: Use Hashmap instead of Treemap because GWT supports it.
642
643         * src/main/java/org/glom/web/shared/libglom/Translatable.java:
644         The use of Treemap lead to this error from async methods, with no 
645         further clue:
646         "The response could not be deserialized"
647
648 2012-05-06  Murray Cumming  <murrayc@murrayc.com>
649
650         OnlineGlom.gwt.xml: Add exludes to fix explicit gwt compilation in Eclipse.
651
652         * src/main/java/org/glom/web/OnlineGlom.gwt.xml: This is necessary 
653         when using the Google -> GWT Compile, or 
654         g toolbar button -> GWT Compile Project... feature in Eclipse.
655
656 2012-05-06  Murray Cumming  <murrayc@murrayc.com>
657
658         ListTable.addColumn(): Protect against a null Formatting.
659
660         * src/main/java/org/glom/web/client/ui/list/ListTable.java: addColumn():
661         Create a default Formatting if it is null, because that is the simplest
662         way to do this.
663
664 2012-05-06  Murray Cumming  <murrayc@murrayc.com>
665
666         ConfiguredDocument.updateLayoutGroup(): Protect against a null dereference.
667
668         * src/main/java/org/glom/web/server/ConfiguredDocument.java
669         updateLayoutGroup(): Check that the field is not null.
670
671 2012-05-06  Murray Cumming  <murrayc@murrayc.com>
672
673         ListViewImpl: Protected against a bad cast error.
674
675         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
676         onEnterKeyDown(): Do not cast without an instanceof check.
677
678 2012-05-06  Murray Cumming  <murrayc@murrayc.com>
679
680         ListTable: Protect against an out of range error.
681
682         * src/main/java/org/glom/web/client/ui/list/ListTable.java
683         createCellTable(): This is unlikely, but can happen while debugging.
684
685 2012-05-06  Murray Cumming  <murrayc@murrayc.com>
686
687         AsyncMessage onFailure() callbacks: Log the exception message.
688
689         * src/main/java/org/glom/web/client/activity/DetailsActivity.java
690         * src/main/java/org/glom/web/client/activity/DocumentSelectionActivity.java:
691         * src/main/java/org/glom/web/client/activity/ListActivity.java:
692         * src/main/java/org/glom/web/client/activity/ReportActivity.java:
693         * src/main/java/org/glom/web/client/activity/TableSelectionActivity:
694         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
695         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
696         These are useful clues when something is wrong.
697
698 2012-05-06  Murray Cumming  <murrayc@murrayc.com>
699
700         ConfiguredDocument: Avoid a null dereference.
701
702         * src/main/java/org/glom/web/server/ConfiguredDocument.java
703         TableLayoutsForLocale.getMapWithAdd(): Make sure that the list and 
704         details maps are created.
705
706 2012-05-06  Murray Cumming  <murrayc@murrayc.com>
707
708         Document: Correct the port number parsing.
709
710         * src/main/java/org/glom/web/server/libglom/Document.java:
711         This lets us actually connect to the database and show the document.
712
713 2012-05-05  Murray Cumming  <murrayc@murrayc.com>
714
715         Fix mvn gwt:test
716
717         * pom.xml: Use htmlunit mode for gwt:test, because the default demands
718         user-interaction, asking us to load a temporary URL in a browser.s
719         * src/main/java/org/glom/web/OnlineGlom.gwt.xml: Add a servlet node,
720         which is apparently necessary for testing the service. See the comment.
721         * src/test/java/org/glom/web/client/GwtTestOnlineGlomService.java: 
722         Show the exception, if any. This is how I saw the 404 in the HTML in 
723         the exception.
724
725 2012-05-05  Murray Cumming  <murrayc@murrayc.com>
726
727         DocumentTest: Move the .glom files into the resources directory.
728
729         * src/test/java/org/glom/web/server/libglom/DocumentTest: And get the
730         URI via getResource().
731
732 2012-05-05  Murray Cumming  <murrayc@murrayc.com>
733
734         Document: Remove the FieldIdentifies inner class.
735
736         * src/main/java/org/glom/web/server/libglom/Document.java: We only
737         use the Relationship (though the same function in libglom is maybe
738         used in other ways) and so this removes a compiler warning.
739
740 2012-05-05  Murray Cumming  <murrayc@murrayc.com>
741
742         Document.load() Remove the error code parameter.
743
744         * src/main/java/org/glom/web/server/libglom/Document.java: load():
745         Remove the parameter. We do not set it yet and it could never have
746         worked as an output parameter (though maybe it did in java-libglom).
747         We could use an exception if we really want the failure reason.
748         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
749         init():
750         * src/test/java/org/glom/web/server/libglom/DocumentTest.java:
751         setUp(), testGetSuitableTableToViewDetails(): Adapt.
752
753 2012-05-05  Murray Cumming  <murrayc@murrayc.com>
754
755         Make some inner classes static.
756
757         * src/main/java/org/glom/web/server/ConfiguredDocument.java
758         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java
759         * src/main/java/org/glom/web/server/ReportGenerator.java
760         * src/main/java/org/glom/web/server/libglom/Document.java
761         Make all inner classes static that can be static.
762
763 2012-05-05  Murray Cumming  <murrayc@murrayc.com>
764
765         OnlineGlomServiceImpl: Do not load and check for java-libglom.
766
767         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java
768         init(): We do not use java-libglom any more.
769
770 2012-05-05  Murray Cumming  <murrayc@murrayc.com>
771
772         Remove mentions of java-libglom.
773
774         * README: Remove mention of java-libglom, because it no longer needed.
775         * utils/build-onlineglom-war.sh:
776         * utils/check-and-recover-tomcat.py:
777         * utils/install-onlineglom-war.sh: Remove these as they are no longer
778         useful. Building is now far easier, with no need for jhbuild.
779
780 2012-05-05  Murray Cumming  <murrayc@murrayc.com>
781
782         Fix the build (mvn package)
783
784         * src/main/java/org/glom/web/shared/libglom/layout/LayoutGroup.java
785         (LayoutGroup): Make the LayoutItemList inner class static and protected.
786         Otherwise the GWT Java->Javascript compilation fails with just this
787         error, during mvn package or when attempting to view in a browser, 
788         in the GWT developer mode in Eclipse.
789
790         [INFO] --- gwt-maven-plugin:2.4.0:compile (default) @ gwt-glom ---
791         [INFO] auto discovered modules [org.glom.web.OnlineGlom]
792         [INFO] Compiling module org.glom.web.OnlineGlom
793         [INFO]    [ERROR] Errors in 'file:/home/murrayc/checkouts/gnome/gwt-glom/src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java'
794         [INFO]       [ERROR] Line 46:  Failed to resolve 'org.glom.web.client.OnlineGlomService' via deferred binding
795         [INFO]    Scanning for additional dependencies: file:/home/murrayc/checkouts/gnome/gwt-glom/src/main/java/org/glom/web/client/ui/details/DetailsCell.java
796         [INFO]       [WARN] For the following type(s), generated source was never committed (did you forget to call commit()?)
797         [INFO]          [WARN] org.glom.web.client.OnlineGlomService_Proxy
798         [INFO]    [ERROR] Cannot proceed due to previous errors
799
800         It has taken me 2 days to find out what was causing that. After reducing
801         the code, the compiler eventually showed me the full error message.
802
803 2012-05-04  Murray Cumming  <murrayc@murrayc.com>
804
805         ConfiguredDocument: Cache the cloned and stripped layouts.
806
807         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
808         getValidListViewLayoutGroup(), .getDetailsLayoutGroup(): Store the cloned
809         layout in a map, so we can retrieve it again without rebuilding it.
810
811 2012-05-04  Murray Cumming  <murrayc@murrayc.com>
812
813         UsesRelationshipImpl: Complete the relationshipEquals() implementation.
814
815 2012-05-04  Murray Cumming  <murrayc@murrayc.com>
816
817         libglom classes: Implement some auto-generated emthods.
818
819 2012-05-04  Murray Cumming  <murrayc@murrayc.com>
820
821         Add GwtTestOnlineGlomService.
822
823         * src/test/java/org/glom/web/client/GwtTestOnlineGlomService.java:
824         However, this (and the other GwtTest*) does not seem to run during 
825         mvn test. 
826
827 2012-05-04  Murray Cumming  <murrayc@murrayc.com>
828
829         Remove use of unsupported features from client code.
830
831         * src/main/java/org/glom/web/client/StringUtils.java: Add equals().
832         * src/main/java/org/glom/web/shared/libglom/layout/UsesRelationshipImpl.java:
833         * src/main/java/org/glom/web/shared/libglom/layout/reportparts/LayoutItemGroupBy.java:
834         Use our client version of StringUtils instead of the apache commons one.
835         
836         However, the GWT Javascript compliation still fails.
837
838 2012-04-25  Murray Cumming  <murrayc@murrayc.com>
839
840         Add a Field class and implement some loading of it in Document.
841
842 2012-04-25  Murray Cumming  <murrayc@murrayc.com>
843
844         Initial Document loading implementation, instead of libglom.
845
846         * src/test/java/org/glom/web/shared/libglom/: Add Document, Report,
847         and Translatable classes, and adapt the rest of the code to use them.
848         However, this is still missing Layout and Field classes and loading.
849
850 2012-04-24  Murray Cumming  <murrayc@murrayc.com>
851
852         Use of jOOQ: Move Field creation into a utility method.
853
854         * src/main/java/org/glom/web/server/SqlUtils.java:
855         This lets us improve it more easily.
856
857 2012-04-24  Murray Cumming  <murrayc@murrayc.com>
858
859         Use of jOOQ: Improve the code to COUNT a sub-select.
860
861         * src/main/java/org/glom/web/server/SqlUtils.java:
862         Move initial query creation into 
863         build_sql_select_step_with_where_clause().
864         build_sql_select_count_rows(): Use the jOOQ API instead of
865         concatentating text, because a jOOQ Select*Step is a TableLike,
866         which is what from() takes.
867
868 2012-04-23  Murray Cumming  <murrayc@murrayc.com>
869
870         Use jOOQ instead of Glom.build_sql*(), to avoid native calls.
871
872         * pom.xml: Depend on jooq.
873         * src/main/java/org/glom/web/server/SqlUtils.java: Reimplement the
874         methods with jOOQ, based on the C++ implementations in libglom,
875         with some changes to the logic required by jooQ.
876         Take a jOOQ Condition rather than a Glom.SqlExpr (GdaSqlExpr) for the
877         where clause.
878         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
879         * src/main/java/org/glom/web/server/ReportGenerator.java:
880         * src/main/java/org/glom/web/server/SqlUtils.java:
881         * src/main/java/org/glom/web/server/database/DetailsDBAccess.java:
882         * src/main/java/org/glom/web/server/database/ListDBAccess.java:
883         * src/main/java/org/glom/web/server/database/ListViewDBAccess.java:
884         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
885         * src/main/java/org/glom/web/server/database/RelatedListNavigation:
886         Adapt. In particular, the SqlUtils methods now need to take a Connection,
887         because jOOQ needs that, though it seems unnecessary.
888
889         This is not quite finished. Ideally jOOQ would help us to build 
890         table_name.field_name names, quoting and escaping them properly.
891         See http://stackoverflow.com/questions/10264001/instantiating-a-jooq-field-by-name
892
893 2012-04-21  Murray Cumming  <murrayc@murrayc.com>
894
895         Move use of Glom.build_sql*() into a new SqlUtils class.
896
897         * src/main/java/org/glom/web/server/SqlUtils.java: Add static methods
898         to wrap Glom.build_sql*(). The parameter types are still Glom one,
899         but this will make it easier to start using something other than 
900         libglom or SqlBuilder.
901
902 2012-04-21  Murray Cumming  <murrayc@murrayc.com>
903
904         Update the project URL.
905
906         * pom.xml: Use an OnlineGlom-specific URL for the project URL.
907
908 2012-04-21  Murray Cumming  <murrayc@murrayc.com>
909
910         Main layout: Use a FlowTable instead of absolute positioning.
911
912         * src/main/java/org/glom/web/client/OnlineGlom.java: onModuleLoad():
913         The RootLayoutPanel is a (extends) AbsolutePanel, so each of its 
914         child panels/widgets must have an absolute position. But that is annoying, so
915         this adds a FlowTable and puts the child panels in there.
916
917 2012-04-21  Murray Cumming  <murrayc@murrayc.com>
918
919         GwtTestOnlineGlom: Comment out unused code.
920
921         * src/test/java/org/glom/web/client/GwtTestOnlineGlom.java:
922         Eclipse has started to say that some code is unused.
923
924 2012-04-21  Murray Cumming  <murrayc@murrayc.com>
925
926         Update to the latest versions of dependencies.
927
928         * pom.xml: Update version numbers of dependencies to the latest
929         versions.
930         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
931         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
932         * src/main/java/org/glom/web/server/ReportGenerator.java:
933         * src/main/java/org/glom/web/server/database/ListViewDBAccess.java:
934         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
935         * src/main/java/org/glom/web/server/database/RelatedListNavigation.
936         java:
937         * src/test/java/org/glom/web/client/GwtTestOnlineGlom.java:
938         Modify the imports where necessary.
939
940 2012-04-17  Murray Cumming  <murrayc@murrayc.com>
941
942         Style: Remove overflow:hidden from searchbox
943
944         * src/main/webapp/style.css: Because this pushes the Back To Link
945         label/link on to the next row, which is then hidden due to the 
946         hard-coded (in ems) height.
947
948 2012-04-20  Murray Cumming  <murrayc@murrayc.com>
949
950         Remove some duplicate code.
951
952         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java
953         getDocumentInfo(): This must have been duplicated during the merge from the
954         reports branch.
955
956 1.21.8.1:
957
958 2012-04-19  Murray Cumming  <murrayc@murrayc.com>
959
960         Reports: Localize the waiting for report message.
961
962         * src/main/java/org/glom/web/client/activity/ReportActivity.java
963         start(): Get the message from the contants.
964         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants.properties:
965         Add the string here.
966         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_cs.properties:
967         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_de.properties:
968         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_es.properties:
969         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_sl.properties:
970         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_zh_CN.properties:
971         Update these files with the English text for newer strings for now.
972
973 2012-04-19  Murray Cumming  <murrayc@murrayc.com>
974
975         Reports: Show a message while waiting for the report.
976
977         * src/main/java/org/glom/web/client/ui/ReportView.java
978         * src/main/java/org/glom/web/client/ui/ReportViewImpl.java:
979         Add setWaitingText(), to show a message saying that we are 
980         waiting for the report to be ready.
981         * src/main/java/org/glom/web/client/activity/ReportActivity.java
982         start(): Call setWaitingText() before calling the async
983         report generation.
984
985 2012-04-19  Murray Cumming  <murrayc@murrayc.com>
986
987         ReportGenerator: Specify date and time formats.
988
989         * src/main/java/org/glom/web/server/ReportGenerator.java:
990         createFieldValueElement(): Use the default (and localized)
991         short formats, though we still need a way to show 4-digit
992         years without providing the format for every locale.
993         * src/main/java/org/glom/web/server/database/DBAccess.java:
994         convertResultSetToDTO(): Use the short formats here too.
995
996 2012-04-18  Murray Cumming  <murrayc@murrayc.com>
997
998         ReportGenerator: Use the correct numeric formatting.
999
1000         * src/main/java/org/glom/web/server/ReportGenerator.java
1001         createFieldExpression(), createFieldValueElement(): Take the
1002         whole LayoutItem_Field instead of just the field name, so
1003         we have access to the formatting.
1004         createFieldValueElement(): Use JRTextField.setPattern() to
1005         specify the numeric formatting, with the help of a 
1006         regular DecimalFormat.
1007
1008 2012-04-18  Murray Cumming  <murrayc@murrayc.com>
1009
1010         ReportGenerator: Avoid showing null for group by titles.
1011
1012         * src/main/java/org/glom/web/server/ReportGenerator.java
1013         generateReport(): Use setBlankWhenNull() on the field title
1014         style too, because this is used for values in group by
1015         sections.
1016
1017 2012-04-18  Murray Cumming  <murrayc@murrayc.com>
1018
1019         ReportGenerator: Add a colon to titles in vertical groups.
1020
1021         * src/main/java/org/glom/web/server/ReportGenerator.java
1022         addFieldToDetailBandVertical(): Pass true for the withColon
1023         parameter.
1024
1025 2012-04-18  Murray Cumming  <murrayc@murrayc.com>
1026
1027         ReportGenerator: Simplify the code by using Position more.
1028
1029 2012-04-18  Murray Cumming  <murrayc@murrayc.com>
1030
1031         Reports: Support vertical groups, roughly.
1032
1033         * src/main/java/org/glom/web/server/ReportGenerator.java:
1034         addToReport(): Rename to addGroupToReport() and, if necessary,
1035         call the new addVerticalGroupToReport() method.
1036         createFieldValueElement(): Let the caller specify the Y position
1037         too.
1038
1039 2012-04-17  Murray Cumming  <murrayc@murrayc.com>
1040
1041         Reports: Allow a second report to be shown.
1042
1043         * src/main/java/org/glom/web/client/ui/ReportViewImpl.java:
1044         clear(): Do not remove the HTML widget, which broke the whole layout.
1045
1046 2012-04-17  Murray Cumming  <murrayc@murrayc.com>
1047
1048         Locales drop-down: Show that we use English by default.
1049
1050         * src/main/java/org/glom/web/client/activity/TableSelectionActivity.java:
1051         fillView(): When we use English, just because that is the default, when
1052         no locale is specified, show that in the Locales drop-down instead of 
1053         just showing the first item.
1054
1055 2012-04-17  Murray Cumming  <murrayc@murrayc.com>
1056
1057         Unselect the Report/Locale/Table combo item when appropriate.
1058
1059         * src/main/java/org/glom/web/client/activity/TableSelectionActivity.java:
1060         setPlace(): clear reportName if this is not a ReportPlace.
1061         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
1062         setSelectedTableName(), setSelectedLocale(), setSelectedReport():
1063         When the provided name is empty, unselect all items, so that none are
1064         indicated. This uses a for loop because I cannot find a single method
1065         to do this.
1066
1067 2012-04-17  Murray Cumming  <murrayc@murrayc.com>
1068
1069         Report: Give the user a way to get back to the list.
1070
1071         * src/main/java/org/glom/web/client/activity/TableSelectionActivity.java:
1072         start(), setPlace(): Show the Back To List link on reports, and also 
1073         interpret selecting the empty report item as back to list.
1074
1075 2012-04-13  Murray Cumming  <murrayc@murrayc.com>
1076
1077         Really show the selected Report name.
1078
1079         * src/main/java/org/glom/web/client/activity/TableSelectionActivity:
1080         setPlace(): Store the reportName here, if it is that kind of Place.
1081         fillView(): Set the selected Report after filling the list of reports.
1082         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
1083         setSelectedLocale(), setSelectedReport(): Avoid possible uses of
1084         null Strings, though we need some way to unselect all ListBox items
1085         in that case.
1086
1087 2012-04-13  Murray Cumming  <murrayc@murrayc.com>
1088
1089         ReportGenerator: Try to avoid some problems.
1090
1091         * src/main/java/org/glom/web/server/ReportGenerator.java
1092         addField(): Try to avoid duplicates, and avoid using a null
1093         class type.
1094
1095 2012-04-13  Murray Cumming  <murrayc@murrayc.com>
1096
1097         Reports: Use quickFind.
1098
1099         * src/main/java/org/glom/web/client/OnlineGlomService.java;
1100         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
1101         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
1102         getReportHTML(): Add a quickFind parameter.
1103         * src/main/java/org/glom/web/client/activity/ReportActivity.java
1104         start(): Pass the quickFind parameter.
1105         * src/main/java/org/glom/web/server/ReportGenerator.java
1106         generateReport(): Take a quickFind parameter.
1107
1108 2012-04-13  Murray Cumming  <murrayc@murrayc.com>
1109
1110         ReportPlace: Actually use the report name.
1111
1112         * src/main/java/org/glom/web/client/place/ReportPlace.java
1113         getPlace(): Do not assign the report name to the quickfind.
1114
1115 2012-04-13  Murray Cumming  <murrayc@murrayc.com>
1116
1117         Show java.library.path when complaining.
1118
1119         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java
1120         init(): When telling us to check java.library.path, show the
1121         current value.
1122
1123 2012-03-06  Murray Cumming  <murrayc@murrayc.com>
1124
1125         ReportGenerator: Do not show nulls.
1126
1127 2012-03-06  Murray Cumming  <murrayc@murrayc.com>
1128
1129         ReportGenerator: Make the title font larger.
1130
1131 2012-03-06  Murray Cumming  <murrayc@murrayc.com>
1132
1133         ReportGenerator: Put field titles inside groups, if there are groups.
1134
1135 2012-03-06  Murray Cumming  <murrayc@murrayc.com>
1136
1137         ReportGenerator: Take the Report itself instead of the name and group.
1138
1139         * src/main/java/org/glom/web/server/ConfiguredDocument.java
1140         Remove getReportLayoutGroup().
1141         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java
1142         getReportHTML(): Pass the report instead
1143         of its name and layout group.
1144         * src/main/java/org/glom/web/server/ReportGenerator.java
1145         generateReport(): Use the report object to use the title 
1146         instead of the name.
1147
1148 2012-03-06  Murray Cumming  <murrayc@murrayc.com>
1149
1150         ReportGenerator: Remove designBand parameters.
1151
1152         * src/main/java/org/glom/web/server/ReportGenerator.java:
1153         Make designBand a class member instead of passing it to all
1154         methods.
1155
1156 2012-03-06  Murray Cumming  <murrayc@murrayc.com>
1157
1158         ReportGenerator: Add lines, a bit like in the desktop version.
1159
1160         * src/main/java/org/glom/web/server/ReportGenerator.java
1161         addToReport(): Use JRDesignLine.
1162
1163 2012-03-06  Murray Cumming  <murrayc@murrayc.com>
1164
1165         ReportGenerator: Correct the title positions and use some bold style.
1166
1167         * src/main/java/org/glom/web/server/ReportGenerator.java:
1168         Break the code up into reusable functions, correct the placement of 
1169         titles, and use normal/bold styles as in the reports in the desktop 
1170         version.
1171
1172 2012-03-06  Murray Cumming  <murrayc@murrayc.com>
1173
1174         ReportGenerator: Add a header band to show the field titles.
1175
1176         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java
1177         getReportHTML(): Pass the localeId to the ReportGenerator 
1178         constructor.
1179         * src/main/java/org/glom/web/server/ReportGenerator.java
1180         constructor: Take the localeID so we can get translated field
1181         titles.
1182         generateReport(), addToReport(), addFieldToBand(): Add field 
1183         titles in a column header band.
1184
1185 2012-03-05  Murray Cumming  <murrayc@murrayc.com>
1186
1187         Reports drop-down list: Some improvement.
1188
1189         * src/main/java/org/glom/web/client/ui/TableSelectionView.java
1190         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
1191         Adedd setSelectedReport(),
1192         setReportList(): Add a blank line so that the user can select the 
1193         first one.
1194         * src/main/java/org/glom/web/client/activity/ReportActivity.java
1195         start(): Show the current report by calling setSelectedReport().
1196         This does not seem to work yet.
1197
1198 2012-03-05  Murray Cumming  <murrayc@murrayc.com>
1199
1200         DetailsActivity, ListActivity: Move some variables into a base class.
1201
1202         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
1203         * src/main/java/org/glom/web/client/activity/HasTableActivity.java:
1204         * src/main/java/org/glom/web/client/activity/ListActivity.java: Move 
1205         the clientFactory, documentID, tableName and authenticationPopup into
1206         a base class, to avoid duplication.
1207
1208 2012-03-05  Murray Cumming  <murrayc@murrayc.com>
1209
1210         Translate the Reports label.
1211
1212         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java
1213         Get the "Reports" label string from the constants.
1214         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants.pro
1215         perties: Add Reports to the constants.
1216
1217 2012-03-05  Murray Cumming  <murrayc@murrayc.com>
1218
1219         Reports: Implement grouping.
1220
1221         * src/main/java/org/glom/web/server/ReportGenerator.java:
1222         Handle LayoutItem_GroupBy items and try to do the right thing
1223         with JRDesignGroup. It seems to work.
1224
1225 2012-03-04  Murray Cumming  <murrayc@murrayc.com>
1226
1227         Actually show some data with JasperReports.
1228
1229         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: 
1230         getReportHTML(): Move most code into a ReportGenerator class.
1231         * src/main/java/org/glom/web/server/ReportGenerator.java:
1232         Recurse into sub-groups, adding fields to the JasperDesign's details
1233         band. Note that we must set an arbitrary width and height, or it just
1234         will not show any data.
1235
1236 2012-03-04  Murray Cumming  <murrayc@murrayc.com>
1237
1238         Reports Chooser: Show the titles, not the names.
1239
1240         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java
1241         (TableSelectionViewImpl.setReportList): Show the titles in the UI,
1242         and the names as the values.
1243         * src/main/java/org/glom/web/server/ConfiguredDocument.java
1244         (ConfiguredDocument.getReportLayoutGroup): Do not return a default
1245         group now that we provide the report name, so it should always 
1246         succeed.
1247
1248 2012-02-15  Murray Cumming  <murrayc@murrayc.com>
1249
1250         Depend on jasperreports.
1251
1252         * pom.xml: Add the dependency. My plan is to use this on the 
1253         server side.
1254
1255 2012-01-31  Murray Cumming  <murrayc@murrayc.com>
1256
1257         Implement navigation to report places.
1258
1259         * src/main/java/org/glom/web/client/activity/ReportActivity.java
1260         start(): Do not bother to handle all events here.
1261         * src/main/java/org/glom/web/client/ui/TableSelectionView.java
1262         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
1263         Added getSelectedReport().
1264         * src/main/java/org/glom/web/client/activity/TableSelectionActivity
1265         .java: start(): When handling a change to the reports chooser,
1266         call getSelectedReport() and goTo() its ReportPlace.
1267         * src/main/java/org/glom/web/client/ui/ReportView.java
1268         * src/main/java/org/glom/web/client/ui/ReportViewImpl.java:
1269         Added setReportHTML() which puts the html in a gwt HTML widget.
1270         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java
1271         getReportHTML(): Return "TODO" just to show that this works.
1272
1273 2012-01-31  Murray Cumming  <murrayc@murrayc.com>
1274
1275         Make ReportPlace usable.
1276
1277         * src/main/java/org/glom/web/client/mvp/AppPlaceHistoryMapper.java:
1278         Mention ReportPlace.
1279         * src/main/java/org/glom/web/client/place/ReportPlace.java:
1280         Correct the @prefix annotation.
1281
1282 2012-01-31  Murray Cumming  <murrayc@murrayc.com>
1283
1284         OnlineGlomService: Return report HTML rather than the LayoutGroup.
1285
1286         * src/main/java/org/glom/web/client/OnlineGlomService.java:
1287         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
1288         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
1289         Change getReportLayout() to getReportHMTL() because we will not need to 
1290         parse or render the report layout on the client side.
1291         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
1292         getReportLayout(): Return the libglom LayoutGroup type because we will
1293         not need to convert to a shared type, because this will not be used on
1294         the client side.
1295         * src/main/java/org/glom/web/client/activity/ReportActivity.java:
1296         Adapted.
1297
1298         Note that there is still no implementation for this.
1299
1300
1301 2012-01-27  Murray Cumming  <murrayc@murrayc.com>
1302
1303         Add a (empty) Report Place, View, and Activity.
1304
1305         * src/main/java/org/glom/web/client/place/HasSelectableTablePlace.java:
1306         Rename to:
1307         * src/main/java/org/glom/web/client/place/HasTablePlace.java
1308         * src/main/java/org/glom/web/client/place/ListPlace.java: Move some of
1309         this into a superclass:
1310         * src/main/java/org/glom/web/client/place/HasRecordsPlace.java
1311         and also use it as the base of this new ReportPlace:
1312         * src/main/java/org/glom/web/client/place/ReportPlace.java
1313
1314         * src/main/java/org/glom/web/client/ui/ReportView.java
1315         * src/main/java/org/glom/web/client/ui/ReportViewImpl.java
1316         * src/main/java/org/glom/web/client/activity/ReportActivity.java:
1317         Add these, containing mostly boiler-plate for now.
1318
1319         * src/main/java/org/glom/web/client/OnlineGlomService.java
1320         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java
1321         * src/main/java/org/glom/web/server/ConfiguredDocument.java
1322         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
1323         Add API to get the LayoutGroup for the report.
1324
1325 2012-01-23  Murray Cumming  <murrayc@murrayc.com>
1326
1327         Add and fill a Reports drop-down list box.
1328
1329         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
1330         Aded getReports():
1331         * src/main/java/org/glom/web/client/OnlineGlomService.java:
1332         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
1333         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
1334         Added getReports(document, table, localeID), calling 
1335         ConfiguredDocument.getReports().
1336         * src/main/java/org/glom/web/client/ui/TableSelectionView.java:
1337         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
1338         Added setReportsList() and a list widget.
1339         * src/main/java/org/glom/web/client/activity/TableSelectionActivity
1340         .java (TableSelectionActivity.fillView(): Fill the view's reports list.
1341
1342
1343 1.21.8:
1344
1345 2012-04-12  Murray Cumming  <murrayc@murrayc.com>
1346
1347         Translations: Add Esperanto.
1348
1349         * src/main/java/org/glom/web/OnlineGlom.gwt.xml
1350         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_eo.
1351         properties: Add this translation because someone took the time to make it.
1352
1353 2012-03-15  Murray Cumming  <murrayc@murrayc.com>
1354
1355         Adapt to the java-libglom 1.21.7 API. 
1356
1357         * src/main/java/org/glom/web/server/ReportGenerator.java:
1358         addToReport(): get_group_secondary_fields() is now
1359         get_secondary_fields().
1360
1361
1362 2012-03-15  Murray Cumming  <murrayc@murrayc.com>
1363
1364         Use the latest java-libglom version.
1365
1366         * pom.xml: Use java-libglom 1.21.7.
1367
1368 2012-03-03  Ben Konrath  <ben@bagu.org>
1369
1370         Display date and time in details view.
1371
1372         https://bugzilla.gnome.org/show_bug.cgi?id=671257
1373
1374         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java:
1375
1376 2012-03-05  Murray Cumming  <murrayc@murrayc.com>
1377
1378         Require the latest java-libglom.
1379
1380         * pom.xml: java-libglom 1.21.5 has LayoutItem_GroupBy.
1381
1382 2012-03-04  Murray Cumming  <murrayc@murrayc.com>
1383
1384         ListViewDbAccess.getSelectQuery(): Avoid using empty quickfind strings.
1385
1386         * src/main/java/org/glom/web/server/database/ListViewDBAccess.java
1387         ListViewDBAccess.getSelectQuery(): Do not create a where clause for 
1388         an empty quickfind string. I also corrected libglom to create only 
1389         empty where clauses for empty quickfind strings, but this avoids the
1390         need for that fix.
1391
1392 2012-02-24  Ben Konrath  <ben@bagu.org>
1393
1394         Improve the tabs in the Notebook widget.
1395
1396         Bug #670728
1397
1398 2012-01-30  Murray Cumming  <murrayc@murrayc.com>
1399
1400         Translations: Try to translate the strings.
1401
1402         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_cs.properties:
1403         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_de.properties:
1404         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_es.properties:
1405         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_sl.properties:
1406         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_zh_CN.properties:
1407         Take the Open translation from GTK+'s .po files.
1408         Take the Details translation from Glom's po files.
1409         I have added the other strings to Glom so we can get translations that way:
1410         http://git.gnome.org/browse/glom/commit/?id=c3cefe607428a84bdf8de1b04e8bef6f70b04564
1411
1412 2012-01-27  Murray Cumming  <murrayc@murrayc.com>
1413
1414         TableSelectionViewImpl: Put the search label and entry in a div.
1415
1416         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
1417         Put the search widgets in a FlowTable so that the CSS can be used to
1418         style them while keeping them together.
1419         * src/main/webapp/style.css: Mention the new div.
1420
1421 2012-01-27  Murray Cumming  <murrayc@murrayc.com>
1422
1423         Translate more strings in more locales.
1424
1425         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants.properties:
1426         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java:
1427         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
1428         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
1429         Translate the "Details" and "Open" string too.
1430
1431         * src/main/java/org/glom/web/OnlineGlom.gwt.xml:
1432         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants.properties:
1433         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_cs.properties:
1434         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_es.properties:
1435         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_sl.properties:
1436         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_zh_CN.properties:
1437         Add these new locales as placeholders though they currently contain English.
1438
1439 2012-01-27  Murray Cumming  <murrayc@murrayc.com>
1440
1441         OnlineGlomServiceImpl: Avoid (unlikely) null object dereferences.
1442
1443         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: get*():
1444         Check the ConfiguredDocument* for null before using it.
1445
1446 2012-01-26  Murray Cumming  <murrayc@murrayc.com>
1447
1448         Tell Eclipse about the generated java files.
1449
1450         * .classpath: This lets it find OnlineGlomConstants.java.
1451         It would be nice if Eclipse just used the maven build files.
1452
1453 2012-01-26  Murray Cumming  <murrayc@murrayc.com>
1454
1455         Prevent a crash when no locale is specified in the URL.
1456
1457         * src/main/java/org/glom/web/client/Utils.java: getCurrentLocaleID():
1458         Avoid returning a null string, obtained from 
1459         Window.Location.getParameter(). This caused a crash when it was
1460         later passed to libglom's API.
1461         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
1462         init(), getDocumentInfo(), getListViewLayout(), getDocuments(),
1463         getDetailsLayoutAndData(): Use StringUtils.defaultString() to
1464         guard against future null strings.
1465
1466 2012-01-26  Murray Cumming  <murrayc@murrayc.com>
1467
1468         Use the ?locale= query param instead of the &lang= token param. 
1469
1470         * src/main/java/org/glom/web/client/place/ListPlace.java
1471         * src/main/java/org/glom/web/client/place/DetailsPlace.java
1472         * src/main/java/org/glom/web/client/place/HasSelectableTablePlace.java
1473         Remove the lang token key and value.
1474         
1475         * src/main/java/org/glom/web/client/ui/TableSelectionView.java
1476         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
1477         When the user selects a different locale from the chooser, use 
1478         Window.Location.assign() to change the URL, which then causes a reload.
1479         
1480         * src/main/java/org/glom/web/client/Utils.java: Added getCurrentLocaleID().
1481         * src/main/java/org/glom/web/client/activity/DetailsActivity.java
1482         * src/main/java/org/glom/web/client/activity/DocumentSelectionActivity.java
1483         * src/main/java/org/glom/web/client/activity/ListActivity.java
1484         * src/main/java/org/glom/web/client/activity/TableSelectionActivity
1485         * src/main/java/org/glom/web/client/ui/DocumentSelectionView.java
1486         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.java:
1487         * src/main/java/org/glom/web/client/ui/ListView.java:
1488         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
1489
1490         Remove localeID member variables and method/constructor parameters, instead
1491         using Utils.getCurrentLocaleID() when we need a localID to pass to 
1492         OnlineGlomService.
1493
1494 2012-01-26  Murray Cumming  <murrayc@murrayc.com>
1495
1496         Internationalize the UI strings.
1497
1498         * pom.xml: gwt-maven-plugin: Add the i18n goal and specify a 
1499         <i18nConstantsBundle>, removing the unused <i18nMessagesBundle>.
1500         * src/main/resources/org/glom/web/client/Messages.properties: Remove this
1501         because it is unused. Messages are apparently strings that can have 
1502         parameters, but we do not need that yet, so Contants will be enough for now.
1503         * src/main/java/org/glom/web/OnlineGlom.gwt.xml: Add extend-property lines
1504         to say that we support the en and de locales.
1505         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants.properties:
1506         The original English strings.
1507         * src/main/resources/org/glom/web/client/ui/OnlineGlomConstants_de.properties:
1508         Some German translations of the English strings.
1509         The i18n goal then uses the .properties file to generate an 
1510         OnlineGlomConstants.java file in target/ and somehow GWT.create() magically
1511         returns an implementation that returns the translated strings.
1512         The documentation suggests putting these in src/java/*/client/, but it seems
1513         best to put it in src/resources/*/client/.
1514         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
1515         Instantiate OnlineGlomConstants via GWT.create() and use it to get the strings
1516         instead of hard-coding them.
1517         Note that we cannot import OnlineGlomConstants because it does not exist yet,
1518         but that does not seem to stop the build, though it confuses Eclipse.
1519         
1520         You can see the translated string by adding ?locale=de to the URL, like so:
1521         http://127.0.0.1:8888/OnlineGlom.html?gwt.codesvr=127.0.0.1:9997?locale=de#list:document=film_manager
1522
1523 2012-01-24  Murray Cumming  <murrayc@murrayc.com>
1524
1525         Improve null/empty String checks. 
1526
1527         * pom.xml: Add a dependency on commons-lang, to use
1528         org.apache.commons.lang.StringUtils.
1529         * src/main/java/org/glom/web/server/ConfiguredDocument.java
1530         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java
1531         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java
1532         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
1533         Use StringUtils.isEmpty().
1534
1535         * src/main/java/org/glom/web/client/StringUtils.java: Add a tiny
1536         StringUtils class with a static isEmpty() function because we 
1537         cannot use org.apache.commons.lang.StringUtils in client-side
1538         GWT code because it (apparently) cannot be compiled to javascript.
1539         * src/main/java/org/glom/web/client/activity/DetailsActivity.java
1540         * src/main/java/org/glom/web/client/activity/ListActivity.java
1541         * src/main/java/org/glom/web/client/activity/TableSelectionActivity.java
1542         * src/main/java/org/glom/web/client/place/DetailsPlace.java
1543         * src/main/java/org/glom/web/client/place/HasSelectableTablePlace.java
1544         * src/main/java/org/glom/web/client/place/ListPlace.java
1545         * src/main/java/org/glom/web/client/ui/cell/NumericCell.java
1546         * src/main/java/org/glom/web/client/ui/cell/TextCell.java
1547         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java
1548         * src/main/java/org/glom/web/client/ui/details/Group.java
1549         * src/main/java/org/glom/web/client/ui/details/Notebook.java: Use 
1550         our StringUtils.isEmpty() function.
1551
1552 2012-01-24  Murray Cumming  <murrayc@murrayc.com>
1553
1554         Update to the latest java-libglom API.
1555
1556         * pom.xml: Require java-libglom 1.21.4.
1557         * src/main/java/org/glom/web/server/ConfiguredDocument.java
1558         getDocumentInfo(), getListViewLayoutGroup():
1559         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java
1560         getDocuments():
1561         * src/main/java/org/glom/web/server/database/DBAccess.java
1562         getFieldsToShowForSQLQueryAddGroup(),
1563         getPrimaryKeyLayoutItemField(): Replace get_database_title()
1564         with either get_database_title_original() or 
1565         get_database_title(localeID).
1566
1567 2012-01-24  Murray Cumming  <murrayc@murrayc.com>
1568
1569         ConfiguredDocument: Avoid a null pointer exception.
1570
1571         * src/main/java/org/glom/web/server/ConfiguredDocument.java
1572         Initialize localeID to "" to avoid returning a null String which 
1573         causes a crash in java-libglom's swing-generated code.
1574
1575 2012-01-23  Murray Cumming  <murrayc@murrayc.com>
1576
1577         Some simple renaming.
1578
1579         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java
1580         * src/main/webapp/style.css: Rename, tableChooser to tablesChooser. Likewise
1581         for localeChooser. This seems more appropriate and is less ambiguous 
1582         particularly in the .css file.
1583
1584 2012-01-23  Murray Cumming  <murrayc@murrayc.com>
1585
1586         ConfiguredDocument: Rename the localedID private member variable.
1587
1588 2012-01-23  Murray Cumming  <murrayc@murrayc.com>
1589
1590         Adapt to the latest java-libglom API from git master.
1591
1592         * src/main/java/org/glom/web/server/database/ListDBAccess.java:
1593         libglom now uses only Vector instead of List, which uses add() instead of
1594         addLast(). 
1595
1596 2012-01-22  Murray Cumming  <murrayc@murrayc.com>
1597
1598         ConfiguredDocument: Rename the localedID private member variable.
1599
1600 2012-01-20  Murray Cumming  <murrayc@murrayc.com>
1601
1602         Build a source tarball with mvn assembly:single
1603
1604         * assembly.xml: Add this file.
1605         * pom.xml: Use the maven-assembly-plugin and tell it to use 
1606         our assembly.xml file.
1607
1608 2012-01-19  Murray Cumming  <murrayc@murrayc.com>
1609
1610         OnlineGlomServiceImpl: Get .glom files recursively.
1611
1612         * pom.xml: Depend on commons-io from org.apache.commons.
1613         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java
1614         init(): Use org.apache.commons.io.FileUtils.listFiles() to get the 
1615         files recursively, and with the easier filter for the extension.
1616         Use org.apache.commons.io.FilenameUtils.removeExtension() to 
1617         simplify that code too.
1618
1619 2012-01-19  Murray Cumming  <murrayc@murrayc.com>
1620
1621         README: Mention that you must install java-libglom packages separately.
1622
1623         But then it works, because java-libglom is now in the central maven 
1624         repository.
1625
1626 2012-01-18  Murray Cumming  <murrayc@murrayc.com>
1627
1628         locales drop-down: Show the correct selected locale when the URL changes.
1629
1630         * src/main/java/org/glom/web/client/activity/TableSelectionActivity
1631         .java: setPlace(): Move some code into fillView().
1632
1633 2012-01-18  Murray Cumming  <murrayc@murrayc.com>
1634
1635         locales drop-down: Do not lose the primary key.
1636
1637         * src/main/java/org/glom/web/client/activity/DetailsActivity.java
1638         start(): onLocaleChange(): Pass the current primary key value, 
1639         instead of an empty value.
1640
1641 2012-01-18  Murray Cumming  <murrayc@murrayc.com>
1642
1643         locales drop-down: Do not lose the drop-down selection.
1644
1645         * src/main/java/org/glom/web/client/activity/TableSelectionActivity
1646         .java (TableSelectionActivity.fillView): Set the selected locale
1647         after changing the drop-down items (though we do not really need
1648         to change them just because the locale changes.)
1649
1650 2012-01-18  Murray Cumming  <murrayc@murrayc.com>
1651
1652         locales drop-down: Change the tables list when this changes.
1653
1654         * src/main/java/org/glom/web/client/activity/TableSelectionActivity
1655         .java: TableSelectionActivity.start(): Move the async table titles
1656         retrieval into a private fillView() method and also call this when 
1657         the chosen locale changes.
1658         Note that the document title is not actually translatable yet, but
1659         that is a problem that I should fix soon in libglom.
1660
1661 2012-01-18  Murray Cumming  <murrayc@murrayc.com>
1662
1663         Improve the placement of the locales drop-down.
1664
1665         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java
1666         Put the title and locales drop-down in a div (gwt.FlowTable).
1667         * src/main/webapp/style.css: Add magic css properties to make this work.
1668         Also remove the left margin from the title so that it lines up with the 
1669         headerbox below it.
1670
1671 2012-01-18  Murray Cumming  <murrayc@murrayc.com>
1672
1673         locales selector: Show human-readable locale titles.
1674
1675         * src/main/java/org/glom/web/server/ConfiguredDocument.java
1676         getDocumentInfo(): Use java.util.Locale to show a real title of 
1677         each locale, in the locale's own language.
1678
1679 2012-01-17  Murray Cumming  <murrayc@murrayc.com>
1680
1681         Add a language/locale selector drop-down.
1682
1683         * src/main/java/org/glom/web/shared/DocumentInfo.java:
1684         Add getLocaleIDs(), setLocaleIDs(), getLocaleTitles(), setLocaleTitles().
1685         * /src/main/java/org/glom/web/server/ConfiguredDocument.java:
1686         getDocumentInfo(): Store the available Locales in the DocumentInfo.
1687         * src/main/java/org/glom/web/client/ui/TableSelectionView.java:
1688         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
1689         Add a ListBox to show the available locales. Add getLocaleSelector(),
1690         setLocaleList(), getSelectedLocale(), setSelectedLocale().
1691         * src/main/java/org/glom/web/client/event/LocaleChangeEvent.java
1692         * src/main/java/org/glom/web/client/event/LocaleChangeEventHandler.
1693         java: Add these classes.
1694         * src/main/java/org/glom/web/client/activity/TableSelectionActivity.java:
1695         start(): Fill the locales ListBox. Handle its change event, firing a 
1696         LocaleChangeEvent.
1697         setPlace(): Show the selected locale as specified by the URL token.
1698         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
1699         * src/main/java/org/glom/web/client/activity/ListActivity.java:
1700         Handle LocaleChangeEvent, going to a new *Place with that locale.
1701
1702         The placement of the ListBox is not pretty, and it currently uses the ID
1703         as a title, instead of "English", "Deutsch", "Espanola", etc, but it 
1704         is a start.
1705
1706
1707 2012-01-17  Murray Cumming  <murrayc@murrayc.com>
1708
1709         Search box: Show the search text from the URL token.
1710
1711         * src/main/java/org/glom/web/client/ui/TableSelectionView.java:
1712         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
1713         Add setQuickFindText().
1714         * src/main/java/org/glom/web/client/activity/TableSelectionActivity
1715         .java: setPlace(): Store the queryText if the place is a ListPlace, 
1716         and call TableSelectionView.setQuickFindText().
1717
1718 2012-01-17  Murray Cumming  <murrayc@murrayc.com>
1719
1720         Allow use of translations via, for instance, &lang=de in the URL.
1721
1722         * pom.xml: Use the unstable java-libglom 1.21 version.
1723
1724         * src/main/java/org/glom/web/client/OnlineGlomService.java:
1725         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java
1726         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
1727         init(): Instead of calling TranslatableItem.set_current_locale() 
1728         (now removed), call ConfiguredDocument.setDefaultLocaleID().
1729         However, this is only for default locales, which are not needed to 
1730         change the locale in the URL.
1731         getDocumentInfo(), getListViewLayout(), getSortedListViewData(),
1732         getDetailsData(), getDetailsLayoutAndData(), getRelatedListData(),
1733         getSortedRelatedListData(): Add a localeID parameter, so we can get the 
1734         layout for a particular locale.
1735         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
1736         Add get/setDefaultLocaleID().
1737         getDocumentInfo(), getListViewData(), getRelatedListData(),
1738         getDetailsLayoutGroup(), getListViewLayoutGroup(),
1739         createLayoutItemPortalDTO(), convertToGWTGlomLayoutItemField(): Add a 
1740         localeID parameter, so we can get the layout for a particular locale.
1741
1742         * src/main/java/org/glom/web/client/place/HasSelectableTablePlace.java:
1743         * src/main/java/org/glom/web/client/place/DetailsPlace.java:
1744         * src/main/java/org/glom/web/client/place/ListPlace.java:
1745         Parse and construct a lang parameter too.
1746
1747         * src/main/java/org/glom/web/client/activity/DocumentSelectionActivity.java:
1748         start(): Pass the defaultLocaleID to addDocumentLink(). It is then
1749         passed to subsequent methods and constructors.
1750         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
1751         * src/main/java/org/glom/web/client/activity/ListActivity.java:
1752         Store the localeID from the *Place and pass it to other constructors
1753         and methods, such as OnlineGlomServiceAsync.getDetailsLayoutAndData().
1754
1755         * src/main/java/org/glom/web/client/ui/DocumentSelectionView.java:
1756         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.java:
1757         * src/main/java/org/glom/web/client/ui/TableSelectionView.java
1758         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java
1759         * src/main/java/org/glom/web/client/ui/ListView.java:
1760         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
1761         Take localeID parameters and pass them to subsequent constructors and 
1762         methods, so that the layout is always retrieved for that locale.
1763
1764         This is rather repetitive.
1765
1766         Note that "" means the original (default) locale of the Glom document,
1767         which is usually English.       
1768
1769 2012-01-17  Murray Cumming  <murrayc@murrayc.com>
1770
1771         Documents: Remove final keyword to fix startup configuration.
1772
1773         * src/main/java/org/glom/web/shared/Documents.java: Remove the
1774         final keywords on the private member variables because that breaks
1775         the startup, apparently (there are warnings) because it stops them
1776         from being serialized. I added these in the previous commit.
1777
1778 2012-01-13  Murray Cumming  <murrayc@murrayc.com>
1779
1780         Documents: Add some final keywords.
1781
1782         * src/main/java/org/glom/web/shared/Documents.java: Eclipse suggested
1783         this.
1784
1785 2012-01-13  Murray Cumming  <murrayc@murrayc.com>
1786
1787         OnlineGlomServiceImpl: Add to overview comments.
1788
1789         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
1790         Note that this is where all the document are loaded. They are not 
1791         loaded freshly for each page.
1792
1793 2012-01-12  Murray Cumming  <murrayc@murrayc.com>
1794
1795         Add a search box.
1796
1797         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
1798         Add a TextBox for the text of a quick find.
1799         Add getQuickFindBox(), to get the widget, and getQuickFindText() to 
1800         get the text.
1801         setBackLink(): Add a String quickFind parameter.
1802         * src/main/java/org/glom/web/client/ui/TableSelectionView.java
1803         (TableSelectionView): Add getQuickFindBox() and getQuickFindText()
1804         to the base interface, because that is how TableSelectionViewImpl is used.
1805         * src/main/webapp/style.css: Add style for the search box and its label.
1806
1807         * src/main/java/org/glom/web/client/event/QuickFindChangeEvent.java:
1808         * src/main/java/org/glom/web/client/event/QuickFindChangeEventHandler.java:
1809         Add these files, based on the existing TableChangeEvent and 
1810         TableChangeEventHandlers.
1811         * src/main/java/org/glom/web/client/activity/DetailsActivity.java
1812         start(): Handle QuickFindChangeEvent, passing its quickFind text to
1813         a ListPlace() that the user should be taken to.
1814         * src/main/java/org/glom/web/client/activity/ListActivity.java
1815         start(): Handle it here too and adapt the TableChangeEvent handler to 
1816         pass the extra "" quickFind parameter to ListPlace.
1817         * src/main/java/org/glom/web/client/place/ListPlace.java: 
1818         Constructor: Take an extra String quickFind parameter and store it, 
1819         returning it from a new  getQuickFind() method.
1820         getToken(): Put the quickFind text in the URL token.
1821         getPlace(): Parse the quickFind text from the URL token.
1822         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.ja
1823         va: addDocumentLink(): Pass an extra "" quickFind parameter to the 
1824         ListPlace constructor.
1825         * src/main/java/org/glom/web/client/activity/TableSelectionActivity
1826         .java: start(): Add a Change handler for the TableSelectionView's
1827         TextBox (via its base HasChangeHandlers interface), firing the new 
1828         QuickFindChangeEvent.
1829         setPlace(): Adapt the call to TableSelectionView.setbackLink(), to 
1830         pass the extra "" quickFind parameter.
1831
1832         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
1833         setCellTable(): Add a String quickFind parameter and pass it to 
1834         the ListViewTable() constructor.
1835         * src/main/java/org/glom/web/client/ui/ListView.java: Change 
1836         setCellTable() in the base interface, because that is how ListViewImpl
1837         is used.
1838
1839         * src/main/java/org/glom/web/client/ui/list/ListTable.java:
1840         Add a String quickFind member variable.
1841         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
1842         Constructor: Add a String quickFind parameter, storing it in the
1843         base ListTable's member variable.
1844         onRangeChanged(): Pass quickFind to the 
1845         OnlineGlomServiceAsync.getSortedListViewData() and 
1846         OnlineGlomServiceAsync.getListViewData() methods.
1847
1848         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
1849         getListViewData(), getSortedListViewData(): Add a String quickFind 
1850         parameter, passing it to ConfiguredDocument.getListViewData().
1851         * src/main/java/org/glom/web/client/OnlineGlomService.java:
1852         Change getListViewData(), getSortedListViewData() in the base interface,
1853         because that is how OnlineGlomServiceImpl is used, via this:
1854         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
1855         Change getListViewData(), getSortedListViewData() here too.
1856         This class can apparently be used to asynchronously call methods on 
1857         OnlineGlomService, and GWT seems to implement that after recognizing 
1858         just the *Async name convention and the extra AsyncCallback parameters.
1859
1860         * src/main/java/org/glom/web/server/ConfiguredDocument.java
1861         getListViewData(): Add a String quickFind parameter, and pass it to 
1862         ListViewDBAccess.getData().
1863         * src/main/java/org/glom/web/server/database/ListDBAccess.java
1864         getListData(): Add a String quickFind parameter and pass it to 
1865         getSelectQuery().
1866         getSelectQuery(): Add a String quickFind parameter.
1867         * src/main/java/org/glom/web/server/database/ListViewDBAccess.java
1868         getSelectQuery(): Add a String quickFind parameter and use it with 
1869         Glom.get_find_where_clause_quick() to pass a where_clause to 
1870         Glom.build_sql_select_with_where_clause(), to actually filter the 
1871         list view results.
1872         getData(): Add a String quickFind parameter, passing it to getListData().
1873         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.ja
1874         va: getData(): Pass an empty string to getListData() for the 
1875         quickFind parameter.
1876
1877 2012-01-12  Murray Cumming  <murrayc@murrayc.com>
1878
1879         ListTable: Minor change.
1880
1881         * src/main/java/org/glom/web/client/ui/list/ListTable.java
1882         createCellTable(): Make this protected instead of public.
1883
1884 2012-01-12  Murray Cumming  <murrayc@murrayc.com>
1885
1886         Many files: Use final for the parameters and use the @override attribute.
1887
1888 2012-01-22  Ben Konrath <ben@bagu.org>
1889
1890         Add anchor links for single line text that starts with http, ftp and www.
1891
1892         Bug #667269
1893
1894 2012-01-22  Ben Konrath <ben@bagu.org>
1895
1896         Add ellipsis to single line text in details view.
1897
1898         Bug #667269
1899
1900 2012-01-04  Murray Cumming  <murrayc@murrayc.com>
1901
1902         Remove all javadoc author tags.
1903
1904         Because they are awkward and meaningless when many people touch
1905         many files.
1906         See https://gitorious.org/online-glom/gwt-glom/commit/7628b732cb90cbc6d5635420a75568504e8b3655#comment_81164
1907  
1908 2012-01-04  Murray Cumming  <murrayc@murrayc.com>
1909
1910         Revert the COPYING.LESSER to COPYING rename.
1911
1912         Apparently both should be there if it is LGPL.
1913
1914 2012-01-03  Murray Cumming  <murrayc@murrayc.com>
1915
1916         *View: Remove unused imports.
1917
1918         * src/main/java/org/glom/web/client/ui/DetailsView.java:
1919         * src/main/java/org/glom/web/client/ui/DocumentSelectionView.java
1920         * src/main/java/org/glom/web/client/ui/ListView.java:
1921         * src/main/java/org/glom/web/client/ui/TableSelectionView.java:
1922         Remove unused imports, as suggested by Eclipse.
1923
1924 2012-01-02  Murray Cumming  <murrayc@murrayc.com>
1925
1926         Move the *View::Presenter types, and some API into one base View.
1927
1928         * src/main/java/org/glom/web/client/ui/DetailsView.java:
1929         * src/main/java/org/glom/web/client/ui/DocumentSelectionView.java:
1930         * src/main/java/org/glom/web/client/ui/ListView.java:
1931         * src/main/java/org/glom/web/client/ui/TableSelectionView.java: Move
1932         Presenter, setPresenter() and clear() into a shared base interface,
1933         to avoid the unnecessary duplicate Presenter types and to more clearly
1934         show how the *Views share the same structure, even if they are not 
1935         used polymorphically.
1936
1937         * src/main/java/org/glom/web/client/ui/DetailsViewImpl.java:
1938         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.ja
1939         va:
1940         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
1941         * src/main/java/org/glom/web/client/activity/ListActivity.java:
1942         * src/main/java/org/glom/web/client/activity/DocumentSelectionActiv
1943         ity.java:
1944         * src/main/java/org/glom/web/client/activity/TableSelectionActivity
1945         .java: Adapt.
1946
1947         Feel free to revert this if there is a good reason for the duplicate
1948         types.
1949
1950 2012-01-02  Murray Cumming  <murrayc@murrayc.com>
1951
1952         OnlineGlom: Make clientFactory a (protected) member, and test it a bit.
1953
1954         * src/main/java/org/glom/web/client/OnlineGlom.java: Make clientFactory
1955         a class member instead of a local variable in the method.
1956         This lets us use it to get the view instances, for use in tests.
1957         * src/test/java/org/glom/web/client/GwtTestOnlineGlom.java:
1958         beforeOnlineGlom(): Test some more details of the initial view.
1959         Again, this is not very useful.
1960
1961         To really test gwt-glom we will need to start a local postgresql 
1962         instance with local data, like the Glom tests in C++.
1963
1964 2012-01-02  Murray Cumming  <murrayc@murrayc.com>
1965
1966         pom.xml: Mention the LGPL license.
1967
1968         * pom.xml: Add a licenses section.
1969         * COPYING.LESSER: Move this to COPYING, which
1970         previously contained the GPL. But gwt-glom is all LGPL.
1971
1972 2012-01-02  Murray Cumming  <murrayc@murrayc.com>
1973
1974         Add project information to README and pom.xml.
1975
1976         * README: Add a brief description and mention some mvn
1977         commands.
1978         * pom.xml: This extra information shows up in mvn site
1979         generated pages.
1980
1981 2011-01-02  Murray Cumming  <murrayc@murrayc.com>
1982
1983         Use the latest java-libglom version.
1984
1985         * pom.xml: Use java-libglom 1.19.2 instead of 1.19.1.
1986
1987 2012-01-01  Murray Cumming  <murrayc@murrayc.com>
1988
1989         GwtTestOnlineGlom: Test a little more.
1990
1991         * src/main/java/org/glom/web/client/OnlineGlom.java: Make the panels
1992         protected rather than private, as suggested by the gwt-test-utils
1993         maintianer here:
1994         http://stackoverflow.com/questions/7931724/gwt-testcase-simulating-clicking-a-button-on-my-page
1995         * src/test/java/org/glom/web/client/GwtTestOnlineGlom.java
1996         Test the initial visibility of the panels.
1997
1998         However, this is not a very useful test.
1999         And I wonder how we should generally test using this idea for an
2000         activity/places app like ours where the real changes happen implicitly
2001         based on the history token/URL.
2002
2003 2012-01-01  Murray Cumming  <murrayc@murrayc.com>
2004
2005         Slight modification to *Mapper comments.
2006
2007         * src/main/java/org/glom/web/client/mvp/DataActivityMapper.java
2008         (DataActivityMapper)
2009         * src/main/java/org/glom/web/client/mvp/DocumentSelectionActivityMa
2010         pper.java
2011         * src/main/java/org/glom/web/client/mvp/TableSelectionActivityMappe
2012         r.java
2013         Remove comments mentioning GIN because they are just copied from 
2014         the example code and are apparently not helpful:
2015         http://groups.google.com/group/google-web-toolkit/msg/82f0098b20669a73
2016         Also change the mention of a class that is only in the example code.
2017
2018 2012-01-01  Murray Cumming  <murrayc@murrayc.com>
2019
2020         GwtTestOnlineGlom test: Minor changes.
2021
2022         * src/test/java/org/glom/web/client/GwtTestOnlineGlom.java:
2023         Avoid the long qualified class name and modify the comment 
2024         because it is now obvious to me that the mocked class is the only
2025         custom one created via GWT.create().
2026
2027 2012-01-01  Murray Cumming  <murrayc@murrayc.com>
2028
2029         Tests: Added the beginnings of a test using gwt-test-utils.
2030
2031         * pom.xml: Add dependencies on gwt-test-utils and easymock.
2032         * src/test/resources/META-INF/gwt-test-utils.properties: Add this file
2033         which tells gwt-test-utils what class will be tested.
2034         * src/test/java/org/glom/web/client/GwtTestOnlineGlom.java:
2035         Add a simple (but empty) test case. One class, used by the OnlineGlom
2036         class, is mocked so that it can be created. However, I am not sure 
2037         why only this class needs to be mocked.
2038
2039         Note that mockito seems more popular, and clearer, than easymock,
2040         but I have not got that working yet. It might be a matter of the 
2041         mockito version.
2042
2043         This test is run during mvn integration-test.
2044
2045 2011-12-31  Murray Cumming  <murrayc@murrayc.com>
2046
2047         Tests: Use junit4-style syntax instead of junit3-style.
2048
2049         * src/test/java/org/glom/web/client/place/DetailsPlaceTest.java:
2050         * src/test/java/org/glom/web/client/place/ListPlaceTest.java:
2051         * src/test/java/org/glom/web/shared/DataItemTest.java:
2052         Use the @Test annotation rather than relying on the test*() prefix.
2053         Also no longer implement TestCase, to avoid triggering support for 
2054         the junit3-way, which stops the annotations from working.
2055         Change the imports from import junit.framework.* to 
2056         import org.junit.*, which is apparently the new way.
2057
2058 2011-12-31  Murray Cumming  <murrayc@murrayc.com>
2059
2060         Added a test for ListPlace token parsing and creation.
2061
2062         * src/test/java/org/glom/web/client/place/ListPlaceTest.java:
2063         This is much the same as DetailsPlaceTest.
2064
2065         I wonder how we could test the other parts of the *Place API.
2066
2067 2011-12-30  Murray Cumming  <murrayc@murrayc.com>
2068
2069         DetailsPlace test: Also test getToken() and recreation via getPlace().
2070
2071         * src/test/java/org/glom/web/client/place/DetailsPlaceTest.java:
2072         testGetPlaceParameters(): Get the tokens from the DetailsPlace and 
2073         recreate it, testing the recreated DetailsPlace for the same parameter
2074         values.
2075
2076 2011-12-30  Murray Cumming  <murrayc@murrayc.com>
2077
2078         Use the surefire-report plugin.
2079
2080         * pom.xml: This generates a HTML report about the tests in 
2081         target/site/surefire-report.html
2082         when you do mvn surefire-report:report. It seems to be popular/normal.
2083
2084 2011-12-30  Murray Cumming  <murrayc@murrayc.com>
2085
2086         Added a test for DetailsPlace.
2087
2088         * src/test/java/org/glom/web/client/place/DetailsPlaceTest.java:
2089         Test the getPlace() token parsing.
2090
2091 2011-12-30  Murray Cumming  <murrayc@murrayc.com>
2092
2093         Added a first unit test.
2094
2095         * pom.xml: Add a test goal, and a dependency on junit in that scope.
2096         * src/test/java/org/glom/web/shared/DataItemTest.java:
2097         This is a silly test but it is just to get things started. Note that
2098         maven/junit finds the test because it looks in src/test by default.
2099
2100 2011-12-22  Ben Konrath  <ben@bagu.org>
2101
2102         Change charsetName to "UTF-8" when replacing line breaks.
2103
2104         JavaScript requires the charsetName to be "UTF-8". CharsetName values
2105         that work in Java (such as "UTF8") will not work when compiled to
2106         JavaScript.
2107
2108         This fixes a problem with multi-line details view fields that have hard
2109         line breaks. The "License Text" field on this page demonstrates the
2110         problem:
2111
2112         http://onlineglom.openismus.com/OnlineGlom/#details:document=debian_repository_analyzer&table=licenses&value=197
2113
2114         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java:
2115
2116 2011-12-22  Ben Konrath  <ben@bagu.org>
2117
2118         Fix another bug with related list navigation.
2119
2120         I've tested all the navigation buttons in all of the related lists
2121         so things should be good now.
2122
2123         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
2124
2125 2011-12-22  Ben Konrath  <ben@bagu.org>
2126
2127         Fix a crasher when refreshing the list view with the default table.
2128
2129         This crash will also happen when loading the list view with the default
2130         table from a link or bookmark.
2131
2132         * src/main/java/org/glom/web/client/activity/DetailsActivity.java: Go
2133         to the main document selection page when the document id hasn't been
2134         set.
2135         * src/main/java/org/glom/web/client/activity/ListActivity.java: Go to
2136         the main document selection page when the document id hasn't been
2137         set.
2138         * src/main/java/org/glom/web/client/place/DetailsPlace.java: Use empty
2139         values for the details place when the document id hasn't been set.
2140         * src/main/java/org/glom/web/client/place/ListPlace.java: Use empty
2141         values for the list place when the document id hasn't been set.
2142
2143 2011-12-21  Ben Konrath  <ben@bagu.org>
2144
2145         Protect against NPE when glom.document.locale is not in config.
2146
2147         This patch protects against an NPE when glom.document.locale is not in
2148         the config file. This NPE will also happen if glom.document.locale is
2149         commented out.
2150
2151         The patch also updates the error message to display the class name when
2152         the getMessage() returns null. This was happening when the NPE was
2153         thrown and I had "Configuration Error: null". If an NPE is encountered
2154         with this patch, "Configuration Error: NullPointerException " will be
2155         displayed.
2156
2157         This commit closes this bug:
2158
2159         https://bugzilla.gnome.org/show_bug.cgi?id=666669
2160
2161         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2162
2163 2011-12-20  Murray Cumming  <murrayc@murrayc.com>
2164
2165         Rename onlineglom.properties to onlineglom.properties.sample.
2166
2167         * src/main/resources/onlineglom.properties: Rename to:
2168         * src/main/resources/onlineglom.properties.sample:
2169         * src/main/resources/README: And add this file explaining that people
2170         should rename it back when deploying.
2171
2172 2011-12-20  Murray Cumming  <murrayc@murrayc.com>
2173
2174         Allow choosing the translation in the .properties file.
2175
2176         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java
2177         init(): Read a glom.document.locale value from the configuration file 
2178         and call Glom's TransatableItem::set_current_locale() method.
2179         * src/main/resources/onlineglom.properties: Add a commented-out 
2180         example of this new setting.
2181
2182         It would be better to add &lang=de_DE to the URL, but the current 
2183         libglom API does not allow us to do this easily. I am working on that.
2184
2185 2011-12-19  Murray Cumming  <murrayc@murrayc.com>
2186
2187         Avoid a crash in parsing of token parameters.
2188
2189         * src/main/java/org/glom/web/client/place/HasSelectableTablePlace.j
2190         ava: getTokenParams(): Do not crash if a parameter has a key but no 
2191         value, and ignore parameters with neither.
2192
2193 2011-12-17  Murray Cumming  <murrayc@murayc.com>
2194
2195         History token building/handling: Improve use of token parameters.
2196
2197         * src/main/java/org/glom/web/client/place/HasSelectableTablePlace.java 
2198         (HasSelectableTablePlace.Tokenizer): Add getTokenParams(String)
2199         and buildParamsToken(HashMap), for use by derived classes.
2200         Make the separator private because it is no longer be needed.
2201         * src/main/java/org/glom/web/client/place/DetailsPlace.java
2202         (DetailsPlace.Tokenizer.getToken): Use buildParamsToken()
2203         instead of manual string concatenation.
2204         (DetailsPlace.Tokenizer.getPlace): Use getTokenParams() instead 
2205         of hardcoded indices and awkward splitting code.
2206         * src/main/java/org/glom/web/client/place/ListPlace.java
2207         (ListPlace.Tokenizer.getToken): Use buildParamsToken()
2208         instead of manual string concatenation.
2209         (ListPlace.Tokenizer.getPlace): Use getTokenParams() instead 
2210         of hardcoded indices and awkward splitting code.
2211         This should fix bug #666420
2212
2213 2011-12-16  Murray Cumming  <murrayc@murrayc.com>
2214
2215         Fix a Navgiation->Navigation typo in the code.
2216
2217         * src/main/java/org/glom/web/client/activity/DetailsActivity.java
2218         Rename processNavgiation() to processNavigation().
2219
2220 2011-12-16  Murray Cumming  <murrayc@murrayc.com>
2221
2222         Fix a seperator->separator typo in the code.
2223
2224         * src/main/java/org/glom/web/client/place/DetailsPlace.java
2225         * src/main/java/org/glom/web/client/place/HasSelectableTablePlace.java
2226         * src/main/java/org/glom/web/client/place/ListPlace.java: Just a 
2227         misspelling.
2228
2229 2011-12-15  Ben Konrath <ben@bagu.org>
2230
2231         Cleanup some comments.
2232
2233         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2234
2235 2011-12-14  Ben Konrath <ben@bagu.org>
2236
2237         Replace \n with <br/> for multiline text in the details view.
2238
2239         Vertical scrollbars are added when needed as well.
2240
2241         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java:
2242
2243 2011-12-14  Ben Konrath <ben@bagu.org>
2244
2245         Specify the font for document selection links.
2246
2247         * src/main/webapp/style.css:
2248
2249 2011-12-14  Ben Konrath <ben@bagu.org>
2250
2251         Fix bouncy CellTable while paging.
2252
2253         This doesn't currently work with related list tables in unselected
2254         Notebook tabs.
2255
2256         * src/main/java/org/glom/web/client/ui/list/ListTable.java
2257
2258 2011-12-14  Ben Konrath <ben@bagu.org>
2259
2260         Revamp the appearance of the document selection page.
2261
2262         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.java:
2263         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.ui.xml:
2264         * src/main/webapp/style.css:
2265
2266 2011-12-13  Ben Konrath <ben@bagu.org>
2267
2268         Set navigation button column to the smallest size possible.
2269
2270         * src/main/java/org/glom/web/client/ui/list/ListTable.java:
2271
2272 2011-12-13  Ben Konrath <ben@bagu.org>
2273
2274         Change OpenButton nomenclature to NavigationButton.
2275
2276         Using NavigtionButton makes things more generic. Classes, methods and
2277         variables have been changed.
2278
2279         This is a rename-only refactor.
2280
2281         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
2282         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
2283         * src/main/java/org/glom/web/client/ui/cell/NavigationButtonCell.java:
2284         Renamed from OpenButtonCell.
2285         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
2286         * src/main/java/org/glom/web/client/ui/list/ListTable.java:
2287         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
2288
2289 2011-12-12  Ben Konrath <ben@bagu.org>
2290
2291         Remove unnecessary String argument in RelatedListTable and ListViewTable.
2292
2293         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
2294         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
2295         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
2296         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
2297
2298 2011-12-12  Ben Konrath <ben@bagu.org>
2299
2300         Update variable names and comments.
2301
2302         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
2303         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
2304
2305 2011-12-12  Ben Konrath <ben@bagu.org>
2306
2307         Properly initialize numNonEmptyRows variable to zero.
2308
2309         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
2310         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
2311
2312 2011-12-05  Ben Konrath  <ben@bagu.org>
2313
2314         Add latest mockup with HTML tables.
2315
2316         Features of this mockup:
2317
2318         -> HTML table for flowtable
2319         -> HTML table for flowtable column
2320         -> Example of how related lists would look
2321         -> Not using text entries for data items
2322
2323         The current version of Online Glom doesn't use HTML tables for the
2324         flowtable columns.
2325
2326         This mockup has been sent to the glom-devel mailing list but it's good
2327         to have it here as well.
2328
2329         * mockups/details-view-html-tables.html:
2330
2331 2011-12-05  Ben Konrath  <ben@bagu.org>
2332
2333         Remove unnecessary getPrimaryKeyField() method.
2334
2335         getPrimaryKeyFieldForTable(String) has been renamed to
2336         getPrimaryKeyField(String).
2337
2338         * src/main/java/org/glom/web/server/database/DBAccess.java:
2339         * src/main/java/org/glom/web/server/database/DetailsDBAccess.java:
2340         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
2341
2342 2011-12-05  Ben Konrath  <ben@bagu.org>
2343
2344         Add string representation of TypedDataItem value to conversion error message.
2345
2346         * src/main/java/org/glom/web/server/Utils.java: Logging the error
2347         message was extracted into its own method to avoid duplication.
2348
2349 2011-12-05  Ben Konrath  <ben@bagu.org>
2350
2351         Add type checking to navigation primary key value creation.
2352
2353         Create navigation primary key only if the expected type from the Glom
2354         document matches the type returned by the SQL query.
2355
2356         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
2357
2358 2011-12-05  Ben Konrath  <ben@bagu.org>
2359
2360         Rename a couple of variables in RelatedListNavigation.
2361
2362         This is a rename-only refactor.
2363
2364         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
2365
2366 2011-12-05  Ben Konrath  <ben@bagu.org>
2367
2368         Move getListLayoutGroup() into getListViewLayoutGroup().
2369
2370         This removes getListLayoutGroup(). It was only being called by
2371         getListViewLayoutGroup().
2372
2373         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
2374
2375 2011-12-05  Ben Konrath  <ben@bagu.org>
2376
2377         Remove check for LayoutItem_Portal in list table method.
2378
2379         This check is no longer necessary because the method isn't being used
2380         to create the LayoutItemPortal DTO.
2381
2382         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
2383
2384 2011-12-05  Ben Konrath  <ben@bagu.org>
2385
2386         Properly support related list navigation.
2387
2388         Navigation from the "Repository Analyzer -> Package Scans ->
2389         Dependencies" related table wasn't working because the primary key for
2390         related tables wasn't being set properly. This commit fixes the
2391         problem.
2392
2393         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Don't use
2394         getListLayoutGroup() to create the LayoutItemPortal DTO. This method
2395         doesn't set the primary key properly for related list tables.
2396         * src/main/java/org/glom/web/server/database/DBAccess.java: Add table
2397         name parameter to getPrimaryKeyLayoutItemField(). This makes the method
2398         useful for getting the primary key for list view tables and for related
2399         list tables.
2400         * src/main/java/org/glom/web/server/database/ListDBAccess.java:
2401         * src/main/java/org/glom/web/server/database/ListViewDBAccess.java:
2402         Move code to set the primary key for the table from the abstract
2403         ListDBAccess class to ListViewDBAccess as it's only correct for list
2404         view tables.
2405         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
2406         Properly add primary key to related list tables.
2407
2408 2011-12-02  Ben Konrath  <ben@bagu.org>
2409
2410         Properly set the horizontal alignment of fields.
2411
2412         This fix is for both the list tables and the details view.
2413
2414         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Use
2415         LayoutItem_WithFormatting.get_formatting_used_horizontal_alignment(boolean)
2416         to set the horizontal alignment of fields.
2417
2418 2011-12-02  Ben Konrath  <ben@bagu.org>
2419
2420         Display currency codes in the details view.
2421
2422         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java:
2423
2424 2011-12-02  Ben Konrath  <ben@bagu.org>
2425
2426         Avoid duplicate JNI call.
2427
2428         JNI is not as efficient as pure Java and this is an easy (and small)
2429         optimization.
2430
2431         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
2432         Use previously retrieved value for whereClauseToTableName instead of
2433         getting it again.
2434
2435 2011-12-02  Ben Konrath  <ben@bagu.org>
2436
2437         Rename a couple of variables in RelatedListNavigation.
2438
2439         This is a rename-only refactor.
2440
2441         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
2442
2443 2011-12-02  Ben Konrath  <ben@bagu.org>
2444
2445         Indicate clearly that a mismatched primary key type is a bug.
2446
2447         * src/main/java/org/glom/web/server/Utils.java: Change log level from
2448         warning to error. Add 'This is a bug.' to message.
2449
2450 2011-12-02  Ben Konrath  <ben@bagu.org>
2451
2452         Update / fix some comments.
2453
2454         * src/main/java/org/glom/web/client/OnlineGlomService.java: Remove old
2455         comments.
2456         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java: Fix
2457         comment.
2458         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
2459         Fix comments. Add some TODOs.
2460
2461 2011-12-02  Ben Konrath  <ben@bagu.org>
2462
2463         Enable navigation to details view with string primary key from related list.
2464
2465         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
2466         Create a text primary key value when return type of result is
2467         java.sql.Types.VARCHAR.
2468
2469 2011-12-02  Ben Konrath  <ben@bagu.org>
2470
2471         Use checkboxes for booleans in the details view.
2472
2473         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java:
2474
2475 2011-12-01  Ben Konrath  <ben@bagu.org>
2476
2477         Improve performance of related list height calculation.
2478
2479         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
2480         Put code to calculate the expected height in a static initializer so
2481         that that it's only called once.
2482
2483 2011-12-01  Ben Konrath  <ben@bagu.org>
2484
2485         Show related list tables in notebooks (again).
2486
2487         Calculate the height of the related list tables so the Notebook can be
2488         set the correct height. The height of the related list table is also needed by
2489         FlowTable to be able decide how to create the layout.
2490
2491         * src/main/java/org/glom/web/client/ui/details/Portal.java: Calculate
2492         and set the Portal height based on the height of the related list
2493         table and the Portal container.
2494         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
2495         Add method to calculate the height of the related list tables.
2496         * src/main/java/org/glom/web/client/ui/list/ListTable.java:
2497         * src/main/webapp/style.css: Add css class for Pager. This is needed to
2498         calculate the height of the Pager widget.
2499
2500 2011-12-01  Ben Konrath  <ben@bagu.org>
2501
2502         Use CellTable API for table property instead of setting style on Element.
2503
2504         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
2505
2506 2011-12-01  Ben Konrath  <ben@bagu.org>
2507
2508         Make ListViewTable and RelatedListTable a consistent height.
2509
2510         The tables are now a consistent height regardless of the contents of
2511         the table. A hidden button is added to empty rows to ensure that the
2512         height of these rows will match the height of rows with data.
2513
2514         A navigation button column is now added to every table. The width of
2515         the navigation column is set to 0px when a RelatedListTable shouldn't
2516         have navigation buttons. This maintains the a consistent row height in
2517         tables that don't show the navigation buttons.
2518
2519         * src/main/java/org/glom/web/client/activity/DetailsActivity.java: Hide
2520         navigation column when not needed.
2521         * src/main/java/org/glom/web/client/ui/ListViewImpl.java: Move method
2522         arguments for navigation button to constructor of ListViewTable.
2523         * src/main/java/org/glom/web/client/ui/cell/OpenButtonCell.java: Render
2524         hidden button for empty data rows.
2525         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java: Add method
2526         arguments for navigation button to constructor.
2527         * src/main/java/org/glom/web/client/ui/list/ListTable.java: Always
2528         create navigation buttons. Add hideNavigationButtons() method.
2529         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java: Add method
2530         arguments for navigation button to constructor.
2531
2532 2011-12-01  Ben Konrath  <ben@bagu.org>
2533
2534         Use 'visibility: hidden' in Utils.getWidgetHeight().
2535
2536         This is better choice because hidden elements are invisible, don't
2537         respond to events and are not part of the tab order. They will,
2538         however, 
2539