修改:调整恋爱日记相关UI

This commit is contained in:
小莫唐尼 2022-12-12 00:30:47 +08:00
parent 1305b4a555
commit f12262f4df
6 changed files with 211 additions and 51 deletions

View File

@ -0,0 +1,79 @@
<template>
<view class="scroll-btn" :style="{ bottom: bottom }" @click.stop="fnScroll()">
<text v-if="_scrollTop >= 180" class="iconfont icon-long-arrow-up"></text>
<text v-else class="iconfont icon-long-arrow-down"></text>
</view>
</template>
<script>
import throttle from '@/utils/throttle.js';
export default {
name: 'scroll-btn',
props: {
bottom: {
type: String,
default: '180rpx'
},
scrollTop: {
type: Number,
default: 0
}
},
data() {
return { _scrollTop: 0 };
},
watch: {
scrollTop(val) {
this._scrollTop = val;
console.log('监听1', val);
this.$forceUpdate();
}
},
created() {
this._scrollTop = this.scrollTop;
},
methods: {
fnScroll() {
throttle(() => {
const isTop = this._scrollTop >= 180;
this._scrollTop = isTop ? 0 : 999999;
uni.pageScrollTo({
duration: 500,
scrollTop: this._scrollTop
});
this.$emit('update:scrollTop', this._scrollTop);
});
}
}
};
</script>
<style scoped lang="scss">
.scroll-btn {
position: fixed;
// bottom: 200rpx;
// right: -90rpx;
right: 52rpx;
width: 80rpx;
height: 80rpx;
display: flex;
align-items: center;
justify-content: center;
box-sizing: border-box;
border-radius: 50%;
border: 4rpx solid #ffffff;
background-color: #bfe9ef;
box-shadow: 0rpx 4rpx 24rpx rgba(0, 0, 0, 0.1);
z-index: 99;
transition: right 0.5s ease-in-out;
&.is-show {
right: 52rpx;
}
.iconfont {
font-size: 36rpx;
color: #555;
}
}
</style>

View File

@ -45,7 +45,7 @@ export default {
// 关于我们:支持富文本内容 // 关于我们:支持富文本内容
journey: ` journey: `
<p>有一只马它的邻居是一只驴</p><p></p><p></p><p></p><p></p><p></p><p></p><p></p><p></p><p></p><p></p><p></p><p></p><p></p><p></p><p></p><p></p> 准备晚安啦,睡觉前讲个故事吧~<p>槐树庄的村口有一棵大槐树树下的村口第一家就是猫奶奶的家</p><p></p><p>tí</p><p></p><p></p><p></p><p></p><p></p><p>niǎolǚ</p><p>chù</p><p>suí</p><p></p><p></p><p>guī</p><p></p><p></p><p></p><p></p><p></p><p>竿</p><p></p><p></p><p></p><p></p><p></p><p></p><p></p><p></p><p></p><p></p>
`, `,
// 恋爱相册 // 恋爱相册
albumKeyName: '恋爱相册', // 对应后台的图库分组名称 albumKeyName: '恋爱相册', // 对应后台的图库分组名称

View File

@ -1,14 +1,21 @@
<template> <template>
<view class="app-page"> <view class="app-page">
<view v-if="loading != 'success'" class="loading-wrap"> <view v-if="loading != 'success'" class="loading-wrap">
<tm-skeleton model="card"></tm-skeleton> <view v-if="loading == 'loading'" class="loading">
<tm-skeleton model="card"></tm-skeleton> <view class="loading-icon flex flex-center"><text class="e-loading-icon iconfont icon-loading"></text></view>
<tm-skeleton model="card"></tm-skeleton> <view class="loadig-text ">相册正在努力加载中啦~</view>
<tm-skeleton model="card"></tm-skeleton> </view>
<tm-empty v-else icon="icon-shiliangzhinengduixiang-" color="red" label="啊偶,加载失败了呢~">
<tm-button theme="red" :shadow="0" size="m" @click="fnRefresh()">刷新试试</tm-button>
</tm-empty>
</view> </view>
<!-- 内容区域 --> <!-- 内容区域 -->
<view v-else class="app-page-content"> <view v-else class="app-page-content">
<view v-if="dataList.length == 0" class="content-empty flex flex-center"><tm-empty icon="icon-shiliangzhinengduixiang-" label="相册暂时还没有数据~"></tm-empty></view> <view v-if="dataList.length == 0" color="light-blue" class="content-empty flex flex-center">
<tm-empty icon="icon-shiliangzhinengduixiang-" label="相册暂时还没有数据~">
<tm-button :shadow="0" size="m" theme="light-blue" @click="fnRefresh()">刷新试试</tm-button>
</tm-empty>
</view>
<block v-else> <block v-else>
<swiper <swiper
class="swiper-album" class="swiper-album"
@ -49,7 +56,11 @@
<text class="icon"><text class="iconfont icon-arrow-left"></text></text> <text class="icon"><text class="iconfont icon-arrow-left"></text></text>
<text class="text">上一张</text> <text class="text">上一张</text>
</view> </view>
<view class="refresh" @click="fnRefresh()">刷新</view> <view class="refresh" @click="fnRefresh()">
<text class="refresh-text">点击</text>
<text class="refresh-heart iconfont icon-diagnose"></text>
<text class="refresh-text">刷新</text>
</view>
<view class="next" @click="fnChange(true)"> <view class="next" @click="fnChange(true)">
<text class="text">下一张</text> <text class="text">下一张</text>
<text class="icon"><text class="iconfont icon-arrow-right"></text></text> <text class="icon"><text class="iconfont icon-arrow-right"></text></text>
@ -62,14 +73,15 @@
<script> <script>
import LoveConfig from '@/config/love.config.js'; import LoveConfig from '@/config/love.config.js';
import tmSkeleton from '@/tm-vuetify/components/tm-skeleton/tm-skeleton.vue'; import throttle from '@/utils/throttle.js';
import tmButton from '@/tm-vuetify/components/tm-button/tm-button.vue';
import tmFlotbutton from '@/tm-vuetify/components/tm-flotbutton/tm-flotbutton.vue'; import tmFlotbutton from '@/tm-vuetify/components/tm-flotbutton/tm-flotbutton.vue';
import tmTranslate from '@/tm-vuetify/components/tm-translate/tm-translate.vue'; import tmTranslate from '@/tm-vuetify/components/tm-translate/tm-translate.vue';
import tmEmpty from '@/tm-vuetify/components/tm-empty/tm-empty.vue'; import tmEmpty from '@/tm-vuetify/components/tm-empty/tm-empty.vue';
export default { export default {
components: { components: {
tmSkeleton, tmButton,
tmFlotbutton, tmFlotbutton,
tmTranslate, tmTranslate,
tmEmpty tmEmpty
@ -82,7 +94,7 @@ export default {
size: 99, size: 99,
page: 0, page: 0,
sort: 'takeTime', sort: 'takeTime',
team: LoveConfig.photoKeyName team: LoveConfig.albumKeyName
}, },
result: {}, result: {},
dataList: [], dataList: [],
@ -113,11 +125,6 @@ export default {
this.fnGetData(); this.fnGetData();
}, },
fnGetData() { fnGetData() {
uni.showLoading({
mask: true,
title: '加载中...'
});
this.loading = 'loading'; this.loading = 'loading';
this.$httpApi this.$httpApi
.getPhotoListByPage(this.queryParams) .getPhotoListByPage(this.queryParams)
@ -131,11 +138,7 @@ export default {
return item; return item;
}); });
this.dataList = _list; this.dataList = _list;
// this.fnCacheDataList(_list);
// this.dataList = this.dataList.concat(_list);
this.swiperIndex = 0; this.swiperIndex = 0;
uni.hideLoading();
} }
} else { } else {
this.loading = 'error'; this.loading = 'error';
@ -168,23 +171,24 @@ export default {
}); });
}, },
fnOnChange(e) { fnOnChange(e) {
console.log('e', e);
this.swiperIndex = e.detail.current; this.swiperIndex = e.detail.current;
}, },
fnChange(isNext) { fnChange(isNext) {
if (isNext) { throttle(() => {
if (this.swiperIndex == this.dataList.length - 1) { if (isNext) {
this.swiperIndex = 0; if (this.swiperIndex == this.dataList.length - 1) {
this.swiperIndex = 0;
} else {
this.swiperIndex += 1;
}
} else { } else {
this.swiperIndex += 1; if (this.swiperIndex == 0) {
this.swiperIndex = this.dataList.length - 1;
} else {
this.swiperIndex -= 1;
}
} }
} else { });
if (this.swiperIndex == 0) {
this.swiperIndex = this.dataList.length - 1;
} else {
this.swiperIndex -= 1;
}
}
} }
} }
}; };
@ -210,18 +214,42 @@ export default {
rgba(7, 179, 155, 0.1) 86%, rgba(7, 179, 155, 0.1) 86%,
rgba(109, 186, 130, 0.1) rgba(109, 186, 130, 0.1)
); );
color: #55423b;
} }
.app-page-content { .app-page-content {
} }
.loading-wrap {
width: 100vw;
height: 60vh;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
box-sizing: border-box;
padding: 36rpx;
::v-deep {
.tm-icons {
margin-right: -20rpx;
}
}
}
.e-loading-icon {
font-size: 120rpx;
// color: #f88ca2;
color: #56bbf9;
}
.loadig-text {
margin-top: 28rpx;
font-size: 28rpx;
// color: #f88ca2;
color: #56bbf9;
}
.content-empty { .content-empty {
width: 100%; width: 100%;
height: 60vh; height: 60vh;
} }
.loading-wrap {
box-sizing: border-box;
padding: 0 24rpx;
}
.swiper-album { .swiper-album {
width: 100vw; width: 100vw;
height: calc(100vh - 24rpx - 144rpx); height: calc(100vh - 24rpx - 144rpx);
@ -286,7 +314,7 @@ export default {
} }
} }
.tabbar { .tabbar {
width: 80vw; width: 90vw;
position: fixed; position: fixed;
left: 50%; left: 50%;
bottom: 40rpx; bottom: 40rpx;
@ -300,18 +328,49 @@ export default {
// background-color: rgba(0, 0, 0, 0.5); // background-color: rgba(0, 0, 0, 0.5);
background-color: #ffffff; background-color: #ffffff;
color: #333; color: #333;
box-shadow: 0rpx 4rpx 24rpx rgba(0, 0, 0, 0.07); box-shadow: 0rpx 4rpx 24rpx rgba(0, 0, 0, 0.05);
.refresh {
animation: refreshAni 6s ease-in-out infinite;
color: #56bbf9;
&-heart {
font-size: 42rpx;
color: inherit;
margin: 0 6rpx;
}
&-text {
font-size: 24rpx;
}
}
.pre { .pre {
color: #56bbf9; color: #56bbf9;
transition: transform 0.1s ease-in-out;
&:hover {
transform: scale(1.05);
}
.text { .text {
padding-left: 12rpx; padding-left: 12rpx;
} }
} }
.next { .next {
color: #f88ca2; color: #f88ca2;
transition: transform 0.1s ease-in-out;
&:hover {
transform: scale(1.03);
}
.text { .text {
padding-right: 12rpx; padding-right: 12rpx;
} }
} }
} }
@keyframes refreshAni {
0% {
color: #f88ca2;
}
50% {
color: #56bbf9;
}
100% {
color: #f88ca2;
}
}
</style> </style>

View File

@ -2,14 +2,19 @@
<view class="app-page"> <view class="app-page">
<view class="page-title">我们的故事</view> <view class="page-title">我们的故事</view>
<view class="html-typed" v-html="html">内容渲染</view> <view class="html-typed" v-html="html">内容渲染</view>
<scroll-btn bottom="60rpx" :scrollTop.sync="scrollTop"></scroll-btn>
</view> </view>
</template> </template>
<script> <script>
import LoveConfig from '@/config/love.config.js'; import LoveConfig from '@/config/love.config.js';
import ScrollBtn from '@/components/scroll-btn/scroll-btn.vue';
export default { export default {
components: { ScrollBtn },
data() { data() {
return { return {
scrollTop: 0,
html: '', html: '',
timer: null timer: null
}; };
@ -17,6 +22,9 @@ export default {
created() { created() {
this.fnInit(); this.fnInit();
}, },
onPageScroll(e) {
this.scrollTop = e.scrollTop;
},
onBackPress() { onBackPress() {
clearTimeout(this.timer); clearTimeout(this.timer);
}, },

View File

@ -70,14 +70,18 @@
</view> </view>
</block> </block>
</view> </view>
<scroll-btn :scrollTop.sync="scrollTop"></scroll-btn>
</view> </view>
</template> </template>
<script> <script>
import LoveConfig from '@/config/love.config.js'; import LoveConfig from '@/config/love.config.js';
import ScrollBtn from '@/components/scroll-btn/scroll-btn.vue';
export default { export default {
components: { ScrollBtn },
data() { data() {
return { return {
scrollTop: 0,
loveConfig: LoveConfig, loveConfig: LoveConfig,
list: [] list: []
}; };
@ -101,6 +105,9 @@ export default {
created() { created() {
this.fnGetList(); this.fnGetList();
}, },
onPageScroll(e) {
this.scrollTop = e.scrollTop;
},
methods: { methods: {
fnGetList() { fnGetList() {
if (LoveConfig.loveList.useApi && LoveConfig.loveList.api) { if (LoveConfig.loveList.useApi && LoveConfig.loveList.api) {
@ -164,9 +171,8 @@ export default {
rgba(7, 179, 155, 0.1) 86%, rgba(7, 179, 155, 0.1) 86%,
rgba(109, 186, 130, 0.1) rgba(109, 186, 130, 0.1)
); );
// background: rgba(247, 246, 242, 1);
// color: #55423b;
} }
.love-card { .love-card {
width: 100%; width: 100%;
display: flex; display: flex;
@ -182,10 +188,8 @@ export default {
background-color: rgba(255, 199, 184, 0.9); background-color: rgba(255, 199, 184, 0.9);
margin-bottom: 52rpx; margin-bottom: 52rpx;
box-shadow: 0rpx 4rpx 24rpx rgba(0, 0, 0, 0.1); box-shadow: 0rpx 4rpx 24rpx rgba(0, 0, 0, 0.1);
transition: transform 0.5s ease-in-out; animation: loveCardAni 3s ease-in-out infinite;
&:hover {
transform: translateY(-6rpx);
}
.head { .head {
display: flex; display: flex;
.avatar { .avatar {
@ -247,6 +251,17 @@ export default {
color: #f88ca2; color: #f88ca2;
} }
} }
@keyframes loveCardAni {
0% {
transform: scale(1);
}
50% {
transform: scale(1.03);
}
100% {
transform: scale(1);
}
}
.list { .list {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
@ -286,13 +301,9 @@ export default {
// background-color: #faf8eb; // background-color: #faf8eb;
background-color: #ffffff; background-color: #ffffff;
margin-bottom: 36rpx; margin-bottom: 36rpx;
box-shadow: 0rpx 4rpx 24rpx rgba(0, 0, 0, 0.1); box-shadow: 0rpx 4rpx 24rpx rgba(0, 0, 0, 0.05);
transition: transform 0.3s ease-in-out;
animation: cardAni 3s ease-in-out infinite; animation: cardAni 3s ease-in-out infinite;
animation-delay: var(--delay); animation-delay: var(--delay);
&:hover {
transform: translateY(-8rpx);
}
.head { .head {
width: 100%; width: 100%;
display: flex; display: flex;
@ -309,6 +320,7 @@ export default {
font-size: 24rpx; font-size: 24rpx;
line-height: 100rpx; line-height: 100rpx;
text-align: center; text-align: center;
color: #55423b;
&.finish { &.finish {
background-color: #bfe9ef; background-color: #bfe9ef;
} }
@ -328,7 +340,7 @@ export default {
&-desc { &-desc {
margin-top: 8rpx; margin-top: 8rpx;
font-size: 26rpx; font-size: 26rpx;
color: rgba(96, 77, 68, 1); color: #555;
text-overflow: ellipsis; text-overflow: ellipsis;
overflow: hidden; overflow: hidden;
white-space: nowrap; white-space: nowrap;
@ -388,6 +400,7 @@ export default {
width: 0; width: 0;
flex-grow: 1; flex-grow: 1;
line-height: 1.5; line-height: 1.5;
color: #333;
} }
} }
</style> </style>

View File

@ -141,6 +141,7 @@ export default {
background-size: cover; background-size: cover;
background-repeat: no-repeat; background-repeat: no-repeat;
background-position: 50% 50%; background-position: 50% 50%;
&::before { &::before {
position: absolute; position: absolute;
left: 0; left: 0;
@ -148,7 +149,7 @@ export default {
right: 0; right: 0;
bottom: 0; bottom: 0;
content: ''; content: '';
background-color: rgba(0, 0, 0, 0.07); background-color: rgba(255, 255, 255, 0.1);
background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAQAAAAECAYAAACp8Z5+AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAKUlEQVQImU3IMREAIAgAwJfNkQCEsH8cijjpMf6vnXlQaIiJFx+omEBfmqIEZLe2jzcAAAAASUVORK5CYII=); background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAQAAAAECAYAAACp8Z5+AAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAKUlEQVQImU3IMREAIAgAwJfNkQCEsH8cijjpMf6vnXlQaIiJFx+omEBfmqIEZLe2jzcAAAAASUVORK5CYII=);
z-index: 0; z-index: 0;
backdrop-filter: blur(4rpx); backdrop-filter: blur(4rpx);