refonte de monaa pour remplacer caotek.fr

This commit is contained in:
2020-04-27 21:38:48 +02:00
parent 5e6495e3ae
commit cb73317f8c
24 changed files with 495 additions and 416 deletions

View File

@@ -34,6 +34,97 @@ import time
import yfinance as yf
import html
@view_config(route_name='portfolio', renderer='../templates/actifs/portfolio.pt', permission='view')
def portfolio(request):
logged_in = request.authenticated_userid
member = get_member_by_email(request, logged_in)
url = request.route_url('portfolio')
message = ''
# lire les categories
items = get_allocation(request, '0')
# construire la liste pour donut
donut_cible=[]
donut_cible.append(('Allocation cible', 'Pourcent'))
donut_actuel=[]
donut_actuel.append(('Allocation actuelle', 'Pourcent'))
# calculer % total
total = 0
for item in items:
# construire la liste pour donut cible
d = (item.classe, item.pc_cible)
donut_cible.append(d)
# construire la liste pour donut actuel
d = (item.classe, int(item.pc_atteint * 10))
donut_actuel.append(d)
# totaliser les pourcentages
total += item.pc_cible
if total != 100:
message = 'Attention, le total de votre répartition cible est incorrect : %s.' % total
# lire les actifs
actifs = get_actifs(request, '0')
# MAJ du prtefeuille
if 'form.submitted' in request.params:
# lire le cours de EURUSD
ticker = yf.Ticker('EUR=X')
# maj des parités des devises
update_actif_devise(request, 'USD', ticker.info.get('regularMarketPrice'))
for item in actifs:
if item.type == 'ACTION':
# lire le cours de l'action
ticker = yf.Ticker(item.symbole)
# caluler son rendement
dividends = get_dividends(ticker)
update_actif_valeur(request, item.symbole, ticker.info.get('regularMarketPrice'), dividends)
time.sleep(1) # attendre 2 secondes
# update du portefeuille
update_portefeuille(request, logged_in)
# relire les actifs
actifs = get_actifs(request, '0')
message = 'Le portefeuille est mis à jour avec succès.'
total_valeur = 0
total_pv = 0
total_rdt = 0
for item in actifs:
total_valeur += item.valeur
total_pv += item.plus_value
total_pc_value = total_pv / total_valeur * 100
total_rdt += item.rendement
# lire l'historique
histos = get_histo(request,'0')
courbe_evoln=[]
courbe_evoln.append(('Date', 'Valeur part PF', 'Valeur part CARINVT:FP'))
for item in histos:
# construire la liste pour donut cible
d = (item.date.strftime('%d/%m/%Y'), int(item.val_part * 1000), int(item.val_part_ref * 1000))
courbe_evoln.append(d)
return {
'page_title': "Portefeuille",
'message': message,
'url': url,
'items': items,
'member': member,
'donut_cible': json.dumps(donut_cible),
'donut_actuel': json.dumps(donut_actuel),
'courbe_evoln': json.dumps(courbe_evoln),
'actifs': actifs,
'total_valeur': total_valeur,
'total_pv': total_pv,
'total_pc_value': total_pc_value,
'total_rdt': total_rdt
}
@view_config(route_name='actif_edit', renderer='../templates/actifs/actif_edit.pt', permission='view')
def actif_edit(request):
no_id = request.matchdict['no_id']
@@ -61,7 +152,7 @@ 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'))
return HTTPFound(location=request.route_url('portfolio'))
page_title= "Actif ACTION : %s" % (actif.libelle)
if 'form.submitted' in request.params:
@@ -80,16 +171,15 @@ def actif_edit(request):
ticker = yf.Ticker(symbole)
new_values['cours'] = ticker.info.get('regularMarketPrice')
new_values['devise'] = ticker.info.get('currency')
longName = html.unescape(ticker.info.get('longName'))
new_values['libelle'] = longName.replace('Vanguard Funds Public Limited Company - ','').replace('Amundi Index Solutions - ','').replace('Distributing','')
new_values['libelle'] = html.unescape(ticker.info.get('shortName'))
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('portfolio'))
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('portfolio'))
return {
'page_title': page_title,
@@ -124,7 +214,7 @@ def actif2_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'))
return HTTPFound(location=request.route_url('portfolio'))
page_title= "Actif : %s" % (actif.symbole)
if 'form.submitted' in request.params:
@@ -137,12 +227,12 @@ def actif2_edit(request):
new_values['devise'] = 'EUR'
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('portfolio'))
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('portfolio'))
return {
'page_title': page_title,
@@ -174,7 +264,7 @@ def allocation_edit(request):
allocation = get_allocation(request, no_cat)
if not allocation:
request.session.flash(u"Classe non trouvé : %s" % no_cat, 'warning')
return HTTPFound(location=request.route_url('home'))
return HTTPFound(location=request.route_url('portfolio'))
page_title= "Classe : %s" % (allocation.classe)
if 'form.submitted' in request.params:
@@ -186,12 +276,12 @@ def allocation_edit(request):
if new_values:
update_allocation(request, no_cat, 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('portfolio'))
if 'form.deleted' in request.params:
delete_allocation(request, no_cat)
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('portfolio'))
return {
'page_title': page_title,

View File

@@ -18,10 +18,6 @@ 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,
)
# import datetime
import time
@@ -70,110 +66,28 @@ def to_percent(x, d):
return pc.replace('.', ',')
@view_config(route_name='home', renderer='../templates/home.pt', permission='view')
@view_config(route_name='home', renderer='../templates/home.pt')
def home(request):
logged_in = request.authenticated_userid
member = get_member_by_email(request, logged_in)
url = request.route_url('home')
message = ''
# lire les categories
items = get_allocation(request, '0')
# construire la liste pour donut
donut_cible=[]
donut_cible.append(('Allocation cible', 'Pourcent'))
donut_actuel=[]
donut_actuel.append(('Allocation actuelle', 'Pourcent'))
# calculer % total
total = 0
for item in items:
# construire la liste pour donut cible
d = (item.classe, item.pc_cible)
donut_cible.append(d)
# construire la liste pour donut actuel
d = (item.classe, int(item.pc_atteint * 10))
donut_actuel.append(d)
# totaliser les pourcentages
total += item.pc_cible
if total != 100:
message = 'Attention, le total de votre répartition cible est incorrect : %s.' % total
# lire les actifs
actifs = get_actifs(request, '0')
# MAJ du prtefeuille
if 'form.submitted' in request.params:
# lire le cours de EURUSD
ticker = yf.Ticker('EUR=X')
# maj des parités des devises
update_actif_devise(request, 'USD', ticker.info.get('regularMarketPrice'))
for item in actifs:
if item.type == 'ACTION':
# lire le cours de l'action
ticker = yf.Ticker(item.symbole)
# caluler son rendement
dividends = get_dividends(ticker)
update_actif_valeur(request, item.symbole, ticker.info.get('regularMarketPrice'), dividends)
time.sleep(1) # attendre 2 secondes
# update du portefeuille
update_portefeuille(request, logged_in)
# relire les actifs
actifs = get_actifs(request, '0')
message = 'Le portefeuille est mis à jour avec succès.'
total_valeur = 0
total_pv = 0
total_rdt = 0
for item in actifs:
total_valeur += item.valeur
total_pv += item.plus_value
total_pc_value = total_pv / total_valeur * 100
total_rdt += item.rendement
# lire l'historique
histos = get_histo(request,'0')
courbe_evoln=[]
courbe_evoln.append(('Date', 'Valeur part PF', 'Valeur part CARINVT:FP'))
for item in histos:
# construire la liste pour donut cible
d = (item.date.strftime('%d/%m/%Y'), int(item.val_part * 1000), int(item.val_part_ref * 1000))
courbe_evoln.append(d)
# lire toutes les docs
items = get_docs_bytheme(request, 'BLOG')
return {
'page_title': "Allocation d'actifs",
'message': message,
'url': url,
'page_title': "Home",
'items': items,
'member': member,
'donut_cible': json.dumps(donut_cible),
'donut_actuel': json.dumps(donut_actuel),
'courbe_evoln': json.dumps(courbe_evoln),
'actifs': actifs,
'total_valeur': total_valeur,
'total_pv': total_pv,
'total_pc_value': total_pc_value,
'total_rdt': total_rdt
}
@view_config(route_name='doc_list', renderer='../templates/doc_list.pt', permission='view')
def doc_list(request):
# lire toutes les docs
docs_finance = get_docs_bytheme(request, 'FINANCE')
docs_maison = get_docs_bytheme(request, 'MAISON')
docs_voiture = get_docs_bytheme(request, 'VOITURE')
memos = get_docs_bytheme(request, 'memo')
docs = get_docs_bytheme(request, 'doc')
return {
'page_title': "Documents",
'docs_finance': docs_finance,
'docs_maison': docs_maison,
'docs_voiture': docs_voiture,
'memos': memos,
'docs': docs,
}
@view_config(route_name='doc_edit', renderer='../templates/doc_edit.pt', permission='view')
@@ -182,6 +96,8 @@ def doc_edit(request):
url = request.route_url('doc_edit',doc_id=doc_id)
message = ""
themes = get_blog_themes(request)
if doc_id == '0':
titre = "Nouveau doc"
intitule = ""
@@ -222,7 +138,7 @@ def doc_edit(request):
'intitule': intitule,
'texte': texte,
'theme': theme,
'themes': ["MAISON","FINANCE","VOITURE"],
'themes': themes,
}
@view_config(route_name='doc_view', renderer='../templates/doc_view.pt', permission='view')

View File

@@ -190,10 +190,7 @@ def logout(request):
request.session.invalidate()
headers = forget(request)
request.session.flash(u"Vous avez bien été déconnecté.")
return HTTPFound(location=request.route_url('login', login=''),
headers=headers)
return HTTPFound(location=request.route_url('home'), headers=headers)
@view_config(route_name='user_edit', renderer='../templates/members/user_edit.pt', permission='manage')