zmp-vue
Version:
Build full featured iOS & Android apps using ZMP & Vue
77 lines (71 loc) • 2.44 kB
JavaScript
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
import { createVNode as _createVNode, renderSlot as _renderSlot, openBlock as _openBlock, createBlock as _createBlock } from "vue";
var _hoisted_1 = /*#__PURE__*/_createVNode("i", {
class: "icon-checkbox"
}, null, -1);
function render(_ctx, _cache) {
return _openBlock(), _createBlock("label", {
class: _ctx.classes
}, [_createVNode("input", {
ref: "inputElRef",
type: "checkbox",
name: _ctx.name,
value: _ctx.value,
disabled: _ctx.disabled,
readonly: _ctx.readonly,
checked: _ctx.checked,
onChange: _cache[1] || (_cache[1] = function () {
return _ctx.onChange && _ctx.onChange.apply(_ctx, arguments);
})
}, null, 40, ["name", "value", "disabled", "readonly", "checked"]), _hoisted_1, _renderSlot(_ctx.$slots, "default")], 2);
}
import { ref, computed, onMounted, watch } from 'vue';
import { classNames } from '../shared/utils';
import { colorClasses, colorProps } from '../shared/mixins';
export default {
name: 'zmp-checkbox',
render: render,
props: _extends({
checked: Boolean,
indeterminate: Boolean,
name: [Number, String],
value: {
type: [Number, String, Boolean],
default: undefined
},
disabled: Boolean,
readonly: Boolean
}, colorProps),
emits: ['update:checked', 'change'],
setup: function setup(props, _ref) {
var emit = _ref.emit;
var inputElRef = ref(null);
var onChange = function onChange(event) {
emit('update:checked', event.target.checked);
emit('change', event);
};
onMounted(function () {
if (inputElRef.value) {
inputElRef.value.indeterminate = !!props.indeterminate;
}
});
watch(function () {
return props.indeterminate;
}, function (newValue) {
if (inputElRef.value) {
inputElRef.value.indeterminate = !!newValue;
}
});
var classes = computed(function () {
return classNames({
checkbox: true,
disabled: props.disabled
}, colorClasses(props));
});
return {
inputElRef: inputElRef,
classes: classes,
onChange: onChange
};
}
};