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

[Feature Request] Transpile away style9 runtime call #63

Open
SukkaW opened this issue Mar 10, 2022 · 5 comments
Open

[Feature Request] Transpile away style9 runtime call #63

SukkaW opened this issue Mar 10, 2022 · 5 comments

Comments

@SukkaW
Copy link
Contributor

SukkaW commented Mar 10, 2022

Facebook's stylex has evolved a lot since it is being first introduced in React Conf 2019. At the time, stylex uses a syntax like this:

const styles = stylex.create({ red });

<div className={styles('red')} />

Nowadays, stylex seems to prefer the syntax with directly stylex() call, see React Finland 2021 - Introducing StyleX:

const styles = stylex.create({ red });

<div className={stylesx(styles.red)} />

And according to React Finland 2021, they are able to strip most of stylex runtime call through static analysis.

Currently, style9 doesn't support stripping away the style9() runtime at all. I am about to experiment with it a little bit to see if it is doable.

@johanholmerin
Copy link
Owner

For styles defined in the same file this should be fairly easy. It may also be more intuitive, since it removes the magic(i.e. lie) of styles being a function. Having a single way of generating class names is also a plus. When it comes to styles defined in other files the compiler will have to bail and stick to using the runtime, which is fine.

Let me know how it goes and what your opinion on the styles() vs style9() syntax is

@SukkaW
Copy link
Contributor Author

SukkaW commented Mar 12, 2022

For styles defined in the same file this should be fairly easy. It may also be more intuitive, since it removes the magic(i.e. lie) of styles being a function. Having a single way of generating class names is also a plus. When it comes to styles defined in other files the compiler will have to bail and stick to using the runtime, which is fine.

Let me know how it goes and what your opinion on the styles() vs style9() syntax is

Personally, I'd prefer the new way (without styles being a function). It enables IDE to find the original style definition:

image

With Go to definition I can find what styles.card is.

And personally, I rarely create the style and export for other files. If I need to re-use a style, I will do composition at the component level (as I mentioned in #59)

@TxHawks
Copy link
Contributor

TxHawks commented Jun 13, 2022

I wonder if the newly released StyleQ could be of any relevance to this discussion

@shravan2x
Copy link

Chiming in to share my preference for the new style. My reasoning is the same as @SukkaW i.e. so the type checker can verify that the style exists

@SukkaW
Copy link
Contributor Author

SukkaW commented Feb 4, 2023

Although Facebook stylex is not officially open-sourced, it does publish an alpha version on npm:

https://unpkg.com/browse/@stylexjs/babel-plugin@0.2.0-beta.8/lib/index.js

And we might be able to learn something from it.

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

No branches or pull requests

4 participants