import React, { useContext } from "react"; import classnames from "classnames"; import { buildAriaProps, buildCss, buildDataProps, buildHtmlProps } from "../../utilities/props"; import { globalProps } from "../../utilities/globalProps"; import { useHandleOnKeyDown } from "../hooks/useHandleOnKeydown"; import DropdownContext from "../context"; import Body from "../../pb_body/_body"; import Icon from "../../pb_icon/_icon"; import Flex from "../../pb_flex/_flex"; import FlexItem from "../../pb_flex/_flex_item"; type DropdownTriggerProps = { aria?: { [key: string]: string }; children?: React.ReactChild[] | React.ReactChild; className?: string; customDisplay?: React.ReactChild[] | React.ReactChild; dark?: boolean; data?: { [key: string]: string }; htmlOptions?: {[key: string]: string | number | boolean | (() => void)}, id?: string; placeholder?: string; }; const DropdownTrigger = (props: DropdownTriggerProps) => { const { aria = {}, children, className, customDisplay, dark = false, data = {}, htmlOptions = {}, id, placeholder, } = props; const { autocomplete, filterItem, handleChange, handleWrapperClick, inputRef, inputWrapperRef, isDropDownClosed, isInputFocused, selected, setIsInputFocused, toggleDropdown, triggerRef, } = useContext(DropdownContext); const handleKeyDown = useHandleOnKeyDown(); const ariaProps = buildAriaProps(aria); const dataProps = buildDataProps(data); const htmlProps = buildHtmlProps(htmlOptions); const classes = classnames( buildCss("pb_dropdown_trigger"), globalProps(props), className ); const triggerWrapperClasses = buildCss( "dropdown_trigger_wrapper", isInputFocused && "focus", !autocomplete && "select_only" ); const customDisplayPlaceholder = selected?.label ? ( {selected.label} ) : autocomplete ? ( "" ) : placeholder ? ( placeholder ) : ( "Select..." ); const defaultDisplayPlaceholder = selected?.label ? selected.label : autocomplete ? "" : placeholder ? placeholder : "Select..."; return (