营销:接入 APP 装修页面

pull/36/head
owen 2024-01-11 11:55:24 +08:00
parent 1694a6f554
commit aa30c2659c
3 changed files with 37 additions and 34 deletions

View File

@ -1,35 +1,32 @@
<!-- 自定义页面支持装修 --> <!-- 自定义页面支持装修 -->
<template> <template>
<s-layout <s-layout
:title="page.name" :title="state.name"
navbar="custom" navbar="custom"
:bgStyle="page.style?.background" :bgStyle="state.page"
:navbarStyle="page.style?.navbar" :navbarStyle="state.navigationBar"
onShareAppMessage onShareAppMessage
showLeftButton showLeftButton
> >
<s-block v-for="(item, index) in page.list" :key="index" :styles="item.style"> <s-block v-for="(item, index) in state.components" :key="index" :styles="item.property.style">
<s-block-item :type="item.type" :data="item.data" :styles="item.style" /> <s-block-item :type="item.id" :data="item.property" :styles="item.property.style" />
</s-block> </s-block>
</s-layout> </s-layout>
</template> </template>
<script setup> <script setup>
import { computed, reactive } from 'vue'; import { reactive } from 'vue';
import sheep from '@/sheep';
import { onLoad, onPageScroll } from '@dcloudio/uni-app'; import { onLoad, onPageScroll } from '@dcloudio/uni-app';
import DiyPageApi from "@/sheep/api/promotion/diy/page";
const page = reactive({ const state = reactive({
name: '', name: '',
list: [], components: [],
style: {}, navigationBar: {},
page: {},
}); });
onLoad(async (options) => { onLoad(async (options) => {
let id; let id = options.id
if (options.id) {
id = options.id;
}
// #ifdef MP // #ifdef MP
// //
@ -39,12 +36,12 @@
} }
// #endif // #endif
// TODO @ const { code, data } = await DiyPageApi.getDiyPage(id);
const { error, data } = await sheep.$api.app.page(id); if (code === 0) {
if (error === 0) { state.name = data.name;
page.name = data.name; state.components = data.property?.components;
page.list = data.diypage?.page?.data; state.navigationBar = data.property?.navigationBar;
page.style = data.diypage?.page?.style; state.page = data.property?.page;
} }
}); });

View File

@ -0,0 +1,15 @@
import request from '@/sheep/request';
const DiyPageApi = {
getDiyPage: (id) => {
return request({
url: '/app-api/promotion/diy-page/get',
method: 'GET',
params: {
id
}
});
},
};
export default DiyPageApi;

View File

@ -307,26 +307,17 @@
type: [Array, Object], type: [Array, Object],
default() { default() {
return { return {
// TODO @
//
title: { show: true },
//
subtitle: { show: true },
// //
price: { show: true }, price: { show: true },
//
original_price: { show: true },
//
sales: { show: true },
// //
stock: { show: true }, stock: { show: true },
// //
name: { show: true }, name: { show: true },
// //
introduction: { show: true }, introduction: { show: true },
// //
marketPrice: { show: true }, marketPrice: { show: true },
// //
salesCount: { show: true }, salesCount: { show: true },
}; };
}, },