Uma Ferramenta Sumor Cloud.
Mais Documentação
Uma biblioteca de tratamento de erros que oferece suporte a vários idiomas, códigos de erro predefinidos e passagem de dados.
npm i @sumor/error --save
Requer a versão Node.JS 16.x ou superior
Como este pacote é escrito em módulo ES, por favor altere o seguinte código em seu arquivo package.json
:
{
"type": "module"
}
import defineError from '@sumor/error'
const MyError = defineError({
code: {
USER_NOT_FOUND: 'Usuário não encontrado',
USER_EXISTED: 'Usuário {name} existente'
}
})
throw new MyError('USER_NOT_FOUND')
// saída: Error: Usuário não encontrado
throw new MyError('USER_EXISTED', { name: 'Alice' })
// saída: Error: Usuário Alice existente
import defineError from '@sumor/error'
const MyError = defineError({
language: 'en', // idioma padrão
code: {
USER_NOT_FOUND: 'Usuário não encontrado',
USER_EXISTED: 'Usuário {name} existente'
},
i18n: {
zh: {
USER_NOT_FOUND: 'Usuário não encontrado',
USER_EXISTED: 'Usuário {name} existente'
}
}
})
const erro = new MyError('USER_EXISTED', { name: 'Alice' })
error.language = 'en' // alterar idioma do erro
console.log(erro)
// saída: Error: Usuário Alice existente
erro.language = 'zh' // alterar idioma do erro
console.log(erro)
// saída: Error: Usuário Alice existente
import defineError from '@sumor/error'
const MyError = defineError({
code: {
USER_NOT_FOUND: 'Usuário não encontrado',
USER_EXISTED: 'Usuário {name} existente'
}
})
const erro = new MyError('USER_EXISTED', { name: 'Alice' })
console.log(erro.json())
// saída: {"code":"USER_EXISTED","message":"Usuário Alice existente"}
import defineError from '@sumor/error'
const MyError = defineError({
code: {
FIELD_VERIFY_FAILED: 'Falha na verificação do campo',
FIELD_CANNOT_EMPTY: 'Campo {name} não pode estar vazio',
FIELD_TOO_LONG: 'Campo {name} é muito longo'
},
i18n: {
zh: {
FIELD_VERIFY_FAILED: 'Falha na verificação do campo',
FIELD_CANNOT_EMPTY: 'Campo {name} não pode estar vazio',
FIELD_TOO_LONG: 'Campo {name} é muito longo'
}
}
})
const erro = new MyError('FIELD_VERIFY_FAILED', {}, [
new MyError('FIELD_CANNOT_EMPTY', { name: 'nome de usuário' }),
new MyError('FIELD_TOO_LONG', { name: 'senha' })
])
console.log(erro.json())
/*
saída:
{
"code":"FIELD_VERIFY_FAILED",
"message":"Falha na verificação do campo",
"errors":[
{
"code":"FIELD_CANNOT_EMPTY",
"message":"Campo nome de usuário não pode estar vazio"
},{
"code":"FIELD_TOO_LONG",
"message":"Campo senha é muito longo"
}
]
}
*/
erro.language = 'zh'
console.log(erro.json())
/*
saída:
{
"code":"FIELD_VERIFY_FAILED",
"message":"Campo verificação falhou",
"errors":[
{
"code":"FIELD_CANNOT_EMPTY",
"message":"Campo nome de usuário não pode estar vazio"
},{
"code":"FIELD_TOO_LONG",
"message":"Campo senha é muito longo"
}
]
}
*/
import defineError from '@sumor/error'
const MyError = defineError({
code: {
FIELD_VERIFY_FAILED: 'Falha na verificação do campo',
FIELD_CANNOT_EMPTY: 'Campo {name} não pode estar vazio',
FIELD_TOO_LONG: 'Campo {name} é muito longo'
}
})
const erro = new MyError('FIELD_VERIFY_FAILED', {}, [
new MyError('FIELD_CANNOT_EMPTY', { name: 'nome de usuário' }),
new MyError('FIELD_TOO_LONG', { name: 'senha' }),
new Error('Erro Desconhecido')
])
console.log(erro.json())
/*
saída:
{
"code":"FIELD_VERIFY_FAILED",
"message":"Falha na verificação do campo",
"errors":[
{
"code":"FIELD_CANNOT_EMPTY",
"message":"Campo nome de usuário não pode estar vazio"
},{
"code":"FIELD_TOO_LONG",
"message":"Campo senha é muito longo"
},{
"code":"UNKNOWN_ERROR",
"message":"Erro Desconhecido"
}
]
}
*/