parent
							
								
									cace3d1743
								
							
						
					
					
						commit
						da5ad39251
					
				|  | @ -1,8 +1,6 @@ | |||
| import request from '@/config/axios' | ||||
| import { Sku, Spu } from '@/api/mall/product/spu' | ||||
| 
 | ||||
| // TODO @puhui999: combinationActivity.ts
 | ||||
| 
 | ||||
| export interface CombinationActivityVO { | ||||
|   id?: number | ||||
|   name?: string | ||||
|  | @ -6,6 +6,7 @@ | |||
|       :is-col="true" | ||||
|       :rules="rules" | ||||
|       :schema="allSchemas.formSchema" | ||||
|       class="mt-10px" | ||||
|     > | ||||
|       <template #spuId> | ||||
|         <el-button @click="spuSelectRef.open()">选择商品</el-button> | ||||
|  | @ -37,8 +38,8 @@ | |||
|   <SpuSelect ref="spuSelectRef" :isSelectSku="true" @confirm="selectSpu" /> | ||||
| </template> | ||||
| <script lang="ts" setup> | ||||
| import * as CombinationActivityApi from '@/api/mall/promotion/combination/combinationactivity' | ||||
| import { CombinationProductVO } from '@/api/mall/promotion/combination/combinationactivity' | ||||
| import * as CombinationActivityApi from '@/api/mall/promotion/combination/combinationActivity' | ||||
| import { CombinationProductVO } from '@/api/mall/promotion/combination/combinationActivity' | ||||
| import { allSchemas, rules } from './combinationActivity.data' | ||||
| import { SpuAndSkuList, SpuProperty, SpuSelect } from '@/views/mall/promotion/components' | ||||
| import { getPropertyList, RuleConfig } from '@/views/mall/product/spu/components' | ||||
|  | @ -1,5 +1,5 @@ | |||
| import type { CrudSchema } from '@/hooks/web/useCrudSchemas' | ||||
| import { dateFormatter, getNowDateTime } from '@/utils/formatTime' | ||||
| import { dateFormatter2 } from '@/utils/formatTime' | ||||
| 
 | ||||
| // 表单校验
 | ||||
| export const rules = reactive({ | ||||
|  | @ -26,29 +26,49 @@ const crudSchemas = reactive<CrudSchema[]>([ | |||
|     } | ||||
|   }, | ||||
|   { | ||||
|     label: '活动时间', | ||||
|     field: 'activityTime', | ||||
|     formatter: dateFormatter, | ||||
|     label: '活动开始时间', | ||||
|     field: 'startTime', | ||||
|     formatter: dateFormatter2, | ||||
|     isSearch: true, | ||||
|     search: { | ||||
|       show: true, | ||||
|       component: 'DatePicker', | ||||
|       componentProps: { | ||||
|         valueFormat: 'x', | ||||
|         type: 'datetimerange', | ||||
|         rangeSeparator: '至' | ||||
|         valueFormat: 'YYYY-MM-DD', | ||||
|         type: 'daterange' | ||||
|       } | ||||
|     }, | ||||
|     form: { | ||||
|       component: 'DatePicker', | ||||
|       componentProps: { | ||||
|         valueFormat: 'x', | ||||
|         type: 'datetimerange', | ||||
|         rangeSeparator: '至' | ||||
|       }, | ||||
|       value: [getNowDateTime().valueOf(), getNowDateTime().valueOf()], | ||||
|       colProps: { | ||||
|         span: 24 | ||||
|         type: 'date', | ||||
|         valueFormat: 'x' | ||||
|       } | ||||
|     }, | ||||
|     table: { | ||||
|       width: 120 | ||||
|     } | ||||
|   }, | ||||
|   { | ||||
|     label: '活动结束时间', | ||||
|     field: 'endTime', | ||||
|     formatter: dateFormatter2, | ||||
|     isSearch: true, | ||||
|     search: { | ||||
|       component: 'DatePicker', | ||||
|       componentProps: { | ||||
|         valueFormat: 'YYYY-MM-DD', | ||||
|         type: 'daterange' | ||||
|       } | ||||
|     }, | ||||
|     form: { | ||||
|       component: 'DatePicker', | ||||
|       componentProps: { | ||||
|         type: 'date', | ||||
|         valueFormat: 'x' | ||||
|       } | ||||
|     }, | ||||
|     table: { | ||||
|       width: 120 | ||||
|     } | ||||
|   }, | ||||
|   { | ||||
|  | @ -63,7 +63,7 @@ | |||
| </template> | ||||
| <script lang="ts" setup> | ||||
| import { allSchemas } from './combinationActivity.data' | ||||
| import * as CombinationActivityApi from '@/api/mall/promotion/combination/combinationactivity' | ||||
| import * as CombinationActivityApi from '@/api/mall/promotion/combination/combinationActivity' | ||||
| import CombinationActivityForm from './CombinationActivityForm.vue' | ||||
| import { cloneDeep } from 'lodash-es' | ||||
| import { createImageViewer } from '@/components/ImageViewer' | ||||
|  | @ -102,10 +102,10 @@ const handleDelete = (id: number) => { | |||
| /** 初始化 **/ | ||||
| onMounted(() => { | ||||
|   /** | ||||
|  TODO | ||||
|  后面准备封装成一个函数来操作 tableColumns 重新排列:比如说需求是表单上商品选择是在后面的而列表展示的时候需要调到位置。 | ||||
|  封装效果支持批量操作,给出 field 和需要插入的位置,例:[{field:'spuId',index: 1}] 效果为把 field 为 spuId 的 column 移动到第一个位置 | ||||
|  */ | ||||
|    TODO | ||||
|    后面准备封装成一个函数来操作 tableColumns 重新排列:比如说需求是表单上商品选择是在后面的而列表展示的时候需要调到位置。 | ||||
|    封装效果支持批量操作,给出 field 和需要插入的位置,例:[{field:'spuId',index: 1}] 效果为把 field 为 spuId 的 column 移动到第一个位置 | ||||
|    */ | ||||
|   // 处理一下表格列让商品往前 | ||||
|   const index = allSchemas.tableColumns.findIndex((item) => item.field === 'spuId') | ||||
|   const column = cloneDeep(allSchemas.tableColumns[index]) | ||||
		Loading…
	
		Reference in New Issue
	
	 puhui999
						puhui999