120 lines
4.1 KiB
TypeScript
120 lines
4.1 KiB
TypeScript
import Search from "@/components/search"
|
|
import useLogin from "@/use/useLogin"
|
|
import { Image, ScrollView, Text, View } from "@tarojs/components"
|
|
import Taro, { useDidShow, usePullDownRefresh, useRouter } from "@tarojs/taro"
|
|
import { useCallback, useEffect, useMemo, useRef, useState } from "react"
|
|
import {ORDER_STATUS} from '@/common/enum'
|
|
import styles from './index.module.scss'
|
|
import classnames from "classnames";
|
|
import Order from "./components/order"
|
|
import InfiniteScroll from "@/components/infiniteScroll"
|
|
import {GetOrderStatusListApi, GetOrderListApi} from '@/api/order'
|
|
import { dataLoadingStatus, getFilterData } from "@/common/util"
|
|
import Tabs from "@/components/tabs"
|
|
|
|
export default () => {
|
|
const {checkLogin} = useLogin()
|
|
useDidShow(async () => {
|
|
await checkLogin()
|
|
})
|
|
|
|
//搜索参数
|
|
const [searchField, setSearchField] = useState({
|
|
status: -1,
|
|
page : 1,
|
|
size : 10,
|
|
Name:''
|
|
})
|
|
|
|
//获取订单状态
|
|
const {fetchData: statusFetchData} = GetOrderStatusListApi()
|
|
const [statusList, setStatusList] = useState<any[]>([{id: -1, name: '全部'}])
|
|
const getOrderStatusList = async () => {
|
|
let res = await statusFetchData()
|
|
let list = [...statusList, ...res.data.list||[]]
|
|
setStatusList(() => list)
|
|
}
|
|
useEffect(() => {
|
|
getOrderStatusList()
|
|
}, [])
|
|
|
|
//获取订单列表
|
|
const {fetchData: listFetchData, state:orderState} = GetOrderListApi()
|
|
const [orderData, setOrderData] = useState<{list:any[], total:number}>({list:[], total:0})
|
|
const getOrderList = async () => {
|
|
let res = await listFetchData(getFilterData(searchField))
|
|
setOrderData({list: res.data.list, total: res.data.total})
|
|
}
|
|
|
|
|
|
//监听筛选条件变化
|
|
useEffect(() => {
|
|
getOrderList()
|
|
}, [searchField])
|
|
|
|
//上拉加载数据
|
|
const pageNum = useRef({size: searchField.size, page: searchField.page})
|
|
const getScrolltolower = useCallback(() => {
|
|
if(orderData.list.length < orderData.total) {
|
|
pageNum.current.page++
|
|
const size = pageNum.current.size * pageNum.current.page
|
|
setSearchField({...searchField, size })
|
|
}
|
|
}, [orderData])
|
|
|
|
//状态改变
|
|
const changeStatus = useCallback((e) => {
|
|
pageNum.current.page = 1
|
|
setSearchField((value) => ({...value, status:e, size:10}))
|
|
setOrderData(() => ({list:[], total:0}))
|
|
}, [])
|
|
|
|
|
|
//数据加载状态
|
|
const statusMore = useMemo(() => {
|
|
return dataLoadingStatus({list:orderData.list, total: orderData.total, status: orderState.loading})
|
|
}, [orderData, orderState])
|
|
|
|
//输入了搜索关键字
|
|
const getSearchData = useCallback((e) => {
|
|
pageNum.current.page = 1
|
|
setOrderData(() => ({list:[], total:0}))
|
|
setSearchField((val) => ({...val, name:e, size:10}))
|
|
}, [])
|
|
|
|
const clickOrderBtn = useCallback((state) => {
|
|
getOrderList()
|
|
}, [orderData])
|
|
|
|
//列表下拉刷新
|
|
const [refresherTriggeredStatus, setRefresherTriggeredStatus] = useState(false)
|
|
const getRefresherRefresh = async () => {
|
|
pageNum.current.size = 1
|
|
setRefresherTriggeredStatus(true)
|
|
}
|
|
|
|
return (
|
|
<View className={styles.order_list_main}>
|
|
<View className={styles.title}>
|
|
<Search placeIcon="out" placeholder="搜索商品/名称/颜色/订单号" showBtn={true} changeOnSearch={getSearchData} debounceTime={300}/>
|
|
<View className={styles.order_status_list}>
|
|
<ScrollView scrollX >
|
|
<View className={styles.order_list_scroll}>
|
|
{statusList.map(item => {
|
|
return <View key={item.id} onClick={() => changeStatus(item.id)} className={classnames(styles.order_status_item, (searchField.status==item.id)&&styles.selected)}>{item.name}</View>
|
|
})}
|
|
</View>
|
|
</ScrollView>
|
|
</View>
|
|
</View>
|
|
<View className={styles.order_list}>
|
|
<InfiniteScroll statusMore={statusMore} selfonScrollToLower={getScrolltolower} refresherEnabled={true} selfOnRefresherRefresh={getRefresherRefresh}>
|
|
{orderData?.list.map(item => {
|
|
return <View key={item.id} className={styles.order_item_con}> <Order value={item} onClickBtn={clickOrderBtn}/></View>
|
|
})}
|
|
</InfiniteScroll>
|
|
</View>
|
|
</View>
|
|
)
|
|
}
|