1.1 --- a/eskp.py Fri Mar 11 09:43:34 2016 +0100
1.2 +++ b/eskp.py Fri Mar 11 09:45:30 2016 +0100
1.3 @@ -19,11 +19,11 @@
1.4 import base64
1.5
1.6 LANGUAGE_SELECTED = "de"
1.7 -#ToDo after engelish is implemented set LANGUAGE_SELECTED = None
1.8 +# ToDo after engelish is implemented set LANGUAGE_SELECTED = None
1.9
1.10 # We need the path of this file to find templates to translate
1.11 ESKP_PATH = os.path.dirname(os.path.abspath(__file__))
1.12 -logging.basicConfig(filename=os.path.join(ESKP_PATH, 'eskp-app.log'),level=logging.DEBUG)
1.13 +logging.basicConfig(filename=os.path.join(ESKP_PATH, 'eskp-app.log'), level=logging.DEBUG)
1.14
1.15 app = Flask(__name__)
1.16 babel = Babel(app)
1.17 @@ -31,12 +31,10 @@
1.18 app.config['BABEL_DEFAULT_LOCALE'] = 'de'
1.19
1.20
1.21 -
1.22 def get_vcard(filename):
1.23 filename = os.path.join(ESKP_PATH, filename)
1.24 with codecs.open(filename, 'r', 'utf-8') as f:
1.25 - vcard = f.read()
1.26 - f.close()
1.27 + vcard = f.read()
1.28 return vobject.readOne(vcard)
1.29
1.30
1.31 @@ -46,25 +44,36 @@
1.32 if os.path.isfile(filename):
1.33 with codecs.open(filename, 'r', 'utf-8') as f:
1.34 rst_data = f.read()
1.35 - f.close()
1.36 content = publish_parts(rst_data, writer_name='html', settings_overrides=overrides)['html_body']
1.37 return content
1.38
1.39 +
1.40 +def get_newest_date():
1.41 + files = os.listdir(os.path.join(ESKP_PATH, 'static/images/uvmap'))
1.42 + getdates = get_valid_dates(files)
1.43 + newest_date = getdates[-1]
1.44 +
1.45 + return newest_date
1.46 +
1.47 +
1.48 def get_topmenue():
1.49 + newest_date = get_newest_date()
1.50 menue = [
1.51 - ('/ozoneloss', _(u'Ozoneloss'),
1.52 - (('/ozoneloss', _(u'overview')),
1.53 - ('/ozoneloss/clams/2016', _(u'calculations')),
1.54 - ('/ozoneloss/vpsc/2016', _(u'estimations')),
1.55 - ('/ozoneloss/uvi', _(u'uv increase')))),
1.56 -
1.57 - ('/eskp', _(u'ESKP'),(None, None)),
1.58 - ('/iek-7', _(u'IEK-7'),(None, None))
1.59 - ]
1.60 + ('/ozoneloss', _(u'Ozoneloss'),
1.61 + (('/ozoneloss', _(u'overview')),
1.62 + ('/ozoneloss/clams/2016', _(u'calculations')),
1.63 + ('/ozoneloss/vpsc/2016', _(u'estimations')),
1.64 + ('/ozoneloss/uvi', _(u'uv increase')),
1.65 + ('/ozoneloss/uvmap/' + newest_date, _(u'uv index map')))),
1.66 + ('/eskp', _(u'ESKP'), (None, None)),
1.67 + ('/iek-7', _(u'IEK-7'), (None, None))
1.68 + ]
1.69 return menue
1.70
1.71 +
1.72 app.jinja_env.globals.update(get_topmenue=get_topmenue)
1.73
1.74 +
1.75 def get_o3lossclams_dates():
1.76 menue = [
1.77 ('/ozoneloss/clams/2016', _(u'2016')),
1.78 @@ -72,9 +81,48 @@
1.79 ('/ozoneloss/clams/2012', _(u'2012')),
1.80 ('/ozoneloss/clams/2011', _(u'2011')),
1.81 ('/ozoneloss/clams/2010', _(u'2010')),
1.82 - ]
1.83 + ]
1.84 return menue
1.85
1.86 +
1.87 +def get_valid_dates(files):
1.88 + dates = []
1.89 +
1.90 + for file in files:
1.91 + if file.endswith('.png') and file.find('uvi') >= 0:
1.92 + date = file[-12:-6]
1.93 + dates.append(date)
1.94 + dates.sort()
1.95 + for date in dates:
1.96 + i = 0
1.97 + for param in ['uvi', 'o3col', 'do3col']:
1.98 + testfile = 'clams_' + param + '_' + date + '12.png'
1.99 + if files.count(testfile) > 0:
1.100 + i = i + 1
1.101 + if i <> 3:
1.102 + dates.remove(date)
1.103 + return dates
1.104 +
1.105 +
1.106 +def get_o3lossuvmap_dates(date_show):
1.107 +
1.108 + files = os.listdir(os.path.join(ESKP_PATH,'static/images/uvmap'))
1.109 + dates = get_valid_dates(files)
1.110 + ndates = len(dates)
1.111 + ind = dates.index(date_show)
1.112 + if ind ==0 :
1.113 + chosendates = [dates[ind+1]]
1.114 + elif ind >= ndates - 1:
1.115 + chosendates= [dates[ind-1]]
1.116 + else:
1.117 + chosendates = [dates[ind-1], dates[ind+1]]
1.118 + menue = []
1.119 + for date in chosendates:
1.120 + text_date = date[-2:] + '.' + date[-4:-2] + '.'
1.121 + menue.append(('/ozoneloss/uvmap/' + date, _(text_date)))
1.122 + return menue
1.123 +
1.124 +
1.125 def get_vpsc_dates():
1.126 menue = [
1.127 ('/ozoneloss/vpsc/2016', _(u'2016')),
1.128 @@ -84,11 +132,13 @@
1.129 ('/ozoneloss/vpsc/2012', _(u'2012')),
1.130 ('/ozoneloss/vpsc/2011', _(u'2011')),
1.131 ('/ozoneloss/vpsc/2010', _(u'2010')),
1.132 - ]
1.133 + ]
1.134 return menue
1.135
1.136 +
1.137 app.jinja_env.globals.update(get_o3lossclams_dates=get_o3lossclams_dates)
1.138 app.jinja_env.globals.update(get_vpsc_dates=get_vpsc_dates)
1.139 +app.jinja_env.globals.update(get_o3lossuvmap_dates=get_o3lossuvmap_dates)
1.140
1.141
1.142 def modal_info(template, act, title, filename):
1.143 @@ -118,6 +168,13 @@
1.144 return render_template("/ozoneloss_clams.html", act="ozoneloss/clams/%s" % year, content=content, year=year)
1.145
1.146
1.147 +@app.route('/ozoneloss/uvmap/<date>')
1.148 +def ozoneloss_uvmap_date(date):
1.149 + filename = os.path.join("templates", get_locale(), "rst", "ozoneloss_uvmap.rst")
1.150 + content = get_content(filename)
1.151 + return render_template("/ozoneloss_uvmap.html", act="ozoneloss/uvmap/%s" % date, content=content, date=date)
1.152 +
1.153 +
1.154 @app.route('/ozoneloss/vpsc/<year>')
1.155 def ozoneloss_vspc_year(year):
1.156 filename = os.path.join("templates", get_locale(), "rst", "ozoneloss_vpsc.rst")
1.157 @@ -137,6 +194,7 @@
1.158 eskp_info=_(u'About ESKP'),
1.159 )
1.160
1.161 +
1.162 @app.route('/en')
1.163 def en():
1.164 global LANGUAGE_SELECTED
1.165 @@ -145,6 +203,7 @@
1.166 eskp_info=_(u'About ESKP'),
1.167 )
1.168
1.169 +
1.170 @app.route("/eskp")
1.171 def eskp():
1.172 filename = os.path.join("templates", get_locale(), "rst", "eskp.rst")
1.173 @@ -155,13 +214,13 @@
1.174
1.175
1.176 def qr_image_data(card):
1.177 - buf= StringIO.StringIO()
1.178 + buf = StringIO.StringIO()
1.179 qr = qrcode.QRCode(
1.180 version=1,
1.181 error_correction=qrcode.constants.ERROR_CORRECT_L,
1.182 box_size=2,
1.183 border=2,
1.184 - )
1.185 + )
1.186 qr.add_data(card.serialize())
1.187 qr.make(fit=True)
1.188 img = qr.make_image()
1.189 @@ -172,12 +231,12 @@
1.190
1.191 @app.route("/ozoneloss")
1.192 def ozoneloss():
1.193 -
1.194 filename = os.path.join("templates", get_locale(), "rst", "ozoneloss.rst")
1.195 content = get_content(filename)
1.196
1.197 vcard_file = os.path.join("vcards", "jug.vcf")
1.198 author = u""
1.199 +
1.200 try:
1.201 card = get_vcard(vcard_file)
1.202 except IOError:
1.203 @@ -185,12 +244,13 @@
1.204 if card is not None:
1.205 qr_image = qr_image_data(card)
1.206 author = render_template("/author_info.html", act="author", title=_(u"Ozoneloss"),
1.207 - card=card, image=qr_image, contact=_(u"Contact"), exit=_(u"Close"))
1.208 + card=card, image=qr_image, contact=_(u"Contact"), exit=_(u"Close"))
1.209
1.210 filename = os.path.join("templates", get_locale(), "rst", "ozoneloss_publications.rst")
1.211 publications = modal_info("/publications_info.html", "publications", _(u"Ozoneloss"), filename)
1.212 return render_template("/ozoneloss.html", act="ozoneloss", content=content,
1.213 - author=author,card=card, publications=publications )
1.214 + author=author, card=card, publications=publications)
1.215 +
1.216
1.217 @app.route("/ozoneloss/clams")
1.218 def ozoneloss_clams():
1.219 @@ -198,6 +258,14 @@
1.220 content = get_content(filename)
1.221 return render_template("/ozoneloss_clams.html", act="ozoneloss/clams", content=content)
1.222
1.223 +
1.224 +@app.route("/ozoneloss/uvmap")
1.225 +def ozoneloss_uvmap():
1.226 + filename = os.path.join("templates", get_locale(), "rst", "ozoneloss_uvmap.rst")
1.227 + content = get_content(filename)
1.228 + return render_template("/ozoneloss_uvmap.html", act="ozoneloss/uvmap", content=content)
1.229 +
1.230 +
1.231 @app.route("/ozoneloss/vpsc")
1.232 def ozoneloss_vspc():
1.233 filename = os.path.join("templates", get_locale(), "rst", "ozoneloss_vpsc.rst")
1.234 @@ -215,10 +283,10 @@
1.235 o3offset = 50.
1.236 figname = "uvincr_lat%0.3i_do3%0.3i.svg" % (lat, o3offset)
1.237
1.238 -
1.239 return render_template('ozoneloss_uvi.html', act="ozoneloss/uvi", content=content, figname=figname,
1.240 alt=_(u"UV increase at {{lat}} degrees N for {{o3offset}} DU ozone depletion"))
1.241
1.242 +
1.243 @app.route("/ozoneloss/uvi_graph", methods=['POST'])
1.244 def ozoneloss_uvi_graph():
1.245 filename = os.path.join("templates", get_locale(), "rst", "ozoneloss_uvi.rst")
1.246 @@ -236,17 +304,12 @@
1.247 latstr2 = latstr2.replace(u'S', '')
1.248 lat = -float(latstr2)
1.249
1.250 -
1.251 figname = "uvincr_lat%0.3i_do3%0.3i.svg" % (lat, float(o3offsetstr))
1.252
1.253 return render_template('graph.html', act="ozoneloss_uvi_graph", content=content, figname=figname,
1.254 o3offsetstr=o3offsetstr, latstr=latstr)
1.255
1.256
1.257 -
1.258 -
1.259 -
1.260 -
1.261 @app.route("/iek-7")
1.262 def institute():
1.263 filename = os.path.join("templates", get_locale(), "rst", "iek-7.rst")
1.264 @@ -260,7 +323,7 @@
1.265 if card is not None:
1.266 qr_image = qr_image_data(card)
1.267 author = render_template("/author_info.html", act="author", title=_(u"IEK-7"),
1.268 - card=card, image=qr_image, contact=_(u"Contact"), exit=_(u"Close"))
1.269 + card=card, image=qr_image, contact=_(u"Contact"), exit=_(u"Close"))
1.270
1.271 return render_template("/iek-7.html", act="iek-7", content=content,
1.272 author=author, card=card, contact=u"IEK-7")
1.273 @@ -273,14 +336,12 @@
1.274 return render_template("/content.html", act="imprint", content=content)
1.275
1.276
1.277 -
1.278 -
1.279 -
1.280 @app.errorhandler(404)
1.281 def page_not_found(e):
1.282 msg = _(u"Url: %(url)s not found", url=request.url)
1.283 info = _(u"This information is not available!")
1.284 return render_template("404.html", msg=msg, info=info)
1.285
1.286 +
1.287 if __name__ == "__main__":
1.288 - app.run(host='localhost', port=5014)
1.289 + app.run(host='localhost', port=5014, debug=True)