You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Depends on #2127, because migrating to ES Modules will mean that we will have two versions we need to support for the foreseeable time (the latest which will be ESM and a long-term support version implemented as commonjs)
Problems
We currently don't have control over the resulting declaration files. They are hard to read and debug. And with growing complexity of Octokit's decomposable and pluggable architecture it's increasingly hard to do so with TypeScript source code
Users who run into TypeScript problems have a hard time to debug their problem and to submit fixes, because the *.d.ts files are not checked into the source code on GitHub. They are generated and published to npm only. Example: https://unpkg.com/browse/@octokit/core@3.5.1/dist-types. The relation between the source code (in this case: https://github.com/octokit/core.js/tree/v3.5.1/src) and the definition file is not always straight forward.
Different versions of the TypeScript compiler (tsc) and different compiler options result in different declaration files.
When writing the entire source code in TypeScript, types are checked throughout the entire code. That can be helpful at times, but more often than not it results in unneeded code complexity and build errors that slow down the development and maintenance of the Octokit source code. I estimate that the introduction of TypeScript slows down code develepoment by a factor of 4x-5x. I think separating the source code from the types will bring it down to 2x-3x, as only the types for the plublic APIs need to be defined and tested.
Solution
Rewrite the TypeScript source files into native JavaScript and add the .d.ts declaration files into the source code. Besides testing the code, add tests for types.
Benefits
Removes all build steps. We currently use @pika/pack which is now unmaintained. The source code in the GitHub repositories is 1:1 what is used in production. The runtime code will be easier to read, debug, and contribute to.
Source code is production code. Easier to debug and contribute to.
Steps
Create a new octokit/octokit-next.js repository as a native ES Module with separate TypeScript Declaration files. There should be no build step necessary.
Once the setup is working for octokit/octokit-next.js, start the transition to ES Modules and .d.ts files with the most low-level dependencies.
Separate the Node usage into Node CommonJS (legacy) and Node ES Modules (12+), e.g. in https://github.com/octokit/endpoint.js#usage. Use npm install @octokit/endpoint@commonjs (etc) for the legacy usage. Mention the long-term support version that is publishing to the @commonjs release channel (dist-tag) in the README and link to it.
Once the new setup and release automation is working for the packages listed above, propagate it to all other @octokit/* packages
Setup automation which helps backport new bug fixes and features to the @commonjs long-term support version. Expand the current automation around OpenAPI spec updates, webhooks updates and app permission updates to also send pull requests against the @commonjs long-term support version branches.
The text was updated successfully, but these errors were encountered:
Glad that i'm not the only person that feels that Typescript are only in the way. I also think the compiling is wasteful, and you can't always use the latest features, IMO i don't think typescripts fits well into a loosed typed language. It's possible to have type safety with jsdoc and vanilla javascript without it. I think the hole extension less and the new introduction of mts and cts to imports for typescript, Deno and nodejs was their downfall. Remote path resolving is a nightmare to get it right.
Deno stop using Typescript for a couple of reasons i can only agree upon
I would like to help out in anyway i can to migrate to vanilla javascript and switching over to ESM, just tell me what i can do
Thanks Jimmy! The work is on hold right now, but I'll let you know once we get back to it.
It's not a simple transpilation of TS -> JS, it's an entire rewrite in many ways, which among other things enables the separation of REST API types and code, making Octokit easier to use with GitHub Enterprise Server and other special environments. The WIP is here: https://github.com/octokit/octokit-next.js
Depends on #2127, because migrating to ES Modules will mean that we will have two versions we need to support for the foreseeable time (the latest which will be ESM and a long-term support version implemented as commonjs)
Problems
*.d.ts
files are not checked into the source code on GitHub. They are generated and published to npm only. Example: https://unpkg.com/browse/@octokit/core@3.5.1/dist-types. The relation between the source code (in this case: https://github.com/octokit/core.js/tree/v3.5.1/src) and the definition file is not always straight forward.tsc
) and different compiler options result in different declaration files.Solution
Rewrite the TypeScript source files into native JavaScript and add the
.d.ts
declaration files into the source code. Besides testing the code, add tests for types.Benefits
@pika/pack
which is now unmaintained. The source code in the GitHub repositories is 1:1 what is used in production. The runtime code will be easier to read, debug, and contribute to.Steps
Create a new
octokit/octokit-next.js
repository as a native ES Module with separate TypeScript Declaration files. There should be no build step necessary.javascript-plugin-architecture-with-typescript-definitions
Once the setup is working for
octokit/octokit-next.js
, start the transition to ES Modules and.d.ts
files with the most low-level dependencies.Separate the Node usage into
Node CommonJS (legacy)
andNode ES Modules (12+)
, e.g. in https://github.com/octokit/endpoint.js#usage. Usenpm install @octokit/endpoint@commonjs
(etc) for the legacy usage. Mention the long-term support version that is publishing to the@commonjs
release channel (dist-tag) in the README and link to it.@octokit/endpoint
@octokit/request-error
@octokit/request
Make sure that all outside dependencies such as
deprecation
andbefore-after-hook
are either built as ES Modules themselves or are fully compatible.Of particular interest isSee Removenode-fetch
. See v3 Roadmap node-fetch/node-fetch#668.node-fetch
by default octokit-next.js#57Forsee Remove@octokit/request
, test the conditional exports for Node (which requires thenode-fetch
polyfill) and Browsers/Deno which do not. Make sure that the published packages work with browsers and deno via https://www.skypack.dev/.node-fetch
by default octokit-next.js#57Once the new setup and release automation is working for the packages listed above, propagate it to all other
@octokit/*
packagesSetup automation which helps backport new bug fixes and features to the
@commonjs
long-term support version. Expand the current automation around OpenAPI spec updates, webhooks updates and app permission updates to also send pull requests against the@commonjs
long-term support version branches.The text was updated successfully, but these errors were encountered: