mirror of
https://github.com/element-hq/element-web
synced 2024-11-28 12:28:50 +03:00
store/load lhs & rhs sizes to/from localStorage
This commit is contained in:
parent
3a26f0fa12
commit
110e4526b8
1 changed files with 47 additions and 17 deletions
|
@ -93,23 +93,9 @@ const LoggedInView = React.createClass({
|
||||||
},
|
},
|
||||||
|
|
||||||
componentDidMount: function() {
|
componentDidMount: function() {
|
||||||
const classNames = {
|
this.resizer = this._createResizer();
|
||||||
handle: "mx_ResizeHandle",
|
this.resizer.attach();
|
||||||
vertical: "mx_ResizeHandle_vertical",
|
this._loadResizerPreferences();
|
||||||
reverse: "mx_ResizeHandle_reverse"
|
|
||||||
};
|
|
||||||
const collapseConfig = {
|
|
||||||
toggleSize: 260 - 50,
|
|
||||||
onCollapsed: (collapsed) => {
|
|
||||||
this.setState({collapseLhs: collapsed});
|
|
||||||
}
|
|
||||||
};
|
|
||||||
const resizer = new Resizer(
|
|
||||||
this.resizeContainer,
|
|
||||||
CollapseDistributor,
|
|
||||||
collapseConfig);
|
|
||||||
resizer.setClassNames(classNames);
|
|
||||||
resizer.attach();
|
|
||||||
},
|
},
|
||||||
|
|
||||||
componentWillMount: function() {
|
componentWillMount: function() {
|
||||||
|
@ -141,6 +127,7 @@ const LoggedInView = React.createClass({
|
||||||
if (this._sessionStoreToken) {
|
if (this._sessionStoreToken) {
|
||||||
this._sessionStoreToken.remove();
|
this._sessionStoreToken.remove();
|
||||||
}
|
}
|
||||||
|
this.resizer.detach();
|
||||||
},
|
},
|
||||||
|
|
||||||
// Child components assume that the client peg will not be null, so give them some
|
// Child components assume that the client peg will not be null, so give them some
|
||||||
|
@ -166,6 +153,49 @@ const LoggedInView = React.createClass({
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_createResizer() {
|
||||||
|
const classNames = {
|
||||||
|
handle: "mx_ResizeHandle",
|
||||||
|
vertical: "mx_ResizeHandle_vertical",
|
||||||
|
reverse: "mx_ResizeHandle_reverse"
|
||||||
|
};
|
||||||
|
const collapseConfig = {
|
||||||
|
toggleSize: 260 - 50,
|
||||||
|
onCollapsed: (collapsed, item) => {
|
||||||
|
if (item.classList.contains("mx_LeftPanel_container")) {
|
||||||
|
this.setState({collapseLhs: collapsed});
|
||||||
|
if (collapsed) {
|
||||||
|
window.localStorage.setItem("mx_lhs_size", '0');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
onResized: (size, item) => {
|
||||||
|
if (item.classList.contains("mx_LeftPanel_container")) {
|
||||||
|
window.localStorage.setItem("mx_lhs_size", '' + size);
|
||||||
|
} else if(item.classList.contains("mx_RightPanel")) {
|
||||||
|
window.localStorage.setItem("mx_rhs_size", '' + size);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
};
|
||||||
|
const resizer = new Resizer(
|
||||||
|
this.resizeContainer,
|
||||||
|
CollapseDistributor,
|
||||||
|
collapseConfig);
|
||||||
|
resizer.setClassNames(classNames);
|
||||||
|
return resizer;
|
||||||
|
},
|
||||||
|
|
||||||
|
_loadResizerPreferences() {
|
||||||
|
const lhsSize = window.localStorage.getItem("mx_lhs_size");
|
||||||
|
if (lhsSize !== null) {
|
||||||
|
this.resizer.forHandleAt(0).resize(parseInt(lhsSize, 10));
|
||||||
|
}
|
||||||
|
const rhsSize = window.localStorage.getItem("mx_rhs_size");
|
||||||
|
if (rhsSize !== null) {
|
||||||
|
this.resizer.forHandleAt(1).resize(parseInt(rhsSize, 10));
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
onAccountData: function(event) {
|
onAccountData: function(event) {
|
||||||
if (event.getType() === "im.vector.web.settings") {
|
if (event.getType() === "im.vector.web.settings") {
|
||||||
this.setState({
|
this.setState({
|
||||||
|
|
Loading…
Reference in a new issue