Skip to content

pasmomusic/bs-glamor

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

36 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

bs-glamor – BuckleScript bindings for glamor

The API is still experimental. Only the css function from glamor is exposed (with its result slightly incorrectly typed as a string); no other functions such as renderStatic are supported yet.

Installation

npm install --save bs-glamor

In your bsconfig.json, include "bs-glamor" in the bs-dependencies.

Usage

The following examples (in Reason syntax) assume that Glamor is included in the namespace:

open Glamor;
  • Simple styling:

    css [
        color "red",
        border "1px solid black"
    ]
  • Styling with selectors (@media, :hover, &, etc.):

    css [
        color "red",
        Selector "@media (min-width: 300px)" [
            color "green"
        ]
    ]
  • Selectors can be nested:

    css [
        color "red",
        Selector "@media (min-width: 300px)" [
            color "green",
            Selector "& .foo" [
                color "blue"
            ]
        ]
    ]

You can isolate inclusion of the Glamor namespace in the following way:

Glamor.(css [color "red"])

The result of the css function can be assigned to a class name, e.g. in JSX:

<div className=(css [color "red"]) />

### Merging css rules

You can merge css rules using merge

let text_primary = css [ color "indigo" ];
let small = css [fontSize "10px"];


<p  className=(merge [text_primary, small])> ...

glamor will make sure that rules are merged in the correct order, managing nesting and precedence for you.

Global css

You can defined global css rules with global

Glamor.(global "body" [margin "0px"]);

Glamor.(global "h1, h2, h3" [color "palegoldenrod"]);

## Keyframes

define animation keyframes;

let bounce = Glamor.keyframes [
  ("0%": [transform "scale(0.1)",  opacity "0"]),
  ("60%": [transform "scale(1.2)",  opacity "1"]),
  ("100%": [transform "scale(1)"])
];
let styles = css [
    animationName bounce,
    animationDuration "2s",
    width "50px",
    height "50px",
    backgroundColor "red"
];

// ...
<div className=styles>
  bounce!
</div>

Example

See reason-react-tictactoe for a live example.

Development

npm run start

Tests

There are some simplistic tests using bs-jest.

npm run test

Thanks

Thanks to reason-react-example, reason-react, and bs-jest for inspiration how to create a Reason library, and of course, thanks to glamor.

About

BuckleScript bindings for glamor

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • OCaml 100.0%