Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/yaireo/ui-range

Beautiful UI-Range input component, highly customisable, based on CSS variables. including a floating output value, min & max values on the sides & ticks according to the steps
https://github.com/yaireo/ui-range

component input range ui web

Last synced: about 2 months ago
JSON representation

Beautiful UI-Range input component, highly customisable, based on CSS variables. including a floating output value, min & max values on the sides & ticks according to the steps

Awesome Lists containing this project

README

        


















UI-Range



CSS-Only Custom & Flexible<input type='range'>


👉 Demos: Codepen 👈

---

A *CSS-only* component which is designed to work along-side the *corresponding **markup*** (examples below).
This code here is designed to bring *customizabiilty* to the **maximum** for the `range` input element,
extending the **very basic** `` native browser component, infusing it with extra features.

## Features:

* Extensive [CSS variables](https://github.com/yairEO/ui-range/blob/master/ui-range.scss#L2-L34) usage = *Much easier* customization:
* Track height, color, gradient
* Progress color/gradient
* Progress shadow
* Thumb size, color & shadow
* Ticks (per step) height, color, width, position, offset
* Ticks count limit (30)
* Ticks skipping (Prints tick every *N* tick)
* Value text color when "active" (component *hover*)
* Value background color
* Cursor for hover & grabbing
* *RTL* (right-to-left) support via `dir=rtl` attribute
* Value is printed by default at all times
* Value supports *prefix* and/or *suffix*
* Minimum & maximum values are printed at the edges
* Ticks are printed on each step, or every N step
* Ticks automatically hidden if too many (too dense to be helpful)

In addition to all the root variables, a helper variable `--is-left-most` exists on the `` element itself,
which can be helpful if it is desirable to visually distingush between left/right thumbs of a multi-range slider.

⚠️`--min` & `--max` variables' values should be kept as *integers* (not *floating-point*) because a [CSS trick](https://stackoverflow.com/a/40179718/104380)
using counters is used to print the values in a pseudo-element, and it only works for integers.

---

I must say that CSS is not yet good enough to make this code much cleaner. I had to rely on repeating the input's attributes in its parent node, as CSS style variables, because CSS is currently unable to [extrapolate attibutes as variables](https://github.com/w3c/csswg-drafts/issues/4482).

Even if the above was possible, still, it would require passing varables from one sibling to another, or to a parent.

The `` element has all the information needed, but the `oninput` event is needed to keep things in-sync for the CSS to be "aware".

`--text-value` is needed along-side `--value` due to CSS inability to cast variables types. Technically
it is possible with new [Houdini](https://developer.mozilla.org/en-US/docs/Web/Houdini), but it's not yet a norm in modern-browsers.

---

I intentionallyl did not use the native `` element, since it wasn't flexible enough (especially not cross-browser). Using `

` instead.

## Install:

```
npm i @yaireo/ui-range
```

## Usage:

Import CSS file via JS

```js
import '@yaireo/ui-range'
```

Or via CSS [`@import`](https://stackoverflow.com/q/10036977/104380)

```css
@import '@yaireo/ui-range'
```

For the SCSS version, use this path:

@yaireo/ui-range/ui-range.scss

### Markup Example (single range):

```html






```

### Markup Example (double range):

```html








```

## CSS Variables

| CSS Variable | Default | Description |
|--------------------------|-------------------------|-----------------------------------------------------------------------|
| --thumb-size | `22px` | The thumb arear which is used for grabbing the slider and moving |
| --value-active-color | `white` | *value* text color when the slider is active/hovered |
| --value-background | `transparent` | |
| --value-background-hover | `--primary-color` | |
| --primary-color | `#0366d6` | The main color of the component |
| --value-offset-y | `--ticks-gap` | Vertical distance of the current numerical value from the slider |
| --track-height | `--thumb-size / 2` | |
| --progress-radius | `20px` | Border radius of the slider |
| --fill-color | `--primary-color` | |
| --show-min-max | | `none` to hide the *min/max* values at the edges |
| --ticks-thickness | `1px` | How wide each *tick* line is |
| --ticks-height | `5px` | How tall each *tick* line is |
| --ticks-gap | `var(--ticks-height,0)` | Vertical gap between the ticks and the slider |
| --min-max-x-offset | `10%` | Horizontal offset of *min/max* values (more to the inside or outside) |
| --min-max-opacity | `0.5` | |
| --ticks-color | `silver` | |