๐ข Progress
Features
- Provides context for assistive technology to read the progress of a task.
- Adheres to the
progressbar
role requirements.
Basic
use NProgress
to display a progress bar.
Color
progress="{color}"
- change the color of the progress.
You can use any color provided by the Tailwind CSS color palette, the default is
primary
. You can also add your own colors to the palette through the Configuration section.Indeterminate
By not providing a modeValue
prop, the progress will be indeterminate. This means that the progress will be animated without a specific value.
Size
size="{size}"
- change the size of the progress.
๐ You can freely adjust the size of the progress using any size imaginable. No limits exist, and you can use
breakpoints
such assm:sm, xs:lg
to change size based on screen size orstates
such ashover:lg, focus:3xl
to change size based on input state and more.
The
height
and width
of the progress scale depends on the progress-size
. If you want to change the height
and width
simultaneously, you can always customize it using utility classes.Customization
You can customize the progress using the
una
prop and utility classes.
You can also globally customize the progress preset if you want to have a different default style. See Configuration section for more details.
Slots
You can use the following slots to customize the progress.
Name | Description | Props |
---|---|---|
default | The progress indicator. | - |
Props
import type { ProgressRootProps } from 'radix-vue'
import type { HTMLAttributes } from 'vue'
type Extensions = ProgressRootProps & { class?: HTMLAttributes['class'] }
export interface NProgressProps extends Extensions {
/**
* Allows you to add `UnaUI` progress preset properties,
* Think of it as a shortcut for adding options or variants to the preset if available.
*
* @see https://github.com/una-ui/una-ui/blob/main/packages/preset/src/_shortcuts/progress.ts
* @example
* progress="red""
*/
progress?: string
/**
* Allows you to change the size of the progress.
*
* @default base|md
*
* @example
* size="sm" | size="2cm" | size="2rem" | size="2px"
*/
size?: string
/**
* `UnaUI` preset configuration
*
* @see https://github.com/una-ui/una-ui/blob/main/packages/preset/src/_shortcuts/progress.ts
*/
una?: {
// components
progressRoot?: HTMLAttributes['class']
progressIndicator?: HTMLAttributes['class']
}
}
Presets
import type { RuleContext } from '@unocss/core'
import type { Theme } from '@unocss/preset-uno'
import { parseColor } from '@unocss/preset-mini/utils'
type ProgressPrefix = 'progress'
export const staticProgress: Record<`${ProgressPrefix}-${string}` | ProgressPrefix, string> = {
// configurations
'progress': 'progress-primary',
// components
'progress-root': 'progress relative h-0.5em w-full overflow-hidden rounded-full bg-muted',
'progress-indicator': 'h-full w-full flex-1 bg-brand transition-all',
'progress-indeterminate': 'absolute bg-brand h-full',
}
export const dynamicProgress = [
[/^progress-(.*)$/, ([, body]: string[], { theme }: RuleContext<Theme>) => {
const color = parseColor(body, theme)
if ((color?.cssColor?.type === 'rgb' || color?.cssColor?.type === 'rgba') && color.cssColor.components)
return `n-${body}-600 dark:n-${body}-500`
}],
]
export const progress = [
...dynamicProgress,
staticProgress,
]
Component
<script setup lang="ts">
import type { NProgressProps } from '../../types'
import {
ProgressIndicator,
ProgressRoot,
} from 'radix-vue'
import { computed } from 'vue'
import { cn } from '../../utils'
const props = withDefaults(
defineProps<NProgressProps>(),
{
},
)
const delegatedProps = computed(() => {
const { class: _, ...delegated } = props
return delegated
})
</script>
<template>
<ProgressRoot
v-bind="delegatedProps"
:class="
cn(
'progress-root',
props.una?.progressRoot,
props.class,
)
"
>
<slot>
<ProgressIndicator
v-if="props.modelValue !== undefined || props.modelValue === null"
:class="cn(
'progress-indicator',
props.una?.progressIndicator,
)"
:style="`transform: translateX(-${100 - (props.modelValue ?? 0)}%);`"
/>
<template
v-else
>
<ProgressIndicator
:class="cn(
'increase progress-indeterminate',
props.una?.progressIndicator,
)"
/>
<ProgressIndicator
:class="cn(
'decrease progress-indeterminate',
props.una?.progressIndicator,
)"
/>
</template>
</slot>
</ProgressRoot>
</template>
<style scoped>
.increase.progress-indeterminate {
animation: progress-increase 2s ease-in-out infinite;
}
.decrease.progress-indeterminate {
animation: progress-indeterminate-decrease 2s 0.9s ease-in-out infinite;
}
@keyframes progress-decrease {
0% {
left: -90%;
width: 90%;
}
100% {
left: 110%;
width: 10%;
}
}
@keyframes progress-increase {
0% {
left: -5%;
width: 5%;
}
100% {
left: 130%;
width: 150%;
}
}
</style>