client: replace error UUIDs with error codes

The error UUIDs were removed from the backend and trying to match against the IDs
no longer works. This can produce confusing UI behaviour when displaying errors.

closes FoundKeyGang/FoundKey#363

Changelog: Fixed
This commit is contained in:
Johann150 2023-03-26 10:55:27 +02:00
parent bc51450fea
commit 77602203b2
Signed by untrusted user: Johann150
GPG key ID: 9EE6577A2A06F8F1
6 changed files with 15 additions and 15 deletions

View file

@ -78,7 +78,7 @@ function fetchAccount(token: string): Promise<Account> {
api('i', {}, token) api('i', {}, token)
.then(res => { .then(res => {
if (res.error) { if (res.error) {
if (res.error.id === 'a8c724b3-6e9c-4b46-b1a8-bc3ed6258370') { if (res.error.code === 'SUSPENDED') {
showSuspendedDialog().then(() => { showSuspendedDialog().then(() => {
signout(); signout();
}); });

View file

@ -207,8 +207,8 @@ function deleteFolder() {
defaultStore.set('uploadFolder', null); defaultStore.set('uploadFolder', null);
} }
}).catch(err => { }).catch(err => {
switch (err.id) { switch (err.code) {
case 'b0fc8a17-963c-405d-bfbc-859a487295e1': case 'HAS_CHILD_FILES_OR_FOLDERS':
os.alert({ os.alert({
type: 'error', type: 'error',
title: i18n.ts.unableToDelete, title: i18n.ts.unableToDelete,

View file

@ -258,8 +258,8 @@ function onDrop(ev: DragEvent): any {
folderId: droppedFolder.id, folderId: droppedFolder.id,
parentId: folder?.id ?? null, parentId: folder?.id ?? null,
}).catch(err => { }).catch(err => {
switch (err) { switch (err.code) {
case 'detected-circular-definition': case 'RECURSIVE_FOLDER':
os.alert({ os.alert({
title: i18n.ts.unableToProcess, title: i18n.ts.unableToProcess,
text: i18n.ts.circularReferenceFolder, text: i18n.ts.circularReferenceFolder,
@ -335,8 +335,8 @@ function deleteFolder(folderToDelete: foundkey.entities.DriveFolder) {
// //
move(folderToDelete.parentId); move(folderToDelete.parentId);
}).catch(err => { }).catch(err => {
switch (err.id) { switch (err.code) {
case 'b0fc8a17-963c-405d-bfbc-859a487295e1': case 'HAS_CHILD_FILES_OR_FOLDERS':
os.alert({ os.alert({
type: 'error', type: 'error',
title: i18n.ts.unableToDelete, title: i18n.ts.unableToDelete,

View file

@ -185,8 +185,8 @@ function onSubmit() {
} }
function loginFailed(err) { function loginFailed(err) {
switch (err.id) { switch (err.code) {
case '6cc579cc-885d-43d8-95c2-b8c7fc963280': { case 'NO_SUCH_USER': {
os.alert({ os.alert({
type: 'error', type: 'error',
title: i18n.ts.loginFailed, title: i18n.ts.loginFailed,
@ -194,7 +194,7 @@ function loginFailed(err) {
}); });
break; break;
} }
case '932c904e-9460-45b7-9ce6-7ed33be7eb2c': { case 'ACCESS_DENIED': {
os.alert({ os.alert({
type: 'error', type: 'error',
title: i18n.ts.loginFailed, title: i18n.ts.loginFailed,
@ -202,11 +202,11 @@ function loginFailed(err) {
}); });
break; break;
} }
case 'e03a5f46-d309-4865-9b69-56282d94e1eb': { case 'SUSPENDED': {
showSuspendedDialog(); showSuspendedDialog();
break; break;
} }
case '22d05606-fbcf-421a-a2db-b32610dcfd1b': { case 'RATE_LIMIT_EXCEEDED': {
os.alert({ os.alert({
type: 'error', type: 'error',
title: i18n.ts.loginFailed, title: i18n.ts.loginFailed,

View file

@ -115,7 +115,7 @@ function save() {
const options = getSaveOptions(); const options = getSaveOptions();
const onError = err => { const onError = err => {
if (err.id === '3d81ceae-475f-4600-b2a8-2bc116157532') { if (err.code === 'INVALID_PARAM') {
if (err.info.param === 'name') { if (err.info.param === 'name') {
os.alert({ os.alert({
type: 'error', type: 'error',

View file

@ -104,7 +104,7 @@ export function getNoteMenu(props: {
os.apiWithDialog(pin ? 'i/pin' : 'i/unpin', { os.apiWithDialog(pin ? 'i/pin' : 'i/unpin', {
noteId: appearNote.id, noteId: appearNote.id,
}, undefined, null, res => { }, undefined, null, res => {
if (res.id === '72dab508-c64d-498f-8740-a8eec1ba385a') { if (res.code === 'PIN_LIMIT_EXCEEDED') {
os.alert({ os.alert({
type: 'error', type: 'error',
text: i18n.ts.pinLimitExceeded, text: i18n.ts.pinLimitExceeded,
@ -149,7 +149,7 @@ export function getNoteMenu(props: {
os.api('clips/add-note', { clipId: clip.id, noteId: appearNote.id }), os.api('clips/add-note', { clipId: clip.id, noteId: appearNote.id }),
null, null,
async (err) => { async (err) => {
if (err.id === '734806c4-542c-463a-9311-15c512803965') { if (err.id === 'ALREADY_CLIPPED') {
const confirm = await os.confirm({ const confirm = await os.confirm({
type: 'warning', type: 'warning',
text: i18n.t('confirmToUnclipAlreadyClippedNote', { name: clip.name }), text: i18n.t('confirmToUnclipAlreadyClippedNote', { name: clip.name }),