This commit is contained in:
Mirco Wittrien 2020-12-22 18:45:40 +01:00
parent e3f7903e9f
commit afbe16e1ba
4 changed files with 137 additions and 85 deletions

View File

@ -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) => {

View File

@ -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"],

View File

@ -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();
}

View File

@ -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
})
});
}