| | |
| | | |
| | | |
| | | <view class="form-item"> |
| | | <view class="form-label">转运时间</view> |
| | | <view class="form-label required">转运时间</view> |
| | | <uni-datetime-picker |
| | | v-model="taskForm.transferTime" |
| | | type="datetime" |
| | |
| | | import uniPopup from '@/uni_modules/uni-popup/components/uni-popup/uni-popup.vue' |
| | | import { addTask } from "@/api/task" |
| | | import { listAvailableVehicles, getUserBoundVehicle } from "@/api/vehicle" |
| | | import { calculateDistance } from "@/api/map" |
| | | import { calculateDistance, baiduDistanceByAddress } from "@/api/map" |
| | | import { searchHospitals } from "@/api/hospital" |
| | | import { listUser } from "@/api/system/user" |
| | | import { searchIcd10 } from "@/api/icd10" |
| | |
| | | } |
| | | }, |
| | | onLoad(options) { |
| | | // 设置默认转运时间为当前时间 |
| | | this.setDefaultTransferTime() |
| | | |
| | | // 先加载车辆列表,然后加载绑定车辆信息 |
| | | this.getAvailableVehicles().then(() => { |
| | | this.getUserBoundVehicleInfo() |
| | |
| | | this.taskForm.hospitalIn.departmentId = selected.id // 保存科室ID |
| | | }, |
| | | |
| | | // 加载默认区院列表(前100条) |
| | | // 加载默认医院列表(前100条) |
| | | loadDefaultHospitals() { |
| | | // 传入空字符串或特殊标识获取前100条,同时传入地域过滤 |
| | | // 转出医院:只加载当前区域的医院(带地域过滤) |
| | | searchHospitals('', this.selectedRegion).then(response => { |
| | | this.defaultHospitals = response.data || [] |
| | | // 同时初始化两个搜索结果为默认数据 |
| | | this.hospitalOutResults = [...this.defaultHospitals] |
| | | this.hospitalInResults = [...this.defaultHospitals] |
| | | this.hospitalOutResults = response.data || [] |
| | | console.log('加载转出医院(当前区域):', this.selectedRegion, '数量:', this.hospitalOutResults.length) |
| | | }).catch(error => { |
| | | console.error('加载默认区院列表失败:', error) |
| | | this.defaultHospitals = [] |
| | | console.error('加载转出医院列表失败:', error) |
| | | this.hospitalOutResults = [] |
| | | }) |
| | | |
| | | // 转入医院:加载所有医院(不带地域过滤,后续会按地域排序) |
| | | searchHospitals('', this.selectedRegion).then(response => { |
| | | const allHospitals = response.data || [] |
| | | // 将医院按地域排序:本地区域优先 |
| | | this.hospitalInResults = this.sortHospitalsByRegion(allHospitals) |
| | | console.log('加载转入医院(全部区域):', '数量:', this.hospitalInResults.length) |
| | | }).catch(error => { |
| | | console.error('加载转入医院列表失败:', error) |
| | | this.hospitalInResults = [] |
| | | }) |
| | | }, |
| | | |
| | | // 按地域排序医院:本地区域优先 |
| | | sortHospitalsByRegion(hospitals) { |
| | | if (!this.selectedRegion || !hospitals || hospitals.length === 0) { |
| | | return hospitals |
| | | } |
| | | |
| | | const region = this.selectedRegion |
| | | const localHospitals = [] |
| | | const otherHospitals = [] |
| | | |
| | | hospitals.forEach(hospital => { |
| | | // 判断医院是否在本地区域(省、市、区任一包含地域关键词) |
| | | const isLocal = |
| | | (hospital.hopsProvince && hospital.hopsProvince.includes(region)) || |
| | | (hospital.hopsCity && hospital.hopsCity.includes(region)) || |
| | | (hospital.hopsArea && hospital.hopsArea.includes(region)) |
| | | |
| | | if (isLocal) { |
| | | localHospitals.push(hospital) |
| | | } else { |
| | | otherHospitals.push(hospital) |
| | | } |
| | | }) |
| | | |
| | | // 本地医院在前,其他医院在后 |
| | | return [...localHospitals, ...otherHospitals] |
| | | }, |
| | | |
| | | // 转出医院输入框获得焦点 |
| | | onHospitalOutFocus() { |
| | | // 如果没有搜索关键词,显示默认的100条数据 |
| | | // 如果没有搜索关键词,只显示当前区域的医院 |
| | | if (!this.hospitalOutSearchKeyword || this.hospitalOutSearchKeyword.trim() === '') { |
| | | this.hospitalOutResults = [...this.defaultHospitals] |
| | | searchHospitals('', this.selectedRegion).then(response => { |
| | | this.hospitalOutResults = response.data || [] |
| | | }).catch(error => { |
| | | console.error('加载转出医院失败:', error) |
| | | this.hospitalOutResults = [] |
| | | }) |
| | | } |
| | | this.showHospitalOutResults = true |
| | | }, |
| | |
| | | clearTimeout(this.searchTimer) |
| | | } |
| | | |
| | | // 如果关键词为空,显示默认100条 |
| | | // 如果关键词为空,只显示当前区域的医院 |
| | | if (!keyword || keyword.trim() === '') { |
| | | this.hospitalOutResults = [...this.defaultHospitals] |
| | | searchHospitals('', this.selectedRegion).then(response => { |
| | | this.hospitalOutResults = response.data || [] |
| | | }).catch(error => { |
| | | console.error('加载转出医院失败:', error) |
| | | this.hospitalOutResults = [] |
| | | }) |
| | | this.showHospitalOutResults = true |
| | | return |
| | | } |
| | | |
| | | // 有关键词时,去服务端搜索 |
| | | // 有关键词时,去服务端搜索(仅限当前区域) |
| | | this.searchTimer = setTimeout(() => { |
| | | this.searchHospitalOut(keyword) |
| | | }, 300) |
| | | }, |
| | | |
| | | // 搜索转出医院 |
| | | // 搜索转出医院(仅限当前区域) |
| | | searchHospitalOut(keyword) { |
| | | // 传入关键词和地域过滤 |
| | | // 传入关键词和地域过滤,只搜索当前区域的医院 |
| | | searchHospitals(keyword, this.selectedRegion).then(response => { |
| | | this.hospitalOutResults = response.data || [] |
| | | this.showHospitalOutResults = true |
| | | console.log('搜索转出医院:', keyword, '区域:', this.selectedRegion, '结果数:', this.hospitalOutResults.length) |
| | | }).catch(error => { |
| | | console.error('搜索医院失败:', error) |
| | | console.error('搜索转出医院失败:', error) |
| | | this.hospitalOutResults = [] |
| | | }) |
| | | }, |
| | |
| | | this.showHospitalOutResults = false |
| | | this.hospitalOutResults = [] |
| | | |
| | | // 如果有GPS坐标,保存下来 |
| | | // 注意:HospData表中可能没有GPS坐标,需要根据地址进行地理编码 |
| | | // 这里先置为null,后续可以通过地址解析获取 |
| | | this.addressCoordinates.hospitalOutAddress = null |
| | | // 保存转出医院的城市信息 |
| | | this.taskForm.hospitalOut.city = hospital.hopsCity || '' |
| | | |
| | | // 如果两个医院都已选择,自动计算距离 |
| | | if (this.taskForm.hospitalIn.address) { |
| | | // 这里可以调用地址解析和距离计算 |
| | | // 暂时留空,由用户手动输入距离 |
| | | this.calculateHospitalDistance() |
| | | } |
| | | }, |
| | | |
| | | // 转入医院输入框获得焦点 |
| | | onHospitalInFocus() { |
| | | // 如果没有搜索关键词,显示默认的100条数据 |
| | | // 如果没有搜索关键词,显示所有医院(本地区域优先) |
| | | if (!this.hospitalInSearchKeyword || this.hospitalInSearchKeyword.trim() === '') { |
| | | this.hospitalInResults = [...this.defaultHospitals] |
| | | searchHospitals('', '').then(response => { |
| | | const allHospitals = response.data || [] |
| | | // 按地域排序:本地区域优先 |
| | | this.hospitalInResults = this.sortHospitalsByRegion(allHospitals) |
| | | }).catch(error => { |
| | | console.error('加载转入医院失败:', error) |
| | | this.hospitalInResults = [] |
| | | }) |
| | | } |
| | | this.showHospitalInResults = true |
| | | }, |
| | |
| | | clearTimeout(this.searchTimer) |
| | | } |
| | | |
| | | // 如果关键词为空,显示默认100条 |
| | | // 如果关键词为空,显示所有医院(本地区域优先) |
| | | if (!keyword || keyword.trim() === '') { |
| | | this.hospitalInResults = [...this.defaultHospitals] |
| | | searchHospitals('', '').then(response => { |
| | | const allHospitals = response.data || [] |
| | | // 按地域排序:本地区域优先 |
| | | this.hospitalInResults = this.sortHospitalsByRegion(allHospitals) |
| | | }).catch(error => { |
| | | console.error('加载转入医院失败:', error) |
| | | this.hospitalInResults = [] |
| | | }) |
| | | this.showHospitalInResults = true |
| | | return |
| | | } |
| | | |
| | | // 有关键词时,去服务端搜索 |
| | | // 有关键词时,去服务端搜索(不限区域,但结果按地域排序) |
| | | this.searchTimer = setTimeout(() => { |
| | | this.searchHospitalIn(keyword) |
| | | }, 300) |
| | | }, |
| | | |
| | | // 搜索转入医院 |
| | | // 搜索转入医院(不限区域,但本地区域优先) |
| | | searchHospitalIn(keyword) { |
| | | // 传入关键词和地域过滤 |
| | | searchHospitals(keyword, this.selectedRegion).then(response => { |
| | | this.hospitalInResults = response.data || [] |
| | | // 传入关键词,不传地域过滤(搜索所有区域) |
| | | searchHospitals(keyword, '').then(response => { |
| | | const allHospitals = response.data || [] |
| | | // 按地域排序:本地区域优先 |
| | | this.hospitalInResults = this.sortHospitalsByRegion(allHospitals) |
| | | this.showHospitalInResults = true |
| | | console.log('搜索转入医院:', keyword, '结果数:', this.hospitalInResults.length) |
| | | }).catch(error => { |
| | | console.error('搜索医院失败:', error) |
| | | console.error('搜索转入医院失败:', error) |
| | | this.hospitalInResults = [] |
| | | }) |
| | | }, |
| | |
| | | this.showHospitalInResults = false |
| | | this.hospitalInResults = [] |
| | | |
| | | // 如果有GPS坐标,保存下来 |
| | | this.addressCoordinates.hospitalInAddress = null |
| | | // 保存转入医院的城市信息 |
| | | this.taskForm.hospitalIn.city = hospital.hopsCity || '' |
| | | |
| | | // 如果两个医院都已选择,自动计算距离 |
| | | if (this.taskForm.hospitalOut.address) { |
| | | // 这里可以调用地址解析和距离计算 |
| | | // 暂时留空,由用户手动输入距离 |
| | | this.calculateHospitalDistance() |
| | | } |
| | | }, |
| | | |
| | |
| | | this.selectedDiseases.splice(index, 1) |
| | | }, |
| | | |
| | | // 设置默认转运时间为当前时间 |
| | | setDefaultTransferTime() { |
| | | const now = new Date() |
| | | const year = now.getFullYear() |
| | | const month = String(now.getMonth() + 1).padStart(2, '0') |
| | | const day = String(now.getDate()).padStart(2, '0') |
| | | const hours = String(now.getHours()).padStart(2, '0') |
| | | const minutes = String(now.getMinutes()).padStart(2, '0') |
| | | const seconds = String(now.getSeconds()).padStart(2, '0') |
| | | |
| | | // 格式化为 YYYY-MM-DD HH:mm:ss |
| | | this.taskForm.transferTime = `${year}-${month}-${day} ${hours}:${minutes}:${seconds}` |
| | | }, |
| | | |
| | | validateForm() { |
| | | if (!this.selectedVehicleId) { |
| | | this.$modal.showToast('请选择任务车辆') |
| | |
| | | |
| | | if (!this.selectedDocumentType) { |
| | | this.$modal.showToast('请选择单据类型') |
| | | return false |
| | | } |
| | | |
| | | if (!this.taskForm.transferTime) { |
| | | this.$modal.showToast('请选择转运时间') |
| | | return false |
| | | } |
| | | |
| | |
| | | parts.push(hospital.hospAddress) |
| | | } |
| | | return parts.join('') |
| | | }, |
| | | |
| | | // 自动计算两个医院之间的距离 |
| | | calculateHospitalDistance() { |
| | | const fromAddress = this.taskForm.hospitalOut.address |
| | | const fromCity = this.taskForm.hospitalOut.city |
| | | const toAddress = this.taskForm.hospitalIn.address |
| | | const toCity = this.taskForm.hospitalIn.city |
| | | |
| | | if (!fromAddress || !toAddress) { |
| | | console.log('地址信息不完整,无法计算距离') |
| | | return |
| | | } |
| | | |
| | | console.log('开始计算距离:', fromAddress, '->', toAddress) |
| | | |
| | | // 显示加载提示 |
| | | uni.showLoading({ |
| | | title: '计算距离中...' |
| | | }) |
| | | |
| | | // 调用百度地图API计算距离 |
| | | baiduDistanceByAddress(fromAddress, fromCity, toAddress, toCity) |
| | | .then(response => { |
| | | uni.hideLoading() |
| | | |
| | | if (response.code === 200 && response.data) { |
| | | const distanceInMeters = response.data.distance |
| | | // 转换为公里,保留1位小数 |
| | | const distanceInKm = (distanceInMeters / 1000).toFixed(1) |
| | | this.taskForm.transferDistance = distanceInKm |
| | | |
| | | console.log('距离计算成功:', distanceInKm, 'km') |
| | | this.$modal.showToast(`距离计算成功: ${distanceInKm}公里`) |
| | | } else { |
| | | console.error('距离计算失败:', response.msg) |
| | | this.$modal.showToast('距离计算失败,请手动输入') |
| | | } |
| | | }) |
| | | .catch(error => { |
| | | uni.hideLoading() |
| | | console.error('距离计算失败:', error) |
| | | this.$modal.showToast('距离计算失败,请手动输入') |
| | | }) |
| | | } |
| | | } |
| | | } |