diff --git a/.env.cas b/.env.cas new file mode 100644 index 0000000..ab26350 --- /dev/null +++ b/.env.cas @@ -0,0 +1,16 @@ +# 页面标题 +VITE_APP_TITLE = 平安水电 + +# CAS 专用构建环境(生产模式) +VITE_APP_ENV = production + +# 生产环境后端前缀 +VITE_APP_BASE_API = '/prod-api' + +# 启用 gzip 压缩 +VITE_BUILD_COMPRESS = gzip + +# CAS 配置(启用CAS模式打包) +VITE_APP_CAS_ENABLE = true +VITE_APP_CAS_SERVER_URL = https://rsso.gxsdxy.cn +VITE_APP_CAS_VALIDATE_URL = https://rsso.gxsdxy.cn/p3/serviceValidate \ No newline at end of file diff --git a/.env.production b/.env.production index ae3f82e..3b751b2 100644 --- a/.env.production +++ b/.env.production @@ -2,10 +2,15 @@ VITE_APP_TITLE = 平安水电 # 生产环境配置 -VITE_APP_ENV = 'production' +VITE_APP_ENV = production # 若依管理系统/生产环境 VITE_APP_BASE_API = '/prod-api' # 是否在打包时开启压缩,支持 gzip 和 brotli -VITE_BUILD_COMPRESS = gzip \ No newline at end of file +VITE_BUILD_COMPRESS = gzip + +# CAS 配置(非CAS模式打包) +VITE_APP_CAS_ENABLE = false +VITE_APP_CAS_SERVER_URL = https://rsso.gxsdxy.cn +VITE_APP_CAS_VALIDATE_URL = https://rsso.gxsdxy.cn/p3/serviceValidate \ No newline at end of file diff --git a/dist.zip b/dist.zip deleted file mode 100644 index a050a4b..0000000 Binary files a/dist.zip and /dev/null differ diff --git a/package.json b/package.json index 34c6e77..d28e7fd 100644 --- a/package.json +++ b/package.json @@ -2,13 +2,14 @@ "name": "ruoyi", "version": "3.8.8", "description": "平安水电", - "author": "若依", + "author": "厚溥", "license": "MIT", "type": "module", "scripts": { "dev": "vite", "build:prod": "vite build", "build:stage": "vite build --mode staging", + "build:cas": "vite build --mode cas", "preview": "vite preview" }, "repository": { diff --git a/src/api/healthcare/outpatientService/patientDiagnosis.js b/src/api/healthcare/outpatientService/patientDiagnosis.js index cfa3f0c..0c4bd59 100644 --- a/src/api/healthcare/outpatientService/patientDiagnosis.js +++ b/src/api/healthcare/outpatientService/patientDiagnosis.js @@ -1,23 +1,30 @@ import request from '@/utils/request' -// 查询患者诊断信息列表 +const defaultYearDate = () => new Date() +const withYearDate = (query) => ({ + yearDate: (query && query.yearDate) || defaultYearDate(), + ...(query || {}) +}) + +// 查询患者诊断信息列�? export function listPatientDiagnosis(query) { return request({ url: '/outpatientService/patientDiagnosis/list', method: 'get', - params: query + params: withYearDate(query) }) } -// 查询患者诊断信息详细 +// 查询患者诊断信息详�? export function getPatientDiagnosis(id) { return request({ url: '/outpatientService/patientDiagnosis/getInfo/' + id, - method: 'get' + method: 'get', + params: { yearDate: defaultYearDate() } }) } -// 新增患者诊断信息 +// 新增患者诊断信�? export function addPatientDiagnosis(data) { return request({ url: '/outpatientService/patientDiagnosis/add', @@ -26,7 +33,7 @@ export function addPatientDiagnosis(data) { }) } -// 修改患者诊断信息 +// 修改患者诊断信�? export function updatePatientDiagnosis(data) { return request({ url: '/outpatientService/patientDiagnosis/update', @@ -35,11 +42,12 @@ export function updatePatientDiagnosis(data) { }) } -// 删除患者诊断信息 +// 删除患者诊断信�? export function delPatientDiagnosis(id) { return request({ url: '/outpatientService/patientDiagnosis/remove/' + id, - method: 'get' + method: 'get', + params: { yearDate: defaultYearDate() } }) } @@ -58,7 +66,7 @@ export function gainDrugPriceList(query) { return request({ url: '/outpatientService/patientDiagnosis/gainDrugPriceList', method: 'get', - params: query + params: withYearDate(query) }) } @@ -67,6 +75,7 @@ export function gainDrugNameList() { return request({ url: '/outpatientService/patientDiagnosis/gainMedicineNameList', method: 'get', + params: { yearDate: defaultYearDate() }, }) } @@ -75,6 +84,7 @@ export function gainDrugNameListName(name) { return request({ url: '/outpatientService/patientDiagnosis/gainMedicineNameListName?name=' + name, method: 'get', + params: { yearDate: defaultYearDate() }, }) } @@ -83,7 +93,7 @@ export function gainMedicineArchiveList(query) { return request({ url: '/outpatientService/patientDiagnosis/gainMedicineArchiveList', method: 'get', - params: query + params: withYearDate(query) }) } @@ -92,27 +102,29 @@ export function gainDrugInventoryList(query) { return request({ url: '/outpatientService/patientDiagnosis/gainDrugInventoryList', method: 'get', - params: query + params: withYearDate(query) }) } -// 修改患者诊断状态 ( 修改为 已发药 ) +// 修改患者诊断状�?( 修改�?已发�?) export function deliverMedicine(id) { return request({ url: '/outpatientService/patientDiagnosis/deliverMedicine/' + id, - method: 'get' + method: 'get', + params: { yearDate: defaultYearDate() } }) } -// 修改患者诊断状态 ( 修改为 已退药 ) +// 修改患者诊断状�?( 修改�?已退�?) export function returnedMedication(id) { return request({ url: '/outpatientService/patientDiagnosis/returnedMedication/' + id, - method: 'get' + method: 'get', + params: { yearDate: defaultYearDate() } }) } -// 保存 患者 诊断 信息 +// 保存 患�?诊断 信息 export function saveDiagnosis(data) { return request({ url: '/outpatientService/patientDiagnosis/save', @@ -121,7 +133,7 @@ export function saveDiagnosis(data) { }) } -// 保存 变成 待发 修改 库存 患者 诊断 信息 +// 保存 变成 待发 修改 库存 患�?诊断 信息 export function saveAddDiagnosis(data) { return request({ url: '/outpatientService/patientDiagnosis/saveAddDiagnosis', @@ -130,7 +142,7 @@ export function saveAddDiagnosis(data) { }) } -// 保存 修改 患者 诊断 信息 +// 保存 修改 患�?诊断 信息 export function saveUpdate(data) { return request({ url: '/outpatientService/patientDiagnosis/saveUpdate', @@ -145,6 +157,7 @@ export function gainPatientDiagnosisListXml() { return request({ url: '/outpatientService/patientDiagnosis/gainPatientDiagnosisListXml', method: 'get', + params: { yearDate: defaultYearDate() }, }) } @@ -153,6 +166,7 @@ export function gainPatientDiagnosisListTotalPriceXml() { return request({ url: '/outpatientService/patientDiagnosis/gainPatientDiagnosisListTotalPriceXml', method: 'get', + params: { yearDate: defaultYearDate() }, }) } @@ -164,7 +178,7 @@ export function obtainSymptomStatisticsNumber(query) { return request({ url: '/outpatientService/patientDiagnosis/obtainSymptomStatisticsNumber', method: 'get', - params: query + params: withYearDate(query) }) } @@ -174,15 +188,33 @@ export function obtainSymptomStatisticsNumberMonth(query) { return request({ url: '/outpatientService/patientDiagnosis/obtainSymptomStatisticsNumberMonth', method: 'get', - params: query + params: withYearDate(query) }) } -// 调用后端的代码判断是否可用医保 -export function verifyInsuranceStatus(idCard,name) { +// 调用后端的代码判断是否可用医�? +export function verifyInsuranceStatus(idCard, name) { return request({ url: '/outpatientService/patientDiagnosis/verify', method: 'get', - params: { idCard,name} + params: withYearDate({ idCard, name }) + }) +} + +// 获取历史医保报销累计金额(按患者ID�? +export function getHistoryReimbursement(patientId, yearDate = new Date()) { + return request({ + url: '/outpatientService/patientDiagnosis/getHistoryReimbursementByYear', + method: 'get', + params: { patientId, yearDate } + }) +} + +// 发药更正:仅调整医保与报销比率 +export function adjustBasic(data) { + return request({ + url: '/outpatientService/patientDiagnosis/adjustBasic', + method: 'post', + data: data }) } diff --git a/src/api/inspection/abnormal.js b/src/api/inspection/abnormal.js new file mode 100644 index 0000000..6e1eb23 --- /dev/null +++ b/src/api/inspection/abnormal.js @@ -0,0 +1,44 @@ +import request from '@/utils/request' + +// 查询巡检异常列表 +export function listAbnormal(query) { + return request({ + url: '/inspection/abnormal/list', + method: 'get', + params: query + }) +} + +// 查询巡检异常详细 +export function getAbnormal(id) { + return request({ + url: '/inspection/abnormal/' + id, + method: 'get' + }) +} + +// 新增巡检异常 +export function addAbnormal(data) { + return request({ + url: '/inspection/abnormal', + method: 'post', + data: data + }) +} + +// 修改巡检异常 +export function updateAbnormal(data) { + return request({ + url: '/inspection/abnormal', + method: 'put', + data: data + }) +} + +// 删除巡检异常 +export function delAbnormal(id) { + return request({ + url: '/inspection/abnormal/' + id, + method: 'delete' + }) +} diff --git a/src/api/inspection/report.js b/src/api/inspection/report.js index 05a4b23..e9b3456 100644 --- a/src/api/inspection/report.js +++ b/src/api/inspection/report.js @@ -33,4 +33,93 @@ export function RoundList(query) { method: 'get', params: query }) - } \ No newline at end of file + } + +// 按天趋势统计 +export function trendDaily(query) { + return request({ + url: '/inspection/report/trendDaily', + method: 'get', + params: query + }) +} + +// 新增:按天双序列 +export function trendDailyDual(query) { + return request({ + url: '/inspection/report/trendDailyDual', + method: 'get', + params: query + }) +} + +// 新增:按月双序列 +export function trendMonthlyDual(query) { + return request({ + url: '/inspection/report/trendMonthlyDual', + method: 'get', + params: query + }) +} + +// 巡检类型占比 +export function typeProportion(query) { + return request({ + url: '/inspection/report/typeProportion', + method: 'get', + params: query + }) +} + +// 覆盖率统计 +export function coverage(query) { + return request({ + url: '/inspection/report/coverage', + method: 'get', + params: query + }) +} + +// 未巡检点清单 +export function uninspectedPoints(query) { + return request({ + url: '/inspection/report/uninspectedPoints', + method: 'get', + params: query + }) +} + +// 点位类型已巡检次数(distinct) +export function pointTypeCounts(query) { + return request({ + url: '/inspection/report/pointTypeCounts', + method: 'get', + params: query + }) +} + +// 点位状态分布 +export function statusDistribution() { + return request({ + url: '/inspection/report/statusDistribution', + method: 'get' + }) +} + +// 巡检人统计(三合一:总/月/日) +export function inspectorStats3(query) { + return request({ + url: '/inspection/report/inspectorStats3', + method: 'get', + params: query + }) +} + +// 巡检点统计(三合一:总/月/日) +export function pointStats3(query) { + return request({ + url: '/inspection/report/pointStats3', + method: 'get', + params: query + }) +} \ No newline at end of file diff --git a/src/api/login.js b/src/api/login.js index 7b7388f..9cd0fcd 100644 --- a/src/api/login.js +++ b/src/api/login.js @@ -57,4 +57,18 @@ export function getCodeImg() { method: 'get', timeout: 20000 }) +} + +// CAS 登录方法(通过请求参数传递 ticket 与 service) +export function casLogin(data) { + return request({ + url: '/cas/login', + headers: { + isToken: false, + repeatSubmit: false + }, + method: 'post', + // 后端使用 @RequestParam 接收参数 + params: data + }) } \ No newline at end of file diff --git a/src/components/Healthcare/OutpatientService/DiagnosisInformation/index.vue b/src/components/Healthcare/OutpatientService/DiagnosisInformation/index.vue index 9240047..2581b17 100644 --- a/src/components/Healthcare/OutpatientService/DiagnosisInformation/index.vue +++ b/src/components/Healthcare/OutpatientService/DiagnosisInformation/index.vue @@ -171,7 +171,7 @@ - + @@ -187,16 +187,16 @@ - + + " label="报销比率" prop="value"> + " @input="calculationWholeTotal()" v-model="form.value" clearable placeholder="请输入报销比率" /> @@ -297,13 +297,27 @@ - + - + -
- 所有药品总价和: {{ totalPriceSum }} 元 +
+ + 应收金额:{{ form.isInsured === 0 ? patientPay : ceilPrice(totalPriceSum) }} 元 + + + 处方总金额:{{ ceilPrice(totalPriceSum) }} 元 + + + 预计报销:{{ Number(currentReimbursement).toFixed(2) }} 元 +
@@ -321,6 +335,16 @@ // const { proxy } = getCurrentInstance() +// 价格向上取整到小数点后两位(进一法) +// 先缩放到整数避免浮点精度问题 +function ceilPrice(value) { + const num = Number(value) + if (isNaN(num)) return '0.00' + const scaled = Math.round(num * 10000) + const cents = Math.ceil(scaled / 100) + return (cents / 100).toFixed(2) +} + // 患者类型 const { healthcare_os_patient_type } = proxy.useDict('healthcare_os_patient_type') // os_patient_type @@ -348,6 +372,8 @@ const form = ref({}) const checkId = ref(0) const totalPriceSum = ref(0) //所有药品总价和 +const currentReimbursement = ref(0) +const patientPay = ref(0) // const props = defineProps({ @@ -593,7 +619,7 @@ const props = defineProps({ { id: 5, name: 'el-row', - description: '6 是否医保 医保率 ', + description: '6 是否医保 报销比率 ', display: true, colList: [ { @@ -614,12 +640,12 @@ const props = defineProps({ { id: 1, name: 'el-col', - description: '6 医保率 col', + description: '6 报销比率 col', display: true, data: [ { id: 0, - name: '医保率', + name: '报销比率', display: true, prohibit: false } @@ -844,11 +870,24 @@ watch( // title.value = '患者诊断信息' // console.log('获取数据111111111111:', form.value) // 更新总价和 - totalPriceSum.value = form.value.prescriptionDetailsList + totalPriceSum.value = ceilPrice(form.value.prescriptionDetailsList .reduce((sum, prescription) => { return sum + prescription.reduce((innerSum, drug) => innerSum + parseFloat(drug.totalPrice || 0), 0) - }, 0) - .toFixed(2) + }, 0)) + const insured = form.value?.isInsured + const sumNum = Number(totalPriceSum.value || 0) + if (insured === 0) { + const rate = Number(form.value?.value || 0) / 100 + const r = isNaN(rate) ? 0 : rate + // 先计算个人应付(向上取整) + const pay = ceilPrice(sumNum * (1 - r)) + patientPay.value = pay + // 预计报销 = 总价 - 个人应付 + currentReimbursement.value = (sumNum - Number(pay)).toFixed(2) + } else { + currentReimbursement.value = '0.00' + patientPay.value = ceilPrice(sumNum) + } }) } ) diff --git a/src/components/Healthcare/OutpatientService/DiagnosisInformation/use.ts b/src/components/Healthcare/OutpatientService/DiagnosisInformation/use.ts index cfd21e4..cbe2624 100644 --- a/src/components/Healthcare/OutpatientService/DiagnosisInformation/use.ts +++ b/src/components/Healthcare/OutpatientService/DiagnosisInformation/use.ts @@ -238,7 +238,7 @@ export default function () { { id: 5, name: "el-row", - description: "6 是否医保 医保率 ", + description: "6 是否医保 报销比率 ", display: true, colList: [ { @@ -259,12 +259,12 @@ export default function () { { id: 1, name: "el-col", - description: "6 医保率 col", + description: "6 报销比率 col", display: true, data: [ { id: 0, - name: "医保率", + name: "报销比率", display: true, prohibit: true, }, @@ -679,7 +679,7 @@ export default function () { { id: 5, name: "el-row", - description: "6 是否医保 医保率 ", + description: "6 是否医保 报销比率 ", display: true, colList: [ { @@ -700,12 +700,12 @@ export default function () { { id: 1, name: "el-col", - description: "6 医保率 col", + description: "6 报销比率 col", display: true, data: [ { id: 0, - name: "医保率", + name: "报销比率", display: true, prohibit: false, }, diff --git a/src/components/Healthcare/OutpatientService/PatientDossier/index.vue b/src/components/Healthcare/OutpatientService/PatientDossier/index.vue index e5abcaf..38a11a6 100644 --- a/src/components/Healthcare/OutpatientService/PatientDossier/index.vue +++ b/src/components/Healthcare/OutpatientService/PatientDossier/index.vue @@ -183,6 +183,7 @@ function selectValue(row) { if (row != null) { console.log('获取患者信息', row) const data = { + id: row.id, patientType: row.patientType, studentId: row.studentId, name: row.name, diff --git a/src/components/Healthcare/OutpatientService/PrescriptionList/index.vue b/src/components/Healthcare/OutpatientService/PrescriptionList/index.vue index 68e0ba6..d60d311 100644 --- a/src/components/Healthcare/OutpatientService/PrescriptionList/index.vue +++ b/src/components/Healthcare/OutpatientService/PrescriptionList/index.vue @@ -274,7 +274,7 @@ }, ]"> - {{ prescription[scope.$index].unitPrice.toFixed(2) }} + {{ Number(prescription[scope.$index].unitPrice || 0).toFixed(2) }} @@ -289,7 +289,13 @@ trigger: controlData[9].check[0].trigger, }, ]"> - {{ prescription[scope.$index].totalPrice.toFixed(2) }}元 + {{ + Number(isInsured) === 0 + ? ceilPrice( + (parseFloat(prescription[scope.$index].totalPrice || 0) * (1 - (parseFloat(reimbursementRate || 0) / 100))) + ) + : ceilPrice(prescription[scope.$index].totalPrice || 0) + }}元 @@ -339,6 +345,16 @@ import { listCommonUsage, listEatingTime, listFrequency } from '@/api/healthcare const { proxy } = getCurrentInstance() +// 价格向上取整到小数点后两位(进一法) +// 先缩放到整数避免浮点精度问题 +function ceilPrice(value) { + const num = Number(value) + if (isNaN(num)) return '0.00' + const scaled = Math.round(num * 10000) + const cents = Math.ceil(scaled / 100) + return (cents / 100).toFixed(2) +} + const { os_patient_type } = proxy.useDict('os_patient_type') // os_patient_type const { os_diagnosis_type } = proxy.useDict('os_diagnosis_type') @@ -390,6 +406,14 @@ const props = defineProps({ prescriptionData: { type: Array }, + isInsured: { + type: [Number, String], + default: 1 + }, + reimbursementRate: { + type: [Number, String], + default: 0 + }, // 控制 纽约 的 显示 隐藏 controlButton: { type: Array, @@ -891,11 +915,10 @@ function calculationTotal(index) { } console.log('totalPrice11111:', form.value.prescription) // 更新总价和 - totalPriceSum.value = form.value.prescription + totalPriceSum.value = ceilPrice(form.value.prescription .reduce((sum, prescri) => { return sum + prescri.reduce((innerSum, drug) => innerSum + parseFloat(drug.totalPrice || 0), 0) - }, 0) - .toFixed(2) + }, 0)) } // 药品 档案 弹框 diff --git a/src/components/ReportAnalytics/CircularDiagram.vue b/src/components/ReportAnalytics/CircularDiagram.vue index f4d7d0e..c4e174e 100644 --- a/src/components/ReportAnalytics/CircularDiagram.vue +++ b/src/components/ReportAnalytics/CircularDiagram.vue @@ -4,7 +4,7 @@ + + diff --git a/src/views/fire/report/index.vue b/src/views/fire/report/index.vue index cb615f7..57e1244 100644 --- a/src/views/fire/report/index.vue +++ b/src/views/fire/report/index.vue @@ -76,7 +76,7 @@ - + - +
fire_facility_type.value || []); const facilityStatuses = computed(() => fire_facility_status.value || []); const isDictLoaded = computed(() => { - // 不仅判断长度,还要验证是否包含有效数据(避免空数组误判) + // 不仅判断长度,还要验证是否包含有效数据(避免空数组误判) return facilityTypes.value.length > 0 && facilityStatuses.value.length > 0 && facilityTypes.value.some(item => item.value !== undefined) && @@ -183,7 +183,7 @@ const detailDialog = ref(false); const dialogTitle = ref(""); // 弹窗类型标识 -const dialogType = ref(""); // 'total' 表示总数弹窗,'status' 表示状态弹窗 +const dialogType = ref(""); // 'total' 表示总数弹窗,'status' 表示状态弹窗 const currentStatusValue = ref(null); // 分页配置 @@ -193,15 +193,15 @@ const pagination = reactive({ total: 0 }); -// 查询参数 - 确保初始值为null(符合后端预期) +// 查询参数 - 确保初始值为null(符合后端预期) const queryParams = reactive({ facilityType: null, }); -// 3. 核心方法:查询报表数据 +// 3. 核心方法:查询报表数据 const handleQuery = () => { loading.value = true; - // 打印查询参数,便于调试 + // 打印查询参数,便于调试 console.log("查询参数:", queryParams); getReportData(queryParams) .then((res) => { @@ -214,7 +214,7 @@ const handleQuery = () => { }) .catch((err) => { console.error("查询报表失败:", err); - proxy.$message.error("获取数据失败,请稍后重试"); + proxy.$message.error("获取数据失败,请稍后重试"); reportData.value = []; totalCount.value = 0; }) @@ -314,7 +314,7 @@ const showTotalDetail = async () => { const loadTotalDetailPage = async () => { detailLoading.value = true; try { - // 获取所有数据(不分页)用于计算总数和分页 + // 获取所有数据(不分页)用于计算总数和分页 const allDataRes = await getAllData({ facilityType: queryParams.facilityType }); @@ -382,7 +382,7 @@ const resetQuery = () => { handleQuery(); }; -// 8. 辅助方法:时间格式化 +// 8. 辅助方法:时间格式化 const parseTime = (time) => { if (!time) return "-"; const date = new Date(time); @@ -393,7 +393,7 @@ const parseTime = (time) => { }); }; -// 9. 辅助方法:过期日期标签类型 +// 9. 辅助方法:过期日期标签类型 const getExpiryTagType = (expiryDate) => { if (!expiryDate) return "default"; const today = new Date(); @@ -411,7 +411,7 @@ onMounted(() => { // proxy.$message.warning(`检测到${invalidStatus.length}个状态样式配置错误`); // } - // 初始化查询逻辑(确保字典加载后执行) + // 初始化查询逻辑(确保字典加载后执行) const initQuery = () => { if (isDictLoaded.value) { handleQuery(); @@ -420,7 +420,7 @@ onMounted(() => { const unwatch = watch(isDictLoaded, (loaded) => { if (loaded) { handleQuery(); - unwatch(); // 执行后销毁监听,避免重复调用 + unwatch(); // 执行后销毁监听,避免重复调用 } }); } @@ -430,7 +430,7 @@ onMounted(() => { initQuery(); }); -// 移除原有的watch(isDictLoaded),改用onMounted中的逻辑 +// 移除原有的watch(isDictLoaded),改用onMounted中的逻辑 + + +
+ +
+

南宁市社会医疗机构专用处方笺

+
+ + +
+
+
费别:
+
+ ${insuranceInfo} 对号划✓ +
+
+ +
+
姓名:
+
${data.name || ''} 
+ +
性别:
+
${genderDisplay} 
+ +
年龄:
+
${data.age || ''} 
+
+ +
+
门诊病历�?
+
${data.medicalRecordNo || ''} 
+ +
科别:
+
${data.classInfo || ''}
+
+ +
+
临床诊断:
+
${data.diagnosis || ''} 
+
+ +
+
开具日�?
+
+ ${dateObj.year}�? + ${dateObj.month}�? + ${dateObj.day}�? +
+
+ + + +
+
主诉: ${data.chiefComplaint || '�?}
+
现病�? ${data.presentIllness || '�?}
+
既往�? ${data.pastHistory || '�?}
+ +
+
Rp:${data.medicalAdvice || ''}
+
+ + + +
+
处方详情
+ + + + + + + + + + + + + + ${data.prescriptionDetailsList?.flat().map((item, index) => ` + + + + + + + + + + `).join('') || ''} + +
序号药品名称规格用法用量频次总量
${index + 1}${item.medicineName || ''}${item.specification || ''}${item.usageValue || ''}${item.dosageValue || ''} ${formatUnit(item.splitUnit) || ''}${formatFrequency(item.frequency) || ''}${item.totalQuantity || ''} ${formatUnit(item.packageUnit) || ''}
无处�?/td>
+
+ + + + + + `; + + // 写入打印内容 + printWindow.document.write(printContent); + printWindow.document.close(); + + // 等待内容加载完成后自动打�? + printWindow.onload = function () { + setTimeout(() => { + printWindow.print(); + }, 500); + }; +} + +// 主诉相关数据 +const complaintsOptions = ref([]) +const loadingComplaints = ref(false) + +// 初始化时加载主诉模板 +onMounted(() => { + loadComplaintsOptions() +}) + +// 加载主诉模板 +const loadComplaintsOptions = async () => { + try { + loadingComplaints.value = true + const response = await listHealthcareOsComplaints({status: 0}) + complaintsOptions.value = response.rows.map(item => ({ + value: item.complaintName, + label: item.complaintName, + ...item + })) + } catch (error) { + console.error('加载主诉模板失败:', error) + } finally { + loadingComplaints.value = false + } +} + +// 处理输入框获取焦点事�? +const handleComplaintFocus = () => { + if (!loadingComplaints.value && complaintsOptions.value.length === 0) { + loadComplaintsOptions() + } +} + +// 查询主诉建议 +const queryComplaintSuggestions = async (queryString, cb) => { + try { + // 如果没有查询字符串或为空,返回所有选项 + if (!queryString || queryString.trim() === '') { + cb(complaintsOptions.value); + return; + } + + // 将查询字符串转为小写以便不区分大小写 + const searchTerm = queryString.toLowerCase(); + + // 过滤匹配的选项 + const filteredOptions = complaintsOptions.value.filter(option => { + // 检查选项的label或value是否包含搜索�? + return ( + (option.label && option.label.toLowerCase().includes(searchTerm)) || + (option.value && option.value.toLowerCase().includes(searchTerm)) + ); + }); + + cb(filteredOptions); + } catch (error) { + console.error('查询主诉失败:', error); + cb([]); + } +}; + +// 选择主诉 +const selectComplaint = (item) => { + if (item.isCustom) { + // 自由输入 + form.value.chiefComplaint = item.value + } else { + // 选择模板 + form.value.chiefComplaint = item.label + form.value.presentIllness = item.currentHistory || '' + form.value.pastHistory = item.pastHistory || '' + form.value.diagnosis = item.diagnosis || '' + form.value.medicalAdvice = item.medicalAdvice || '' + } +} +// 清空主诉及相关字�? +const clearComplaint = () => { + form.value.chiefComplaint = '' + form.value.presentIllness = '' + form.value.pastHistory = '' + form.value.diagnosis = '' + form.value.medicalAdvice = '' +} + +// +const timesData = ref('饭后') +const xuanZheData = (val, index) => { + console.log('选中12345'); + console.log(val, index); +} + + +getList() + + + diff --git a/src/views/healthcare/pharmacy/dispensing/index.vue b/src/views/healthcare/pharmacy/dispensing/index.vue index 78110a0..5f3d9c7 100644 --- a/src/views/healthcare/pharmacy/dispensing/index.vue +++ b/src/views/healthcare/pharmacy/dispensing/index.vue @@ -161,16 +161,16 @@ - + - - + + @@ -439,7 +439,7 @@ }, ]"> - {{ form.prescriptionDetailsList[item][scope.$index].unitPrice.toFixed(2) }} + {{ Number(form.prescriptionDetailsList[item][scope.$index].unitPrice || 0).toFixed(2) }} @@ -452,7 +452,7 @@ }, ]"> - {{ form.prescriptionDetailsList[item][scope.$index].unitPrice.toFixed(2) }} + {{ Number(form.prescriptionDetailsList[item][scope.$index].unitPrice || 0).toFixed(2) }} @@ -461,7 +461,14 @@ @@ -481,12 +488,21 @@ - +
- 所有药品总价和: {{ totalPriceSum }} 元 + + 应收金额:{{ form.isInsured === 0 ? patientPay : ceilPrice(totalPriceSum) }} 元 + + + 处方总金额:{{ ceilPrice(totalPriceSum) }} 元 + + + 预计报销:{{ Number(currentReimbursement).toFixed(2) }} 元 +
+
@@ -498,6 +514,11 @@ 驳回 + 更正 + 保存更正 + 取消 取 消
@@ -516,7 +537,18 @@ diff --git a/src/views/inspection/manage/index.vue b/src/views/inspection/manage/index.vue index d8e926c..211035d 100644 --- a/src/views/inspection/manage/index.vue +++ b/src/views/inspection/manage/index.vue @@ -36,7 +36,7 @@ >删除 --> - 批量生产二维码 + 批量生成二维码 + + + diff --git a/src/views/register.vue b/src/views/register.vue index 7bb3812..dcae782 100644 --- a/src/views/register.vue +++ b/src/views/register.vue @@ -70,7 +70,7 @@
diff --git a/vite.config.js b/vite.config.js index 3441c9e..ec3666d 100644 --- a/vite.config.js +++ b/vite.config.js @@ -5,11 +5,13 @@ import createVitePlugins from './vite/plugins' // https://vitejs.dev/config/ export default defineConfig(({ mode, command }) => { const env = loadEnv(mode, process.cwd()) - const { VITE_APP_ENV } = env + const { VITE_APP_ENV, VITE_APP_CAS_ENABLE } = env return { // 部署生产环境和开发环境下的URL. - base: VITE_APP_ENV === 'production' ? '/' : '/', + // 根据 .env 中的 CAS 开关动态设置 base 路径 + // 注意:不要从 src/settings 引入,因为 vite 配置运行在 Node 环境,无法使用 import.meta.env + base: VITE_APP_ENV === 'production' ? ((VITE_APP_CAS_ENABLE === 'true') ? '/cas/' : '/srs/') : '/', plugins: createVitePlugins(env, command === 'build'), resolve: { // https://cn.vitejs.dev/config/#resolve-alias @@ -26,8 +28,8 @@ export default defineConfig(({ mode, command }) => { proxy: { // https://cn.vitejs.dev/config/#server-proxy '/dev-api': { - target: 'http://localhost:8080', // 测试 - // target: 'http://172.16.129.101:8080', // 正式环境 + // target: 'http://localhost:8080', // 测试 + target: 'http://172.16.129.101:8080', // 正式环境 changeOrigin: true, rewrite: (p) => p.replace(/^\/dev-api/, '') }, diff --git a/vite.config.js.timestamp-1760689999596-49762782f98ed.mjs b/vite.config.js.timestamp-1760689999596-49762782f98ed.mjs new file mode 100644 index 0000000..b6ee6a1 --- /dev/null +++ b/vite.config.js.timestamp-1760689999596-49762782f98ed.mjs @@ -0,0 +1,202 @@ +// vite.config.js +import path2 from "path"; +import { defineConfig, loadEnv } from "file:///D:/code/pasd_V1.0/pasd_pc/node_modules/vite/dist/node/index.js"; + +// src/settings.js +var settings_default = { + /** + * 网页标题 + */ + title: import.meta.env?.VITE_APP_TITLE || "\u5E73\u5B89\u6C34\u7535", + /** + * 侧边栏主题 深色主题theme-dark,浅色主题theme-light + */ + sideTheme: "theme-dark", + /** + * 是否系统布局配置 + */ + showSettings: true, + /** + * 是否显示顶部导航 + */ + topNav: false, + /** + * 是否显示 tagsView + */ + tagsView: true, + /** + * 是否固定头部 + */ + fixedHeader: false, + /** + * 是否显示logo + */ + sidebarLogo: true, + /** + * 是否显示动态标题 + */ + dynamicTitle: false, + /** + * @type {string | array} 'production' | ['production', 'development'] + * @description Need show err logs component. + * The default is only used in the production env + * If you want to also use it in dev, you can pass ['production', 'development'] + */ + errorLog: "production", + /** + * CAS登录配置 + */ + // 是否启用CAS登录 (true: CAS登录模式, false: 传统登录模式) + casEnable: true, + // CAS服务器地址 + casServerUrl: "https://rsso.gxsdxy.cn", + // 部署路径配置 (CAS模式: /cas/, 传统模式: /srs/) + deployPath: function() { + return this.casEnable ? "/cas/" : "/srs/"; + } +}; + +// vite/plugins/index.js +import vue from "file:///D:/code/pasd_V1.0/pasd_pc/node_modules/@vitejs/plugin-vue/dist/index.mjs"; + +// vite/plugins/auto-import.js +import autoImport from "file:///D:/code/pasd_V1.0/pasd_pc/node_modules/unplugin-auto-import/dist/vite.js"; +function createAutoImport() { + return autoImport({ + imports: [ + "vue", + "vue-router", + "pinia" + ], + dts: false + }); +} + +// vite/plugins/svg-icon.js +import { createSvgIconsPlugin } from "file:///D:/code/pasd_V1.0/pasd_pc/node_modules/vite-plugin-svg-icons/dist/index.mjs"; +import path from "path"; +function createSvgIcon(isBuild) { + return createSvgIconsPlugin({ + iconDirs: [path.resolve(process.cwd(), "src/assets/icons/svg")], + symbolId: "icon-[dir]-[name]", + svgoOptions: isBuild + }); +} + +// vite/plugins/compression.js +import compression from "file:///D:/code/pasd_V1.0/pasd_pc/node_modules/vite-plugin-compression/dist/index.mjs"; +function createCompression(env) { + const { VITE_BUILD_COMPRESS } = env; + const plugin = []; + if (VITE_BUILD_COMPRESS) { + const compressList = VITE_BUILD_COMPRESS.split(","); + if (compressList.includes("gzip")) { + plugin.push( + compression({ + ext: ".gz", + deleteOriginFile: false + }) + ); + } + if (compressList.includes("brotli")) { + plugin.push( + compression({ + ext: ".br", + algorithm: "brotliCompress", + deleteOriginFile: false + }) + ); + } + } + return plugin; +} + +// vite/plugins/setup-extend.js +import setupExtend from "file:///D:/code/pasd_V1.0/pasd_pc/node_modules/unplugin-vue-setup-extend-plus/dist/vite.js"; +function createSetupExtend() { + return setupExtend({}); +} + +// vite/plugins/index.js +function createVitePlugins(viteEnv, isBuild = false) { + const vitePlugins = [vue()]; + vitePlugins.push(createAutoImport()); + vitePlugins.push(createSetupExtend()); + vitePlugins.push(createSvgIcon(isBuild)); + isBuild && vitePlugins.push(...createCompression(viteEnv)); + return vitePlugins; +} + +// vite.config.js +var __vite_injected_original_dirname = "D:\\code\\pasd_V1.0\\pasd_pc"; +var vite_config_default = defineConfig(({ mode, command }) => { + const env = loadEnv(mode, process.cwd()); + const { VITE_APP_ENV } = env; + return { + // 部署生产环境和开发环境下的URL. + // 根据CAS配置动态设置base路径 + base: env.VITE_APP_ENV === "production" ? settings_default.deployPath() : "/", + plugins: createVitePlugins(env, command === "build"), + resolve: { + // https://cn.vitejs.dev/config/#resolve-alias + alias: { + "~": path2.resolve(__vite_injected_original_dirname, "./"), + "@": path2.resolve(__vite_injected_original_dirname, "./src") + }, + // https://cn.vitejs.dev/config/#resolve-extensions + extensions: [".mjs", ".js", ".ts", ".jsx", ".tsx", ".json", ".vue"] + }, + server: { + host: true, + open: true, + proxy: { + // https://cn.vitejs.dev/config/#server-proxy + "/dev-api": { + target: "http://localhost:8080", + // 测试 + // target: 'http://172.16.129.101:8080', // 正式环境 + changeOrigin: true, + rewrite: (p) => p.replace(/^\/dev-api/, "") + }, + // 添加对第三方 API 的代理配置 + "/api/v1/jssdk/upload": { + target: "https://px.effirst.com", + changeOrigin: true, + rewrite: (p) => p.replace(/^\/api\/v1\/jssdk\/upload/, "/api/v1/jssdk/upload") + } + } + }, + // fix:error:stdin>:7356:1: warning: "@charset" must be the first rule in the file + css: { + postcss: { + plugins: [ + { + postcssPlugin: "internal:charset-removal", + AtRule: { + charset: (atRule) => { + if (atRule.name === "charset") { + atRule.remove(); + } + } + } + } + ] + } + }, + build: { + target: "es2015", + // 指定编译目标 + minify: "terser", + terserOptions: { + compress: { + drop_console: true, + drop_debugger: true + } + } + } + }; +}); +export { + vite_config_default as default +}; +//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["vite.config.js", "src/settings.js", "vite/plugins/index.js", "vite/plugins/auto-import.js", "vite/plugins/svg-icon.js", "vite/plugins/compression.js", "vite/plugins/setup-extend.js"],
  "sourcesContent": ["const __vite_injected_original_dirname = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\";const __vite_injected_original_filename = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite.config.js\";const __vite_injected_original_import_meta_url = \"file:///D:/code/pasd_V1.0/pasd_pc/vite.config.js\";import path from 'path'\r\nimport { defineConfig, loadEnv } from 'vite'\r\nimport settings from './src/settings'\r\nimport createVitePlugins from './vite/plugins'\r\n\r\n// https://vitejs.dev/config/\r\nexport default defineConfig(({ mode, command }) => {\r\n  const env = loadEnv(mode, process.cwd())\r\n  const { VITE_APP_ENV } = env\r\n\r\n  return {\r\n    // \u90E8\u7F72\u751F\u4EA7\u73AF\u5883\u548C\u5F00\u53D1\u73AF\u5883\u4E0B\u7684URL.\r\n    // \u6839\u636ECAS\u914D\u7F6E\u52A8\u6001\u8BBE\u7F6Ebase\u8DEF\u5F84\r\n    base: env.VITE_APP_ENV === 'production' ? settings.deployPath() : '/',\r\n    plugins: createVitePlugins(env, command === 'build'),\r\n    resolve: {\r\n      // https://cn.vitejs.dev/config/#resolve-alias\r\n      alias: {\r\n        '~': path.resolve(__dirname, './'),\r\n        '@': path.resolve(__dirname, './src')\r\n      },\r\n      // https://cn.vitejs.dev/config/#resolve-extensions\r\n      extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue']\r\n    },\r\n    server: {\r\n      host: true,\r\n      open: true,\r\n      proxy: {\r\n        // https://cn.vitejs.dev/config/#server-proxy\r\n        '/dev-api': {\r\n            target: 'http://localhost:8080', // \u6D4B\u8BD5\r\n          // target: 'http://172.16.129.101:8080', // \u6B63\u5F0F\u73AF\u5883\r\n          changeOrigin: true,\r\n          rewrite: (p) => p.replace(/^\\/dev-api/, '')\r\n        },\r\n        // \u6DFB\u52A0\u5BF9\u7B2C\u4E09\u65B9 API \u7684\u4EE3\u7406\u914D\u7F6E\r\n        '/api/v1/jssdk/upload': {\r\n          target: 'https://px.effirst.com',\r\n          changeOrigin: true,\r\n          rewrite: (p) => p.replace(/^\\/api\\/v1\\/jssdk\\/upload/, '/api/v1/jssdk/upload')\r\n        }\r\n      }\r\n    },\r\n    // fix:error:stdin>:7356:1: warning: \"@charset\" must be the first rule in the file\r\n    css: {\r\n      postcss: {\r\n        plugins: [\r\n          {\r\n            postcssPlugin: 'internal:charset-removal',\r\n            AtRule: {\r\n              charset: (atRule) => {\r\n                if (atRule.name === 'charset') {\r\n                  atRule.remove();\r\n                }\r\n              }\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    build: {\r\n      target: 'es2015', // \u6307\u5B9A\u7F16\u8BD1\u76EE\u6807\r\n      minify: 'terser',\r\n      terserOptions: {\r\n        compress: {\r\n          drop_console: true,\r\n          drop_debugger: true,\r\n        }\r\n      }\r\n    }\r\n  }\r\n})", "const __vite_injected_original_dirname = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\src\";const __vite_injected_original_filename = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\src\\\\settings.js\";const __vite_injected_original_import_meta_url = \"file:///D:/code/pasd_V1.0/pasd_pc/src/settings.js\";export default {\r\n  /**\r\n   * \u7F51\u9875\u6807\u9898\r\n   */\r\n  title: import.meta.env?.VITE_APP_TITLE || '\u5E73\u5B89\u6C34\u7535',\r\n  /**\r\n   * \u4FA7\u8FB9\u680F\u4E3B\u9898 \u6DF1\u8272\u4E3B\u9898theme-dark,\u6D45\u8272\u4E3B\u9898theme-light\r\n   */\r\n  sideTheme: 'theme-dark',\r\n  /**\r\n   * \u662F\u5426\u7CFB\u7EDF\u5E03\u5C40\u914D\u7F6E\r\n   */\r\n  showSettings: true,\r\n\r\n  /**\r\n   * \u662F\u5426\u663E\u793A\u9876\u90E8\u5BFC\u822A\r\n   */\r\n  topNav: false,\r\n\r\n  /**\r\n   * \u662F\u5426\u663E\u793A tagsView\r\n   */\r\n  tagsView: true,\r\n\r\n  /**\r\n   * \u662F\u5426\u56FA\u5B9A\u5934\u90E8\r\n   */\r\n  fixedHeader: false,\r\n\r\n  /**\r\n   * \u662F\u5426\u663E\u793Alogo\r\n   */\r\n  sidebarLogo: true,\r\n\r\n  /**\r\n   * \u662F\u5426\u663E\u793A\u52A8\u6001\u6807\u9898\r\n   */\r\n  dynamicTitle: false,\r\n\r\n  /**\r\n   * @type {string | array} 'production' | ['production', 'development']\r\n   * @description Need show err logs component.\r\n   * The default is only used in the production env\r\n   * If you want to also use it in dev, you can pass ['production', 'development']\r\n   */\r\n  errorLog: 'production',\r\n\r\n  /**\r\n   * CAS\u767B\u5F55\u914D\u7F6E\r\n   */\r\n  // \u662F\u5426\u542F\u7528CAS\u767B\u5F55 (true: CAS\u767B\u5F55\u6A21\u5F0F, false: \u4F20\u7EDF\u767B\u5F55\u6A21\u5F0F)\r\n  casEnable: true,\r\n  \r\n  // CAS\u670D\u52A1\u5668\u5730\u5740\r\n  casServerUrl: 'https://rsso.gxsdxy.cn',\r\n  \r\n  // \u90E8\u7F72\u8DEF\u5F84\u914D\u7F6E (CAS\u6A21\u5F0F: /cas/, \u4F20\u7EDF\u6A21\u5F0F: /srs/)\r\n  deployPath: function() {\r\n    return this.casEnable ? '/cas/' : '/srs/';\r\n  }\r\n}\r\n", "const __vite_injected_original_dirname = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\\\\index.js\";const __vite_injected_original_import_meta_url = \"file:///D:/code/pasd_V1.0/pasd_pc/vite/plugins/index.js\";import vue from '@vitejs/plugin-vue'\r\n\r\nimport createAutoImport from './auto-import'\r\nimport createSvgIcon from './svg-icon'\r\nimport createCompression from './compression'\r\nimport createSetupExtend from './setup-extend'\r\n\r\nexport default function createVitePlugins(viteEnv, isBuild = false) {\r\n    const vitePlugins = [vue()]\r\n    vitePlugins.push(createAutoImport())\r\n\tvitePlugins.push(createSetupExtend())\r\n    vitePlugins.push(createSvgIcon(isBuild))\r\n\tisBuild && vitePlugins.push(...createCompression(viteEnv))\r\n    return vitePlugins\r\n}\r\n", "const __vite_injected_original_dirname = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\\\\auto-import.js\";const __vite_injected_original_import_meta_url = \"file:///D:/code/pasd_V1.0/pasd_pc/vite/plugins/auto-import.js\";import autoImport from 'unplugin-auto-import/vite'\r\n\r\nexport default function createAutoImport() {\r\n    return autoImport({\r\n        imports: [\r\n            'vue',\r\n            'vue-router',\r\n            'pinia'\r\n        ],\r\n        dts: false\r\n    })\r\n}\r\n", "const __vite_injected_original_dirname = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\\\\svg-icon.js\";const __vite_injected_original_import_meta_url = \"file:///D:/code/pasd_V1.0/pasd_pc/vite/plugins/svg-icon.js\";import { createSvgIconsPlugin } from 'vite-plugin-svg-icons'\r\nimport path from 'path'\r\n\r\nexport default function createSvgIcon(isBuild) {\r\n    return createSvgIconsPlugin({\r\n\t\ticonDirs: [path.resolve(process.cwd(), 'src/assets/icons/svg')],\r\n        symbolId: 'icon-[dir]-[name]',\r\n        svgoOptions: isBuild\r\n    })\r\n}\r\n", "const __vite_injected_original_dirname = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\\\\compression.js\";const __vite_injected_original_import_meta_url = \"file:///D:/code/pasd_V1.0/pasd_pc/vite/plugins/compression.js\";import compression from 'vite-plugin-compression'\r\n\r\nexport default function createCompression(env) {\r\n    const { VITE_BUILD_COMPRESS } = env\r\n    const plugin = []\r\n    if (VITE_BUILD_COMPRESS) {\r\n        const compressList = VITE_BUILD_COMPRESS.split(',')\r\n        if (compressList.includes('gzip')) {\r\n            // http://doc.ruoyi.vip/ruoyi-vue/other/faq.html#\u4F7F\u7528gzip\u89E3\u538B\u7F29\u9759\u6001\u6587\u4EF6\r\n            plugin.push(\r\n                compression({\r\n                    ext: '.gz',\r\n                    deleteOriginFile: false\r\n                })\r\n            )\r\n        }\r\n        if (compressList.includes('brotli')) {\r\n            plugin.push(\r\n                compression({\r\n                    ext: '.br',\r\n                    algorithm: 'brotliCompress',\r\n                    deleteOriginFile: false\r\n                })\r\n            )\r\n        }\r\n    }\r\n    return plugin\r\n}\r\n", "const __vite_injected_original_dirname = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\\\\setup-extend.js\";const __vite_injected_original_import_meta_url = \"file:///D:/code/pasd_V1.0/pasd_pc/vite/plugins/setup-extend.js\";import setupExtend from 'unplugin-vue-setup-extend-plus/vite'\r\n\r\nexport default function createSetupExtend() {\r\n    return setupExtend({})\r\n}\r\n"],
  "mappings": "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",
  "names": ["path", "path"]
}
 diff --git a/vite.config.js.timestamp-1761642518249-ed073713ec89a.mjs b/vite.config.js.timestamp-1761642518249-ed073713ec89a.mjs new file mode 100644 index 0000000..3967132 --- /dev/null +++ b/vite.config.js.timestamp-1761642518249-ed073713ec89a.mjs @@ -0,0 +1,204 @@ +// vite.config.js +import path2 from "path"; +import { defineConfig, loadEnv } from "file:///D:/code/pasd_V1.0/pasd_pc/node_modules/vite/dist/node/index.js"; + +// src/settings.js +var settings_default = { + /** + * 网页标题 + */ + title: import.meta.env?.VITE_APP_TITLE || "\u5E73\u5B89\u6C34\u7535", + /** + * 侧边栏主题 深色主题theme-dark,浅色主题theme-light + */ + sideTheme: "theme-dark", + /** + * 是否系统布局配置 + */ + showSettings: true, + /** + * 是否显示顶部导航 + */ + topNav: false, + /** + * 是否显示 tagsView + */ + tagsView: true, + /** + * 是否固定头部 + */ + fixedHeader: false, + /** + * 是否显示logo + */ + sidebarLogo: true, + /** + * 是否显示动态标题 + */ + dynamicTitle: false, + /** + * @type {string | array} 'production' | ['production', 'development'] + * @description Need show err logs component. + * The default is only used in the production env + * If you want to also use it in dev, you can pass ['production', 'development'] + */ + errorLog: "production", + /** + * CAS登录配置 + */ + // 是否启用CAS登录 (true: CAS登录模式, false: 传统登录模式) + casEnable: (import.meta.env?.VITE_APP_CAS_ENABLE || "false") === "true", + // CAS服务器地址 + casServerUrl: import.meta.env?.VITE_APP_CAS_SERVER_URL || "https://rsso.gxsdxy.cn", + // CAS票据验证地址(CAS3默认 p3) + casValidateUrl: import.meta.env?.VITE_APP_CAS_VALIDATE_URL || "https://rsso.gxsdxy.cn/p3/serviceValidate", + // 部署路径配置 (CAS模式: /cas/, 传统模式: /srs/) + deployPath: function() { + return this.casEnable ? "/cas/" : "/srs/"; + } +}; + +// vite/plugins/index.js +import vue from "file:///D:/code/pasd_V1.0/pasd_pc/node_modules/@vitejs/plugin-vue/dist/index.mjs"; + +// vite/plugins/auto-import.js +import autoImport from "file:///D:/code/pasd_V1.0/pasd_pc/node_modules/unplugin-auto-import/dist/vite.js"; +function createAutoImport() { + return autoImport({ + imports: [ + "vue", + "vue-router", + "pinia" + ], + dts: false + }); +} + +// vite/plugins/svg-icon.js +import { createSvgIconsPlugin } from "file:///D:/code/pasd_V1.0/pasd_pc/node_modules/vite-plugin-svg-icons/dist/index.mjs"; +import path from "path"; +function createSvgIcon(isBuild) { + return createSvgIconsPlugin({ + iconDirs: [path.resolve(process.cwd(), "src/assets/icons/svg")], + symbolId: "icon-[dir]-[name]", + svgoOptions: isBuild + }); +} + +// vite/plugins/compression.js +import compression from "file:///D:/code/pasd_V1.0/pasd_pc/node_modules/vite-plugin-compression/dist/index.mjs"; +function createCompression(env) { + const { VITE_BUILD_COMPRESS } = env; + const plugin = []; + if (VITE_BUILD_COMPRESS) { + const compressList = VITE_BUILD_COMPRESS.split(","); + if (compressList.includes("gzip")) { + plugin.push( + compression({ + ext: ".gz", + deleteOriginFile: false + }) + ); + } + if (compressList.includes("brotli")) { + plugin.push( + compression({ + ext: ".br", + algorithm: "brotliCompress", + deleteOriginFile: false + }) + ); + } + } + return plugin; +} + +// vite/plugins/setup-extend.js +import setupExtend from "file:///D:/code/pasd_V1.0/pasd_pc/node_modules/unplugin-vue-setup-extend-plus/dist/vite.js"; +function createSetupExtend() { + return setupExtend({}); +} + +// vite/plugins/index.js +function createVitePlugins(viteEnv, isBuild = false) { + const vitePlugins = [vue()]; + vitePlugins.push(createAutoImport()); + vitePlugins.push(createSetupExtend()); + vitePlugins.push(createSvgIcon(isBuild)); + isBuild && vitePlugins.push(...createCompression(viteEnv)); + return vitePlugins; +} + +// vite.config.js +var __vite_injected_original_dirname = "D:\\code\\pasd_V1.0\\pasd_pc"; +var vite_config_default = defineConfig(({ mode, command }) => { + const env = loadEnv(mode, process.cwd()); + const { VITE_APP_ENV } = env; + return { + // 部署生产环境和开发环境下的URL. + // 根据CAS配置动态设置base路径 + base: env.VITE_APP_ENV === "production" ? settings_default.deployPath() : "/", + plugins: createVitePlugins(env, command === "build"), + resolve: { + // https://cn.vitejs.dev/config/#resolve-alias + alias: { + "~": path2.resolve(__vite_injected_original_dirname, "./"), + "@": path2.resolve(__vite_injected_original_dirname, "./src") + }, + // https://cn.vitejs.dev/config/#resolve-extensions + extensions: [".mjs", ".js", ".ts", ".jsx", ".tsx", ".json", ".vue"] + }, + server: { + host: true, + open: true, + proxy: { + // https://cn.vitejs.dev/config/#server-proxy + "/dev-api": { + // target: 'http://localhost:8080', // 测试 + target: "http://172.16.129.101:8080", + // 正式环境 + changeOrigin: true, + rewrite: (p) => p.replace(/^\/dev-api/, "") + }, + // 添加对第三方 API 的代理配置 + "/api/v1/jssdk/upload": { + target: "https://px.effirst.com", + changeOrigin: true, + rewrite: (p) => p.replace(/^\/api\/v1\/jssdk\/upload/, "/api/v1/jssdk/upload") + } + } + }, + // fix:error:stdin>:7356:1: warning: "@charset" must be the first rule in the file + css: { + postcss: { + plugins: [ + { + postcssPlugin: "internal:charset-removal", + AtRule: { + charset: (atRule) => { + if (atRule.name === "charset") { + atRule.remove(); + } + } + } + } + ] + } + }, + build: { + target: "es2015", + // 指定编译目标 + minify: "terser", + terserOptions: { + compress: { + drop_console: true, + drop_debugger: true + } + } + } + }; +}); +export { + vite_config_default as default +}; +//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["vite.config.js", "src/settings.js", "vite/plugins/index.js", "vite/plugins/auto-import.js", "vite/plugins/svg-icon.js", "vite/plugins/compression.js", "vite/plugins/setup-extend.js"],
  "sourcesContent": ["const __vite_injected_original_dirname = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\";const __vite_injected_original_filename = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite.config.js\";const __vite_injected_original_import_meta_url = \"file:///D:/code/pasd_V1.0/pasd_pc/vite.config.js\";import path from 'path'\r\nimport { defineConfig, loadEnv } from 'vite'\r\nimport settings from './src/settings'\r\nimport createVitePlugins from './vite/plugins'\r\n\r\n// https://vitejs.dev/config/\r\nexport default defineConfig(({ mode, command }) => {\r\n  const env = loadEnv(mode, process.cwd())\r\n  const { VITE_APP_ENV } = env\r\n\r\n  return {\r\n    // \u90E8\u7F72\u751F\u4EA7\u73AF\u5883\u548C\u5F00\u53D1\u73AF\u5883\u4E0B\u7684URL.\r\n    // \u6839\u636ECAS\u914D\u7F6E\u52A8\u6001\u8BBE\u7F6Ebase\u8DEF\u5F84\r\n    base: env.VITE_APP_ENV === 'production' ? settings.deployPath() : '/',\r\n    plugins: createVitePlugins(env, command === 'build'),\r\n    resolve: {\r\n      // https://cn.vitejs.dev/config/#resolve-alias\r\n      alias: {\r\n        '~': path.resolve(__dirname, './'),\r\n        '@': path.resolve(__dirname, './src')\r\n      },\r\n      // https://cn.vitejs.dev/config/#resolve-extensions\r\n      extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue']\r\n    },\r\n    server: {\r\n      host: true,\r\n      open: true,\r\n      proxy: {\r\n        // https://cn.vitejs.dev/config/#server-proxy\r\n        '/dev-api': {\r\n            // target: 'http://localhost:8080', // \u6D4B\u8BD5\r\n          target: 'http://172.16.129.101:8080', // \u6B63\u5F0F\u73AF\u5883\r\n          changeOrigin: true,\r\n          rewrite: (p) => p.replace(/^\\/dev-api/, '')\r\n        },\r\n        // \u6DFB\u52A0\u5BF9\u7B2C\u4E09\u65B9 API \u7684\u4EE3\u7406\u914D\u7F6E\r\n        '/api/v1/jssdk/upload': {\r\n          target: 'https://px.effirst.com',\r\n          changeOrigin: true,\r\n          rewrite: (p) => p.replace(/^\\/api\\/v1\\/jssdk\\/upload/, '/api/v1/jssdk/upload')\r\n        }\r\n      }\r\n    },\r\n    // fix:error:stdin>:7356:1: warning: \"@charset\" must be the first rule in the file\r\n    css: {\r\n      postcss: {\r\n        plugins: [\r\n          {\r\n            postcssPlugin: 'internal:charset-removal',\r\n            AtRule: {\r\n              charset: (atRule) => {\r\n                if (atRule.name === 'charset') {\r\n                  atRule.remove();\r\n                }\r\n              }\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    build: {\r\n      target: 'es2015', // \u6307\u5B9A\u7F16\u8BD1\u76EE\u6807\r\n      minify: 'terser',\r\n      terserOptions: {\r\n        compress: {\r\n          drop_console: true,\r\n          drop_debugger: true,\r\n        }\r\n      }\r\n    }\r\n  }\r\n})", "const __vite_injected_original_dirname = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\src\";const __vite_injected_original_filename = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\src\\\\settings.js\";const __vite_injected_original_import_meta_url = \"file:///D:/code/pasd_V1.0/pasd_pc/src/settings.js\";export default {\r\n  /**\r\n   * \u7F51\u9875\u6807\u9898\r\n   */\r\n  title: import.meta.env?.VITE_APP_TITLE || '\u5E73\u5B89\u6C34\u7535',\r\n  /**\r\n   * \u4FA7\u8FB9\u680F\u4E3B\u9898 \u6DF1\u8272\u4E3B\u9898theme-dark,\u6D45\u8272\u4E3B\u9898theme-light\r\n   */\r\n  sideTheme: 'theme-dark',\r\n  /**\r\n   * \u662F\u5426\u7CFB\u7EDF\u5E03\u5C40\u914D\u7F6E\r\n   */\r\n  showSettings: true,\r\n\r\n  /**\r\n   * \u662F\u5426\u663E\u793A\u9876\u90E8\u5BFC\u822A\r\n   */\r\n  topNav: false,\r\n\r\n  /**\r\n   * \u662F\u5426\u663E\u793A tagsView\r\n   */\r\n  tagsView: true,\r\n\r\n  /**\r\n   * \u662F\u5426\u56FA\u5B9A\u5934\u90E8\r\n   */\r\n  fixedHeader: false,\r\n\r\n  /**\r\n   * \u662F\u5426\u663E\u793Alogo\r\n   */\r\n  sidebarLogo: true,\r\n\r\n  /**\r\n   * \u662F\u5426\u663E\u793A\u52A8\u6001\u6807\u9898\r\n   */\r\n  dynamicTitle: false,\r\n\r\n  /**\r\n   * @type {string | array} 'production' | ['production', 'development']\r\n   * @description Need show err logs component.\r\n   * The default is only used in the production env\r\n   * If you want to also use it in dev, you can pass ['production', 'development']\r\n   */\r\n  errorLog: 'production',\r\n\r\n  /**\r\n   * CAS\u767B\u5F55\u914D\u7F6E\r\n   */\r\n  // \u662F\u5426\u542F\u7528CAS\u767B\u5F55 (true: CAS\u767B\u5F55\u6A21\u5F0F, false: \u4F20\u7EDF\u767B\u5F55\u6A21\u5F0F)\r\n  casEnable: (import.meta.env?.VITE_APP_CAS_ENABLE || 'false') === 'true',\r\n  \r\n  // CAS\u670D\u52A1\u5668\u5730\u5740\r\n  casServerUrl: import.meta.env?.VITE_APP_CAS_SERVER_URL || 'https://rsso.gxsdxy.cn',\r\n\r\n  // CAS\u7968\u636E\u9A8C\u8BC1\u5730\u5740\uFF08CAS3\u9ED8\u8BA4 p3\uFF09\r\n  casValidateUrl: import.meta.env?.VITE_APP_CAS_VALIDATE_URL || 'https://rsso.gxsdxy.cn/p3/serviceValidate',\r\n  \r\n  // \u90E8\u7F72\u8DEF\u5F84\u914D\u7F6E (CAS\u6A21\u5F0F: /cas/, \u4F20\u7EDF\u6A21\u5F0F: /srs/)\r\n  deployPath: function() {\r\n    return this.casEnable ? '/cas/' : '/srs/'\r\n  }\r\n}\r\n", "const __vite_injected_original_dirname = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\\\\index.js\";const __vite_injected_original_import_meta_url = \"file:///D:/code/pasd_V1.0/pasd_pc/vite/plugins/index.js\";import vue from '@vitejs/plugin-vue'\r\n\r\nimport createAutoImport from './auto-import'\r\nimport createSvgIcon from './svg-icon'\r\nimport createCompression from './compression'\r\nimport createSetupExtend from './setup-extend'\r\n\r\nexport default function createVitePlugins(viteEnv, isBuild = false) {\r\n    const vitePlugins = [vue()]\r\n    vitePlugins.push(createAutoImport())\r\n\tvitePlugins.push(createSetupExtend())\r\n    vitePlugins.push(createSvgIcon(isBuild))\r\n\tisBuild && vitePlugins.push(...createCompression(viteEnv))\r\n    return vitePlugins\r\n}\r\n", "const __vite_injected_original_dirname = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\\\\auto-import.js\";const __vite_injected_original_import_meta_url = \"file:///D:/code/pasd_V1.0/pasd_pc/vite/plugins/auto-import.js\";import autoImport from 'unplugin-auto-import/vite'\r\n\r\nexport default function createAutoImport() {\r\n    return autoImport({\r\n        imports: [\r\n            'vue',\r\n            'vue-router',\r\n            'pinia'\r\n        ],\r\n        dts: false\r\n    })\r\n}\r\n", "const __vite_injected_original_dirname = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\\\\svg-icon.js\";const __vite_injected_original_import_meta_url = \"file:///D:/code/pasd_V1.0/pasd_pc/vite/plugins/svg-icon.js\";import { createSvgIconsPlugin } from 'vite-plugin-svg-icons'\r\nimport path from 'path'\r\n\r\nexport default function createSvgIcon(isBuild) {\r\n    return createSvgIconsPlugin({\r\n\t\ticonDirs: [path.resolve(process.cwd(), 'src/assets/icons/svg')],\r\n        symbolId: 'icon-[dir]-[name]',\r\n        svgoOptions: isBuild\r\n    })\r\n}\r\n", "const __vite_injected_original_dirname = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\\\\compression.js\";const __vite_injected_original_import_meta_url = \"file:///D:/code/pasd_V1.0/pasd_pc/vite/plugins/compression.js\";import compression from 'vite-plugin-compression'\r\n\r\nexport default function createCompression(env) {\r\n    const { VITE_BUILD_COMPRESS } = env\r\n    const plugin = []\r\n    if (VITE_BUILD_COMPRESS) {\r\n        const compressList = VITE_BUILD_COMPRESS.split(',')\r\n        if (compressList.includes('gzip')) {\r\n            // http://doc.ruoyi.vip/ruoyi-vue/other/faq.html#\u4F7F\u7528gzip\u89E3\u538B\u7F29\u9759\u6001\u6587\u4EF6\r\n            plugin.push(\r\n                compression({\r\n                    ext: '.gz',\r\n                    deleteOriginFile: false\r\n                })\r\n            )\r\n        }\r\n        if (compressList.includes('brotli')) {\r\n            plugin.push(\r\n                compression({\r\n                    ext: '.br',\r\n                    algorithm: 'brotliCompress',\r\n                    deleteOriginFile: false\r\n                })\r\n            )\r\n        }\r\n    }\r\n    return plugin\r\n}\r\n", "const __vite_injected_original_dirname = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\";const __vite_injected_original_filename = \"D:\\\\code\\\\pasd_V1.0\\\\pasd_pc\\\\vite\\\\plugins\\\\setup-extend.js\";const __vite_injected_original_import_meta_url = \"file:///D:/code/pasd_V1.0/pasd_pc/vite/plugins/setup-extend.js\";import setupExtend from 'unplugin-vue-setup-extend-plus/vite'\r\n\r\nexport default function createSetupExtend() {\r\n    return setupExtend({})\r\n}\r\n"],
  "mappings": "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",
  "names": ["path", "path"]
}
