mirror of
https://github.com/foss42/apidash.git
synced 2025-06-05 01:46:21 +08:00
CodeGen class
This commit is contained in:
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
@ -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",
|
||||||
|
Reference in New Issue
Block a user