Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/itsjonq/styled-providers

✨ Handy Providers for Emotion / Styled Components
https://github.com/itsjonq/styled-providers

emotion providers react styled styled-components

Last synced: 3 months ago
JSON representation

✨ Handy Providers for Emotion / Styled Components

Awesome Lists containing this project

README

        

# ✨ Styled Providers

[![Build Status](https://travis-ci.org/ItsJonQ/styled-providers.svg?branch=master)](https://travis-ci.org/ItsJonQ/styled-providers)

> Handy Providers for Emotion / Styled Components

- [Installation](#installation)
- [Requirements](#requirements)
- [Usage](#usage)
- [Emotion](#emotion)
- [Styled Components](#styled-components)
- [Components](#components)
- [FrameProvider](#frameprovider)
- [ScopeProvider](#scopeprovider)

## Installation

```
npm install --save styled-providers
```

## Requirements

- [React v16.8.0+](https://reactjs.org/blog/2019/02/06/react-v16.8.0.html)
- [Emotion v10+](https://emotion.sh/docs/migrating-to-emotion-10) **or** [Styled Components v5+](https://medium.com/styled-components/announcing-styled-components-v5-beast-mode-389747abd987)

## Usage

[Emotion](https://emotion.sh/) and [Styled Components](https://www.styled-components.com/) are supported.

### Emotion

```jsx
import React from "react";
import styled from "@emotion/styled";
import { ScopeProvider } from "styled-providers/emotion";

const View = styled.div`
background: blue;
`;

const App = () => {
return (






);
};
```

### Styled Components

```jsx
import React from "react";
import styled from "styled-components";
import { ScopeProvider } from "styled-providers/styled-components";

const View = styled.div`
background: blue;
`;

const App = () => {
return (






);
};
```

## Components

### FrameProvider

Provides the correct document.head to mount the `` tag for either Emotion or Styled Components. This is necessary when rendering CSS-in-JS generated styles within elements like iFrames on runtime.

##### Example

```jsx
import React from "react";
import styled from "@emotion/styled";
import { FrameProvider } from "styled-providers/emotion";
import Frame from "react-frame-component";

const View = styled.div`
background: blue;
`;

const App = () => {
return (
<Frame>
<FrameProvider>
<View />
</FrameProvider>
</Frame>
);
};
```

### ScopeProvider

Provides a scope to prefix before generated classNames for either Emotion or Styled Components. Prefixing increases specificity, allowing for smoother integrations with pre-existing CSS rules.

##### Example

```jsx
import React from "react";
import styled from "@emotion/styled";
import { ScopeProvider } from "styled-providers/emotion";

const View = styled.div`
background: blue;
`;

const App = () => {
return (
<div id="#app">
<ScopeProvider scope="html #app">
<View />
</ScopeProvider>
</div>
);
};
```

In the above example, rendered selectors (e.g. `.css-123jda`) will be prefixed with `html #app`, resulting in selectors like `html #app .css-123jda`)