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