refactor: enhance ProtectedRoute and dashboard components for improved access control and user experience
- Updated the ProtectedRoute component to optimize access checking logic, preventing unnecessary re-checks and improving authentication flow. - Enhanced the dashboard page to automatically open the login modal for authentication errors and refined loading states for better user feedback. - Improved UI elements across various components for consistency and visual appeal, including updated tab styles and enhanced alert messages. - Removed redundant footer from the vacation management page to streamline the interface.
This commit is contained in:
@@ -636,7 +636,7 @@ export const getStatusSistema = query({
|
||||
|
||||
/**
|
||||
* Atividade do banco no último minuto (agregada em buckets)
|
||||
* Usa mensagensPorMinuto como proxy de atividade quando disponível.
|
||||
* Usa logsAtividades e systemMetrics para calcular atividade real.
|
||||
*/
|
||||
export const getAtividadeBancoDados = query({
|
||||
args: {},
|
||||
@@ -652,6 +652,14 @@ export const getAtividadeBancoDados = query({
|
||||
const agora = Date.now();
|
||||
const haUmMinuto = agora - 60 * 1000;
|
||||
|
||||
// Buscar atividades reais do sistema
|
||||
const atividadesRecentes = await ctx.db
|
||||
.query('logsAtividades')
|
||||
.withIndex('by_timestamp', (q) => q.gte('timestamp', haUmMinuto))
|
||||
.order('asc')
|
||||
.collect();
|
||||
|
||||
// Buscar métricas também (para mensagens se houver)
|
||||
const metricasRecentes = await ctx.db
|
||||
.query('systemMetrics')
|
||||
.withIndex('by_timestamp', (q) => q.gte('timestamp', haUmMinuto))
|
||||
@@ -666,15 +674,30 @@ export const getAtividadeBancoDados = query({
|
||||
for (let i = 0; i < numBuckets; i++) {
|
||||
const inicio = haUmMinuto + i * bucketSizeMs;
|
||||
const fim = inicio + bucketSizeMs;
|
||||
|
||||
// Contar atividades de criação/inserção (entradas)
|
||||
const atividadesBucket = atividadesRecentes.filter(
|
||||
(a) => a.timestamp >= inicio && a.timestamp < fim
|
||||
);
|
||||
const entradasAtividades = atividadesBucket.filter(
|
||||
a => a.acao === 'criar' || a.acao === 'inserir' || a.acao === 'cadastrar'
|
||||
).length;
|
||||
|
||||
// Contar atividades de exclusão/remoção (saídas)
|
||||
const saidasAtividades = atividadesBucket.filter(
|
||||
a => a.acao === 'excluir' || a.acao === 'remover' || a.acao === 'deletar'
|
||||
).length;
|
||||
|
||||
// Usar mensagensPorMinuto como adicional se disponível
|
||||
const bucketMetricas = metricasRecentes.filter(
|
||||
(m) => m.timestamp >= inicio && m.timestamp < fim
|
||||
);
|
||||
|
||||
// Usar mensagensPorMinuto como proxy de "entradas"; "saídas" como fração
|
||||
const somaMensagens =
|
||||
bucketMetricas.reduce((acc, m) => acc + (m.mensagensPorMinuto ?? 0), 0) || 0;
|
||||
const entradas = Math.max(0, Math.round(somaMensagens));
|
||||
const saidas = Math.max(0, Math.round(entradas * 0.6));
|
||||
|
||||
// Combinar atividades reais com métricas de mensagens
|
||||
const entradas = Math.max(0, Math.round(entradasAtividades + somaMensagens * 0.3));
|
||||
const saidas = Math.max(0, Math.round(saidasAtividades + somaMensagens * 0.2));
|
||||
|
||||
historico.push({ entradas, saidas });
|
||||
}
|
||||
@@ -684,7 +707,7 @@ export const getAtividadeBancoDados = query({
|
||||
});
|
||||
|
||||
/**
|
||||
* Distribuição de operações (estimada a partir das métricas)
|
||||
* Distribuição de operações (calculada a partir de logsAtividades e métricas)
|
||||
*/
|
||||
export const getDistribuicaoRequisicoes = query({
|
||||
args: {},
|
||||
@@ -696,21 +719,43 @@ export const getDistribuicaoRequisicoes = query({
|
||||
}),
|
||||
handler: async (ctx) => {
|
||||
const umaHoraAtras = Date.now() - 60 * 60 * 1000;
|
||||
|
||||
// Buscar atividades reais do sistema
|
||||
const atividades = await ctx.db
|
||||
.query('logsAtividades')
|
||||
.withIndex('by_timestamp', (q) => q.gte('timestamp', umaHoraAtras))
|
||||
.collect();
|
||||
|
||||
// Buscar métricas também
|
||||
const metricas = await ctx.db
|
||||
.query('systemMetrics')
|
||||
.withIndex('by_timestamp', (q) => q.gte('timestamp', umaHoraAtras))
|
||||
.order('desc')
|
||||
.take(100);
|
||||
|
||||
const totalOps = Math.max(
|
||||
// Contar operações de leitura (consultas, visualizações)
|
||||
const leituras = atividades.filter(
|
||||
a => a.acao === 'consultar' || a.acao === 'visualizar' || a.acao === 'listar' || a.acao === 'buscar'
|
||||
).length;
|
||||
|
||||
// Contar operações de escrita (criar, editar, excluir)
|
||||
const escritas = atividades.filter(
|
||||
a => a.acao === 'criar' || a.acao === 'editar' || a.acao === 'excluir' ||
|
||||
a.acao === 'inserir' || a.acao === 'atualizar' || a.acao === 'deletar' ||
|
||||
a.acao === 'cadastrar' || a.acao === 'remover'
|
||||
).length;
|
||||
|
||||
// Adicionar estimativa baseada em mensagens se disponível
|
||||
const totalMensagens = Math.max(
|
||||
0,
|
||||
Math.round(metricas.reduce((acc, m) => acc + (m.mensagensPorMinuto ?? 0), 0))
|
||||
);
|
||||
|
||||
const queries = Math.round(totalOps * 0.7);
|
||||
const mutations = Math.max(0, totalOps - queries);
|
||||
const leituras = queries;
|
||||
const escritas = mutations;
|
||||
// Queries são leituras + parte das mensagens (como consultas de chat)
|
||||
const queries = leituras + Math.round(totalMensagens * 0.5);
|
||||
|
||||
// Mutations são escritas + parte das mensagens (como envio de mensagens)
|
||||
const mutations = escritas + Math.round(totalMensagens * 0.3);
|
||||
|
||||
return { queries, mutations, leituras, escritas };
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user