refonte de monaa pour remplacer caotek.fr
This commit is contained in:
@@ -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')
|
||||
|
||||
Reference in New Issue
Block a user