@veracity/vui 1.5.0 → 1.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/core/vuiProvider/globalStyle.d.ts +1 -1
- package/dist/cjs/core/vuiProvider/globalStyle.d.ts.map +1 -1
- package/dist/cjs/core/vuiProvider/index.d.ts +1 -0
- package/dist/cjs/core/vuiProvider/index.d.ts.map +1 -1
- package/dist/cjs/core/vuiProvider/index.js +1 -0
- package/dist/cjs/core/vuiProvider/notifyOffline.d.ts +4 -0
- package/dist/cjs/core/vuiProvider/notifyOffline.d.ts.map +1 -0
- package/dist/cjs/core/vuiProvider/notifyOffline.js +43 -0
- package/dist/cjs/core/vuiProvider/resetCSS.d.ts +1 -1
- package/dist/cjs/core/vuiProvider/resetCSS.d.ts.map +1 -1
- package/dist/cjs/core/vuiProvider/useOfflineMode.d.ts +4 -0
- package/dist/cjs/core/vuiProvider/useOfflineMode.d.ts.map +1 -0
- package/dist/cjs/core/vuiProvider/useOfflineMode.js +19 -0
- package/dist/cjs/core/vuiProvider/vuiProvider.d.ts +2 -0
- package/dist/cjs/core/vuiProvider/vuiProvider.d.ts.map +1 -1
- package/dist/cjs/core/vuiProvider/vuiProvider.js +3 -1
- package/dist/cjs/icons/baseIcons/cul/culAutoSave.d.ts +4 -0
- package/dist/cjs/icons/baseIcons/cul/culAutoSave.d.ts.map +1 -0
- package/dist/cjs/icons/baseIcons/cul/culAutoSave.js +7 -0
- package/dist/cjs/icons/baseIcons/fal/falArrowsLeftRight.d.ts +4 -0
- package/dist/cjs/icons/baseIcons/fal/falArrowsLeftRight.d.ts.map +1 -0
- package/dist/cjs/icons/baseIcons/fal/falArrowsLeftRight.js +7 -0
- package/dist/cjs/icons/baseIcons/fal/falArrowsUpDown.d.ts +4 -0
- package/dist/cjs/icons/baseIcons/fal/falArrowsUpDown.d.ts.map +1 -0
- package/dist/cjs/icons/baseIcons/fal/falArrowsUpDown.js +7 -0
- package/dist/cjs/icons/baseIcons/fal/falBalanceScale.d.ts +4 -0
- package/dist/cjs/icons/baseIcons/fal/falBalanceScale.d.ts.map +1 -0
- package/dist/cjs/icons/baseIcons/fal/falBalanceScale.js +7 -0
- package/dist/cjs/icons/baseIcons/fal/falCodeBranch.d.ts +4 -0
- package/dist/cjs/icons/baseIcons/fal/falCodeBranch.d.ts.map +1 -0
- package/dist/cjs/icons/baseIcons/fal/falCodeBranch.js +7 -0
- package/dist/cjs/icons/baseIcons/fal/falCodeCommit.d.ts +4 -0
- package/dist/cjs/icons/baseIcons/fal/falCodeCommit.d.ts.map +1 -0
- package/dist/cjs/icons/baseIcons/fal/falCodeCommit.js +7 -0
- package/dist/cjs/icons/baseIcons/fal/falCodeMerge.d.ts +4 -0
- package/dist/cjs/icons/baseIcons/fal/falCodeMerge.d.ts.map +1 -0
- package/dist/cjs/icons/baseIcons/fal/falCodeMerge.js +7 -0
- package/dist/cjs/icons/baseIcons/fal/falFileExclamation.d.ts +4 -0
- package/dist/cjs/icons/baseIcons/fal/falFileExclamation.d.ts.map +1 -0
- package/dist/cjs/icons/baseIcons/fal/falFileExclamation.js +7 -0
- package/dist/cjs/icons/baseIcons/fal/falPencilRuler.d.ts +4 -0
- package/dist/cjs/icons/baseIcons/fal/falPencilRuler.d.ts.map +1 -0
- package/dist/cjs/icons/baseIcons/fal/falPencilRuler.js +7 -0
- package/dist/cjs/icons/baseIcons/fal/falProjectDiagram.d.ts +4 -0
- package/dist/cjs/icons/baseIcons/fal/falProjectDiagram.d.ts.map +1 -0
- package/dist/cjs/icons/baseIcons/fal/falProjectDiagram.js +7 -0
- package/dist/cjs/icons/baseIcons/fal/falRuler.d.ts +4 -0
- package/dist/cjs/icons/baseIcons/fal/falRuler.d.ts.map +1 -0
- package/dist/cjs/icons/baseIcons/fal/falRuler.js +7 -0
- package/dist/cjs/icons/baseIcons/fas/fasGripDotsVertical.d.ts +4 -0
- package/dist/cjs/icons/baseIcons/fas/fasGripDotsVertical.d.ts.map +1 -0
- package/dist/cjs/icons/baseIcons/fas/fasGripDotsVertical.js +7 -0
- package/dist/cjs/icons/baseIcons/fas/fasLayerGroup.d.ts +4 -0
- package/dist/cjs/icons/baseIcons/fas/fasLayerGroup.d.ts.map +1 -0
- package/dist/cjs/icons/baseIcons/fas/fasLayerGroup.js +7 -0
- package/dist/cjs/icons/baseIcons/fas/fasMousePointer.d.ts +4 -0
- package/dist/cjs/icons/baseIcons/fas/fasMousePointer.d.ts.map +1 -0
- package/dist/cjs/icons/baseIcons/fas/fasMousePointer.js +7 -0
- package/dist/cjs/icons/baseIcons/fas/fasShield.d.ts +4 -0
- package/dist/cjs/icons/baseIcons/fas/fasShield.d.ts.map +1 -0
- package/dist/cjs/icons/baseIcons/fas/fasShield.js +7 -0
- package/dist/cjs/icons/baseIcons/icons.d.ts +15 -0
- package/dist/cjs/icons/baseIcons/icons.d.ts.map +1 -1
- package/dist/cjs/icons/baseIcons/icons.js +37 -7
- package/dist/cjs/icons/baseIcons/types.d.ts +1 -1
- package/dist/cjs/icons/baseIcons/types.d.ts.map +1 -1
- package/dist/cjs/index.d.ts +1 -0
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +1 -0
- package/dist/cjs/select/theme.d.ts +8 -0
- package/dist/cjs/select/theme.d.ts.map +1 -1
- package/dist/cjs/select/theme.js +8 -0
- package/dist/cjs/tabs/useTabsState.d.ts +1 -1
- package/dist/cjs/tabs/useTabsState.d.ts.map +1 -1
- package/dist/cjs/theme/components.d.ts +8 -0
- package/dist/cjs/theme/components.d.ts.map +1 -1
- package/dist/cjs/theme/defaultTheme.d.ts +8 -0
- package/dist/cjs/theme/defaultTheme.d.ts.map +1 -1
- package/dist/cjs/toast/useToast.d.ts +1 -1
- package/dist/cjs/toast/useToast.d.ts.map +1 -1
- package/dist/cjs/tutorial/index.d.ts +6 -0
- package/dist/cjs/tutorial/index.d.ts.map +1 -0
- package/dist/cjs/tutorial/index.js +21 -0
- package/dist/cjs/tutorial/tutorial.d.ts +4 -0
- package/dist/cjs/tutorial/tutorial.d.ts.map +1 -0
- package/dist/cjs/tutorial/tutorial.js +32 -0
- package/dist/cjs/tutorial/tutorial.types.d.ts +64 -0
- package/dist/cjs/tutorial/tutorial.types.d.ts.map +1 -0
- package/dist/cjs/tutorial/tutorial.types.js +2 -0
- package/dist/cjs/tutorial/tutorialCard.d.ts +3 -0
- package/dist/cjs/tutorial/tutorialCard.d.ts.map +1 -0
- package/dist/cjs/tutorial/tutorialCard.js +65 -0
- package/dist/cjs/tutorial/tutorialStep.d.ts +3 -0
- package/dist/cjs/tutorial/tutorialStep.d.ts.map +1 -0
- package/dist/cjs/tutorial/tutorialStep.js +14 -0
- package/dist/cjs/tutorial/useTutorial.d.ts +8 -0
- package/dist/cjs/tutorial/useTutorial.d.ts.map +1 -0
- package/dist/cjs/tutorial/useTutorial.js +14 -0
- package/dist/cjs/utils/uid.d.ts +1 -1
- package/dist/cjs/utils/uid.d.ts.map +1 -1
- package/dist/esm/core/vuiProvider/globalStyle.d.ts +1 -1
- package/dist/esm/core/vuiProvider/globalStyle.d.ts.map +1 -1
- package/dist/esm/core/vuiProvider/index.d.ts +1 -0
- package/dist/esm/core/vuiProvider/index.d.ts.map +1 -1
- package/dist/esm/core/vuiProvider/index.js +1 -0
- package/dist/esm/core/vuiProvider/notifyOffline.d.ts +4 -0
- package/dist/esm/core/vuiProvider/notifyOffline.d.ts.map +1 -0
- package/dist/esm/core/vuiProvider/notifyOffline.js +18 -0
- package/dist/esm/core/vuiProvider/resetCSS.d.ts +1 -1
- package/dist/esm/core/vuiProvider/resetCSS.d.ts.map +1 -1
- package/dist/esm/core/vuiProvider/useOfflineMode.d.ts +4 -0
- package/dist/esm/core/vuiProvider/useOfflineMode.d.ts.map +1 -0
- package/dist/esm/core/vuiProvider/useOfflineMode.js +15 -0
- package/dist/esm/core/vuiProvider/vuiProvider.d.ts +2 -0
- package/dist/esm/core/vuiProvider/vuiProvider.d.ts.map +1 -1
- package/dist/esm/core/vuiProvider/vuiProvider.js +3 -1
- package/dist/esm/icons/baseIcons/cul/culAutoSave.d.ts +4 -0
- package/dist/esm/icons/baseIcons/cul/culAutoSave.d.ts.map +1 -0
- package/dist/esm/icons/baseIcons/cul/culAutoSave.js +5 -0
- package/dist/esm/icons/baseIcons/fal/falArrowsLeftRight.d.ts +4 -0
- package/dist/esm/icons/baseIcons/fal/falArrowsLeftRight.d.ts.map +1 -0
- package/dist/esm/icons/baseIcons/fal/falArrowsLeftRight.js +5 -0
- package/dist/esm/icons/baseIcons/fal/falArrowsUpDown.d.ts +4 -0
- package/dist/esm/icons/baseIcons/fal/falArrowsUpDown.d.ts.map +1 -0
- package/dist/esm/icons/baseIcons/fal/falArrowsUpDown.js +5 -0
- package/dist/esm/icons/baseIcons/fal/falBalanceScale.d.ts +4 -0
- package/dist/esm/icons/baseIcons/fal/falBalanceScale.d.ts.map +1 -0
- package/dist/esm/icons/baseIcons/fal/falBalanceScale.js +5 -0
- package/dist/esm/icons/baseIcons/fal/falCodeBranch.d.ts +4 -0
- package/dist/esm/icons/baseIcons/fal/falCodeBranch.d.ts.map +1 -0
- package/dist/esm/icons/baseIcons/fal/falCodeBranch.js +5 -0
- package/dist/esm/icons/baseIcons/fal/falCodeCommit.d.ts +4 -0
- package/dist/esm/icons/baseIcons/fal/falCodeCommit.d.ts.map +1 -0
- package/dist/esm/icons/baseIcons/fal/falCodeCommit.js +5 -0
- package/dist/esm/icons/baseIcons/fal/falCodeMerge.d.ts +4 -0
- package/dist/esm/icons/baseIcons/fal/falCodeMerge.d.ts.map +1 -0
- package/dist/esm/icons/baseIcons/fal/falCodeMerge.js +5 -0
- package/dist/esm/icons/baseIcons/fal/falFileExclamation.d.ts +4 -0
- package/dist/esm/icons/baseIcons/fal/falFileExclamation.d.ts.map +1 -0
- package/dist/esm/icons/baseIcons/fal/falFileExclamation.js +5 -0
- package/dist/esm/icons/baseIcons/fal/falPencilRuler.d.ts +4 -0
- package/dist/esm/icons/baseIcons/fal/falPencilRuler.d.ts.map +1 -0
- package/dist/esm/icons/baseIcons/fal/falPencilRuler.js +5 -0
- package/dist/esm/icons/baseIcons/fal/falProjectDiagram.d.ts +4 -0
- package/dist/esm/icons/baseIcons/fal/falProjectDiagram.d.ts.map +1 -0
- package/dist/esm/icons/baseIcons/fal/falProjectDiagram.js +5 -0
- package/dist/esm/icons/baseIcons/fal/falRuler.d.ts +4 -0
- package/dist/esm/icons/baseIcons/fal/falRuler.d.ts.map +1 -0
- package/dist/esm/icons/baseIcons/fal/falRuler.js +5 -0
- package/dist/esm/icons/baseIcons/fas/fasGripDotsVertical.d.ts +4 -0
- package/dist/esm/icons/baseIcons/fas/fasGripDotsVertical.d.ts.map +1 -0
- package/dist/esm/icons/baseIcons/fas/fasGripDotsVertical.js +5 -0
- package/dist/esm/icons/baseIcons/fas/fasLayerGroup.d.ts +4 -0
- package/dist/esm/icons/baseIcons/fas/fasLayerGroup.d.ts.map +1 -0
- package/dist/esm/icons/baseIcons/fas/fasLayerGroup.js +5 -0
- package/dist/esm/icons/baseIcons/fas/fasMousePointer.d.ts +4 -0
- package/dist/esm/icons/baseIcons/fas/fasMousePointer.d.ts.map +1 -0
- package/dist/esm/icons/baseIcons/fas/fasMousePointer.js +5 -0
- package/dist/esm/icons/baseIcons/fas/fasShield.d.ts +4 -0
- package/dist/esm/icons/baseIcons/fas/fasShield.d.ts.map +1 -0
- package/dist/esm/icons/baseIcons/fas/fasShield.js +5 -0
- package/dist/esm/icons/baseIcons/icons.d.ts +15 -0
- package/dist/esm/icons/baseIcons/icons.d.ts.map +1 -1
- package/dist/esm/icons/baseIcons/icons.js +15 -0
- package/dist/esm/icons/baseIcons/types.d.ts +1 -1
- package/dist/esm/icons/baseIcons/types.d.ts.map +1 -1
- package/dist/esm/index.d.ts +1 -0
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +1 -0
- package/dist/esm/select/theme.d.ts +8 -0
- package/dist/esm/select/theme.d.ts.map +1 -1
- package/dist/esm/select/theme.js +8 -0
- package/dist/esm/tabs/useTabsState.d.ts +1 -1
- package/dist/esm/tabs/useTabsState.d.ts.map +1 -1
- package/dist/esm/theme/components.d.ts +8 -0
- package/dist/esm/theme/components.d.ts.map +1 -1
- package/dist/esm/theme/defaultTheme.d.ts +8 -0
- package/dist/esm/theme/defaultTheme.d.ts.map +1 -1
- package/dist/esm/toast/useToast.d.ts +1 -1
- package/dist/esm/toast/useToast.d.ts.map +1 -1
- package/dist/esm/tutorial/index.d.ts +6 -0
- package/dist/esm/tutorial/index.d.ts.map +1 -0
- package/dist/esm/tutorial/index.js +5 -0
- package/dist/esm/tutorial/tutorial.d.ts +4 -0
- package/dist/esm/tutorial/tutorial.d.ts.map +1 -0
- package/dist/esm/tutorial/tutorial.js +25 -0
- package/dist/esm/tutorial/tutorial.types.d.ts +64 -0
- package/dist/esm/tutorial/tutorial.types.d.ts.map +1 -0
- package/dist/esm/tutorial/tutorial.types.js +1 -0
- package/dist/esm/tutorial/tutorialCard.d.ts +3 -0
- package/dist/esm/tutorial/tutorialCard.d.ts.map +1 -0
- package/dist/esm/tutorial/tutorialCard.js +37 -0
- package/dist/esm/tutorial/tutorialStep.d.ts +3 -0
- package/dist/esm/tutorial/tutorialStep.d.ts.map +1 -0
- package/dist/esm/tutorial/tutorialStep.js +7 -0
- package/dist/esm/tutorial/useTutorial.d.ts +8 -0
- package/dist/esm/tutorial/useTutorial.d.ts.map +1 -0
- package/dist/esm/tutorial/useTutorial.js +10 -0
- package/dist/esm/utils/uid.d.ts +1 -1
- package/dist/esm/utils/uid.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/core/vuiProvider/index.ts +1 -0
- package/src/core/vuiProvider/notifyOffline.ts +22 -0
- package/src/core/vuiProvider/useOfflineMode.ts +18 -0
- package/src/core/vuiProvider/vuiProvider.tsx +6 -1
- package/src/icons/baseIcons/cul/culAutoSave.ts +8 -0
- package/src/icons/baseIcons/fal/falArrowsLeftRight.ts +8 -0
- package/src/icons/baseIcons/fal/falArrowsUpDown.ts +8 -0
- package/src/icons/baseIcons/fal/falBalanceScale.ts +8 -0
- package/src/icons/baseIcons/fal/falCodeBranch.ts +8 -0
- package/src/icons/baseIcons/fal/falCodeCommit.ts +8 -0
- package/src/icons/baseIcons/fal/falCodeMerge.ts +8 -0
- package/src/icons/baseIcons/fal/falFileExclamation.ts +8 -0
- package/src/icons/baseIcons/fal/falPencilRuler.ts +8 -0
- package/src/icons/baseIcons/fal/falProjectDiagram.ts +8 -0
- package/src/icons/baseIcons/fal/falRuler.ts +8 -0
- package/src/icons/baseIcons/fas/fasGripDotsVertical.ts +8 -0
- package/src/icons/baseIcons/fas/fasLayerGroup.ts +8 -0
- package/src/icons/baseIcons/fas/fasMousePointer.ts +8 -0
- package/src/icons/baseIcons/fas/fasShield.ts +8 -0
- package/src/icons/baseIcons/icons.ts +15 -0
- package/src/icons/baseIcons/types.ts +15 -0
- package/src/icons/readme.md +10 -1
- package/src/index.ts +1 -0
- package/src/select/theme.ts +8 -0
- package/src/tutorial/index.ts +5 -0
- package/src/tutorial/tutorial.tsx +60 -0
- package/src/tutorial/tutorial.types.ts +69 -0
- package/src/tutorial/tutorialCard.tsx +137 -0
- package/src/tutorial/tutorialStep.tsx +20 -0
- package/src/tutorial/useTutorial.ts +16 -0
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import React from 'react'
|
|
2
|
+
import { Placement } from 'tippy.js'
|
|
3
|
+
|
|
4
|
+
export type TutorialDataStep = {
|
|
5
|
+
/** title of step */
|
|
6
|
+
title: string
|
|
7
|
+
/** description of step */
|
|
8
|
+
description: string
|
|
9
|
+
/** Read more link */
|
|
10
|
+
readMoreLink?: string
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export type TutorialProps = {
|
|
14
|
+
/** Target element for the tutorial */
|
|
15
|
+
children: React.ReactNode
|
|
16
|
+
/** Custom class name */
|
|
17
|
+
className?: string
|
|
18
|
+
/** An id for further handling with localStorage */
|
|
19
|
+
id: string
|
|
20
|
+
/** A general tutorial description */
|
|
21
|
+
description?: string
|
|
22
|
+
/** Invoked once the dismiss button clicked. */
|
|
23
|
+
onDismiss?: () => void
|
|
24
|
+
/** Invoked once the finish button clicked. */
|
|
25
|
+
onFinish?: () => void
|
|
26
|
+
/** Popover placement */
|
|
27
|
+
placement?: Placement
|
|
28
|
+
/** Link to page where user can read more */
|
|
29
|
+
readMoreLink?: string
|
|
30
|
+
/** An array of steps */
|
|
31
|
+
steps: TutorialDataStep[]
|
|
32
|
+
/** A general tutorial title */
|
|
33
|
+
title: string
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
export type TutorialCardProps = {
|
|
37
|
+
/** Custom class name */
|
|
38
|
+
className?: string
|
|
39
|
+
/** The card title */
|
|
40
|
+
title: string
|
|
41
|
+
/** Steps of the card */
|
|
42
|
+
steps: TutorialDataStep[]
|
|
43
|
+
/** Callback for the dismiss button click. */
|
|
44
|
+
onDismiss?: () => void
|
|
45
|
+
/** Callback for the finish button click. */
|
|
46
|
+
onFinish?: () => void
|
|
47
|
+
/** Description of feature */
|
|
48
|
+
description?: string
|
|
49
|
+
/** Link to page where they can read more */
|
|
50
|
+
readMoreLink?: string
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
export type TutorialStepProps = {
|
|
54
|
+
/** If the step is active or not */
|
|
55
|
+
active: boolean
|
|
56
|
+
/** Title of step */
|
|
57
|
+
title: string
|
|
58
|
+
/** Description of step */
|
|
59
|
+
description: string
|
|
60
|
+
/** Link to page where user can read more */
|
|
61
|
+
readMoreLink?: string
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
export type TutorialStepWrapper = {
|
|
65
|
+
key: number
|
|
66
|
+
step: TutorialDataStep
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
export type CloseEvent = 'dismissed' | 'finished'
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
import React, { useEffect, useState } from 'react'
|
|
2
|
+
|
|
3
|
+
import { Box, Button, Card, H3, Icon, T } from '../index'
|
|
4
|
+
import { TutorialCardProps, TutorialDataStep, TutorialStepWrapper } from './tutorial.types'
|
|
5
|
+
import { TutorialStep } from './tutorialStep'
|
|
6
|
+
|
|
7
|
+
export function TutorialCard({
|
|
8
|
+
className,
|
|
9
|
+
description,
|
|
10
|
+
title,
|
|
11
|
+
readMoreLink,
|
|
12
|
+
steps: propsSteps = [],
|
|
13
|
+
onDismiss,
|
|
14
|
+
onFinish
|
|
15
|
+
}: TutorialCardProps) {
|
|
16
|
+
const [started, setStarted] = useState<boolean>(false)
|
|
17
|
+
const [steps, setSteps] = useState<TutorialStepWrapper[]>([])
|
|
18
|
+
const [activeStep, setActiveStep] = useState<number>(0)
|
|
19
|
+
|
|
20
|
+
useEffect(() => {
|
|
21
|
+
if (title && propsSteps.length) {
|
|
22
|
+
const s = propsSteps.map((step, key) => ({ active: false, step, key }))
|
|
23
|
+
|
|
24
|
+
const finalStep: TutorialDataStep = {
|
|
25
|
+
title: `Completed!`,
|
|
26
|
+
description: `${readMoreLink ? 'To learn more, please visit:' : 'Thank you!'}`
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
if (readMoreLink) finalStep.readMoreLink = readMoreLink
|
|
30
|
+
|
|
31
|
+
setSteps([...s, { step: finalStep, key: propsSteps.length }])
|
|
32
|
+
}
|
|
33
|
+
}, [title, propsSteps])
|
|
34
|
+
|
|
35
|
+
const isStartStep = activeStep === 0
|
|
36
|
+
const isFinalStep = activeStep === propsSteps.length
|
|
37
|
+
const decrementStep = () => setActiveStep(activeStep - 1)
|
|
38
|
+
const incrementStep = () => setActiveStep(activeStep + 1)
|
|
39
|
+
|
|
40
|
+
return (
|
|
41
|
+
<Card bg="blue.100" className={className} color="white" column justifyContent="space-between" minH={200} w={450}>
|
|
42
|
+
<Box
|
|
43
|
+
alignContent="center"
|
|
44
|
+
alignItems="center"
|
|
45
|
+
display="flex"
|
|
46
|
+
flex={0}
|
|
47
|
+
flexDirection="row"
|
|
48
|
+
flexGrow={0}
|
|
49
|
+
justifyContent="space-between"
|
|
50
|
+
m={2}
|
|
51
|
+
mb={1}
|
|
52
|
+
minH="48px"
|
|
53
|
+
row
|
|
54
|
+
style={{ WebkitFlexGrow: '0' }}
|
|
55
|
+
>
|
|
56
|
+
<H3>{title}</H3>
|
|
57
|
+
{!isFinalStep && (
|
|
58
|
+
<Button color="white" hoverColor="prussian.80" icon="falTimes" onClick={onDismiss} scale={2} variant="text" />
|
|
59
|
+
)}
|
|
60
|
+
</Box>
|
|
61
|
+
<Box column flex={5} hidden={started} mx={2}>
|
|
62
|
+
<T flexGrow={1}>{description}</T>
|
|
63
|
+
<Box alignItems="center" flexDirection="row-reverse" row>
|
|
64
|
+
<Button bg="white" color="prussian.80" float="right" mb={0} onClick={() => setStarted(true)} pb={0}>
|
|
65
|
+
Let's get started!
|
|
66
|
+
</Button>
|
|
67
|
+
</Box>
|
|
68
|
+
</Box>
|
|
69
|
+
<Box flex={5} hidden={!started} mx={2} row>
|
|
70
|
+
{steps?.map?.(s => (
|
|
71
|
+
<TutorialStep
|
|
72
|
+
active={s.key === activeStep}
|
|
73
|
+
description={s.step.description}
|
|
74
|
+
key={s.step.title}
|
|
75
|
+
readMoreLink={s.step.readMoreLink}
|
|
76
|
+
title={s.step.title}
|
|
77
|
+
/>
|
|
78
|
+
))}
|
|
79
|
+
</Box>
|
|
80
|
+
<Box
|
|
81
|
+
alignItems="center"
|
|
82
|
+
flex={0}
|
|
83
|
+
flexGrow={0}
|
|
84
|
+
hidden={!started}
|
|
85
|
+
justifyContent="space-between"
|
|
86
|
+
m={2}
|
|
87
|
+
mt={0}
|
|
88
|
+
row
|
|
89
|
+
style={{ WebkitFlexGrow: '0' }}
|
|
90
|
+
>
|
|
91
|
+
<Button
|
|
92
|
+
color="white"
|
|
93
|
+
disabled={isStartStep}
|
|
94
|
+
disabledBg="blue.100"
|
|
95
|
+
disabledBorderColor="blue.100"
|
|
96
|
+
disabledColor="prussian.80"
|
|
97
|
+
focusBorderColor="none"
|
|
98
|
+
hoverBg="none"
|
|
99
|
+
hoverBorder="none"
|
|
100
|
+
hoverBorderColor="blue.100"
|
|
101
|
+
icon="falArrowLeft"
|
|
102
|
+
onClick={decrementStep}
|
|
103
|
+
scale={2}
|
|
104
|
+
transition="none"
|
|
105
|
+
variant="text"
|
|
106
|
+
w="80"
|
|
107
|
+
/>
|
|
108
|
+
|
|
109
|
+
<Box className="vuiTutorialStepDots">
|
|
110
|
+
{steps?.map?.(s => (
|
|
111
|
+
<Icon color={s.key === activeStep ? 'white' : 'grey.70'} key={s.key} name="cusDotFull" />
|
|
112
|
+
))}
|
|
113
|
+
</Box>
|
|
114
|
+
|
|
115
|
+
{isFinalStep ? (
|
|
116
|
+
<Button bg="white" color="prussian.80" hoverBg="blue.30" hoverColor="prussian.80" onClick={onFinish}>
|
|
117
|
+
Finish
|
|
118
|
+
</Button>
|
|
119
|
+
) : (
|
|
120
|
+
<Button
|
|
121
|
+
color="white"
|
|
122
|
+
focusBorderColor="none"
|
|
123
|
+
hoverBg="none"
|
|
124
|
+
hoverBorder="none"
|
|
125
|
+
hoverBorderColor="blue.100"
|
|
126
|
+
icon="falArrowRight"
|
|
127
|
+
onClick={incrementStep}
|
|
128
|
+
scale={2}
|
|
129
|
+
transition="none"
|
|
130
|
+
variant="text"
|
|
131
|
+
w="80"
|
|
132
|
+
/>
|
|
133
|
+
)}
|
|
134
|
+
</Box>
|
|
135
|
+
</Card>
|
|
136
|
+
)
|
|
137
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import React from 'react'
|
|
2
|
+
|
|
3
|
+
import { H5, P, v } from '../index'
|
|
4
|
+
import { TutorialStepProps } from './tutorial.types'
|
|
5
|
+
|
|
6
|
+
export const TutorialStep = ({ active, description, readMoreLink, title }: TutorialStepProps) => (
|
|
7
|
+
<v.div className="vui-tutorialStep" hidden={!active} pb={2}>
|
|
8
|
+
<H5 fontWeight="medium" mb={1}>
|
|
9
|
+
{title}
|
|
10
|
+
</H5>
|
|
11
|
+
<P>{description}</P>
|
|
12
|
+
{!!readMoreLink && (
|
|
13
|
+
<P>
|
|
14
|
+
<v.a href={readMoreLink} textDecoration="underline">
|
|
15
|
+
{readMoreLink}
|
|
16
|
+
</v.a>
|
|
17
|
+
</P>
|
|
18
|
+
)}
|
|
19
|
+
</v.div>
|
|
20
|
+
)
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { useEffect, useState } from 'react'
|
|
2
|
+
|
|
3
|
+
import { CloseEvent } from './tutorial.types'
|
|
4
|
+
|
|
5
|
+
export const useTutorial = (tutorialId: string) => {
|
|
6
|
+
const [isVisible, setIsVisible] = useState<boolean>(false)
|
|
7
|
+
const localStorageId = `vuiTutorial-${tutorialId}`
|
|
8
|
+
|
|
9
|
+
useEffect(() => {
|
|
10
|
+
setIsVisible(!window.localStorage.getItem(localStorageId))
|
|
11
|
+
}, [])
|
|
12
|
+
|
|
13
|
+
const saveDisplayed = (e: CloseEvent) => window.localStorage.setItem(localStorageId, e)
|
|
14
|
+
|
|
15
|
+
return { isVisible, setIsVisible, saveDisplayed }
|
|
16
|
+
}
|