X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/1a949f7c97dc2f34c135f5cdf088df2927d3d652..0cfc940c3e7643ed83e8d54f647c7e09d80c1bc4:/forum/settings/forms.py diff --git a/forum/settings/forms.py b/forum/settings/forms.py index 337dea1..15bbef6 100644 --- a/forum/settings/forms.py +++ b/forum/settings/forms.py @@ -1,9 +1,18 @@ import os +from string import strip from django import forms -from base import Setting, StringSetting, IntegerSetting, BoolSetting, FloatSetting +from base import Setting from django.utils.translation import ugettext as _ from django.core.files.storage import FileSystemStorage +class DummySetting: + pass + +class UnfilteredField(forms.CharField): + def clean(self, value): + return value + + class SettingsSetForm(forms.Form): def __init__(self, set, data=None, *args, **kwargs): if data is None: @@ -12,16 +21,18 @@ class SettingsSetForm(forms.Form): super(SettingsSetForm, self).__init__(data, *args, **kwargs) for setting in set: - if isinstance(setting, StringSetting): + if isinstance(setting, (Setting.emulators.get(str, DummySetting), Setting.emulators.get(unicode, DummySetting))): + if not setting.field_context.get('widget', None): + setting.field_context['widget'] = forms.TextInput(attrs={'class': 'longstring'}) field = forms.CharField(**setting.field_context) - elif isinstance(setting, FloatSetting): + elif isinstance(setting, Setting.emulators.get(float, DummySetting)): field = forms.FloatField(**setting.field_context) - elif isinstance(setting, IntegerSetting): + elif isinstance(setting, Setting.emulators.get(int, DummySetting)): field = forms.IntegerField(**setting.field_context) - elif isinstance(setting, BoolSetting): + elif isinstance(setting, Setting.emulators.get(bool, DummySetting)): field = forms.BooleanField(**setting.field_context) else: - field = forms.CharField(**setting.field_context) + field = UnfilteredField(**setting.field_context) self.fields[setting.name] = field @@ -60,4 +71,37 @@ class ImageFormWidget(forms.Widget): elif name in data: return data[name] +class StringListWidget(forms.Widget): + def render(self, name, value, attrs=None): + ret = "" + for s in value: + ret += """ +
+ + +
+ """ % {'name': name, 'value': s} + + return """ +
+ %(ret)s +
+
+ """ % dict(name=name, ret=ret) + + def value_from_datadict(self, data, files, name): + if 'submit' in data: + return data.getlist(name) + else: + return data[name] + +class CommaStringListWidget(forms.Textarea): + def value_from_datadict(self, data, files, name): + if 'submit' in data: + return map(strip, data[name].split(',')) + else: + return ', '.join(data[name]) + + +