- Updated Provider version
- Migrated to null safety
- Clear Preferences issue fixed
- Introduce a PersistenceProvider interface for storing step completion in any mechanism the user wants.
- Fully backward compatible, no need to change your code.
- All historic steps are honored and will not show again, just as you’d expect.
- Fixes FeatureDiscovery position issue
- Fixes a null pointer exception.
- Breaking change:
isDisplayed
is replaced byhasPreviouslyCompleted
. - Fix: the
onComplete
returned value will no longer be ignored, and the next overlay won't show if this function returnsfalse
. FeatureDiscovery.completeCurrentStep
will force complete the current step and not execute theonComplete
function.- Deprecated methods in
FeatureDiscovery
have been removed. - New parameter
recordStepsInSharedPreferences
inFeatureDiscovery
to prevent step completions to be recorded in Shared Preferences. - New parameter
sharedPreferencesPrefix
inFeatureDiscovery
.
- Added
FeatureDiscovery.backgroundOpacity
in order to customize overlay background opacity when it is displayed.backgroundOpacity
is optional. If ignored, the default value is 0.96.
- Added
FeatureDiscovery.isDisplayed
method to check status of feature - Added Feature/animation durations customization
- Added
openDuration
flag that controls open animation duration. - Added
pulseDuration
flag that controls tap target pulse animation duration. - Added
completeDuration
flag that controls complete animation duration. - Added
dismissDuration
flag that controls dismiss animation duration.
- Added
barrierDismissible
flag which decides whether the overlay should dismiss on touching outside or not.
- Breaking change:
FeatureDiscovery.completeCurrentStep
is async now. - Added preferences for each feature to show is understood by user or not
- Library will not show understood feature
- Added method for reset all preferences of features
FeatureDiscovery.clearPreferences
- Breaking change: removed deprecated static methods in
FeatureDiscovery
. - Breaking change: removed deprecated parameters in the
EnsureVisible
constructor. - Breaking change: overlays will always be dismissed when calling
FeatureDiscovery.dismissAll
. - Deprecated
activeFeatureId
; replaced bycurrentFeatureIdOf
to emphasize that this is a getter. - Deprecated
FeatureDiscovery.dismiss
; replaced bydismissAll
to indicate that no next step will be shown. - Added
assert
to require at least one step to be passed toFeatureDiscovery.discoverFeatures
. - Incorrect documentation of some static methods in
FeatureDiscovery
has been updated. - Error messages have been improved : the error thrown when the widget tree isn't wrapped in
a
FeatureDiscovery
widget is clearer. - Incorrect behavior when
onDismiss
returnedFuture<false>
has been fixed.
- Update version constraint to
^4.0.1
forprovider
dependency.
- Breaking change: Renamed
ContentOrientation
toContentLocation
. - Breaking change: Made
onComplete
of typeFuture<bool> Function()
to matchonOpen
andonDismiss
. - Methods
completeStep
andmarkStepComplete
have been deprecated andcompleteCurrentStep
should now be used. - Method
clear
is deprecated anddismiss
should now be used. - Added an
OverflowMode
enum and theoverflowMode
parameter toDescribedFeatureOverlay
to control how the overlay should handle content that exceeds the background's boundaries. - Added
FeatureDiscovery.activeFeatureId
, which allows you to get the feature id of the current feature discovery step. - Added
duration
,curve
, andpreciseAligment
parameters toEnsureVisibleState.ensureVisible
. - Deprecated
EnsureVisible.duration
andEnsureVisible.curve
as parameters because they should be passed when callingEnsureVisibleState.ensureVisible
. This is not a breaking change. - Made the return type of
EnsureVisibleState.ensureVisible
beFuture<void>
. This is not a breaking change because the previous return type wasvoid
, which you cannot work with. - Made the
enablePulsingAnimation
respond to rebuilds, allowing to change it after the overlay has been shown. - Added GIF demo of the package to the
README.md
file of the package and the example. - Updated example.
- Added
OverflowMode
toREADME.md
. - Added
CONTRIBUTING.md
and mentioned it inREADME.md
.
- Breaking change: Instead of the
icon
parameter, you now need to use thetapTarget
parameter, which takes aWidget
instead ofIconData
. Before:DescribedFeatureOverlay(icon: Icons.add, ..)
After:DescribedFeatureOverlay(tapTarget: const Icon(Icons.add), ..)
- Breaking change:
title
anddescription
parameters now take aWidget
. - Breaking change: Callbacks are now
onOpen
,onDismiss
, andonComplete
.onOpen
andonDismiss
need to returnFuture<bool>
when specified to decide if the step should be open or dismissed respectively. - Fixed
DescribedFeatureOverlay
's constantly rebuilding even if they were never displayed. - Fixed
DescribedFeatureOverlay
's rebuilding after dismissing them. - Warning:
Theme.of(context)
is now used to determine text styles - Title and description can now be null.
- Added option to disable pulsing animation.
- Added parameter that is called when the overlay is dismissed.
- Added parameters to change text color, target color, and icon color.
- Added possibility to pass any
Iterable
for the steps toFeatureDiscovery.discoverFeatures
. - Added the
@required
annotation to parameters that cannot be null. - Ensured that overlay for each step is only shown once at a time.
- Removed unnecessary files.
- Formatted files.
- Updated the plugin description.
- Fixed animation bugs.
- Added
ContentOrientation
.
- Consider landscape and portrait orientation in
DescribedFeatureDiscoveryWidget
.
- Add
EnsureVisible
widget to scroll to target when it is in a scrollable container.
- Applied Pub health suggestions.
- Applied Pub health suggestions.
- Initial release.