为什么管理员UI不使用django-taggit为某些模型添加标签部分?

时间:2013-08-07 18:13:30

标签: django tagging django-taggit

我是django的新手,我在我的django 1.4.2应用程序中使用django-taggit 0.10a1标记功能。我也尝试了django-tagging应用程序,但由于该项目没有得到维护,而且django-taggit得到了很多开发人员的积极评价,我选择了这个。

我想知道你们中的任何一个人是否可以帮助我解决我所看到的问题。在关注documentation之后,我添加了:

tags = TaggableManager()

到我需要标记的所有模型。大多数模型会自动在django admin中添加标签部分作为指定的文档,但对于某些模型,标签部分不会显示在管理界面UI上。我无法弄清楚原因。这里有几个模型,我在所有字段后声明了标签行。如果您在我的模型中看到该声明的位置有任何问题,如果您发现任何问题可以告诉我,我将非常感激。使用TaggableManager的非工作模型示例如下:


DigitalObject模型

class DigitalObject(models.Model):
    title = models.CharField(max_length=255, verbose_name=_("title"))
    ascii_title = models.CharField(max_length=255, verbose_name=_("ASCII title"))
    title_variants = models.CharField(max_length=300, null=True, blank=True, verbose_name=_("title variants"))
    collection = models.ForeignKey(Collection, related_name="collection_objects", verbose_name=_("collection"))
    object_creator = models.ForeignKey(Creator, null=True, blank=True, related_name="objects_created", verbose_name=_("object creator"))
    language = models.ManyToManyField("Language", null=True, blank=True, verbose_name=_("language"), related_name="language_objects")
    subject = models.ManyToManyField(SubjectHeading, null=True, blank=True, related_name="collection_objects", verbose_name=_("subject"))
    object_id = models.CharField(max_length=6, null=True, blank=True, verbose_name=_("object ID"))
    digital_id = models.CharField(max_length=100, null=True, blank=True, verbose_name=_("digital ID"))
    rights_holders = models.CharField(max_length=255, null=True, blank=True, verbose_name=_("rights holder(s)"))
    license_type = models.ForeignKey("License", default=1, verbose_name=_("license type"))
    permission_form = models.FileField(upload_to='permissionforms', verbose_name=_("permission form"), null=True, blank=True)
    # Physical object info
    identifier = models.CharField(max_length=60, help_text=_("e.g. ISBN, ISSN, DOI"), null=True, blank=True, verbose_name=_("identifier"))
    marks = models.CharField(max_length=255, null=True, blank=True, verbose_name=_("marks/inscriptions"))
    measurements = models.CharField(max_length=255, null=True, blank=True, verbose_name=_("physical description"))
    phys_object_type = models.ForeignKey("PhysicalObjectType", verbose_name=_("Physical object type"), related_name="digital_objects", null=True, blank=True)
    donor = models.CharField(max_length=255, null=True, blank=True, verbose_name=_("donor"))
    sponsor_note = models.CharField(max_length=255, null=True, blank=True, verbose_name=_("sponsor note"))
    phys_obj_date = models.DateField(null=True, blank=True, verbose_name=_("physical object date"))
    phys_obj_precision = models.CharField(max_length=1, choices=constants.DATE_PRECISION_CHOICES, default=u'f', null=True, blank=True, verbose_name=_("Precision"))
    phys_obj_BC = models.BooleanField(default=False, verbose_name=_("Is B.C. date"))
    phys_obj_location = models.ForeignKey("Location", null=True, blank=True, verbose_name=_("physical object location"))
    # Digital object info
    digi_object_format = models.ForeignKey("DigitalObjectType", verbose_name=_("Digital object format"), null=True, blank=True)
    # Container info
    series_num = models.CharField(max_length=12, null=True, blank=True, verbose_name=_("series #"))
    series_name = models.CharField(max_length=255, null=True, blank=True, verbose_name=_("series name"))
    subseries_num = models.CharField(max_length=12, null=True, blank=True, verbose_name=_("subseries #"))
    subseries_name = models.CharField(max_length=255, null=True, blank=True, verbose_name=_("subseries name"))
    box_num = models.CharField(max_length=12, null=True, blank=True, verbose_name=_("box #"))
    folder_num = models.CharField(max_length=12, null=True, blank=True, verbose_name=_("folder #"))
    drawer_num = models.CharField(max_length=12, null=True, blank=True, verbose_name=_("drawer #"))
    folder_name = models.CharField(max_length=255, null=True, blank=True, verbose_name=_("folder name"))
    folder_date = models.CharField(max_length=255, null=True, blank=True, verbose_name=_("folder date"))
    # Relationships
    related_production = models.ManyToManyField(Production, related_name="related_objects", null=True, blank=True, verbose_name=_("related production"))
    related_festival = models.ManyToManyField(FestivalOccurrence, related_name="related_objects", null=True, blank=True, verbose_name=_("related festival"))
    related_venue = models.ManyToManyField(Location, related_name="related_objects", null=True, blank=True, verbose_name=_("related venue"))
    related_creator = models.ManyToManyField(Creator, related_name="related_objects", null=True, blank=True, verbose_name=_("related creator"))
    related_work = models.ManyToManyField(WorkRecord, related_name="related_objects", null=True, blank=True, verbose_name=_("related work"))
    # extra details
    summary = models.TextField(null=True, blank=True, verbose_name=_("summary"))
    notes = models.TextField(null=True, blank=True, verbose_name=_("notes"))
    creation_date = models.DateField(null=True, blank=True, help_text="Click 'Today' to see today's date in the proper date format.", verbose_name=_("creation date"))
    creation_date_precision = models.CharField(max_length=1, null=True, blank=True, choices=constants.DATE_PRECISION_CHOICES, default=u'y', verbose_name=_("Precision"))
    creation_date_BC = models.BooleanField(default=False, verbose_name=_("Is B.C. date"))
    restricted = models.BooleanField(default=False, verbose_name=_("Restricted?"))
    restricted_description = models.CharField(max_length=255, null=True, blank=True, verbose_name=_("Details of restrictions"))
    ready_to_stream = models.BooleanField(default=False, verbose_name=_("Uploaded to streaming server"))
    hi_def_video = models.BooleanField(default=False, verbose_name=_("Hi-def video"))
    poster_image = models.FileField(upload_to='digitalobjects/poster_images', storage=OverwriteStorage(), verbose_name=_("Poster image (for videos)"), null=True, blank=True)
    attention = models.TextField(null=True, blank=True, verbose_name=_("attention"))
    has_attention = models.BooleanField(default=False)
    needs_editing = models.BooleanField(default=True, verbose_name=_("needs editing"))
    published = models.BooleanField(default=True, verbose_name=_("published"))   
    tags = TaggableManager()

    def phys_obj_date_display(self):
        return display_date(self.phys_obj_date, self.phys_obj_precision, self.phys_obj_BC)

    def creation_date_display(self):
        return display_date(self.creation_date, self.creation_date_precision, self.creation_date_BC)

    def has_related_things(self):
        if self.related_production.exists():
            return True
        if self.related_festival.exists():
            return True
        if self.related_venue.exists():
            return True
        if self.related_creator.exists():
            return True
        if self.related_work.exists():
            return True
        return False

    def object_number(self):
        num = ''
        num += self.collection.repository.repository_id
        num += self.collection.collection_id
        num += self.object_id
        return num

    def first_file(self):
        if self.files:
          df = self.files.order_by('seq_id')[0]
          return df
        else:
          return False

    def __unicode__(self):
        return "%s (%s)" % (self.title, str(self.object_number()))

def update_digital_object_title(sender, **kwargs):
    obj = kwargs['instance']
    obj.ascii_title = unidecode(obj.title)

pre_save.connect(update_digital_object_title, sender=DigitalObject)

WorkRecord模型

class WorkRecord(models.Model):
    title = models.CharField(max_length=255, verbose_name=_("title"))
    title_variants = models.CharField(max_length=300, null=True, blank=True, verbose_name=_("title variants"))
    ascii_title = models.CharField(max_length=255, verbose_name=_("ASCII title"))
    creators = models.ManyToManyField(Creator, through="WorkRecordCreator", verbose_name=_("creators"))
    creators_display = models.CharField(max_length=255, verbose_name=_("creators"))
    work_type = models.ForeignKey("WorkRecordType", verbose_name=_("work type"))
    subject = models.ManyToManyField(SubjectHeading, null=True, blank=True, related_name="works", verbose_name=_("subject"))
    genre = models.ForeignKey("WorkGenre", null=True, blank=True, help_text=_("The work's genre - e.g. drama, comedy"), verbose_name=_("genre"))
    culture = models.ForeignKey("WorkCulture", null=True, blank=True, help_text=_("The culture the work is a part of"), verbose_name=_("culture"))
    style = models.ForeignKey("WorkStyle", null=True, blank=True, help_text=_("A movement or period the work belongs to"), verbose_name=_("style"))
    lang = models.ManyToManyField("Language", null=True, blank=True, verbose_name=_("language"))
    creation_date = models.DateField(null=True, blank=True, help_text="Click 'Today' to see today's date in the proper date format.", verbose_name=_("creation date"))
    creation_date_precision = models.CharField(max_length=1, choices=constants.DATE_PRECISION_CHOICES, default=u'y', null=True, blank=True, verbose_name=_("Precision"))
    creation_date_BC = models.BooleanField(default=False, verbose_name=_("Is B.C. date"))
    publication_date = models.DateField(null=True, blank=True, help_text="Click 'Today' to see today's date in the proper date format.", verbose_name=_("publication date"))
    publication_date_precision = models.CharField(max_length=1, choices=constants.DATE_PRECISION_CHOICES, default=u'y', null=True, blank=True, verbose_name=_("Precision"))
    publication_date_BC = models.BooleanField(default=False, verbose_name=_("Is B.C. date"))
    publication_rights = models.CharField(max_length=30, null=True, blank=True, verbose_name=_("publication rights"))
    performance_rights = models.CharField(max_length=30, null=True, blank=True, verbose_name=_("performance rights"))
    website = models.URLField(null=True, blank=True, help_text=_("A site where users can find the text of this work"), verbose_name=_("website"))
    digital_copy = models.ForeignKey("DigitalObject", null=True, blank=True, verbose_name=_("digital copy"))
    summary = models.TextField(null=True, blank=True, verbose_name=_("summary"))
    notes = models.TextField(null=True, blank=True, verbose_name=_("notes"))
    related_works = models.ManyToManyField("self", through="RelatedWork", symmetrical=False, null=True, blank=True, related_name="related_to", verbose_name=_("related works"))
    attention = models.TextField(null=True, blank=True, verbose_name=_("attention"))
    has_attention = models.BooleanField(default=False)
    needs_editing = models.BooleanField(default=True, verbose_name=_("needs editing"))
    published = models.BooleanField(default=True, verbose_name=_("published"))
    awards_text = models.TextField(null=True, blank=True, verbose_name=_("awards (plain text)"))
    biblio_text = models.TextField(null=True, blank=True, verbose_name=_("bibliography (plain text)"))
    biblio_text_es = models.TextField(null=True, blank=True, verbose_name=_("bibliography (plain text, Spanish)"))
    secondary_biblio_text = models.TextField(null=True, blank=True, verbose_name=_("secondary bibliography (plain text)"))
    secondary_biblio_text_es = models.TextField(null=True, blank=True, verbose_name=_("secondary bibliography (plain text, Spanish)"))
    tags = TaggableManager()

    def creation_date_display(self):
        return display_date(self.creation_date, self.creation_date_precision, self.creation_date_BC)
    creation_date_display.short_description = _("Creation date")

    def publication_date_display(self):
        return display_date(self.publication_date, self.publication_date_precision, self.publication_date_BC)
    publication_date_display.short_description = _("Publication date")

    def creators_display_links(self):
        cs = ""
        for wrc in WorkRecordCreator.objects.filter(work_record=self):
            cs += "<a href='/creator/" + str(wrc.creator.id) + "'>"
            cs += wrc.creator.display_name()
            cs += "</a>, "
        cs = cs.rstrip(', ')
        return cs

    def has_system_links(self):
        if AwardCandidate.objects.filter(work_record=self).exists():
            return True
        elif RelatedWork.objects.filter(first_work=self).exists():
            return True
        elif RelatedWork.objects.filter(second_work=self).exists():
            return True
        elif WorkRecordCreator.objects.filter(work_record=self).exists():
            return True
        elif Role.objects.filter(source_text=self).exists():
            return True
        elif Production.objects.filter(source_work=self).exists():
            return True
        elif DigitalObject.objects.filter(related_work=self).exists():
            return True
        elif BibliographicRecord.objects.filter(work_record=self).exists():
            return True
        else:
            return False

    def __unicode__(self):
        return "%s (%s)" % (self.title, self.work_type.name)

def update_wr_title(sender, **kwargs):
    obj = kwargs['instance']
    obj.ascii_title = unidecode(obj.title)

pre_save.connect(update_wr_title, sender=WorkRecord)

如果您有任何人可以请一看,我真诚地感谢您,如果您发现任何我可能错过的内容,或者您​​需要更多信息来了解我的问题,请告诉我。

提前致谢。

1 个答案:

答案 0 :(得分:0)

事实证明,标签列未显示的模型在admin.py中具有字段集。对于不按字段集排列的模型,taggit会自动将“标签”列添加到管理界面。对于按字段集排列的那些,模型中的“标签”列应特别包含在其中一个字段集中。

admin.py for WorkRecord模型

class WorkRecordAdmin(TranslationAdmin):
    form = arcforms.WorkRecordAdminForm
    inlines = (WorkRecordCreatorInline, RoleInline, RelatedWorkInline,)
    list_display = ('title', 'creators_display', 'work_type', 'genre', 'culture', 'style', 'has_system_links')
    list_filter = ('work_type', 'lang', 'genre', 'culture', 'style', 'has_attention',)
    search_fields = ['title', 'ascii_title', 'title_variants']
    filter_horizontal = ['subject', 'lang']
    fieldsets = (
        ('Titles', {
            'fields': ('title', 'title_variants')
        }),
        ('Description', {
            'fields': ('work_type', 'subject', 'genre', 'culture', 'style', 'lang')
        }),
        ('Creation / Publication', {
            'fields': (('creation_date', 'creation_date_precision', 'creation_date_BC'), ('publication_date', 'publication_date_precision', 'publication_date_BC'), 'publication_rights', 'performance_rights')
        }),
        ('Access', {
            'fields': ('website', 'digital_copy')
        }),
        ('Standard fields', {
            'fields': ('summary', 'notes', 'attention', 'needs_editing', 'published', 'tags')
        })
    )

标签列包含在上面的标准字段字段集中。