Skip to content

(╬▔皿▔)╯[reverse-card] : CSS file to tailwind token, with configurable file.

Notifications You must be signed in to change notification settings

Stvchm9703/rewind-card

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Rewind-Card

https://github.com/Stvchm9703/rewind-card/raw/main/doc/img/rewind-cover-2.png

ReWind-Card

inspiration by UNOCSS, so this project is like a UNO reverse card, converts to CSS property to Tailwind CSS class, and

  • Table of Contents

About The Project

In my experience in frontend development, functional CSS frameworks (like Tailwind CSS, WindiCSS, or UNOCSS) have a nice performance in Page Speed and Development Experience (DX). However, it won’t be easy to rewrite a new page when the project is ongoing and launched when the learning cost is still high. So, I make a transformer program (currently are CLI program that 😅 ) to convert the CSS property to Tailwind-like CSS class (or, say, tailwind-token)

So in my case, I have a Vue Component Library with many SCSS files, and one day I felt when the libs was implemented for the Nuxt project, those projects were not working as light-weight as expected! Neither the flexibility of applying the design token nor the overall performance caused by the CSS file. And I start thinking about rewriting the style files and reconsidering the page distribution in the project-based projects.

(back to top)

Usage

  1. clone this project
  2. create a directory input-src/ under the project, and put the CSS file under the input-src directory
  3. create a directory out-tw-token/ under the project for the result JSON file.
  4. execute the main script, cargo run
  5. Ta Da~, the token is exported as array form.

(back to top)

Roadmap

  • create a raw concept program
  • fixing the media query logic handle
  • fixing the class / pseudo-element replacing the logic
  • feature: add custom tailwind.config.js rule/variable
  • feature: export new config file for unsolve token
  • convert HTML / Vue / Svelte
    • convert style to token
    • convert the template part code’s class name to the token,

See the open issues for a full list of proposed features (and known issues).

(back to top)

Contributing

Contributions make the open-source community an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.

If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement". Don't forget to give the project a star! Thanks again!

  1. Fork the Project
  2. Create your Feature Branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the Branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

(back to top)

License

So call MIT License, just better for contributing.

(back to top)

Contact

Steven Chm - [email protected]

Project Link: https://github.com/Stvchm9703/rewind-card

(back to top)

Acknowledgments

Use this list of resources you may be interested in:

Tailwind CSS: the origin of everything

Windi CSS: the better engine in the conception of JIT.

UNOCSS: the greater one JIT of Atomic CSS Engine. Most of the code conversion is based on this engine, and makes sure the converted token can execute

lightningcss : the main CSS parser for this project

tailwind-rs : maybe better community for a similar project

(back to top)

About

(╬▔皿▔)╯[reverse-card] : CSS file to tailwind token, with configurable file.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages