expandable_text

Creator: coderz1093

Last updated:

Add to Cart

Description:

expandable text

This Flutter package includes the widget ExpandableText which you can use to initially only show a
defined number of lines of a probably long text. The widget appends a configurable text link which
lets the user expand the full text, or collapse it again.

Getting started #
Add this to your package's pubspec.yaml file:
dependencies:
expandable_text: 2.3.0
copied to clipboard
Next, import the package into your dart code:
import 'package:expandable_text/expandable_text.dart';
copied to clipboard
Usage #
Show an expandable text if longText exceeds one line:
Widget build(BuildContext context) {
return ExpandableText(
longText,
expandText: 'show more',
collapseText: 'show less',
maxLines: 1,
linkColor: Colors.blue,
);
}
copied to clipboard
Advanced example
This example shows a message that was posted by a user.
The username is always visible right before the text and tapping on it opens the user profile.
The text is truncated after two lines and can be expanded by tapping on the link show more at the end or the text itself.
After the text was expanded it cannot be collapsed again as no collapseText was provided.
URLs, @mentions and #hashtags in the text are styled differently and can be tapped to open the browser or the user profile.
Widget build(BuildContext context) {
return ExpandableText(
message,
expandText: 'show more',
maxLines: 2,
linkColor: Colors.blue,
animation: true,
collapseOnTextTap: true,
prefixText: username,
onPrefixTap: () => showProfile(username),
prefixStyle: TextStyle(fontWeight: FontWeight.bold),
onHashtagTap: (name) => showHashtag(name),
hashtagStyle: TextStyle(
color: Color(0xFF30B6F9),
),
onMentionTap: (username) => showProfile(username),
mentionStyle: TextStyle(
fontWeight: FontWeight.w600,
),
onUrlTap: (url) => launchUrl(url),
urlStyle: TextStyle(
decoration: TextDecoration.underline,
),
);
}
copied to clipboard
Features #

Link to expand the collapsed text (expandText)
Expand and collapse animation (animation, animationDuration, animationCurve)
Optional link to collapse the expanded text (collapseText)
Configure the style of the link (linkStyle / linkColor)
Control whether the ellipsis is part of the link (linkEllipsis)
Optional prefix text with style and tap callback (prefixText, prefixStyle, onPrefixTap)
Text with tappable and styled links (onUrlTap, urlStyle)
Text with tappable and styled @mentions (onMentionTap, mentionStyle)
Text with tappable and styled #hashtags (onHashtagTap, hashtagStyle)
Configure the number of visible lines of the collapsed text (maxLines)
Control the default expanded state (expanded, onLinkTap)
Callback for expanded changed event (onExpandedChanged)
Tap on the text to expand or collapse the text (expandOnTextTap, collapseOnTextTap)

Bugs and feature requests #
Have a bug or a feature request? Please first search for existing and closed issues.
If your problem or idea is not addressed yet, please open a new issue.
Copyright & License #
Code copyright 2020–2022 Florian Weinaug.
Code released under the MIT license.

License

For personal and professional use. You cannot resell or redistribute these repositories in their original state.

Customer Reviews

There are no reviews.