Exemplo n.º 1
0
 /**
  * 
  * @return type
  */
 public function getHtmlCorrectionChapitre()
 {
     $return = NULL;
     $idFtaSuiviProjet = FtaSuiviProjetModel::getIdFtaSuiviProjetByIdFtaAndIdChapitre($this->ftaModel->getDataField(FtaModel::KEYNAME)->getFieldValue(), 1);
     $recordsetIdFtaSuiviProjet = new FtaSuiviProjetModel($idFtaSuiviProjet);
     $HtmlSuiviProjet = new DataFieldToHtmlTextArea($recordsetIdFtaSuiviProjet->getDataField(FtaSuiviProjetModel::FIELDNAME_CORRECTION_FTA_SUIVI_PROJET));
     $HtmlSuiviProjet->setIsEditable($this->getIsEditable());
     $return .= $HtmlSuiviProjet->getHtmlResult();
     return $return;
 }
Exemplo n.º 2
0
 public static function initChapitre($id_fta, $id_fta_chapitre, $synthese_action, $comeback, $idFtaEtat, $abreviationFtaEtat, $idFtaRole, $checkArcadiaData)
 {
     self::$checkArcadiaData = $checkArcadiaData;
     self::$is_data_validation_successful = FALSE;
     self::$id_fta = $id_fta;
     self::$comeback = $comeback;
     self::$id_fta_etat = $idFtaEtat;
     self::$abrevation_etat = $abreviationFtaEtat;
     self::$id_fta_role = $idFtaRole;
     self::$id_fta_chapitre = $id_fta_chapitre;
     self::$ftaModel = new FtaModel(self::$id_fta);
     self::$ftaChapitreModel = new FtaChapitreModel(self::$id_fta_chapitre);
     self::$id_fta_workflow = self::$ftaModel->getDataField(FtaModel::FIELDNAME_WORKFLOW)->getFieldValue();
     self::$ftaWorkflowModel = new FtaWorkflowModel(self::$id_fta_workflow);
     self::$synthese_action = $synthese_action;
     $globalConfig = new GlobalConfig();
     UserModel::checkUserSessionExpired($globalConfig);
     self::$idUser = $globalConfig->getAuthenticatedUser()->getKeyValue();
     $idFtaSuiviProjet = FtaSuiviProjetModel::getIdFtaSuiviProjetByIdFtaAndIdChapitre(self::$id_fta, self::$id_fta_chapitre);
     self::$ftaSuiviProjetModel = new FtaSuiviProjetModel($idFtaSuiviProjet);
     //        self::$objectFta = new ObjectFta(self::$id_fta); //cela genère un id fta_suivie projet de trop
     //        self::$objectFta->loadCurrentSuiviProjectByChapter(self::$id_fta_chapitre);
     self::$id_fta_workflow_structure = FtaWorkflowStructureModel::getIdFtaWorkflowStructureByIdFtaAndIdChapitre(self::$id_fta, self::$id_fta_chapitre);
     self::$ftaWorkflowStructureModel = new FtaWorkflowStructureModel(self::$id_fta_workflow_structure);
     self::$id_fta_processus = self::$ftaWorkflowStructureModel->getDataField(FtaWorkflowStructureModel::FIELDNAME_ID_FTA_PROCESSUS)->getFieldValue();
     self::$id_intranet_actions = IntranetActionsModel::getIdIntranetActionsFromIdParentAction(self::$ftaWorkflowModel->getDataField(FtaWorkflowModel::FIELDNAME_ID_INTRANET_ACTIONS)->getFieldValue(), self::$id_fta_chapitre, self::$id_fta_workflow, self::$id_fta_role);
     self::$moduleIntranetActionsModel = new IntranetActionsModel(self::$id_intranet_actions);
     self::$is_owner = self::buildIsOwner();
     self::$is_editable = self::buildIsEditable();
     self::$is_correctable = self::buildIsCorrectable();
     self::$taux_validation_processus = self::buildTauxValidationProcessus();
     self::$html_correct_button = self::buildHtmlCorrectButton();
     self::$html_chapitre_core = self::buildChapitreCore();
     self::$html_submit_button = self::buildHtmlSubmitButton();
     self::$html_suivi_dossier = self::buildSuiviDossier();
     self::$html_chapitre_all = self::buildChapitreAll();
 }
Exemplo n.º 3
0
if ($comeback) {
    $_SESSION["comeback_url"] = $_SERVER["HTTP_REFERER"];
}
$action = Lib::getParameterFromRequest('action');
$demande_abreviation_fta_transition = Lib::getParameterFromRequest('demande_abreviation_fta_transition');
$syntheseAction = Lib::getParameterFromRequest('synthese_action');
$checkPost = Lib::getParameterFromRequest('checkPost');
/*
 * Initinalisation du modele Fta
 * 
 */
$ftaModel = new FtaModel($idFta);
$globalConfig = new GlobalConfig();
UserModel::checkUserSessionExpired($globalConfig);
$idUser = $globalConfig->getAuthenticatedUser()->getKeyValue();
$idFtaWorkflow = $ftaModel->getDataField(FtaModel::FIELDNAME_WORKFLOW)->getFieldValue();
$arrayIdFtaRoleAcces = FtaRoleModel::getArrayIdFtaRoleByIdUserAndWorkflow($idUser, $idFtaWorkflow);
$idFtaRole = $arrayIdFtaRoleAcces["0"];
/**
 * Affichage commentaire à modifier
 */
$NOM_commentaire_maj_fta = $ftaModel->getHtmlCommentaireMajFta();
//$NOM_commentaire_maj_fta = str_replace('<>');
/**
 * Recupération des élement de la Fta en cours
 */
$arrayFta = DatabaseOperation::convertSqlStatementWithoutKeyToArray('SELECT ' . FtaModel::FIELDNAME_DOSSIER_FTA . ',' . FtaModel::FIELDNAME_DESIGNATION_COMMERCIALE . ',' . FtaModel::FIELDNAME_COMMENTAIRE_MAJ_FTA . ',' . FtaModel::FIELDNAME_LIBELLE . ',' . FtaEtatModel::FIELDNAME_NOM_FTA_ETAT . ',' . FtaEtatModel::FIELDNAME_ABREVIATION . ',' . FtaModel::FIELDNAME_WORKFLOW . ',' . FtaModel::FIELDNAME_VERSION_DOSSIER_FTA . ' FROM ' . FtaModel::TABLENAME . ',' . FtaEtatModel::TABLENAME . ' WHERE ' . FtaModel::KEYNAME . '=' . $idFta . ' AND ' . FtaModel::TABLENAME . '.' . FtaModel::FIELDNAME_ID_FTA_ETAT . '=' . FtaEtatModel::TABLENAME . '.' . FtaEtatModel::KEYNAME);
//Information de la fiche sélectionnée
foreach ($arrayFta as $rowsFta) {
    $idDossierFta = $rowsFta[FtaModel::FIELDNAME_DOSSIER_FTA];
    //Identifiant de toutes les fiches de cette matière
 if ($prefixe_code_produit_agrologic_fta_nomenclature == "13" or $prefixe_code_produit_agrologic_fta_nomenclature == "11") {
     $ftaComposantModel->getDataField(FtaComposantModel::FIELDNAME_ID_ANNEXE_UNITE)->setFieldValue("kg");
 }
 /**
  * Les Produits toujours en L
  */
 if ($prefixe_code_produit_agrologic_fta_nomenclature == "17") {
     $ftaComposantModel->getDataField(FtaComposantModel::FIELDNAME_ID_ANNEXE_UNITE)->setFieldValue("L");
 }
 /**
  * Création de la nomenclature orpheline
  */
 if ($isComposition) {
     if ($creation) {
         $ftaModel = new FtaModel($id_fta);
         $DureeDeVieTechnique = $ftaModel->getDataField(FtaModel::FIELDNAME_DUREE_DE_VIE_TECHNIQUE_PRODUCTION)->getFieldValue();
         $PCB = $ftaModel->getDataField(FtaModel::FIELDNAME_NOMBRE_UVC_PAR_CARTON)->getFieldValue();
         $poidsUVFValueKG = $ftaModel->getDataField(FtaModel::FIELDNAME_POIDS_ELEMENTAIRE)->getFieldValue();
         $poidsUVFValueG = $poidsUVFValueKG * "1000";
         //Valeur par défaut
         $nom_fta_nomenclature = $ftaComposantModel->getDataField(FtaComposantModel::FIELDNAME_DESIGNATION_CODIFICATION)->getFieldValue();
         $ftaComposantModel->getDataField(FtaComposantModel::FIELDNAME_NOM_FTA_COMPOSITION)->setFieldValue($nom_fta_nomenclature);
         $site_production_fta_nomenclature = $ftaComposantModel->getDataField(FtaComposantModel::FIELDNAME_SITE_PRODUCTION_FTA_CODIFICATION)->getFieldValue();
         $ftaComposantModel->getDataField(FtaComposantModel::FIELDNAME_ID_GEO)->setFieldValue($site_production_fta_nomenclature);
         $poids_fta_nomenclature = $ftaComposantModel->getDataField(FtaComposantModel::FIELDNAME_POIDS_UNITAIRE_CODIFICATION)->getFieldValue();
         $ftaComposantModel->getDataField(FtaComposantModel::FIELDNAME_POIDS_FTA_COMPOSITION)->setFieldValue($poidsUVFValueG);
         $ftaComposantModel->getDataField(FtaComposantModel::FIELDNAME_DUREE_VIE_TECHNIQUE_FTA_COMPOSITION)->setFieldValue($DureeDeVieTechnique);
         $ftaComposantModel->getDataField(FtaComposantModel::FIELDNAME_QUANTITE_FTA_COMPOSITION)->setFieldValue($PCB);
     }
     $ftaComposantModel->getDataField(FtaComposantModel::FIELDNAME_IS_COMPOSITION_FTA_COMPOSANT)->setFieldValue("1");
 } else {
 $bloc .= $annexeEmballageModel->getHtmlDataField(AnnexeEmballageModel::FIELDNAME_LONGUEUR_ANNEXE_EMBALLAGE);
 //Largeur de l'emballage
 $bloc .= $annexeEmballageModel->getHtmlDataField(AnnexeEmballageModel::FIELDNAME_LARGEUR_ANNEXE_EMBALLAGE);
 //Hauteur de l'emballage
 $bloc .= $annexeEmballageModel->getHtmlDataField(AnnexeEmballageModel::FIELDNAME_HAUTEUR_ANNEXE_EMBALLAGE);
 //Poids de l'emballage
 $bloc .= $annexeEmballageModel->getHtmlDataField(AnnexeEmballageModel::FIELDNAME_POIDS_ANNEXE_EMBALLAGE);
 //Nombre d'emballage présent
 switch ($annexeEmballageGroupeModel->getDataField(AnnexeEmballageGroupeModel::FIELDNAME_ID_ANNEXE_EMBALLAGE_GROUPE_CONFIGURATION)->getFieldValue()) {
     case 1:
         $idAnnexeEmballageGroupeTypeTmp = $annexeEmballageGroupeTypeModel->getDataField(AnnexeEmballageGroupeTypeModel::KEYNAME)->getFieldValue();
         //Quantité par couche
         if ($idAnnexeEmballageGroupeTypeTmp == 2) {
             $nbEmballage .= '<tr><td>Quantité par Colis:</td><td>';
             if (!$quantite_par_couche_fta_conditionnement) {
                 $quantite_par_couche_fta_conditionnement = $ftaModel->getDataField(FtaModel::FIELDNAME_NOMBRE_UVC_PAR_CARTON)->getFieldValue();
                 if (!$quantite_par_couche_fta_conditionnement) {
                     $quantite_par_couche_fta_conditionnement = 0;
                 }
             }
         } else {
             $nbEmballage .= '<tr><td>Quantité par UVC:</td><td>';
             $quantite_par_couche_fta_conditionnement = 0;
         }
         $nbEmballage .= '<input type=text name= ' . FtaConditionnementModel::FIELDNAME_QUANTITE_PAR_COUCHE_FTA_CONDITIONNEMENT . ' value=\'' . $quantite_par_couche_fta_conditionnement . '\' size=20/ >';
         $nbEmballage .= '</td></tr>';
         //Nombre de couche
         $nbEmballage .= '<input type=hidden name=' . FtaConditionnementModel::FIELDNAME_NOMBRE_COUCHE_FTA_CONDITIONNEMENT . ' value=1 size=20/>';
         $nbEmballage .= '</td></tr>';
         break;
     case 3:
//    $bloc .=$ingredient_fta_composition;
$bloc .= $ftaComposantView->getHtmlDataField(FtaComposantModel::FIELDNAME_INGREDIENT_FTA_COMPOSITION);
//}
//$bloc.="</td></tr>";
//Liste des ingrédients (extension supplémentaire)
//$bloc .= "<tr><td>" . DatabaseDescription::getFieldDocLabel(FtaComposantModel::TABLENAME, FtaComposantModel::FIELDNAME_INGREDIENT_FTA_COMPOSITION1) . "</td><td>";
//
//if ($proprietaire) {
//    $bloc .= "<textarea name=" . FtaComposantModel::FIELDNAME_INGREDIENT_FTA_COMPOSITION1 . " rows=15 cols=75>" . $ingredient_fta_composition1 . "</textarea>";
//} else {
//    $bloc .=$ingredient_fta_composition1;
$bloc .= $ftaComposantView->getHtmlDataField(FtaComposantModel::FIELDNAME_INGREDIENT_FTA_COMPOSITION1);
//}
$bloc .= "</td></tr>";
//Site de Fabrication
$SiteDeProduction = $ftaModel->getDataField(FtaModel::FIELDNAME_SITE_PRODUCTION)->getFieldValue();
//Site de facbrication de la composition
$HtmlList = new HtmlListSelect();
$bloc .= $ftaComposantView->showListeDeroulanteSiteProdForComposant($HtmlList, $editable, FtaComposantModel::FIELDNAME_ID_GEO);
//$bloc.="</td></tr>";
//echo $id_fta."<br>";
//Durée de Vie
//$bloc .= "<tr><td>" . DatabaseDescription::getFieldDocLabel(FtaComposantModel::TABLENAME, FtaComposantModel::FIELDNAME_DUREE_VIE_TECHNIQUE_FTA_COMPOSITION) . "</td><td>";
//if ($proprietaire) {
//    $bloc .= "<input type=text name=" . FtaComposantModel::FIELDNAME_DUREE_VIE_TECHNIQUE_FTA_COMPOSITION . " value='" . $duree_vie_technique_fta_composition . "' size=50/>";
//} else {
//    $bloc .=$duree_vie_technique_fta_composition;
$bloc .= $ftaComposantView->getHtmlDataField(FtaComposantModel::FIELDNAME_DUREE_VIE_TECHNIQUE_FTA_COMPOSITION);
//}
//$bloc.="</td></tr>";
//Poids
Exemplo n.º 7
0
 Initialisation des variables
*/
$page_default = substr(strrchr($_SERVER['PHP_SELF'], '/'), '1', '-4');
$page_action = $page_default . '_post.php';
$page_pdf = $page_default . '_pdf.php';
$action = 'valider';
//Action proposée à la page _post.php
$method = 'POST';
//Pour une url > 2000 caractères, ne pas utiliser utiliser GET
$html_table = 'table ' . 'border=1 ' . 'width=100% ' . 'class=contenu ';
/*
 Récupération des données MySQL
*/
//Informations de la Fiche Originale
$id_dossier_fta_original = $ftaOrigModel->getDossierFta();
$id_version_dossier_fta_original = $ftaOrigModel->getDataField(FtaModel::FIELDNAME_VERSION_DOSSIER_FTA)->getFieldValue();
//Informations de la Nouvelle Fiche
$id_dossier_fta_new = $ftaNewModel->getDossierFta();
$id_version_dossier_fta_new = $ftaNewModel->getDataField(FtaModel::FIELDNAME_VERSION_DOSSIER_FTA)->getFieldValue();
/*
 Création des objets HTML (listes déroulante, cases à cocher ...etc.)
*/
/* * *********
  Fin Code PHP
 * ********* */
/* * ************
  Début Code HTML
 * ************ */
echo '
     <form method=post action=modification_fiche.php>
     <input type=hidden name=action value=' . $action . '>
  */
 $checkArcadiaData = Fta2ArcadiaTransactionModel::isIdArcadiaTransactionActif($idFta);
 $id_fta_chapitre_encours = Lib::getParameterFromRequest('id_fta_chapitre_encours', '1');
 $synthese_action = Lib::isDefined('synthese_action');
 $comeback = Lib::isDefined('comeback');
 $idFtaEtat = Lib::isDefined(FtaEtatModel::KEYNAME);
 $abreviationFtaEtat = Lib::isDefined(FtaEtatModel::FIELDNAME_ABREVIATION);
 $idFtaRole = Lib::isDefined(FtaRoleModel::KEYNAME);
 $ftaModification = Acl::getValueAccesRights('fta_modification');
 $id_fta_chapitre = $id_fta_chapitre_encours;
 /**
  * Initilisation
  */
 $ftaModel = new FtaModel($idFta);
 //Rien ne garantie que l'utilisateur est mis un idFta existant
 $idWorkflowFtaEncours = $ftaModel->getDataField(FtaModel::FIELDNAME_WORKFLOW)->getFieldValue();
 $idSiteDeProduction = $ftaModel->getDataField(FtaModel::FIELDNAME_SITE_PRODUCTION)->getFieldValue();
 /**
  * Ticket 49823 en 3.1 activation/désactivation d'un workflow
  */
 //    FtaWorkflowModel::checkActifWorkflow($idWorkflowFtaEncours);
 /**
  * Verification des droits d'accès sur une Fta en modification
  */
 if ($idFtaEtat == FtaEtatModel::ID_VALUE_MODIFICATION and !$ftaModification) {
     $titre = UserInterfaceMessage::FR_WARNING_ACCES_RIGHTS_TITLE;
     $message = UserInterfaceMessage::FR_WARNING_ACCES_RIGHTS;
     $redirection = "index.php";
     Lib::showMessage($titre, $message, $redirection);
 }
 //    $selection_proprietaire1 = Lib::getParameterFromRequest('selection_proprietaire1');
 /**
  * Affiche l'historique de la Fta
  * @param int $paramIdFtaDossier
  * @param int $paramIdFtaWorkflow
  * @return string
  */
 public static function getHtmlHistoriqueFta($paramIdFtaDossier, $paramIdFtaWorkflow)
 {
     /**
      * Historisation des changement d'état initialisé en modification
      */
     $arrayHistoValidationFta = DatabaseOperation::convertSqlStatementWithoutKeyToArray("SELECT DISTINCT " . FtaEtatHistoriqueModel::FIELDNAME_ID_DOSSIER_FTA . "," . FtaEtatHistoriqueModel::FIELDNAME_ID_DOSSIER_VERSION_FTA . "," . FtaEtatHistoriqueModel::FIELDNAME_ID_FTA_ETAT_DEST . "," . UserModel::FIELDNAME_NOM . "," . UserModel::FIELDNAME_PRENOM . "," . FtaEtatHistoriqueModel::FIELDNAME_STATE_CHANGE_DATE . " FROM " . FtaEtatHistoriqueModel::TABLENAME . "," . UserModel::TABLENAME . " WHERE " . FtaEtatHistoriqueModel::TABLENAME . "." . FtaEtatHistoriqueModel::FIELDNAME_ID_USER . "=" . UserModel::TABLENAME . "." . UserModel::KEYNAME . " AND " . FtaEtatHistoriqueModel::FIELDNAME_ID_DOSSIER_FTA . "=" . $paramIdFtaDossier . " ORDER BY " . FtaEtatHistoriqueModel::FIELDNAME_STATE_CHANGE_DATE . " DESC ");
     if ($arrayHistoValidationFta) {
         foreach ($arrayHistoValidationFta as $rowsHistoValidationFta) {
             $ftaEtatModel = new FtaEtatModel($rowsHistoValidationFta[FtaEtatHistoriqueModel::FIELDNAME_ID_FTA_ETAT_DEST]);
             $nomFtaEtat = $ftaEtatModel->getDataField(FtaEtatModel::FIELDNAME_NOM_FTA_ETAT)->getFieldValue();
             $versionEncours = "V" . $rowsHistoValidationFta[FtaEtatHistoriqueModel::FIELDNAME_ID_DOSSIER_VERSION_FTA];
             $nomSignataire = $rowsHistoValidationFta[UserModel::FIELDNAME_PRENOM] . " " . $rowsHistoValidationFta[UserModel::FIELDNAME_NOM];
             $dateValidation = $rowsHistoValidationFta[FtaEtatHistoriqueModel::FIELDNAME_STATE_CHANGE_DATE];
             /**
              * Changment de format de date
              */
             $date = FtaController::changementDuFormatDeDateFR($dateValidation);
             $arrayHistoModif[] = array("date" => $date, "nom" => $nomSignataire, "version" => $versionEncours, "etat" => $nomFtaEtat, "oldValue" => $oldValue, "newValue" => $newValue);
         }
     }
     /**
      * Listes des tables Fta à vérifier
      */
     $arrayTableCheck = array(FtaModel::TABLENAME, FtaComposantModel::TABLENAME, FtaConditionnementModel::TABLENAME);
     /**
      * Historiques des changement de données par les utilisateurs
      */
     foreach ($arrayTableCheck as $rowsTableCheck) {
         /**
          * Tableau des Fta selon le dossier encours
          */
         $arrayIdFta = FtaModel::getArrayIdFtaByIdDossierFta($paramIdFtaDossier);
         foreach ($arrayIdFta as $rowsIdFta) {
             $idFtaEncours = $rowsIdFta[FtaModel::KEYNAME];
             $ftaModelEncours = new FtaModel($idFtaEncours);
             $versionFta = "V" . $ftaModelEncours->getDataField(FtaModel::FIELDNAME_VERSION_DOSSIER_FTA)->getFieldValue();
             /**
              * Listes des noms des champs avec le label de la table encours
              */
             if ($rowsTableCheck == FtaModel::TABLENAME) {
                 $model = new FtaModel($idFtaEncours);
                 $model->setDataFtaTableToCompare();
                 $arrayChamps = DatabaseOperation::convertSqlStatementWithoutKeyToArray("SELECT DISTINCT " . IntranetColumnInfoModel::FIELDNAME_COLUMN_NAME_INTRANET_COLUMN_INFO . "," . IntranetColumnInfoModel::FIELDNAME_LABEL_INTRANET_COLUMN_INFO . "," . IntranetColumnInfoModel::FIELDNAME_ID_LISTE_CHAPITRE_HISTORIQUE . " FROM " . IntranetColumnInfoModel::TABLENAME . " WHERE " . IntranetColumnInfoModel::FIELDNAME_TABLE_NAME_INTRANET_COLUMN_INFO . "='" . $rowsTableCheck . "'" . " AND " . IntranetColumnInfoModel::FIELDNAME_IS_ENABLED_INTRANET_HISTORIQUE . "=" . IntranetColumnInfoModel::IS_ENABLED_INTRANET_HISTORIQUE_TRUE);
                 foreach ($arrayChamps as $rowsChamps) {
                     $check = $model->getDataField($rowsChamps[IntranetColumnInfoModel::FIELDNAME_COLUMN_NAME_INTRANET_COLUMN_INFO])->isFieldDiff();
                     if ($check) {
                         $htmlObjetOld = Html::getHtmlObjectFromDataField($model->getDataToCompare()->getDataFieldByFieldName($rowsChamps[IntranetColumnInfoModel::FIELDNAME_COLUMN_NAME_INTRANET_COLUMN_INFO]));
                         $oldValue = $htmlObjetOld->getRawContent();
                         $htmlObjetNew = Html::getHtmlObjectFromDataField($model->getDataField($rowsChamps[IntranetColumnInfoModel::FIELDNAME_COLUMN_NAME_INTRANET_COLUMN_INFO]));
                         $newValue = $htmlObjetNew->getRawContent();
                         $label = $rowsChamps[IntranetColumnInfoModel::FIELDNAME_LABEL_INTRANET_COLUMN_INFO];
                         $idFtaChapitreTmp = $rowsChamps[IntranetColumnInfoModel::FIELDNAME_ID_LISTE_CHAPITRE_HISTORIQUE];
                         $idFtaChapitreArray = explode(',', $idFtaChapitreTmp);
                         $idFtaChapitre = FtaWorkflowStructureModel::getIdFtaChapitreBetweenArrayByWorkflowAndArrayByColumn($paramIdFtaWorkflow, $idFtaChapitreArray);
                         if ($idFtaChapitre) {
                             $nomSignataire = FtaSuiviProjetModel::getUserNameByIdFtaChapitreAndIdFta($idFtaEncours, $idFtaChapitre);
                             $dateValidation = FtaSuiviProjetModel::getValidationDateByIdFtaChapitreAndIdFta($idFtaEncours, $idFtaChapitre);
                             $arrayHistoModif[] = array("date" => $dateValidation, "nom" => $nomSignataire, "version" => $versionFta, "etat" => $label, "oldValue" => $oldValue, "newValue" => $newValue);
                         }
                     }
                 }
             } elseif ($rowsTableCheck == FtaComposantModel::TABLENAME) {
                 /**
                  * On récupère la liste des composants
                  */
                 $arraIdFtaComposant = FtaComposantModel::getArrayIdFtaComposantTable($idFtaEncours);
                 if ($arraIdFtaComposant) {
                     foreach ($arraIdFtaComposant as $rowsIdFtaComposant) {
                         $idFtaComposant = $rowsIdFtaComposant[FtaComposantModel::KEYNAME];
                         $model = new FtaComposantModel($idFtaComposant);
                         $model->setDataFtaComposantTableToCompare();
                         $arrayChamps = DatabaseOperation::convertSqlStatementWithoutKeyToArray("SELECT DISTINCT " . IntranetColumnInfoModel::FIELDNAME_COLUMN_NAME_INTRANET_COLUMN_INFO . "," . IntranetColumnInfoModel::FIELDNAME_LABEL_INTRANET_COLUMN_INFO . "," . IntranetColumnInfoModel::FIELDNAME_ID_LISTE_CHAPITRE_HISTORIQUE . " FROM " . IntranetColumnInfoModel::TABLENAME . " WHERE " . IntranetColumnInfoModel::FIELDNAME_TABLE_NAME_INTRANET_COLUMN_INFO . "='" . $rowsTableCheck . "'" . " AND " . IntranetColumnInfoModel::FIELDNAME_IS_ENABLED_INTRANET_HISTORIQUE . "=" . IntranetColumnInfoModel::IS_ENABLED_INTRANET_HISTORIQUE_TRUE);
                         foreach ($arrayChamps as $rowsChamps) {
                             $check = $model->getDataField($rowsChamps[IntranetColumnInfoModel::FIELDNAME_COLUMN_NAME_INTRANET_COLUMN_INFO])->isFieldDiff();
                             if ($check) {
                                 $htmlObjetOld = Html::getHtmlObjectFromDataField($model->getDataToCompare()->getDataFieldByFieldName($rowsChamps[IntranetColumnInfoModel::FIELDNAME_COLUMN_NAME_INTRANET_COLUMN_INFO]));
                                 $oldValue = $htmlObjetOld->getRawContent();
                                 $htmlObjetNew = Html::getHtmlObjectFromDataField($model->getDataField($rowsChamps[IntranetColumnInfoModel::FIELDNAME_COLUMN_NAME_INTRANET_COLUMN_INFO]));
                                 $newValue = $htmlObjetNew->getRawContent();
                                 $label = $rowsChamps[IntranetColumnInfoModel::FIELDNAME_LABEL_INTRANET_COLUMN_INFO];
                                 $idFtaChapitreTmp = $rowsChamps[IntranetColumnInfoModel::FIELDNAME_ID_LISTE_CHAPITRE_HISTORIQUE];
                                 $idFtaChapitreArray = explode(',', $idFtaChapitreTmp);
                                 $idFtaChapitre = FtaWorkflowStructureModel::getIdFtaChapitreBetweenArrayByWorkflowAndArrayByColumn($paramIdFtaWorkflow, $idFtaChapitreArray);
                                 if ($idFtaChapitre) {
                                     $nomSignataire = FtaSuiviProjetModel::getUserNameByIdFtaChapitreAndIdFta($idFtaEncours, $idFtaChapitre);
                                     $dateValidation = FtaSuiviProjetModel::getValidationDateByIdFtaChapitreAndIdFta($idFtaEncours, $idFtaChapitre);
                                     $arrayHistoModif[] = array("date" => $dateValidation, "nom" => $nomSignataire, "version" => $versionFta, "etat" => $label, "oldValue" => $oldValue, "newValue" => $newValue);
                                 }
                             }
                         }
                     }
                 }
             } elseif ($rowsTableCheck == FtaConditionnementModel::TABLENAME) {
                 $arraIdFtaConditionnment = FtaConditionnementModel::getArrayIdFtaConditionnement($idFtaEncours);
                 /**
                  * On récupère la liste des embalalges
                  */
                 if ($arraIdFtaConditionnment) {
                     foreach ($arraIdFtaConditionnment as $rowsIdFtaConditionnment) {
                         $idFtaConditionnement = $rowsIdFtaConditionnment[FtaConditionnementModel::KEYNAME];
                         $model = new FtaConditionnementModel($idFtaConditionnement);
                         /**
                          * On vérifie si l'un des champs de l'emballage encours est différents de la version précedentes
                          */
                         $model->setDataFtaConditionnementTableToCompare();
                         /**
                          * restraiendre la liste des champs
                          */
                         $arrayChamps = DatabaseOperation::convertSqlStatementWithoutKeyToArray("SELECT DISTINCT " . IntranetColumnInfoModel::FIELDNAME_COLUMN_NAME_INTRANET_COLUMN_INFO . "," . IntranetColumnInfoModel::FIELDNAME_LABEL_INTRANET_COLUMN_INFO . " FROM " . IntranetColumnInfoModel::TABLENAME . " WHERE " . IntranetColumnInfoModel::FIELDNAME_TABLE_NAME_INTRANET_COLUMN_INFO . "='" . $rowsTableCheck . "'" . " AND " . IntranetColumnInfoModel::FIELDNAME_IS_ENABLED_INTRANET_HISTORIQUE . "=" . IntranetColumnInfoModel::IS_ENABLED_INTRANET_HISTORIQUE_TRUE);
                         foreach ($arrayChamps as $rowsChamps) {
                             $check = $model->getDataField($rowsChamps[IntranetColumnInfoModel::FIELDNAME_COLUMN_NAME_INTRANET_COLUMN_INFO])->isFieldDiff();
                             if ($check) {
                                 $htmlObjetOld = Html::getHtmlObjectFromDataField($model->getDataToCompare()->getDataFieldByFieldName($rowsChamps[IntranetColumnInfoModel::FIELDNAME_COLUMN_NAME_INTRANET_COLUMN_INFO]));
                                 $oldValue = $htmlObjetOld->getRawContent();
                                 $htmlObjetNew = Html::getHtmlObjectFromDataField($model->getDataField($rowsChamps[IntranetColumnInfoModel::FIELDNAME_COLUMN_NAME_INTRANET_COLUMN_INFO]));
                                 $newValue = $htmlObjetNew->getRawContent();
                                 $label = $rowsChamps[IntranetColumnInfoModel::FIELDNAME_LABEL_INTRANET_COLUMN_INFO];
                                 $idFtaChapitreTmp = $rowsChamps[IntranetColumnInfoModel::FIELDNAME_ID_LISTE_CHAPITRE_HISTORIQUE];
                                 $idFtaChapitreArray = explode(',', $idFtaChapitreTmp);
                                 $idFtaChapitre = FtaWorkflowStructureModel::getIdFtaChapitreBetweenArrayByWorkflowAndArrayByColumn($paramIdFtaWorkflow, $idFtaChapitreArray);
                                 if ($idFtaChapitre) {
                                     $nomSignataire = FtaSuiviProjetModel::getUserNameByIdFtaChapitreAndIdFta($idFtaEncours, $idFtaChapitre);
                                     $dateValidation = FtaSuiviProjetModel::getValidationDateByIdFtaChapitreAndIdFta($idFtaEncours, $idFtaChapitre);
                                     $arrayHistoModif[] = array("date" => $dateValidation, "nom" => $nomSignataire, "version" => $versionFta, "etat" => $label, "oldValue" => $oldValue, "newValue" => $newValue);
                                 }
                             }
                         }
                     }
                 }
             }
         }
     }
     /**
      * Affichage du tableau
      */
     if (is_array($arrayHistoModif)) {
         FtaController::arraySortByColumn($arrayHistoModif, "date");
         $tableauFiche .= '<th>' . 'Date' . '</th><th>' . 'Ultilisateur' . '</th><th>' . 'Version du dossier FTA' . '</th><th>' . 'Colonne' . '</th><th>' . 'Ancienne valeur' . '</th><th>' . 'Nouvelle valeur' . '</th>';
         foreach ($arrayHistoModif as $rowsHistoModif) {
             $tableauFiche .= '<tr class=contenu >' . '<td width=8%> ' . $rowsHistoModif["date"] . '</td>' . '<td >' . $rowsHistoModif["nom"] . '</td>' . '<td >' . $rowsHistoModif["version"] . '</td>' . '<td >' . $rowsHistoModif["etat"] . '</td>' . '<td >' . $rowsHistoModif["oldValue"] . '</td>' . '<td >' . $rowsHistoModif["newValue"] . '</td>' . '</tr >';
         }
     }
     return $tableauFiche;
 }
  en fonction de la variable "$action". Ensuite elle redirige le
  résultat vers une autre page.
 Le plus souvent, le traitement est délocalisé sous forme de
  fonction située dans le fichier "functions.php"
*/
/*
 Récupération des données MySQL
*/
$action = Lib::getParameterFromRequest('action');
$paramIdFta = Lib::getParameterFromRequest(FtaModel::KEYNAME);
$paramFieldName = Lib::getParameterFromRequest('FieldName');
$string = substr(strrchr($_SERVER["HTTP_REFERER"], '?'), '1');
/**
 * Initialisation
 */
$ftaModel = new FtaModel($paramIdFta);
$idFtaDossier = $ftaModel->getDataField(FtaModel::FIELDNAME_DOSSIER_FTA)->getFieldValue();
if ($idFtaDossier) {
    $idFtaVerrrouillageChamps = FtaVerrouillageChampsModel::getIdFtaVerrouillageChamps($idFtaDossier, $paramFieldName);
    $ftaVerrouillageChampsModel = new FtaVerrouillageChampsModel($idFtaVerrrouillageChamps);
    $ftaVerrouillageChampsModel->changeStateFieldLock();
    //Redirection
    header('Location: modification_fiche.php?' . $string);
} else {
    $titre = UserInterfaceMessage::FR_WARNING_DATA_VERROUILLAGE_TITLE;
    $message = UserInterfaceMessage::FR_WARNING_DATA_VERROUILLAGE;
    Lib::showMessage($titre, $message, $redirection);
}
?>

Exemplo n.º 11
0
 public static function updatetFtaSuiviProjet($paramIdFta)
 {
     /*
      * Changement de workflow fais par la chef de projet
      */
     $ftaModel = new FtaModel($paramIdFta);
     $idFtaWorlflow = $ftaModel->getDataField(FtaModel::FIELDNAME_WORKFLOW)->getFieldValue();
     $arrayChapitre = DatabaseOperation::convertSqlStatementWithoutKeyToArray('SELECT ' . FtaWorkflowStructureModel::FIELDNAME_ID_FTA_CHAPITRE . ', ' . FtaWorkflowStructureModel::FIELDNAME_ID_FTA_PROCESSUS . ' FROM ' . FtaWorkflowStructureModel::TABLENAME . ' WHERE ' . FtaWorkflowStructureModel::FIELDNAME_ID_FTA_WORKFLOW . '=' . $idFtaWorlflow);
     /*
      * On supprime de la table fta_suivi_projet tous les chapitres de l'ancien workflow 
      * sauf les chapitres du processus identidé.
      */
     DatabaseOperation::execute('DELETE FROM ' . FtaSuiviProjetModel::TABLENAME . ' WHERE ' . FtaSuiviProjetModel::FIELDNAME_ID_FTA . '=' . $paramIdFta . ' AND ' . FtaSuiviProjetModel::FIELDNAME_ID_FTA_CHAPITRE . '<>1' . ' AND ' . FtaSuiviProjetModel::FIELDNAME_ID_FTA_CHAPITRE . '<>21' . ' AND ' . FtaSuiviProjetModel::FIELDNAME_ID_FTA_CHAPITRE . '<>22' . ' AND ' . FtaSuiviProjetModel::FIELDNAME_ID_FTA_CHAPITRE . '<>23' . ' AND ' . FtaSuiviProjetModel::FIELDNAME_ID_FTA_CHAPITRE . '<>32');
     foreach ($arrayChapitre as $rowsChapitre) {
         if ($rowsChapitre[FtaWorkflowStructureModel::FIELDNAME_ID_FTA_PROCESSUS] == 0) {
             DatabaseOperation::execute('INSERT INTO ' . FtaSuiviProjetModel::TABLENAME . '(' . FtaSuiviProjetModel::FIELDNAME_ID_FTA . ', ' . FtaSuiviProjetModel::FIELDNAME_ID_FTA_CHAPITRE . ', ' . FtaSuiviProjetModel::FIELDNAME_SIGNATURE_VALIDATION_SUIVI_PROJET . ') VALUES (' . $paramIdFta . ', ' . $rowsChapitre[FtaWorkflowStructureModel::FIELDNAME_ID_FTA_CHAPITRE] . ', 1 )');
         } else {
             $arrayCheckIdSuiviProjet = DatabaseOperation::convertSqlStatementWithoutKeyToArray('SELECT ' . FtaSuiviProjetModel::KEYNAME . ' FROM ' . FtaSuiviProjetModel::TABLENAME . ' WHERE ' . FtaSuiviProjetModel::FIELDNAME_ID_FTA . '=' . $paramIdFta . ' AND ' . FtaSuiviProjetModel::FIELDNAME_ID_FTA_CHAPITRE . '=' . $rowsChapitre[FtaSuiviProjetModel::FIELDNAME_ID_FTA_CHAPITRE]);
             if (!$arrayCheckIdSuiviProjet) {
                 DatabaseOperation::execute('INSERT INTO ' . FtaSuiviProjetModel::TABLENAME . '(' . FtaSuiviProjetModel::FIELDNAME_ID_FTA . ', ' . FtaSuiviProjetModel::FIELDNAME_ID_FTA_CHAPITRE . ', ' . FtaSuiviProjetModel::FIELDNAME_SIGNATURE_VALIDATION_SUIVI_PROJET . ') VALUES (' . $paramIdFta . ', ' . $rowsChapitre[FtaWorkflowStructureModel::FIELDNAME_ID_FTA_CHAPITRE] . ', 0 )');
             }
         }
     }
 }
Exemplo n.º 12
0
 public static function getChapitreDefautByWorkflow($paramId)
 {
     $ftaModel = new FtaModel($paramId);
     $IdWorkflow = $ftaModel->getDataField(FtaModel::FIELDNAME_WORKFLOW)->getFieldValue();
     /*
      * Non fonctionnelle
      */
     $rarrayChapitreDefaut = DatabaseOperation::convertSqlStatementWithoutKeyToArray('SELECT DISTINCT ' . FtaProcessusModel::TABLENAME . '.' . FtaProcessusModel::KEYNAME . ' FROM ' . FtaProcessusModel::TABLENAME . 'LEFT JOIN ' . FtaProcessusCycleModel::TABLENAME . ' ON ' . FtaProcessusCycleModel::TABLENAME . '.' . FtaProcessusCycleModel::FIELDNAME_PROCESSUS_NEXT . '=' . FtaProcessusModel::TABLENAME . '.' . FtaProcessusModel::KEYNAME . ' WHERE ' . FtaProcessusCycleModel::TABLENAME . '.' . FtaProcessusCycleModel::FIELDNAME_WORKFLOW . '=' . $IdWorkflow);
     foreach ($rarrayChapitreDefaut as $rowsChapitreDefaut) {
         return $rowsChapitreDefaut[FtaProcessusModel::KEYNAME];
     }
 }
 /**
  * 
  * @param type $paramIdFta
  * @param type $paramIdChapitre
  * @return type
  */
 public static function getIdFtaWorkflowStructureByIdFtaAndIdChapitre($paramIdFta, $paramIdChapitre)
 {
     //Géneration de id_fta_workflow
     $modelFta = new FtaModel($paramIdFta);
     $idFtaWorkflow = $modelFta->getDataField(FtaModel::FIELDNAME_WORKFLOW)->getFieldValue();
     //Récupération du tableau de résultat
     $keyName = FtaWorkflowStructureModel::KEYNAME;
     $tableName = FtaWorkflowStructureModel::TABLENAME;
     $idFtaWorkflowName = FtaWorkflowStructureModel::FIELDNAME_ID_FTA_WORKFLOW;
     $idFtaChapitreName = FtaWorkflowStructureModel::FIELDNAME_ID_FTA_CHAPITRE;
     $sql = 'SELECT ' . $keyName . ' ' . 'FROM ' . $tableName . ' ' . 'WHERE ' . $idFtaWorkflowName . '=' . $idFtaWorkflow . ' ' . 'AND ' . $idFtaChapitreName . '=' . $paramIdChapitre . ' ';
     $array = DatabaseOperation::convertSqlStatementWithoutKeyToArray($sql);
     //Retourne uniquement la première valeur
     return $array[0][$keyName];
 }
Exemplo n.º 14
0
 /**
  * Actualisation du calcul de la duree de vie client pour les espace de trvail MDD
  * @param string $paramWorkflow
  * @param string $paramNomChapitre
  * @param FtaModel $paramFtaModel
  */
 public static function refreshDureeDeVieMDD($paramWorkflow, $paramNomChapitre, FtaModel $paramFtaModel)
 {
     switch ($paramWorkflow) {
         case FtaWorkflowModel::NOM_FTA_WORKFLOW_MDD_AVEC:
         case FtaWorkflowModel::NOM_FTA_WORKFLOW_MDD_SANS:
             if ($paramNomChapitre == FtaChapitreModel::NOM_CHAPITRE_DUREE_DE_VIE) {
                 $dureeDeVieProductionValue = $paramFtaModel->getDureeDeVieClientByDureeDeVieProduction();
                 $paramFtaModel->getDataField(FtaModel::FIELDNAME_DUREE_DE_VIE)->setFieldValue($dureeDeVieProductionValue);
                 $paramFtaModel->saveToDatabase();
             }
             break;
         default:
             break;
     }
 }
Exemplo n.º 15
0
<?php

/* * ***********
  Début Code PDF
 * *********** */
$id_fta = Lib::getParameterFromRequest(FtaModel::KEYNAME);
//Récupération des Informations FTA
$ftaModel = new FtaModel($id_fta);
$siteDeProduction = $ftaModel->getDataField(FtaModel::FIELDNAME_SITE_PRODUCTION)->getFieldValue();
$description_origine_transformation_fta = $ftaModel->getDataField(FtaModel::FIELDNAME_PRODUIT_TRANSFORME)->getFieldValue();
$idFtaWorkflow = $ftaModel->getDataField(FtaModel::FIELDNAME_WORKFLOW)->getFieldValue();
switch ($description_origine_transformation_fta) {
    case "0":
        $description_origine_transformation_fta = "Non";
        break;
    case "1":
    case "2":
        $description_origine_transformation_fta = "Oui";
        break;
}
$NOM_origine_transformation_fta = $ftaModel->getDataField(FtaModel::FIELDNAME_PRODUIT_TRANSFORME)->getFieldLabel();
$synoptique_valide_fta = $ftaModel->getDataField(FtaModel::FIELDNAME_DESCRIPTION_DU_PRODUIT)->getFieldValue();
$NOM_synoptique_valide_fta = $ftaModel->getDataField(FtaModel::FIELDNAME_DESCRIPTION_DU_PRODUIT)->getFieldLabel();
$geoModel = new GeoModel($siteDeProduction);
$site_agrement_ce = $geoModel->getDataField(GeoModel::FIELDNAME_SITE_AGREMENT_CE)->getFieldValue();
$NOM_site_agrement_ce = $geoModel->getDataField(GeoModel::FIELDNAME_SITE_AGREMENT_CE)->getFieldLabel();
//Récupération des information de classification.
//Rayon
$IdFtaClassification2 = $ftaModel->getDataField(FtaModel::FIELDNAME_ID_FTA_CLASSIFICATION2)->getFieldValue();
if ($IdFtaClassification2) {
    $rayon = ClassificationArborescenceArticleCategorieContenuModel::getElementClassificationFta($IdFtaClassification2, ClassificationFta2Model::FIELDNAME_ID_RAYON);
Exemplo n.º 16
0
     break;
     /*     * *********
           Fin Code PDF
          * ********* */
 /*     * *********
       Fin Code PDF
      * ********* */
 default:
     /*
      Création des objets HTML (listes déroulante, cases à cocher ...etc.)
     */
     $bloc = '';
     /*
      * Marque
      */
     $IdFtaClassification2 = $ftaModel->getDataField(FtaModel::FIELDNAME_ID_FTA_CLASSIFICATION2)->getFieldValue();
     $classificationMarque = ClassificationArborescenceArticleCategorieContenuModel::getElementClassificationFta($IdFtaClassification2, ClassificationFta2Model::FIELDNAME_ID_MARQUE);
     $bloc .= 'Marque(s) <i>(anciennement gamme)</i>:';
     $bloc .= $classificationMarque;
     $bloc .= '<br>';
     /*
      * Activité
      */
     $classificationActivite = ClassificationArborescenceArticleCategorieContenuModel::getElementClassificationFta($IdFtaClassification2, ClassificationFta2Model::FIELDNAME_ID_ACTIVITE);
     $bloc .= 'Activité(s) <i>(anciennement ségment)</i>:';
     $bloc .= $classificationActivite;
     $bloc .= '<br>';
     /*         * ************
               Début Code HTML
              * ************ */
     echo '
     $modelFta = new FtaModel($paramIdFta);
     $idDossierFta = $modelFta->getDossierFta();
     /**
      * Liste des IdFta changeant d'espace de travail
      */
     $arrayIdFtaChange = FtaModel::getArrayIdFtaByIdDossierFta($idDossierFta);
     foreach ($arrayIdFtaChange as $rowsIdFtaChange) {
         $idFta = $rowsIdFtaChange[FtaModel::KEYNAME];
         $idFtaEtatChange = $rowsIdFtaChange[FtaModel::FIELDNAME_ID_FTA_ETAT];
         $ftaEtatModel = new FtaEtatModel($idFtaEtatChange);
         $arbreviationFta = $ftaEtatModel->getDataField(FtaEtatModel::FIELDNAME_ABREVIATION)->getFieldValue();
         /**
          * Changement de l'espace de travail
          */
         $ftaModel = new FtaModel($idFta);
         $ftaModel->getDataField(FtaModel::FIELDNAME_WORKFLOW)->setFieldValue($idFtaWorkflowNEW);
         $oldComment = $ftaModel->getDataField(FtaModel::FIELDNAME_COMMENTAIRE_MAJ_FTA)->getFieldValue();
         $ftaModel->getDataField(FtaModel::FIELDNAME_COMMENTAIRE_MAJ_FTA)->setFieldValue($commentaire . $oldComment);
         $ftaModel->saveToDatabase();
         FtaSuiviProjetModel::createNewChapitresFromNewWorkflow($idFta, $idFtaWorkflowNEW, $arbreviationFta, $idUser);
         /**
          * Suppression des chapitres de l'ancien espace de travail
          */
         FtaSuiviProjetModel::deleteOldChapitreFromOldWorkflow($idFta, $idFtaWorkflowNEW);
     }
     //Redirection
     header('Location: modification_fiche.php?id_fta=' . $paramIdFta . '&id_fta_chapitre_encours=' . $paramIdFtaChapitreEncours . '&synthese_action=' . $paramSyntheseAction . '&id_fta_etat=' . $idFtaEtat . '&abreviation_fta_etat=' . $abreviationFtaEtat . '&id_fta_role=' . FtaRoleModel::ID_FTA_ROLE_COMMUN);
 } else {
     $titre = UserInterfaceMessage::FR_WARNING_DATA_ESPACE_DE_TRAVAIL_TITLE;
     $message = UserInterfaceMessage::FR_WARNING_DATA_ESPACE_DE_TRAVAIL_CHANGEMENT;
     Lib::showMessage($titre, $message, $redirection);
Exemplo n.º 18
0
 /**
  * Affiche la liste des espaces de travail pour lesquel l'utilisateur connecté à les droits d'accès
  * et l'identifiant de la Fta en cours
  * @param int $paramIdUser
  * @param HtmlListSelect $paramObjetList
  * @param boolean $paramIsEditable
  * @param int $paramIdFta
  * @return string
  */
 public static function showListeDeroulanteNomWorkflowByAccesAndIdFta($paramIdUser, $paramObjetList, $paramIsEditable, $paramIdFta, $paramIdRole)
 {
     $ftaModel = new FtaModel($paramIdFta);
     $arrayWorkflow = DatabaseOperation::convertSqlStatementWithKeyAndOneFieldToArray('SELECT DISTINCT ' . self::TABLENAME . '.' . self::KEYNAME . ',' . self::FIELDNAME_DESCRIPTION_FTA_WORKFLOW . ' FROM ' . self::TABLENAME . ', ' . IntranetDroitsAccesModel::TABLENAME . ', ' . FtaWorkflowStructureModel::TABLENAME . ' WHERE ' . self::FIELDNAME_DESCRIPTION_FTA_WORKFLOW . '<>\'\'' . ' AND ' . self::TABLENAME . '.' . self::FIELDNAME_ID_INTRANET_ACTIONS . '=' . IntranetDroitsAccesModel::TABLENAME . '.' . IntranetDroitsAccesModel::FIELDNAME_ID_INTRANET_ACTIONS . ' AND ' . FtaWorkflowStructureModel::TABLENAME . '.' . FtaWorkflowStructureModel::FIELDNAME_ID_FTA_ROLE . '=' . $paramIdRole . ' AND ' . self::TABLENAME . '.' . self::KEYNAME . '=' . FtaWorkflowStructureModel::TABLENAME . '.' . FtaWorkflowStructureModel::FIELDNAME_ID_FTA_WORKFLOW . ' AND ' . IntranetDroitsAccesModel::FIELDNAME_ID_USER . '=' . $paramIdUser . ' AND ' . IntranetDroitsAccesModel::TABLENAME . '.' . IntranetDroitsAccesModel::FIELDNAME_NIVEAU_INTRANET_DROITS_ACCES . '=' . IntranetNiveauAccesModel::NIVEAU_GENERIC_TRUE . ' ORDER BY ' . self::FIELDNAME_DESCRIPTION_FTA_WORKFLOW);
     $paramObjetList->setArrayListContent($arrayWorkflow);
     $HtmlTableName = FtaModel::TABLENAME . '_' . FtaModel::FIELDNAME_WORKFLOW . '_' . $paramIdFta;
     $paramObjetList->getAttributes()->getName()->setValue(FtaModel::FIELDNAME_WORKFLOW);
     $paramObjetList->setLabel(DatabaseDescription::getFieldDocLabel(self::TABLENAME, self::FIELDNAME_DESCRIPTION_FTA_WORKFLOW));
     $paramObjetList->setIsEditable($paramIsEditable);
     $paramObjetList->initAbstractHtmlSelect($HtmlTableName, $paramObjetList->getLabel(), $ftaModel->getDataField(FtaModel::FIELDNAME_WORKFLOW)->getFieldValue(), NULL, $paramObjetList->getArrayListContent());
     $paramObjetList->getEventsForm()->setOnChangeWithAjaxAutoSave(FtaModel::TABLENAME, FtaModel::KEYNAME, $paramIdFta, FtaModel::FIELDNAME_WORKFLOW);
     $listeSiteWorkflow = $paramObjetList->getHtmlResult();
     return $listeSiteWorkflow;
 }
Exemplo n.º 19
0
 Récupération des données MySQL
*/
/*
 Création des objets HTML (listes déroulante, cases à cocher ...etc.)
*/
$id_fta = Lib::getParameterFromRequest(FtaModel::KEYNAME);
$idFtaRole = Lib::getParameterFromRequest(FtaRoleModel::KEYNAME);
$globalConfig = new GlobalConfig();
UserModel::checkUserSessionExpired($globalConfig);
$idUser = $globalConfig->getAuthenticatedUser()->getKeyValue();
$checked_vierge = '';
$checked_duplicate = '';
if ($id_fta) {
    $checked_duplicate = 'checked';
    $ftaModel = new FtaModel($id_fta);
    $idFtaWorkflow = $ftaModel->getDataField(FtaModel::FIELDNAME_WORKFLOW)->getFieldValue();
    $SiteDeProduction = $ftaModel->getDataField(FtaModel::FIELDNAME_SITE_PRODUCTION)->getFieldValue();
    $designationCommercialeFta = $ftaModel->getDataField(FtaModel::FIELDNAME_DESIGNATION_COMMERCIALE)->getFieldValue();
    $arrayIdFtaRoleAcces = FtaRoleModel::getArrayIdFtaRoleByIdUserAndWorkflow($idUser, $idFtaWorkflow);
    $idFtaRole = $arrayIdFtaRoleAcces["0"];
    $comeback = Lib::getParameterFromRequest('comeback');
    /**
     * Initialisation du bouton de retour de synthèse
     */
    if ($comeback) {
        $_SESSION["comeback_url"] = $_SERVER["HTTP_REFERER"];
    }
} else {
    $checked_vierge = 'checked';
}
$HtmlList = new HtmlListSelectTagName();
$selection_activite = Lib::getParameterFromRequest('selection_activite2');
$selection_rayon = Lib::getParameterFromRequest('selection_rayon2');
$selection_environnement = Lib::getParameterFromRequest('selection_environnement2');
$selection_reseau = Lib::getParameterFromRequest('selection_reseau2');
$selection_saisonnalite = Lib::getParameterFromRequest('selection_saisonnalite2');
if ($selection_saisonnalite) {
    //Enregistrement du nouvel éléments de classification
    $idClassification2 = ClassificationFta2Model::getIdFtaClassification2($selection_proprietaire1, $selection_proprietaire2, $selection_marque, $selection_activite, $selection_rayon, $selection_environnement, $selection_reseau, $selection_saisonnalite);
}
switch ($action) {
    /*
     S'il n'y a pas d'actions défini
    */
    case 'valider':
        $modelFta = new FtaModel($paramIdFta);
        $modelFta->getDataField(FtaModel::FIELDNAME_ID_FTA_CLASSIFICATION2)->setFieldValue($idClassification2);
        /**
         * Vérification que la classification est des données correspondantes Arcadia
         */
        $modelFta->checkArcadiaClassifData($idClassification2);
        $abreviationFtaEtat = $modelFta->getModelFtaEtat()->getDataField(FtaEtatModel::FIELDNAME_ABREVIATION)->getFieldValue();
        $modelFta->saveToDatabase();
        //Redirection
        header('Location: modification_fiche.php?id_fta=' . $paramIdFta . '&id_fta_chapitre_encours=' . $paramIdFtaChapitreEncours . '&synthese_action=' . $paramSyntheseAction . '&id_fta_etat=' . $idFtaEtat . '&abreviation_fta_etat=' . $abreviationFtaEtat . '&id_fta_role=' . $idFtaRole);
        break;
    case 'gestionnaire':
        $validation = DatabaseOperation::execute("UPDATE " . FtaModel::TABLENAME . " SET " . FtaModel::FIELDNAME_ID_FTA_CLASSIFICATION2 . "=" . $idClassification2 . " WHERE " . FtaModel::FIELDNAME_DOSSIER_FTA . "=" . $paramIdFta);
        //Redirection
        header('Location: modification_classification.php');
        break;
    case 'gestionnaire1':
Exemplo n.º 21
0
        //           include ('./menu_principal.inc');    //Sinon, menu par défaut
        //        }
}
//Fin de la sélection du mode d'affichage de la page
$id_fta = Lib::getParameterFromRequest(FtaModel::KEYNAME);
$synthese_action = Lib::getParameterFromRequest('synthese_action');
$id_fta_chapitre_encours = Lib::getParameterFromRequest('id_fta_chapitre_encours', '1');
$comeback = Lib::getParameterFromRequest('comeback');
$idFtaEtat = Lib::getParameterFromRequest(FtaEtatModel::KEYNAME);
$abreviationFtaEtat = Lib::getParameterFromRequest(FtaEtatModel::FIELDNAME_ABREVIATION);
$idFtaRole = Lib::getParameterFromRequest(FtaRoleModel::KEYNAME);
/**
 * Initialisation
 */
$ftaModel = new FtaModel($id_fta);
$date_echeance_fta = $ftaModel->getDataField(FtaModel::FIELDNAME_DATE_ECHEANCE_FTA)->getFieldValue();
$idFtaWorkflow = $ftaModel->getDataField(FtaModel::FIELDNAME_WORKFLOW)->getFieldValue();
$globalConfig = new GlobalConfig();
if ($globalConfig->getAuthenticatedUser()) {
    $idUser = $globalConfig->getAuthenticatedUser()->getKeyValue();
} else {
    $titre = UserInterfaceMessage::FR_WARNING_DECONNECTION_TITLE;
    $message = UserInterfaceMessage::FR_WARNING_DECONNECTION;
    Lib::showMessage($titre, $message, $redirection);
}
$idUser = $globalConfig->getAuthenticatedUser()->getKeyValue();
/**
 * Contrôle du rôle attribué
 */
if ($idFtaRole == FtaRoleModel::ID_FTA_ROLE_COMMUN) {
    if ($abreviationFtaEtat == FtaEtatModel::ETAT_ABREVIATION_VALUE_MODIFICATION) {
Exemplo n.º 22
0
function calcul_palettisation_fta($id_fta)
{
    /*
     Valeurs de retours de la fonction:
    */
    //Emballages
    $return["uvc_emballage"] = 0;
    //Poids de l'emballage contenu dans une UVC
    $return["colis_emballage"] = 0;
    //Poids de l'emballage contenu dans un Colis
    $return["palette_emballage"] = 0;
    //Poids de l'emballage contenu dans une Palette
    //Poids net
    $return["uvc_net"];
    $return["colis_net"];
    $return["palette_net"];
    //Poids brut
    $return["uvc_brut"];
    $return["colis_brut"];
    $return["palette_brut"];
    //Palettisation
    $return["pcb"];
    $return["hauteur_colis"];
    $return["hauteur_palette"];
    $return["couche_palette"];
    //Combien de couche par palette
    $return["colis_couche"];
    //Combien de colis par couche
    $return["total_colis"];
    $return["dimension_uvc"];
    //H x L x l
    $return["dimension_colis"];
    $return["dimension_palette"];
    $return["dimension_uvc_hauteur"] = 0;
    //Hauteur en mm
    $return["dimension_uvc_longueur"] = 0;
    //Longueur en mm
    $return["dimension_uvc_largeur"] = 0;
    //Hauteur en mm
    /*
     Dictionnaire des variables:
    */
    $id_fta;
    //Identifiant de la fiche technique Article
    //$palettisation_2_3_3 = calcul_palettisation_fta_2_3_3($id_fta);         //Ancienne Données
    /*
     Corps de la fonction
    */
    //PCB
    $return["pcb"] = $temp_nb_uvc_dans_colis;
    if (!$return["pcb"]) {
        $req = "SELECT NB_UNIT_ELEM FROM fta WHERE id_fta='" . $id_fta . "' ";
        $result = DatabaseOperation::convertSqlStatementWithoutKeyToArray($req);
        foreach ($result as $value) {
            $NB_UNIT_ELEM = $value["NB_UNIT_ELEM"];
        }
        $return["pcb"] = $NB_UNIT_ELEM;
    }
    //Calcul du poids et dimension de Emballages par UVC (Type 1)
    $id_annexe_emballage_groupe_type = 1;
    $description_annexe_emballage_groupe_type = "uvc_emballage";
    $req = "SELECT * " . " FROM fta_conditionnement, annexe_emballage_groupe, annexe_emballage_groupe_type " . " WHERE id_fta=" . $id_fta . " AND annexe_emballage_groupe_type.id_annexe_emballage_groupe_type=" . $id_annexe_emballage_groupe_type . " AND fta_conditionnement.id_annexe_emballage_groupe=annexe_emballage_groupe.id_annexe_emballage_groupe " . " AND ( " . "( fta_conditionnement.id_annexe_emballage_groupe_type IS NOT NULL AND fta_conditionnement.id_annexe_emballage_groupe_type=annexe_emballage_groupe_type.id_annexe_emballage_groupe_type )" . " OR " . "( fta_conditionnement.id_annexe_emballage_groupe_type IS NULL AND annexe_emballage_groupe.id_annexe_emballage_groupe_configuration=annexe_emballage_groupe_type.id_annexe_emballage_groupe_type )" . "    ) " . " ORDER BY nom_annexe_emballage_groupe_type ";
    $arrayType1 = DatabaseOperation::convertSqlStatementWithoutKeyToArray($req);
    if ($arrayType1) {
        foreach ($arrayType1 as $rows) {
            //Calcul du poids
            $return["{$description_annexe_emballage_groupe_type}"] += $rows["poids_fta_conditionnement"] * $rows["quantite_par_couche_fta_conditionnement"] * $rows["nombre_couche_fta_conditionnement"];
            //Calcul des dimension (on recherche la taille la plus grande
            if ($return["dimension_uvc_hauteur"] < $rows["hauteur_fta_conditionnement"]) {
                $return["dimension_uvc_hauteur"] = $rows["hauteur_fta_conditionnement"];
            }
            if ($return["dimension_uvc_longueur"] < $rows["longueur_fta_conditionnement"]) {
                $return["dimension_uvc_longueur"] = $rows["longueur_fta_conditionnement"];
            }
            if ($return["dimension_uvc_largeur"] < $rows["largeur_fta_conditionnement"]) {
                $return["dimension_uvc_largeur"] = $rows["largeur_fta_conditionnement"];
            }
        }
        //$return["dimension_uvc"]=$return["dimension_uvc_hauteur"]."x".$return["dimension_uvc_longueur"]."x".$return["dimension_uvc_largeur"];
        $return["dimension_uvc"] = $return["dimension_uvc_longueur"] . "x" . $return["dimension_uvc_largeur"];
        //Si la hauteur n'est pas nulle, on l'intègre.
        if ($return["dimension_uvc_hauteur"]) {
            $return["dimension_uvc"] = $return["dimension_uvc"] . "x" . $return["dimension_uvc_hauteur"];
        }
    } else {
        //Tentative de récupération des données au format version 2.3.3
        //$return["dimension_uvc"]=$palettisation_2_3_3["dimension_uvc"];
        //$return["$description_annexe_emballage_groupe_type"]=$palettisation_2_3_3["uvc_emballage"];
    }
    //echo   "Emballage dans l'UVC: ".$return["$description_annexe_emballage_groupe_type"]."<br>";
    //Calcul du poids de Emballages par Colis (Type 2)
    $id_annexe_emballage_groupe_type = 2;
    $description_annexe_emballage_groupe_type = "colis_emballage";
    /* $req = "SELECT * "
        . "FROM fta_conditionnement, annexe_emballage_groupe, annexe_emballage_groupe_type "
        . "WHERE id_fta=$id_fta "
        . "AND annexe_emballage_groupe_type.id_annexe_emballage_groupe_type=$id_annexe_emballage_groupe_type "
        . "AND fta_conditionnement.id_annexe_emballage_groupe=annexe_emballage_groupe.id_annexe_emballage_groupe "
        . "AND fta_conditionnement.id_annexe_emballage_groupe_type=annexe_emballage_groupe_type.id_annexe_emballage_groupe_type "
        . "ORDER BY nom_annexe_emballage_groupe_type "
        ;
       */
    $req = "SELECT * " . " FROM fta_conditionnement, annexe_emballage_groupe, annexe_emballage_groupe_type " . " WHERE id_fta=" . $id_fta . " AND annexe_emballage_groupe_type.id_annexe_emballage_groupe_type=" . $id_annexe_emballage_groupe_type . " AND fta_conditionnement.id_annexe_emballage_groupe=annexe_emballage_groupe.id_annexe_emballage_groupe " . " AND ( " . "( fta_conditionnement.id_annexe_emballage_groupe_type IS NOT NULL AND fta_conditionnement.id_annexe_emballage_groupe_type=annexe_emballage_groupe_type.id_annexe_emballage_groupe_type )" . " OR " . "( fta_conditionnement.id_annexe_emballage_groupe_type IS NULL AND annexe_emballage_groupe.id_annexe_emballage_groupe_configuration=annexe_emballage_groupe_type.id_annexe_emballage_groupe_type )" . "    ) " . " ORDER BY nom_annexe_emballage_groupe_type ";
    $arrayType2 = DatabaseOperation::convertSqlStatementWithoutKeyToArray($req);
    if ($arrayType2) {
        foreach ($arrayType2 as $rows) {
            $return["{$description_annexe_emballage_groupe_type}"] += $rows["poids_fta_conditionnement"] * $rows["quantite_par_couche_fta_conditionnement"] * $rows["nombre_couche_fta_conditionnement"];
        }
    } else {
        //Tentative de récupération des données au format version 2.3.3
        //$return["$description_annexe_emballage_groupe_type"]=$palettisation_2_3_3["$description_annexe_emballage_groupe_type"];
    }
    //echo   "Emballage dans le colis (sans l'UVC): ".$return["$description_annexe_emballage_groupe_type"]."<br>";
    //$return["$description_annexe_emballage_groupe_type"]+=$return["uvc_emballage"];
    $return["{$description_annexe_emballage_groupe_type}"] += $return["uvc_emballage"] * $return["pcb"];
    //Ajout de l'emballage du Colis (Type 3)
    $id_annexe_emballage_groupe_type = 3;
    $description_annexe_emballage_groupe_type = "colis_emballage";
    /* $req = "SELECT * "
        . "FROM fta_conditionnement, annexe_emballage_groupe, annexe_emballage_groupe_type "
        . "WHERE id_fta=$id_fta "
        . "AND annexe_emballage_groupe_type.id_annexe_emballage_groupe_type=$id_annexe_emballage_groupe_type "
        . "AND fta_conditionnement.id_annexe_emballage_groupe=annexe_emballage_groupe.id_annexe_emballage_groupe "
        . "AND fta_conditionnement.id_annexe_emballage_groupe_type=annexe_emballage_groupe_type.id_annexe_emballage_groupe_type "
        . "ORDER BY nom_annexe_emballage_groupe_type "
        ;
       */
    $req = "SELECT * " . " FROM fta_conditionnement, annexe_emballage_groupe, annexe_emballage_groupe_type " . " WHERE id_fta=" . $id_fta . " AND annexe_emballage_groupe_type.id_annexe_emballage_groupe_type=" . $id_annexe_emballage_groupe_type . " AND fta_conditionnement.id_annexe_emballage_groupe=annexe_emballage_groupe.id_annexe_emballage_groupe " . " AND ( " . "( fta_conditionnement.id_annexe_emballage_groupe_type IS NOT NULL AND fta_conditionnement.id_annexe_emballage_groupe_type=annexe_emballage_groupe_type.id_annexe_emballage_groupe_type )" . " OR " . "( fta_conditionnement.id_annexe_emballage_groupe_type IS NULL AND annexe_emballage_groupe.id_annexe_emballage_groupe_configuration=annexe_emballage_groupe_type.id_annexe_emballage_groupe_type )" . "    ) " . " ORDER BY nom_annexe_emballage_groupe_type ";
    $arrayType3 = DatabaseOperation::convertSqlStatementWithoutKeyToArray($req);
    if (count($arrayType3) > 1) {
        $titre = "Cas non géré";
        $message = "Il ne doit y avoir qu'un seul emballage Colis";
        afficher_message($titre, $message, $redirection);
    } else {
        //Il ne doit exister qu'un seul emballage Colis
        if ($arrayType3) {
            foreach ($arrayType3 as $rows) {
                //echo   "Emballage du colis: ".$rows["poids_fta_conditionnement"]."<br>";
                //echo   "Emballage du colis: ".$return["colis_emballage"]."<br>";
                //echo $return["colis_emballage"];
                $return["hauteur_colis"] = $rows["hauteur_fta_conditionnement"];
                $return["colis_emballage"] += $rows["poids_fta_conditionnement"];
                $return["couche_palette"] = $rows["nombre_couche_fta_conditionnement"];
                $return["colis_couche"] = $rows["quantite_par_couche_fta_conditionnement"];
                $temp_nb_colis_dans_palette = $return["couche_palette"] * $return["colis_couche"];
                $hauteur_total_palette = $rows["hauteur_fta_conditionnement"] * $return["couche_palette"];
                if ($rows["old_dim"]) {
                    $return["dimension_colis"] = $rows["old_dim"];
                } else {
                    $return["dimension_colis"] = $rows["longueur_fta_conditionnement"] . "x" . $rows["largeur_fta_conditionnement"] . "x" . $rows["hauteur_fta_conditionnement"] . " mm";
                }
            }
            $return["colis_emballage"] += $return["uvc_emballage"] * $temp_nb_uvc_dans_colis;
            $return["total_colis"] = $temp_nb_colis_dans_palette;
        } else {
            //Tentative de récupération des données au format version 2.3.3
            /* $return["$description_annexe_emballage_groupe_type"]=$palettisation_2_3_3["$description_annexe_emballage_groupe_type"];
                          $return["hauteur_colis"]=$palettisation_2_3_3["hauteur_colis"];
                          $return["total_colis"]=$palettisation_2_3_3["total_colis"];
                          $temp_nb_colis_dans_palette=$return["total_colis"];
            
                          $return["couche_palette"]=$palettisation_2_3_3["couche_palette"];
                          $return["colis_couche"]=$palettisation_2_3_3["colis_couche"]; */
        }
    }
    //echo   "Emballage total du colis: ".$return["$description_annexe_emballage_groupe_type"]."<br>";
    //Calcul du poids des emballages d'une Palette
    $id_annexe_emballage_groupe_type = 4;
    $description_annexe_emballage_groupe_type = "palette_emballage";
    /* $req = "SELECT * "
        . "FROM fta_conditionnement, annexe_emballage_groupe, annexe_emballage_groupe_type "
        . "WHERE id_fta=$id_fta "
        . "AND annexe_emballage_groupe_type.id_annexe_emballage_groupe_type=$id_annexe_emballage_groupe_type "
        . "AND fta_conditionnement.id_annexe_emballage_groupe=annexe_emballage_groupe.id_annexe_emballage_groupe "
        . "AND fta_conditionnement.id_annexe_emballage_groupe_type=annexe_emballage_groupe_type.id_annexe_emballage_groupe_type "
        . "ORDER BY nom_annexe_emballage_groupe_type "
        ;
       */
    $req = "SELECT * " . " FROM fta_conditionnement, annexe_emballage_groupe, annexe_emballage_groupe_type " . " WHERE id_fta=" . $id_fta . " AND annexe_emballage_groupe_type.id_annexe_emballage_groupe_type=" . $id_annexe_emballage_groupe_type . " AND fta_conditionnement.id_annexe_emballage_groupe=annexe_emballage_groupe.id_annexe_emballage_groupe " . " AND ( " . "( fta_conditionnement.id_annexe_emballage_groupe_type IS NOT NULL AND fta_conditionnement.id_annexe_emballage_groupe_type=annexe_emballage_groupe_type.id_annexe_emballage_groupe_type )" . " OR " . "( fta_conditionnement.id_annexe_emballage_groupe_type IS NULL AND annexe_emballage_groupe.id_annexe_emballage_groupe_configuration=annexe_emballage_groupe_type.id_annexe_emballage_groupe_type )" . "    ) " . " ORDER BY nom_annexe_emballage_groupe_type ";
    $arrayType4 = DatabaseOperation::convertSqlStatementWithoutKeyToArray($req);
    if (count($arrayType4) > 1) {
        $titre = "Cas non géré";
        $message = "Il ne doit y avoir qu'une seule Palette";
        afficher_message($titre, $message, $redirection);
    } else {
        //Il ne doit exister qu'une seule Palette
        if ($arrayType4) {
            foreach ($arrayType4 as $rows) {
                $return["palette_emballage"] += $rows["poids_fta_conditionnement"] / 1000;
                //Converstion de gramme en Kilo
                $return["dimension_palette"] = $rows["longueur_fta_conditionnement"] . "x" . $rows["largeur_fta_conditionnement"] . "x" . $rows["hauteur_fta_conditionnement"] . " mm";
                $hauteur_palette = $rows["hauteur_fta_conditionnement"];
            }
            $return["palette_emballage"] += $return["colis_emballage"] / 1000 * $temp_nb_colis_dans_palette;
            //Conversion gramme vers Kilo
        } else {
            //Tentative de récupération des données au format version 2.3.3
            //$return["palette_emballage"]=$palettisation_2_3_3["palette_emballage"];
            //$return["dimension_palette"]=$palettisation_2_3_3["dimension_palette"];
        }
    }
    //Calcul des poids net
    $ftaModel = new FtaModel($id_fta);
    $return["uvc_net"] = $ftaModel->getDataField("Poids_ELEM")->getFieldValue() * 1000;
    //Conversion de Kg en Gramme
    //Le calcul du poids net colis est fonction de la composition colis
    //$return["colis_net"]=$return["pcb"] * $return["uvc_net"] / 1000;      //Conversion de g en Kg
    $return["colis_net"] = calcul_poids_net_colis($id_fta);
    $return["palette_net"] = $return["colis_net"] * $temp_nb_colis_dans_palette;
    //Poids brut
    $return["uvc_brut"] = $return["uvc_net"] + $return["uvc_emballage"];
    $return["colis_brut"] = $return["colis_net"] + $return["colis_emballage"] / 1000;
    $return["palette_brut"] = $return["palette_net"] + $return["palette_emballage"];
    //Palettisation
    //Hauteur palette
    $hauteur_total_palette = $hauteur_total_palette + $hauteur_palette;
    $return["hauteur_palette"] = $hauteur_total_palette / 1000;
    return $return;
}
Exemplo n.º 23
0
 public static function getHtmlTable($paramIdFta, $paramChoix, $paramResultLimitByPage = self::DEFAULT_RESULT_LIMIT_BY_PAGE, $paramOrderCommon = NULL)
 {
     /*
      * Déclaration des variables locales
      */
     $largeur_html_C1 = self::HTML_CELL_WIDTH_C1;
     // largeur cellule type
     $largeur_html_C3 = self::HTML_CELL_WIDTH_C3;
     // largeur cellule type
     $compteur_ligne = 1;
     $selection_width = self::HTML_CELL_WIDTH_SELECTION;
     $lien = "";
     $tableau_fiches = "<table class=titre width=100% border=0>" . "<tr class=titre_principal><td></td><td>";
     $synthese_action = "all";
     /*
      * Initilisation
      */
     $globalConfig = new GlobalConfig();
     UserModel::checkUserSessionExpired($globalConfig);
     $idUser = $globalConfig->getAuthenticatedUser()->getKeyValue();
     $idFtaRole = FtaRoleModel::getKeyNameOfFirstRoleByIdUser($idUser);
     $ftaModel = new FtaModel($paramIdFta);
     //Chargement manuel des données pour optimiser les performances
     $abreviation_fta_etat = $ftaModel->getModelFtaEtat()->getDataField(FtaEtatModel::FIELDNAME_ABREVIATION)->getFieldValue();
     $LIBELLE = $ftaModel->getDataField(FtaModel::FIELDNAME_LIBELLE)->getFieldValue();
     $NB_UNIT_ELEM = $ftaModel->getDataField(FtaModel::FIELDNAME_NOMBRE_UVC_PAR_CARTON)->getFieldValue();
     $Poids_ELEM = $ftaModel->getDataField(FtaModel::FIELDNAME_POIDS_ELEMENTAIRE)->getFieldValue();
     $suffixe_agrologic_fta = $ftaModel->getModelClassificationRacourcis()->getNameRaccourcisClassif();
     $designation_commerciale_fta = $ftaModel->getDataField(FtaModel::FIELDNAME_DESIGNATION_COMMERCIALE)->getFieldValue();
     $id_dossier_fta = $ftaModel->getDataField(FtaModel::FIELDNAME_DOSSIER_FTA)->getFieldValue();
     $id_version_dossier_fta = $ftaModel->getDataField(FtaModel::FIELDNAME_VERSION_DOSSIER_FTA)->getFieldValue();
     $code_article_ldc = $ftaModel->getDataField(FtaModel::FIELDNAME_CODE_ARTICLE_LDC)->getFieldValue();
     $dateEcheanceFtatmp = $ftaModel->getDataField(FtaModel::FIELDNAME_DATE_ECHEANCE_FTA)->getFieldValue();
     $createur_nom = $ftaModel->getModelCreateur()->getDataField(UserModel::FIELDNAME_NOM)->getFieldValue();
     $createur_prenom = $ftaModel->getModelCreateur()->getDataField(UserModel::FIELDNAME_PRENOM)->getFieldValue();
     $workflowName = $ftaModel->getModelFtaWorkflow()->getDataField(FtaWorkflowModel::FIELDNAME_DESCRIPTION_FTA_WORKFLOW)->getFieldValue();
     $idWorkflowFtaEncours = $ftaModel->getModelFtaWorkflow()->getKeyValue();
     $nomSiteProduction = $ftaModel->getModelSiteProduction()->getDataField(GeoModel::FIELDNAME_GEO)->getFieldValue();
     $idclassification = $ftaModel->getDataField(FtaModel::FIELDNAME_ID_FTA_CLASSIFICATION2)->getFieldValue();
     $listeIdFtaRole = $ftaModel->getDataField(FtaModel::FIELDNAME_LISTE_ID_FTA_ROLE)->getFieldValue();
     $idSiteDeProduction = $ftaModel->getDataField(FtaModel::FIELDNAME_SITE_PRODUCTION)->getFieldValue();
     $idFtaEtat = $ftaModel->getDataField(FtaModel::FIELDNAME_ID_FTA_ETAT)->getFieldValue();
     /**
      * Changment du format de date en Fr
      */
     $dateEcheanceFta = FtaController::changementDuFormatDeDateFR($dateEcheanceFtatmp);
     /**
      * On obtient IdintranetAction du site de production
      */
     $idIntranetActionsSiteDeProduction = FtaActionSiteModel::getArrayIdIntranetActionByWorkflowAndSiteDeProduction($idWorkflowFtaEncours, $idSiteDeProduction);
     /**
      * On verifie si selon le workflow  et site de production en cours l'utilisateur connecté à les droits d'accès.
      * Puisqu'un utilisateur ne doit pas avoir accès aux boutons :
      * historique, transition, retirer, duplication et pourcentage d'avancement
      * si il n'a pas les accès aux site de production.
      */
     $checkAccesButtonBySiteProd = IntranetActionsModel::isAccessFtaActionByIdUserFtaWorkflowAndSiteDeProduction($idUser, $idWorkflowFtaEncours, $idIntranetActionsSiteDeProduction);
     /**
      * Donne accès aux bouton de transition 
      * pour les utilisateur se trouvant en fin de parcours de l'espace de travail
      */
     $accesTransitionButton = FtaTransitionModel::isAccesTransitionButton($idFtaRole, $idWorkflowFtaEncours);
     /*
      * Attribution des couleurs de fonds suivant l'état de la FTA
      */
     $bgcolor = self::getHtmlCellBgColor($abreviation_fta_etat);
     $bgcolorArcadia = self::getHtmlCellBgColorArcadia($paramIdFta, $bgcolor);
     $tauxRound = FtaSuiviProjetModel::getPourcentageFtaTauxValidation($ftaModel);
     /**
      * Lien vers l'historique de la Fta
      */
     $lienHistorique = self::getHtmlLinkHistorique($abreviation_fta_etat, $paramIdFta, FtaRoleModel::ID_FTA_ROLE_COMMUN, $synthese_action, $tauxRound, $checkAccesButtonBySiteProd, $idFtaEtat);
     /**
      * Gestion des icones en fonction des délais
      */
     $bgcolor_header = self::getHtmlBgColorIconHeader($abreviation_fta_etat, $paramIdFta);
     $icon_header = self::getHtmlIconEcheanceByEtatAndFta($abreviation_fta_etat, $paramIdFta);
     /**
      * Bouton d'accès au détail de la FTA
      */
     $lien .= self::getHtmlLinkModify($abreviation_fta_etat, $paramIdFta, $synthese_action, $idFtaEtat, $checkAccesButtonBySiteProd);
     /**
      * Historique de modification
      */
     $lien .= self::getHtmlLinkHistoriqueModfify($abreviation_fta_etat, $paramIdFta, $synthese_action, $idFtaEtat);
     /**
      * Bouton d'accès au rendu PDF de la FTA
      */
     $lien .= self::getHtmlLinkPDF($abreviation_fta_etat, $paramIdFta, $idWorkflowFtaEncours);
     /**
      * Bouton d'accès à la transition
      */
     $lien .= self::getHmlLinkTransiter($paramIdFta, $idFtaRole, $abreviation_fta_etat, $checkAccesButtonBySiteProd, $accesTransitionButton, $synthese_action, $tauxRound);
     /**
      * Bouton d'accès pour retirer une FTA
      */
     if (FtaRoleModel::isGestionnaire($idFtaRole) and $checkAccesButtonBySiteProd and $abreviation_fta_etat != FtaEtatModel::ETAT_ABREVIATION_VALUE_RETIRE) {
         $lien .= self::getHtmlLinkRemoveFta($paramIdFta);
         $javascript .= self::getJavascriptLinkRemoveFta($paramIdFta, $idFtaRole, $synthese_action);
     }
     /**
      * Bouton d'accès pour dupliquer  une FTA
      */
     if (FtaRoleModel::isGestionnaire($idFtaRole) and $checkAccesButtonBySiteProd) {
         $lien .= self::getHtmlLinkDuplicateFta($paramIdFta, $idFtaRole);
     }
     //Désignation commerciale
     $din = self::getStringDINCompacted($designation_commerciale_fta, $LIBELLE, $NB_UNIT_ELEM, $Poids_ELEM);
     /*
      * Noms des services dans lequel la Fta se trouve
      */
     $service = FtaRoleModel::getNameServiceEncours($listeIdFtaRole);
     //        switch (TRUE) {
     //            /**
     //             * Si la FTA est en modification et que l'utilisateur n'est pas autorisé à accéder aux boutons.
     //             */
     //            case (
     //            $abreviation_fta_etat == FtaEtatModel::ETAT_ABREVIATION_VALUE_MODIFICATION AND $checkAccesButton != FALSE
     //            ):
     //                $service = "";
     //                break;
     //
     //            /**
     //             * Si la FTA est en modification et que l'utilisateur est autorisé à accéder aux boutons.
     //             */
     //            case (
     //            $abreviation_fta_etat == FtaEtatModel::ETAT_ABREVIATION_VALUE_MODIFICATION AND $checkAccesButton != TRUE
     //            ):
     //                $service = FtaRoleModel::getNameServiceEncours($listeIdFtaRole);
     //                break;
     //            /**
     //             * Sinon:
     //             */
     //            default:
     //                $service = FtaRoleModel::getNameServiceEncours($listeIdFtaRole);
     //        }
     /**
      * Calssification
      */
     if ($idclassification) {
         $classification = ClassificationArborescenceArticleCategorieContenuModel::getElementClassificationFta($idclassification, ClassificationFta2Model::FIELDNAME_ID_PROPRIETAIRE_GROUPE);
     }
     //Nom de l'assistante de projet responsable:
     $createur_link = "\"Géré par {$createur_prenom} {$createur_nom}\"";
     $tableau_fiches .= "<tr class=contenu>\r\n                              <td {$bgcolor_header} " . $selection_width . " > {$icon_header} {$selection}</td>\r\n                              ";
     $tableau_fiches .= '<td ' . $bgcolor . ' width=8%>' . $nomSiteProduction . '<br>(' . $workflowName . ')</td>' . '<td ' . $bgcolor . ' width=3%>' . $classification . '</td>' . '<td ' . $bgcolor . ' width=3%>' . $suffixe_agrologic_fta . '</td>';
     // Raccourcie Class.
     $tableau_fiches .= "<td {$bgcolor} {$largeur_html_C1}><a title={$createur_link} />" . $din . "</a></td>" . "<td {$bgcolor} width=3%>" . $id_dossier_fta . "v" . $id_version_dossier_fta . "</td>";
     $tableau_fiches .= "<td {$bgcolorArcadia} width=\"1%\"> <b><font size=\"2\" color=\"#0000FF\">" . $code_article_ldc . "</font></b></td>";
     if ($abreviation_fta_etat == FtaEtatModel::ETAT_ABREVIATION_VALUE_MODIFICATION) {
         $tableau_fiches .= '<td ' . $bgcolor . $largeur_html_C3 . ' align=center>' . $dateEcheanceFta . '</td>';
         //échance de validation
     } else {
         $tableau_fiches .= '<td ' . $bgcolor . $largeur_html_C3 . ' align=center>' . $dateEcheanceFta . '</td>';
         //échance de validation
     }
     $tableau_fiches .= '<td ' . $bgcolor . ' width=5% align=center >' . $lienHistorique . '</td>' . '<td ' . $bgcolor . $largeur_html_C3 . ' align=center >' . $service . '</td>' . '<td ' . $bgcolor . ' width=8%' . ' align=center >' . $lien . '</td>';
     // Actions
     $tableau_fiches .= "</tr>";
     $compteur_ligne++;
     //        }//fin tant que tableau_origine
     $tableau_fiches = $javascript . $tableau_fiches . "</table>";
     //Ajoute de la fonction de traitement de masse
     if ($traitementDeMasse) {
         $liste_action_groupe = FtaTransitionModel::getListeFtaGrouper($abreviation_fta_etat);
         $tableau_fiches .= '&nbsp;
         <img src = ../lib/images/fleche_gauche_et_haut.png width = 38 height = 22 border = 0 />
         <i>Transitions groupées</i>:
         ' . $liste_action_groupe . '
         <input type = \'text\' name=\'subject\' size=\'20\' />
         <input type=image src=images/transiter.png width=20 height=20 />
         <input type=hidden name=action value=transition_groupe>
                      ';
     }
     return $tableau_fiches;
 }
 /**
  * On affiche la liste des gammes famille budget associé à une classification
  * @param object $paramFtaModel FtaModel
  * @param int $paramIdClassificationFta2
  * @param boolean $paramIsEditable
  * @return string
  */
 public static function getHtmlClassificationGammeFamilleBudget(FtaModel $paramFtaModel, $paramIdClassificationFta2, $paramIsEditable)
 {
     $htmlList = new HtmlListSelect();
     $paramFtaModel->setDataFtaTableToCompare();
     $idMarque = ClassificationFta2Model::getIdClassificationTypeByTypeNameAndIdClassificationFta2($paramIdClassificationFta2, ClassificationFta2Model::FIELDNAME_ID_MARQUE);
     $dataFieldIdArcadiaGammeFamilleBudgetTMP = $paramFtaModel->getDataField(FtaModel::FIELDNAME_ID_ARCADIA_GAMME_FAMILLE_BUDGET);
     $arrayGammeFamilleBudget = DatabaseOperation::convertSqlStatementWithKeyAndOneFieldToArray('SELECT DISTINCT ' . ArcadiaGammeFamilleBudgetModel::TABLENAME . '.' . ArcadiaGammeFamilleBudgetModel::KEYNAME . ', CONCAT_WS(  \' - \',' . ArcadiaGammeFamilleBudgetModel::TABLENAME . '.' . ArcadiaGammeFamilleBudgetModel::KEYNAME . ',' . ArcadiaGammeFamilleBudgetModel::FIELDNAME_NOM_ARCADIA_GAMME_FAMILLE_BUDGET . ') FROM ' . ArcadiaGammeFamilleBudgetModel::TABLENAME . ',' . self::TABLENAME . ' WHERE ' . ArcadiaGammeFamilleBudgetModel::TABLENAME . '.' . ArcadiaGammeFamilleBudgetModel::KEYNAME . ' = ' . self::TABLENAME . '.' . self::FIELDNAME_ID_ARCADIA_GAMME_FAMILLE_BUDGET . ' AND ' . self::FIELDNAME_ID_MARQUE . '=' . $idMarque . ' ORDER BY ' . ArcadiaGammeFamilleBudgetModel::KEYNAME);
     /**
      * Si le chapitre est editable alors on vérifie si 
      * pour une classification nous avons plusieurs gamme famille budget associé
      * Si nous avons plusieur résultat alors on affiche la liste déroulante 
      * sinon on enregistre l'unique  résutat 
      */
     //        if ($paramIsEditable == Chapitre::EDITABLE) {
     //            if (count($arrayGammeFamilleBudget) > "1") {
     //                $paramIsEditable = Chapitre::EDITABLE;
     //            } else {
     //                /**
     //                 * Enregistrement de la donnée gamme famille budget
     //                 */
     //                if ($arrayGammeFamilleBudget) {
     //                    foreach ($arrayGammeFamilleBudget as $key => $value) {
     //                        $ftaModel->getDataField(FtaModel::FIELDNAME_ID_ARCADIA_GAMME_FAMILLE_BUDGET)->setFieldValue($key);
     //                        $ftaModel->saveToDatabase();
     //                    }
     //                }
     //                $paramIsEditable = Chapitre::NOT_EDITABLE;
     //            }
     //        }
     $htmlList->setArrayListContent($arrayGammeFamilleBudget);
     /**
      * On vérifie si la donnée en BDD se trouve dans le tableau
      * Sinon alors on vide la donnée de la BDD
      */
     $dataFieldIdArcadiaGammeFamilleBudget = FtaController::checkDataInArrayKeyList($dataFieldIdArcadiaGammeFamilleBudgetTMP, $arrayGammeFamilleBudget);
     $HtmlTableName = FtaModel::TABLENAME . '_' . FtaModel::FIELDNAME_ID_ARCADIA_GAMME_FAMILLE_BUDGET . '_' . $paramFtaModel->getKeyValue();
     /**
      * Vérification des règle de validation
      */
     $dataFieldIdArcadiaGammeFamilleBudget->checkValidationRules();
     if ($dataFieldIdArcadiaGammeFamilleBudget->getDataValidationSuccessful() == TRUE) {
         $htmlList->setIsWarningMessage($dataFieldIdArcadiaGammeFamilleBudget->getDataValidationSuccessful());
         $paramFtaModel->setDataValidationSuccessfulToTrue();
     } else {
         $htmlList->setIsWarningMessage($dataFieldIdArcadiaGammeFamilleBudget->getDataValidationSuccessful());
         $htmlList->setWarningMessage($dataFieldIdArcadiaGammeFamilleBudget->getDataWarningMessage());
         $paramFtaModel->setDataValidationSuccessfulToFalse();
     }
     $htmlList->getAttributes()->getName()->setValue(FtaModel::FIELDNAME_ID_ARCADIA_GAMME_FAMILLE_BUDGET);
     $htmlList->setLabel(DatabaseDescription::getFieldDocLabel(FtaModel::TABLENAME, FtaModel::FIELDNAME_ID_ARCADIA_GAMME_FAMILLE_BUDGET));
     $htmlList->setIsEditable($paramIsEditable);
     $htmlList->initAbstractHtmlSelect($HtmlTableName, $htmlList->getLabel(), $dataFieldIdArcadiaGammeFamilleBudget->getFieldValue(), $dataFieldIdArcadiaGammeFamilleBudget->isFieldDiff(), $htmlList->getArrayListContent(), $htmlList->getIsWarningMessage(), $htmlList->getWarningMessage());
     $htmlList->getEventsForm()->setOnChangeWithAjaxAutoSave(FtaModel::TABLENAME, FtaModel::KEYNAME, $paramFtaModel->getKeyValue(), FtaModel::FIELDNAME_ID_ARCADIA_GAMME_FAMILLE_BUDGET);
     /**
      * Description d'un champ
      */
     $htmlList->setHelp(IntranetColumnInfoModel::getFieldDesc($dataFieldIdArcadiaGammeFamilleBudget->getTableName(), $dataFieldIdArcadiaGammeFamilleBudget->getFieldName(), $dataFieldIdArcadiaGammeFamilleBudget->getFieldLabel(), $htmlList));
     $listeGammeFamilleBudget = $htmlList->getHtmlResult();
     return $listeGammeFamilleBudget;
 }
$userModelOLD = new UserModel($createurFtaOLD);
$userModelNEW = new UserModel($createurFtaNEW);
$nomWorkflowOLD = $userModelOLD->getPrenomNom();
$nomWorkflowNEW = $userModelNEW->getPrenomNom();
$commentaire = FtaController::getCommentGestionnaireChange($nomWorkflowOLD, $nomWorkflowNEW, $nomPrenomConnect);
switch ($action) {
    /*
     S'il n'y a pas d'actions défini
    */
    case 'valider':
        if ($createurFtaOLD != $createurFtaNEW) {
            $modelFta = new FtaModel($paramIdFta);
            /**
             * Commentaire de modification du gestionnaire de la Fta
             */
            $commentaire_maj_fta = $modelFta->getDataField(FtaModel::FIELDNAME_COMMENTAIRE_MAJ_FTA)->getFieldValue();
            $modelFta->getDataField(FtaModel::FIELDNAME_COMMENTAIRE_MAJ_FTA)->setFieldValue($commentaire . $commentaire_maj_fta);
            $modelFta->getDataField(FtaModel::FIELDNAME_CREATEUR)->setFieldValue($createurFtaNEW);
            $modelFta->saveToDatabase();
            //Redirection
            header('Location: modification_fiche.php?id_fta=' . $paramIdFta . '&id_fta_chapitre_encours=' . $paramIdFtaChapitreEncours . '&synthese_action=' . $paramSyntheseAction . '&id_fta_etat=' . $idFtaEtat . '&abreviation_fta_etat=' . $abreviationFtaEtat . '&id_fta_role=' . FtaRoleModel::ID_FTA_ROLE_COMMUN);
        } else {
            $titre = UserInterfaceMessage::FR_WARNING_DATA_GESTIONNAIRE_TITLE;
            $message = UserInterfaceMessage::FR_WARNING_DATA_GESTIONNAIRE;
            Lib::showMessage($titre, $message, $redirection);
        }
        break;
        /*     * **********
              Fin de switch
             * ********** */
}
Exemplo n.º 26
0
 /**
  * Affiche le lien vers les Fta secondaires
  * @param int $paramIdFtaChapitre
  * @param string $paramSyntheseAction
  * @param int $paramComeback  
  * @param int $paramIdFtaRole
  * @return string
  */
 function getLinkToSecondaryFta($paramIdFtaChapitre, $paramSyntheseAction, $paramComeback, $paramIdFtaRole)
 {
     $arraySecondaryFta = $this->getArrayIdFtaFromDossierFtaPrimary();
     $separator = " ";
     $link = "<tr ><td class=\"contenu\"> " . UserInterfaceLabel::FR_FTA_SECONDAIRE . "</td ><td class=\"contenu\" width=75% >";
     foreach ($arraySecondaryFta as $rowsSecondaryFta) {
         $ftaModelSecond = new FtaModel($rowsSecondaryFta[self::KEYNAME]);
         /**
          * On vérifie si le code Article Arcadia est renseigné
          * si oui on l'affiche 
          * sinon on affiche le dossier avec la version
          */
         if ($ftaModelSecond->getDataField(self::FIELDNAME_CODE_ARTICLE_LDC)->getFieldValue()) {
             $valueLink = $ftaModelSecond->getDataField(self::FIELDNAME_CODE_ARTICLE_LDC)->getFieldValue();
         } else {
             $valueLink = $ftaModelSecond->getDataField(self::FIELDNAME_DOSSIER_FTA)->getFieldValue() . "v" . $ftaModelSecond->getDataField(FtaModel::FIELDNAME_VERSION_DOSSIER_FTA)->getFieldValue();
         }
         $link .= $separator . "<a href=" . "modification_fiche.php?" . "id_fta=" . $ftaModelSecond->getKeyValue() . "&id_fta_chapitre_encours=" . $paramIdFtaChapitre . "&synthese_action=" . $paramSyntheseAction . "&comeback=" . $paramComeback . "&id_fta_etat=" . $ftaModelSecond->getDataField(self::FIELDNAME_ID_FTA_ETAT)->getFieldValue() . "&abreviation_fta_etat=" . $ftaModelSecond->getModelFtaEtat()->getDataField(FtaEtatModel::FIELDNAME_ABREVIATION)->getFieldValue() . "&id_fta_role=" . $paramIdFtaRole . ">" . $valueLink . "</a>";
         $separator = " - ";
     }
     $link .= "</td></tr>";
     return $link;
 }
 /**
  * On affiche la liste des raccourcis de classification associé à une classification
  * @param objet $paramFtaModel
  * @param int $paramIdClassificationFta2
  * @param boolean $paramIsEditable
  * @return string
  */
 public static function getHtmlClassificationRaccourcisAssociation(FtaModel $paramFtaModel, $paramIdClassificationFta2, $paramIsEditable)
 {
     $htmlList = new HtmlListSelect();
     $paramFtaModel->setDataFtaTableToCompare();
     $dataFieldIdClassificationRaccourcisTMP = $paramFtaModel->getDataField(FtaModel::FIELDNAME_ID_CLASSIFICATION_RACCOURCIS);
     $arrayClassificationRaccourcis = DatabaseOperation::convertSqlStatementWithKeyAndOneFieldToArray('SELECT DISTINCT ' . ClassificationRaccourcisModel::TABLENAME . '.' . ClassificationRaccourcisModel::KEYNAME . ',' . ClassificationRaccourcisModel::TABLENAME . '.' . ClassificationRaccourcisModel::FIELDNAME_NOM_CLASSIFICATION_RACCOURCIS . ' FROM ' . ClassificationRaccourcisModel::TABLENAME . ',' . self::TABLENAME . ' WHERE ' . ClassificationRaccourcisModel::TABLENAME . '.' . ClassificationRaccourcisModel::KEYNAME . ' = ' . self::TABLENAME . '.' . self::FIELDNAME_ID_CLASSIFICATION_RACCOURCIS . ' AND ' . self::FIELDNAME_ID_FTA_CLASSIFICATION2 . '=' . $paramIdClassificationFta2 . ' ORDER BY ' . ClassificationRaccourcisModel::FIELDNAME_NOM_CLASSIFICATION_RACCOURCIS);
     /**
      * Si le chapitre est editable alors on vérifie si 
      * pour une classification nous avons plusieurs raccourcis de classification associé
      * Si nous avons plusieur résultat alors on affiche la liste déroulante 
      * sinon on enregistre l'unique  résutat 
      */
     //        if ($paramIsEditable == Chapitre::EDITABLE) {
     //            if (count($arrayClassificationRaccourcis) > "1") {
     //                $paramIsEditable = Chapitre::EDITABLE;
     //            } else {
     //                /**
     //                 * Enregistrement de la donnée raccourcis de classification
     //                 */
     //                if ($arrayClassificationRaccourcis) {
     //                    foreach ($arrayClassificationRaccourcis as $key => $value) {
     //                        $ftaModel->getDataField(FtaModel::FIELDNAME_ID_CLASSIFICATION_RACCOURCIS)->setFieldValue($key);
     //                        $ftaModel->saveToDatabase();
     //                    }
     //                }
     //                $paramIsEditable = Chapitre::NOT_EDITABLE;
     //            }
     //        }
     $htmlList->setArrayListContent($arrayClassificationRaccourcis);
     /**
      * On vérifie si la donnée en BDD se trouve dans le tableau
      * Sinon alors on vide la donnée de la BDD
      */
     $dataFieldIdClassificationRaccourcis = FtaController::checkDataInArrayKeyList($dataFieldIdClassificationRaccourcisTMP, $arrayClassificationRaccourcis);
     $HtmlTableName = FtaModel::TABLENAME . '_' . FtaModel::FIELDNAME_ID_CLASSIFICATION_RACCOURCIS . '_' . $paramFtaModel->getKeyValue();
     /**
      * Vérification des règle de validation
      */
     $dataFieldIdClassificationRaccourcis->checkValidationRules();
     if ($dataFieldIdClassificationRaccourcis->getDataValidationSuccessful() == TRUE) {
         $htmlList->setIsWarningMessage($dataFieldIdClassificationRaccourcis->getDataValidationSuccessful());
         $paramFtaModel->setDataValidationSuccessfulToTrue();
     } else {
         $htmlList->setIsWarningMessage($dataFieldIdClassificationRaccourcis->getDataValidationSuccessful());
         $htmlList->setWarningMessage($dataFieldIdClassificationRaccourcis->getDataWarningMessage());
         $paramFtaModel->setDataValidationSuccessfulToFalse();
     }
     $htmlList->setSelectedValue($dataFieldIdClassificationRaccourcis->getFieldValue());
     $htmlList->getAttributes()->getName()->setValue(FtaModel::FIELDNAME_ID_CLASSIFICATION_RACCOURCIS);
     $htmlList->setLabel(DatabaseDescription::getFieldDocLabel(ClassificationRaccourcisAssociationModel::TABLENAME, ClassificationRaccourcisAssociationModel::FIELDNAME_ID_CLASSIFICATION_RACCOURCIS));
     $htmlList->setIsEditable($paramIsEditable);
     $htmlList->initAbstractHtmlSelect($HtmlTableName, $htmlList->getLabel(), $dataFieldIdClassificationRaccourcis->getFieldValue(), $dataFieldIdClassificationRaccourcis->isFieldDiff(), $htmlList->getArrayListContent(), $htmlList->getIsWarningMessage(), $htmlList->getWarningMessage());
     $htmlList->getEventsForm()->setOnChangeWithAjaxAutoSave(FtaModel::TABLENAME, FtaModel::KEYNAME, $paramFtaModel->getKeyValue(), FtaModel::FIELDNAME_ID_CLASSIFICATION_RACCOURCIS);
     /**
      * Description d'un champ
      */
     $htmlList->setHelp(IntranetColumnInfoModel::getFieldDesc($dataFieldIdClassificationRaccourcis->getTableName(), $dataFieldIdClassificationRaccourcis->getFieldName(), $dataFieldIdClassificationRaccourcis->getFieldLabel(), $htmlList));
     $listeClassificationRaccourcis = $htmlList->getHtmlResult();
     return $listeClassificationRaccourcis;
 }
Exemplo n.º 28
0
 /**
  * Envoi un mail d'information détaillé (pour une FTA uniquement)
  * @param type $paramIdFta
  * @param type $paramListeDiffusion
  * @param type $paramCommentaire
  */
 public static function buildEnvoiMailDetail($paramIdFta, $paramListeDiffusion, $paramCommentaire)
 {
     /**
      * Initilisation
      */
     $ftamodel = new FtaModel($paramIdFta);
     $SiteDeProduction = $ftamodel->getDataField(FtaModel::FIELDNAME_SITE_PRODUCTION)->getFieldValue();
     $CodeArticleLdc = $ftamodel->getDataField(FtaModel::FIELDNAME_CODE_ARTICLE_LDC)->getFieldValue();
     $Libelle = $ftamodel->getDataField(FtaModel::FIELDNAME_LIBELLE)->getFieldValue();
     $UniteFacturation = $ftamodel->getDataField(FtaModel::FIELDNAME_UNITE_FACTURATION)->getFieldValue();
     $globalConfig = new GlobalConfig();
     $idUser = $globalConfig->getAuthenticatedUser()->getKeyValue();
     $url = $globalConfig->getConf()->getUrlFullRoot();
     $userModel = new UserModel($idUser);
     $nom = $userModel->getDataField(UserModel::FIELDNAME_NOM)->getFieldValue();
     $prenom = $userModel->getDataField(UserModel::FIELDNAME_PRENOM)->getFieldValue();
     $mail = $userModel->getDataField(UserModel::FIELDNAME_MAIL)->getFieldValue();
     /*
      * Récupération du nom du site d'assemblage
      */
     $arrayGeoSite = DatabaseOperation::convertSqlStatementWithoutKeyToArray("SELECT " . GeoModel::FIELDNAME_LIBELLE_SITE_AGIS . " FROM " . GeoModel::TABLENAME . " WHERE " . GeoModel::KEYNAME . " = " . $SiteDeProduction);
     foreach ($arrayGeoSite as $rowsGeoSite) {
         $libelleSiteAgis = $rowsGeoSite[GeoModel::FIELDNAME_LIBELLE_SITE_AGIS];
     }
     /*
      * Récupération de la liste des produits (nomenclatures)
      */
     $req = "SELECT " . FtaComposantModel::FIELDNAME_CODE_PRODUIT_AGROLOGIC_FTA_NOMENCLATURE . "," . AnnexeAgrologicArticleCodificationModel::FIELDNAME_PREFIXE_ANNEXE_AGRO_ART_COD . " FROM " . FtaComposantModel::TABLENAME . ", " . AnnexeAgrologicArticleCodificationModel::TABLENAME . " WHERE " . FtaComposantModel::TABLENAME . "." . FtaComposantModel::FIELDNAME_ID_FTA . "=" . $paramIdFta . " AND " . FtaComposantModel::FIELDNAME_IS_COMPOSITION_FTA_COMPOSANT . "=1 " . " AND " . FtaComposantModel::TABLENAME . "." . FtaComposantModel::FIELDNAME_ID_ANNEXE_AGRO_ART_CODIFICATION . "=" . AnnexeAgrologicArticleCodificationModel::TABLENAME . "." . AnnexeAgrologicArticleCodificationModel::KEYNAME . " ORDER BY " . AnnexeAgrologicArticleCodificationModel::FIELDNAME_PREFIXE_ANNEXE_AGRO_ART_COD . " ASC, " . FtaComposantModel::FIELDNAME_DESIGNATION_CODIFICATION . "";
     $logTransition = "\n\n" . $req;
     $arrayProd = DatabaseOperation::convertSqlStatementWithoutKeyToArray($req);
     if ($arrayProd) {
         $text_prod = "";
         foreach ($arrayProd as $rowsProd) {
             /*
              * Chargement du code de codification
              */
             $text_prod .= $rowsProd[AnnexeAgrologicArticleCodificationModel::FIELDNAME_PREFIXE_ANNEXE_AGRO_ART_COD] . $rowsProd[FtaComposantModel::FIELDNAME_CODE_PRODUIT_AGROLOGIC_FTA_NOMENCLATURE] . ", ";
         }
     }
     //Fin de la récupération de la liste des produits
     /**
      * Contenu du message d'information conernant la validation de la FTA
      */
     $sujetmail = "FTA/Validée: \"" . $CodeArticleLdc . " - " . $Libelle . "\"";
     $text = "La Fiche Technique Article \"" . $CodeArticleLdc . " - " . $Libelle . "\" " . "vient d'être validée.\n" . "Cet Article est maintenant actif et disponible dans l'ensemble de notre système informatique.\n" . "\n" . "Lien de la Fta sur l'intranet " . "<a href='" . $url . "/fta/modification_fiche.php?" . FtaModel::KEYNAME . "=" . $paramIdFta . "&synthese_action=all&comeback=0&" . FtaEtatModel::KEYNAME . "=3&" . FtaEtatModel::FIELDNAME_ABREVIATION . "=V&" . FtaRoleModel::KEYNAME . "=0' >" . $ftamodel->getDataField(FtaModel::FIELDNAME_CODE_ARTICLE_LDC)->getFieldValue() . " " . $ftamodel->getDataField(FtaModel::FIELDNAME_LIBELLE)->getFieldValue() . " </a>" . "\n" . "INFORMATIONS PRINCIPALES:\n" . $ftamodel->getDataField(FtaModel::FIELDNAME_SITE_PRODUCTION)->getFieldLabel() . ": " . $libelleSiteAgis . "\n" . "\n" . "Listes des produits créés:\n" . $text_prod . "\n" . "\n" . "INFORMATIONS SUPPLEMENTAIRES:\n" . $ftamodel->getDataField(FtaModel::FIELDNAME_CODE_ARTICLE_LDC)->getFieldLabel() . ": " . $ftamodel->getDataField(FtaModel::FIELDNAME_CODE_ARTICLE_LDC)->getFieldValue() . "\n" . $ftamodel->getDataField(FtaModel::FIELDNAME_EAN_UVC)->getFieldLabel() . ": " . $ftamodel->getDataField(FtaModel::FIELDNAME_EAN_UVC)->getFieldValue() . "\n" . $ftamodel->getDataField(FtaModel::FIELDNAME_EAN_COLIS)->getFieldLabel() . ": " . $ftamodel->getDataField(FtaModel::FIELDNAME_EAN_COLIS)->getFieldValue() . "\n" . $ftamodel->getDataField(FtaModel::FIELDNAME_NOMBRE_UVC_PAR_CARTON)->getFieldLabel() . ": " . $ftamodel->getDataField(FtaModel::FIELDNAME_NOMBRE_UVC_PAR_CARTON)->getFieldValue() . "\n" . $ftamodel->getDataField(FtaModel::FIELDNAME_POIDS_ELEMENTAIRE)->getFieldLabel() . ": " . $ftamodel->getDataField(FtaModel::FIELDNAME_POIDS_ELEMENTAIRE)->getFieldValue() . "\n" . "Identifiant du Dossier Technique: " . $ftamodel->getDataField(FtaModel::FIELDNAME_DOSSIER_FTA)->getFieldValue() . "-v" . $ftamodel->getDataField(FtaModel::FIELDNAME_VERSION_DOSSIER_FTA)->getFieldValue() . "\n";
     switch ($UniteFacturation) {
         case 2:
             //Pièce
             $temp = "Pièce";
             break;
         case 3:
             //Kilo
             $temp = "Kilo";
             break;
     }
     $text .= $ftamodel->getDataField(FtaModel::FIELDNAME_UNITE_FACTURATION)->getFieldLabel() . ": " . $temp . "\n" . $ftamodel->getDataField(FtaModel::FIELDNAME_DUREE_DE_VIE)->getFieldLabel() . ": " . $ftamodel->getDataField(FtaModel::FIELDNAME_DUREE_DE_VIE)->getFieldValue() . "\n" . $ftamodel->getDataField(FtaModel::FIELDNAME_DUREE_DE_VIE_TECHNIQUE_PRODUCTION)->getFieldLabel() . ": " . $ftamodel->getDataField(FtaModel::FIELDNAME_DUREE_DE_VIE_TECHNIQUE_PRODUCTION)->getFieldValue() . "\n" . $ftamodel->getDataField(FtaModel::FIELDNAME_DESIGNATION_COMMERCIALE)->getFieldLabel() . ": " . $ftamodel->getDataField(FtaModel::FIELDNAME_DESIGNATION_COMMERCIALE)->getFieldValue() . "\n" . "\n" . "\n";
     if ($paramCommentaire) {
         $text .= "COMMENTAIRE:\n" . stripslashes($paramCommentaire) . "\n" . "\n";
     }
     $text .= "Bonne journée à tous.\n" . "Ce message a été envoyé automatiquement par le module Intranet - Fiche Technique Article.\n";
     $typeMail = "Validation";
     /*
      * Envoi du mail d'information
      */
     foreach ($paramListeDiffusion as $mail_validation) {
         if (!is_string($mail_validation)) {
             $destinataire = $mail_validation[UserModel::FIELDNAME_MAIL];
             $liste_destinataire .= $mail_validation["prenom_nom"] . ": " . $destinataire . "\n";
             $expediteur = $prenom . " " . $nom . " <" . $mail . ">";
             envoismail($sujetmail, $text, $destinataire, $expediteur, $typeMail);
         }
     }
     /*
      * Envoi du mail de contrôle
      */
     $sujetmail = "FTA/Information \"" . $CodeArticleLdc . " - " . $Libelle . "\"";
     $corp = "DESTINATAIRES:\n" . $liste_destinataire . "\n" . "\n" . "Message envoyé:\n" . "\n" . $text . "\n" . "INFORMATIONS DE DEBUGGAGE:\n" . $logTransition;
     $expediteur = $prenom . " " . $nom . " <" . $mail . ">";
     envoismail($sujetmail, $corp, $mail, $expediteur, $typeMail);
 }