stuff
This commit is contained in:
parent
e3f7903e9f
commit
afbe16e1ba
|
@ -1069,7 +1069,7 @@ module.exports = (_ => {
|
|||
var NotificationBars = [], DesktopNotificationQueue = {queue: [], running: false};
|
||||
BDFDB.NotificationUtils = {};
|
||||
BDFDB.NotificationUtils.toast = function (text, options = {}) {
|
||||
let toasts = document.querySelector(".toasts, .bd-toasts");
|
||||
let toasts = document.querySelector(BDFDB.dotCNC.toasts + ".bd-toasts");
|
||||
if (!toasts) {
|
||||
let channels = document.querySelector(BDFDB.dotCN.channels + " + div");
|
||||
let channelRects = channels ? BDFDB.DOMUtils.getRects(channels) : null;
|
||||
|
@ -1078,31 +1078,31 @@ module.exports = (_ => {
|
|||
let width = channelRects ? (members ? channelRects.width - BDFDB.DOMUtils.getRects(members).width : channelRects.width) : window.outerWidth - 0;
|
||||
let form = channels ? channels.querySelector("form") : null;
|
||||
let bottom = form ? BDFDB.DOMUtils.getRects(form).height : 80;
|
||||
toasts = BDFDB.DOMUtils.create(`<div class="toasts bd-toasts" style="width: ${width}px; left: ${left}px; bottom: ${bottom}px;"></div>`);
|
||||
toasts = BDFDB.DOMUtils.create(`<div class="${BDFDB.disCN.toasts} bd-toasts" style="width: ${width}px; left: ${left}px; bottom: ${bottom}px;"></div>`);
|
||||
(document.querySelector(BDFDB.dotCN.app) || document.body).appendChild(toasts);
|
||||
}
|
||||
const {type = "", icon = true, timeout = 3000, html = false, selector = "", nopointer = false, color = ""} = options;
|
||||
let toast = BDFDB.DOMUtils.create(`<div class="toast bd-toast">${html === true ? text : BDFDB.StringUtils.htmlEscape(text)}</div>`);
|
||||
let toast = BDFDB.DOMUtils.create(`<div class="${BDFDB.disCN.toast} bd-toast">${html === true ? text : BDFDB.StringUtils.htmlEscape(text)}</div>`);
|
||||
if (type) {
|
||||
BDFDB.DOMUtils.addClass(toast, "toast-" + type);
|
||||
if (icon) BDFDB.DOMUtils.addClass(toast, "icon");
|
||||
if (icon) BDFDB.DOMUtils.addClass(toast, BDFDB.disCN.toasticon);
|
||||
}
|
||||
else if (color) {
|
||||
let rgbColor = BDFDB.ColorUtils.convert(color, "RGB");
|
||||
if (rgbColor) {
|
||||
toast.style.setProperty("background-color", rgbColor);
|
||||
BDFDB.DOMUtils.addClass(toast, "toast-custom");
|
||||
BDFDB.DOMUtils.addClass(toast, BDFDB.disCN.toastcustom);
|
||||
}
|
||||
}
|
||||
BDFDB.DOMUtils.addClass(toast, selector);
|
||||
toasts.appendChild(toast);
|
||||
toast.close = _ => {
|
||||
if (document.contains(toast)) {
|
||||
BDFDB.DOMUtils.addClass(toast, "closing");
|
||||
BDFDB.DOMUtils.addClass(toast, BDFDB.disCN.toastclosing);
|
||||
toast.style.setProperty("pointer-events", "none", "important");
|
||||
BDFDB.TimeUtils.timeout(_ => {
|
||||
toast.remove();
|
||||
if (!toasts.querySelectorAll(".toast, .bd-toast").length) toasts.remove();
|
||||
if (!toasts.querySelectorAll(BDFDB.dotCNC.toast + ".bd-toast").length) toasts.remove();
|
||||
}, 3000);
|
||||
}
|
||||
};
|
||||
|
@ -1111,15 +1111,15 @@ module.exports = (_ => {
|
|||
BDFDB.TimeUtils.timeout(_ => {toast.close();}, timeout > 0 ? timeout : 600000);
|
||||
return toast;
|
||||
};
|
||||
BDFDB.NotificationUtils.desktop = function (parsedcontent, parsedoptions = {}) {
|
||||
BDFDB.NotificationUtils.desktop = function (parsedContent, parsedOptions = {}) {
|
||||
const queue = _ => {
|
||||
DesktopNotificationQueue.queue.push({parsedcontent, parsedoptions});
|
||||
DesktopNotificationQueue.queue.push({parsedContent, parsedOptions});
|
||||
runqueue();
|
||||
};
|
||||
const runqueue = _ => {
|
||||
if (!DesktopNotificationQueue.running) {
|
||||
let notification = DesktopNotificationQueue.queue.shift();
|
||||
if (notification) notify(notification.parsedcontent, notification.parsedoptions);
|
||||
if (notification) notify(notification.parsedContent, notification.parsedOptions);
|
||||
}
|
||||
};
|
||||
const notify = (content, options) => {
|
||||
|
|
|
@ -886,6 +886,15 @@
|
|||
"hue": "hue-13HAGb",
|
||||
"saturation": "saturation-1FDvtn",
|
||||
"wrapper": "wrapper-2AQieU"
|
||||
},
|
||||
"Toast": {
|
||||
"avatar": "toast-avatar",
|
||||
"closing": "closing",
|
||||
"custom": "toast-custom",
|
||||
"icon": "icon",
|
||||
"inner": "toast-inner",
|
||||
"toast": "toast",
|
||||
"toasts": "toasts"
|
||||
}
|
||||
},
|
||||
"DiscordClassModules": {
|
||||
|
@ -2578,6 +2587,13 @@
|
|||
"titlesize12": ["UserPopout", "size12"],
|
||||
"titlesize14": ["UserPopout", "size14"],
|
||||
"titlesize16": ["UserPopout", "size16"],
|
||||
"toast": ["Toast", "toast"],
|
||||
"toastavatar": ["Toast", "avatar"],
|
||||
"toastclosing": ["Toast", "closing"],
|
||||
"toastcustom": ["Toast", "custom"],
|
||||
"toasticon": ["Toast", "icon"],
|
||||
"toastinner": ["Toast", "inner"],
|
||||
"toasts": ["Toast", "toasts"],
|
||||
"tooltip": ["Tooltip", "tooltip"],
|
||||
"tooltipactivityicon": ["TooltipGuild", "activityIcon"],
|
||||
"tooltipblack": ["Tooltip", "tooltipBlack"],
|
||||
|
|
|
@ -1059,7 +1059,7 @@ img:not([src]), img[src=""], img[src="null"] {
|
|||
text-decoration: underline;
|
||||
}
|
||||
|
||||
.toasts {
|
||||
[REPLACE_CLASS_toasts] {
|
||||
position: fixed;
|
||||
display: flex;
|
||||
top: 0;
|
||||
|
@ -1075,7 +1075,7 @@ img:not([src]), img[src=""], img[src="null"] {
|
|||
opacity: 0;
|
||||
}
|
||||
}
|
||||
.toast {
|
||||
[REPLACE_CLASS_toast] {
|
||||
background-color: var(--background-floating);
|
||||
border-radius: 5px;
|
||||
box-shadow: var(--elevation-medium);
|
||||
|
@ -1096,17 +1096,17 @@ img:not([src]), img[src=""], img[src="null"] {
|
|||
opacity: 0;
|
||||
}
|
||||
}
|
||||
.toast.closing {
|
||||
[REPLACE_CLASS_toast][REPLACE_CLASS_toastclosing] {
|
||||
animation: toast-down 200ms ease;
|
||||
animation-fill-mode: forwards;
|
||||
opacity: 1;
|
||||
transform: translateY(-10px);
|
||||
}
|
||||
.toast .toast-inner {
|
||||
[REPLACE_CLASS_toast] [REPLACE_CLASS_toastinner] {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
}
|
||||
.toast .toast-avatar {
|
||||
[REPLACE_CLASS_toast] [REPLACE_CLASS_toastavatar] {
|
||||
margin-right: 5px;
|
||||
width: 25px;
|
||||
height: 25px;
|
||||
|
@ -1115,88 +1115,88 @@ img:not([src]), img[src=""], img[src="null"] {
|
|||
background-position: center;
|
||||
border-radius: 50%;
|
||||
}
|
||||
.toast.icon {
|
||||
[REPLACE_CLASS_toast][REPLACE_CLASS_toasticon] {
|
||||
padding-left: 30px;
|
||||
background-position: 6px 50%;
|
||||
background-size: 20px 20px;
|
||||
background-repeat: no-repeat;
|
||||
}
|
||||
.toast.toast-custom {
|
||||
[REPLACE_CLASS_toast][REPLACE_CLASS_toastcustom] {
|
||||
color: #FFF;
|
||||
}
|
||||
.toast.toast-brand {
|
||||
[REPLACE_CLASS_toast].toast-brand {
|
||||
background-color: var(--bdfdb-blurple);
|
||||
color: #FFF;
|
||||
}
|
||||
.toast.toast-brand.icon {
|
||||
[REPLACE_CLASS_toast].toast-brand[REPLACE_CLASS_toasticon] {
|
||||
background-image: url();
|
||||
}
|
||||
.toast.toast-danger,
|
||||
.toast.toast-error {
|
||||
[REPLACE_CLASS_toast].toast-danger,
|
||||
[REPLACE_CLASS_toast].toast-error {
|
||||
background-color: #F04747;
|
||||
color: #FFF;
|
||||
}
|
||||
.toast.toast-danger.icon,
|
||||
.toast.toast-error.icon {
|
||||
[REPLACE_CLASS_toast].toast-danger[REPLACE_CLASS_toasticon],
|
||||
[REPLACE_CLASS_toast].toast-error[REPLACE_CLASS_toasticon] {
|
||||
background-image: url();
|
||||
}
|
||||
.toast.toast-default {
|
||||
[REPLACE_CLASS_toast].toast-default {
|
||||
background-color: #F26522;
|
||||
color: #FFF;
|
||||
}
|
||||
.toast.toast-default.icon {
|
||||
[REPLACE_CLASS_toast].toast-default[REPLACE_CLASS_toasticon] {
|
||||
padding-left: 10px;
|
||||
}
|
||||
.toast.toast-facebook {
|
||||
[REPLACE_CLASS_toast].toast-facebook {
|
||||
background-color: #355089;
|
||||
color: #FFF;
|
||||
}
|
||||
.toast.toast-facebook.icon {
|
||||
[REPLACE_CLASS_toast].toast-facebook[REPLACE_CLASS_toasticon] {
|
||||
background-image: url();
|
||||
}
|
||||
.toast.toast-info {
|
||||
[REPLACE_CLASS_toast].toast-info {
|
||||
background-color: #4A90E2;
|
||||
color: #FFF;
|
||||
}
|
||||
.toast.toast-info.icon {
|
||||
[REPLACE_CLASS_toast].toast-info[REPLACE_CLASS_toasticon] {
|
||||
background-image: url();
|
||||
}
|
||||
.toast.toast-premium {
|
||||
[REPLACE_CLASS_toast].toast-premium {
|
||||
background-color: #202225;
|
||||
color: #FFF;
|
||||
}
|
||||
.toast.toast-premium.icon {
|
||||
[REPLACE_CLASS_toast].toast-premium[REPLACE_CLASS_toasticon] {
|
||||
background-image: url();
|
||||
background-size: 63px 16px;
|
||||
padding-left: 73px;
|
||||
}
|
||||
.toast.toast-spotify {
|
||||
[REPLACE_CLASS_toast].toast-spotify {
|
||||
background-color: #1DB954;
|
||||
color: #FFF;
|
||||
}
|
||||
.toast.toast-spotify.icon {
|
||||
[REPLACE_CLASS_toast].toast-spotify[REPLACE_CLASS_toasticon] {
|
||||
background-image: url();
|
||||
}
|
||||
.toast.toast-streamermode {
|
||||
[REPLACE_CLASS_toast].toast-streamermode {
|
||||
background-color: #593695;
|
||||
color: #FFF;
|
||||
}
|
||||
.toast.toast-streamermode.icon {
|
||||
[REPLACE_CLASS_toast].toast-streamermode[REPLACE_CLASS_toasticon] {
|
||||
background-image: url();
|
||||
}
|
||||
.toast.toast-success {
|
||||
[REPLACE_CLASS_toast].toast-success {
|
||||
background-color: #43B581;
|
||||
color: #FFF;
|
||||
}
|
||||
.toast.toast-success.icon {
|
||||
[REPLACE_CLASS_toast].toast-success[REPLACE_CLASS_toasticon] {
|
||||
background-image: url();
|
||||
}
|
||||
.toast.toast-warning,
|
||||
.toast.toast-warn {
|
||||
[REPLACE_CLASS_toast].toast-warning,
|
||||
[REPLACE_CLASS_toast].toast-warn {
|
||||
background-color: #FFA600;
|
||||
color: #FFF;
|
||||
}
|
||||
.toast.toast-warning.icon,
|
||||
.toast.toast-warn.icon {
|
||||
[REPLACE_CLASS_toast].toast-warning[REPLACE_CLASS_toasticon],
|
||||
[REPLACE_CLASS_toast].toast-warn[REPLACE_CLASS_toasticon] {
|
||||
background-image: url();
|
||||
}
|
||||
|
|
|
@ -14,12 +14,12 @@ module.exports = (_ => {
|
|||
"info": {
|
||||
"name": "FriendNotifications",
|
||||
"author": "DevilBro",
|
||||
"version": "1.5.4",
|
||||
"version": "1.5.5",
|
||||
"description": "Get a notification when a Friend or a User you choose to observe changes their online status, can be configured individually in the settings"
|
||||
},
|
||||
"changeLog": {
|
||||
"fixed": {
|
||||
"New Settings Menu": "Fixed for new settings menu"
|
||||
"added": {
|
||||
"Search": "You can now search for a username in the time log modal"
|
||||
}
|
||||
}
|
||||
};
|
||||
|
@ -64,7 +64,8 @@ module.exports = (_ => {
|
|||
}
|
||||
} : (([Plugin, BDFDB]) => {
|
||||
var _this;
|
||||
var userStatusStore, timeLog, lastTimes, friendCounter, checkInterval, paginationOffset = {};
|
||||
var userStatusStore, timeLog, lastTimes, checkInterval, paginationOffset = {};
|
||||
var friendCounter, timeLogList;
|
||||
var settings = {}, amounts = {}, notificationStrings = {}, notificationSounds = {}, observedUsers = {};
|
||||
|
||||
const FriendOnlineCounterComponent = class FriendOnlineCounter extends BdApi.React.Component {
|
||||
|
@ -84,6 +85,49 @@ module.exports = (_ => {
|
|||
});
|
||||
}
|
||||
};
|
||||
|
||||
const TimeLogComponent = class TimeLog extends BdApi.React.Component {
|
||||
componentDidMount() {
|
||||
timeLogList = this;
|
||||
}
|
||||
render() {
|
||||
return this.props.entries.length ? BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.PaginatedList, {
|
||||
items: this.props.entries,
|
||||
amount: 100,
|
||||
copyToBottom: true,
|
||||
renderItem: (log, i) => [
|
||||
i > 0 ? BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormDivider, {
|
||||
className: BDFDB.disCNS.margintop8 + BDFDB.disCN.marginbottom8
|
||||
}) : null,
|
||||
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Flex, {
|
||||
align: BDFDB.LibraryComponents.Flex.Align.CENTER,
|
||||
children: [
|
||||
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextElement, {
|
||||
className: BDFDB.disCN._friendnotificationslogtime,
|
||||
children: `[${log.timeString}]`
|
||||
}),
|
||||
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.AvatarComponents.default, {
|
||||
className: BDFDB.disCN._friendnotificationslogavatar,
|
||||
src: log.avatar,
|
||||
status: log.status,
|
||||
size: BDFDB.LibraryComponents.AvatarComponents.Sizes.SIZE_40
|
||||
}),
|
||||
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextScroller, {
|
||||
className: BDFDB.disCN._friendnotificationslogcontent,
|
||||
speed: 1,
|
||||
children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextElement, {
|
||||
children: BDFDB.ReactUtils.elementToReact(BDFDB.DOMUtils.create(log.string))
|
||||
})
|
||||
})
|
||||
]
|
||||
})
|
||||
]
|
||||
}) : BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.MessagesPopoutComponents.EmptyStateBottom, {
|
||||
msg: BDFDB.LanguageUtils.LanguageStrings.AUTOCOMPLETE_NO_RESULTS_HEADER,
|
||||
image: BDFDB.DiscordUtils.getTheme() == BDFDB.disCN.themelight ? "/assets/9b0d90147f7fab54f00dd193fe7f85cd.svg" : "/assets/308e587f3a68412f137f7317206e92c2.svg"
|
||||
})
|
||||
}
|
||||
};
|
||||
|
||||
return class FriendNotifications extends Plugin {
|
||||
onLoad() {
|
||||
|
@ -144,6 +188,11 @@ module.exports = (_ => {
|
|||
${BDFDB.dotCN._friendnotificationsfriendsonline} {
|
||||
cursor: pointer;
|
||||
}
|
||||
${BDFDB.dotCNS._friendnotificationstimelogmodal + BDFDB.dotCN.messagespopoutemptyplaceholder} {
|
||||
position: absolute;
|
||||
bottom: 0;
|
||||
width: 100%;
|
||||
}
|
||||
`;
|
||||
|
||||
for (let type in this.defaults.notificationstrings) {
|
||||
|
@ -399,19 +448,19 @@ module.exports = (_ => {
|
|||
children: [BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Flex, {
|
||||
className: BDFDB.disCN.marginbottom8,
|
||||
children: BDFDB.ReactUtils.createElement("div", {
|
||||
className: BDFDB.disCNS.settingsrowtitle + BDFDB.disCNS.settingsrowtitledefault + BDFDB.disCN.cursordefault,
|
||||
className: BDFDB.disCNS.settingsrowtitle + BDFDB.disCNS.settingsrowtitle + BDFDB.disCNS.settingsrowtitledefault + BDFDB.disCN.cursordefault,
|
||||
children: [
|
||||
"Allows you to configure your own message strings for the different statuses. ",
|
||||
BDFDB.ReactUtils.createElement("strong", {children: "$user"}),
|
||||
" is the placeholder for the username, ",
|
||||
BDFDB.ReactUtils.createElement("strong", {children: "$status"}),
|
||||
" for the statusName, ",
|
||||
" for the status name, ",
|
||||
BDFDB.ReactUtils.createElement("strong", {children: "$game"}),
|
||||
" for the gamename, ",
|
||||
" for the game name, ",
|
||||
BDFDB.ReactUtils.createElement("strong", {children: "$song"}),
|
||||
" for the songname and ",
|
||||
" for the song name and ",
|
||||
BDFDB.ReactUtils.createElement("strong", {children: "$artist"}),
|
||||
" for the songartist."
|
||||
" for the song artist."
|
||||
]
|
||||
})
|
||||
})].concat(Object.keys(notificationStrings).map(key => BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsSaveItem, {
|
||||
|
@ -622,7 +671,7 @@ module.exports = (_ => {
|
|||
};
|
||||
if (!observedUsers[id].desktop) {
|
||||
if (!document.querySelector(`.friendnotifications-${id}-toast`)) {
|
||||
let toast = BDFDB.NotificationUtils.toast(`<div class="toast-inner"><div class="toast-avatar" style="background-image: url(${avatar});"></div><div>${toastString}</div></div>`, {html: true, timeout: toastTime, color: BDFDB.UserUtils.getStatusColor(status.statusName), icon: false, selector: `friendnotifications-${status.statusName}-toast friendnotifications-${id}-toast`});
|
||||
let toast = BDFDB.NotificationUtils.toast(`<div class="${BDFDB.disCN.toastinner}"><div class="${BDFDB.disCN.toastavatar}" style="background-image: url(${avatar});"></div><div>${toastString}</div></div>`, {html: true, timeout: toastTime, color: BDFDB.UserUtils.getStatusColor(status.statusName), icon: false, selector: `friendnotifications-${status.statusName}-toast friendnotifications-${id}-toast`});
|
||||
toast.addEventListener("click", openChannel);
|
||||
let notificationsound = notificationSounds["toast" + status.statusName] || {};
|
||||
if (!notificationsound.mute && notificationsound.song) {
|
||||
|
@ -646,43 +695,30 @@ module.exports = (_ => {
|
|||
}
|
||||
|
||||
showTimeLog () {
|
||||
if (!timeLog.length) BDFDB.NotificationUtils.toast("No logs saved yet", {type: "error"});
|
||||
else BDFDB.ModalUtils.open(this, {
|
||||
let searchTimeout;
|
||||
BDFDB.ModalUtils.open(this, {
|
||||
size: "MEDIUM",
|
||||
header: "LogIn/-Out Timelog",
|
||||
subheader: "",
|
||||
className: `${this.name}-Log-modal`,
|
||||
children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.PaginatedList, {
|
||||
items: timeLog,
|
||||
amount: 100,
|
||||
copyToBottom: true,
|
||||
renderItem: (log, i) => [
|
||||
i > 0 ? BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormDivider, {
|
||||
className: BDFDB.disCNS.margintop8 + BDFDB.disCN.marginbottom8
|
||||
}) : null,
|
||||
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Flex, {
|
||||
align: BDFDB.LibraryComponents.Flex.Align.CENTER,
|
||||
children: [
|
||||
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextElement, {
|
||||
className: BDFDB.disCN._friendnotificationslogtime,
|
||||
children: `[${log.timeString}]`
|
||||
}),
|
||||
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.AvatarComponents.default, {
|
||||
className: BDFDB.disCN._friendnotificationslogavatar,
|
||||
src: log.avatar,
|
||||
status: log.status,
|
||||
size: BDFDB.LibraryComponents.AvatarComponents.Sizes.SIZE_40
|
||||
}),
|
||||
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextScroller, {
|
||||
className: BDFDB.disCN._friendnotificationslogcontent,
|
||||
speed: 1,
|
||||
children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextElement, {
|
||||
children: BDFDB.ReactUtils.elementToReact(BDFDB.DOMUtils.create(log.string))
|
||||
})
|
||||
})
|
||||
]
|
||||
})
|
||||
]
|
||||
className: BDFDB.disCN._friendnotificationstimelogmodal,
|
||||
titleChildren: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SearchBar, {
|
||||
autoFocus: true,
|
||||
query: "",
|
||||
onChange: (value, instance) => {
|
||||
BDFDB.TimeUtils.clear(searchTimeout);
|
||||
searchTimeout = BDFDB.TimeUtils.timeout(_ => {
|
||||
let searchString = value.toUpperCase();
|
||||
timeLogList.props.entries = timeLog.filter(n => n && n.name && n.name.toUpperCase().indexOf(searchString) > -1);
|
||||
BDFDB.ReactUtils.forceUpdate(timeLogList);
|
||||
}, 1000);
|
||||
},
|
||||
onClear: instance => {
|
||||
timeLogList.props.entries = timeLog;
|
||||
BDFDB.ReactUtils.forceUpdate(timeLogList);
|
||||
}
|
||||
}),
|
||||
children: BDFDB.ReactUtils.createElement(TimeLogComponent, {
|
||||
entries: timeLog
|
||||
})
|
||||
});
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue