Browse Source

处理冲突

master
王泽彦 10 months ago
parent
commit
ccf07be9ba
  1. 5
      admin/components.d.ts
  2. 33
      admin/src/app/api/order_table.ts
  3. 33
      admin/src/app/api/physical_test.ts
  4. 3
      admin/src/app/lang/zh-cn/customer_resource_changes.customer_resource_changes.json
  5. 143
      admin/src/app/lang/zh-cn/customer_resources.customer_resources.json
  6. 54
      admin/src/app/lang/zh-cn/order_table.order_table.json
  7. 52
      admin/src/app/lang/zh-cn/physical_test.physical_test.json
  8. 76
      admin/src/app/lang/zh-cn/physical_test.physical_test_edit.json
  9. 37
      admin/src/app/lang/zh-cn/tc_dialog.physical_test_edit.json
  10. 722
      admin/src/app/views/customer_resources/customer_resources.vue
  11. 610
      admin/src/app/views/order_table/components/order-table-edit.vue
  12. 607
      admin/src/app/views/order_table/order_table.vue
  13. 723
      admin/src/app/views/physical_test/components/physical-test-edit.vue
  14. 451
      admin/src/app/views/physical_test/physical_test.vue
  15. 722
      admin/src/app/views/physical_test/physical_test_edit.vue
  16. 239
      admin/src/app/views/tc_dialog/tc_dialog.vue
  17. 168
      niucloud/app/adminapi/controller/customer_resources/CustomerResources.php
  18. 49
      niucloud/app/adminapi/controller/order_table/OrderTable.php
  19. 21
      niucloud/app/adminapi/controller/physical_test/PhysicalTest.php
  20. 10
      niucloud/app/adminapi/route/order_table.php
  21. 8
      niucloud/app/adminapi/route/physical_test.php
  22. 226
      niucloud/app/model/class_grade/ClassGrade.php
  23. 166
      niucloud/app/model/order_table/OrderTable.php
  24. 54
      niucloud/app/model/physical_test/PhysicalTest.php
  25. 40
      niucloud/app/service/admin/customer_resources/CustomerResourcesService.php
  26. 42
      niucloud/app/service/admin/order_table/OrderTableService.php
  27. 22
      niucloud/app/service/admin/physical_test/PhysicalTestService.php
  28. 12
      niucloud/app/validate/order_table/OrderTable.php
  29. 4
      niucloud/app/validate/physical_test/PhysicalTest.php

5
admin/components.d.ts

@ -21,6 +21,7 @@ declare module '@vue/runtime-core' {
ElColorPicker: typeof import('element-plus/es')['ElColorPicker'] ElColorPicker: typeof import('element-plus/es')['ElColorPicker']
ElConfigProvider: typeof import('element-plus/es')['ElConfigProvider'] ElConfigProvider: typeof import('element-plus/es')['ElConfigProvider']
ElContainer: typeof import('element-plus/es')['ElContainer'] ElContainer: typeof import('element-plus/es')['ElContainer']
ElDatePicker: typeof import('element-plus/es')['ElDatePicker']
ElDialog: typeof import('element-plus/es')['ElDialog'] ElDialog: typeof import('element-plus/es')['ElDialog']
ElDrawer: typeof import('element-plus/es')['ElDrawer'] ElDrawer: typeof import('element-plus/es')['ElDrawer']
ElDropdown: typeof import('element-plus/es')['ElDropdown'] ElDropdown: typeof import('element-plus/es')['ElDropdown']
@ -40,8 +41,6 @@ declare module '@vue/runtime-core' {
ElOption: typeof import('element-plus/es')['ElOption'] ElOption: typeof import('element-plus/es')['ElOption']
ElPagination: typeof import('element-plus/es')['ElPagination'] ElPagination: typeof import('element-plus/es')['ElPagination']
ElPopover: typeof import('element-plus/es')['ElPopover'] ElPopover: typeof import('element-plus/es')['ElPopover']
ElRadio: typeof import('element-plus/es')['ElRadio']
ElRadioGroup: typeof import('element-plus/es')['ElRadioGroup']
ElRow: typeof import('element-plus/es')['ElRow'] ElRow: typeof import('element-plus/es')['ElRow']
ElScrollbar: typeof import('element-plus/es')['ElScrollbar'] ElScrollbar: typeof import('element-plus/es')['ElScrollbar']
ElSelect: typeof import('element-plus/es')['ElSelect'] ElSelect: typeof import('element-plus/es')['ElSelect']
@ -51,9 +50,7 @@ declare module '@vue/runtime-core' {
ElTableColumn: typeof import('element-plus/es')['ElTableColumn'] ElTableColumn: typeof import('element-plus/es')['ElTableColumn']
ElTabPane: typeof import('element-plus/es')['ElTabPane'] ElTabPane: typeof import('element-plus/es')['ElTabPane']
ElTabs: typeof import('element-plus/es')['ElTabs'] ElTabs: typeof import('element-plus/es')['ElTabs']
ElTag: typeof import('element-plus/es')['ElTag']
ElTooltip: typeof import('element-plus/es')['ElTooltip'] ElTooltip: typeof import('element-plus/es')['ElTooltip']
ElTreeSelect: typeof import('element-plus/es')['ElTreeSelect']
ElUpload: typeof import('element-plus/es')['ElUpload'] ElUpload: typeof import('element-plus/es')['ElUpload']
ExportSure: typeof import('./src/components/export-sure/index.vue')['default'] ExportSure: typeof import('./src/components/export-sure/index.vue')['default']
HeatMap: typeof import('./src/components/heat-map/index.vue')['default'] HeatMap: typeof import('./src/components/heat-map/index.vue')['default']

33
admin/src/app/api/order_table.ts

@ -1,5 +1,9 @@
import request from '@/utils/request' import request from '@/utils/request'
// USER_CODE_BEGIN -- order_table // USER_CODE_BEGIN -- order_table
/** /**
* *
@ -7,7 +11,7 @@ import request from '@/utils/request'
* @returns * @returns
*/ */
export function getOrderTableList(params: Record<string, any>) { export function getOrderTableList(params: Record<string, any>) {
return request.get(`order_table/order_table`, { params }) return request.get(`order_table/order_table`, {params})
} }
/** /**
@ -16,7 +20,7 @@ export function getOrderTableList(params: Record<string, any>) {
* @returns * @returns
*/ */
export function getOrderTableInfo(id: number) { export function getOrderTableInfo(id: number) {
return request.get(`order_table/order_table/${id}`) return request.get(`order_table/order_table/${id}`);
} }
/** /**
@ -25,10 +29,7 @@ export function getOrderTableInfo(id: number) {
* @returns * @returns
*/ */
export function addOrderTable(params: Record<string, any>) { export function addOrderTable(params: Record<string, any>) {
return request.post('order_table/order_table', params, { return request.post('order_table/order_table', params, { showErrorMessage: true, showSuccessMessage: true })
showErrorMessage: true,
showSuccessMessage: true,
})
} }
/** /**
@ -38,10 +39,7 @@ export function addOrderTable(params: Record<string, any>) {
* @returns * @returns
*/ */
export function editOrderTable(params: Record<string, any>) { export function editOrderTable(params: Record<string, any>) {
return request.put(`order_table/order_table/${params.id}`, params, { return request.put(`order_table/order_table/${params.id}`, params, { showErrorMessage: true, showSuccessMessage: true })
showErrorMessage: true,
showSuccessMessage: true,
})
} }
/** /**
@ -50,10 +48,17 @@ export function editOrderTable(params: Record<string, any>) {
* @returns * @returns
*/ */
export function deleteOrderTable(id: number) { export function deleteOrderTable(id: number) {
return request.delete(`order_table/order_table/${id}`, { return request.delete(`order_table/order_table/${id}`, { showErrorMessage: true, showSuccessMessage: true })
showErrorMessage: true, }
showSuccessMessage: true,
}) export function getWithCustomerResourcesList(params: Record<string,any>){
return request.get('order_table/customer_resources_all', {params})
}export function getWithCourseList(params: Record<string,any>){
return request.get('order_table/course_all', {params})
}export function getWithClassGradeList(params: Record<string,any>){
return request.get('order_table/class_grade_all', {params})
}export function getWithPersonnelList(params: Record<string,any>){
return request.get('order_table/personnel_all', {params})
} }
// USER_CODE_END -- order_table // USER_CODE_END -- order_table

33
admin/src/app/api/physical_test.ts

@ -1,5 +1,11 @@
import request from '@/utils/request' import request from '@/utils/request'
// USER_CODE_BEGIN -- physical_test // USER_CODE_BEGIN -- physical_test
/** /**
* *
@ -7,7 +13,7 @@ import request from '@/utils/request'
* @returns * @returns
*/ */
export function getPhysicalTestList(params: Record<string, any>) { export function getPhysicalTestList(params: Record<string, any>) {
return request.get(`physical_test/physical_test`, { params }) return request.get(`physical_test/physical_test`, {params})
} }
/** /**
@ -16,7 +22,7 @@ export function getPhysicalTestList(params: Record<string, any>) {
* @returns * @returns
*/ */
export function getPhysicalTestInfo(id: number) { export function getPhysicalTestInfo(id: number) {
return request.get(`physical_test/physical_test/${id}`) return request.get(`physical_test/physical_test/${id}`);
} }
/** /**
@ -25,10 +31,7 @@ export function getPhysicalTestInfo(id: number) {
* @returns * @returns
*/ */
export function addPhysicalTest(params: Record<string, any>) { export function addPhysicalTest(params: Record<string, any>) {
return request.post('physical_test/physical_test', params, { return request.post('physical_test/physical_test', params, { showErrorMessage: true, showSuccessMessage: true })
showErrorMessage: true,
showSuccessMessage: true,
})
} }
/** /**
@ -38,10 +41,7 @@ export function addPhysicalTest(params: Record<string, any>) {
* @returns * @returns
*/ */
export function editPhysicalTest(params: Record<string, any>) { export function editPhysicalTest(params: Record<string, any>) {
return request.put(`physical_test/physical_test/${params.id}`, params, { return request.put(`physical_test/physical_test/${params.id}`, params, { showErrorMessage: true, showSuccessMessage: true })
showErrorMessage: true,
showSuccessMessage: true,
})
} }
/** /**
@ -50,10 +50,15 @@ export function editPhysicalTest(params: Record<string, any>) {
* @returns * @returns
*/ */
export function deletePhysicalTest(id: number) { export function deletePhysicalTest(id: number) {
return request.delete(`physical_test/physical_test/${id}`, { return request.delete(`physical_test/physical_test/${id}`, { showErrorMessage: true, showSuccessMessage: true })
showErrorMessage: true, }
showSuccessMessage: true,
}) export function getWithCustomerResourcesList(params: Record<string,any>){
return request.get('physical_test/customer_resources_all', {params})
}export function getWithStudentList(params: Record<string,any>){
return request.get('physical_test/student_all', {params})
}export function getWithPersonnelList(params: Record<string,any>){
return request.get('physical_test/personnel_all', {params})
} }
// USER_CODE_END -- physical_test // USER_CODE_END -- physical_test

3
admin/src/app/lang/zh-cn/customer_resource_changes.customer_resource_changes.json

@ -18,4 +18,7 @@
"customerResourceChangesDeleteTips": "确定要删除该数据吗?", "customerResourceChangesDeleteTips": "确定要删除该数据吗?",
"startDate": "请选择开始时间", "startDate": "请选择开始时间",
"endDate": "请选择结束时间" "endDate": "请选择结束时间"
} }

143
admin/src/app/lang/zh-cn/customer_resources.customer_resources.json

@ -1,38 +1,107 @@
{ {
"source": "来源", "source":"来源",
"sourcePlaceholder": "请输入来源", "sourcePlaceholder":"请输入来源",
"sourceChannel": "来源渠道", "sourceChannel":"来源渠道",
"sourceChannelPlaceholder": "请输入来源渠道", "sourceChannelPlaceholder":"请输入来源渠道",
"consultant": "顾问", "consultant":"顾问",
"name": "姓名", "name":"姓名",
"namePlaceholder": "请输入姓名", "namePlaceholder":"请输入姓名",
"age": "年龄", "age":"年龄",
"agePlaceholder": "请输入年龄", "agePlaceholder":"请输入年龄",
"gender": "性别", "gender":"性别",
"genderPlaceholder": "请输入性别", "genderPlaceholder":"请输入性别",
"phoneNumber": "联系电话", "phoneNumber":"联系电话",
"phoneNumberPlaceholder": "请输入联系电话", "phoneNumberPlaceholder":"请输入联系电话",
"demand": "需求", "demand":"需求",
"demandPlaceholder": "请输入需求", "demandPlaceholder":"请输入需求",
"purchasingPower": "购买力", "purchasingPower":"购买力",
"purchasingPowerPlaceholder": "请输入购买力", "purchasingPowerPlaceholder":"请输入购买力",
"cognitiveIdea": "认知理念", "cognitiveIdea":"认知理念",
"cognitiveIdeaPlaceholder": "请输入认知理念", "cognitiveIdeaPlaceholder":"请输入认知理念",
"optionalClassTime": "可选上课时间", "optionalClassTime":"可选上课时间",
"optionalClassTimePlaceholder": "请输入可选上课时间", "optionalClassTimePlaceholder":"请输入可选上课时间",
"distance": "距离", "distance":"距离",
"distancePlaceholder": "请输入距离", "distancePlaceholder":"请输入距离",
"decisionMaker": "决策人", "decisionMaker":"决策人",
"decisionMakerPlaceholder": "请输入决策人", "decisionMakerPlaceholder":"请输入决策人",
"initialIntent": "客户初步意向度", "initialIntent":"客户初步意向度",
"initialIntentPlaceholder": "请输入客户初步意向度", "initialIntentPlaceholder":"请输入客户初步意向度",
"campus": "所属校区", "campus":"所属校区",
"campusPlaceholder": "请输入所属校区", "campusPlaceholder":"请输入所属校区",
"status": "客户状态", "status":"客户状态",
"statusPlaceholder": "请输入客户状态", "statusPlaceholder":"请输入客户状态",
"addCustomerResources": "添加客户资源", "addCustomerResources":"添加客户资源",
"updateCustomerResources": "编辑客户资源", "updateCustomerResources":"编辑客户资源",
"customerResourcesDeleteTips": "确定要删除该数据吗?", "customerResourcesDeleteTips":"确定要删除该数据吗?",
"startDate": "请选择开始时间", "startDate":"请选择开始时间",
"endDate": "请选择结束时间" "endDate":"请选择结束时间",
}
"resourceId":"资源",
"resourceIdPlaceholder":"请输入资源",
"orderStatus":"订单状态",
"orderStatusPlaceholder":"请输入订单状态",
"paymentType":"付款类型",
"paymentTypePlaceholder":"请输入付款类型",
"orderAmount":"订单金额",
"orderAmountPlaceholder":"请输入订单金额",
"courseId":"课程",
"courseIdPlaceholder":"请输入课程",
"classId":"班级",
"classIdPlaceholder":"请输入班级",
"staffId":"人员",
"paymentTime":"支付时间",
"addOrderTable":"添加订单",
"updateOrderTable":"编辑订单",
"resourceId":"客户姓名",
"resourceIdPlaceholder":"全部",
"studentId":"学员姓名",
"studentIdPlaceholder":"全部",
"height":"身高",
"heightPlaceholder":"请输入身高",
"createdAt":"创建时间",
"updatedAt":"修改时间",
"addPhysicalTest":"添加体测",
"updatePhysicalTest":"编辑体测",
"physicalTestDeleteTips":"确定要删除该数据吗?",
"startDate":"请选择开始时间",
"endDate":"请选择结束时间",
"resourceId":"客户姓名",
"resourceIdPlaceholder":"全部",
"studentId":"学员姓名",
"studentIdPlaceholder":"全部",
"height":"身高",
"heightPlaceholder":"请输入身高",
"weight":"体重",
"weightPlaceholder":"请输入体重",
"coachId":"教练",
"coachIdPlaceholder":"请输入教练",
"seatedForwardBend":"坐位体前屈",
"seatedForwardBendPlaceholder":"请输入坐位体前屈",
"sitUps":"仰卧卷腹",
"sitUpsPlaceholder":"请输入仰卧卷腹",
"pushUps":"九十度仰卧撑",
"pushUpsPlaceholder":"请输入九十度仰卧撑",
"flamingoBalance":"火烈鸟平衡测试",
"flamingoBalancePlaceholder":"请输入火烈鸟平衡测试",
"thirtySecJump":"三十秒双脚连续跳",
"thirtySecJumpPlaceholder":"请输入三十秒双脚连续跳",
"standingLongJump":"立定跳远",
"standingLongJumpPlaceholder":"请输入立定跳远",
"agilityRun":"4乘10m灵敏折返跑",
"agilityRunPlaceholder":"请输入4乘10m灵敏折返跑",
"balanceBeam":"走平衡木",
"balanceBeamPlaceholder":"请输入走平衡木",
"tennisThrow":"网球掷远",
"tennisThrowPlaceholder":"请输入网球掷远",
"tenMeterShuttleRun":"十米往返跑",
"tenMeterShuttleRunPlaceholder":"请输入十米往返跑",
"addPhysicalTest":"添加体测",
"updatePhysicalTest":"编辑体测",
"physicalTestDeleteTips":"确定要删除该数据吗?",
"startDate":"请选择开始时间",
"endDate":"请选择结束时间"
}

54
admin/src/app/lang/zh-cn/order_table.order_table.json

@ -1,35 +1,21 @@
{ {
"id": "订单编号", "resourceId":"资源",
"idPlaceholder": "请输入订单编号", "resourceIdPlaceholder":"请输入资源",
"paymentId": "支付编号", "orderStatus":"订单状态",
"paymentIdPlaceholder": "请输入支付编号", "orderStatusPlaceholder":"请输入订单状态",
"orderStatus": "订单状态: pending-待支付, paid-已支付", "paymentType":"付款类型",
"orderStatusPlaceholder": "请输入订单状态: pending-待支付, paid-已支付", "paymentTypePlaceholder":"请输入付款类型",
"paymentType": "付款类型: cash-现金支付, scan_code-扫码支付, subscription-订阅支付", "orderAmount":"订单金额",
"paymentTypePlaceholder": "请输入付款类型: cash-现金支付, scan_code-扫码支付, subscription-订阅支付", "orderAmountPlaceholder":"请输入订单金额",
"orderAmount": "订单金额", "courseId":"课程",
"orderAmountPlaceholder": "请输入订单金额", "courseIdPlaceholder":"请输入课程",
"courseId": "课程ID", "classId":"班级",
"courseIdPlaceholder": "请输入课程ID", "classIdPlaceholder":"请输入班级",
"classId": "班级ID", "staffId":"人员",
"classIdPlaceholder": "请输入班级ID", "paymentTime":"支付时间",
"staffId": "人员ID", "addOrderTable":"添加订单",
"staffIdPlaceholder": "请输入人员ID", "updateOrderTable":"编辑订单",
"resourceId": "资源ID", "orderTableDeleteTips":"确定要删除该数据吗?",
"resourceIdPlaceholder": "请输入资源ID", "startDate":"请选择开始时间",
"afterSalesStatus": "售后状态", "endDate":"请选择结束时间"
"afterSalesStatusPlaceholder": "请输入售后状态", }
"afterSalesReason": "售后原因",
"afterSalesReasonPlaceholder": "请输入售后原因",
"afterSalesTime": "售后时间",
"afterSalesTimePlaceholder": "请输入售后时间",
"paymentTime": "支付时间",
"paymentTimePlaceholder": "请输入支付时间",
"subscriptionPaymentTime": "订阅支付生成时间",
"subscriptionPaymentTimePlaceholder": "请输入订阅支付生成时间",
"addOrderTable": "添加订单",
"updateOrderTable": "编辑订单",
"orderTableDeleteTips": "确定要删除该数据吗?",
"startDate": "请选择开始时间",
"endDate": "请选择结束时间"
}

52
admin/src/app/lang/zh-cn/physical_test.physical_test.json

@ -1,17 +1,37 @@
{ {
"resourceId": "客户姓名", "resourceId":"客户姓名",
"resourceIdPlaceholder": "请输入客户姓名", "resourceIdPlaceholder":"全部",
"studentId": "学员姓名", "studentId":"学员姓名",
"studentIdPlaceholder": "请输入学员姓名", "studentIdPlaceholder":"全部",
"height": "身高", "height":"身高",
"heightPlaceholder": "请输入身高", "heightPlaceholder":"请输入身高",
"createdAt": "创建时间", "weight":"体重",
"createdAtPlaceholder": "请输入创建时间", "weightPlaceholder":"请输入体重",
"updatedAt": "修改时间", "coachId":"教练",
"updatedAtPlaceholder": "请输入修改时间", "coachIdPlaceholder":"请输入教练",
"addPhysicalTest": "添加体测", "seatedForwardBend":"坐位体前屈",
"updatePhysicalTest": "编辑体测", "seatedForwardBendPlaceholder":"请输入坐位体前屈",
"physicalTestDeleteTips": "确定要删除该数据吗?", "sitUps":"仰卧卷腹",
"startDate": "请选择开始时间", "sitUpsPlaceholder":"请输入仰卧卷腹",
"endDate": "请选择结束时间" "pushUps":"九十度仰卧撑",
} "pushUpsPlaceholder":"请输入九十度仰卧撑",
"flamingoBalance":"火烈鸟平衡测试",
"flamingoBalancePlaceholder":"请输入火烈鸟平衡测试",
"thirtySecJump":"三十秒双脚连续跳",
"thirtySecJumpPlaceholder":"请输入三十秒双脚连续跳",
"standingLongJump":"立定跳远",
"standingLongJumpPlaceholder":"请输入立定跳远",
"agilityRun":"4乘10m灵敏折返跑",
"agilityRunPlaceholder":"请输入4乘10m灵敏折返跑",
"balanceBeam":"走平衡木",
"balanceBeamPlaceholder":"请输入走平衡木",
"tennisThrow":"网球掷远",
"tennisThrowPlaceholder":"请输入网球掷远",
"tenMeterShuttleRun":"十米往返跑",
"tenMeterShuttleRunPlaceholder":"请输入十米往返跑",
"addPhysicalTest":"添加体测",
"updatePhysicalTest":"编辑体测",
"physicalTestDeleteTips":"确定要删除该数据吗?",
"startDate":"请选择开始时间",
"endDate":"请选择结束时间"
}

76
admin/src/app/lang/zh-cn/physical_test.physical_test_edit.json

@ -1,39 +1,39 @@
{ {
"resourceId": "客户姓名", "resourceId":"客户姓名",
"studentId": "学员姓名", "studentId":"学员姓名",
"height": "身高", "height":"身高",
"weight": "体重", "weight":"体重",
"coachId": "教练", "coachId":"教练",
"createdAt": "创建时间", "createdAt":"创建时间",
"updatedAt": "修改时间", "updatedAt":"修改时间",
"seatedForwardBend": "坐位体前屈", "seatedForwardBend":"坐位体前屈",
"sitUps": "仰卧卷腹", "sitUps":"仰卧卷腹",
"pushUps": "九十度仰卧撑", "pushUps":"九十度仰卧撑",
"flamingoBalance": "火烈鸟平衡测试", "flamingoBalance":"火烈鸟平衡测试",
"thirtySecJump": "三十秒双脚连续跳", "thirtySecJump":"三十秒双脚连续跳",
"standingLongJump": "立定跳远", "standingLongJump":"立定跳远",
"agilityRun": "4乘10m灵敏折返跑", "agilityRun":"4乘10m灵敏折返跑",
"balanceBeam": "走平衡木", "balanceBeam":"走平衡木",
"tennisThrow": "网球掷远", "tennisThrow":"网球掷远",
"tenMeterShuttleRun": "十米往返跑", "tenMeterShuttleRun":"十米往返跑",
"resourceIdPlaceholder": "请输入客户姓名", "resourceIdPlaceholder":"请选择客户姓名",
"studentIdPlaceholder": "请输入学员姓名", "studentIdPlaceholder":"请选择学员姓名",
"heightPlaceholder": "请输入身高", "heightPlaceholder":"请输入身高",
"weightPlaceholder": "请输入体重", "weightPlaceholder":"请输入体重",
"coachIdPlaceholder": "请输入教练", "coachIdPlaceholder":"请选择教练",
"createdAtPlaceholder": "请输入创建时间", "createdAtPlaceholder":"请输入创建时间",
"updatedAtPlaceholder": "请输入修改时间", "updatedAtPlaceholder":"请输入修改时间",
"seatedForwardBendPlaceholder": "请输入坐位体前屈", "seatedForwardBendPlaceholder":"请输入坐位体前屈",
"sitUpsPlaceholder": "请输入仰卧卷腹", "sitUpsPlaceholder":"请输入仰卧卷腹",
"pushUpsPlaceholder": "请输入九十度仰卧撑", "pushUpsPlaceholder":"请输入九十度仰卧撑",
"flamingoBalancePlaceholder": "请输入火烈鸟平衡测试", "flamingoBalancePlaceholder":"请输入火烈鸟平衡测试",
"thirtySecJumpPlaceholder": "请输入三十秒双脚连续跳", "thirtySecJumpPlaceholder":"请输入三十秒双脚连续跳",
"standingLongJumpPlaceholder": "请输入立定跳远", "standingLongJumpPlaceholder":"请输入立定跳远",
"agilityRunPlaceholder": "请输入4乘10m灵敏折返跑", "agilityRunPlaceholder":"请输入4乘10m灵敏折返跑",
"balanceBeamPlaceholder": "请输入走平衡木", "balanceBeamPlaceholder":"请输入走平衡木",
"tennisThrowPlaceholder": "请输入网球掷远", "tennisThrowPlaceholder":"请输入网球掷远",
"tenMeterShuttleRunPlaceholder": "请输入十米往返跑", "tenMeterShuttleRunPlaceholder":"请输入十米往返跑",
"addPhysicalTest": "添加体测", "addPhysicalTest":"添加体测",
"updatePhysicalTest": "编辑体测", "updatePhysicalTest":"编辑体测",
"physicalTestDeleteTips": "确定要删除该体测吗?" "physicalTestDeleteTips":"确定要删除该体测吗?"
} }

37
admin/src/app/lang/zh-cn/tc_dialog.physical_test_edit.json

@ -0,0 +1,37 @@
{
"resourceId":"客户姓名",
"resourceIdPlaceholder":"全部",
"studentId":"学员姓名",
"studentIdPlaceholder":"全部",
"height":"身高",
"heightPlaceholder":"请输入身高",
"weight":"体重",
"weightPlaceholder":"请输入体重",
"coachId":"教练",
"coachIdPlaceholder":"请输入教练",
"seatedForwardBend":"坐位体前屈",
"seatedForwardBendPlaceholder":"请输入坐位体前屈",
"sitUps":"仰卧卷腹",
"sitUpsPlaceholder":"请输入仰卧卷腹",
"pushUps":"九十度仰卧撑",
"pushUpsPlaceholder":"请输入九十度仰卧撑",
"flamingoBalance":"火烈鸟平衡测试",
"flamingoBalancePlaceholder":"请输入火烈鸟平衡测试",
"thirtySecJump":"三十秒双脚连续跳",
"thirtySecJumpPlaceholder":"请输入三十秒双脚连续跳",
"standingLongJump":"立定跳远",
"standingLongJumpPlaceholder":"请输入立定跳远",
"agilityRun":"4乘10m灵敏折返跑",
"agilityRunPlaceholder":"请输入4乘10m灵敏折返跑",
"balanceBeam":"走平衡木",
"balanceBeamPlaceholder":"请输入走平衡木",
"tennisThrow":"网球掷远",
"tennisThrowPlaceholder":"请输入网球掷远",
"tenMeterShuttleRun":"十米往返跑",
"tenMeterShuttleRunPlaceholder":"请输入十米往返跑",
"addPhysicalTest":"添加体测",
"updatePhysicalTest":"编辑体测",
"physicalTestDeleteTips":"确定要删除该数据吗?",
"startDate":"请选择开始时间",
"endDate":"请选择结束时间"
}

722
admin/src/app/views/customer_resources/customer_resources.vue

@ -1,368 +1,368 @@
<template> <template>
<div class="main-container"> <div class="main-container">
<el-card class="box-card !border-none" shadow="never"> <el-card class="box-card !border-none" shadow="never">
<div class="flex justify-between items-center">
<span class="text-lg">{{ pageName }}</span> <div class="flex justify-between items-center">
<el-button type="primary" @click="addEvent" v-if="type == 'khzy'"> <span class="text-lg">{{pageName}}</span>
{{ t('addCustomerResources') }} <el-button type="primary" @click="addEvent" v-if="customerResourcesTable.searchParam.type == 'khzy'">
</el-button> {{ t('addCustomerResources') }}
</div> </el-button>
</div>
<el-card
class="box-card !border-none my-[10px] table-search-wrap" <el-card class="box-card !border-none my-[10px] table-search-wrap" shadow="never">
shadow="never" <el-form :inline="true" :model="customerResourcesTable.searchParam" ref="searchFormRef">
> <el-form-item :label="t('name')" prop="name">
<el-form <el-input v-model="customerResourcesTable.searchParam.name"
:inline="true" :placeholder="t('namePlaceholder')" />
:model="customerResourcesTable.searchParam" </el-form-item>
ref="searchFormRef"
> <el-form-item label="年龄" prop="age">
<el-form-item :label="t('name')" prop="name"> <el-input v-model="customerResourcesTable.searchParam.age" placeholder="请输入年龄" />
<el-input </el-form-item>
v-model="customerResourcesTable.searchParam.name"
:placeholder="t('namePlaceholder')"
/> <el-form-item label="性别" prop="gender">
</el-form-item> <el-select v-model="customerResourcesTable.searchParam.gender" placeholder="请选择性别">
<el-form-item :label="t('phoneNumber')" prop="phone_number"> <el-option label="男性" value="male" />
<el-input <el-option label="女性" value="female" />
v-model="customerResourcesTable.searchParam.phone_number" <el-option label="其他" value="other" />
:placeholder="t('phoneNumberPlaceholder')" </el-select>
/> </el-form-item>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="loadCustomerResourcesList()">{{ <el-form-item :label="t('phoneNumber')" prop="phone_number">
t('search') <el-input v-model="customerResourcesTable.searchParam.phone_number"
}}</el-button> :placeholder="t('phoneNumberPlaceholder')" />
<el-button @click="resetForm(searchFormRef)">{{ </el-form-item>
t('reset')
}}</el-button>
</el-form-item> <el-form-item label="创建时间">
</el-form> <el-date-picker v-model="customerResourcesTable.searchParam.created_at" type="daterange" range-separator=""
</el-card> start-placeholder="开始日期" end-placeholder="结束日期" format="YYYY-MM-DD"
value-format="YYYY-MM-DD" />
<div class="mt-[10px]"> </el-form-item>
<el-table
:data="customerResourcesTable.data" <!-- 更新时间 -->
size="large" <el-form-item label="更新时间">
v-loading="customerResourcesTable.loading" <el-date-picker v-model="customerResourcesTable.searchParam.updated_at" type="daterange" range-separator=""
> start-placeholder="开始日期" end-placeholder="结束日期" format="YYYY-MM-DD"
<template #empty> value-format="YYYY-MM-DD" />
<span>{{ </el-form-item>
!customerResourcesTable.loading ? t('emptyData') : ''
}}</span>
</template> <el-form-item>
<el-table-column <el-button type="primary" @click="loadCustomerResourcesList()">{{ t('search') }}</el-button>
:label="t('source')" <el-button @click="resetForm(searchFormRef)">{{ t('reset') }}</el-button>
min-width="180" </el-form-item>
align="center" </el-form>
:show-overflow-tooltip="true" </el-card>
>
<template #default="{ row }"> <div class="mt-[10px]">
<div v-for="(item, index) in sourceList"> <el-table :data="customerResourcesTable.data" size="large" v-loading="customerResourcesTable.loading">
<div v-if="item.value == row.source">{{ item.name }}</div> <template #empty>
</div> <span>{{ !customerResourcesTable.loading ? t('emptyData') : '' }}</span>
</template> </template>
</el-table-column> <el-table-column :label="t('source')" min-width="180" align="center" :show-overflow-tooltip="true">
<template #default="{ row }">
<el-table-column <div v-for="(item, index) in sourceList">
prop="consultant_name" <div v-if="item.value == row.source">{{ item.name }}</div>
:label="t('consultant')" </div>
min-width="120" </template>
:show-overflow-tooltip="true" </el-table-column>
/>
<el-table-column prop="consultant_name" :label="t('consultant')" min-width="120"
<el-table-column :show-overflow-tooltip="true" />
prop="name"
:label="t('name')" <el-table-column prop="name" :label="t('name')" min-width="120" :show-overflow-tooltip="true" />
min-width="120"
:show-overflow-tooltip="true" <el-table-column prop="age" :label="t('age')" min-width="50" :show-overflow-tooltip="true" />
/>
<el-table-column :label="t('gender')" min-width="60" align="center" :show-overflow-tooltip="true">
<el-table-column <template #default="{ row }">
prop="age" <div v-for="(item, index) in genderList">
:label="t('age')" <div v-if="item.value == row.gender">{{ item.name }}</div>
min-width="120" </div>
:show-overflow-tooltip="true" </template>
/> </el-table-column>
<el-table-column <el-table-column prop="phone_number" :label="t('phoneNumber')" min-width="120"
:label="t('gender')" :show-overflow-tooltip="true" />
min-width="180"
align="center" <el-table-column prop="decision_maker" :label="t('decisionMaker')" min-width="120"
:show-overflow-tooltip="true" :show-overflow-tooltip="true" />
>
<template #default="{ row }">
<div v-for="(item, index) in genderList"> <el-table-column prop="created_at" label="添加时间" min-width="120" :show-overflow-tooltip="true" />
<div v-if="item.value == row.gender">{{ item.name }}</div>
</div> <el-table-column prop="updated_at" label="修改时间" min-width="120" :show-overflow-tooltip="true" />
</template>
</el-table-column>
<el-table-column :label="t('operation')" fixed="right" min-width="200" v-if="customerResourcesTable.searchParam.type == 'khzy'">
<el-table-column <template #default="{ row }">
prop="phone_number" <el-button type="primary" link @click="modificationLog(row.id)">六要素修改记录</el-button>
:label="t('phoneNumber')" <el-button type="primary" link @click="resourceChanges(row.id)">客户信息修改记录</el-button>
min-width="120" <el-button type="primary" link @click="editEvent(row)">{{ t('edit') }}</el-button>
:show-overflow-tooltip="true" <el-button type="primary" link @click="deleteEvent(row.id)">{{ t('delete') }}</el-button>
/>
</template>
<el-table-column </el-table-column>
prop="decision_maker"
:label="t('decisionMaker')"
min-width="120"
:show-overflow-tooltip="true" <el-table-column :label="t('operation')" fixed="right" min-width="200"
/> v-if="customerResourcesTable.searchParam.type == 'yjfp'">
<template #default="{ row }">
<el-table-column <el-button type="primary" link @click="fpEvent(row)">分配</el-button>
:label="t('operation')" </template>
fixed="right" </el-table-column>
min-width="200"
v-if="type == 'khzy'"
> <el-table-column :label="t('operation')" fixed="right" min-width="200"
<template #default="{ row }"> v-if="customerResourcesTable.searchParam.type == 'zylb'">
<el-button type="primary" link @click="modificationLog(row.id)" <template #default="{ row }">
>六要素修改记录</el-button <el-button type="primary" link @click="editEvent(row)">{{ t('edit') }}</el-button>
>
<el-button type="primary" link @click="resourceChanges(row.id)" <el-button type="primary" link @click="addOrder({'resource_id':row.id})">添加订单</el-button>
>客户信息修改记录</el-button
> <el-button type="primary" link @click="tcEvent({'resource_id':row.id})">体测</el-button>
<el-button type="primary" link @click="editEvent(row)">{{ </template>
t('edit') </el-table-column>
}}</el-button>
<el-button type="primary" link @click="deleteEvent(row.id)">{{ </el-table>
t('delete') <div class="mt-[16px] flex justify-end">
}}</el-button> <el-pagination v-model:current-page="customerResourcesTable.page"
</template> v-model:page-size="customerResourcesTable.limit"
</el-table-column> layout="total, sizes, prev, pager, next, jumper" :total="customerResourcesTable.total"
@size-change="loadCustomerResourcesList()" @current-change="loadCustomerResourcesList" />
<el-table-column </div>
:label="t('operation')" </div>
fixed="right"
min-width="200" <edit ref="editCustomerResourcesDialog" @complete="loadCustomerResourcesList" />
v-if="type == 'yjfp'"
> <fp ref="fpCustomerResourcesDialog" @complete="loadCustomerResourcesList" />
<template #default="{ row }">
<el-button type="primary" link @click="fpEvent(row)" <Order ref="editOrderTableDialog" @complete="loadCustomerResourcesList" />
>分配</el-button
> <tc ref="TcCustomerResourcesDialog" @complete="loadCustomerResourcesList" />
</template>
</el-table-column> </el-card>
</el-table> </div>
<div class="mt-[16px] flex justify-end">
<el-pagination
v-model:current-page="customerResourcesTable.page"
v-model:page-size="customerResourcesTable.limit"
layout="total, sizes, prev, pager, next, jumper"
:total="customerResourcesTable.total"
@size-change="loadCustomerResourcesList()"
@current-change="loadCustomerResourcesList"
/>
</div>
</div>
<edit
ref="editCustomerResourcesDialog"
@complete="loadCustomerResourcesList"
/>
<fp
ref="fpCustomerResourcesDialog"
@complete="loadCustomerResourcesList"
/>
</el-card>
</div>
</template> </template>
<script lang="ts" setup> <script lang="ts" setup>
import { reactive, ref, watch } from 'vue' import { reactive, ref, watch } from 'vue'
import { t } from '@/lang' import { t } from '@/lang'
import { useDictionary } from '@/app/api/dict' import { useDictionary } from '@/app/api/dict'
import { import { getCustomerResourcesList, deleteCustomerResources, getWithPersonnelList, getWithCampusList } from '@/app/api/customer_resources'
getCustomerResourcesList, import { img } from '@/utils/common'
deleteCustomerResources, import { ElMessageBox, FormInstance } from 'element-plus'
getWithPersonnelList, import Edit from '@/app/views/customer_resources/components/customer-resources-edit.vue'
getWithCampusList, import Fp from '@/app/views/customer_resources/components/fp.vue'
} from '@/app/api/customer_resources' import Order from '@/app/views/order_table/components/order-table-edit.vue'
import { img } from '@/utils/common'
import { ElMessageBox, FormInstance } from 'element-plus' import Tc from '@/app/views/tc_dialog/tc_dialog.vue'
import Edit from '@/app/views/customer_resources/components/customer-resources-edit.vue'
import Fp from '@/app/views/customer_resources/components/fp.vue' import { useRouter, useRoute } from 'vue-router'
import { useRouter, useRoute } from 'vue-router' const route = useRoute()
const route = useRoute() const pageName = route.meta.title;
const pageName = route.meta.title const router = useRouter()
const router = useRouter()
let customerResourcesTable = reactive({
const type = pageName == '业绩分配' ? 'yjfp' : 'khzy' page: 1,
limit: 10,
const modificationLog = (id: number) => { total: 0,
router.push({ loading: true,
path: '/six_speed_modification_log/six_speed_modification_log', data: [],
query: { id: id }, searchParam: {
}) "name": "",
} "age": "",
"gender": "",
const resourceChanges = (id: number) => { "phone_number": "",
router.push({ 'type': '',
path: '/customer_resource_changes/customer_resource_changes', "created_at" : "",
query: { id: id }, "updated_at" : ""
}) }
} })
let customerResourcesTable = reactive({ if (pageName == '业绩分配') {
page: 1, customerResourcesTable.searchParam.type = 'yjfp';
limit: 10, } else if (pageName == '客户资源列表') {
total: 0, customerResourcesTable.searchParam.type = 'khzy';
loading: true, } else if (pageName == '资源列表') {
data: [], customerResourcesTable.searchParam.type = 'zylb';
searchParam: { }
name: '',
phone_number: '', // const type = pageName == '' ? 'yjfp' : 'khzy';
type: type,
},
})
const modificationLog = (id : number) => {
const searchFormRef = ref<FormInstance>() router.push({ path: '/six_speed_modification_log/six_speed_modification_log', query: { id: id } })
}
//
const selectData = ref<any[]>([]) const resourceChanges = (id : number) => {
router.push({ path: '/customer_resource_changes/customer_resource_changes', query: { id: id } })
// }
const sourceList = ref([] as any[])
const sourceDictList = async () => {
sourceList.value = await (await useDictionary('source')).data.dictionary /**
} * 添加订单
sourceDictList() */
const source_channelList = ref([] as any[]) const editOrderTableDialog : Record<string, any> | null = ref(null)
const source_channelDictList = async () => { const addOrder = (row : any) => {
source_channelList.value = await (
await useDictionary('SourceChannel') console.log(row);
).data.dictionary editOrderTableDialog.value.setFormData(row)
} editOrderTableDialog.value.showDialog = true
source_channelDictList() }
const genderList = ref([] as any[])
const genderDictList = async () => {
genderList.value = await (await useDictionary('zy_sex')).data.dictionary const TcCustomerResourcesDialog : Record<string, any> | null = ref(null)
} const tcEvent = (row : any) => {
genderDictList() TcCustomerResourcesDialog.value.setFormData(row)
const purchasing_powerList = ref([] as any[]) TcCustomerResourcesDialog.value.showDialog = true
const purchasing_powerDictList = async () => { }
purchasing_powerList.value = await (
await useDictionary('customer_purchasing_power')
).data.dictionary
}
purchasing_powerDictList() const searchFormRef = ref<FormInstance>()
const cognitive_ideaList = ref([] as any[])
const cognitive_ideaDictList = async () => { //
cognitive_ideaList.value = await ( const selectData = ref<any[]>([])
await useDictionary('cognitive_concept')
).data.dictionary //
} const sourceList = ref([] as any[])
cognitive_ideaDictList() const sourceDictList = async () => {
const initial_intentList = ref([] as any[]) sourceList.value = await (await useDictionary('source')).data.dictionary
const initial_intentDictList = async () => { }
initial_intentList.value = await ( sourceDictList();
await useDictionary('preliminarycustomerintention') const source_channelList = ref([] as any[])
).data.dictionary const source_channelDictList = async () => {
} source_channelList.value = await (await useDictionary('SourceChannel')).data.dictionary
initial_intentDictList() }
const statusList = ref([] as any[]) source_channelDictList();
const statusDictList = async () => { const genderList = ref([] as any[])
statusList.value = await (await useDictionary('kh_status')).data.dictionary const genderDictList = async () => {
} genderList.value = await (await useDictionary('zy_sex')).data.dictionary
statusDictList() }
genderDictList();
/** const purchasing_powerList = ref([] as any[])
* 获取客户资源列表 const purchasing_powerDictList = async () => {
*/ purchasing_powerList.value = await (await useDictionary('customer_purchasing_power')).data.dictionary
const loadCustomerResourcesList = (page: number = 1) => { }
customerResourcesTable.loading = true purchasing_powerDictList();
customerResourcesTable.page = page const cognitive_ideaList = ref([] as any[])
const cognitive_ideaDictList = async () => {
getCustomerResourcesList({ cognitive_ideaList.value = await (await useDictionary('cognitive_concept')).data.dictionary
page: customerResourcesTable.page, }
limit: customerResourcesTable.limit, cognitive_ideaDictList();
...customerResourcesTable.searchParam, const initial_intentList = ref([] as any[])
}) const initial_intentDictList = async () => {
.then((res) => { initial_intentList.value = await (await useDictionary('preliminarycustomerintention')).data.dictionary
customerResourcesTable.loading = false }
customerResourcesTable.data = res.data.data initial_intentDictList();
customerResourcesTable.total = res.data.total const statusList = ref([] as any[])
}) const statusDictList = async () => {
.catch(() => { statusList.value = await (await useDictionary('kh_status')).data.dictionary
customerResourcesTable.loading = false }
}) statusDictList();
}
loadCustomerResourcesList()
/**
const editCustomerResourcesDialog: Record<string, any> | null = ref(null) * 获取客户资源列表
*/
const fpCustomerResourcesDialog: Record<string, any> | null = ref(null) const loadCustomerResourcesList = (page : number = 1) => {
customerResourcesTable.loading = true
/** customerResourcesTable.page = page
* 添加客户资源
*/ getCustomerResourcesList({
const addEvent = () => { page: customerResourcesTable.page,
editCustomerResourcesDialog.value.setFormData() limit: customerResourcesTable.limit,
editCustomerResourcesDialog.value.showDialog = true ...customerResourcesTable.searchParam
} }).then(res => {
customerResourcesTable.loading = false
/** customerResourcesTable.data = res.data.data
* 编辑客户资源 customerResourcesTable.total = res.data.total
* @param data }).catch(() => {
*/ customerResourcesTable.loading = false
const editEvent = (data: any) => { })
editCustomerResourcesDialog.value.setFormData(data) }
editCustomerResourcesDialog.value.showDialog = true loadCustomerResourcesList()
}
const editCustomerResourcesDialog : Record<string, any> | null = ref(null)
const fpEvent = (data: any) => {
fpCustomerResourcesDialog.value.setFormData(data) const fpCustomerResourcesDialog : Record<string, any> | null = ref(null)
fpCustomerResourcesDialog.value.showDialog = true
} /**
* 添加客户资源
/** */
* 删除客户资源 const addEvent = () => {
*/ editCustomerResourcesDialog.value.setFormData()
const deleteEvent = (id: number) => { editCustomerResourcesDialog.value.showDialog = true
ElMessageBox.confirm(t('customerResourcesDeleteTips'), t('warning'), { }
confirmButtonText: t('confirm'),
cancelButtonText: t('cancel'), /**
type: 'warning', * 编辑客户资源
}).then(() => { * @param data
deleteCustomerResources(id) */
.then(() => { const editEvent = (data : any) => {
loadCustomerResourcesList() editCustomerResourcesDialog.value.setFormData(data)
}) editCustomerResourcesDialog.value.showDialog = true
.catch(() => {}) }
})
} const fpEvent = (data : any) => {
fpCustomerResourcesDialog.value.setFormData(data)
const consultantList = ref([]) fpCustomerResourcesDialog.value.showDialog = true
const setConsultantList = async () => { }
consultantList.value = await (await getWithPersonnelList({})).data
}
setConsultantList() /**
const campusList = ref([]) * 删除客户资源
const setCampusList = async () => { */
campusList.value = await (await getWithCampusList({})).data const deleteEvent = (id : number) => {
} ElMessageBox.confirm(t('customerResourcesDeleteTips'), t('warning'),
setCampusList() {
confirmButtonText: t('confirm'),
const resetForm = (formEl: FormInstance | undefined) => { cancelButtonText: t('cancel'),
if (!formEl) return type: 'warning',
formEl.resetFields() }
loadCustomerResourcesList() ).then(() => {
} deleteCustomerResources(id).then(() => {
loadCustomerResourcesList()
}).catch(() => {
})
})
}
const consultantList = ref([])
const setConsultantList = async () => {
consultantList.value = await (await getWithPersonnelList({})).data
}
setConsultantList()
const campusList = ref([])
const setCampusList = async () => {
campusList.value = await (await getWithCampusList({})).data
}
setCampusList()
const resetForm = (formEl : FormInstance | undefined) => {
if (!formEl) return
formEl.resetFields()
loadCustomerResourcesList()
}
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
/* 多行超出隐藏 */ /* 多行超出隐藏 */
.multi-hidden { .multi-hidden {
word-break: break-all; word-break: break-all;
text-overflow: ellipsis; text-overflow: ellipsis;
overflow: hidden; overflow: hidden;
display: -webkit-box; display: -webkit-box;
-webkit-line-clamp: 2; -webkit-line-clamp: 2;
-webkit-box-orient: vertical; -webkit-box-orient: vertical;
} }
</style> </style>

610
admin/src/app/views/order_table/components/order-table-edit.vue

@ -1,343 +1,267 @@
<template> <template>
<el-dialog <el-dialog v-model="showDialog" :title="formData.id ? t('updateOrderTable') : t('addOrderTable')" width="50%" class="diy-dialog-wrap" :destroy-on-close="true">
v-model="showDialog" <el-form :model="formData" label-width="120px" ref="formRef" :rules="formRules" class="page-form" v-loading="loading">
:title="formData.id ? t('updateOrderTable') : t('addOrderTable')" <el-form-item :label="t('resourceId')" prop="resource_id">
width="50%" <el-select class="input-width" v-model="formData.resource_id" clearable :placeholder="t('resourceIdPlaceholder')">
class="diy-dialog-wrap" <el-option label="请选择" value=""></el-option>
:destroy-on-close="true" <el-option
> v-for="(item, index) in resourceIdList"
<el-form :key="index"
:model="formData" :label="item['name']"
label-width="120px" :value="item['id']"
ref="formRef" />
:rules="formRules" </el-select>
class="page-form" </el-form-item>
v-loading="loading"
> <el-form-item :label="t('orderStatus')" prop="order_status">
<el-form-item :label="t('paymentId')" prop="payment_id"> <el-select class="input-width" v-model="formData.order_status" clearable :placeholder="t('orderStatusPlaceholder')">
<el-input <el-option label="请选择" value=""></el-option>
v-model="formData.payment_id" <el-option
clearable v-for="(item, index) in order_statusList"
:placeholder="t('paymentIdPlaceholder')" :key="index"
class="input-width" :label="item.name"
/> :value="item.value"
</el-form-item> />
</el-select>
<el-form-item :label="t('orderStatus')" prop="order_status"> </el-form-item>
<el-input
v-model="formData.order_status" <el-form-item :label="t('paymentType')" prop="payment_type">
clearable <el-select class="input-width" v-model="formData.payment_type" clearable :placeholder="t('paymentTypePlaceholder')">
:placeholder="t('orderStatusPlaceholder')" <el-option label="请选择" value=""></el-option>
class="input-width" <el-option
/> v-for="(item, index) in payment_typeList"
</el-form-item> :key="index"
:label="item.name"
<el-form-item :label="t('paymentType')" prop="payment_type"> :value="item.value"
<el-input />
v-model="formData.payment_type" </el-select>
clearable </el-form-item>
:placeholder="t('paymentTypePlaceholder')"
class="input-width" <el-form-item :label="t('orderAmount')" prop="order_amount">
/> <el-input v-model="formData.order_amount" clearable :placeholder="t('orderAmountPlaceholder')" class="input-width" />
</el-form-item> </el-form-item>
<el-form-item :label="t('orderAmount')" prop="order_amount"> <el-form-item :label="t('courseId')" prop="course_id">
<el-input <el-select class="input-width" v-model="formData.course_id" clearable :placeholder="t('courseIdPlaceholder')">
v-model="formData.order_amount" <el-option label="请选择" value=""></el-option>
clearable <el-option
:placeholder="t('orderAmountPlaceholder')" v-for="(item, index) in courseIdList"
class="input-width" :key="index"
/> :label="item['course_name']"
</el-form-item> :value="item['id']"
/>
<el-form-item :label="t('courseId')" prop="course_id"> </el-select>
<el-input </el-form-item>
v-model="formData.course_id"
clearable <el-form-item :label="t('classId')" prop="class_id">
:placeholder="t('courseIdPlaceholder')" <el-select class="input-width" v-model="formData.class_id" clearable :placeholder="t('classIdPlaceholder')">
class="input-width" <el-option label="请选择" value=""></el-option>
/> <el-option
</el-form-item> v-for="(item, index) in classIdList"
:key="index"
<el-form-item :label="t('classId')" prop="class_id"> :label="item['class_name']"
<el-input :value="item['id']"
v-model="formData.class_id" />
clearable </el-select>
:placeholder="t('classIdPlaceholder')" </el-form-item>
class="input-width"
/> </el-form>
</el-form-item>
<template #footer>
<el-form-item :label="t('staffId')" prop="staff_id"> <span class="dialog-footer">
<el-input <el-button @click="showDialog = false">{{ t('cancel') }}</el-button>
v-model="formData.staff_id" <el-button type="primary" :loading="loading" @click="confirm(formRef)">{{
clearable t('confirm')
:placeholder="t('staffIdPlaceholder')" }}</el-button>
class="input-width" </span>
/> </template>
</el-form-item> </el-dialog>
</template>
<el-form-item :label="t('resourceId')" prop="resource_id">
<el-input <script lang="ts" setup>
v-model="formData.resource_id" import { ref, reactive, computed, watch } from 'vue'
clearable import { useDictionary } from '@/app/api/dict'
:placeholder="t('resourceIdPlaceholder')" import { t } from '@/lang'
class="input-width" import type { FormInstance } from 'element-plus'
/> import { addOrderTable, editOrderTable, getOrderTableInfo, getWithCustomerResourcesList, getWithCourseList, getWithClassGradeList, getWithPersonnelList } from '@/app/api/order_table'
</el-form-item>
let showDialog = ref(false)
<el-form-item :label="t('afterSalesStatus')"> const loading = ref(false)
<el-input
v-model="formData.after_sales_status" /**
clearable * 表单数据
:placeholder="t('afterSalesStatusPlaceholder')" */
class="input-width" const initialFormData = {
/> id: '',
</el-form-item> resource_id: '',
order_status: '',
<el-form-item :label="t('afterSalesReason')"> payment_type: '',
<el-input order_amount: '',
v-model="formData.after_sales_reason" course_id: '',
clearable class_id: '',
:placeholder="t('afterSalesReasonPlaceholder')" }
class="input-width" const formData: Record<string, any> = reactive({ ...initialFormData })
/>
</el-form-item> const formRef = ref<FormInstance>()
<el-form-item :label="t('afterSalesTime')"> //
<el-input const formRules = computed(() => {
v-model="formData.after_sales_time" return {
clearable resource_id: [
:placeholder="t('afterSalesTimePlaceholder')" { required: true, message: t('resourceIdPlaceholder'), trigger: 'blur' },
class="input-width"
/> ]
</el-form-item> ,
order_status: [
<el-form-item :label="t('paymentTime')"> { required: true, message: t('orderStatusPlaceholder'), trigger: 'blur' },
<el-input
v-model="formData.payment_time" ]
clearable ,
:placeholder="t('paymentTimePlaceholder')" payment_type: [
class="input-width" { required: true, message: t('paymentTypePlaceholder'), trigger: 'blur' },
/>
</el-form-item> ]
,
<el-form-item :label="t('subscriptionPaymentTime')"> order_amount: [
<el-input { required: true, message: t('orderAmountPlaceholder'), trigger: 'blur' },
v-model="formData.subscription_payment_time"
clearable ]
:placeholder="t('subscriptionPaymentTimePlaceholder')" ,
class="input-width" course_id: [
/> { required: true, message: t('courseIdPlaceholder'), trigger: 'blur' },
</el-form-item>
</el-form> ]
,
<template #footer> class_id: [
<span class="dialog-footer"> { required: true, message: t('classIdPlaceholder'), trigger: 'blur' },
<el-button @click="showDialog = false">{{ t('cancel') }}</el-button>
<el-button ]
type="primary" ,
:loading="loading" }
@click="confirm(formRef)" })
>{{ t('confirm') }}</el-button
> const emit = defineEmits(['complete'])
</span>
</template> /**
</el-dialog> * 确认
</template> * @param formEl
*/
<script lang="ts" setup> const confirm = async (formEl: FormInstance | undefined) => {
import { ref, reactive, computed, watch } from 'vue' if (loading.value || !formEl) return
import { useDictionary } from '@/app/api/dict' let save = formData.id ? editOrderTable : addOrderTable
import { t } from '@/lang'
import type { FormInstance } from 'element-plus' await formEl.validate(async (valid) => {
import { if (valid) {
addOrderTable, loading.value = true
editOrderTable,
getOrderTableInfo, let data = formData
} from '@/app/api/order_table'
save(data).then(res => {
let showDialog = ref(false) loading.value = false
const loading = ref(false) showDialog.value = false
emit('complete')
/** }).catch(err => {
* 表单数据 loading.value = false
*/ })
const initialFormData = { }
id: '', })
payment_id: '', }
order_status: '',
payment_type: '', //
order_amount: '', let order_statusList = ref([])
course_id: '', const order_statusDictList = async () => {
class_id: '', order_statusList.value = await (await useDictionary('order_status')).data.dictionary
staff_id: '', }
resource_id: '', order_statusDictList();
after_sales_status: '', watch(() => order_statusList.value, () => { formData.order_status = order_statusList.value[0].value })
after_sales_reason: '', let payment_typeList = ref([])
after_sales_time: '', const payment_typeDictList = async () => {
payment_time: '', payment_typeList.value = await (await useDictionary('payment_type')).data.dictionary
subscription_payment_time: '', }
} payment_typeDictList();
const formData: Record<string, any> = reactive({ ...initialFormData }) watch(() => payment_typeList.value, () => { formData.payment_type = payment_typeList.value[0].value })
const formRef = ref<FormInstance>()
const resourceIdList = ref([] as any[])
// const setResourceIdList = async () => {
const formRules = computed(() => { resourceIdList.value = await (await getWithCustomerResourcesList({})).data
return { }
payment_id: [ setResourceIdList()
{ required: true, message: t('paymentIdPlaceholder'), trigger: 'blur' }, const courseIdList = ref([] as any[])
], const setCourseIdList = async () => {
order_status: [ courseIdList.value = await (await getWithCourseList({})).data
{ required: true, message: t('orderStatusPlaceholder'), trigger: 'blur' }, }
], setCourseIdList()
payment_type: [ const classIdList = ref([] as any[])
{ required: true, message: t('paymentTypePlaceholder'), trigger: 'blur' }, const setClassIdList = async () => {
], classIdList.value = await (await getWithClassGradeList({})).data
order_amount: [ }
{ required: true, message: t('orderAmountPlaceholder'), trigger: 'blur' }, setClassIdList()
], const staffIdList = ref([] as any[])
course_id: [ const setStaffIdList = async () => {
{ required: true, message: t('courseIdPlaceholder'), trigger: 'blur' }, staffIdList.value = await (await getWithPersonnelList({})).data
], }
class_id: [ setStaffIdList()
{ required: true, message: t('classIdPlaceholder'), trigger: 'blur' }, const setFormData = async (row: any = null) => {
], Object.assign(formData, initialFormData)
staff_id: [ Object.assign(formData, row)
{ required: true, message: t('staffIdPlaceholder'), trigger: 'blur' }, // formData.resource_id = row.resource_id;
], // console.log(0)
resource_id: [ // loading.value = true
{ required: true, message: t('resourceIdPlaceholder'), trigger: 'blur' }, // if(row){
], // const data = await (await getOrderTableInfo(row.id)).data
after_sales_status: [ // if (data) Object.keys(formData).forEach((key: string) => {
{ // if (data[key] != undefined) formData[key] = data[key]
required: true, // })
message: t('afterSalesStatusPlaceholder'), // }
trigger: 'blur', // loading.value = false
}, }
],
after_sales_reason: [ //
{ const mobileVerify = (rule: any, value: any, callback: any) => {
required: true, if (value && !/^1[3-9]\d{9}$/.test(value)) {
message: t('afterSalesReasonPlaceholder'), callback(new Error(t('generateMobile')))
trigger: 'blur', } else {
}, callback()
], }
after_sales_time: [ }
{
required: true, //
message: t('afterSalesTimePlaceholder'), const idCardVerify = (rule: any, value: any, callback: any) => {
trigger: 'blur', if (value && !/^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/.test(value)) {
}, callback(new Error(t('generateIdCard')))
], } else {
payment_time: [ callback()
{ required: true, message: t('paymentTimePlaceholder'), trigger: 'blur' }, }
], }
subscription_payment_time: [
{ //
required: true, const emailVerify = (rule: any, value: any, callback: any) => {
message: t('subscriptionPaymentTimePlaceholder'), if (value && !/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/.test(value)) {
trigger: 'blur', callback(new Error(t('generateEmail')))
}, } else {
], callback()
} }
}) }
const emit = defineEmits(['complete']) //
const numberVerify = (rule: any, value: any, callback: any) => {
/** if (!Number.isInteger(value)) {
* 确认 callback(new Error(t('generateNumber')))
* @param formEl } else {
*/ callback()
const confirm = async (formEl: FormInstance | undefined) => { }
if (loading.value || !formEl) return }
let save = formData.id ? editOrderTable : addOrderTable
defineExpose({
await formEl.validate(async (valid) => { showDialog,
if (valid) { setFormData
loading.value = true })
</script>
let data = formData
<style lang="scss" scoped></style>
save(data) <style lang="scss">
.then((res) => { .diy-dialog-wrap .el-form-item__label{
loading.value = false height: auto !important;
showDialog.value = false }
emit('complete') </style>
})
.catch((err) => {
loading.value = false
})
}
})
}
//
const setFormData = async (row: any = null) => {
Object.assign(formData, initialFormData)
loading.value = true
if (row) {
const data = await (await getOrderTableInfo(row.id)).data
if (data)
Object.keys(formData).forEach((key: string) => {
if (data[key] != undefined) formData[key] = data[key]
})
}
loading.value = false
}
//
const mobileVerify = (rule: any, value: any, callback: any) => {
if (value && !/^1[3-9]\d{9}$/.test(value)) {
callback(new Error(t('generateMobile')))
} else {
callback()
}
}
//
const idCardVerify = (rule: any, value: any, callback: any) => {
if (
value &&
!/^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/.test(
value
)
) {
callback(new Error(t('generateIdCard')))
} else {
callback()
}
}
//
const emailVerify = (rule: any, value: any, callback: any) => {
if (value && !/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/.test(value)) {
callback(new Error(t('generateEmail')))
} else {
callback()
}
}
//
const numberVerify = (rule: any, value: any, callback: any) => {
if (!Number.isInteger(value)) {
callback(new Error(t('generateNumber')))
} else {
callback()
}
}
defineExpose({
showDialog,
setFormData,
})
</script>
<style lang="scss" scoped></style>
<style lang="scss">
.diy-dialog-wrap .el-form-item__label {
height: auto !important;
}
</style>

607
admin/src/app/views/order_table/order_table.vue

@ -1,369 +1,238 @@
<template> <template>
<div class="main-container"> <div class="main-container">
<el-card class="box-card !border-none" shadow="never"> <el-card class="box-card !border-none" shadow="never">
<div class="flex justify-between items-center">
<span class="text-lg">{{ pageName }}</span> <div class="flex justify-between items-center">
<el-button type="primary" @click="addEvent"> <span class="text-lg">{{pageName}}</span>
{{ t('addOrderTable') }} <el-button type="primary" @click="addEvent">
</el-button> {{ t('addOrderTable') }}
</div> </el-button>
</div>
<el-card
class="box-card !border-none my-[10px] table-search-wrap" <el-card class="box-card !border-none my-[10px] table-search-wrap" shadow="never">
shadow="never" <el-form :inline="true" :model="orderTableTable.searchParam" ref="searchFormRef">
>
<el-form <el-form-item :label="t('orderStatus')" prop="order_status">
:inline="true" <el-select class="w-[280px]" v-model="orderTableTable.searchParam.order_status" clearable :placeholder="t('orderStatusPlaceholder')">
:model="orderTableTable.searchParam" <el-option label="全部" value=""></el-option>
ref="searchFormRef" <el-option
> v-for="(item, index) in order_statusList"
<el-form-item :label="t('paymentId')" prop="payment_id"> :key="index"
<el-input :label="item.name"
v-model="orderTableTable.searchParam.payment_id" :value="item.value"
:placeholder="t('paymentIdPlaceholder')" />
/> </el-select>
</el-form-item> </el-form-item>
<el-form-item :label="t('orderStatus')" prop="order_status">
<el-input
v-model="orderTableTable.searchParam.order_status" <el-form-item :label="t('paymentType')" prop="payment_type">
:placeholder="t('orderStatusPlaceholder')" <el-select class="w-[280px]" v-model="orderTableTable.searchParam.payment_type" clearable :placeholder="t('paymentTypePlaceholder')">
/> <el-option label="全部" value=""></el-option>
</el-form-item> <el-option
<el-form-item :label="t('paymentType')" prop="payment_type"> v-for="(item, index) in payment_typeList"
<el-input :key="index"
v-model="orderTableTable.searchParam.payment_type" :label="item.name"
:placeholder="t('paymentTypePlaceholder')" :value="item.value"
/> />
</el-form-item> </el-select>
<el-form-item :label="t('orderAmount')" prop="order_amount"> </el-form-item>
<el-input
v-model="orderTableTable.searchParam.order_amount" <el-form-item>
:placeholder="t('orderAmountPlaceholder')" <el-button type="primary" @click="loadOrderTableList()">{{ t('search') }}</el-button>
/> <el-button @click="resetForm(searchFormRef)">{{ t('reset') }}</el-button>
</el-form-item> </el-form-item>
<el-form-item :label="t('courseId')" prop="course_id"> </el-form>
<el-input </el-card>
v-model="orderTableTable.searchParam.course_id"
:placeholder="t('courseIdPlaceholder')" <div class="mt-[10px]">
/> <el-table :data="orderTableTable.data" size="large" v-loading="orderTableTable.loading">
</el-form-item> <template #empty>
<el-form-item :label="t('classId')" prop="class_id"> <span>{{ !orderTableTable.loading ? t('emptyData') : '' }}</span>
<el-input </template>
v-model="orderTableTable.searchParam.class_id" <el-table-column prop="resource_id_name" :label="t('resourceId')" min-width="120" :show-overflow-tooltip="true"/>
:placeholder="t('classIdPlaceholder')"
/> <el-table-column :label="t('orderStatus')" min-width="180" align="center" :show-overflow-tooltip="true">
</el-form-item> <template #default="{ row }">
<el-form-item :label="t('staffId')" prop="staff_id"> <div v-for="(item, index) in order_statusList">
<el-input <div v-if="item.value == row.order_status">{{ item.name }}</div>
v-model="orderTableTable.searchParam.staff_id" </div>
:placeholder="t('staffIdPlaceholder')" </template>
/> </el-table-column>
</el-form-item>
<el-form-item :label="t('resourceId')" prop="resource_id"> <el-table-column :label="t('paymentType')" min-width="180" align="center" :show-overflow-tooltip="true">
<el-input <template #default="{ row }">
v-model="orderTableTable.searchParam.resource_id" <div v-for="(item, index) in payment_typeList">
:placeholder="t('resourceIdPlaceholder')" <div v-if="item.value == row.payment_type">{{ item.name }}</div>
/> </div>
</el-form-item> </template>
<el-form-item </el-table-column>
:label="t('afterSalesStatus')"
prop="after_sales_status" <el-table-column prop="order_amount" :label="t('orderAmount')" min-width="120" :show-overflow-tooltip="true"/>
>
<el-input <el-table-column prop="course_id_name" :label="t('courseId')" min-width="120" :show-overflow-tooltip="true"/>
v-model="orderTableTable.searchParam.after_sales_status"
:placeholder="t('afterSalesStatusPlaceholder')" <el-table-column prop="class_id_name" :label="t('classId')" min-width="120" :show-overflow-tooltip="true"/>
/>
</el-form-item> <el-table-column prop="staff_id_name" :label="t('staffId')" min-width="120" :show-overflow-tooltip="true"/>
<el-form-item
:label="t('afterSalesReason')" <el-table-column prop="payment_time" :label="t('paymentTime')" min-width="120" :show-overflow-tooltip="true"/>
prop="after_sales_reason"
> <el-table-column :label="t('operation')" fixed="right" min-width="120">
<el-input <template #default="{ row }">
v-model="orderTableTable.searchParam.after_sales_reason" <el-button type="primary" link @click="editEvent(row)">{{ t('edit') }}</el-button>
:placeholder="t('afterSalesReasonPlaceholder')" <el-button type="primary" link @click="deleteEvent(row.id)">{{ t('delete') }}</el-button>
/> </template>
</el-form-item> </el-table-column>
<el-form-item :label="t('afterSalesTime')" prop="after_sales_time">
<el-input </el-table>
v-model="orderTableTable.searchParam.after_sales_time" <div class="mt-[16px] flex justify-end">
:placeholder="t('afterSalesTimePlaceholder')" <el-pagination v-model:current-page="orderTableTable.page" v-model:page-size="orderTableTable.limit"
/> layout="total, sizes, prev, pager, next, jumper" :total="orderTableTable.total"
</el-form-item> @size-change="loadOrderTableList()" @current-change="loadOrderTableList" />
<el-form-item :label="t('paymentTime')" prop="payment_time"> </div>
<el-input </div>
v-model="orderTableTable.searchParam.payment_time"
:placeholder="t('paymentTimePlaceholder')" <edit ref="editOrderTableDialog" @complete="loadOrderTableList" />
/> </el-card>
</el-form-item> </div>
<el-form-item </template>
:label="t('subscriptionPaymentTime')"
prop="subscription_payment_time" <script lang="ts" setup>
> import { reactive, ref, watch } from 'vue'
<el-input import { t } from '@/lang'
v-model="orderTableTable.searchParam.subscription_payment_time" import { useDictionary } from '@/app/api/dict'
:placeholder="t('subscriptionPaymentTimePlaceholder')" import { getOrderTableList, deleteOrderTable, getWithCustomerResourcesList, getWithCourseList, getWithClassGradeList, getWithPersonnelList } from '@/app/api/order_table'
/> import { img } from '@/utils/common'
</el-form-item> import { ElMessageBox,FormInstance } from 'element-plus'
import Edit from '@/app/views/order_table/components/order-table-edit.vue'
<el-form-item> import { useRoute } from 'vue-router'
<el-button type="primary" @click="loadOrderTableList()">{{ const route = useRoute()
t('search') const pageName = route.meta.title;
}}</el-button>
<el-button @click="resetForm(searchFormRef)">{{ let orderTableTable = reactive({
t('reset') page: 1,
}}</el-button> limit: 10,
</el-form-item> total: 0,
</el-form> loading: true,
</el-card> data: [],
searchParam:{
<div class="mt-[10px]"> "order_status":"",
<el-table "payment_type":""
:data="orderTableTable.data" }
size="large" })
v-loading="orderTableTable.loading"
> const searchFormRef = ref<FormInstance>()
<template #empty>
<span>{{ !orderTableTable.loading ? t('emptyData') : '' }}</span> //
</template> const selectData = ref<any[]>([])
<el-table-column
prop="payment_id" //
:label="t('paymentId')" const order_statusList = ref([] as any[])
min-width="120" const order_statusDictList = async () => {
:show-overflow-tooltip="true" order_statusList.value = await (await useDictionary('order_status')).data.dictionary
/> }
order_statusDictList();
<el-table-column const payment_typeList = ref([] as any[])
prop="order_status" const payment_typeDictList = async () => {
:label="t('orderStatus')" payment_typeList.value = await (await useDictionary('payment_type')).data.dictionary
min-width="120" }
:show-overflow-tooltip="true" payment_typeDictList();
/>
/**
<el-table-column * 获取订单列表
prop="payment_type" */
:label="t('paymentType')" const loadOrderTableList = (page: number = 1) => {
min-width="120" orderTableTable.loading = true
:show-overflow-tooltip="true" orderTableTable.page = page
/>
getOrderTableList({
<el-table-column page: orderTableTable.page,
prop="order_amount" limit: orderTableTable.limit,
:label="t('orderAmount')" ...orderTableTable.searchParam
min-width="120" }).then(res => {
:show-overflow-tooltip="true" orderTableTable.loading = false
/> orderTableTable.data = res.data.data
orderTableTable.total = res.data.total
<el-table-column }).catch(() => {
prop="course_id" orderTableTable.loading = false
:label="t('courseId')" })
min-width="120" }
:show-overflow-tooltip="true" loadOrderTableList()
/>
const editOrderTableDialog: Record<string, any> | null = ref(null)
<el-table-column
prop="class_id" /**
:label="t('classId')" * 添加订单
min-width="120" */
:show-overflow-tooltip="true" const addEvent = () => {
/> editOrderTableDialog.value.setFormData()
editOrderTableDialog.value.showDialog = true
<el-table-column }
prop="staff_id"
:label="t('staffId')" /**
min-width="120" * 编辑订单
:show-overflow-tooltip="true" * @param data
/> */
const editEvent = (data: any) => {
<el-table-column editOrderTableDialog.value.setFormData(data)
prop="resource_id" editOrderTableDialog.value.showDialog = true
:label="t('resourceId')" }
min-width="120"
:show-overflow-tooltip="true" /**
/> * 删除订单
*/
<el-table-column const deleteEvent = (id: number) => {
prop="after_sales_status" ElMessageBox.confirm(t('orderTableDeleteTips'), t('warning'),
:label="t('afterSalesStatus')" {
min-width="120" confirmButtonText: t('confirm'),
:show-overflow-tooltip="true" cancelButtonText: t('cancel'),
/> type: 'warning',
}
<el-table-column ).then(() => {
prop="after_sales_reason" deleteOrderTable(id).then(() => {
:label="t('afterSalesReason')" loadOrderTableList()
min-width="120" }).catch(() => {
:show-overflow-tooltip="true" })
/> })
}
<el-table-column
prop="after_sales_time"
:label="t('afterSalesTime')" const resourceIdList = ref([])
min-width="120" const setResourceIdList = async () => {
:show-overflow-tooltip="true" resourceIdList.value = await (await getWithCustomerResourcesList({})).data
/> }
setResourceIdList()
<el-table-column const courseIdList = ref([])
prop="payment_time" const setCourseIdList = async () => {
:label="t('paymentTime')" courseIdList.value = await (await getWithCourseList({})).data
min-width="120" }
:show-overflow-tooltip="true" setCourseIdList()
/> const classIdList = ref([])
const setClassIdList = async () => {
<el-table-column classIdList.value = await (await getWithClassGradeList({})).data
prop="subscription_payment_time" }
:label="t('subscriptionPaymentTime')" setClassIdList()
min-width="120" const staffIdList = ref([])
:show-overflow-tooltip="true" const setStaffIdList = async () => {
/> staffIdList.value = await (await getWithPersonnelList({})).data
}
<el-table-column setStaffIdList()
:label="t('operation')"
fixed="right" const resetForm = (formEl: FormInstance | undefined) => {
min-width="120" if (!formEl) return
> formEl.resetFields()
<template #default="{ row }"> loadOrderTableList()
<el-button type="primary" link @click="editEvent(row)">{{ }
t('edit') </script>
}}</el-button>
<el-button type="primary" link @click="deleteEvent(row.id)">{{ <style lang="scss" scoped>
t('delete') /* 多行超出隐藏 */
}}</el-button> .multi-hidden {
</template> word-break: break-all;
</el-table-column> text-overflow: ellipsis;
</el-table> overflow: hidden;
<div class="mt-[16px] flex justify-end"> display: -webkit-box;
<el-pagination -webkit-line-clamp: 2;
v-model:current-page="orderTableTable.page" -webkit-box-orient: vertical;
v-model:page-size="orderTableTable.limit" }
layout="total, sizes, prev, pager, next, jumper" </style>
:total="orderTableTable.total"
@size-change="loadOrderTableList()"
@current-change="loadOrderTableList"
/>
</div>
</div>
<edit ref="editOrderTableDialog" @complete="loadOrderTableList" />
</el-card>
</div>
</template>
<script lang="ts" setup>
import { reactive, ref, watch } from 'vue'
import { t } from '@/lang'
import { useDictionary } from '@/app/api/dict'
import { getOrderTableList, deleteOrderTable } from '@/app/api/order_table'
import { img } from '@/utils/common'
import { ElMessageBox, FormInstance } from 'element-plus'
import Edit from '@/app/views/order_table/components/order-table-edit.vue'
import { useRoute } from 'vue-router'
const route = useRoute()
const pageName = route.meta.title
let orderTableTable = reactive({
page: 1,
limit: 10,
total: 0,
loading: true,
data: [],
searchParam: {
payment_id: '',
order_status: '',
payment_type: '',
order_amount: '',
course_id: '',
class_id: '',
staff_id: '',
resource_id: '',
after_sales_status: '',
after_sales_reason: '',
after_sales_time: '',
payment_time: '',
subscription_payment_time: '',
},
})
const searchFormRef = ref<FormInstance>()
//
const selectData = ref<any[]>([])
//
/**
* 获取订单列表
*/
const loadOrderTableList = (page: number = 1) => {
orderTableTable.loading = true
orderTableTable.page = page
getOrderTableList({
page: orderTableTable.page,
limit: orderTableTable.limit,
...orderTableTable.searchParam,
})
.then((res) => {
orderTableTable.loading = false
orderTableTable.data = res.data.data
orderTableTable.total = res.data.total
})
.catch(() => {
orderTableTable.loading = false
})
}
loadOrderTableList()
const editOrderTableDialog: Record<string, any> | null = ref(null)
/**
* 添加订单
*/
const addEvent = () => {
editOrderTableDialog.value.setFormData()
editOrderTableDialog.value.showDialog = true
}
/**
* 编辑订单
* @param data
*/
const editEvent = (data: any) => {
editOrderTableDialog.value.setFormData(data)
editOrderTableDialog.value.showDialog = true
}
/**
* 删除订单
*/
const deleteEvent = (id: number) => {
ElMessageBox.confirm(t('orderTableDeleteTips'), t('warning'), {
confirmButtonText: t('confirm'),
cancelButtonText: t('cancel'),
type: 'warning',
}).then(() => {
deleteOrderTable(id)
.then(() => {
loadOrderTableList()
})
.catch(() => {})
})
}
const resetForm = (formEl: FormInstance | undefined) => {
if (!formEl) return
formEl.resetFields()
loadOrderTableList()
}
</script>
<style lang="scss" scoped>
/* 多行超出隐藏 */
.multi-hidden {
word-break: break-all;
text-overflow: ellipsis;
overflow: hidden;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
}
</style>

723
admin/src/app/views/physical_test/components/physical-test-edit.vue

@ -1,399 +1,324 @@
<template> <template>
<el-dialog <el-dialog v-model="showDialog" :title="formData.id ? t('updatePhysicalTest') : t('addPhysicalTest')" width="50%" class="diy-dialog-wrap" :destroy-on-close="true">
v-model="showDialog" <el-form :model="formData" label-width="120px" ref="formRef" :rules="formRules" class="page-form" v-loading="loading">
:title="formData.id ? t('updatePhysicalTest') : t('addPhysicalTest')" <el-form-item :label="t('resourceId')" prop="resource_id">
width="50%" <el-select class="input-width" v-model="formData.resource_id" clearable :placeholder="t('resourceIdPlaceholder')">
class="diy-dialog-wrap" <el-option label="请选择" value=""></el-option>
:destroy-on-close="true" <el-option
> v-for="(item, index) in resourceIdList"
<el-form :key="index"
:model="formData" :label="item['name']"
label-width="120px" :value="item['id']"
ref="formRef" />
:rules="formRules" </el-select>
class="page-form" </el-form-item>
v-loading="loading"
> <el-form-item :label="t('studentId')" prop="student_id">
<el-form-item :label="t('resourceId')" prop="resource_id"> <el-select class="input-width" v-model="formData.student_id" clearable :placeholder="t('studentIdPlaceholder')">
<el-input <el-option label="请选择" value=""></el-option>
v-model="formData.resource_id" <el-option
clearable v-for="(item, index) in studentIdList"
:placeholder="t('resourceIdPlaceholder')" :key="index"
class="input-width" :label="item['name']"
/> :value="item['id']"
</el-form-item> />
</el-select>
<el-form-item :label="t('studentId')" prop="student_id"> </el-form-item>
<el-input
v-model="formData.student_id" <el-form-item :label="t('height')" prop="height">
clearable <el-input v-model="formData.height" clearable :placeholder="t('heightPlaceholder')" class="input-width" />
:placeholder="t('studentIdPlaceholder')" </el-form-item>
class="input-width"
/> <el-form-item :label="t('weight')" prop="weight">
</el-form-item> <el-input v-model="formData.weight" clearable :placeholder="t('weightPlaceholder')" class="input-width" />
</el-form-item>
<el-form-item :label="t('height')" prop="height">
<el-input <el-form-item :label="t('coachId')" prop="coach_id">
v-model="formData.height" <el-select class="input-width" v-model="formData.coach_id" clearable :placeholder="t('coachIdPlaceholder')">
clearable <el-option label="请选择" value=""></el-option>
:placeholder="t('heightPlaceholder')" <el-option
class="input-width" v-for="(item, index) in coachIdList"
/> :key="index"
</el-form-item> :label="item['name']"
:value="item['id']"
<el-form-item :label="t('weight')" prop="weight"> />
<el-input </el-select>
v-model="formData.weight" </el-form-item>
clearable
:placeholder="t('weightPlaceholder')" <el-form-item :label="t('seatedForwardBend')" >
class="input-width" <el-input v-model="formData.seated_forward_bend" clearable :placeholder="t('seatedForwardBendPlaceholder')" class="input-width" />
/> </el-form-item>
</el-form-item>
<el-form-item :label="t('sitUps')" >
<el-form-item :label="t('coachId')" prop="coach_id"> <el-input v-model="formData.sit_ups" clearable :placeholder="t('sitUpsPlaceholder')" class="input-width" />
<el-input </el-form-item>
v-model="formData.coach_id"
clearable <el-form-item :label="t('pushUps')" >
:placeholder="t('coachIdPlaceholder')" <el-input v-model="formData.push_ups" clearable :placeholder="t('pushUpsPlaceholder')" class="input-width" />
class="input-width" </el-form-item>
/>
</el-form-item> <el-form-item :label="t('flamingoBalance')" >
<el-input v-model="formData.flamingo_balance" clearable :placeholder="t('flamingoBalancePlaceholder')" class="input-width" />
<el-form-item :label="t('createdAt')"> </el-form-item>
<el-input
v-model="formData.created_at" <el-form-item :label="t('thirtySecJump')" >
clearable <el-input v-model="formData.thirty_sec_jump" clearable :placeholder="t('thirtySecJumpPlaceholder')" class="input-width" />
:placeholder="t('createdAtPlaceholder')" </el-form-item>
class="input-width"
/> <el-form-item :label="t('standingLongJump')" >
</el-form-item> <el-input v-model="formData.standing_long_jump" clearable :placeholder="t('standingLongJumpPlaceholder')" class="input-width" />
</el-form-item>
<el-form-item :label="t('updatedAt')">
<el-input <el-form-item :label="t('agilityRun')" >
v-model="formData.updated_at" <el-input v-model="formData.agility_run" clearable :placeholder="t('agilityRunPlaceholder')" class="input-width" />
clearable </el-form-item>
:placeholder="t('updatedAtPlaceholder')"
class="input-width" <el-form-item :label="t('balanceBeam')" >
/> <el-input v-model="formData.balance_beam" clearable :placeholder="t('balanceBeamPlaceholder')" class="input-width" />
</el-form-item> </el-form-item>
<el-form-item :label="t('seatedForwardBend')"> <el-form-item :label="t('tennisThrow')" >
<el-input <el-input v-model="formData.tennis_throw" clearable :placeholder="t('tennisThrowPlaceholder')" class="input-width" />
v-model="formData.seated_forward_bend" </el-form-item>
clearable
:placeholder="t('seatedForwardBendPlaceholder')" <el-form-item :label="t('tenMeterShuttleRun')" >
class="input-width" <el-input v-model="formData.ten_meter_shuttle_run" clearable :placeholder="t('tenMeterShuttleRunPlaceholder')" class="input-width" />
/> </el-form-item>
</el-form-item>
</el-form>
<el-form-item :label="t('sitUps')">
<el-input <template #footer>
v-model="formData.sit_ups" <span class="dialog-footer">
clearable <el-button @click="showDialog = false">{{ t('cancel') }}</el-button>
:placeholder="t('sitUpsPlaceholder')" <el-button type="primary" :loading="loading" @click="confirm(formRef)">{{
class="input-width" t('confirm')
/> }}</el-button>
</el-form-item> </span>
</template>
<el-form-item :label="t('pushUps')"> </el-dialog>
<el-input </template>
v-model="formData.push_ups"
clearable <script lang="ts" setup>
:placeholder="t('pushUpsPlaceholder')" import { ref, reactive, computed, watch } from 'vue'
class="input-width" import { useDictionary } from '@/app/api/dict'
/> import { t } from '@/lang'
</el-form-item> import type { FormInstance } from 'element-plus'
import { addPhysicalTest, editPhysicalTest, getPhysicalTestInfo, getWithCustomerResourcesList, getWithStudentList, getWithPersonnelList } from '@/app/api/physical_test'
<el-form-item :label="t('flamingoBalance')">
<el-input let showDialog = ref(false)
v-model="formData.flamingo_balance" const loading = ref(false)
clearable
:placeholder="t('flamingoBalancePlaceholder')" /**
class="input-width" * 表单数据
/> */
</el-form-item> const initialFormData = {
id: '',
<el-form-item :label="t('thirtySecJump')"> resource_id: '',
<el-input student_id: '',
v-model="formData.thirty_sec_jump" height: '',
clearable weight: '',
:placeholder="t('thirtySecJumpPlaceholder')" coach_id: '',
class="input-width" seated_forward_bend: '',
/> sit_ups: '',
</el-form-item> push_ups: '',
flamingo_balance: '',
<el-form-item :label="t('standingLongJump')"> thirty_sec_jump: '',
<el-input standing_long_jump: '',
v-model="formData.standing_long_jump" agility_run: '',
clearable balance_beam: '',
:placeholder="t('standingLongJumpPlaceholder')" tennis_throw: '',
class="input-width" ten_meter_shuttle_run: '',
/> }
</el-form-item> const formData: Record<string, any> = reactive({ ...initialFormData })
<el-form-item :label="t('agilityRun')"> const formRef = ref<FormInstance>()
<el-input
v-model="formData.agility_run" //
clearable const formRules = computed(() => {
:placeholder="t('agilityRunPlaceholder')" return {
class="input-width" resource_id: [
/> { required: true, message: t('resourceIdPlaceholder'), trigger: 'blur' },
</el-form-item>
]
<el-form-item :label="t('balanceBeam')"> ,
<el-input student_id: [
v-model="formData.balance_beam" { required: true, message: t('studentIdPlaceholder'), trigger: 'blur' },
clearable
:placeholder="t('balanceBeamPlaceholder')" ]
class="input-width" ,
/> height: [
</el-form-item> { required: true, message: t('heightPlaceholder'), trigger: 'blur' },
<el-form-item :label="t('tennisThrow')"> ]
<el-input ,
v-model="formData.tennis_throw" weight: [
clearable { required: true, message: t('weightPlaceholder'), trigger: 'blur' },
:placeholder="t('tennisThrowPlaceholder')"
class="input-width" ]
/> ,
</el-form-item> coach_id: [
{ required: true, message: t('coachIdPlaceholder'), trigger: 'blur' },
<el-form-item :label="t('tenMeterShuttleRun')">
<el-input ]
v-model="formData.ten_meter_shuttle_run" ,
clearable seated_forward_bend: [
:placeholder="t('tenMeterShuttleRunPlaceholder')" { required: true, message: t('seatedForwardBendPlaceholder'), trigger: 'blur' },
class="input-width"
/> ]
</el-form-item> ,
</el-form> sit_ups: [
{ required: true, message: t('sitUpsPlaceholder'), trigger: 'blur' },
<template #footer>
<span class="dialog-footer"> ]
<el-button @click="showDialog = false">{{ t('cancel') }}</el-button> ,
<el-button push_ups: [
type="primary" { required: true, message: t('pushUpsPlaceholder'), trigger: 'blur' },
:loading="loading"
@click="confirm(formRef)" ]
>{{ t('confirm') }}</el-button ,
> flamingo_balance: [
</span> { required: true, message: t('flamingoBalancePlaceholder'), trigger: 'blur' },
</template>
</el-dialog> ]
</template> ,
thirty_sec_jump: [
<script lang="ts" setup> { required: true, message: t('thirtySecJumpPlaceholder'), trigger: 'blur' },
import { ref, reactive, computed, watch } from 'vue'
import { useDictionary } from '@/app/api/dict' ]
import { t } from '@/lang' ,
import type { FormInstance } from 'element-plus' standing_long_jump: [
import { { required: true, message: t('standingLongJumpPlaceholder'), trigger: 'blur' },
addPhysicalTest,
editPhysicalTest, ]
getPhysicalTestInfo, ,
} from '@/app/api/physical_test' agility_run: [
{ required: true, message: t('agilityRunPlaceholder'), trigger: 'blur' },
let showDialog = ref(false)
const loading = ref(false) ]
,
/** balance_beam: [
* 表单数据 { required: true, message: t('balanceBeamPlaceholder'), trigger: 'blur' },
*/
const initialFormData = { ]
id: '', ,
resource_id: '', tennis_throw: [
student_id: '', { required: true, message: t('tennisThrowPlaceholder'), trigger: 'blur' },
height: '',
weight: '', ]
coach_id: '', ,
created_at: '', ten_meter_shuttle_run: [
updated_at: '', { required: true, message: t('tenMeterShuttleRunPlaceholder'), trigger: 'blur' },
seated_forward_bend: '',
sit_ups: '', ]
push_ups: '', ,
flamingo_balance: '', }
thirty_sec_jump: '', })
standing_long_jump: '',
agility_run: '', const emit = defineEmits(['complete'])
balance_beam: '',
tennis_throw: '', /**
ten_meter_shuttle_run: '', * 确认
} * @param formEl
const formData: Record<string, any> = reactive({ ...initialFormData }) */
const confirm = async (formEl: FormInstance | undefined) => {
const formRef = ref<FormInstance>() if (loading.value || !formEl) return
let save = formData.id ? editPhysicalTest : addPhysicalTest
//
const formRules = computed(() => { await formEl.validate(async (valid) => {
return { if (valid) {
resource_id: [ loading.value = true
{ required: true, message: t('resourceIdPlaceholder'), trigger: 'blur' },
], let data = formData
student_id: [
{ required: true, message: t('studentIdPlaceholder'), trigger: 'blur' }, save(data).then(res => {
], loading.value = false
height: [ showDialog.value = false
{ required: true, message: t('heightPlaceholder'), trigger: 'blur' }, emit('complete')
], }).catch(err => {
weight: [ loading.value = false
{ required: true, message: t('weightPlaceholder'), trigger: 'blur' }, })
], }
coach_id: [ })
{ required: true, message: t('coachIdPlaceholder'), trigger: 'blur' }, }
],
created_at: [ //
{ required: true, message: t('createdAtPlaceholder'), trigger: 'blur' },
],
updated_at: [
{ required: true, message: t('updatedAtPlaceholder'), trigger: 'blur' }, const resourceIdList = ref([] as any[])
], const setResourceIdList = async () => {
seated_forward_bend: [ resourceIdList.value = await (await getWithCustomerResourcesList({})).data
{ }
required: true, setResourceIdList()
message: t('seatedForwardBendPlaceholder'), const studentIdList = ref([] as any[])
trigger: 'blur', const setStudentIdList = async () => {
}, studentIdList.value = await (await getWithStudentList({})).data
], }
sit_ups: [ setStudentIdList()
{ required: true, message: t('sitUpsPlaceholder'), trigger: 'blur' }, const coachIdList = ref([] as any[])
], const setCoachIdList = async () => {
push_ups: [ coachIdList.value = await (await getWithPersonnelList({})).data
{ required: true, message: t('pushUpsPlaceholder'), trigger: 'blur' }, }
], setCoachIdList()
flamingo_balance: [ const setFormData = async (row: any = null) => {
{ Object.assign(formData, initialFormData)
required: true, loading.value = true
message: t('flamingoBalancePlaceholder'),
trigger: 'blur', Object.assign(formData, row)
}, // if(row){
], // const data = await (await getPhysicalTestInfo(row.id)).data
thirty_sec_jump: [ // if (data) Object.keys(formData).forEach((key: string) => {
{ // if (data[key] != undefined) formData[key] = data[key]
required: true, // })
message: t('thirtySecJumpPlaceholder'), // }
trigger: 'blur', loading.value = false
}, }
],
standing_long_jump: [ //
{ const mobileVerify = (rule: any, value: any, callback: any) => {
required: true, if (value && !/^1[3-9]\d{9}$/.test(value)) {
message: t('standingLongJumpPlaceholder'), callback(new Error(t('generateMobile')))
trigger: 'blur', } else {
}, callback()
], }
agility_run: [ }
{ required: true, message: t('agilityRunPlaceholder'), trigger: 'blur' },
], //
balance_beam: [ const idCardVerify = (rule: any, value: any, callback: any) => {
{ required: true, message: t('balanceBeamPlaceholder'), trigger: 'blur' }, if (value && !/^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/.test(value)) {
], callback(new Error(t('generateIdCard')))
tennis_throw: [ } else {
{ required: true, message: t('tennisThrowPlaceholder'), trigger: 'blur' }, callback()
], }
ten_meter_shuttle_run: [ }
{
required: true, //
message: t('tenMeterShuttleRunPlaceholder'), const emailVerify = (rule: any, value: any, callback: any) => {
trigger: 'blur', if (value && !/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/.test(value)) {
}, callback(new Error(t('generateEmail')))
], } else {
} callback()
}) }
}
const emit = defineEmits(['complete'])
//
/** const numberVerify = (rule: any, value: any, callback: any) => {
* 确认 if (!Number.isInteger(value)) {
* @param formEl callback(new Error(t('generateNumber')))
*/ } else {
const confirm = async (formEl: FormInstance | undefined) => { callback()
if (loading.value || !formEl) return }
let save = formData.id ? editPhysicalTest : addPhysicalTest }
await formEl.validate(async (valid) => { defineExpose({
if (valid) { showDialog,
loading.value = true setFormData
})
let data = formData </script>
save(data) <style lang="scss" scoped></style>
.then((res) => { <style lang="scss">
loading.value = false .diy-dialog-wrap .el-form-item__label{
showDialog.value = false height: auto !important;
emit('complete') }
}) </style>
.catch((err) => {
loading.value = false
})
}
})
}
//
const setFormData = async (row: any = null) => {
Object.assign(formData, initialFormData)
loading.value = true
if (row) {
const data = await (await getPhysicalTestInfo(row.id)).data
if (data)
Object.keys(formData).forEach((key: string) => {
if (data[key] != undefined) formData[key] = data[key]
})
}
loading.value = false
}
//
const mobileVerify = (rule: any, value: any, callback: any) => {
if (value && !/^1[3-9]\d{9}$/.test(value)) {
callback(new Error(t('generateMobile')))
} else {
callback()
}
}
//
const idCardVerify = (rule: any, value: any, callback: any) => {
if (
value &&
!/^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/.test(
value
)
) {
callback(new Error(t('generateIdCard')))
} else {
callback()
}
}
//
const emailVerify = (rule: any, value: any, callback: any) => {
if (value && !/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/.test(value)) {
callback(new Error(t('generateEmail')))
} else {
callback()
}
}
//
const numberVerify = (rule: any, value: any, callback: any) => {
if (!Number.isInteger(value)) {
callback(new Error(t('generateNumber')))
} else {
callback()
}
}
defineExpose({
showDialog,
setFormData,
})
</script>
<style lang="scss" scoped></style>
<style lang="scss">
.diy-dialog-wrap .el-form-item__label {
height: auto !important;
}
</style>

451
admin/src/app/views/physical_test/physical_test.vue

@ -1,247 +1,204 @@
<template> <template>
<div class="main-container"> <div class="main-container">
<el-card class="box-card !border-none" shadow="never"> <el-card class="box-card !border-none" shadow="never">
<div class="flex justify-between items-center">
<span class="text-lg">{{ pageName }}</span> <div class="flex justify-between items-center">
<el-button type="primary" @click="addEvent"> <span class="text-lg">{{pageName}}</span>
{{ t('addPhysicalTest') }} <el-button type="primary" @click="addEvent">
</el-button> {{ t('addPhysicalTest') }}
</div> </el-button>
</div>
<el-card
class="box-card !border-none my-[10px] table-search-wrap" <el-card class="box-card !border-none my-[10px] table-search-wrap" shadow="never">
shadow="never" <el-form :inline="true" :model="physicalTestTable.searchParam" ref="searchFormRef">
>
<el-form <el-form-item :label="t('resourceId')" prop="resource_id">
:inline="true" <el-select class="w-[280px]" v-model="physicalTestTable.searchParam.resource_id" clearable :placeholder="t('resourceIdPlaceholder')">
:model="physicalTestTable.searchParam" <el-option
ref="searchFormRef" v-for="(item, index) in resourceIdList"
> :key="index"
<el-form-item :label="t('resourceId')" prop="resource_id"> :label="item['name']"
<el-input :value="item['id']"
v-model="physicalTestTable.searchParam.resource_id" />
:placeholder="t('resourceIdPlaceholder')" </el-select>
/> </el-form-item>
</el-form-item>
<el-form-item :label="t('studentId')" prop="student_id">
<el-input <el-form-item :label="t('studentId')" prop="student_id">
v-model="physicalTestTable.searchParam.student_id" <el-select class="w-[280px]" v-model="physicalTestTable.searchParam.student_id" clearable :placeholder="t('studentIdPlaceholder')">
:placeholder="t('studentIdPlaceholder')" <el-option
/> v-for="(item, index) in studentIdList"
</el-form-item> :key="index"
<el-form-item :label="t('height')" prop="height"> :label="item['name']"
<el-input :value="item['id']"
v-model="physicalTestTable.searchParam.height" />
:placeholder="t('heightPlaceholder')" </el-select>
/> </el-form-item>
</el-form-item>
<el-form-item :label="t('createdAt')" prop="created_at"> <el-form-item>
<el-input <el-button type="primary" @click="loadPhysicalTestList()">{{ t('search') }}</el-button>
v-model="physicalTestTable.searchParam.created_at" <el-button @click="resetForm(searchFormRef)">{{ t('reset') }}</el-button>
:placeholder="t('createdAtPlaceholder')" </el-form-item>
/> </el-form>
</el-form-item> </el-card>
<el-form-item :label="t('updatedAt')" prop="updated_at">
<el-input <div class="mt-[10px]">
v-model="physicalTestTable.searchParam.updated_at" <el-table :data="physicalTestTable.data" size="large" v-loading="physicalTestTable.loading">
:placeholder="t('updatedAtPlaceholder')" <template #empty>
/> <span>{{ !physicalTestTable.loading ? t('emptyData') : '' }}</span>
</el-form-item> </template>
<el-table-column prop="resource_id_name" :label="t('resourceId')" min-width="120" :show-overflow-tooltip="true"/>
<el-form-item>
<el-button type="primary" @click="loadPhysicalTestList()">{{ <el-table-column prop="student_id_name" :label="t('studentId')" min-width="120" :show-overflow-tooltip="true"/>
t('search')
}}</el-button> <el-table-column prop="height" :label="t('height')" min-width="120" :show-overflow-tooltip="true"/>
<el-button @click="resetForm(searchFormRef)">{{
t('reset') <el-table-column prop="weight" :label="t('weight')" min-width="120" :show-overflow-tooltip="true"/>
}}</el-button>
</el-form-item> <el-table-column prop="coach_id_name" :label="t('coachId')" min-width="120" :show-overflow-tooltip="true"/>
</el-form>
</el-card> <el-table-column :label="t('operation')" fixed="right" min-width="120">
<template #default="{ row }">
<div class="mt-[10px]"> <el-button type="primary" link @click="editEvent(row)">{{ t('edit') }}</el-button>
<el-table <el-button type="primary" link @click="deleteEvent(row.id)">{{ t('delete') }}</el-button>
:data="physicalTestTable.data" </template>
size="large" </el-table-column>
v-loading="physicalTestTable.loading"
> </el-table>
<template #empty> <div class="mt-[16px] flex justify-end">
<span>{{ !physicalTestTable.loading ? t('emptyData') : '' }}</span> <el-pagination v-model:current-page="physicalTestTable.page" v-model:page-size="physicalTestTable.limit"
</template> layout="total, sizes, prev, pager, next, jumper" :total="physicalTestTable.total"
<el-table-column @size-change="loadPhysicalTestList()" @current-change="loadPhysicalTestList" />
prop="resource_id" </div>
:label="t('resourceId')" </div>
min-width="120"
:show-overflow-tooltip="true" <edit ref="editPhysicalTestDialog" @complete="loadPhysicalTestList" />
/> </el-card>
</div>
<el-table-column </template>
prop="student_id"
:label="t('studentId')" <script lang="ts" setup>
min-width="120" import { reactive, ref, watch } from 'vue'
:show-overflow-tooltip="true" import { t } from '@/lang'
/> import { useDictionary } from '@/app/api/dict'
import { getPhysicalTestList, deletePhysicalTest, getWithCustomerResourcesList, getWithStudentList, getWithPersonnelList } from '@/app/api/physical_test'
<el-table-column import { img } from '@/utils/common'
prop="height" import { ElMessageBox,FormInstance } from 'element-plus'
:label="t('height')" import Edit from '@/app/views/physical_test/components/physical-test-edit.vue'
min-width="120" import { useRoute } from 'vue-router'
:show-overflow-tooltip="true" const route = useRoute()
/> const pageName = route.meta.title;
<el-table-column let physicalTestTable = reactive({
prop="created_at" page: 1,
:label="t('createdAt')" limit: 10,
min-width="120" total: 0,
:show-overflow-tooltip="true" loading: true,
/> data: [],
searchParam:{
<el-table-column "resource_id":"",
prop="updated_at" "student_id":""
:label="t('updatedAt')" }
min-width="120" })
:show-overflow-tooltip="true"
/> const searchFormRef = ref<FormInstance>()
<el-table-column //
:label="t('operation')" const selectData = ref<any[]>([])
fixed="right"
min-width="120" //
>
<template #default="{ row }">
<el-button type="primary" link @click="editEvent(row)">{{ /**
t('edit') * 获取体测列表
}}</el-button> */
<el-button type="primary" link @click="deleteEvent(row.id)">{{ const loadPhysicalTestList = (page: number = 1) => {
t('delete') physicalTestTable.loading = true
}}</el-button> physicalTestTable.page = page
</template>
</el-table-column> getPhysicalTestList({
</el-table> page: physicalTestTable.page,
<div class="mt-[16px] flex justify-end"> limit: physicalTestTable.limit,
<el-pagination ...physicalTestTable.searchParam
v-model:current-page="physicalTestTable.page" }).then(res => {
v-model:page-size="physicalTestTable.limit" physicalTestTable.loading = false
layout="total, sizes, prev, pager, next, jumper" physicalTestTable.data = res.data.data
:total="physicalTestTable.total" physicalTestTable.total = res.data.total
@size-change="loadPhysicalTestList()" }).catch(() => {
@current-change="loadPhysicalTestList" physicalTestTable.loading = false
/> })
</div> }
</div> loadPhysicalTestList()
</el-card>
</div> const editPhysicalTestDialog: Record<string, any> | null = ref(null)
</template>
/**
<script lang="ts" setup> * 添加体测
import { reactive, ref, watch } from 'vue' */
import { t } from '@/lang' const addEvent = () => {
import { useDictionary } from '@/app/api/dict' editPhysicalTestDialog.value.setFormData()
import { editPhysicalTestDialog.value.showDialog = true
getPhysicalTestList, }
deletePhysicalTest,
} from '@/app/api/physical_test' /**
import { img } from '@/utils/common' * 编辑体测
import { ElMessageBox, FormInstance } from 'element-plus' * @param data
import { useRouter } from 'vue-router' */
import { useRoute } from 'vue-router' const editEvent = (data: any) => {
const route = useRoute() editPhysicalTestDialog.value.setFormData(data)
const pageName = route.meta.title editPhysicalTestDialog.value.showDialog = true
}
let physicalTestTable = reactive({
page: 1, /**
limit: 10, * 删除体测
total: 0, */
loading: true, const deleteEvent = (id: number) => {
data: [], ElMessageBox.confirm(t('physicalTestDeleteTips'), t('warning'),
searchParam: { {
resource_id: '', confirmButtonText: t('confirm'),
student_id: '', cancelButtonText: t('cancel'),
height: '', type: 'warning',
created_at: '', }
updated_at: '', ).then(() => {
}, deletePhysicalTest(id).then(() => {
}) loadPhysicalTestList()
}).catch(() => {
const searchFormRef = ref<FormInstance>() })
})
// }
const selectData = ref<any[]>([])
// const resourceIdList = ref([])
const setResourceIdList = async () => {
/** resourceIdList.value = await (await getWithCustomerResourcesList({})).data
* 获取体测列表 }
*/ setResourceIdList()
const loadPhysicalTestList = (page: number = 1) => { const studentIdList = ref([])
physicalTestTable.loading = true const setStudentIdList = async () => {
physicalTestTable.page = page studentIdList.value = await (await getWithStudentList({})).data
}
getPhysicalTestList({ setStudentIdList()
page: physicalTestTable.page, const coachIdList = ref([])
limit: physicalTestTable.limit, const setCoachIdList = async () => {
...physicalTestTable.searchParam, coachIdList.value = await (await getWithPersonnelList({})).data
}) }
.then((res) => { setCoachIdList()
physicalTestTable.loading = false
physicalTestTable.data = res.data.data const resetForm = (formEl: FormInstance | undefined) => {
physicalTestTable.total = res.data.total if (!formEl) return
}) formEl.resetFields()
.catch(() => { loadPhysicalTestList()
physicalTestTable.loading = false }
}) </script>
}
loadPhysicalTestList() <style lang="scss" scoped>
/* 多行超出隐藏 */
const router = useRouter() .multi-hidden {
word-break: break-all;
/** text-overflow: ellipsis;
* 添加体测 overflow: hidden;
*/ display: -webkit-box;
const addEvent = () => { -webkit-line-clamp: 2;
router.push('/physical_test/physical_test_edit') -webkit-box-orient: vertical;
} }
</style>
/**
* 编辑体测
* @param data
*/
const editEvent = (data: any) => {
router.push('/physical_test/physical_test_edit?id=' + data.id)
}
/**
* 删除体测
*/
const deleteEvent = (id: number) => {
ElMessageBox.confirm(t('physicalTestDeleteTips'), t('warning'), {
confirmButtonText: t('confirm'),
cancelButtonText: t('cancel'),
type: 'warning',
}).then(() => {
deletePhysicalTest(id)
.then(() => {
loadPhysicalTestList()
})
.catch(() => {})
})
}
const resetForm = (formEl: FormInstance | undefined) => {
if (!formEl) return
formEl.resetFields()
loadPhysicalTestList()
}
</script>
<style lang="scss" scoped>
/* 多行超出隐藏 */
.multi-hidden {
word-break: break-all;
text-overflow: ellipsis;
overflow: hidden;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
}
</style>

722
admin/src/app/views/physical_test/physical_test_edit.vue

@ -1,383 +1,339 @@
<template> <template>
<div class="main-container"> <div class="main-container">
<div class="detail-head"> <div class="detail-head">
<div class="left" @click="back()"> <div class="left" @click="back()">
<span class="iconfont iconxiangzuojiantou !text-xs"></span> <span class="iconfont iconxiangzuojiantou !text-xs"></span>
<span class="ml-[1px]">{{ t('returnToPreviousPage') }}</span> <span class="ml-[1px]">{{t('returnToPreviousPage')}}</span>
</div> </div>
<span class="adorn">|</span> <span class="adorn">|</span>
<span class="right">{{ pageName }}</span> <span class="right">{{ pageName }}</span>
</div> </div>
<el-card class="box-card !border-none" shadow="never"> <el-card class="box-card !border-none" shadow="never">
<el-form <el-form :model="formData" label-width="90px" ref="formRef" :rules="formRules" class="page-form">
:model="formData" <el-form-item :label="t('resourceId')" prop="resource_id">
label-width="90px" <el-select class="input-width" v-model="formData.resource_id" clearable :placeholder="t('resourceIdPlaceholder')">
ref="formRef" <el-option label="请选择" value=""></el-option>
:rules="formRules" <el-option
class="page-form" v-for="(item, index) in resourceIdList"
> :key="index"
<el-form-item :label="t('resourceId')" prop="resource_id"> :label="item['name']"
<el-input :value="item['id']"
v-model="formData.resource_id" />
clearable </el-select>
:placeholder="t('resourceIdPlaceholder')" </el-form-item>
class="input-width"
/> <el-form-item :label="t('studentId')" prop="student_id">
</el-form-item> <el-select class="input-width" v-model="formData.student_id" clearable :placeholder="t('studentIdPlaceholder')">
<el-option label="请选择" value=""></el-option>
<el-form-item :label="t('studentId')" prop="student_id"> <el-option
<el-input v-for="(item, index) in studentIdList"
v-model="formData.student_id" :key="index"
clearable :label="item['name']"
:placeholder="t('studentIdPlaceholder')" :value="item['id']"
class="input-width" />
/> </el-select>
</el-form-item> </el-form-item>
<el-form-item :label="t('height')" prop="height"> <el-form-item :label="t('height')" prop="height">
<el-input <el-input v-model="formData.height" clearable :placeholder="t('heightPlaceholder')" class="input-width" />
v-model="formData.height" </el-form-item>
clearable
:placeholder="t('heightPlaceholder')" <el-form-item :label="t('weight')" prop="weight">
class="input-width" <el-input v-model="formData.weight" clearable :placeholder="t('weightPlaceholder')" class="input-width" />
/> </el-form-item>
</el-form-item>
<el-form-item :label="t('coachId')" prop="coach_id">
<el-form-item :label="t('weight')" prop="weight"> <el-select class="input-width" v-model="formData.coach_id" clearable :placeholder="t('coachIdPlaceholder')">
<el-input <el-option label="请选择" value=""></el-option>
v-model="formData.weight" <el-option
clearable v-for="(item, index) in coachIdList"
:placeholder="t('weightPlaceholder')" :key="index"
class="input-width" :label="item['name']"
/> :value="item['id']"
</el-form-item> />
</el-select>
<el-form-item :label="t('coachId')" prop="coach_id"> </el-form-item>
<el-input
v-model="formData.coach_id" <el-form-item :label="t('createdAt')" >
clearable <el-input v-model="formData.created_at" clearable :placeholder="t('createdAtPlaceholder')" class="input-width" />
:placeholder="t('coachIdPlaceholder')" </el-form-item>
class="input-width"
/> <el-form-item :label="t('updatedAt')" >
</el-form-item> <el-input v-model="formData.updated_at" clearable :placeholder="t('updatedAtPlaceholder')" class="input-width" />
</el-form-item>
<el-form-item :label="t('createdAt')">
<el-input <el-form-item :label="t('seatedForwardBend')" >
v-model="formData.created_at" <el-input v-model="formData.seated_forward_bend" clearable :placeholder="t('seatedForwardBendPlaceholder')" class="input-width" />
clearable </el-form-item>
:placeholder="t('createdAtPlaceholder')"
class="input-width" <el-form-item :label="t('sitUps')" >
/> <el-input v-model="formData.sit_ups" clearable :placeholder="t('sitUpsPlaceholder')" class="input-width" />
</el-form-item> </el-form-item>
<el-form-item :label="t('updatedAt')"> <el-form-item :label="t('pushUps')" >
<el-input <el-input v-model="formData.push_ups" clearable :placeholder="t('pushUpsPlaceholder')" class="input-width" />
v-model="formData.updated_at" </el-form-item>
clearable
:placeholder="t('updatedAtPlaceholder')" <el-form-item :label="t('flamingoBalance')" >
class="input-width" <el-input v-model="formData.flamingo_balance" clearable :placeholder="t('flamingoBalancePlaceholder')" class="input-width" />
/> </el-form-item>
</el-form-item>
<el-form-item :label="t('thirtySecJump')" >
<el-form-item :label="t('seatedForwardBend')"> <el-input v-model="formData.thirty_sec_jump" clearable :placeholder="t('thirtySecJumpPlaceholder')" class="input-width" />
<el-input </el-form-item>
v-model="formData.seated_forward_bend"
clearable <el-form-item :label="t('standingLongJump')" >
:placeholder="t('seatedForwardBendPlaceholder')" <el-input v-model="formData.standing_long_jump" clearable :placeholder="t('standingLongJumpPlaceholder')" class="input-width" />
class="input-width" </el-form-item>
/>
</el-form-item> <el-form-item :label="t('agilityRun')" >
<el-input v-model="formData.agility_run" clearable :placeholder="t('agilityRunPlaceholder')" class="input-width" />
<el-form-item :label="t('sitUps')"> </el-form-item>
<el-input
v-model="formData.sit_ups" <el-form-item :label="t('balanceBeam')" >
clearable <el-input v-model="formData.balance_beam" clearable :placeholder="t('balanceBeamPlaceholder')" class="input-width" />
:placeholder="t('sitUpsPlaceholder')" </el-form-item>
class="input-width"
/> <el-form-item :label="t('tennisThrow')" >
</el-form-item> <el-input v-model="formData.tennis_throw" clearable :placeholder="t('tennisThrowPlaceholder')" class="input-width" />
</el-form-item>
<el-form-item :label="t('pushUps')">
<el-input <el-form-item :label="t('tenMeterShuttleRun')" >
v-model="formData.push_ups" <el-input v-model="formData.ten_meter_shuttle_run" clearable :placeholder="t('tenMeterShuttleRunPlaceholder')" class="input-width" />
clearable </el-form-item>
:placeholder="t('pushUpsPlaceholder')"
class="input-width" </el-form>
/> </el-card>
</el-form-item> <div class="fixed-footer-wrap">
<div class="fixed-footer">
<el-form-item :label="t('flamingoBalance')"> <el-button type="primary" @click="onSave(formRef)">{{ t('save') }}</el-button>
<el-input <el-button @click="back()">{{ t('cancel') }}</el-button>
v-model="formData.flamingo_balance" </div>
clearable </div>
:placeholder="t('flamingoBalancePlaceholder')" </div>
class="input-width" </template>
/>
</el-form-item> <script lang="ts" setup>
import { ref, reactive, computed, watch } from 'vue'
<el-form-item :label="t('thirtySecJump')"> import { t } from '@/lang'
<el-input import { useDictionary } from '@/app/api/dict'
v-model="formData.thirty_sec_jump" import type { FormInstance } from 'element-plus'
clearable import { getPhysicalTestInfo,addPhysicalTest,editPhysicalTest, getWithCustomerResourcesList, getWithStudentList, getWithPersonnelList } from '@/app/api/physical_test';
:placeholder="t('thirtySecJumpPlaceholder')" import { useRoute } from 'vue-router'
class="input-width"
/> const route = useRoute()
</el-form-item> const id:number = parseInt(route.query.id);
const loading = ref(false)
<el-form-item :label="t('standingLongJump')"> const pageName = route.meta.title
<el-input
v-model="formData.standing_long_jump"
clearable
:placeholder="t('standingLongJumpPlaceholder')" /**
class="input-width" * 表单数据
/> */
</el-form-item> const initialFormData = {
id: 0,
<el-form-item :label="t('agilityRun')"> resource_id: '',
<el-input student_id: '',
v-model="formData.agility_run" height: '',
clearable weight: '',
:placeholder="t('agilityRunPlaceholder')" coach_id: '',
class="input-width" created_at: '',
/> updated_at: '',
</el-form-item> seated_forward_bend: '',
sit_ups: '',
<el-form-item :label="t('balanceBeam')"> push_ups: '',
<el-input flamingo_balance: '',
v-model="formData.balance_beam" thirty_sec_jump: '',
clearable standing_long_jump: '',
:placeholder="t('balanceBeamPlaceholder')" agility_run: '',
class="input-width" balance_beam: '',
/> tennis_throw: '',
</el-form-item> ten_meter_shuttle_run: '',
}
<el-form-item :label="t('tennisThrow')"> const formData: Record<string, any> = reactive({ ...initialFormData })
<el-input
v-model="formData.tennis_throw" const setFormData = async (id:number = 0) => {
clearable Object.assign(formData, initialFormData)
:placeholder="t('tennisThrowPlaceholder')" const data = await (await getPhysicalTestInfo(id)).data
class="input-width" Object.keys(formData).forEach((key: string) => {
/> if (data[key] != undefined) formData[key] = data[key]
</el-form-item> })
}
<el-form-item :label="t('tenMeterShuttleRun')"> if(id) setFormData(id);
<el-input
v-model="formData.ten_meter_shuttle_run" const formRef = ref<FormInstance>()
clearable //
:placeholder="t('tenMeterShuttleRunPlaceholder')" const selectData = ref<any[]>([])
class="input-width"
/> //
</el-form-item>
</el-form>
</el-card>
<div class="fixed-footer-wrap"> const resourceIdList = ref([] as any[])
<div class="fixed-footer"> const setResourceIdList = async () => {
<el-button type="primary" @click="onSave(formRef)">{{ resourceIdList.value = await (await getWithCustomerResourcesList({})).data
t('save') }
}}</el-button> setResourceIdList()
<el-button @click="back()">{{ t('cancel') }}</el-button> const studentIdList = ref([] as any[])
</div> const setStudentIdList = async () => {
</div> studentIdList.value = await (await getWithStudentList({})).data
</div> }
</template> setStudentIdList()
const coachIdList = ref([] as any[])
<script lang="ts" setup> const setCoachIdList = async () => {
import { ref, reactive, computed, watch } from 'vue' coachIdList.value = await (await getWithPersonnelList({})).data
import { t } from '@/lang' }
import { useDictionary } from '@/app/api/dict' setCoachIdList()
import type { FormInstance } from 'element-plus' //
import { const formRules = computed(() => {
getPhysicalTestInfo, return {
addPhysicalTest, resource_id: [
editPhysicalTest, { required: true, message: t('resourceIdPlaceholder'), trigger: 'blur' },
} from '@/app/api/physical_test'
import { useRoute } from 'vue-router' ]
,
const route = useRoute() student_id: [
const id: number = parseInt(route.query.id) { required: true, message: t('studentIdPlaceholder'), trigger: 'blur' },
const loading = ref(false)
const pageName = route.meta.title ]
,
/** height: [
* 表单数据 { required: true, message: t('heightPlaceholder'), trigger: 'blur' },
*/
const initialFormData = { ]
id: 0, ,
resource_id: 0, weight: [
student_id: 0, { required: true, message: t('weightPlaceholder'), trigger: 'blur' },
height: '',
weight: '', ]
coach_id: 0, ,
created_at: '', coach_id: [
updated_at: '', { required: true, message: t('coachIdPlaceholder'), trigger: 'blur' },
seated_forward_bend: '',
sit_ups: '', ]
push_ups: '', ,
flamingo_balance: '', created_at: [
thirty_sec_jump: '', { required: true, message: t('createdAtPlaceholder'), trigger: 'blur' },
standing_long_jump: '',
agility_run: '', ]
balance_beam: '', ,
tennis_throw: '', updated_at: [
ten_meter_shuttle_run: '', { required: true, message: t('updatedAtPlaceholder'), trigger: 'blur' },
}
const formData: Record<string, any> = reactive({ ...initialFormData }) ]
,
const setFormData = async (id: number = 0) => { seated_forward_bend: [
Object.assign(formData, initialFormData) { required: true, message: t('seatedForwardBendPlaceholder'), trigger: 'blur' },
const data = await (await getPhysicalTestInfo(id)).data
Object.keys(formData).forEach((key: string) => { ]
if (data[key] != undefined) formData[key] = data[key] ,
}) sit_ups: [
} { required: true, message: t('sitUpsPlaceholder'), trigger: 'blur' },
if (id) setFormData(id)
]
const formRef = ref<FormInstance>() ,
// push_ups: [
const selectData = ref<any[]>([]) { required: true, message: t('pushUpsPlaceholder'), trigger: 'blur' },
// ]
,
// flamingo_balance: [
const formRules = computed(() => { { required: true, message: t('flamingoBalancePlaceholder'), trigger: 'blur' },
return {
resource_id: [ ]
{ required: true, message: t('resourceIdPlaceholder'), trigger: 'blur' }, ,
], thirty_sec_jump: [
student_id: [ { required: true, message: t('thirtySecJumpPlaceholder'), trigger: 'blur' },
{ required: true, message: t('studentIdPlaceholder'), trigger: 'blur' },
], ]
height: [ ,
{ required: true, message: t('heightPlaceholder'), trigger: 'blur' }, standing_long_jump: [
], { required: true, message: t('standingLongJumpPlaceholder'), trigger: 'blur' },
weight: [
{ required: true, message: t('weightPlaceholder'), trigger: 'blur' }, ]
], ,
coach_id: [ agility_run: [
{ required: true, message: t('coachIdPlaceholder'), trigger: 'blur' }, { required: true, message: t('agilityRunPlaceholder'), trigger: 'blur' },
],
created_at: [ ]
{ required: true, message: t('createdAtPlaceholder'), trigger: 'blur' }, ,
], balance_beam: [
updated_at: [ { required: true, message: t('balanceBeamPlaceholder'), trigger: 'blur' },
{ required: true, message: t('updatedAtPlaceholder'), trigger: 'blur' },
], ]
seated_forward_bend: [ ,
{ tennis_throw: [
required: true, { required: true, message: t('tennisThrowPlaceholder'), trigger: 'blur' },
message: t('seatedForwardBendPlaceholder'),
trigger: 'blur', ]
}, ,
], ten_meter_shuttle_run: [
sit_ups: [ { required: true, message: t('tenMeterShuttleRunPlaceholder'), trigger: 'blur' },
{ required: true, message: t('sitUpsPlaceholder'), trigger: 'blur' },
], ]
push_ups: [ ,
{ required: true, message: t('pushUpsPlaceholder'), trigger: 'blur' }, }
], })
flamingo_balance: [
{ const onSave = async (formEl: FormInstance | undefined) => {
required: true, if (loading.value || !formEl) return
message: t('flamingoBalancePlaceholder'), await formEl.validate(async (valid) => {
trigger: 'blur', if (valid) {
}, loading.value = true
], let data = formData
thirty_sec_jump: [
{ const save = id ? editPhysicalTest : addPhysicalTest
required: true, save(data).then(res => {
message: t('thirtySecJumpPlaceholder'), loading.value = false
trigger: 'blur', history.back()
}, }).catch(err => {
], loading.value = false
standing_long_jump: [ })
{
required: true, }
message: t('standingLongJumpPlaceholder'), })
trigger: 'blur', }
},
], //
agility_run: [ const mobileVerify = (rule: any, value: any, callback: any) => {
{ required: true, message: t('agilityRunPlaceholder'), trigger: 'blur' }, if (value && !/^1[3-9]\d{9}$/.test(value)) {
], callback(new Error(t('generateMobile')))
balance_beam: [ } else {
{ required: true, message: t('balanceBeamPlaceholder'), trigger: 'blur' }, callback()
], }
tennis_throw: [ }
{ required: true, message: t('tennisThrowPlaceholder'), trigger: 'blur' },
], //
ten_meter_shuttle_run: [ const idCardVerify = (rule: any, value: any, callback: any) => {
{ if (value && !/^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/.test(value)) {
required: true, callback(new Error(t('generateIdCard')))
message: t('tenMeterShuttleRunPlaceholder'), } else {
trigger: 'blur', callback()
}, }
], }
}
}) //
const emailVerify = (rule: any, value: any, callback: any) => {
const onSave = async (formEl: FormInstance | undefined) => { if (value && !/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/.test(value)) {
if (loading.value || !formEl) return callback(new Error(t('generateEmail')))
await formEl.validate(async (valid) => { } else {
if (valid) { callback()
loading.value = true }
let data = formData }
const save = id ? editPhysicalTest : addPhysicalTest
save(data) //
.then((res) => { const numberVerify = (rule: any, value: any, callback: any) => {
loading.value = false if (!Number.isInteger(value)) {
history.back() callback(new Error(t('generateNumber')))
}) } else {
.catch((err) => { callback()
loading.value = false }
}) }
} const back = () => {
}) history.back()
} }
</script>
//
const mobileVerify = (rule: any, value: any, callback: any) => { <style lang="scss" scoped></style>
if (value && !/^1[3-9]\d{9}$/.test(value)) {
callback(new Error(t('generateMobile')))
} else {
callback()
}
}
//
const idCardVerify = (rule: any, value: any, callback: any) => {
if (
value &&
!/^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/.test(
value
)
) {
callback(new Error(t('generateIdCard')))
} else {
callback()
}
}
//
const emailVerify = (rule: any, value: any, callback: any) => {
if (value && !/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/.test(value)) {
callback(new Error(t('generateEmail')))
} else {
callback()
}
}
//
const numberVerify = (rule: any, value: any, callback: any) => {
if (!Number.isInteger(value)) {
callback(new Error(t('generateNumber')))
} else {
callback()
}
}
const back = () => {
history.back()
}
</script>
<style lang="scss" scoped></style>

239
admin/src/app/views/tc_dialog/tc_dialog.vue

@ -0,0 +1,239 @@
<template>
<el-dialog
v-model="showDialog"
title="体测列表"
width="80%"
class="diy-dialog-wrap"
:destroy-on-close="true"
>
<div class="main-container">
<el-card class="box-card !border-none" shadow="never">
<div class="flex justify-between items-center">
<span class="text-lg">体测列表</span>
<el-button type="primary" @click="addEvent">
{{ t('addPhysicalTest') }}
</el-button>
</div>
<!-- <el-card class="box-card !border-none my-[10px] table-search-wrap" shadow="never">
<el-form :inline="true" :model="physicalTestTable.searchParam" ref="searchFormRef">
<el-form-item :label="t('resourceId')" prop="resource_id">
<el-select class="w-[280px]" v-model="physicalTestTable.searchParam.resource_id" clearable :placeholder="t('resourceIdPlaceholder')">
<el-option
v-for="(item, index) in resourceIdList"
:key="index"
:label="item['name']"
:value="item['id']"
/>
</el-select>
</el-form-item>
<el-form-item :label="t('studentId')" prop="student_id">
<el-select class="w-[280px]" v-model="physicalTestTable.searchParam.student_id" clearable :placeholder="t('studentIdPlaceholder')">
<el-option
v-for="(item, index) in studentIdList"
:key="index"
:label="item['name']"
:value="item['id']"
/>
</el-select>
</el-form-item>
<el-form-item :label="t('height')" prop="height">
<el-input v-model="physicalTestTable.searchParam.height" :placeholder="t('heightPlaceholder')" />
</el-form-item>
<el-form-item>
<el-button type="primary" @click="loadPhysicalTestList()">{{ t('search') }}</el-button>
<el-button @click="resetForm(searchFormRef)">{{ t('reset') }}</el-button>
</el-form-item>
</el-form>
</el-card> -->
<div class="mt-[10px]">
<el-table :data="physicalTestTable.data" size="large" v-loading="physicalTestTable.loading">
<template #empty>
<span>{{ !physicalTestTable.loading ? t('emptyData') : '' }}</span>
</template>
<el-table-column prop="resource_id_name" :label="t('resourceId')" min-width="120" :show-overflow-tooltip="true"/>
<el-table-column prop="student_id_name" :label="t('studentId')" min-width="120" :show-overflow-tooltip="true"/>
<el-table-column prop="height" :label="t('height')" min-width="120" :show-overflow-tooltip="true"/>
<el-table-column prop="created_at" :label="t('createdAt')" min-width="120" :show-overflow-tooltip="true"/>
<el-table-column prop="updated_at" :label="t('updatedAt')" min-width="120" :show-overflow-tooltip="true"/>
<el-table-column :label="t('operation')" fixed="right" min-width="120">
<template #default="{ row }">
<el-button type="primary" link @click="editEvent(row)">{{ t('edit') }}</el-button>
<!-- <el-button type="primary" link @click="deleteEvent(row.id)">{{ t('delete') }}</el-button> -->
</template>
</el-table-column>
</el-table>
<div class="mt-[16px] flex justify-end">
<el-pagination v-model:current-page="physicalTestTable.page" v-model:page-size="physicalTestTable.limit"
layout="total, sizes, prev, pager, next, jumper" :total="physicalTestTable.total"
@size-change="loadPhysicalTestList()" @current-change="loadPhysicalTestList" />
</div>
</div>
<edit ref="editPhysicalTestDialog" @complete="loadPhysicalTestList" />
</el-card>
</div>
</el-dialog>
</template>
<script lang="ts" setup>
import { reactive, ref, watch } from 'vue'
import { t } from '@/lang'
import { useDictionary } from '@/app/api/dict'
import { getPhysicalTestList, deletePhysicalTest, getWithCustomerResourcesList, getWithStudentList, getWithPersonnelList } from '@/app/api/physical_test'
import { img } from '@/utils/common'
import { ElMessageBox,FormInstance } from 'element-plus'
import Edit from '@/app/views/physical_test/components/physical-test-edit.vue'
import { useRouter } from 'vue-router'
import { useRoute } from 'vue-router'
const route = useRoute()
const pageName = route.meta.title;
let showDialog = ref(false)
let physicalTestTable = reactive({
page: 1,
limit: 10,
total: 0,
loading: true,
data: [],
searchParam:{
"resource_id":"",
"student_id":"",
"height":""
}
})
const searchFormRef = ref<FormInstance>()
//
const selectData = ref<any[]>([])
//
/**
* 获取体测列表
*/
const loadPhysicalTestList = (page: number = 1) => {
physicalTestTable.loading = true
physicalTestTable.page = page
getPhysicalTestList({
page: physicalTestTable.page,
limit: physicalTestTable.limit,
...physicalTestTable.searchParam
}).then(res => {
physicalTestTable.loading = false
physicalTestTable.data = res.data.data
physicalTestTable.total = res.data.total
}).catch(() => {
physicalTestTable.loading = false
})
}
const router = useRouter()
const editPhysicalTestDialog: Record<string, any> | null = ref(null)
/**
* 添加体测
*/
const addEvent = () => {
editPhysicalTestDialog.value.setFormData({'resource_id':physicalTestTable.searchParam.resource_id})
editPhysicalTestDialog.value.showDialog = true
}
/**
* 编辑体测
* @param data
*/
const editEvent = (data: any) => {
// router.push('/physical_test/physical_test_edit?id='+data.id)
editPhysicalTestDialog.value.setFormData(data)
editPhysicalTestDialog.value.showDialog = true
}
/**
* 删除体测
*/
const deleteEvent = (id: number) => {
ElMessageBox.confirm(t('physicalTestDeleteTips'), t('warning'),
{
confirmButtonText: t('confirm'),
cancelButtonText: t('cancel'),
type: 'warning',
}
).then(() => {
deletePhysicalTest(id).then(() => {
loadPhysicalTestList()
}).catch(() => {
})
})
}
const resourceIdList = ref([])
const setResourceIdList = async () => {
resourceIdList.value = await (await getWithCustomerResourcesList({})).data
}
setResourceIdList()
const studentIdList = ref([])
const setStudentIdList = async () => {
studentIdList.value = await (await getWithStudentList({})).data
}
setStudentIdList()
const coachIdList = ref([])
const setCoachIdList = async () => {
coachIdList.value = await (await getWithPersonnelList({})).data
}
setCoachIdList()
const resetForm = (formEl: FormInstance | undefined) => {
if (!formEl) return
formEl.resetFields()
loadPhysicalTestList()
}
const setFormData = async (row: any = null) => {
// Object.assign(formData, initialFormData)
physicalTestTable.searchParam.resource_id = row.resource_id
console.log(physicalTestTable.searchParam.resource_id);
loadPhysicalTestList()
}
defineExpose({
showDialog,
setFormData
})
</script>
<style lang="scss" scoped>
/* 多行超出隐藏 */
.multi-hidden {
word-break: break-all;
text-overflow: ellipsis;
overflow: hidden;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
}
</style>

168
niucloud/app/adminapi/controller/customer_resources/CustomerResources.php

@ -22,16 +22,19 @@ use app\service\admin\customer_resources\CustomerResourcesService;
*/ */
class CustomerResources extends BaseAdminController class CustomerResources extends BaseAdminController
{ {
/** /**
* 获取客户资源列表 * 获取客户资源列表
* @return \think\Response * @return \think\Response
*/ */
public function lists() public function lists(){
{
$data = $this->request->params([ $data = $this->request->params([
["name", ""], ["name",""],
["phone_number", ""], ["age",""],
["type", "khzy"] ["gender",""],
["phone_number",""],
["type","khzy"],
["created_at",[]],
["updated_at",[]],
]); ]);
return success((new CustomerResourcesService())->getPage($data)); return success((new CustomerResourcesService())->getPage($data));
} }
@ -41,8 +44,7 @@ class CustomerResources extends BaseAdminController
* @param int $id * @param int $id
* @return \think\Response * @return \think\Response
*/ */
public function info(int $id) public function info(int $id){
{
return success((new CustomerResourcesService())->getInfo($id)); return success((new CustomerResourcesService())->getInfo($id));
} }
@ -50,37 +52,36 @@ class CustomerResources extends BaseAdminController
* 添加客户资源 * 添加客户资源
* @return \think\Response * @return \think\Response
*/ */
public function add() public function add(){
{
$data = $this->request->params([ $data = $this->request->params([
["source", ""], ["source",""],
["source_channel", ""], ["source_channel",""],
["name", ""], ["name",""],
["age", 0], ["age",0],
["gender", ""], ["gender",""],
["phone_number", ""], ["phone_number",""],
["demand", ""], ["demand",""],
["purchasing_power", ""], ["purchasing_power",""],
["cognitive_idea", ""], ["cognitive_idea",""],
["optional_class_time", ""], ["optional_class_time",""],
["distance", ""], ["distance",""],
["decision_maker", ""], ["decision_maker",""],
["initial_intent", ""], ["initial_intent",""],
["campus", ""], ["campus",""],
["status", ""], ["status",""],
["create_year_month", date("Y-m")], ["create_year_month",date("Y-m")],
["create_date", date("Y-m-d")], ["create_date",date("Y-m-d")],
["purchase_power", ""], ["purchase_power",""],
["concept_awareness", ""], ["concept_awareness",""],
["preferred_class_time", ""], ["preferred_class_time",""],
["distance_tow", ""], ["distance_tow",""],
["communication", ""], ["communication",""],
["promised_visit_time", ""], ["promised_visit_time",""],
["actual_visit_time", ""], ["actual_visit_time",""],
["call_intent", ""], ["call_intent",""],
["first_visit_status", ""], ["first_visit_status",""],
["second_visit_status", ""], ["second_visit_status",""],
["is_closed", ""] ["is_closed",""]
]); ]);
$this->validate($data, 'app\validate\customer_resources\CustomerResources.add'); $this->validate($data, 'app\validate\customer_resources\CustomerResources.add');
@ -92,38 +93,37 @@ class CustomerResources extends BaseAdminController
* @param $id 客户资源id * @param $id 客户资源id
* @return \think\Response * @return \think\Response
*/ */
public function edit(int $id) public function edit(int $id){
{
$data = $this->request->params([ $data = $this->request->params([
["source", ""], ["source",""],
["source_channel", ""], ["source_channel",""],
["name", ""], ["name",""],
["age", 0], ["age",0],
["gender", ""], ["gender",""],
["phone_number", ""], ["phone_number",""],
["demand", ""], ["demand",""],
["purchasing_power", ""], ["purchasing_power",""],
["cognitive_idea", ""], ["cognitive_idea",""],
["optional_class_time", ""], ["optional_class_time",""],
["distance", ""], ["distance",""],
["decision_maker", ""], ["decision_maker",""],
["initial_intent", ""], ["initial_intent",""],
["campus", ""], ["campus",""],
["status", ""], ["status",""],
["create_year_month", date("Y-m")], ["create_year_month",date("Y-m")],
["create_date", date("Y-m-d")], ["create_date",date("Y-m-d")],
["purchase_power", ""], ["purchase_power",""],
["concept_awareness", ""], ["concept_awareness",""],
["preferred_class_time", ""], ["preferred_class_time",""],
["distance_tow", ""], ["distance_tow",""],
["communication", ""], ["communication",""],
["promised_visit_time", ""], ["promised_visit_time",""],
["actual_visit_time", ""], ["actual_visit_time",""],
["call_intent", ""], ["call_intent",""],
["first_visit_status", ""], ["first_visit_status",""],
["second_visit_status", ""], ["second_visit_status",""],
["is_closed", ""] ["is_closed",""]
]); ]);
$this->validate($data, 'app\validate\customer_resources\CustomerResources.edit'); $this->validate($data, 'app\validate\customer_resources\CustomerResources.edit');
@ -135,35 +135,31 @@ class CustomerResources extends BaseAdminController
* @param $id 客户资源id * @param $id 客户资源id
* @return \think\Response * @return \think\Response
*/ */
public function del(int $id) public function del(int $id){
{
(new CustomerResourcesService())->del($id); (new CustomerResourcesService())->del($id);
return success('DELETE_SUCCESS'); return success('DELETE_SUCCESS');
} }
public function getPersonnelAll() public function getPersonnelAll(){
{
$data = $this->request->params([ $data = $this->request->params([
["role_id", ""], ["role_id",""],
]); ]);
return success((new CustomerResourcesService())->getPersonnelAll($data)); return success(( new CustomerResourcesService())->getPersonnelAll($data));
} }
public function getCampusAll() public function getCampusAll(){
{ return success(( new CustomerResourcesService())->getCampusAll());
return success((new CustomerResourcesService())->getCampusAll());
} }
public function fp_edit() public function fp_edit(){
{
$data = $this->request->params([ $data = $this->request->params([
["shared_id", ""], ["shared_id",""],
["shared_by", ""], ["shared_by",""],
]); ]);
return success((new CustomerResourcesService())->fp_edit($data)); return success(( new CustomerResourcesService())->fp_edit($data));
} }

49
niucloud/app/adminapi/controller/order_table/OrderTable.php

@ -28,19 +28,8 @@ class OrderTable extends BaseAdminController
*/ */
public function lists(){ public function lists(){
$data = $this->request->params([ $data = $this->request->params([
["payment_id",""],
["order_status",""], ["order_status",""],
["payment_type",""], ["payment_type",""]
["order_amount",""],
["course_id",""],
["class_id",""],
["staff_id",""],
["resource_id",""],
["after_sales_status",""],
["after_sales_reason",""],
["after_sales_time",""],
["payment_time",""],
["subscription_payment_time",""]
]); ]);
return success((new OrderTableService())->getPage($data)); return success((new OrderTableService())->getPage($data));
} }
@ -60,19 +49,13 @@ class OrderTable extends BaseAdminController
*/ */
public function add(){ public function add(){
$data = $this->request->params([ $data = $this->request->params([
["payment_id",""], ["resource_id",0],
["order_status",""], ["order_status",""],
["payment_type",""], ["payment_type",""],
["order_amount",0.00], ["order_amount",0.00],
["course_id",0], ["course_id",0],
["class_id",0], ["class_id",0],
["staff_id",0],
["resource_id",0],
["after_sales_status",""],
["after_sales_reason",""],
["after_sales_time",1747388736],
["payment_time",1747388736],
["subscription_payment_time",1747388736]
]); ]);
$this->validate($data, 'app\validate\order_table\OrderTable.add'); $this->validate($data, 'app\validate\order_table\OrderTable.add');
$id = (new OrderTableService())->add($data); $id = (new OrderTableService())->add($data);
@ -86,19 +69,13 @@ class OrderTable extends BaseAdminController
*/ */
public function edit(int $id){ public function edit(int $id){
$data = $this->request->params([ $data = $this->request->params([
["payment_id",""], ["resource_id",0],
["order_status",""], ["order_status",""],
["payment_type",""], ["payment_type",""],
["order_amount",0.00], ["order_amount",0.00],
["course_id",0], ["course_id",0],
["class_id",0], ["class_id",0],
["staff_id",0],
["resource_id",0],
["after_sales_status",""],
["after_sales_reason",""],
["after_sales_time",1747388736],
["payment_time",1747388736],
["subscription_payment_time",1747388736]
]); ]);
$this->validate($data, 'app\validate\order_table\OrderTable.edit'); $this->validate($data, 'app\validate\order_table\OrderTable.edit');
(new OrderTableService())->edit($id, $data); (new OrderTableService())->edit($id, $data);
@ -116,4 +93,20 @@ class OrderTable extends BaseAdminController
} }
public function getCustomerResourcesAll(){
return success(( new OrderTableService())->getCustomerResourcesAll());
}
public function getCourseAll(){
return success(( new OrderTableService())->getCourseAll());
}
public function getClassGradeAll(){
return success(( new OrderTableService())->getClassGradeAll());
}
public function getPersonnelAll(){
return success(( new OrderTableService())->getPersonnelAll());
}
} }

21
niucloud/app/adminapi/controller/physical_test/PhysicalTest.php

@ -29,10 +29,7 @@ class PhysicalTest extends BaseAdminController
public function lists(){ public function lists(){
$data = $this->request->params([ $data = $this->request->params([
["resource_id",""], ["resource_id",""],
["student_id",""], ["student_id",""]
["height",""],
["created_at",""],
["updated_at",""]
]); ]);
return success((new PhysicalTestService())->getPage($data)); return success((new PhysicalTestService())->getPage($data));
} }
@ -57,8 +54,6 @@ class PhysicalTest extends BaseAdminController
["height",0.00], ["height",0.00],
["weight",0.00], ["weight",0.00],
["coach_id",0], ["coach_id",0],
["created_at",1747576653],
["updated_at",1747576653],
["seated_forward_bend",0.00], ["seated_forward_bend",0.00],
["sit_ups",0.00], ["sit_ups",0.00],
["push_ups",0.00], ["push_ups",0.00],
@ -87,8 +82,6 @@ class PhysicalTest extends BaseAdminController
["height",0.00], ["height",0.00],
["weight",0.00], ["weight",0.00],
["coach_id",0], ["coach_id",0],
["created_at",1747576653],
["updated_at",1747576653],
["seated_forward_bend",0.00], ["seated_forward_bend",0.00],
["sit_ups",0.00], ["sit_ups",0.00],
["push_ups",0.00], ["push_ups",0.00],
@ -116,4 +109,16 @@ class PhysicalTest extends BaseAdminController
} }
public function getCustomerResourcesAll(){
return success(( new PhysicalTestService())->getCustomerResourcesAll());
}
public function getStudentAll(){
return success(( new PhysicalTestService())->getStudentAll());
}
public function getPersonnelAll(){
return success(( new PhysicalTestService())->getPersonnelAll());
}
} }

10
niucloud/app/adminapi/route/order_table.php

@ -14,6 +14,8 @@ use think\facade\Route;
use app\adminapi\middleware\AdminCheckRole; use app\adminapi\middleware\AdminCheckRole;
use app\adminapi\middleware\AdminCheckToken; use app\adminapi\middleware\AdminCheckToken;
use app\adminapi\middleware\AdminLog; use app\adminapi\middleware\AdminLog;
// USER_CODE_BEGIN -- order_table // USER_CODE_BEGIN -- order_table
Route::group('order_table', function () { Route::group('order_table', function () {
@ -29,6 +31,14 @@ Route::group('order_table', function () {
//删除订单 //删除订单
Route::delete('order_table/:id', 'order_table.OrderTable/del'); Route::delete('order_table/:id', 'order_table.OrderTable/del');
Route::get('customer_resources_all','order_table.OrderTable/getCustomerResourcesAll');
Route::get('course_all','order_table.OrderTable/getCourseAll');
Route::get('class_grade_all','order_table.OrderTable/getClassGradeAll');
Route::get('personnel_all','order_table.OrderTable/getPersonnelAll');
})->middleware([ })->middleware([
AdminCheckToken::class, AdminCheckToken::class,
AdminCheckRole::class, AdminCheckRole::class,

8
niucloud/app/adminapi/route/physical_test.php

@ -16,6 +16,8 @@ use app\adminapi\middleware\AdminCheckToken;
use app\adminapi\middleware\AdminLog; use app\adminapi\middleware\AdminLog;
// USER_CODE_BEGIN -- physical_test // USER_CODE_BEGIN -- physical_test
Route::group('physical_test', function () { Route::group('physical_test', function () {
@ -31,6 +33,12 @@ Route::group('physical_test', function () {
//删除体测 //删除体测
Route::delete('physical_test/:id', 'physical_test.PhysicalTest/del'); Route::delete('physical_test/:id', 'physical_test.PhysicalTest/del');
Route::get('customer_resources_all','physical_test.PhysicalTest/getCustomerResourcesAll');
Route::get('student_all','physical_test.PhysicalTest/getStudentAll');
Route::get('personnel_all','physical_test.PhysicalTest/getPersonnelAll');
})->middleware([ })->middleware([
AdminCheckToken::class, AdminCheckToken::class,
AdminCheckRole::class, AdminCheckRole::class,

226
niucloud/app/model/class_grade/ClassGrade.php

@ -0,0 +1,226 @@
<?php
// +----------------------------------------------------------------------
// | Niucloud-admin 企业快速开发的多应用管理平台
// +----------------------------------------------------------------------
// | 官方网址:https://www.niucloud.com
// +----------------------------------------------------------------------
// | niucloud团队 版权所有 开源版本可自由商用
// +----------------------------------------------------------------------
// | Author: Niucloud Team
// +----------------------------------------------------------------------
namespace app\model\class_grade;
use core\base\BaseModel;
use think\model\concern\SoftDelete;
use think\model\relation\HasMany;
use think\model\relation\HasOne;
/**
* 班级模型
* Class Class
* @package app\model\class
*/
class ClassGrade extends BaseModel
{
use SoftDelete;
/**
* 数据表主键
* @var string
*/
protected $pk = 'id';
/**
* 模型名称
* @var string
*/
protected $name = 'class';
/**
* 定义软删除标记字段.
* @var string
*/
protected $deleteTime = 'deleted_at';
/**
* 定义软删除字段的默认值.
* @var int
*/
protected $defaultSoftDelete = 0;
/**
* 搜索器:班级班级编号
* @param $value
* @param $data
*/
public function searchIdAttr($query, $value, $data)
{
if ($value) {
$query->where("id", $value);
}
}
/**
* 搜索器:班级校区ID
* @param $value
* @param $data
*/
public function searchCampusIdAttr($query, $value, $data)
{
if ($value) {
$query->where("campus_id", $value);
}
}
/**
* 搜索器:班级校区名称
* @param $value
* @param $data
*/
public function searchCampusNameAttr($query, $value, $data)
{
if ($value) {
$query->where("campus_name", $value);
}
}
/**
* 搜索器:班级班级名称
* @param $value
* @param $data
*/
public function searchClassNameAttr($query, $value, $data)
{
if ($value) {
$query->where("class_name", $value);
}
}
/**
* 搜索器:班级班级主教练
* @param $value
* @param $data
*/
public function searchHeadCoachAttr($query, $value, $data)
{
if ($value) {
$query->where("head_coach", $value);
}
}
/**
* 搜索器:班级班级授课年龄段
* @param $value
* @param $data
*/
public function searchAgeGroupAttr($query, $value, $data)
{
if ($value) {
$query->where("age_group", $value);
}
}
/**
* 搜索器:班级班级类型
* @param $value
* @param $data
*/
public function searchClassTypeAttr($query, $value, $data)
{
if ($value) {
$query->where("class_type", $value);
}
}
/**
* 搜索器:班级班级助教
* @param $value
* @param $data
*/
public function searchAssistantCoachAttr($query, $value, $data)
{
if ($value) {
$query->where("assistant_coach", $value);
}
}
/**
* 搜索器:班级创建时间
* @param $value
* @param $data
*/
public function searchCreatedAtAttr($query, $value, $data)
{
if ($value) {
$query->where("created_at", $value);
}
}
/**
* 搜索器:班级修改时间
* @param $value
* @param $data
*/
public function searchUpdatedAtAttr($query, $value, $data)
{
if ($value) {
$query->where("updated_at", $value);
}
}
/**
* 搜索器:班级逻辑删除时间
* @param $value
* @param $data
*/
public function searchDeletedAtAttr($query, $value, $data)
{
if ($value) {
$query->where("deleted_at", $value);
}
}
/**
* 搜索器:班级班级状态
* @param $value
* @param $data
*/
public function searchStatusAttr($query, $value, $data)
{
if ($value) {
$query->where("status", $value);
}
}
/**
* 搜索器:班级班级排序
* @param $value
* @param $data
*/
public function searchSortOrderAttr($query, $value, $data)
{
if ($value) {
$query->where("sort_order", $value);
}
}
/**
* 搜索器:班级班级备注
* @param $value
* @param $data
*/
public function searchRemarksAttr($query, $value, $data)
{
if ($value) {
$query->where("remarks", $value);
}
}
}

166
niucloud/app/model/order_table/OrderTable.php

@ -16,6 +16,14 @@ use think\model\concern\SoftDelete;
use think\model\relation\HasMany; use think\model\relation\HasMany;
use think\model\relation\HasOne; use think\model\relation\HasOne;
use app\model\customer_resources\CustomerResources;
use app\model\course\Course;
use app\model\class_grade\ClassGrade;
use app\model\personnel\Personnel;
/** /**
* 订单模型 * 订单模型
* Class OrderTable * Class OrderTable
@ -43,31 +51,7 @@ class OrderTable extends BaseModel
/** /**
* 搜索器:订单订单编号 * 搜索器:订单订单状态
* @param $value
* @param $data
*/
public function searchIdAttr($query, $value, $data)
{
if ($value) {
$query->where("id", $value);
}
}
/**
* 搜索器:订单支付编号
* @param $value
* @param $data
*/
public function searchPaymentIdAttr($query, $value, $data)
{
if ($value) {
$query->where("payment_id", $value);
}
}
/**
* 搜索器:订单订单状态: pending-待支付, paid-已支付
* @param $value * @param $value
* @param $data * @param $data
*/ */
@ -79,7 +63,7 @@ class OrderTable extends BaseModel
} }
/** /**
* 搜索器:订单付款类型: cash-现金支付, scan_code-扫码支付, subscription-订阅支付 * 搜索器:订单付款类型
* @param $value * @param $value
* @param $data * @param $data
*/ */
@ -90,129 +74,25 @@ class OrderTable extends BaseModel
} }
} }
/**
* 搜索器:订单订单金额
* @param $value
* @param $data
*/
public function searchOrderAmountAttr($query, $value, $data)
{
if ($value) {
$query->where("order_amount", $value);
}
}
/**
* 搜索器:订单课程ID
* @param $value
* @param $data
*/
public function searchCourseIdAttr($query, $value, $data)
{
if ($value) {
$query->where("course_id", $value);
}
}
/**
* 搜索器:订单班级ID
* @param $value
* @param $data
*/
public function searchClassIdAttr($query, $value, $data)
{
if ($value) {
$query->where("class_id", $value);
}
}
/**
* 搜索器:订单人员ID
* @param $value
* @param $data
*/
public function searchStaffIdAttr($query, $value, $data)
{
if ($value) {
$query->where("staff_id", $value);
}
}
/**
* 搜索器:订单资源ID
* @param $value
* @param $data
*/
public function searchResourceIdAttr($query, $value, $data)
{
if ($value) {
$query->where("resource_id", $value);
}
}
/**
* 搜索器:订单售后状态
* @param $value
* @param $data
*/
public function searchAfterSalesStatusAttr($query, $value, $data)
{
if ($value) {
$query->where("after_sales_status", $value);
}
}
/**
* 搜索器:订单售后原因
* @param $value
* @param $data
*/
public function searchAfterSalesReasonAttr($query, $value, $data)
{
if ($value) {
$query->where("after_sales_reason", $value);
}
}
/** public function customerResources(){
* 搜索器:订单售后时间 return $this->hasOne(CustomerResources::class, 'id', 'resource_id')->joinType('left')->withField('name,id')->bind(['resource_id_name'=>'name']);
* @param $value
* @param $data
*/
public function searchAfterSalesTimeAttr($query, $value, $data)
{
if ($value) {
$query->where("after_sales_time", $value);
}
} }
/** public function course(){
* 搜索器:订单支付时间 return $this->hasOne(Course::class, 'id', 'course_id')->joinType('left')->withField('course_name,id')->bind(['course_id_name'=>'course_name']);
* @param $value
* @param $data
*/
public function searchPaymentTimeAttr($query, $value, $data)
{
if ($value) {
$query->where("payment_time", $value);
}
} }
/** public function classGrade(){
* 搜索器:订单订阅支付生成时间 return $this->hasOne(ClassGrade::class, 'id', 'class_id')->joinType('left')->withField('class_name,id')->bind(['class_id_name'=>'class_name']);
* @param $value
* @param $data
*/
public function searchSubscriptionPaymentTimeAttr($query, $value, $data)
{
if ($value) {
$query->where("subscription_payment_time", $value);
}
} }
public function personnel(){
return $this->hasOne(Personnel::class, 'id', 'staff_id')->joinType('left')->withField('name,id')->bind(['staff_id_name'=>'name']);
}
} }

54
niucloud/app/model/physical_test/PhysicalTest.php

@ -16,6 +16,12 @@ use think\model\concern\SoftDelete;
use think\model\relation\HasMany; use think\model\relation\HasMany;
use think\model\relation\HasOne; use think\model\relation\HasOne;
use app\model\customer_resources\CustomerResources;
use app\model\student\Student;
use app\model\personnel\Personnel;
/** /**
* 体测模型 * 体测模型
* Class PhysicalTest * Class PhysicalTest
@ -66,45 +72,21 @@ class PhysicalTest extends BaseModel
} }
} }
/**
* 搜索器:体测身高
* @param $value
* @param $data
*/
public function searchHeightAttr($query, $value, $data)
{
if ($value) {
$query->where("height", $value);
}
}
/**
* 搜索器:体测创建时间
* @param $value
* @param $data
*/
public function searchCreatedAtAttr($query, $value, $data)
{
if ($value) {
$query->where("created_at", $value);
}
}
/**
* 搜索器:体测修改时间
* @param $value
* @param $data
*/
public function searchUpdatedAtAttr($query, $value, $data)
{
if ($value) {
$query->where("updated_at", $value);
}
}
public function customerResources(){
return $this->hasOne(CustomerResources::class, 'id', 'resource_id')->joinType('left')->withField('name,id')->bind(['resource_id_name'=>'name']);
}
public function student(){
return $this->hasOne(Student::class, 'id', 'student_id')->joinType('left')->withField('name,id')->bind(['student_id_name'=>'name']);
}
public function personnel(){
return $this->hasOne(Personnel::class, 'id', 'coach_id')->joinType('left')->withField('name,id')->bind(['coach_id_name'=>'name']);
}
} }

40
niucloud/app/service/admin/customer_resources/CustomerResourcesService.php

@ -42,6 +42,7 @@ class CustomerResourcesService extends BaseAdminService
*/ */
public function getPage(array $data = []) public function getPage(array $data = [])
{ {
// dump($data);die;
$field = 'a.*,b.id as shared_id'; $field = 'a.*,b.id as shared_id';
$order = 'a.id desc'; $order = 'a.id desc';
$where = []; $where = [];
@ -53,16 +54,39 @@ class CustomerResourcesService extends BaseAdminService
$where[] = ['a.name','=',$data['name']]; $where[] = ['a.name','=',$data['name']];
} }
if($data['age']){
$where[] = ['a.age','=',$data['age']];
}
if($data['gender']){
$where[] = ['a.gender','=',$data['gender']];
}
if($data['type'] == 'yjfp'){ if($data['type'] == 'yjfp'){
$where[] = ['b.shared_by','=',0]; $where[] = ['b.shared_by','=',0];
} }
$search_model = $this->model $search_model = $this->model
->alias("a") ->alias("a")
->join(['school_resource_sharing' => 'b'],'a.id = b.resource_id','left') ->join(['school_resource_sharing' => 'b'],'a.id = b.resource_id','left')
->where($where) ->where($where)
->with(['personnel'])->field($field)->order($order); ->with(['personnel'])->field($field)->order($order);
if (isset($data['created_at'][0]) && isset($data['created_at'][1])) {
$search_model->whereBetweenTime('created_at', $data['created_at'][0]."00:00:00", $data['created_at'][1]."23:59:59");
}
if (isset($data['updated_at'][0]) && isset($data['updated_at'][1])) {
$search_model->whereBetweenTime('updated_at', $data['updated_at'][0]."00:00:00", $data['updated_at'][1]."23:59:59");
}
$list = $this->pageQuery($search_model); $list = $this->pageQuery($search_model);
@ -152,19 +176,19 @@ class CustomerResourcesService extends BaseAdminService
public function edit(int $id, array $data) public function edit(int $id, array $data)
{ {
$personnel = new Personnel(); $personnel = new Personnel();
$data['consultant'] = $personnel->where(['sys_user_id' => $this->uid])->value("id"); // $data['consultant'] = $personnel->where(['sys_user_id' => $this->uid])->value("id");
if(!$data['consultant']){ // if(!$data['consultant']){
return fail("操作失败"); // return fail("操作失败");
} // }
// $data['consultant'] = 1; $data['consultant'] = 1;
$res = $this->model->where([['id', '=', $id]])->findOrEmpty()->toArray(); $res = $this->model->where([['id', '=', $id]])->findOrEmpty()->toArray();
$this->model->where([['id', '=', $id]])->update([ $this->model->where([['id', '=', $id]])->update([
'source' => $data['source'], 'source' => $data['source'],
'source_channel' => $data['source_channel'], 'source_channel' => $data['source_channel'],
'consultant' => $data['consultant'], // 'consultant' => $data['consultant'],
'name' => $data['name'], 'name' => $data['name'],
'age' => $data['age'], 'age' => $data['age'],
'gender' => $data['gender'], 'gender' => $data['gender'],
@ -201,7 +225,7 @@ class CustomerResourcesService extends BaseAdminService
if($data['purchase_power']){ if($data['purchase_power']){
$sixSpeedModificationLog = new SixSpeedModificationLog(); $sixSpeedModificationLog = new SixSpeedModificationLog();
$six_id = $sixSpeed->where(['resource_id' => $id])->value("id"); $six_id = $sixSpeed->where(['resource_id' => $id])->value("id");
$data['staff_id'] = $data['consultant']; // $data['staff_id'] = $data['consultant'];
@ -217,7 +241,7 @@ class CustomerResourcesService extends BaseAdminService
'first_visit_status' => $data['first_visit_status'], 'first_visit_status' => $data['first_visit_status'],
'second_visit_status' => $data['second_visit_status'], 'second_visit_status' => $data['second_visit_status'],
'is_closed' => $data['is_closed'], 'is_closed' => $data['is_closed'],
'staff_id' => $data['staff_id'], // 'staff_id' => $data['staff_id'],
'resource_id' => $id 'resource_id' => $id
]; ];
if($six_id){ if($six_id){

42
niucloud/app/service/admin/order_table/OrderTableService.php

@ -12,6 +12,10 @@
namespace app\service\admin\order_table; namespace app\service\admin\order_table;
use app\model\order_table\OrderTable; use app\model\order_table\OrderTable;
use app\model\customer_resources\CustomerResources;
use app\model\course\Course;
use app\model\class_grade\ClassGrade;
use app\model\personnel\Personnel;
use core\base\BaseAdminService; use core\base\BaseAdminService;
@ -36,10 +40,10 @@ class OrderTableService extends BaseAdminService
*/ */
public function getPage(array $where = []) public function getPage(array $where = [])
{ {
$field = 'id,payment_id,order_status,payment_type,order_amount,course_id,class_id,staff_id,resource_id,after_sales_status,after_sales_reason,after_sales_time,created_at,updated_at,payment_time,subscription_payment_time'; $field = 'id,resource_id,payment_id,order_status,payment_type,order_amount,course_id,class_id,staff_id,after_sales_status,after_sales_reason,after_sales_time,created_at,updated_at,payment_time,subscription_payment_time';
$order = 'id desc'; $order = 'id desc';
$search_model = $this->model->withSearch(["id","payment_id","order_status","payment_type","order_amount","course_id","class_id","staff_id","resource_id","after_sales_status","after_sales_reason","after_sales_time","payment_time","subscription_payment_time"], $where)->field($field)->order($order); $search_model = $this->model->withSearch(["order_status","payment_type"], $where)->with(['customerResources','course','classGrade','personnel'])->field($field)->order($order);
$list = $this->pageQuery($search_model); $list = $this->pageQuery($search_model);
return $list; return $list;
} }
@ -51,9 +55,9 @@ class OrderTableService extends BaseAdminService
*/ */
public function getInfo(int $id) public function getInfo(int $id)
{ {
$field = 'id,payment_id,order_status,payment_type,order_amount,course_id,class_id,staff_id,resource_id,after_sales_status,after_sales_reason,after_sales_time,created_at,updated_at,payment_time,subscription_payment_time'; $field = 'id,resource_id,payment_id,order_status,payment_type,order_amount,course_id,class_id,staff_id,after_sales_status,after_sales_reason,after_sales_time,created_at,updated_at,payment_time,subscription_payment_time';
$info = $this->model->field($field)->where([['id', "=", $id]])->findOrEmpty()->toArray(); $info = $this->model->field($field)->where([['id', "=", $id]])->with(['customerResources','course','classGrade','personnel'])->findOrEmpty()->toArray();
return $info; return $info;
} }
@ -64,6 +68,14 @@ class OrderTableService extends BaseAdminService
*/ */
public function add(array $data) public function add(array $data)
{ {
$personnel = new Personnel();
$data['staff_id'] = $personnel->where(['sys_user_id' => $this->uid])->value("id");
if(!$data['staff_id']){
return fail("操作失败");
}
// $data['staff_id'] = 1;
$res = $this->model->create($data); $res = $this->model->create($data);
return $res->id; return $res->id;
@ -94,6 +106,26 @@ class OrderTableService extends BaseAdminService
return $res; return $res;
} }
public function getCustomerResourcesAll(){
$customerResourcesModel = new CustomerResources();
return $customerResourcesModel->select()->toArray();
}
public function getCourseAll(){
$courseModel = new Course();
return $courseModel->select()->toArray();
}
public function getClassGradeAll(){
$classGradeModel = new ClassGrade();
return $classGradeModel->select()->toArray();
}
public function getPersonnelAll(){
$personnelModel = new Personnel();
return $personnelModel->select()->toArray();
}
} }

22
niucloud/app/service/admin/physical_test/PhysicalTestService.php

@ -12,6 +12,9 @@
namespace app\service\admin\physical_test; namespace app\service\admin\physical_test;
use app\model\physical_test\PhysicalTest; use app\model\physical_test\PhysicalTest;
use app\model\customer_resources\CustomerResources;
use app\model\student\Student;
use app\model\personnel\Personnel;
use core\base\BaseAdminService; use core\base\BaseAdminService;
@ -39,7 +42,7 @@ class PhysicalTestService extends BaseAdminService
$field = 'id,resource_id,student_id,height,weight,coach_id,created_at,updated_at,seated_forward_bend,sit_ups,push_ups,flamingo_balance,thirty_sec_jump,standing_long_jump,agility_run,balance_beam,tennis_throw,ten_meter_shuttle_run'; $field = 'id,resource_id,student_id,height,weight,coach_id,created_at,updated_at,seated_forward_bend,sit_ups,push_ups,flamingo_balance,thirty_sec_jump,standing_long_jump,agility_run,balance_beam,tennis_throw,ten_meter_shuttle_run';
$order = 'id desc'; $order = 'id desc';
$search_model = $this->model->withSearch(["resource_id","student_id","height","created_at","updated_at"], $where)->field($field)->order($order); $search_model = $this->model->withSearch(["resource_id","student_id"], $where)->with(['customerResources','student','personnel'])->field($field)->order($order);
$list = $this->pageQuery($search_model); $list = $this->pageQuery($search_model);
return $list; return $list;
} }
@ -53,7 +56,7 @@ class PhysicalTestService extends BaseAdminService
{ {
$field = 'id,resource_id,student_id,height,weight,coach_id,created_at,updated_at,seated_forward_bend,sit_ups,push_ups,flamingo_balance,thirty_sec_jump,standing_long_jump,agility_run,balance_beam,tennis_throw,ten_meter_shuttle_run'; $field = 'id,resource_id,student_id,height,weight,coach_id,created_at,updated_at,seated_forward_bend,sit_ups,push_ups,flamingo_balance,thirty_sec_jump,standing_long_jump,agility_run,balance_beam,tennis_throw,ten_meter_shuttle_run';
$info = $this->model->field($field)->where([['id', "=", $id]])->findOrEmpty()->toArray(); $info = $this->model->field($field)->where([['id', "=", $id]])->with(['customerResources','student','personnel'])->findOrEmpty()->toArray();
return $info; return $info;
} }
@ -95,5 +98,20 @@ class PhysicalTestService extends BaseAdminService
} }
public function getCustomerResourcesAll(){
$customerResourcesModel = new CustomerResources();
return $customerResourcesModel->select()->toArray();
}
public function getStudentAll(){
$studentModel = new Student();
return $studentModel->select()->toArray();
}
public function getPersonnelAll(){
$personnelModel = new Personnel();
return $personnelModel->select()->toArray();
}
} }

12
niucloud/app/validate/order_table/OrderTable.php

@ -20,30 +20,26 @@ class OrderTable extends BaseValidate
{ {
protected $rule = [ protected $rule = [
'payment_id' => 'require', 'resource_id' => 'require',
'order_status' => 'require', 'order_status' => 'require',
'payment_type' => 'require', 'payment_type' => 'require',
'order_amount' => 'require', 'order_amount' => 'require',
'course_id' => 'require', 'course_id' => 'require',
'class_id' => 'require', 'class_id' => 'require',
'staff_id' => 'require',
'resource_id' => 'require',
]; ];
protected $message = [ protected $message = [
'payment_id.require' => ['common_validate.require', ['payment_id']], 'resource_id.require' => ['common_validate.require', ['resource_id']],
'order_status.require' => ['common_validate.require', ['order_status']], 'order_status.require' => ['common_validate.require', ['order_status']],
'payment_type.require' => ['common_validate.require', ['payment_type']], 'payment_type.require' => ['common_validate.require', ['payment_type']],
'order_amount.require' => ['common_validate.require', ['order_amount']], 'order_amount.require' => ['common_validate.require', ['order_amount']],
'course_id.require' => ['common_validate.require', ['course_id']], 'course_id.require' => ['common_validate.require', ['course_id']],
'class_id.require' => ['common_validate.require', ['class_id']], 'class_id.require' => ['common_validate.require', ['class_id']],
'staff_id.require' => ['common_validate.require', ['staff_id']],
'resource_id.require' => ['common_validate.require', ['resource_id']],
]; ];
protected $scene = [ protected $scene = [
"add" => ['payment_id', 'order_status', 'payment_type', 'order_amount', 'course_id', 'class_id', 'staff_id', 'resource_id', 'after_sales_status', 'after_sales_reason', 'after_sales_time', 'payment_time', 'subscription_payment_time'], "add" => ['resource_id', 'order_status', 'payment_type', 'order_amount', 'course_id', 'class_id'],
"edit" => ['payment_id', 'order_status', 'payment_type', 'order_amount', 'course_id', 'class_id', 'staff_id', 'resource_id', 'after_sales_status', 'after_sales_reason', 'after_sales_time', 'payment_time', 'subscription_payment_time'] "edit" => ['resource_id', 'order_status', 'payment_type', 'order_amount', 'course_id', 'class_id']
]; ];
} }

4
niucloud/app/validate/physical_test/PhysicalTest.php

@ -36,8 +36,8 @@ class PhysicalTest extends BaseValidate
]; ];
protected $scene = [ protected $scene = [
"add" => ['resource_id', 'student_id', 'height', 'weight', 'coach_id', 'created_at', 'updated_at', 'seated_forward_bend', 'sit_ups', 'push_ups', 'flamingo_balance', 'thirty_sec_jump', 'standing_long_jump', 'agility_run', 'balance_beam', 'tennis_throw', 'ten_meter_shuttle_run'], "add" => ['resource_id', 'student_id', 'height', 'weight', 'coach_id', 'seated_forward_bend', 'sit_ups', 'push_ups', 'flamingo_balance', 'thirty_sec_jump', 'standing_long_jump', 'agility_run', 'balance_beam', 'tennis_throw', 'ten_meter_shuttle_run'],
"edit" => ['resource_id', 'student_id', 'height', 'weight', 'coach_id', 'created_at', 'updated_at', 'seated_forward_bend', 'sit_ups', 'push_ups', 'flamingo_balance', 'thirty_sec_jump', 'standing_long_jump', 'agility_run', 'balance_beam', 'tennis_throw', 'ten_meter_shuttle_run'] "edit" => ['resource_id', 'student_id', 'height', 'weight', 'coach_id', 'seated_forward_bend', 'sit_ups', 'push_ups', 'flamingo_balance', 'thirty_sec_jump', 'standing_long_jump', 'agility_run', 'balance_beam', 'tennis_throw', 'ten_meter_shuttle_run']
]; ];
} }

Loading…
Cancel
Save