信达小程序
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

1091 lines
39 KiB

import dayjs from 'dayjs'
const app = getApp<IAppOption>()
const licia = require('miniprogram-licia')
let echarts: any = null
Page({
data: {
calendarDate: '',
fold: true,
ec: {
lazyLoad: true,
},
calendarConfig: {
multi: false,
hideSelectYear: true,
autoChoosedWhenJump: true,
firstDayOfWeek: 'Mon',
theme: 'nuohe',
takeoverTap: true,
highlightToday: true,
onlyShowCurrentMonth: true,
disableMode: {
type: 'after', // [‘before’, 'after']
},
},
foldAll: true,
BeginMonth: '',
EndMonth: '',
Type: '2',
Num: '' as string | number,
fields: {
1: 'day',
2: 'month',
3: 'year',
},
detail: {},
alertAdl: {},
partNameList: app.globalData.partNameList,
list: [],
pagination: {
page: 1,
pages: 1,
count: 1,
},
defaultList: [],
count: 0,
defaultListLast: {},
mList: [],
zdUserInfo: {} as any,
todayBg: '',
page: 0,
tableData: [
{
title: '说话',
key: 'TalkingScore',
},
{
title: '咀嚼',
key: 'ChewScore',
},
{
title: '吞咽',
key: 'SwallowScore',
},
{
title: '呼吸',
key: 'BreathScore',
},
{
title: '刷牙梳头能力受损',
key: 'BrushTeethAndCombHairScore',
},
{
title: '从椅子上起身能力受损',
key: 'GetUpFromChairScore',
},
{
title: '复视/重影',
key: 'DoubleVisionScore',
},
{
title: '眼睑下垂',
key: 'DroopyEyelidsScore',
},
],
selectLegends: {
呼吸: false,
延髓: false,
眼肌: false,
肢体: false,
总分: true,
},
tab: 1,
theme: '',
},
ecDataTrendComponent: null as any,
ecDataHormoneComponent: null as any,
onLoad() {
app.zdGetTheme().then((res) => {
this.setData({
theme: res,
})
})
},
async onShow() {
echarts = await require.async('../../compontnts/echart/echarts.js')
this.ecDataTrendComponent = this.selectComponent('#mychart-dom-bar')
this.ecDataHormoneComponent = this.selectComponent('#mychart-hormone')
this.setData({
calendarDate: dayjs().format('YYYY-MM'),
})
this.handleChangeType()
app.waitLogin().then(() => {
// 强制疾病患者以上身份
app.zdPermissionVerification(3, 0, `/gift/pages/myHealthRecord/index`).then(() => {
app.mpBehavior({ PageName: 'PG_PATIENTHEALTHRECORD' })
app.getZdUserInfo(this, true, (res) => {
if (res.UserType != 4) {
this.setData({
tab: 2,
})
}
this.getCale()
this.handleTabCallBack()
this.getMedicationAlertAdl()
})
})
})
},
handleChangeInput() {
if (Number(this.data.Num) > 100) {
this.setData({
Num: 100,
})
}
},
getCale() {
wx.ajax({
method: 'GET',
url: '?r=zd/adl/cale',
data: {
Month: this.data.calendarDate,
},
}).then((res) => {
this.setCalendarTodos(res)
})
},
setCalendarTodos({ adl = [], medication = [] }: { adl: any[]; medication: string[] }) {
const theme = this.data.theme
const calendar = this.selectComponent('#calendar').calendar
const adlDate = adl.map((item) => item.Date)
const dates: any[] = []
const intersectDate = licia.intersect(adlDate, medication)
const filterAdlDate = adl.filter((item) => !intersectDate.includes(item.Date))
const filterMedication = medication.filter((item) => !intersectDate.includes(item))
const intersectAdlDate = adl.filter((item) => intersectDate.includes(item.Date))
const doc = theme === 'DRUG' ? 'doc' : ' '
filterMedication.forEach((Date: string) => {
dates.push({
year: Date.split('-')[0],
month: Date.split('-')[1],
date: Date.split('-')[2],
class: doc,
})
})
intersectAdlDate.forEach(({ Date, TotalScore, LastTotalScore }) => {
dates.push({
year: Date.split('-')[0],
month: Date.split('-')[1],
date: Date.split('-')[2],
class: TotalScore > 5 || TotalScore - LastTotalScore >= 2 ? `error ${doc}` : `primary ${doc}`,
})
})
filterAdlDate.forEach(({ Date, TotalScore, LastTotalScore }) => {
dates.push({
year: Date.split('-')[0],
month: Date.split('-')[1],
date: Date.split('-')[2],
class: TotalScore > 5 || TotalScore - LastTotalScore >= 2 ? 'error' : 'primary',
})
})
calendar.setDateStyle(dates)
},
getMedicationAlertAdl() {
wx.ajax({
method: 'GET',
url: '?r=zd/medication/medication-alert-adl',
data: {},
}).then((res) => {
this.setData({
alertAdl: res,
})
})
},
handleWhenChangeMonth(e: { detail: { next: any } }) {
const current = e.detail.next
this.setData({
calendarDate: dayjs(`${current.year}-${current.month}`).format('YYYY-MM'),
})
this.getCale()
},
handleChangeType(e?: WechatMiniprogram.CustomEvent) {
let type = ''
let callback = true
if (e) {
type = e.currentTarget.dataset.type
} else {
type = this.data.Type
callback = false
}
let EndMonth = ''
let BeginMonth = ''
if (type == '1') {
if (e) {
app.mpBehavior({ PageName: 'BTN_PATIENTHEALTHRECORDDAILYCURVE' })
}
EndMonth = dayjs().format('YYYY-MM-DD')
BeginMonth = dayjs().subtract(6, 'd').format('YYYY-MM-DD')
} else if (type == '2') {
if (e) {
app.mpBehavior({ PageName: 'BTN_PATIENTHEALTHRECORDMONTHLYCURVE' })
}
EndMonth = dayjs().format('YYYY-MM')
BeginMonth = dayjs().subtract(1, 'M').format('YYYY-MM')
} else if (type == '3') {
if (e) {
app.mpBehavior({ PageName: 'BTN_PATIENTHEALTHRECORDYEARLYCURVE' })
}
EndMonth = dayjs().format('YYYY')
BeginMonth = dayjs().subtract(1, 'y').format('YYYY')
} else if (type == '4' && e) {
app.mpBehavior({ PageName: 'BTN_PATIENTHEALTHRECORDTIMECURVE' })
}
this.setData({
page: 0,
Type: type,
Num: '5',
EndMonth,
BeginMonth,
})
if (callback) {
this.handleTabCallBack()
}
},
handleChange() {
this.handleTabCallBack()
},
handleTab(e) {
const { index } = e.currentTarget.dataset
this.setData({
tab: index,
})
if (index == 1) {
app.mpBehavior({ PageName: 'BTN_PATIENTHEALTHRECORDCOMPREHENSIVEREPORT' })
}
if (index == 2) {
app.mpBehavior({ PageName: 'BTN_PATIENTHEALTHRECORDDUALCOMPLIANCENOTES' })
}
if (index == 3) {
app.mpBehavior({ PageName: 'BTN_PATIENTHEALTHRECORDMEDICATIONRECORD' })
}
this.handleTabCallBack()
},
handleTabCallBack() {
const tab = this.data.tab
this.setData({
pagination: {
page: 1,
pages: 1,
count: 1,
},
})
if (tab == 1) {
this.getAllList()
}
if (tab == 2) {
this.getList()
}
if (tab == 3) {
this.getMedicationList()
}
this.getChart()
},
getAllList(newPage = 1) {
const { BeginMonth, EndMonth, Type, Num } = this.data
wx.ajax({
method: 'GET',
url: '?r=zd/adl/composite-list',
data: {
Type: Number(Type) === 4 ? 2 : 1,
DateType: Number(Type) === 4 ? '' : Number(Type),
StartDate: BeginMonth,
EndDate: EndMonth,
Num,
page: newPage,
},
}).then((res) => {
const list = res.list
list.map((item) => {
let grade = 1
if (item.TotalScore < 5) {
grade = 1
} else if (item.TotalScore >= 5 && item.TotalScore < 15) {
grade = 2
} else {
grade = 3
}
item.grade = grade
item.fold = true
return item
})
const newList = res.page === 1 ? res.list : [...this.data.list, ...res.list]
this.setData({
list: newList,
pagination: {
page: res.page,
pages: res.pages,
count: res.count,
},
})
})
},
onReachBottom() {
const { page, pages } = this.data.pagination
const tab = this.data.tab
if (pages > page) {
if (tab == 1) {
this.getAllList(page + 1)
}
if (tab == 2) {
this.getList(page + 1)
}
if (tab == 3) {
this.getMedicationList(page + 1)
}
}
},
getList(newPage = 1) {
const { BeginMonth, EndMonth, Type, Num } = this.data
wx.ajax({
method: 'GET',
url: '?r=zd/adl/list',
data: {
Type: Number(Type) === 4 ? 2 : 1,
DateType: Number(Type) === 4 ? '' : Number(Type),
StartDate: BeginMonth,
EndDate: EndMonth,
Num,
page: newPage,
},
}).then((res) => {
const list = res.list
list.map((item) => {
let grade = 1
if (item.TotalScore < 5) {
grade = 1
} else if (item.TotalScore >= 5 && item.TotalScore < 15) {
grade = 2
} else {
grade = 3
}
item.grade = grade
item.fold = true
item.Type = 1
return item
})
const newList = res.page === 1 ? res.list : [...this.data.list, ...res.list]
this.setData({
list: newList,
pagination: {
page: res.page,
pages: res.pages,
count: res.count,
},
})
})
},
getMedicationList(newPage = 1) {
const { BeginMonth, EndMonth, Type, Num } = this.data
wx.ajax({
method: 'GET',
url: '?r=zd/medication/list',
data: {
Type: Number(Type) === 4 ? 2 : 1,
DateType: Number(Type) === 4 ? '' : Number(Type),
StartDate: BeginMonth,
EndDate: EndMonth,
Num,
page: newPage,
},
}).then((res) => {
const list = res.list
list.map((item) => {
let grade = 1
if (item.TotalScore < 5) {
grade = 1
} else if (item.TotalScore >= 5 && item.TotalScore < 15) {
grade = 2
} else {
grade = 3
}
item.grade = grade
item.fold = true
item.Type = 2
return item
})
const newList = res.page === 1 ? res.list : [...this.data.list, ...res.list]
this.setData({
list: newList,
pagination: {
page: res.page,
pages: res.pages,
count: res.count,
},
})
})
},
getChart() {
const { BeginMonth, EndMonth, Type, Num } = this.data
wx.ajax({
method: 'GET',
url: '?r=zd/adl/list',
data: {
Type: Number(Type) === 4 ? 2 : 1,
DateType: Number(Type) === 4 ? '' : Number(Type),
StartDate: BeginMonth,
EndDate: EndMonth,
Num,
count: 0,
IsAsc: 1,
},
}).then(async (res) => {
if (Number(Type) == 4) {
this.setData({
defaultList: res.list,
count: res.list.length,
defaultListLast: res.list.at(-1),
})
const chart1 = await this.initChart(res.list)
const chart2 = await this.initHormoneChart(res.list)
echarts.connect([chart1, chart2])
}
})
if (Number(Type) != 4) {
wx.ajax({
method: 'GET',
url: '?r=zd/adl/graph',
data: {
Type: Number(Type) === 4 ? 2 : 1,
DateType: Number(Type) === 4 ? '' : Number(Type),
StartDate: BeginMonth,
EndDate: EndMonth,
count: 0,
},
}).then(async (res) => {
const medication = res.medication.map((item) => {
return {
Date: item.InjectionDate,
...item,
}
})
const list = res.list
const newList: any[] = this.mergeArr(list, medication)
if (Number(Type) != 4) {
this.setData({
defaultList: newList as never[],
defaultListLast: newList.at(-1),
count: list.length,
})
const chart1 = await this.initChart(newList as never[])
const chart2 = await this.initHormoneChart(newList as never[])
echarts.connect([chart1, chart2])
}
})
}
},
mergeArr(array1: any[] = [], array2: any[] = []) {
// 合并两个数组中相同Date字段的对象
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
},
initChart(defaultList = []) {
const { theme } = this.data
const list: any = defaultList
return new Promise((reslove) => {
this.ecDataTrendComponent.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,
inside: true,
length: 1,
alignWithLabel: true,
lineStyle: {
type: 'dotted',
color: '#D8D8D8',
width: 4,
cap: 'round',
},
},
axisLine: {
lineStyle: {
color: '#8C8C8C',
type: 'dashed',
},
},
data: list.map((item) => dayjs(item.Date).format('MM-DD')),
axisLabel: {
formatter() {
return ''
},
},
},
],
yAxis: [
{
type: 'value',
minInterval: 1,
},
],
series: [
{
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: 0,
endValue: 4,
filterMode: 'none',
},
}
if (theme === 'DRUG') {
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],
},
}
})
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
})
})
},
initHormoneChart(defaultList = []) {
const { theme } = this.data
const list: any = defaultList
return new Promise((reslove) => {
this.ecDataHormoneComponent.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,
inside: true,
length: 1,
alignWithLabel: true,
lineStyle: {
type: 'dotted',
color: '#D8D8D8',
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: [
{
name: '激素用量',
data: list.length ? list.map((item) => item.SteroidDailyDose) : [20],
barWidth: '16',
type: 'line',
symbol: 'circle',
symbolSize: 8,
connectNulls: true,
showSymbol: list.length >= 1,
z: 10,
label: {
show: true,
position: 'top',
color: '#18474e',
z: 11,
formatter({ value }) {
return `${value}mg`
},
},
itemStyle: {
color: '#3192A1',
},
markLine: {
symbol: ['none', 'none'],
data: [
{
name: '达标区(5mg)',
yAxis: 5,
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: 5,
},
],
],
},
},
],
dataZoom: {
type: 'inside', // 有type这个属性,滚动条在最下面,也可以不行,写y:36,这表示距离顶端36px,一般就是在图上面。
startValue: 0,
endValue: 4,
filterMode: 'none',
},
}
if (theme === 'DRUG') {
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)
reslove(chart)
return chart
})
})
},
touchend(e) {
const { type } = e.currentTarget.dataset
const { page, defaultList } = this.data
if (type == 'left' && page > 0) {
this.setData({
page: page - 1,
})
this.initChart(defaultList)
this.initHormoneChart(defaultList)
} else if (type == 'right' && page < defaultList.length / 5 - 1) {
this.setData({
page: page + 1,
})
this.initChart(defaultList)
this.initHormoneChart(defaultList)
}
},
handleFoldAll() {
const { list } = this.data
this.setData({
list: list.map((item) => {
item.fold = !this.data.foldAll
return item
}),
foldAll: !this.data.foldAll,
})
},
handleFold(e) {
const { index } = e.currentTarget.dataset
this.setData({
[`list[${index}].fold`]: !this.data.list[index].fold,
})
},
handleDetail(e) {
const { id, isi } = e.currentTarget.dataset
const tab = this.data.tab
if (isi == 1) {
return
}
if (tab == 1) {
app.mpBehavior({ PageName: 'BTN_PATIENTHEALTHRECORDREPORTLIST' })
}
if (tab == 2) {
app.mpBehavior({ PageName: 'BTN_PATIENTHEALTHRECORDNOTESLIST' })
}
wx.navigateTo({
url: `/pages/adlResult/index?id=${id}`,
})
},
handleDel(e) {
const { id, index, isi } = e.currentTarget.dataset
if (isi == 1) {
return
}
if (index != 0) return
wx.showModal({
title: '确认删除?',
confirmColor: '#cf5375',
success: (res) => {
if (res.confirm) {
wx.ajax({
method: 'POST',
url: '?r=zd/adl/delete',
data: {
Id: id,
},
}).then(() => {
this.handleTabCallBack()
})
}
},
})
},
handleAdd() {
app.mpBehavior({ PageName: 'BTN_PATIENTHEALTHRECORDASSESSMENT' })
wx.navigateTo({
url: '/pages/adl/index',
})
},
handleAddDrug() {
app.mpBehavior({ PageName: 'BTN_PATIENTHEALTHRECORDMEDICATION' })
wx.navigateTo({
url: '/pages/drugRecord/index',
})
},
handleChartDetail() {
const that = this
wx.navigateTo({
url: '/gift/pages/myHealthRecordChart/index',
success(res) {
res.eventChannel.emit('acceptDataFromOpenerPage', {
list: that.data.defaultList,
selectLegends: that.data.selectLegends,
})
},
})
},
handleDetailDrug(e) {
const { id, isi } = e.currentTarget.dataset
app.mpBehavior({ PageName: 'BTN_PATIENTHEALTHRECORDMEDICATIONLIST' })
if (isi == 1) {
return
}
wx.navigateTo({
url: `/pages/drugRecord/index?id=${id}`,
})
},
handleDelDrug(e) {
const { id, isi } = e.currentTarget.dataset
if (isi == 1) {
return
}
wx.showModal({
title: '确认删除?',
confirmColor: '#cf5375',
success: (res) => {
if (res.confirm) {
wx.ajax({
method: 'POST',
url: '?r=zd/medication/delete',
data: {
Id: id,
},
}).then(() => {
this.handleTabCallBack()
})
}
},
})
},
toggleFold() {
this.setData({
fold: !this.data.fold,
})
},
handleShare() {
app.mpBehavior({ PageName: 'BTN_PATIENTHEALTHRECORDSHAREDUALCOMPLIANCEPOSTER' })
wx.navigateTo({
url: '/pages/adlShare/index',
})
},
handleBack() {
wx.navigateBack({
fail() {
wx.reLaunch({ url: '/pages/index/index' })
},
})
},
onShareAppMessage() {
return {
title: 'MG-ADL测评表:评估重症肌无力患者症状对生活质量的影响',
path: '/pages/adl/index',
}
},
})