Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dvingo/cljs-emotion
ClojureScript wrapper of the emotion css-in-js library
https://github.com/dvingo/cljs-emotion
clojurescript emotion
Last synced: 3 months ago
JSON representation
ClojureScript wrapper of the emotion css-in-js library
- Host: GitHub
- URL: https://github.com/dvingo/cljs-emotion
- Owner: dvingo
- License: mit
- Created: 2020-05-29T03:24:20.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-11-24T22:39:40.000Z (about 1 year ago)
- Last Synced: 2024-10-13T10:27:41.525Z (3 months ago)
- Topics: clojurescript, emotion
- Language: Clojure
- Homepage: https://dvingo.github.io/cljs-emotion
- Size: 6.64 MB
- Stars: 25
- Watchers: 2
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# ClojureScript wrapper for emotion
[![Clojars Project](https://img.shields.io/clojars/v/dv/cljs-emotion.svg)](https://clojars.org/dv/cljs-emotion)
[![cljdoc badge](https://cljdoc.org/badge/dv/cljs-emotion)](https://cljdoc.org/d/dv/cljs-emotion)
Documentation and example usage are hosted in devcards here:
https://dvingo.github.io/cljs-emotion/#!/dv.cljs_emotion.devcards
https://dvingo.github.io/cljs-emotion
For info about emotion itself, see:
https://emotion.sh/docs/introduction
# To use this library
Include it in your clojure project dependency list (see most recent version on Clojars).
And install emotion:
```bash
npm install @emotion/react @emotion/styled
```
The main namespaces are:`dv.cljs-emotion` - Plain React components/elements
With API: `defstyled`, `jsx`, `css`, `global-style`, `theme-provider`, `keyframes`
`dv.cljs-emotion-reagent` - Reagent components
With API: `defstyled`, `jsx`, `css`, `global-style`, `theme-provider`, `keyframes`
`dv.emotion-helix-dom`
DOM elements for use with helix that support the `:css` prop, with the same API as the components in the `helix.dom` namespace.
## Use with plain react components
```clojure
(require [dv.cljs-emotion :refer [jsx css defstyled keyframes global-style theme-provider]])(defstyled sample1 :div
{:background-color "RebeccaPurple"})(react/createElement sample1 nil "hello")
```See the devcards for lots more details
https://dvingo.github.io/cljs-emotion/#!/dv.cljs_emotion.devcards
## Use with helix
https://github.com/lilactown/helix
The namespace `dv.emotion-helix-dom` is a drop in replacement for `helix.dom`, and supports all the props that helix
supports in addition to supporting the `:css` property of emotion. Here is an example:```clojure
(:require
[dv.emotion-helix-dom :as d]
[helix.core :refer [$ defnc]]
[dv.cljs-emotion :as em :refer [css defstyled keyframes global-style theme-provider]](def some-css
{:self (em/css #js {:backgroundColor "#aefefe"
:border "2px solid #eee"
:borderRadius "0.5rem"
:padding "1rem"})
:title (em/css {:font-size "1.25rem"
:color "red"}
#js{:border "1px dashed"
"> div > p" {:color "blue"}})
:more (em/css {:border "2px solid"})})(def merged-css
(em/css
{:background-color "black"}
(:title some-css)
(:more some-css)))(defn object-styles []
(d/div {:css (:self some-css)}
(d/h2 {:css (:title some-css)} "here we have a title")
(d/h2 {:css merged-css} "here we have a title")
(d/p {:css (em/css merged-css {:color "white"})}
"And overwrite inline")))
```You can of course use the `defstyled` API as well if you wish as that outputs React components.
More examples in the devcards:
https://dvingo.github.io/cljs-emotion/#!/dv.cljs_emotion.helix_cards
## Use with reagent
There is a separate namespace for reagent support:
```clojure
(:require
[dv.cljs-emotion-reagent :refer [jsx css defstyled keyframes global-style theme-provider]])(defstyled a-child :div {:color "deepSKYBlue"})
(defstyled a-parent2 :div
(fn [{:keys [color]}]
{:color "red"
a-child {:color (or color "darkorchid")}
"@media (min-width: 1024px)"
{a-child {:color "black"}}}))(def black-bg {:background-color "black"})
;; in your component's render function:
[:div
[a-parent2 "parent should be red"]
(jsx {:css (em/css black-bg {:color "white"})})
[a-parent2 {:color "steelblue"}
[a-child "nested child should be darkorchid"]]]
```The component output by `defstyled` supports passing reagent vectors as children and will convert them to React Elements
for you.If you want to use the `:css` property you have to use the `jsx` helper or create a component with `defstyled`
```clojure
(em/defstyled div :div {});; in your render function:
[div {:css [{:background "blue"} {:color "#eff"}]} "Some text"]
```A cool future development would be to plug into the Reagent compiler and add support for `:css` on all elements.
Pull requests welcome if that interests you!
More examples in the devcards:
https://dvingo.github.io/cljs-emotion/#!/dv.cljs_emotion.reagent_cards
# Development
```bash
make dev
```This starts the shadow-cljs server and watch process for the devcards build.
Open the shadow-cljs devtools webpage and then click on the webserver that hosts the devcards.
## Deploy
Notes for deploy:
- update pom.xml version
- commitBuild a deployable jar of this library:
clojure -X:jar
Install it locally:
clojure -M:install
Deploy it to Clojars -- needs `CLOJARS_USERNAME` and `CLOJARS_PASSWORD` environment variables:
clojure -M:deploy
## Publish github pages
See `Makefile`
```bash
git checkout gh-pages
git merge master
make gh-pages
git add -A
git commit -m
git push github HEAD -f
```