owntone-server/web-src/src/templates/ContentWithHeading.vue

106 lines
2.7 KiB
Vue
Raw Normal View History

<template>
<section class="section">
<div class="container">
<div class="columns is-centered">
<div class="column is-four-fifths">
<section v-if="$slots['options']">
<div ref="options_ref" style="height: 1px" />
<slot name="options" />
<nav
class="buttons is-centered"
style="margin-bottom: 6px; margin-top: 16px"
>
<a
v-if="!options_visible"
class="button is-small is-white"
@click="scroll_to_top"
>
<span class="icon is-small"
><mdicon name="chevron-down" size="16"
/></span>
2022-05-20 07:44:22 -04:00
</a>
<a
v-else
class="button is-small is-white"
@click="scroll_to_content"
>
<span class="icon is-small"
><mdicon name="chevron-up" size="16"
/></span>
2022-05-20 07:44:22 -04:00
</a>
</nav>
</section>
<div :class="{ 'fd-content-with-option': $slots['options'] }">
<nav id="top" class="level">
2020-10-07 03:03:02 -04:00
<!-- Left side -->
<div class="level-left">
<div class="level-item has-text-centered-mobile">
<div>
<slot name="heading-left" />
2020-10-07 03:03:02 -04:00
</div>
</div>
</div>
2020-10-07 03:03:02 -04:00
<!-- Right side -->
<div class="level-right has-text-centered-mobile">
<slot name="heading-right" />
2020-10-07 03:03:02 -04:00
</div>
</nav>
<slot name="content" />
<div style="margin-top: 16px">
<slot name="footer" />
</div>
</div>
</div>
</div>
</div>
</section>
</template>
<script>
export default {
name: 'ContentWithHeading',
data() {
2020-10-07 03:03:02 -04:00
return {
2022-02-19 00:18:01 -05:00
options_visible: false
}
},
mounted() {
if (this.$slots['options']) {
this.observer = new IntersectionObserver(this.onElementObserved, {
rootMargin: '-82px 0px 0px 0px',
threshold: 1.0
})
2022-02-19 00:18:01 -05:00
this.observer.observe(this.$refs.options_ref)
2020-10-07 03:03:02 -04:00
}
},
methods: {
2022-02-19 00:18:01 -05:00
onElementObserved(entries) {
entries.forEach(({ target, isIntersecting }) => {
2022-02-19 00:18:01 -05:00
this.options_visible = isIntersecting
})
2022-02-19 00:18:01 -05:00
},
scroll_to_top() {
window.scrollTo({ top: 0, behavior: 'smooth' })
2020-10-07 03:03:02 -04:00
},
scroll_to_content() {
2020-10-07 03:03:02 -04:00
if (this.$route.meta.has_tabs) {
this.$scrollTo('#top', { offset: -140 })
} else {
this.$scrollTo('#top', { offset: -110 })
2020-10-07 03:03:02 -04:00
}
},
visibilityChanged(isVisible) {
2020-10-07 03:03:02 -04:00
this.options_visible = isVisible
}
}
}
</script>
<style></style>