From: Christian Heller Date: Sun, 23 Mar 2025 12:38:53 +0000 (+0100) Subject: Do not treat sink warnings as line-specific. X-Git-Url: https://plomlompom.com/repos/%7B%7Bdb.prefix%7D%7D/%7B%7B%20web_path%20%7D%7D/tasks?a=commitdiff_plain;h=8824b639dfc820c69765d8944fa6a0e45c79f266;p=ledgplom Do not treat sink warnings as line-specific. --- diff --git a/src/ledgplom/http.py b/src/ledgplom/http.py index b1734f5..232b427 100644 --- a/src/ledgplom/http.py +++ b/src/ledgplom/http.py @@ -182,6 +182,7 @@ class _Handler(PlomHttpHandler): ctx['id'] = id_ ctx['dat_lines'] = [dl if raw else dl.as_dict for dl in booking.booked_lines] + ctx['sink_error'] = booking.sink_error ctx['valid'] = self.server.ledger.bookings_valid_up_incl(id_) if not raw: ctx['all_accounts'] = sorted(self.server.ledger.accounts.keys()) diff --git a/src/ledgplom/ledger.py b/src/ledgplom/ledger.py index 798596a..450c6d8 100644 --- a/src/ledgplom/ledger.py +++ b/src/ledgplom/ledger.py @@ -200,11 +200,6 @@ class DatLine(_Dictable): """Return error if registered on attempt to parse into BookingLine.""" return '; '.join(self.booked.errors) if self.booked else '' - @property - def is_questionable(self) -> bool: - """Return whether line be questionable per associated _Booking.""" - return bool(self.booking and self.booking.is_questionable) - @property def raw_nbsp(self) -> str: """Return .raw but ensure whitespace as  , and at least one.""" @@ -341,6 +336,7 @@ class _Booking: # calculate .account_changes changes = _Wealth() sink_account = None + self.sink_error = '' self.account_changes: dict[str, _Wealth] = {} for transfer_line in [tl for tl in self._transfer_lines if not tl.errors]: @@ -348,8 +344,9 @@ class _Booking: self.account_changes[transfer_line.account] = _Wealth() if transfer_line.amount is None: if sink_account: - transfer_line.errors += ['too many sinks'] - sink_account = transfer_line.account + self.sink_error = 'too many sinks' + else: + sink_account = transfer_line.account continue change = _Wealth({transfer_line.currency: transfer_line.amount}) self.account_changes[transfer_line.account] += change @@ -357,7 +354,7 @@ class _Booking: if sink_account: self.account_changes[sink_account] += changes.as_sink elif not changes.sink_empty: - self._transfer_lines[-1].errors += ['needed sink missing'] + self.sink_error = 'needed sink missing' def recalc_prev_next(self, bookings: list[Self]) -> None: """Assuming .id_ to be index in bookings, link prev + next bookings.""" @@ -408,7 +405,9 @@ class _Booking: @property def is_questionable(self) -> bool: - """Whether lines count any errors.""" + """Whether lines count any errors, or add up to a .sink_error.""" + if self.sink_error: + return True for _ in [bl for bl in [self.intro_line] + self._transfer_lines if bl.errors]: return True diff --git a/src/templates/_macros.tmpl b/src/templates/_macros.tmpl index 9135e51..84be211 100644 --- a/src/templates/_macros.tmpl +++ b/src/templates/_macros.tmpl @@ -13,13 +13,13 @@ td.balance.curr { width: 3em; } {% macro css_errors() %} -td.invalid, tr.warning td.invalid { background-color: #ff0000; } +span.sink_error, td.invalid, tr.warning td.invalid { background-color: #ff0000; } {% endmacro %} {% macro css_ledger_index_col() %} -table.ledger tr > td:first-child { background-color: white; text-align: right; } +table.ledger tr > td:first-child { text-align: right; } {% endmacro %} @@ -37,9 +37,9 @@ table.ledger tr > td:first-child { background-color: white; text-align: right; } {% if (not raw) and dat_line.prev_line_empty %}   {% endif %} - + - + {% if dat_line.is_intro %} [#] {{ table_dat_lines_action_button(dat_line, "moveup", "^", dat_line.booking.can_move(1)) }} @@ -129,7 +129,7 @@ function taint() { -{% macro edit_bar(target, id) %} +{% macro edit_bar(target, id, sink_error) %} prev · next @@ -139,6 +139,10 @@ function taint() { switch to {{target}} · balance after · in ledger
+{% if sink_error %} +balancing error: {{ sink_error }} +
+{% endif %} {% endmacro %} diff --git a/src/templates/edit_raw.tmpl b/src/templates/edit_raw.tmpl index adfccbc..fb7b804 100644 --- a/src/templates/edit_raw.tmpl +++ b/src/templates/edit_raw.tmpl @@ -15,7 +15,7 @@ {% block content %}
-{{ macros.edit_bar("structured", id) }} +{{ macros.edit_bar("structured", id, sink_error) }} diff --git a/src/templates/edit_structured.tmpl b/src/templates/edit_structured.tmpl index 3250ae4..dad2e0a 100644 --- a/src/templates/edit_structured.tmpl +++ b/src/templates/edit_structured.tmpl @@ -256,7 +256,7 @@ window.onload = update_form; {% block content %} -{{ macros.edit_bar("raw", id) }} +{{ macros.edit_bar("raw", id, sink_error) }} |