trilium/src/public/javascripts/setup.js

141 lines
3.9 KiB
JavaScript
Raw Normal View History

2018-07-22 20:49:59 +08:00
import utils from "./services/utils.js";
2018-04-03 10:33:54 +08:00
function SetupModel() {
if (syncInProgress) {
setInterval(checkOutstandingSyncs, 1000);
}
const serverAddress = location.protocol + '//' + location.host;
$("#current-host").html(serverAddress);
this.step = ko.observable(syncInProgress ? "sync-in-progress" : "setup-type");
this.setupType = ko.observable();
this.setupNewDocument = ko.observable(false);
this.setupSyncFromDesktop = ko.observable(false);
this.setupSyncFromServer = ko.observable(false);
this.username = ko.observable();
this.password1 = ko.observable();
this.password2 = ko.observable();
2018-07-25 14:30:41 +08:00
this.syncServerHost = ko.observable();
this.syncProxy = ko.observable();
2018-07-22 20:49:59 +08:00
this.instanceType = utils.isElectron() ? "desktop" : "server";
this.setupTypeSelected = this.getSetupType = () =>
this.setupNewDocument()
|| this.setupSyncFromDesktop()
|| this.setupSyncFromServer();
this.selectSetupType = () => {
this.step(this.getSetupType());
this.setupType(this.getSetupType());
};
2018-07-22 20:49:59 +08:00
this.back = () => {
this.step("setup-type");
this.setupNewDocument(false);
this.setupSyncFromServer(false);
this.setupSyncFromDesktop(false);
};
this.finish = async () => {
if (this.setupNewDocument()) {
const username = this.username();
const password1 = this.password1();
const password2 = this.password2();
if (!username) {
showAlert("Username can't be empty");
return;
}
if (!password1) {
showAlert("Password can't be empty");
return;
}
if (password1 !== password2) {
showAlert("Both password fields need be identical.");
return;
}
// not using server.js because it loads too many dependencies
$.post('/api/setup/new-document', {
username: username,
password: password1
}).then(() => {
window.location.replace("/");
});
}
2018-07-22 20:49:59 +08:00
else if (this.setupSyncFromServer()) {
2018-07-25 14:30:41 +08:00
const syncServerHost = this.syncServerHost();
const syncProxy = this.syncProxy();
2018-07-22 20:49:59 +08:00
const username = this.username();
const password = this.password1();
2018-07-25 14:30:41 +08:00
if (!syncServerHost) {
2018-07-22 20:49:59 +08:00
showAlert("Trilium server address can't be empty");
return;
}
if (!username) {
showAlert("Username can't be empty");
return;
}
if (!password) {
showAlert("Password can't be empty");
return;
}
// not using server.js because it loads too many dependencies
const resp = await $.post('/api/setup/sync-from-server', {
2018-07-25 14:30:41 +08:00
syncServerHost: syncServerHost,
syncProxy: syncProxy,
username: username,
password: password
});
if (resp.result === 'success') {
this.step('sync-in-progress');
setInterval(checkOutstandingSyncs, 1000);
hideAlert();
}
else {
showAlert('Sync setup failed: ' + resp.error);
}
2018-07-22 20:49:59 +08:00
}
};
}
2017-12-04 11:29:23 +08:00
async function checkOutstandingSyncs() {
const { stats, initialized } = await $.get('/api/sync/stats');
if (initialized) {
window.location.replace("/");
}
const totalOutstandingSyncs = stats.outstandingPushes + stats.outstandingPulls;
$("#outstanding-syncs").html(totalOutstandingSyncs);
}
2017-12-04 11:29:23 +08:00
function showAlert(message) {
$("#alert").html(message);
$("#alert").show();
}
function hideAlert() {
$("#alert").hide();
}
2018-07-22 20:49:59 +08:00
ko.applyBindings(new SetupModel(), document.getElementById('setup-dialog'));
$("#setup-dialog").show();