mirror of
https://github.com/simonmichael/hledger.git
synced 2024-12-31 22:31:54 +03:00
lib: multiBalanceReport: Change indentation.
This commit is contained in:
parent
0b30b2f9fb
commit
baa5844d4e
@ -91,115 +91,115 @@ multiBalanceReport today ropts j =
|
|||||||
-- function directly.
|
-- function directly.
|
||||||
multiBalanceReportWith :: ReportOpts -> Query -> Journal -> PriceOracle -> MultiBalanceReport
|
multiBalanceReportWith :: ReportOpts -> Query -> Journal -> PriceOracle -> MultiBalanceReport
|
||||||
multiBalanceReportWith ropts@ReportOpts{..} q j priceoracle =
|
multiBalanceReportWith ropts@ReportOpts{..} q j priceoracle =
|
||||||
(if invert_ then prNegate else id) $
|
(if invert_ then prNegate else id) $
|
||||||
PeriodicReport colspans mappedsortedrows mappedtotalsrow
|
PeriodicReport colspans mappedsortedrows mappedtotalsrow
|
||||||
where
|
where
|
||||||
----------------------------------------------------------------------
|
----------------------------------------------------------------------
|
||||||
-- 1. Queries, report/column dates.
|
-- 1. Queries, report/column dates.
|
||||||
|
|
||||||
depthq = dbg "depthq" $ filterQuery queryIsDepth q
|
depthq = dbg "depthq" $ filterQuery queryIsDepth q
|
||||||
depth = queryDepth depthq
|
depth = queryDepth depthq
|
||||||
-- The date span specified by -b/-e/-p options and query args if any.
|
-- The date span specified by -b/-e/-p options and query args if any.
|
||||||
requestedspan = dbg "requestedspan" $ queryDateSpan date2_ q
|
requestedspan = dbg "requestedspan" $ queryDateSpan date2_ q
|
||||||
-- If the requested span is open-ended, close it using the journal's end dates.
|
-- If the requested span is open-ended, close it using the journal's end dates.
|
||||||
-- This can still be the null (open) span if the journal is empty.
|
-- This can still be the null (open) span if the journal is empty.
|
||||||
requestedspan' = dbg "requestedspan'" $ requestedspan `spanDefaultsFrom` journalDateSpan date2_ j
|
requestedspan' = dbg "requestedspan'" $ requestedspan `spanDefaultsFrom` journalDateSpan date2_ j
|
||||||
-- The list of interval spans enclosing the requested span.
|
-- The list of interval spans enclosing the requested span.
|
||||||
-- This list can be empty if the journal was empty,
|
-- This list can be empty if the journal was empty,
|
||||||
-- or if hledger-ui has added its special date:-tomorrow to the query
|
-- or if hledger-ui has added its special date:-tomorrow to the query
|
||||||
-- and all txns are in the future.
|
-- and all txns are in the future.
|
||||||
intervalspans = dbg "intervalspans" $ splitSpan interval_ requestedspan'
|
intervalspans = dbg "intervalspans" $ splitSpan interval_ requestedspan'
|
||||||
-- The requested span enlarged to enclose a whole number of intervals.
|
-- The requested span enlarged to enclose a whole number of intervals.
|
||||||
-- This can be the null span if there were no intervals.
|
-- This can be the null span if there were no intervals.
|
||||||
reportspan = dbg "reportspan" $ DateSpan (maybe Nothing spanStart $ headMay intervalspans)
|
reportspan = dbg "reportspan" $ DateSpan (maybe Nothing spanStart $ headMay intervalspans)
|
||||||
(maybe Nothing spanEnd $ lastMay intervalspans)
|
(maybe Nothing spanEnd $ lastMay intervalspans)
|
||||||
-- The user's query with no depth limit, and expanded to the report span
|
-- The user's query with no depth limit, and expanded to the report span
|
||||||
-- if there is one (otherwise any date queries are left as-is, which
|
-- if there is one (otherwise any date queries are left as-is, which
|
||||||
-- handles the hledger-ui+future txns case above).
|
-- handles the hledger-ui+future txns case above).
|
||||||
reportq = dbg "reportq" $ makeReportQuery ropts reportspan q
|
reportq = dbg "reportq" $ makeReportQuery ropts reportspan q
|
||||||
|
|
||||||
-- The matched accounts with a starting balance. All of these shold appear
|
-- The matched accounts with a starting balance. All of these shold appear
|
||||||
-- in the report, even if they have no postings during the report period.
|
-- in the report, even if they have no postings during the report period.
|
||||||
startbals = dbg' "startbals" $ startingBalances ropts reportq j reportspan
|
startbals = dbg' "startbals" $ startingBalances ropts reportq j reportspan
|
||||||
-- The matched accounts with a starting balance. All of these should appear
|
-- The matched accounts with a starting balance. All of these should appear
|
||||||
-- in the report even if they have no postings during the report period.
|
-- in the report even if they have no postings during the report period.
|
||||||
startaccts = dbg'' "startaccts" $ HM.keys startbals
|
startaccts = dbg'' "startaccts" $ HM.keys startbals
|
||||||
|
|
||||||
-- Postings matching the query within the report period.
|
-- Postings matching the query within the report period.
|
||||||
ps :: [(Posting, Day)] = dbg'' "ps" $ getPostings ropts reportq j
|
ps :: [(Posting, Day)] = dbg'' "ps" $ getPostings ropts reportq j
|
||||||
days = map snd ps
|
days = map snd ps
|
||||||
|
|
||||||
-- The date spans to be included as report columns.
|
-- The date spans to be included as report columns.
|
||||||
colspans = dbg "colspans" $ calculateColSpans ropts reportspan days
|
colspans = dbg "colspans" $ calculateColSpans ropts reportspan days
|
||||||
|
|
||||||
-- Group postings into their columns.
|
-- Group postings into their columns.
|
||||||
colps = dbg'' "colps" $ calculateColumns colspans ps
|
colps = dbg'' "colps" $ calculateColumns colspans ps
|
||||||
|
|
||||||
-- Each account's balance changes across all columns.
|
-- Each account's balance changes across all columns.
|
||||||
acctchanges = dbg'' "acctchanges" $ calculateAccountChanges ropts q startbals colps
|
acctchanges = dbg'' "acctchanges" $ calculateAccountChanges ropts q startbals colps
|
||||||
|
|
||||||
-- Process changes into normal, cumulative, or historical amounts, plus value them
|
-- Process changes into normal, cumulative, or historical amounts, plus value them
|
||||||
accumvalued = dbg'' "accumvalued" $ accumValueAmounts ropts j priceoracle startbals acctchanges
|
accumvalued = dbg'' "accumvalued" $ accumValueAmounts ropts j priceoracle startbals acctchanges
|
||||||
|
|
||||||
-- All account names that will be displayed, possibly depth-clipped.
|
-- All account names that will be displayed, possibly depth-clipped.
|
||||||
displayaccts :: [ClippedAccountName] =
|
displayaccts :: [ClippedAccountName] =
|
||||||
dbg'' "displayaccts" $
|
dbg'' "displayaccts" $
|
||||||
(if tree_ ropts then expandAccountNames else id) $
|
(if tree_ ropts then expandAccountNames else id) $
|
||||||
nub $ map (clipOrEllipsifyAccountName depth) $
|
nub $ map (clipOrEllipsifyAccountName depth) $
|
||||||
if empty_ || balancetype_ == HistoricalBalance
|
if empty_ || balancetype_ == HistoricalBalance
|
||||||
then nubSort $ startaccts ++ allpostedaccts
|
then nubSort $ startaccts ++ allpostedaccts
|
||||||
else allpostedaccts
|
else allpostedaccts
|
||||||
where
|
where
|
||||||
allpostedaccts :: [AccountName] =
|
allpostedaccts :: [AccountName] =
|
||||||
dbg'' "allpostedaccts" . sort . accountNamesFromPostings $ map fst ps
|
dbg'' "allpostedaccts" . sort . accountNamesFromPostings $ map fst ps
|
||||||
|
|
||||||
-- All the rows of the report.
|
-- All the rows of the report.
|
||||||
rows = dbg'' "rows" $ buildReportRows ropts reportq accumvalued
|
rows = dbg'' "rows" $ buildReportRows ropts reportq accumvalued
|
||||||
|
|
||||||
-- Sorted report rows.
|
-- Sorted report rows.
|
||||||
sortedrows = dbg' "sortedrows" $ sortRows ropts j rows
|
sortedrows = dbg' "sortedrows" $ sortRows ropts j rows
|
||||||
|
|
||||||
----------------------------------------------------------------------
|
----------------------------------------------------------------------
|
||||||
-- 8. Build the report totals row.
|
-- 8. Build the report totals row.
|
||||||
|
|
||||||
-- Calculate the column totals. These are always the sum of column amounts.
|
-- Calculate the column totals. These are always the sum of column amounts.
|
||||||
highestlevelaccts = [a | a <- displayaccts, not $ any (`elem` displayaccts) $ init $ expandAccountName a]
|
highestlevelaccts = [a | a <- displayaccts, not $ any (`elem` displayaccts) $ init $ expandAccountName a]
|
||||||
colamts = transpose . map prrAmounts $ filter isHighest rows
|
colamts = transpose . map prrAmounts $ filter isHighest rows
|
||||||
where isHighest row = not (tree_ ropts) || prrName row `elem` highestlevelaccts
|
where isHighest row = not (tree_ ropts) || prrName row `elem` highestlevelaccts
|
||||||
coltotals :: [MixedAmount] =
|
coltotals :: [MixedAmount] =
|
||||||
dbg'' "coltotals" $ map sum colamts
|
dbg'' "coltotals" $ map sum colamts
|
||||||
-- Calculate the grand total and average. These are always the sum/average
|
-- Calculate the grand total and average. These are always the sum/average
|
||||||
-- of the column totals.
|
-- of the column totals.
|
||||||
[grandtotal,grandaverage] =
|
[grandtotal,grandaverage] =
|
||||||
let amts = map ($ map sum colamts)
|
let amts = map ($ map sum colamts)
|
||||||
[if balancetype_==PeriodChange then sum else const 0
|
[if balancetype_==PeriodChange then sum else const 0
|
||||||
,averageMixedAmounts
|
,averageMixedAmounts
|
||||||
]
|
]
|
||||||
in amts
|
in amts
|
||||||
-- Totals row.
|
-- Totals row.
|
||||||
totalsrow :: PeriodicReportRow () MixedAmount =
|
totalsrow :: PeriodicReportRow () MixedAmount =
|
||||||
dbg' "totalsrow" $ PeriodicReportRow () 0 coltotals grandtotal grandaverage
|
dbg' "totalsrow" $ PeriodicReportRow () 0 coltotals grandtotal grandaverage
|
||||||
|
|
||||||
----------------------------------------------------------------------
|
----------------------------------------------------------------------
|
||||||
-- 9. Map the report rows to percentages if needed
|
-- 9. Map the report rows to percentages if needed
|
||||||
-- It is not correct to do this before step 6 due to the total and average columns.
|
-- It is not correct to do this before step 6 due to the total and average columns.
|
||||||
-- This is not done in step 6, since the report totals are calculated in 8.
|
-- This is not done in step 6, since the report totals are calculated in 8.
|
||||||
-- Perform the divisions to obtain percentages
|
-- Perform the divisions to obtain percentages
|
||||||
mappedsortedrows :: [MultiBalanceReportRow] =
|
mappedsortedrows :: [MultiBalanceReportRow] =
|
||||||
if not percent_ then sortedrows
|
if not percent_ then sortedrows
|
||||||
else dbg'' "mappedsortedrows"
|
else dbg'' "mappedsortedrows"
|
||||||
[ PeriodicReportRow aname alevel
|
[ PeriodicReportRow aname alevel
|
||||||
(zipWith perdivide rowvals coltotals)
|
(zipWith perdivide rowvals coltotals)
|
||||||
(rowtotal `perdivide` grandtotal)
|
(rowtotal `perdivide` grandtotal)
|
||||||
(rowavg `perdivide` grandaverage)
|
(rowavg `perdivide` grandaverage)
|
||||||
| PeriodicReportRow aname alevel rowvals rowtotal rowavg <- sortedrows
|
| PeriodicReportRow aname alevel rowvals rowtotal rowavg <- sortedrows
|
||||||
]
|
]
|
||||||
mappedtotalsrow :: PeriodicReportRow () MixedAmount
|
mappedtotalsrow :: PeriodicReportRow () MixedAmount
|
||||||
| percent_ = dbg'' "mappedtotalsrow" $ PeriodicReportRow () 0
|
| percent_ = dbg'' "mappedtotalsrow" $ PeriodicReportRow () 0
|
||||||
(map (\t -> perdivide t t) coltotals)
|
(map (\t -> perdivide t t) coltotals)
|
||||||
(perdivide grandtotal grandtotal)
|
(perdivide grandtotal grandtotal)
|
||||||
(perdivide grandaverage grandaverage)
|
(perdivide grandaverage grandaverage)
|
||||||
| otherwise = totalsrow
|
| otherwise = totalsrow
|
||||||
|
|
||||||
|
|
||||||
-- | Calculate starting balances, if needed for -H
|
-- | Calculate starting balances, if needed for -H
|
||||||
|
Loading…
Reference in New Issue
Block a user