2017-04-22 13:03:00 +00:00
|
|
|
"use strict";
|
2017-05-18 20:08:54 +00:00
|
|
|
|
2017-04-22 13:03:00 +00:00
|
|
|
const $ = require("jquery");
|
|
|
|
const settings = $("#settings");
|
|
|
|
const userStyles = $("#user-specified-css");
|
|
|
|
const storage = require("./localStorage");
|
2017-05-06 18:44:57 +00:00
|
|
|
const tz = require("./libs/handlebars/tz");
|
2017-04-22 13:03:00 +00:00
|
|
|
|
|
|
|
const windows = $("#windows");
|
|
|
|
const chat = $("#chat");
|
|
|
|
|
|
|
|
const options = $.extend({
|
|
|
|
coloredNicks: true,
|
|
|
|
desktopNotifications: false,
|
|
|
|
join: true,
|
|
|
|
links: true,
|
|
|
|
mode: true,
|
2017-05-09 22:18:32 +00:00
|
|
|
motd: true,
|
2017-04-22 13:03:00 +00:00
|
|
|
nick: true,
|
|
|
|
notification: true,
|
|
|
|
notifyAllMessages: false,
|
|
|
|
part: true,
|
|
|
|
quit: true,
|
2017-05-06 18:44:57 +00:00
|
|
|
showSeconds: false,
|
2017-04-22 13:03:00 +00:00
|
|
|
theme: $("#theme").attr("href").replace(/^themes\/(.*).css$/, "$1"), // Extracts default theme name, set on the server configuration
|
|
|
|
thumbnails: true,
|
|
|
|
userStyles: userStyles.text(),
|
|
|
|
highlights: []
|
|
|
|
}, JSON.parse(storage.get("settings")));
|
|
|
|
|
|
|
|
module.exports = options;
|
|
|
|
|
|
|
|
for (var i in options) {
|
|
|
|
if (i === "userStyles") {
|
|
|
|
if (!/[?&]nocss/.test(window.location.search)) {
|
|
|
|
$(document.head).find("#user-specified-css").html(options[i]);
|
|
|
|
}
|
|
|
|
settings.find("#user-specified-css-input").val(options[i]);
|
|
|
|
} else if (i === "highlights") {
|
|
|
|
settings.find("input[name=" + i + "]").val(options[i]);
|
|
|
|
} else if (i === "theme") {
|
|
|
|
$("#theme").attr("href", "themes/" + options[i] + ".css");
|
|
|
|
settings.find("select[name=" + i + "]").val(options[i]);
|
|
|
|
} else if (options[i]) {
|
|
|
|
settings.find("input[name=" + i + "]").prop("checked", true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
settings.on("change", "input, select, textarea", function() {
|
2017-06-03 18:41:21 +00:00
|
|
|
const self = $(this);
|
|
|
|
const type = self.attr("type");
|
|
|
|
const name = self.attr("name");
|
2017-04-22 13:03:00 +00:00
|
|
|
|
2017-06-03 18:41:21 +00:00
|
|
|
if (type === "password") {
|
|
|
|
return;
|
|
|
|
} else if (type === "checkbox") {
|
2017-04-22 13:03:00 +00:00
|
|
|
options[name] = self.prop("checked");
|
|
|
|
} else {
|
|
|
|
options[name] = self.val();
|
|
|
|
}
|
|
|
|
|
|
|
|
storage.set("settings", JSON.stringify(options));
|
|
|
|
|
|
|
|
if ([
|
|
|
|
"join",
|
|
|
|
"mode",
|
|
|
|
"motd",
|
|
|
|
"nick",
|
|
|
|
"part",
|
|
|
|
"quit",
|
|
|
|
"notifyAllMessages",
|
|
|
|
].indexOf(name) !== -1) {
|
|
|
|
chat.toggleClass("hide-" + name, !self.prop("checked"));
|
|
|
|
} else if (name === "coloredNicks") {
|
|
|
|
chat.toggleClass("colored-nicks", self.prop("checked"));
|
|
|
|
} else if (name === "theme") {
|
|
|
|
$("#theme").attr("href", "themes/" + options[name] + ".css");
|
|
|
|
} else if (name === "userStyles") {
|
|
|
|
userStyles.html(options[name]);
|
|
|
|
} else if (name === "highlights") {
|
|
|
|
var highlightString = options[name];
|
|
|
|
options.highlights = highlightString.split(",").map(function(h) {
|
|
|
|
return h.trim();
|
|
|
|
}).filter(function(h) {
|
|
|
|
// Ensure we don't have empty string in the list of highlights
|
|
|
|
// otherwise, users get notifications for everything
|
|
|
|
return h !== "";
|
|
|
|
});
|
2017-05-06 18:44:57 +00:00
|
|
|
} else if (name === "showSeconds") {
|
|
|
|
chat.find(".msg > .time").each(function() {
|
|
|
|
$(this).text(tz($(this).parent().data("time")));
|
|
|
|
});
|
2017-04-22 13:03:00 +00:00
|
|
|
}
|
|
|
|
}).find("input")
|
|
|
|
.trigger("change");
|
|
|
|
|
|
|
|
$("#desktopNotifications").on("change", function() {
|
|
|
|
if ($(this).prop("checked") && Notification.permission !== "granted") {
|
|
|
|
Notification.requestPermission(updateDesktopNotificationStatus);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// Updates the checkbox and warning in settings when the Settings page is
|
|
|
|
// opened or when the checkbox state is changed.
|
|
|
|
// When notifications are not supported, this is never called (because
|
|
|
|
// checkbox state can not be changed).
|
|
|
|
var updateDesktopNotificationStatus = function() {
|
|
|
|
if (Notification.permission === "denied") {
|
|
|
|
desktopNotificationsCheckbox.attr("disabled", true);
|
|
|
|
desktopNotificationsCheckbox.attr("checked", false);
|
|
|
|
warningBlocked.show();
|
|
|
|
} else {
|
|
|
|
if (Notification.permission === "default" && desktopNotificationsCheckbox.prop("checked")) {
|
|
|
|
desktopNotificationsCheckbox.attr("checked", false);
|
|
|
|
}
|
|
|
|
desktopNotificationsCheckbox.attr("disabled", false);
|
|
|
|
warningBlocked.hide();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
// If browser does not support notifications, override existing settings and
|
|
|
|
// display proper message in settings.
|
|
|
|
var desktopNotificationsCheckbox = $("#desktopNotifications");
|
|
|
|
var warningUnsupported = $("#warnUnsupportedDesktopNotifications");
|
|
|
|
var warningBlocked = $("#warnBlockedDesktopNotifications");
|
|
|
|
warningBlocked.hide();
|
|
|
|
if (("Notification" in window)) {
|
|
|
|
warningUnsupported.hide();
|
|
|
|
windows.on("show", "#settings", updateDesktopNotificationStatus);
|
|
|
|
} else {
|
|
|
|
options.desktopNotifications = false;
|
|
|
|
desktopNotificationsCheckbox.attr("disabled", true);
|
|
|
|
desktopNotificationsCheckbox.attr("checked", false);
|
|
|
|
}
|