Skip to content

Commit

Permalink
feat(webapp): create generic email field
Browse files Browse the repository at this point in the history
  • Loading branch information
Rotzbua committed Nov 5, 2023
1 parent 327ccf2 commit faaf2ec
Show file tree
Hide file tree
Showing 8 changed files with 154 additions and 94 deletions.
17 changes: 6 additions & 11 deletions www/webapp/src/components/DonateDirectDebitForm.vue
Original file line number Diff line number Diff line change
Expand Up @@ -75,14 +75,10 @@
validate-on-blur
/>

<v-text-field
<generic-email
v-model="email"
label="Email Address (optional)"
:prepend-icon="mdiEmail"
outlined
:rules="email_rules"
:error-messages="email_errors"
validate-on-blur
:errorMessages="email_errors"
:required="false"
/>

<v-btn
Expand All @@ -98,10 +94,10 @@

<script>
import axios from 'axios';
import {email_pattern} from '@/validation';
import {digestError} from '@/utils';
import ErrorAlert from '@/components/ErrorAlert.vue';
import {mdiAccount, mdiBank, mdiCash100, mdiEmail, mdiMessageTextOutline} from "@mdi/js";
import {mdiAccount, mdiBank, mdiCash100, mdiMessageTextOutline} from "@mdi/js";
import GenericEmail from "@/components/Field/GenericEmail.vue";
const HTTP = axios.create({
baseURL: '/api/v1/',
Expand All @@ -112,6 +108,7 @@
export default {
name: 'DonateDirectDebitForm',
components: {
GenericEmail,
ErrorAlert,
},
data: () => ({
Expand All @@ -125,7 +122,6 @@
mdiBank,
mdiCash100,
mdiMessageTextOutline,
mdiEmail,
/* from env */
creditorid: import.meta.env.VITE_APP_DESECSTACK_API_SEPA_CREDITOR_ID,
Expand Down Expand Up @@ -154,7 +150,6 @@
/* email field */
email: '',
email_rules: [v => v === '' || !!email_pattern.test(v || '') || 'This is not an email address.'],
email_errors: [],
/* donation interval (every N months) */
Expand Down
101 changes: 101 additions & 0 deletions www/webapp/src/components/Field/GenericEmail.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
<template>
<v-text-field
v-bind="computedProps"
v-on="$listeners"
/>
</template>

<script>
import {email_pattern} from '@/validation';
import {mdiEmail, mdiEmailLock} from '@mdi/js';
import {VTextField} from 'vuetify/lib/components';
export default {
name: 'GenericEmail',
extends: VTextField,
props: {
value: {
type: String,
required: false,
},
errorMessages: {
type: [String, Array],
default: () => [],
},
label: {
type: String,
required: false,
},
placeholder: {
type: String,
required: false,
},
required: {
type: Boolean,
default: true,
},
standalone: {
type: Boolean,
default: false,
},
readonly: {
type: Boolean,
required: false,
},
autofocus: {
type: Boolean,
required: false,
},
new: {
type: Boolean,
required: false,
},
},
computed: {
computedProps() {
let label = 'Email Address';
if(!this.required) {
label += ' (optional)';
}
if(this.new) {
label = 'New ' + label;
}
if(this.standalone) {
label = '';
}
if(this.label) { // Override if custom is set.
label = this.label;
}
const icon = this.readonly ? mdiEmailLock : mdiEmail;
const ruleDefs = {
required: v => !!v || 'Email is required.',
valid: v => (v !== undefined && !!email_pattern.test(v)) || 'We need an valid email address for account recovery and technical support.',
};
let rules = []
if(this.required) {
rules.push(ruleDefs.required);
}
if(this.new) {
rules.push(ruleDefs.valid);
}
return {
type: 'email',
value: this.value,
'error-messages': this.errorMessages,
label: label,
required: this.required,
disabled: this.readonly,
autofocus: this.autofocus,
placeholder: this.placeholder ?? 'Email Address',
prependIcon: this.standalone ? '' : icon,
prependInnerIcon: this.standalone ? icon : '',
flat: this.standalone,
solo: this.standalone,
outlined: true,
rules: rules,
validateOnInput: true,
}
}
},
};
</script>
28 changes: 8 additions & 20 deletions www/webapp/src/views/ChangeEmail.vue
Original file line number Diff line number Diff line change
Expand Up @@ -35,14 +35,10 @@
</p>
</v-alert>

<v-text-field
v-model="email"
label="Current Email"
prepend-icon="mdi-blank"
outlined
required
:disabled="true"
validate-on-blur
<generic-email
v-model="email"
label="Current Email Address"
:readonly="true"
/>
<v-text-field
v-model="password"
Expand All @@ -59,16 +55,9 @@
ref="password"
tabindex="1"
></v-text-field>
<v-text-field
<generic-email
v-model="new_email"
label="New Email"
prepend-icon="mdi-email"
outlined
required
:rules="[rules.required, rules.email]"
:error-messages="email_errors"
@change="email_errors=[]"
validate-on-blur
:new="true"
tabindex="2"
/>
</v-card-text>
Expand All @@ -91,13 +80,13 @@

<script>
import { HTTP, withWorking ,digestError} from '@/utils';
import {email_pattern} from '@/validation';
import ErrorAlert from "@/components/ErrorAlert.vue";
import GenericEmail from "@/components/Field/GenericEmail.vue";
export default {
name: 'ChangeEmail',
components: {
GenericEmail,
ErrorAlert,
},
data: () => ({
Expand All @@ -108,7 +97,6 @@
email: '',
rules: {
required: v => !!v || 'Required.',
email: v => !!email_pattern.test(v) || 'Not a valid email address.'
},
show: false,
Expand Down
13 changes: 5 additions & 8 deletions www/webapp/src/views/DeleteAccount.vue
Original file line number Diff line number Diff line change
Expand Up @@ -33,14 +33,10 @@
</p>
</v-alert>

<v-text-field
<generic-email
v-model="email"
label="Current Email"
prepend-icon="mdi-blank"
outlined
required
:disabled="true"
validate-on-blur
label="Current Email Address"
:readonly="true"
/>
<v-text-field
v-model="password"
Expand Down Expand Up @@ -78,10 +74,11 @@
<script>
import { HTTP, withWorking, digestError } from '@/utils';
import ErrorAlert from "@/components/ErrorAlert.vue";
import GenericEmail from "@/components/Field/GenericEmail.vue";
export default {
name: 'DeleteAccount',
components: {ErrorAlert},
components: {GenericEmail, ErrorAlert},
data: () => ({
valid: false,
working: false,
Expand Down
18 changes: 7 additions & 11 deletions www/webapp/src/views/HomePage.vue
Original file line number Diff line number Diff line change
Expand Up @@ -31,17 +31,11 @@
<v-radio class="pb-2" label="dynDNS account" value="dynDNS"></v-radio>
</v-radio-group>
</div>
<v-text-field
outlined
solo
flat
v-model="email"
:prepend-inner-icon="mdiEmail"
type="email"
placeholder="Account Email Address"
:rules="email_rules"
validate-on-blur
></v-text-field>
<generic-email
v-model="email"
:standalone="true"
:new="true"
/>
<v-btn
color="primary"
type="submit"
Expand Down Expand Up @@ -224,10 +218,12 @@ import {
mdiRobot, mdiRunFast,
mdiTwoFactorAuthentication
} from "@mdi/js";
import GenericEmail from "@/components/Field/GenericEmail.vue";
export default {
name: 'HomePage',
components: {
GenericEmail
},
methods: {
async signup() {
Expand Down
22 changes: 10 additions & 12 deletions www/webapp/src/views/LoginPage.vue
Original file line number Diff line number Diff line change
Expand Up @@ -27,15 +27,10 @@
</v-toolbar>
<v-card-text>
<error-alert :errors="errors"></error-alert>
<v-text-field
v-model="email"
label="Email"
outlined
required
:rules="email_rules"
:error-messages="email_errors"
tabindex="1"
@change="email_errors=[]"
<generic-email
v-model="email"
:autofocus="true"
tabindex="1"
/>
<v-text-field
v-model="password"
Expand Down Expand Up @@ -89,22 +84,25 @@
import { HTTP, digestError } from '@/utils';
import ErrorAlert from "@/components/ErrorAlert.vue";
import {useUserStore} from "@/store/user";
import GenericEmail from "@/components/Field/GenericEmail.vue";
export default {
name: 'LoginPage',
components: {
GenericEmail,
ErrorAlert,
},
data: () => ({
user: useUserStore(),
valid: false,
working: false,
email: '',
password: '',
terms: false,
useSessionStorage: false,
email_rules: [v => !!v || 'Please enter the email address associated with your account'],
email: '',
email_errors: [],
password: '',
password_rules: [
v => !!v || 'Enter your password to log in',
],
Expand Down
Loading

0 comments on commit faaf2ec

Please sign in to comment.