diff --git a/.eslintrc.js b/.eslintrc.js
index ec48f6b2ff..fae41ec159 100644
--- a/.eslintrc.js
+++ b/.eslintrc.js
@@ -97,7 +97,6 @@ module.exports = {
"new-cap": ["warn"],
"key-spacing": ["warn"],
"prefer-const": ["warn"],
- "arrow-parens": "off",
// crashes currently: https://github.com/eslint/eslint/issues/6274
"generator-star-spacing": "off",
diff --git a/res/css/views/elements/_Field.scss b/res/css/views/elements/_Field.scss
index 06002939f5..6f215412db 100644
--- a/res/css/views/elements/_Field.scss
+++ b/res/css/views/elements/_Field.scss
@@ -100,7 +100,8 @@ limitations under the License.
top 0.25s ease-out 0s,
background-color 0.25s ease-out 0s;
font-size: 10px;
- top: -14px;
+ top: -13px;
+ padding: 0 2px;
background-color: $field-focused-label-bg-color;
}
diff --git a/src/components/structures/LeftPanel.js b/src/components/structures/LeftPanel.js
index 489e9bd243..cb374a02a3 100644
--- a/src/components/structures/LeftPanel.js
+++ b/src/components/structures/LeftPanel.js
@@ -199,9 +199,10 @@ const LeftPanel = React.createClass({
},
);
- const searchBox = !this.props.collapsed ?
- :
- undefined;
+ const searchBox = ();
return (
diff --git a/src/components/structures/MatrixChat.js b/src/components/structures/MatrixChat.js
index 5682f96634..bb90b2aeb5 100644
--- a/src/components/structures/MatrixChat.js
+++ b/src/components/structures/MatrixChat.js
@@ -1647,11 +1647,6 @@ export default React.createClass({
this.showScreen("forgot_password");
},
- onReturnToAppClick: function() {
- // treat it the same as if the user had completed the login
- this._onLoggedIn();
- },
-
// returns a promise which resolves to the new MatrixClient
onRegistered: function(credentials) {
// XXX: This should be in state or ideally store(s) because we risk not
@@ -1862,7 +1857,6 @@ export default React.createClass({
sessionId={this.state.register_session_id}
idSid={this.state.register_id_sid}
email={this.props.startingFragmentQueryParams.email}
- referrer={this.props.startingFragmentQueryParams.referrer}
defaultServerDiscoveryError={this.state.defaultServerDiscoveryError}
defaultHsUrl={this.getDefaultHsUrl()}
defaultIsUrl={this.getDefaultIsUrl()}
@@ -1870,11 +1864,8 @@ export default React.createClass({
customHsUrl={this.getCurrentHsUrl()}
customIsUrl={this.getCurrentIsUrl()}
makeRegistrationUrl={this._makeRegistrationUrl}
- defaultDeviceDisplayName={this.props.defaultDeviceDisplayName}
onLoggedIn={this.onRegistered}
onLoginClick={this.onLoginClick}
- onRegisterClick={this.onRegisterClick}
- onCancelClick={MatrixClientPeg.get() ? this.onReturnToAppClick : null}
onServerConfigChange={this.onServerConfigChange}
/>
);
@@ -1911,7 +1902,6 @@ export default React.createClass({
defaultDeviceDisplayName={this.props.defaultDeviceDisplayName}
onForgotPasswordClick={this.onForgotPasswordClick}
enableGuest={this.props.enableGuest}
- onCancelClick={MatrixClientPeg.get() ? this.onReturnToAppClick : null}
onServerConfigChange={this.onServerConfigChange}
/>
);
diff --git a/src/components/structures/MessagePanel.js b/src/components/structures/MessagePanel.js
index fc3b421e89..dd3d92913c 100644
--- a/src/components/structures/MessagePanel.js
+++ b/src/components/structures/MessagePanel.js
@@ -642,14 +642,13 @@ module.exports = React.createClass({
updateTimelineMinHeight: function() {
const scrollPanel = this.refs.scrollPanel;
- const whoIsTyping = this.refs.whoIsTyping;
- const isTypingVisible = whoIsTyping && whoIsTyping.isVisible();
if (scrollPanel) {
- if (isTypingVisible) {
+ const isAtBottom = scrollPanel.isAtBottom();
+ const whoIsTyping = this.refs.whoIsTyping;
+ const isTypingVisible = whoIsTyping && whoIsTyping.isVisible();
+ if (isAtBottom && isTypingVisible) {
scrollPanel.blockShrinking();
- } else {
- scrollPanel.clearBlockShrinking();
}
}
},
diff --git a/src/components/structures/ScrollPanel.js b/src/components/structures/ScrollPanel.js
index be5f23c420..1df5e876e8 100644
--- a/src/components/structures/ScrollPanel.js
+++ b/src/components/structures/ScrollPanel.js
@@ -169,6 +169,10 @@ module.exports = React.createClass({
//
// This will also re-check the fill state, in case the paginate was inadequate
this.checkScroll();
+
+ if (!this.isAtBottom()) {
+ this.clearBlockShrinking();
+ }
},
componentWillUnmount: function() {
diff --git a/src/components/structures/SearchBox.js b/src/components/structures/SearchBox.js
index ea1fa312c1..fbcd9a7279 100644
--- a/src/components/structures/SearchBox.js
+++ b/src/components/structures/SearchBox.js
@@ -71,7 +71,7 @@ module.exports = React.createClass({
function() {
this.props.onSearch(this.refs.search.value);
},
- 100,
+ 500,
),
_onKeyDown: function(ev) {
@@ -95,8 +95,13 @@ module.exports = React.createClass({
},
render: function() {
- const TintableSvg = sdk.getComponent('elements.TintableSvg');
-
+ // check for collapsed here and
+ // not at parent so we keep
+ // searchTerm in our state
+ // when collapsing and expanding
+ if (this.props.collapsed) {
+ return null;
+ }
const clearButton = this.state.searchTerm.length > 0 ?
(
-
- ;
+ // TODO: ...
+ return null;
}
- let serverDetails = null;
- switch (this.state.serverType) {
- case ServerType.FREE:
- break;
- case ServerType.PREMIUM:
- serverDetails =