prefix . 'rl_mailwarmer_conversations'; $message_table = $wpdb->prefix . 'rl_mailwarmer_messages'; // Fetch conversations with their messages $conversations = $wpdb->get_results(" SELECT c.id as conversation_id, c.campaign_id, c.created_at, m.id as message_id, m.scheduled_for_timestamp, m.from_email, m.to_email, m.subject FROM $conversation_table c LEFT JOIN $message_table m ON c.id = m.conversation_id WHERE m.status != 'scheduled' ORDER BY c.created_at DESC, m.scheduled_for_timestamp ASC "); ?>

message_id) : ?> conversation_id); ?> campaign_id); ?> created_at); ?> message_id); ?> scheduled_for_timestamp); ?> from_email); ?> to_email); ?> subject); ?>

__('Permission denied.', 'rl-mailwarmer')]); } $message_ids = isset($_POST['message_ids']) ? array_map('intval', $_POST['message_ids']) : []; if (empty($message_ids)) { wp_send_json_error(['message' => __('No messages selected.', 'rl-mailwarmer')]); } $table_name = $wpdb->prefix . 'rl_mailwarmer_messages'; // Delete selected messages $placeholders = implode(',', array_fill(0, count($message_ids), '%d')); $query = "DELETE FROM $table_name WHERE id IN ($placeholders)"; $result = $wpdb->query($wpdb->prepare($query, $message_ids)); if ($result === false) { wp_send_json_error(['message' => __('Failed to delete messages.', 'rl-mailwarmer')]); } wp_send_json_success(['message' => __('Messages deleted successfully.', 'rl-mailwarmer')]); });