mirror of
https://github.com/foss42/apidash.git
synced 2025-07-01 21:47:11 +08:00
Generate Codes for different Languages based on API
This commit is contained in:
@ -184,4 +184,72 @@ generate same to same type of test case url for test purpose
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Future<String> generateCode({
|
||||
required dynamic requestModel,
|
||||
required dynamic responseModel,
|
||||
required String language
|
||||
}) async {
|
||||
final method = requestModel.httpRequestModel?.method
|
||||
?.toString()
|
||||
?.split('.')
|
||||
?.last
|
||||
?.toUpperCase() ?? "GET";
|
||||
final endpoint = requestModel.httpRequestModel?.url ?? "Unknown endpoint";
|
||||
final headers = requestModel.httpRequestModel?.enabledHeadersMap ?? {};
|
||||
final params = requestModel.httpRequestModel?.enabledParamsMap ?? {};
|
||||
final body = requestModel.httpRequestModel?.body;
|
||||
final responseBody = responseModel.body;
|
||||
|
||||
final prompt = '''
|
||||
Generate complete $language code for this API integration:
|
||||
|
||||
API Request:
|
||||
- URL: $endpoint
|
||||
- Method: $method
|
||||
- Headers: ${headers.isEmpty ? 'None' : jsonEncode(headers)}
|
||||
- Params: ${params.isEmpty ? 'None' : jsonEncode(params)}
|
||||
- Body: ${body ?? 'None'}
|
||||
|
||||
Response Structure:
|
||||
${_formatResponse(responseBody)}
|
||||
|
||||
Requirements:
|
||||
1. Single-file solution with no external config
|
||||
2. Direct API URL implementation
|
||||
3. Error handling for network/status errors
|
||||
4. UI components matching response data
|
||||
5. Ready-to-run code with example data display
|
||||
|
||||
Generate complete implementation code only.
|
||||
''';
|
||||
|
||||
return generateResponse(prompt);
|
||||
}
|
||||
|
||||
String _formatResponse(dynamic response) {
|
||||
if (response is Map) {
|
||||
return response.entries
|
||||
.map((e) => '${e.key}: ${_valueType(e.value)}')
|
||||
.join('\n');
|
||||
}
|
||||
return response?.toString() ?? 'No response body';
|
||||
}
|
||||
|
||||
String _valueType(dynamic value) {
|
||||
if (value is List) return 'List[${value.isNotEmpty ? _valueType(value.first) : '?'}]';
|
||||
if (value is Map) return 'Object';
|
||||
return value.runtimeType.toString();
|
||||
}
|
||||
|
||||
// Simplified UI detection
|
||||
List<String> _detectUIElements(dynamic response) {
|
||||
final elements = <String>[];
|
||||
if (response is Map) {
|
||||
if (response.containsKey('image') || response.containsKey('imageUrl')) elements.add('image');
|
||||
if (response.containsKey('items') || response.containsKey('list')) elements.add('list');
|
||||
if (response.containsKey('title') || response.containsKey('name')) elements.add('title');
|
||||
}
|
||||
return elements;
|
||||
}
|
||||
}
|
||||
|
@ -1,9 +1,10 @@
|
||||
import 'dart:convert';
|
||||
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
||||
import 'package:apidash/providers/providers.dart';
|
||||
import 'package:flutter_markdown/flutter_markdown.dart';
|
||||
|
||||
|
||||
class ChatbotWidget extends ConsumerStatefulWidget {
|
||||
const ChatbotWidget({Key? key}) : super(key: key);
|
||||
|
||||
@ -16,6 +17,40 @@ class _ChatbotWidgetState extends ConsumerState<ChatbotWidget> {
|
||||
final List<Map<String, dynamic>> _messages = [];
|
||||
bool _isLoading = false;
|
||||
|
||||
Future<void> _handleCodeGeneration() async {
|
||||
final language = await showDialog<String>(
|
||||
context: context,
|
||||
builder: (context) => AlertDialog(
|
||||
title: const Text('Select Language'),
|
||||
content: SizedBox(
|
||||
width: 300,
|
||||
child: ListView(
|
||||
shrinkWrap: true,
|
||||
children: [
|
||||
_buildLanguageTile('Dart'),
|
||||
_buildLanguageTile('Flutter'),
|
||||
_buildLanguageTile('React'),
|
||||
_buildLanguageTile('Python'),
|
||||
_buildLanguageTile('JavaScript'),
|
||||
_buildLanguageTile('Node.js'),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
);
|
||||
|
||||
if (language != null) {
|
||||
_sendMessage("Generate $language Code");
|
||||
}
|
||||
}
|
||||
|
||||
ListTile _buildLanguageTile(String language) {
|
||||
return ListTile(
|
||||
title: Text(language),
|
||||
onTap: () => Navigator.pop(context, language),
|
||||
);
|
||||
}
|
||||
|
||||
void _sendMessage(String message) async {
|
||||
if (message.trim().isEmpty) return;
|
||||
final ollamaService = ref.read(ollamaServiceProvider);
|
||||
@ -30,6 +65,7 @@ class _ChatbotWidgetState extends ConsumerState<ChatbotWidget> {
|
||||
|
||||
try {
|
||||
String response;
|
||||
|
||||
if (message == "Explain API") {
|
||||
response = await ollamaService.explainLatestApi(
|
||||
requestModel: requestModel,
|
||||
@ -42,15 +78,25 @@ class _ChatbotWidgetState extends ConsumerState<ChatbotWidget> {
|
||||
);
|
||||
} else if (message == "Generate Test Case") {
|
||||
response = await ollamaService.generateTestCases(
|
||||
requestModel: requestModel,
|
||||
responseModel: responseModel
|
||||
requestModel: requestModel,
|
||||
responseModel: responseModel,
|
||||
);
|
||||
} else if (message.startsWith("Generate ") && message.endsWith(" Code")) {
|
||||
final language = message.replaceAll("Generate ", "").replaceAll(" Code", "");
|
||||
response = await ollamaService.generateCode(
|
||||
requestModel: requestModel,
|
||||
responseModel: responseModel,
|
||||
language: language,
|
||||
);
|
||||
} else {
|
||||
response = await ollamaService.generateResponse(message);
|
||||
}
|
||||
|
||||
setState(() {
|
||||
_messages.add({'role': 'bot', 'message': response});
|
||||
_messages.add({
|
||||
'role': 'bot',
|
||||
'message': response.contains("```") ? response : "```$response```"
|
||||
});
|
||||
});
|
||||
} catch (error) {
|
||||
setState(() {
|
||||
@ -100,7 +146,12 @@ class _ChatbotWidgetState extends ConsumerState<ChatbotWidget> {
|
||||
icon: const Icon(Icons.developer_mode),
|
||||
label: const Text("Test Case"),
|
||||
),
|
||||
|
||||
const SizedBox(width: 8),
|
||||
ElevatedButton.icon(
|
||||
onPressed: _handleCodeGeneration,
|
||||
icon: const Icon(Icons.code),
|
||||
label: const Text("Generate Code"),
|
||||
),
|
||||
const Spacer(),
|
||||
],
|
||||
),
|
||||
@ -168,7 +219,7 @@ class ChatBubble extends StatelessWidget {
|
||||
),
|
||||
child: MarkdownBody(
|
||||
data: message,
|
||||
selectable: true, // Allows copying text
|
||||
selectable: true,
|
||||
),
|
||||
),
|
||||
);
|
||||
|
Reference in New Issue
Block a user