aboutsummaryrefslogtreecommitdiff
path: root/src/components/mobile_post_status_modal
diff options
context:
space:
mode:
authoreugenijm <eugenijm@protonmail.com>2019-04-25 19:32:21 +0300
committereugenijm <eugenijm@protonmail.com>2019-04-29 21:32:29 +0300
commitae1496cfb4b0a432d9a30370df6825e0fc483eb8 (patch)
treeecab9d121e5eaa1202580c52201c24cb71101a63 /src/components/mobile_post_status_modal
parentc8f967d5c0424c7dd504ad4afeaefb7c745eed31 (diff)
Make floating post button configurable
Diffstat (limited to 'src/components/mobile_post_status_modal')
-rw-r--r--src/components/mobile_post_status_modal/mobile_post_status_modal.js33
1 files changed, 29 insertions, 4 deletions
diff --git a/src/components/mobile_post_status_modal/mobile_post_status_modal.js b/src/components/mobile_post_status_modal/mobile_post_status_modal.js
index 2f24dd08..d9806ad9 100644
--- a/src/components/mobile_post_status_modal/mobile_post_status_modal.js
+++ b/src/components/mobile_post_status_modal/mobile_post_status_modal.js
@@ -1,5 +1,5 @@
import PostStatusForm from '../post_status_form/post_status_form.vue'
-import { throttle } from 'lodash'
+import { throttle, debounce } from 'lodash'
const MobilePostStatusModal = {
components: {
@@ -16,11 +16,17 @@ const MobilePostStatusModal = {
}
},
created () {
- window.addEventListener('scroll', this.handleScroll)
+ if (this.autohideFloatingPostButton) {
+ window.addEventListener('scroll', this.handleScroll)
+ window.addEventListener('scroll', this.handleScrollDown)
+ }
window.addEventListener('resize', this.handleOSK)
},
destroyed () {
- window.removeEventListener('scroll', this.handleScroll)
+ if (this.autohideFloatingPostButton) {
+ window.removeEventListener('scroll', this.handleScroll)
+ window.removeEventListener('scroll', this.handleScrollDown)
+ }
window.removeEventListener('resize', this.handleOSK)
},
computed: {
@@ -28,7 +34,21 @@ const MobilePostStatusModal = {
return this.$store.state.users.currentUser
},
isHidden () {
- return this.hidden || this.inputActive
+ return this.autohideFloatingPostButton && (this.hidden || this.inputActive)
+ },
+ autohideFloatingPostButton () {
+ return !!this.$store.state.config.autohideFloatingPostButton
+ }
+ },
+ watch: {
+ autohideFloatingPostButton: function (isEnabled) {
+ if (isEnabled) {
+ window.addEventListener('scroll', this.handleScroll)
+ window.addEventListener('scroll', this.handleScrollDown)
+ } else {
+ window.removeEventListener('scroll', this.handleScroll)
+ window.removeEventListener('scroll', this.handleScrollDown)
+ }
}
},
methods: {
@@ -84,6 +104,11 @@ const MobilePostStatusModal = {
this.oldScrollPos = window.scrollY
this.scrollingDown = scrollingDown
+ }, 100),
+ handleScrollDown: debounce(function () {
+ if (this.scrollingDown) {
+ this.hidden = false
+ }
}, 100)
}
}