mirror of
				https://github.com/mealie-recipes/mealie.git
				synced 2025-10-30 01:34:39 -04: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 };
 | |
| };
 |