handoff 0.1.0
handoff: ^0.1.0 copied to clipboard
A Flutter plugin for Apple's Handoff functionality.
import 'package:flutter/material.dart';
import 'package:handoff/handoff.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatefulWidget {
const MyApp({super.key});
@override
State<MyApp> createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
final TextEditingController _urlController = TextEditingController(
text: 'https://flutter.dev',
);
final TextEditingController _titleController = TextEditingController(
text: 'Browse URL from Flutter',
);
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(title: Text('Handoff Plugin Example')),
body: Builder(
builder: (context) {
return Padding(
padding: EdgeInsets.all(16.0),
child: Column(
children: [
TextField(
controller: _urlController,
decoration: InputDecoration(
labelText: 'URL to handoff',
border: OutlineInputBorder(),
),
),
SizedBox(height: 20),
TextField(
controller: _titleController,
decoration: InputDecoration(
labelText: 'Title',
border: OutlineInputBorder(),
),
),
SizedBox(height: 20),
ElevatedButton(
onPressed: () async {
try {
await Handoff.setHandoffUrl(
_urlController.text,
title: _titleController.text,
);
if (mounted) {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(
content: Text('Handoff URL set successfully'),
),
);
}
} catch (e) {
if (mounted) {
ScaffoldMessenger.of(
context,
).showSnackBar(SnackBar(content: Text('Error: $e')));
}
}
},
child: Text('Set Handoff URL'),
),
SizedBox(height: 10),
ElevatedButton(
onPressed: () async {
try {
await Handoff.clearHandoff();
if (mounted) {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(content: Text('Handoff cleared')),
);
}
} catch (e) {
if (mounted) {
ScaffoldMessenger.of(
context,
).showSnackBar(SnackBar(content: Text('Error: $e')));
}
}
},
child: Text('Clear Handoff'),
),
],
),
);
},
),
),
);
}
}