Quick Interact
Quick Interact is a Flutter package inspired by the Instagram quick send feature. It provides a simple and intuitive API to create interactive widgets with ease, allowing you to show quick interactions for any widget with various configurations.
data:image/s3,"s3://crabby-images/22d26/22d26f5c00d9998462b8de8a2a0a413970fac541" alt="Screen Recording 2023-09-25 at 20 59 36"
data:image/s3,"s3://crabby-images/ec275/ec2756eb6b4351b52826e2f111aa0bd09eeb95b7" alt="Screen Recording 2023-09-25 at 20 58 54"
data:image/s3,"s3://crabby-images/1e7d0/1e7d0af0fa322fa8b3c44482082d1897104e0f70" alt="Screen Recording 2023-09-25 at 20 59 16"
data:image/s3,"s3://crabby-images/0c7b5/0c7b55f11e81b62458b1a5bb1b0330e1fcc44e06" alt="Screen Recording 2023-09-25 at 21 00 45"
data:image/s3,"s3://crabby-images/5cfc5/5cfc527f3439361f09c54a3b63f98524207191d0" alt="Screen Recording 2023-09-25 at 21 00 34"
data:image/s3,"s3://crabby-images/1279a/1279a4f49ae92b6e59232b457140864009a90abc" alt="Screen Recording 2023-09-25 at 21 00 16"
Features
- Display quick interactions for any widget
- Customize the interaction with various configurations
- Easy to use and integrate into any Flutter project
Installation
To use this package, add quick_interact
as a dependency in your pubspec.yaml
file.
dependencies:
quick_interact: ^latest_version
Or you can install it from the command line:
bash
flutter pub add quick_interact
Usage
Here is a basic example of using Quick Interact:
Widget iconQuickReaction({required QuickInteractConfig config}) {
return Center(
child: QuickInteractions(
quickInteractionWidgets: const [
Icon(Icons.thumb_up),
Icon(Icons.thumb_down),
Icon(Icons.favorite),
Icon(Icons.bookmark),
],
onQuickInteractCompleted: (index) {
print('Quick interaction selected: $index');
},
config: config,
child: const Icon(Icons.send),
),
);
}
Example User Avatar Usage
Widget userAvatarQuickReaction({required QuickInteractConfig config}) {
return Center(
child: QuickInteractions(
quickInteractionWidgets: const [
CircleAvatar(
radius: 15,
backgroundImage:
NetworkImage('https://randomuser.me/api/portraits/men/1.jpg'),
),
CircleAvatar(
radius: 15,
backgroundImage:
NetworkImage('https://randomuser.me/api/portraits/women/2.jpg'),
),
CircleAvatar(
radius: 15,
backgroundImage:
NetworkImage('https://randomuser.me/api/portraits/men/3.jpg'),
),
CircleAvatar(
radius: 15,
backgroundImage:
NetworkImage('https://randomuser.me/api/portraits/women/4.jpg'),
),
],
onQuickInteractCompleted: (index) {
print('Quick interaction selected: $index');
},
animate: true,
config: QuickInteractConfig(),
showToolTipDelay: const Duration(milliseconds: 300),
child: const Icon(Icons.send),
),
);
}
API
QuickInteractions
QuickInteractions is a widget that provides quick interaction functionality. It uses long press gesture to trigger a set of quick interaction widgets.
Attributes:
quickInteractionWidgets
: The list of widgets for quick interactions.config
: The configuration model for QuickInteractBuilder and QuickInteract classes.onQuickInteractCompleted
: The callback function when a quick interaction is completed.child
: The child widget.onTap
: The callback function when the widget is tapped.toolTip
: The tooltip widget.disable
: A flag to disable the quick interactions.animate
: A flag to enable animation for the quick interactions.showToolTipDelay
: The delay before showing the tooltip.
QuickInteractConfig
QuickInteractConfig
is a configuration model for QuickInteractBuilder
and QuickInteract
classes. It allows you to
customize the behavior and appearance of the quick interaction widgets.
Parameters
-
widgetSize
: Size of the quick interaction widgets container. Default is 35. -
widgetPadding
: Padding between quick interaction widgets. Default is 4. -
transitionAnimationEndOffset
: Offset animations end value. Default is Offset(0, -1). -
scaleAnimationEndScale
: Scale animations end value. Default is 1.5. -
cursorAnimationDuration
: Duration of the cursor animation. Default is Duration(milliseconds: 300). -
containerColor
: Color of the quick interaction container. No default value. -
containerHeight
: Height of the quick interaction container. Default is 40. -
containerBorderRadius
: Border radius of the quick interaction container. Default is BorderRadius.all( Radius.circular(30)). -
containerAnimationDuration
: Duration of the container animation. Default is Duration(milliseconds: 300). -
containerAnimationCurve
: Curve of the container animation. Default is Curves.linearToEaseOut. -
widgetAnimationCurve
: Curve of the widget animation. Default is Curves.linearToEaseOut. -
elevation
: Elevation of the quick interaction container. Default is 5. Named Constructors -
QuickInteractConfig()
: Creates a new instance ofQuickInteractConfig
with default values. -
QuickInteractConfig.onlyTransition()
: Creates a new instance ofQuickInteractConfig
with only transition offset -2. The default elevation is set to 5. -
QuickInteractConfig.onlyScale()
: Creates a new instance ofQuickInteractConfig
with only scale 2. The default elevation is set to 5.
Examples
You can find more examples and different usages in the example main.dart.
Upcoming Features
- Displaying quick interaction in a safe area
- Providing a builder constructor to change state when active with boolean
- For more information, please refer to the API documentation.