diff options
author | Charlie Denton <charlie@incuna.com> | 2011-07-25 17:20:00 +0100 |
---|---|---|
committer | Charlie Denton <charlie@incuna.com> | 2011-07-25 17:20:00 +0100 |
commit | a18798423e3d1b39eb9b8fa8702265001b1311aa (patch) | |
tree | 35eb353d95e95cd96c6cef57db9fdb23264a5463 /wkhtmltopdf | |
parent | 3db3101bbfef9b03ec34b96fc4d1cc68ca9c2274 (diff) | |
download | django-wkhtmltopdf-a18798423e3d1b39eb9b8fa8702265001b1311aa.tar.gz django-wkhtmltopdf-a18798423e3d1b39eb9b8fa8702265001b1311aa.tar.bz2 django-wkhtmltopdf-a18798423e3d1b39eb9b8fa8702265001b1311aa.zip |
fixed some bugs, added filename support
Diffstat (limited to 'wkhtmltopdf')
-rw-r--r-- | wkhtmltopdf/utils.py | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/wkhtmltopdf/utils.py b/wkhtmltopdf/utils.py index 7988371..8eb569b 100644 --- a/wkhtmltopdf/utils.py +++ b/wkhtmltopdf/utils.py @@ -50,7 +50,7 @@ def wkhtmltopdf(pages, output=None, **kwargs): stdoutdata, stderrdata = process.communicate() if process.returncode != 0: - raise CalledProcessError(returncode, args) + raise CalledProcessError(process.returncode, args) if output is None: output = stdoutdata @@ -60,14 +60,16 @@ def wkhtmltopdf(pages, output=None, **kwargs): def render_to_pdf(template_name, dictionary=None, context_instance=None, header_template=None, footer_template=None, **kwargs): """Renders a html template as a PDF response.""" + filename = kwargs.pop('filename', None) + page_path = template_to_temp_file(template_name, dictionary, context_instance) tmp_files = [] if header_template is not None: - kwargs['header_html'] = render_to_temp_file(header_template, dictionary, context_instance) + kwargs['header_html'] = template_to_temp_file(header_template, dictionary, context_instance) tmp_files.append(kwargs['header_html']) if footer_template is not None: - kwargs['footer_html'] = render_to_temp_file(footer_template, dictionary, context_instance) + kwargs['footer_html'] = template_to_temp_file(footer_template, dictionary, context_instance) tmp_files.append(kwargs['footer_html']) content = wkhtmltopdf([page_path], **kwargs) @@ -75,7 +77,11 @@ def render_to_pdf(template_name, dictionary=None, context_instance=None, header_ for path in tmp_files: remove(path) - return HttpResponse(content, mimetype='application/pdf') + response = HttpResponse(content, mimetype='application/pdf') + if filename is not None: + response['Content-Disposition'] = 'attachment;' + ' filename=%s' %filename + return response + def template_to_temp_file(*args, **kwargs): """Renders a template to a temp file, and returns the path of the file.""" |