workmanager 0.1.1 workmanager: ^0.1.1 copied to clipboard
Flutter Workmanager. This plugin allows you to schedule background work on Android and iOS.
import 'dart:async';
import 'dart:io';
import 'package:flutter/material.dart';
import 'package:path_provider/path_provider.dart';
import 'package:workmanager/workmanager.dart';
void main() => runApp(MyApp());
const simpleTaskKey = "simpleTask";
const simpleDelayedTask = "simpleDelayedTask";
const simplePeriodicTask = "simplePeriodicTask";
const simplePeriodic1HourTask = "simplePeriodic1HourTask";
void callbackDispatcher() {
Workmanager.executeTask((task) async {
switch (task) {
case simpleTaskKey:
stderr.writeln("$simpleTaskKey was executed");
Directory tempDir = await getTemporaryDirectory();
String tempPath = tempDir.path;
print("You can access other plugins in the background: $tempPath");
break;
case simpleDelayedTask:
stderr.writeln("$simpleDelayedTask was executed");
break;
case simplePeriodicTask:
stderr.writeln("$simplePeriodicTask was executed");
break;
case simplePeriodic1HourTask:
stderr.writeln("$simplePeriodic1HourTask was executed");
break;
case Workmanager.iOSBackgroundTask:
stderr.writeln("The iOS background fetch was triggered");
break;
}
return Future.value(true);
});
}
class MyApp extends StatefulWidget {
@override
_MyAppState createState() => _MyAppState();
}
enum _Platform { android, ios }
class PlatformEnabledButton extends RaisedButton {
final _Platform platform;
PlatformEnabledButton({
this.platform,
@required Widget child,
@required VoidCallback onPressed,
}) : assert(child != null, onPressed != null),
super(
child: child,
onPressed: (Platform.isAndroid && platform == _Platform.android ||
Platform.isIOS && platform == _Platform.ios)
? onPressed
: null);
}
class _MyAppState extends State<MyApp> {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(
title: Text("Flutter WorkManager Example"),
),
body: Padding(
padding: const EdgeInsets.all(8.0),
child: Column(
crossAxisAlignment: CrossAxisAlignment.stretch,
children: <Widget>[
Text("Plugin initialization",
style: Theme.of(context).textTheme.headline),
RaisedButton(
child: Text("Start the Flutter background service"),
onPressed: () {
Workmanager.initialize(
callbackDispatcher,
isInDebugMode: true,
);
}),
SizedBox(height: 16),
Text("One Off Tasks (Android only)",
style: Theme.of(context).textTheme.headline),
//This task runs once.
//Most likely this will trigger immediately
PlatformEnabledButton(
platform: _Platform.android,
child: Text("Register OneOff Task"),
onPressed: () {
Workmanager.registerOneOffTask(
"1",
simpleTaskKey,
);
}),
//This task runs once
//This wait at least 10 seconds before running
PlatformEnabledButton(
platform: _Platform.android,
child: Text("Register Delayed OneOff Task"),
onPressed: () {
Workmanager.registerOneOffTask(
"2",
simpleDelayedTask,
initialDelay: Duration(seconds: 10),
);
}),
SizedBox(height: 8),
Text("Periodic Tasks (Android only)",
style: Theme.of(context).textTheme.headline),
//This task runs periodically
//It will wait at least 10 seconds before its first launch
//Since we have not provided a frequency it will be the default 15 minutes
PlatformEnabledButton(
platform: _Platform.android,
child: Text("Register Periodic Task"),
onPressed: () {
Workmanager.registerPeriodicTask(
"3",
simplePeriodicTask,
initialDelay: Duration(seconds: 10),
);
}),
//This task runs periodically
//It will run about every hour
PlatformEnabledButton(
platform: _Platform.android,
child: Text("Register 1 hour Periodic Task"),
onPressed: () {
Workmanager.registerPeriodicTask(
"5",
simplePeriodic1HourTask,
frequency: Duration(hours: 1),
);
}),
PlatformEnabledButton(
platform: _Platform.android,
child: Text("Cancel All"),
onPressed: () async {
await Workmanager.cancelAll();
print('Cancel all tasks completed');
},
),
],
),
),
),
);
}
}