Sha256: cac20ffcc400ae751115d241a8774f62820918d1d45a7f0a7a70e4ead186f716

Contents?: true

Size: 1.96 KB

Versions: 520

Compression:

Stored size: 1.96 KB

Contents

import React from "react";
import {
  render,
  screen,
  fireEvent,
} from "../utilities/test-utils";
import { Button, Filter, Flex, Select, TextInput } from "..";

function FilterTest(props) {
  const SortingChangeCallback = (sortOptions) => {
    alert(JSON.stringify(sortOptions[0]));
  };

  const options = [
    { value: "USA" },
    { value: "Canada" },
    { value: "Brazil" },
    { value: "Philippines" },
    { value: "A Galaxy Far Far Away Like Really Far Away" },
  ];
  return (
    <Filter
        onSortChange={SortingChangeCallback}
        results={1}
        sortOptions={{
        popularity: "Popularity",
        // eslint-disable-next-line
        manager_title: "Manager's Title",
        // eslint-disable-next-line
        manager_name: "Manager's Name",
      }}
        sortValue={[{ name: "popularity", dir: "desc" }]}
        {...props}
    >
      <TextInput
          label="Example Text Field"
          placeholder="Enter Text"
          {...props}
      />

      <Select
          blankSelection="Select One..."
          label="Example Collection Select"
          name="Collection Select"
          options={options}
          {...props}
      />
      <Flex spacing="between"
          {...props}>
        <Button text="Apply"
            {...props} />
        <Button text="Clear"
            variant="secondary"
            {...props} />
      </Flex>
    </Filter>
  );
}

test("triggers popover on filter button click", () => {
  render(<FilterTest data={{ testid: "render-test" }}/>);

  const btn = screen.getAllByRole("button")[0];

  // checks if the sort menu rendered
  expect(screen.getByLabelText("sort-amount-down icon")).toBeInTheDocument()
  expect(screen.getByText('Popularity')).toBeInTheDocument() // check if filter/sort is rendered 

  // hits the filter button and triggers popover
  fireEvent.click(btn);

  // check if popover displays correctly by checking its tet
  expect(screen.getByText("Example Text Field")).toBeInTheDocument() 


});

Version data entries

520 entries across 520 versions & 1 rubygems

Version Path
playbook_ui-13.16.0.pre.alpha.PBNTR177NewAdvancedTableKit2023 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.16.0.pre.alpha.PBNTR177NewAdvancedTableKit2010 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.16.0.pre.alpha.PLAY11642006 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.16.0.pre.alpha.play1141iconkitusinglibrary1995 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.16.0.pre.alpha.play1141iconkitusinglibrary1993 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.16.0.pre.alpha.PLAY11641992 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.16.0.pre.alpha.PLAY11641991 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.16.0.pre.alpha.fonttest1972 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.15.0.pre.alpha.play1141iconkitusinglibrary1956 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.16.0 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.15.0.pre.alpha.play10841940 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.15.0.pre.alpha.1132globalpropdatepickerspacing1929 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.15.0.pre.alpha.PLAY10851907 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.15.0.pre.alpha.PLAY11311893 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.15.0.pre.alpha.reactselectbump581876 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.15.0.pre.alpha.PLAY10831873 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.14.0.pre.alpha.play1101betaicons1825 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.14.0.pre.alpha.play1101betaicons1798 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.14.0.pre.alpha.play1120lintdatepicker1797 app/pb_kits/playbook/pb_filter/filter.test.js
playbook_ui-13.15.0 app/pb_kits/playbook/pb_filter/filter.test.js