diff options
| author | Étienne Loks <etienne.loks@peacefrogs.net> | 2013-12-14 23:52:13 +0100 | 
|---|---|---|
| committer | Étienne Loks <etienne.loks@peacefrogs.net> | 2013-12-14 23:52:13 +0100 | 
| commit | dd005db8c38c1139c33a5f3b8b9e3e1556b28b38 (patch) | |
| tree | e702a5e335c4366a1e27499a4db51e31b7f5c7b7 /ishtar_common/forms.py | |
| parent | c6f301b76291d2f416f6a641fe92b03cd10076a7 (diff) | |
| parent | b3c5ce577b925da4022f21ccdf8d138486557450 (diff) | |
| download | Ishtar-dd005db8c38c1139c33a5f3b8b9e3e1556b28b38.tar.bz2 Ishtar-dd005db8c38c1139c33a5f3b8b9e3e1556b28b38.zip | |
Merge branch 'master' of lysithea.proxience.net:/home/proxience/git/ishtar
Diffstat (limited to 'ishtar_common/forms.py')
| -rw-r--r-- | ishtar_common/forms.py | 26 | 
1 files changed, 26 insertions, 0 deletions
| diff --git a/ishtar_common/forms.py b/ishtar_common/forms.py index e82a6e86d..5faa232fb 100644 --- a/ishtar_common/forms.py +++ b/ishtar_common/forms.py @@ -145,3 +145,29 @@ def get_form_selection(class_name, label, key, model, base_form, get_url,          return cleaned_data      attrs['clean'] = clean      return type(class_name, (forms.Form,), attrs) + +class DocumentGenerationForm(forms.Form): +    """ +    Form to generate document by choosing the template +    """ +    _associated_model = None # ex: AdministrativeAct +    _associated_object_name = '' # ex: 'archaeological_operations.models.AdministrativeAct' +    document_template = forms.ChoiceField(label=_("Template"), choices=[]) + +    def __init__(self, *args, **kwargs): +        super(DocumentGenerationForm, self).__init__(*args, **kwargs) +        self.fields['document_template'].choices = \ +                models.DocumentTemplate.get_tuples( +                    dct={'associated_object_name':self._associated_object_name}) + +    def save(self, object_pk): +        try: +            c_object = self._associated_model.objects.get(pk=object_pk) +        except self._associated_model.DoesNotExist: +            return +        try: +            template = models.DocumentTemplate.objects.get( +                            pk=self.cleaned_data.get('document_template')) +        except models.DocumentTemplate.DoesNotExist: +            return +        return template.publish(c_object) | 
