col2.js 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. 'use strict';
  2. Object.defineProperty(exports, '__esModule', { value: true });
  3. var vue = require('vue');
  4. var col = require('./col.js');
  5. var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
  6. var constants = require('../../row/src/constants.js');
  7. var index = require('../../../hooks/use-namespace/index.js');
  8. var types = require('../../../utils/types.js');
  9. var shared = require('@vue/shared');
  10. const __default__ = vue.defineComponent({
  11. name: "ElCol"
  12. });
  13. const _sfc_main = /* @__PURE__ */ vue.defineComponent({
  14. ...__default__,
  15. props: col.colProps,
  16. setup(__props) {
  17. const props = __props;
  18. const { gutter } = vue.inject(constants.rowContextKey, { gutter: vue.computed(() => 0) });
  19. const ns = index.useNamespace("col");
  20. const style = vue.computed(() => {
  21. const styles = {};
  22. if (gutter.value) {
  23. styles.paddingLeft = styles.paddingRight = `${gutter.value / 2}px`;
  24. }
  25. return styles;
  26. });
  27. const colKls = vue.computed(() => {
  28. const classes = [];
  29. const pos = ["span", "offset", "pull", "push"];
  30. pos.forEach((prop) => {
  31. const size = props[prop];
  32. if (types.isNumber(size)) {
  33. if (prop === "span")
  34. classes.push(ns.b(`${props[prop]}`));
  35. else if (size > 0)
  36. classes.push(ns.b(`${prop}-${props[prop]}`));
  37. }
  38. });
  39. const sizes = ["xs", "sm", "md", "lg", "xl"];
  40. sizes.forEach((size) => {
  41. if (types.isNumber(props[size])) {
  42. classes.push(ns.b(`${size}-${props[size]}`));
  43. } else if (shared.isObject(props[size])) {
  44. Object.entries(props[size]).forEach(([prop, sizeProp]) => {
  45. classes.push(prop !== "span" ? ns.b(`${size}-${prop}-${sizeProp}`) : ns.b(`${size}-${sizeProp}`));
  46. });
  47. }
  48. });
  49. if (gutter.value) {
  50. classes.push(ns.is("guttered"));
  51. }
  52. return [ns.b(), classes];
  53. });
  54. return (_ctx, _cache) => {
  55. return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(_ctx.tag), {
  56. class: vue.normalizeClass(vue.unref(colKls)),
  57. style: vue.normalizeStyle(vue.unref(style))
  58. }, {
  59. default: vue.withCtx(() => [
  60. vue.renderSlot(_ctx.$slots, "default")
  61. ]),
  62. _: 3
  63. }, 8, ["class", "style"]);
  64. };
  65. }
  66. });
  67. var Col = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "col.vue"]]);
  68. exports["default"] = Col;
  69. //# sourceMappingURL=col2.js.map