UserPrintSetting.vue 2.67 KB
<template>
  <a-modal
    :title="title"
    :width="modalWidth"
    :visible="visible"
    :confirmLoading="confirmLoading"
    @ok="handleOk"
    @cancel="handleCancel"
    cancelText="关闭"
  >
    <a-spin :spinning="confirmLoading">
      <a-form-model ref="form" :model="model" :rules="validatorRules">
        <a-row>
          <a-col :span="24">
            <a-form-model-item label="打印机连接" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="printerConnect">
              <j-dict-select-tag type="list" v-model="model.printerConnect" dictCode="printer_connect"
                                 placeholder="请选择打印机连接"/>
            </a-form-model-item>
          </a-col>
        </a-row>
      </a-form-model>
    </a-spin>
  </a-modal>
</template>

<script>

import { httpAction, putAction } from '@/api/manage'

export default {
  name: "UserPrintSetting",
  data() {
    return {
      title: "设置打印机连接",
      modalWidth: 800,
      visible: false,
      confirmLoading: false,
      model:{
      },
      validatorRules: {
          printerConnect: [
            {required: true, message: '请选择打印机连接!'},
          ],
      },
      confirmDirty: false,
      labelCol: {
        xs: {span: 24},
        sm: {span: 5},
      },
      wrapperCol: {
        xs: {span: 24},
        sm: {span: 16},
      },

      form: this.$form.createForm(this),
      url: "sys/user/updatePrinterSetting",
      username: "",
    }
  },
  created () {
    //备份model原始值
    this.modelDefault = JSON.parse(JSON.stringify(this.model));
  },
  methods: {
    show(uname) {
      if (!uname) {
        this.$message.warning("当前系统无登录用户!");
        return
      } else {
        this.username = uname
        this.form.resetFields();
        this.visible = true;
      }
    },
    handleCancel() {
      this.close()
    },
    close() {
      this.$emit('close');
      this.visible = false;
      this.disableSubmit = false;
      this.selectedRole = [];
    },
    handleOk() {
      const that = this;
      this.$refs.form.validate(valid => {
        if (valid) {
          that.confirmLoading = true;
          let params = Object.assign({username: this.username}, this.model)
          putAction(this.url, params).then((res) => {
            if (res.success) {
              console.log(res)
              that.$message.success(res.message);
              that.close();
            } else {
              that.$message.warning(res.message);
            }
          }).finally(() => {
            that.confirmLoading = false;
          })
        }else{
          return false
        }
      })
    },

  }
}
</script>

<style scoped>

</style>