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