Refonte JS

This commit is contained in:
Adrien RENARD 2024-01-20 21:09:27 +01:00
parent 74981fc92a
commit 2e463acc45
46 changed files with 2829 additions and 3010 deletions

View File

@ -32,6 +32,12 @@ define('PANIERS_TYPES_TABLE_STRUCT', array(
"del" => array( "type" => "bool", "default" => 0 ) "del" => array( "type" => "bool", "default" => 0 )
)); ));
function getCountPaniersTypesListSelectBaseSQL() {
return "SELECT count(*) as nb"
." FROM ".PANIERS_TYPES_TABLE
." LEFT JOIN ".PANIERS_GROUPES_TABLE." ON ".PANIERS_TYPES_TABLE.".`groupe`=".PANIERS_GROUPES_TABLE.".`ref`";
}
function getPaniersTypesSelectBaseSQL() { function getPaniersTypesSelectBaseSQL() {
return "SELECT " return "SELECT "
.PANIERS_TYPES_TABLE.".`ref`," .PANIERS_TYPES_TABLE.".`ref`,"
@ -63,6 +69,10 @@ define('CLIENTS_TABLE_STRUCT', array(
"del" => array( "type" => "bool", "default" => 0 ) "del" => array( "type" => "bool", "default" => 0 )
)); ));
function getCountClientsListSelectBaseSQL() {
return "SELECT count(*) as nb FROM ".CLIENTS_TABLE;
}
function getClientsTableSelectBaseSQL() { function getClientsTableSelectBaseSQL() {
return "SELECT " return "SELECT "
.CLIENTS_TABLE.".`ref`," .CLIENTS_TABLE.".`ref`,"
@ -138,6 +148,17 @@ define('CONTRATS_TABLE_STRUCT', array(
define('CONTRATS_PANIERS_STATUT',"contrats_paniers_statut"); define('CONTRATS_PANIERS_STATUT',"contrats_paniers_statut");
function getCountContratsListSelectBaseSQL() {
return "SELECT count(*) as nb"
." FROM ".CONTRATS_TABLE
." LEFT JOIN ".CLIENTS_TABLE." ON ".CONTRATS_TABLE.".`client`=".CLIENTS_TABLE.".`ref`"
." LEFT JOIN ".CONTRATS_TYPES_TABLE." ON ".CONTRATS_TABLE.".`type`=".CONTRATS_TYPES_TABLE.".`ref`"
." LEFT JOIN ".PANIERS_GROUPES_TABLE." ON ".CONTRATS_TABLE.".`groupe`=".PANIERS_GROUPES_TABLE.".`ref`"
." LEFT JOIN ".PANIERS_TYPES_TABLE." ON ".CONTRATS_TABLE.".`panier_type`=".PANIERS_TYPES_TABLE.".`ref`"
." LEFT JOIN ".LIEUX_TABLE." ON ".CONTRATS_TABLE.".`lieu_depot`=".LIEUX_TABLE.".`ref`"
." LEFT JOIN ".CONTRATS_PANIERS_STATUT." ON ".CONTRATS_TABLE.".`ref`=".CONTRATS_PANIERS_STATUT.".`ref`";
}
function getContratsTableSelectBaseSQL() { function getContratsTableSelectBaseSQL() {
return "SELECT " return "SELECT "
.CONTRATS_TABLE.".`ref`," .CONTRATS_TABLE.".`ref`,"
@ -183,6 +204,23 @@ function buildContratsListSearchSQL($search) {
return $sql; return $sql;
} }
function buildContratsListFiltresSQL($sql, $filtres) {
if(array_key_exists('client', $filtres) && (int)$filtres['client']>0) $sql.=" AND ".CONTRATS_TABLE.".`client`=".intval($filtres['client']);
if(array_key_exists('groupe', $filtres) && (int)$filtres['groupe']>0) $sql.=" AND ".CONTRATS_TABLE.".`groupe`=".intval($filtres['groupe']);
if(array_key_exists('frequence', $filtres) && $filtres['frequence']!="") {
switch($filtres['frequence']) {
case 'hebdo' : $sql.=" AND ".CONTRATS_TABLE.".`frequence`='hebdo'"; break;
case 'quinz' : $sql.=" AND ".CONTRATS_TABLE.".`frequence`='quinz'"; break;
case 'quinz_A' : $sql.=" AND ".CONTRATS_TABLE.".`frequence`='quinz' AND ".CONTRATS_TABLE.".`quinz_groupe`='A'"; break;
case 'quinz_B' : $sql.=" AND ".CONTRATS_TABLE.".`frequence`='quinz' AND ".CONTRATS_TABLE.".`quinz_groupe`='B'"; break;
}
}
if(array_key_exists('panier', $filtres) && (int)$filtres['panier']>0) $sql.=" AND ".CONTRATS_TABLE.".`panier_type`=".intval($filtres['panier']);
if(array_key_exists('lieu', $filtres) && (int)$filtres['lieu']>0) $sql.=" AND ".CONTRATS_TABLE.".`lieu_depot`=".intval($filtres['lieu']);
if(array_key_exists('archive', $filtres) && (int)$filtres['archive']>=0) $sql.=" AND ".CONTRATS_TABLE.".`archive`=".intval($filtres['archive']);
return $sql;
}
//////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////
// CONTRATS - TYPES //////////////////////////////////////////////////// // CONTRATS - TYPES ////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////
@ -230,6 +268,10 @@ define('LEGUMES_TABLE_STRUCT', array(
"del" => array( "type" => "bool", "default" => 0 ) "del" => array( "type" => "bool", "default" => 0 )
)); ));
function getCountLegumesListSelectBaseSQL() {
return "SELECT count(*) as nb FROM ".LEGUMES_TABLE;
}
function getLegumesTableSelectBaseSQL() { function getLegumesTableSelectBaseSQL() {
return "SELECT " return "SELECT "
.LEGUMES_TABLE.".`ref`," .LEGUMES_TABLE.".`ref`,"
@ -254,9 +296,11 @@ define('LEGUMES_TARIFS_UNITES_ACRONYMES',array( 'kg' => 'kg', 'pièce' => 'pc',
define('LEGUMES_TARIFS_TABLE',"legumes_tarifs"); define('LEGUMES_TARIFS_TABLE',"legumes_tarifs");
define('LEGUMES_TARIFS_TABLE_STRUCT', array( define('LEGUMES_TARIFS_TABLE_STRUCT', array(
"legume" => array( "type" => "int", "min" => 1, "max" => NULL, "default" => NULL, "force_default_under_min" => true ), "legume" => array( "type" => "int", "min" => 1, "max" => NULL, "default" => NULL, "force_default_under_min" => true ),
"groupe" => array( "type" => "int", "min" => 1, "max" => NULL, "default" => NULL, "force_default_under_min" => true ),
"prix" => array( "type" => "float", "min" => 0, "max" => 999.99, "default" => 0, "force_default_under_min" => true ), "prix" => array( "type" => "float", "min" => 0, "max" => 999.99, "default" => 0, "force_default_under_min" => true ),
"unite" => array( "type" => "set", "values" => LEGUMES_TARIFS_UNITES, "default" => "poids" ), "unite" => array( "type" => "set", "values" => LEGUMES_TARIFS_UNITES, "default" => "poids" ),
"date" => array( "type" => "date", "default" => "today" ), "date" => array( "type" => "date", "default" => "today" ),
"archive" => array( "type" => "bool", "default" => 0 ),
"del" => array( "type" => "bool", "default" => 0 ) "del" => array( "type" => "bool", "default" => 0 )
)); ));
@ -265,12 +309,15 @@ function getLegumesTarifsTableSelectBaseSQL() {
.LEGUMES_TARIFS_TABLE.".`ref`," .LEGUMES_TARIFS_TABLE.".`ref`,"
.LEGUMES_TARIFS_TABLE.".`legume` as 'legume_ref'," .LEGUMES_TARIFS_TABLE.".`legume` as 'legume_ref',"
.LEGUMES_TABLE.".`nom` as 'legume_nom'," .LEGUMES_TABLE.".`nom` as 'legume_nom',"
.LEGUMES_TARIFS_TABLE.".`ref` as 'tarif_ref'," .LEGUMES_TARIFS_TABLE.".`groupe` as 'groupe_ref',"
.PANIERS_GROUPES_TABLE.".`nom` as 'groupe_nom',"
.LEGUMES_TARIFS_TABLE.".`prix` as 'tarif_prix'," .LEGUMES_TARIFS_TABLE.".`prix` as 'tarif_prix',"
.LEGUMES_TARIFS_TABLE.".`unite` as 'tarif_unite'," .LEGUMES_TARIFS_TABLE.".`unite` as 'tarif_unite',"
.LEGUMES_TARIFS_TABLE.".`date` as 'tarif_date'" .LEGUMES_TARIFS_TABLE.".`date` as 'tarif_date',"
.LEGUMES_TARIFS_TABLE.".`archive`"
." FROM ".LEGUMES_TARIFS_TABLE ." FROM ".LEGUMES_TARIFS_TABLE
." LEFT JOIN ".LEGUMES_TABLE." ON ".LEGUMES_TARIFS_TABLE.".`legume`=".LEGUMES_TABLE.".`ref`"; ." LEFT JOIN ".LEGUMES_TABLE." ON ".LEGUMES_TARIFS_TABLE.".`legume`=".LEGUMES_TABLE.".`ref`"
." LEFT JOIN ".PANIERS_GROUPES_TABLE." ON ".LEGUMES_TARIFS_TABLE.".`groupe`=".PANIERS_GROUPES_TABLE.".`ref`";
} }
//////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////
@ -309,6 +356,13 @@ define('LIVRAISONS_TABLE_STRUCT', array(
"del" => array( "type" => "bool", "default" => 0 ) "del" => array( "type" => "bool", "default" => 0 )
)); ));
function getCountLivraisonsListSelectBaseSQL() {
return "SELECT count(*) as nb"
." FROM ".LIVRAISONS_TABLE
." LEFT JOIN ".PANIERS_GROUPES_TABLE." ON ".LIVRAISONS_TABLE.".`paniers_groupe`=".PANIERS_GROUPES_TABLE.".`ref`"
." LEFT JOIN ".LIVRAISONS_NB_PANIERS_VIEW." ON ".LIVRAISONS_TABLE.".`ref`=".LIVRAISONS_NB_PANIERS_VIEW.".`ref`";
}
function getLivraisonsTableSelectBaseSQL() { function getLivraisonsTableSelectBaseSQL() {
return "SELECT " return "SELECT "
.LIVRAISONS_TABLE.".`ref`," .LIVRAISONS_TABLE.".`ref`,"

View File

@ -67,6 +67,12 @@ $GLOBALS['db_admin'] = array(
define('AUTO_ARCHIVE_OLD_LIVRAISONS_DELAY',5); // NB DE JOURS define('AUTO_ARCHIVE_OLD_LIVRAISONS_DELAY',5); // NB DE JOURS
define('AUTO_ARCHIVE_OLD_CONTRATS_DELAY',5); // NB DE JOURS (après le dernier panier livré) define('AUTO_ARCHIVE_OLD_CONTRATS_DELAY',5); // NB DE JOURS (après le dernier panier livré)
////////////////////////////////////////////////////////////////////////
// LISTES - NB DE LIGNE PAR PAGE ///////////////////////////////////////
////////////////////////////////////////////////////////////////////////
define('LIST_NB_LIGNES_PAR_PAGE',30);
//////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////
// WARNINGS CONTRATS /////////////////////////////////////////////////// // WARNINGS CONTRATS ///////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////

View File

@ -2462,6 +2462,23 @@ function getRequestTableDatas($table_structure, $force_default_values=false) {
return $ret; return $ret;
} }
function buildSqlSearch($sql, $search, $partBuilderFct) {
if($search && $search!="" && is_callable($partBuilderFct)) {
$parts = explode(" ", $search);
if(is_array($parts) && count($parts>0)) {
$search_sql = "";
foreach($parts as $p) {
if($p!="") $search_sql .= (($search_sql!="") ? " OR " : "").$partBuilderFct($p);
}
if($search_sql!="") {
if(strpos($sql, "WHERE")>0) $sql .= " AND (".$search_sql.")";
else $sql .= " WHERE (".$search_sql.")";
}
}
}
return $sql;
}
function buildTableDatas($table_structure, $datas, $force_default_values=false) { function buildTableDatas($table_structure, $datas, $force_default_values=false) {
$ret = array(); $ret = array();
foreach($table_structure as $key => $infos) { foreach($table_structure as $key => $infos) {

View File

@ -14,22 +14,24 @@ $allowClientsListOrder = array(
'email' => "email" 'email' => "email"
); );
function getClientsList($order='nom',$sens='ASC',$simple=false,$search=false) { function getNbClientsInList($search=false) {
$sql = getCountClientsListSelectBaseSQL()." WHERE ".CLIENTS_TABLE.".`del`=0";
$sql = buildSqlSearch($sql, $search, buildClientsListSearchSQL);
$r = $GLOBALS['db_admin']['man']->select($sql, 1);
if(!$r['erreur']) return intval($r['datas']['nb']);
else {
$er = "</br>sql: ".$sql."</br>error: ".getReadableVar($r['erreur']);
return "Une erreur est survenue durant du nombre d'item dans la liste !".$er;
}
}
function getClientsList($order='nom',$sens='ASC',$simple=false,$search=false,$limits=false) {
$list = array(); $list = array();
$sql = getClientsTableSelectBaseSQL()." WHERE ".CLIENTS_TABLE.".`del`=0"; $sql = getClientsTableSelectBaseSQL()." WHERE ".CLIENTS_TABLE.".`del`=0";
// SEARCH // SEARCH
if($search && $search!="") { $sql = buildSqlSearch($sql, $search, buildClientsListSearchSQL);
$parts = explode(" ", $search);
if(is_array($parts) && count($parts>0)) {
$search_sql = "";
foreach($parts as $p) {
if($p!="") $search_sql .= (($search_sql!="") ? " OR " : "").buildClientsListSearchSQL($p);
}
if($search_sql!="") $sql .= " AND (".$search_sql.")";
}
}
// ORDRE // ORDRE
$sql.=" ORDER BY "; $sql.=" ORDER BY ";
@ -45,6 +47,9 @@ function getClientsList($order='nom',$sens='ASC',$simple=false,$search=false) {
if($sens=='DESC') $sql .= ' DESC'; if($sens=='DESC') $sql .= ' DESC';
else $sql .= ' ASC'; else $sql .= ' ASC';
// LIMITS
if(is_array($limits)) $sql .= " LIMIT ".$limits['start'].", ".$limits['nbItemsByPage'];
$r = $GLOBALS['db_admin']['man']->select($sql); $r = $GLOBALS['db_admin']['man']->select($sql);
if(!$r['erreur']) { if(!$r['erreur']) {

View File

@ -20,7 +20,19 @@ $allowContratsListOrder = array(
'lieu_depot' => "lieu de dépôt" 'lieu_depot' => "lieu de dépôt"
); );
function getContratsList($order='id',$sens='ASC', $filtres=array(), $search=false) { function getNbContratsInList($filtres=array(), $search=false) {
$sql = getCountContratsListSelectBaseSQL()." WHERE ".CONTRATS_TABLE.".`del`=0";
$sql = buildContratsListFiltresSQL($sql, $filtres);
$sql = buildSqlSearch($sql, $search, buildContratsListSearchSQL);
$r = $GLOBALS['db_admin']['man']->select($sql, 1);
if(!$r['erreur']) return intval($r['datas']['nb']);
else {
$er = "</br>sql: ".$sql."</br>error: ".getReadableVar($r['erreur']);
return "Une erreur est survenue durant du nombre d'item dans la liste !".$er;
}
}
function getContratsList($order='id', $sens='ASC', $filtres=array(), $search=false, $limits=false) {
// ARCHIVES OLD CONTRATS // ARCHIVES OLD CONTRATS
archiveOldContrat(); archiveOldContrat();
@ -30,31 +42,10 @@ function getContratsList($order='id',$sens='ASC', $filtres=array(), $search=fals
$sql = getContratsTableSelectBaseSQL()." WHERE ".CONTRATS_TABLE.".`del`=0"; $sql = getContratsTableSelectBaseSQL()." WHERE ".CONTRATS_TABLE.".`del`=0";
// FILTRES // FILTRES
if(array_key_exists('client', $filtres) && (int)$filtres['client']>0) $sql.=" AND ".CONTRATS_TABLE.".`client`=".intval($filtres['client']); $sql = buildContratsListFiltresSQL($sql, $filtres);
if(array_key_exists('groupe', $filtres) && (int)$filtres['groupe']>0) $sql.=" AND ".CONTRATS_TABLE.".`groupe`=".intval($filtres['groupe']);
if(array_key_exists('frequence', $filtres) && $filtres['frequence']!="") {
switch($filtres['frequence']) {
case 'hebdo' : $sql.=" AND ".CONTRATS_TABLE.".`frequence`='hebdo'"; break;
case 'quinz' : $sql.=" AND ".CONTRATS_TABLE.".`frequence`='quinz'"; break;
case 'quinz_A' : $sql.=" AND ".CONTRATS_TABLE.".`frequence`='quinz' AND ".CONTRATS_TABLE.".`quinz_groupe`='A'"; break;
case 'quinz_B' : $sql.=" AND ".CONTRATS_TABLE.".`frequence`='quinz' AND ".CONTRATS_TABLE.".`quinz_groupe`='B'"; break;
}
}
if(array_key_exists('panier', $filtres) && (int)$filtres['panier']>0) $sql.=" AND ".CONTRATS_TABLE.".`panier_type`=".intval($filtres['panier']);
if(array_key_exists('lieu', $filtres) && (int)$filtres['lieu']>0) $sql.=" AND ".CONTRATS_TABLE.".`lieu_depot`=".intval($filtres['lieu']);
if(array_key_exists('archive', $filtres) && (int)$filtres['archive']>=0) $sql.=" AND ".CONTRATS_TABLE.".`archive`=".intval($filtres['archive']);
// SEARCH // SEARCH
if($search && $search!="") { $sql = buildSqlSearch($sql, $search, buildContratsListSearchSQL);
$parts = explode(" ", $search);
if(is_array($parts) && count($parts>0)) {
$search_sql = "";
foreach($parts as $p) {
if($p!="") $search_sql .= (($search_sql!="") ? " OR " : "").buildContratsListSearchSQL($p);
}
if($search_sql!="") $sql .= " AND (".$search_sql.")";
}
}
// ORDRE // ORDRE
$sql.=" ORDER BY "; $sql.=" ORDER BY ";
@ -76,6 +67,9 @@ function getContratsList($order='id',$sens='ASC', $filtres=array(), $search=fals
if($sens=='DESC') $sql .= ' DESC'; if($sens=='DESC') $sql .= ' DESC';
else $sql .= ' ASC'; else $sql .= ' ASC';
// LIMITS
if(is_array($limits)) $sql .= " LIMIT ".$limits['start'].", ".$limits['nbItemsByPage'];
$r = $GLOBALS['db_admin']['man']->select($sql); $r = $GLOBALS['db_admin']['man']->select($sql);
if(!$r['erreur']) { if(!$r['erreur']) {

View File

@ -13,22 +13,24 @@ $allowLegumesListOrder = array(
'date' => "date" 'date' => "date"
); );
function getLegumesList($order='nom',$sens='ASC', $search=false) { function getNbLegumesInList($search=false) {
$sql = getCountLegumesListSelectBaseSQL()." WHERE ".LEGUMES_TABLE.".`del`=0";
$sql = buildSqlSearch($sql, $search, buildLegumesListSearchSQL);
$r = $GLOBALS['db_admin']['man']->select($sql, 1);
if(!$r['erreur']) return intval($r['datas']['nb']);
else {
$er = "</br>sql: ".$sql."</br>error: ".getReadableVar($r['erreur']);
return "Une erreur est survenue durant du nombre d'item dans la liste !".$er;
}
}
function getLegumesList($order='nom',$sens='ASC', $search=false, $limits=false) {
$list = array(); $list = array();
$sql = getLegumesTableSelectBaseSQL()." WHERE ".LEGUMES_TABLE.".`del`=0"; $sql = getLegumesTableSelectBaseSQL()." WHERE ".LEGUMES_TABLE.".`del`=0";
// SEARCH // SEARCH
if($search && $search!="") { $sql = buildSqlSearch($sql, $search, buildLegumesListSearchSQL);
$parts = explode(" ", $search);
if(is_array($parts) && count($parts>0)) {
$search_sql = "";
foreach($parts as $p) {
if($p!="") $search_sql .= (($search_sql!="") ? " OR " : "").buildLegumesListSearchSQL($p);
}
if($search_sql!="") $sql .= " AND (".$search_sql.")";
}
}
// ORDRE // ORDRE
$sql.=" ORDER BY "; $sql.=" ORDER BY ";
@ -43,6 +45,9 @@ function getLegumesList($order='nom',$sens='ASC', $search=false) {
if($sens=='DESC') $sql .= ' DESC'; if($sens=='DESC') $sql .= ' DESC';
else $sql .= ' ASC'; else $sql .= ' ASC';
// LIMITS
if(is_array($limits)) $sql .= " LIMIT ".$limits['start'].", ".$limits['nbItemsByPage'];
$r = $GLOBALS['db_admin']['man']->select($sql); $r = $GLOBALS['db_admin']['man']->select($sql);
if(!$r['erreur']) { if(!$r['erreur']) {
@ -185,6 +190,40 @@ function eraseLegume($id) {
// LEGUMES - TARIFS //////////////////////////////////////////////////// // LEGUMES - TARIFS ////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////
function getLegumeTarifs($legume) {
$list = array();
return $list;
}
function getLegumeTarif($legume, $groupe) {
$i = array();
$sql = getLegumesTarifsTableSelectBaseSQL()
." WHERE ".LEGUMES_TARIFS_TABLE.".`legume`=".intval($legume);
if($groupe>0) $sql .= " AND ".LEGUMES_TARIFS_TABLE.".`groupe`=".intval($groupe);
else $sql .= " AND ".LEGUMES_TARIFS_TABLE.".`groupe` IS NULL";
$r = $GLOBALS['db_admin']['man']->select($sql,1);
if(!$r['erreur']) {
$i = $r['datas'];
$i["tarif_print"] = $i["tarif_prix"]." €/".$i["tarif_unite"];
$i["tarif_date_print"] = formatDate($i["tarif_date"], "mysql_date", "print_date");
}
else {
$er = "</br>sql: ".$sql."</br>error: ".getReadableVar($r['erreur']);
$GLOBALS['errors'][] = "Une erreur est survenue durant la récupération des informations du légume dans le base de données !".$er;
}
return $i;
}
function addLegumeTarif($datas) { function addLegumeTarif($datas) {
return addDatasInTable( return addDatasInTable(
$GLOBALS['db_admin']['man'], // DB MANAGER $GLOBALS['db_admin']['man'], // DB MANAGER

View File

@ -14,7 +14,19 @@ $allowLivraisonsListOrder = array(
'nb_paniers' => "nb. de paniers" 'nb_paniers' => "nb. de paniers"
); );
function getLivraisonsList($order='id',$sens='ASC', $groupe=0, $archive=0) { function getNbLivraisonsInList($groupe=0, $archive=0) {
$sql = getCountLivraisonsListSelectBaseSQL()." WHERE ".LIVRAISONS_TABLE.".`del`=0";
if((int)$groupe>0) $sql.=" AND ".LIVRAISONS_TABLE.".`paniers_groupe`=".intval($groupe);
if((int)$archive>=0) $sql.=" AND ".LIVRAISONS_TABLE.".`archive`=".intval($archive);
$r = $GLOBALS['db_admin']['man']->select($sql, 1);
if(!$r['erreur']) return intval($r['datas']['nb']);
else {
$er = "</br>sql: ".$sql."</br>error: ".getReadableVar($r['erreur']);
return "Une erreur est survenue durant du nombre d'item dans la liste !".$er;
}
}
function getLivraisonsList($order='id',$sens='ASC', $groupe=0, $archive=0, $limits=false) {
// ARCHIVES OLD LIVRAISONS // ARCHIVES OLD LIVRAISONS
archiveOldLivraison(); archiveOldLivraison();
@ -41,6 +53,9 @@ function getLivraisonsList($order='id',$sens='ASC', $groupe=0, $archive=0) {
if($sens=='DESC') $sql .= ' DESC'; if($sens=='DESC') $sql .= ' DESC';
else $sql .= ' ASC'; else $sql .= ' ASC';
// LIMITS
if(is_array($limits)) $sql .= " LIMIT ".$limits['start'].", ".$limits['nbItemsByPage'];
$r = $GLOBALS['db_admin']['man']->select($sql); $r = $GLOBALS['db_admin']['man']->select($sql);
if(!$r['erreur']) { if(!$r['erreur']) {

View File

@ -14,7 +14,7 @@ $allowPaniersGroupesListOrder = array(
function getPaniersGroupesList($order='nom',$sens='ASC', $search=false) { function getPaniersGroupesList($order='nom',$sens='ASC', $search=false) {
$list = array(); $list = array();
$sql = getPaniersGroupesSelectBaseSQL()." WHERE ".PANIERS_GROUPES_TABLE.".`ref`>0"; $sql = getPaniersGroupesSelectBaseSQL()." WHERE ".PANIERS_GROUPES_TABLE.".`del`=0";
// SEARCH // SEARCH
if($search && $search!="") { if($search && $search!="") {

View File

@ -13,22 +13,25 @@ $allowPaniersTypesListOrder = array(
'valeur' => 'valeur' 'valeur' => 'valeur'
); );
function getPaniersTypesList($order='nom',$sens='ASC', $search=false, $groupe=0) { function getNbPaniersInList($search=false, $groupe=0) {
$sql = getCountPaniersTypesListSelectBaseSQL()." WHERE ".PANIERS_TYPES_TABLE.".`del`=0";
$sql = buildSqlSearch($sql, $search, buildPaniersTypesListSearchSQL);
if($groupe>0) $sql .= " AND ".PANIERS_TYPES_TABLE.".`groupe`=".intval($groupe);
$r = $GLOBALS['db_admin']['man']->select($sql, 1);
if(!$r['erreur']) return intval($r['datas']['nb']);
else {
$er = "</br>sql: ".$sql."</br>error: ".getReadableVar($r['erreur']);
return "Une erreur est survenue durant du nombre d'item dans la liste !".$er;
}
}
function getPaniersTypesList($order='nom',$sens='ASC', $search=false, $groupe=0, $limits=false) {
$list = array(); $list = array();
$sql = getPaniersTypesSelectBaseSQL()." WHERE ".PANIERS_TYPES_TABLE.".`ref`>0"; $sql = getPaniersTypesSelectBaseSQL()." WHERE ".PANIERS_TYPES_TABLE.".`del`=0";
// SEARCH // SEARCH
if($search && $search!="") { $sql = buildSqlSearch($sql, $search, buildPaniersTypesListSearchSQL);
$parts = explode(" ", $search);
if(is_array($parts) && count($parts>0)) {
$search_sql = "";
foreach($parts as $p) {
if($p!="") $search_sql .= (($search_sql!="") ? " OR " : "").buildPaniersTypesListSearchSQL($p);
}
if($search_sql!="") $sql .= " AND (".$search_sql.")";
}
}
// GROUPE // GROUPE
if($groupe>0) $sql .= " AND ".PANIERS_TYPES_TABLE.".`groupe`=".intval($groupe); if($groupe>0) $sql .= " AND ".PANIERS_TYPES_TABLE.".`groupe`=".intval($groupe);
@ -46,6 +49,9 @@ function getPaniersTypesList($order='nom',$sens='ASC', $search=false, $groupe=0)
if($sens=='DESC') $sql .= ' DESC'; if($sens=='DESC') $sql .= ' DESC';
else $sql .= ' ASC'; else $sql .= ' ASC';
// LIMITS
if(is_array($limits)) $sql .= " LIMIT ".$limits['start'].", ".$limits['nbItemsByPage'];
$r = $GLOBALS['db_admin']['man']->select($sql); $r = $GLOBALS['db_admin']['man']->select($sql);
if(!$r['erreur']) { if(!$r['erreur']) {

View File

@ -163,12 +163,16 @@ DEFAULT CHARSET=utf8;
CREATE TABLE `legumes_tarifs` ( CREATE TABLE `legumes_tarifs` (
`ref` smallint(5) UNSIGNED NOT NULL AUTO_INCREMENT, `ref` smallint(5) UNSIGNED NOT NULL AUTO_INCREMENT,
`legume` smallint(5) UNSIGNED NOT NULL, `legume` smallint(5) UNSIGNED NOT NULL,
`groupe` smallint(5) UNSIGNED NULL DEFAULT NULL,
`prix` float(5,2) UNSIGNED NOT NULL, `prix` float(5,2) UNSIGNED NOT NULL,
`unite` set('kg','pièce','botte') NOT NULL DEFAULT 'kg', `unite` set('kg','pièce','botte') NOT NULL DEFAULT 'kg',
`date` date NOT NULL, `date` date NOT NULL,
`archive` tinyint(1) UNSIGNED NOT NULL DEFAULT '0',
`del` tinyint(1) UNSIGNED NOT NULL DEFAULT '0', `del` tinyint(1) UNSIGNED NOT NULL DEFAULT '0',
PRIMARY KEY (`ref`), PRIMARY KEY (`ref`),
CONSTRAINT `legumes_tarifs_legume_fk` FOREIGN KEY (`legume`) REFERENCES `legumes`(`ref`) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT `legumes_tarifs_legume_fk` FOREIGN KEY (`legume`) REFERENCES `legumes`(`ref`) ON DELETE RESTRICT ON UPDATE RESTRICT,
CONSTRAINT `legumes_tarifs_groupe_fk` FOREIGN KEY (`groupe`) REFERENCES `paniers_groupes`(`ref`) ON DELETE RESTRICT ON UPDATE RESTRICT,
INDEX (`archive`),
INDEX (`del`) INDEX (`del`)
) )
ENGINE=InnoDB ENGINE=InnoDB

View File

@ -95,12 +95,30 @@ switch($action) {
case "autocomplete_list": die( json_encode( getClientsAutocompleteList() ) ); break; case "autocomplete_list": die( json_encode( getClientsAutocompleteList() ) ); break;
// DEFAULT - LIST // DEFAULT - LIST
default: { default: {
// LIST // SEARCH
$search = getSearch("clients_search"); $search = getSearch("clients_search");
// LIMITS
$limits = array("start" => 0, "end" => LIST_NB_LIGNES_PAR_PAGE, "nbItemsByPage" => LIST_NB_LIGNES_PAR_PAGE, "max" => getNbClientsInList($search));
if(isset($_REQUEST['startListAt']) && (int)$_REQUEST['startListAt']>0) {
$limits['start'] = intval($_REQUEST['startListAt']);
$limits['end'] = $limits['start'] + $limits['nbItemsByPage'];
if($limits['end'] > $limits['max']) $limits['end'] = $limits['max'];
}
$limits['rest'] = $limits['max'] - $limits['end'];
$GLOBALS['smarty'] -> assign('list_limits',$limits);
// LIST
$order = getListOrder('clients_list_order', 'clients_list_sens', $allowClientsListOrder, 'prenom'); $order = getListOrder('clients_list_order', 'clients_list_sens', $allowClientsListOrder, 'prenom');
$list = getClientsList($order["order"], $order["sens"], false, $search); $list = getClientsList($order["order"], $order["sens"], false, $search, $limits);
$GLOBALS['smarty'] -> assign('list',$list); $GLOBALS['smarty'] -> assign('list',$list);
// LIST PART
if(isset($_REQUEST['startListAt']) && (int)$_REQUEST['startListAt']>0) {
$limits["list"] = $GLOBALS['smarty']->fetch("clients/clients_list_builder.tpl");
die(json_encode($limits));
}
// TEMPLATE // TEMPLATE
$GLOBALS['template'] = 'clients/clients_list.tpl'; $GLOBALS['template'] = 'clients/clients_list.tpl';
$jsFiles[] = PUBLIC_HTML_ADMIN.'js/clients.js'; $jsFiles[] = PUBLIC_HTML_ADMIN.'js/clients.js';

View File

@ -140,12 +140,30 @@ switch($action) {
"archive" => getRequestAndSessionSave("archive", "livraisons_filtre_archive", "archive", "int", 0, array(-1,0,1)) "archive" => getRequestAndSessionSave("archive", "livraisons_filtre_archive", "archive", "int", 0, array(-1,0,1))
); );
// LIST // SEARCH
$search = getSearch("contrats_search"); $search = getSearch("contrats_search");
// LIMITS
$limits = array("start" => 0, "end" => LIST_NB_LIGNES_PAR_PAGE, "nbItemsByPage" => LIST_NB_LIGNES_PAR_PAGE, "max" => getNbContratsInList($filtres, $search));
if(isset($_REQUEST['startListAt']) && (int)$_REQUEST['startListAt']>0) {
$limits['start'] = intval($_REQUEST['startListAt']);
$limits['end'] = $limits['start'] + $limits['nbItemsByPage'];
if($limits['end'] > $limits['max']) $limits['end'] = $limits['max'];
}
$limits['rest'] = $limits['max'] - $limits['end'];
$GLOBALS['smarty'] -> assign('list_limits',$limits);
// LIST
$order = getListOrder('contrats_list_order', 'contrats_list_sens', $allowContratsListOrder, 'prenom'); $order = getListOrder('contrats_list_order', 'contrats_list_sens', $allowContratsListOrder, 'prenom');
$list = getContratsList($order["order"], $order["sens"], $filtres, $search); $list = getContratsList($order["order"], $order["sens"], $filtres, $search, $limits);
$GLOBALS['smarty'] -> assign('list',$list); $GLOBALS['smarty'] -> assign('list',$list);
// LIST PART
if(isset($_REQUEST['startListAt']) && (int)$_REQUEST['startListAt']>0) {
$limits["list"] = $GLOBALS['smarty']->fetch("contrats/contrats_list_builder.tpl");
die(json_encode($limits));
}
// TEMPLATE // TEMPLATE
$GLOBALS['template'] = 'contrats/contrats_list.tpl'; $GLOBALS['template'] = 'contrats/contrats_list.tpl';
$jsFiles[] = PUBLIC_HTML_ADMIN.'js/contrats.js'; $jsFiles[] = PUBLIC_HTML_ADMIN.'js/contrats.js';

View File

@ -117,6 +117,59 @@ div.intl-tel-input { display: block; }
font-style: italic; font-style: italic;
} }
/* LIST */
table.scrollingTableList { margin: 0; }
table.scrollingTableList ::-webkit-scrollbar {
-webkit-appearance: none;
width: 16px;
background-color: rgba(51, 122, 183, .2);
}
table.scrollingTableList ::-webkit-scrollbar-thumb {
border-radius: 4px;
background-color: rgba(51, 122, 183, .5);
box-shadow: 0 0 1px rgba(51, 122, 183, .5);
}
table.scrollingTableList tbody { display: block; overflow: auto; margin: 0; }
table.scrollingTableList tbody tr:first-child td { border: none; }
table.scrollingTableList thead, table.scrollingTableList tbody tr {
display: table;
width: 100%;
table-layout: fixed;
}
table.scrollingTableList:not(.no-scroll) thead { width: calc( 100% - 16px ); }
table.scrollingTableList th.id, table.scrollingTableList td.id { width: 45px; }
table.scrollingTableList th.groupe, table.scrollingTableList td.groupe { width: 100px; }
table.scrollingTableList th.valeur, table.scrollingTableList td.valeur { width: 130px; }
table.scrollingTableList th.tel, table.scrollingTableList td.tel { width: 150px; }
table.scrollingTableList th.email, table.scrollingTableList td.email { width: 300px; }
table.scrollingTableList th.contrat_type, table.scrollingTableList td.contrat_type { width: 300px; }
table.scrollingTableList th.panier_type, table.scrollingTableList td.panier_type { width: 160px; }
table.scrollingTableList th.date, table.scrollingTableList td.date { width: 140px; }
table.scrollingTableList th.freq, table.scrollingTableList td.freq { width: 160px; }
table.scrollingTableList th.lieu, table.scrollingTableList td.lieu { width: 200px; }
table.scrollingTableList th.items_long, table.scrollingTableList td.items_long { width: 120px; }
table.scrollingTableList th.items, table.scrollingTableList td.items { width: 55px; }
table.scrollingTableList th.btn_action, table.scrollingTableList td.td_btn_action { width: 30px; }
table.scrollingTableList th.btn_action[colspan="2"] { width: 60px; }
table.scrollingTableList th.btn_action[colspan="3"] { width: 90px; }
table.scrollingTableList td.loader {
background-color: rgba(161, 95, 150, .1);
height: 100px;
background-image: url('../img/wait.svg');
background-position: center;
background-size: contain;
background-repeat: no-repeat;
}
/* FEEDBACKS */ /* FEEDBACKS */
span.form-control-feedback { position: absolute; } span.form-control-feedback { position: absolute; }
@ -448,6 +501,22 @@ table.modal-body tr:last-child td:first-child { border-bottom-left-radius: 6px;
table.modal-body tr:last-child th:first-child { border-bottom-left-radius: 6px; } table.modal-body tr:last-child th:first-child { border-bottom-left-radius: 6px; }
table.modal-body tr:last-child td:last-child { border-bottom-right-radius: 6px; } table.modal-body tr:last-child td:last-child { border-bottom-right-radius: 6px; }
/* INLINE SELECT MANAGER */
.btnSecondAction {
border-radius: 0;
border-left: none;
}
/* FORM TABS */
div.formTabs div.tab:not(.active) { display: none; }
div.formTabs div.tab { overflow-y: scroll; }
div.formTabs table.modal-body tr:first-child th,
div.formTabs table.modal-body tr:first-child td { border-top: none; }
/* PANIER FORM */ /* PANIER FORM */
.formPanier .btnGroupeSecondAction { .formPanier .btnGroupeSecondAction {

View File

@ -6,6 +6,8 @@
#modalViewContrat .formContrat { margin: -15px; } #modalViewContrat .formContrat { margin: -15px; }
#modalViewContrat div.tabPaniers table { margin-bottom: 0!important; }
/* NAV TABS */ /* NAV TABS */
.formContrat ul.nav.nav-tabs { padding-left: 10px; } .formContrat ul.nav.nav-tabs { padding-left: 10px; }

View File

@ -12,28 +12,28 @@
.formLivraison ul.nav.nav-tabs { padding-left: 10px; } .formLivraison ul.nav.nav-tabs { padding-left: 10px; }
div.formLivraisonTabs > div.tab { .formLivraison div.formTabs > div.tab {
display: none; display: none;
border-bottom-left-radius: 6px; border-bottom-left-radius: 6px;
border-bottom-right-radius: 6px; border-bottom-right-radius: 6px;
overflow-y: scroll; overflow-y: scroll;
} }
div.formLivraisonTabs > div.tab.active { display: block; } .formLivraison div.formTabs > div.tab.active { display: block; }
div.formLivraisonTabs > div.tab span.nullChild { display: block; padding: 10px; } .formLivraison div.formTabs > div.tab span.nullChild { display: block; padding: 10px; }
/* TAB GENERAL */ /* TAB GENERAL */
#modalAddLivraison div.formLivraisonTabs > div.tabGeneral, #modalAddLivraison div.formTabs > div.tabGeneral,
#modalEditLivraison div.formLivraisonTabs > div.tabGeneral { padding: 15px; } #modalEditLivraison div.formTabs > div.tabGeneral { padding: 15px; }
div.formLivraisonTabs > div.tabGeneral table, .formLivraison div.formTabs > div.tabGeneral table,
div.formLivraisonTabs > div.tabGeneral div.form-group:last-child { margin-bottom: 0; } .formLivraison div.formTabs > div.tabGeneral div.form-group:last-child { margin-bottom: 0; }
div.formLivraisonTabs > div.tabGeneral table tr:first-child > th, .formLivraison div.formTabs > div.tabGeneral table tr:first-child > th,
div.formLivraisonTabs > div.tabGeneral table tr:first-child > td { border-top: none; } .formLivraison div.formTabs > div.tabGeneral table tr:first-child > td { border-top: none; }
div.formLivraisonTabs > div.tabGeneral table th { width: 160px; } .formLivraison div.formTabs > div.tabGeneral table th { width: 160px; }
/* TABLE PANIER */ /* TABLE PANIER */
@ -71,7 +71,8 @@ div.formLivraisonTabs > div.tabGeneral table th { width: 160px; }
.formLivraison table.panier th.titre small { font-size: 0.75em; font-weight: 400; font-style: italic; } .formLivraison table.panier th.titre small { font-size: 0.75em; font-weight: 400; font-style: italic; }
.formLivraison table.panier th.total { text-align: right; vertical-align: bottom; } .formLivraison table.panier th.total { text-align: right; vertical-align: bottom; }
.formLivraison table.panier th.total.unite { text-align: left; } .formLivraison table.panier th.total.unite { text-align: left; }
.formLivraison table.panier th.action { padding-top: 0!important; } .formLivraison table.panier th.action { padding-top: 0!important; text-align: center; }
.formLivraison table.panier th.action .btnCopyCompo { margin-top: -3px; }
.formLivraison table.panier tr.head > th { .formLivraison table.panier tr.head > th {
background-color: #3296c8; background-color: #3296c8;
@ -105,26 +106,26 @@ div.formLivraisonTabs > div.tabGeneral table th { width: 160px; }
/* TAB PANIERS */ /* TAB PANIERS */
div.formLivraisonTabs > div.tabPaniers input[type=checkbox] { cursor: pointer; } .formLivraison div.formTabs > div.tabPaniers input[type=checkbox] { cursor: pointer; }
div.formLivraisonTabs > div.tabPaniers table.panier tbody div.tooltip { max-width: 170px; } .formLivraison div.formTabs > div.tabPaniers table.panier tbody div.tooltip { max-width: 170px; }
div.formLivraisonTabs > div.tabPaniers tr.panier { cursor: pointer; } .formLivraison div.formTabs > div.tabPaniers tr.panier { cursor: pointer; }
div.formLivraisonTabs > div.tabPaniers tr.panier.absent, .formLivraison div.formTabs > div.tabPaniers tr.panier.absent,
div.formLivraisonTabs > div.tabPaniers tr.panier.absent input[type=checkbox] { cursor: not-allowed; } .formLivraison div.formTabs > div.tabPaniers tr.panier.absent input[type=checkbox] { cursor: not-allowed; }
/* TAB COMPO */ /* TAB COMPO */
div.formLivraisonTabs > div.tabCompo table.panier { margin: 10px 0; } .formLivraison div.formTabs > div.tabCompo table.panier { margin: 10px 0; }
div.formLivraisonTabs > div.tabCompo table.panier tr.legume.editable td.nom, .formLivraison div.formTabs > div.tabCompo table.panier tr.legume.editable td.nom,
div.formLivraisonTabs > div.tabCompo table.panier tr.legume.editable td.quantite { cursor: pointer; } .formLivraison div.formTabs > div.tabCompo table.panier tr.legume.editable td.quantite { cursor: pointer; }
/* TAB LEGUMES */ /* TAB LEGUMES */
div.formLivraisonTabs > div.tabLegumes table.panier { margin-top: 10px; } .formLivraison div.formTabs > div.tabLegumes table.panier { margin-top: 10px; }
div.formLivraisonTabs > div.tabLegumes table.panier th.total.montant { font-size: 1.5em; } .formLivraison div.formTabs > div.tabLegumes table.panier th.total.montant { font-size: 1.5em; }
div.formLivraisonTabs > div.tabLegumes table.panier th.total.unite { font-size: 1.5em; } .formLivraison div.formTabs > div.tabLegumes table.panier th.total.unite { font-size: 1.5em; }
/* PRINT */ /* PRINT */

View File

@ -1,121 +1,80 @@
// SETTINGS
var clientsConf = {
type : "client",
baseURL : "clients.php",
// LIST
list_selector : "#clientsList",
// SEARCH // SEARCH
var clientsSearch = false; search_selector : "#clientsSearch .searchGrp",
// VIEW // VIEW
var modalViewClient = false; view_modalSelector : "#modalViewClient",
var btnViewClient = false; view_btnSelector : ".btnViewClient",
var currentViewClient = 0;
var clientsBaseURL = "clients.php";
// ADD // ADD
var modalAddClient = false; add_modalSelector : "#modalAddClient",
var formAddClient = false; add_btnSelector : "#btnAddClient",
var btnAddClient = false;
// EDIT // EDIT
var modalEditClient = false; edit_modalSelector : "#modalEditClient",
var formEditClient = false; edit_btnSelector : ".btnEditClient",
var btnEditClient = false;
var currentEditClient = 0;
// DELETE // DELETE
delete_modalSelector : "#modalDeleteClient",
delete_btnSelector : ".btnDeleteClient",
}
// MODALS
var modalViewClient = false;
var modalAddClient = false;
var modalEditClient = false;
var modalDeleteClient = false; var modalDeleteClient = false;
var btnDeleteClient = false;
var currentDeleteClient = 0;
$(document).ready( function() { $(document).ready( function() {
// INIT SEARCH // LIST LOADER
clientsSearch = $("#clientsSearch"); initListProgressLoad($(clientsConf.list_selector), clientsConf.baseURL, clientsConf.type+" list");
if(clientsSearch.length>0) initSearchClients();
// INIT VIEW CLIENT // SEARCH
modalViewClient = $("#modalViewClient"); $(clientsConf.search_selector).initSearchGroup();
btnViewClient = $(".btnViewClient");
if(modalViewClient.length>0 && btnViewClient.length>0) { // VIEW
modalViewClient = $(clientsConf.view_modalSelector);
if(modalViewClient.length>0) {
initViewClient(); initViewClient();
// VIEW REQUEST // VIEW REQUEST
var id = getUrlParameter("id"); var id = getUrlParameter("ref");
if(id!==false && parseInt(id)>0) loadDatasInViewClientModal(id); if(id!==false && parseInt(id)>0 && current_page == "clients") {
modalViewClient_clear(modalViewClient);
modalViewClient_loadDatas(modalViewClient, id);
}
} }
// INIT ADD CLIENT // ADD
modalAddClient = $("#modalAddClient"); modalAddClient = $(clientsConf.add_modalSelector);
formAddClient = $("#formAddClient"); if(modalAddClient.length>0) initAddClient();
btnAddClient = $("#btnAddClient");
if(modalAddClient.length>0 && formAddClient.length>0 && btnAddClient.length>0) initAddClient();
// INIT EDIT CLIENT // EDIT
modalEditClient = $("#modalEditClient"); modalEditClient = $(clientsConf.edit_modalSelector);
formEditClient = $("#formEditClient"); if(modalEditClient.length>0) initEditClient();
btnEditClient = $(".btnEditClient");
if(modalEditClient.length>0 && formEditClient.length>0 && btnEditClient.length>0) initEditClient();
// INIT DELETE CLIENT // DELETE
modalDeleteClient = $("#modalDeleteClient"); modalDeleteClient = $(clientsConf.delete_modalSelector);
btnDeleteClient = $(".btnDeleteClient"); if(modalDeleteClient.length>0) initDeleteClient();
if(modalDeleteClient.length>0 && btnDeleteClient.length>0) initDeleteClient();
}); });
/***** SEARCH CLIENTS *****/ /***** MODAL VIEW *****/
function initSearchClients() {
clientsSearch.find("input[name=search]").unbind('keypress').keypress( function(event) {
if(event.keyCode==13) searchClient(false);
});
clientsSearch.find(".btnClearSearch").unbind('click').click( function(event) {
searchClient(true);
});
}
function searchClient(clear) {
clientsSearch.find("input[name=search]").blur();
clientsSearch.find(".btnClearSearch").blur();
if(clear) document.location = "?clearSearch";
else document.location = "?search="+clientsSearch.find("input[name=search]").val();
}
/***** VIEW CLIENT *****/
function initViewClient() { function initViewClient() {
// BTN VIEW // INIT VIEW BTNs
btnViewClient.unbind('click').click( function(event) { var initBtnFct = function() { modalForm_initBtnView(
event.preventDefault(); $(clientsConf.view_btnSelector), // BTNs
id = parseInt($(this).attr('ref')); modalViewClient, // MODAL
if(!id>0) return; modalViewClient_clear, // CLEAR FUNCTION
clearViewClientModal(); modalViewClient_loadDatas // LOAD DATAS FUNCTION
currentViewClient = id; )};
loadDatasInViewClientModal(id); registerListProgressLoadCbkFct( $("tbody.progressLoadList"), initBtnFct );
}); initBtnFct();
// INIT FORM VIEW
var form = modalViewClient.find("div.formClient");
// TABS // TABS
form.find("a.formClientTabBtn").click(function(e) { modalForm_initTabs(modalViewClient);
e.preventDefault();
// BTN
if(!$(this).parent().hasClass("active")) {
form.find("ul.formClientTabs > li").removeClass('active');
$(this).parent().addClass("active");
}
// TAB
var tab = form.find("div.tab."+$(this).attr("tab"));
if(tab.length>0) {
if(tab.hasClass("active")) return;
form.find("div.formClientTabs > div.tab").removeClass("active");
tab.addClass("active");
}
});
resizeFormClient(form);
$( window ).on( "resize", function() { resizeFormClient(form) });
// CANCEL // CANCEL
modalViewClient.on('hidden.bs.modal', function (e) { modalViewClient.on('hidden.bs.modal', function() { modalViewClient_clear(modalViewClient); });
clearViewClientModal();
currentViewClient = 0;
});
// EMPECHE LA FERMETURE SI ON EST ENTRAIN D'EDITER UNE LIGNE D'ABSENCE // EMPECHE LA FERMETURE SI ON EST ENTRAIN D'EDITER UNE LIGNE D'ABSENCE
modalViewClient.on('hide.bs.modal', function(e) { modalViewClient.on('hide.bs.modal', function(e) {
@ -123,58 +82,55 @@ function initViewClient() {
}); });
} }
function resizeFormClient(form) { function modalViewClient_loadDatas(modal, id) {
var wh = window.innerHeight; $.post(clientsConf.baseURL, { 'ref' : id, 'action' : 'getDatas' }, function(jsonTxt) {
form.find("div.formClientTabs div.tab").css("max-height", (wh-180)+"px"); var datas = JSON.parse(jsonTxt);
}
function loadDatasInViewClientModal(id) { modal.find("small.db_ref > span").html(datas.ref);
datas = {
'ref' : id,
'action' : 'getDatas'
};
$.post( clientsBaseURL, datas, function( result ) {
var datas = JSON.parse(result);
currentViewClient = parseInt(datas.ref); modal.find("td.nom").html(datas.prenom+" "+datas.nom);
modalViewClient.find("small.db_ref > span").html(datas.ref); modal.find("td.tel").html( (datas.tel!="" && datas.tel!=null) ? '<a href="tel:'+datas.tel+'">'+datas.tel+'</a>' : "." );
modal.find("td.email").html( (datas.email!="" && datas.email!=null) ? '<a href="mailto:'+datas.email+'">'+datas.email+'</a>' : ".");
modalViewClient.find("td.nom").html(datas.prenom+" "+datas.nom);
modalViewClient.find("td.tel").html( (datas.tel!="" && datas.tel!=null) ? '<a href="tel:'+datas.tel+'">'+datas.tel+'</a>' : "." );
modalViewClient.find("td.email").html( (datas.email!="" && datas.email!=null) ? '<a href="mailto:'+datas.email+'">'+datas.email+'</a>' : ".");
// CONTRATS // CONTRATS
$.post(clientsBaseURL, { 'ref' : id, 'action' : 'modalView_getTab', 'tab' : 'contrats' }, function(result) { $.post(clientsConf.baseURL, { 'ref' : id, 'action' : 'modalView_getTab', 'tab' : 'contrats' }, function(result) {
modalViewClient.find("div.tabContrats").html(result); modal.find("div.tabContrats").html(result);
}).fail(function() { alert(srvErrorMsg+" (load modal view client - tab contrats)"); }); }).fail(function() { alert("ERREUR SERVEUR ! (client modal view - load tab contrats)"); });
// ABSENCES // ABSENCES
loadModalViewTabAbsences(); modalViewClient_loadTabAbsences();
modalViewClient.modal('show'); modal.modal('show');
}).fail(function() { alert(srvErrorMsg+" (load modal view client)"); }); }).fail(function() { alert("("+clientsConf.type+" - load modal view)"); });
} }
function clearViewClientModal() { function modalViewClient_clear(modal) {
modalViewClient.find("small.db_ref > span").html(""); modal.removeAttr("view_id");
modalViewClient.find("ul.formClientTabs > li").removeClass('active hide'); modal.find("small.db_ref > span").html("");
modalViewClient.find("ul.formClientTabs > li:first-child").addClass('active');
modalViewClient.find("div.formClientTabs > div.tab").removeClass("active");
modalViewClient.find("div.formClientTabs > div.tab:first-child").addClass("active");
modalViewClient.find("td.nom").html(""); modalForm_resetTabs(modal);
modalViewClient.find("td.tel").html("");
modalViewClient.find("td.email").html("");
modalViewClient.find("div.tabContrats").html(""); modal.find("td.nom").html("");
modalViewClient.find("div.tabAbsences").html(""); modal.find("td.tel").html("");
modal.find("td.email").html("");
modal.find("div.tabContrats").html("");
modal.find("div.tabAbsences").html("");
modal.find("table.modal-body tfoot").addClass("hide").find("tr:not(.header)").remove();
} }
function initModalViewClientTabAbsences() { function modalViewClient_loadTabAbsences() {
$.post(clientsConf.baseURL, { 'ref' : modalViewClient.attr("view_id"), 'action' : 'modalView_getTab', 'tab' : 'absences' }, function(result) {
modalViewClient.find("div.tabAbsences").html(result);
modalViewClient_initTabAbsences();
}).fail(function() { alert(srvErrorMsg+" (load modal view client - tab absences)"); });
}
function modalViewClient_initTabAbsences() {
// BTN ADD ABSENCES // BTN ADD ABSENCES
modalViewClient.find("#btnAddAbsence").click(function(e) { modalViewClient.find("#btnAddAbsence").click(function(e) {
e.preventDefault(); e.preventDefault(); $(this).blur();
$(this).blur();
var tr = $("<tr ref='new'></tr>").html( modalViewClient.find("tr.absenceNewRowTemplate").html() ); var tr = $("<tr ref='new'></tr>").html( modalViewClient.find("tr.absenceNewRowTemplate").html() );
modalViewClient.find("div.tabAbsences table tbody").append(tr); modalViewClient.find("div.tabAbsences table tbody").append(tr);
@ -182,14 +138,14 @@ function initModalViewClientTabAbsences() {
nullChild = modalViewClient.find("div.tabAbsences table tbody tr.nullChild"); nullChild = modalViewClient.find("div.tabAbsences table tbody tr.nullChild");
if(nullChild.length>0) nullChild.remove(); if(nullChild.length>0) nullChild.remove();
initModalViewClientAbsenceRow(tr); modalViewClient_initAbsenceRow(tr);
}); });
// INIT ROWS // INIT ROWS
modalViewClient.find("div.tabAbsences table tbody tr.absence").each(function(n,e) { initModalViewClientAbsenceRow($(this)); }) modalViewClient.find("div.tabAbsences table tbody tr.absence").each(function(n,e) { modalViewClient_initAbsenceRow($(this)); })
} }
function initModalViewClientAbsenceRow(row) { function modalViewClient_initAbsenceRow(row) {
var ref = row.attr("ref"); if(parseInt(ref)>0) ref = parseInt(ref); var ref = row.attr("ref"); if(parseInt(ref)>0) ref = parseInt(ref);
var tdDebut = row.find("td.debut"); var tdFin = row.find("td.fin"); var tdRmq = row.find("td.remarque"); var tdDebut = row.find("td.debut"); var tdFin = row.find("td.fin"); var tdRmq = row.find("td.remarque");
@ -229,24 +185,25 @@ function initModalViewClientAbsenceRow(row) {
var btnDel = row.find("button.btnDeleteAbsence"); var btnDel = row.find("button.btnDeleteAbsence");
btnEdit.click(function(e) { btnEdit.click(function(e) {
e.preventDefault(); e.preventDefault(); $(this).blur();
$(this).blur();
if(modalViewClient.find("tr.editable").length>0 && !row.hasClass("editable")) return; if(modalViewClient.find("tr.editable").length>0 && !row.hasClass("editable")) return;
// SAVE // SAVE
if(row.hasClass("editable")) { if(row.hasClass("editable")) {
iptDebut.blur(); iptFin.blur(); iptRmq.blur(); iptDebut.blur(); iptFin.blur(); iptRmq.blur();
datas = { 'client' : currentViewClient, 'debut' : debut, 'fin' : fin, 'remarque' : rmq }; datas = {
'client' : modalViewClient.attr("view_id"),
'debut' : debut,
'fin' : fin,
'remarque' : rmq
};
if(ref=='new') datas.action = "add_client_absence"; if(ref=='new') datas.action = "add_client_absence";
else { datas.action = "edit_client_absence"; datas.absence_ref = ref; } else { datas.action = "edit_client_absence"; datas.absence_ref = ref; }
$.post(clientsBaseURL, datas, function(result) { $.post(clientsConf.baseURL, datas, function(result) {
if(parseInt(result)>0) loadModalViewTabAbsences(); if(parseInt(result)>0) modalViewClient_loadTabAbsences();
else { else { console.error(result); alert(result); }
console.error(result); }).fail(function() { alert("ERREUR SERVEUR ! (modal view client - save absence)"); });
alert(result);
}
}).fail(function() { alert(srvErrorMsg+" (modal view client - save absence)"); });
} }
// EDIT // EDIT
else { else {
@ -263,8 +220,7 @@ function initModalViewClientAbsenceRow(row) {
}); });
btnDel.click(function(e) { btnDel.click(function(e) {
e.preventDefault(); e.preventDefault(); $(this).blur();
$(this).blur();
if(modalViewClient.find("tr.editable").length>0 && !row.hasClass("editable")) return; if(modalViewClient.find("tr.editable").length>0 && !row.hasClass("editable")) return;
// CANCEL // CANCEL
@ -286,13 +242,10 @@ function initModalViewClientAbsenceRow(row) {
else { else {
if(!ref>0) return; if(!ref>0) return;
if(confirm("Êtes-vous sur de vouloir supprimer cette absence ?")) { if(confirm("Êtes-vous sur de vouloir supprimer cette absence ?")) {
$.post(clientsBaseURL, { 'action': "delete_client_absence", 'absence_ref': ref }, function(result) { $.post(clientsConf.baseURL, { 'action': "delete_client_absence", 'absence_ref': ref }, function(result) {
if(parseInt(result)>0) loadModalViewTabAbsences(); if(parseInt(result)>0) modalViewClient_loadTabAbsences();
else { else { console.error(result); alert(result); }
console.error(result); }).fail(function() { alert("ERREUR SERVEUR ! (modal view client - delete absence)"); });
alert(result);
}
}).fail(function() { alert(srvErrorMsg+" (modal view client - delete absence)"); });
} }
} }
}); });
@ -300,220 +253,148 @@ function initModalViewClientAbsenceRow(row) {
if(ref == "new") row.find("button.btnEditAbsence").click(); if(ref == "new") row.find("button.btnEditAbsence").click();
} }
function loadModalViewTabAbsences() { /***** MODAL FORM ADD/EDIT *****/
$.post(clientsBaseURL, { 'ref' : currentViewClient, 'action' : 'modalView_getTab', 'tab' : 'absences' }, function(result) { function modalFormClient_init(modal) {
modalViewClient.find("div.tabAbsences").html(result); modal.find("form").on("submit", function(e) { e.preventDefault(); });
initModalViewClientTabAbsences();
}).fail(function() { alert(srvErrorMsg+" (load modal view client - tab absences)"); });
}
/***** FORM CLIENT *****/
function initFormClient(form) {
form.on("submit", function(e) { e.preventDefault(); });
// NOM // NOM
initUpperCaseInput(form.find("input[name=nom]"), null, function() { $(this).blur(); }); initUpperCaseInput(modal.find("input[name=nom]"), null, function() { $(this).blur(); });
// PRENOM // PRENOM
initFirstUpperCaseInput(form.find("input[name=prenom]"), null, function() { $(this).blur(); }); initFirstUpperCaseInput(modal.find("input[name=prenom]"), null, function() { $(this).blur(); });
// TEL // TEL
initTelInput(form.find("input[name=tel]"), true, "libs/intl-tel-input-15.0.0/build/js/utils.js"); initTelInput(modal.find("input[name=tel]"), true, "libs/intl-tel-input-15.0.0/build/js/utils.js");
// EMAIL // EMAIL
initEmailInput(form.find("input[name=email]")); initEmailInput(modal.find("input[name=email]"));
} }
function loadDatasInFormClientDatas(modal,form,id) { function modalFormClient_loadDatas(modal,id) {
datas = { $.post(clientsConf.baseURL, { 'ref' : id, 'action' : 'getDatas' }, function(jsonTxt) {
'ref' : id, var datas = JSON.parse(jsonTxt);
'action' : 'getDatas'
};
$.post( clientsBaseURL, datas, function( result ) {
var datas = JSON.parse(result);
form.find("input[name=nom]").val(datas.nom); modal.find("input[name=nom]").val(datas.nom);
form.find("input[name=prenom]").val(datas.prenom); modal.find("input[name=prenom]").val(datas.prenom);
form.find("input[name=tel]").val(datas.tel); modal.find("input[name=tel]").val(datas.tel);
form.find("input[name=email]").val(datas.email); modal.find("input[name=email]").val(datas.email);
if(modal) modal.modal('show'); if(modal) modal.modal('show');
}).fail(function() { alert(srvErrorMsg+" (form client - load datas)"); }); }).fail(function() { alert("("+clientsConf.type+" - load datas in modal form)"); });
} }
function clearFormClientDatas(form) { function modalFormClient_clear(modal) {
form.find("input[name=nom]").val(""); modal.removeAttr("edit_id");
form.find("input[name=prenom]").val(""); modal.find("div.modaLoader").removeClass("show");
form.find("input[name=tel]").val("");
form.find("input[name=email]").val("");
// MODALOADER modal.find("input[name=nom]").val("");
form.find("div.modaLoader").removeClass("show"); modal.find("input[name=prenom]").val("");
modal.find("input[name=tel]").val("");
modal.find("input[name=email]").val("");
} }
// GET FORM DATAS function modalFormClient_getDatas(modal) {
function getClientFormDatas(form) {
var datas = { var datas = {
'nom' : form.find("input[name=nom]").val(), 'nom' : modal.find("input[name=nom]").val(),
'prenom' : form.find("input[name=prenom]").val(), 'prenom' : modal.find("input[name=prenom]").val(),
'tel' : form.find("input[name=tel]").intlTelInput("isValidNumber") ? form.find("input[name=tel]").val() : "", 'tel' : modal.find("input[name=tel]").intlTelInput("isValidNumber") ? modal.find("input[name=tel]").val() : "",
'email' : validateEmail(form.find("input[name=email]").val()) ? form.find("input[name=email]").val() : "", 'email' : validateEmail(modal.find("input[name=email]").val()) ? modal.find("input[name=email]").val() : ""
}; };
return datas; return datas;
} }
/***** ADD CLIENT *****/ function modalFormClient_checkDatas(datas) {
if(datas.nom=="" || datas.prenom=="") {
alert("ERREUR : au minimum, un nom et un prénom doivent être renseigné !");
return false;
}
return true;
}
/***** ADD *****/
function initAddClient() { function initAddClient() {
// BTN ADD // INIT FORM
btnAddClient.unbind('click').click( function(event) { modalFormClient_init(modalAddClient);
event.preventDefault();
clearFormClientDatas(formAddClient);
modalAddClient.modal('show');
});
// INIT FORM ADD // INIT ADD BTN
initFormClient(formAddClient); modalForm_initBtnAdd(
$(clientsConf.add_btnSelector), // BTN ADD
modalAddClient, // MODAL
modalFormClient_clear // CLEAR FORM FUNCTION
);
// SAVE CLIENT // INIT SAVE BTN
$(".btnSaveAddClient").unbind('click').click( function(event) { modalForm_initBtnSaveAdd(
event.preventDefault(); modalAddClient.find(".btnSave"), // BTN SAVE
clientsConf.type, // ADD TYPE
var datas = getClientFormDatas(formAddClient); modalAddClient, // MODAL
if(datas.nom=="" || datas.prenom=="") { modalFormClient_getDatas, // GET FORM DATAS FUNCTION
alert("ERREUR : au minimum, un nom et un prénom doivent être renseigné !"); modalFormClient_checkDatas, // CHECK FORM DATAS FUNCTION
return; clientsConf.baseURL // SAVE URL
} );
datas.action = 'add';
formAddClient.find("div.modaLoader").addClass("show");
$(".btnSaveAddClient").prop("disabled", true);
$.post( clientsBaseURL, datas, function( result ) {
if(parseInt(result)>0) {
modalAddClient.modal('hide');
setTimeout(function() {
document.location.reload();
},200);
}
else {
console.error(result);
alert(result);
formAddClient.find("div.modaLoader").removeClass("show");
$(".btnSaveAddClient").prop("disabled", false);
}
}).fail(function() {
alert(srvErrorMsg+" (add client)");
formAddClient.find("div.modaLoader").removeClass("show");
$(".btnSaveAddClient").prop("disabled", false);
});
});
// CANCEL // CANCEL
modalAddClient.on('hidden.bs.modal', function (e) { clearFormClientDatas(formAddClient); }); modalAddClient.on('hidden.bs.modal', function (e) { modalFormClient_clear(modalAddClient); });
} }
/***** EDIT CLIENT *****/ /***** EDIT *****/
function initEditClient() { function initEditClient() {
// BTN EDIT // INIT FORM
btnEditClient.unbind('click').click( function(event) { modalFormClient_init(modalEditClient);
event.preventDefault();
id = parseInt($(this).attr('ref'));
if(!id>0) return;
currentEditClient = id;
clearFormClientDatas(formEditClient);
loadDatasInFormClientDatas(modalEditClient,formEditClient,id);
});
// INIT FORM EDIT // INIT EDIT BTNs
initFormClient(formEditClient); var initBtnFct = function() { modalForm_initBtnEdit(
$(clientsConf.edit_btnSelector), // BTNs
modalEditClient, // MODAL
modalFormClient_clear, // CLEAR FUNCTION
modalFormClient_loadDatas // LOAD DATAS FUNCTION
)};
registerListProgressLoadCbkFct( $("tbody.progressLoadList"), initBtnFct );
initBtnFct();
// SAVE CLIENT // INIT SAVE EDIT BTN
$(".btnSaveEditClient").unbind('click').click( function(event) { modalForm_initBtnSaveEdit(
event.preventDefault(); modalEditClient.find(".btnSave"), // BTN SAVE
clientsConf.type, // EDIT TYPE
if(!currentEditClient>0) return; modalEditClient, // MODAL
modalFormClient_getDatas, // GET FORM DATAS FUNCTION
var datas = getClientFormDatas(formEditClient); modalFormClient_checkDatas, // CHECK FORM DATAS FUNCTION
if(datas.nom=="" || datas.prenom=="") { clientsConf.baseURL // SAVE URL
alert("ERREUR : au minimum, un nom et un prénom doivent être renseigné !"); );
return;
}
datas.action = 'edit';
datas.ref = currentEditClient;
formEditClient.find("div.modaLoader").addClass("show");
$(".btnSaveEditClient").prop("disabled", true);
$.post( clientsBaseURL, datas, function( result ) {
if(parseInt(result)>0) {
modalEditClient.modal('hide');
setTimeout(function() {
document.location.reload();
},200);
}
else {
console.error(result);
alert(result);
formEditClient.find("div.modaLoader").removeClass("show");
$(".btnSaveEditClient").prop("disabled", false);
}
}).fail(function() {
alert(srvErrorMsg+" (edit client)");
formEditClient.find("div.modaLoader").removeClass("show");
$(".btnSaveEditClient").prop("disabled", false);
});
});
// CANCEL // CANCEL
modalEditClient.on('hidden.bs.modal', function (e) { modalEditClient.on('hidden.bs.modal', function (e) { modalFormClient_clear(modalEditClient); });
clearFormClientDatas(formEditClient);
currentEditClient = 0;
});
} }
/***** DELETE CLIENT *****/ /***** DELETE *****/
function initDeleteClient() { function initDeleteClient() {
// BTN DELETE // INIT DELETE BTNs
btnDeleteClient.unbind('click').click( function(event) { var initBtnFct = function() { modalForm_initBtnDelete(
event.preventDefault(); $(clientsConf.delete_btnSelector), // BTNs
id = parseInt($(this).attr('ref')); modalDeleteClient, // MODAL
if(!id>0) return; modalDeleteClient_clear, // CLEAR MODAL FUNCTION
currentDeleteClient = id; modalDeleteClient_loadDatas // LOAD DATAS FUNCTION
)};
registerListProgressLoadCbkFct( $("tbody.progressLoadList"), initBtnFct );
initBtnFct();
modalDeleteClient.find('b.name').html( $(this).attr('nom') ); // INIT SAVE DELETE BTN
modalForm_initBtnSaveDelete(
modalDeleteClient.modal('show'); modalDeleteClient.find(".btnSave"), // BTN SAVE
}); clientsConf.type, // DELETE TYPE
modalDeleteClient, // MODAL
// DELETE false, // GET FORM DATAS FUNCTION
$("#btnDeleteClient").unbind('click').click( function(event) { false, // CHECK FORM DATAS FUNCTION
event.preventDefault(); clientsConf.baseURL // SAVE URL
$(this).blur(); );
if(!currentDeleteClient>0) return;
var datas = {
action : 'delete',
ref : currentDeleteClient
};
$.post( clientsBaseURL, datas, function( result ) {
if(parseInt(result)>0) {
modalEditClient.modal('hide');
setTimeout(function() {
document.location.reload();
},200);
}
else {
console.error(result);
alert(result);
}
}).fail(function() { alert(srvErrorMsg+" (delete client)"); });
});
// CANCEL // CANCEL
modalDeleteClient.on('hidden.bs.modal', function (e) { modalDeleteClient.on('hidden.bs.modal', function (e) { modalDeleteClient_clear(); });
modalDeleteClient.find('b.name').html(""); }
currentDeleteClient = 0;
}); function modalDeleteClient_loadDatas(btn, id) {
modalDeleteClient.find('b.name').html( btn.attr('nom') );
modalDeleteClient.modal('show');
}
function modalDeleteClient_clear() {
modalDeleteClient.removeAttr("delete_id");
modalDeleteClient.find('b.name').html("");
} }

File diff suppressed because it is too large Load Diff

View File

@ -5,6 +5,632 @@ var array_keys_ponctuations = ['.','-','_','#','@'];
var array_keys_minuscules = ['a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z']; var array_keys_minuscules = ['a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'];
var array_keys_majuscules = ['A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z']; var array_keys_majuscules = ['A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'];
function isDefined(val){
return (val === undefined || val == null || val.length <= 0) ? false : true;
}
/* MODAL FORM UTIL */
function modalForm_initBtnView(btn, modal, clearFormFct, loadFormDatasFct) {
btn.unbind('click').click( function(e) {
e.preventDefault(); $(this).blur();
id = parseInt($(this).attr('ref'));
if(!id>0) return;
clearFormFct(modal);
modal.attr("view_id", id);
loadFormDatasFct(modal, id);
});
}
function modalForm_initBtnAdd(btn, modal, clearFormFct) {
btn.unbind('click').click( function(e) {
e.preventDefault(); $(this).blur();
clearFormFct(modal);
modal.modal('show');
});
}
function modalForm_initBtnCopy(btn, modal, clearFormFct, loadFormDatasFct) {
btn.unbind('click').click( function(e) {
e.preventDefault(); $(this).blur();
id = parseInt($(this).attr('ref'));
if(!id>0) return;
clearFormFct(modal);
loadFormDatasFct(modal,id, true);
});
}
function modalForm_initBtnSaveAdd(btn, addType, modal, getModalFormDataFct, checkModalFormDataFct, saveURL) {
btn.unbind('click').click( function(e) {
e.preventDefault(); $(this).blur();
// GET & CHECK DATAS
var datas = getModalFormDataFct(modal);
console.log("modalForm_btnSaveAdd", datas);
if( !checkModalFormDataFct(datas) ) return;
datas.action = 'add';
// RUN REQUEST
modalForm_runFormRequest( saveURL, datas, ("add "+addType) , modal, $(this) );
});
}
function modalForm_initBtnEdit(btn, modal, clearFormFct, loadFormDatasFct) {
btn.unbind('click').click( function(e) {
e.preventDefault(); $(this).blur();
id = parseInt($(this).attr('ref'));
if(!id>0) return;
clearFormFct(modal);
modal.attr("edit_id", id);
loadFormDatasFct(modal,id);
});
}
function modalForm_initBtnSaveEdit(btn, editType, modal, getModalFormDataFct, checkModalFormDataFct, saveURL) {
btn.unbind('click').click( function(e) {
e.preventDefault(); $(this).blur();
// GET MODAL EDIT ID
var id = parseInt( modal.attr("edit_id") );
if(!id>0) return;
// GET & CHECK DATAS
var datas = getModalFormDataFct(modal);
console.log("modalForm_btnSaveEdit", datas);
if( !checkModalFormDataFct(datas) ) return;
datas.action = 'edit';
datas.ref = id;
// RUN REQUEST
modalForm_runFormRequest( saveURL, datas, ("edit "+editType) , modal, $(this) );
});
}
function modalForm_initBtnArchive(btn, modal, clearFormFct, loadFormDatasFct) {
btn.unbind('click').click( function(e) {
e.preventDefault(); $(this).blur();
id = parseInt($(this).attr('ref'));
if(!id>0) return;
clearFormFct(modal);
modal.attr("archive_id", id);
loadFormDatasFct($(this),id);
});
}
function modalForm_initBtnSaveArchive(btn, archiveType, modal, saveURL) {
btn.unbind('click').click( function(e) {
e.preventDefault(); $(this).blur();
// GET MODAL DELETE ID
var id = parseInt( modal.attr("archive_id") );
if(!id>0) return;
// GET DATAS
var datas = {
'action' : 'archive',
'ref' : id
};
console.log("ARCHIVE", id, datas );
// RUN REQUEST
modalForm_runFormRequest( saveURL, datas, ("archive "+archiveType) , modal, $(this) );
});
}
function modalForm_initBtnUnarchive(btn, archiveType, modal, saveURL) {
btn.unbind('click').click( function(e) {
e.preventDefault(); $(this).blur();
id = parseInt($(this).attr('ref'));
if(!id>0) return;
var datas = {
'action' : 'unarchive',
'ref' : id
};
console.log("UNARCHIVE", id, datas );
// RUN REQUEST
$.post( saveURL, datas, function( result ) {
if(parseInt(result)>0) document.location.reload();
else {
console.error(result); alert(result);
}
}).fail(function(xhr) {
var errMsg = "SERVER ERROR (unarchive "+archiveType+")";
if( xhr['responseText']!="" ) errMsg += " : " + xhr['responseText'];
console.error(errMsg); alert(errMsg);
});
});
}
function modalForm_initBtnDelete(btn, modal, clearFormFct, loadFormDatasFct) {
btn.unbind('click').click( function(e) {
e.preventDefault(); $(this).blur();
id = parseInt($(this).attr('ref'));
if(!id>0) return;
clearFormFct(modal);
modal.attr("delete_id", id);
loadFormDatasFct($(this),id);
});
}
function modalForm_initBtnSaveDelete(btn, deleteType, modal, getModalFormDataFct, checkModalFormDataFct, saveURL) {
btn.unbind('click').click( function(e) {
e.preventDefault(); $(this).blur();
// GET MODAL DELETE ID
var id = parseInt( modal.attr("delete_id") );
if(!id>0) return;
// GET & CHECK DATAS
var datas = {};
if(typeof getModalFormDataFct === 'function') datas = getModalFormDataFct(modal);
console.log("DELETE", id, datas );
if(typeof checkModalFormDataFct === 'function') { if( !checkModalFormDataFct(datas) ) return; }
datas.action = 'delete';
datas.ref = id;
// RUN REQUEST
modalForm_runFormRequest( saveURL, datas, ("delete "+deleteType) , modal, $(this) );
});
}
function modalForm_runFormRequest(url, datas, srvErrorAction, modal, btnRun) {
modalForm_runFormRequest_lockModal(modal, btnRun);
$.post( url, datas, function( result ) {
if(parseInt(result)>0) {
if(modal && modal.length>0) {
modal.modal('hide');
setTimeout(function() { document.location.reload(); },200);
}
else document.location.reload();
}
else {
console.error(result); alert(result);
modalForm_runFormRequest_unlockModal(modal, btnRun);
}
}).fail(function(xhr) {
var errMsg = "SERVER ERROR";
if( isDefined( srvErrorAction ) ) errMsg += " ("+srvErrorAction+")";
if( xhr['responseText']!="" ) errMsg += " : " + xhr['responseText'];
console.error(errMsg); alert(errMsg);
modalForm_runFormRequest_unlockModal(modal, btnRun);
});
}
function modalForm_runFormRequest_lockModal(modal, btnRun) {
if( isDefined( modal ) && modal.find("div.modaLoader").length>0) modal.find("div.modaLoader").addClass("show");
if( isDefined( btnRun ) ) btnRun.prop("disabled", true);
}
function modalForm_runFormRequest_unlockModal(modal, btnRun) {
if( isDefined( modal ) && modal.find("div.modaLoader").length>0) modal.find("div.modaLoader").removeClass("show");
if( isDefined( btnRun ) ) btnRun.prop("disabled", false);
}
function modalForm_initTabs(modal) {
// TABS
modal.find("a.formTabBtn").click(function(e) {
e.preventDefault();
// BTN
if(!$(this).parent().hasClass("active")) {
modal.find("ul.formTabsBtns > li").removeClass('active');
$(this).parent().addClass("active");
}
// TAB
var tab = modal.find("div.tab."+$(this).attr("tab"));
if(tab.length>0) {
if(tab.hasClass("active")) return;
modal.find("div.formTabs > div.tab").removeClass("active");
tab.addClass("active");
}
});
// RESIZE TABS
var resizeFct = function resizeFormClient(modal) {
var wh = window.innerHeight;
modal.find("div.formTabs div.tab").css("max-height", (wh-180)+"px");
}
resizeFct(modal);
$( window ).on( "resize", function() { resizeFct(modal) });
}
function modalForm_resetTabs(modal) {
modal.find("ul.formTabsBtns > li").removeClass('active hide');
modal.find("ul.formTabsBtns > li:first-child").addClass('active');
modal.find("div.formTabs > div.tab").removeClass("active");
modal.find("div.formTabs > div.tab:first-child").addClass("active");
}
/* INLINE SELECT MANAGER */
function inlineSelectManager_init(
modal,
modal_form_name,
grp,
value_name,
url,
ref_attr,
add_action,
edit_action,
delete_action,
refresh_list_action,
selectClbkFct,
addClbkFct,
editClbkFct,
cancelClbkFct,
getDatasFct,
checkDatasFct,
saveClbkFct
) {
grp.attr("modal_form_name", modal_form_name)
.attr("value_name", value_name)
.attr("ref_attr", ref_attr)
.attr("add_action", add_action)
.attr("edit_action", edit_action)
.attr("delete_action", delete_action)
.attr("refresh_list_action", refresh_list_action);
// SELECT CHANGE => SWITCH ACTION
grp.find("select").change(function(e) {
$(this).blur();
// EXISTING
if(parseInt($(this).val())>0) {
inlineSelectManager_switchBtnAction(grp, "delete");
inlineSelectManager_switchBtnSecondAction(grp, "edit");
}
// CHOISIR...
else {
inlineSelectManager_switchBtnAction(grp, "add");
inlineSelectManager_switchBtnSecondAction(grp, "hide");
}
if(typeof selectClbkFct === 'function') selectClbkFct(modal, grp, $(this));
});
// BTN ACTION
grp.find("button.btnAction").click(function(e) {
e.preventDefault(); $(this).blur();
// ADD / SAVE NEW
if($(this).hasClass("add") || $(this).hasClass("save_new")) {
inlineSelectManager_addInputName(grp, "add");
inlineSelectManager_switchBtnAction(grp, "save");
inlineSelectManager_switchBtnSecondAction(grp, "cancel");
if(typeof addClbkFct === 'function') addClbkFct(modal, grp);
}
// SAVE
else if($(this).hasClass("save")) inlineSelectManager_save(modal, grp, url, getDatasFct, checkDatasFct, saveClbkFct);
// DELETE
else if($(this).hasClass("delete")) inlineSelectManager_delete(modal, grp, url);
});
// BTN SECOND ACTION
grp.find("button.btnSecondAction").click(function(e) {
e.preventDefault(); $(this).blur();
// EDIT
if($(this).hasClass("edit")) {
inlineSelectManager_addInputName(grp, "edit");
inlineSelectManager_switchBtnAction(grp, "save");
inlineSelectManager_switchBtnSecondAction(grp, "cancel");
if(typeof editClbkFct === 'function') editClbkFct(modal, grp);
}
// CANCEL
else if($(this).hasClass("cancel")) {
inlineSelectManager_removeInputName(grp);
// EDIT
if(parseInt(grp.find("select").val())>0) {
inlineSelectManager_switchBtnAction(grp, "delete");
inlineSelectManager_switchBtnSecondAction(grp, "edit");
}
// ADD
else {
inlineSelectManager_switchBtnAction(grp, "add");
inlineSelectManager_switchBtnSecondAction(grp, "hide");
}
if(typeof cancelClbkFct === 'function') cancelClbkFct(modal, grp);
}
});
}
function inlineSelectManager_setValue(grp, val) {
if(isDefined(val) && parseInt(val) > 0) {
grp.find("select").val(val);
inlineSelectManager_switchBtnAction(grp, "delete");
inlineSelectManager_switchBtnSecondAction(grp, "edit");
}
else {
grp.find("select").val("0");
inlineSelectManager_switchBtnAction(grp, "add");
inlineSelectManager_switchBtnSecondAction(grp, "hide");
}
}
function inlineSelectManager_switchBtnAction(grp, action) {
var btn = grp.find("button.btnAction");
if(action == "add") {
btn.removeClass("save save_new delete").addClass("add").removeClass("btn-danger btn-primary").addClass("btn-default")
.find("i").removeClass("glyphicon-floppy-saved glyphicon-floppy-disk glyphicon-trash").addClass("glyphicon-plus");
}
else if(action == "save") {
btn.removeClass("add save_new delete").addClass("save").removeClass("btn-danger btn-default").addClass("btn-primary")
.find("i").removeClass("glyphicon-plus glyphicon-floppy-disk glyphicon-trash").addClass("glyphicon-floppy-saved");
}
else if(action == "save_new") {
btn.removeClass("add save delete").addClass("save_new").removeClass("btn-danger btn-primary").addClass("btn-default")
.find("i").removeClass("glyphicon-plus glyphicon-floppy-saved glyphicon-trash").addClass("glyphicon-floppy-disk");
}
else if(action == "delete") {
btn.removeClass("add save_new save").addClass("delete").removeClass("btn-default btn-primary").addClass("btn-danger")
.find("i").removeClass("glyphicon-plus glyphicon-floppy-saved glyphicon-floppy-disk").addClass("glyphicon-trash");
}
}
function inlineSelectManager_switchBtnSecondAction(grp, action) {
var btn = grp.find("button.btnSecondAction");
if(action == "cancel") {
btn.removeClass("edit").addClass("cancel").removeClass("btn-default").addClass("btn-danger")
.find("i").removeClass("glyphicon-edit").addClass("glyphicon-floppy-remove");
btn.parent().removeClass("hide");
}
else if(action == "edit") {
btn.removeClass("cancel").addClass("edit").removeClass("btn-danger").addClass("btn-default")
.find("i").removeClass("glyphicon-floppy-remove").addClass("glyphicon-edit");
btn.parent().removeClass("hide");
}
else if(action == "hide") {
btn.parent().addClass("hide");
}
}
function inlineSelectManager_addInputName(grp, action) {
var select = grp.find("select");
select.addClass("hide");
var ipt = $('<input type="text" class="form-control" name="name" placeholder="nom">').attr("action", action);
ipt.insertBefore(select);
if(action=="edit") {
ipt.attr("ref", select.val());
ipt.val( select.find("option:selected").html() );
}
else ipt.attr("ref", "new");
ipt.focus();
ipt.keypress(function(e) {
if(e.keyCode==13) {
e.preventDefault();
$(this).parent().find("button.btnAction").click();
}
});
}
function inlineSelectManager_removeInputName(grp) {
var ipt = grp.find("input[name=name]");
if(ipt.length>0) ipt.remove();
grp.find("select").removeClass("hide");
}
function inlineSelectManager_save(modal, grp, url, getDatasFct, checkDatasFct, saveClbkFct) {
// GET DATAS
var datas = (typeof getDatasFct === 'function') ? getDatasFct(modal, grp) : inlineSelectManager_getDatas(grp);
// CHECK DATAS
if(typeof checkDatasFct === 'function') { if( !checkDatasFct(datas) ) return; }
else { if( !inlineSelectManager_checkDatas(datas) ) return; }
var ref = grp.find("input[name=name]").attr("ref");
// ADD
if(ref == "new") datas.action = grp.attr("add_action");
// EDIT
else if(parseInt(ref)>0) {
ref = parseInt(ref);
datas.action = grp.attr("edit_action");
datas[grp.attr("ref_attr")] = ref;
}
// LOCK
modal.find("div.modaLoader").addClass("show");
modal.find("button.btnAction").prop("disabled", true);
$.post( url, datas, function( result ) {
if(parseInt(result)>0) {
inlineSelectManager_switchBtnAction(grp, "delete");
inlineSelectManager_switchBtnSecondAction(grp, "edit");
inlineSelectManager_removeInputName(grp);
if(ref == "new") ref = parseInt(result);
if(typeof saveClbkFct === 'function') saveClbkFct(modal, grp, ref);
// REFRESH LIST
$.post( url, { action: grp.attr("refresh_list_action") }, function( result ) {
grp.find("select").html(result).val(ref);
}).fail(function() {
alert("ERREUR SERVEUR ! (modal form "+grp.attr("modal_form_name")+" - add/edit "+grp.find("select").attr("name")+" - refresh list after)");
});
}
else { console.error(result); alert(result); }
}).fail(function() {
alert("ERREUR SERVEUR ! (modal form "+grp.attr("modal_form_name")+" - add/edit "+grp.find("select").attr("name")+")");
}).always(function() {
// UNLOCK
modal.find("div.modaLoader").removeClass("show");
modal.find("button.btnAction").prop("disabled", false);
});
}
function inlineSelectManager_delete(modal, grp, url) {
var ref = parseInt(grp.find("select").val());
var nom = grp.find("select option:selected").html();
if(confirm('Etês vous sûr de vouloir supprimer '+grp.attr('value_name')+' "'+nom+'" ?')) {
// LOCK
modal.find("div.modaLoader").addClass("show");
modal.find("button.btnGroupeAction").prop("disabled", false);
var datas = { action : grp.attr("delete_action") };
datas[grp.attr("ref_attr")] = ref;
$.post( url, datas, function( result ) {
if(parseInt(result)>0) {
// REFRESH LIST
$.post( url, { action: grp.attr("refresh_list_action") }, function( result ) {
grp.find("select").html(result).val("0");
}).fail(function() {
alert("ERREUR SERVEUR ! (modal form "+grp.attr("modal_form_name")+" - delete "+grp.find("select").attr("name")+" - refresh list after)");
});
}
else { console.error(result); alert(result); }
}).fail(function() {
alert("ERREUR SERVEUR ! (modal form "+grp.attr("modal_form_name")+" - delete "+grp.find("select").attr("name")+")");
}).always(function() {
// UNLOCK
modal.find("div.modaLoader").removeClass("show");
modal.find("button.btnAction").prop("disabled", false);
});
}
}
function inlineSelectManager_getDatas(grp) {
var datas = { 'nom' : grp.find("input[name=name]").val() };
return datas;
}
function inlineSelectManager_checkDatas(datas) {
if(datas.nom=="") {
alert("Merci de renseigner un nom !");
return false;
}
return true;
}
/* AUTOCOMPLETE INPUT */
function initAutocompleteInput(form, ipt, url, action, errContext, requestDataFct, selectFct, clearFct, blurFct) {
ipt.autocomplete({
html: true,
delay: 200,
source: function(requete, reponse) {
datas = {
'action' : action,
'search' : ipt.val(),
'nohist' : true
};
if(typeof requestDataFct === 'function') datas = requestDataFct(form, ipt, datas);
$.post(url, datas, function(jsonTxt) {
datas = JSON.parse(jsonTxt);
reponse(datas);
}).fail(function() { alert("ERREUR SERVEUR !"+( (isDefined(errContext)) ? " "+errContext : "" )); });
},
focus: function(event, ui) { event.preventDefault(); },
select: function(event, ui) {
event.preventDefault();
if(typeof selectFct === 'function') selectFct(form, ipt, ui.item);
else ipt.val( ui.item.value ).attr('ref', ui.item.ref).blur();
}
});
ipt.keydown(function(e) {
if(e.keyCode==13) { e.preventDefault(); $(this).blur(); }
else if(parseInt($(this).attr('ref'))>0) {
if(typeof clearFct === 'function') clearFct(form, $(this));
else $(this).val("").removeAttr('ref');
}
});
ipt.on("blur", function(e) {
if(typeof blurFct === 'function') blurFct(form, $(this));
else if(!parseInt($(this).attr('ref'))>0) $(this).val("").removeAttr('ref');
});
}
/* LIST PROGRESS LOAD */
function initListProgressLoad(list, url, listName) {
if(isDefined(list)) {
var contentH = list.innerHeight();
list.listProgressLoad_resize();
$(window).resize( function() { list.listProgressLoad_resize(); } );
list.scroll(function(e) {
var rest = list.prop("scrollHeight") - list.innerHeight() - list.scrollTop();
if(rest<300 && list.find("td.loader").length==0 && parseInt(list.attr('rest'))>0) {
// APPEND LOADER
var tr = $("<tr class='loader'><td class='loader' colspan='17'></td></tr>");
list.append(tr);
// LOAD
$.post(url, { 'startListAt' : parseInt(list.attr('end')) }, function(jsonTxt) {
datas = JSON.parse(jsonTxt);
list.attr("start", datas.start);
list.attr("end", datas.end);
list.attr("rest", datas.rest);
list.append($(datas.list));
list.trigger( "loaded" );
tr.remove();
}).fail(function(xhr) {
errMsg = "SERVER ERROR ("+(( isDefined( listName ) && listName != "" ) ? listName : "list")+" - load items)";
if( xhr['responseText']!="" ) errMsg += " : " + xhr['responseText'];
console.error(errMsg); alert(errMsg);
});
}
});
// FORCE LOAD IF WINDOWS NOT FULL
h = $(window).innerHeight() - list.position().top;
if(parseInt(list.attr("rest"))>0 && contentH<h) list.trigger("scroll");
}
}
function registerListProgressLoadCbkFct(list, clbFct) { if( isDefined(list) && (typeof clbFct === 'function')) list.on("loaded", clbFct); }
$.fn.listProgressLoad_resize = function() {
var h = $(window).innerHeight() - $(this).position().top;
$(this).removeAttr("style");
if($(this).prop("scrollHeight") < h) $(this).parent().addClass("no-scroll");
else $(this).parent().removeClass("no-scroll");
$(this).css("height", h);
};
/* SEARCH */
$.fn.initSearchGroup = function() {
$(this).find("input[search]").unbind('keypress').keypress( function(event) {
if(event.keyCode==13) {
$(this).blur();
document.location = "?search="+$(this).val();
}
});
$(this).find(".btnClearSearch").unbind('click').click( function(event) {
event.preventDefault(); $(this).blur();
document.location = "?clearSearch";
});
}
$.fn.initFiltreSelect = function() {
// LOAD VALUE
$(this).each(function(n,e) {
if(isDefined($(this).attr("load_value"))) $(this).val($(this).attr("load_value"));
});
// SELECT
$(this).change(function(e) {
if( !isDefined( $(this).attr("filtre_request") ) ) return;
$(this).blur();
document.location = "?"+$(this).attr("filtre_request")+"="+$(this).val();
});
}
/* FONCTIONS */ /* FONCTIONS */
function getUrlParameters() { function getUrlParameters() {

View File

@ -1,376 +1,284 @@
// SETTINGS
var legumesConf = {
type : "legume",
baseURL : "legumes.php",
// LIST
list_selector : "#legumesList",
// SEARCH // SEARCH
var legumesSearch = false; search_selector : "#legumesSearch .searchGrp",
filtres_selector : "#legumesSearch select",
// VIEW // VIEW
var modalViewLegume = false; view_modalSelector : "#modalViewLegume",
var btnViewLegume = false; view_btnSelector : ".btnViewLegume",
var currentViewLegume = 0;
var legumesBaseURL = "legumes.php";
// ADD // ADD
var modalAddLegume = false; add_modalSelector : "#modalAddLegume",
var formAddLegume = false; add_btnSelector : "#btnAddLegume",
var btnAddLegume = false;
// EDIT // EDIT
var modalEditLegume = false; edit_modalSelector : "#modalEditLegume",
var formEditLegume = false; edit_btnSelector : ".btnEditLegume",
var btnEditLegume = false;
var currentEditLegume = 0;
// DELETE // DELETE
delete_modalSelector : "#modalDeleteLegume",
delete_btnSelector : ".btnDeleteLegume",
}
// MODALS
var modalViewLegume = false;
var modalAddLegume = false;
var modalEditLegume = false;
var modalDeleteLegume = false; var modalDeleteLegume = false;
var btnDeleteLegume = false;
var currentDeleteLegume = 0;
$(document).ready( function() { $(document).ready( function() {
// INIT SEARCH // LIST LOADER
legumesSearch = $("#legumesSearch"); initListProgressLoad($(legumesConf.list_selector), legumesConf.baseURL, legumesConf.type+" list");
if(legumesSearch.length>0) initSearchLegumes();
// INIT VIEW LEGUME // SEARCH
modalViewLegume = $("#modalViewLegume"); $(legumesConf.search_selector).initSearchGroup();
btnViewLegume = $(".btnViewLegume");
if(modalViewLegume.length>0 && btnViewLegume.length>0) { // VIEW
modalViewLegume = $(legumesConf.view_modalSelector);
if(modalViewLegume.length>0) {
initViewLegume(); initViewLegume();
// VIEW REQUEST // VIEW REQUEST
var id = getUrlParameter("id"); var id = getUrlParameter("ref");
if(id!==false && parseInt(id)>0) loadDatasInViewLegumeModal(id); if(id!==false && parseInt(id)>0 && current_page == "legumes") {
modalViewLegume_clear(modalViewLegume);
modalViewLegume_loadDatas(modalViewLegume, id);
}
} }
// INIT ADD LEGUME // ADD
modalAddLegume = $("#modalAddLegume"); modalAddLegume = $(legumesConf.add_modalSelector);
formAddLegume = $("#formAddLegume"); if(modalAddLegume.length>0) initAddLegume();
btnAddLegume = $("#btnAddLegume");
if(modalAddLegume.length>0 && formAddLegume.length>0 && btnAddLegume.length>0) initAddLegume();
// INIT EDIT LEGUME // EDIT
modalEditLegume = $("#modalEditLegume"); modalEditLegume = $(legumesConf.edit_modalSelector);
formEditLegume = $("#formEditLegume"); if(modalEditLegume.length>0) initEditLegume();
btnEditLegume = $(".btnEditLegume");
if(modalEditLegume.length>0 && formEditLegume.length>0 && btnEditLegume.length>0) initEditLegume();
// INIT DELETE LEGUME // DELETE
modalDeleteLegume = $("#modalDeleteLegume"); modalDeleteLegume = $(legumesConf.delete_modalSelector);
btnDeleteLegume = $(".btnDeleteLegume"); if(modalDeleteLegume.length>0) initDeleteLegume();
if(modalDeleteLegume.length>0 && btnDeleteLegume.length>0) initDeleteLegume();
}); });
/***** SEARCH LEGUMES *****/ /***** MODAL VIEW *****/
function initSearchLegumes() {
legumesSearch.find("input[name=search]").unbind('keypress').keypress( function(event) {
if(event.keyCode==13) searchLegume(false);
});
legumesSearch.find(".btnClearSearch").unbind('click').click( function(event) {
searchLegume(true);
});
}
function searchLegume(clear) {
legumesSearch.find("input[name=search]").blur();
legumesSearch.find(".btnClearSearch").blur();
if(clear) document.location = "?clearSearch";
else document.location = "?search="+legumesSearch.find("input[name=search]").val();
}
/***** VIEW LEGUME *****/
function initViewLegume() { function initViewLegume() {
// BTN VIEW // INIT VIEW BTNs
btnViewLegume.unbind('click').click( function(event) { var initBtnFct = function() { modalForm_initBtnView(
event.preventDefault(); $(legumesConf.view_btnSelector), // BTNs
id = parseInt($(this).attr('ref')); modalViewLegume, // MODAL
if(!id>0) return; modalViewLegume_clear, // CLEAR FUNCTION
clearViewLegumeModal(); modalViewLegume_loadDatas // LOAD DATAS FUNCTION
currentViewLegume = id; )};
loadDatasInViewLegumeModal(id); registerListProgressLoadCbkFct( $("tbody.progressLoadList"), initBtnFct );
}); initBtnFct();
// CANCEL // CANCEL
modalViewLegume.on('hidden.bs.modal', function (e) { modalViewLegume.on('hidden.bs.modal', function() { modalViewLegume_clear(modalViewLegume); });
clearViewLegumeModal();
currentViewLegume = 0;
});
} }
function loadDatasInViewLegumeModal(id) { function modalViewLegume_loadDatas(modal, id) {
datas = { $.post(legumesConf.baseURL, { 'ref' : id, 'action' : 'getDatas' }, function(jsonTxt) {
'ref' : id, var datas = JSON.parse(jsonTxt);
'action' : 'getDatas'
};
$.post( legumesBaseURL, datas, function( result ) {
var datas = JSON.parse(result);
modalViewLegume.find("small.db_ref > span").html(datas.ref); modal.find("small.db_ref > span").html(datas.ref);
modalViewLegume.find("td.nom").html(datas.nom); modal.find("td.nom").html(datas.nom);
modalViewLegume.find("td.tarif").html(datas.tarif_print+" <small>(depuis le "+datas.tarif_date_print+")</small>"); modal.find("td.tarif").html(datas.tarif_print+" <small>(depuis le "+datas.tarif_date_print+")</small>");
if(datas.historique_tarif.length>0) { if(datas.historique_tarif.length>0) {
modalViewLegume.find("table.modal-body tfoot").removeClass("hide"); modal.find("table.modal-body tfoot").removeClass("hide");
$.each(datas.historique_tarif, function(n,e) { addTarifLegumeHist(e); }); $.each(datas.historique_tarif, function(n,e) { addTarifLegumeHist(e); });
} }
modalViewLegume.modal('show'); modal.modal('show');
}).fail(function() { alert(srvErrorMsg+" (load modal view legume)"); }); }).fail(function() { alert("("+legumesConf.type+" - load modal view)"); });
} }
function addTarifLegumeHist(datas) { function modalViewLegume_clear(modal) {
modal.find("small.db_ref > span").html("");
modal.find("td.nom").html("");
modal.find("td.tarif").html("");
modal.find("table.modal-body tfoot").addClass("hide").find("tr:not(.header)").remove();
}
function modalViewLegume_addTarifLegumeHist(modal, datas) {
var tr = $("<tr></tr>").attr("ref", datas.ref); var tr = $("<tr></tr>").attr("ref", datas.ref);
tr.append($("<td></td>").html(datas.tarif_print)); tr.append($("<td></td>").html(datas.tarif_print));
tr.append($("<td></td>").html(datas.tarif_periode)); tr.append($("<td></td>").html(datas.tarif_periode));
btnDel = $('<button class="btn btn-xs btn-link glyphicon glyphicon-trash btnDeleteTarifLegume"></button>').attr('ref', datas.ref).attr('tarif', datas.tarif_print).attr('periode', datas.tarif_periode); btnDel = $('<button class="btn btn-xs btn-link glyphicon glyphicon-trash btnDeleteTarifLegume"></button>').attr('ref', datas.ref).attr('tarif', datas.tarif_print).attr('periode', datas.tarif_periode);
tr.append($("<td class='td_btn_action td_btn_delete'></td>").append(btnDel)); tr.append($("<td class='td_btn_action td_btn_delete'></td>").append(btnDel));
modalViewLegume.find("table.modal-body tfoot").append(tr); modal.find("table.modal-body tfoot").append(tr);
btnDel.click(function(e) { btnDel.click(function(e) {
e.preventDefault(); $(this).blur();
tr = $(this).parent().parent(); tr = $(this).parent().parent();
e.preventDefault();
$(this).blur();
id = parseInt( $(this).attr("ref") ); id = parseInt( $(this).attr("ref") );
if(!id>0) return; if(!id>0) return;
msg = "Êtes vous sûr de vouloir supprimer le tarif de "+$(this).attr("tarif")+" en application "+$(this).attr("periode")+" ?"; msg = "Êtes vous sûr de vouloir supprimer le tarif de "+$(this).attr("tarif")+" en application "+$(this).attr("periode")+" ?";
if(confirm(msg)) { if(confirm(msg)) {
datas = { datas = { 'action' : 'deleteTarif', 'tarif' : id };
'action' : 'deleteTarif', $.post( legumesConf.baseURL, datas, function( result ) {
'tarif' : id
};
$.post( legumesBaseURL, datas, function( result ) {
if(parseInt(result)>0) { if(parseInt(result)>0) {
tr.remove(); tr.remove();
if(modalViewLegume.find("table.modal-body tfoot tr:not(.header)").length == 0) modalViewLegume.find("table.modal-body tfoot").addClass("hide"); if(modal.find("table.modal-body tfoot tr:not(.header)").length == 0) modal.find("table.modal-body tfoot").addClass("hide");
} }
else { else { console.error(result); alert(result); }
console.error(result); }).fail(function() { alert("("+legumesConf.type+" - delete tarif)"); });
alert(result);
}
}).fail(function() { alert(srvErrorMsg+" (form legume - delete tarif)"); });
} }
}) })
} }
function clearViewLegumeModal() { /***** MODAL FORM ADD/EDIT *****/
modalViewLegume.find("small.db_ref > span").html(""); function modalFormLegume_init(modal) {
modal.find("form").on("submit", function(e) { e.preventDefault(); });
modalViewLegume.find("td.nom").html(""); // BTN EDIT TARIF
modalViewLegume.find("td.tarif").html(""); modal.find("button.btnEditTarif").click(function(e) {
modalViewLegume.find("table.modal-body tfoot").addClass("hide").find("tr:not(.header)").remove();
}
/***** FORM LEGUME *****/
function initFormLegume(form) {
form.on("submit", function(e) { e.preventDefault(); });
form.find("button.btnEditTarif").click(function(e) {
e.preventDefault(); e.preventDefault();
$(this).blur().addClass('hide'); $(this).blur().addClass('hide');
form.find("input[name=prix]").attr('ref', 'new').prop('disabled', false); modal.find("input[name=prix]").attr('ref', 'new').prop('disabled', false);
form.find("select[name=unite]").prop('disabled', false); modal.find("select[name=unite]").prop('disabled', false);
form.find("input[name=date]").prop('disabled', false).val(getTodayDate("yyyy-mm-dd")); modal.find("input[name=date]").prop('disabled', false).val(getTodayDate("yyyy-mm-dd"));
}); });
initFloatInput(form.find("input[name=prix]"));
// PRIX
initFloatInput(modal.find("input[name=prix]"));
} }
function loadDatasInFormLegumeDatas(modal,form,id) { function modalFormLegume_loadDatas(modal,id) {
datas = { $.post(legumesConf.baseURL, { 'ref' : id, 'action' : 'getDatas' }, function(jsonTxt) {
'ref' : id, var datas = JSON.parse(jsonTxt);
'action' : 'getDatas'
};
$.post( legumesBaseURL, datas, function( result ) {
var datas = JSON.parse(result);
form.find("input[name=nom]").val(datas.nom); modal.find("input[name=nom]").val(datas.nom);
form.find("input[name=prix]").val(datas.tarif_prix).attr('ref', datas.tarif_ref); modal.find("input[name=prix]").val(datas.tarif_prix).attr('ref', datas.tarif_ref);
form.find("select[name=unite]").val(datas.tarif_unite); modal.find("select[name=unite]").val(datas.tarif_unite);
form.find("input[name=date]").val(datas.tarif_date); modal.find("input[name=date]").val(datas.tarif_date);
if(modal) modal.modal('show'); if(modal) modal.modal('show');
}).fail(function() { alert(srvErrorMsg+" (form legume - load datas)"); }); }).fail(function() { alert("("+legumesConf.type+" - load datas in modal form)"); });
} }
function clearFormLegumeDatas(form) { function modalFormLegume_clear(modal) {
add = (form.attr('id') == "formAddLegume"); modal.removeAttr("edit_id");
modal.find("div.modaLoader").removeClass("show");
form.find("input[name=nom]").val(""); add = modal.hasClass("add");
if(add) form.find("button.btnEditTarif").addClass('hide');
else form.find("button.btnEditTarif").removeClass('hide');
form.find("input[name=prix]").val("").attr('ref', "new").prop('disabled', !add);
form.find("select[name=unite]").val("kg").prop('disabled', !add);
form.find("input[name=date]").val(getTodayDate("yyyy-mm-dd")).prop('disabled', !add);
// MODALOADER modal.find("input[name=nom]").val("");
form.find("div.modaLoader").removeClass("show"); if(add) modal.find("button.btnEditTarif").addClass('hide');
else modal.find("button.btnEditTarif").removeClass('hide');
modal.find("input[name=prix]").val("").attr('ref', "new").prop('disabled', !add);
modal.find("select[name=unite]").val("kg").prop('disabled', !add);
modal.find("input[name=date]").val(getTodayDate("yyyy-mm-dd")).prop('disabled', !add);
} }
// GET FORM DATAS function modalFormLegume_getDatas(modal) {
function getLegumeFormDatas(form) {
var datas = { var datas = {
'nom' : form.find("input[name=nom]").val(), 'nom' : modal.find("input[name=nom]").val(),
'tarif_ref' : (form.find("input[name=prix]").attr('ref')=="new") ? "new" : parseInt(form.find("input[name=prix]").attr('ref')), 'tarif_ref' : (modal.find("input[name=prix]").attr('ref')=="new") ? "new" : parseInt(modal.find("input[name=prix]").attr('ref')),
'tarif_prix' : parseFloat( form.find("input[name=prix]").val() ), 'tarif_prix' : parseFloat( modal.find("input[name=prix]").val() ),
'tarif_unite' : form.find("select[name=unite]").val(), 'tarif_unite' : modal.find("select[name=unite]").val(),
'tarif_date' : form.find("input[name=date]").val() 'tarif_date' : modal.find("input[name=date]").val()
}; };
return datas; return datas;
} }
/***** ADD LEGUME *****/ function modalFormLegume_checkDatas(datas) {
if(datas.nom=="") {
alert("ERREUR : au minimum, un nom doit être renseigné !");
return false;
}
return true;
}
/***** ADD *****/
function initAddLegume() { function initAddLegume() {
// BTN ADD // INIT FORM
btnAddLegume.unbind('click').click( function(event) { modalFormLegume_init(modalAddLegume);
event.preventDefault();
clearFormLegumeDatas(formAddLegume);
modalAddLegume.modal('show');
});
// INIT FORM ADD // INIT ADD BTN
initFormLegume(formAddLegume); modalForm_initBtnAdd(
$(legumesConf.add_btnSelector), // BTN ADD
modalAddLegume, // MODAL
modalFormLegume_clear // CLEAR FORM FUNCTION
);
// SAVE LEGUME // INIT SAVE BTN
$(".btnSaveAddLegume").unbind('click').click( function(event) { modalForm_initBtnSaveAdd(
event.preventDefault(); modalAddLegume.find(".btnSave"), // BTN SAVE
legumesConf.type, // ADD TYPE
var datas = getLegumeFormDatas(formAddLegume); modalAddLegume, // MODAL
modalFormLegume_getDatas, // GET FORM DATAS FUNCTION
if(datas.nom=="") { modalFormLegume_checkDatas, // CHECK FORM DATAS FUNCTION
alert("ERREUR : au minimum un nom doit être renseigné !"); legumesConf.baseURL // SAVE URL
return; );
}
datas.action = 'add';
formAddLegume.find("div.modaLoader").addClass("show");
$(".btnSaveAddLegume").prop("disabled", true);
$.post( legumesBaseURL, datas, function( result ) {
if(parseInt(result)>0) {
modalAddLegume.modal('hide');
setTimeout(function() {
document.location.reload();
},200);
}
else {
console.error(result);
alert(result);
formAddLegume.find("div.modaLoader").removeClass("show");
$(".btnSaveAddLegume").prop("disabled", false);
}
}).fail(function() {
alert(srvErrorMsg+" (add legume)");
formAddLegume.find("div.modaLoader").removeClass("show");
$(".btnSaveAddLegume").prop("disabled", false);
});
});
// CANCEL // CANCEL
modalAddLegume.on('hidden.bs.modal', function (e) { clearFormLegumeDatas(formAddLegume); }); modalAddLegume.on('hidden.bs.modal', function (e) { modalFormLegume_clear(modalAddLegume); });
} }
/***** EDIT LEGUME *****/ /***** EDIT *****/
function initEditLegume() { function initEditLegume() {
// BTN EDIT // INIT FORM
btnEditLegume.unbind('click').click( function(event) { modalFormLegume_init(modalEditLegume);
event.preventDefault();
id = parseInt($(this).attr('ref'));
if(!id>0) return;
currentEditLegume = id;
clearFormLegumeDatas(formEditLegume);
loadDatasInFormLegumeDatas(modalEditLegume,formEditLegume,id);
});
// INIT FORM EDIT // INIT EDIT BTNs
initFormLegume(formEditLegume); var initBtnFct = function() { modalForm_initBtnEdit(
$(legumesConf.edit_btnSelector), // BTNs
modalEditLegume, // MODAL
modalFormLegume_clear, // CLEAR FUNCTION
modalFormLegume_loadDatas // LOAD DATAS FUNCTION
)};
registerListProgressLoadCbkFct( $("tbody.progressLoadList"), initBtnFct );
initBtnFct();
// SAVE LEGUME // INIT SAVE EDIT BTN
$(".btnSaveEditLegume").unbind('click').click( function(event) { modalForm_initBtnSaveEdit(
event.preventDefault(); modalEditLegume.find(".btnSave"), // BTN SAVE
legumesConf.type, // EDIT TYPE
if(!currentEditLegume>0) return; modalEditLegume, // MODAL
modalFormLegume_getDatas, // GET FORM DATAS FUNCTION
var datas = getLegumeFormDatas(formEditLegume); modalFormLegume_checkDatas, // CHECK FORM DATAS FUNCTION
if(datas.nom=="") { legumesConf.baseURL // SAVE URL
alert("ERREUR : au minimum un nom doit être renseigné !"); );
return;
}
datas.action = 'edit';
datas.ref = currentEditLegume;
formEditLegume.find("div.modaLoader").addClass("show");
$(".btnSaveEditLegume").prop("disabled", true);
$.post( legumesBaseURL, datas, function( result ) {
if(parseInt(result)>0) {
modalEditLegume.modal('hide');
setTimeout(function() {
document.location.reload();
},200);
}
else {
console.error(result);
alert(result);
formEditLegume.find("div.modaLoader").removeClass("show");
$(".btnSaveEditLegume").prop("disabled", false);
}
}).fail(function() {
alert(srvErrorMsg+" (edit legume)");
formEditLegume.find("div.modaLoader").removeClass("show");
$(".btnSaveEditLegume").prop("disabled", false);
});
});
// CANCEL // CANCEL
modalEditLegume.on('hidden.bs.modal', function (e) { modalEditLegume.on('hidden.bs.modal', function (e) { modalFormLegume_clear(modalEditLegume); });
clearFormLegumeDatas(formEditLegume);
currentEditLegume = 0;
});
} }
/***** DELETE LEGUME *****/ /***** DELETE *****/
function initDeleteLegume() { function initDeleteLegume() {
// BTN DELETE // INIT DELETE BTNs
btnDeleteLegume.unbind('click').click( function(event) { var initBtnFct = function() { modalForm_initBtnDelete(
event.preventDefault(); $(legumesConf.delete_btnSelector), // BTNs
id = parseInt($(this).attr('ref')); modalDeleteLegume, // MODAL
if(!id>0) return; modalDeleteLegume_clear, // CLEAR MODAL FUNCTION
currentDeleteLegume = id; modalDeleteLegume_loadDatas // LOAD DATAS FUNCTION
)};
registerListProgressLoadCbkFct( $("tbody.progressLoadList"), initBtnFct );
initBtnFct();
modalDeleteLegume.find('b.name').html( $(this).attr('nom') ); // INIT SAVE DELETE BTN
modalForm_initBtnSaveDelete(
modalDeleteLegume.modal('show'); modalDeleteLegume.find(".btnSave"), // BTN SAVE
}); legumesConf.type, // DELETE TYPE
modalDeleteLegume, // MODAL
// DELETE false, // GET FORM DATAS FUNCTION
$("#btnDeleteLegume").unbind('click').click( function(event) { false, // CHECK FORM DATAS FUNCTION
event.preventDefault(); legumesConf.baseURL // SAVE URL
$(this).blur(); );
if(!currentDeleteLegume>0) return;
var datas = {
action : 'delete',
ref : currentDeleteLegume
};
$.post( legumesBaseURL, datas, function( result ) {
if(parseInt(result)>0) {
modalEditLegume.modal('hide');
setTimeout(function() {
document.location.reload();
},200);
}
else {
console.error(result);
alert(result);
}
}).fail(function() { alert(srvErrorMsg+" (delete legume)"); });
});
// CANCEL // CANCEL
modalDeleteLegume.on('hidden.bs.modal', function (e) { modalDeleteLegume.on('hidden.bs.modal', function (e) { modalDeleteLegume_clear(); });
modalDeleteLegume.find('b.name').html(""); }
currentDeleteLegume = 0;
}); function modalDeleteLegume_loadDatas(btn, id) {
modalDeleteLegume.find('b.name').html( btn.attr('nom') );
modalDeleteLegume.modal('show');
}
function modalDeleteLegume_clear() {
modalDeleteLegume.removeAttr("delete_id");
modalDeleteLegume.find('b.name').html("");
} }

File diff suppressed because it is too large Load Diff

View File

@ -1,544 +1,265 @@
// SEARCH // SETTINGS
var paniersSearch = false; var paniersConf = {
type : "panier",
baseURL : "paniers.php",
// LIST
list_selector : "#paniersList",
// SEARCH / FILTRES
search_selector : "#paniersSearch .searchGrp",
filtres_selector : "#paniersSearch select",
// VIEW // VIEW
var modalViewPanier = false; view_modalSelector : "#modalViewPanier",
var btnViewPanier = false; view_btnSelector : ".btnViewPanier",
var currentViewPanier = 0;
var paniersBaseURL = "paniers.php";
// ADD // ADD
var modalAddPanier = false; add_modalSelector : "#modalAddPanier",
var formAddPanier = false; add_btnSelector : "#btnAddPanier",
var btnAddPanier = false;
// EDIT // EDIT
var modalEditPanier = false; edit_modalSelector : "#modalEditPanier",
var formEditPanier = false; edit_btnSelector : ".btnEditPanier",
var btnEditPanier = false;
var currentEditPanier = 0;
// DELETE // DELETE
delete_modalSelector : "#modalDeletePanier",
delete_btnSelector : ".btnDeletePanier",
}
// MODALS
var modalViewPanier = false;
var modalAddPanier = false;
var modalEditPanier = false;
var modalDeletePanier = false; var modalDeletePanier = false;
var btnDeletePanier = false;
var currentDeletePanier = 0;
$(document).ready( function() { $(document).ready( function() {
// INIT SEARCH // LIST LOADER
paniersSearch = $("#paniersSearch"); initListProgressLoad($(paniersConf.list_selector), paniersConf.baseURL, paniersConf.type+" list");
if(paniersSearch.length>0) initSearchPaniers();
// INIT VIEW PANIER // SEARCH / FILTRES
modalViewPanier = $("#modalViewPanier"); $(paniersConf.search_selector).initSearchGroup();
btnViewPanier = $(".btnViewPanier"); $(paniersConf.filtres_selector).initFiltreSelect();
if(modalViewPanier.length>0 && btnViewPanier.length>0) {
// VIEW
modalViewPanier = $(paniersConf.view_modalSelector);
if(modalViewPanier.length>0) {
initViewPanier(); initViewPanier();
// VIEW REQUEST // VIEW REQUEST
var id = getUrlParameter("id"); var id = getUrlParameter("ref");
if(id!==false && parseInt(id)>0) loadDatasInViewPanierModal(id); if(id!==false && parseInt(id)>0 && current_page == "paniers") {
modalViewPanier_clear(modalViewPanier);
modalViewPanier_loadDatas(modalViewPanier, id);
}
} }
// INIT ADD PANIER // ADD
modalAddPanier = $("#modalAddPanier"); modalAddPanier = $(paniersConf.add_modalSelector);
formAddPanier = $("#formAddPanier"); if(modalAddPanier.length>0) initAddPanier();
btnAddPanier = $("#btnAddPanier");
if(modalAddPanier.length>0 && formAddPanier.length>0 && btnAddPanier.length>0) initAddPanier();
// INIT EDIT PANIER // EDIT
modalEditPanier = $("#modalEditPanier"); modalEditPanier = $(paniersConf.edit_modalSelector);
formEditPanier = $("#formEditPanier"); if(modalEditPanier.length>0) initEditPanier();
btnEditPanier = $(".btnEditPanier");
if(modalEditPanier.length>0 && formEditPanier.length>0 && btnEditPanier.length>0) initEditPanier();
// INIT DELETE PANIER // DELETE
modalDeletePanier = $("#modalDeletePanier"); modalDeletePanier = $(paniersConf.delete_modalSelector);
btnDeletePanier = $(".btnDeletePanier"); if(modalDeletePanier.length>0) initDeletePanier();
if(modalDeletePanier.length>0 && btnDeletePanier.length>0) initDeletePanier();
}); });
/***** SEARCH PANIERS *****/ /***** MODAL VIEW *****/
function initSearchPaniers() {
// SEARCH
paniersSearch.find("input[name=search]").unbind('keypress').keypress( function(event) {
if(event.keyCode==13) searchPanier(false);
});
paniersSearch.find(".btnClearSearch").unbind('click').click( function(event) {
searchPanier(true);
});
// FILTRE GROUPE
loadValue = paniersSearch.find("select[name=groupe]").attr("load_value");
paniersSearch.find("select[name=groupe]").change(function(e) {
$(this).blur();
document.location = "?groupe="+parseInt($(this).val());
}).val(loadValue);
}
function searchPanier(clear) {
paniersSearch.find("input[name=search]").blur();
paniersSearch.find(".btnClearSearch").blur();
if(clear) document.location = "?clearSearch";
else document.location = "?search="+paniersSearch.find("input[name=search]").val();
}
/***** VIEW PANIER *****/
function initViewPanier() { function initViewPanier() {
// BTN VIEW // INIT VIEW BTNs
btnViewPanier.unbind('click').click( function(event) { var initBtnFct = function() { modalForm_initBtnView(
event.preventDefault(); $(paniersConf.view_btnSelector), // BTNs
id = parseInt($(this).attr('ref')); modalViewPanier, // MODAL
if(!id>0) return; modalViewPanier_clear, // CLEAR FUNCTION
clearViewPanierModal(); modalViewPanier_loadDatas // LOAD DATAS FUNCTION
currentViewPanier = id; )};
loadDatasInViewPanierModal(id); registerListProgressLoadCbkFct( $("tbody.progressLoadList"), initBtnFct );
}); initBtnFct();
// CANCEL // CANCEL
modalViewPanier.on('hidden.bs.modal', function (e) { modalViewPanier.on('hidden.bs.modal', function() { modalViewPanier_clear(modalViewPanier); });
clearViewPanierModal();
currentViewPanier = 0;
});
} }
function loadDatasInViewPanierModal(id) { function modalViewPanier_loadDatas(modal, id) {
datas = { $.post(paniersConf.baseURL, { 'ref' : id, 'action' : 'getDatas' }, function(jsonTxt) {
'ref' : id,
'action' : 'getDatas'
};
$.post(paniersBaseURL, datas, function(jsonTxt) {
var datas = JSON.parse(jsonTxt); var datas = JSON.parse(jsonTxt);
modalViewPanier.find("small.db_ref > span").html(datas.ref); modal.find("small.db_ref > span").html(datas.ref);
modalViewPanier.find("td.nom").html(datas.nom); modal.find("td.nom").html(datas.nom);
modalViewPanier.find("td.groupe").html(datas.groupe_nom); modal.find("td.groupe").html(datas.groupe_nom);
modalViewPanier.find("td.valeur").html(number_format(datas.valeur,2)+" €"); modal.find("td.valeur").html(number_format(datas.valeur,2)+" €");
modalViewPanier.modal('show'); modal.modal('show');
}).fail(function() { alert(srvErrorMsg+" (load modal view panier)"); });; }).fail(function() { alert("("+paniersConf.type+" - load modal view)"); });
} }
function clearViewPanierModal() { function modalViewPanier_clear(modal) {
modalViewPanier.find("small.db_ref > span").html(""); modal.removeAttr("view_id");
modalViewPanier.find("td.nom").html(""); modal.find("small.db_ref > span").html("");
modalViewPanier.find("td.groupe").html("");
modalViewPanier.find("td.valeur").html(""); modal.find("td.nom").html("");
modal.find("td.groupe").html("");
modal.find("td.valeur").html("");
modal.find("table.modal-body tfoot").addClass("hide").find("tr:not(.header)").remove();
} }
/***** FORM PANIER *****/ /***** MODAL FORM ADD/EDIT *****/
function initFormPanier(form) { function modalFormPanier_init(modal) {
form.on("submit", function(e) { e.preventDefault(); }); modal.find("form").on("submit", function(e) { e.preventDefault(); });
// NOM // NOM
initFirstUpperCaseInput(form.find("input[name=nom]"), null, function() { $(this).blur(); }); initFirstUpperCaseInput(modal.find("input[name=nom]"), null, function() { $(this).blur(); });
form.find("input[name=nom]").keydown(function(e) { modal.find("input[name=nom]").keydown(function(e) {
if(e.keyCode==13) { e.preventDefault(); $(this).blur(); } if(e.keyCode==13) { e.preventDefault(); $(this).blur(); }
}); });
// GROUPE // GROUPE
form.find("select[name=groupe]").change(function(e) { inlineSelectManager_init(
$(this).blur(); modal, // MODAL
// EXISTING "panier", // MODAL FORM NAME
if(parseInt($(this).val())>0) { modal.find("select[name=groupe]").parent(), // SELECT GROUPE
switchBtnGroupeAction(form, "delete"); "le groupe de panier", // VALUE NAME
switchBtnGroupeSecondAction(form, "edit"); paniersConf.baseURL, // URL
} "groupe_ref", // REF ATTR
// CHOISIR... "add_groupe", // ADD ACTION
else { "edit_groupe", // EDIT ACTION
switchBtnGroupeAction(form, "add"); "delete_groupe", // DELETE ACTION
switchBtnGroupeSecondAction(form, "hide"); "groupes_select_list" // REFRESH LIST ACTION
} );
});
form.find("button.btnGroupeAction").click(function(e) {
e.preventDefault();
$(this).blur();
// ADD / SAVE NEW
if($(this).hasClass("add") || $(this).hasClass("save_new")) {
addInputGroupeName(form, "add");
switchBtnGroupeAction(form, "save");
switchBtnGroupeSecondAction(form, "cancel");
}
// SAVE
else if($(this).hasClass("save")) {
var ipt = form.find("input[name=groupeName]");
if(ipt.length>0) {
var ref = ipt.attr("ref");
var datas = { 'nom' : ipt.val() };
if(datas.nom=="") {
alert("Merci de renseigner le nom du groupe !");
return;
}
// ADD GROUPE
if(ref == "new") datas.action = "add_groupe";
// EDIT GROUPE
else if(parseInt(ref)>0) {
ref = parseInt(ref);
datas.action = "edit_groupe";
datas.groupe_ref = ref;
}
form.find("div.modaLoader").addClass("show");
form.find("button.btnGroupeAction").prop("disabled", true);
$.post( paniersBaseURL, datas, function( result ) {
if(parseInt(result)>0) {
switchBtnGroupeAction(form, "delete");
switchBtnGroupeSecondAction(form, "edit");
removeInputGroupeName(form);
if(ref == "new") ref = parseInt(result);
// REFRESH GROUPES LIST
$.post( paniersBaseURL, {action: "groupes_select_list"}, function( result ) {
form.find("select[name=groupe]").html(result).val(ref);
}).fail(function() { alert(srvErrorMsg+" (form panier - add/edit groupe - refresh list after)"); });
}
else {
console.error(result);
alert(result);
}
}).always(function() {
form.find("div.modaLoader").removeClass("show");
form.find("button.btnGroupeAction").prop("disabled", false);
}).fail(function() { alert(srvErrorMsg+" (form panier - add/edit groupe)"); });
}
}
// DELETE
else if($(this).hasClass("delete")) {
var ref = parseInt(form.find("select[name=groupe]").val());
var nom = form.find("select[name=groupe] option:selected").html();
if(confirm('Etês vous sûr de vouloir supprimer le groupe de panier "'+nom+'" ?')) {
form.find("div.modaLoader").addClass("show");
form.find("button.btnGroupeAction").prop("disabled", false);
var datas = { action : 'delete_groupe', groupe_ref : ref };
$.post( paniersBaseURL, datas, function( result ) {
if(parseInt(result)>0) {
// REFRESH CONTRATS TYPES LIST
$.post( paniersBaseURL, {action: "groupes_select_list"}, function( result ) {
form.find("select[name=groupe]").html(result).val("0");
}).fail(function() { alert(srvErrorMsg+" (form panier - delete groupe - refresh list after)"); });
}
else {
console.error(result);
alert(result);
}
}).always(function() {
form.find("div.modaLoader").removeClass("show");
form.find("button.btnGroupeAction").prop("disabled", false);
}).fail(function() { alert(srvErrorMsg+" (form panier - delete groupe)"); });
}
}
});
form.find("button.btnGroupeSecondAction").click(function(e) {
e.preventDefault();
$(this).blur();
// EDIT
if($(this).hasClass("edit")) {
addInputGroupeName(form, "edit");
switchBtnGroupeAction(form, "save");
switchBtnGroupeSecondAction(form, "cancel");
}
// CANCEL
else if($(this).hasClass("cancel")) {
removeInputGroupeName(form);
// EDIT
if(parseInt(form.find("select[name=groupe]").val())>0) {
switchBtnGroupeAction(form, "delete");
switchBtnGroupeSecondAction(form, "edit");
}
// ADD
else {
switchBtnGroupeAction(form, "add");
switchBtnGroupeSecondAction(form, "hide");
}
}
});
// VALEUR // VALEUR
initFloatInput(form.find("input[name=valeur]")); initFloatInput(modal.find("input[name=valeur]"));
form.find("input[name=valeur]").keydown(function(e) { modal.find("input[name=valeur]").keydown(function(e) {
if(e.keyCode==13) { e.preventDefault(); $(this).blur(); } if(e.keyCode==13) { e.preventDefault(); $(this).blur(); }
}); });
} }
function loadDatasInFormPanierDatas(modal,form,id) { function modalFormPanier_loadDatas(modal,id) {
datas = { $.post(paniersConf.baseURL, { 'ref' : id, 'action' : 'getDatas' }, function(jsonTxt) {
'ref' : id,
'action' : 'getDatas'
};
$.post(paniersBaseURL, datas, function(jsonTxt) {
var datas = JSON.parse(jsonTxt); var datas = JSON.parse(jsonTxt);
form.find("input[name=nom]").val(datas.nom); modal.find("input[name=nom]").val(datas.nom);
if(parseInt(datas.groupe_ref) > 0) { inlineSelectManager_setValue(modal.find("select[name=groupe]").parent(), datas.groupe_ref);
form.find("select[name=groupe]").val(datas.groupe_ref);
switchBtnGroupeAction(form, "delete");
switchBtnGroupeSecondAction(form, "edit");
}
else {
form.find("select[name=groupe]").val("0");
switchBtnGroupeAction(form, "add");
switchBtnGroupeSecondAction(form, "hide");
}
form.find("input[name=valeur]").val(datas.valeur); modal.find("input[name=valeur]").val(datas.valeur);
if(modal) modal.modal('show'); if(modal) modal.modal('show');
}).fail(function() { alert(srvErrorMsg+" (form panier - load datas)"); }); }).fail(function() { alert("("+paniersConf.type+" - load datas in modal form)"); });
} }
function clearFormPanierDatas(form) { function modalFormPanier_clear(modal) {
form.find("input[name=nom]").val(""); modal.removeAttr("edit_id");
modal.find("div.modaLoader").removeClass("show");
form.find("select[name=groupe]").val("0"); modal.find("input[name=nom]").val("");
removeInputGroupeName(form); inlineSelectManager_setValue(modal.find("select[name=groupe]").parent(), 0);
switchBtnGroupeAction(form, "add"); modal.find("input[name=valeur]").val("0");
switchBtnGroupeSecondAction(form, "hide");
form.find("input[name=valeur]").val("0");
// MODALOADER
form.find("div.modaLoader").removeClass("show");
} }
// GROUPE function modalFormPanier_getDatas(modal) {
function switchBtnGroupeAction(form, action) { // ADD / SAVE / DELETE
var btn = form.find("button.btnGroupeAction");
if(action == "add") {
btn.removeClass("save delete").addClass("add").removeClass("btn-danger btn-primary").addClass("btn-default")
.find("i").removeClass("glyphicon-floppy-saved glyphicon-trash").addClass("glyphicon-plus");
}
else if(action == "save") {
btn.removeClass("add save_new delete").addClass("save").removeClass("btn-danger btn-default").addClass("btn-primary")
.find("i").removeClass("glyphicon-plus glyphicon-trash").addClass("glyphicon-floppy-saved");
}
else if(action == "delete") {
btn.removeClass("add save_new save").addClass("delete").removeClass("btn-default btn-primary").addClass("btn-danger")
.find("i").removeClass("glyphicon-plus glyphicon-floppy-saved").addClass("glyphicon-trash");
}
}
function switchBtnGroupeSecondAction(form, action) { // CANCEL / EDIT
var btn = form.find("button.btnGroupeSecondAction");
if(action == "cancel") {
btn.removeClass("edit").addClass("cancel").removeClass("btn-default").addClass("btn-danger")
.find("i").removeClass("glyphicon-edit").addClass("glyphicon-floppy-remove");
btn.parent().removeClass("hide");
}
else if(action == "edit") {
btn.removeClass("cancel").addClass("edit").removeClass("btn-danger").addClass("btn-default")
.find("i").removeClass("glyphicon-floppy-remove").addClass("glyphicon-edit");
btn.parent().removeClass("hide");
}
else if(action == "hide") {
btn.parent().addClass("hide");
}
}
function addInputGroupeName(form, action) {
var select = form.find("select[name=groupe]");
var ipt = $('<input type="text" class="form-control" name="groupeName" placeholder="nom">').attr("action", action);
select.addClass("hide");
ipt.insertBefore(select);
if(action=="edit") {
ipt.attr("ref", select.val());
ipt.val( select.find("option:selected").html() );
}
else ipt.attr("ref", "new");
ipt.focus();
ipt.keypress(function(e) {
if(e.keyCode==13) {
e.preventDefault();
form.find("button.btnGroupeAction").click();
}
});
}
function removeInputGroupeName(form) {
var ipt = form.find("input[name=groupeName]");
if(ipt.length>0) ipt.remove();
form.find("select[name=groupe]").removeClass("hide");
}
// GET FORM DATAS
function getPanierFormDatas(form) {
var datas = { var datas = {
'nom' : form.find("input[name=nom]").val(), 'nom' : modal.find("input[name=nom]").val(),
'groupe' : parseInt(form.find("select[name=groupe]").val()), 'groupe' : parseInt(modal.find("select[name=groupe]").val()),
'valeur' : parseFloat(form.find("input[name=valeur]").val()) 'valeur' : parseFloat(modal.find("input[name=valeur]").val())
}; };
return datas; return datas;
} }
/***** ADD PANIER *****/ function modalFormPanier_checkDatas(datas) {
if(datas.nom=="") {
alert("ERREUR : au minimum, un nom doit être renseigné !");
return false;
}
return true;
}
/***** ADD *****/
function initAddPanier() { function initAddPanier() {
// BTN ADD // INIT FORM
btnAddPanier.unbind('click').click( function(event) { modalFormPanier_init(modalAddPanier);
event.preventDefault();
clearFormPanierDatas(formAddPanier);
modalAddPanier.modal('show');
});
// INIT FORM ADD // INIT ADD BTN
initFormPanier(formAddPanier); modalForm_initBtnAdd(
$(paniersConf.add_btnSelector), // BTN ADD
modalAddPanier, // MODAL
modalFormPanier_clear // CLEAR FORM FUNCTION
);
// SAVE PANIER // INIT SAVE BTN
$(".btnSaveAddPanier").unbind('click').click( function(event) { modalForm_initBtnSaveAdd(
event.preventDefault(); modalAddPanier.find(".btnSave"), // BTN SAVE
paniersConf.type, // ADD TYPE
var datas = getPanierFormDatas(formAddPanier); modalAddPanier, // MODAL
if(datas.nom=="" || !datas.groupe>0) { modalFormPanier_getDatas, // GET FORM DATAS FUNCTION
alert("ERREUR : au minimum, un nom et un groupe doivent être renseigné !"); modalFormPanier_checkDatas, // CHECK FORM DATAS FUNCTION
return; paniersConf.baseURL // SAVE URL
} );
datas.action = 'add';
formAddPanier.find("div.modaLoader").addClass("show");
$(".btnSaveAddPanier").prop("disabled", true);
$.post( paniersBaseURL, datas, function( result ) {
if(parseInt(result)>0) {
modalAddPanier.modal('hide');
setTimeout(function() {
document.location.reload();
},200);
}
else {
console.error(result);
alert(result);
formAddPanier.find("div.modaLoader").removeClass("show");
$(".btnSaveAddPanier").prop("disabled", false);
}
}).fail( function() {
alert(srvErrorMsg+" (add panier)");
formAddPanier.find("div.modaLoader").removeClass("show");
$(".btnSaveAddPanier").prop("disabled", false);
});
});
// CANCEL // CANCEL
modalAddPanier.on('hidden.bs.modal', function (e) { clearFormPanierDatas(formAddPanier); }); modalAddPanier.on('hidden.bs.modal', function (e) { modalFormPanier_clear(modalAddPanier); });
} }
/***** EDIT PANIER *****/ /***** EDIT *****/
function initEditPanier() { function initEditPanier() {
// BTN EDIT // INIT FORM
btnEditPanier.unbind('click').click( function(event) { modalFormPanier_init(modalEditPanier);
event.preventDefault();
id = parseInt($(this).attr('ref'));
if(!id>0) return;
currentEditPanier = id;
clearFormPanierDatas(formEditPanier);
loadDatasInFormPanierDatas(modalEditPanier,formEditPanier,id);
});
// INIT FORM EDIT // INIT EDIT BTNs
initFormPanier(formEditPanier); var initBtnFct = function() { modalForm_initBtnEdit(
$(paniersConf.edit_btnSelector), // BTNs
modalEditPanier, // MODAL
modalFormPanier_clear, // CLEAR FUNCTION
modalFormPanier_loadDatas // LOAD DATAS FUNCTION
)};
registerListProgressLoadCbkFct( $("tbody.progressLoadList"), initBtnFct );
initBtnFct();
// SAVE PANIER // INIT SAVE EDIT BTN
$(".btnSaveEditPanier").unbind('click').click( function(event) { modalForm_initBtnSaveEdit(
event.preventDefault(); modalEditPanier.find(".btnSave"), // BTN SAVE
paniersConf.type, // EDIT TYPE
if(!currentEditPanier>0) return; modalEditPanier, // MODAL
modalFormPanier_getDatas, // GET FORM DATAS FUNCTION
var datas = getPanierFormDatas(formEditPanier); modalFormPanier_checkDatas, // CHECK FORM DATAS FUNCTION
if(datas.nom=="" || !datas.groupe>0) { paniersConf.baseURL // SAVE URL
alert("ERREUR : au minimum, un nom et un groupe doivent être renseigné !"); );
return;
}
datas.action = 'edit';
datas.ref = currentEditPanier;
formEditPanier.find("div.modaLoader").addClass("show");
$(".btnSaveEditPanier").prop("disabled", true);
$.post( paniersBaseURL, datas, function( result ) {
if(parseInt(result)>0) {
modalEditPanier.modal('hide');
setTimeout(function() {
document.location.reload();
},200);
}
else {
console.error(result);
alert(result);
formEditPanier.find("div.modaLoader").removeClass("show");
$(".btnSaveEditPanier").prop("disabled", false);
}
}).fail( function() {
alert(srvErrorMsg+" (edit panier)");
formEditPanier.find("div.modaLoader").removeClass("show");
$(".btnSaveEditPanier").prop("disabled", false);
});
});
// CANCEL // CANCEL
modalEditPanier.on('hidden.bs.modal', function (e) { modalEditPanier.on('hidden.bs.modal', function (e) { modalFormPanier_clear(modalEditPanier); });
clearFormPanierDatas(formEditPanier);
currentEditPanier = 0;
});
} }
/***** DELETE PANIER *****/ /***** DELETE *****/
function initDeletePanier() { function initDeletePanier() {
// BTN DELETE // INIT DELETE BTNs
btnDeletePanier.unbind('click').click( function(event) { var initBtnFct = function() { modalForm_initBtnDelete(
event.preventDefault(); $(paniersConf.delete_btnSelector), // BTNs
id = parseInt($(this).attr('ref')); modalDeletePanier, // MODAL
if(!id>0) return; modalDeletePanier_clear, // CLEAR MODAL FUNCTION
currentDeletePanier = id; modalDeletePanier_loadDatas // LOAD DATAS FUNCTION
)};
registerListProgressLoadCbkFct( $("tbody.progressLoadList"), initBtnFct );
initBtnFct();
modalDeletePanier.find('b.name').html( $(this).attr('nom') ); // INIT SAVE DELETE BTN
modalForm_initBtnSaveDelete(
modalDeletePanier.modal('show'); modalDeletePanier.find(".btnSave"), // BTN SAVE
}); paniersConf.type, // DELETE TYPE
modalDeletePanier, // MODAL
// DELETE false, // GET FORM DATAS FUNCTION
$("#btnDeletePanier").unbind('click').click( function(event) { false, // CHECK FORM DATAS FUNCTION
event.preventDefault(); paniersConf.baseURL // SAVE URL
$(this).blur(); );
if(!currentDeletePanier>0) return;
var datas = {
action : 'delete',
ref : currentDeletePanier
};
$.post( paniersBaseURL, datas, function( result ) {
if(parseInt(result)>0) {
modalEditPanier.modal('hide');
setTimeout(function() {
document.location.reload();
},200);
}
else {
console.error(result);
alert(result);
}
}).fail(function() { alert(srvErrorMsg+" (delete panier)"); });
});
// CANCEL // CANCEL
modalDeletePanier.on('hidden.bs.modal', function (e) { modalDeletePanier.on('hidden.bs.modal', function (e) { modalDeletePanier_clear(); });
modalDeletePanier.find('b.name').html(""); }
currentDeletePanier = 0;
}); function modalDeletePanier_loadDatas(btn, id) {
modalDeletePanier.find('b.name').html( btn.attr('nom') );
modalDeletePanier.modal('show');
}
function modalDeletePanier_clear() {
modalDeletePanier.removeAttr("delete_id");
modalDeletePanier.find('b.name').html("");
} }

View File

@ -89,12 +89,30 @@ switch($action) {
case "autocomplete_list": die( json_encode( getLegumesAutocompleteList() ) ); break; case "autocomplete_list": die( json_encode( getLegumesAutocompleteList() ) ); break;
// DEFAULT - LIST // DEFAULT - LIST
default: { default: {
// LIST // SEARCH
$search = getSearch("legumes_search"); $search = getSearch("legumes_search");
// LIMITS
$limits = array("start" => 0, "end" => LIST_NB_LIGNES_PAR_PAGE, "nbItemsByPage" => LIST_NB_LIGNES_PAR_PAGE, "max" => getNbLegumesInList($search));
if(isset($_REQUEST['startListAt']) && (int)$_REQUEST['startListAt']>0) {
$limits['start'] = intval($_REQUEST['startListAt']);
$limits['end'] = $limits['start'] + $limits['nbItemsByPage'];
if($limits['end'] > $limits['max']) $limits['end'] = $limits['max'];
}
$limits['rest'] = $limits['max'] - $limits['end'];
$GLOBALS['smarty'] -> assign('list_limits',$limits);
// LIST
$order = getListOrder('legumes_list_order', 'legumes_list_sens', $allowLegumesListOrder, 'prenom'); $order = getListOrder('legumes_list_order', 'legumes_list_sens', $allowLegumesListOrder, 'prenom');
$list = getLegumesList($order["order"], $order["sens"], $search); $list = getLegumesList($order["order"], $order["sens"], $search, $limits);
$GLOBALS['smarty'] -> assign('list',$list); $GLOBALS['smarty'] -> assign('list',$list);
// LIST PART
if(isset($_REQUEST['startListAt']) && (int)$_REQUEST['startListAt']>0) {
$limits["list"] = $GLOBALS['smarty']->fetch("legumes/legumes_list_builder.tpl");
die(json_encode($limits));
}
// TEMPLATE // TEMPLATE
$GLOBALS['template'] = 'legumes/legumes_list.tpl'; $GLOBALS['template'] = 'legumes/legumes_list.tpl';
$jsFiles[] = PUBLIC_HTML_ADMIN.'js/legumes.js'; $jsFiles[] = PUBLIC_HTML_ADMIN.'js/legumes.js';

View File

@ -173,14 +173,34 @@ switch($action) {
} break; } break;
// DEFAULT - LIST // DEFAULT - LIST
default: { default: {
// LIST // GROUPE
$groupesList = getPaniersGroupesList(); $groupesList = getPaniersGroupesList();
$groupe = getRequestAndSessionSave("groupe", "livraisons_list_groupe", "groupe", "int", 0, $groupesList, true); $groupe = getRequestAndSessionSave("groupe", "livraisons_list_groupe", "groupe", "int", 0, $groupesList, true);
// ARCHIVE
$archive = getRequestAndSessionSave("archive", "livraisons_list_archive", "archive", "int", 0); $archive = getRequestAndSessionSave("archive", "livraisons_list_archive", "archive", "int", 0);
// LIMITS
$limits = array("start" => 0, "end" => LIST_NB_LIGNES_PAR_PAGE, "nbItemsByPage" => LIST_NB_LIGNES_PAR_PAGE, "max" => getNbLivraisonsInList($groupe, $archive));
if(isset($_REQUEST['startListAt']) && (int)$_REQUEST['startListAt']>0) {
$limits['start'] = intval($_REQUEST['startListAt']);
$limits['end'] = $limits['start'] + $limits['nbItemsByPage'];
if($limits['end'] > $limits['max']) $limits['end'] = $limits['max'];
}
$limits['rest'] = $limits['max'] - $limits['end'];
$GLOBALS['smarty'] -> assign('list_limits',$limits);
// LIST
$order = getListOrder('livraisons_list_order', 'livraisons_list_sens', $allowLivraisonsListOrder, "date", "DESC"); $order = getListOrder('livraisons_list_order', 'livraisons_list_sens', $allowLivraisonsListOrder, "date", "DESC");
$list = getLivraisonsList($order["order"], $order["sens"], $groupe, $archive); $list = getLivraisonsList($order["order"], $order["sens"], $groupe, $archive, $limits);
$GLOBALS['smarty'] -> assign('list',$list); $GLOBALS['smarty'] -> assign('list',$list);
// LIST PART
if(isset($_REQUEST['startListAt']) && (int)$_REQUEST['startListAt']>0) {
$limits["list"] = $GLOBALS['smarty']->fetch("livraisons/livraisons_list_builder.tpl");
die(json_encode($limits));
}
// TEMPLATE // TEMPLATE
$GLOBALS['template'] = 'livraisons/livraisons_list.tpl'; $GLOBALS['template'] = 'livraisons/livraisons_list.tpl';
$jsFiles[] = PUBLIC_HTML_ADMIN.'js/livraisons.js'; $jsFiles[] = PUBLIC_HTML_ADMIN.'js/livraisons.js';

View File

@ -58,7 +58,7 @@ switch($action) {
$id = isset($_REQUEST['groupe_ref']) ? intval($_REQUEST['groupe_ref']) : 0; $id = isset($_REQUEST['groupe_ref']) ? intval($_REQUEST['groupe_ref']) : 0;
if($id>0) { if($id>0) {
$datas = getPaniersGroupeDatasFromRequest(); $datas = getPaniersGroupeDatasFromRequest();
die( strval( updatePaniersGroupe($datas) ) ); die( strval( updatePaniersGroupe($id, $datas) ) );
} }
else die("ERREUR : aucune référence de groupe transmis..."); else die("ERREUR : aucune référence de groupe transmis...");
} break; } break;
@ -88,14 +88,34 @@ switch($action) {
} break; } break;
// DEFAULT - LIST // DEFAULT - LIST
default: { default: {
// LIST // GROUPE
$groupesList = getPaniersGroupesList(); $groupesList = getPaniersGroupesList();
$groupe = getRequestAndSessionSave("groupe", "paniers_filtre_groupe", "groupe", "int", 0, $groupesList, true); $groupe = getRequestAndSessionSave("groupe", "paniers_filtre_groupe", "groupe", "int", 0, $groupesList, true);
// SEARCH
$search = getSearch("paniers_search"); $search = getSearch("paniers_search");
// LIMITS
$limits = array("start" => 0, "end" => LIST_NB_LIGNES_PAR_PAGE, "nbItemsByPage" => LIST_NB_LIGNES_PAR_PAGE, "max" => getNbPaniersInList($search, $groupe));
if(isset($_REQUEST['startListAt']) && (int)$_REQUEST['startListAt']>0) {
$limits['start'] = intval($_REQUEST['startListAt']);
$limits['end'] = $limits['start'] + $limits['nbItemsByPage'];
if($limits['end'] > $limits['max']) $limits['end'] = $limits['max'];
}
$limits['rest'] = $limits['max'] - $limits['end'];
$GLOBALS['smarty'] -> assign('list_limits',$limits);
// LIST
$order = getListOrder('paniers_list_order', 'paniers_list_sens', $allowPaniersTypesListOrder); $order = getListOrder('paniers_list_order', 'paniers_list_sens', $allowPaniersTypesListOrder);
$list = getPaniersTypesList($order["order"], $order["sens"], $search, $groupe); $list = getPaniersTypesList($order["order"], $order["sens"], $search, $groupe, $limits);
$GLOBALS['smarty'] -> assign('list',$list); $GLOBALS['smarty'] -> assign('list',$list);
// LIST PART
if(isset($_REQUEST['startListAt']) && (int)$_REQUEST['startListAt']>0) {
$limits["list"] = $GLOBALS['smarty']->fetch("paniers/paniers_list_builder.tpl");
die(json_encode($limits));
}
// TEMPLATE // TEMPLATE
$GLOBALS['template'] = 'paniers/paniers_list.tpl'; $GLOBALS['template'] = 'paniers/paniers_list.tpl';
$jsFiles[] = PUBLIC_HTML_ADMIN.'js/paniers.js'; $jsFiles[] = PUBLIC_HTML_ADMIN.'js/paniers.js';

View File

@ -11,12 +11,12 @@
</h2> </h2>
</div> </div>
<div class="modal-body formClient"> <div class="modal-body formClient">
<ul class="nav nav-tabs formClientTabs"> <ul class="nav nav-tabs formTabsBtns">
<li role="presentation" class="active"><a href="#" class="formClientTabBtn" tab="tabInfos">Informations</a></li> <li role="presentation" class="active"><a href="#" class="formTabBtn" tab="tabInfos">Informations</a></li>
<li role="presentation"><a href="#" class="formClientTabBtn" tab="tabContrats">Contrats</a></li> <li role="presentation"><a href="#" class="formTabBtn" tab="tabContrats">Contrats</a></li>
<li role="presentation"><a href="#" class="formClientTabBtn" tab="tabAbsences">Absences</a></li> <li role="presentation"><a href="#" class="formTabBtn" tab="tabAbsences">Absences</a></li>
</ul> </ul>
<div class="formClientTabs"> <div class="formTabs">
<div class="tab tabInfos active"> <div class="tab tabInfos active">
<table class="table modal-body"> <table class="table modal-body">
<tr><th>nom :</th><td class="nom"></td></tr> <tr><th>nom :</th><td class="nom"></td></tr>

View File

@ -1,14 +1,14 @@
{if !$frameDisplay}{include file='structure/top.tpl'}{/if} {if !$frameDisplay}{include file='structure/top.tpl'}{/if}
<table class="table table-hover"> <table class="table table-hover scrollingTableList">
<thead> <thead>
<th style="width:45px;" class="center visible-lg"> <th class="center visible-lg id">
<a href={if $order=="ref" && $sens=="ASC"}"?order=ref&sens=DESC" <a href={if $order=="ref" && $sens=="ASC"}"?order=ref&sens=DESC"
{else}"?order=ref&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=ref&sens=ASC"{/if} style="text-decoration: none;">
#{if $order=="ref"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} #{if $order=="ref"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th> <th class="name">
<a href={if $order=="prenom" && $sens=="ASC"}"?order=prenom&sens=DESC" <a href={if $order=="prenom" && $sens=="ASC"}"?order=prenom&sens=DESC"
{else}"?order=prenom&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=prenom&sens=ASC"{/if} style="text-decoration: none;">
{if $order=="prenom"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}prénom {if $order=="prenom"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}prénom
@ -18,36 +18,22 @@
nom{if $order=="nom"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} nom{if $order=="nom"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th class="visible-md visible-lg"> <th class="visible-md visible-lg tel">
<a href={if $order=="tel" && $sens=="ASC"}"?order=tel&sens=DESC" <a href={if $order=="tel" && $sens=="ASC"}"?order=tel&sens=DESC"
{else}"?order=tel&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=tel&sens=ASC"{/if} style="text-decoration: none;">
téléphone{if $order=="tel"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} téléphone{if $order=="tel"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th class="visible-md visible-lg"> <th class="visible-md visible-lg email">
<a href={if $order=="email" && $sens=="ASC"}"?order=email&sens=DESC" <a href={if $order=="email" && $sens=="ASC"}"?order=email&sens=DESC"
{else}"?order=email&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=email&sens=ASC"{/if} style="text-decoration: none;">
email{if $order=="email"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} email{if $order=="email"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th style="width: 30px;"></th> <th class="btn_action right" colspan="2"><button class="btn btn-xs btn-info glyphicon glyphicon-plus" id="btnAddClient"></button></th>
<th style="width: 30px;"><button class="btn btn-xs btn-info glyphicon glyphicon-plus" id="btnAddClient"></button></th>
</thead> </thead>
<tbody class="table"> <tbody class="table progressLoadList" id="clientsList" start="{$list_limits.start}" end="{$list_limits.end}" rest="{$list_limits.rest}">
{foreach from=$list item=i} {include file='clients/clients_list_builder.tpl'}
<tr>
<td class="center visible-lg">{$i.ref}</td>
<td><a href="#" class="btnViewClient" ref={$i.ref}>{$i.prenom} {$i.nom}</a></td>
<td class="visible-md visible-lg">{if $i.tel}<a href="tel:{$i.tel}">{$i.tel}</a>{else}.{/if}</td>
<td class="visible-md visible-lg">{if $i.email}<a href="mailto:{$i.email}">{$i.email}</a>{else}.{/if}</td>
<td class="td_btn_action"><button class="btn btn-xs btn-link glyphicon glyphicon-edit btnEditClient" ref="{$i.ref}"></button></td>
<td class="td_btn_action td_btn_delete"><button class="btn btn-xs btn-link glyphicon glyphicon-trash btnDeleteClient" ref="{$i.ref}" nom="{$i.nom} {$i.prenom}"></button></td>
</tr>
{foreachelse}
<tr>
<td colspan="6">aucun client</td>
</tr>
{/foreach}
</tbody> </tbody>
</table> </table>
@ -60,7 +46,7 @@
<div class="modal-header"> <div class="modal-header">
<div class="pull-right hidden-xs"> <div class="pull-right hidden-xs">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveAddClient">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
<h2 class="modal-title"> <h2 class="modal-title">
@ -69,14 +55,14 @@
</h2> </h2>
</div> </div>
<div class="modal-body"> <div class="modal-body">
<form id="formAddClient" class="formClient"> <form class="formClient">
{include file='clients/client_form.tpl'} {include file='clients/client_form.tpl'}
</form> </form>
</div> </div>
<div class="modal-footer visible-xs"> <div class="modal-footer visible-xs">
<div class="pull-right"> <div class="pull-right">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveAddClient">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
</div> </div>
</div> </div>
@ -91,7 +77,7 @@
<div class="modal-header"> <div class="modal-header">
<div class="pull-right hidden-xs"> <div class="pull-right hidden-xs">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveEditClient">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
<h2 class="modal-title"> <h2 class="modal-title">
@ -100,14 +86,14 @@
</h2> </h2>
</div> </div>
<div class="modal-body"> <div class="modal-body">
<form id="formEditClient" class="formClient"> <form class="formClient">
{include file='clients/client_form.tpl'} {include file='clients/client_form.tpl'}
</form> </form>
</div> </div>
<div class="modal-footer visible-xs"> <div class="modal-footer visible-xs">
<div class="pull-right"> <div class="pull-right">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveEditClient">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
</div> </div>
</div> </div>
@ -130,7 +116,7 @@
</div> </div>
<div class="modal-footer"> <div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-danger" id="btnDeleteClient">Confirmer</button> <button type="button" class="btn btn-danger btnSave">Confirmer</button>
</div> </div>
</div> </div>
</div> </div>

View File

@ -0,0 +1,14 @@
{foreach from=$list item=i}
<tr>
<td class="center visible-lg id">{$i.ref}</td>
<td class="name"><a href="#" class="btnViewClient" ref={$i.ref}>{$i.prenom} {$i.nom}</a></td>
<td class="visible-md visible-lg tel">{if $i.tel}<a href="tel:{$i.tel}">{$i.tel}</a>{else}.{/if}</td>
<td class="visible-md visible-lg email">{if $i.email}<a href="mailto:{$i.email}">{$i.email}</a>{else}.{/if}</td>
<td class="td_btn_action"><button class="btn btn-xs btn-link glyphicon glyphicon-edit btnEditClient" ref="{$i.ref}"></button></td>
<td class="td_btn_action td_btn_delete"><button class="btn btn-xs btn-link glyphicon glyphicon-trash btnDeleteClient" ref="{$i.ref}" nom="{$i.nom} {$i.prenom}"></button></td>
</tr>
{foreachelse}
<tr>
<td colspan="6">aucun client</td>
</tr>
{/foreach}

View File

@ -4,7 +4,7 @@
<button type="button" class="navbar-toggle"><span class="glyphicon glyphicon-filter"></span></button> <button type="button" class="navbar-toggle"><span class="glyphicon glyphicon-filter"></span></button>
<a class="navbar-brand brand"> <a class="navbar-brand brand">
<img src="img/clients.svg" class="hidden-xs"> <img src="img/clients.svg" class="hidden-xs">
<span>{$list|@count} CLIENT{if $list|@count>1}S{/if}</span> <span>{$list_limits.max} CLIENT{if $list_limits.max>1}S{/if}</span>
</a> </a>
</div> </div>
<div class="collapse navbar-collapse"> <div class="collapse navbar-collapse">

View File

@ -11,12 +11,12 @@
<div class="input-group"> <div class="input-group">
<select class="form-control" name="type">{include file='contrats/contrats_types_select_list.tpl'}</select> <select class="form-control" name="type">{include file='contrats/contrats_types_select_list.tpl'}</select>
<span class="input-group-btn hide"> <span class="input-group-btn hide">
<button class="btn btn-default btnContratTypeSecondAction"> <button class="btn btn-default btnSecondAction">
<i class="glyphicon glyphicon-remove"></i> <i class="glyphicon glyphicon-remove"></i>
</button> </button>
</span> </span>
<span class="input-group-btn"> <span class="input-group-btn">
<button class="btn btn-default btnContratTypeAction add"> <button class="btn btn-default btnAction add">
<i class="glyphicon glyphicon-plus"></i> <i class="glyphicon glyphicon-plus"></i>
</button> </button>
</span> </span>
@ -54,12 +54,12 @@
<div class="input-group"> <div class="input-group">
<select class="form-control" name="lieu_depot">{include file='contrats/lieux_select_list.tpl'}</select> <select class="form-control" name="lieu_depot">{include file='contrats/lieux_select_list.tpl'}</select>
<span class="input-group-btn hide"> <span class="input-group-btn hide">
<button class="btn btn-default btnLieuSecondAction"> <button class="btn btn-default btnSecondAction">
<i class="glyphicon glyphicon-remove"></i> <i class="glyphicon glyphicon-remove"></i>
</button> </button>
</span> </span>
<span class="input-group-btn"> <span class="input-group-btn">
<button class="btn btn-default btnLieuAction add"> <button class="btn btn-default btnAction add">
<i class="glyphicon glyphicon-plus"></i> <i class="glyphicon glyphicon-plus"></i>
</button> </button>
</span> </span>

View File

@ -11,13 +11,13 @@
</h2> </h2>
</div> </div>
<div class="modal-body formContrat"> <div class="modal-body formContrat">
<ul class="nav nav-tabs formContratTabs"> <ul class="nav nav-tabs formTabsBtns">
<li role="presentation" class="active"><a href="#" class="formContratTabBtn" tab="tabInfos">Informations</a></li> <li role="presentation" class="active"><a href="#" class="formTabBtn" tab="tabInfos">Informations</a></li>
<li role="presentation"><a href="#" class="formContratTabBtn" tab="tabPaniers">Paniers Livrés</a></li> <li role="presentation"><a href="#" class="formTabBtn" tab="tabPaniers">Paniers Livrés</a></li>
</ul> </ul>
<div class="formContratTabs"> <div class="formTabs">
<div class="tab tabInfos active"> <div class="tab tabInfos active">
<table class="table"> <table class="table modal-body">
<tr><th>type de contrat :</th><td class="type"></td></tr> <tr><th>type de contrat :</th><td class="type"></td></tr>
<tr><th>client :</th><td class="client"></td></tr> <tr><th>client :</th><td class="client"></td></tr>
<tr><th>date de début :</th><td class="date"></td></tr> <tr><th>date de début :</th><td class="date"></td></tr>

View File

@ -1,14 +1,14 @@
{if !$frameDisplay}{include file='structure/top.tpl'}{/if} {if !$frameDisplay}{include file='structure/top.tpl'}{/if}
<table class="table table-hover"> <table class="table table-hover scrollingTableList">
<thead> <thead>
<th style="width:45px;" class="center visible-lg"> <th class="center visible-lg id">
<a href={if $order=="ref" && $sens=="ASC"}"?order=ref&sens=DESC" <a href={if $order=="ref" && $sens=="ASC"}"?order=ref&sens=DESC"
{else}"?order=ref&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=ref&sens=ASC"{/if} style="text-decoration: none;">
#{if $order=="ref"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} #{if $order=="ref"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th> <th class="name">
<a href={if $order=="prenom" && $sens=="ASC"}"?order=prenom&sens=DESC" <a href={if $order=="prenom" && $sens=="ASC"}"?order=prenom&sens=DESC"
{else}"?order=prenom&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=prenom&sens=ASC"{/if} style="text-decoration: none;">
{if $order=="prenom"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}prénom {if $order=="prenom"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}prénom
@ -18,86 +18,58 @@
nom{if $order=="nom"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} nom{if $order=="nom"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th class="visible-lg"> <th class="visible-lg groupe">
<a href={if $order=="groupe" && $sens=="ASC"}"?order=groupe&sens=DESC" <a href={if $order=="groupe" && $sens=="ASC"}"?order=groupe&sens=DESC"
{else}"?order=groupe&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=groupe&sens=ASC"{/if} style="text-decoration: none;">
groupe{if $order=="groupe"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} groupe{if $order=="groupe"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th class="visible-lg"> <th class="visible-lg contrat_type">
<a href={if $order=="type" && $sens=="ASC"}"?order=type&sens=DESC" <a href={if $order=="type" && $sens=="ASC"}"?order=type&sens=DESC"
{else}"?order=type&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=type&sens=ASC"{/if} style="text-decoration: none;">
type{if $order=="type"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} type{if $order=="type"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th class="visible-md visible-lg center"> <th class="visible-md visible-lg center date">
<a href={if $order=="date" && $sens=="ASC"}"?order=date&sens=DESC" <a href={if $order=="date" && $sens=="ASC"}"?order=date&sens=DESC"
{else}"?order=date&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=date&sens=ASC"{/if} style="text-decoration: none;">
début de contrat{if $order=="date"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} début de contrat{if $order=="date"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th class="visible-md visible-lg center"> <th class="visible-md visible-lg center freq">
<a href={if $order=="frequence" && $sens=="ASC"}"?order=frequence&sens=DESC" <a href={if $order=="frequence" && $sens=="ASC"}"?order=frequence&sens=DESC"
{else}"?order=frequence&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=frequence&sens=ASC"{/if} style="text-decoration: none;">
fréquence{if $order=="frequence"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} fréquence{if $order=="frequence"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th class="visible-md visible-lg center"> <th class="visible-md visible-lg center panier_type">
<a href={if $order=="panier_type" && $sens=="ASC"}"?order=panier_type&sens=DESC" <a href={if $order=="panier_type" && $sens=="ASC"}"?order=panier_type&sens=DESC"
{else}"?order=panier_type&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=panier_type&sens=ASC"{/if} style="text-decoration: none;">
type de panier{if $order=="panier_type"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} type de panier{if $order=="panier_type"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th class="visible-md visible-lg center"> <th class="visible-md visible-lg center items_long">
<a href={if $order=="nb_paniers_livre" && $sens=="ASC"}"?order=nb_paniers_livre&sens=DESC" <a href={if $order=="nb_paniers_livre" && $sens=="ASC"}"?order=nb_paniers_livre&sens=DESC"
{else}"?order=nb_paniers_livre&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=nb_paniers_livre&sens=ASC"{/if} style="text-decoration: none;">
nb. de paniers livrés{if $order=="nb_paniers_livres"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} livrés{if $order=="nb_paniers_livre"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th class="visible-lg center"> <th class="visible-lg center items_long">
<a href={if $order=="nb_paniers_restant" && $sens=="ASC"}"?order=nb_paniers_restant&sens=DESC" <a href={if $order=="nb_paniers_restant" && $sens=="ASC"}"?order=nb_paniers_restant&sens=DESC"
{else}"?order=nb_paniers_restant&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=nb_paniers_restant&sens=ASC"{/if} style="text-decoration: none;">
nb. de paniers restants{if $order=="nb_paniers_restants"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} restants{if $order=="nb_paniers_restant"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th class="visible-md visible-lg center"> <th class="visible-md visible-lg center lieu">
<a href={if $order=="lieu_depot" && $sens=="ASC"}"?order=lieu_depot&sens=DESC" <a href={if $order=="lieu_depot" && $sens=="ASC"}"?order=lieu_depot&sens=DESC"
{else}"?order=lieu_depot&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=lieu_depot&sens=ASC"{/if} style="text-decoration: none;">
lieu de dépôt{if $order=="lieu_depot"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} lieu de dépôt{if $order=="lieu_depot"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th style="width: 30px;"></th> <th class="btn_action right" colspan="2"><button class="btn btn-xs btn-info glyphicon glyphicon-plus" id="btnAddContrat"></button></th>
<th style="width: 30px;"><button class="btn btn-xs btn-info glyphicon glyphicon-plus" id="btnAddContrat"></button></th>
</thead> </thead>
<tbody class="table"> <tbody class="table progressLoadList" id="contratsList" start="{$list_limits.start}" end="{$list_limits.end}" rest="{$list_limits.rest}">
{foreach from=$list item=i} {include file='contrats/contrats_list_builder.tpl'}
<tr class="{if $i.archive>0}archive{/if}{if $i.warning_nb_paniers} warning{/if}{if $i.nb_paniers_restants<=0} danger{/if}">
<td class="center visible-lg">{$i.ref}</td>
<td><a href="#" class="btnViewContrat" ref={$i.ref}>{$i.client_prenom} {$i.client_nom}</a></td>
<td class="visible-lg">{$i.groupe_nom}</td>
<td class="visible-lg">{$i.type_nom}</td>
<td class="visible-md visible-lg center">{$i.date_print}</td>
<td class="visible-md visible-lg center">{$i.frequence_print}</td>
<td class="visible-md visible-lg center">{$i.panier_type_nom}</td>
<td class="visible-md visible-lg center">{$i.nb_paniers_livres} / {$i.nb_paniers}</td>
<td class="visible-lg center">{$i.nb_paniers_restants}{if $i.force_eligible>0} <i class="glyphicon glyphicon-star"></i>{/if}</td>
<td class="visible-md visible-lg center">{$i.lieu_depot_nom}</td>
<td class="td_btn_action"><button class="btn btn-xs btn-link glyphicon glyphicon-edit btnEditContrat" ref="{$i.ref}"></button></td>
{if $i.nb_paniers_livres_absolute>0}
{if $i.archive>0}
<td class="td_btn_action td_btn_unarchive"><button class="btn btn-xs btn-link glyphicon glyphicon-folder-open btnUnarchiveContrat" ref="{$i.ref}" nom="{$i.client_prenom} {$i.client_nom}"></button></td>
{else}
<td class="td_btn_action td_btn_archive"><button class="btn btn-xs btn-link glyphicon glyphicon-folder-close btnArchiveContrat" ref="{$i.ref}" nom="{$i.client_prenom} {$i.client_nom}"></button></td>
{/if}
{else}
<td class="td_btn_action td_btn_delete"><button class="btn btn-xs btn-link glyphicon glyphicon-trash btnDeleteContrat" ref="{$i.ref}" nom="{$i.client_prenom} {$i.client_nom}"></button></td>
{/if}
</tr>
{foreachelse}
<tr>
<td colspan="12">aucun contrat</td>
</tr>
{/foreach}
</tbody> </tbody>
</table> </table>
@ -110,23 +82,22 @@
<div class="modal-header"> <div class="modal-header">
<div class="pull-right hidden-xs"> <div class="pull-right hidden-xs">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveAddContrat">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
<h2 class="modal-title"> <h2 class="modal-title">
<img style="width:50px;" class="hidden-xs" src="img/contrat.svg"> <img style="width:50px;" class="hidden-xs" src="img/contrat.svg">
Ajouter un contrat Ajouter un contrat
</h2> </h2>
</div> </div>
<div class="modal-body"> <div class="modal-body">
<form id="formAddContrat" class="formContrat"> <form class="formContrat">
{include file='contrats/contrat_form.tpl'} {include file='contrats/contrat_form.tpl'}
</form> </form>
</div> </div>
<div class="modal-footer visible-xs"> <div class="modal-footer visible-xs">
<div class="pull-right"> <div class="pull-right">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveAddContrat">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
</div> </div>
</div> </div>
@ -141,23 +112,22 @@
<div class="modal-header"> <div class="modal-header">
<div class="pull-right hidden-xs"> <div class="pull-right hidden-xs">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveEditContrat">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
<h2 class="modal-title"> <h2 class="modal-title">
<img style="width:50px;" class="hidden-xs" src="img/contrat.svg"> <img style="width:50px;" class="hidden-xs" src="img/contrat.svg">
Modifier un contrat Modifier un contrat
</h2> </h2>
</div> </div>
<div class="modal-body"> <div class="modal-body">
<form id="formEditContrat" class="formContrat"> <form class="formContrat">
{include file='contrats/contrat_form.tpl'} {include file='contrats/contrat_form.tpl'}
</form> </form>
</div> </div>
<div class="modal-footer visible-xs"> <div class="modal-footer visible-xs">
<div class="pull-right"> <div class="pull-right">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveEditContrat">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
</div> </div>
</div> </div>
@ -180,7 +150,7 @@
</div> </div>
<div class="modal-footer"> <div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-danger" id="btnArchiveContrat">Confirmer</button> <button type="button" class="btn btn-danger btnSave">Confirmer</button>
</div> </div>
</div> </div>
</div> </div>
@ -202,7 +172,7 @@
</div> </div>
<div class="modal-footer"> <div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-danger" id="btnDeleteContrat">Confirmer</button> <button type="button" class="btn btn-danger btnSave">Confirmer</button>
</div> </div>
</div> </div>
</div> </div>

View File

@ -0,0 +1,28 @@
{foreach from=$list item=i}
<tr class="{if $i.archive>0}archive{/if}{if $i.warning_nb_paniers} warning{/if}{if $i.nb_paniers_restants<=0} danger{/if}">
<td class="center visible-lg id">{$i.ref}</td>
<td class="name"><a href="#" class="btnViewContrat" ref={$i.ref}>{$i.client_prenom} {$i.client_nom}</a></td>
<td class="visible-lg groupe">{$i.groupe_nom}</td>
<td class="visible-lg contrat_type">{$i.type_nom}</td>
<td class="visible-md visible-lg center date">{$i.date_print}</td>
<td class="visible-md visible-lg center freq">{$i.frequence_print}</td>
<td class="visible-md visible-lg center panier_type">{$i.panier_type_nom}</td>
<td class="visible-md visible-lg center items_long">{$i.nb_paniers_livres} / {$i.nb_paniers}</td>
<td class="visible-lg center items_long">{$i.nb_paniers_restants}{if $i.force_eligible>0} <i class="glyphicon glyphicon-star"></i>{/if}</td>
<td class="visible-md visible-lg center lieu">{$i.lieu_depot_nom}</td>
<td class="td_btn_action"><button class="btn btn-xs btn-link glyphicon glyphicon-edit btnEditContrat" ref="{$i.ref}"></button></td>
{if $i.nb_paniers_livres_absolute>0}
{if $i.archive>0}
<td class="td_btn_action td_btn_unarchive"><button class="btn btn-xs btn-link glyphicon glyphicon-folder-open btnUnarchiveContrat" ref="{$i.ref}" nom="{$i.client_prenom} {$i.client_nom}"></button></td>
{else}
<td class="td_btn_action td_btn_archive"><button class="btn btn-xs btn-link glyphicon glyphicon-folder-close btnArchiveContrat" ref="{$i.ref}" nom="{$i.client_prenom} {$i.client_nom}"></button></td>
{/if}
{else}
<td class="td_btn_action td_btn_delete"><button class="btn btn-xs btn-link glyphicon glyphicon-trash btnDeleteContrat" ref="{$i.ref}" nom="{$i.client_prenom} {$i.client_nom}"></button></td>
{/if}
</tr>
{foreachelse}
<tr>
<td colspan="12">aucun contrat</td>
</tr>
{/foreach}

View File

@ -4,7 +4,7 @@
<button type="button" class="navbar-toggle"><span class="glyphicon glyphicon-filter"></span></button> <button type="button" class="navbar-toggle"><span class="glyphicon glyphicon-filter"></span></button>
<a class="navbar-brand brand"> <a class="navbar-brand brand">
<img src="img/contrat.svg" class="hidden-xs"> <img src="img/contrat.svg" class="hidden-xs">
<span>{$list|@count} CONTRAT{if $list|@count>1}S{/if}</span> <span>{$list_limits.max} CONTRAT{if $list_limits.max>1}S{/if}</span>
</a> </a>
</div> </div>
<div class="collapse navbar-collapse"> <div class="collapse navbar-collapse">
@ -12,12 +12,12 @@
<!-- GROUPE --> <!-- GROUPE -->
<div class="input-group"> <div class="input-group">
<span class="input-group-addon{if $groupe>0} active{/if}">groupe :</span> <span class="input-group-addon{if $groupe>0} active{/if}">groupe :</span>
<select class="form-control" name="groupe" load_value="{$groupe}">{include file='paniers_groupes/paniers_groupes_select_list.tpl'}</select> <select class="form-control" name="groupe" load_value="{$groupe}" filtre_request="groupe">{include file='paniers_groupes/paniers_groupes_select_list.tpl'}</select>
</div> </div>
<!-- FREQUENCE --> <!-- FREQUENCE -->
<div class="input-group"> <div class="input-group">
<span class="input-group-addon{if $frequence!="0"} active{/if}">fréq. :</span> <span class="input-group-addon{if $frequence!="0"} active{/if}">fréq. :</span>
<select class="form-control" name="frequence" load_value="{$frequence}"> <select class="form-control" name="frequence" load_value="{$frequence}" filtre_request="frequence">
<option value="0">choisir...</option> <option value="0">choisir...</option>
<option value="hebdo">hebdo</option> <option value="hebdo">hebdo</option>
<option value="quinz">quinz.</option> <option value="quinz">quinz.</option>
@ -28,26 +28,26 @@
<!-- PANIER --> <!-- PANIER -->
<div class="input-group"> <div class="input-group">
<span class="input-group-addon{if $panier>0} active{/if}">panier :</span> <span class="input-group-addon{if $panier>0} active{/if}">panier :</span>
<select class="form-control" name="panier" load_value="{$panier}">{include file='paniers/paniers_select_list.tpl'}</select> <select class="form-control" name="panier" load_value="{$panier}" filtre_request="panier">{include file='paniers/paniers_select_list.tpl'}</select>
</div> </div>
<!-- LIEU --> <!-- LIEU -->
<div class="input-group"> <div class="input-group">
<span class="input-group-addon{if $lieu>0} active{/if}">lieu :</span> <span class="input-group-addon{if $lieu>0} active{/if}">lieu :</span>
<select class="form-control" name="lieu" load_value="{$lieu}"> <select class="form-control" name="lieu" load_value="{$lieu}" filtre_request="lieu">
{include file='contrats/lieux_select_list.tpl'} {include file='contrats/lieux_select_list.tpl'}
</select> </select>
</div> </div>
<!-- ARCHIVE --> <!-- ARCHIVE -->
<div class="input-group"> <div class="input-group">
<span class="input-group-addon{if $archive!=0} active{/if}">archive :</span> <span class="input-group-addon{if $archive!=0} active{/if}">archive :</span>
<select class="form-control" name="archive" load_value="{$archive}"> <select class="form-control" name="archive" load_value="{$archive}" filtre_request="archive">
<option value="-1">tous</option> <option value="-1">tous</option>
<option value="0">non</option> <option value="0">non</option>
<option value="1">oui</option> <option value="1">oui</option>
</select> </select>
</div> </div>
<!-- SEARCH --> <!-- SEARCH -->
<div class="input-group class"> <div class="input-group class searchGrp">
<span class="input-group-addon{if $search!=""} active{/if}"><i class="glyphicon glyphicon-search"></i></span> <span class="input-group-addon{if $search!=""} active{/if}"><i class="glyphicon glyphicon-search"></i></span>
<input type="text" class="form-control" placeholder="rechercher..." name="search" value="{$search}"> <input type="text" class="form-control" placeholder="rechercher..." name="search" value="{$search}">
{if $search!=""}<span class="input-group-addon btn-danger btnClearSearch"><i class="glyphicon glyphicon-remove"></i></span>{/if} {if $search!=""}<span class="input-group-addon btn-danger btnClearSearch"><i class="glyphicon glyphicon-remove"></i></span>{/if}

View File

@ -1,62 +1,48 @@
{if !$frameDisplay}{include file='structure/top.tpl'}{/if} {if !$frameDisplay}{include file='structure/top.tpl'}{/if}
<table class="table table-hover"> <table class="table table-hover scrollingTableList">
<thead> <thead>
<th style="width:45px;" class="center visible-lg"> <th class="center visible-lg id">
<a href={if $order=="ref" && $sens=="ASC"}"?order=ref&sens=DESC" <a href={if $order=="ref" && $sens=="ASC"}"?order=ref&sens=DESC"
{else}"?order=ref&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=ref&sens=ASC"{/if} style="text-decoration: none;">
#{if $order=="ref"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} #{if $order=="ref"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th> <th class="nom">
<a href={if $order=="nom" && $sens=="ASC"}"?order=nom&sens=DESC" <a href={if $order=="nom" && $sens=="ASC"}"?order=nom&sens=DESC"
{else}"?order=nom&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=nom&sens=ASC"{/if} style="text-decoration: none;">
nom{if $order=="nom"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} nom{if $order=="nom"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th class="visible-md visible-lg"> <th class="visible-md visible-lg tarif">
<a href={if $order=="tarif" && $sens=="ASC"}"?order=tarif&sens=DESC" <a href={if $order=="tarif" && $sens=="ASC"}"?order=tarif&sens=DESC"
{else}"?order=tarif&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=tarif&sens=ASC"{/if} style="text-decoration: none;">
tarif{if $order=="tarif"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} tarif{if $order=="tarif"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th class="visible-md visible-lg"> <th class="visible-md visible-lg center date">
<a href={if $order=="date" && $sens=="ASC"}"?order=date&sens=DESC" <a href={if $order=="date" && $sens=="ASC"}"?order=date&sens=DESC"
{else}"?order=date&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=date&sens=ASC"{/if} style="text-decoration: none;">
date d'application du tarif{if $order=="date"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} date{if $order=="date"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th style="width: 30px;"></th> <th class="btn_action right" colspan="2"><button class="btn btn-xs btn-info glyphicon glyphicon-plus" id="btnAddLegume"></button></th>
<th style="width: 30px;"><button class="btn btn-xs btn-info glyphicon glyphicon-plus" id="btnAddLegume"></button></th>
</thead> </thead>
<tbody class="table"> <tbody class="table progressLoadList" id="legumesList" start="{$list_limits.start}" end="{$list_limits.end}" rest="{$list_limits.rest}">
{foreach from=$list item=i} {include file='legumes/legumes_list_builder.tpl'}
<tr>
<td class="center visible-lg">{$i.ref}</td>
<td><a href="#" class="btnViewLegume" ref={$i.ref}>{$i.nom}</a></td>
<td class="visible-md visible-lg">{if $i.tarif_print}{$i.tarif_print}{else}.{/if}</td>
<td class="visible-md visible-lg">{$i.tarif_date_print}</td>
<td class="td_btn_action"><button class="btn btn-xs btn-link glyphicon glyphicon-edit btnEditLegume" ref="{$i.ref}"></button></td>
<td class="td_btn_action td_btn_delete"><button class="btn btn-xs btn-link glyphicon glyphicon-trash btnDeleteLegume" ref="{$i.ref}" nom="{$i.nom} {$i.prenom}"></button></td>
</tr>
{foreachelse}
<tr>
<td colspan="6">aucun légume</td>
</tr>
{/foreach}
</tbody> </tbody>
</table> </table>
{include file='legumes/legume_modal_view.tpl'} {include file='legumes/legume_modal_view.tpl'}
<!-- MODAL ADD LEGUME --> <!-- MODAL ADD LEGUME -->
<div class="modal fade" id="modalAddLegume" tabindex="-1" role="dialog" aria-hidden="true" data-backdrop="static" data-keyboard="false"> <div class="modal fade add" id="modalAddLegume" tabindex="-1" role="dialog" aria-hidden="true" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog modal-lg"> <div class="modal-dialog modal-lg">
<div class="modal-content"> <div class="modal-content">
<div class="modal-header"> <div class="modal-header">
<div class="pull-right hidden-xs"> <div class="pull-right hidden-xs">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveAddLegume">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
<h2 class="modal-title"> <h2 class="modal-title">
@ -65,14 +51,14 @@
</h2> </h2>
</div> </div>
<div class="modal-body"> <div class="modal-body">
<form id="formAddLegume" class="formLegume"> <form class="formLegume">
{include file='legumes/legume_form.tpl'} {include file='legumes/legume_form.tpl'}
</form> </form>
</div> </div>
<div class="modal-footer visible-xs"> <div class="modal-footer visible-xs">
<div class="pull-right"> <div class="pull-right">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveAddLegume">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
</div> </div>
</div> </div>
@ -81,13 +67,13 @@
<!-- end MODAL ADD LEGUME --> <!-- end MODAL ADD LEGUME -->
<!-- MODAL EDIT LEGUME --> <!-- MODAL EDIT LEGUME -->
<div class="modal fade" id="modalEditLegume" tabindex="-1" role="dialog" aria-hidden="true" data-backdrop="static" data-keyboard="false"> <div class="modal fade edit" id="modalEditLegume" tabindex="-1" role="dialog" aria-hidden="true" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog modal-lg"> <div class="modal-dialog modal-lg">
<div class="modal-content"> <div class="modal-content">
<div class="modal-header"> <div class="modal-header">
<div class="pull-right hidden-xs"> <div class="pull-right hidden-xs">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveEditLegume">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
<h2 class="modal-title"> <h2 class="modal-title">
@ -96,14 +82,14 @@
</h2> </h2>
</div> </div>
<div class="modal-body"> <div class="modal-body">
<form id="formEditLegume" class="formLegume"> <form class="formLegume">
{include file='legumes/legume_form.tpl'} {include file='legumes/legume_form.tpl'}
</form> </form>
</div> </div>
<div class="modal-footer visible-xs"> <div class="modal-footer visible-xs">
<div class="pull-right"> <div class="pull-right">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveEditLegume">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
</div> </div>
</div> </div>
@ -112,7 +98,7 @@
<!-- end MODAL EDIT LEGUME --> <!-- end MODAL EDIT LEGUME -->
<!-- MODAL DELETE LEGUME --> <!-- MODAL DELETE LEGUME -->
<div class="modal fade" id="modalDeleteLegume" tabindex="-1" role="dialog" aria-hidden="true"> <div class="modal fade delete" id="modalDeleteLegume" tabindex="-1" role="dialog" aria-hidden="true">
<div class="modal-dialog modal-lg"> <div class="modal-dialog modal-lg">
<div class="modal-content"> <div class="modal-content">
<div class="modal-header"> <div class="modal-header">
@ -126,7 +112,7 @@
</div> </div>
<div class="modal-footer"> <div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-danger" id="btnDeleteLegume">Confirmer</button> <button type="button" class="btn btn-danger btnSave">Confirmer</button>
</div> </div>
</div> </div>
</div> </div>

View File

@ -0,0 +1,14 @@
{foreach from=$list item=i}
<tr>
<td class="center visible-lg id">{$i.ref}</td>
<td><a href="#" class="btnViewLegume" ref={$i.ref}>{$i.nom}</a></td>
<td class="visible-md visible-lg tarif">{if $i.tarif_print}{$i.tarif_print}{else}.{/if}</td>
<td class="visible-md visible-lg date">{$i.tarif_date_print}</td>
<td class="td_btn_action"><button class="btn btn-xs btn-link glyphicon glyphicon-edit btnEditLegume" ref="{$i.ref}"></button></td>
<td class="td_btn_action td_btn_delete"><button class="btn btn-xs btn-link glyphicon glyphicon-trash btnDeleteLegume" ref="{$i.ref}" nom="{$i.nom} {$i.prenom}"></button></td>
</tr>
{foreachelse}
<tr>
<td colspan="6">aucun légume</td>
</tr>
{/foreach}

View File

@ -4,12 +4,12 @@
<button type="button" class="navbar-toggle"><span class="glyphicon glyphicon-filter"></span></button> <button type="button" class="navbar-toggle"><span class="glyphicon glyphicon-filter"></span></button>
<a class="navbar-brand brand"> <a class="navbar-brand brand">
<img src="img/legumes.svg" class="hidden-xs"> <img src="img/legumes.svg" class="hidden-xs">
<span>{$list|@count} LÉGUME{if $list|@count>1}S{/if}</span> <span>{$list_limits.max} LÉGUME{if $list_limits.max>1}S{/if}</span>
</a> </a>
</div> </div>
<div class="collapse navbar-collapse"> <div class="collapse navbar-collapse">
<form class="navbar-form navbar-right" role="search" id="legumesSearch"> <form class="navbar-form navbar-right" role="search" id="legumesSearch">
<div class="input-group class"> <div class="input-group class searchGrp">
<span class="input-group-addon{if $search!=""} active{/if}"><i class="glyphicon glyphicon-search"></i></span> <span class="input-group-addon{if $search!=""} active{/if}"><i class="glyphicon glyphicon-search"></i></span>
<input type="text" class="form-control" placeholder="rechercher..." name="search" value="{$search}"> <input type="text" class="form-control" placeholder="rechercher..." name="search" value="{$search}">
{if $search!=""}<span class="input-group-addon btn-danger btnClearSearch"><i class="glyphicon glyphicon-remove"></i></span>{/if} {if $search!=""}<span class="input-group-addon btn-danger btnClearSearch"><i class="glyphicon glyphicon-remove"></i></span>{/if}

View File

@ -1,11 +1,11 @@
<div class="modaLoader"></div> <div class="modaLoader"></div>
<ul class="nav nav-tabs formLivraisonTabs"> <ul class="nav nav-tabs formTabsBtns">
<li role="presentation" class="active"><a href="#" class="formLivraisonTabBtn" tab="tabGeneral">Général</a></li> <li role="presentation" class="active"><a href="#" class="formTabBtn" tab="tabGeneral">Général</a></li>
<li role="presentation"><a href="#" class="formLivraisonTabBtn" tab="tabPaniers">Paniers</a></li> <li role="presentation"><a href="#" class="formTabBtn" tab="tabPaniers">Paniers</a></li>
<li role="presentation"><a href="#" class="formLivraisonTabBtn" tab="tabCompo">Composition</a></li> <li role="presentation"><a href="#" class="formTabBtn" tab="tabCompo">Composition</a></li>
<li role="presentation"><a href="#" class="formLivraisonTabBtn" tab="tabLegumes">Total Légumes</a></li> <li role="presentation"><a href="#" class="formTabBtn" tab="tabLegumes">Total Légumes</a></li>
</ul> </ul>
<div class="formLivraisonTabs"> <div class="formTabs">
<div class="tab tabGeneral active"> <div class="tab tabGeneral active">
<div class="row"> <div class="row">
<div class="col-md-12"> <div class="col-md-12">
@ -76,6 +76,3 @@
</table> </table>
</div> </div>
</div> </div>

View File

@ -21,15 +21,15 @@
<li print_type="full"><a href="#" target="_blank" print_type="full">Complet</a></li> <li print_type="full"><a href="#" target="_blank" print_type="full">Complet</a></li>
</ul> </ul>
</div> </div>
<ul class="nav nav-tabs formLivraisonTabs"> <ul class="nav nav-tabs formTabsBtns">
<li tab="tabGeneral"><a href="#" class="formLivraisonTabBtn" tab="tabGeneral">Général</a></li> <li tab="tabGeneral"><a href="#" class="formTabBtn" tab="tabGeneral">Général</a></li>
<li tab="tabPaniers"><a href="#" class="formLivraisonTabBtn" tab="tabPaniers">Paniers</a></li> <li tab="tabPaniers"><a href="#" class="formTabBtn" tab="tabPaniers">Paniers</a></li>
<li tab="tabCompo"><a href="#" class="formLivraisonTabBtn" tab="tabCompo">Composition</a></li> <li tab="tabCompo"><a href="#" class="formTabBtn" tab="tabCompo">Composition</a></li>
<li tab="tabLegumes"><a href="#" class="formLivraisonTabBtn" tab="tabLegumes">Total Légumes</a></li> <li tab="tabLegumes"><a href="#" class="formTabBtn" tab="tabLegumes">Total Légumes</a></li>
</ul> </ul>
<div class="formLivraisonTabs"> <div class="formTabs">
<div class="tab tabGeneral active"> <div class="tab tabGeneral active">
<table class="table"> <table class="table modal-body">
<tr><th>groupe de paniers :</th><td class="groupe"></td></tr> <tr><th>groupe de paniers :</th><td class="groupe"></td></tr>
<tr><th>date :</th><td class="date"></td></tr> <tr><th>date :</th><td class="date"></td></tr>
<tr><th>groupe bi-hebdo :</th><td class="quinz_groupe"></td></tr> <tr><th>groupe bi-hebdo :</th><td class="quinz_groupe"></td></tr>

View File

@ -1,64 +1,41 @@
{if !$frameDisplay}{include file='structure/top.tpl'}{/if} {if !$frameDisplay}{include file='structure/top.tpl'}{/if}
<table class="table table-hover"> <table class="table table-hover scrollingTableList">
<thead> <thead>
<th style="width:45px;" class="center visible-lg"> <th class="center visible-lg id">
<a href={if $order=="ref" && $sens=="ASC"}"?order=ref&sens=DESC" <a href={if $order=="ref" && $sens=="ASC"}"?order=ref&sens=DESC"
{else}"?order=ref&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=ref&sens=ASC"{/if} style="text-decoration: none;">
#{if $order=="ref"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} #{if $order=="ref"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th> <th class="visible-md visible-lg groupe center">
<a href={if $order=="paniers_groupe" && $sens=="ASC"}"?order=paniers_groupe&sens=DESC"
{else}"?order=paniers_groupe&sens=ASC"{/if} style="text-decoration: none;">
groupe{if $order=="paniers_groupe"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a>
</th>
<th class="name">
<a href={if $order=="date" && $sens=="ASC"}"?order=date&sens=DESC" <a href={if $order=="date" && $sens=="ASC"}"?order=date&sens=DESC"
{else}"?order=date&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=date&sens=ASC"{/if} style="text-decoration: none;">
date{if $order=="date"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} date{if $order=="date"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th class="visible-md visible-lg"> <th class="visible-md visible-lg quinz_group">
<a href={if $order=="quinz_groupe" && $sens=="ASC"}"?order=quinz_groupe&sens=DESC" <a href={if $order=="quinz_groupe" && $sens=="ASC"}"?order=quinz_groupe&sens=DESC"
{else}"?order=quinz_groupe&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=quinz_groupe&sens=ASC"{/if} style="text-decoration: none;">
groupe quinzaine{if $order=="quinz_groupe"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} groupe quinzaine{if $order=="quinz_groupe"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th class="visible-md visible-lg"> <th class="visible-md visible-lg items_long center">
<a href={if $order=="paniers_groupe" && $sens=="ASC"}"?order=paniers_groupe&sens=DESC"
{else}"?order=paniers_groupe&sens=ASC"{/if} style="text-decoration: none;">
groupe de paniers{if $order=="paniers_groupe"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a>
</th>
<th class="visible-md visible-lg">
<a href={if $order=="nb_paniers" && $sens=="ASC"}"?order=nb_paniers&sens=DESC" <a href={if $order=="nb_paniers" && $sens=="ASC"}"?order=nb_paniers&sens=DESC"
{else}"?order=nb_paniers&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=nb_paniers&sens=ASC"{/if} style="text-decoration: none;">
nb. de paniers{if $order=="nb_paniers"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} nb. de paniers{if $order=="nb_paniers"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th style="width: 30px;"></th> <th class="btn_action right" colspan="3"><button class="btn btn-xs btn-info glyphicon glyphicon-plus" id="btnAddLivraison"></button></th>
<th style="width: 30px;"><button class="btn btn-xs btn-info glyphicon glyphicon-plus" id="btnAddLivraison"></button></th>
</thead> </thead>
<tbody class="table"> <tbody class="table progressLoadList" id="livraisonsList" start="{$list_limits.start}" end="{$list_limits.end}" rest="{$list_limits.rest}">
{foreach from=$list item=i} {include file='livraisons/livraisons_list_builder.tpl'}
<tr{if $i.archive>0} class="archive"{/if}>
<td class="center visible-lg">{$i.ref}</td>
<td><a href="#" class="btnViewLivraison" ref="{$i.ref}">{$i.date_print}</a></td>
<td class="visible-md visible-lg">{if $i.quinz_groupe!=""}groupe {$i.quinz_groupe}{else}.{/if}</td>
<td class="visible-md visible-lg">{$i.paniers_groupe_nom}</td>
<td class="visible-md visible-lg">{$i.nb_paniers} panier{if $i.nb_paniers>1}s{/if}</td>
<td class="td_btn_action"><button class="btn btn-xs btn-link glyphicon glyphicon-edit btnEditLivraison" ref="{$i.ref}"></button></td>
{if $i.nb_paniers>0}
{if $i.archive>0}
<td class="td_btn_action td_btn_unarchive"><button class="btn btn-xs btn-link glyphicon glyphicon-folder-open btnUnarchiveLivraison" ref="{$i.ref}" date="{$i.date_print}"></button></td>
{else}
<td class="td_btn_action td_btn_archive"><button class="btn btn-xs btn-link glyphicon glyphicon-folder-close btnArchiveLivraison" ref="{$i.ref}" date="{$i.date_print}"></button></td>
{/if}
{else}
<td class="td_btn_action td_btn_delete"><button class="btn btn-xs btn-link glyphicon glyphicon-trash btnDeleteLivraison" ref="{$i.ref}" date="{$i.date_print}"></button></td>
{/if}
</tr>
{foreachelse}
<tr>
<td colspan="6">aucune livraison</td>
</tr>
{/foreach}
</tbody> </tbody>
</table> </table>
@ -71,7 +48,7 @@
<div class="modal-header"> <div class="modal-header">
<div class="pull-right hidden-xs"> <div class="pull-right hidden-xs">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveAddLivraison">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
<h2 class="modal-title"> <h2 class="modal-title">
@ -80,14 +57,14 @@
</h2> </h2>
</div> </div>
<div class="modal-body"> <div class="modal-body">
<form id="formAddLivraison" class="formLivraison"> <form class="formLivraison">
{include file='livraisons/livraison_form.tpl'} {include file='livraisons/livraison_form.tpl'}
</form> </form>
</div> </div>
<div class="modal-footer visible-xs"> <div class="modal-footer visible-xs">
<div class="pull-right"> <div class="pull-right">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveAddLivraison">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
</div> </div>
</div> </div>
@ -102,7 +79,7 @@
<div class="modal-header"> <div class="modal-header">
<div class="pull-right hidden-xs"> <div class="pull-right hidden-xs">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveEditLivraison">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
<h2 class="modal-title"> <h2 class="modal-title">
@ -111,14 +88,14 @@
</h2> </h2>
</div> </div>
<div class="modal-body"> <div class="modal-body">
<form id="formEditLivraison" class="formLivraison"> <form class="formLivraison">
{include file='livraisons/livraison_form.tpl'} {include file='livraisons/livraison_form.tpl'}
</form> </form>
</div> </div>
<div class="modal-footer visible-xs"> <div class="modal-footer visible-xs">
<div class="pull-right"> <div class="pull-right">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveEditLivraison">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
</div> </div>
</div> </div>
@ -126,6 +103,28 @@
</div> </div>
<!-- end MODAL EDIT LIVRAISON --> <!-- end MODAL EDIT LIVRAISON -->
<!-- MODAL ARCHIVE LIVRAISON -->
<div class="modal fade" id="modalArchiveLivraison" tabindex="-1" role="dialog" aria-hidden="true">
<div class="modal-dialog modal-lg">
<div class="modal-content">
<div class="modal-header">
<h2 class="modal-title">
<img style="width:50px;" class="hidden-xs" src="img/livraison.svg">
Archiver une livraison
</h2>
</div>
<div class="modal-body">
<p>Etes-vous sûr de vouloir archiver la livraison <b class="groupe">groupe</b> du <b class="date">date</b> ?</p>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-warning btnSave">Confirmer</button>
</div>
</div>
</div>
</div>
<!-- end MODAL ARCHIVE LIVRAISON -->
<!-- MODAL DELETE LIVRAISON --> <!-- MODAL DELETE LIVRAISON -->
<div class="modal fade" id="modalDeleteLivraison" tabindex="-1" role="dialog" aria-hidden="true"> <div class="modal fade" id="modalDeleteLivraison" tabindex="-1" role="dialog" aria-hidden="true">
<div class="modal-dialog modal-lg"> <div class="modal-dialog modal-lg">
@ -141,33 +140,11 @@
</div> </div>
<div class="modal-footer"> <div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-danger" id="btnDeleteLivraison">Confirmer</button> <button type="button" class="btn btn-danger btnSave">Confirmer</button>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
<!-- end MODAL DELETE LIVRAISON --> <!-- end MODAL DELETE LIVRAISON -->
<!-- MODAL ARCHIVE LIVRAISON -->
<div class="modal fade" id="modalArchiveLivraison" tabindex="-1" role="dialog" aria-hidden="true">
<div class="modal-dialog modal-lg">
<div class="modal-content">
<div class="modal-header">
<h2 class="modal-title">
<img style="width:50px;" class="hidden-xs" src="img/livraison.svg">
Archiver une livraison
</h2>
</div>
<div class="modal-body">
<p>Etes-vous sûr de vouloir archiver la livraison du <b class="date">date</b> ?</p>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-danger" id="btnArchiveLivraison">Confirmer</button>
</div>
</div>
</div>
</div>
<!-- end MODAL ARCHIVE LIVRAISON -->
{if !$frameDisplay}{include file='structure/bottom.tpl'}{/if} {if !$frameDisplay}{include file='structure/bottom.tpl'}{/if}

View File

@ -0,0 +1,24 @@
{foreach from=$list item=i}
<tr{if $i.archive>0} class="archive"{/if}>
<td class="center visible-lg id">{$i.ref}</td>
<td class="visible-md visible-lg groupe center">{$i.paniers_groupe_nom}</td>
<td class="name"><a href="#" class="btnViewLivraison" ref="{$i.ref}">{$i.date_print}</a></td>
<td class="visible-md visible-lg quinz_groupe">{if $i.quinz_groupe!=""}groupe {$i.quinz_groupe}{else}.{/if}</td>
<td class="visible-md visible-lg items_long center">{$i.nb_paniers} panier{if $i.nb_paniers>1}s{/if}</td>
<td class="td_btn_action"><button class="btn btn-xs btn-link glyphicon glyphicon-edit btnEditLivraison" ref="{$i.ref}"></button></td>
<td class="td_btn_action"><button class="btn btn-xs btn-link glyphicon glyphicon-duplicate btnCopyLivraison" ref="{$i.ref}"></button></td>
{if $i.nb_paniers>0}
{if $i.archive>0}
<td class="td_btn_action td_btn_unarchive"><button class="btn btn-xs btn-link glyphicon glyphicon-folder-open btnUnarchiveLivraison" ref="{$i.ref}" groupe="{$i.paniers_groupe_nom}" date="{$i.date_print}"></button></td>
{else}
<td class="td_btn_action td_btn_archive"><button class="btn btn-xs btn-link glyphicon glyphicon-folder-close btnArchiveLivraison" ref="{$i.ref}" groupe="{$i.paniers_groupe_nom}" date="{$i.date_print}"></button></td>
{/if}
{else}
<td class="td_btn_action td_btn_delete"><button class="btn btn-xs btn-link glyphicon glyphicon-trash btnDeleteLivraison" ref="{$i.ref}" groupe="{$i.paniers_groupe_nom}" date="{$i.date_print}"></button></td>
{/if}
</tr>
{foreachelse}
<tr>
<td colspan="6">aucune livraison</td>
</tr>
{/foreach}

View File

@ -4,18 +4,18 @@
<button type="button" class="navbar-toggle"><span class="glyphicon glyphicon-filter"></span></button> <button type="button" class="navbar-toggle"><span class="glyphicon glyphicon-filter"></span></button>
<a class="navbar-brand brand"> <a class="navbar-brand brand">
<img src="img/livraison.svg" class="hidden-xs"> <img src="img/livraison.svg" class="hidden-xs">
<span>{$list|@count} LIVRAISON{if $list|@count>1}S{/if}</span> <span>{$list_limits.max} LIVRAISON{if $list_limits.max>1}S{/if}</span>
</a> </a>
</div> </div>
<div class="collapse navbar-collapse"> <div class="collapse navbar-collapse">
<form class="navbar-form navbar-right" role="search" id="livraisonsFiltre"> <form class="navbar-form navbar-right" role="search" id="livraisonsSearch">
<div class="input-group"> <div class="input-group">
<span class="input-group-addon{if $groupe>0} active{/if}">groupe :</span> <span class="input-group-addon{if $groupe>0} active{/if}">groupe :</span>
<select class="form-control" name="groupe" load_value="{$groupe}">{include file='paniers_groupes/paniers_groupes_select_list.tpl'}</select> <select class="form-control" name="groupe" load_value="{$groupe}" filtre_request="groupe">{include file='paniers_groupes/paniers_groupes_select_list.tpl'}</select>
</div> </div>
<div class="input-group"> <div class="input-group">
<span class="input-group-addon{if $archive!=0} active{/if}">archive :</span> <span class="input-group-addon{if $archive!=0} active{/if}">archive :</span>
<select class="form-control" name="archive" load_value="{$archive}"> <select class="form-control" name="archive" load_value="{$archive}" filtre_request="archive">
<option value="-1">tous</option> <option value="-1">tous</option>
<option value="0">non</option> <option value="0">non</option>
<option value="1">oui</option> <option value="1">oui</option>

View File

@ -11,12 +11,12 @@
<div class="input-group"> <div class="input-group">
<select class="form-control" name="groupe">{include file='paniers_groupes/paniers_groupes_select_list.tpl'}</select> <select class="form-control" name="groupe">{include file='paniers_groupes/paniers_groupes_select_list.tpl'}</select>
<span class="input-group-btn hide"> <span class="input-group-btn hide">
<button class="btn btn-default btnGroupeSecondAction"> <button class="btn btn-default btnSecondAction">
<i class="glyphicon glyphicon-remove"></i> <i class="glyphicon glyphicon-remove"></i>
</button> </button>
</span> </span>
<span class="input-group-btn"> <span class="input-group-btn">
<button class="btn btn-default btnGroupeAction add"> <button class="btn btn-default btnAction add">
<i class="glyphicon glyphicon-plus"></i> <i class="glyphicon glyphicon-plus"></i>
</button> </button>
</span> </span>

View File

@ -1,49 +1,35 @@
{if !$frameDisplay}{include file='structure/top.tpl'}{/if} {if !$frameDisplay}{include file='structure/top.tpl'}{/if}
<table class="table table-hover"> <table class="table table-hover scrollingTableList">
<thead> <thead>
<th style="width:45px;" class="center visible-lg"> <th class="center visible-lg id">
<a href={if $order=="ref" && $sens=="ASC"}"?order=ref&sens=DESC" <a href={if $order=="ref" && $sens=="ASC"}"?order=ref&sens=DESC"
{else}"?order=ref&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=ref&sens=ASC"{/if} style="text-decoration: none;">
#{if $order=="ref"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} #{if $order=="ref"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th> <th class="name">
<a href={if $order=="nom" && $sens=="ASC"}"?order=nom&sens=DESC" <a href={if $order=="nom" && $sens=="ASC"}"?order=nom&sens=DESC"
{else}"?order=nom&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=nom&sens=ASC"{/if} style="text-decoration: none;">
nom{if $order=="nom"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} nom{if $order=="nom"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th class="visible-md visible-lg"> <th class="visible-md visible-lg groupe center">
<a href={if $order=="groupe" && $sens=="ASC"}"?order=groupe&sens=DESC" <a href={if $order=="groupe" && $sens=="ASC"}"?order=groupe&sens=DESC"
{else}"?order=groupe&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=groupe&sens=ASC"{/if} style="text-decoration: none;">
groupe{if $order=="groupe"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} groupe{if $order=="groupe"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th class="visible-md visible-lg"> <th class="visible-md visible-lg valeur center">
<a href={if $order=="valeur" && $sens=="ASC"}"?order=valeur&sens=DESC" <a href={if $order=="valeur" && $sens=="ASC"}"?order=valeur&sens=DESC"
{else}"?order=valeur&sens=ASC"{/if} style="text-decoration: none;"> {else}"?order=valeur&sens=ASC"{/if} style="text-decoration: none;">
valeur{if $order=="valeur"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if} valeur{if $order=="valeur"} <i class="glyphicon glyphicon-chevron-{if $sens=="ASC"}up{else}down{/if}"></i>{/if}
</a> </a>
</th> </th>
<th style="width: 30px;"></th> <th class="btn_action right" colspan="2"><button class="btn btn-xs btn-info glyphicon glyphicon-plus" id="btnAddPanier"></button></th>
<th style="width: 30px;"><button class="btn btn-xs btn-info glyphicon glyphicon-plus" id="btnAddPanier"></button></th>
</thead> </thead>
<tbody class="table"> <tbody class="table progressLoadList" id="paniersList" start="{$list_limits.start}" end="{$list_limits.end}" rest="{$list_limits.rest}">
{foreach from=$list item=i} {include file='paniers/paniers_list_builder.tpl'}
<tr>
<td class="center visible-lg">{$i.ref}</td>
<td><a href="#" class="btnViewPanier" ref={$i.ref}>{$i.nom}</a></td>
<td class="visible-md visible-lg">{$i.groupe_nom}</td>
<td class="visible-md visible-lg">{$i.valeur|string_format:"%.2f"} €</td>
<td class="td_btn_action"><button class="btn btn-xs btn-link glyphicon glyphicon-edit btnEditPanier" ref="{$i.ref}"></button></td>
<td class="td_btn_action td_btn_delete"><button class="btn btn-xs btn-link glyphicon glyphicon-trash btnDeletePanier" ref="{$i.ref}" nom="{$i.nom}"></button></td>
</tr>
{foreachelse}
<tr>
<td colspan="6">aucun type de panier</td>
</tr>
{/foreach}
</tbody> </tbody>
</table> </table>
@ -56,7 +42,7 @@
<div class="modal-header"> <div class="modal-header">
<div class="pull-right hidden-xs"> <div class="pull-right hidden-xs">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveAddPanier">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
<h2 class="modal-title"> <h2 class="modal-title">
@ -65,14 +51,14 @@
</h2> </h2>
</div> </div>
<div class="modal-body"> <div class="modal-body">
<form id="formAddPanier" class="formPanier"> <form class="formPanier">
{include file='paniers/panier_form.tpl'} {include file='paniers/panier_form.tpl'}
</form> </form>
</div> </div>
<div class="modal-footer visible-xs"> <div class="modal-footer visible-xs">
<div class="pull-right"> <div class="pull-right">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveAddPanier">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
</div> </div>
</div> </div>
@ -87,7 +73,7 @@
<div class="modal-header"> <div class="modal-header">
<div class="pull-right hidden-xs"> <div class="pull-right hidden-xs">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveEditPanier">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
<h2 class="modal-title"> <h2 class="modal-title">
@ -96,14 +82,14 @@
</h2> </h2>
</div> </div>
<div class="modal-body"> <div class="modal-body">
<form id="formEditPanier" class="formPanier"> <form class="formPanier">
{include file='paniers/panier_form.tpl'} {include file='paniers/panier_form.tpl'}
</form> </form>
</div> </div>
<div class="modal-footer visible-xs"> <div class="modal-footer visible-xs">
<div class="pull-right"> <div class="pull-right">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-custom btnSaveEditPanier">Enregistrer</button> <button type="button" class="btn btn-custom btnSave">Enregistrer</button>
</div> </div>
</div> </div>
</div> </div>
@ -126,7 +112,7 @@
</div> </div>
<div class="modal-footer"> <div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button> <button type="button" class="btn btn-default" data-dismiss="modal">Annuler</button>
<button type="button" class="btn btn-danger" id="btnDeletePanier">Confirmer</button> <button type="button" class="btn btn-danger btnSave">Confirmer</button>
</div> </div>
</div> </div>
</div> </div>

View File

@ -0,0 +1,14 @@
{foreach from=$list item=i}
<tr>
<td class="center visible-lg id">{$i.ref}</td>
<td class="name"><a href="#" class="btnViewPanier" ref={$i.ref}>{$i.nom}</a></td>
<td class="visible-md visible-lg groupe center">{$i.groupe_nom}</td>
<td class="visible-md visible-lg valeur center">{$i.valeur|string_format:"%.2f"} €</td>
<td class="td_btn_action"><button class="btn btn-xs btn-link glyphicon glyphicon-edit btnEditPanier" ref="{$i.ref}"></button></td>
<td class="td_btn_action td_btn_delete"><button class="btn btn-xs btn-link glyphicon glyphicon-trash btnDeletePanier" ref="{$i.ref}" nom="{$i.nom}"></button></td>
</tr>
{foreachelse}
<tr>
<td colspan="6">aucun type de panier</td>
</tr>
{/foreach}

View File

@ -4,7 +4,7 @@
<button type="button" class="navbar-toggle"><span class="glyphicon glyphicon-filter"></span></button> <button type="button" class="navbar-toggle"><span class="glyphicon glyphicon-filter"></span></button>
<a class="navbar-brand brand"> <a class="navbar-brand brand">
<img src="img/panier.svg" class="hidden-xs"> <img src="img/panier.svg" class="hidden-xs">
<span>{$list|@count} PANIER{if $list|@count>1}S{/if}</span> <span>{$list_limits.max} PANIER{if $list_limits.max>1}S{/if}</span>
</a> </a>
</div> </div>
<div class="collapse navbar-collapse"> <div class="collapse navbar-collapse">
@ -12,7 +12,7 @@
<!-- GROUPE --> <!-- GROUPE -->
<div class="input-group"> <div class="input-group">
<span class="input-group-addon{if $groupe>0} active{/if}">groupe :</span> <span class="input-group-addon{if $groupe>0} active{/if}">groupe :</span>
<select class="form-control" name="groupe" load_value="{$groupe}">{include file='paniers_groupes/paniers_groupes_select_list.tpl'}</select> <select class="form-control" name="groupe" load_value="{$groupe}" filtre_request="groupe">{include file='paniers_groupes/paniers_groupes_select_list.tpl'}</select>
</div> </div>
<!-- SEARCH --> <!-- SEARCH -->
<div class="input-group class"> <div class="input-group class">

View File

@ -21,7 +21,7 @@
{foreach from=$jsFiles item=file} {foreach from=$jsFiles item=file}
<script src="{$file}?gitVS={$gitVS.short}"></script> <script src="{$file}?gitVS={$gitVS.short}"></script>
{/foreach} {/foreach}
<script>var srvErrorMsg = "ERREUR SERVEUR ! Contacter Adrien..."; </script> <script>var current_page = "{$page}"; </script>
</head> </head>
<body id="body" lang="{$lang}"> <body id="body" lang="{$lang}">
{if !$noMenu} {if !$noMenu}