2018-08-11 01:47:10 -04:00
|
|
|
<template>
|
2023-06-23 16:23:32 -04:00
|
|
|
<section class="section">
|
2018-08-11 01:47:10 -04:00
|
|
|
<div class="container">
|
|
|
|
<div class="columns is-centered">
|
|
|
|
<div class="column is-four-fifths">
|
2020-10-06 11:15:02 -04:00
|
|
|
<section v-if="$slots['options']">
|
2022-02-19 00:39:14 -05:00
|
|
|
<div ref="options_ref" style="height: 1px" />
|
|
|
|
<slot name="options" />
|
2022-05-29 12:49:00 -04:00
|
|
|
<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"
|
|
|
|
>
|
2023-06-30 15:41:40 -04:00
|
|
|
<mdicon class="icon is-small" name="chevron-down" size="16" />
|
2022-05-20 07:44:22 -04:00
|
|
|
</a>
|
2022-05-29 12:49:00 -04:00
|
|
|
<a
|
|
|
|
v-else
|
|
|
|
class="button is-small is-white"
|
|
|
|
@click="scroll_to_content"
|
|
|
|
>
|
2023-06-30 15:41:40 -04:00
|
|
|
<mdicon class="icon is-small" name="chevron-up" size="16" />
|
2022-05-20 07:44:22 -04:00
|
|
|
</a>
|
2020-10-06 11:15:02 -04:00
|
|
|
</nav>
|
|
|
|
</section>
|
2022-02-19 00:39:14 -05:00
|
|
|
<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>
|
2022-02-19 00:39:14 -05:00
|
|
|
<slot name="heading-left" />
|
2020-10-07 03:03:02 -04:00
|
|
|
</div>
|
2018-08-11 01:47:10 -04:00
|
|
|
</div>
|
|
|
|
</div>
|
2020-10-07 03:03:02 -04:00
|
|
|
<!-- Right side -->
|
|
|
|
<div class="level-right has-text-centered-mobile">
|
2022-02-19 00:39:14 -05:00
|
|
|
<slot name="heading-right" />
|
2020-10-07 03:03:02 -04:00
|
|
|
</div>
|
|
|
|
</nav>
|
2022-02-19 00:39:14 -05:00
|
|
|
<slot name="content" />
|
|
|
|
<div style="margin-top: 16px">
|
|
|
|
<slot name="footer" />
|
2018-08-11 01:47:10 -04:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</section>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
2020-10-06 11:15:02 -04:00
|
|
|
export default {
|
|
|
|
name: 'ContentWithHeading',
|
|
|
|
|
2022-02-19 00:39:14 -05:00
|
|
|
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']) {
|
2022-02-19 00:39:14 -05:00
|
|
|
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
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2020-10-06 11:15:02 -04:00
|
|
|
methods: {
|
2022-02-19 00:18:01 -05:00
|
|
|
onElementObserved(entries) {
|
2022-02-19 00:39:14 -05:00
|
|
|
entries.forEach(({ target, isIntersecting }) => {
|
2022-02-19 00:18:01 -05:00
|
|
|
this.options_visible = isIntersecting
|
2022-02-19 00:39:14 -05:00
|
|
|
})
|
2022-02-19 00:18:01 -05:00
|
|
|
},
|
|
|
|
|
2023-06-07 15:25:54 -04:00
|
|
|
scroll_to_top() {
|
2020-10-06 11:15:02 -04:00
|
|
|
window.scrollTo({ top: 0, behavior: 'smooth' })
|
2020-10-07 03:03:02 -04:00
|
|
|
},
|
|
|
|
|
2023-06-07 15:25:54 -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 {
|
2022-02-19 01:47:54 -05:00
|
|
|
this.$scrollTo('#top', { offset: -110 })
|
2020-10-07 03:03:02 -04:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2023-06-07 15:25:54 -04:00
|
|
|
visibilityChanged(isVisible) {
|
2020-10-07 03:03:02 -04:00
|
|
|
this.options_visible = isVisible
|
2020-10-06 11:15:02 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-08-11 01:47:10 -04:00
|
|
|
</script>
|
|
|
|
|
2022-02-19 00:39:14 -05:00
|
|
|
<style></style>
|