-
Notifications
You must be signed in to change notification settings - Fork 900
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
Missing type paths for TypeScript 4.7 Node16 modules #6300
Comments
I couldn't figure out how to label this issue, so I've labeled it for a human to triage. Hang tight. |
Hi @andipaetzold , thanks for the report. I was able to reproduce the behavior using your minimal repro. Let me check what we can do for this issue or bring someone here that can provide more context about it. I’ll update this thread if I have any information to share. |
Would it help if I open a PR with my current changes to show what needs to be done to resolve the issue? Alternatively, here is a PR from the Playwright folks that resolves the same problem: microsoft/playwright#14428 About the triage: This issue affects all packages/APIs. Not only database. Database was chosen to reproduce the issue. |
Yes, pull requests are definitely welcome! I'll notify an engineer to have this checked. Thank you for your contribution! |
This solution looks good, I just wanted to double check if there is a chance adding this field will break anyone using older versions of Node or Typescript or different configurations. It doesn't seem like it should but if you can double check that, that would be great. I think you've provided enough info so you don't need to make a demo PR to show the problem, but if you want to make an actual PR to fully fix the problem, that would be great (but totally optional). |
I just created a PR (#6307) to resolve this issue in all firebase packages. |
This will go out in the next release which is currently scheduled for 6/23/2022 but I'm looking into doing an earlier one as that's a long ways off. |
FYI this has been released in 9.8.3 |
Since the filename pointed at by `default` and `import` (`empty`) is not identical to the filename of the `d.ts` file (`index`), the top level `types` field is not enough when using `"moduleResolution":"Node16"` and TypeScript `4.7`. To fix this, `types` must be explicitly specified inside the `exports` object in addition to the top level `types` field. See [firebase/firebase-js-sdk#6300](/firebase/firebase-js-sdk/issues/6300) and [microsoft/playwright#14428](/microsoft/playwright/pull/14428)
[REQUIRED] Describe your environment
[REQUIRED] Describe the problem
With TypeScript 4.7 a new
module
was introduced to improve the ES module support:Node16
(https://devblogs.microsoft.com/typescript/announcing-typescript-4-7/#esm-nodejs). When using thatmodule
in atsconfig.json
and importing fromfirebase/xxx
, an error is thrown because the type declaration cannot be found.The issue is that only a global
typings
/types
path is defined. Withmodule: Node16
andstrict: true
, the path to the types must also be added to theexports
field in the package.json. (At least this is the only way I got it working).Steps to reproduce:
module: Node16
andstrict: true
firebase/xxx
tsc
You will receive an error similar to this:
I've created a repository to easily reproduce the issue: https://github.com/andipaetzold/firebase-node16-issue
Relevant Code:
index.ts
tsconfig.json
Solution
In order to get the repository linked above working, I had to adjust several files in the
node_modules
folder:node_modules/firebase/package.json
"./database": { "node": { "require": "./database/dist/index.cjs.js", "import": "./database/dist/index.mjs" }, "default": "./database/dist/index.esm.js", + "types": "./database/dist/database/index.d.ts" },
node_modules/@firebase/database/package.json
"exports": { ".": { "node": { "import": "./dist/node-esm/index.node.esm.js", "require": "./dist/index.node.cjs.js" }, "esm5": "./dist/index.esm5.js", "standalone": "./dist/index.standalone.js", "default": "./dist/index.esm2017.js", + "types": "./dist/public.d.ts" }, "./package.json": "./package.json" },
With
skipLibCheck: false
in tsconfig.json, similar changes must be done in all indirectly imported firebase packagesAfter the adjustments,
tsc
does not throw and compiles successfully.In order to fix all imports, the
types
need to be added to allexports
.I started on this locally, but wanted to open this issue first in case I failed using TypeScript or you are working on a fix already. Also, the solution might be added to the
use_typings.js
script and I didn't want to mess around with your build setupThe text was updated successfully, but these errors were encountered: