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.
1092 lines
39 KiB
1092 lines
39 KiB
4 weeks ago
|
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',
|
||
|
}
|
||
|
},
|
||
|
})
|