tntd
Version:
tntd是基于 TNT Design 设计体系的 React UI 组件库,主要用于研发企业级中后台产品。
103 lines (102 loc) • 5.44 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
var _exportNames = {
Form: true
};
exports.Form = void 0;
var _react = _interopRequireWildcard(require("react"));
var _configProvider = require("../config-provider");
var _form = _interopRequireWildcard(require("antd/es/form"));
Object.keys(_form).forEach(function (key) {
if (key === "default" || key === "__esModule") return;
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
if (key in exports && exports[key] === _form[key]) return;
Object.defineProperty(exports, key, {
enumerable: true,
get: function get() {
return _form[key];
}
});
});
var _utils = require("../utils");
require("./form.less");
var _classnames = _interopRequireDefault(require("classnames"));
function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
var __rest = void 0 && (void 0).__rest || function (s, e) {
var t = {};
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
}
return t;
};
var Form = exports.Form = (0, _react.forwardRef)(function (_a, ref) {
var rest = __rest(_a, []);
return _react["default"].createElement(_configProvider.ConfigConsumer, null, function (_ref) {
var getPrefixCls = _ref.getPrefixCls;
return _react["default"].createElement(_form["default"], Object.assign({}, rest, {
className: (0, _classnames["default"])(rest.className, 'tnt-form'),
ref: ref
}));
});
});
Form.Item = (0, _react.forwardRef)(function (_a, ref) {
var label = _a.label,
rest = __rest(_a, ["label"]);
return _react["default"].createElement(_configProvider.ConfigConsumer, null, function (_ref2) {
var getPrefixCls = _ref2.getPrefixCls;
return _react["default"].createElement(_form["default"].Item, Object.assign({}, rest, {
label: (0, _utils.doUpperTitle)(label),
ref: ref
}));
});
});
var Create = function Create(options) {
return function (WrappedComponent) {
var validateSubmitMap = {};
var CustomFormWrapper = function CustomFormWrapper(props, ref) {
var getFieldDecorator = props.form.getFieldDecorator;
props.form.getFieldDecorator = function (name, options) {
var opt = options || {};
if (opt.validateSubmit) {
opt = Object.assign(Object.assign({}, options), {
validateTrigger: 'noEvent'
});
validateSubmitMap[name] = true;
}
return getFieldDecorator(name, opt);
};
return _react["default"].createElement(WrappedComponent, Object.assign({}, props, {
ref: ref
}));
};
return _form["default"].create(Object.assign(Object.assign({}, options), {
onValuesChange: function onValuesChange(props, changedValues, allValues) {
var keys = Object.keys(changedValues);
if (keys.length === 1) {
keys.forEach(function (name) {
if (validateSubmitMap[name]) {
props.form.setFields(_defineProperty({}, name, {
value: changedValues[name],
errors: undefined
}));
}
});
}
if (options && options.onValuesChange) {
options.onValuesChange(props, changedValues, allValues);
}
}
}))((0, _react.forwardRef)(CustomFormWrapper));
};
};
Form.createFormField = _form["default"].createFormField;
Form.create = Create;