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)
})