Giter Site home page Giter Site logo

mliq / ferdi Goto Github PK

View Code? Open in Web Editor NEW

This project forked from nfsergiu/ferdi

0.0 1.0 0.0 23.4 MB

πŸ§”πŸ½ Community fork of @meetfranz. Ferdi allows you to combine your favourite messaging services into one application

Home Page: https://getferdi.com/

License: Apache License 2.0

JavaScript 83.91% HTML 0.28% CSS 6.33% TypeScript 9.47%

ferdi's Introduction

Ferdi

Open Collective backers Open Collective sponsors Build Status Windows Build Status Mac & Linux

🀴🏽 Hard-fork of Franz, adding awesome features and removing unwanted ones.

Table of contents

Toggle navigation

What is Ferdi?

Ferdi is a messaging browser that allows you to combine your favorite messaging services into one application. It is based on Franz - a software already used by thousands of people - with the difference that Ferdi gives you many additonal features and doesn't restrict its usage! Ferdi is compatible with your existing Franz account so you can continue right where you left off. Find out more about Ferdi and its features on getferdi.com.

What does Ferdi look like?

Toggle screenshots

Keep all your messaging services in one place. "Keep all your messaging services in one place." Order your services with Ferdi Workspaces. "Order your services with Ferdi Workspaces." Always keep your Todo list open with Ferdi Todos. "Always keep your Todo list open with Ferdi Todos." Supporting all your services. "Supporting all your services."

Download Ferdi

You can find the installers in the latest stable release assets and all the other release here.

Or use homebrew (macOS only)

$ brew cask install ferdi

(Don't know homebrew? brew.sh)

Or use AUR (Arch Linux)

Ferdi has two seperate AUR packages you can use:

  • ferdi-bin: Uses your debian build and extracts it to Arch
  • ferdi-git: Uses system electron version

If you use an AUR Helper e.g. yay, simply install it via yay -S ferdi-bin.

ferdi-git may not work on all systems so we advice you to use ferdi-bin instead.

Ferdi-specific Features

  • Removes the counter-productive fullscreen app delay inviting users to upgrade
  • Removes pages begging you to donate after registration
  • Remove "Franz is better together" popup
  • Remove bug that would incorrectly display unread messages count on some services (more info in 7566ccd)
  • Makes all users Premium by default (#15)
  • Using the Ferdi API instead of Franz's servers
  • Upgrading to Electron 7
  • Add several new services
  • Add option to change server to a custom ferdi-server
  • Add option to use Ferdi without an account (#5)
  • Add "Private Notification"-Mode, that hides message content from notifications (franz#879)
  • Add Password Lock feature to keep your messages protected (#41, franz#810, franz#950, franz#1430)
  • Add an option to keep individual workspaces always loaded (#37)
  • Add Universal Dark Mode via the DarkReader extension (#71)
  • Add adaptable Dark Mode that will respect the system's Dark Mode setting (#173)
  • Add an option to auto-hide the menubar (#7, franz#833)
  • Add "Quick Switch" feature to help you navigate a long list of services (similar to Rambox's Quick Switcher)
  • Add "Service Hibernation" that will automatically unload services when they are unused
  • Add "Scheduled Do-not-Disturb" feature in which you won't get notifications (similar to Rambox's Work Hours)
  • Add CTRL+← and CTRL+β†’ shortcuts and menu options to go back and forward in the service browsing history(#39)
  • Add option to show a browser-like navigation bar on all services
  • Add option to change accent color
  • Add local recipe repository that removes the need of downloading recipes from a remote server
  • Add portable version for Windows
  • Add Process Manager to find services using a lot of resources
  • Add "npm run prepare-code" command for development to lint and beautify code
  • Add button to open darkmode.css for a service
  • Allow SVGs for service custom icon
  • Switch to electron-spellchecker to improve application size
  • Improve "About Ferdi" screen to better display versions
  • Minifying build files to improve app size
  • Makes it possible to edit the "Franz Todo" server
  • Makes RocketChat self-hosted generally available (#6)
  • Comes with a custom branding proper to Ferdi
  • UI improvements

Development

Install OS dependencies

Node.js

Please make sure you are running NodeJS v10 (v10.16.3 suggested). Versions above will throw an errow when trying to install due to an old fsevent dependency.

Git

The version 2.23.0 for Git is working fine for development. You can then use the console from Git to do the development procedure.

Debian/Ubuntu

$ apt install libx11-dev libxext-dev libxss-dev libxkbfile-dev

Fedora

$ dnf install libX11-devel libXext-devel libXScrnSaver-devel libxkbfile-devel

Windows

$ npm install --global windows-build-tools --vs2015

Clone repository with submodule

$ git clone https://github.com/getferdi/ferdi.git
$ cd ferdi
$ git submodule update --init --recursive

It is important you execute the last command to get the required submodules (recipes, server).

Install dependencies

Run the following command to install all dependencies, and link sibling modules with Ferdi.

$ npx lerna bootstrap

If you previously ran npm install it sometimes is necessary to delete your node_modules folder before running npx lerna bootstrap.

Fix native modules to match current electron node version

$ npm run rebuild

Start development app

Run these two commands simultaneously in different console tabs:

$ npm run dev
$ npm run start

Be aware that the development database will be reset regularly.

Packaging

$ npm run build

Deliverables will be available in the out folder.

Release

$ git checkout develop && git pull
$ git submodule update --remote --force
$ git add .
$ git commit -m "Update submodules"
$ git checkout master
$ git merge --no-ff develop
$ git tag v5.3.4-beta.4
$ git push --tags

When pushing a new tag, the CI builds will create a draft GitHub release and upload the deliverables in the draft release assets. Wait for all the assets to be uploaded before publishing the draft release.

Contributors ✨

Thanks goes to these wonderful people (emoji key):


Bennett

πŸ’» 🎨 πŸ“– πŸ€” 🌍 πŸ’‘ πŸ› πŸ–‹ πŸš‡ πŸ““ πŸ’¬ πŸ“† πŸ‘€

Stefan Malzner

πŸ’» πŸ–‹ 🎨 πŸ“– πŸ€” πŸš‡ πŸ“† ⚠️ 🌍

Amine Mouafik

πŸ’¬ πŸ’» πŸ“– πŸ€” 🚧 πŸ“¦ πŸ“† πŸ‘€ πŸš‡ πŸ” πŸ“

ZeroCool

πŸ’» πŸ€”

rseitbekov

πŸ’»

Peter Bittner

πŸ€” πŸ›

Justus Saul

πŸ› πŸ€”

igreil

πŸ€”

Marco Lopes

πŸ€”

dayzlun

πŸ›

Tobias GΓΌnther

πŸ€”

AGCaesar

πŸ“¦

Makazzz

πŸ› πŸ’» 🌍 πŸ–‹ πŸ“– πŸ“¦

xthursdayx

πŸ’» πŸ“– πŸš‡ πŸ“¦

Gaboris

πŸ’¬ πŸ›

Ce

πŸ›

Stanislav N.

πŸ›

Patrick Curl

πŸ€”

Benjamin Staneck

🎨

ammarmalhas

πŸ› πŸ›‘οΈ

Steliyan Stoyanov

πŸ’» πŸ€”

Bror Winther

πŸ“–

Felix W. Dekker

πŸ“–

Sauceee

🎨

Lennart Weller

πŸ“¦

Andrzej Ressel

πŸ’»

This project follows the all-contributors specification. Contributions of any kind welcome!

Backers via OpenCollective

Sponsors via OpenCollective

ferdi's People

Contributors

058c37a272bed3464d47f0b01038a16a avatar adlk avatar alecive avatar allcontributors[bot] avatar andrzejressel avatar antonpirker avatar atakangktepe avatar benestem avatar blizzke avatar brorbw avatar closingin avatar dannyqiu avatar dbozhinovski avatar dnlup avatar dominikguzei avatar gustavokatel avatar haraldox avatar haveneersrobin avatar jensderond avatar koma-private avatar makazzz avatar phmigotto avatar rherwig avatar shiifu avatar sinstein avatar stanzilla avatar steliyan avatar vantezzen avatar weliveinferdi avatar ywjameslin avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    πŸ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. πŸ“ŠπŸ“ˆπŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❀️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.