๐ฉ 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 | Example | 
|---|---|---|
| .getLighterShade(percent) | Turns red into diet red (10% lighter)! | Colors.red.getLighterShade(10) | 
| .isDark | Checks if the color is dark. ๐ | Colors.red.isDark | 
| .isLight | Checks if the color is light. ๐ | Colors.red.isLight | 
| .luminance | Computes the luminance to determine brightness. ๐ | Colors.red.luminance | 
| .toHex() | Converts red into that fancy #FF0000 format. | Colors.red.toHex() | 
๐ฅ No more googling โFlutter color to hexโ like a caveman.
๐ Context Extensions โ Your Appโs Sixth Sense
๐ง Global Context Extensions
| Extension | Description | 
|---|---|
| context.hideKeyboard() | Hides the keyboard when needed. โจ๏ธ | 
| context.safeSetState(callback) | Performs safe setState operations. ๐ท๏ธ | 
๐ฑ MediaQuery Context Extensions
| Extension | Description | 
|---|---|
| context.isDarkMode | Detects if your app has gone full Sith mode. ๐ | 
| context.screenSize | Retrieves the full screen size. ๐ | 
| 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. ๐ | 
| context.safePadding | Retrieves the safe padding from MediaQuery. ๐๏ธ | 
| context.orientation | Gets the screen orientation. ๐ | 
| context.brightness | Checks platform brightness. ๐ | 
| context.isKeyboardVisible | Detects if the keyboard is on screen. โจ๏ธ | 
| context.isLandscape | Detects if the device is in landscape mode. ๐ข | 
| context.isPortrait | Detects if the device is in portrait mode. ๐ | 
โ๏ธ Navigator Context Extensions
| Extension | Description | 
|---|---|
| context.navigateTo(page) | Simplifies navigation to a new screen. ๐ | 
| context.popScreen() | Pops the current screen from the stack. โ๏ธ | 
๐ป Platform Context Extensions
| Extension | Description | 
|---|---|
| context.isIOS | Checks if the platform is iOS. ๐ | 
| context.isAndroid | Checks if the platform is Android. ๐ฑ | 
| context.isWindows | Checks if the platform is Windows. ๐ฅ๏ธ | 
| context.isMacOS | Checks if the platform is macOS. ๐ป | 
| context.isLinux | Checks if the platform is Linux. ๐ | 
| context.isFuchsia | Checks if the platform is Fuchsia. ๐ถ | 
๐๏ธ Theme Context Extensions
| Extension | Description | 
|---|---|
| context.theme | Retrieves the whole theme like a style guru. ๐ | 
| context.textTheme | Retrieves the text theme of the app. ๐๏ธ | 
| context.colorScheme | Retrieves the color scheme of the app. ๐ | 
| context.iconTheme | Retrieves the icon theme data. ๐ | 
๐ก 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!
๐ Future Extensions โ Async Like a Boss!
๐ก Tired of waiting for your Futures like they're stuck in dial-up internet? Say hello to instant gratification! These extensions turn async from a patience test into a speedrun to successโno more unnecessary delays, retries, or timeout meltdowns!
๐ฐ๏ธ Future Extensions (Click to reveal the magic)
| Extension | What It Does (In Normal-Person Terms) | Example | 
|---|---|---|
| .wrapInCompleter() | Turns your Future into a Completer like a pro. | myFuture.wrapInCompleter() | 
| .isComplete() | Checks if a Future is donezo or still playing hard to get. | myFuture.isComplete() | 
| .retry(retries, delay) | Gives your Future extra lives (great for network calls). | myFuture.retry(3, delay: Duration(seconds: 2)) | 
| .timeoutWithFallback(timeout, fallbackValue) | Stops waiting after a timeout and gives a backup plan. | myFuture.timeoutWithFallback(Duration(seconds: 5), fallbackData) | 
| .runAfterDelay(delay) | Hits snooze before running the Future. | myFuture.runAfterDelay(Duration(seconds: 2)) | 
๐ Future Iterable Extensions (Click to reveal the magic)
| Extension | What It Does (In Normal-Person Terms) | Example | 
|---|---|---|
| .runWithLimit(limit) | Runs multiple Futures at once, but limits how many run simultaneously. | myFutures.runWithLimit(3) | 
| .runWithLimitOrdered(limit) | Runs multiple Futures in order, with limited concurrent executions. | myFutures.runWithLimitOrdered(2) | 
๐ String Future Extensions (Click to reveal the magic)
| Extension | What It Does (In Normal-Person Terms) | Example | 
|---|---|---|
| .copyToClipboard() | Copies a string to the clipboard like a sneaky ninja. | await 'Hello, world!'.copyToClipboard() | 
๐ฅ Wave goodbye to async chaos and say hello to Future-powered hyperspeed! No more waiting in the async DMV lineโyour code is now on rollerblades. ๐ผโก
๐ฆ 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) | 
| .minutes | 5.minutes | Duration(minutes: 5) | 
| .seconds | 5.seconds | Duration(seconds: 5) | 
| .milliSeconds | 5.milliSeconds | Duration(milliSeconds: 5) | 
| .microSeconds | 5.microSeconds | 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.)
๐ญ 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. ๐๐


