import React, {Component} from 'react'
|
import PropTypes from 'prop-types'
|
import { is, fromJS } from 'immutable'
|
|
import asyncComponent from '@/utils/asyncComponent'
|
import MKEmitter from '@/utils/events.js'
|
import './index.scss'
|
|
const CardCellComponent = asyncComponent(() => import('../cardcellList'))
|
|
class CardBoxComponent extends Component {
|
static propTpyes = {
|
cards: PropTypes.object, // 卡片行配置信息
|
card: PropTypes.object, // 卡片配置信息
|
data: PropTypes.object,
|
}
|
|
shouldComponentUpdate (nextProps, nextState) {
|
return !is(fromJS(this.props), fromJS(nextProps))
|
}
|
|
/**
|
* @description 组件销毁,清除state更新,清除快捷键设置
|
*/
|
componentWillUnmount () {
|
this.setState = () => {
|
return
|
}
|
}
|
|
openView = (e) => {
|
const { card, data, cards, onClick } = this.props
|
|
onClick && onClick()
|
|
if (!card.setting.click || data.$disabled) return
|
|
e.stopPropagation()
|
|
if (card.setting.click === 'menus') {
|
let menu = null
|
|
if (card.menus && card.menus.length > 0) {
|
let s = data[card.setting.menuType] + ''
|
card.menus.forEach(m => {
|
if (s !== m.sign) return
|
menu = m
|
})
|
}
|
if (!menu) return
|
|
let newtab = {
|
MenuID: menu.MenuID,
|
MenuName: menu.MenuName,
|
type: menu.tabType,
|
param: {$BID: data.$$uuid || ''}
|
}
|
|
Object.keys(data).forEach(key => {
|
if (/^\$/.test(key)) return
|
if (key === 'children') return
|
newtab.param[key] = data[key]
|
})
|
|
MKEmitter.emit('modifyTabs', newtab, true)
|
} else if (card.setting.click === 'menu') {
|
let menuId = card.setting.menu.slice(-1)[0]
|
let menu = null
|
|
if (window.GLOB.mkThdMenus.has(menuId)) {
|
menu = {...window.GLOB.mkThdMenus.get(menuId)}
|
} else if (card.setting.MenuID) {
|
menu = {
|
MenuID: card.setting.MenuID,
|
MenuName: card.setting.MenuName,
|
type: card.setting.tabType
|
}
|
}
|
|
if (!menu) return
|
|
menu.param = {$BID: data.$$uuid || ''}
|
|
Object.keys(data).forEach(key => {
|
if (/^\$/.test(key)) return
|
if (key === 'children') return
|
menu.param[key] = data[key]
|
})
|
|
MKEmitter.emit('modifyTabs', menu, true)
|
} else if (card.setting.click === 'link') {
|
let src = card.setting.linkurl
|
|
if (card.setting.joint === 'true') {
|
let con = '?'
|
|
if (/\?/ig.test(src)) {
|
con = '&'
|
}
|
|
src = src + `${con}id=${data.$$uuid || ''}&appkey=${window.GLOB.appkey}&userid=${sessionStorage.getItem('UserID')}&LoginUID=${sessionStorage.getItem('LoginUID') || ''}`
|
} else if (/@/.test(src)) {
|
src = src.replace(/@id@/ig, data.$$uuid || '')
|
src = src.replace(/@appkey@/ig, window.GLOB.appkey)
|
src = src.replace(/@userid@/ig, sessionStorage.getItem('UserID'))
|
src = src.replace(/@LoginUID@/ig, sessionStorage.getItem('LoginUID'))
|
|
Object.keys(data).forEach(key => {
|
if (/^\$/.test(key)) return
|
let reg = new RegExp('@' + key + '@', 'ig')
|
src = src.replace(reg, data[key])
|
})
|
}
|
|
window.open(src)
|
} else if (card.setting.click === 'button' && card.setting.clickType !== 'multi' && card.setting.linkbtn) {
|
if (data.$$type === 'extendCard') {
|
MKEmitter.emit('triggerBtnId', card.setting.linkbtn, data.$$selectedData || [])
|
} else if (cards.subtype === 'datacard') {
|
MKEmitter.emit('triggerBtnId', card.setting.linkbtn, [data], 'linkbtn', (data.$$uuid || '') + (data.$Index || ''))
|
} else {
|
MKEmitter.emit('triggerBtnId', card.setting.linkbtn, data.$$empty ? [] : [data])
|
}
|
}
|
}
|
|
doubleClick = () => {
|
const { card, data, cards, onDoubleClick } = this.props
|
|
onDoubleClick && onDoubleClick()
|
|
if (card.setting.click !== 'button' || card.setting.clickType !== 'multi' || data.$disabled) return
|
|
if (card.setting.linkbtn) {
|
if (data.$$type === 'extendCard') {
|
MKEmitter.emit('triggerBtnId', card.setting.linkbtn, data.$$selectedData || [])
|
} else if (cards.subtype === 'datacard') {
|
MKEmitter.emit('triggerBtnId', card.setting.linkbtn, [data], 'linkbtn', (data.$$uuid || '') + (data.$Index || ''))
|
} else {
|
MKEmitter.emit('triggerBtnId', card.setting.linkbtn, data.$$empty ? [] : [data])
|
}
|
}
|
}
|
|
render() {
|
const { card, data, cards, children } = this.props
|
let style = {...card.style}
|
let bg = null
|
|
if (card.setting.bgField) {
|
style.backgroundImage = `url('${data[card.setting.bgField] || ''}')`
|
}
|
|
if (style.backgroundImage) {
|
bg = <div className="card-background" style={{backgroundImage: style.backgroundImage}}></div>
|
style.backgroundImage = ''
|
}
|
|
return (
|
<div className={'card-item-box ' + (card.setting.btnControl || '') + (card.setting.click ? ' mk-pointer' : '')} style={style} onClick={this.openView} onDoubleClick={this.doubleClick}>
|
{bg}
|
{children}
|
<CardCellComponent data={data} cards={cards} cardCell={card} elements={card.elements}/>
|
{card.setting.type === 'multi' ? <div className={'back-side ' + card.setting.transform} style={card.backStyle}>
|
<CardCellComponent data={data} cards={cards} cardCell={card} elements={card.backElements}/>
|
</div> : null}
|
</div>
|
)
|
}
|
}
|
|
export default CardBoxComponent
|