ant-design-vue
Version:
An enterprise-class UI design language and Vue-based implementation
89 lines (88 loc) • 3.79 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.useProvideFormItemContext = exports.useInjectFormItemContext = exports.default = void 0;
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _vue = require("vue");
var _devWarning = _interopRequireDefault(require("../vc-util/devWarning"));
var ContextKey = Symbol('ContextProps');
var InternalContextKey = Symbol('InternalContextProps');
var useProvideFormItemContext = function useProvideFormItemContext(props) {
var useValidation = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : (0, _vue.computed)(function () {
return true;
});
var formItemFields = (0, _vue.ref)(new Map());
var addFormItemField = function addFormItemField(key, type) {
formItemFields.value.set(key, type);
formItemFields.value = new Map(formItemFields.value);
};
var removeFormItemField = function removeFormItemField(key) {
formItemFields.value.delete(key);
formItemFields.value = new Map(formItemFields.value);
};
var instance = (0, _vue.getCurrentInstance)();
(0, _vue.watch)([useValidation, formItemFields], function () {
if (process.env.NODE_ENV !== 'production') {
if (useValidation.value && formItemFields.value.size > 1) {
(0, _devWarning.default)(false, 'Form.Item', "FormItem can only collect one field item, you haved set ".concat((0, _toConsumableArray2.default)(formItemFields.value.values()).map(function (v) {
return "`".concat(v.name, "`");
}).join(', '), " ").concat(formItemFields.value.size, " field items.\n You can set not need to be collected fields into `a-form-item-rest`"));
var cur = instance;
while (cur.parent) {
console.warn('at', cur.type);
cur = cur.parent;
}
}
}
});
(0, _vue.provide)(ContextKey, props);
(0, _vue.provide)(InternalContextKey, {
addFormItemField: addFormItemField,
removeFormItemField: removeFormItemField
});
};
exports.useProvideFormItemContext = useProvideFormItemContext;
var defaultContext = {
id: (0, _vue.computed)(function () {
return undefined;
}),
onFieldBlur: function onFieldBlur() {},
onFieldChange: function onFieldChange() {},
clearValidate: function clearValidate() {}
};
var defaultInternalContext = {
addFormItemField: function addFormItemField() {},
removeFormItemField: function removeFormItemField() {}
};
var useInjectFormItemContext = function useInjectFormItemContext() {
var internalContext = (0, _vue.inject)(InternalContextKey, defaultInternalContext);
var formItemFieldKey = Symbol('FormItemFieldKey');
var instance = (0, _vue.getCurrentInstance)();
internalContext.addFormItemField(formItemFieldKey, instance.type);
(0, _vue.onBeforeUnmount)(function () {
internalContext.removeFormItemField(formItemFieldKey);
});
// We should prevent the passing of context for children
(0, _vue.provide)(InternalContextKey, defaultInternalContext);
(0, _vue.provide)(ContextKey, defaultContext);
return (0, _vue.inject)(ContextKey, defaultContext);
};
exports.useInjectFormItemContext = useInjectFormItemContext;
var _default = (0, _vue.defineComponent)({
compatConfig: {
MODE: 3
},
name: 'AFormItemRest',
setup: function setup(_, _ref) {
var slots = _ref.slots;
(0, _vue.provide)(InternalContextKey, defaultInternalContext);
(0, _vue.provide)(ContextKey, defaultContext);
return function () {
var _slots$default;
return (_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots);
};
}
});
exports.default = _default;
;