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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 62b6bcb6b36c501d383c226bf3445bc4339d43d222175f242bb68db89ef44152
4
- data.tar.gz: b15b4e307f4f97a66db2761b2cba1973a67e19bd5e8a8ab6ef747655bb8985e0
3
+ metadata.gz: 7d8d8989dd23f539baf18ba85a01dd08457cf3a1e0770b549a909567ac8be0d8
4
+ data.tar.gz: d1d92d88f08b6c88acc436126d8b6bd219e1778a63df8113179cbb8304dc3dc8
5
5
  SHA512:
6
- metadata.gz: dc869834053fe2289cd31fc58350bb291d4a19658b6dce38b5a674e2ec38bc855912d3bbbe2c7dacc92a0968b6ae1f5172959721d3df469e3e4393259c63110e
7
- data.tar.gz: 174f6d032e05b7e6f5718bfa4dc002959613d339265bbdebc8e2d8c48f0436ded74ada3635f08ad217f00acb0d2b059e359a6044c72bffbbeb710dfaeabcbf88
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';
@@ -101,3 +101,4 @@ kits:
101
101
  - title_count
102
102
  - title_detail
103
103
  - user_badge
104
+ - walkthrough
@@ -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'
@@ -23,6 +23,8 @@
23
23
  overflow-x: auto;
24
24
  }
25
25
  [class^=pb_rich_text_editor_kit] {
26
+ // Fixes flex container resizing bug
27
+ overflow-x: auto;
26
28
  // Disables File Attatchment Button in Toolbar
27
29
  trix-toolbar [data-trix-button-group="file-tools"] {
28
30
  display: none;
@@ -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
@@ -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,10 @@
1
+ examples:
2
+
3
+
4
+ react:
5
+ - walkthrough_default: Default
6
+ - walkthrough_continuous: Continuous
7
+ - walkthrough_no_beacon: No Beacon
8
+ - walkthrough_no_overlay: No Overlay
9
+ - walkthrough_multi_beacon: Multi Beacon
10
+ - walkthrough_styled: Styled
@@ -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.registerComponents({
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
- )
@@ -0,0 +1,3 @@
1
+ .ns_tabular {
2
+ font-variant-numeric: tabular-nums !important;
3
+ }
@@ -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
- *{box-sizing:border-box;margin:0;padding:0}*:before,*:after{box-sizing:border-box}html{-webkit-tap-highlight-color:rgba(0,0,0,0);height:100vh;overflow-x:hidden}body{font-family:"Proxima Nova","Helvetica Neue",Helvetica,Arial,sans_serif;font-size:16px;line-height:1.5;background-color:#F3F7FB;height:100%;letter-spacing:0;font-weight:400;font-style:normal;text-rendering:optimizeLegibility;-moz-font-feature-settings:"liga" on;color:#242B42;margin:0 !important;padding:0 !important;box-sizing:border-box;min-height:100vh;padding:50px}a{text-decoration:none;color:#0056CF}
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
 
@@ -15,6 +15,7 @@ module Playbook
15
15
  dark_props,
16
16
  max_width_props,
17
17
  z_index_props,
18
+ number_spacing_props,
18
19
  ].compact.join(" ")
19
20
  end
20
21
 
@@ -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
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Playbook
4
- PREVIOUS_VERSION = "10.0.1"
5
- VERSION = "10.0.2-alpha-iconfix"
4
+ PREVIOUS_VERSION = "10.0.0"
5
+ VERSION = "10.0.3.pre.alpha.walkthrough"
6
6
  end
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.2.pre.alpha.pre.iconfix
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-08 00:00:00.000000000 Z
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