Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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
- Host: GitHub
- URL: https://github.com/yaireo/ui-range
- Owner: yairEO
- License: mit
- Created: 2020-10-26T15:30:53.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2022-02-07T07:57:39.000Z (almost 3 years ago)
- Last Synced: 2024-12-06T17:48:34.899Z (about 2 months ago)
- Topics: component, input, range, ui, web
- Language: SCSS
- Homepage:
- Size: 697 KB
- Stars: 105
- Watchers: 6
- Forks: 11
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
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` | |