playbook_ui_docs 16.2.0 → 16.3.0.pre.alpha.PLAY2791closeonclick14694

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.
Files changed (35) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/pb_caption/docs/_caption_colors.html.erb +6 -4
  3. data/app/pb_kits/playbook/pb_caption/docs/_caption_colors.jsx +14 -4
  4. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_positions.md +1 -0
  5. data/app/pb_kits/playbook/pb_detail/docs/_detail_colors.html.erb +6 -24
  6. data/app/pb_kits/playbook/pb_detail/docs/_detail_colors.jsx +35 -33
  7. data/app/pb_kits/playbook/pb_dialog/docs/_dialog_compound_components.md +3 -1
  8. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_closing_options.jsx +63 -0
  9. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_closing_options.md +1 -0
  10. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_closing_options_rails.html.erb +16 -0
  11. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_closing_options_rails.md +1 -0
  12. data/app/pb_kits/playbook/pb_dropdown/docs/example.yml +2 -0
  13. data/app/pb_kits/playbook/pb_dropdown/docs/index.js +1 -0
  14. data/app/pb_kits/playbook/pb_form/docs/_form_form_with.html.erb +2 -1
  15. data/app/pb_kits/playbook/pb_form/docs/_form_with_required_indicator.html.erb +2 -0
  16. data/app/pb_kits/playbook/pb_link/docs/_link_underline.jsx +31 -1
  17. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_react_reset_key.jsx +100 -0
  18. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_react_reset_key.md +1 -0
  19. data/app/pb_kits/playbook/pb_multi_level_select/docs/example.yml +1 -0
  20. data/app/pb_kits/playbook/pb_multi_level_select/docs/index.js +1 -0
  21. data/app/pb_kits/playbook/pb_pagination/docs/_pagination_default.jsx +1 -1
  22. data/app/pb_kits/playbook/pb_select/docs/_select_required_indicator.html.erb +24 -0
  23. data/app/pb_kits/playbook/pb_select/docs/_select_required_indicator.jsx +33 -0
  24. data/app/pb_kits/playbook/pb_select/docs/_select_required_indicator.md +3 -0
  25. data/app/pb_kits/playbook/pb_select/docs/example.yml +3 -2
  26. data/app/pb_kits/playbook/pb_select/docs/index.js +1 -0
  27. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_disabled.jsx +11 -13
  28. data/app/pb_kits/playbook/pb_textarea/docs/_textarea_disabled.html.erb +10 -0
  29. data/app/pb_kits/playbook/pb_textarea/docs/_textarea_disabled.jsx +27 -0
  30. data/app/pb_kits/playbook/pb_textarea/docs/_textarea_input_options.jsx +68 -0
  31. data/app/pb_kits/playbook/pb_textarea/docs/example.yml +3 -0
  32. data/app/pb_kits/playbook/pb_textarea/docs/index.js +10 -8
  33. data/app/pb_kits/playbook/pb_title/docs/_title_colors.html.erb +2 -0
  34. data/app/pb_kits/playbook/pb_title/docs/_title_colors.jsx +14 -0
  35. metadata +14 -2
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: a7bb2214a52b11123d3b0e739b02b0b6f6e556e7dc4b2db0212080e1773cfbfa
4
- data.tar.gz: ebe6a162f19e4efa53fbc8f30b705147c56269f5b05f1ff7d987476e0b3d4f17
3
+ metadata.gz: 9b15a838be78fa03d9a2abdeb52ec5f47a5d47ddce7033a82bafde117b7182c7
4
+ data.tar.gz: dcc70228338285727d42fa9f20f8f72f15e2010c817b7e47246aa26038005cbe
5
5
  SHA512:
6
- metadata.gz: 1f280040d880d2542c3931ca6dc156b9fbd61d6fd5ca5eb198ecefda34c216b44ab1dbfd8738d22b09385fec0142025f340173b9ccacd944d176ebfc5e1d5985
7
- data.tar.gz: 92aad1b9bfdb2307addd84602b38fb657ae9ac393b2b532bb80fe935ec67176570c144233f865383f1c8f586e171867d766a96518d29e2009f021ef68d4f3a27
6
+ metadata.gz: 7e694a12a159407d4014bbc13fff5f358274b57fd87a1254cfd8f899aeb06eee606b65ba57e22b6f6540dfbea54eda51cd45618fdb5affd82bc3bfcecd687046
7
+ data.tar.gz: b9886ed7f7e8e89959e509ebfaf5e8a4e179bcdf9035145ae722f93d7e7de85a773cfe85a09931e36958d2845c4b9153bf629694f524ea257dab381b2a16f884
@@ -1,4 +1,6 @@
1
- <%= pb_rails("caption", props: { text: "Test colors" }) %>
2
- <%= pb_rails("caption", props: { text: "Test colors", color: "success" }) %>
3
- <%= pb_rails("caption", props: { text: "Test colors", color: "error" }) %>
4
- <%= pb_rails("caption", props: { text: "Test colors", color: "link" }) %>
1
+ <%= pb_rails("caption", props: { text: "Caption light" }) %>
2
+ <%= pb_rails("caption", props: { text: "Caption default", color: "default" }) %>
3
+ <%= pb_rails("caption", props: { text: "Caption lighter", color: "lighter" }) %>
4
+ <%= pb_rails("caption", props: { text: "Caption success", color: "success" }) %>
5
+ <%= pb_rails("caption", props: { text: "Caption error", color: "error" }) %>
6
+ <%= pb_rails("caption", props: { text: "Caption link", color: "link" }) %>
@@ -4,23 +4,33 @@ import Caption from "../../pb_caption/_caption"
4
4
  const CaptionColors = (props) => {
5
5
  return (
6
6
  <div>
7
+ <Caption
8
+ text="Caption light"
9
+ {...props}
10
+ />
11
+ <Caption
12
+ color="default"
13
+ text="Caption default"
14
+ {...props}
15
+ />
7
16
  <Caption
8
- text="Test colors"
17
+ color="lighter"
18
+ text="Caption lighter"
9
19
  {...props}
10
20
  />
11
21
  <Caption
12
22
  color="success"
13
- text="Test colors"
23
+ text="Caption success"
14
24
  {...props}
15
25
  />
16
26
  <Caption
17
27
  color="error"
18
- text="Test colors"
28
+ text="Caption error"
19
29
  {...props}
20
30
  />
21
31
  <Caption
22
32
  color="link"
23
- text="Test colors"
33
+ text="Caption link"
24
34
  {...props}
25
35
  />
26
36
  </div>
@@ -1,6 +1,7 @@
1
1
  Datepicker supports `position` options from [Flatpickr Options Documentation](https://flatpickr.js.org/options/). There are multiple positioning options to choose from.
2
2
 
3
3
  **Note:** In order for the above prop to work properly, you must also send `staticPosition={false}` to your Datepicker kit instance.
4
+ If you are using the Datepicker within a Dialog, you cannot use the `staticPosition`/`static_position` prop.
4
5
 
5
6
  #### Affix Datepicker Upon Scrolling
6
7
 
@@ -1,24 +1,6 @@
1
- <%= pb_rails("detail", props: {
2
- text: "I am a detail kit",
3
- color: "default"
4
- }) %>
5
-
6
- <%= pb_rails("detail", props: {
7
- text: "I am a detail kit",
8
- color: "lighter"
9
- }) %>
10
-
11
- <%= pb_rails("detail", props: {
12
- text: "I am a detail kit",
13
- color: "link"
14
- }) %>
15
-
16
- <%= pb_rails("detail", props: {
17
- text: "I am a detail kit",
18
- color: "error"
19
- }) %>
20
-
21
- <%= pb_rails("detail", props: {
22
- text: "I am a detail kit",
23
- color: "success"
24
- }) %>
1
+ <%= pb_rails("detail", props: { text: "I am a detail kit" }) %>
2
+ <%= pb_rails("detail", props: { text: "I am a detail kit", color: "default" }) %>
3
+ <%= pb_rails("detail", props: { text: "I am a detail kit", color: "lighter" }) %>
4
+ <%= pb_rails("detail", props: { text: "I am a detail kit", color: "link" }) %>
5
+ <%= pb_rails("detail", props: { text: "I am a detail kit", color: "error" }) %>
6
+ <%= pb_rails("detail", props: { text: "I am a detail kit", color: "success" }) %>
@@ -1,38 +1,40 @@
1
1
  import React from 'react'
2
2
  import Detail from '../../pb_detail/_detail'
3
3
 
4
- const DetailColors = (props) => (
5
- <div>
6
- <Detail
7
- color="default"
8
- text="I am a detail kit"
9
- {...props}
10
- />
11
-
12
- <Detail
13
- color="lighter"
14
- text="I am a detail kit"
15
- {...props}
16
- />
17
-
18
- <Detail
19
- color="link"
20
- text="I am a detail kit"
21
- {...props}
22
- />
23
-
24
- <Detail
25
- color="error"
26
- text="I am a detail kit"
27
- {...props}
28
- />
29
-
30
- <Detail
31
- color="success"
32
- text="I am a detail kit"
33
- {...props}
34
- />
35
- </div>
36
- )
4
+ const DetailColors = (props) => {
5
+ return (
6
+ <div>
7
+ <Detail
8
+ text="I am a detail kit"
9
+ {...props}
10
+ />
11
+ <Detail
12
+ color="default"
13
+ text="I am a detail kit"
14
+ {...props}
15
+ />
16
+ <Detail
17
+ color="lighter"
18
+ text="I am a detail kit"
19
+ {...props}
20
+ />
21
+ <Detail
22
+ color="link"
23
+ text="I am a detail kit"
24
+ {...props}
25
+ />
26
+ <Detail
27
+ color="error"
28
+ text="I am a detail kit"
29
+ {...props}
30
+ />
31
+ <Detail
32
+ color="success"
33
+ text="I am a detail kit"
34
+ {...props}
35
+ />
36
+ </div>
37
+ )
38
+ }
37
39
 
38
40
  export default DetailColors
@@ -1,4 +1,6 @@
1
1
  The dialog kit also supports customizing your dialog with a [compound component](https://kentcdodds.com/blog/compound-components-with-react-hooks) structure.
2
2
  This allows for greater flexibility and more complex dialogs.
3
3
 
4
- For the Rails version, when using the kit as a compound component it is necessary to pass the same value as the id for the dialog, the dialog header and the dialog footer in order for the opening and closing of the dialog to function as expected.
4
+ For the Rails version, when using the kit as a compound component it is necessary to pass the same value as the id for the dialog, the dialog header and the dialog footer in order for the opening and closing of the dialog to function as expected.
5
+
6
+ If you are using the datepicker within the Rails dialog, do not use the `static_position` prop on the datepicker.
@@ -0,0 +1,63 @@
1
+ import React from 'react'
2
+ import Dropdown from '../../pb_dropdown/_dropdown'
3
+ import Caption from '../../pb_caption/_caption'
4
+
5
+ const DropdownClosingOptions = (props) => {
6
+ const options = [
7
+ {
8
+ label: "United States",
9
+ value: "unitedStates",
10
+ id: "us"
11
+ },
12
+ {
13
+ label: "Canada",
14
+ value: "canada",
15
+ id: "ca"
16
+ },
17
+ {
18
+ label: "Pakistan",
19
+ value: "pakistan",
20
+ id: "pk"
21
+ }
22
+ ];
23
+
24
+ return (
25
+ <>
26
+ <Caption
27
+ marginBottom="xs"
28
+ text="Any"
29
+ />
30
+ <Dropdown
31
+ closeOnClick='any'
32
+ options={options}
33
+ {...props}
34
+ />
35
+
36
+ <br />
37
+
38
+ <Caption
39
+ marginBottom="xs"
40
+ text="Outside"
41
+ />
42
+ <Dropdown
43
+ closeOnClick='outside'
44
+ options={options}
45
+ {...props}
46
+ />
47
+
48
+ <br />
49
+
50
+ <Caption
51
+ marginBottom="xs"
52
+ text="Inside"
53
+ />
54
+ <Dropdown
55
+ closeOnClick='inside'
56
+ options={options}
57
+ {...props}
58
+ />
59
+ </>
60
+ )
61
+ }
62
+
63
+ export default DropdownClosingOptions
@@ -0,0 +1 @@
1
+ The `closeOnClick` prop allows you to control when the Dropdown closes in response to click interactions. The value `any` reflects the default behavior, where the dropdown will close after any click. Set it to `outside` to ensure interactive elements as dropdown options are able to be interacted with or modified. Set it to `inside` for a dropdown that only closes when the input or dropdown menu is clicked.
@@ -0,0 +1,16 @@
1
+ <%
2
+ options = [
3
+ { label: "United States", value: "unitedStates", id: "us" },
4
+ { label: "Canada", value: "canada", id: "ca" },
5
+ { label: "Pakistan", value: "pakistan", id: "pk" },
6
+ ]
7
+ %>
8
+
9
+ <%= pb_rails("caption", props: { margin_bottom: "xs", text: "Any" }) %>
10
+ <%= pb_rails("dropdown", props: { options: options, close_on_click: "any", margin_bottom: "md" }) %>
11
+
12
+ <%= pb_rails("caption", props: { margin_bottom: "xs", text: "Outside" }) %>
13
+ <%= pb_rails("dropdown", props: { options: options, close_on_click: "outside", margin_bottom: "md" }) %>
14
+
15
+ <%= pb_rails("caption", props: { margin_bottom: "xs", text: "Inside" }) %>
16
+ <%= pb_rails("dropdown", props: { options: options, close_on_click: "inside" }) %>
@@ -0,0 +1 @@
1
+ The `close_on_click` prop allows you to control when the Dropdown closes in response to click interactions. The value `any` reflects the default behavior, where the dropdown will close after any click. Set it to `outside` to ensure interactive elements as dropdown options are able to be interacted with or modified. Set it to `inside` for a dropdown that only closes when the input or dropdown menu is clicked.
@@ -25,6 +25,7 @@ examples:
25
25
  - dropdown_separators_hidden: Separators Hidden
26
26
  - dropdown_with_clearable: Clearable
27
27
  - dropdown_with_constrain_height_rails: Constrain Height
28
+ - dropdown_closing_options_rails: Closing Options
28
29
  - dropdown_quickpick_rails: Quick Pick Variant
29
30
  - dropdown_quickpick_range_end_rails: Quick Pick Variant (Range Ends Today)
30
31
  - dropdown_quickpick_default_dates: Quick Pick Variant (Default Dates)
@@ -62,6 +63,7 @@ examples:
62
63
  - dropdown_with_constrain_height: Constrain Height
63
64
  - dropdown_separators_hidden: Separators Hidden
64
65
  - dropdown_with_external_control: useDropdown Hook
66
+ - dropdown_closing_options: Closing Options
65
67
  - dropdown_quickpick: Quick Pick Variant
66
68
  - dropdown_quickpick_range_end: Quick Pick Variant (Range Ends Today)
67
69
  - dropdown_quickpick_default_dates: Quick Pick Variant (Default Dates)
@@ -31,4 +31,5 @@ export { default as DropdownQuickpickWithDatePickers } from './_dropdown_quickpi
31
31
  export { default as DropdownQuickpickCustom } from './_dropdown_quickpick_custom.jsx'
32
32
  export { default as DropdownWithClearable } from './_dropdown_with_clearable.jsx'
33
33
  export { default as DropdownWithConstrainHeight } from './_dropdown_with_constrain_height.jsx'
34
+ export { default as DropdownClosingOptions } from './_dropdown_closing_options.jsx'
34
35
  export { default as DropdownRequiredIndicator } from "./_dropdown_required_indicator.jsx";
@@ -92,7 +92,8 @@
92
92
  <%= form.typeahead :example_typeahead, props: { data: { typeahead_example1: true, user: {} }, label: true, placeholder: "Search for a user" } %>
93
93
  <%= form.text_field :example_text_field, props: { label: true } %>
94
94
  <%= form.text_field :example_text_field_2, props: { label: "Text Field Custom Label" } %>
95
- <%= form.phone_number_field :example_phone_number_field, props: { label: "Example phone field", hidden_inputs: true } %>
95
+ <%= form.phone_number_field :example_phone_number_field, props: { label: true, hidden_inputs: true} %>
96
+ <%= form.intl_telephone :example_intl_telephone, props: { label: true, hidden_inputs: true } %>
96
97
  <%= form.email_field :example_email_field, props: { label: true } %>
97
98
  <%= form.number_field :example_number_field, props: { label: true } %>
98
99
  <%= form.search_field :example_search_field, props: { label: true } %>
@@ -146,6 +146,8 @@
146
146
  <%= form.time_picker :example_time_picker_required_indicator, props: { label: true, required: true, required_indicator: true } %>
147
147
  <%= form.date_picker :example_date_picker_required_indicator, props: { label: true, required: true, required_indicator: true } %>
148
148
  <%= form.date_picker :example_date_picker_required_indicator_custom, props: { label: "Custom Date Picker Label", required: true, required_indicator: true } %>
149
+ <%= form.select :example_select_required_indicator, [["Yes", 1], ["No", 2]], props: { label: true, required: true, required_indicator: true } %>
150
+ <%= form.select :example_select_required_indicator_2, [["Yes", 1], ["No", 2]], props: { label: "Example Select Field", required: true, required_indicator: true } %>
149
151
  <%= form.multi_level_select :example_multi_level_select_required_indicator, props: {
150
152
  label: true,
151
153
  margin_y: 'sm',
@@ -4,7 +4,37 @@ import Link from '../../pb_link/_link'
4
4
  const LinkUnderline = (props) => (
5
5
  <div>
6
6
  <Link
7
- href="#underline"
7
+ href="#underline1"
8
+ text="link example"
9
+ underline
10
+ {...props}
11
+ />
12
+
13
+ <br />
14
+
15
+ <Link
16
+ color="body"
17
+ href="#underline2"
18
+ text="link example"
19
+ underline
20
+ {...props}
21
+ />
22
+
23
+ <br />
24
+
25
+ <Link
26
+ color="muted"
27
+ href="#underline3"
28
+ text="link example"
29
+ underline
30
+ {...props}
31
+ />
32
+
33
+ <br />
34
+
35
+ <Link
36
+ color="destructive"
37
+ href="#underline4"
8
38
  text="link example"
9
39
  underline
10
40
  {...props}
@@ -0,0 +1,100 @@
1
+ import React, { useState } from "react";
2
+ import MultiLevelSelect from "../_multi_level_select";
3
+ import { Button } from "playbook-ui";
4
+
5
+ const treeData = [
6
+ {
7
+ label: "Power Home Remodeling",
8
+ value: "powerHomeRemodeling",
9
+ id: "100",
10
+ expanded: true,
11
+ children: [
12
+ {
13
+ label: "People",
14
+ value: "people",
15
+ id: "101",
16
+ expanded: true,
17
+ children: [
18
+ {
19
+ label: "Talent Acquisition",
20
+ value: "talentAcquisition",
21
+ id: "102",
22
+ },
23
+ {
24
+ label: "Business Affairs",
25
+ value: "businessAffairs",
26
+ id: "103",
27
+ children: [
28
+ {
29
+ label: "Initiatives",
30
+ value: "initiatives",
31
+ id: "104",
32
+ },
33
+ {
34
+ label: "Learning & Development",
35
+ value: "learningAndDevelopment",
36
+ id: "105",
37
+ },
38
+ ],
39
+ },
40
+ {
41
+ label: "People Experience",
42
+ value: "peopleExperience",
43
+ id: "106",
44
+ },
45
+ ],
46
+ },
47
+ {
48
+ label: "Contact Center",
49
+ value: "contactCenter",
50
+ id: "107",
51
+ children: [
52
+ {
53
+ label: "Appointment Management",
54
+ value: "appointmentManagement",
55
+ id: "108",
56
+ },
57
+ {
58
+ label: "Customer Service",
59
+ value: "customerService",
60
+ id: "109",
61
+ },
62
+ {
63
+ label: "Energy",
64
+ value: "energy",
65
+ id: "110",
66
+ },
67
+ ],
68
+ },
69
+ ],
70
+ },
71
+ ];
72
+
73
+ const MultiLevelSelectReactResetKey = (props) => {
74
+ const [resetKey, setResetKey] = useState(0);
75
+
76
+ const handleReset = () => {
77
+ setResetKey((k) => k + 1);
78
+ };
79
+
80
+ return (
81
+ <>
82
+ <MultiLevelSelect
83
+ {...props}
84
+ id="multi-level-select-reset-example"
85
+ key={`multi-level-select-reset-${resetKey}`}
86
+ name="my_array"
87
+ returnAllSelected
88
+ treeData={treeData}
89
+ />
90
+ <Button
91
+ id="multilevelselect-reset-button"
92
+ marginTop="lg"
93
+ onClick={handleReset}
94
+ text="Reset"
95
+ />
96
+ </>
97
+ );
98
+ };
99
+
100
+ export default MultiLevelSelectReactResetKey;
@@ -0,0 +1 @@
1
+ When a parent resets a Multi Level Select (e.g., “Default” or “Clear”), the kit needs a `key` that changes with the selection because React uses the `key` to determine component identity and whether to preserve internal state. If the `key` doesn’t change, React reuses the existing instance and may keep showing the old selection instead of resetting to the new one.
@@ -39,3 +39,4 @@ examples:
39
39
  - multi_level_select_disabled_options_parent: Disabled Parent Option (Return All Selected)
40
40
  - multi_level_select_single_disabled: Disabled Options (Single Select)
41
41
  - multi_level_select_required_indicator: Required Indicator
42
+ - multi_level_select_react_reset_key: Reset with Key (React)
@@ -17,3 +17,4 @@ export { default as MultiLevelSelectDisabledOptionsDefault } from "./_multi_leve
17
17
  export { default as MultiLevelSelectLabel } from "./_multi_level_select_label.jsx"
18
18
  export { default as MultiLevelSelectSingleDisabled } from "./_multi_level_select_single_disabled.jsx"
19
19
  export { default as MultiLevelSelectRequiredIndicator } from "./_multi_level_select_required_indicator.jsx"
20
+ export { default as MultiLevelSelectReactResetKey } from "./_multi_level_select_react_reset_key.jsx"
@@ -9,7 +9,7 @@ const PaginationDefault = (props) => {
9
9
  <Pagination
10
10
  current={1}
11
11
  range={5}
12
- total={10}
12
+ total={1000}
13
13
  {...props}
14
14
  />
15
15
  </>
@@ -0,0 +1,24 @@
1
+ <%= pb_rails("select", props: {
2
+ label: "Favorite Snacks",
3
+ name: "food",
4
+ required_indicator: true,
5
+ options: [
6
+ {
7
+ value: "1",
8
+ value_text: "Popcorn",
9
+ },
10
+ {
11
+ value: "2",
12
+ selected: true,
13
+ value_text: "Chips",
14
+ },
15
+ {
16
+ value: "3",
17
+ value_text: "Twizzlers",
18
+ },
19
+ {
20
+ value: "4",
21
+ value_text: "Cookies",
22
+ },
23
+ ]
24
+ }) %>
@@ -0,0 +1,33 @@
1
+ import React from "react";
2
+
3
+ import { Select } from "playbook-ui";
4
+
5
+ const SelectRequiredIndicator = () => {
6
+ const options = [
7
+ {
8
+ value: "1",
9
+ text: "Popcorn",
10
+ },
11
+ {
12
+ value: "2",
13
+ text: "Chips",
14
+ },
15
+ {
16
+ value: "3",
17
+ text: "Twizzlers",
18
+ },
19
+ ];
20
+
21
+ return (
22
+ <div>
23
+ <Select
24
+ label="Favorite Snack"
25
+ name="food"
26
+ options={options}
27
+ requiredIndicator
28
+ />
29
+ </div>
30
+ );
31
+ };
32
+
33
+ export default SelectRequiredIndicator;
@@ -0,0 +1,3 @@
1
+ The `requiredIndicator`/`required_indicator` prop displays a red asterisk (\*) next to the label, visually indicating that the field is required. This is purely visual and does not enforce validation.
2
+
3
+ You can use `requiredIndicator`/`required_indicator` with any validation approach: HTML5 validation via the `required` prop, client-side validation, or backend validation. For this reason, it works independently and doesn't need to be paired with the `required` prop.
@@ -16,7 +16,7 @@ examples:
16
16
  - select_attributes: Select W/ Attributes
17
17
  - select_multiple: Select Multiple
18
18
  - select_input_options: Input Options
19
-
19
+ - select_required_indicator: Required Indicator
20
20
 
21
21
 
22
22
  react:
@@ -35,8 +35,9 @@ examples:
35
35
  - select_multiple: Select Multiple
36
36
  - select_react_hook: React Hook
37
37
  - select_input_options: Input Options
38
+ - select_required_indicator: Required Indicator
38
39
 
39
40
  swift:
40
41
  - select_default_swift: Default
41
42
  - select_error_swift: Error
42
- - select_props_table: ""
43
+ - select_props_table: ""
@@ -13,3 +13,4 @@ export { default as SelectMultiple } from './_select_multiple.jsx'
13
13
  export { default as SelectReactHook } from './_select_react_hook.jsx'
14
14
  export { default as SelectCustomSelectSubheaders } from './_select_custom_select_subheaders.jsx'
15
15
  export { default as SelectInputOptions } from './_select_input_options.jsx'
16
+ export { default as SelectRequiredIndicator } from './_select_required_indicator.jsx'
@@ -2,19 +2,17 @@ import React from 'react'
2
2
 
3
3
  import TextInput from '../_text_input'
4
4
 
5
- class TextInputDisabled extends React.Component {
6
- render(props) {
7
- return (
8
- <div>
9
- <TextInput
10
- disabled
11
- label="Last Name"
12
- placeholder="Enter last name"
13
- {...props}
14
- />
15
- </div>
16
- )
17
- }
5
+ const TextInputDisabled = (props) => {
6
+ return (
7
+ <div>
8
+ <TextInput
9
+ disabled
10
+ label="Last Name"
11
+ placeholder="Enter last name"
12
+ {...props}
13
+ />
14
+ </div>
15
+ )
18
16
  }
19
17
 
20
18
  export default TextInputDisabled
@@ -0,0 +1,10 @@
1
+ <%= pb_rails("textarea", props: { label: "Disabled", rows: 4, id: "disabled-example-1", disabled: true }) %>
2
+
3
+ <br/>
4
+
5
+ <%= pb_rails("textarea", props: {
6
+ label: "Disabled with Placeholder",
7
+ placeholder: "Placeholder text",
8
+ id: "disabled-example-2",
9
+ disabled: true
10
+ }) %>
@@ -0,0 +1,27 @@
1
+ import React from 'react'
2
+
3
+ import Textarea from '../_textarea'
4
+
5
+ const TextareaDefault = (props) => {
6
+ return (
7
+ <>
8
+ <Textarea
9
+ disabled
10
+ id="disabled-example"
11
+ label="Disabled"
12
+ {...props}
13
+ rows={4}
14
+ />
15
+ <Textarea
16
+ disabled
17
+ id="disabled-example-with-placeholder"
18
+ label="Disabled with Placeholder"
19
+ placeholder="Content goes here"
20
+ {...props}
21
+ rows={4}
22
+ />
23
+ </>
24
+ )
25
+ }
26
+
27
+ export default TextareaDefault
@@ -0,0 +1,68 @@
1
+ import React, { useState } from "react"
2
+
3
+ import Textarea from "../_textarea"
4
+
5
+ const TextareaInputOptions = (props) => {
6
+ const [value1, setValue1] = useState("")
7
+ const [value2, setValue2] = useState("")
8
+ const [value3, setValue3] = useState("")
9
+ const [value4, setValue4] = useState("")
10
+
11
+ return (
12
+ <div>
13
+ <Textarea
14
+ id="container-id"
15
+ label="ID on Container"
16
+ name="comment"
17
+ onChange={(e) => setValue1(e.target.value)}
18
+ rows={4}
19
+ value={value1}
20
+ {...props}
21
+ />
22
+
23
+ <br />
24
+
25
+ <Textarea
26
+ inputOptions={{ id: "textarea-id" }}
27
+ label="ID on Textarea via inputOptions"
28
+ name="comment"
29
+ onChange={(e) => setValue2(e.target.value)}
30
+ rows={4}
31
+ value={value2}
32
+ {...props}
33
+ />
34
+
35
+ <br />
36
+
37
+ <Textarea
38
+ id="container-id-2"
39
+ inputOptions={{ id: "textarea-id-2" }}
40
+ label="Both Container and Textarea IDs"
41
+ name="comment"
42
+ onChange={(e) => setValue3(e.target.value)}
43
+ rows={4}
44
+ value={value3}
45
+ {...props}
46
+ />
47
+
48
+ <br />
49
+
50
+ <Textarea
51
+ inputOptions={{
52
+ "aria-label": "Enter description",
53
+ "aria-describedby": "help-text",
54
+ data: { controller: "textarea", action: "focus->handleFocus" },
55
+ id: "description-textarea"
56
+ }}
57
+ label="Data and ARIA Attributes"
58
+ name="description"
59
+ onChange={(e) => setValue4(e.target.value)}
60
+ rows={4}
61
+ value={value4}
62
+ {...props}
63
+ />
64
+ </div>
65
+ )
66
+ }
67
+
68
+ export default TextareaInputOptions
@@ -10,6 +10,7 @@ examples:
10
10
  - textarea_emoji_mask: Emoji Mask
11
11
  - textarea_required_indicator: Required Indicator
12
12
  - textarea_input_options: Input Options
13
+ - textarea_disabled: Disabled
13
14
 
14
15
  react:
15
16
  - textarea_default: Default
@@ -20,6 +21,8 @@ examples:
20
21
  - textarea_inline: Inline
21
22
  - textarea_emoji_mask: Emoji Mask
22
23
  - textarea_required_indicator: Required Indicator
24
+ - textarea_input_options: Input Options
25
+ - textarea_disabled: Disabled
23
26
 
24
27
  swift:
25
28
  - textarea_default_swift: Default
@@ -1,8 +1,10 @@
1
- export { default as TextareaDefault } from './_textarea_default.jsx'
2
- export { default as TextareaResize } from './_textarea_resize.jsx'
3
- export { default as TextareaCustom } from './_textarea_custom.jsx'
4
- export { default as TextareaError } from './_textarea_error.jsx'
5
- export { default as TextareaCharacterCounter } from './_textarea_character_counter.jsx'
6
- export { default as TextareaInline } from './_textarea_inline.jsx'
7
- export { default as TextareaEmojiMask } from './_textarea_emoji_mask.jsx'
8
- export { default as TextareaRequiredIndicator } from './_textarea_required_indicator.jsx'
1
+ export { default as TextareaDefault } from "./_textarea_default.jsx"
2
+ export { default as TextareaDisabled } from './_textarea_disabled.jsx'
3
+ export { default as TextareaResize } from "./_textarea_resize.jsx"
4
+ export { default as TextareaCustom } from "./_textarea_custom.jsx"
5
+ export { default as TextareaError } from "./_textarea_error.jsx"
6
+ export { default as TextareaCharacterCounter } from "./_textarea_character_counter.jsx"
7
+ export { default as TextareaInline } from "./_textarea_inline.jsx"
8
+ export { default as TextareaEmojiMask } from "./_textarea_emoji_mask.jsx"
9
+ export { default as TextareaRequiredIndicator } from "./_textarea_required_indicator.jsx"
10
+ export { default as TextareaInputOptions } from "./_textarea_input_options.jsx"
@@ -1,4 +1,6 @@
1
1
  <%= pb_rails("title", props: { text: "Default Color", tag: "h1", size: 3 }) %>
2
+ <%= pb_rails("title", props: { text: "Title Color", tag: "h1", size: 3, color: "light" }) %>
3
+ <%= pb_rails("title", props: { text: "Title Color", tag: "h1", size: 3, color: "lighter" }) %>
2
4
  <%= pb_rails("title", props: { text: "Title Color", tag: "h1", size: 3, color: "link" }) %>
3
5
  <%= pb_rails("title", props: { text: "Title Color", tag: "h1", size: 3, color: "success" }) %>
4
6
  <%= pb_rails("title", props: { text: "Title Color", tag: "h1", size: 3, color: "error" }) %>
@@ -9,6 +9,20 @@ const TitleColors = (props) => {
9
9
  text="Default Color"
10
10
  {...props}
11
11
  />
12
+ <Title
13
+ color="light"
14
+ size={3}
15
+ tag="h1"
16
+ text="Title Color"
17
+ {...props}
18
+ />
19
+ <Title
20
+ color="lighter"
21
+ size={3}
22
+ tag="h1"
23
+ text="Title Color"
24
+ {...props}
25
+ />
12
26
  <Title
13
27
  color="link"
14
28
  size={3}
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: playbook_ui_docs
3
3
  version: !ruby/object:Gem::Version
4
- version: 16.2.0
4
+ version: 16.3.0.pre.alpha.PLAY2791closeonclick14694
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: 2026-02-11 00:00:00.000000000 Z
12
+ date: 2026-02-26 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: playbook_ui
@@ -857,6 +857,10 @@ files:
857
857
  - app/pb_kits/playbook/pb_dropdown/docs/_dropdown_blank_selection_react.md
858
858
  - app/pb_kits/playbook/pb_dropdown/docs/_dropdown_clear_selection.jsx
859
859
  - app/pb_kits/playbook/pb_dropdown/docs/_dropdown_clear_selection.md
860
+ - app/pb_kits/playbook/pb_dropdown/docs/_dropdown_closing_options.jsx
861
+ - app/pb_kits/playbook/pb_dropdown/docs/_dropdown_closing_options.md
862
+ - app/pb_kits/playbook/pb_dropdown/docs/_dropdown_closing_options_rails.html.erb
863
+ - app/pb_kits/playbook/pb_dropdown/docs/_dropdown_closing_options_rails.md
860
864
  - app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default.jsx
861
865
  - app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default.md
862
866
  - app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default_rails.html.erb
@@ -1447,6 +1451,8 @@ files:
1447
1451
  - app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_label.md
1448
1452
  - app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_react_hook.jsx
1449
1453
  - app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_react_hook.md
1454
+ - app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_react_reset_key.jsx
1455
+ - app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_react_reset_key.md
1450
1456
  - app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_required_indicator.html.erb
1451
1457
  - app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_required_indicator.jsx
1452
1458
  - app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_required_indicator.md
@@ -2058,6 +2064,9 @@ files:
2058
2064
  - app/pb_kits/playbook/pb_select/docs/_select_react_hook.md
2059
2065
  - app/pb_kits/playbook/pb_select/docs/_select_required.html.erb
2060
2066
  - app/pb_kits/playbook/pb_select/docs/_select_required.jsx
2067
+ - app/pb_kits/playbook/pb_select/docs/_select_required_indicator.html.erb
2068
+ - app/pb_kits/playbook/pb_select/docs/_select_required_indicator.jsx
2069
+ - app/pb_kits/playbook/pb_select/docs/_select_required_indicator.md
2061
2070
  - app/pb_kits/playbook/pb_select/docs/_select_value_text_same.html.erb
2062
2071
  - app/pb_kits/playbook/pb_select/docs/_select_value_text_same.jsx
2063
2072
  - app/pb_kits/playbook/pb_select/docs/example.yml
@@ -2372,6 +2381,8 @@ files:
2372
2381
  - app/pb_kits/playbook/pb_textarea/docs/_textarea_default.jsx
2373
2382
  - app/pb_kits/playbook/pb_textarea/docs/_textarea_default.md
2374
2383
  - app/pb_kits/playbook/pb_textarea/docs/_textarea_default_swift.md
2384
+ - app/pb_kits/playbook/pb_textarea/docs/_textarea_disabled.html.erb
2385
+ - app/pb_kits/playbook/pb_textarea/docs/_textarea_disabled.jsx
2375
2386
  - app/pb_kits/playbook/pb_textarea/docs/_textarea_emoji_mask.html.erb
2376
2387
  - app/pb_kits/playbook/pb_textarea/docs/_textarea_emoji_mask.jsx
2377
2388
  - app/pb_kits/playbook/pb_textarea/docs/_textarea_emoji_mask.md
@@ -2382,6 +2393,7 @@ files:
2382
2393
  - app/pb_kits/playbook/pb_textarea/docs/_textarea_inline.html.erb
2383
2394
  - app/pb_kits/playbook/pb_textarea/docs/_textarea_inline.jsx
2384
2395
  - app/pb_kits/playbook/pb_textarea/docs/_textarea_input_options.html.erb
2396
+ - app/pb_kits/playbook/pb_textarea/docs/_textarea_input_options.jsx
2385
2397
  - app/pb_kits/playbook/pb_textarea/docs/_textarea_input_options.md
2386
2398
  - app/pb_kits/playbook/pb_textarea/docs/_textarea_props_swift.md
2387
2399
  - app/pb_kits/playbook/pb_textarea/docs/_textarea_required_indicator.html.erb