Skip to content
This repository has been archived by the owner on Jan 6, 2025. It is now read-only.

Sunsetting the Webview UI Toolkit #561

Open
hawkticehurst opened this issue Jul 30, 2024 · 32 comments
Open

Sunsetting the Webview UI Toolkit #561

hawkticehurst opened this issue Jul 30, 2024 · 32 comments

Comments

@hawkticehurst
Copy link
Member

hawkticehurst commented Jul 30, 2024

Toolkit project announcement

Hi all,

With a heavy heart I'm here to share that we will be deprecating the Webview UI Toolkit for VS Code by the end of the year.

As some of you may have seen, at the beginning of May the FAST project announced a project re-alignment which includes the deprecation of several core packages. Notably, FAST Foundation (one of the defining pieces of technology we used to build the toolkit) was on this list.

Since that announcement we've been working in the background to determine how we should move forward. Skipping some of the details, the only meaningful path forward is a full top-to-bottom rewrite of the toolkit using FAST Element (a lower-level library from FAST for building web components) and unfortunately the resourcing to complete this work was not allocated.

Packages / repositories

As part of sunsetting this project the following packages and repositories will be deprecated and/or archived.

Timeline

There will be two key dates for sunsetting this project.

  • The toolkit samples repository will be archived on August 1, 2024 August 2, 2024
  • The toolkit NPM package and main repository will be deprecated/archived on January 1, 2025 January 6, 2025

Ongoing maintenance

During the time between this announcement and formal deprecation, all feature and documentation work, along with most bug fixes, will be closed. Critical security issues will continue to be addressed until January 1.

Thank you

Those are the highest level details, but if there are any questions, comments, or feedback please feel free to leave a message on this thread and I'm more than happy to discuss.

Beyond that, thank you for the last few years of participating in and using this tool. It was a joy to serve and work with all of you. I wish you all the best in your future VS Code extension endeavors!

@hawkticehurst hawkticehurst pinned this issue Jul 30, 2024
This was referenced Jul 30, 2024
@Sanderand
Copy link

Hey there. I was just starting out using Webview UI toolkit - which works fantastic. So this is bad news for me.
Going forward, what are the official alternatives to build web views that are compatible with the VSCode design language?

@alexweininger
Copy link
Member

Is there any advice or guidance for consumers of the toolkit going forward?

@hawkticehurst
Copy link
Member Author

Going forward, what are the official alternatives to build web views that are compatible with the VSCode design language?

Unfortunately, in terms of official support/alternatives, webview extension development will return to what is was before the toolkit. It will once again be the full responsibility of extension authors to implement webview UIs that align with the VS Code design language and follow the webview UX guidelines.

The UX guidelines do link to some samples/documentation, but these aren't the most thorough samples so I do have a personal goal to write something (a message, docs, maybe blog post... it's tbd) that summarizes some of the key takeaways/advice I'd give to extension authors who need to build webview UI of their own.

I have actually written a blog post in the past that covers some of this (notably theming) at a very high level that you're welcome to look at, but I would mostly ignore the code snippets provided since they're tied to the way that FAST works.

Is there any advice or guidance for consumers of the toolkit going forward?

I suppose it goes without saying, but the highest level guidance is that I would plan to no longer be a consumer of the toolkit and remove any dependencies on it by the end of the year.

This means the two primary paths forward are to either:

  1. Make a plan to recreate the toolkit UI you used in your extension (depending on the components used this will be pretty easy to very hard)
  2. Use some combination of third-party projects/component libraries to recreate the UI that the toolkit provided

Like I just mentioned above, I'm hoping to write something that offers a bit more guidance/insights for those who decided to pursue the first option. For those who decide to go with the second option, I unfortunately don't have any particular advice to give.

As for other advice/guidance I think it will depend greatly on what components you are using and the type of extension experiences you have implemented. If you have any specific questions I'd be more than happy to answer them here :)

@figuernd
Copy link

figuernd commented Aug 7, 2024

I would have assumed that this toolkit is the same set of UI components that VSCode itself uses. Does the FAST deprecation not affect VSCode's native components?

@Sanderand
Copy link

Sanderand commented Aug 7, 2024

I'd also like to know if there is the way to make use of the components, that VSCode uses itself - without the need of having to reinvent the same, existing components?

@hawkticehurst which main problems do you expect for extensions that continue to use the ui toolkit beyond it's deprecation date? I guess some of the design tokens will stop working eventually. What other issues do you see?

Do you have any insights in how the big consumers are dealing with the problem of the deprecation of this package (i.e. nx-console)? Is there any plan that somebody will continue with the maintenance of this package? I find it personally quite sad to see this package go. A lot of unnecessary and duplicate work will be caused by this across hundreds of organizations... :(

@hawkticehurst
Copy link
Member Author

hawkticehurst commented Aug 7, 2024

I would have assumed that this toolkit is the same set of UI components that VSCode itself uses. Does the FAST deprecation not affect VSCode's native components?

Perhaps surprisingly, no they are not the same components. The FAST deprecation has no affect on the native UI.

I'd also like to know if there is the way to make use of the components, that VSCode uses itself - without the need of having to reinvent the same, existing components?

Alas no, and it's not without trying. VS Code's native UI is extremely tightly integrated with the VS Code source code itself. Despite several behind the scenes efforts over the years that have explored pulling out the UI code and trying to turn into something consumable for others, it's proven too difficult to dissect from the rest of VS Code. For example, I spent a lot of the second half of 2022 seeing if I could make that happen without any meaningful success.

The basic gist of the problem is that VS Code's native UI is highly imperative vanilla TypeScript (i.e. a bunch of calls to vanilla DOM APIs wrapped inside a bunch of classes) that make heavy usage of custom internal VS Code services and interfaces to function correctly. The end result is a set of components that are very far from being easy to pull out and consume by external developers.

At the end of the day it's easier to just recreate the UI from scratch using a technology like web components, so that's what we did for the toolkit.

Also for anyone who's curious all the native UI source code is open source and is pretty interesting to read through.

Which main problems do you expect for extensions that continue to use the ui toolkit beyond it's deprecation date? I guess some of the design tokens will stop working eventually. What other issues do you see?

The two biggest concerns that come to mind are:

  1. Exposure to bugs and security issues without any path to resolve those issues
  2. When VS Code updates it's UI/design language there will be no way to adopt those changes

Do you have any insights in how the big consumers are dealing with the problem of the deprecation of this package (i.e. nx-console)?

Unfortunately, I don't have any insights into how the bigger consumers are navigating the deprecation. Everyone was notified of this deprecation at the same time, so I expect bigger consumers are also in the early stages of trying to figure out a plan forward at this point.

As a general call to action: Anyone from the community who reads this and maintains a larger extension please do give some updates about how you've decided to move forward. I know the rest of the community (and myself) would be very grateful for that insight!

Is there any plan that somebody will continue with the maintenance of this package?

Aside from the commitment to fix critical security issues until January 1, 2025, there are sadly no plans to continue the maintenance of this project.

Once FAST Foundation is deprecated trying to maintain the toolkit (as it exists today) would become a nightmare because it would effectively mean adopting ownership/maintenance of an entire second project just to keep the lights on. It would entail even more work than rewriting the project from scratch.

@estruyf
Copy link

estruyf commented Aug 20, 2024

@akurtaliqi-sg happy to hear. Feel free to join the discord server.

Yesterday I created the repository to get the community project started: https://github.com/estruyf/vscode-community-ui-toolkit

@fabritw
Copy link

fabritw commented Aug 30, 2024

Alternative library based on Lit

https://github.com/vscode-elements/elements

@korbinianhutter
Copy link

Alternative library based on Lit

https://github.com/vscode-elements/elements

Thanks for sharing, I didn't know this library exists. It even provides more components then the webview-ui-toolkit.

Am I missing something or what are the reason not to use this library but develop a new one?

@MaxKless
Copy link
Contributor

Wow this looks really good... On a first glance I'm not spotting anything that looks non-native either

yannick-beot-sp added a commit to yannick-beot-sp/vscode-sailpoint-identitynow that referenced this issue Oct 9, 2024
- Add User Agent
- Add transform evaluation support for `decomposeDiacriticalMarks` (cf. [#90](#90)) by [@Semperverus](https://github.com/Semperverus)
- Add new command to enable logging
- Fixed dependency (axios, micromatch)
- Refactored code due to [#36](sailpoint-oss/typescript-sdk#36)
- Removed Workflow Tester view due to webview-ui-toolkit deprecation (cf. microsoft/vscode-webview-ui-toolkit#561)
- Add support for Applications
- Error with session management (cf. [#93](#93))
brodao2 added a commit to totvs/TDS-WebToolKit that referenced this issue Oct 16, 2024
O pacote @vscode/webview-ui-toolkit foi descontinuado, por isso foi migrado para @vscode-elements/elements.

microsoft/vscode-webview-ui-toolkit#561
mhuisi added a commit to leanprover/vscode-lean4 that referenced this issue Nov 6, 2024
[`@vscode/webview-ui-toolkit` is being deprecated in
January](microsoft/vscode-webview-ui-toolkit#561).
This PR replaces the UI components from `@vscode/webview-ui-toolkit`
with components from `@vscode-elements/elements`.
@hifron
Copy link

hifron commented Nov 19, 2024

https://kermanx.github.io/reactive-vscode/

@namanyayg
Copy link

Since this is going to be deprecated, what can we use now for building VSCode extension webviews using React/Vite?

@NatKarmios
Copy link

https://vscode-elements.github.io/

@estruyf
Copy link

estruyf commented Jan 4, 2025

If you like to use a React library, check out https://www.npmjs.com/package/vscrui - https://github.com/estruyf/vscrui

@hawkticehurst
Copy link
Member Author

Hi all, I'm doing the final wrap up/shutting down of the project today and wanted to give a quick summary of this thread and a final goodbye.

Alternatives

For those seeking alternatives to the toolkit it seems like two great solutions are available that community has landed on:

  1. VS Code Elements - A mature web components implementation of VS Code UI
  2. VS Code React UI - A WIP React implementation of VS Code UI

Where to ask questions

Once this repo is archived this thread will be locked, so for those with any further questions feel free to bring them to VS Code Community Discussions.

Bye 👋

Again, thank you so much for all the involvement these last few years. It was a pleasure to work with and be a part of building your extensions. Wish you all the best!

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

No branches or pull requests