Fix addresses in user profiles. Closes #1061
[platal.git] / plugins / function.display_address.php
1 <?php
2 /***************************************************************************
3 * Copyright (C) 2003-2010 Polytechnique.org *
4 * http://opensource.polytechnique.org/ *
5 * *
6 * This program is free software; you can redistribute it and/or modify *
7 * it under the terms of the GNU General Public License as published by *
8 * the Free Software Foundation; either version 2 of the License, or *
9 * (at your option) any later version. *
10 * *
11 * This program is distributed in the hope that it will be useful, *
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
14 * GNU General Public License for more details. *
15 * *
16 * You should have received a copy of the GNU General Public License *
17 * along with this program; if not, write to the Free Software *
18 * Foundation, Inc., *
19 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *
20 ***************************************************************************/
21
22 function display_address_isIdentity($idt, $value, $test_reverse = true)
23 {
24 $value = strtolower(replace_accent($value));
25 $idt = strtolower(replace_accent($idt));
26 $idt = preg_replace('/[^a-z]/', '', $idt);
27
28 $value = preg_replace('/[^a-z]/', '', $value);
29 if (strpos($value, $idt) !== false || strpos($idt, $value) !== false || levenshtein($value, $idt) < strlen($idt) / 3) {
30 return true;
31 }
32
33 if ($test_reverse) {
34 return display_address_isIdentity($idt, implode(' ', array_reverse(explode(' ', $value))), false);
35 }
36 return false;
37 }
38
39 function smarty_function_display_address($param, &$smarty)
40 {
41 require_once('geocoding.inc.php');
42 $adr = $param['adr'];
43 $txtad = $adr->text;
44 if (!$txtad && !$adr->phones() && !count($adr->phones())) {
45 return "";
46 }
47
48 $lines = explode("\n", $txtad);
49 $idt = array_shift($lines);
50 $restore = true;
51
52 if (!display_address_isIdentity($param['for'], $idt)) {
53 array_unshift($lines, $idt);
54 $idt = $param['for'];
55 $restore = false;
56 }
57
58 $txthtml = "";
59 $map = "<a href=\"http://maps.google.fr/?q="
60 . urlencode(implode(", ", $lines) . " ($idt)")
61 . "\"><img src=\"images/icons/map.gif\" alt=\"Google Maps\" title=\"Carte\"/></a>";
62 $comment = "";
63 if ($adr->comment != "")
64 {
65 $commentHtml = str_replace(array('&', '"'), array('&amp;', '&quot;'), $adr->comment);
66 $commentJs = str_replace(array('\\', '\''), array('\\\\', '\\\''), $commentHtml);
67 $comment = "<img style=\"margin-left: 5px;\" src=\"images/icons/comments.gif\""
68 . " onmouseover=\"return overlib('"
69 . $commentJs
70 . "',WIDTH,250);\""
71 . " onmouseout=\"nd();\""
72 . " alt=\"Commentaire\" title=\""
73 . $commentHtml
74 . "\"/>";
75 }
76 if ($restore) {
77 array_unshift($lines, $idt);
78 }
79 if ($param['titre'])
80 {
81 if ($param['titre_div'])
82 $txthtml .= "<div class='titre'>".pl_entity_decode($param['titre'])."&nbsp;".$map.$comment."</div>\n";
83 else
84 $txthtml .= "<em>".pl_entity_decode($param['titre'])."&nbsp;</em>".$map.$comment."<br />\n";
85 }
86 foreach ($lines as $line)
87 {
88 $txthtml .= "<strong>".$line."</strong><br/>\n";
89 }
90 if($adr->phones() != null) {
91 require_once('function.display_phones.php');
92 $txthtml .= smarty_function_display_phones(array('tels' => $adr->phones()),$smarty);
93 }
94 if (!$param['nodiv']) {
95 $pos = $param['pos'] ? " style='float: " . $param['pos'] . "'" : '';
96 $txthtml = "<div class='adresse' $pos>\n".$txthtml."</div>\n";
97 }
98 return $txthtml;
99 }
100
101 // vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8:
102 ?>