Fix button patching
This commit is contained in:
parent
b67ca5c42d
commit
83ef17d302
|
@ -53,27 +53,48 @@ export default new class E2EE extends BuiltinModule {
|
||||||
return haveKey.value.value;
|
return haveKey.value.value;
|
||||||
}
|
}
|
||||||
|
|
||||||
async enabled(e) {
|
async patchMessageContent() {
|
||||||
const ctaComponent = await ReactComponents.getComponent('ChannelTextArea');
|
const selector = '.' + WebpackModules.getClassName('container', 'containerCozy', 'containerCompact', 'edited');
|
||||||
MonkeyPatch('BD:E2EE', ctaComponent.component.prototype).after('render', this.render);
|
const MessageContent = await ReactComponents.getComponent('MessageContent', { selector });
|
||||||
MonkeyPatch('BD:E2EE', ctaComponent.component.prototype).before('handleSubmit', this.handleSubmit.bind(this));
|
MonkeyPatch('BD:E2EE', MessageContent.component.prototype).after('render', this.renderMessageContent.bind(this));
|
||||||
}
|
}
|
||||||
|
|
||||||
render(component, args, retVal) {
|
async enabled(e) {
|
||||||
|
this.patchMessageContent();
|
||||||
|
const selector = '.' + WebpackModules.getClassName('channelTextArea', 'emojiButton');
|
||||||
|
const ChannelTextArea = await ReactComponents.getComponent('ChannelTextArea', { selector });
|
||||||
|
MonkeyPatch('BD:E2EE', ChannelTextArea.component.prototype).after('render', this.renderCta);
|
||||||
|
MonkeyPatch('BD:E2EE', ChannelTextArea.component.prototype).before('handleSubmit', this.handleSubmitCta.bind(this));
|
||||||
|
ChannelTextArea.forceUpdateAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
renderMessageContent(component, args, retVal) {
|
||||||
|
const key = this.getKey(DiscordApi.currentChannel.id);
|
||||||
|
if (!key) return;
|
||||||
|
const markup = retVal.props.children[1].props;
|
||||||
|
if (!markup || !markup.children || markup.children.length < 2) return;
|
||||||
|
if (typeof markup.children[1][0] !== 'string') return;
|
||||||
|
const textContent = markup.children[1][0];
|
||||||
|
if (!textContent.startsWith('$:')) return;
|
||||||
|
markup.children[1][0] = this.decrypt(this.decrypt(this.decrypt(seed, this.master), key), textContent);
|
||||||
|
}
|
||||||
|
|
||||||
|
renderCta(component, args, retVal) {
|
||||||
if (!(retVal.props.children instanceof Array)) retVal.props.children = [retVal.props.children];
|
if (!(retVal.props.children instanceof Array)) retVal.props.children = [retVal.props.children];
|
||||||
const inner = retVal.props.children.find(child => child.props.className && child.props.className.includes('inner'));
|
const inner = retVal.props.children.find(child => child.props.className && child.props.className.includes('inner'));
|
||||||
|
inner.props.children.splice(0, 0, VueInjector.createReactElement(E2EEComponent, {}, false));
|
||||||
inner.props.children.splice(0, 0, VueInjector.createReactElement(E2EEComponent, {}, true));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
handleSubmit(component, args, retVal) {
|
handleSubmitCta(component, args, retVal) {
|
||||||
const key = this.getKey(DiscordApi.currentChannel.id);
|
const key = this.getKey(DiscordApi.currentChannel.id);
|
||||||
if (!key) return;
|
if (!key) return;
|
||||||
component.props.value = this.encrypt(this.decrypt(this.decrypt(seed, this.master), key), component.props.value);
|
component.props.value = this.encrypt(this.decrypt(this.decrypt(seed, this.master), key), component.props.value);
|
||||||
}
|
}
|
||||||
|
|
||||||
disabled(e) {
|
async disabled(e) {
|
||||||
for (const patch of Patcher.getPatchesByCaller('BD:E2EE')) patch.unpatch();
|
for (const patch of Patcher.getPatchesByCaller('BD:E2EE')) patch.unpatch();
|
||||||
|
const ctaComponent = await ReactComponents.getComponent('ChannelTextArea');
|
||||||
|
ctaComponent.forceUpdateAll();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,11 +31,37 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.bd-taDivider {
|
.bd-taDivider {
|
||||||
background-color: hsla(0,0%,100%,.1);
|
background-color: rgba(255, 255, 255, 0.1);
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
height: 80%;
|
|
||||||
position: relative;
|
position: relative;
|
||||||
top: 10%;
|
top: 10%;
|
||||||
width: 1px;
|
width: 1px;
|
||||||
|
height: 37px;
|
||||||
|
margin-top: 5px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.bd-e2eeMdContainer {
|
||||||
|
position: relative;
|
||||||
|
display: inline-block;
|
||||||
|
top: 4px;
|
||||||
|
|
||||||
|
.bd-e2eeMdBtn {
|
||||||
|
cursor: pointer;
|
||||||
|
|
||||||
|
&.bd-e2eeLock {
|
||||||
|
&.bd-error {
|
||||||
|
fill: #cc3e3e;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.bd-ok {
|
||||||
|
fill: $colbdgreen;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.bd-warn {
|
||||||
|
fill: #ccab3e;
|
||||||
|
animation: bd-pulse 2s ease-in-out infinite;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue