161 lines
6.7 KiB
TypeScript
161 lines
6.7 KiB
TypeScript
import {Image, ScrollView, View } from "@tarojs/components"
|
||
import Popup from "@/components/popup"
|
||
import classnames from "classnames";
|
||
import MCheckbox from "@/components/checkbox";
|
||
import LoadingCard from "@/components/loadingCard";
|
||
import InfiniteScroll from "@/components/infiniteScroll";
|
||
import styles from "./index.module.scss"
|
||
import { useEffect, useState } from "react";
|
||
import Taro from "@tarojs/taro";
|
||
|
||
type param = {
|
||
show?: true|false,
|
||
onClose?: () => void
|
||
}
|
||
export default ({show = false, onClose}: param) => {
|
||
const selectList = ['不限', '剪板', '散剪', '大货']
|
||
const [selectIndex, setSelectIndex] = useState(0)
|
||
const selectProduct = (index:number) => {
|
||
setSelectIndex(index)
|
||
}
|
||
|
||
const [list, setList] = useState<any[]>([])
|
||
const [loading, setLoading] = useState(false)
|
||
|
||
useEffect(() => {
|
||
if(!show) return
|
||
let lists:any[] = []
|
||
for(let i = 0; i < 20; i++) {
|
||
lists = [...lists, {
|
||
title:`${i}#薄荷绿`,
|
||
subtitle: '0770# 21S单面平纹(食毛)',
|
||
tag: '剪板',
|
||
select: i%2?true: false
|
||
}]
|
||
}
|
||
setList([...lists])
|
||
}, [show])
|
||
|
||
useEffect(() => {
|
||
return () => {
|
||
setList([])
|
||
}
|
||
}, [])
|
||
|
||
const [showPopup, setShowPopup] = useState(false)
|
||
useEffect(() => {
|
||
setShowPopup(show)
|
||
}, [show])
|
||
|
||
|
||
const [selectStatus, setSelectStatus] = useState(false)
|
||
const selectAll = () => {
|
||
list.map(item => {
|
||
item.select = !selectStatus
|
||
})
|
||
setSelectStatus(!selectStatus)
|
||
setList([...list])
|
||
}
|
||
|
||
//checkbox选中回调
|
||
const selectCallBack = (item) => {
|
||
item.select = true
|
||
setList([...list])
|
||
}
|
||
|
||
//checkbox关闭回调
|
||
const colseCallBack = (item) => {
|
||
item.select = false
|
||
setList([...list])
|
||
}
|
||
|
||
//popup关闭
|
||
const closePopup = () => {
|
||
onClose?.()
|
||
setShowPopup(false)
|
||
}
|
||
|
||
const delSelect = () => {
|
||
Taro.showModal({
|
||
content: '删除所选商品?',
|
||
success: function (res) {
|
||
if (res.confirm) {
|
||
Taro.showToast({
|
||
title: '成功',
|
||
icon: 'success',
|
||
duration: 2000
|
||
})
|
||
} else if (res.cancel) {
|
||
console.log('用户点击取消')
|
||
}
|
||
}
|
||
})
|
||
}
|
||
|
||
return (
|
||
<View className={styles.shop_cart_main}>
|
||
<Popup showTitle={false} show={showPopup} onClose={() => closePopup()}>
|
||
<View className={styles.popup_con}>
|
||
<View className={styles.header}>
|
||
<View onClick={selectAll}>{!selectStatus?'全选':'反选'}</View>
|
||
<View onClick={delSelect}>
|
||
<text className={classnames('iconfont', 'icon-lajixiang', styles.miconfont)}></text>
|
||
删除勾选项
|
||
</View>
|
||
</View>
|
||
<View className={styles.search}>
|
||
{selectList.map((item, index) => {
|
||
return <View key={index} onClick={() => selectProduct(index)} className={classnames(styles.search_item, (selectIndex==index)&&styles.search_item_select)}>{item}</View>
|
||
})}
|
||
|
||
</View>
|
||
<View className={styles.con}>
|
||
{loading&&<LoadingCard/>}
|
||
{!loading&&list.length > 0&&<InfiniteScroll selfonScrollToLower={() => {console.log('触底了')}} paddingBottom={100}>
|
||
<View className={styles.product_list}>
|
||
{list.map((item, index) => {
|
||
return <View key={index} className={styles.product_item}>
|
||
<View className={styles.checkbox}>
|
||
<MCheckbox status={item.select} onSelect={() => selectCallBack(item)} onClose={() => colseCallBack(item)}/>
|
||
</View>
|
||
<View className={styles.img}>
|
||
<Image src="https://bpic.588ku.com//back_origin_min_pic/22/01/11/aa3da17bab9a6556564028e4f1d77874.jpg!/fw/750/quality/99/unsharp/true/compress/true"/>
|
||
</View>
|
||
<View className={styles.des}>
|
||
<View className={styles.title}>{item.title}</View>
|
||
<View className={styles.subtitle}>0770# 21S单面平纹(食毛)</View>
|
||
<View className={styles.tag}>剪板</View>
|
||
</View>
|
||
<View className={styles.count}>
|
||
<View className={styles.price}><text>¥</text>40.5<text>/kg</text></View>
|
||
<View className={styles.long}>×12m</View>
|
||
</View>
|
||
</View>
|
||
})}
|
||
</View>
|
||
</InfiniteScroll>}
|
||
{!loading&&list.length > 0&&<View className={styles.empty}>
|
||
<View className={styles.title}>暂未选择商品</View>
|
||
<View className={styles.btn}>去选购</View>
|
||
</View>}
|
||
|
||
</View>
|
||
<View className={styles.buy_btn}>
|
||
<View className={styles.buy_con}>
|
||
<View className={styles.icon}>
|
||
<View className={classnames('iconfont', 'icon-gouwuche', styles.miconfont)}></View>
|
||
</View>
|
||
<View className={styles.price_con}>
|
||
<View className={styles.price_real}><text>¥</text>200</View>
|
||
<View className={styles.price_forecast}>预估金额</View>
|
||
</View>
|
||
<View className={styles.goPay}>
|
||
去结算
|
||
</View>
|
||
</View>
|
||
</View>
|
||
</View>
|
||
</Popup>
|
||
</View>
|
||
)
|
||
} |