mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-05-05 11:39:29 -05:00

* Added devcontainer * Add feature storage pathes * Exclude tests and add versioning * Check escaping * Check escaping * Check quoting * Echo * Escape * Escape : * Double escape \ * Escaping * Remove if * Escape colon * Missing \ * Esacpe : * Escape all * test * Remove sed * Fix exclude * Remove SED command * Add LD_LIBRARY_PATH * Adjusted to v1.7 * Updated test-cases * Remove devcontainer * Removed internal build-file * Run pre-commit * Corrected flak8 error * Adjusted to v1.7 * Updated test-cases * Corrected flak8 error * Adjusted to new plural translations * Small adjustments due to code-review backend * Adjusted line-break * Removed PAPERLESS prefix from settings variables * Corrected style change due to search+replace * First documentation draft * Revert changes to Pipfile * Add sphinx-autobuild with keep-outdated * Revert merge error that results in wrong storage path is evaluated * Adjust styles of generated files ... * Adds additional testing to cover dynamic storage path functionality * Remove unnecessary condition * Add hint to edit storage path dialog * Correct spelling of pathes to paths * Minor documentation tweaks * Minor typo * improving wrapping of filter editor buttons with new storage path button * Update .gitignore * Fix select border radius in non input-groups * Better storage path edit hint * Add note to edit storage path dialog re document_renamer * Add note to bulk edit storage path re document_renamer * Rename FILTER_STORAGE_DIRECTORY to PATH * Fix broken filter rule parsing * Show default storage if unspecified * Remove note re storage path on bulk edit * Add basic validation of filename variables Co-authored-by: Markus Kling <markus@markus-kling.net> Co-authored-by: Trenton Holmes <holmes.trenton@gmail.com> Co-authored-by: Michael Shamoon <4887959+shamoon@users.noreply.github.com> Co-authored-by: Quinn Casey <quinn@quinncasey.com>
120 lines
3.1 KiB
Python
120 lines
3.1 KiB
Python
from django.contrib import admin
|
|
|
|
from .models import Correspondent
|
|
from .models import Document
|
|
from .models import DocumentType
|
|
from .models import SavedView
|
|
from .models import SavedViewFilterRule
|
|
from .models import StoragePath
|
|
from .models import Tag
|
|
|
|
|
|
class CorrespondentAdmin(admin.ModelAdmin):
|
|
|
|
list_display = ("name", "match", "matching_algorithm")
|
|
list_filter = ("matching_algorithm",)
|
|
list_editable = ("match", "matching_algorithm")
|
|
|
|
|
|
class TagAdmin(admin.ModelAdmin):
|
|
|
|
list_display = ("name", "color", "match", "matching_algorithm")
|
|
list_filter = ("color", "matching_algorithm")
|
|
list_editable = ("color", "match", "matching_algorithm")
|
|
|
|
|
|
class DocumentTypeAdmin(admin.ModelAdmin):
|
|
|
|
list_display = ("name", "match", "matching_algorithm")
|
|
list_filter = ("matching_algorithm",)
|
|
list_editable = ("match", "matching_algorithm")
|
|
|
|
|
|
class DocumentAdmin(admin.ModelAdmin):
|
|
|
|
search_fields = ("correspondent__name", "title", "content", "tags__name")
|
|
readonly_fields = (
|
|
"added",
|
|
"modified",
|
|
"mime_type",
|
|
"storage_type",
|
|
"filename",
|
|
"checksum",
|
|
"archive_filename",
|
|
"archive_checksum",
|
|
)
|
|
|
|
list_display_links = ("title",)
|
|
|
|
list_display = ("id", "title", "mime_type", "filename", "archive_filename")
|
|
|
|
list_filter = (
|
|
("mime_type"),
|
|
("archive_serial_number", admin.EmptyFieldListFilter),
|
|
("archive_filename", admin.EmptyFieldListFilter),
|
|
)
|
|
|
|
filter_horizontal = ("tags",)
|
|
|
|
ordering = ["-id"]
|
|
|
|
date_hierarchy = "created"
|
|
|
|
def has_add_permission(self, request):
|
|
return False
|
|
|
|
def created_(self, obj):
|
|
return obj.created.date().strftime("%Y-%m-%d")
|
|
|
|
created_.short_description = "Created"
|
|
|
|
def delete_queryset(self, request, queryset):
|
|
from documents import index
|
|
|
|
with index.open_index_writer() as writer:
|
|
for o in queryset:
|
|
index.remove_document(writer, o)
|
|
|
|
super().delete_queryset(request, queryset)
|
|
|
|
def delete_model(self, request, obj):
|
|
from documents import index
|
|
|
|
index.remove_document_from_index(obj)
|
|
super().delete_model(request, obj)
|
|
|
|
def save_model(self, request, obj, form, change):
|
|
from documents import index
|
|
|
|
index.add_or_update_document(obj)
|
|
super().save_model(request, obj, form, change)
|
|
|
|
|
|
class RuleInline(admin.TabularInline):
|
|
model = SavedViewFilterRule
|
|
|
|
|
|
class SavedViewAdmin(admin.ModelAdmin):
|
|
|
|
list_display = ("name", "user")
|
|
|
|
inlines = [RuleInline]
|
|
|
|
|
|
class StoragePathInline(admin.TabularInline):
|
|
model = StoragePath
|
|
|
|
|
|
class StoragePathAdmin(admin.ModelAdmin):
|
|
list_display = ("name", "path", "match", "matching_algorithm")
|
|
list_filter = ("path", "matching_algorithm")
|
|
list_editable = ("path", "match", "matching_algorithm")
|
|
|
|
|
|
admin.site.register(Correspondent, CorrespondentAdmin)
|
|
admin.site.register(Tag, TagAdmin)
|
|
admin.site.register(DocumentType, DocumentTypeAdmin)
|
|
admin.site.register(Document, DocumentAdmin)
|
|
admin.site.register(SavedView, SavedViewAdmin)
|
|
admin.site.register(StoragePath, StoragePathAdmin)
|