35 lines
1.2 KiB
JavaScript
35 lines
1.2 KiB
JavaScript
/**
|
|
* Password validator for login pages
|
|
*/
|
|
import value from 'assets/scss/_themes-vars.module.scss';
|
|
|
|
// has number
|
|
const hasNumber = (number) => new RegExp(/[0-9]/).test(number);
|
|
|
|
// has mix of small and capitals
|
|
const hasMixed = (number) => new RegExp(/[a-z]/).test(number) && new RegExp(/[A-Z]/).test(number);
|
|
|
|
// has special chars
|
|
const hasSpecial = (number) => new RegExp(/[!#@$%^&*)(+=._-]/).test(number);
|
|
|
|
// set color based on password strength
|
|
export const strengthColor = (count) => {
|
|
if (count < 2) return { label: 'Poor', color: value.errorMain };
|
|
if (count < 3) return { label: 'Weak', color: value.warningDark };
|
|
if (count < 4) return { label: 'Normal', color: value.orangeMain };
|
|
if (count < 5) return { label: 'Good', color: value.successMain };
|
|
if (count < 6) return { label: 'Strong', color: value.successDark };
|
|
return { label: 'Poor', color: value.errorMain };
|
|
};
|
|
|
|
// password strength indicator
|
|
export const strengthIndicator = (number) => {
|
|
let strengths = 0;
|
|
if (number.length > 5) strengths += 1;
|
|
if (number.length > 7) strengths += 1;
|
|
if (hasNumber(number)) strengths += 1;
|
|
if (hasSpecial(number)) strengths += 1;
|
|
if (hasMixed(number)) strengths += 1;
|
|
return strengths;
|
|
};
|