Ajout nouvelle catégorie/article + auth/article

- Lors de la création ou modification d'un article, il est possible de
  sélectionner une catégorie existante ou d'en créer une nouvelle.
- Autorisations pour la création/modif d'article prises en compte
  correctement. Si l'utilisateur identifié n'a pas la permission
add(ou change)_accoount, input password apparait et l'utilisateur est
identifié temporairement pour la validation de l'ajout/modif.
This commit is contained in:
Aurélien Delobelle 2016-08-21 18:10:35 +02:00
parent a6b961d2ab
commit 74c3f07c66
4 changed files with 32 additions and 5 deletions

View file

@ -5,7 +5,7 @@ from django.contrib.contenttypes.models import ContentType
from django.contrib.admin.widgets import FilteredSelectMultiple from django.contrib.admin.widgets import FilteredSelectMultiple
from django.forms import modelformset_factory from django.forms import modelformset_factory
from kfet.models import (Account, Checkout, Article, OperationGroup, Operation, from kfet.models import (Account, Checkout, Article, OperationGroup, Operation,
CheckoutStatement) CheckoutStatement, ArticleCategory)
from gestioncof.models import CofProfile from gestioncof.models import CofProfile
# ----- # -----
@ -129,6 +129,24 @@ class CheckoutStatementForm(forms.ModelForm):
# ----- # -----
class ArticleForm(forms.ModelForm): class ArticleForm(forms.ModelForm):
category_new = forms.CharField(
max_length=45,
required = False)
category = forms.ModelChoiceField(
queryset = ArticleCategory.objects.all(),
required = False)
def clean(self):
category = self.cleaned_data.get('category')
category_new = self.cleaned_data.get('category_new')
if not category and not category_new:
raise ValidationError('Sélectionnez une catégorie ou créez en une')
elif not category:
category, _ = ArticleCategory.objects.get_or_create(name=category_new)
self.cleaned_data['category'] = category
super(ArticleForm, self).clean()
class Meta: class Meta:
model = Article model = Article
fields = ['name', 'is_sold', 'price', 'stock', 'category'] fields = ['name', 'is_sold', 'price', 'stock', 'category']

View file

@ -8,6 +8,9 @@
<form submit="" method="post"> <form submit="" method="post">
{% csrf_token %} {% csrf_token %}
{{ form.as_p }} {{ form.as_p }}
{% if not perms.kfet.add_article %}
<input type="password" name="KFETPASSWORD">
{% endif %}
<input type="submit" value="Enregistrer"> <input type="submit" value="Enregistrer">
</form> </form>

View file

@ -8,6 +8,9 @@
<form action="" method="post"> <form action="" method="post">
{% csrf_token %} {% csrf_token %}
{{ form.as_p }} {{ form.as_p }}
{% if not perms.kfet.change_article %}
<input type="password" name="KFETPASSWORD">
{% endif %}
<input type="submit" value="Mettre à jour"> <input type="submit" value="Mettre à jour">
</form> </form>

View file

@ -432,8 +432,10 @@ class ArticleCreate(SuccessMessageMixin, CreateView):
# Surcharge de la validation # Surcharge de la validation
def form_valid(self, form): def form_valid(self, form):
# Checking permission # Checking permission
if not self.request.user.has_perm('add_article'): if not self.request.user.has_perm('kfet.add_article'):
raise PermissionDenied form.add_error(None, 'Permission refusée')
return self.form_invalid(form)
# Creating # Creating
return super(ArticleCreate, self).form_valid(form) return super(ArticleCreate, self).form_valid(form)
@ -455,8 +457,9 @@ class ArticleUpdate(UpdateView):
# Surcharge de la validation # Surcharge de la validation
def form_valid(self, form): def form_valid(self, form):
# Checking permission # Checking permission
if not self.request.user.has_perm('change_article'): if not self.request.user.has_perm('kfet.change_article'):
raise PermissionDenied form.add_error(None, 'Permission refusée')
return self.form_invalid(form)
# Updating # Updating
return super(ArticleUpdate, self).form_valid(form) return super(ArticleUpdate, self).form_valid(form)