- def balance_as_html(self, db, stop_date=None, plus=0):
- lines = []
- bookings = db.bookings
- if stop_date:
- bookings = []
- i = -1
- for b in db.bookings:
- if b.date_string == stop_date:
- if -1 == i:
- i = 0
- if i >= plus:
- break
- if i > -1:
- i += 1
- bookings += [b]
- account_tree, account_sums = bookings_to_account_tree(bookings)
- def print_subtree(lines, indent, node, subtree, path):
- line = f"{indent}{node}"
- n_tabs = 5 - (len(line) // 8)
- line += n_tabs * "\t"
- if "€" in account_sums[path + node].keys():
- amount = account_sums[path + node]["€"]
- line += f"{amount:9.2f} €\t"
- else:
- line += f"\t\t"
- for currency, amount in account_sums[path + node].items():
- if currency != '€' and amount > 0:
- line += f"{amount:5.2f} {currency}\t"
- lines += [line]
- indent += " "
- for k, v in sorted(subtree.items()):
- print_subtree(lines, indent, k, v, path + node + ":")
- for k, v in sorted(account_tree.items()):
- print_subtree(lines, "", k, v, "")
- content = "\n".join(lines)
- return f"<pre>{content}</pre>"
-
- def ledger_as_html(self, db):
- elements_to_write = []
- account_sums = {} ##
- nth_of_same_date = 0
- same_date = ''
- for booking in db.bookings:
- if booking.date_string == same_date:
- nth_of_same_date += 1
- else:
- same_date = booking.date_string
- nth_of_same_date = 0
- booking_end = booking.start_line + len(booking.lines)
- booking_lines = []
- for booking_line in booking.lines[1:]:
- if booking_line == '':
- continue
- account = booking_line[0] ##
- account_toks = account.split(':') ##
- path = '' ##
- for tok in account_toks: ##
- path += tok ##
- if not path in account_sums.keys(): ##
- account_sums[path] = {} ##
- path += ':' ##
- moneys = [] ##
- money = ''
- if booking_line[1] is not None:
- moneys += [(booking_line[1], booking_line[2])] ##
- money = f'{moneys[0][0]} {moneys[0][1]}'
- else: ##
- for currency, amount in booking.sink.items(): ##
- moneys += {(amount, currency)} ##
- money = '[' ##
- for m in moneys: ##
- money += f'{m[0]} {m[1]} ' ##
- money += ']' ##
- balance = '' ##
- for amount, currency in moneys: ##
- path = '' ##
- for tok in account_toks: ##
- path += tok ##
- if not currency in account_sums[path].keys(): ##
- account_sums[path][currency] = 0 ##
- account_sums[path][currency] += amount ##
- path += ':' ##
- balance += f'{account_sums[account][currency]} {currency}' ##
- booking_lines += [{'acc': booking_line[0], 'money':money, 'comment':balance}] ##
- elements_to_write += [self.booking_tmpl.render(
- start=booking.start_line,
- end=booking_end,
- date=booking.date_string,
- desc=booking.description,
- head_comment=db.comments[booking.start_line],
- steps_after_date=nth_of_same_date,
- booking_lines = booking_lines)]
- return '\n'.join(elements_to_write)
-
- def ledger2_as_html(self, db):
- single_c_tmpl = jinja2.Template('<span class="comment">{{c|e}}</span><br />')
- elements_to_write = []
- last_i = i = 0 ##
- nth_of_same_date = 0
- same_date = ''
- for booking in db.bookings:
- if booking.date_string == same_date:
- nth_of_same_date += 1
- else:
- same_date = booking.date_string
- nth_of_same_date = 0
- i = booking.start_line ##
- elements_to_write += [single_c_tmpl.render(c=c) for c in db.comments[last_i:i] if c != ''] ##
- booking_end = last_i = booking.start_line + len(booking.lines)
- booking_lines = []
- for booking_line in booking.lines[1:]:
- i += 1
- comment = db.comments[i]
- if booking_line == '':
- booking_lines += [{'acc': None, 'money': None, 'comment': comment}]
- continue
- account = booking_line[0]
- money = ''
- if booking_line[1] is not None:
- money = f'{booking_line[1]} {booking_line[2]}'
- booking_lines += [{'acc': booking_line[0], 'money':money, 'comment':comment}] ##
- elements_to_write += [self.booking_tmpl.render(
- start=booking.start_line,
- end=booking_end,
- date=booking.date_string,
- desc=booking.description,
- head_comment=db.comments[booking.start_line],
- steps_after_date=nth_of_same_date,
- booking_lines = booking_lines)]
- elements_to_write += [single_c_tmpl.render(c=c) for c in db.comments[last_i:] if c != '']
- return '\n'.join(elements_to_write)
-
- def add_free(self, db, start=0, end=0, copy=False):
- tmpl = jinja2.Template("""
-<form method="POST" action="{{action|e}}">
-<textarea name="booking" rows=10 cols=80>
-{% for line in lines %}{{ line }}
-{% endfor %}
-</textarea>
-<input type="hidden" name="start" value={{start}} />
-<input type="hidden" name="end" value={{end}} />
-<input type="submit" name="save" value="save!">
-</form>
-""")
- lines = db.get_lines(start, end)
- if copy:
- start = end = 0
- return tmpl.render(action='add_free', start=start, end=end, lines=lines)
-
- def add_structured(self, db, start=0, end=0, copy=False, temp_lines=[], add_empty_line=None):
- tmpl = jinja2.Template("""
-<form method="POST" action="{{action|e}}">
-<input type="submit" name="check" value="check" />
-<input type="submit" name="revert" value="revert" />
-<input type="submit" name="add_taxes" value="add taxes" />
-<input type="submit" name="add_taxes2" value="add taxes2" />
-<br />
-<input name="date" value="{{date|e}}" size=9 />
-<input name="description" value="{{desc|e}}" list="descriptions" />
-<textarea name="line_0_comment" rows=1 cols=20>{{head_comment|e}}</textarea>
-<input type="submit" name="line_0_add" value="[+]" />
-<br />
-{% for line in booking_lines %}
-<input name="line_{{line.i}}_account" value="{{line.acc|e}}" size=40 list="accounts" />
-<input type="number" name="line_{{line.i}}_amount" step=0.01 value="{{line.amt}}" size=10 />
-<input name="line_{{line.i}}_currency" value="{{line.curr|e}}" size=3 list="currencies" />
-<input type="submit" name="line_{{line.i}}_delete" value="[x]" />
-<input type="submit" name="line_{{line.i}}_delete_after" value="[XX]" />
-<input type="submit" name="line_{{line.i}}_add" value="[+]" />
-<textarea name="line_{{line.i}}_comment" rows=1 cols={% if line.comm_cols %}{{line.comm_cols}}{% else %}20{% endif %}>{{line.comment|e}}</textarea>
-<br />
-{% endfor %}
-{% for name, items in datalist_sets.items() %}
-<datalist id="{{name}}">
-{% for item in items %}
- <option value="{{item|e}}">{{item|e}}</option>
-{% endfor %}
-</datalist>
-{% endfor %}
-<input type="hidden" name="start" value={{start}} />
-<input type="hidden" name="end" value={{end}} />
-<input type="submit" name="save" value="save!">
-</form>
-""")
- import datetime
- lines = temp_lines if len(''.join(temp_lines)) > 0 else db.get_lines(start, end)
- bookings, comments = parse_lines(lines, validate_bookings=False)
- if len(bookings) > 1:
- raise HandledException('can only edit single Booking')
- if add_empty_line is not None:
- comments = comments[:add_empty_line+1] + [''] + comments[add_empty_line+1:]
- booking = bookings[0]
- booking.lines = booking.lines[:add_empty_line+1] + [''] + booking.lines[add_empty_line+1:]
- action = 'add_structured'
- datalist_sets = {'descriptions': set(), 'accounts': set(), 'currencies': set()}
- for b in db.bookings:
- datalist_sets['descriptions'].add(b.description)
- for account, moneys in b.account_changes.items():
- datalist_sets['accounts'].add(account)
- for currency in moneys.keys():
- datalist_sets['currencies'].add(currency)
- content = ''
- today = str(datetime.datetime.now())[:10]
- booking_lines = []
- if copy:
- start = end = 0
- desc = head_comment = ''
- if len(bookings) == 0:
- for i in range(1, 3):
- booking_lines += [{'i': i, 'acc': '', 'amt': '', 'curr': '', 'comment': ''}]
- date=today
- else:
- booking = bookings[0]
- desc = booking.description
- date = today if copy else booking.date_string
- head_comment=comments[0]
- last_line = len(comments)
- for i in range(1, len(comments)):
- account = amount = currency = ''
- if i < len(booking.lines) and booking.lines[i] != '':
- account = booking.lines[i][0]
- amount = booking.lines[i][1]
- currency = booking.lines[i][2]
- booking_lines += [{
- 'i': i,
- 'acc': account,
- 'amt': amount,
- 'curr': currency if currency else '',
- 'comment': comments[i],
- 'comm_cols': len(comments[i])}]
- content += tmpl.render(
- action=action,
- date=date,
- desc=desc,
- head_comment=head_comment,
- booking_lines=booking_lines,
- datalist_sets=datalist_sets,
- start=start,
- end=end)
- return content