forked from ScoDoc/ScoDoc
nouveaux bulletins BUT (commit d712bcf de SL)
This commit is contained in:
parent
23672bebde
commit
2f7e0b06a4
@ -1,298 +1,322 @@
|
|||||||
/* Bulletin BUT, Seb. L. 2021-12-06 */
|
/* Bulletin BUT, Seb. L. 2021-12-06 */
|
||||||
/*******************/
|
/*******************/
|
||||||
/* Styles généraux */
|
/* Styles généraux */
|
||||||
/*******************/
|
/*******************/
|
||||||
.wait{
|
.wait{
|
||||||
width: 60px;
|
width: 60px;
|
||||||
height: 6px;
|
height: 6px;
|
||||||
margin: auto;
|
margin: auto;
|
||||||
background: #424242; /* la réponse à tout */
|
background: #424242; /* la réponse à tout */
|
||||||
animation: wait .4s infinite alternate;
|
animation: wait .4s infinite alternate;
|
||||||
}
|
}
|
||||||
@keyframes wait{
|
@keyframes wait{
|
||||||
100%{transform: translateY(40px) rotate(1turn);}
|
100%{transform: translateY(40px) rotate(1turn);}
|
||||||
}
|
}
|
||||||
main{
|
main{
|
||||||
--couleurPrincipale: rgb(240,250,255);
|
--couleurPrincipale: rgb(240,250,255);
|
||||||
--couleurFondTitresUE: rgb(206,255,235);
|
--couleurFondTitresUE: rgb(206,255,235);
|
||||||
--couleurFondTitresRes: rgb(125, 170, 255);
|
--couleurFondTitresRes: rgb(125, 170, 255);
|
||||||
--couleurFondTitresSAE: rgb(211, 255, 255);
|
--couleurFondTitresSAE: rgb(211, 255, 255);
|
||||||
--couleurSecondaire: #fec;
|
--couleurSecondaire: #fec;
|
||||||
--couleurIntense: #c09;
|
--couleurIntense: #c09;
|
||||||
--couleurSurlignage: rgba(232, 255, 132, 0.47);
|
--couleurSurlignage: rgba(232, 255, 132, 0.47);
|
||||||
max-width: 1000px;
|
max-width: 1000px;
|
||||||
margin: auto;
|
margin: auto;
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
.ready .wait{display: none;}
|
.ready .wait{display: none;}
|
||||||
.ready main{display: block;}
|
.ready main{display: block;}
|
||||||
h2{
|
h2{
|
||||||
margin: 0;
|
margin: 0;
|
||||||
color: black;
|
color: black;
|
||||||
}
|
}
|
||||||
section{
|
section{
|
||||||
background: #FFF;
|
background: #FFF;
|
||||||
border-radius: 16px;
|
border-radius: 16px;
|
||||||
border: 1px solid #AAA;
|
border: 1px solid #AAA;
|
||||||
padding: 16px 32px;
|
padding: 16px 32px;
|
||||||
margin: 8px 0;
|
margin: 8px 0;
|
||||||
}
|
}
|
||||||
section>div:nth-child(1){
|
section>div:nth-child(1){
|
||||||
display: flex;
|
display: flex;
|
||||||
justify-content: space-between;
|
justify-content: space-between;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
gap: 8px;
|
gap: 8px;
|
||||||
}
|
}
|
||||||
.CTA_Liste{
|
.CTA_Liste{
|
||||||
display: flex;
|
display: flex;
|
||||||
gap: 4px;
|
gap: 4px;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
background: var(--couleurIntense);
|
background: var(--couleurIntense);
|
||||||
color: #FFF;
|
color: #FFF;
|
||||||
padding: 4px 8px;
|
padding: 4px 8px;
|
||||||
border-radius: 4px;
|
border-radius: 4px;
|
||||||
box-shadow: 0 2px 2px rgba(0,0,0,0.26);
|
box-shadow: 0 2px 2px rgba(0,0,0,0.26);
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
.CTA_Liste>svg{
|
.CTA_Liste>svg{
|
||||||
transition: 0.2s;
|
transition: 0.2s;
|
||||||
}
|
}
|
||||||
.CTA_Liste:hover{
|
.CTA_Liste:hover{
|
||||||
outline: 2px solid #424242;
|
outline: 2px solid #424242;
|
||||||
}
|
}
|
||||||
.listeOff svg{
|
.listeOff svg{
|
||||||
transform: rotate(180deg);
|
transform: rotate(180deg);
|
||||||
}
|
}
|
||||||
.listeOff .syntheseModule,
|
.listeOff .syntheseModule,
|
||||||
.listeOff .eval{
|
.listeOff .eval{
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
.moduleOnOff>.syntheseModule,
|
.moduleOnOff>.syntheseModule,
|
||||||
.moduleOnOff>.eval{
|
.moduleOnOff>.eval{
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
.listeOff .moduleOnOff>.syntheseModule,
|
.listeOff .moduleOnOff>.syntheseModule,
|
||||||
.listeOff .moduleOnOff>.eval{
|
.listeOff .moduleOnOff>.eval{
|
||||||
display: flex !important;
|
display: flex !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.listeOff .ue::before,
|
.listeOff .ue::before,
|
||||||
.listeOff .module::before,
|
.listeOff .module::before,
|
||||||
.moduleOnOff .ue::before,
|
.moduleOnOff .ue::before,
|
||||||
.moduleOnOff .module::before{
|
.moduleOnOff .module::before{
|
||||||
transform: rotate(0);
|
transform: rotate(0);
|
||||||
}
|
}
|
||||||
.listeOff .moduleOnOff .ue::before,
|
.listeOff .moduleOnOff .ue::before,
|
||||||
.listeOff .moduleOnOff .module::before{
|
.listeOff .moduleOnOff .module::before{
|
||||||
transform: rotate(180deg) !important;
|
transform: rotate(180deg) !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
/***********************/
|
/***********************/
|
||||||
/* Options d'affichage */
|
/* Options d'affichage */
|
||||||
/***********************/
|
/***********************/
|
||||||
.hide_abs .absences,
|
.hide_abs .absencesRecap,
|
||||||
.hide_abs_modules .module>.absences,
|
/*.hide_abs .absences,*/
|
||||||
.hide_coef .synthese em,
|
.hide_abs_modules .module>.absences,
|
||||||
.hide_coef .eval>em,
|
.hide_coef .synthese em,
|
||||||
.hide_date_inscr .dateInscription,
|
.hide_coef .eval>em,
|
||||||
.hide_ects .ects{
|
.hide_date_inscr .dateInscription,
|
||||||
display: none;
|
.hide_ects .ects{
|
||||||
}
|
display: none;
|
||||||
|
}
|
||||||
.module>.absences,
|
|
||||||
.module .moyenne,
|
/*.module>.absences,*/
|
||||||
.module .info{
|
.module .moyenne,
|
||||||
display: none;
|
.module .info{
|
||||||
}
|
display: none;
|
||||||
|
}
|
||||||
/************/
|
|
||||||
/* Etudiant */
|
/************/
|
||||||
/************/
|
/* Etudiant */
|
||||||
.info_etudiant{
|
/************/
|
||||||
color: #000;
|
.info_etudiant{
|
||||||
text-decoration: none;
|
color: #000;
|
||||||
}
|
text-decoration: none;
|
||||||
.etudiant{
|
}
|
||||||
display: flex;
|
.etudiant{
|
||||||
align-items: center;
|
display: flex;
|
||||||
gap: 16px;
|
align-items: center;
|
||||||
border-color: var(--couleurPrincipale);
|
gap: 16px;
|
||||||
background: var(--couleurPrincipale);
|
border-color: var(--couleurPrincipale);
|
||||||
color: rgb(0, 0, 0);
|
background: var(--couleurPrincipale);
|
||||||
}
|
color: rgb(0, 0, 0);
|
||||||
.civilite{
|
}
|
||||||
font-weight: bold;
|
.civilite{
|
||||||
font-size: 130%;
|
font-weight: bold;
|
||||||
}
|
font-size: 130%;
|
||||||
|
}
|
||||||
/************/
|
|
||||||
/* Semestre */
|
/************/
|
||||||
/************/
|
/* Semestre */
|
||||||
.flex{
|
/************/
|
||||||
display: flex;
|
.flex{
|
||||||
gap: 16px;
|
display: flex;
|
||||||
}
|
flex-wrap: wrap;
|
||||||
.infoSemestre{
|
gap: 8px;
|
||||||
display: flex;
|
margin-top: 8px;
|
||||||
flex-wrap: wrap;
|
}
|
||||||
justify-content: center;
|
.infoSemestre{
|
||||||
gap: 4px;
|
display: flex;
|
||||||
flex: none;
|
flex-wrap: wrap;
|
||||||
}
|
align-items: flex-start;
|
||||||
.infoSemestre>div{
|
gap: 4px;
|
||||||
border: 1px solid var(--couleurIntense);
|
}
|
||||||
padding: 4px 8px;
|
.infoSemestre>div{
|
||||||
border-radius: 4px;
|
border: 1px solid var(--couleurIntense);
|
||||||
display: grid;
|
padding: 4px 8px;
|
||||||
grid-template-columns: auto auto;
|
border-radius: 4px;
|
||||||
column-gap: 4px;
|
display: grid;
|
||||||
}
|
grid-template-columns: auto auto;
|
||||||
.infoSemestre>div:nth-child(1){
|
column-gap: 4px;
|
||||||
margin-right: auto;
|
flex: none;
|
||||||
}
|
}
|
||||||
.infoSemestre>div>div:nth-child(even){
|
.infoSemestre>div:nth-child(1){
|
||||||
text-align: right;
|
margin-right: auto;
|
||||||
}
|
}
|
||||||
.rang{
|
.infoSemestre>div>div:nth-child(even){
|
||||||
text-decoration: underline var(--couleurIntense);
|
text-align: right;
|
||||||
}
|
}
|
||||||
.decision{
|
.rang{
|
||||||
margin: 5px 0;
|
text-decoration: underline var(--couleurIntense);
|
||||||
font-weight: bold;
|
}
|
||||||
font-size: 20px;
|
.decision{
|
||||||
text-decoration: underline var(--couleurIntense);
|
margin: 5px 0;
|
||||||
}
|
font-weight: bold;
|
||||||
.enteteSemestre{
|
font-size: 20px;
|
||||||
color: black;
|
text-decoration: underline var(--couleurIntense);
|
||||||
font-weight: bold;
|
}
|
||||||
font-size: 20px;
|
.enteteSemestre{
|
||||||
margin-bottom: 4px;
|
color: black;
|
||||||
}
|
font-weight: bold;
|
||||||
|
font-size: 20px;
|
||||||
/***************/
|
margin-bottom: 4px;
|
||||||
/* Synthèse */
|
}
|
||||||
/***************/
|
/***************/
|
||||||
.synthese .ue,
|
/* Zone custom */
|
||||||
.synthese h3{
|
/***************/
|
||||||
background: var(--couleurFondTitresUE);
|
.custom:empty{
|
||||||
}
|
display: none;
|
||||||
.synthese em,
|
}
|
||||||
.eval em{
|
|
||||||
opacity: 0.6;
|
/***************/
|
||||||
min-width: 80px;
|
/* Synthèse */
|
||||||
display: inline-block;
|
/***************/
|
||||||
}
|
.synthese .ue,
|
||||||
|
.synthese h3{
|
||||||
/***************/
|
background: var(--couleurFondTitresUE);
|
||||||
/* Evaluations */
|
}
|
||||||
/***************/
|
.synthese em,
|
||||||
.module, .ue {
|
.eval em{
|
||||||
background: var(--couleurSecondaire);
|
opacity: 0.6;
|
||||||
color: #000;
|
min-width: 80px;
|
||||||
padding: 4px 32px;
|
display: inline-block;
|
||||||
border-radius: 4px;
|
}
|
||||||
display: flex;
|
.ueBonus,
|
||||||
gap: 16px;
|
.ueBonus h3{
|
||||||
margin: 4px 0 2px 0;
|
background: var(--couleurFondTitresSAE) !important;
|
||||||
overflow-x: auto;
|
color: #000 !important;
|
||||||
overflow-y: hidden;
|
}
|
||||||
cursor: pointer;
|
|
||||||
position: relative;
|
/***************/
|
||||||
}
|
/* Evaluations */
|
||||||
.module::before, .ue::before {
|
/***************/
|
||||||
content:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='26px' height='26px' fill='black'><path d='M7.41,8.58L12,13.17L16.59,8.58L18,10L12,16L6,10L7.41,8.58Z' /></svg>");
|
.evaluations>div,
|
||||||
width: 26px;
|
.sae>div{
|
||||||
height: 26px;
|
scroll-margin-top: 60px;
|
||||||
position: absolute;
|
}
|
||||||
bottom: 0;
|
.module, .ue {
|
||||||
left: 50%;
|
background: var(--couleurSecondaire);
|
||||||
margin-left: -13px;
|
color: #000;
|
||||||
transform: rotate(180deg);
|
padding: 4px 32px;
|
||||||
transition: 0.2s;
|
border-radius: 4px;
|
||||||
}
|
display: flex;
|
||||||
h3{
|
gap: 16px;
|
||||||
display: flex;
|
margin: 4px 0 2px 0;
|
||||||
align-items: center;
|
overflow-x: auto;
|
||||||
margin: 0 auto 0 0;
|
overflow-y: hidden;
|
||||||
position: sticky;
|
cursor: pointer;
|
||||||
left: -32px;
|
position: relative;
|
||||||
z-index: 1;
|
}
|
||||||
font-size: 16px;
|
.module::before, .ue::before {
|
||||||
background: var(--couleurSecondaire);
|
content:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='26px' height='26px' fill='white'><path d='M7.41,8.58L12,13.17L16.59,8.58L18,10L12,16L6,10L7.41,8.58Z' /></svg>");
|
||||||
}
|
width: 26px;
|
||||||
.sae .module, .sae h3{
|
height: 26px;
|
||||||
background: var(--couleurFondTitresSAE);
|
position: absolute;
|
||||||
}
|
bottom: 0;
|
||||||
|
left: calc(50% - 13px);
|
||||||
.moyenne{
|
transform: rotate(180deg);
|
||||||
font-weight: bold;
|
transition: 0.2s;
|
||||||
text-align: right;
|
}
|
||||||
}
|
@media screen and (max-width: 1000px) {
|
||||||
.info{
|
/* Placer le chevron à gauche au lieu du milieu */
|
||||||
opacity: 0.9;
|
.module::before, .ue::before {
|
||||||
}
|
left: 2px;
|
||||||
.syntheseModule{
|
bottom: calc(50% - 13px);
|
||||||
cursor: pointer;
|
}
|
||||||
}
|
}
|
||||||
.eval, .syntheseModule{
|
h3{
|
||||||
position: relative;
|
display: flex;
|
||||||
display: flex;
|
align-items: center;
|
||||||
justify-content: space-between;
|
margin: 0 auto 0 0;
|
||||||
margin: 0 0 0 28px;
|
position: sticky;
|
||||||
padding: 0px 4px;
|
left: -32px;
|
||||||
border-bottom: 1px solid #aaa;
|
z-index: 1;
|
||||||
}
|
font-size: 16px;
|
||||||
.eval>div, .syntheseModule>div{
|
background: var(--couleurSecondaire);
|
||||||
display: flex;
|
}
|
||||||
gap: 4px;
|
.sae .module, .sae h3{
|
||||||
}
|
background: var(--couleurFondTitresSAE);
|
||||||
|
}
|
||||||
.eval:hover, .syntheseModule:hover{
|
|
||||||
background: var(--couleurSurlignage);
|
.moyenne{
|
||||||
/* color: #FFF; */
|
font-weight: bold;
|
||||||
}
|
text-align: right;
|
||||||
.complement{
|
}
|
||||||
pointer-events:none;
|
.info{
|
||||||
position: absolute;
|
opacity: 0.9;
|
||||||
bottom: 100%;
|
}
|
||||||
right: 0;
|
.syntheseModule{
|
||||||
padding: 8px;
|
cursor: pointer;
|
||||||
border-radius: 4px;
|
}
|
||||||
background: #FFF;
|
.eval, .syntheseModule{
|
||||||
color: #000;
|
position: relative;
|
||||||
border: 1px solid var(--couleurIntense);
|
display: flex;
|
||||||
opacity: 0;
|
justify-content: space-between;
|
||||||
display: grid !important;
|
margin: 0 0 0 28px;
|
||||||
grid-template-columns: auto auto;
|
padding: 0px 4px;
|
||||||
gap: 0 !important;
|
border-bottom: 1px solid #aaa;
|
||||||
column-gap: 4px !important;
|
}
|
||||||
}
|
.eval>div, .syntheseModule>div{
|
||||||
.eval:hover .complement{
|
display: flex;
|
||||||
opacity: 1;
|
gap: 4px;
|
||||||
z-index: 1;
|
}
|
||||||
}
|
|
||||||
.complement>div:nth-child(even){
|
.eval:hover, .syntheseModule:hover{
|
||||||
text-align: right;
|
background: var(--couleurSurlignage);
|
||||||
}
|
/* color: #FFF; */
|
||||||
.complement>div:nth-child(1),
|
}
|
||||||
.complement>div:nth-child(2){
|
.complement{
|
||||||
font-weight: bold;
|
pointer-events:none;
|
||||||
}
|
position: absolute;
|
||||||
.complement>div:nth-child(1),
|
bottom: 100%;
|
||||||
.complement>div:nth-child(7){
|
right: 0;
|
||||||
margin-bottom: 8px;
|
padding: 8px;
|
||||||
}
|
border-radius: 4px;
|
||||||
|
background: #FFF;
|
||||||
.absences{
|
color: #000;
|
||||||
display: grid;
|
border: 1px solid var(--couleurIntense);
|
||||||
grid-template-columns: auto auto;
|
opacity: 0;
|
||||||
column-gap: 4px;
|
display: grid !important;
|
||||||
text-align: right;
|
grid-template-columns: auto auto;
|
||||||
border-left: 1px solid;
|
gap: 0 !important;
|
||||||
padding-left: 16px;
|
column-gap: 4px !important;
|
||||||
}
|
}
|
||||||
.absences>div:nth-child(1),
|
.eval:hover .complement{
|
||||||
.absences>div:nth-child(2){
|
opacity: 1;
|
||||||
font-weight: bold;
|
z-index: 1;
|
||||||
}
|
}
|
||||||
|
.complement>div:nth-child(even){
|
||||||
|
text-align: right;
|
||||||
|
}
|
||||||
|
.complement>div:nth-child(1),
|
||||||
|
.complement>div:nth-child(2){
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
.complement>div:nth-child(1),
|
||||||
|
.complement>div:nth-child(7){
|
||||||
|
margin-bottom: 8px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*.absences{
|
||||||
|
display: grid;
|
||||||
|
grid-template-columns: auto auto;
|
||||||
|
column-gap: 4px;
|
||||||
|
text-align: right;
|
||||||
|
border-left: 1px solid;
|
||||||
|
padding-left: 16px;
|
||||||
|
}
|
||||||
|
.absences>div:nth-child(1),
|
||||||
|
.absences>div:nth-child(2){
|
||||||
|
font-weight: bold;
|
||||||
|
}*/
|
||||||
|
@ -15,13 +15,10 @@ class releveBUT extends HTMLElement {
|
|||||||
/* Style du module */
|
/* Style du module */
|
||||||
const styles = document.createElement('link');
|
const styles = document.createElement('link');
|
||||||
styles.setAttribute('rel', 'stylesheet');
|
styles.setAttribute('rel', 'stylesheet');
|
||||||
styles.setAttribute('href', '/ScoDoc/static/css/releve-but.css');
|
if (location.href.split("/")[3] == "ScoDoc") {
|
||||||
/* variante "ScoDoc" ou "Passerelle" (ENT) ? */
|
styles.setAttribute('href', '/ScoDoc/static/css/releve-but.css'); // Scodoc
|
||||||
if (location.href.split("/")[3] == "ScoDoc") { /* un peu osé... */
|
|
||||||
styles.setAttribute('href', '/ScoDoc/static/css/releve-but.css');
|
|
||||||
} else {
|
} else {
|
||||||
// Passerelle
|
styles.setAttribute('href', '/assets/styles/releve-but.css'); // Passerelle
|
||||||
styles.setAttribute('href', '/assets/styles/releve-but.css');
|
|
||||||
}
|
}
|
||||||
this.shadow.appendChild(styles);
|
this.shadow.appendChild(styles);
|
||||||
}
|
}
|
||||||
@ -49,6 +46,8 @@ class releveBUT extends HTMLElement {
|
|||||||
this.showSynthese(data);
|
this.showSynthese(data);
|
||||||
this.showEvaluations(data);
|
this.showEvaluations(data);
|
||||||
|
|
||||||
|
this.showCustom(data);
|
||||||
|
|
||||||
this.setOptions(data.options);
|
this.setOptions(data.options);
|
||||||
|
|
||||||
this.shadow.querySelectorAll(".CTA_Liste").forEach(e => {
|
this.shadow.querySelectorAll(".CTA_Liste").forEach(e => {
|
||||||
@ -57,7 +56,7 @@ class releveBUT extends HTMLElement {
|
|||||||
this.shadow.querySelectorAll(".ue, .module").forEach(e => {
|
this.shadow.querySelectorAll(".ue, .module").forEach(e => {
|
||||||
e.addEventListener("click", this.moduleOnOff)
|
e.addEventListener("click", this.moduleOnOff)
|
||||||
})
|
})
|
||||||
this.shadow.querySelectorAll(".syntheseModule").forEach(e => {
|
this.shadow.querySelectorAll(":not(.ueBonus)+.syntheseModule").forEach(e => {
|
||||||
e.addEventListener("click", this.goTo)
|
e.addEventListener("click", this.goTo)
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -77,6 +76,11 @@ class releveBUT extends HTMLElement {
|
|||||||
<div class=infoEtudiant></div>
|
<div class=infoEtudiant></div>
|
||||||
</section>
|
</section>
|
||||||
|
|
||||||
|
<!--------------------------------------------------------------------------------------->
|
||||||
|
<!-- Zone spéciale pour que les IUT puisse ajouter des infos locales sur la passerelle -->
|
||||||
|
<!--------------------------------------------------------------------------------------->
|
||||||
|
<section class=custom></section>
|
||||||
|
|
||||||
<!--------------------------->
|
<!--------------------------->
|
||||||
<!-- Semestre -->
|
<!-- Semestre -->
|
||||||
<!--------------------------->
|
<!--------------------------->
|
||||||
@ -169,8 +173,8 @@ class releveBUT extends HTMLElement {
|
|||||||
output += `
|
output += `
|
||||||
</div>
|
</div>
|
||||||
<div class=numerosEtudiant>
|
<div class=numerosEtudiant>
|
||||||
Numéro étudiant : ${data.etudiant.code_nip} -
|
Numéro étudiant : ${data.etudiant.code_nip || "~"} -
|
||||||
Code INE : ${data.etudiant.code_ine}
|
Code INE : ${data.etudiant.code_ine || "~"}
|
||||||
</div>
|
</div>
|
||||||
<div>${data.formation.titre}</div>
|
<div>${data.formation.titre}</div>
|
||||||
`;
|
`;
|
||||||
@ -183,6 +187,13 @@ class releveBUT extends HTMLElement {
|
|||||||
this.shadow.querySelector(".infoEtudiant").innerHTML = output;
|
this.shadow.querySelector(".infoEtudiant").innerHTML = output;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*******************************/
|
||||||
|
/* Affichage local */
|
||||||
|
/*******************************/
|
||||||
|
showCustom(data) {
|
||||||
|
this.shadow.querySelector(".custom").innerHTML = data.custom || "";
|
||||||
|
}
|
||||||
|
|
||||||
/*******************************/
|
/*******************************/
|
||||||
/* Information sur le semestre */
|
/* Information sur le semestre */
|
||||||
/*******************************/
|
/*******************************/
|
||||||
@ -196,6 +207,11 @@ class releveBUT extends HTMLElement {
|
|||||||
<div>Max. promo. :</div><div>${data.semestre.notes.max}</div>
|
<div>Max. promo. :</div><div>${data.semestre.notes.max}</div>
|
||||||
<div>Moy. promo. :</div><div>${data.semestre.notes.moy}</div>
|
<div>Moy. promo. :</div><div>${data.semestre.notes.moy}</div>
|
||||||
<div>Min. promo. :</div><div>${data.semestre.notes.min}</div>
|
<div>Min. promo. :</div><div>${data.semestre.notes.min}</div>
|
||||||
|
</div>
|
||||||
|
<div class=absencesRecap>
|
||||||
|
<div class=enteteSemestre>Absences</div>
|
||||||
|
<div class=enteteSemestre>N.J. ${data.semestre.absences?.injustifie ?? "-"}</div>
|
||||||
|
<div style="grid-column: 2">Total ${data.semestre.absences?.total ?? "-"}</div>
|
||||||
</div>`;
|
</div>`;
|
||||||
/*${data.semestre.groupes.map(groupe => {
|
/*${data.semestre.groupes.map(groupe => {
|
||||||
return `
|
return `
|
||||||
@ -210,7 +226,7 @@ class releveBUT extends HTMLElement {
|
|||||||
}).join("")
|
}).join("")
|
||||||
}*/
|
}*/
|
||||||
this.shadow.querySelector(".infoSemestre").innerHTML = output;
|
this.shadow.querySelector(".infoSemestre").innerHTML = output;
|
||||||
/*this.shadow.querySelector(".decision").innerHTML = data.semestre.decision.code;*/
|
this.shadow.querySelector(".decision").innerHTML = data.semestre.decision?.code || "";
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************/
|
/*******************************/
|
||||||
@ -219,32 +235,44 @@ class releveBUT extends HTMLElement {
|
|||||||
showSynthese(data) {
|
showSynthese(data) {
|
||||||
let output = ``;
|
let output = ``;
|
||||||
Object.entries(data.ues).forEach(([ue, dataUE]) => {
|
Object.entries(data.ues).forEach(([ue, dataUE]) => {
|
||||||
output += `
|
if (dataUE.type == 1) { // UE Sport / Bonus
|
||||||
|
output += `
|
||||||
<div>
|
<div>
|
||||||
<div class=ue>
|
<div class="ue ueBonus">
|
||||||
<h3>
|
<h3>Bonus</h3>
|
||||||
${(dataUE.competence) ? dataUE.competence + " - " : ""}${ue}
|
<div>${dataUE.bonus_description}</div>
|
||||||
</h3>
|
|
||||||
<div>
|
|
||||||
<div class=moyenne>Moyenne : ${dataUE.moyenne?.value || "-"}</div>
|
|
||||||
<div class=info>
|
|
||||||
Bonus : ${dataUE.bonus || 0} -
|
|
||||||
Malus : ${dataUE.malus || 0}
|
|
||||||
<span class=ects> -
|
|
||||||
ECTS : ${dataUE.ECTS.acquis} / ${dataUE.ECTS.total}
|
|
||||||
</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class=absences>
|
|
||||||
<div>Abs N.J.</div><div>${dataUE.absences?.injustifie || 0}</div>
|
|
||||||
<div>Total</div><div>${dataUE.absences?.total || 0}</div>
|
|
||||||
</div>
|
</div>
|
||||||
|
${this.ueSport(dataUE.modules)}
|
||||||
</div>
|
</div>
|
||||||
${this.synthese(data, dataUE.ressources)}
|
`;
|
||||||
${this.synthese(data, dataUE.saes)}
|
} else {
|
||||||
</div>
|
output += `
|
||||||
`;
|
<div>
|
||||||
|
<div class=ue>
|
||||||
|
<h3>
|
||||||
|
${ue}${(dataUE.competence) ? " - " + dataUE.competence : ""}
|
||||||
|
</h3>
|
||||||
|
<div>
|
||||||
|
<div class=moyenne>Moyenne : ${dataUE.moyenne?.value || "-"}</div>
|
||||||
|
<div class=info>
|
||||||
|
Bonus : ${dataUE.bonus || 0} -
|
||||||
|
Malus : ${dataUE.malus || 0}
|
||||||
|
<span class=ects> -
|
||||||
|
ECTS : ${dataUE.ECTS.acquis} / ${dataUE.ECTS.total}
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>`;
|
||||||
|
/*<div class=absences>
|
||||||
|
<div>Abs N.J.</div><div>${dataUE.absences?.injustifie || 0}</div>
|
||||||
|
<div>Total</div><div>${dataUE.absences?.total || 0}</div>
|
||||||
|
</div>*/
|
||||||
|
output += `
|
||||||
|
</div>
|
||||||
|
${this.synthese(data, dataUE.ressources)}
|
||||||
|
${this.synthese(data, dataUE.saes)}
|
||||||
|
</div>
|
||||||
|
`;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
this.shadow.querySelector(".synthese").innerHTML = output;
|
this.shadow.querySelector(".synthese").innerHTML = output;
|
||||||
}
|
}
|
||||||
@ -252,7 +280,7 @@ class releveBUT extends HTMLElement {
|
|||||||
let output = "";
|
let output = "";
|
||||||
Object.entries(modules).forEach(([module, dataModule]) => {
|
Object.entries(modules).forEach(([module, dataModule]) => {
|
||||||
let titre = data.ressources[module]?.titre || data.saes[module]?.titre;
|
let titre = data.ressources[module]?.titre || data.saes[module]?.titre;
|
||||||
let url = data.ressources[module]?.url || data.saes[module]?.url;
|
//let url = data.ressources[module]?.url || data.saes[module]?.url;
|
||||||
output += `
|
output += `
|
||||||
<div class=syntheseModule data-module="${module.replace(/[^a-zA-Z0-9]/g, "")}">
|
<div class=syntheseModule data-module="${module.replace(/[^a-zA-Z0-9]/g, "")}">
|
||||||
<div>${module} - ${titre}</div>
|
<div>${module} - ${titre}</div>
|
||||||
@ -265,6 +293,23 @@ class releveBUT extends HTMLElement {
|
|||||||
})
|
})
|
||||||
return output;
|
return output;
|
||||||
}
|
}
|
||||||
|
ueSport(modules) {
|
||||||
|
let output = "";
|
||||||
|
Object.values(modules).forEach((module) => {
|
||||||
|
Object.values(module.evaluations).forEach((evaluation) => {
|
||||||
|
output += `
|
||||||
|
<div class=syntheseModule>
|
||||||
|
<div>${module.titre} - ${evaluation.description}</div>
|
||||||
|
<div>
|
||||||
|
${evaluation.note.value ?? "-"}
|
||||||
|
<em>Coef. ${evaluation.coef}</em>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
`;
|
||||||
|
})
|
||||||
|
})
|
||||||
|
return output;
|
||||||
|
}
|
||||||
|
|
||||||
/*******************************/
|
/*******************************/
|
||||||
/* Evaluations */
|
/* Evaluations */
|
||||||
@ -305,7 +350,7 @@ class releveBUT extends HTMLElement {
|
|||||||
evaluations.forEach((evaluation) => {
|
evaluations.forEach((evaluation) => {
|
||||||
output += `
|
output += `
|
||||||
<div class=eval>
|
<div class=eval>
|
||||||
<div>${this.URL(evaluation.url, evaluation.description)}</div>
|
<div>${this.URL(evaluation.url, evaluation.description || "Évaluation")}</div>
|
||||||
<div>
|
<div>
|
||||||
${evaluation.note.value}
|
${evaluation.note.value}
|
||||||
<em>Coef. ${evaluation.coef}</em>
|
<em>Coef. ${evaluation.coef}</em>
|
||||||
@ -363,4 +408,4 @@ class releveBUT extends HTMLElement {
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
customElements.define('releve-but', releveBUT);
|
customElements.define('releve-but', releveBUT);
|
||||||
|
Loading…
Reference in New Issue
Block a user