2 /***************************************************************************
3 * Copyright (C) 2003-2008 Polytechnique.org *
4 * http://opensource.polytechnique.org/ *
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. *
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. *
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 *
19 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *
20 ***************************************************************************/
24 class MedalReq
extends Validate
34 public function __construct(User
&$_user, $_idmedal, $_subidmedal, $_stamp=0)
36 parent
::__construct($_user, false
, 'medal', $_stamp);
37 $this->mid
= $_idmedal;
38 $this->gid
= $_subidmedal;
39 if (is_null($this->gid
)) {
45 // {{{ function formu()
47 public function formu()
49 return 'include/form.valid.medals.tpl';
53 // {{{ function _mail_subj
55 protected function _mail_subj()
57 return "[Polytechnique.org/Décoration] Demande de décoration : ".$this->medal_name();
61 // {{{ function _mail_body
63 protected function _mail_body($isok)
66 return " La décoration ".$this->medal_name()." vient d'être ajoutée à ta fiche.";
68 return " La demande que tu avais faite pour la décoration ".$this->medal_name()." a été refusée.";
73 // {{{ function medal_name
75 public function medal_name()
79 SELECT IF (g.text IS NOT NULL, CONCAT(m.text,' - ', g.text), m.text)
80 FROM profile_medals AS m
81 LEFT JOIN profile_medals_grades AS g ON(g.mid = m.id AND g.gid = {?})
82 WHERE m.id = {?}", $this->gid
, $this->mid
);
83 return $r->fetchOneCell();
87 // {{{ function submit()
89 public function submit()
91 $res = XDB
::query("SELECT FIND_IN_SET('validation', flags)
93 WHERE id = {?}", $this->mid
);
94 if ($res->fetchOneCell()) {
102 // {{{ function commit()
104 public function commit ()
106 require_once 'notifs.inc.php';
107 register_watch_op($this->user
->id(), WATCH_FICHE
, '', 'medals');
108 return XDB
::execute('REPLACE INTO profile_medals_sub
109 VALUES ({?}, {?}, {?})',
110 $this->user
->id(), $this->mid
,
111 is_null($this->gid
) ?
0 : $this->gid
);
115 // {{{ function get_request($medal)
117 static public function get_request($uid, $type)
119 $reqs = Validate
::get_typed_requests($uid, 'medal');
120 foreach ($reqs as &$req) {
121 if ($req->mid
== $type) {
133 // vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: