<h1 style="display: flex; justify-content: space-between; align-items: center;">
  🔥 Vue 3 Slider 🔥 
  <a style="color: #EA005E; text-decoration: underline; font-size: 28px;" href="https://github.com/freddie-nelson/vue3-slider/stargazers">Become a Stargazer</a>
</h1>

**Horizontal, vertical and circular sliders!**
**Fully responsive, touch screen and keyboard control support!**

## Table of Contents 📰

- [Demo](#demo)
- [Installation](#installation)
- [Getting Started](#getting-started)
  - [Import Component](#import-component)
  - [How to use](#how-to-use)
- [License](#license)
- [Contact](#contact)

## Demo [(Live Demo)](https://freddie-nelson.github.io/vue3-slider/)

![Demo](https://raw.githubusercontent.com/freddie-nelson/vue3-slider/main/demo.gif)

## Installation

```bash
# with npm
npm install vue3-slider
```

```bash
# with yarn
yarn add vue3-slider
```

## Getting Started 👍

### Import component

```js
import slider from "vue3-slider"

export default {
  ...
  components: {
    "vue3-slider": slider
  }
  ...
}
```

### How to use

```html
<vue3-slider v-model="myNumber" color="#FB278D" track-color="#FEFEFE" />
```

## Props

| Name              | Type     | Required | Default    | Rules                                                         |
| ----------------- | -------- | -------- | ---------- | ------------------------------------------------------------- |
| v-model           | Number   | ✔️       |            |                                                               |
| width             | String   |          | 100%       | must be valid css length                                      |
| height            | Number   |          | 6          |                                                               |
| handleScale       | Number   |          | 1.35       |                                                               |
| handleColor       | String   |          |            | When empty this will take the value of color                  |
| alwaysShowHandle  | Boolean  |          | false      |                                                               |
| color             | String   |          | #FB2727    | must be a valid hex, rgb, rgba or html color value            |
| trackColor        | String   |          | #F1F6F8    | ^^^                                                           |
| max               | Number   |          | 100        | cannot be less than min                                       |
| min               | Number   |          | 0          | cannot be greater than max                                    |
| limit             | Number   |          |            |                                                               |
| step              | Number   |          | 1          |                                                               |
| customSliderSteps | Number[] |          | undefined  |                                                               |
| tooltip           | Boolean  |          | false      |                                                               |
| tooltipText       | String   |          | "%v"       | must contain %v (%v is replaced with slider's value)          |
| tooltipColor      | String   |          | #FFFFFF    | must be a valid hex, rgb, rgba or html color value            |
| tooltipTextColor  | String   |          | #000000    | ^^^                                                           |
| formatTooltip     | Function |          | null       | function must take one parameter (number) and return a string |
| flipTooltip       | Boolean  |          | false      |                                                               |
| tooltipStyles     | Object   |          |            | Should be a valid vue style object                            |
| orientation       | String   |          | horizontal | restricted choice (horizontal, vertical, circular)            |
| repeat            | Boolean  |          | false      |                                                               |
| sticky            | Boolean  |          | false      |                                                               |
| flip              | Boolean  |          | false      |                                                               |
| circleOffset      | Number   |          | 0          | must be between 0 and 360 (inclusive)                         |
| circleGap         | Number   |          | 0          | must be between 0 and 360                                     |

**NOTE: When using the circular slider width is the diameter of the circle and height is the stroke width**

**NOTE: When using the circular slider it is advised to use absolute units for width to avoid issues**

**NOTE: circleOffset is calculated in degrees clockwise from the top of the circle (anti-clockwise with flip set to true)**

## Events

#### change

- Arguments: `(value: number)`
- Usage: The event is fired when the slider value changes

#### drag-start

- Arguments: `(value: number, event: MouseEvent | TouchEvent)`
- Usage: The event is fired when the user presses the slider

#### drag-end

- Arguments: `(value: number, event: MouseEvent | TouchEvent)`
- Usage: The event is fired when the user releases the slider

#### dragging

- Arguments: `(value: number, event: MouseEvent | TouchEvent)`
- Usage: The event is fired when the user drags the slider

## Contributing

### Prerequisites

- node (latest version)
- yarn (1.^22.10)

### Setup

```bash
# clone repo
git clone https://github.com/freddie-nelson/vue3-slider
cd vue3-slider

# install deps
npm i
# with yarn
yarn

# start dev server
npm run serve
# with yarn
yarn serve
```

## License

[MIT](https://opensource.org/licenses/MIT)

Copyright © 2020 - Present, Freddie Nelson

## Contact

- [Send me an email 📧](mailto:freddie@freddienelson.co.uk)
- [Contact me through my website](https://freddienelson.co.uk)
