From a1d7e81859f554f3a53680cc35f0f49bf1f77098 Mon Sep 17 00:00:00 2001
From: wwf <1971391498@qq.com>
Date: 星期四, 14 五月 2026 14:37:02 +0800
Subject: [PATCH] 导入项目
---
src/views/mall/promotion/diy/page/decorate.vue | 74 +++++++++++++++++++++++++++++++++++++
1 files changed, 74 insertions(+), 0 deletions(-)
diff --git a/src/views/mall/promotion/diy/page/decorate.vue b/src/views/mall/promotion/diy/page/decorate.vue
new file mode 100644
index 0000000..fa20c3e
--- /dev/null
+++ b/src/views/mall/promotion/diy/page/decorate.vue
@@ -0,0 +1,74 @@
+<template>
+ <DiyEditor
+ v-if="formData && !formLoading"
+ v-model="formData.property"
+ :title="formData.name"
+ :libs="PAGE_LIBS"
+ @save="submitForm"
+ />
+</template>
+<script setup lang="ts">
+import * as DiyPageApi from '@/api/mall/promotion/diy/page'
+import { useTagsViewStore } from '@/store/modules/tagsView'
+import { PAGE_LIBS } from '@/components/DiyEditor/util'
+
+/** 瑁呬慨椤甸潰琛ㄥ崟 */
+defineOptions({ name: 'DiyPageDecorate' })
+
+const message = useMessage() // 娑堟伅寮圭獥
+
+const formLoading = ref(false) // 琛ㄥ崟鐨勫姞杞戒腑锛�1锛変慨鏀规椂鐨勬暟鎹姞杞斤紱2锛夋彁浜ょ殑鎸夐挳绂佺敤
+const formData = ref<DiyPageApi.DiyPageVO>()
+const formRef = ref() // 琛ㄥ崟 Ref
+
+// 鑾峰彇璇︽儏
+const getPageDetail = async (id: any) => {
+ formLoading.value = true
+ try {
+ formData.value = await DiyPageApi.getDiyPageProperty(id)
+ } finally {
+ formLoading.value = false
+ }
+}
+
+// 鎻愪氦琛ㄥ崟
+const submitForm = async () => {
+ // 鏍¢獙琛ㄥ崟
+ if (!formRef) return
+ // 鎻愪氦璇锋眰
+ formLoading.value = true
+ try {
+ await DiyPageApi.updateDiyPageProperty(unref(formData)!)
+ message.success('淇濆瓨鎴愬姛')
+ } finally {
+ formLoading.value = false
+ }
+}
+
+// 閲嶇疆琛ㄥ崟
+const resetForm = () => {
+ formData.value = {
+ id: undefined,
+ templateId: undefined,
+ name: '',
+ remark: '',
+ previewPicUrls: [],
+ property: ''
+ } as DiyPageApi.DiyPageVO
+ formRef.value?.resetFields()
+}
+
+/** 鍒濆鍖� **/
+const { currentRoute } = useRouter() // 璺敱
+const { delView } = useTagsViewStore() // 瑙嗗浘鎿嶄綔
+const route = useRoute()
+onMounted(() => {
+ resetForm()
+ if (!route.params.id) {
+ message.warning('鍙傛暟閿欒锛岄〉闈㈢紪鍙蜂笉鑳戒负绌猴紒')
+ delView(unref(currentRoute))
+ return
+ }
+ getPageDetail(route.params.id)
+})
+</script>
--
Gitblit v1.8.0