Easy way to have a personal Guide + tutorial of your react app.
Download or clone this repo by using belowe command
git clone https://github.com/deuex-solutions/react-tutorial.git
include reacttour.min.js file to your project
import ReactTour from 'reacttour.min.js' // prod
import ReactTour from 'reacttour.js' // dev
styled-components it isn't bundled into the package and is required styled-components@^6.1.8
and react@^16.3
due to the use of createRef, so:
npm i -S styled-components@^6.1.8
# or
yarn add styled-components@^6.1.8
Add the ReactTour
Component in your Application, passing the steps
with the elements to highlight during the ReactTour.
import React from 'react'
import ReactTour from '@deuex-solutions/react-tour'
class App extends Component {
// ...
render (
<>
{ /* other stuff */}
<ReactTour
steps={steps}
playTour={this.state.playTour}
onRequestClose={this.closeTour} />
</>
)
}
const steps = [
{
selector: '.first-step',
content: 'This is my first Step',
},
// ...
]
Change
--reactour-accent
(defaults to accentColor on IE) css custom prop to apply color in Helper, number, dots, etc
Type: string
Default: #007aff
Customize Badge content using
current
andtotal
steps values
Type: func
// example
<ReactTour badgeContent={(curr, tot) => `${curr} of ${tot}`} />
Content to be rendered inside the Helper
Type: node | elem
Custom class name to add to the Helper
Type: string
Disable interactivity with Dots navigation in Helper
Type: bool
Disable the ability to click or intercat in any way with the Highlighted element
Type: bool
Disable all keyboard navigation (next and prev step) when true, disable only selected keys when array
Type: bool | array(['esc', 'right', 'left'])
// example
<ReactTour disableKeyboardNavigation={['esc']} />
Custom class name to add to the element which is the overlay for the target element when
disableInteraction
Type: string
Tolerance in pixels to add when calculating if an element is outside viewport to scroll into view
Type: number
You know…
Type: bool
Required: true
Change Next button in last step into a custom button to close the Tour
Type: node
// example
<ReactTour lastStepNextButton={<MyButton>Done! Let's start playing</MyButton>} />
Custom class name to add to the Mask
Type: string
Extra Space between in pixels between Highlighted element and Mask
Type: number
Default: 10
Renders as next button navigation
Type: node
Do something after Tour is opened
Type: func
// example
<ReactTour onAfterOpen={target => (document.body.style.overflowY = 'hidden')} />
Do something before Tour is closed
Type: func
// example
<ReactTour onBeforeClose={target => (document.body.style.overflowY = 'auto')} />
Function to close the Tour
Type: func
Required: true
Renders as prev button navigation
Type: node
Beautify Helper and Mask with
border-radius
(in px)
Type: number
Default: 0
Smooth scroll duration when positioning the target element (in ms)
Type: number
Default: 1
Offset when positioning the target element after scroll to it
Type: number
Default: a calculation to the center of the viewport
Show/Hide Helper Navigation buttons
Type: bool
Default: true
Show/Hide Helper Navigation Dots
Type: bool
Default: true
Show/Hide number when hovers on each Navigation Dot
Type: bool
Default: true
Show/Hide Helper Number Badge
Type: bool
Default: true
Starting step when ReactTour is open the first time
Type: number
Default: 0
delay of playing next step after current is completed
Type: number
Default: 0
Color for fading out unhighlighted part
type: string
default: #000
allow scrolling screen
type: bool
default: false
Array of elements to highligt with special info and props
Type: shape
Required: true
steps: PropTypes.arrayOf(
PropTypes.shape({
selector: PropTypes.string,
content: PropTypes.oneOfType([
PropTypes.node,
PropTypes.element,
PropTypes.func,
]).isRequired,
position: PropTypes.oneOf(['top', 'right', 'bottom', 'left']),
arrowPosition: PropTypes.oneOf(['top', 'right', 'bottom', 'left']),
dropSelector: PropTypes.string,
actionType: PropTypes.oneOf(['click', 'dblclick', 'typing', 'dragndrop','dragwithmove', 'custom', 'wait']),
userTypeText: PropTypes.string,
waitTimer: PropTypes.number,
beforeStep: PropTypes.func,
afterStep: PropTypes.func,
beforePrev: PropTypes.func,
beforeNext: PropTypes.func
}),
click // StepUp will be done when user click on element with given selector
dblclick // StepUp will be done when user dbl click on element with given selector
typing // StepUp will be done when user type exact string as userTypeText on element with given selector
dragdrop // StepUp will be done when user drag element with given selector and drop it to element with dropSelector
dragwithmove // StepUp will be done when user perform mouseDown element with given selector, move it to dropSelector element and at last perform mouse up on the dropselector element
custom // Control of stepUp is in authors hand by providing function to content wich will have goto and step as nextstep number
wait // StepUp will be done after waitTimer is over ( waitTimer will be in ms)
function will be called before performing step
Type: func
function will be called before performing step
Type: func
function will be called onClick of Prev button and perform task before going to prev step
Type: func
function will be called onClick of Next button and perform task before going to Next step
Type: func
const steps = [
{
selector: '[data-tour="my-first-step"]',
content: ({ goTo, inDOM }) => (
<div>
Lorem ipsum <button onClick={() => goTo(4)}>Go to Step 5</button>
<br />
{inDOM && '🎉 Look at your step!'}
</div>
),
position: 'top', // Position is optional, if not provided, tour will auto calculate the position.
style: {
backgroundColor: '#bada55',
},
// Disable interaction for this specific step.
// Could be enabled passing `true`
// when `disableInteraction` prop is present in Tour
stepInteraction: false,
},
// ...
]