feat(uniapp_v2): 二开功能迁移与小程序主包优化

- 从 uniapp 迁移 HJF 页面、API、组件及用户/订单相关改动
- queue、assets 使用独立分包以降低主包体积
- 修复首页单根节点与支付结果页 v-if 链
- 关闭 HjfDemoPanel 全局注册;uniNoticeBar 注释 $getAppWebview 避免 __webviewId__ 报错
- 配置域名与 manifest 应用名称;cache/store 防御性处理

Made-with: Cursor
This commit is contained in:
apple
2026-03-26 12:16:01 +08:00
parent c84aeda062
commit 8e17762510
742 changed files with 184117 additions and 0 deletions

View File

@@ -0,0 +1,113 @@
<template>
<!-- 标题 -->
<view v-if="!dataConfig.isHide" :style="[titleWrapperStyle]">
<view :style="[titleWrapStyle]">
<view @click="goLink" class="title acea-row row-middle row-between" :style="[titleLocation]">
<view :style="[titleStyle]">{{dataConfig.titleConfig.value}}</view>
<view class="more" v-if="!dataConfig.buttonConfig.tabVal" :style="[moreStyle]">
{{dataConfig.titleConfigRight.value}}
<text class="iconfont icon-ic_rightarrow"></text>
</view>
</view>
</view>
</view>
</template>
<script>
export default {
name: 'titles',
props: {
dataConfig: {
type: Object,
default: () => {}
},
isSortType: {
type: String | Number,
default: 0
}
},
computed: {
titleWrapperStyle() {
return {
'padding': `${this.dataConfig.topConfig.val * 2}rpx ${this.dataConfig.prConfig.val * 2}rpx ${this.dataConfig.bottomConfig.val * 2}rpx`,
'margin-top': `${this.dataConfig.mbConfig.val * 2}rpx`,
'background': this.dataConfig.bottomBgColor.color[0].item,
};
},
titleWrapStyle() {
let borderRadius = `${this.dataConfig.fillet.val * 2}rpx`;
if (this.dataConfig.fillet.type) {
borderRadius =
`${this.dataConfig.fillet.valList[0].val * 2}rpx ${this.dataConfig.fillet.valList[1].val * 2}rpx ${this.dataConfig.fillet.valList[2].val * 2}rpx ${this.dataConfig.fillet.valList[3].val * 2}rpx`;
}
return {
'border-radius': borderRadius,
'background': `linear-gradient(90deg, ${this.dataConfig.titleColor.color[0].item} 0%, ${this.dataConfig.titleColor.color[1].item} 100%)`,
};
},
titleStyle() {
let style = {
'font-size': `${this.dataConfig.fontSize.val * 2}rpx`,
'color': this.dataConfig.themeColor.color[0].item,
};
switch (this.dataConfig.textStyle.tabVal) {
case 1:
style['font-style'] = 'italic';
break;
case 2:
style['font-weight'] = 'bold';
break;
}
return style;
},
titleLocation() {
if(this.dataConfig.buttonConfig.tabVal){
let style = {}
switch (this.dataConfig.textPosition.tabVal) {
case 1:
style['justify-content'] = 'center';
break;
case 2:
style['justify-content'] = 'flex-end';
break;
}
return style;
}
},
moreStyle() {
return {
'font-size': `${this.dataConfig.buttonText.val * 2}rpx`,
'color': this.dataConfig.buttonColor.color[0].item,
};
},
},
methods: {
goLink() {
this.$util.JumpPath(this.dataConfig.linkConfig.value);
}
}
}
</script>
<style lang="scss">
.title {
justify-content: space-between;
padding: 26rpx 24rpx;
border-radius: 16rpx 16rpx 0rpx 0rpx;
font-weight: 500;
font-size: 32rpx;
line-height: 44rpx;
color: #333333;
.more {
font-weight: 400;
font-size: 24rpx;
line-height: 34rpx;
color: #999999;
}
.iconfont {
font-size: 24rpx;
}
}
</style>