mirror of
https://github.com/hay-kot/mealie.git
synced 2025-07-12 08:07:14 -07:00
Some checks are pending
CodeQL / Analyze (push) Waiting to run
Docker Nightly Production / Backend Server Tests (push) Waiting to run
Docker Nightly Production / Frontend Tests (push) Waiting to run
Docker Nightly Production / Build Package (push) Waiting to run
Docker Nightly Production / Build Tagged Release (push) Blocked by required conditions
Docker Nightly Production / Notify Discord (push) Blocked by required conditions
Release Drafter / ✏️ Draft release (push) Waiting to run
Co-authored-by: Michael Genson <71845777+michael-genson@users.noreply.github.com> Co-authored-by: Kuchenpirat <24235032+Kuchenpirat@users.noreply.github.com>
58 lines
1.4 KiB
TypeScript
58 lines
1.4 KiB
TypeScript
import { computed } from "vue";
|
|
import type { VueI18n } from "vue-i18n";
|
|
import { scorePassword } from "~/lib/validators";
|
|
|
|
export function usePasswordField() {
|
|
const show = ref(false);
|
|
const { $globals } = useNuxtApp();
|
|
|
|
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.t("user.password-strength-values.weak");
|
|
}
|
|
else if (score.value < 80) {
|
|
return i18n.t("user.password-strength-values.good");
|
|
}
|
|
else if (score.value < 100) {
|
|
return i18n.t("user.password-strength-values.strong");
|
|
}
|
|
else {
|
|
return i18n.t("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 };
|
|
};
|