????

Your IP : 216.73.216.79


Current Path : /home/arabianr/www/wp-content/plugins/complianz-gdpr/settings/src/Settings/Inputs/
Upload File :
Current File : /home/arabianr/www/wp-content/plugins/complianz-gdpr/settings/src/Settings/Inputs/PasswordInput.js

import {memo, useEffect, useState} from 'react';
import Icon from "../../utils/Icon";
const PasswordInput = ({
					   value,
					   onChange,
					   required,
					   disabled,
					   id,
					   name,
					   placeholder
				   }) => {
	const inputId = id || name;
	const [inputValue, setInputValue] = useState('');
	const [inputType, setInputType] = useState('password');
	const [icon, setIcon] = useState('eye');

	//ensure that the initial value is set
	useEffect(() => {
		setInputValue(value || '');
	},[value]);

	//because an update on the entire Fields array is costly, we only update after the user has stopped typing
	useEffect(() => {
		if (value=== inputValue) {
			return;
		}
		// skip first render
		const typingTimer = setTimeout(() => {
			onChange(inputValue);
		}, 400);

		return () => {
			clearTimeout(typingTimer);
		};
	}, [inputValue]);

	const handleChange = ( value ) => {
		setInputValue(value);
	};

	const toggleVisible = (e) => {
		console.log("togle", e);
		if (inputType === 'password') {
			setInputType('text');
			setIcon('eye-slash');
		} else {
			setInputType('password');
			setIcon('eye');
		}
	}

	return (
		<div className="cmplz-input-group cmplz-password-input-group">
			<input
				type={inputType}
				id={inputId}
				name={name}
				value={inputValue}
				onChange={(event) => handleChange(event.target.value)}
				required={required}
				disabled={disabled}
				className="cmplz-text-input-group__input"
				placeholder={placeholder}
			/>
			<div onClick={(e) => toggleVisible(e)}><Icon name={icon} color={'grey'} size={16} /></div>
		</div>
	);
};

export default memo(PasswordInput);