feat: add Clear All button to CommsTab — purge all messages from DB

Adds trash icon button in Messages header that clears all communications
for the active group: DMs, channel messages, activity feed, seen tracking,
and dead letters. Shows Tauri warning dialog with confirmation before delete.

- Rust: clear_all_communications() in btmsg.rs (4 DELETE queries)
- Tauri command: btmsg_clear_all_comms
- Bridge: clearAllComms(groupId)
- UI: trash button with hover-red styling, resets all local state after clear
This commit is contained in:
DexterFromLab 2026-03-15 17:24:40 +01:00
parent 6504a79bfe
commit 37b2b82ae5
5 changed files with 100 additions and 0 deletions

View file

@ -877,6 +877,35 @@ pub fn clear_dead_letters(group_id: &str) -> Result<(), String> {
Ok(())
}
/// Clear all communications for a group: messages, channel messages, seen tracking, dead letters
pub fn clear_all_communications(group_id: &str) -> Result<(), String> {
let db = open_db()?;
let agent_ids_clause = "(SELECT id FROM agents WHERE group_id = ?1)";
// Order matters: seen_messages references messages, so delete seen first
db.execute(
&format!("DELETE FROM seen_messages WHERE message_id IN (SELECT id FROM messages WHERE group_id = ?1 OR from_agent IN {agent_ids_clause} OR to_agent IN {agent_ids_clause})"),
params![group_id],
).map_err(|e| format!("Clear seen_messages error: {e}"))?;
db.execute(
&format!("DELETE FROM messages WHERE group_id = ?1 OR from_agent IN {agent_ids_clause} OR to_agent IN {agent_ids_clause}"),
params![group_id],
).map_err(|e| format!("Clear messages error: {e}"))?;
db.execute(
&format!("DELETE FROM channel_messages WHERE channel_id IN (SELECT id FROM channels WHERE group_id = ?1) OR from_agent IN {agent_ids_clause}"),
params![group_id],
).map_err(|e| format!("Clear channel_messages error: {e}"))?;
db.execute(
&format!("DELETE FROM dead_letter_queue WHERE from_agent IN {agent_ids_clause} OR to_agent IN {agent_ids_clause}"),
params![group_id],
).map_err(|e| format!("Clear dead_letter_queue error: {e}"))?;
Ok(())
}
// ---- Audit log ----
#[derive(Debug, Serialize, Deserialize)]

View file

@ -124,6 +124,11 @@ pub fn btmsg_clear_dead_letters(group_id: String) -> Result<(), String> {
btmsg::clear_dead_letters(&group_id)
}
#[tauri::command]
pub fn btmsg_clear_all_comms(group_id: String) -> Result<(), String> {
btmsg::clear_all_communications(&group_id)
}
#[tauri::command]
pub fn btmsg_queue_dead_letter(
from_agent: String,

View file

@ -277,6 +277,7 @@ pub fn run() {
commands::btmsg::btmsg_get_agent_heartbeats,
commands::btmsg::btmsg_get_dead_letters,
commands::btmsg::btmsg_clear_dead_letters,
commands::btmsg::btmsg_clear_all_comms,
commands::btmsg::btmsg_queue_dead_letter,
// Audit log
commands::btmsg::audit_log_event,