import React from 'react'
|
import { useDrag, useDrop } from 'react-dnd'
|
import { Icon, Button, Popover, Switch, Checkbox, Form } from 'antd'
|
import moment from 'moment'
|
|
import asyncComponent from '@/utils/asyncComponent'
|
import './index.scss'
|
|
const CheckCard = asyncComponent(() => import('@/templates/modalconfig/checkCard'))
|
|
const Card = ({ id, card, moveCard, findCard, editCard, closeCard, copyCard, showField }) => {
|
const originalIndex = findCard(id).index
|
const [{ isDragging }, drag] = useDrag({
|
item: { type: 'form', id, originalIndex },
|
collect: monitor => ({
|
isDragging: monitor.isDragging(),
|
}),
|
})
|
const [, drop] = useDrop({
|
accept: 'form',
|
canDrop: () => true,
|
drop: (item) => {
|
const { id: draggedId, originalIndex } = item
|
|
if (originalIndex === undefined) {
|
item.dropTargetId = id
|
} else if (draggedId && draggedId !== id) {
|
const { index: overIndex } = findCard(id)
|
moveCard(draggedId, overIndex)
|
}
|
}
|
})
|
const opacity = isDragging ? 0 : 1
|
|
const edit = () => {
|
editCard(id)
|
}
|
|
const close = () => {
|
closeCard(id)
|
}
|
|
const copy = () => {
|
copyCard(id)
|
}
|
|
let selectval = ''
|
if (card.type === 'select' || card.type === 'link') {
|
if (card.initval) {
|
let _option = card.options.filter(option => option.Value === card.initval)[0]
|
if (_option) {
|
selectval = _option.Text || ''
|
} else {
|
selectval = ''
|
}
|
} else if (card.setAll === 'true') {
|
selectval = card.emptyText || '空'
|
}
|
}
|
|
let formItem = null
|
if (card.type === 'text' || card.type === 'number') {
|
formItem = (<div className="am-list-item"><div className="am-list-line"><div className="am-input-label">{card.label}</div><div className={'am-input-control ' + card.cursor}>{card.initval}</div>{card.scan && card.scan !== 'false' ? <div className="am-list-extra"><Icon type="scan" /></div> : null}</div></div>)
|
} else if (card.type === 'number') {
|
formItem = (<div className="am-list-item"><div className="am-list-line"><div className="am-input-label">{card.label}</div><div className={'am-input-control ' + card.cursor}>{card.initval}</div></div></div>)
|
} else if (card.type === 'select' || card.type === 'link') {
|
formItem = (<div className="am-list-item"><div className="am-list-line"><div className="am-input-label">{card.label}</div><div className="am-input-control">{selectval || '请选择'}</div><div className="am-list-extra"><Icon type="right" /></div></div></div>)
|
} else if (card.type === 'date') {
|
formItem = (<div className="am-list-item"><div className="am-list-line"><div className="am-input-label">{card.label}</div><div className="am-input-control">{card.initval ? moment().subtract(card.initval, 'days').format('YYYY-MM-DD') : '请选择'}</div><div className="am-list-extra"><Icon type="right" /></div></div></div>)
|
} else if (card.type === 'datemonth') {
|
formItem = (<div className="am-list-item"><div className="am-list-line"><div className="am-input-label">{card.label}</div><div className="am-input-control">{card.initval ? moment().subtract(card.initval, 'month').format('YYYY-MM') : '请选择'}</div><div className="am-list-extra"><Icon type="right" /></div></div></div>)
|
} else if (card.type === 'datetime') {
|
formItem = (<div className="am-list-item"><div className="am-list-line"><div className="am-input-label">{card.label}</div><div className="am-input-control">{card.initval ? moment().subtract(card.initval, 'days').format('YYYY-MM-DD HH:mm') : '请选择'}</div><div className="am-list-extra"><Icon type="right" /></div></div></div>)
|
} else if (card.type === 'textarea') {
|
let height = (card.maxRows || 2) * 25
|
formItem = (<div className="am-list-item check-card">
|
<div className="am-list-line">
|
<div className="am-input-label">{card.label}</div>
|
<div className="am-input-control">
|
<div style={{textAlign: 'left', position: 'relative', height, lineHeight: 1.5}}>
|
{card.initval ? card.initval : <span style={{color: '#bcbcbc'}}>{card.placeholder || ''}</span> }
|
{card.count === 'true' ? <span style={{position: 'absolute', right: 0, bottom: 0}}>0/{card.fieldlength}</span> : null}
|
</div>
|
</div>
|
</div>
|
</div>)
|
} else if (card.type === 'fileupload') {
|
formItem = (
|
<div className="am-list-item checkbox">
|
<div className="am-list-line">
|
<div className="am-input-label">{card.label}</div>
|
<div className="am-input-control" style={{textAlign: 'left'}}>
|
{card.fileType !== 'picture-card' ? <Icon type="upload" style={{position: 'absolute', right: '10px', top: '10px'}} /> : null}
|
{card.fileType === 'picture-card' ? <Button style={{width: '100px', marginBottom: '10px', height: '100px', fontSize: '50px', color: '#d9d9d9'}}><Icon type="plus" /></Button> : null}
|
</div>
|
</div>
|
</div>
|
)
|
} else if (card.type === 'funcvar') {
|
formItem = (<div className="am-list-item"><div className="am-list-line"><div className="am-input-label">{card.label}</div><div className="am-input-control">{card.linkfield}</div></div></div>)
|
} else if (card.type === 'switch') {
|
formItem = (<div className="am-list-item"><div className="am-list-line"><div className="am-input-label">{card.label}</div><div className="am-list-switch"><Switch checked={card.initval}/></div></div></div>)
|
} else if (card.type === 'radio') {
|
let options = null
|
if (card.options && card.options.length > 0) {
|
options = card.options
|
} else {
|
options = [
|
{key: 'A', Value: 'A', Text: 'A'},
|
{key: 'B', Value: 'B', Text: 'B'},
|
{key: 'C', Value: 'C', Text: 'C'}
|
]
|
}
|
|
formItem = (
|
<div className={'am-list-item checkbox mk-radio ' + (card.arrange || '')}>
|
<div className="am-list-line">
|
<div className="am-input-label">{card.label}</div>
|
<div className="am-input-control">
|
{card.arrange !== 'line' ? <Checkbox.Group value={[card.initval]}>
|
{options.map(cell => <Checkbox key={cell.key} value={cell.Value}>{cell.Text}</Checkbox>)}
|
</Checkbox.Group> : <div className="mk-radio-group">
|
{options.map(cell => (<div key={cell.key} className="mk-radio-wrapper">
|
<span className="radio-value">{cell.Text}</span>
|
<span className={'radio-check ' + (card.initval === cell.Value ? 'checked' : '')}></span>
|
</div>))}
|
</div>}
|
</div>
|
</div>
|
</div>)
|
} else if (card.type === 'checkbox') {
|
let _val = card.initval ? card.initval.split(',') : []
|
let options = null
|
if (card.options && card.options.length > 0) {
|
options = card.options
|
} else {
|
options = [
|
{key: 'A', Value: 'A', Text: 'A'},
|
{key: 'B', Value: 'B', Text: 'B'},
|
{key: 'C', Value: 'C', Text: 'C'}
|
]
|
}
|
|
formItem = (
|
<div className={'am-list-item checkbox ' + (card.arrange || '')}>
|
<div className="am-list-line">
|
<div className="am-input-label">{card.label}</div>
|
<div className="am-input-control">
|
{<Checkbox.Group value={_val}>
|
{options.map(cell => <Checkbox key={cell.key} value={cell.Value}>{cell.Text}</Checkbox>)}
|
</Checkbox.Group>}
|
</div>
|
</div>
|
</div>
|
)
|
|
} else if (card.type === 'hint') {
|
formItem = <div className="am-list-item hint">
|
<div className="am-list-line">
|
<div className="am-input-label">{card.label}</div>
|
<div className="am-input-control">
|
{card.message}
|
</div>
|
</div>
|
</div>
|
} else if (card.type === 'split') {
|
formItem = <div className="split-line">{card.label}</div>
|
} else if (card.type === 'checkcard') {
|
formItem = (<div className="am-list-item check-card">
|
<div className="am-list-line">
|
{card.hidelabel !== 'true' ? <div className="am-input-label">{card.label}</div> : null}
|
<div className="am-input-control">
|
<CheckCard config={card} />
|
</div>
|
</div>
|
</div>)
|
}
|
|
return (
|
<Popover overlayClassName="mk-popover-control-wrap" mouseLeaveDelay={0.2} mouseEnterDelay={0.2} content={
|
<div className="mk-popover-control">
|
<Icon className="edit" type="edit" onClick={edit} />
|
<Icon className="copy" type="copy" onClick={copy} />
|
<Icon className="close" type="close" onClick={close} />
|
</div>
|
} trigger="hover">
|
<div className="page-card" style={{ opacity: opacity}}>
|
<div ref={node => drag(drop(node))}>
|
{card.type === 'split' ? formItem : <Form.Item
|
className={'ant-form-item' + (card.required === 'true' ? ' required' : '') + (card.splitline === 'false' ? ' no-boder' : '')}
|
>
|
{formItem}
|
{showField ? <div className="field-name">{card.field}{card.hidden === 'true' ? '(隐藏)' : ''}</div> : ''}
|
</Form.Item>}
|
</div>
|
</div>
|
</Popover>
|
)
|
}
|
export default Card
|