5

当我在 django admin 中保存模型时,我需要一种方法来显示中间页面。

我想要完成的是在“保存”模型之后,显示一个页面,其中排列了模型的所有属性,然后有一个按钮,上面写着Print. 单击 时,我曾经使用 Jquery 对话框 div 解决此问题save。这意味着我在实际保存模型之前显示了设置打印视图,但我现在需要先验证模型。

它就像“删除模型”动作的实现方式。我似乎无法找到从哪里开始寻找。

编辑: 我已经开始寻找django.contrib.admin.options.pyforresponse_changeresponse_add方法。不知道如何覆盖它们。而且它只需要一个特定的模型,所以它不是通用的。我还在 Class ModelAdmin 中发现了模板列表。仍然不确定如何在不破坏管理员的情况下继续进行操作。

编辑2: 在下面添加了我的工作解决方案。

4

3 回答 3

5

您可以创建一个表单,其中包含一个额外的验证“你确定”步骤的步骤。

在我们的 models.py 中给出这个模型:

from django.db import models

class Person(models.Model):
    name = models.CharField(max_length=100)

在 forms.py 中添加一个表单:

from django import forms
from .models import Person

class PersonForm(forms.ModelForm):
    i_am_sure = forms.BooleanField(required=False, widget=forms.HiddenInput())

    def __init__(self, *args, **kwargs):
        super(PersonForm, self).__init__(*args, **kwargs)

        if self.errors.get('i_am_sure'):
            # show the 'are you sure' checkbox when we want confirmation
            self.fields['i_am_sure'].widget = forms.CheckboxInput()

    def clean(self):
        cleaned_data = super(PersonForm, self).clean()

        if not self.errors:
            # only validate i_am_sure once all other validation has passed
            i_am_sure = cleaned_data.get('i_am_sure')
            if self.instance.id and not i_am_sure:
                self._errors['i_am_sure'] = self.error_class(["Are you sure you want to change this person?"])
                del cleaned_data['i_am_sure']

        return cleaned_data

    class Meta:
        model = Person

如果你想在 Django admin 中使用它。在您的 admin.py 中指定此表单:

from django.contrib import admin
from .forms import PersonForm
from .models import Person

class PersonAdmin(admin.ModelAdmin):
    form = PersonForm

admin.site.register(Person, PersonAdmin)

但是请注意,在 Django 管理表单上存在隐藏输入的错误。这个 Stack Overflow question 有一个解决方案

于 2013-08-14T15:08:31.823 回答
2

您可以将视图和 url 添加到您的 ModelAdmin 并覆盖您的 modeladmin 添加视图以进行相应的重定向。

class MyModelAdmin(admin.ModelAdmin):
    def get_urls(self):
        urls = super(MyModelAdmin, self).get_urls()
        my_urls = patterns('',
            (r'^my_view/$', self.my_view)
        )
        return my_urls + urls

    def my_view(self, request):
        # custom view which should return an HttpResponse
        pass
于 2013-03-02T09:37:52.027 回答
0

所以,经过一些编码后,我得到了它的工作。

我的模型管理员现在看起来与此类似

class MyModelAdmin(admin.ModelAdmin):
    def get_urls(self):
        urls = super(MyModelAdmin, self).get_urls()
        my_urls = patterns('',
            (r'^my_view/$', self.my_view)
        )
        return my_urls + urls

    def my_view(self,request,pk):
        from django.shortcuts import render_to_response
        from django.template import RequestContext

        object = Model.objects.get(pk=pk)
        model_dict = model_object.__dict__
        return render_to_response('admin/app_name/model/model_view.html',locals(),context_instance=RequestContext(request))

    @csrf_protect_m
    @transaction.commit_on_success
    def add_view(self, request, form_url='', extra_context=None):
        "The 'add' admin view for this model."
        model = self.model
        opts = model._meta

        if not self.has_add_permission(request):
            raise PermissionDenied

        ModelForm = self.get_form(request)
        formsets = []
        inline_instances = self.get_inline_instances(request)
        if request.method == 'POST':
            form = ModelForm(request.POST, request.FILES)
            if form.is_valid():
               new_object = self.save_form(request, form, change=False)
               form_validated = True
            else:
               form_validated = False
               new_object = self.model()
            prefixes = {}
            for FormSet, inline in zip(self.get_formsets(request), inline_instances):
               prefix = FormSet.get_default_prefix()
               prefixes[prefix] = prefixes.get(prefix, 0) + 1
               if prefixes[prefix] != 1 or not prefix:
                  prefix = "%s-%s" % (prefix, prefixes[prefix])
               formset = FormSet(data=request.POST, files=request.FILES,
                              instance=new_object,
                              save_as_new="_saveasnew" in request.POST,
                              prefix=prefix, queryset=inline.queryset(request))
               formsets.append(formset)
            if all_valid(formsets) and form_validated:
               self.save_model(request, new_object, form, False)
               self.save_related(request, form, formsets, False)
               self.log_addition(request, new_object)
               log.info('The new object has %s id' % new_object.id)
               return HttpResponseRedirect('/admin/draws/contest/contest_view/%s' % new_object.id)  <-- changed to my new one
               .................
               .................

在其中创建了一个 html 模板templates/admin/app_name/model_view.html,就是这样!

于 2013-03-03T08:22:10.647 回答