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