Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pyncz/tailwind-mask-image
A `mask-image` plugin for TailwindCSS
https://github.com/pyncz/tailwind-mask-image
css css-utils mask-image plugin tailwind tailwindcss
Last synced: 3 months ago
JSON representation
A `mask-image` plugin for TailwindCSS
- Host: GitHub
- URL: https://github.com/pyncz/tailwind-mask-image
- Owner: pyncz
- License: mit
- Created: 2023-03-19T19:05:26.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2023-11-27T10:26:54.000Z (about 1 year ago)
- Last Synced: 2024-04-14T10:37:09.420Z (10 months ago)
- Topics: css, css-utils, mask-image, plugin, tailwind, tailwindcss
- Language: JavaScript
- Homepage: https://play.tailwindcss.com/szgRchW420
- Size: 1.16 MB
- Stars: 14
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# @pyncz/tailwind-mask-image
A `mask-image` plugin for [Tailwind CSS](https://tailwindcss.com).
[
](https://play.tailwindcss.com/szgRchW420)
---
# Install
Install the package with your preferred package-manager.
```
pnpm install @pyncz/tailwind-mask-image
```After that, simply add the plugin into your `tailwind.config.js`:
```js
// tailwind.config.js
module.exports = {
// ...
plugins: [
// ...
require('@pyncz/tailwind-mask-image')
],
}
```# Usage
## mask-image
There are 3 default values the `mask` utility can accept:
- `linear`
- `radial`
- `none`### `linear`
Applies a `linear-gradient` as the mask image. Opacity is set from 100% at the start to 0% at the end, by default.
```html
```
data:image/s3,"s3://crabby-images/ad979/ad97977a1b4c064b08ffbb6383782ef54d88641b" alt="mask-linear example"#### Direction `mask-dir`
By default, the gradient is [directed](https://developer.mozilla.org/en-US/docs/Web/CSS/gradient/linear-gradient#values) to bottom. You can easily customize the direction with `mask-dir` utility, including arbitrary values.
```html
```
data:image/s3,"s3://crabby-images/22fbc/22fbc0b5c22ec3beea941fcb7698fa42674e73a4" alt="mask-dir example"#### Opacity Stops
The `stops` API is similar to tailwind's [Gradient Color Stops](https://tailwindcss.com/docs/gradient-color-stops) core utils, so you can customize your linear mask in a familiar way.
**But!** An important difference is that here you should use not `colors` but `opacity` values.
The `opacity` values are taken from your theme specified in the `tailwind.config.js`, but you obviously can use arbitrary opacity values as well.
```html
```
data:image/s3,"s3://crabby-images/43422/4342233523e83b78daab0cabcea58d5e93d10ae1" alt="mask-linear stops' example"> **Note**
> You don't have to specify **all** the stops, because the default values (100% for the start and 0% for the end point) still work.##### Stops positions
In addition to setting the opacity of the stops, you can also set the **position** using `mask-point`.
```html
```
data:image/s3,"s3://crabby-images/c39cb/c39cb3e869bb8ebda82dcadf96a607a07a94fcae" alt="stops' points example"This utility don't accept any default value, so use arbitrary values.
### `radial`
Applies a `radial-gradient` as the mask image. Like for the `mask-linear` util, the gradient is spread from 100% opacity at the center to 0% at the ending shape.
```html
```
data:image/s3,"s3://crabby-images/ec8a9/ec8a9ee62657d0310b4fc2d41e20539d1bd8d24c" alt="mask-radial example"#### Shape `mask-shape`
[Shape](https://developer.mozilla.org/en-US/docs/Web/CSS/gradient/radial-gradient#values) of the gradient, `ellipse` (by default) or `circle`.
```html
```
data:image/s3,"s3://crabby-images/51edc/51edc6dfc794fb87ebabcb0034354abdb2adefd3" alt="mask-shape example"#### Position `mask-at`
By default, the gradient's position is `center`. You can use the same values as for the [`background-position` css prop](https://developer.mozilla.org/en-US/docs/Web/CSS/background-position#syntax) (`top`, `bottom left` etc), as well as arbitrary values with explicit position.
```html
```
data:image/s3,"s3://crabby-images/cbde2/cbde27f4da9630aefd4521ab50a3516d4c3b0f8a" alt="mask-at example"#### Reach `mask-reach`
With this util you can specify the size of the gradient.
```html
```
data:image/s3,"s3://crabby-images/ed1a4/ed1a412ab5bd42179de6c038ea7c116297615518" alt="mask-reach example"Besides *as-they-are* keyword-values, there are also a couple of aliases:
- `mask-reach-contain` for `closest-side`
- `mask-reach-cover` for `farthest-corner`You can also use arbitrary values:
```html
```
data:image/s3,"s3://crabby-images/c1674/c1674eb599da063fd10fc3e1fb933dff972f2b45" alt="example for mask-reach with arbitrary values"#### Stops
> **Note**
> The opacity stops for `mask-radial` are the same as [the ones described for `mask-linear`](#opacity-stops), including [points API](#stops-positions).```html
```
data:image/s3,"s3://crabby-images/e30f2/e30f2604a4084378773ad995ef67f02a31c0e517" alt="mask-radial stops' example"### `none`
This value matches `mask-image` css prop's default value so it makes no sense to use it *separately*, but it may be pretty useful if you apply the mask responsively.
```html
```
data:image/s3,"s3://crabby-images/e10fd/e10fd865db3e2cccd94b4415632922ed6c797c88" alt="mask-none example"### Arbitrary values
#### Images
The `mask-image` css prop accepts not only gradients but images as well. You can use arbitrary values, for example, to apply `url()` as the mask image.
```html
```
data:image/s3,"s3://crabby-images/acee7/acee74e8433baa32c3cb65aebf9e7ba9e2797147" alt="arbitrary mask image example"#### Gradients
You can pass other types of the gradients, e.g. `conic-gradient` etc.
```html
```
data:image/s3,"s3://crabby-images/94859/948594fc3a8a61d5c91876a08a90326673fa7482" alt="arbitrary conic-gradient mask example"Also, you may want not to use the API above even for `linear-gradient` or `radial-gradient` so you can pass them arbitrarily too.
```html
```## mask-size
```html
```
data:image/s3,"s3://crabby-images/0e797/0e79761c5117038d6ff9341c3ff5f2b0a9a19fb8" alt="mask size example"## mask-position
```html
```
data:image/s3,"s3://crabby-images/894da/894da9ea2ddc2f02507cf19aed3dd366c6cbda5c" alt="mask position example"## mask-repeat
You can manage the [`mask-repeat` css property](https://developer.mozilla.org/en-US/docs/Web/CSS/mask-repeat) as well with the following utilities:
- `mask-repeat`
- `mask-repeat-x`
- `mask-repeat-y`
- `mask-repeat-space`
- `mask-repeat-round`
- `mask-no-repeat````html
```
data:image/s3,"s3://crabby-images/662bd/662bd4d16738d8178bc6bc6093d2846ec6305585" alt="mask-repeat example"