README.md
			
		
		
			
			
		
	
	FluffyChat is an open source, nonprofit and cute [matrix] client written in Flutter. The goal of the app is to create an easy to use instant messenger which is open source and accessible for everyone.
Links:
- 🌐 [Weblate] Translate FluffyChat into your language
- 🌍 [m] Join the community
- 📰 [Mastodon] Get updates on social media
- 🖥️ [Famedly] Server hosting and professional support
- 💝 [Liberapay] Support FluffyChat development
Screenshots:
 
 
Features
- 📩 Send all kinds of messages, images and files
- 🎙️ Voice messages
- 📍 Location sharing
- 🔔 Push notifications
- 💬 Unlimited private and public group chats
- 📣 Public channels with thousands of participants
- 🛠️ Feature rich group moderation including all matrix features
- 🔍 Discover and join public groups
- 🌙 Dark mode
- 🎨 Material You design
- 📟 Hides complexity of Matrix IDs behind simple QR codes
- 😄 Custom emotes and stickers
- 🌌 Spaces
- 🔄 Compatible with Element, Nheko, NeoChat and all other Matrix apps
- 🔐 End to end encryption
- 🔒 Encrypted chat backup
- 😀 Emoji verification & cross signing
... and much more.
Installation
Please visit the website for installation instructions:
How to build
git clone https://github.com/krille-chan/fluffychat.git
cd fluffychat
- Choose your target platform below and enable support for it. 3.1 If you want, enable Googles Firebase Cloud Messaging:
git apply ./scripts/enable-android-google-services.patch
- Debug with: flutter run
Android
- Build with: flutter build apk
iOS / iPadOS
- Have a Mac with Xcode installed, and set up for Xcode-managed app signing
- If you want automatic app installation to connected devices, make sure you have Apple Configurator installed, with the Automation Tools (cfgutil) enabled
- Set a few environment variables
- FLUFFYCHAT_NEW_TEAM: the Apple Developer team that your certificates should live under
- FLUFFYCHAT_NEW_GROUP: the group you want App IDs and such to live under (ie: com.example.fluffychat)
- FLUFFYCHAT_INSTALL_IPA: set to 1if you want the IPA to be deployed to connected devices after building, otherwise unset
 
- Run ./scripts/build-ios.sh
Web
- Build with:
./scripts/prepare-web.sh # To install Vodozemac
flutter build web --release
- Optionally configure by serving a config.jsonat the same path as fluffychat. An example can be found atconfig.sample.json. All values there are optional. Please only the values, you really need. If you e.g. only want to change the default homeserver, then only modify thedefaultHomeserverkey.
Desktop (Linux, Windows, macOS)
- Enable Desktop support in Flutter: https://flutter.dev/desktop
Install custom dependencies (Linux)
sudo apt install libjsoncpp1 libsecret-1-dev libsecret-1-0 librhash0 libwebkit2gtk-4.0-dev
- Build with one of these:
flutter build linux --release
flutter build windows --release
flutter build macos --release
Special thanks
- 
Fabiyamada is a graphics designer and has made the fluffychat logo and the banner. Big thanks for her great designs. 
- 
Advocatux has made the Spanish translation with great love and care. He always stands by my side and supports my work with great commitment. 
- 
Thanks to MTRNord and Sorunome for developing. 
- 
Also thanks to all translators and testers! With your help, fluffychat is now available in more than 12 languages. 
- 
WoodenBeaver sound theme for the notification sound. 
- 
The Matrix Foundation for making and maintaining the emoji translations used for emoji verification, licensed Apache 2.0 

