Instead of inserting the path of the apps into the Python app, the apps are now referenced by their full import path. This app name claves with external or native Python libraries. Example: Mayan statistics app vs. Python new statistics library. Every app reference is now prepended with 'mayan.apps'. Existing config.yml files need to be updated manually. Signed-off-by: Roberto Rosario <roberto.rosario.gonzalez@gmail.com>
180 lines
5.5 KiB
Python
180 lines
5.5 KiB
Python
from __future__ import absolute_import, unicode_literals
|
|
|
|
from django.contrib import messages
|
|
from django.http import HttpResponseRedirect
|
|
from django.shortcuts import get_object_or_404
|
|
from django.urls import reverse, reverse_lazy
|
|
from django.utils.translation import ugettext_lazy as _, ungettext
|
|
|
|
from mayan.apps.common.generics import (
|
|
FormView, MultipleObjectConfirmActionView, SingleObjectDetailView,
|
|
SingleObjectDownloadView, SingleObjectEditView, SingleObjectListView
|
|
)
|
|
from mayan.apps.documents.models import Document, DocumentPage, DocumentType
|
|
|
|
from .forms import (
|
|
DocumentPageOCRContentForm, DocumentOCRContentForm,
|
|
DocumentTypeSelectForm
|
|
)
|
|
from .models import DocumentVersionOCRError
|
|
from .permissions import (
|
|
permission_ocr_content_view, permission_ocr_document,
|
|
permission_document_type_ocr_setup
|
|
)
|
|
from .utils import get_document_ocr_content
|
|
|
|
|
|
class DocumentOCRContentView(SingleObjectDetailView):
|
|
form_class = DocumentOCRContentForm
|
|
model = Document
|
|
object_permission = permission_ocr_content_view
|
|
|
|
def dispatch(self, request, *args, **kwargs):
|
|
result = super(DocumentOCRContentView, self).dispatch(
|
|
request, *args, **kwargs
|
|
)
|
|
self.get_object().add_as_recent_document_for_user(user=request.user)
|
|
return result
|
|
|
|
def get_extra_context(self):
|
|
return {
|
|
'document': self.get_object(),
|
|
'hide_labels': True,
|
|
'object': self.get_object(),
|
|
'title': _('OCR result for document: %s') % self.get_object(),
|
|
}
|
|
|
|
|
|
class DocumentPageOCRContentView(SingleObjectDetailView):
|
|
form_class = DocumentPageOCRContentForm
|
|
model = DocumentPage
|
|
object_permission = permission_ocr_content_view
|
|
|
|
def dispatch(self, request, *args, **kwargs):
|
|
result = super(DocumentPageOCRContentView, self).dispatch(
|
|
request, *args, **kwargs
|
|
)
|
|
self.get_object().document.add_as_recent_document_for_user(
|
|
user=request.user
|
|
)
|
|
return result
|
|
|
|
def get_extra_context(self):
|
|
return {
|
|
'hide_labels': True,
|
|
'object': self.get_object(),
|
|
'title': _('OCR result for document page: %s') % self.get_object(),
|
|
}
|
|
|
|
|
|
class DocumentSubmitView(MultipleObjectConfirmActionView):
|
|
model = Document
|
|
object_permission = permission_ocr_document
|
|
success_message = '%(count)d document submitted to the OCR queue.'
|
|
success_message_plural = '%(count)d documents submitted to the OCR queue.'
|
|
|
|
def get_extra_context(self):
|
|
queryset = self.get_queryset()
|
|
|
|
result = {
|
|
'title': ungettext(
|
|
'Submit the selected document to the OCR queue?',
|
|
'Submit the selected documents to the OCR queue?',
|
|
queryset.count()
|
|
)
|
|
}
|
|
|
|
return result
|
|
|
|
def object_action(self, form, instance):
|
|
instance.submit_for_ocr()
|
|
|
|
|
|
class DocumentTypeSubmitView(FormView):
|
|
extra_context = {
|
|
'title': _('Submit all documents of a type for OCR')
|
|
}
|
|
form_class = DocumentTypeSelectForm
|
|
|
|
def form_valid(self, form):
|
|
count = 0
|
|
for document in form.cleaned_data['document_type'].documents.all():
|
|
document.submit_for_ocr()
|
|
count += 1
|
|
|
|
messages.success(
|
|
self.request, _(
|
|
'%(count)d documents of type "%(document_type)s" added to the '
|
|
'OCR queue.'
|
|
) % {
|
|
'count': count,
|
|
'document_type': form.cleaned_data['document_type']
|
|
}
|
|
)
|
|
|
|
return HttpResponseRedirect(self.get_success_url())
|
|
|
|
def get_post_action_redirect(self):
|
|
return reverse('common:tools_list')
|
|
|
|
|
|
class DocumentTypeSettingsEditView(SingleObjectEditView):
|
|
fields = ('auto_ocr',)
|
|
object_permission = permission_document_type_ocr_setup
|
|
post_action_redirect = reverse_lazy('documents:document_type_list')
|
|
|
|
def get_document_type(self):
|
|
return get_object_or_404(DocumentType, pk=self.kwargs['pk'])
|
|
|
|
def get_extra_context(self):
|
|
return {
|
|
'object': self.get_document_type(),
|
|
'title': _(
|
|
'Edit OCR settings for document type: %s'
|
|
) % self.get_document_type()
|
|
}
|
|
|
|
def get_object(self, queryset=None):
|
|
return self.get_document_type().ocr_settings
|
|
|
|
|
|
class EntryListView(SingleObjectListView):
|
|
extra_context = {
|
|
'hide_object': True,
|
|
'title': _('OCR errors'),
|
|
}
|
|
view_permission = permission_document_type_ocr_setup
|
|
|
|
def get_object_list(self):
|
|
return DocumentVersionOCRError.objects.all()
|
|
|
|
|
|
class DocumentOCRErrorsListView(SingleObjectListView):
|
|
object_permission = permission_ocr_document
|
|
|
|
def get_document(self):
|
|
return get_object_or_404(Document, pk=self.kwargs['pk'])
|
|
|
|
def get_extra_context(self):
|
|
return {
|
|
'hide_object': True,
|
|
'object': self.get_document(),
|
|
'title': _('OCR errors for document: %s') % self.get_document(),
|
|
}
|
|
|
|
def get_object_list(self):
|
|
return self.get_document().latest_version.ocr_errors.all()
|
|
|
|
|
|
class DocumentOCRDownloadView(SingleObjectDownloadView):
|
|
model = Document
|
|
object_permission = permission_ocr_content_view
|
|
|
|
def get_file(self):
|
|
file_object = DocumentOCRDownloadView.TextIteratorIO(
|
|
iterator=get_document_ocr_content(document=self.get_object())
|
|
)
|
|
return DocumentOCRDownloadView.VirtualFile(
|
|
file=file_object, name='{}-OCR'.format(self.get_object())
|
|
)
|