Vue-ldemort is a headless component for Vue 3 which helps you to create wizards in your own way, handling navigation implementation for you. It's inspired by the react-albus component library.
npm i vue-ldemort
- KWizard. The root wrapper.
- KSteps. Wrapper for pages. Accepts only KStep components as childs.
- KStep. Wrapper for a page. Has a required
id
prop.
The top node of each of these components is a div
, so you can
freely style them whatever you like.
<script setup lang="ts">
import { KWizard, KSteps, KStep, WizardState } from 'vue-ldemort'
</script>
<template>
<KWizard cycled v-slot="{context}">
<h2> Wizard demo </h2>
<KSteps>
<KStep id="1">
Step one
</KStep>
<KStep id="2">
Step two
</KStep>
<KStep id="3">
Step three
</KStep>
</KSteps>
<button @click="context.prevStep()"> Prev page </button>
<button @click="context.nextStep()"> Next page </button>
<button @click="context.setStep('2')"> Go to the second page </button>
</KWizard>
</template>
KWizard
exposes a WizardState
object via a scoped slot. This object implements
basic navigation functions:
export interface WizardState {
/*
* Array of step's ids
*/
steps: Ref<string[]>
/**
* currently active step
*/
currentStep: Ref<string | undefined>,
/**
* Sets current page
*/
setStep(id: string): void
/**
* Go to next slide
*/
nextStep(): void
/**
* Go to prev slide
*/
prevStep(): void
}