* refactor: eslint config adjusted for better diff's * refactor: stricter linting + dependencies updated * refactoring: paragraph component - component - docs * refactoring: heading component - component - docs * Update docs/components/heading.md Co-authored-by: Ilya Artamonov <ilya.sosidka@gmail.com> * refactoring: link component - component - docs * refactoring: image component - component - docs * refactoring: alert component - component - docs * refactoring: avatar component - component - docs * refactoring: removed unnecessary code - component names come from the file name * refactoring: breadcrumb component - component - docs * refactoring: accordion component - component - docs * refactoring: buttom component - component - docs * refactoring: badge component - component - docs * refactoring: card component - component - docs * refactoring: order of components in docs updated * refactoring: unnecessary semicolons removed * refactoring: button group component - component - docs * refactoring: carousel component - component - docs * refactoring: dropdown component - component - docs * refactoring: footer component - component - docs * refactoring:list-group component - component - docs * refactoring: modal component - component - docs * refactoring: navbar component - component - docs * refactoring: pagination component - component - docs * refactoring: progress component - component - docs * refactoring: rating component - component - docs * refactoring: spinner component - component - docs * refactoring: table component - component - docs * refactoring: tabs component - component - docs * feat: Updated pagination examples * lint: Lister fixes * feat: Sidebar component and some fixes * feat: Input component * feat: Some fixes * feat: Some fixes * chore: update deps * refactor: removed old Modal component * refactor: radio component and some fixes * fix: fixed path error * refactor: Range component * refactoring: timeline component - component - docs * refactor: Select component * refactoring: toast component - component - docs * refactoring: tooltip component - component - docs * refactoring: sidebar component - component - docs * refactoring: input component - component - docs * refactoring: fileInput component - component - docs * refactoring: select component - component - docs * refactoring: textarea component - component - docs * refactoring: checkbox component - component - docs * refactoring: radio component - component - docs * refactoring: toggle component - component - docs * refactoring: range component - component - docs * local configs linted * documentation quick start updated * flowbite-themable refactored to fit new linters and style guide * random linter fixes * refactoring: toast-provider component - component - docs * final linter fixes * lint: Linter fixes * fix: Fixed types * fix: Fixed card component * docs: Updated card examples * fix: Fixed tabs * refactor: Heading component refactoring * Fwb rename - few fixes after component review (#237) * fix: button documentation * fix: model type in range examples * chore: Toast marked as WIP --------- Co-authored-by: Sqrcz <naorniakowski@slashlab.pl> Co-authored-by: Sqrcz <naorniakowski@gmail.com>
67 lines
1.2 KiB
Vue
67 lines
1.2 KiB
Vue
<template>
|
|
<label class="flex flex-col">
|
|
<span
|
|
:class="labelClasses"
|
|
>{{ label }}</span>
|
|
<input
|
|
v-model="model"
|
|
:step="steps"
|
|
:min="min"
|
|
:max="max"
|
|
:disabled="disabled"
|
|
type="range"
|
|
:class="rangeClasses"
|
|
>
|
|
</label>
|
|
</template>
|
|
|
|
<script lang="ts" setup>
|
|
import { computed, toRefs } from 'vue'
|
|
import { useRangeClasses } from './composables/useRangeClasses'
|
|
import type { InputSize } from '@/components/FwbInput/types'
|
|
|
|
interface RangeProps {
|
|
disabled?: boolean
|
|
label?: string
|
|
max?: number
|
|
min?: number
|
|
modelValue?: number
|
|
size?: InputSize
|
|
steps?: number
|
|
}
|
|
|
|
const props = withDefaults(defineProps<RangeProps>(), {
|
|
disabled: false,
|
|
label: 'Range slider',
|
|
max: 100,
|
|
min: 0,
|
|
modelValue: 50,
|
|
size: 'md',
|
|
steps: 1,
|
|
})
|
|
|
|
const emit = defineEmits(['update:modelValue'])
|
|
|
|
const model = computed({
|
|
get () {
|
|
return props.modelValue
|
|
},
|
|
set (val) {
|
|
emit('update:modelValue', val)
|
|
},
|
|
})
|
|
|
|
const { rangeClasses, labelClasses } = useRangeClasses(toRefs(props))
|
|
</script>
|
|
|
|
<style scoped>
|
|
input[type="range"].range-lg::-moz-range-thumb {
|
|
height: 1.5rem;
|
|
width: 1.5rem;
|
|
}
|
|
input[type="range"].range-sm::-moz-range-thumb {
|
|
height: 1rem;
|
|
width: 1rem;
|
|
}
|
|
</style>
|