playbook_ui 14.0.0.pre.alpha.play1447alphatest3462 → 14.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (94) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/pb_advanced_table/Components/TableHeaderCell.tsx +2 -5
  3. data/app/pb_kits/playbook/pb_advanced_table/SubKits/TableBody.tsx +20 -24
  4. data/app/pb_kits/playbook/pb_advanced_table/SubKits/TableHeader.tsx +12 -17
  5. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +1 -86
  6. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +1 -5
  7. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.test.jsx +0 -30
  8. data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +0 -1
  9. data/app/pb_kits/playbook/pb_advanced_table/docs/index.js +1 -2
  10. data/app/pb_kits/playbook/pb_avatar/_avatar.scss +30 -0
  11. data/app/pb_kits/playbook/pb_avatar/_avatar.tsx +1 -19
  12. data/app/pb_kits/playbook/pb_avatar/avatar.rb +1 -44
  13. data/app/pb_kits/playbook/pb_avatar/avatar.test.js +0 -17
  14. data/app/pb_kits/playbook/pb_date_picker/docs/_description.md +1 -3
  15. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/_fixed_confirmation_toast.scss +1 -1
  16. data/app/pb_kits/playbook/pb_form/docs/_form_form_with.html.erb +0 -1
  17. data/app/pb_kits/playbook/pb_icon/_icon.tsx +0 -3
  18. data/app/pb_kits/playbook/pb_icon/icon.rb +0 -2
  19. data/app/pb_kits/playbook/pb_icon_circle/_icon_circle.tsx +1 -2
  20. data/app/pb_kits/playbook/pb_icon_circle/icon_circle.rb +2 -2
  21. data/app/pb_kits/playbook/pb_icon_stat_value/_icon_stat_value.scss +11 -0
  22. data/app/pb_kits/playbook/pb_icon_stat_value/_icon_stat_value.tsx +2 -3
  23. data/app/pb_kits/playbook/pb_icon_stat_value/docs/_icon_stat_value_color.html.erb +0 -1
  24. data/app/pb_kits/playbook/pb_icon_stat_value/icon_stat_value.rb +2 -2
  25. data/app/pb_kits/playbook/pb_icon_stat_value/icon_stat_value.test.js +4 -5
  26. data/app/pb_kits/playbook/pb_map/docs/_map_default.md +2 -2
  27. data/app/pb_kits/playbook/pb_nav/_horizontal_nav.scss +1 -1
  28. data/app/pb_kits/playbook/pb_online_status/_online_status.scss +5 -52
  29. data/app/pb_kits/playbook/pb_online_status/_online_status.tsx +1 -6
  30. data/app/pb_kits/playbook/pb_online_status/_online_status_mixins.scss +32 -0
  31. data/app/pb_kits/playbook/pb_online_status/docs/example.yml +2 -6
  32. data/app/pb_kits/playbook/pb_online_status/docs/index.js +0 -2
  33. data/app/pb_kits/playbook/pb_online_status/online_status.rb +1 -11
  34. data/app/pb_kits/playbook/pb_overlay/docs/example.yml +2 -4
  35. data/app/pb_kits/playbook/pb_overlay/docs/index.js +0 -1
  36. data/app/pb_kits/playbook/pb_star_rating/_star_rating.scss +6 -83
  37. data/app/pb_kits/playbook/pb_star_rating/docs/example.yml +1 -3
  38. data/app/pb_kits/playbook/pb_star_rating/index.js +4 -73
  39. data/app/pb_kits/playbook/pb_star_rating/star_rating.html.erb +1 -1
  40. data/app/pb_kits/playbook/pb_star_rating/star_rating.rb +2 -2
  41. data/app/pb_kits/playbook/pb_star_rating/stars/utils.tsx +1 -5
  42. data/app/pb_kits/playbook/pb_star_rating/subcomponents/_star_rating_interactive.tsx +21 -50
  43. data/app/pb_kits/playbook/pb_table/_table.tsx +1 -1
  44. data/app/pb_kits/playbook/pb_table/index.ts +4 -4
  45. data/app/pb_kits/playbook/pb_table/subcomponents/_table_body.tsx +1 -1
  46. data/app/pb_kits/playbook/pb_table/subcomponents/_table_cell.tsx +1 -1
  47. data/app/pb_kits/playbook/pb_table/subcomponents/_table_head.tsx +1 -1
  48. data/app/pb_kits/playbook/pb_table/subcomponents/_table_header.tsx +1 -1
  49. data/app/pb_kits/playbook/pb_table/subcomponents/_table_row.tsx +1 -1
  50. data/app/pb_kits/playbook/pb_table/table.test.js +0 -2
  51. data/app/pb_kits/playbook/pb_text_input/_text_input.tsx +1 -1
  52. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_default.jsx +1 -1
  53. data/app/pb_kits/playbook/pb_textarea/_textarea.tsx +27 -45
  54. data/app/pb_kits/playbook/pb_textarea/index.ts +3 -3
  55. data/app/pb_kits/playbook/pb_time/_time.tsx +3 -3
  56. data/app/pb_kits/playbook/pb_time_range_inline/_time_range_inline.tsx +1 -1
  57. data/app/pb_kits/playbook/pb_timeline/_item.tsx +1 -1
  58. data/app/pb_kits/playbook/pb_timeline/_timeline.tsx +1 -1
  59. data/app/pb_kits/playbook/pb_title_detail/_title_detail.tsx +10 -10
  60. data/app/pb_kits/playbook/pb_toggle/_toggle.tsx +1 -1
  61. data/app/pb_kits/playbook/pb_tooltip/_tooltip.tsx +2 -2
  62. data/app/pb_kits/playbook/pb_treemap_chart/_treemap_chart.tsx +2 -1
  63. data/app/pb_kits/playbook/pb_treemap_chart/treemapChart.test.js +0 -2
  64. data/app/pb_kits/playbook/pb_typeahead/_typeahead.tsx +2 -2
  65. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_multi_kit.html.erb +1 -1
  66. data/app/pb_kits/playbook/pb_typeahead/typeahead.rb +0 -1
  67. data/app/pb_kits/playbook/pb_user/_user.tsx +1 -1
  68. data/app/pb_kits/playbook/pb_user_badge/_user_badge.tsx +6 -6
  69. data/app/pb_kits/playbook/pb_user_badge/badges/million-dollar.tsx +235 -236
  70. data/app/pb_kits/playbook/pb_user_badge/badges/veteran.tsx +1 -1
  71. data/app/pb_kits/playbook/pb_walkthrough/_walkthrough.tsx +63 -68
  72. data/app/pb_kits/playbook/pb_weekday_stacked/_weekday_stacked.tsx +1 -1
  73. data/app/pb_kits/playbook/utilities/_positioning.scss +15 -26
  74. data/dist/chunks/{_typeahead-D6PRvP-1.js → _typeahead-COUJ88EA.js} +2 -2
  75. data/dist/chunks/{_weekday_stacked-Dzgi_IL5.js → _weekday_stacked-BAkwel5p.js} +2 -2
  76. data/dist/chunks/{lib-BE0Z3F7x.js → lib-Bf_E03gc.js} +1 -1
  77. data/dist/chunks/{pb_form_validation-TzZQ0Flx.js → pb_form_validation-D0dhqeN2.js} +1 -1
  78. data/dist/chunks/vendor.js +1 -1
  79. data/dist/playbook-doc.js +1 -1
  80. data/dist/playbook-rails-react-bindings.js +1 -1
  81. data/dist/playbook-rails.js +1 -1
  82. data/dist/playbook.css +1 -1
  83. data/lib/playbook/version.rb +2 -2
  84. metadata +10 -19
  85. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_responsive.jsx +0 -67
  86. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_responsive.md +0 -1
  87. data/app/pb_kits/playbook/pb_online_status/docs/_online_status_no_border.html.erb +0 -1
  88. data/app/pb_kits/playbook/pb_online_status/docs/_online_status_no_border.jsx +0 -14
  89. data/app/pb_kits/playbook/pb_online_status/docs/_online_status_size.html.erb +0 -3
  90. data/app/pb_kits/playbook/pb_online_status/docs/_online_status_size.jsx +0 -25
  91. data/app/pb_kits/playbook/pb_online_status/online_status.test.js +0 -31
  92. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_toggle.html.erb +0 -61
  93. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_toggle.jsx +0 -70
  94. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_toggle.md +0 -1
@@ -17,7 +17,7 @@ type TableHeadPropTypes = {
17
17
  tag?: "table" | "div";
18
18
  };
19
19
 
20
- const TableHead = (props: TableHeadPropTypes): React.ReactElement => {
20
+ const TableHead = (props: TableHeadPropTypes) => {
21
21
  const {
22
22
  aria = {},
23
23
  children,
@@ -18,7 +18,7 @@ type TableHeaderPropTypes = {
18
18
  text?: string;
19
19
  };
20
20
 
21
- const TableHeader = (props: TableHeaderPropTypes): React.ReactElement => {
21
+ const TableHeader = (props: TableHeaderPropTypes) => {
22
22
  const {
23
23
  aria = {},
24
24
  children,
@@ -19,7 +19,7 @@ type TableRowPropTypes = {
19
19
  tag?: "table" | "div";
20
20
  };
21
21
 
22
- const TableRow = (props: TableRowPropTypes): React.ReactElement => {
22
+ const TableRow = (props: TableRowPropTypes) => {
23
23
  const {
24
24
  aria = {},
25
25
  children,
@@ -1,5 +1,3 @@
1
- /* eslint-disable react/no-multi-comp */
2
-
3
1
  import React from "react";
4
2
  import { ensureAccessible, renderKit, render, screen } from "../utilities/test-utils"
5
3
 
@@ -107,7 +107,7 @@ const TextInput = (props: TextInputProps, ref: React.LegacyRef<HTMLInputElement>
107
107
  required={required}
108
108
  type={type}
109
109
  value={value}
110
- />)
110
+ />)
111
111
  )
112
112
 
113
113
  const addOnInput = (
@@ -5,12 +5,12 @@ import TextInput from '../../pb_text_input/_text_input'
5
5
  import Title from '../../pb_title/_title'
6
6
 
7
7
  const TextInputDefault = (props) => {
8
- const [firstName, setFirstName] = useState('')
9
8
  const handleOnChangeFirstName = ({ target }) => {
10
9
  setFirstName(target.value)
11
10
  }
12
11
  const ref = React.createRef()
13
12
 
13
+ const [firstName, setFirstName] = useState('')
14
14
  const [formFields, setFormFields] = useState({
15
15
  firstName: 'Jane',
16
16
  lastName: 'Doe',
@@ -52,15 +52,14 @@ const Textarea = ({
52
52
  label,
53
53
  maxCharacters,
54
54
  name,
55
- // eslint-disable-next-line @typescript-eslint/no-empty-function
56
55
  onChange = () => {},
57
56
  placeholder,
58
57
  required,
59
58
  rows = 4,
60
59
  value,
61
60
  ...props
62
- }: TextareaProps) => {
63
- const ref = useRef<HTMLTextAreaElement>(null)
61
+ }: TextareaProps, ref: any) => {
62
+ ref = useRef<HTMLTextAreaElement>(null)
64
63
  useEffect(() => {
65
64
  if (ref.current && resize === 'auto') {
66
65
  PbTextarea.addMatch(ref.current)
@@ -72,75 +71,58 @@ const Textarea = ({
72
71
  const resizeClass = `resize_${resize}`
73
72
  const classes = classnames('pb_textarea_kit', errorClass, inlineClass, resizeClass, globalProps(props), className)
74
73
  const noCount = typeof characterCount !== 'undefined'
75
- const ariaProps: {[key: string]: string} = buildAriaProps(aria)
76
- const dataProps: {[key: string]: string} = buildDataProps(data)
74
+ const ariaProps: {[key: string]: any} = buildAriaProps(aria)
75
+ const dataProps: {[key: string]: any} = buildDataProps(data)
77
76
  const htmlProps = buildHtmlProps(htmlOptions)
78
- const checkIfZero = (characterCount: string | number) => {
79
- return characterCount == 0 ? characterCount.toString() : characterCount
80
- }
81
77
  const characterCounter = () => {
82
78
  return maxCharacters && characterCount ? `${checkIfZero(characterCount)} / ${maxCharacters}` : `${checkIfZero(characterCount)}`
83
79
  }
84
80
 
81
+ const checkIfZero = (characterCount: string | number) => {
82
+ return characterCount == 0 ? characterCount.toString() : characterCount
83
+ }
84
+
85
85
  return (
86
86
  <div
87
- {...ariaProps}
88
- {...dataProps}
89
- {...htmlProps}
90
- className={classes}
87
+ {...ariaProps}
88
+ {...dataProps}
89
+ {...htmlProps}
90
+ className={classes}
91
91
  >
92
92
  <Caption text={label} />
93
93
  {children || (
94
94
  <textarea
95
- className="pb_textarea_kit"
96
- disabled={disabled}
97
- name={name}
98
- onChange={onChange}
99
- placeholder={placeholder}
100
- ref={ref}
101
- required={required}
102
- rows={rows}
103
- value={value}
104
- {...props}
95
+ className="pb_textarea_kit"
96
+ disabled={disabled}
97
+ name={name}
98
+ onChange={onChange}
99
+ placeholder={placeholder}
100
+ ref={ref}
101
+ required={required}
102
+ rows={rows}
103
+ value={value}
104
+ {...props}
105
105
  />
106
106
  )}
107
107
 
108
108
  {error ? (
109
109
  <>
110
110
  {characterCount ? (
111
- <Flex
112
- spacing="between"
113
- vertical="center"
114
- >
111
+ <Flex spacing="between" vertical="center">
115
112
  <FlexItem>
116
- <Body
117
- margin="none"
118
- status="negative"
119
- text={error}
120
- />
113
+ <Body margin="none" status="negative" text={error} />
121
114
  </FlexItem>
122
115
  <FlexItem>
123
- <Caption
124
- margin="none"
125
- size="xs"
126
- text={characterCounter()}
127
- />
116
+ <Caption margin="none" size="xs" text={characterCounter()} />
128
117
  </FlexItem>
129
118
  </Flex>
130
119
  ) : (
131
- <Body
132
- status="negative"
133
- text={error}
134
- />
120
+ <Body status="negative" text={error} />
135
121
  )}
136
122
  </>
137
123
  ) : (
138
124
  noCount && (
139
- <Caption
140
- margin="none"
141
- size="xs"
142
- text={characterCounter()}
143
- />
125
+ <Caption margin="none" size="xs" text={characterCounter()} />
144
126
  )
145
127
  )}
146
128
  </div>
@@ -3,16 +3,16 @@ import PbEnhancedElement from '../pb_enhanced_element'
3
3
  export default class PbTextarea extends PbEnhancedElement {
4
4
  style: {[key: string]: string}
5
5
  scrollHeight: string
6
- static get selector(): string {
6
+ static get selector() {
7
7
  return '.resize_auto textarea'
8
8
  }
9
9
 
10
- onInput(): void {
10
+ onInput() {
11
11
  this.style.height = 'auto'
12
12
  this.style.height = (this.scrollHeight) + 'px'
13
13
  }
14
14
 
15
- connect(): void {
15
+ connect() {
16
16
  this.element.setAttribute('style', 'height:' + (this.element.scrollHeight) + 'px;overflow-y:hidden;')
17
17
  this.element.addEventListener('input', this.onInput, false)
18
18
  }
@@ -24,7 +24,7 @@ type TimeProps = {
24
24
  unstyled?: boolean;
25
25
  } & GlobalProps
26
26
 
27
- const Time = (props: TimeProps): React.ReactElement => {
27
+ const Time = (props: TimeProps) => {
28
28
  const {
29
29
  align,
30
30
  className,
@@ -47,8 +47,8 @@ const Time = (props: TimeProps): React.ReactElement => {
47
47
 
48
48
  return (
49
49
  <div
50
- {...htmlProps}
51
- className={classes}
50
+ {...htmlProps}
51
+ className={classes}
52
52
  >
53
53
  {showIcon && (
54
54
  unstyled
@@ -36,7 +36,7 @@ const dateTimeIso = (dateValue: Date) => {
36
36
  return DateTime.toIso(dateValue)
37
37
  }
38
38
 
39
- const TimeRangeInline = (props: TimeRangeInlineProps): React.ReactElement => {
39
+ const TimeRangeInline = (props: TimeRangeInlineProps) => {
40
40
  const {
41
41
  aria = {},
42
42
  className,
@@ -26,7 +26,7 @@ const TimelineItem = ({
26
26
  iconColor = 'default',
27
27
  lineStyle = 'solid',
28
28
  ...props
29
- }: ItemProps): React.ReactElement => {
29
+ }: ItemProps) => {
30
30
  const timelineItemCss = buildCss('pb_timeline_item_kit', lineStyle)
31
31
 
32
32
  const htmlProps = buildHtmlProps(htmlOptions)
@@ -27,7 +27,7 @@ const Timeline = ({
27
27
  orientation = 'horizontal',
28
28
  showDate = false,
29
29
  ...props
30
- }: TimelineProps): React.ReactElement => {
30
+ }: TimelineProps) => {
31
31
  const ariaProps = buildAriaProps(aria)
32
32
  const dataProps = buildDataProps(data)
33
33
  const htmlProps = buildHtmlProps(htmlOptions)
@@ -18,7 +18,7 @@ type TitleDetailProps = {
18
18
  title: string,
19
19
  } & GlobalProps
20
20
 
21
- const TitleDetail = (props: TitleDetailProps): React.ReactElement => {
21
+ const TitleDetail = (props: TitleDetailProps) => {
22
22
  const {
23
23
  align = "left",
24
24
  aria = {},
@@ -37,19 +37,19 @@ const TitleDetail = (props: TitleDetailProps): React.ReactElement => {
37
37
 
38
38
  return (
39
39
  <div
40
- {...ariaProps}
41
- {...dataProps}
42
- {...htmlProps}
43
- className={classnames(pbCss, globalProps(props), className)}
44
- id={id}
40
+ {...ariaProps}
41
+ {...dataProps}
42
+ {...htmlProps}
43
+ className={classnames(pbCss, globalProps(props), className)}
44
+ id={id}
45
45
  >
46
46
  <Title
47
- size={4}
48
- text={title}
47
+ size={4}
48
+ text={title}
49
49
  />
50
50
  <Body
51
- color="light"
52
- text={detail}
51
+ color="light"
52
+ text={detail}
53
53
  />
54
54
  </div>
55
55
  )
@@ -42,7 +42,7 @@ const Toggle = ({
42
42
  size = 'sm',
43
43
  value,
44
44
  ...props
45
- }: Props): React.ReactElement => {
45
+ }: Props) => {
46
46
  const ariaProps = buildAriaProps(aria)
47
47
  const dataProps = buildDataProps(data)
48
48
  const htmlProps = buildHtmlProps(htmlOptions)
@@ -50,8 +50,8 @@ const Tooltip = forwardRef((props: TooltipProps, ref: ForwardedRef<unknown>): Re
50
50
  ...rest
51
51
  } = props
52
52
 
53
- const dataProps: { [key: string]: string } = buildDataProps(data)
54
- const ariaProps: { [key: string]: string } = buildAriaProps(aria)
53
+ const dataProps: { [key: string]: any } = buildDataProps(data)
54
+ const ariaProps: { [key: string]: any } = buildAriaProps(aria)
55
55
  const htmlProps = buildHtmlProps(htmlOptions)
56
56
 
57
57
  const css = classnames(
@@ -52,7 +52,7 @@ const TreemapChart = ({
52
52
  tooltipHtml = '<span style="font-weight: bold; color:{point.color};">●</span>{point.name}: <b>{point.value}</b>',
53
53
  type = "treemap",
54
54
  ...props
55
- }: TreemapChartProps): React.ReactElement => {
55
+ }: TreemapChartProps) => {
56
56
 
57
57
  const ariaProps = buildAriaProps(aria)
58
58
  const dataProps = buildDataProps(data)
@@ -98,6 +98,7 @@ const TreemapChart = ({
98
98
  const [options, setOptions] = useState({});
99
99
 
100
100
  useEffect(() => {
101
+
101
102
  setOptions(merge(staticOptions, customOptions));
102
103
  }, [chartData]);
103
104
 
@@ -1,5 +1,3 @@
1
- /* eslint-disable no-console */
2
-
3
1
  import React from 'react';
4
2
  import { render, screen } from '../utilities/test-utils';
5
3
  import TreemapChart from './_treemap_chart';
@@ -4,7 +4,7 @@ import AsyncSelect from 'react-select/async'
4
4
  import CreateableSelect from 'react-select/creatable'
5
5
  import AsyncCreateableSelect from 'react-select/async-creatable'
6
6
  import { get, isString, uniqueId } from 'lodash'
7
- import { globalProps, GlobalProps } from '../utilities/globalProps'
7
+ import { globalProps } from '../utilities/globalProps'
8
8
  import classnames from 'classnames'
9
9
 
10
10
  import {
@@ -45,7 +45,7 @@ type TypeaheadProps = {
45
45
  getOptionLabel?: string | (() => any),
46
46
  getOptionValue?: string | (() => any),
47
47
  name?: string,
48
- } & GlobalProps
48
+ }
49
49
 
50
50
  export type SelectValueType = {
51
51
  label: string,
@@ -31,5 +31,5 @@
31
31
  options: expressionists,
32
32
  label: "Small Pills",
33
33
  multi_kit: "smallPill",
34
- pills: true
34
+ pills: true,
35
35
  }) %>
@@ -57,7 +57,6 @@ module Playbook
57
57
 
58
58
  def typeahead_react_options
59
59
  base_options = {
60
- className: classname,
61
60
  dark: dark,
62
61
  defaultValue: default_options,
63
62
  error: error,
@@ -26,7 +26,7 @@ type UserProps = {
26
26
  title?: string,
27
27
  } & GlobalProps
28
28
 
29
- const User = (props: UserProps): React.ReactElement => {
29
+ const User = (props: UserProps) => {
30
30
  const {
31
31
  align = 'left',
32
32
  aria = {},
@@ -15,7 +15,7 @@ type UserBadgeProps = {
15
15
  size?: "sm" | "md" | "lg",
16
16
  }
17
17
 
18
- const UserBadge = (props: UserBadgeProps): React.ReactElement => {
18
+ const UserBadge = (props: UserBadgeProps) => {
19
19
  const {
20
20
  aria = {},
21
21
  badge = 'million-dollar',
@@ -38,11 +38,11 @@ const UserBadge = (props: UserBadgeProps): React.ReactElement => {
38
38
 
39
39
  return (
40
40
  <div
41
- {...ariaProps}
42
- {...dataProps}
43
- {...htmlProps}
44
- className={classes}
45
- id={id}
41
+ {...ariaProps}
42
+ {...dataProps}
43
+ {...htmlProps}
44
+ className={classes}
45
+ id={id}
46
46
  >
47
47
  <div className="pb_user_badge_wrapper">
48
48
  {image}