feat: 凍結された場合のダイアログを実装 (#7811)
* feat: 凍結された場合のダイアログを実装 * Update CHANGELOG.md * Update basic.js * improve error handling * cypressなんもわからん * Update basic.js
This commit is contained in:
@@ -3,6 +3,7 @@ import { reactive } from 'vue';
|
||||
import { apiUrl } from '@client/config';
|
||||
import { waiting } from '@client/os';
|
||||
import { unisonReload, reloadChannel } from '@client/scripts/unison-reload';
|
||||
import { showSuspendedDialog } from './scripts/show-suspended-dialog';
|
||||
|
||||
// TODO: 他のタブと永続化されたstateを同期
|
||||
|
||||
@@ -82,17 +83,20 @@ function fetchAccount(token): Promise<Account> {
|
||||
i: token
|
||||
})
|
||||
})
|
||||
.then(res => res.json())
|
||||
.then(res => {
|
||||
// When failed to authenticate user
|
||||
if (res.status !== 200 && res.status < 500) {
|
||||
return signout();
|
||||
if (res.error) {
|
||||
if (res.error.id === 'a8c724b3-6e9c-4b46-b1a8-bc3ed6258370') {
|
||||
showSuspendedDialog().then(() => {
|
||||
signout();
|
||||
});
|
||||
} else {
|
||||
signout();
|
||||
}
|
||||
} else {
|
||||
res.token = token;
|
||||
done(res);
|
||||
}
|
||||
|
||||
// Parse response
|
||||
res.json().then(i => {
|
||||
i.token = token;
|
||||
done(i);
|
||||
});
|
||||
})
|
||||
.catch(fail);
|
||||
});
|
||||
|
@@ -54,6 +54,7 @@ import { apiUrl, host } from '@client/config';
|
||||
import { byteify, hexify } from '@client/scripts/2fa';
|
||||
import * as os from '@client/os';
|
||||
import { login } from '@client/account';
|
||||
import { showSuspendedDialog } from '../scripts/show-suspended-dialog';
|
||||
|
||||
export default defineComponent({
|
||||
components: {
|
||||
@@ -169,15 +170,7 @@ export default defineComponent({
|
||||
this.signing = false;
|
||||
this.challengeData = res;
|
||||
return this.queryKey();
|
||||
}).catch(() => {
|
||||
os.dialog({
|
||||
type: 'error',
|
||||
text: this.$ts.signinFailed
|
||||
});
|
||||
this.challengeData = null;
|
||||
this.totpLogin = false;
|
||||
this.signing = false;
|
||||
});
|
||||
}).catch(this.loginFailed);
|
||||
} else {
|
||||
this.totpLogin = true;
|
||||
this.signing = false;
|
||||
@@ -190,14 +183,36 @@ export default defineComponent({
|
||||
}).then(res => {
|
||||
this.$emit('login', res);
|
||||
this.onLogin(res);
|
||||
}).catch(() => {
|
||||
}).catch(this.loginFailed);
|
||||
}
|
||||
},
|
||||
|
||||
loginFailed(err) {
|
||||
switch (err.id) {
|
||||
case '6cc579cc-885d-43d8-95c2-b8c7fc963280': {
|
||||
os.dialog({
|
||||
type: 'error',
|
||||
text: this.$ts.loginFailed
|
||||
title: this.$ts.loginFailed,
|
||||
text: this.$ts.noSuchUser
|
||||
});
|
||||
this.signing = false;
|
||||
});
|
||||
break;
|
||||
}
|
||||
case 'e03a5f46-d309-4865-9b69-56282d94e1eb': {
|
||||
showSuspendedDialog();
|
||||
break;
|
||||
}
|
||||
default: {
|
||||
os.dialog({
|
||||
type: 'error',
|
||||
title: this.$ts.loginFailed,
|
||||
text: JSON.stringify(err)
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
this.challengeData = null;
|
||||
this.totpLogin = false;
|
||||
this.signing = false;
|
||||
},
|
||||
|
||||
resetPassword() {
|
||||
|
10
src/client/scripts/show-suspended-dialog.ts
Normal file
10
src/client/scripts/show-suspended-dialog.ts
Normal file
@@ -0,0 +1,10 @@
|
||||
import * as os from '@client/os';
|
||||
import { i18n } from '@client/i18n';
|
||||
|
||||
export function showSuspendedDialog() {
|
||||
return os.dialog({
|
||||
type: 'error',
|
||||
title: i18n.locale.yourAccountSuspendedTitle,
|
||||
text: i18n.locale.yourAccountSuspendedDescription
|
||||
});
|
||||
}
|
Reference in New Issue
Block a user