10 Commits

Author SHA1 Message Date
Caijinglong
88a48be157 修复了一个V1中的bug 2018-08-16 14:26:07 +08:00
cjl_macbook
8bf4ebe233 format code 2018-08-11 21:23:25 +08:00
cjl_macbook
103d92b610 delete some print and update comment 2018-08-11 21:22:16 +08:00
cjl_macbook
6f007e8157 use the string replace's method the resolve the int and double problem.
replace the generate code's num to int.
2018-08-11 17:30:00 +08:00
Caijinglong
65cc06fe99 support version 1.0.0+ 2018-08-10 17:28:46 +08:00
Caijinglong
b507386ccc 更新了当前的版本 修改int 为num类型,以暂时解决dartweb中1.0会被认为是int的问题 2018-08-09 17:58:29 +08:00
Caijinglong
a0b0606c9d update the int to num 2018-08-09 17:27:06 +08:00
Caijinglong
626512e475 fix the need input bug 2018-08-09 16:33:07 +08:00
Caijinglong
bd858b22fb 自动保存entity 名称 2018-08-09 16:30:28 +08:00
Caijinglong
267425767a auto save left input json 2018-08-09 16:23:40 +08:00
7 changed files with 296 additions and 95 deletions

View File

@@ -1,21 +1,39 @@
import 'dart:convert'; import 'dart:convert';
import 'package:json2dart_serialization/json_generator.dart';
import 'package:json2dart_serialization/template.dart'; import 'package:json2dart_serialization/template.dart';
class Generator { class Generator {
String jsonString; String jsonString;
String entityName; String entityName;
Version version;
Generator(this.jsonString, [this.entityName]); Generator(this.jsonString, [this.entityName, this.version = Version.v0]) {
this.jsonString = convertJsonString(jsonString);
}
List<DefaultTemplate> templateList = []; List<DefaultTemplate> templateList = [];
String makeDartCode() { String makeDartCode() {
var entityName = this.entityName ?? "Entity"; var entityName = this.entityName ?? "Entity";
DefaultTemplate template = DefaultTemplate(srcJson: jsonString, className: entityName); DefaultTemplate template;
if (version == Version.v1) {
template = V1Template(srcJson: jsonString, className: entityName);
} else {
template = DefaultTemplate(srcJson: jsonString, className: entityName);
}
StringBuffer resultSb = StringBuffer(); StringBuffer resultSb = StringBuffer();
if (!template.isList) {
templateList.add(template); templateList.add(template);
refreshTemplate(template); refreshTemplate(template);
// return resultSb.toString();
} else {
var listTemplate = template.getListTemplate();
templateList.add(listTemplate);
refreshTemplate(template);
}
resultSb.writeln(header); resultSb.writeln(header);
templateList.forEach((template) { templateList.forEach((template) {
@@ -28,13 +46,18 @@ class Generator {
var fieldList = template.fieldList; var fieldList = template.fieldList;
fieldList.forEach((filed) { fieldList.forEach((filed) {
if (filed is MapField) { if (filed is MapField) {
// filed.typeString
DefaultTemplate template = DefaultTemplate(srcJson: json.encode(filed.map), className: filed.typeString); DefaultTemplate template = DefaultTemplate(srcJson: json.encode(filed.map), className: filed.typeString);
if (version == Version.v1) {
template = V1Template(srcJson: json.encode(filed.map), className: filed.typeString);
}
templateList.add(template); templateList.add(template);
refreshTemplate(template); refreshTemplate(template);
} else if (filed is ListField) { } else if (filed is ListField) {
if (filed.childIsObject) { if (filed.childIsObject) {
DefaultTemplate template = DefaultTemplate(srcJson: json.encode(filed.list[0]), className: filed.typeName); DefaultTemplate template = DefaultTemplate(srcJson: json.encode(filed.list[0]), className: filed.typeName);
if (version == Version.v1) {
template = V1Template(srcJson: json.encode(filed.list[0]), className: filed.typeName);
}
templateList.add(template); templateList.add(template);
refreshTemplate(template); refreshTemplate(template);
} }
@@ -60,3 +83,22 @@ String camelCase2UnderScoreCase(String name) {
return "_" + str.toLowerCase(); return "_" + str.toLowerCase();
}); });
} }
/// use the string replace's method the resolve the int and double problem.
String convertJsonString(String jsonString) {
var numberReg = RegExp(r"[0-9]\.[0-9]+");
//匹配小数数字正则
var allMatch = numberReg.allMatches(jsonString).toList();
for (var i = 0; i < allMatch.length; i++) {
//是一个小数数字
var m = allMatch[i];
var s = m.group(0);
// 应该是double但由于js的原因被识别成了整数数这里对这种数据进行处理将这里的最后一位从0替换为5以便于让该被js识别成小数 而非数字
s = s.replaceRange(s.length - 1, s.length, "5");
jsonString = jsonString.replaceRange(m.start, m.end, s);
}
return jsonString;
}

View File

@@ -3,6 +3,7 @@ import 'dart:convert';
import 'dart:html'; import 'dart:html';
import 'package:json2dart_serialization/generator.dart'; import 'package:json2dart_serialization/generator.dart';
import 'package:json2dart_serialization/storage.dart';
String entityName = null; String entityName = null;
@@ -22,28 +23,36 @@ var downloadFileName = "";
// }"""; // }""";
const defaultValue = ""; const defaultValue = "";
enum Version { v0, v1 }
Version v = Version.v0;
void main() async { void main() async {
isChinese = await _isChinese(); isChinese = await _isChinese();
var dataHelper = CookieHelper();
TextAreaElement jsonInput = querySelector("#json"); TextAreaElement jsonInput = querySelector("#json");
jsonInput.value = defaultValue; jsonInput.value = dataHelper.loadJsonString();
jsonInput.onInput.listen((event) { jsonInput.onInput.listen((event) {
// print(jsonInput.value); dataHelper.saveJsonString(jsonInput.value);
refreshData(); refreshData();
}); });
InputElement entityNameEle = querySelector("#out_entity_name"); InputElement entityNameEle = querySelector("#out_entity_name");
entityNameEle.value = dataHelper.loadEntityName();
entityName = entityNameEle.value;
entityNameEle.onInput.listen((event) { entityNameEle.onInput.listen((event) {
entityName = entityNameEle.value; entityName = entityNameEle.value;
dataHelper.saveEntityName(entityName);
refreshData(); refreshData();
}); });
ButtonElement formatButton = querySelector("#format"); ButtonElement formatButton = querySelector("#format");
formatButton.onClick.listen((click) { formatButton.onClick.listen((click) {
String pretty; String pretty;
pretty = convertJsonString(jsonInput.value);
try { try {
pretty = formatJson(jsonInput.value); pretty = formatJson(pretty);
} on Exception { } on Exception {
return; return;
} }
@@ -53,6 +62,39 @@ void main() async {
InputElement eJsonKey = querySelector("#use_json_key"); InputElement eJsonKey = querySelector("#use_json_key");
InputElement eCamelCase = querySelector("#camelCase"); InputElement eCamelCase = querySelector("#camelCase");
TextAreaElement result = querySelector("#result"); TextAreaElement result = querySelector("#result");
RadioButtonInputElement v0 = querySelector("#v0");
RadioButtonInputElement v1 = querySelector("#v1");
void updateVersioin() {
if (v1.checked) {
v = Version.v1;
} else {
v = Version.v0;
}
dataHelper.saveVersion(v);
}
void updateVersionUI() {
if (v == Version.v1) {
v1.checked = true;
} else {
v1.checked = false;
}
}
v = dataHelper.loadVersion();
updateVersionUI();
v0.onInput.listen((event) {
updateVersioin();
refreshData();
});
v1.onInput.listen((event) {
updateVersioin();
refreshData();
});
void onJsonKeyChange() { void onJsonKeyChange() {
useJsonKey = eJsonKey.checked; useJsonKey = eJsonKey.checked;
@@ -101,7 +143,8 @@ void main() async {
// FileWriter fw = await fileEntry.createWriter(); // FileWriter fw = await fileEntry.createWriter();
// fw.write(blob); // fw.write(blob);
// File file = await fileEntry.file(); // File file = await fileEntry.file();
AnchorElement saveLink = document.createElementNS("http://www.w3.org/1999/xhtml", "a"); AnchorElement saveLink =
document.createElementNS("http://www.w3.org/1999/xhtml", "a");
saveLink.href = Url.createObjectUrlFromBlob(blob); saveLink.href = Url.createObjectUrlFromBlob(blob);
// saveLink.type = "download"; // saveLink.type = "download";
saveLink.download = downloadFileName; saveLink.download = downloadFileName;
@@ -133,10 +176,10 @@ bool isChinese = false;
void refreshData() async { void refreshData() async {
TextAreaElement jsonInput = querySelector("#json"); TextAreaElement jsonInput = querySelector("#json");
var string = jsonInput.value; var string = jsonInput.value;
String pretty;
TextAreaElement result = querySelector("#result"); TextAreaElement result = querySelector("#result");
try { try {
pretty = formatJson(string); formatJson(string);
} on Exception { } on Exception {
if (isChinese) { if (isChinese) {
result.value = "不是一个正确的json"; result.value = "不是一个正确的json";
@@ -152,7 +195,7 @@ void refreshData() async {
entityClassName = entityName; entityClassName = entityName;
} }
var generator = Generator(string, entityClassName); var generator = Generator(string, entityClassName, v);
var dartCode = generator.makeDartCode(); var dartCode = generator.makeDartCode();
var dartFileName = ("${generator.fileName}.dart"); var dartFileName = ("${generator.fileName}.dart");
downloadFileName = dartFileName; downloadFileName = dartFileName;
@@ -163,7 +206,7 @@ void refreshData() async {
} else { } else {
filePrefix = "your dart file name is:"; filePrefix = "your dart file name is:";
} }
print(filePrefix); // print(filePrefix);
querySelector("#file_name").text = "$filePrefix $dartFileName"; querySelector("#file_name").text = "$filePrefix $dartFileName";
result.value = dartCode; result.value = dartCode;

44
lib/storage.dart Normal file
View File

@@ -0,0 +1,44 @@
import 'dart:html';
import 'package:json2dart_serialization/json_generator.dart';
const _entityKey = "entityKey";
const _versionKey = "versionKey";
class CookieHelper {
String loadJsonString() {
var storage = window.localStorage;
if (!storage.containsKey("json")) {
return "";
}
return window.localStorage["json"];
}
void saveJsonString(String jsonString) {
window.localStorage.addAll({"json": jsonString});
}
void saveEntityName(String entityName) {
window.localStorage.addAll({_entityKey: entityName});
}
String loadEntityName() {
if (!window.localStorage.containsKey(_entityKey)) {
return "";
}
return window.localStorage[_entityKey];
}
void saveVersion(Version version) {
var index = Version.values.indexOf(version);
window.localStorage.addAll({_versionKey: index.toString()});
}
Version loadVersion() {
if (!window.localStorage.containsKey(_versionKey)) {
return Version.v0;
}
return Version.values[int.parse(window.localStorage[_versionKey])];
}
}

View File

@@ -45,7 +45,11 @@ class DefaultTemplate extends Template {
@override @override
String declare() { String declare() {
return """@JsonSerializable() return """@JsonSerializable()
class $className extends Object with _\$${className}SerializerMixin {"""; class $className extends Object ${interface()}{""";
}
String interface() {
return "with _\$${className}SerializerMixin";
} }
@override @override
@@ -97,6 +101,76 @@ class $className extends Object with _\$${className}SerializerMixin {""";
} }
List<Field> get fieldList => FieldHelper(srcJson).getFields(); List<Field> get fieldList => FieldHelper(srcJson).getFields();
bool get isList => json.decode(srcJson) is List;
ListTemplate getListTemplate() {
if (this is ListTemplate) {
return this;
}
return ListTemplate(srcJson: srcJson, className: className, delegateTemplate: this);
}
}
class ListTemplate extends DefaultTemplate {
Template delegateTemplate;
ListTemplate({String srcJson, String className = "Entity", this.delegateTemplate}) : super(className: className, srcJson: srcJson);
@override
String declare() {
return _declareListMethod() + "\n" + delegateTemplate?.declare() ?? super.declare();
}
String _declareListMethod() {
var listMethod = """List<$className> get${className}List(List<dynamic> list){
List<$className> result = [];
list.forEach((item){
result.add($className.fromJson(item));
});
return result;
}""";
return listMethod;
}
@override
String constructor() {
return delegateTemplate?.constructor() ?? super.constructor();
}
@override
String field() {
return delegateTemplate?.field() ?? super.field();
}
@override
String method() {
return delegateTemplate?.method() ?? super.method();
}
@override
String end() {
return delegateTemplate?.end() ?? super.end();
}
@override
List<Field> get fieldList => FieldHelper(json.encode(json.decode(srcJson)[0])).getFields();
}
class V1Template extends DefaultTemplate {
V1Template({String srcJson, String className = "Entity"}) : super(className: className, srcJson: srcJson);
@override
String interface() => "";
@override
String method() {
var result = StringBuffer();
result.writeln(super.method());
result.writeln();
result.write(" Map<String, dynamic> toJson() => _\$${className}ToJson(this);");
return result.toString();
}
} }
class FieldHelper { class FieldHelper {
@@ -104,11 +178,9 @@ class FieldHelper {
FieldHelper(this.srcJson); FieldHelper(this.srcJson);
List<Field> getFields() { List<Field> _getMapFiled(Map<String, dynamic> map) {
var j = json.decode(srcJson);
if (j is Map<String, dynamic>) {
List<Field> list = []; List<Field> list = [];
j.forEach((k, v) { map.forEach((k, v) {
if (v is List) { if (v is List) {
list.add(ListField(v, k)); list.add(ListField(v, k));
} else if (v is String) { } else if (v is String) {
@@ -125,6 +197,17 @@ class FieldHelper {
}); });
return list; return list;
} }
List<Field> getFields() {
var j = json.decode(srcJson);
if (j is Map<String, dynamic>) {
return _getMapFiled(j);
} else if (j is List) {
var item = j[0];
if (item is Map<String, dynamic>) {
return _getMapFiled(item);
}
}
return []; return [];
} }
} }

View File

@@ -21,9 +21,14 @@
<img src="github_logo.jpg" width="50px" /> <img src="github_logo.jpg" width="50px" />
</a> </a>
</div> </div>
<div>
<h1>simple use <h1>simple use
<a href="https://pub.dartlang.org/packages/json_serializable" target="_blank">json_serializable</a> <a href="https://pub.dartlang.org/packages/json_serializable" target="_blank">json_serializable</a>
</h1> </h1>
<div class="version">
<input class="version" type="radio" value="0" name="version" id="v0" checked="true">v0.x.x</input>
<input class="version" type="radio" value="1" name="version" id="v1">v1.x.x</input>
</div>
<div> <div>
<div class="title"> <div class="title">
<span class="half_span">copy your json to left textarea</span> <span class="half_span">copy your json to left textarea</span>

View File

@@ -21,8 +21,15 @@
<img src="github_logo.jpg" width="50px" /> <img src="github_logo.jpg" width="50px" />
</a> </a>
</div> </div>
<div>
<h1>为了便利使用 <h1>为了便利使用
<a href="https://pub.dartlang.org/packages/json_serializable">json_serializable</a></h1> <a href="https://pub.dartlang.org/packages/json_serializable">json_serializable</a>
</h1>
<div class="version">
<input class="version" type="radio" value="0" name="version" id="v0" checked="true">v0.x.x</input>
<input class="version" type="radio" value="1" name="version" id="v1">v1.x.x</input>
</div>
</div>
<div> <div>
<div class="title"> <div class="title">
<span class="half_span">将json粘贴至左边</span> <span class="half_span">将json粘贴至左边</span>

View File

@@ -8,34 +8,6 @@ body {
padding: 0; padding: 0;
font-family: "Roboto", sans-serif; font-family: "Roboto", sans-serif;
} }
/*
.top {
height: 4vh;
text-align: center;
padding-top: 1vh;
}
.result_title {
padding-bottom: 15px;
}
.textarea {
width: 50%;
height: 90%;
text-align: center;
float: left;
}
.content_area {
width: 80%;
height: 90vh;
text-align: center;
float: left;
}
.out_entity_name {
height: 40px;
} */
h1 { h1 {
text-align: center; text-align: center;
@@ -86,3 +58,8 @@ a {
a:hover { a:hover {
text-decoration-line: underline; text-decoration-line: underline;
} }
.version {
font-size: 10px;
text-align: center;
}