Browse Source

qol功能开发

qol
kola-web 3 days ago
parent
commit
57988c941a
  1. 20
      project.private.config.json
  2. 40
      src/pages/d_interactiveDoctor/index.scss
  3. 18
      src/pages/d_interactiveDoctor/index.wxml
  4. 61
      src/pages/d_patientDetail/index.scss
  5. 602
      src/pages/d_patientDetail/index.ts
  6. 51
      src/pages/d_patientDetail/index.wxml
  7. 18
      src/patient/pages/index/index.ts
  8. 12
      src/patient/pages/index/index.wxml
  9. 17
      src/patient/pages/interactivePatient/index.ts
  10. 4
      src/patient/pages/interactivePatient/index.wxml
  11. 9
      src/patient/pages/qol/index.ts
  12. 6
      src/patient/pages/qol/index.wxml
  13. 27
      src/patient/pages/qolAdd/index.scss
  14. 226
      src/patient/pages/qolAdd/index.ts
  15. 45
      src/patient/pages/qolAdd/index.wxml
  16. 2
      src/patient/pages/qolReport/index.scss
  17. 143
      src/patient/pages/qolReport/index.ts
  18. 33
      src/patient/pages/qolReport/index.wxml
  19. 3
      src/patient/pages/qolResult/index.scss
  20. 29
      src/patient/pages/qolResult/index.ts
  21. 38
      src/patient/pages/qolResult/index.wxml

20
project.private.config.json

@ -23,15 +23,22 @@
"miniprogram": { "miniprogram": {
"list": [ "list": [
{ {
"name": "患者-qol评估报告", "name": "医生-患者详情",
"pathName": "patient/pages/qolReport/index", "pathName": "pages/d_patientDetail/index",
"query": "", "query": "id=21",
"scene": null, "scene": null,
"launchMode": "default" "launchMode": "default"
}, },
{ {
"name": "患者-qol结果", "name": "患者-qol结果",
"pathName": "patient/pages/qolResult/index", "pathName": "patient/pages/qolResult/index",
"query": "id=6",
"launchMode": "default",
"scene": null
},
{
"name": "患者-qol评估报告",
"pathName": "patient/pages/qolReport/index",
"query": "", "query": "",
"launchMode": "default", "launchMode": "default",
"scene": null "scene": null
@ -86,13 +93,6 @@
"scene": null "scene": null
}, },
{ {
"name": "医生-患者详情",
"pathName": "pages/d_patientDetail/index",
"query": "id=10",
"launchMode": "default",
"scene": null
},
{
"name": "患者-直播结果页", "name": "患者-直播结果页",
"pathName": "patient/pages/liveResult/index", "pathName": "patient/pages/liveResult/index",
"query": "id=5", "query": "id=5",

40
src/pages/d_interactiveDoctor/index.scss

@ -343,36 +343,40 @@ page {
} }
} }
.adl { .adl {
position: relative;
margin-bottom: 32rpx; margin-bottom: 32rpx;
padding: 32rpx 156rpx 34rpx 30rpx; padding: 32rpx;
border-radius: 32rpx; border-radius: 24rpx;
background: linear-gradient(141deg, #edfcff 0%, #d4f3f9 100%); background: linear-gradient(180deg, #f6efff 0%, #ffffff 100%);
border: 2rpx solid #fff; border: 2rpx solid #fff;
.title { .title {
width: 324rpx; font-size: 36rpx;
height: 40rpx; color: #211d2e;
font-weight: bold;
} }
.sub-title { .sub-title {
margin-top: 18rpx; margin-top: 10rpx;
line-height: 1; margin-right: 222rpx;
font-size: 28rpx; font-size: 28rpx;
color: rgba(255, 255, 255, 0.8); color: #211d2e;
} }
.btn { .btn {
margin-top: 20rpx; margin-top: 18rpx;
width: 220rpx; width: 224rpx;
height: 56rpx; height: 64rpx;
text-align: center; text-align: center;
line-height: 56rpx; line-height: 64rpx;
font-size: 28rpx; font-size: 28rpx;
color: #e04775; color: #ffffff;
background: #ffffff; background: linear-gradient(197deg, #ffbcf9 0%, #b982ff 100%);
border-radius: 102rpx 102rpx 102rpx 102rpx; border-radius: 102rpx 102rpx 102rpx 102rpx;
} }
.tip { .photo {
margin-top: 10rpx; position: absolute;
font-size: 24rpx; bottom: 30rpx;
color: #fff; right: 0;
width: 214rpx;
height: 212rpx;
} }
} }
.audio { .audio {

18
src/pages/d_interactiveDoctor/index.wxml

@ -93,19 +93,11 @@
</block> </block>
</view> </view>
</view> </view>
<view <view class="adl" wx:elif="{{message.msgContentType==='10'}}">
class="adl" <view class="title">GO-QOL生活质量评分</view>
wx:elif="{{message.msgContentType==='3'}}" <view class="sub-title">可从主观感受变化反馈治疗效果,建议您每月定期测评</view>
style="padding-top: {{top+25}}px;background: url({{imageUrl}}za-images/doctor/d_interactive-adl-bg.png?t={{Timestamp}}) no-repeat bottom right / 268rpx 222rpx,#D74D75;" <view class="btn">点击开始自评</view>
> <image class="photo" src="/images/bg17.png"></image>
<image
class="title"
src="{{imageUrl}}za-images/doctor/d_interactiveTitle1.png?t={{Timestamp}}"
mode="aspectFit"
></image>
<view class="sub-title">ADL+激素双达标</view>
<view class="btn" bind:tap="handleAdl">点击进入ADL</view>
<view class="tip">建议您定期做ADL测评</view>
</view> </view>
<view <view
class="audio" class="audio"

61
src/pages/d_patientDetail/index.scss

@ -388,6 +388,65 @@ page {
border: 2rpx solid #b982ff; border: 2rpx solid #b982ff;
} }
} }
.chart-list {
padding: 32rpx 40rpx 0;
.chart-title {
font-size: 36rpx;
color: #211d2e;
font-weight: bold;
}
.chart-filter {
margin-bottom: 24rpx;
position: relative;
z-index: 3;
margin-top: 32rpx;
display: flex;
gap: 16rpx;
align-items: center;
border-radius: 80rpx 80rpx 80rpx 80rpx;
.type {
padding: 10rpx 32rpx;
display: flex;
align-items: center;
justify-content: center;
font-size: 32rpx;
color: #69686E;
background-color: #FFFFFF;
border-radius: 34rpx;
.icon {
width: 24rpx;
height: 24rpx;
}
}
.range {
padding: 10rpx 32rpx;
display: flex;
align-items: center;
font-size: 32rpx;
color: #69686E;
border-radius: 34rpx;
background-color: #FFFFFF;
.icon {
width: 24rpx;
height: 24rpx;
}
}
}
.chart-card {
margin-bottom: 24rpx;
padding: 32rpx;
background-color: #fff;
border-radius: 24rpx;
.title {
font-size: 32rpx;
color: #211d2e;
font-weight: bold;
}
.chart {
height: 420rpx;
}
}
}
} }
.popup-remark { .popup-remark {
@ -416,7 +475,7 @@ page {
display: flex; display: flex;
justify-content: center; justify-content: center;
align-items: center; align-items: center;
background: linear-gradient( 197deg, #FFBCF9 0%, #B982FF 100%); background: linear-gradient(197deg, #ffbcf9 0%, #b982ff 100%);
font-size: 36rpx; font-size: 36rpx;
color: #fff; color: #fff;
border-radius: 64rpx 64rpx 64rpx 64rpx; border-radius: 64rpx 64rpx 64rpx 64rpx;

602
src/pages/d_patientDetail/index.ts

@ -1,6 +1,7 @@
import dayjs from 'dayjs' import dayjs from 'dayjs'
const app = getApp<IAppOption>() const app = getApp<IAppOption>()
let echarts: any = null
Page({ Page({
data: { data: {
@ -161,7 +162,14 @@ Page({
count: 1, count: 1,
}, },
}, },
chartComponent1: null as any,
chartComponent2: null as any,
chartComponent3: null as any,
async onLoad(option) { async onLoad(option) {
echarts = await require.async('../../gift/compontnts/echart/echarts.js')
this.chartComponent1 = this.selectComponent('#chart1')
this.chartComponent2 = this.selectComponent('#chart2')
this.chartComponent3 = this.selectComponent('#chart3')
this.setData({ this.setData({
id: option.id, id: option.id,
}) })
@ -169,6 +177,7 @@ Page({
app.waitLogin({ type: [2] }).then(async (_res) => { app.waitLogin({ type: [2] }).then(async (_res) => {
app.mpBehavior({ PageName: 'PG_DoctorPatientDetail' }) app.mpBehavior({ PageName: 'PG_DoctorPatientDetail' })
this.getDoctorDetail() this.getDoctorDetail()
this.handleTypeChange()
await this.getDetail() await this.getDetail()
app.getUserInfo(2).then((userInfo) => { app.getUserInfo(2).then((userInfo) => {
this.setData({ this.setData({
@ -215,8 +224,11 @@ Page({
}) })
}, },
handleTypeChange(e) { handleTypeChange(e) {
const index = e.detail.value let index = 0
const { typeRange, nav } = this.data if (e) {
index = e.detail.value
}
const { typeRange } = this.data
const type = typeRange[index].id const type = typeRange[index].id
const typeName = typeRange[index].value const typeName = typeRange[index].value
let EndDate = '' let EndDate = ''
@ -237,228 +249,47 @@ Page({
EndDate, EndDate,
StartDate, StartDate,
}) })
if (nav === '0') {
this.getGraph() this.getGraph()
} else {
this.getAdlList()
}
},
handleChange() {
const { nav } = this.data
if (nav === '0') {
this.getGraph()
} else {
this.getAdlList()
}
}, },
getGraph() { getGraph() {
const { type, StartDate, EndDate } = this.data
wx.ajax({ wx.ajax({
method: 'GET', method: 'GET',
url: '?r=zd/doctor/patient/adl-graph', url: '?r=xd/doctor/qol/graph',
data: { data: {
patientId: this.data.id, DateType: type,
StartDate: this.data.StartDate, StartDate: StartDate,
EndDate: this.data.EndDate, EndDate: EndDate,
DateType: this.data.type,
count: 0, count: 0,
PatientId: this.data.id,
}, },
}).then(async (res) => { }).then((res) => {
this.initChart1(res.adlSummary) const list0: any[] = []
this.initChart2(res.adlSummary) const list1: any[] = []
const list2: any[] = []
const medication = res.medication.map((item) => { res.list.forEach((item: any) => {
return { list0.push({
Date: item.InjectionDate, Date: item.Date,
...item, value: item.TotalScore,
}
}) })
const list = res.list list1.push({
const newList: any[] = this.mergeArr(list, medication) Date: item.Date,
const chart3 = await this.initChart3(newList as never[]) value: item.VisionScore,
const chart4 = await this.initChart4(newList as never[])
echarts.connect([chart3, chart4])
}) })
}, list2.push({
mergeArr(array1: any[] = [], array2: any[] = []) { Date: item.Date,
// 合并两个数组中相同Date字段的对象 value: item.AppearanceScore,
const mergedArray: any[] = []
const mergedMap = new Map()
array1.concat(array2).forEach((obj) => {
const date = obj.Date
if (mergedMap.has(date)) {
mergedMap.get(date).push(obj)
} else {
mergedMap.set(date, [obj])
}
}) })
mergedMap.forEach((objs: any) => {
if (objs.length === 1) {
mergedArray.push(objs[0])
} else {
const mergedObj = objs.reduce((acc, cur) => ({ ...acc, ...cur }))
mergedArray.push(mergedObj)
}
})
// 按照Date字段对合并后的数组进行排序
mergedArray.sort((a, b) => {
return a.Date.localeCompare(b.Date)
})
return mergedArray
},
initChart1(adlSummary = {}) {
this.ecDataTrendComponent1.init((canvas, width, height, dpr) => {
const chart = echarts.init(canvas, null, {
width,
height,
devicePixelRatio: dpr, // new
}) })
canvas.setChart(chart)
const option = {
tooltip: {
trigger: 'item',
formatter: '{b} \n {c}次,{d}%',
},
legend: {
show: false,
},
color: ['rgba(226, 219, 65, 1)', 'rgba(215, 108, 108, 1)', 'rgba(98, 190, 208, 1)'],
series: [
{
name: '全部患者',
type: 'pie',
radius: ['40%', '60%'],
center: ['50%', '50%'],
label: {
show: true,
width: 80,
alignTo: 'edge',
minMargin: 5,
edgeDistance: 10,
lineHeight: 15,
formatter: '{b} \n{time|{d}%}',
rich: {
time: {
fontSize: 10,
color: '#999',
},
},
},
labelLine: {
length: 15,
length2: 0,
maxSurfaceAngle: 80,
},
labelLayout(params) {
const isLeft = params.labelRect.x < chart.getWidth() / 2
const points = params.labelLinePoints
// Update the end point.
points[2][0] = isLeft ? params.labelRect.x : params.labelRect.x + params.labelRect.width
return {
labelLinePoints: points,
}
},
data: [
{ value: adlSummary.adlNearNum, name: 'ADL接近达标' },
{ value: adlSummary.adlUnStandardNum, name: 'ADL未达标' },
{ value: adlSummary.adlStandardNum, name: 'ADL达标' },
],
emphasis: {
itemStyle: {
shadowBlur: 10,
shadowOffsetX: 0,
shadowColor: 'rgba(0, 0, 0, 0.5)',
},
},
},
],
}
chart.setOption(option)
return chart
})
},
initChart2(adlSummary = {}) {
this.ecDataTrendComponent2.init((canvas, width, height, dpr) => {
const chart = echarts.init(canvas, null, {
width,
height,
devicePixelRatio: dpr, // new
})
canvas.setChart(chart)
const option = {
tooltip: {
trigger: 'item',
formatter: '{b} \n {c}次,{d}%',
},
legend: {
show: false,
},
color: ['rgba(215, 108, 108, 1)', 'rgba(98, 190, 208, 1)'],
series: [
{
name: '全部患者',
type: 'pie',
radius: ['40%', '60%'],
center: ['50%', '50%'],
label: {
show: true,
width: 80,
alignTo: 'edge',
minMargin: 5,
edgeDistance: 10,
lineHeight: 15,
formatter: '{b} \n{time|{d}%}',
rich: {
time: {
fontSize: 10,
color: '#999',
},
},
},
labelLine: {
length: 15,
length2: 0,
maxSurfaceAngle: 80,
},
labelLayout(params) {
const isLeft = params.labelRect.x < chart.getWidth() / 2
const points = params.labelLinePoints
// Update the end point.
points[2][0] = isLeft ? params.labelRect.x : params.labelRect.x + params.labelRect.width
return {
labelLinePoints: points,
}
},
data: [
{ value: adlSummary.SteroidDailyDoseUnStandardNum, name: '激素未达标' },
{ value: adlSummary.SteroidDailyDoseStandardNum, name: '激素达标' },
],
emphasis: {
itemStyle: {
shadowBlur: 10,
shadowOffsetX: 0,
shadowColor: 'rgba(0, 0, 0, 0.5)',
},
},
},
],
}
chart.setOption(option) this.initChart(list0, 'chartComponent1')
return chart this.initChart(list1, 'chartComponent2')
this.initChart(list2, 'chartComponent3')
}) })
}, },
initChart(defaultList = [] as any[], key) {
initChart3(defaultList = []) {
const { userInfo } = this.data
const list: any = defaultList
return new Promise((reslove) => { return new Promise((reslove) => {
this.ecDataTrendComponent3.init((canvas, width, height, dpr) => { this[key].init((canvas, width, height, dpr) => {
const chart = echarts.init(canvas, null, { const chart = echarts.init(canvas, null, {
width, width,
height, height,
@ -492,7 +323,7 @@ Page({
{ {
type: 'category', type: 'category',
axisTick: { axisTick: {
show: true, show: false,
inside: true, inside: true,
length: 1, length: 1,
alignWithLabel: true, alignWithLabel: true,
@ -509,258 +340,63 @@ Page({
type: 'dashed', type: 'dashed',
}, },
}, },
data: list.map((item) => dayjs(item.Date).format('MM-DD')), splitLine: {
axisLabel: { show: true,
formatter() { showMinLine: false,
return '' lineStyle: {
type: 'dotted',
color: 'rgba(137, 141, 151, 0.23)',
}, },
}, },
data: defaultList.map((item) => dayjs(item.Date).format('MM-DD')),
}, },
], ],
yAxis: [ yAxis: [
{ {
type: 'value', type: 'value',
minInterval: 1, minInterval: 20,
}, max: 100,
], axisLine: {
series: [ show: false,
{
name: '总分',
data: list.length ? list.map((item) => item.TotalScore) : [25],
barWidth: '16',
label: {
show: true,
position: 'top',
color: '#CF5375',
},
type: 'line',
symbol: 'circle',
symbolSize: 8,
showSymbol: list.length >= 1,
connectNulls: true,
z: 10,
itemStyle: {
color: '#CF5375',
},
markLine: {
symbol: ['none', 'none'],
data: [
{
name: '达标区(1分)',
yAxis: 1,
label: {
formatter: '{b}',
position: 'insideMiddle',
color: '#24D8C8',
fontSize: '10',
},
lineStyle: {
cap: '',
color: '#34D7C7',
type: 'dashed',
},
},
],
},
markArea: {
itemStyle: {
color: 'rgba(37,217,200,0.19)',
},
data: [
[
{
yAxis: 0,
},
{
yAxis: 1,
},
],
],
},
},
],
dataZoom: {
type: 'inside', // 有type这个属性,滚动条在最下面,也可以不行,写y:36,这表示距离顶端36px,一般就是在图上面。
startValue: list.length - 5,
endValue: list.length - 1,
filterMode: 'none',
},
}
if (this.data.detail.UserType === 4) {
const markLineData = list
.filter((item) => item.InjectionBottles)
.map((item) => {
return {
name: '',
xAxis: dayjs(item.Date).format('MM-DD'),
lineStyle: { lineStyle: {
color: 'rgba(37, 217, 200,0.5)',
cap: '',
type: 'solid', type: 'solid',
color: 'rgba(161, 164, 172, 1)',
}, },
label: {
formatter: '',
position: 'insideEndBottom',
rotate: 0,
color: '#25D9C8',
offset: [60, 0],
}, },
} splitLine: {
})
option.series.push({
name: '用药',
data: list.map((item) => (item.InjectionBottles ? 0 : null)),
type: 'line',
symbol:
'image://',
symbolSize: [11, 16],
symbolOffset: [0, 0],
itemStyle: {
color: '#25D9C8',
},
lineStyle: {
width: 0,
},
tooltip: {
show: false,
},
z: 11,
markLine: {
symbol: ['none', 'none'],
data: markLineData,
},
})
// option.series.push({
// name: "用药时间",
// data: list.map((item: any) => (item.InjectionBottles ? item.TotalScore : 0)),
// type: "line",
// symbol:
// "image://",
// symbolSize: [11, 16],
// symbolOffset: [0, "100%"],
// itemStyle: {
// color: "#25D9C8",
// },
// tooltip: {
// show: false,
// },
// lineStyle: {
// width: 0,
// },
// z: 1,
// });
}
chart.setOption(option)
reslove(chart)
return chart
})
})
},
initChart4(defaultList = []) {
const { userInfo } = this.data
const list: any = defaultList
return new Promise((reslove) => {
this.ecDataTrendComponent4.init((canvas, width, height, dpr) => {
const chart = echarts.init(canvas, null, {
width,
height,
devicePixelRatio: dpr, // new
})
canvas.setChart(chart)
const option: any = {
tooltip: {
show: false,
trigger: 'axis',
axisPointer: {
type: 'shadow',
},
confine: true,
backgroundColor: 'rgba(0, 0, 0, 0.5)',
textStyle: {
color: '#fff',
fontSize: 10,
},
order: 'seriesDesc',
},
grid: {
top: '30',
left: '0',
right: '0',
bottom: '10',
containLabel: true,
},
xAxis: [
{
type: 'category',
axisTick: {
show: true, show: true,
inside: true, showMinLine: false,
length: 1,
alignWithLabel: true,
lineStyle: { lineStyle: {
type: 'dotted', type: 'dotted',
color: '#D8D8D8', color: 'rgba(137, 141, 151, 0.23)',
width: 4,
cap: 'round',
},
},
axisLine: {
lineStyle: {
color: '#8C8C8C',
type: 'dashed',
},
},
data: list.map((item) => dayjs(item.Date).format('MM-DD')),
},
],
yAxis: [
{
type: 'value',
minInterval: 1,
max(value) {
return value.max + 20 > 999 ? 999 : value.max + 20
},
axisLabel: {
// width: 20,
formatter(value: number) {
return value
}, },
}, },
}, },
], ],
series: [ series: [
{ {
name: '激素用量', name: '总分',
data: list.length ? list.map((item) => item.SteroidDailyDose) : [20], data: defaultList.length ? defaultList.map((item) => item.value) : [25],
barWidth: '16', barWidth: '16',
type: 'line',
symbol: 'circle',
symbolSize: 8,
connectNulls: true,
showSymbol: list.length >= 1,
z: 10,
label: { label: {
show: true, show: true,
position: 'top', position: 'top',
color: '#18474e', color: '#B982FF',
z: 11,
formatter({ value }) {
return `${value}mg`
},
}, },
type: 'line',
symbolSize: 4,
showSymbol: defaultList.length >= 1,
connectNulls: true,
z: 10,
itemStyle: { itemStyle: {
color: '#3192A1', color: '#B982FF',
}, },
markLine: { markLine: {
symbol: ['none', 'none'], symbol: ['none', 'none'],
data: [ data: [
{ {
name: '达标区(5mg)', name: '达标区',
yAxis: 5, yAxis: 80,
label: { label: {
formatter: '{b}', formatter: '{b}',
position: 'insideMiddle', position: 'insideMiddle',
@ -773,21 +409,6 @@ Page({
type: 'dashed', type: 'dashed',
}, },
}, },
{
name: '20',
yAxis: 20,
label: {
formatter: '{b}',
position: 'start',
color: '#D76C6C',
distance: 8,
},
lineStyle: {
cap: '',
color: '#D76C6C',
type: 'dashed',
},
},
], ],
}, },
markArea: { markArea: {
@ -797,10 +418,10 @@ Page({
data: [ data: [
[ [
{ {
yAxis: 0, yAxis: 80,
}, },
{ {
yAxis: 5, yAxis: 100,
}, },
], ],
], ],
@ -809,76 +430,11 @@ Page({
], ],
dataZoom: { dataZoom: {
type: 'inside', // 有type这个属性,滚动条在最下面,也可以不行,写y:36,这表示距离顶端36px,一般就是在图上面。 type: 'inside', // 有type这个属性,滚动条在最下面,也可以不行,写y:36,这表示距离顶端36px,一般就是在图上面。
startValue: list.length - 5, startValue: 0,
endValue: list.length - 1, endValue: 4,
filterMode: 'none', filterMode: 'none',
}, },
} }
if (this.data.detail.UserType === 4) {
const markLineData = list
.filter((item) => item.InjectionBottles)
.map((item) => {
return {
name: '',
xAxis: dayjs(item.Date).format('MM-DD'),
lineStyle: {
color: 'rgba(37, 217, 200,0.5)',
cap: '',
type: 'solid',
},
label: {
formatter: '',
position: 'insideEndBottom',
rotate: 0,
color: '#25D9C8',
offset: [60, 0],
},
}
})
const maxValue = Math.max(...list.map((item) => item.SteroidDailyDose))
option.series.push({
name: '用药',
data: list.map((item) => (item.InjectionBottles ? 0 : null)),
type: 'line',
symbol:
'image://',
symbolSize: [11, 16],
symbolOffset: [0, 0],
itemStyle: {
color: '#25D9C8',
},
lineStyle: {
width: 0,
},
tooltip: {
show: false,
},
z: 11,
markLine: {
symbol: ['none', 'none'],
data: markLineData,
},
})
// option.series.push({
// name: "用药时间",
// data: list.map((item: any) => (item.InjectionBottles ? item.TotalScore : 0)),
// type: "line",
// symbol:
// "image://",
// symbolSize: [11, 16],
// symbolOffset: [0, "100%"],
// itemStyle: {
// color: "#25D9C8",
// },
// tooltip: {
// show: false,
// },
// lineStyle: {
// width: 0,
// },
// z: 1,
// });
}
chart.setOption(option) chart.setOption(option)
reslove(chart) reslove(chart)
@ -975,17 +531,6 @@ Page({
}) })
}, },
handleNav(e, mp = true) {
const { index } = e.currentTarget.dataset
if (index == 0 && mp) {
}
if (index == 1 && mp) {
}
this.setData({
nav: index,
})
this.handleTypeChange({ detail: { value: '2' } })
},
getAdlList(newPage = 1) { getAdlList(newPage = 1) {
const { detail, EndDate, StartDate, type } = this.data const { detail, EndDate, StartDate, type } = this.data
wx.ajax({ wx.ajax({
@ -1024,13 +569,6 @@ Page({
}) })
}) })
}, },
onReachBottom() {
const { page, pages } = this.data.pagination
const nav = this.data.nav
if (pages > page && nav === '1') {
this.getAdlList(page + 1)
}
},
handleFold(e) { handleFold(e) {
const { index } = e.currentTarget.dataset const { index } = e.currentTarget.dataset
this.setData({ this.setData({

51
src/pages/d_patientDetail/index.wxml

@ -60,6 +60,57 @@
<view class="btn" bind:tap="handleSend">发消息</view> <view class="btn" bind:tap="handleSend">发消息</view>
<view class="btn" bind:tap="handleRemark">备注</view> <view class="btn" bind:tap="handleRemark">备注</view>
</view> </view>
<view class="chart-list">
<view class="chart-title">GO-QOL生活质量评估报告</view>
<view class="chart-filter">
<picker class="type" mode="selector" range="{{typeRange}}" range-key="value" bind:change="handleTypeChange">
{{typeName}}
<image class="icon" src="{{imageUrl}}za-images/doctor/triangle-down.png?t={{Timestamp}}"></image>
</picker>
<view class="range">
<picker
mode="date"
end="{{EndDate}}"
fields="{{fields[type]}}"
mode="date"
model:value="{{StartDate}}"
bindchange="handleChange"
>
{{StartDate}}
</picker>
~
<picker
mode="date"
start="{{StartDate}}"
fields="{{fields[type]}}"
mode="date"
model:value="{{EndDate}}"
bindchange="handleChange"
>
{{EndDate}}
</picker>
<image class="icon" src="{{imageUrl}}za-images/doctor/triangle-down.png?t={{Timestamp}}"></image>
</view>
</view>
<view class="chart-card">
<view class="title">GO-QOL整体记录曲线</view>
<view class="chart">
<ec-canvas id="chart1" ec="{{ ec }}"></ec-canvas>
</view>
</view>
<view class="chart-card">
<view class="title">GO-QOL视觉功能影响记录曲线</view>
<view class="chart">
<ec-canvas id="chart2" ec="{{ ec }}"></ec-canvas>
</view>
</view>
<view class="chart-card">
<view class="title">GO-QOL外观影响记录曲线</view>
<view class="chart">
<ec-canvas id="chart3" ec="{{ ec }}"></ec-canvas>
</view>
</view>
</view>
</view> </view>
<van-popup <van-popup

18
src/patient/pages/index/index.ts

@ -14,6 +14,8 @@ Page({
regGuide: true, regGuide: true,
isLogin: 1, isLogin: 1,
qolDetail: {},
adlList: [], adlList: [],
adlNum: '', adlNum: '',
adlNewRecord: {} as any, adlNewRecord: {} as any,
@ -194,7 +196,7 @@ Page({
this.getStoryList(item.configId) this.getStoryList(item.configId)
} }
if (item.code == 'adl') { if (item.code == 'adl') {
this.getAdl() this.getQol()
} }
if (item.code == 'activity2') { if (item.code == 'activity2') {
this.getActivity(item.configId, item.showNum, 'liveList') this.getActivity(item.configId, item.showNum, 'liveList')
@ -250,20 +252,16 @@ Page({
}) })
}) })
}, },
getAdl() { getQol() {
wx.ajax({ wx.ajax({
method: 'GET', method: 'GET',
url: '?r=zd/adl/index', url: '?r=xd/qol/index',
data: {}, data: {},
}).then((res) => { }).then((res) => {
const newRecord = res.newRecord
this.setData({ this.setData({
adlList: res.list, qolDetail: {
adlNum: res.count, ...res.newRecord,
adlNewRecord: { CreateDate: dayjs(res.newRecord.CreateTime).format('YYYY-MM-DD'),
days: dayjs().diff(newRecord.CreateTime, 'day'),
...newRecord,
newCreateTime: dayjs(newRecord.CreateTime).format('YYYY-MM-DD'),
}, },
}) })
}) })

12
src/patient/pages/index/index.wxml

@ -39,9 +39,6 @@
</view> </view>
<view class="btn">{{unreadCount ? '去看看':'去咨询'}}</view> <view class="btn">{{unreadCount ? '去看看':'去咨询'}}</view>
</view> </view>
<view class="qol" style="background: url('/images/bg14.png') no-repeat top center/100%" bind:tap="routerTo" data-url="/patient/pages/qol/index">
<view class="date">最近一次评测 xxxx-xx-xx</view>
</view>
<block wx:for="{{configList}}" wx:key="index" wx:for-item="card" wx:for-index="cIndex"> <block wx:for="{{configList}}" wx:key="index" wx:for-item="card" wx:for-index="cIndex">
<view <view
class="banner" class="banner"
@ -78,6 +75,15 @@
</swiper-item> </swiper-item>
</swiper> </swiper>
</view> </view>
<view
class="qol"
wx:if="{{card.code == 'adl' && card.showStatus == 1}}"
style="background: url('/images/bg14.png') no-repeat top center/100%"
bind:tap="routerTo"
data-url="/patient/pages/qol/index"
>
<view class="date" wx:if="{{qolDetail.CreateTime}}">最近一次评测 {{qolDetail.CreateDate}}</view>
</view>
<view class="live-up-new" wx:if="{{card.code == 'activity2' && card.showStatus == 1 }}"> <view class="live-up-new" wx:if="{{card.code == 'activity2' && card.showStatus == 1 }}">
<view class="header" wx:if="{{card.name}}"> <view class="header" wx:if="{{card.name}}">
<view class="title">{{card.name}}</view> <view class="title">{{card.name}}</view>

17
src/patient/pages/interactivePatient/index.ts

@ -127,18 +127,6 @@ Page({
nextMsgId, nextMsgId,
}, },
}).then((res) => { }).then((res) => {
res.messageList.push({
msgId: '112',
msgContentType: '3',
msgContent:
'你好,我是你的专属医生kola医生,我们可以在TED关爱中心上进行简单的互动啦!如果你需要了解我的出诊时间,或者有症状反复、需要调药的情况,可以给我留言。\r\n甲状腺眼突通过合理的治疗,是可以达到期待的状态的,放松心情,规范管理,加油。',
welcomeMsg: '',
msgVisitTimeType: '0',
msgVisitTime: '',
msgFromType: '2',
ReVisitInfo: '',
msgCreateTime: '2025-08-21 11:12:58',
})
res.messageList.map((item) => { res.messageList.map((item) => {
if (item.msgContentType === '4') { if (item.msgContentType === '4') {
item.msgContent = JSON.parse(item.msgContent) item.msgContent = JSON.parse(item.msgContent)
@ -374,6 +362,11 @@ Page({
], ],
}) })
}, },
handleQol() {
wx.navigateTo({
url: '/patient/pages/qol/index',
})
},
handleBack() { handleBack() {
wx.navigateBack({ wx.navigateBack({
fail() { fail() {

4
src/patient/pages/interactivePatient/index.wxml

@ -66,10 +66,10 @@
</block> </block>
</view> </view>
</view> </view>
<view class="adl" wx:elif="{{message.msgContentType==='3'}}"> <view class="adl" wx:elif="{{message.msgContentType==='10'}}" bind:tap="handleQol">
<view class="title">GO-QOL生活质量评分</view> <view class="title">GO-QOL生活质量评分</view>
<view class="sub-title">可从主观感受变化反馈治疗效果,建议您每月定期测评</view> <view class="sub-title">可从主观感受变化反馈治疗效果,建议您每月定期测评</view>
<view class="btn" bind:tap="handleAdl">点击开始自评</view> <view class="btn">点击开始自评</view>
<image class="photo" src="/images/bg17.png"></image> <image class="photo" src="/images/bg17.png"></image>
</view> </view>
<view <view

9
src/patient/pages/qol/index.ts

@ -1,13 +1,18 @@
const _app = getApp<IAppOption>() const app = getApp<IAppOption>()
Page({ Page({
data: {}, data: {},
onLoad() {}, onLoad() {
app.waitLogin({ type: [0, 1] }).then(() => {})
},
handleAdd() { handleAdd() {
wx.navigateTo({ wx.navigateTo({
url: '/patient/pages/qolAdd/index', url: '/patient/pages/qolAdd/index',
}) })
}, },
handleBack() {
wx.navigateBack()
},
}) })
export {} export {}

6
src/patient/pages/qol/index.wxml

@ -1,4 +1,6 @@
<navbar custom-style="background:{{background}}" fixed></navbar> <navbar custom-style="background:{{background}}" fixed>
<van-icon name="arrow-left" slot="left" size="18px" color="#000" bind:tap="handleBack" />
</navbar>
<view <view
class="page" class="page"
style="background: url('/images/bg15.png') no-repeat top center/100% 518rpx;padding-top:{{pageTop}}px;" style="background: url('/images/bg15.png') no-repeat top center/100% 518rpx;padding-top:{{pageTop}}px;"
@ -16,7 +18,7 @@
<view class="progress"> <view class="progress">
<view class="row"> <view class="row">
<view class="aside"> <view class="aside">
<view class="line-top" style="opacity: 0;"></view> <view class="line-top" style="opacity: 0"></view>
<view class="side"></view> <view class="side"></view>
<view class="line"></view> <view class="line"></view>
</view> </view>

27
src/patient/pages/qolAdd/index.scss

@ -1,5 +1,5 @@
page { page {
background-color: #f6f8f9; background-color: #ffffff;
} }
.page { .page {
@ -65,7 +65,8 @@ page {
gap: 24rpx; gap: 24rpx;
.s-item1, .s-item1,
.s-item2, .s-item2,
.s-item3 { .s-item3,
.s-item4 {
padding: 18rpx; padding: 18rpx;
font-size: 32rpx; font-size: 32rpx;
color: #69686e; color: #69686e;
@ -74,20 +75,36 @@ page {
background-color: #f6f8f9; background-color: #f6f8f9;
border-radius: 16rpx; border-radius: 16rpx;
} }
.s-item1.active { .s-item4 {
order: 1;
&.active {
background-color: #dafdee;
color: #1ec580;
}
}
.s-item3 {
order: 2;
&.active {
background-color: #dafdee; background-color: #dafdee;
color: #1ec580; color: #1ec580;
} }
.s-item2.active { }
.s-item2 {
order: 3;
&.active {
background-color: #fff4e0; background-color: #fff4e0;
color: #ffa300; color: #ffa300;
} }
.s-item3.active { }
.s-item1 {
order: 4;
&.active {
background-color: #ffe7e7; background-color: #ffe7e7;
color: #ef3939; color: #ef3939;
} }
} }
} }
}
.btn { .btn {
display: flex; display: flex;
align-items: center; align-items: center;

226
src/patient/pages/qolAdd/index.ts

@ -1,10 +1,202 @@
const _app = getApp<IAppOption>() const app = getApp<IAppOption>()
Page({ Page({
data: { data: {
id: '',
step: 0, step: 0,
qolList0: [
{
title: '1. 骑自行车或电动车',
answer: '',
answerList: {
4: '没学过',
3: '无影响',
2: '有点影响',
1: '严重影响',
},
},
{
title: '2. 开车',
answer: '',
answerList: {
4: '没学过',
3: '无影响',
2: '有点影响',
1: '严重影响',
},
},
{
title: '3. 室内走动',
answer: '',
answerList: {
3: '无影响',
2: '有点影响',
1: '严重影响',
},
},
{
title: '4. 室外走动',
answer: '',
answerList: {
3: '无影响',
2: '有点影响',
1: '严重影响',
},
},
{
title: '5. 看书看报',
answer: '',
answerList: {
3: '无影响',
2: '有点影响',
1: '严重影响',
},
},
{
title: '6. 看电视',
answer: '',
answerList: {
3: '无影响',
2: '有点影响',
1: '严重影响',
},
},
{
title: '7. 兴趣爱好及平时娱乐',
answer: '',
answerList: {
3: '无影响',
2: '有点影响',
1: '严重影响',
},
},
{
title: '8. 过去的1周内,您是否觉得甲状腺相关眼病会阻碍您去做您想做的事',
answer: '',
answerList: {
3: '无影响',
2: '有点影响',
1: '严重影响',
},
},
],
qolList1: [
{
title: '9. 您是否感觉到甲状腺相关眼病改变您的外表?',
answer: '',
answerList: {
3: '不,没有',
2: '是的,有点',
1: '是的,严重',
},
},
{
title: '10. 您是否感觉到甲状腺相关眼病使您受到了别人的注视?',
answer: '',
answerList: {
3: '不,没有',
2: '是的,有点',
1: '是的,严重',
},
},
{
title: '11. 您是否感觉到别人因为甲状腺相关眼病对您不友善?',
answer: '',
answerList: {
3: '不,没有',
2: '是的,有点',
1: '是的,严重',
},
},
{
title: '12. 您是否感觉到甲状腺相关眼病影响您的自信心?',
answer: '',
answerList: {
3: '不,没有',
2: '是的,有点',
1: '是的,严重',
},
},
{
title: '13. 您是否感觉到甲状腺相关眼病影响您结交新朋友?',
answer: '',
answerList: {
3: '无影响',
2: '有点影响',
1: '严重影响',
},
},
{
title: '14. 您是否感觉到甲状腺相关眼病使您收到了社会孤立?',
answer: '',
answerList: {
3: '不,没有',
2: '是的,有点',
1: '是的,严重',
},
},
{
title: '15. 您是否感觉到甲状腺相关眼病使您拍照的次数减少了?',
answer: '',
answerList: {
3: '不,没有',
2: '是的,有点',
1: '是的,严重',
},
},
{
title: '16. 您是否会试图掩饰甲状腺相关眼病给您带来的外貌变化?',
answer: '',
answerList: {
3: '不,没有',
2: '是的,有点',
1: '是的,严重',
},
},
],
},
onLoad(options) {
this.setData({
id: options.id,
})
app.waitLogin({ type: [1] }).then(() => {
if (options.id) {
this.getDetail()
}
})
},
getDetail() {
const { qolList0, qolList1 } = this.data
wx.ajax({
method: 'GET',
url: '?r=xd/qol/view',
data: {
Id: this.data.id,
},
}).then((res) => {
this.setData({
detail: res,
})
qolList0.forEach((item, index) => {
item.answer = res[`Question${index + 1}`]
})
qolList1.forEach((item, index) => {
item.answer = res[`Question${index + 9}`]
})
this.setData({
qolList0,
qolList1,
})
})
},
handleSelect(e) {
const { id } = this.data
if (id) return
const { list, key, index } = e.currentTarget.dataset
this.setData({
[`${list}[${index}].answer`]: key,
})
}, },
onLoad() {},
handleNext() { handleNext() {
this.setData({ this.setData({
step: 1, step: 1,
@ -13,9 +205,37 @@ Page({
scrollTop: 0, scrollTop: 0,
}) })
}, },
handleReset() {
wx.redirectTo({
url: '/patient/pages/qolAdd/index',
})
},
handleSubmit() { handleSubmit() {
const { qolList0, qolList1 } = this.data
const arr = [...qolList0, ...qolList1]
const form = {}
for (let i = 0; i < arr.length; i++) {
const item = arr[i]
const order = item.title.split('.')[0]
if (!item.answer) {
wx.showToast({
title: `请填写第${order}`,
icon: 'none',
})
return
}
form[`Question${order}`] = item.answer
}
wx.ajax({
method: 'POST',
url: '?r=xd/qol/create',
data: {
...form,
},
}).then((res) => {
wx.navigateTo({ wx.navigateTo({
url: '/patient/pages/qolResult/index', url: `/patient/pages/qolResult/index?id=${res.Id}`,
})
}) })
}, },
handlePrev() { handlePrev() {

45
src/patient/pages/qolAdd/index.wxml

@ -18,28 +18,47 @@
<view class="content">过去一周内,甲状腺相关眼病是否影响您做以下的事情?根据您的实际情况选择。</view> <view class="content">过去一周内,甲状腺相关眼病是否影响您做以下的事情?根据您的实际情况选择。</view>
</view> </view>
<view class="module" wx:if="{{step==0}}"> <view class="module" wx:if="{{step==0}}">
<view class="row" wx:for="{{8}}" wx:key="index"> <view class="row" wx:for="{{qolList0}}" wx:key="index">
<view class="title">1.骑自行车或电动车</view> <view class="title">{{item.title}}</view>
<view class="select"> <view class="select">
<view class="s-item1 active">没学过</view> <view
<view class="s-item1 active">没学过</view> class="s-item{{answerKey}} {{item.answer == answerKey && 'active'}}"
<view class="s-item2 active">没学过</view> wx:for="{{item.answerList}}"
<view class="s-item3 active">没学过</view> wx:key="index"
wx:for-item="answerItem"
wx:for-index="answerKey"
bind:tap="handleSelect"
data-list="qolList0"
data-index="{{index}}"
data-key="{{answerKey}}"
>
{{answerItem}}
</view>
</view> </view>
</view> </view>
<view class="btn" bind:tap="handleNext">下一页(1/2)</view> <view class="btn" bind:tap="handleNext">下一页(1/2)</view>
</view> </view>
<view class="module" wx:if="{{step==1}}"> <view class="module" wx:if="{{step==1}}">
<view class="row" wx:for="{{8}}" wx:key="index"> <view class="row" wx:for="{{qolList1}}" wx:key="index">
<view class="title">1.骑自行车或电动车</view> <view class="title">{{item.title}}</view>
<view class="select"> <view class="select">
<view class="s-item1 active">没学过</view> <view
<view class="s-item1 active">没学过</view> class="s-item{{answerKey}} {{item.answer == answerKey && 'active'}}"
<view class="s-item2 active">没学过</view> wx:for="{{item.answerList}}"
<view class="s-item3 active">没学过</view> wx:key="index"
wx:for-item="answerItem"
wx:for-index="answerKey"
bind:tap="handleSelect"
data-list="qolList1"
data-index="{{index}}"
data-key="{{answerKey}}"
>
{{answerItem}}
</view>
</view> </view>
</view> </view>
<view class="btn" bind:tap="handleSubmit">提交(2/2)</view> <view class="btn" wx:if="{{id}}" bind:tap="handleReset">重新测评</view>
<view class="btn" wx:else bind:tap="handleSubmit">提交(2/2)</view>
<view class="prev" bind:tap="handlePrev">上一步</view> <view class="prev" bind:tap="handlePrev">上一步</view>
</view> </view>
</view> </view>

2
src/patient/pages/qolReport/index.scss

@ -3,6 +3,7 @@ page {
} }
.page { .page {
padding-bottom: 200rpx;
.page-header { .page-header {
background-color: #fff; background-color: #fff;
.form { .form {
@ -42,7 +43,6 @@ page {
} }
.list { .list {
margin: 28rpx 40rpx 0; margin: 28rpx 40rpx 0;
padding-bottom: 32rpx;
.list-title { .list-title {
font-size: 36rpx; font-size: 36rpx;
color: #211d2e; color: #211d2e;

143
src/patient/pages/qolReport/index.ts

@ -1,5 +1,5 @@
import dayjs from 'dayjs' import dayjs from 'dayjs'
const _app = getApp<IAppOption>() const app = getApp<IAppOption>()
let echarts: any = null let echarts: any = null
Page({ Page({
@ -7,27 +7,34 @@ Page({
type: '1', type: '1',
BeginMonth: '', BeginMonth: '',
EndMonth: '', EndMonth: '',
list: [],
pagination: {
page: 1,
pages: 1,
count: 1,
},
}, },
chartComponent1: null as any, chartComponent1: null as any,
chartComponent2: null as any, chartComponent2: null as any,
chartComponent3: null as any, chartComponent3: null as any,
async onLoad() { async onLoad() {
this.handleChangeType()
echarts = await require.async('../../../gift/compontnts/echart/echarts.js') echarts = await require.async('../../../gift/compontnts/echart/echarts.js')
this.chartComponent1 = this.selectComponent('#chart1') this.chartComponent1 = this.selectComponent('#chart1')
this.chartComponent2 = this.selectComponent('#chart2') this.chartComponent2 = this.selectComponent('#chart2')
this.chartComponent3 = this.selectComponent('#chart3') this.chartComponent3 = this.selectComponent('#chart3')
this.initChart()
},
app.waitLogin({ type: [1] }).then(() => {
this.handleChangeType()
this.getList()
})
},
handleChangeType(e?: WechatMiniprogram.CustomEvent) { handleChangeType(e?: WechatMiniprogram.CustomEvent) {
let type = '' let type = ''
let callback = true
if (e) { if (e) {
type = e.currentTarget.dataset.type type = e.detail.index + 1
} else { } else {
type = this.data.type type = this.data.type
callback = false
} }
let EndMonth = '' let EndMonth = ''
let BeginMonth = '' let BeginMonth = ''
@ -49,27 +56,46 @@ Page({
EndMonth, EndMonth,
BeginMonth, BeginMonth,
}) })
if (callback) { this.getChatData()
this.handleTabCallBack()
}
},
initChart(defaultList = []) {
const list: any = [
{
Date: '2025-09-04',
TotalScore: '5',
},
{
Date: '2025-09-05',
TotalScore: '5',
}, },
{ getChatData() {
Date: '2025-09-06', const { type, BeginMonth, EndMonth } = this.data
TotalScore: '5', wx.ajax({
method: 'GET',
url: '?r=xd/qol/graph',
data: {
DateType: type,
StartDate: BeginMonth,
EndDate: EndMonth,
count: 0,
},
}).then((res) => {
const list0: any[] = []
const list1: any[] = []
const list2: any[] = []
res.list.forEach((item: any) => {
list0.push({
Date: item.Date,
value: item.TotalScore,
})
list1.push({
Date: item.Date,
value: item.VisionScore,
})
list2.push({
Date: item.Date,
value: item.AppearanceScore,
})
})
this.initChart(list0, 'chartComponent1')
this.initChart(list1, 'chartComponent2')
this.initChart(list2, 'chartComponent3')
})
}, },
] initChart(defaultList = [] as any[], key) {
return new Promise((reslove) => { return new Promise((reslove) => {
this.chartComponent1.init((canvas, width, height, dpr) => { this[key].init((canvas, width, height, dpr) => {
const chart = echarts.init(canvas, null, { const chart = echarts.init(canvas, null, {
width, width,
height, height,
@ -128,7 +154,7 @@ Page({
color: 'rgba(137, 141, 151, 0.23)', color: 'rgba(137, 141, 151, 0.23)',
}, },
}, },
data: list.map((item) => dayjs(item.Date).format('MM-DD')), data: defaultList.map((item) => dayjs(item.Date).format('MM-DD')),
}, },
], ],
yAxis: [ yAxis: [
@ -156,7 +182,7 @@ Page({
series: [ series: [
{ {
name: '总分', name: '总分',
data: list.length ? list.map((item) => item.TotalScore) : [25], data: defaultList.length ? defaultList.map((item) => item.value) : [25],
barWidth: '16', barWidth: '16',
label: { label: {
show: true, show: true,
@ -165,7 +191,7 @@ Page({
}, },
type: 'line', type: 'line',
symbolSize: 4, symbolSize: 4,
showSymbol: list.length >= 1, showSymbol: defaultList.length >= 1,
connectNulls: true, connectNulls: true,
z: 10, z: 10,
itemStyle: { itemStyle: {
@ -222,6 +248,67 @@ Page({
}) })
}) })
}, },
getList(newPage = 1) {
wx.ajax({
method: 'GET',
url: '?r=xd/qol/list',
data: {
page: newPage,
},
}).then((res) => {
let list = res.page == 1 ? res.list : [...this.data.list, ...res.list]
this.setData({
list: list,
pagination: {
page: res.page,
pages: res.pages,
count: res.count,
},
})
})
},
onReachBottom() {
const { page, pages } = this.data.pagination
if (pages > page) {
this.getList(page + 1)
}
},
handleDelete(e) {
const { id, index } = e.currentTarget.dataset
const { list } = this.data
wx.showModal({
title: '确认删除吗?',
success: (res) => {
if (res.confirm) {
wx.ajax({
method: 'POST',
url: '?r=xd/qol/delete',
data: {
Id: id,
},
}).then(() => {
this.setData({
list: list.filter((_item, i) => i !== index),
})
})
}
},
})
},
handleDetail(e) {
const { id } = e.currentTarget.dataset
wx.navigateTo({
url: `/patient/pages/qolAdd/index?id=${id}`,
})
},
handleQol() {
wx.navigateTo({
url: '/patient/pages/qol/index',
})
},
handleBack() {
wx.navigateBack()
},
}) })
export {} export {}

33
src/patient/pages/qolReport/index.wxml

@ -1,4 +1,6 @@
<navbar custom-style="background:{{background}}" fixed></navbar> <navbar custom-style="background:{{background}}" fixed>
<van-icon name="arrow-left" slot="left" size="18px" color="#000" bind:tap="handleBack" />
</navbar>
<view class="page"> <view class="page">
<view class="page-header"> <view class="page-header">
<van-tabs <van-tabs
@ -8,7 +10,7 @@
line-height="8rpx" line-height="8rpx"
title-active-color="#211D2E" title-active-color="#211D2E"
title-inactive-color="#69686E" title-inactive-color="#69686E"
bind:change="onChange" bind:change="handleChangeType"
> >
<van-tab title="日"></van-tab> <van-tab title="日"></van-tab>
<van-tab title="月度"></van-tab> <van-tab title="月度"></van-tab>
@ -66,39 +68,50 @@
<view class="list"> <view class="list">
<view class="list-title">我的历史测评报告</view> <view class="list-title">我的历史测评报告</view>
<view class="list-container"> <view class="list-container">
<view class="row" wx:for="{{2}}" wx:key="index"> <view
class="row"
wx:for="{{list}}"
wx:key="index"
bind:tap="handleDetail"
data-id="{{item.Id}}"
data-index="{{index}}"
bind:longpress="handleDelete"
>
<view class="aside"> <view class="aside">
<view class="line-top" style="opacity: 0"></view> <view class="line-top" style="opacity: 0"></view>
<view class="side"></view> <view class="side"></view>
<view class="line"></view> <view class="line"></view>
</view> </view>
<view class="r-container"> <view class="r-container">
<view class="date">评估日期:2025-09-02</view> <view class="date">评估日期:{{item.Date}}</view>
<view class="r-card"> <view class="r-card">
<view class="wrap"> <view class="wrap">
<view class="num">100</view> <view class="num">{{item.TotalScore}}</view>
<view class="inner"> <view class="inner">
<view class="label">轻度影响</view> <view class="label" wx:if="{{item.TotalScore >= 80}}">轻度影响</view>
<view class="label" wx:elif="{{item.TotalScore >= 40}}">中度影响</view>
<view class="label" wx:else>重度影响</view>
<view class="name">TED生活质量评分</view> <view class="name">TED生活质量评分</view>
</view> </view>
</view> </view>
<view class="stat"> <view class="stat">
<view class="s-item"> <view class="s-item">
视觉功能 视觉功能
<view class="score">30分</view> <view class="score">{{item.VisionScore}}分</view>
</view> </view>
<view class="s-item"> <view class="s-item">
视觉功能 外观
<view class="score">30分</view> <view class="score">{{item.AppearanceScore}}分</view>
</view> </view>
</view> </view>
</view> </view>
</view> </view>
</view> </view>
<pagination pagination="{{pagination}}"></pagination>
</view> </view>
</view> </view>
<view class="page-footer"> <view class="page-footer">
<view class="btn">评测</view> <view class="btn" bind:tap="handleQol">评测</view>
</view> </view>
</view> </view>

3
src/patient/pages/qolResult/index.scss

@ -152,7 +152,8 @@ page {
bottom: -12rpx; bottom: -12rpx;
left: 50%; left: 50%;
transform: translate(-50%, 100%); transform: translate(-50%, 100%);
width: 52rpx; padding: 0 10rpx;
min-width: 52rpx;
height: 32rpx; height: 32rpx;
font-size: 32rpx; font-size: 32rpx;
color: #b982ff; color: #b982ff;

29
src/patient/pages/qolResult/index.ts

@ -1,8 +1,31 @@
const _app = getApp<IAppOption>() const app = getApp<IAppOption>()
Page({ Page({
data: {}, data: {
onLoad() {}, id: '',
detail: {},
},
onLoad(options) {
this.setData({
id: options.id,
})
app.waitLogin({ type: [1] }).then(() => {
this.getDetail()
})
},
getDetail() {
wx.ajax({
method: 'GET',
url: '?r=xd/qol/view',
data: {
Id: this.data.id,
},
}).then((res) => {
this.setData({
detail: res,
})
})
},
handleReport() { handleReport() {
wx.navigateTo({ wx.navigateTo({
url: '/patient/pages/qolReport/index', url: '/patient/pages/qolReport/index',

38
src/patient/pages/qolResult/index.wxml

@ -1,20 +1,22 @@
<navbar custom-style="background:{{background}}" fixed></navbar> <navbar custom-style="background:{{background}}" fixed></navbar>
<view <view
class="page status3" class="page {{detail.TotalScore>0 && 'status1'}} {{detail.TotalScore>=40 && 'status2'}} {{detail.TotalScore>=80 && 'status3'}}"
style="background: url('/images/bg15.png') no-repeat top center/100% 518rpx;padding-top:{{pageTop+20}}px;" style="background: url('/images/bg15.png') no-repeat top center/100% 518rpx;padding-top:{{pageTop+20}}px;"
> >
<view class="container"> <view class="container">
<view class="info"> <view class="info">
<view class="wrap"> <view class="wrap">
<view class="w-header"> <view class="w-header">
<view class="num">1</view> <view class="num">{{detail.TotalScore}}</view>
<view class="label">重度影响</view> <view class="label" wx:if="{{detail.TotalScore >= 80}}">轻度影响</view>
<view class="label" wx:elif="{{detail.TotalScore >= 40}}">中度影响</view>
<view class="label" wx:else>重度影响</view>
</view> </view>
<view class="tip">本次TED生活质量评分</view> <view class="tip">本次TED生活质量评分</view>
</view> </view>
<image class="status" src="/images/icon70.png"></image> <image class="status" wx:if="{{detail.TotalScore >= 80}}" src="/images/icon72.png"></image>
<!-- <image class="status" src="/images/icon71.png"></image> --> <image class="status" wx:elif="{{detail.TotalScore >= 40}}" src="/images/icon71.png"></image>
<!-- <image class="status" src="/images/icon72.png"></image> --> <image class="status" wx:else src="/images/icon70.png"></image>
</view> </view>
<view class="c-line"></view> <view class="c-line"></view>
<view class="card"> <view class="card">
@ -23,8 +25,10 @@
视觉功能 视觉功能
</view> </view>
<view class="c-content"> <view class="c-content">
当前分数:1 当前分数:{{detail.VisionScore}}
<view class="label">重度影响</view> <view class="label" wx:if="{{detail.VisionScore >= 80}}">轻度影响</view>
<view class="label" wx:elif="{{detail.VisionScore >= 40}}">中度影响</view>
<view class="label" wx:else>重度影响</view>
</view> </view>
<view class="progress"> <view class="progress">
<view class="p-item"> <view class="p-item">
@ -48,9 +52,9 @@
</view> </view>
<view class="line3"></view> <view class="line3"></view>
</view> </view>
<view class="slide"> <view class="slide" style="left:{{detail.VisionScore - 5}}%">
<view class="circle"></view> <view class="circle"></view>
<view class="num">2</view> <view class="num">{{detail.VisionScore}}</view>
</view> </view>
</view> </view>
</view> </view>
@ -60,8 +64,10 @@
外观 外观
</view> </view>
<view class="c-content"> <view class="c-content">
当前分数:1 当前分数:{{detail.AppearanceScore}}
<view class="label">重度影响</view> <view class="label" wx:if="{{detail.AppearanceScore >= 80}}">轻度影响</view>
<view class="label" wx:elif="{{detail.AppearanceScore >= 40}}">中度影响</view>
<view class="label" wx:else>重度影响</view>
</view> </view>
<view class="progress"> <view class="progress">
<view class="p-item"> <view class="p-item">
@ -85,16 +91,18 @@
</view> </view>
<view class="line3"></view> <view class="line3"></view>
</view> </view>
<view class="slide"> <view class="slide" style="left:{{detail.AppearanceScore - 5}}%">
<view class="circle"></view> <view class="circle"></view>
<view class="num">2</view> <view class="num">{{detail.AppearanceScore}}</view>
</view> </view>
</view> </view>
</view> </view>
<view class="effect">分数越低, 对生活质量影响越严重</view> <view class="effect">分数越低, 对生活质量影响越严重</view>
</view> </view>
<view class="page-effect-wrap"> <view class="page-effect-wrap">
<view class="page-effect">建议前往眼科中心 及时就诊</view> <view class="page-effect" wx:if="{{detail.TotalScore >= 80}}">建议保持定期监测,保持良好生活习惯</view>
<view class="page-effect" wx:elif="{{detail.TotalScore >= 40}}">建议就诊检查,评估是否需要调整治疗</view>
<view class="page-effect" wx:else>建议前往眼科中心 及时就诊</view>
</view> </view>
<view class="report" bind:tap="handleReport"> <view class="report" bind:tap="handleReport">

Loading…
Cancel
Save