OpenInApp: Support profile activity on web & profile connection
This commit is contained in:
parent
51adb26d01
commit
088a8bd1b6
1 changed files with 32 additions and 7 deletions
|
@ -19,20 +19,38 @@
|
||||||
import { Devs } from "@utils/constants";
|
import { Devs } from "@utils/constants";
|
||||||
import definePlugin from "@utils/types";
|
import definePlugin from "@utils/types";
|
||||||
|
|
||||||
const SpotifyMatcher = /https:\/\/open\.spotify\.com\/(track|album|artist|playlist)\/([^S]+)/;
|
const SpotifyMatcher = /https:\/\/open\.spotify\.com\/(track|album|artist|playlist|user)\/([^S]+)/;
|
||||||
|
|
||||||
export default definePlugin({
|
export default definePlugin({
|
||||||
name: "OpenInApp",
|
name: "OpenInApp",
|
||||||
description: "Open spotify URLs in app",
|
description: "Open spotify URLs in app",
|
||||||
authors: [Devs.Ven],
|
authors: [Devs.Ven],
|
||||||
|
|
||||||
patches: [{
|
patches: [
|
||||||
find: '"MaskedLinkStore"',
|
{
|
||||||
replacement: {
|
find: '"MaskedLinkStore"',
|
||||||
match: /return ((\i)\.apply\(this,arguments\))(?=\}function \i.{0,200}\.trusted)/,
|
replacement: {
|
||||||
replace: "return $self.handleLink(...arguments)||$1"
|
match: /return ((\i)\.apply\(this,arguments\))(?=\}function \i.{0,200}\.trusted)/,
|
||||||
|
replace: "return $self.handleLink(...arguments)||$1"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
// Make Spotify profile activity links open in app on web
|
||||||
|
{
|
||||||
|
find: "WEB_OPEN(",
|
||||||
|
predicate: () => !IS_DISCORD_DESKTOP,
|
||||||
|
replacement: {
|
||||||
|
match: /\i\.\i\.isProtocolRegistered\(\)(.{0,100})window.open/g,
|
||||||
|
replace: "true$1VencordNative.native.openExternal"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
find: ".CONNECTED_ACCOUNT_VIEWED,",
|
||||||
|
replacement: {
|
||||||
|
match: /(?<=href:\i,onClick:function\(\)\{)(?=return \i=(\i)\.type,.{0,50}CONNECTED_ACCOUNT_VIEWED)/,
|
||||||
|
replace: "$self.handleAccountView(arguments[0],$1.type,$1.id);"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}],
|
],
|
||||||
|
|
||||||
handleLink(data: { href: string; }, event: MouseEvent) {
|
handleLink(data: { href: string; }, event: MouseEvent) {
|
||||||
if (!data) return;
|
if (!data) return;
|
||||||
|
@ -45,5 +63,12 @@ export default definePlugin({
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
|
|
||||||
return Promise.resolve();
|
return Promise.resolve();
|
||||||
|
},
|
||||||
|
|
||||||
|
handleAccountView(event: MouseEvent, platformType: string, otherUserId: string) {
|
||||||
|
if (platformType !== "spotify") return;
|
||||||
|
|
||||||
|
VencordNative.native.openExternal(`spotify:user:${otherUserId}`);
|
||||||
|
event.preventDefault();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
Loading…
Add table
Reference in a new issue