améliorer la page d'accueil
This commit is contained in:
@@ -51,17 +51,32 @@ def actifs_list(request):
|
||||
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.'
|
||||
if item.type == 'ACTION':
|
||||
sym = Share(item.symbole)
|
||||
# import pdb;pdb.set_trace()
|
||||
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.'
|
||||
# update du portefeuille
|
||||
update_portefeuille(request)
|
||||
|
||||
total_valeur = 0
|
||||
total_pv = 0
|
||||
for item in items:
|
||||
total_valeur += item.valeur
|
||||
total_pv += item.plus_value
|
||||
total_pc_value = total_pv / total_valeur * 100
|
||||
|
||||
return {
|
||||
'page_title': u"Mes actifs",
|
||||
'url': url,
|
||||
'items': items,
|
||||
'message': message,
|
||||
'total_valeur': total_valeur,
|
||||
'total_pv': total_pv,
|
||||
'total_pc_value': total_pc_value,
|
||||
}
|
||||
|
||||
|
||||
@@ -70,7 +85,7 @@ 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')
|
||||
categories_list = get_categories_bytype(request,'ACTION')
|
||||
|
||||
if no_id == '0':
|
||||
# nouveau
|
||||
@@ -86,15 +101,15 @@ def actif_edit(request):
|
||||
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.libelle)
|
||||
return HTTPFound(location=request.route_url('actifs_list'))
|
||||
page_title= u"Actif ACTION : %s" % (actif.libelle)
|
||||
|
||||
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:
|
||||
@@ -109,16 +124,18 @@ def actif_edit(request):
|
||||
new_values['cours'] = sym.get_price()
|
||||
new_values['devise'] = sym.get_currency()
|
||||
|
||||
# ajouter son type
|
||||
new_values['type'] = 'ACTION'
|
||||
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'))
|
||||
return HTTPFound(location=request.route_url('actifs_list'))
|
||||
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 HTTPFound(location=request.route_url('actifs_list'))
|
||||
|
||||
return {
|
||||
'page_title': page_title,
|
||||
@@ -133,23 +150,24 @@ def actif2_edit(request):
|
||||
no_id = request.matchdict['no_id']
|
||||
url = request.route_url('actif2_edit', no_id=no_id)
|
||||
message = ''
|
||||
categories_list = get_categories(request,'0')
|
||||
categories_list = get_categories_bytype(request,'AUTRE')
|
||||
|
||||
if no_id == '0':
|
||||
# nouveau
|
||||
actif = {}
|
||||
actif['no_id'] = '0'
|
||||
actif['symbole'] = ''
|
||||
actif['categorie'] = 'Actions Europe'
|
||||
actif['nombre'] = '0'
|
||||
actif['categorie'] = 'Obligations'
|
||||
actif['libelle'] = ''
|
||||
actif['pru'] = '0'
|
||||
actif['cours'] = '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'))
|
||||
return HTTPFound(location=request.route_url('actifs_list'))
|
||||
page_title= u"Actif : %s" % (actif.symbole)
|
||||
|
||||
if 'form.submitted' in request.params:
|
||||
@@ -159,29 +177,18 @@ def actif2_edit(request):
|
||||
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.'
|
||||
new_values['nombre'] = 1000
|
||||
new_values['devise'] = 'EUR'
|
||||
# ajouter son type
|
||||
new_values['type'] = 'AUTRE'
|
||||
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('actifs_list'))
|
||||
|
||||
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 HTTPFound(location=request.route_url('actifs_list'))
|
||||
|
||||
return {
|
||||
'page_title': page_title,
|
||||
|
||||
@@ -26,6 +26,9 @@ from sqlalchemy.exc import DBAPIError
|
||||
from ..security import groupfinder
|
||||
|
||||
from ..models.default import *
|
||||
from ..models.actifs import (
|
||||
get_actifs,
|
||||
)
|
||||
from ..models.members import (
|
||||
get_member_by_email,
|
||||
)
|
||||
@@ -41,7 +44,7 @@ def to_euro(x):
|
||||
#if x == 0:
|
||||
# return ""
|
||||
#else:
|
||||
return (u"%.2f €" % x).replace('.', ',')
|
||||
return (u"{:,.2f}".format(x).replace(',', ' ').replace('.', ',') + u" €")
|
||||
|
||||
def to_usd(x):
|
||||
"""Takes a float and returns a string"""
|
||||
@@ -60,26 +63,40 @@ def to_int(x):
|
||||
|
||||
def to_percent(x):
|
||||
"""Takes a float and returns a string"""
|
||||
return (u"%.2f " % x).replace('.', ',') + "%"
|
||||
return (u"%.1f " % x).replace('.', ',') + "%"
|
||||
|
||||
|
||||
@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('/'))
|
||||
|
||||
# lire les categories
|
||||
items = get_categories(request, '0')
|
||||
|
||||
# calculer % total
|
||||
total = 0
|
||||
for item in items:
|
||||
total += item.pc_cible
|
||||
if total <> 100:
|
||||
message = u'Attention, le total de votre répartition cible ne fait pas 100%.'
|
||||
|
||||
# lire les actifs
|
||||
actifs = get_actifs(request, '0')
|
||||
|
||||
total_valeur = 0
|
||||
total_pv = 0
|
||||
for item in actifs:
|
||||
total_valeur += item.valeur
|
||||
total_pv += item.plus_value
|
||||
total_pc_value = total_pv / total_valeur * 100
|
||||
|
||||
return {
|
||||
'page_title': u"%s %s" % (membre.prenom, membre.nom),
|
||||
'page_title': u"Allocation d'actifs",
|
||||
'message': message,
|
||||
'items': items,
|
||||
'actifs': actifs,
|
||||
'total_valeur': total_valeur,
|
||||
'total_pv': total_pv,
|
||||
'total_pc_value': total_pc_value,
|
||||
}
|
||||
|
||||
@view_config(route_name='doc_list', renderer='../templates/doc_list.pt', permission='view')
|
||||
@@ -182,13 +199,14 @@ def categorie_edit(request):
|
||||
no_cat = request.matchdict['no_cat']
|
||||
url = request.route_url('categorie_edit', no_cat=no_cat)
|
||||
message = ''
|
||||
categories_list = get_categories(request,'0')
|
||||
types_list = ['ACTION', 'AUTRE']
|
||||
|
||||
if no_cat == '0':
|
||||
# nouveau
|
||||
categorie = {}
|
||||
categorie['no_cat'] = '0'
|
||||
categorie['categorie'] = ''
|
||||
categorie['type'] = 'ACTION'
|
||||
categorie['pc_cible'] = '0'
|
||||
page_title= u'Nouvelle catégorie'
|
||||
else:
|
||||
@@ -220,5 +238,6 @@ def categorie_edit(request):
|
||||
'page_title': page_title,
|
||||
'url': url,
|
||||
'categorie': categorie,
|
||||
'types_list': types_list,
|
||||
'message': message,
|
||||
}
|
||||
Reference in New Issue
Block a user