frontend validation of team members limitation

This commit is contained in:
Čarodej
2021-11-26 16:44:23 +01:00
parent 459087337c
commit 8456aaf01e
6 changed files with 119 additions and 26 deletions
@@ -192,30 +192,23 @@
})
},
addMember() {
let email = this.email.match(/^[^\s@]+@[^\s@]+\.[^\s@]+$/)[0]
if (!email) {
if (this.$isInvalidEmail(this.email)) {
this.$refs.teamFolderForm.setErrors({
'Email': this.$t("You have to type valid email")
});
return
return;
}
// Get team folder limitations
let limit = this.user.data.meta.limitations.max_team_members
if (limit.percentage >= 100 && ! limit.meta.allowed_emails.includes(email)) {
if ( this.$cantInviteMember(this.email, this.invitations) ) {
this.$refs.teamFolderForm.setErrors({
'Email': this.$t("You have to upgrade your account to add this new member.")
});
return
return;
}
this.$refs.teamFolderForm.reset()
this.invitations.push({
this.invitations.unshift({
type: 'invitation',
email: this.email,
permission: 'can-edit',
@@ -250,6 +243,10 @@
this.invitations = []
}, 150)
})
console.log(
);
}
}
</script>
@@ -153,28 +153,23 @@
})
},
addMember() {
let email = this.email.match(/^[^\s@]+@[^\s@]+\.[^\s@]+$/)[0]
if (!email) {
if (this.$isInvalidEmail(this.email)) {
this.$refs.teamFolderForm.setErrors({
'Email': this.$t("You have to type valid email")
});
return;
}
// Get team folder limitations
let limit = this.user.data.meta.limitations.max_team_members
if (limit.percentage >= 100 && ! limit.meta.allowed_emails.includes(email)) {
if ( this.$cantInviteMember(this.email, this.invitations) ) {
this.$refs.teamFolderForm.setErrors({
'Email': this.$t("You have to upgrade your account to add this new member.")
});
return
return;
}
this.$refs.teamFolderForm.reset()
this.invitations.push({
this.invitations.unshift({
type: 'invitation',
email: this.email,
permission: 'can-edit',
+27
View File
@@ -0,0 +1,27 @@
import store from '../store/index'
const ValidatorHelpers = {
install(Vue) {
Vue.prototype.$cantInviteMember = function (email, invitations) {
// Get max team members limitations
let limit = store.getters.user.data.meta.limitations.max_team_members
// Get emails from invitations and currently active members
let newInvitationEmails = invitations.map(item => item['email'])
let allowedMemberEmails = limit.meta.allowed_emails
// Get unique list of member emails
let totalUniqueEmails = [...new Set(newInvitationEmails.concat(Object.values(allowedMemberEmails)))]
// If there is more unique emails than can be in limit, disable ability to add member
return totalUniqueEmails.length >= limit.total && !totalUniqueEmails.includes(email);
}
Vue.prototype.$isInvalidEmail = function (email) {
return email.match(/^[^\s@]+@[^\s@]+\.[^\s@]+$/) === null
}
}
}
export default ValidatorHelpers
+2
View File
@@ -6,6 +6,7 @@ import router from "./router";
import App from "./App.vue";
import store from "./store";
import {events} from "./bus";
import ValidatorHelpers from "./helpers/ValidatorHelpers";
import functionHelpers from "./helpers/functionHelpers";
import itemHelpers from "./helpers/itemHelpers"
import { library } from "@fortawesome/fontawesome-svg-core";
@@ -86,6 +87,7 @@ library.add(
Vue.component("FontAwesomeIcon", FontAwesomeIcon);
Vue.use(VueRouter);
Vue.use(ValidatorHelpers);
Vue.use(functionHelpers);
Vue.use(itemHelpers);
@@ -1,9 +1,9 @@
<template>
<ContentSidebar>
<!--Empty storage warning-->
<ContentGroup v-if="user && config.storageLimit && storage.used > 95">
<!-- <ContentGroup v-if="user && config.storageLimit && storage.used > 95">
<UpgradeSidebarBanner/>
</ContentGroup>
</ContentGroup>-->
<!--Locations-->
<ContentGroup :title="$t('sidebar.locations_title')">