/***************************************************************************
- * Copyright (C) 2003-2010 Polytechnique.org *
+ * Copyright (C) 2003-2011 Polytechnique.org *
* http://opensource.polytechnique.org/ *
* *
* This program is free software; you can redistribute it and/or modify *
updateGroupSubLink();
break;
case 'deco':
- for (var i in names) {
- if ($('#medal_' + i).length != 0) {
- getMedalName(i);
- buildGrade(i, $('#medal_' + i).find('[name*=medal_' + i + '_grade]').val());
- }
+ var i = 0;
+ while ($('#medal_' + i).length != 0) {
+ prepareMedal(i);
+ ++i;
}
break;
case 'emploi':
- for (var i = 0 ; $('#job_' + i).length != 0; ++i) {
- updateJobSector(i, $('#job_' + i).find("[name='jobs[" + i + "][subSector]']").val());
- updateJobSubSector(i, $('#job_' + i).find("[name='jobs[" + i + "][subSubSector]']").val());
- updateJobAlternates(i);
- }
- if ($('#job_0').find("[name='jobs[0][name]']").val() == '') {
- $.get(platal_baseurl + 'profile/ajax/job/0', makeAddJob(0));
+ if ($('#jobs_0').find("[name='jobs[0][name]']").val() == '') {
+ registerEnterpriseAutocomplete(0);
}
break;
}
var educationDegreeName;
var subgrades;
var names;
+var multiples;
+
+// Publicity follows the following ordering: private < ax < public.
+var publicity = [];
+publicity['private'] = 0;
+publicity['ax'] = 1;
+publicity['public'] = 2;
// Names {{{1
while ($('#search_name_' + i).length != 0) {
i++;
}
- Ajax.update_html('search_name_' + i, 'profile/ajax/searchname/' + i + '/' + isFemale, function(data){
- $('#searchname').before(data);
- changeNameFlag(i);
- });
+ $('#search_name_' + i)
+ .updateHtml('profile/ajax/searchname/' + i + '/' + isFemale,
+ function(data) {
+ $('#searchname').before(data);
+ changeNameFlag(i);
+ });
}
function removeSearchName(i, isFemale)
searchnames += $('#search_name_' + i).find(':text').val() + ';;';
}
}
- Ajax.update_html(null, 'profile/ajax/buildnames/' + searchnames + '/' + isFemale, function(data){
- var name = data.split(';');
- $('#public_name').html(name[0]);
- $('#private_name').html(name[0] + name[1]);
- });
+ $.xget('profile/ajax/buildnames/' + searchnames + '/' + isFemale,
+ function(data){
+ var name = data.split(';');
+ $('#public_name').html(name[0]);
+ $('#private_name').html(name[0] + name[1]);
+ });
}
function toggleParticle(id)
var edu = $('.edu_' + id).find("[name='edus[" + id + "][eduid]']").val() - 1;
var sel = $('.edu_' + id).find('[name=edu_' + id + '_tmp]').val();
var html = '';
- var length = educationDegree[edu].length;
+ if (educationDegree[edu]) {
+ var length = educationDegree[edu].length;
+ } else {
+ var length = 0;
+ }
for (i = 0; i < length; ++i) {
html += '<option value="' + educationDegree[edu][i] + '"';
if (sel == educationDegree[edu][i]) {
}
html += '>' + educationDegreeName[educationDegree[edu][i] - 1] + '</option>';
}
+ // XXX: to be removed once SQL table profile_merge_issues is.
+ if (sel != '' && html == '') {
+ html += '<option value="' + sel + '" selected="selected">' + educationDegreeName[sel - 1] + '</option>';
+ }
$('.edu_' + id).find("[name='edus[" + id + "][degreeid]']").html(html);
}
i++;
$('#edu_add').addClass(prefix + i);
i--;
- $.get(platal_baseurl + 'profile/ajax/edu/' + i + '/' + class_parity,
+ $.xget('profile/ajax/edu/' + i + '/' + class_parity,
function(data) {
$('#edu_add').before(data);
prepareType(i);
i++;
}
$('#add_address').before('<div id="addresses_' + i + '_cont"></div>');
- Ajax.update_html('addresses_' + i + '_cont', 'profile/ajax/address/' + i, checkCurrentAddress());
+ $('#addresses_' + i + '_cont').updateHtml('profile/ajax/address/' + i,
+ checkCurrentAddress());
}
function addressChanged(prefid)
$('#' + prefid + '_cont').find('[name*=changed]').val("1");
}
-function validGeoloc(prefid, id, geoloc)
+function deleteGeocoding(prefid, hrpid)
{
- if (geoloc == 1) {
- $('#' + prefid + '_cont').find('[name*=text]').val($('#' + prefid + '_cont').find('[name*=geoloc]').val());
- $('#' + prefid + '_cont').find('[name*=postalText]').val($('#' + prefid + '_cont').find('[name*=geocodedPostalText]').val());
- }
- if (geoloc > 0) {
- $('#' + prefid + '_cont').find("[name*='[geoloc]']").remove();
+ var confirmation = confirm(
+ "La localisation de l'adresse sert à deux choses : te placer dans "
+ + "le planisphère et te faire apparaître dans la recherche avancée par "
+ + "pays, région, département, ville... La supprimer t'en fera disparaître. "
+ + "\nIl ne faut le faire que si cette localisation "
+ + "est réellement erronée. Avant de supprimer cette localisation, l'équipe de "
+ + "Polytechnique.org tentera de la réparer.\n\nConfirmes-tu ta "
+ + "demande de suppression de cette localisation ?");
+
+ if (confirmation) {
+ var address = $('#' + prefid).find("[name*='[text]']").val();
+ $.xpost('profile/ajax/address/del/' + hrpid, { address:address });
+ $('#' + prefid + '_geocoding_removal').html('Localisation en attente de validation.');
}
- $('#' + prefid + '_cont').find('[name*=text]').removeClass('error');
- $('#' + prefid + '_cont').find('[name*=geoloc_choice]').val(geoloc);
- $('.' + prefid + '_geoloc').remove();
}
// {{{1 Phones
-function addTel(prefid, prefname)
+function addTel(prefid, prefname, subField, mainField, mainId)
{
var i = 0;
var prefix = prefid + '_';
i++;
}
$('#' + prefix + 'add').before('<div id="' + prefix + i + '" style="clear: both; padding-top: 4px; padding-bottom: 4px"></div>');
- Ajax.update_html(prefix + i, 'profile/ajax/tel/' + prefid + '/' + prefname + '/' + i);
+ $('#' + prefix + i).updateHtml('profile/ajax/tel/' + prefid + '/' + prefname + '/' + i + '/' + subField + '/' + mainField + '/' + mainId);
}
function removeTel(prefname, prefid, id)
// {{{1 Medals
+function prepareMedal(i)
+{
+ getMedalName($('#medal_' + i).find('[name="medals[' + i + '][id]"]').val());
+ buildGrade(i);
+}
+
function updateMedal()
{
var val = $('#medals').find('[name*=medal_sel]').val();
- if (val && ($('#medal_' + val).length == 0)) {
+
+ if ((multiple[val] && subgrades[val]) || $('.medal_name_' + val).length == 0) {
$('#medal_add').show();
} else {
$('#medal_add').hide();
function getMedalName(id)
{
- $('#medal_name_' + id).html(names[id]);
+ $('.medal_name_' + id).html(names[id]);
}
-function buildGrade(id, current)
+function buildGrade(i)
{
- var grade;
- var subg = subgrades[id];
- var obj = $('#medal_grade_' + id);
+ var id = $('#medal_' + i).find('[name="medals[' + i + '][id]"]').val();
+ var current = $('#medal_' + i).find('[name="medals_' + i + '_grade"]').val();
+ var subg = subgrades[id];
+ var obj = $('#medal_grade_' + i);
if (!subg) {
- obj.prepend('<input type="hidden" name="medals[' + id + '][grade]" value="0" />');
+ obj.prepend('<input type="hidden" name="medals[' + i + '][grade]" value="0" />');
} else {
- var html = 'Agrafe : <select name="medals[' + id + '][grade]">';
+ var html = 'Agrafe : <select name="medals[' + i + '][grade]">';
html += '<option value="0">Non précisée</option>';
- for (grade = 0 ; grade < subg.length ; grade++) {
+ for (var grade = 0; grade < subg.length; ++grade) {
html += '<option value="' + subg[grade][0] + '"';
if (subg[grade][0] == current) {
html += ' selected="selected"';
}
html += '>' + subg[grade][1] + '</option>';
}
-
html += '</select>';
obj.prepend(html);
}
}
-function makeAddProcess(id)
+function makeAddProcess(i, id)
{
return function(data)
{
$('#medals').after(data);
updateMedal();
getMedalName(id);
- buildGrade(id, 0);
+ buildGrade(i, 0);
};
}
function addMedal()
{
+ var i = 0;
+ while ($('#medal_' + i).length != 0) {
+ ++i;
+ }
+
var id = $('#medals').find('[name=medal_sel]').val();
- $.get(platal_baseurl + 'profile/ajax/medal/' + id, makeAddProcess(id));
+ $.xget('profile/ajax/medal/' + i + '/' + id, makeAddProcess(i, id));
}
function removeMedal(id)
{
- $("#medal_" + id).remove();
+ var total = 0;
+ while ($('#medal_' + total).length != 0) {
+ ++total;
+ }
+ $('#medal_' + id).remove();
+ for (var i = parseInt(id) + 1; i < total; ++i) {
+ renumberMedal(i);
+ }
updateMedal();
}
+function renumberMedal(i)
+{
+ var new_i = i - 1;
+
+ $('#medal_' + i).attr('id', 'medal_' + new_i);
+ $('#medal_grade_' + i).attr('id', 'medal_grade_' + new_i);
+ $('#medal_grade_' + new_i).find("[name='medals_" + i + "_grade']").attr('name', 'medals_' + new_i + '_grade');
+ $('#medal_grade_' + new_i).find("[name='medals[" + i + "][id]']").attr('name', 'medals[' + new_i + '][id]');
+ $('#medal_grade_' + new_i).find("[name='medals[" + i + "][valid]']").attr('name', 'medals[' + new_i + '][valid]');
+ $('#medal_grade_' + new_i).find("[name='medals[" + i + "][grade]']").attr('name', 'medals[' + new_i + '][grade]');
+ $('#medal_' + new_i).find('a.removeMedal').attr('href', 'javascript:removeMedal(' + new_i + ')');
+}
+
// Jobs {{{1
function removeJob(id, pref)
$('#' + id).find("[name='" + pref + "[removed]']").val('0');
}
-function updateJobSector(id, sel)
-{
- var sector = $('#job_' + id).find("[name='jobs[" + id + "][sector]']").val();
- if (sector == '') {
- sector = '-1';
- }
- Ajax.update_html('job_' + id + '_subSector', 'profile/ajax/sector/' + id + '/job_' + id + '/jobs[' + id + ']/' + sector + '/' + sel);
-}
-
-function updateJobSubSector(id, sel)
-{
- var subSector = $('#job_' + id).find("[name='jobs[" + id + "][subSector]']").val();
- if (subSector == '') {
- subSector = '-1';
- }
- Ajax.update_html('job_' + id + '_subSubSector', 'profile/ajax/sub_sector/' + id + '/' + subSector + '/' + sel);
-}
-
-function updateJobAlternates(id)
-{
- var subSubSector = $('#job_' + id).find("[name='jobs[" + id + "][subSubSector]']").val();
- if (subSubSector != '') {
- Ajax.update_html('job_' + id + '_alternates', 'profile/ajax/alternates/' + id + '/' + subSubSector);
- }
-}
-
-function emptyJobSubSector(id)
-{
- Ajax.update_html('job_' + id + '_subSubSector', 'profile/ajax/sub_sector/' + id + '/-1/-1');
-}
-
-function emptyJobAlternates(id)
-{
- Ajax.update_html('job_' + id + '_alternates', 'profile/ajax/alternates/' + id + '/-1');
-}
-
-function displayAllSector(id)
-{
- $('.sector_text_' + id).remove();
- $('.sector_' + id).show();
-}
-
function makeAddJob(id)
{
return function(data)
function addJob()
{
var i = 0;
- while ($('#job_' + i).length != 0) {
+ while ($('#jobs_' + i).length != 0) {
++i;
}
- $.get(platal_baseurl + 'profile/ajax/job/' + i, makeAddJob(i));
+ $.xget('profile/ajax/job/' + i, makeAddJob(i));
}
function addEntreprise(id)
jobid = '';
formvarname = 'terms';
} else {
- parentpath = '#job_'+jobid+' ';
+ parentpath = '#jobs_'+jobid+' ';
formvarname = 'jobs['+jobid+'][terms]';
}
- var lastJobTerm = $(parentpath + '.job_term:last');
+ var lastJobTerm = $(parentpath + '.jobs_term:last');
if (lastJobTerm.length != 0) {
termid = parseInt(lastJobTerm.children('input').attr('name').replace(/^(jobs\[[0-9]+\]\[terms\]|terms)\[([0-9]+)\]\[jtid\]/, '$2')) + 1;
if ($('#job'+jobid+'_term'+jtid).length > 0) {
return false;
}
}
- var newdiv = '<div class="job_term" id="job'+jobid+'_term'+jtid+'">'+
+ var newdiv = '<div class="jobs_term" id="job'+jobid+'_term'+jtid+'">'+
'<span>'+full_name+'</span>'+
'<input type="hidden" name="'+formvarname+'['+termid+'][jtid]" value="'+jtid+'" />'+
'<img title="Retirer ce mot-clef" alt="retirer" src="images/icons/cross.gif" />'+
'</div>';
if (lastJobTerm.length == 0) {
- $(parentpath + '.job_terms').prepend(newdiv);
+ $(parentpath + '.jobs_terms').prepend(newdiv);
} else {
lastJobTerm.after(newdiv);
}
function displayJobTerm(row)
{
if (row[1] < 0) {
- return '... <em>précise ta recherche</em> ...';
+ return '... <em>parcourir les résultats dans un arbre</em> ...';
}
return row[0];
}
*/
function selectJobTerm(li)
{
- if (li.extra[0] < 0) {
- return;
- }
var jobid = this.extraParams.jobid;
- addJobTerm(jobid,li.extra[0],$(li).text());
+ if (li.extra[0] >= 0) {
+ addJobTerm(jobid,li.extra[0],$(li).text());
+ }
var search_input;
if (jobid < 0) {
search_input = $('.term_search')[0];
} else {
- search_input = $('#job_'+jobid+' .term_search')[0];
+ search_input = $('#jobs_'+jobid+' .term_search')[0];
+ }
+ if (li.extra[0] >= 0) {
+ search_input.value = '';
+ search_input.focus();
+ } else {
+ search_input.value = li.selectValue.replace(/%$/,'');
+ toggleJobTermsTree(jobid, li.selectValue);
}
- search_input.value = '';
- search_input.focus();
}
/**
* Function to show or hide a terms tree in job edition
* @param jobid is the id of the job currently edited
*/
-function toggleJobTermsTree(jobid)
+function toggleJobTermsTree(jobid, textfilter)
{
+ $('#term_tree_comment').toggle();
+
var treepath;
if (jobid < 0) {
treepath = '';
} else {
- treepath = '#job_'+jobid+' ';
+ treepath = '#jobs_'+jobid+' ';
}
treepath += '.term_tree';
if ($(treepath + ' ul').length > 0) {
$(treepath).empty().removeClass().addClass('term_tree');
- return;
+ if (!textfilter) {
+ return;
+ }
}
- createJobTermsTree(treepath, 'profile/ajax/tree/jobterms/all', 'job' + jobid, 'chooseJobTerm');
+ createJobTermsTree(treepath, 'profile/ajax/tree/jobterms/all', 'job' + jobid, 'chooseJobTerm', textfilter);
}
/**
{
var val = $('#' + cat + '_table').find('[name=' + cat + '_sel]').val();
var text = $('#' + cat + '_table').find('[name=' + cat + '_sel] :selected').text();
- $.get(platal_baseurl + 'profile/ajax/skill/' + cat + '/' + val,
+ $.xget('profile/ajax/skill/' + cat + '/' + val,
function(data) {
$('#' + cat).append(data);
$('#' + cat + '_' + val + '_title').text(text);
updateElement('countries');
}
-function updateSubSector()
-{
- var s = $('#sectorSelection').find('[name=sectorSelection]').val();
- var ss = $('#subSectorSelection').find("[name='jobs[-1][subSector]']").val();
- if ((s == '' || ss == '') || $('#sectors_' + s + '_' + ss).length != 0) {
- $('#addSector').hide();
- } else {
- $('#addSector').show();
- }
-}
-
-function removeSector(s, ss)
-{
- $('#sectors_' + s + '_' + ss).remove();
- updateSubSector();
-}
-
-function updateSector()
-{
- var sector = $('#sectorSelection').find('[name=sectorSelection]').val();
- if (sector == '') {
- sector = '-1';
- $('#subSectorSelection').html('');
- return;
- }
- $.get(platal_baseurl + 'profile/ajax/sector/-1/0/0/' + sector,
- function(data) {
- data = '<a href="javascript:addSector()" style="display: none; float: right" id="addSector">'
- + ' <img src="images/icons/add.gif" alt="Ajouter ce secteur" title="Ajouter ce secteur" />'
- + '</a>' + data;
- $('#subSectorSelection').html(data);
- $('#subSectorSelection').find("[name='jobs[-1][subSector]']").change(updateSubSector);
- });
-}
-
-function addSector()
-{
- var s = $('#sectorSelection').find('[name=sectorSelection]').val();
- var ss = $('#subSectorSelection').find("[name='jobs[-1][subSector]']").val();
- var sst = $('#subSectorSelection').find("[name='jobs[-1][subSector]'] :selected").text();
-
- var html = '<div id="sectors_' + s + '_' + ss + '" style="clear: both; margin-top: 0.5em" class="titre">'
- + ' <a href="javascript:removeSector(\'' + s + '\',\'' + ss + '\')" style="display: block; float: right">'
- + ' <img src="images/icons/cross.gif" alt="" title="Supprimer ce secteur" />'
- + ' </a>'
- + ' <input type="hidden" name="sectors[' + s + '][' + ss + ']" value="' + sst + '" />'
- + ' ' + sst
- + '</div>';
- $('#sectors').append(html);
- updateSubSector();
-}
-
function registerEnterpriseAutocomplete(id)
{
$(".enterpriseName").each(
function() {
if (id == -1 || this.name == "jobs[" + id + "][name]") {
- $(this).autocomplete(platal_baseurl + "search/autocomplete/entreprise",
+ $(this).autocomplete($.plURL("search/autocomplete/entreprise"),
{
selectOnly:1,
field:this.name,
$(".sectorName").each(
function() {
if (id == -1 || this.name == "jobs[" + id + "][subSubSectorName]") {
- $(this).autocomplete(platal_baseurl + "search/autocomplete/subSubSector",
+ $(this).autocomplete($.plURL("search/autocomplete/subSubSector"),
{
selectOnly:1,
field:this.name,
updateElement(cat);
}
+function updateSubPublicity(subFieldId, name, mainPub)
+{
+ var subPub = $(subFieldId).find("[name='" + name + "']:checked").val();
+ if (publicity[subPub] > publicity[mainPub]) {
+ $(subFieldId).find("[name='" + name + "']:checked").removeAttr('checked');
+ $(subFieldId).find('[value=' + mainPub + ']').attr('checked', 'checked');
+ }
+}
+
+function updatePublicity(mainField, mainId, subField, subId)
+{
+ var mainFieldId = '#' + mainField + '_' + mainId;
+ var mainPub = $(mainFieldId).find("[name='" + mainField + "[" + mainId + "][pub]']:checked").val();
+ if (subId == -1) {
+ var subFields = subField.split(',');
+ for (var i =0; i < subFields.length; ++i) {
+ var subFieldBaseId = mainFieldId + '_' + subFields[i];
+ var name = mainField + '[' + mainId + '][' + subFields[i] + ']';
+ if ($(subFieldBaseId).length != 0) {
+ updateSubPublicity(subFieldBaseId, name + '[pub]', mainPub);
+ updateSubPublicity(subFieldBaseId, mainField + '[' + mainId + '][' + subFields[i] + '_pub]', mainPub);
+ }
+ subId = 0;
+ while ($(subFieldBaseId + '_' + subId).length != 0) {
+ updateSubPublicity(subFieldBaseId + '_' + subId, name + '[' + subId + '][pub]', mainPub);
+ ++subId;
+ }
+ }
+ } else {
+ if (subId == '') {
+ updateSubPublicity(mainFieldId + '_' + subField, mainField + '[' + mainId + '][' + subField + '_pub]', mainPub);
+ updateSubPublicity(mainFieldId + '_' + subField, mainField + '[' + mainId + '][' + subField + '][pub]', mainPub);
+ } else {
+ updateSubPublicity(mainFieldId + '_' + subField + '_' + subId, mainField + '[' + mainId + '][' + subField + '][' + subId + '][pub]', mainPub);
+ }
+ }
+}
+
// vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: