mirror of
				https://github.com/mealie-recipes/mealie.git
				synced 2025-11-03 10:43:40 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			53 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import { computed, Ref, ref, useContext } from "@nuxtjs/composition-api";
 | 
						|
import VueI18n from "vue-i18n";
 | 
						|
import { scorePassword } from "~/lib/validators";
 | 
						|
 | 
						|
export function usePasswordField() {
 | 
						|
  const show = ref(false);
 | 
						|
  const { $globals } = useContext();
 | 
						|
 | 
						|
  const passwordIcon = computed(() => {
 | 
						|
    return show.value ? $globals.icons.eyeOff : $globals.icons.eye;
 | 
						|
  });
 | 
						|
  const inputType = computed(() => (show.value ? "text" : "password"));
 | 
						|
 | 
						|
  const togglePasswordShow = () => {
 | 
						|
    show.value = !show.value;
 | 
						|
  };
 | 
						|
 | 
						|
  return {
 | 
						|
    inputType,
 | 
						|
    togglePasswordShow,
 | 
						|
    passwordIcon,
 | 
						|
  };
 | 
						|
}
 | 
						|
 | 
						|
export const usePasswordStrength = (password: Ref<string>, i18n: VueI18n) => {
 | 
						|
  const score = computed(() => scorePassword(password.value));
 | 
						|
  const strength = computed(() => {
 | 
						|
    if (score.value < 50) {
 | 
						|
      return i18n.tc("user.password-strength-values.weak");
 | 
						|
    } else if (score.value < 80) {
 | 
						|
      return i18n.tc("user.password-strength-values.good");
 | 
						|
    } else if (score.value < 100) {
 | 
						|
      return i18n.tc("user.password-strength-values.strong");
 | 
						|
    } else {
 | 
						|
      return i18n.tc("user.password-strength-values.very-strong");
 | 
						|
    }
 | 
						|
  });
 | 
						|
 | 
						|
  const color = computed(() => {
 | 
						|
    if (score.value < 50) {
 | 
						|
      return "error";
 | 
						|
    } else if (score.value < 80) {
 | 
						|
      return "warning";
 | 
						|
    } else if (score.value < 100) {
 | 
						|
      return "info";
 | 
						|
    } else {
 | 
						|
      return "success";
 | 
						|
    }
 | 
						|
  });
 | 
						|
 | 
						|
  return { score, strength, color };
 | 
						|
};
 |