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

DataTablesJS Component #80

Open
hasansezertasan opened this issue Dec 8, 2023 · 7 comments
Open

DataTablesJS Component #80

hasansezertasan opened this issue Dec 8, 2023 · 7 comments

Comments

@hasansezertasan
Copy link
Contributor

Hi,

I discovered Starlette Admin in these last months and started to use in production. It uses DataTables/DataTables for tables which is quite powerfull.

My proposal is basically this: a component/field to use DataTables within FastUI.

@samuelcolvin
Copy link
Member

Maybe, but what specifically do you need from DataTablesJS?

@hasansezertasan
Copy link
Contributor Author

Many of my applications are data-first applications with many tables that presented to the users. Plain table approach is not enough for good user experience but DataTablesJS is.

Here are some examples: DataTables example - Zero configuration, DataTables example - Ajax sourced data

It basically creates a table with pagination, search and sorting features. It has a lot of customization options and its free. The best part is that we can easily seed the table with JSON data. We can set pagination endpoints in it and ta da ✨

Long story short: It's usefull and does a lot of magic based on definitions. I believe I "specifically need" another (a better) option to plain tables.

@paddymul
Copy link
Contributor

paddymul commented Dec 8, 2023

FWIW as developer of a related project I have a bunch of opinions, and so do datatable projects in general.

To the point where I think FastUI including a built in datatable component is way out of scope for the aims of this project. I think a simple HTML/bootstrap based table could work as a builtin for FastUI. Just take a list of strings for headers, and either a 2d array for the table, or maybe a list of dicts.

If I were recommending a generic datatable, I would look at IPyAggrid, which closely mimics the API of Ag-Grid in a jupyter widget. My own project, buckaroo is more opinionated, built around enabling summary stats and EDA for dataframes.

Once FastUI figures out extensibility I will make a component for it based on buckaroo. Building one for jquery datatables, or whatever other library would be nice additions.

There are a lot of projects in this space. I made a whole explainer page about related projects in the buckaroo docs. https://buckaroo-data.readthedocs.io/en/latest/articles/related_projects.html

After doing some digging, it seems that starlette admin is popular in the FastAPI ecosystem, and that uses DataTables.js So there is some familiarity with the package in this ecosystem. Still, I'd say make it a 3rd party package.

@paddymul
Copy link
Contributor

paddymul commented Dec 8, 2023

@samuelcolvin Maybe some guidance for users about what should and should not be in the core FastUI package, along with your reasoning would be helpful.

@hasansezertasan
Copy link
Contributor Author

hasansezertasan commented Dec 8, 2023

To the point where I think FastUI including a built in datatable component is way out of scope for the aims of this project.

You sound right but my situation here is different. I'm not a react person. I write some Vanilla JS. Let's say that I really want to use DataTablesJS, I tried to implement it in FastUI just looking at the example here: DataTables example - Ajax sourced data. I can't figure out how to make it work.

That's why I opened this issue because in the end we were gonna talk about this: Using other great JavaScript Libraries with FastUI. I can think of some other libraries:

@samuelcolvin Maybe some guidance for users about what should and should not be in the core FastUI package, along with your reasoning would be helpful.

I believe a contribution guide could be awesome.

After doing some digging, it seems that starlette admin is popular in the FastAPI ecosystem, and that uses DataTables.js So there is some familiarity with the package in this ecosystem. Still, I'd say make it a 3rd party package.

Since FastUI is quite new package, I couldn't find a 3rd party package that can inspire me to build such a thing. I believe a guidance that shows how to do it could also work for me.

@paddymul
Copy link
Contributor

paddymul commented Dec 8, 2023

Custom components which will be necessary for third party components are discussed here:
#19

When I was trying to learn FastUI and get a feel for it, I created a PR that integrated my own component into core FastUI, expecting the PR would never be merged. It still gave me a feel for many of the pieces and code that will be needed for a custom component. You could take a look here #73

@hasansezertasan
Copy link
Contributor Author

hasansezertasan commented Dec 20, 2023

@paddymul Thank you for your answer. #88 now adds Custom Components support but I'm not sure how we will be able to start a component that initialized via JavaScript snippet.

Edit: I just saw #102. I believe the same solution will solve this one too.

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

No branches or pull requests

3 participants