htkc_utils 1.5.1 htkc_utils: ^1.5.1 copied to clipboard
HTKC Utils is a reusable Flutter package that provides a collection of utility functions, classes, and widgets that can be used in any Flutter project.
import 'package:example/htkc_main_home.dart';
import 'package:example/htkc_sample_drag_and_drop.dart';
import 'package:htkc_utils/htkc_utils.dart';
import 'package:htkc_utils/upgrader/hc_upgrade_new_version.dart';
void main() => runApp(MyApp());
class MyApp extends StatefulWidget {
const MyApp({super.key});
@override
State<MyApp> createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
@override
void initState() {
super.initState();
// Instantiate NewVersion manager object (Using GCP Console app as example)
final newVersion = HcUpgradeVersion(
iOSId: 'com.google.Vespa',
androidId: 'com.google.android.apps.cloudconsole',
);
// You can let the plugin handle fetching the status and showing a dialog,
// or you can fetch the status and display your own dialog, or no dialog.
const simpleBehavior = true;
if (simpleBehavior) {
basicStatusCheck(newVersion);
}
}
basicStatusCheck(HcUpgradeVersion newVersion) {
newVersion.showAlertIfNecessary(context: context);
}
advancedStatusCheck(HcUpgradeVersion newVersion) async {
final status = await newVersion.getHcNewVersionStatus();
if (status != null) {
debugPrint(status.releaseNotes);
debugPrint(status.appStoreLink);
debugPrint(status.localVersion);
debugPrint(status.storeVersion);
debugPrint(status.canUpdate.toString());
newVersion.showUpdateDialog(
context: context,
versionStatus: status,
dialogTitle: 'Custom Title',
dialogText: 'Custom Text',
);
}
}
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return EmergentApp(
debugShowCheckedModeBanner: false,
title: 'Flutter Demo',
themeMode: ThemeMode.light,
theme: EmergentThemeData(
baseColor: Color(0xFFFFFFFF),
lightSource: LightSource.topLeft,
depth: 10,
),
darkTheme: EmergentThemeData(
baseColor: Color(0xFF3E3E3E),
lightSource: LightSource.topLeft,
depth: 6,
),
home: MyHomePage(),
);
}
}
class MyHomePage extends StatelessWidget {
MyHomePage({Key? key}) : super(key: key);
Widget build(BuildContext context) {
return Scaffold(
floatingActionButton: EmergentFloatingActionButton(
child: Icon(Icons.add, size: 30),
onPressed: () {},
),
backgroundColor: EmergentTheme.baseColor(context),
body: Center(
child: Column(
mainAxisSize: MainAxisSize.min,
children: <Widget>[
EmergentButton(
onPressed: () {
print("onClick");
},
style: EmergentStyle(
shape: EmergentShape.flat,
boxShape: EmergentBoxShape.circle(),
),
padding: const EdgeInsets.all(12.0),
child: Icon(
Icons.favorite_border,
color: _iconsColor(context),
),
),
EmergentButton(
margin: EdgeInsets.only(top: 12),
onPressed: () {
EmergentTheme.of(context)?.themeMode =
EmergentTheme.isUsingDark(context)
? ThemeMode.light
: ThemeMode.dark;
},
style: EmergentStyle(
shape: EmergentShape.flat,
boxShape:
EmergentBoxShape.roundRect(BorderRadius.circular(8)),
),
padding: const EdgeInsets.all(12.0),
child: Text(
"Toggle Theme",
style: TextStyle(color: _textColor(context)),
)),
EmergentButton(
margin: EdgeInsets.only(top: 12),
onPressed: () {
Navigator.of(context)
.pushReplacement(MaterialPageRoute(builder: (context) {
return FullSampleHomePage();
}));
},
style: EmergentStyle(
shape: EmergentShape.flat,
boxShape:
EmergentBoxShape.roundRect(BorderRadius.circular(8)),
//border: EmergentBorder()
),
padding: const EdgeInsets.all(12.0),
child: Text(
"Go to full sample",
style: TextStyle(color: _textColor(context)),
)),
EmergentButton(
margin: EdgeInsets.only(top: 12),
onPressed: () {
Navigator.of(context)
.pushReplacement(MaterialPageRoute(builder: (context) {
return HcDragAndDropSample();
}));
},
style: EmergentStyle(
shape: EmergentShape.flat,
boxShape:
EmergentBoxShape.roundRect(BorderRadius.circular(8)),
//border: EmergentBorder()
),
padding: const EdgeInsets.all(12.0),
child: Text(
"Go to Drag And Drop Sample",
style: TextStyle(color: _textColor(context)),
)),
],
),
),
);
}
Color? _iconsColor(BuildContext context) {
final theme = EmergentTheme.of(context);
if (theme!.isUsingDark) {
return theme.current?.accentColor;
} else {
return null;
}
}
Color _textColor(BuildContext context) {
if (EmergentTheme.isUsingDark(context)) {
return Colors.white;
} else {
return Colors.black;
}
}
}