Add event listener for focus so elements hidden behind the footer will scroll to the center of the screen
This commit is contained in:
parent
ffb05bbc74
commit
6fbb49d74e
11
js/index.js
11
js/index.js
@ -1,5 +1,7 @@
|
||||
import 'svg-innerhtml'
|
||||
import 'babel-polyfill'
|
||||
import ally from 'ally.js'
|
||||
|
||||
|
||||
import classes from '../styles/atat.scss'
|
||||
import Vue from 'vue/dist/vue'
|
||||
@ -28,6 +30,7 @@ import MembersList from './components/members_list'
|
||||
import LocalDatetime from './components/local_datetime'
|
||||
import RequestsList from './components/requests_list'
|
||||
import ConfirmationPopover from './components/confirmation_popover'
|
||||
import {isNotInVerticalViewport} from './lib/viewport'
|
||||
|
||||
Vue.config.productionTip = false
|
||||
|
||||
@ -77,6 +80,14 @@ const app = new Vue({
|
||||
const modal = modalOpen.getAttribute("data-modal")
|
||||
this.openModal(modal)
|
||||
}
|
||||
|
||||
ally.query.focusable().forEach( function(el) {
|
||||
el.addEventListener('focus', function(){
|
||||
if (isNotInVerticalViewport(el)) {
|
||||
el.scrollIntoView({block: 'center'})
|
||||
}
|
||||
})
|
||||
})
|
||||
},
|
||||
delimiters: ['!{', '}']
|
||||
})
|
||||
|
15
js/lib/viewport.js
Normal file
15
js/lib/viewport.js
Normal file
@ -0,0 +1,15 @@
|
||||
export const isNotInVerticalViewport = (el) => {
|
||||
const bounds = el.getBoundingClientRect()
|
||||
|
||||
if (bounds.top < 0) {
|
||||
return true
|
||||
}
|
||||
|
||||
if (bounds.bottom > ((window.innerHeight - 50))) {
|
||||
// 50 is a magic number to offset for the sticky footer
|
||||
// see variables.scss for $footer-height
|
||||
return true
|
||||
}
|
||||
|
||||
return false
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user