index.vue 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. <template>
  2. <div class="app-container">
  3. <!-- 操作工具栏 -->
  4. <el-row :gutter="10" class="mb8">
  5. <el-col :span="1.5">
  6. <XButton preIcon="fa:search" type="primary" @click="handleAdd" title="IP 查询" />
  7. </el-col>
  8. </el-row>
  9. <!-- 列表 -->
  10. <el-table
  11. v-if="refreshTable"
  12. v-loading="loading"
  13. :data="list"
  14. row-key="id"
  15. :tree-props="{ children: 'children', hasChildren: 'hasChildren' }"
  16. >
  17. <el-table-column label="编号" prop="id" />
  18. <el-table-column label="名字" prop="name" />
  19. </el-table>
  20. <!-- <XTable ref="xGrid" @register="registerTable" show-overflow /> -->
  21. <!-- 对话框(添加 / 修改) -->
  22. <el-dialog title="IP 查询" v-model="open" width="500px" append-to-body>
  23. <el-form ref="formRef" :model="form" :rules="rules" label-width="80px">
  24. <el-form-item label="IP" prop="ip">
  25. <el-input v-model="form.ip" placeholder="请输入 IP 地址" />
  26. </el-form-item>
  27. <el-form-item label="地址" prop="result">
  28. <el-input v-model="form.result" readonly placeholder="展示查询 IP 结果" />
  29. </el-form-item>
  30. </el-form>
  31. <template #footer>
  32. <el-button type="primary" @click="submitForm(formRef)">查 询</el-button>
  33. <el-button @click="cancel(formRef)">取 消</el-button>
  34. </template>
  35. </el-dialog>
  36. </div>
  37. </template>
  38. <script lang="ts" setup name="SystemArea">
  39. import * as areaApi from '@/api/system/area'
  40. import type { FormInstance } from 'element-plus'
  41. // import { allSchemas } from './area.data'
  42. // import { getAreaByIp, getAreaTree } from '@/api/system/area'
  43. // 遮罩层
  44. const loading = ref(true)
  45. // 地区列表
  46. const list = ref([])
  47. // 弹出层标题
  48. // const title = ref('')
  49. // 是否显示弹出层
  50. const open = ref(false)
  51. // 重新渲染表格状态
  52. const refreshTable = ref(true)
  53. // 表单参数
  54. const form = ref({
  55. ip: undefined,
  56. result: undefined
  57. })
  58. const formRef = ref<FormInstance>()
  59. // 表单校验
  60. const rules = ref({
  61. ip: [{ required: true, message: 'IP 地址不能为控', trigger: 'blur' }]
  62. })
  63. const message = useMessage() // 消息弹窗
  64. // const treeConfig = {
  65. // transform: true,
  66. // rowField: 'id',
  67. // parentField: 'id'
  68. // // expandAll: true
  69. // }
  70. // const [registerTable, { reload }] = useXTable({
  71. // allSchemas: allSchemas,
  72. // treeConfig: treeConfig,
  73. // getListApi: areaApi.getAreaTree
  74. // })
  75. /** 查询列表 */
  76. const getList = async () => {
  77. loading.value = true
  78. const response = await areaApi.getAreaTree()
  79. list.value = response
  80. loading.value = false
  81. }
  82. /** 取消按钮 */
  83. const cancel = (formEl: FormInstance | undefined) => {
  84. if (!formEl) return
  85. formEl.resetFields()
  86. open.value = false
  87. reset()
  88. }
  89. /** 表单重置 */
  90. const reset = async () => {
  91. form.value = {
  92. ip: undefined,
  93. result: undefined
  94. }
  95. // await reload()
  96. }
  97. /** 新增按钮操作 */
  98. const handleAdd = () => {
  99. open.value = true
  100. reset()
  101. }
  102. /** 提交按钮 */
  103. const submitForm = async (formEl: FormInstance | undefined) => {
  104. if (!formEl) return
  105. await formEl.validate(async (valid, fields) => {
  106. if (valid) {
  107. console.log('submit!')
  108. const response = await areaApi.getAreaByIp(form.value.ip)
  109. message.success('查询成功')
  110. form.value.result = response
  111. } else {
  112. console.log('error submit!', fields)
  113. }
  114. })
  115. }
  116. onMounted(() => {
  117. getList()
  118. })
  119. </script>