DevicePerson.vue 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358
  1. <template>
  2. <el-row :gutter="20">
  3. <!-- 左侧部门树 -->
  4. <el-col :span="4" :xs="24">
  5. <ContentWrap class="h-1/1" v-if="treeShow">
  6. <DeptTree @node-click="handleDeptNodeClick" />
  7. </ContentWrap>
  8. </el-col>
  9. <el-col :span="contentSpan" :xs="24">
  10. <ContentWrap>
  11. <!-- 搜索工作栏 -->
  12. <el-form
  13. class="-mb-15px"
  14. :model="queryParams"
  15. ref="queryFormRef"
  16. :inline="true"
  17. label-width="68px"
  18. >
  19. <el-form-item :label="t('devicePerson.deviceCode')" prop="deviceCode" style="margin-left: 25px">
  20. <el-input
  21. v-model="queryParams.deviceCode"
  22. :placeholder="t('devicePerson.codeHolder')"
  23. clearable
  24. @keyup.enter="handleQuery"
  25. class="!w-200px"
  26. />
  27. </el-form-item>
  28. <el-form-item :label="t('devicePerson.deviceName')" prop="deviceName">
  29. <el-input
  30. v-model="queryParams.deviceName"
  31. :placeholder="t('devicePerson.nameHolder')"
  32. clearable
  33. @keyup.enter="handleQuery"
  34. class="!w-200px"
  35. />
  36. </el-form-item>
  37. <el-form-item :label="t('devicePerson.responsiblePerson')" prop="setFlag" label-width="140px">
  38. <el-select
  39. v-model="queryParams.setFlag"
  40. :placeholder="t('devicePerson.choose')"
  41. clearable
  42. class="!w-240px"
  43. >
  44. <el-option
  45. v-for="dict in resultOptions"
  46. :key="dict.value"
  47. :label="dict.label"
  48. :value="dict.value"
  49. />
  50. </el-select>
  51. </el-form-item>
  52. <el-form-item v-show="ifShow" :label="t('devicePerson.status')" label-width="85px" prop="deviceStatus">
  53. <el-select
  54. v-model="queryParams.deviceStatus"
  55. :placeholder="t('devicePerson.status')"
  56. clearable
  57. class="!w-240px"
  58. >
  59. <el-option
  60. v-for="dict in getStrDictOptions(DICT_TYPE.PMS_DEVICE_STATUS)"
  61. :key="dict.value"
  62. :label="dict.label"
  63. :value="dict.value"
  64. />
  65. </el-select>
  66. </el-form-item>
  67. <el-form-item v-show="ifShow" :label="t('devicePerson.assets')" prop="assetProperty">
  68. <el-select
  69. v-model="queryParams.assetProperty"
  70. :placeholder="t('devicePerson.assets')"
  71. clearable
  72. class="!w-240px"
  73. >
  74. <el-option
  75. v-for="dict in getStrDictOptions(DICT_TYPE.PMS_ASSET_PROPERTY)"
  76. :key="dict.value"
  77. :label="dict.label"
  78. :value="dict.value"
  79. />
  80. </el-select>
  81. </el-form-item>
  82. <el-form-item v-show="ifShow" :label="t('devicePerson.brand')" prop="brand">
  83. <el-input
  84. v-model="queryParams.brand"
  85. :placeholder="t('devicePerson.brandHolder')"
  86. clearable
  87. @keyup.enter="handleQuery"
  88. class="!w-200px"
  89. />
  90. </el-form-item>
  91. <el-form-item>
  92. <el-button v-if="!ifShow" @click="moreQuery(true)" type="warning"
  93. ><Icon icon="ep:search" class="mr-5px" />
  94. {{ t('devicePerson.moreSearch') }}</el-button
  95. >
  96. <el-button v-if="ifShow" @click="moreQuery(false)" type="danger"
  97. ><Icon icon="ep:search" class="mr-5px" /> {{ t('devicePerson.closeSearch') }}</el-button
  98. >
  99. <el-button @click="handleQuery"
  100. ><Icon icon="ep:search" class="mr-5px" /> {{ t('devicePerson.search') }}</el-button
  101. >
  102. <el-button @click="resetQuery"
  103. ><Icon icon="ep:refresh" class="mr-5px" /> {{ t('devicePerson.reset') }}</el-button
  104. >
  105. <el-button
  106. type="primary"
  107. plain
  108. @click="openForm('create', undefined, queryParams.deptId)"
  109. v-hasPermi="['rq:iot-device:create']"
  110. >
  111. <Icon icon="ep:plus" class="mr-5px" /> {{ t('devicePerson.setUp') }}
  112. </el-button>
  113. <el-button
  114. type="success"
  115. plain
  116. @click="handleExport"
  117. :loading="exportLoading"
  118. v-hasPermi="['rq:iot-device:export']"
  119. >
  120. <Icon icon="ep:download" class="mr-5px" /> 导出
  121. </el-button>
  122. </el-form-item>
  123. </el-form>
  124. </ContentWrap>
  125. <!-- 列表 -->
  126. <ContentWrap>
  127. <el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
  128. <el-table-column :label="t('monitor.serial')" width="70" align="center">
  129. <template #default="scope">
  130. {{ scope.$index + 1 }}
  131. </template>
  132. </el-table-column>
  133. <el-table-column :label="t('monitor.deviceCode')" align="center" prop="deviceCode" />
  134. <el-table-column :label="t('monitor.deviceName')" align="center" prop="deviceName">
  135. <template #default="scope">
  136. <el-link :underline="false" type="primary" @click="handleDetail(scope.row.id)">
  137. {{ scope.row.deviceName }}
  138. </el-link>
  139. </template>
  140. </el-table-column>
  141. <el-table-column :label="t('devicePerson.dept')" align="center" prop="deptName" />
  142. <el-table-column :label="t('devicePerson.rp')" align="center" prop="responsibleNames" />
  143. <el-table-column :label="t('devicePerson.operation')" align="center" min-width="120px">
  144. <template #default="scope">
  145. <el-button
  146. link
  147. type="primary"
  148. @click="handleView(scope.row.id)"
  149. v-hasPermi="['rq:iot-device:query']"
  150. >
  151. {{ t('devicePerson.adjustmentRecords') }}
  152. </el-button>
  153. </template>
  154. </el-table-column>
  155. </el-table>
  156. <!-- 分页 -->
  157. <Pagination
  158. :total="total"
  159. v-model:page="queryParams.pageNo"
  160. v-model:limit="queryParams.pageSize"
  161. @pagination="getList"
  162. />
  163. </ContentWrap>
  164. </el-col>
  165. </el-row>
  166. <DevicePersonLogDrawer
  167. :model-value="drawerVisible"
  168. @update:model-value="val => drawerVisible = val"
  169. :device-id="currentDeviceId"
  170. ref="showDrawer"
  171. />
  172. </template>
  173. <script setup lang="ts">
  174. import download from '@/utils/download'
  175. import { IotDeviceApi, IotDeviceVO } from '@/api/pms/device'
  176. import { DICT_TYPE, getStrDictOptions } from '@/utils/dict'
  177. import { dateFormatter } from '@/utils/formatTime'
  178. import DeptTree from '@/views/system/user/DeptTree.vue'
  179. import { CACHE_KEY, useCache } from '@/hooks/web/useCache'
  180. import DevicePersonLogDrawer from "@/views/pms/device/personlog/DevicePersonLogDrawer.vue";
  181. /** 设备台账 列表 */
  182. defineOptions({ name: 'IotDevicePerson' })
  183. const message = useMessage() // 消息弹窗
  184. const { t } = useI18n() // 国际化
  185. const { push } = useRouter() // 路由跳转
  186. const loading = ref(true) // 列表的加载中
  187. const ifShow = ref(false)
  188. const isDetail = ref(false) // 是否查看详情
  189. const list = ref<IotDeviceVO[]>([]) // 列表的数据
  190. const total = ref(0) // 列表的总页数
  191. const queryParams = reactive({
  192. pageNo: 1,
  193. pageSize: 10,
  194. deviceCode: undefined,
  195. deviceName: undefined,
  196. brand: undefined,
  197. model: undefined,
  198. deptId: undefined,
  199. deviceStatus: undefined,
  200. assetProperty: undefined,
  201. picUrl: undefined,
  202. remark: undefined,
  203. manufacturerId: undefined,
  204. supplierId: undefined,
  205. manDate: [],
  206. nameplate: undefined,
  207. expires: undefined,
  208. plPrice: undefined,
  209. plDate: [],
  210. plYear: undefined,
  211. plStartDate: [],
  212. plMonthed: undefined,
  213. plAmounted: undefined,
  214. remainAmount: undefined,
  215. infoId: undefined,
  216. infoType: undefined,
  217. infoName: undefined,
  218. infoRemark: undefined,
  219. infoUrl: undefined,
  220. templateJson: undefined,
  221. creator: undefined,
  222. setFlag: ''
  223. })
  224. const queryFormRef = ref() // 搜索的表单
  225. const exportLoading = ref(false) // 导出的加载中
  226. const contentSpan = ref(20)
  227. const treeShow = ref(true)
  228. const shou = (tree) =>{
  229. treeShow.value = !tree
  230. if (tree) {
  231. contentSpan.value = 20
  232. } else {
  233. contentSpan.value = 24
  234. }
  235. }
  236. /** 查询列表 */
  237. const getList = async () => {
  238. loading.value = true
  239. try {
  240. const data = await IotDeviceApi.responsiblePage(queryParams)
  241. list.value = data.list
  242. total.value = data.total
  243. } finally {
  244. loading.value = false
  245. }
  246. }
  247. /** 处理部门被点击 */
  248. const handleDeptNodeClick = async (row) => {
  249. queryParams.deptId = row.id
  250. await getList()
  251. }
  252. /** 搜索按钮操作 */
  253. const handleQuery = () => {
  254. queryParams.pageNo = 1
  255. getList()
  256. }
  257. const moreQuery = (show) => {
  258. ifShow.value = show
  259. }
  260. /** 重置按钮操作 */
  261. const resetQuery = () => {
  262. queryFormRef.value.resetFields()
  263. handleQuery()
  264. }
  265. /** 添加/修改操作 */
  266. const formRef = ref()
  267. const openForm = (type: string, id?: number) => {
  268. //修改
  269. if (typeof id === 'number') {
  270. push({ name: 'DeviceDetailEdit', params: { id } })
  271. return
  272. }
  273. // 新增
  274. push({ name: 'ConfigDevicePerson', params: {} })
  275. }
  276. /** 删除按钮操作 */
  277. const handleDelete = async (id: number) => {
  278. try {
  279. // 删除的二次确认
  280. await message.delConfirm()
  281. // 发起删除
  282. await IotDeviceApi.deleteIotDevice(id)
  283. message.success(t('common.delSuccess'))
  284. // 刷新列表
  285. await getList()
  286. } catch {}
  287. }
  288. // 是否设置过责任人 下拉列表 模拟字典项
  289. const resultOptions = computed(() => [
  290. {
  291. label: '全部',
  292. value: 'A' // 空值会触发 clearable 效果
  293. },
  294. {
  295. label: '是',
  296. value: 'Y' // 空值会触发 clearable 效果
  297. },
  298. {
  299. label: '否',
  300. value: 'N' // 空值会触发 clearable 效果
  301. },
  302. ])
  303. const handleDetail = (id: number) => {
  304. push({ name: 'DeviceDetailInfo', params: { id } })
  305. }
  306. const handleUpload = (id: number) => {
  307. push({ name: 'DeviceUpload', params: { id } })
  308. }
  309. /** 查看设备责任人调整详情 */
  310. const currentDeviceId = ref() // 设备id
  311. const drawerVisible = ref<boolean>(false)
  312. const showDrawer = ref()
  313. const handleView = async (deviceId) => {
  314. currentDeviceId.value = deviceId
  315. drawerVisible.value = true
  316. showDrawer.value.openDrawer()
  317. }
  318. /** 导出按钮操作 */
  319. const handleExport = async () => {
  320. try {
  321. // 导出的二次确认
  322. await message.exportConfirm()
  323. // 发起导出
  324. exportLoading.value = true
  325. const data = await IotDeviceApi.exportIotDevice(queryParams)
  326. download.excel(data, '设备台账.xls')
  327. } catch {
  328. } finally {
  329. exportLoading.value = false
  330. }
  331. }
  332. const { wsCache } = useCache()
  333. /** 初始化 **/
  334. onMounted(() => {
  335. const user = wsCache.get(CACHE_KEY.USER)
  336. // queryParams.deptId = user.user.deptId
  337. getList()
  338. })
  339. </script>
  340. <style scoped></style>