luobisheng
2022-11-29 15de314310f14ebd37b820c99a7da81bbbd1cdfd
src/views/operate/images/updateUser/index.vue
@@ -2,35 +2,59 @@
  <div class="updateUser">
    <main>
      <div class="mainContent">
        <el-form :disabled="isDisabled" ref="user" style="width: 100%;">
          <el-form-item prop="baseId" label="所属事件编号">
            <el-input v-model="imagedata.baseId"></el-input>
        <el-form
          label-position="right"
          label-width="150px"
          :model="imagedata"
          :rules="rules"
          :disabled="isDisabled"
          ref="user"
          style="width: 100%"
        >
          <el-form-item prop="belongToId" label="所属事件编号">
            <el-input v-model="imagedata.code"></el-input>
          </el-form-item>
          <el-form-item prop="eventSource" label="大类名称">
            <el-input v-model="imagedata.eventSource"></el-input>
          <el-form-item prop="eventSource" label="事件来源">
            <el-input
              v-model="getEventSource(imagedata.eventSource).label"
            ></el-input>
          </el-form-item>
          <el-form-item prop="regionName" label="小类名称">
          <el-form-item prop="category" label="问题类别">
            <el-input
              v-model="getCategory(imagedata.category).label"
            ></el-input>
          </el-form-item>
          <el-form-item prop="type" label="类型">
            <el-select v-model="imagedata.type">
              <el-option
                v-for="item in getResourceType()"
                :key="item.value"
                :label="item.label"
                :value="item.value"
              />
            </el-select>
          </el-form-item>
          <el-form-item prop="regionName" label="社区名称">
            <el-input v-model="imagedata.regionName"></el-input>
          </el-form-item>
          <el-form-item prop="id" label="图片Id">
            <el-input v-model="imagedata.id"></el-input>
          </el-form-item>
          <el-form-item prop="createTime" label="上传时间">
            <el-input v-model="imagedata.createTime"></el-input>
          </el-form-item>
          <el-form-item prop="eventSource" label="图片:" min-width="8">
<!--            <img style="width: 180px;height: 120px;" :src=imagedata.url>-->
            <el-upload
                action=""
                :show-file-list="false"
                :on-success="handleImageSuccess"
                :before-upload="beforeImageUpload">
              <img v-if="imagedata.url" :src="imagedata.url" class="avatar">
              <i v-else class="el-icon-plus avatar-uploader-icon"></i>
            </el-upload>
          <el-form-item prop="url" label="图片:" min-width="8">
            <my-upload
              :picture-list="imageList"
              :is-show-upload="dialogType !== 'view'"
              @setPictureUrl="setPictureUrl"
              @delPictureUrl="delPictureUrl"
            ></my-upload>
          </el-form-item>
          <div v-if="!isDisabled" class="optionBtn">
            <el-button type="primary" class="btn submit" @click.native.prevent="onSubmit">提交</el-button>
            <el-button
              type="primary"
              class="btn submit"
              @click.native.prevent="onSubmit"
              >提交</el-button
            >
          </div>
        </el-form>
      </div>
@@ -38,70 +62,136 @@
  </div>
</template>
<script>
import { deepClone } from "@/utils/helper";
import {
  deepClone,
  RESOURCE_TYPE,
  CATEGOTY,
  EVENT_SOURCE,
} from "@/utils/helper";
import imageManagement from "@/api/operate/imageManagement";
import { FILE_ORIGINAL_URL } from "@/utils";
import MyUpload from "@/components/myUpload";
export default {
  components: { MyUpload },
  data() {
    const validateImageUrl = (rule, value, callback) => {
      if (this.imagedata.url) {
        callback();
      } else {
        callback(new Error("请上传图片"));
      }
    };
    return {
      imagedata: {
        code: '',
        eventSource: '',
        regionName: '',
        smallType: '',
        id: '',
        createTime: '',
        url: ''
        belongToId: "",
        eventSource: 1,
        regionName: "",
        category: 1,
        id: "",
        url: "",
        type: "",
      },
      isDisabled: false
    }
      rules: {
        belongToId: [
          { required: true, trigger: "blur", message: "请输入所属事件编号" },
        ],
        eventSource: [
          { required: true, trigger: "blur", message: "请输入事件来源" },
        ],
        regionName: [
          { required: true, trigger: "blur", message: "请输入社区名称" },
        ],
        id: [{ required: true, trigger: "blur", message: "请输入图片Id" }],
        category: [
          { required: true, trigger: "blue", message: "请输入问题类型" },
        ],
        url: [{ required: true, validator: validateImageUrl }],
        type: [
          {
            required: true,
            trigger: ["blur", "change"],
            message: "请选择类型",
          },
        ],
      },
      isDisabled: false,
      imageList: [],
    };
  },
  created() {
    this.imagedata = deepClone(this.originalData);
    this.isDisabled = this.dialogType === 'view';
    if (this.originalData) {
      this.imagedata = deepClone(this.originalData);
    }
    if (this.dialogType !== "create") {
      this.imageList = this.imagedata.url.split(",");
    }
    this.isDisabled = this.dialogType === "view";
  },
  methods: {
    onSubmit() {
      this.$refs.user.validate(valid => {
      this.$refs.user.validate((valid) => {
        if (valid) {
          if (this.dialogType === 'create') {
            imageManagement.addImageResource(this.imagedata)
                .then(() => {
                  this.$message.success('操作成功');
                  this.$emit('closeDialog');
                })
                .catch(err => this.$message.error(`${err}`))
          const params = Object.assign({}, this.imagedata);
          delete params.regionName;
          delete params.category;
          delete params.eventSource;
          delete params.id;
          params.belongToId = +params.belongToId;
          if (this.dialogType === "create") {
            imageManagement
              .addImageResource(params)
              .then(() => {
                this.$message.success("操作成功");
                this.$emit("closeDialog");
              })
              .catch((err) => this.$message.error(`${err}`));
          } else {
            imageManagement.updateImageResource(this.imagedata)
                .then(() => {
                  this.$message.success('操作成功');
                  this.$emit('closeDialog');
                })
                .catch(err => this.$message.error(`${err}`))
            imageManagement
              .updateImageResource(params)
              .then(() => {
                this.$message.success("操作成功");
                this.$emit("closeDialog");
              })
              .catch((err) => this.$message.error(`${err}`));
          }
        } else {
          this.$message.warning('请检查必填项');
          this.$message.warning("请检查必填项");
        }
      })
      });
    },
    handleImageSuccess() {},
    beforeImageUpload(file) {
      imageManagement.importImage(file)
          .then(res => {
          })
          .catch(err => this.$message.error(`${err}`))
    }
    setPictureUrl({ url }) {
      this.imageList.push(`${FILE_ORIGINAL_URL}${url}`);
      this.imagedata.url = this.imageList.join(",");
    },
    delPictureUrl({ url }) {
      this.imageList = this.imageList.filter((item) => item !== url);
      this.imagedata.url = this.imageList.join(",");
    },
    getCategory(value) {
      return CATEGOTY.find((item) => item.value === value);
    },
    getEventSource(value) {
      return EVENT_SOURCE.find((item) => item.value === value);
    },
    getResourceType(value) {
      return value
        ? RESOURCE_TYPE.find((item) => item.value === value)
        : RESOURCE_TYPE;
    },
  },
  props: {
    originalData: {
      type: Object,
      default: () => null
      default: () => null,
    },
    dialogType: {
      type: String,
      default: () => 'create'
    }
  }
      default: () => "create",
    },
  },
};
</script>
<style lang="scss" scoped>
@@ -115,13 +205,6 @@
    padding: 0 55px;
    background-color: #09152f;
    padding-bottom: 50px;
    // .mainTitle {
    //     color: #4b9bb7;
    //     font-weight: 600;
    //     line-height: 100px;
    //     font-size: 14px;
    // }
    .mainContent {
      display: flex;
@@ -257,7 +340,8 @@
  color: red;
}
.el-input {
.el-input,
.el-select {
  width: 280px !important;
}
</style>