theta 0.1.3 theta: ^0.1.3 copied to clipboard
Build remote, dynamic and responsive user interfaces with the Theta Flutter library.
import 'package:flutter/material.dart';
import 'package:theta/theta.dart';
Future<void> main() async {
/// Initialize Theta instance.
/// You can get an anonymous key at https://app.buildwiththeta.com
await Theta.initialize(
cacheEnabled: false,
anonKey: '',
);
runApp(const MyApp());
}
class MyApp extends StatefulWidget {
const MyApp({super.key});
@override
State<MyApp> createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
@override
Widget build(BuildContext context) {
/// ThetaProvider is used to provide the project styles to the widgets.
/// It's required to use Theta widgets.
return ThetaProvider(
theme: ThemeMode.light,
child: MaterialApp(
home: Scaffold(
/// UIBox is the main widget.
/// It's used to build the UI.
/// It requires a page [name].
body: UIBox(
'Button',
/// [placeholder] is the widget displayed while the page is loading.
placeholder: () => const CircularProgressIndicator(),
/// [errorWidget] is the widget displayed if an error occurs.
errorWidget: (error) => Text(error),
overrides: const [
Override(
nodeIdenfier: 'node.id',
props: [
ChildProperty(
child: Text('Click me!'),
),
],
)
],
/// [workflows] are the workflows that can be triggered by the user, mixing no-code and code.
workflows: [
Workflow(
'node id',
Trigger.onMouseEnter,
() => debugPrint('Hovered!'),
),
Workflow(
'node name',
Trigger.onMouseExit,
() => debugPrint('Not hovered!'),
),
Workflow(
'node id',
Trigger.onTap,
() => debugPrint('Tapped!'),
),
],
),
),
),
);
}
}