Sunil Mohan Adapa 74214c18ae
*: Use Django gettext functions instead of ugettext
- ugettext functions will be removed in Django 4.0. Each use emits a warning
when running with Django 3.2. Since we have warnings enabled in developer mode,
we see quite a few messages because of this.

- ugettext is already a simple alias of gettext. So, no regressions are
expected.

Tests:

- Accessing an affected app in UI with Django 3.2 and Django 2.2 works fine.

- Using Django 3.2 there are no warnings related to removal of ugettext
functions.

- Ran regular unit tests.

Signed-off-by: Sunil Mohan Adapa <sunil@medhas.org>
Reviewed-by: James Valleroy <jvalleroy@mailbox.org>
2021-09-20 16:50:16 -04:00

51 lines
1.4 KiB
Python

# SPDX-License-Identifier: AGPL-3.0-or-later
"""
FreedomBox app for configuring date and time.
"""
import logging
from django.contrib import messages
from django.utils.translation import gettext as _
from plinth import actions
from plinth.views import AppView
from .forms import DateTimeForm
logger = logging.getLogger(__name__)
class DateTimeAppView(AppView):
form_class = DateTimeForm
app_id = 'datetime'
def get_initial(self):
status = super().get_initial()
status['time_zone'] = self.get_current_time_zone()
return status
def get_current_time_zone(self):
"""Get current time zone."""
time_zone = open('/etc/timezone').read().rstrip()
return time_zone or 'none'
def form_valid(self, form):
old_status = form.initial
new_status = form.cleaned_data
if old_status['time_zone'] != new_status['time_zone'] and \
new_status['time_zone'] != 'none':
try:
actions.superuser_run('timezone-change',
[new_status['time_zone']])
except Exception as exception:
messages.error(
self.request,
_('Error setting time zone: {exception}').format(
exception=exception))
else:
messages.success(self.request, _('Time zone set'))
return super().form_valid(form)