47 lines
1.2 KiB
Vue
47 lines
1.2 KiB
Vue
<template>
|
|
<div>
|
|
<button @click="reset" class="ui primary">%i18n:desktop.tags.mk-password-setting.reset%</button>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import Vue from 'vue';
|
|
|
|
export default Vue.extend({
|
|
methods: {
|
|
reset() {
|
|
(this as any).apis.input({
|
|
title: '%i18n:desktop.tags.mk-password-setting.enter-current-password%',
|
|
type: 'password'
|
|
}).then(currentPassword => {
|
|
(this as any).apis.input({
|
|
title: '%i18n:desktop.tags.mk-password-setting.enter-new-password%',
|
|
type: 'password'
|
|
}).then(newPassword => {
|
|
(this as any).apis.input({
|
|
title: '%i18n:desktop.tags.mk-password-setting.enter-new-password-again%',
|
|
type: 'password'
|
|
}).then(newPassword2 => {
|
|
if (newPassword !== newPassword2) {
|
|
(this as any).apis.dialog({
|
|
title: null,
|
|
text: '%i18n:desktop.tags.mk-password-setting.not-match%',
|
|
actions: [{
|
|
text: 'OK'
|
|
}]
|
|
});
|
|
return;
|
|
}
|
|
(this as any).api('i/change_password', {
|
|
current_password: currentPassword,
|
|
new_password: newPassword
|
|
}).then(() => {
|
|
(this as any).apis.notify('%i18n:desktop.tags.mk-password-setting.changed%');
|
|
});
|
|
});
|
|
});
|
|
});
|
|
}
|
|
}
|
|
});
|
|
</script>
|