add lightbox navigation and basic view & view model

This commit is contained in:
Bruno Windels 2020-10-28 17:42:18 +01:00
parent fe6e4464fd
commit 68a0dd30ca
7 changed files with 91 additions and 0 deletions

View File

@ -36,6 +36,8 @@ function allowsChild(parent, child) {
case "rooms": case "rooms":
// downside of the approach: both of these will control which tile is selected // downside of the approach: both of these will control which tile is selected
return type === "room" || type === "empty-grid-tile"; return type === "room" || type === "empty-grid-tile";
case "room":
return type === "lightbox";
default: default:
return false; return false;
} }

View File

@ -17,6 +17,7 @@ limitations under the License.
import {LeftPanelViewModel} from "./leftpanel/LeftPanelViewModel.js"; import {LeftPanelViewModel} from "./leftpanel/LeftPanelViewModel.js";
import {RoomViewModel} from "./room/RoomViewModel.js"; import {RoomViewModel} from "./room/RoomViewModel.js";
import {LightboxViewModel} from "./room/LightboxViewModel.js";
import {SessionStatusViewModel} from "./SessionStatusViewModel.js"; import {SessionStatusViewModel} from "./SessionStatusViewModel.js";
import {RoomGridViewModel} from "./RoomGridViewModel.js"; import {RoomGridViewModel} from "./RoomGridViewModel.js";
import {SettingsViewModel} from "./settings/SettingsViewModel.js"; import {SettingsViewModel} from "./settings/SettingsViewModel.js";
@ -67,6 +68,12 @@ export class SessionViewModel extends ViewModel {
this._updateSettings(settingsOpen); this._updateSettings(settingsOpen);
})); }));
this._updateSettings(settings.get()); this._updateSettings(settings.get());
const lightbox = this.navigation.observe("lightbox");
this.track(lightbox.subscribe(eventId => {
this._updateLightbox(eventId);
}));
this._updateLightbox(lightbox.get());
} }
get id() { get id() {
@ -194,4 +201,18 @@ export class SessionViewModel extends ViewModel {
} }
this.emitChange("activeSection"); this.emitChange("activeSection");
} }
_updateLightbox(eventId) {
if (this._lightboxViewModel) {
this._lightboxViewModel = this.disposeTracked(this._lightboxViewModel);
}
if (eventId) {
this._lightboxViewModel = this.track(new LightboxViewModel(this.childOptions({eventId})));
}
this.emitChange("lightboxViewModel");
}
get lightboxViewModel() {
return this._lightboxViewModel;
}
} }

View File

@ -0,0 +1,33 @@
/*
Copyright 2020 The Matrix.org Foundation C.I.C.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
import {ViewModel} from "../../ViewModel.js";
export class LightboxViewModel extends ViewModel {
constructor(options) {
super(options);
this._eventId = options.eventId;
this._closeUrl = this.urlCreator.urlUntilSegment("room");
}
get eventId() {
return this._eventId;
}
get closeUrl() {
return this._closeUrl;
}
}

View File

@ -27,6 +27,11 @@ export class ImageTile extends MessageTile {
this._decryptedImage = null; this._decryptedImage = null;
this._error = null; this._error = null;
this.load(); this.load();
this._lightboxUrl = this.urlCreator.urlForSegments([
// ensure the right room is active if in grid view
this.navigation.segment("room", this._room.id),
this.navigation.segment("lightbox", this._entry.id)
]);
} }
async _loadEncryptedFile(file) { async _loadEncryptedFile(file) {
@ -54,6 +59,10 @@ export class ImageTile extends MessageTile {
} }
} }
get lightboxUrl() {
return this._lightboxUrl;
}
get thumbnailUrl() { get thumbnailUrl() {
if (this._decryptedThumbail) { if (this._decryptedThumbail) {
return this._decryptedThumbail.url; return this._decryptedThumbail.url;

View File

@ -17,6 +17,7 @@ limitations under the License.
import {LeftPanelView} from "./leftpanel/LeftPanelView.js"; import {LeftPanelView} from "./leftpanel/LeftPanelView.js";
import {RoomView} from "./room/RoomView.js"; import {RoomView} from "./room/RoomView.js";
import {LightboxView} from "./room/LightboxView.js";
import {TemplateView} from "../general/TemplateView.js"; import {TemplateView} from "../general/TemplateView.js";
import {StaticView} from "../general/StaticView.js"; import {StaticView} from "../general/StaticView.js";
import {SessionStatusView} from "./SessionStatusView.js"; import {SessionStatusView} from "./SessionStatusView.js";
@ -45,6 +46,7 @@ export class SessionView extends TemplateView {
return new RoomView(vm.currentRoomViewModel); return new RoomView(vm.currentRoomViewModel);
} }
}), }),
t.mapView(vm => vm.lightboxViewModel, lightboxViewModel => lightboxViewModel ? new LightboxView(lightboxViewModel) : null)
]); ]);
} }
} }

View File

@ -0,0 +1,23 @@
/*
Copyright 2020 The Matrix.org Foundation C.I.C.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
import {TemplateView} from "../../general/TemplateView.js";
export class LightboxView extends TemplateView {
render(t, vm) {
return t.div({className: "lightbox"}, [vm.eventId, t.br(), t.a({href: vm.closeUrl}, "close")]);
}
}

View File

@ -31,6 +31,7 @@ export class ImageView extends TemplateView {
title: vm => vm.label, title: vm => vm.label,
}); });
const linkContainer = t.a({ const linkContainer = t.a({
href: vm.lightboxUrl,
style: `padding-top: ${heightRatioPercent}%; width: ${vm.thumbnailWidth}px;` style: `padding-top: ${heightRatioPercent}%; width: ${vm.thumbnailWidth}px;`
}, [ }, [
image, image,