def ready(self): super(DocumentsApp, self).ready() from actstream import registry APIEndPoint(app=self, version_string='1') DeletedDocument = self.get_model('DeletedDocument') Document = self.get_model('Document') DocumentPage = self.get_model('DocumentPage') DocumentPageResult = self.get_model('DocumentPageResult') DocumentType = self.get_model('DocumentType') DocumentTypeFilename = self.get_model('DocumentTypeFilename') DocumentVersion = self.get_model('DocumentVersion') DynamicSerializerField.add_serializer( klass=Document, serializer_class='documents.serializers.DocumentSerializer' ) DashboardWidget( func=new_document_pages_this_month, icon='fa fa-calendar', label=_('New pages this month'), link=reverse_lazy( 'statistics:statistic_detail', args=('new-document-pages-per-month',) ) ) DashboardWidget( func=new_documents_this_month, icon='fa fa-calendar', label=_('New documents this month'), link=reverse_lazy( 'statistics:statistic_detail', args=('new-documents-per-month',) ) ) DashboardWidget( icon='fa fa-file', queryset=Document.objects.all(), label=_('Total documents'), link=reverse_lazy('documents:document_list') ) DashboardWidget( icon='fa fa-book', queryset=DocumentType.objects.all(), label=_('Document types'), link=reverse_lazy('documents:document_type_list') ) DashboardWidget( icon='fa fa-trash', queryset=DeletedDocument.objects.all(), label=_('Documents in trash'), link=reverse_lazy('documents:document_list_deleted') ) MissingItem( label=_('Create a document type'), description=_( 'Every uploaded document must be assigned a document type, ' 'it is the basic way Mayan EDMS categorizes documents.' ), condition=lambda: not DocumentType.objects.exists(), view='documents:document_type_list' ) ModelAttribute( Document, label=_('Label'), name='label', type_name='field' ) ModelAttribute( Document, description=_('The MIME type of any of the versions of a document'), label=_('MIME type'), name='versions__mimetype', type_name='field' ) ModelPermission.register( model=Document, permissions=( permission_acl_edit, permission_acl_view, permission_document_delete, permission_document_download, permission_document_edit, permission_document_new_version, permission_document_print, permission_document_properties_edit, permission_document_restore, permission_document_trash, permission_document_version_revert, permission_document_view, permission_events_view, permission_transformation_create, permission_transformation_delete, permission_transformation_edit, permission_transformation_view, ) ) ModelPermission.register( model=DocumentType, permissions=(permission_document_create,) ) ModelPermission.register_proxy( source=Document, model=DocumentType, ) ModelPermission.register_inheritance( model=Document, related='document_type', ) ModelPermission.register_inheritance( model=DocumentVersion, related='document', ) ModelPermission.register_inheritance( model=DocumentPage, related='document', ) # Document and document page thumbnail widget document_thumbnail_widget = DocumentThumbnailWidget() document_page_thumbnail_widget = DocumentPageThumbnailWidget() SourceColumn( source=Document, label=_('Thumbnail'), func=lambda context: document_thumbnail_widget.render( instance=context['object'] ) ) SourceColumn( source=Document, label=_('Type'), attribute='document_type' ) SourceColumn( source=DocumentPage, label=_('Thumbnail'), func=lambda context: document_page_thumbnail_widget.render( instance=context['object'] ) ) SourceColumn( source=DocumentPageResult, label=_('Thumbnail'), func=lambda context: document_page_thumbnail_widget.render( instance=context['object'] ) ) SourceColumn( source=DocumentPageResult, label=_('Type'), attribute='document_version.document.document_type' ) SourceColumn( source=DocumentType, label=_('Documents'), func=lambda context: context['object'].get_document_count( user=context['request'].user ) ) SourceColumn( source=DocumentTypeFilename, label=_('Enabled'), func=lambda context: two_state_template(context['object'].enabled) ) SourceColumn( source=DeletedDocument, label=_('Thumbnail'), func=lambda context: document_thumbnail_widget.render( instance=context['object'] ) ) SourceColumn( source=DeletedDocument, label=_('Type'), attribute='document_type' ) SourceColumn( source=DeletedDocument, label=_('Date time trashed'), attribute='deleted_date_time' ) SourceColumn( source=DocumentVersion, label=_('Time and date'), attribute='timestamp' ) SourceColumn( source=DocumentVersion, label=_('MIME type'), attribute='mimetype' ) SourceColumn( source=DocumentVersion, label=_('Encoding'), attribute='encoding' ) SourceColumn( source=DocumentVersion, label=_('Comment'), attribute='comment' ) app.conf.CELERYBEAT_SCHEDULE.update( { 'task_check_delete_periods': { 'task': 'documents.tasks.task_check_delete_periods', 'schedule': timedelta( seconds=CHECK_DELETE_PERIOD_INTERVAL ), }, 'task_check_trash_periods': { 'task': 'documents.tasks.task_check_trash_periods', 'schedule': timedelta(seconds=CHECK_TRASH_PERIOD_INTERVAL), }, 'task_delete_stubs': { 'task': 'documents.tasks.task_delete_stubs', 'schedule': timedelta(seconds=DELETE_STALE_STUBS_INTERVAL), }, } ) app.conf.CELERY_QUEUES.extend( ( Queue( 'converter', Exchange('converter'), routing_key='converter', delivery_mode=1 ), Queue( 'documents_periodic', Exchange('documents_periodic'), routing_key='documents_periodic', delivery_mode=1 ), Queue('uploads', Exchange('uploads'), routing_key='uploads'), ) ) app.conf.CELERY_ROUTES.update( { 'documents.tasks.task_check_delete_periods': { 'queue': 'documents_periodic' }, 'documents.tasks.task_check_trash_periods': { 'queue': 'documents_periodic' }, 'documents.tasks.task_delete_stubs': { 'queue': 'documents_periodic' }, 'documents.tasks.task_clear_image_cache': { 'queue': 'tools' }, 'documents.tasks.task_generate_document_page_image': { 'queue': 'converter' }, 'documents.tasks.task_update_page_count': { 'queue': 'uploads' }, 'documents.tasks.task_upload_new_version': { 'queue': 'uploads' }, } ) menu_documents.bind_links( links=( link_document_list_recent, link_document_list, link_document_list_deleted ) ) menu_main.bind_links(links=(menu_documents,), position=0) menu_setup.bind_links(links=(link_document_type_setup,)) menu_tools.bind_links(links=(link_clear_image_cache,)) # Document type links menu_object.bind_links( links=( link_document_type_edit, link_document_type_filename_list, link_acl_list, link_document_type_delete ), sources=(DocumentType,) ) menu_object.bind_links( links=( link_document_type_filename_edit, link_document_type_filename_delete ), sources=(DocumentTypeFilename,) ) menu_secondary.bind_links( links=(link_document_type_list, link_document_type_create), sources=( DocumentType, 'documents:document_type_create', 'documents:document_type_list' ) ) menu_sidebar.bind_links( links=(link_document_type_filename_create,), sources=( DocumentTypeFilename, 'documents:document_type_filename_list', 'documents:document_type_filename_create' ) ) menu_sidebar.bind_links( links=(link_trash_can_empty,), sources=( 'documents:document_list_deleted', 'documents:trash_can_empty' ) ) # Document object links menu_object.bind_links( links=( link_document_edit, link_document_document_type_edit, link_document_print, link_document_trash, link_document_download, link_document_clear_transformations, link_document_clone_transformations, link_document_update_page_count ), sources=(Document,) ) menu_object.bind_links( links=(link_document_restore, link_document_delete), sources=(DeletedDocument,) ) # Document facet links menu_facet.bind_links(links=(link_acl_list,), sources=(Document,)) menu_facet.bind_links( links=(link_document_preview,), sources=(Document,), position=0 ) menu_facet.bind_links( links=(link_document_properties,), sources=(Document,), position=2 ) menu_facet.bind_links( links=(link_events_for_object, link_document_version_list,), sources=(Document,), position=2 ) menu_facet.bind_links(links=(link_document_pages,), sources=(Document,)) # Document actions menu_object.bind_links( links=( link_document_version_revert, link_document_version_download ), sources=(DocumentVersion,) ) menu_multi_item.bind_links( links=( link_document_multiple_clear_transformations, link_document_multiple_trash, link_document_multiple_download, link_document_multiple_update_page_count, link_document_multiple_document_type_edit ), sources=(Document,) ) menu_multi_item.bind_links( links=( link_document_multiple_restore, link_document_multiple_delete ), sources=(DeletedDocument,) ) # Document pages menu_facet.bind_links( links=( link_document_page_rotate_left, link_document_page_rotate_right, link_document_page_zoom_in, link_document_page_zoom_out, link_document_page_view_reset ), sources=('documents:document_page_view',) ) menu_facet.bind_links( links=(link_document_page_return, link_document_page_view), sources=(DocumentPage,) ) menu_facet.bind_links( links=( link_document_page_navigation_first, link_document_page_navigation_previous, link_document_page_navigation_next, link_document_page_navigation_last, link_transformation_list ), sources=(DocumentPage,) ) menu_object.bind_links( links=(link_transformation_list,), sources=(DocumentPage,) ) namespace = StatisticNamespace(slug='documents', label=_('Documents')) namespace.add_statistic( slug='new-documents-per-month', label=_('New documents per month'), func=new_documents_per_month, renderer=CharJSLine, minute='0' ) namespace.add_statistic( slug='new-document-versions-per-month', label=_('New document versions per month'), func=new_document_versions_per_month, renderer=CharJSLine, minute='0' ) namespace.add_statistic( slug='new-document-pages-per-month', label=_('New document pages per month'), func=new_document_pages_per_month, renderer=CharJSLine, minute='0' ) namespace.add_statistic( slug='total-documents-at-each-month', label=_('Total documents at each month'), func=total_document_per_month, renderer=CharJSLine, minute='0' ) namespace.add_statistic( slug='total-document-versions-at-each-month', label=_('Total document versions at each month'), func=total_document_version_per_month, renderer=CharJSLine, minute='0' ) namespace.add_statistic( slug='total-document-pages-at-each-month', label=_('Total document pages at each month'), func=total_document_page_per_month, renderer=CharJSLine, minute='0' ) post_initial_setup.connect( create_default_document_type, dispatch_uid='create_default_document_type' ) registry.register(DeletedDocument) registry.register(Document)
def get_document_types_queryset(): DocumentType = apps.get_model(app_label='documents', model_name='DocumentType') return DocumentType.objects.all() def get_deleted_documents_queryset(): DeletedDocument = apps.get_model(app_label='documents', model_name='DeletedDocument') return DeletedDocument.objects.all() widget_pages_per_month = DashboardWidget( func=new_document_pages_this_month, icon_class=icon_dashboard_pages_per_month, label=_('New pages this month'), link=reverse_lazy('statistics:statistic_detail', args=('new-document-pages-per-month', ))) widget_new_documents_this_month = DashboardWidget( func=new_documents_this_month, icon_class=icon_dashboard_new_documents_this_month, label=_('New documents this month'), link=reverse_lazy('statistics:statistic_detail', args=('new-documents-per-month', ))) widget_total_documents = DashboardWidget( icon_class=icon_dashboard_total_document, queryset=get_total_documents_queryset, label=_('Total documents'), link=reverse_lazy('documents:document_list'))
from __future__ import absolute_import, unicode_literals from django.apps import apps from django.urls import reverse_lazy from django.utils.translation import ugettext_lazy as _ from common.classes import DashboardWidget from .icons import icon_dashboard_checkouts def checkedout_documents_queryset(): DocumentCheckout = apps.get_model(app_label='checkouts', model_name='DocumentCheckout') return DocumentCheckout.objects.all() widget_checkouts = DashboardWidget( icon_class=icon_dashboard_checkouts, label=_('Checkedout documents'), link=reverse_lazy('checkouts:checkout_list'), queryset=checkedout_documents_queryset)
def ready(self): super(CheckoutsApp, self).ready() APIEndPoint(app=self, version_string='1') Document = apps.get_model(app_label='documents', model_name='Document') DocumentVersion = apps.get_model(app_label='documents', model_name='DocumentVersion') DocumentCheckout = self.get_model('DocumentCheckout') DashboardWidget(icon='fa fa-shopping-cart', queryset=DocumentCheckout.objects.all(), label=_('Checkedout documents'), link=reverse_lazy('checkouts:checkout_list')) Document.add_to_class('check_in', lambda document, user=None: DocumentCheckout. objects.check_in_document(document, user)) Document.add_to_class( 'checkout_info', lambda document: DocumentCheckout.objects. document_checkout_info(document)) Document.add_to_class( 'checkout_state', lambda document: DocumentCheckout.objects. document_checkout_state(document)) Document.add_to_class( 'is_checked_out', lambda document: DocumentCheckout.objects. is_document_checked_out(document)) ModelPermission.register( model=Document, permissions=(permission_document_checkout, permission_document_checkin, permission_document_checkin_override, permission_document_checkout_detail_view)) app.conf.CELERYBEAT_SCHEDULE.update({ 'task_check_expired_check_outs': { 'task': 'checkouts.tasks.task_check_expired_check_outs', 'schedule': timedelta(seconds=CHECK_EXPIRED_CHECK_OUTS_INTERVAL), }, }) app.conf.CELERY_QUEUES.append( Queue('checkouts_periodic', Exchange('checkouts_periodic'), routing_key='checkouts_periodic', delivery_mode=1), ) app.conf.CELERY_ROUTES.update({ 'checkouts.tasks.task_check_expired_check_outs': { 'queue': 'checkouts_periodic' }, }) menu_facet.bind_links(links=(link_checkout_info, ), sources=(Document, )) menu_main.bind_links(links=(link_checkout_list, ), position=98) menu_sidebar.bind_links(links=(link_checkout_document, link_checkin_document), sources=('checkouts:checkout_info', 'checkouts:checkout_document', 'checkouts:checkin_document')) pre_save.connect(check_new_version_creation, dispatch_uid='check_new_version_creation', sender=DocumentVersion)
from __future__ import absolute_import, unicode_literals from django.apps import apps from django.urls import reverse_lazy from django.utils.translation import ugettext_lazy as _ from common.classes import DashboardWidget def checkedout_documents_queryset(): DocumentCheckout = apps.get_model(app_label='checkouts', model_name='DocumentCheckout') return DocumentCheckout.objects.all() widget_checkouts = DashboardWidget( label=_('Checkedout documents'), link=reverse_lazy('checkouts:checkout_list'), icon='fa fa-shopping-cart', queryset=checkedout_documents_queryset)