-
Notifications
You must be signed in to change notification settings - Fork 47
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
ArgsFromMeta utility and generic ArgsStoryFn RT #51
Conversation
ceabbe7
to
23af5af
Compare
"@babel/cli": "^7.8.4", | ||
"@babel/core": "^7.9.0", | ||
"@babel/preset-env": "^7.9.5", | ||
"@babel/preset-typescript": "^7.9.0", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
😍
tsconfig.json
Outdated
"lib": ["es2015", "es2017", "dom"], | ||
"module": "commonjs", | ||
"moduleResolution": "Node", | ||
"module": "ES2022", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The storybook monorepo is still using:
"target": "ES2020",
"module": "CommonJS",
This seems like quite a jump. Is this going to impact our chrome 100+ support target?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In the storybook monorepo the tsconfig isn't used to determine the compile target at all
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is it being used in this case? If so, is this the correct target?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It might not matter at all, depending on the source code. but let's play it safe and target 2020?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
will do
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
tomorrow, was a long day 😅
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good, although I'm not quite sure what it is for?
export type ArgsFromMeta<TFramework extends AnyFramework, Meta> = Meta extends { | ||
render?: ArgsStoryFn<TFramework, infer RArgs>; | ||
loaders?: (infer Loaders)[]; | ||
decorators?: (infer Decorators)[]; | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we have a TS "test" for this? At the very least it would document what it is for :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hehe, yeah, good point, I have tests for it in this PR:
https://github.com/storybookjs/storybook/pull/19512/files
But maybe good to put a simple test here as well.
I was not really sure where to put this. I could also have put it somewhere in the monorepo. Because StoryObj will now use Meta(OrArgs) as generic (typeof meta), I will need something like this in the public types of every renderer (we use it now only for react and svelte). But because there is also framework-specific inference (to infer the args of the component or specific stuff for action arg inference) I can not put all of StoryObj in this package.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
added a test now
Hey @kasperpeulen this looks good but your PR has no description, would be nice to explain what's the purpose with some small example use cases. This might help anyone that wants to revisit this PR in the future |
@yannbf Added a description and a test to make it a bit more clear hopefully 😅 |
🚀 PR was released in |
What I did:
ArgsFromMeta:
Added ArgsFromMeta type, this a type that can be used to infer the args from Meta that are unrelated to the component. It is used here:
https://github.com/storybookjs/storybook/blob/b42d9456cce20d06097d83f080f52ca65a9ba7b2/code/renderers/react/src/public-types.ts#L38-L59
Basically, when StoryObj accepts a meta (
StoryObj<typeof meta>
), we need to find out the args that are passed to render/loader/decorators, which will be used as the actual args for StoryObj. This is common across the implementation of StoryObj across frameworks, so therefore I put it here.The inference of the args of the component is framework specific, so has to stay in the renderer code.
Upgraded to tsup
Also upgraded many other dependencies, and added some github workflows.
📦 Published PR as canary version:
0.0.2--canary.51.084d9eb.0
✨ Test out this PR locally via:
npm install @storybook/csf@0.0.2--canary.51.084d9eb.0 # or yarn add @storybook/csf@0.0.2--canary.51.084d9eb.0