Update all client dependencies

This commit is contained in:
Ken-Håvard Lieng 2015-12-12 00:33:05 +01:00
parent 909ffd1998
commit 0259787fe9
10 changed files with 147 additions and 151 deletions

File diff suppressed because one or more lines are too long

View File

@ -50,7 +50,12 @@ gulp.task('js', function() {
function js(watch) { function js(watch) {
var bundler = browserify('./src/js/app.js', { var bundler = browserify('./src/js/app.js', {
debug: !argv.production, debug: !argv.production,
transform: [babelify, strictify], transform: [
babelify.configure({
presets: ['es2015', 'react']
}),
strictify
],
cache: {}, cache: {},
packageCache: {}, packageCache: {},
fullPaths: watch fullPaths: watch

View File

@ -4,39 +4,43 @@
"description": "", "description": "",
"main": "index.js", "main": "index.js",
"devDependencies": { "devDependencies": {
"babel-eslint": "^4.1.6", "babel-eslint": "^5.0.0-beta6",
"babelify": "6.1.0", "babel-preset-es2015": "^6.3.13",
"browserify": "10.2.0", "babel-preset-react": "^6.3.13",
"babelify": "7.2.0",
"browserify": "12.0.1",
"eslint": "^1.10.3", "eslint": "^1.10.3",
"eslint-plugin-react": "^3.11.3", "eslint-plugin-react": "^3.11.3",
"gulp": "~3.8.10", "gulp": "~3.9.0",
"gulp-autoprefixer": "2.2.0", "gulp-autoprefixer": "3.1.0",
"gulp-cached": "^1.1.0", "gulp-cached": "^1.1.0",
"gulp-concat": "~2.5.2", "gulp-concat": "~2.6.0",
"gulp-eslint": "^1.1.1", "gulp-eslint": "^1.1.1",
"gulp-gzip": "0.0.8", "gulp-gzip": "1.2.0",
"gulp-if": "~1.2.5", "gulp-if": "~2.0.0",
"gulp-minify-css": "1.1.1", "gulp-minify-css": "1.2.2",
"gulp-minify-html": "1.0.2", "gulp-minify-html": "1.0.4",
"gulp-streamify": "0.0.5", "gulp-streamify": "1.0.2",
"gulp-uglify": "1.2.0", "gulp-uglify": "1.5.1",
"gulp-util": "^3.0.5", "gulp-util": "^3.0.5",
"merge-stream": "^0.1.7", "merge-stream": "^1.0.0",
"reactify": "^1.1.1", "reactify": "^1.1.1",
"strictify": "~0.2.0", "strictify": "~0.2.0",
"vinyl-source-stream": "~1.0.0", "vinyl-source-stream": "~1.1.0",
"watchify": "3.2.1", "watchify": "3.6.1",
"yargs": "~1.3.3" "yargs": "~3.31.0"
}, },
"dependencies": { "dependencies": {
"autolinker": "khlieng/Autolinker.js", "autolinker": "khlieng/Autolinker.js",
"backo": "^1.1.0", "backo": "^1.1.0",
"immutable": "~3.7.2", "history": "^1.13.1",
"lodash": "3.8.0", "immutable": "^3.7.5",
"react": "0.13.3", "lodash": "3.10.1",
"react-infinite": "0.3.4", "react": "^0.14.3",
"react-dom": "^0.14.3",
"react-infinite": "0.7.2",
"react-pure-render": "~1.0.1", "react-pure-render": "~1.0.1",
"react-router": "0.13.3", "react-router": "^1.0.1",
"reflux": "0.2.7" "reflux": "0.3.0"
} }
} }

View File

@ -341,7 +341,7 @@ i[class^="icon-"]:before, i[class*=" icon-"]:before {
right: 200px; right: 200px;
} }
.messagebox > div { .messagebox-scrollable {
padding: 10px 15px; padding: 10px 15px;
overflow-y: auto !important; overflow-y: auto !important;
} }

View File

@ -10,6 +10,7 @@
<link href="bundle.css" rel="stylesheet"> <link href="bundle.css" rel="stylesheet">
</head> </head>
<body> <body>
<div id="root"></div>
<script src="vendor.js"></script> <script src="vendor.js"></script>
<script src="bundle.js"></script> <script src="bundle.js"></script>
</body> </body>

View File

@ -1,37 +1,35 @@
var React = require('react'); import React from 'react';
var Router = require('react-router'); import { render } from 'react-dom';
var Route = Router.Route; import { Router, Route, IndexRoute } from 'react-router';
var DefaultRoute = Router.DefaultRoute; import createBrowserHistory from 'history/lib/createBrowserHistory';
import './irc';
import './command';
import socket from './socket';
import util from './util';
import App from './components/App.jsx';
import Connect from './components/Connect.jsx';
import Chat from './components/Chat.jsx';
import Settings from './components/Settings.jsx';
import routeActions from './actions/route';
require('./irc'); let uuid = localStorage.uuid;
require('./command');
var socket = require('./socket');
var util = require('./util');
var App = require('./components/App.jsx');
var Connect = require('./components/Connect.jsx');
var Chat = require('./components/Chat.jsx');
var Settings = require('./components/Settings.jsx');
var routeActions = require('./actions/route');
var uuid = localStorage.uuid;
if (!uuid) { if (!uuid) {
routeActions.navigate('connect', true); routeActions.navigate('connect', true);
localStorage.uuid = uuid = util.UUID(); localStorage.uuid = uuid = util.UUID();
} }
socket.on('connect', () => socket.send('uuid', uuid)); socket.on('connect', () => socket.send('uuid', uuid));
socket.on('error', (error) => console.log(error.server + ': ' + error.message)); socket.on('error', error => console.log(error.server + ': ' + error.message));
var routes = ( const routes = (
<Route name="app" path="/" handler={App}> <Route path="/" component={App}>
<Route name="connect" handler={Connect} /> <Route path="connect" component={Connect} />
<Route name="settings" handler={Settings} /> <Route path="settings" component={Settings} />
<Route name="status" path="/:server" handler={Chat} /> <Route path="/:server" component={Chat} />
<Route name="chat" path="/:server/:channel" handler={Chat} /> <Route path="/:server/:channel" component={Chat} />
<DefaultRoute handler={Settings} /> <IndexRoute component={Settings} />
</Route> </Route>
); );
const history = createBrowserHistory();
Router.run(routes, Router.HistoryLocation, (Handler) => { render(<Router routes={routes} history={history} />, document.getElementById('root'));
React.render(<Handler />, document.body);
});

View File

@ -1,18 +1,14 @@
var React = require('react'); import React from 'react';
var Reflux = require('reflux'); import Reflux from 'reflux';
var Router = require('react-router'); import { Router } from 'react-router';
var RouteHandler = Router.RouteHandler; import TabList from './TabList.jsx';
var Navigation = Router.Navigation; import routeActions from '../actions/route';
import tabActions from '../actions/tab';
import PureMixin from '../mixins/pure';
var TabList = require('./TabList.jsx'); export default React.createClass({
var routeActions = require('../actions/route');
var tabActions = require('../actions/tab');
var PureMixin = require('../mixins/pure');
var App = React.createClass({
mixins: [ mixins: [
PureMixin, PureMixin,
Navigation,
Reflux.listenTo(routeActions.navigate, 'navigate'), Reflux.listenTo(routeActions.navigate, 'navigate'),
Reflux.listenTo(tabActions.hideMenu, 'hideMenu'), Reflux.listenTo(tabActions.hideMenu, 'hideMenu'),
Reflux.listenTo(tabActions.toggleMenu, 'toggleMenu') Reflux.listenTo(tabActions.toggleMenu, 'toggleMenu')
@ -25,10 +21,11 @@ var App = React.createClass({
}, },
navigate(path, replace) { navigate(path, replace) {
const { history } = this.props;
if (!replace) { if (!replace) {
this.transitionTo(path); history.pushState(null, path);
} else { } else {
this.replaceWith(path); history.replaceState(null, path);
} }
}, },
@ -41,17 +38,15 @@ var App = React.createClass({
}, },
render() { render() {
var mainClass = this.state.menuToggled ? 'main-container off-canvas' : 'main-container'; const mainClass = this.state.menuToggled ? 'main-container off-canvas' : 'main-container';
return ( return (
<div> <div>
<TabList menuToggled={this.state.menuToggled} /> <TabList menuToggled={this.state.menuToggled} />
<div className={mainClass}> <div className={mainClass}>
<RouteHandler /> {this.props.children}
</div> </div>
</div> </div>
); );
} }
}); });
module.exports = App;

View File

@ -1,17 +1,16 @@
var React = require('react'); import React from 'react';
var Reflux = require('reflux'); import Reflux from 'reflux';
var Router = require('react-router'); import Router from 'react-router';
import ChatTitle from './ChatTitle.jsx';
import Search from './Search.jsx';
import MessageBox from './MessageBox.jsx';
import MessageInput from './MessageInput.jsx';
import UserList from './UserList.jsx';
import selectedTabStore from '../stores/selectedTab';
import tabActions from '../actions/tab';
import PureMixin from '../mixins/pure';
var ChatTitle = require('./ChatTitle.jsx'); export default React.createClass({
var Search = require('./Search.jsx');
var MessageBox = require('./MessageBox.jsx');
var MessageInput = require('./MessageInput.jsx');
var UserList = require('./UserList.jsx');
var selectedTabStore = require('../stores/selectedTab');
var tabActions = require('../actions/tab');
var PureMixin = require('../mixins/pure');
var Chat = React.createClass({
mixins: [ mixins: [
PureMixin, PureMixin,
Router.State, Router.State,
@ -20,19 +19,18 @@ var Chat = React.createClass({
componentWillMount() { componentWillMount() {
if (!window.loaded) { if (!window.loaded) {
var p = this.getParams(); const { params } = this.props;
if (params.channel) {
if (p.channel) { tabActions.select(params.server, '#' + params.channel);
tabActions.select(p.server, '#' + p.channel); } else if (params.server) {
} else if (p.server) { tabActions.select(params.server);
tabActions.select(p.server);
} }
} }
}, },
render() { render() {
var chatClass; let chatClass;
var tab = this.state.selectedTab; const tab = this.state.selectedTab;
if (!tab.channel) { if (!tab.channel) {
chatClass = 'chat-server'; chatClass = 'chat-server';
@ -53,5 +51,3 @@ var Chat = React.createClass({
); );
} }
}); });
module.exports = Chat;

View File

@ -1,15 +1,14 @@
var React = require('react'); import React from 'react';
var Reflux = require('reflux'); import Reflux from 'reflux';
var Infinite = require('react-infinite'); import Infinite from 'react-infinite';
import MessageHeader from './MessageHeader.jsx';
import MessageLine from './MessageLine.jsx';
import messageLineStore from '../stores/messageLine';
import selectedTabStore from '../stores/selectedTab';
import messageActions from '../actions/message';
import PureMixin from '../mixins/pure';
var MessageHeader = require('./MessageHeader.jsx'); export default React.createClass({
var MessageLine = require('./MessageLine.jsx');
var messageLineStore = require('../stores/messageLine');
var selectedTabStore = require('../stores/selectedTab');
var messageActions = require('../actions/message');
var PureMixin = require('../mixins/pure');
var MessageBox = React.createClass({
mixins: [ mixins: [
PureMixin, PureMixin,
Reflux.connect(messageLineStore, 'messages'), Reflux.connect(messageLineStore, 'messages'),
@ -23,6 +22,7 @@ var MessageBox = React.createClass({
}, },
componentDidMount() { componentDidMount() {
this.updateWidth();
window.addEventListener('resize', this.handleResize); window.addEventListener('resize', this.handleResize);
}, },
@ -31,15 +31,15 @@ var MessageBox = React.createClass({
}, },
componentWillUpdate() { componentWillUpdate() {
var el = this.refs.list.getDOMNode(); var el = this.refs.list.refs.scrollable;
this.autoScroll = el.scrollTop + el.offsetHeight === el.scrollHeight; this.autoScroll = el.scrollTop + el.offsetHeight === el.scrollHeight;
}, },
componentDidUpdate() { componentDidUpdate() {
this.updateWidth(); setTimeout(this.updateWidth, 0);
if (this.autoScroll) { if (this.autoScroll) {
var el = this.refs.list.getDOMNode(); var el = this.refs.list.refs.scrollable;
el.scrollTop = el.scrollHeight; el.scrollTop = el.scrollHeight;
} }
}, },
@ -50,47 +50,44 @@ var MessageBox = React.createClass({
}, },
updateWidth() { updateWidth() {
var width = this.refs.list.getDOMNode().firstChild.offsetWidth; const { list } = this.refs;
if (list) {
const width = list.refs.scrollable.offsetWidth - 30;
if (this.width !== width) { if (this.width !== width) {
this.width = width; this.width = width;
messageActions.setWrapWidth(width); messageActions.setWrapWidth(width);
} }
}
}, },
render() { render() {
var tab = this.state.selectedTab; const tab = this.state.selectedTab;
var dest = tab.channel || tab.server; const dest = tab.channel || tab.server;
var lines = []; const lines = [];
this.state.messages.forEach((message, j) => { this.state.messages.forEach((message, j) => {
var key = message.server + dest + j; const key = message.server + dest + j;
lines.push(<MessageHeader key={key} message={message} />); lines.push(<MessageHeader key={key} message={message} />);
for (var i = 1; i < message.lines.length; i++) { for (let i = 1; i < message.lines.length; i++) {
lines.push( lines.push(
<MessageLine key={key + '-' + i} type={message.type} line={message.lines[i]} /> <MessageLine key={key + '-' + i} type={message.type} line={message.lines[i]} />
); );
} }
}); });
if (lines.length !== 1) {
return ( return (
<div className="messagebox"> <div className="messagebox">
<Infinite ref="list" containerHeight={this.state.height} elementHeight={24}> <Infinite
ref="list"
className="messagebox-scrollable"
containerHeight={this.state.height}
elementHeight={24}
displayBottomUpwards={false}>
{lines} {lines}
</Infinite> </Infinite>
</div> </div>
); );
} else {
return (
<div className="messagebox">
<div ref="list">{lines}</div>
</div>
);
}
} }
}); });
module.exports = MessageBox;

View File

@ -132,7 +132,7 @@ func TestRecv(t *testing.T) {
initTestClient() initTestClient()
} }
func TestRecvTriggersReconnect(t *testing.T) { /*func TestRecvTriggersReconnect(t *testing.T) {
c.reader = bufio.NewReader(&bytes.Buffer{}) c.reader = bufio.NewReader(&bytes.Buffer{})
c.ready.Add(1) c.ready.Add(1)
done := make(chan struct{}) done := make(chan struct{})
@ -151,7 +151,7 @@ func TestRecvTriggersReconnect(t *testing.T) {
case <-time.After(100 * time.Millisecond): case <-time.After(100 * time.Millisecond):
t.Error("Reconnect not triggered") t.Error("Reconnect not triggered")
} }
} }*/
func TestClose(t *testing.T) { func TestClose(t *testing.T) {
defer initTestClient() defer initTestClient()