From c3ecc1f9cd466203b05194321f2b5c26410170b9 Mon Sep 17 00:00:00 2001 From: catch <catch@35733.no-reply.drupal.org> Date: Sun, 20 Nov 2011 22:40:42 +0900 Subject: [PATCH] Rollback of #589440 which needs more discussion. --- core/modules/book/book.admin.inc | 11 ++++++----- core/modules/book/book.module | 6 ++---- 2 files changed, 8 insertions(+), 9 deletions(-) diff --git a/core/modules/book/book.admin.inc b/core/modules/book/book.admin.inc index 08ec5ec81fd0..7b9dea390f5b 100644 --- a/core/modules/book/book.admin.inc +++ b/core/modules/book/book.admin.inc @@ -174,6 +174,10 @@ function _book_admin_table($node, &$form) { * @see book_admin_edit() */ function _book_admin_table_tree($tree, &$form) { + // The delta must be big enough to give each node a distinct value. + $count = count($tree); + $delta = ($count < 30) ? 15 : intval($count / 2) + 1; + foreach ($tree as $data) { $form['book-admin-' . $data['link']['nid']] = array( '#item' => $data['link'], @@ -187,12 +191,9 @@ function _book_admin_table_tree($tree, &$form) { '#size' => 40, ), 'weight' => array( - // Using a textfield and a validator instead of a simple weight select - // to avoid unnecessarily oversized HTML for books with hundreds of - // pages. - '#type' => 'textfield', - '#element_validate' => array('element_validate_integer'), + '#type' => 'weight', '#default_value' => $data['link']['weight'], + '#delta' => max($delta, abs($data['link']['weight'])), '#title' => t('Weight for @title', array('@title' => $data['link']['title'])), '#title_display' => 'invisible', ), diff --git a/core/modules/book/book.module b/core/modules/book/book.module index ce3c9e415803..10809843a850 100644 --- a/core/modules/book/book.module +++ b/core/modules/book/book.module @@ -515,12 +515,10 @@ function _book_add_form_elements(&$form, &$form_state, $node) { // @see _book_admin_table_tree(). The weight may be larger than 15. $form['book']['weight'] = array( - // Using a textfield and a validator instead of a simple weight select to - // avoid unnecessarily oversized HTML for books with hundreds of pages. - '#type' => 'textfield', - '#element_validate' => array('element_validate_integer'), + '#type' => 'weight', '#title' => t('Weight'), '#default_value' => $node->book['weight'], + '#delta' => max(15, abs($node->book['weight'])), '#weight' => 5, '#description' => t('Pages at a given level are ordered first by weight and then by title.'), ); -- GitLab