musician website create directives filter group name and helptext
This commit is contained in:
parent
1ebf30db33
commit
475df0a2e5
|
@ -58,3 +58,9 @@ MUSICIAN_EDIT_ENABLE_PHP_OPTIONS = Setting('MUSICIAN_EDIT_ENABLE_PHP_OPTIONS', (
|
|||
'post_max_size',
|
||||
'upload_max_filesize',
|
||||
))
|
||||
|
||||
MUSICIAN_WEBSITES_ENABLE_GROUP_DIRECTIVE = Setting('MUSICIAN_WEBSITES_ENABLE_GROUP_DIRECTIVE', (
|
||||
'HTTPD',
|
||||
),
|
||||
help_text="Valid groups: HTTPD, ModSecurity, SSL, SaaS"
|
||||
)
|
||||
|
|
|
@ -92,6 +92,6 @@
|
|||
{% endfor %}
|
||||
</tbody>
|
||||
</table>
|
||||
<!-- <a class="btn btn-primary mt-4 mb-4" href="{% url 'musician:webapp-add-option' object.pk %}">{% trans "Add new option" %}</a></td> -->
|
||||
<a class="btn btn-primary mt-4 mb-4" href="{% url 'musician:website-add-directive' object.pk %}">{% trans "Add new directive" %}</a></td>
|
||||
|
||||
{% endblock %}
|
||||
|
|
|
@ -3,11 +3,14 @@ from orchestra.forms.widgets import DynamicHelpTextSelect
|
|||
|
||||
from django.core.exceptions import ValidationError
|
||||
from django.utils.translation import gettext_lazy as _
|
||||
from django.utils.encoding import force_str
|
||||
|
||||
from orchestra.contrib.websites.directives import SiteDirective
|
||||
from orchestra.contrib.websites.models import Website, Content, WebsiteDirective
|
||||
from orchestra.contrib.webapps.models import WebApp
|
||||
from orchestra.contrib.domains.models import Domain
|
||||
|
||||
from orchestra.contrib.musician.settings import MUSICIAN_WEBSITES_ENABLE_GROUP_DIRECTIVE
|
||||
|
||||
|
||||
class WebsiteUpdateForm(forms.ModelForm):
|
||||
|
@ -47,11 +50,70 @@ class WesiteContentCreateForm(forms.ModelForm):
|
|||
cleaned_data = super().clean()
|
||||
path = self.cleaned_data.get("path")
|
||||
path = "/" if path == "" else path
|
||||
print(f"mypath: {path}")
|
||||
if Content.objects.filter(website=self.website, path=path).exists():
|
||||
self.add_error('path',_("This Path already exists on this Website."))
|
||||
return cleaned_data
|
||||
|
||||
def save(self, commit=True):
|
||||
instance = super().save(commit=False)
|
||||
instance.website = self.website
|
||||
if commit:
|
||||
super().save(commit=True)
|
||||
self.website.save()
|
||||
return instance
|
||||
|
||||
from collections import defaultdict
|
||||
from orchestra.contrib.websites.utils import normurlpath
|
||||
|
||||
class WesiteDirectiveCreateForm(forms.ModelForm):
|
||||
|
||||
DIRECTIVES_HELP_TEXT = {
|
||||
op.name: force_str(op.help_text) for op in SiteDirective.get_plugins()
|
||||
}
|
||||
|
||||
class Meta:
|
||||
model = WebsiteDirective
|
||||
fields = ("name", "value")
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
self.website = kwargs.pop('website')
|
||||
# self.user = kwargs.pop('user')
|
||||
super().__init__(*args, **kwargs)
|
||||
target = 'this.id.replace("name", "value")'
|
||||
self.fields['name'].widget.attrs = DynamicHelpTextSelect(target, self.DIRECTIVES_HELP_TEXT).attrs
|
||||
self.fields['name'].choices = self.get_allow_choices()
|
||||
|
||||
def get_allow_choices(self):
|
||||
groups = MUSICIAN_WEBSITES_ENABLE_GROUP_DIRECTIVE
|
||||
yield (None, '-------')
|
||||
options = SiteDirective.get_option_groups()
|
||||
for grp in groups:
|
||||
if grp in options.keys():
|
||||
yield (grp, [(op.name, op.verbose_name) for op in options[grp]])
|
||||
|
||||
|
||||
|
||||
# def clean(self):
|
||||
# TODO: comprovar que la ruta no exista
|
||||
# locations = set()
|
||||
# for form in self.content_formset.forms:
|
||||
# location = form.cleaned_data.get('path')
|
||||
# delete = form.cleaned_data.get('DELETE')
|
||||
# if not delete and location is not None:
|
||||
# locations.add(normurlpath(location))
|
||||
|
||||
# values = defaultdict(list)
|
||||
# for form in self.forms:
|
||||
# wdirective = form.instance
|
||||
# directive = form.cleaned_data
|
||||
# if directive.get('name') is not None:
|
||||
# try:
|
||||
# wdirective.directive_instance.validate_uniqueness(directive, values, locations)
|
||||
# except ValidationError as err:
|
||||
# for k,v in err.error_dict.items():
|
||||
# form.add_error(k, v)
|
||||
|
||||
|
||||
def save(self, commit=True):
|
||||
instance = super().save(commit=False)
|
||||
instance.website = self.website
|
||||
|
|
|
@ -12,7 +12,8 @@ from orchestra.contrib.musician.mixins import (CustomContextMixin, ExtendedPagin
|
|||
UserTokenRequiredMixin)
|
||||
|
||||
from orchestra.contrib.websites.models import Website, Content, WebsiteDirective
|
||||
from orchestra.contrib.musician.tidy_forms.websites import WebsiteUpdateForm, WesiteContentCreateForm
|
||||
from orchestra.contrib.musician.tidy_forms.websites import ( WebsiteUpdateForm, WesiteContentCreateForm,
|
||||
WesiteDirectiveCreateForm)
|
||||
|
||||
|
||||
class WebsiteListView(CustomContextMixin, UserTokenRequiredMixin, ListView):
|
||||
|
@ -121,4 +122,20 @@ class WebsiteAddContentView(CustomContextMixin, UserTokenRequiredMixin, CreateVi
|
|||
|
||||
def get_success_url(self):
|
||||
return reverse_lazy("musician:website-detail", kwargs={"pk": self.kwargs["pk"]})
|
||||
|
||||
|
||||
class WebsiteAddDirectiveView(CustomContextMixin, UserTokenRequiredMixin, CreateView):
|
||||
model = WebsiteDirective
|
||||
form_class = WesiteDirectiveCreateForm
|
||||
template_name = "musician/websites/website_create_option_form.html"
|
||||
|
||||
def get_form_kwargs(self):
|
||||
kwargs = super().get_form_kwargs()
|
||||
website = get_object_or_404(Website, account=self.request.user, pk=self.kwargs["pk"])
|
||||
kwargs['website'] = website
|
||||
# kwargs["user"] = self.request.user
|
||||
return kwargs
|
||||
|
||||
def get_success_url(self):
|
||||
return reverse_lazy("musician:website-detail", kwargs={"pk": self.kwargs["pk"]})
|
||||
|
|
@ -49,6 +49,7 @@ urlpatterns = [
|
|||
path('websites/<int:pk>/', views.WebsiteDetailView.as_view(), name='website-detail'),
|
||||
path('websites/<int:pk>/edit/', views.WebsiteUpdateView.as_view(), name='website-update'),
|
||||
path('websites/<int:pk>/add-content/', views.WebsiteAddContentView.as_view(), name='website-add-content'),
|
||||
path('websites/<int:pk>/add-directive/', views.WebsiteAddDirectiveView.as_view(), name='website-add-directive'),
|
||||
path('websites/<int:pk>/content/<int:content_pk>/delete/', views.WebsiteDeleteContentView.as_view(), name='website-delete-content'),
|
||||
path('websites/<int:pk>/directive/<int:directive_pk>/delete/', views.WebsiteDeleteDirectiveView.as_view(), name='website-delete-directive'),
|
||||
|
||||
|
|
|
@ -55,7 +55,7 @@ class SiteDirective(plugins.Plugin, metaclass=plugins.PluginMount):
|
|||
yield (option.name, option.verbose_name)
|
||||
for group, options in options.items():
|
||||
yield (group, [(op.name, op.verbose_name) for op in options])
|
||||
|
||||
|
||||
def validate_uniqueness(self, directive, values, locations):
|
||||
""" Validates uniqueness location, name and value """
|
||||
errors = defaultdict(list)
|
||||
|
|
|
@ -67,7 +67,7 @@ class WebsiteDirectiveInlineFormSet(forms.models.BaseInlineFormSet):
|
|||
delete = form.cleaned_data.get('DELETE')
|
||||
if not delete and location is not None:
|
||||
locations.add(normurlpath(location))
|
||||
|
||||
|
||||
values = defaultdict(list)
|
||||
for form in self.forms:
|
||||
wdirective = form.instance
|
||||
|
|
Loading…
Reference in a new issue