mirror of
https://github.com/pretix/pretix.git
synced 2026-05-08 15:44:02 +00:00
Allow creating KnownDomains in the interface
This commit is contained in:
@@ -3,6 +3,7 @@ from django.utils.translation import ugettext_lazy as _
|
|||||||
|
|
||||||
from pretix.base.forms import I18nModelForm
|
from pretix.base.forms import I18nModelForm
|
||||||
from pretix.base.models import Organizer
|
from pretix.base.models import Organizer
|
||||||
|
from pretix.multidomain.models import KnownDomain
|
||||||
|
|
||||||
|
|
||||||
class OrganizerForm(I18nModelForm):
|
class OrganizerForm(I18nModelForm):
|
||||||
@@ -25,9 +26,42 @@ class OrganizerForm(I18nModelForm):
|
|||||||
|
|
||||||
|
|
||||||
class OrganizerUpdateForm(OrganizerForm):
|
class OrganizerUpdateForm(OrganizerForm):
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
|
self.domain = kwargs.pop('domain', False)
|
||||||
|
kwargs.setdefault('initial', {})
|
||||||
|
self.instance = kwargs['instance']
|
||||||
|
if self.domain and self.instance:
|
||||||
|
initial_domain = self.instance.domains.first()
|
||||||
|
if initial_domain:
|
||||||
|
kwargs['initial'].setdefault('domain', initial_domain.domainname)
|
||||||
|
|
||||||
super().__init__(*args, **kwargs)
|
super().__init__(*args, **kwargs)
|
||||||
self.fields['slug'].widget.attrs['readonly'] = 'readonly'
|
self.fields['slug'].widget.attrs['readonly'] = 'readonly'
|
||||||
|
if self.domain:
|
||||||
|
self.fields['domain'] = forms.CharField(
|
||||||
|
max_length=255,
|
||||||
|
label=_('Custom domain'),
|
||||||
|
required=False,
|
||||||
|
help_text=_('You need to configure the custom domain in the webserver beforehand.')
|
||||||
|
)
|
||||||
|
|
||||||
def clean_slug(self):
|
def clean_slug(self):
|
||||||
return self.instance.slug
|
return self.instance.slug
|
||||||
|
|
||||||
|
def save(self, commit=True):
|
||||||
|
instance = super().save(commit)
|
||||||
|
|
||||||
|
if self.domain:
|
||||||
|
current_domain = instance.domains.first()
|
||||||
|
if self.cleaned_data['domain']:
|
||||||
|
if current_domain and current_domain.domainname != self.cleaned_data['domain']:
|
||||||
|
current_domain.delete()
|
||||||
|
KnownDomain.objects.create(organizer=instance, domainname=self.cleaned_data['domain'])
|
||||||
|
elif not current_domain:
|
||||||
|
KnownDomain.objects.create(organizer=instance, domainname=self.cleaned_data['domain'])
|
||||||
|
elif current_domain:
|
||||||
|
current_domain.delete()
|
||||||
|
instance.get_cache().clear()
|
||||||
|
|
||||||
|
return instance
|
||||||
|
|||||||
@@ -11,6 +11,9 @@
|
|||||||
<legend>{% trans "General information" %}</legend>
|
<legend>{% trans "General information" %}</legend>
|
||||||
{% bootstrap_field form.name layout="horizontal" %}
|
{% bootstrap_field form.name layout="horizontal" %}
|
||||||
{% bootstrap_field form.slug layout="horizontal" %}
|
{% bootstrap_field form.slug layout="horizontal" %}
|
||||||
|
{% if form.domain %}
|
||||||
|
{% bootstrap_field form.domain layout="horizontal" %}
|
||||||
|
{% endif %}
|
||||||
</fieldset>
|
</fieldset>
|
||||||
<div class="form-group submit-group">
|
<div class="form-group submit-group">
|
||||||
<button type="submit" class="btn btn-primary btn-save">
|
<button type="submit" class="btn btn-primary btn-save">
|
||||||
|
|||||||
@@ -205,6 +205,12 @@ class OrganizerUpdate(OrganizerPermissionRequiredMixin, UpdateView):
|
|||||||
messages.success(self.request, _('Your changes have been saved.'))
|
messages.success(self.request, _('Your changes have been saved.'))
|
||||||
return super().form_valid(form)
|
return super().form_valid(form)
|
||||||
|
|
||||||
|
def get_form_kwargs(self):
|
||||||
|
kwargs = super().get_form_kwargs()
|
||||||
|
if self.request.user.is_superuser:
|
||||||
|
kwargs['domain'] = True
|
||||||
|
return kwargs
|
||||||
|
|
||||||
def get_success_url(self) -> str:
|
def get_success_url(self) -> str:
|
||||||
return reverse('control:organizer.edit', kwargs={
|
return reverse('control:organizer.edit', kwargs={
|
||||||
'organizer': self.request.organizer.slug,
|
'organizer': self.request.organizer.slug,
|
||||||
|
|||||||
Reference in New Issue
Block a user