Add quick actions

This commit is contained in:
Anton Tananaev 2025-05-10 11:16:46 -07:00
parent dd164e95ea
commit 795393d543
9 changed files with 128 additions and 2 deletions

View file

@ -17,5 +17,8 @@
"intervalLabel": "Frequency",
"distanceLabel": "Distance",
"bufferLabel": "Offline buffering",
"trackingLabel": "Continuous tracking"
"trackingLabel": "Continuous tracking",
"startAction": "Start service",
"stopAction": "Stop service",
"sosAction": "Send SOS"
}

View file

@ -1,6 +1,7 @@
import 'package:flutter/material.dart';
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
import 'package:flutter_background_geolocation/flutter_background_geolocation.dart' as bg;
import 'package:traccar_client/quick_actions.dart';
import 'main_screen.dart';
import 'preferences.dart';
@ -25,7 +26,12 @@ class MainApp extends StatelessWidget {
seedColor: Colors.green,
),
),
home: MainScreen(),
home: Stack(
children: const [
QuickActionsInitializer(),
MainScreen(),
],
),
);
}
}

48
lib/quick_actions.dart Normal file
View file

@ -0,0 +1,48 @@
import 'dart:developer' as developer;
import 'package:flutter/material.dart';
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
import 'package:quick_actions/quick_actions.dart';
class QuickActionsInitializer extends StatefulWidget {
const QuickActionsInitializer({super.key});
@override
State<QuickActionsInitializer> createState() => _QuickActionsInitializerState();
}
class _QuickActionsInitializerState extends State<QuickActionsInitializer> {
final QuickActions quickActions = QuickActions();
@override
void initState() {
super.initState();
quickActions.initialize((shortcutType) {
developer.log('action $shortcutType');
switch (shortcutType) {
case 'start':
break;
case 'stop':
break;
case 'sos':
break;
}
});
}
@override
void didChangeDependencies() {
super.didChangeDependencies();
final localizations = AppLocalizations.of(context)!;
quickActions.setShortcutItems(<ShortcutItem>[
ShortcutItem(type: 'sos', localizedTitle: localizations.sosAction, icon: 'exclamation'),
ShortcutItem(type: 'stop', localizedTitle: localizations.stopAction, icon: 'stop'),
ShortcutItem(type: 'start', localizedTitle: localizations.startAction, icon: 'play'),
]);
}
@override
Widget build(BuildContext context) {
return const SizedBox.shrink();
}
}