Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Unexpected behavior on table horizontal scrolling #416

Closed
moreei opened this issue May 22, 2023 · 5 comments · Fixed by #1370 · May be fixed by #1345
Closed

Unexpected behavior on table horizontal scrolling #416

moreei opened this issue May 22, 2023 · 5 comments · Fixed by #1370 · May be fixed by #1345

Comments

@moreei
Copy link

moreei commented May 22, 2023

Hi @shadcn! Many thanks for this repo, amazing work 👏

Just noticed a strange behavior on the table component. When the content of the table is larger than the screen, a white space the size of the overflow is created. I have tried several things to fix this but nothing that works properly so far.

Tasks.-.22.May.2023.mp4
@PixeledCode
Copy link
Contributor

opened up a PR that solves this overflow issue #428

@moreei
Copy link
Author

moreei commented May 23, 2023

Hey! Implemented in my code, it works fine 👌 Thanks for your contribution ❤️

@Cesar90
Copy link

Cesar90 commented Sep 29, 2024

Hey folks, perhaps this could work for someone

First watch of change of size of parent div using useLayoutEffect and ResizeObserver to observe changes to the div's size and save state in useState

const [elementWidth, setElementWidth] = React.useState(0);
React.useLayoutEffect(() => {
        // Function to update the width of the div using getElementById
        const updateWidth = () => {
            const element = document.getElementById('main-content');
            if (element) {
                setElementWidth(element.clientWidth - 70);
            }
        };

        // Create a ResizeObserver instance to observe changes to the div's size
        const resizeObserver = new ResizeObserver(() => {
            updateWidth(); // Call updateWidth when the div is resized
        });

        const element = document.getElementById('main-content');
        if (element) {
            resizeObserver.observe(element); // Start observing the div
        }

        // Initial width calculation
        updateWidth();

        // Cleanup function to disconnect the observer
        return () => {
            if (element) {
                resizeObserver.unobserve(element);
            }
        };
}, []);

Second I use elementWidth on the parent div of <Table /> like this

image

With this the size of table can change when screen change.

@brandontle
Copy link

Thanks @Cesar90! This was the only solution that worked for me

@repovic
Copy link

repovic commented Jan 12, 2025

In case someone want a version with the ScrollArea you can use this:

const Table = React.forwardRef<
    HTMLTableElement,
    React.HTMLAttributes<HTMLTableElement>
>(({ className, ...props }, ref) => (
    <ScrollArea className="w-full overflow-auto grid grid-cols-1 h-full">
        <table
            ref={ref}
            className={cn("relative w-full caption-bottom text-sm", className)}
            {...props}
        />
        <ScrollBar orientation="horizontal" />
        <ScrollBar orientation="vertical" />
    </ScrollArea>
));
Table.displayName = "Table";

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
5 participants