Jose Olarte III
8 months ago
1 changed files with 104 additions and 0 deletions
@ -0,0 +1,104 @@ |
|||||
|
<template> |
||||
|
<div> |
||||
|
<VOnboardingWrapper ref="wrapper" :steps="steps"> |
||||
|
<template #default="{ previous, next, step, exit, isFirst, isLast, index }"> |
||||
|
<VOnboardingStep> |
||||
|
<div class="bg-white shadow sm:rounded-lg"> |
||||
|
<div class="px-4 py-5 sm:p-6"> |
||||
|
<div class="sm:flex sm:items-center sm:justify-between"> |
||||
|
<div v-if="step.content"> |
||||
|
<h3 v-if="step.content.title" class="text-lg font-medium leading-6 text-gray-900">{{ step.content.title }}</h3> |
||||
|
<div v-if="step.content.description" class="mt-2 max-w-xl text-sm text-gray-500"> |
||||
|
<p>{{ step.content.description }}</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
<div class="mt-5 space-x-4 sm:mt-0 sm:ml-6 sm:flex sm:flex-shrink-0 sm:items-center relative"> |
||||
|
<span class="absolute right-0 bottom-full mb-2 mr-2 text-gray-600 font-medium text-xs">{{ `${index + 1}/${steps.length}` }}</span> |
||||
|
<template v-if="!isFirst"> |
||||
|
<button @click="previous" type="button" class="inline-flex items-center justify-center rounded-md border border-transparent bg-yellow-100 px-4 py-2 font-medium text-yellow-700 hover:bg-yellow-200 focus:outline-none focus:ring-2 focus:ring-yellow-500 focus:ring-offset-2 sm:text-sm">Previous</button> |
||||
|
</template> |
||||
|
<button @click="next" type="button" class="inline-flex items-center rounded-md border border-transparent bg-indigo-600 px-4 py-2 font-medium text-white shadow-sm hover:bg-indigo-700 focus:outline-none focus:ring-2 focus:ring-indigo-500 focus:ring-offset-2 sm:text-sm">{{ isLast ? 'Finish' : 'Next' }}</button> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</div> |
||||
|
</VOnboardingStep> |
||||
|
</template> |
||||
|
</VOnboardingWrapper> |
||||
|
<span id="foo">Howdy, My Friend!</span> |
||||
|
<button id="bar">Click me for no reason</button> |
||||
|
<button @click="() => goToStep(1)">Click to go second step</button> |
||||
|
<div> |
||||
|
<button @click="start">Start Onboarding</button> |
||||
|
<button @click="finish">Finish Onboarding</button> |
||||
|
</div> |
||||
|
</div> |
||||
|
</template> |
||||
|
|
||||
|
<script> |
||||
|
import { defineComponent, ref } from 'vue' |
||||
|
import { VOnboardingWrapper, VOnboardingStep, useVOnboarding } from 'v-onboarding' |
||||
|
export default defineComponent ({ |
||||
|
components: { |
||||
|
VOnboardingWrapper, |
||||
|
VOnboardingStep |
||||
|
}, |
||||
|
setup() { |
||||
|
const wrapper = ref(null) |
||||
|
const { start, goToStep, finish } = useVOnboarding(wrapper) |
||||
|
const steps = [ |
||||
|
{ |
||||
|
attachTo: { element: '#foo' }, |
||||
|
content: { title: "Welcome!" } |
||||
|
}, |
||||
|
{ |
||||
|
attachTo: { element: '#bar' }, |
||||
|
content: { |
||||
|
title: "Testing v-onboarding..", |
||||
|
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation." |
||||
|
} |
||||
|
} |
||||
|
] |
||||
|
|
||||
|
return { |
||||
|
wrapper, |
||||
|
steps, |
||||
|
start, |
||||
|
finish, |
||||
|
goToStep |
||||
|
} |
||||
|
} |
||||
|
}) |
||||
|
</script> |
||||
|
<style> |
||||
|
[data-v-onboarding-wrapper] [data-popper-arrow]::before { |
||||
|
content: ''; |
||||
|
background: var(--v-onboarding-step-arrow-background, white); |
||||
|
top: 0; |
||||
|
left: 0; |
||||
|
transition: transform 0.2s ease-out,visibility 0.2s ease-out; |
||||
|
visibility: visible; |
||||
|
transform: translateX(0px) rotate(45deg); |
||||
|
transform-origin: center; |
||||
|
width: var(--v-onboarding-step-arrow-size, 10px); |
||||
|
height: var(--v-onboarding-step-arrow-size, 10px); |
||||
|
position: absolute; |
||||
|
z-index: -1; |
||||
|
} |
||||
|
|
||||
|
[data-v-onboarding-wrapper] [data-popper-placement^='top'] > [data-popper-arrow] { |
||||
|
bottom: 5px; |
||||
|
} |
||||
|
|
||||
|
[data-v-onboarding-wrapper] [data-popper-placement^='right'] > [data-popper-arrow] { |
||||
|
left: -4px; |
||||
|
} |
||||
|
|
||||
|
[data-v-onboarding-wrapper] [data-popper-placement^='bottom'] > [data-popper-arrow] { |
||||
|
top: -4px; |
||||
|
} |
||||
|
|
||||
|
[data-v-onboarding-wrapper] [data-popper-placement^='left'] > [data-popper-arrow] { |
||||
|
right: -4px; |
||||
|
} |
||||
|
</style> |
Loading…
Reference in new issue