Row.js 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
  2. import _typeof from "@babel/runtime/helpers/esm/typeof";
  3. import { createVNode as _createVNode } from "vue";
  4. import { defineComponent, ref, onMounted, onBeforeUnmount, computed } from 'vue';
  5. import classNames from '../_util/classNames';
  6. import { tuple } from '../_util/type';
  7. import ResponsiveObserve, { responsiveArray } from '../_util/responsiveObserve';
  8. import useConfigInject from '../_util/hooks/useConfigInject';
  9. import useFlexGapSupport from '../_util/hooks/useFlexGapSupport';
  10. import useProvideRow from './context';
  11. var RowAligns = tuple('top', 'middle', 'bottom', 'stretch');
  12. var RowJustify = tuple('start', 'end', 'center', 'space-around', 'space-between');
  13. export var rowProps = function rowProps() {
  14. return {
  15. align: String,
  16. justify: String,
  17. prefixCls: String,
  18. gutter: {
  19. type: [Number, Array, Object],
  20. default: 0
  21. },
  22. wrap: {
  23. type: Boolean,
  24. default: undefined
  25. }
  26. };
  27. };
  28. var ARow = defineComponent({
  29. compatConfig: {
  30. MODE: 3
  31. },
  32. name: 'ARow',
  33. props: rowProps(),
  34. setup: function setup(props, _ref) {
  35. var slots = _ref.slots;
  36. var _useConfigInject = useConfigInject('row', props),
  37. prefixCls = _useConfigInject.prefixCls,
  38. direction = _useConfigInject.direction;
  39. var token;
  40. var screens = ref({
  41. xs: true,
  42. sm: true,
  43. md: true,
  44. lg: true,
  45. xl: true,
  46. xxl: true,
  47. xxxl: true
  48. });
  49. var supportFlexGap = useFlexGapSupport();
  50. onMounted(function () {
  51. token = ResponsiveObserve.subscribe(function (screen) {
  52. var currentGutter = props.gutter || 0;
  53. if (!Array.isArray(currentGutter) && _typeof(currentGutter) === 'object' || Array.isArray(currentGutter) && (_typeof(currentGutter[0]) === 'object' || _typeof(currentGutter[1]) === 'object')) {
  54. screens.value = screen;
  55. }
  56. });
  57. });
  58. onBeforeUnmount(function () {
  59. ResponsiveObserve.unsubscribe(token);
  60. });
  61. var gutter = computed(function () {
  62. var results = [0, 0];
  63. var _props$gutter = props.gutter,
  64. gutter = _props$gutter === void 0 ? 0 : _props$gutter;
  65. var normalizedGutter = Array.isArray(gutter) ? gutter : [gutter, 0];
  66. normalizedGutter.forEach(function (g, index) {
  67. if (_typeof(g) === 'object') {
  68. for (var i = 0; i < responsiveArray.length; i++) {
  69. var breakpoint = responsiveArray[i];
  70. if (screens.value[breakpoint] && g[breakpoint] !== undefined) {
  71. results[index] = g[breakpoint];
  72. break;
  73. }
  74. }
  75. } else {
  76. results[index] = g || 0;
  77. }
  78. });
  79. return results;
  80. });
  81. useProvideRow({
  82. gutter: gutter,
  83. supportFlexGap: supportFlexGap,
  84. wrap: computed(function () {
  85. return props.wrap;
  86. })
  87. });
  88. var classes = computed(function () {
  89. var _classNames;
  90. return classNames(prefixCls.value, (_classNames = {}, _defineProperty(_classNames, "".concat(prefixCls.value, "-no-wrap"), props.wrap === false), _defineProperty(_classNames, "".concat(prefixCls.value, "-").concat(props.justify), props.justify), _defineProperty(_classNames, "".concat(prefixCls.value, "-").concat(props.align), props.align), _defineProperty(_classNames, "".concat(prefixCls.value, "-rtl"), direction.value === 'rtl'), _classNames));
  91. });
  92. var rowStyle = computed(function () {
  93. var gt = gutter.value;
  94. // Add gutter related style
  95. var style = {};
  96. var horizontalGutter = gt[0] > 0 ? "".concat(gt[0] / -2, "px") : undefined;
  97. var verticalGutter = gt[1] > 0 ? "".concat(gt[1] / -2, "px") : undefined;
  98. if (horizontalGutter) {
  99. style.marginLeft = horizontalGutter;
  100. style.marginRight = horizontalGutter;
  101. }
  102. if (supportFlexGap.value) {
  103. // Set gap direct if flex gap support
  104. style.rowGap = "".concat(gt[1], "px");
  105. } else if (verticalGutter) {
  106. style.marginTop = verticalGutter;
  107. style.marginBottom = verticalGutter;
  108. }
  109. return style;
  110. });
  111. return function () {
  112. var _slots$default;
  113. return _createVNode("div", {
  114. "class": classes.value,
  115. "style": rowStyle.value
  116. }, [(_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots)]);
  117. };
  118. }
  119. });
  120. export default ARow;