✌️
This commit is contained in:
parent
dd0d86cbb6
commit
9923cfaf50
4 changed files with 28 additions and 8 deletions
|
@ -90,6 +90,13 @@ export default defineComponent({
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
function onBeforeLeave(el: HTMLElement) {
|
||||||
|
el.style.top = `${el.offsetTop}px`;
|
||||||
|
}
|
||||||
|
function onLeaveCanceled(el: HTMLElement) {
|
||||||
|
el.style.top = '';
|
||||||
|
}
|
||||||
|
|
||||||
return () => h(
|
return () => h(
|
||||||
defaultStore.state.animation ? TransitionGroup : 'div',
|
defaultStore.state.animation ? TransitionGroup : 'div',
|
||||||
defaultStore.state.animation ? {
|
defaultStore.state.animation ? {
|
||||||
|
@ -101,6 +108,8 @@ export default defineComponent({
|
||||||
tag: 'div',
|
tag: 'div',
|
||||||
'data-direction': props.direction,
|
'data-direction': props.direction,
|
||||||
'data-reversed': props.reversed ? 'true' : 'false',
|
'data-reversed': props.reversed ? 'true' : 'false',
|
||||||
|
onBeforeLeave,
|
||||||
|
onLeaveCanceled,
|
||||||
} : {
|
} : {
|
||||||
class: {
|
class: {
|
||||||
'sqadhkmv': true,
|
'sqadhkmv': true,
|
||||||
|
@ -123,17 +132,25 @@ export default defineComponent({
|
||||||
> *:not(:last-child) {
|
> *:not(:last-child) {
|
||||||
margin-bottom: var(--margin);
|
margin-bottom: var(--margin);
|
||||||
}
|
}
|
||||||
|
|
||||||
&:not(.deny-move-transition) > * {
|
> .list-move {
|
||||||
transition: transform 0.7s cubic-bezier(0.23, 1, 0.32, 1);
|
transition: transform 0.7s cubic-bezier(0.23, 1, 0.32, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
&.deny-move-transition > .list-move {
|
||||||
|
transition: none !important;
|
||||||
|
}
|
||||||
|
|
||||||
> .list-leave-active,
|
> .list-leave-active,
|
||||||
> .list-enter-active {
|
> .list-enter-active {
|
||||||
transition: transform 0.7s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.7s cubic-bezier(0.23, 1, 0.32, 1);
|
transition: transform 0.7s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.7s cubic-bezier(0.23, 1, 0.32, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
> .list-leave-from,
|
||||||
|
> .list-leave-to,
|
||||||
> .list-leave-active {
|
> .list-leave-active {
|
||||||
position: absolute;
|
transition: transform 0.7s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.7s cubic-bezier(0.23, 1, 0.32, 1);
|
||||||
|
position: absolute !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
&[data-direction="up"] {
|
&[data-direction="up"] {
|
||||||
|
|
|
@ -66,6 +66,7 @@ function del() {
|
||||||
position: relative;
|
position: relative;
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
display: flex;
|
display: flex;
|
||||||
|
width: 100%;
|
||||||
|
|
||||||
> .avatar {
|
> .avatar {
|
||||||
position: sticky;
|
position: sticky;
|
||||||
|
@ -249,6 +250,7 @@ function del() {
|
||||||
&.isMe {
|
&.isMe {
|
||||||
flex-direction: row-reverse;
|
flex-direction: row-reverse;
|
||||||
padding-right: var(--margin);
|
padding-right: var(--margin);
|
||||||
|
right: var(--margin); // 削除時にposition: absoluteになったときに使う
|
||||||
|
|
||||||
> .content {
|
> .content {
|
||||||
padding-right: 16px;
|
padding-right: 16px;
|
||||||
|
|
|
@ -31,7 +31,7 @@
|
||||||
<MkEllipsis/>
|
<MkEllipsis/>
|
||||||
</div>
|
</div>
|
||||||
<transition :name="animation ? 'fade' : ''">
|
<transition :name="animation ? 'fade' : ''">
|
||||||
<div class="new-message" v-if="showIndicator">
|
<div class="new-message" v-show="showIndicator">
|
||||||
<button class="_buttonPrimary" @click="onIndicatorClick"><i class="fas fa-fw fa-arrow-circle-down"></i>{{ i18n.locale.newMessageExists }}</button>
|
<button class="_buttonPrimary" @click="onIndicatorClick"><i class="fas fa-fw fa-arrow-circle-down"></i>{{ i18n.locale.newMessageExists }}</button>
|
||||||
</div>
|
</div>
|
||||||
</transition>
|
</transition>
|
||||||
|
@ -324,14 +324,15 @@ defineExpose({
|
||||||
position: sticky;
|
position: sticky;
|
||||||
z-index: 2;
|
z-index: 2;
|
||||||
bottom: 8px;
|
bottom: 8px;
|
||||||
|
padding-top: 8px;
|
||||||
|
|
||||||
@media (max-width: 500px) {
|
@media (max-width: 500px) {
|
||||||
bottom: 100px;
|
bottom: 92px;
|
||||||
}
|
}
|
||||||
|
|
||||||
> .new-message {
|
> .new-message {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
padding: 8px 0;
|
padding-bottom: 8px;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
|
|
||||||
> button {
|
> button {
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
type ScrollBehavior = 'auto' | 'smooth' | 'instant';
|
type ScrollBehavior = 'auto' | 'smooth' | 'instant';
|
||||||
|
|
||||||
export function getScrollContainer(el: HTMLElement | null): HTMLElement | null {
|
export function getScrollContainer(el: HTMLElement | null): HTMLElement | null {
|
||||||
if (el == null) return null;
|
if (el == null || el.tagName === 'HTML') return null;
|
||||||
if (el.scrollHeight > el.clientHeight) {
|
if (el.scrollHeight > el.clientHeight) {
|
||||||
return el;
|
return el;
|
||||||
} else {
|
} else {
|
||||||
|
@ -77,7 +77,6 @@ export function scrollToBottom(el: HTMLElement, options: { behavior?: ScrollBeha
|
||||||
scroll(el, { top: el.scrollHeight, ...options }); // TODO: ちゃんと計算する
|
scroll(el, { top: el.scrollHeight, ...options }); // TODO: ちゃんと計算する
|
||||||
}
|
}
|
||||||
|
|
||||||
// https://developer.mozilla.org/en-US/docs/Web/API/Element/scrollHeight#determine_if_an_element_has_been_totally_scrolled
|
|
||||||
export function isBottom(el: HTMLElement, asobi = 1) {
|
export function isBottom(el: HTMLElement, asobi = 1) {
|
||||||
const container = getScrollContainer(el);
|
const container = getScrollContainer(el);
|
||||||
return isScrollBottom(container, asobi);
|
return isScrollBottom(container, asobi);
|
||||||
|
@ -92,6 +91,7 @@ export function getBodyScrollHeight() {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// https://developer.mozilla.org/en-US/docs/Web/API/Element/scrollHeight#determine_if_an_element_has_been_totally_scrolled
|
||||||
export function isScrollBottom(container?: HTMLElement | null, asobi = 1) {
|
export function isScrollBottom(container?: HTMLElement | null, asobi = 1) {
|
||||||
if (container) return container.scrollHeight - Math.abs(container.scrollTop) <= container.clientHeight + asobi;
|
if (container) return container.scrollHeight - Math.abs(container.scrollTop) <= container.clientHeight + asobi;
|
||||||
return getBodyScrollHeight() - window.scrollY <= window.innerHeight + asobi;
|
return getBodyScrollHeight() - window.scrollY <= window.innerHeight + asobi;
|
||||||
|
|
Loading…
Reference in a new issue