mirror of
https://github.com/revoltchat/revite.git
synced 2025-01-12 15:31:26 -05:00
Context Menus: Add "mark as unread" back.
Servers: Fix various issues relating to voice channels.
This commit is contained in:
parent
eef3e11e62
commit
352c0e880c
7 changed files with 40 additions and 23 deletions
|
@ -53,6 +53,7 @@
|
||||||
"detect-browser": "^5.2.0",
|
"detect-browser": "^5.2.0",
|
||||||
"eslint": "^7.28.0",
|
"eslint": "^7.28.0",
|
||||||
"eslint-config-preact": "^1.1.4",
|
"eslint-config-preact": "^1.1.4",
|
||||||
|
"eventemitter3": "^4.0.7",
|
||||||
"highlight.js": "^11.0.1",
|
"highlight.js": "^11.0.1",
|
||||||
"idb": "^6.1.2",
|
"idb": "^6.1.2",
|
||||||
"localforage": "^1.9.0",
|
"localforage": "^1.9.0",
|
||||||
|
@ -76,7 +77,7 @@
|
||||||
"react-scroll": "^1.8.2",
|
"react-scroll": "^1.8.2",
|
||||||
"react-tippy": "^1.4.0",
|
"react-tippy": "^1.4.0",
|
||||||
"redux": "^4.1.0",
|
"redux": "^4.1.0",
|
||||||
"revolt.js": "4.3.2",
|
"revolt.js": "4.3.2-patch.1",
|
||||||
"rimraf": "^3.0.2",
|
"rimraf": "^3.0.2",
|
||||||
"sass": "^1.35.1",
|
"sass": "^1.35.1",
|
||||||
"shade-blend-color": "^1.0.0",
|
"shade-blend-color": "^1.0.0",
|
||||||
|
|
|
@ -82,7 +82,7 @@ export function UserButton({ active, alert, alertCount, user, context, channel }
|
||||||
}
|
}
|
||||||
|
|
||||||
type ChannelProps = CommonProps & {
|
type ChannelProps = CommonProps & {
|
||||||
channel: Channels.Channel,
|
channel: Channels.Channel & { unread?: string },
|
||||||
user?: Users.User
|
user?: Users.User
|
||||||
compact?: boolean
|
compact?: boolean
|
||||||
}
|
}
|
||||||
|
@ -101,7 +101,7 @@ export function ChannelButton({ active, alert, alertCount, channel, user, compac
|
||||||
data-active={active}
|
data-active={active}
|
||||||
data-alert={typeof alert === 'string'}
|
data-alert={typeof alert === 'string'}
|
||||||
className={classNames(styles.item, { [styles.compact]: compact })}
|
className={classNames(styles.item, { [styles.compact]: compact })}
|
||||||
onContextMenu={attachContextMenu('Menu', { channel: channel._id })}>
|
onContextMenu={attachContextMenu('Menu', { channel: channel._id, unread: typeof channel.unread !== 'undefined' })}>
|
||||||
<div className={styles.avatar}>
|
<div className={styles.avatar}>
|
||||||
<ChannelIcon target={channel} size={compact ? 24 : 32} />
|
<ChannelIcon target={channel} size={compact ? 24 : 32} />
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -47,7 +47,7 @@ function ServerSidebar(props: Props & WithDispatcher) {
|
||||||
if (!server) return <Redirect to="/" />;
|
if (!server) return <Redirect to="/" />;
|
||||||
|
|
||||||
const channels = (useChannels(server.channels, ctx)
|
const channels = (useChannels(server.channels, ctx)
|
||||||
.filter(entry => typeof entry !== 'undefined') as Readonly<Channels.TextChannel>[])
|
.filter(entry => typeof entry !== 'undefined') as Readonly<Channels.TextChannel | Channels.VoiceChannel>[])
|
||||||
.map(x => mapChannelWithUnread(x, props.unreads));
|
.map(x => mapChannelWithUnread(x, props.unreads));
|
||||||
|
|
||||||
const channel = channels.find(x => x?._id === channel_id);
|
const channel = channels.find(x => x?._id === channel_id);
|
||||||
|
|
|
@ -104,6 +104,16 @@ export function registerEvents({
|
||||||
client.addListener(listener, (listenerFunc as any)[listener]);
|
client.addListener(listener, (listenerFunc as any)[listener]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function logMutation(target: string, key: string) {
|
||||||
|
console.log('(o) Object mutated', target, '\nChanged:', key);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (import.meta.env.DEV) {
|
||||||
|
client.users.addListener('mutation', logMutation);
|
||||||
|
client.servers.addListener('mutation', logMutation);
|
||||||
|
client.channels.addListener('mutation', logMutation);
|
||||||
|
}
|
||||||
|
|
||||||
const online = () => {
|
const online = () => {
|
||||||
if (operations.ready()) {
|
if (operations.ready()) {
|
||||||
setStatus(ClientStatus.RECONNECTING);
|
setStatus(ClientStatus.RECONNECTING);
|
||||||
|
@ -128,6 +138,12 @@ export function registerEvents({
|
||||||
client.removeListener(listener, (listenerFunc as any)[listener]);
|
client.removeListener(listener, (listenerFunc as any)[listener]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (import.meta.env.DEV) {
|
||||||
|
client.users.removeListener('mutation', logMutation);
|
||||||
|
client.servers.removeListener('mutation', logMutation);
|
||||||
|
client.channels.removeListener('mutation', logMutation);
|
||||||
|
}
|
||||||
|
|
||||||
window.removeEventListener("online", online);
|
window.removeEventListener("online", online);
|
||||||
window.removeEventListener("offline", offline);
|
window.removeEventListener("offline", offline);
|
||||||
};
|
};
|
||||||
|
|
|
@ -11,7 +11,7 @@ export interface HookContext {
|
||||||
export function useForceUpdate(context?: HookContext): HookContext {
|
export function useForceUpdate(context?: HookContext): HookContext {
|
||||||
const client = useContext(AppContext);
|
const client = useContext(AppContext);
|
||||||
if (context) return context;
|
if (context) return context;
|
||||||
const H = useState(undefined);
|
/*const H = useState(undefined);
|
||||||
var updateState: (_: undefined) => void;
|
var updateState: (_: undefined) => void;
|
||||||
if (Array.isArray(H)) {
|
if (Array.isArray(H)) {
|
||||||
let [, u] = H;
|
let [, u] = H;
|
||||||
|
@ -20,14 +20,16 @@ export function useForceUpdate(context?: HookContext): HookContext {
|
||||||
console.warn('Failed to construct using useState.');
|
console.warn('Failed to construct using useState.');
|
||||||
console.warn(H);
|
console.warn(H);
|
||||||
updateState = ()=>{};
|
updateState = ()=>{};
|
||||||
}
|
}*/
|
||||||
return { client, forceUpdate: useCallback(() => updateState(undefined), []) };
|
|
||||||
|
const [, updateState] = useState(0);
|
||||||
|
return { client, forceUpdate: () => updateState(Math.random()) };
|
||||||
}
|
}
|
||||||
|
|
||||||
function useObject(type: string, id?: string | string[], context?: HookContext) {
|
function useObject(type: string, id?: string | string[], context?: HookContext) {
|
||||||
const ctx = useForceUpdate(context);
|
const ctx = useForceUpdate(context);
|
||||||
|
|
||||||
function mutation(target: string) {
|
function update(target: any) {
|
||||||
if (typeof id === 'string' ? target === id :
|
if (typeof id === 'string' ? target === id :
|
||||||
Array.isArray(id) ? id.includes(target) : true) {
|
Array.isArray(id) ? id.includes(target) : true) {
|
||||||
ctx.forceUpdate();
|
ctx.forceUpdate();
|
||||||
|
@ -36,8 +38,8 @@ function useObject(type: string, id?: string | string[], context?: HookContext)
|
||||||
|
|
||||||
const map = (ctx.client as any)[type];
|
const map = (ctx.client as any)[type];
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
map.addListener("update", mutation);
|
map.addListener("update", update);
|
||||||
return () => map.removeListener("update", mutation);
|
return () => map.removeListener("update", update);
|
||||||
}, [id]);
|
}, [id]);
|
||||||
|
|
||||||
return typeof id === 'string' ? map.get(id)
|
return typeof id === 'string' ? map.get(id)
|
||||||
|
|
|
@ -62,9 +62,9 @@ type Action =
|
||||||
| { action: "set_status" }
|
| { action: "set_status" }
|
||||||
| { action: "clear_status" }
|
| { action: "clear_status" }
|
||||||
| { action: "create_channel"; target: Servers.Server }
|
| { action: "create_channel"; target: Servers.Server }
|
||||||
| { action: "create_invite"; target: Channels.GroupChannel | Channels.TextChannel }
|
| { action: "create_invite"; target: Channels.GroupChannel | Channels.TextChannel | Channels.VoiceChannel }
|
||||||
| { action: "leave_group"; target: Channels.GroupChannel }
|
| { action: "leave_group"; target: Channels.GroupChannel }
|
||||||
| { action: "delete_channel"; target: Channels.TextChannel }
|
| { action: "delete_channel"; target: Channels.TextChannel | Channels.VoiceChannel }
|
||||||
| { action: "close_dm"; target: Channels.DirectMessageChannel }
|
| { action: "close_dm"; target: Channels.DirectMessageChannel }
|
||||||
| { action: "leave_server"; target: Servers.Server }
|
| { action: "leave_server"; target: Servers.Server }
|
||||||
| { action: "delete_server"; target: Servers.Server }
|
| { action: "delete_server"; target: Servers.Server }
|
||||||
|
@ -374,20 +374,17 @@ function ContextMenus(props: WithDispatcher) {
|
||||||
const targetChannel = channel ?? contextualChannel;
|
const targetChannel = channel ?? contextualChannel;
|
||||||
|
|
||||||
const user = useUser(uid, forceUpdate);
|
const user = useUser(uid, forceUpdate);
|
||||||
const server = useServer(targetChannel?.channel_type === 'TextChannel' ? targetChannel.server : sid, forceUpdate);
|
const serverChannel = targetChannel && (targetChannel.channel_type === 'TextChannel' || targetChannel.channel_type === 'VoiceChannel') ? targetChannel : undefined;
|
||||||
|
const server = useServer(serverChannel ? serverChannel.server : sid, forceUpdate);
|
||||||
|
|
||||||
const channelPermissions = targetChannel ? useChannelPermission(targetChannel._id, forceUpdate) : 0;
|
const channelPermissions = targetChannel ? useChannelPermission(targetChannel._id, forceUpdate) : 0;
|
||||||
const serverPermissions = server ? useServerPermission(server._id, forceUpdate) : (
|
const serverPermissions = server ? useServerPermission(server._id, forceUpdate) : (
|
||||||
targetChannel?.channel_type === 'TextChannel' ? useServerPermission(targetChannel.server, forceUpdate) : 0
|
serverChannel ? useServerPermission(serverChannel.server, forceUpdate) : 0
|
||||||
);
|
);
|
||||||
const userPermissions = user ? useUserPermission(user._id, forceUpdate) : 0;
|
const userPermissions = user ? useUserPermission(user._id, forceUpdate) : 0;
|
||||||
|
|
||||||
if (channel && unread) {
|
if (channel && unread) {
|
||||||
generateAction(
|
generateAction({ action: "mark_as_read", channel });
|
||||||
{ action: "mark_as_read", channel },
|
|
||||||
undefined,
|
|
||||||
true
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (contextualChannel) {
|
if (contextualChannel) {
|
||||||
|
@ -580,6 +577,7 @@ function ContextMenus(props: WithDispatcher) {
|
||||||
generateAction({ action: "close_dm", target: channel });
|
generateAction({ action: "close_dm", target: channel });
|
||||||
break;
|
break;
|
||||||
case 'TextChannel':
|
case 'TextChannel':
|
||||||
|
case 'VoiceChannel':
|
||||||
// ! FIXME: add permission for invites
|
// ! FIXME: add permission for invites
|
||||||
generateAction({ action: "create_invite", target: channel });
|
generateAction({ action: "create_invite", target: channel });
|
||||||
|
|
||||||
|
|
|
@ -3412,10 +3412,10 @@ reusify@^1.0.4:
|
||||||
resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76"
|
resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76"
|
||||||
integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==
|
integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==
|
||||||
|
|
||||||
revolt.js@4.3.2:
|
revolt.js@4.3.2-patch.1:
|
||||||
version "4.3.2"
|
version "4.3.2-patch.1"
|
||||||
resolved "https://registry.yarnpkg.com/revolt.js/-/revolt.js-4.3.2.tgz#2e613ff1d918d77266e9c777e226bfbddd5a9b87"
|
resolved "https://registry.yarnpkg.com/revolt.js/-/revolt.js-4.3.2-patch.1.tgz#0c4190f0a640951636c6f2577c9298418b06917f"
|
||||||
integrity sha512-JyD3fRaory3Rhy/sAWcvHjLb/CluJRZap2Di2ZFFf9uiRJBgLNlClS/3RkBLAcQqx4KVx7Ua3WbKq1/dU6x7dQ==
|
integrity sha512-XAu2JeYc2+OFLM56WktGT/4tAyvjibmNL5oGc5pPZEjl0DnoIxPE96CZPe+35ZCX9bEiuoX378Fwfmfe3uN7sw==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@insertish/mutable" "1.1.0"
|
"@insertish/mutable" "1.1.0"
|
||||||
axios "^0.19.2"
|
axios "^0.19.2"
|
||||||
|
|
Loading…
Reference in a new issue