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

Scaffold for typescript in @wordpress/create-block #39915

Open
AdsonCicilioti opened this issue Mar 30, 2022 · 11 comments
Open

Scaffold for typescript in @wordpress/create-block #39915

AdsonCicilioti opened this issue Mar 30, 2022 · 11 comments
Labels
Developer Experience Ideas about improving block and theme developer experience [Status] Blocked Used to indicate that a current effort isn't able to move forward [Tool] Create Block /packages/create-block [Type] Enhancement A suggestion for improvement.

Comments

@AdsonCicilioti
Copy link

What problem does this address?

For those who already use Typescript, it is extremely unsatisfactory to have to work with JS. Even more so when getting to know a new library and its API.

What is your proposed solution?

The @wordpress/create-block package could have a scaffold for Typescript. This would help a lot in learning and greatly improve the developer experience.

@Mamaduka Mamaduka added [Type] Enhancement A suggestion for improvement. [Tool] Create Block /packages/create-block labels Mar 31, 2022
@gziolo gziolo added the Developer Experience Ideas about improving block and theme developer experience label Apr 1, 2022
@gziolo
Copy link
Member

gziolo commented Apr 7, 2022

@ryanwelcher, do you have a template for Create Block that works with TypeScript?

@github-actions
Copy link

github-actions bot commented Oct 5, 2022

Hi,
This issue has gone 180 days without any activity. This means it is time for a check-in to make sure it is still relevant. If you are still experiencing this issue with the latest versions, you can help the project by responding to confirm the problem and by providing any updated reproduction steps.
Thanks for helping out.

@github-actions github-actions bot added the Needs Testing Needs further testing to be confirmed. label Oct 5, 2022
@Mamaduka
Copy link
Member

An excellent idea for the "Create Block" template.

I'm going to remove the "Needs Testing" label.

@Mamaduka Mamaduka removed the Needs Testing Needs further testing to be confirmed. label Oct 18, 2022
@ryanwelcher
Copy link
Contributor

ryanwelcher commented Oct 18, 2022

This doesn't need to be part of the tool but rather can be an external template. The two templates that are included are the most common use cases and I wonder if enough block developers are using Typescript to make this part of the tool instead of an external template.

To be clear, I LOVE the idea of having a template that supports TS and this is where we should be headed.

However, in my ( admittedly limited ) experience working with blocks and TS, the main pain point is the lack of available types. There has been an effort to add types to many of the packages in GB but not for some of the packages that block developers will use, such as the @wordpress/blocks package and the types available at DefinitelyTyped don't reflect the current APIs. There is an effort to move those into the project ( #43686 ) but it has stalled - which is on me.

I think that before we move a full TS template into the tool, we should get the types in place for the packages that block devs will use to avoid the hassle of having to extend an out-of-date type set or having to roll their own types for built-in items.

This is a larger question that perhaps needs its own issue but perhaps we should consider creating this template as an external package in the repo. This would allow the types to be introduced in the template and then moved over to the corresponding packages as needed.

@gziolo
Copy link
Member

gziolo commented Oct 19, 2022

This is a larger question that perhaps needs its own issue but perhaps we should consider creating this template as an external package in the repo. This would allow the types to be introduced in the template and then moved over to the corresponding packages as needed.

I fully agree that the first step would be to create the external template hosted on npm or GitHub (assuming Create Block can consume GitHub repository) that works with TypeScript. I don't think we are in good shape in terms of types to offer an official template that is 100% TypeScript ready. However, having an unofficial template ready for the community would help find what's missing and bring more attention to tasks that eventually bridge the gaps.

@tresorama
Copy link

tresorama commented Aug 31, 2023

I would be good to have a semi-official scaffolded template in TS.

The good news about current situation is that webpack config that ships with @wordpress/create-block is already compatible with TS, it's necessary only to change extension of files to .ts and everyting compiles.

Maybe is required also to create a tsconfig.json in your workspace, i don't remember exactly. But you can grap a prefilled json config from the tsc cli or from https://github.com/tsconfig/bases

@tuanfront-end
Copy link

Hello @ryanwelcher, hope there are new updates on this?

@luisherranz
Copy link
Member

Just as a heads up, I was planning to include a new template to show how to use TypeScript with the Interactivity API in this pull request:

It might make sense to create a general TypeScript template where the block is interactive and the Interactivity API is also typed instead of creating a template just for the Interactivity API, but for the conversation here it seems like that's not something that will happen soon, is it? Should I continue with the Interactivity API-only template? What do you think?

@gziolo
Copy link
Member

gziolo commented Aug 27, 2024

Just as a heads up, I was planning to include a new template to show how to use TypeScript with the Interactivity API in this pull request:

#64577

I responded with the following #64577 (comment). The gist of it is, the main differences when using TypeScript is the file extensions and types added to JavaScript code so there is no need for creating new templates. Instead, we can offer variants of existing templates using concept of variants.

@gziolo gziolo mentioned this issue Oct 10, 2024
69 tasks
@gziolo gziolo added the [Status] Blocked Used to indicate that a current effort isn't able to move forward label Dec 20, 2024
@gziolo
Copy link
Member

gziolo commented Dec 20, 2024

It looks like one of the prerequisites for adding full TypeScript support to Create Block would be adding first-class TypeScript support for the most important core packages. @manzoorwanijk is coordinating adding support to @wordpress/block-editor and @wordpress/blocks which are the biggest packages necessary to develop blocks:

@ryanwelcher
Copy link
Contributor

I've recently been testing Typescript out with @wordpress/scripts and it's trivial to get it working. typescript is already a dependency and it would only take adding a tsconfig.json to the project and a tsc command to package.json.

After that is where things start to get complicated. There currently no reliable types available for registerBlockType and the only way to get it working is to define all of the items defined in block.json in the call as well - which is not ideal for a number of reasons.

I would say that before we can create a template/variant for TS, we need to get the types in place for @wordpress/blocks which would give extenders what they need for the basic scaffold. We'd need to fill in gaps from there.

In the meantime, defining the contents of tsconfig.json is a discussion that we would have here. Currently, I am using the following which seems to a sane set of defaults for using TS to lint.

{
	"compilerOptions": {
		
		"esModuleInterop": true,
		"skipLibCheck": true,
		"target": "es2022",
		"allowJs": true,
		"resolveJsonModule": true,
		"moduleDetection": "force",
		"isolatedModules": true,
		"verbatimModuleSyntax": true,

		
		"strict": true,
		"noUncheckedIndexedAccess": true,
		"noImplicitOverride": true,

		"jsx": "preserve",

		"module": "preserve",
		"noEmit": true,

		"lib": ["es2022", "dom", "dom.iterable"]
	},
	"include": ["src/**/*", "src/**/*.json"]
}

My TS knowledge is not as deep as I'd like so I'm happy to discuss/learn about these or other configs that may make sense.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Developer Experience Ideas about improving block and theme developer experience [Status] Blocked Used to indicate that a current effort isn't able to move forward [Tool] Create Block /packages/create-block [Type] Enhancement A suggestion for improvement.
Projects
None yet
Development

No branches or pull requests

7 participants