playbook_ui 10.0.2.pre.alpha.pre.iconfix → 10.0.3.pre.alpha.walkthrough
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.
- checksums.yaml +4 -4
- data/app/pb_kits/playbook/_playbook.scss +2 -0
- data/app/pb_kits/playbook/data/menu.yml +1 -0
- data/app/pb_kits/playbook/index.js +1 -0
- data/app/pb_kits/playbook/pb_rich_text_editor/_rich_text_editor.scss +2 -0
- data/app/pb_kits/playbook/pb_walkthrough/_walkthrough.jsx +194 -0
- data/app/pb_kits/playbook/pb_walkthrough/_walkthrough.scss +0 -0
- data/app/pb_kits/playbook/pb_walkthrough/docs/_walkthrough_continuous.jsx +68 -0
- data/app/pb_kits/playbook/pb_walkthrough/docs/_walkthrough_default.jsx +70 -0
- data/app/pb_kits/playbook/pb_walkthrough/docs/_walkthrough_multi_beacon.jsx +109 -0
- data/app/pb_kits/playbook/pb_walkthrough/docs/_walkthrough_no_beacon.jsx +75 -0
- data/app/pb_kits/playbook/pb_walkthrough/docs/_walkthrough_no_overlay.jsx +75 -0
- data/app/pb_kits/playbook/pb_walkthrough/docs/_walkthrough_styled.jsx +75 -0
- data/app/pb_kits/playbook/pb_walkthrough/docs/example.yml +10 -0
- data/app/pb_kits/playbook/pb_walkthrough/docs/index.js +6 -0
- data/app/pb_kits/playbook/pb_walkthrough/walkthrough.test.jsx +34 -0
- data/app/pb_kits/playbook/playbook-doc.js +4 -6
- data/app/pb_kits/playbook/utilities/_number_spacing.scss +3 -0
- data/app/pb_kits/playbook/utilities/globalProps.js +7 -1
- data/dist/reset.css +60 -1
- data/lib/playbook/classnames.rb +1 -0
- data/lib/playbook/kit_base.rb +2 -0
- data/lib/playbook/number_spacing.rb +31 -0
- data/lib/playbook/version.rb +2 -2
- metadata +15 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 7d8d8989dd23f539baf18ba85a01dd08457cf3a1e0770b549a909567ac8be0d8
|
4
|
+
data.tar.gz: d1d92d88f08b6c88acc436126d8b6bd219e1778a63df8113179cbb8304dc3dc8
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 43244a13a534d399aa2b4e80760a2cfe0cbdf012bca40c54da11ef75b269a99f1f1a17259a81c5dec1f2a85f3e1e88d6c1e6a3324d66821e15fb1b7b9b8a0a22
|
7
|
+
data.tar.gz: 77024ce1631997dd284b58c98e083555e184d98b31a865e7c1f90817530b42ffe2aac7385505c24823569023e682cce93ef5d4fa29adaeb412be2a3ff0b6913a
|
@@ -90,7 +90,9 @@
|
|
90
90
|
@import 'pb_user/user';
|
91
91
|
@import 'pb_user_badge/user_badge';
|
92
92
|
@import 'pb_time_stacked/time_stacked';
|
93
|
+
@import 'pb_walkthrough/walkthrough';
|
93
94
|
@import 'pb_weekday_stacked/weekday_stacked';
|
94
95
|
@import './utilities/spacing';
|
95
96
|
@import './utilities/max_width';
|
96
97
|
@import './utilities/positioning';
|
98
|
+
@import './utilities/number_spacing';
|
@@ -4,6 +4,7 @@ import 'lazysizes/plugins/attrchange/ls.attrchange'
|
|
4
4
|
import 'lazysizes'
|
5
5
|
|
6
6
|
// vvv React Component JSX Imports from the React Kits vvv
|
7
|
+
export { default as Walkthrough } from './pb_walkthrough/_walkthrough.jsx'
|
7
8
|
export { default as Avatar } from './pb_avatar/_avatar'
|
8
9
|
export { default as AvatarActionButton } from './pb_avatar_action_button/_avatar_action_button'
|
9
10
|
export { default as Background } from './pb_background/_background'
|
@@ -0,0 +1,194 @@
|
|
1
|
+
/* eslint-disable react/display-name */
|
2
|
+
/* eslint-disable no-unused-vars */
|
3
|
+
|
4
|
+
/* @flow */
|
5
|
+
|
6
|
+
import React, { useState } from 'react'
|
7
|
+
import classnames from 'classnames'
|
8
|
+
import { buildAriaProps, buildCss, buildDataProps } from '../utilities/props'
|
9
|
+
import { globalProps } from '../utilities/globalProps.js'
|
10
|
+
import Joyride, { ACTIONS, EVENTS, STATUS } from 'react-joyride'
|
11
|
+
import CircleIconButton from '../pb_circle_icon_button/_circle_icon_button'
|
12
|
+
import Button from '../pb_button/_button'
|
13
|
+
import Card from '../pb_card/_card'
|
14
|
+
import Flex from '../pb_flex/_flex'
|
15
|
+
import SectionSeparator from '../pb_section_separator/_section_separator'
|
16
|
+
import Title from '../pb_title/_title'
|
17
|
+
|
18
|
+
type WalkthroughProps = {
|
19
|
+
aria?: object,
|
20
|
+
callback?: () => void,
|
21
|
+
className?: string,
|
22
|
+
continuous?: boolean,
|
23
|
+
data?: object,
|
24
|
+
id?: string,
|
25
|
+
run?: boolean,
|
26
|
+
steps?: array,
|
27
|
+
stepIndex?: number,
|
28
|
+
debug?: Boolean,
|
29
|
+
disableCloseOnEsc?: Boolean,
|
30
|
+
disableOverlay?: Boolean,
|
31
|
+
disableOverlayClose?: Boolean,
|
32
|
+
disableScrolling?: Boolean,
|
33
|
+
floaterProps?: object,
|
34
|
+
hideBackButton?: Boolean,
|
35
|
+
hideCloseButton?: Boolean,
|
36
|
+
showProgress?: Boolean,
|
37
|
+
showSkipButton?: Boolean,
|
38
|
+
spotlightClicks?: Boolean,
|
39
|
+
spotlightPadding?: number,
|
40
|
+
styles?: {
|
41
|
+
options: {
|
42
|
+
beaconSize?: Number,
|
43
|
+
arrowColor?: String,
|
44
|
+
backgroundColor?: String,
|
45
|
+
primaryColor?: String,
|
46
|
+
overlayColor?: String,
|
47
|
+
spotlightShadow?: String,
|
48
|
+
width?: Number,
|
49
|
+
zIndex?: Number,
|
50
|
+
},
|
51
|
+
},
|
52
|
+
}
|
53
|
+
|
54
|
+
type TooltipProps = {
|
55
|
+
continuous?: Boolean,
|
56
|
+
className?: String,
|
57
|
+
index?: number,
|
58
|
+
isLastStep?: Boolean,
|
59
|
+
size?: number,
|
60
|
+
step: {
|
61
|
+
title?: String,
|
62
|
+
content?: array<React.ReactNode> | React.ReactNode | String,
|
63
|
+
target: String,
|
64
|
+
disableBeacon?: Boolean,
|
65
|
+
},
|
66
|
+
skip?: Boolean,
|
67
|
+
backProps?: object,
|
68
|
+
closeProps?: object,
|
69
|
+
primaryProps?: object,
|
70
|
+
skipProps?: object,
|
71
|
+
tooltipProps?: object,
|
72
|
+
}
|
73
|
+
|
74
|
+
const Tooltip = React.forwardRef((props: TooltipProps, ref) => (
|
75
|
+
<div
|
76
|
+
{...props.tooltipProps}
|
77
|
+
>
|
78
|
+
<Card
|
79
|
+
borderNone
|
80
|
+
padding="none"
|
81
|
+
>
|
82
|
+
{props.step.title && <div>
|
83
|
+
<Flex
|
84
|
+
align="center"
|
85
|
+
justify="between"
|
86
|
+
padding="xs"
|
87
|
+
>
|
88
|
+
<Title
|
89
|
+
paddingLeft="xs"
|
90
|
+
size={4}
|
91
|
+
>
|
92
|
+
{props.step.title}
|
93
|
+
</Title>
|
94
|
+
{props.skip && (<Button
|
95
|
+
{...props.skipProps}
|
96
|
+
id="skip"
|
97
|
+
text="Skip Tour"
|
98
|
+
variant="link"
|
99
|
+
/>)}
|
100
|
+
<Button
|
101
|
+
{...props.skipProps}
|
102
|
+
id="skip"
|
103
|
+
text="Skip Tour"
|
104
|
+
variant="link"
|
105
|
+
/>
|
106
|
+
</Flex>
|
107
|
+
<SectionSeparator />
|
108
|
+
</div>}
|
109
|
+
|
110
|
+
<Flex padding="sm">{props.step.content}</Flex>
|
111
|
+
<SectionSeparator />
|
112
|
+
<Flex
|
113
|
+
justify={props.index == 0 ? 'end' : 'between'}
|
114
|
+
padding="xs"
|
115
|
+
>
|
116
|
+
|
117
|
+
{props.index > 0 && (
|
118
|
+
<Button
|
119
|
+
{...props.backProps}
|
120
|
+
id="back"
|
121
|
+
text="Back"
|
122
|
+
/>
|
123
|
+
)}
|
124
|
+
<Choose>
|
125
|
+
<When condition={props.continuous && !props.isLastStep}>
|
126
|
+
<Button
|
127
|
+
{...props.primaryProps}
|
128
|
+
id="next"
|
129
|
+
text="Next"
|
130
|
+
/>
|
131
|
+
</When>
|
132
|
+
<When condition={!props.continuous}>
|
133
|
+
<Button
|
134
|
+
{...props.closeProps}
|
135
|
+
id="close"
|
136
|
+
text="Close"
|
137
|
+
/>
|
138
|
+
</When>
|
139
|
+
<Otherwise>
|
140
|
+
<Button
|
141
|
+
{...props.closeProps}
|
142
|
+
id="close"
|
143
|
+
text="Close"
|
144
|
+
/>
|
145
|
+
</Otherwise>
|
146
|
+
</Choose>
|
147
|
+
</Flex>
|
148
|
+
</Card>
|
149
|
+
</div>
|
150
|
+
))
|
151
|
+
|
152
|
+
const Walkthrough = (props: WalkthroughProps) => {
|
153
|
+
const {
|
154
|
+
aria = {},
|
155
|
+
callback,
|
156
|
+
className,
|
157
|
+
continuous = false,
|
158
|
+
data = {},
|
159
|
+
disableOverlay,
|
160
|
+
id,
|
161
|
+
run = false,
|
162
|
+
steps,
|
163
|
+
styles,
|
164
|
+
showSkipButton,
|
165
|
+
} = props
|
166
|
+
|
167
|
+
const ariaProps = buildAriaProps(aria)
|
168
|
+
const dataProps = buildDataProps(data)
|
169
|
+
const classes = classnames(buildCss('pb_walkthrough'), globalProps(props), className)
|
170
|
+
|
171
|
+
return (
|
172
|
+
<div
|
173
|
+
{...ariaProps}
|
174
|
+
{...dataProps}
|
175
|
+
className={classes}
|
176
|
+
id={id}
|
177
|
+
>
|
178
|
+
<Joyride
|
179
|
+
callback={callback}
|
180
|
+
continuous={continuous}
|
181
|
+
disableOverlay={disableOverlay}
|
182
|
+
disableScrolling
|
183
|
+
run={run}
|
184
|
+
showSkipButton={showSkipButton}
|
185
|
+
steps={steps}
|
186
|
+
styles={styles}
|
187
|
+
tooltipComponent={Tooltip}
|
188
|
+
{...props}
|
189
|
+
/>
|
190
|
+
</div>
|
191
|
+
)
|
192
|
+
}
|
193
|
+
|
194
|
+
export default Walkthrough
|
File without changes
|
@@ -0,0 +1,68 @@
|
|
1
|
+
import React, { useState } from 'react'
|
2
|
+
import { Button, Walkthrough } from '../../'
|
3
|
+
|
4
|
+
const WalkthroughContinuous = (props) => {
|
5
|
+
const [state, setState] = useState({
|
6
|
+
run: false,
|
7
|
+
steps: [
|
8
|
+
{
|
9
|
+
title: 'Example Title',
|
10
|
+
content: 'Setting the prop - continuous allows the next button to appear and lets the user move to the next step by pressing the next button instead of the beacon',
|
11
|
+
target: '.examplePaused',
|
12
|
+
},
|
13
|
+
{
|
14
|
+
title: 'Toggle',
|
15
|
+
content: 'Setting the prop - continuous allows the next button to appear and lets the user move to the next step by pressing the next button instead of the beacon',
|
16
|
+
target: '.pb_toggle_control',
|
17
|
+
},
|
18
|
+
{
|
19
|
+
title: 'Top Nav',
|
20
|
+
content: 'Setting the prop - continuous allows the next button to appear and lets the user move to the next step by pressing the next button instead of the beacon',
|
21
|
+
target: '.pb--page--topNav',
|
22
|
+
},
|
23
|
+
],
|
24
|
+
})
|
25
|
+
|
26
|
+
return (
|
27
|
+
<div>
|
28
|
+
<div
|
29
|
+
className="examplePaused"
|
30
|
+
style={{ 'display': 'inline' }}
|
31
|
+
>
|
32
|
+
{'Start the Tour. Then click the Beacon to demo the default behavior of the Walkthrough Kit'}
|
33
|
+
</div>
|
34
|
+
<br />
|
35
|
+
<br />
|
36
|
+
<Button
|
37
|
+
onClick={() => {
|
38
|
+
setState({ ...state,
|
39
|
+
run: true,
|
40
|
+
})
|
41
|
+
}}
|
42
|
+
>
|
43
|
+
{'Start Tour'}
|
44
|
+
</Button>
|
45
|
+
<br />
|
46
|
+
<br />
|
47
|
+
<Button
|
48
|
+
onClick={() => {
|
49
|
+
setState({
|
50
|
+
...state,
|
51
|
+
run: false,
|
52
|
+
})
|
53
|
+
}}
|
54
|
+
>
|
55
|
+
{'Reset/Stop Tour'}
|
56
|
+
</Button>
|
57
|
+
|
58
|
+
<Walkthrough
|
59
|
+
run={state.run}
|
60
|
+
steps={state.steps}
|
61
|
+
{...props}
|
62
|
+
continuous
|
63
|
+
/>
|
64
|
+
</div>
|
65
|
+
)
|
66
|
+
}
|
67
|
+
|
68
|
+
export default WalkthroughContinuous
|
@@ -0,0 +1,70 @@
|
|
1
|
+
import React, { useState } from 'react'
|
2
|
+
import { Button, Walkthrough } from '../../'
|
3
|
+
|
4
|
+
const WalkthroughDefault = (props) => {
|
5
|
+
const [state, setState] = useState({
|
6
|
+
run: false,
|
7
|
+
steps: [
|
8
|
+
{
|
9
|
+
title: 'Example title',
|
10
|
+
content:
|
11
|
+
'This was an example of a Beacon in the Walkthrough Kit it is used as a simple indicator to inform users about a particular thing',
|
12
|
+
target: '.example',
|
13
|
+
},
|
14
|
+
{
|
15
|
+
title: 'Toggle',
|
16
|
+
content:
|
17
|
+
'By default the walkthrough kit will cycle through each step provided.',
|
18
|
+
target: '.pb_toggle_control',
|
19
|
+
},
|
20
|
+
{
|
21
|
+
title: 'Top Nav',
|
22
|
+
content:
|
23
|
+
'By default the walkthrough kit will cycle through each step provided.',
|
24
|
+
target: '.pb--page--topNav',
|
25
|
+
},
|
26
|
+
],
|
27
|
+
})
|
28
|
+
|
29
|
+
return (
|
30
|
+
<div>
|
31
|
+
<div
|
32
|
+
className="example"
|
33
|
+
style={{ 'display': 'inline' }}
|
34
|
+
>
|
35
|
+
{'Start the Tour. Then click the Beacon to demo the default behavior of the Walkthrough Kit'}
|
36
|
+
</div>
|
37
|
+
<br />
|
38
|
+
<br />
|
39
|
+
<Button
|
40
|
+
onClick={() => {
|
41
|
+
setState({ ...state,
|
42
|
+
run: true,
|
43
|
+
})
|
44
|
+
}}
|
45
|
+
>
|
46
|
+
{'Start Tour'}
|
47
|
+
</Button>
|
48
|
+
<br />
|
49
|
+
<br />
|
50
|
+
<Button
|
51
|
+
onClick={() => {
|
52
|
+
setState({
|
53
|
+
...state,
|
54
|
+
run: false,
|
55
|
+
})
|
56
|
+
}}
|
57
|
+
>
|
58
|
+
{'Reset/Stop Tour'}
|
59
|
+
</Button>
|
60
|
+
|
61
|
+
<Walkthrough
|
62
|
+
run={state.run}
|
63
|
+
steps={state.steps}
|
64
|
+
{...props}
|
65
|
+
/>
|
66
|
+
</div>
|
67
|
+
)
|
68
|
+
}
|
69
|
+
|
70
|
+
export default WalkthroughDefault
|
@@ -0,0 +1,109 @@
|
|
1
|
+
import React, { useState } from 'react'
|
2
|
+
import { Button, Walkthrough } from '../../'
|
3
|
+
|
4
|
+
const WalkthroughMultiBeacon = (props) => {
|
5
|
+
const [stateA, setStateA] = useState({
|
6
|
+
run: false,
|
7
|
+
steps: [
|
8
|
+
{
|
9
|
+
title: 'Example title',
|
10
|
+
content:
|
11
|
+
'This was an example of a Beacon in the Walkthrough Kit it is used as a simple indicator to inform users about a particular thing',
|
12
|
+
target: '.exampleMulti',
|
13
|
+
},
|
14
|
+
],
|
15
|
+
})
|
16
|
+
|
17
|
+
const [stateB, setStateB] = useState({
|
18
|
+
run: false,
|
19
|
+
steps: [
|
20
|
+
{
|
21
|
+
title: 'Toggle',
|
22
|
+
content:
|
23
|
+
'By default the walkthrough kit will cycle through each step provided.',
|
24
|
+
target: '.pb_toggle_control',
|
25
|
+
},
|
26
|
+
],
|
27
|
+
})
|
28
|
+
|
29
|
+
const [stateC, setStateC] = useState({
|
30
|
+
run: false,
|
31
|
+
steps: [
|
32
|
+
{
|
33
|
+
title: 'Top Nav',
|
34
|
+
content:
|
35
|
+
'By default the walkthrough kit will cycle through each step provided.',
|
36
|
+
target: '.pb--page--topNav',
|
37
|
+
},
|
38
|
+
],
|
39
|
+
})
|
40
|
+
|
41
|
+
return (
|
42
|
+
<div>
|
43
|
+
<div
|
44
|
+
className="exampleMulti"
|
45
|
+
style={{ 'display': 'inline' }}
|
46
|
+
>
|
47
|
+
{'Start the Tour. Then click the Beacon to demo the default behavior of the Walkthrough Kit'}
|
48
|
+
</div>
|
49
|
+
<br />
|
50
|
+
<br />
|
51
|
+
<Button
|
52
|
+
onClick={() => {
|
53
|
+
setStateA({
|
54
|
+
...stateA,
|
55
|
+
run: true,
|
56
|
+
})
|
57
|
+
setStateB({
|
58
|
+
...stateB,
|
59
|
+
run: true,
|
60
|
+
})
|
61
|
+
setStateC({
|
62
|
+
...stateC,
|
63
|
+
run: true,
|
64
|
+
})
|
65
|
+
}}
|
66
|
+
>
|
67
|
+
{'Start Tour'}
|
68
|
+
</Button>
|
69
|
+
<br />
|
70
|
+
<br />
|
71
|
+
<Button
|
72
|
+
onClick={() => {
|
73
|
+
setStateA({
|
74
|
+
...stateA,
|
75
|
+
run: false,
|
76
|
+
})
|
77
|
+
setStateB({
|
78
|
+
...stateB,
|
79
|
+
run: false,
|
80
|
+
})
|
81
|
+
setStateC({
|
82
|
+
...stateC,
|
83
|
+
run: false,
|
84
|
+
})
|
85
|
+
}}
|
86
|
+
>
|
87
|
+
{'Reset/Stop Tour'}
|
88
|
+
</Button>
|
89
|
+
|
90
|
+
<Walkthrough
|
91
|
+
run={stateA.run}
|
92
|
+
steps={stateA.steps}
|
93
|
+
{...props}
|
94
|
+
/>
|
95
|
+
<Walkthrough
|
96
|
+
run={stateB.run}
|
97
|
+
steps={stateB.steps}
|
98
|
+
{...props}
|
99
|
+
/>
|
100
|
+
<Walkthrough
|
101
|
+
run={stateC.run}
|
102
|
+
steps={stateC.steps}
|
103
|
+
{...props}
|
104
|
+
/>
|
105
|
+
</div>
|
106
|
+
)
|
107
|
+
}
|
108
|
+
|
109
|
+
export default WalkthroughMultiBeacon
|
@@ -0,0 +1,75 @@
|
|
1
|
+
import React, { useState } from 'react'
|
2
|
+
import { Button, Walkthrough } from '../../'
|
3
|
+
|
4
|
+
const WalkthroughNoBeacon = (props) => {
|
5
|
+
const [state, setState] = useState({
|
6
|
+
callback: (data) => {
|
7
|
+
if (data.action === 'close' && data.type === 'step:after') {
|
8
|
+
// This explicitly stops the tour (otherwise it displays a "beacon" to resume the tour)
|
9
|
+
setState({ ...state, run: false })
|
10
|
+
}
|
11
|
+
},
|
12
|
+
run: false,
|
13
|
+
steps: [
|
14
|
+
{
|
15
|
+
title: 'Example Title',
|
16
|
+
content: 'Setting the prop - continuous allows the next button to appear and lets the user move to the next step by pressing the next button instead of the beacon',
|
17
|
+
target: '.exampleNoBeacon',
|
18
|
+
disableBeacon: true,
|
19
|
+
},
|
20
|
+
{
|
21
|
+
title: 'Toggle',
|
22
|
+
content: 'Setting the prop - continuous allows the next button to appear and lets the user move to the next step by pressing the next button instead of the beacon',
|
23
|
+
target: '.pb_toggle_control',
|
24
|
+
},
|
25
|
+
{
|
26
|
+
title: 'Top Nav',
|
27
|
+
content: 'Setting the prop - continuous allows the next button to appear and lets the user move to the next step by pressing the next button instead of the beacon',
|
28
|
+
target: '.pb--page--topNav',
|
29
|
+
},
|
30
|
+
],
|
31
|
+
})
|
32
|
+
|
33
|
+
return (
|
34
|
+
<div>
|
35
|
+
<div
|
36
|
+
className="exampleNoBeacon"
|
37
|
+
style={{ 'display': 'inline' }}
|
38
|
+
>
|
39
|
+
{'Start the Tour. Then click the Beacon to demo the default behavior of the Walkthrough Kit'}
|
40
|
+
</div>
|
41
|
+
<br />
|
42
|
+
<br />
|
43
|
+
<Button
|
44
|
+
onClick={() => {
|
45
|
+
setState({ ...state,
|
46
|
+
run: true,
|
47
|
+
})
|
48
|
+
}}
|
49
|
+
>
|
50
|
+
{'Start Tour'}
|
51
|
+
</Button>
|
52
|
+
<br />
|
53
|
+
<br />
|
54
|
+
<Button
|
55
|
+
onClick={() => {
|
56
|
+
setState({
|
57
|
+
...state,
|
58
|
+
run: false,
|
59
|
+
})
|
60
|
+
}}
|
61
|
+
>
|
62
|
+
{'Reset/Stop Tour'}
|
63
|
+
</Button>
|
64
|
+
|
65
|
+
<Walkthrough
|
66
|
+
run={state.run}
|
67
|
+
steps={state.steps}
|
68
|
+
{...props}
|
69
|
+
continuous
|
70
|
+
/>
|
71
|
+
</div>
|
72
|
+
)
|
73
|
+
}
|
74
|
+
|
75
|
+
export default WalkthroughNoBeacon
|
@@ -0,0 +1,75 @@
|
|
1
|
+
import React, { useState } from 'react'
|
2
|
+
import { Button, Walkthrough } from '../../'
|
3
|
+
|
4
|
+
const WalkthroughNoOverlay = (props) => {
|
5
|
+
const [noOverlay, setNoOverlayState] = useState({
|
6
|
+
callback: (data) => {
|
7
|
+
if (data.action === 'close' && data.type === 'step:after') {
|
8
|
+
// This explicitly stops the tour (otherwise it displays a "beacon" to resume the tour)
|
9
|
+
setNoOverlayState({ ...noOverlay, run: false })
|
10
|
+
}
|
11
|
+
},
|
12
|
+
disableOverlay: true,
|
13
|
+
run: false,
|
14
|
+
steps: [
|
15
|
+
{
|
16
|
+
title: 'Example Title',
|
17
|
+
content: 'Setting the prop - continuous allows the next button to appear and lets the user move to the next step by pressing the next button instead of the beacon',
|
18
|
+
target: '.exampleNoOverlay',
|
19
|
+
},
|
20
|
+
{
|
21
|
+
title: 'Toggle',
|
22
|
+
content: 'Setting the prop - continuous allows the next button to appear and lets the user move to the next step by pressing the next button instead of the beacon',
|
23
|
+
target: '.pb_toggle_control',
|
24
|
+
},
|
25
|
+
{
|
26
|
+
title: 'Top Nav',
|
27
|
+
content: 'Setting the prop - continuous allows the next button to appear and lets the user move to the next step by pressing the next button instead of the beacon',
|
28
|
+
target: '.pb--page--topNav',
|
29
|
+
},
|
30
|
+
],
|
31
|
+
})
|
32
|
+
|
33
|
+
return (
|
34
|
+
<div>
|
35
|
+
<div
|
36
|
+
className="exampleNoOverlay"
|
37
|
+
style={{ 'display': 'inline' }}
|
38
|
+
>
|
39
|
+
{'Start the Tour. Then click the Beacon to demo the default behavior of the Walkthrough Kit'}
|
40
|
+
</div>
|
41
|
+
<br />
|
42
|
+
<br />
|
43
|
+
<Button
|
44
|
+
onClick={() => {
|
45
|
+
setNoOverlayState({ ...noOverlay,
|
46
|
+
run: true,
|
47
|
+
})
|
48
|
+
}}
|
49
|
+
>
|
50
|
+
{'Start Tour'}
|
51
|
+
</Button>
|
52
|
+
<br />
|
53
|
+
<br />
|
54
|
+
<Button
|
55
|
+
onClick={() => {
|
56
|
+
setNoOverlayState({
|
57
|
+
...noOverlay,
|
58
|
+
run: false,
|
59
|
+
})
|
60
|
+
}}
|
61
|
+
>
|
62
|
+
{'Reset/Stop Tour'}
|
63
|
+
</Button>
|
64
|
+
|
65
|
+
<Walkthrough
|
66
|
+
disableOverlay
|
67
|
+
run={noOverlay.run}
|
68
|
+
steps={noOverlay.steps}
|
69
|
+
{...props}
|
70
|
+
/>
|
71
|
+
</div>
|
72
|
+
)
|
73
|
+
}
|
74
|
+
|
75
|
+
export default WalkthroughNoOverlay
|
@@ -0,0 +1,75 @@
|
|
1
|
+
import React, { useState } from 'react'
|
2
|
+
import { Button, Walkthrough } from '../../'
|
3
|
+
|
4
|
+
const WalkthroughStyled = (props) => {
|
5
|
+
const [state, setState] = useState({
|
6
|
+
run: false,
|
7
|
+
steps: [
|
8
|
+
{
|
9
|
+
title: 'Example title',
|
10
|
+
content:
|
11
|
+
'This was an example of a Beacon in the Walkthrough Kit it is used as a simple indicator to inform users about a particular thing',
|
12
|
+
target: '.styled',
|
13
|
+
},
|
14
|
+
{
|
15
|
+
title: 'Toggle',
|
16
|
+
content:
|
17
|
+
'By default the walkthrough kit will cycle through each step provided.',
|
18
|
+
target: '.pb_toggle_control',
|
19
|
+
},
|
20
|
+
{
|
21
|
+
title: 'Top Nav',
|
22
|
+
content:
|
23
|
+
'By default the walkthrough kit will cycle through each step provided.',
|
24
|
+
target: '.pb--page--topNav',
|
25
|
+
},
|
26
|
+
],
|
27
|
+
})
|
28
|
+
|
29
|
+
return (
|
30
|
+
<div>
|
31
|
+
<div
|
32
|
+
className="styled"
|
33
|
+
style={{ 'display': 'inline' }}
|
34
|
+
>
|
35
|
+
{'Start the Tour. Then click the Beacon to demo the default behavior of the Walkthrough Kit'}
|
36
|
+
</div>
|
37
|
+
<br />
|
38
|
+
<br />
|
39
|
+
<Button
|
40
|
+
onClick={() => {
|
41
|
+
setState({ ...state,
|
42
|
+
run: true,
|
43
|
+
})
|
44
|
+
}}
|
45
|
+
>
|
46
|
+
{'Start Tour'}
|
47
|
+
</Button>
|
48
|
+
<br />
|
49
|
+
<br />
|
50
|
+
<Button
|
51
|
+
onClick={() => {
|
52
|
+
setState({
|
53
|
+
...state,
|
54
|
+
run: false,
|
55
|
+
})
|
56
|
+
}}
|
57
|
+
>
|
58
|
+
{'Reset/Stop Tour'}
|
59
|
+
</Button>
|
60
|
+
|
61
|
+
<Walkthrough
|
62
|
+
run={state.run}
|
63
|
+
steps={state.steps}
|
64
|
+
styles={{
|
65
|
+
options: {
|
66
|
+
beaconSize: 120,
|
67
|
+
},
|
68
|
+
}}
|
69
|
+
{...props}
|
70
|
+
/>
|
71
|
+
</div>
|
72
|
+
)
|
73
|
+
}
|
74
|
+
|
75
|
+
export default WalkthroughStyled
|
@@ -0,0 +1,6 @@
|
|
1
|
+
export { default as WalkthroughDefault } from './_walkthrough_default.jsx'
|
2
|
+
export { default as WalkthroughContinuous } from './_walkthrough_continuous.jsx'
|
3
|
+
export { default as WalkthroughNoBeacon } from './_walkthrough_no_beacon.jsx'
|
4
|
+
export { default as WalkthroughMultiBeacon } from './_walkthrough_multi_beacon.jsx'
|
5
|
+
export { default as WalkthroughNoOverlay } from './_walkthrough_no_overlay.jsx'
|
6
|
+
export { default as WalkthroughStyled } from './_walkthrough_styled.jsx'
|
@@ -0,0 +1,34 @@
|
|
1
|
+
/* eslint-disable no-unused-vars */
|
2
|
+
import { ensureAccessible, render, renderKit, screen } from '../utilities/test-utils'
|
3
|
+
import React from 'react'
|
4
|
+
import { Walkthrough } from '../'
|
5
|
+
|
6
|
+
/* See these resources for more testing info:
|
7
|
+
- https://github.com/testing-library/jest-dom#usage for useage and examples
|
8
|
+
- https://jestjs.io/docs/en/using-matchers
|
9
|
+
*/
|
10
|
+
|
11
|
+
const testId = 'walkthroughKitTest',
|
12
|
+
kitClass = 'pb_walkthrough'
|
13
|
+
|
14
|
+
test('expect kit to exist', () => {
|
15
|
+
const props = {
|
16
|
+
data: { testid: testId },
|
17
|
+
}
|
18
|
+
|
19
|
+
const kit = renderKit(Walkthrough, props)
|
20
|
+
expect(kit).toBeInTheDocument()
|
21
|
+
expect(kit).toHaveClass(kitClass)
|
22
|
+
})
|
23
|
+
|
24
|
+
test('returns namespaced class name', () => {
|
25
|
+
render(
|
26
|
+
<Walkthrough
|
27
|
+
className="additional_class"
|
28
|
+
data={{ testid: testId }}
|
29
|
+
/>
|
30
|
+
)
|
31
|
+
|
32
|
+
const kit = screen.getByTestId(testId)
|
33
|
+
expect(kit).toHaveClass('additional_class')
|
34
|
+
})
|
@@ -1,6 +1,6 @@
|
|
1
|
+
/* eslint-disable no-unused-vars */
|
1
2
|
// !!! IMPORTANT: This file is autogenerated. Please do not edit.!!!
|
2
3
|
import WebpackerReact from 'webpacker-react'
|
3
|
-
import ujs from 'webpacker-react/ujs'
|
4
4
|
|
5
5
|
// KIT EXAMPLES
|
6
6
|
import 'pb_form/pb_form_validation'
|
@@ -94,9 +94,10 @@ import * as Toggle from 'pb_toggle/docs'
|
|
94
94
|
import * as Typeahead from 'pb_typeahead/docs'
|
95
95
|
import * as User from 'pb_user/docs'
|
96
96
|
import * as UserBadge from 'pb_user_badge/docs'
|
97
|
+
import * as Walkthrough from 'pb_walkthrough/docs'
|
97
98
|
import * as WeekdayStacked from 'pb_weekday_stacked/docs'
|
98
99
|
|
99
|
-
WebpackerReact.
|
100
|
+
WebpackerReact.setup({
|
100
101
|
...Avatar,
|
101
102
|
...AvatarActionButton,
|
102
103
|
...Background,
|
@@ -187,9 +188,6 @@ WebpackerReact.registerComponents({
|
|
187
188
|
...Typeahead,
|
188
189
|
...User,
|
189
190
|
...UserBadge,
|
191
|
+
...Walkthrough,
|
190
192
|
...WeekdayStacked,
|
191
193
|
})
|
192
|
-
ujs.setup(
|
193
|
-
() => WebpackerReact.mountComponents(),
|
194
|
-
() => WebpackerReact.unmountComponents()
|
195
|
-
)
|
@@ -39,6 +39,12 @@ const darkProps = ({ dark }) => {
|
|
39
39
|
return css
|
40
40
|
}
|
41
41
|
|
42
|
+
const numberSpacingProps = ({ numberSpacing }) => {
|
43
|
+
let css = ''
|
44
|
+
css += numberSpacing ? `ns_${numberSpacing} ` : ''
|
45
|
+
return css
|
46
|
+
}
|
47
|
+
|
42
48
|
const maxWidthProps = ({ maxWidth }) => {
|
43
49
|
let css = ''
|
44
50
|
css += maxWidth ? `max_width_${maxWidth } ` : ''
|
@@ -54,7 +60,7 @@ const zIndexProps = ({ zIndex }) => {
|
|
54
60
|
// All Exported as a single function
|
55
61
|
export const globalProps = (props, defaultProps = {}) => {
|
56
62
|
const allProps = { ...props, ...defaultProps }
|
57
|
-
return spacingProps(allProps) + darkProps(allProps) + maxWidthProps(allProps) + zIndexProps(allProps)
|
63
|
+
return spacingProps(allProps) + darkProps(allProps) + maxWidthProps(allProps) + zIndexProps(allProps) + numberSpacingProps(allProps)
|
58
64
|
}
|
59
65
|
|
60
66
|
export const deprecatedProps = (kit, props = []) => {
|
data/dist/reset.css
CHANGED
@@ -1,2 +1,61 @@
|
|
1
|
-
|
1
|
+
/* CLEAN UP AND REMOVE */
|
2
|
+
/* Headings */
|
3
|
+
/* Standard Font Weights */
|
4
|
+
/* Non_Standard Font Weights */
|
5
|
+
/*=====================================
|
6
|
+
Base colors should not be documented.
|
7
|
+
Only document color use.
|
8
|
+
|
9
|
+
Colors -----------------------------*/
|
10
|
+
/* Specialty Gradient -----------------*/
|
11
|
+
/* Interface colors -------------------*/
|
12
|
+
/* Main colors ------------------------*/
|
13
|
+
/*=====================================
|
14
|
+
|
15
|
+
Background colors ------------------*/
|
16
|
+
/* Card colors ------------------*/
|
17
|
+
/* Active colors ----------------------*/
|
18
|
+
/* Hover colors -----------------------*/
|
19
|
+
/* Focus colors -----------------------*/
|
20
|
+
/* Border colors ----------------------*/
|
21
|
+
/* Shadow colors ----------------------*/
|
22
|
+
/* Text colors ------------------------*/
|
23
|
+
/* Data colors ------------------------*/
|
24
|
+
/* Status colors ----------------------*/
|
25
|
+
/* Link colors ------------------------*/
|
26
|
+
/* Product colors ---------------------*/
|
27
|
+
/* Category colors ---------------------*/
|
28
|
+
* {
|
29
|
+
box-sizing: border-box;
|
30
|
+
margin: 0;
|
31
|
+
padding: 0; }
|
32
|
+
*:before, *:after {
|
33
|
+
box-sizing: border-box; }
|
34
|
+
|
35
|
+
html {
|
36
|
+
-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
|
37
|
+
height: 100vh;
|
38
|
+
overflow-x: hidden; }
|
39
|
+
|
40
|
+
body {
|
41
|
+
font-family: "Proxima Nova", "Helvetica Neue", Helvetica, Arial, sans_serif;
|
42
|
+
font-size: 16px;
|
43
|
+
line-height: 1.5;
|
44
|
+
background-color: #F3F7FB;
|
45
|
+
height: 100%;
|
46
|
+
letter-spacing: 0;
|
47
|
+
font-weight: 400;
|
48
|
+
font-style: normal;
|
49
|
+
text-rendering: optimizeLegibility;
|
50
|
+
-moz-font-feature-settings: "liga" on;
|
51
|
+
color: #242B42;
|
52
|
+
margin: 0 !important;
|
53
|
+
padding: 0 !important;
|
54
|
+
box-sizing: border-box;
|
55
|
+
min-height: 100vh;
|
56
|
+
padding: 50px; }
|
57
|
+
|
58
|
+
a {
|
59
|
+
text-decoration: none;
|
60
|
+
color: #0056CF; }
|
2
61
|
|
data/lib/playbook/classnames.rb
CHANGED
data/lib/playbook/kit_base.rb
CHANGED
@@ -3,6 +3,7 @@
|
|
3
3
|
require "playbook/classnames"
|
4
4
|
require "playbook/spacing"
|
5
5
|
require "playbook/z_index"
|
6
|
+
require "playbook/number_spacing"
|
6
7
|
|
7
8
|
module Playbook
|
8
9
|
class KitBase < ViewComponent::Base
|
@@ -11,6 +12,7 @@ module Playbook
|
|
11
12
|
include Playbook::Classnames
|
12
13
|
include Playbook::Spacing
|
13
14
|
include Playbook::ZIndex
|
15
|
+
include Playbook::NumberSpacing
|
14
16
|
|
15
17
|
prop :id
|
16
18
|
prop :data, type: Playbook::Props::Hash, default: {}
|
@@ -0,0 +1,31 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Playbook
|
4
|
+
module NumberSpacing
|
5
|
+
def self.included(base)
|
6
|
+
base.prop :number_spacing
|
7
|
+
end
|
8
|
+
|
9
|
+
private
|
10
|
+
|
11
|
+
def number_spacing_props
|
12
|
+
selected_index_props = number_spacing_options.keys.select { |sk| try(sk) }
|
13
|
+
return nil unless selected_index_props.present?
|
14
|
+
|
15
|
+
selected_index_props.map do |k|
|
16
|
+
index_value = send(k)
|
17
|
+
"ns_#{index_value}" if number_spacing_values.include? index_value
|
18
|
+
end.compact.join(" ")
|
19
|
+
end
|
20
|
+
|
21
|
+
def number_spacing_options
|
22
|
+
{
|
23
|
+
number_spacing: "ns",
|
24
|
+
}
|
25
|
+
end
|
26
|
+
|
27
|
+
def number_spacing_values
|
28
|
+
%w[tabular]
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
data/lib/playbook/version.rb
CHANGED
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: playbook_ui
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 10.0.
|
4
|
+
version: 10.0.3.pre.alpha.walkthrough
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Power UX
|
@@ -9,7 +9,7 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2021-07-
|
12
|
+
date: 2021-07-14 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: actionpack
|
@@ -1958,6 +1958,17 @@ files:
|
|
1958
1958
|
- app/pb_kits/playbook/pb_user_badge/docs/index.js
|
1959
1959
|
- app/pb_kits/playbook/pb_user_badge/user_badge.html.erb
|
1960
1960
|
- app/pb_kits/playbook/pb_user_badge/user_badge.rb
|
1961
|
+
- app/pb_kits/playbook/pb_walkthrough/_walkthrough.jsx
|
1962
|
+
- app/pb_kits/playbook/pb_walkthrough/_walkthrough.scss
|
1963
|
+
- app/pb_kits/playbook/pb_walkthrough/docs/_walkthrough_continuous.jsx
|
1964
|
+
- app/pb_kits/playbook/pb_walkthrough/docs/_walkthrough_default.jsx
|
1965
|
+
- app/pb_kits/playbook/pb_walkthrough/docs/_walkthrough_multi_beacon.jsx
|
1966
|
+
- app/pb_kits/playbook/pb_walkthrough/docs/_walkthrough_no_beacon.jsx
|
1967
|
+
- app/pb_kits/playbook/pb_walkthrough/docs/_walkthrough_no_overlay.jsx
|
1968
|
+
- app/pb_kits/playbook/pb_walkthrough/docs/_walkthrough_styled.jsx
|
1969
|
+
- app/pb_kits/playbook/pb_walkthrough/docs/example.yml
|
1970
|
+
- app/pb_kits/playbook/pb_walkthrough/docs/index.js
|
1971
|
+
- app/pb_kits/playbook/pb_walkthrough/walkthrough.test.jsx
|
1961
1972
|
- app/pb_kits/playbook/pb_weekday_stacked/_weekday_stacked.jsx
|
1962
1973
|
- app/pb_kits/playbook/pb_weekday_stacked/_weekday_stacked.scss
|
1963
1974
|
- app/pb_kits/playbook/pb_weekday_stacked/docs/_weekday_stacked_compact.html.erb
|
@@ -2000,6 +2011,7 @@ files:
|
|
2000
2011
|
- app/pb_kits/playbook/utilities/_background_colors.scss
|
2001
2012
|
- app/pb_kits/playbook/utilities/_colors.scss
|
2002
2013
|
- app/pb_kits/playbook/utilities/_max_width.scss
|
2014
|
+
- app/pb_kits/playbook/utilities/_number_spacing.scss
|
2003
2015
|
- app/pb_kits/playbook/utilities/_positioning.scss
|
2004
2016
|
- app/pb_kits/playbook/utilities/_spacing.scss
|
2005
2017
|
- app/pb_kits/playbook/utilities/globalProps.js
|
@@ -2026,6 +2038,7 @@ files:
|
|
2026
2038
|
- lib/playbook/markdown.rb
|
2027
2039
|
- lib/playbook/markdown/helper.rb
|
2028
2040
|
- lib/playbook/markdown/template_handler.rb
|
2041
|
+
- lib/playbook/number_spacing.rb
|
2029
2042
|
- lib/playbook/pb_doc_helper.rb
|
2030
2043
|
- lib/playbook/pb_forms_helper.rb
|
2031
2044
|
- lib/playbook/pb_kit_helper.rb
|