Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/StevenIseki/deku-css-modules
mapping of class names to CSS modules inside Deku components
https://github.com/StevenIseki/deku-css-modules
Last synced: 17 days ago
JSON representation
mapping of class names to CSS modules inside Deku components
- Host: GitHub
- URL: https://github.com/StevenIseki/deku-css-modules
- Owner: svnm
- Created: 2015-11-25T10:40:41.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2016-11-03T03:45:38.000Z (about 8 years ago)
- Last Synced: 2024-05-18T21:42:39.608Z (8 months ago)
- Language: JavaScript
- Size: 79.1 KB
- Stars: 8
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-deku - deku-css-modules - mapping of class names to CSS modules inside Deku components. (Components)
README
# deku-css-modules
[![npm version](https://badge.fury.io/js/deku-css-modules.svg)](https://badge.fury.io/js/deku-css-modules)
Mapping of class names to CSS modules in Deku components
## CSS Modules
[CSS Modules](https://github.com/css-modules/css-modules) uses a module bundler such as [webpack](http://webpack.github.io/docs/) to load CSS scoped to a particular document.
CSS module loader will generate a unique name for a each CSS class at the time of loading the CSS document
CSS Modules with Deku looks like this:
```js
/** @jsx element */
import { element } from 'deku';
import styles from './table.css';let Table = {
render () {
return;
A0
}
}
```Rendering the component will produce a markup similar to:
```js
A0
```and a corresponding CSS file that matches those CSS classes... Awesome!
### deku-css-modules
Similar to [React CSS Modules](https://github.com/gajus/react-css-modules), Deku CSS Modules automates loading of CSS Modules using the `styleName` property.
Check out the [deku-webpack-example](https://github.com/StevenIseki/deku-webpack-example)
```js
/** @jsx element */import { element } from 'deku';
import CSSModules from 'deku-css-modules.js';
import styles from './table.css';const Table = function () {
return (
A0
)
}export default CSSModules(Table, styles);
```
Benefits of using `deku-css-modules`:
* You are not forced to use `camelCase` naming convention.
* You do not need to refer to the `styles` object every time you use a CSS Module.
* There is clear distinction between global CSS `class` and CSS Modules `styleName`## Implementation
`deku-css-modules` extends the `render` method of the target component. It uses the value of `styleName` to look for CSS Modules in the associated styles object and appends the matching unique CSS class names to each `Element`s `className` property value.
## Usage
* Set up a [module bundler](#modulebundler) to load the [Interoperable CSS](https://github.com/css-modules/icss).
* Configure the render method of your component to use `deku-css-modules`### Bundlers
#### webpack
* Install [`style-loader`](https://www.npmjs.com/package/style-loader) and [`css-loader`](https://www.npmjs.com/package/css-loader)
* Use [`extract-text-webpack-plugin`](https://www.npmjs.com/package/extract-text-webpack-plugin) to aggregate the CSS into a single file
* Setup your `/\.css$/` loaderCheck out the example [deku-webpack-example](https://github.com/StevenIseki/deku-webpack-example)
### Extending Component StylesUse `styles` property to overwrite the default component styles.
Explanation using `Table` component:
```js
/** @jsx element */
import { element } from 'deku';
import CSSModules from 'deku-css-modules.js';
import styles from './table.css';const Table = function () {
return (
A0
)
}export default CSSModules(Table, styles);
```In this example, `CSSModules` is used to decorate `Table` component using `./table.css` CSS Modules. When `Table` component is rendered, it will use the properties of the `styles` object to construct `className` values.
Using `styles` property you can overwrite the default component `styles` object, e.g.
```js
import customStyles from './table-custom-styles.css';;
```
[Interoperable CSS](https://github.com/css-modules/icss) can [extend other ICSS](https://github.com/css-modules/css-modules#dependencies). Use this feature to extend default styles, e.g.```css
/* table-custom-styles.css */
.table {
composes: table from './table.css';
}.row {
composes: row from './table.css';
}/* .cell {
composes: cell from './table.css';
} */.table {
width: 400px;
}.cell {
float: left; width: 154px; background: #eee; padding: 10px; margin: 10px 0 10px 10px;
}
```In this example, `table-custom-styles.css` selectively extends `table.css` (the default styles of `Table` component).
Refer to the [`UsingStylesProperty` example](https://github.com/gajus/react-css-modules-examples/tree/master/src/UsingStylesProperty) for an example of a working implementation.
### `styles` Property
Decorated components inherit `styles` property that describes the mapping between CSS modules and CSS classes.
```js
const render = ({props}) => {
;
}
```In the above example, `styleName='foo'` and `class={this.props.styles.foo}` are equivalent.
### Decorator
You need to decorate your component using `deku-css-modules`, e.g.```js
/** @jsx element **/
import { element } from 'deku';
import CSSModules from 'deku-css-modules.js';
import styles from './table.css';const Table = function () {
return (
A0
)
}export default CSSModules(Table, styles);
```Thats it!
As the name implies, `deku-css-modules` is compatible with the [ES7 decorators](https://github.com/wycats/javascript-decorators) syntax:
```js
/** @jsx element **/
import { element } from 'deku';
import CSSModules from 'deku-css-modules.js';
import styles from './table.css';export default {
@CSSModules(styles)
render: () => {
return (
A0
)
},
onCreate: () => {
console.log('A MyComponent entity was created!')
}
}
```#### Browserify
Refer to [`css-modulesify`](https://github.com/css-modules/css-modulesify).
## Development
npm install
npm run build
npm test
npm start## License
[MIT](http://isekivacenz.mit-license.org/)