king
2021-07-28 137fb8ea6af2789b3238b22bac31d80bced41dfe
src/templates/modalconfig/checkCard/index.jsx
@@ -6,33 +6,38 @@
class CheckCard extends Component {
  static propTpyes = {
    multiple: PropTypes.bool,    // 是否可多选
    ratio: PropTypes.string,     // 图片比例
    width: PropTypes.number,     // 宽度
    display: PropTypes.string,   // 显示为:text(文本)、picture(图片)
    fields: PropTypes.array,     // 字段集
    options: PropTypes.array,    // 数据列表
    config: PropTypes.object,    // 表单配置信息
    onChange: PropTypes.func,    // 数据切换
  }
  state = {}
  getCards = () => {
    const { display, width, options, fields, ratio } = this.props
    const { display, width, options, fields, ratio, picratio, backgroundColor, borderColor } = this.props.config
    let _ratio = picratio || ratio
    let paddingTop = '100%'
    if (ratio === '4:3') {
    if (_ratio === '4:3') {
      paddingTop = '75%'
    } else if (ratio === '3:2') {
    } else if (_ratio === '3:2') {
      paddingTop = '66.7%'
    } else if (ratio === '16:9') {
    } else if (_ratio === '16:9') {
      paddingTop = '56.25%'
    }
    let style = {}
    if (borderColor) {
      style.borderColor = borderColor
    }
    if (display !== 'picture') {
      let _style = backgroundColor ? {backgroundColor} : null
      if (!options || options.length === 0) {
        return <Col span={width}>
          <div className="card-cell">
          <div className="card-cell" style={style}>
            <div className="bg-mask" style={_style}></div>
            {fields ? 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}}>{col.field}</span>
            }) : null}
@@ -42,7 +47,8 @@
      }
      return options.map(item => {
        return <Col span={width} key={item.key}>
          <div className="card-cell">
          <div className="card-cell" style={style}>
            <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>
            })}
@@ -52,13 +58,13 @@
    } else {
      if (!options || options.length === 0) {
        return <Col span={width}>
          <div className="card-pic-cell" style={{paddingTop, background: '#91d5ff'}}>
          <div className="card-pic-cell" style={{...style, paddingTop, background: '#91d5ff'}}>
          </div>
        </Col>
      }
      return options.map(item => {
        return <Col span={width} key={item.key}>
          <div className="card-pic-cell" style={{paddingTop, backgroundImage: `url(${item.$url})`}}>
          <div className="card-pic-cell" style={{...style, paddingTop, backgroundImage: `url(${item.$url})`}}>
          </div>
        </Col>
      })