mirror of https://github.com/Kozea/pygal.git
Python to generate nice looking SVG graph
http://pygal.org/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
54 lines
1.8 KiB
54 lines
1.8 KiB
# -*- coding: utf-8 -*- |
|
# This file is part of pygal |
|
# |
|
# A python svg graph plotting library |
|
# Copyright © 2012 Kozea |
|
# |
|
# This library is free software: you can redistribute it and/or modify it under |
|
# the terms of the GNU Lesser General Public License as published by the Free |
|
# Software Foundation, either version 3 of the License, or (at your option) any |
|
# later version. |
|
# |
|
# This library is distributed in the hope that it will be useful, but WITHOUT |
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS |
|
# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more |
|
# details. |
|
# |
|
# You should have received a copy of the GNU Lesser General Public License |
|
# along with pygal. If not, see <http://www.gnu.org/licenses/>. |
|
from flask import Flask, render_template, request |
|
from pygal import CHARTS_BY_NAME |
|
from pygal.graph import CHARTS_NAMES |
|
from pygal.config import CONFIG_ITEMS |
|
from pygal.style import styles |
|
from json import loads |
|
|
|
|
|
def create_app(): |
|
"""Creates the pygal test web app""" |
|
|
|
app = Flask(__name__) |
|
|
|
@app.route("/") |
|
def index(): |
|
return render_template( |
|
'index.jinja2', charts_names=CHARTS_NAMES, configs=CONFIG_ITEMS, |
|
styles_names=styles.keys()) |
|
|
|
@app.route("/svg", methods=('POST',)) |
|
def svg(): |
|
values = request.values |
|
config = loads(values['opts']) |
|
config['disable_xml_declaration'] = True |
|
config['style'] = styles[values['style']] |
|
config['js'] = [] |
|
for item in CONFIG_ITEMS: |
|
value = config.get(item.name, None) |
|
if value: |
|
config[item.name] = item.coerce(value) |
|
chart = CHARTS_BY_NAME[values['type']](**config) |
|
for title, vals in loads(values['vals']).items(): |
|
chart.add(title, vals) |
|
return chart.render_response() |
|
|
|
return app
|
|
|