CodeGen class

This commit is contained in:
Ankit Mahato
2023-03-22 23:57:55 +05:30
parent 5c39ffd34f
commit a8fbbc96d2
2 changed files with 109 additions and 113 deletions

View File

@ -2,8 +2,10 @@ import 'dart:io';
import 'dart:convert'; import 'dart:convert';
import 'package:jinja/jinja.dart' as jj; import 'package:jinja/jinja.dart' as jj;
import 'package:apidash/consts.dart'; import 'package:apidash/consts.dart';
import 'package:apidash/utils/utils.dart' show padMultilineString;
import 'package:apidash/models/models.dart' show RequestModel, rowsToMap; import 'package:apidash/models/models.dart' show RequestModel, rowsToMap;
class DartHttpCodeGen {
String kTemplateUrl = """import 'package:http/http.dart' as http; String kTemplateUrl = """import 'package:http/http.dart' as http;
void main() async { void main() async {
@ -83,17 +85,7 @@ String kStringResult = r"""
} }
"""; """;
String padMultilineString(String text, int padding, String? getCode(RequestModel requestModel) {
{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) {
try { try {
String result = ""; String result = "";
bool hasHeaders = false; bool hasHeaders = false;
@ -124,7 +116,8 @@ String? getDartHttpCode(RequestModel requestModel) {
} }
var method = requestModel.method; 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; var contentLength = utf8.encode(requestModel.requestBody).length;
if (contentLength > 0) { if (contentLength > 0) {
hasBody = true; hasBody = true;
@ -187,3 +180,4 @@ String? getDartHttpCode(RequestModel requestModel) {
return null; return null;
} }
} }
}

View File

@ -13,6 +13,8 @@ class CodePane extends ConsumerStatefulWidget {
} }
class _CodePaneState extends ConsumerState<CodePane> { class _CodePaneState extends ConsumerState<CodePane> {
final DartHttpCodeGen dartHttpCodeGen = DartHttpCodeGen();
@override @override
void initState() { void initState() {
super.initState(); super.initState();
@ -39,7 +41,7 @@ class _CodePaneState extends ConsumerState<CodePane> {
borderRadius: kBorderRadius8, borderRadius: kBorderRadius8,
); );
final code = getDartHttpCode(requestModel); final code = dartHttpCodeGen.getCode(requestModel);
if (code == null) { if (code == null) {
return const ErrorMessage( return const ErrorMessage(
message: "An error was encountered while generating code. $kRaiseIssue", message: "An error was encountered while generating code. $kRaiseIssue",