déplacer les templates actif dans un module à part

This commit is contained in:
2017-07-24 09:53:05 +02:00
parent 988bb87263
commit a2c5ac2cfe
11 changed files with 303 additions and 152 deletions

View File

@@ -0,0 +1,137 @@
# -*- coding: utf8 -*-
from pyramid.response import Response
from pyramid.renderers import render, get_renderer
from pyramid.view import (
view_config,
forbidden_view_config,
)
from pyramid.security import (
authenticated_userid,
remember,
forget,
)
from pyramid.httpexceptions import (
HTTPFound,
HTTPNotFound,
HTTPForbidden,
)
from pyramid_mailer import get_mailer
from pyramid_mailer.message import Message, Attachment
from datetime import *
import hashlib
from yahoo_finance import Share, Currency
from sqlalchemy.exc import DBAPIError
from ..security import groupfinder
from ..models.default import *
from ..models.actifs import *
from ..models.members import (
get_member_by_email,
)
from ..views.default import (
to_euro,
to_usd,
)
import json
@view_config(route_name='actifs_list', renderer='../templates/actifs/actifs_list.pt', permission='view')
def actifs_list(request):
message = ''
# lire les actifs
items = get_actifs(request, '0')
# MAJ du prtefeuille
if 'form.submitted' in request.params:
# maj des parités des devises d'après Yahoo finance
usdeur = Currency('USDEUR')
update_actif_devise(request, 'USD', usdeur.get_rate())
for item in items:
sym = Share(item.symbole)
update_actif_valeur(request, item.symbole, sym.get_price())
# relire les actifs
items = get_actifs(request, '0')
message = u'Le portefeuille est mis à jour avec succès.'
# construire la liste
liste=[]
for item in items:
if item.devise == 'EUR':
cours = to_euro(item.cours)
else:
cours = to_usd(item.cours)
d = (item.categorie, item.symbole, item.libelle, str(item.nombre), cours, to_euro(item.pru), to_euro(item.valeur), to_euro(item.plus_value),str(item.no_id))
liste.append(d)
return {
'page_title': u"Mes actifs",
'dt_data': json.dumps(liste),
'message': message,
}
@view_config(route_name='actif_edit', renderer='../templates/actifs/actif_edit.pt', permission='view')
def actif_edit(request):
no_id = request.matchdict['no_id']
url = request.route_url('actif_edit', no_id=no_id)
message = ''
categories_list = get_categories(request,'0')
if no_id == '0':
# nouveau
actif = {}
actif['no_id'] = '0'
actif['symbole'] = ''
actif['categorie'] = 'Actions Europe'
actif['nombre'] = '0'
actif['pru'] = '0'
page_title= 'Nouvel actif'
else:
# lire la fiche du actif
actif = get_actifs(request, no_id)
if not actif:
request.session.flash(u"Actif non trouvé : %s" % no_id, 'warning')
return HTTPFound(location=request.route_url('home'))
page_title= u"Actif : %s" % (actif.symbole)
if 'form.submitted' in request.params:
new_values = {}
for param, db_value in actif.items():
if param in request.params and request.params[param] != db_value:
new_values[param] = request.params[param]
if new_values:
# récupérer les infos du symbole de Yahoo finance
if 'symbole' in request.params:
symbole = request.params['symbole']
else:
symbole = actif.symbole
sym = Share(symbole)
if sym.get_name() <> None:
# import pdb;pdb.set_trace()
new_values['libelle'] = sym.get_name()
new_values['cours'] = sym.get_price()
new_values['devise'] = sym.get_currency()
update_actif(request, no_id, new_values)
request.session.flash(u"La fiche a été mise à jour avec succès.", 'success')
return HTTPFound(location=request.route_url('home'))
else:
message = 'Symbole inconnu. Veuillez ressaisir.'
if 'form.deleted' in request.params:
delete_actif(request, no_id)
request.session.flash(u"La fiche a été supprimée avec succès.", 'success')
return HTTPFound(location=request.route_url('home'))
return {
'page_title': page_title,
'url': url,
'actif': actif,
'categories_list': categories_list,
'message': message,
}

View File

@@ -20,7 +20,7 @@ from pyramid_mailer.message import Message, Attachment
from datetime import *
import hashlib
from docutils.core import publish_parts
from yahoo_finance import Share
from yahoo_finance import Share, Currency
from sqlalchemy.exc import DBAPIError
from ..security import groupfinder
@@ -43,6 +43,14 @@ def to_euro(x):
#else:
return (u"%.2f" % x).replace('.', ',')
def to_usd(x):
"""Takes a float and returns a string"""
#if x == 0:
# return ""
#else:
return (u"%.2f $" % x).replace('.', ',')
def to_int(x):
try:
number = int(x.replace(',', '.'))
@@ -57,25 +65,17 @@ def to_percent(x):
@view_config(route_name='home', renderer='../templates/home.pt', permission='view')
def home(request):
message = ''
logged_in = authenticated_userid(request)
# lire la fiche du membre
membre = get_member_by_email(request, logged_in)
if not membre:
request.session.flash(u"Utilisateur non trouvé : %s" % logged_in, 'warning')
return HTTPFound(location=request.route_url('/home'))
return HTTPFound(location=request.route_url('/'))
# lire les actifs
items = get_actifs(request, '0')
# construire la liste
liste=[]
for item in items:
d = (str(item.no_id), item.symbole, item.libelle, item.categorie, str(item.nombre), to_euro(item.cours), to_euro(item.pru), to_euro(item.valeur), to_euro(item.plus_value))
liste.append(d)
return {
'page_title': u"%s %s" % (membre.prenom, membre.nom),
'dt_data': json.dumps(liste),
'message': message,
}
@view_config(route_name='doc_list', renderer='../templates/doc_list.pt', permission='view')
@@ -171,60 +171,3 @@ gestion.entreprise-dumas.com
mailer = get_mailer(request)
mailer.send_immediately(message)
@view_config(route_name='actif_edit', renderer='../templates/actif_edit.pt', permission='view')
def actif_edit(request):
no_id = request.matchdict['no_id']
url = request.route_url('actif_edit', no_id=no_id)
message = ''
categories_list = get_categories(request,'0')
if no_id == '0':
# nouveau
actif = {}
actif['no_id'] = '0'
actif['symbole'] = ''
actif['categorie'] = 'Actions Europe'
actif['nombre'] = '0'
actif['pru'] = '0'
page_title= 'Nouvel actif'
else:
# lire la fiche du actif
actif = get_actifs(request, no_id)
if not actif:
request.session.flash(u"Actif non trouvé : %s" % no_id, 'warning')
return HTTPFound(location=request.route_url('home'))
page_title= u"Fiche de %s" % (actif.symbole)
if 'form.submitted' in request.params:
new_values = {}
for param, db_value in actif.items():
if param in request.params and request.params[param] != db_value:
new_values[param] = request.params[param]
if new_values:
# récupérer les infos du symbole de Yahoo finance
if 'symbole' in request.params:
symbole = request.params['symbole']
else:
symbole = actif.symbole
sym = Share(symbole)
new_values['libelle'] = sym.get_name()
new_values['cours'] = sym.get_price()
update_actif(request, no_id, new_values)
request.session.flash(u"La fiche a été mise à jour avec succès.", 'success')
return HTTPFound(location=request.route_url('home'))
if 'form.deleted' in request.params:
delete_actif(request, no_id)
request.session.flash(u"La fiche a été supprimée avec succès.", 'success')
return HTTPFound(location=request.route_url('home'))
return {
'page_title': page_title,
'url': url,
'actif': actif,
'categories_list': categories_list,
'message': message,
}

View File

@@ -213,7 +213,7 @@ def user_edit(request):
if not membre:
request.session.flash(u"Utilisateur non trouvé : %s" % email, 'warning')
return HTTPFound(location=request.route_url('users_list'))
page_title= u"Fiche de %s" %(membre.nom)
page_title= u"Membre : %s" %(membre.nom)
if 'form.submitted' in request.params:
new_values = {}