zhanghua
2022-11-17 66a8754e17eb6ecbc3fd251be683dd15408e3869
src/views/operate/writManager/writ/index.vue
@@ -42,17 +42,35 @@
          style="width: 100%"
        >
          <el-table-column type="selection" min-width="5"> </el-table-column>
          <el-table-column prop="name" label="单兵名称" min-width="10">
          <el-table-column prop="writCode" label="文书编号" min-width="10">
          </el-table-column>
          <el-table-column prop="code" label="单兵编号" min-width="10">
          <el-table-column prop="writTypeName" label="文书种类" min-width="10">
          </el-table-column>
          <el-table-column prop="user" label="使用人员" min-width="10">
          <el-table-column prop="categoryName" label="违法类型" min-width="20">
          </el-table-column>
          <el-table-column prop="phone" label="联系方式" min-width="10">
          <el-table-column prop="eventCode" label="事件编号" min-width="10">
          </el-table-column>
          <el-table-column prop="pdepartName" label="所属部门" min-width="10">
          <el-table-column prop="sendTime" label="文书发放时间" min-width="10">
          </el-table-column>
          <el-table-column prop="departName" label="所属大队" min-width="10">
          <el-table-column prop="limitTime" label="文书限定时间" min-width="10">
          </el-table-column>
          <el-table-column
            prop="sendContent"
            label="文书发放内容"
            min-width="10"
          >
          </el-table-column>
          <el-table-column
            prop="rectifyTime"
            label="实际整改时间"
            min-width="10"
          >
          </el-table-column>
          <el-table-column
            prop="rectifySituation"
            label="整改情况"
            min-width="10"
          >
          </el-table-column>
          <el-table-column
@@ -66,9 +84,14 @@
          <el-table-column prop="operation" label="操作" min-width="20">
            <template slot-scope="scope">
              <div class="operation">
                <span @click="handleEdit(scope.row)">编辑</span>
                <span v-if="!scope.row.value" @click="handleEdit(scope.row)"
                  >下发文书</span
                >
                <span v-if="scope.row.value" @click="handleView(scope.row)"
                  >查看</span
                >
                <span class="line">|</span>
                <span @click="handleDelete(scope.row)">删除</span>
                <span @click="handleDelete(scope.row)">删除文书</span>
              </div>
            </template>
          </el-table-column>
@@ -94,15 +117,19 @@
      </div>
    </main>
    <footer>
      <!-- 添加音柱 -->
      <!-- 下发文书 -->
      <el-dialog
        title="添加音柱"
        title="下发文书"
        :visible.sync="dialogCreate"
        v-if="dialogCreate"
        width="60%"
        :before-close="handleClose"
      >
        <MyForm :info="handheldTerminal" @closeDialog="handleCallBack"></MyForm>
        <component
          :is="componentName"
          :writ="writ"
          @closeDialog="handleCallBack"
        ></component>
      </el-dialog>
    </footer>
  </div>
@@ -111,13 +138,13 @@
import { createNamespacedHelpers } from "vuex";
const { mapActions } = createNamespacedHelpers("writ");
import InquestRecord from "../components/inquest_record/view.vue";
import Notification from "../components/instruct_notification/view.vue";
import InquestRecordEdit from "../components/inquest_record/edit.vue";
import NotificationEdit from "../components/instruct_notification/edit.vue";
export default {
  components: {
    InquestRecord,
    Notification,
    InquestRecordEdit,
    NotificationEdit,
  },
  data() {
    return {
@@ -142,33 +169,39 @@
      pageSize: 10,
      currentPage: 1,
      renderFlag: false,
      handheldTerminal: {},
      writ: {},
      componentName: "",
    };
  },
  created() {
    this.setTableData();
  },
  methods: {
    ...mapActions(["getHandheldTerminalList", "deleteHandheldTerminal"]),
    handleAdd() {
      this.handheldTerminal = {
        id: 0,
        name: "",
        code: "",
        user: "",
        phone: "",
        departId: 0,
        departName: "",
      };
    ...mapActions(["getWritList", "updateWrit", "deleteWrit"]),
    handleEdit(row) {
      this.writ = row;
      this.setComponent(row);
      this.dialogCreate = true;
    },
    handleEdit(row) {
      this.handheldTerminal = row;
    handleView(row) {
      this.writ = row;
      this.setComponent(row);
      this.dialogCreate = true;
    },
    setComponent(row, isEdit) {
      switch (row.templateCode) {
        case "inquest_record":
          this.componentName = InquestRecordEdit;
          break;
        case "instruct_to_correct_notification":
          this.componentName = NotificationEdit;
          break;
      }
    },
    handleDelete(row) {
      this.$confirm("确认删除?").then((_) => {
        this.deleteHandheldTerminal(row.id).then((res) => {
        this.deleteWrit(row.id).then((res) => {
          this.$message({
            type: "success",
            message: "删除成功!",
@@ -184,7 +217,7 @@
      this.setTableData();
    },
    formatSate(row, column) {
      return row.state == 1 ? "在线" : "离线";
      return row.value ? "已下发" : "未下发";
    },
    // 设置表格斑马纹
@@ -206,7 +239,7 @@
    // 设置tableData
    setTableData() {
      const { currentPage, pageSize, context } = this;
      this.getHandheldTerminalList({
      this.getWritList({
        currentPage,
        pageSize,
        state: context,
@@ -379,5 +412,15 @@
      }
    }
  }
  // 设置dialog样式
  ::v-deep .el-dialog__body {
    background-color: #fff;
    color: #000;
  }
  ::v-deep .el-dialog__header {
    background-color: #06122c !important;
    color: #fff;
  }
}
</style>