Merge branch 'master' into fusionax
[platal.git] / include / reminder / profile_update.inc.php
CommitLineData
894c18b2
SJ
1<?php
2/***************************************************************************
3 * Copyright (C) 2003-2009 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
22class ReminderProfileUpdate extends Reminder
23{
24 public function HandleAction($action)
25 {
26 switch ($action) {
27 case 'dismiss':
28 $this->UpdateOnDismiss();
29 break;
30
31 case 'profile':
32 $this->UpdateOnDismiss();
33 pl_redirect('profile/edit');
34 break;
35
36 case 'photo':
37 $this->UpdateOnDismiss();
38 pl_redirect('photo/change');
39 break;
40
41 case 'geoloc':
42 $this->UpdateOnDismiss();
43 pl_redirect('profile/edit/adresses');
44 break;
45 }
46 }
47
4b0cb388 48 public function Prepare(&$page)
894c18b2 49 {
4b0cb388 50 parent::Prepare($page);
894c18b2
SJ
51
52 $res = XDB::query('SELECT date < DATE_SUB(NOW(), INTERVAL 365 DAY) AS is_profile_old,
003fafc0 53 date AS profile_date, LENGTH(p.attach) > 0 AS has_photo
5f2bea23
SJ
54 FROM auth_user_md5 AS u
55 LEFT JOIN photo AS p ON (u.user_id = p.uid)
894c18b2 56 WHERE user_id = {?}',
4b0cb388 57 $this->user->id());
894c18b2
SJ
58 list($is_profile_old, $profile_date, $has_photo) = $res->fetchOneRow();
59
4b0cb388
VZ
60 $page->assign('profile_incitation', $is_profile_old);
61 $page->assign('profile_last_update', $profile_date);
003fafc0 62 $page->assign('photo_incitation', !$has_photo);
894c18b2 63
5f2bea23
SJ
64 $res = XDB::query('SELECT COUNT(*)
65 FROM profile_addresses
66 WHERE pid = {?} AND accuracy = 0'
67 $this->user->id());
68 $page->assign('geocoding_incitation', $res->fetchOneCell());
894c18b2
SJ
69 }
70
4b0cb388
VZ
71 public function template()
72 {
73 return 'reminder/profile_update.tpl';
74 }
75 public function title()
76 {
77 return "Mise à jour de ton profil";
78 }
79 public function warning()
80 {
81 return true;
82 }
83
0e4b87b2 84 public static function IsCandidate(User &$user, $candidate)
894c18b2
SJ
85 {
86 $res = XDB::query('SELECT date < DATE_SUB(NOW(), INTERVAL 365 DAY) AS is_profile_old,
87 p.attach AS photo
88 FROM auth_user_md5 AS u
89 LEFT JOIN photo AS p ON (u.user_id = p.uid)
90 WHERE user_id = {?}',
91 $user->id());
92 list($is_profile_old, $has_photo) = $res->fetchOneRow();
894c18b2 93
5f2bea23
SJ
94 $res = XDB::query('SELECT COUNT(*)
95 FROM profile_addresses
96 WHERE pid = {?} AND accuracy = 0'
97 $this->user->id());
98
99 return ($res->fetchOneCell() || !$has_photo || $is_profile_old);
894c18b2
SJ
100 }
101}
102
103// vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8:
104?>