An experimental fork of FluffyChat.
Go to file
2020-10-14 04:49:13 +03:00
.github/workflows Make windows build parallel to others 2020-10-09 17:31:41 +03:00
android Fix android notifications, closes #7 2020-10-09 13:05:31 +00:00
assets fix: annoying notification sound 2020-08-23 19:58:14 +02:00
ios Forking out 2020-10-06 22:59:36 +03:00
lib fix formatting 2020-10-14 04:49:13 +03:00
linux Forking out 2020-10-06 22:59:36 +03:00
macos Forking out 2020-10-06 22:59:36 +03:00
snap Initial snapcraft metadata 2020-10-13 10:24:47 +11:00
test Forking out 2020-10-06 22:59:36 +03:00
web update sql-wasm 2020-07-18 16:25:59 +02:00
windows fix: Desktop file picker 2020-10-04 18:38:21 +03:00
.gitignore fix: LocalStorage location on desktop 2020-10-13 12:21:02 +02:00
.gitlab-ci.yml ci: Optimize dependencies 2020-10-12 08:09:47 +00:00
.metadata Initial commit 2020-01-01 19:10:13 +01:00
_config.yml Add license and gitlab pages stuff 2020-01-02 13:42:49 +00:00
analysis_options.yaml Soru/moor 2020-05-13 13:58:59 +00:00
CHANGELOG.md fix: resize images in a separate isolate 2020-10-06 19:17:04 +02:00
CONTRIBUTING.md Add French translations 2020-05-17 08:18:31 +00:00
Dockerfile Fork chores 2020-06-13 22:37:40 +03:00
l10n.yaml fix(l10n): Make en the default fallback language. 2020-10-12 06:44:41 +00:00
LICENSE Add license and gitlab pages stuff 2020-01-02 13:42:49 +00:00
PRIVACY.md Forking out 2020-10-06 22:59:36 +03:00
pubspec.lock Merge branch 'main' of https://gitlab.com/ChristianPauly/fluffychat-flutter into yiffed 2020-10-14 04:47:54 +03:00
pubspec.yaml Merge remote-tracking branch 'upstream/main' into yiffed 2020-10-11 17:47:09 +03:00
README.md Merge branch 'main' of https://gitlab.com/ChristianPauly/fluffychat-flutter into yiffed 2020-10-14 04:47:54 +03:00

FurryChat

An experimental fork of FluffyChat.

Changes from FluffyChat

  • Reworked auth flow
  • Removed Sentry
  • Double check of .well-known
  • Get Jitsi instance from .well-known
  • Redesigned settings

Features

  • Single and group chats
  • Send images and files
  • Voice messages
  • Offline chat history
  • Push Notifications
  • Account settings
  • Display user avatars
  • Themes, chat wallpapers and dark mode
  • Device management
  • Edit chat settings and permissions
  • Kick, ban and unban users
  • Display and edit chat topics
  • Change chat & user avatars
  • Archived chats
  • Discover public chats on the user's homeserver
  • Registration
  • Disable account
  • Change password
  • End-To-End-Encryption

How to build

  1. Install flutter

  2. Clone the repo:

git clone --recurse-submodules https://gitlab.com/ChristianPauly/fluffychat-flutter
cd fluffychat-flutter
  1. Choose your target platform below and enable support for it.

  2. Debug with: flutter run

Android

  • Install CMake from the SDK Manager

  • Install ninja:

sudo apt install ninja-build
  • Outcomment the Google Services plugin at the end of the file android/app/build.gradle:
// apply plugin: "com.google.gms.google-services"
  • Build with: flutter build apk

iOS / iPadOS

  • With xcode you can't build a release version without our cert. :-/ Use flutter run --profile to have a working version on your iOS device.

Web

Desktop (Linux, Windows, macOS)

flutter build linux --release
flutter build windows --release
flutter build macos --release

Docker

Don't even ask.

docker run -ti --privileged -v /dev/bus/usb:/dev/bus/usb -v ${PWD}:/build -v /home/inex/.pub-cache:/home/inex/.pub-cache -v /home/inex/flutter:/home/inex/flutter -d flutter-fluffy:1.0

How to add translations for your language

You can use Weblate to translate the app to your language:

https://hosted.weblate.org/projects/fluffychat/

  1. Replace the non-translated string in the codebase:
Text("Hello world"),

with a method call:

Text(L10n.of(context).helloWorld),

and add the following import if missing:

import 'package:flutter_gen/gen_l10n/l10n.dart';
  1. Add the string to /lib/l10n/l10n_en.arb:

(The following example need to be sorounded by the usual json {} and after the @@locale key)

Example A:

"helloWorld": "Hello World!",
"@helloWorld": {
  "description": "The conventional newborn programmer greeting"
}

Example B:

"hello": "Hello {userName}",
"@hello": {
  "description": "A message with a single parameter",
  "placeholders": {
    "userName": {
      "type": “String”,
      “example”: “Bob”
    }
  }
}
  1. For testing just run a regular build without extras

Special thanks to

  • Fabiyamada is a graphics designer from Brasil 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.

  • Thanks to Mark for all his support and the chat background.

  • Also thanks to all translators and testers! With your help, fluffychat is now available in more than 12 languages.