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