puppeteer/compat
2022-06-27 09:24:23 +02:00
..
cjs feat: export public types only (#8584) 2022-06-27 09:24:23 +02:00
esm feat: export public types only (#8584) 2022-06-27 09:24:23 +02:00
README.md feat: support ES modules (#8306) 2022-05-09 11:17:24 +00:00

Compatibility layer

This directory provides an additional compatibility layer between ES modules and CommonJS.

Why?

Both ./cjs/compat.ts and ./esm/compat.ts are written as ES modules, but ./cjs/compat.ts can additionally use NodeJS CommonJS globals such as __dirname and require while these are disabled in ES module mode. For more information, see Differences between ES modules and CommonJS.

Adding exports

In order to add exports, two things need to be done:

  • The exports must be declared in src/compat.ts.
  • The exports must be realized in ./cjs/compat.ts and ./esm/compat.ts.

In the event compat.ts becomes too large, you can place declarations in another file. Just make sure ./cjs, ./esm, and src have the same structure.