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

This commit is contained in:
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 { refreshTab } = useTabs();
const domain = import.meta.env.VITE_MALL_H5_DOMAIN; const domain = import.meta.env.VITE_MALL_H5_DOMAIN;
// 特殊:存储 reset 重置时,当前 selectedTemplateItem 值,从而进行恢复 const DIY_PAGE_INDEX_KEY = 'diy_page_index'; // 特殊:存储 reset 重置时,当前 selectedTemplateItem 值,从而进行恢复
const DIY_PAGE_INDEX_KEY = 'diy_page_index';
const selectedTemplateItem = ref(0); const selectedTemplateItem = ref(0);
// 左上角工具栏操作按钮
const templateItems = ref([ const templateItems = ref([
{ key: 0, name: '基础设置', icon: 'lucide:settings' }, { key: 0, name: '基础设置', icon: 'lucide:settings' },
{ key: 1, name: '首页', icon: 'lucide:home' }, { key: 1, name: '首页', icon: 'lucide:home' },
{ key: 2, name: '我的', icon: 'lucide:user' }, { key: 2, name: '我的', icon: 'lucide:user' },
]); ]); // 左上角工具栏操作按钮
const formData = ref<MallDiyTemplateApi.DiyTemplateProperty>(); const formData = ref<MallDiyTemplateApi.DiyTemplateProperty>();
// 当前编辑的属性
const currentFormData = ref< const currentFormData = ref<
MallDiyPageApi.DiyPage | MallDiyTemplateApi.DiyTemplateProperty MallDiyPageApi.DiyPage | MallDiyTemplateApi.DiyTemplateProperty
>({ >({
property: '', property: '',
} as MallDiyPageApi.DiyPage); } as MallDiyPageApi.DiyPage); // 当前编辑的属性
// templateItem 对应的缓存
const currentFormDataMap = ref< const currentFormDataMap = ref<
Map<string, MallDiyPageApi.DiyPage | MallDiyTemplateApi.DiyTemplateProperty> Map<string, MallDiyPageApi.DiyPage | MallDiyTemplateApi.DiyTemplateProperty>
>(new Map()); >(new Map()); // templateItem 对应的缓存
// 商城 H5 预览地址
const previewUrl = ref(''); const previewUrl = ref(''); // 商城 H5 预览地址
// 模板组件库 const templateLibs = [] as DiyComponentLibrary[]; // 模板组件库
const templateLibs = [] as DiyComponentLibrary[]; const libs = ref<DiyComponentLibrary[]>(templateLibs); // 当前组件库
// 当前组件库
const libs = ref<DiyComponentLibrary[]>(templateLibs);
/** 获取详情 */ /** 获取详情 */
async function getPageDetail(id: any) { async function getPageDetail(id: any) {
@@ -73,9 +67,8 @@ async function getPageDetail(id: any) {
} }
/** 模板选项切换 */ /** 模板选项切换 */
/** 模板选项切换 */ function handleTemplateItemChange(valObj: any) {
function handleTemplateItemChange(val: any) { const val = valObj.target.value;
const valIndex = val.target.value;
// 缓存模版编辑数据 // 缓存模版编辑数据
currentFormDataMap.value.set( currentFormDataMap.value.set(
templateItems.value[selectedTemplateItem.value]?.name || '', templateItems.value[selectedTemplateItem.value]?.name || '',
@@ -83,14 +76,14 @@ function handleTemplateItemChange(val: any) {
); );
// 读取模版缓存 // 读取模版缓存
const data = currentFormDataMap.value.get( 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; libs.value = templateLibs;
currentFormData.value = (isEmpty(data) ? formData.value : data) as currentFormData.value = (isEmpty(data) ? formData.value : data) as
| MallDiyPageApi.DiyPage | MallDiyPageApi.DiyPage
@@ -104,7 +97,7 @@ function handleTemplateItemChange(val: any) {
isEmpty(data) isEmpty(data)
? formData.value!.pages.find( ? formData.value!.pages.find(
(page: MallDiyPageApi.DiyPage) => (page: MallDiyPageApi.DiyPage) =>
page.name === templateItems.value[valIndex]?.name, page.name === templateItems.value[val]?.name,
) )
: data : data
) as MallDiyPageApi.DiyPage | MallDiyTemplateApi.DiyTemplateProperty; ) as MallDiyPageApi.DiyPage | MallDiyTemplateApi.DiyTemplateProperty;

View File

@@ -14,7 +14,7 @@ defineOptions({ name: 'TabNews' });
const props = defineProps<{ const props = defineProps<{
modelValue: Reply; modelValue: Reply;
newsType: NewsType; newsType?: NewsType;
}>(); }>();
const emit = defineEmits<{ 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 { MallDiyTemplateApi } from '#/api/mall/promotion/diy/template';
import type { DiyComponentLibrary } from '#/views/mall/promotion/components'; // 商城的 DIY 组件,在 DiyEditor 目录下 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 { useRoute } from 'vue-router';
import { useTabs } from '@vben/hooks'; import { useTabs } from '@vben/hooks';
@@ -35,7 +35,7 @@ const { refreshTab } = useTabs();
const DIY_PAGE_INDEX_KEY = 'diy_page_index'; // 特殊:存储 reset 重置时,当前 selectedTemplateItem 值,从而进行恢复 const DIY_PAGE_INDEX_KEY = 'diy_page_index'; // 特殊:存储 reset 重置时,当前 selectedTemplateItem 值,从而进行恢复
const selectedTemplateItem = ref(0); const selectedTemplateItem = ref(0);
const templateItems = reactive([ const templateItems = ref([
{ name: '基础设置', icon: 'ep:iphone' }, { name: '基础设置', icon: 'ep:iphone' },
{ name: '首页', icon: 'ep:home-filled' }, { name: '首页', icon: 'ep:home-filled' },
{ name: '我的', icon: 'ep:user-filled' }, { name: '我的', icon: 'ep:user-filled' },
@@ -77,11 +77,13 @@ async function getPageDetail(id: any) {
function handleTemplateItemChange(val: any) { function handleTemplateItemChange(val: any) {
// 缓存模版编辑数据 // 缓存模版编辑数据
currentFormDataMap.value.set( currentFormDataMap.value.set(
templateItems[selectedTemplateItem.value]?.name || '', templateItems.value[selectedTemplateItem.value]?.name || '',
currentFormData.value!, currentFormData.value!,
); );
// 读取模版缓存 // 读取模版缓存
const data = currentFormDataMap.value.get(templateItems[val]?.name || ''); const data = currentFormDataMap.value.get(
templateItems.value[val]?.name || '',
);
// 切换模版 // 切换模版
selectedTemplateItem.value = val; selectedTemplateItem.value = val;
@@ -101,7 +103,7 @@ function handleTemplateItemChange(val: any) {
isEmpty(data) isEmpty(data)
? formData.value!.pages.find( ? formData.value!.pages.find(
(page: MallDiyPageApi.DiyPage) => (page: MallDiyPageApi.DiyPage) =>
page.name === templateItems[val]?.name, page.name === templateItems.value[val]?.name,
) )
: data : data
) as MallDiyPageApi.DiyPage | MallDiyTemplateApi.DiyTemplateProperty; ) as MallDiyPageApi.DiyPage | MallDiyTemplateApi.DiyTemplateProperty;
@@ -114,7 +116,7 @@ async function submitForm() {
}); });
try { try {
// 对所有的 templateItems 都进行保存,有缓存则保存缓存,解决都有修改时只保存了当前所编辑的 templateItem导致装修效果存在差异 // 对所有的 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; const data = currentFormDataMap.value.get(templateItem.name) as any;
// 情况一:基础设置 // 情况一:基础设置
if (i === 0) { if (i === 0) {
@@ -188,7 +190,7 @@ onMounted(async () => {
:show-navigation-bar="selectedTemplateItem !== 0" :show-navigation-bar="selectedTemplateItem !== 0"
:show-page-config="selectedTemplateItem !== 0" :show-page-config="selectedTemplateItem !== 0"
:show-tab-bar="selectedTemplateItem === 0" :show-tab-bar="selectedTemplateItem === 0"
:title="templateItems[selectedTemplateItem]?.name || ''" :title="templateItems[selectedTemplateItem]?.name ?? ''"
@reset="handleEditorReset" @reset="handleEditorReset"
@save="submitForm" @save="submitForm"
> >