$value[] = $sn;
} while ($sn = $sn_all->next());
}
- require_once 'validations.inc.php';
$namesRequest = ProfileValidate::get_typed_requests($page->pid(), 'usage');
if (count($namesRequest) > 0) {
Platal::page()->assign('validation', true);
public function save(ProfilePage &$page, $field, $value)
{
require_once 'name.func.inc.php';
- require_once 'validations.inc.php';
$sn_old = build_sn_pub($page->pid());
XDB::execute("DELETE FROM s
$display_names = array();
build_display_names($display_names, $this->search_names,
$page->profile->isFemale(), $this->private_name_end);
- set_profile_display($display_names, $page->pid());
+ set_profile_display($display_names, $page->profile);
}
}
} else {
$i = 0;
foreach ($value as $key=>&$edu) {
+ if ($edu['eduid'] < 1 || !isset($edu['degreeid']) || $edu['degreeid'] < 1) {
+ Platal::page()->trigError('L\'université ou le diplôme d\'une formation manque.');
+ $success = false;
+ }
if (($edu['grad_year'] < 1921) || ($edu['grad_year'] > (date('Y') + 4))) {
Platal::page()->trigWarning('L\'année d\'obtention du diplôme est mal ou non renseignée, elle doit être du type : 2004.');
$edu['grad_year'] = null;
$page->pid());
foreach ($value as $eduid=>&$edu) {
if ($edu['eduid'] != '') {
+ $fieldId = ($edu['fieldid'] == 0) ? null : $edu['fieldid'];
XDB::execute("INSERT INTO profile_education
SET id = {?}, pid = {?}, eduid = {?}, degreeid = {?},
fieldid = {?}, grad_year = {?}, program = {?}",
$eduid, $page->pid(), $edu['eduid'], $edu['degreeid'],
- $edu['fieldid'], $edu['grad_year'], $edu['program']);
+ $fieldId, $edu['grad_year'], $edu['program']);
}
}
}
$gradYearNew, $page->profile->id());
Platal::page()->trigSuccess('Ton statut « orange » a été supprimé.');
} else {
- require_once 'validations.inc.php';
-
$myorange = new OrangeReq(S::user(), $page->profile, $gradYearNew);
$myorange->submit();
Platal::page()->trigSuccess('Tu pourras changer l\'affichage de ta promotion dès que ta nouvelle promotion aura été validée.');
}
-class ProfileSettingGeneral extends ProfilePage
+class ProfilePageGeneral extends ProfilePage
{
protected $pg_template = 'profile/general.tpl';
$this->settings['search_names']
= new ProfileSettingSearchNames();
$this->settings['birthdate'] = new ProfileSettingDate();
- $this->settings['freetext_pub']
- = $this->settings['photo_pub']
- = new ProfileSettingPub();
- $this->settings['freetext']
- = $this->settings['nationality1']
+ $this->settings['nationality1']
= $this->settings['nationality2']
= $this->settings['nationality3']
- = $this->settings['yourself']
= $this->settings['promo_display']
= null;
$this->settings['email_directory']
$this->settings['email_directory_new']
= new ProfileSettingEmailDirectory();
$this->settings['networking'] = new ProfileSettingNetworking();
- $this->settings['tels'] = new ProfileSettingPhones('user', 0);
+ $this->settings['tels'] = new ProfileSettingPhones();
$this->settings['edus'] = new ProfileSettingEdu();
$this->settings['promo'] = new ProfileSettingPromo();
- $this->watched= array('freetext' => true, 'tels' => true,
+ $this->watched= array('tels' => true,
'networking' => true, 'edus' => true,
'nationality1' => true, 'nationality2' => true,
'nationality3' => true, 'search_names' => true);
+
+ /* Some fields editable under condition */
+ if (!S::user()->isMe($this->owner)) {
+ $this->settings['deathdate'] = new ProfileSettingDate(true);
+ }
+ if (S::user()->checkPerms('directory_private')
+ || S::user()->isMyProfile($this->owner)) {
+ $this->settings['yourself']
+ = $this->settings['freetext']
+ = null;
+ $this->settings['freetext_pub']
+ = $this->settings['photo_pub']
+ = new ProfileSettingPub();
+ $this->watched['freetext'] = true;
+ }
+
}
protected function _fetchData()
{
// Checkout all data...
$res = XDB::query("SELECT p.nationality1, p.nationality2, p.nationality3, p.birthdate,
- pp.display_tel as mobile, pp.pub as mobile_pub,
p.email_directory as email_directory, pd.promo AS promo_display,
- p.freetext, p.freetext_pub, p.ax_id AS matricule_ax, pd.yourself
+ p.freetext, p.freetext_pub, p.ax_id AS matricule_ax, pd.yourself,
+ p.deathdate
FROM profiles AS p
INNER JOIN profile_display AS pd ON (pd.pid = p.pid)
- LEFT JOIN profile_phones AS pp ON (pp.pid = p.pid AND link_type = 'user')
WHERE p.pid = {?}", $this->pid());
$this->values = $res->fetchOneAssoc();
- if ($this->owner) {
- $this->values['yourself'] = $this->owner->displayName();
- }
// Retreive photo informations
$res = XDB::query("SELECT pub
FROM profile_photos
WHERE pid = {?}", $this->pid());
- $this->values['photo_pub'] = $res->fetchOneCell();
+ if ($res->numRows() == 0) {
+ $this->values['photo_pub'] = 'private';
+ } else {
+ $this->values['photo_pub'] = $res->fetchOneCell();
+ }
if ($this->owner) {
$res = XDB::query("SELECT COUNT(*)
freetext = {?}, freetext_pub = {?}, email_directory = {?}
WHERE pid = {?}",
$this->values['nationality1'], $this->values['nationality2'], $this->values['nationality3'],
- preg_replace('@(\d{2})/(\d{2})/(\d{4})@', '\3-\2-\1', $this->values['birthdate']),
+ ProfileSettingDate::toSQLDate($this->values['birthdate']),
$this->values['freetext'], $this->values['freetext_pub'], $new_email, $this->pid());
}
if ($this->changed['photo_pub']) {
WHERE pid = {?}",
$this->values['photo_pub'], $this->pid());
}
- if ($this->changed['yourself']) {
+ if (S::user()->isMe($this->owner) && $this->changed['yourself']) {
if ($this->owner) {
XDB::execute('UPDATE accounts
SET display_name = {?}
}
}
}
+ if (!S::user()->isMe($this->owner) && $this->changed['deathdate']) {
+ XDB::execute('UPDATE profiles
+ SET deathdate = {?}, deathdate_rec = NOW()
+ WHERE pid = {?} AND deathdate_rec IS NULL',
+ ProfileSettingDate::toSQLDate($this->values['deathdate']), $this->pid());
+ if (XDB::affectedRows() > 0) {
+ $this->profile->clear();
+ if ($this->owner) {
+ $this->owner->clear(true);
+ }
+ } else {
+ /* deathdate_rec was not NULL, this is just an update of the death date
+ */
+ XDB::execute('UPDATE profiles
+ SET deathdate = {?}
+ WHERE pid = {?}',
+ ProfileSettingDate::toSQLDate($this->values['deathdate']), $this->pid());
+ }
+ }
}
public function _prepare(PlPage &$page, $id)
$page->assign('edu_fields', $res->fetchAllAssoc());
require_once "emails.combobox.inc.php";
- fill_email_combobox($page, $this->owner, $this->profile);
+ fill_email_combobox($page, $this->owner);
$res = XDB::query("SELECT nw.nwid AS type, nw.name
FROM profile_networking_enum AS nw