From e9a025a5e0c21fd762c1a402a95f3e18cb5a559e Mon Sep 17 00:00:00 2001 From: xdrm-brackets Date: Tue, 20 Oct 2015 22:10:38 +0200 Subject: [PATCH] Commit 1 de @dev --- API.js | 77 ------- API.php | 99 --------- css/layout.css | 249 ++++++++++++----------- css/menu.css | 168 +++------------- index.php | 42 ++-- js/actionScript.js | 279 ++------------------------ js/pageManager.js | 237 ---------------------- js/shortcut.js | 145 ------------- manager/database.php | 18 -- manager/security.php | 76 ------- manager/user.php | 135 ------------- page/_JS/auth.js | 80 -------- page/_JS/groups.js | 43 ---- page/auth.php | 42 ---- page/career.php | 1 - page/groups.php | 145 ------------- page/home.php | 44 ---- page/marks.php | 1 - page/modules.php | 4 - page/semestre.php | 1 - page/settings.php | 1 - page/ue.php | 1 - src/input_icon/default.svg | 1 - src/input_icon/default_grayscale.svg | 59 ------ src/input_icon/password.svg | 49 ----- src/input_icon/password_grayscale.svg | 51 ----- src/input_icon/user.svg | 59 ------ src/input_icon/user_grayscale.svg | 61 ------ src/menu_icon/auth.svg | 53 ----- src/menu_icon/auth_grayscale.svg | 53 ----- src/menu_icon/groups.svg | 51 ----- src/menu_icon/groups_grayscale.svg | 51 ----- src/menu_icon/home.svg | 151 -------------- src/menu_icon/home_grayscale.svg | 151 -------------- src/menu_icon/marks.svg | 57 ------ src/menu_icon/marks_grayscale.svg | 58 ------ src/menu_icon/modules.svg | 71 ------- src/menu_icon/modules_grayscale.svg | 71 ------- src/menu_icon/settings.svg | 49 ----- src/menu_icon/settings_grayscale.svg | 49 ----- src/menu_icon/ue.svg | 53 ----- src/menu_icon/ue_grayscale.svg | 53 ----- src/userlist.json | 32 --- 43 files changed, 198 insertions(+), 2973 deletions(-) delete mode 100755 API.js delete mode 100755 API.php mode change 100755 => 100644 js/actionScript.js delete mode 100755 js/pageManager.js delete mode 100755 js/shortcut.js delete mode 100755 manager/database.php delete mode 100755 manager/security.php delete mode 100755 manager/user.php delete mode 100755 page/_JS/auth.js delete mode 100755 page/_JS/groups.js delete mode 100755 page/auth.php delete mode 100755 page/career.php delete mode 100755 page/groups.php delete mode 100755 page/home.php delete mode 100755 page/marks.php delete mode 100755 page/modules.php delete mode 100755 page/semestre.php delete mode 100755 page/settings.php delete mode 100755 page/ue.php delete mode 100755 src/input_icon/default.svg delete mode 100755 src/input_icon/default_grayscale.svg delete mode 100755 src/input_icon/password.svg delete mode 100755 src/input_icon/password_grayscale.svg delete mode 100755 src/input_icon/user.svg delete mode 100755 src/input_icon/user_grayscale.svg delete mode 100755 src/menu_icon/auth.svg delete mode 100755 src/menu_icon/auth_grayscale.svg delete mode 100755 src/menu_icon/groups.svg delete mode 100755 src/menu_icon/groups_grayscale.svg delete mode 100755 src/menu_icon/home.svg delete mode 100755 src/menu_icon/home_grayscale.svg delete mode 100755 src/menu_icon/marks.svg delete mode 100755 src/menu_icon/marks_grayscale.svg delete mode 100755 src/menu_icon/modules.svg delete mode 100755 src/menu_icon/modules_grayscale.svg delete mode 100755 src/menu_icon/settings.svg delete mode 100755 src/menu_icon/settings_grayscale.svg delete mode 100755 src/menu_icon/ue.svg delete mode 100755 src/menu_icon/ue_grayscale.svg delete mode 100755 src/userlist.json diff --git a/API.js b/API.js deleted file mode 100755 index d5b8def..0000000 --- a/API.js +++ /dev/null @@ -1,77 +0,0 @@ -/* classe API */ -function APIClass(){}; - -APIClass.prototype = { - xhr: [], // tableau d'objets pour les requêtes ajax - - - - /* transaction avec le serveur (API.php) - * - * @param pRequest l'objet passé en JSON à API.php - * @param pHandler fonction qui s'éxécutera lors de la réponse (1 argument -> réponse) - * - * @return answer l'objet retourné par API.php via pHandler (1er argument) - * - *************************************************************************************************** - * - * @usecase - * 1. var answerObject = sendRequest( - * 2. { var1: "exemple", var2: 198294 }, - * 3. function(rep){ alert(rep); } - * 4. ); - * @explain - * 1. on appelle la fonction <=> on créé la requête - * 2. on passe l'objet qui sera envoyé - * 3. on passe une fonction qui utilise un argument (sera la réponse de API.php) (sous forme d'objet) - * - */ - send: function(pRequest, pHandler){ - - // on efface les requêtes qui sont terminées (toutes celles de this.xhr) - for( var i = 0 ; i < this.xhr.length ; i++ ){ - if( this.xhr[i].readyState == 4 ) // si terminée - this.xhr = this.xhr.slice(0,i-1).concat(this.xhr.slice(i,this.xhr.length-1)); // suppression entrée - } - - // on créé une nouvelle entrée - this.xhr.push(null); - i = this.xhr.length-1; - - // création de l'objet AJAX - if(window.XMLHttpRequest) // IE7+, Firefox, Chrome, Opera, Safari - this.xhr[i] = new XMLHttpRequest(); - else // IE5, IE6 - this.xhr[i] = new ActiveXObject('Microsoft.XMLHttpRequest'); - - console.log(pRequest); - - var ptrAPI = this; - this.xhr[i].onreadystatechange = function(){ - if( ptrAPI.xhr[i].readyState == 4 ){ // si la requête est terminée - - /* DEBUG : affiche la réponse BRUTE de API.php */ - // console.log('API.php => '+ptrAPI.xhr[i].responseText); - console.log(JSON.parse(ptrAPI.xhr[i].responseText) ); - - /* si success de requête */ - if( [0,200].indexOf(ptrAPI.xhr[i].status) > -1 ){ // si fichier existe et reçu - try{ pHandler( JSON.parse(ptrAPI.xhr[i].responseText) ); } // si on peut parser, on envoie - catch(e){ pHandler({request:'corrupted'}); } // sinon on envoie obj.request = 'corrupted' - } - /* sinon retourne obj.request = 'unreachable' */ - else - pHandler({request: 'unreachable'}); - - } - } - - // on créé un formulaire POST (virtuel) - var form = new FormData(); - form.append('json', JSON.stringify(pRequest) ); // on créé la variable $_POST['json']=>request - - this.xhr[i].open('POST', 'API.php', true); - this.xhr[i].send( form ); - - } -}; diff --git a/API.php b/API.php deleted file mode 100755 index 08d527c..0000000 --- a/API.php +++ /dev/null @@ -1,99 +0,0 @@ -level_0 ){ - - /***************/ - /* UTILISATEUR */ - /***************/ - case 'user': - if( isset($request->level_1) ){ include 'manager/user.php'; user_switch_level_1($request, $answer); } - else { $answer->request = 'missing_level_1'; } - break; - - - /***********/ - /* GROUPES */ - /***********/ - case 'groups': - $answer->type = "group"; - break; - - - /******/ - /* UE */ - /******/ - case 'ues': - break; - - - /**********/ - /* MODULE */ - /**********/ - case 'modules': - break; - - - /************/ - /* CONTRÔLE */ - /************/ - case 'tests': - break; - - - /**************/ - /* PARAMETRES */ - /**************/ - case 'settings': - break; - - - /***********/ - /* DEFAULT */ - /***********/ - default: - $answer->request = 'unknown_level_0'; - break; - } - - - if( $answer == null ) - $answer->request = 'no_level_0'; - - - - }else // si json corrompu (undécodable) - $answer->request = 'jsoncorrupted'; - - }else // $_POST vide [OU] $_POST['json'] pas défini - $answer->request = 'nopost'; - - - // on envoie (affiche) l'objet en JSON - echo json_encode($answer); - - } - -?> \ No newline at end of file diff --git a/css/layout.css b/css/layout.css index 9a20ccf..9b23f06 100755 --- a/css/layout.css +++ b/css/layout.css @@ -3,9 +3,11 @@ * Positionnement global et mise en page * ------------------------------------- * 1. Propriétés globales -* 2. MENU -* 3. CONTAINER -* 4. msgBox +* 2. HEADER +* 3. MENU +* 4. AUTH(entification) +* 5. CONTAINER +* 6. msgBox * */ @@ -20,19 +22,20 @@ /*** 1. Propriétés globales ***/ /******************************/ *{ /* on supprime le margin/padding par défaut */ - margin : 0; + margin: 0; padding: 0; } +a{ text-decoration: none; color: inherit; } /* on initialise le body avec les valeurs par défaut [compatibilité] */ body{ /* position */ display: block; position: absolute; - top : 0; - left : 0; - width : 100%; + top: 0; + left: 0; + width: 100%; height: 100%; /* background */ @@ -42,8 +45,7 @@ body{ overflow-x: hidden; /* empêche la barre horizontale de scroll [précaution] */ /* foreground */ - font: 18px 'Lato', 'Helvetica', 'Arial', 'sans-serif'; - font-size: 16px; + font: 16px 'Open Sans', 'Helvetica Neue', 'Arial', 'sans-serif'; } @@ -52,138 +54,149 @@ body{ -/***************/ -/*** 2. MENU ***/ -/***************/ -#MENU{ +/*****************/ +/*** 2. HEADER ***/ +/*****************/ +#HEADER{ /* position */ display: flex; + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 48px; + + /* flex (as container) */ + flex-direction: row; + flex-wrap: nowrap; + justify-content: space-between; + + /* background */ + background: #1d1d1d; + + /* foreground */ + font-size: 12px; +} + + + + + +/***************/ +/*** 3. MENU ***/ +/***************/ +#HEADER #MENU{ + /* position */ + display: flex; + height: 100%; + + /* flex (as container) */ + flex-direction: row; + flex-wrap: nowrap; + justify-content: space-between; + +} + + + +/***************/ +/*** 4. AUTH ***/ +/***************/ +#AUTH_FILTER{ + /* position */ + /*display: block;*/ display: none; position: fixed; - top : 0; - left : 0; - width : 5.5em; + top: 0; + left: 0; + width: 100%; height: 100%; - /* flex */ - flex-direction : column; - justify-content: flex-start; - flex-wrap: nowrap; /* default, une seule colonne */ - - /* background */ - /*background: #424c54 url(https://www.iut-tlse3.fr/static/ui/v1/icons/iut/iut.png) bottom .9em center no-repeat;*/ - background: #424c54; - - /* foreground */ - /*font-size: 1.7vh;*/ + background: rgba(0,0,0,.2); /* z axis */ - z-index: 2; - - /* list */ - list-style-type: none; + z-index: 100; } +#AUTH_FILTER.active{ display: block; } - - - -/********************/ -/*** 3. CONTAINER ***/ -/********************/ -#CONTAINER{ +#AUTH{ /* position */ - display: block; - position: absolute; - top : 0; - left : 5.5em; - width : calc( 100% - 5.5em ); - min-height: 100%; - - /* background */ - background: #fff; - - /* foreground */ - /*font-size: 1.7vh;*/ - - /* border < inherit < hgroup */ - border-color: #fff; - - /* z axis */ - z-index: 0; -} - - -/*****************/ -/*** 4. MSGBOX ***/ -/*****************/ -#MSGBOX{ - /* position */ - display: block; + /*display: block;*/ display: none; position: fixed; - top: calc( 100% - 2*1em - 1em - 1em ); /* 100% - padding - taille - marge */ - left: 30%; - width: 40%; - height: 1em; - padding: 1em; + top: 30%; + left: calc( 50% - 500px/2 ); + width: 500px; + + /* z axis */ + z-index: 101; +} + +#AUTH_FILTER.active + #AUTH{ display: block; } + +/* tout les INPUT */ +#AUTH input{ + /* position */ + display: block; + position: relative; + top: 0; + left: 25%; + width: calc( 50% - 2*.8em ); + margin-bottom: 2em; + padding: .8em; /* border */ - border-radius: 3px; - border: 1px solid transparent; + border-radius: 5px; + border: 1px solid #A1A1A1; + + /* foreground */ + font-family: inherit; + + transition: .2s ease-in-out; + -moz-transition: .2s ease-in-out; + -webkit-transition: .2s ease-in-out; + -ms-transition: .2s ease-in-out; + -o-transition: .2s ease-in-out; +} + +/* INPUT text/password */ +#AUTH input[type=text]:focus, +#AUTH input[type=password]:focus{ + border-color: #21a4a8; + box-shadow: 0 0 3px #2bccd4; +} + +/* SUBMIT */ +#AUTH input[type=submit]{ + /* position */ + width: 50%; - /* background */ - background-color: #f64b2f; - /* foreground */ color: #fff; - text-shadow: 1px 1px 1px #d33e27; - line-height: 1em; + font-weight: bold; - transition: all 0s ease 0s, top .3s ease-in-out; - -moz-transition: all 0s ease 0s, top .3s ease-in-out; - -webkit-transition: all 0s ease 0s, top .3s ease-in-out; - -ms-transition: all 0s ease 0s, top .3s ease-in-out; - -o-transition: all 0s ease 0s, top .3s ease-in-out; + /* background */ + background-color: #279cea; + + /* xTra */ + cursor: pointer; } -/* LES DIFFERENTES CLASSES */ - -/* validation ou réussite */ -#MSGBOX.success{ - border-color: #689525; - background-color: #7eb62e; - text-shadow: 1px 1px 1px #689525; +#AUTH input[type=submit]:hover{ + background-color: #2494de; } -/* information */ -#MSGBOX.info{ - border-color: #278fd0; - background-color: #2fa9f6; - text-shadow: 1px 1px 1px #278fd0; + + +/********************/ +/*** 5. CONTAINER ***/ +/********************/ +#CONTAINER{ } -/* avertissement */ -#MSGBOX.warning{ - border-color: #d87620; - background-color: #f68725; - text-shadow: 1px 1px 1px #d87620; + +/*****************/ +/*** 6. MSGBOX ***/ +/*****************/ +#MSGBOX{ } - -/* notice */ -#MSGBOX.error{ - border-color: #d33e27; - background-color: #f64b2f; - text-shadow: 1px 1px 1px #d33e27; -} - -/* LORSQUE PAS ACTIVE */ -#MSGBOX:not( [class] ), /* si n'a pas de classe */ -#MSGBOX[class='']{ /* ou qu'elle est vide */ - top: 100%; - - transition: all 0s ease .3s, top .3s ease-in-out; - -moz-transition: all 0s ease .3s, top .3s ease-in-out; - -webkit-transition: all 0s ease .3s, top .3s ease-in-out; - -ms-transition: all 0s ease .3s, top .3s ease-in-out; - -o-transition: all 0s ease .3s, top .3s ease-in-out; -} \ No newline at end of file diff --git a/css/menu.css b/css/menu.css index 1307ee8..aded677 100755 --- a/css/menu.css +++ b/css/menu.css @@ -1,4 +1,4 @@ - +/* * * Gestion complète du MENU * ------------------------------------- @@ -15,156 +15,36 @@ /*******************************************/ /*** 1. Propriétés complémentaires #MENU ***/ /*******************************************/ -#MENU{} - - - -/**************************/ -/*** 2. Position textes ***/ -/**************************/ -#MENU li{ - /* position */ - display: block; - position: relative; - margin: .75em; - width: 4em; /* 5.5 - 1.5 */ - height: 4em; - - /* border */ - border-radius: .3em; - - /* background */ - background: center center no-repeat; - background-size: auto 2.2em; - - /* Xtra */ - cursor: pointer; - -webkit-touch-callout: none; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; - - /* animation */ - transition: all 0s, background-color .2s ease-in-out; - -moz-transition: all 0s, background-color .2s ease-in-out; - -webkit-transition: all 0s, background-color .2s ease-in-out; - -ms-transition: all 0s, background-color .2s ease-in-out; - -o-transition: all 0s, background-color .2s ease-in-out; -} - - - -/*****************/ -/*** 3. Icônes ***/ -/*****************/ -/* dernier en bas */ -#MENU li:last-child{ align-self: flex-start; } - -/* icônes de base */ -#MENU li[data-link='home'] { background-image: url(../src/menu_icon/home_grayscale.svg); } -#MENU li[data-link='groups'] { background-image: url(../src/menu_icon/groups_grayscale.svg); } -#MENU li[data-link='ue'] { background-image: url(../src/menu_icon/ue_grayscale.svg); } -#MENU li[data-link='modules'] { background-image: url(../src/menu_icon/modules_grayscale.svg); } -#MENU li[data-link='marks'] { background-image: url(../src/menu_icon/marks_grayscale.svg); } -#MENU li[data-link='settings'] { background-image: url(../src/menu_icon/settings_grayscale.svg); } -#MENU li[data-link='auth'] { background-image: url(../src/menu_icon/auth_grayscale.svg); } - -/* HOVER ou active (page courante) */ -#MENU li:hover, #MENU li.active{ - color: #fff; - background-color: rgba(0,0,0,.3); -} - -/* icône quand HOVER ou .active */ -#MENU li[data-link='home']:hover , #MENU li[data-link='home'].active { background-image: url(../src/menu_icon/home.svg); } -#MENU li[data-link='groups']:hover , #MENU li[data-link='groups'].active { background-image: url(../src/menu_icon/groups.svg); } -#MENU li[data-link='ue']:hover , #MENU li[data-link='ue'].active { background-image: url(../src/menu_icon/ue.svg); } -#MENU li[data-link='modules']:hover , #MENU li[data-link='modules'].active { background-image: url(../src/menu_icon/modules.svg); } -#MENU li[data-link='marks']:hover , #MENU li[data-link='marks'].active { background-image: url(../src/menu_icon/marks.svg); } -#MENU li[data-link='settings']:hover , #MENU li[data-link='settings'].active { background-image: url(../src/menu_icon/settings.svg); } -#MENU li[data-link='auth']:hover , #MENU li[data-link='auth'].active { background-image: url(../src/menu_icon/auth.svg); } - - -/* le séparateur qui remplit l'espace entre le haut et le bas */ -#MENU li.fill{ - flex-grow: 1; - opacity: 0; - cursor: default; -} - - - -/*****************/ -/*** 4. Labels ***/ -/*****************/ -#MENU li[data-text]::before{ /* affichage du texte */ - content: attr(data-text); - +#HEADER #MENU a, +#HEADER a{ /* position */ display: block; - position: absolute; - top: .4em; - left: 6em; - width: auto; - width: 0; - height: 3em; - padding: 0 0; + position: relative; + padding: 0 1em; /* border */ - border-radius: 5px; - - /* background */ - background: #232323; + border-bottom: 3px solid transparent; /* foreground */ - line-height: 3em; + color: #fff; + line-height: 48px; + text-transform: uppercase; + letter-spacing: 1px; - /* animation */ - transition: .1s ease-out; - -moz-transition: .1s ease-out; - -webkit-transition: .1s ease-out; - -ms-transition: .1s ease-out; - -o-transition: .1s ease-out; - - /* overflow */ - overflow: hidden; - - /* z axis */ - z-index: -1; + /* xTra */ + cursor: pointer; } +#HEADER #MENU a:nth-child(1):hover, +#HEADER a:hover{ background-color: #6c336d; } +#HEADER #MENU a:nth-child(2):hover{ background-color: #6eab2e; } +#HEADER #MENU a:nth-child(3):hover{ background-color: #f98012; } +#HEADER #MENU a:nth-child(4):hover{ background-color: #999999; } +#HEADER #MENU a:nth-child(5):hover{ background-color: #DD9F22; } +#HEADER #MENU a:nth-child(6):hover{ background-color: #4653b4; } +#HEADER #MENU a:nth-child(7):hover{ background-color: #a62a3e; } +#HEADER #MENU a:nth-child(8):hover{ background-color: #fb4b28; } - -#MENU li[data-text]::after{ /* petite flèche */ - content: ''; - - /* position */ - display: none; - position: absolute; - top: 1.16em; - left: 5.7em; - - /* border */ - border-style: solid; - border-width: .8em .8em .8em 0; - border-color: transparent #232323 transparent transparent; - - /* animation */ - transition: .2s ease-in; - -moz-transition: .2s ease-in; - -webkit-transition: .2s ease-in; - -ms-transition: .2s ease-in; - -o-transition: .2s ease-in; - - /* z axis */ - z-index: -1; -} - - - -/* lors du survol */ - -#MENU li[data-text]:hover::before{ width: auto; left: 6em; padding: 0 1em; } /* affichage du texte */ - -#MENU li[data-text]:hover::after{ display: block; } /* affichage de la petite flèche \ No newline at end of file +/***********************/ +/* 2. Authentification */ +/***********************/ diff --git a/index.php b/index.php index e5d0afd..9db9c62 100755 --- a/index.php +++ b/index.php @@ -1,4 +1,4 @@ - - - + - - - @@ -40,20 +36,32 @@ - - + Authentification + + + +
+
+ + + +
diff --git a/js/actionScript.js b/js/actionScript.js old mode 100755 new mode 100644 index 723d7b0..b40b213 --- a/js/actionScript.js +++ b/js/actionScript.js @@ -1,264 +1,21 @@ - - /*********************************************************** - * * - * SCRIPT POST-HTML - SCRIPT PRINCIPAL * - * * - ************************************************************ - * * - * [0] Variables * - * [1] Gestionnaires de navigation * - * [a] pageManager.js * - * [b] API.js * - * [2] Gestion des liens * - * [a] catégories * - * [b] sous-parties * - * [3] Gestion des formulaires * - * [4] Gestion de la messageBox * - * * - * * - * * - * * - * * - * * - * * - * * - * * - ***********************************************************/ - - -/* [0] VARIABLES -==============================================================*/ -var msgBoxTimeout = null; - -/* pageManager */ -var pageM; -/* API */ -var API; - -/* Structure de la page */ +/* VARIABLES */ var DOM = { - menu : document.getElementById('MENU'), - container : document.getElementById('CONTAINER'), - msgBox : document.getElementById('MSGBOX') + header : document.querySelector('#HEADER'), + menu : document.querySelector('#MENU'), + authBtn : document.querySelector('#HEADER > a:last-child'), + loginForm : document.querySelector('#AUTH'), + loginFltr : document.querySelector('#AUTH_FILTER'), + container : document.querySelector('#CONTAINER') }; - - - - - - -/* [1] GESTIONNAIRES DE NAVIGATION -==============================================================*/ - - - /* [a] pageManager.js - ==============================================================*/ - pageM = new pageManager(); // instance principale - - /* initialisation du gestionnaire */ - pageM.setPage(null, 'page', DOM.container, ['home', 'groups', 'ue', 'modules', 'marks', 'auth', 'settings'] ); - - - /* [b] API.js - ==============================================================*/ - API = new APIClass(); - - - - - - - -/* [2] GESTION DES LIENS -==============================================================*/ - - - /* [a] CATÉGORIES - ==============================================================*/ - /* GESTION DES CATEGORIES (SECTIONS) - * - * @param section l'élément à activer - * - * [1] selectionne l'élément, l'affichage de la page associée est géré par pageManager.js - * [2] déselectionne l'élément précédemment selectioné - * - */ - function selectSection(section){ - - // si @subSection est un de type
  • qui a la propriété "data-link" [ET] section pas déjà active - if( section instanceof Element && section.tagName == 'LI' && section.dataset.hasOwnProperty('link') && section.className != 'active' ){ - - // on charge la page - pageM.setPage( section.dataset.link ); - - // on récupère la section déja selectionnée si elle existe - var last = document.querySelector('#MENU li.active'); - - if( last != null ) // si une section est déjà activée - last.className = ''; // on désactive la courante - - section.className = 'active'; // on active @section - - }else // sinon on affiche l'erreur - console.log("[selectSection_Error] - ("+section+")"); - - } - - /* activation au chargement en fonction de la page courante de pageManager.js */ - lastSection = document.querySelector('[data-link='+pageM.page+']'); - lastSection.className = 'active'; // on l'active - - /* Gestion des liens du menu */ - DOM.menu.addEventListener('click', function(e){ selectSection( e.target ); }, false); - - - /* [b] SOUS-PARTIES - ==============================================================*/ - /* GESTION DES SOUS-PARTIES (SOUS-CATÉGORIES) - * - * @param subSection l'élément à activer - * - * [1] selectionne l'élément, l'affichage de la page associée est géré en CSS3 - * [2] déselectionne l'élément précédemment selectioné - * - */ - function selectSubSection(subSection){ - - // si @subSection est un de type HGROUP [ET] - if( subSection instanceof Element && subSection.tagName == 'HGROUP' ){ - - if( subSection.className != 'active' ){ // si @subSection pas déjà active - - // on récupère la sous-partie selectionnée en cours - var last = document.querySelector('hgroup.active'); - - if( last != null ) // si un sous-partie est déjà selectionnée - last.className = ''; // on la désactive - - subSection.className = 'active'; // on active @subSection - - }else // sinon on affiche l'erreur - console.log("[selectSubSection_Error] - ("+subSection+")"); - - } - - } - - /* gestion du clic sur les sous-parties */ - DOM.container.addEventListener('click', function(e){ selectSubSection(e.target); }, false); - - - - - - - - -/* [3] GESTION DES FORMULAIRES -==============================================================*/ -/* INITIALISE UN FORMULAIRE POUR QU'IL INTERPRETE UN OBJET LORS DE SA SOUMISSIONS -* -* @param pForm le formulaire cible -* @param pHandler fonction exécutée lors de la soumission du formulaire -* -* [1] parcourt les élements du formulaire @pForm et active un évènement lors du "submit" -* [2] retourne l'objet à @pHandler lors du "submit" -* -* -* @example -* -*
    -* -* -* -* -* -* -*
    -* -* @explaination -* -* Lors du clic sur le bouton [VALIDER], la fonction @pHandler s'exécutera avec pour paramètre un objet -* OBJ{ id: nomFormulaire, nomDuChamp1: valeurDuChamp1, nomDuChamp2: valeurDuChamp2 } -* -*/ -function initForm(pForm, pHandler){ - - // vérification des arguments - var isForm = pForm instanceof Element && pForm.tagName == 'FORM'; - var isFunc = pHandler instanceof Function; - - // si les arguments sont corrects - if( pForm instanceof Element && pForm.tagName == 'FORM' ){ - - var submitButton = null; // contiendra le bouton d'envoi du formulaire - - for( var i = 0 ; i < pForm.children.length ; i++ ) - if( pForm.children[i].type == 'button' && pForm.children[i].name == 'submit' ){ - submitButton = pForm.children[i]; // on définit le bouton - break; // on sort du for - } - - - // on définit l'évènement de validation du formulaie - function submitEvent(){ - - var obj = {} // on créé l'objet qui va être envoyé - - for( var i = 0 ; i < pForm.children.length ; i++ ) // on parcourt les enfants - if( pForm.children[i].tagName == 'INPUT' && pForm.children[i].name != 'submit' ) // si c'est un champ et que c'est pas le bouton - obj[pForm.children[i].name] = pForm.children[i].value; // alors on enregistre le champ dans l'objet - - // on exécute la fonction @pHandler en lui envoyant les arguments - pHandler(obj); - - } - - // on définit l'évènement du clic sur le bouton - submitButton.addEventListener('click', function(e){ - submitEvent(e.target.parentNode); // on envoie le formulaire - }, false); - - // on définit l'évènement de l'appui sur la touche [ENTRER] - pForm.addEventListener('keydown', function(e){ - if(e.keyCode==13) submitEvent(e.target); // si c'est la bonne touche, on submit le formulaire - }, false); - - - - }else - console.log('[initForm_Error] - ('+pForm+', '+pHandler+')'); - - -} - - - - - - - -/* [4] GESTION DE LA MESSAGEBOX -==============================================================*/ -function messageBox(message, type){ - - /* on affecte le message */ - DOM.msgBox.innerHTML = message; - - /* on définit le style s'il est correct */ - if( ['success', 'info', 'warning', 'error'].indexOf(type) > -1 ) - DOM.msgBox.className = type; - else - DOM.msgBox.className = 'info'; - - - - if( msgBoxTimeout != null ) // si une autre message box est en cours, on arrête son timeout - clearTimeout(msgBoxTimeout); - - msgBoxTimeout = setTimeout( function(){ - DOM.msgBox.className = ''; - }, 2000); - -} \ No newline at end of file +/* GESTION DE L'AFFICHAGE DU LOGIN */ +DOM.authBtn.addEventListener('click', function(e){ // clic sur "Authentification" + e.preventDefault(); // désactive l'action par défaut + DOM.loginFltr.className = 'active'; +}, false); + +/* GESTION DE CACHAGE DU LOGIN */ +DOM.loginFltr.addEventListener('click', function(e){ + e.preventDefault(); // désactive l'action par défaut + DOM.loginFltr.className = ''; +}, false); \ No newline at end of file diff --git a/js/pageManager.js b/js/pageManager.js deleted file mode 100755 index 44ce627..0000000 --- a/js/pageManager.js +++ /dev/null @@ -1,237 +0,0 @@ -function pageManager(){}; - -var ptrPageManager; // pointeur global pour l'utilisation de fonctions de fonctions - -pageManager.prototype = { - depJS: null, // la dépendance javascript - depCSS: null, // la dépendance css - xhr: [], // tableau d'objets pour les requêtes ajax - page: null, // l'indice de la page courante dans pagelist - vars: [], // les variables suivant le nom de la page dans l'URL - path: '', // le chemin du dossier contenant les pages (.php) - pagelist: null, // la liste des pages pouvant être chargées - container: null, // élément DOM qui contiendra le contenu des pages à charger - /* ======================================================================= - Cette fonction effectue une requête Ajax (compatible à partir de IE5) - PARAMETRES: - - pLink le lien à charger - - pHandler une fonction qui s'éxécutera avec la réponse de la requête passée en paramètre (voir exemples dessous pour pHandler) - - pMethod type de méthode, vaut 'POST' ou 'GET' et vaut 'POST' par défaut ou s'il n'est pas renseigné - - pForm formulaire de type FormData() contenant les données à envoyer (uniquement en POST), si pForm vaut GET les données doivent être passées dans l'URL - ========================================================================== */ - ajax: function(pLink, pHandler, pMethod, pForm){ - // on efface les requêtes qui sont terminées et on push une nouvelle - for( var i = 0 ; i < this.xhr.length ; i++ ){ - if( this.xhr[i].readyState == 4 ) // si terminée - this.xhr = this.xhr.slice(0,i-1).concat(this.xhr.slice(i,this.xhr.length-1)); // suppression entrée - } - - this.xhr.push(true); - i = this.xhr.length-1; - - if(window.XMLHttpRequest) // IE7+, Firefox, Chrome, Opera, Safari - this.xhr[i] = new XMLHttpRequest(); - else // IE5, IE6 - this.xhr[i] = new ActiveXObject('Microsoft.XMLHttpRequest'); - - var ptrPageManager = this; - this.xhr[i].onreadystatechange = function(){ - if( ptrPageManager.xhr[i].readyState == 4 ) // si la requête est terminée - if( [0,200].indexOf(ptrPageManager.xhr[i].status) > -1 ) // si fichier existe et reçu - pHandler(ptrPageManager.xhr[i].responseText); - else // si code d'erreur retourne null - pHandler(); - } - - // gestion de la méthode - var method = ( typeof pMethod == 'string' && /^POST|GET$/i.test(pMethod) ) ? pMethod.toUpperCase() : 'POST'; - - // gestion du formulaire si la méthode est POST - var form = ( method == 'POST' && typeof pForm == 'object' && pForm instanceof FormData ) ? pForm : null; - - this.xhr[i].open( method, pLink, true); - this.xhr[i].send( form ); - }, - /***************************************************** [APPLICATION] Ajax() ******************************************************/ - // EXEMPLES DE FONCTIONS POUR pHandler // - // 1. var a = function(param){ alert(param); } // les deux notations 1 et 2 sont équivalents - // 2. function a(param){ alert(param); } // les deux notations 1 et 2 sont équivalents - - // ajax( 'index.php', a ); // utilisation d'une fonction définie - - // ajax( 'index.php', alert ); // utilisation d'une fonction prédéfinie - // ajax( 'index.php', alert, 'GET' ); // utilisation de méthode - - // var fd = new FormData(); // création d'un formulaire - // fd.append('var', 100); // ajout de la variable VAR qui vaut 100 - - // ajax( 'index.php', alert, null, fd ); // saut de paramètre avec null + envoi formulaire - // ajax( 'index.php?var=10', alert, 'GET' ); // envoi formulaire en GET (dans l'url) - // ajax( 'index.php?var=10', alert, 'POST', fd ); // envoi formulaire en GET (dans l'url) + en POST via le formulaire FD - - - /* ======================================================================= - Cette fonction effectue une décomposition de l'URL sur le shéma spécifié dessous - Renvoie pour http://www.exemple.com/dirA/dirB/#/NOMPAGE/VARPAGE - - null si la page n'est pas référencée dans le tableau PAGELIST - - null si le lien ne contient pas /#/NOMPAGE à la fin - - null si NOMPAGE ne contient pas uniquement : lettres, chiffres, underscore - - null si VARPAGE ne contient pas uniquement : lettres, chiffres, underscore - - un objet contenant {page: valeur, var: valeur} - ========================================================================== */ - explodeURL: function(url_data){ - url_data = (arguments.length >= 1) ? url_data : document.URL; - // si pageList est correct et que l'URL correspond à un schéma de page => continue [sinon] return null - if( this.pagelist != null && /^(?:.+)\/#\/([a-z0-9_]+)\/?(?:\/((?:[a-z0-9_]+\/)+)\/?)?$/i.test(url_data) ){ - // si la page récupérée dans l'url est dans la liste => renvoi de l'objet [sinon] null - var vars = RegExp.$2.split('/'); - while( vars[vars.length-1] == '' ) // on supprime les dernières entrées vides - vars.pop(); - - return ( this.pagelist.indexOf(RegExp.$1) > -1 ) ? {page: RegExp.$1, var: vars} : null; - }else - return null; - }, - /* ======================================================================= - Cette fonction ajoute des dépendances (un js et un css) situés dans le répertoire des pages. - pageDir/ - _JS/ - page1.js - page2.js - _CSS/ - page1.css - page2.css - ========================================================================== */ - loadDependencies: function(){ - // si depCSS est un élément du DOM c'est à dire qu'il contient le fichier de la page précédente et qu'il est enfant de , on le détruit - if( typeof this.depCSS == 'object' && this.depCSS instanceof Element && this.depCSS.parentNode == document.head ) - document.head.removeChild( this.depCSS ); - - // si depJS est un élément du DOM c'est à dire qu'il contient le fichier de la page précédente, on le détruit - if( typeof this.depJS == 'object' && this.depJS instanceof Element && this.depJS.parentNode == document.head ) - document.head.removeChild( this.depJS ); - - ptrPageManager = this; - // si le fichier css existe - this.ajax(this.path+'/'+'_CSS'+'/'+this.page+'.css', function(e){ - if( e != null ){ // on charge la dépendance CSS si le fichier existe - ptrPageManager.depCSS = document.createElement('link'); - ptrPageManager.depCSS.rel = 'stylesheet'; - ptrPageManager.depCSS.type = 'text/css'; - ptrPageManager.depCSS.href = ptrPageManager.path+'/'+'_CSS'+'/'+ptrPageManager.page+'.css'; - document.head.appendChild(ptrPageManager.depCSS); - }else - console.log('[loadDependencies_Error] - ('+ptrPageManager.path+'/'+'_CSS'+'/'+ptrPageManager.page+'.css'+')'); - }); - - // si le fichier js existe - this.ajax(this.path+'/'+'_JS'+'/'+this.page+'.js', function(e){ - if( e != null ){ // on charge la dépendance JS si le fichier existe - ptrPageManager.depJS = document.createElement('script'); - ptrPageManager.depJS.type = 'text/javascript'; - ptrPageManager.depJS.src = ptrPageManager.path+'/'+'_JS'+'/'+ptrPageManager.page+'.js'; - document.head.appendChild(ptrPageManager.depJS); - }else - console.log('[loadDependencies_Error] - ('+ptrPageManager.path+'/'+'_JS'+'/'+ptrPageManager.page+'.js'+')'); - }); - }, - - /* ======================================================================= - Cette fonction est celle qui gère les 2 autres et celle que l'utilisateur utilisera - PARAMETRES: - - pName le nom de la page à charger (lettres, chiffres, underscore) (*) - - pPath chemin (relatif ou absolu) du dossier contenant les pages de même nom de fichier que le nom (extension .php) - - pContainer l'élément du DOM qui contiendra la page chargée (**) - - pPageList> tableau contenant la liste des pages sous forme de chaînes de caractères (**) (***) - * Le chemin du dossier sans le '/' final si c'est le dossier actuel le chemin est une chaîne vide - Si le dossier est 'page' et que l'on cherche la page 'accUe1l', la requête sera vers 'page/accUe1l.php' - le nom de la page est sensible à la casse - ** 1. pPageList et pContainer doivent être mis en paramètres uniquement à la première utilisation - et la première utilisation doit se faire au chargement de la page car elle permetra - de mettre l'URL à jour et/ou charger la page de l'URL - *** la première page du tableau est la page par défaut (qui est chargée si l'URL ne contient - pas la page ou si la page de l'URL ne correspond à aucune page de la liste) - ========================================================================== */ - setPage: function(pName, pPath, pContainer, pPageList){ - - // liste de pages si c'est un tableau - var pageList = ( typeof pPageList == 'object' && pPageList instanceof Array ) ? pPageList : null; // si this.pagelist n'est pas overwrite il vaut null - - if( pageList != null ){ // si c'est un tableau - for( var i = 0 ; i < pageList.length ; i++ ){ // on parcourt tout les éléments pour vérifier que chaque élément ne contient que : lettres, chiffres, underscore [non]> pageList = null - pageList = ( typeof pageList[i] == 'string' && /^[a-z0-9_]+$/i.test(pageList[i]) ) ? pageList : null; - if( pageList == null ) break; // si le tableau est null stoppe la boucle - } - } - /* on attribue la variable temporaire pageList à l'attribut de l'objet si la variable pageList temporaire n'est pas nulle */ - this.pagelist = ( pageList != null ) ? pageList : this.pagelist; - // affecte à l'attribut page la page par défaut (premier élément de pagelist) - this.page = this.pagelist[0]; - // affecte pPath à l'attribut path s'il est renseigné - this.path = ( typeof pPath == 'string' ) ? pPath : this.path; - /* on attribue le paramètre pContainer à l'attribut si il est spécifié */ - this.container = ( typeof pContainer == 'object' && pContainer instanceof Element ) ? pContainer : this.container; - - // si this.pagelist && this.container ne sont pas null && - if( this.pagelist != null && this.container != null ){ - // si le pName est renseigné et qu'il est dans pagelist - if( typeof pName == 'string' && this.pagelist.indexOf(pName) > -1 ){ - // affecte pName à l'attribut page - this.page = pName; - - // charge le contenu de la page dans le container - var ptrPageManager = this; - - // formulaire POST - var fd = new FormData(); - for( var i = 0 ; i < this.vars.length ; i++ ) - fd.append(this.vars[i], null); - - this.ajax(this.path+'/'+this.page+'.php', function(e){ - ptrPageManager.container.innerHTML = e; - ptrPageManager.loadDependencies(); - }, 'POST', fd); - - // change l'URL en conséquences(stateObj, titre, url) - if( this.vars.length > 0 ) // si il y a des variables - window.history.pushState(null, this.page, '#/'+this.page+'/'+this.vars.join('/')+'/'); - else // s'il n'y en a pas - window.history.pushState(null, this.page, '#/'+this.page+'/'); - - }else{ // si la page n'est pas spécifiée ou qu'elle n'est pas dans la liste des pages - var urlGet = this.explodeURL(); - - // si on a récupéré le numéro de la page dans l'URL et qu'elle fait partie de la liste des pages - if( urlGet != null ){ - this.page = urlGet.page; - // charge le contenu de la page dans le container - var ptrThis = this; - - // formulaire POST - var fd = new FormData(); - this.vars.length = 0; - - for( var i = 0 ; i < urlGet.var.length ; i++ ){ // replacing object variables with explodeURL variables - this.vars[i] = urlGet.var[i]; - fd.append(this.vars[i], null); - } - - this.ajax(this.path+'/'+this.page+'.php', function(e){ - ptrThis.container.innerHTML = e; - ptrThis.loadDependencies(); - }, 'POST', fd); - - // change l'URL en conséquences(stateObj, titre, url) - if( this.vars.length > 0 ) // si il y a des variables - window.history.pushState(null, this.page, '#/'+this.page+'/'+this.vars.join('/')+'/'); - else // s'il n'y en a pas - window.history.pushState(null, this.page, '#/'+this.page+'/'); - - }else // si l'url ne contient rien, on charge la page par défaut - this.setPage(this.pagelist[0]); - } - }else - console.log('pagelist et container manquant'); - } - -} \ No newline at end of file diff --git a/js/shortcut.js b/js/shortcut.js deleted file mode 100755 index b032b03..0000000 --- a/js/shortcut.js +++ /dev/null @@ -1,145 +0,0 @@ -/* Retourne le keyCode correspondant à la chaîne -* -* @param keyStore enchaînement de touches sous forme de string -* @param handler function qui s'éxécute lors du raccourci -* -* return keyCode le code de la touche correspondante -*/ -function strToKeyCode(str){ - // on enregistre le keyCode du premier caractère - var keyCode = str.toUpperCase().charCodeAt(0); - - // s'il s'agit d'un caractère uniquement (entre "a" et "z") - if( str.length == 1 && keyCode >= 65 && keyCode <= 90 ) - return keyCode; // on retourne le keyCode associé - else - switch( str ){ - case 'ctrl': return 17; break; - case 'maj': return 16; break; - case 'alt': return 18; break; - case 'tab': return 9; break; - } - - return null; -} - - - - -var shortcutList = []; // contient les combinaisons de touches -var shortcutStep = []; // contient l'avancée d'un raccourcis - -/* Gestion des raccourcis claviers -* -* @param keyStore enchaînement de touches sous forme de string -* @param handler function qui s'éxécute lors du raccourci -* -*/ -function Shortcut(keyStore, handler){ - - var splittedString = keyStore.toLowerCase().split('+'), // découpe la chaîne (en minuscule) par "+" - splittedKeyCode = new Array(); // contiendra les keyCode de chaque touche - - - // pour chaque touche, on récupère le keyCode - for( var i = 0 ; i < splittedString.length ; i++ ) - splittedKeyCode[i] = strToKeyCode( splittedString[i] ); // on enregistre le keyCode correspondant - - - // on ajout à la liste globale - eventIndex = shortcutList.length; - shortcutList.push( splittedKeyCode ); - - // on initialise l'avancement - shortcutStep[eventIndex] = 0; - - - - // creation de la fonction d'évènement - shortcutList[eventIndex].push( function(k, f, h){ /* k ; f ; h */ - // on cherche l'avancée - var step = shortcutStep[f]; - - // on regarde si la touche est bonne - if( shortcutList[f][step] == k ){ // si c'est la touche suivante - - if( step >= shortcutList[f].length-2 ){ // si c'était la dernière touche - - // on initialise le tableau - for( var i = 0 ; i < shortcutStep[f].length ; i++ ) - shortcutStep[f][i] = 0; - - h(); // EXECUTION DE : handler(); - - }else // sinon on incrémente l'avancée - shortcutStep[f]++; - - }else // si c'est pas la bonne touche, on réinitialise le tableau - shortcutStep[f] = 0; - - }); - - console.log( shortcutList ); - - - // création de l'évènement - window.addEventListener( - 'keydown', - function(e){ e.preventDefault(); shortcutList[eventIndex][shortcutList[eventIndex].length-1](e.keyCode, eventIndex, handler); }, - false - ); - -} - -/* quand on lâche une touche, tout les raccourcis s'effacent */ -window.addEventListener('keyup', function(){ - for( var i = 0 ; i < shortcutStep.length ; i++ ) - shortcutStep[i] = 0; -}, false); - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -/*** UTILISATION ***/ - -// Shortcut( -// 'ctrl+s', -// function(){ alert('sauvegardé'); } -// ); \ No newline at end of file diff --git a/manager/database.php b/manager/database.php deleted file mode 100755 index 5b4c2cb..0000000 --- a/manager/database.php +++ /dev/null @@ -1,18 +0,0 @@ -connection = new PDO("mysql:host=$host;dbname=$dbname", $username, $password); - } -} - -?> \ No newline at end of file diff --git a/manager/security.php b/manager/security.php deleted file mode 100755 index 6781c74..0000000 --- a/manager/security.php +++ /dev/null @@ -1,76 +0,0 @@ - 0; - $permissionsDefinedProperly = isset($_SESSION['permissions']) && !empty($_SESSION['permissions']) && gettype($_SESSION['permissions']) == 'string' && strlen($_SESSION['permissions']) > 0; - - // si les variables sessions ne sont pas toutes les 2 correctes - if( !($usernameDefinedProperly && $permissionsDefinedProperly) ){ - $_SESSION['username'] = null; // on les initialise à NULL - $_SESSION['permissions'] = null; - } - } - - - - - - - -?> \ No newline at end of file diff --git a/manager/user.php b/manager/user.php deleted file mode 100755 index 0d37fe9..0000000 --- a/manager/user.php +++ /dev/null @@ -1,135 +0,0 @@ -level_1 ){ - - /****************************/ - /* authentification (login) */ - /****************************/ - case 'authentification': - $areSetParam = isset($request->username) && isset($request->password); // les arguments existent - $typeOkParam = $areSetParam && is_string($request->username) && is_string($request->password); // ils sont tous 2 des string - $nEmptyParam = $typeOkParam && strlen($request->username) > 0 && strlen($request->password) > 0; // d'au moins 1 caractère - - if( $areSetParam && $typeOkParam && $nEmptyParam ) - $answer->request = user_authentification($request->username, $request->password); - else{ - if ( !$areSetParam ) $answer->request= 'missing_param'; - elseif( !$typeOkParam ) $answer->request = 'wrong_type'; - else $answer->request = 'empty_param'; - } - break; - - - - /***********/ - /* DEFAULT */ - /***********/ - default: - $answer->request = 'unknown_level_1'; - break; - } - - } - - - - - - - - - - - - - - - - - - - /* [2] AUTHENTIFICATION - ============================================================*/ - - /* [a] userlist */ - function user_getUserList(){ - $userlistFile = file_get_contents("src/userlist.json"); - return json_decode( $userlistFile ); - } - - - /* [b] CONNECTION - ========================================================*/ - /* GESTION DE L'AUTHENTIFICATION D'UN UTILISATEUR - * - * @param username Identifiant de l'utilisateur - * @param password Mot de passe de l'utilisateur - * - * si @username est référencé et que le mot de passe associé vaut @password - * alors @return TRUE sinon FALSE - * + mise ajout à @answer - * - * Les variables sessions suivantes sont définies : - * - $_SESSION['permissions'] - * - $_SESSION['userid'] - * - $_SESSION['username'] - * - * @return Boolean true si l'utilisateur est ok - */ - function user_authentification($username, $password){ - - // [1] On récupère la liste d'utilisateurs (/src/userlist.json) - $userList = user_getUserList(); - - // [2] On check l'existence de l'utilisateur - if( isset($userList->{$username}) ){ - - // [3] On check le mot de passe - if( $userList->{$username}->password == $password ){ - // on définit les variables session - $_SESSION['username'] = $username; - $_SESSION['permissions'] = $userList->{$username}->permissions; - return 'success'; - }else - return 'wrong_password'; - - }else - return 'unknown_user'; - } - - -?> \ No newline at end of file diff --git a/page/_JS/auth.js b/page/_JS/auth.js deleted file mode 100755 index 7e95c72..0000000 --- a/page/_JS/auth.js +++ /dev/null @@ -1,80 +0,0 @@ - - /*********************************************************** - * * - * SCRIPT LOCAL DE LA PAGE D'AUTHENTIFICATION * - * * - ************************************************************ - * * - * [0] Variables * - * [1] Gestion des formulaires * - * [a] Gestion des réponses * - * [b] Initialisation des formulaires * - * * - * * - * * - * * - * * - * * - * * - * * - * * - ***********************************************************/ - - /* [0] Variables - ==============================================================*/ - var subSections = document.querySelectorAll('hgroup'); - - - /* [1] Gestion des formulaires - ==============================================================*/ - - - /* [a] Gestion des réponses - ==============================================================*/ - /* GESTION DU COMPORTEMENT EN FONCTION DE LA REPONSE POUR LE [LOGIN] - * - * @param response - * - * Gestion de toutes les réponse possibles avec une "messageBox" ou de redirection - * - */ - function manageAuthentificationResponse(response){ - switch( response.request ){ - - case 'success': - messageBox('Vous êtes maintenant connecté', 'success'); // on affiche le message - selectSection( document.querySelector('#MENU li:first-child') ); // on redirige vers la page d'accueil - break; - - // case 'missing_param': messageBox('Un des champs requis n\'est pas présent', 'warning'); break; - // case 'empty_param': messageBox('Un des champs requis est vide', 'warning'); break; - // case 'unknown_user': messageBox('Nom d\'utilisateur inconnu', 'error'); break; - // case 'wrong_password': messageBox('Mot de passe incorrect', 'error'); break; - - - case 'empty_param': case 'missing_param': case 'unknown_user': case 'wrong_password': - messageBox('Identifiants incorrects', 'error'); - break; - - default: - messageBox('Erreur interne', 'error'); - break; - - } - } - - - - - /* [b] Initialisation des formulaires - ==============================================================*/ - initForm( // initialisation du formulaire de connection - document.querySelector('#user'), // formulaire (élément DOM) - function(request){ // handler - // ajout d'informations à la requête - request.level_0 = 'user'; - request.level_1 = 'authentification'; - - API.send(request, function(response){ manageAuthentificationResponse(response); }); - } - ); diff --git a/page/_JS/groups.js b/page/_JS/groups.js deleted file mode 100755 index 65848f2..0000000 --- a/page/_JS/groups.js +++ /dev/null @@ -1,43 +0,0 @@ -var subSections = document.querySelectorAll('hgroup'); - - - - -// si aucune sous-partie n'est active, on active la première -if( document.querySelector('#CONTAINER hgroup.active') == null ) - selectSubSection( document.querySelector('#CONTAINER hgroup') ); - - - - - - - - - - - - - - - - - -/*************************************************/ -/****************** EXEMPLE API ******************/ -/*************************************************/ - -/* objet envoyé à API.php */ -var request = { - level_0: 'groups', - level_1: 'visualiser', - group : 'ego' -}; - -// console.log( request ); - -// envoi de la requête -// @ on envoie l'objet -// @ quand réception: affichage de l'objet reçu -// -API.send(request, function(){} ); diff --git a/page/auth.php b/page/auth.php deleted file mode 100755 index d0847f8..0000000 --- a/page/auth.php +++ /dev/null @@ -1,42 +0,0 @@ - - -
    Connection
    -
    - -
    - - - -
    - -
    - - - - - - -
    Mon Profil
    -
    - - username =
    - droits = - -
    - - - \ No newline at end of file diff --git a/page/career.php b/page/career.php deleted file mode 100755 index 12bea97..0000000 --- a/page/career.php +++ /dev/null @@ -1 +0,0 @@ -career.php \ No newline at end of file diff --git a/page/groups.php b/page/groups.php deleted file mode 100755 index 6420150..0000000 --- a/page/groups.php +++ /dev/null @@ -1,145 +0,0 @@ - -
    Mon Groupe
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    NomPrénomBlablabla
    001002003
    001002003
    001002003
    001002003
    001002003
    001002003
    001002003
    001002003
    001002003
    001002003
    - -
    - - - - -
    Mes Groupe
    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    Nom du groupeNombre d'élèvesNombre de modules
    A302
    B283
    D321
    F212
    - -
    - - - - -
    Tout les groupes
    -
    - Tout les groupes
    - bla
    - bla
    -
    - - - - -
    Mon Groupe 2
    -
    - Mon Groupe 2
    - bla
    - bla
    -
    \ No newline at end of file diff --git a/page/home.php b/page/home.php deleted file mode 100755 index 25d6e2a..0000000 --- a/page/home.php +++ /dev/null @@ -1,44 +0,0 @@ - -
    Présentation
    -
    - -Version 0.1

    - -Bienvenue sur la plateforme de gestion des élèves.

    -Seuls les membres du département y possède un accès, c'est à dire:
    -
      -
    • - Elèves
    • -
    • - Enseignants
    • -
    • - Personnel administratif
    • -
    - -Si vous faite partie de cette liste et que vous n'avez pas de compte, veuillez envoyer une requête au chef du département: Monsieur. Max Chevalier. - - -
    - - - - -
    Qui peut avoir accès à la plateforme
    -
    -blabla -
    \ No newline at end of file diff --git a/page/marks.php b/page/marks.php deleted file mode 100755 index 58569ea..0000000 --- a/page/marks.php +++ /dev/null @@ -1 +0,0 @@ -Notes ici !!! \ No newline at end of file diff --git a/page/modules.php b/page/modules.php deleted file mode 100755 index de1673c..0000000 --- a/page/modules.php +++ /dev/null @@ -1,4 +0,0 @@ - - - -modules.php \ No newline at end of file diff --git a/page/semestre.php b/page/semestre.php deleted file mode 100755 index 83d0be7..0000000 --- a/page/semestre.php +++ /dev/null @@ -1 +0,0 @@ -semestre.php \ No newline at end of file diff --git a/page/settings.php b/page/settings.php deleted file mode 100755 index 3dd1e75..0000000 --- a/page/settings.php +++ /dev/null @@ -1 +0,0 @@ -settings.php \ No newline at end of file diff --git a/page/ue.php b/page/ue.php deleted file mode 100755 index 49446a4..0000000 --- a/page/ue.php +++ /dev/null @@ -1 +0,0 @@ -ue.php \ No newline at end of file diff --git a/src/input_icon/default.svg b/src/input_icon/default.svg deleted file mode 100755 index 405ca99..0000000 --- a/src/input_icon/default.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/src/input_icon/default_grayscale.svg b/src/input_icon/default_grayscale.svg deleted file mode 100755 index ed397a3..0000000 --- a/src/input_icon/default_grayscale.svg +++ /dev/null @@ -1,59 +0,0 @@ - - - - - - image/svg+xml - - - - - - - - - - diff --git a/src/input_icon/password.svg b/src/input_icon/password.svg deleted file mode 100755 index 6f078a4..0000000 --- a/src/input_icon/password.svg +++ /dev/null @@ -1,49 +0,0 @@ - -image/svg+xml \ No newline at end of file diff --git a/src/input_icon/password_grayscale.svg b/src/input_icon/password_grayscale.svg deleted file mode 100755 index 8f2447c..0000000 --- a/src/input_icon/password_grayscale.svg +++ /dev/null @@ -1,51 +0,0 @@ - -image/svg+xml \ No newline at end of file diff --git a/src/input_icon/user.svg b/src/input_icon/user.svg deleted file mode 100755 index 4a35e05..0000000 --- a/src/input_icon/user.svg +++ /dev/null @@ -1,59 +0,0 @@ - -image/svg+xml \ No newline at end of file diff --git a/src/input_icon/user_grayscale.svg b/src/input_icon/user_grayscale.svg deleted file mode 100755 index 6a1d45f..0000000 --- a/src/input_icon/user_grayscale.svg +++ /dev/null @@ -1,61 +0,0 @@ - -image/svg+xml \ No newline at end of file diff --git a/src/menu_icon/auth.svg b/src/menu_icon/auth.svg deleted file mode 100755 index b87b166..0000000 --- a/src/menu_icon/auth.svg +++ /dev/null @@ -1,53 +0,0 @@ - -image/svg+xml \ No newline at end of file diff --git a/src/menu_icon/auth_grayscale.svg b/src/menu_icon/auth_grayscale.svg deleted file mode 100755 index 9f3378c..0000000 --- a/src/menu_icon/auth_grayscale.svg +++ /dev/null @@ -1,53 +0,0 @@ - -image/svg+xml \ No newline at end of file diff --git a/src/menu_icon/groups.svg b/src/menu_icon/groups.svg deleted file mode 100755 index bf6f121..0000000 --- a/src/menu_icon/groups.svg +++ /dev/null @@ -1,51 +0,0 @@ - -image/svg+xml \ No newline at end of file diff --git a/src/menu_icon/groups_grayscale.svg b/src/menu_icon/groups_grayscale.svg deleted file mode 100755 index 2eb2cd1..0000000 --- a/src/menu_icon/groups_grayscale.svg +++ /dev/null @@ -1,51 +0,0 @@ - -image/svg+xml \ No newline at end of file diff --git a/src/menu_icon/home.svg b/src/menu_icon/home.svg deleted file mode 100755 index 5d68207..0000000 --- a/src/menu_icon/home.svg +++ /dev/null @@ -1,151 +0,0 @@ - - - - - - - - - - image/svg+xml - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/src/menu_icon/home_grayscale.svg b/src/menu_icon/home_grayscale.svg deleted file mode 100755 index 6a9bc63..0000000 --- a/src/menu_icon/home_grayscale.svg +++ /dev/null @@ -1,151 +0,0 @@ - - - - - - - - - - image/svg+xml - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/src/menu_icon/marks.svg b/src/menu_icon/marks.svg deleted file mode 100755 index 894e9ee..0000000 --- a/src/menu_icon/marks.svg +++ /dev/null @@ -1,57 +0,0 @@ - - - -image/svg+xml \ No newline at end of file diff --git a/src/menu_icon/marks_grayscale.svg b/src/menu_icon/marks_grayscale.svg deleted file mode 100755 index 0aafb63..0000000 --- a/src/menu_icon/marks_grayscale.svg +++ /dev/null @@ -1,58 +0,0 @@ - - - -image/svg+xml \ No newline at end of file diff --git a/src/menu_icon/modules.svg b/src/menu_icon/modules.svg deleted file mode 100755 index 0882a93..0000000 --- a/src/menu_icon/modules.svg +++ /dev/null @@ -1,71 +0,0 @@ - - - - - - - - - - image/svg+xml - - - - - - - - - - diff --git a/src/menu_icon/modules_grayscale.svg b/src/menu_icon/modules_grayscale.svg deleted file mode 100755 index 6b2b773..0000000 --- a/src/menu_icon/modules_grayscale.svg +++ /dev/null @@ -1,71 +0,0 @@ - - - - - - - - - - image/svg+xml - - - - - - - - - - diff --git a/src/menu_icon/settings.svg b/src/menu_icon/settings.svg deleted file mode 100755 index 64f8cf1..0000000 --- a/src/menu_icon/settings.svg +++ /dev/null @@ -1,49 +0,0 @@ - - - -image/svg+xml \ No newline at end of file diff --git a/src/menu_icon/settings_grayscale.svg b/src/menu_icon/settings_grayscale.svg deleted file mode 100755 index 6c7c89d..0000000 --- a/src/menu_icon/settings_grayscale.svg +++ /dev/null @@ -1,49 +0,0 @@ - - - -image/svg+xml \ No newline at end of file diff --git a/src/menu_icon/ue.svg b/src/menu_icon/ue.svg deleted file mode 100755 index 578cd4d..0000000 --- a/src/menu_icon/ue.svg +++ /dev/null @@ -1,53 +0,0 @@ - -image/svg+xml \ No newline at end of file diff --git a/src/menu_icon/ue_grayscale.svg b/src/menu_icon/ue_grayscale.svg deleted file mode 100755 index 4c14e1e..0000000 --- a/src/menu_icon/ue_grayscale.svg +++ /dev/null @@ -1,53 +0,0 @@ - -image/svg+xml \ No newline at end of file diff --git a/src/userlist.json b/src/userlist.json deleted file mode 100755 index 5b1059e..0000000 --- a/src/userlist.json +++ /dev/null @@ -1,32 +0,0 @@ -{ - "eleve1": { - "permissions": "student", - "password" : "eleve1password" - }, - - "eleve2": { - "permissions": "student", - "password" : "eleve2password" - }, - - "prof1": { - "permissions": "teacher", - "password" : "prof1password" - }, - - "prof2": { - "permissions": "master", - "password" : "prof2password" - }, - - "admin1": { - "permissions": "admin", - "password" : "admin1password" - }, - - "admin2": { - "permissions": "admin", - "password" : "admin2password" - } - -} \ No newline at end of file