Feat: Copy Response

This commit is contained in:
siddu015
2025-02-27 22:23:06 +05:30
parent 1abfb4be2c
commit 2a43640dc9
2 changed files with 27 additions and 24 deletions

View File

@ -1,5 +1,6 @@
// lib/dashbot/widgets/chat_bubble.dart
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'content_renderer.dart';
class ChatBubble extends StatelessWidget {
@ -21,7 +22,28 @@ class ChatBubble extends StatelessWidget {
: Theme.of(context).colorScheme.surfaceContainerHighest,
borderRadius: BorderRadius.circular(8),
),
child: renderContent(context, message),
child: Row(
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisSize: MainAxisSize.min,
children: [
Flexible(
child: renderContent(context, message),
),
if (!isUser) ...[
const SizedBox(width: 8),
IconButton(
icon: const Icon(Icons.copy, size: 20),
tooltip: 'Copy Response',
onPressed: () {
Clipboard.setData(ClipboardData(text: message));
ScaffoldMessenger.of(context).showSnackBar(
const SnackBar(content: Text('Copied to clipboard')),
);
},
),
],
],
),
),
);
}

View File

@ -3,7 +3,6 @@ import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:apidash/dashbot/providers/dashbot_providers.dart';
import 'package:apidash/providers/providers.dart';
import 'package:flutter/services.dart';
import 'chat_bubble.dart';
class DashBotWidget extends ConsumerStatefulWidget {
@ -106,28 +105,10 @@ class _DashBotWidgetState extends ConsumerState<DashBotWidget> {
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
const Text('DashBot', style: TextStyle(fontSize: 18, fontWeight: FontWeight.bold)),
Row(
children: [
IconButton(
icon: const Icon(Icons.copy),
tooltip: 'Copy Last Response',
onPressed: () {
final lastBotMessage = ref.read(chatMessagesProvider).lastWhere(
(msg) => msg['role'] == 'bot',
orElse: () => {'message': ''},
)['message'];
Clipboard.setData(ClipboardData(text: lastBotMessage));
ScaffoldMessenger.of(context).showSnackBar(
const SnackBar(content: Text('Copied to clipboard')),
);
},
),
IconButton(
icon: const Icon(Icons.delete_sweep),
tooltip: 'Clear Chat',
onPressed: () => ref.read(chatMessagesProvider.notifier).clearMessages(),
),
],
IconButton(
icon: const Icon(Icons.delete_sweep),
tooltip: 'Clear Chat',
onPressed: () => ref.read(chatMessagesProvider.notifier).clearMessages(),
),
],
);