import React from 'react'
|
import { useDrag, useDrop } from 'react-dnd'
|
import { fromJS } from 'immutable'
|
import { Button, Popover, Switch, Checkbox, Form, Rate } from 'antd'
|
import { ScanOutlined, RightOutlined, PlusOutlined, StarFilled, EditOutlined, CopyOutlined, CloseOutlined, FontColorsOutlined } from '@ant-design/icons'
|
import moment from 'moment'
|
|
import asyncComponent from '@/utils/asyncComponent'
|
import MkIcon from '@/components/mk-icon'
|
import MKEmitter from '@/utils/events.js'
|
import './index.scss'
|
|
const CheckCard = asyncComponent(() => import('@/templates/modalconfig/checkCard'))
|
|
const Card = ({ id, card, moveCard, findCard, editCard, closeCard, copyCard, showField, setStyle }) => {
|
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.5 : 1
|
|
const edit = () => {
|
editCard(id)
|
}
|
|
const close = () => {
|
closeCard(id)
|
}
|
|
const copy = () => {
|
copyCard(id)
|
}
|
|
const changeStyle = () => {
|
let options = ['font1', 'margin']
|
let style = fromJS(card.style || {}).toJS()
|
|
if (card.marginTop && !style.marginTop) { // 外边距设置转移
|
style.marginTop = card.marginTop
|
}
|
if (card.marginBottom && !style.marginBottom) {
|
style.marginBottom = card.marginBottom
|
}
|
|
MKEmitter.emit('changeStyle', options, style, (s) => {setStyle(s, 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 = ''
|
}
|
}
|
}
|
|
let formItem = null
|
if (card.type === 'text' || card.type === 'linkMain') {
|
formItem = (<div className={'am-list-item input ' + (card.place || '')}><div className="am-list-line"><div className="am-input-label">{card.label}</div><div className={'am-input-control ' + card.cursor}>{card.initval ? card.initval : <span style={{color: '#bcbcbc'}}>{card.placeholder || <span style={{color: 'transparent'}}>input</span>}</span> }</div>{card.scan && card.scan !== 'false' ? <div className="am-list-extra"><ScanOutlined /></div> : null}</div></div>)
|
} else if (card.type === 'number') {
|
formItem = (<div className={'am-list-item input ' + (card.place || '')}><div className="am-list-line"><div className="am-input-label">{card.label}</div><div className={'am-input-control ' + card.cursor}>{card.initval || 0}</div>{card.placeholder ? <div className="am-list-extra" style={{color: '#999999', width: 'auto', lineHeight: 1.5, height: '22px'}}>{card.placeholder}</div> : null}</div></div>)
|
} else if (card.type === 'number') {
|
formItem = (<div className="am-list-item input"><div className="am-list-line"><div className="am-input-label">{card.label}</div><div className={'am-input-control ' + card.cursor}>{card.initval || <span style={{color: 'transparent'}}>input</span>}</div></div></div>)
|
} else if (card.type === 'select' || card.type === 'link' || card.type === 'cascader') {
|
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"><RightOutlined /></div></div></div>)
|
} else if (card.type === 'date') {
|
let format = 'YYYY-MM-DD'
|
if (card.precision === 'hour') {
|
format = 'YYYY-MM-DD HH'
|
} else if (card.precision === 'minute') {
|
format = 'YYYY-MM-DD HH:mm'
|
} else if (card.precision === 'second') {
|
format = 'YYYY-MM-DD HH:mm:ss'
|
}
|
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(format) : '请选择'}</div><div className="am-list-extra"><RightOutlined /></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"><RightOutlined /></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"><RightOutlined /></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 === 'rate') {
|
formItem = (<div className={'am-list-item ' + (card.place || '')}><div className="am-list-line"><div className="am-input-label">{card.label}</div><div style={{textAlign: 'left'}} className={'am-input-control ' + (card.place === 'up_down' ? 'left' : '')}>
|
<Rate value={card.initval || 0} count={card.rateCount || 5} character={card.character ? <MkIcon type={card.character}/> : <StarFilled />} allowHalf={card.allowHalf === 'true'} />
|
</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'}}>
|
<Button style={{width: '100px', marginBottom: '10px', height: '100px', fontSize: '50px', color: '#d9d9d9'}}><PlusOutlined /></Button>
|
</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 === 'formula') {
|
formItem = <div className="am-list-item formula">
|
<div className="am-list-line">
|
<div className="am-input-label">{card.label}</div>
|
<div className="am-input-control">
|
{card.formula}{card.postfix || ''}
|
</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>)
|
} else if (card.type === 'vercode') {
|
formItem = <div className="am-list-item"><div className="am-list-line"><div className="am-input-label">{card.label}</div><div className="am-input-control"><span style={{color: '#bcbcbc'}}>{card.placeholder || ''}</span></div><div className="am-list-extra" style={{width: 'auto', height: 'auto', backgroundColor: '#fafafa', padding: '0 15px'}}>获取验证码</div></div></div>
|
}
|
|
let className = `${card.required === 'true' ? 'required' : ''} ${card.type === 'split' ? 'split-wrap' : ''} ${card.splitline === 'false' ? 'no-boder' : ''}`
|
|
if (window.GLOB.formId === card.uuid) {
|
className += ' actived'
|
}
|
|
let style = {...card.style}
|
|
if (card.marginTop && !style.marginTop) { // 外边距设置转移
|
style.marginTop = card.marginTop
|
}
|
if (card.marginBottom && !style.marginBottom) {
|
style.marginBottom = card.marginBottom
|
}
|
|
return (
|
<Popover overlayClassName="mk-popover-control-wrap" mouseLeaveDelay={0.2} mouseEnterDelay={0.2} content={
|
<div className="mk-popover-control">
|
<EditOutlined className="edit" onClick={edit} />
|
<CopyOutlined className="copy" onClick={copy} />
|
<FontColorsOutlined className="style" onClick={changeStyle} />
|
<CloseOutlined className="close" onClick={close} />
|
</div>
|
} trigger="hover">
|
<div className="page-card" style={{ opacity: opacity}}>
|
<div ref={node => drag(drop(node))} style={{ border: '0.5px solid transparent'}} onDoubleClick={edit}>
|
<Form.Item
|
style={style}
|
className={className}
|
>
|
{formItem}
|
<div></div>
|
{showField && card.field ? <div className="field-name" style={card.writein === 'false' ? {color: 'orange'} : {}}>
|
{card.field}{card.hidden === 'true' || card.type === 'funcvar' ? '(隐藏)' : ''}{card.readonly === 'true' ? '(只读)' : ''}{card.linkField ? <span style={{color: '#1890ff'}}>{`(关联${card.linkField})`}</span> : ''}{card.supField ? <span style={{color: '#8E44AD'}}>{`(上级${card.supField})`}</span> : ''}
|
</div> : ''}
|
</Form.Item>
|
</div>
|
</div>
|
</Popover>
|
)
|
}
|
export default Card
|