diff options
| author | tamaina <tamaina@hotmail.co.jp> | 2020-02-12 00:38:29 +0900 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-02-12 00:38:29 +0900 |
| commit | 4ab38b7894f725d17012a6fdf6552a5c075e5cd9 (patch) | |
| tree | b499048eb288b87b608489bc7dd9cd1716aa1cfc /src/client/components | |
| parent | Update app.vue (diff) | |
| download | sharkey-4ab38b7894f725d17012a6fdf6552a5c075e5cd9.tar.gz sharkey-4ab38b7894f725d17012a6fdf6552a5c075e5cd9.tar.bz2 sharkey-4ab38b7894f725d17012a6fdf6552a5c075e5cd9.zip | |
タイムラインを放置すると先頭の投稿が見えなくなるのを修正 Fix #5903 (#5913)
* seqent fix
* comment
* :v:
Diffstat (limited to 'src/client/components')
| -rw-r--r-- | src/client/components/sequential-entrance.vue | 25 |
1 files changed, 16 insertions, 9 deletions
diff --git a/src/client/components/sequential-entrance.vue b/src/client/components/sequential-entrance.vue index a09d67f1c7..c909b51727 100644 --- a/src/client/components/sequential-entrance.vue +++ b/src/client/components/sequential-entrance.vue @@ -40,22 +40,29 @@ export default Vue.extend({ i: 0, methods: { beforeEnter(el) { + if (document.hidden) return; + el.style.opacity = 0; el.style.transform = this.direction === 'down' ? 'translateY(-64px)' : 'translateY(64px)'; - let index = this.$options.i; - const delay = this.delay * index; + const delay = this.delay * this.$options.i; el.style.transition = [getComputedStyle(el).transition, `transform 0.7s cubic-bezier(0.23, 1, 0.32, 1) ${delay}ms`, `opacity 0.7s cubic-bezier(0.23, 1, 0.32, 1) ${delay}ms`].filter(x => x != '').join(','); this.$options.i++; - }, - enter(el, done) { + setTimeout(() => { + el.style.transition = ''; + this.$options.i--; + }, delay + 710); + }, + enter(el) { + if (document.hidden) { + el.style.opacity = 1; + el.style.transform = 'translateY(0px)'; + return; + }; + + setTimeout(() => { // 必要 el.style.opacity = 1; el.style.transform = 'translateY(0px)'; - el.addEventListener('transitionend', () => { - el.style.transition = ''; - this.$options.i--; - done(); - }, { once: true }); }); }, leave(el) { |