playbook_ui 9.11.0 → 9.14.1.alpha.radio.alignment

Sign up to get free protection for your applications and to get access to all the features.
Files changed (102) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/_playbook.scss +1 -0
  3. data/app/pb_kits/playbook/data/menu.yml +26 -22
  4. data/app/pb_kits/playbook/index.js +1 -0
  5. data/app/pb_kits/playbook/pb_badge/_badge.jsx +26 -1
  6. data/app/pb_kits/playbook/pb_badge/_badge.scss +1 -1
  7. data/app/pb_kits/playbook/pb_bread_crumbs/_bread_crumb_item.jsx +51 -0
  8. data/app/pb_kits/playbook/pb_bread_crumbs/_bread_crumbs.jsx +49 -0
  9. data/app/pb_kits/playbook/pb_bread_crumbs/_bread_crumbs.scss +55 -0
  10. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumb_item.html.erb +9 -0
  11. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumb_item.rb +12 -0
  12. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumbs.html.erb +7 -0
  13. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumbs.rb +11 -0
  14. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumbs.test.js +35 -0
  15. data/app/pb_kits/playbook/pb_bread_crumbs/docs/_bread_crumbs_default.html.erb +17 -0
  16. data/app/pb_kits/playbook/pb_bread_crumbs/docs/_bread_crumbs_default.jsx +56 -0
  17. data/app/pb_kits/playbook/pb_bread_crumbs/docs/_description.md +1 -0
  18. data/app/pb_kits/playbook/pb_bread_crumbs/docs/example.yml +7 -0
  19. data/app/pb_kits/playbook/pb_bread_crumbs/docs/index.js +1 -0
  20. data/app/pb_kits/playbook/pb_button/button.rb +1 -1
  21. data/app/pb_kits/playbook/pb_date_picker/_date_picker.jsx +6 -1
  22. data/app/pb_kits/playbook/pb_date_picker/date_picker_helper.js +3 -0
  23. data/app/pb_kits/playbook/pb_date_stacked/_date_stacked.jsx +45 -11
  24. data/app/pb_kits/playbook/pb_date_stacked/date_stacked.html.erb +17 -6
  25. data/app/pb_kits/playbook/pb_date_stacked/date_stacked.rb +12 -5
  26. data/app/pb_kits/playbook/pb_date_stacked/docs/_date_stacked_bold.html.erb +5 -0
  27. data/app/pb_kits/playbook/pb_date_stacked/docs/_date_stacked_bold.jsx +38 -0
  28. data/app/pb_kits/playbook/pb_date_stacked/docs/example.yml +3 -1
  29. data/app/pb_kits/playbook/pb_date_stacked/docs/index.js +1 -0
  30. data/app/pb_kits/playbook/pb_date_time_stacked/_date_time_stacked.jsx +32 -16
  31. data/app/pb_kits/playbook/pb_date_time_stacked/_date_time_stacked.scss +23 -4
  32. data/app/pb_kits/playbook/pb_date_time_stacked/date_time_stacked.html.erb +12 -8
  33. data/app/pb_kits/playbook/pb_date_time_stacked/date_time_stacked.rb +9 -2
  34. data/app/pb_kits/playbook/pb_date_time_stacked/date_time_stacked.test.js +35 -0
  35. data/app/pb_kits/playbook/pb_date_time_stacked/docs/_date_time_stacked_default.html.erb +8 -1
  36. data/app/pb_kits/playbook/pb_date_time_stacked/docs/_date_time_stacked_default.jsx +19 -1
  37. data/app/pb_kits/playbook/pb_dialog/dialog.test.jsx +1 -1
  38. data/app/pb_kits/playbook/pb_flex/_flex.jsx +6 -1
  39. data/app/pb_kits/playbook/pb_form_pill/_form_pill.jsx +12 -2
  40. data/app/pb_kits/playbook/pb_form_pill/_form_pill.scss +19 -0
  41. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_size.html.erb +13 -0
  42. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_size.jsx +25 -0
  43. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_user.html.erb +4 -5
  44. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_user.jsx +2 -6
  45. data/app/pb_kits/playbook/pb_form_pill/docs/example.yml +2 -0
  46. data/app/pb_kits/playbook/pb_form_pill/docs/index.js +1 -0
  47. data/app/pb_kits/playbook/pb_form_pill/form_pill.html.erb +1 -1
  48. data/app/pb_kits/playbook/pb_form_pill/form_pill.rb +5 -0
  49. data/app/pb_kits/playbook/pb_multiple_users_stacked/_multiple_users_stacked.scss +6 -2
  50. data/app/pb_kits/playbook/pb_passphrase/_passphrase.jsx +14 -11
  51. data/app/pb_kits/playbook/pb_passphrase/_passphrase.scss +18 -13
  52. data/app/pb_kits/playbook/pb_pill/_pill.jsx +1 -0
  53. data/app/pb_kits/playbook/pb_pill/pill.html.erb +1 -1
  54. data/app/pb_kits/playbook/pb_radio/_radio.jsx +3 -1
  55. data/app/pb_kits/playbook/pb_radio/_radio.scss +10 -0
  56. data/app/pb_kits/playbook/pb_radio/docs/_radio_alignment.html.erb +27 -0
  57. data/app/pb_kits/playbook/pb_radio/docs/_radio_alignment.jsx +36 -0
  58. data/app/pb_kits/playbook/pb_radio/docs/example.yml +2 -0
  59. data/app/pb_kits/playbook/pb_radio/docs/index.js +1 -0
  60. data/app/pb_kits/playbook/pb_radio/radio.rb +7 -1
  61. data/app/pb_kits/playbook/pb_rich_text_editor/_rich_text_editor.jsx +10 -0
  62. data/app/pb_kits/playbook/pb_rich_text_editor/_rich_text_editor.scss +61 -0
  63. data/app/pb_kits/playbook/pb_rich_text_editor/docs/_rich_text_editor_inline.html.erb +6 -0
  64. data/app/pb_kits/playbook/pb_rich_text_editor/docs/_rich_text_editor_inline.jsx +16 -0
  65. data/app/pb_kits/playbook/pb_rich_text_editor/docs/_rich_text_editor_toolbar_bottom.html.erb +4 -0
  66. data/app/pb_kits/playbook/pb_rich_text_editor/docs/_rich_text_editor_toolbar_bottom.jsx +14 -0
  67. data/app/pb_kits/playbook/pb_rich_text_editor/docs/example.yml +4 -0
  68. data/app/pb_kits/playbook/pb_rich_text_editor/docs/index.js +2 -0
  69. data/app/pb_kits/playbook/pb_rich_text_editor/rich_text_editor.rb +7 -0
  70. data/app/pb_kits/playbook/pb_section_separator/_section_separator.jsx +7 -3
  71. data/app/pb_kits/playbook/pb_select/_select.jsx +5 -5
  72. data/app/pb_kits/playbook/pb_text_input/_text_input.jsx +83 -31
  73. data/app/pb_kits/playbook/pb_text_input/_text_input.scss +106 -0
  74. data/app/pb_kits/playbook/pb_text_input/add_on.html.erb +13 -0
  75. data/app/pb_kits/playbook/pb_text_input/add_on.rb +30 -0
  76. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_add_on.html.erb +24 -0
  77. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_add_on.jsx +82 -0
  78. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_custom.html.erb +1 -1
  79. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_inline.html.erb +5 -0
  80. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_inline.jsx +22 -0
  81. data/app/pb_kits/playbook/pb_text_input/docs/example.yml +4 -0
  82. data/app/pb_kits/playbook/pb_text_input/docs/index.js +2 -0
  83. data/app/pb_kits/playbook/pb_text_input/text_input.html.erb +7 -16
  84. data/app/pb_kits/playbook/pb_text_input/text_input.rb +43 -3
  85. data/app/pb_kits/playbook/pb_time_stacked/time_stacked.html.erb +2 -2
  86. data/app/pb_kits/playbook/pb_typeahead/_typeahead.jsx +11 -2
  87. data/app/pb_kits/playbook/pb_typeahead/_typeahead.scss +23 -0
  88. data/app/pb_kits/playbook/pb_typeahead/components/MultiValue.jsx +23 -11
  89. data/app/pb_kits/playbook/pb_typeahead/components/Placeholder.jsx +17 -4
  90. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_createable.jsx +25 -0
  91. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_inline.html.erb +36 -0
  92. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_inline.jsx +43 -0
  93. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_multi_kit.html.erb +35 -0
  94. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_multi_kit.jsx +44 -0
  95. data/app/pb_kits/playbook/pb_typeahead/docs/example.yml +5 -0
  96. data/app/pb_kits/playbook/pb_typeahead/docs/index.js +8 -5
  97. data/app/pb_kits/playbook/pb_typeahead/typeahead.html.erb +1 -1
  98. data/app/pb_kits/playbook/pb_typeahead/typeahead.rb +18 -2
  99. data/lib/playbook/props.rb +1 -0
  100. data/lib/playbook/props/nested_props.rb +23 -0
  101. data/lib/playbook/version.rb +2 -1
  102. metadata +50 -14
@@ -1,13 +1,17 @@
1
1
  <%= content_tag(:div,
2
2
  id: object.id,
3
3
  data: object.data,
4
- class: object.classname) do %>
5
- <%= pb_rails("flex", props: { orientation: "row", vertical: "center" }) do %>
6
- <%= pb_rails("flex/flex_item") do %>
7
- <%= pb_rails("date_stacked", props: { align: "right", date: object.date, reverse: true, size: "sm", dark: object.dark }) %>
4
+ class: object.classname,
5
+ aria: object.aria) do %>
6
+
7
+ <%= pb_rails("flex", props: {classname: "flex-container", vertical: "stretch"}) do %>
8
+ <%= pb_rails("body", props: {classname: "flex-item"}) do %>
9
+ <%= pb_rails("date_stacked", props: { date: object.date_time_value, size: "sm", align: "right", bold: true, dark: object.dark }) %>
8
10
  <% end %>
9
- <%= pb_rails("flex/flex_item") do %>
10
- <%= pb_rails("time_stacked", props: { classname: "pb_date_time_stacked_kit", time: object.date, tag: "caption" }) %>
11
+ <%= pb_rails("section_separator", props: { orientation: "vertical", classname: "date-time-padding" }) %>
12
+ <%= pb_rails("body", props: {classname: "flex-item"}) do %>
13
+ <%= pb_rails("time_stacked", props: { time: object.date_time_value, dark: object.dark, timezone: object.timezone }) %>
11
14
  <% end %>
12
- <% end %>
13
- <% end %>
15
+ <% end %>
16
+
17
+ <% end %>
@@ -3,10 +3,17 @@
3
3
  module Playbook
4
4
  module PbDateTimeStacked
5
5
  class DateTimeStacked < Playbook::KitBase
6
- prop :date, type: Playbook::Props::Date,
7
- default: ::DateTime.current
6
+ prop :date, deprecated: true
7
+ prop :date_time, type: Playbook::Props::Date,
8
+ default: ::DateTime.current
8
9
  prop :dark, type: Playbook::Props::Boolean,
9
10
  default: false
11
+ prop :timezone, type: Playbook::Props::String,
12
+ default: "America/New_York"
13
+
14
+ def date_time_value
15
+ date || date_time
16
+ end
10
17
  end
11
18
  end
12
19
  end
@@ -0,0 +1,35 @@
1
+ import { ensureAccessible, renderKit } from '../utilities/test-utils'
2
+ import { DateTimeStacked } from '../'
3
+
4
+ /* eslint-disable jsx-control-statements/jsx-jcs-no-undef */
5
+
6
+ const props = {
7
+ data: { testid: 'datetimestacked' },
8
+ datetime: new Date('Wed Mar 31 2021 12:00:00 GMT-0500'),
9
+ }
10
+
11
+ test('Kit renders date time', () => {
12
+ const kit = renderKit(DateTimeStacked, props)
13
+ expect(kit).toBeInTheDocument()
14
+ })
15
+
16
+ it('Should be accessible', async () => {
17
+ ensureAccessible(DateTimeStacked, props)
18
+ })
19
+
20
+ test('renders time in default timezone', () => {
21
+ const kit = renderKit(DateTimeStacked, props)
22
+ expect(kit).toHaveTextContent(/Mar311:00pEDT/i)
23
+ })
24
+
25
+ test('renders time in timezone', () => {
26
+ props.timeZone = 'Asia/Tokyo'
27
+ const kit = renderKit(DateTimeStacked, props)
28
+ expect(kit).toHaveTextContent(/Mar312:00aJST/i)
29
+ })
30
+
31
+ test('renders time in timezone', () => {
32
+ props.timeZone = 'America/Denver'
33
+ const kit = renderKit(DateTimeStacked, props)
34
+ expect(kit).toHaveTextContent(/Mar3111:00aMDT/i)
35
+ })
@@ -1 +1,8 @@
1
- <%= pb_rails("date_time_stacked") %>
1
+ <%= pb_rails("date_time_stacked", props: { date_time: DateTime.now }) %>
2
+ <br>
3
+ <%= pb_rails("date_time_stacked", props: { date_time: Date.new(2018, 03, 20) }) %>
4
+ <br>
5
+ <%= pb_rails("date_time_stacked", props: { date_time: DateTime.now, timezone: "Asia/Tokyo" }) %>
6
+ <br>
7
+ <%= pb_rails("date_time_stacked", props: { date_time: DateTime.now, timezone: "America/Denver" }) %>
8
+
@@ -4,10 +4,28 @@ import { DateTimeStacked } from '../../'
4
4
  const DateTimeStackedDefault = (props) => (
5
5
  <div>
6
6
  <DateTimeStacked
7
- date={new Date()}
7
+ datetime={new Date()}
8
8
  {...props}
9
9
  />
10
+ <br />
11
+ <DateTimeStacked
12
+ datetime={new Date()}
13
+ timeZone="Asia/Tokyo"
14
+
15
+ {...props}
16
+ />
17
+ <br />
18
+ <DateTimeStacked
19
+ datetime={new Date()}
20
+ timeZone="America/Denver"
21
+
22
+ {...props}
23
+ />
24
+
10
25
  </div>
11
26
  )
12
27
 
13
28
  export default DateTimeStackedDefault
29
+
30
+ // *Development Note* - We are reviewing this kit for a potential name change due to naming collisions when `new Date()` is used.
31
+ // To avoid this bug, please use name spacing as shown in the code examples. ie `import { Date as AliasedComponentName } from '../../'
@@ -9,7 +9,7 @@ import { Dialog } from '../'
9
9
  - https://jestjs.io/docs/en/using-matchers
10
10
  */
11
11
 
12
- test('generated scaffold test - update me', () => {
12
+ test('Kit renders Dialog', () => {
13
13
  const testId = 'test1'
14
14
 
15
15
  render(
@@ -2,11 +2,12 @@
2
2
 
3
3
  import React from 'react'
4
4
  import classnames from 'classnames'
5
- import { buildCss } from '../utilities/props'
5
+ import { buildCss, buildDataProps } from '../utilities/props'
6
6
  import { globalProps } from '../utilities/globalProps.js'
7
7
  type FlexProps = {
8
8
  children: array<React.ReactNode> | React.ReactNode,
9
9
  className?: string,
10
+ data?: object,
10
11
  horizontal?: "left" | "center" | "right" | "stretch" | "none",
11
12
  justify?: "start" | "center" | "end" | "around" | "between" | "evenly" | "none",
12
13
  id?: string,
@@ -27,6 +28,7 @@ const Flex = (props: FlexProps) => {
27
28
  align = 'none',
28
29
  children,
29
30
  className,
31
+ data = {},
30
32
  inline = false,
31
33
  horizontal = 'left',
32
34
  justify = 'none',
@@ -51,6 +53,8 @@ const Flex = (props: FlexProps) => {
51
53
  const columnGapClass = columnGap !== 'none' ? `columnGap_${columnGap}` : ''
52
54
  const wrapClass = wrap === true ? 'wrap' : ''
53
55
  const reverseClass = reverse === true ? 'reverse' : ''
56
+ const dataProps = buildDataProps(data)
57
+
54
58
  return (
55
59
  <div
56
60
  className={classnames(
@@ -70,6 +74,7 @@ const Flex = (props: FlexProps) => {
70
74
  globalProps(props),
71
75
  className
72
76
  )}
77
+ {...dataProps}
73
78
  >
74
79
  {children}
75
80
  </div>
@@ -14,6 +14,7 @@ type FormPillProps = {
14
14
  onClick?: EventHandler,
15
15
  avatar?: boolean,
16
16
  avatarUrl?: string,
17
+ size?: string,
17
18
  closeProps?: {
18
19
  onClick?: EventHandler,
19
20
  onMouseDown?: EventHandler,
@@ -21,11 +22,20 @@ type FormPillProps = {
21
22
  },
22
23
  }
23
24
  const FormPill = (props: FormPillProps) => {
24
- const { className, text, name, onClick = () => {}, avatarUrl, closeProps = {} } = props
25
+ const {
26
+ className,
27
+ text,
28
+ name,
29
+ onClick = () => {},
30
+ avatarUrl,
31
+ closeProps = {},
32
+ size = '',
33
+ } = props
25
34
  const css = classnames(
26
35
  `pb_form_pill_kit_${'primary'}`,
27
36
  globalProps(props),
28
- className
37
+ className,
38
+ size === 'small' ? 'small' : null,
29
39
  )
30
40
  return (
31
41
  <div className={css}>
@@ -51,4 +51,23 @@ $form_pill_colors: (
51
51
  }
52
52
  }
53
53
  }
54
+ &.small {
55
+ height: fit-content;
56
+ height: -moz-fit-content;
57
+ .pb_form_pill_text, .pb_form_pill_close, .pb_form_pill_tag {
58
+ font-size: 16px;
59
+ font-weight: 400;
60
+ }
61
+ .pb_form_pill_text, .pb_form_pill_tag {
62
+ line-height: 1.7;
63
+ padding-left: $space_xs;
64
+ padding-right: 2px;
65
+ }
66
+ [class^=pb_avatar_kit], [class^=pb_avatar_kit] .avatar_wrapper {
67
+ width: 20px;
68
+ height: 20px;
69
+ flex-basis: 20px;
70
+ &::before { line-height: 21px; }
71
+ }
72
+ }
54
73
  }
@@ -0,0 +1,13 @@
1
+ <%= pb_rails("form_pill", props: {
2
+ name: "Anna Black",
3
+ avatar_url: "https://randomuser.me/api/portraits/women/44.jpg",
4
+ size: "small",
5
+ }) %>
6
+
7
+ <br />
8
+ <br />
9
+
10
+ <%= pb_rails("form_pill", props: {
11
+ name: "Anna Black",
12
+ size: "small",
13
+ }) %>
@@ -0,0 +1,25 @@
1
+ import React from 'react'
2
+ import FormPill from '../_form_pill.jsx'
3
+
4
+ const FormPillSize = (props) => {
5
+ return (
6
+
7
+ <div>
8
+ <FormPill
9
+ avatarUrl="https://randomuser.me/api/portraits/women/44.jpg"
10
+ name="Anna Black"
11
+ size="small"
12
+ {...props}
13
+ />
14
+ <br />
15
+ <br />
16
+ <FormPill
17
+ name="Anna Black"
18
+ size="small"
19
+ {...props}
20
+ />
21
+ </div>
22
+ )
23
+ }
24
+
25
+ export default FormPillSize
@@ -1,12 +1,11 @@
1
1
  <%= pb_rails("form_pill", props: {
2
2
  name: "Anna Black",
3
3
  avatar_url: "https://randomuser.me/api/portraits/women/44.jpg",
4
+ }) %>
4
5
 
5
- }) %>
6
-
7
- <br>
8
- <br>
6
+ <br />
7
+ <br />
9
8
 
10
9
  <%= pb_rails("form_pill", props: {
11
10
  name: "Anna Black",
12
- }) %>
11
+ }) %>
@@ -8,18 +8,14 @@ const FormPillDefault = (props) => {
8
8
  <FormPill
9
9
  avatarUrl="https://randomuser.me/api/portraits/women/44.jpg"
10
10
  name="Anna Black"
11
- onClick={() => {
12
- alert('Click!')
13
- }}
11
+ onClick={() => alert('Click!')}
14
12
  {...props}
15
13
  />
16
14
  <br />
17
15
  <br />
18
16
  <FormPill
19
17
  name="Anna Black"
20
- onClick={() => {
21
- alert('Click!')
22
- }}
18
+ onClick={() => alert('Click!')}
23
19
  {...props}
24
20
  />
25
21
  </div>
@@ -2,9 +2,11 @@ examples:
2
2
 
3
3
  rails:
4
4
  - form_pill_user: Form Pill User
5
+ - form_pill_size: Form Pill Size
5
6
  - form_pill_tag: Form Pill Tag
6
7
 
7
8
 
8
9
  react:
9
10
  - form_pill_user: Form Pill User
11
+ - form_pill_size: Form Pill Size
10
12
  - form_pill_tag: Form Pill Tag
@@ -1,2 +1,3 @@
1
1
  export { default as FormPillUser } from './_form_pill_user.jsx'
2
+ export { default as FormPillSize } from './_form_pill_size.jsx'
2
3
  export { default as FormPillTag } from './_form_pill_tag.jsx'
@@ -1,7 +1,7 @@
1
1
  <%= content_tag(:div,
2
2
  id: object.id,
3
3
  data: object.data,
4
- class: object.classname) do %>
4
+ class: object.classname + object.size_class) do %>
5
5
  <% if object.name.present? %>
6
6
  <%= pb_rails("avatar", props: {
7
7
  name: object.name,
@@ -6,6 +6,7 @@ module Playbook
6
6
  prop :avatar_url
7
7
  prop :name
8
8
  prop :text
9
+ prop :size
9
10
 
10
11
  def classname
11
12
  generate_classname("pb_form_pill_kit", "primary", name, text)
@@ -14,6 +15,10 @@ module Playbook
14
15
  def display_text
15
16
  name.downcase
16
17
  end
18
+
19
+ def size_class
20
+ size == "small" ? " small" : ""
21
+ end
17
22
  end
18
23
  end
19
24
  end
@@ -16,7 +16,7 @@
16
16
  position: relative;
17
17
  flex-shrink: 0;
18
18
  flex-grow: 0;
19
- .pb_multiple_users_stacked_item {
19
+ [class^=pb_avatar_kit].pb_multiple_users_stacked_item {
20
20
  height: $stacked_size;
21
21
  width: $stacked_size;
22
22
  &.dark {
@@ -41,13 +41,17 @@
41
41
  height: $container_size;
42
42
  }
43
43
  }
44
- .second_item {
44
+ [class^=pb_avatar_kit].second_item, [class^=pb_badge_kit].second_item {
45
45
  position: absolute;
46
46
  bottom: 0;
47
47
  right: 0;
48
48
  z-index: 2;
49
49
  background: tint($primary, 90%);
50
50
  border-radius: $border_rad_mega;
51
+ padding: 0;
52
+ span {
53
+ transform: translateY(0);
54
+ }
51
55
  .avatar_wrapper {
52
56
  border: $border_size solid $white;
53
57
  height: $stacked_size;
@@ -7,7 +7,7 @@ import { buildAriaProps, buildCss, buildDataProps } from '../utilities/props'
7
7
  import { globalProps } from '../utilities/globalProps.js'
8
8
  import useZxcvbn from './useZxcvbn'
9
9
  import useHaveIBeenPwned from './useHaveIBeenPwned'
10
- import { Body, Caption, Flex, Icon, PbReactPopover, ProgressSimple, TextInput } from '../'
10
+ import { Body, Caption, CircleIconButton, Flex, Icon, PbReactPopover, ProgressSimple, TextInput } from '../'
11
11
 
12
12
  type PassphraseProps = {
13
13
  aria?: object,
@@ -69,6 +69,10 @@ const Passphrase = (props: PassphraseProps) => {
69
69
 
70
70
  const [showPopover, setShowPopover] = useState(false)
71
71
  const toggleShowPopover = () => setShowPopover(!showPopover)
72
+ const handleShouldClosePopover = (shouldClosePopover) => {
73
+ setShowPopover(!shouldClosePopover)
74
+ }
75
+
72
76
  const [showPassphrase, setShowPassphrase] = useState(false)
73
77
  const toggleShowPassphrase = () => setShowPassphrase(!showPassphrase)
74
78
 
@@ -85,7 +89,7 @@ const Passphrase = (props: PassphraseProps) => {
85
89
  }, [strength])
86
90
 
87
91
  const tipClass = classnames(
88
- (dark ? 'dark' : null),
92
+ 'passphrase-popover',
89
93
  (showTipsBelow === 'always' ? null : `show-below-${showTipsBelow}`),
90
94
  )
91
95
  const dataProps = useMemo(
@@ -94,17 +98,13 @@ const Passphrase = (props: PassphraseProps) => {
94
98
  )
95
99
 
96
100
  const popoverReference = (
97
- <a
101
+ <CircleIconButton
98
102
  className={tipClass}
103
+ dark={dark}
104
+ icon="info-circle"
99
105
  onClick={toggleShowPopover}
100
- >
101
- <Icon
102
- dark={dark}
103
- icon="info-circle"
104
- size="xs"
105
- variant="link"
106
- />
107
- </a>
106
+ variant="link"
107
+ />
108
108
  )
109
109
 
110
110
  return (
@@ -122,8 +122,11 @@ const Passphrase = (props: PassphraseProps) => {
122
122
  />
123
123
  <If condition={tips.length > 0 && !confirmation}>
124
124
  <PbReactPopover
125
+ className="passphrase-tips"
126
+ closeOnClick="outside"
125
127
  placement="right"
126
128
  reference={popoverReference}
129
+ shouldClosePopover={handleShouldClosePopover}
127
130
  show={showPopover}
128
131
  >
129
132
  <Flex