mirror of
https://github.com/TitanEmbeds/Titan.git
synced 2025-01-05 20:07:03 +01:00
175 lines
5.4 KiB
JavaScript
175 lines
5.4 KiB
JavaScript
/*global $, ace, Materialize, newCSS, CSS_ID, ADMIN*/
|
|
(function () {
|
|
$(window).bind('beforeunload', function(){
|
|
if ($("#live_preview_warning").is(":visible")) {
|
|
return true;
|
|
}
|
|
});
|
|
|
|
if($("#css_editor").length != 0) {
|
|
var editor = ace.edit("css_editor");
|
|
}
|
|
|
|
function postForm() {
|
|
var name = $('#css_name').val();
|
|
var var_enabled = $("#toggleCSSVar").is(':checked');
|
|
var css = null;
|
|
if($("#css_editor").length != 0) {
|
|
css = editor.getValue();
|
|
if (css.length == 0) {
|
|
css = null;
|
|
}
|
|
}
|
|
|
|
var payload = {"name": name, "variables_enabled": var_enabled, "css": css};
|
|
if (var_enabled) {
|
|
var variables = JSON.stringify(formatCSSVars());
|
|
payload.variables = variables;
|
|
}
|
|
if (ADMIN) {
|
|
var user_id = $('#css_user_id').val();
|
|
payload.user_id = user_id;
|
|
}
|
|
|
|
var funct = $.ajax({
|
|
dataType: "json",
|
|
method: "POST",
|
|
data: payload
|
|
});
|
|
return funct.promise();
|
|
}
|
|
|
|
$(function(){
|
|
if($("#css_editor").length != 0) {
|
|
editor.getSession().setMode("ace/mode/css");
|
|
editor.setTheme("ace/theme/chrome");
|
|
|
|
editor.commands.addCommand({
|
|
name: 'save',
|
|
bindKey: {win: "Ctrl-S", "mac": "Cmd-S"},
|
|
exec: function(editor) {
|
|
$('#submit-btn').trigger('click');
|
|
}
|
|
});
|
|
editor.on("blur", function () {
|
|
update_live_preview();
|
|
});
|
|
}
|
|
$("#submit-btn").click(submitForm);
|
|
|
|
if (!newCSS) {
|
|
$("#delete-btn").click(delete_css);
|
|
}
|
|
|
|
$(".updateLivePreview").on("blur", function () {
|
|
update_live_preview();
|
|
});
|
|
|
|
$("#toggleCSSVar").on("change", function () {
|
|
update_live_preview();
|
|
});
|
|
|
|
$("#preview_guildid").keyup(function (event) {
|
|
if (event.keyCode == 13) {
|
|
change_live_preview();
|
|
}
|
|
});
|
|
});
|
|
|
|
function formatCSSVars() {
|
|
return {
|
|
"modal": $("#css_var_modal").val(),
|
|
"noroleusers": $("#css_var_noroleusers").val(),
|
|
"main": $("#css_var_main").val(),
|
|
"placeholder": $("#css_var_placeholder").val(),
|
|
"sidebardivider": $("#css_var_sidebardivider").val(),
|
|
"leftsidebar": $("#css_var_leftsidebar").val(),
|
|
"rightsidebar": $("#css_var_rightsidebar").val(),
|
|
"header": $("#css_var_header").val(),
|
|
"chatmessage": $("#css_var_chatmessage").val(),
|
|
"discrim": $("#css_var_discrim").val(),
|
|
"chatbox": $("#css_var_chatbox").val(),
|
|
};
|
|
}
|
|
|
|
function submitForm() {
|
|
var name = $('#css_name').val();
|
|
if (name == "") {
|
|
Materialize.toast("Don't forget to name your CSS!", 10000);
|
|
return;
|
|
}
|
|
|
|
$("#live_preview_warning").hide();
|
|
var formPost = postForm();
|
|
formPost.done(function (data) {
|
|
if (newCSS) {
|
|
window.location.href = "edit/" + data.id;
|
|
} else {
|
|
Materialize.toast('CSS Updated!', 10000);
|
|
update_live_preview(true);
|
|
$("#live_preview_warning").hide();
|
|
}
|
|
});
|
|
formPost.fail(function () {
|
|
Materialize.toast('Oh no! Something has failed posting your CSS!', 10000);
|
|
$("#live_preview_warning").show();
|
|
});
|
|
}
|
|
|
|
function delete_css() {
|
|
var candelete = confirm("Do you really want to delete this css???");
|
|
if (!candelete) {
|
|
return;
|
|
}
|
|
|
|
$.ajax({
|
|
type: 'DELETE',
|
|
success: function() {
|
|
alert("You have successfully deleted the CSS!");
|
|
if (ADMIN) {
|
|
window.location.href = "/admin/custom_css";
|
|
} else {
|
|
window.location.href = "/user/dashboard";
|
|
}
|
|
},
|
|
error: function() {
|
|
Materialize.toast('Oh no! Something has failed deleting your CSS!', 10000);
|
|
}
|
|
});
|
|
}
|
|
|
|
function update_live_preview(refresh=false) {
|
|
if (refresh) {
|
|
$('#iframepreview').attr('src', $('#iframepreview').attr('src'));
|
|
return;
|
|
}
|
|
$("#live_preview_warning").show();
|
|
var output = "";
|
|
|
|
if ($("#toggleCSSVar").is(':checked')) {
|
|
var cssVars = formatCSSVars();
|
|
output += ":root {";
|
|
for (var key in cssVars) {
|
|
if (cssVars.hasOwnProperty(key)) {
|
|
output += "--" + key + ":" + cssVars[key] + ";";
|
|
}
|
|
}
|
|
output += "}";
|
|
}
|
|
|
|
if($("#css_editor").length != 0) {
|
|
output += editor.getValue();
|
|
}
|
|
|
|
$("#iframepreview").contents().find('#user-defined-css').html(output);
|
|
}
|
|
|
|
function change_live_preview() {
|
|
var src = "/embed/" + $("#preview_guildid").val();
|
|
if (!newCSS) {
|
|
src += "?css=" + CSS_ID;
|
|
}
|
|
$("#iframepreview").attr("src", src);
|
|
update_live_preview();
|
|
}
|
|
})(); |