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

Reduce the surface area - deprecate the JS cookiecutter #25

Closed
ibdafna opened this issue Jun 20, 2023 · 15 comments
Closed

Reduce the surface area - deprecate the JS cookiecutter #25

ibdafna opened this issue Jun 20, 2023 · 15 comments

Comments

@ibdafna
Copy link
Member

ibdafna commented Jun 20, 2023

cc @jupyter-widgets/jupyter-widgets-council

Following the feedback we received during JupyterCon 23 about seeding new widget projects from the TS/JS cookiecutters, and in line with more recent discussions on the same topic during our weekly dev meetings, I propose that we reduce the surface area and deprecate the JS cookiecutter, so we can focus on maintaining only one cookiecutter. TypeScript has come a long way since the early days of widgets and is considered best practice nowadays. This will also be a great opportunity to modernize our TS cookiecutter and make it a good experience for new widget developers.

@ibdafna
Copy link
Member Author

ibdafna commented Aug 29, 2023

We've gotten four thumbs-up on this, which is great - but I'd like to make sure everyone has had the chance to properly vote on this.

Are you in favor of deprecating the JavaScript cookiecutter for jupyter-widgets extensions?

@jtpio
Copy link
Member

jtpio commented Aug 29, 2023

Of note, anywidget seems to be getting some traction for authoring custom widgets: https://github.com/manzt/anywidget. Which can be a good replacement for those looking for a JavaScript cookiecutter.

Maybe the ipywidgets docs or the TypeScript cookiecutter could link to it as another option, with the disclaimer that it is not officially supported.

@ibdafna
Copy link
Member Author

ibdafna commented Aug 29, 2023

We should mention anywidget in the documentation for sure. I'd also like to discuss potentially using it at some capacity in ipywidgets - perhaps in the next meeting?

@davidbrochart
Copy link
Member

Having tried anywidget, I'm not going back to the cookiecutter.

@maartenbreddels
Copy link
Member

offtopic: I feel the time is ripe to propose to serve all ipywidgets assets from the kernel instead of the jupyter server (like anywidget does) so we'll have 0 installation issues 🥳

ontopic: yes, i think we should advertise the low friction entries sooner, ipyvue(tify), ipyreact and anywidget (in particular).

I'd also like to discuss potentially using it at some capacity in ipywidgets - perhaps in the next meeting?

Seriously, I think we should think about serving all widget assets as (es) modules from the kernel.. so yes, I think we should use the underlying ideas.

@martinRenou
Copy link
Member

offtopic: I feel the time is ripe to propose to serve all ipywidgets assets from the kernel instead of the jupyter server (like anywidget does) so we'll have 0 installation issues 🥳

Staying offtopic: that means not benefiting from the browser caching, right? Duplication of style assets and JS in the page whenever you restart the kernel may be an issue as well, or when you have multiple kernels.

@maartenbreddels
Copy link
Member

Still offtopic, but not quite maybe: I think styling collisions can happen, but we can maybe be careful about that with ipywidgets 9 at least. But I think both browser cache can work, and multiple jupyter-widgets versions can live on a single page.

I wouldn't say it is easy to solve, but I think with collective brainpower feasible, and a huge win for usability.

@martinRenou
Copy link
Member

serving all widget assets as (es) modules from the kernel

I would not be in favor of this BTW. That means getting rid of TypeScript and going back to JavaScript everywhere, right? At least, I understand that the point of anywidget is to get rid of all the complicated dev tooling around widgets, like TypeScript compilation and webpack, which makes it appealing to newcomers.

@maartenbreddels
Copy link
Member

No, anywidgets loads an ES module, which you can generate using webpack, esbuild, vite and probably a few more. The simplest case is to manually write it, as most anywidget examples will show. So we can keep using whatever build chain we like. With the (es) between parenthesis I mean not per se en ES module, anything will be fine for me, as long as they come from the kernel.

@ibdafna
Copy link
Member Author

ibdafna commented Sep 12, 2023

@jasongrout @ivanov @marimeireles @davidbrochart @vidartf Gentle reminder to cast your vote 😸 We'll look to finalize a decision in the next meeting!

@ivanov
Copy link

ivanov commented Sep 13, 2023

@ibdafna I can't edit your comment so I'm probably not on the appropriate team, but my thumbs up was intended as a yes vote, so please go ahead and adjust that accordingly.

@jasongrout
Copy link
Member

The thing I've always preferred about the js cookiecutter is that it is very minimal, so it was easier to see what the essential parts of a widget were, to integrate into existing workflows, etc. It would be nice if there was a very minimal barebones typescript widget example or cookiecutter. (Or perhaps anywidget fills that roll?)

That said, I won't stand in the way of deprecating the js cookiecutter either.

@jtpio
Copy link
Member

jtpio commented Dec 15, 2023

So the current vote seems to show a majority of 👍

Should we go ahead and deprecate the JS cookiecutter? Or should this be discussed more?

so it was easier to see what the essential parts of a widget were, to integrate into existing workflows, etc. It would be nice if there was a very minimal barebones typescript widget example or cookiecutter. (Or perhaps anywidget fills that roll?)

Agree that having a simple version is good for newcomers, or widget authors who don't have time to learn TypeScript. anywidget seems to be quite popular these days and simple to get started. So maybe this could be the replacement for the JS cookiecutter? In that case it could be mentioned in the documentation as an alternative to using the TypeScript cookiecutter.

@ibdafna
Copy link
Member Author

ibdafna commented Dec 18, 2023

@jtpio Yes, let's deprecate it - there's consensus from the majority of the team. The concern for having an accessible entrypoint for newcomers to learn widgets is valid, and I do agree with it. Hopefully adding links in the deprecated JS cookiecutter page (and maybe even the TS one) to the anywidget documentation should help.

@ibdafna
Copy link
Member Author

ibdafna commented Jan 22, 2024

Completed via jupyter-widgets/widget-cookiecutter#109

@ibdafna ibdafna closed this as completed Jan 22, 2024
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

7 participants