flutter_js 0.1.0+2 copy "flutter_js: ^0.1.0+2" to clipboard
flutter_js: ^0.1.0+2 copied to clipboard

outdated

A Javascript engine to use with flutter. It uses quickjs on Android and JavascriptCore on IOS

example/lib/main.dart

import 'package:flutter/material.dart';
import 'dart:async';

import 'package:flutter/services.dart';
import 'package:flutter_js/flutter_js.dart';
import 'package:flutter_js_example/ajv_example.dart';

void main() => runApp(MyApp());

class MyApp extends StatefulWidget {

  GlobalKey<ScaffoldState> scaffoldState = GlobalKey();
  @override
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: FlutterJsHomeScreen(),
    );
  }
}

class FlutterJsHomeScreen extends StatefulWidget {
  @override
  _FlutterJsHomeScreenState createState() => _FlutterJsHomeScreenState();
}

class _FlutterJsHomeScreenState extends State<FlutterJsHomeScreen> {

  String _jsResult = '';
  JavascriptRuntime flutterJs;
  @override
  void initState() {
    super.initState();

    flutterJs = getJavascriptRuntime();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text('FlutterJS Example'),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Text('JS Evaluate Result: $_jsResult\n'),
            SizedBox(height: 20,),
            Padding(padding: EdgeInsets.all(10), child: Text('Click on the big JS Yellow Button to evaluate the expression bellow using the flutter_js plugin'),),
            Padding(
              padding: const EdgeInsets.all(8.0),
              child: Text("Math.trunc(Math.random() * 100).toString();", style: TextStyle(fontSize: 12, fontStyle: FontStyle.italic, fontWeight: FontWeight.bold),),
            ),
            RaisedButton(onPressed: () => Navigator.of(context).push(MaterialPageRoute(builder: (ctx) => AjvExample())), child: const Text('See Ajv Example'),),
          ],
        ),
      ),
      floatingActionButton: FloatingActionButton(
        backgroundColor: Colors.transparent,
        child: Image.asset('assets/js.ico'),
        onPressed: () async {
          try {
            JsEvalResult jsResult = flutterJs.evaluate(
                "Math.trunc(Math.random() * 100).toString();");
            setState(() {
              _jsResult = jsResult.stringResult;
            });
          } on PlatformException catch (e) {
            print('ERRO: ${e.details}');
          }
        },
      ),
    );
  }
}
288
likes
0
pub points
95%
popularity

Publisher

unverified uploader

A Javascript engine to use with flutter. It uses quickjs on Android and JavascriptCore on IOS

Repository (GitHub)
View/report issues

License

unknown (LICENSE)

Dependencies

ffi, flutter, http

More

Packages that depend on flutter_js