@aplus-frontend/antdv
Version:
Vue basic component library maintained based on ant-design-vue
158 lines (156 loc) • 6.33 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
var _vue = require("vue");
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _classNames = _interopRequireDefault(require("../_util/classNames"));
var _Checkbox = _interopRequireDefault(require("../vc-checkbox/Checkbox"));
var _propsUtil = require("../_util/props-util");
var _warning = _interopRequireDefault(require("../_util/warning"));
var _FormItemContext = require("../form/FormItemContext");
var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
var _DisabledContext = require("../config-provider/DisabledContext");
var _interface = require("./interface");
var _style = _interopRequireDefault(require("./style"));
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;
};
// CSSINJS
var _default = exports.default = (0, _vue.defineComponent)({
compatConfig: {
MODE: 3
},
name: 'ACheckbox',
inheritAttrs: false,
__ANT_CHECKBOX: true,
props: (0, _interface.checkboxProps)(),
// emits: ['change', 'update:checked'],
setup(props, _ref) {
let {
emit,
attrs,
slots,
expose
} = _ref;
const formItemContext = (0, _FormItemContext.useInjectFormItemContext)();
const formItemInputContext = _FormItemContext.FormItemInputContext.useInject();
const {
prefixCls,
direction,
disabled
} = (0, _useConfigInject.default)('checkbox', props);
const contextDisabled = (0, _DisabledContext.useInjectDisabled)();
// style
const [wrapSSR, hashId] = (0, _style.default)(prefixCls);
const checkboxGroup = (0, _vue.inject)(_interface.CheckboxGroupContextKey, undefined);
const uniId = Symbol('checkboxUniId');
const mergedDisabled = (0, _vue.computed)(() => {
return (checkboxGroup === null || checkboxGroup === void 0 ? void 0 : checkboxGroup.disabled.value) || disabled.value;
});
(0, _vue.watchEffect)(() => {
if (!props.skipGroup && checkboxGroup) {
checkboxGroup.registerValue(uniId, props.value);
}
});
(0, _vue.onBeforeUnmount)(() => {
if (checkboxGroup) {
checkboxGroup.cancelValue(uniId);
}
});
(0, _vue.onMounted)(() => {
(0, _warning.default)(!!(props.checked !== undefined || checkboxGroup || props.value === undefined), 'Checkbox', '`value` is not validate prop, do you mean `checked`?');
});
const handleChange = event => {
const targetChecked = event.target.checked;
emit('update:checked', targetChecked);
emit('change', event);
formItemContext.onFieldChange();
};
const checkboxRef = (0, _vue.ref)();
const focus = () => {
var _a;
(_a = checkboxRef.value) === null || _a === void 0 ? void 0 : _a.focus();
};
const blur = () => {
var _a;
(_a = checkboxRef.value) === null || _a === void 0 ? void 0 : _a.blur();
};
expose({
focus,
blur
});
return () => {
var _a;
const children = (0, _propsUtil.flattenChildren)((_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots));
const {
indeterminate,
skipGroup,
id = formItemContext.id.value
} = props,
restProps = __rest(props, ["indeterminate", "skipGroup", "id"]);
const {
onMouseenter,
onMouseleave,
onInput,
class: className,
style
} = attrs,
restAttrs = __rest(attrs, ["onMouseenter", "onMouseleave", "onInput", "class", "style"]);
const checkboxProps = (0, _extends2.default)((0, _extends2.default)((0, _extends2.default)((0, _extends2.default)({}, restProps), {
id,
prefixCls: prefixCls.value
}), restAttrs), {
disabled: mergedDisabled.value
});
if (checkboxGroup && !skipGroup) {
checkboxProps.onChange = function () {
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
emit('change', ...args);
checkboxGroup.toggleOption({
label: children,
value: props.value
});
};
checkboxProps.name = checkboxGroup.name.value;
checkboxProps.checked = checkboxGroup.mergedValue.value.includes(props.value);
checkboxProps.disabled = mergedDisabled.value || contextDisabled.value;
checkboxProps.indeterminate = indeterminate;
} else {
checkboxProps.onChange = handleChange;
}
const classString = (0, _classNames.default)({
[`${prefixCls.value}-wrapper`]: true,
[`${prefixCls.value}-rtl`]: direction.value === 'rtl',
[`${prefixCls.value}-wrapper-checked`]: checkboxProps.checked,
[`${prefixCls.value}-wrapper-disabled`]: checkboxProps.disabled,
[`${prefixCls.value}-wrapper-in-form-item`]: formItemInputContext.isFormItemInput
}, className, hashId.value);
const checkboxClass = (0, _classNames.default)({
[`${prefixCls.value}-indeterminate`]: indeterminate
}, hashId.value);
const ariaChecked = indeterminate ? 'mixed' : undefined;
return wrapSSR((0, _vue.createVNode)("label", {
"class": classString,
"style": style,
"onMouseenter": onMouseenter,
"onMouseleave": onMouseleave
}, [(0, _vue.createVNode)(_Checkbox.default, (0, _objectSpread2.default)((0, _objectSpread2.default)({
"aria-checked": ariaChecked
}, checkboxProps), {}, {
"class": checkboxClass,
"ref": checkboxRef
}), null), children.length ? (0, _vue.createVNode)("span", null, [children]) : null]));
};
}
});
;