';
    private $previous_markup    = '';
    private $next_markup        = '';
    private $last_markup        = '';
    private $rewrite_transition;
    private $rewrite_extension;
    /**
     * Build pagination
     * @param string  $sql         Elément commun de requête : "FROM..." auquel sera ajouté le "LIMIT..."
     * @param string  $mpp         Nombre max de lignes par page
     * @param string  $querystring Elément de querystring indiquant le n° de page
     * @param string  $url         URL de la page
     * @param integer $long        Nombre max de pages avant et après la page courante
     */
    public function pagine($sql, $mpp, $querystring, $url, $long = 5, $rewrite_links = true, $rewrite_transition = '-', $rewrite_extension = '.html', $debug = false)
    {
    // Pour construire les liens, regarde si $url contient déjà un ?
        $t   = $this->rewrite_transition = $rewrite_transition;
        $ext = $this->rewrite_extension = $rewrite_extension;
        $url = $this->removePreviousQuerystring($url, $querystring, $rewrite_links);
        if ($rewrite_links !== true) {
            if (strpos($url, "?")) {
                $t = '&';
            } else {
                $t = '?';
            }
        }
        $rs_pagination = parent::query($sql);
        if ($debug === true) {
            echo parent::getLastSQL();
        }
        $nbre = parent::rowCount($rs_pagination);  // Nombre total d'enregistrements retournés
        if (!empty($nbre)) {
            $_SESSION['result_rs'] = $nbre;    // Calcul du nombre de pages
            $nbpage = ceil($nbre/$mpp);    // La page courante est
            $p = @$_GET[$querystring];
            if (!$p) {
                $p = 1;
            }
            if ($p>$nbpage) {
                $p = $nbpage;    // Longueur de la liste de pages
            }
            $deb = max(1, $p-$long);
            $fin = min($nbpage, $p+$long);    // Construction de la liste de pages
            $this->pagine = "";
            if ($nbpage > 1) {
                for ($i = $deb; $i <= $fin; $i++) { // Page courante ?
                    if ($i == $p) {
                        $this->pagine .= '
' . $i . '' . "\n";    // Page 1 > lien sans query
                    } elseif ($i == 1) {
                        if ($rewrite_links === true) {
                            $this->pagine .= '' . $i . '' . "\n";   // Autre page -> lien avec query
                        } else {
                            $this->pagine .= '' . $i . '' . "\n";   // Autre page -> lien avec query
                        }
                    } else {
                        if ($rewrite_links === true) {
                            $this->pagine .= '' . $i . '' . "\n";
                        } else {
                            $this->pagine .= '' . $i . '' . "\n";
                        }
                    }
                }
                if ($this->pagine) {
                    $this->pagine = 'Page' . $this->pagine . "\n";
                }
                if ($this->pagine && ($p > 1)) { //PREVIOUS
                    if ($p == 2) {
                        if ($rewrite_links === true) {
                            $this->pagine = '' . $this->previous_markup . '' . $this->pagine . "\n";
                        } else {
                            $this->pagine = '' . $this->previous_markup . '' . $this->pagine . "\n";
                        }
                    } else { //PREVIOUS
                        if ($rewrite_links === true) {
                            $this->pagine = '' . $this->previous_markup . '' . $this->pagine . "\n";
                        } else {
                            $this->pagine = '' . $this->previous_markup . '' . $this->pagine . "\n";
                        }
                    }
                    if ($p>1) { // FIRST
                        if ($rewrite_links === true) {
                            $this->pagine = '' . $this->first_markup . '' . $this->pagine . "\n";
                        } else {
                            $this->pagine = '' . $this->first_markup . '' . $this->pagine . "\n";
                        }
                    }
                }
                if ($this->pagine && ($p<$nbpage)) { // NEXT, LAST
                    if ($rewrite_links === true) {
                        $this->pagine .= '' . $this->next_markup . '' . "\n"; //SUIVANT
                    } else {
                        $this->pagine .= '' . $this->next_markup . '' . "\n";
                    }
                    if ($p<$nbpage) { // LAST
                        if ($rewrite_links === true) {
                            $this->pagine .= '' . $this->last_markup . '' . "\n";
                        } else {
                            $this->pagine .= '' . $this->last_markup . '' . "\n";
                        }
                    }
                }    // Modification de la requête
                $suppr = 'LIMIT';
                $cherche = strstr($sql, $suppr);
                $sql = str_replace($cherche, "", $sql);    // si vide on supprime la clause "LIMIT"
                $sql .= ' LIMIT ' . (($p-1) *$mpp)  . ',' . $mpp;
                $rs_pagination = parent::query($sql);    // nouveau jeu d'enregistrements avec la clause LIMIT
                $nbrePageActu = parent::rowCount($rs_pagination);    // affichage 'résultats n à m sur x    // départ = $depart    //fin = $fin    // total = $nbre
                $depart = $mpp*($p-1) +1;    // nbre par page x page actuelle.
                $fin = $depart+$nbrePageActu-1;
            } else {    //s'il n'y a qu'une seule page
                $this->pagine = '' . "\n";
                $depart = 1;    // nbre par page x page actuelle.
                $fin = $nbre;
            }
            // CRUD admin i18n
            if (defined('PAGINATION_RESULTS')) {
                $this->resultats = '' . PAGINATION_RESULTS . ' ' . $depart . ' ' . PAGINATION_TO . ' ' . $fin . ' ' . PAGINATION_OF . ' ' . $nbre . '
' . "\n";
            } else {
                $this->resultats = 'résultats ' . $depart . ' à ' . $fin . ' sur ' . $nbre . '
' . "\n";
            }
            $htmlPagination = '';
            if (!empty($this->resultats)) {
                $htmlPagination .= '' . "\n";
            }
            $htmlPagination .= '' . "\n";
            $htmlPagination .= $this->resultats;
            $htmlPagination .= '
' . "\n";
            return $htmlPagination;
        }
    }
    /**
     * Sets form layout options to match your framework
     *
     * @param array $user_options (Optional) An associative array containing the
     *                            options names as keys and values as data.
     * @return $this
     */
    public function setOptions($user_options = array())
    {
        $options = array('active_class', 'disabled_class', 'first_markup', 'pagination_class', 'previous_markup', 'next_markup', 'last_markup', 'rewrite_transition', 'rewrite_extension');
        foreach ($user_options as $key => $value) {
            if (in_array($key, $options)) {
                $this->$key = $value;
            }
        }
    }
    private function removePreviousQuerystring($url, $querystring, $rewrite_links)
    {
        if ($rewrite_links === true) {
            $find = array('`' . $this->rewrite_transition . $querystring . '[0-9]+`', '`' . $this->rewrite_extension . '`');
            $replace = array('', '');
        } else {
            $find = array('`\?' . $querystring . '=([0-9]+)&(amp;)?`', '`\?' . $querystring . '=([0-9]+)`', '`&(amp;)?' . $querystring . '=([0-9]+)`');
            $replace = array('?', '', '');
        }
        $url = preg_replace($find, $replace, $url);
        return $url;
    }
}