2020-06-04 20:27:22 +00:00
|
|
|
'use strict';
|
|
|
|
|
2021-02-12 16:02:09 +00:00
|
|
|
/* eslint-disable no-new */
|
2021-02-19 08:28:14 +00:00
|
|
|
/* global __, dijit, dojo, Tables, xhrPost, Notify, xhr, App, fox */
|
2020-06-04 20:27:22 +00:00
|
|
|
|
2020-06-04 17:04:17 +00:00
|
|
|
const Helpers = {
|
|
|
|
AppPasswords: {
|
|
|
|
getSelected: function() {
|
|
|
|
return Tables.getSelected("app-password-list");
|
|
|
|
},
|
|
|
|
updateContent: function(data) {
|
2021-02-18 18:51:18 +00:00
|
|
|
App.byId("app_passwords_holder").innerHTML = data;
|
2020-06-04 17:04:17 +00:00
|
|
|
dojo.parser.parse("app_passwords_holder");
|
|
|
|
},
|
|
|
|
removeSelected: function() {
|
|
|
|
const rows = this.getSelected();
|
2019-11-01 12:03:57 +00:00
|
|
|
|
2020-06-04 17:04:17 +00:00
|
|
|
if (rows.length == 0) {
|
|
|
|
alert("No passwords selected.");
|
2020-06-04 20:27:22 +00:00
|
|
|
} else if (confirm(__("Remove selected app passwords?"))) {
|
2019-11-01 12:03:57 +00:00
|
|
|
|
2021-02-19 10:44:56 +00:00
|
|
|
xhr.post("backend.php", {op: "pref-prefs", method: "deleteAppPassword", ids: rows.toString()}, (reply) => {
|
|
|
|
this.updateContent(reply);
|
2020-06-04 20:27:22 +00:00
|
|
|
Notify.close();
|
|
|
|
});
|
2019-11-01 12:03:57 +00:00
|
|
|
|
2020-06-04 20:27:22 +00:00
|
|
|
Notify.progress("Loading, please wait...");
|
2020-06-04 17:04:17 +00:00
|
|
|
}
|
2019-11-01 12:03:57 +00:00
|
|
|
},
|
2020-06-04 17:04:17 +00:00
|
|
|
generate: function() {
|
|
|
|
const title = prompt("Password description:")
|
2018-12-02 14:00:58 +00:00
|
|
|
|
2020-06-04 17:04:17 +00:00
|
|
|
if (title) {
|
2021-02-19 10:44:56 +00:00
|
|
|
xhr.post("backend.php", {op: "pref-prefs", method: "generateAppPassword", title: title}, (reply) => {
|
|
|
|
this.updateContent(reply);
|
2020-06-04 17:04:17 +00:00
|
|
|
Notify.close();
|
2018-12-02 14:00:58 +00:00
|
|
|
});
|
|
|
|
|
2018-12-02 17:56:30 +00:00
|
|
|
Notify.progress("Loading, please wait...");
|
2018-12-02 14:00:58 +00:00
|
|
|
}
|
|
|
|
},
|
2020-06-04 17:04:17 +00:00
|
|
|
},
|
2021-02-12 18:51:32 +00:00
|
|
|
Feeds: {
|
|
|
|
clearFeedAccessKeys: function() {
|
|
|
|
if (confirm(__("This will invalidate all previously generated feed URLs. Continue?"))) {
|
|
|
|
Notify.progress("Clearing URLs...");
|
2018-12-02 14:00:58 +00:00
|
|
|
|
2021-02-19 08:28:14 +00:00
|
|
|
xhr.post("backend.php", {op: "pref-feeds", method: "clearKeys"}, () => {
|
2021-02-12 18:51:32 +00:00
|
|
|
Notify.info("Generated URLs cleared.");
|
|
|
|
});
|
|
|
|
}
|
2018-12-02 14:00:58 +00:00
|
|
|
|
2021-02-12 18:51:32 +00:00
|
|
|
return false;
|
|
|
|
},
|
2020-06-04 17:04:17 +00:00
|
|
|
},
|
2021-02-12 18:43:38 +00:00
|
|
|
System: {
|
2021-02-14 09:29:08 +00:00
|
|
|
//
|
2021-02-12 18:43:38 +00:00
|
|
|
},
|
2021-02-06 07:10:54 +00:00
|
|
|
EventLog: {
|
|
|
|
log_page: 0,
|
|
|
|
refresh: function() {
|
|
|
|
this.log_page = 0;
|
|
|
|
this.update();
|
|
|
|
},
|
|
|
|
update: function() {
|
2021-02-19 10:44:56 +00:00
|
|
|
xhr.post("backend.php", {
|
|
|
|
op: "pref-system",
|
|
|
|
severity: dijit.byId("severity").attr('value'),
|
|
|
|
page: Helpers.EventLog.log_page
|
|
|
|
}, (reply) => {
|
|
|
|
|
|
|
|
dijit.byId('systemTab').attr('content', reply);
|
2021-02-06 07:10:54 +00:00
|
|
|
Notify.close();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
nextPage: function() {
|
|
|
|
this.log_page += 1;
|
|
|
|
this.update();
|
|
|
|
},
|
|
|
|
prevPage: function() {
|
|
|
|
if (this.log_page > 0) this.log_page -= 1;
|
2020-06-04 17:04:17 +00:00
|
|
|
|
2021-02-06 07:10:54 +00:00
|
|
|
this.update();
|
|
|
|
},
|
|
|
|
clear: function() {
|
|
|
|
if (confirm(__("Clear event log?"))) {
|
2020-06-04 17:04:17 +00:00
|
|
|
|
2021-02-06 07:10:54 +00:00
|
|
|
Notify.progress("Loading, please wait...");
|
|
|
|
|
2021-02-19 08:28:14 +00:00
|
|
|
xhr.post("backend.php", {op: "pref-system", method: "clearLog"}, () => {
|
2021-02-06 07:10:54 +00:00
|
|
|
Helpers.EventLog.refresh();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
},
|
2020-06-04 17:04:17 +00:00
|
|
|
},
|
2021-02-12 18:51:32 +00:00
|
|
|
Profiles: {
|
|
|
|
edit: function() {
|
|
|
|
const dialog = new fox.SingleUseDialog({
|
|
|
|
id: "profileEditDlg",
|
|
|
|
title: __("Settings Profiles"),
|
|
|
|
getSelectedProfiles: function () {
|
|
|
|
return Tables.getSelected("pref-profiles-list");
|
|
|
|
},
|
|
|
|
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."))) {
|
|
|
|
Notify.progress("Removing selected profiles...", true);
|
|
|
|
|
|
|
|
const query = {
|
2021-02-18 08:54:22 +00:00
|
|
|
op: "pref-prefs", method: "remprofiles",
|
2021-02-12 18:51:32 +00:00
|
|
|
ids: sel_rows.toString()
|
|
|
|
};
|
|
|
|
|
2021-02-19 08:28:14 +00:00
|
|
|
xhr.post("backend.php", query, () => {
|
2021-02-12 18:51:32 +00:00
|
|
|
Notify.close();
|
|
|
|
dialog.refresh();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
alert(__("No profiles selected."));
|
|
|
|
}
|
|
|
|
},
|
|
|
|
addProfile: function () {
|
|
|
|
if (this.validate()) {
|
|
|
|
Notify.progress("Creating profile...", true);
|
|
|
|
|
2021-02-18 08:54:22 +00:00
|
|
|
const query = {op: "pref-prefs", method: "addprofile", title: dialog.attr('value').newprofile};
|
2018-12-02 14:00:58 +00:00
|
|
|
|
2021-02-19 08:28:14 +00:00
|
|
|
xhr.post("backend.php", query, () => {
|
2018-12-02 17:56:30 +00:00
|
|
|
Notify.close();
|
2021-02-12 12:22:10 +00:00
|
|
|
dialog.refresh();
|
2018-12-02 14:00:58 +00:00
|
|
|
});
|
2018-12-11 11:25:41 +00:00
|
|
|
|
2021-02-12 18:51:32 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
refresh: function() {
|
2021-02-19 07:22:00 +00:00
|
|
|
xhr.json("backend.php", {op: 'pref-prefs', method: 'getprofiles'}, (reply) => {
|
2021-02-18 08:54:22 +00:00
|
|
|
dialog.attr('content', `
|
|
|
|
<div dojoType='fox.Toolbar'>
|
|
|
|
<div dojoType='fox.form.DropDownButton'>
|
|
|
|
<span>${__('Select')}</span>
|
|
|
|
<div dojoType='dijit.Menu' style='display: none'>
|
|
|
|
<div onclick="Tables.select('pref-profiles-list', true)"
|
|
|
|
dojoType='dijit.MenuItem'>${__('All')}</div>
|
|
|
|
<div onclick="Tables.select('pref-profiles-list', false)"
|
|
|
|
dojoType='dijit.MenuItem'>${__('None')}</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="pull-right">
|
|
|
|
<input name='newprofile' dojoType='dijit.form.ValidationTextBox' required='1'>
|
|
|
|
${App.FormFields.button_tag(__('Create profile'), "", {onclick: 'App.dialogOf(this).addProfile()'})}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<form onsubmit='return false'>
|
|
|
|
<div class='panel panel-scrollable'>
|
|
|
|
<table width='100%' id='pref-profiles-list'>
|
|
|
|
${reply.map((profile) => `
|
|
|
|
<tr data-row-id="${profile.id}">
|
|
|
|
<td width='5%'>
|
|
|
|
${App.FormFields.checkbox_tag("", false, "", {onclick: 'Tables.onRowChecked(this)'})}
|
|
|
|
</td>
|
|
|
|
<td>
|
|
|
|
${profile.id > 0 ?
|
|
|
|
`<span dojoType='dijit.InlineEditBox' width='300px' autoSave='false'
|
|
|
|
profile-id='${profile.id}'>${profile.title}
|
|
|
|
<script type='dojo/method' event='onChange' args='value'>
|
2021-02-19 10:44:56 +00:00
|
|
|
xhr.post("backend.php",
|
|
|
|
{op: 'pref-prefs', method: 'saveprofile', value: value, id: this.attr('profile-id')}, () => {
|
2021-02-18 08:54:22 +00:00
|
|
|
//
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
</span>` : `${profile.title}`}
|
|
|
|
${profile.active ? __("(active)") : ""}
|
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
`).join("")}
|
|
|
|
</table>
|
|
|
|
</div>
|
2021-02-18 08:55:00 +00:00
|
|
|
|
2021-02-18 08:54:22 +00:00
|
|
|
<footer>
|
|
|
|
${App.FormFields.button_tag(__('Remove selected profiles'), "",
|
|
|
|
{class: 'pull-left alt-danger', onclick: 'App.dialogOf(this).removeSelected()'})}
|
|
|
|
${App.FormFields.submit_tag(__('Activate profile'), {onclick: 'App.dialogOf(this).execute()'})}
|
|
|
|
${App.FormFields.cancel_dialog_tag(__('Cancel'))}
|
|
|
|
</footer>
|
|
|
|
</form>
|
|
|
|
`);
|
2020-06-04 17:04:17 +00:00
|
|
|
});
|
2021-02-12 18:51:32 +00:00
|
|
|
},
|
|
|
|
execute: function () {
|
|
|
|
const sel_rows = this.getSelectedProfiles();
|
2020-06-04 17:04:17 +00:00
|
|
|
|
2021-02-12 18:51:32 +00:00
|
|
|
if (sel_rows.length == 1) {
|
|
|
|
if (confirm(__("Activate selected profile?"))) {
|
|
|
|
Notify.progress("Loading, please wait...");
|
2021-02-12 07:35:13 +00:00
|
|
|
|
2021-02-19 08:28:14 +00:00
|
|
|
xhr.post("backend.php", {op: "pref-prefs", method: "activateprofile", id: sel_rows.toString()}, () => {
|
2021-02-12 18:51:32 +00:00
|
|
|
window.location.reload();
|
|
|
|
});
|
|
|
|
}
|
2021-02-12 07:35:13 +00:00
|
|
|
|
2021-02-12 18:51:32 +00:00
|
|
|
} else {
|
|
|
|
alert(__("Please choose a profile to activate."));
|
2021-02-12 07:35:13 +00:00
|
|
|
}
|
2021-02-12 18:51:32 +00:00
|
|
|
},
|
|
|
|
content: ""
|
|
|
|
});
|
2021-02-12 07:35:13 +00:00
|
|
|
|
2021-02-12 18:51:32 +00:00
|
|
|
dialog.refresh();
|
|
|
|
dialog.show();
|
|
|
|
},
|
2020-06-04 17:04:17 +00:00
|
|
|
},
|
2021-02-12 18:51:32 +00:00
|
|
|
Prefs: {
|
|
|
|
customizeCSS: function() {
|
2021-02-19 07:22:00 +00:00
|
|
|
xhr.json("backend.php", {op: "pref-prefs", method: "customizeCSS"}, (reply) => {
|
2021-02-12 18:51:32 +00:00
|
|
|
|
|
|
|
const dialog = new fox.SingleUseDialog({
|
|
|
|
title: __("Customize stylesheet"),
|
|
|
|
apply: function() {
|
2021-02-19 08:28:14 +00:00
|
|
|
xhr.post("backend.php", this.attr('value'), () => {
|
2021-02-18 18:51:18 +00:00
|
|
|
Element.show("css_edit_apply_msg");
|
|
|
|
App.byId("user_css_style").innerText = this.attr('value');
|
2021-02-12 18:51:32 +00:00
|
|
|
});
|
|
|
|
},
|
|
|
|
execute: function () {
|
|
|
|
Notify.progress('Saving data...', true);
|
2021-02-12 06:02:44 +00:00
|
|
|
|
2021-02-19 08:28:14 +00:00
|
|
|
xhr.post("backend.php", this.attr('value'), () => {
|
2021-02-12 18:51:32 +00:00
|
|
|
window.location.reload();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
content: `
|
|
|
|
<div class='alert alert-info'>
|
|
|
|
${__("You can override colors, fonts and layout of your currently selected theme with custom CSS declarations here.")}
|
|
|
|
</div>
|
2020-06-04 17:04:17 +00:00
|
|
|
|
2021-02-17 16:34:54 +00:00
|
|
|
${App.FormFields.hidden_tag('op', 'rpc')}
|
|
|
|
${App.FormFields.hidden_tag('method', 'setpref')}
|
|
|
|
${App.FormFields.hidden_tag('key', 'USER_STYLESHEET')}
|
2021-02-12 18:51:32 +00:00
|
|
|
|
|
|
|
<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>
|
2021-02-12 06:02:44 +00:00
|
|
|
</div>
|
2018-12-02 14:00:58 +00:00
|
|
|
|
2021-02-12 18:51:32 +00:00
|
|
|
<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();
|
2020-06-04 17:04:17 +00:00
|
|
|
|
2018-12-02 14:00:58 +00:00
|
|
|
});
|
2021-02-12 18:51:32 +00:00
|
|
|
},
|
|
|
|
confirmReset: function() {
|
|
|
|
if (confirm(__("Reset to defaults?"))) {
|
2021-02-19 10:44:56 +00:00
|
|
|
xhr.post("backend.php", {op: "pref-prefs", method: "resetconfig"}, (reply) => {
|
2021-02-12 18:51:32 +00:00
|
|
|
Helpers.Prefs.refresh();
|
2021-02-19 10:44:56 +00:00
|
|
|
Notify.info(reply);
|
2021-02-12 18:51:32 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
},
|
2021-02-27 10:05:02 +00:00
|
|
|
refresh: function() {
|
|
|
|
xhr.post("backend.php", { op: "pref-prefs" }, (reply) => {
|
|
|
|
dijit.byId('prefsTab').attr('content', reply);
|
|
|
|
Notify.close();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Plugins: {
|
2021-02-12 18:51:32 +00:00
|
|
|
clearPluginData: function(name) {
|
|
|
|
if (confirm(__("Clear stored data for this plugin?"))) {
|
|
|
|
Notify.progress("Loading, please wait...");
|
2018-12-03 09:26:49 +00:00
|
|
|
|
2021-02-27 10:05:02 +00:00
|
|
|
xhr.post("backend.php", {op: "pref-prefs", method: "clearPluginData", name: name}, () => {
|
2021-02-12 18:51:32 +00:00
|
|
|
Helpers.Prefs.refresh();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
},
|
2021-02-27 14:29:41 +00:00
|
|
|
checkForUpdate: function(name = null) {
|
|
|
|
Notify.progress("Checking for plugin updates...");
|
|
|
|
|
|
|
|
xhr.json("backend.php", {op: "pref-prefs", method: "checkForPluginUpdates", name: name}, (reply) => {
|
|
|
|
Notify.close();
|
|
|
|
|
|
|
|
if (reply) {
|
|
|
|
let plugins_with_updates = 0;
|
|
|
|
|
|
|
|
reply.forEach((p) => {
|
|
|
|
if (p.rv.o) {
|
|
|
|
const button = dijit.getEnclosingWidget(App.find(`*[data-update-btn-for-plugin="${p.plugin}"]`));
|
|
|
|
|
|
|
|
if (button) {
|
|
|
|
button.domNode.show();
|
|
|
|
++plugins_with_updates;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
if (plugins_with_updates > 0)
|
|
|
|
App.find(".update-all-plugins-btn").show();
|
|
|
|
} else {
|
|
|
|
Notify.error("Unable to check for plugin updates.");
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
update: function(name = null) {
|
2021-02-27 10:05:02 +00:00
|
|
|
const msg = name ? __("Update %p using git?").replace("%p", name) :
|
|
|
|
__("Update all local plugins using git?");
|
|
|
|
|
|
|
|
if (confirm(msg)) {
|
|
|
|
|
|
|
|
const dialog = new fox.SingleUseDialog({
|
|
|
|
title: __("Plugin Updater"),
|
2021-02-27 14:32:41 +00:00
|
|
|
execute: function() {
|
|
|
|
Helpers.Prefs.refresh();
|
|
|
|
},
|
2021-02-27 10:05:02 +00:00
|
|
|
content: `
|
|
|
|
<ul class="panel panel-scrollable update-results">
|
|
|
|
<li>${__("Loading, please wait...")}</li>
|
|
|
|
</ul>
|
|
|
|
|
|
|
|
<footer class="text-center">
|
|
|
|
${App.FormFields.submit_tag(__("Close this window"))}
|
|
|
|
</footer>
|
|
|
|
`,
|
|
|
|
});
|
|
|
|
|
|
|
|
const tmph = dojo.connect(dialog, 'onShow', function () {
|
|
|
|
dojo.disconnect(tmph);
|
|
|
|
|
|
|
|
xhr.json("backend.php", {op: "pref-prefs", method: "updateLocalPlugins", name: name}, (reply) => {
|
|
|
|
const container = dialog.domNode.querySelector(".update-results");
|
|
|
|
|
|
|
|
if (!reply) {
|
|
|
|
container.innerHTML = __("Operation failed: check event log.");
|
|
|
|
} else {
|
|
|
|
container.innerHTML = "";
|
|
|
|
|
|
|
|
reply.forEach((p) => {
|
|
|
|
container.innerHTML +=
|
|
|
|
`
|
|
|
|
<li><h3 style="margin-top: 0">${p.plugin}</h3>
|
|
|
|
${p.rv.e ? `<pre class="small text-error">${p.rv.e}</pre>` : ''}
|
|
|
|
${p.rv.o ? `<pre class="small text-success">${p.rv.o}</pre>` : ''}
|
|
|
|
<p class="small">
|
|
|
|
${p.rv.s ? __("Exited with RC: %d").replace("%d", p.rv.s) : __("OK")}
|
|
|
|
</p>
|
|
|
|
</li>
|
|
|
|
`
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
dialog.show();
|
|
|
|
}
|
2021-02-12 18:51:32 +00:00
|
|
|
},
|
2020-06-04 17:04:17 +00:00
|
|
|
},
|
|
|
|
OPML: {
|
|
|
|
import: function() {
|
2021-02-18 18:51:18 +00:00
|
|
|
const opml_file = App.byId("opml_file");
|
2020-06-04 17:04:17 +00:00
|
|
|
|
|
|
|
if (opml_file.value.length == 0) {
|
|
|
|
alert(__("Please choose an OPML file first."));
|
|
|
|
return false;
|
|
|
|
} else {
|
|
|
|
Notify.progress("Importing, please wait...", true);
|
2018-12-03 09:26:49 +00:00
|
|
|
|
2021-02-12 05:22:00 +00:00
|
|
|
const xhr = new XMLHttpRequest();
|
2018-12-03 09:26:49 +00:00
|
|
|
|
2021-02-12 05:22:00 +00:00
|
|
|
xhr.open( 'POST', 'backend.php', true );
|
|
|
|
xhr.onload = function () {
|
|
|
|
Notify.close();
|
|
|
|
|
2021-02-12 12:22:10 +00:00
|
|
|
const dialog = new fox.SingleUseDialog({
|
2021-02-12 05:22:00 +00:00
|
|
|
title: __("OPML Import"),
|
|
|
|
onCancel: function () {
|
2021-02-12 12:22:10 +00:00
|
|
|
this.execute();
|
2021-02-12 05:22:00 +00:00
|
|
|
},
|
|
|
|
execute: function () {
|
2021-02-12 12:22:10 +00:00
|
|
|
const tree = dijit.byId('feedTree');
|
|
|
|
|
|
|
|
if (tree) tree.reload();
|
2021-02-12 05:22:00 +00:00
|
|
|
},
|
|
|
|
content: `
|
|
|
|
<div class='alert alert-info'>
|
|
|
|
${__("If you have imported labels and/or filters, you might need to reload preferences to see your new data.")}
|
|
|
|
</div>
|
|
|
|
<div class='panel panel-scrollable'>
|
|
|
|
${xhr.responseText}
|
|
|
|
</div>
|
|
|
|
<footer class='text-center'>
|
|
|
|
<button dojoType='dijit.form.Button' type='submit' class='alt-primary'>
|
|
|
|
${__('Close this window')}
|
|
|
|
</button>
|
|
|
|
</footer>
|
|
|
|
`
|
|
|
|
});
|
|
|
|
|
|
|
|
dialog.show();
|
|
|
|
};
|
|
|
|
|
2021-02-18 18:51:18 +00:00
|
|
|
xhr.send(new FormData(App.byId("opml_import_form")));
|
2021-02-12 05:22:00 +00:00
|
|
|
|
|
|
|
return false;
|
2020-06-04 17:04:17 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
export: function() {
|
|
|
|
console.log("export");
|
|
|
|
window.open("backend.php?op=opml&method=export&" + dojo.formToQuery("opmlExportForm"));
|
|
|
|
},
|
2021-02-21 15:04:44 +00:00
|
|
|
publish: function() {
|
|
|
|
Notify.progress("Loading, please wait...", true);
|
|
|
|
|
|
|
|
xhr.json("backend.php", {op: "pref-feeds", method: "getOPMLKey"}, (reply) => {
|
|
|
|
try {
|
|
|
|
const dialog = new fox.SingleUseDialog({
|
|
|
|
title: __("Public OPML URL"),
|
|
|
|
regenOPMLKey: function() {
|
|
|
|
if (confirm(__("Replace current OPML publishing address with a new one?"))) {
|
|
|
|
Notify.progress("Trying to change address...", true);
|
|
|
|
|
|
|
|
xhr.json("backend.php", {op: "pref-feeds", method: "regenOPMLKey"}, (reply) => {
|
|
|
|
if (reply) {
|
|
|
|
const new_link = reply.link;
|
|
|
|
const target = this.domNode.querySelector('.generated_url');
|
|
|
|
|
|
|
|
if (new_link && target) {
|
|
|
|
target.href = new_link;
|
|
|
|
target.innerHTML = new_link;
|
|
|
|
|
|
|
|
Notify.close();
|
|
|
|
|
|
|
|
} else {
|
|
|
|
Notify.error("Could not change feed URL.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
},
|
|
|
|
content: `
|
|
|
|
<header>${__("Your Public OPML URL is:")}</header>
|
|
|
|
<section>
|
|
|
|
<div class='panel text-center'>
|
|
|
|
<a class='generated_url' href="${App.escapeHtml(reply.link)}" target='_blank'>${App.escapeHtml(reply.link)}</a>
|
|
|
|
</div>
|
|
|
|
</section>
|
|
|
|
<footer class='text-center'>
|
|
|
|
<button dojoType='dijit.form.Button' onclick="return App.dialogOf(this).regenOPMLKey()">
|
|
|
|
${__('Generate new URL')}
|
|
|
|
</button>
|
|
|
|
<button dojoType='dijit.form.Button' type='submit' class='alt-primary'>
|
|
|
|
${__('Close this window')}
|
|
|
|
</button>
|
|
|
|
</footer>
|
|
|
|
`
|
|
|
|
});
|
|
|
|
|
|
|
|
dialog.show();
|
|
|
|
|
|
|
|
Notify.close();
|
|
|
|
|
|
|
|
} catch (e) {
|
|
|
|
App.Error.report(e);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
2020-06-04 17:04:17 +00:00
|
|
|
}
|
|
|
|
};
|