├── .gitignore ├── README.md ├── backend ├── .projectile ├── Makefile ├── README.md ├── jbuild ├── jbuild-workspace.dev ├── server.ml ├── src │ ├── jbuild │ ├── main.ml │ └── state.ml └── tictactoe-server.opam └── frontend ├── .gitignore ├── .projectile ├── README.md ├── bsconfig.json ├── package.json ├── public └── index.html ├── src ├── app.re ├── board.re ├── fetch.re ├── game.re ├── game_test.re ├── loader.re ├── square.re └── tictactoe.re ├── webpack.config.js └── yarn.lock /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | .merlin 3 | *.install 4 | _build 5 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # TicTacToe as a Service 2 | 3 | This is a fullstack TicTacToe application with a dedicated OCaml server and 4 | ReasonML-based frontend. 5 | 6 | ## OBSOLETE, THIS PROJECT WAS MIGRATED TO THE NEWEST REASON SYNTAX (v3) 7 | 8 | Check out https://github.com/ryyppy/reason-tictactoe for the newest version 9 | -------------------------------------------------------------------------------- /backend/.projectile: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ryyppy/reason-lnd/8b9bcbee3ee2fc9d0e51ce61390984373e0e617f/backend/.projectile -------------------------------------------------------------------------------- /backend/Makefile: -------------------------------------------------------------------------------- 1 | sources := \ 2 | src/jbuild \ 3 | $(wildcard src/*.ml) 4 | 5 | executable := \ 6 | _build/install/default/bin/server 7 | 8 | build: $(executable) 9 | 10 | clean: 11 | jbuilder clean 12 | 13 | run: build 14 | $(executable) 15 | 16 | install: build 17 | 18 | $(executable): $(sources) src/jbuild 19 | jbuilder build @install 20 | 21 | .PHONY: clean build run install 22 | -------------------------------------------------------------------------------- /backend/README.md: -------------------------------------------------------------------------------- 1 | # TicTacToe-Server 2 | 3 | This is a small server for some async interaction in the TicTacToe frontend. 4 | 5 | Current goal(s) of this project: 6 | 7 | * Provide a REST endpoint to store / load the current TicTacToe state 8 | 9 | (Note: This project structure was relentlessly copied from https://github.com/mads-hartmann/random/blob/master/gh/README.md) 10 | 11 | 12 | # Build / Run 13 | 14 | ```sh 15 | opam switch install 4.04.0 16 | opam install jbuilder core yojson ssl tls cohttp async cohttp-lwt cohttp-lwt-unix lwt_ssl opium 17 | 18 | # Builds the project and creates the server executable 19 | make build 20 | 21 | # Run the server 22 | PORT=3000 ./_build/default/server.exe 23 | ``` 24 | ## Installing 25 | 26 | ```sh 27 | opam pin add tictactoe-server . 28 | ``` 29 | 30 | ## Uninstalling 31 | 32 | ```sh 33 | opam uninstall tictactoe-server 34 | opam pin remove tictactoe-server 35 | ``` 36 | 37 | # Endpoint Documentation 38 | 39 | ## GET /load 40 | 41 | On existing TicTacToe state: 42 | 43 | ``` 44 | Status: 200 45 | Accept: json/application 46 | 47 | Body: 48 | { 49 | "board": [ 50 | ["x", "o", "empty"], 51 | ["x", "o", "empty"], 52 | ["x", "o", "empty"], 53 | ], 54 | 55 | // case 1 56 | "progress": ["Turn", "x"] 57 | 58 | // case 2 59 | "progress": ["Turn", "o"] 60 | 61 | // case 3 62 | "progress": ["Win", "o"] 63 | 64 | // case 4 65 | "progress": ["Draw"] 66 | } 67 | ``` 68 | 69 | On non-existing TicTacToe state: 70 | 71 | ``` 72 | Status: 404 73 | Body: Not found 74 | ``` 75 | 76 | ## POST /save 77 | 78 | Will receive and parse a TicTacToe state and store it for the next `load` call. 79 | 80 | On success: 81 | 82 | ``` 83 | Status: 200 84 | Body: OK 85 | ``` 86 | 87 | On failure: 88 | 89 | ``` 90 | Status: 400 91 | Body: 92 | ``` 93 | -------------------------------------------------------------------------------- /backend/jbuild: -------------------------------------------------------------------------------- 1 | (jbuild_version 1) -------------------------------------------------------------------------------- /backend/jbuild-workspace.dev: -------------------------------------------------------------------------------- 1 | (context ((switch 4.04.0))) 2 | -------------------------------------------------------------------------------- /backend/server.ml: -------------------------------------------------------------------------------- 1 | Lwt_main.run (Lwt_io.printf "Hello World.") 2 | -------------------------------------------------------------------------------- /backend/src/jbuild: -------------------------------------------------------------------------------- 1 | (jbuild_version 1) 2 | 3 | (executables 4 | ((names (main)) 5 | (public_names (server)) 6 | (libraries (core async str atdgen yojson cohttp cohttp-lwt cohttp-lwt-unix opium)))) -------------------------------------------------------------------------------- /backend/src/main.ml: -------------------------------------------------------------------------------- 1 | open Opium.Std 2 | 3 | let getPort = 4 | try int_of_string (Sys.getenv "PORT") with | Failure _ | Not_found -> 8000 5 | 6 | let headers = 7 | Cohttp.Header.init_with "Content-Type" "application/json" 8 | 9 | let status_route = 10 | get "/status" 11 | (fun req -> `String "Hi, I am up and running!" |> respond') 12 | 13 | let load_route = 14 | get "/load" 15 | (fun req -> `String (State.serializeState !State.currentState) |> respond' ~headers) 16 | 17 | let staticPublic = 18 | Middleware.static 19 | ~local_path:"../frontend/public" 20 | ~uri_prefix:"/public" 21 | 22 | let staticJsAssets = 23 | Middleware.static 24 | ~local_path:"../frontend/bundledOutputs" 25 | ~uri_prefix:"/public" 26 | 27 | let _ = 28 | let port = getPort in 29 | let app = App.empty 30 | |> App.port port 31 | |> middleware staticPublic 32 | |> middleware staticJsAssets 33 | |> status_route 34 | |> load_route 35 | |> App.run_command' in 36 | match app with 37 | | `Ok a -> 38 | print_endline ("Server is running on port " ^ (string_of_int port)); 39 | Lwt_main.run a 40 | | `Error -> 41 | print_endline "Server could not be started"; 42 | exit 1 43 | | `Not_running -> exit 0 44 | 45 | -------------------------------------------------------------------------------- /backend/src/state.ml: -------------------------------------------------------------------------------- 1 | type token = 2 | | O 3 | | X 4 | | Empty 5 | 6 | type row = (token * token * token) 7 | 8 | type board = (row * row * row) 9 | 10 | type player = 11 | | O 12 | | X 13 | 14 | type progress = 15 | | Turn of player 16 | | Win of player 17 | | Draw 18 | 19 | type t = { 20 | board: board; 21 | progress: progress; 22 | } 23 | 24 | let json_of_token (token: token) = 25 | match token with 26 | | O -> `String "o" 27 | | X -> `String "x" 28 | | Empty -> `String "empty" 29 | 30 | let json_of_row row = 31 | let (t1, t2, t3) = row in 32 | `List [ 33 | json_of_token t1; 34 | json_of_token t2; 35 | json_of_token t3 36 | ] 37 | 38 | let json_of_board board = 39 | let (r1, r2, r3) = board in 40 | `List [ 41 | json_of_row r1; 42 | json_of_row r2; 43 | json_of_row r3 44 | ] 45 | 46 | let json_of_player player = 47 | match player with 48 | | O -> `String "o" 49 | | X -> `String "x" 50 | 51 | let json_of_progress progress = 52 | match progress with 53 | | Turn player -> `List [ `String "Turn"; json_of_player player ] 54 | | Win player -> `List [ `String "Win"; json_of_player player ] 55 | | Draw -> `List [ `String "Draw" ] 56 | 57 | 58 | let json_of_state state = 59 | `Assoc [ 60 | ("board", (json_of_board state.board)); 61 | ("progress", (json_of_progress state.progress)) 62 | ] 63 | 64 | let serializeState state = 65 | Yojson.to_string (json_of_state state) 66 | 67 | let initialState = 68 | let emptyRow = (Empty, Empty, Empty) in 69 | 70 | { 71 | board = (emptyRow, emptyRow, emptyRow); 72 | progress = Turn X 73 | } 74 | 75 | (* OH! what is this? Mutable global state? Gee, we all gonna die~~ *) 76 | let currentState: t ref = ref initialState;; 77 | -------------------------------------------------------------------------------- /backend/tictactoe-server.opam: -------------------------------------------------------------------------------- 1 | opam-version: "1.2" 2 | name: "tictactoe-server" 3 | version: "0.1" 4 | maintainer: "Patrick Stapfer " 5 | author: "Patrick Stapfer " 6 | build: [make] 7 | install: [make "install"] 8 | remove: [make "clean"] 9 | -------------------------------------------------------------------------------- /frontend/.gitignore: -------------------------------------------------------------------------------- 1 | lib 2 | node_modules 3 | .merlin 4 | npm-debug.log 5 | bundledOutputs 6 | -------------------------------------------------------------------------------- /frontend/.projectile: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ryyppy/reason-lnd/8b9bcbee3ee2fc9d0e51ce61390984373e0e617f/frontend/.projectile -------------------------------------------------------------------------------- /frontend/README.md: -------------------------------------------------------------------------------- 1 | This is a repo with examples usages of [ReasonReact](https://github.com/reasonml/reason-react). 2 | Have something you don't understand? Join us on [Discord](https://discord.gg/reasonml)! 3 | 4 | ## Setup 5 | 6 | If you are using the `npm` workflow, just follow the official [installation guide](https://reasonml.github.io/guide/editor-tools/global-installation): 7 | 8 | For those who are using `opam` for your editor integration, make sure to use the correct switch and packages: 9 | 10 | ``` 11 | opam switch 4.02.3 12 | opam install reason.1.13.6 13 | opam install merlin.2.5.4 14 | ``` 15 | 16 | ## Build & Run 17 | 18 | ``` 19 | yarn install 20 | 21 | # in one tab 22 | npm start 23 | 24 | # in another tab 25 | npm run webpack:watch 26 | ``` 27 | 28 | Now you should see build artifacts in `bundledOutputs`. 29 | 30 | 31 | Make sure to use the backend to load the application... 32 | the `public/index.html` will not work as a local file. 33 | -------------------------------------------------------------------------------- /frontend/bsconfig.json: -------------------------------------------------------------------------------- 1 | /* This is the BuckleScript configuration file. Note that this is a comment; 2 | BuckleScript comes with a JSON parser that supports comments and trailing 3 | comma. If this screws with your editor highlighting, please tell us by filing 4 | an issue! */ 5 | { 6 | "name" : "frontend", 7 | "reason" : {"react-jsx" : 2}, 8 | "bsc-flags": ["-bs-super-errors"], 9 | "bs-dependencies": [ 10 | "reason-react", 11 | "bs-fetch", 12 | "bs-json" 13 | ], 14 | "sources": [ 15 | { 16 | "dir": "src", 17 | "subdirs": [] 18 | } 19 | ] 20 | } 21 | -------------------------------------------------------------------------------- /frontend/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "frontend", 3 | "private": true, 4 | "version": "0.1.0", 5 | "description": "", 6 | "main": "index.js", 7 | "scripts": { 8 | "test": "echo \"Error: no test specified\" && exit 1", 9 | "start": "bsb -make-world -w", 10 | "build": "bsb -make-world", 11 | "webpack": "webpack", 12 | "webpack:watch": "webpack -w", 13 | "clean": "bsb -clean-world" 14 | }, 15 | "keywords": [], 16 | "author": "", 17 | "license": "ISC", 18 | "dependencies": { 19 | "bs-fetch": "^0.1.1", 20 | "bs-json": "^0.2.1", 21 | "react": "^15.4.2", 22 | "react-dom": "^15.4.2", 23 | "reason-react": "^0.2.4" 24 | }, 25 | "devDependencies": { 26 | "bs-platform": "^1.9.1", 27 | "webpack": "^1.14.0" 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /frontend/public/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | Pure Reason Example 6 | 7 | 8 |
9 | 10 | 11 | 12 | -------------------------------------------------------------------------------- /frontend/src/app.re: -------------------------------------------------------------------------------- 1 | ReactDOMRe.renderToElementWithId "index"; 2 | -------------------------------------------------------------------------------- /frontend/src/board.re: -------------------------------------------------------------------------------- 1 | open Game; 2 | 3 | type props = { 4 | rows: (row, row, row), 5 | handleSquareClick: selection => unit 6 | }; 7 | 8 | let component = ReasonReact.statelessComponent "Board"; 9 | 10 | let renderRow row handleSquareClick rid => { 11 | let (c1, c2, c3) = row; 12 |
13 | handleSquareClick (rid, C1)) 17 | /> 18 | handleSquareClick (rid, C2)) 22 | /> 23 | handleSquareClick (rid, C3)) 27 | /> 28 |
29 | }; 30 | 31 | let make ::rows ::handleSquareClick _children => { 32 | ...component, 33 | render: fun _self => { 34 | let (r1, r2, r3) = rows; 35 |
36 | (renderRow r1 handleSquareClick R1) 37 | (renderRow r2 handleSquareClick R2) 38 | (renderRow r3 handleSquareClick R3) 39 |
40 | } 41 | }; 42 | -------------------------------------------------------------------------------- /frontend/src/fetch.re: -------------------------------------------------------------------------------- 1 | open Game; 2 | 3 | open Bs_fetch; 4 | 5 | exception MalformedData string; 6 | 7 | type remoteData = 8 | | NotAsked 9 | | Loading 10 | | Error string 11 | | Success Game.ticTacToeState; 12 | 13 | type data = { 14 | board: array (array string), 15 | progress: array string 16 | }; 17 | 18 | let string_to_token str => 19 | switch str { 20 | | "x" => Cross 21 | | "o" => Circle 22 | | _ => Empty 23 | }; 24 | 25 | let parseRow row => 26 | switch row { 27 | | [|c1, c2, c3|] => (string_to_token c1, string_to_token c2, string_to_token c3) 28 | | _ => (Empty, Empty, Empty) 29 | }; 30 | 31 | let parseBoard board => 32 | switch board { 33 | | [|r1, r2, r3|] => (parseRow r1, parseRow r2, parseRow r3) 34 | | _ => ((Empty, Empty, Empty), (Empty, Empty, Empty), (Empty, Empty, Empty)) 35 | }; 36 | 37 | let parsePlayer p => 38 | switch p { 39 | | "o" => CirclePlayer 40 | | "x" => CrossPlayer 41 | | _ => CirclePlayer 42 | }; 43 | 44 | /* mock this for now */ 45 | let parseProgress arr => 46 | switch arr { 47 | | [||] => raise (MalformedData "Progress doesn't contain any data") 48 | | [|"Draw"|] => Draw 49 | | [|"Turn", p|] => Turn (parsePlayer p) 50 | | [|"Win", p|] => Win (parsePlayer p) 51 | | rest => 52 | raise ( 53 | MalformedData ("Could not parse progress: [" ^ String.concat "," (Array.to_list rest) ^ "]") 54 | ) 55 | }; 56 | 57 | let convertData {board, progress} :ticTacToeState => { 58 | board: parseBoard board, 59 | progress: parseProgress progress 60 | }; 61 | 62 | let parseGameJsonExn text => 63 | Js.Json.parseExn text |> ( 64 | fun json => 65 | Json.Decode.{ 66 | board: field "board" (array (array string)) json, 67 | progress: field "progress" (array string) json 68 | } 69 | ) |> convertData; 70 | 71 | let handleFailure = 72 | ( 73 | fun 74 | | MalformedData str => str 75 | ) 76 | [@bs.open]; 77 | 78 | let mockBody = {js| 79 | { 80 | "board": [ 81 | ["x", "o", "empty"], 82 | ["x", "o", "empty"], 83 | ["x", "empty", "o"] 84 | ], 85 | "progress": ["Turn", "x"] 86 | } 87 | |js}; 88 | 89 | let fetchData _ => 90 | Js.Promise.( 91 | fetch "/load" |> then_ Response.text |> 92 | then_ ( 93 | fun text => 94 | try (parseGameJsonExn text |> resolve) { 95 | | ex => reject ex 96 | } 97 | ) 98 | ); 99 | -------------------------------------------------------------------------------- /frontend/src/game.re: -------------------------------------------------------------------------------- 1 | type token = 2 | | Circle 3 | | Cross 4 | | Empty; 5 | 6 | type player = 7 | | CirclePlayer 8 | | CrossPlayer; 9 | 10 | type progress = 11 | | Turn player 12 | | Win player 13 | | Draw; 14 | 15 | type colId = 16 | | C1 17 | | C2 18 | | C3; 19 | 20 | type rowId = 21 | | R1 22 | | R2 23 | | R3; 24 | 25 | type row = (token, token, token); 26 | 27 | type selection = (rowId, colId); 28 | 29 | type ticTacToeState = { 30 | board: (row, row, row), 31 | progress 32 | }; 33 | 34 | let initialState () => { 35 | board: ((Empty, Empty, Empty), (Empty, Empty, Empty), (Empty, Empty, Empty)), 36 | progress: Turn CirclePlayer 37 | }; 38 | 39 | let row_to_string rid => 40 | switch rid { 41 | | R1 => "r1" 42 | | R2 => "r2" 43 | | R3 => "r3" 44 | }; 45 | 46 | let player_to_string player => 47 | switch player { 48 | | CirclePlayer => "O" 49 | | CrossPlayer => "X" 50 | }; 51 | 52 | let playerToken player => 53 | switch player { 54 | | CirclePlayer => Circle 55 | | CrossPlayer => Cross 56 | }; 57 | 58 | let switchPlayer (current: player) => 59 | switch current { 60 | | CirclePlayer => CrossPlayer 61 | | CrossPlayer => CirclePlayer 62 | }; 63 | 64 | let isEmptyToken (square: token) => 65 | switch square { 66 | | Empty => true 67 | | _ => false 68 | }; 69 | 70 | let updateColumn rid cid value => { 71 | let (t1, t2, t3) = rid; 72 | switch cid { 73 | | C1 => isEmptyToken t1 ? (value, t2, t3) : rid 74 | | C2 => isEmptyToken t2 ? (t1, value, t3) : rid 75 | | C3 => isEmptyToken t3 ? (t1, t2, value) : rid 76 | } 77 | }; 78 | 79 | let updateRow board rid cid value => { 80 | let (r1, r2, r3) = board; 81 | switch rid { 82 | | R1 => 83 | let r = updateColumn r1 cid value; 84 | (r, r2, r3) 85 | | R2 => 86 | let r = updateColumn r2 cid value; 87 | (r1, r, r3) 88 | | R3 => 89 | let r = updateColumn r3 cid value; 90 | (r1, r2, r) 91 | } 92 | }; 93 | 94 | let getToken board rid cid => { 95 | let (r1, r2, r3) = board; 96 | let fromRow (t1, t2, t3) cid => 97 | switch cid { 98 | | C1 => t1 99 | | C2 => t2 100 | | C3 => t3 101 | }; 102 | switch rid { 103 | | R1 => fromRow r1 cid 104 | | R2 => fromRow r2 cid 105 | | R3 => fromRow r3 cid 106 | } 107 | }; 108 | 109 | let isCellEmpty board rid cid => getToken board rid cid == Empty; 110 | 111 | let isDraw board => { 112 | let ((t1, t2, t3), (t4, t5, t6), (t7, t8, t9)) = board; 113 | List.for_all (fun t => t != Empty) [t1, t2, t3, t4, t5, t6, t7, t8, t9] 114 | }; 115 | 116 | let processTurn (state: ticTacToeState) (select: selection) player => { 117 | let (rid, cid) = select; 118 | 119 | if (isCellEmpty state.board rid cid) { 120 | let board = updateRow state.board rid cid (playerToken player); 121 | let progress = { 122 | let playerToken = playerToken player; 123 | let isFull (t1, t2, t3) => t1 == playerToken && t2 == playerToken && t3 == playerToken; 124 | let (r1, r2, r3) = board; 125 | let ((t1, t2, t3), (t4, t5, t6), (t7, t8, t9)) = board; 126 | let horizontal () => isFull r1 || isFull r2 || isFull r3; 127 | let vertical () => isFull (t1, t4, t7) || isFull (t2, t5, t8) || isFull (t3, t6, t9); 128 | let diagonal () => isFull (t1, t5, t9) || isFull (t3, t5, t7); 129 | if (horizontal () || vertical () || diagonal ()) { 130 | Win player 131 | } else if (isDraw board) { 132 | Draw 133 | } else { 134 | Turn (switchPlayer player) 135 | } 136 | }; 137 | {board, progress} 138 | } else { 139 | state 140 | } 141 | }; 142 | 143 | let playTurn state select => 144 | switch state.progress { 145 | | Turn player => processTurn state select player 146 | | _ => state 147 | }; 148 | -------------------------------------------------------------------------------- /frontend/src/game_test.re: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /frontend/src/loader.re: -------------------------------------------------------------------------------- 1 | open Fetch; 2 | 3 | let se = ReasonReact.stringToElement; 4 | 5 | type state = Fetch.remoteData; 6 | 7 | type action = 8 | | Load 9 | | Failed string 10 | | Finished Game.ticTacToeState; 11 | 12 | let component = ReasonReact.reducerComponent "Loader"; 13 | 14 | let make _ => { 15 | ...component, 16 | initialState: fun () => NotAsked, 17 | didMount: fun self => { 18 | Js.Promise.( 19 | Fetch.fetchData () |> 20 | then_ (fun data => (self.reduce (fun () => Finished data)) () |> resolve) |> 21 | catch ( 22 | fun err => 23 | switch (Fetch.handleFailure err) { 24 | | Some msg => 25 | self.reduce (fun () => Failed msg) (); 26 | resolve () 27 | | None => 28 | self.reduce (fun () => Failed "Unhandled Exception occurred!") (); 29 | resolve () 30 | } 31 | ) 32 | ) |> ignore; 33 | ReasonReact.NoUpdate 34 | }, 35 | reducer: fun action _state => 36 | switch action { 37 | | Load => ReasonReact.Update Loading 38 | | Failed msg => ReasonReact.Update (Error msg) 39 | | Finished data => ReasonReact.Update (Success data) 40 | }, 41 | render: fun {state} => 42 | switch state { 43 | | NotAsked =>
(se "Starting Application")
44 | | Loading =>
(se "Loading Game...")
45 | | Error errorMsg =>
(se errorMsg)
46 | | Success {board, progress} => 47 | } 48 | }; 49 | -------------------------------------------------------------------------------- /frontend/src/square.re: -------------------------------------------------------------------------------- 1 | 2 | open Game; 3 | 4 | let emptySvg = "M571 589q-10-25-34-35t-49 0q-108 44-191 127t-127 191q-10 25 0 49t35 34q13 5 24 5 42 0 60-40 34-84 98.5-148.5t148.5-98.5q25-11 35-35t0-49zm942-356l46 46-244 243 68 68q19 19 19 45.5t-19 45.5l-64 64q89 161 89 343 0 143-55.5 273.5t-150 225-225 150-273.5 55.5-273.5-55.5-225-150-150-225-55.5-273.5 55.5-273.5 150-225 225-150 273.5-55.5q182 0 343 89l64-64q19-19 45.5-19t45.5 19l68 68zm8-56q-10 10-22 10-13 0-23-10l-91-90q-9-10-9-23t9-23q10-9 23-9t23 9l90 91q10 9 10 22.5t-10 22.5zm230 230q-11 9-23 9t-23-9l-90-91q-10-9-10-22.5t10-22.5q9-10 22.5-10t22.5 10l91 90q9 10 9 23t-9 23zm41-183q0 14-9 23t-23 9h-96q-14 0-23-9t-9-23 9-23 23-9h96q14 0 23 9t9 23zm-192-192v96q0 14-9 23t-23 9-23-9-9-23v-96q0-14 9-23t23-9 23 9 9 23zm151 55l-91 90q-10 10-22 10-13 0-23-10-10-9-10-22.5t10-22.5l90-91q10-9 23-9t23 9q9 10 9 23t-9 23z"; 5 | 6 | let crossSvg = "M1490 1322q0 40-28 68l-136 136q-28 28-68 28t-68-28l-294-294-294 294q-28 28-68 28t-68-28l-136-136q-28-28-28-68t28-68l294-294-294-294q-28-28-28-68t28-68l136-136q28-28 68-28t68 28l294 294 294-294q28-28 68-28t68 28l136 136q28 28 28 68t-28 68l-294 294 294 294q28 28 28 68z"; 7 | 8 | let circleSvg = "M896 352q-148 0-273 73t-198 198-73 273 73 273 198 198 273 73 273-73 198-198 73-273-73-273-198-198-273-73zm768 544q0 209-103 385.5t-279.5 279.5-385.5 103-385.5-103-279.5-279.5-103-385.5 103-385.5 279.5-279.5 385.5-103 385.5 103 279.5 279.5 103 385.5z"; 9 | 10 | type props = {value: token, handleClick: ReactEventRe.Mouse.t => unit}; 11 | 12 | let component = ReasonReact.statelessComponent "Square"; 13 | 14 | let name = "Square"; 15 | let squareStyle = 16 | ReactDOMRe.Style.make width::"25px" backgroundColor::"blue" fontSize::"100pt" (); 17 | 18 | let make ::value ::handleClick _children => { 19 | ...component, 20 | render: fun _self => 21 | 22 | ( 23 | switch value { 24 | | Cross => 25 | 26 | 27 | 28 | | Circle => 29 | 30 | 31 | 32 | | Empty => 33 | 34 | 35 | 36 | } 37 | ) 38 | 39 | }; 40 | -------------------------------------------------------------------------------- /frontend/src/tictactoe.re: -------------------------------------------------------------------------------- 1 | open Game; 2 | 3 | type action = 4 | | PlayTurn selection 5 | | Restart; 6 | 7 | type state = ticTacToeState; 8 | 9 | let component = ReasonReact.reducerComponent "TicTacToe"; 10 | 11 | let se = ReasonReact.stringToElement; 12 | 13 | let renderWin player restartClick => 14 |
15 |
(se (player_to_string player ^ " won!"))
16 | 17 |
; 18 | 19 | let renderDraw restartClick => 20 |
21 |
(ReasonReact.stringToElement "It's a draw!")
22 | 23 |
; 24 | 25 | let renderCurrentPlayer player => 26 |
(se ("Player: " ^ player_to_string player))
; 27 | 28 | let make ::board=? ::progress=? _children => { 29 | ...component, 30 | initialState: fun () => { 31 | let init = initialState (); 32 | switch (board, progress) { 33 | | (Some b, Some p) => {board: b, progress: p} 34 | | (Some b, None) => {...init, board: b} 35 | | (None, Some p) => {...init, progress: p} 36 | | (None, None) => init 37 | } 38 | }, 39 | reducer: fun action state => 40 | switch action { 41 | | PlayTurn s => ReasonReact.Update (playTurn state s) 42 | | Restart => ReasonReact.Update (initialState ()) 43 | }, 44 | render: fun {state, reduce} => 45 |
46 |
47 | PlayTurn selection)) /> 48 |
49 | ( 50 | switch state.progress { 51 | | Turn p => renderCurrentPlayer p 52 | | Win p => renderWin p (reduce (fun _evt => Restart)) 53 | | Draw => renderDraw (reduce (fun _evt => Restart)) 54 | } 55 | ) 56 |
57 | }; 58 | -------------------------------------------------------------------------------- /frontend/webpack.config.js: -------------------------------------------------------------------------------- 1 | const path = require('path'); 2 | 3 | module.exports = { 4 | entry: { 5 | app: './lib/js/src/app.js', 6 | }, 7 | output: { 8 | path: path.join(__dirname, "bundledOutputs"), 9 | filename: '[name].js', 10 | }, 11 | }; 12 | -------------------------------------------------------------------------------- /frontend/yarn.lock: -------------------------------------------------------------------------------- 1 | # THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. 2 | # yarn lockfile v1 3 | 4 | 5 | abbrev@1: 6 | version "1.1.0" 7 | resolved "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.0.tgz#d0554c2256636e2f56e7c2e5ad183f859428d81f" 8 | 9 | acorn@^3.0.0: 10 | version "3.3.0" 11 | resolved "https://registry.yarnpkg.com/acorn/-/acorn-3.3.0.tgz#45e37fb39e8da3f25baee3ff5369e2bb5f22017a" 12 | 13 | ajv@^4.9.1: 14 | version "4.11.8" 15 | resolved "https://registry.yarnpkg.com/ajv/-/ajv-4.11.8.tgz#82ffb02b29e662ae53bdc20af15947706739c536" 16 | dependencies: 17 | co "^4.6.0" 18 | json-stable-stringify "^1.0.1" 19 | 20 | align-text@^0.1.1, align-text@^0.1.3: 21 | version "0.1.4" 22 | resolved "https://registry.yarnpkg.com/align-text/-/align-text-0.1.4.tgz#0cd90a561093f35d0a99256c22b7069433fad117" 23 | dependencies: 24 | kind-of "^3.0.2" 25 | longest "^1.0.1" 26 | repeat-string "^1.5.2" 27 | 28 | amdefine@>=0.0.4: 29 | version "1.0.1" 30 | resolved "https://registry.yarnpkg.com/amdefine/-/amdefine-1.0.1.tgz#4a5282ac164729e93619bcfd3ad151f817ce91f5" 31 | 32 | ansi-regex@^2.0.0: 33 | version "2.1.1" 34 | resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-2.1.1.tgz#c3b33ab5ee360d86e0e628f0468ae7ef27d654df" 35 | 36 | anymatch@^1.3.0: 37 | version "1.3.2" 38 | resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-1.3.2.tgz#553dcb8f91e3c889845dfdba34c77721b90b9d7a" 39 | dependencies: 40 | micromatch "^2.1.5" 41 | normalize-path "^2.0.0" 42 | 43 | aproba@^1.0.3: 44 | version "1.1.2" 45 | resolved "https://registry.yarnpkg.com/aproba/-/aproba-1.1.2.tgz#45c6629094de4e96f693ef7eab74ae079c240fc1" 46 | 47 | are-we-there-yet@~1.1.2: 48 | version "1.1.4" 49 | resolved "https://registry.yarnpkg.com/are-we-there-yet/-/are-we-there-yet-1.1.4.tgz#bb5dca382bb94f05e15194373d16fd3ba1ca110d" 50 | dependencies: 51 | delegates "^1.0.0" 52 | readable-stream "^2.0.6" 53 | 54 | arr-diff@^2.0.0: 55 | version "2.0.0" 56 | resolved "https://registry.yarnpkg.com/arr-diff/-/arr-diff-2.0.0.tgz#8f3b827f955a8bd669697e4a4256ac3ceae356cf" 57 | dependencies: 58 | arr-flatten "^1.0.1" 59 | 60 | arr-flatten@^1.0.1: 61 | version "1.1.0" 62 | resolved "https://registry.yarnpkg.com/arr-flatten/-/arr-flatten-1.1.0.tgz#36048bbff4e7b47e136644316c99669ea5ae91f1" 63 | 64 | array-unique@^0.2.1: 65 | version "0.2.1" 66 | resolved "https://registry.yarnpkg.com/array-unique/-/array-unique-0.2.1.tgz#a1d97ccafcbc2625cc70fadceb36a50c58b01a53" 67 | 68 | asap@~2.0.3: 69 | version "2.0.6" 70 | resolved "https://registry.yarnpkg.com/asap/-/asap-2.0.6.tgz#e50347611d7e690943208bbdafebcbc2fb866d46" 71 | 72 | asn1@~0.2.3: 73 | version "0.2.3" 74 | resolved "https://registry.yarnpkg.com/asn1/-/asn1-0.2.3.tgz#dac8787713c9966849fc8180777ebe9c1ddf3b86" 75 | 76 | assert-plus@1.0.0, assert-plus@^1.0.0: 77 | version "1.0.0" 78 | resolved "https://registry.yarnpkg.com/assert-plus/-/assert-plus-1.0.0.tgz#f12e0f3c5d77b0b1cdd9146942e4e96c1e4dd525" 79 | 80 | assert-plus@^0.2.0: 81 | version "0.2.0" 82 | resolved "https://registry.yarnpkg.com/assert-plus/-/assert-plus-0.2.0.tgz#d74e1b87e7affc0db8aadb7021f3fe48101ab234" 83 | 84 | assert@^1.1.1: 85 | version "1.4.1" 86 | resolved "https://registry.yarnpkg.com/assert/-/assert-1.4.1.tgz#99912d591836b5a6f5b345c0f07eefc08fc65d91" 87 | dependencies: 88 | util "0.10.3" 89 | 90 | async-each@^1.0.0: 91 | version "1.0.1" 92 | resolved "https://registry.yarnpkg.com/async-each/-/async-each-1.0.1.tgz#19d386a1d9edc6e7c1c85d388aedbcc56d33602d" 93 | 94 | async@^0.9.0: 95 | version "0.9.2" 96 | resolved "https://registry.yarnpkg.com/async/-/async-0.9.2.tgz#aea74d5e61c1f899613bf64bda66d4c78f2fd17d" 97 | 98 | async@^1.3.0: 99 | version "1.5.2" 100 | resolved "https://registry.yarnpkg.com/async/-/async-1.5.2.tgz#ec6a61ae56480c0c3cb241c95618e20892f9672a" 101 | 102 | async@~0.2.6: 103 | version "0.2.10" 104 | resolved "https://registry.yarnpkg.com/async/-/async-0.2.10.tgz#b6bbe0b0674b9d719708ca38de8c237cb526c3d1" 105 | 106 | asynckit@^0.4.0: 107 | version "0.4.0" 108 | resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" 109 | 110 | aws-sign2@~0.6.0: 111 | version "0.6.0" 112 | resolved "https://registry.yarnpkg.com/aws-sign2/-/aws-sign2-0.6.0.tgz#14342dd38dbcc94d0e5b87d763cd63612c0e794f" 113 | 114 | aws4@^1.2.1: 115 | version "1.6.0" 116 | resolved "https://registry.yarnpkg.com/aws4/-/aws4-1.6.0.tgz#83ef5ca860b2b32e4a0deedee8c771b9db57471e" 117 | 118 | balanced-match@^1.0.0: 119 | version "1.0.0" 120 | resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.0.tgz#89b4d199ab2bee49de164ea02b89ce462d71b767" 121 | 122 | base64-js@^1.0.2: 123 | version "1.2.1" 124 | resolved "https://registry.yarnpkg.com/base64-js/-/base64-js-1.2.1.tgz#a91947da1f4a516ea38e5b4ec0ec3773675e0886" 125 | 126 | bcrypt-pbkdf@^1.0.0: 127 | version "1.0.1" 128 | resolved "https://registry.yarnpkg.com/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.1.tgz#63bc5dcb61331b92bc05fd528953c33462a06f8d" 129 | dependencies: 130 | tweetnacl "^0.14.3" 131 | 132 | big.js@^3.1.3: 133 | version "3.1.3" 134 | resolved "https://registry.yarnpkg.com/big.js/-/big.js-3.1.3.tgz#4cada2193652eb3ca9ec8e55c9015669c9806978" 135 | 136 | binary-extensions@^1.0.0: 137 | version "1.10.0" 138 | resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-1.10.0.tgz#9aeb9a6c5e88638aad171e167f5900abe24835d0" 139 | 140 | block-stream@*: 141 | version "0.0.9" 142 | resolved "https://registry.yarnpkg.com/block-stream/-/block-stream-0.0.9.tgz#13ebfe778a03205cfe03751481ebb4b3300c126a" 143 | dependencies: 144 | inherits "~2.0.0" 145 | 146 | boom@2.x.x: 147 | version "2.10.1" 148 | resolved "https://registry.yarnpkg.com/boom/-/boom-2.10.1.tgz#39c8918ceff5799f83f9492a848f625add0c766f" 149 | dependencies: 150 | hoek "2.x.x" 151 | 152 | brace-expansion@^1.1.7: 153 | version "1.1.8" 154 | resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.8.tgz#c07b211c7c952ec1f8efd51a77ef0d1d3990a292" 155 | dependencies: 156 | balanced-match "^1.0.0" 157 | concat-map "0.0.1" 158 | 159 | braces@^1.8.2: 160 | version "1.8.5" 161 | resolved "https://registry.yarnpkg.com/braces/-/braces-1.8.5.tgz#ba77962e12dff969d6b76711e914b737857bf6a7" 162 | dependencies: 163 | expand-range "^1.8.1" 164 | preserve "^0.2.0" 165 | repeat-element "^1.1.2" 166 | 167 | browserify-aes@0.4.0: 168 | version "0.4.0" 169 | resolved "https://registry.yarnpkg.com/browserify-aes/-/browserify-aes-0.4.0.tgz#067149b668df31c4b58533e02d01e806d8608e2c" 170 | dependencies: 171 | inherits "^2.0.1" 172 | 173 | browserify-zlib@^0.1.4: 174 | version "0.1.4" 175 | resolved "https://registry.yarnpkg.com/browserify-zlib/-/browserify-zlib-0.1.4.tgz#bb35f8a519f600e0fa6b8485241c979d0141fb2d" 176 | dependencies: 177 | pako "~0.2.0" 178 | 179 | bs-fetch@^0.1.1: 180 | version "0.1.1" 181 | resolved "https://registry.yarnpkg.com/bs-fetch/-/bs-fetch-0.1.1.tgz#1bee13786813eeee697c48959c008bc08ed8210a" 182 | 183 | bs-json@^0.2.1: 184 | version "0.2.1" 185 | resolved "https://registry.yarnpkg.com/bs-json/-/bs-json-0.2.1.tgz#b30bd33405a1694cd1cd78e927d10cfa93b80a0a" 186 | 187 | bs-platform@^1.9.1: 188 | version "1.9.1" 189 | resolved "https://registry.yarnpkg.com/bs-platform/-/bs-platform-1.9.1.tgz#1195562f0f8b131cc758693e7c9b31d7e0022001" 190 | 191 | buffer@^4.9.0: 192 | version "4.9.1" 193 | resolved "https://registry.yarnpkg.com/buffer/-/buffer-4.9.1.tgz#6d1bb601b07a4efced97094132093027c95bc298" 194 | dependencies: 195 | base64-js "^1.0.2" 196 | ieee754 "^1.1.4" 197 | isarray "^1.0.0" 198 | 199 | builtin-status-codes@^3.0.0: 200 | version "3.0.0" 201 | resolved "https://registry.yarnpkg.com/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz#85982878e21b98e1c66425e03d0174788f569ee8" 202 | 203 | camelcase@^1.0.2: 204 | version "1.2.1" 205 | resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-1.2.1.tgz#9bb5304d2e0b56698b2c758b08a3eaa9daa58a39" 206 | 207 | caseless@~0.12.0: 208 | version "0.12.0" 209 | resolved "https://registry.yarnpkg.com/caseless/-/caseless-0.12.0.tgz#1b681c21ff84033c826543090689420d187151dc" 210 | 211 | center-align@^0.1.1: 212 | version "0.1.3" 213 | resolved "https://registry.yarnpkg.com/center-align/-/center-align-0.1.3.tgz#aa0d32629b6ee972200411cbd4461c907bc2b7ad" 214 | dependencies: 215 | align-text "^0.1.3" 216 | lazy-cache "^1.0.3" 217 | 218 | chokidar@^1.0.0: 219 | version "1.7.0" 220 | resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-1.7.0.tgz#798e689778151c8076b4b360e5edd28cda2bb468" 221 | dependencies: 222 | anymatch "^1.3.0" 223 | async-each "^1.0.0" 224 | glob-parent "^2.0.0" 225 | inherits "^2.0.1" 226 | is-binary-path "^1.0.0" 227 | is-glob "^2.0.0" 228 | path-is-absolute "^1.0.0" 229 | readdirp "^2.0.0" 230 | optionalDependencies: 231 | fsevents "^1.0.0" 232 | 233 | cliui@^2.1.0: 234 | version "2.1.0" 235 | resolved "https://registry.yarnpkg.com/cliui/-/cliui-2.1.0.tgz#4b475760ff80264c762c3a1719032e91c7fea0d1" 236 | dependencies: 237 | center-align "^0.1.1" 238 | right-align "^0.1.1" 239 | wordwrap "0.0.2" 240 | 241 | clone@^1.0.2: 242 | version "1.0.2" 243 | resolved "https://registry.yarnpkg.com/clone/-/clone-1.0.2.tgz#260b7a99ebb1edfe247538175f783243cb19d149" 244 | 245 | co@^4.6.0: 246 | version "4.6.0" 247 | resolved "https://registry.yarnpkg.com/co/-/co-4.6.0.tgz#6ea6bdf3d853ae54ccb8e47bfa0bf3f9031fb184" 248 | 249 | code-point-at@^1.0.0: 250 | version "1.1.0" 251 | resolved "https://registry.yarnpkg.com/code-point-at/-/code-point-at-1.1.0.tgz#0d070b4d043a5bea33a2f1a40e2edb3d9a4ccf77" 252 | 253 | combined-stream@^1.0.5, combined-stream@~1.0.5: 254 | version "1.0.5" 255 | resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.5.tgz#938370a57b4a51dea2c77c15d5c5fdf895164009" 256 | dependencies: 257 | delayed-stream "~1.0.0" 258 | 259 | concat-map@0.0.1: 260 | version "0.0.1" 261 | resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" 262 | 263 | console-browserify@^1.1.0: 264 | version "1.1.0" 265 | resolved "https://registry.yarnpkg.com/console-browserify/-/console-browserify-1.1.0.tgz#f0241c45730a9fc6323b206dbf38edc741d0bb10" 266 | dependencies: 267 | date-now "^0.1.4" 268 | 269 | console-control-strings@^1.0.0, console-control-strings@~1.1.0: 270 | version "1.1.0" 271 | resolved "https://registry.yarnpkg.com/console-control-strings/-/console-control-strings-1.1.0.tgz#3d7cf4464db6446ea644bf4b39507f9851008e8e" 272 | 273 | constants-browserify@^1.0.0: 274 | version "1.0.0" 275 | resolved "https://registry.yarnpkg.com/constants-browserify/-/constants-browserify-1.0.0.tgz#c20b96d8c617748aaf1c16021760cd27fcb8cb75" 276 | 277 | core-js@^1.0.0: 278 | version "1.2.7" 279 | resolved "https://registry.yarnpkg.com/core-js/-/core-js-1.2.7.tgz#652294c14651db28fa93bd2d5ff2983a4f08c636" 280 | 281 | core-util-is@1.0.2, core-util-is@~1.0.0: 282 | version "1.0.2" 283 | resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" 284 | 285 | create-react-class@^15.6.0: 286 | version "15.6.0" 287 | resolved "https://registry.yarnpkg.com/create-react-class/-/create-react-class-15.6.0.tgz#ab448497c26566e1e29413e883207d57cfe7bed4" 288 | dependencies: 289 | fbjs "^0.8.9" 290 | loose-envify "^1.3.1" 291 | object-assign "^4.1.1" 292 | 293 | cryptiles@2.x.x: 294 | version "2.0.5" 295 | resolved "https://registry.yarnpkg.com/cryptiles/-/cryptiles-2.0.5.tgz#3bdfecdc608147c1c67202fa291e7dca59eaa3b8" 296 | dependencies: 297 | boom "2.x.x" 298 | 299 | crypto-browserify@3.3.0: 300 | version "3.3.0" 301 | resolved "https://registry.yarnpkg.com/crypto-browserify/-/crypto-browserify-3.3.0.tgz#b9fc75bb4a0ed61dcf1cd5dae96eb30c9c3e506c" 302 | dependencies: 303 | browserify-aes "0.4.0" 304 | pbkdf2-compat "2.0.1" 305 | ripemd160 "0.2.0" 306 | sha.js "2.2.6" 307 | 308 | dashdash@^1.12.0: 309 | version "1.14.1" 310 | resolved "https://registry.yarnpkg.com/dashdash/-/dashdash-1.14.1.tgz#853cfa0f7cbe2fed5de20326b8dd581035f6e2f0" 311 | dependencies: 312 | assert-plus "^1.0.0" 313 | 314 | date-now@^0.1.4: 315 | version "0.1.4" 316 | resolved "https://registry.yarnpkg.com/date-now/-/date-now-0.1.4.tgz#eaf439fd4d4848ad74e5cc7dbef200672b9e345b" 317 | 318 | debug@^2.2.0: 319 | version "2.6.8" 320 | resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.8.tgz#e731531ca2ede27d188222427da17821d68ff4fc" 321 | dependencies: 322 | ms "2.0.0" 323 | 324 | decamelize@^1.0.0: 325 | version "1.2.0" 326 | resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290" 327 | 328 | deep-extend@~0.4.0: 329 | version "0.4.2" 330 | resolved "https://registry.yarnpkg.com/deep-extend/-/deep-extend-0.4.2.tgz#48b699c27e334bf89f10892be432f6e4c7d34a7f" 331 | 332 | delayed-stream@~1.0.0: 333 | version "1.0.0" 334 | resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" 335 | 336 | delegates@^1.0.0: 337 | version "1.0.0" 338 | resolved "https://registry.yarnpkg.com/delegates/-/delegates-1.0.0.tgz#84c6e159b81904fdca59a0ef44cd870d31250f9a" 339 | 340 | domain-browser@^1.1.1: 341 | version "1.1.7" 342 | resolved "https://registry.yarnpkg.com/domain-browser/-/domain-browser-1.1.7.tgz#867aa4b093faa05f1de08c06f4d7b21fdf8698bc" 343 | 344 | ecc-jsbn@~0.1.1: 345 | version "0.1.1" 346 | resolved "https://registry.yarnpkg.com/ecc-jsbn/-/ecc-jsbn-0.1.1.tgz#0fc73a9ed5f0d53c38193398523ef7e543777505" 347 | dependencies: 348 | jsbn "~0.1.0" 349 | 350 | emojis-list@^2.0.0: 351 | version "2.1.0" 352 | resolved "https://registry.yarnpkg.com/emojis-list/-/emojis-list-2.1.0.tgz#4daa4d9db00f9819880c79fa457ae5b09a1fd389" 353 | 354 | encoding@^0.1.11: 355 | version "0.1.12" 356 | resolved "https://registry.yarnpkg.com/encoding/-/encoding-0.1.12.tgz#538b66f3ee62cd1ab51ec323829d1f9480c74beb" 357 | dependencies: 358 | iconv-lite "~0.4.13" 359 | 360 | enhanced-resolve@~0.9.0: 361 | version "0.9.1" 362 | resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-0.9.1.tgz#4d6e689b3725f86090927ccc86cd9f1635b89e2e" 363 | dependencies: 364 | graceful-fs "^4.1.2" 365 | memory-fs "^0.2.0" 366 | tapable "^0.1.8" 367 | 368 | errno@^0.1.3: 369 | version "0.1.4" 370 | resolved "https://registry.yarnpkg.com/errno/-/errno-0.1.4.tgz#b896e23a9e5e8ba33871fc996abd3635fc9a1c7d" 371 | dependencies: 372 | prr "~0.0.0" 373 | 374 | events@^1.0.0: 375 | version "1.1.1" 376 | resolved "https://registry.yarnpkg.com/events/-/events-1.1.1.tgz#9ebdb7635ad099c70dcc4c2a1f5004288e8bd924" 377 | 378 | expand-brackets@^0.1.4: 379 | version "0.1.5" 380 | resolved "https://registry.yarnpkg.com/expand-brackets/-/expand-brackets-0.1.5.tgz#df07284e342a807cd733ac5af72411e581d1177b" 381 | dependencies: 382 | is-posix-bracket "^0.1.0" 383 | 384 | expand-range@^1.8.1: 385 | version "1.8.2" 386 | resolved "https://registry.yarnpkg.com/expand-range/-/expand-range-1.8.2.tgz#a299effd335fe2721ebae8e257ec79644fc85337" 387 | dependencies: 388 | fill-range "^2.1.0" 389 | 390 | extend@~3.0.0: 391 | version "3.0.1" 392 | resolved "https://registry.yarnpkg.com/extend/-/extend-3.0.1.tgz#a755ea7bc1adfcc5a31ce7e762dbaadc5e636444" 393 | 394 | extglob@^0.3.1: 395 | version "0.3.2" 396 | resolved "https://registry.yarnpkg.com/extglob/-/extglob-0.3.2.tgz#2e18ff3d2f49ab2765cec9023f011daa8d8349a1" 397 | dependencies: 398 | is-extglob "^1.0.0" 399 | 400 | extsprintf@1.3.0, extsprintf@^1.2.0: 401 | version "1.3.0" 402 | resolved "https://registry.yarnpkg.com/extsprintf/-/extsprintf-1.3.0.tgz#96918440e3041a7a414f8c52e3c574eb3c3e1e05" 403 | 404 | fbjs@^0.8.9: 405 | version "0.8.14" 406 | resolved "https://registry.yarnpkg.com/fbjs/-/fbjs-0.8.14.tgz#d1dbe2be254c35a91e09f31f9cd50a40b2a0ed1c" 407 | dependencies: 408 | core-js "^1.0.0" 409 | isomorphic-fetch "^2.1.1" 410 | loose-envify "^1.0.0" 411 | object-assign "^4.1.0" 412 | promise "^7.1.1" 413 | setimmediate "^1.0.5" 414 | ua-parser-js "^0.7.9" 415 | 416 | filename-regex@^2.0.0: 417 | version "2.0.1" 418 | resolved "https://registry.yarnpkg.com/filename-regex/-/filename-regex-2.0.1.tgz#c1c4b9bee3e09725ddb106b75c1e301fe2f18b26" 419 | 420 | fill-range@^2.1.0: 421 | version "2.2.3" 422 | resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-2.2.3.tgz#50b77dfd7e469bc7492470963699fe7a8485a723" 423 | dependencies: 424 | is-number "^2.1.0" 425 | isobject "^2.0.0" 426 | randomatic "^1.1.3" 427 | repeat-element "^1.1.2" 428 | repeat-string "^1.5.2" 429 | 430 | for-in@^1.0.1: 431 | version "1.0.2" 432 | resolved "https://registry.yarnpkg.com/for-in/-/for-in-1.0.2.tgz#81068d295a8142ec0ac726c6e2200c30fb6d5e80" 433 | 434 | for-own@^0.1.4: 435 | version "0.1.5" 436 | resolved "https://registry.yarnpkg.com/for-own/-/for-own-0.1.5.tgz#5265c681a4f294dabbf17c9509b6763aa84510ce" 437 | dependencies: 438 | for-in "^1.0.1" 439 | 440 | forever-agent@~0.6.1: 441 | version "0.6.1" 442 | resolved "https://registry.yarnpkg.com/forever-agent/-/forever-agent-0.6.1.tgz#fbc71f0c41adeb37f96c577ad1ed42d8fdacca91" 443 | 444 | form-data@~2.1.1: 445 | version "2.1.4" 446 | resolved "https://registry.yarnpkg.com/form-data/-/form-data-2.1.4.tgz#33c183acf193276ecaa98143a69e94bfee1750d1" 447 | dependencies: 448 | asynckit "^0.4.0" 449 | combined-stream "^1.0.5" 450 | mime-types "^2.1.12" 451 | 452 | fs.realpath@^1.0.0: 453 | version "1.0.0" 454 | resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" 455 | 456 | fsevents@^1.0.0: 457 | version "1.1.2" 458 | resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-1.1.2.tgz#3282b713fb3ad80ede0e9fcf4611b5aa6fc033f4" 459 | dependencies: 460 | nan "^2.3.0" 461 | node-pre-gyp "^0.6.36" 462 | 463 | fstream-ignore@^1.0.5: 464 | version "1.0.5" 465 | resolved "https://registry.yarnpkg.com/fstream-ignore/-/fstream-ignore-1.0.5.tgz#9c31dae34767018fe1d249b24dada67d092da105" 466 | dependencies: 467 | fstream "^1.0.0" 468 | inherits "2" 469 | minimatch "^3.0.0" 470 | 471 | fstream@^1.0.0, fstream@^1.0.10, fstream@^1.0.2: 472 | version "1.0.11" 473 | resolved "https://registry.yarnpkg.com/fstream/-/fstream-1.0.11.tgz#5c1fb1f117477114f0632a0eb4b71b3cb0fd3171" 474 | dependencies: 475 | graceful-fs "^4.1.2" 476 | inherits "~2.0.0" 477 | mkdirp ">=0.5 0" 478 | rimraf "2" 479 | 480 | gauge@~2.7.3: 481 | version "2.7.4" 482 | resolved "https://registry.yarnpkg.com/gauge/-/gauge-2.7.4.tgz#2c03405c7538c39d7eb37b317022e325fb018bf7" 483 | dependencies: 484 | aproba "^1.0.3" 485 | console-control-strings "^1.0.0" 486 | has-unicode "^2.0.0" 487 | object-assign "^4.1.0" 488 | signal-exit "^3.0.0" 489 | string-width "^1.0.1" 490 | strip-ansi "^3.0.1" 491 | wide-align "^1.1.0" 492 | 493 | getpass@^0.1.1: 494 | version "0.1.7" 495 | resolved "https://registry.yarnpkg.com/getpass/-/getpass-0.1.7.tgz#5eff8e3e684d569ae4cb2b1282604e8ba62149fa" 496 | dependencies: 497 | assert-plus "^1.0.0" 498 | 499 | glob-base@^0.3.0: 500 | version "0.3.0" 501 | resolved "https://registry.yarnpkg.com/glob-base/-/glob-base-0.3.0.tgz#dbb164f6221b1c0b1ccf82aea328b497df0ea3c4" 502 | dependencies: 503 | glob-parent "^2.0.0" 504 | is-glob "^2.0.0" 505 | 506 | glob-parent@^2.0.0: 507 | version "2.0.0" 508 | resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-2.0.0.tgz#81383d72db054fcccf5336daa902f182f6edbb28" 509 | dependencies: 510 | is-glob "^2.0.0" 511 | 512 | glob@^7.0.5: 513 | version "7.1.2" 514 | resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.2.tgz#c19c9df9a028702d678612384a6552404c636d15" 515 | dependencies: 516 | fs.realpath "^1.0.0" 517 | inflight "^1.0.4" 518 | inherits "2" 519 | minimatch "^3.0.4" 520 | once "^1.3.0" 521 | path-is-absolute "^1.0.0" 522 | 523 | graceful-fs@^4.1.2: 524 | version "4.1.11" 525 | resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.1.11.tgz#0e8bdfe4d1ddb8854d64e04ea7c00e2a026e5658" 526 | 527 | har-schema@^1.0.5: 528 | version "1.0.5" 529 | resolved "https://registry.yarnpkg.com/har-schema/-/har-schema-1.0.5.tgz#d263135f43307c02c602afc8fe95970c0151369e" 530 | 531 | har-validator@~4.2.1: 532 | version "4.2.1" 533 | resolved "https://registry.yarnpkg.com/har-validator/-/har-validator-4.2.1.tgz#33481d0f1bbff600dd203d75812a6a5fba002e2a" 534 | dependencies: 535 | ajv "^4.9.1" 536 | har-schema "^1.0.5" 537 | 538 | has-flag@^1.0.0: 539 | version "1.0.0" 540 | resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-1.0.0.tgz#9d9e793165ce017a00f00418c43f942a7b1d11fa" 541 | 542 | has-unicode@^2.0.0: 543 | version "2.0.1" 544 | resolved "https://registry.yarnpkg.com/has-unicode/-/has-unicode-2.0.1.tgz#e0e6fe6a28cf51138855e086d1691e771de2a8b9" 545 | 546 | hawk@~3.1.3: 547 | version "3.1.3" 548 | resolved "https://registry.yarnpkg.com/hawk/-/hawk-3.1.3.tgz#078444bd7c1640b0fe540d2c9b73d59678e8e1c4" 549 | dependencies: 550 | boom "2.x.x" 551 | cryptiles "2.x.x" 552 | hoek "2.x.x" 553 | sntp "1.x.x" 554 | 555 | hoek@2.x.x: 556 | version "2.16.3" 557 | resolved "https://registry.yarnpkg.com/hoek/-/hoek-2.16.3.tgz#20bb7403d3cea398e91dc4710a8ff1b8274a25ed" 558 | 559 | http-signature@~1.1.0: 560 | version "1.1.1" 561 | resolved "https://registry.yarnpkg.com/http-signature/-/http-signature-1.1.1.tgz#df72e267066cd0ac67fb76adf8e134a8fbcf91bf" 562 | dependencies: 563 | assert-plus "^0.2.0" 564 | jsprim "^1.2.2" 565 | sshpk "^1.7.0" 566 | 567 | https-browserify@0.0.1: 568 | version "0.0.1" 569 | resolved "https://registry.yarnpkg.com/https-browserify/-/https-browserify-0.0.1.tgz#3f91365cabe60b77ed0ebba24b454e3e09d95a82" 570 | 571 | iconv-lite@~0.4.13: 572 | version "0.4.18" 573 | resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.18.tgz#23d8656b16aae6742ac29732ea8f0336a4789cf2" 574 | 575 | ieee754@^1.1.4: 576 | version "1.1.8" 577 | resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.1.8.tgz#be33d40ac10ef1926701f6f08a2d86fbfd1ad3e4" 578 | 579 | indexof@0.0.1: 580 | version "0.0.1" 581 | resolved "https://registry.yarnpkg.com/indexof/-/indexof-0.0.1.tgz#82dc336d232b9062179d05ab3293a66059fd435d" 582 | 583 | inflight@^1.0.4: 584 | version "1.0.6" 585 | resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" 586 | dependencies: 587 | once "^1.3.0" 588 | wrappy "1" 589 | 590 | inherits@2, inherits@^2.0.1, inherits@~2.0.0, inherits@~2.0.1, inherits@~2.0.3: 591 | version "2.0.3" 592 | resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.3.tgz#633c2c83e3da42a502f52466022480f4208261de" 593 | 594 | inherits@2.0.1: 595 | version "2.0.1" 596 | resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.1.tgz#b17d08d326b4423e568eff719f91b0b1cbdf69f1" 597 | 598 | ini@~1.3.0: 599 | version "1.3.4" 600 | resolved "https://registry.yarnpkg.com/ini/-/ini-1.3.4.tgz#0537cb79daf59b59a1a517dff706c86ec039162e" 601 | 602 | interpret@^0.6.4: 603 | version "0.6.6" 604 | resolved "https://registry.yarnpkg.com/interpret/-/interpret-0.6.6.tgz#fecd7a18e7ce5ca6abfb953e1f86213a49f1625b" 605 | 606 | is-binary-path@^1.0.0: 607 | version "1.0.1" 608 | resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-1.0.1.tgz#75f16642b480f187a711c814161fd3a4a7655898" 609 | dependencies: 610 | binary-extensions "^1.0.0" 611 | 612 | is-buffer@^1.1.5: 613 | version "1.1.5" 614 | resolved "https://registry.yarnpkg.com/is-buffer/-/is-buffer-1.1.5.tgz#1f3b26ef613b214b88cbca23cc6c01d87961eecc" 615 | 616 | is-dotfile@^1.0.0: 617 | version "1.0.3" 618 | resolved "https://registry.yarnpkg.com/is-dotfile/-/is-dotfile-1.0.3.tgz#a6a2f32ffd2dfb04f5ca25ecd0f6b83cf798a1e1" 619 | 620 | is-equal-shallow@^0.1.3: 621 | version "0.1.3" 622 | resolved "https://registry.yarnpkg.com/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz#2238098fc221de0bcfa5d9eac4c45d638aa1c534" 623 | dependencies: 624 | is-primitive "^2.0.0" 625 | 626 | is-extendable@^0.1.1: 627 | version "0.1.1" 628 | resolved "https://registry.yarnpkg.com/is-extendable/-/is-extendable-0.1.1.tgz#62b110e289a471418e3ec36a617d472e301dfc89" 629 | 630 | is-extglob@^1.0.0: 631 | version "1.0.0" 632 | resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-1.0.0.tgz#ac468177c4943405a092fc8f29760c6ffc6206c0" 633 | 634 | is-fullwidth-code-point@^1.0.0: 635 | version "1.0.0" 636 | resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz#ef9e31386f031a7f0d643af82fde50c457ef00cb" 637 | dependencies: 638 | number-is-nan "^1.0.0" 639 | 640 | is-glob@^2.0.0, is-glob@^2.0.1: 641 | version "2.0.1" 642 | resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-2.0.1.tgz#d096f926a3ded5600f3fdfd91198cb0888c2d863" 643 | dependencies: 644 | is-extglob "^1.0.0" 645 | 646 | is-number@^2.1.0: 647 | version "2.1.0" 648 | resolved "https://registry.yarnpkg.com/is-number/-/is-number-2.1.0.tgz#01fcbbb393463a548f2f466cce16dece49db908f" 649 | dependencies: 650 | kind-of "^3.0.2" 651 | 652 | is-number@^3.0.0: 653 | version "3.0.0" 654 | resolved "https://registry.yarnpkg.com/is-number/-/is-number-3.0.0.tgz#24fd6201a4782cf50561c810276afc7d12d71195" 655 | dependencies: 656 | kind-of "^3.0.2" 657 | 658 | is-posix-bracket@^0.1.0: 659 | version "0.1.1" 660 | resolved "https://registry.yarnpkg.com/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz#3334dc79774368e92f016e6fbc0a88f5cd6e6bc4" 661 | 662 | is-primitive@^2.0.0: 663 | version "2.0.0" 664 | resolved "https://registry.yarnpkg.com/is-primitive/-/is-primitive-2.0.0.tgz#207bab91638499c07b2adf240a41a87210034575" 665 | 666 | is-stream@^1.0.1: 667 | version "1.1.0" 668 | resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-1.1.0.tgz#12d4a3dd4e68e0b79ceb8dbc84173ae80d91ca44" 669 | 670 | is-typedarray@~1.0.0: 671 | version "1.0.0" 672 | resolved "https://registry.yarnpkg.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a" 673 | 674 | isarray@1.0.0, isarray@^1.0.0, isarray@~1.0.0: 675 | version "1.0.0" 676 | resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" 677 | 678 | isobject@^2.0.0: 679 | version "2.1.0" 680 | resolved "https://registry.yarnpkg.com/isobject/-/isobject-2.1.0.tgz#f065561096a3f1da2ef46272f815c840d87e0c89" 681 | dependencies: 682 | isarray "1.0.0" 683 | 684 | isomorphic-fetch@^2.1.1: 685 | version "2.2.1" 686 | resolved "https://registry.yarnpkg.com/isomorphic-fetch/-/isomorphic-fetch-2.2.1.tgz#611ae1acf14f5e81f729507472819fe9733558a9" 687 | dependencies: 688 | node-fetch "^1.0.1" 689 | whatwg-fetch ">=0.10.0" 690 | 691 | isstream@~0.1.2: 692 | version "0.1.2" 693 | resolved "https://registry.yarnpkg.com/isstream/-/isstream-0.1.2.tgz#47e63f7af55afa6f92e1500e690eb8b8529c099a" 694 | 695 | js-tokens@^3.0.0: 696 | version "3.0.2" 697 | resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-3.0.2.tgz#9866df395102130e38f7f996bceb65443209c25b" 698 | 699 | jsbn@~0.1.0: 700 | version "0.1.1" 701 | resolved "https://registry.yarnpkg.com/jsbn/-/jsbn-0.1.1.tgz#a5e654c2e5a2deb5f201d96cefbca80c0ef2f513" 702 | 703 | json-schema@0.2.3: 704 | version "0.2.3" 705 | resolved "https://registry.yarnpkg.com/json-schema/-/json-schema-0.2.3.tgz#b480c892e59a2f05954ce727bd3f2a4e882f9e13" 706 | 707 | json-stable-stringify@^1.0.1: 708 | version "1.0.1" 709 | resolved "https://registry.yarnpkg.com/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz#9a759d39c5f2ff503fd5300646ed445f88c4f9af" 710 | dependencies: 711 | jsonify "~0.0.0" 712 | 713 | json-stringify-safe@~5.0.1: 714 | version "5.0.1" 715 | resolved "https://registry.yarnpkg.com/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz#1296a2d58fd45f19a0f6ce01d65701e2c735b6eb" 716 | 717 | json5@^0.5.0: 718 | version "0.5.1" 719 | resolved "https://registry.yarnpkg.com/json5/-/json5-0.5.1.tgz#1eade7acc012034ad84e2396767ead9fa5495821" 720 | 721 | jsonify@~0.0.0: 722 | version "0.0.0" 723 | resolved "https://registry.yarnpkg.com/jsonify/-/jsonify-0.0.0.tgz#2c74b6ee41d93ca51b7b5aaee8f503631d252a73" 724 | 725 | jsprim@^1.2.2: 726 | version "1.4.1" 727 | resolved "https://registry.yarnpkg.com/jsprim/-/jsprim-1.4.1.tgz#313e66bc1e5cc06e438bc1b7499c2e5c56acb6a2" 728 | dependencies: 729 | assert-plus "1.0.0" 730 | extsprintf "1.3.0" 731 | json-schema "0.2.3" 732 | verror "1.10.0" 733 | 734 | kind-of@^3.0.2: 735 | version "3.2.2" 736 | resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-3.2.2.tgz#31ea21a734bab9bbb0f32466d893aea51e4a3c64" 737 | dependencies: 738 | is-buffer "^1.1.5" 739 | 740 | kind-of@^4.0.0: 741 | version "4.0.0" 742 | resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-4.0.0.tgz#20813df3d712928b207378691a45066fae72dd57" 743 | dependencies: 744 | is-buffer "^1.1.5" 745 | 746 | lazy-cache@^1.0.3: 747 | version "1.0.4" 748 | resolved "https://registry.yarnpkg.com/lazy-cache/-/lazy-cache-1.0.4.tgz#a1d78fc3a50474cb80845d3b3b6e1da49a446e8e" 749 | 750 | loader-utils@^0.2.11: 751 | version "0.2.17" 752 | resolved "https://registry.yarnpkg.com/loader-utils/-/loader-utils-0.2.17.tgz#f86e6374d43205a6e6c60e9196f17c0299bfb348" 753 | dependencies: 754 | big.js "^3.1.3" 755 | emojis-list "^2.0.0" 756 | json5 "^0.5.0" 757 | object-assign "^4.0.1" 758 | 759 | longest@^1.0.1: 760 | version "1.0.1" 761 | resolved "https://registry.yarnpkg.com/longest/-/longest-1.0.1.tgz#30a0b2da38f73770e8294a0d22e6625ed77d0097" 762 | 763 | loose-envify@^1.0.0, loose-envify@^1.1.0, loose-envify@^1.3.1: 764 | version "1.3.1" 765 | resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.3.1.tgz#d1a8ad33fa9ce0e713d65fdd0ac8b748d478c848" 766 | dependencies: 767 | js-tokens "^3.0.0" 768 | 769 | memory-fs@^0.2.0: 770 | version "0.2.0" 771 | resolved "https://registry.yarnpkg.com/memory-fs/-/memory-fs-0.2.0.tgz#f2bb25368bc121e391c2520de92969caee0a0290" 772 | 773 | memory-fs@~0.3.0: 774 | version "0.3.0" 775 | resolved "https://registry.yarnpkg.com/memory-fs/-/memory-fs-0.3.0.tgz#7bcc6b629e3a43e871d7e29aca6ae8a7f15cbb20" 776 | dependencies: 777 | errno "^0.1.3" 778 | readable-stream "^2.0.1" 779 | 780 | micromatch@^2.1.5: 781 | version "2.3.11" 782 | resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-2.3.11.tgz#86677c97d1720b363431d04d0d15293bd38c1565" 783 | dependencies: 784 | arr-diff "^2.0.0" 785 | array-unique "^0.2.1" 786 | braces "^1.8.2" 787 | expand-brackets "^0.1.4" 788 | extglob "^0.3.1" 789 | filename-regex "^2.0.0" 790 | is-extglob "^1.0.0" 791 | is-glob "^2.0.1" 792 | kind-of "^3.0.2" 793 | normalize-path "^2.0.1" 794 | object.omit "^2.0.0" 795 | parse-glob "^3.0.4" 796 | regex-cache "^0.4.2" 797 | 798 | mime-db@~1.30.0: 799 | version "1.30.0" 800 | resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.30.0.tgz#74c643da2dd9d6a45399963465b26d5ca7d71f01" 801 | 802 | mime-types@^2.1.12, mime-types@~2.1.7: 803 | version "2.1.17" 804 | resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.17.tgz#09d7a393f03e995a79f8af857b70a9e0ab16557a" 805 | dependencies: 806 | mime-db "~1.30.0" 807 | 808 | minimatch@^3.0.0, minimatch@^3.0.2, minimatch@^3.0.4: 809 | version "3.0.4" 810 | resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" 811 | dependencies: 812 | brace-expansion "^1.1.7" 813 | 814 | minimist@0.0.8: 815 | version "0.0.8" 816 | resolved "https://registry.yarnpkg.com/minimist/-/minimist-0.0.8.tgz#857fcabfc3397d2625b8228262e86aa7a011b05d" 817 | 818 | minimist@^1.2.0: 819 | version "1.2.0" 820 | resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.0.tgz#a35008b20f41383eec1fb914f4cd5df79a264284" 821 | 822 | minimist@~0.0.1: 823 | version "0.0.10" 824 | resolved "https://registry.yarnpkg.com/minimist/-/minimist-0.0.10.tgz#de3f98543dbf96082be48ad1a0c7cda836301dcf" 825 | 826 | "mkdirp@>=0.5 0", mkdirp@^0.5.1, mkdirp@~0.5.0: 827 | version "0.5.1" 828 | resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.1.tgz#30057438eac6cf7f8c4767f38648d6697d75c903" 829 | dependencies: 830 | minimist "0.0.8" 831 | 832 | ms@2.0.0: 833 | version "2.0.0" 834 | resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" 835 | 836 | nan@^2.3.0: 837 | version "2.7.0" 838 | resolved "https://registry.yarnpkg.com/nan/-/nan-2.7.0.tgz#d95bf721ec877e08db276ed3fc6eb78f9083ad46" 839 | 840 | node-fetch@^1.0.1: 841 | version "1.7.2" 842 | resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-1.7.2.tgz#c54e9aac57e432875233525f3c891c4159ffefd7" 843 | dependencies: 844 | encoding "^0.1.11" 845 | is-stream "^1.0.1" 846 | 847 | node-libs-browser@^0.7.0: 848 | version "0.7.0" 849 | resolved "https://registry.yarnpkg.com/node-libs-browser/-/node-libs-browser-0.7.0.tgz#3e272c0819e308935e26674408d7af0e1491b83b" 850 | dependencies: 851 | assert "^1.1.1" 852 | browserify-zlib "^0.1.4" 853 | buffer "^4.9.0" 854 | console-browserify "^1.1.0" 855 | constants-browserify "^1.0.0" 856 | crypto-browserify "3.3.0" 857 | domain-browser "^1.1.1" 858 | events "^1.0.0" 859 | https-browserify "0.0.1" 860 | os-browserify "^0.2.0" 861 | path-browserify "0.0.0" 862 | process "^0.11.0" 863 | punycode "^1.2.4" 864 | querystring-es3 "^0.2.0" 865 | readable-stream "^2.0.5" 866 | stream-browserify "^2.0.1" 867 | stream-http "^2.3.1" 868 | string_decoder "^0.10.25" 869 | timers-browserify "^2.0.2" 870 | tty-browserify "0.0.0" 871 | url "^0.11.0" 872 | util "^0.10.3" 873 | vm-browserify "0.0.4" 874 | 875 | node-pre-gyp@^0.6.36: 876 | version "0.6.36" 877 | resolved "https://registry.yarnpkg.com/node-pre-gyp/-/node-pre-gyp-0.6.36.tgz#db604112cb74e0d477554e9b505b17abddfab786" 878 | dependencies: 879 | mkdirp "^0.5.1" 880 | nopt "^4.0.1" 881 | npmlog "^4.0.2" 882 | rc "^1.1.7" 883 | request "^2.81.0" 884 | rimraf "^2.6.1" 885 | semver "^5.3.0" 886 | tar "^2.2.1" 887 | tar-pack "^3.4.0" 888 | 889 | nopt@^4.0.1: 890 | version "4.0.1" 891 | resolved "https://registry.yarnpkg.com/nopt/-/nopt-4.0.1.tgz#d0d4685afd5415193c8c7505602d0d17cd64474d" 892 | dependencies: 893 | abbrev "1" 894 | osenv "^0.1.4" 895 | 896 | normalize-path@^2.0.0, normalize-path@^2.0.1: 897 | version "2.1.1" 898 | resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-2.1.1.tgz#1ab28b556e198363a8c1a6f7e6fa20137fe6aed9" 899 | dependencies: 900 | remove-trailing-separator "^1.0.1" 901 | 902 | npmlog@^4.0.2: 903 | version "4.1.2" 904 | resolved "https://registry.yarnpkg.com/npmlog/-/npmlog-4.1.2.tgz#08a7f2a8bf734604779a9efa4ad5cc717abb954b" 905 | dependencies: 906 | are-we-there-yet "~1.1.2" 907 | console-control-strings "~1.1.0" 908 | gauge "~2.7.3" 909 | set-blocking "~2.0.0" 910 | 911 | number-is-nan@^1.0.0: 912 | version "1.0.1" 913 | resolved "https://registry.yarnpkg.com/number-is-nan/-/number-is-nan-1.0.1.tgz#097b602b53422a522c1afb8790318336941a011d" 914 | 915 | oauth-sign@~0.8.1: 916 | version "0.8.2" 917 | resolved "https://registry.yarnpkg.com/oauth-sign/-/oauth-sign-0.8.2.tgz#46a6ab7f0aead8deae9ec0565780b7d4efeb9d43" 918 | 919 | object-assign@^4.0.1, object-assign@^4.1.0, object-assign@^4.1.1: 920 | version "4.1.1" 921 | resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" 922 | 923 | object.omit@^2.0.0: 924 | version "2.0.1" 925 | resolved "https://registry.yarnpkg.com/object.omit/-/object.omit-2.0.1.tgz#1a9c744829f39dbb858c76ca3579ae2a54ebd1fa" 926 | dependencies: 927 | for-own "^0.1.4" 928 | is-extendable "^0.1.1" 929 | 930 | once@^1.3.0, once@^1.3.3: 931 | version "1.4.0" 932 | resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" 933 | dependencies: 934 | wrappy "1" 935 | 936 | optimist@~0.6.0: 937 | version "0.6.1" 938 | resolved "https://registry.yarnpkg.com/optimist/-/optimist-0.6.1.tgz#da3ea74686fa21a19a111c326e90eb15a0196686" 939 | dependencies: 940 | minimist "~0.0.1" 941 | wordwrap "~0.0.2" 942 | 943 | os-browserify@^0.2.0: 944 | version "0.2.1" 945 | resolved "https://registry.yarnpkg.com/os-browserify/-/os-browserify-0.2.1.tgz#63fc4ccee5d2d7763d26bbf8601078e6c2e0044f" 946 | 947 | os-homedir@^1.0.0: 948 | version "1.0.2" 949 | resolved "https://registry.yarnpkg.com/os-homedir/-/os-homedir-1.0.2.tgz#ffbc4988336e0e833de0c168c7ef152121aa7fb3" 950 | 951 | os-tmpdir@^1.0.0: 952 | version "1.0.2" 953 | resolved "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz#bbe67406c79aa85c5cfec766fe5734555dfa1274" 954 | 955 | osenv@^0.1.4: 956 | version "0.1.4" 957 | resolved "https://registry.yarnpkg.com/osenv/-/osenv-0.1.4.tgz#42fe6d5953df06c8064be6f176c3d05aaaa34644" 958 | dependencies: 959 | os-homedir "^1.0.0" 960 | os-tmpdir "^1.0.0" 961 | 962 | pako@~0.2.0: 963 | version "0.2.9" 964 | resolved "https://registry.yarnpkg.com/pako/-/pako-0.2.9.tgz#f3f7522f4ef782348da8161bad9ecfd51bf83a75" 965 | 966 | parse-glob@^3.0.4: 967 | version "3.0.4" 968 | resolved "https://registry.yarnpkg.com/parse-glob/-/parse-glob-3.0.4.tgz#b2c376cfb11f35513badd173ef0bb6e3a388391c" 969 | dependencies: 970 | glob-base "^0.3.0" 971 | is-dotfile "^1.0.0" 972 | is-extglob "^1.0.0" 973 | is-glob "^2.0.0" 974 | 975 | path-browserify@0.0.0: 976 | version "0.0.0" 977 | resolved "https://registry.yarnpkg.com/path-browserify/-/path-browserify-0.0.0.tgz#a0b870729aae214005b7d5032ec2cbbb0fb4451a" 978 | 979 | path-is-absolute@^1.0.0: 980 | version "1.0.1" 981 | resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" 982 | 983 | pbkdf2-compat@2.0.1: 984 | version "2.0.1" 985 | resolved "https://registry.yarnpkg.com/pbkdf2-compat/-/pbkdf2-compat-2.0.1.tgz#b6e0c8fa99494d94e0511575802a59a5c142f288" 986 | 987 | performance-now@^0.2.0: 988 | version "0.2.0" 989 | resolved "https://registry.yarnpkg.com/performance-now/-/performance-now-0.2.0.tgz#33ef30c5c77d4ea21c5a53869d91b56d8f2555e5" 990 | 991 | preserve@^0.2.0: 992 | version "0.2.0" 993 | resolved "https://registry.yarnpkg.com/preserve/-/preserve-0.2.0.tgz#815ed1f6ebc65926f865b310c0713bcb3315ce4b" 994 | 995 | process-nextick-args@~1.0.6: 996 | version "1.0.7" 997 | resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-1.0.7.tgz#150e20b756590ad3f91093f25a4f2ad8bff30ba3" 998 | 999 | process@^0.11.0: 1000 | version "0.11.10" 1001 | resolved "https://registry.yarnpkg.com/process/-/process-0.11.10.tgz#7332300e840161bda3e69a1d1d91a7d4bc16f182" 1002 | 1003 | promise@^7.1.1: 1004 | version "7.3.1" 1005 | resolved "https://registry.yarnpkg.com/promise/-/promise-7.3.1.tgz#064b72602b18f90f29192b8b1bc418ffd1ebd3bf" 1006 | dependencies: 1007 | asap "~2.0.3" 1008 | 1009 | prop-types@^15.5.10: 1010 | version "15.5.10" 1011 | resolved "https://registry.yarnpkg.com/prop-types/-/prop-types-15.5.10.tgz#2797dfc3126182e3a95e3dfbb2e893ddd7456154" 1012 | dependencies: 1013 | fbjs "^0.8.9" 1014 | loose-envify "^1.3.1" 1015 | 1016 | prr@~0.0.0: 1017 | version "0.0.0" 1018 | resolved "https://registry.yarnpkg.com/prr/-/prr-0.0.0.tgz#1a84b85908325501411853d0081ee3fa86e2926a" 1019 | 1020 | punycode@1.3.2: 1021 | version "1.3.2" 1022 | resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.3.2.tgz#9653a036fb7c1ee42342f2325cceefea3926c48d" 1023 | 1024 | punycode@^1.2.4, punycode@^1.4.1: 1025 | version "1.4.1" 1026 | resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.4.1.tgz#c0d5a63b2718800ad8e1eb0fa5269c84dd41845e" 1027 | 1028 | qs@~6.4.0: 1029 | version "6.4.0" 1030 | resolved "https://registry.yarnpkg.com/qs/-/qs-6.4.0.tgz#13e26d28ad6b0ffaa91312cd3bf708ed351e7233" 1031 | 1032 | querystring-es3@^0.2.0: 1033 | version "0.2.1" 1034 | resolved "https://registry.yarnpkg.com/querystring-es3/-/querystring-es3-0.2.1.tgz#9ec61f79049875707d69414596fd907a4d711e73" 1035 | 1036 | querystring@0.2.0: 1037 | version "0.2.0" 1038 | resolved "https://registry.yarnpkg.com/querystring/-/querystring-0.2.0.tgz#b209849203bb25df820da756e747005878521620" 1039 | 1040 | randomatic@^1.1.3: 1041 | version "1.1.7" 1042 | resolved "https://registry.yarnpkg.com/randomatic/-/randomatic-1.1.7.tgz#c7abe9cc8b87c0baa876b19fde83fd464797e38c" 1043 | dependencies: 1044 | is-number "^3.0.0" 1045 | kind-of "^4.0.0" 1046 | 1047 | rc@^1.1.7: 1048 | version "1.2.1" 1049 | resolved "https://registry.yarnpkg.com/rc/-/rc-1.2.1.tgz#2e03e8e42ee450b8cb3dce65be1bf8974e1dfd95" 1050 | dependencies: 1051 | deep-extend "~0.4.0" 1052 | ini "~1.3.0" 1053 | minimist "^1.2.0" 1054 | strip-json-comments "~2.0.1" 1055 | 1056 | react-dom@>=15.0.0, react-dom@^15.4.2: 1057 | version "15.6.1" 1058 | resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-15.6.1.tgz#2cb0ed4191038e53c209eb3a79a23e2a4cf99470" 1059 | dependencies: 1060 | fbjs "^0.8.9" 1061 | loose-envify "^1.1.0" 1062 | object-assign "^4.1.0" 1063 | prop-types "^15.5.10" 1064 | 1065 | react@>=15.0.0, react@^15.4.2: 1066 | version "15.6.1" 1067 | resolved "https://registry.yarnpkg.com/react/-/react-15.6.1.tgz#baa8434ec6780bde997cdc380b79cd33b96393df" 1068 | dependencies: 1069 | create-react-class "^15.6.0" 1070 | fbjs "^0.8.9" 1071 | loose-envify "^1.1.0" 1072 | object-assign "^4.1.0" 1073 | prop-types "^15.5.10" 1074 | 1075 | readable-stream@^2.0.1, readable-stream@^2.0.2, readable-stream@^2.0.5, readable-stream@^2.0.6, readable-stream@^2.1.4, readable-stream@^2.2.6: 1076 | version "2.3.3" 1077 | resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.3.tgz#368f2512d79f9d46fdfc71349ae7878bbc1eb95c" 1078 | dependencies: 1079 | core-util-is "~1.0.0" 1080 | inherits "~2.0.3" 1081 | isarray "~1.0.0" 1082 | process-nextick-args "~1.0.6" 1083 | safe-buffer "~5.1.1" 1084 | string_decoder "~1.0.3" 1085 | util-deprecate "~1.0.1" 1086 | 1087 | readdirp@^2.0.0: 1088 | version "2.1.0" 1089 | resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-2.1.0.tgz#4ed0ad060df3073300c48440373f72d1cc642d78" 1090 | dependencies: 1091 | graceful-fs "^4.1.2" 1092 | minimatch "^3.0.2" 1093 | readable-stream "^2.0.2" 1094 | set-immediate-shim "^1.0.1" 1095 | 1096 | reason-react@^0.2.4: 1097 | version "0.2.4" 1098 | resolved "https://registry.yarnpkg.com/reason-react/-/reason-react-0.2.4.tgz#96d85a533fc93e695818dbb3e6a8ae05fbf0de7d" 1099 | dependencies: 1100 | react ">=15.0.0" 1101 | react-dom ">=15.0.0" 1102 | 1103 | regex-cache@^0.4.2: 1104 | version "0.4.4" 1105 | resolved "https://registry.yarnpkg.com/regex-cache/-/regex-cache-0.4.4.tgz#75bdc58a2a1496cec48a12835bc54c8d562336dd" 1106 | dependencies: 1107 | is-equal-shallow "^0.1.3" 1108 | 1109 | remove-trailing-separator@^1.0.1: 1110 | version "1.1.0" 1111 | resolved "https://registry.yarnpkg.com/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz#c24bce2a283adad5bc3f58e0d48249b92379d8ef" 1112 | 1113 | repeat-element@^1.1.2: 1114 | version "1.1.2" 1115 | resolved "https://registry.yarnpkg.com/repeat-element/-/repeat-element-1.1.2.tgz#ef089a178d1483baae4d93eb98b4f9e4e11d990a" 1116 | 1117 | repeat-string@^1.5.2: 1118 | version "1.6.1" 1119 | resolved "https://registry.yarnpkg.com/repeat-string/-/repeat-string-1.6.1.tgz#8dcae470e1c88abc2d600fff4a776286da75e637" 1120 | 1121 | request@^2.81.0: 1122 | version "2.81.0" 1123 | resolved "https://registry.yarnpkg.com/request/-/request-2.81.0.tgz#c6928946a0e06c5f8d6f8a9333469ffda46298a0" 1124 | dependencies: 1125 | aws-sign2 "~0.6.0" 1126 | aws4 "^1.2.1" 1127 | caseless "~0.12.0" 1128 | combined-stream "~1.0.5" 1129 | extend "~3.0.0" 1130 | forever-agent "~0.6.1" 1131 | form-data "~2.1.1" 1132 | har-validator "~4.2.1" 1133 | hawk "~3.1.3" 1134 | http-signature "~1.1.0" 1135 | is-typedarray "~1.0.0" 1136 | isstream "~0.1.2" 1137 | json-stringify-safe "~5.0.1" 1138 | mime-types "~2.1.7" 1139 | oauth-sign "~0.8.1" 1140 | performance-now "^0.2.0" 1141 | qs "~6.4.0" 1142 | safe-buffer "^5.0.1" 1143 | stringstream "~0.0.4" 1144 | tough-cookie "~2.3.0" 1145 | tunnel-agent "^0.6.0" 1146 | uuid "^3.0.0" 1147 | 1148 | right-align@^0.1.1: 1149 | version "0.1.3" 1150 | resolved "https://registry.yarnpkg.com/right-align/-/right-align-0.1.3.tgz#61339b722fe6a3515689210d24e14c96148613ef" 1151 | dependencies: 1152 | align-text "^0.1.1" 1153 | 1154 | rimraf@2, rimraf@^2.5.1, rimraf@^2.6.1: 1155 | version "2.6.1" 1156 | resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.6.1.tgz#c2338ec643df7a1b7fe5c54fa86f57428a55f33d" 1157 | dependencies: 1158 | glob "^7.0.5" 1159 | 1160 | ripemd160@0.2.0: 1161 | version "0.2.0" 1162 | resolved "https://registry.yarnpkg.com/ripemd160/-/ripemd160-0.2.0.tgz#2bf198bde167cacfa51c0a928e84b68bbe171fce" 1163 | 1164 | safe-buffer@^5.0.1, safe-buffer@~5.1.0, safe-buffer@~5.1.1: 1165 | version "5.1.1" 1166 | resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.1.tgz#893312af69b2123def71f57889001671eeb2c853" 1167 | 1168 | semver@^5.3.0: 1169 | version "5.4.1" 1170 | resolved "https://registry.yarnpkg.com/semver/-/semver-5.4.1.tgz#e059c09d8571f0540823733433505d3a2f00b18e" 1171 | 1172 | set-blocking@~2.0.0: 1173 | version "2.0.0" 1174 | resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7" 1175 | 1176 | set-immediate-shim@^1.0.1: 1177 | version "1.0.1" 1178 | resolved "https://registry.yarnpkg.com/set-immediate-shim/-/set-immediate-shim-1.0.1.tgz#4b2b1b27eb808a9f8dcc481a58e5e56f599f3f61" 1179 | 1180 | setimmediate@^1.0.4, setimmediate@^1.0.5: 1181 | version "1.0.5" 1182 | resolved "https://registry.yarnpkg.com/setimmediate/-/setimmediate-1.0.5.tgz#290cbb232e306942d7d7ea9b83732ab7856f8285" 1183 | 1184 | sha.js@2.2.6: 1185 | version "2.2.6" 1186 | resolved "https://registry.yarnpkg.com/sha.js/-/sha.js-2.2.6.tgz#17ddeddc5f722fb66501658895461977867315ba" 1187 | 1188 | signal-exit@^3.0.0: 1189 | version "3.0.2" 1190 | resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.2.tgz#b5fdc08f1287ea1178628e415e25132b73646c6d" 1191 | 1192 | sntp@1.x.x: 1193 | version "1.0.9" 1194 | resolved "https://registry.yarnpkg.com/sntp/-/sntp-1.0.9.tgz#6541184cc90aeea6c6e7b35e2659082443c66198" 1195 | dependencies: 1196 | hoek "2.x.x" 1197 | 1198 | source-list-map@~0.1.7: 1199 | version "0.1.8" 1200 | resolved "https://registry.yarnpkg.com/source-list-map/-/source-list-map-0.1.8.tgz#c550b2ab5427f6b3f21f5afead88c4f5587b2106" 1201 | 1202 | source-map@~0.4.1: 1203 | version "0.4.4" 1204 | resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.4.4.tgz#eba4f5da9c0dc999de68032d8b4f76173652036b" 1205 | dependencies: 1206 | amdefine ">=0.0.4" 1207 | 1208 | source-map@~0.5.1: 1209 | version "0.5.7" 1210 | resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz#8a039d2d1021d22d1ea14c80d8ea468ba2ef3fcc" 1211 | 1212 | sshpk@^1.7.0: 1213 | version "1.13.1" 1214 | resolved "https://registry.yarnpkg.com/sshpk/-/sshpk-1.13.1.tgz#512df6da6287144316dc4c18fe1cf1d940739be3" 1215 | dependencies: 1216 | asn1 "~0.2.3" 1217 | assert-plus "^1.0.0" 1218 | dashdash "^1.12.0" 1219 | getpass "^0.1.1" 1220 | optionalDependencies: 1221 | bcrypt-pbkdf "^1.0.0" 1222 | ecc-jsbn "~0.1.1" 1223 | jsbn "~0.1.0" 1224 | tweetnacl "~0.14.0" 1225 | 1226 | stream-browserify@^2.0.1: 1227 | version "2.0.1" 1228 | resolved "https://registry.yarnpkg.com/stream-browserify/-/stream-browserify-2.0.1.tgz#66266ee5f9bdb9940a4e4514cafb43bb71e5c9db" 1229 | dependencies: 1230 | inherits "~2.0.1" 1231 | readable-stream "^2.0.2" 1232 | 1233 | stream-http@^2.3.1: 1234 | version "2.7.2" 1235 | resolved "https://registry.yarnpkg.com/stream-http/-/stream-http-2.7.2.tgz#40a050ec8dc3b53b33d9909415c02c0bf1abfbad" 1236 | dependencies: 1237 | builtin-status-codes "^3.0.0" 1238 | inherits "^2.0.1" 1239 | readable-stream "^2.2.6" 1240 | to-arraybuffer "^1.0.0" 1241 | xtend "^4.0.0" 1242 | 1243 | string-width@^1.0.1, string-width@^1.0.2: 1244 | version "1.0.2" 1245 | resolved "https://registry.yarnpkg.com/string-width/-/string-width-1.0.2.tgz#118bdf5b8cdc51a2a7e70d211e07e2b0b9b107d3" 1246 | dependencies: 1247 | code-point-at "^1.0.0" 1248 | is-fullwidth-code-point "^1.0.0" 1249 | strip-ansi "^3.0.0" 1250 | 1251 | string_decoder@^0.10.25: 1252 | version "0.10.31" 1253 | resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-0.10.31.tgz#62e203bc41766c6c28c9fc84301dab1c5310fa94" 1254 | 1255 | string_decoder@~1.0.3: 1256 | version "1.0.3" 1257 | resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.0.3.tgz#0fc67d7c141825de94282dd536bec6b9bce860ab" 1258 | dependencies: 1259 | safe-buffer "~5.1.0" 1260 | 1261 | stringstream@~0.0.4: 1262 | version "0.0.5" 1263 | resolved "https://registry.yarnpkg.com/stringstream/-/stringstream-0.0.5.tgz#4e484cd4de5a0bbbee18e46307710a8a81621878" 1264 | 1265 | strip-ansi@^3.0.0, strip-ansi@^3.0.1: 1266 | version "3.0.1" 1267 | resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-3.0.1.tgz#6a385fb8853d952d5ff05d0e8aaf94278dc63dcf" 1268 | dependencies: 1269 | ansi-regex "^2.0.0" 1270 | 1271 | strip-json-comments@~2.0.1: 1272 | version "2.0.1" 1273 | resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz#3c531942e908c2697c0ec344858c286c7ca0a60a" 1274 | 1275 | supports-color@^3.1.0: 1276 | version "3.2.3" 1277 | resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-3.2.3.tgz#65ac0504b3954171d8a64946b2ae3cbb8a5f54f6" 1278 | dependencies: 1279 | has-flag "^1.0.0" 1280 | 1281 | tapable@^0.1.8, tapable@~0.1.8: 1282 | version "0.1.10" 1283 | resolved "https://registry.yarnpkg.com/tapable/-/tapable-0.1.10.tgz#29c35707c2b70e50d07482b5d202e8ed446dafd4" 1284 | 1285 | tar-pack@^3.4.0: 1286 | version "3.4.0" 1287 | resolved "https://registry.yarnpkg.com/tar-pack/-/tar-pack-3.4.0.tgz#23be2d7f671a8339376cbdb0b8fe3fdebf317984" 1288 | dependencies: 1289 | debug "^2.2.0" 1290 | fstream "^1.0.10" 1291 | fstream-ignore "^1.0.5" 1292 | once "^1.3.3" 1293 | readable-stream "^2.1.4" 1294 | rimraf "^2.5.1" 1295 | tar "^2.2.1" 1296 | uid-number "^0.0.6" 1297 | 1298 | tar@^2.2.1: 1299 | version "2.2.1" 1300 | resolved "https://registry.yarnpkg.com/tar/-/tar-2.2.1.tgz#8e4d2a256c0e2185c6b18ad694aec968b83cb1d1" 1301 | dependencies: 1302 | block-stream "*" 1303 | fstream "^1.0.2" 1304 | inherits "2" 1305 | 1306 | timers-browserify@^2.0.2: 1307 | version "2.0.4" 1308 | resolved "https://registry.yarnpkg.com/timers-browserify/-/timers-browserify-2.0.4.tgz#96ca53f4b794a5e7c0e1bd7cc88a372298fa01e6" 1309 | dependencies: 1310 | setimmediate "^1.0.4" 1311 | 1312 | to-arraybuffer@^1.0.0: 1313 | version "1.0.1" 1314 | resolved "https://registry.yarnpkg.com/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz#7d229b1fcc637e466ca081180836a7aabff83f43" 1315 | 1316 | tough-cookie@~2.3.0: 1317 | version "2.3.2" 1318 | resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-2.3.2.tgz#f081f76e4c85720e6c37a5faced737150d84072a" 1319 | dependencies: 1320 | punycode "^1.4.1" 1321 | 1322 | tty-browserify@0.0.0: 1323 | version "0.0.0" 1324 | resolved "https://registry.yarnpkg.com/tty-browserify/-/tty-browserify-0.0.0.tgz#a157ba402da24e9bf957f9aa69d524eed42901a6" 1325 | 1326 | tunnel-agent@^0.6.0: 1327 | version "0.6.0" 1328 | resolved "https://registry.yarnpkg.com/tunnel-agent/-/tunnel-agent-0.6.0.tgz#27a5dea06b36b04a0a9966774b290868f0fc40fd" 1329 | dependencies: 1330 | safe-buffer "^5.0.1" 1331 | 1332 | tweetnacl@^0.14.3, tweetnacl@~0.14.0: 1333 | version "0.14.5" 1334 | resolved "https://registry.yarnpkg.com/tweetnacl/-/tweetnacl-0.14.5.tgz#5ae68177f192d4456269d108afa93ff8743f4f64" 1335 | 1336 | ua-parser-js@^0.7.9: 1337 | version "0.7.14" 1338 | resolved "https://registry.yarnpkg.com/ua-parser-js/-/ua-parser-js-0.7.14.tgz#110d53fa4c3f326c121292bbeac904d2e03387ca" 1339 | 1340 | uglify-js@~2.7.3: 1341 | version "2.7.5" 1342 | resolved "https://registry.yarnpkg.com/uglify-js/-/uglify-js-2.7.5.tgz#4612c0c7baaee2ba7c487de4904ae122079f2ca8" 1343 | dependencies: 1344 | async "~0.2.6" 1345 | source-map "~0.5.1" 1346 | uglify-to-browserify "~1.0.0" 1347 | yargs "~3.10.0" 1348 | 1349 | uglify-to-browserify@~1.0.0: 1350 | version "1.0.2" 1351 | resolved "https://registry.yarnpkg.com/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz#6e0924d6bda6b5afe349e39a6d632850a0f882b7" 1352 | 1353 | uid-number@^0.0.6: 1354 | version "0.0.6" 1355 | resolved "https://registry.yarnpkg.com/uid-number/-/uid-number-0.0.6.tgz#0ea10e8035e8eb5b8e4449f06da1c730663baa81" 1356 | 1357 | url@^0.11.0: 1358 | version "0.11.0" 1359 | resolved "https://registry.yarnpkg.com/url/-/url-0.11.0.tgz#3838e97cfc60521eb73c525a8e55bfdd9e2e28f1" 1360 | dependencies: 1361 | punycode "1.3.2" 1362 | querystring "0.2.0" 1363 | 1364 | util-deprecate@~1.0.1: 1365 | version "1.0.2" 1366 | resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" 1367 | 1368 | util@0.10.3, util@^0.10.3: 1369 | version "0.10.3" 1370 | resolved "https://registry.yarnpkg.com/util/-/util-0.10.3.tgz#7afb1afe50805246489e3db7fe0ed379336ac0f9" 1371 | dependencies: 1372 | inherits "2.0.1" 1373 | 1374 | uuid@^3.0.0: 1375 | version "3.1.0" 1376 | resolved "https://registry.yarnpkg.com/uuid/-/uuid-3.1.0.tgz#3dd3d3e790abc24d7b0d3a034ffababe28ebbc04" 1377 | 1378 | verror@1.10.0: 1379 | version "1.10.0" 1380 | resolved "https://registry.yarnpkg.com/verror/-/verror-1.10.0.tgz#3a105ca17053af55d6e270c1f8288682e18da400" 1381 | dependencies: 1382 | assert-plus "^1.0.0" 1383 | core-util-is "1.0.2" 1384 | extsprintf "^1.2.0" 1385 | 1386 | vm-browserify@0.0.4: 1387 | version "0.0.4" 1388 | resolved "https://registry.yarnpkg.com/vm-browserify/-/vm-browserify-0.0.4.tgz#5d7ea45bbef9e4a6ff65f95438e0a87c357d5a73" 1389 | dependencies: 1390 | indexof "0.0.1" 1391 | 1392 | watchpack@^0.2.1: 1393 | version "0.2.9" 1394 | resolved "https://registry.yarnpkg.com/watchpack/-/watchpack-0.2.9.tgz#62eaa4ab5e5ba35fdfc018275626e3c0f5e3fb0b" 1395 | dependencies: 1396 | async "^0.9.0" 1397 | chokidar "^1.0.0" 1398 | graceful-fs "^4.1.2" 1399 | 1400 | webpack-core@~0.6.9: 1401 | version "0.6.9" 1402 | resolved "https://registry.yarnpkg.com/webpack-core/-/webpack-core-0.6.9.tgz#fc571588c8558da77be9efb6debdc5a3b172bdc2" 1403 | dependencies: 1404 | source-list-map "~0.1.7" 1405 | source-map "~0.4.1" 1406 | 1407 | webpack@^1.14.0: 1408 | version "1.15.0" 1409 | resolved "https://registry.yarnpkg.com/webpack/-/webpack-1.15.0.tgz#4ff31f53db03339e55164a9d468ee0324968fe98" 1410 | dependencies: 1411 | acorn "^3.0.0" 1412 | async "^1.3.0" 1413 | clone "^1.0.2" 1414 | enhanced-resolve "~0.9.0" 1415 | interpret "^0.6.4" 1416 | loader-utils "^0.2.11" 1417 | memory-fs "~0.3.0" 1418 | mkdirp "~0.5.0" 1419 | node-libs-browser "^0.7.0" 1420 | optimist "~0.6.0" 1421 | supports-color "^3.1.0" 1422 | tapable "~0.1.8" 1423 | uglify-js "~2.7.3" 1424 | watchpack "^0.2.1" 1425 | webpack-core "~0.6.9" 1426 | 1427 | whatwg-fetch@>=0.10.0: 1428 | version "2.0.3" 1429 | resolved "https://registry.yarnpkg.com/whatwg-fetch/-/whatwg-fetch-2.0.3.tgz#9c84ec2dcf68187ff00bc64e1274b442176e1c84" 1430 | 1431 | wide-align@^1.1.0: 1432 | version "1.1.2" 1433 | resolved "https://registry.yarnpkg.com/wide-align/-/wide-align-1.1.2.tgz#571e0f1b0604636ebc0dfc21b0339bbe31341710" 1434 | dependencies: 1435 | string-width "^1.0.2" 1436 | 1437 | window-size@0.1.0: 1438 | version "0.1.0" 1439 | resolved "https://registry.yarnpkg.com/window-size/-/window-size-0.1.0.tgz#5438cd2ea93b202efa3a19fe8887aee7c94f9c9d" 1440 | 1441 | wordwrap@0.0.2: 1442 | version "0.0.2" 1443 | resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-0.0.2.tgz#b79669bb42ecb409f83d583cad52ca17eaa1643f" 1444 | 1445 | wordwrap@~0.0.2: 1446 | version "0.0.3" 1447 | resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-0.0.3.tgz#a3d5da6cd5c0bc0008d37234bbaf1bed63059107" 1448 | 1449 | wrappy@1: 1450 | version "1.0.2" 1451 | resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" 1452 | 1453 | xtend@^4.0.0: 1454 | version "4.0.1" 1455 | resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.1.tgz#a5c6d532be656e23db820efb943a1f04998d63af" 1456 | 1457 | yargs@~3.10.0: 1458 | version "3.10.0" 1459 | resolved "https://registry.yarnpkg.com/yargs/-/yargs-3.10.0.tgz#f7ee7bd857dd7c1d2d38c0e74efbd681d1431fd1" 1460 | dependencies: 1461 | camelcase "^1.0.2" 1462 | cliui "^2.1.0" 1463 | decamelize "^1.0.0" 1464 | window-size "0.1.0" 1465 | --------------------------------------------------------------------------------