/* @flow */ import React, { useCallback, useMemo, useState } from "react" import classnames from "classnames" import { buildAriaProps, buildCss, buildDataProps, buildHtmlProps } from "../utilities/props" import { globalProps } from "../utilities/globalProps" import Body from '../pb_body/_body' import Caption from '../pb_caption/_caption' import CircleIconButton from '../pb_circle_icon_button/_circle_icon_button' import Flex from '../pb_flex/_flex' import Icon from '../pb_icon/_icon' import PbReactPopover from '../pb_popover/_popover' import TextInput from '../pb_text_input/_text_input' type PassphraseProps = { aria?: { [key: string]: string }, confirmation?: boolean, className?: string, data?: object, dark?: boolean, htmlOptions?: {[key: string]: string | number | boolean | Function}, id?: string, inputProps?: {}, label?: string, onChange: (inputValue: String) => void, showTipsBelow?: "always" | "xs" | "sm" | "md" | "lg" | "xl", tips?: Array, uncontrolled?: boolean, value: string, } const Passphrase = (props: PassphraseProps) => { const { aria = {}, className, confirmation = false, data = {}, dark = false, htmlOptions = {}, id, inputProps = {}, label = confirmation ? "Confirm Passphrase" : "Passphrase", onChange = () => { }, showTipsBelow = "always", tips = [], uncontrolled = false, value = "", } = props const [uncontrolledValue, setUncontrolledValue] = useState("") const [showPopover, setShowPopover] = useState(false) const [showPassphrase, setShowPassphrase] = useState(false) const handleChange = useCallback( (e) => (uncontrolled ? setUncontrolledValue(e.target.value) : onChange(e)), [uncontrolled, onChange] ) const displayValue = useMemo( () => (uncontrolled ? uncontrolledValue : value), [value, uncontrolledValue, uncontrolled] ) const toggleShowPopover = () => setShowPopover(!showPopover) const handleShouldClosePopover = (shouldClosePopover: boolean) => { setShowPopover(!shouldClosePopover) } const toggleShowPassphrase = (e: React.MouseEvent) => { e.preventDefault() setShowPassphrase(!showPassphrase) } const tipClass = classnames( "passphrase-popover", showTipsBelow === "always" ? null : `show-below-${showTipsBelow}` ) const ariaProps = buildAriaProps(aria) const classes = classnames( buildCss("pb_passphrase"), globalProps(props), className ) const dataProps = buildDataProps(data) const htmlProps = buildHtmlProps(htmlOptions) const popoverReference = ( ) return (
); }; export default Passphrase;