@wufengteam/inputs
Version:
平台提供的右侧属性编辑器,需要在主工程中注册
78 lines • 4.18 kB
JavaScript
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
/* eslint-disable no-console */
import React, { useState } from 'react';
import { Button, Form, Modal, message } from 'antd';
import '@wangeditor/editor/dist/css/style.css';
import RichEditor from './RichEditor';
var InnerRichText = function InnerRichText(props) {
var onChange = props.onChange,
value = props.value,
imageType = props.imageType,
maxLength = props.maxLength,
_props$imageMaxNumber = props.imageMaxNumber,
imageMaxNumber = _props$imageMaxNumber === void 0 ? 5 : _props$imageMaxNumber;
var _useState = useState(false),
_useState2 = _slicedToArray(_useState, 2),
isModalVisible = _useState2[0],
setIsModalVisible = _useState2[1];
// 富文本编辑器内容
var _useState3 = useState(value),
_useState4 = _slicedToArray(_useState3, 2),
html = _useState4[0],
setHtml = _useState4[1];
var onOk = function onOk() {
var imgList = html.match(/<img(?:(?!\/>).|\n)*?\/?>/g);
if (Array.isArray(imgList) && imgList.length > imageMaxNumber) {
var exceedNumber = imgList.length - imageMaxNumber;
message.warning("\u5141\u8BB8\u8BBE\u7F6E\u7684\u56FE\u7247\u6570\u91CF\u5DF2\u7ECF\u8D85\u51FA".concat(exceedNumber, "\u5F20\uFF0C\u8BF7\u4FEE\u6539\u3002"));
} else {
setIsModalVisible(false);
onChange === null || onChange === void 0 ? void 0 : onChange(html);
}
};
return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Button, {
block: true,
onClick: function onClick() {
setIsModalVisible(true);
},
style: {
fontSize: '12px'
}
}, "\u8BBE\u7F6E\u56FE\u6587\u5185\u5BB9"), /*#__PURE__*/React.createElement(Modal, {
width: 1250,
destroyOnClose: true,
closable: false,
visible: isModalVisible,
onOk: onOk,
onCancel: function onCancel() {
setHtml(value);
setIsModalVisible(false);
}
}, /*#__PURE__*/React.createElement(RichEditor, {
value: value,
onChange: setHtml,
imageType: imageType,
maxLength: maxLength
})));
};
var RichText = function RichText(props) {
var _a;
var name = props.name,
rules = props.rules,
label = props.label,
selectedComp = props.selectedComp;
var initialValue = ((_a = selectedComp === null || selectedComp === void 0 ? void 0 : selectedComp.props) === null || _a === void 0 ? void 0 : _a.richText) || [];
return /*#__PURE__*/React.createElement(Form.Item, {
label: label,
name: name,
rules: rules
}, /*#__PURE__*/React.createElement(InnerRichText, Object.assign({
initialValue: initialValue
}, props)));
};
export default RichText;