/[openfoncier]/trunk/obj/utils.class.php
ViewVC logotype

Diff of /trunk/obj/utils.class.php

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 2605 by softime, Thu Dec 12 18:00:35 2013 UTC revision 2757 by softime, Wed Feb 19 17:46:10 2014 UTC
# Line 722  class utils extends application { Line 722  class utils extends application {
722          }          }
723          return $res;          return $res;
724      }      }
725    
726        /**
727         * Permet de copier un enregistrement
728         * @param  mixed $idx   Identifiant de l'enregistrment
729         * @param  string $obj   Objet de l'enregistrment
730         * @param  string $objsf Objets associés
731         * @return array        Tableau des nouveaux id et du message
732         */
733        function copier($idx, $obj, $objsf) {
734    
735            // Tableau de résultat
736            $resArray = array();
737            // Message retourné à l'utilisateur
738            $message = "";
739            // Type du message (valid ou error)
740            $message_type = "valid";
741    
742            // Requête SQL permettant de récupérer les informations sur l'objet métier
743            $sql = "SELECT *
744                    FROM ".DB_PREFIXE.$obj."
745                    WHERE ".$obj." = ".$idx;
746            $res = $this->db->query($sql);
747            $this->isDatabaseError($res);
748    
749            // Valeurs clonées
750            $valF = array();
751            while ($row=& $res->fetchRow(DB_FETCHMODE_ASSOC)) {
752                // Recupère la valeur
753                $valF = $row;
754            }
755    
756            // Valeurs non clonées
757            // Identifiant modifié pour que ça soit un ajout
758            $valF[$obj] = "]";
759    
760            // Inclus la classe de l'objet métier
761            require_once "../obj/".$obj.".class.php";
762    
763            // Instance de l'objet métier
764            $clone_obj = new $obj("]", $this->db, DEBUG);
765            // Si dans l'objet métier la fonction "copier" existe
766            if (method_exists($clone_obj, "copier")) {
767                // Traitement sur les valeurs du duplicata
768                $valF = $clone_obj->copier($valF, $objsf, DEBUG);
769                // Recupère les messages retourné par la fonction
770                $message .= $valF['message'];
771                // Supprime les messages de la liste des valeurs
772                unset($valF['message']);
773            }
774            // Ajoute le duplicata
775            $clone_obj->ajouter($valF, $this->db, DEBUG);
776            // Si aucune erreur se produit dans la classe instanciée
777            if ($clone_obj->correct === true) {
778                // Récupère l'identifiant de l'objet créé
779                $clone_obj_id = $clone_obj->valF[$obj];
780    
781                // Message
782                $message .= sprintf(_("La copie de l'enregistrement %s avec l'identifiant %s s'est effectuee avec succes"), "<span class='bold'>"._($obj)."</span>", "<span class='bold'>".$idx."</span>")."<br />";
783    
784                // Ajout de l'identifant au tableau des résultat
785                $resArray[$obj.'_'.$idx] = $clone_obj_id;
786    
787                // S'il y a au moins un objet metier associé
788                if ($objsf != "") {
789                    // Liste des objet métier associés
790                    $list_objsf = explode(",", $objsf);
791                    // Pour chaque objet associé
792                    foreach ($list_objsf as $key => $objsf) {
793                        // Inclus la classe de l'objet métier associé
794                        require_once "../obj/".$objsf.".class.php";
795    
796                        // Requête SQL permettant de récupérer les informations sur
797                        // l'objet métier associé
798                        $sql = "SELECT *
799                                FROM ".DB_PREFIXE.$objsf."
800                                WHERE ".$obj." = ".$idx;
801                        $res = $this->db->query($sql);
802                        $this->isDatabaseError($res);                    
803    
804                        // Pour chaque élément associé
805                        while ($row=& $res->fetchRow(DB_FETCHMODE_ASSOC)) {
806                            // Identifiant de l'objet associé à copier
807                            $idxsf = $row[$objsf];
808    
809                            // Valeurs clonées
810                            $valF = $row;
811                            // Valeurs non clonées
812                            $valF[$obj] = $clone_obj_id;
813                            // Identifiant modifié pour que ça soit un ajout
814                            $valF[$objsf] = "]";
815                            // Instance de l'objet métier associé
816                            $clone_objsf = new $objsf("]", $this->db, DEBUG);
817                            // Si dans l'objet métier associé
818                            // la fonction "copier" existe
819                            if (method_exists($clone_objsf, "copier")) {
820                                // Traitement sur les valeurs du duplicata
821                                $valF = $clone_objsf->copier($valF, $objsf, DEBUG);
822                                // Recupère les messages retourné par la fonction
823                                $message .= $valF['message'];
824                                // Supprime les messages de la liste des valeurs
825                                unset($valF['message']);
826                            }
827                            // Ajoute le duplicata
828                            $clone_objsf->ajouter($valF, $this->db, DEBUG);
829                            // Si aucune erreur se produit dans la classe instanciée
830                            if ($clone_objsf->correct === true) {
831                                // Récupère l'identifiant de l'objet créé
832                                $clone_objsf_id = $clone_objsf->valF[$objsf];
833    
834                                // Message
835                                $message .= sprintf(_("La copie de l'enregistrement %s avec l'identifiant %s s'est effectuee avec succes"), "<span class='bold'>"._($objsf)."</span>", "<span class='bold'>".$idxsf."</span>")."<br />";
836    
837                                // Ajout de l'identifant au tableau des résultat
838                                $resArray[$objsf.'_'.$row[$objsf]] = $clone_objsf_id;
839                            } else {
840    
841                                // Message d'erreur récupéré depuis la classe
842                                $message .= $clone_objsf->msg;
843                                // Type du message
844                                $message_type = "error";
845                            }
846                        }
847                    }
848                }
849            //    
850            } else {
851    
852                // Message d'erreur récupéré depuis la classe
853                $message .= $clone_obj->msg;
854                // Type du message
855                $message_type = "error";
856            }
857    
858            // Ajout du message au tableau des résultats
859            $resArray['message'] = $message;
860            // Ajout du type de message au tableau des résultats
861            $resArray['message_type'] = $message_type;
862    
863            // Retourne le tableau des résultats
864            return $resArray;
865        }
866    
867        /**
868         * Permet de détailler les conditions pour l'affichage des contraintes dans
869         * une édition.
870         * @param string $contraintes_param    Chaine des conditions
871         *
872         * @return array                        Conditions
873         */
874        function explodeConditionContrainte($contraintes_param) {
875    
876            // Initialisation des variables
877            $return = array();
878            $listGroupes = "";
879            $listSousgroupes = "";
880            $service_consulte = "";
881    
882            // Coupe la condition au ";"
883            // Doit séparer groupe et sous-groupe
884            $contraintes_params = explode(";", $contraintes_param);
885            
886            // Pour chaque paramètres
887            foreach ($contraintes_params as $value) {
888                // Si le mot-clés "liste_groupe="
889                if (strstr($value, "liste_groupe=")) {
890                    // On enlève le mots-clés "liste_groupe="
891                    $listGroupes = str_replace("liste_groupe=", "", $value);
892                }
893                // Si le mot-clés "liste_ssgroupe="
894                if (strstr($value, "liste_ssgroupe=")) {
895                    // On enlève le mots-clés "liste_ssgroupe="
896                    $listSousgroupes = str_replace("liste_ssgroupe=", "", $value);
897                }
898                // Si le mot-clés "service_consulte="
899                if (strstr($value, "service_consulte=")) {
900                    // On enlève le mots-clés "service_consulte="
901                    $service_consulte = str_replace("service_consulte=", "", $value);
902                }
903            }
904    
905            // Récupère la liste des groupes et sous-groupes qui doivent
906            // être utilisés pour la condition
907            if ($listGroupes != "") {
908                $listGroupes = explode(",", $listGroupes);
909            }
910            if ($listSousgroupes != "") {
911                $listSousgroupes = explode(",", $listSousgroupes);
912            }
913    
914            // Tableau à retourner
915            $return['groupes'] = $listGroupes;
916            $return['sousgroupes'] = $listSousgroupes;
917            $return['service_consulte'] = $service_consulte;
918    
919            //
920            return $return;
921        }
922    
923        /**
924         * Traitement pour créer la condition sur les contraintes dans les éditions.
925         * @param string $part SQL et parti du pdf (sql, titre ou corps)
926         *
927         * @return string      Condition pour la requête sur les contraintes
928         */
929        function traitement_condition_contrainte($part) {
930    
931            // Initialisationd de la condition
932            $whereContraintes = "";
933    
934            // Détaille la condtion
935            $explodeConditionContrainte = $this->explodeConditionContrainte($part);
936    
937            // Récupère les groupes, sous-groupes et service_consulte pour la condition
938            $groupes = $explodeConditionContrainte['groupes'];
939            $sousgroupes = $explodeConditionContrainte['sousgroupes'];
940            $service_consulte = $explodeConditionContrainte['service_consulte'];
941    
942            // Pour chaque groupe
943            if ($groupes != "") {
944                foreach ($groupes as $key => $groupe) {
945                    // Si le groupe n'est pas vide
946                    if (!empty($groupe)) {
947                        // Choisit l'opérateur logique
948                        $op_logique = $key > 0 ? 'OR' : 'AND (';
949                        // Ajoute la condition
950                        $whereContraintes .= " ".$op_logique." contrainte.groupe = '"
951                            .$groupe."'";
952                    }
953                }
954                // S'il y a des valeurs dans groupe
955                if (count($groupe) > 0) {
956                    // Ferme la parenthèse
957                    $whereContraintes .= " ) ";
958                }
959            }
960    
961            // Pour chaque sous-groupe
962            if ($sousgroupes != "") {
963                foreach ($sousgroupes as $key => $sousgroupe) {
964                    // Si le sous-groupe n'est pas vide
965                    if (!empty($sousgroupe)) {
966                        // Choisit l'opérateur logique
967                        $op_logique = $key > 0 ? 'OR' : 'AND (';
968                        // Ajoute la condition
969                        $whereContraintes .= " ".$op_logique." contrainte.sousgroupe = '"
970                            .$sousgroupe."'";
971                    }
972                }
973                // S'il y a des valeurs dans sous-groupe
974                if (count($sousgroupes) > 0) {
975                    // Ferme la parenthèse
976                    $whereContraintes .= " ) ";
977                }
978            }
979    
980            // Si l'option service_consulte n'est pas vide
981            if ($service_consulte != "") {
982                // Ajoute la condition
983                $whereContraintes .= " AND service_consulte = '".$service_consulte."'";
984            }
985    
986            // Condition retournée
987            return $whereContraintes;
988        }
989  }  }
990    
991  ?>  ?>

Legend:
Removed from v.2605  
changed lines
  Added in v.2757

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26