Changed the side bar document grouping with carousel style document grouping form widget
This commit is contained in:
@@ -91,7 +91,6 @@
|
||||
{% endwith %}
|
||||
{% endfor %}
|
||||
|
||||
|
||||
{% for subtemplate in subtemplates_dict %}
|
||||
{% with subtemplate.title as title %}
|
||||
{% with subtemplate.object_list as object_list %}
|
||||
@@ -100,8 +99,30 @@
|
||||
{% with subtemplate.main_object as main_object %}
|
||||
{% with subtemplate.hide_link as hide_link %}
|
||||
{% with subtemplate.hide_header as hide_header %}
|
||||
|
||||
<div class="grid_{{ subtemplate.grid|default:11 }}">
|
||||
{% include subtemplate.name %}
|
||||
|
||||
{% if subtemplate.form %}
|
||||
{% with subtemplate.submit_method as submit_method %}
|
||||
{% with subtemplate.striptags as striptags %}
|
||||
{% with subtemplate.object as object %}
|
||||
{% with subtemplate.object_name as object_name %}
|
||||
{% with subtemplate.form_action as form_action %}
|
||||
{% with "true" as read_only %}
|
||||
{% with subtemplate.form as form %}
|
||||
<div class="generic_subform">
|
||||
{% include subtemplate.name %}
|
||||
</div>
|
||||
{% endwith %}
|
||||
{% endwith %}
|
||||
{% endwith %}
|
||||
{% endwith %}
|
||||
{% endwith %}
|
||||
{% endwith %}
|
||||
{% endwith %}
|
||||
{% else %}
|
||||
{% include subtemplate.name %}
|
||||
{% endif %}
|
||||
</div>
|
||||
{% if subtemplate.grid_clear or not subtemplate.grid %}
|
||||
<div class="clear"></div>
|
||||
|
||||
@@ -92,7 +92,7 @@ class ImageWidget(forms.widgets.Widget):
|
||||
<img src="%(img)s?page=%(page)s" />
|
||||
</a>
|
||||
<div class="tc">
|
||||
<a class="fancybox-iframe" href="%(url)s"><span class="famfam active famfam-page_go"></span>%(details_string)s</a>
|
||||
<a class="fancybox-iframe" href="%(url)s"><span class="famfam active famfam-page_white_go"></span>%(details_string)s</a>
|
||||
</div>
|
||||
</div>''' % {
|
||||
'url': reverse('document_page_view', args=[page.pk]),
|
||||
@@ -297,3 +297,60 @@ class DocumentCreateWizard(BoundFormWizard):
|
||||
|
||||
url = reverse(view, args=[self.document_type.id])
|
||||
return HttpResponseRedirect('%s?%s' % (url, urlencode(self.urldata)))
|
||||
|
||||
|
||||
class MetaDataImageWidget(forms.widgets.Widget):
|
||||
def render(self, name, value, attrs=None):
|
||||
output = []
|
||||
output.append(
|
||||
u'<br /><span class="famfam active famfam-page_copy"></span>%s<br />' %
|
||||
ugettext(u'Total documents: %s') % len(value['group_data']))
|
||||
|
||||
output.append(u'<div style="white-space:nowrap; overflow: auto;">')
|
||||
for document in value['group_data']:
|
||||
output.append(
|
||||
u'''<div style="display: inline-block; margin: 10px; %(current)s">
|
||||
<div class="tc">%(document_name)s</div>
|
||||
<div class="tc">%(page_string)s: %(document_pages)d</div>
|
||||
<div class="tc">
|
||||
<a rel="group_%(group_id)d_documents_gallery" class="fancybox-noscaling" href="%(view_url)s">
|
||||
<img style="border: 1px solid black; margin: 10px;" src="%(img)s" />
|
||||
</a>
|
||||
</div>
|
||||
<div class="tc">
|
||||
<a href="%(url)s"><span class="famfam active famfam-page_go"></span>%(details_string)s</a>
|
||||
</div>
|
||||
</div>''' % {
|
||||
'url': reverse('document_view_simple', args=[document.pk]),
|
||||
'img': reverse('document_preview_multipage', args=[document.pk]),
|
||||
'current': u'border: 5px solid black; padding: 3px;' if value['current_document'] == document else u'',
|
||||
'view_url': reverse('document_display', args=[document.pk]),
|
||||
'document_pages': document.documentpage_set.count(),
|
||||
'page_string': ugettext(u'Pages'),
|
||||
'details_string': ugettext(u'Select'),
|
||||
'group_id': value['group'].pk,
|
||||
'document_name': document
|
||||
})
|
||||
output.append(u'</div>')
|
||||
output.append(
|
||||
u'<br /><span class="famfam active famfam-magnifier"></span>%s' %
|
||||
ugettext(u'Click on the image for full size view of the first page.'))
|
||||
|
||||
return mark_safe(u''.join(output))
|
||||
|
||||
|
||||
class MetaDataGroupForm(forms.Form):
|
||||
def __init__(self, *args, **kwargs):
|
||||
groups = kwargs.pop('groups', None)
|
||||
current_document = kwargs.pop('current_document', None)
|
||||
super(MetaDataGroupForm, self).__init__(*args, **kwargs)
|
||||
for group, data in groups.items():
|
||||
self.fields['preview-%s' % group] = forms.CharField(
|
||||
widget=MetaDataImageWidget(),
|
||||
label=group,
|
||||
initial={
|
||||
'group': group,
|
||||
'group_data': data,
|
||||
'current_document': current_document
|
||||
}
|
||||
)
|
||||
|
||||
@@ -49,7 +49,7 @@ from forms import DocumentTypeSelectForm, DocumentCreateWizard, \
|
||||
MetadataForm, DocumentForm, DocumentForm_edit, DocumentForm_view, \
|
||||
StagingDocumentForm, DocumentTypeMetadataType, DocumentPreviewForm, \
|
||||
MetadataFormSet, DocumentPageForm, DocumentPageTransformationForm, \
|
||||
DocumentContentForm, DocumentPageForm_edit
|
||||
DocumentContentForm, DocumentPageForm_edit, MetaDataGroupForm
|
||||
|
||||
from metadata import save_metadata_list, \
|
||||
decode_metadata_from_url, metadata_repr_as_list
|
||||
@@ -301,46 +301,36 @@ def document_view(request, document_id):
|
||||
},
|
||||
]
|
||||
|
||||
metadata_groups, errors = document.get_metadata_groups()
|
||||
if (request.user.is_staff or request.user.is_superuser) and errors:
|
||||
for error in errors:
|
||||
messages.warning(request, _(u'Metadata group query error: %s' % error))
|
||||
|
||||
if not GROUP_SHOW_EMPTY:
|
||||
#If GROUP_SHOW_EMPTY is False, remove empty groups from
|
||||
#dictionary
|
||||
metadata_groups = dict([(group, data) for group, data in metadata_groups.items() if data])
|
||||
|
||||
if metadata_groups:
|
||||
subtemplates_dict.append(
|
||||
{
|
||||
'title':_(u'metadata groups'),
|
||||
'form': MetaDataGroupForm(groups=metadata_groups, current_document=document),
|
||||
'name': 'generic_form_subtemplate.html',
|
||||
}
|
||||
)
|
||||
|
||||
if FILESERVING_ENABLE:
|
||||
subtemplates_dict.append({
|
||||
'name': 'generic_list_subtemplate.html',
|
||||
'title': _(u'index links'),
|
||||
'object_list': document.documentmetadataindex_set.all(),
|
||||
'hide_link': True})
|
||||
|
||||
sidebar_groups = []
|
||||
for group, data in metadata_groups.items():
|
||||
if len(data) or GROUP_SHOW_EMPTY:
|
||||
if len(data):
|
||||
if len(data) > GROUP_MAX_RESULTS:
|
||||
total_string = '(%s out of %s)' % (GROUP_MAX_RESULTS, len(data))
|
||||
else:
|
||||
total_string = '(%s)' % len(data)
|
||||
else:
|
||||
total_string = ''
|
||||
|
||||
extra_columns = [{'name':'current', 'attribute':lambda x:
|
||||
'<span class="famfam active famfam-resultset_previous"></span>' if x == document else ''}]
|
||||
|
||||
if GROUP_SHOW_THUMBNAIL:
|
||||
extra_columns.append({'name': _(u'thumbnail'), 'attribute':
|
||||
lambda x: '<a class="fancybox" href="%s"><img src="%s" /></a>' % (reverse('document_preview', args=[x.id]),
|
||||
reverse('document_thumbnail', args=[x.id]))})
|
||||
|
||||
sidebar_groups.append({
|
||||
'title': '%s %s' % (group.label, total_string),
|
||||
'name': 'generic_list_subtemplate.html',
|
||||
'object_list': data[:GROUP_MAX_RESULTS],
|
||||
'hide_columns': True,
|
||||
'hide_header': True,
|
||||
'extra_columns': extra_columns,
|
||||
})
|
||||
|
||||
|
||||
return render_to_response('generic_detail.html', {
|
||||
'form_list': form_list,
|
||||
'object': document,
|
||||
'subtemplates_dict': subtemplates_dict,
|
||||
'sidebar_subtemplates_dict': sidebar_groups,
|
||||
}, context_instance=RequestContext(request))
|
||||
|
||||
|
||||
@@ -824,11 +814,6 @@ def document_view_simple(request, document_id):
|
||||
|
||||
content_form = DocumentContentForm(document=document)
|
||||
|
||||
metadata_groups, errors = document.get_metadata_groups()
|
||||
if (request.user.is_staff or request.user.is_superuser) and errors:
|
||||
for error in errors:
|
||||
messages.warning(request, _(u'Metadata group query error: %s' % error))
|
||||
|
||||
preview_form = DocumentPreviewForm(document=document)
|
||||
form_list = [
|
||||
{
|
||||
@@ -841,6 +826,7 @@ def document_view_simple(request, document_id):
|
||||
'object': document,
|
||||
},
|
||||
]
|
||||
|
||||
subtemplates_dict = [
|
||||
{
|
||||
'name': 'generic_list_subtemplate.html',
|
||||
@@ -851,39 +837,29 @@ def document_view_simple(request, document_id):
|
||||
},
|
||||
]
|
||||
|
||||
sidebar_groups = []
|
||||
for group, data in metadata_groups.items():
|
||||
if len(data) or GROUP_SHOW_EMPTY:
|
||||
if len(data):
|
||||
if len(data) > GROUP_MAX_RESULTS:
|
||||
total_string = '(%s out of %s)' % (GROUP_MAX_RESULTS, len(data))
|
||||
else:
|
||||
total_string = '(%s)' % len(data)
|
||||
else:
|
||||
total_string = ''
|
||||
metadata_groups, errors = document.get_metadata_groups()
|
||||
if (request.user.is_staff or request.user.is_superuser) and errors:
|
||||
for error in errors:
|
||||
messages.warning(request, _(u'Metadata group query error: %s' % error))
|
||||
|
||||
extra_columns = [{'name': 'current', 'attribute': lambda x:
|
||||
'<span class="famfam active famfam-resultset_previous"></span>' if x == document else ''}]
|
||||
|
||||
if GROUP_SHOW_THUMBNAIL:
|
||||
extra_columns.append({'name': _(u'thumbnail'), 'attribute':
|
||||
lambda x: '<a class="fancybox" href="%s"><img src="%s" /></a>' % (reverse('document_preview', args=[x.id]),
|
||||
reverse('document_thumbnail', args=[x.id]))})
|
||||
|
||||
sidebar_groups.append({
|
||||
'title': '%s %s' % (group.label, total_string),
|
||||
'name': 'generic_list_subtemplate.html',
|
||||
'object_list': data[:GROUP_MAX_RESULTS],
|
||||
'hide_columns': True,
|
||||
'hide_header': True,
|
||||
'extra_columns': extra_columns,
|
||||
})
|
||||
if not GROUP_SHOW_EMPTY:
|
||||
#If GROUP_SHOW_EMPTY is False, remove empty groups from
|
||||
#dictionary
|
||||
metadata_groups = dict([(group, data) for group, data in metadata_groups.items() if data])
|
||||
|
||||
if metadata_groups:
|
||||
subtemplates_dict.append(
|
||||
{
|
||||
'title':_(u'metadata groups'),
|
||||
'form': MetaDataGroupForm(groups=metadata_groups, current_document=document),
|
||||
'name': 'generic_form_subtemplate.html',
|
||||
}
|
||||
)
|
||||
|
||||
return render_to_response('generic_detail.html', {
|
||||
'form_list': form_list,
|
||||
'object': document,
|
||||
'subtemplates_dict': subtemplates_dict,
|
||||
'sidebar_subtemplates_dict': sidebar_groups,
|
||||
}, context_instance=RequestContext(request))
|
||||
|
||||
|
||||
|
||||
@@ -9,6 +9,7 @@
|
||||
{% project_name %}<br /><br />
|
||||
{% trans 'Open source, Django based document manager with custom metadata indexing, file serving integration and OCR capabilities' %}<br /><br />
|
||||
<a href="http://www.github.com/rosarior/mayan/">http://www.github.com/rosarior/mayan/</a><br /><br />
|
||||
<br/>{% trans "Released under the GPL V3 License" %}
|
||||
</h3>
|
||||
<div class="tc"><img src="{{ MEDIA_URL }}images/1299551545_egypt200.png"/></div>
|
||||
</div>
|
||||
|
||||
Reference in New Issue
Block a user