fix ask every time not being respected for no preview option

This commit is contained in:
Bruno Windels 2020-12-07 17:51:17 +01:00
parent 9712ecf974
commit 9395d7f3f5
2 changed files with 12 additions and 7 deletions

View file

@ -25,7 +25,7 @@ export class ServerConsentView extends TemplateView {
onClick: () => vm.setShowServers()}, "use another server");
const continueWithoutPreview = t.button({
className: "text",
onClick: () => vm.continueWithoutConsent()
onClick: () => vm.continueWithoutConsent(this._askEveryTimeChecked)
}, "continue without a preview");
return t.div({className: "ServerConsentView"}, [
t.p([
@ -48,7 +48,7 @@ export class ServerConsentView extends TemplateView {
continueWithoutPreview,
"."
]),
t.form({action: "#", onSubmit: evt => this._onSubmit(evt)}, [
t.form({action: "#", id: "serverConsentForm", onSubmit: evt => this._onSubmit(evt)}, [
t.mapView(vm => vm.showSelectServer, show => show ? new ServerOptions(vm) : null),
t.div({className: "actions"}, [
t.label([t.input({type: "checkbox", name: "askEveryTime"}), "Ask every time"]),
@ -60,8 +60,13 @@ export class ServerConsentView extends TemplateView {
_onSubmit(evt) {
evt.preventDefault();
const {askEveryTime} = evt.target.elements;
this.value.continueWithSelection(askEveryTime.checked);
this.value.continueWithSelection(this._askEveryTimeChecked);
}
get _askEveryTimeChecked() {
const form = document.getElementById("serverConsentForm");
const {askEveryTime} = form.elements;
return askEveryTime.checked;
}
}

View file

@ -64,8 +64,8 @@ export class ServerConsentViewModel extends ViewModel {
this.done();
}
continueWithoutConsent() {
this.preferences.setHomeservers([]);
continueWithoutConsent(askEveryTime) {
this.preferences.setHomeservers([], !askEveryTime);
this.done();
}
}