/*
 * Copyright (C) 2007-2022 Crafter Software Corporation. All Rights Reserved.
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License version 3 as published by
 * the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */

import React from 'react';
import { CSSObject as CSSProperties } from 'tss-react';
type PasswordRequirementsDisplayClassKey =
  | 'listOfConditions'
  | 'conditionItem'
  | 'conditionItemIcon'
  | 'conditionItemNotMet'
  | 'conditionItemMet';
type PasswordRequirementsDisplayStyles = Partial<Record<PasswordRequirementsDisplayClassKey, CSSProperties>>;
export interface PasswordRequirementsDisplayProps {
  value: string;
  formatMessage: Function;
  onValidStateChanged: (isValid: boolean) => void;
  passwordRequirementsRegex: string;
  classes?: Partial<Record<PasswordRequirementsDisplayClassKey, string>>;
  styles?: PasswordRequirementsDisplayStyles;
}
export declare function PasswordRequirementsDisplay(props: PasswordRequirementsDisplayProps): React.JSX.Element;
export default PasswordRequirementsDisplay;
