playbook_ui_docs 15.6.0.pre.rc.4 → 15.7.0.pre.alpha.play263313229

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 (107) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_background_colors_rails.html.erb +43 -0
  3. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_background_colors_rails.md +1 -0
  4. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_background_control_rails.html.erb +11 -5
  5. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_background_control_rails.md +7 -1
  6. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_background.jsx +54 -0
  7. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_background.md +9 -0
  8. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_background_multi.jsx +80 -0
  9. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_background_multi.md +3 -0
  10. data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +4 -1
  11. data/app/pb_kits/playbook/pb_advanced_table/docs/index.js +3 -1
  12. data/app/pb_kits/playbook/pb_card/docs/_card_header.md +1 -1
  13. data/app/pb_kits/playbook/pb_card/docs/_card_highlight.md +1 -1
  14. data/app/pb_kits/playbook/pb_collapsible/docs/_collapsible_icons.jsx +0 -1
  15. data/app/pb_kits/playbook/pb_collapsible/docs/_collapsible_state.jsx +0 -3
  16. data/app/pb_kits/playbook/pb_contact/docs/_contact_unstyled.html.erb +33 -0
  17. data/app/pb_kits/playbook/pb_contact/docs/_contact_unstyled.jsx +46 -0
  18. data/app/pb_kits/playbook/pb_contact/docs/_contact_unstyled_rails.md +2 -0
  19. data/app/pb_kits/playbook/pb_contact/docs/_contact_unstyled_react.md +2 -0
  20. data/app/pb_kits/playbook/pb_contact/docs/example.yml +2 -0
  21. data/app/pb_kits/playbook/pb_contact/docs/index.js +1 -0
  22. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_range_pattern_rails.html.erb +23 -14
  23. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_range_pattern_rails.md +1 -1
  24. data/app/pb_kits/playbook/pb_dialog/docs/_dialog_closeable.html.erb +24 -0
  25. data/app/pb_kits/playbook/pb_dialog/docs/_dialog_closeable.jsx +60 -0
  26. data/app/pb_kits/playbook/pb_dialog/docs/_dialog_closeable.md +3 -0
  27. data/app/pb_kits/playbook/pb_dialog/docs/_dialog_overflow_visible.html.erb +71 -0
  28. data/app/pb_kits/playbook/pb_dialog/docs/_dialog_overflow_visible.jsx +57 -0
  29. data/app/pb_kits/playbook/pb_dialog/docs/_dialog_overflow_visible_rails.md +1 -0
  30. data/app/pb_kits/playbook/pb_dialog/docs/_dialog_overflow_visible_react.md +1 -0
  31. data/app/pb_kits/playbook/pb_dialog/docs/example.yml +4 -0
  32. data/app/pb_kits/playbook/pb_dialog/docs/index.js +3 -1
  33. data/app/pb_kits/playbook/pb_distribution_bar/docs/_distribution_bar_custom_colors.md +1 -1
  34. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default_rails.html.erb +7 -5
  35. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_default_dates.html.erb +19 -0
  36. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_rails.html.erb +12 -0
  37. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_rails.md +26 -0
  38. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_range_end_rails.html.erb +19 -0
  39. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_range_end_rails.md +1 -0
  40. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_with_date_pickers_default_rails.html.erb +30 -0
  41. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_with_date_pickers_default_rails.md +3 -0
  42. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_with_date_pickers_rails.html.erb +29 -0
  43. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_with_date_pickers_rails.md +13 -0
  44. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display_rails.html.erb +3 -1
  45. data/app/pb_kits/playbook/pb_dropdown/docs/example.yml +5 -0
  46. data/app/pb_kits/playbook/pb_form/docs/_form_form_with.html.erb +1 -1
  47. data/app/pb_kits/playbook/pb_form/docs/_form_form_with_validate.html.erb +2 -1
  48. data/app/pb_kits/playbook/pb_form/docs/_form_with_required_indicator.html.erb +14 -0
  49. data/app/pb_kits/playbook/pb_form/docs/_form_with_required_indicator.md +3 -0
  50. data/app/pb_kits/playbook/pb_form/docs/example.yml +1 -0
  51. data/app/pb_kits/playbook/pb_radio/docs/_radio_error.md +1 -1
  52. data/app/pb_kits/playbook/pb_select/docs/_select_error.md +1 -1
  53. data/app/pb_kits/playbook/pb_select/docs/_select_input_options.html.erb +16 -0
  54. data/app/pb_kits/playbook/pb_select/docs/_select_input_options.jsx +30 -0
  55. data/app/pb_kits/playbook/pb_select/docs/_select_input_options.md +1 -0
  56. data/app/pb_kits/playbook/pb_select/docs/example.yml +2 -0
  57. data/app/pb_kits/playbook/pb_select/docs/index.js +1 -0
  58. data/app/pb_kits/playbook/pb_table/docs/_table_with_filter_variant.jsx +134 -0
  59. data/app/pb_kits/playbook/pb_table/docs/_table_with_filter_variant.md +34 -0
  60. data/app/pb_kits/playbook/pb_table/docs/_table_with_filter_variant_rails.html.erb +101 -0
  61. data/app/pb_kits/playbook/pb_table/docs/_table_with_filter_variant_rails.md +33 -0
  62. data/app/pb_kits/playbook/pb_table/docs/_table_with_filter_variant_with_pagination.jsx +180 -0
  63. data/app/pb_kits/playbook/pb_table/docs/_table_with_filter_variant_with_pagination.md +3 -0
  64. data/app/pb_kits/playbook/pb_table/docs/_table_with_filter_variant_with_pagination_rails.html.erb +122 -0
  65. data/app/pb_kits/playbook/pb_table/docs/_table_with_filter_variant_with_pagination_rails.md +3 -0
  66. data/app/pb_kits/playbook/pb_table/docs/example.yml +4 -0
  67. data/app/pb_kits/playbook/pb_table/docs/index.js +2 -0
  68. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_error.md +1 -1
  69. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_required_indicator.html.erb +6 -0
  70. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_required_indicator.jsx +25 -0
  71. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_required_indicator.md +3 -0
  72. data/app/pb_kits/playbook/pb_text_input/docs/example.yml +3 -0
  73. data/app/pb_kits/playbook/pb_text_input/docs/index.js +1 -0
  74. data/app/pb_kits/playbook/pb_textarea/docs/_textarea_error.md +1 -1
  75. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_24_hour.html.erb +2 -0
  76. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_24_hour.jsx +16 -0
  77. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_24_hour.md +1 -0
  78. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_default.html.erb +1 -0
  79. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_default.jsx +13 -0
  80. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_default.md +1 -0
  81. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_default_time.html.erb +4 -0
  82. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_default_time.jsx +29 -0
  83. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_default_time.md +1 -0
  84. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_disabled.html.erb +13 -0
  85. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_disabled.jsx +23 -0
  86. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_error.html.erb +5 -0
  87. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_error.jsx +15 -0
  88. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_input_options.html.erb +14 -0
  89. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_label.html.erb +2 -0
  90. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_label.jsx +15 -0
  91. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_min_max_time.html.erb +42 -0
  92. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_min_max_time.jsx +52 -0
  93. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_min_max_time.md +1 -0
  94. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_on_handler.jsx +45 -0
  95. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_on_handler.md +1 -0
  96. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_timezone.html.erb +3 -0
  97. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_timezone.jsx +21 -0
  98. data/app/pb_kits/playbook/pb_time_picker/docs/_time_picker_timezone.md +1 -0
  99. data/app/pb_kits/playbook/pb_time_picker/docs/example.yml +24 -0
  100. data/app/pb_kits/playbook/pb_time_picker/docs/index.js +9 -0
  101. data/app/pb_kits/playbook/pb_timeline/docs/_timeline_show_current_year.html.erb +60 -0
  102. data/app/pb_kits/playbook/pb_timeline/docs/_timeline_show_current_year.jsx +118 -0
  103. data/app/pb_kits/playbook/pb_timeline/docs/_timeline_show_current_year.md +1 -0
  104. data/app/pb_kits/playbook/pb_timeline/docs/_timeline_with_date.md +1 -1
  105. data/app/pb_kits/playbook/pb_timeline/docs/example.yml +2 -0
  106. data/app/pb_kits/playbook/pb_timeline/docs/index.js +1 -0
  107. metadata +73 -2
@@ -0,0 +1,101 @@
1
+ <% users = [
2
+ { id: 1, name: "Jennifer", title: "Associate Scrum Master", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 1) },
3
+ { id: 2, name: "Nick", title: "UX Engineer II", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 2) },
4
+ { id: 3, name: "Nida", title: "Senior UX Engineer", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 3) },
5
+ { id: 4, name: "Justin", title: "Director of User Experience Engineering", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 4) },
6
+ { id: 5, name: "Edward", title: "UX Designer II", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 5) },
7
+ { id: 6, name: "Elisa", title: "UX Engineer", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 6) },
8
+ { id: 7, name: "Gary", title: "UX Engineer", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 7) },
9
+ { id: 8, name: "Barkley", title: "Nitro Quality Ninja", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 8) },
10
+ { id: 9, name: "Aaron", title: "Associate Nitro Quality Ninja", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 9) },
11
+ ] %>
12
+
13
+ <% filter_content =
14
+ pb_rails("text_input", props: {
15
+ label: "Territory ID",
16
+ placeholder: "Enter Territory ID"
17
+ }) +
18
+ pb_rails("typeahead", props: {
19
+ label: "Title",
20
+ options: [
21
+ { label: "Senior UX Engineer", value: "senior-ux-engineer" },
22
+ { label: "UX Engineer", value: "ux-engineer" },
23
+ { label: "UX Designer", value: "ux-designer" }
24
+ ]
25
+ }) +
26
+ pb_rails("select", props: {
27
+ blank_selection: "All Departments",
28
+ label: "Department",
29
+ options: [
30
+ { value: "Business Technology", text: "Business Technology" },
31
+ { value: "Customer Development", text: "Customer Development" },
32
+ { value: "Talent Acquisition", text: "Talent Acquisition" }
33
+ ]
34
+ }) +
35
+ pb_rails("dropdown", props: {
36
+ label: "Branch",
37
+ options: [
38
+ { label: "Philadelphia", value: "philadelphia" },
39
+ { label: "New York", value: "new-york" },
40
+ { label: "Austin", value: "austin" }
41
+ ]
42
+ }) +
43
+ pb_rails("date_picker", props: {
44
+ label: "Start Date",
45
+ padding_y: "sm",
46
+ picker_id: "startedOn"
47
+ }) +
48
+ pb_rails("flex", props: { spacing: "between" }) do
49
+ pb_rails("button", props: {
50
+ text: "Filter",
51
+ }) +
52
+ pb_rails("button", props: {
53
+ text: "Defaults",
54
+ variant: "secondary"
55
+ })
56
+ end
57
+ %>
58
+
59
+ <%= pb_rails("table", props: {
60
+ variant: "with_filter",
61
+ title: "Table Title Here",
62
+ filter_content: filter_content,
63
+ filter_props: {
64
+ id: "user-table-filters-1",
65
+ results: 9,
66
+ sort_menu: [
67
+ { item: "Start Date", link: "?q[sorts]=started_on+asc", active: true, direction: "asc" },
68
+ { item: "First Name", link: "?q[sorts]=name+asc", active: false },
69
+ { item: "Title", link: "?q[sorts]=title+asc", active: false },
70
+ { item: "Department", link: "?q[sorts]=department+asc", active: false },
71
+ { item: "Branch", link: "?q[sorts]=branch+asc", active: false },
72
+ { item: "Territory ID", link: "?q[sorts]=territory_id+asc", active: false },
73
+ ],
74
+ }
75
+ }) do %>
76
+ <%= pb_rails("table/table_head") do %>
77
+ <%= pb_rails("table/table_row") do %>
78
+ <%= pb_rails("table/table_header", props: { text: "Territory ID" }) %>
79
+ <%= pb_rails("table/table_header", props: { text: "Name" }) %>
80
+ <%= pb_rails("table/table_header", props: { text: "Title" }) %>
81
+ <%= pb_rails("table/table_header", props: { text: "Department" }) %>
82
+ <%= pb_rails("table/table_header", props: { text: "Branch" }) %>
83
+ <%= pb_rails("table/table_header", props: { text: "Start Date", text_align: "right" }) %>
84
+ <% end %>
85
+ <% end %>
86
+
87
+ <%= pb_rails("table/table_body") do %>
88
+ <% users.each do |user| %>
89
+ <%= pb_rails("table/table_row") do %>
90
+ <%= pb_rails("table/table_cell", props: { margin_x: { xs: "sm" }, number_spacing: "tabular" }) { user[:id].to_s } %>
91
+ <%= pb_rails("table/table_cell", props: { margin_x: { xs: "sm" } }) { user[:name] } %>
92
+ <%= pb_rails("table/table_cell", props: { margin_x: { xs: "sm" } }) { user[:title] } %>
93
+ <%= pb_rails("table/table_cell", props: { margin_x: { xs: "sm" } }) { user[:department] } %>
94
+ <%= pb_rails("table/table_cell", props: { margin_x: { xs: "sm" } }) { user[:branch] } %>
95
+ <%= pb_rails("table/table_cell", props: { margin_x: { xs: "sm" } }) do %>
96
+ <%= pb_rails("date", props: {alignment: "right", date: user[:start_date].to_s, show_current_year: true } ) %>
97
+ <% end %>
98
+ <% end %>
99
+ <% end %>
100
+ <% end %>
101
+ <% end %>
@@ -0,0 +1,33 @@
1
+ Set the `variant` prop to `with_filter` to render a Table with a filter. The variant automatically handles:
2
+
3
+ - Card wrapper with standard responsive margins
4
+ - Optional `title` prop to render title above the card
5
+ - Filter component rendering with Design defaults
6
+ - SectionSeparator between filter and table
7
+ - Flex layout for proper alignment
8
+
9
+ #### Required Props
10
+
11
+ - `variant: "with_filter"`: Enables the filter variant
12
+ - `filter_content`: The filter's body content (inputs, buttons, etc.) built with `pb_rails` string concatenation
13
+ - `filter_props`: A hash containing Filter-specific props like `results`, `sort_menu`, etc.
14
+
15
+ #### Optional Props
16
+
17
+ - `title`: Displays a title above the card
18
+ - All standard Table props (`size`, `collapse`, etc.) can be used, but defaults are already set to match Design guidelines
19
+
20
+ #### Default Filter Props
21
+
22
+ The Table kit automatically sets these Filter defaults (which you can override via `filter_props`):
23
+
24
+ - `background: false`
25
+ - `max_height: "50vh"`
26
+ - `min_width: "xs"`
27
+ - `popover_props: { width: "350px" }`
28
+
29
+
30
+ **IMPORTANT NOTE**:
31
+ The purpose of this variant is to provide an easy way to set up a Table with a Filter with Design standards applied by default.
32
+
33
+ If you are looking for more customization than this embedded variant provides, you may be better served by using the individual kits as demonstrating in our Table Filter Card Building Block as seen [here](https://playbook.powerapp.cloud/building_blocks/table_filter_card/rails).
@@ -0,0 +1,180 @@
1
+ import React, { useState } from "react"
2
+ import { Button, Date as DateKit, DatePicker, Dropdown, Pagination, Select, Table, TextInput, Typeahead, Flex } from "playbook-ui"
3
+
4
+
5
+ // Mock Data for Table
6
+ const users = [
7
+ { id: 1, name: "Jennifer", title: "Associate Scrum Master", department: "Business Technology", branch: "Philadelphia", startDate: "2025-01-01" },
8
+ { id: 2, name: "Nick", title: "UX Engineer II", department: "Business Technology", branch: "Philadelphia", startDate: "2025-01-02" },
9
+ { id: 3, name: "Nida", title: "Senior UX Engineer", department: "Business Technology", branch: "Philadelphia", startDate: "2025-01-03" },
10
+ { id: 4, name: "Justin", title: "Director of User Experience Engineering", department: "Business Technology", branch: "Philadelphia", startDate: "2025-01-04" },
11
+ { id: 5, name: "Edward", title: "UX Designer II", department: "Business Technology", branch: "Philadelphia", startDate: "2025-01-05" },
12
+ { id: 6, name: "Elisa", title: "UX Engineer", department: "Business Technology", branch: "Philadelphia", startDate: "2025-01-06" },
13
+ { id: 7, name: "Gary", title: "UX Engineer", department: "Business Technology", branch: "Philadelphia", startDate: "2025-01-07" },
14
+ { id: 8, name: "Barkley", title: "Nitro Quality Ninja", department: "Business Technology", branch: "Philadelphia", startDate: "2025-01-08" },
15
+ { id: 9, name: "Aaron", title: "Associate Nitro Quality Ninja", department: "Business Technology", branch: "Philadelphia", startDate: "2025-01-09" },
16
+ { id: 10, name: "Sarah", title: "Senior Product Manager", department: "Business Technology", branch: "New York", startDate: "2025-01-10" },
17
+ { id: 11, name: "Michael", title: "Software Engineer III", department: "Business Technology", branch: "Austin", startDate: "2025-01-11" },
18
+ { id: 12, name: "Emma", title: "Data Analyst II", department: "Customer Development", branch: "Philadelphia", startDate: "2025-01-12" },
19
+ { id: 13, name: "David", title: "QA Engineer", department: "Business Technology", branch: "New York", startDate: "2025-01-13" },
20
+ { id: 14, name: "Lisa", title: "UX Researcher", department: "Business Technology", branch: "Philadelphia", startDate: "2025-01-14" },
21
+ { id: 15, name: "James", title: "DevOps Engineer", department: "Business Technology", branch: "Austin", startDate: "2025-01-15" },
22
+ { id: 16, name: "Anna", title: "Product Designer", department: "Business Technology", branch: "Philadelphia", startDate: "2025-01-16" },
23
+ { id: 17, name: "Robert", title: "Backend Engineer", department: "Business Technology", branch: "New York", startDate: "2025-01-17" },
24
+ { id: 18, name: "Maria", title: "Frontend Developer", department: "Business Technology", branch: "Austin", startDate: "2025-01-18" },
25
+ { id: 19, name: "William", title: "Tech Lead", department: "Business Technology", branch: "Philadelphia", startDate: "2025-01-19" },
26
+ { id: 20, name: "Jessica", title: "Scrum Master", department: "Business Technology", branch: "New York", startDate: "2025-01-20" },
27
+ { id: 21, name: "Daniel", title: "Software Architect", department: "Business Technology", branch: "Austin", startDate: "2025-01-21" },
28
+ { id: 22, name: "Laura", title: "Business Analyst", department: "Customer Development", branch: "Philadelphia", startDate: "2025-01-22" },
29
+ { id: 23, name: "Chris", title: "Security Engineer", department: "Business Technology", branch: "New York", startDate: "2025-01-23" },
30
+ { id: 24, name: "Ashley", title: "UX Engineer III", department: "Business Technology", branch: "Austin", startDate: "2025-01-24" },
31
+ { id: 25, name: "Kevin", title: "Platform Engineer", department: "Business Technology", branch: "Philadelphia", startDate: "2025-01-25" },
32
+ { id: 26, name: "Michelle", title: "Content Designer", department: "Business Technology", branch: "New York", startDate: "2025-01-26" },
33
+ ]
34
+
35
+
36
+ const TableWithFilterVariantWithPagination = () => {
37
+ const [territory, setTerritory] = useState("")
38
+ // ------Pagination-----
39
+ const [activePage, setActivePage] = useState(1)
40
+ // Calculate pagination
41
+ const itemsPerPage = 20
42
+ const totalPages = Math.ceil(users.length / itemsPerPage)
43
+ const startIndex = (activePage - 1) * itemsPerPage
44
+ const endIndex = startIndex + itemsPerPage
45
+ const currentData = users.slice(startIndex, endIndex)
46
+
47
+ const onPageChange = (page) => {
48
+ setActivePage(page)
49
+ }
50
+ // ------End Pagination-----
51
+
52
+ // -------Filter content example ------
53
+ const filterContent = ({ closePopover }) => (
54
+ <>
55
+ <TextInput
56
+ label="Territory ID"
57
+ onChange={event => setTerritory(event.target.value)}
58
+ value={territory}
59
+ />
60
+ <Typeahead
61
+ label="Title"
62
+ options={[
63
+ { key: "senior-ux-engineer", label: "Senior UX Engineer", value: "senior-ux-engineer" },
64
+ { key: "ux-engineer", label: "UX Engineer", value: "ux-engineer" },
65
+ { key: "ux-designer", label: "UX Designer", value: "ux-designer" }
66
+ ]}
67
+ />
68
+
69
+ <Select
70
+ blankSelection="All Departments"
71
+ label="Department"
72
+ options={[
73
+ { value: "Business Technology", label: "Business Technology", key: "business-technology" },
74
+ { value: "Customer Development", label: "Customer Development", key: "customer-development" },
75
+ { value: "Talent Acquisition", label: "Talent Acquisition", key: "talent-acquisition" }
76
+ ]}
77
+ />
78
+
79
+ <Dropdown
80
+ label="Branch"
81
+ options={[
82
+ { key: "Philadelphia", label: "Philadelphia", value: "philadelphia" },
83
+ { key: "New York", label: "New York", value: "new-york" },
84
+ { key: "Austin", label: "Austin", value: "austin" }
85
+ ]}
86
+ />
87
+
88
+ <DatePicker
89
+ label="Start Date"
90
+ paddingY="sm"
91
+ pickerId="startedOn"
92
+ />
93
+ <Flex spacing="between">
94
+ <Button
95
+ onClick={() => {
96
+ alert("No filtering functionality - just a pattern demo!")
97
+ closePopover()
98
+ }}
99
+ text="Filter"
100
+ />
101
+ <Button
102
+ text="Defaults"
103
+ variant="secondary"
104
+ />
105
+ </Flex>
106
+ </>
107
+ )
108
+ // -------End Filter content example ------
109
+
110
+ // -------Pagination element example ------
111
+ const paginationElement = (
112
+ <Pagination
113
+ current={activePage}
114
+ key={`pagination-${activePage}`}
115
+ marginLeft="lg"
116
+ onChange={onPageChange}
117
+ paddingY="xs"
118
+ range={5}
119
+ total={totalPages}
120
+ />
121
+ )
122
+ // -------End Pagination element example ------
123
+
124
+ return (
125
+ <Table
126
+ filterContent={filterContent}
127
+ filterProps={{
128
+ results: 50,
129
+ sortOptions: {
130
+ territory_id: "Territory ID",
131
+ first_name: "Name",
132
+ started_on: "Start Date",
133
+ department_name: "Department",
134
+ title_name: "Title",
135
+ branch_branch_name: "Branch",
136
+ },
137
+ sortValue: [{ name: 'started_on', dir: 'asc' }],
138
+ }}
139
+ pagination={paginationElement}
140
+ title="Table Title Here"
141
+ variant="withFilter"
142
+ >
143
+ <Table.Head>
144
+ <Table.Row>
145
+ <Table.Header>{'Territory ID'}</Table.Header>
146
+ <Table.Header>{'Name'}</Table.Header>
147
+ <Table.Header>{'Title'}</Table.Header>
148
+ <Table.Header>{'Department'}</Table.Header>
149
+ <Table.Header>{'Branch'}</Table.Header>
150
+ <Table.Header textAlign="right">{'Start Date'}</Table.Header>
151
+ </Table.Row>
152
+ </Table.Head>
153
+ <Table.Body>
154
+ {currentData.map((user) => (
155
+ <Table.Row key={user.id}>
156
+ <Table.Cell
157
+ marginX={{ xs: "sm" }}
158
+ numberSpacing="tabular"
159
+ >
160
+ {user.id}
161
+ </Table.Cell>
162
+ <Table.Cell marginX={{ xs: "sm" }}>{user.name}</Table.Cell>
163
+ <Table.Cell marginX={{ xs: "sm" }}>{user.title}</Table.Cell>
164
+ <Table.Cell marginX={{ xs: "sm" }}>{user.department}</Table.Cell>
165
+ <Table.Cell marginX={{ xs: "sm" }}>{user.branch}</Table.Cell>
166
+ <Table.Cell marginX={{ xs: "sm" }}>
167
+ <DateKit
168
+ alignment="right"
169
+ showCurrentYear
170
+ value={user.startDate}
171
+ />
172
+ </Table.Cell>
173
+ </Table.Row>
174
+ ))}
175
+ </Table.Body>
176
+ </Table>
177
+ )
178
+ }
179
+
180
+ export default TableWithFilterVariantWithPagination
@@ -0,0 +1,3 @@
1
+ The `withFilter` variant can also be used with the Pagination kit as shown here. Simply set up your Pagination as normal, and pass the Pagination kit to the prop `pagination` as shown.
2
+
3
+ For more information on the Pagination Kit and how to use it, see the documentation [here](https://playbook.powerapp.cloud/kits/pagination/react)
@@ -0,0 +1,122 @@
1
+ <% users = [
2
+ { id: 1, name: "Jennifer", title: "Associate Scrum Master", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 1) },
3
+ { id: 2, name: "Nick", title: "UX Engineer II", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 2) },
4
+ { id: 3, name: "Nida", title: "Senior UX Engineer", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 3) },
5
+ { id: 4, name: "Justin", title: "Director of User Experience Engineering", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 4) },
6
+ { id: 5, name: "Edward", title: "UX Designer II", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 5) },
7
+ { id: 6, name: "Elisa", title: "UX Engineer", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 6) },
8
+ { id: 7, name: "Gary", title: "UX Engineer", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 7) },
9
+ { id: 8, name: "Barkley", title: "Nitro Quality Ninja", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 8) },
10
+ { id: 9, name: "Aaron", title: "Associate Nitro Quality Ninja", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 9) },
11
+ { id: 10, name: "Sarah", title: "Senior Product Manager", department: "Business Technology", branch: "New York", start_date: Date.new(2025, 1, 10) },
12
+ { id: 11, name: "Michael", title: "Software Engineer III", department: "Business Technology", branch: "Austin", start_date: Date.new(2025, 1, 11) },
13
+ { id: 12, name: "Emma", title: "Data Analyst II", department: "Customer Development", branch: "Philadelphia", start_date: Date.new(2025, 1, 12) },
14
+ { id: 13, name: "David", title: "QA Engineer", department: "Business Technology", branch: "New York", start_date: Date.new(2025, 1, 13) },
15
+ { id: 14, name: "Lisa", title: "UX Researcher", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 14) },
16
+ { id: 15, name: "James", title: "DevOps Engineer", department: "Business Technology", branch: "Austin", start_date: Date.new(2025, 1, 15) },
17
+ { id: 16, name: "Anna", title: "Product Designer", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 16) },
18
+ { id: 17, name: "Robert", title: "Backend Engineer", department: "Business Technology", branch: "New York", start_date: Date.new(2025, 1, 17) },
19
+ { id: 18, name: "Maria", title: "Frontend Developer", department: "Business Technology", branch: "Austin", start_date: Date.new(2025, 1, 18) },
20
+ { id: 19, name: "William", title: "Tech Lead", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 19) },
21
+ { id: 20, name: "Jessica", title: "Scrum Master", department: "Business Technology", branch: "New York", start_date: Date.new(2025, 1, 20) },
22
+ { id: 21, name: "Daniel", title: "Software Architect", department: "Business Technology", branch: "Austin", start_date: Date.new(2025, 1, 21) },
23
+ { id: 22, name: "Laura", title: "Business Analyst", department: "Customer Development", branch: "Philadelphia", start_date: Date.new(2025, 1, 22) },
24
+ { id: 23, name: "Chris", title: "Security Engineer", department: "Business Technology", branch: "New York", start_date: Date.new(2025, 1, 23) },
25
+ { id: 24, name: "Ashley", title: "UX Engineer III", department: "Business Technology", branch: "Austin", start_date: Date.new(2025, 1, 24) },
26
+ { id: 25, name: "Kevin", title: "Platform Engineer", department: "Business Technology", branch: "Philadelphia", start_date: Date.new(2025, 1, 25) },
27
+ { id: 26, name: "Michelle", title: "Content Designer", department: "Business Technology", branch: "New York", start_date: Date.new(2025, 1, 26) },
28
+ ] %>
29
+
30
+ <% filter_content =
31
+ pb_rails("text_input", props: {
32
+ label: "Territory ID",
33
+ placeholder: "Enter Territory ID"
34
+ }) +
35
+ pb_rails("typeahead", props: {
36
+ label: "Title",
37
+ options: [
38
+ { label: "Senior UX Engineer", value: "senior-ux-engineer" },
39
+ { label: "UX Engineer", value: "ux-engineer" },
40
+ { label: "UX Designer", value: "ux-designer" }
41
+ ]
42
+ }) +
43
+ pb_rails("select", props: {
44
+ blank_selection: "All Departments",
45
+ label: "Department",
46
+ options: [
47
+ { value: "Business Technology", text: "Business Technology" },
48
+ { value: "Customer Development", text: "Customer Development" },
49
+ { value: "Talent Acquisition", text: "Talent Acquisition" }
50
+ ]
51
+ }) +
52
+ pb_rails("dropdown", props: {
53
+ label: "Branch",
54
+ options: [
55
+ { label: "Philadelphia", value: "philadelphia" },
56
+ { label: "New York", value: "new-york" },
57
+ { label: "Austin", value: "austin" }
58
+ ]
59
+ }) +
60
+ pb_rails("date_picker", props: {
61
+ label: "Start Date",
62
+ padding_y: "sm",
63
+ picker_id: "startedOn"
64
+ }) +
65
+ pb_rails("flex", props: { spacing: "between" }) do
66
+ pb_rails("button", props: {
67
+ text: "Filter",
68
+ }) +
69
+ pb_rails("button", props: {
70
+ text: "Defaults",
71
+ variant: "secondary"
72
+ })
73
+ end
74
+ %>
75
+
76
+ <%# Replace "model" in pagination here with your specific data source %>
77
+ <% pagination_element = pb_rails("pagination", props: { model: @users, view: self, padding_y:"xs", margin_left:"lg" }) %>
78
+
79
+ <%= pb_rails("table", props: {
80
+ variant: "with_filter",
81
+ title: "Table Title Here",
82
+ filter_content: filter_content,
83
+ pagination: pagination_element,
84
+ filter_props: {
85
+ id: "user-table-filters-2",
86
+ results: users.length,
87
+ sort_menu: [
88
+ { item: "Start Date", link: "?q[sorts]=started_on+asc", active: true, direction: "asc" },
89
+ { item: "First Name", link: "?q[sorts]=name+asc", active: false },
90
+ { item: "Title", link: "?q[sorts]=title+asc", active: false },
91
+ { item: "Department", link: "?q[sorts]=department+asc", active: false },
92
+ { item: "Branch", link: "?q[sorts]=branch+asc", active: false },
93
+ { item: "Territory ID", link: "?q[sorts]=territory_id+asc", active: false },
94
+ ],
95
+ }
96
+ }) do %>
97
+ <%= pb_rails("table/table_head") do %>
98
+ <%= pb_rails("table/table_row") do %>
99
+ <%= pb_rails("table/table_header", props: { text: "Territory ID" }) %>
100
+ <%= pb_rails("table/table_header", props: { text: "Name" }) %>
101
+ <%= pb_rails("table/table_header", props: { text: "Title" }) %>
102
+ <%= pb_rails("table/table_header", props: { text: "Department" }) %>
103
+ <%= pb_rails("table/table_header", props: { text: "Branch" }) %>
104
+ <%= pb_rails("table/table_header", props: { text: "Start Date", text_align: "right" }) %>
105
+ <% end %>
106
+ <% end %>
107
+
108
+ <%= pb_rails("table/table_body") do %>
109
+ <% users.each do |user| %>
110
+ <%= pb_rails("table/table_row") do %>
111
+ <%= pb_rails("table/table_cell", props: { margin_x: { xs: "sm" }, number_spacing: "tabular" }) { user[:id].to_s } %>
112
+ <%= pb_rails("table/table_cell", props: { margin_x: { xs: "sm" } }) { user[:name] } %>
113
+ <%= pb_rails("table/table_cell", props: { margin_x: { xs: "sm" } }) { user[:title] } %>
114
+ <%= pb_rails("table/table_cell", props: { margin_x: { xs: "sm" } }) { user[:department] } %>
115
+ <%= pb_rails("table/table_cell", props: { margin_x: { xs: "sm" } }) { user[:branch] } %>
116
+ <%= pb_rails("table/table_cell", props: { margin_x: { xs: "sm" } }) do %>
117
+ <%= pb_rails("date", props: {alignment: "right", date: user[:start_date].to_s, show_current_year: true } ) %>
118
+ <% end %>
119
+ <% end %>
120
+ <% end %>
121
+ <% end %>
122
+ <% end %>
@@ -0,0 +1,3 @@
1
+ The `with_filter` variant can also be used with the Pagination kit as shown here. Simply set up your Pagination as normal, and pass the Pagination kit to the prop `pagination` as shown.
2
+
3
+ **IMPORTANT NOTE**: This is NOT a working example of pagination, please set up your use case with the relevant data in your controller. For more information on the Pagination Kit and how to use it, see the documentation [here](https://playbook.powerapp.cloud/kits/pagination/rails)
@@ -40,6 +40,8 @@ examples:
40
40
  - table_with_selectable_rows: Table with Selectable Rows
41
41
  - table_with_header_style_borderless: Header Style Borderless
42
42
  - table_with_header_style_floating: Header Style Floating
43
+ - table_with_filter_variant_rails: Variant with Filter
44
+ - table_with_filter_variant_with_pagination_rails: Variant with Filter and Pagination
43
45
 
44
46
  react:
45
47
  - table_sm: Small
@@ -81,3 +83,5 @@ examples:
81
83
  - table_with_selectable_rows: Table with Selectable Rows
82
84
  - table_with_header_style_borderless: Header Style Borderless
83
85
  - table_with_header_style_floating: Header Style Floating
86
+ - table_with_filter_variant: Variant with Filter
87
+ - table_with_filter_variant_with_pagination: Variant with Filter and Pagination
@@ -38,3 +38,5 @@ export { default as TableWithSelectableRows } from './_table_with_selectable_row
38
38
  export { default as TableWithClickableRows } from './_table_with_clickable_rows.jsx'
39
39
  export { default as TableWithHeaderStyleBorderless } from './_table_with_header_style_borderless.jsx'
40
40
  export { default as TableWithHeaderStyleFloating } from './_table_with_header_style_floating.jsx'
41
+ export { default as TableWithFilterVariant } from './_table_with_filter_variant.jsx'
42
+ export { default as TableWithFilterVariantWithPagination } from './_table_with_filter_variant_with_pagination.jsx'
@@ -1 +1 @@
1
- Text Input w/ Error shows that the radio option must be selected or is invalid (ie when used in a form it signals a user to fix an error).
1
+ Text Input w/ Error shows that the input must be filled out (i.e. when used in a form it signals a user to fix an error).
@@ -0,0 +1,6 @@
1
+ <%= pb_rails("text_input", props: {
2
+ label: "First Name",
3
+ placeholder: "Enter first name",
4
+ id: "text_input_required_indicator",
5
+ required_indicator: true,
6
+ }) %>
@@ -0,0 +1,25 @@
1
+ import React, { useState } from 'react'
2
+
3
+ import TextInput from '../../pb_text_input/_text_input'
4
+
5
+ const TextInputDefault = (props) => {
6
+ const [firstName, setFirstName] = useState('')
7
+ const handleOnChangeFirstName = ({ target }) => {
8
+ setFirstName(target.value)
9
+ }
10
+
11
+ return (
12
+ <TextInput
13
+ id="text_input_required_indicator"
14
+ label="First Name"
15
+ name="firstName"
16
+ onChange={handleOnChangeFirstName}
17
+ placeholder="Enter first name"
18
+ requiredIndicator
19
+ value={firstName}
20
+ {...props}
21
+ />
22
+ )
23
+ }
24
+
25
+ export default TextInputDefault
@@ -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.
@@ -10,6 +10,8 @@ examples:
10
10
  - text_input_options: Input Options
11
11
  - text_input_mask: Mask
12
12
  - text_input_autocomplete: Autocomplete
13
+ - text_input_required_indicator: Required Indicator
14
+
13
15
 
14
16
  react:
15
17
  - text_input_default: Default
@@ -22,6 +24,7 @@ examples:
22
24
  - text_input_mask: Mask
23
25
  - text_input_sanitize: Sanitized Masked Input
24
26
  - text_input_autocomplete: Autocomplete
27
+ - text_input_required_indicator: Required Indicator
25
28
 
26
29
 
27
30
  swift:
@@ -8,3 +8,4 @@ export { default as TextInputNoLabel } from './_text_input_no_label.jsx'
8
8
  export { default as TextInputMask } from './_text_input_mask.jsx'
9
9
  export { default as TextInputSanitize } from './_text_input_sanitize.jsx'
10
10
  export { default as TextInputAutocomplete } from './_text_input_autocomplete.jsx'
11
+ export { default as TextInputRequiredIndicator } from './_text_input_required_indicator.jsx'
@@ -1 +1 @@
1
- Textarea w/ Error shows that the radio option must be selected or is invalid (ie when used in a form it signals a user to fix an error).
1
+ Textarea w/ Error shows that the input must be filled out (i.e. when used in a form it signals a user to fix an error).
@@ -0,0 +1,2 @@
1
+ <%= pb_rails("time_picker", props: { id: "time-picker-24-hour", label: "24-Hour Format", time_format: "24hour" }) %>
2
+
@@ -0,0 +1,16 @@
1
+ import React from 'react'
2
+ import TimePicker from '../../pb_time_picker/_time_picker'
3
+
4
+ const TimePicker24Hour = (props) => (
5
+ <div>
6
+ <TimePicker
7
+ id="time-picker-24-hour"
8
+ label="24-Hour Format"
9
+ timeFormat="24hour"
10
+ {...props}
11
+ />
12
+ </div>
13
+ )
14
+
15
+ export default TimePicker24Hour
16
+
@@ -0,0 +1 @@
1
+ Set `time_format` / `timeFormat` to 24hour to display the time selection dropdown in a 24-hour format.
@@ -0,0 +1 @@
1
+ <%= pb_rails("time_picker", props: { id: "time-picker-default" }) %>
@@ -0,0 +1,13 @@
1
+ import React from 'react'
2
+ import TimePicker from '../../pb_time_picker/_time_picker'
3
+
4
+ const TimePickerDefault = (props) => (
5
+ <div>
6
+ <TimePicker
7
+ id="time-picker-default"
8
+ {...props}
9
+ />
10
+ </div>
11
+ )
12
+
13
+ export default TimePickerDefault
@@ -0,0 +1 @@
1
+ Use the Time Picker for time-only selection. For date and time selection, use the [DatePicker with Time Selection Enabled](https://playbook.powerapp.cloud/kits/date_picker/react#time-selection) instead.
@@ -0,0 +1,4 @@
1
+ <%= pb_rails("time_picker", props: { id: "time-picker-default-time-12hr", default_time: "2:30 PM", label: "12-Hour Format (2:30 PM)" }) %>
2
+ <%= pb_rails("time_picker", props: { id: "time-picker-default-time-24hr", default_time: "14:30", label: "24-Hour Format (14:30)" }) %>
3
+ <%= pb_rails("time_picker", props: { id: "time-picker-default-time-24hr-format", default_time: "14:30", label: "24-Hour Format with timeFormat (14:30)", time_format: "24hour" }) %>
4
+
@@ -0,0 +1,29 @@
1
+ import React from 'react'
2
+ import TimePicker from '../../pb_time_picker/_time_picker'
3
+
4
+ const TimePickerDefaultTime = (props) => (
5
+ <div>
6
+ <TimePicker
7
+ defaultTime="2:30 PM"
8
+ id="time-picker-default-time-12hr"
9
+ label="12-Hour Format (2:30 PM)"
10
+ {...props}
11
+ />
12
+ <TimePicker
13
+ defaultTime="14:30"
14
+ id="time-picker-default-time-24hr"
15
+ label="24-Hour Format (14:30)"
16
+ {...props}
17
+ />
18
+ <TimePicker
19
+ defaultTime="14:30"
20
+ id="time-picker-default-time-24hr-format"
21
+ label="24-Hour Format with timeFormat (14:30)"
22
+ timeFormat="24hour"
23
+ {...props}
24
+ />
25
+ </div>
26
+ )
27
+
28
+ export default TimePickerDefaultTime
29
+
@@ -0,0 +1 @@
1
+ The `default_time` / `defaultTime` prop sets a default time value and accepts both 12-hour and 24-hour formats.