mirror of https://github.com/snachodog/mybuddy.git
breakout feeding types
This commit is contained in:
parent
acde3156c6
commit
8c34075696
|
@ -7,30 +7,63 @@ import plotly.graph_objs as go
|
||||||
|
|
||||||
from reports import utils
|
from reports import utils
|
||||||
|
|
||||||
|
|
||||||
def feeding_amounts(instances):
|
def feeding_amounts(instances):
|
||||||
"""
|
"""
|
||||||
Create a graph showing daily feeding amounts over time.
|
Create a graph showing daily feeding amounts over time.
|
||||||
:param instances: a QuerySet of Feeding instances.
|
:param instances: a QuerySet of Feeding instances.
|
||||||
:returns: a tuple of the the graph's html and javascript.
|
:returns: a tuple of the the graph's html and javascript.
|
||||||
"""
|
"""
|
||||||
totals = {}
|
feeding_types=[
|
||||||
|
'breast milk',
|
||||||
|
'formula',
|
||||||
|
'fortified breast milk',
|
||||||
|
'solid food',
|
||||||
|
]
|
||||||
|
feeding_types_desc=[
|
||||||
|
'Breast milk',
|
||||||
|
'Formula',
|
||||||
|
'Fortified breast milk',
|
||||||
|
'Solid food',
|
||||||
|
]
|
||||||
|
total_idx=len(feeding_types)+1 #+1 for aggregate total
|
||||||
|
totals_list=list()
|
||||||
|
for i in range(total_idx):
|
||||||
|
totals_list.append({})
|
||||||
for instance in instances:
|
for instance in instances:
|
||||||
end = timezone.localtime(instance.end)
|
end = timezone.localtime(instance.end)
|
||||||
date = end.date()
|
date = end.date()
|
||||||
if date not in totals.keys():
|
if date not in totals_list[total_idx-1].keys():
|
||||||
totals[date] = 0
|
for item in totals_list:
|
||||||
totals[date] += instance.amount or 0
|
item[date]=0
|
||||||
|
feeding_idx=feeding_types.index(instance.type)
|
||||||
|
totals_list[feeding_idx][date]+= instance.amount or 0
|
||||||
|
totals_list[total_idx-1][date]+= instance.amount or 0
|
||||||
|
zeros = [0 for a in totals_list[total_idx-1].values()]
|
||||||
|
|
||||||
amounts = [round(amount, 2) for amount in totals.values()]
|
#sum each feeding type for graph
|
||||||
trace = go.Bar(
|
amounts_array=[]
|
||||||
name=_('Total feeding amount'),
|
for i in range(total_idx):
|
||||||
x=list(totals.keys()),
|
amounts_array.append([round(amount, 2) for amount in totals_list[i].values()])
|
||||||
y=amounts,
|
|
||||||
|
traces=[]
|
||||||
|
for i in range(total_idx-1):
|
||||||
|
traces.append(go.Bar(
|
||||||
|
name=feeding_types_desc[i],
|
||||||
|
x=list(totals_list[total_idx-1].keys()),
|
||||||
|
y=amounts_array[i],
|
||||||
|
text=amounts_array[i]
|
||||||
|
|
||||||
|
))
|
||||||
|
|
||||||
|
traces.append(go.Bar(
|
||||||
|
name=_('Total'),
|
||||||
|
x=list(totals_list[total_idx-1].keys()),
|
||||||
|
y=zeros,
|
||||||
hoverinfo='text',
|
hoverinfo='text',
|
||||||
textposition='outside',
|
textposition='outside',
|
||||||
text=amounts
|
text=amounts_array[total_idx-1]
|
||||||
)
|
))
|
||||||
|
|
||||||
|
|
||||||
layout_args = utils.default_graph_layout_options()
|
layout_args = utils.default_graph_layout_options()
|
||||||
layout_args['title'] = _('<b>Total Feeding Amounts</b>')
|
layout_args['title'] = _('<b>Total Feeding Amounts</b>')
|
||||||
|
@ -39,8 +72,9 @@ def feeding_amounts(instances):
|
||||||
layout_args['yaxis']['title'] = _('Feeding amount')
|
layout_args['yaxis']['title'] = _('Feeding amount')
|
||||||
|
|
||||||
fig = go.Figure({
|
fig = go.Figure({
|
||||||
'data': [trace],
|
'data': traces,
|
||||||
'layout': go.Layout(**layout_args)
|
'layout': go.Layout(**layout_args)
|
||||||
})
|
})
|
||||||
|
fig.update_layout(barmode='stack')
|
||||||
output = plotly.plot(fig, output_type='div', include_plotlyjs=False)
|
output = plotly.plot(fig, output_type='div', include_plotlyjs=False)
|
||||||
return utils.split_graph_output(output)
|
return utils.split_graph_output(output)
|
||||||
|
|
Loading…
Reference in New Issue