mirror of https://github.com/vector-im/riot-web
first go at show redact only if we can redact
Signed-off-by: Michael Telatynski <7t3chguy@gmail.com>pull/3925/head
parent
fe61a7eefd
commit
aff1e14efc
|
@ -25,6 +25,11 @@ var Modal = require('matrix-react-sdk/lib/Modal');
|
||||||
var Resend = require("matrix-react-sdk/lib/Resend");
|
var Resend = require("matrix-react-sdk/lib/Resend");
|
||||||
import * as UserSettingsStore from 'matrix-react-sdk/lib/UserSettingsStore';
|
import * as UserSettingsStore from 'matrix-react-sdk/lib/UserSettingsStore';
|
||||||
|
|
||||||
|
function parseIntWithDefault(val, def) {
|
||||||
|
var res = parseInt(val);
|
||||||
|
return isNaN(res) ? def : res;
|
||||||
|
}
|
||||||
|
|
||||||
module.exports = React.createClass({
|
module.exports = React.createClass({
|
||||||
displayName: 'MessageContextMenu',
|
displayName: 'MessageContextMenu',
|
||||||
|
|
||||||
|
@ -126,7 +131,19 @@ module.exports = React.createClass({
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!eventStatus && !this.props.mxEvent.isRedacted()) { // sent and not redacted
|
const cli = MatrixClientPeg.get();
|
||||||
|
|
||||||
|
const room = cli.getRoom(this.props.mxEvent.getRoomId());
|
||||||
|
const powerLevelEvents = room.currentState.getStateEvents('m.room.power_levels', '');
|
||||||
|
const powerLevels = powerLevelEvents ? powerLevelEvents.getContent() : {};
|
||||||
|
const userLevels = powerLevels.users || {};
|
||||||
|
|
||||||
|
const userLevel = userLevels[cli.credentials.userId] || parseIntWithDefault(powerLevels.users_default, 0);
|
||||||
|
|
||||||
|
if (!eventStatus && !this.props.mxEvent.isRedacted() && (// sent and not redacted
|
||||||
|
this.props.mxEvent.getSender() === cli.credentials.userId // own event
|
||||||
|
|| userLevel >= parseIntWithDefault(powerLevels.redact, 50) // has PL to redact
|
||||||
|
)) {
|
||||||
redactButton = (
|
redactButton = (
|
||||||
<div className="mx_MessageContextMenu_field" onClick={this.onRedactClick}>
|
<div className="mx_MessageContextMenu_field" onClick={this.onRedactClick}>
|
||||||
Redact
|
Redact
|
||||||
|
|
Loading…
Reference in New Issue