Extract Reset Password Dialog into separate component

This commit is contained in:
Angelina Filippova 2020-05-20 22:40:25 +03:00
parent 4b701ced5f
commit 1d2ecc5255
3 changed files with 68 additions and 45 deletions

View file

@ -0,0 +1,58 @@
<template>
<el-dialog
v-loading="loading"
:visible="dialogOpen"
:title="$t('users.passwordResetTokenCreated')"
custom-class="password-reset-token-dialog"
@close="closeResetPasswordDialog">
<div>
<p class="password-reset-token">Password reset token was generated: {{ passwordResetToken }}</p>
<p>You can also use this link to reset password:
<a :href="passwordResetLink" target="_blank" class="reset-password-link">{{ passwordResetLink }}</a>
</p>
</div>
</el-dialog>
</template>
<script>
export default {
name: 'ResetPasswordDialog',
props: {
resetPasswordDialogOpen: {
type: Boolean,
default: false
}
},
computed: {
dialogOpen() {
return this.resetPasswordDialogOpen
},
loading() {
return this.$store.state.users.loading
},
passwordResetLink() {
return this.$store.state.users.passwordResetToken.link
},
passwordResetToken() {
return this.$store.state.users.passwordResetToken.token
}
},
methods: {
closeResetPasswordDialog() {
this.$emit('close-reset-token-dialog')
}
}
}
</script>
<style rel='stylesheet/scss' lang='scss'>
.password-reset-token-dialog {
width: 50%
}
@media only screen and (max-width:480px) {
.password-reset-token-dialog {
width: 85%
}
}
</style>

View file

@ -81,19 +81,9 @@
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<el-dialog <reset-password-dialog
v-loading="loading" :reset-password-dialog-open="resetPasswordDialogOpen"
:visible.sync="resetPasswordDialogOpen" @close-reset-token-dialog="closeResetPasswordDialog"/>
:title="$t('users.passwordResetTokenCreated')"
custom-class="password-reset-token-dialog"
@close="closeResetPasswordDialog">
<div>
<p class="password-reset-token">Password reset token was generated: {{ passwordResetToken }}</p>
<p>You can also use this link to reset password:
<a :href="passwordResetLink" target="_blank" class="reset-password-link">{{ passwordResetLink }}</a>
</p>
</div>
</el-dialog>
<div v-if="!loading" class="pagination"> <div v-if="!loading" class="pagination">
<el-pagination <el-pagination
:total="usersCount" :total="usersCount"
@ -115,6 +105,7 @@ import MultipleUsersMenu from './components/MultipleUsersMenu'
import NewAccountDialog from './components/NewAccountDialog' import NewAccountDialog from './components/NewAccountDialog'
import ModerationDropdown from './components/ModerationDropdown' import ModerationDropdown from './components/ModerationDropdown'
import RebootButton from '@/components/RebootButton' import RebootButton from '@/components/RebootButton'
import ResetPasswordDialog from './components/ResetPasswordDialog'
export default { export default {
name: 'Users', name: 'Users',
@ -123,6 +114,7 @@ export default {
ModerationDropdown, ModerationDropdown,
MultipleUsersMenu, MultipleUsersMenu,
RebootButton, RebootButton,
ResetPasswordDialog,
UsersFilter UsersFilter
}, },
data() { data() {
@ -149,12 +141,6 @@ export default {
pageSize() { pageSize() {
return this.$store.state.users.pageSize return this.$store.state.users.pageSize
}, },
passwordResetLink() {
return this.$store.state.users.passwordResetToken.link
},
passwordResetToken() {
return this.$store.state.users.passwordResetToken.token
},
currentPage() { currentPage() {
return this.$store.state.users.currentPage return this.$store.state.users.currentPage
}, },
@ -256,9 +242,6 @@ export default {
.password-reset-token { .password-reset-token {
margin: 0 0 14px 0; margin: 0 0 14px 0;
} }
.password-reset-token-dialog {
width: 50%
}
.reset-password-link { .reset-password-link {
text-decoration: underline; text-decoration: underline;
} }
@ -295,9 +278,6 @@ export default {
} }
@media only screen and (max-width:480px) { @media only screen and (max-width:480px) {
.password-reset-token-dialog {
width: 85%
}
.users-container { .users-container {
h1 { h1 {
margin: 0; margin: 0;

View file

@ -26,19 +26,9 @@
:page="'userPage'" :page="'userPage'"
@open-reset-token-dialog="openResetPasswordDialog"/> @open-reset-token-dialog="openResetPasswordDialog"/>
</div> </div>
<el-dialog <reset-password-dialog
v-loading="loading" :reset-password-dialog-open="resetPasswordDialogOpen"
:visible.sync="resetPasswordDialogOpen" @close-reset-token-dialog="closeResetPasswordDialog"/>
:title="$t('users.passwordResetTokenCreated')"
custom-class="password-reset-token-dialog"
@close="closeResetPasswordDialog">
<div>
<p class="password-reset-token">Password reset token was generated: {{ passwordResetToken }}</p>
<p>You can also use this link to reset password:
<a :href="passwordResetLink" target="_blank" class="reset-password-link">{{ passwordResetLink }}</a>
</p>
</div>
</el-dialog>
<div class="user-profile-container"> <div class="user-profile-container">
<el-card class="user-profile-card"> <el-card class="user-profile-card">
<div class="el-table el-table--fit el-table--enable-row-hover el-table--enable-row-transition el-table--medium"> <div class="el-table el-table--fit el-table--enable-row-hover el-table--enable-row-transition el-table--medium">
@ -121,10 +111,11 @@ import Status from '@/components/Status'
import ModerationDropdown from './components/ModerationDropdown' import ModerationDropdown from './components/ModerationDropdown'
import SecuritySettingsModal from './components/SecuritySettingsModal' import SecuritySettingsModal from './components/SecuritySettingsModal'
import RebootButton from '@/components/RebootButton' import RebootButton from '@/components/RebootButton'
import ResetPasswordDialog from './components/ResetPasswordDialog'
export default { export default {
name: 'UsersShow', name: 'UsersShow',
components: { ModerationDropdown, RebootButton, Status, SecuritySettingsModal }, components: { ModerationDropdown, RebootButton, ResetPasswordDialog, Status, SecuritySettingsModal },
data() { data() {
return { return {
showPrivate: false, showPrivate: false,
@ -145,12 +136,6 @@ export default {
loading() { loading() {
return this.$store.state.users.loading return this.$store.state.users.loading
}, },
passwordResetLink() {
return this.$store.state.users.passwordResetToken.link
},
passwordResetToken() {
return this.$store.state.users.passwordResetToken.token
},
statuses() { statuses() {
return this.$store.state.userProfile.statuses return this.$store.state.userProfile.statuses
}, },