2025-10-15

添加字体
项目描述
聊天记录加载修改
This commit is contained in:
2025-10-15 17:22:54 +08:00
parent f53ec45c51
commit ad2ce26c08
29 changed files with 310 additions and 45 deletions

View File

@@ -44,4 +44,12 @@
<style lang="scss"> <style lang="scss">
@import "./uni_modules/vk-uview-ui/index.scss"; @import "./uni_modules/vk-uview-ui/index.scss";
// @import "./static/fontsFamily/ht.css";
// @import "./static/fontsFamily/fs.css";
// @import "./static/fontsFamily/kt.css";
// @import "./static/fontsFamily/bkt.css";
// @import "./static/fontsFamily/hwfs.css";
// @import "./static/fontsFamily/hwkt.css";
// @import "./static/fontsFamily/st.css";
// @import "./static/fontsFamily/wryh.css";
</style> </style>

View File

@@ -2,7 +2,8 @@ import {
http http
} from "../util/api" } from "../util/api"
const baseURL = "http://192.168.0.12:3005/term" // const baseURL = "http://192.168.0.12:3005/term"
const baseURL = "http://192.168.0.15:3006"
// 项目相关API // 项目相关API
export const programAPI = { export const programAPI = {

View File

@@ -17,7 +17,8 @@
{ {
"path": "pages/my/my", "path": "pages/my/my",
"style": { "style": {
"navigationBarTitleText": "我的" "navigationBarTitleText": "我的",
"navigationStyle": "custom"
} }
}, },
{ {

View File

@@ -563,16 +563,21 @@
userId.value = uni.getStorageSync("user").id userId.value = uni.getStorageSync("user").id
// 获取标题 // 获取标题
groupAPI.getById(groupId.value).then(res => { groupAPI.getById(groupId.value).then(res => {
chatTitle.value = res.data.program.linkman.username + "(" + res.data.program.name + ")" // chatTitle.value = res.data.program.linkman.username + "(" + res.data.program.name + ")"
chatTitle.value = res.data.program.name
}) })
loadHistoryData() // 最近10条
setTimeout(()=>{
scrollToBottom()
}, 1000)
// 未读变已读 // 未读变已读
let data = { groupId: groupId.value, userId: userId.value } // let data = { groupId: groupId.value, userId: userId.value }
messageAPI.unread(data).then(res => { // messageAPI.unread(data).then(res => {
if (res.code == 200) { // if (res.code == 200) {
dataList.value = dataList.value.concat(res.data) // dataList.value = dataList.value.concat(res.data)
} // }
}) // })
messageAPI.read({ groupId: groupId.value, userId: userId.value }) messageAPI.read({ groupId: groupId.value, userId: userId.value })
} }
@@ -584,10 +589,10 @@
const loadFix = ref(true) const loadFix = ref(true)
// 历史记录 // 历史记录
const loadHistoryData = () => { const loadHistoryData = async () => {
params.value.groupId = groupId.value params.value.groupId = groupId.value
messageAPI.list(params.value).then(res => { await messageAPI.list(params.value).then(res => {
console.log(res); // console.log(res);
if (res.data.list.length != 0) { if (res.data.list.length != 0) {
res.data.list.forEach(item => { res.data.list.forEach(item => {
dataList.value.unshift(item) dataList.value.unshift(item)
@@ -793,6 +798,7 @@
.img-content { .img-content {
margin-left: 10rpx; margin-left: 10rpx;
height: 200rpx; height: 200rpx;
margin-bottom: 30rpx;
} }
} }

View File

@@ -1,12 +1,59 @@
<template> <template>
<view class="my-container"> <view class="my-container">
<scroll-view scroll-y="true" style="height: 100%;">
<view v-if="user!=null">
<view class="header">
<view class="header-user">
<view class="header-avatar">
<u-avatar :src="getImageUrl(user.avatar)"></u-avatar>
</view>
<view class="header-username u-m-l-10">
{{user.real_name}}
</view>
</view>
<view class="header-setting">
<image src="/static/icon/Settings.png" style="width: 100%;height: 100%;" mode=""></image>
</view>
</view>
<view v-if="user!=null"> <view class="statistics">
{{user.real_name}} <view class="item">
</view> <view class="count">
111
<u-button @click="loginOut">退出登录</u-button> </view>
<view class="title">
积分
</view>
</view>
<view class="item">
<view class="count">
5
</view>
<view class="title">
优惠券
</view>
</view>
<view class="item">
<view class="count">
10
</view>
<view class="title">
我的兑换
</view>
</view>
<view class="item">
<view class="count">
283
</view>
<view class="title">
我的收藏
</view>
</view>
</view>
<u-button @click="loginOut">退出登录</u-button>
</view>
</scroll-view>
</view> </view>
<Tabbar></Tabbar> <Tabbar></Tabbar>
</template> </template>
@@ -14,10 +61,13 @@
<script setup lang="ts"> <script setup lang="ts">
import { onMounted, ref } from 'vue'; import { onMounted, ref } from 'vue';
import { getImageUrl } from '../../util/common';
const user = ref() const user = ref()
onMounted(() => { onMounted(() => {
user.value = uni.getStorageSync("user") user.value = uni.getStorageSync("user")
console.log(user.value);
}) })
const loginOut = () => { const loginOut = () => {
@@ -29,5 +79,42 @@
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">
.my-container {} .my-container {
width: 100%;
height: 100vh;
background: linear-gradient(180deg, #E3E8FF 0%, #E8EAF4 100%);
background-blend-mode: lighten;
padding: 60rpx 20rpx;
.header {
display: flex;
width: 100%;
justify-content: flex-end;
.header-user {
padding: 20rpx 10rpx;
flex: 1;
display: flex;
align-items: center;
}
.header-setting {
width: 52rpx;
height: 52rpx;
}
}
.statistics{
display: flex;
.item{
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
width: 25%;
border: 1rpx solid #000;
}
}
}
</style> </style>

View File

@@ -7,14 +7,14 @@
<u-search :show-action="false" placeholder="输入项目名称、企业名称" v-model="params.keyword" bgColor="#CADBFF" <u-search :show-action="false" placeholder="输入项目名称、企业名称" v-model="params.keyword" bgColor="#CADBFF"
@search="handleSearch"></u-search> @search="handleSearch"></u-search>
</view> </view>
<u-dropdown :duration="0" class="dropdown"> <!-- <u-dropdown :duration="0" class="dropdown">
<u-dropdown-item class="u-dropdown" v-model="areaFilter" title="区域筛选" <u-dropdown-item class="u-dropdown" v-model="areaFilter" title="区域筛选"
:options="areaOptions"></u-dropdown-item> :options="areaOptions"></u-dropdown-item>
<u-dropdown-item class="u-dropdown" v-model="timeFilter" title="时间筛选" <u-dropdown-item class="u-dropdown" v-model="timeFilter" title="时间筛选"
:options="timeOptions"></u-dropdown-item> :options="timeOptions"></u-dropdown-item>
<u-dropdown-item class="u-dropdown" v-model="typeFilter" title="类型筛选" <u-dropdown-item class="u-dropdown" v-model="typeFilter" title="类型筛选"
:options="typeOptions"></u-dropdown-item> :options="typeOptions"></u-dropdown-item>
</u-dropdown> </u-dropdown> -->
</view> </view>
<view class="program-list" :style="'height:'+scrollHeight+'px'"> <view class="program-list" :style="'height:'+scrollHeight+'px'">
@@ -37,9 +37,9 @@
<view class="program-contact"> <view class="program-contact">
项目联系人{{maskPhoneNumber(item.user.username)}} 项目联系人{{maskPhoneNumber(item.user.username)}}
</view> </view>
<view class="program-introduction"> <!-- <view class="program-introduction">
项目简介{{item.introduction}} 项目简介<span v-html="item.introduction"></span>
</view> </view> -->
</view> </view>
</view> </view>
<u-loadmore color="#fff" :status="status" /> <u-loadmore color="#fff" :status="status" />
@@ -131,7 +131,7 @@
// 列表 // 列表
const programList = ref([]) const programList = ref([])
const defaultSize = 5 const defaultSize = 10
const params = ref({ const params = ref({
page: 1, page: 1,
size: defaultSize, size: defaultSize,

View File

@@ -1,5 +1,5 @@
<template> <template>
<view class="detail-contrainer"> <scroll-view class="detail-contrainer" scroll-y="true">
<u-navbar :is-fixed="false" title="项目详情" :background="{background: 'transparent' }" :border-bottom="false" <u-navbar :is-fixed="false" title="项目详情" :background="{background: 'transparent' }" :border-bottom="false"
back-icon-color="#fff" title-color="#fff"> back-icon-color="#fff" title-color="#fff">
<template v-slot:right> <template v-slot:right>
@@ -47,6 +47,18 @@
</view> </view>
<view class="card"> <view class="card">
<view class="card-title">
<view class="icon">
<image style="width: 100%;height: 100%;" src="/static/icon/card-title-icon.png" mode=""></image>
</view>
项目需求<span>4</span>
</view>
<view class="u-m-t-10 editor-content-view">
<view v-html="program.introduction"></view>
</view>
</view>
<!-- <view class="card">
<view class="card-title"> <view class="card-title">
<view class="icon"> <view class="icon">
<image style="width: 100%;height: 100%;" src="/static/icon/card-title-icon.png" mode=""></image> <image style="width: 100%;height: 100%;" src="/static/icon/card-title-icon.png" mode=""></image>
@@ -76,7 +88,6 @@
</view> </view>
</view> </view>
<view class="card"> <view class="card">
<view class="card-title"> <view class="card-title">
<view class="icon"> <view class="icon">
@@ -94,7 +105,7 @@
<u-col span="6" class="card-value">5</u-col> <u-col span="6" class="card-value">5</u-col>
</u-row> </u-row>
</view> </view>
</view> </view> -->
<u-row justify="flex-end" class="u-m-r-40 btn-group"> <u-row justify="flex-end" class="u-m-r-40 btn-group">
<u-col span="3"><u-button class="btn" type="primary" <u-col span="3"><u-button class="btn" type="primary"
@@ -102,7 +113,13 @@
<u-col span="3"><u-button class="btn" type="success" @click="handleOpen">立刻融</u-button></u-col> <u-col span="3"><u-button class="btn" type="success" @click="handleOpen">立刻融</u-button></u-col>
</u-row> </u-row>
<u-link class="change-next" @click="handleChange">不感兴趣换一个</u-link> <view class="change-next u-m-t-60">
<u-link @click="handleChange">不感兴趣换一个</u-link>
</view>
<!-- 占位 -->
<view style="height: 20rpx;">
</view>
<u-modal v-model="showWarning" border-radius="20" ref="warningRef" :mask-close-able="true" <u-modal v-model="showWarning" border-radius="20" ref="warningRef" :mask-close-able="true"
@@ -168,15 +185,29 @@
</u-modal> </u-modal>
<u-toast ref="pdMsgRef" /> <u-toast ref="pdMsgRef" />
</view> </scroll-view>
</template> </template>
<script setup lang="ts"> <script setup>
import { onMounted, ref } from 'vue'; import {
import { getUserInfo } from '../../util/common'; onMounted,
import { programAPI } from '../../api/program'; ref,
import { onLoad } from '@dcloudio/uni-app' } from 'vue';
import { groupAPI } from '../../api/group'; import {
getUserInfo
} from '../../util/common';
import {
programAPI
} from '../../api/program';
import {
onLoad
} from '@dcloudio/uni-app'
import {
groupAPI
} from '../../api/group';
// #ifdef APP
import '@/static/css/wangeditor.css'
// #endif
const pdMsgRef = ref() const pdMsgRef = ref()
@@ -266,9 +297,19 @@
}) })
programAPI.getProgram(programId.value).then(res => { programAPI.getProgram(programId.value).then(res => {
program.value = res.data program.value = res.data
// 解决上传视频宽度问题
program.value.introduction = program.value.introduction.replace(
/<video([^>]*)width\s*=\s*["'][^"']*["']([^>]*)>/gi,
'<video$1width="100%"$2>'
);
// 同时确保没有width属性的video也设置宽度
program.value.introduction = program.value.introduction.replace(
/<video((?!(width))[^>]*)>/gi,
'<video width="100%" $1>'
);
}) })
} }
onLoad((val) => { onLoad((val) => {
programId.value = val.programId programId.value = val.programId
let user = getUserInfo() let user = getUserInfo()
@@ -283,7 +324,10 @@
const handleChat = () => { const handleChat = () => {
if (isChat.value) { if (isChat.value) {
// 继续聊 // 继续聊
groupAPI.getOne({ programId: programId.value, userId: userId.value }).then(res => { groupAPI.getOne({
programId: programId.value,
userId: userId.value
}).then(res => {
if (res.code == 200) { if (res.code == 200) {
// 进入聊天 // 进入聊天
uni.redirectTo({ uni.redirectTo({
@@ -293,7 +337,10 @@
}) })
} else { } else {
// 开启群组聊天 // 开启群组聊天
groupAPI.add({ programId: programId.value, userId: userId.value }).then(res => { groupAPI.add({
programId: programId.value,
userId: userId.value
}).then(res => {
if (res.code == 200) { if (res.code == 200) {
// 创建成功,进入聊天 // 创建成功,进入聊天
uni.redirectTo({ uni.redirectTo({
@@ -336,6 +383,10 @@
return return
} }
// TODO 同意协议 // TODO 同意协议
pdMsgRef.value.show({
title: '立刻融',
type: 'success'
})
showWarning.value = false showWarning.value = false
} }
@@ -383,6 +434,14 @@
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">
// @import "../../static/fontsFamily/ht.css";
// @import "../../static/fontsFamily/fs.css";
// @import "../../static/fontsFamily/kt.css";
// @import "../../static/fontsFamily/bkt.css";
// @import "../../static/fontsFamily/hwfs.css";
// @import "../../static/fontsFamily/hwkt.css";
// @import "../../static/fontsFamily/st.css";
// @import "../../static/fontsFamily/wryh.css";
.detail-contrainer { .detail-contrainer {
width: 100%; width: 100%;
height: 100vh; height: 100vh;
@@ -515,12 +574,7 @@
} }
.change-next { .change-next {
position: absolute;
bottom: 0%;
left: 0%;
right: 0%;
text-align: center; text-align: center;
margin-bottom: 20rpx;
} }
// 按钮设置 // 按钮设置

52
static/css/wangeditor.css Normal file
View File

@@ -0,0 +1,52 @@
.editor-content-view {
border: 3px solid #ccc;
border-radius: 5px;
padding: 0 10px;
margin-top: 20px;
overflow-x: auto;
}
.editor-content-view p,
.editor-content-view li {
white-space: pre-wrap; /* 保留空格 */
}
.editor-content-view blockquote {
border-left: 8px solid #d0e5f2;
padding: 10px 10px;
margin: 10px 0;
background-color: #f1f1f1;
}
.editor-content-view code {
font-family: monospace;
background-color: #eee;
padding: 3px;
border-radius: 3px;
}
.editor-content-view pre>code {
display: block;
padding: 10px;
}
.editor-content-view table {
border-collapse: collapse;
}
.editor-content-view td,
.editor-content-view th {
border: 1px solid #ccc;
min-width: 50px;
height: 20px;
}
.editor-content-view th {
background-color: #f1f1f1;
}
.editor-content-view ul,
.editor-content-view ol {
padding-left: 20px;
}
.editor-content-view input[type="checkbox"] {
margin-right: 5px;
}

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

File diff suppressed because one or more lines are too long

View File

@@ -0,0 +1,8 @@
@font-face {
font-family: '仿宋';
src: url('~@/static/fontsFamily/FangSong_GB2312.woff') format('woff'),
url('~@/static/fontsFamily/FangSong_GB2312.woff2') format('woff2');
font-weight: normal;
font-style: normal;
font-display: swap;
}

View File

@@ -0,0 +1,8 @@
@font-face {
font-family: '黑体';
src: url('~@/static/fontsFamily/SimHei.woff') format('woff'),
url('~@/static/fontsFamily/SimHei.woff2') format('woff2');
font-weight: normal;
font-style: normal;
font-display: swap;
}

View File

@@ -0,0 +1,8 @@
@font-face {
font-family: '华文仿宋';
src: url('~@/static/fontsFamily/STFangsong.woff') format('woff'),
url('~@/static/fontsFamily/STFangsong.woff2') format('woff2');
font-weight: normal;
font-style: normal;
font-display: swap;
}

View File

@@ -0,0 +1,8 @@
@font-face {
font-family: '华文楷体';
src: url('~@/static/fontsFamily/STKaiti.woff') format('woff'),
url('~@/static/fontsFamily/STKaiti.woff2') format('woff2');
font-weight: normal;
font-style: normal;
font-display: swap;
}

View File

@@ -0,0 +1,8 @@
@font-face {
font-family: '楷体';
src: url('~@/static/fontsFamily/KaiTi.woff') format('woff'),
url('~@/static/fontsFamily/KaiTi.woff2') format('woff2');
font-weight: normal;
font-style: normal;
font-display: swap;
}

View File

@@ -0,0 +1,8 @@
@font-face {
font-family: '宋体';
src: url('~@/static/fontsFamily/SongTi.woff') format('woff'),
url('~@/static/fontsFamily/SongTi.woff2') format('woff2');
font-weight: normal;
font-style: normal;
font-display: swap;
}

File diff suppressed because one or more lines are too long

BIN
static/icon/Settings.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.0 KiB