index.vue 4.2 KB
<template>
  <div class="app-container">
    <el-form ref="form" :model="form" label-width="180px" style="width:50%">
      <el-form-item label="系统名称">
        <el-input v-model="form.name"></el-input>
      </el-form-item>


   <el-form-item label="首页广告图">
      <el-upload :headers="{Authorization:token}" 
      class="avatar-uploader"
      :action="BASE_URL + '/api/upload/single'"
      :show-file-list="false"
      :on-success="handleAvatarSuccess"
 >
      <img v-if="imageUrl" :src="imageUrl" class="avatar">
      <i v-else class="el-icon-plus avatar-uploader-icon"></i>
    </el-upload>

      </el-form-item>


      
      <!-- <el-form-item label="活动区域">
        <el-select v-model="form.region" placeholder="请选择活动区域">
          <el-option label="区域一" value="shanghai"></el-option>
          <el-option label="区域二" value="beijing"></el-option>
        </el-select>
      </el-form-item>
      <el-form-item label="活动时间">
        <el-col :span="11">
          <el-date-picker type="date" placeholder="选择日期" v-model="form.date1" style="width: 100%;"></el-date-picker>
        </el-col>
        <el-col class="line" :span="2">-</el-col>
        <el-col :span="11">
          <el-time-picker placeholder="选择时间" v-model="form.date2" style="width: 100%;"></el-time-picker>
        </el-col>
      </el-form-item>
      <el-form-item label="即时配送">
        <el-switch v-model="form.delivery"></el-switch>
      </el-form-item>
      <el-form-item label="活动性质">
        <el-checkbox-group v-model="form.type">
          <el-checkbox label="美食/餐厅线上活动" name="type"></el-checkbox>
          <el-checkbox label="地推活动" name="type"></el-checkbox>
          <el-checkbox label="线下主题活动" name="type"></el-checkbox>
          <el-checkbox label="单纯品牌曝光" name="type"></el-checkbox>
        </el-checkbox-group>
      </el-form-item>
      <el-form-item label="特殊资源">
        <el-radio-group v-model="form.resource">
          <el-radio label="线上品牌商赞助"></el-radio>
          <el-radio label="线下场地免费"></el-radio>
        </el-radio-group>
      </el-form-item>
      <el-form-item label="活动形式">
        <el-input type="textarea" v-model="form.desc"></el-input>
      </el-form-item> -->
      <el-form-item>
        <el-button type="primary" @click="submitForm">保存</el-button>
    
      </el-form-item>
    </el-form>
  </div>
</template>

<script>

  
import {
    getToken
  } from '@/utils/auth'



  import {
    GetInfo,
    Update
  } from '@/api/setting'
   export default {
      data() {
 
        return {
          token:getToken(),
          imageUrl:'',
          form: {
            pass: '',
            checkPass: '',
          },
          rules: { 
          }
        };
      },
      created(){
        var _this = this;
        GetInfo(1).then(res=>{
          _this.form = res.data.data;  
          if(_this.form.home_images){
            _this.imageUrl = _this.BASE_URL+_this.form.home_images;
          }
        });
      },

      methods: {
        handleAvatarSuccess(res, file) {
        this.imageUrl = URL.createObjectURL(file.raw);
        this.form.home_images = res.data.data.src || '';
      },

        submitForm(formName) {
          Update(this.form).then(res=>{
                if (res.data.code==200) {
                  this.$notify({
                    title: '提示',
                    message: '保存成功',
                    type: 'success',
                    duration: 1000
                  })
                
                }
              })
        },
        resetForm(formName) {
          this.$refs[formName].resetFields();
        }
      }
    }
</script>

<style>
</style>
<style scoped>
  .avatar-uploader .el-upload {
    border: 1px dashed #d9d9d9;
    border-radius: 6px;
    cursor: pointer;
    position: relative;
    overflow: hidden;
  }
  .avatar-uploader .el-upload:hover {
    border-color: #409EFF;
  }
  .avatar-uploader-icon {
    font-size: 28px;
    color: #8c939d;
    width: 178px;
    height: 178px;
    line-height: 178px;
    text-align: center;
  }
  .avatar {
    width: 178px;
    height: 178px;
    display: block;
  }
</style>