/** * * @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; }
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(); }
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
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); } ?>
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 )'); } } } }
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]; }
/** * 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; } }
<?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);
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);
/** * 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; }
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':
// 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) {
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; }
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 .= ' <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 * ********** */ }
/** * 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; }
/** * 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); }