From 53a5b5bea0fb1efae2b1793e6735754e78982d63 Mon Sep 17 00:00:00 2001 From: king <18310653075@163.com> Date: 星期五, 19 十一月 2021 13:31:27 +0800 Subject: [PATCH] 2021-11-19 --- src/tabviews/zshare/mutilform/index.jsx | 24 ++++++++++++++++++++++-- 1 files changed, 22 insertions(+), 2 deletions(-) diff --git a/src/tabviews/zshare/mutilform/index.jsx b/src/tabviews/zshare/mutilform/index.jsx index f5f056e..5e054e8 100644 --- a/src/tabviews/zshare/mutilform/index.jsx +++ b/src/tabviews/zshare/mutilform/index.jsx @@ -1,7 +1,7 @@ import React, {Component} from 'react' import PropTypes from 'prop-types' import { fromJS } from 'immutable' -import { Form, Row, Col, notification, Tooltip } from 'antd' +import { Form, Row, Col, notification, Tooltip, Icon, Rate } from 'antd' import { QuestionCircleOutlined } from '@ant-design/icons' import moment from 'moment' @@ -74,7 +74,7 @@ if (item.type === 'split' || item.type === 'hint') return true - if (!item.field || !['text', 'number', 'switch', 'select', 'link', 'linkMain', 'funcvar', 'date', 'datemonth', 'datetime', 'radio', 'checkbox', 'checkcard', 'fileupload', 'textarea', 'multiselect', 'brafteditor', 'color'].includes(item.type)) return false + if (!item.field || !['text', 'number', 'switch', 'rate', 'select', 'link', 'linkMain', 'funcvar', 'date', 'datemonth', 'datetime', 'radio', 'checkbox', 'checkcard', 'fileupload', 'textarea', 'multiselect', 'brafteditor', 'color'].includes(item.type)) return false // 鏁版嵁鑷姩濉厖 let readin = item.readin !== 'false' @@ -161,6 +161,24 @@ if (['select', 'link', 'radio', 'checkbox', 'checkcard', 'multiselect'].includes(item.type) && item.resourceType === '1') { deForms.push(item) + } else if (item.type === 'rate') { + item.rateCount = item.rateCount || 5 + item.allowHalf = item.allowHalf === 'true' + + if (item.allowHalf) { + item.initval = parseFloat(item.initval) + if (item.initval % 0.5 !== 0) { + item.initval = parseInt(item.initval) + } + } else { + item.initval = parseInt(item.initval) + } + + if (isNaN(item.initval) || item.initval < 0) { + item.initval = 0 + } else if (item.initval > item.rateCount) { + item.initval = item.rateCount + } } if (item.type === 'text') { @@ -711,6 +729,8 @@ content = (<MKFileUpload config={item} onChange={(val) => this.recordChange({[item.field]: val})} />) } else if (item.type === 'textarea') { content = (<MKTextArea config={item} onChange={(val, defer) => !defer && this.recordChange({[item.field]: val})}/>) + } else if (item.type === 'rate') { + content = (<Rate count={item.rateCount} disabled={item.readonly} onChange={(val) => this.recordChange({[item.field]: val})} character={item.character ? <Icon type={item.character}/> : <Icon type="star" theme="filled"/>} allowHalf={item.allowHalf}/>) } else if (item.type === 'brafteditor') { content = (<MKEditor config={item} onChange={(val) => this.recordChange({[item.field]: val})}/>) label = item.hidelabel !== 'true' ? label : '' -- Gitblit v1.8.0