import React from "react" import { render, screen } from "../utilities/test-utils" import { Dropdown, Icon } from 'playbook-ui' const testId = 'dropdown' const options = [ { label: "United States", value: "United States", areaCode: "+1", icon: "πŸ‡ΊπŸ‡Έ", id: "United-states" }, { label: "Canada", value: "Canada", areaCode: "+1", icon: "πŸ‡¨πŸ‡¦", id: "canada" }, { label: "Pakistan", value: "Pakistan", areaCode: "+92", icon: "πŸ‡΅πŸ‡°", id: "pakistan" } ]; const DefaultDropdownKit = () => { return ( {options.map((option) => ( ))} ) } test('generated default kit and classname', () => { render() const kit = screen.getByTestId(testId) expect(kit).toBeInTheDocument() expect(kit).toHaveClass('pb_dropdown') }) test('generated default Trigger and Container when none passed in', () => { render() const kit = screen.getByTestId(testId) const trigger = kit.querySelector('.pb_dropdown_trigger') expect(trigger).toBeInTheDocument() const container = kit.querySelector('.pb_dropdown_container') expect(container).toBeInTheDocument() const defaultTrigger = kit.querySelector('.dropdown_trigger_wrapper_select_only') expect(defaultTrigger).toBeInTheDocument() }) test('generated Options', () => { render() const kit = screen.getByTestId(testId) const option = kit.querySelector('.pb_dropdown_option_list') expect(option).toBeInTheDocument() }) test('generated customDisplay for trigger', () => { render ( } /> {options.map((option) => ( ))} ) const kit = screen.getByTestId(testId) const trigger = kit.querySelector('.pb_dropdown_trigger') const customDisplay = trigger.querySelector('.fa-flag.pb_icon_kit.fa-fw') expect(customDisplay).toBeInTheDocument() }) test('generated placeholder prop', () => { render ( {options.map((option) => ( ))} ) const kit = screen.getByTestId(testId) const trigger = kit.querySelector('.pb_dropdown_trigger') expect(trigger).toHaveTextContent('Select a country') }) test('generated label prop', () => { render ( {options.map((option) => ( ))} ) const kit = screen.getByTestId(testId) const label = kit.querySelector('.pb_caption_kit_md') expect(label).toHaveTextContent('Countries') }) test('generated custom option', () => { render ( {options.map((option) => ( ))} ) const kit = screen.getByTestId(testId) const customOption = kit.querySelector('.pb_icon_kit_emoji') expect(customOption).toBeInTheDocument() }) test('generated custom Trigger', () => { render ( {options.map((option) => ( ))} ) const kit = screen.getByTestId(testId) const trigger = kit.querySelector('.pb_dropdown_trigger') const customTrigger = trigger.querySelector('.fa-elephant.pb_icon_kit.fa-fw') expect(customTrigger).toBeInTheDocument() }) test('selected option on click', () => { render ( {options.map((option) => ( ))} ) const kit = screen.getByTestId(testId) const option = kit.querySelector('.pb_dropdown_option_list') option.click() expect(option).toHaveClass('pb_dropdown_option_selected') }) test('show error message', () => { const errorMessage = 'Please make a valid selection' render ( ) const kit = screen.getByTestId(testId) expect(kit).toHaveTextContent(errorMessage) })