fixedHeader Auto offset bug

fixedHeader Auto offset bug

Berserker55Berserker55 Posts: 11Questions: 5Answers: 0
edited January 2020 in Free community support

Go into this example:
https://datatables.net/extensions/fixedheader/examples/options/offset-automatic.html

go into the html of the bar and change it to this:
<div class="fh-fixedHeader" style="position:fixed; background-color:#4E6CA3; top:20px; right:0; left:0; height:50px; z-index:1;"></div>

(Add top 20 pixels)
This now renders wrong in Chrome, at least.

Here's what I see in case it isn't easy to replicate:

So, the header is now under the "navbar" on the z-level and partially occluded.

I found this issue because on my page the navbar is slightly offset from the top and that made this break, though on my page it is entirely occluded and so I thought I messed up for a while.

Answers

  • allanallan Posts: 63,498Questions: 1Answers: 10,470 Site admin

    I believe the issue is that FixedHeaders reads the offset height when it starts up, so if you set it after initialisation (like dynamically in the inspector) it won't see that.

    Here is an example of it working: http://live.datatables.net/hevetafe/1/edit .

    Allan

  • Berserker55Berserker55 Posts: 11Questions: 5Answers: 0
        window.tablelookup = {};
        function adjust() {
            console.log("attempting adjustment")
            for (let table of Object.values(window.tablelookup)){
                table.fixedHeader.adjust();
                console.log("adjust");
            }
            setTimeout(adjust, 500);
        }
        adjust();
    

    Added this for testing and it is still behind the navbar. I can see that "adjust" is printed to console, so it is trying.

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

    Could you update the example, please, that Allan posted above to demonstrate that problem. It's working in the code that he posted.

    Colin

This discussion has been closed.