From 60bc7643d20c80740711dd1de1cff37c01222d3d Mon Sep 17 00:00:00 2001
From: king <18310653075@163.com>
Date: 星期二, 18 七月 2023 15:22:31 +0800
Subject: [PATCH] 2023-07-18
---
src/tabviews/custom/components/share/normalTable/index.jsx | 608 ++++++++++++++++++++++++++++++++++--------------------
1 files changed, 379 insertions(+), 229 deletions(-)
diff --git a/src/tabviews/custom/components/share/normalTable/index.jsx b/src/tabviews/custom/components/share/normalTable/index.jsx
index e56e977..b16b14a 100644
--- a/src/tabviews/custom/components/share/normalTable/index.jsx
+++ b/src/tabviews/custom/components/share/normalTable/index.jsx
@@ -1,18 +1,19 @@
import React, {Component} from 'react'
import PropTypes from 'prop-types'
import md5 from 'md5'
-import { connect } from 'react-redux'
import { is, fromJS } from 'immutable'
-import { Table, Typography, Icon, Col, Switch, message } from 'antd'
+import { Table, Typography, Col, Switch, message } from 'antd'
import asyncComponent from '@/utils/asyncComponent'
+import { getMark } from '@/utils/utils.js'
import MKEmitter from '@/utils/events.js'
-import zhCN from '@/locales/zh-CN/main.js'
-import enUS from '@/locales/en-US/main.js'
-import '@/assets/css/table.scss'
+import Encrypts from '@/components/encrypts'
import './index.scss'
const { Paragraph } = Typography
+const Video = asyncComponent(() => import('@/components/video'))
+const MkIcon = asyncComponent(() => import('@/components/mk-icon'))
+const MkPicture = asyncComponent(() => import('@/components/mkPicture'))
const CardCellComponent = asyncComponent(() => import('@/tabviews/custom/components/card/cardcellList'))
const PicRadio = {
'4:3': '75%', '3:2': '66.67%', '16:9': '56.25%', '2:1': '50%', '3:1': '33.33%', '4:1': '25%',
@@ -21,12 +22,16 @@
}
class BodyRow extends React.Component {
shouldComponentUpdate (nextProps, nextState) {
- return !is(fromJS(this.props.data), fromJS(nextProps.data)) || !is(fromJS(this.props.className), fromJS(nextProps.className))
+ return !is(fromJS(this.props.data), fromJS(nextProps.data)) || this.props.className !== nextProps.className
}
render() {
let { lineMarks, onDoubleClick, data, className, ...resProps } = this.props
let style = {}
+
+ if (data && data.$disabled) {
+ className = className + ' mk-disabled '
+ }
if (lineMarks && lineMarks.length > 0) {
lineMarks.some(mark => {
@@ -78,7 +83,7 @@
if (mark.fontColor) {
style.color = mark.fontColor
}
- className += className + ' background'
+ className = className + ' background'
} else if (mark.signType[0] === 'underline') {
style.textDecoration = 'underline'
style.color = mark.color
@@ -97,77 +102,6 @@
}
class BodyCell extends React.Component {
- getMark = (record, marks, style, content) => {
- marks.some(mark => {
- let originVal = record[mark.field[0]] + ''
- let contrastVal = ''
- let result = false
-
- if (mark.field[1] === 'static') {
- contrastVal = mark.contrastValue + ''
- } else {
- contrastVal = record[mark.field[2]] + ''
- }
-
- if (mark.match === '=') {
- result = originVal === contrastVal
- } else if (mark.match === '!=') {
- result = originVal !== contrastVal
- } else if (mark.match === 'like') {
- result = originVal.indexOf(contrastVal) > -1
- } else if (mark.match === '>') {
- try {
- originVal = parseFloat(originVal)
- contrastVal = parseFloat(contrastVal)
- } catch (e) {
- originVal = NaN
- }
-
- if (!isNaN(originVal) && !isNaN(contrastVal) && originVal > contrastVal) {
- result = true
- }
- } else if (mark.match === '<') {
- try {
- originVal = parseFloat(originVal)
- contrastVal = parseFloat(contrastVal)
- } catch (e) {
- originVal = NaN
- }
-
- if (!isNaN(originVal) && !isNaN(contrastVal) && originVal < contrastVal) {
- result = true
- }
- }
-
- if (result) {
- if (mark.signType[0] === 'font') {
- style.color = mark.color
- } else if (mark.signType[0] === 'background') {
- style.background = mark.color
- if (mark.fontColor) {
- style.color = mark.fontColor
- }
- } else if (mark.signType[0] === 'underline') {
- style.textDecoration = 'underline'
- style.color = mark.color
- } else if (mark.signType[0] === 'line-through') {
- style.textDecoration = 'line-through'
- style.color = mark.color
- } else if (mark.signType[0] === 'icon') {
- let icon = (<Icon style={{color: mark.color}} type={mark.signType[3]} />)
- if (mark.signType[1] === 'front') {
- content = <span>{icon} {content}</span>
- } else {
- content = <span>{content} {icon}</span>
- }
- }
- }
- return result
- })
-
- return content
- }
-
shouldComponentUpdate (nextProps, nextState) {
return !nextProps.record || !is(fromJS(this.props.record), fromJS(nextProps.record))
}
@@ -188,14 +122,29 @@
content = `${content.substr(0, 4)}-${content.substr(5, 2)}-${content.substr(8, 2)}`
} else if (col.textFormat === 'YYYY-MM-DD HH:mm:ss' && /^[1-9]\d{3}(-|\/)(0[1-9]|1[0-2])(-|\/)(0[1-9]|[1-2][0-9]|3[0-1]).([0-1][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9]/.test(content)) {
content = `${content.substr(0, 4)}-${content.substr(5, 2)}-${content.substr(8, 2)} ${content.substr(11, 2)}:${content.substr(14, 2)}:${content.substr(17, 2)}`
+ } else if (col.textFormat === 'encryption') {
+ content = <span>{col.prefix || ''}<Encrypts value={content} />{col.postfix || ''}</span>
}
-
- content = (col.prefix || '') + content + (col.postfix || '')
+
+ if (col.textFormat !== 'encryption') {
+ content = (col.prefix || '') + content + (col.postfix || '')
+ }
}
if (col.marks) {
- style = style || {}
- content = this.getMark(record, col.marks, style, content)
+ let mark = getMark(col.marks, record, style)
+
+ style = mark.style
+
+ if (mark.icon) {
+ if (mark.position === 'front') {
+ content = <span><MkIcon style={mark.innerStyle} type={mark.icon} /> {content}</span>
+ } else {
+ content = <span>{content} <MkIcon style={mark.innerStyle} type={mark.icon} /></span>
+ }
+ } else if (mark.innerStyle) {
+ content = <span style={mark.innerStyle}>{content}</span>
+ }
}
if (col.blur) {
content = md5(content)
@@ -205,7 +154,7 @@
resProps.rowSpan = record['$$' + col.field]
}
- if (col.linkThdMenu || col.linkurl) {
+ if (!record.$disabled && (col.linkThdMenu || col.linkurl)) {
content = (
<div>
<div className="link-menu" onDoubleClick={(e) => triggerLink(e, col, record)}></div>
@@ -227,24 +176,39 @@
}
if (content !== '') {
- let decimal = col.decimal || 0
+ if (col.round) {
+ content = Math.round(content * col.round) / col.round
+ }
if (col.format === 'percent') {
content = content * 100
- decimal = decimal > 2 ? decimal - 2 : 0
+ } else if (col.format === 'abs') {
+ content = Math.abs(content)
}
-
- content = content.toFixed(decimal)
+ if (col.round) {
+ content = content.toFixed(col.decimal)
+ }
if (col.format === 'thdSeparator') {
content = content.replace(/\d{1,3}(?=(\d{3})+(\.\d*)?$)/g, '$&,')
}
- content = col.prefix + content + col.postfix
+ content = (col.prefix || '') + content + (col.postfix || '')
}
if (col.marks) {
- style = style || {}
- content = this.getMark(record, col.marks, style, content)
+ let mark = getMark(col.marks, record, style)
+
+ style = mark.style
+
+ if (mark.icon) {
+ if (mark.position === 'front') {
+ content = <span><MkIcon style={mark.innerStyle} type={mark.icon} /> {content}</span>
+ } else {
+ content = <span>{content} <MkIcon style={mark.innerStyle} type={mark.icon} /></span>
+ }
+ } else if (mark.innerStyle) {
+ content = <span style={mark.innerStyle}>{content}</span>
+ }
}
if (col.blur) {
@@ -255,7 +219,7 @@
resProps.rowSpan = record['$$' + col.field]
}
- if (col.linkThdMenu || col.linkurl) {
+ if (!record.$disabled && (col.linkThdMenu || col.linkurl)) {
content = (
<div>
<div className="link-menu" onDoubleClick={(e) => triggerLink(e, col, record)}></div>
@@ -269,10 +233,14 @@
let photos = ''
if (record[col.field]) {
photos = `${record[col.field]}`
- photos = photos.split(',')
}
- let cols = 24 / (col.picSort || 1)
+ if (/^data:image/.test(photos)) {
+ photos = [photos]
+ } else {
+ photos = photos.split(',').filter(Boolean)
+ }
+
let paddingTop = '100%'
let scale = col.scale === 'true'
@@ -282,14 +250,19 @@
resProps.children = (
<div>
- {photos && photos.map((url, i) => (
- <Col key={i} span={cols}>
- <div className={'ant-mk-picture' + (scale ? ' scale' : '')} onClick={() => {
- if (!scale) return
- MKEmitter.emit('mkImageScale', url, photos)
- }} style={{paddingTop, backgroundImage: `url('${url}')`}}></div>
+ {photos.map((url, i) => (
+ <Col key={i} span={col.span || 24}>
+ <MkPicture style={{paddingTop, backgroundSize: col.backgroundSize || 'cover'}} scale={scale} url={url} urls={photos}/>
</Col>
))}
+ </div>
+ )
+ } else if (col.type === 'video') {
+ let url = record[col.field] || ''
+
+ resProps.children = (
+ <div className="video-wrap">
+ {url ? <Video card={col} value={url}/> : null}
</div>
)
} else if (col.type === 'textarea') {
@@ -299,7 +272,7 @@
}
if (content) {
- content = col.prefix + content + col.postfix
+ content = (col.prefix || '') + content + (col.postfix || '')
}
if (col.blur) {
@@ -346,22 +319,86 @@
content = md5(content)
}
+ if (_href && /^https/.test(window.location.protocol)) { // https杞崲
+ _href = _href.replace(/^http:/ig, 'https:')
+ }
+
resProps.children = (
<div>
{content && _href ? <a href={_href} target="_blank" rel="noopener noreferrer">{content}</a> : null }
</div>
)
+ } else if (col.type === 'formula') {
+ let content = col.formula
+
+ if (col.eval === 'func') {
+ try {
+ // eslint-disable-next-line
+ let func = new Function('data', col.formula)
+ content = func([record])
+ } catch (e) {
+ if (window.debugger) {
+ console.warn(e)
+ }
+ content = ''
+ }
+ } else {
+ Object.keys(record).forEach(key => {
+ let reg = new RegExp('@' + key + '@', 'ig')
+ content = content.replace(reg, record[key])
+ })
+ if (col.eval !== 'false') {
+ try {
+ // eslint-disable-next-line
+ content = eval(content)
+ } catch (e) {
+ if (window.debugger) {
+ console.info(content)
+ console.warn(e)
+ }
+ content = ''
+ }
+
+ if (col.round && typeof(content) === 'number') {
+ content = Math.round(content * col.round) / col.round
+ content = content.toFixed(col.decimal)
+ }
+ }
+ }
+
+ content = content === undefined ? '' : content
+
+ if (col.eval === 'func') {
+ content = <span dangerouslySetInnerHTML={{__html: content}}></span>
+ } else if (content !== '') {
+ content = `${col.prefix || ''}${content}${col.postfix || ''}`
+ content = content.replace(/\n/ig, '<br/>').replace(/\s/ig, ' ')
+ content = <span dangerouslySetInnerHTML={{__html: content}}></span>
+ }
+
+ if (col.marks) {
+ let mark = getMark(col.marks, record, style)
+
+ style = mark.style
+
+ if (mark.icon) {
+ if (mark.position === 'front') {
+ content = <span><MkIcon style={mark.innerStyle} type={mark.icon} /> {content}</span>
+ } else {
+ content = <span>{content} <MkIcon style={mark.innerStyle} type={mark.icon} /></span>
+ }
+ } else if (mark.innerStyle) {
+ content = <span style={mark.innerStyle}>{content}</span>
+ }
+ }
+
+ resProps.children = content
} else if (col.type === 'custom') {
style.padding = '0px'
if (col.style) {
style = {...style, ...col.style}
}
- resProps.children = (
- <CardCellComponent data={record} cards={config} elements={col.elements}/>
- )
- } else if (col.type === 'action') {
- style.padding = '0px 5px'
resProps.children = (
<CardCellComponent data={record} cards={config} elements={col.elements}/>
)
@@ -380,17 +417,15 @@
columns: PropTypes.array, // 琛ㄦ牸鍒�
lineMarks: PropTypes.array, // 琛屾爣璁�
fields: PropTypes.array, // 缁勪欢瀛楁闆�
- ContainerId: PropTypes.any, // 鏍囩椤靛灞侷d
- BData: PropTypes.any, // 涓昏〃鏁版嵁
data: PropTypes.any, // 琛ㄦ牸鏁版嵁
total: PropTypes.any, // 鎬绘暟
loading: PropTypes.bool, // 琛ㄦ牸鍔犺浇涓�
refreshdata: PropTypes.func, // 琛ㄦ牸涓帓搴忓垪銆侀〉鐮佺殑鍙樺寲鏃跺埛鏂�
chgSelectData: PropTypes.func, // 鏁版嵁鍒囨崲
+ autoMatic: PropTypes.any
}
state = {
- dict: sessionStorage.getItem('lang') !== 'en-US' ? zhCN : enUS,
tableId: '', // 琛ㄦ牸ID
selectedRowKeys: [], // 琛ㄦ牸涓�変腑琛�
pageIndex: 1, // 鍒濆椤甸潰绱㈠紩
@@ -399,72 +434,92 @@
activeIndex: null, // 鏍囪褰撳墠閫変腑琛�
rowspans: null, // 琛屽悎骞跺瓧娈典俊鎭�
pickup: false, // 鏀惰捣鏈�夋嫨椤�
- orderfields: {} // 鎺掑簭id涓巉ield杞崲
+ orderfields: {}, // 鎺掑簭id涓巉ield杞崲
+ pageOptions: []
}
UNSAFE_componentWillMount () {
- const { menuType, memberLevel, setting, fields, columns } = this.props
+ const { setting, fields, columns } = this.props
let radio = 5 // 铏氬寲姣斾緥
let _format = false // 鏄惁铏氬寲澶勭悊
let rowspans = []
let orderfields = {}
- if (window.GLOB.dataFormat && menuType !== 'HS' && memberLevel) {
+ if (window.GLOB.dataFormat && !window.GLOB.mkHS) {
_format = true
- if (memberLevel >= 30) {
+ if (window.GLOB.memberLevel >= 30) {
radio = 20
- } else if (memberLevel >= 20) {
+ } else if (window.GLOB.memberLevel >= 20) {
radio = 10
}
}
- let getColumns = (cols) => {
- return cols.map(item => {
- let cell = null
-
- if (item.type === 'colspan') {
- cell = { title: item.label, align: item.Align }
- cell.children = getColumns(item.subcols)
- } else {
- if (item.rowspan === 'true') {
- rowspans.push(item.field)
- }
- if (item.type === 'index') {
- item.field = '$Index'
- item.type = 'text'
- } else if (_format && !Math.floor(Math.random() * radio)) {
- item.blur = true
- }
-
- if (item.marks && item.marks.length === 0) {
- item.marks = ''
- }
+ let _columns = []
- if (item.field) {
- orderfields[item.uuid] = item.field
- }
-
- cell = {
- align: item.Align,
- dataIndex: item.uuid,
- title: item.label,
- sorter: item.field && item.IsSort === 'true',
- width: item.Width || 120,
- onCell: record => ({
- record,
- col: item,
- config: item.type === 'custom' || item.type === 'action' ? {setting, columns: fields} : null,
- triggerLink: this.triggerLink
- })
- }
- }
+ if (setting.tableMode !== 'fast') {
+ let getColumns = (cols) => {
+ return cols.map(item => {
+ let cell = null
+
+ if (item.type === 'colspan') {
+ cell = { title: item.label, align: item.Align }
+ cell.children = getColumns(item.subcols)
+ } else {
+ if (item.rowspan === 'true') {
+ rowspans.push(item.field)
+ }
+ if (item.type === 'index') {
+ item.field = '$Index'
+ item.type = 'text'
+ } else if (_format && !Math.floor(Math.random() * radio)) {
+ item.blur = true
+ }
+
+ if (item.marks && item.marks.length === 0) {
+ item.marks = ''
+ }
- return cell
+ if (item.field) {
+ orderfields[item.uuid] = item.field
+ }
+
+ cell = {
+ align: item.Align,
+ dataIndex: item.uuid,
+ title: item.label,
+ sorter: item.field && item.IsSort === 'true',
+ width: item.Width || 120,
+ onCell: record => ({
+ record,
+ col: item,
+ config: item.type === 'custom' ? {setting, columns: fields} : null,
+ triggerLink: this.triggerLink
+ })
+ }
+ }
+
+ return cell
+ })
+ }
+ _columns = getColumns(columns)
+ } else {
+ let fields = []
+ columns.forEach(item => {
+ if (!item.field || fields.includes(item.field)) return
+ fields.push(item.field)
+
+ _columns.push({
+ align: item.Align,
+ dataIndex: item.field,
+ title: item.label,
+ sorter: item.IsSort === 'true',
+ width: item.Width || 120
+ })
})
- }
- let _columns = getColumns(columns)
+ orderfields = null
+ }
if (rowspans.length === 0) {
rowspans = null
@@ -479,18 +534,27 @@
return uuid.join('')
}) ()
- if (setting.borderColor) { // 杈规棰滆壊
- let style = `#${tableId} table, #${tableId} tr, #${tableId} th, #${tableId} td {border-color: ${setting.borderColor}}`
- let ele = document.createElement('style')
- ele.innerHTML = style
- document.getElementsByTagName('head')[0].appendChild(ele)
+ let size = (setting.pageSize || 10) + ''
+ let pageOptions = ['10', '25', '50', '100', '500', '1000']
+
+ if (!pageOptions.includes(size)) {
+ pageOptions.push(size)
+ pageOptions = pageOptions.sort((a, b) => a - b)
}
this.setState({
+ pageSize: setting.pageSize || 10,
+ pageOptions,
columns: _columns,
rowspans,
tableId,
orderfields
+ }, () => {
+ const element = document.getElementById(tableId)
+ element && element.style.setProperty('--mk-table-border-color', setting.borderColor || '#e8e8e8')
+ element && element.style.setProperty('--mk-table-color', setting.color || 'rgba(0, 0, 0, 0.65)')
+ element && element.style.setProperty('--mk-table-font-size', setting.fontSize || '14px')
+ element && element.style.setProperty('--mk-table-font-weight', setting.fontWeight || 'normal')
})
}
@@ -499,9 +563,17 @@
}
componentDidMount () {
- MKEmitter.addListener('mkCheckTopLine', this.mkCheckTopLine)
+ const { autoMatic } = this.props
+
MKEmitter.addListener('mkCheckAll', this.mkCheckAll)
MKEmitter.addListener('resetTable', this.resetTable)
+
+ if (autoMatic === true) {
+ MKEmitter.addListener('autoQueryData', this.autoQueryData)
+ MKEmitter.addListener('autoSelectData', this.autoSelectData)
+ }
+
+ MKEmitter.addListener('mkCheckTopLine', this.mkCheckTopLine)
}
/**
@@ -511,22 +583,95 @@
this.setState = () => {
return
}
- MKEmitter.removeListener('mkCheckTopLine', this.mkCheckTopLine)
MKEmitter.removeListener('mkCheckAll', this.mkCheckAll)
MKEmitter.removeListener('resetTable', this.resetTable)
+ MKEmitter.removeListener('autoQueryData', this.autoQueryData)
+ MKEmitter.removeListener('autoSelectData', this.autoSelectData)
+ MKEmitter.removeListener('mkCheckTopLine', this.mkCheckTopLine)
}
- mkCheckTopLine = (menuId) => {
+ autoSelectData = (id, index) => {
+ if (id !== this.props.MenuID) return
+
+ const { pageSize, pageIndex } = this.state
+
+ let i = index - (pageIndex - 1) * pageSize - 1
+
+ if (this.props.data[i]) {
+ this.changeRow(this.props.data[i], i)
+ MKEmitter.emit('autoTransSelectData', this.props.MenuID, this.props.data[i])
+ } else {
+ MKEmitter.emit('autoMaticOver', this.props.MenuID)
+ }
+ }
+
+ autoQueryData = (id, index) => {
+ if (id !== this.props.MenuID) return
+
+ const { total } = this.props
+ const { pageSize } = this.state
+
+ if (index !== 1 && (!total || index > total)) {
+ MKEmitter.emit('autoMaticOver', this.props.MenuID)
+ return
+ }
+
+ console.clear()
+
+ let pageIndex = Math.ceil(index / pageSize)
+
+ this.setState({
+ pageIndex: pageIndex,
+ selectedRowKeys: [],
+ activeIndex: null
+ })
+
+ this.props.refreshdata({pageIndex})
+ }
+
+ mkCheckTopLine = (menuId, id, type) => {
const { MenuID, data, setting } = this.props
if (MenuID !== menuId || !data || data.length === 0) return
- this.changedata(0)
- this.setState({ selectedRowKeys: [0], activeIndex: 0 })
- this.props.chgSelectData([data[0]])
+ if (type === 'sign') {
+ let index = ''
+ let keys = []
+ let items = []
+ data.forEach((item, i) => {
+ if (!item.$disabled && item.selected === 'true') {
+ items.push(item)
+ keys.push(i)
+ index = i
+ }
+ })
+
+ this.changedata(index)
+ this.setState({ selectedRowKeys: keys, activeIndex: index })
+ this.props.chgSelectData(items)
+
+ if (setting.$hasSyncModule) {
+ MKEmitter.emit('syncBalconyData', MenuID, items, data.length === keys.length)
+ }
+ return
+ }
+
+ let index = 0
+ if (id) {
+ index = data.findIndex(item => item.$$uuid === id)
+ if (index === -1) {
+ index = 0
+ }
+ }
+
+ if (data[index].$disabled) return
+
+ this.changedata(index)
+ this.setState({ selectedRowKeys: [index], activeIndex: index })
+ this.props.chgSelectData([data[index]])
if (setting.$hasSyncModule) {
- MKEmitter.emit('syncBalconyData', MenuID, [data[0]], data.length === 1)
+ MKEmitter.emit('syncBalconyData', MenuID, [data[index]], data.length === 1)
}
}
@@ -582,42 +727,24 @@
tabmenu.param = __param
- if (['linkage_navigation', 'linkage', 'menu_board'].includes(window.GLOB.navBar)) {
- MKEmitter.emit('modifyTabs', tabmenu, 'replace')
- } else {
- MKEmitter.emit('modifyTabs', tabmenu, 'plus')
- }
+ MKEmitter.emit('modifyTabs', tabmenu, true)
} else if (item.linkurl) {
let src = item.linkurl
- if (src.indexOf('paramsmain/') > -1) {
- try {
- let _url = item.linkurl.split('paramsmain/')[0] + 'paramsmain/'
- let _param = JSON.parse(window.decodeURIComponent(window.atob(item.linkurl.split('paramsmain/')[1])))
- _param.UserID = sessionStorage.getItem('UserID')
- _param.LoginUID = sessionStorage.getItem('LoginUID')
- _param.User_Name = sessionStorage.getItem('User_Name')
- _param.param = __param
- src = _url + window.btoa(window.encodeURIComponent(JSON.stringify(_param)))
- } catch (e) {
- console.warn('鑿滃崟鍙傛暟瑙f瀽閿欒锛�')
- }
- } else {
- let con = '?'
+ let con = '?'
- if (/\?/ig.test(src)) {
- con = '&'
- }
-
- if (item.linkfields && item.linkfields.length > 0) {
- item.linkfields.forEach(field => {
- if (field.toLowerCase() === 'id') return
- con += `${field}=${record[field] || ''}&`
- })
- }
-
- src = src + `${con}id=${record.$$uuid}&appkey=${window.GLOB.appkey}&userid=${sessionStorage.getItem('UserID')}&LoginUID=${sessionStorage.getItem('LoginUID') || ''}`
+ if (/\?/ig.test(src)) {
+ con = '&'
}
+
+ if (item.linkfields && item.linkfields.length > 0) {
+ item.linkfields.forEach(field => {
+ if (field.toLowerCase() === 'id') return
+ con += `${field}=${record[field] || ''}&`
+ })
+ }
+
+ src = src + `${con}id=${record.$$uuid}&appkey=${window.GLOB.appkey}&userid=${sessionStorage.getItem('UserID')}&LoginUID=${sessionStorage.getItem('LoginUID') || ''}`
window.open(src)
}
@@ -626,12 +753,13 @@
/**
*
*/
- onSelectChange = selectedRowKeys => {
+ onSelectChange = (selectedRowKeys, e) => {
const { setting, MenuID, data } = this.props
let index = ''
let _activeIndex = null
if (selectedRowKeys.length > 0) {
+ selectedRowKeys = selectedRowKeys.filter(key => !data[key].$disabled)
index = selectedRowKeys.slice(-1)[0]
}
@@ -643,7 +771,7 @@
this.setState({ selectedRowKeys, activeIndex: _activeIndex })
- let selects = this.props.data.filter((item, _index) => selectedRowKeys.includes(_index))
+ let selects = data.filter((item, _index) => selectedRowKeys.includes(_index) && !item.$disabled)
this.props.chgSelectData(selects)
if (setting.$hasSyncModule) {
@@ -658,6 +786,7 @@
const { setting, MenuID, data } = this.props
if (!setting.tableType || this.state.pickup) return
+ if (record.$disabled) return
let newkeys = fromJS(this.state.selectedRowKeys).toJS()
@@ -682,7 +811,7 @@
this.setState({ selectedRowKeys: newkeys, activeIndex: _index !== '' ? _index : null })
}
- let selects = this.props.data.filter((item, _index) => newkeys.includes(_index))
+ let selects = this.props.data.filter((item, _index) => newkeys.includes(_index) && !item.$disabled)
this.props.chgSelectData(selects)
@@ -702,32 +831,43 @@
pickup: false
})
- sorter.field = orderfields[sorter.field] || ''
+ if (orderfields) {
+ sorter.field = orderfields[sorter.field] || ''
+ }
this.props.refreshdata(pagination, filters, sorter)
}
changedata = (index) => {
- const { MenuID, data, setting } = this.props
+ const { MenuID, data } = this.props
let _id = ''
let _data = ''
if (data && data.length > 0 && index !== '') {
- _id = data[index][setting.primaryKey] || ''
+ _id = data[index].$$uuid || ''
_data = data[index] || ''
}
+
+ if (_data && _data.$disabled) return
MKEmitter.emit('resetSelectLine', MenuID, _id, _data)
}
- resetTable = (id, repage) => {
+ resetTable = (id, repage, pageIndex) => {
const { MenuID } = this.props
if (id !== MenuID) return
if (repage === 'false') {
this.setState({
+ selectedRowKeys: [],
+ activeIndex: null,
+ pickup: false
+ })
+ } else if (repage === 'repage') {
+ this.setState({
+ pageIndex: pageIndex,
selectedRowKeys: [],
activeIndex: null,
pickup: false
@@ -806,13 +946,14 @@
const { setting } = this.props
if (!setting.doubleClick) return
+ if (record.$disabled) return
- MKEmitter.emit('triggerBtnId', setting.doubleClick, [record])
+ MKEmitter.emit('triggerBtnId', setting.doubleClick, [record], 'linkbtn')
}
render() {
const { setting, statFValue, lineMarks, data } = this.props
- const { selectedRowKeys, activeIndex, pickup, tableId } = this.state
+ const { selectedRowKeys, activeIndex, pickup, tableId, pageOptions, columns } = this.state
// 璁剧疆琛ㄦ牸閫夋嫨灞炴�э細鍗曢�夈�佸閫夈�佷笉鍙��
let rowSelection = null
@@ -824,11 +965,14 @@
}
}
- const components = {
+ let components = {
body: {
- row: BodyRow,
- cell: BodyCell
+ row: BodyRow
}
+ }
+
+ if (setting.tableMode !== 'fast') {
+ components.body.cell = BodyCell
}
// 鏁版嵁鏀惰捣鏃讹紝杩囨护宸查�夋暟鎹�
@@ -845,10 +989,10 @@
_pagination = {
current: this.state.pageIndex,
pageSize: this.state.pageSize,
- pageSizeOptions: ['10', '25', '50', '100', '500', '1000'],
+ pageSizeOptions: pageOptions,
showSizeChanger: true,
total: this.props.total || 0,
- showTotal: (total, range) => `${range[0]}-${range[1]} ${this.state.dict['main.pagination.of']} ${total} ${this.state.dict['main.pagination.items']}`
+ showTotal: (total, range) => `${range[0]}-${range[1]} 鍏� ${total} 鏉
}
}
@@ -859,26 +1003,43 @@
}
let height = setting.height || false
+ if (height && height <= 100) {
+ height = height + 'vh'
+ }
+ let loading = this.props.loading
+ if (setting.mask === 'hidden') {
+ loading = false
+ }
+
+ let fixed = ''
+ if (setting.colfixed && setting.colfixed.length) {
+ if (setting.colfixed.includes('first')) {
+ fixed = 'mk-fixed-first-col'
+ }
+ if (setting.colfixed.includes('last')) {
+ fixed += ' mk-fixed-last-col'
+ }
+ }
return (
- <div className={`normal-custom-table ${setting.tableHeader || ''} ${height ? 'fixed-height' : ''} ${setting.mode || ''}`} id={tableId}>
+ <div className={`normal-custom-table ${setting.tableHeader || ''} ${height ? 'fixed-height' : ''} ${setting.mode || ''} table-vertical-${setting.vertical || 'middle'} table-col-${columns.length} ${fixed}`} id={tableId}>
{(setting.tableType === 'radio' || setting.tableType === 'checkbox') && data && data.length > 0 ?
<Switch title="鏀惰捣" className="main-pickup" checkedChildren="寮�" unCheckedChildren="鍏�" checked={pickup} onChange={this.pickupChange} /> : null
}
<Table
components={components}
- style={setting.style}
size={setting.size || 'middle'}
bordered={setting.bordered !== 'false'}
rowSelection={rowSelection}
- columns={this.state.columns}
+ columns={columns}
dataSource={_data}
- loading={this.props.loading}
+ loading={loading}
scroll={{ x: '100%', y: height }}
onRow={(record, index) => {
return {
- lineMarks,
+ lineMarks: setting.tableMode !== 'fast' ? lineMarks : null,
data: record,
+ title: setting.tipField ? record[setting.tipField] : '',
className: index === activeIndex ? ' mk-row-active ' : '',
onClick: () => {this.changeRow(record, index)},
onDoubleClick: () => {this.doubleClickLine(record)}
@@ -893,15 +1054,4 @@
}
}
-const mapStateToProps = (state) => {
- return {
- menuType: state.editLevel,
- memberLevel: state.memberLevel
- }
-}
-
-const mapDispatchToProps = () => {
- return {}
-}
-
-export default connect(mapStateToProps, mapDispatchToProps)(NormalTable)
\ No newline at end of file
+export default NormalTable
\ No newline at end of file
--
Gitblit v1.8.0