Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

Output tw.apply calls #2

Open
itsMapleLeaf opened this issue Jan 14, 2021 · 1 comment
Open

Output tw.apply calls #2

itsMapleLeaf opened this issue Jan 14, 2021 · 1 comment
Labels
enhancement New feature or request

Comments

@itsMapleLeaf
Copy link
Contributor

Pending this proposal

Here's the gist:

// input
import '@twind/macro'

const jsx = <button tw="bg-blue-500" />

// output, as of now
import { tw } from 'twind'

const jsx = <button className={tw`bg-blue-500`} />

// rough proposed output, aliasing to avoid conflicts
import { tw as _tw } from 'twind'
const _macro_tw = (...args) => _tw(_tw.apply(...args))

const jsx = <button className={_macro_tw`bg-blue-500`} />

This gives the benefit of reliable styling depending on class name order when using the macro, something that would be especially welcome for users coming from twin.macro and other CSS in JS libs. This should probably also apply to standalone tw usages that are imported from the macro.

At first, I'm thinking this would be an option/flag for the macro, but I'm wondering if there's any reason it shouldn't do this by default 🤔 Would this negatively impact performance? I guess it's hard to know for sure without measurements. cc @sastan

I also realized (right after making the issue 🙃) that the hashed class names would make debugging a little harder. One way to fix that would be to add an extra attribute to the element that shows the actual classes used, so it'll show up in the DOM as <button class="tw-abcxyz" data-tw="bg-blue-500" />

@itsMapleLeaf itsMapleLeaf changed the title Output calls wrapped with tw.apply Output tw.apply calls Jan 14, 2021
@sastan
Copy link
Contributor

sastan commented Jan 14, 2021

When using the global tw the following should work:

// input
import '@twind/macro'

<button tw="bg-blue-500" />

// output, as of now
import { tw } from 'twind'

<button className={`${tw.apply`bg-blue-500`} ${tw(props.className)}`} />

This gives the benefit of reliable styling depending on class name order when using the macro, something that would be especially welcome for users coming from twin.macro and other CSS in JS libs. This should probably also apply to standalone tw usages that are imported from the macro.

At first, I'm thinking this would be an option/flag for the macro, but I'm wondering if there's any reason it shouldn't do this by default 🤔 Would this negatively impact performance? I guess it's hard to know for sure without measurements. cc @sastan

Twind is a tailwind in js runtime with to goal to generate tailwind like css. The component mode mirrors the behavior of emotion and styled-components. I see two options:

  1. add a config option which "mode" to use with default to tailwind (need a different naming here as mode is already used by twind setup)
  2. when using the macro we default to the component mode which would all to customize/override the component styles using tailwind class; this is how twind/styled will work

I also realized (right after making the issue 🙃) that the hashed class names would make debugging a little harder. One way to fix that would be to add an extra attribute to the element that shows the actual classes used, so it'll show up in the DOM as <button class="tw-abcxyz" data-tw="bg-blue-500" />

We may have a solution for this on the way: tw-in-js/twind#76

@sastan sastan transferred this issue from tw-in-js/twind.macro Mar 4, 2021
@itsMapleLeaf itsMapleLeaf added the enhancement New feature or request label Mar 5, 2021
# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

2 participants