283 lines
8.8 KiB
JavaScript
283 lines
8.8 KiB
JavaScript
// JS for all ScoDoc pages (using jQuery UI)
|
|
|
|
|
|
$(function () {
|
|
// Autocomplete recherche etudiants par nom
|
|
$(".in-expnom").autocomplete(
|
|
{
|
|
delay: 300, // wait 300ms before suggestions
|
|
minLength: 2, // min nb of chars before suggest
|
|
position: { collision: 'flip' }, // automatic menu position up/down
|
|
source: SCO_URL + "/search_etud_by_name",
|
|
select: function (event, ui) {
|
|
$(".in-expnom").val(ui.item.value);
|
|
$("#form-chercheetud").submit();
|
|
}
|
|
});
|
|
|
|
// Date picker
|
|
$(".datepicker").datepicker({
|
|
showOn: 'button',
|
|
buttonImage: '/ScoDoc/static/icons/calendar_img.png',
|
|
buttonImageOnly: true,
|
|
dateFormat: 'dd/mm/yy',
|
|
duration: 'fast',
|
|
});
|
|
$('.datepicker').datepicker('option', $.extend({ showMonthAfterYear: false },
|
|
$.datepicker.regional['fr']));
|
|
|
|
/* Barre menu */
|
|
var sco_menu_position = { my: "left top", at: "left bottom" };
|
|
$("#sco_menu").menu({
|
|
position: sco_menu_position,
|
|
blur: function () {
|
|
$(this).menu("option", "position", sco_menu_position);
|
|
},
|
|
focus: function (e, ui) {
|
|
if ($("#sco_menu").get(0) !== $(ui).get(0).item.parent().get(0)) {
|
|
$(this).menu("option", "position", { my: "left top", at: "right top" });
|
|
}
|
|
}
|
|
}).mouseleave(function (x, y) {
|
|
$("#sco_menu").menu('collapseAll');
|
|
});
|
|
|
|
$("#sco_menu > li > a > span").switchClass("ui-icon-carat-1-e", "ui-icon-carat-1-s");
|
|
|
|
/* Les menus isoles dropdown */
|
|
$(".sco_dropdown_menu").menu({
|
|
position: sco_menu_position
|
|
}).mouseleave(function (x, y) {
|
|
$(".sco_dropdown_menu").menu('collapseAll');
|
|
}
|
|
);
|
|
$(".sco_dropdown_menu > li > a > span").switchClass("ui-icon-carat-1-e", "ui-icon-carat-1-s");
|
|
|
|
/* up-to-date status */
|
|
var update_div = document.getElementById("update_warning");
|
|
if (update_div) {
|
|
fetch('install_info').then(
|
|
response => response.text()
|
|
).then(text => {
|
|
update_div.innerHTML = text;
|
|
if (text) {
|
|
update_div.style.display = "block";
|
|
}
|
|
});
|
|
}
|
|
});
|
|
|
|
// Affiche un message transitoire
|
|
function sco_message(msg) {
|
|
var div = document.createElement("div");
|
|
div.className = "message_curtom";
|
|
div.innerHTML = msg;
|
|
document.querySelector("body").appendChild(div);
|
|
setTimeout(() => {
|
|
div.remove();
|
|
}, 3000);
|
|
}
|
|
|
|
|
|
|
|
function get_query_args() {
|
|
var s = window.location.search; // eg "?x=1&y=2"
|
|
var vars = {};
|
|
s.replace(
|
|
/[?&]+([^=&]+)=?([^&]*)?/gi, // regexp
|
|
function (m, key, value) { // callback
|
|
vars[key] = value !== undefined ? value : '';
|
|
}
|
|
);
|
|
return vars;
|
|
}
|
|
|
|
|
|
// Tables (gen_tables)
|
|
$(function () {
|
|
if ($('table.gt_table').length > 0) {
|
|
var table_options = {
|
|
"paging": false,
|
|
"searching": false,
|
|
"info": false,
|
|
/* "autoWidth" : false, */
|
|
"fixedHeader": {
|
|
"header": true,
|
|
"footer": true
|
|
},
|
|
"orderCellsTop": true, // cellules ligne 1 pour tri
|
|
"aaSorting": [], // Prevent initial sorting
|
|
};
|
|
$('table.gt_table').DataTable(table_options);
|
|
table_options["searching"] = true;
|
|
$('table.gt_table_searchable').DataTable(table_options);
|
|
}
|
|
});
|
|
|
|
|
|
// Show tags (readonly)
|
|
function readOnlyTags(nodes) {
|
|
// nodes are textareas, hide them and create a span showing tags
|
|
for (var i = 0; i < nodes.length; i++) {
|
|
var node = $(nodes[i]);
|
|
node.hide();
|
|
var tags = nodes[i].value.split(',');
|
|
node.after('<span class="ro_tags"><span class="ro_tag">' + tags.join('</span><span class="ro_tag">') + '</span></span>');
|
|
}
|
|
}
|
|
|
|
/* Editeur pour champs
|
|
* Usage: créer un élément avec data-oid (object id)
|
|
* La méthode d'URL save sera appelée en POST avec deux arguments: oid et value,
|
|
* value contenant la valeur du champs.
|
|
* Inspiré par les codes et conseils de Seb. L.
|
|
*/
|
|
class ScoFieldEditor {
|
|
constructor(selector, save_url, read_only) {
|
|
this.save_url = save_url;
|
|
this.read_only = read_only;
|
|
this.selector = selector;
|
|
this.installListeners();
|
|
}
|
|
// Enregistre l'élément obj
|
|
save(obj) {
|
|
var value = obj.innerText.trim();
|
|
if (value.length == 0) {
|
|
value = "";
|
|
}
|
|
if (value == obj.dataset.value) {
|
|
return true; // Aucune modification, pas d'enregistrement mais on continue normalement
|
|
}
|
|
obj.classList.add("sco_wait");
|
|
// DEBUG
|
|
// console.log(`
|
|
// data : ${value},
|
|
// id: ${obj.dataset.oid}
|
|
// `);
|
|
|
|
$.post(this.save_url,
|
|
{
|
|
oid: obj.dataset.oid,
|
|
value: value,
|
|
},
|
|
function (result) {
|
|
obj.classList.remove("sco_wait");
|
|
obj.classList.add("sco_modified");
|
|
}
|
|
);
|
|
return true;
|
|
}
|
|
/*****************************/
|
|
/* Gestion des évènements */
|
|
/*****************************/
|
|
installListeners() {
|
|
if (this.read_only) {
|
|
return;
|
|
}
|
|
document.body.addEventListener("keydown", this.key);
|
|
let editor = this;
|
|
this.handleSelectCell = (event) => { editor.selectCell(event) };
|
|
this.handleModifCell = (event) => { editor.modifCell(event) };
|
|
this.handleBlur = (event) => { editor.blurCell(event) };
|
|
this.handleKeyCell = (event) => { editor.keyCell(event) };
|
|
document.querySelectorAll(this.selector).forEach(cellule => {
|
|
cellule.addEventListener("click", this.handleSelectCell);
|
|
cellule.addEventListener("dblclick", this.handleModifCell);
|
|
cellule.addEventListener("blur", this.handleBlur);
|
|
});
|
|
}
|
|
/*********************************/
|
|
/* Interaction avec les cellules */
|
|
/*********************************/
|
|
blurCell(event) {
|
|
let currentModif = document.querySelector(".sco_modifying");
|
|
if (currentModif) {
|
|
if (!this.save(currentModif)) {
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
selectCell(event) {
|
|
let obj = event.currentTarget;
|
|
if (obj) {
|
|
if (obj.classList.contains("sco_modifying")) {
|
|
return; // Cellule en cours de modification, ne pas sélectionner.
|
|
}
|
|
let currentModif = document.querySelector(".sco_modifying");
|
|
if (currentModif) {
|
|
if (!this.save(currentModif)) {
|
|
return;
|
|
}
|
|
}
|
|
|
|
this.unselectCell();
|
|
obj.classList.add("sco_selected");
|
|
}
|
|
}
|
|
unselectCell() {
|
|
document.querySelectorAll(".sco_selected, .sco_modifying").forEach(cellule => {
|
|
cellule.classList.remove("sco_selected", "sco_modifying");
|
|
cellule.removeAttribute("contentEditable");
|
|
cellule.removeEventListener("keydown", this.handleKeyCell);
|
|
});
|
|
}
|
|
modifCell(event) {
|
|
let obj = event.currentTarget;
|
|
if (obj) {
|
|
obj.classList.add("sco_modifying");
|
|
obj.contentEditable = true;
|
|
obj.addEventListener("keydown", this.handleKeyCell);
|
|
obj.focus();
|
|
}
|
|
}
|
|
key(event) {
|
|
switch (event.key) {
|
|
case "Enter":
|
|
this.modifCell(document.querySelector(".sco_selected"));
|
|
event.preventDefault();
|
|
break;
|
|
}
|
|
}
|
|
keyCell(event) {
|
|
let obj = event.currentTarget;
|
|
if (obj) {
|
|
if (event.key == "Enter") {
|
|
event.preventDefault();
|
|
event.stopPropagation();
|
|
if (!this.save(obj)) {
|
|
return
|
|
}
|
|
obj.classList.remove("sco_modifying");
|
|
// ArrowMove(0, 1);
|
|
// modifCell(document.querySelector(".sco_selected"));
|
|
this.unselectCell();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
function getCurrentScriptPath() {
|
|
// Get all the script elements on the page
|
|
var scripts = document.getElementsByTagName('script');
|
|
|
|
// Find the last script element (which is the currently executing script)
|
|
var currentScript = scripts[scripts.length - 1];
|
|
|
|
// Retrieve the src attribute of the script element
|
|
var scriptPath = currentScript.src;
|
|
|
|
return scriptPath;
|
|
}
|
|
function removeLastTwoComponents(path) {
|
|
// Split the path into individual components
|
|
var components = path.split('/');
|
|
|
|
// Remove the last two components (filename and enclosing directory)
|
|
components.splice(-2);
|
|
|
|
// Join the remaining components back into a path
|
|
var newPath = components.join('/');
|
|
|
|
return newPath;
|
|
}
|