/freeman

A free, extensible, cross-platform file manager for power users

Primary LanguageTypeScriptGNU General Public License v3.0GPL-3.0

FreeMAN

Travis-CI build status AppVeyor build status Dependencies Dev Dependencies Maintainability First contributions welcome

A free, extensible, cross-platform file manager for power users


FreeMAN with open integrated terminal

Features

  • Quick, clean, dual-paned file-system navigation with a strong keyboard-led focus
  • Integrated terminal per navigation pane for those things a file explorer just can't do
  • Focus on customisability to tailor it to the user's whims
  • Quick navigation with a Go To box

Future

  • Tighter integration between navigation and integrated terminals
  • Further behaviour to be customisable
  • Extending usefulness of the Go To and Commands boxes

Roadmap

  • Core application ready for beta use
  • Out-of-the-box plugins ready for beta use
  • Core application ready for production use
  • Out-of-the-box plugins ready for production use

The core application is ready for beta use, supporting Linux and Windows OS's. Feel free to set up electron-builder for MacOS and make a PR.

Getting started

Requires node 12.x, as some dependencies do not build with node 13.x.

npm install
npm start

If you want, you can add user-specific settings files, e.g. freeman.keys.json like so:

touch {userData}/freeman.keys.json

{userData} above refers to Electron's app.getPath("userData") location, (which depends on whether the application is running in a development or production environment). Example files can be found in the ./resources/ folder.

Packaging

If you would like to package / install the program, on Windows and Linux you can:

npm run package

Then run the appropriate built executable.

Running

During development, after compiling you can:

npm run start

After packaging, you can run the system-dependent executable outputted by electron-builder in the ./dist/ folder.

Developing

An overview of the codebase can be found in the docs. If you find it helpful, you can npm run docs and open the generated docs/generated/index.html file. Please let me know if you find this useful.

Debugging

Providing the --verbose or -V command-line argument will make the application log in more detail, helping trace execution when using the packaged app. Logs of warnings and errors can be found at {appData}/log.log.

How to contribute

Contributions are welcome! Work on the core application is still under way. There are numerous areas with room for improvement in usability and stability. My priorities for development are currently:

  • Core functionality
  • Plugin functionality (starting with out-of-the-box ones)
  • Appearance

I'll take whatever pull requests, issues, contributors and PMs I can get! Please have a look at the Contributing Guidelines before submitting a PR.