├── .gitignore ├── .npmignore ├── CHANGELOG.md ├── LICENSE ├── README.md ├── examples ├── blessed │ ├── README.md │ ├── foo-context.js │ ├── index.js │ ├── layout.js │ └── package.json ├── clicker-babel │ ├── README.md │ ├── build.sh │ ├── index.html │ └── index.js ├── clicker-rx │ ├── README.md │ ├── build.sh │ ├── index.coffee │ └── index.html ├── clicker │ ├── README.md │ ├── build.sh │ ├── index.coffee │ └── index.html ├── helloworld │ ├── README.md │ ├── build.sh │ ├── index.coffee │ └── index.html ├── transition │ ├── README.md │ ├── build.sh │ ├── index.coffee │ └── index.html ├── typescript │ ├── .gitignore │ ├── build.sh │ ├── dtsm.json │ ├── index.html │ └── index.ts └── website-router │ ├── README.md │ ├── build.sh │ ├── index.html │ └── index.js ├── index.d.ts ├── node.js ├── package.json ├── src ├── context.coffee ├── default-layout.coffee ├── dispatcher-button.coffee ├── index.coffee ├── mixin.coffee └── router.coffee ├── test ├── component-test.coffee ├── context-test.coffee ├── router-test.coffee └── spec_helper.coffee └── yarn.lock /.gitignore: -------------------------------------------------------------------------------- 1 | ### https://raw.github.com/github/gitignore/d866fb556184cc1edffd9d0f1ca205fe1916a7f6/Node.gitignore 2 | 3 | # Logs 4 | logs 5 | *.log 6 | 7 | # Runtime data 8 | pids 9 | *.pid 10 | *.seed 11 | bundle.js 12 | 13 | # Directory for instrumented libs generated by jscoverage/JSCover 14 | lib-cov 15 | scratch.coffee 16 | 17 | # Coverage directory used by tools like istanbul 18 | coverage 19 | 20 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) 21 | .grunt 22 | 23 | # node-waf configuration 24 | .lock-wscript 25 | 26 | # Compiled binary addons (http://nodejs.org/api/addons.html) 27 | build/Release 28 | 29 | # Dependency directory 30 | # https://www.npmjs.org/doc/misc/npm-faq.html#should-i-check-my-node_modules-folder-into-git- 31 | node_modules 32 | 33 | 34 | ### https://raw.github.com/github/gitignore/d866fb556184cc1edffd9d0f1ca205fe1916a7f6/Global/OSX.gitignore 35 | 36 | .DS_Store 37 | .AppleDouble 38 | .LSOverride 39 | 40 | # Icon must end with two \r 41 | Icon 42 | 43 | # Thumbnails 44 | ._* 45 | 46 | # Files that might appear on external disk 47 | .Spotlight-V100 48 | .Trashes 49 | 50 | # Directories potentially created on remote AFP share 51 | .AppleDB 52 | .AppleDesktop 53 | Network Trash Folder 54 | Temporary Items 55 | .apdisk 56 | 57 | 58 | ### https://raw.github.com/github/gitignore/d866fb556184cc1edffd9d0f1ca205fe1916a7f6/Ruby.gitignore 59 | 60 | *.gem 61 | *.rbc 62 | /.config 63 | /coverage/ 64 | /InstalledFiles 65 | /pkg/ 66 | /spec/reports/ 67 | /test/tmp/ 68 | /test/version_tmp/ 69 | /tmp/ 70 | 71 | ## Specific to RubyMotion: 72 | .dat* 73 | .repl_history 74 | build/ 75 | 76 | ## Documentation cache and generated files: 77 | /.yardoc/ 78 | /_yardoc/ 79 | /doc/ 80 | /rdoc/ 81 | 82 | ## Environment normalisation: 83 | /.bundle/ 84 | /lib/bundler/man/ 85 | 86 | # for a library or gem, you might want to ignore these files since the code is 87 | # intended to run in multiple environments; otherwise, check them in: 88 | # Gemfile.lock 89 | # .ruby-version 90 | # .ruby-gemset 91 | 92 | # unless supporting rvm < 1.11.0 or doing something fancy, ignore this: 93 | .rvmrc 94 | lib/ 95 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | src/ 2 | examples/ 3 | test/ 4 | -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # ChangeLog 2 | 3 | ## v0.13 4 | 5 | - Now occuring warnings again. Roolback internal to avoid nested case. 6 | 7 | ## v0.12 8 | 9 | - Remove static member access in Context Class 10 | - Context's `static component` -> `get component()` 11 | - Context's `static subscribers` -> `get subscribers()` 12 | - Reason: ES6 classese extends can't extend static props. CoffeeScript and TypeScript work but Babel doesn't 13 | - Remove Arda.Component class 14 | - Use React.createClass `Arda.mixin` instead. 15 | - Reason: ES6 Classes is not filled React context features. If it works well later, I will restore it. 16 | - No warning now 17 | 18 | ## v0.11 19 | 20 | - Cache context state on pop 21 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2015 Koutaro Chikuba 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in 13 | all copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 21 | THE SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Arda 2 | 3 | Meta-Flux framework for real world. 4 | 5 | ``` 6 | $ npm install arda --save 7 | ``` 8 | 9 | ## Changelog 10 | 11 | - v0.16: Drop React < v15 12 | 13 | ## Concept 14 | 15 | Today's Flux is weak at scene transitions. Arda make it simple by `router` and `context`(chunk of flux). 16 | 17 | Context has Flux features and its stack is very simple. 18 | 19 | - Dispatcher is just EventEmitter 20 | - View is just React.Component (with mixin) 21 | - Store should be covered by typesafe steps with promise 22 | 23 | I need to develop to make my company's react project simple. Arda is started from extraction of my works and well dogfooded. Thx [Increments Inc.](https://github.com/increments "Increments Inc.") 24 | 25 | 26 | ## Goals 27 | 28 | - Transition with Promise 29 | - Loose coupling and testable 30 | - *TypeScript*, *CoffeeScript*, and *ES6* friendly 31 | - Protect mutable state and make it atomic. 32 | 33 | ## Intro 34 | 35 | Context, it extends way of react, is just one flux loop and has data flow, `Props => State => ComponentProps` 36 | 37 | simple example 38 | 39 | ```js 40 | window.React = require('react'); 41 | var Arda = require('arda'); 42 | var Clicker = React.createClass({ 43 | mixins: [Arda.mixin], 44 | render() { 45 | return React.createElement('button', {onClick: this.onClick.bind(this)}, this.props.cnt); 46 | }, 47 | onClick() { 48 | this.dispatch('hello:++'); 49 | } 50 | }); 51 | 52 | class ClickerContext extends Arda.Context { 53 | get component() { 54 | return Clicker; 55 | } 56 | 57 | initState() { 58 | return {cnt: 0}; 59 | } 60 | 61 | expandComponentProps(props, state) { 62 | return {cnt: state.cnt}; 63 | } 64 | 65 | delegate(subscribe) { 66 | super.delegate(); 67 | subscribe('context:created', () => console.log('created')); 68 | subscribe('hello:++', () => 69 | this.update((s) => { return {cnt: s.cnt+1}; }) 70 | ); 71 | } 72 | }; 73 | 74 | window.addEventListener('DOMContentLoaded', () => { 75 | var router = new Arda.Router(Arda.DefaultLayout, document.body); 76 | router.pushContext(ClickerContext, {}); 77 | }); 78 | ``` 79 | 80 | ![](http://i.gyazo.com/7b2dffed4f296beddc8a305270db884a.png) 81 | 82 | ## Transition 83 | 84 | Arda.Router has `pushContext`, `popContext` and `replaceContext` and return promise object. 85 | 86 | (coffeescript) 87 | 88 | ```coffee 89 | router = new Arda.Router(Arda.DefaultLayout, document.body) 90 | router.pushContext(MainContext, {}) # Main 91 | .then => router.pushContext(SubContext, {}) # Main, Sub 92 | .then => router.pushContext(MainContext, {}) # Main, Sub, Main 93 | .then => router.popContext() # Main, Sub 94 | .then => router.replaceContext(MainContext, {}) # Main, Main 95 | .then => console.log router.history 96 | ``` 97 | 98 | `pushContext` and `replaceContext`'s second argument is to be context.props as immutable object. 99 | 100 | ## LifeCycle 101 | 102 | (coffeescript) 103 | 104 | ```coffee 105 | subscriber = (context, subscribe) -> 106 | subscribe 'context:created', -> console.log 'created' 107 | subscribe 'context:started', -> console.log 'started' 108 | subscribe 'context:paused', -> console.log 'paused' 109 | subscribe 'context:resumed', -> console.log 'resumed' 110 | subscribe 'context:disposed', -> console.log 'disposed' 111 | 112 | class MyContext extends Arda.Context 113 | component: MyComponent 114 | subscribers: [subscriber] 115 | ``` 116 | 117 | ![](http://i.gyazo.com/ff7ddb2643ea4d1587f1ce236da0f918.png) 118 | 119 | static `subscribers` is automatic delegator on instantiate. 120 | 121 | ## DispatcherButton 122 | 123 | This is just utility ReactElement. 124 | 125 | (coffeescript) 126 | 127 | ```coffee 128 | {DispatcherButton} = arda 129 | React.createClass 130 | mixins: [Arda.mixin] 131 | render: -> 132 | React.createElement 'div', {}, [ 133 | React.createElement DispatcherButton, { 134 | event: 'foo-event' 135 | args: ['foo-id-12345'] 136 | }, 'foo' # => button foo 137 | React.createElement DispatcherButton, { 138 | event: 'foo-event' 139 | args: ['foo-id-**'] 140 | className: 'custome-button' 141 | }, [ 142 | React.createElement 'span', {}, 'text' 143 | ] # => span.custome-button > span text 144 | ] 145 | ``` 146 | 147 | ## with TypeScript 148 | 149 | To achive purpose to make mutable state typesafe, Arda with TypeScript is better than other AltJS. 150 | 151 | ```javascript 152 | interface Props {firstName: string; lastName: string;} 153 | interface State {age: number;} 154 | interface ComponentProps {greeting: string;} 155 | 156 | class MyContext extends Arda.Context { 157 | get component() { 158 | return React.createClass({ 159 | mixins: [Arda.mixin], 160 | render: function(){return React.createElement('h1', {}, this.props.greeting);} 161 | }); 162 | } 163 | 164 | initState(props){ 165 | // Can use promise (State | Promise) 166 | return new Promise(done => { 167 | setTimeout(done({age:10}), 1000) 168 | }) 169 | } 170 | expandComponentProps(props, state) { 171 | // Can use promise (ComponentProps | Promise) 172 | return {greeting: 'Hello, '+props.firstName+', '+state.age+' years old'} 173 | } 174 | } 175 | 176 | var router = new Arda.Router(Arda.DefaultLayout, document.body); 177 | // Unfortunately, initial props by router are not validated yet 178 | // If you want, you can create your original router wrapper 179 | router.pushContext(MyContext, {firstName: 'Jonh', lastName: 'Doe'}) 180 | .then(context => { 181 | setInterval(() => { 182 | context.state(state => {age: state.age+1}) // this is validated 183 | }, 1000 * 60 * 60 * 24 * 360) // fire once by each year haha:) 184 | }); 185 | ``` 186 | 187 | See [typescript working example](examples/typescript/index.ts) 188 | 189 | Or see mizchi's starter project[mizchi-sandbox/arda-starter-project](https://github.com/mizchi-sandbox/arda-starter-project "mizchi-sandbox/arda-starter-project") 190 | 191 | ## Custom Layout (Advanced) 192 | 193 | Arda provide default layout to use. It can resolve most cases. 194 | 195 | But occasionally you need custom layout. 196 | 197 | example. 198 | 199 | ```js 200 | const Layout = React.createClass({ 201 | childContextTypes: { 202 | shared: React.PropTypes.object 203 | }, 204 | contextTypes: { 205 | ctx: React.PropTypes.object 206 | }, 207 | 208 | getChildContext() { 209 | return {shared: this.getContext()}; 210 | }, 211 | 212 | getContext() { 213 | return this.state.activeContext || this.context.shared; 214 | }, 215 | 216 | getInitialState() { 217 | return { 218 | activeContext: null, 219 | templateProps: {} 220 | }; 221 | }, 222 | 223 | render() { 224 | if (this.state.activeContext != null) { 225 | this.state.templateProps.ref = 'root'; 226 | return React.createElement( 227 | this.state.activeContext.component, 228 | this.state.templateProps 229 | ); 230 | } else { 231 | return
232 | } 233 | } 234 | }) 235 | 236 | // use it! 237 | const router = new Arda.Router(Layout, document.body); 238 | ``` 239 | 240 | Custom layout is required some implementations. 241 | 242 | - implement contextTypes.shared 243 | - implement childContextTypes.ctx 244 | - implement getChildContext() to return contextTypes.shared 245 | - implement getInitialState() to fill contextTypes. 246 | - optional: render initial case and use context propeties 247 | 248 | This implement resolve dispatch mixin behaviour. 249 | 250 | Perhaps you can resolve by Copy and Paste and edit manually. 251 | 252 | ## Custom Renderer (Advanced) 253 | 254 | Initialize in node.js to use custom renderer. 255 | 256 | ```js 257 | const React = require('react') 258 | const Arda = require('arda/node')(React); 259 | const {render} from '@mizchi/react-blessed'; 260 | 261 | // you should prepare custom layout for its environment 262 | // and function to get root component 263 | // (el: ReactElement) => ReactComponent 264 | const router = new Arda.Router(Layout, layout => { 265 | const screen = render(layout, { 266 | autoPadding: true, 267 | smartCSR: true, 268 | title: 'react-blessed hello world' 269 | }); 270 | screen.key(['escape'], () => process.exit(0)); 271 | return screen._component; 272 | }); 273 | 274 | ``` 275 | 276 | custom layout hs to fill contextTypes specs. 277 | See [example with react-blessed](/examples/blessed) 278 | 279 | ## Dependencies 280 | 281 | - React v0.14.0-beta3 >= 282 | - Promise or its poryfill 283 | 284 | ## API 285 | 286 | See detail at [index.d.ts](index.d.ts) 287 | 288 | ## LICENSE 289 | 290 | MIT 291 | -------------------------------------------------------------------------------- /examples/blessed/README.md: -------------------------------------------------------------------------------- 1 | # Arda example with blessed 2 | 3 | ``` 4 | npm install 5 | $(npm bin)/babel-node index.js 6 | ``` 7 | -------------------------------------------------------------------------------- /examples/blessed/foo-context.js: -------------------------------------------------------------------------------- 1 | import React, {Component} from 'react' 2 | const Arda = require('../../node')(React); 3 | 4 | export class Foo extends Component { 5 | constructor(){ 6 | super(); 7 | this.state = {cnt: 1}; 8 | } 9 | 10 | render() { 11 | return 17 | Fooooooooooooooooooooo 18 | ; 19 | } 20 | } 21 | 22 | export default class FooContext extends Arda.Context { 23 | get component() { 24 | return Foo; 25 | } 26 | expandComponentProps(props, state) { 27 | return {}; 28 | } 29 | }; 30 | -------------------------------------------------------------------------------- /examples/blessed/index.js: -------------------------------------------------------------------------------- 1 | import React, {Component} from 'react'; 2 | const Arda = require('../../node')(React); 3 | global.Arda = Arda; 4 | 5 | import {render} from 'react-blessed'; 6 | import blessed from 'blessed'; 7 | import Layout from './layout'; 8 | import FooContext from './foo-context'; 9 | 10 | // Rendering a simple centered box 11 | class App extends Component { 12 | constructor(){ 13 | super(); 14 | this.state = {cnt: 1}; 15 | } 16 | 17 | componentDidMount() { 18 | this._id =setInterval(() => { 19 | this.incrementCounter(); 20 | }, 1000) 21 | } 22 | 23 | componentWillUnmount() { 24 | clearInterval(this._id); 25 | } 26 | 27 | incrementCounter() { 28 | this.setState({cnt: this.state.cnt + 1}); 29 | } 30 | 31 | render() { 32 | return 38 | {this.state.cnt.toString()} 39 | ; 40 | } 41 | } 42 | 43 | 44 | class AppContext extends Arda.Context { 45 | get component() { 46 | return App; 47 | } 48 | 49 | expandComponentProps(props, state) { 50 | return {name: props.name}; 51 | } 52 | 53 | delegate(subscribe) { 54 | super.delegate(); 55 | subscribe('context:created', () => console.log('created', this.props.name)); 56 | } 57 | }; 58 | 59 | let screen = blessed.screen({ 60 | autoPadding: true, 61 | smartCSR: true, 62 | title: 'react-blessed hello world' 63 | }); 64 | screen.key(['escape', 'q', 'C-c'], function(ch, key) { 65 | return process.exit(0); 66 | }); 67 | 68 | const router = new Arda.Router(Layout, (el) => { 69 | let component = render(el, screen); 70 | screen.key(['b'], function(ch, key) { 71 | router.pushContext(FooContext, {}); 72 | }); 73 | 74 | return component; 75 | }); 76 | 77 | router.pushContext(AppContext, {}) 78 | .then(context => { 79 | screen.key(['a'], function(ch, key) { 80 | const c = context.getActiveComponent(); 81 | c.incrementCounter(); 82 | }); 83 | }) 84 | .catch(e => { 85 | console.log('error', e.stack); 86 | }); 87 | -------------------------------------------------------------------------------- /examples/blessed/layout.js: -------------------------------------------------------------------------------- 1 | const React = require('react'); 2 | const T = React.PropTypes; 3 | const $ = React.createElement; 4 | 5 | module.exports = React.createClass({ 6 | childContextTypes: { 7 | shared: T.object 8 | }, 9 | contextTypes: { 10 | ctx: T.object 11 | }, 12 | 13 | getChildContext() { 14 | return {shared: this.getContext()}; 15 | }, 16 | 17 | getContext() { 18 | return this.state.activeContext || this.context.shared; 19 | }, 20 | 21 | getInitialState() { 22 | return { 23 | activeContext: null, 24 | templateProps: {} 25 | }; 26 | }, 27 | 28 | render() { 29 | if (this.state.activeContext != null) { 30 | this.state.templateProps.ref = 'root'; 31 | return $( 32 | this.state.activeContext.component, 33 | this.state.templateProps 34 | ); 35 | } else { 36 | return 42 | Loading 43 | ; 44 | } 45 | } 46 | }) 47 | -------------------------------------------------------------------------------- /examples/blessed/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "blessed", 3 | "version": "1.0.0", 4 | "description": "``` sh build.sh open index.html ```", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "ISC", 11 | "devDependencies": { 12 | "babel": "5.8.23", 13 | "blessed": "0.1.14", 14 | "react-blessed": "0.1.0" 15 | } 16 | } 17 | -------------------------------------------------------------------------------- /examples/clicker-babel/README.md: -------------------------------------------------------------------------------- 1 | # Arda HelloWorld Example 2 | 3 | ``` 4 | sh build.sh 5 | open index.html 6 | ``` 7 | -------------------------------------------------------------------------------- /examples/clicker-babel/build.sh: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env 2 | 3 | browserify -t babelify -o bundle.js index.js 4 | -------------------------------------------------------------------------------- /examples/clicker-babel/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /examples/clicker-babel/index.js: -------------------------------------------------------------------------------- 1 | window.React = require('react'); 2 | var Arda = require('../../lib'); 3 | 4 | var Clicker = React.createClass({ 5 | mixins: [Arda.mixin], 6 | render() { 7 | return React.createElement('button', {onClick: this.onClick.bind(this)}, this.props.cnt); 8 | }, 9 | 10 | onClick() { 11 | this.dispatch('hello:++'); 12 | } 13 | }); 14 | 15 | class ClickerContext extends Arda.Context { 16 | get component() { 17 | return Clicker; 18 | } 19 | 20 | initState() { 21 | return {cnt: 0}; 22 | } 23 | expandComponentProps(props, state) { 24 | return {cnt: state.cnt}; 25 | } 26 | 27 | delegate(subscribe) { 28 | super.delegate(); 29 | subscribe('context:created', () => console.log('created')); 30 | subscribe('hello:++', () => 31 | this.update((s) => { return {cnt: s.cnt+1}; }) 32 | ); 33 | } 34 | }; 35 | 36 | window.addEventListener('DOMContentLoaded', () => { 37 | var router = new Arda.Router(Arda.DefaultLayout, document.body); 38 | router.pushContext(ClickerContext, {}); 39 | }); 40 | -------------------------------------------------------------------------------- /examples/clicker-rx/README.md: -------------------------------------------------------------------------------- 1 | # Arda HelloWorld Example 2 | 3 | ``` 4 | sh build.sh 5 | open index.html 6 | ``` 7 | -------------------------------------------------------------------------------- /examples/clicker-rx/build.sh: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env 2 | 3 | browserify -t coffeeify --extension=".coffee" -o bundle.js index.coffee 4 | -------------------------------------------------------------------------------- /examples/clicker-rx/index.coffee: -------------------------------------------------------------------------------- 1 | window.React = require 'react' 2 | window.Promise = require 'bluebird' 3 | window.Rx = require 'rx' 4 | Arda = require '../../src/' 5 | 6 | Clicker = React.createClass 7 | mixins: [Arda.mixin] 8 | render: -> 9 | React.createElement 'button', {onClick: @onClick.bind(@)}, 'double click me' 10 | 11 | onClick: -> 12 | @dispatch 'clicker:click' 13 | 14 | class ClickerContext extends Arda.Context 15 | component: Clicker 16 | delegate: (subscribe) -> 17 | super 18 | subscribe 'context:created', -> console.log 'created' 19 | clicks = Rx.Node.fromEvent @, 'clicker:click' 20 | clicks 21 | # .buffer clicks.throttle 250 22 | # .map (xs) -> xs.length 23 | # .filter (n) -> n is 2 24 | .subscribe (n) -> console.log "double click" 25 | 26 | window.addEventListener 'DOMContentLoaded', -> 27 | router = new Arda.Router(Arda.DefaultLayout, document.body) 28 | router.pushContext(ClickerContext, {}) 29 | -------------------------------------------------------------------------------- /examples/clicker-rx/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /examples/clicker/README.md: -------------------------------------------------------------------------------- 1 | # Arda HelloWorld Example 2 | 3 | ``` 4 | sh build.sh 5 | open index.html 6 | ``` 7 | -------------------------------------------------------------------------------- /examples/clicker/build.sh: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env 2 | 3 | browserify -t coffeeify --extension=".coffee" -o bundle.js index.coffee 4 | -------------------------------------------------------------------------------- /examples/clicker/index.coffee: -------------------------------------------------------------------------------- 1 | window.React = require 'react' 2 | window.Promise = require 'bluebird' 3 | Arda = require '../../src/' 4 | 5 | Clicker = React.createClass 6 | mixins: [Arda.mixin] 7 | render: -> 8 | React.createElement 'button', {onClick: @onClick.bind(@)}, @props.cnt 9 | 10 | onClick: -> 11 | @dispatch 'hello:++' 12 | 13 | class ClickerContext extends Arda.Context 14 | component: Clicker 15 | 16 | initState: -> cnt: 0 17 | expandComponentProps: -> 18 | cnt: @state.cnt 19 | 20 | delegate: (subscribe) -> 21 | super 22 | subscribe 'context:created', -> console.log 'created' 23 | subscribe 'hello:++', -> 24 | @update (s) => cnt: s.cnt+1 25 | 26 | window.addEventListener 'DOMContentLoaded', -> 27 | router = new Arda.Router(Arda.DefaultLayout, document.body) 28 | router.pushContext(ClickerContext, {}) 29 | -------------------------------------------------------------------------------- /examples/clicker/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /examples/helloworld/README.md: -------------------------------------------------------------------------------- 1 | # Arda HelloWorld Example 2 | 3 | ``` 4 | sh build.sh 5 | open index.html 6 | ``` 7 | -------------------------------------------------------------------------------- /examples/helloworld/build.sh: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env 2 | 3 | browserify -t coffeeify --extension=".coffee" -o bundle.js index.coffee 4 | -------------------------------------------------------------------------------- /examples/helloworld/index.coffee: -------------------------------------------------------------------------------- 1 | window.React = require 'react' 2 | window.Promise = require 'bluebird' 3 | Arda = require '../../src/' 4 | 5 | HelloComponent = React.createClass 6 | mixins: [Arda.mixin] 7 | render: -> 8 | React.createElement 'h1', {}, 'Hello Arda' 9 | 10 | class HelloContext extends Arda.Context 11 | component: HelloComponent 12 | 13 | window.addEventListener 'DOMContentLoaded', -> 14 | router = new Arda.Router(Arda.DefaultLayout, document.body) 15 | router.pushContext(HelloContext, {}) 16 | -------------------------------------------------------------------------------- /examples/helloworld/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /examples/transition/README.md: -------------------------------------------------------------------------------- 1 | # Arda Transition Example 2 | 3 | ``` 4 | sh build.sh 5 | open index.html 6 | ``` 7 | -------------------------------------------------------------------------------- /examples/transition/build.sh: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env 2 | 3 | browserify -t coffeeify --extension=".coffee" -o bundle.js index.coffee 4 | -------------------------------------------------------------------------------- /examples/transition/index.coffee: -------------------------------------------------------------------------------- 1 | window.React = require 'react' 2 | window.Promise = require 'bluebird' 3 | Arda = require '../../src/' 4 | 5 | class MainContext extends Arda.Context 6 | component: 7 | Main = React.createClass 8 | mixins: [Arda.mixin] 9 | render: -> 10 | React.createElement 'h1', {}, 'Main' 11 | 12 | class SubContext extends Arda.Context 13 | component: 14 | Sub = React.createClass 15 | mixins: [Arda.mixin] 16 | render: -> 17 | React.createElement 'h1', {}, 'Sub' 18 | 19 | window.addEventListener 'DOMContentLoaded', -> 20 | window.router = new Arda.Router(Arda.DefaultLayout, document.body) 21 | router.pushContext(MainContext, {}) # Main 22 | .then => router.pushContext(SubContext, {}) # Main, Sub 23 | .then => router.pushContext(MainContext, {}) # Main, Sub, Main 24 | .then => router.popContext() # Main, Sub 25 | .then => router.replaceContext(MainContext, {}) # Main, Main 26 | .then => router.replaceContext(SubContext, {}) # Main, Sub 27 | .then => console.log router.history 28 | -------------------------------------------------------------------------------- /examples/transition/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /examples/typescript/.gitignore: -------------------------------------------------------------------------------- 1 | typings 2 | index.js 3 | -------------------------------------------------------------------------------- /examples/typescript/build.sh: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env 2 | dtsm install 3 | tsc -t es6 index.ts 4 | browserify -o bundle.js index.js 5 | -------------------------------------------------------------------------------- /examples/typescript/dtsm.json: -------------------------------------------------------------------------------- 1 | { 2 | "repos": [ 3 | { 4 | "url": "https://github.com/borisyankov/DefinitelyTyped.git", 5 | "ref": "master" 6 | } 7 | ], 8 | "path": "typings", 9 | "bundle": "typings/bundle.d.ts", 10 | "dependencies": { 11 | "node/node.d.ts": { 12 | "ref": "7d298be1db15bbd1e17638b9c37423efc38fa602" 13 | } 14 | } 15 | } 16 | -------------------------------------------------------------------------------- /examples/typescript/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /examples/typescript/index.ts: -------------------------------------------------------------------------------- 1 | /// 2 | /// 3 | 4 | declare var React: any; 5 | global.React = require('react'); 6 | //global.Promise = require('bluebird');*/ 7 | global.Arda = require('../../lib'); 8 | 9 | interface Props {firstName: string; lastName: string;} 10 | interface State {age: number;} 11 | interface ComponentProps {greeting: string;} 12 | 13 | class MyContext extends Arda.Context { 14 | get component() { 15 | return React.createClass({ 16 | mixins: [Arda.mixin], 17 | render: function(){return React.createElement('h1', {}, this.props.greeting);} 18 | }); 19 | } 20 | 21 | initState(props){ 22 | // Can use promise (State | Promise) 23 | return new Promise(done => { 24 | setTimeout(done({age:10}), 1000) 25 | }) 26 | } 27 | expandComponentProps(props, state) { 28 | // Can use promise (ComponentProps | Promise) 29 | return {greeting: 'Hello, '+props.firstName+', '+state.age+' years old'} 30 | } 31 | } 32 | 33 | window.addEventListener('DOMContentLoaded', () => { 34 | var router = new Arda.Router(Arda.DefaultLayout, document.body); 35 | // Unfortunately, initial props by router are not validated yet 36 | // If you want, you can create your original router wrapper 37 | router.pushContext(MyContext, {firstName: 'Jonh', lastName: 'Doe'}) 38 | .then(context => { 39 | setInterval(() => { 40 | context.state(state => {age: state.age+1}) // this is validated 41 | }, 1000 * 60 * 60 * 24 * 360) // fire once by each year haha:) 42 | }) 43 | }); 44 | -------------------------------------------------------------------------------- /examples/website-router/README.md: -------------------------------------------------------------------------------- 1 | # Arda HelloWorld Example 2 | 3 | ``` 4 | sh build.sh 5 | open index.html 6 | ``` 7 | -------------------------------------------------------------------------------- /examples/website-router/build.sh: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env 2 | 3 | browserify -t babelify -o bundle.js index.js 4 | -------------------------------------------------------------------------------- /examples/website-router/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /examples/website-router/index.js: -------------------------------------------------------------------------------- 1 | window.React = require('react'); 2 | const Arda = require('../../lib'); 3 | const $ = React.createElement; 4 | const App = React.createClass({ 5 | mixins: [Arda.mixin], 6 | render() { 7 | return $('div', {}, [ 8 | $('h1', {}, this.props.name), 9 | $('a', {href:'#foo'}, 'foo'), 10 | $('a', {href:'#bar'}, 'bar'), 11 | $('a', {href:'#baz'}, 'baz') 12 | ]); 13 | } 14 | }); 15 | 16 | class AppContext extends Arda.Context { 17 | get component() { 18 | return App; 19 | } 20 | 21 | expandComponentProps(props, state) { 22 | return {name: props.name}; 23 | } 24 | 25 | dispose() { 26 | super.dispose(); 27 | console.log('disposed:', this); 28 | } 29 | 30 | delegate(subscribe) { 31 | super.delegate(); 32 | subscribe('context:created', () => console.log('created', this.props.name)); 33 | } 34 | }; 35 | 36 | let Router = require('@mizchi/router'); 37 | var router; 38 | window.addEventListener('hashchange', () => { 39 | router.emit(location.hash) 40 | }); 41 | 42 | window.addEventListener('DOMContentLoaded', () => { 43 | // arda 44 | var ardaRouter = new Arda.Router(Arda.DefaultLayout, document.body); 45 | ardaRouter.setMaxHistory(3); // Cache only last 3 context 46 | 47 | // router 48 | router = new Router({hash: true}); 49 | router.route(':context', params => { 50 | ardaRouter.pushContext(AppContext, {name: 'context:' + params.context}); 51 | }); 52 | router.route('', params => { 53 | ardaRouter.pushContext(AppContext, {name: 'root'}); 54 | }); 55 | 56 | // emit first manually 57 | if (location.hash === '') { 58 | ardaRouter.pushContext(AppContext, {name: 'root'}); 59 | } else { 60 | router.emit(location.hash); 61 | } 62 | }); 63 | -------------------------------------------------------------------------------- /index.d.ts: -------------------------------------------------------------------------------- 1 | // Arda, also known as the Earth, was the world in which Elves, Men, Dwarves, and Hobbits live. 2 | // ref. http://lotr.wikia.com/wiki/Arda 3 | declare module Arda { 4 | export class Router { 5 | // mount on element with layout component 6 | // example. 7 | // new Arda.Router(Arda.DefaultLayout, document.body); 8 | constructor(layout: typeof Component, elOrMountFunc: HTMLElement | Function); 9 | 10 | // history push with promise 11 | // example. 12 | // var router = new Arda.Router(Arda.DefaultLayout, document.body); 13 | pushContext(context: typeof Context, args?: any): Promise>; 14 | 15 | // history push and wait next context's finish 16 | pushContextAndWaitForBack(context: typeof Context, args?: any): Promise>; 17 | 18 | // historay replace with promise 19 | replaceContext(context: typeof Context, args?: any): Promise>; 20 | 21 | // historay pop with promise 22 | popContext(): Promise>; 23 | } 24 | 25 | export var mixin: { 26 | dispatch: (eventName: string, ...args: any[]) => boolean; 27 | }; 28 | 29 | // Arda.Component extends React.Component 30 | export class Component { 31 | refs: any; 32 | props: ComponentProps; 33 | state: InternalState; 34 | dispatch: (eventName: string, ...args: any[]) => boolean; 35 | } 36 | 37 | // Arda.Component extends React.Component 38 | export class DefaultLayout extends Component<{}, { 39 | // Top context on history 40 | activeContext: Context; 41 | 42 | // last template props 43 | templateProps: ComponentProps; 44 | }> {} 45 | 46 | export class DispatcherButton { 47 | props: { 48 | event: string; 49 | args: any[]; 50 | } 51 | } 52 | 53 | export class Context { 54 | // root component of this context 55 | component: typeof Component; 56 | 57 | // active / pause / disposed 58 | lifecycle: string; 59 | 60 | // static subscribers are automatically delegated at instantiate 61 | // example 62 | // class MyContext extends Context 63 | // static subscribers: [ 64 | // require('./lifecycle-subscriber'), 65 | // (context: MyContext, subscribe) => { 66 | // subscribe('my:update', () => console.log('updated')) 67 | // } 68 | subscribers: (( 69 | self: any, 70 | subscribe: (eventName: string, ...args: any[]) => any 71 | ) => any)[]; 72 | 73 | delegate( 74 | fn: ( 75 | subscribe: 76 | ((eventName: string, fn?: (...args: any[]) => any) => any) 77 | ) => void 78 | ) 79 | 80 | // Immutable object given by pushContext 81 | props: Props; 82 | 83 | // Mutable object update by initState and context.update 84 | state: State; 85 | 86 | getActiveComponent(): Component; 87 | initState(p: Props): State | Promise; 88 | expandComponentProps(p: Props, s: State): ComponentProps | Promise; 89 | update(updater?: (s: State) => (State | void)): Promise; 90 | } 91 | 92 | // Type checking helper for typescript 93 | export function subscriber 94 | ( 95 | fn: ( 96 | context: Context, 97 | subscribe: 98 | ((eventName: string, fn?: (...args: any[]) => any) => any) 99 | ) => void 100 | ): 101 | ( 102 | fn: ( 103 | context: Context, 104 | subscribe: 105 | ((eventName: string, fn?: (...args: any[]) => any) => any) 106 | ) => void 107 | ) => void 108 | } 109 | -------------------------------------------------------------------------------- /node.js: -------------------------------------------------------------------------------- 1 | // for node.js environment 2 | module.exports = function(React) { 3 | global.React = React; 4 | var Arda = require('./lib/index'); 5 | return Arda; 6 | } 7 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "arda", 3 | "version": "0.16.0", 4 | "description": "Flux with application transition", 5 | "repository": "mizchi/arda", 6 | "main": "lib/index.js", 7 | "scripts": { 8 | "prepublish": "$(npm bin)/coffee -o lib -c src/*", 9 | "build": "$(npm bin)/coffee -o lib -c src/*", 10 | "test": "$(npm bin)/mocha --require espower-coffee/guess test/*.coffee -t 100" 11 | }, 12 | "author": "", 13 | "license": "MIT", 14 | "dependencies": {}, 15 | "peerDdependencies": { 16 | "react": "*", 17 | "react-dom": "*" 18 | }, 19 | "devDependencies": { 20 | "@mizchi/router": "0.0.2", 21 | "babelify": "^6.2.0", 22 | "cheerio": "^0.18.0", 23 | "coffee-script": "^1.9.0", 24 | "coffeeify": "^1.0.0", 25 | "espower-coffee": "^0.10.0", 26 | "jsdom": "^9.11.0", 27 | "mocha": "^2.1.0", 28 | "power-assert": "^0.10.1", 29 | "react": "^15.4.2", 30 | "react-dom": "^15.4.2", 31 | "sinon": "^1.12.2", 32 | "source-map-support": "^0.2.9" 33 | } 34 | } 35 | -------------------------------------------------------------------------------- /src/context.coffee: -------------------------------------------------------------------------------- 1 | EventEmitter = require 'events' 2 | React = require 'react' 3 | 4 | # Context mixin React.Component 5 | module.exports = 6 | class Context extends EventEmitter 7 | ##### Properties ##### 8 | # static contextType: Object 9 | # props: Props 10 | # state: State 11 | # lifecycle: string; 12 | # _component: Component 13 | ###################### 14 | 15 | constructor: (@_component, @props) -> 16 | super 17 | subscribers = @subscribers ? [] 18 | @_onDisposes = [] 19 | @lifecycle = null 20 | @state = null 21 | 22 | @delegate (eventName, callback) => 23 | if callback? 24 | return @on eventName, callback 25 | else 26 | unless Rx? 27 | throw new Error 'you need callback as second argument if you don\'t have Rx' 28 | return Rx.Node.fromEvent @, eventName 29 | 30 | dispose: -> 31 | Promise.all(@_onDisposes) 32 | 33 | getActiveComponent: -> @_component.refs.root 34 | 35 | delegate: (subscribe) -> 36 | subscribers = @subscribers ? [] 37 | subscribers.forEach (subscriber) => 38 | subscriber @, subscribe 39 | 40 | # (State => State)? => Promise 41 | update: (stateFn = null) -> 42 | Promise.resolve( 43 | if !@state? and @props 44 | Promise.resolve(@initState(@props)) 45 | .then (@state) => Promise.resolve() 46 | ) 47 | .then => 48 | nextState = stateFn?(@state) ? @state 49 | # ignore undefined 50 | if nextState? 51 | @state = nextState 52 | 53 | @expandComponentProps(@props, @state) 54 | .then (templateProps) => 55 | # Stop if 56 | if @lifecycle in ['paused', 'disposed'] 57 | return Promise.reject new Error('Context is not active but tried to update') 58 | @_component.setState 59 | activeContext: @ 60 | templateProps: templateProps 61 | 62 | # Override 63 | # Props -> Promise 64 | initState: (props) -> props 65 | 66 | # Override 67 | # Props, State -> Promise 68 | expandComponentProps: (props, state) -> props 69 | 70 | # Override 71 | # Register 72 | render: (templateProps = {}) -> 73 | component = React.createFactory(@component) 74 | component(templateProps) 75 | 76 | # Props => () 77 | # Update internal props and state 78 | _initByProps: (@props) -> new Promise (done) => 79 | Promise.resolve(@initState(@props)) 80 | .then (@state) => done() 81 | -------------------------------------------------------------------------------- /src/default-layout.coffee: -------------------------------------------------------------------------------- 1 | React = require 'react' 2 | T = React.PropTypes 3 | module.exports = React.createClass 4 | childContextTypes: 5 | shared: T.object 6 | 7 | contextTypes: 8 | ctx: T.object 9 | 10 | getChildContext: -> 11 | # shared: @state.activeContext 12 | shared: @getContext() 13 | 14 | getContext: -> this.state.activeContext or @context.shared 15 | # return this.props.shared or (@context and @context.shared) 16 | 17 | getInitialState: -> 18 | activeContext: null 19 | templateProps: {} 20 | 21 | render: -> 22 | if @state.activeContext? 23 | @state.templateProps.ref = 'root' 24 | React.createFactory(@state.activeContext?.component)(@state.templateProps) 25 | else 26 | React.createElement 'div' 27 | -------------------------------------------------------------------------------- /src/dispatcher-button.coffee: -------------------------------------------------------------------------------- 1 | React = require 'react' 2 | mixin = require './mixin' 3 | module.exports = React.createClass 4 | mixins: [mixin] 5 | propTypes: 6 | event: React.PropTypes.any.isRequired 7 | args: React.PropTypes.any 8 | className: React.PropTypes.string 9 | render: -> 10 | rootElement = 11 | if (typeof @props.children) is 'string' 12 | 'button' 13 | else 14 | 'span' 15 | args = @props.args ? [] 16 | React.createElement rootElement, { 17 | className: @props.className ? 'arda-dispatcher-button' 18 | onClick: => @dispatch @props.event, args... 19 | }, @props.children 20 | -------------------------------------------------------------------------------- /src/index.coffee: -------------------------------------------------------------------------------- 1 | module.exports = Arda = {} 2 | Arda.Context = require './context' 3 | Arda.DefaultLayout = require './default-layout' 4 | Arda.DispatcherButton = require './dispatcher-button' 5 | Arda.Router = require './router' 6 | Arda.mixin = require './mixin' 7 | Arda.subscriber = (id) -> id # for typescript 8 | -------------------------------------------------------------------------------- /src/mixin.coffee: -------------------------------------------------------------------------------- 1 | React = require 'react' 2 | DispatcherButton = require './dispatcher-button' 3 | module.exports = 4 | contextTypes: 5 | shared: React.PropTypes.any 6 | 7 | dispatch: -> 8 | @context.shared.emit arguments... 9 | 10 | DispatcherButton: DispatcherButton 11 | 12 | createChildRouter: (node) -> 13 | Router = require './router' 14 | DefaultLayout = require './default-layout' 15 | 16 | childRouter = new Router(DefaultLayout, node) 17 | childRouter 18 | 19 | createContextOnNode: (node, contextClass, props) -> 20 | childRouter = @createChildRouter(node) 21 | childRouter.pushContext(contextClass, props) 22 | .then (context) => Promise.resolve(context) 23 | -------------------------------------------------------------------------------- /src/router.coffee: -------------------------------------------------------------------------------- 1 | React = require('react') 2 | ReactDOM = require('react-dom') 3 | ReactDOMServer = require('react-dom/server') 4 | EventEmitter = require 'events' 5 | $ = React.createElement 6 | 7 | module.exports = 8 | class Router extends EventEmitter 9 | # React.Class * ?HTMLElement| (e: ReactComponentClass) => ReactComponent => Router 10 | constructor: (layoutComponent, @_elOrMountFunc)-> 11 | @history = [] 12 | @_max_history = null 13 | @_locked = false 14 | @_disposers = [] 15 | if @_elOrMountFunc 16 | if @_elOrMountFunc instanceof Function 17 | @_rootComponent = @_elOrMountFunc $(layoutComponent, {}) 18 | else 19 | @_rootComponent = ReactDOM.render $(layoutComponent, {}), @_elOrMountFunc 20 | @_rootComponent.isRoot = true 21 | 22 | setMaxHistory: (_max_history) => 23 | if _max_history < 1 24 | throw new Error 'setMaxHistory need more than 1' 25 | @_max_history = _max_history 26 | 27 | # () => boolean 28 | isLocked: => @_locked 29 | 30 | dispose: => 31 | Promise.all @_disposers.map (disposer) => do disposer 32 | .then => new Promsie (done) => 33 | do popUntilBlank = => 34 | if @history.length > 0 35 | @popContext().then => popUntilBlank() 36 | else 37 | done() 38 | .then => 39 | @diposed = true 40 | @_lock = true 41 | delete @history 42 | delete @_disposers 43 | @removeAllListeners() 44 | Object.freeze(@) 45 | if @_elOrMountFunc? and not (@_elOrMountFunc instanceof Function) 46 | React.unmountComponentAtNode(@_elOrMountFunc) 47 | @emit 'router:disposed' 48 | 49 | pushContextAndWaitForBack: (contextClass, initialProps = {}) => 50 | new Promise (done) => 51 | @pushContext(contextClass, initialProps) 52 | .then (context) => 53 | context.on 'context:disposed', done 54 | 55 | # typeof Context => Thenable 56 | pushContext: (contextClass, initialProps = {}) => 57 | @_lock() 58 | 59 | # check 60 | if lastContext = @activeContext 61 | lastContext.emit 'context:paused' 62 | lastContext.lifecycle = 'paused' 63 | 64 | @activeContext = new contextClass @_rootComponent, initialProps 65 | @_mountToParent(@activeContext, initialProps) 66 | .then => 67 | @history.push 68 | name: contextClass.name 69 | props: initialProps 70 | context: @activeContext 71 | 72 | # dispose context that is out of cache 73 | if @_max_history? and @history.length > @_max_history 74 | willDisposeHistory = @history.shift() 75 | if willDisposeHistory 76 | @_disposeContext(willDisposeHistory.context) 77 | 78 | @_unlock() 79 | @activeContext.emit 'context:created' 80 | @activeContext.emit 'context:started' 81 | @activeContext.lifecycle = 'active' 82 | @emit 'router:pushed', @activeContext 83 | .then => 84 | @activeContext 85 | 86 | # () => Thenable 87 | popContext: => 88 | if @history.length <= 0 89 | throw 'history stack is null' 90 | 91 | @_lock() 92 | @history.pop() 93 | 94 | # emit disposed in context.dispose 95 | Promise.resolve( 96 | if lastContext = @activeContext 97 | @_disposeContext(lastContext) 98 | ) 99 | .then => 100 | @activeContext = @history[@history.length-1]?.context 101 | if @activeContext? 102 | @_mountToParent(@activeContext, @activeContext.props, true) 103 | else 104 | @_unmountAll() 105 | .then => 106 | if @activeContext 107 | @activeContext.emit 'context:started' 108 | @activeContext.emit 'context:resumed' 109 | @activeContext.lifecycle = 'active' 110 | @emit 'router:popped', @activeContext 111 | else 112 | @emit 'router:blank' 113 | @_unlock() 114 | .then => 115 | @activeContext 116 | 117 | # () => Thenable 118 | replaceContext: (contextClass, initialProps = {}) => 119 | if @history.length <= 0 120 | throw 'history stack is null' 121 | @_lock() 122 | 123 | lastContext = @activeContext 124 | Promise.resolve( 125 | if lastContext then @_disposeContext(lastContext) else null 126 | ) 127 | .then => 128 | @activeContext = new contextClass @_rootComponent, initialProps 129 | @activeContext.emit 'context:created' 130 | @activeContext.emit 'context:started' 131 | @activeContext.lifecycle = 'active' 132 | @_mountToParent(@activeContext, initialProps) 133 | .then => 134 | @history.pop() 135 | @history.push 136 | name: contextClass.name 137 | props: initialProps 138 | context: @activeContext 139 | @_unlock() 140 | @emit 'router:replaced', @activeContext 141 | 142 | .then => 143 | @activeContext 144 | 145 | # Context * Object => Thenable 146 | _mountToParent: (context, initialProps, reuseState = false) => 147 | @_initContextWithExpanding(context, initialProps, reuseState) 148 | .then (templateProps) => 149 | @_outputByEnv(context, templateProps) 150 | 151 | # () => Thenable 152 | _unmountAll: => 153 | @_outputByEnv(null) 154 | 155 | # React.Element => Thenable 156 | _outputByEnv: (activeContext, props) => 157 | if @_elOrMountFunc? 158 | @_distributeProps(activeContext, props) 159 | else 160 | @_outputToRouterInnerHTML(activeContext, props) 161 | 162 | _distributeProps: (activeContext, props) => 163 | # TODO: now Arda grasp setState error. 164 | # In react-blessed example, first transition failed. I can't guess why yet. 165 | # ref. http://stackoverflow.com/questions/27153166/typeerror-when-using-react-cannot-read-property-firstchild-of-undefined 166 | try 167 | @_rootComponent.setState 168 | activeContext: activeContext 169 | templateProps: props 170 | 171 | # For test dry run 172 | _outputToRouterInnerHTML: (activeContext, templateProps) => 173 | if activeContext 174 | rendered = React.createFactory(activeContext.component)(templateProps) 175 | @innerHTML = ReactDOMServer.renderToString rendered 176 | else 177 | @innerHTML = '' 178 | 179 | _unlock: -> @_locked = false 180 | 181 | _lock: -> @_locked = true 182 | 183 | _disposeContext: (context) => 184 | delete context.props 185 | delete context.state 186 | context.emit 'context:disposed' 187 | context.lifecycle = 'disposed' 188 | context.removeAllListeners?() 189 | context.dispose() 190 | context.disposed = true 191 | Object.freeze(context) 192 | 193 | _initContextWithExpanding: (context, props, reuseState = false) => 194 | if context.state? and reuseState 195 | Promise.resolve( 196 | context.expandComponentProps(context.props, context.state) 197 | ) 198 | else 199 | context._initByProps(props) 200 | .then => context.expandComponentProps(context.props, context.state) 201 | -------------------------------------------------------------------------------- /test/component-test.coffee: -------------------------------------------------------------------------------- 1 | require './spec_helper' 2 | Arda = require '../src' 3 | 4 | React = require 'react' 5 | ReactDOM = require 'react-dom' 6 | 7 | describe "src/component", -> 8 | describe '#dispatch', -> 9 | it 'use shared context emitter', (done) -> 10 | HelloComponent = React.createClass 11 | mixins: [Arda.mixin] 12 | componentDidMount: -> 13 | @dispatch 'foo' 14 | 15 | render: -> 16 | React.createElement 'div' 17 | 18 | class HelloContext extends Arda.Context 19 | subscribers: [ 20 | (context, subscribe) -> 21 | assert context instanceof Arda.Context 22 | subscribe 'foo', (prop) => 23 | subscribe 'bar', => 24 | done() 25 | ] 26 | component: HelloComponent 27 | 28 | router = new Arda.Router(Arda.DefaultLayout, document.body) 29 | router.pushContext(HelloContext, {}).then (context) => 30 | assert context instanceof Arda.Context 31 | context.emit 'bar' 32 | 33 | context 'without Rx', -> 34 | beforeEach -> delete global.Rx 35 | it '`subscribe` throw with 1 argument', (done) -> 36 | HelloComponent = React.createClass 37 | mixins: [Arda.mixin] 38 | componentDidMount: -> @dispatch 'foo' 39 | render: -> React.createElement 'div' 40 | 41 | class HelloContext extends Arda.Context 42 | subscribers: [ 43 | (context, subscribe) -> 44 | try 45 | fooStream = subscribe 'foo' 46 | done 1 47 | catch e 48 | done() 49 | ] 50 | component: HelloComponent 51 | 52 | router = new Arda.Router(Arda.DefaultLayout, document.body) 53 | router.pushContext(HelloContext, {}) 54 | 55 | describe '#createChildRouter', -> 56 | it 'create router', (done)-> 57 | TestComponent = React.createClass 58 | mixins: [Arda.mixin] 59 | componentDidMount: -> 60 | subRouter = @createChildRouter @refs.container 61 | assert subRouter instanceof Arda.Router 62 | done() 63 | 64 | render: -> 65 | React.createElement 'div', {}, [ 66 | React.createElement 'div', {key: 1, ref:'container'} 67 | ] 68 | 69 | c = React.createFactory(TestComponent) 70 | ReactDOM.render c(), document.body 71 | 72 | describe '#createContextOnNode', -> 73 | it 'create context', (done) -> 74 | class Context extends Arda.Context 75 | component: React.createClass 76 | mixins: [Arda.mixin] 77 | componentDidMount: -> 78 | done() 79 | render: -> 80 | React.createElement 'div' 81 | 82 | TestComponent = React.createClass 83 | mixins: [Arda.mixin] 84 | componentDidMount: -> 85 | @createContextOnNode(@refs.container, Context, {}) 86 | 87 | render: -> 88 | React.createElement 'div', {}, [ 89 | React.createElement 'div', {key: 1, ref:'container'} 90 | ] 91 | 92 | c = React.createFactory(TestComponent) 93 | ReactDOM.render c(), document.body 94 | -------------------------------------------------------------------------------- /test/context-test.coffee: -------------------------------------------------------------------------------- 1 | require './spec_helper' 2 | Arda = require '../src' 3 | Context = require '../src/context' 4 | React = require 'react' 5 | ReactDOM = require 'react-dom' 6 | 7 | describe "src/context", -> 8 | describe '#update', -> 9 | it "update state by result of function", -> 10 | class Ctx extends Context 11 | initState: (props) -> {a: 1} 12 | context = new Ctx setState: (templateProps) -> 13 | context.props = {} 14 | context.update((state) => {a: state.a+1}) 15 | .then => 16 | assert.deepEqual context.state, {a: 2} 17 | 18 | it "update with side effect if result of function is undefined ", -> 19 | class Ctx extends Context 20 | initState: (props) -> {a: 1} 21 | context = new Ctx setState: (templateProps) -> 22 | context.props = {} 23 | context.update (state) => state.a = 100; undefined 24 | .then => 25 | assert.deepEqual context.state, {a: 100} 26 | 27 | it "call initState if props is null", -> 28 | initStateSpy = sinon.spy() 29 | updateSpy = sinon.spy() 30 | 31 | class C extends Context 32 | initState: (props) -> 33 | initStateSpy() 34 | {a: 1} 35 | expandComponentProps: (props, state) -> 36 | updateSpy(state.a) 37 | state 38 | 39 | context = new C setState: (templateProps) -> 40 | context.props = {} 41 | 42 | assert !initStateSpy.called 43 | context.update((state) => {a: state.a+1}) 44 | .then => 45 | assert initStateSpy.calledOnce 46 | assert updateSpy.calledWith(2) 47 | context.update((state) => {a: state.a+1}) 48 | .then => 49 | assert initStateSpy.calledOnce 50 | assert updateSpy.calledWith(3) 51 | assert updateSpy.calledTwice 52 | 53 | describe '#render', -> 54 | it "should render child context", -> 55 | class ChildContext extends Arda.Context 56 | component: React.createClass 57 | mixins: [React.mixin] 58 | render: -> React.createElement 'h1', {}, 'Child' 59 | 60 | Parent = React.createClass 61 | mixins: [React.mixin] 62 | render: -> 63 | child = new ChildContext 64 | React.createElement 'div', {}, [ 65 | React.createElement 'h1', {}, 'Parent' 66 | child.render({}) 67 | ] 68 | ReactDOM.render React.createFactory(Parent)({}), document.body 69 | assert document.body.innerHTML.indexOf('Parent') > -1 70 | assert document.body.innerHTML.indexOf('Child') > -1 71 | 72 | it "should update render on child", -> 73 | class ChildContext extends Arda.Context 74 | component: React.createClass 75 | mixins: [React.mixin] 76 | render: -> React.createElement 'h1', {}, 'Child' 77 | 78 | Parent = React.createClass 79 | mixins: [React.mixin] 80 | render: -> 81 | child = new ChildContext 82 | React.createElement 'div', {}, [ 83 | React.createElement 'h1', {}, 'Parent' 84 | child.render({}) 85 | ] 86 | ReactDOM.render React.createFactory(Parent)({}), document.body 87 | assert document.body.innerHTML.indexOf('Parent') > -1 88 | assert document.body.innerHTML.indexOf('Child') > -1 89 | -------------------------------------------------------------------------------- /test/router-test.coffee: -------------------------------------------------------------------------------- 1 | require './spec_helper' 2 | Arda = require '../src/index' 3 | 4 | describe "src/router", -> 5 | describe '#pushContextAndWaitForBack', -> 6 | it "will mount target by pushContext", (done) -> 7 | router = new Arda.Router Arda.DefaultLayout, document.body 8 | class AutoEndContext extends Arda.Context 9 | component: React.createClass 10 | mixins: [Arda.mixin] 11 | componentWillMount: -> 12 | # It cause back to here 13 | setTimeout => router.popContext() 14 | render: -> React.createElement 'div', {}, 'test' 15 | 16 | class TestContext extends Arda.Context 17 | component: React.createClass 18 | mixins: [Arda.mixin] 19 | render: -> React.createElement 'div', {}, 'test' 20 | router.pushContext(TestContext, {}) 21 | .then => 22 | assert router.pushContextAndWaitForBack instanceof Function 23 | router.pushContextAndWaitForBack(AutoEndContext, {}) 24 | .then => 25 | done() 26 | 27 | describe '#pushContext', -> 28 | it "will mount target by pushContext", (done) -> 29 | class TestContext extends Arda.Context 30 | component: React.createClass 31 | mixins: [Arda.mixin] 32 | componentWillMount: -> done() 33 | render: -> React.createElement 'div', {}, 'test' 34 | router = new Arda.Router Arda.DefaultLayout, null 35 | router.pushContext(TestContext, {}) 36 | 37 | it "will render template by default", -> 38 | class TestContext extends Arda.Context 39 | component: React.createClass 40 | mixins: [Arda.mixin] 41 | render: -> React.createElement 'div', {className: 'name'}, 'my name is '+@props.name 42 | 43 | router = new Arda.Router Arda.DefaultLayout, null 44 | router.pushContext(TestContext, {name: 'john doe'}) 45 | .then -> 46 | console.log('router', router) 47 | assert $$(router.innerHTML)('.name').text() is 'my name is john doe' 48 | 49 | it "will render template with initState and expandComponentProps", -> 50 | class TestContext extends Arda.Context 51 | initState: (props) -> name: props.name + ' foo' 52 | expandComponentProps: (props, state) -> name: state.name + ' bar' 53 | component: React.createClass 54 | mixins: [Arda.mixin] 55 | render: -> React.createElement 'div', {className: 'name'}, 'my name is '+@props.name 56 | router = new Arda.Router Arda.DefaultLayout, null 57 | router.pushContext(TestContext, {name: 'john'}).then -> 58 | assert $$(router.innerHTML)('.name').text() is 'my name is john foo bar' 59 | 60 | it "will render template with initState and expandComponentProps with Promise", -> 61 | class TestContext extends Arda.Context 62 | initState: (props) -> new Promise (done) -> 63 | done name: props.name + ' foo' 64 | expandComponentProps: (props, state) -> new Promise (done) -> 65 | done name: state.name + ' bar' 66 | component: React.createClass 67 | mixins: [Arda.mixin] 68 | render: -> React.createElement 'div', {className: 'name'}, 'my name is '+@props.name 69 | 70 | router = new Arda.Router Arda.DefaultLayout, null 71 | router.pushContext(TestContext, {name: 'john'}).then -> 72 | assert $$(router.innerHTML)('.name').text() is 'my name is john foo bar' 73 | 74 | it "will dispose context that is out of cache", (done) -> 75 | class TestContext extends Arda.Context 76 | component: React.createClass 77 | mixins: [Arda.mixin] 78 | # componentWillMount: -> done() 79 | render: -> React.createElement 'div', {}, 'test' 80 | router = new Arda.Router Arda.DefaultLayout, null 81 | router.setMaxHistory(1) 82 | c1 = null 83 | router.pushContext(TestContext, {}) 84 | .then (context) -> 85 | c1 = context 86 | router.pushContext(TestContext, {}) 87 | .then (context) -> 88 | assert.ok c1.disposed 89 | assert router.history.length is 1 90 | done() 91 | 92 | describe '#popContext', -> 93 | it "throws at blank", (done) -> 94 | router = new Arda.Router Arda.DefaultLayout, null 95 | try 96 | router.popContext() 97 | done 1 98 | catch 99 | done() 100 | 101 | it "dispose last context", -> 102 | class Context extends Arda.Context 103 | component: React.createClass 104 | mixins: [Arda.mixin] 105 | render: -> React.createElement 'div', {className: 'name'} 106 | router = new Arda.Router Arda.DefaultLayout, null 107 | router.pushContext(Context, {}) 108 | .then -> 109 | assert router.history.length is 1 110 | router.popContext() 111 | .then -> 112 | assert router.history.length is 0 113 | assert !router.activeContext? 114 | 115 | describe '#replaceContext', -> 116 | it "throws at blank", (done) -> 117 | class Context1 extends Arda.Context 118 | component: React.createClass 119 | mixins: [Arda.mixin] 120 | render: -> React.createElement 'div', {}, 'context1' 121 | router = new Arda.Router Arda.DefaultLayout, null 122 | try 123 | router.replaceContext(Context1, {}) 124 | done 1 125 | catch 126 | done() 127 | 128 | it "replace active context", -> 129 | class Context1 extends Arda.Context 130 | component: React.createClass 131 | mixins: [Arda.mixin] 132 | render: -> React.createElement 'div', {}, 'context1' 133 | 134 | class Context2 extends Arda.Context 135 | component: React.createClass 136 | mixins: [Arda.mixin] 137 | render: -> React.createElement 'div', {}, 'context2' 138 | 139 | router = new Arda.Router Arda.DefaultLayout, null 140 | router.pushContext(Context1, {}) 141 | .then -> 142 | assert router.history.length is 1 143 | router.replaceContext(Context2, {}) 144 | .then -> 145 | assert router.history.length is 1 146 | 147 | it "fire disposed", (done) -> 148 | class Context1 extends Arda.Context 149 | component: React.createClass 150 | mixins: [Arda.mixin] 151 | render: -> React.createElement 'div', {}, '' 152 | 153 | spy = sinon.spy() 154 | class Context2 extends Arda.Context 155 | subscribers: [ 156 | (context, subscribe) -> 157 | subscribe 'context:disposed' , -> spy 'disposed' 158 | ] 159 | component: React.createClass 160 | mixins: [Arda.mixin] 161 | render: -> React.createElement 'div', {}, '' 162 | 163 | # subscribe: (subscribe) -> 164 | # subscribe 'disposed' , -> spy 'disposed' 165 | 166 | router = new Arda.Router Arda.DefaultLayout, null 167 | router.pushContext(Context1, {}) 168 | .then -> router.pushContext(Context2, {}) 169 | .then -> router.popContext() 170 | .then -> 171 | assert spy.calledWith('disposed') 172 | assert spy.callCount is 1 173 | done() 174 | 175 | describe '#isLocked', -> 176 | it "return true if on pushContext or popContext", -> 177 | class TestContext extends Arda.Context 178 | expandComponentProps: (props, state) -> new Promise (_done) -> 179 | setTimeout -> _done {} 180 | 181 | dispose: -> new Promise (_done) => 182 | super 183 | setTimeout -> _done {} 184 | 185 | component: React.createClass 186 | mixins: [Arda.mixin] 187 | render: -> React.createElement 'div', {className: 'name'} 188 | 189 | router = new Arda.Router Arda.DefaultLayout, null 190 | pushing = router.pushContext(TestContext, {}) 191 | assert router.isLocked() is true 192 | pushing.then -> 193 | assert router.isLocked() is false 194 | replacing = router.replaceContext(TestContext, {}) 195 | assert router.isLocked() is true 196 | replacing 197 | .then -> 198 | assert router.isLocked() is false 199 | popping = router.popContext() 200 | assert router.isLocked() is true 201 | popping 202 | .then -> 203 | assert router.isLocked() is false 204 | 205 | context 'withDOM', -> 206 | it 'render', -> 207 | class Context1 extends Arda.Context 208 | component: React.createClass 209 | mixins: [Arda.mixin] 210 | render: -> React.createElement 'div', {className: 'content'}, @props.name 211 | router = new Arda.Router Arda.DefaultLayout, document.body 212 | router.pushContext(Context1, {name: 1}) 213 | .then -> 214 | assert $$(document.body.innerHTML)('.content').text() is '1' 215 | router.pushContext(Context1, {name: 2}) 216 | .then -> 217 | assert $$(document.body.innerHTML)('.content').text() is '2' 218 | 219 | it 'update' , -> 220 | class Context1 extends Arda.Context 221 | initState: (props) -> props 222 | expandComponentProps: (props, state) -> state 223 | component: React.createClass 224 | mixins: [Arda.mixin] 225 | render: -> React.createElement 'div', {className: 'content'}, @props.name 226 | 227 | router = new Arda.Router Arda.DefaultLayout, document.body 228 | router.pushContext(Context1, {name: 1}) 229 | .then -> router.activeContext.update((state) => {name: 2}) 230 | .then -> 231 | assert $$(document.body.innerHTML)('.content').text() is '2' 232 | 233 | describe 'Lifecycle', -> 234 | it "fires created | started | resumed | disposed", -> 235 | spy = sinon.spy() 236 | class Context1 extends Arda.Context 237 | component: React.createClass 238 | mixins: [Arda.mixin] 239 | render: -> React.createElement 'div', {}, '' 240 | subscribers: [ 241 | (component, subscribe) -> 242 | subscribe 'context:created', -> spy 'created' 243 | subscribe 'context:started', -> spy 'started' 244 | subscribe 'context:paused' , -> spy 'paused' 245 | subscribe 'context:resumed' , -> spy 'resumed' 246 | ] 247 | class Context2 extends Arda.Context 248 | component: React.createClass 249 | mixins: [Arda.mixin] 250 | render: -> React.createElement 'div', {}, '' 251 | 252 | router = new Arda.Router Arda.DefaultLayout, null 253 | assert !router.activeContext 254 | router.pushContext(Context1, {}).then -> 255 | assert spy.calledWith('created') 256 | assert spy.calledWith('started') 257 | assert spy.callCount is 2 258 | 259 | router.pushContext(Context2, {}) 260 | .then -> 261 | assert spy.calledWith('paused') 262 | assert spy.callCount is 3 263 | router.popContext() 264 | .then -> 265 | assert spy.calledWith('resumed') 266 | assert spy.calledWith('started') 267 | assert spy.callCount is 5 268 | 269 | # describe 'blank', -> 270 | # it 'create child context and dispose', (done) -> 271 | # class SubContext extends Arda.Context 272 | # component: React.createClass 273 | # mixins: [Arda.mixin] 274 | # render: -> 275 | # React.createElement 'h1', {}, 'Sub' 276 | # 277 | # HelloComponent = React.createClass 278 | # mixins: [Arda.mixin] 279 | # createChildRouter: (node) -> 280 | # childRouter = new Arda.Router(Arda.DefaultLayout, node) 281 | # # @context.shared.on 'disposed', => childRouter.dispose?() 282 | # childRouter 283 | # 284 | # createContextOnNode: (node, contextClass, props) -> 285 | # childRouter = @createChildRouter(node) 286 | # childRouter.pushContext(contextClass, props) 287 | # .then (context) => Promise.resolve(context) 288 | # 289 | # componentDidMount: -> 290 | # subRouter = @createChildRouter @refs.container.getDOMNode() 291 | # subRouter.on 'router:blank', -> done() 292 | # subRouter.pushContext(SubContext, {}) 293 | # .then (context) => 294 | # subRouter.popContext() 295 | # 296 | # render: -> 297 | # React.createElement 'div', {}, [ 298 | # React.createElement 'h1', {}, 'Hello Arda' 299 | # React.createElement 'div', {ref:'container'} 300 | # ] 301 | # 302 | # class HelloContext extends Arda.Context 303 | # component: HelloComponent 304 | # 305 | # router = new Arda.Router(Arda.DefaultLayout, document.body) 306 | # router.pushContext(HelloContext, {}) 307 | -------------------------------------------------------------------------------- /test/spec_helper.coffee: -------------------------------------------------------------------------------- 1 | jsdom = require('jsdom').jsdom 2 | global.document = jsdom('') 3 | global.window = document.defaultView 4 | global.navigator = window.navigator 5 | 6 | global.React = require 'react' 7 | global.assert = require 'power-assert' 8 | global.sinon = require 'sinon' 9 | 10 | cheerio = require 'cheerio' 11 | global.$$ = (html) -> cheerio.load html 12 | # console.warn = -> 13 | 14 | beforeEach -> @sinon = sinon.sandbox.create() 15 | afterEach -> 16 | @sinon.restore() 17 | document.body.innerHTML = '' 18 | -------------------------------------------------------------------------------- /yarn.lock: -------------------------------------------------------------------------------- 1 | # THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. 2 | # yarn lockfile v1 3 | 4 | 5 | "@mizchi/router@0.0.2": 6 | version "0.0.2" 7 | resolved "http://registry.npmjs.org/@mizchi/router/-/router-0.0.2.tgz#067d2e65701cdc1e8a0d7f4b9543642d616490d5" 8 | dependencies: 9 | path-to-regexp "^1.2.0" 10 | 11 | CSSselect@~0.4.0: 12 | version "0.4.1" 13 | resolved "https://registry.yarnpkg.com/CSSselect/-/CSSselect-0.4.1.tgz#f8ab7e1f8418ce63cda6eb7bd778a85d7ec492b2" 14 | dependencies: 15 | CSSwhat "0.4" 16 | domutils "1.4" 17 | 18 | CSSwhat@0.4: 19 | version "0.4.7" 20 | resolved "https://registry.yarnpkg.com/CSSwhat/-/CSSwhat-0.4.7.tgz#867da0ff39f778613242c44cfea83f0aa4ebdf9b" 21 | 22 | abab@^1.0.3: 23 | version "1.0.3" 24 | resolved "https://registry.yarnpkg.com/abab/-/abab-1.0.3.tgz#b81de5f7274ec4e756d797cd834f303642724e5d" 25 | 26 | acorn-globals@^3.1.0: 27 | version "3.1.0" 28 | resolved "https://registry.yarnpkg.com/acorn-globals/-/acorn-globals-3.1.0.tgz#fd8270f71fbb4996b004fa880ee5d46573a731bf" 29 | dependencies: 30 | acorn "^4.0.4" 31 | 32 | acorn@^3.1.0: 33 | version "3.3.0" 34 | resolved "https://registry.yarnpkg.com/acorn/-/acorn-3.3.0.tgz#45e37fb39e8da3f25baee3ff5369e2bb5f22017a" 35 | 36 | acorn@^4.0.4: 37 | version "4.0.11" 38 | resolved "https://registry.yarnpkg.com/acorn/-/acorn-4.0.11.tgz#edcda3bd937e7556410d42ed5860f67399c794c0" 39 | 40 | align-text@^0.1.1, align-text@^0.1.3: 41 | version "0.1.4" 42 | resolved "https://registry.yarnpkg.com/align-text/-/align-text-0.1.4.tgz#0cd90a561093f35d0a99256c22b7069433fad117" 43 | dependencies: 44 | kind-of "^3.0.2" 45 | longest "^1.0.1" 46 | repeat-string "^1.5.2" 47 | 48 | alter@~0.2.0: 49 | version "0.2.0" 50 | resolved "https://registry.yarnpkg.com/alter/-/alter-0.2.0.tgz#c7588808617572034aae62480af26b1d4d1cb3cd" 51 | dependencies: 52 | stable "~0.1.3" 53 | 54 | amdefine@>=0.0.4: 55 | version "1.0.1" 56 | resolved "https://registry.yarnpkg.com/amdefine/-/amdefine-1.0.1.tgz#4a5282ac164729e93619bcfd3ad151f817ce91f5" 57 | 58 | ansi-regex@^2.0.0: 59 | version "2.1.1" 60 | resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-2.1.1.tgz#c3b33ab5ee360d86e0e628f0468ae7ef27d654df" 61 | 62 | ansi-styles@^2.2.1: 63 | version "2.2.1" 64 | resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-2.2.1.tgz#b432dd3358b634cf75e1e4664368240533c1ddbe" 65 | 66 | array-equal@^1.0.0: 67 | version "1.0.0" 68 | resolved "https://registry.yarnpkg.com/array-equal/-/array-equal-1.0.0.tgz#8c2a5ef2472fd9ea742b04c77a75093ba2757c93" 69 | 70 | asap@~2.0.3: 71 | version "2.0.5" 72 | resolved "https://registry.yarnpkg.com/asap/-/asap-2.0.5.tgz#522765b50c3510490e52d7dcfe085ef9ba96958f" 73 | 74 | asn1@~0.2.3: 75 | version "0.2.3" 76 | resolved "https://registry.yarnpkg.com/asn1/-/asn1-0.2.3.tgz#dac8787713c9966849fc8180777ebe9c1ddf3b86" 77 | 78 | assert-plus@^0.2.0: 79 | version "0.2.0" 80 | resolved "https://registry.yarnpkg.com/assert-plus/-/assert-plus-0.2.0.tgz#d74e1b87e7affc0db8aadb7021f3fe48101ab234" 81 | 82 | assert-plus@^1.0.0: 83 | version "1.0.0" 84 | resolved "https://registry.yarnpkg.com/assert-plus/-/assert-plus-1.0.0.tgz#f12e0f3c5d77b0b1cdd9146942e4e96c1e4dd525" 85 | 86 | ast-traverse@~0.1.1: 87 | version "0.1.1" 88 | resolved "https://registry.yarnpkg.com/ast-traverse/-/ast-traverse-0.1.1.tgz#69cf2b8386f19dcda1bb1e05d68fe359d8897de6" 89 | 90 | ast-types@0.8.12: 91 | version "0.8.12" 92 | resolved "https://registry.yarnpkg.com/ast-types/-/ast-types-0.8.12.tgz#a0d90e4351bb887716c83fd637ebf818af4adfcc" 93 | 94 | ast-types@0.9.5: 95 | version "0.9.5" 96 | resolved "https://registry.yarnpkg.com/ast-types/-/ast-types-0.9.5.tgz#1a660a09945dbceb1f9c9cbb715002617424e04a" 97 | 98 | asynckit@^0.4.0: 99 | version "0.4.0" 100 | resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" 101 | 102 | aws-sign2@~0.6.0: 103 | version "0.6.0" 104 | resolved "https://registry.yarnpkg.com/aws-sign2/-/aws-sign2-0.6.0.tgz#14342dd38dbcc94d0e5b87d763cd63612c0e794f" 105 | 106 | aws4@^1.2.1: 107 | version "1.6.0" 108 | resolved "https://registry.yarnpkg.com/aws4/-/aws4-1.6.0.tgz#83ef5ca860b2b32e4a0deedee8c771b9db57471e" 109 | 110 | babel-core@^5.0.0: 111 | version "5.8.38" 112 | resolved "https://registry.yarnpkg.com/babel-core/-/babel-core-5.8.38.tgz#1fcaee79d7e61b750b00b8e54f6dfc9d0af86558" 113 | dependencies: 114 | babel-plugin-constant-folding "^1.0.1" 115 | babel-plugin-dead-code-elimination "^1.0.2" 116 | babel-plugin-eval "^1.0.1" 117 | babel-plugin-inline-environment-variables "^1.0.1" 118 | babel-plugin-jscript "^1.0.4" 119 | babel-plugin-member-expression-literals "^1.0.1" 120 | babel-plugin-property-literals "^1.0.1" 121 | babel-plugin-proto-to-assign "^1.0.3" 122 | babel-plugin-react-constant-elements "^1.0.3" 123 | babel-plugin-react-display-name "^1.0.3" 124 | babel-plugin-remove-console "^1.0.1" 125 | babel-plugin-remove-debugger "^1.0.1" 126 | babel-plugin-runtime "^1.0.7" 127 | babel-plugin-undeclared-variables-check "^1.0.2" 128 | babel-plugin-undefined-to-void "^1.1.6" 129 | babylon "^5.8.38" 130 | bluebird "^2.9.33" 131 | chalk "^1.0.0" 132 | convert-source-map "^1.1.0" 133 | core-js "^1.0.0" 134 | debug "^2.1.1" 135 | detect-indent "^3.0.0" 136 | esutils "^2.0.0" 137 | fs-readdir-recursive "^0.1.0" 138 | globals "^6.4.0" 139 | home-or-tmp "^1.0.0" 140 | is-integer "^1.0.4" 141 | js-tokens "1.0.1" 142 | json5 "^0.4.0" 143 | lodash "^3.10.0" 144 | minimatch "^2.0.3" 145 | output-file-sync "^1.1.0" 146 | path-exists "^1.0.0" 147 | path-is-absolute "^1.0.0" 148 | private "^0.1.6" 149 | regenerator "0.8.40" 150 | regexpu "^1.3.0" 151 | repeating "^1.1.2" 152 | resolve "^1.1.6" 153 | shebang-regex "^1.0.0" 154 | slash "^1.0.0" 155 | source-map "^0.5.0" 156 | source-map-support "^0.2.10" 157 | to-fast-properties "^1.0.0" 158 | trim-right "^1.0.0" 159 | try-resolve "^1.0.0" 160 | 161 | babel-plugin-constant-folding@^1.0.1: 162 | version "1.0.1" 163 | resolved "https://registry.yarnpkg.com/babel-plugin-constant-folding/-/babel-plugin-constant-folding-1.0.1.tgz#8361d364c98e449c3692bdba51eff0844290aa8e" 164 | 165 | babel-plugin-dead-code-elimination@^1.0.2: 166 | version "1.0.2" 167 | resolved "https://registry.yarnpkg.com/babel-plugin-dead-code-elimination/-/babel-plugin-dead-code-elimination-1.0.2.tgz#5f7c451274dcd7cccdbfbb3e0b85dd28121f0f65" 168 | 169 | babel-plugin-eval@^1.0.1: 170 | version "1.0.1" 171 | resolved "https://registry.yarnpkg.com/babel-plugin-eval/-/babel-plugin-eval-1.0.1.tgz#a2faed25ce6be69ade4bfec263f70169195950da" 172 | 173 | babel-plugin-inline-environment-variables@^1.0.1: 174 | version "1.0.1" 175 | resolved "https://registry.yarnpkg.com/babel-plugin-inline-environment-variables/-/babel-plugin-inline-environment-variables-1.0.1.tgz#1f58ce91207ad6a826a8bf645fafe68ff5fe3ffe" 176 | 177 | babel-plugin-jscript@^1.0.4: 178 | version "1.0.4" 179 | resolved "https://registry.yarnpkg.com/babel-plugin-jscript/-/babel-plugin-jscript-1.0.4.tgz#8f342c38276e87a47d5fa0a8bd3d5eb6ccad8fcc" 180 | 181 | babel-plugin-member-expression-literals@^1.0.1: 182 | version "1.0.1" 183 | resolved "https://registry.yarnpkg.com/babel-plugin-member-expression-literals/-/babel-plugin-member-expression-literals-1.0.1.tgz#cc5edb0faa8dc927170e74d6d1c02440021624d3" 184 | 185 | babel-plugin-property-literals@^1.0.1: 186 | version "1.0.1" 187 | resolved "https://registry.yarnpkg.com/babel-plugin-property-literals/-/babel-plugin-property-literals-1.0.1.tgz#0252301900192980b1c118efea48ce93aab83336" 188 | 189 | babel-plugin-proto-to-assign@^1.0.3: 190 | version "1.0.4" 191 | resolved "https://registry.yarnpkg.com/babel-plugin-proto-to-assign/-/babel-plugin-proto-to-assign-1.0.4.tgz#c49e7afd02f577bc4da05ea2df002250cf7cd123" 192 | dependencies: 193 | lodash "^3.9.3" 194 | 195 | babel-plugin-react-constant-elements@^1.0.3: 196 | version "1.0.3" 197 | resolved "https://registry.yarnpkg.com/babel-plugin-react-constant-elements/-/babel-plugin-react-constant-elements-1.0.3.tgz#946736e8378429cbc349dcff62f51c143b34e35a" 198 | 199 | babel-plugin-react-display-name@^1.0.3: 200 | version "1.0.3" 201 | resolved "https://registry.yarnpkg.com/babel-plugin-react-display-name/-/babel-plugin-react-display-name-1.0.3.tgz#754fe38926e8424a4e7b15ab6ea6139dee0514fc" 202 | 203 | babel-plugin-remove-console@^1.0.1: 204 | version "1.0.1" 205 | resolved "https://registry.yarnpkg.com/babel-plugin-remove-console/-/babel-plugin-remove-console-1.0.1.tgz#d8f24556c3a05005d42aaaafd27787f53ff013a7" 206 | 207 | babel-plugin-remove-debugger@^1.0.1: 208 | version "1.0.1" 209 | resolved "https://registry.yarnpkg.com/babel-plugin-remove-debugger/-/babel-plugin-remove-debugger-1.0.1.tgz#fd2ea3cd61a428ad1f3b9c89882ff4293e8c14c7" 210 | 211 | babel-plugin-runtime@^1.0.7: 212 | version "1.0.7" 213 | resolved "https://registry.yarnpkg.com/babel-plugin-runtime/-/babel-plugin-runtime-1.0.7.tgz#bf7c7d966dd56ecd5c17fa1cb253c9acb7e54aaf" 214 | 215 | babel-plugin-undeclared-variables-check@^1.0.2: 216 | version "1.0.2" 217 | resolved "https://registry.yarnpkg.com/babel-plugin-undeclared-variables-check/-/babel-plugin-undeclared-variables-check-1.0.2.tgz#5cf1aa539d813ff64e99641290af620965f65dee" 218 | dependencies: 219 | leven "^1.0.2" 220 | 221 | babel-plugin-undefined-to-void@^1.1.6: 222 | version "1.1.6" 223 | resolved "https://registry.yarnpkg.com/babel-plugin-undefined-to-void/-/babel-plugin-undefined-to-void-1.1.6.tgz#7f578ef8b78dfae6003385d8417a61eda06e2f81" 224 | 225 | babelify@^6.2.0: 226 | version "6.4.0" 227 | resolved "https://registry.yarnpkg.com/babelify/-/babelify-6.4.0.tgz#caf43888ba731b876b5567b643eecc66147693a5" 228 | dependencies: 229 | babel-core "^5.0.0" 230 | object-assign "^4.0.0" 231 | 232 | babylon@^5.8.38: 233 | version "5.8.38" 234 | resolved "https://registry.yarnpkg.com/babylon/-/babylon-5.8.38.tgz#ec9b120b11bf6ccd4173a18bf217e60b79859ffd" 235 | 236 | balanced-match@^0.4.1: 237 | version "0.4.2" 238 | resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-0.4.2.tgz#cb3f3e3c732dc0f01ee70b403f302e61d7709838" 239 | 240 | bcrypt-pbkdf@^1.0.0: 241 | version "1.0.1" 242 | resolved "https://registry.yarnpkg.com/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.1.tgz#63bc5dcb61331b92bc05fd528953c33462a06f8d" 243 | dependencies: 244 | tweetnacl "^0.14.3" 245 | 246 | bluebird@^2.9.33: 247 | version "2.11.0" 248 | resolved "https://registry.yarnpkg.com/bluebird/-/bluebird-2.11.0.tgz#534b9033c022c9579c56ba3b3e5a5caafbb650e1" 249 | 250 | boom@2.x.x: 251 | version "2.10.1" 252 | resolved "https://registry.yarnpkg.com/boom/-/boom-2.10.1.tgz#39c8918ceff5799f83f9492a848f625add0c766f" 253 | dependencies: 254 | hoek "2.x.x" 255 | 256 | brace-expansion@^1.0.0: 257 | version "1.1.6" 258 | resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.6.tgz#7197d7eaa9b87e648390ea61fc66c84427420df9" 259 | dependencies: 260 | balanced-match "^0.4.1" 261 | concat-map "0.0.1" 262 | 263 | breakable@~1.0.0: 264 | version "1.0.0" 265 | resolved "https://registry.yarnpkg.com/breakable/-/breakable-1.0.0.tgz#784a797915a38ead27bad456b5572cb4bbaa78c1" 266 | 267 | camelcase@^1.2.1: 268 | version "1.2.1" 269 | resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-1.2.1.tgz#9bb5304d2e0b56698b2c758b08a3eaa9daa58a39" 270 | 271 | caseless@~0.11.0: 272 | version "0.11.0" 273 | resolved "https://registry.yarnpkg.com/caseless/-/caseless-0.11.0.tgz#715b96ea9841593cc33067923f5ec60ebda4f7d7" 274 | 275 | center-align@^0.1.1: 276 | version "0.1.3" 277 | resolved "https://registry.yarnpkg.com/center-align/-/center-align-0.1.3.tgz#aa0d32629b6ee972200411cbd4461c907bc2b7ad" 278 | dependencies: 279 | align-text "^0.1.3" 280 | lazy-cache "^1.0.3" 281 | 282 | chalk@^1.0.0, chalk@^1.1.1: 283 | version "1.1.3" 284 | resolved "https://registry.yarnpkg.com/chalk/-/chalk-1.1.3.tgz#a8115c55e4a702fe4d150abd3872822a7e09fc98" 285 | dependencies: 286 | ansi-styles "^2.2.1" 287 | escape-string-regexp "^1.0.2" 288 | has-ansi "^2.0.0" 289 | strip-ansi "^3.0.0" 290 | supports-color "^2.0.0" 291 | 292 | cheerio@^0.18.0: 293 | version "0.18.0" 294 | resolved "https://registry.yarnpkg.com/cheerio/-/cheerio-0.18.0.tgz#4e1c06377e725b740e996e0dfec353863de677fa" 295 | dependencies: 296 | CSSselect "~0.4.0" 297 | dom-serializer "~0.0.0" 298 | entities "~1.1.1" 299 | htmlparser2 "~3.8.1" 300 | lodash "~2.4.1" 301 | 302 | cliui@^2.1.0: 303 | version "2.1.0" 304 | resolved "https://registry.yarnpkg.com/cliui/-/cliui-2.1.0.tgz#4b475760ff80264c762c3a1719032e91c7fea0d1" 305 | dependencies: 306 | center-align "^0.1.1" 307 | right-align "^0.1.1" 308 | wordwrap "0.0.2" 309 | 310 | clone@~0.1.18: 311 | version "0.1.19" 312 | resolved "https://registry.yarnpkg.com/clone/-/clone-0.1.19.tgz#613fb68639b26a494ac53253e15b1a6bd88ada85" 313 | 314 | coffee-script@^1.10.0, coffee-script@^1.9.0: 315 | version "1.12.4" 316 | resolved "https://registry.yarnpkg.com/coffee-script/-/coffee-script-1.12.4.tgz#fe1bced97fe1fb3927b998f2b45616e0658be1ff" 317 | 318 | coffeeify@^1.0.0: 319 | version "1.2.0" 320 | resolved "https://registry.yarnpkg.com/coffeeify/-/coffeeify-1.2.0.tgz#df2a2facdb18b874327ad753330171c000728239" 321 | dependencies: 322 | coffee-script "^1.10.0" 323 | convert-source-map "^1.1.2" 324 | through "^2.3.8" 325 | 326 | combined-stream@^1.0.5, combined-stream@~1.0.5: 327 | version "1.0.5" 328 | resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.5.tgz#938370a57b4a51dea2c77c15d5c5fdf895164009" 329 | dependencies: 330 | delayed-stream "~1.0.0" 331 | 332 | commander@0.6.1: 333 | version "0.6.1" 334 | resolved "https://registry.yarnpkg.com/commander/-/commander-0.6.1.tgz#fa68a14f6a945d54dbbe50d8cdb3320e9e3b1a06" 335 | 336 | commander@2.3.0: 337 | version "2.3.0" 338 | resolved "https://registry.yarnpkg.com/commander/-/commander-2.3.0.tgz#fd430e889832ec353b9acd1de217c11cb3eef873" 339 | 340 | commander@^2.5.0, commander@^2.9.0: 341 | version "2.9.0" 342 | resolved "https://registry.yarnpkg.com/commander/-/commander-2.9.0.tgz#9c99094176e12240cb22d6c5146098400fe0f7d4" 343 | dependencies: 344 | graceful-readlink ">= 1.0.0" 345 | 346 | commoner@~0.10.3: 347 | version "0.10.8" 348 | resolved "https://registry.yarnpkg.com/commoner/-/commoner-0.10.8.tgz#34fc3672cd24393e8bb47e70caa0293811f4f2c5" 349 | dependencies: 350 | commander "^2.5.0" 351 | detective "^4.3.1" 352 | glob "^5.0.15" 353 | graceful-fs "^4.1.2" 354 | iconv-lite "^0.4.5" 355 | mkdirp "^0.5.0" 356 | private "^0.1.6" 357 | q "^1.1.2" 358 | recast "^0.11.17" 359 | 360 | concat-map@0.0.1: 361 | version "0.0.1" 362 | resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" 363 | 364 | content-type-parser@^1.0.1: 365 | version "1.0.1" 366 | resolved "https://registry.yarnpkg.com/content-type-parser/-/content-type-parser-1.0.1.tgz#c3e56988c53c65127fb46d4032a3a900246fdc94" 367 | 368 | convert-source-map@^0.4.1, convert-source-map@~0.4.1: 369 | version "0.4.1" 370 | resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-0.4.1.tgz#f919a0099fe31f80fc5a1d0eb303161b394070c7" 371 | 372 | convert-source-map@^1.1.0, convert-source-map@^1.1.2: 373 | version "1.4.0" 374 | resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.4.0.tgz#e3dad195bf61bfe13a7a3c73e9876ec14a0268f3" 375 | 376 | core-js@^1.0.0: 377 | version "1.2.7" 378 | resolved "https://registry.yarnpkg.com/core-js/-/core-js-1.2.7.tgz#652294c14651db28fa93bd2d5ff2983a4f08c636" 379 | 380 | core-util-is@~1.0.0: 381 | version "1.0.2" 382 | resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" 383 | 384 | cryptiles@2.x.x: 385 | version "2.0.5" 386 | resolved "https://registry.yarnpkg.com/cryptiles/-/cryptiles-2.0.5.tgz#3bdfecdc608147c1c67202fa291e7dca59eaa3b8" 387 | dependencies: 388 | boom "2.x.x" 389 | 390 | cssom@0.3.x, "cssom@>= 0.3.2 < 0.4.0": 391 | version "0.3.2" 392 | resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.3.2.tgz#b8036170c79f07a90ff2f16e22284027a243848b" 393 | 394 | "cssstyle@>= 0.2.37 < 0.3.0": 395 | version "0.2.37" 396 | resolved "https://registry.yarnpkg.com/cssstyle/-/cssstyle-0.2.37.tgz#541097234cb2513c83ceed3acddc27ff27987d54" 397 | dependencies: 398 | cssom "0.3.x" 399 | 400 | dashdash@^1.12.0: 401 | version "1.14.1" 402 | resolved "https://registry.yarnpkg.com/dashdash/-/dashdash-1.14.1.tgz#853cfa0f7cbe2fed5de20326b8dd581035f6e2f0" 403 | dependencies: 404 | assert-plus "^1.0.0" 405 | 406 | debug@2.2.0, debug@^2.1.1: 407 | version "2.2.0" 408 | resolved "https://registry.yarnpkg.com/debug/-/debug-2.2.0.tgz#f87057e995b1a1f6ae6a4960664137bc56f039da" 409 | dependencies: 410 | ms "0.7.1" 411 | 412 | decamelize@^1.0.0: 413 | version "1.2.0" 414 | resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290" 415 | 416 | deep-equal@~0.2.1: 417 | version "0.2.2" 418 | resolved "https://registry.yarnpkg.com/deep-equal/-/deep-equal-0.2.2.tgz#84b745896f34c684e98f2ce0e42abaf43bba017d" 419 | 420 | deep-is@~0.1.2, deep-is@~0.1.3: 421 | version "0.1.3" 422 | resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.3.tgz#b369d6fb5dbc13eecf524f91b070feedc357cf34" 423 | 424 | defined@^1.0.0: 425 | version "1.0.0" 426 | resolved "https://registry.yarnpkg.com/defined/-/defined-1.0.0.tgz#c98d9bcef75674188e110969151199e39b1fa693" 427 | 428 | defs@~1.1.0: 429 | version "1.1.1" 430 | resolved "https://registry.yarnpkg.com/defs/-/defs-1.1.1.tgz#b22609f2c7a11ba7a3db116805c139b1caffa9d2" 431 | dependencies: 432 | alter "~0.2.0" 433 | ast-traverse "~0.1.1" 434 | breakable "~1.0.0" 435 | esprima-fb "~15001.1001.0-dev-harmony-fb" 436 | simple-fmt "~0.1.0" 437 | simple-is "~0.2.0" 438 | stringmap "~0.2.2" 439 | stringset "~0.2.1" 440 | tryor "~0.1.2" 441 | yargs "~3.27.0" 442 | 443 | delayed-stream@~1.0.0: 444 | version "1.0.0" 445 | resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" 446 | 447 | detect-indent@^3.0.0: 448 | version "3.0.1" 449 | resolved "https://registry.yarnpkg.com/detect-indent/-/detect-indent-3.0.1.tgz#9dc5e5ddbceef8325764b9451b02bc6d54084f75" 450 | dependencies: 451 | get-stdin "^4.0.1" 452 | minimist "^1.1.0" 453 | repeating "^1.1.0" 454 | 455 | detective@^4.3.1: 456 | version "4.3.2" 457 | resolved "https://registry.yarnpkg.com/detective/-/detective-4.3.2.tgz#77697e2e7947ac3fe7c8e26a6d6f115235afa91c" 458 | dependencies: 459 | acorn "^3.1.0" 460 | defined "^1.0.0" 461 | 462 | diff@1.4.0: 463 | version "1.4.0" 464 | resolved "https://registry.yarnpkg.com/diff/-/diff-1.4.0.tgz#7f28d2eb9ee7b15a97efd89ce63dcfdaa3ccbabf" 465 | 466 | dom-serializer@0, dom-serializer@~0.0.0: 467 | version "0.0.1" 468 | resolved "https://registry.yarnpkg.com/dom-serializer/-/dom-serializer-0.0.1.tgz#9589827f1e32d22c37c829adabd59b3247af8eaf" 469 | dependencies: 470 | domelementtype "~1.1.1" 471 | entities "~1.1.1" 472 | 473 | domelementtype@1, domelementtype@~1.1.1: 474 | version "1.1.3" 475 | resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-1.1.3.tgz#bd28773e2642881aec51544924299c5cd822185b" 476 | 477 | domhandler@2.3: 478 | version "2.3.0" 479 | resolved "https://registry.yarnpkg.com/domhandler/-/domhandler-2.3.0.tgz#2de59a0822d5027fabff6f032c2b25a2a8abe738" 480 | dependencies: 481 | domelementtype "1" 482 | 483 | domutils@1.4: 484 | version "1.4.3" 485 | resolved "https://registry.yarnpkg.com/domutils/-/domutils-1.4.3.tgz#0865513796c6b306031850e175516baf80b72a6f" 486 | dependencies: 487 | domelementtype "1" 488 | 489 | domutils@1.5: 490 | version "1.5.1" 491 | resolved "https://registry.yarnpkg.com/domutils/-/domutils-1.5.1.tgz#dcd8488a26f563d61079e48c9f7b7e32373682cf" 492 | dependencies: 493 | dom-serializer "0" 494 | domelementtype "1" 495 | 496 | eastasianwidth@~0.1.0: 497 | version "0.1.1" 498 | resolved "https://registry.yarnpkg.com/eastasianwidth/-/eastasianwidth-0.1.1.tgz#44d656de9da415694467335365fb3147b8572b7c" 499 | 500 | ecc-jsbn@~0.1.1: 501 | version "0.1.1" 502 | resolved "https://registry.yarnpkg.com/ecc-jsbn/-/ecc-jsbn-0.1.1.tgz#0fc73a9ed5f0d53c38193398523ef7e543777505" 503 | dependencies: 504 | jsbn "~0.1.0" 505 | 506 | empower@~0.10.0: 507 | version "0.10.0" 508 | resolved "https://registry.yarnpkg.com/empower/-/empower-0.10.0.tgz#f1eb1309d2be7b711a781df65389b483e0c2ae23" 509 | dependencies: 510 | escallmatch "~1.0.0" 511 | xtend "~4.0.0" 512 | 513 | encoding@^0.1.11: 514 | version "0.1.12" 515 | resolved "https://registry.yarnpkg.com/encoding/-/encoding-0.1.12.tgz#538b66f3ee62cd1ab51ec323829d1f9480c74beb" 516 | dependencies: 517 | iconv-lite "~0.4.13" 518 | 519 | entities@1.0: 520 | version "1.0.0" 521 | resolved "https://registry.yarnpkg.com/entities/-/entities-1.0.0.tgz#b2987aa3821347fcde642b24fdfc9e4fb712bf26" 522 | 523 | entities@~1.1.1: 524 | version "1.1.1" 525 | resolved "https://registry.yarnpkg.com/entities/-/entities-1.1.1.tgz#6e5c2d0a5621b5dadaecef80b90edfb5cd7772f0" 526 | 527 | escallmatch@~1.0.0: 528 | version "1.0.1" 529 | resolved "https://registry.yarnpkg.com/escallmatch/-/escallmatch-1.0.1.tgz#6579074b1681657b1127c069ef9c791aadeb449e" 530 | dependencies: 531 | deep-equal "~0.2.1" 532 | esprima "~1.2.2" 533 | espurify "~1.0.0" 534 | estraverse "~1.8.0" 535 | 536 | escape-string-regexp@1.0.2, escape-string-regexp@^1.0.2: 537 | version "1.0.2" 538 | resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.2.tgz#4dbc2fe674e71949caf3fb2695ce7f2dc1d9a8d1" 539 | 540 | escodegen@^1.6.1: 541 | version "1.8.1" 542 | resolved "https://registry.yarnpkg.com/escodegen/-/escodegen-1.8.1.tgz#5a5b53af4693110bebb0867aa3430dd3b70a1018" 543 | dependencies: 544 | esprima "^2.7.1" 545 | estraverse "^1.9.1" 546 | esutils "^2.0.2" 547 | optionator "^0.8.1" 548 | optionalDependencies: 549 | source-map "~0.2.0" 550 | 551 | escodegen@~1.4.1: 552 | version "1.4.3" 553 | resolved "https://registry.yarnpkg.com/escodegen/-/escodegen-1.4.3.tgz#2b2422bf18c95e2542effaabc0c998712d490291" 554 | dependencies: 555 | esprima "^1.2.2" 556 | estraverse "^1.9.0" 557 | esutils "^1.1.6" 558 | optionator "^0.4.0" 559 | optionalDependencies: 560 | source-map "~0.1.40" 561 | 562 | espower-coffee@^0.10.0: 563 | version "0.10.0" 564 | resolved "https://registry.yarnpkg.com/espower-coffee/-/espower-coffee-0.10.0.tgz#1b605fc26c943b85bbb04d324226805405e3ac97" 565 | dependencies: 566 | convert-source-map "^0.4.1" 567 | espower-source "^0.10.0" 568 | minimatch "^1.0.0" 569 | xtend "^4.0.0" 570 | 571 | espower-source@^0.10.0: 572 | version "0.10.0" 573 | resolved "https://registry.yarnpkg.com/espower-source/-/espower-source-0.10.0.tgz#fb435c94e50a4af8f7f3b47d83a7757724239d2e" 574 | dependencies: 575 | convert-source-map "~0.4.1" 576 | escodegen "~1.4.1" 577 | espower "~0.10.0" 578 | esprima "~1.2.2" 579 | multi-stage-sourcemap "~0.2.1" 580 | xtend "~4.0.0" 581 | 582 | espower@~0.10.0: 583 | version "0.10.0" 584 | resolved "https://registry.yarnpkg.com/espower/-/espower-0.10.0.tgz#48d742aae001675990c875efe7582a2ece99163b" 585 | dependencies: 586 | clone "~0.1.18" 587 | escallmatch "~1.0.0" 588 | escodegen "~1.4.1" 589 | espurify "~1.0.0" 590 | estraverse "~1.7.0" 591 | source-map "~0.1.40" 592 | type-name "~1.0.0" 593 | xtend "~4.0.0" 594 | 595 | esprima-fb@~15001.1001.0-dev-harmony-fb: 596 | version "15001.1001.0-dev-harmony-fb" 597 | resolved "https://registry.yarnpkg.com/esprima-fb/-/esprima-fb-15001.1001.0-dev-harmony-fb.tgz#43beb57ec26e8cf237d3dd8b33e42533577f2659" 598 | 599 | esprima@^1.2.2, esprima@~1.2.2: 600 | version "1.2.5" 601 | resolved "https://registry.yarnpkg.com/esprima/-/esprima-1.2.5.tgz#0993502feaf668138325756f30f9a51feeec11e9" 602 | 603 | esprima@^2.6.0, esprima@^2.7.1: 604 | version "2.7.3" 605 | resolved "https://registry.yarnpkg.com/esprima/-/esprima-2.7.3.tgz#96e3b70d5779f6ad49cd032673d1c312767ba581" 606 | 607 | esprima@~3.1.0: 608 | version "3.1.3" 609 | resolved "https://registry.yarnpkg.com/esprima/-/esprima-3.1.3.tgz#fdca51cee6133895e3c88d535ce49dbff62a4633" 610 | 611 | espurify@~1.0.0: 612 | version "1.0.1" 613 | resolved "https://registry.yarnpkg.com/espurify/-/espurify-1.0.1.tgz#010bfc489ddf3149e97b119d8c6885a1f736f4e2" 614 | dependencies: 615 | indexof "0.0.1" 616 | traverse "~0.6.6" 617 | 618 | estraverse@^1.9.0, estraverse@^1.9.1: 619 | version "1.9.3" 620 | resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-1.9.3.tgz#af67f2dc922582415950926091a4005d29c9bb44" 621 | 622 | estraverse@~1.7.0: 623 | version "1.7.1" 624 | resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-1.7.1.tgz#9282b5c38911eb70ec63ad65254491338ef29d78" 625 | 626 | estraverse@~1.8.0: 627 | version "1.8.0" 628 | resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-1.8.0.tgz#3f1264fb62c8500dbae5e4f73705cd576d6af428" 629 | 630 | esutils@^1.1.6: 631 | version "1.1.6" 632 | resolved "https://registry.yarnpkg.com/esutils/-/esutils-1.1.6.tgz#c01ccaa9ae4b897c6d0c3e210ae52f3c7a844375" 633 | 634 | esutils@^2.0.0, esutils@^2.0.2: 635 | version "2.0.2" 636 | resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.2.tgz#0abf4f1caa5bcb1f7a9d8acc6dea4faaa04bac9b" 637 | 638 | extend@~3.0.0: 639 | version "3.0.0" 640 | resolved "https://registry.yarnpkg.com/extend/-/extend-3.0.0.tgz#5a474353b9f3353ddd8176dfd37b91c83a46f1d4" 641 | 642 | extsprintf@1.0.2: 643 | version "1.0.2" 644 | resolved "https://registry.yarnpkg.com/extsprintf/-/extsprintf-1.0.2.tgz#e1080e0658e300b06294990cc70e1502235fd550" 645 | 646 | fast-levenshtein@~1.0.0: 647 | version "1.0.7" 648 | resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-1.0.7.tgz#0178dcdee023b92905193af0959e8a7639cfdcb9" 649 | 650 | fast-levenshtein@~2.0.4: 651 | version "2.0.6" 652 | resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917" 653 | 654 | fbjs@^0.8.1, fbjs@^0.8.4: 655 | version "0.8.9" 656 | resolved "https://registry.yarnpkg.com/fbjs/-/fbjs-0.8.9.tgz#180247fbd347dcc9004517b904f865400a0c8f14" 657 | dependencies: 658 | core-js "^1.0.0" 659 | isomorphic-fetch "^2.1.1" 660 | loose-envify "^1.0.0" 661 | object-assign "^4.1.0" 662 | promise "^7.1.1" 663 | setimmediate "^1.0.5" 664 | ua-parser-js "^0.7.9" 665 | 666 | forever-agent@~0.6.1: 667 | version "0.6.1" 668 | resolved "https://registry.yarnpkg.com/forever-agent/-/forever-agent-0.6.1.tgz#fbc71f0c41adeb37f96c577ad1ed42d8fdacca91" 669 | 670 | form-data@~2.1.1: 671 | version "2.1.2" 672 | resolved "https://registry.yarnpkg.com/form-data/-/form-data-2.1.2.tgz#89c3534008b97eada4cbb157d58f6f5df025eae4" 673 | dependencies: 674 | asynckit "^0.4.0" 675 | combined-stream "^1.0.5" 676 | mime-types "^2.1.12" 677 | 678 | formatio@1.1.1: 679 | version "1.1.1" 680 | resolved "https://registry.yarnpkg.com/formatio/-/formatio-1.1.1.tgz#5ed3ccd636551097383465d996199100e86161e9" 681 | dependencies: 682 | samsam "~1.1" 683 | 684 | fs-readdir-recursive@^0.1.0: 685 | version "0.1.2" 686 | resolved "https://registry.yarnpkg.com/fs-readdir-recursive/-/fs-readdir-recursive-0.1.2.tgz#315b4fb8c1ca5b8c47defef319d073dad3568059" 687 | 688 | generate-function@^2.0.0: 689 | version "2.0.0" 690 | resolved "https://registry.yarnpkg.com/generate-function/-/generate-function-2.0.0.tgz#6858fe7c0969b7d4e9093337647ac79f60dfbe74" 691 | 692 | generate-object-property@^1.1.0: 693 | version "1.2.0" 694 | resolved "https://registry.yarnpkg.com/generate-object-property/-/generate-object-property-1.2.0.tgz#9c0e1c40308ce804f4783618b937fa88f99d50d0" 695 | dependencies: 696 | is-property "^1.0.0" 697 | 698 | get-stdin@^4.0.1: 699 | version "4.0.1" 700 | resolved "https://registry.yarnpkg.com/get-stdin/-/get-stdin-4.0.1.tgz#b968c6b0a04384324902e8bf1a5df32579a450fe" 701 | 702 | getpass@^0.1.1: 703 | version "0.1.6" 704 | resolved "https://registry.yarnpkg.com/getpass/-/getpass-0.1.6.tgz#283ffd9fc1256840875311c1b60e8c40187110e6" 705 | dependencies: 706 | assert-plus "^1.0.0" 707 | 708 | glob@3.2.11: 709 | version "3.2.11" 710 | resolved "https://registry.yarnpkg.com/glob/-/glob-3.2.11.tgz#4a973f635b9190f715d10987d5c00fd2815ebe3d" 711 | dependencies: 712 | inherits "2" 713 | minimatch "0.3" 714 | 715 | glob@^5.0.15: 716 | version "5.0.15" 717 | resolved "https://registry.yarnpkg.com/glob/-/glob-5.0.15.tgz#1bc936b9e02f4a603fcc222ecf7633d30b8b93b1" 718 | dependencies: 719 | inflight "^1.0.4" 720 | inherits "2" 721 | minimatch "2 || 3" 722 | once "^1.3.0" 723 | path-is-absolute "^1.0.0" 724 | 725 | globals@^6.4.0: 726 | version "6.4.1" 727 | resolved "https://registry.yarnpkg.com/globals/-/globals-6.4.1.tgz#8498032b3b6d1cc81eebc5f79690d8fe29fabf4f" 728 | 729 | googlediff@~0.1.0: 730 | version "0.1.0" 731 | resolved "https://registry.yarnpkg.com/googlediff/-/googlediff-0.1.0.tgz#99acf05cc06223eb66c29008d81f9b2d18c2453d" 732 | 733 | graceful-fs@^4.1.2, graceful-fs@^4.1.4: 734 | version "4.1.11" 735 | resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.1.11.tgz#0e8bdfe4d1ddb8854d64e04ea7c00e2a026e5658" 736 | 737 | "graceful-readlink@>= 1.0.0": 738 | version "1.0.1" 739 | resolved "https://registry.yarnpkg.com/graceful-readlink/-/graceful-readlink-1.0.1.tgz#4cafad76bc62f02fa039b2f94e9a3dd3a391a725" 740 | 741 | growl@1.9.2: 742 | version "1.9.2" 743 | resolved "https://registry.yarnpkg.com/growl/-/growl-1.9.2.tgz#0ea7743715db8d8de2c5ede1775e1b45ac85c02f" 744 | 745 | har-validator@~2.0.6: 746 | version "2.0.6" 747 | resolved "https://registry.yarnpkg.com/har-validator/-/har-validator-2.0.6.tgz#cdcbc08188265ad119b6a5a7c8ab70eecfb5d27d" 748 | dependencies: 749 | chalk "^1.1.1" 750 | commander "^2.9.0" 751 | is-my-json-valid "^2.12.4" 752 | pinkie-promise "^2.0.0" 753 | 754 | has-ansi@^2.0.0: 755 | version "2.0.0" 756 | resolved "https://registry.yarnpkg.com/has-ansi/-/has-ansi-2.0.0.tgz#34f5049ce1ecdf2b0649af3ef24e45ed35416d91" 757 | dependencies: 758 | ansi-regex "^2.0.0" 759 | 760 | hawk@~3.1.3: 761 | version "3.1.3" 762 | resolved "https://registry.yarnpkg.com/hawk/-/hawk-3.1.3.tgz#078444bd7c1640b0fe540d2c9b73d59678e8e1c4" 763 | dependencies: 764 | boom "2.x.x" 765 | cryptiles "2.x.x" 766 | hoek "2.x.x" 767 | sntp "1.x.x" 768 | 769 | hoek@2.x.x: 770 | version "2.16.3" 771 | resolved "https://registry.yarnpkg.com/hoek/-/hoek-2.16.3.tgz#20bb7403d3cea398e91dc4710a8ff1b8274a25ed" 772 | 773 | home-or-tmp@^1.0.0: 774 | version "1.0.0" 775 | resolved "https://registry.yarnpkg.com/home-or-tmp/-/home-or-tmp-1.0.0.tgz#4b9f1e40800c3e50c6c27f781676afcce71f3985" 776 | dependencies: 777 | os-tmpdir "^1.0.1" 778 | user-home "^1.1.1" 779 | 780 | html-encoding-sniffer@^1.0.1: 781 | version "1.0.1" 782 | resolved "https://registry.yarnpkg.com/html-encoding-sniffer/-/html-encoding-sniffer-1.0.1.tgz#79bf7a785ea495fe66165e734153f363ff5437da" 783 | dependencies: 784 | whatwg-encoding "^1.0.1" 785 | 786 | htmlparser2@~3.8.1: 787 | version "3.8.3" 788 | resolved "https://registry.yarnpkg.com/htmlparser2/-/htmlparser2-3.8.3.tgz#996c28b191516a8be86501a7d79757e5c70c1068" 789 | dependencies: 790 | domelementtype "1" 791 | domhandler "2.3" 792 | domutils "1.5" 793 | entities "1.0" 794 | readable-stream "1.1" 795 | 796 | http-signature@~1.1.0: 797 | version "1.1.1" 798 | resolved "https://registry.yarnpkg.com/http-signature/-/http-signature-1.1.1.tgz#df72e267066cd0ac67fb76adf8e134a8fbcf91bf" 799 | dependencies: 800 | assert-plus "^0.2.0" 801 | jsprim "^1.2.2" 802 | sshpk "^1.7.0" 803 | 804 | iconv-lite@0.4.13, iconv-lite@^0.4.5, iconv-lite@~0.4.13: 805 | version "0.4.13" 806 | resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.13.tgz#1f88aba4ab0b1508e8312acc39345f36e992e2f2" 807 | 808 | indexof@0.0.1: 809 | version "0.0.1" 810 | resolved "https://registry.yarnpkg.com/indexof/-/indexof-0.0.1.tgz#82dc336d232b9062179d05ab3293a66059fd435d" 811 | 812 | inflight@^1.0.4: 813 | version "1.0.6" 814 | resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" 815 | dependencies: 816 | once "^1.3.0" 817 | wrappy "1" 818 | 819 | inherits@2, inherits@2.0.1, inherits@~2.0.1: 820 | version "2.0.1" 821 | resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.1.tgz#b17d08d326b4423e568eff719f91b0b1cbdf69f1" 822 | 823 | invert-kv@^1.0.0: 824 | version "1.0.0" 825 | resolved "https://registry.yarnpkg.com/invert-kv/-/invert-kv-1.0.0.tgz#104a8e4aaca6d3d8cd157a8ef8bfab2d7a3ffdb6" 826 | 827 | is-buffer@^1.0.2: 828 | version "1.1.4" 829 | resolved "https://registry.yarnpkg.com/is-buffer/-/is-buffer-1.1.4.tgz#cfc86ccd5dc5a52fa80489111c6920c457e2d98b" 830 | 831 | is-finite@^1.0.0: 832 | version "1.0.2" 833 | resolved "https://registry.yarnpkg.com/is-finite/-/is-finite-1.0.2.tgz#cc6677695602be550ef11e8b4aa6305342b6d0aa" 834 | dependencies: 835 | number-is-nan "^1.0.0" 836 | 837 | is-integer@^1.0.4: 838 | version "1.0.6" 839 | resolved "https://registry.yarnpkg.com/is-integer/-/is-integer-1.0.6.tgz#5273819fada880d123e1ac00a938e7172dd8d95e" 840 | dependencies: 841 | is-finite "^1.0.0" 842 | 843 | is-my-json-valid@^2.12.4: 844 | version "2.15.0" 845 | resolved "https://registry.yarnpkg.com/is-my-json-valid/-/is-my-json-valid-2.15.0.tgz#936edda3ca3c211fd98f3b2d3e08da43f7b2915b" 846 | dependencies: 847 | generate-function "^2.0.0" 848 | generate-object-property "^1.1.0" 849 | jsonpointer "^4.0.0" 850 | xtend "^4.0.0" 851 | 852 | is-property@^1.0.0: 853 | version "1.0.2" 854 | resolved "https://registry.yarnpkg.com/is-property/-/is-property-1.0.2.tgz#57fe1c4e48474edd65b09911f26b1cd4095dda84" 855 | 856 | is-stream@^1.0.1: 857 | version "1.1.0" 858 | resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-1.1.0.tgz#12d4a3dd4e68e0b79ceb8dbc84173ae80d91ca44" 859 | 860 | is-typedarray@~1.0.0: 861 | version "1.0.0" 862 | resolved "https://registry.yarnpkg.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a" 863 | 864 | isarray@0.0.1: 865 | version "0.0.1" 866 | resolved "https://registry.yarnpkg.com/isarray/-/isarray-0.0.1.tgz#8a18acfca9a8f4177e09abfc6038939b05d1eedf" 867 | 868 | isomorphic-fetch@^2.1.1: 869 | version "2.2.1" 870 | resolved "https://registry.yarnpkg.com/isomorphic-fetch/-/isomorphic-fetch-2.2.1.tgz#611ae1acf14f5e81f729507472819fe9733558a9" 871 | dependencies: 872 | node-fetch "^1.0.1" 873 | whatwg-fetch ">=0.10.0" 874 | 875 | isstream@~0.1.2: 876 | version "0.1.2" 877 | resolved "https://registry.yarnpkg.com/isstream/-/isstream-0.1.2.tgz#47e63f7af55afa6f92e1500e690eb8b8529c099a" 878 | 879 | jade@0.26.3: 880 | version "0.26.3" 881 | resolved "https://registry.yarnpkg.com/jade/-/jade-0.26.3.tgz#8f10d7977d8d79f2f6ff862a81b0513ccb25686c" 882 | dependencies: 883 | commander "0.6.1" 884 | mkdirp "0.3.0" 885 | 886 | jodid25519@^1.0.0: 887 | version "1.0.2" 888 | resolved "https://registry.yarnpkg.com/jodid25519/-/jodid25519-1.0.2.tgz#06d4912255093419477d425633606e0e90782967" 889 | dependencies: 890 | jsbn "~0.1.0" 891 | 892 | js-tokens@1.0.1: 893 | version "1.0.1" 894 | resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-1.0.1.tgz#cc435a5c8b94ad15acb7983140fc80182c89aeae" 895 | 896 | js-tokens@^3.0.0: 897 | version "3.0.1" 898 | resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-3.0.1.tgz#08e9f132484a2c45a30907e9dc4d5567b7f114d7" 899 | 900 | jsbn@~0.1.0: 901 | version "0.1.1" 902 | resolved "https://registry.yarnpkg.com/jsbn/-/jsbn-0.1.1.tgz#a5e654c2e5a2deb5f201d96cefbca80c0ef2f513" 903 | 904 | jsdom@^9.11.0: 905 | version "9.11.0" 906 | resolved "https://registry.yarnpkg.com/jsdom/-/jsdom-9.11.0.tgz#a95b0304e521a2ca5a63c6ea47bf7708a7a84591" 907 | dependencies: 908 | abab "^1.0.3" 909 | acorn "^4.0.4" 910 | acorn-globals "^3.1.0" 911 | array-equal "^1.0.0" 912 | content-type-parser "^1.0.1" 913 | cssom ">= 0.3.2 < 0.4.0" 914 | cssstyle ">= 0.2.37 < 0.3.0" 915 | escodegen "^1.6.1" 916 | html-encoding-sniffer "^1.0.1" 917 | nwmatcher ">= 1.3.9 < 2.0.0" 918 | parse5 "^1.5.1" 919 | request "^2.79.0" 920 | sax "^1.2.1" 921 | symbol-tree "^3.2.1" 922 | tough-cookie "^2.3.2" 923 | webidl-conversions "^4.0.0" 924 | whatwg-encoding "^1.0.1" 925 | whatwg-url "^4.3.0" 926 | xml-name-validator "^2.0.1" 927 | 928 | jsesc@~0.5.0: 929 | version "0.5.0" 930 | resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-0.5.0.tgz#e7dee66e35d6fc16f710fe91d5cf69f70f08911d" 931 | 932 | json-schema@0.2.3: 933 | version "0.2.3" 934 | resolved "https://registry.yarnpkg.com/json-schema/-/json-schema-0.2.3.tgz#b480c892e59a2f05954ce727bd3f2a4e882f9e13" 935 | 936 | json-stringify-safe@~5.0.1: 937 | version "5.0.1" 938 | resolved "https://registry.yarnpkg.com/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz#1296a2d58fd45f19a0f6ce01d65701e2c735b6eb" 939 | 940 | json5@^0.4.0: 941 | version "0.4.0" 942 | resolved "https://registry.yarnpkg.com/json5/-/json5-0.4.0.tgz#054352e4c4c80c86c0923877d449de176a732c8d" 943 | 944 | jsonpointer@^4.0.0: 945 | version "4.0.1" 946 | resolved "https://registry.yarnpkg.com/jsonpointer/-/jsonpointer-4.0.1.tgz#4fd92cb34e0e9db3c89c8622ecf51f9b978c6cb9" 947 | 948 | jsprim@^1.2.2: 949 | version "1.3.1" 950 | resolved "https://registry.yarnpkg.com/jsprim/-/jsprim-1.3.1.tgz#2a7256f70412a29ee3670aaca625994c4dcff252" 951 | dependencies: 952 | extsprintf "1.0.2" 953 | json-schema "0.2.3" 954 | verror "1.3.6" 955 | 956 | kind-of@^3.0.2: 957 | version "3.1.0" 958 | resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-3.1.0.tgz#475d698a5e49ff5e53d14e3e732429dc8bf4cf47" 959 | dependencies: 960 | is-buffer "^1.0.2" 961 | 962 | lazy-cache@^1.0.3: 963 | version "1.0.4" 964 | resolved "https://registry.yarnpkg.com/lazy-cache/-/lazy-cache-1.0.4.tgz#a1d78fc3a50474cb80845d3b3b6e1da49a446e8e" 965 | 966 | lcid@^1.0.0: 967 | version "1.0.0" 968 | resolved "https://registry.yarnpkg.com/lcid/-/lcid-1.0.0.tgz#308accafa0bc483a3867b4b6f2b9506251d1b835" 969 | dependencies: 970 | invert-kv "^1.0.0" 971 | 972 | leven@^1.0.2: 973 | version "1.0.2" 974 | resolved "https://registry.yarnpkg.com/leven/-/leven-1.0.2.tgz#9144b6eebca5f1d0680169f1a6770dcea60b75c3" 975 | 976 | levn@~0.2.5: 977 | version "0.2.5" 978 | resolved "https://registry.yarnpkg.com/levn/-/levn-0.2.5.tgz#ba8d339d0ca4a610e3a3f145b9caf48807155054" 979 | dependencies: 980 | prelude-ls "~1.1.0" 981 | type-check "~0.3.1" 982 | 983 | levn@~0.3.0: 984 | version "0.3.0" 985 | resolved "https://registry.yarnpkg.com/levn/-/levn-0.3.0.tgz#3b09924edf9f083c0490fdd4c0bc4421e04764ee" 986 | dependencies: 987 | prelude-ls "~1.1.2" 988 | type-check "~0.3.2" 989 | 990 | lodash@^3.10.0, lodash@^3.9.3: 991 | version "3.10.1" 992 | resolved "https://registry.yarnpkg.com/lodash/-/lodash-3.10.1.tgz#5bf45e8e49ba4189e17d482789dfd15bd140b7b6" 993 | 994 | lodash@~2.4.1: 995 | version "2.4.2" 996 | resolved "https://registry.yarnpkg.com/lodash/-/lodash-2.4.2.tgz#fadd834b9683073da179b3eae6d9c0d15053f73e" 997 | 998 | lolex@1.3.2: 999 | version "1.3.2" 1000 | resolved "https://registry.yarnpkg.com/lolex/-/lolex-1.3.2.tgz#7c3da62ffcb30f0f5a80a2566ca24e45d8a01f31" 1001 | 1002 | longest@^1.0.1: 1003 | version "1.0.1" 1004 | resolved "https://registry.yarnpkg.com/longest/-/longest-1.0.1.tgz#30a0b2da38f73770e8294a0d22e6625ed77d0097" 1005 | 1006 | loose-envify@^1.0.0, loose-envify@^1.1.0: 1007 | version "1.3.1" 1008 | resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.3.1.tgz#d1a8ad33fa9ce0e713d65fdd0ac8b748d478c848" 1009 | dependencies: 1010 | js-tokens "^3.0.0" 1011 | 1012 | lru-cache@2: 1013 | version "2.7.3" 1014 | resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-2.7.3.tgz#6d4524e8b955f95d4f5b58851ce21dd72fb4e952" 1015 | 1016 | mime-db@~1.26.0: 1017 | version "1.26.0" 1018 | resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.26.0.tgz#eaffcd0e4fc6935cf8134da246e2e6c35305adff" 1019 | 1020 | mime-types@^2.1.12, mime-types@~2.1.7: 1021 | version "2.1.14" 1022 | resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.14.tgz#f7ef7d97583fcaf3b7d282b6f8b5679dab1e94ee" 1023 | dependencies: 1024 | mime-db "~1.26.0" 1025 | 1026 | minimatch@0.3: 1027 | version "0.3.0" 1028 | resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-0.3.0.tgz#275d8edaac4f1bb3326472089e7949c8394699dd" 1029 | dependencies: 1030 | lru-cache "2" 1031 | sigmund "~1.0.0" 1032 | 1033 | "minimatch@2 || 3", minimatch@^2.0.3: 1034 | version "2.0.10" 1035 | resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-2.0.10.tgz#8d087c39c6b38c001b97fca7ce6d0e1e80afbac7" 1036 | dependencies: 1037 | brace-expansion "^1.0.0" 1038 | 1039 | minimatch@^1.0.0: 1040 | version "1.0.0" 1041 | resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-1.0.0.tgz#e0dd2120b49e1b724ce8d714c520822a9438576d" 1042 | dependencies: 1043 | lru-cache "2" 1044 | sigmund "~1.0.0" 1045 | 1046 | minimist@0.0.8: 1047 | version "0.0.8" 1048 | resolved "https://registry.yarnpkg.com/minimist/-/minimist-0.0.8.tgz#857fcabfc3397d2625b8228262e86aa7a011b05d" 1049 | 1050 | minimist@^1.1.0: 1051 | version "1.2.0" 1052 | resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.0.tgz#a35008b20f41383eec1fb914f4cd5df79a264284" 1053 | 1054 | mkdirp@0.3.0: 1055 | version "0.3.0" 1056 | resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.3.0.tgz#1bbf5ab1ba827af23575143490426455f481fe1e" 1057 | 1058 | mkdirp@0.5.1, mkdirp@^0.5.0, mkdirp@^0.5.1: 1059 | version "0.5.1" 1060 | resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.1.tgz#30057438eac6cf7f8c4767f38648d6697d75c903" 1061 | dependencies: 1062 | minimist "0.0.8" 1063 | 1064 | mocha@^2.1.0: 1065 | version "2.5.3" 1066 | resolved "https://registry.yarnpkg.com/mocha/-/mocha-2.5.3.tgz#161be5bdeb496771eb9b35745050b622b5aefc58" 1067 | dependencies: 1068 | commander "2.3.0" 1069 | debug "2.2.0" 1070 | diff "1.4.0" 1071 | escape-string-regexp "1.0.2" 1072 | glob "3.2.11" 1073 | growl "1.9.2" 1074 | jade "0.26.3" 1075 | mkdirp "0.5.1" 1076 | supports-color "1.2.0" 1077 | to-iso-string "0.0.2" 1078 | 1079 | ms@0.7.1: 1080 | version "0.7.1" 1081 | resolved "https://registry.yarnpkg.com/ms/-/ms-0.7.1.tgz#9cd13c03adbff25b65effde7ce864ee952017098" 1082 | 1083 | multi-stage-sourcemap@~0.2.1: 1084 | version "0.2.1" 1085 | resolved "https://registry.yarnpkg.com/multi-stage-sourcemap/-/multi-stage-sourcemap-0.2.1.tgz#b09fc8586eaa17f81d575c4ad02e0f7a3f6b1105" 1086 | dependencies: 1087 | source-map "^0.1.34" 1088 | 1089 | node-fetch@^1.0.1: 1090 | version "1.6.3" 1091 | resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-1.6.3.tgz#dc234edd6489982d58e8f0db4f695029abcd8c04" 1092 | dependencies: 1093 | encoding "^0.1.11" 1094 | is-stream "^1.0.1" 1095 | 1096 | number-is-nan@^1.0.0: 1097 | version "1.0.1" 1098 | resolved "https://registry.yarnpkg.com/number-is-nan/-/number-is-nan-1.0.1.tgz#097b602b53422a522c1afb8790318336941a011d" 1099 | 1100 | "nwmatcher@>= 1.3.9 < 2.0.0": 1101 | version "1.3.9" 1102 | resolved "https://registry.yarnpkg.com/nwmatcher/-/nwmatcher-1.3.9.tgz#8bab486ff7fa3dfd086656bbe8b17116d3692d2a" 1103 | 1104 | oauth-sign@~0.8.1: 1105 | version "0.8.2" 1106 | resolved "https://registry.yarnpkg.com/oauth-sign/-/oauth-sign-0.8.2.tgz#46a6ab7f0aead8deae9ec0565780b7d4efeb9d43" 1107 | 1108 | object-assign@^4.0.0, object-assign@^4.1.0: 1109 | version "4.1.1" 1110 | resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" 1111 | 1112 | object-keys@~1.0.3: 1113 | version "1.0.11" 1114 | resolved "https://registry.yarnpkg.com/object-keys/-/object-keys-1.0.11.tgz#c54601778ad560f1142ce0e01bcca8b56d13426d" 1115 | 1116 | once@^1.3.0: 1117 | version "1.4.0" 1118 | resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" 1119 | dependencies: 1120 | wrappy "1" 1121 | 1122 | optionator@^0.4.0: 1123 | version "0.4.0" 1124 | resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.4.0.tgz#e79c7926ff7d550f92c714dfc3da21d7877ebea6" 1125 | dependencies: 1126 | deep-is "~0.1.2" 1127 | fast-levenshtein "~1.0.0" 1128 | levn "~0.2.5" 1129 | prelude-ls "~1.1.0" 1130 | type-check "~0.3.1" 1131 | wordwrap "~0.0.2" 1132 | 1133 | optionator@^0.8.1: 1134 | version "0.8.2" 1135 | resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.8.2.tgz#364c5e409d3f4d6301d6c0b4c05bba50180aeb64" 1136 | dependencies: 1137 | deep-is "~0.1.3" 1138 | fast-levenshtein "~2.0.4" 1139 | levn "~0.3.0" 1140 | prelude-ls "~1.1.2" 1141 | type-check "~0.3.2" 1142 | wordwrap "~1.0.0" 1143 | 1144 | os-locale@^1.4.0: 1145 | version "1.4.0" 1146 | resolved "https://registry.yarnpkg.com/os-locale/-/os-locale-1.4.0.tgz#20f9f17ae29ed345e8bde583b13d2009803c14d9" 1147 | dependencies: 1148 | lcid "^1.0.0" 1149 | 1150 | os-tmpdir@^1.0.1: 1151 | version "1.0.2" 1152 | resolved "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz#bbe67406c79aa85c5cfec766fe5734555dfa1274" 1153 | 1154 | output-file-sync@^1.1.0: 1155 | version "1.1.2" 1156 | resolved "https://registry.yarnpkg.com/output-file-sync/-/output-file-sync-1.1.2.tgz#d0a33eefe61a205facb90092e826598d5245ce76" 1157 | dependencies: 1158 | graceful-fs "^4.1.4" 1159 | mkdirp "^0.5.1" 1160 | object-assign "^4.1.0" 1161 | 1162 | parse5@^1.5.1: 1163 | version "1.5.1" 1164 | resolved "https://registry.yarnpkg.com/parse5/-/parse5-1.5.1.tgz#9b7f3b0de32be78dc2401b17573ccaf0f6f59d94" 1165 | 1166 | path-exists@^1.0.0: 1167 | version "1.0.0" 1168 | resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-1.0.0.tgz#d5a8998eb71ef37a74c34eb0d9eba6e878eea081" 1169 | 1170 | path-is-absolute@^1.0.0: 1171 | version "1.0.1" 1172 | resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" 1173 | 1174 | path-to-regexp@^1.2.0: 1175 | version "1.7.0" 1176 | resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-1.7.0.tgz#59fde0f435badacba103a84e9d3bc64e96b9937d" 1177 | dependencies: 1178 | isarray "0.0.1" 1179 | 1180 | pinkie-promise@^2.0.0: 1181 | version "2.0.1" 1182 | resolved "https://registry.yarnpkg.com/pinkie-promise/-/pinkie-promise-2.0.1.tgz#2135d6dfa7a358c069ac9b178776288228450ffa" 1183 | dependencies: 1184 | pinkie "^2.0.0" 1185 | 1186 | pinkie@^2.0.0: 1187 | version "2.0.4" 1188 | resolved "https://registry.yarnpkg.com/pinkie/-/pinkie-2.0.4.tgz#72556b80cfa0d48a974e80e77248e80ed4f7f870" 1189 | 1190 | power-assert-formatter@~0.10.2: 1191 | version "0.10.2" 1192 | resolved "https://registry.yarnpkg.com/power-assert-formatter/-/power-assert-formatter-0.10.2.tgz#a7ae92c690a6c74c564904d80e83def25475579e" 1193 | dependencies: 1194 | eastasianwidth "~0.1.0" 1195 | esprima "~1.2.2" 1196 | estraverse "~1.7.0" 1197 | googlediff "~0.1.0" 1198 | object-keys "~1.0.3" 1199 | stringifier "~1.0.1" 1200 | type-name "~1.0.1" 1201 | xtend "~4.0.0" 1202 | 1203 | power-assert@^0.10.1: 1204 | version "0.10.2" 1205 | resolved "https://registry.yarnpkg.com/power-assert/-/power-assert-0.10.2.tgz#6c70985782ed280ae826ff78d41865cd095266a3" 1206 | dependencies: 1207 | empower "~0.10.0" 1208 | power-assert-formatter "~0.10.2" 1209 | xtend "~4.0.0" 1210 | 1211 | prelude-ls@~1.1.0, prelude-ls@~1.1.2: 1212 | version "1.1.2" 1213 | resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.1.2.tgz#21932a549f5e52ffd9a827f570e04be62a97da54" 1214 | 1215 | private@^0.1.6, private@~0.1.5: 1216 | version "0.1.7" 1217 | resolved "https://registry.yarnpkg.com/private/-/private-0.1.7.tgz#68ce5e8a1ef0a23bb570cc28537b5332aba63ef1" 1218 | 1219 | promise@^7.1.1: 1220 | version "7.1.1" 1221 | resolved "https://registry.yarnpkg.com/promise/-/promise-7.1.1.tgz#489654c692616b8aa55b0724fa809bb7db49c5bf" 1222 | dependencies: 1223 | asap "~2.0.3" 1224 | 1225 | punycode@^1.4.1: 1226 | version "1.4.1" 1227 | resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.4.1.tgz#c0d5a63b2718800ad8e1eb0fa5269c84dd41845e" 1228 | 1229 | q@^1.1.2: 1230 | version "1.4.1" 1231 | resolved "https://registry.yarnpkg.com/q/-/q-1.4.1.tgz#55705bcd93c5f3673530c2c2cbc0c2b3addc286e" 1232 | 1233 | qs@~6.3.0: 1234 | version "6.3.1" 1235 | resolved "https://registry.yarnpkg.com/qs/-/qs-6.3.1.tgz#918c0b3bcd36679772baf135b1acb4c1651ed79d" 1236 | 1237 | react-dom@^15.4.2: 1238 | version "15.4.2" 1239 | resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-15.4.2.tgz#015363f05b0a1fd52ae9efdd3a0060d90695208f" 1240 | dependencies: 1241 | fbjs "^0.8.1" 1242 | loose-envify "^1.1.0" 1243 | object-assign "^4.1.0" 1244 | 1245 | react@^15.4.2: 1246 | version "15.4.2" 1247 | resolved "https://registry.yarnpkg.com/react/-/react-15.4.2.tgz#41f7991b26185392ba9bae96c8889e7e018397ef" 1248 | dependencies: 1249 | fbjs "^0.8.4" 1250 | loose-envify "^1.1.0" 1251 | object-assign "^4.1.0" 1252 | 1253 | readable-stream@1.1: 1254 | version "1.1.13" 1255 | resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-1.1.13.tgz#f6eef764f514c89e2b9e23146a75ba106756d23e" 1256 | dependencies: 1257 | core-util-is "~1.0.0" 1258 | inherits "~2.0.1" 1259 | isarray "0.0.1" 1260 | string_decoder "~0.10.x" 1261 | 1262 | recast@0.10.33, recast@^0.10.10: 1263 | version "0.10.33" 1264 | resolved "https://registry.yarnpkg.com/recast/-/recast-0.10.33.tgz#942808f7aa016f1fa7142c461d7e5704aaa8d697" 1265 | dependencies: 1266 | ast-types "0.8.12" 1267 | esprima-fb "~15001.1001.0-dev-harmony-fb" 1268 | private "~0.1.5" 1269 | source-map "~0.5.0" 1270 | 1271 | recast@^0.11.17: 1272 | version "0.11.22" 1273 | resolved "https://registry.yarnpkg.com/recast/-/recast-0.11.22.tgz#dedeb18fb001a2bbc6ac34475fda53dfe3d47dfa" 1274 | dependencies: 1275 | ast-types "0.9.5" 1276 | esprima "~3.1.0" 1277 | private "~0.1.5" 1278 | source-map "~0.5.0" 1279 | 1280 | regenerate@^1.2.1: 1281 | version "1.3.2" 1282 | resolved "https://registry.yarnpkg.com/regenerate/-/regenerate-1.3.2.tgz#d1941c67bad437e1be76433add5b385f95b19260" 1283 | 1284 | regenerator@0.8.40: 1285 | version "0.8.40" 1286 | resolved "https://registry.yarnpkg.com/regenerator/-/regenerator-0.8.40.tgz#a0e457c58ebdbae575c9f8cd75127e93756435d8" 1287 | dependencies: 1288 | commoner "~0.10.3" 1289 | defs "~1.1.0" 1290 | esprima-fb "~15001.1001.0-dev-harmony-fb" 1291 | private "~0.1.5" 1292 | recast "0.10.33" 1293 | through "~2.3.8" 1294 | 1295 | regexpu@^1.3.0: 1296 | version "1.3.0" 1297 | resolved "https://registry.yarnpkg.com/regexpu/-/regexpu-1.3.0.tgz#e534dc991a9e5846050c98de6d7dd4a55c9ea16d" 1298 | dependencies: 1299 | esprima "^2.6.0" 1300 | recast "^0.10.10" 1301 | regenerate "^1.2.1" 1302 | regjsgen "^0.2.0" 1303 | regjsparser "^0.1.4" 1304 | 1305 | regjsgen@^0.2.0: 1306 | version "0.2.0" 1307 | resolved "https://registry.yarnpkg.com/regjsgen/-/regjsgen-0.2.0.tgz#6c016adeac554f75823fe37ac05b92d5a4edb1f7" 1308 | 1309 | regjsparser@^0.1.4: 1310 | version "0.1.5" 1311 | resolved "https://registry.yarnpkg.com/regjsparser/-/regjsparser-0.1.5.tgz#7ee8f84dc6fa792d3fd0ae228d24bd949ead205c" 1312 | dependencies: 1313 | jsesc "~0.5.0" 1314 | 1315 | repeat-string@^1.5.2: 1316 | version "1.6.1" 1317 | resolved "https://registry.yarnpkg.com/repeat-string/-/repeat-string-1.6.1.tgz#8dcae470e1c88abc2d600fff4a776286da75e637" 1318 | 1319 | repeating@^1.1.0, repeating@^1.1.2: 1320 | version "1.1.3" 1321 | resolved "https://registry.yarnpkg.com/repeating/-/repeating-1.1.3.tgz#3d4114218877537494f97f77f9785fab810fa4ac" 1322 | dependencies: 1323 | is-finite "^1.0.0" 1324 | 1325 | request@^2.79.0: 1326 | version "2.79.0" 1327 | resolved "https://registry.yarnpkg.com/request/-/request-2.79.0.tgz#4dfe5bf6be8b8cdc37fcf93e04b65577722710de" 1328 | dependencies: 1329 | aws-sign2 "~0.6.0" 1330 | aws4 "^1.2.1" 1331 | caseless "~0.11.0" 1332 | combined-stream "~1.0.5" 1333 | extend "~3.0.0" 1334 | forever-agent "~0.6.1" 1335 | form-data "~2.1.1" 1336 | har-validator "~2.0.6" 1337 | hawk "~3.1.3" 1338 | http-signature "~1.1.0" 1339 | is-typedarray "~1.0.0" 1340 | isstream "~0.1.2" 1341 | json-stringify-safe "~5.0.1" 1342 | mime-types "~2.1.7" 1343 | oauth-sign "~0.8.1" 1344 | qs "~6.3.0" 1345 | stringstream "~0.0.4" 1346 | tough-cookie "~2.3.0" 1347 | tunnel-agent "~0.4.1" 1348 | uuid "^3.0.0" 1349 | 1350 | resolve@^1.1.6: 1351 | version "1.2.0" 1352 | resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.2.0.tgz#9589c3f2f6149d1417a40becc1663db6ec6bc26c" 1353 | 1354 | right-align@^0.1.1: 1355 | version "0.1.3" 1356 | resolved "https://registry.yarnpkg.com/right-align/-/right-align-0.1.3.tgz#61339b722fe6a3515689210d24e14c96148613ef" 1357 | dependencies: 1358 | align-text "^0.1.1" 1359 | 1360 | samsam@1.1.2, samsam@~1.1: 1361 | version "1.1.2" 1362 | resolved "https://registry.yarnpkg.com/samsam/-/samsam-1.1.2.tgz#bec11fdc83a9fda063401210e40176c3024d1567" 1363 | 1364 | sax@^1.2.1: 1365 | version "1.2.2" 1366 | resolved "https://registry.yarnpkg.com/sax/-/sax-1.2.2.tgz#fd8631a23bc7826bef5d871bdb87378c95647828" 1367 | 1368 | setimmediate@^1.0.5: 1369 | version "1.0.5" 1370 | resolved "https://registry.yarnpkg.com/setimmediate/-/setimmediate-1.0.5.tgz#290cbb232e306942d7d7ea9b83732ab7856f8285" 1371 | 1372 | shebang-regex@^1.0.0: 1373 | version "1.0.0" 1374 | resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-1.0.0.tgz#da42f49740c0b42db2ca9728571cb190c98efea3" 1375 | 1376 | sigmund@~1.0.0: 1377 | version "1.0.1" 1378 | resolved "https://registry.yarnpkg.com/sigmund/-/sigmund-1.0.1.tgz#3ff21f198cad2175f9f3b781853fd94d0d19b590" 1379 | 1380 | simple-fmt@~0.1.0: 1381 | version "0.1.0" 1382 | resolved "https://registry.yarnpkg.com/simple-fmt/-/simple-fmt-0.1.0.tgz#191bf566a59e6530482cb25ab53b4a8dc85c3a6b" 1383 | 1384 | simple-is@~0.2.0: 1385 | version "0.2.0" 1386 | resolved "https://registry.yarnpkg.com/simple-is/-/simple-is-0.2.0.tgz#2abb75aade39deb5cc815ce10e6191164850baf0" 1387 | 1388 | sinon@^1.12.2: 1389 | version "1.17.7" 1390 | resolved "https://registry.yarnpkg.com/sinon/-/sinon-1.17.7.tgz#4542a4f49ba0c45c05eb2e9dd9d203e2b8efe0bf" 1391 | dependencies: 1392 | formatio "1.1.1" 1393 | lolex "1.3.2" 1394 | samsam "1.1.2" 1395 | util ">=0.10.3 <1" 1396 | 1397 | slash@^1.0.0: 1398 | version "1.0.0" 1399 | resolved "https://registry.yarnpkg.com/slash/-/slash-1.0.0.tgz#c41f2f6c39fc16d1cd17ad4b5d896114ae470d55" 1400 | 1401 | sntp@1.x.x: 1402 | version "1.0.9" 1403 | resolved "https://registry.yarnpkg.com/sntp/-/sntp-1.0.9.tgz#6541184cc90aeea6c6e7b35e2659082443c66198" 1404 | dependencies: 1405 | hoek "2.x.x" 1406 | 1407 | source-map-support@^0.2.10, source-map-support@^0.2.9: 1408 | version "0.2.10" 1409 | resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.2.10.tgz#ea5a3900a1c1cb25096a0ae8cc5c2b4b10ded3dc" 1410 | dependencies: 1411 | source-map "0.1.32" 1412 | 1413 | source-map@0.1.32: 1414 | version "0.1.32" 1415 | resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.1.32.tgz#c8b6c167797ba4740a8ea33252162ff08591b266" 1416 | dependencies: 1417 | amdefine ">=0.0.4" 1418 | 1419 | source-map@^0.1.34, source-map@~0.1.40: 1420 | version "0.1.43" 1421 | resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.1.43.tgz#c24bc146ca517c1471f5dacbe2571b2b7f9e3346" 1422 | dependencies: 1423 | amdefine ">=0.0.4" 1424 | 1425 | source-map@^0.5.0, source-map@~0.5.0: 1426 | version "0.5.6" 1427 | resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.6.tgz#75ce38f52bf0733c5a7f0c118d81334a2bb5f412" 1428 | 1429 | source-map@~0.2.0: 1430 | version "0.2.0" 1431 | resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.2.0.tgz#dab73fbcfc2ba819b4de03bd6f6eaa48164b3f9d" 1432 | dependencies: 1433 | amdefine ">=0.0.4" 1434 | 1435 | sshpk@^1.7.0: 1436 | version "1.10.2" 1437 | resolved "https://registry.yarnpkg.com/sshpk/-/sshpk-1.10.2.tgz#d5a804ce22695515638e798dbe23273de070a5fa" 1438 | dependencies: 1439 | asn1 "~0.2.3" 1440 | assert-plus "^1.0.0" 1441 | dashdash "^1.12.0" 1442 | getpass "^0.1.1" 1443 | optionalDependencies: 1444 | bcrypt-pbkdf "^1.0.0" 1445 | ecc-jsbn "~0.1.1" 1446 | jodid25519 "^1.0.0" 1447 | jsbn "~0.1.0" 1448 | tweetnacl "~0.14.0" 1449 | 1450 | stable@~0.1.3: 1451 | version "0.1.5" 1452 | resolved "https://registry.yarnpkg.com/stable/-/stable-0.1.5.tgz#08232f60c732e9890784b5bed0734f8b32a887b9" 1453 | 1454 | string_decoder@~0.10.x: 1455 | version "0.10.31" 1456 | resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-0.10.31.tgz#62e203bc41766c6c28c9fc84301dab1c5310fa94" 1457 | 1458 | stringifier@~1.0.1: 1459 | version "1.0.1" 1460 | resolved "https://registry.yarnpkg.com/stringifier/-/stringifier-1.0.1.tgz#24394d437bc92aa1dd69dabbcbd3630e842de512" 1461 | dependencies: 1462 | traverse "~0.6.6" 1463 | type-name "~1.0.1" 1464 | xtend "~4.0.0" 1465 | 1466 | stringmap@~0.2.2: 1467 | version "0.2.2" 1468 | resolved "http://registry.npmjs.org/stringmap/-/stringmap-0.2.2.tgz#556c137b258f942b8776f5b2ef582aa069d7d1b1" 1469 | 1470 | stringset@~0.2.1: 1471 | version "0.2.1" 1472 | resolved "https://registry.yarnpkg.com/stringset/-/stringset-0.2.1.tgz#ef259c4e349344377fcd1c913dd2e848c9c042b5" 1473 | 1474 | stringstream@~0.0.4: 1475 | version "0.0.5" 1476 | resolved "https://registry.yarnpkg.com/stringstream/-/stringstream-0.0.5.tgz#4e484cd4de5a0bbbee18e46307710a8a81621878" 1477 | 1478 | strip-ansi@^3.0.0: 1479 | version "3.0.1" 1480 | resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-3.0.1.tgz#6a385fb8853d952d5ff05d0e8aaf94278dc63dcf" 1481 | dependencies: 1482 | ansi-regex "^2.0.0" 1483 | 1484 | supports-color@1.2.0: 1485 | version "1.2.0" 1486 | resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-1.2.0.tgz#ff1ed1e61169d06b3cf2d588e188b18d8847e17e" 1487 | 1488 | supports-color@^2.0.0: 1489 | version "2.0.0" 1490 | resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-2.0.0.tgz#535d045ce6b6363fa40117084629995e9df324c7" 1491 | 1492 | symbol-tree@^3.2.1: 1493 | version "3.2.2" 1494 | resolved "https://registry.yarnpkg.com/symbol-tree/-/symbol-tree-3.2.2.tgz#ae27db38f660a7ae2e1c3b7d1bc290819b8519e6" 1495 | 1496 | through@^2.3.8, through@~2.3.8: 1497 | version "2.3.8" 1498 | resolved "https://registry.yarnpkg.com/through/-/through-2.3.8.tgz#0dd4c9ffaabc357960b1b724115d7e0e86a2e1f5" 1499 | 1500 | to-fast-properties@^1.0.0: 1501 | version "1.0.2" 1502 | resolved "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-1.0.2.tgz#f3f5c0c3ba7299a7ef99427e44633257ade43320" 1503 | 1504 | to-iso-string@0.0.2: 1505 | version "0.0.2" 1506 | resolved "https://registry.yarnpkg.com/to-iso-string/-/to-iso-string-0.0.2.tgz#4dc19e664dfccbe25bd8db508b00c6da158255d1" 1507 | 1508 | tough-cookie@^2.3.2, tough-cookie@~2.3.0: 1509 | version "2.3.2" 1510 | resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-2.3.2.tgz#f081f76e4c85720e6c37a5faced737150d84072a" 1511 | dependencies: 1512 | punycode "^1.4.1" 1513 | 1514 | tr46@~0.0.3: 1515 | version "0.0.3" 1516 | resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a" 1517 | 1518 | traverse@~0.6.6: 1519 | version "0.6.6" 1520 | resolved "https://registry.yarnpkg.com/traverse/-/traverse-0.6.6.tgz#cbdf560fd7b9af632502fed40f918c157ea97137" 1521 | 1522 | trim-right@^1.0.0: 1523 | version "1.0.1" 1524 | resolved "https://registry.yarnpkg.com/trim-right/-/trim-right-1.0.1.tgz#cb2e1203067e0c8de1f614094b9fe45704ea6003" 1525 | 1526 | try-resolve@^1.0.0: 1527 | version "1.0.1" 1528 | resolved "https://registry.yarnpkg.com/try-resolve/-/try-resolve-1.0.1.tgz#cfde6fabd72d63e5797cfaab873abbe8e700e912" 1529 | 1530 | tryor@~0.1.2: 1531 | version "0.1.2" 1532 | resolved "https://registry.yarnpkg.com/tryor/-/tryor-0.1.2.tgz#8145e4ca7caff40acde3ccf946e8b8bb75b4172b" 1533 | 1534 | tunnel-agent@~0.4.1: 1535 | version "0.4.3" 1536 | resolved "https://registry.yarnpkg.com/tunnel-agent/-/tunnel-agent-0.4.3.tgz#6373db76909fe570e08d73583365ed828a74eeeb" 1537 | 1538 | tweetnacl@^0.14.3, tweetnacl@~0.14.0: 1539 | version "0.14.5" 1540 | resolved "https://registry.yarnpkg.com/tweetnacl/-/tweetnacl-0.14.5.tgz#5ae68177f192d4456269d108afa93ff8743f4f64" 1541 | 1542 | type-check@~0.3.1, type-check@~0.3.2: 1543 | version "0.3.2" 1544 | resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.3.2.tgz#5884cab512cf1d355e3fb784f30804b2b520db72" 1545 | dependencies: 1546 | prelude-ls "~1.1.2" 1547 | 1548 | type-name@~1.0.0, type-name@~1.0.1: 1549 | version "1.0.1" 1550 | resolved "https://registry.yarnpkg.com/type-name/-/type-name-1.0.1.tgz#49af8e6663682c7aa501dca6832d90c02ebcf1b2" 1551 | 1552 | ua-parser-js@^0.7.9: 1553 | version "0.7.12" 1554 | resolved "https://registry.yarnpkg.com/ua-parser-js/-/ua-parser-js-0.7.12.tgz#04c81a99bdd5dc52263ea29d24c6bf8d4818a4bb" 1555 | 1556 | user-home@^1.1.1: 1557 | version "1.1.1" 1558 | resolved "https://registry.yarnpkg.com/user-home/-/user-home-1.1.1.tgz#2b5be23a32b63a7c9deb8d0f28d485724a3df190" 1559 | 1560 | "util@>=0.10.3 <1": 1561 | version "0.10.3" 1562 | resolved "https://registry.yarnpkg.com/util/-/util-0.10.3.tgz#7afb1afe50805246489e3db7fe0ed379336ac0f9" 1563 | dependencies: 1564 | inherits "2.0.1" 1565 | 1566 | uuid@^3.0.0: 1567 | version "3.0.1" 1568 | resolved "https://registry.yarnpkg.com/uuid/-/uuid-3.0.1.tgz#6544bba2dfda8c1cf17e629a3a305e2bb1fee6c1" 1569 | 1570 | verror@1.3.6: 1571 | version "1.3.6" 1572 | resolved "https://registry.yarnpkg.com/verror/-/verror-1.3.6.tgz#cff5df12946d297d2baaefaa2689e25be01c005c" 1573 | dependencies: 1574 | extsprintf "1.0.2" 1575 | 1576 | webidl-conversions@^3.0.0: 1577 | version "3.0.1" 1578 | resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz#24534275e2a7bc6be7bc86611cc16ae0a5654871" 1579 | 1580 | webidl-conversions@^4.0.0: 1581 | version "4.0.1" 1582 | resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-4.0.1.tgz#8015a17ab83e7e1b311638486ace81da6ce206a0" 1583 | 1584 | whatwg-encoding@^1.0.1: 1585 | version "1.0.1" 1586 | resolved "https://registry.yarnpkg.com/whatwg-encoding/-/whatwg-encoding-1.0.1.tgz#3c6c451a198ee7aec55b1ec61d0920c67801a5f4" 1587 | dependencies: 1588 | iconv-lite "0.4.13" 1589 | 1590 | whatwg-fetch@>=0.10.0: 1591 | version "2.0.2" 1592 | resolved "https://registry.yarnpkg.com/whatwg-fetch/-/whatwg-fetch-2.0.2.tgz#fe294d1d89e36c5be8b3195057f2e4bc74fc980e" 1593 | 1594 | whatwg-url@^4.3.0: 1595 | version "4.5.0" 1596 | resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-4.5.0.tgz#79bb6f0e370a4dda1cbc8f3062a490cf8bbb09ea" 1597 | dependencies: 1598 | tr46 "~0.0.3" 1599 | webidl-conversions "^3.0.0" 1600 | 1601 | window-size@^0.1.2: 1602 | version "0.1.4" 1603 | resolved "https://registry.yarnpkg.com/window-size/-/window-size-0.1.4.tgz#f8e1aa1ee5a53ec5bf151ffa09742a6ad7697876" 1604 | 1605 | wordwrap@0.0.2: 1606 | version "0.0.2" 1607 | resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-0.0.2.tgz#b79669bb42ecb409f83d583cad52ca17eaa1643f" 1608 | 1609 | wordwrap@~0.0.2: 1610 | version "0.0.3" 1611 | resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-0.0.3.tgz#a3d5da6cd5c0bc0008d37234bbaf1bed63059107" 1612 | 1613 | wordwrap@~1.0.0: 1614 | version "1.0.0" 1615 | resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-1.0.0.tgz#27584810891456a4171c8d0226441ade90cbcaeb" 1616 | 1617 | wrappy@1: 1618 | version "1.0.2" 1619 | resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" 1620 | 1621 | xml-name-validator@^2.0.1: 1622 | version "2.0.1" 1623 | resolved "https://registry.yarnpkg.com/xml-name-validator/-/xml-name-validator-2.0.1.tgz#4d8b8f1eccd3419aa362061becef515e1e559635" 1624 | 1625 | xtend@^4.0.0, xtend@~4.0.0: 1626 | version "4.0.1" 1627 | resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.1.tgz#a5c6d532be656e23db820efb943a1f04998d63af" 1628 | 1629 | y18n@^3.2.0: 1630 | version "3.2.1" 1631 | resolved "https://registry.yarnpkg.com/y18n/-/y18n-3.2.1.tgz#6d15fba884c08679c0d77e88e7759e811e07fa41" 1632 | 1633 | yargs@~3.27.0: 1634 | version "3.27.0" 1635 | resolved "https://registry.yarnpkg.com/yargs/-/yargs-3.27.0.tgz#21205469316e939131d59f2da0c6d7f98221ea40" 1636 | dependencies: 1637 | camelcase "^1.2.1" 1638 | cliui "^2.1.0" 1639 | decamelize "^1.0.0" 1640 | os-locale "^1.4.0" 1641 | window-size "^0.1.2" 1642 | y18n "^3.2.0" 1643 | --------------------------------------------------------------------------------