theta 0.1.9 theta: ^0.1.9 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(
'Homepage',
/// [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),
/// [fit] is how the component should fit the parent.
/// It can be [ComponentFit.absolute] or [ComponentFit.autoLayout].
fit: ComponentFit.absolute,
/// [overrides] are the properties that can be overriden by the user.
overrides: [
/// [Override] requires a [node] identifier and a list of [props].
/// Use one Override per node.
Override(
'node id',
)..setChild(const UIBox('ComponentName')),
Override(
'node id',
)
..setText('Click me!')
..setColor(Colors.red, 1),
Override(
'node id 2',
)..setChildren([
const Text('Click me!'),
const 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!'),
),
],
),
),
),
);
}
}