ajout prototype page d'accueil dans paramètres
This commit is contained in:
@@ -19,8 +19,8 @@ pyramid.includes =
|
|||||||
pyramid_tm
|
pyramid_tm
|
||||||
|
|
||||||
|
|
||||||
sqlalchemy.url = mysql://phuoc:phuoc!@localhost/bddevfac?charset=utf8
|
#sqlalchemy.url = mysql://phuoc:phuoc!@localhost/bddevfac?charset=utf8
|
||||||
#sqlalchemy.url = mysql://phuoc:phuoc!@192.168.1.17/bddevfac?charset=utf8
|
sqlalchemy.url = mysql://phuoc:phuoc!@192.168.1.17/bddevfac?charset=utf8
|
||||||
# sqlalchemy.url = mysql://phuoc:phuoc!@192.168.0.31/bddevfac?charset=utf8
|
# sqlalchemy.url = mysql://phuoc:phuoc!@192.168.0.31/bddevfac?charset=utf8
|
||||||
|
|
||||||
mondumas.admin_email = cao.thien-phuoc@orange.fr
|
mondumas.admin_email = cao.thien-phuoc@orange.fr
|
||||||
|
|||||||
@@ -227,3 +227,37 @@ def get_tarif(request, groupe, ref):
|
|||||||
query = "SELECT * FROM tarifs WHERE groupe = :groupe and ref = :ref;"
|
query = "SELECT * FROM tarifs WHERE groupe = :groupe and ref = :ref;"
|
||||||
results = request.dbsession.execute(query, {'groupe': groupe, 'ref': ref}).first()
|
results = request.dbsession.execute(query, {'groupe': groupe, 'ref': ref}).first()
|
||||||
return results
|
return results
|
||||||
|
|
||||||
|
def get_dd_restant(request):
|
||||||
|
query = """SELECT SUM(IF(societe='PE',1,0)) AS nb_PE,
|
||||||
|
SUM(IF(societe='ME',1,0)) AS nb_ME,
|
||||||
|
SUM(IF(societe='PL',1,0)) AS nb_PL
|
||||||
|
FROM dem_devis WHERE STATUS=0;"""
|
||||||
|
results = request.dbsession.execute(query).first()
|
||||||
|
return results
|
||||||
|
|
||||||
|
def get_de_restant(request):
|
||||||
|
query = """SELECT SUM(IF(societe='PE',1,0)) AS nb_PE,
|
||||||
|
SUM(IF(societe='ME',1,0)) AS nb_ME,
|
||||||
|
SUM(IF(societe='PL',1,0)) AS nb_PL
|
||||||
|
FROM devis WHERE STATUS<4;"""
|
||||||
|
results = request.dbsession.execute(query).first()
|
||||||
|
return results
|
||||||
|
|
||||||
|
def get_fa_restant(request):
|
||||||
|
query = """SELECT SUM(IF(societe='PE',1,0)) AS nb_PE,
|
||||||
|
SUM(IF(societe='ME',1,0)) AS nb_ME,
|
||||||
|
SUM(IF(societe='PL',1,0)) AS nb_PL
|
||||||
|
FROM facture WHERE STATUS<8;"""
|
||||||
|
results = request.dbsession.execute(query).first()
|
||||||
|
return results
|
||||||
|
|
||||||
|
def get_rdv_by_date(request, date, agenda):
|
||||||
|
query = """SELECT COUNT(*) AS nb_rdv FROM bddevfac.dem_lig WHERE DATEVI=:date AND LISTE=:agenda;"""
|
||||||
|
results = request.dbsession.execute(query, {'date': date, 'agenda': agenda}).first()
|
||||||
|
return results
|
||||||
|
|
||||||
|
def get_rdf_null(request):
|
||||||
|
query = """SELECT COUNT(*) AS nb_rdf FROM bddevfac.dem_rdf WHERE date_relu IS NULL;"""
|
||||||
|
results = request.dbsession.execute(query).first()
|
||||||
|
return results
|
||||||
|
|||||||
@@ -72,6 +72,7 @@ def includeme(config):
|
|||||||
config.add_route('user_edit', '/user_edit/{cd_uti}')
|
config.add_route('user_edit', '/user_edit/{cd_uti}')
|
||||||
config.add_route('users', '/users')
|
config.add_route('users', '/users')
|
||||||
config.add_route('users_ua', '/users_ua')
|
config.add_route('users_ua', '/users_ua')
|
||||||
|
config.add_route('new_home', '/new_home')
|
||||||
|
|
||||||
# stats
|
# stats
|
||||||
config.add_route('stats', '/stats')
|
config.add_route('stats', '/stats')
|
||||||
|
|||||||
117
mondumas/templates/parametres/new_home.pt
Normal file
117
mondumas/templates/parametres/new_home.pt
Normal file
@@ -0,0 +1,117 @@
|
|||||||
|
<metal:block use-macro="main_template">
|
||||||
|
<div metal:fill-slot="content">
|
||||||
|
|
||||||
|
<div class="container-fluid">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-3 text-center" tal:condition="logged_in=='CAO'">
|
||||||
|
<a href="${request.application_url}/devis_list">
|
||||||
|
<span class="glyphicon glyphicon-text-height logo-small"></span>
|
||||||
|
<h4>E-DEVIS</h4></a>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-3">
|
||||||
|
<div class="info-box bg-grey">
|
||||||
|
<span class="info-box-icon"><i class="glyphicon glyphicon-folder-open"></i></span>
|
||||||
|
<div class="info-box-content">
|
||||||
|
<span class="info-box-number">DEMANDES DEVIS</span>
|
||||||
|
<span class="info-box-text">A traiter : </span>
|
||||||
|
<span class="info-box-number"><span class="badge bg-PE">${nb_dd_restants.nb_PE}</span>
|
||||||
|
<span class="badge bg-ME">${nb_dd_restants.nb_ME}</span>
|
||||||
|
<span class="badge bg-PL">${nb_dd_restants.nb_PL}</span></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-3">
|
||||||
|
<div class="info-box bg-blue">
|
||||||
|
<span class="info-box-icon"><i class="glyphicon glyphicon-file"></i></span>
|
||||||
|
<div class="info-box-content">
|
||||||
|
<span class="info-box-number">DEVIS</span>
|
||||||
|
<span class="info-box-text">A traiter : </span>
|
||||||
|
<span class="info-box-number"><span class="badge bg-PE">${nb_de_restants.nb_PE}</span>
|
||||||
|
<span class="badge bg-ME">${nb_dd_restants.nb_ME}</span>
|
||||||
|
<span class="badge bg-PL">${nb_dd_restants.nb_PL}</span></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-3">
|
||||||
|
<div class="info-box bg-orange">
|
||||||
|
<span class="info-box-icon"><i class="glyphicon glyphicon-inbox"></i></span>
|
||||||
|
<div class="info-box-content">
|
||||||
|
<span class="info-box-number">FACTURES</span>
|
||||||
|
<span class="info-box-text">A traiter : </span>
|
||||||
|
<span class="info-box-number"><span class="badge bg-PE">${nb_fa_restants.nb_PE}</span>
|
||||||
|
<span class="badge bg-ME">${nb_dd_restants.nb_ME}</span>
|
||||||
|
<span class="badge bg-PL">${nb_dd_restants.nb_PL}</span></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<br />
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-3 text-center">
|
||||||
|
<a href="${request.application_url}/agenda/today">
|
||||||
|
<span class="glyphicon glyphicon-calendar logo-small"></span><br />
|
||||||
|
<h4>MON AGENDA</h4></a>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-3">
|
||||||
|
<div class="info-box bg-yellow">
|
||||||
|
<span class="info-box-icon"><i class="glyphicon glyphicon-calendar"></i></span>
|
||||||
|
<div class="info-box-content">
|
||||||
|
<span class="info-box-number">AGENDA</span>
|
||||||
|
<span class="info-box-text">A traiter : </span>
|
||||||
|
<span class="info-box-number"><span class="badge bg-red">${nb_rdv.nb_rdv}</span></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-3">
|
||||||
|
<div class="info-box bg-green">
|
||||||
|
<span class="info-box-icon"><i class="glyphicon glyphicon-tint"></i></span>
|
||||||
|
<div class="info-box-content">
|
||||||
|
<span class="info-box-number">RDF</span>
|
||||||
|
<span class="info-box-text">A traiter : </span>
|
||||||
|
<span class="info-box-number"><span class="badge bg-red">${nb_rdf.nb_rdf}</span></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-3">
|
||||||
|
<div class="info-box bg-purple">
|
||||||
|
<span class="info-box-icon"><i class="glyphicon glyphicon-envelope"></i></span>
|
||||||
|
<div class="info-box-content">
|
||||||
|
<span class="info-box-number">EMAILS</span>
|
||||||
|
<span class="info-box-text">A traiter : </span>
|
||||||
|
<span class="info-box-number"><span class="badge bg-red">${nb_mails}</span></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<br>
|
||||||
|
|
||||||
|
<div class="row text-center" tal:condition="access >= 5">
|
||||||
|
<div class="col-sm-3">
|
||||||
|
<a href="${request.application_url}/planning/today">
|
||||||
|
<span class="glyphicon glyphicon-calendar logo-small"></span><br />
|
||||||
|
<h4>PLANNING</h4></a>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-3">
|
||||||
|
<a href="${request.application_url}/demandes" tal:condition="access > 0">
|
||||||
|
<span class="glyphicon glyphicon-download-alt logo-warning"></span>
|
||||||
|
<h4>EMAILS <span class="glyphicon glyphicon-arrow-right"></span> DOSSIERS</h4></a>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-3">
|
||||||
|
<a href="${request.application_url}/upload_om" tal:condition="access > 0">
|
||||||
|
<span class="glyphicon glyphicon-download-alt logo-warning"></span>
|
||||||
|
<h4>PDF <span class="glyphicon glyphicon-arrow-right"></span> DOSSIERS</h4></a>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-3">
|
||||||
|
<a href="${request.application_url}/stats" tal:condition="access > 6">
|
||||||
|
<span class="glyphicon glyphicon-stats logo-warning"></span>
|
||||||
|
<h4>STATISTIQUES</h4></a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<br />
|
||||||
|
<br />
|
||||||
|
<br />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div><!-- content -->
|
||||||
|
</metal:block>
|
||||||
|
|
||||||
@@ -34,6 +34,10 @@
|
|||||||
<a href="${request.application_url}/text_list"><span class="glyphicon glyphicon-list logo-primary"></span></a>
|
<a href="${request.application_url}/text_list"><span class="glyphicon glyphicon-list logo-primary"></span></a>
|
||||||
<h4>TEXTES EMAIL</h4>
|
<h4>TEXTES EMAIL</h4>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="col-sm-3">
|
||||||
|
<a href="${request.application_url}/new_home"><span class="glyphicon glyphicon-dashboard logo-primary"></span></a>
|
||||||
|
<h4>PROTOTYPE HOME</h4>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<br />
|
<br />
|
||||||
<div class="row text-center">
|
<div class="row text-center">
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ from pyramid.httpexceptions import (
|
|||||||
HTTPForbidden,
|
HTTPForbidden,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
from pyramid_mailer import get_mailer
|
||||||
from pyramid_mailer.message import Message, Attachment
|
from pyramid_mailer.message import Message, Attachment
|
||||||
from datetime import *
|
from datetime import *
|
||||||
from dateutil.relativedelta import *
|
from dateutil.relativedelta import *
|
||||||
@@ -263,6 +264,7 @@ def rdf_cause_edit(request):
|
|||||||
if 'form.submitted' in request.params:
|
if 'form.submitted' in request.params:
|
||||||
code = request.params['code']
|
code = request.params['code']
|
||||||
libelle = request.params['libelle']
|
libelle = request.params['libelle']
|
||||||
|
|
||||||
update_rdf_cause(request, old_code, code, libelle)
|
update_rdf_cause(request, old_code, code, libelle)
|
||||||
request.session.flash(u"La cause a été mise à jour avec succès.", 'success')
|
request.session.flash(u"La cause a été mise à jour avec succès.", 'success')
|
||||||
return HTTPFound(location=request.route_url('rdf_causes'))
|
return HTTPFound(location=request.route_url('rdf_causes'))
|
||||||
@@ -837,3 +839,97 @@ def tarifs_import(request):
|
|||||||
'groupe': groupe,
|
'groupe': groupe,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@view_config(route_name='new_home', renderer='../templates/parametres/new_home.pt', permission='view')
|
||||||
|
def new_home(request):
|
||||||
|
logged_in = request.authenticated_userid.upper()
|
||||||
|
url = request.route_url('new_home')
|
||||||
|
# lire la fiche de l'utilisateur
|
||||||
|
member = get_member_by_id(request, logged_in)
|
||||||
|
access = member.access
|
||||||
|
agenda = member.agenda
|
||||||
|
|
||||||
|
datedeb = date.today().strftime("%Y-%m-%d")
|
||||||
|
|
||||||
|
nb_dd_restants = get_dd_restant(request)
|
||||||
|
nb_de_restants = get_de_restant(request)
|
||||||
|
nb_fa_restants = get_fa_restant(request)
|
||||||
|
|
||||||
|
nb_rdv = get_rdv_by_date(request, datedeb, agenda)
|
||||||
|
nb_rdf = get_rdf_null(request)
|
||||||
|
|
||||||
|
# Récupération de la listes des mails pour ensuite avoir leur nombre
|
||||||
|
def demandes_lister(societe, search_criteria):
|
||||||
|
# connecter au serveur de mail
|
||||||
|
conn = mailbox_connect(request, societe)
|
||||||
|
# select INBOX
|
||||||
|
rv, data = conn.select('INBOX', readonly =True)
|
||||||
|
|
||||||
|
# créer la liste des entêtes des messages à afficher
|
||||||
|
liste = []
|
||||||
|
for criteria in search_criteria:
|
||||||
|
rv, data = conn.search(None, criteria)
|
||||||
|
if rv != 'OK':
|
||||||
|
request.session.flash("ERREUR de lecture de la boîte de réception", 'danger')
|
||||||
|
return HTTPFound(location=request.route_url('home'))
|
||||||
|
|
||||||
|
mail_ids = data[0]
|
||||||
|
for email_UID in mail_ids.split():
|
||||||
|
rv, msg_data = conn.fetch(email_UID, '(RFC822)')
|
||||||
|
if rv != 'OK':
|
||||||
|
request.session.flash("ERREUR de lecture du message %s" % email_UID, 'danger')
|
||||||
|
return HTTPFound(location=request.route_url('home'))
|
||||||
|
|
||||||
|
msg = email.message_from_bytes(msg_data[0][1])
|
||||||
|
hdr = email.header.make_header(email.header.decode_header(msg['Subject']))
|
||||||
|
email_subject = str(hdr)
|
||||||
|
email_from = email.utils.parseaddr(msg['from'])[1]
|
||||||
|
# Now convert to local date-time
|
||||||
|
date_tuple = email.utils.parsedate_tz(msg['Date'])
|
||||||
|
if date_tuple:
|
||||||
|
email_date = datetime.fromtimestamp(email.utils.mktime_tz(date_tuple))
|
||||||
|
else:
|
||||||
|
email_date = datetime.now()
|
||||||
|
|
||||||
|
d = {
|
||||||
|
"email_societe": societe,
|
||||||
|
"email_date": email_date,
|
||||||
|
"email_from": email_from.split('@')[1],
|
||||||
|
'email_subject':email_subject,
|
||||||
|
"email_uid": email_UID
|
||||||
|
}
|
||||||
|
liste.append(d)
|
||||||
|
|
||||||
|
# deconnexion du serveur
|
||||||
|
conn.close()
|
||||||
|
conn.logout()
|
||||||
|
return liste
|
||||||
|
|
||||||
|
societes = ['PE','ME','PL','PO']
|
||||||
|
|
||||||
|
# critères de recherche des demandes d'interventions de la MAIF
|
||||||
|
# search_criteria = ['FROM service.sinistres@domus-services.fr SUBJECT "Ordre de mission DOMUS - Dossier" UNDELETED'] "
|
||||||
|
search_criteria = ['FROM gestionsinistre@maif.fr SUBJECT "Intervention entreprise partenaire"',
|
||||||
|
'FROM service.sinistres@domus-services.fr UNDELETED']
|
||||||
|
# 'FROM service.sinistres@domus-services.fr SUBJECT "Ordre de mission DOMUS - Dossier" UNDELETED']
|
||||||
|
|
||||||
|
emails=[]
|
||||||
|
# lister les demandes par societe
|
||||||
|
for societe in societes:
|
||||||
|
emails = emails + demandes_lister(societe, search_criteria)
|
||||||
|
|
||||||
|
# messages lus
|
||||||
|
msglus = bool(emails)
|
||||||
|
|
||||||
|
return {
|
||||||
|
'page_title': 'Bienvenue sur %s' % request.host,
|
||||||
|
'project': 'mondumas',
|
||||||
|
'access': access,
|
||||||
|
'logged_in': logged_in,
|
||||||
|
'nb_dd_restants': nb_dd_restants,
|
||||||
|
'nb_de_restants': nb_de_restants,
|
||||||
|
'nb_fa_restants': nb_fa_restants,
|
||||||
|
'nb_rdv': nb_rdv,
|
||||||
|
'nb_rdf': nb_rdf,
|
||||||
|
'nb_mails': len(emails),
|
||||||
|
#'mails': emails,
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user