2018-08-03 18:03:27 +03:00
|
|
|
/*
|
|
|
|
Copyright 2018 New Vector Ltd
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
import React from 'react';
|
2018-08-07 19:04:37 +03:00
|
|
|
import PropTypes from 'prop-types';
|
|
|
|
import classNames from 'classnames';
|
2018-08-03 18:03:27 +03:00
|
|
|
import { _t } from '../../../languageHandler';
|
|
|
|
|
|
|
|
export default React.createClass({
|
2018-08-07 19:04:37 +03:00
|
|
|
propTypes: {
|
|
|
|
// 'hard' if the logged in user has been locked out, 'soft' if they haven't
|
|
|
|
kind: PropTypes.string,
|
2018-08-15 19:03:54 +03:00
|
|
|
adminContact: PropTypes.string,
|
|
|
|
// The type of limit that has been hit.
|
|
|
|
limitType: PropTypes.string.isRequired,
|
2018-08-07 19:04:37 +03:00
|
|
|
},
|
|
|
|
|
|
|
|
getDefaultProps: function() {
|
|
|
|
return {
|
|
|
|
kind: 'hard',
|
2018-08-13 16:04:08 +03:00
|
|
|
};
|
2018-08-07 19:04:37 +03:00
|
|
|
},
|
|
|
|
|
2018-08-03 18:03:27 +03:00
|
|
|
render: function() {
|
2018-08-07 19:04:37 +03:00
|
|
|
const toolbarClasses = {
|
|
|
|
'mx_MatrixToolbar': true,
|
|
|
|
};
|
|
|
|
|
|
|
|
const translateLink = (sub) => {
|
2018-08-15 19:03:54 +03:00
|
|
|
if (this.props.adminContact) {
|
|
|
|
return <a rel="noopener" target="_blank" href={this.props.adminContact}>{sub}</a>;
|
2018-08-07 19:04:37 +03:00
|
|
|
} else {
|
|
|
|
return sub;
|
|
|
|
}
|
2018-08-13 16:04:08 +03:00
|
|
|
};
|
2018-08-07 19:04:37 +03:00
|
|
|
|
2018-08-15 19:03:54 +03:00
|
|
|
let adminContact;
|
|
|
|
let limitError;
|
2018-08-07 19:04:37 +03:00
|
|
|
if (this.props.kind === 'hard') {
|
|
|
|
toolbarClasses['mx_MatrixToolbar_error'] = true;
|
2018-08-15 19:03:54 +03:00
|
|
|
adminContact = _t(
|
2018-08-13 16:04:08 +03:00
|
|
|
"Please <a>contact your service administrator</a> to continue using the service.",
|
2018-08-07 19:04:37 +03:00
|
|
|
{},
|
|
|
|
{
|
|
|
|
'a': translateLink,
|
|
|
|
},
|
|
|
|
);
|
2018-08-15 19:03:54 +03:00
|
|
|
if (this.props.limitType === 'monthly_active_user') {
|
|
|
|
limitError = _t("This homeserver has hit its Monthly Active User limit.");
|
|
|
|
} else {
|
|
|
|
limitError = _t("This homeserver has exceeded one of its resource limits.");
|
|
|
|
}
|
2018-08-07 19:04:37 +03:00
|
|
|
} else {
|
|
|
|
toolbarClasses['mx_MatrixToolbar_info'] = true;
|
2018-08-15 19:03:54 +03:00
|
|
|
adminContact = _t(
|
2018-08-13 16:04:08 +03:00
|
|
|
"Please <a>contact your service administrator</a> to get this limit increased.",
|
2018-08-07 19:04:37 +03:00
|
|
|
{},
|
|
|
|
{
|
|
|
|
'a': translateLink,
|
|
|
|
},
|
|
|
|
);
|
2018-08-15 19:03:54 +03:00
|
|
|
if (this.props.limitType === 'monthly_active_user') {
|
|
|
|
limitError = _t(
|
|
|
|
"This homeserver has hit its Monthly Active User limit so " +
|
|
|
|
"<b>some users will not be able to log in</b>.", {},
|
|
|
|
{'b': sub => <b>{sub}</b>},
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
limitError = _t(
|
|
|
|
"This homeserver has exceeded one of its resource limits so " +
|
|
|
|
"<b>some users will not be able to log in</b>.", {},
|
|
|
|
{'b': sub => <b>{sub}</b>},
|
|
|
|
);
|
|
|
|
}
|
2018-08-07 19:04:37 +03:00
|
|
|
}
|
2018-08-03 18:03:27 +03:00
|
|
|
return (
|
2018-08-07 19:04:37 +03:00
|
|
|
<div className={classNames(toolbarClasses)}>
|
2018-08-03 18:03:27 +03:00
|
|
|
<div className="mx_MatrixToolbar_content">
|
2018-08-15 19:03:54 +03:00
|
|
|
{limitError}
|
|
|
|
{' '}
|
|
|
|
{adminContact}
|
2018-08-03 18:03:27 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
},
|
|
|
|
});
|