gecko/browser/components/loop
2015-04-30 00:32:05 +09:00
..
content Bug 1102219 - Part 4: Replace String.prototype.contains with String.prototype.includes in chrome code. r=till 2015-04-30 00:32:05 +09:00
standalone Bug 1158800 - Don't show errors for context in conversations on the standalone UI as they may force the user into an unnecessary re-obtaining of the URL. r=dmose 2015-04-28 08:17:56 +01:00
test Bug 1102219 - Part 5: Replace more String.prototype.contains with String.prototype.includes in chrome code. r=till 2015-04-30 00:32:05 +09:00
ui Bug 1142587 - Implement indicators for context in conversations in the panel alongside room names. r=mikedeboer 2015-04-21 21:53:15 +01:00
.eslintignore Bug 1150632 - Extend eslint to Loop's .jsm files. r=dmose 2015-04-04 14:43:27 +01:00
.eslintrc Bug 1150632 - Extend eslint to Loop's .jsm files. r=dmose 2015-04-04 14:43:27 +01:00
.gitignore
build-jsx Bug 1045690 Ensure the correct version of react is used when building the Loop jsx files. r=Standard8 2014-09-16 11:38:59 +01:00
CardDavImporter.jsm Bug 972079 - CardDAV Address Importer for Loop r=MattN 2014-08-29 13:31:46 -05:00
GoogleImporter.jsm Bug 1150632 - Extend eslint to Loop's .jsm files. r=dmose 2015-04-04 14:43:27 +01:00
jar.mn Bug 1152296 - Move roomStore.js from shared code to desktop specific code for Loop. r=mikedeboer 2015-04-08 17:13:03 +01:00
LoopCalls.jsm Bug 1102219 - Part 4: Replace String.prototype.contains with String.prototype.includes in chrome code. r=till 2015-04-30 00:32:05 +09:00
LoopContacts.jsm Bug 1079941: implement LoopContacts.search to allow searching for contacts by query and use that to find out if a contact who's trying to call you is blocked. r=abr 2014-10-16 16:35:10 +02:00
LoopRooms.jsm Bug 1137813 - Part 3. Add room connection status logging. r=mikedeboer 2015-04-28 08:17:56 +01:00
LoopStorage.jsm Bug 1150632 - Extend eslint to Loop's .jsm files. r=dmose 2015-04-04 14:43:27 +01:00
manifest.ini Bug 1088006 - Hook up Loop's ui-showcase to unit tests so that we don't keep on breaking it, and so that it can possibly catch use of es6 errors. r=dmose 2015-03-12 08:04:51 +00:00
moz.build Bug 1142522 - Part 1 Share utils and crypto content modules with chrome as well. r=Standard8 2015-04-13 11:54:25 +01:00
MozLoopAPI.jsm Bug 1145541. r=mikedeboer 2015-04-21 21:53:15 +01:00
MozLoopPushHandler.jsm Bug 1099296 - Attach LoadInfo to remaining callers of ioService and ProtocolHandlers - websocket changes in browser/ (r=gavin) 2015-02-17 10:10:06 -08:00
MozLoopService.jsm Bug 1153788 - Part 1 Opportunistically obtain encryption keys for FxA for Loop conversations context. r=mikedeboer 2015-04-22 19:17:15 +01:00
MozLoopWorker.js
README.txt Follow-up to bug 1150632 - add documentation for running eslint against Loop's jsm files. rs=dmose over irc. NPOTB DONTBUILD 2015-04-07 21:56:59 +01:00
run-all-loop-tests.sh No bug. Update Loop's run-all-loop-tests.sh to reference the new location of browser_UITour_loop.js. rs=mikedeboer over irc. NPOTB DONTBUILD 2015-04-13 14:48:02 +01:00

This is the directory for the Loop desktop implementation and the standalone
client.

The desktop implementation is the UX built into Firefox, activated by the Loop
button on the toolbar. The standalone client is the link-clicker UX for any
modern browser that supports WebRTC.

The standalone client is a set of web pages intended to be hosted on a
standalone server referenced by the loop-server.

The standalone client exists in standalone/ but shares items
(from content/shared/) with the desktop implementation. See the README.md
file in the standalone/ directory for how to run the server locally.

Working with React JSX files
============================

Our views use [React](http://facebook.github.io/react/) written in JSX files
and transpiled to JS before we commit. You need to install the JSX compiler
using npm in order to compile the .jsx files into regular .js ones:

    npm install -g react-tools

Once installed, run build-jsx with the --watch option from
browser/components/loop, eg.:

    cd browser/components/loop
    ./build-jsx --watch

build-jsx can also be do a one-time compile pass instead of watching if
the --watch argument is omitted.  Be sure to commit any transpiled files
at the same time as changes to their sources.


Hacking
=======
Please be sure to execute

  browser/components/loop/run-all-loop-tests.sh

from the top level before requesting review on a patch.

Linting
=======
run-all-loop-tests.sh will take care of this for you automatically, after
you've installed the dependencies by typing:

  ( cd standalone ; make install )

If you install eslint and the react plugin globally:

  npm install -g eslint
  npm install -g eslint-plugin-react

You can also run it by hand in the browser/components/loop directory:

  eslint -ext .js -ext .jsx --ext .jsm .

Front-End Unit Tests
====================
The unit tests for Loop reside in three directories:

- test/desktop-local
- test/shared
- test/standalone

You can run these as part of the run-all-loop-tests.sh command above, or you can run these individually in Firefox. To run them individually, start the standalone client (see standalone/README.md) and load:

  http://localhost:3000/test/


Functional Tests
================
These are currently a work in progress, but it's already possible to run a test
if you have a [loop-server](https://github.com/mozilla-services/loop-server)
install that is properly configured.  From the top-level gecko directory,
execute:

  export LOOP_SERVER=/Users/larry/src/loop-server
  ./mach marionette-test browser/components/loop/test/functional/manifest.ini

Once the automation is complete, we'll include this in run-all-loop-tests.sh
as well.


UI-Showcase
===========
This is a tool giving the layouts for all the frontend views of Loop, allowing debugging and testing of css layouts and local component behavior.

To access it, start the standalone client (see standalone/README.md) and load:

  http://localhost:3000/ui/