Frosty
A mobile Twitch client for iOS and Android with 7TV, BetterTTV (BTTV), and FrankerFaceZ (FFZ) support.
The official Twitch mobile app doesn't support emotes from [7TV](https://chrome.google.com/webstore/detail/7tv/ammjkodgmmoknidbanneddgankgfejfh), [BetterTTV (BTTV)](https://chrome.google.com/webstore/detail/betterttv/ajopnjidmegmdimjlfnijceegpefgped), and [FrankerFaceZ (FFZ)](https://chrome.google.com/webstore/detail/frankerfacez/fadndhdgpmmaapbmfcknlfgcflmmmieb) — third-party extensions for Twitch used by millions. As a result, only emote text names are rendered rather than their actual image o... The project is written primarily in Dart, distributed under the GNU Affero General Public License v3.0 license, first published in 2021. It has gained significant community traction with 1,017 stars and 68 forks on GitHub. Key topics include: actions, android, chat, chat-application, dart.
Download
<p> <a href="https://apps.apple.com/us/app/frosty-for-twitch/id1603987585"> <img title="Get it on iOS (Apple App Store)" alt="Apple App Store badge." src="https://user-images.githubusercontent.com/54859075/160051843-1d8b2186-97e9-4edd-a957-bb4797b71b4a.svg" width="200px" /> </a> <a href="https://play.google.com/store/apps/details?id=com.tommychow.frosty"> <img title="Get it on Android (Google Play Store)" alt="Google Play Store badge." src="https://user-images.githubusercontent.com/54859075/160051854-21a57556-6b5a-41e9-8127-334daf1fac47.svg" width="225px" /> </a> </p>Why
The official Twitch mobile app doesn't support emotes from 7TV, BetterTTV (BTTV), and FrankerFaceZ (FFZ) — third-party extensions for Twitch used by millions. As a result, only emote text names are rendered rather than their actual image or GIF, making the chat unreadable in many channels.
Features
- Support for 7TV, BetterTTV, and FrankerFaceZ emotes and badges
- Browse followed streams, top streams, and top categories
- Autocomplete for emotes and user mentions
- Light, dark, and black (OLED) themes
- Search for channels and categories
- See and filter chatters in a channel
- Local chat user message history
- Theater and fullscreen mode
- Watch live streams with chat
- Picture-in-picture mode
- Block and report users
- Emote menu
- Sleep timer
- And more...
For a more detailed overview, visit frostyapp.io.
Development setup
-
Clone this repo (e.g.,
git clone https://github.com/tommyxchow/frosty.git). -
Go to the Twitch dev console and register a new application to retrieve a Client ID and Client Secret.
-
Copy
.env.exampleto.envand fill in your credentials:bashcp .env.example .env -
Run
flutter pub getto fetch all the dependencies. -
Choose an emulator or device and run the app! The included VS Code launch configurations will automatically read your
.envfile. -
(Optional) Run
dart run scripts/get_twitch_token.dartto quickly get a user auth token. Long-press the Anonymous account tile in the app to log in.
[!IMPORTANT]
Frosty uses MobX for state management. Please refer to the documentation about code generation, otherwise your changes within MobX stores may not be applied.
Donate
If you appreciate my work and would like to donate/tip, you can through:
Otherwise, downloading Frosty, leaving a review, or starring this repository is more than enough to show support. Thank you!
License
Frosty is licensed under AGPL-3.0-or-later.
Contributors
Showing top 7 contributors by commit count.
