checkbox2.js 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. 'use strict';
  2. Object.defineProperty(exports, '__esModule', { value: true });
  3. var vue = require('vue');
  4. var checkbox = require('./checkbox.js');
  5. var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
  6. var useCheckbox = require('./composables/use-checkbox.js');
  7. var index = require('../../../hooks/use-namespace/index.js');
  8. const __default__ = vue.defineComponent({
  9. name: "ElCheckbox"
  10. });
  11. const _sfc_main = /* @__PURE__ */ vue.defineComponent({
  12. ...__default__,
  13. props: checkbox.checkboxProps,
  14. emits: checkbox.checkboxEmits,
  15. setup(__props) {
  16. const props = __props;
  17. const slots = vue.useSlots();
  18. const {
  19. inputId,
  20. isLabeledByFormItem,
  21. isChecked,
  22. isDisabled,
  23. isFocused,
  24. checkboxSize,
  25. hasOwnLabel,
  26. model,
  27. actualValue,
  28. handleChange,
  29. onClickRoot
  30. } = useCheckbox.useCheckbox(props, slots);
  31. const ns = index.useNamespace("checkbox");
  32. const compKls = vue.computed(() => {
  33. return [
  34. ns.b(),
  35. ns.m(checkboxSize.value),
  36. ns.is("disabled", isDisabled.value),
  37. ns.is("bordered", props.border),
  38. ns.is("checked", isChecked.value)
  39. ];
  40. });
  41. const spanKls = vue.computed(() => {
  42. return [
  43. ns.e("input"),
  44. ns.is("disabled", isDisabled.value),
  45. ns.is("checked", isChecked.value),
  46. ns.is("indeterminate", props.indeterminate),
  47. ns.is("focus", isFocused.value)
  48. ];
  49. });
  50. return (_ctx, _cache) => {
  51. return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(!vue.unref(hasOwnLabel) && vue.unref(isLabeledByFormItem) ? "span" : "label"), {
  52. class: vue.normalizeClass(vue.unref(compKls)),
  53. "aria-controls": _ctx.indeterminate ? _ctx.ariaControls : null,
  54. onClick: vue.unref(onClickRoot)
  55. }, {
  56. default: vue.withCtx(() => {
  57. var _a, _b, _c, _d;
  58. return [
  59. vue.createElementVNode("span", {
  60. class: vue.normalizeClass(vue.unref(spanKls))
  61. }, [
  62. _ctx.trueValue || _ctx.falseValue || _ctx.trueLabel || _ctx.falseLabel ? vue.withDirectives((vue.openBlock(), vue.createElementBlock("input", {
  63. key: 0,
  64. id: vue.unref(inputId),
  65. "onUpdate:modelValue": ($event) => vue.isRef(model) ? model.value = $event : null,
  66. class: vue.normalizeClass(vue.unref(ns).e("original")),
  67. type: "checkbox",
  68. indeterminate: _ctx.indeterminate,
  69. name: _ctx.name,
  70. tabindex: _ctx.tabindex,
  71. disabled: vue.unref(isDisabled),
  72. "true-value": (_b = (_a = _ctx.trueValue) != null ? _a : _ctx.trueLabel) != null ? _b : true,
  73. "false-value": (_d = (_c = _ctx.falseValue) != null ? _c : _ctx.falseLabel) != null ? _d : false,
  74. onChange: vue.unref(handleChange),
  75. onFocus: ($event) => isFocused.value = true,
  76. onBlur: ($event) => isFocused.value = false,
  77. onClick: vue.withModifiers(() => {
  78. }, ["stop"])
  79. }, null, 42, ["id", "onUpdate:modelValue", "indeterminate", "name", "tabindex", "disabled", "true-value", "false-value", "onChange", "onFocus", "onBlur", "onClick"])), [
  80. [vue.vModelCheckbox, vue.unref(model)]
  81. ]) : vue.withDirectives((vue.openBlock(), vue.createElementBlock("input", {
  82. key: 1,
  83. id: vue.unref(inputId),
  84. "onUpdate:modelValue": ($event) => vue.isRef(model) ? model.value = $event : null,
  85. class: vue.normalizeClass(vue.unref(ns).e("original")),
  86. type: "checkbox",
  87. indeterminate: _ctx.indeterminate,
  88. disabled: vue.unref(isDisabled),
  89. value: vue.unref(actualValue),
  90. name: _ctx.name,
  91. tabindex: _ctx.tabindex,
  92. onChange: vue.unref(handleChange),
  93. onFocus: ($event) => isFocused.value = true,
  94. onBlur: ($event) => isFocused.value = false,
  95. onClick: vue.withModifiers(() => {
  96. }, ["stop"])
  97. }, null, 42, ["id", "onUpdate:modelValue", "indeterminate", "disabled", "value", "name", "tabindex", "onChange", "onFocus", "onBlur", "onClick"])), [
  98. [vue.vModelCheckbox, vue.unref(model)]
  99. ]),
  100. vue.createElementVNode("span", {
  101. class: vue.normalizeClass(vue.unref(ns).e("inner"))
  102. }, null, 2)
  103. ], 2),
  104. vue.unref(hasOwnLabel) ? (vue.openBlock(), vue.createElementBlock("span", {
  105. key: 0,
  106. class: vue.normalizeClass(vue.unref(ns).e("label"))
  107. }, [
  108. vue.renderSlot(_ctx.$slots, "default"),
  109. !_ctx.$slots.default ? (vue.openBlock(), vue.createElementBlock(vue.Fragment, { key: 0 }, [
  110. vue.createTextVNode(vue.toDisplayString(_ctx.label), 1)
  111. ], 64)) : vue.createCommentVNode("v-if", true)
  112. ], 2)) : vue.createCommentVNode("v-if", true)
  113. ];
  114. }),
  115. _: 3
  116. }, 8, ["class", "aria-controls", "onClick"]);
  117. };
  118. }
  119. });
  120. var Checkbox = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "checkbox.vue"]]);
  121. exports["default"] = Checkbox;
  122. //# sourceMappingURL=checkbox2.js.map