|
|
@ -40,16 +40,18 @@ const Helpers = {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
clearFeedAccessKeys: function() {
|
|
|
|
Feeds: {
|
|
|
|
if (confirm(__("This will invalidate all previously generated feed URLs. Continue?"))) {
|
|
|
|
clearFeedAccessKeys: function() {
|
|
|
|
Notify.progress("Clearing URLs...");
|
|
|
|
if (confirm(__("This will invalidate all previously generated feed URLs. Continue?"))) {
|
|
|
|
|
|
|
|
Notify.progress("Clearing URLs...");
|
|
|
|
|
|
|
|
|
|
|
|
xhrPost("backend.php", {op: "pref-feeds", method: "clearKeys"}, () => {
|
|
|
|
xhrPost("backend.php", {op: "pref-feeds", method: "clearKeys"}, () => {
|
|
|
|
Notify.info("Generated URLs cleared.");
|
|
|
|
Notify.info("Generated URLs cleared.");
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
System: {
|
|
|
|
System: {
|
|
|
|
getPHPInfo: function(widget) {
|
|
|
|
getPHPInfo: function(widget) {
|
|
|
@ -90,151 +92,155 @@ const Helpers = {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
editProfiles: function() {
|
|
|
|
Profiles: {
|
|
|
|
const dialog = new fox.SingleUseDialog({
|
|
|
|
edit: function() {
|
|
|
|
id: "profileEditDlg",
|
|
|
|
const dialog = new fox.SingleUseDialog({
|
|
|
|
title: __("Settings Profiles"),
|
|
|
|
id: "profileEditDlg",
|
|
|
|
getSelectedProfiles: function () {
|
|
|
|
title: __("Settings Profiles"),
|
|
|
|
return Tables.getSelected("pref-profiles-list");
|
|
|
|
getSelectedProfiles: function () {
|
|
|
|
},
|
|
|
|
return Tables.getSelected("pref-profiles-list");
|
|
|
|
removeSelected: function () {
|
|
|
|
},
|
|
|
|
const sel_rows = this.getSelectedProfiles();
|
|
|
|
removeSelected: function () {
|
|
|
|
|
|
|
|
const sel_rows = this.getSelectedProfiles();
|
|
|
|
if (sel_rows.length > 0) {
|
|
|
|
|
|
|
|
if (confirm(__("Remove selected profiles? Active and default profiles will not be removed."))) {
|
|
|
|
if (sel_rows.length > 0) {
|
|
|
|
Notify.progress("Removing selected profiles...", true);
|
|
|
|
if (confirm(__("Remove selected profiles? Active and default profiles will not be removed."))) {
|
|
|
|
|
|
|
|
Notify.progress("Removing selected profiles...", true);
|
|
|
|
const query = {
|
|
|
|
|
|
|
|
op: "rpc", method: "remprofiles",
|
|
|
|
const query = {
|
|
|
|
ids: sel_rows.toString()
|
|
|
|
op: "rpc", method: "remprofiles",
|
|
|
|
};
|
|
|
|
ids: sel_rows.toString()
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
xhrPost("backend.php", query, () => {
|
|
|
|
|
|
|
|
Notify.close();
|
|
|
|
|
|
|
|
dialog.refresh();
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
alert(__("No profiles selected."));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
addProfile: function () {
|
|
|
|
|
|
|
|
if (this.validate()) {
|
|
|
|
|
|
|
|
Notify.progress("Creating profile...", true);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const query = {op: "rpc", method: "addprofile", title: dialog.attr('value').newprofile};
|
|
|
|
|
|
|
|
|
|
|
|
xhrPost("backend.php", query, () => {
|
|
|
|
xhrPost("backend.php", query, () => {
|
|
|
|
Notify.close();
|
|
|
|
Notify.close();
|
|
|
|
dialog.refresh();
|
|
|
|
dialog.refresh();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
alert(__("No profiles selected."));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
addProfile: function () {
|
|
|
|
|
|
|
|
if (this.validate()) {
|
|
|
|
|
|
|
|
Notify.progress("Creating profile...", true);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const query = {op: "rpc", method: "addprofile", title: dialog.attr('value').newprofile};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
xhrPost("backend.php", query, () => {
|
|
|
|
}
|
|
|
|
Notify.close();
|
|
|
|
},
|
|
|
|
dialog.refresh();
|
|
|
|
refresh: function() {
|
|
|
|
|
|
|
|
xhrPost("backend.php", {op: 'pref-prefs', method: 'editPrefProfiles'}, (transport) => {
|
|
|
|
|
|
|
|
dialog.attr('content', transport.responseText);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
execute: function () {
|
|
|
|
|
|
|
|
const sel_rows = this.getSelectedProfiles();
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
if (sel_rows.length == 1) {
|
|
|
|
},
|
|
|
|
if (confirm(__("Activate selected profile?"))) {
|
|
|
|
refresh: function() {
|
|
|
|
Notify.progress("Loading, please wait...");
|
|
|
|
xhrPost("backend.php", {op: 'pref-prefs', method: 'editPrefProfiles'}, (transport) => {
|
|
|
|
|
|
|
|
dialog.attr('content', transport.responseText);
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
execute: function () {
|
|
|
|
|
|
|
|
const sel_rows = this.getSelectedProfiles();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (sel_rows.length == 1) {
|
|
|
|
xhrPost("backend.php", {op: "rpc", method: "setprofile", id: sel_rows.toString()}, () => {
|
|
|
|
if (confirm(__("Activate selected profile?"))) {
|
|
|
|
window.location.reload();
|
|
|
|
Notify.progress("Loading, please wait...");
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
xhrPost("backend.php", {op: "rpc", method: "setprofile", id: sel_rows.toString()}, () => {
|
|
|
|
} else {
|
|
|
|
window.location.reload();
|
|
|
|
alert(__("Please choose a profile to activate."));
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
content: ""
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
} else {
|
|
|
|
dialog.refresh();
|
|
|
|
alert(__("Please choose a profile to activate."));
|
|
|
|
dialog.show();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
content: ""
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
dialog.refresh();
|
|
|
|
|
|
|
|
dialog.show();
|
|
|
|
|
|
|
|
},
|
|
|
|
},
|
|
|
|
customizeCSS: function() {
|
|
|
|
Prefs: {
|
|
|
|
xhrJson("backend.php", {op: "pref-prefs", method: "customizeCSS"}, (reply) => {
|
|
|
|
customizeCSS: function() {
|
|
|
|
|
|
|
|
xhrJson("backend.php", {op: "pref-prefs", method: "customizeCSS"}, (reply) => {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const dialog = new fox.SingleUseDialog({
|
|
|
|
|
|
|
|
title: __("Customize stylesheet"),
|
|
|
|
|
|
|
|
apply: function() {
|
|
|
|
|
|
|
|
xhrPost("backend.php", this.attr('value'), () => {
|
|
|
|
|
|
|
|
new Effect.Appear("css_edit_apply_msg");
|
|
|
|
|
|
|
|
$("user_css_style").innerText = this.attr('value');
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
execute: function () {
|
|
|
|
|
|
|
|
Notify.progress('Saving data...', true);
|
|
|
|
|
|
|
|
|
|
|
|
const dialog = new fox.SingleUseDialog({
|
|
|
|
xhrPost("backend.php", this.attr('value'), () => {
|
|
|
|
title: __("Customize stylesheet"),
|
|
|
|
window.location.reload();
|
|
|
|
apply: function() {
|
|
|
|
});
|
|
|
|
xhrPost("backend.php", this.attr('value'), () => {
|
|
|
|
},
|
|
|
|
new Effect.Appear("css_edit_apply_msg");
|
|
|
|
content: `
|
|
|
|
$("user_css_style").innerText = this.attr('value');
|
|
|
|
<div class='alert alert-info'>
|
|
|
|
});
|
|
|
|
${__("You can override colors, fonts and layout of your currently selected theme with custom CSS declarations here.")}
|
|
|
|
},
|
|
|
|
</div>
|
|
|
|
execute: function () {
|
|
|
|
|
|
|
|
Notify.progress('Saving data...', true);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
xhrPost("backend.php", this.attr('value'), () => {
|
|
|
|
${App.FormFields.hidden('op', 'rpc')}
|
|
|
|
window.location.reload();
|
|
|
|
${App.FormFields.hidden('method', 'setpref')}
|
|
|
|
});
|
|
|
|
${App.FormFields.hidden('key', 'USER_STYLESHEET')}
|
|
|
|
},
|
|
|
|
|
|
|
|
content: `
|
|
|
|
<div id='css_edit_apply_msg' style='display : none'>
|
|
|
|
<div class='alert alert-info'>
|
|
|
|
<div class='alert alert-warning'>
|
|
|
|
${__("You can override colors, fonts and layout of your currently selected theme with custom CSS declarations here.")}
|
|
|
|
${__("User CSS has been applied, you might need to reload the page to see all changes.")}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
${App.FormFields.hidden('op', 'rpc')}
|
|
|
|
|
|
|
|
${App.FormFields.hidden('method', 'setpref')}
|
|
|
|
|
|
|
|
${App.FormFields.hidden('key', 'USER_STYLESHEET')}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<div id='css_edit_apply_msg' style='display : none'>
|
|
|
|
|
|
|
|
<div class='alert alert-warning'>
|
|
|
|
|
|
|
|
${__("User CSS has been applied, you might need to reload the page to see all changes.")}
|
|
|
|
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<textarea class='panel user-css-editor' dojoType='dijit.form.SimpleTextarea'
|
|
|
|
|
|
|
|
style='font-size : 12px;' name='value'>${reply.value}</textarea>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<footer>
|
|
|
|
|
|
|
|
<button dojoType='dijit.form.Button' class='alt-success' onclick="App.dialogOf(this).apply()">
|
|
|
|
|
|
|
|
${__('Apply')}
|
|
|
|
|
|
|
|
</button>
|
|
|
|
|
|
|
|
<button dojoType='dijit.form.Button' class='alt-primary' type='submit'>
|
|
|
|
|
|
|
|
${__('Save and reload')}
|
|
|
|
|
|
|
|
</button>
|
|
|
|
|
|
|
|
<button dojoType='dijit.form.Button' onclick="App.dialogOf(this).hide()">
|
|
|
|
|
|
|
|
${__('Cancel')}
|
|
|
|
|
|
|
|
</button>
|
|
|
|
|
|
|
|
</footer>
|
|
|
|
|
|
|
|
`
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
dialog.show();
|
|
|
|
<textarea class='panel user-css-editor' dojoType='dijit.form.SimpleTextarea'
|
|
|
|
|
|
|
|
style='font-size : 12px;' name='value'>${reply.value}</textarea>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<footer>
|
|
|
|
|
|
|
|
<button dojoType='dijit.form.Button' class='alt-success' onclick="App.dialogOf(this).apply()">
|
|
|
|
|
|
|
|
${__('Apply')}
|
|
|
|
|
|
|
|
</button>
|
|
|
|
|
|
|
|
<button dojoType='dijit.form.Button' class='alt-primary' type='submit'>
|
|
|
|
|
|
|
|
${__('Save and reload')}
|
|
|
|
|
|
|
|
</button>
|
|
|
|
|
|
|
|
<button dojoType='dijit.form.Button' onclick="App.dialogOf(this).hide()">
|
|
|
|
|
|
|
|
${__('Cancel')}
|
|
|
|
|
|
|
|
</button>
|
|
|
|
|
|
|
|
</footer>
|
|
|
|
|
|
|
|
`
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
dialog.show();
|
|
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
confirmReset: function() {
|
|
|
|
|
|
|
|
if (confirm(__("Reset to defaults?"))) {
|
|
|
|
|
|
|
|
xhrPost("backend.php", {op: "pref-prefs", method: "resetconfig"}, (transport) => {
|
|
|
|
|
|
|
|
Helpers.refresh();
|
|
|
|
|
|
|
|
Notify.info(transport.responseText);
|
|
|
|
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
confirmReset: function() {
|
|
|
|
clearPluginData: function(name) {
|
|
|
|
if (confirm(__("Reset to defaults?"))) {
|
|
|
|
if (confirm(__("Clear stored data for this plugin?"))) {
|
|
|
|
xhrPost("backend.php", {op: "pref-prefs", method: "resetconfig"}, (transport) => {
|
|
|
|
Notify.progress("Loading, please wait...");
|
|
|
|
Helpers.Prefs.refresh();
|
|
|
|
|
|
|
|
Notify.info(transport.responseText);
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
clearPluginData: function(name) {
|
|
|
|
|
|
|
|
if (confirm(__("Clear stored data for this plugin?"))) {
|
|
|
|
|
|
|
|
Notify.progress("Loading, please wait...");
|
|
|
|
|
|
|
|
|
|
|
|
xhrPost("backend.php", {op: "pref-prefs", method: "clearplugindata", name: name}, () => {
|
|
|
|
xhrPost("backend.php", {op: "pref-prefs", method: "clearplugindata", name: name}, () => {
|
|
|
|
Helpers.refresh();
|
|
|
|
Helpers.Prefs.refresh();
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
refresh: function() {
|
|
|
|
|
|
|
|
xhrPost("backend.php", { op: "pref-prefs" }, (transport) => {
|
|
|
|
|
|
|
|
dijit.byId('prefsTab').attr('content', transport.responseText);
|
|
|
|
|
|
|
|
Notify.close();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
refresh: function() {
|
|
|
|
|
|
|
|
xhrPost("backend.php", { op: "pref-prefs" }, (transport) => {
|
|
|
|
|
|
|
|
dijit.byId('prefsTab').attr('content', transport.responseText);
|
|
|
|
|
|
|
|
Notify.close();
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
},
|
|
|
|
},
|
|
|
|
OPML: {
|
|
|
|
OPML: {
|
|
|
|
import: function() {
|
|
|
|
import: function() {
|
|
|
|