This project is not a script or an extension. It is just an approach to use custom themes inside tailwindcss
You can try it online
At the begnning of each project, I'm always stuck at the phase of choosing the font and the colors of the website. I can have so many Color Palettes but I don't know which color to use for text and which for the background etc.
So, I created this project to save all my themes in. It's like a .dotfile
but for my themes configuration.
I also created ash-input
and ash-button
(ash for my name 🌚), custom components, that takes the color as a prop to preview the different colors used in each theme. If the color doesn't exist, then you will see the component colors with the css defaults (will be handled better later).
This project uses tailwindcss to be able to integrate the custom themes with the project.
- Integrate with TailwindCSS
- See the Themes Store File. I use Pinia if you are using it, you can take the file to your project. If not, you can write your own functions that does the same behaviour.
- Download the Themes File and add it to your assets folder.
- Don't forget to update the import in the Themes Store File after you download the Themes File
I followed the convension of DaisyUI in naming the colors so this is what the themes file should have in order to work perfectly.
{
"--color-primary": "",
"--color-primary-content": "",
"--color-primary-focus": "",
"--color-secondary": "",
"--color-secondary-content": "",
"--color-secondary-focus": "",
"--color-accent": "",
"--color-accent-content": "",
"--color-accent-focus": "",
"--color-neutral": "",
"--color-neutral-content": "",
"--color-neutral-focus": "",
"--color-base": "",
"--color-base-content": "",
"--color-base-darker": "",
"--color-base-darkest": "",
"--color-info": "",
"--color-info-content": "",
"--color-success": "",
"--color-success-content": "",
"--color-warning": "",
"--color-warning-content": "",
"--color-error": "",
"--color-error-content": "",
}
As you can see, each color have the default
, content
and focus
colors. So it is now easier to know which one goes for the background and which one goes for the text. Except for the status color I did not think I need to use a focus color but might be added at the future.
Also, you can use any color format suits the css such as rgb(), rgba(), hsl(), or hex.
-
Clone the repo
git clone [email protected]:AhmedAshrafAZ/tailwindcss-themes.git
-
Install dependencies (I use yarn)
yarn install
-
Run the development Server
yarn dev -- --open
-
Create a list to choose the preview theme
-
Create custom components to preview theme colors
-
Add some DaisyUI themes
-
Add more themes
-
Convert all colors to one format (maybe hex).
-
Import and Export themes
-
Auto generate the
content
andfocus
colors if the main color is chosen. Inspired by @adhamfarrag Example Repo