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