list.vue 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. <template>
  2. <div class="body-layer">
  3. <div class="body-head">
  4. <h3 style="visibility: hidden">项目列表</h3>
  5. <div class="table-ctrl-right">
  6. <slot name="tableCtrl" />
  7. </div>
  8. </div>
  9. <el-table
  10. :data="pagging.state.table.rows"
  11. id="multipleTable"
  12. style="width: 100%"
  13. class="table"
  14. size="large"
  15. @selection-change="pagging.changeSelectRows"
  16. >
  17. <el-table-column
  18. type="selection"
  19. width="50"
  20. :selectable="() => !!operateIsPermissionByPath(checkPerm)"
  21. />
  22. <el-table-column label="序号" width="70" v-slot:default="{ $index }">
  23. <div style="text-align: center">
  24. {{ pagging.state.pag.size * (pagging.state.pag.currentPage - 1) + $index + 1 }}
  25. </div>
  26. </el-table-column>
  27. <el-table-column label="项目编号" prop="projectSn"></el-table-column>
  28. <el-table-column label="起火对象" prop="projectName" v-slot:default="{ row }">
  29. <el-tooltip
  30. class="item"
  31. effect="dark"
  32. :content="row.projectName"
  33. placement="bottom-start"
  34. v-if="row.projectName && row.projectName.length > 15"
  35. >
  36. <p class="tip oper-user">{{ row.projectName }}</p>
  37. </el-tooltip>
  38. <p class="tip" v-else>{{ row.projectName }}</p>
  39. </el-table-column>
  40. <el-table-column label="起火地址" prop="projectAddress" v-slot:default="{ row }">
  41. <el-tooltip
  42. class="item"
  43. effect="dark"
  44. :content="row.projectAddress"
  45. placement="bottom-start"
  46. v-if="row.projectAddress && row.projectAddress.length > 15"
  47. >
  48. <p class="tip oper-user">{{ row.projectAddress }}</p>
  49. </el-tooltip>
  50. <p class="tip" v-else>{{ row.projectAddress }}</p>
  51. </el-table-column>
  52. <el-table-column label="起火场所" prop="projectSite" v-slot:default="{ row }">
  53. <el-tooltip
  54. class="item"
  55. effect="dark"
  56. :content="row.projectSite"
  57. placement="bottom-start"
  58. v-if="row.projectSite && row.projectSite.length > 10"
  59. >
  60. <p class="tip oper-user">{{ row.projectSite }}</p>
  61. </el-tooltip>
  62. <p class="tip" v-else>{{ row.projectSite }}</p>
  63. </el-table-column>
  64. <el-table-column label="承办单位" prop="organizerDeptName"></el-table-column>
  65. <el-table-column label="事故日期" prop="accidentDate"></el-table-column>
  66. <el-table-column label="火灾原因" prop="fireReason" v-slot:default="{ row }">
  67. <el-tooltip
  68. class="item"
  69. effect="dark"
  70. :content="row.fireReason"
  71. placement="bottom-start"
  72. v-if="row.fireReason && row.fireReason.length > 15"
  73. >
  74. <p class="tip oper-user">{{ row.fireReason }}</p>
  75. </el-tooltip>
  76. <p class="tip" v-else>{{ row.fireReason }}</p>
  77. </el-table-column>
  78. <el-table-column label="项目状态" v-slot:default="{ row }">
  79. {{ fireStatusDesc[row.status as FireStatus] }}
  80. </el-table-column>
  81. <el-table-column label="操作" v-slot:default="{ row }" :width="180">
  82. <slot name="rowCtrl" :row="row" />
  83. </el-table-column>
  84. </el-table>
  85. <com-pagination
  86. @size-change="pagging.changPageSize"
  87. @current-change="pagging.changPageCurrent"
  88. :current-page="pagging.state.pag.currentPage"
  89. :page-size="pagging.state.pag.size"
  90. :total="pagging.state.pag.total"
  91. />
  92. </div>
  93. </template>
  94. <script lang="ts" setup>
  95. import comPagination from "@/components/pagination/index.vue";
  96. import { fireStatusDesc } from "@/app/fire/constant/fire";
  97. import { FireStatus } from "@/app/fire/store/fire";
  98. import { operateIsPermissionByPath } from "@/directive/permission";
  99. import { FirePagging } from "./pagging";
  100. defineProps<{ pagging: FirePagging; checkPerm: string }>();
  101. </script>