Added a document indexing list view

This commit is contained in:
Roberto Rosario
2011-05-18 11:45:32 -04:00
parent e83529ae2e
commit 1d20a10d49
11 changed files with 123 additions and 21 deletions

View File

@@ -1,7 +1,7 @@
{% extends "base.html" %}
{% load i18n %}
{% load navigation_tags %}
{% block title %} :: {% blocktrans %}List of {{ title }}{% endblocktrans %}{% endblock %}
{% block title %} :: {% blocktrans with title|striptags as stripped_title %}List of {{ stripped_title }}{% endblocktrans %}{% endblock %}
{#{% block secondary_links %}{{ secondary_links|safe }}{% endblock %}#}
{% block sidebar %}

View File

@@ -85,7 +85,7 @@
{% endif %}
</tr>
{% empty %}
<tr><td colspan=99 class="tc">{% blocktrans %}There are no {{ title }}{% endblocktrans %}</td></tr>
<tr><td colspan=99 class="tc">{% blocktrans with title|striptags as stripped_title %}There are no {{ stripped_title }}{% endblocktrans %}</td></tr>
{% endfor %}
</tbody>
</table>

View File

@@ -13,7 +13,7 @@ class IndexInstanceInline(admin.StackedInline):
class IndexAdmin(MPTTModelAdmin):
list_display = ('expression', 'enabled', 'link_document')
list_display = ('expression', 'enabled', 'link_documents')
class IndexInstanceAdmin(MPTTModelAdmin):

View File

@@ -1,4 +1,7 @@
from django.utils.translation import ugettext_lazy as _
from django.utils.translation import ugettext
from django.core.urlresolvers import reverse
from django.utils.safestring import mark_safe
from metadata.classes import MetadataObject
@@ -14,7 +17,7 @@ def evaluate_index(eval_dict, document, node, parent_index_instance=None):
try:
result = eval(node.expression, eval_dict, AVAILABLE_INDEXING_FUNCTIONS)
index_instance, created = IndexInstance.objects.get_or_create(index=node, value=result, parent=parent_index_instance)
if node.link_document:
if node.link_documents:
index_instance.documents.add(document)
for children in node.get_children():
@@ -42,7 +45,6 @@ def update_indexes(document):
eval_dict['metadata'] = MetadataObject(metadata_dict)
for root in Index.objects.filter(parent=None):
#for node in root.get_children():
index_warnings = evaluate_index(eval_dict, document, root)
warnings.extend(index_warnings)
@@ -51,3 +53,40 @@ def update_indexes(document):
def delete_indexes(document):
print 'delete_indexes'
def get_instance_link(index_instance=None, text=None, simple=False):
if simple:
# Just display the instance's value or overrided text, no
# HTML anchor
template = u'%(value)s'
else:
template = u'<a href="%(url)s">%(value)s</a>'
if index_instance:
return template % {
'url': index_instance.get_absolute_url(), 'value': text if text else index_instance
}
else:
# Root node
return template % {
'url': reverse('index_instance_list'), 'value': ugettext(u'root')
}
def get_breadcrumbs(index_instance, simple=False, single_link=False):
result = []
if single_link:
# Return the entire breadcrumb as a single HTML anchor
simple = True
result.append(get_instance_link(simple=simple))
for instance in index_instance.get_ancestors():
result.append(get_instance_link(instance, simple=simple))
result.append(get_instance_link(index_instance, simple=simple))
if single_link:
return mark_safe(get_instance_link(index_instance=index_instance, text=(u' / '.join(result))))
else:
return mark_safe(u' / '.join(result))

View File

@@ -1,7 +1,8 @@
from django.db import models
from django.utils.translation import ugettext_lazy as _
from mptt.models import MPTTModel, TreeForeignKey
from mptt.models import MPTTModel
from mptt.fields import TreeForeignKey
from documents.models import Document
@@ -15,10 +16,10 @@ class Index(MPTTModel):
expression = models.CharField(max_length=128, verbose_name=_(u'indexing expression'), help_text=_(u'Enter a python string expression to be evaluated.'))
# % available_indexing_functions_string)
enabled = models.BooleanField(default=True, verbose_name=_(u'enabled'))
link_document = models.BooleanField(default=False, verbose_name=_(u'link document'))
link_documents = models.BooleanField(default=False, verbose_name=_(u'link documents'))
def __unicode__(self):
return self.expression if not self.link_document else u'%s/[document]' % self.expression
return self.expression if not self.link_documents else u'%s/[document]' % self.expression
class Meta:
verbose_name = _(u'index')
@@ -34,9 +35,12 @@ class IndexInstance(MPTTModel):
def __unicode__(self):
return self.value
@models.permalink
def get_absolute_url(self):
return ('index_instance_list', [self.pk])
def get_document_list_display(self):
return u', '.join([d.file_filename for d in self.documents.all()])
class Meta:
verbose_name = _(u'index instance')

View File

@@ -0,0 +1,6 @@
from django.conf.urls.defaults import patterns, url
urlpatterns = patterns('document_indexing.views',
url(r'^(?P<index_id>\d+)/list/$', 'index_instance_list', (), 'index_instance_list'),
url(r'^list/$', 'index_instance_list', (), 'index_instance_list'),
)

View File

@@ -0,0 +1,23 @@
from django.utils.translation import ugettext_lazy as _
from document_indexing.api import get_breadcrumbs
def get_document_indexing_subtemplate(document):
"""
Return all the settings to render a subtemplate containing a
list of index instances where a document may be found
"""
object_list = []
for index_instance in document.indexinstance_set.all():
object_list.append(get_breadcrumbs(index_instance, single_link=True))
return {
'name': 'generic_list_subtemplate.html',
'context': {
'title': _(u'index links'),
'object_list': object_list,
'hide_link': True
}
}

View File

@@ -1 +1,37 @@
# Create your views here.
from django.utils.translation import ugettext_lazy as _
from django.utils.translation import ugettext
from django.http import HttpResponseRedirect
from django.shortcuts import render_to_response, get_object_or_404
from django.template import RequestContext
from django.contrib import messages
from django.core.urlresolvers import reverse
from django.conf import settings
from django.utils.safestring import mark_safe
from document_indexing.models import IndexInstance
from document_indexing.api import get_breadcrumbs, get_instance_link
def index_instance_list(request, index_id=None):
#TODO: check_permissions
#check_permissions(request.user, 'documents', [PERMISSION_DOCUMENT_VIEW])
if index_id:
index_instance = get_object_or_404(IndexInstance, pk=index_id)
index_instance_list = [index for index in index_instance.get_children()]
breadcrumbs = get_breadcrumbs(index_instance)
if index_instance.documents.count():
for document in index_instance.documents.all():
index_instance_list.append(document)
else:
index_instance_list = IndexInstance.objects.filter(parent=None)
breadcrumbs = get_instance_link()
title = mark_safe(_(u'contents for index: %s') % breadcrumbs)
return render_to_response('generic_list.html', {
'object_list': index_instance_list,
'title': title,
'hide_links': True,
}, context_instance=RequestContext(request))

View File

@@ -26,7 +26,6 @@ from converter.api import DEFAULT_ZOOM_LEVEL, DEFAULT_ROTATION, \
DEFAULT_FILE_FORMAT, QUALITY_PRINT
from document_comments.utils import get_comments_subtemplate
from filesystem_serving.api import document_create_fs_links, document_delete_fs_links
from filesystem_serving.conf.settings import FILESERVING_ENABLE
from filetransfers.api import serve_file
from grouping.models import DocumentGroup
from grouping import document_group_link
@@ -37,6 +36,7 @@ from metadata.forms import MetadataFormSet
from navigation.utils import resolve_to_name
from permissions.api import check_permissions
from tags.utils import get_tags_subtemplate
from document_indexing.utils import get_document_indexing_subtemplate
from documents.conf.settings import DELETE_STAGING_FILE_AFTER_UPLOAD
from documents.conf.settings import USE_STAGING_DIRECTORY
@@ -396,15 +396,8 @@ def document_view_advanced(request, document_id):
if document_group_subtemplate:
subtemplates_list.append(document_group_subtemplate)
if FILESERVING_ENABLE:
subtemplates_list.append({
'name': 'generic_list_subtemplate.html',
'context': {
'title': _(u'index links'),
'object_list': document.documentmetadataindex_set.all(),
'hide_link': True
}
})
if document.indexinstance_set.count():
subtemplates_list.append(get_document_indexing_subtemplate(document))
return render_to_response('generic_detail.html', {
'object': document,

View File

@@ -147,8 +147,8 @@ INSTALLED_APPS = (
'user_management',
'documents',
'grouping',
'document_indexing',
'mptt',
'document_indexing',
)
TEMPLATE_CONTEXT_PROCESSORS = (

View File

@@ -23,6 +23,7 @@ urlpatterns = patterns('',
(r'^settings/', include('smart_settings.urls')),
(r'^metadata/', include('metadata.urls')),
(r'^grouping/', include('grouping.urls')),
(r'^document_indexing/', include('document_indexing.urls')),
)