get_submitted_get_value('filtre'); if (! empty($filtreContexte)) { $filtre = $filtreContexte; } // $params = array( "filtre" => $filtre, "contexte" => $contexte, "dossier_cloture" => isset($_GET['dossier_cloture']) ? $_GET['dossier_cloture'] : "", ); /** * Récupération de la configuration de la requête à partir du widget. */ // require_once "../obj/om_widget.class.php"; include "../sql/pgsql/app_om_tab_common_select.inc.php"; $om_widget = new om_widget(0); // $conf = $om_widget->get_config_messages_retours($params); /** * */ // $tab_description = $conf["message_help"]; // $tab_title = __("message"); // $displayed_fields_begin = array( 'dossier_message.dossier_message as "'.__("dossier_message").'"', $select__dossier_libelle__column_as, 'dossier_message.type as "'.__("type").'"', 'dossier_message.emetteur as "'.__("emetteur").'"', 'dossier_message.destinataire as "'.__("destinataire").'"', 'to_char(dossier_message.date_emission ,\'DD/MM/YYYY\') as "'.__("date_emission").'"', 'to_char(dossier_message.date_emission ,\'HH24:MI:SS\') as "'.__("heure_emission").'"', ); $displayed_field_instructeur = array( 'instructeur.nom as "'.__("instructeur").'"', 'instructeur_secondaire.nom as "'.__("instructeur secondaire").'"' ); // Dans le contexte contentieux, affiche les deux instructeurs if ($contexte === 'contentieux') { // $displayed_field_instructeur = array( 'CONCAT_WS(\' / \', instructeur.nom, instructeur_secondaire.nom) as "'.__("juriste / technicien").'"', ); } $displayed_field_division = array( 'division.code as "'.__("division").'"', ); $displayed_field_collectivite = array( 'om_collectivite.libelle as "'.__("collectivite").'"', ); $displayed_fields_end = array($select_enjeux_dossier); // FILTRE $sqlFilter = $om_widget->get_query_filter( $conf["query_ct_from"].' WHERE '.$conf["query_ct_where_common"], $filtre ); // Pour les messages en plus du filtre ont souhaite récupérer tous les messages // à destination de la commune pour les collectivité mono if ($conf['arguments']['filtre'] != 'aucun') { if ($this->isCollectiviteMono($_SESSION['collectivite']) === true) { // Modifie la condition du filtre pour récupérer les messages voulus (filtre // instructeur, instructeur_secondaire ou division) ainsi que les messages de // à destination de la commune. // Le filtre récupéré a un 'AND' devant la condition pour éviter une erreur de // base de donnée on le supprime pour ne récupérer que la condition et pouvoir // l'associer à la condition sur le destinataire $sqlFilter['WHERE'] = sprintf( ' AND (%s %s dossier_message.destinataire = \'commune\')', str_replace(' AND ', '', $sqlFilter['WHERE']), ! empty($sqlFilter['WHERE']) ? 'OR' : '' ); } else { // Modifie la condition du filtre pour récupérer les messages voulus (filtre // instructeur, instructeur_secondaire ou division) qui sont à destination de // l'instructeur $sqlFilter['WHERE'] = sprintf( ' %s AND dossier_message.destinataire = \'instructeur\'', $sqlFilter['WHERE'] ); } } // FROM $table = sprintf( '%s %s', $conf["query_ct_from"], $sqlFilter['FROM'] ); // WHERE $selection = sprintf( "WHERE %s %s", $conf["query_ct_where_common"], $sqlFilter['WHERE'] ); // $tri = " ORDER BY $order_by_enjeux_priorite_dossier, dossier_message.date_emission ASC "; $options[] = array( 'type' => 'pagination_group_by', 'pagination_group_by' => false ); // if ($contexte === 'contentieux') { // $tri = " ORDER BY dossier_message.date_emission ASC "; } // $tab_actions['corner']['ajouter'] = null; /** * Options - ADVSEARCH */ // $advsearch_fields_begin = array( // 'dossier' => array( 'table' => 'dossier_message', 'colonne' => 'dossier', 'type' => 'text', 'libelle' => __('Dossier'), 'taille' => '', 'max' => '', ), // 'type' => array( 'table' => 'dossier_message', 'colonne' => 'type', 'type' => 'select', 'libelle' => __('Type message'), 'subtype' => 'sqlselect', 'sql' => 'SELECT DISTINCT(dossier_message.type), dossier_message.type FROM '.DB_PREFIXE.'dossier_message WHERE dossier_message.lu IS FALSE ORDER BY dossier_message.type ASC', ), // 'emetteur' => array( 'colonne' => 'emetteur', 'table' => 'dossier_message', 'libelle' => __('Emetteur'), 'type' => 'text', 'taille' => '', 'max' => '', ), // 'date_emission' => array( 'colonne' => 'date_emission', 'table' => 'dossier_message', 'libelle' => __('Date d\'emission'), 'type' => 'date', 'where' => 'intervaldate', 'taille' => '', ), ); // $advsearch_field_instructeur = array( // 'instructeur' => array( 'colonne' => 'nom', 'table' => 'instructeur', 'libelle' => __('Juriste/Technicien'), 'type' => 'text', 'taille' => '', 'max' => '', ), 'instructeur_2' => array( 'table' => 'dossier', 'colonne' => 'instructeur_2', 'type' => 'select', 'libelle' => __('Instructeur secondaire'), 'subtype' => 'sqlselect', 'sql' => "SELECT instructeur.instructeur, instructeur.nom FROM ".DB_PREFIXE."instructeur INNER JOIN ".DB_PREFIXE."instructeur_qualite ON instructeur_qualite.instructeur_qualite=instructeur.instructeur_qualite WHERE ((instructeur.om_validite_debut IS NULL AND (instructeur.om_validite_fin IS NULL OR instructeur.om_validite_fin > CURRENT_DATE)) OR (instructeur.om_validite_debut <= CURRENT_DATE AND (instructeur.om_validite_fin IS NULL OR instructeur.om_validite_fin > CURRENT_DATE))) AND LOWER(instructeur_qualite.code) = LOWER('instr') ORDER BY nom", ), ); // Dans le contexte contentieux, affiche les deux instructeurs if ($contexte === 'contentieux') { // $advsearch_field_instructeur = array( 'instructeur' => array( 'table' => 'dossier', 'colonne' => 'instructeur', 'type' => 'select', 'libelle' => __('Juriste'), 'subtype' => 'sqlselect', 'sql' => "SELECT instructeur.instructeur, instructeur.nom FROM ".DB_PREFIXE."instructeur INNER JOIN ".DB_PREFIXE."instructeur_qualite ON instructeur_qualite.instructeur_qualite=instructeur.instructeur_qualite WHERE ((instructeur.om_validite_debut IS NULL AND (instructeur.om_validite_fin IS NULL OR instructeur.om_validite_fin > CURRENT_DATE)) OR (instructeur.om_validite_debut <= CURRENT_DATE AND (instructeur.om_validite_fin IS NULL OR instructeur.om_validite_fin > CURRENT_DATE))) AND LOWER(instructeur_qualite.code) = LOWER('juri') ORDER BY nom", ), // 'instructeur_2' => array( 'table' => 'dossier', 'colonne' => 'instructeur_2', 'type' => 'select', 'libelle' => __('Technicien'), 'subtype' => 'sqlselect', 'sql' => "SELECT instructeur.instructeur, instructeur.nom FROM ".DB_PREFIXE."instructeur INNER JOIN ".DB_PREFIXE."instructeur_qualite ON instructeur_qualite.instructeur_qualite=instructeur.instructeur_qualite WHERE ((instructeur.om_validite_debut IS NULL AND (instructeur.om_validite_fin IS NULL OR instructeur.om_validite_fin > CURRENT_DATE)) OR (instructeur.om_validite_debut <= CURRENT_DATE AND (instructeur.om_validite_fin IS NULL OR instructeur.om_validite_fin > CURRENT_DATE))) AND LOWER(instructeur_qualite.code) = LOWER('tech') ORDER BY nom", ), ); } // $advsearch_field_division = array( // 'division' => array( 'colonne' => 'code', 'table' => 'division', 'libelle' => __('Division'), 'type' => 'text', 'taille' => '', 'max' => '', ), ); // $advsearch_field_collectivite = array( // 'collectivite' => array( 'table' => 'om_collectivite', 'colonne' => 'libelle', 'type' => 'text', 'libelle' => __('om_collectivite'), 'taille' => '', 'max' => '', ), ); // $advsearch_fields_end = array( 'enjeu' => array( 'tablejoin' => sprintf( 'INNER JOIN ( SELECT lien_dossier_enjeux.dossier, string_agg(enjeux.libelle, \', \') AS enjeux_libelles FROM %1$slien_dossier_enjeux LEFT JOIN %1$senjeux ON lien_dossier_enjeux.enjeux = enjeux.enjeux GROUP BY lien_dossier_enjeux.dossier) AS enjeux_libelles ON enjeux_libelles.dossier = dossier.dossier AND TRANSLATE( LOWER(enjeux_libelles.enjeux_libelles::varchar), \'àáâãäçèéêëìíîïñòóôõöùúûüýÿ\', \'aaaaaceeeeiiiinooooouuuuyy\' ) LIKE %%s', DB_PREFIXE ), 'type' => 'text', 'libelle' => __('Enjeu'), 'taille' => '', 'max' => '', 'help' => __("Recherche parmis la liste d'enjeux associés au dossier. Vous devez utiliser les '*' au début du terme que vous recherchez. Exemple, pour chercher tous les dossier ayant un enjeu 'test' vous devez saisir '*test'.") ), ); ?>