web-dev-qa-db-fra.com

Comment créer des tableaux triables avec un pager avec les données d'une table personnalisée?

Pour Drupal 6, vous pouvez faire quelque chose comme ceci:

$header = array(
  array('data' => t('Order id'), 'field' => 'order_id'),
  ...
  array('data' => t('Transaction time'), 'field' => 'payment_time', 'sort' => 'desc'),
);
$sql = "...";
$sql .= tablesort_sql($header);
$limit = 25;
$result = pager_query($sql, $limit);
...

J'ai jeté un oeil et pour drupal 7 et les deux pager_query et tablesort_sql est maintenant parti. Il semble qu'au lieu de cela, la classe PagerDefault puisse être utilisée pour créer une requête de pageur à l'aide de DBTNG. Je n'ai pas pu trouver d'indices sur une API simple pour attacher une table triable à la requête comme cela se fait dans Drupal 6.

Alors, comment créez-vous une table triable avec un pager tirant des données d'une table personnalisée?

20
googletorp

Vous utilisez les extensions dites. Dans votre cas, le code serait similaire au suivant.

$header = array(
  array('data' => t('Order id'), 'field' => 'order_id'),
  // ...
  array('data' => t('Transaction time'), 'field' => 'payment_time', 'sort' => 'desc'),
);

// Initialize $query with db_select().
$query = db_select('your table name');

// Add the fields you need to query.
// ... 

// Add the table sort extender.
$query = $query->extend('TableSort')->orderByHeader($header);

// Add the pager.
$query = $query->extend('PagerDefault')->limit(25);
$result = $query->execute();

Voir HowTo: convertir un module en DBTNG , requêtes dynamiques: tri de table et extensions .

8
Berdir

Utilisez les extensions TableSort et PagerDefault.

$query = db_select('node', 'n');
$query->fields('n', array('nid', 'title', 'status'));

$table_sort = $query->extend('TableSort') // Add table sort extender.
  ->orderByHeader($header); // Add order by headers.

$pager = $table_sort->extend('PagerDefault')
  ->limit(5); // 5 rows per page.

$result = $pager->execute();
6
Serjas

Utilisez le module DataTables .

Le module DataTables intègre le plugin jQuery DataTables dans Drupal comme style de vues et fonction de thème appelable. DataTables vous permet d'ajouter des fonctionnalités dynamiques aux tableaux, notamment:

  • Pagination de longueur variable
  • Filtrage à la volée
  • Tri avec détection de type de données
  • Gestion intelligente des largeurs de colonne
  • Themeable par CSS
  • Et plus à venir ...
2
Satya

Vous pouvez simplement inclure le même Drupal 6 tablesort_sql dans votre code et cela fonctionne très bien.

Pour pager:

$count = <Total No. of Table rows>

$sql = "...";
$sql .= tablesort_sql($header);
$limit = 25; //Pager limit

$results = db_query( $sql );
$rows = array();
//Loop through the result.
while ( $row = $results->fetchAssoc() ) {
$rows = <Get your array values for Table row>
}
$current_page = pager_default_initialize($count, $limit);
$chunks = array_chunk($rows,$limit, TRUE);
$output = theme( 'table', array( 'header' => $headers, 'rows' => $chunks[$current_page] ) );
$output .= theme( 'pager', array('quantity',$count ) );
print $output;
0
Paulraj