playbook_ui 14.21.1 → 14.21.2.pre.alpha.PLAY2020sidebarfilterPOC8265
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 +1 -3
- data/app/pb_kits/playbook/pb_checkbox/checkbox.rb +18 -1
- data/app/pb_kits/playbook/pb_checkbox/docs/_checkbox_custom.html.erb +1 -0
- data/app/pb_kits/playbook/pb_checkbox/docs/_checkbox_custom_rails.md +1 -0
- data/app/pb_kits/playbook/pb_checkbox/docs/_checkbox_form.html.erb +22 -0
- data/app/pb_kits/playbook/pb_checkbox/docs/_checkbox_form.md +5 -0
- data/app/pb_kits/playbook/pb_checkbox/docs/_checkbox_options.html.erb +1 -0
- data/app/pb_kits/playbook/pb_checkbox/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_dropdown/_dropdown.tsx +3 -12
- data/app/pb_kits/playbook/pb_dropdown/docs/example.yml +0 -2
- data/app/pb_kits/playbook/pb_dropdown/docs/index.js +1 -2
- data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownOption.tsx +10 -14
- data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownTrigger.tsx +15 -26
- data/app/pb_kits/playbook/pb_filter/Filter/FilterSection.tsx +49 -0
- data/app/pb_kits/playbook/pb_filter/Filter/FilterSidebar.tsx +69 -0
- data/app/pb_kits/playbook/pb_filter/Filter/index.tsx +13 -0
- data/app/pb_kits/playbook/pb_filter/_filter.scss +4 -0
- data/app/pb_kits/playbook/pb_filter/docs/_filter_sidebar.jsx +224 -0
- data/app/pb_kits/playbook/pb_filter/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_filter/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_form/docs/_form_form_with_validate.html.erb +1 -1
- data/app/pb_kits/playbook/pb_section_separator/docs/_description.md +3 -1
- data/dist/chunks/{_typeahead-BlPRej0F.js → _typeahead-CoOpeYom.js} +2 -2
- data/dist/chunks/{_weekday_stacked-LCNJiSQ3.js → _weekday_stacked-BitxTXxk.js} +2 -2
- data/dist/chunks/lazysizes-DHz07jlL.js +1 -0
- data/dist/chunks/lib-D7Va7yqa.js +29 -0
- data/dist/chunks/{pb_form_validation-DyvJ8iPe.js → pb_form_validation-DSkdRDMf.js} +1 -1
- data/dist/chunks/vendor.js +1 -1
- data/dist/playbook-doc.js +1 -1
- data/dist/playbook-rails-react-bindings.js +1 -1
- data/dist/playbook-rails.js +1 -1
- data/dist/playbook.css +1 -1
- data/lib/playbook/version.rb +2 -2
- metadata +13 -9
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_close_on_select.jsx +0 -42
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_close_on_select.md +0 -1
- data/dist/chunks/lazysizes-B7xYodB-.js +0 -1
- data/dist/chunks/lib-D4vXIZF5.js +0 -29
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA256:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: 110027cf4b6fc7f41901f5d8a95eeee3cabd472a0f64d95870e83cac6155d44f
         | 
| 4 | 
            +
              data.tar.gz: 96c09cbb3a87483920bfd554a727e6663767bc3447cc2e363af5adcb09d6a5c7
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 14c26029d6c5254a2f62b2ea222c4cd5d06ffb3e6586d36d506dfaeed57c4f824e41418e9ce5533838e720d94c1257bace7f55a78da5a2d6ee6dd6768d066fdf
         | 
| 7 | 
            +
              data.tar.gz: 0cd5c076dfb211d337b2de733d3b4a94b09c208b00261b74bcd2eeae88c255b59cd6849025ad1f3548be3f1a910244d6b8e6f689dd413b210a8903855b656a90
         | 
| @@ -39,7 +39,7 @@ | |
| 39 39 | 
             
                  }
         | 
| 40 40 |  | 
| 41 41 | 
             
                  -ms-overflow-style: none !important;
         | 
| 42 | 
            -
                  scrollbar-width: thin | 
| 42 | 
            +
                  scrollbar-width: thin;
         | 
| 43 43 | 
             
                  scrollbar-color: #00000033 transparent !important;
         | 
| 44 44 | 
             
              }
         | 
| 45 45 |  | 
| @@ -410,7 +410,6 @@ | |
| 410 410 |  | 
| 411 411 | 
             
              // Make sure all horizontal borders use the default border color
         | 
| 412 412 | 
             
              tr, th, td {
         | 
| 413 | 
            -
                border-top-color: $border_light !important;
         | 
| 414 413 | 
             
                border-bottom-color: $border_light !important;
         | 
| 415 414 | 
             
              }
         | 
| 416 415 |  | 
| @@ -633,7 +632,6 @@ | |
| 633 632 |  | 
| 634 633 | 
             
                // Make sure all horizontal borders use the default border color in dark mode
         | 
| 635 634 | 
             
                tr, th, td {
         | 
| 636 | 
            -
                  border-top-color: $border_dark !important;
         | 
| 637 635 | 
             
                  border-bottom-color: $border_dark !important;
         | 
| 638 636 | 
             
                }
         | 
| 639 637 |  | 
| @@ -18,13 +18,30 @@ module Playbook | |
| 18 18 | 
             
                                  default: false
         | 
| 19 19 | 
             
                  prop :form_spacing, type: Playbook::Props::Boolean,
         | 
| 20 20 | 
             
                                      default: false
         | 
| 21 | 
            +
                  prop :hidden_input, type: Playbook::Props::Boolean,
         | 
| 22 | 
            +
                                      default: false
         | 
| 23 | 
            +
                  prop :hidden_value
         | 
| 21 24 |  | 
| 22 25 | 
             
                  def classname
         | 
| 23 26 | 
             
                    generate_classname("pb_checkbox_kit", checked_class) + error_class
         | 
| 24 27 | 
             
                  end
         | 
| 25 28 |  | 
| 26 29 | 
             
                  def input
         | 
| 27 | 
            -
                     | 
| 30 | 
            +
                    inputs = []
         | 
| 31 | 
            +
                    effective_name = name || input_options[:name]
         | 
| 32 | 
            +
                    effective_value = value || input_options[:value] || "1"
         | 
| 33 | 
            +
                    is_checked = checked || input_options[:checked]
         | 
| 34 | 
            +
             | 
| 35 | 
            +
                    inputs << hidden_field_tag(effective_name, hidden_value || "0") if hidden_input && effective_name.present?
         | 
| 36 | 
            +
             | 
| 37 | 
            +
                    inputs << check_box_tag(
         | 
| 38 | 
            +
                      effective_name,
         | 
| 39 | 
            +
                      effective_value,
         | 
| 40 | 
            +
                      is_checked,
         | 
| 41 | 
            +
                      input_options.merge(disabled: disabled)
         | 
| 42 | 
            +
                    )
         | 
| 43 | 
            +
             | 
| 44 | 
            +
                    safe_join(inputs)
         | 
| 28 45 | 
             
                  end
         | 
| 29 46 |  | 
| 30 47 | 
             
                  def checkbox_label_status
         | 
| @@ -0,0 +1 @@ | |
| 1 | 
            +
            When using a custom checkbox wrapped in the Checkbox kit, hidden inputs are not automatically included and cannot be prop enabled. Manually add a hidden input before the checkbox if necessary to submit a value when the checkbox is unchecked (as is standard in Rails forms).
         | 
| @@ -0,0 +1,22 @@ | |
| 1 | 
            +
             | 
| 2 | 
            +
            <%= pb_form_with(scope: :example, url: "", method: :get) do |form| %>
         | 
| 3 | 
            +
              <%=pb_rails("flex", props: { gap: "sm", orientation: "column"}) do %>
         | 
| 4 | 
            +
                <%= pb_rails("checkbox" , props: {
         | 
| 5 | 
            +
                  text: "1. pb_rails(\"checkbox\") Checkbox from kit",
         | 
| 6 | 
            +
                  value: "checkbox-value",
         | 
| 7 | 
            +
                  name: "checkbox-name",
         | 
| 8 | 
            +
                  hidden_input: true
         | 
| 9 | 
            +
                  }) %>
         | 
| 10 | 
            +
                <%= form.check_box :example_checkbox,
         | 
| 11 | 
            +
                  data: { field1: "value1", field2: "value2" },
         | 
| 12 | 
            +
                  props: { text: "2. form.check_box Checkbox from Form Builder" },
         | 
| 13 | 
            +
                  unchecked_value: "no",
         | 
| 14 | 
            +
                  id: "checkbox-id",
         | 
| 15 | 
            +
                  name: "checkbox-name",
         | 
| 16 | 
            +
                  class: "checkbox-class"
         | 
| 17 | 
            +
                %>
         | 
| 18 | 
            +
                <%= form.actions do |action| %>
         | 
| 19 | 
            +
                  <%= action.button props: { type: "submit", text: "Submit", variant: "primary" } %>
         | 
| 20 | 
            +
                <% end %>   
         | 
| 21 | 
            +
              <% end %>
         | 
| 22 | 
            +
            <% end %>
         | 
| @@ -0,0 +1,5 @@ | |
| 1 | 
            +
            The way to access hidden inputs for form submission depends on which version of the kit being used within the form context.
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            If using the Rails Checkbox version of the kit, set `hidden_input: true`. Inspect Checkbox #1 in the example above to see the hidden input in the DOM. 
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            If using the Form Builder version of the kit (reference the [Form kit page](https://playbook.powerapp.cloud/kits/form) for more on these), the hidden input will appear if the input has a set `unchecked_value`. Inspect Checkbox #2 in the example above (and the two checkbox examples on the Form kit page) to see the hidden input in the DOM. See the [Rails check_box FormHelper docs](https://api.rubyonrails.org/classes/ActionView/Helpers/FormHelper.html#method-i-check_box) for more.
         | 
| @@ -25,7 +25,6 @@ type DropdownProps = { | |
| 25 25 | 
             
                blankSelection?: string;
         | 
| 26 26 | 
             
                children?: React.ReactChild[] | React.ReactChild | React.ReactElement[];
         | 
| 27 27 | 
             
                className?: string;
         | 
| 28 | 
            -
                closeOnSelection?: boolean;
         | 
| 29 28 | 
             
                formPillProps?: GenericObject;
         | 
| 30 29 | 
             
                dark?: boolean;
         | 
| 31 30 | 
             
                data?: { [key: string]: string };
         | 
| @@ -56,7 +55,6 @@ let Dropdown = (props: DropdownProps, ref: any): React.ReactElement | null => { | |
| 56 55 | 
             
                    blankSelection = '',
         | 
| 57 56 | 
             
                    children,
         | 
| 58 57 | 
             
                    className,
         | 
| 59 | 
            -
                    closeOnSelection = true,
         | 
| 60 58 | 
             
                    dark = false,
         | 
| 61 59 | 
             
                    data = {},
         | 
| 62 60 | 
             
                    defaultValue = {},
         | 
| @@ -154,7 +152,7 @@ let Dropdown = (props: DropdownProps, ref: any): React.ReactElement | null => { | |
| 154 152 | 
             
                    if (!multiSelect) return optionsWithBlankSelection;
         | 
| 155 153 | 
             
                    return optionsWithBlankSelection.filter((option: GenericObject) => !selectedArray.some((sel) => sel.label === option.label));
         | 
| 156 154 | 
             
                }, [optionsWithBlankSelection, selectedArray, multiSelect]);
         | 
| 157 | 
            -
             | 
| 155 | 
            +
                
         | 
| 158 156 | 
             
                const filteredOptions = useMemo(() => {
         | 
| 159 157 | 
             
                      return availableOptions.filter((opt: GenericObject) =>
         | 
| 160 158 | 
             
                        String(opt.label).toLowerCase().includes(filterItem.toLowerCase())
         | 
| @@ -194,18 +192,12 @@ let Dropdown = (props: DropdownProps, ref: any): React.ReactElement | null => { | |
| 194 192 | 
             
                                   return next;
         | 
| 195 193 | 
             
                               });
         | 
| 196 194 | 
             
                               setFilterItem("");
         | 
| 197 | 
            -
                                | 
| 198 | 
            -
                               if (closeOnSelection) {
         | 
| 199 | 
            -
                                   setIsDropDownClosed(true);
         | 
| 200 | 
            -
                               }
         | 
| 195 | 
            +
                               setIsDropDownClosed(true);
         | 
| 201 196 | 
             
                           } else {
         | 
| 202 197 | 
             
                               setSelected(clickedItem);
         | 
| 203 198 | 
             
                               setFilterItem("");
         | 
| 199 | 
            +
                               setIsDropDownClosed(true);
         | 
| 204 200 | 
             
                               onSelect && onSelect(clickedItem);
         | 
| 205 | 
            -
                               // Only close dropdown if closeOnSelection is true
         | 
| 206 | 
            -
                               if (closeOnSelection) {
         | 
| 207 | 
            -
                                   setIsDropDownClosed(true);
         | 
| 208 | 
            -
                               }
         | 
| 209 201 | 
             
                        }
         | 
| 210 202 | 
             
                         };
         | 
| 211 203 |  | 
| @@ -260,7 +252,6 @@ let Dropdown = (props: DropdownProps, ref: any): React.ReactElement | null => { | |
| 260 252 | 
             
                        <DropdownContext.Provider
         | 
| 261 253 | 
             
                            value={{
         | 
| 262 254 | 
             
                                autocomplete,
         | 
| 263 | 
            -
                                closeOnSelection,
         | 
| 264 255 | 
             
                                dropdownContainerRef,
         | 
| 265 256 | 
             
                                filteredOptions,
         | 
| 266 257 | 
             
                                filterItem,
         | 
| @@ -19,5 +19,4 @@ export { default as DropdownMultiSelect } from './_dropdown_multi_select.jsx' | |
| 19 19 | 
             
            export { default as DropdownMultiSelectDisplay } from './_dropdown_multi_select_display.jsx'
         | 
| 20 20 | 
             
            export { default as DropdownMultiSelectWithAutocomplete } from './_dropdown_multi_select_with_autocomplete.jsx'
         | 
| 21 21 | 
             
            export { default as DropdownMultiSelectWithDefault } from './_dropdown_multi_select_with_default.jsx'
         | 
| 22 | 
            -
            export { default as DropdownMultiSelectWithCustomOptions } from './_dropdown_multi_select_with_custom_options.jsx'
         | 
| 23 | 
            -
            export { default as DropdownCloseOnSelect } from './_dropdown_close_on_select.jsx'
         | 
| 22 | 
            +
            export { default as DropdownMultiSelectWithCustomOptions } from './_dropdown_multi_select_with_custom_options.jsx'
         | 
| @@ -25,7 +25,7 @@ type DropdownOptionProps = { | |
| 25 25 | 
             
              key?: string | number;
         | 
| 26 26 | 
             
              option?: GenericObject;
         | 
| 27 27 | 
             
              padding?: string;
         | 
| 28 | 
            -
            } | 
| 28 | 
            +
            }  & GlobalProps;
         | 
| 29 29 |  | 
| 30 30 | 
             
            const DropdownOption = (props: DropdownOptionProps) => {
         | 
| 31 31 | 
             
              const {
         | 
| @@ -56,17 +56,16 @@ const DropdownOption = (props: DropdownOptionProps) => { | |
| 56 56 |  | 
| 57 57 | 
             
              // When multiSelect, then if an option is selected, remove from dropdown
         | 
| 58 58 | 
             
              const isSelected = Array.isArray(selected)
         | 
| 59 | 
            -
             | 
| 60 | 
            -
             | 
| 59 | 
            +
               ? selected.some((item) => item.label === option?.label)
         | 
| 60 | 
            +
               : (selected as GenericObject)?.label === option?.label;
         | 
| 61 61 |  | 
| 62 | 
            +
              
         | 
| 62 63 | 
             
              if (!isItemMatchingFilter(option) || (multiSelect && isSelected)) {
         | 
| 63 64 | 
             
                return null;
         | 
| 64 65 | 
             
              }
         | 
| 65 | 
            -
             | 
| 66 66 | 
             
              const isFocused =
         | 
| 67 67 | 
             
                focusedOptionIndex >= 0 &&
         | 
| 68 68 | 
             
                filteredOptions[focusedOptionIndex].label === option?.label;
         | 
| 69 | 
            -
             | 
| 70 69 | 
             
              const focusedClass = isFocused && "focused";
         | 
| 71 70 |  | 
| 72 71 | 
             
              const selectedClass = isSelected ? "selected" : "list";
         | 
| @@ -92,10 +91,7 @@ const DropdownOption = (props: DropdownOptionProps) => { | |
| 92 91 | 
             
                    className={classes}
         | 
| 93 92 | 
             
                    id={id}
         | 
| 94 93 | 
             
                    key={key}
         | 
| 95 | 
            -
                    onClick={( | 
| 96 | 
            -
                        e.stopPropagation();
         | 
| 97 | 
            -
                        handleOptionClick(option);
         | 
| 98 | 
            -
                    }}
         | 
| 94 | 
            +
                    onClick= {() => handleOptionClick(option)}
         | 
| 99 95 | 
             
                >
         | 
| 100 96 | 
             
                  <ListItem
         | 
| 101 97 | 
             
                      cursor="pointer"
         | 
| @@ -104,12 +100,12 @@ const DropdownOption = (props: DropdownOptionProps) => { | |
| 104 100 | 
             
                      key={option?.label}
         | 
| 105 101 | 
             
                      padding="none"
         | 
| 106 102 | 
             
                  >
         | 
| 107 | 
            -
             | 
| 103 | 
            +
                      {children ? 
         | 
| 108 104 | 
             
                      <div className="dropdown_option_wrapper">{children}</div> :
         | 
| 109 | 
            -
             | 
| 110 | 
            -
             | 
| 111 | 
            -
             | 
| 112 | 
            -
             | 
| 105 | 
            +
                          <Body dark={dark} 
         | 
| 106 | 
            +
                              text={option?.label} 
         | 
| 107 | 
            +
                          />
         | 
| 108 | 
            +
                      }
         | 
| 113 109 | 
             
                  </ListItem>
         | 
| 114 110 | 
             
                </div>
         | 
| 115 111 | 
             
              );
         | 
| @@ -44,7 +44,6 @@ const DropdownTrigger = (props: DropdownTriggerProps) => { | |
| 44 44 |  | 
| 45 45 | 
             
              const {
         | 
| 46 46 | 
             
                autocomplete,
         | 
| 47 | 
            -
                closeOnSelection,
         | 
| 48 47 | 
             
                filterItem,
         | 
| 49 48 | 
             
                handleBackspace,
         | 
| 50 49 | 
             
                handleChange,
         | 
| @@ -55,7 +54,6 @@ const DropdownTrigger = (props: DropdownTriggerProps) => { | |
| 55 54 | 
             
                isInputFocused,
         | 
| 56 55 | 
             
                multiSelect,
         | 
| 57 56 | 
             
                selected,
         | 
| 58 | 
            -
                setIsDropDownClosed,
         | 
| 59 57 | 
             
                setIsInputFocused,
         | 
| 60 58 | 
             
                toggleDropdown,
         | 
| 61 59 | 
             
              } = useContext(DropdownContext);
         | 
| @@ -105,26 +103,11 @@ const DropdownTrigger = (props: DropdownTriggerProps) => { | |
| 105 103 | 
             
                ? placeholder
         | 
| 106 104 | 
             
                : "Select...";
         | 
| 107 105 |  | 
| 108 | 
            -
              // Click handler that respects closeOnSelection
         | 
| 109 | 
            -
              const handleInputClick = (e: React.MouseEvent) => {
         | 
| 110 | 
            -
                e.stopPropagation(); // keep the wrapper's handler from firing
         | 
| 111 | 
            -
                if (isDropDownClosed) {
         | 
| 112 | 
            -
                  // Always open if closed
         | 
| 113 | 
            -
                  setIsDropDownClosed(false);
         | 
| 114 | 
            -
                } else if (!closeOnSelection) {
         | 
| 115 | 
            -
                  // Keep open if closeOnSelection is false
         | 
| 116 | 
            -
                  return;
         | 
| 117 | 
            -
                } else {
         | 
| 118 | 
            -
                  // Default behavior - toggle
         | 
| 119 | 
            -
                  toggleDropdown();
         | 
| 120 | 
            -
                }
         | 
| 121 | 
            -
              };
         | 
| 122 | 
            -
             | 
| 123 106 | 
             
              return (
         | 
| 124 | 
            -
                <div {...ariaProps}
         | 
| 125 | 
            -
                    {...dataProps}
         | 
| 107 | 
            +
                <div {...ariaProps} 
         | 
| 108 | 
            +
                    {...dataProps} 
         | 
| 126 109 | 
             
                    {...htmlProps}
         | 
| 127 | 
            -
                    className={classes}
         | 
| 110 | 
            +
                    className={classes} 
         | 
| 128 111 | 
             
                    id={id}
         | 
| 129 112 | 
             
                >
         | 
| 130 113 | 
             
                  {
         | 
| @@ -162,7 +145,7 @@ const DropdownTrigger = (props: DropdownTriggerProps) => { | |
| 162 145 | 
             
                                {customDisplay ? (
         | 
| 163 146 | 
             
                                  <Flex align="center">
         | 
| 164 147 | 
             
                                    {customDisplay}
         | 
| 165 | 
            -
                                    <Body dark={dark}
         | 
| 148 | 
            +
                                    <Body dark={dark} 
         | 
| 166 149 | 
             
                                        paddingLeft={`${joinedLabels ? "xs" : "none"}`}
         | 
| 167 150 | 
             
                                    >
         | 
| 168 151 | 
             
                                      {customDisplayPlaceholder}
         | 
| @@ -181,7 +164,10 @@ const DropdownTrigger = (props: DropdownTriggerProps) => { | |
| 181 164 | 
             
                                      <input
         | 
| 182 165 | 
             
                                          className="dropdown_input"
         | 
| 183 166 | 
             
                                          onChange={handleChange}
         | 
| 184 | 
            -
                                          onClick={ | 
| 167 | 
            +
                                          onClick={(e) => {
         | 
| 168 | 
            +
                                            e.stopPropagation();// keep the wrapper’s handler from firing
         | 
| 169 | 
            +
                                            toggleDropdown();
         | 
| 170 | 
            +
                                          }}
         | 
| 185 171 | 
             
                                          onFocus={() => setIsInputFocused(true)}
         | 
| 186 172 | 
             
                                          onKeyDown={(e) => {
         | 
| 187 173 | 
             
                                             handleKeyDown(e);
         | 
| @@ -200,8 +186,8 @@ const DropdownTrigger = (props: DropdownTriggerProps) => { | |
| 200 186 | 
             
                                    )}
         | 
| 201 187 | 
             
                                    </>
         | 
| 202 188 | 
             
                                  ) : (
         | 
| 203 | 
            -
                                    <Body dark={dark}
         | 
| 204 | 
            -
                                        text={defaultDisplayPlaceholder}
         | 
| 189 | 
            +
                                    <Body dark={dark} 
         | 
| 190 | 
            +
                                        text={defaultDisplayPlaceholder} 
         | 
| 205 191 | 
             
                                    />
         | 
| 206 192 | 
             
                                  )
         | 
| 207 193 | 
             
                                )}
         | 
| @@ -209,7 +195,10 @@ const DropdownTrigger = (props: DropdownTriggerProps) => { | |
| 209 195 | 
             
                                  <input
         | 
| 210 196 | 
             
                                      className="dropdown_input"
         | 
| 211 197 | 
             
                                      onChange={handleChange}
         | 
| 212 | 
            -
                                      onClick={ | 
| 198 | 
            +
                                      onClick={(e) => {
         | 
| 199 | 
            +
                                        e.stopPropagation();// keep the wrapper’s handler from firing
         | 
| 200 | 
            +
                                        toggleDropdown();
         | 
| 201 | 
            +
                                      }}
         | 
| 213 202 | 
             
                                      onFocus={() => setIsInputFocused(true)}
         | 
| 214 203 | 
             
                                      onKeyDown={handleKeyDown}
         | 
| 215 204 | 
             
                                      placeholder={
         | 
| @@ -234,7 +223,7 @@ const DropdownTrigger = (props: DropdownTriggerProps) => { | |
| 234 223 | 
             
                                    onClick: (e: Event) => {e.stopPropagation();handleWrapperClick()}
         | 
| 235 224 | 
             
                                  }}
         | 
| 236 225 | 
             
                                  key={`${isDropDownClosed ? "chevron-down" : "chevron-up"}`}
         | 
| 237 | 
            -
                              >
         | 
| 226 | 
            +
                              > 
         | 
| 238 227 | 
             
                              {
         | 
| 239 228 | 
             
                                selectedArray.length > 0 && (
         | 
| 240 229 | 
             
                                  <div onClick={(e)=>{e.stopPropagation();handleBackspace()}}>
         | 
| @@ -0,0 +1,49 @@ | |
| 1 | 
            +
            import React from 'react'
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            import Collapsible from '../../pb_collapsible/_collapsible'
         | 
| 4 | 
            +
            import Caption from '../../pb_caption/_caption'
         | 
| 5 | 
            +
            import Body from '../../pb_body/_body'
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            type FilterSectionProps = {
         | 
| 8 | 
            +
              children?: React.ReactChild[] | React.ReactChild,
         | 
| 9 | 
            +
              collapsible?: boolean,
         | 
| 10 | 
            +
              collapsed?: boolean,
         | 
| 11 | 
            +
              headerText?: string,
         | 
| 12 | 
            +
            }
         | 
| 13 | 
            +
            const FilterSection = ({ children, collapsible = false, collapsed = true, headerText, }: FilterSectionProps): React.ReactElement => {
         | 
| 14 | 
            +
              if (collapsible) {
         | 
| 15 | 
            +
                return (
         | 
| 16 | 
            +
                  <Collapsible
         | 
| 17 | 
            +
                      collapsed={collapsed}
         | 
| 18 | 
            +
                      padding="none"
         | 
| 19 | 
            +
                  >
         | 
| 20 | 
            +
                    <Collapsible.Main
         | 
| 21 | 
            +
                        paddingX="sm"
         | 
| 22 | 
            +
                        paddingY="xs"
         | 
| 23 | 
            +
                    >
         | 
| 24 | 
            +
                        <Caption>{ headerText }</Caption>
         | 
| 25 | 
            +
                    </Collapsible.Main>
         | 
| 26 | 
            +
                    <Collapsible.Content
         | 
| 27 | 
            +
                        className="filter_section_collapsible"
         | 
| 28 | 
            +
                        paddingX="sm"
         | 
| 29 | 
            +
                    >
         | 
| 30 | 
            +
                      { children }
         | 
| 31 | 
            +
                    </Collapsible.Content>
         | 
| 32 | 
            +
                  </Collapsible>
         | 
| 33 | 
            +
                )
         | 
| 34 | 
            +
              }
         | 
| 35 | 
            +
              
         | 
| 36 | 
            +
              return (
         | 
| 37 | 
            +
                <Body
         | 
| 38 | 
            +
                    paddingTop="xs"
         | 
| 39 | 
            +
                    paddingX="sm"
         | 
| 40 | 
            +
                >
         | 
| 41 | 
            +
                  <>
         | 
| 42 | 
            +
                    {headerText && <Caption marginBottom="sm">{ headerText }</Caption>}
         | 
| 43 | 
            +
                    { children }
         | 
| 44 | 
            +
                  </>
         | 
| 45 | 
            +
                </Body>
         | 
| 46 | 
            +
              )
         | 
| 47 | 
            +
            }
         | 
| 48 | 
            +
             | 
| 49 | 
            +
            export default FilterSection
         | 
| @@ -0,0 +1,69 @@ | |
| 1 | 
            +
            import React from 'react'
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            import { FilterDescription } from './CurrentFilters'
         | 
| 4 | 
            +
            import FilterBackground, { FilterBackgroundProps } from './FilterBackground'
         | 
| 5 | 
            +
            import ResultsCount from './ResultsCount'
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            import Flex from '../../pb_flex/_flex'
         | 
| 8 | 
            +
            import SectionSeparator from '../../pb_section_separator/_section_separator'
         | 
| 9 | 
            +
            import Card from '../../pb_card/_card'
         | 
| 10 | 
            +
            import Caption from '../../pb_caption/_caption'
         | 
| 11 | 
            +
             | 
| 12 | 
            +
            export type FilterSidebarProps = {
         | 
| 13 | 
            +
              children?: React.ReactChild[] | React.ReactChild,
         | 
| 14 | 
            +
              filters?: FilterDescription,
         | 
| 15 | 
            +
              results?: number,
         | 
| 16 | 
            +
            } & FilterBackgroundProps
         | 
| 17 | 
            +
             | 
| 18 | 
            +
            const FilterSidebar = ({
         | 
| 19 | 
            +
              onCollapse,
         | 
| 20 | 
            +
              onSortChange,
         | 
| 21 | 
            +
              sortOptions,
         | 
| 22 | 
            +
              sortValue,
         | 
| 23 | 
            +
              filters,
         | 
| 24 | 
            +
              results,
         | 
| 25 | 
            +
              children,
         | 
| 26 | 
            +
              dark,
         | 
| 27 | 
            +
              isCollapsed,
         | 
| 28 | 
            +
              maxHeight,
         | 
| 29 | 
            +
              minWidth,
         | 
| 30 | 
            +
              placement,
         | 
| 31 | 
            +
              popoverProps,
         | 
| 32 | 
            +
              ...bgProps
         | 
| 33 | 
            +
            }: FilterSidebarProps): React.ReactElement => (
         | 
| 34 | 
            +
              <FilterBackground
         | 
| 35 | 
            +
                  dark={dark}
         | 
| 36 | 
            +
                  {...bgProps}
         | 
| 37 | 
            +
              >
         | 
| 38 | 
            +
                <Card.Body
         | 
| 39 | 
            +
                    paddingX="sm"
         | 
| 40 | 
            +
                    paddingY="xs"
         | 
| 41 | 
            +
                >
         | 
| 42 | 
            +
                  <Flex
         | 
| 43 | 
            +
                      align="center"
         | 
| 44 | 
            +
                      justify="between"
         | 
| 45 | 
            +
                      orientation="row"
         | 
| 46 | 
            +
                  >
         | 
| 47 | 
            +
                    <ResultsCount
         | 
| 48 | 
            +
                        dark={dark}
         | 
| 49 | 
            +
                        results={results}
         | 
| 50 | 
            +
                        title
         | 
| 51 | 
            +
                    />
         | 
| 52 | 
            +
                    <div onClick={onCollapse}>
         | 
| 53 | 
            +
                      <Caption
         | 
| 54 | 
            +
                          color="link"
         | 
| 55 | 
            +
                          cursor="pointer"
         | 
| 56 | 
            +
                          size="xs"
         | 
| 57 | 
            +
                          text={isCollapsed ? "Expand All" : "Collapse All"}
         | 
| 58 | 
            +
                      />
         | 
| 59 | 
            +
                    </div>
         | 
| 60 | 
            +
                  </Flex>
         | 
| 61 | 
            +
                </Card.Body>
         | 
| 62 | 
            +
                <SectionSeparator dark={dark} />
         | 
| 63 | 
            +
                <>
         | 
| 64 | 
            +
                  { children }
         | 
| 65 | 
            +
                </>
         | 
| 66 | 
            +
              </FilterBackground>
         | 
| 67 | 
            +
            )
         | 
| 68 | 
            +
             | 
| 69 | 
            +
            export default FilterSidebar
         | 
| @@ -1,18 +1,29 @@ | |
| 1 1 | 
             
            import React from 'react'
         | 
| 2 2 | 
             
            import FilterSingle, { FilterSingleProps } from './FilterSingle'
         | 
| 3 3 | 
             
            import FilterDouble, { FilterDoubleProps } from './FilterDouble'
         | 
| 4 | 
            +
            import FilterSidebar, { FilterSidebarProps } from './FilterSidebar'
         | 
| 5 | 
            +
            import FilterSection from './FilterSection'
         | 
| 4 6 |  | 
| 5 7 | 
             
            type FilterProps =
         | 
| 6 8 | 
             
              | FilterSingleProps
         | 
| 7 9 | 
             
              | (FilterDoubleProps & {
         | 
| 8 10 | 
             
                  double?: boolean,
         | 
| 9 11 | 
             
                })
         | 
| 12 | 
            +
              | (FilterSidebarProps & {
         | 
| 13 | 
            +
                variant?: null | 'sidebar',
         | 
| 14 | 
            +
              })
         | 
| 10 15 |  | 
| 11 16 | 
             
            const Filter = ({
         | 
| 12 17 | 
             
              double = false,
         | 
| 18 | 
            +
              variant,
         | 
| 13 19 | 
             
              ...templateProps
         | 
| 14 20 | 
             
              }: FilterProps): React.ReactElement => {
         | 
| 15 21 | 
             
              const displayFilter = () => {
         | 
| 22 | 
            +
                if (variant === 'sidebar') {
         | 
| 23 | 
            +
                  return (
         | 
| 24 | 
            +
                    <FilterSidebar {...templateProps} />
         | 
| 25 | 
            +
                  )
         | 
| 26 | 
            +
                }
         | 
| 16 27 | 
             
                if (double === true) {
         | 
| 17 28 | 
             
                  return (
         | 
| 18 29 | 
             
                    <FilterDouble {...templateProps} />
         | 
| @@ -30,4 +41,6 @@ const Filter = ({ | |
| 30 41 | 
             
              )
         | 
| 31 42 | 
             
            }
         | 
| 32 43 |  | 
| 44 | 
            +
            Filter.Section = FilterSection
         | 
| 45 | 
            +
             | 
| 33 46 | 
             
            export default Filter
         |