reason.vue 5.37 KB
<template>
    <div v-if="product.checked" class="reason">
        <div class="select-reason">
            <slot name="type">退货原因</slot>

            <span class="span-right">
                <select class="reason" v-model="product.reason.id" @change="changeReason(product.reason.id)" name="reason">
                    <option v-for="(reason, index) in reasons" :key="index" :value="reason.id" :selected="reason.id === product.reason.id">{{reason.name}}</option>
                </select>
                <span class="iconfont">&#xe604;</span>
            </span>
        </div>
        <template v-if="specialReasons.indexOf(product.reason.id) !== -1">
            <div class="remark">
                <textarea v-model="product.remark" max-length="100" placeholder="退货原因说明"></textarea>
            </div>
            <div class="image-list clearfix">
                <div class="image-item" v-for="(image, index) in imageListForShow" :key="index">
                    <span @click="deleteImage(image.index)" class="icon icon-close"></span>
                    <img :src="image.path | resize(100, 130)">
                </div>
                <upload v-show="imageListForShow.length < 4" class="image-item" :image-list="product.imageList" :bucket="bucket"></upload>
            </div>
        </template>
    </div>
    <div v-else></div>
</template>

<script>
    const upload = require('components/tools/upload.vue');
    const util = require('plugin/util');
    const tip = require('plugin/tip');
    const reasonConfig = require('home/return/reason');

    module.exports = {
        props: ['product', 'data'],
        data() {
            return {
                bucket: 'evidenceImages',
                reasons: [],
                specialReasons: []
            };
        },
        computed: {
            imageListForShow() {
                const list = [];

                this.product.imageList.forEach((path, index) => {
                    list.push({
                        index: index,
                        path: util.getImgHost(path, this.bucket) + '?imageView2/2/w/160/h/160'
                    });
                });

                return list;
            }
        },
        methods: {
            deleteImage(index) {
                this.product.imageList.splice(index, 1);
            },
            changeReason(rid) {
                if (this.product.change &&
                    this.product.change.sku === this.product.productSku &&
                    this.specialReasons.indexOf(rid) === -1) {
                    this.product.change = null;
                    tip.show('无理由换货不可选择相同颜色尺码');
                }
            }
        },
        components: {
            upload
        },
        created() {
            this.reasons = reasonConfig.reasons;
            this.specialReasons = reasonConfig.specialReasons;
        }
    };

</script>

<style>
    .reason {
        font-size: 32px;
        background: #f6f6f6;

        &:after {
            content: "";
            display: block;
            width: 100%;
            height: 30px;
        }

        .select-reason {
            position: relative;
            padding: 0 30px;
            width: 100%;
            height: 90px;
            line-height: 90px;
            background: #fff;
            border-bottom: 1px solid #e0e0e0;
            overflow: hidden;

            select {
                direction: rtl;
                height: 90px;
                line-height: 90px;
                color: #b0b0b0;
            }

            > span {
                float: left;
            }

            .span-right {
                float: right;
                color: #b0b0b0;
            }
        }

        .remark {
            background: #fff;
            padding: 20px 30px;

            textarea {
                width: 100%;
                font-size: 24px;
                resize: none;
                border: 1px solid #e0e0e0;
                border-radius: 5px;
                padding: 10px;
            }
        }

        .image-list {
            padding: 30px;
            padding-top: 5px;
            background: #fff;

            .image-item {
                position: relative;
                float: left;
                margin-right: 25px;
                margin-top: 25px;
                width: 154px;
                height: 154px;

                &:last-child {
                    margin-right: 0;
                }

                .icon-close {
                    position: absolute;
                    right: -20px;
                    top: -20px;
                    font-size: 40px;
                    color: #fff;
                    background: #b0b0b0;
                    border-radius: 100%;
                    z-index: 2;
                }

                img {
                    width: 100%;
                    height: 100%;
                }
            }

            .label-input {
                position: relative;
                width: 150px;
                height: 150px;
                font-size: 150px;

                &:before {
                    content: "\e604";
                }

                input {
                    position: absolute;
                    left: 0;
                    top: 0;
                    width: 0;
                    height: 0;
                    opacity: 0;
                }
            }
        }
    }
</style>