forked from ScoDoc/ScoDoc
Update opolka/ScoDoc from ScoDoc/ScoDoc #2
@ -1014,7 +1014,7 @@ def _edit_one(assiduite_unique: Assiduite, data: dict) -> tuple[int, str]:
|
|||||||
else assiduite_unique.external_data
|
else assiduite_unique.external_data
|
||||||
)
|
)
|
||||||
|
|
||||||
if force and not external_data.get("module", False):
|
if force and not (external_data is not None and external_data.get("module", False) != ""):
|
||||||
errors.append(
|
errors.append(
|
||||||
"param 'moduleimpl_id' : le moduleimpl_id ne peut pas être nul"
|
"param 'moduleimpl_id' : le moduleimpl_id ne peut pas être nul"
|
||||||
)
|
)
|
||||||
|
@ -331,15 +331,16 @@ def moduleimpl_status(moduleimpl_id=None, partition_id=None):
|
|||||||
>Saisie Absences journée</a></span>
|
>Saisie Absences journée</a></span>
|
||||||
"""
|
"""
|
||||||
)
|
)
|
||||||
|
year, week, day = datetime.date.today().isocalendar()
|
||||||
|
semaine: str = f"{year}-W{week}"
|
||||||
H.append(
|
H.append(
|
||||||
f"""
|
f"""
|
||||||
<span class="moduleimpl_abs_link"><a class="stdlink" href="{
|
<span class="moduleimpl_abs_link"><a class="stdlink" href="{
|
||||||
url_for(
|
url_for(
|
||||||
"assiduites.signal_assiduites_group",
|
"assiduites.signal_assiduites_diff",
|
||||||
scodoc_dept=g.scodoc_dept,
|
scodoc_dept=g.scodoc_dept,
|
||||||
group_ids=group_id,
|
group_ids=group_id,
|
||||||
jour=datetime.date.today().isoformat(),
|
semaine=semaine,
|
||||||
formsemestre_id=formsemestre.id,
|
formsemestre_id=formsemestre.id,
|
||||||
moduleimpl_id="" if moduleimpl_id is None else moduleimpl_id
|
moduleimpl_id="" if moduleimpl_id is None else moduleimpl_id
|
||||||
)}"
|
)}"
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
// <=== CONSTANTS and GLOBALS ===>
|
// <=== CONSTANTS and GLOBALS ===>
|
||||||
|
|
||||||
const TIMEZONE = "Europe/Paris";
|
|
||||||
let url;
|
let url;
|
||||||
|
|
||||||
function getUrl() {
|
function getUrl() {
|
||||||
@ -192,8 +191,9 @@ function sync_get(path, success, errors) {
|
|||||||
*/
|
*/
|
||||||
async function async_get(path, success, errors) {
|
async function async_get(path, success, errors) {
|
||||||
console.log("async_get " + path);
|
console.log("async_get " + path);
|
||||||
|
let response;
|
||||||
try {
|
try {
|
||||||
const response = await fetch(path);
|
response = await fetch(path);
|
||||||
if (response.ok) {
|
if (response.ok) {
|
||||||
const data = await response.json();
|
const data = await response.json();
|
||||||
success(data);
|
success(data);
|
||||||
@ -204,6 +204,8 @@ async function async_get(path, success, errors) {
|
|||||||
console.error(error);
|
console.error(error);
|
||||||
if (errors) errors(error);
|
if (errors) errors(error);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return response;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -234,8 +236,9 @@ function sync_post(path, data, success, errors) {
|
|||||||
*/
|
*/
|
||||||
async function async_post(path, data, success, errors) {
|
async function async_post(path, data, success, errors) {
|
||||||
console.log("async_post " + path);
|
console.log("async_post " + path);
|
||||||
|
let response;
|
||||||
try {
|
try {
|
||||||
const response = await fetch(path, {
|
response = await fetch(path, {
|
||||||
method: "POST",
|
method: "POST",
|
||||||
headers: {
|
headers: {
|
||||||
"Content-Type": "application/json",
|
"Content-Type": "application/json",
|
||||||
@ -253,6 +256,8 @@ async function async_post(path, data, success, errors) {
|
|||||||
console.error(error);
|
console.error(error);
|
||||||
if (errors) errors(error);
|
if (errors) errors(error);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return response;
|
||||||
}
|
}
|
||||||
|
|
||||||
// <<== Gestion des actions de masse ==>>
|
// <<== Gestion des actions de masse ==>>
|
||||||
@ -630,13 +635,17 @@ function updateDate() {
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
openAlertModal("Attention", div, "", "#eec660");
|
openAlertModal("Attention", div, "", "#eec660");
|
||||||
$(dateInput).datepicker(
|
const date_fra = Date.toFRA(lastWorkDay.toIsoUtcString().split("T")[0]);
|
||||||
"setDate",
|
|
||||||
Date.toFRA(lastWorkDay.toIsoUtcString().split("T")[0])
|
$(dateInput).datepicker("setDate", date_fra);
|
||||||
);
|
dateInput.value = date_fra;
|
||||||
|
date = lastWorkDay;
|
||||||
|
|
||||||
dateStr = formatDate(lastWorkDay).capitalize();
|
dateStr = formatDate(lastWorkDay).capitalize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
console.warn(dateStr, date, date.toIsoUtcString());
|
||||||
|
|
||||||
document.querySelector("#datestr").textContent = dateStr;
|
document.querySelector("#datestr").textContent = dateStr;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -89,8 +89,8 @@
|
|||||||
const readOnly = {{ readonly }};
|
const readOnly = {{ readonly }};
|
||||||
|
|
||||||
|
|
||||||
updateDate();
|
|
||||||
setupDate();
|
setupDate();
|
||||||
|
updateDate();
|
||||||
setupTimeLine();
|
setupTimeLine();
|
||||||
|
|
||||||
window.forceModule = "{{ forcer_module }}"
|
window.forceModule = "{{ forcer_module }}"
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
{% block scripts %}
|
{% block scripts %}
|
||||||
{{ super() }}
|
{{ super() }}
|
||||||
<script src="{{scu.STATIC_DIR}}/js/etud_info.js"></script>
|
<script src="{{scu.STATIC_DIR}}/js/etud_info.js"></script>
|
||||||
|
<script src="{{scu.STATIC_DIR}}/js/date_utils.js"></script>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
{% block app_content %}
|
{% block app_content %}
|
||||||
@ -31,8 +32,8 @@
|
|||||||
const group_ids = "{{group_ids}}";
|
const group_ids = "{{group_ids}}";
|
||||||
|
|
||||||
function stats() {
|
function stats() {
|
||||||
const deb = document.querySelector('#stats_date_debut').value;
|
const deb = Date.fromFRA(document.querySelector('#stats_date_debut').value);
|
||||||
const fin = document.querySelector('#stats_date_fin').value;
|
const fin = Date.fromFRA(document.querySelector('#stats_date_fin').value);
|
||||||
location.href = `VisualisationAssiduitesGroupe?group_ids=${group_ids}&date_debut=${deb}&date_fin=${fin}`;
|
location.href = `VisualisationAssiduitesGroupe?group_ids=${group_ids}&date_debut=${deb}&date_fin=${fin}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -954,24 +954,27 @@
|
|||||||
|
|
||||||
editList.push(edit);
|
editList.push(edit);
|
||||||
})
|
})
|
||||||
|
const values = { "create": {}, "edit": {} };
|
||||||
$.when(
|
Promise.all(
|
||||||
asyncCreateAssiduiteGroup(createList, (data) => {
|
[asyncCreateAssiduiteGroup(createList, (data) => {
|
||||||
|
values.create = data;
|
||||||
}),
|
}),
|
||||||
|
|
||||||
asyncEditAssiduiteGroup(editList, (data) => {
|
asyncEditAssiduiteGroup(editList, (data) => {
|
||||||
|
values.edit = data;
|
||||||
|
|
||||||
})
|
})]
|
||||||
).done((c, e) => {
|
).then(() => {
|
||||||
|
const c = values.create;
|
||||||
|
const e = values.edit;
|
||||||
let error;
|
let error;
|
||||||
Object.keys(c[0].success).forEach((k) => {
|
Object.keys(c.success).forEach((k) => {
|
||||||
const assiduite = createList[Number.parseInt(k)];
|
const assiduite = createList[Number.parseInt(k)];
|
||||||
assiduite["assiduite_id"] = c[0].success[k].message.assiduite_id;
|
assiduite["assiduite_id"] = c.success[k].message.assiduite_id;
|
||||||
assiduites[assiduite.etudid].push(assiduite);
|
assiduites[assiduite.etudid].push(assiduite);
|
||||||
})
|
})
|
||||||
if (c[0].errors.length > 0) {
|
if (c.errors.length > 0) {
|
||||||
error = c[0].errors[Object.keys(c[0].errors)[0]];
|
error = c.errors[Object.keys(c.errors)[0]];
|
||||||
if (error.message.indexOf("Module") != -1) {
|
if (error.message.indexOf("Module") != -1) {
|
||||||
const html = `
|
const html = `
|
||||||
<h3>Aucun module n'a été spécifié (préférence du semestre concerné)</h3>
|
<h3>Aucun module n'a été spécifié (préférence du semestre concerné)</h3>
|
||||||
@ -982,7 +985,7 @@
|
|||||||
toCreate.length = 0
|
toCreate.length = 0
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Object.keys(e[0].success).forEach((k) => {
|
Object.keys(e.success).forEach((k) => {
|
||||||
const { etudid, assiduite_id, moduleimpl_id, etat } = editList[Number.parseInt(k)]
|
const { etudid, assiduite_id, moduleimpl_id, etat } = editList[Number.parseInt(k)]
|
||||||
assiduites[etudid].map((a) => {
|
assiduites[etudid].map((a) => {
|
||||||
if (a.assiduite_id == assiduite_id) {
|
if (a.assiduite_id == assiduite_id) {
|
||||||
|
@ -1019,7 +1019,7 @@ def visu_assi_group():
|
|||||||
short=False,
|
short=False,
|
||||||
),
|
),
|
||||||
date_debut=_dateiso_to_datefr(dates["debut"]),
|
date_debut=_dateiso_to_datefr(dates["debut"]),
|
||||||
date_fin=_dateiso_to_datefr(dates["debut"]),
|
date_fin=_dateiso_to_datefr(dates["fin"]),
|
||||||
gr_tit=gr_tit,
|
gr_tit=gr_tit,
|
||||||
group_ids=request.args.get("group_ids", None),
|
group_ids=request.args.get("group_ids", None),
|
||||||
sco=ScoData(formsemestre=groups_infos.get_formsemestre()),
|
sco=ScoData(formsemestre=groups_infos.get_formsemestre()),
|
||||||
|
Loading…
Reference in New Issue
Block a user