FooterCallback on btn Click

FooterCallback on btn Click

chuck808chuck808 Posts: 7Questions: 2Answers: 0

Hello,

I am trying to create an attendance register for a local Club that lists attendee's, displays if Members or not, and populate Subs column with appropriate session payment and show total Subs £ for session.

I am using Bootstrap Toggle Button to trigger the events, including storing attendees to MySQL.

As you can see from the second image, it's all working fine apart from the total in the footer. I am trying to use the FotterCallback function to sum up the Subs column,

       ```$(document).ready(function(e){
            $('#tblRiders').DataTable({

                "footerCallback": function ( row, data, start, end, display ) {
                    var api = this.api(), data;

                    // Remove the formatting to get integer data for summation
                    var intVal = function ( i ) {
                        return typeof i === 'string' ?
                            i.replace(/[\$,]/g, '')*1 :
                            typeof i === 'number' ?
                                i : 0;
                    };

                    // Total over all pages
                    total = api
                        .column( 6 )
                        .data()
                        .reduce( function (a, b) {
                            return intVal(a) + intVal(b);
                        } );

                    // Total over this page
                    pageTotal = api
                        .column( 6, { page: 'current'} )
                        .data()
                        .reduce( function (a, b) {
                            return intVal(a) + intVal(b);
                        }, 0 );

                    // Update footer
                    $( api.column( 6 ).footer() ).html(
                        ('£' + total)
                    );
                },```

But this is obviously a static function that triggers on page load, which is not what I am aiming for. I have also tried

$('#example').DataTable().ajax.reload();

in the

$(document).on('change', '.toggleBtn', function(ev)

I have also tried o use the FooterCallback function inside the toggleBtn function, but I can't get it to work.

Any ideas?

Thanks in advance.

This question has accepted answers - jump to:

Answers

  • kthorngrenkthorngren Posts: 21,571Questions: 26Answers: 4,996
    Answer ✓

    static function that triggers on page load

    It runs each time the Datatable is redrawn. You can see this by looking at this example and changing pages. The page total updates.

    I have also tried $('#example').DataTable().ajax.reload();

    Are you using the ajax option? This will only work if you have configured ajax. Likely this isn't what you need to solve your problem.

    How are you updating the table information? Datatables won't know about the changes if you are updating the DOM directly. You can use row().invalidate() to have Datatables update its data cache and when the draw() occurs the footerCallback will run.

    Or you can use Datatables APIs like row().data() or cell().data() to update the table.

    Kevin

  • chuck808chuck808 Posts: 7Questions: 2Answers: 0

    Hi Kevin,

    Thanks for the reply.

    Static function wasn't the best description, but you know what I meant :smile:

    No, not using ajax, but I thought it was worth a try.

    At the moment I am updating the DOM directly -

    var $subs = 3.50;
    
    var currow = $(this).closest('tr');
    var membstat = currow.find('td:eq(5)').text();
    
    if(membstat == 'Member'){
        //currow.find('td:eq(6)').html('£' + $subs.toFixed(2));
        currow.find('td:eq(6)').html(($subs).toFixed(2));
    }else{
        $subs = 5.00
        //currow.find('td:eq(6)').html('£' + $subs.toFixed(2));
        currow.find('td:eq(6)').html(($subs).toFixed(2));
    };
    

    I'll have a try with the

    function row().invalidate( [ source ] )
    

    first and see how I get on or maybe update from the database.

    Thanks for your help.

  • chuck808chuck808 Posts: 7Questions: 2Answers: 0

    This seems to have done the trick -

    var table = $('#tblRiders').DataTable();
    
    if(membstat == 'Member'){
        currow.find('td:eq(6)').html(($subs).toFixed(2));
        table
            .row( currow )
            .invalidate()
            .draw(false);
    }else{
        $subs = 5.00
        currow.find('td:eq(6)').html(($subs).toFixed(2));
        table
            .row( currow )
            .invalidate()
            .draw(false);
    };
    

    Added the .draw(false) to prevent the table from jumping back to the first page.

    The only issue I seem to be having now is the the FooterCllback isn't returning a decimal to 2 places. So, for £5.00 I get £5 and for £3.50 it shows £3.5. Any ideas?

    Thank you for you help, very much appreciated!

  • kthorngrenkthorngren Posts: 21,571Questions: 26Answers: 4,996
    Answer ✓

    Good work, nice find with the .draw(false).

    You will probably want to use toFixed(2) in the footerCallback, for example:

                 $( api.column( 6 ).footer() ).html(
                     ('£' + total.toFixed(2))
                 );
    

    Kevin

  • chuck808chuck808 Posts: 7Questions: 2Answers: 0

    What an idiot :worried:

    I didn't even try that. It's working now.

    Thank you for the help, as before, very much appreciated.

This discussion has been closed.