From 137fb8ea6af2789b3238b22bac31d80bced41dfe Mon Sep 17 00:00:00 2001
From: king <18310653075@163.com>
Date: 星期三, 28 七月 2021 11:39:39 +0800
Subject: [PATCH] 2021-07-28

---
 src/tabviews/zshare/mutilform/checkCard/index.jsx |   29 ++++++++++++++++++++++-------
 1 files changed, 22 insertions(+), 7 deletions(-)

diff --git a/src/tabviews/zshare/mutilform/checkCard/index.jsx b/src/tabviews/zshare/mutilform/checkCard/index.jsx
index c8ceec6..fd825fa 100644
--- a/src/tabviews/zshare/mutilform/checkCard/index.jsx
+++ b/src/tabviews/zshare/mutilform/checkCard/index.jsx
@@ -2,6 +2,7 @@
 import PropTypes from 'prop-types'
 import { Col, Row } from 'antd'
 
+import MKEmitter from '@/utils/events.js'
 import './index.scss'
 
 class CheckCard extends Component {
@@ -29,10 +30,12 @@
   }
 
   changeCard = (item) => {
-    const { multiple } = this.props.card
+    const { card } = this.props
     const { selectKeys } = this.state
 
-    if (multiple === 'true') {
+    if (card.readonly) return
+
+    if (card.multiple === 'true') {
       let keys = []
       if (selectKeys.includes(item.$value)) {
         keys = selectKeys.filter(key => key !== item.$value)
@@ -45,7 +48,13 @@
       }, () => {
         this.props.onChange && this.props.onChange(keys.join(','))
       })
-    } else if (multiple !== 'true' && selectKeys !== item.$value) {
+    } else if (selectKeys !== item.$value) {
+      card.linkFields && card.linkFields.forEach((m, i) => {
+        setTimeout(() => {
+          MKEmitter.emit('mkSP', m.uuid, item.$value, 0)
+        }, (i + 1) * 10)
+      })
+
       this.setState({
         selectKeys: item.$value
       }, () => {
@@ -55,7 +64,7 @@
   }
 
   getCards = () => {
-    const { display, width, options, fields, ratio, multiple } = this.props.card
+    const { display, width, options, fields, ratio, multiple, backgroundColor, borderColor } = this.props.card
     const { selectKeys } = this.state
 
     let paddingTop = '100%'
@@ -67,12 +76,16 @@
       paddingTop = '56.25%'
     }
 
+    let style = borderColor ? {borderColor} : {}
+    let _style = backgroundColor ? {backgroundColor} : null
+
     if (!options || options.length === 0) {
       return null
     } else if (display !== 'picture') {
       if (!fields || fields.length === 0) {
         return null
       }
+
       return options.map(item => {
         let _active = false
         if (multiple === 'true' && selectKeys.includes(item.$value)) {
@@ -82,7 +95,8 @@
         }
 
         return <Col span={width} key={item.key}>
-          <div className={'card-cell ' + (_active ? 'active' : '')} onClick={() => this.changeCard(item)}>
+          <div className={'card-cell' + (_active ? ' active' : '') + (_style ? ' bg-control' : '')} style={style} onClick={() => this.changeCard(item)}>
+            <div className="bg-mask" style={_style}></div>
             {fields.map(col => {
               return <span key={col.key} style={{color: col.color, fontSize: col.fontSize + 'px', height: col.fontSize * 1.5 + 'px', textAlign: col.align}}>{item[col.field]}</span>
             })}
@@ -99,7 +113,7 @@
         }
 
         return <Col span={width} key={item.key}>
-          <div className={'card-pic-cell ' + (_active ? 'active' : '')} onClick={() => this.changeCard(item)} style={{paddingTop, backgroundImage: `url(${item.$url})`}}>
+          <div className={'card-pic-cell ' + (_active ? 'active' : '')} onClick={() => this.changeCard(item)} style={{...style, paddingTop, backgroundImage: `url(${item.$url})`}}>
           </div>
         </Col>
       })
@@ -107,8 +121,9 @@
   }
 
   render() {
+    const { card } = this.props
     return (
-      <div className="check-card-form-box">
+      <div className={'check-card-form-box' + (card.readonly ? ' readonly' : '')}>
         <Row gutter={12}>{this.getCards()}</Row>
       </div>
     )

--
Gitblit v1.8.0