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