ajout demandes.pt"
This commit is contained in:
47
mondumas/templates/dossier/demandes.pt
Normal file
47
mondumas/templates/dossier/demandes.pt
Normal file
@@ -0,0 +1,47 @@
|
|||||||
|
<metal:block use-macro="main_template">
|
||||||
|
<div metal:fill-slot="content">
|
||||||
|
|
||||||
|
<p>
|
||||||
|
<a href="${request.application_url}/" class="btn btn-default" role="button">
|
||||||
|
<span class="glyphicon glyphicon-chevron-left"></span> Retour</a>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<table id="users_list" class="table table-striped table-bordered">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th>No</th>
|
||||||
|
<th>Date</th>
|
||||||
|
<th>Expéditeur</th>
|
||||||
|
<th>Destinataire</th>
|
||||||
|
<th>Objet</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
<br />
|
||||||
|
<br />
|
||||||
|
|
||||||
|
<script type="text/javascript">
|
||||||
|
var dataSet = ${dt_data};
|
||||||
|
|
||||||
|
$(document).ready(function() {
|
||||||
|
$.fn.dataTable.moment('DD-MM-YYYY MH:mm:ss');
|
||||||
|
$('#users_list').DataTable({
|
||||||
|
data: dataSet,
|
||||||
|
pageLength: 50,
|
||||||
|
bLengthChange: false,
|
||||||
|
language: {
|
||||||
|
url: 'https://cdn.datatables.net/plug-ins/1.10.16/i18n/French.json'
|
||||||
|
},
|
||||||
|
columnDefs: [
|
||||||
|
{ className: "text-right", "targets": [0] },
|
||||||
|
],
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
</div><!-- content -->
|
||||||
|
</metal:block>
|
||||||
|
|
||||||
|
|
||||||
@@ -24,6 +24,9 @@ from ..security import groupfinder
|
|||||||
import os
|
import os
|
||||||
import shutil
|
import shutil
|
||||||
import pdfkit
|
import pdfkit
|
||||||
|
import imaplib
|
||||||
|
import base64
|
||||||
|
import email
|
||||||
|
|
||||||
from ..views.default import *
|
from ..views.default import *
|
||||||
from ..models.default import *
|
from ..models.default import *
|
||||||
@@ -693,7 +696,7 @@ def rdf_bill(request):
|
|||||||
article = request.params['article']
|
article = request.params['article']
|
||||||
insert_facture_rdf(request, 'PL', rapport.nochantier, logged_in, article, rapport.date_rapport.strftime('%d-%m-%Y'))
|
insert_facture_rdf(request, 'PL', rapport.nochantier, logged_in, article, rapport.date_rapport.strftime('%d-%m-%Y'))
|
||||||
|
|
||||||
request.session.flash(u"Le rapport a été généré avec succès.", 'success')
|
request.session.flash("Le rapport a été généré avec succès.", 'success')
|
||||||
return HTTPFound(location=request.route_url('dossier_view', nodossier=nodossier))
|
return HTTPFound(location=request.route_url('dossier_view', nodossier=nodossier))
|
||||||
|
|
||||||
return {
|
return {
|
||||||
@@ -710,27 +713,64 @@ def rdf_bill(request):
|
|||||||
}
|
}
|
||||||
|
|
||||||
@view_config(route_name='demandes', renderer='../templates/dossier/demandes.pt', permission='view')
|
@view_config(route_name='demandes', renderer='../templates/dossier/demandes.pt', permission='view')
|
||||||
def rdf_list(request):
|
def demandes(request):
|
||||||
# lire les rapports de RDF
|
|
||||||
items = get_rapport_rdf(request)
|
def process_messages(data, search_criteria, liste):
|
||||||
|
# créer la liste des entêtes des messages à afficher
|
||||||
|
rv, data = conn.search(None, search_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 num in mail_ids.split():
|
||||||
|
rv, msg_data = conn.fetch(num, '(RFC822)')
|
||||||
|
if rv != 'OK':
|
||||||
|
request.session.flash("ERREUR de lecture du message %s" % num, '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]
|
||||||
|
import pdb;pdb.set_trace()
|
||||||
|
# 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 = (str(int(num)), email_date.strftime('%d-%m-%Y %H:%M:%S'), email_from, mbx_name.replace('entreprise-dumas.com', ''), email_subject)
|
||||||
|
liste.append(d)
|
||||||
|
return liste
|
||||||
|
|
||||||
|
# lire les demandes d'interventions arrivées par email
|
||||||
|
mbx_name = 'peinture-dumas@entreprise-dumas.com'
|
||||||
|
mbx_pwd = 'sasdumas'
|
||||||
|
conn = imaplib.IMAP4_SSL('imap.entreprise-dumas.com')
|
||||||
|
try:
|
||||||
|
# se connecter à la mailbox
|
||||||
|
conn.login(mbx_name, mbx_pwd)
|
||||||
|
except imaplib.IMAP4.error:
|
||||||
|
request.session.flash("ERREUR connexion au compte %s" % mbx_name, 'danger')
|
||||||
|
return HTTPFound(location=request.route_url('home'))
|
||||||
|
|
||||||
|
# lire le INBOX
|
||||||
|
rv, data = conn.select('INBOX', readonly =True)
|
||||||
|
|
||||||
# construire la liste
|
|
||||||
liste=[]
|
liste=[]
|
||||||
for item in items:
|
# lire demandes de la MAIF
|
||||||
if item.date_relu :
|
mbx_subject = 'FROM gestionsinistre@maif.fr SUBJECT "Missionnement r"'
|
||||||
date_relu = item.date_relu.strftime('%d-%m-%Y')
|
process_messages(data, mbx_subject, liste)
|
||||||
else:
|
|
||||||
date_relu = ''
|
|
||||||
if item.date_rapport :
|
|
||||||
date_rapport = item.date_rapport.strftime('%d-%m-%Y')
|
|
||||||
else:
|
|
||||||
date_rapport = ''
|
|
||||||
|
|
||||||
d = (item.no_id, item.date_inter.strftime('%d-%m-%Y'), date_relu, date_rapport, '%s - %s %s' % (item.nochantier, item.C_QUALITE, item.C_NOM), item.NOMCLI, item.NOSIN,
|
# lire demandes de DOMUS
|
||||||
item.auteur_code)
|
mbx_subject = 'FROM service.sinistres@domus-services.fr SUBJECT "Ordre de mission DOMUS - Dossier"'
|
||||||
liste.append(d)
|
process_messages(data, mbx_subject, liste)
|
||||||
|
|
||||||
|
conn.logout()
|
||||||
|
|
||||||
return {
|
return {
|
||||||
'page_title': u'Liste des rapports de RDF',
|
'page_title': 'Liste des demandes pour la PEINTURE',
|
||||||
'dt_data': json.dumps(liste),
|
'dt_data': json.dumps(liste),
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user