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

fix(types): use TS interfaces only for public api #1106

Merged
merged 1 commit into from
Jul 19, 2022

Conversation

dai-shi
Copy link
Member

@dai-shi dai-shi commented Jul 19, 2022

This mostly reverts #1012.
@typescript-eslint/consistent-type-definitions rule doesn't work for library code.

So, our new ground rule is:

  • prefer interface for public api (always with export)
  • otherwise, prefer type alias

close #1100
close #1103
close #1113


jotai and valtio should follow this too.

@codesandbox-ci
Copy link

This pull request is automatically built and testable in CodeSandbox.

To see build info of the built libraries, click here or the icon next to each commit SHA.

Latest deployment of this branch, based on commit a9a05f7:

Sandbox Source
React Configuration
React Typescript Configuration
React Browserify Configuration
React Snowpack Configuration
React Parcel Configuration
Next.js Configuration
zustand-4.0.0-rc.2-declaration Issue #1103
zustand-4.0.0-rc.2-declaration-from-docs Issue #1103

@github-actions
Copy link

Size Change: -1 B (0%)

Total Size: 28.8 kB

Filename Size Change
dist/system/middleware.production.js 1.75 kB -1 B (0%)
ℹ️ View Unchanged
Filename Size
dist/context.js 518 B
dist/esm/context.js 448 B
dist/esm/index.js 415 B
dist/esm/middleware.js 2.66 kB
dist/esm/middleware/immer.js 210 B
dist/esm/shallow.js 272 B
dist/esm/vanilla.js 377 B
dist/index.js 670 B
dist/middleware.js 3.23 kB
dist/middleware/immer.js 373 B
dist/shallow.js 318 B
dist/system/context.development.js 572 B
dist/system/context.production.js 393 B
dist/system/index.development.js 589 B
dist/system/index.production.js 393 B
dist/system/middleware.development.js 2.75 kB
dist/system/middleware/immer.development.js 292 B
dist/system/middleware/immer.production.js 187 B
dist/system/shallow.development.js 338 B
dist/system/shallow.production.js 253 B
dist/system/vanilla.development.js 444 B
dist/system/vanilla.production.js 270 B
dist/umd/context.development.js 662 B
dist/umd/context.production.js 488 B
dist/umd/index.development.js 816 B
dist/umd/index.production.js 570 B
dist/umd/middleware.development.js 3.35 kB
dist/umd/middleware.production.js 2.06 kB
dist/umd/middleware/immer.development.js 514 B
dist/umd/middleware/immer.production.js 371 B
dist/umd/shallow.development.js 447 B
dist/umd/shallow.production.js 344 B
dist/umd/vanilla.development.js 590 B
dist/umd/vanilla.production.js 378 B
dist/vanilla.js 456 B

compressed-size-action

@ShravanSunder
Copy link

onsistent-type-definitions

@dai-shi i'm wondering why interface is preffered over types for external public api

@dai-shi
Copy link
Member Author

dai-shi commented Jul 20, 2022

for complex types, type aliases will be inlined, which doesn't look nice.

See screenshot in pmndrs/jotai#1234 for example.

@ShravanSunder
Copy link

@dai-shi would this be released soon? any timeline? thanks 🙏🏾

@dai-shi
Copy link
Member Author

dai-shi commented Jul 23, 2022

It's already released.

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.

Typescript store error Missing exports on middleware Store factory typings
2 participants