ispect 1.1.0 ispect: ^1.1.0 copied to clipboard
A package combining Inspector, Talker, and more from pub.dev for efficient project implementation.
import 'package:flutter/material.dart';
import 'package:ispect/ispect.dart';
import 'package:ispect_example/src/core/localization/generated/l10n.dart';
import 'package:talker_flutter/talker_flutter.dart';
GlobalKey<NavigatorState> navigatorKey = GlobalKey<NavigatorState>();
void main() {
final talker = TalkerFlutter.init();
/// Use global variable [talkerWrapper] for logging.
talkerWrapper.initHandling(talker: talker);
talkerWrapper.debug('Hello World!');
runApp(App(talker: talker));
}
class App extends StatefulWidget {
final Talker talker;
const App({super.key, required this.talker});
@override
State<App> createState() => _AppState();
}
class _AppState extends State<App> {
@override
void initState() {
super.initState();
}
@override
Widget build(BuildContext context) {
final ISpectOptions options = ISpectOptions(
talker: widget.talker,
themeMode: ThemeMode.dark,
lightTheme: ThemeData.light(),
darkTheme: ThemeData.from(
colorScheme: ColorScheme.fromSeed(
seedColor: Colors.blue,
brightness: Brightness.dark,
),
),
locale: const Locale('en'),
);
/// It is necessary to wrap `MaterialApp` with `ISpectScopeWrapper`.
return ISpectScopeWrapper(
options: options,
isISpectEnabled: true,
child: MaterialApp(
navigatorKey: navigatorKey,
navigatorObservers: [
TalkerRouteObserver(widget.talker),
],
/// Add this to `MaterialApp`'s localizationsDelegates for add `ISpect` localization. You can also add your own localization delegates.
localizationsDelegates: ISpectLocalizations.localizationDelegates(
[AppGeneratedLocalization.delegate]),
theme: options.lightTheme,
darkTheme: options.darkTheme,
themeMode: options.themeMode,
builder: (context, child) {
/// Add this to `MaterialApp`'s builder for add `Draggable ISpect` button.
child = ISpectBuilder(
navigatorKey: navigatorKey,
child: child,
);
return child;
},
home: const _Home(),
),
);
}
}
class _Home extends StatelessWidget {
const _Home();
@override
Widget build(BuildContext context) {
return Scaffold(
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Text(AppGeneratedLocalization.of(context).app_title),
ElevatedButton(
onPressed: () {
/// Use `ISpect` to toggle `ISpect` visibility.
ISpect.read(context).toggleISpect();
},
child: const Text('Toggle ISpect'),
),
],
),
),
);
}
}