@schema-render/form-render-react
Version:
Out-of-the-box form rendering library based on Core and Antd.
134 lines (133 loc) • 5.2 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function() {
return _default;
}
});
var _jsxruntime = require("react/jsx-runtime");
var _corereact = require("@schema-render/core-react");
var _antd = require("antd");
var _dayjs = /*#__PURE__*/ _interop_require_default(require("dayjs"));
var _react = /*#__PURE__*/ _interop_require_default(require("react"));
var _Description = /*#__PURE__*/ _interop_require_default(require("../components/Description"));
var _constants = require("../constants");
function _define_property(obj, key, value) {
if (key in obj) {
Object.defineProperty(obj, key, {
value: value,
enumerable: true,
configurable: true,
writable: true
});
} else {
obj[key] = value;
}
return obj;
}
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
function _object_spread(target) {
for(var i = 1; i < arguments.length; i++){
var source = arguments[i] != null ? arguments[i] : {};
var ownKeys = Object.keys(source);
if (typeof Object.getOwnPropertySymbols === "function") {
ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
return Object.getOwnPropertyDescriptor(source, sym).enumerable;
}));
}
ownKeys.forEach(function(key) {
_define_property(target, key, source[key]);
});
}
return target;
}
function ownKeys(object, enumerableOnly) {
var keys = Object.keys(object);
if (Object.getOwnPropertySymbols) {
var symbols = Object.getOwnPropertySymbols(object);
if (enumerableOnly) {
symbols = symbols.filter(function(sym) {
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
});
}
keys.push.apply(keys, symbols);
}
return keys;
}
function _object_spread_props(target, source) {
source = source != null ? source : {};
if (Object.getOwnPropertyDescriptors) {
Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
} else {
ownKeys(Object(source)).forEach(function(key) {
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
});
}
return target;
}
function toISOString(date) {
return (0, _dayjs.default)(date).toISOString();
}
/**
* 编辑与禁用态组件
*/ var DateRangePicker = function(param) {
var schema = param.schema, value = param.value, onChange = param.onChange, disabled = param.disabled, validator = param.validator;
var showTime = (schema.renderOptions || {}).showTime;
return /*#__PURE__*/ (0, _jsxruntime.jsx)(_antd.DatePicker.RangePicker, _object_spread_props(_object_spread({
allowClear: true,
allowEmpty: true,
style: {
width: '100%'
}
}, schema.renderOptions), {
disabled: disabled,
status: validator.status,
value: value ? [
(0, _dayjs.default)(value[0]),
(0, _dayjs.default)(value[1])
] : null,
onChange: function(val) {
if (val && val[0] && val[1]) {
// 不是 showTime 的情况,endTime 时分秒设置到当日结束时间
var startTime = showTime ? val[0] : val[0].startOf('day');
var endTime = showTime ? val[1] : val[1].endOf('day');
onChange([
toISOString(startTime),
toISOString(endTime)
]);
} else {
onChange(undefined);
}
}
}));
};
/**
* 只读态组件
*/ var ReadonlyDateRangePicker = function(param) {
var schema = param.schema, value = param.value, locale = param.locale;
var displayText = '';
if (_corereact.utils.isArray(value) && value[0] && value[1]) {
var _schema_renderOptions, _schema_renderOptions1, _schema_renderOptions2;
var defaultFormat = ((_schema_renderOptions = schema.renderOptions) === null || _schema_renderOptions === void 0 ? void 0 : _schema_renderOptions.showTime) ? _constants.DEFAULT_DATE_TIME_FORMAT : _constants.DEFAULT_DATE_FORMAT;
var format = ((_schema_renderOptions1 = schema.renderOptions) === null || _schema_renderOptions1 === void 0 ? void 0 : _schema_renderOptions1.format) || defaultFormat;
var displayTextTemplate = ((_schema_renderOptions2 = schema.renderOptions) === null || _schema_renderOptions2 === void 0 ? void 0 : _schema_renderOptions2.displayTextTemplate) || locale.FormRender.displayDateRange;
displayText = _corereact.utils.templateCompiled(displayTextTemplate, {
start: (0, _dayjs.default)(value[0]).format(format),
end: (0, _dayjs.default)(value[1]).format(format)
});
}
return /*#__PURE__*/ (0, _jsxruntime.jsx)(_Description.default, {
children: displayText
});
};
var _default = {
component: DateRangePicker,
readonlyComponent: ReadonlyDateRangePicker
};
;