08335 / hivui-platform-template
hivui平台项目模板
Newer
Older
hivui-platform-template / project / hivuiMain / components / grid / col.vue
caibinghong on 4 Jun 2021 add
<template>
    <div :class="divProps.class" v-on="divProps.on" v-bind="divProps.attrs" :style="divProps.style"><slot></slot></div>
</template>

<script>
import PropTypes from '@main/utils/vue-types/index'

const stringOrNumber = PropTypes.oneOfType([PropTypes.string, PropTypes.number]);

export const ColSize = PropTypes.shape({
  span: stringOrNumber,
  order: stringOrNumber,
  offset: stringOrNumber,
  push: stringOrNumber,
  pull: stringOrNumber,
}).loose;

const objectOrNumber = PropTypes.oneOfType([PropTypes.number, ColSize]);

export const ColProps = {
  span: stringOrNumber,
  order: stringOrNumber,
  offset: stringOrNumber,
  push: stringOrNumber,
  pull: stringOrNumber,
  xs: objectOrNumber,
  sm: objectOrNumber,
  md: objectOrNumber,
  lg: objectOrNumber,
  xl: objectOrNumber,
  xxl: objectOrNumber,
  prefixCls: PropTypes.string,
};

export default {
  name: 'pl-col',
  props: ColProps,
  computed:{
      divProps(){
        const {
            span,
            order,
            offset,
            push,
            pull,
            prefixCls = 'pl-col',
            $slots,
            $attrs,
            $listeners,
            rowContext,
        } = this;
        let sizeClassObj = {};
        ['xs', 'sm', 'md', 'lg', 'xl', 'xxl'].forEach(size => {
            let sizeProps = {};
            if (typeof this[size] === 'number') {
                sizeProps.span = this[size];
            } else if (typeof this[size] === 'object') {
                sizeProps = this[size] || {};
            }

            sizeClassObj = {
                ...sizeClassObj,
                [`${prefixCls}-${size}-${sizeProps.span}`]: sizeProps.span !== undefined,
                [`${prefixCls}-${size}-order-${sizeProps.order}`]: sizeProps.order || sizeProps.order === 0,
                [`${prefixCls}-${size}-offset-${sizeProps.offset}`]:
                sizeProps.offset || sizeProps.offset === 0,
                [`${prefixCls}-${size}-push-${sizeProps.push}`]: sizeProps.push || sizeProps.push === 0,
                [`${prefixCls}-${size}-pull-${sizeProps.pull}`]: sizeProps.pull || sizeProps.pull === 0,
            };
        });
        const classes = {
            [`${prefixCls}-${span}`]: span !== undefined,
            [`${prefixCls}-order-${order}`]: order,
            [`${prefixCls}-offset-${offset}`]: offset,
            [`${prefixCls}-push-${push}`]: push,
            [`${prefixCls}-pull-${pull}`]: pull,
            ...sizeClassObj,
        };
        const divProps = {
            on: $listeners,
            attrs: $attrs,
            class: classes,
            style: {},
        };
        if (rowContext) {
            const gutter = rowContext.getGutter();
            if (gutter > 0) {
                divProps.style = {
                paddingLeft: `${gutter / 2}px`,
                paddingRight: `${gutter / 2}px`,
                };
            }
        }
        return divProps;
    }
  },
  inject: {
    rowContext: {
      default: () => null,
    },
  }
};
</script>