|
|
@@ -3,13 +3,16 @@
|
|
|
<template #header>
|
|
|
<app-navbar title="市场资讯" />
|
|
|
</template>
|
|
|
- <Tabs v-model:active="active" @click-tab="onClickTab">
|
|
|
- <Tab v-for="(item, index) in configs" :key="index" :title="item.columnname">
|
|
|
- <Empty v-if="empty" />
|
|
|
- </Tab>
|
|
|
+ <Tabs v-model:active="currentColumnId" @change="onClickTab">
|
|
|
+ <template v-for="(item, index) in siteColumns" :key="index">
|
|
|
+ <Tab :name="item.id" :title="item.columnname" />
|
|
|
+ </template>
|
|
|
</Tabs>
|
|
|
- <app-pull-refresh class="news-list__container" v-model:pageIndex="pageIndex" :page-count="pageCount"
|
|
|
- :updateList="dataList" @refresh="onRefresh" @updated="onUpdated">
|
|
|
+ <app-pull-refresh ref="pullRefreshRef" class="news-list__container" :dataList="dataList" v-model:error="error"
|
|
|
+ v-model:pageIndex="pageIndex" :page-count="pageCount" @refresh="onRefresh">
|
|
|
+ <template #header>
|
|
|
+ <Empty v-if="dataList.length === 0" />
|
|
|
+ </template>
|
|
|
<template #default="{ item }">
|
|
|
<Cell class="article-item" title-class="article-item__title" value-class="article-item__time"
|
|
|
:title="item.title" :value="formatDate(item.creaedate, 'MM/DD')"
|
|
|
@@ -20,50 +23,34 @@
|
|
|
</template>
|
|
|
|
|
|
<script lang="ts" setup>
|
|
|
-
|
|
|
-import { ref, shallowRef } from 'vue'
|
|
|
+import { shallowRef } from 'vue'
|
|
|
import { Cell, Tab, Tabs, Empty } from 'vant'
|
|
|
import { formatDate } from '@/filters'
|
|
|
import { useSiteColumnDetail } from '@/business/news'
|
|
|
-import { querySiteColumnConfig } from '@/services/api/news'
|
|
|
import AppPullRefresh from '@mobile/components/base/pull-refresh/index.vue'
|
|
|
|
|
|
-/// tab激活项
|
|
|
-const active = ref(0);
|
|
|
-const empty = shallowRef(false)
|
|
|
-const configs = shallowRef<Model.SiteColumnConfigRsp[]>([])
|
|
|
-const config = shallowRef<Model.SiteColumnConfigRsp>({})
|
|
|
+const { siteColumns, currentColumnId, pageIndex, pageCount, getSiteColumnDetail } = useSiteColumnDetail()
|
|
|
+const pullRefreshRef = shallowRef()
|
|
|
+const dataList = shallowRef<Model.SiteColumnDetailRsp[]>([])
|
|
|
+const error = shallowRef(false)
|
|
|
|
|
|
-const { dataList, pageIndex, pageCount, getSiteColumnDetail } = useSiteColumnDetail()
|
|
|
-/// Tab触发
|
|
|
-const onClickTab = (e) => {
|
|
|
- active.value = e.name
|
|
|
- /// 设置选中的数据
|
|
|
- if (configs.value.length>0) {
|
|
|
- config.value = configs.value[e.name]
|
|
|
- }
|
|
|
- getSiteColumnDetail(config.value.id)
|
|
|
+// Tab触发
|
|
|
+const onClickTab = () => {
|
|
|
+ pullRefreshRef.value?.refresh()
|
|
|
}
|
|
|
|
|
|
-/// 查询栏目配置
|
|
|
-querySiteColumnConfig({
|
|
|
- success: (res) => {
|
|
|
- configs.value = res.data
|
|
|
- /// 默认第一个
|
|
|
- if (res.data.length > 0) {
|
|
|
- config.value = res.data[0]
|
|
|
+const onRefresh = (finish: () => void) => {
|
|
|
+ getSiteColumnDetail().then((res) => {
|
|
|
+ if (pageIndex.value === 1) {
|
|
|
+ dataList.value = []
|
|
|
}
|
|
|
- }
|
|
|
-})
|
|
|
-
|
|
|
-const onRefresh = (callback: () => void) => {
|
|
|
- getSiteColumnDetail(config.value.id).finally(() => callback())
|
|
|
+ dataList.value.push(...res)
|
|
|
+ }).catch(() => {
|
|
|
+ error.value = true
|
|
|
+ }).finally(() => {
|
|
|
+ finish()
|
|
|
+ })
|
|
|
}
|
|
|
-
|
|
|
-const onUpdated = (lists: Model.THJProductRsp[]) => {
|
|
|
- empty.value = lists.length===0
|
|
|
-}
|
|
|
-
|
|
|
</script>
|
|
|
|
|
|
<style lang="less">
|