aboutsummaryrefslogtreecommitdiff
path: root/viewer/src/views/MainLayout.vue
diff options
context:
space:
mode:
Diffstat (limited to 'viewer/src/views/MainLayout.vue')
-rw-r--r--viewer/src/views/MainLayout.vue20
1 files changed, 16 insertions, 4 deletions
diff --git a/viewer/src/views/MainLayout.vue b/viewer/src/views/MainLayout.vue
index 6ef9a3b..9cd518b 100644
--- a/viewer/src/views/MainLayout.vue
+++ b/viewer/src/views/MainLayout.vue
@@ -22,7 +22,7 @@
22 <ld-title :gallery-title="$galleryStore.galleryTitle" :current-item="$galleryStore.currentItem" /> 22 <ld-title :gallery-title="$galleryStore.galleryTitle" :current-item="$galleryStore.currentItem" />
23 <panel-top v-if="isReady" class="layout layout-top" /> 23 <panel-top v-if="isReady" class="layout layout-top" />
24 <panel-left v-if="isReady" class="layout layout-left" /> 24 <panel-left v-if="isReady" class="layout layout-left" />
25 <router-view v-if="!isLoading" ref="content" class="layout layout-content scrollbar" /> 25 <router-view v-if="!isLoading" ref="content" class="layout layout-content scrollbar" tabindex="01" />
26 <b-loading :active="isLoading" is-full-page /> 26 <b-loading :active="isLoading" is-full-page />
27 <ld-key-press :keycode="27" @action="$uiStore.toggleFullscreen(false)" /> 27 <ld-key-press :keycode="27" @action="$uiStore.toggleFullscreen(false)" />
28 </div> 28 </div>
@@ -43,6 +43,10 @@ export default class MainLayout extends Vue {
43 isLoading: boolean = true; 43 isLoading: boolean = true;
44 scrollPositions: ScrollPosition = {}; 44 scrollPositions: ScrollPosition = {};
45 45
46 get contentDiv() {
47 return this.content.$el as HTMLDivElement;
48 }
49
46 mounted() { 50 mounted() {
47 history.replaceState({ ldgallery: "ENTRYPOINT" }, ""); 51 history.replaceState({ ldgallery: "ENTRYPOINT" }, "");
48 this.fetchGalleryItems(); 52 this.fetchGalleryItems();
@@ -53,11 +57,15 @@ export default class MainLayout extends Vue {
53 document.body.removeEventListener("fullscreenchange", this.onFullscreenChange); 57 document.body.removeEventListener("fullscreenchange", this.onFullscreenChange);
54 } 58 }
55 59
60 moveFocusToContentDiv() {
61 setTimeout(() => this.contentDiv.focus());
62 }
63
56 @Watch("$route") 64 @Watch("$route")
57 routeChanged(newRoute: Route, oldRoute: Route) { 65 routeChanged(newRoute: Route, oldRoute: Route) {
58 const el = this.content.$el; 66 this.scrollPositions[oldRoute.path] = this.contentDiv.scrollTop;
59 this.scrollPositions[oldRoute.path] = el.scrollTop; 67 this.$nextTick(() => (this.contentDiv.scrollTop = this.scrollPositions[newRoute.path]));
60 this.$nextTick(() => (el.scrollTop = this.scrollPositions[newRoute.path])); 68 this.moveFocusToContentDiv();
61 } 69 }
62 70
63 fetchGalleryItems() { 71 fetchGalleryItems() {
@@ -66,6 +74,7 @@ export default class MainLayout extends Vue {
66 .fetchConfig() 74 .fetchConfig()
67 .then(this.$uiStore.initFromConfig) 75 .then(this.$uiStore.initFromConfig)
68 .then(this.$galleryStore.fetchGalleryItems) 76 .then(this.$galleryStore.fetchGalleryItems)
77 .then(this.moveFocusToContentDiv)
69 .finally(() => (this.isLoading = false)) 78 .finally(() => (this.isLoading = false))
70 .catch(this.displayError); 79 .catch(this.displayError);
71 } 80 }
@@ -130,6 +139,9 @@ html {
130 left: var(--layout-left); 139 left: var(--layout-left);
131 z-index: 3; 140 z-index: 3;
132 overflow-x: hidden; 141 overflow-x: hidden;
142 &:focus {
143 outline: none;
144 }
133 } 145 }
134} 146}
135.fullscreen { 147.fullscreen {