mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-23 01:17:58 +00:00
53 lines
1.3 KiB
TypeScript
53 lines
1.3 KiB
TypeScript
// Copyright 2017-2026 @pezkuwi/react-components authors & contributors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import React from 'react';
|
|
|
|
import Input from './Input.js';
|
|
|
|
interface Props {
|
|
autoFocus?: boolean;
|
|
children?: React.ReactNode;
|
|
className?: string;
|
|
defaultValue?: string;
|
|
isDisabled?: boolean;
|
|
isError?: boolean;
|
|
isFull?: boolean;
|
|
label?: string;
|
|
labelExtra?: React.ReactNode;
|
|
name?: string;
|
|
onChange: (value: string) => void;
|
|
onEnter?: () => void;
|
|
onEscape?: () => void;
|
|
tabIndex?: number;
|
|
value: string;
|
|
withLabel?: boolean;
|
|
}
|
|
|
|
function Password ({ autoFocus, children, className = '', defaultValue, isDisabled, isError, isFull, label, labelExtra, name, onChange, onEnter, onEscape, tabIndex, value, withLabel }: Props): React.ReactElement<Props> {
|
|
return (
|
|
<Input
|
|
autoFocus={autoFocus}
|
|
className={`${className} ui--Password`}
|
|
defaultValue={defaultValue}
|
|
isDisabled={isDisabled}
|
|
isError={isError}
|
|
isFull={isFull}
|
|
label={label}
|
|
labelExtra={labelExtra}
|
|
name={name}
|
|
onChange={onChange}
|
|
onEnter={onEnter}
|
|
onEscape={onEscape}
|
|
tabIndex={tabIndex}
|
|
type='password'
|
|
value={value}
|
|
withLabel={withLabel}
|
|
>
|
|
{children}
|
|
</Input>
|
|
);
|
|
}
|
|
|
|
export default React.memo(Password);
|