A refreshed "new tab page" for Firefox
Перейти к файлу
Ed Lee 7410e4b21a chore(lint): Enable and autofix comma-dangle never. 2016-08-10 11:17:03 -07:00
artifacts/latest chore(meta): drop plural from activity stream in addon metadata 2016-05-09 16:11:15 -04:00
bin chore(lint): Autofix no-multi-spaces. 2016-08-09 09:57:46 -07:00
common chore(lint): Enable and autofix comma-dangle never. 2016-08-10 11:17:03 -07:00
content-src chore(lint): Enable and autofix comma-dangle never. 2016-08-10 11:17:03 -07:00
content-test chore(lint): Enable and autofix comma-dangle never. 2016-08-10 11:17:03 -07:00
data fix (content): #891 wait for content bridge to be setup before render 2016-06-30 18:54:02 -04:00
dist bare addon skeleton 2016-02-01 09:05:16 -05:00
lib chore(lint): Enable and autofix comma-dangle never. 2016-08-10 11:17:03 -07:00
test chore(lint): Enable and autofix comma-dangle never. 2016-08-10 11:17:03 -07:00
.babelrc Added dependencies, webpack.config, yamscripts 2016-02-01 14:57:40 -05:00
.eslintignore chore (addon): Add python virtual env to eslintignore 2016-08-05 09:50:05 -04:00
.eslintrc chore(lint): Enable and autofix comma-dangle never. 2016-08-10 11:17:03 -07:00
.gitignore chore(addon): #781 use webpack in addon for external deps 2016-06-02 12:41:29 -04:00
.jpmignore chore(addon): #781 use webpack in addon for external deps 2016-06-02 12:41:29 -04:00
.sass-lint.yml fix(lint): order sass rules by alphabetical order 2016-05-12 13:23:19 -07:00
.travis.yml chore(package): Update npm dev dependenices to latest versions. 2016-08-02 14:56:51 +01:00
CHANGELOG.md 1.1.1 changelog 2016-07-26 15:50:02 -04:00
LICENSE Add LICENSE file. 2016-02-02 12:13:14 -05:00
README.md Correct running tests command 2016-05-10 22:16:09 -04:00
config.default.yml chore(https): use https for embedly proxy 2016-03-04 17:45:43 -05:00
config.production.yml chore(https): use https for embedly proxy 2016-03-04 17:45:43 -05:00
data_dictionary.md fix(metrics): Add recommendation fields to data_events.md 2016-07-22 14:15:39 -04:00
data_events.md fix(metrics): Add recommendation fields to data_events.md 2016-07-22 14:15:39 -04:00
dev-prefs.json test(addon): Reduce useless jpm test output 2016-06-02 16:25:16 -04:00
experiments.json chore(experiment): #931 Disable experiment for context menu 2016-07-22 13:09:07 -04:00
experiments_how_to.md chore(experiments): #905 Update experiments docs 2016-07-13 11:53:28 -04:00
fabfile.py chore(meta): drop plural from activity stream in addon metadata 2016-05-09 16:11:15 -04:00
karma.conf.js chore(tests): #363 Fix coveralls reporting 2016-04-22 17:52:04 -04:00
metadata_schema.md Document metadata database schema #985 2016-07-27 17:10:50 -04:00
package.json chore(package): Update eslint to latest version; fix reported issues with defining generators when yield isn't used and also fix indentation in a couple of places. 2016-08-09 09:55:30 -07:00
requirements.txt chore(deploy): #219 s3 deployment scripts for addon 2016-02-29 17:24:18 -05:00
test-prefs.json test(addon): Reduce useless jpm test output 2016-06-02 16:25:16 -04:00
webpack.addon.config.js chore(lint): Autofix arrow-parens as-needed. 2016-08-09 09:57:46 -07:00
webpack.config.js chore(lint): Enable and autofix comma-dangle never. 2016-08-10 11:17:03 -07:00
yamscripts.yml Merge pull request #1030 from rlr/gh1024/package 2016-08-04 20:23:56 -04:00

README.md

Activity Stream Add-on

Coverage Status

TLDR; I just want to try the add-on

  1. Make sure you have Firefox Beta, node 5.0+ and at npm 3.0+ installed.
  2. npm install
  3. npm run once

Requirements

  • You must have at Firefox (45.0+) installed
  • node 5.0+, npm 3.0+ (You can install both here)

Installation

Just clone the repo and install the dependencies.

git clone https://github.com/mozilla/activity-stream.git
cd activity-stream
npm install

Configuration

Default configuration is in config.default.yml. Create a file called config.yml to override any default configuration.

Embedly Proxy Server

By default, the add-on will request data from embedly through a dev instance of our embedly proxy server. If you want to run the add-on with a different endpoint, change the following in config.yml:

EMBEDLY_ENDPOINT: http://....

Please file issues related to the embedly proxy server at https://github.com/mozilla/embedly-proxy/issues.

Using shim data

If you want to run the content on http://localhost:1963 with shim data (i.e. outside the add-on), add the following to config.yml.

USE_SHIM: true

You can also disable the embedly service by setting EMBEDLY_ENDPOINT to an empty string.

Running tasks

You may run npm run help to see a description of all commands available, which you can run via npm run [command]. Here are some important ones:

Running the add-on

If you just want to build assets and run the add-on to test it, you may simply run:

npm run once

Developing the add-on

If you want to watch assets and compile them continuously, you will want to run

npm run start

in one terminal session, and

npm run firefox

to start the add-on. This way, when you make changes to the content-src folder, they will be reflected immediately without needing to restart the add-on.

Running Tests

Run npm test to run the tests once. Run npm run help for more options.

Architecture - ActionManager

When you instantiate an ActionManager, you give it a list of types which are valid for the application. If at any time you try to create an action with a type that isn't part of that list, it will throw an error. Yay!

const am = new ActionManager(["STUFF_REQUEST", "STUFF_RESPONSE"]);

You can find the action manager instance for Activity stream at common/action-manager.

Dispatching actions

To dispatch actions, all you have to do is call am.actions.YourActionType(...).

By default, there is a Action type action defined which simply takes an object as an argument. However, it is a good idea to define actions that are specific enough to prevent typos and formatting errors.

const {actions} = require("common/action-manager");

// These are all equivalent
this.dispatch(actions.Action({
  type:"TOP_FRECENT_SITES_REQUEST",
  meta: {expect: "TOP_FRECENT_SITES_RESPONSE"}
}));
this.dispatch(actions.RequestExpect("TOP_FRECENT_SITES_REQUEST", "TOP_FRECENT_SITES_RESPONSE"));
this.dispatch(actions.GetTopFrecentSites());

Defining new actions

You can define new actions on the ActionManager instance with am.defineActions. All action definitions should be functions that return a plain object representing the action.

function Foo(data) {
  return {type: 'FOO', data};
}
am.defineActions({Foo});

All new actions will have some basic validators applied to them like checking for the type property. Action functions also get called in the context of the action manager instance.

Extending existing actions

Most new actions will actually be extensions of new ones. To do this, simply call another action function inside your new one.

It is generally not a good idea to call this.actions.SomeAction inside another action, as that will result in the validators being run twice. Use the plain SomeAction function instead, or you can access it from this.actions.SomeAction.definition.

function Request(type, data) {
  return {type, data};
}
function GetFoo() {
  return Request(foo);
}
am.defineActions({Request, GetFoo});

Conventions for Actions

In this project we use a modified version of the Standard Flux Action. Our standard action looks something like this:

{
  // The type should be upper-case.
  // Request-type actions should end in _REQUEST
  // Response-type actions should end in _RESPONSE
  // Required.
  type: "SOMETHING_REQUEST",

  // For request or response-type actions.
  // For responses:
  //    If the response is successful, it should be an array OR object.
  //    If the response is an error, it should be an Error.
  // Optional.
  data: {},

  // This should be included for actions that contain errors
  // It should be true, or omitted if not applicable.
  error: true

  // This can contain action-specific info
  meta: {
    // This is to indicate that the application should receive the
    // following action within a specified time period, or a timeout
    // error should be thrown
    expect: "SOMETHING_RESPONSE",

    // Optional. A custom timeout for an 'expect' type action.
    timeout: 10000,

    // This indicates to the ReduxChannel middleware that
    // the action should broadcast via message passing to the other
    // side of the channel.
    broadcast: "content-to-addon",

    // This indicates new results should be appended to old results,
    // instead of replacing them.
    append: true
  }
}