index.vue 14.3 KB
<template>
  <div class="app-container">
    <el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch" label-width="68px">

      <el-form-item label="经营单位" prop="garOrderCompanyName">
        <el-input v-model="queryParams.garOrderCompanyName" placeholder="请输入经营单位" clearable size="small"
          @keyup.enter.native="handleQuery" />
      </el-form-item>
      <el-form-item label="处理状态" prop="garOrderHandlerStatus">
        <el-select v-model="queryParams.garOrderHandlerStatus" placeholder="请选择处理状态" clearable size="small">
          <el-option label="未处理" value="0" />
          <el-option label="处理中" value="1" />
          <el-option label="已处理" value="3" />
        </el-select>
      </el-form-item>
      <el-form-item label="是否取消" prop="garCancelFlag">
        <el-select v-model="queryParams.garCancelFlag" placeholder="请选择处理状态" clearable size="small">
          <el-option label="未取消" value="0" />
          <el-option label="已取消" value="1" />
        </el-select>
      </el-form-item>
      <el-form-item>
        <el-button type="cyan" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
        <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
      </el-form-item>
    </el-form>

    <el-row :gutter="10" class="mb8">
      <el-col :span="1.5">
        <el-button type="warning" icon="el-icon-download" size="mini" @click="handleExport"
          v-hasPermi="['garbage:order:export']">导出</el-button>
      </el-col>
      <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
    </el-row>

    <el-table v-loading="loading" :data="orderList" @selection-change="handleSelectionChange">
      <el-table-column type="selection" width="55" align="center" />
      <el-table-column label="订单号" width="180" align="center" prop="garOrderId" />
      <el-table-column label="用户姓名" align="center" prop="garOrderContactName" />
      <el-table-column label="订单地址" width="200px" align="center" prop="garOrderAddress" />
      <el-table-column label="订单详细地址" width="200px" align="center" prop="garOrderAddressDetails" />
      <el-table-column label="垃圾类型" align="center" prop="garOrderTrashType" />
      <el-table-column label="订单人电话" width="200px" align="center" prop="garOrderContactTel" />
      <el-table-column label="经营单位" width="200px" align="center" prop="garOrderCompanyName" />
      <el-table-column label="公司负责人电话" width="200px" align="center" prop="garOrderCompanyTel" />
      <el-table-column label="处理状态" align="center" prop="garOrderHandlerStatus">
        <template slot-scope="scope">
          {{ computedHandleStatusString(scope.row.garOrderHandlerStatus).toString() }}
        </template>
      </el-table-column>
      <el-table-column label="约定时间" width="180" align="center" prop="garOrderAgreementTime" />
      <el-table-column label="备注" align="center" prop="garRemark" />
      <el-table-column label="是否取消" align="center" prop="garCancelFlag">
        <template slot-scope="scope">
          {{ computedCancelFlagString(scope.row.garCancelFlag).toString() }}
        </template>
      </el-table-column>
      <el-table-column label="车子数量" align="center" prop="garOrderCarNumber" />
      <el-table-column label="车子类型" width="200px" align="center" prop="garOrderCarType" />
      <el-table-column fixed="right" label="操作" width="200px" align="center" class-name="small-padding fixed-width">
        <template slot-scope="scope">
          <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)"
            v-hasPermi="['garbage:order:edit']">详情</el-button>
        </template>
      </el-table-column>
    </el-table>

    <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize"
      @pagination="getList" />

    <!-- 添加或修改清运派单对话框 -->
    <el-dialog label-position="left" :visible.sync="open" width="800px" append-to-body>
      <div class="handle-box-title" style="display: flex; align-items: center;margin: 10px 0;">
        <div class="handle-box-title-ui" style="height: 30px; width: 10px; background-color: #409EFF;margin-right: 15px;">
        </div>
        <div class="handle-box-title-text" style="color: #409EFF; font-size: 25px;">派单基本信息</div>
      </div>
      <el-form ref="form" :model="form" :inline="true">
        <el-form-item label="处理状态">
          {{ computedHandleStatusString(form.garOrderHandlerStatus).toString() }}
        </el-form-item>
        <el-form-item label="是否取消" prop="garCancelFlag">
          {{ computedCancelFlagString(form.garCancelFlag).toString() }}
        </el-form-item>
        <el-form-item v-if="form.garCancelFlag === 1" label="原因" prop="garReason">
          <div class="text" style="color: red;">{{ form.garReason }}</div>
        </el-form-item>
        <el-form-item label="订单姓名" prop="garOrderContactName">
          <el-input :disabled="true" v-model="form.garOrderContactName" placeholder="请输入订单姓名" />
        </el-form-item>
        <el-form-item label="垃圾类型" prop="garOrderTrashType">
          <el-input :disabled="true" v-model="form.garOrderTrashType" placeholder="请输入垃圾类型" />
        </el-form-item>
        <el-form-item label="订单人电话" prop="garOrderContactTel">
          <el-input :disabled="true" v-model="form.garOrderContactTel" placeholder="请输入订单人电话" />
        </el-form-item>
        <el-form-item label="经营单位" prop="garOrderCompanyName">
          <el-input :disabled="true" v-model="form.garOrderCompanyName" placeholder="请输入公司名称" />
        </el-form-item>
        <el-form-item label="公司负责人电话" prop="garOrderCompanyTel">
          <el-input :disabled="true" v-model="form.garOrderCompanyTel" placeholder="请输入公司负责人电话" />
        </el-form-item>
        <el-form-item label="约定时间" prop="garOrderAgreementTime">
          <el-input :disabled="true" v-model="form.garOrderAgreementTime" placeholder="请输入约定时间" />
        </el-form-item>
        <el-form-item label="订单创建时间" prop="garCreateTime">
          <el-date-picker :disabled="true" clearable size="small" style="width: 200px" v-model="form.garCreateTime"
            type="date" value-format="yyyy-MM-dd" placeholder="选择订单创建时间">
          </el-date-picker>
        </el-form-item>
        <el-form-item label="车子类型" prop="garOrderCarType">
          <el-input :disabled="true" v-model="form.garOrderCarType" placeholder="请输入车子类型" />
        </el-form-item>
        <el-form-item label="车子数量" prop="garOrderCarNumber">
          <el-input :disabled="true" v-model="form.garOrderCarNumber" placeholder="请输入车子数量" />
        </el-form-item>
        <el-form-item label="备注" prop="garRemark">
          <el-input :disabled="true" v-model="form.garRemark" type="textarea" placeholder="请输入内容" />
        </el-form-item>
        <el-form-item v-if="form.currentImages" label="现场图片" prop="currentImages">
          <el-image style="width: 100px; height: 100px" :src="form.currentImages[0]"
            :preview-src-list="form.currentImages">
          </el-image>
        </el-form-item>
      </el-form>
      <div class="handle-box" v-if="form.garOrderHandlerStatus == 3">
        <div class="handle-box-title" style="display: flex; align-items: center;margin: 10px 0;">
          <div class="handle-box-title-ui"
            style="height: 30px; width: 10px; background-color: #409EFF;margin-right: 15px;"></div>
          <div class="handle-box-title-text" style="color: #409EFF; font-size: 25px;">派单处理信息</div>
        </div>
        <el-form :inline="true" :model="form">
          <el-form-item label="派单负责人" prop="garOrderHandler">
            <el-input v-model="form.garOrderHandleName" placeholder="派单负责人" />
          </el-form-item>
          <el-form-item label="派单负责人电话" prop="garOrderHandlerTel">
            <el-input v-model="form.garOrderHandleTel" placeholder="派单负责人电话" />
          </el-form-item>
          <el-form-item v-if="form.putOnImages" label="现场图片" prop="putOnImages">
            <el-image style="width: 100px; height: 100px" :src="form.putOnImages[0]" :preview-src-list="form.putOnImages">
            </el-image>
          </el-form-item>
          <el-form-item v-if="form.putDownImages" label="现场图片" prop="putDownImages">
            <el-image style="width: 100px; height: 100px" :src="form.putDownImages[0]"
              :preview-src-list="form.putDownImages">
            </el-image>
          </el-form-item>
        </el-form>
      </div>

      <div slot="footer" class="dialog-footer">
        <el-button type="primary" @click="submitForm">确 定</el-button>
      </div>
    </el-dialog>
  </div>
</template>

<script>
import { delOrder, exportOrder, getOrder, listOrder } from "@/api/gar/order";

export default {
  name: "Order",
  data() {
    return {
      // 遮罩层
      loading: true,
      // 选中数组
      ids: [],
      // 非单个禁用
      single: true,
      // 非多个禁用
      multiple: true,
      // 显示搜索条件
      showSearch: true,
      // 总条数
      total: 0,
      // 清运派单表格数据
      orderList: [],
      // 弹出层标题
      title: "",
      // 是否显示弹出层
      open: false,
      // 是否显示弹出层
      openEvaluate: false,
      // 查询参数
      queryParams: {
        pageNum: 1,
        pageSize: 10,
        garOrderUserId: null,
        garOrderHandlerId: null,
        garOrderAddress: null,
        garOrderAddressDetails: null,
        garOrderContactName: null,
        garOrderTrashType: null,
        garOrderContactTel: null,
        garOrderCompanyId: null,
        garOrderCompanyName: null,
        garOrderCompanyTel: null,
        garOrderHandlerStatus: null,
        garOrderAgreementTime: null,
        garCreateTime: null,
        garUpdateTime: null,
        garCreateBy: null,
        garUpdateBy: null,
        garRemark: null,
        garReason: null,
        garCancelFlag: null,
        garEvaluateFlag: null,
        garOrderCarNumber: null,
        garOrderCarType: null,
        garHandlerEvaluateFlag: null
      },
      // 表单参数
      form: {},
      // 表单校验
      rules: {
      }
    };
  },
  created() {
    this.getList();
  },
  methods: {
    computedCancelFlagString(val) {
      if (val === 0) {
        return '未取消'
      }
      if (val === 1) {
        return '已取消'
      }
      return ""
    },
    computedHandleStatusString(val) {
      console.log(val);
      if (val === 0) {
        return '未处理'
      }
      if (val === 1) {
        return '处理中'
      }
      if (val === 3) {
        return '已处理'
      }
      return ""
    },
    /** 查询清运派单列表 */
    getList() {
      this.loading = true;
      listOrder(this.queryParams).then(response => {
        this.orderList = response.data.list;
        this.total = response.data.total;
        this.loading = false;
      });
    },
    // 取消按钮
    cancel() {
      this.open = false;
      this.reset();
    },
    // 表单重置
    reset() {
      this.form = {
        garOrderId: null,
        garOrderUserId: null,
        garOrderHandlerId: null,
        garOrderAddress: null,
        garOrderAddressDetails: null,
        garOrderContactName: null,
        garOrderTrashType: null,
        garOrderContactTel: null,
        garOrderCompanyId: null,
        garOrderCompanyName: null,
        garOrderCompanyTel: null,
        garOrderHandlerStatus: 0,
        garOrderAgreementTime: null,
        currentImages: [],
        putDownImages: [],
        putOnImages: [],
        garCreateTime: null,
        garUpdateTime: null,
        garCreateBy: null,
        garUpdateBy: null,
        garRemark: null,
        garReason: null,
        garCancelFlag: null,
        garEvaluateFlag: null,
        garOrderCarNumber: null,
        garOrderCarType: null,
        garHandlerEvaluateFlag: null
      };
      this.resetForm("form");
    },
    /** 搜索按钮操作 */
    handleQuery() {
      this.queryParams.pageNum = 1;
      this.getList();
    },
    /** 重置按钮操作 */
    resetQuery() {
      this.resetForm("queryForm");
      this.handleQuery();
    },
    // 多选框选中数据
    handleSelectionChange(selection) {
      this.ids = selection.map(item => item.garOrderId)
      this.single = selection.length !== 1
      this.multiple = !selection.length
    },
    /** 修改按钮操作 */
    handleUpdate(row) {
      this.reset();
      const garOrderId = row.garOrderId || this.ids
      getOrder(garOrderId).then(response => {
        this.form = response.data;
        this.form.currentImages = this.form.currentImages.map(map => process.env.VUE_APP_BASE_API + map)
        this.form.putDownImages = this.form.putDownImages.map(map => process.env.VUE_APP_BASE_API + map)
        this.form.putOnImages = this.form.putOnImages.map(map => process.env.VUE_APP_BASE_API + map)
        this.open = true;
        this.title = "清运派单详情";
      });
    },
    /** 提交按钮 */
    submitForm() {
      this.open = false;
      this.getList();
    },
    /** 删除按钮操作 */
    handleDelete(row) {
      const garOrderIds = row.garOrderId || this.ids;
      this.$confirm('是否确认删除清运派单编号为"' + garOrderIds + '"的数据项?', "警告", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning"
      }).then(function () {
        return delOrder(garOrderIds);
      }).then(() => {
        this.getList();
        this.msgSuccess("删除成功");
      })
    },
    /** 导出按钮操作 */
    handleExport() {
      const queryParams = this.queryParams;
      this.$confirm('是否确认导出所有清运派单数据项?', "警告", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning"
      }).then(function () {
        return exportOrder(queryParams);
      }).then(response => {
        this.download(response.msg);
      })
    }
  }
};
</script>