Correção de erro 500 em mensagens (UUID), criação de tabela messages e tratamento defensivo no front-end para evitar crashes
This commit is contained in:
@@ -72,7 +72,7 @@ export const TeamPresence: React.FC = () => {
|
||||
|
||||
// Create a map of pending messages by recipient ID
|
||||
const pendingMessagesByRecipient = new Map(
|
||||
pendingMessages.map(msg => [msg.toUser?.email, msg])
|
||||
(pendingMessages || []).map(msg => [msg.toUser?.email, msg])
|
||||
);
|
||||
|
||||
const handleMemberClick = (member: OrganizationMember) => {
|
||||
@@ -102,11 +102,11 @@ export const TeamPresence: React.FC = () => {
|
||||
<div className="px-6 py-3">
|
||||
<div className="mb-2">
|
||||
<span className="text-[10px] font-bold text-text-muted uppercase tracking-[0.2em]">
|
||||
Equipe ({activeUsers.length}/{allMembers.length} online)
|
||||
Equipe ({(activeUsers || []).length}/{(allMembers || []).length} online)
|
||||
</span>
|
||||
</div>
|
||||
<div className="flex flex-wrap gap-2">
|
||||
{allMembers.map((member) => {
|
||||
{(allMembers || []).map((member) => {
|
||||
const isOnline = activeUserLogtoIds.has(member.logto_id);
|
||||
const isCurrentUser = member.logto_id === appUser?.logtoId;
|
||||
const hasPendingMessage = pendingMessagesByRecipient.has(member.email);
|
||||
|
||||
@@ -9,7 +9,7 @@ interface AuthProviderProps {
|
||||
}
|
||||
|
||||
const defaultUser: AppUser = {
|
||||
id: 'guest-user',
|
||||
id: '00000000-0000-0000-0000-000000000000',
|
||||
email: 'guest@gpi.app',
|
||||
name: 'Guest User',
|
||||
role: 'user',
|
||||
@@ -18,7 +18,7 @@ const defaultUser: AppUser = {
|
||||
updatedAt: new Date().toISOString()
|
||||
};
|
||||
|
||||
const DEFAULT_ORGANIZATION_ID = 'default-org';
|
||||
const DEFAULT_ORGANIZATION_ID = '00000000-0000-0000-0000-000000000001';
|
||||
const DEFAULT_ORGANIZATION_NAME = 'Organização Padrão';
|
||||
|
||||
export const AuthProvider: React.FC<AuthProviderProps> = ({ children }) => {
|
||||
|
||||
@@ -83,7 +83,7 @@ export const NotificationProvider: React.FC<{ children: React.ReactNode }> = ({
|
||||
}
|
||||
}, [isSignedIn, fetchNotifications]);
|
||||
|
||||
const unreadCount = notifications.filter(n => !n.isRead).length;
|
||||
const unreadCount = (notifications || []).filter(n => !n.isRead).length;
|
||||
|
||||
return (
|
||||
<NotificationContext.Provider value={{
|
||||
|
||||
Reference in New Issue
Block a user