playbook_ui 14.6.2.pre.alpha.PLAY1613darkdatetimecolors4432 → 14.6.2.pre.alpha.PLAY15814348
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 +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/Components/CustomCell.tsx +1 -8
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +28 -21
- data/app/pb_kits/playbook/pb_advanced_table/advanced_table.test.jsx +1 -37
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_custom_cell.jsx +2 -13
- data/app/pb_kits/playbook/pb_card/_card.tsx +3 -2
- data/app/pb_kits/playbook/pb_card/docs/_card_light.jsx +17 -3
- data/app/pb_kits/playbook/pb_date/_date.scss +0 -3
- data/app/pb_kits/playbook/pb_dropdown/_dropdown.tsx +7 -8
- data/app/pb_kits/playbook/pb_form_pill/_form_pill.scss +2 -6
- data/app/pb_kits/playbook/pb_form_pill/_form_pill.tsx +26 -30
- data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_truncated_text.html.erb +1 -24
- data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_truncated_text.jsx +2 -25
- data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_truncated_text.md +1 -0
- data/app/pb_kits/playbook/pb_form_pill/form_pill.html.erb +8 -46
- data/app/pb_kits/playbook/pb_timeline/_item.tsx +23 -59
- data/app/pb_kits/playbook/pb_timeline/_timeline.tsx +0 -8
- data/app/pb_kits/playbook/pb_timeline/docs/example.yml +1 -2
- data/app/pb_kits/playbook/pb_timeline/docs/index.js +0 -1
- data/app/pb_kits/playbook/pb_timeline/item.html.erb +21 -17
- data/app/pb_kits/playbook/pb_timeline/item.rb +0 -4
- data/app/pb_kits/playbook/pb_timeline/timeline.test.js +0 -84
- data/app/pb_kits/playbook/utilities/_hover.scss +43 -46
- data/app/pb_kits/playbook/utilities/globalPropNames.mjs +0 -1
- data/app/pb_kits/playbook/utilities/globalProps.ts +0 -5
- data/dist/chunks/_typeahead-BtdghxJo.js +22 -0
- data/dist/chunks/_weekday_stacked-D1RoR5CN.js +45 -0
- data/dist/chunks/vendor.js +1 -1
- data/dist/menu.yml +1 -4
- data/dist/playbook-doc.js +1 -1
- data/dist/playbook-rails-react-bindings.js +1 -1
- data/dist/playbook-rails.js +1 -1
- data/dist/playbook.css +1 -1
- data/lib/playbook/hover.rb +1 -4
- data/lib/playbook/kit_base.rb +15 -33
- data/lib/playbook/version.rb +1 -1
- metadata +5 -37
- data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_truncated_text_rails.md +0 -3
- data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_truncated_text_react.md +0 -1
- data/app/pb_kits/playbook/pb_skeleton_loading/_skeleton_loading.scss +0 -37
- data/app/pb_kits/playbook/pb_skeleton_loading/_skeleton_loading.tsx +0 -67
- data/app/pb_kits/playbook/pb_skeleton_loading/_skeleton_loading_mixins.scss +0 -40
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_border_radius.jsx +0 -51
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_border_radius.md +0 -1
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_color.jsx +0 -26
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_color.md +0 -1
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_default.html.erb +0 -1
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_default.jsx +0 -11
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_height_width.jsx +0 -59
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_height_width.md +0 -3
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_layout.jsx +0 -20
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_layout.md +0 -3
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/example.yml +0 -13
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/index.js +0 -5
- data/app/pb_kits/playbook/pb_skeleton_loading/skeleton_loading.html.erb +0 -12
- data/app/pb_kits/playbook/pb_skeleton_loading/skeleton_loading.rb +0 -8
- data/app/pb_kits/playbook/pb_skeleton_loading/skeleton_loading.test.jsx +0 -81
- data/app/pb_kits/playbook/pb_timeline/detail.html.erb +0 -3
- data/app/pb_kits/playbook/pb_timeline/detail.rb +0 -11
- data/app/pb_kits/playbook/pb_timeline/docs/_timeline_with_children.html.erb +0 -43
- data/app/pb_kits/playbook/pb_timeline/docs/_timeline_with_children.jsx +0 -68
- data/app/pb_kits/playbook/pb_timeline/docs/_timeline_with_children.md +0 -2
- data/app/pb_kits/playbook/pb_timeline/label.html.erb +0 -12
- data/app/pb_kits/playbook/pb_timeline/label.rb +0 -13
- data/app/pb_kits/playbook/pb_timeline/step.html.erb +0 -14
- data/app/pb_kits/playbook/pb_timeline/step.rb +0 -16
- data/app/pb_kits/playbook/pb_timeline/subcomponents/Detail.tsx +0 -29
- data/app/pb_kits/playbook/pb_timeline/subcomponents/Label.tsx +0 -38
- data/app/pb_kits/playbook/pb_timeline/subcomponents/Step.tsx +0 -42
- data/app/pb_kits/playbook/pb_timeline/subcomponents/index.tsx +0 -3
- data/dist/chunks/_typeahead-DhLic2Fe.js +0 -22
- data/dist/chunks/_weekday_stacked-Mx8TYP5I.js +0 -45
@@ -1,81 +0,0 @@
|
|
1
|
-
import React from 'react'
|
2
|
-
import { render, screen } from '@testing-library/react'
|
3
|
-
import { ensureAccessible } from '../utilities/test-utils'
|
4
|
-
import { SkeletonLoading } from 'playbook-ui'
|
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
|
-
describe('SkeletonLoading', () => {
|
12
|
-
const defaultProps = {
|
13
|
-
data: { testid: 'skeleton-loading' }
|
14
|
-
}
|
15
|
-
|
16
|
-
it('should be accessible', async () => {
|
17
|
-
ensureAccessible(SkeletonLoading, defaultProps)
|
18
|
-
})
|
19
|
-
|
20
|
-
it('renders with default props', () => {
|
21
|
-
const { container } = render(<SkeletonLoading {...defaultProps} />)
|
22
|
-
const skeleton = screen.getByTestId('skeleton-loading')
|
23
|
-
|
24
|
-
expect(skeleton).toBeInTheDocument()
|
25
|
-
expect(skeleton).toHaveClass('pb_skeleton_loading')
|
26
|
-
expect(container.querySelectorAll('div[class*="border_radius_"]')).toHaveLength(1)
|
27
|
-
})
|
28
|
-
|
29
|
-
it('renders multiple skeleton items based on stack prop', () => {
|
30
|
-
const props = {
|
31
|
-
...defaultProps,
|
32
|
-
stack: 3
|
33
|
-
}
|
34
|
-
const { container } = render(<SkeletonLoading {...props} />)
|
35
|
-
|
36
|
-
expect(container.querySelectorAll('div[class*="border_radius_"]')).toHaveLength(3)
|
37
|
-
})
|
38
|
-
|
39
|
-
it('applies custom styles correctly', () => {
|
40
|
-
const props = {
|
41
|
-
...defaultProps,
|
42
|
-
height: '24px',
|
43
|
-
width: '50%',
|
44
|
-
borderRadius: 'lg',
|
45
|
-
color: 'light',
|
46
|
-
dark: true
|
47
|
-
}
|
48
|
-
const { container } = render(<SkeletonLoading {...props} />)
|
49
|
-
const skeletonItem = container.querySelector('div[class*="border_radius_"]')
|
50
|
-
|
51
|
-
expect(skeletonItem).toHaveClass('border_radius_lg')
|
52
|
-
expect(skeletonItem).toHaveClass('dark')
|
53
|
-
})
|
54
|
-
|
55
|
-
it('applies gap class to items after first one', () => {
|
56
|
-
const props = {
|
57
|
-
...defaultProps,
|
58
|
-
stack: 3,
|
59
|
-
gap: 'md'
|
60
|
-
}
|
61
|
-
const { container } = render(<SkeletonLoading {...props} />)
|
62
|
-
const skeletonItems = container.querySelectorAll('div[class*="border_radius_"]')
|
63
|
-
|
64
|
-
expect(skeletonItems[0]).not.toHaveClass('gap_md')
|
65
|
-
expect(skeletonItems[1]).toHaveClass('gap_md')
|
66
|
-
expect(skeletonItems[2]).toHaveClass('gap_md')
|
67
|
-
})
|
68
|
-
|
69
|
-
it('handles no gap properly', () => {
|
70
|
-
const props = {
|
71
|
-
...defaultProps,
|
72
|
-
stack: 2,
|
73
|
-
gap: 'none'
|
74
|
-
}
|
75
|
-
const { container } = render(<SkeletonLoading {...props} />)
|
76
|
-
const skeletonItems = container.querySelectorAll('div[class*="border_radius_"]')
|
77
|
-
|
78
|
-
expect(skeletonItems[0]).not.toHaveClass('gap_none')
|
79
|
-
expect(skeletonItems[1]).not.toHaveClass('gap_none')
|
80
|
-
})
|
81
|
-
})
|
@@ -1,43 +0,0 @@
|
|
1
|
-
<%= pb_rails("timeline", props: {orientation: "horizontal", show_date: true}) do %>
|
2
|
-
<%= pb_rails("timeline/item", props: { line_style: "solid"}) do |item| %>
|
3
|
-
|
4
|
-
<% item.label do %>
|
5
|
-
<%= pb_rails("timeline/label") do %>
|
6
|
-
<%= pb_rails("title", props: { text: "Any Kit Here", size: 2 }) %>
|
7
|
-
<% end %>
|
8
|
-
<% end %>
|
9
|
-
|
10
|
-
<% item.step do %>
|
11
|
-
<%= pb_rails("timeline/step", props: { icon: 'check', icon_color: 'teal' }) %>
|
12
|
-
<% end %>
|
13
|
-
|
14
|
-
<% item.detail do %>
|
15
|
-
<%= pb_rails("title_detail", props: {
|
16
|
-
title: "Jackson Heights",
|
17
|
-
detail: "37-27 74th Street"
|
18
|
-
}) %>
|
19
|
-
<% end %>
|
20
|
-
<% end %>
|
21
|
-
<%= pb_rails("timeline/item", props: { line_style: "dotted"}) do |item| %>
|
22
|
-
|
23
|
-
<% item.step do %>
|
24
|
-
<%= pb_rails("timeline/step") do %>
|
25
|
-
<%= pb_rails("pill", props: { text: "Any Kit" , variant: "success" }) %>
|
26
|
-
<% end %>
|
27
|
-
<% end %>
|
28
|
-
|
29
|
-
<% item.detail do %>
|
30
|
-
<%= pb_rails("title_detail", props: {
|
31
|
-
title: "Greenpoint",
|
32
|
-
detail: "81 Gate St Brooklyn"
|
33
|
-
}) %>
|
34
|
-
<% end %>
|
35
|
-
<% end %>
|
36
|
-
|
37
|
-
<%= pb_rails("timeline/item", props: {icon: "map-marker-alt", icon_color: "purple", date: Date.today+1 }) do |item| %>
|
38
|
-
<%= pb_rails("title_detail", props: {
|
39
|
-
title: "Society Hill",
|
40
|
-
detail: "72 E St Astoria"
|
41
|
-
}) %>
|
42
|
-
<% end %>
|
43
|
-
<% end %>
|
@@ -1,68 +0,0 @@
|
|
1
|
-
import React from 'react'
|
2
|
-
|
3
|
-
import Timeline from '../_timeline'
|
4
|
-
import Title from '../../pb_title/_title'
|
5
|
-
import Pill from '../../pb_pill/_pill'
|
6
|
-
|
7
|
-
import TitleDetail from '../../pb_title_detail/_title_detail'
|
8
|
-
|
9
|
-
const TimelineWithChildren = (props) => (
|
10
|
-
<div>
|
11
|
-
<Timeline orientation="horizontal"
|
12
|
-
showDate
|
13
|
-
{...props}
|
14
|
-
>
|
15
|
-
<Timeline.Item lineStyle="solid"
|
16
|
-
{...props}
|
17
|
-
>
|
18
|
-
<Timeline.Label>
|
19
|
-
<Title size={2}
|
20
|
-
text='Any Kit Here'
|
21
|
-
/>
|
22
|
-
</Timeline.Label>
|
23
|
-
<Timeline.Step icon="user"
|
24
|
-
iconColor="royal"
|
25
|
-
/>
|
26
|
-
<Timeline.Detail>
|
27
|
-
<TitleDetail detail="37-27 74th Street"
|
28
|
-
title="Jackson Heights"
|
29
|
-
{...props}
|
30
|
-
/>
|
31
|
-
</Timeline.Detail>
|
32
|
-
</Timeline.Item>
|
33
|
-
|
34
|
-
<Timeline.Item lineStyle="dotted"
|
35
|
-
{...props}
|
36
|
-
>
|
37
|
-
<Timeline.Step>
|
38
|
-
<Pill text="Any Kit"
|
39
|
-
variant="success"
|
40
|
-
/>
|
41
|
-
</Timeline.Step>
|
42
|
-
<Timeline.Detail>
|
43
|
-
<TitleDetail detail="81 Gate St Brooklyn"
|
44
|
-
title="Greenpoint"
|
45
|
-
{...props}
|
46
|
-
/>
|
47
|
-
</Timeline.Detail>
|
48
|
-
</Timeline.Item>
|
49
|
-
|
50
|
-
<Timeline.Item lineStyle="solid"
|
51
|
-
{...props}
|
52
|
-
>
|
53
|
-
<Timeline.Label date={new Date(new Date().setDate(new Date().getDate() + 1))} />
|
54
|
-
<Timeline.Step icon="map-marker-alt"
|
55
|
-
iconColor="purple"
|
56
|
-
/>
|
57
|
-
<Timeline.Detail>
|
58
|
-
<TitleDetail detail="72 E St Astoria"
|
59
|
-
title="Society Hill"
|
60
|
-
{...props}
|
61
|
-
/>
|
62
|
-
</Timeline.Detail>
|
63
|
-
</Timeline.Item>
|
64
|
-
</Timeline>
|
65
|
-
</div>
|
66
|
-
)
|
67
|
-
|
68
|
-
export default TimelineWithChildren
|
@@ -1,14 +0,0 @@
|
|
1
|
-
<%= pb_content_tag do %>
|
2
|
-
<% if object.icon.present? %>
|
3
|
-
<%= pb_rails("icon_circle", props: {
|
4
|
-
icon: object.icon,
|
5
|
-
variant: object.icon_color,
|
6
|
-
size: "xs"
|
7
|
-
}) %>
|
8
|
-
<% else %>
|
9
|
-
<%= content.presence %>
|
10
|
-
<% end %>
|
11
|
-
<div class="pb_timeline_item_connector"></div>
|
12
|
-
<% end %>
|
13
|
-
|
14
|
-
|
@@ -1,16 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
module Playbook
|
4
|
-
module PbTimeline
|
5
|
-
class Step < Playbook::KitBase
|
6
|
-
prop :icon, type: Playbook::Props::String
|
7
|
-
prop :icon_color, type: Playbook::Props::Enum,
|
8
|
-
values: %w[default royal blue purple teal red yellow green],
|
9
|
-
default: "default"
|
10
|
-
|
11
|
-
def classname
|
12
|
-
generate_classname("pb_timeline_item_step")
|
13
|
-
end
|
14
|
-
end
|
15
|
-
end
|
16
|
-
end
|
@@ -1,29 +0,0 @@
|
|
1
|
-
import React from 'react'
|
2
|
-
import classnames from 'classnames'
|
3
|
-
import { buildHtmlProps } from '../../utilities/props'
|
4
|
-
import { globalProps, GlobalProps } from "../../utilities/globalProps"
|
5
|
-
|
6
|
-
type TimelineDetailProps = {
|
7
|
-
children?: React.ReactNode,
|
8
|
-
className?: string,
|
9
|
-
htmlOptions?: { [key: string]: any },
|
10
|
-
} & GlobalProps
|
11
|
-
|
12
|
-
const TimelineDetail: React.FC<TimelineDetailProps> = ({
|
13
|
-
children,
|
14
|
-
className,
|
15
|
-
htmlOptions = {},
|
16
|
-
...props
|
17
|
-
}) => {
|
18
|
-
const htmlProps = buildHtmlProps(htmlOptions)
|
19
|
-
return (
|
20
|
-
<div
|
21
|
-
{...htmlProps}
|
22
|
-
className={classnames('pb_timeline_item_right_block', globalProps(props), className)}
|
23
|
-
>
|
24
|
-
{children}
|
25
|
-
</div>
|
26
|
-
)
|
27
|
-
}
|
28
|
-
|
29
|
-
export default TimelineDetail
|
@@ -1,38 +0,0 @@
|
|
1
|
-
import React from 'react'
|
2
|
-
import classnames from 'classnames'
|
3
|
-
import { buildHtmlProps } from '../../utilities/props'
|
4
|
-
import { globalProps, GlobalProps } from "../../utilities/globalProps"
|
5
|
-
import DateStacked from '../../pb_date_stacked/_date_stacked'
|
6
|
-
|
7
|
-
type TimelineLabelProps = {
|
8
|
-
date?: Date,
|
9
|
-
children?: React.ReactNode,
|
10
|
-
className?: string,
|
11
|
-
htmlOptions?: { [key: string]: any },
|
12
|
-
} & GlobalProps
|
13
|
-
|
14
|
-
const TimelineLabel: React.FC<TimelineLabelProps> = ({
|
15
|
-
date,
|
16
|
-
children,
|
17
|
-
className,
|
18
|
-
htmlOptions = {},
|
19
|
-
...props
|
20
|
-
}) => {
|
21
|
-
const htmlProps = buildHtmlProps(htmlOptions)
|
22
|
-
return (
|
23
|
-
<div
|
24
|
-
{...htmlProps}
|
25
|
-
className={classnames('pb_timeline_item_left_block', globalProps(props), className)}
|
26
|
-
>
|
27
|
-
{children}
|
28
|
-
{date && (
|
29
|
-
<DateStacked align="center"
|
30
|
-
date={date}
|
31
|
-
size="sm"
|
32
|
-
/>
|
33
|
-
)}
|
34
|
-
</div>
|
35
|
-
)
|
36
|
-
}
|
37
|
-
|
38
|
-
export default TimelineLabel
|
@@ -1,42 +0,0 @@
|
|
1
|
-
import React from 'react'
|
2
|
-
import classnames from 'classnames'
|
3
|
-
import { buildHtmlProps } from '../../utilities/props'
|
4
|
-
import { globalProps, GlobalProps } from "../../utilities/globalProps"
|
5
|
-
import IconCircle from '../../pb_icon_circle/_icon_circle'
|
6
|
-
|
7
|
-
type TimelineStepProps = {
|
8
|
-
icon?: string,
|
9
|
-
iconColor?: 'default' | 'royal' | 'blue' | 'purple' | 'teal' | 'red' | 'yellow' | 'green',
|
10
|
-
children?: React.ReactNode,
|
11
|
-
className?: string,
|
12
|
-
htmlOptions?: { [key: string]: any },
|
13
|
-
} & GlobalProps
|
14
|
-
|
15
|
-
const TimelineStep: React.FC<TimelineStepProps> = ({
|
16
|
-
icon = 'user',
|
17
|
-
iconColor = 'default',
|
18
|
-
children,
|
19
|
-
className,
|
20
|
-
htmlOptions = {},
|
21
|
-
...props
|
22
|
-
}) => {
|
23
|
-
const htmlProps = buildHtmlProps(htmlOptions)
|
24
|
-
return (
|
25
|
-
<div
|
26
|
-
{...htmlProps}
|
27
|
-
className={classnames('pb_timeline_item_step', globalProps(props), className)}
|
28
|
-
>
|
29
|
-
{children ? (
|
30
|
-
children
|
31
|
-
) : (
|
32
|
-
<IconCircle icon={icon}
|
33
|
-
size="xs"
|
34
|
-
variant={iconColor}
|
35
|
-
/>
|
36
|
-
)}
|
37
|
-
<div className="pb_timeline_item_connector" />
|
38
|
-
</div>
|
39
|
-
)
|
40
|
-
}
|
41
|
-
|
42
|
-
export default TimelineStep
|