index.vue 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. <template>
  2. <div class="h-full flex">
  3. <div class="p-5 w-80 pr-0">
  4. <div class="bg-white w-full h-full shadow-md rounded-md flex flex-col">
  5. <div class="flex-1 p-3 overflow-y-auto">
  6. <!-- 筛选条件 -->
  7. <el-form :model="filterForm" label-width="70px" style="max-width: 600px">
  8. <el-form-item v-for="(item, index) in filterItems" :key="index" :label="item.label">
  9. <el-input v-if="item.type === 'input'" v-model="filterForm[item.key as keyof FilterForm]" clearable placeholder="请输入"></el-input>
  10. <el-select v-else v-model="filterForm[item.key as keyof FilterForm]" placeholder="请选择" clearable>
  11. <el-option v-for="option in item.options" :key="option.id" :label="option.name" :value="option.id" />
  12. </el-select>
  13. </el-form-item>
  14. </el-form>
  15. </div>
  16. </div>
  17. </div>
  18. <div class="flex-1 p-5 overflow-auto">
  19. <div class="bg-white w-full h-full p-3 shadow-md rounded-md flex flex-col">
  20. <div class="flex justify-end pb-3">
  21. <!-- 操作按钮 -->
  22. <el-button v-for="(button, index) in actionButtons" :key="index" type="primary">{{ button.text }}</el-button>
  23. </div>
  24. <div class="flex-1 w-full overflow-hidden">
  25. <!-- 表格 -->
  26. <el-table ref="clueTableRef" :data="formTable" border v-loading="allLoading.formTableLading"
  27. style="width: 100%;height: 100%;">
  28. <el-table-column v-for="(column, index) in tableColumns" :key="index" :prop="column.prop" :label="column.label" :width="column.width">
  29. <template #default="scope">
  30. <template v-if="column.event === 'toDetali'">
  31. <el-button link type="primary" size="large" @click="toDetali(scope.row)">{{ scope.row.name }}</el-button>
  32. </template>
  33. </template>
  34. </el-table-column>
  35. <el-table-column :label="'操作'" :width="'200px'" fixed="right">
  36. <template #default="scope">
  37. <el-button link type="primary" size="large">编辑</el-button>
  38. <el-button link type="primary" size="large">新建任务</el-button>
  39. <el-button link type="danger" size="large">删除</el-button>
  40. </template>
  41. </el-table-column>
  42. </el-table>
  43. </div>
  44. <div class="flex justify-end pt-3">
  45. <!-- 分页 -->
  46. <el-pagination layout="total, prev, pager, next, sizes" :total="formTablePaging.total"
  47. :hide-on-single-page="true" />
  48. </div>
  49. </div>
  50. </div>
  51. </div>
  52. </template>
  53. <script lang="ts" setup>
  54. import { ref, reactive, onMounted, inject } from "vue";
  55. import { getAllListByCode, getFromValue, resetFromValue, getFirstDayOfMonth, getLastDayOfMonth, formatDate } from '@/utils/tools'
  56. import { post, get } from "@/utils/request";
  57. import { actionButtons, tableColumns, GETSYSFILED, GETPERSONNEL, GETGENERATEFOEM, MOD } from "./api";
  58. import { useRouter, useRoute } from "vue-router";
  59. const router = useRouter()
  60. const filterForm = reactive<FilterForm>({ // 筛选条件
  61. contactPerson: "",
  62. customerId: "",
  63. phoneNumber: '',
  64. responsibleId: '',
  65. createId: '',
  66. email: '',
  67. });
  68. const selectData = reactive({ // 下拉数据
  69. Personnel: [] as personnelInterface[],
  70. Customer: [] as any[],
  71. })
  72. const filterItems = ref<FilterItem[]>([
  73. { label: '联系人', key: 'contactPerson', type: 'input' },
  74. { label: '客户名称', key: 'customerId', type: 'select', options: selectData.Customer },
  75. { label: '电话号码', key: 'phoneNumber', type: 'input' },
  76. { label: '邮箱', key: 'email', type: 'input' },
  77. { label: '负责人', key: 'responsibleId', type: 'select', options: selectData.Personnel },
  78. { label: '创建人', key: 'createId', type: 'select', options: selectData.Personnel },
  79. ])
  80. const formTablePaging = reactive({ // 分页条件
  81. currentPage: 1,
  82. pageSize: 10,
  83. total: 0,
  84. })
  85. const generateFormData = ref([]) // 自定义表单数据
  86. const formTable = ref([
  87. {name: '联系人', mobile: '13311112222', email: '123@qq.com', responsible: '张三', createId: '张三'}
  88. ]) // 表格数据
  89. const allLoading = reactive({ // 按钮加载 Loading
  90. formTableLading: false,
  91. })
  92. const dialogVisible = reactive({
  93. })
  94. function toDetali(row: any) {
  95. router.push({
  96. path: `${MOD}/detail`,
  97. query: { id: row.name }
  98. })
  99. }
  100. async function getSystemField() {
  101. const systemField = getAllListByCode([])
  102. for (let i in systemField) {
  103. const { data } = await get(`${GETSYSFILED}?code=${systemField[i]}`)
  104. for (let key of Object.keys(selectData)) {
  105. if (systemField[i] == key) {
  106. Object.assign(selectData, { [key]: data })
  107. }
  108. }
  109. }
  110. const { data } = await post(GETPERSONNEL, {})
  111. selectData.Personnel = data.map((item: any) => {
  112. const { id, name, phone, jobNumber } = item
  113. return {
  114. id, name, phone, jobNumber
  115. }
  116. })
  117. // const res = await get(GETGENERATEFOEM)
  118. // generateFormData.value = JSON.parse(res.data[0].config)
  119. setFilterItems()
  120. }
  121. function setFilterItems() {
  122. console.log(selectData)
  123. filterItems.value = [
  124. { label: '联系人', key: 'contactPerson', type: 'input' },
  125. { label: '客户名称', key: 'customerId', type: 'select', options: selectData.Customer },
  126. { label: '电话号码', key: 'phoneNumber', type: 'input' },
  127. { label: '邮箱', key: 'email', type: 'input' },
  128. { label: '负责人', key: 'responsibleId', type: 'select', options: selectData.Personnel },
  129. { label: '创建人', key: 'createId', type: 'select', options: selectData.Personnel },
  130. ]
  131. }
  132. onMounted(() => {
  133. getSystemField()
  134. })
  135. </script>
  136. <style lang="scss" scoped></style>