playbook_ui 14.24.0.pre.alpha.PLAY2346reactpaginationexternalcontrol9346 → 14.24.0.pre.alpha.PLAY2360circleiconbuttonvariantdatabug9438
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +34 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_headers_vertical_border.html.erb +43 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_headers_vertical_border.jsx +64 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/table_row.rb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/table_subrow_header.rb +1 -1
- data/app/pb_kits/playbook/pb_circle_icon_button/circle_icon_button.html.erb +10 -1
- data/app/pb_kits/playbook/pb_circle_icon_button/circle_icon_button.rb +2 -0
- data/app/pb_kits/playbook/pb_circle_icon_button/docs/_circle_icon_button_input_options.html.erb +24 -0
- data/app/pb_kits/playbook/pb_circle_icon_button/docs/_circle_icon_button_input_options.md +3 -0
- data/app/pb_kits/playbook/pb_circle_icon_button/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_date/_date.tsx +5 -3
- data/app/pb_kits/playbook/pb_date/date.html.erb +6 -6
- data/app/pb_kits/playbook/pb_date/date.rb +2 -0
- data/app/pb_kits/playbook/pb_date/docs/_date_with_show_current_year.html.erb +4 -0
- data/app/pb_kits/playbook/pb_date/docs/_date_with_show_current_year.jsx +17 -0
- data/app/pb_kits/playbook/pb_date/docs/_date_with_show_current_year.md +1 -0
- data/app/pb_kits/playbook/pb_date/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_date/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_pagination/_pagination.tsx +1 -8
- data/app/pb_kits/playbook/pb_pagination/docs/example.yml +0 -1
- data/app/pb_kits/playbook/pb_pagination/docs/index.js +0 -1
- data/app/pb_kits/playbook/pb_table/styles/_vertical_border.scss +49 -1
- data/dist/chunks/{_weekday_stacked-BavTnN0s.js → _weekday_stacked-CJIFKKe7.js} +1 -1
- data/dist/chunks/vendor.js +1 -1
- data/dist/menu.yml +1 -1
- data/dist/playbook-doc.js +1 -1
- data/dist/playbook.css +1 -1
- data/lib/playbook/version.rb +1 -1
- metadata +10 -6
- data/app/pb_kits/playbook/pb_pagination/_pagination.test.jsx +0 -212
- data/app/pb_kits/playbook/pb_pagination/docs/_pagination_external_control.jsx +0 -112
- data/app/pb_kits/playbook/pb_pagination/docs/_pagination_external_control_react.md +0 -3
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA256:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: 8d63f8caad922ad77209ac5c84981e8afa63785f9293cc729d85bab21f7a6b9e
         | 
| 4 | 
            +
              data.tar.gz: 301b9c1eb70fefd1a9d7e43023db95bfd2eb6829d2594ff09f53ea79a9ab8e96
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 0e8f122547dcf95b2598b27081cb0e51b2c31d871871b357cae1e957e7af6740dfcb147d7ca4aac7f5c8ce96ee43dd7bacd6a397cffd73c44bda691142c1e0e7
         | 
| 7 | 
            +
              data.tar.gz: d671ca594ccbbcf966350fa8e2e0f894da084a212d173d04b1f54f7ed003131d390c127eed7601c7fa24ea4728dcb2d9103f32f590d79c6f2723c7907f6ba0af
         | 
| @@ -971,6 +971,40 @@ | |
| 971 971 | 
             
                  }
         | 
| 972 972 | 
             
                }
         | 
| 973 973 | 
             
              }
         | 
| 974 | 
            +
             | 
| 975 | 
            +
              // Firefox-specific fix for last-header-cell and last-cell vertical borders
         | 
| 976 | 
            +
              @-moz-document url-prefix() {
         | 
| 977 | 
            +
                .pb_advanced_table_header {
         | 
| 978 | 
            +
                  .last-header-cell {
         | 
| 979 | 
            +
                    border-right: none !important;
         | 
| 980 | 
            +
                    box-shadow: 1px 0 0 0 $border_light !important;
         | 
| 981 | 
            +
                  }
         | 
| 982 | 
            +
                }
         | 
| 983 | 
            +
             | 
| 984 | 
            +
                .pb_advanced_table_body {
         | 
| 985 | 
            +
                  .last-cell {
         | 
| 986 | 
            +
                    border-right: none !important;
         | 
| 987 | 
            +
                    box-shadow: 1px 0 0 0 $border_light !important;
         | 
| 988 | 
            +
                  }
         | 
| 989 | 
            +
                }
         | 
| 990 | 
            +
             | 
| 991 | 
            +
                // Dark mode Firefox fixes
         | 
| 992 | 
            +
                &.dark {
         | 
| 993 | 
            +
                  .pb_advanced_table_header {
         | 
| 994 | 
            +
                    .last-header-cell {
         | 
| 995 | 
            +
                      border-right: none !important;
         | 
| 996 | 
            +
                      box-shadow: 1px 0 0 0 $border_dark !important;
         | 
| 997 | 
            +
                    }
         | 
| 998 | 
            +
                  }
         | 
| 999 | 
            +
             | 
| 1000 | 
            +
                  .pb_advanced_table_body {
         | 
| 1001 | 
            +
                    .last-cell {
         | 
| 1002 | 
            +
                      border-right: none !important;
         | 
| 1003 | 
            +
                      box-shadow: 1px 0 0 0 $border_dark !important;
         | 
| 1004 | 
            +
                    }
         | 
| 1005 | 
            +
                  }
         | 
| 1006 | 
            +
                }
         | 
| 1007 | 
            +
              }
         | 
| 974 1008 | 
             
            }
         | 
| 975 1009 |  | 
| 976 1010 | 
             
            // Outside of the pb_advanced_table class for popover
         | 
| @@ -0,0 +1,43 @@ | |
| 1 | 
            +
            <% column_definitions = [
         | 
| 2 | 
            +
              {
         | 
| 3 | 
            +
                accessor: "year",
         | 
| 4 | 
            +
                label: "Year",
         | 
| 5 | 
            +
                cellAccessors: ["quarter", "month", "day"],
         | 
| 6 | 
            +
              },
         | 
| 7 | 
            +
              {
         | 
| 8 | 
            +
                label: "Enrollment Data",
         | 
| 9 | 
            +
                columns: [
         | 
| 10 | 
            +
                  {
         | 
| 11 | 
            +
                    accessor: "newEnrollments",
         | 
| 12 | 
            +
                    label: "New Enrollments",
         | 
| 13 | 
            +
                  },
         | 
| 14 | 
            +
                  {
         | 
| 15 | 
            +
                    accessor: "scheduledMeetings",
         | 
| 16 | 
            +
                    label: "Scheduled Meetings",
         | 
| 17 | 
            +
                  },
         | 
| 18 | 
            +
                ],
         | 
| 19 | 
            +
              },
         | 
| 20 | 
            +
              {
         | 
| 21 | 
            +
                label: "Performance Data",
         | 
| 22 | 
            +
                columns: [
         | 
| 23 | 
            +
                  {
         | 
| 24 | 
            +
                    accessor: "attendanceRate",
         | 
| 25 | 
            +
                    label: "Attendance Rate",
         | 
| 26 | 
            +
                  },
         | 
| 27 | 
            +
                  {
         | 
| 28 | 
            +
                    accessor: "completedClasses",
         | 
| 29 | 
            +
                    label: "Completed Classes",
         | 
| 30 | 
            +
                  },
         | 
| 31 | 
            +
                  {
         | 
| 32 | 
            +
                    accessor: "classCompletionRate",
         | 
| 33 | 
            +
                    label: "Class Completion Rate",
         | 
| 34 | 
            +
                  },
         | 
| 35 | 
            +
                  {
         | 
| 36 | 
            +
                    accessor: "graduatedStudents",
         | 
| 37 | 
            +
                    label: "Graduated Students",
         | 
| 38 | 
            +
                  },
         | 
| 39 | 
            +
                ],
         | 
| 40 | 
            +
              },
         | 
| 41 | 
            +
            ] %>
         | 
| 42 | 
            +
             | 
| 43 | 
            +
            <%= pb_rails("advanced_table", props: { id: "table_multi_headers_vertical_borders", table_data: @table_data, column_definitions: column_definitions, table_props: { vertical_border: true } }) %>
         | 
    
        data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_headers_vertical_border.jsx
    ADDED
    
    | @@ -0,0 +1,64 @@ | |
| 1 | 
            +
            import React from "react"
         | 
| 2 | 
            +
            import AdvancedTable from '../../pb_advanced_table/_advanced_table'
         | 
| 3 | 
            +
            import MOCK_DATA from "./advanced_table_mock_data.json"
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            const AdvancedTableColumnHeadersVerticalBorder = (props) => {
         | 
| 6 | 
            +
              const columnDefinitions = [
         | 
| 7 | 
            +
                {
         | 
| 8 | 
            +
                  accessor: "year",
         | 
| 9 | 
            +
                  label: "Year",
         | 
| 10 | 
            +
                  cellAccessors: ["quarter", "month", "day"],
         | 
| 11 | 
            +
                },
         | 
| 12 | 
            +
                {
         | 
| 13 | 
            +
                  label: "Enrollment Data",
         | 
| 14 | 
            +
                  columns: [
         | 
| 15 | 
            +
                    {
         | 
| 16 | 
            +
                      accessor: "newEnrollments",
         | 
| 17 | 
            +
                      label: "New Enrollments",
         | 
| 18 | 
            +
                    },
         | 
| 19 | 
            +
                    {
         | 
| 20 | 
            +
                      accessor: "scheduledMeetings",
         | 
| 21 | 
            +
                      label: "Scheduled Meetings",
         | 
| 22 | 
            +
                    },
         | 
| 23 | 
            +
                  ],
         | 
| 24 | 
            +
                },
         | 
| 25 | 
            +
                {
         | 
| 26 | 
            +
                  label: "Performance Data",
         | 
| 27 | 
            +
                  columns: [
         | 
| 28 | 
            +
                    {
         | 
| 29 | 
            +
                      accessor: "attendanceRate",
         | 
| 30 | 
            +
                      label: "Attendance Rate",
         | 
| 31 | 
            +
                    },
         | 
| 32 | 
            +
                    {
         | 
| 33 | 
            +
                      accessor: "completedClasses",
         | 
| 34 | 
            +
                      label: "Completed Classes",
         | 
| 35 | 
            +
                    },
         | 
| 36 | 
            +
                    {
         | 
| 37 | 
            +
                      accessor: "classCompletionRate",
         | 
| 38 | 
            +
                      label: "Class Completion Rate",
         | 
| 39 | 
            +
                    },
         | 
| 40 | 
            +
                    {
         | 
| 41 | 
            +
                      accessor: "graduatedStudents",
         | 
| 42 | 
            +
                      label: "Graduated Students",
         | 
| 43 | 
            +
                    },
         | 
| 44 | 
            +
                  ],
         | 
| 45 | 
            +
                },
         | 
| 46 | 
            +
              ];
         | 
| 47 | 
            +
              
         | 
| 48 | 
            +
              const tableProps = {
         | 
| 49 | 
            +
                verticalBorder: true
         | 
| 50 | 
            +
              }
         | 
| 51 | 
            +
             | 
| 52 | 
            +
              return (
         | 
| 53 | 
            +
                <>
         | 
| 54 | 
            +
                  <AdvancedTable
         | 
| 55 | 
            +
                      columnDefinitions={columnDefinitions}
         | 
| 56 | 
            +
                      tableData={MOCK_DATA}
         | 
| 57 | 
            +
                      tableProps={tableProps}
         | 
| 58 | 
            +
                      {...props}
         | 
| 59 | 
            +
                  />
         | 
| 60 | 
            +
                </>
         | 
| 61 | 
            +
              )
         | 
| 62 | 
            +
            }
         | 
| 63 | 
            +
             | 
| 64 | 
            +
            export default AdvancedTableColumnHeadersVerticalBorder
         | 
| @@ -13,6 +13,7 @@ examples: | |
| 13 13 | 
             
              - advanced_table_with_custom_header_rails: Custom Header Cell
         | 
| 14 14 | 
             
              - advanced_table_column_headers: Multi-Header Columns
         | 
| 15 15 | 
             
              - advanced_table_column_headers_multiple: Multi-Header Columns (Multiple Levels)
         | 
| 16 | 
            +
              - advanced_table_column_headers_vertical_border: Multi-Header Columns with Vertical Borders
         | 
| 16 17 | 
             
              - advanced_table_no_subrows: Table with No Subrows or Expansion
         | 
| 17 18 | 
             
              - advanced_table_selectable_rows_rails: Selectable Rows
         | 
| 18 19 | 
             
              - advanced_table_selectable_rows_no_subrows_rails: Selectable Rows (No Subrows)
         | 
| @@ -53,6 +54,7 @@ examples: | |
| 53 54 | 
             
              - advanced_table_column_headers: Multi-Header Columns
         | 
| 54 55 | 
             
              - advanced_table_column_headers_multiple: Multi-Header Columns (Multiple Levels)
         | 
| 55 56 | 
             
              - advanced_table_column_headers_custom_cell: Multi-Header Columns with Custom Cells
         | 
| 57 | 
            +
              - advanced_table_column_headers_vertical_border: Multi-Header Columns with Vertical Borders
         | 
| 56 58 | 
             
              - advanced_table_no_subrows: Table with No Subrows or Expansion
         | 
| 57 59 | 
             
              - advanced_table_pinned_rows: Pinned Rows
         | 
| 58 60 | 
             
              - advanced_table_selectable_rows: Selectable Rows
         | 
| @@ -21,6 +21,7 @@ export { default as AdvancedTableSelectableRowsHeader } from './_advanced_table_ | |
| 21 21 | 
             
            export { default as AdvancedTableSelectableRowsActions } from './_advanced_table_selectable_rows_actions.jsx'
         | 
| 22 22 | 
             
            export { default as AdvancedTableTablePropsStickyHeader } from './_advanced_table_table_props_sticky_header.jsx'
         | 
| 23 23 | 
             
            export { default as AdvancedTableColumnHeadersCustomCell } from './_advanced_table_column_headers_custom_cell.jsx'
         | 
| 24 | 
            +
            export { default as AdvancedTableColumnHeadersVerticalBorder } from './_advanced_table_column_headers_vertical_border.jsx'
         | 
| 24 25 | 
             
            export { default as AdvancedTableInlineEditing } from './_advanced_table_inline_editing.jsx'
         | 
| 25 26 | 
             
            export { default as AdvancedTableFullscreen } from './_advanced_table_fullscreen.jsx'
         | 
| 26 27 | 
             
            export { default as AdvancedTableStickyColumns } from './_advanced_table_sticky_columns.jsx'
         | 
| @@ -43,7 +43,7 @@ module Playbook | |
| 43 43 | 
             
                  end
         | 
| 44 44 |  | 
| 45 45 | 
             
                  def td_classname(column, index)
         | 
| 46 | 
            -
                    classes = %w[id-cell | 
| 46 | 
            +
                    classes = %w[id-cell]
         | 
| 47 47 | 
             
                    classes << "last-cell" if column[:is_last_in_group]
         | 
| 48 48 | 
             
                    classes << "pinned-left" if index.zero? && is_pinned_left && responsive == "scroll"
         | 
| 49 49 | 
             
                    classes.join(" ")
         | 
| @@ -1,5 +1,14 @@ | |
| 1 1 | 
             
            <%= pb_content_tag do %>
         | 
| 2 | 
            -
              <%= pb_rails("button", props: { | 
| 2 | 
            +
              <%= pb_rails("button", props: {
         | 
| 3 | 
            +
                type: object.type, 
         | 
| 4 | 
            +
                loading: object.loading, 
         | 
| 5 | 
            +
                link: object.link, 
         | 
| 6 | 
            +
                new_window: object.new_window, 
         | 
| 7 | 
            +
                variant: object.variant, 
         | 
| 8 | 
            +
                target: object.target, 
         | 
| 9 | 
            +
                disabled: object.disabled, 
         | 
| 10 | 
            +
                dark: object.dark
         | 
| 11 | 
            +
              }.merge(object.input_options)) do %>
         | 
| 3 12 | 
             
                <%= pb_rails("icon", props: {icon: object.icon, fixed_width: true, dark: object.dark}) %>
         | 
| 4 13 | 
             
              <% end %>
         | 
| 5 14 | 
             
            <% end %>
         | 
| @@ -21,6 +21,8 @@ module Playbook | |
| 21 21 | 
             
                  prop :size, type: Playbook::Props::Enum,
         | 
| 22 22 | 
             
                              values: %w[default sm],
         | 
| 23 23 | 
             
                              default: "default"
         | 
| 24 | 
            +
                  prop :input_options, type: Playbook::Props::HashProp,
         | 
| 25 | 
            +
                                       default: {}
         | 
| 24 26 |  | 
| 25 27 | 
             
                  def classname
         | 
| 26 28 | 
             
                    generate_classname("pb_circle_icon_button_kit") + size_class
         | 
    
        data/app/pb_kits/playbook/pb_circle_icon_button/docs/_circle_icon_button_input_options.html.erb
    ADDED
    
    | @@ -0,0 +1,24 @@ | |
| 1 | 
            +
            <%= pb_rails("circle_icon_button", props: {
         | 
| 2 | 
            +
              icon: "plus",
         | 
| 3 | 
            +
              input_options: {
         | 
| 4 | 
            +
                data: { "test-id": "add-button", remote: true },
         | 
| 5 | 
            +
              }
         | 
| 6 | 
            +
            }) %>
         | 
| 7 | 
            +
            <br/>
         | 
| 8 | 
            +
            <%= pb_rails("circle_icon_button", props: {
         | 
| 9 | 
            +
              icon: "pen",
         | 
| 10 | 
            +
              variant: "secondary",
         | 
| 11 | 
            +
              input_options: {
         | 
| 12 | 
            +
                data: { "test-id": "edit-button" },
         | 
| 13 | 
            +
                classname: "custom-secondary-button-class"
         | 
| 14 | 
            +
              }
         | 
| 15 | 
            +
            }) %>
         | 
| 16 | 
            +
            <br/>
         | 
| 17 | 
            +
            <%= pb_rails("circle_icon_button", props: {
         | 
| 18 | 
            +
              icon: "user",
         | 
| 19 | 
            +
              variant: "link",
         | 
| 20 | 
            +
              input_options: {
         | 
| 21 | 
            +
                data: { "test-id": "user-button" },
         | 
| 22 | 
            +
                id: "user-button-id"
         | 
| 23 | 
            +
              }
         | 
| 24 | 
            +
            }) %>
         | 
| @@ -0,0 +1,3 @@ | |
| 1 | 
            +
            Use the `input_options` prop to pass additional attributes directly to the internal Playbook Button component. While the wrapper div has access to the standard `data` prop from KitBase, `input_options` allows you to attach attributes specifically to the internal button element.
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            This is particularly useful when you need data attributes or other HTML attributes to apply to the button itself.
         | 
| @@ -19,6 +19,7 @@ type PbDateProps = { | |
| 19 19 | 
             
              htmlOptions?: { [key: string]: string | number | boolean | (() => void) };
         | 
| 20 20 | 
             
              id?: string;
         | 
| 21 21 | 
             
              showDayOfWeek?: boolean;
         | 
| 22 | 
            +
              showCurrentYear?: boolean;
         | 
| 22 23 | 
             
              showIcon?: boolean;
         | 
| 23 24 | 
             
              size?: "sm" | "md" | "lg";
         | 
| 24 25 | 
             
              unstyled?: boolean;
         | 
| @@ -35,6 +36,7 @@ const PbDate = (props: PbDateProps): React.ReactElement => { | |
| 35 36 | 
             
                htmlOptions = {},
         | 
| 36 37 | 
             
                id,
         | 
| 37 38 | 
             
                showDayOfWeek = false,
         | 
| 39 | 
            +
                showCurrentYear = false,
         | 
| 38 40 | 
             
                showIcon = false,
         | 
| 39 41 | 
             
                size = "md",
         | 
| 40 42 | 
             
                unstyled = false,
         | 
| @@ -90,7 +92,7 @@ const PbDate = (props: PbDateProps): React.ReactElement => { | |
| 90 92 | 
             
                            {month} {day}
         | 
| 91 93 | 
             
                          </span>
         | 
| 92 94 |  | 
| 93 | 
            -
                          {currentYear  | 
| 95 | 
            +
                          {(currentYear !== year || showCurrentYear) && <span>{`, ${year}`}</span>}
         | 
| 94 96 | 
             
                        </span>
         | 
| 95 97 | 
             
                      </>
         | 
| 96 98 | 
             
                    : size == "md" || size == "lg"
         | 
| @@ -124,7 +126,7 @@ const PbDate = (props: PbDateProps): React.ReactElement => { | |
| 124 126 | 
             
                          <span>
         | 
| 125 127 | 
             
                            {month} {day}
         | 
| 126 128 | 
             
                          </span>
         | 
| 127 | 
            -
                          {currentYear  | 
| 129 | 
            +
                          {(currentYear !== year || showCurrentYear) && <span>{`, ${year}`}</span>}
         | 
| 128 130 | 
             
                        </Title>
         | 
| 129 131 | 
             
                        )
         | 
| 130 132 | 
             
                      : (
         | 
| @@ -158,7 +160,7 @@ const PbDate = (props: PbDateProps): React.ReactElement => { | |
| 158 160 | 
             
                            <Caption dark={dark}
         | 
| 159 161 | 
             
                                tag="span">
         | 
| 160 162 | 
             
                              {month} {day}
         | 
| 161 | 
            -
                              {currentYear  | 
| 163 | 
            +
                              {(currentYear !== year || showCurrentYear) && <>{`, ${year}`}</>}
         | 
| 162 164 | 
             
                            </Caption>
         | 
| 163 165 | 
             
                          </>
         | 
| 164 166 | 
             
                        )}
         | 
| @@ -13,8 +13,8 @@ | |
| 13 13 | 
             
                <% end %>
         | 
| 14 14 |  | 
| 15 15 | 
             
                <!-- month day, year -->
         | 
| 16 | 
            -
                <%# if not current year %>
         | 
| 17 | 
            -
                <% if object.year.to_s == DateTime.now.year.to_s %>
         | 
| 16 | 
            +
                <%# if not current year or show_current_year is false %>
         | 
| 17 | 
            +
                <% if object.year.to_s == DateTime.now.year.to_s && !object.show_current_year %>
         | 
| 18 18 | 
             
                  <span><%= "#{object.month} #{object.day}" %></span>
         | 
| 19 19 | 
             
                <%# if is current year %>
         | 
| 20 20 | 
             
                <% else %>
         | 
| @@ -44,8 +44,8 @@ | |
| 44 44 |  | 
| 45 45 | 
             
                <!-- month day, year -->
         | 
| 46 46 |  | 
| 47 | 
            -
                <%# if not current year %>
         | 
| 48 | 
            -
                <% if object.year.to_s == DateTime.now.year.to_s %>
         | 
| 47 | 
            +
                <%# if not current year or show_current_year is false %>
         | 
| 48 | 
            +
                <% if object.year.to_s == DateTime.now.year.to_s  && !object.show_current_year  %>
         | 
| 49 49 | 
             
                  <%= pb_rails("title", props: { tag: "div", text: "#{object.month} #{object.day}", size: 4 }) %>
         | 
| 50 50 | 
             
                <%# if is current year %>
         | 
| 51 51 | 
             
                <% else %>
         | 
| @@ -74,8 +74,8 @@ | |
| 74 74 |  | 
| 75 75 | 
             
                <!-- month day, year -->
         | 
| 76 76 |  | 
| 77 | 
            -
                <%# if not current year %>
         | 
| 78 | 
            -
                <% if object.year.to_s == DateTime.now.year.to_s %>
         | 
| 77 | 
            +
                <%# if not current year or show_current_year is false %>
         | 
| 78 | 
            +
                <% if object.year.to_s == DateTime.now.year.to_s  && !object.show_current_year %>
         | 
| 79 79 | 
             
                  <%= pb_rails("caption", props: { tag: "span", text: "#{object.month} #{object.day}" }) %>
         | 
| 80 80 | 
             
                <%# if is current year %>
         | 
| 81 81 | 
             
                <% else %>
         | 
| @@ -11,6 +11,8 @@ module Playbook | |
| 11 11 | 
             
                                   default: false
         | 
| 12 12 | 
             
                  prop :show_day_of_week, type: Playbook::Props::Boolean,
         | 
| 13 13 | 
             
                                          default: false
         | 
| 14 | 
            +
                  prop :show_current_year, type: Playbook::Props::Boolean,
         | 
| 15 | 
            +
                                           default: false
         | 
| 14 16 | 
             
                  prop :size, type: Playbook::Props::Enum,
         | 
| 15 17 | 
             
                              values: %w[lg md sm xs],
         | 
| 16 18 | 
             
                              default: "md"
         | 
| @@ -0,0 +1,17 @@ | |
| 1 | 
            +
            import React from 'react'
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            import FormattedDate from '../../pb_date/_date'
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            const DateWithShowCurrentYear = (props) => {
         | 
| 6 | 
            +
              return (
         | 
| 7 | 
            +
                <>
         | 
| 8 | 
            +
                  <FormattedDate
         | 
| 9 | 
            +
                      showCurrentYear
         | 
| 10 | 
            +
                      value={new Date()}
         | 
| 11 | 
            +
                      {...props}
         | 
| 12 | 
            +
                  />
         | 
| 13 | 
            +
                </>
         | 
| 14 | 
            +
              )
         | 
| 15 | 
            +
            }
         | 
| 16 | 
            +
             | 
| 17 | 
            +
            export default DateWithShowCurrentYear
         | 
| @@ -0,0 +1 @@ | |
| 1 | 
            +
            By default, the Date kit does NOT display the year if it is the current year. If you want to display the current year you can do so by setting `showCurrentYear`/`show_current_year` to true as shown here. 
         | 
| @@ -5,12 +5,14 @@ examples: | |
| 5 5 | 
             
              - date_variants: Variants
         | 
| 6 6 | 
             
              - date_alignment: Alignment
         | 
| 7 7 | 
             
              - date_timezone: Timezones
         | 
| 8 | 
            +
              - date_with_show_current_year: Show Current Year
         | 
| 8 9 | 
             
              - date_unstyled: Unstyled
         | 
| 9 10 |  | 
| 10 11 | 
             
              react:
         | 
| 11 12 | 
             
              - date_default: Default
         | 
| 12 13 | 
             
              - date_variants: Variants
         | 
| 13 14 | 
             
              - date_alignment: Alignment
         | 
| 15 | 
            +
              - date_with_show_current_year: Show Current Year
         | 
| 14 16 | 
             
              - date_unstyled: Unstyled
         | 
| 15 17 |  | 
| 16 18 | 
             
              swift:
         | 
| @@ -2,3 +2,4 @@ export { default as DateDefault } from './_date_default.jsx' | |
| 2 2 | 
             
            export { default as DateVariants } from './_date_variants.jsx'
         | 
| 3 3 | 
             
            export { default as DateAlignment } from './_date_alignment.jsx'
         | 
| 4 4 | 
             
            export { default as DateUnstyled } from './_date_unstyled.jsx'
         | 
| 5 | 
            +
            export { default as DateWithShowCurrentYear } from './_date_with_show_current_year.jsx'
         | 
| @@ -1,4 +1,4 @@ | |
| 1 | 
            -
            import React, { useState | 
| 1 | 
            +
            import React, { useState } from "react";
         | 
| 2 2 | 
             
            import classnames from 'classnames'
         | 
| 3 3 | 
             
            import { GlobalProps, globalProps } from '../utilities/globalProps'
         | 
| 4 4 | 
             
            import { buildAriaProps, buildCss, buildDataProps, buildHtmlProps } from '../utilities/props'
         | 
| @@ -123,13 +123,6 @@ const Pagination = ( props: PaginationProps) => { | |
| 123 123 |  | 
| 124 124 | 
             
                return buttons;
         | 
| 125 125 | 
             
              };
         | 
| 126 | 
            -
             | 
| 127 | 
            -
              // Sync internal state with external current prop
         | 
| 128 | 
            -
              useEffect(() => {
         | 
| 129 | 
            -
                if (current >= 1 && current <= total) {
         | 
| 130 | 
            -
                  setCurrentPage(current);
         | 
| 131 | 
            -
                }
         | 
| 132 | 
            -
              }, [current, total]);
         | 
| 133 126 |  | 
| 134 127 |  | 
| 135 128 | 
             
              const ariaProps = buildAriaProps(aria)
         | 
| @@ -7,7 +7,7 @@ | |
| 7 7 | 
             
                thead tr:not(:first-child) th {
         | 
| 8 8 | 
             
                  border-right: 1px solid $border_light !important;
         | 
| 9 9 | 
             
                }
         | 
| 10 | 
            -
             | 
| 10 | 
            +
             | 
| 11 11 | 
             
                @media screen and (min-width: $screen-xs-min) {
         | 
| 12 12 | 
             
                  tr:hover, .pb_table_tr:hover {
         | 
| 13 13 | 
             
                    td:last-child, .pb_table_td:last-child {
         | 
| @@ -15,5 +15,53 @@ | |
| 15 15 | 
             
                    }
         | 
| 16 16 | 
             
                  }
         | 
| 17 17 | 
             
                }
         | 
| 18 | 
            +
             | 
| 19 | 
            +
                // Firefox-specific fix for sticky elements
         | 
| 20 | 
            +
                @-moz-document url-prefix() {
         | 
| 21 | 
            +
                  // Target sticky headers
         | 
| 22 | 
            +
                  &.sticky-header {
         | 
| 23 | 
            +
                    th:not(:last-child) {
         | 
| 24 | 
            +
                      border-right: none !important;
         | 
| 25 | 
            +
                      box-shadow: 1px 0 0 0 $border_light !important;
         | 
| 26 | 
            +
                    }
         | 
| 27 | 
            +
             | 
| 28 | 
            +
                    .pb_advanced_table_body {
         | 
| 29 | 
            +
                      .pinned-row {
         | 
| 30 | 
            +
                        td:not(:first-child):not(:last-child) {
         | 
| 31 | 
            +
                          border-right: none !important;
         | 
| 32 | 
            +
                          box-shadow: 1px 0 0 0 $border_light !important;
         | 
| 33 | 
            +
                        }
         | 
| 34 | 
            +
                      }
         | 
| 35 | 
            +
                    }
         | 
| 36 | 
            +
                  }
         | 
| 37 | 
            +
             | 
| 38 | 
            +
                  // Target sticky left columns
         | 
| 39 | 
            +
                  &.sticky-left-column {
         | 
| 40 | 
            +
                    td[style="left"], th[style="left"] {
         | 
| 41 | 
            +
                      border-right: none !important;
         | 
| 42 | 
            +
                      box-shadow: 1px 0 0 0 $border_light !important;
         | 
| 43 | 
            +
                    }
         | 
| 44 | 
            +
                  }
         | 
| 45 | 
            +
             | 
| 46 | 
            +
                  // Target sticky right columns
         | 
| 47 | 
            +
                  &.sticky-right-column {
         | 
| 48 | 
            +
                    td[style="right"], th[style="right"] {
         | 
| 49 | 
            +
                      border-right: none !important;
         | 
| 50 | 
            +
                      box-shadow: 1px 0 0 0 $border_light !important;
         | 
| 51 | 
            +
                    }
         | 
| 52 | 
            +
                  }
         | 
| 53 | 
            +
             | 
| 54 | 
            +
                  // Handle hover states in Firefox
         | 
| 55 | 
            +
                  @media screen and (min-width: $screen-xs-min) {
         | 
| 56 | 
            +
                    tr:hover, .pb_table_tr:hover {
         | 
| 57 | 
            +
                      td:last-child, .pb_table_td:last-child {
         | 
| 58 | 
            +
                        &[style="left"], &[style="right"] {
         | 
| 59 | 
            +
                          border-right: none !important;
         | 
| 60 | 
            +
                          box-shadow: 1px 0 0 0 darken($border_light, 10%) !important;
         | 
| 61 | 
            +
                        }
         | 
| 62 | 
            +
                      }
         | 
| 63 | 
            +
                    }
         | 
| 64 | 
            +
                  }
         | 
| 65 | 
            +
                }
         | 
| 18 66 | 
             
              }
         | 
| 19 67 | 
             
            }
         |