mirror of
https://github.com/wgh136/flutter_qjs.git
synced 2025-09-27 05:27:23 +00:00
update doc
This commit is contained in:
@@ -72,7 +72,8 @@ class CodeInputController extends TextEditingController {
|
||||
InlineSpan leftSpan;
|
||||
oldSpan.children?.indexWhere((element) {
|
||||
String elementText = element.toPlainText();
|
||||
if (start + elementText.length > splitAt || !newText.startsWith(elementText, start)) {
|
||||
if (start + elementText.length > splitAt ||
|
||||
!newText.startsWith(elementText, start)) {
|
||||
leftSpan = element;
|
||||
return true;
|
||||
}
|
||||
@@ -86,7 +87,9 @@ class CodeInputController extends TextEditingController {
|
||||
oldSpan.children?.sublist(beforeSpans.length)?.lastIndexWhere((element) {
|
||||
String elementText = element.toPlainText();
|
||||
if (splitAt + end + elementText.length >= newText.length ||
|
||||
!newText.substring(start, newText.length - end).endsWith(elementText)) {
|
||||
!newText
|
||||
.substring(start, newText.length - end)
|
||||
.endsWith(elementText)) {
|
||||
rightSpan = element;
|
||||
return true;
|
||||
}
|
||||
@@ -98,7 +101,9 @@ class CodeInputController extends TextEditingController {
|
||||
return TextSpan(style: style, children: [
|
||||
...beforeSpans,
|
||||
TextSpan(
|
||||
style: leftSpan != null && leftSpan == rightSpan ? leftSpan.style : style,
|
||||
style: leftSpan != null && leftSpan == rightSpan
|
||||
? leftSpan.style
|
||||
: style,
|
||||
text: newText.substring(start, max(start, newText.length - end))),
|
||||
...endSpans.reversed
|
||||
]);
|
||||
|
@@ -1,21 +1,24 @@
|
||||
/*
|
||||
* @Description:
|
||||
* @Description: example
|
||||
* @Author: ekibun
|
||||
* @Date: 2020-08-08 08:16:51
|
||||
* @LastEditors: ekibun
|
||||
* @LastEditTime: 2020-08-17 21:46:10
|
||||
* @LastEditTime: 2020-08-20 14:42:10
|
||||
*/
|
||||
import 'package:flutter/material.dart';
|
||||
import 'dart:typed_data';
|
||||
|
||||
import 'package:flutter_qjs_example/test.dart';
|
||||
import 'package:dio/dio.dart';
|
||||
import 'package:flutter_qjs/flutter_qjs.dart';
|
||||
|
||||
import 'code/editor.dart';
|
||||
|
||||
void main() {
|
||||
runApp(MyApp());
|
||||
}
|
||||
|
||||
class MyApp extends StatelessWidget {
|
||||
|
||||
const MyApp({ Key key }) : super(key: key);
|
||||
const MyApp({Key key}) : super(key: key);
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
@@ -24,8 +27,6 @@ class MyApp extends StatelessWidget {
|
||||
debugShowCheckedModeBanner: false,
|
||||
theme: ThemeData(
|
||||
appBarTheme: AppBarTheme(brightness: Brightness.dark, elevation: 0),
|
||||
primaryColor: Color(0xfff09199),
|
||||
accentColor: Color(0xffec818a),
|
||||
backgroundColor: Colors.grey[300],
|
||||
primaryColorBrightness: Brightness.dark,
|
||||
),
|
||||
@@ -35,5 +36,109 @@ class MyApp extends StatelessWidget {
|
||||
initialRoute: 'home',
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
class TestPage extends StatefulWidget {
|
||||
@override
|
||||
State<StatefulWidget> createState() => _TestPageState();
|
||||
}
|
||||
|
||||
class _TestPageState extends State<TestPage> {
|
||||
String code, resp;
|
||||
FlutterJs engine;
|
||||
|
||||
_createEngine() async {
|
||||
if (engine != null) return;
|
||||
engine = FlutterJs();
|
||||
await engine.setMethodHandler((String method, List arg) async {
|
||||
switch (method) {
|
||||
case "http":
|
||||
Response response = await Dio().get(arg[0]);
|
||||
return response.data;
|
||||
case "test":
|
||||
return await arg[0]([
|
||||
true,
|
||||
1,
|
||||
0.5,
|
||||
"str",
|
||||
{"key": "val", 0: 1},
|
||||
Uint8List(2),
|
||||
Int32List(2),
|
||||
Int64List(2),
|
||||
Float64List(2),
|
||||
Float32List(2)
|
||||
]);
|
||||
default:
|
||||
return JsMethodHandlerNotImplement();
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Scaffold(
|
||||
appBar: AppBar(
|
||||
title: Text("JS engine test"),
|
||||
),
|
||||
body: SingleChildScrollView(
|
||||
padding: const EdgeInsets.all(16),
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
SingleChildScrollView(
|
||||
scrollDirection: Axis.horizontal,
|
||||
child: Row(
|
||||
children: [
|
||||
FlatButton(
|
||||
child: Text("create engine"), onPressed: _createEngine),
|
||||
FlatButton(
|
||||
child: Text("evaluate"),
|
||||
onPressed: () async {
|
||||
if (engine == null) {
|
||||
print("please create engine first");
|
||||
return;
|
||||
}
|
||||
try {
|
||||
resp = (await engine.evaluate(code ?? '', "<eval>"))
|
||||
.toString();
|
||||
} catch (e) {
|
||||
resp = e.toString();
|
||||
}
|
||||
setState(() {});
|
||||
}),
|
||||
FlatButton(
|
||||
child: Text("close engine"),
|
||||
onPressed: () async {
|
||||
if (engine != null) return;
|
||||
await engine.destroy();
|
||||
engine = null;
|
||||
}),
|
||||
],
|
||||
),
|
||||
),
|
||||
Container(
|
||||
padding: const EdgeInsets.all(12),
|
||||
color: Colors.grey.withOpacity(0.1),
|
||||
constraints: BoxConstraints(minHeight: 200),
|
||||
child: CodeEditor(
|
||||
onChanged: (v) {
|
||||
code = v;
|
||||
},
|
||||
),
|
||||
),
|
||||
SizedBox(height: 16),
|
||||
Text("result:"),
|
||||
SizedBox(height: 16),
|
||||
Container(
|
||||
width: double.infinity,
|
||||
padding: const EdgeInsets.all(12),
|
||||
color: Colors.green.withOpacity(0.05),
|
||||
constraints: BoxConstraints(minHeight: 100),
|
||||
child: Text(resp ?? ''),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
@@ -1,116 +0,0 @@
|
||||
/*
|
||||
* @Description:
|
||||
* @Author: ekibun
|
||||
* @Date: 2020-07-18 23:28:55
|
||||
* @LastEditors: ekibun
|
||||
* @LastEditTime: 2020-08-20 13:11:33
|
||||
*/
|
||||
import 'dart:typed_data';
|
||||
|
||||
import 'package:dio/dio.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter_qjs/flutter_qjs.dart';
|
||||
|
||||
import 'code/editor.dart';
|
||||
|
||||
class TestPage extends StatefulWidget {
|
||||
@override
|
||||
State<StatefulWidget> createState() => _TestPageState();
|
||||
}
|
||||
|
||||
class _TestPageState extends State<TestPage> {
|
||||
String code, resp;
|
||||
FlutterJs engine;
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Scaffold(
|
||||
appBar: AppBar(
|
||||
title: Text("JS engine test"),
|
||||
),
|
||||
body: SingleChildScrollView(
|
||||
padding: const EdgeInsets.all(16),
|
||||
child: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
SingleChildScrollView(
|
||||
scrollDirection: Axis.horizontal,
|
||||
child: Row(
|
||||
children: [
|
||||
FlatButton(
|
||||
child: Text("create engine"),
|
||||
onPressed: () async {
|
||||
if (engine != null) return;
|
||||
engine = FlutterJs();
|
||||
engine.setMethodHandler((String method, List arg) async {
|
||||
switch (method) {
|
||||
case "http":
|
||||
Response response = await Dio().get(arg[0]);
|
||||
return response.data;
|
||||
case "test":
|
||||
return await arg[0]([
|
||||
true,
|
||||
1,
|
||||
0.5,
|
||||
"str",
|
||||
{ "key": "val", 0: 1 },
|
||||
Uint8List(2),
|
||||
Int32List(2),
|
||||
Int64List(2),
|
||||
Float64List(2),
|
||||
Float32List(2)]);
|
||||
default:
|
||||
return JsMethodHandlerNotImplement();
|
||||
}
|
||||
});
|
||||
}),
|
||||
FlatButton(
|
||||
child: Text("evaluate"),
|
||||
onPressed: () async {
|
||||
if (engine == null) {
|
||||
print("please create engine first");
|
||||
return;
|
||||
}
|
||||
try {
|
||||
resp = "${await engine.evaluate(code ?? '', "<eval>")}";
|
||||
} catch (e) {
|
||||
resp = e.toString();
|
||||
}
|
||||
setState(() {});
|
||||
}),
|
||||
FlatButton(
|
||||
child: Text("close engine"),
|
||||
onPressed: () async {
|
||||
if (engine != null) return;
|
||||
await engine.destroy();
|
||||
engine = null;
|
||||
}),
|
||||
],
|
||||
),
|
||||
),
|
||||
Container(
|
||||
padding: const EdgeInsets.all(12),
|
||||
color: Colors.grey.withOpacity(0.1),
|
||||
constraints: BoxConstraints(minHeight: 200),
|
||||
child: CodeEditor(
|
||||
onChanged: (v) {
|
||||
code = v;
|
||||
},
|
||||
),
|
||||
),
|
||||
SizedBox(height: 16),
|
||||
Text("result:"),
|
||||
SizedBox(height: 16),
|
||||
Container(
|
||||
width: double.infinity,
|
||||
padding: const EdgeInsets.all(12),
|
||||
color: Colors.green.withOpacity(0.05),
|
||||
constraints: BoxConstraints(minHeight: 100),
|
||||
child: Text(resp ?? ''),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
@@ -75,7 +75,7 @@ packages:
|
||||
path: ".."
|
||||
relative: true
|
||||
source: path
|
||||
version: "0.0.1"
|
||||
version: "0.0.2"
|
||||
flutter_test:
|
||||
dependency: "direct dev"
|
||||
description: flutter
|
||||
|
Reference in New Issue
Block a user