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

chore: build kits with cjs and esm targets #1049

Open
wants to merge 34 commits into
base: development
Choose a base branch
from
Open

Conversation

dasanra
Copy link
Collaborator

@dasanra dasanra commented Nov 15, 2024

What it solves

Continues #1047

How this PR fixes it

@dasanra dasanra requested review from yagopv and DaniSomoza November 15, 2024 14:14
@coveralls
Copy link

coveralls commented Nov 15, 2024

Pull Request Test Coverage Report for Build 12989722537

Details

  • 9 of 9 (100.0%) changed or added relevant lines in 4 files are covered.
  • No unchanged relevant lines lost coverage.
  • Overall coverage increased (+0.1%) to 75.038%

Totals Coverage Status
Change from base Build 12986758611: 0.1%
Covered Lines: 803
Relevant Lines: 993

💛 - Coveralls

@frontendphil
Copy link

Hey folks! I wanted to give this a little bump because I'm working on the next thing, and once again, I'm seeing your code in a stack trace related to the whole CJS/ESM interop stuff. As always, If there is anything I can do to help push this forward, just let me know.

@DaniSomoza
Copy link
Contributor

Hi @frontendphil

We’ve made significant progress and, after running multiple tests, it seems to be working well overall.

However, there’s one issue related to CommonJS compatibility that we’re still trying to address.

Specifically, due to the way the Safe class from the protocol-kit is exported, users currently need to use .default when importing it in CommonJS:

const Safe = require('@safe-global/protocol-kit').default // TODO: remove .default

Safe.init({ key: 'value' })

We’d love to eliminate the need for .default to simplify integration for CommonJS, but we haven’t found a clean, simple solution without introducing extra complexity.

Thanks for your time and support.

@frontendphil
Copy link

Hey @DaniSomoza

Thanks for getting back to me. This probably won't be the answer you're looking for, but I need to ask anyway :) Would eliminating the default export (which is discouraged anyway) and replacing it with a named export be something you'd consider?

Then, instead of:

const Safe = require('@safe-global/protocol-kit').default

People would need to do:

const { Safe } = require('@safe-global/protocol-kit')

This would mean a breaking API change, but it may also be worth considering.

@DaniSomoza DaniSomoza marked this pull request as ready for review January 24, 2025 15:31
@DaniSomoza
Copy link
Contributor

The changes are now ready for review.

I've published the following packages as alpha version for testing purposes:

  • @safe-global/api-kit → 2.5.8-alpha.0
  • @safe-global/protocol-kit → 5.2.1-alpha.0
  • @safe-global/relay-kit → 3.4.1-alpha.1
  • @safe-global/sdk-starter-kit → 1.1.3-alpha.0
  • @safe-global/types-kit → 1.0.2-alpha.0
  • @safe-global/testing-kit → 0.0.1-alpha.0

I've tested these versions in several of our demo projects, and everything seems to be working as expected. 🚀

CC: @frontendphil

Thanks!

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

Successfully merging this pull request may close these issues.

[SDK Refactoring] ESM Modules
4 participants