Adds ax_letter reminder.
[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
48 protected function GetDisplayText() {}
49
50 public function Display(&$page)
51 {
52 header('Content-Type: text/html; charset=utf-8');
53 $page->changeTpl('reminder/profile_update.tpl', NO_SKIN);
54 $page->assign('baseurl', $this->GetBaseUrl());
55 $user = S::user();
56
57 $res = XDB::query('SELECT date < DATE_SUB(NOW(), INTERVAL 365 DAY) AS is_profile_old,
58 date AS profile_date, p.attach AS photo
59 FROM auth_user_md5 AS u
60 LEFT JOIN photo AS p ON (u.user_id = p.uid)
61 WHERE user_id = {?}',
62 $user->id());
63 list($is_profile_old, $profile_date, $has_photo) = $res->fetchOneRow();
64
65 $profile_date = $is_profile_old ? $profile_date : null;
66 $page->assign('profile_update', $profile_date);
67 $page->assign('needs_photo', $has_photo);
68
69 require_once 'geoloc.inc.php';
70 $res = localize_addresses($user->id());
71 $page->assign('geocoding_incitation', count($res));
72
73 $page->assign('incitations_count',
74 ($is_profile_old ? 1 : 0) +
75 ($has_photo ? 1 : 0) +
76 (count($res) > 0 ? 1 : 0));
77 }
78
79 public static function IsCandidate(User &$user)
80 {
81 $res = XDB::query('SELECT date < DATE_SUB(NOW(), INTERVAL 365 DAY) AS is_profile_old,
82 p.attach AS photo
83 FROM auth_user_md5 AS u
84 LEFT JOIN photo AS p ON (u.user_id = p.uid)
85 WHERE user_id = {?}',
86 $user->id());
87 list($is_profile_old, $has_photo) = $res->fetchOneRow();
88 require_once 'geoloc.inc.php';
89 $res = localize_addresses($user->id());
90
91 return (count($res) || !$has_photo || $is_profile_old);
92 }
93}
94
95// vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8:
96?>