2FAuth/resources/js_vue3/composables/helpers.js
2023-11-21 13:45:49 +01:00

52 lines
1.1 KiB
JavaScript
Vendored

// import { ref } from 'vue'
import { useUserStore } from '@/stores/user'
export function useIdGenerator(fieldType, fieldName) {
let prefix
fieldName = fieldName.toString()
switch (fieldType) {
case 'text':
prefix = 'txt'
break
case 'button':
prefix = 'btn'
break
case 'email':
prefix = 'eml'
break
case 'password':
prefix = 'pwd'
break
case 'radio':
prefix = 'rdo'
break
case 'label':
prefix = 'lbl'
break
default:
prefix = 'txt'
break
}
return {
inputId: prefix + fieldName[0].toUpperCase() + fieldName.toLowerCase().slice(1)
}
}
export function useDisplayablePassword(pwd) {
const user = useUserStore()
if (user.preferences.formatPassword && pwd.length > 0) {
const x = Math.ceil(user.preferences.formatPasswordBy < 1
? pwd.length * user.preferences.formatPasswordBy
: user.preferences.formatPasswordBy)
const chunks = pwd.match(new RegExp(`.{1,${x}}`, 'g'));
if (chunks) {
pwd = chunks.join(' ')
}
}
return user.preferences.showOtpAsDot ? pwd.replace(/[0-9]/g, '●') : pwd
}