review:【antd】【mall】diy 店铺装修

pull/289/head^2
YunaiV 2025-12-01 19:40:07 +08:00
parent 60400525cc
commit 16f9057e1c
3 changed files with 24 additions and 29 deletions

View File

@ -27,34 +27,28 @@ const route = useRoute();
const { refreshTab } = useTabs();
const domain = import.meta.env.VITE_MALL_H5_DOMAIN;
// reset selectedTemplateItem
const DIY_PAGE_INDEX_KEY = 'diy_page_index';
const DIY_PAGE_INDEX_KEY = 'diy_page_index'; // reset selectedTemplateItem
const selectedTemplateItem = ref(0);
//
const templateItems = ref([
{ key: 0, name: '基础设置', icon: 'lucide:settings' },
{ key: 1, name: '首页', icon: 'lucide:home' },
{ key: 2, name: '我的', icon: 'lucide:user' },
]);
]); //
const formData = ref<MallDiyTemplateApi.DiyTemplateProperty>();
//
const currentFormData = ref<
MallDiyPageApi.DiyPage | MallDiyTemplateApi.DiyTemplateProperty
>({
property: '',
} as MallDiyPageApi.DiyPage);
// templateItem
} as MallDiyPageApi.DiyPage); //
const currentFormDataMap = ref<
Map<string, MallDiyPageApi.DiyPage | MallDiyTemplateApi.DiyTemplateProperty>
>(new Map());
// H5
const previewUrl = ref('');
//
const templateLibs = [] as DiyComponentLibrary[];
//
const libs = ref<DiyComponentLibrary[]>(templateLibs);
>(new Map()); // templateItem
const previewUrl = ref(''); // H5
const templateLibs = [] as DiyComponentLibrary[]; //
const libs = ref<DiyComponentLibrary[]>(templateLibs); //
/** 获取详情 */
async function getPageDetail(id: any) {
@ -73,9 +67,8 @@ async function getPageDetail(id: any) {
}
/** 模板选项切换 */
/** 模板选项切换 */
function handleTemplateItemChange(val: any) {
const valIndex = val.target.value;
function handleTemplateItemChange(valObj: any) {
const val = valObj.target.value;
//
currentFormDataMap.value.set(
templateItems.value[selectedTemplateItem.value]?.name || '',
@ -83,14 +76,14 @@ function handleTemplateItemChange(val: any) {
);
//
const data = currentFormDataMap.value.get(
templateItems.value[valIndex]?.name || '',
templateItems.value[val]?.name || '',
);
//
selectedTemplateItem.value = valIndex;
selectedTemplateItem.value = val;
//
if (valIndex === 0) {
if (val === 0) {
libs.value = templateLibs;
currentFormData.value = (isEmpty(data) ? formData.value : data) as
| MallDiyPageApi.DiyPage
@ -104,7 +97,7 @@ function handleTemplateItemChange(val: any) {
isEmpty(data)
? formData.value!.pages.find(
(page: MallDiyPageApi.DiyPage) =>
page.name === templateItems.value[valIndex]?.name,
page.name === templateItems.value[val]?.name,
)
: data
) as MallDiyPageApi.DiyPage | MallDiyTemplateApi.DiyTemplateProperty;

View File

@ -14,7 +14,7 @@ defineOptions({ name: 'TabNews' });
const props = defineProps<{
modelValue: Reply;
newsType: NewsType;
newsType?: NewsType;
}>();
const emit = defineEmits<{

View File

@ -3,7 +3,7 @@ import type { MallDiyPageApi } from '#/api/mall/promotion/diy/page';
import type { MallDiyTemplateApi } from '#/api/mall/promotion/diy/template';
import type { DiyComponentLibrary } from '#/views/mall/promotion/components'; // DIY DiyEditor
import { onMounted, reactive, ref } from 'vue';
import { onMounted, ref } from 'vue';
import { useRoute } from 'vue-router';
import { useTabs } from '@vben/hooks';
@ -35,7 +35,7 @@ const { refreshTab } = useTabs();
const DIY_PAGE_INDEX_KEY = 'diy_page_index'; // reset selectedTemplateItem
const selectedTemplateItem = ref(0);
const templateItems = reactive([
const templateItems = ref([
{ name: '基础设置', icon: 'ep:iphone' },
{ name: '首页', icon: 'ep:home-filled' },
{ name: '我的', icon: 'ep:user-filled' },
@ -77,11 +77,13 @@ async function getPageDetail(id: any) {
function handleTemplateItemChange(val: any) {
//
currentFormDataMap.value.set(
templateItems[selectedTemplateItem.value]?.name || '',
templateItems.value[selectedTemplateItem.value]?.name || '',
currentFormData.value!,
);
//
const data = currentFormDataMap.value.get(templateItems[val]?.name || '');
const data = currentFormDataMap.value.get(
templateItems.value[val]?.name || '',
);
//
selectedTemplateItem.value = val;
@ -101,7 +103,7 @@ function handleTemplateItemChange(val: any) {
isEmpty(data)
? formData.value!.pages.find(
(page: MallDiyPageApi.DiyPage) =>
page.name === templateItems[val]?.name,
page.name === templateItems.value[val]?.name,
)
: data
) as MallDiyPageApi.DiyPage | MallDiyTemplateApi.DiyTemplateProperty;
@ -114,7 +116,7 @@ async function submitForm() {
});
try {
// templateItems templateItem
for (const [i, templateItem] of templateItems.entries()) {
for (const [i, templateItem] of templateItems.value.entries()) {
const data = currentFormDataMap.value.get(templateItem.name) as any;
//
if (i === 0) {
@ -188,7 +190,7 @@ onMounted(async () => {
:show-navigation-bar="selectedTemplateItem !== 0"
:show-page-config="selectedTemplateItem !== 0"
:show-tab-bar="selectedTemplateItem === 0"
:title="templateItems[selectedTemplateItem]?.name || ''"
:title="templateItems[selectedTemplateItem]?.name ?? ''"
@reset="handleEditorReset"
@save="submitForm"
>