<template>
  <div class="divBox">
    <el-card class="box-card">
      <div slot="header" class="clearfix">
        <el-steps :active="currentTab" align-center finish-status="success">
          <el-step title="商品信息" />
          <el-step title="商品详情" />
          <!-- <el-step title="其他设置" /> -->
          <!--<el-step title="规格设置" />-->
        </el-steps>
      </div>
      <el-form
        ref="formValidate"
        v-loading="loading"
        class="formValidate mt20"
        :rules="ruleValidate"
        :model="formValidate"
        label-width="120px"
        @submit.native.prevent
      >
        <el-row v-show="currentTab === 0" :gutter="24">
          <!-- 商品信息-->
          <el-col v-bind="grid2">
            <el-form-item label="商品分类:" prop="categorys" :rules="[{ required: true, message: '请选择商品分类', trigger: ['blur'] }]">
              <el-cascader
                @change="cascaderChange"
                v-model="formValidate.categorys"
                :options="merCateList"
                :props="props2"
                clearable
                class="selWidth"
                :show-all-levels="false"
                :disabled="isDisabled"
              />
            </el-form-item>
          </el-col>
          <el-col v-bind="grid2">
            <el-form-item label="商品名称:" prop="productName" :rules="[{ required: true, message: '请输入商品名称', trigger: ['blur'] }]">
              <el-input v-model="formValidate.productName" maxlength="249" placeholder="请输入商品名称" :disabled="isDisabled" />
            </el-form-item>
          </el-col>
          <el-col v-bind="grid2">
            <el-form-item label="商品关键字:" prop="keyword">
              <el-input v-model="formValidate.keyword" placeholder="请输入商品关键字" :disabled="isDisabled" />
            </el-form-item>
          </el-col>
          <el-col v-bind="grid2">
            <el-form-item label="商品品牌:" prop="brandId" :rules="[{ required: true, message: '请选择商品品牌', trigger: ['blur'] }]">
              <el-select style="width: 100%;" v-model="formValidate.brandId" placeholder="请选择">
                <el-option v-for="item in brandOptions" :key="item.id" :label="item.brandName" :value="item.id"> </el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col v-bind="grid2">
            <el-form-item label="商品货号" prop="productNum">
              <el-input v-model="formValidate.productNum" maxlength="249" placeholder="请输入商品货号" :disabled="isDisabled" />
            </el-form-item>
          </el-col>
          <el-col v-bind="grid2">
            <el-form-item label="商品售价" prop="price" :rules="[{ required: true, message: '请输入商品售价', trigger: ['blur'] }]">
              <el-input v-model="formValidate.price" maxlength="249" type="number" placeholder="请输入商品售价" :disabled="isDisabled" />
            </el-form-item>
          </el-col>
          <el-col v-bind="grid2">
            <el-form-item label="商品类型:" prop="productType" :rules="[{ required: true, message: '请选择商品类型', trigger: ['blur'] }]">
              <el-select style="width: 100%;" v-model="formValidate.productType" placeholder="请选择商品类型">
                <el-option label="店铺商品" value="2"> </el-option>
                <el-option label="平台商品" value="1"> </el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <!-- <el-col v-bind="grid2">
            <el-form-item label="商品简介:" prop="storeInfo">
              <el-input v-model="formValidate.storeInfo" type="textarea" maxlength="250" :rows="3" placeholder="请输入商品简介"
                :disabled="isDisabled" />
            </el-form-item>
          </el-col> -->
          <el-col v-bind="grid2">
            <el-form-item label="自提油站" prop="siteIds">
              <el-tag
                style="margin-left: 10px;"
                :key="tagIndex"
                v-for="(tag, tagIndex) in OilStationSelectionList"
                closable
                :disable-transitions="false"
                @close="delectOilStationSelectionList(tag, tagIndex)"
              >
                {{ tag.siteName }}
              </el-tag>
              <el-button class="button-new-tag" size="small" @click="isOilStationSelection = true">+ 添加油站</el-button>
            </el-form-item>
          </el-col>
          <el-col v-bind="grid2">
            <el-form-item label="商品推荐:">
              <el-select style="width: 100%;" v-model="formValidate.recommendOrNewMark" placeholder="请选择商品类型">
                <el-option label="新品" value="1"> </el-option>
                <el-option label="推荐" value="2"> </el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="24">
            <el-form-item label="商品上架" prop="productStatus">
              <el-switch active-value="1" inactive-value="2" v-model="formValidate.productStatus" active-color="#13ce66" inactive-color="#ff4949">
              </el-switch>
            </el-form-item>
          </el-col>
          <el-col :span="24">
            <el-form-item label="商品封面图:" prop="image">
              <CustomUpload ref="CustomUpload"></CustomUpload>
            </el-form-item>
          </el-col>
          <el-col :span="24">
            <el-form-item label="商品相册:" prop="sliderImages">
              <CustomUpload :limit="5" ref="CustomLBUpload"> </CustomUpload>
            </el-form-item>
          </el-col>
          <!-- <el-col :span="24">
            <el-form-item label="商品规格:" props="specType">
              <el-radio-group v-model="formValidate.specType" @change="onChangeSpec(formValidate.specType)"
                :disabled="isDisabled">
                <el-radio :label="false" class="radio">单规格</el-radio>
                <el-radio :label="true">多规格</el-radio>
              </el-radio-group>
            </el-form-item>
          </el-col> -->
          <!-- 多规格添加-->
          <el-col v-if="!isDisabled" :span="24" class="noForm">
            <el-form-item
              label="选择规格:"
              prop="attributesTypeId"
              :rules="[{ required: true, message: '请选择规格', trigger: ['blur'] }]"
            >
              <div class="acea-row">
                <el-select v-model="formValidate.attributesTypeId">
                  <el-option v-for="item in ruleList" :key="item.id" :label="item.name" :value="item.id" />
                </el-select>
                <el-button type="primary" class="mr20" @click="confirm">确认</el-button>
                <!-- <el-button class="mr15" @click="addRule">添加规格</el-button> -->
              </div>
            </el-form-item>
            <el-form-item>
              <div v-for="(item, index) in formValidate.attr" :key="index">
                <div class="acea-row row-middle">
                  <span class="mr5">{{ item.attributeName }}</span
                  ><i class="el-icon-circle-close" @click="handleRemoveAttr(index)" />
                </div>
                <div class="rulesBox">
                  <el-tag
                    v-for="(j, indexn) in item.sku.value"
                    :key="indexn"
                    closable
                    size="medium"
                    :disable-transitions="false"
                    class="mb5 mr10"
                    @close="handleClose(item.sku.value, indexn, index)"
                  >
                    {{ j }}
                  </el-tag>
                </div>
              </div>
            </el-form-item>
          </el-col>
          <!-- 批量设置-->
          <el-col v-if="formValidate.attr.length > 0 && !isDisabled" :span="24" class="noForm">
            <el-form-item label="批量设置:">
              <el-table :data="oneFormBatch" border class="tabNumWidth" size="mini">
                <el-table-column v-for="(item, iii) in attrValue" :key="iii" :label="item.label" align="center" min-width="120">
                  <template slot-scope="scope">
                    <el-input
                      :disabled="isDisabled"
                      maxlength="9"
                      min="0.01"
                      v-model="scope.row[item.value]"
                      class="priceBox"
                      @blur="keyupEvent(iii, scope.row[item.value], scope.$index, 3)"
                    />
                  </template>
                </el-table-column>
                <el-table-column align="center" label="操作" min-width="80">
                  <template>
                    <el-button type="text" class="submission" @click="batchAdd">批量添加</el-button>
                  </template>
                </el-table-column>
              </el-table>
            </el-form-item>
          </el-col>
          <el-col :xl="24" :lg="24" :md="24" :sm="24" :xs="24">
            <!-- 单规格表格-->
            <!-- <el-form-item v-if="formValidate.specType === false">
              <el-table :data="OneattrValue" border class="tabNumWidth" size="mini">
                <el-table-column v-for="(item, iii) in attrValue" :key="iii" :label="item.label" align="center"
                  min-width="120">
                  <template slot-scope="scope">
                    <el-input :disabled="isDisabled" maxlength="9" min="0.01" v-model="scope.row[item.value]"
                      class="priceBox" @blur="keyupEvent(iii, scope.row[item.value], scope.$index, 3)" />
                  </template>
                </el-table-column>
              </el-table>
            </el-form-item> -->
            <!-- <el-form-item label="全部sku:" v-if="$route.params.id && showAll">
              <el-button type="default" @click="showAllSku()" :disabled="isDisabled">展示</el-button>
            </el-form-item> -->
            <!-- 多规格表格-->
            <el-form-item v-if="formValidate.attr.length > 0" label="商品属性:" class="labeltop" :class="isDisabled ? 'disLabel' : 'disLabelmoren'">
              <el-table :data="ManyAttrValue" border class="tabNumWidth" size="mini">
                <template v-if="manyTabDate">
                  <el-table-column v-for="item in manyTabDate" :key="item" align="center" :label="item" min-width="80">
                    <template slot-scope="scope">
                      <span class="priceBox" v-text="scope.row[item]" />
                    </template>
                  </el-table-column>
                </template>
                <el-table-column v-for="(item, iii) in attrValue" :key="iii" :label="item.label" align="center" min-width="120">
                  <template slot-scope="scope">
                    <el-input
                      :disabled="isDisabled"
                      maxlength="9"
                      min="0.01"
                      required
                      v-model="scope.row[item.value]"
                      class="priceBox"
                      @blur="keyupEvent(iii, scope.row[item.value], scope.$index, 3)"
                    />
                  </template>
                </el-table-column>
                <el-table-column label="操作" fixed="right">
                  <template slot-scope="scope">
                    <el-button type="text" @click="delAttrTable(scope.$index)">删除</el-button>
                  </template>
                </el-table-column>
              </el-table>
            </el-form-item>
          </el-col>
        </el-row>
        <!-- 商品详情-->
        <el-row v-show="currentTab === 1 && !isDisabled">
          <el-col :span="24">
            <el-form-item label="商品详情:">
              <Tinymce v-model="formValidate.productDetail"></Tinymce>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row v-show="currentTab === 1 && isDisabled">
          <el-col :span="24">
            <el-form-item label="商品详情:">
              <span v-html="formValidate.productDetail || '无'"></span>
            </el-form-item>
          </el-col>
        </el-row>
        <!-- 其他设置-->
        <el-row v-show="currentTab === 2">
          <el-col :span="24">
            <el-col v-bind="grid">
              <el-form-item label="排序:">
                <el-input-number v-model="formValidate.sort" :min="0" placeholder="请输入排序" :disabled="isDisabled" />
              </el-form-item>
            </el-col>
            <el-col v-bind="grid">
              <el-form-item label="积分:">
                <el-input-number v-model="formValidate.giveIntegral" :min="0" placeholder="请输入排序" :disabled="isDisabled" />
              </el-form-item>
            </el-col>
            <el-col v-bind="grid">
              <el-form-item label="虚拟销量:">
                <el-input-number v-model="formValidate.ficti" :min="0" placeholder="请输入排序" :disabled="isDisabled" />
              </el-form-item>
            </el-col>
          </el-col>
          <el-col :span="24">
            <el-form-item label="商品推荐:">
              <el-checkbox-group v-model="checkboxGroup" size="small" @change="onChangeGroup" :disabled="isDisabled">
                <el-checkbox v-for="(item, index) in recommend" :key="index" :label="item.value">{{ item.name }}</el-checkbox>
              </el-checkbox-group>
            </el-form-item>
          </el-col>
          <el-col :span="24">
            <el-form-item label="活动优先级:">
              <div class="color-list acea-row row-middle">
                <div
                  :disabled="isDisabled"
                  class="color-item"
                  :class="activity[item]"
                  v-for="item in formValidate.activity"
                  :key="item"
                  draggable="true"
                  @dragstart="handleDragStart($event, item)"
                  @dragover.prevent="handleDragOver($event, item)"
                  @dragenter="handleDragEnterFont($event, item)"
                  @dragend="handleDragEnd($event, item)"
                >
                  {{ item }}
                </div>
                <div class="tip">可拖动按钮调整活动的优先展示顺序</div>
              </div>
            </el-form-item>
          </el-col>
          <el-col :span="24">
            <el-form-item label="优惠券:" class="proCoupon">
              <div class="acea-row">
                <el-tag
                  v-for="(tag, index) in formValidate.coupons"
                  :key="index"
                  class="mr10 mb10"
                  :closable="!isDisabled"
                  :disable-transitions="false"
                  @close="handleCloseCoupon(tag)"
                >
                  {{ tag.name }}
                </el-tag>
                <!-- <span v-if="formValidate.couponIds == null">无</span> -->
                <el-button v-if="!isDisabled" class="mr15" @click="addCoupon">选择优惠券</el-button>
              </div>
            </el-form-item>
          </el-col>
        </el-row>
        <el-form-item>
          <el-button v-show="currentTab > 0" class="submission priamry_border" @click="handleSubmitUp">上一步</el-button>
          <el-button v-show="currentTab < 1" type="primary" class="submission" @click="handleSubmitNest('formValidate')">下一步</el-button>
          <el-button
            v-show="(currentTab === 1 || $route.params.id) && !isDisabled"
            type="primary"
            class="submission"
            @click="handleSubmit('formValidate')"
            >提交</el-button
          >
        </el-form-item>
      </el-form>
    </el-card>
    <CreatTemplates ref="addTemplates" @getList="getShippingList" />
    <el-dialog width="80%" title="选择油站" :visible.sync="isOilStationSelection">
      <OilStationSelection :product-id="this.$route.query.id" ref="selectSites" :OilStationSelectionList="OilStationSelectionList" @submit="oilStationSelectionSubmit"> </OilStationSelection>
    </el-dialog>
  </div>
</template>

<script>
import productApi from '@/api/product/productAttr.js'
import Tinymce from '@/components/Tinymce/index'
import CreatTemplates from '@/views/systemSetting/logistics/shippingTemplates/creatTemplates'
import Templates from '../../appSetting/wxAccount/wxTemplate/index'
import { Debounce } from '@/utils/validate'
import CustomUpload from './components/CustomUpload.vue'
import OilStationSelection from './components/OilStationSelection.vue'
import { loadingFn } from '@/utils/validate'

const defaultObj = {
  image: '',
  sliderImages: [],
  videoLink: '',
  sliderImage: '',
  storeName: '',
  storeInfo: '',
  keyword: '',
  cateIds: [], // 商品分类id
  cateId: null, // 商品分类id传值
  unitName: '',
  sort: 0,
  giveIntegral: 0,
  ficti: 0,
  isShow: false,
  isBenefit: false,
  isNew: false,
  isGood: false,
  isHot: false,
  isBest: false,
  tempId: '',
  attrValue: [
    {
      image: '',
      price: 0,
      cost: 0,
      otPrice: 0,
      stock: 0,
      barCode: '',
      weight: 0,
      volume: 0
    }
  ],
  attr: [],
  selectRule: '',
  isSub: false,
  content: '',
  specType: false,
  id: 0,
  couponIds: [],
  coupons: [],
  activity: ['默认', '秒杀', '砍价', '拼团']
}
const objTitle = {
  price: {
    title: '市场价格'
  },
  cost: {
    title: '销售价格'
  },
  otPrice: {
    title: '商品库存'
  },
  stock: {
    title: 'SKU编号'
  },
  barCode: {
    title: '兑换积分'
  }
}
export default {
  name: 'ProductProductAdd',
  components: { Templates, CreatTemplates, Tinymce, CustomUpload, OilStationSelection },
  data() {
    return {
      loading: false,
      OilStationSelectionList: [],
      isOilStationSelection: false,
      brandOptions: [],
      isDisabled: this.$route.params.isDisabled === '1' ? true : false,
      activity: { 默认: 'red', 秒杀: 'blue', 砍价: 'green', 拼团: 'yellow' },
      props2: {
        children: 'children',
        label: 'categoryName',
        value: 'id'
      },
      checkboxGroup: [],
      recommend: [],
      tabs: [],
      fullscreenLoading: false,
      props: { multiple: true },
      active: 0,
      OneattrValue: [Object.assign({}, defaultObj.attrValue[0])], // 单规格
      ManyAttrValue: [Object.assign({}, defaultObj.attrValue[0])], // 多规格
      ruleList: [],
      merCateList: [], // 商户分类筛选
      shippingList: [], // 运费模板
      formThead: Object.assign({}, objTitle),
      formValidate: {
        recommendOrNewMark: '1',
        productStatus: '1',
        attr: [],
        productDetail: ''
      },
      formDynamics: {
        ruleName: '',
        ruleValue: []
      },
      tempData: {
        page: 1,
        limit: 9999
      },
      manyTabTit: {},
      manyTabDate: {},
      grid2: {
        xl: 12,
        lg: 12,
        md: 12,
        sm: 24,
        xs: 24
      },
      // 规格数据
      formDynamic: {
        attrsName: '',
        attrsVal: ''
      },
      isBtn: false,
      manyFormValidate: [],
      currentTab: 0,
      isChoice: '',
      grid: {
        xl: 8,
        lg: 8,
        md: 12,
        sm: 24,
        xs: 24
      },
      ruleValidate: {
        // storeName: [
        //   { required: true, message: '请输入商品名称', trigger: 'blur' }
        // ],
        // cateIds: [
        //   { required: true, message: '请选择商品分类', trigger: 'change', type: 'array', min: '1' }
        // ],
        // keyword: [
        //   { required: true, message: '请输入商品关键字', trigger: 'blur' }
        // ],
        // unitName: [
        //   { required: true, message: '请输入单位', trigger: 'blur' }
        // ],
        // storeInfo: [
        //   { required: true, message: '请输入商品简介', trigger: 'blur' }
        // ],
        // tempId: [
        //   { required: true, message: '请选择运费模板', trigger: 'change' }
        // ],
        // image: [
        //   { required: true, message: '请上传商品图', trigger: 'change' }
        // ],
        // sliderImages: [
        //   { required: true, message: '请上传商品轮播图', type: 'array', trigger: 'change' }
        // ],
        // specType: [
        //   { required: true, message: '请选择商品规格', trigger: 'change' }
        // ]
      },
      attrInfo: {},
      tableFrom: {
        page: 1,
        limit: 9999,
        keywords: ''
      },
      tempRoute: {},
      keyNum: 0,
      isAttr: false,
      showAll: false,
      videoLink: '',
      attrValue: [
        {
          label: '市场价格',
          name: '市场价格',
          value: 'marketPrice'
        },
        {
          label: '销售价格',
          name: '销售价格',
          value: 'sellPrice'
        },
        {
          label: '商品库存',
          name: '商品库存',
          value: 'stock'
        },
        {
          label: 'SKU编号',
          name: 'SKU编号',

          value: 'skuNum'
        },
        {
          label: '兑换积分',
          name: '兑换积分',
          value: 'integral'
        }
      ]
    }
  },
  computed: {
    oneFormBatch() {
      const obj = [Object.assign({}, defaultObj.attrValue[0])]
      delete obj[0].barCode
      return obj
    }
  },
  watch: {
    $route(to, from) {
      if (from.path == '/productList' && to.params.id) {
        this.chenkId()
      }
      console.log(from.path) //从哪来
      console.log(to.path, to.params) //到哪去
    },
    'formValidate.content': function(n) {  },
    ManyAttrValue(n) {},
    'formValidate.attr': {
      handler: function(val,o) {
        if (this.isAttr) this.watCh(val,o) //重要!!!
      },
      immediate: false,
      deep: true
    }
  },
  async created() {
    await this.chenkId()
    await this.getCategorySelect()
    await this.productGetRule()
    await this.brandGetAll()
  },
  mounted() {},
  deactivated() {
        this.$destroy();
    },
  methods: {
    async chenkId() {
      if (this.$route.query && this.$route.query.id) {
        await this.getproductInfo(this.$route.query.id)
      }
    },
    productAddGetSites(ids) {
      Promise.all(
        ids.map(id => {
          return productApi.productAddGetSites(id)
        })
      ).then(res => {
        console.log(res, 'productAddGetSites')
      })
    },
    async inverseAnalysis(data) {
      let { categoryOneId, categoryTwoId } = data;
      let categorys = [categoryOneId, categoryTwoId];
      this.OilStationSelectionList = data.siteInfos;
      this.formValidate =  {
        ...this.formValidate,
        categorys,
        ...data
      }
      // Object.assign(this.formValidate, {
      //   categorys,
      //   ...data
      // })
      this.$refs.CustomUpload.fileList = [...this.formValidate.images.filter(item => item.mainMark == '1')]
      this.$refs.CustomLBUpload.fileList = [...this.formValidate.images.filter(item => item.mainMark != '1')]
      await this.confirm()
      this.$nextTick(() => {
        this.formValidate.attr = this.formValidate.attr.map(item => {
            let align = this.formValidate.checkedList.find(i => item.id == i.attributeId)
            if (align) {
              return {
                ...item,
                sku: {
                  ...item.sku,
                  value: align.checked.split(',')
                }
              }
            } else {
              return null
            }
          }).filter(item => item);
        setTimeout(() => {
          this.ManyAttrValue.forEach((item, index) => {
            let data = this.formValidate.stockList.find(i => i.attributeJson == JSON.stringify(item.data));
            if (data) {
              Object.assign(item, data,{delect:false})
            }else{
              Object.assign(item, data,{delect:true})
            }
          })
          this.ManyAttrValue = this.ManyAttrValue.filter(item=>!item.delect)
        }, 1000)
      })
    },
    async getproductInfo(id) {
      await productApi.productAddGetEdit(id).then( async res => {
        if (res.code == 20000) {
         await this.inverseAnalysis(res.data)
        }
      })
    },
    setPreferred(setPreferred) {
      console.log(setPreferred, 'setPreferred')
    },
    delectOilStationSelectionList(e, index) {
      this.OilStationSelectionList.splice(index, 1)
      if (this.$refs.selectSites&&this.$refs.selectSites.checkedSites){
        this.$refs.selectSites.checkedSites =  this.$refs.selectSites.checkedSites.filter(site => e.siteId !== site.siteId);
      }
    },
    oilStationSelectionSubmit(e) {
      this.OilStationSelectionList = e
      this.isOilStationSelection = false
      this.formValidate.siteIds = e.map(item => item.siteId)
    },
   async brandGetAll() {
      await productApi.brandGetAll().then(res => {
        if (res.code == 20000) {
          this.brandOptions = res.data
        }
      })
    },
    cascaderChange(e) {
      console.log(e, 'cascaderChange')
    },
    // 校验输入框不能输入0,保留2位小数,库存为正整数
    keyupEvent(key, val, index, num) {
      if (key === 'barCode') return
      var re = /^\D*([0-9]\d*\.?\d{0,2})?.*$/
      switch (num) {
        case 1:
          if (val == 0) {
            this.oneFormBatch[index][key] = key === 'stock' ? 0 : 0.01
          } else {
            this.oneFormBatch[index][key] =
              key === 'stock' ? parseInt(val) : this.$set(this.oneFormBatch[index], key, val.toString().replace(re, '$1'))
          }
          break
        case 2:
          if (val == 0) {
            this.OneattrValue[index][key] = key === 'stock' ? 0 : 0.01
          } else {
            this.OneattrValue[index][key] =
              key === 'stock' ? parseInt(val) : this.$set(this.OneattrValue[index], key, val.toString().replace(re, '$1'))
          }
          break
        default:
          if (val == 0) {
            this.ManyAttrValue[index][key] = key === 'stock' ? 0 : 0.01
          } else {
            this.ManyAttrValue[index][key] =
              key === 'stock' ? parseInt(val) : this.$set(this.ManyAttrValue[index], key, val.toString().replace(re, '$1'))
          }
          break
      }
    },
    handleCloseCoupon(tag) {
      this.isAttr = true
      this.formValidate.coupons.splice(this.formValidate.coupons.indexOf(tag), 1)
      this.formValidate.couponIds.splice(this.formValidate.couponIds.indexOf(tag.id), 1)
    },
    addCoupon() {
      const _this = this
      this.$modalCoupon(
        'wu',
        (this.keyNum += 1),
        this.formValidate.coupons,
        function(row) {
          _this.formValidate.couponIds = []
          _this.formValidate.coupons = row
          row.map(item => {
            _this.formValidate.couponIds.push(item.id)
          })
        },
        ''
      )
    },
    setTagsViewTitle() {
      const title = this.isDisabled ? '商品详情' : '编辑商品'
      const route = Object.assign({}, this.tempRoute, { title: `${title}-${this.$route.query.id}` })
      this.$store.dispatch('tagsView/updateVisitedView', route)
    },
    onChangeGroup() {
      this.checkboxGroup.includes('isGood') ? (this.formValidate.isGood = true) : (this.formValidate.isGood = false)
      this.checkboxGroup.includes('isBenefit') ? (this.formValidate.isBenefit = true) : (this.formValidate.isBenefit = false)
      this.checkboxGroup.includes('isBest') ? (this.formValidate.isBest = true) : (this.formValidate.isBest = false)
      this.checkboxGroup.includes('isNew') ? (this.formValidate.isNew = true) : (this.formValidate.isNew = false)
      this.checkboxGroup.includes('isHot') ? (this.formValidate.isHot = true) : (this.formValidate.isHot = false)
    },
    // sku算法
    watCh(val,o) {
      let arr = []
      this.manyTabDate = []
      for (let i = 0; i < val.length; i++) {
        arr.push(val[i].sku)
        this.manyTabDate.push(val[i].sku.name)
      }
      this.ManyAttrValue = arr.reduce(
        (a, b, c) => {
          let res = []
          a.map(x => {
            b.value.map(y => {
              res.push({
                ...x,
                [b.name]: y,
                data: Object.assign({}, x.data || {}, { [b.name]: y }),
                ...Object.fromEntries(
                  this.attrValue.map(item => {
                    return [item.value, '']
                  })
                )
              })
            })
          })
          return res
        },
        [{}]
      );
      console.log(this.ManyAttrValue ,"this.ManyAttrValue ")
    },
    attrFormat(arr) {
      let data = []
      const res = []
      return format(arr)
      function format(arr) {
        if (arr.length > 1) {
          arr.forEach((v, i) => {
            if (i === 0) data = arr[i]['attrValue']
            const tmp = []
            if (!data) return
            data.forEach(function(vv) {
              arr[i + 1] &&
                arr[i + 1]['attrValue'] &&
                arr[i + 1]['attrValue'].forEach(g => {
                  const rep2 = (i !== 0 ? '' : arr[i]['attrName'] + '_') + vv + '$&' + arr[i + 1]['attrName'] + '_' + g
                  tmp.push(rep2)
                  if (i === arr.length - 2) {
                    const rep4 = {
                      image: '',
                      price: 0,
                      cost: 0,
                      otPrice: 0,
                      stock: 0,
                      barCode: '',
                      weight: 0,
                      volume: 0,
                      brokerage: 0,
                      brokerage_two: 0
                    }
                    rep2.split('$&').forEach((h, k) => {
                      const rep3 = h.split('_')
                      if (!rep4['attrValue']) rep4['attrValue'] = {}
                      rep4['attrValue'][rep3[0]] = rep3.length > 1 ? rep3[1] : ''
                    })
                    for (let attrValueKey in rep4.attrValue) {
                      rep4[attrValueKey] = rep4.attrValue[attrValueKey]
                    }
                    res.push(rep4)
                  }
                })
            })
            data = tmp.length ? tmp : []
          })
        } else {
          const dataArr = []
          arr.forEach((v, k) => {
            v['attrValue'].forEach((vv, kk) => {
              dataArr[kk] = v['attrName'] + '_' + vv
              res[kk] = {
                image: '',
                price: 0,
                cost: 0,
                otPrice: 0,
                stock: 0,
                barCode: '',
                weight: 0,
                volume: 0,
                brokerage: 0,
                brokerage_two: 0,
                attrValue: { [v['attrName']]: vv }
              }
              // Object.values(res[kk].attrValue).forEach((v, i) => {
              //   res[kk]['value' + i] = v
              // })
              for (let attrValueKey in res[kk].attrValue) {
                res[kk][attrValueKey] = res[kk].attrValue[attrValueKey]
              }
            })
          })
          data.push(dataArr.join('$&'))
        }
        return res
      }
    },
    // 运费模板
    addTem() {
      this.$refs.addTemplates.dialogVisible = true
      this.$refs.addTemplates.getCityList()
    },
    // 添加规则;
    addRule() {
      const _this = this
      this.$modalAttr(this.formDynamics, function() {
        _this.productGetRule()
      })
    },
    // 选择规格
    onChangeSpec(num) {
      this.isAttr = true
      if (num) this.productGetRule()
    },
    // 选择属性确认
    async confirm(is = true) {
      this.isAttr = true
      if (is) {
        if (!this.formValidate.attributesTypeId) {
          return this.$message.warning('请选择属性')
        }
        await this.productGetRule()
        this.formValidate.attr = JSON.parse(JSON.stringify(this.ruleList.find(item => item.id == this.formValidate.attributesTypeId).attributesList))
      }
    },
    // 商品分类;
   async getCategorySelect() {
      await productApi.getClassificationTree().then(res => {
        if (res.code == 20000) {
          this.merCateList = res.data
        }
      })
    },
    filerMerCateList(treeData) {
      return treeData.map(item => {
        if (!item.child) {
          item.disabled = true
        }
        item.label = item.name
        return item
      })
    },
    // 获取商品属性模板;
    productGetRule() {
      return new Promise((re, rj) => {
        productApi.getAllAttributesType().then(res => {
          if (res.code == 20000) {
            this.ruleList = res.data.map(item => {
              return {
                ...item,
                attributesList: item.attributesList.map(citem => {
                  return {
                    ...citem,
                    sku: { name: citem.attributeName, value: citem.attributeContent.split(',') }
                  }
                })
              }
            })
            re(this.ruleList)
          }
        })
      })
    },
    // 运费模板;
    getShippingList() {
      shippingTemplatesList(this.tempData).then(res => {
        this.shippingList = res.list
      })
    },
    showInput(item) {
      this.$set(item, 'inputVisible', true)
    },
    onChangetype(item) {
      if (item === 1) {
        this.OneattrValue.map(item => {
          this.$set(item, 'brokerage', null)
          this.$set(item, 'brokerageTwo', null)
        })
        this.ManyAttrValue.map(item => {
          this.$set(item, 'brokerage', null)
          this.$set(item, 'brokerageTwo', null)
        })
      } else {
        this.OneattrValue.map(item => {
          delete item.brokerage
          delete item.brokerageTwo
          this.$set(item, 'brokerage', null)
          this.$set(item, 'brokerageTwo', null)
        })
        this.ManyAttrValue.map(item => {
          delete item.brokerage
          delete item.brokerageTwo
        })
      }
    },
    // 删除表格中的属性
    delAttrTable(index) {
      this.ManyAttrValue.splice(index, 1)
    },
    // 批量添加
    batchAdd() {
      // if (!this.oneFormBatch[0].pic || !this.oneFormBatch[0].price || !this.oneFormBatch[0].cost || !this.oneFormBatch[0].ot_price ||
      //     !this.oneFormBatch[0].stock || !this.oneFormBatch[0].bar_code) return this.$Message.warning('请填写完整的批量设置内容!');
      console.log(this.ManyAttrValue, this.oneFormBatch, ' this.ManyAttrValue')
      this.ManyAttrValue.forEach(item => {
        Object.assign(item, this.oneFormBatch[0])
      })
    },
    // 添加按钮
    addBtn() {
      this.clearAttr()
      this.isBtn = true
    },
    // 取消
    offAttrName() {
      this.isBtn = false
    },
    clearAttr() {
      this.isAttr = true
      this.formDynamic.attrsName = ''
      this.formDynamic.attrsVal = ''
    },
    // 删除规格
    handleRemoveAttr(index) {
      this.isAttr = true
      this.formValidate.attr.splice(index, 1)
      this.manyFormValidate.splice(index, 1)
    },
    // 删除属性
    handleClose(item, index, parentIndex) {
      if (item.length == 1) {
        this.handleRemoveAttr(parentIndex)
      } else {
        item.splice(index, 1)
      }

    },
    // 添加规则名称
    createAttrName() {
      this.isAttr = true
      if (this.formDynamic.attrsName && this.formDynamic.attrsVal) {
        const data = {
          attrName: this.formDynamic.attrsName,
          attrValue: [this.formDynamic.attrsVal]
        }
        this.formValidate.attr.push(data)
        var hash = {}
        this.formValidate.attr = this.formValidate.attr.reduce(function(item, next) {
          /* eslint-disable */
          hash[next.attrName] ? '' : (hash[next.attrName] = true && item.push(next))
          return item
        }, [])
        this.clearAttr()
        this.isBtn = false
      } else {
        this.$Message.warning('请添加完整的规格!')
      }
    },
    // 添加属性
    createAttr(num, idx) {
      this.isAttr = true
      if (num) {
        this.formValidate.attr[idx].attrValue.push(num)
        var hash = {}
        this.formValidate.attr[idx].attrValue = this.formValidate.attr[idx].attrValue.reduce(function(item, next) {
          /* eslint-disable */
          hash[next] ? '' : (hash[next] = true && item.push(next))
          return item
        }, [])
        this.formValidate.attr[idx].inputVisible = false
      } else {
        this.$message.warning('请添加属性')
      }
    },
    //点击展示所有多规格属性
    showAllSku() {
      if (this.isAttr == false) {
        this.isAttr = true
        if (this.formValidate.specType && this.isAttr) this.watCh(this.formValidate.attr) //重要!!!
      } else if (this.isAttr == true) {
        this.isAttr = false
        this.getInfo()
      }
    },
    // 详情
    getInfo() {
      this.fullscreenLoading = true
      productDetailApi(this.$route.query.id)
        .then(async res => {
          // this.isAttr = true;
          let info = res
          this.formValidate = {
            image: this.$selfUtil.setDomain(info.image),
            sliderImage: info.sliderImage,
            sliderImages: JSON.parse(info.sliderImage),
            storeName: info.storeName,
            storeInfo: info.storeInfo,
            keyword: info.keyword,
            cateIds: info.cateId.split(','), // 商品分类id
            cateId: info.cateId, // 商品分类id传值
            unitName: info.unitName,
            sort: info.sort,
            isShow: info.isShow,
            isBenefit: info.isBenefit,
            isNew: info.isNew,
            isGood: info.isGood,
            isHot: info.isHot,
            isBest: info.isBest,
            tempId: info.tempId,
            attr: info.attr,
            attrValue: info.attrValue,
            selectRule: info.selectRule,
            isSub: info.isSub,
            content: this.$selfUtil.replaceImgSrcHttps(info.content),
            specType: info.specType,
            id: info.id,
            giveIntegral: info.giveIntegral,
            ficti: info.ficti,
            coupons: info.coupons,
            couponIds: info.couponIds,
            activity: info.activityStr ? info.activityStr.split(',') : ['默认', '秒杀', '砍价', '拼团']
          }
          marketingSendApi({ type: 3 }).then(res => {
            if (this.formValidate.couponIds !== null) {
              let ids = this.formValidate.couponIds.toString()
              let arr = res.list
              let obj = {}
              for (let i in arr) {
                obj[arr[i].id] = arr[i]
              }
              let strArr = ids.split(',')
              let newArr = []
              for (let item of strArr) {
                if (obj[item]) {
                  newArr.push(obj[item])
                }
              }
              this.$set(this.formValidate, 'coupons', newArr) //在编辑回显时,让返回数据中的优惠券id,通过接口匹配显示,
            }
          })
          let imgs = JSON.parse(info.sliderImage)
          let imgss = []
          Object.keys(imgs).map(i => {
            imgss.push(this.$selfUtil.setDomain(imgs[i]))
          })
          this.formValidate.sliderImages = [...imgss]
          if (info.isHot) this.checkboxGroup.push('isHot')
          if (info.isGood) this.checkboxGroup.push('isGood')
          if (info.isBenefit) this.checkboxGroup.push('isBenefit')
          if (info.isBest) this.checkboxGroup.push('isBest')
          if (info.isNew) this.checkboxGroup.push('isNew')
          this.productGetRule()
          if (info.specType) {
            this.formValidate.attr = info.attr.map(item => {
              return {
                attrName: item.attrName,
                attrValue: item.attrValues.split(',')
              }
            })
            this.ManyAttrValue = info.attrValue
            this.ManyAttrValue.forEach(val => {
              val.image = this.$selfUtil.setDomain(val.image)
              val.attrValue = JSON.parse(val.attrValue)
              this.attrInfo[
                Object.values(val.attrValue)
                  .sort()
                  .join('/')
              ] = val
            })
            /***多规格商品如果被删除过sku,优先展示api返回的数据,否则会有没有删除的错觉***/
            let manyAttr = this.attrFormat(this.formValidate.attr)
            if (manyAttr.length !== this.ManyAttrValue.length) {
              this.$set(this, 'showAll', true)
              this.isAttr = false
            } else {
              this.isAttr = true
            }
            /*******/
            const tmp = {}
            const tmpTab = {}
            this.formValidate.attr.forEach((o, i) => {
              // tmp['value' + i] = { title: o.attrName }
              // tmpTab['value' + i] = ''
              tmp[o.attrName] = { title: o.attrName }
              tmpTab[o.attrName] = ''
            })

            // 此处手动实现后台原本value0 value1的逻辑
            this.formValidate.attrValue.forEach(item => {
              for (let attrValueKey in item.attrValue) {
                item[attrValueKey] = item.attrValue[attrValueKey]
              }
            })

            this.manyTabTit = tmp
            this.manyTabDate = tmpTab
            this.formThead = Object.assign({}, this.formThead, tmp)
          } else {
            this.OneattrValue = info.attrValue
            // this.formValidate.attr = [] //单规格商品规格设置为空
          }
          this.fullscreenLoading = false
        })
        .catch(res => {
          this.fullscreenLoading = false
          this.$message.error(res.message)
        })
    },
    handleRemove(i) {
      this.formValidate.sliderImages.splice(i, 1)
    },
    // 点击商品图
    modalPicTap(tit, num, i, status) {
      const _this = this
      if (_this.isDisabled) return
      this.$modalUpload(
        function(img) {
          if (tit === '1' && !num) {
            _this.formValidate.image = img[0].sattDir
            _this.OneattrValue[0].image = img[0].sattDir
          }
          if (tit === '2' && !num) {
            if (img.length > 10) return this.$message.warning('最多选择10张图片!')
            if (img.length + _this.formValidate.sliderImages.length > 10) return this.$message.warning('最多选择10张图片!')
            img.map(item => {
              _this.formValidate.sliderImages.push(item.sattDir)
            })
          }
          if (tit === '1' && num === 'dan') {
            _this.OneattrValue[0].image = img[0].sattDir
          }
          if (tit === '1' && num === 'duo') {
            _this.ManyAttrValue[i].image = img[0].sattDir
          }
          if (tit === '1' && num === 'pi') {
            _this.oneFormBatch[0].image = img[0].sattDir
          }
        },
        tit,
        'content'
      )
    },
    handleSubmitUp() {
      // this.currentTab --
      if (this.currentTab-- < 0) this.currentTab = 0
    },
    handleSubmitNest(name) {
      console.log(this.formValidate,"handleSubmitNest")
      if (this.formValidate.attr<1){
        this.$message.error('规格属性不能为空')
        return
      }
      this.$refs[name].validate(valid => {
        if (valid) {
          if (this.currentTab++ > 2) this.currentTab = 0
        } else {
          if (
            !this.formValidate.store_name ||
            !this.formValidate.cate_id ||
            !this.formValidate.keyword ||
            !this.formValidate.unit_name ||
            !this.formValidate.store_info ||
            !this.formValidate.image ||
            !this.formValidate.slider_image
          ) {
            this.$message.warning('请填写完整商品信息!')
          }
        }
      })
    },
    // 提交
    handleSubmit: Debounce(function(name) {
      let cover = this.$refs.CustomUpload.getFileList()
      let Carousel = this.$refs.CustomLBUpload.getFileList()
      cover.length && (cover[0]['mainMark'] = 1)
      let [categoryOneId, categoryTwoId] = this.formValidate.categorys
      let isRecommendOrNewMark = this.formValidate.recommendOrNewMark == '1' ? 'newMark' : 'recommend'
      let siteIds = this.OilStationSelectionList.map(item => item.siteId)
      if(siteIds.length==0){
        this.$message.error('请选择油站')
        return
      }
      let checkedList = this.formValidate.attr.map(item => {
        let attributeId = item.id
        let checked = item.sku.value.join(',')
        return { attributeId, checked }
      })
      let images = cover.concat(Carousel).map((item, index) => {
        let { name, url, mainMark = '' } = item
        return {
          name,
          url,
          mainMark
        }
      })
      let stockList = this.ManyAttrValue.map(item => {
        let { marketPrice = '', sellPrice = '', stock = '', integral = '', skuNum = '', id = '' } = item
        return {
          attributeJson: JSON.stringify(item.data),
          marketPrice,
          sellPrice,
          stock,
          integral,
          skuNum,
          id
        }
      })
      this.formValidate[isRecommendOrNewMark] = '1'
      loadingFn.call(
        this,
        'loading',
        productApi[this.$route.query.id ? 'addUpdate' : 'addSave'](
          Object.assign(this.formValidate, {
            categoryOneId,
            categoryTwoId,
            siteIds,
            checkedList,
            images,
            stockList
          })
        ).then(res => {
          if (res.code == 20000) {
            this.$message.success('操作成功')
            setTimeout(() => {
              this.$router.push({ path: 'productList', query: { refresh: true }})
              // this.$destroy()
            }, 1000)
          }
        })
      )

      // this.onChangeGroup()
      // if (this.formValidate.specType && this.formValidate.attr.length < 1) return this.$message.warning("请填写多规格属性!");
      // this.formValidate.cateId = this.formValidate.cateIds.join(',')
      // this.formValidate.sliderImage = JSON.stringify(this.formValidate.sliderImages)
      // if (this.formValidate.specType) {
      //   this.formValidate.attrValue = this.ManyAttrValue;
      //   this.formValidate.attr = this.formValidate.attr.map((item) => {
      //     return {
      //       attrName: item.attrName,
      //       id: item.id,
      //       attrValues: item.attrValue.join(','),
      //     }
      //   })
      //   for (var i = 0; i < this.formValidate.attrValue.length; i++) {
      //     this.$set(this.formValidate.attrValue[i], 'id', 0);
      //     this.$set(this.formValidate.attrValue[i], 'productId', 0);
      //     this.$set(this.formValidate.attrValue[i], 'attrValue', JSON.stringify(this.formValidate.attrValue[i].attrValue)); //
      //     delete this.formValidate.attrValue[i].value0
      //   }
      // } else {
      //   this.formValidate.attr = [{ attrName: '规格', attrValues: '默认', id: this.$route.params.id ? this.formValidate.attr[0].id : 0 }]
      //   this.OneattrValue.map(item => {
      //     this.$set(item, 'attrValue', JSON.stringify({ '规格': '默认' }))
      //   })
      //   this.formValidate.attrValue = this.OneattrValue
      // }
      // this.$refs[name].validate((valid) => {
      //   if (valid) {
      //     this.fullscreenLoading = true
      //     this.$route.params.id ? productUpdateApi(this.formValidate).then(async res => {
      //       this.$message.success('编辑成功');
      //       setTimeout(() => {
      //         this.$router.push({ path: '/store/index' });
      //       }, 500);
      //       this.fullscreenLoading = false
      //     }).catch(res => {
      //       this.fullscreenLoading = false
      //     }) : productCreateApi(this.formValidate).then(async res => {
      //       this.$message.success('新增成功');
      //       setTimeout(() => {
      //         this.$router.push({ path: '/store/index' });
      //       }, 500);
      //       this.fullscreenLoading = false
      //     }).catch(res => {
      //       this.fullscreenLoading = false
      //     })
      //   } else {
      //     if (!this.formValidate.storeName || !this.formValidate.cateId || !this.formValidate.keyword
      //       || !this.formValidate.unitName || !this.formValidate.storeInfo || !this.formValidate.image || !this.formValidate.sliderImages) {
      //       this.$message.warning("请填写完整商品信息!");
      //     }
      //   }
      // });
    }),
    // 表单验证
    validate(prop, status, error) {
      if (status === false) {
        this.$message.warning(error)
      }
    },
    // 移动
    handleDragStart(e, item) {
      if (!this.isDisabled) this.dragging = item
    },
    handleDragEnd(e, item) {
      if (!this.isDisabled) this.dragging = null
    },
    handleDragOver(e) {
      if (!this.isDisabled) e.dataTransfer.dropEffect = 'move'
    },
    handleDragEnter(e, item) {
      if (!this.isDisabled) {
        e.dataTransfer.effectAllowed = 'move'
        if (item === this.dragging) {
          return
        }
        const newItems = [...this.formValidate.sliderImages]
        const src = newItems.indexOf(this.dragging)
        const dst = newItems.indexOf(item)
        newItems.splice(dst, 0, ...newItems.splice(src, 1))
        this.formValidate.sliderImages = newItems
      }
    },
    handleDragEnterFont(e, item) {
      if (!this.isDisabled) {
        e.dataTransfer.effectAllowed = 'move'
        if (item === this.dragging) {
          return
        }
        const newItems = [...this.formValidate.activity]
        const src = newItems.indexOf(this.dragging)
        const dst = newItems.indexOf(item)
        newItems.splice(dst, 0, ...newItems.splice(src, 1))
        this.formValidate.activity = newItems
      }
    },
    getGoodsType() {
      /** 让商品推荐列表的name属性与页面设置tab的name匹配**/
      goodDesignList({ gid: 70 }).then(response => {
        let list = response.list
        let arr = [],
          arr1 = []
        const listArr = [{ name: '是否热卖', value: 'isGood' }]
        let typeLists = [
          { name: '', value: 'isHot', type: '2' }, //热门榜单
          { name: '', value: 'isBenefit', type: '4' }, //促销单品
          { name: '', value: 'isBest', type: '1' }, //精品推荐
          { name: '', value: 'isNew', type: '3' }
        ] //首发新品
        list.forEach(item => {
          let obj = {}
          obj.value = JSON.parse(item.value)
          obj.id = item.id
          obj.gid = item.gid
          obj.status = item.status
          arr.push(obj)
        })
        arr.forEach(item1 => {
          let obj1 = {}
          obj1.name = item1.value.fields[1].value
          obj1.status = item1.status
          obj1.type = item1.value.fields[3].value
          arr1.push(obj1)
        })
        typeLists.forEach(item => {
          arr1.forEach(item1 => {
            if (item.type == item1.type) {
              listArr.push({
                name: item1.name,
                value: item.value,
                type: item.type
              })
            }
          })
        })
        this.recommend = listArr
      })
    }
  }
}
</script>
<style scoped lang="scss">
.disLabel {
  ::v-deep.el-form-item__label {
    margin-left: 36px !important;
  }
}

.disLabelmoren {
  ::v-deep.el-form-item__label {
    margin-left: 120px !important;
  }
}

.priamry_border {
  border: 1px solid #1890ff;
  color: #1890ff;
}

.color-item {
  height: 30px;
  line-height: 30px;
  padding: 0 10px;
  color: #fff;
  margin-right: 10px;
}

.color-list .color-item.blue {
  background-color: #1e9fff;
}

.color-list .color-item.yellow {
  background-color: rgb(254, 185, 0);
}

.color-list .color-item.green {
  background-color: #009688;
}

.color-list .color-item.red {
  background-color: #ed4014;
}

.proCoupon {
  ::v-deep.el-form-item__content {
    margin-top: 5px;
  }
}

.tabPic {
  width: 40px !important;
  height: 40px !important;

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

.noLeft {
  ::v-deep.el-form-item__content {
    margin-left: 0 !important;
  }
}

.tabNumWidth {
  ::v-deep.el-input-number--medium {
    width: 121px !important;
  }

  ::v-deep.el-input-number__increase {
    width: 20px !important;
    font-size: 12px !important;
  }

  ::v-deep.el-input-number__decrease {
    width: 20px !important;
    font-size: 12px !important;
  }

  ::v-deep.el-input-number--medium .el-input__inner {
    padding-left: 25px !important;
    padding-right: 25px !important;
  }

  ::v-deep thead {
    line-height: normal !important;
  }

  ::v-deep .el-table .cell {
    line-height: normal !important;
  }
}

.selWidth {
  width: 100%;
}

.selWidthd {
  width: 300px;
}

.button-new-tag {
  height: 28px;
  line-height: 26px;
  padding-top: 0;
  padding-bottom: 0;
}

.input-new-tag {
  width: 90px;
  margin-left: 10px;
  vertical-align: bottom;
}

.pictrue {
  width: 60px;
  height: 60px;
  border: 1px dotted rgba(0, 0, 0, 0.1);
  margin-right: 10px;
  position: relative;
  cursor: pointer;

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

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

.btndel {
  position: absolute;
  z-index: 1;
  width: 20px !important;
  height: 20px !important;
  left: 46px;
  top: -4px;
}

.labeltop {
  ::v-deep.el-form-item__label {
    float: none !important;
    display: inline-block !important;
    width: auto !important;
  }
}

.iview-video-style {
  width: 300px;
  height: 180px;
  border-radius: 10px;
  background-color: #707070;
  margin: 0 120px 20px;
  position: relative;
  overflow: hidden;
}

.iview-video-style .iconv {
  color: #fff;
  line-height: 180px;
  width: 50px;
  height: 50px;
  display: inherit;
  font-size: 26px;
  position: absolute;
  top: -74px;
  left: 50%;
  margin-left: -25px;
}

.iview-video-style .mark {
  position: absolute;
  width: 100%;
  height: 30px;
  top: 0;
  background-color: rgba(0, 0, 0, 0.5);
  text-align: center;
}
</style>