Add a search box.
[online-glom:gwt-glom.git] / ChangeLog
1 2012-01-12  Murray Cumming  <murrayc@murrayc.com>
2
3         Add a search box.
4
5         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
6         Add a TextBox for the text of a quick find.
7         Add getQuickFindBox(), to get the widget, and getQuickFindText() to 
8         get the text.
9         setBackLink(): Add a String quickFind parameter.
10         * src/main/java/org/glom/web/client/ui/TableSelectionView.java
11         (TableSelectionView): Add getQuickFindBox() and getQuickFindText()
12         to the base interface, because that is how TableSelectionViewImpl is used.
13         * src/main/webapp/style.css: Add style for the search box and its label.
14
15         * src/main/java/org/glom/web/client/event/QuickFindChangeEvent.java:
16         * src/main/java/org/glom/web/client/event/QuickFindChangeEventHandler.java:
17         Add these files, based on the existing TableChangeEvent and 
18         TableChangeEventHandlers.
19         * src/main/java/org/glom/web/client/activity/DetailsActivity.java
20         start(): Handle QuickFindChangeEvent, passing its quickFind text to
21         a ListPlace() that the user should be taken to.
22         * src/main/java/org/glom/web/client/activity/ListActivity.java
23         start(): Handle it here too and adapt the TableChangeEvent handler to 
24         pass the extra "" quickFind parameter to ListPlace.
25         * src/main/java/org/glom/web/client/place/ListPlace.java: 
26         Constructor: Take an extra String quickFind parameter and store it, 
27         returning it from a new  getQuickFind() method.
28         getToken(): Put the quickFind text in the URL token.
29         getPlace(): Parse the quickFind text from the URL token.
30         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.ja
31         va: addDocumentLink(): Pass an extra "" quickFind parameter to the 
32         ListPlace constructor.
33         * src/main/java/org/glom/web/client/activity/TableSelectionActivity
34         .java: start(): Add a Change handler for the TableSelectionView's
35         TextBox (via its base HasChangeHandlers interface), firing the new 
36         QuickFindChangeEvent.
37         setPlace(): Adapt the call to TableSelectionView.setbackLink(), to 
38         pass the extra "" quickFind parameter.
39
40         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
41         setCellTable(): Add a String quickFind parameter and pass it to 
42         the ListViewTable() constructor.
43         * src/main/java/org/glom/web/client/ui/ListView.java: Change 
44         setCellTable() in the base interface, because that is how ListViewImpl
45         is used.
46
47         * src/main/java/org/glom/web/client/ui/list/ListTable.java:
48         Add a String quickFind member variable.
49         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
50         Constructor: Add a String quickFind parameter, storing it in the
51         base ListTable's member variable.
52         onRangeChanged(): Pass quickFind to the 
53         OnlineGlomServiceAsync.getSortedListViewData() and 
54         OnlineGlomServiceAsync.getListViewData() methods.
55
56         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
57         getListViewData(), getSortedListViewData(): Add a String quickFind 
58         parameter, passing it to ConfiguredDocument.getListViewData().
59         * src/main/java/org/glom/web/client/OnlineGlomService.java:
60         Change getListViewData(), getSortedListViewData() in the base interface,
61         because that is how OnlineGlomServiceImpl is used, via this:
62         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
63         Change getListViewData(), getSortedListViewData() here too.
64         This class can apparently be used to asynchronously call methods on 
65         OnlineGlomService, and GWT seems to implement that after recognizing 
66         just the *Async name convention and the extra AsyncCallback parameters.
67
68         * src/main/java/org/glom/web/server/ConfiguredDocument.java
69         getListViewData(): Add a String quickFind parameter, and pass it to 
70         ListViewDBAccess.getData().
71         * src/main/java/org/glom/web/server/database/ListDBAccess.java
72         getListData(): Add a String quickFind parameter and pass it to 
73         getSelectQuery().
74         getSelectQuery(): Add a String quickFind parameter.
75         * src/main/java/org/glom/web/server/database/ListViewDBAccess.java
76         getSelectQuery(): Add a String quickFind parameter and use it with 
77         Glom.get_find_where_clause_quick() to pass a where_clause to 
78         Glom.build_sql_select_with_where_clause(), to actually filter the 
79         list view results.
80         getData(): Add a String quickFind parameter, passing it to getListData().
81         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.ja
82         va: getData(): Pass an empty string to getListData() for the 
83         quickFind parameter.
84
85 2012-01-12  Murray Cumming  <murrayc@murrayc.com>
86
87         ListTable: Minor change.
88
89         * src/main/java/org/glom/web/client/ui/list/ListTable.java
90         createCellTable(): Make this protected instead of public.
91
92 2012-01-12  Murray Cumming  <murrayc@murrayc.com>
93
94         Many files: Use final for the parameters and use the @override attribute.
95
96 2012-01-22  Ben Konrath <ben@bagu.org>
97
98         Add anchor links for single line text that starts with http, ftp and www.
99
100         Bug #667269
101
102 2012-01-22  Ben Konrath <ben@bagu.org>
103
104         Add ellipsis to single line text in details view.
105
106         Bug #667269
107
108 2012-01-04  Murray Cumming  <murrayc@murrayc.com>
109
110         Remove all javadoc author tags.
111
112         Because they are awkward and meaningless when many people touch
113         many files.
114         See https://gitorious.org/online-glom/gwt-glom/commit/7628b732cb90cbc6d5635420a75568504e8b3655#comment_81164
115  
116 2012-01-04  Murray Cumming  <murrayc@murrayc.com>
117
118         Revert the COPYING.LESSER to COPYING rename.
119
120         Apparently both should be there if it is LGPL.
121
122 2012-01-03  Murray Cumming  <murrayc@murrayc.com>
123
124         *View: Remove unused imports.
125
126         * src/main/java/org/glom/web/client/ui/DetailsView.java:
127         * src/main/java/org/glom/web/client/ui/DocumentSelectionView.java
128         * src/main/java/org/glom/web/client/ui/ListView.java:
129         * src/main/java/org/glom/web/client/ui/TableSelectionView.java:
130         Remove unused imports, as suggested by Eclipse.
131
132 2012-01-02  Murray Cumming  <murrayc@murrayc.com>
133
134         Move the *View::Presenter types, and some API into one base View.
135
136         * src/main/java/org/glom/web/client/ui/DetailsView.java:
137         * src/main/java/org/glom/web/client/ui/DocumentSelectionView.java:
138         * src/main/java/org/glom/web/client/ui/ListView.java:
139         * src/main/java/org/glom/web/client/ui/TableSelectionView.java: Move
140         Presenter, setPresenter() and clear() into a shared base interface,
141         to avoid the unnecessary duplicate Presenter types and to more clearly
142         show how the *Views share the same structure, even if they are not 
143         used polymorphically.
144
145         * src/main/java/org/glom/web/client/ui/DetailsViewImpl.java:
146         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.ja
147         va:
148         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
149         * src/main/java/org/glom/web/client/activity/ListActivity.java:
150         * src/main/java/org/glom/web/client/activity/DocumentSelectionActiv
151         ity.java:
152         * src/main/java/org/glom/web/client/activity/TableSelectionActivity
153         .java: Adapt.
154
155         Feel free to revert this if there is a good reason for the duplicate
156         types.
157
158 2012-01-02  Murray Cumming  <murrayc@murrayc.com>
159
160         OnlineGlom: Make clientFactory a (protected) member, and test it a bit.
161
162         * src/main/java/org/glom/web/client/OnlineGlom.java: Make clientFactory
163         a class member instead of a local variable in the method.
164         This lets us use it to get the view instances, for use in tests.
165         * src/test/java/org/glom/web/client/GwtTestOnlineGlom.java:
166         beforeOnlineGlom(): Test some more details of the initial view.
167         Again, this is not very useful.
168
169         To really test gwt-glom we will need to start a local postgresql 
170         instance with local data, like the Glom tests in C++.
171
172 2012-01-02  Murray Cumming  <murrayc@murrayc.com>
173
174         pom.xml: Mention the LGPL license.
175
176         * pom.xml: Add a licenses section.
177         * COPYING.LESSER: Move this to COPYING, which
178         previously contained the GPL. But gwt-glom is all LGPL.
179
180 2012-01-02  Murray Cumming  <murrayc@murrayc.com>
181
182         Add project information to README and pom.xml.
183
184         * README: Add a brief description and mention some mvn
185         commands.
186         * pom.xml: This extra information shows up in mvn site
187         generated pages.
188
189 2011-01-02  Murray Cumming  <murrayc@murrayc.com>
190
191         Use the latest java-libglom version.
192
193         * pom.xml: Use java-libglom 1.19.2 instead of 1.19.1.
194
195 2012-01-01  Murray Cumming  <murrayc@murrayc.com>
196
197         GwtTestOnlineGlom: Test a little more.
198
199         * src/main/java/org/glom/web/client/OnlineGlom.java: Make the panels
200         protected rather than private, as suggested by the gwt-test-utils
201         maintianer here:
202         http://stackoverflow.com/questions/7931724/gwt-testcase-simulating-clicking-a-button-on-my-page
203         * src/test/java/org/glom/web/client/GwtTestOnlineGlom.java
204         Test the initial visibility of the panels.
205
206         However, this is not a very useful test.
207         And I wonder how we should generally test using this idea for an
208         activity/places app like ours where the real changes happen implicitly
209         based on the history token/URL.
210
211 2012-01-01  Murray Cumming  <murrayc@murrayc.com>
212
213         Slight modification to *Mapper comments.
214
215         * src/main/java/org/glom/web/client/mvp/DataActivityMapper.java
216         (DataActivityMapper)
217         * src/main/java/org/glom/web/client/mvp/DocumentSelectionActivityMa
218         pper.java
219         * src/main/java/org/glom/web/client/mvp/TableSelectionActivityMappe
220         r.java
221         Remove comments mentioning GIN because they are just copied from 
222         the example code and are apparently not helpful:
223         http://groups.google.com/group/google-web-toolkit/msg/82f0098b20669a73
224         Also change the mention of a class that is only in the example code.
225
226 2012-01-01  Murray Cumming  <murrayc@murrayc.com>
227
228         GwtTestOnlineGlom test: Minor changes.
229
230         * src/test/java/org/glom/web/client/GwtTestOnlineGlom.java:
231         Avoid the long qualified class name and modify the comment 
232         because it is now obvious to me that the mocked class is the only
233         custom one created via GWT.create().
234
235 2012-01-01  Murray Cumming  <murrayc@murrayc.com>
236
237         Tests: Added the beginnings of a test using gwt-test-utils.
238
239         * pom.xml: Add dependencies on gwt-test-utils and easymock.
240         * src/test/resources/META-INF/gwt-test-utils.properties: Add this file
241         which tells gwt-test-utils what class will be tested.
242         * src/test/java/org/glom/web/client/GwtTestOnlineGlom.java:
243         Add a simple (but empty) test case. One class, used by the OnlineGlom
244         class, is mocked so that it can be created. However, I am not sure 
245         why only this class needs to be mocked.
246
247         Note that mockito seems more popular, and clearer, than easymock,
248         but I have not got that working yet. It might be a matter of the 
249         mockito version.
250
251         This test is run during mvn integration-test.
252
253 2011-12-31  Murray Cumming  <murrayc@murrayc.com>
254
255         Tests: Use junit4-style syntax instead of junit3-style.
256
257         * src/test/java/org/glom/web/client/place/DetailsPlaceTest.java:
258         * src/test/java/org/glom/web/client/place/ListPlaceTest.java:
259         * src/test/java/org/glom/web/shared/DataItemTest.java:
260         Use the @Test annotation rather than relying on the test*() prefix.
261         Also no longer implement TestCase, to avoid triggering support for 
262         the junit3-way, which stops the annotations from working.
263         Change the imports from import junit.framework.* to 
264         import org.junit.*, which is apparently the new way.
265
266 2011-12-31  Murray Cumming  <murrayc@murrayc.com>
267
268         Added a test for ListPlace token parsing and creation.
269
270         * src/test/java/org/glom/web/client/place/ListPlaceTest.java:
271         This is much the same as DetailsPlaceTest.
272
273         I wonder how we could test the other parts of the *Place API.
274
275 2011-12-30  Murray Cumming  <murrayc@murrayc.com>
276
277         DetailsPlace test: Also test getToken() and recreation via getPlace().
278
279         * src/test/java/org/glom/web/client/place/DetailsPlaceTest.java:
280         testGetPlaceParameters(): Get the tokens from the DetailsPlace and 
281         recreate it, testing the recreated DetailsPlace for the same parameter
282         values.
283
284 2011-12-30  Murray Cumming  <murrayc@murrayc.com>
285
286         Use the surefire-report plugin.
287
288         * pom.xml: This generates a HTML report about the tests in 
289         target/site/surefire-report.html
290         when you do mvn surefire-report:report. It seems to be popular/normal.
291
292 2011-12-30  Murray Cumming  <murrayc@murrayc.com>
293
294         Added a test for DetailsPlace.
295
296         * src/test/java/org/glom/web/client/place/DetailsPlaceTest.java:
297         Test the getPlace() token parsing.
298
299 2011-12-30  Murray Cumming  <murrayc@murrayc.com>
300
301         Added a first unit test.
302
303         * pom.xml: Add a test goal, and a dependency on junit in that scope.
304         * src/test/java/org/glom/web/shared/DataItemTest.java:
305         This is a silly test but it is just to get things started. Note that
306         maven/junit finds the test because it looks in src/test by default.
307
308 2011-12-22  Ben Konrath  <ben@bagu.org>
309
310         Change charsetName to "UTF-8" when replacing line breaks.
311
312         JavaScript requires the charsetName to be "UTF-8". CharsetName values
313         that work in Java (such as "UTF8") will not work when compiled to
314         JavaScript.
315
316         This fixes a problem with multi-line details view fields that have hard
317         line breaks. The "License Text" field on this page demonstrates the
318         problem:
319
320         http://onlineglom.openismus.com/OnlineGlom/#details:document=debian_repository_analyzer&table=licenses&value=197
321
322         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java:
323
324 2011-12-22  Ben Konrath  <ben@bagu.org>
325
326         Fix another bug with related list navigation.
327
328         I've tested all the navigation buttons in all of the related lists
329         so things should be good now.
330
331         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
332
333 2011-12-22  Ben Konrath  <ben@bagu.org>
334
335         Fix a crasher when refreshing the list view with the default table.
336
337         This crash will also happen when loading the list view with the default
338         table from a link or bookmark.
339
340         * src/main/java/org/glom/web/client/activity/DetailsActivity.java: Go
341         to the main document selection page when the document id hasn't been
342         set.
343         * src/main/java/org/glom/web/client/activity/ListActivity.java: Go to
344         the main document selection page when the document id hasn't been
345         set.
346         * src/main/java/org/glom/web/client/place/DetailsPlace.java: Use empty
347         values for the details place when the document id hasn't been set.
348         * src/main/java/org/glom/web/client/place/ListPlace.java: Use empty
349         values for the list place when the document id hasn't been set.
350
351 2011-12-21  Ben Konrath  <ben@bagu.org>
352
353         Protect against NPE when glom.document.locale is not in config.
354
355         This patch protects against an NPE when glom.document.locale is not in
356         the config file. This NPE will also happen if glom.document.locale is
357         commented out.
358
359         The patch also updates the error message to display the class name when
360         the getMessage() returns null. This was happening when the NPE was
361         thrown and I had "Configuration Error: null". If an NPE is encountered
362         with this patch, "Configuration Error: NullPointerException " will be
363         displayed.
364
365         This commit closes this bug:
366
367         https://bugzilla.gnome.org/show_bug.cgi?id=666669
368
369         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
370
371 2011-12-20  Murray Cumming  <murrayc@murrayc.com>
372
373         Rename onlineglom.properties to onlineglom.properties.sample.
374
375         * src/main/resources/onlineglom.properties: Rename to:
376         * src/main/resources/onlineglom.properties.sample:
377         * src/main/resources/README: And add this file explaining that people
378         should rename it back when deploying.
379
380 2011-12-20  Murray Cumming  <murrayc@murrayc.com>
381
382         Allow choosing the translation in the .properties file.
383
384         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java
385         init(): Read a glom.document.locale value from the configuration file 
386         and call Glom's TransatableItem::set_current_locale() method.
387         * src/main/resources/onlineglom.properties: Add a commented-out 
388         example of this new setting.
389
390         It would be better to add &lang=de_DE to the URL, but the current 
391         libglom API does not allow us to do this easily. I am working on that.
392
393 2011-12-19  Murray Cumming  <murrayc@murrayc.com>
394
395         Avoid a crash in parsing of token parameters.
396
397         * src/main/java/org/glom/web/client/place/HasSelectableTablePlace.j
398         ava: getTokenParams(): Do not crash if a parameter has a key but no 
399         value, and ignore parameters with neither.
400
401 2011-12-17  Murray Cumming  <murrayc@murayc.com>
402
403         History token building/handling: Improve use of token parameters.
404
405         * src/main/java/org/glom/web/client/place/HasSelectableTablePlace.java 
406         (HasSelectableTablePlace.Tokenizer): Add getTokenParams(String)
407         and buildParamsToken(HashMap), for use by derived classes.
408         Make the separator private because it is no longer be needed.
409         * src/main/java/org/glom/web/client/place/DetailsPlace.java
410         (DetailsPlace.Tokenizer.getToken): Use buildParamsToken()
411         instead of manual string concatenation.
412         (DetailsPlace.Tokenizer.getPlace): Use getTokenParams() instead 
413         of hardcoded indices and awkward splitting code.
414         * src/main/java/org/glom/web/client/place/ListPlace.java
415         (ListPlace.Tokenizer.getToken): Use buildParamsToken()
416         instead of manual string concatenation.
417         (ListPlace.Tokenizer.getPlace): Use getTokenParams() instead 
418         of hardcoded indices and awkward splitting code.
419         This should fix bug #666420
420
421 2011-12-16  Murray Cumming  <murrayc@murrayc.com>
422
423         Fix a Navgiation->Navigation typo in the code.
424
425         * src/main/java/org/glom/web/client/activity/DetailsActivity.java
426         Rename processNavgiation() to processNavigation().
427
428 2011-12-16  Murray Cumming  <murrayc@murrayc.com>
429
430         Fix a seperator->separator typo in the code.
431
432         * src/main/java/org/glom/web/client/place/DetailsPlace.java
433         * src/main/java/org/glom/web/client/place/HasSelectableTablePlace.java
434         * src/main/java/org/glom/web/client/place/ListPlace.java: Just a 
435         misspelling.
436
437 2011-12-15  Ben Konrath <ben@bagu.org>
438
439         Cleanup some comments.
440
441         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
442
443 2011-12-14  Ben Konrath <ben@bagu.org>
444
445         Replace \n with <br/> for multiline text in the details view.
446
447         Vertical scrollbars are added when needed as well.
448
449         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java:
450
451 2011-12-14  Ben Konrath <ben@bagu.org>
452
453         Specify the font for document selection links.
454
455         * src/main/webapp/style.css:
456
457 2011-12-14  Ben Konrath <ben@bagu.org>
458
459         Fix bouncy CellTable while paging.
460
461         This doesn't currently work with related list tables in unselected
462         Notebook tabs.
463
464         * src/main/java/org/glom/web/client/ui/list/ListTable.java
465
466 2011-12-14  Ben Konrath <ben@bagu.org>
467
468         Revamp the appearance of the document selection page.
469
470         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.java:
471         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.ui.xml:
472         * src/main/webapp/style.css:
473
474 2011-12-13  Ben Konrath <ben@bagu.org>
475
476         Set navigation button column to the smallest size possible.
477
478         * src/main/java/org/glom/web/client/ui/list/ListTable.java:
479
480 2011-12-13  Ben Konrath <ben@bagu.org>
481
482         Change OpenButton nomenclature to NavigationButton.
483
484         Using NavigtionButton makes things more generic. Classes, methods and
485         variables have been changed.
486
487         This is a rename-only refactor.
488
489         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
490         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
491         * src/main/java/org/glom/web/client/ui/cell/NavigationButtonCell.java:
492         Renamed from OpenButtonCell.
493         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
494         * src/main/java/org/glom/web/client/ui/list/ListTable.java:
495         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
496
497 2011-12-12  Ben Konrath <ben@bagu.org>
498
499         Remove unnecessary String argument in RelatedListTable and ListViewTable.
500
501         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
502         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
503         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
504         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
505
506 2011-12-12  Ben Konrath <ben@bagu.org>
507
508         Update variable names and comments.
509
510         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
511         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
512
513 2011-12-12  Ben Konrath <ben@bagu.org>
514
515         Properly initialize numNonEmptyRows variable to zero.
516
517         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
518         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
519
520 2011-12-05  Ben Konrath  <ben@bagu.org>
521
522         Add latest mockup with HTML tables.
523
524         Features of this mockup:
525
526         -> HTML table for flowtable
527         -> HTML table for flowtable column
528         -> Example of how related lists would look
529         -> Not using text entries for data items
530
531         The current version of Online Glom doesn't use HTML tables for the
532         flowtable columns.
533
534         This mockup has been sent to the glom-devel mailing list but it's good
535         to have it here as well.
536
537         * mockups/details-view-html-tables.html:
538
539 2011-12-05  Ben Konrath  <ben@bagu.org>
540
541         Remove unnecessary getPrimaryKeyField() method.
542
543         getPrimaryKeyFieldForTable(String) has been renamed to
544         getPrimaryKeyField(String).
545
546         * src/main/java/org/glom/web/server/database/DBAccess.java:
547         * src/main/java/org/glom/web/server/database/DetailsDBAccess.java:
548         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
549
550 2011-12-05  Ben Konrath  <ben@bagu.org>
551
552         Add string representation of TypedDataItem value to conversion error message.
553
554         * src/main/java/org/glom/web/server/Utils.java: Logging the error
555         message was extracted into its own method to avoid duplication.
556
557 2011-12-05  Ben Konrath  <ben@bagu.org>
558
559         Add type checking to navigation primary key value creation.
560
561         Create navigation primary key only if the expected type from the Glom
562         document matches the type returned by the SQL query.
563
564         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
565
566 2011-12-05  Ben Konrath  <ben@bagu.org>
567
568         Rename a couple of variables in RelatedListNavigation.
569
570         This is a rename-only refactor.
571
572         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
573
574 2011-12-05  Ben Konrath  <ben@bagu.org>
575
576         Move getListLayoutGroup() into getListViewLayoutGroup().
577
578         This removes getListLayoutGroup(). It was only being called by
579         getListViewLayoutGroup().
580
581         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
582
583 2011-12-05  Ben Konrath  <ben@bagu.org>
584
585         Remove check for LayoutItem_Portal in list table method.
586
587         This check is no longer necessary because the method isn't being used
588         to create the LayoutItemPortal DTO.
589
590         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
591
592 2011-12-05  Ben Konrath  <ben@bagu.org>
593
594         Properly support related list navigation.
595
596         Navigation from the "Repository Analyzer -> Package Scans ->
597         Dependencies" related table wasn't working because the primary key for
598         related tables wasn't being set properly. This commit fixes the
599         problem.
600
601         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Don't use
602         getListLayoutGroup() to create the LayoutItemPortal DTO. This method
603         doesn't set the primary key properly for related list tables.
604         * src/main/java/org/glom/web/server/database/DBAccess.java: Add table
605         name parameter to getPrimaryKeyLayoutItemField(). This makes the method
606         useful for getting the primary key for list view tables and for related
607         list tables.
608         * src/main/java/org/glom/web/server/database/ListDBAccess.java:
609         * src/main/java/org/glom/web/server/database/ListViewDBAccess.java:
610         Move code to set the primary key for the table from the abstract
611         ListDBAccess class to ListViewDBAccess as it's only correct for list
612         view tables.
613         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
614         Properly add primary key to related list tables.
615
616 2011-12-02  Ben Konrath  <ben@bagu.org>
617
618         Properly set the horizontal alignment of fields.
619
620         This fix is for both the list tables and the details view.
621
622         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Use
623         LayoutItem_WithFormatting.get_formatting_used_horizontal_alignment(boolean)
624         to set the horizontal alignment of fields.
625
626 2011-12-02  Ben Konrath  <ben@bagu.org>
627
628         Display currency codes in the details view.
629
630         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java:
631
632 2011-12-02  Ben Konrath  <ben@bagu.org>
633
634         Avoid duplicate JNI call.
635
636         JNI is not as efficient as pure Java and this is an easy (and small)
637         optimization.
638
639         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
640         Use previously retrieved value for whereClauseToTableName instead of
641         getting it again.
642
643 2011-12-02  Ben Konrath  <ben@bagu.org>
644
645         Rename a couple of variables in RelatedListNavigation.
646
647         This is a rename-only refactor.
648
649         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
650
651 2011-12-02  Ben Konrath  <ben@bagu.org>
652
653         Indicate clearly that a mismatched primary key type is a bug.
654
655         * src/main/java/org/glom/web/server/Utils.java: Change log level from
656         warning to error. Add 'This is a bug.' to message.
657
658 2011-12-02  Ben Konrath  <ben@bagu.org>
659
660         Update / fix some comments.
661
662         * src/main/java/org/glom/web/client/OnlineGlomService.java: Remove old
663         comments.
664         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java: Fix
665         comment.
666         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
667         Fix comments. Add some TODOs.
668
669 2011-12-02  Ben Konrath  <ben@bagu.org>
670
671         Enable navigation to details view with string primary key from related list.
672
673         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
674         Create a text primary key value when return type of result is
675         java.sql.Types.VARCHAR.
676
677 2011-12-02  Ben Konrath  <ben@bagu.org>
678
679         Use checkboxes for booleans in the details view.
680
681         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java:
682
683 2011-12-01  Ben Konrath  <ben@bagu.org>
684
685         Improve performance of related list height calculation.
686
687         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
688         Put code to calculate the expected height in a static initializer so
689         that that it's only called once.
690
691 2011-12-01  Ben Konrath  <ben@bagu.org>
692
693         Show related list tables in notebooks (again).
694
695         Calculate the height of the related list tables so the Notebook can be
696         set the correct height. The height of the related list table is also needed by
697         FlowTable to be able decide how to create the layout.
698
699         * src/main/java/org/glom/web/client/ui/details/Portal.java: Calculate
700         and set the Portal height based on the height of the related list
701         table and the Portal container.
702         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
703         Add method to calculate the height of the related list tables.
704         * src/main/java/org/glom/web/client/ui/list/ListTable.java:
705         * src/main/webapp/style.css: Add css class for Pager. This is needed to
706         calculate the height of the Pager widget.
707
708 2011-12-01  Ben Konrath  <ben@bagu.org>
709
710         Use CellTable API for table property instead of setting style on Element.
711
712         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
713
714 2011-12-01  Ben Konrath  <ben@bagu.org>
715
716         Make ListViewTable and RelatedListTable a consistent height.
717
718         The tables are now a consistent height regardless of the contents of
719         the table. A hidden button is added to empty rows to ensure that the
720         height of these rows will match the height of rows with data.
721
722         A navigation button column is now added to every table. The width of
723         the navigation column is set to 0px when a RelatedListTable shouldn't
724         have navigation buttons. This maintains the a consistent row height in
725         tables that don't show the navigation buttons.
726
727         * src/main/java/org/glom/web/client/activity/DetailsActivity.java: Hide
728         navigation column when not needed.
729         * src/main/java/org/glom/web/client/ui/ListViewImpl.java: Move method
730         arguments for navigation button to constructor of ListViewTable.
731         * src/main/java/org/glom/web/client/ui/cell/OpenButtonCell.java: Render
732         hidden button for empty data rows.
733         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java: Add method
734         arguments for navigation button to constructor.
735         * src/main/java/org/glom/web/client/ui/list/ListTable.java: Always
736         create navigation buttons. Add hideNavigationButtons() method.
737         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java: Add method
738         arguments for navigation button to constructor.
739
740 2011-12-01  Ben Konrath  <ben@bagu.org>
741
742         Use 'visibility: hidden' in Utils.getWidgetHeight().
743
744         This is better choice because hidden elements are invisible, don't
745         respond to events and are not part of the tab order. They will,
746         however, take up space which is required to be able to calculate the
747         height of the widget.
748
749         * src/main/java/org/glom/web/client/Utils.java:
750
751 2011-12-01  Ben Konrath  <ben@bagu.org>
752
753         Use Utils.getWidgetHeight() in FlowTable.
754
755         * src/main/java/org/glom/web/client/Utils.java: Remove TODO item about
756         this.
757         * src/main/java/org/glom/web/client/ui/details/FlowTable.java:
758
759 2011-12-01  Ben Konrath  <ben@bagu.org>
760
761         Put the details css class name on the correct table column.
762
763         * src/main/java/org/glom/web/client/ui/list/ListTable.java:
764
765 2011-11-30  Ben Konrath  <ben@bagu.org>
766
767         Update for java-libglom API change.
768
769         The getters and setters on FieldFormatting and NumericFormat were
770         changed to remove the 'M'.
771
772         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
773
774 2011-11-29  Ben Konrath  <ben@bagu.org>
775
776         Only allow RelatedListTables in Portals.
777
778         * src/main/java/org/glom/web/client/ui/details/Portal.java:
779
780 2011-11-29  Ben Konrath  <ben@bagu.org>
781
782         Only create a contents panel for Portals when title is being set.
783
784         * src/main/java/org/glom/web/client/ui/details/Portal.java:
785
786 2011-11-29  Ben Konrath  <ben@bagu.org>
787
788         Set TabLayoutPanel height based on calculated height its widgets.
789
790         This is a potential fix for this bug:
791
792         https://bugzilla.gnome.org/show_bug.cgi?id=665133
793
794         * src/main/java/org/glom/web/client/ui/details/Notebook.java:
795
796 2011-11-29  Ben Konrath  <ben@bagu.org>
797
798         Align details field labels and data with the Open buttons.
799
800         * src/main/webapp/style.css:
801
802 2011-11-29  Ben Konrath  <ben@bagu.org>
803
804         Remove unnecessary <div> in the Notebook widget.
805
806         * src/main/java/org/glom/web/client/ui/details/Group.java: Remove
807         method to get container FlowPanel (<div>).
808         * src/main/java/org/glom/web/client/ui/details/Notebook.java: Run the
809         initWidget() method directly on the TabLayoutPanel widget instead of
810         Group's container widget.
811
812 2011-11-29  Ben Konrath  <ben@bagu.org>
813
814         Don't add group titles for Portals in Notebooks.
815
816         This reverts the previous patch and fixes a bug I introduced with
817         commit b1753fd27bd2c4ea189c4c353e0ece92dcc66c2c .
818
819         * src/main/java/org/glom/web/client/ui/details/Group.java:
820         * src/main/java/org/glom/web/client/ui/details/Portal.java:
821
822 2011-11-28  Ben Konrath  <ben@bagu.org>
823
824         Remove unused boolean argument in Portal constructor.
825
826         Just a code cleanup.
827
828         * src/main/java/org/glom/web/client/ui/details/Group.java:
829         * src/main/java/org/glom/web/client/ui/details/Portal.java:
830
831 2011-11-28  Ben Konrath  <ben@bagu.org>
832
833         Remove hack for glom 1.18 style glom files.
834
835         * src/main/java/org/glom/web/client/ui/details/Group.java:
836         * src/main/java/org/glom/web/client/ui/details/Notebook.java:
837         * src/main/java/org/glom/web/client/ui/details/Portal.java:
838
839 2011-11-28  Ben Konrath  <ben@bagu.org>
840
841         Use Gda Value version of primary key to log result too large error.
842
843         * src/main/java/org/glom/web/server/database/DetailsDBAccess.java:
844
845 2011-11-28  Ben Konrath  <ben@bagu.org>
846
847         Don't use TypedDataItem.getText() for Unknown types from the URL.
848
849         * src/main/java/org/glom/web/client/place/DetailsPlace.java:
850         * src/main/java/org/glom/web/server/Utils.java: Use getUnknown()
851         instead of getText().
852         * src/main/java/org/glom/web/shared/TypedDataItem.java: Add unknown
853         String field and getUnknown() method.
854
855 2011-11-28  Ben Konrath  <ben@bagu.org>
856
857         Log an error message when the java-libglom .so is not present.
858
859         The error message was being set in the exception but not logged.
860
861         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
862
863 2011-11-28  Ben Konrath  <ben@bagu.org>
864
865         Ignore LayoutItem_CalendarPortals.
866
867         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Don't
868         create the LayoutItemPortal DTO for LayoutItem_CanendarPortals.
869
870 2011-11-28  Ben Konrath  <ben@bagu.org>
871
872         Extract method for creating the LayoutItemPortal DTO.
873
874         Just breaking the code up into smaller chunks.
875
876         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
877
878 2011-11-28  Ben Konrath  <ben@bagu.org>
879
880         Add TypedDataItem.
881
882         This should have been added with the refactor. Oops!
883
884         * src/main/java/org/glom/web/shared/TypedDataItem.java:
885
886 2011-11-28  Ben Konrath  <ben@bagu.org>
887
888         Create primary key value from URL string using type from Glom document.
889
890         See this bug, comments 19 - 25:
891
892         https://bugzilla.gnome.org/show_bug.cgi?id=662376#c19
893
894         * src/main/java/org/glom/web/client/place/DetailsPlace.java: Don't
895         create a TypeDataItem for the primary key here when loading from a
896         URL. Show the same string for the primary key value as was received
897         from the URL string (when loading from a URL).
898         * src/main/java/org/glom/web/server/Utils.java: Update method for
899         creating the Gda Value from the TypeDataItem to properly deal with
900         creating a Gda Value based on the Glom document type for the primary
901         key value string when loading from a URL.
902         * src/main/java/org/glom/web/server/database/DetailsDBAccess.java:
903         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
904         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
905         Update for changed method name.
906
907 2011-11-27  Ben Konrath  <ben@bagu.org>
908
909         Rename PrimaryKeyItem to TypedDataItem.
910
911         The name PrimaryKeyItem suggests what the class should be used for.
912         TypedDataItem is a neutral name that describes the class better.
913
914         This is a rename-only refactor.
915
916         * src/main/java/org/glom/web/client/OnlineGlomService.java:
917         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
918         * src/main/java/org/glom/web/client/Utils.java:
919         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
920         * src/main/java/org/glom/web/client/place/DetailsPlace.java:
921         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
922         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
923         * src/main/java/org/glom/web/client/ui/list/ListTable.java:
924         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
925         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
926         * src/main/java/org/glom/web/server/Utils.java:
927         * src/main/java/org/glom/web/server/database/DetailsDBAccess.java:
928         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
929         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
930         * src/main/java/org/glom/web/shared/NavigationRecord.java:
931
932 2011-11-25  Ben Konrath  <ben@bagu.org>
933
934         Improve Gda Value conversion from PrimaryKeyItem.
935
936         The value from the PrimaryKeyItem is only used if its type match the
937         type from the glom document.
938
939         * src/main/java/org/glom/web/server/Utils.java:
940
941 2011-11-25  Ben Konrath  <ben@bagu.org>
942
943         Manually check if the java-liblgom .so is visible to the JVM.
944
945         It seems that Tomcat has problems when a static initializer throws an
946         exception. This check is done before the first method call into
947         java-libglom so that execution doesn't continue if the .so is not
948         found.
949
950         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
951
952 2011-11-25  Ben Konrath  <ben@bagu.org>
953
954         Improve browser configuration error messages.
955
956         This fixes:
957
958         https://bugzilla.gnome.org/show_bug.cgi?id=662792
959
960         * src/main/java/org/glom/web/client/OnlineGlomService.java:
961         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java: Add
962         getConfigurationErrorMessage() method.
963         * src/main/java/org/glom/web/client/activity/DocumentSelectionActivity.java:
964         Get and display a specific configuration error message when no Glom
965         documents are found.
966         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
967         Implement getConfigurationErrorMessage() method. Surround configuration
968         code in the init() method with a try/catch block. This allows the
969         errors to be caught while keeping the servlet available to retrieve the
970         configuration error message.
971
972 2011-11-25  Ben Konrath  <ben@bagu.org>
973
974         Don't use Strings to hold primary key values.
975
976         The primary key values are now held in a new data object
977         (PrimaryKeyItem) that holds type information and the primary key value
978         using the correct type.
979
980         * src/main/java/org/glom/web/client/OnlineGlomService.java:
981         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
982         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Use
983         PrimaryKeyItem instead of String to hold the primary key value.
984         * src/main/java/org/glom/web/client/Utils.java: Remove
985         getKeyValueStringForQuery(). Add getPrimaryKeyItem() which creates a
986         PrimaryKeyItem based on the GlomFieldType and the DataItem.
987         * src/main/java/org/glom/web/client/activity/DetailsActivity.java: Use
988         PrimaryKeyItem instead of String to hold the primary key value. Load
989         document selection page when the documentID has not been set correctly.
990         * src/main/java/org/glom/web/client/place/DetailsPlace.java: Re-work
991         DetailsPlace -> URL and URL -> DetailsPlace conversion with
992         PrimaryKeyItem.
993         * src/main/java/org/glom/web/client/place/DocumentSelectionPlace.java:
994         Return empty string for URL instead of "null".
995         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
996         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
997         * src/main/java/org/glom/web/client/ui/list/ListTable.java:
998         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Use
999         PrimaryKeyItem instead of String to hold primary key values.
1000         * src/main/java/org/glom/web/server/Utils.java: New method to convert a
1001         PrimaryKeyValue to a Gda Value.
1002         * src/main/java/org/glom/web/server/database/DetailsDBAccess.java:
1003         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
1004         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
1005         Replace temporary database access code that uses the PrimaryKeyValue to
1006         Gda Value conversion.
1007         * src/main/java/org/glom/web/shared/DataItem.java: Add comment.
1008         * src/main/java/org/glom/web/shared/NavigationRecord.java: Use
1009         PrimaryKeyItem instead of String.
1010         * src/main/java/org/glom/web/shared/PrimaryKeyItem.java: New class to
1011         hold primary key values.
1012
1013 2011-11-24  Ben Konrath  <ben@bagu.org>
1014
1015         Use newly added java-libglom API to create queries.
1016
1017         This isn't finished. I still need to stop using Strings for primary key
1018         values in the client code.
1019
1020         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Tell
1021         libglom to use fake connections so that retrieving the query string will
1022         work.
1023         * src/main/java/org/glom/web/server/database/DetailsDBAccess.java:
1024         * src/main/java/org/glom/web/server/database/ListViewDBAccess.java:
1025         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
1026         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
1027         Use the newly added libglom sql methods and classes to create the
1028         query. Add temporary hack to convert primary value strings to Gda
1029         Value.
1030
1031 2011-11-23  Ben Konrath  <ben@bagu.org>
1032
1033         Don't explicitly set the height of Portals.
1034
1035         See comments 6 - 10 of this bug for details:
1036
1037         https://bugzilla.gnome.org/show_bug.cgi?id=662930#c6
1038
1039         * src/main/java/org/glom/web/client/ui/details/Portal.java:
1040
1041 2011-11-23  Ben Konrath  <ben@bagu.org>
1042
1043         Use an HTML table instead of CSS for the FlowTable layout.
1044
1045         * src/main/java/org/glom/web/client/ui/details/FlowTable.java: Use
1046         GWT's FlexTable to implement the FlowTable.
1047         * src/main/webapp/style.css: Adjust CSS for the change to FlexTable.
1048
1049 2011-11-18  Ben Konrath  <ben@bagu.org>
1050
1051         Add boolean example to HTML table mockup.
1052
1053         * mockups/details-view-html-tables-text-entries.html:
1054
1055 2011-11-17  Ben Konrath  <ben@bagu.org>
1056
1057         Ensure the pager buttons are always visible for related lists.
1058
1059         To accomplish this, I've turned off text wrapping in the list view and
1060         related list tables for both the header and data text. The related list
1061         table now has a fixed layout so the it doesn't overflow its container.
1062         This is required to ensure that the cell text is clipped when it
1063         overflows the cell and an ellipsis is added to the right side of the
1064         cell when text is clipped.
1065
1066         A fixed table layout for the related list table in the details view
1067         seems what we want for the details view anyway, so the side-effect is
1068         desirable.
1069
1070         The ellipsis will only be displayed in Firefox >= 7.
1071
1072         This fixes bug:
1073
1074         https://bugzilla.gnome.org/show_bug.cgi?id=662930
1075
1076         * src/main/java/org/glom/web/client/ui/cell/NumericCell.java:
1077         * src/main/java/org/glom/web/client/ui/cell/TextCell.java: Add
1078         'overflow: hidden; text-overflow: ellipsis;' CSS properties to the table
1079         cell text.
1080         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
1081         Set the 'table-layout: fixed' CSS property to the related list table.
1082         * src/main/java/org/glom/web/client/ui/list/ListTable.java: Set the
1083         'white-space: nowrap;' CSS property on both the list view and the
1084         related list tables.
1085
1086 2011-11-16  Ben Konrath  <ben@bagu.org>
1087
1088         Rework the fix for empty notebook tab labels.
1089
1090         Setting the empty group titles with its name caused problems for the
1091         details layout. Instead of using libglom's
1092         LayoutItem.get_title_or_name(), the LayoutItem name is explicitly sent
1093         to the client when the title is empty. This allows the Notebook to use
1094         the name when the title is empty without affecting anything else.
1095
1096         * src/main/java/org/glom/web/client/ui/details/Notebook.java:
1097         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
1098
1099 2011-11-16  Ben Konrath  <ben@bagu.org>
1100
1101         Set group titles with name when title is empty.
1102
1103         This fixes a problem with an empty notebook tab label in the Lesson
1104         Planner document. The forth tab in the notebook should be "Internet":
1105
1106         http://bagu.org:8080/OnlineGlom/#details:document=lesson-planner&table=teachers&value=0
1107
1108         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Use
1109         libglom's LayoutItem.get_title_or_name() to fill in the LayoutGroup
1110         DTO title.
1111
1112 2011-11-16  Ben Konrath  <ben@bagu.org>
1113
1114         Remove whitespace from the configured username properties.
1115
1116         This assumes that usernames won't have whitespace at the beginning
1117         or end. But I think this is a reasonable assumption.
1118
1119         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Use
1120         String.trim() to remove the whitespace from the username properties.
1121
1122 2011-11-15  Ben Konrath  <ben@bagu.org>
1123
1124         Add details view mockup with HTML tables and text entries.
1125
1126         This is from the attachment on this bug:
1127
1128         https://bugzilla.gnome.org/show_bug.cgi?id=663109
1129
1130         * mockups/details-view-html-tables-text-entries.html:
1131
1132 2011-11-15  Ben Konrath  <ben@bagu.org>
1133
1134         Add space between the columns of the flow table.
1135
1136         This fixes:
1137
1138         https://bugzilla.gnome.org/show_bug.cgi?id=662918
1139
1140         * src/main/java/org/glom/web/client/ui/details/FlowTable.java: Add a 1%
1141         space between columns in the flow table.
1142
1143 2011-11-15  Ben Konrath  <ben@bagu.org>
1144
1145         Add backup files to the .gitignore.
1146
1147         * .gitignore: Ignore files that end with ~.
1148
1149 2011-11-09  Ben Konrath  <ben@bagu.org>
1150
1151         Use latest release of gwt-log.
1152
1153         Gwt-log releases are now being submitted to the maven central
1154         repository so manual installation of the jar is no longer required.
1155
1156         * pom.xml: Update version and groupId of gwt-log dependency.
1157
1158 2011-10-31  Ben Konrath  <ben@bagu.org>
1159
1160         Don't use GWT numeric formatting to override the glom currency formatting.
1161
1162         Currencies are now displayed like they are in Glom. See this bug:
1163
1164         https://bugzilla.gnome.org/show_bug.cgi?id=646216
1165
1166         * src/main/java/org/glom/web/client/Utils.java: Remove GWT currency
1167         formatting.
1168         * src/main/java/org/glom/web/client/ui/cell/NumericCell.java: Add
1169         currency code to constructor and set it when the cell is rendered.
1170         * src/main/java/org/glom/web/client/ui/list/ListTable.java: Add the
1171         currency code to the constructor of the NumericCell.
1172
1173 2011-10-27  Ben Konrath  <ben@bagu.org>
1174
1175         Require the latest release of java-libglom (1.17.4).
1176
1177         * pom.xml:
1178
1179 2011-10-26  Ben Konrath  <ben@bagu.org>
1180
1181         Add style to Notebook that matches current theme.
1182
1183         It's not the best style in the world but it's better than the default.
1184
1185         * src/main/java/org/glom/web/client/ui/details/Notebook.java: Add some
1186         padding at the bottom of the child widgets.
1187         * src/main/webapp/style.css: Add style for the Notebook.
1188
1189 2011-10-26  Ben Konrath  <ben@bagu.org>
1190
1191         Move servlet initialization code to overridden init method.
1192
1193         This is half of the solution to getting proper error messages
1194         displayed when configuration errors occur. Here's the relevant bug:
1195
1196         https://bugzilla.gnome.org/show_bug.cgi?id=662792
1197
1198         The rest of the solution involves surrounding the init method with a
1199         try/catch block and setting a global variable with the error /
1200         exception. A new async method should be created to retrieve and display
1201         the error message / exception.
1202
1203         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Move
1204         code from constructor to init method adding exceptions as needed.
1205
1206 2011-10-26  Ben Konrath  <ben@bagu.org>
1207
1208         Add script to monitor and restart tomcat if required.
1209
1210         * utils/check-and-recover-tomcat.py: New file.
1211
1212 2011-10-26  Ben Konrath  <ben@bagu.org>
1213
1214         Display the correct number of data items in the pager.
1215
1216         This commit fixes:
1217
1218         https://bugzilla.gnome.org/show_bug.cgi?id=661441
1219
1220         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
1221         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
1222         The implementation is the same for both tables: Keep track of the
1223         number of non-empty rows and fire and RowCountChangeEvent after the data has
1224         been updated.
1225         * src/main/java/org/glom/web/client/ui/list/ListTable.java: Add a
1226         custom Pager class that subclasses SimplePager to handle displaying
1227         the correct number when empty rows have been added.
1228
1229 2011-10-26  Ben Konrath  <ben@bagu.org>
1230
1231         Correct error in previous commit.
1232
1233         * src/main/java/org/glom/web/client/activity/ListActivity.java: Remove
1234         eventBus parameter from listView.setCellTable().
1235
1236 2011-10-26  Ben Konrath  <ben@bagu.org>
1237
1238         Fix error in TODO comment.
1239
1240         * src/main/java/org/glom/web/client/activity/ListActivity.java:
1241
1242 2011-10-24  Ben Konrath  <ben@bagu.org>
1243
1244         Create Notebook widgets to the details view.
1245
1246         This isn't finished just yet - I still need to create a reasonable
1247         style to match the current theme.
1248
1249         * src/main/java/org/glom/web/client/Utils.java: Add method for
1250         calculating the height of a widget. This is used in the Notebook class.
1251         * src/main/java/org/glom/web/client/ui/DetailsViewImpl.java: Update for
1252         new constructor method in Group.
1253         * src/main/java/org/glom/web/client/ui/details/Group.java: Add new
1254         method for creating child widget that can be used by subclasses
1255         like Notebook. New constructor that allows disabling the group
1256         titles - Notebooks don't set a group title for their child groups.
1257         * src/main/java/org/glom/web/client/ui/details/Notebook.java: New class
1258         to make Notebooks using GWT's TabLayoutPanel.
1259         * src/main/java/org/glom/web/client/ui/details/Portal.java: New
1260         constructor that allows disabling the group titles.
1261         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Create the
1262         LayoutItemNotebook DTO.
1263         * src/main/java/org/glom/web/shared/layout/LayoutItemNotebook.java: New
1264         DTO for Notebooks. It's just an empty class for now but we might need
1265         it to transfer some specific information in the future.
1266
1267 2011-10-21  Ben Konrath  <ben@bagu.org>
1268
1269         Add navigation buttons to related list tables.
1270
1271         * src/main/java/org/glom/web/client/OnlineGlomService.java:
1272         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
1273         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Add new
1274         method getSuitableRecordToViewDetails() for getting the table name
1275         and primary key value for related list navigation buttons.
1276         * src/main/java/org/glom/web/client/activity/DetailsActivity.java: Add
1277         private cell renderer class to get the navigation information for
1278         related list tables from the server. Extract the navigation
1279         processing code from the details cell navigation and use it for the
1280         related list navigation as well.
1281         * src/main/java/org/glom/web/client/ui/ListViewImpl.java: Add private
1282         cell renderer class for the details open buttons. This was needed
1283         because the related list navigation buttons and the list view
1284         navigation buttons need to react differently when clicked.
1285         * src/main/java/org/glom/web/client/ui/cell/OpenButtonCell.java: Remove
1286         the onEnterKeyDown() method because it's now overriden in the
1287         subclasses that are specific to the related list tables and the list
1288         view tables.
1289         * src/main/java/org/glom/web/client/ui/details/Portal.java: Increase
1290         the vertical size a little because the buttons add a bit of vertical
1291         space to table. This is not a perfect solution because the vertical
1292         size of with table fewer than 5 rows will be a little smaller.
1293         * src/main/java/org/glom/web/client/ui/list/ListTable.java: Update for
1294         changes in how navigation buttons are handled.
1295         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Implement
1296         getSuitableRecordToViewDetails() using the new RelatedListNavigation
1297         database access object.
1298         * src/main/java/org/glom/web/server/database/DBAccess.java: Move code
1299         to find the portal for a given relationship name from
1300         RelatedListDBAccess. Add method to find a primary key field for a
1301         given table.
1302         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
1303         Move code to find the portal for a given relationship name to
1304         DBAccess.
1305         * src/main/java/org/glom/web/server/database/RelatedListNavigation.java:
1306         New file: database access object for getting the related list
1307         navigation information (the table name and the primary key value).
1308         * src/main/java/org/glom/web/shared/NavigationRecord.java: New file:
1309         DTO for transferring a table name to navigate to and a primary key
1310         value.
1311         * src/main/java/org/glom/web/shared/layout/LayoutItemPortal.java: Add
1312         boolean and getter/setter to specifies if the related list should add
1313         navigation buttons.
1314
1315 2011-10-24  Murray Cumming  <murrayc@murrayc.com>
1316
1317         Use the master branch of java-libglom
1318
1319         * pom.xml: Depend on java-libglom 1.19 instead.
1320         
1321         This is the master branch. See also the libglom-1-18 branch.
1322
1323 2011-10-11  Ben Konrath  <ben@bagu.org>
1324
1325         Enable the open navigation button when the data has been set.
1326
1327         This avoids having active buttons that don't do anything when the data
1328         has not been set.
1329
1330         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java:
1331
1332 2011-10-11  Ben Konrath  <ben@bagu.org>
1333
1334         Use IsWidget interface for FlowTableItem.
1335
1336         * src/main/java/org/glom/web/client/ui/details/FlowTable.java: Change
1337         FlowTableItem.getWidget() to asWidget() from the IsWidget interface.
1338
1339 2011-10-11  Ben Konrath  <ben@bagu.org>
1340
1341         Remove GWT styling from open button in details view.
1342
1343         There are still some issues with how the details cell is arranged but
1344         this should be made to match Glom 1.20. I'm going to leave fixing this
1345         until I have Glom 1.20 up and running.
1346
1347         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java: Set
1348         style name on open button.
1349         * src/main/webapp/style.css: Move and edit details-navigation class.
1350         Re-arrange some classes to make them appear in the same order as the
1351         UI.
1352
1353 2011-10-07  Ben Konrath  <ben@bagu.org>
1354
1355         Update to GWT 2.4.0.
1356
1357         * .gitignore: Ignore new cache directory.
1358         * .settings/com.google.gwt.eclipse.core.prefs: Update Eclipse settting.
1359         * pom.xml: Change GWT and maven plugin to 2.4.0.
1360         * src/main/java/org/glom/web/OnlineGlom.gwt.xml: Update doctype for
1361         2.4.0.
1362         * src/main/java/org/glom/web/client/ClientFactory.java:
1363         * src/main/java/org/glom/web/client/ClientFactoryImpl.java:
1364         * src/main/java/org/glom/web/client/OnlineGlom.java:
1365         Update source for API changes.
1366         * utils/build-onlineglom-war.sh: Remove cache directory before the
1367         build.
1368
1369 2011-10-07  Ben Konrath  <ben@bagu.org>
1370
1371         Add navigation buttons in the details view.
1372
1373         This isn't finished but I thought I'd commit what I have as it's a
1374         pretty good start. I still need to:
1375
1376         1. Change the style so that it fits better into the current theme
1377         2. Adjust the details cell to expand as much as possible.
1378
1379         * src/main/java/org/glom/web/client/activity/DetailsActivity.java: Add
1380         click handlers to navigation buttons in the DetailsCells. Create a
1381         refreshData() method to get just the data from the server without the
1382         layout.
1383         * src/main/java/org/glom/web/client/activity/TableSelectionActivity.java:
1384         Update the tableSelector and browser title when the table name
1385         changes without using the tableSelector.
1386         * src/main/java/org/glom/web/client/ui/DetailsView.java:
1387         * src/main/java/org/glom/web/client/ui/DetailsViewImpl.java: Rename
1388         getDetailsCells() to getCells(). Update variable names.
1389         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java: Add
1390         method to set click handler on navigation button. Rename a few
1391         variables. Add navigation buttons where needed.
1392         * src/main/java/org/glom/web/client/ui/details/Group.java: Rename a few
1393         variables and methods.
1394         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Set the
1395         navigation boolean and navigation table as required in the
1396         LayoutItemField DTO.
1397         * src/main/java/org/glom/web/shared/layout/LayoutItemField.java: Add
1398         variables for navigation along with getter/setter methods.
1399
1400 2011-10-07  Ben Konrath  <ben@bagu.org>
1401
1402         Rename Field to DetailsCell.
1403
1404         This is a refactor-only commit. No functionality has been added or
1405         removed.
1406
1407         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
1408         Update variable and method names.
1409         * src/main/java/org/glom/web/client/ui/DetailsView.java:
1410         * src/main/java/org/glom/web/client/ui/DetailsViewImpl.java: Update
1411         variable and method names.
1412         * src/main/java/org/glom/web/client/ui/details/DetailsCell.java:
1413         Renamed from Field.
1414         * src/main/java/org/glom/web/client/ui/details/Group.java: Update
1415         variable and method names.
1416
1417 2011-10-07  Ben Konrath  <ben@bagu.org>
1418
1419         Create separate methods for layout and data the details view.
1420
1421         This is a refactor-only commit. No functionality has been added or
1422         removed.
1423
1424         * src/main/java/org/glom/web/client/activity/DetailsActivity.java: New
1425         private methods: setData(), createLayout().
1426
1427 2011-10-07  Ben Konrath  <ben@bagu.org>
1428
1429         Don't use TableSelectorImpl implementation details in TableSelectorActivity.
1430
1431         This is part of a change to get navigation buttons in the details view
1432         but it should have been done this way from the start.
1433
1434         * src/main/java/org/glom/web/client/activity/ListActivity.java: Update
1435         for method name change in TableSelectionView.
1436         * src/main/java/org/glom/web/client/activity/TableSelectionActivity.java:
1437         Create TableChangeEvent and set the browser title using the
1438         TableSelectionView API.
1439         * src/main/java/org/glom/web/client/ui/TableSelectionView.java:
1440         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
1441         Change getSelectedTable() to getSelectedTableName(). Add
1442         getSelectedTableTitle().
1443
1444 2011-10-07  Ben Konrath  <ben@bagu.org>
1445
1446         Use primaryKeyValue naming convention in constructor of DetailsPlace.
1447
1448         * src/main/java/org/glom/web/client/place/DetailsPlace.java:
1449
1450 2011-10-07  Ben Konrath  <ben@bagu.org>
1451
1452         Update TableChangeEvent to use newTableName naming convention.
1453
1454         This makes the class more consistent with GWT naming conventions.
1455
1456         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
1457         Update for method name change in TableChangeEvent.
1458         * src/main/java/org/glom/web/client/activity/ListActivity.java: Update
1459         for method name change in TableChangeEvent.
1460         * src/main/java/org/glom/web/client/event/TableChangeEvent.java: Update
1461         newTableName variable and getter method. Make toDebugString()
1462         actually work.
1463
1464 2011-09-30  Ben Konrath  <ben@bagu.org>
1465
1466         Disable the pager in the list tables when the data row count is less than the minimum.
1467
1468         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
1469         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
1470
1471 2011-09-30  Ben Konrath  <ben@bagu.org>
1472
1473         Add empty rows to the end of related list and list view tables.
1474
1475         I also extracted the cell rendering classes from the ListTable because
1476         the code was becoming a little crazy with all the anonymous inner
1477         classes. My plan is to use these cell rendering classes in the details
1478         view as well so this refactor will be needed for that change.
1479
1480         * src/main/java/org/glom/web/client/activity/DetailsActivity.java: Only
1481         set the row count in related list tables if the data has more rows
1482         than the minimum number of rows visible.
1483         * src/main/java/org/glom/web/client/ui/ListViewImpl.java: Only set the
1484         row count in list view tables if the data has more rows than the
1485         minimum number of rows visible.
1486         * src/main/java/org/glom/web/client/ui/cell/BooleanCell.java: New class
1487         for rendering TYPE_BOOLEAN cells. The code was extracted from the
1488         ListTable class.
1489         * src/main/java/org/glom/web/client/ui/cell/NumericCell.java: New class
1490         for rendering TYPE_NUMERIC cells. The code was extracted from the
1491         ListTable class.
1492         * src/main/java/org/glom/web/client/ui/cell/OpenButtonCell.java: New
1493         class for rendering cells with buttons in list views. The code was
1494         extracted from the ListTable class.
1495         * src/main/java/org/glom/web/client/ui/cell/TextCell.java: New class
1496         for rendering TYPE_TEXT cells. The code was extracted from the
1497         ListTable class.
1498         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
1499         Add empty rows to the end of the data if required. Implement
1500         ListTable.getMinNumVisibleRows().
1501         * src/main/java/org/glom/web/client/ui/list/ListTable.java: Extract
1502         cell renderer code to public classes. Return null in
1503         Column.getValue() for empty rows. Add new abstract method:
1504         getMinNumVisibleRows(). Move code to set the row count of the list view
1505         table to ListViewImpl.
1506         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java: Add
1507         empty rows to the end of the data if required. Implement
1508         ListTable.getMinNumVisibleRows().
1509
1510
1511 2011-09-27  Ben Konrath  <ben@bagu.org>
1512
1513         Use GWT.log for client-side debugging statements.
1514
1515         These are optimized out when deployed so I should have used this method
1516         in the first place. These statements will eventually be replaced with some sort
1517         of notification in the browser.
1518
1519         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
1520         * src/main/java/org/glom/web/client/activity/ListActivity.java:
1521         * src/main/java/org/glom/web/client/activity/TableSelectionActivity.java:
1522         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
1523         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
1524
1525 2011-09-27  Ben Konrath  <ben@bagu.org>
1526
1527         Put tableselector on the right, back to list link on right.
1528
1529         The idea is that the table selector is acting like a label for the
1530         currently displayed table so it should be placed below the document title. This
1531         puts the table title in a similar position to where it is in Glom.
1532
1533         * mockups/details-contacts.html:
1534         * mockups/details-projects.html:
1535         * mockups/listview-contacts.html:
1536         * mockups/listview-projects.html:
1537         * mockups/style.css:
1538         Update mockups to match how the interfaces currently look.
1539         * src/main/webapp/style.css: Swap positions of backlink with the table
1540         selector. Add some space on the left side of the table selector to
1541         line things up with the document title.
1542
1543 2011-09-27  Ben Konrath  <ben@bagu.org>
1544
1545         Add field colouring to details view.
1546
1547         This change re-works how field colouring works. The colour formatting
1548         information is now set to the client with the layout information instead of
1549         with the data. This eliminates the need to send the same colour strings for
1550         data in list view column when colour information is set.
1551
1552         In order to set an alternate colour for negative numeric values, the
1553         number is now sent to client and formatted with the GWT NumberFormat class.
1554
1555         This change also fixes:
1556
1557         https://bugzilla.gnome.org/show_bug.cgi?id=659752
1558
1559         * src/main/java/org/glom/web/OnlineGlom.gwt.xml: Add the GWT
1560         internationalization framework which is needed for client side numeric
1561         formatting.
1562         * src/main/java/org/glom/web/client/Utils.java: New file for some
1563         client static utility methods.
1564         * src/main/java/org/glom/web/client/activity/DetailsActivity.java: Pass
1565         the DataItem object to the Field class. Use a utility method to
1566         create the foreignKeyValue string.
1567         * src/main/java/org/glom/web/client/ui/details/Field.java: Set
1568         alignment and text colours in the constructor. Add setData(DataItem)
1569         method. Remove setText(String) method.
1570         * src/main/java/org/glom/web/client/ui/list/ListTable.java: Add the
1571         colour information to GlomTextCell. Create and use GlomNumberCell for
1572         rendering numbers. Use utility method to get the string for the
1573         primary key of the key provider. Re-work how the horizontal alignment
1574         is set.
1575         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Add
1576         formatting to layout information. Methods for converting the libglom
1577         formatting information were moved from DBAccess.
1578         * src/main/java/org/glom/web/server/database/DBAccess.java: Remove
1579         numeric formatting (it's now done on the client side). Don't set text
1580         colours in DataItem. Move libglom formatting conversion methods to
1581         ConfiguredDocument.
1582         * src/main/java/org/glom/web/shared/DataItem.java: Remove fields and
1583         getters/setters for text colour information.
1584         * src/main/java/org/glom/web/shared/GlomNumericFormat.java: New file
1585         for transferring the libglom NumericFormat information to the client.
1586         * src/main/java/org/glom/web/shared/layout/Formatting.java: Add fields
1587         and getters/setters for: GlomNumericFormat, background colour and
1588         foreground colour strings.
1589
1590 2011-09-26  Ben Konrath  <ben@bagu.org>
1591
1592         Simplify code that iterates through the LayoutGroup.
1593
1594         * src/main/java/org/glom/web/client/ui/list/ListTable.java:
1595
1596 2011-09-26  Ben Konrath  <ben@bagu.org>
1597
1598         Accept Eclipse formatting for OnlineGlomServiceAsync.
1599
1600         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
1601
1602 2011-09-26  Ben Konrath  <ben@bagu.org>
1603
1604         Don't use the ListDBAccess classes to get the primary key layout information.
1605
1606         This was causing a bug where the wrong index for the hidden primary key
1607         was being sent to the client.
1608
1609         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Find the
1610         primary key while creating the LayoutGroup DTO. Create a
1611         LayoutItemField DTO for hidden primary keys. Don't use the
1612         RelatedListDBAccess because it was only used for getting the primary
1613         key.
1614         * src/main/java/org/glom/web/server/database/DBAccess.java: Change the
1615         access modifier from public to protected for getPrimaryKeyField() and
1616         getPrimaryKeyLayoutItemField().
1617         * src/main/java/org/glom/web/server/database/ListDBAccess.java: Remove
1618         abstract method getExpectedResultSize() because RelatedListDBAccess
1619         doesn't have enough info to implement it.
1620         * src/main/java/org/glom/web/server/database/ListViewDBAccess.java:
1621         Remove @Override for getExpectedResultSize().
1622         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
1623         Remove method getExpectedResultSize().
1624
1625 2011-09-23  Ben Konrath  <ben@bagu.org>
1626
1627         Log which layout (list or details) the ignored item is from.
1628
1629         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
1630
1631 2011-09-23  Ben Konrath  <ben@bagu.org>
1632
1633         Remove annotations that turn off code formatting in DataItem.
1634
1635         * src/main/java/org/glom/web/shared/DataItem.java:
1636
1637 2011-09-23  Ben Konrath  <ben@bagu.org>
1638
1639         Rename GlomField to DataItem and update associated methods.
1640
1641         This is a rename-only refactor. No functionality has been added or
1642         removed.
1643
1644         * src/main/java/org/glom/web/client/OnlineGlomService.java:
1645         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
1646         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
1647         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
1648         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
1649         * src/main/java/org/glom/web/client/ui/list/ListTable.java:
1650         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
1651         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
1652         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
1653         * src/main/java/org/glom/web/server/database/DBAccess.java:
1654         * src/main/java/org/glom/web/server/database/DetailsDBAccess.java:
1655         * src/main/java/org/glom/web/server/database/ListDBAccess.java:
1656         * src/main/java/org/glom/web/server/database/ListViewDBAccess.java:
1657         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
1658         * src/main/java/org/glom/web/shared/DataItem.java:
1659         * src/main/java/org/glom/web/shared/DetailsLayoutAndData.java:
1660         * src/main/java/org/glom/web/shared/layout/LayoutGroup.java:
1661
1662 2011-09-23  Ben Konrath  <ben@bagu.org>
1663
1664         Rename GlomDocument to DocumentInfo and update associated methods.
1665
1666         This is a rename-only refactor. No functionality has been added or
1667         removed.
1668
1669         * src/main/java/org/glom/web/client/OnlineGlomService.java:
1670         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
1671         * src/main/java/org/glom/web/client/activity/ListActivity.java:
1672         * src/main/java/org/glom/web/client/activity/TableSelectionActivity.java:
1673         * src/main/java/org/glom/web/server/ConfiguredDocument.java:
1674         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
1675         * src/main/java/org/glom/web/shared/DocumentInfo.java:
1676
1677 2011-09-20  Ben Konrath  <ben@bagu.org>
1678
1679         Require java-libglom 1.17.3.
1680
1681         This picks up the fix for the seg fault problem with the Scenes table
1682         in the Openismus Film Manager example.
1683
1684         * pom.xml:
1685
1686 2011-09-20  Ben Konrath  <ben@bagu.org>
1687
1688         Change the way sort clause is added for primary key when no sort clause is requested.
1689
1690         The primary key is now added to the LayoutFieldVector (fieldsToGet)
1691         before the sort clause is created. When a sort clause is not requested, the
1692         sort clause is created by finding the primary key in the LayoutFieldVector
1693         (fieldsToGet).
1694
1695         * src/main/java/org/glom/web/server/database/ListDBAccess.java:
1696
1697 2011-09-20  Ben Konrath  <ben@bagu.org>
1698
1699         Log error message if no documents are found in the configured directory.
1700
1701         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Also:
1702         Extract the glom file extension string to a private static final class
1703         variable (mostly as syntactic sugar). Accept a minor formatting change.
1704         * src/main/resources/onlineglom.properties: Add '/glomfile' to end of
1705         the example glom.document.directory configuration property to make it
1706         more clear that it can any directory, not just the home directory.
1707
1708 2011-09-18  Ben Konrath  <ben@bagu.org>
1709
1710         Add related lists to details view.
1711
1712         The related list table has support for paging and sorting just like the
1713         table in the list view.
1714
1715         * pom.xml: Require java-libglom 1.17.2 for the new methods to build the
1716         SQL queries for the related list tables.
1717         * src/main/java/org/glom/web/client/OnlineGlomService.java:
1718         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
1719         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
1720         Rename getList methods to getListView and add comments. Remove
1721         getDetailsLayout() as it's not used anymore. Add note to getDetailsData() about
1722         it being unused. Add methods: getDetailsLayoutAndData(),
1723         getSortedRelatedListData(), getRelatedListData(), getRelatedListRowCount()
1724         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
1725         Create the layout and set the data for the fields in one async call
1726         instead of two. Create related lists where appropriate.
1727         * src/main/java/org/glom/web/client/activity/ListActivity.java: Changes
1728         for method name changes in OnlineGlomService.
1729         * src/main/java/org/glom/web/client/ui/DetailsView.java:
1730         * src/main/java/org/glom/web/client/ui/DetailsViewImpl.java: Rename
1731         addLayoutGroup() to addGroup(). Add methods to get the DTOs for the
1732         visible UI objects.
1733         * src/main/java/org/glom/web/client/ui/ListView.java:
1734         * src/main/java/org/glom/web/client/ui/ListViewImpl.java: Remove
1735         tableName from setCellTable(). Create a ListViewTable instead of
1736         ListTable.
1737         * src/main/java/org/glom/web/client/ui/details/Field.java: New class to
1738         represent a data field in the details view.
1739         * src/main/java/org/glom/web/client/ui/details/Group.java: Move to code
1740         from addDetailsCell() to Field class. Keep track of the Fields and
1741         Portals in the details view.
1742         * src/main/java/org/glom/web/client/ui/details/Portal.java: Make portal
1743         a little bigger to match Glom. Keep track of the LayoutItemPortal DTO
1744         and add a method to get it. Add method to set the contents of the
1745         portal.
1746         * src/main/java/org/glom/web/client/ui/details/RelatedListTable.java:
1747         New class for related list tables. This class has the data provider
1748         for the related list table.
1749         * src/main/java/org/glom/web/client/ui/list/ListTable.java: Change to
1750         abstract class which is the base class for the ListViewTable and the
1751         RelatedListTable.
1752         * src/main/java/org/glom/web/client/ui/list/ListViewTable.java:
1753         New class for list view tables. This class has the data provider for
1754         the list view table.
1755         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Add
1756         methods for related list tables. Add more information to the
1757         LayoutItemField and LayoutItemPortal DTOs.
1758         * src/main/java/org/glom/web/server/database/DetailsDBAccess.java:
1759         Remove debugging print statement.
1760         * src/main/java/org/glom/web/server/database/ListDBAccess.java:
1761         Remove debugging print statements. Add primary key field to SQL count
1762         query.
1763         * src/main/java/org/glom/web/server/database/ListViewDBAccess.java:
1764         Remove unnecessary LayoutFieldVector parameter from
1765         getResultSizeOfSQLQuery() method.
1766         * src/main/java/org/glom/web/server/database/RelatedListDBAccess.java:
1767         New class for related list table database access.
1768         * src/main/java/org/glom/web/shared/DetailsLayoutAndData.java: New
1769         class that is a wrapper DTO for details view layout and data.
1770         * src/main/java/org/glom/web/shared/layout/LayoutItemPortal.java: Add
1771         new 'fromField' string to this DTO.
1772         * src/main/webapp/style.css: Remove bottom margin and override top
1773         margin with 0em.
1774
1775 2011-09-15  Ben Konrath  <ben@bagu.org>
1776
1777         Breakup the OnlineGlomServiceImpl class to make it more manageable.
1778
1779         This sets things up to make it easier to add the data retrieval for
1780         related lists (portals). No user noticeable changes were made with
1781         this commit.
1782
1783         * src/main/java/org/glom/web/server/ConfiguredDocument.java: This
1784         class has the code to retrieve the layouts and access the
1785         database using the new database helper classes.
1786         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
1787         Most of the functionality has been removed from this class. This
1788         class now represents the public interface for the client side
1789         code. It also deals with configuring the servlet and cleaning
1790         things up when the servlet is stopped.
1791         * src/main/java/org/glom/web/server/Utils.java: Extract a couple
1792         of static methods into this utility class.
1793         * src/main/java/org/glom/web/server/database/DBAccess.java:
1794         * src/main/java/org/glom/web/server/database/DetailsDBAccess.java:
1795         * src/main/java/org/glom/web/server/database/ListDBAccess.java:
1796         * src/main/java/org/glom/web/server/database/ListViewDBAccess.java:
1797         These classes have the database retrieval code. The class hierarchy
1798         has been setup to make it easy to reuse code for similar
1799         functionality.
1800
1801 2011-09-06  Ben Konrath  <ben@bagu.org>
1802
1803         Create separate classes for list table code and the data provider.
1804
1805         As part of this refactor, I also split up the code a bit to make it
1806         more manageable.
1807
1808         * src/main/java/org/glom/web/client/ui/ListViewImpl.java: Move list
1809         table code to two new classes (below).
1810         * src/main/java/org/glom/web/client/ui/list/ListTable.java: New file
1811         with code from ListViewImpl.
1812         * src/main/java/org/glom/web/client/ui/list/ListTableDataProvider.java:
1813         New file with code from ListViewImpl.
1814
1815 2011-09-06  Ben Konrath  <ben@bagu.org>
1816
1817         Change the LayoutItemPortal DTO to extend LayoutGroup instead of LayoutItem.
1818
1819         This fixes the LayoutItemPortal DTO to match the libglom layout object
1820         hierarchy.
1821
1822         * src/main/java/org/glom/web/shared/layout/LayoutItemPortal.java:
1823
1824 2011-09-01  Ben Konrath  <ben@bagu.org>
1825
1826         Set title of Portals in the Details View.
1827
1828         * pom.xml: Bump required version of java-libglom to 1.17.1.
1829         * src/main/java/org/glom/web/client/ui/details/Group.java: Move Portal
1830         widget creation to its own class. Add comments to constructor.
1831         * src/main/java/org/glom/web/client/ui/details/Portal.java: New file.
1832         The code is mostly from the Group class with the title now set.
1833         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Set
1834         title of Portal. Update some comments. Fix some code formatting.
1835
1836 2011-09-01  Ben Konrath  <ben@bagu.org>
1837
1838         Remove TODO comment for the flow table column width.
1839
1840         The flow table column width is working correctly and doesn't need to be
1841         changed. See this mailing list post for more info:
1842
1843         https://mail.gnome.org/archives/glom-devel-list/2011-August/msg00017.html
1844
1845         * src/main/java/org/glom/web/client/ui/details/FlowTable.java:
1846
1847 2011-08-27  Ben Konrath  <ben@bagu.org>
1848
1849         Add document title (database name) to top of the browser page.
1850
1851         I added the document title to the TableSelecitonView but that will
1852         change if / when we add a view that doesn't require table selection.
1853
1854         * mockups/details-contacts.html:
1855         * mockups/details-projects.html:
1856         * mockups/listview-contacts.html:
1857         * mockups/listview-projects.html:
1858         * mockups/style.css: Add document title to mockups to keep things
1859         consistent.
1860         * src/main/java/org/glom/web/client/OnlineGlom.java: Adjust LayoutPanel
1861         sizes to account for the document title.
1862         * src/main/java/org/glom/web/client/activity/TableSelectionActivity.java:
1863         Set the document title when it has been retrieved from the server.
1864         * src/main/java/org/glom/web/client/ui/TableSelectionView.java:
1865         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java: Add
1866         and implement setDocumentTitle(String) method.
1867         * src/main/webapp/style.css: Add ID for document title style.
1868
1869 2011-08-25  Ben Konrath  <ben@bagu.org>
1870
1871         Add NavigationType enum to LayoutItemPortal DTO.
1872
1873         This is the start of adding support for Portals to the Details View.
1874
1875         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Convert
1876         LayoutItem_Portal.navigation_type enum from libglom to
1877         LayoutItemPortal.NavigationType enum.
1878         * src/main/java/org/glom/web/shared/layout/LayoutItemPortal.java: Add
1879         NavigationType enum, field for storing the NavigationType and getter
1880         and setter methods.
1881
1882 2011-08-25  Ben Konrath  <ben@bagu.org>
1883
1884         Implement the flow table layout in the Details View.
1885
1886         * src/main/java/org/glom/web/client/ui/DetailsViewImpl.java: Change
1887         FlowTable to Group to account for the renamed class.
1888         * src/main/java/org/glom/web/client/ui/details/FlowTable.java: New
1889         File. This is a container widget that implements the Glom details view
1890         flow table behaviour.
1891         * src/main/java/org/glom/web/client/ui/details/Group.java: Moved from
1892         org/glom/web/client/ui/FlowTable.java.
1893         * src/main/webapp/style.css: Adjust bottom margin of the subgroup-title
1894         so that the size of the subgroups are a closer match to the size of
1895         the Glom subgroups. This makes the flowtable layout match the layout
1896         in Glom for the Music Collection example file.
1897
1898 2011-08-16  Ben Konrath  <ben@bagu.org>
1899
1900         Create container element for LayoutItemPortal in Details View.
1901
1902         This will help me develop the layout for the FlowTable.
1903
1904         * src/main/java/org/glom/web/client/ui/FlowTable.java: Also rename
1905         fieldPanel variable to detailsCell.
1906
1907 2011-08-15  Ben Konrath  <ben@bagu.org>
1908
1909         Set the height of the data element in the Details View.
1910
1911         I changed the InlineLabels (text in a span element) to Labels (text in
1912         a div element) so that I could set the height of the details-data
1913         elements instead of the details-cell parent elements. This allows the
1914         the details-data element to display the correct height if style is
1915         applied that shows the height.
1916
1917         This change has the added benefit of allowing the order of the labels
1918         and data elements to be changed for right-to-left languages.
1919
1920         * src/main/java/org/glom/web/client/ui/DetailsViewImpl.java: Change
1921         InlineLabels to Labels.
1922         * src/main/java/org/glom/web/client/ui/FlowTable.java: Change
1923         InlineLabels to Labels. Set the height of the data element.
1924         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Set the
1925         multiline text height in the Formatting DTO.
1926         * src/main/java/org/glom/web/shared/layout/Formatting.java: Add field
1927         for multiline height along with getter and setter methods.
1928         * src/main/webapp/style.css: Adjust style to account for the change
1929         from span elements to div elements in the details cell.
1930
1931 2011-08-15  Ben Konrath  <ben@bagu.org>
1932
1933         Make the List View appearance match the mockups.
1934
1935         It doesn't match exactly but it's much better than it was.
1936
1937         * mockups/listview-contacts.html: Remove unused css classes.
1938         * mockups/listview-projects.html: Remove unused css classes.
1939         * src/main/java/org/glom/web/client/ui/ListViewImpl.java: Display 15
1940         rows instead of 20. Rename vPanel to mainPanel. Use FlowPanel (div)
1941         for mainPanel instead of VerticalPanel (table). Set style name on
1942         CellTable. Set style name on Details column. Right-align Details
1943         buttons.
1944         * src/main/webapp/style.css: Adjust properties to match the mockups.
1945
1946 2011-08-12  Ben Konrath  <ben@bagu.org>
1947
1948         Add better support for subgroups in the details view.
1949
1950         * src/main/java/org/glom/web/client/ui/DetailsViewImpl.java: Update for
1951         changed FlowTable constructor.
1952         * src/main/java/org/glom/web/client/ui/FlowTable.java: Add better
1953         support for subgroups and subgroup-titles.
1954         * src/main/webapp/style.css: Add CSS class for subgroups and
1955         subgroup-titles.
1956
1957 2011-08-12  Ben Konrath  <ben@bagu.org>
1958
1959         Return the top level LayoutGroup title.
1960
1961         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
1962
1963 2011-08-11  Ben Konrath  <ben@bagu.org>
1964
1965         Make the TableSelector header match the mockup.
1966
1967         * src/main/java/org/glom/web/client/OnlineGlom.java: Add a margin to
1968         the layout panel. Properly lineup the table selection header with
1969         the list and details view.
1970         * src/main/java/org/glom/web/client/ui/DetailsViewImpl.java: Remove the
1971         margin around the details view.
1972         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
1973         Rename listBox variable to tableSelector. Set id for the style sheet.
1974         Use a FlowPanel instead of a HorizontalPanel.
1975         * src/main/webapp/style.css: Add properties to make the TableSelector
1976         box match the mockups.
1977
1978 2011-07-13  Ben Konrath  <ben@bagu.org>
1979
1980         Update install script for java-libglom version change.
1981
1982         * utils/install-onlineglom-war.sh: Also exit if 'make check' in
1983         java-libglom fails.
1984
1985 2011-07-13  Ben Konrath  <ben@bagu.org>
1986
1987         Add support sub-group in the details view.
1988
1989         I also removed the code that special-cased the default details view
1990         layout. See:
1991
1992         http://mail.gnome.org/archives/glom-devel-list/2011-July/msg00005.html
1993
1994         I still have to make a proper flowtable.
1995
1996         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
1997         Don't special-case default details view layout.
1998         * src/main/java/org/glom/web/client/ui/DetailsView.java: Remove
1999         addLayoutField() as I'm going to use it.
2000         * src/main/java/org/glom/web/client/ui/DetailsViewImpl.java: Extract
2001         GroupPanel to FlowTable class. Remove unimplemented addLayoutField()
2002         method.
2003         * src/main/java/org/glom/web/client/ui/FlowTable.java: New class
2004         extracted from DetailsViewImpl.GroupPanel. Add support for
2005         sub-groups.
2006         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Set
2007         column count when getting the details layout.
2008
2009 2011-07-12  Ben Konrath  <ben@bagu.org>
2010
2011         Set browser title with database and table titles.
2012
2013         * src/main/java/org/glom/web/client/activity/TableSelectionActivity.java:
2014         Set the browser title when the table changes and when the activity
2015         first starts.
2016         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Set
2017         title when retrieving document info (the GlomDocument object).
2018         * src/main/java/org/glom/web/shared/GlomDocument.java: Add title field
2019         with getter and setter methods. Remove unused convenience constructor.
2020         Use default code formatting.
2021
2022 2011-07-12  Ben Konrath  <ben@bagu.org>
2023
2024         Ignore LayoutItemPortals in the details view.
2025
2026         I added a new DTO for the LayoutItemPortal so that I can ignore it in
2027         the client code.
2028
2029         * src/main/java/org/glom/web/client/ui/DetailsViewImpl.java: Ignore
2030         LayoutItemPortal layout objects.
2031         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Create
2032         LayoutItemPortal objects when retrieving the details layout.
2033         * src/main/java/org/glom/web/shared/layout/LayoutItemPortal.java: New
2034         file. This is an empty class and just used to get type information for
2035         now.
2036
2037 2011-07-12  Ben Konrath  <ben@bagu.org>
2038
2039         Use java-libglom 1.17.0.
2040
2041         * pom.xml:
2042
2043 2011-07-11  Ben Konrath  <ben@bagu.org>
2044
2045         Remove "Table:" label from table selector.
2046
2047         This matches a recent change in the Glom UI.
2048
2049         * mockups/details-contacts.html:
2050         * mockups/details-projects.html:
2051         * mockups/listview-contacts.html:
2052         * mockups/listview-projects.html: Remove the "Table:" label from the
2053         mockups as well.
2054         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
2055
2056 2011-07-11  Ben Konrath  <ben@bagu.org>
2057
2058         Add main groups to the details view.
2059
2060         This makes things look a little nicer in the details view. The next step
2061         is to implement the flowtable.
2062
2063         * src/main/java/org/glom/web/OnlineGlom.gwt.xml: Inherit only the
2064         resources from the standard gwt css theme. Standard.css is now
2065         included in OnlineGlom.html so that the online glom css rules have
2066         precedence over the gwt theme.
2067         * src/main/java/org/glom/web/client/activity/DetailsActivity.java: Pass
2068         the whole LayoutGroup to the DetailsView instead of just the titles.
2069         * src/main/java/org/glom/web/client/ui/DetailsView.java:
2070         * src/main/java/org/glom/web/client/ui/DetailsViewImpl.java: Create the
2071         details layout with a helper class (GroupPanel). I might extract this
2072         class when I make the full flowtable.
2073         * src/main/java/org/glom/web/shared/layout/LayoutItem.java: Add empty
2074         string as default so I don't have to worry about NPEs when processing
2075         the layout objects.
2076         * src/main/webapp/OnlineGlom.html: Add the gwt standard css file (see
2077         note beside OnlineGlom.gwt.xml above).
2078         * src/main/webapp/style.css: Add default font-size to body to override
2079         the font-size set by the standard theme. Don't use h2 tags for
2080         group-title. Create new details-cell class.
2081
2082 2011-07-08  Murray Cumming  <murrayc@murrayc.com>
2083
2084         ConfiguredDocument: Set the port number too.
2085
2086         * src/main/java/org/glom/web/server/ConfiguredDocument.java
2087         (ConfiguredDocument.ConfiguredDocument): Get the port number from the 
2088         Glom document. Presumably this worked sometimes so far because there is a 
2089         default port number.
2090
2091 2011-07-08  Murray Cumming  <murrayc@murrayc.com>
2092
2093         ConfiguredDocument: Warn that sqlite and self-hosting are not supported.
2094
2095         * src/main/java/org/glom/web/server/ConfiguredDocument.java
2096         (ConfiguredDocument.ConfiguredDocument): Check that the hosting mode is 
2097         correct, though we should throw an exception too.
2098
2099 2011-07-08  Murray Cumming  <murrayc@murrayc.com>
2100
2101         Fix a addDocuemnt typo.
2102
2103         * src/main/java/org/glom/web/shared/Documents.java
2104         (Documents.addDocuemnt): Rename to addDocument().
2105         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java
2106         (OnlineGlomServiceImpl.getDocuments): Adapt.
2107         
2108 2011-07-08  Murray Cumming  <murrayc@murrayc.com>
2109
2110         Slightly improved log output when connection fails.
2111
2112         * src/main/java/org/glom/web/server/ConfiguredDocument.java
2113         (ConfiguredDocument.setUsernameAndPassword):
2114         We don't know for sure if it' the username/password that's wrong, so 
2115         rephrase the message.
2116         Also ouput the exception message, though it's generic in this case.
2117
2118 2011-07-08  Ben Konrath  <ben@bagu.org>
2119
2120         Cleanup comments.
2121
2122         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Also
2123         added braces to a one line if statement because the Eclipse formatter
2124         was getting confused.
2125
2126 2011-07-07  Ben Konrath  <ben@bagu.org>
2127
2128         Update project config files for Eclipse 3.7 and use GWT 2.3.0.
2129
2130         These should really be two separate tasks but I counldn't get things to
2131         work with GWT 2.2.0 and Eclipse 3.7.
2132
2133         * .classpath:
2134         * .project:
2135         * .settings/org.eclipse.jdt.core.prefs:
2136         * .settings/org.eclipse.jdt.ui.prefs:
2137         * .settings/org.eclipse.ltk.core.refactoring.prefs:
2138         * .settings/org.eclipse.m2e.core.prefs:
2139         Add new config files. Update current files. Remove references to the
2140         webtools plugins as we're not using any of the webtools features.
2141         * .gitignore: Add logs directory which is created when running with
2142         'mvn gwt:run'.
2143         * pom.xml: Update to GWT 2.3.0. Eclipse configuration was automatically added.
2144         * src/main/java/org/glom/web/OnlineGlom.gwt.xml: Moved from
2145         src/main/resources/org/glom/web/OnlineGlom.gwt.xml as per this known
2146         limitation:
2147         http://mojo.codehaus.org/gwt-maven-plugin/eclipse/google_plugin.html#Limitations
2148
2149 2011-07-07  Murray Cumming  <murrayc@murrayc.com>
2150
2151         onlineglom.properties: Add explanatory comments.
2152
2153         * src/main/resources/onlineglom.properties: Also change the default user 
2154         from ben to someuser, to avoid the risk of people thinking we just 
2155         stupidly hard-coded a locale path, when they see that on stderr or in a log.
2156
2157 2011-06-28  Ben Konrath  <ben@bagu.org>
2158
2159         Use filename in Log for incorrect passwords.
2160
2161         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Add
2162         getFileName(String) method to get the filename from the URI.
2163
2164 2011-06-28  Ben Konrath  <ben@bagu.org>
2165
2166         Add the table name to the URL token for the ListPlace.
2167
2168         This makes things consistent between the DetailsPlace and the
2169         ListPlace. It also allows the the ListPlace to be bookmarked.
2170
2171         * src/main/java/org/glom/web/client/OnlineGlomService.java:
2172         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
2173         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2174         Remove getDefaultListLayout(). The default layout is now returned
2175         by the getListLayout() method when the table name is an empty string.
2176         * src/main/java/org/glom/web/client/activity/ListActivity.java:
2177         Add table name field. Change to a new ListPlace when the table
2178         has been changed. Use getListLayout() for getting the default
2179         list layout.
2180         * src/main/java/org/glom/web/client/activity/TableSelectionActivity.java:
2181         Add table name field. Set the correct table name in the list box
2182         when loading from bookmark. This corrects a problem for the
2183         DetailsPlace too.
2184         * src/main/java/org/glom/web/client/place/DetailsPlace.java:
2185         Move table name to super-class (HasSelectableTable). Move document
2186         and table URL keys to super-class in HasSelectableTable.
2187         * src/main/java/org/glom/web/client/place/HasSelectableTablePlace.java:
2188         Add table name field. Add Tokenizer class with URL key common to
2189         the subclasses (DetailsPlace and ListPlace).
2190         * src/main/java/org/glom/web/client/place/ListPlace.java:
2191         Add table name. Add code to parse the URL token.
2192         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.java:
2193         Update ListPlace construction with empty table name string.
2194         * src/main/java/org/glom/web/client/ui/TableSelectionView.java:
2195         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
2196         Change setTableSelectedIndex(int) to setSelectedTableName(String).
2197         Update ListPlace construction with table name string.
2198         * src/main/java/org/glom/web/shared/layout/LayoutGroup.java:
2199         Change defaultTableName field to tableName to reflect how it's now
2200         used. Update the getter and setter methods.
2201
2202 2011-06-28  Ben Konrath  <ben@bagu.org>
2203
2204         Enable the table selector in the DetailsView.
2205
2206         * src/main/java/org/glom/web/client/OnlineGlomService.java:
2207         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
2208         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2209         Remove getDefaultDetailsLayout(). The default layout is now returned
2210         by the getDetailsLayout() method when the table name is an empty
2211         string.
2212         * src/main/java/org/glom/web/client/activity/DetailsActivity.java: Add
2213         event handler for table change event. Change to using
2214         getDetailsLayout() for the default details layout.
2215         * src/main/java/org/glom/web/client/place/DetailsPlace.java: Add table
2216         name to URL token.
2217         * src/main/java/org/glom/web/client/ui/ListViewImpl.java: Use table
2218         when navigating to the details place.
2219
2220 2011-06-27  Ben Konrath  <ben@bagu.org>
2221
2222         Use filename based unique document ID in URL and for RPC.
2223
2224         The document ID is the glom document name with spaces (' ') replaced
2225         with pluses ('+') and without the .glom extension.
2226
2227         This change is mostly a string substitution of 'documentTitle' for
2228         'documentID'. The only code change is the addition of a Documents DTO to get the
2229         filename to document title mappings as indicated below.
2230
2231         * src/main/java/org/glom/web/client/OnlineGlomService.java:
2232         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
2233         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
2234         * src/main/java/org/glom/web/client/activity/DocumentSelectionActivity.java:
2235         Use Documents DTO to create the document links in the document
2236         selection view.
2237         * src/main/java/org/glom/web/client/activity/ListActivity.java:
2238         * src/main/java/org/glom/web/client/activity/TableSelectionActivity.java:
2239         * src/main/java/org/glom/web/client/place/DetailsPlace.java:
2240         * src/main/java/org/glom/web/client/place/HasSelectableTablePlace.java:
2241         * src/main/java/org/glom/web/client/place/ListPlace.java:
2242         * src/main/java/org/glom/web/client/ui/DocumentSelectionView.java:
2243         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.java:
2244         * src/main/java/org/glom/web/client/ui/ListView.java:
2245         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
2246         * src/main/java/org/glom/web/client/ui/TableSelectionView.java:
2247         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
2248         * src/main/java/org/glom/web/server/Log.java:
2249         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Change
2250         getDocumentTitles() to getDocuments() and return the Documents DTO.
2251         * src/main/java/org/glom/web/shared/Documents.java: New DTO for
2252         transferring the filename to document title mappings.
2253
2254 2011-06-25  Ben Konrath  <ben@bagu.org>
2255
2256         Make the authentication popup work again.
2257
2258         This bug was introduced when I extracted ConfiguredDocument to its own class.
2259
2260         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Return the
2261         correct success / fail status in setUsernameAndPassword().
2262
2263 2011-06-25  Ben Konrath  <ben@bagu.org>
2264
2265         Use filename as unique key for configuring database usernames and passwords.
2266
2267         This replaces the use of the Glom document title which could change
2268         depending on the locale. Thanks to Murray Cumming for pointing out this
2269         problem.
2270
2271         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2272         * src/main/resources/onlineglom.properties:
2273
2274 2011-06-24  Ben Konrath  <ben@bagu.org>
2275
2276         Pass primary key value to DetailsView.
2277
2278         This enables the DetailsView to load the correct data.
2279
2280         * src/main/java/org/glom/web/client/activity/DetailsActivity.java: Add
2281         primary key value field and set in constructor. Pass primary key
2282         value to getDetailsData().
2283         * src/main/java/org/glom/web/client/place/DetailsPlace.java: Add URL
2284         variables for document title and primary key value.
2285         * src/main/java/org/glom/web/client/ui/ListViewImpl.java: Pass primary
2286         key value to the DetailsPlace.
2287
2288 2011-06-24  Ben Konrath  <ben@bagu.org>
2289
2290         Add primary key index to LayoutGroup DTO and add ProvidesKey to CellTable.
2291
2292         This allows the primary key to be retrieved by the Details button. This
2293         functionality has not been implemented yet but it's in the works.
2294
2295         * src/main/java/org/glom/web/client/activity/ListActivity.java: Pass
2296         the LayoutGroup result to ListView.setCellTable instead of all of its
2297         fields individually.
2298         * src/main/java/org/glom/web/client/ui/ListView.java:
2299         * src/main/java/org/glom/web/client/ui/ListViewImpl.java: Use
2300         LayoutGroup as parameter for setCellTable. Add ProvidesKey to CellTable
2301         get the primary key for the table.
2302         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Set the
2303         index of the primary key in the LayoutGroup accounting for hidden
2304         primary keys. Rename getJavaNumberFormat() to
2305         convertToJavaNumberFormat() for consistency. Cleanup / add some
2306         comments.
2307         * src/main/java/org/glom/web/shared/layout/LayoutGroup.java: Add a
2308         field for primary key index and a field to indicate whether the
2309         primary key is hidden or not.
2310
2311 2011-06-23  Ben Konrath  <ben@bagu.org>
2312
2313         Rename getTableData methods to getListData.
2314
2315         This is a rename refactor for consistency with other methods.
2316
2317         * src/main/java/org/glom/web/client/OnlineGlomService.java:
2318         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
2319         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
2320         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2321
2322 2011-06-23  Ben Konrath  <ben@bagu.org>
2323
2324         Extract the ConfiguredDocument innerclass into its own class.
2325
2326         This makes the servlet code more object oriented.
2327
2328         * src/main/java/org/glom/web/server/ConfiguredDocument.java: Extracted
2329         from private ConfiguredDocument class in OnlineGlomServiceImpl.
2330         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Use the
2331         new ConfiguredDocument class.
2332
2333 2011-06-21  Ben Konrath  <ben@bagu.org>
2334
2335         Use the LayoutGroup group for the list layout instead of ColumnInfo and LayoutListTable.
2336
2337         This makes things more inline with how libglom works and reduces code
2338         duplication. This refactor lays the groundwork for adding the primary key to
2339         the LayoutGroup object.
2340
2341         * src/main/java/org/glom/web/client/OnlineGlomService.java:
2342         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
2343         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2344         Change method names to getListLayout and getDefaultListLayout for
2345         consistency. Use LayoutGroup as the DTO for the list layout instead of
2346         ColumnInfo and LayoutListTable.
2347         * src/main/java/org/glom/web/client/activity/ListActivity.java: Use the
2348         new method names along with the LayoutGroup object for transferring the
2349         list layout.
2350         * src/main/java/org/glom/web/client/ui/ListView.java:
2351         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
2352         Use ArrayList<LayoutItem> instead of ColumnInfo[] in setCellTable().
2353         * src/main/java/org/glom/web/shared/ColumnInfo.java: Deleted. Replaced
2354         with LayoutGroup.
2355         * src/main/java/org/glom/web/shared/LayoutListTable.java: Deleted.
2356         Replaced with LayoutGroup.
2357         * src/main/java/org/glom/web/shared/layout/LayoutGroup.java: Add
2358         expectedResultSize and defaultTableName fields which are needed for
2359         the list layout.
2360         * src/main/java/org/glom/web/shared/layout/LayoutItemField.java: Add
2361         type field which is needed for the list layout but will also be
2362         useful for the details layout as things progress.
2363         * src/main/java/org/glom/web/shared/layout/LayoutItemWithFormatting.java:
2364         Make class abstract. Remove the unnecessary
2365         getFormattingHorizontalAlignment method. Add setFormatting method.
2366
2367 2011-06-16  Ben Konrath  <ben@bagu.org>
2368
2369         Add scripts for building and installing war.
2370
2371         These will help when updating OnlineGlom but they're also good
2372         supplemental documentation of the build and deployment proceeding.
2373
2374         * utils/build-onlineglom-war.sh: New file.
2375         * utils/install-onlineglom-war.sh: New file.
2376
2377 2011-06-16  Ben Konrath  <ben@bagu.org>
2378
2379         Create wrapper class to create consistent log messages.
2380
2381         I wrapped methods in the Log class of gwt-log to add the method names
2382         from the servlet and create consistent formatting of the document title
2383         and table names in the log messages.
2384
2385         * src/main/java/org/glom/web/server/Log.java: New file with wrapped methods.
2386         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Convert all
2387         log methods to use methods from wrapped Log class.
2388
2389 2011-06-16  Ben Konrath  <ben@bagu.org>
2390
2391         Remove superfluous conditional return.
2392
2393         Thanks to Murray Cumming for pointing this out!
2394
2395         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2396
2397 2011-06-15  Ben Konrath  <ben@bagu.org>
2398
2399         Return an ArrayList of LayoutGroups for the Details layout.
2400
2401         This corrects a problem with the details layout as it can have more
2402         than one top level LayoutGroup.
2403
2404         * src/main/java/org/glom/web/client/OnlineGlomService.java:
2405         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java: Change
2406         method name from get*DetailsLayoutGroup to get*DetailsLayout. Return
2407         an ArrayList<LayoutGroup> in the get*DetailsLayout methods.
2408         * src/main/java/org/glom/web/client/activity/DetailsActivity.java: Deal
2409         with ArrayList of LayoutGroups for the details view layout.
2410         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Change
2411         method name from get*DetailsLayoutGroup to get*DetailsLayout. Return an
2412         ArrayList<LayoutGroup> in the get*DetailsLayout methods. Inline
2413         getTableFieldsToShowForSequence() into getFieldsToShowForSQLQuery() to simplify
2414         the code a bit. Rename getTableFieldsToShowForSequenceAddGroup() to
2415         getFieldsToShowForSQLQueryAddGroup() to try to keep things more consistent.
2416
2417 2011-06-14  Ben Konrath  <ben@bagu.org>
2418
2419         Use cast_dynamic method to determine the libglom LayoutItem type.
2420
2421         This is better than finding the LayoutItem type by using the string
2422         returned from the get_part_type_name() method.
2423
2424         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2425
2426 2011-06-14  Ben Konrath  <ben@bagu.org>
2427
2428         Add method names to log entries in the servlet.
2429
2430         This helps when tracking down deployment problems.
2431
2432         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2433
2434 2011-06-14  Ben Konrath  <ben@bagu.org>
2435
2436         Add data to the DetailsView using a hard-coded primary key value.
2437
2438         The layout and functionality of the DetailsView is not complete. This
2439         is just a checkpoint so the patch doesn't get too big.
2440
2441         * src/main/java/org/glom/web/client/OnlineGlomService.java:
2442         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
2443         Add getDetailsData() servlet method.
2444         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
2445         Add RPC to getDetailsData(). Change the way the LayoutGroups and
2446         LayoutFields are added to the DetailsView.
2447         * src/main/java/org/glom/web/client/ui/DetailsView.java:
2448         * src/main/java/org/glom/web/client/ui/DetailsViewImpl.java:
2449         Add setData() method. Change addLayoutGroup() and addLayoutField() to
2450         take the string for the title instead of the object.
2451         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2452         Add implementation getDetailsData() along with some private helper
2453         methods.
2454         * src/main/webapp/style.css: Add padding to details-data class. Add a
2455         details-label class with the same padding as the details-data class.
2456
2457 2011-06-03  Ben Konrath  <ben@bagu.org>
2458
2459         Use presenter.goTo() to change to the DetailsPlace.
2460
2461         This will make things easier when we need to open the DetailsView with
2462         data specific to the row that was clicked.
2463
2464         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
2465
2466 2011-06-02  Ben Konrath  <ben@bagu.org>
2467
2468         Add CSS file from mockups.
2469
2470         I'm adding this now because it's going to be useful to have when
2471         developing the DetailsView. The TableSelectionView and ListView aren't
2472         setup properly yet.
2473
2474         * src/main/webapp/OnlineGlom.html:
2475         * src/main/webapp/style.css:
2476
2477 2011-06-02  Ben Konrath  <ben@bagu.org>
2478
2479         Use String.isEmpty() to check for empty string.
2480
2481         * src/main/java/org/glom/web/client/activity/ListActivity.java:
2482
2483 2011-06-02  Ben Konrath  <ben@bagu.org>
2484
2485         Display main layout group titles in the DetailsView.
2486
2487         This is the start of the DetailsActivity/DetailsView implementation.
2488
2489         * src/main/java/org/glom/web/client/OnlineGlomService.java:
2490         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
2491         Add getDetailsLayoutGroup() and getDefaultDetailsLayoutGroup() methods.
2492         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
2493         Get the layout information for the details view from the server and set
2494         the main layout group titles.
2495         * src/main/java/org/glom/web/client/ui/DetailsView.java:
2496         * src/main/java/org/glom/web/client/ui/DetailsViewImpl.java:
2497         Add addLayoutGroup() and addLayoutField() methods. This are just
2498         temporary methods for creating the the details view that will change
2499         in the future.
2500         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2501         Implement getDetailsLayoutGroup() and getDefaultDetailsLayoutGroup()
2502         methods.
2503         * src/main/java/org/glom/web/shared/layout/Formatting.java:
2504         * src/main/java/org/glom/web/shared/layout/LayoutGroup.java:
2505         * src/main/java/org/glom/web/shared/layout/LayoutItem.java:
2506         * src/main/java/org/glom/web/shared/layout/LayoutItemField.java:
2507         * src/main/java/org/glom/web/shared/layout/LayoutItemWithFormatting.java:
2508         Data Transfer Objects that mimic the libglom object structure. These are
2509         used for transferring the details layout but could also be used for
2510         transferring the list layout.
2511
2512 2011-05-27  Ben Konrath  <ben@bagu.org>
2513
2514         Reset the AuthenticationPopup when clearing the ListView.
2515
2516         * src/main/java/org/glom/web/client/activity/ListActivity.java:
2517
2518 2011-05-27  Ben Konrath  <ben@bagu.org>
2519
2520         Fix problem with onlineglom.properties file loading.
2521
2522         The old way worked in Eclipse but not on the server. Loading the
2523         onlineglom.properties file now works in Eclipse and on the server.
2524
2525         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2526
2527 2011-05-24  Ben Konrath  <ben@bagu.org>
2528
2529         Update gwt-log from 3.1.0 to 3.1.2.
2530
2531         Gwt-log 3.1.0 has been marked as depreciated.
2532
2533         * pom.xml:
2534
2535 2011-05-24  Ben Konrath  <ben@bagu.org>
2536
2537         Add comment to ListActivity.goTo() method.
2538
2539         * src/main/java/org/glom/web/client/activity/ListActivity.java:
2540
2541 2011-05-24  Ben Konrath  <ben@bagu.org>
2542
2543         Remove FIXME in convertGdkColorToHtmlColour()
2544
2545         The Gdk::Color value returned by libglom is 16-bits per channel on both
2546         64 and 32-bit platforms.
2547
2548         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2549
2550 2011-05-19  Ben Konrath  <ben@bagu.org>
2551
2552         Improve performance of initial ListView load.
2553
2554         I removed a round trip to the server for getting the default table name
2555         and then requesting information about that table. This also removes a potential
2556         problem with the table change handler not being setup in time to receive the
2557         table change event from the ListActivity.
2558
2559         * src/main/java/org/glom/web/client/OnlineGlomService.java:
2560         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java: Add
2561         getDefaultLayoutListTable() method. Improve comments.
2562         * src/main/java/org/glom/web/client/activity/ListActivity.java: Use
2563         getDefaultLayoutListTable() method instead of firing a table change
2564         event to get the table to load.
2565         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Add
2566         implementation of getDefaultLayoutListTable() method.
2567         * src/main/java/org/glom/web/shared/LayoutListTable.java: Add field for
2568         table name.
2569
2570 2011-05-19  Ben Konrath  <ben@bagu.org>
2571
2572         Override toDebugString() in TableChangeEvent.
2573
2574         This is useful to have for debugging.
2575
2576         * src/main/java/org/glom/web/client/event/TableChangeEvent.java:
2577
2578 2011-05-19  Ben Konrath  <ben@bagu.org>
2579
2580         Add a "Back to List" link when at the DetailsPlace.
2581
2582         * src/main/java/org/glom/web/client/activity/ListActivity.java:
2583         Populate the CellTable based on the selected table of the ListBox if
2584         it's set otherwise use the default table. This allows the "Back to
2585         List" link to work.
2586         * src/main/java/org/glom/web/client/activity/TableSelectionActivity.java:
2587         Remove Place from constructors. Add a setPlace() method. Add
2588         goToPlace() method. Set class as presenter for TableSelectionView.
2589         * src/main/java/org/glom/web/client/mvp/TableSelectionActivityMapper.java:
2590         Use the same TableSelectionActivity when switching between the List and
2591         Details Places.
2592         * src/main/java/org/glom/web/client/place/DetailsPlace.java:
2593         Subclass the new HasSelectableTablePlace. This removes some duplicate
2594         code.
2595         * src/main/java/org/glom/web/client/place/HasSelectableTablePlace.java:
2596         New class to represent Places that display the TableSelectionView.
2597         * src/main/java/org/glom/web/client/place/ListPlace.java:
2598         Subclass the new HasSelectableTablePlace. This removes some duplicate
2599         code.
2600         * src/main/java/org/glom/web/client/ui/TableSelectionView.java:
2601         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
2602         Add Presenter interface. Add setBackLinkVisible() method. Add
2603         setBackLink() method.
2604
2605 2011-05-18  Ben Konrath  <ben@bagu.org>
2606
2607         Enable the "Details" buttons.
2608
2609         Right now only an empty details view is displayed.
2610
2611         * src/main/java/org/glom/web/client/ClientFactory.java:
2612         * src/main/java/org/glom/web/client/ClientFactoryImpl.java:
2613         Add DetailsView to ClientFactory.
2614         * src/main/java/org/glom/web/client/activity/DetailsActivity.java:
2615         A basic activity for the details view.
2616         * src/main/java/org/glom/web/client/activity/TableSelectionActivity.java:
2617         Add a new constructor that takes a DetailsPlace. Rename shutdown() to
2618         clearView().
2619         * src/main/java/org/glom/web/client/mvp/AppPlaceHistoryMapper.java:
2620         Add DetailsPlace.Tokenizer to the list of tokens that are generated by
2621         GWT.
2622         * src/main/java/org/glom/web/client/mvp/DataActivityMapper.java:
2623         Create a new DetailsActivity when a DetailsPlace is requested. Remove
2624         unnecessary super() in constructor.
2625         * src/main/java/org/glom/web/client/mvp/TableSelectionActivityMapper.java:
2626         Create a new TableSelectionActivity when a DetailsPlace is requested. We
2627         really shouldn't create a new TableSelectionActivity for both the ListPlace
2628         and the DetailsPlace so this should be considered a temporary solution.
2629         * src/main/java/org/glom/web/client/place/DetailsPlace.java:
2630         New file. Represents a URL for the details view.
2631         * src/main/java/org/glom/web/client/ui/DetailsView.java:
2632         * src/main/java/org/glom/web/client/ui/DetailsViewImpl.java:
2633         A basic details view interface and implementation.
2634         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
2635         Enable the "Details" buttons.
2636
2637 2011-05-12  Ben Konrath  <ben@bagu.org>
2638
2639         Use a LayoutPanel with multiple display areas for main layout.
2640
2641         This is mostly a refactor in that there are no changes from the user
2642         point of view. These changes are required so that we can swap out the list view
2643         with the details view when the user clicks the "Details" button.
2644
2645         * src/main/java/org/glom/web/client/ClientFactory.java:
2646         * src/main/java/org/glom/web/client/ClientFactoryImpl.java: Remove
2647         OnlineGlomView. Add TableSelectionView, ListView and
2648         AuthenticationPopup.
2649         * src/main/java/org/glom/web/client/OnlineGlom.java: Use LayoutPanel
2650         for main layout. Add display regions for main activities. Add
2651         activity manager for for main activities.
2652         * src/main/java/org/glom/web/client/activity/ListActivity.java: New
2653         file from parts of the deleted OnlineGlomActivity.
2654         * src/main/java/org/glom/web/client/activity/TableSelectionActivity.java:
2655         New file from parts of the deleted OnlineGlomActivity.
2656         * src/main/java/org/glom/web/client/event/TableChangeEvent.java:
2657         * src/main/java/org/glom/web/client/event/TableChangeEventHandler.java:
2658         New files for app wide table change event.
2659         * src/main/java/org/glom/web/client/mvp/DataActivityMapper.java:
2660         * src/main/java/org/glom/web/client/mvp/DocumentSelectionActivityMapper.java:
2661         * src/main/java/org/glom/web/client/mvp/TableSelectionActivityMapper.java:
2662         Activity mappers for the main activities replace the deleted app-wide
2663         AppActivityMapper.
2664         * src/main/java/org/glom/web/client/ui/AuthenticationPopup.java:
2665         Fix a spelling error in he comment.
2666         * src/main/java/org/glom/web/client/ui/ListView.java:
2667         * src/main/java/org/glom/web/client/ui/ListViewImpl.java:
2668         Renamed from LayoutListView and modified for MVP. This still not a
2669         proper dumb view as prescribed by the MVP pattern but it works for now.
2670         * src/main/java/org/glom/web/client/ui/TableSelectionView.java:
2671         * src/main/java/org/glom/web/client/ui/TableSelectionViewImpl.java:
2672         New widget stripped out of the deleted OnlineGlomView.
2673         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2674         Remove hack that is fixed by this patch.
2675
2676 2011-05-06  Ben Konrath  <ben@bagu.org>
2677
2678         Rename OnlineGlomPlace to ListPlace.
2679
2680         The only change besides the rename is that url will now display #list
2681         instead of #Document.
2682
2683         * src/main/java/org/glom/web/client/activity/OnlineGlomActivity.java:
2684         * src/main/java/org/glom/web/client/mvp/AppActivityMapper.java:
2685         * src/main/java/org/glom/web/client/mvp/AppPlaceHistoryMapper.java:
2686         * src/main/java/org/glom/web/client/place/ListPlace.java:
2687         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.java:
2688
2689 2011-05-06  Ben Konrath  <ben@bagu.org>
2690
2691         Use Presenter for app navigation.
2692
2693         This is the proper way to deal with Place (URL) changes with the MVP
2694         framework.
2695
2696         * src/main/java/org/glom/web/client/ClientFactory.java:
2697         * src/main/java/org/glom/web/client/ClientFactoryImpl.java: Remove
2698         PlaceHistoryMapper and PlaceHistoryHandler.
2699         * src/main/java/org/glom/web/client/OnlineGlom.java: Re-add
2700         PlaceHistoryMapper and PlaceHistoryHandler.
2701         * src/main/java/org/glom/web/client/activity/DocumentSelectionActivity.java:
2702         Don't use getHistoryMapper().getToken(place) to create the hyperlinks.
2703         * src/main/java/org/glom/web/client/ui/DocumentSelectionView.java:
2704         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.java:
2705         Add Presenter interface and setPresenter methods. Rename addHyperLink
2706         to addDocumentLink taking only the document title as a parameter.
2707
2708 2011-04-14  Ben Konrath  <ben@bagu.org>
2709
2710         Prompt for db username/password if they haven't been set.
2711
2712         This is implemented with a popup widget that is contained within the
2713         OnlineGlomView and managed by the OnlineGlomActivity.
2714
2715         * src/main/java/org/glom/web/client/OnlineGlomService.java: Two new
2716         methods for checking and setting the database username and password.
2717         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java: Two
2718         new methods for checking and setting the database username and
2719         password.
2720         * src/main/java/org/glom/web/client/activity/OnlineGlomActivity.java:
2721         Display authentication popup if the JDBC connection to the database
2722         has not been authenticated.
2723         * src/main/java/org/glom/web/client/ui/AuthenticationPopup.java: New
2724         file.
2725         * src/main/java/org/glom/web/client/ui/OnlineGlomView.java: Add methods
2726         for dealing with the authentication popup.
2727         * src/main/java/org/glom/web/client/ui/OnlineGlomViewImpl.java:
2728         Implement the methods for dealing with the authentication popup.
2729         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Don't
2730         try to executed queries if the database connection hasn't been
2731         authenticated. Implement methods for checking and setting the
2732         database username and password.
2733
2734 2011-04-12  Ben Konrath  <ben@bagu.org>
2735
2736         Make log messages a little clearer.
2737
2738         Add a dash betweeen the document title and the table name.
2739
2740         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2741
2742 2011-04-12  Ben Konrath  <ben@bagu.org>
2743
2744         Protect against NPEs when cleaning up database resources.
2745
2746         While this isn't strictly necessary because the exception is caught,
2747         not protecting against the NPEs makes it harder to find the real error
2748         in the log file.
2749
2750         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2751
2752 2011-04-12  Ben Konrath  <ben@bagu.org>
2753
2754         Move configuration of the servlet to the constructor.
2755
2756         The servlet will be initialized even if the database authentication
2757         information is not set or correct. I still need to add the UI for prompting
2758         the user for the authentication information when it's required.
2759
2760         * src/main/java/org/glom/web/client/OnlineGlomService.java: Add
2761         javadocs for getDocumentTitles() method.
2762         * src/main/java/org/glom/web/client/activity/DocumentSelectionActivity.java:
2763         Set error message when RPC fails.
2764         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Get the
2765         glom files directory from the configuration file. Try to set the
2766         database authentication information for the specific document if it's
2767         set and works otherwise try to use the global authentication
2768         information set for the directory.
2769         * src/main/resources/onlineglom.properties: Moved from
2770         src/main/webapp/WEB-INF/OnlineGlom.properties. Updated with new keys.
2771         Added detailed comments for the new keys.
2772
2773 2011-04-11  Ben Konrath  <ben@bagu.org>
2774
2775         Remove unnecessary @Override in DocumentSelectionViewImpl.
2776
2777         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.java:
2778
2779 2011-04-11  Ben Konrath  <ben@bagu.org>
2780
2781         Remove center alignment in DocumentSelectionView.
2782
2783         The title element is still centred but the document titles and bottom
2784         sentence are both left-aligned.
2785
2786         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.ui.xml:
2787
2788 2011-04-11  Ben Konrath  <ben@bagu.org>
2789
2790         Change 'Demo' naming convention to 'Document'.
2791
2792         This is just a rename refactor with no functional changes to the code.
2793
2794         * src/main/java/org/glom/web/client/ClientFactory.java:
2795         * src/main/java/org/glom/web/client/ClientFactoryImpl.java:
2796         * src/main/java/org/glom/web/client/OnlineGlom.java:
2797         * src/main/java/org/glom/web/client/OnlineGlomService.java:
2798         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
2799         * src/main/java/org/glom/web/client/activity/DocumentSelectionActivity.java:
2800         * src/main/java/org/glom/web/client/mvp/AppActivityMapper.java:
2801         * src/main/java/org/glom/web/client/mvp/AppPlaceHistoryMapper.java:
2802         * src/main/java/org/glom/web/client/place/DocumentSelectionPlace.java:
2803         * src/main/java/org/glom/web/client/ui/DocumentSelectionView.java:
2804         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.java:
2805         * src/main/java/org/glom/web/client/ui/DocumentSelectionViewImpl.ui.xml:
2806         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2807
2808 2011-04-08  Ben Konrath  <ben@bagu.org>
2809
2810         Remove FIXME from safeLongToInt() method.
2811
2812         Libglom uses longs on 32-bit and 64-bit platforms so it's ok to use
2813         this method.
2814
2815         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2816
2817 2011-04-08  Ben Konrath  <ben@bagu.org>
2818
2819         Display an error if no glom documents are found in the specified directory.
2820
2821         * src/main/java/org/glom/web/client/activity/DemoSelectionActivity.java:
2822         * src/main/java/org/glom/web/client/ui/DemoSelectionView.java:
2823         * src/main/java/org/glom/web/client/ui/DemoSelectionViewImpl.java:
2824         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2825
2826 2011-04-08  Ben Konrath  <ben@bagu.org>
2827
2828         Add copyright header to one more file ... oops.
2829
2830         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java:
2831
2832 2011-04-08  Ben Konrath  <ben@bagu.org>
2833
2834         Add copyright header to files without it.
2835
2836         * src/main/java/org/glom/web/client/activity/DemoSelectionActivity.java:
2837         * src/main/java/org/glom/web/client/place/DemoSelectionPlace.java:
2838         * src/main/java/org/glom/web/client/ui/DemoSelectionView.java:
2839         * src/main/java/org/glom/web/client/ui/DemoSelectionViewImpl.java:
2840         * src/main/java/org/glom/web/shared/ColumnInfo.java:
2841         * src/main/java/org/glom/web/shared/GlomField.java:
2842
2843 2011-04-08  Ben Konrath  <ben@bagu.org>
2844
2845         Add support for accessing multiple glom documents in the servlet.
2846
2847         This completes the demo selection functionality.
2848
2849         * src/main/java/org/glom/web/client/OnlineGlomService.java: Add
2850         document title to methods.
2851         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java: Add
2852         document title to methods.
2853         * src/main/java/org/glom/web/client/activity/DemoSelectionActivity.java:
2854         Set browser window title when the activity starts. Correct name of
2855         document title variable.
2856         * src/main/java/org/glom/web/client/activity/OnlineGlomActivity.java:
2857         Set browser window title when the activity starts. Set the table
2858         selector change handler after table selector has been set. Clear the
2859         OnlineGlomView when the activity has been stopped.
2860         * src/main/java/org/glom/web/client/place/OnlineGlomPlace.java: Use the
2861         document title as the place token. Use "#Document:" instead of
2862         "#OnlineGlomPlace:" in the URL.
2863         * src/main/java/org/glom/web/client/ui/DemoSelectionViewImpl.ui.xml:
2864         Change heading to "Online Glom"
2865         * src/main/java/org/glom/web/client/ui/LayoutListView.java: Use
2866         document title in RPC methods.
2867         * src/main/java/org/glom/web/client/ui/OnlineGlomView.java: Remove
2868         setDocumentTitle() method. Add clear() method.
2869         * src/main/java/org/glom/web/client/ui/OnlineGlomViewImpl.java: Remove
2870         setDocumentTitle() method. Implement clear() method which removes the
2871         change handler on the ListBox, clears the ListBox and clears the
2872         DataPanel.
2873         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
2874         Implement methods with document title. Keep track for the configured
2875         glom documents and their corresponding JDBC configurations in a hash
2876         table. This information is retrieved using the document title as the
2877         key in the hash table.
2878         * src/main/java/org/glom/web/shared/GlomDocument.java: Remove
2879         document title field as it's no longer needed.
2880
2881 2011-04-08  Ben Konrath  <ben@bagu.org>
2882
2883         Update the Eclipse JDT configuration.
2884
2885         * .settings/org.eclipse.jdt.ui.prefs: Automatically add comments to new
2886         methods. Automatically add the copyright header to new files.
2887
2888 2011-04-05  Ben Konrath  <ben@bagu.org>
2889
2890         Add new page for demo selection.
2891
2892         This patch adds all the components required to view and start an
2893         OnlineGlom demo by clicking on the desired hyperlink. The user is
2894         able to return to the demo selection page with the browser's back
2895         button. I still need to modify the servlet to work with multiple
2896         documents so all demo links will load the file defined in the
2897         OnlineGlom.properties.
2898
2899         * .gitignore: Add .gwt which holds the error log for the GWT UiBuidler.
2900         This is only useful during development so we don't need to save it.
2901         * src/main/java/org/glom/web/client/ClientFactory.java: Add method to
2902         get a reference to the DemoSelectionView.
2903         * src/main/java/org/glom/web/client/ClientFactoryImpl.java: Implement
2904         method to get a reference to the DemoSelectionView.
2905         * src/main/java/org/glom/web/client/OnlineGlom.java: Change the
2906         default view to DemoSelectionView.
2907         * src/main/java/org/glom/web/client/OnlineGlomService.java: Add method
2908         to get glom document titles for glom files in a hard-coded directory.
2909         * src/main/java/org/glom/web/client/OnlineGlomServiceAsync.java: Add
2910         method to get glom document titles for glom files in a hard-coded
2911         directory.
2912         * src/main/java/org/glom/web/client/activity/DemoSelectionActivity.java:
2913         Presenter for DemoSelectionView.
2914         * src/main/java/org/glom/web/client/mvp/AppActivityMapper.java: Update
2915         for DemoSelectionView.
2916         * src/main/java/org/glom/web/client/mvp/AppPlaceHistoryMapper.java:
2917         Update for DemoSelectionView.
2918         * src/main/java/org/glom/web/client/place/DemoSelectionPlace.java:
2919         Basic 'Place' implementation for the DemoSelectionView.
2920         * src/main/java/org/glom/web/client/ui/DemoSelectionView.java:
2921         The interface for the DemoSelectionView.
2922         * src/main/java/org/glom/web/client/ui/DemoSelectionViewImpl.java:
2923         The implementation of the DemoSelectionView.
2924         * src/main/java/org/glom/web/client/ui/DemoSelectionViewImpl.ui.xml:
2925         The GWT UiBuilder xml file used in DemoSelectionViewImpl.
2926         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Add
2927         implementation of method to get glom document titles for glom files
2928         in a hard-coded directory.
2929         * src/main/webapp/OnlineGlom.html: Remove link to CSS file as it's
2930         on longer being used.
2931         * src/main/webapp/glom.png: Glom logo.
2932
2933 2011-04-05  Ben Konrath  <ben@bagu.org>
2934
2935         Move RPC code from OnlineGlomViewImpl to OnlineGlomActivity.
2936
2937         This is the forth and final commit of a refactor that will allow
2938         OnlineGlom to be used with multiple documents.
2939
2940         * src/main/java/org/glom/web/client/activity/OnlineGlomActivity.java:
2941         Move RPC code from OnlineGlomViewImpl to this class.
2942         * src/main/java/org/glom/web/client/ui/OnlineGlomView.java: Add methods
2943         to inferface.
2944         * src/main/java/org/glom/web/client/ui/OnlineGlomViewImpl.java: Move
2945         RPC code to the presenter class (the P in MVP).
2946
2947 2011-04-04  Ben Konrath  <ben@bagu.org>
2948
2949         Start moving the existing OnlineGlom code to MVP.
2950
2951         This work is based on the GWT MVP framework that is documented here:
2952
2953         https://code.google.com/webtoolkit/doc/2.2/DevGuideMvpActivitiesAndPlaces.html
2954
2955         This is the third commit of a refactor that will allow OnlineGlom to
2956         be used with multiple documents.
2957
2958         * src/main/java/org/glom/web/client/ClientFactory.java: New file.
2959         Interface for client factory which is used to get instances of various
2960         classes throughout the app.
2961         * src/main/java/org/glom/web/client/ClientFactoryImpl.java: New file.
2962         Implementation of client factory.
2963         * src/main/java/org/glom/web/client/OnlineGlom.java: Add code to
2964         initialize the MVP framework.
2965         * src/main/java/org/glom/web/client/activity/OnlineGlomActivity.java:
2966         New file. Activity manager for the main container widget. This is the
2967         Presenter in MVP.
2968         * src/main/java/org/glom/web/client/mvp/AppActivityMapper.java: New file.
2969         Maps place (URL) to its corresponding activity.
2970         * src/main/java/org/glom/web/client/mvp/AppPlaceHistoryMapper.java:
2971         New file. This is just a place holder for a generated file.
2972         * src/main/java/org/glom/web/client/place/OnlineGlomPlace.java:
2973         New file. Represents the URL for the main Online Glom app.
2974         * src/main/java/org/glom/web/client/ui/LayoutListView.java: Update
2975         for changes in LayoutListViewImpl.
2976         * src/main/java/org/glom/web/client/ui/OnlineGlomView.java: Create
2977         interface for View. Move code to OnlineGlomViewImpl class.
2978         * src/main/java/org/glom/web/client/ui/OnlineGlomViewImpl.java: New
2979         file. Implementation of OnlineGlomView.
2980         * src/main/resources/org/glom/web/OnlineGlom.gwt.xml: Add Activity and
2981         Place resources. Use ClientFactoryImpl by default.
2982
2983 2011-04-04  Ben Konrath  <ben@bagu.org>
2984
2985         Move View classes to their own package.
2986
2987         This is the second commit of a refactor that will allow OnlineGlom to
2988         be used with multiple documents.
2989
2990         * src/main/java/org/glom/web/client/OnlineGlom.java:
2991         * src/main/java/org/glom/web/client/ui/LayoutListView.java:
2992         * src/main/java/org/glom/web/client/ui/OnlineGlomView.java:
2993
2994 2011-04-02  Ben Konrath  <ben@bagu.org>
2995
2996         Move UI code from the main module to its own class.
2997
2998         This is the first commit of a refactor that will allow OnlineGlom to be
2999         used with multiple documents.
3000
3001         * src/main/java/org/glom/web/client/LayoutListView.java: Update
3002         references to OnlineGlom to OnlineGlomView.
3003         * src/main/java/org/glom/web/client/OnlineGlom.java: Move code to
3004         OnlineGlomView and instantiate it here.
3005         * src/main/java/org/glom/web/client/OnlineGlomView.java: New class that
3006         represents the main OnlineGlomView with one document.
3007
3008 2011-04-01  Ben Konrath  <ben@bagu.org>
3009
3010         Fix formatting of gwt.xml and add DTD.
3011
3012         * src/main/resources/org/glom/web/OnlineGlom.gwt.xml:
3013
3014 2011-03-30  Ben Konrath  <ben@bagu.org>
3015
3016         Propperly convert gdkColor string to html colour string.
3017
3018         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
3019
3020 2011-03-28  Ben Konrath  <ben@bagu.org>
3021
3022         Change implementation of OnlineGlomServiceImpl.getColumnInfoHorizontalAlignment().
3023
3024         This implementation matches
3025         OnlineGlomServiceImpl.getColumnInfoGlomFieldType(), should perform better, is more
3026         readable and is not tied to Swig.
3027
3028         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
3029
3030 2011-03-28  Ben Konrath  <ben@bagu.org>
3031
3032         Use read-only checkboxes for boolean field types.
3033
3034         * src/main/java/org/glom/web/client/LayoutListView.java: Create columns
3035         in the CellTable based on the field type. It currently only
3036         distinguishes between boolean and text columns but I'll need to add
3037         support for more types.
3038         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Set the
3039         column type in the ColumnInfo object. Add method to convert between the
3040         glom field type enum in ColumnInfo and the glom field type in libglom.
3041         * src/main/java/org/glom/web/shared/ColumnInfo.java: Add support for
3042         field type.
3043         * src/main/java/org/glom/web/shared/GlomField.java: Add support for
3044         getting and setting booleans.
3045
3046 2011-03-25  Ben Konrath  <ben@bagu.org>
3047
3048         Don't get the Date twice from the ResultSet.
3049
3050         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
3051
3052 2011-03-25  Ben Konrath  <ben@bagu.org>
3053
3054         Cleanup code in the servlet.
3055
3056         * TODO: Remove item about row count. Add item about testing row count
3057         query with large number of rows.
3058         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Fix
3059         spelling mistakes, change method parameter to be consistent with
3060         other methods.
3061
3062 2011-03-25  Ben Konrath  <ben@bagu.org>
3063
3064         Add server side logging with the gwt-log library.
3065
3066         * .gitignore: Ignore the log file we're now producing.
3067         * TODO: Add a couple TODO item for logging.
3068         * pom.xml: Add gwt-log and log4j as a dependency.
3069         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Add
3070         logging of errors, warnings and some important info.
3071         * src/main/resources/log4j.properties: New file to configure log4j.
3072
3073 2011-03-24  Ben Konrath  <ben@bagu.org>
3074
3075         Add a disable button for the Details view.
3076
3077         * src/main/java/org/glom/web/client/LayoutListView.java:
3078
3079 2011-03-22  Ben Konrath  <ben@bagu.org>
3080
3081         Use a count query to get the number of rows for the list view pager.
3082
3083         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
3084
3085 2011-03-22  Ben Konrath  <ben@bagu.org>
3086
3087         Add more TODO information about CellTable pager positioning. 
3088
3089         * TODO:
3090
3091 2011-03-19  Ben Konrath  <ben@bagu.org>
3092
3093         Add TODO item about CellTable pager positioning.
3094
3095         * TODO:
3096
3097 2011-03-18  Ben Konrath  <ben@bagu.org>
3098
3099         Remove unneeded GlomFieldColumn class.
3100
3101         This is just a small code cleanup.
3102
3103         * src/main/java/org/glom/web/client/LayoutListView.java:
3104
3105 2011-03-18  Ben Konrath  <ben@bagu.org>
3106
3107         Use cursor mode in the query that gets data for the list view.
3108
3109         I still need to fix the potential memory problem when getting the row
3110         count for the list view.
3111
3112         * TODO: Add note about testing memory usage with large data sets. Add
3113         item about fixing row counting with large data sets.
3114         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Put the
3115         PostgreSQL JDBC driver into cursor mode when getting data for the
3116         list view.
3117
3118 2011-03-15  Ben Konrath  <ben@bagu.org>
3119
3120         Remove the GWT Container from the Eclipse build classpath.
3121
3122         The GWT dependencies are set by Maven so this isn't needed.
3123
3124         * .classpath:
3125
3126 2011-03-15  Murray Cumming  <murrayc@murrayc.com>
3127
3128         Added some earlier mockups to git, but not to the tarball dist.
3129
3130         * mockups/: Added some mockups from 2010-02 by Daniel Borgmann for
3131         Openismus. These hopefully show how we might structure the HTML so that
3132         it can be styled easily with CSS. However, we probably need to adapt them
3133         for the CSS structure that GWT dictates for common widgets.
3134
3135 2011-03-14  Ben Konrath  <ben@bagu.org>
3136
3137         Locate OnlineGlom.properties using the ServletContext.
3138
3139         This is required to be able to locate the file in the deployed servlet.
3140
3141         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
3142         Configure the database and glom document in in a helper method so
3143         that the ServletContext can be used to locate OnlineGlom.properties.
3144         * src/main/webapp/WEB-INF/OnlineGlom.properties: Moved from
3145         src/main/webapp. This is the proper location for .properites files.
3146
3147 2011-03-12  Ben Konrath  <ben@bagu.org>
3148
3149         Add note to README about why we're compiling down to obfuscated JavaScript.
3150
3151         * README:
3152
3153 2011-03-11  Ben Konrath  <ben@bagu.org>
3154
3155         Use properties file to configure servlet.
3156
3157         This allows people to change the glom file path, db username and db
3158         password without recompiling the code.
3159
3160         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
3161         * src/main/webapp/OnlineGlom.properties:
3162
3163 2011-03-11  Ben Konrath  <ben@bagu.org>
3164
3165         Use table fields in layout list view if the layout list is not defined.
3166
3167         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
3168         Manually create a LayoutFieldVector for the query builder using the
3169         table fields when a layout list is not defined in the glom file.
3170
3171 2011-03-11  Ben Konrath  <ben@bagu.org>
3172
3173         Only show FIXME string for images when there's an image.
3174
3175         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Also included
3176         in this change are some small code cleanups.
3177
3178 2011-03-11  Ben Konrath  <ben@bagu.org>
3179
3180         Set text for fields with TYPE_IMAGE and TYPE_INVALID to avoid NPEs.
3181
3182         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
3183
3184 2011-03-11  Ben Konrath  <ben@bagu.org>
3185
3186         Correctly set the index of the default table.
3187
3188         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java:
3189         Correctly set the index of the default table. Add commented out example
3190         file paths.
3191
3192 2011-03-10  Ben Konrath  <ben@bagu.org>
3193
3194         Add comment to pom.xml about the previous change.
3195
3196         * pom.xml: Add comment about the deployment issue so that it's obvious
3197         why java-libglom is set to the provided scope.
3198
3199 2011-03-10  Ben Konrath  <ben@bagu.org>
3200
3201         Change java-libglom dependency from compile to provided in pom.xml.
3202
3203         Since java-libglom uses jni it can only be loaded once and therefore
3204         must be placed in $CATALINA_HOME/lib and not included in each war.
3205         This directory is defined as /usr/share/tomcat6/lib/ on Ubuntu 10.04.
3206         More information about this issue can be found in the Tomcat 6 release
3207         notes in the "JNI Based Applications" section:
3208
3209         http://tomcat.apache.org/tomcat-6.0-doc/RELEASE-NOTES.txt
3210
3211         * README: Remove note about this issue. Deployment info should really
3212         be on the wiki anyway so I'll add it right now.
3213         * pom.xml: Change java-libglom dependency from compile to provided so
3214         that it's copied in to the packaged war.
3215
3216 2011-03-09  Ben Konrath  <ben@bagu.org>
3217
3218         Change to using a neutral locale for currency, date and time formatting.
3219
3220         This solves the problem of currency values being represented without a
3221         space between the currency code and the number (e.g. "EUR5.89" is now
3222         represented as "EUR 5.89"). More work is required when we implement
3223         a locale preference setting.
3224
3225         * TODO: Add note about currency formatting issues with different
3226         locales.
3227         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Change
3228         to using the neutral ROOT locale.
3229
3230 2011-03-09  Ben Konrath  <ben@bagu.org>
3231
3232         Add support for currency codes that are not ISO 4217 codes.
3233
3234         * src/main/java/org/glom/web/server/OnlineGlomServiceImpl.java: Use
3235         the currency code defined in the glom file when it's not 3 characters
3236         long or when Java doesn't recognize the string as an ISO 4217 code.
3237