aboutsummaryrefslogtreecommitdiff
path: root/fiche.py
diff options
context:
space:
mode:
authorClyhtsuriva Synck <clyhtsuriva>2020-03-01 15:14:15 +0100
committerClyhtsuriva Synck <clyhtsuriva>2020-03-01 15:14:15 +0100
commit703c1c623892d69d8e24af68b31d84495301ca02 (patch)
tree743b32ed4cc4a5d597b4fbc5726e0c3e52bf7c7b /fiche.py
parentf33d24f47fa9d39e687d55cff1de9b4cc4ceb033 (diff)
initial files
Diffstat (limited to 'fiche.py')
-rw-r--r--fiche.py110
1 files changed, 110 insertions, 0 deletions
diff --git a/fiche.py b/fiche.py
new file mode 100644
index 0000000..e65a798
--- /dev/null
+++ b/fiche.py
@@ -0,0 +1,110 @@
+#!/usr/bin/python
+# -*- coding: utf-8 -*-
+
+from mod_python import Session
+from fonctions import redirectionSiNonConnecte, lien, codeHTML, connexionBD
+
+def index(req):
+ req.content_type="text/html"
+
+ sess = Session.Session(req) #recup session
+ redirectionSiNonConnecte(req,sess) #redirige si la session est nouvelle
+ id_util=sess["id_util"] #recup l'id_util
+ id_contact=req.form["id_contact"] #recup l'id_contact
+
+#debut sql
+ conn = connexionBD()
+ cur = conn.cursor()
+ sql = "select * from contact where id_contact={} and id_util={};".format(id_contact, id_util)
+ cur.execute(sql)
+ conn.commit()
+ data = cur.fetchall()
+ conn.close()
+#fin sql
+
+ if not data:
+ req.write(codeHTML("Erreur !", """
+<p>Ce contact ne vous appartient pas.</p>
+""" + lien('menu.py',"Retour au menu")))
+#si le resultat de la req sql est vide
+#alors le contact n'appartient pas à l'utilisateur connecté
+
+ else:
+#début prise info dans les var
+ data = data[0]
+ nom=str(data[1])
+ email=str(data[2])
+ tel=str(data[3])
+ addr=str(data[4])
+ lat=str(data[5])
+ lon=str(data[6])
+#fin prise infos
+ content = "" #ou tout le surplus va être ajouté (en plus du nom)
+
+ if email != "":
+ content += """
+ <tr>
+ <td>Email</td>
+ <td>""" + lien("mailto:" + email , email) + """</td>
+ </tr>
+
+"""
+#check si l'email est donné
+
+ if tel != "":
+ content += """
+ <tr>
+ <td>Telephone</td>
+ <td>""" + tel + """</td>
+ </tr>
+
+"""
+#check si le num est donné
+
+ if addr != "":
+ content += """
+ <tr>
+ <td>Adresse</td>
+ <td>""" + addr + """</td>
+ </tr>
+"""
+#check si l'addresse est donné
+
+
+#debut affiche map
+ if addr == "": #si pas d'adresse
+ maps="<b>Adresse non précisé</b>"
+ elif lat=="None" and lon=="None": #si le geocodage ne renvoit rien
+ maps="<b>Emplacement indisponible</b>"
+ else: #créé la map avec lat et lon de geocodage
+ maps="""
+<link rel="stylesheet" href="leaflet.css"/>
+<script src="leaflet.js"></script>
+<div id="carte" style="width: 600px; height: 400px"></div>
+<script>
+ var map = L.map("carte");
+ map.setView({lat: """ + lat + """, lon: """ + lon + """}, 10);
+ url="https://{s}.tile.openstreetmap.org" + "/{z}/{x}/{y}.png";
+ var layer = L.tileLayer(url);
+ layer.addTo(map);
+ var m = L.marker({lat: """ + lat + """, lon: """ + lon + """});
+ m.addTo(map);
+</script>
+"""
+#fin affichage maps
+
+#la suite écrit la page avec les différentes variables données
+ req.write(codeHTML("Fiche d'un contact","""
+<b>Fiche d'un contact</b><br/>
+<table>
+ <tr>
+ <td>Nom</td>
+ <td>""" + nom + """</td>
+ </tr>
+""" + content + """
+</table>
+""" + maps + """
+<br/>
+""" + lien ("supression.py?id_contact=" + id_contact ,"Supression du contact") + """
+<br/>
+""" + lien("menu.py","Retour au menu")))