# bubble_head
A flutter plugin to enable you launch a bubble while putting your application to background and upon clicking the bubble brings your application back to foreground
## Getting Started
### Add dependency
```yaml
dependencies:
bubble_head: ^0.0.4
```
### Add in android-manifest file (**../main/AndroidManifest.xml**)
If you are unsure on where to do this, you can reference the example project AndroidManifest.xml file [here](example/android/app/src/main/AndroidManifest.xml)
Add `SYSTEM_ALERT_WINDOW` permission in manifest
```xml
```
NOTE: For best UX practices, you should request for `SYSTEM_ALERT_WINDOW` permission on your application launch (if permission `status` is not granted)
To request for permission, we advise the use of this [package](https://pub.dev/packages/permission_handler)
Add `intent-filter` in activity tag
```xml
```
Add `service` in application tag
```xml
```
### Note: To set bubble icon, create `assets/images` folder path and add your png icon with name `icon.png` to the directory (ensure to import assets in your `pubspec.yaml` file)
**GIF illustration**
[](example/assets/images/bubble_head_example.gif "Bubble-head example")
### Examples
**To start bubble**
[This puts your app in background and can be re-launched (brought to foreground) on tap of the bubble]
```dart
Bubble _bubble = new Bubble();
Future startBubbleHead() async {
try {
await _bubble.startBubbleHead();
} on PlatformException {
print('Failed to call startBubbleHead');
}
}
```
**To stop/close bubble**
```dart
Bubble _bubble = new Bubble();
Future stopBubbleHead() async {
try {
await _bubble.stopBubbleHead();
} on PlatformException {
print('Failed to call stopBubbleHead');
}
}
```
You can prevent the default action of putting your application in background when starting `bubble_head` by setting `sendAppToBackground` parameter when starting bubble head (if you choose to use another means of sending your application to background)
```dart
Bubble _bubble = new Bubble();
Future startBubbleHead() async {
try {
// this will only display the bubble-head without sending the application to background
await _bubble.startBubbleHead(sendAppToBackground: false);
} on PlatformException {
print('Failed to call startBubbleHead');
}
}
```
**Other parameters**
(You can choose to tweak **optional** parameters when initializing bubble)
```dart
Bubble({
this.shouldBounce = true,
this.allowDragToClose = true,
this.showCloseButton = false,
});
```
```dart
Bubble().startBubbleHead(sendAppToBackground: true);
```
**Parameter Definition**
- shouldBounce - Defaults to `True`
(Adds animation to bubble-head)
- allowDragToClose - Defaults to `True`
(Enables dragging bubble to bottom screen to exit)
- showCloseButton - Defaults to `False`
(Adds a close button icon to the bubble-head)
- sendAppToBackground - Defaults to `True`
(Sends application to background)
## [Buy me a Coffee](https://www.buymeacoffee.com/dsaved)