🚀 Big News: Socket Acquires Coana to Bring Reachability Analysis to Every Appsec Team.Learn more
Socket
DemoInstallSign in
Socket

hepha

Package Overview
Dependencies
Maintainers
1
Versions
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

hepha

aphrodite's ugly husband for global styles

0.0.1
latest
Source
npm
Version published
Weekly downloads
0
-100%
Maintainers
1
Weekly downloads
 
Created
Source

Hepha

"aphrodite's ugly husband for global styles"

##Installation npm i -S hepha

What's it do

Allows you to write global inline styles (normalizers, resets, 3rd party css overrides)

aphrodite is a 2-part contract. It uses StyleShee.create to generate a unique, modular classname, and then css() to inject the styles and definitions into the DOM. That's what makes aphrodite beautiful.

Globals are ugly. They aren't unique. They are rarely !important.

...but they're necessary.

That's where Hepha comes in.

API

injectGlobals(injectStyleOnce, globalStyles)

Example

import {injectGlobals} from 'hepha';
import {injectStyleOnce} from 'aphrodite/lib/inject';
import {themeColors} from './myThemeColors';
const globalStyles = {
  html: {
    fontFamily: [
      {
        "fontFamily": "FontFoo",
        "fontWeight": 400,
        "fontStyle": "normal",
        "src": "url('data:application/octet-stream;base64,d09...') format('woff2')"
      },
      {
        "fontFamily": "FontFoo",
        "fontWeight": 400,
        "fontStyle": "italic",
        "src": "url('/static/fonts/foo.woff2') format('woff2')"
      }
    ]
  },
  '*': {
   boxSizing: 'border-box' 
  },
  'body #a0-namespace.a0-theme-default .a0-panel button.a0-primary': {
    backgroundColor: `${themeColors.warm} !important`
  }
};

const statelessComponent = (props) => {
  // it MUST go inside your component, just like `css()` 
  injectGlobals(injectStyleOnce, globalStyles);
  return <div>Foo</div>
}

How it works

Heaven forbid you read 11 lines of code.

Is it performant?

Aphrodite only injects to the DOM when necessary. Hepha only calls aphrodite once per object (so don't recreate your globalStyles object on rerender).

License

MIT

Keywords

aphrodite

FAQs

Package last updated on 03 Oct 2016

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts