Reports: Add option to display a table of data beneath barcharts.

Patch by Joachim Herb.
BP


git-svn-id: svn+ssh://svn.gnucash.org/repo/gnucash/trunk@17316 57a11ea4-9604-0410-9ed3-97b8803252fd
This commit is contained in:
Charles Day 2008-07-12 17:01:27 +00:00
parent 6454d1d6bf
commit 43e2e82482
3 changed files with 132 additions and 4 deletions

View File

@ -161,6 +161,7 @@ Alexandru Harsanyi <haral@codec.ro> for core dumps, lockups, gtk work
John Hasler <john@dhh.gt.org> engine patch
Jon Kåre Hellan <hellan@acm.org> misc core dump fixes
Hendrik-Jan Heins <hjh@passys.nl> Dutch translation
Joachim Herb <joachim.herb@gmx.de> Data table option for barchart reports
Claus Hindsgaul <claus_h@image.dk> messages Danish translation
Ori Hoch <ori@uumpa.com> Hebrew translation
Péter Hosszú <hosszu@web.de> Hungarian translation

View File

@ -146,13 +146,20 @@ developing over time"))
"c" (N_ "Maximum number of bars in the chart") 8
2 24 0 1))
(add-option
(gnc:make-simple-boolean-option
gnc:pagename-display
(N_ "Show table")
"d" (N_ "Display a table of the selected data.")
#f))
(gnc:options-add-plot-size!
options gnc:pagename-display
optname-plot-width optname-plot-height "d" 400 400)
optname-plot-width optname-plot-height "e" 400 400)
(gnc:options-add-sort-method!
options gnc:pagename-display
optname-sort-method "e" 'amount)
optname-sort-method "f" 'amount)
(gnc:options-set-default-section options gnc:pagename-general)
@ -209,8 +216,10 @@ developing over time"))
(work-done 0)
(work-to-do 0)
(show-table? (get-option gnc:pagename-display (N_ "Show table")))
(document (gnc:make-html-document))
(chart (gnc:make-html-barchart))
(table (gnc:make-html-table))
(topl-accounts (gnc:filter-accountlist-type
account-types
(gnc-account-get-children-sorted
@ -518,7 +527,79 @@ developing over time"))
chart (append urls urls)))
(gnc:report-percent-done 98)
(gnc:html-document-add-object! document chart))
(gnc:html-document-add-object! document chart)
(if show-table?
(begin
(gnc:html-table-append-column! table date-string-list)
(letrec
((addcol
(lambda (col)
(if (not (null? col))
(begin
(gnc:html-table-append-column!
table (car col))
(addcol (cdr col))
)
))
))
(addcol (map cadr all-data))
)
(gnc:html-table-set-col-headers!
table
(append
(list (_ "Date"))
(map (lambda (pair)
(regexp-substitute/global #f "&"
(if (string? (car pair))
(car pair)
((if show-fullname?
gnc-account-get-full-name
xaccAccountGetName) (car pair)))
'pre " " (_ "and") " " 'post))
all-data)
(if (> (gnc:html-table-num-columns table) 2)
(list (_ "Grand Total"))
(list nil)
)
))
(if (> (gnc:html-table-num-columns table) 2)
(letrec
((sumtot
(lambda (row)
(if (null? row)
'()
(cons (sumrow (car row)) (sumtot (cdr row)))
)
)
)
(sumrow
(lambda (row)
(if (not (null? row))
(+ (car row) (sumrow (cdr row)))
0
)
)
))
(gnc:html-table-append-column!
table
(sumtot (apply zip (map cadr all-data)))
)
)
)
;; set numeric columns to align right
(for-each
(lambda (col)
(gnc:html-table-set-col-style!
table col "td"
'attribute (list "align" "right")))
'(1 2 3 4 5 6 7 8 9 10 11 12 13 14))
(gnc:html-document-add-object! document table)
) ;; begin if
)
)
;; else if empty data
(gnc:html-document-add-object!

View File

@ -120,9 +120,16 @@
(N_ "Show a Net Worth bar?"))
#t))
(add-option
(gnc:make-simple-boolean-option
gnc:pagename-display
(N_ "Show table")
"c" (N_ "Display a table of the selected data.")
#f))
(gnc:options-add-plot-size!
options gnc:pagename-display
optname-plot-width optname-plot-height "c" 500 400)
optname-plot-width optname-plot-height "d" 500 400)
(gnc:options-set-default-section options gnc:pagename-general)
@ -179,6 +186,7 @@
(report-title (get-option gnc:pagename-general
gnc:optname-reportname))
(classified-accounts (gnc:decompose-accountlist accounts))
(show-table? (get-option gnc:pagename-display (N_ "Show table")))
(document (gnc:make-html-document))
(chart (gnc:make-html-barchart))
(non-zeros #f))
@ -356,7 +364,45 @@
;; Test for all-zero data here.
(if non-zeros
(begin
(gnc:html-document-add-object! document chart)
(if show-table?
(let ((table (gnc:make-html-table)))
(gnc:html-table-set-col-headers!
table
(append
(list (_ "Date"))
(if show-sep?
(if inc-exp?
(list (_ "Income") (_ "Expense"))
(list (_ "Assets") (_ "Liabilities")))
'())
(if show-net?
(if inc-exp?
(list (_ "Net Profit"))
(list (_ "Net Worth")))
'()))
)
(gnc:html-table-append-column! table date-string-list)
(if show-sep?
(begin
(gnc:html-table-append-column! table assets-list)
(gnc:html-table-append-column! table liability-list)
)
)
(if show-net?
(gnc:html-table-append-column! table net-list)
)
;; set numeric columns to align right
(for-each
(lambda (col)
(gnc:html-table-set-col-style!
table col "td"
'attribute (list "align" "right")))
'(1 2 3))
(gnc:html-document-add-object! document table))
))
(gnc:html-document-add-object!
document
(gnc:html-make-empty-data-warning