Forget Password e Update Password (1)
This commit is contained in:
BIN
.file.out.txt.kate-swp
Normal file
BIN
.file.out.txt.kate-swp
Normal file
Binary file not shown.
@@ -16,5 +16,5 @@ export class Patterns {
|
|||||||
*
|
*
|
||||||
* 8 to 20 characters string with at least one digit, one upper case letter, one lower case letter and one special symbol
|
* 8 to 20 characters string with at least one digit, one upper case letter, one lower case letter and one special symbol
|
||||||
*/
|
*/
|
||||||
public static Password = /^((?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,30})/i
|
public static Password = /^((?=.*[A-Z])(?=.*\d)(?=.*[@#*=])(?!.* ).{8,30})/i
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -62,33 +62,6 @@ export default defineComponent({
|
|||||||
return '/requestresetpwd'
|
return '/requestresetpwd'
|
||||||
}
|
}
|
||||||
|
|
||||||
function errorMsg(cosa: string, item: any) {
|
|
||||||
/*
|
|
||||||
try {
|
|
||||||
if (!item.$error) {
|
|
||||||
return ''
|
|
||||||
}
|
|
||||||
if (item.$params.email && !item.email) {
|
|
||||||
return t('reg.err.email')
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!item.required) {
|
|
||||||
return t('reg.err.required')
|
|
||||||
}
|
|
||||||
if (!item.minLength) {
|
|
||||||
return t('reg.err.atleast') + ' ${item.$params.minLength.min} ' + t('reg.err.char')
|
|
||||||
}
|
|
||||||
if (!item.maxLength) {
|
|
||||||
return t('reg.err.notmore') + ` ${item.$params.maxLength.max} ` + t('reg.err.char')
|
|
||||||
}
|
|
||||||
return ''
|
|
||||||
} catch (err) {
|
|
||||||
// console.log("ERR : " + error);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
function isError() {
|
function isError() {
|
||||||
if (refUsername.value) {
|
if (refUsername.value) {
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
@@ -172,7 +145,6 @@ export default defineComponent({
|
|||||||
refUsername,
|
refUsername,
|
||||||
onReset,
|
onReset,
|
||||||
onSubmit,
|
onSubmit,
|
||||||
errorMsg,
|
|
||||||
signin,
|
signin,
|
||||||
getlinkforgetpwd,
|
getlinkforgetpwd,
|
||||||
myForm,
|
myForm,
|
||||||
|
|||||||
@@ -87,74 +87,6 @@ export default defineComponent({
|
|||||||
return process.env
|
return process.env
|
||||||
}
|
}
|
||||||
|
|
||||||
function errorMsg(cosa: string, item: any) {
|
|
||||||
try {
|
|
||||||
if (!item.$error) {
|
|
||||||
return ''
|
|
||||||
}
|
|
||||||
console.log('errorMsg', cosa, item)
|
|
||||||
|
|
||||||
if (cosa === 'repeatpassword') {
|
|
||||||
if (!item.sameAsPassword) {
|
|
||||||
return t('reg.err.sameaspassword')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (item.email) {
|
|
||||||
if (item.email.$invalid)
|
|
||||||
return t('reg.err.email')
|
|
||||||
}
|
|
||||||
|
|
||||||
if (item.minLength !== undefined) {
|
|
||||||
if (item.minLength.$invalid) {
|
|
||||||
return t('reg.err.atleast') + ` ${item.minLength.$params.min} ` + t('reg.err.char')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (item.complexity !== undefined) {
|
|
||||||
if (item.complexity.$invalid) {
|
|
||||||
return t('reg.err.complexity')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// if (!item.maxLength) { return t('reg.err.notmore') + ` ${item.$params.maxLength.max} ` + t('reg.err.char') }
|
|
||||||
|
|
||||||
if (item.required !== undefined) {
|
|
||||||
if (item.required.$invalid) {
|
|
||||||
console.log('required')
|
|
||||||
return t('reg.err.required')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
console.log(' cosa', cosa)
|
|
||||||
|
|
||||||
// console.log(' ....avanti')
|
|
||||||
if (cosa === 'email') {
|
|
||||||
// console.log("EMAIL " + item.isUnique);
|
|
||||||
// console.log(item);
|
|
||||||
if (!item.email.$invalid) {
|
|
||||||
return t('reg.err.duplicate_email')
|
|
||||||
}
|
|
||||||
} else if (cosa === 'username') {
|
|
||||||
// console.log(item);
|
|
||||||
console.log('username')
|
|
||||||
console.log(item.$error)
|
|
||||||
if (!item.registereduser.$invalid) {
|
|
||||||
return t('reg.err.duplicate_username')
|
|
||||||
}
|
|
||||||
} else if (cosa === 'aportador_solidario') {
|
|
||||||
// console.log(item);
|
|
||||||
if (!item.aportadorexist) {
|
|
||||||
// console.log('!item.aportadorexist !')
|
|
||||||
return t('reg.err.aportador_not_exist')
|
|
||||||
}
|
|
||||||
} else if ((cosa === 'name') || (cosa === 'surname')) {
|
|
||||||
// console.log(item);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ''
|
|
||||||
} catch (error) {
|
|
||||||
// console.log("ERR : " + error);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function changeemail() {
|
function changeemail() {
|
||||||
signup.email = tools.removespaces(signup.email!)
|
signup.email = tools.removespaces(signup.email!)
|
||||||
@@ -223,7 +155,6 @@ export default defineComponent({
|
|||||||
}
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
errorMsg,
|
|
||||||
changeemail,
|
changeemail,
|
||||||
changeusername,
|
changeusername,
|
||||||
submitOk,
|
submitOk,
|
||||||
|
|||||||
@@ -16,7 +16,7 @@
|
|||||||
@blur="v$.email.$touch"
|
@blur="v$.email.$touch"
|
||||||
@input="changeemail()"
|
@input="changeemail()"
|
||||||
:error="v$.email.$error"
|
:error="v$.email.$error"
|
||||||
:error-message="errorMsg('email', v$.email)"
|
:error-message="tools.errorMsg( 'email', v$.email)"
|
||||||
maxlength="50"
|
maxlength="50"
|
||||||
debounce="3000"
|
debounce="3000"
|
||||||
:label="$t('reg.email')">
|
:label="$t('reg.email')">
|
||||||
@@ -36,7 +36,7 @@
|
|||||||
@keydown.space="(event) => event.preventDefault()"
|
@keydown.space="(event) => event.preventDefault()"
|
||||||
maxlength="20"
|
maxlength="20"
|
||||||
debounce="1000"
|
debounce="1000"
|
||||||
:error-message="errorMsg('username', v$.username)"
|
:error-message="tools.errorMsg( 'username', v$.username)"
|
||||||
:label="$t('reg.username')">
|
:label="$t('reg.username')">
|
||||||
|
|
||||||
<template v-slot:prepend>
|
<template v-slot:prepend>
|
||||||
@@ -52,7 +52,7 @@
|
|||||||
:error="v$.name.$error"
|
:error="v$.name.$error"
|
||||||
maxlength="30"
|
maxlength="30"
|
||||||
debounce="1000"
|
debounce="1000"
|
||||||
:error-message="errorMsg('name', v$.name)"
|
:error-message="tools.errorMsg( 'name', v$.name)"
|
||||||
:label="$t('reg.name')">
|
:label="$t('reg.name')">
|
||||||
|
|
||||||
<template v-slot:prepend>
|
<template v-slot:prepend>
|
||||||
@@ -68,7 +68,7 @@
|
|||||||
@blur="v$.surname.$touch"
|
@blur="v$.surname.$touch"
|
||||||
maxlength="30"
|
maxlength="30"
|
||||||
debounce="1000"
|
debounce="1000"
|
||||||
:error-message="errorMsg('surname', v$.surname)"
|
:error-message="tools.errorMsg( 'surname', v$.surname)"
|
||||||
:label="$t('reg.surname')">
|
:label="$t('reg.surname')">
|
||||||
|
|
||||||
<template v-slot:prepend>
|
<template v-slot:prepend>
|
||||||
@@ -83,7 +83,7 @@
|
|||||||
rounded outlined
|
rounded outlined
|
||||||
@blur="v$.password.$touch"
|
@blur="v$.password.$touch"
|
||||||
:error="v$.password.$error"
|
:error="v$.password.$error"
|
||||||
:error-message="`${errorMsg('password', v$.password)}`"
|
:error-message="`${tools.errorMsg( 'password', v$.password)}`"
|
||||||
maxlength="30"
|
maxlength="30"
|
||||||
debounce="1000"
|
debounce="1000"
|
||||||
:label="$t('reg.password')">
|
:label="$t('reg.password')">
|
||||||
@@ -101,7 +101,7 @@
|
|||||||
rounded outlined
|
rounded outlined
|
||||||
@blur="v$.repeatPassword.$touch"
|
@blur="v$.repeatPassword.$touch"
|
||||||
:error="v$.repeatPassword.$error"
|
:error="v$.repeatPassword.$error"
|
||||||
:error-message="`${errorMsg('repeatpassword', v$.repeatPassword)}`"
|
:error-message="`${tools.errorMsg( 'repeatpassword', v$.repeatPassword)}`"
|
||||||
|
|
||||||
:label="$t('reg.repeatPassword')">
|
:label="$t('reg.repeatPassword')">
|
||||||
|
|
||||||
@@ -152,7 +152,7 @@
|
|||||||
color="secondary"
|
color="secondary"
|
||||||
@blur="v$.terms.$touch"
|
@blur="v$.terms.$touch"
|
||||||
:error="v$.terms.$error"
|
:error="v$.terms.$error"
|
||||||
:error-message="`${errorMsg('terms', v$.terms)}`"
|
:error-message="`${tools.errorMsg( 'terms', v$.terms)}`"
|
||||||
:label="$t('reg.terms')">
|
:label="$t('reg.terms')">
|
||||||
|
|
||||||
</q-checkbox>
|
</q-checkbox>
|
||||||
|
|||||||
@@ -42,6 +42,8 @@ export interface INotify {
|
|||||||
icon?: string | ''
|
icon?: string | ''
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const { t } = useI18n()
|
||||||
|
|
||||||
export const tools = {
|
export const tools = {
|
||||||
CAN_EDIT: 'q-ce',
|
CAN_EDIT: 'q-ce',
|
||||||
TABBED_DASHBOARD: 't-db',
|
TABBED_DASHBOARD: 't-db',
|
||||||
@@ -1443,7 +1445,7 @@ export const tools = {
|
|||||||
|
|
||||||
|
|
||||||
askfornotification($q: any) {
|
askfornotification($q: any) {
|
||||||
const { t } = useI18n()
|
|
||||||
console.log('askfornotification', $q)
|
console.log('askfornotification', $q)
|
||||||
this.showNotif($q, t('notification.waitingconfirm'), { color: 'positive', icon: 'notifications' })
|
this.showNotif($q, t('notification.waitingconfirm'), { color: 'positive', icon: 'notifications' })
|
||||||
|
|
||||||
@@ -1499,7 +1501,7 @@ export const tools = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const globalStore = useGlobalStore()
|
const globalStore = useGlobalStore()
|
||||||
const { t } = useI18n()
|
|
||||||
|
|
||||||
return globalStore.saveTable(mydata)
|
return globalStore.saveTable(mydata)
|
||||||
.then((record) => {
|
.then((record) => {
|
||||||
@@ -1698,7 +1700,7 @@ export const tools = {
|
|||||||
executefunc(mythisq: any, table: string, func: number, par: IParamDialog, mythis?: any) {
|
executefunc(mythisq: any, table: string, func: number, par: IParamDialog, mythis?: any) {
|
||||||
const globalStore = useGlobalStore()
|
const globalStore = useGlobalStore()
|
||||||
const calendarStore = useCalendarStore()
|
const calendarStore = useCalendarStore()
|
||||||
const { t } = useI18n()
|
|
||||||
if (func === lists.MenuAction.DELETE) {
|
if (func === lists.MenuAction.DELETE) {
|
||||||
// console.log('param1', par.param1)
|
// console.log('param1', par.param1)
|
||||||
calendarStore.CancelBookingEvent({
|
calendarStore.CancelBookingEvent({
|
||||||
@@ -1844,7 +1846,7 @@ export const tools = {
|
|||||||
},
|
},
|
||||||
|
|
||||||
async saveFieldToServer(mythisq: any, table: string, id: any, mydata: any, notif = true) {
|
async saveFieldToServer(mythisq: any, table: string, id: any, mydata: any, notif = true) {
|
||||||
const { t } = useI18n()
|
|
||||||
const mydatatosave = {
|
const mydatatosave = {
|
||||||
id,
|
id,
|
||||||
table,
|
table,
|
||||||
@@ -2377,7 +2379,7 @@ export const tools = {
|
|||||||
|
|
||||||
getstrDateEmailTime(mytimestamp: Date | number | string | undefined) {
|
getstrDateEmailTime(mytimestamp: Date | number | string | undefined) {
|
||||||
// console.log('getstrDate', mytimestamp)
|
// console.log('getstrDate', mytimestamp)
|
||||||
const { t } = useI18n()
|
|
||||||
if (mytimestamp) return `${date.formatDate(mytimestamp, 'DD/MM/YYYY')} ${t('cal.starttime')} ${date.formatDate(mytimestamp, 'HH:mm')}`
|
if (mytimestamp) return `${date.formatDate(mytimestamp, 'DD/MM/YYYY')} ${t('cal.starttime')} ${date.formatDate(mytimestamp, 'HH:mm')}`
|
||||||
return ''
|
return ''
|
||||||
},
|
},
|
||||||
@@ -2584,7 +2586,7 @@ export const tools = {
|
|||||||
|
|
||||||
showNotificationExample() {
|
showNotificationExample() {
|
||||||
let options: any = null
|
let options: any = null
|
||||||
const { t } = useI18n()
|
|
||||||
if ('serviceWorker' in navigator) {
|
if ('serviceWorker' in navigator) {
|
||||||
options = {
|
options = {
|
||||||
body: t('notification.subscribed'),
|
body: t('notification.subscribed'),
|
||||||
@@ -2839,7 +2841,7 @@ export const tools = {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
,
|
,
|
||||||
gettextdescr(data: { [index: string]: any }, numdescr = 'description',
|
gettextdescr(data: {[index: string]: any}, numdescr = 'description',
|
||||||
) {
|
) {
|
||||||
if (!!data[numdescr]) {
|
if (!!data[numdescr]) {
|
||||||
if (data[numdescr][toolsext.getLocale()])
|
if (data[numdescr][toolsext.getLocale()])
|
||||||
@@ -2941,7 +2943,7 @@ export const tools = {
|
|||||||
|
|
||||||
},
|
},
|
||||||
getappname(short: boolean) {
|
getappname(short: boolean) {
|
||||||
const { t } = useI18n()
|
|
||||||
if (short) {
|
if (short) {
|
||||||
return t('ws.siteshortname')
|
return t('ws.siteshortname')
|
||||||
}
|
}
|
||||||
@@ -2974,7 +2976,7 @@ export const tools = {
|
|||||||
|
|
||||||
loginInCorso(mythisq: any) {
|
loginInCorso(mythisq: any) {
|
||||||
// console.log('loginInCorso')
|
// console.log('loginInCorso')
|
||||||
const { t } = useI18n()
|
|
||||||
|
|
||||||
const msg = t('login.incorso')
|
const msg = t('login.incorso')
|
||||||
// if (process.env.DEBUG) {
|
// if (process.env.DEBUG) {
|
||||||
@@ -2993,7 +2995,7 @@ export const tools = {
|
|||||||
SignIncheckErrors(mythisq: any, $router: Router, route: any, riscode: any, ispageLogin ?: boolean) {
|
SignIncheckErrors(mythisq: any, $router: Router, route: any, riscode: any, ispageLogin ?: boolean) {
|
||||||
// console.log('SignIncheckErrors: ', riscode)
|
// console.log('SignIncheckErrors: ', riscode)
|
||||||
const $q = useQuasar()
|
const $q = useQuasar()
|
||||||
const { t } = useI18n()
|
|
||||||
const globalStore = useGlobalStore()
|
const globalStore = useGlobalStore()
|
||||||
const userStore = useUserStore()
|
const userStore = useUserStore()
|
||||||
|
|
||||||
@@ -3071,7 +3073,7 @@ export const tools = {
|
|||||||
const endload = true
|
const endload = true
|
||||||
|
|
||||||
const userStore = useUserStore()
|
const userStore = useUserStore()
|
||||||
const { t } = useI18n()
|
|
||||||
|
|
||||||
if (riscode === serv_constants.RIS_CODE_EMAIL_ALREADY_EXIST) {
|
if (riscode === serv_constants.RIS_CODE_EMAIL_ALREADY_EXIST) {
|
||||||
this.showNotif(mythisq, t('reg.err.duplicate_email'))
|
this.showNotif(mythisq, t('reg.err.duplicate_email'))
|
||||||
@@ -3144,7 +3146,7 @@ export const tools = {
|
|||||||
},
|
},
|
||||||
CancelEvent(mythisq: any, eventparam: IEvents) {
|
CancelEvent(mythisq: any, eventparam: IEvents) {
|
||||||
console.log('CancelEvent ', eventparam)
|
console.log('CancelEvent ', eventparam)
|
||||||
this.askConfirm(mythisq, translate('cal.event'), translate('cal.cancelevent') + ' ' + this.gettextevent(eventparam) + '?', translate('dialog.yes'), translate('dialog.no'), '', lists.MenuAction.DELETE_EVENT, 0, {
|
this.askConfirm(mythisq, translate('cal.event'), translate('cal.cancelevent') + ' ' + this.gettextevent(eventparam) + '?', translate('dialog.yes'), translate('dialog.no'), '', lists.MenuAction.DELETE_EVENT, 0, {
|
||||||
param1: eventparam,
|
param1: eventparam,
|
||||||
param2: true,
|
param2: true,
|
||||||
})
|
})
|
||||||
@@ -3152,7 +3154,7 @@ export const tools = {
|
|||||||
AskGiaPartecipatoZoom(mythis: any, user: any) {
|
AskGiaPartecipatoZoom(mythis: any, user: any) {
|
||||||
console.log('AskGiaPartecipatoZoom', user.username)
|
console.log('AskGiaPartecipatoZoom', user.username)
|
||||||
const $q = useQuasar()
|
const $q = useQuasar()
|
||||||
this.askConfirm($q, translate('steps.zoom_gia_partecipato'), translate('steps.zoom_gia_partecipato'), translate('dialog.yes'), translate('dialog.no'), '', lists.MenuAction.ZOOM_GIA_PARTECIPATO, 0, {
|
this.askConfirm($q, translate('steps.zoom_gia_partecipato'), translate('steps.zoom_gia_partecipato'), translate('dialog.yes'), translate('dialog.no'), '', lists.MenuAction.ZOOM_GIA_PARTECIPATO, 0, {
|
||||||
param1: user,
|
param1: user,
|
||||||
param2: user,
|
param2: user,
|
||||||
param3: 'Confermato',
|
param3: 'Confermato',
|
||||||
@@ -3309,7 +3311,7 @@ export const tools = {
|
|||||||
if (numbercell) {
|
if (numbercell) {
|
||||||
if (numbercell.substring(0, 1) !== '+') mynum = intcode + mynum
|
if (numbercell.substring(0, 1) !== '+') mynum = intcode + mynum
|
||||||
else mynum = mynum.substring(1)
|
else mynum = mynum.substring(1)
|
||||||
} else {
|
} else {
|
||||||
return ''
|
return ''
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -3561,7 +3563,7 @@ export const tools = {
|
|||||||
|
|
||||||
copyStringToClipboard(mystr: string, show: boolean) {
|
copyStringToClipboard(mystr: string, show: boolean) {
|
||||||
const $q = useQuasar()
|
const $q = useQuasar()
|
||||||
const { t } = useI18n()
|
|
||||||
copyToClipboard(mystr).then(() => {
|
copyToClipboard(mystr).then(() => {
|
||||||
let msg = t('dialog.copyclipboard')
|
let msg = t('dialog.copyclipboard')
|
||||||
if (show)
|
if (show)
|
||||||
@@ -4251,6 +4253,71 @@ export const tools = {
|
|||||||
return false
|
return false
|
||||||
},
|
},
|
||||||
|
|
||||||
|
errorMsg(cosa: string, item: any) {
|
||||||
|
try {
|
||||||
|
if (!item.$error) {
|
||||||
|
return ''
|
||||||
|
}
|
||||||
|
console.log('errorMsg', cosa, item)
|
||||||
|
|
||||||
|
if (cosa === 'repeatpassword') {
|
||||||
|
if (item.sameAsPassword) {
|
||||||
|
if (item.sameAsPassword.$invalid) {
|
||||||
|
return t('reg.err.sameaspassword')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (item.email) {
|
||||||
|
if (item.email.$invalid)
|
||||||
|
return t('reg.err.email')
|
||||||
|
}
|
||||||
|
|
||||||
|
if (item.minLength !== undefined) {
|
||||||
|
if (item.minLength.$invalid) {
|
||||||
|
return t('reg.err.atleast') + ` ${item.minLength.$params.min} ` + t('reg.err.char')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (item.complexity !== undefined) {
|
||||||
|
if (item.complexity.$invalid) {
|
||||||
|
return t('reg.err.complexity')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// if (!item.maxLength) { return t('reg.err.notmore') + ` ${item.$params.maxLength.max} ` + t('reg.err.char') }
|
||||||
|
|
||||||
|
if (item.required !== undefined) {
|
||||||
|
if (item.required.$invalid) {
|
||||||
|
return t('reg.err.required')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// console.log(' ....avanti')
|
||||||
|
if (cosa === 'email') {
|
||||||
|
// console.log("EMAIL " + item.isUnique);
|
||||||
|
// console.log(item);
|
||||||
|
if (item.registeredemail.$invalid) {
|
||||||
|
return t('reg.err.duplicate_email')
|
||||||
|
}
|
||||||
|
} else if (cosa === 'username') {
|
||||||
|
if (item.registereduser.$invalid) {
|
||||||
|
return t('reg.err.duplicate_username')
|
||||||
|
}
|
||||||
|
} else if (cosa === 'aportador_solidario') {
|
||||||
|
// console.log(item);
|
||||||
|
if (item.aportadorexist.$invalid) {
|
||||||
|
// console.log('!item.aportadorexist !')
|
||||||
|
return t('reg.err.aportador_not_exist')
|
||||||
|
}
|
||||||
|
} else if ((cosa === 'name') || (cosa === 'surname')) {
|
||||||
|
// console.log(item);
|
||||||
|
}
|
||||||
|
|
||||||
|
return ''
|
||||||
|
} catch (error) {
|
||||||
|
// console.log("ERR : " + error);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
// getLocale() {
|
// getLocale() {
|
||||||
// if (navigator.languages && navigator.languages.length > 0) {
|
// if (navigator.languages && navigator.languages.length > 0) {
|
||||||
// return navigator.languages[0]
|
// return navigator.languages[0]
|
||||||
|
|||||||
@@ -4,10 +4,8 @@ import { email, minLength, required, sameAs } from '@vuelidate/validators'
|
|||||||
import { complexity, registeredemail, registereduser, aportadorexist } from '../../validation'
|
import { complexity, registeredemail, registereduser, aportadorexist } from '../../validation'
|
||||||
|
|
||||||
export const validations = {
|
export const validations = {
|
||||||
form: {
|
email: {
|
||||||
email: {
|
email,
|
||||||
email,
|
required
|
||||||
required
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,34 +4,17 @@ import { tools } from '@store/Modules/tools'
|
|||||||
import { Logo } from '../../components/logo'
|
import { Logo } from '../../components/logo'
|
||||||
import { CTitleBanner } from '../../components/CTitleBanner'
|
import { CTitleBanner } from '../../components/CTitleBanner'
|
||||||
|
|
||||||
import { defineComponent, ref } from 'vue'
|
import { defineComponent, reactive, ref } from 'vue'
|
||||||
import { useI18n } from '@src/boot/i18n'
|
import { useI18n } from '@src/boot/i18n'
|
||||||
import { useUserStore } from '@store/UserStore'
|
import { useUserStore } from '@store/UserStore'
|
||||||
import { useGlobalStore } from '@store/globalStore'
|
import { useGlobalStore } from '@store/globalStore'
|
||||||
import { useQuasar } from 'quasar'
|
import { useQuasar } from 'quasar'
|
||||||
|
import useVuelidate from '@vuelidate/core'
|
||||||
|
import { validations } from '@src/views/requestresetpwd/request-resetpwd-validate'
|
||||||
|
|
||||||
import useValidate from '@vuelidate/core'
|
|
||||||
|
|
||||||
// https://learnvue.co/2020/01/getting-smart-with-vue-form-validation-vuelidate-tutorial/
|
|
||||||
|
|
||||||
export default defineComponent({
|
export default defineComponent({
|
||||||
name: 'RequestResetPwd',
|
name: 'RequestResetPwd',
|
||||||
props: {
|
|
||||||
mystr: {
|
|
||||||
type: String,
|
|
||||||
required: true,
|
|
||||||
},
|
|
||||||
myval: {
|
|
||||||
type: Number,
|
|
||||||
required: true,
|
|
||||||
default: 0,
|
|
||||||
},
|
|
||||||
mybool: {
|
|
||||||
type: Boolean,
|
|
||||||
required: true,
|
|
||||||
default: false,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
components: { Logo, CTitleBanner },
|
components: { Logo, CTitleBanner },
|
||||||
setup(props, { emit }) {
|
setup(props, { emit }) {
|
||||||
const $q = useQuasar()
|
const $q = useQuasar()
|
||||||
@@ -39,19 +22,23 @@ export default defineComponent({
|
|||||||
const userStore = useUserStore()
|
const userStore = useUserStore()
|
||||||
const globalStore = useGlobalStore()
|
const globalStore = useGlobalStore()
|
||||||
|
|
||||||
const v$ = useValidate()
|
|
||||||
|
|
||||||
const emailsent = ref(false)
|
const emailsent = ref(false)
|
||||||
const form = ref({
|
const form = reactive({
|
||||||
email: '',
|
email: '',
|
||||||
tokenforgot: ''
|
tokenforgot: ''
|
||||||
})
|
})
|
||||||
|
|
||||||
|
// @ts-ignore
|
||||||
|
const v$ = useVuelidate(validations, form)
|
||||||
|
|
||||||
|
const emailRef = ref(null)
|
||||||
|
|
||||||
function emailinviata() {
|
function emailinviata() {
|
||||||
return emailsent.value
|
return emailsent.value
|
||||||
}
|
}
|
||||||
|
|
||||||
function submit() {
|
function submit() {
|
||||||
|
console.log('submit')
|
||||||
// v$.form.touch()
|
// v$.form.touch()
|
||||||
|
|
||||||
/*if (v$.form.$error) {
|
/*if (v$.form.$error) {
|
||||||
@@ -59,12 +46,21 @@ export default defineComponent({
|
|||||||
return
|
return
|
||||||
}*/
|
}*/
|
||||||
|
|
||||||
|
// @ts-ignore
|
||||||
|
emailRef.value!.validate()
|
||||||
|
|
||||||
|
// @ts-ignore
|
||||||
|
if (emailRef.value!.hasError) {
|
||||||
|
// form has error
|
||||||
|
tools.showNotif($q, t('reg.err.errore_generico'))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
$q.loading.show({ message: t('reset.incorso') })
|
$q.loading.show({ message: t('reset.incorso') })
|
||||||
|
|
||||||
form.value.tokenforgot = ''
|
form.tokenforgot = ''
|
||||||
|
|
||||||
console.log(form.value)
|
userStore.requestpwd(form)
|
||||||
userStore.requestpwd(form.value)
|
|
||||||
.then((ris: any) => {
|
.then((ris: any) => {
|
||||||
if (ris.code === serv_constants.RIS_CODE_OK)
|
if (ris.code === serv_constants.RIS_CODE_OK)
|
||||||
emailsent.value = true
|
emailsent.value = true
|
||||||
@@ -78,40 +74,13 @@ export default defineComponent({
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function errorMsg(cosa: string, item: any) {
|
|
||||||
try {
|
|
||||||
if (!item.$error) {
|
|
||||||
return ''
|
|
||||||
}
|
|
||||||
if (item.$params.email && !item.email) {
|
|
||||||
return t('reg.err.email')
|
|
||||||
}
|
|
||||||
|
|
||||||
if (item.required !== undefined) {
|
|
||||||
if (!item.required) {
|
|
||||||
return t('reg.err.required')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (cosa === 'email') {
|
|
||||||
if (!item.isUnique) {
|
|
||||||
return t('reg.err.duplicate_email')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return ''
|
|
||||||
} catch (error) {
|
|
||||||
// console.log("ERR : " + error);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
return {
|
return {
|
||||||
emailinviata,
|
emailinviata,
|
||||||
errorMsg,
|
|
||||||
submit,
|
submit,
|
||||||
form,
|
form,
|
||||||
|
emailRef,
|
||||||
v$,
|
v$,
|
||||||
|
tools,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="row justify-center text-center padding">
|
<form @submit.prevent.stop="submit" class="row justify-center text-center padding">
|
||||||
<div class="q-gutter-sm q-ma-sm" style="max-width: 800px; margin: auto;">
|
<div class="q-gutter-sm q-ma-sm">
|
||||||
|
|
||||||
<div v-if="!emailinviata">
|
<div v-if="!emailinviata()">
|
||||||
<q-banner
|
<q-banner
|
||||||
rounded
|
rounded
|
||||||
class="bg-primary text-white"
|
class="bg-primary text-white"
|
||||||
@@ -12,13 +12,14 @@
|
|||||||
<br>
|
<br>
|
||||||
|
|
||||||
<q-input
|
<q-input
|
||||||
|
ref="emailRef"
|
||||||
v-model="form.email"
|
v-model="form.email"
|
||||||
rounded outlined
|
rounded outlined
|
||||||
autocomplete="email"
|
autocomplete="email"
|
||||||
:error="v$.form.email.$error"
|
|
||||||
:error-message="errorMsg('email', v$.form.email)"
|
|
||||||
maxlength="50"
|
maxlength="50"
|
||||||
debounce="1000"
|
debounce="1000"
|
||||||
|
:error="v$.email.$error"
|
||||||
|
:error-message="tools.errorMsg( 'email', v$.email)"
|
||||||
:label="$t('reg.email')">
|
:label="$t('reg.email')">
|
||||||
|
|
||||||
<template v-slot:prepend>
|
<template v-slot:prepend>
|
||||||
@@ -31,8 +32,7 @@
|
|||||||
|
|
||||||
<div class="center q-ma-sm">
|
<div class="center q-ma-sm">
|
||||||
<q-btn
|
<q-btn
|
||||||
rounded size="lg" color="primary" @click="submit" :disable="v$.$error">
|
rounded size="lg" color="primary" type="submit" :disable="v$.$error || v$.$invalid">{{ $t('reset.send_reset_pwd') }}
|
||||||
{{ $t('reset.send_reset_pwd') }}
|
|
||||||
</q-btn>
|
</q-btn>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@@ -54,7 +54,7 @@
|
|||||||
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</form>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script lang="ts" src="./requestresetpwd.ts">
|
<script lang="ts" src="./requestresetpwd.ts">
|
||||||
|
|||||||
@@ -0,0 +1,6 @@
|
|||||||
|
.mypanel {
|
||||||
|
padding: 10px;
|
||||||
|
margin: 10px;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -15,22 +15,6 @@ import { useRoute, useRouter } from 'vue-router'
|
|||||||
|
|
||||||
export default defineComponent({
|
export default defineComponent({
|
||||||
name: 'Updatepassword',
|
name: 'Updatepassword',
|
||||||
props: {
|
|
||||||
mystr: {
|
|
||||||
type: String,
|
|
||||||
required: true,
|
|
||||||
},
|
|
||||||
myval: {
|
|
||||||
type: Number,
|
|
||||||
required: true,
|
|
||||||
default: 0,
|
|
||||||
},
|
|
||||||
mybool: {
|
|
||||||
type: Boolean,
|
|
||||||
required: true,
|
|
||||||
default: false,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
components: { Logo, CTitleBanner },
|
components: { Logo, CTitleBanner },
|
||||||
setup(props, { emit }) {
|
setup(props, { emit }) {
|
||||||
const $q = useQuasar()
|
const $q = useQuasar()
|
||||||
@@ -52,11 +36,6 @@ export default defineComponent({
|
|||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
const v$ = useVuelidate(validations, form)
|
const v$ = useVuelidate(validations, form)
|
||||||
|
|
||||||
function created() {
|
|
||||||
// load()
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function submit() {
|
function submit() {
|
||||||
v$.value.$touch()
|
v$.value.$touch()
|
||||||
|
|
||||||
@@ -95,62 +74,13 @@ export default defineComponent({
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function errorMsg(cosa: string, item: any) {
|
|
||||||
try {
|
|
||||||
if (!item.$error) {
|
|
||||||
return ''
|
|
||||||
}
|
|
||||||
// console.log('errorMsg', cosa, item)
|
|
||||||
if (item.$params.email && !item.email) {
|
|
||||||
return t('reg.err.email')
|
|
||||||
}
|
|
||||||
|
|
||||||
if (cosa === 'repeatpassword') {
|
|
||||||
if (!item.sameAsPassword) {
|
|
||||||
return t('reg.err.sameaspassword')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// console.log('item', item)
|
|
||||||
|
|
||||||
if (item.minLength !== undefined) {
|
|
||||||
if (!item.minLength) {
|
|
||||||
return t('reg.err.atleast') + ` ${item.$params.minLength.min} ` + t('reg.err.char')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (item.complexity !== undefined) {
|
|
||||||
if (!item.complexity) {
|
|
||||||
return t('reg.err.complexity')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// if (!item.maxLength) { return t('reg.err.notmore') + ` ${item.$params.maxLength.max} ` + t('reg.err.char') }
|
|
||||||
|
|
||||||
if (item.required !== undefined) {
|
|
||||||
if (!item.required) {
|
|
||||||
return t('reg.err.required')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// console.log(' ....avanti')
|
|
||||||
if (cosa === 'email') {
|
|
||||||
// console.log("EMAIL " + item.isUnique);
|
|
||||||
// console.log(item);
|
|
||||||
if (!item.isUnique) {
|
|
||||||
return t('reg.err.duplicate_email')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return ''
|
|
||||||
} catch (error) {
|
|
||||||
// console.log("ERR : " + error);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return {
|
return {
|
||||||
form,
|
form,
|
||||||
emailsent,
|
emailsent,
|
||||||
submit,
|
submit,
|
||||||
errorMsg,
|
tools,
|
||||||
|
v$,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,75 +1,84 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="mypanel">
|
<div class="mypanel">
|
||||||
|
<form @submit.prevent.stop="submit" class="q-col-gutter-lg row justify-center text-center padding q-pa-md">
|
||||||
|
|
||||||
<div v-if="!emailsent">
|
<div v-if="!emailsent">
|
||||||
<q-banner
|
<q-banner
|
||||||
rounded
|
rounded
|
||||||
class="bg-primary text-white"
|
dense
|
||||||
style="text-align: center;">
|
class="bg-primary text-white"
|
||||||
<span class="mybanner">{{ $t('reset.title_update_pwd')}}</span>
|
style="text-align: center;">
|
||||||
</q-banner>
|
<span class="mybanner">{{ $t('reset.title_update_pwd') }}</span>
|
||||||
<br>
|
</q-banner>
|
||||||
|
|
||||||
<div class="column">
|
<div class="q-my-lg"></div>
|
||||||
|
|
||||||
<q-input
|
<div class="column">
|
||||||
v-model="form.password"
|
|
||||||
type="password"
|
|
||||||
rounded outlined
|
|
||||||
@blur="$v.form.password.$touch"
|
|
||||||
:error="$v.form.password.$error"
|
|
||||||
:error-message="`${errorMsg('password', $v.form.password)}`"
|
|
||||||
maxlength="30"
|
|
||||||
:label="$t('reg.password')">
|
|
||||||
|
|
||||||
<template v-slot:prepend>
|
<q-input
|
||||||
<q-icon name="vpn_key"/>
|
v-model="form.password"
|
||||||
</template>
|
type="password"
|
||||||
|
dense
|
||||||
|
rounded outlined
|
||||||
|
@blur="v$.password.$touch"
|
||||||
|
:error="v$.password.$error"
|
||||||
|
:error-message="`${tools.errorMsg('password', v$.password)}`"
|
||||||
|
maxlength="30"
|
||||||
|
:label="$t('reg.password')">
|
||||||
|
|
||||||
</q-input>
|
<template v-slot:prepend>
|
||||||
|
<q-icon name="vpn_key"/>
|
||||||
|
</template>
|
||||||
|
|
||||||
<q-input
|
</q-input>
|
||||||
v-model="form.repeatPassword"
|
|
||||||
type="password"
|
|
||||||
maxlength="30"
|
|
||||||
rounded outlined
|
|
||||||
@blur="$v.form.repeatPassword.$touch"
|
|
||||||
:error="$v.form.repeatPassword.$error"
|
|
||||||
:error-message="`${errorMsg('repeatpassword', $v.form.repeatPassword)}`"
|
|
||||||
|
|
||||||
:label="$t('reg.repeatPassword')">
|
<div class="q-my-sm"></div>
|
||||||
|
|
||||||
<template v-slot:prepend>
|
<q-input
|
||||||
<q-icon name="vpn_key"/>
|
v-model="form.repeatPassword"
|
||||||
</template>
|
type="password"
|
||||||
|
dense
|
||||||
|
maxlength="30"
|
||||||
|
rounded outlined
|
||||||
|
@blur="v$.repeatPassword.$touch"
|
||||||
|
:error="v$.repeatPassword.$error"
|
||||||
|
:error-message="`${tools.errorMsg('repeatpassword', v$.repeatPassword)}`"
|
||||||
|
|
||||||
</q-input>
|
:label="$t('reg.repeatPassword')">
|
||||||
|
|
||||||
|
<template v-slot:prepend>
|
||||||
|
<q-icon name="vpn_key"/>
|
||||||
|
</template>
|
||||||
|
|
||||||
<div align="center">
|
</q-input>
|
||||||
<q-btn rounded size="lg" color="primary" @click="submit" :disable="$v.$error">
|
|
||||||
{{$t('reset.update_password')}}
|
<div class="q-my-sm"></div>
|
||||||
</q-btn>
|
|
||||||
|
<div align="center">
|
||||||
|
<q-btn rounded size="lg" color="primary" type="submit" :disable="v$.$error">
|
||||||
|
{{ $t('reset.update_password') }}
|
||||||
|
</q-btn>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div v-else>
|
||||||
|
<q-banner
|
||||||
|
rounded
|
||||||
|
class="bg-primary text-white"
|
||||||
|
style="text-align: center;">
|
||||||
|
<span class="mybanner">{{ $t('reset.email_sent') }}</span>
|
||||||
|
</q-banner>
|
||||||
|
<br>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
{{ $t('reset.check_email') }}
|
||||||
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
|
||||||
<div v-else>
|
|
||||||
<q-banner
|
|
||||||
rounded
|
|
||||||
class="bg-primary text-white"
|
|
||||||
style="text-align: center;">
|
|
||||||
<span class="mybanner">{{ $t('reset.email_sent')}}</span>
|
|
||||||
</q-banner>
|
|
||||||
<br>
|
|
||||||
|
|
||||||
<div>
|
|
||||||
{{ $t('reset.check_email')}}
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@@ -77,5 +86,5 @@
|
|||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
@import './updatepassword';
|
@import './updatepassword';
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
Reference in New Issue
Block a user