Files
happy-life-star/mini-program/src/App.vue
T
peanut 89fc42819d feat: AI 场景路由、ASR 服务及前后端全链路同步
- 新增 AI 场景路由控制器和管理接口
- 新增 ASR 语音识别服务及前后端集成
- 同步 AI Runtime 客户端到 Web/小程序/Life-Script
- 完善 AI 配置测试修复和管理后台路由配置
- 新增数据库迁移脚本

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-23 13:25:21 +08:00

134 lines
3.3 KiB
Vue

<script setup>
import { ref } from 'vue'
import { onLaunch, onShow, onHide } from '@dcloudio/uni-app'
import { logRuntimeEnv } from './services/request.js'
import analytics from './services/analytics.js'
const statusBarHeight = ref(0)
const safeAreaTop = ref(0)
const safeAreaBottom = ref(0)
const hydrateSafeArea = () => {
try {
const windowInfo = uni.getWindowInfo ? uni.getWindowInfo() : uni.getSystemInfoSync()
statusBarHeight.value = windowInfo.statusBarHeight || 20
safeAreaTop.value = windowInfo.safeAreaInsets?.top || windowInfo.statusBarHeight || 20
safeAreaBottom.value = windowInfo.safeAreaInsets?.bottom || 0
uni.setStorageSync('statusBarHeight', statusBarHeight.value)
uni.setStorageSync('safeAreaTop', safeAreaTop.value)
uni.setStorageSync('safeAreaBottom', safeAreaBottom.value)
} catch (error) {
statusBarHeight.value = 20
safeAreaTop.value = 20
safeAreaBottom.value = 0
}
}
onLaunch(() => {
console.log('App Launch')
analytics.initAnalytics()
logRuntimeEnv('app:onLaunch')
hydrateSafeArea()
})
onShow(() => {
console.log('App Show')
analytics.track('app_show', {}, { eventType: 'app' })
})
onHide(() => {
console.log('App Hide')
analytics.track('app_hide', {}, { eventType: 'app' })
analytics.flush()
})
</script>
<style>
page {
width: 100%;
height: 100%;
overflow: hidden;
color: #f8f4ff;
background: #050615;
font-family: -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", sans-serif;
font-size: 28rpx;
line-height: 1.45;
-webkit-font-smoothing: antialiased;
}
button {
padding: 0;
margin: 0;
border: 0;
color: inherit;
background: transparent;
line-height: normal;
font: inherit;
}
button::after {
border: 0;
}
input,
textarea {
color: #f8f4ff;
font: inherit;
}
::-webkit-scrollbar {
width: 0;
height: 0;
display: none;
}
.safe-area-bottom {
padding-bottom: constant(safe-area-inset-bottom);
padding-bottom: env(safe-area-inset-bottom);
}
.safe-area-top {
padding-top: constant(safe-area-inset-top);
padding-top: env(safe-area-inset-top);
}
.kos-page {
min-height: 100vh;
color: #f8f4ff;
background:
radial-gradient(circle at 78% 10%, rgba(111, 55, 255, 0.32), transparent 28%),
radial-gradient(circle at 14% 34%, rgba(36, 124, 255, 0.17), transparent 28%),
linear-gradient(180deg, #07091b 0%, #07031a 46%, #04030f 100%);
}
.kos-card {
border: 1rpx solid rgba(163, 92, 255, 0.38);
background:
linear-gradient(145deg, rgba(31, 23, 76, 0.78), rgba(8, 8, 30, 0.9)),
radial-gradient(circle at 90% 20%, rgba(139, 78, 255, 0.14), transparent 38%);
box-shadow:
inset 0 0 44rpx rgba(147, 92, 255, 0.08),
0 22rpx 64rpx rgba(0, 0, 0, 0.26);
backdrop-filter: blur(24rpx);
-webkit-backdrop-filter: blur(24rpx);
}
.kos-pill {
border: 1rpx solid rgba(157, 108, 255, 0.34);
background: rgba(255, 255, 255, 0.055);
box-shadow: inset 0 0 20rpx rgba(160, 96, 255, 0.08);
}
.kos-primary {
color: #fff;
background:
radial-gradient(circle at 68% 20%, rgba(255, 255, 255, 0.28), transparent 22%),
linear-gradient(135deg, #b045ff 0%, #612eff 56%, #2b1aff 100%);
box-shadow: 0 18rpx 42rpx rgba(129, 66, 255, 0.38), inset 0 0 20rpx rgba(255, 255, 255, 0.1);
}
.placeholder {
color: rgba(213, 199, 239, 0.42);
}
</style>