<template>
    <view class="u-empty" v-if="show" :style="{
        marginTop: marginTop + 'rpx'
    }">
        <u-icon
            :name="src ? src : 'empty-' + mode"
            :custom-style="iconStyle"
            :label="text ? text : icons[mode]"
            label-pos="bottom"
            :label-color="color"
            :label-size="fontSize"
            :size="iconSize"
            :color="iconColor"
            margin-top="14"
        ></u-icon>
        <view class="u-slot-wrap">
            <slot name="bottom"></slot>
        </view>
    </view>
</template>

<script>
    /**
     * empty 内容为空
     * @description 该组件用于需要加载内容,但是加载的第一页数据就为空,提示一个"没有内容"的场景, 我们精心挑选了十几个场景的图标,方便您使用。
     * @tutorial https://www.uviewui.com/components/empty.html
     * @property {String} color 文字颜色(默认#c0c4cc)
     * @property {String} text 文字提示(默认“无内容”)
     * @property {String} src 自定义图标路径,如定义,mode参数会失效
     * @property {String Number} font-size 提示文字的大小,单位rpx(默认28)
     * @property {String} mode 内置的图标,见官网说明(默认data)
     * @property {String Number} img-width 图标的宽度,单位rpx(默认240)
     * @property {String} img-height 图标的高度,单位rpx(默认auto)
     * @property {String Number} margin-top 组件距离上一个元素之间的距离(默认0)
     * @property {Boolean} show 是否显示组件(默认true)
     * @event {Function} click 点击组件时触发
     * @event {Function} close 点击关闭按钮时触发
     * @example <u-empty text="所谓伊人,在水一方" mode="list"></u-empty>
     */
    export default {
        name: "u-empty",
        props: {
            // 图标路径
            src: {
                type: String,
                default: ''
            },
            // 提示文字
            text: {
                type: String,
                default: ''
            },
            // 文字颜色
            color: {
                type: String,
                default: '#c0c4cc'
            },
            // 图标的颜色
            iconColor: {
                type: String,
                default: '#c0c4cc'
            },
            // 图标的大小
            iconSize: {
                type: [String, Number],
                default: 120
            },
            // 文字大小,单位rpx
            fontSize: {
                type: [String, Number],
                default: 26
            },
            // 选择预置的图标类型
            mode: {
                type: String,
                default: 'data'
            },
            //  图标宽度,单位rpx
            imgWidth: {
                type: [String, Number],
                default: 120
            },
            // 图标高度,单位rpx
            imgHeight: {
                type: [String, Number],
                default: 'auto'
            },
            // 是否显示组件
            show: {
                type: Boolean,
                default: true
            },
            // 组件距离上一个元素之间的距离
            marginTop: {
                type: [String, Number],
                default: 0
            },
            iconStyle: {
                type: Object,
                default() {
                    return {}
                }
            }
        },
        data() {
            return {
                icons: {
                    car: '购物车为空',
                    page: '页面不存在',
                    search: '没有搜索结果',
                    address: '没有收货地址',
                    wifi: '没有WiFi',
                    order: '订单为空',
                    coupon: '没有优惠券',
                    favor: '暂无收藏',
                    permission: '无权限',
                    history: '无历史记录',
                    news: '无新闻列表',
                    message: '消息列表为空',
                    list: '列表为空',
                    data: '数据为空'
                },
                // icons: [{
                //     icon: 'car',
                //     text: '购物车为空'
                // },{
                //     icon: 'page',
                //     text: '页面不存在'
                // },{
                //     icon: 'search',
                //     text: '没有搜索结果'
                // },{
                //     icon: 'address',
                //     text: '没有收货地址'
                // },{
                //     icon: 'wifi',
                //     text: '没有WiFi'
                // },{
                //     icon: 'order',
                //     text: '订单为空'
                // },{
                //     icon: 'coupon',
                //     text: '没有优惠券'
                // },{
                //     icon: 'favor',
                //     text: '暂无收藏'
                // },{
                //     icon: 'permission',
                //     text: '无权限'
                // },{
                //     icon: 'history',
                //     text: '无历史记录'
                // },{
                //     icon: 'news',
                //     text: '无新闻列表'
                // },{
                //     icon: 'message',
                //     text: '消息列表为空'
                // },{
                //     icon: 'list',
                //     text: '列表为空'
                // },{
                //     icon: 'data',
                //     text: '数据为空'
                // }],

            }
        }
    }
</script>

<style scoped lang="scss">
    @import "../../libs/css/style.components.scss";

    .u-empty {
        @include vue-flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        height: 100%;
    }

    .u-image {
        margin-bottom: 20rpx;
    }

    .u-slot-wrap {
        @include vue-flex;
        justify-content: center;
        align-items: center;
        margin-top: 20rpx;
    }
</style>