2023-04-15 00:26:46 +00:00
|
|
|
/*
|
|
|
|
* Vencord, a modification for Discord's desktop app
|
|
|
|
* Copyright (c) 2023 Vendicated and contributors
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2023-04-16 23:06:54 +00:00
|
|
|
import { definePluginSettings, Settings, useSettings } from "@api/settings";
|
|
|
|
import { OptionType } from "@utils/types";
|
|
|
|
import { findStoreLazy } from "@webpack";
|
|
|
|
|
|
|
|
export const enum PinOrder {
|
|
|
|
LastMessage,
|
|
|
|
Custom
|
|
|
|
}
|
|
|
|
|
|
|
|
export const settings = definePluginSettings({
|
|
|
|
pinOrder: {
|
|
|
|
type: OptionType.SELECT,
|
|
|
|
description: "Which order should pinned DMs be displayed in?",
|
|
|
|
options: [
|
|
|
|
{ label: "Most recent message", value: PinOrder.LastMessage, default: true },
|
|
|
|
{ label: "Custom (right click channels to reorder)", value: PinOrder.Custom }
|
|
|
|
]
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
const PrivateChannelSortStore = findStoreLazy("PrivateChannelSortStore");
|
2023-04-15 00:26:46 +00:00
|
|
|
|
|
|
|
export let snapshotArray: string[];
|
|
|
|
let snapshot: Set<string> | undefined;
|
|
|
|
|
|
|
|
const getArray = () => (Settings.plugins.PinDMs.pinnedDMs || void 0)?.split(",") as string[] | undefined;
|
|
|
|
const save = (pins: string[]) => {
|
|
|
|
snapshot = void 0;
|
|
|
|
Settings.plugins.PinDMs.pinnedDMs = pins.join(",");
|
|
|
|
};
|
|
|
|
const takeSnapshot = () => {
|
|
|
|
snapshotArray = getArray() ?? [];
|
|
|
|
return snapshot = new Set<string>(snapshotArray);
|
|
|
|
};
|
|
|
|
const requireSnapshot = () => snapshot ?? takeSnapshot();
|
|
|
|
|
|
|
|
export function usePinnedDms() {
|
|
|
|
useSettings(["plugins.PinDMs.pinnedDMs"]);
|
|
|
|
|
|
|
|
return requireSnapshot();
|
|
|
|
}
|
|
|
|
|
|
|
|
export function isPinned(id: string) {
|
|
|
|
return requireSnapshot().has(id);
|
|
|
|
}
|
|
|
|
|
|
|
|
export function togglePin(id: string) {
|
|
|
|
const snapshot = requireSnapshot();
|
|
|
|
if (!snapshot.delete(id)) {
|
|
|
|
snapshot.add(id);
|
|
|
|
}
|
|
|
|
|
|
|
|
save([...snapshot]);
|
|
|
|
}
|
|
|
|
|
2023-04-16 23:06:54 +00:00
|
|
|
function sortedSnapshot() {
|
2023-04-15 00:26:46 +00:00
|
|
|
requireSnapshot();
|
2023-04-16 23:06:54 +00:00
|
|
|
if (settings.store.pinOrder === PinOrder.LastMessage)
|
|
|
|
return PrivateChannelSortStore.getPrivateChannelIds().filter(isPinned);
|
|
|
|
|
|
|
|
return snapshotArray;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function getPinAt(idx: number) {
|
|
|
|
return sortedSnapshot()[idx];
|
2023-04-15 00:26:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export function movePin(id: string, direction: -1 | 1) {
|
|
|
|
const pins = getArray()!;
|
|
|
|
const a = pins.indexOf(id);
|
|
|
|
const b = a + direction;
|
|
|
|
|
|
|
|
[pins[a], pins[b]] = [pins[b], pins[a]];
|
|
|
|
|
|
|
|
save(pins);
|
|
|
|
}
|