index.vue 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  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. <template v-for="(item, index) in filterItems">
  9. <el-form-item :label="item.label" v-if="item.type != 'date'">
  10. <el-input v-if="item.type === 'input'" v-model="filterForm[item.key as keyof FilterForm]" clearable
  11. placeholder="请输入"></el-input>
  12. <el-select v-else v-model="filterForm[item.key as keyof FilterForm]" placeholder="请选择" clearable>
  13. <el-option v-for="option in item.options" :key="option.id" :label="option.name" :value="option.id" />
  14. </el-select>
  15. </el-form-item>
  16. <template v-if="item.type == 'date'">
  17. <el-form-item :label="item.label">
  18. <el-date-picker v-model="filterForm.startTime" type="date" placeholder="请选择" :clearable="false"
  19. format="YYYY-MM-DD" value-format="YYYY-MM-DD" />
  20. </el-form-item>
  21. <el-form-item label="">
  22. <el-date-picker v-model="filterForm.endTime" type="date" placeholder="请选择" :clearable="false"
  23. format="YYYY-MM-DD" value-format="YYYY-MM-DD" />
  24. </el-form-item>
  25. </template>
  26. </template>
  27. </el-form>
  28. </div>
  29. <div class="w-full flex p-3 shadow-[0_-3px_5px_0px_rgba(0,0,0,0.2)]">
  30. <El-button class="w-full" @click="resetFilterForm()">重置</El-Button>
  31. <El-button type="primary" class="w-full" @click="getTableList()">搜索</El-Button>
  32. </div>
  33. </div>
  34. </div>
  35. <div class="flex-1 p-5 overflow-auto">
  36. <div class="bg-white w-full h-full p-3 shadow-md rounded-md flex flex-col">
  37. <div class="flex justify-end pb-3">
  38. <!-- 操作按钮 -->
  39. <el-button v-for="(button, index) in actionButtons" :key="index" type="primary">{{ button.text }}</el-button>
  40. </div>
  41. <div class="flex-1 w-full overflow-hidden">
  42. <!-- 表格 -->
  43. <el-table ref="clueTableRef" :data="formTable" border v-loading="allLoading.formTableLading"
  44. style="width: 100%;height: 100%;">
  45. <el-table-column v-for="(column, index) in tableColumns" :key="index" :prop="column.prop"
  46. :label="column.label" :width="column.width">
  47. <template #default="scope">
  48. <template v-if="column.event === 'toDetali'">
  49. <el-button link type="primary" size="large" @click="toDetali(scope.row)">{{ scope.row.name
  50. }}</el-button>
  51. </template>
  52. </template>
  53. </el-table-column>
  54. <el-table-column :label="'操作'" :width="'200px'" fixed="right">
  55. <template #default="scope">
  56. <el-button link type="primary" size="large">编辑</el-button>
  57. <el-button link type="primary" size="large">新建任务</el-button>
  58. <el-button link type="danger" size="large">删除</el-button>
  59. </template>
  60. </el-table-column>
  61. </el-table>
  62. </div>
  63. <div class="flex justify-end pt-3">
  64. <!-- 分页 -->
  65. <el-pagination layout="total, prev, pager, next, sizes" :total="formTablePaging.total"
  66. :hide-on-single-page="true" />
  67. </div>
  68. </div>
  69. </div>
  70. </div>
  71. </template>
  72. <script lang="ts" setup>
  73. import { ref, reactive, onMounted, inject } from "vue";
  74. import { getAllListByCode, getFromValue, resetFromValue, getFirstDayOfMonth, getLastDayOfMonth, formatDate } from '@/utils/tools'
  75. import { post, get } from "@/utils/request";
  76. import { actionButtons, tableColumns, GETSYSFILED, GETPERSONNEL, GETGENERATEFOEM, MOD, GETTABLELIST, GETALLPRODUCT } from "./api";
  77. import { useRouter, useRoute } from "vue-router";
  78. const router = useRouter()
  79. const filterForm = reactive<FilterForm>({ // 筛选条件 Value
  80. contactPerson: "",
  81. customerId: "",
  82. phoneNumber: '',
  83. responsibleId: '',
  84. createId: '',
  85. email: '',
  86. startTime: getFirstDayOfMonth(new Date()),
  87. endTime: formatDate(new Date())
  88. });
  89. const selectData = reactive({ // 下拉数据
  90. Personnel: [] as personnelInterface[],
  91. Customer: [] as any[], // 客户名称
  92. OrderType: [] as any[], // 订单类型
  93. RemittanceStatus: [] as any[], // 回款状态
  94. AllProduct: [] as any[] // 所有产品
  95. })
  96. const filterItems = ref<FilterItem[]>([]) // 渲染筛选条件
  97. const formTablePaging = reactive({ // 分页条件
  98. currentPage: 1,
  99. pageSize: 10,
  100. total: 0,
  101. })
  102. const generateFormData = ref([]) // 自定义表单数据
  103. const formTable = ref([
  104. { name: '订单名称', mobile: '13311112222', email: '123@qq.com', responsible: '张三', createId: '张三' }
  105. ]) // 表格数据
  106. const allLoading = reactive({ // 按钮加载 Loading
  107. formTableLading: false,
  108. })
  109. const dialogVisible = reactive({
  110. })
  111. function toDetali(row: any) {
  112. router.push({
  113. path: `${MOD}/detail`,
  114. query: { id: row.name }
  115. })
  116. }
  117. function getTableList() {
  118. const formValue = getFromValue(filterForm)
  119. const formPaging = { pageIndex: formTablePaging.currentPage, pageSize: formTablePaging.pageSize }
  120. allLoading.formTableLading = true
  121. post(GETTABLELIST, { ...formValue, ...formPaging }).then(res => {
  122. const { total, record } = res.data
  123. formTable.value = record
  124. formTablePaging.total = total
  125. }).finally(() => {
  126. allLoading.formTableLading = false
  127. })
  128. }
  129. function resetFilterForm() {
  130. let newFilterForm = resetFromValue(filterForm, { startTime: getFirstDayOfMonth(new Date()), endTime: formatDate(new Date()) })
  131. Object.assign(filterForm, newFilterForm)
  132. getTableList()
  133. }
  134. function getAllProduct() {
  135. post(GETALLPRODUCT, { pageIndex: -1, pageSize: -1 }).then((res) => {
  136. const { record } = res.data
  137. selectData.AllProduct = record
  138. })
  139. }
  140. async function getSystemField() {
  141. const systemField = getAllListByCode([])
  142. for (let i in systemField) {
  143. const { data } = await get(`${GETSYSFILED}?code=${systemField[i]}`)
  144. for (let key of Object.keys(selectData)) {
  145. if (systemField[i] == key) {
  146. Object.assign(selectData, { [key]: data })
  147. }
  148. }
  149. }
  150. const { data } = await post(GETPERSONNEL, {})
  151. selectData.Personnel = data.map((item: any) => {
  152. const { id, name, phone, jobNumber } = item
  153. return {
  154. id, name, phone, jobNumber
  155. }
  156. })
  157. // const res = await get(GETGENERATEFOEM)
  158. // generateFormData.value = JSON.parse(res.data[0].config)
  159. setFilterItems()
  160. }
  161. function setFilterItems() {
  162. filterItems.value = [
  163. { label: '订单编号', key: 'orderCode', type: 'input' },
  164. { label: '订单名称', key: 'orderName', type: 'input' },
  165. { label: '客户名称', key: 'customId', type: 'select', options: selectData.Customer },
  166. { label: '商机名称', key: 'email', type: 'input' },
  167. { label: '订单类型', key: 'type', type: 'select', options: selectData.OrderType },
  168. { label: '回款状态', key: 'remittanceStatus', type: 'select', options: selectData.RemittanceStatus },
  169. { label: '负责人', key: 'responsibleId', type: 'select', options: selectData.Personnel },
  170. { label: '下单时间', key: '', type: 'date' },
  171. ]
  172. }
  173. onMounted(() => {
  174. getSystemField()
  175. getAllProduct()
  176. getTableList()
  177. })
  178. </script>
  179. <style lang="scss" scoped></style>