GitXplorerGitXplorer
a

flix

public
0 stars
0 forks
0 issues

Commits

List of commits on branch master.
Unverified
c96f2127267648b710c8567463be47786c13aa04

Update package-lock.json

ffeross committed 5 years ago
Verified
80c1a61c33d8f4d9b2f762427304c40e3b5a5b7c

Merge pull request #1605 from webtorrent/greenkeeper/babel-eslint-10.0.2

ffeross committed 5 years ago
Verified
4da9da3d9a4aa5ea15892f6038a083416a2b0eb8

Merge pull request #1620 from webtorrent/greenkeeper/walk-sync-2.0.2

ffeross committed 6 years ago
Verified
9916073a982e9700a8052a188349e0ea47517b65

Merge pull request #1540 from RecoX/patch-1

ffeross committed 6 years ago
Verified
820776427baddf145d631c474e16c2d2b4a68215

Merge pull request #1585 from webtorrent/greenkeeper/depcheck-0.8.0

ffeross committed 6 years ago
Unverified
da76ff53ce0d942c0c16371058909541b8da888b

chore(package): update lockfile package-lock.json

ggreenkeeper[bot] committed 6 years ago

README

The README file for this repository.


WebTorrent
WebTorrent Desktop

The streaming torrent app. For Mac, Windows, and Linux.

gitter travis github release version github release downloads Standard - JavaScript Style Guide

Install

Recommended Install

Download the latest version of WebTorrent Desktop from the official website:

Advanced Install

  • Download specific installer files from the GitHub releases page.

  • Use Homebrew-Cask to install from the command line:

    $ brew cask install webtorrent
    
  • Try the (unstable) development version by cloning the Git repository. See the "How to Contribute" instructions.

Screenshots

screenshot screenshot

How to Contribute

Get the code

$ git clone https://github.com/webtorrent/webtorrent-desktop.git
$ cd webtorrent-desktop
$ npm install

Run the app

$ npm start

Watch the code

Restart the app automatically every time code changes. Useful during development.

$ npm run watch

Run linters

$ npm test

Run integration tests

$ npm run test-integration

The integration tests use Spectron and Tape. They click through the app, taking screenshots and comparing each one to a reference. Why screenshots?

  • Ad-hoc checking makes the tests a lot more work to write
  • Even diffing the whole HTML is not as thorough as screenshot diffing. For example, it wouldn't catch an bug where hitting ESC from a video doesn't correctly restore window size.
  • Chrome's own integration tests use screenshot diffing iirc
  • Small UI changes will break a few tests, but the fix is as easy as deleting the offending screenshots and running the tests, which will recreate them with the new look.
  • The resulting Github PR will then show, pixel by pixel, the exact UI changes that were made! See https://github.com/blog/817-behold-image-view-modes

For MacOS, you'll need a Retina screen for the integration tests to pass. Your screen should have the same resolution as a 2016 12" Macbook.

For Windows, you'll need Windows 10 with a 1366x768 screen.

When running integration tests, keep the mouse on the edge of the screen and don't touch the mouse or keyboard while the tests are running.

Package the app

Builds app binaries for Mac, Linux, and Windows.

$ npm run package

To build for one platform:

$ npm run package -- [platform] [options]

Where [platform] is darwin, linux, win32, or all (default).

The following optional arguments are available:

  • --sign - Sign the application (Mac, Windows)
  • --package=[type] - Package single output type.
    • deb - Debian package
    • zip - Linux zip file
    • dmg - Mac disk image
    • exe - Windows installer
    • portable - Windows portable app
    • all - All platforms (default)

Note: Even with the --package option, the auto-update files (.nupkg for Windows, -darwin.zip for Mac) will always be produced.

Windows build notes

The Windows app can be packaged from any platform.

Note: Windows code signing only works from Windows, for now.

Note: To package the Windows app from non-Windows platforms, Wine needs to be installed. For example on Mac, first install XQuartz, then run:

brew install wine

(Requires the Homebrew package manager.)

Mac build notes

The Mac app can only be packaged from macOS.

Linux build notes

The Linux app can be packaged from any platform.

Recommended readings to start working in the app

Electron (Framework to make native apps for Windows, OSX and Linux in Javascript): https://electronjs.org/docs/tutorial/quick-start

React.js (Framework to work with Frontend UI): https://reactjs.org/docs/getting-started.html

Material UI (React components that implement Google's Material Design.): https://material-ui.com/getting-started

Privacy

WebTorrent Desktop collects some basic usage stats to help us make the app better. For example, we track how well the play button works. How often does it succeed? Time out? Show a missing codec error?

The app never sends any personally identifying information, nor does it track which torrents you add.

License

MIT. Copyright (c) WebTorrent, LLC.