Show/Hide Details in Datatable that is within a Modal

Show/Hide Details in Datatable that is within a Modal

shaadak@gmail.comshaadak@gmail.com Posts: 36Questions: 3Answers: 0
edited June 2021 in DataTables

Hello,
I have a dataTable that is displayed within a Modal once I click on an element in another DataTable Editor.
Everything works fine until I dismiss my modal and have go to another line of the same table in the modal and click on show/hide again. Then my data is undefined.

alasql.promise('SELECT DISTINCT * INTO ? FROM XLSX("' + POFILE + '") Where [Requisition ID] IN @(?)', [report2Status, pr1]).then(function (r) {
                                                            document.body.style.cursor = 'auto';
                                                            $("#ModalReport2").modal('show');
                                                            var Mtable = $('#TableReport2').DataTable(
                                                                {
                                                                    data: report2Status,
                                                                    destroy: true,
                                                                    columns: [
                                                                        {
                                                                            className: 'details-control2',
                                                                            ordarable: false,
                                                                            defaultContent: ''
                                                                        },
                                                                        { data: 'P/O Number' },
                                                                        { data: 'Line Number' },
                                                                        { data: 'Line Desc' },
                                                                        // { data: 'Vendor Name' },
                                                                        // { data: 'Manufacturer Part ID' },
                                                                        // { data: 'Vendor Part ID' },
                                                                        {
                                                                            data: 'NeedDate',
                                                                            type: 'date',
                                                                            render: function (data) {
                                                                                if (data)
                                                                                    return moment(data).format('l');
                                                                                else return "";
                                                                            }
                                                                        },
                                                                        {
                                                                            data: 'Order Date',
                                                                            type: 'date',

                                                                            render: function (data) {
                                                                                var d = ((data - (25567 + 1)) * 86400 * 1000)
                                                                                return moment(d).format('l');

                                                                            },
                                                                        },

                                                                        {
                                                                            data: 'Due Date',
                                                                            type: 'date',
                                                                            render: function (data) {
                                                                                var d = ((data - (25567 + 1)) * 86400 * 1000)
                                                                                return moment(parseInt(d)).format('l');

                                                                            }
                                                                        },

                                                                        { data: 'Order Quantity' },
                                                                        { data: 'Received Qty' },
                                                                        { data: 'Accepted Qty' },
                                                                        // { data: 'Unit Cost' },
                                                                        {
                                                                            data: 'Line Total Amount',
                                                                            type: 'currency',
                                                                            render: function (data) {

                                                                                return "$" + data

                                                                            }
                                                                        }
                                                                        // { data: 'Assigned To' },
                                                                        // {
                                                                        //     data: 'Expediting Notes',
                                                                        //     defaultContent: "",
                                                                        // }
                                                                        // { data: 'Line Comment' },
                                                                        // { data: 'Confirmation (Y/N)' },
                                                                        // { data: 'Prime Contract ID' },
                                                                        // { data: 'Program' }
                                                                    ]
                                                                });

                                                            $('#TableReport2 tbody').on('click', 'td.details-control2', function () {
                                                                var tr2 = $(this).closest('tr');
                                                                var row2 = Mtable.row(tr2);

                                                                console.log(tr2);
                                                                console.log(row2)
                                                                console.log(row2.data())


                                                                if (row2.child.isShown()) {
                                                                    // This row is already open - close it
                                                                    row2.child.hide();
                                                                    tr2.removeClass('shown');
                                                                } else {
                                                                    // Open this row
                                                                    row2.child(format2(row2.data())).show();
                                                                    tr2.addClass('shown');
                                                                }
                                                            });


                                                        });

Edited by Colin - Syntax highlighting. Details on how to highlight code using markdown can be found in this guide.

Answers

  • colincolin Posts: 15,240Questions: 1Answers: 2,599

    The code looks fine, are you able to link to your page so we can take a look please. Information on how to create a test case (if you aren't able to link to the page you are working on) is available here.

    Cheers,

    Colin

  • shaadak@gmail.comshaadak@gmail.com Posts: 36Questions: 3Answers: 0

    Hello Colin,
    Unfortunately I cannot provide a link - since it is behind code is behind the firewall and requires for you to have login information. I will try to create the test case sometime today. The code works the first iteration without a problem, once the modal is dismissed and i click on a second progress bar, row2.data() that is passed to format2 becomes undefined

  • kthorngrenkthorngren Posts: 21,555Questions: 26Answers: 4,994

    What is the output of these statements when row2.data()) is undefined?

                                                                    console.log(tr2);
                                                                    console.log(row2)
                                                                    console.log(row2.data())
    

    Kevin

  • shaadak@gmail.comshaadak@gmail.com Posts: 36Questions: 3Answers: 0

    Yes it is undefined, yet, the row is showing in the table fine

  • shaadak@gmail.comshaadak@gmail.com Posts: 36Questions: 3Answers: 0

    I am so confused on why the row is undefined but still showing!

  • kthorngrenkthorngren Posts: 21,555Questions: 26Answers: 4,994

    In order for us to help we will need to see a test case showing the problem. This will allow us to debug what is happening. Please build a test case showing the problem. We don't need to see your data. You can simulate it. You can find some starter code here.

    Kevin

  • shaadak@gmail.comshaadak@gmail.com Posts: 36Questions: 3Answers: 0

    Thank you Kevin,
    I have moved some data around and not showing the data from the row from show/hide for now. I would love to create a test case, but since my backend is SP 2016 on Prime it makes it difficult to create all the data sets in your environment in a timely manner. Once I have some free time I will do so.

  • kthorngrenkthorngren Posts: 21,555Questions: 26Answers: 4,994

    Maybe you can simulate the data. The link I posted has some ajax data you can use. Or maybe you can create some Javascript data like this example. The problem doesn't seem to be with your data or data source but more about your process with the modals. That is what we are interested in seeing.

    Kevin

This discussion has been closed.