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