import { Button, View } from '@tarojs/components'
import Taro, { setNavigationBarTitle, useDidShow, usePullDownRefresh, useRouter } from '@tarojs/taro'
import type { ReactNode } from 'react'
import React, { memo, useCallback, useEffect, useMemo, useRef, useState } from 'react'
import classnames from 'classnames'
import Remark from '../orderDetails/components/remark'
import styles from './index.module.scss'
import Form from './components/form'
import Popup from '@/components/popup'
import { debounce } from '@/common/util'
import { alert, goLink } from '@/common/common'
import { formatDateTime, formatPriceDiv, formatWeightDiv } from '@/common/format'
import Address from '@/components/address'
import { MpPurchaser, MpPurchaserPost, MpPurchaserPut } from '@/api/customer'
// 卡片盒子元素
interface Obs {
title?: string
modeName?: string
showMode?: boolean
children?: ReactNode
clickNode?: () => void
}
const DefaultBox = (props: Obs) => {
const {
title = '标题',
modeName = '大货',
showMode = false,
children,
clickNode,
} = props
return (
{title}
{
showMode && clickNode?.()}>{modeName}
}
{children}
)
}
const DefaultBoxWithMemo = memo(DefaultBox)
interface AddressParms {
id: number
name: string
}
const CustomerEditor = () => {
const router = useRouter()
const [infoObj, setinfoObj] = useState()
const [formData, setformData] = useState()
const [addressArr, setaddressArr] = useState([])
// 默认业务员
useDidShow(() => {
if (router.params.type === 'add') {
setNavigationBarTitle({ title: '新增客户' })
}
else {
setNavigationBarTitle({ title: '客户编辑' })
}
const userInfo = JSON.parse(Taro.getStorageSync('userInfo'))
// 获取选择的客户
const pages = Taro.getCurrentPages()
const currPage = pages[pages.length - 1] // 获取当前页面
// 判断是否有跳转选择业务员
if (currPage.data?.saleuserId && currPage.data?.saleuserId !== '') {
setformData(val => ({
...val,
sale_user_id: currPage.data?.saleuserId,
sale_user_name: currPage.data?.saleuserName,
}))
}
// 默认业务员
if (currPage.data?.saleuserId == null) {
setformData(e => ({
...e,
sale_user_id: userInfo?.user_id,
sale_user_name: userInfo?.user_name,
}))
}
})
const { fetchData: getDesc } = MpPurchaser()
const handTitle = useCallback((e) => {
setformData(val => ({ ...val, name: e }))
}, [])
const handName = useCallback((e) => {
setformData(val => ({ ...val, short_name: e }))
}, [])
const handUsername = useCallback((e) => {
setformData(val => ({ ...val, director: e }))
}, [])
const handUserPhone = useCallback((e) => {
setformData(val => ({ ...val, phone: e }))
}, [])
const handAddress = useCallback((e) => {
setformData(val => ({ ...val, address_detail: e }))
}, [])
// 客户类型数组
const [list, setlist] = useState([
{
id: 1,
name: '布行',
check: false,
},
{
id: 2,
name: '二批',
check: false,
},
{
id: 3,
name: '制衣厂',
check: false,
},
])
// 选择客户类型
const handItem = (item) => {
list.map((it) => {
if (it.id === item.id) {
it.check = true
}
else {
it.check = false
}
return it
})
setlist([...list])
setformData(val => ({ ...val, purchaser_type: item.id }))
}
// 备注操作
const [remarkDesc, setremarkDesc] = useState('')
const getInfo = async() => {
Taro.showLoading({
title: '请稍等...',
mask: true,
})
const res = await getDesc({ id: router.params.id })
setinfoObj(res.data)
list.map((item) => {
if (item.id == res.data.purchaser_type) {
item.check = true
}
else {
item.check = false
}
return item
})
setlist([...list])
setformData({
sale_user_id: res.data?.sale_user_id,
sale_user_name: res.data?.sale_user_name,
name: res.data?.name,
short_name: res.data?.short_name,
director: res.data?.director,
phone: res.data?.phone,
addressName: res.data?.province_name + res.data?.city_name + res.data?.district_name,
address_detail: res.data?.address_detail,
purchaser_type: res.data?.purchaser_type,
district_id: res.data?.district_id,
})
setremarkDesc(res.data?.remark)
let arr: any[] = []
arr = [
{ id: res.data.province_id, name: res.data.province_name },
{ id: res.data.city_id, name: res.data.city_name },
{ id: res.data.district_id, name: res.data.district_name },
]
setaddressArr([...arr])
Taro.hideLoading()
}
const [showDesc, setShowDesc] = useState(false)
const getRemark = useCallback(async(e) => {
setShowDesc(false)
setremarkDesc(e)
// setformData((val) => ({ ...val, remark: e }))
}, [])
// 地址选择
const [showSiteModal, setShowSiteModal] = useState(false)
const handleSetSite = (ev) => {
const addressName: any = []
ev.forEach((v) => {
addressName.push(v?.name)
})
if (ev.length === 3) {
setShowSiteModal(false)
setformData(val => ({ ...val, addressName: ev[0]?.name + ev[1]?.name + ev[2]?.name || '', district_id: ev[2]?.id }))
}
}
const onClose = () => {
setShowSiteModal(false)
}
useEffect(() => {
if (router.params.type === 'edit') {
getInfo()
}
}, [])
const isDisabled = useMemo(() => {
let empty: any = null
if (typeof (formData) == 'undefined') { return }
for (const key in formData) {
if (key in formData) {
if (formData[key] !== '' && typeof (formData[key]) !== 'undefined') {
empty = false
}
else {
empty = true
break
}
}
}
return empty
}, [formData])
// 重置
const handReset = () => {
setformData({
sale_user_id: '',
sale_user_name: '',
name: '',
short_name: '',
director: '',
phone: '',
addressName: '',
address_detail: '',
purchaser_type: '',
remark: '',
district_id: '',
})
}
const { fetchData: postFetch } = MpPurchaserPost()
const { fetchData: putFetch } = MpPurchaserPut()
// 提交
const handSure = async() => {
// if (!isDisabled) return false
const query = {
...formData,
remark: remarkDesc,
id: infoObj?.id,
}
if (router.params.type == 'add') {
delete query.id
}
Taro.showModal({
content: '确定要提交吗?',
confirmText: '确认',
cancelText: '取消',
async success(res) {
if (res.confirm) {
const res = await (router.params.type == 'add' ? postFetch(query) : putFetch(query))
Taro.showLoading({
title: '请稍等...',
mask: true,
})
if (res.msg === 'success') {
Taro.showToast({
title: '成功',
})
Taro.hideLoading()
Taro.navigateBack({
delta: 1,
})
}
else {
Taro.showToast({
title: res.msg,
icon: 'error',
})
}
}
},
})
}
return (
<>
`} clickNode={() => setShowDesc(true)}>
{remarkDesc === '' ? '尚未备注信息' : remarkDesc}
setShowDesc(false)}>
getRemark(e)} defaultValue={infoObj?.remark} showInput={!!showDesc} />
handleSetSite(val)} defaultValue={addressArr} addressOnClose={() => onClose()} show={showSiteModal} />
>
)
}
export default CustomerEditor