Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dashdrum/django-reportview
Class-based views for PDF output
https://github.com/dashdrum/django-reportview
Last synced: 2 months ago
JSON representation
Class-based views for PDF output
- Host: GitHub
- URL: https://github.com/dashdrum/django-reportview
- Owner: dashdrum
- License: other
- Created: 2013-05-14T20:45:39.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2014-10-24T00:14:37.000Z (about 10 years ago)
- Last Synced: 2024-08-04T04:05:01.461Z (6 months ago)
- Language: Python
- Size: 234 KB
- Stars: 9
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- starred-awesome - django-reportview - Class-based views for PDF output (Python)
README
# Django ReportView
Based on PDFGenView by Inka Labs
Django ReportView provides drop-in replacements for generic class-based views that send the output to a PDF file. The same code used to generate a web page can be repurposed to create a printable copy.
The trml2pdf libary is used to convert a ReportLab template (RML) to PDF output.
Each view adds a class variable called `output-filename`, which holds the name of the file to be created.## Dependencies
- Django 1.3+
- reportlab
- trml2pdf## ReportMixin
This mixin holds the key code from the Inka Labs example.
The `get` method is where all of the magic happens. After setting up the MIME type and filename for the `response`, the RML template is rendered using standard Django code. Trml2pdf takes takes the rendered template and outputs a PDF file. One should take care when overriding this method as to not break this functionality. (Hopefully there won't be much reason to.)
Also, the code to set and check for the `output-filename` variable is here. In this version, the functionality of SingleObjectTemplateResponseMixin and MultipleObjectTemplateResponseMixin have not been implemented.
This mixin should be used with TemplateResponseMixin and View in the inheritence chain.
## TemplateReportView
Mimicking the function of Django's TemplateView, TemplateReportView will output a template, including any context provided.
### Example
class SimpleReportTest(TemplateReportView):
template_name = 'simpletest.rml'
output_filename = 'simpletest.pdf'
def get_context_data(self,**kwargs):
context = super(SimpleReportTest,self).get_context_data(**kwargs)
context['name'] = 'Simple Report Test'
return context
## DetailReportViewUsed to generate a report based on a single object. Just like the generic DetailView, the programmer should provide a template name and data source (model or queryset), along with the output filename.
### Example
class AuthorReport(DetailReportView):
template_name = 'author_report.rml'
model = Author
output_filename = 'author_report.pdf'
`get_context_data()` may be overriden to provide additional context to the template, but the `super` call must be included, since the object value is set in the parent class. (See the TempleReportView example.)The URL definition should pass a `pk` or `slug` variable to the class.
url(r'authorreport/(?P\d+)/$',AuthorReport.as_view(),name='author_report'),
## ListReportView
ListReportView follows the function of ListView to send a list of objects to be rendered into a report. A template name, data source (model or queryset), and output filename should be provided.
At this point, I haven't done anything with the pagination settings, so they will be ignored.
### Example
class PublisherReport(ListReportView):
template_name = 'pub_report.rml'
model = Publisher
output_filename = 'pub_report.pdf'
Once again, 'get_context_data()' should be overridden including a `super` call, in this case to set the `object-list` class variable.## RML Templates
RML is a very rich templating language included in the ReportLab package. I have only begun to explore the possibilities, so there are just a few basic examples provided in this release.
## Version History
### Version 0.1 - May 5, 2013
Initial release
## License
Django Reportview is distributed under the terms of the University of Illinois/NCSA Open Source License license.