Pagination with textbox

Pagination with textbox

mungletmunglet Posts: 14Questions: 0Answers: 0
edited August 2009 in General
I know that the pagination control can be customized but I was wondering if anyone else has already added a textbox control to the "full_numbers" pagination control? That way you can jump to a specific page number, instead of having to hit, next, next, next,....

Thanks.

Replies

  • fliesflies Posts: 35Questions: 0Answers: 0
    Yeap it was done. => http://datatables.net/examples/example_alt_pagination.html

    except you have buttons (for pages) instead of text, but you can easily change it in code...
  • allanallan Posts: 63,761Questions: 1Answers: 10,510 Site admin
    edited August 2009
    Hi munglet,

    Good idea! I've been thinking about a few extra paging plug-ins to put up on the site while working on the updated required for 1.5, and this sounds like quite a nice addition. A quick little hack of my standard paging results in this, which will hopefully do what you are looking for:
  • allanallan Posts: 63,761Questions: 1Answers: 10,510 Site admin
    [code]
    $.fn.dataTableExt.oPagination.input = {
    /*
    * Function: oPagination.input.fnInit
    * Purpose: Initalise dom elements required for pagination with input textbox
    * Returns: -
    * Inputs: object:oSettings - dataTables settings object
    * function:fnCallbackDraw - draw function which must be called on update
    */
    "fnInit": function ( oSettings, fnCallbackDraw )
    {
    var nPaging = oSettings.anFeatures.p;
    var nFirst = document.createElement( 'span' );
    var nPrevious = document.createElement( 'span' );
    var nNext = document.createElement( 'span' );
    var nLast = document.createElement( 'span' );
    var nInput = document.createElement( 'input' );
    var nPage = document.createElement( 'span' );
    var nOf = document.createElement( 'span' );

    nFirst.innerHTML = oSettings.oLanguage.oPaginate.sFirst;
    nPrevious.innerHTML = oSettings.oLanguage.oPaginate.sPrevious;
    nNext.innerHTML = oSettings.oLanguage.oPaginate.sNext;
    nLast.innerHTML = oSettings.oLanguage.oPaginate.sLast;

    nFirst.className = "paginate_button first";
    nPrevious.className = "paginate_button previous";
    nNext.className="paginate_button next";
    nLast.className = "paginate_button last";
    nOf.className = "paginate_of";
    nPage.className = "paginate_page";

    if ( oSettings.sTableId !== '' )
    {
    nPaging.setAttribute( 'id', oSettings.sTableId+'_paginate' );
    nPrevious.setAttribute( 'id', oSettings.sTableId+'_previous' );
    nPrevious.setAttribute( 'id', oSettings.sTableId+'_previous' );
    nNext.setAttribute( 'id', oSettings.sTableId+'_next' );
    nLast.setAttribute( 'id', oSettings.sTableId+'_last' );
    }

    nInput.type = "text";
    nInput.style.width = "15px";
    nInput.style.display = "inline";
    nPage.innerHTML = "Page ";

    nPaging.appendChild( nFirst );
    nPaging.appendChild( nPrevious );
    nPaging.appendChild( nPage );
    nPaging.appendChild( nInput );
    nPaging.appendChild( nOf );
    nPaging.appendChild( nNext );
    nPaging.appendChild( nLast );

    $(nFirst).click( function () {
    oSettings._iDisplayStart = 0;
    fnCallbackDraw( oSettings );
    } );

    $(nPrevious).click( function() {
    oSettings._iDisplayStart -= oSettings._iDisplayLength;

    /* Correct for underrun */
    if ( oSettings._iDisplayStart < 0 )
    {
    oSettings._iDisplayStart = 0;
    }

    fnCallbackDraw( oSettings );
    } );

    $(nNext).click( function() {
    /* Make sure we are not over running the display array */
    if ( oSettings._iDisplayStart + oSettings._iDisplayLength < oSettings.fnRecordsDisplay() )
    {
    oSettings._iDisplayStart += oSettings._iDisplayLength;
    }

    fnCallbackDraw( oSettings );
    } );

    $(nLast).click( function() {
    var iPages = parseInt( (oSettings.fnRecordsDisplay()-1) / oSettings._iDisplayLength, 10 ) + 1;
    oSettings._iDisplayStart = (iPages-1) * oSettings._iDisplayLength;

    fnCallbackDraw( oSettings );
    } );

    $(nInput).keyup( function (e) {

    if ( e.which == 38 || e.which == 39 )
    {
    this.value++;
    }
    else if ( (e.which == 37 || e.which == 40) && this.value > 1 )
    {
    this.value--;
    }

    if ( this.value == "" || this.value.match(/[^0-9]/) )
    {
    /* Nothing entered or non-numeric character */
    return;
    }

    var iNewStart = oSettings._iDisplayLength * (this.value - 1);
    if ( iNewStart > oSettings.fnRecordsDisplay() )
    {
    /* Display overrun */
    oSettings._iDisplayStart = (Math.ceil((oSettings.fnRecordsDisplay()-1) /
    oSettings._iDisplayLength)-1) * oSettings._iDisplayLength;
    fnCallbackDraw( oSettings );
    return;
    }

    oSettings._iDisplayStart = iNewStart;
    fnCallbackDraw( oSettings );
    } );

    /* Take the brutal approach to cancelling text selection */
    $('span', nPaging).bind( 'mousedown', function () { return false; } );
    $('span', nPaging).bind( 'selectstart', function () { return false; } );

    oSettings.nPagingOf = nOf;
    oSettings.nPagingInput = nInput;
    },

    /*
    * Function: oPagination.input.fnUpdate
    * Purpose: Update the input element
    * Returns: -
    * Inputs: object:oSettings - dataTables settings object
    * function:fnCallbackDraw - draw function which must be called on update
    */
    "fnUpdate": function ( oSettings, fnCallbackDraw )
    {
    if ( !oSettings.anFeatures.p )
    {
    return;
    }

    var iPages = Math.ceil((oSettings.fnRecordsDisplay()-1) / oSettings._iDisplayLength);
    var iCurrentPage = Math.ceil(oSettings._iDisplayStart / oSettings._iDisplayLength) + 1;

    oSettings.nPagingOf.innerHTML = " of "+iPages
    oSettings.nPagingInput.value = iCurrentPage;
    }
    }


    $(document).ready(function() {
    $('#example').dataTable( {
    "sPaginationType": "input"
    } );
    } );
    [/code]
  • ohazarohazar Posts: 1Questions: 0Answers: 0
    edited February 2011
    Hi all,

    Here is my simple contrib to override the full_number pagination style with a page input : (simply did some copy/pastes with the latest Text Input pagination plugin found there http://www.datatables.net/plug-ins/pagination)

    [code]$.fn.dataTableExt.oPagination.full_number_override = {

    "fnInit": function ( oSettings, nPaging, fnCallbackDraw )
    {
    nPaging.className = oSettings.oClasses.sPaging+"full_numbers"; // keep "full_numbers" style to keep current css

    $.fn.dataTableExt.oPagination.full_numbers.fnInit( oSettings, nPaging, fnCallbackDraw );

    // Initalise dom elements required for pagination with input textbox
    var nInput = document.createElement( 'input' );
    var nPage = document.createElement( 'span' );
    var nOf = document.createElement( 'span' );
    nOf.className = "paginate_of";
    nPage.className = "paginate_page";
    nInput.type = "text";
    nInput.style.width = "30px";
    nInput.style.display = "inline";
    nPage.innerHTML = "Page ";

    nPaging.appendChild( nPage );
    nPaging.appendChild( nInput );
    nPaging.appendChild( nOf );


    $(nInput).keyup( function (e) {

    if ( e.which == 38 || e.which == 39 )
    {
    this.value++;
    }
    else if ( (e.which == 37 || e.which == 40) && this.value > 1 )
    {
    this.value--;
    }

    if ( this.value == "" || this.value.match(/[^0-9]/) )
    {
    /* Nothing entered or non-numeric character */
    return;
    }

    var iNewStart = oSettings._iDisplayLength * (this.value - 1);
    if ( iNewStart > oSettings.fnRecordsDisplay() )
    {
    /* Display overrun */
    oSettings._iDisplayStart = (Math.ceil((oSettings.fnRecordsDisplay()-1) /
    oSettings._iDisplayLength)-1) * oSettings._iDisplayLength;
    fnCallbackDraw( oSettings );
    return;
    }

    oSettings._iDisplayStart = iNewStart;
    fnCallbackDraw( oSettings );
    } );

    /* Take the brutal approach to cancelling text selection */
    $('span', nPaging).bind( 'mousedown', function () { return false; } );
    $('span', nPaging).bind( 'selectstart', function () { return false; } );
    },

    "fnUpdate": function ( oSettings, fnCallbackDraw )
    {
    $.fn.dataTableExt.oPagination.full_numbers.fnUpdate( oSettings, fnCallbackDraw );

    //Update the input element
    if ( !oSettings.aanFeatures.p )
    {
    return;
    }
    var iPages = Math.ceil((oSettings.fnRecordsDisplay()) / oSettings._iDisplayLength);
    var iCurrentPage = Math.ceil(oSettings._iDisplayStart / oSettings._iDisplayLength) + 1;

    /* Loop over each instance of the pager */
    var an = oSettings.aanFeatures.p;
    for ( var i=0, iLen=an.length ; i
This discussion has been closed.