๐ฉ Flutter Extend โ The Magical Extensions Toolbox!
๐ Welcome to the ultimate Flutter cheat code! This package brings you a collection of mind-blowing extensions that'll make your development experience smoother than a buttered-up otter sliding down a rainbow. ๐โจ
๐ Why Should You Care?
Because Flutter Extend makes your life easier, that's why! Instead of writing boring repetitive code, let these extensions do the heavy lifting while you sip on your coffee โ (or energy drink, we donโt judge).
๐ Save time โ Fewer lines of code, more time for memes.
๐ Write cleaner code โ Your future self will thank you.
๐ง Look like a coding wizard โ Impress your teammates.
โ๏ธ Installation โ Get Started Faster than a Cheetah on Roller Skates
- Summon Flutter Extend into your project by adding this to your pubspec.yaml:
dependencies:
  flutter_extend: ^0.0.6
- Run this spell in your terminal:
flutter pub get
- Import the package and start your journey to developer enlightenment:
import 'package:flutter_extend/flutter_extend.dart';
BOOM. ๐ฅ Youโre now 10x more powerful (results may vary).
๐คฏ Behold, The Extensions That Will Blow Your Mind!
๐จ Color Extensions โ For When You Need to Make Things Pretty
Global Color Extensions (Click to open)
| Extension | Description | 
|---|---|
| Colors.red.getLighterShade(10) | Turns red into diet red (10% lighter)! | 
| Colors.red.toHex() | Converts red into that fancy #FF0000 format. | 
๐ฅ No more googling โFlutter color to hexโ like a caveman.
๐ Context Extensions โ Your Appโs Sixth Sense
๐ง Context Extensions (Click to reveal the magic!)
| Extension | Description | 
|---|---|
| context.colorScheme | Knows what colors your app is vibing with. ๐จ | 
| context.isDarkMode | Detects if your app has gone full Sith mode. ๐ | 
| context.screenHeight | Measures how tall your app stands. ๐ | 
| context.screenWidth | Measures the width, because size matters. ๐ | 
| context.theme | Retrieves the whole theme like a style guru. ๐ | 
๐ก These context extensions always know whatโs up (literally).
๐ DateTime Extensions โ Manipulate Time Like Doctor Strange
โณ DateTime Comparison Extensions (Click to open)
| Extension | What It Does | 
|---|---|
| .isToday() | Is todayโฆ today? ๐ค | 
| .isPast() | Confirms if your date is ancient. ๐ | 
| .isFuture() | Predicts the futureโฆ kinda. ๐ฎ | 
| .isYesterday() | Checks if it was Laundry Day. | 
| .isTomorrow() | Future You says hello. ๐ | 
๐๏ธ DateTime Formatting Extensions (Click to open)
| Extension | Example | Output | 
|---|---|---|
| .timeAgo() | DateTime(2024, 1, 1).timeAgo() | "1 year ago" | 
| .timeUntil() | DateTime(2026, 1, 1).timeUntil() | "in 1 year" | 
| .monthName() | DateTime(2024, 1, 1).monthName() | "January" | 
| .monthNameShort() | DateTime(2024, 1, 1).monthNameShort() | "Jan" | 
| .dayName() | DateTime(2024, 1, 1).dayName() | "Monday" | 
| .dayNameShort() | DateTime(2024, 1, 1).dayNameShort() | "Mon" | 
| .slashedDate() | DateTime(2024, 1, 1).slashedDate() | "01/01/2024" | 
| .weekNumber() | DateTime(2024, 1, 1).weekNumber() | 1 | 
๐ ๏ธ DateTime Manipulation Extensions (Click to open)
| Extension | Example | Output | 
|---|---|---|
| .addDays(days) | DateTime(2025, 1, 1).addDays(5) | DateTime(2025, 1, 6) | 
| .subtractDays(days) | DateTime(2025, 1, 1).subtractDays(5) | DateTime(2024, 12, 27) | 
| .addMonths(months) | DateTime(2025, 1, 1).addMonths(5) | DateTime(2025, 6, 1) | 
| .subtractMonths(months) | DateTime(2025, 1, 1).subtractMonths(5) | DateTime(2024, 8, 1) | 
| .addYears(years) | DateTime(2025, 1, 1).addYears(5) | DateTime(2030, 1, 1) | 
| .subtractYears(years) | DateTime(2025, 1, 1).subtractYears(5) | DateTime(2020, 1, 1) | 
| .addBusinessDays(days) | DateTime(2025, 1, 1).addBusinessDays(5) | DateTime(2025, 1, 8) | 
๐ Master time manipulation and become the Flutter Time Lord!
๐ File Extensions โ Handle Files Like a Pro!
๐ File Extensions (Click to open)
| Extension | Example | Output | 
|---|---|---|
| .fileFormattedSize() | File('path').fileFormattedSize() | 500 MB | 
| .filePath() | File('path').filePath() | /emulated/0/storage... | 
| .fileExtension() | File('path').fileExtension() | pdf, jpg, etc. | 
| .fileNameWithoutExtension() | File('path').fileNameWithoutExtension() | myAwesomeFile | 
๐๏ธ Stop wrestling with file paths like itโs 1999!
๐ฆ Generator Extensions โ Auto-Magic String Generation!
NB: String generator methods should be used on Empty Strings for the best results.
๐ String Generator Extensions (Click to open)
| Extension | Example | Output | 
|---|---|---|
| .generateLoremIpsum(wordCount) | "".generateLoremIpsum(wordCount: 5) | Lorem ipsum dolor sit amet | 
| .generateUUID(length) | "".generateUUID(length: 10) | Random UUID | 
| .generateClipboardContents(textIfNull) | "".generateClipboardContents() | Returns a String clipboard contents | 
| .generateRandomString(length) | "".generateRandomString(10) | Random 10-character string | 
๐ Because manually typing random text is so last year!
๐ List Extensions โ Sorting, Chunking, and More!
๐ List Extensions (Click to open)
| Extension | Example | Output | 
|---|---|---|
| .firstOrNull() | "hello", "world", "awesome".firstOrNull() | hello | 
| .lastOrNull() | "hello", "world", "awesome".lastOrNull() | awesome | 
| .sortBy() | "Urus", "BMW", "Aston Martin", "Ferari", "Lambo".sortBy((car) => car) | "Aston Martin", "BMW", "Ferari", "Lambo", "Urus" | 
| .sortByAndReturnSorted() | "Urus", "BMW", "Aston Martin", "Ferari", "Lambo".sortByAndReturnSorted((car) => car) | "Aston Martin", "BMW", "Ferari", "Lambo", "Urus" | 
| .shuffled() | "Urus", "BMW", "Aston Martin", "Ferari", "Lambo".shuffled() | "Ferari", "Aston Martin", "BMW", "Lambo", "Urus" | 
| .chunked(size) | "Urus", "BMW", "Aston Martin", "Ferari", "Lambo".chunked(2) | [ 'Urus', 'BMW','Aston Martin', 'Ferari','Lambo'] | 
๐ Because sorting lists manually is for mere mortals!
๐ข Number Extensions โ Math is Hard, Letโs Make It Easy
๐ Number Duration Extensions
| Extension | Example | Output | 
|---|---|---|
| .days | 5.days | Duration(days: 5) | 
| .hours | 5.hours | Duration(hours: 5) | 
| .mins | 5.mins | Duration(minutes: 5) | 
| .secs | 5.secs | Duration(seconds: 5) | 
| .milliSecs | 5.milliSecs | Duration(milliSeconds: 5) | 
| .microSecs | 5.microSecs | Duration(microSeconds: 5) | 
๐ฐ Number Currency Extensions
| Extension | Example | Output | 
|---|---|---|
| .toCurrency() | 100000.toCurrency() | KES 100,000 | 
| .toAbbreviated() | 100000.toAbbreviated() | 100K | 
๐ง Because numbers should work for you, not the other way around.
๐ค String Extensions โ Tame Your Text Like a Pro!
๐ Validation String Extensions (Click to open)
| Extension | Example | Output | 
|---|---|---|
| .isEmailValid() | "badEmail.com".isEmailValid() | false | 
| .isPasswordValid() | "weak12".isPasswordValid() | false | 
| .isValidURL() | "weirdurl//".isValidURL() | false | 
๐ Global String Extensions (Click to open)
| Extension | Example | Output | 
|---|---|---|
| .capitalizeFirstLetter() | "hello".capitalizeFirstLetter() | Hello | 
| .capitalizeFirstLetterOfEachWord() | "hello world".capitalizeFirstLetterOfEachWord() | Hello World | 
| .getLastNCharacters(n) | "hello".getLastNCharacters(2) | lo | 
| .mask(visibleCount) | "helloworld".mask() | he******ld | 
| .reverse() | "hello".reverse() | olleh | 
| .truncateName() | "Ken Starry".truncateName() | Ken S. | 
๐ต๏ธ Regex String Extensions (Click to open)
| Extension | Example | Output | 
|---|---|---|
| .extractDigits() | "abc123".extractDigits() | "123" | 
| .removeAllDigits() | "abc123".removeAllDigits() | "abc" | 
| .removeAllWordsStartingWithNumber() | "1abc 2def ghi".removeAllWordsStartingWithNumber() | "ghi" | 
| .isDigitsOnly() | "12345".isDigitsOnly() | true | 
| .isTextOnly() | "abc".isTextOnly() | true | 
| .removeAllWhiteSpaces() | "a b c".removeAllWhiteSpaces() | "abc" | 
| .getWords() | "Hello world!".getWords() | ["Hello", "world"] | 
๐ข String Formatter Extensions (Click to open)
| Extension | Example | Output | 
|---|---|---|
| .capitalizeFirstLetter() | 'hello'.capitalizeFirstLetter() | 'Hello' | 
| .toTitleCase() | 'hello world'.toTitleCase() | 'Hello World' | 
| .toCamelCase() | 'hello_world'.toCamelCase() | 'helloWorld' | 
| .toSlug() | 'Hello World!'.toSlug() | 'hello-world' | 
| .toOrdinal() | '23'.toOrdinal() | '23rd' | 
| .toBase64() | 'Hello'.toBase64() | 'SGVsbG8=' | 
| .fromBase64() | 'SGVsbG8='.fromBase64() | 'Hello' | 
๐ฐ String Currency Extensions
| Extension | Example | Output | 
|---|---|---|
| .thousandNumberFormat | '100000'.thousandNumberFormat | '100,000' | 
| .cleanNumbers | '100,000'.cleanNumbers | '100000' | 
๐ Say goodbye to messy text handling forever!
๐ผ๏ธ Widget Extensions โ Supercharge Your Widgets!
๐งฉ Widget Extensions (Click to open)
| Extension | Example | Output | 
|---|---|---|
| clickableMouse | Text('Click me').clickableMouse(onTap: () { print('Clicked'); }) | A text widget that shows a mouse pointer on hover and prints 'Clicked' on tap. | 
| expanded | Text('Expanded').expanded() | A text widget wrapped with an Expandedwidget. | 
| flexibe | Text('Flexible').flexibe() | A text widget wrapped with a Flexiblewidget. | 
| padding | Text('Padded').padding(padding: EdgeInsets.all(16)) | A text widget with 16 pixels of padding on all sides. | 
| align | Text('Aligned').align(alignment: Alignment.centerRight) | A text widget aligned to the center right of its parent. | 
| clip | Image.network('url').clip(borderRadius: BorderRadius.circular(8)) | An image widget clipped with an 8-pixel border radius. | 
| removeScrollbar | ListView().removeScrollbar(context) | A ListViewwithout a scrollbar. | 
| addScrollbar | ListView().addScrollbar(context) | A ListViewwith a scrollbar. | 
| visibility | Text('Visible').visibility(visible: false) | A text widget that is not visible. | 
| invinsible | Text('Invisible').invinsible() | A text widget that is not visible. | 
| visible | Text('Visible').visible() | A text widget that is visible. | 
| addSelectionArea | Text('Selectable').addSelectionArea() | A text widget that can be selected. | 
| center | Text('Centered').center() | A text widget centered within its parent. | 
๐ ๏ธ Scaffold Extensions (Click to open)
| Extension | Example | Output | 
|---|---|---|
| .addAnnotatedRegion() | Scaffold().addAnnotatedRegion(statusBarColor: Colors.red, statusBarBrightness: Brightness.dark, navigationBarColor: Colors.blue, navigationBarBrightness: Brightness.light) | A Scaffoldwidget with customized status bar and navigation bar colors and brightness. | 
๐ Text Extensions (Click to open)
| Extension | Example | Output | 
|---|---|---|
| .addHyperLinks | Text('Click here for more info').addHyperLinks(hyperLinkTexts: ['here'], onHyperlinkClicked: (word) => {}) | A Textwidget with the word "here" as a hyperlink that triggers theonHyperlinkClickedfunction. | 
๐๏ธ Make your widgets do more with less code!
โณ Coming Soon โ The Future is Bright!
๐ฆ Animation Extensions โ Because Motion is Magic!
(Coming soonโฆ if I ever stop procrastinating.)
๐ Future Extensions โ Async Like a Boss!
(Coming soonโฆ after I finish scrolling through cat videos.)
๐ญ Widget Generators โ The Magic is Brewing! โ๐ฎ
(Coming soon... currently summoning the code wizards for this one. ๐งโโ๏ธโจ)
๐ค Contributors
A huge shoutout to the amazing people who have contributed to making Flutter Extend even more awesome! ๐
๐ฅ Want to Contribute?
๐ Found something cool to add? Please read our Contribution Guidelines before making a pull request.
๐พ Join the Fun! We love developers who break things (and then fix them).
๐ Useful Links โ Because Youโll Need โEm
๐ Package on pub.flutter-io.cn
๐ GitHub Repo
๐ Flutter Documentation
๐ Dart Documentation
Examples
๐ Enough talk, time for action! Want to see these extensions in action? Head over to our **examples directory ** directory and witness the magic firsthand! โจ ๐ See. Try. Enjoy. Repeat.
(Warning: May cause extreme excitement and spontaneous coding sprees.) ๐
๐ License โ Go Wild!
This package is licensed under MIT, meaning you can use it, modify it, and show it off to your friends. ๐
๐ Thatโs it, folks! Now go forth and write Flutter code like an absolute legend. ๐๐

