mirror of
https://github.com/foss42/apidash.git
synced 2025-05-31 06:08:09 +08:00
CodeGen class
This commit is contained in:
@ -2,8 +2,10 @@ import 'dart:io';
|
||||
import 'dart:convert';
|
||||
import 'package:jinja/jinja.dart' as jj;
|
||||
import 'package:apidash/consts.dart';
|
||||
import 'package:apidash/utils/utils.dart' show padMultilineString;
|
||||
import 'package:apidash/models/models.dart' show RequestModel, rowsToMap;
|
||||
|
||||
class DartHttpCodeGen {
|
||||
String kTemplateUrl = """import 'package:http/http.dart' as http;
|
||||
|
||||
void main() async {
|
||||
@ -83,17 +85,7 @@ String kStringResult = r"""
|
||||
}
|
||||
""";
|
||||
|
||||
String padMultilineString(String text, int padding,
|
||||
{bool firstLinePadded = false}) {
|
||||
var lines = kSplitter.convert(text);
|
||||
int start = firstLinePadded ? 0 : 1;
|
||||
for (start; start < lines.length; start++) {
|
||||
lines[start] = ' ' * padding + lines[start];
|
||||
}
|
||||
return lines.join("\n");
|
||||
}
|
||||
|
||||
String? getDartHttpCode(RequestModel requestModel) {
|
||||
String? getCode(RequestModel requestModel) {
|
||||
try {
|
||||
String result = "";
|
||||
bool hasHeaders = false;
|
||||
@ -124,7 +116,8 @@ String? getDartHttpCode(RequestModel requestModel) {
|
||||
}
|
||||
|
||||
var method = requestModel.method;
|
||||
if (kMethodsWithBody.contains(method) && requestModel.requestBody != null) {
|
||||
if (kMethodsWithBody.contains(method) &&
|
||||
requestModel.requestBody != null) {
|
||||
var contentLength = utf8.encode(requestModel.requestBody).length;
|
||||
if (contentLength > 0) {
|
||||
hasBody = true;
|
||||
@ -187,3 +180,4 @@ String? getDartHttpCode(RequestModel requestModel) {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -13,6 +13,8 @@ class CodePane extends ConsumerStatefulWidget {
|
||||
}
|
||||
|
||||
class _CodePaneState extends ConsumerState<CodePane> {
|
||||
final DartHttpCodeGen dartHttpCodeGen = DartHttpCodeGen();
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
@ -39,7 +41,7 @@ class _CodePaneState extends ConsumerState<CodePane> {
|
||||
borderRadius: kBorderRadius8,
|
||||
);
|
||||
|
||||
final code = getDartHttpCode(requestModel);
|
||||
final code = dartHttpCodeGen.getCode(requestModel);
|
||||
if (code == null) {
|
||||
return const ErrorMessage(
|
||||
message: "An error was encountered while generating code. $kRaiseIssue",
|
||||
|
Reference in New Issue
Block a user