From e895de3abc75af0ed018047d2de236a64e83fc9f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E4=BE=9D=E7=91=AA=E8=B2=93?= Date: Tue, 14 Jul 2020 22:10:27 +0800 Subject: [PATCH] Changed Period to use the current language instead of expecting the language passed by the caller. --- accounting/views/__init__.py | 3 +-- mia_core/period.py | 18 ++++++------------ 2 files changed, 7 insertions(+), 14 deletions(-) diff --git a/accounting/views/__init__.py b/accounting/views/__init__.py index 8fada30..5a1c287 100644 --- a/accounting/views/__init__.py +++ b/accounting/views/__init__.py @@ -73,8 +73,7 @@ def cash(request, subject_code, period_spec): data_start = first_txn.date if first_txn is not None else None last_txn = Transaction.objects.order_by("-date").first() data_end = last_txn.date if last_txn is not None else None - period = Period( - period_spec, data_start, data_end, get_language()) + period = Period(period_spec, data_start, data_end) subjects = list(Subject.objects.raw("""SELECT s.* FROM accounting_subjects AS s WHERE s.code IN (SELECT s1.code diff --git a/mia_core/period.py b/mia_core/period.py index b7e6f00..4097370 100644 --- a/mia_core/period.py +++ b/mia_core/period.py @@ -26,7 +26,9 @@ from django.core.serializers.json import DjangoJSONEncoder from django.template import defaultfilters from django.utils import dateformat from django.utils.timezone import localdate -from django.utils.translation import gettext +from django.utils.translation import gettext, get_language + +from mia_core.utils import Language class Period: @@ -36,7 +38,6 @@ class Period: spec (str): The current period specification data_start (date): The available first day of the data. data_end (date): The available last day of the data. - language (str): The current language. Attributes: spec (date): The currently-working period specification. @@ -83,12 +84,11 @@ class Period: _period = None def __init__( - self, spec = None, - data_start = None, data_end = None, language = None): + self, spec = None, data_start = None, data_end = None): self._period = self.Parser(spec) self._data_start = data_start self._data_end = data_end - self._language = language + self._language = Language(get_language()) @property def spec(self): @@ -306,15 +306,9 @@ class Period: def month_picker_params(self): if self._data_start is None: return None - if self._language == "zh-Hant": - locale = "zh_TW" - elif self._language == "zh-Hans": - locale = "zh_CN" - else: - locale = self._language.replace("-", "_") start = date(self._data_start.year, self._data_start.month, 1) return DjangoJSONEncoder().encode({ - "locale": locale, + "locale": self._language.locale, "minDate": start, "maxDate": self._data_end, "defaultDate": self.chosen_month,