Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/ufologist/postcss-hairline

transform your border to retina hairline
https://github.com/ufologist/postcss-hairline

1px hairline retina

Last synced: about 1 month ago
JSON representation

transform your border to retina hairline

Awesome Lists containing this project

README

        

# postcss-hairline

[![NPM version][npm-image]][npm-url] [![Build Status][ci-status-image]][ci-status-url] [![Coverage Status][coverage-status-image]][coverage-status-url] [![Known Vulnerabilities][vulnerabilities-status-image]][vulnerabilities-status-url] [![changelog][changelog-image]][changelog-url] [![license][license-image]][license-url]

[vulnerabilities-status-image]: https://snyk.io/test/npm/postcss-hairline/badge.svg
[vulnerabilities-status-url]: https://snyk.io/test/npm/postcss-hairline
[ci-status-image]: https://travis-ci.org/ufologist/postcss-hairline.svg?branch=master
[ci-status-url]: https://travis-ci.org/ufologist/postcss-hairline
[coverage-status-image]: https://coveralls.io/repos/github/ufologist/postcss-hairline/badge.svg?branch=master
[coverage-status-url]: https://coveralls.io/github/ufologist/postcss-hairline
[npm-image]: https://img.shields.io/npm/v/postcss-hairline.svg?style=flat-square
[npm-url]: https://npmjs.org/package/postcss-hairline
[license-image]: https://img.shields.io/github/license/ufologist/postcss-hairline.svg
[license-url]: https://github.com/ufologist/postcss-hairline/blob/master/LICENSE
[changelog-image]: https://img.shields.io/badge/CHANGE-LOG-blue.svg?style=flat-square
[changelog-url]: https://github.com/ufologist/postcss-hairline/blob/master/CHANGELOG.md

[![npm-image](https://nodei.co/npm/postcss-hairline.png?downloads=true&downloadRank=true&stars=true)](https://npmjs.com/package/postcss-hairline)

PostCSS plugin for transform your border to retina [hairline](https://github.com/ufologist/hairline).

## Example

before:

```css
.foo {
color: white;
border: 1px solid red; /* hairline */
border-radius: 20px; /* hairline */
}
```

after:

```css
.foo {
color: white;
border-radius: 10px; /* no */
position: relative;
}

.foo::after {
border: 1px solid red; /* no */
border-radius: 20px; /* no */
}

.foo::after {
content: '';
position: absolute;
top: -50%;
bottom: -50%;
left: -50%;
right: -50%;
-webkit-transform: scale(0.5);
transform: scale(0.5);
pointer-events: none;
}
```

## Usage

1. install plugin

```
npm install --save-dev postcss-hairline
```

2. code `border` or `border-radius` style as usual

```css
.foo {
color: white;
border: 1px solid red;
border-radius: 20px;
}
```

3. add `/* hairline */` comment

```css
.foo {
color: white;
border: 1px solid red; /* hairline */
border-radius: 20px; /* hairline */
}
```

support comment
* `/* hairline */` default create `::after` pseudo style
* `/* hairline-before */` specify create `::before` pseudo style
* `/* hairline-after */` specify create `::after` pseudo style

4. use plugin

```
postcss([
require('postcss-hairline')
]);
```

[PostCSS plugin usage](https://github.com/postcss/autoprefixer#usage)

## Options

```javascript
require('postcss-hairline')({
pxComment: 'no'
})
```

Available options are:
* `pxComment` (string): border px unit comment. Default: `no`.

## Reference

* [postcss-retina](https://github.com/Ziphwy/postcss-retina)