X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;f=modules%2Fprofile%2Fdecos.inc.php;h=7a88b6114c2fd9c14693d8f77be1141563930d3e;hb=ce0b2c6f3fc4e7c524df32f56f1bc8e8d573bb1a;hp=9aaea5ee579b313f1a02e625f7add007f7203589;hpb=ddb649901f5a88d695a7050f2a59da140842ec89;p=platal.git diff --git a/modules/profile/decos.inc.php b/modules/profile/decos.inc.php index 9aaea5e..7a88b61 100644 --- a/modules/profile/decos.inc.php +++ b/modules/profile/decos.inc.php @@ -1,6 +1,6 @@ pid()); $value = array(); while (list($id, $grade) = $res->next()) { - $value[$id] = array('grade' => $grade, + $value[$id] = array('grade' => $grade, 'valid' => '1'); } @@ -61,9 +61,9 @@ class ProfileDeco implements ProfileSetting foreach ($orig as $id=>&$val) { if (!isset($value[$id]) || $val['grade'] != $value[$id]['grade']) { if ($val['valid']) { - XDB::execute("DELETE FROM profile_medals_sub + XDB::execute("DELETE FROM profile_medals WHERE uid = {?} AND mid = {?}", - S::i('uid'), $id); + $page->pid(), $id); } else { $req = MedalReq::get_request(S::i('uid'), $id); if ($req) { @@ -76,8 +76,9 @@ class ProfileDeco implements ProfileSetting // Add new ones foreach ($value as $id=>&$val) { if (!isset($orig[$id]) || $orig[$id]['grade'] != $val['grade']) { - $req = new MedalReq(S::i('uid'), $id, $val['grade']); + $req = new MedalReq(S::user(), $id, $val['grade']); $req->submit(); + sleep(1); } } } @@ -92,50 +93,38 @@ class ProfileDecos extends ProfilePage parent::__construct($wiz); $this->settings['medals'] = new ProfileDeco(); $this->settings['medals_pub'] = new ProfilePub(); + $this->watched['medals'] = true; } - protected function fetchData() + protected function _fetchData() { - $res = XDB::query("SELECT profile_medals_pub - FROM auth_user_quick - WHERE user_id = {?}", - S::i('uid')); + $res = XDB::query("SELECT medals_pub + FROM profiles + WHERE pid = {?}", + $this->pid()); $this->values['medals_pub'] = $res->fetchOneCell(); - parent::fetchData(); } - protected function saveData() + protected function _saveData() { - parent::saveData(); if ($this->changed['medals_pub']) { - XDB::execute("UPDATE auth_user_quick - SET profile_medals_pub = {?} - WHERE user_id = {?}", - $this->values['medals_pub'], S::i('uid')); + XDB::execute("UPDATE profiles + SET medals_pub = {?} + WHERE pid = {?}", + $this->values['medals_pub'], $this->pid()); } } - public function prepare(PlatalPage &$page, $id) + public function _prepare(PlPage &$page, $id) { - parent::prepare($page, $id); - $res = XDB::iterator("SELECT * - FROM profile_medals_grades - ORDER BY mid, pos"); - $grades = array(); - while ($tmp = $res->next()) { - $grades[$tmp['mid']][] = $tmp; - } - $page->assign('grades', $grades); - $res = XDB::iterator("SELECT *, FIND_IN_SET('validation', flags) AS validate - FROM profile_medals + FROM profile_medal_enum ORDER BY type, text"); $mlist = array(); while ($tmp = $res->next()) { $mlist[$tmp['type']][] = $tmp; } $page->assign('medal_list', $mlist); - $trad = Array('ordre' => 'Ordres', 'croix' => 'Croix', 'militaire' => 'Médailles militaires',