Files
FE_CPONE/test/vuex/one-result-print-adm-v2/modules/re_patient.js
2026-04-27 10:13:31 +07:00

238 lines
7.6 KiB
JavaScript

// 1 => LOADING
// 2 => DONE
// 3 => ERROR
import * as api from "../api/re_patient.js"
window.api = api
export default {
namespaced: true,
state: {
order_id:0,
search: '',
nolab: '',
sdate: new Date().toISOString().substr(0, 10),
edate: null,
search_status:0,
search_error_message:'',
search_dialog_is_active: false,
patients: [],
total_patient: 0,
total_patient_page: 0,
curr_patient_page: 1,
selected_patient: { },
total_day:0,
total_susulan:0,
// PX
total_px: 0,
pxs: [],
// Print
print_dialog: false,
rpt_url: '',
dialog_req: false,
info_req: {req_fo:[],req_spec_col:[],req_spec_ver:[],req_samp_ver:[],req_pre_an:[]},
url_print:'',
deliveries:[],
selected_delivery:{id:'0',name:'Semua'},
bar_chx_all:false,
indeterminatex:false,
current_page:1,
selected_patients:[]
},
mutations: {
update_selected_patients(state,val) {
state.selected_patients=val
},
update_total_day(state,val) {
state.total_day=val
},
update_total_susulan(state,val) {
state.total_susulan=val
},
update_current_page(state,val) {
state.current_page=val
},
update_indeterminatex(state,val) {
state.indeterminatex=val
},
update_bar_chx_all(state,val) {
state.bar_chx_all=val
},
update_deliveries(state,val) {
state.deliveries=val
},
update_selected_delivery(state,val) {
state.selected_delivery=val
},
update_url_print(state,val) {
state.url_print=val
},
update_search_dialog_is_active(state,status) {
state.search_dialog_is_active = status
},
update_search_error_message(state,status) {
state.search_error_message = status
},
update_search(state,val) {
state.search=val
},
update_nolab(state, val) {
state.nolab = val
},
update_search_status(state,status) {
state.search_status = status
},
update_patients(state, data) {
state.patients= data.records
state.total_patient = data.total
state.total_patient_page = data.total_page
},
update_curr_patient_page(state, data) {
state.curr_patient_page = data
},
update_selected_patient(state,val) {
state.selected_patient=val
},
update_id(state, id) {
state.order_id = id
},
update_pxs(state, pxs) {
state.pxs = pxs.records
},
update_sdate(state, date) {
state.sdate = date
},
update_edate(state, date) {
state.edate = date
},
update_print_dialog(state, v) {
state.print_dialog = v
},
update_rpt_url(state, v) {
let user = window.one_user()
state.rpt_url = '/birt/frameset?__report=report/one/lab/rpt_test.rptdesign&__format=pdf&username='+user.M_UserUsername+'%20&PID='+v+'&ts='+Math.floor(Date.now() / 1000)
},
update_info_req(state, v) {
state.info_req = v
},
update_dialog_req(state, v) {
state.dialog_req = v
}
},
actions: {
async search(context) {
context.commit("update_search_status", 1)
try {
let inp_no = context.state.search
let company_id = 0
if (context.rootState.company.company)
company_id = context.rootState.company.company.M_CompanyID
let resp= await api.search(one_token(), context.state.sdate, inp_no , context.state.curr_patient_page, company_id,context.state.selected_delivery.id,context.state.current_page)
if (resp.status != "OK") {
context.commit("update_search_status", 3)
context.commit("update_search_error_message", resp.message)
} else {
context.commit("update_search_status",2)
context.commit("update_search_error_message","")
let data = {
records : resp.data.records,
total: resp.data.total,
total_page: resp.data.total_page
}
context.commit("update_patients", data)
context.commit("update_total_day", resp.data.total_day)
context.commit("update_total_susulan", resp.data.total_susulan)
if (data.records.length < 1) {
context.commit('update_selected_patient', null)
context.commit('re_px/update_pxs', [], {root:true})
}
else {
context.commit('update_selected_patient', data.records[0])
context.commit('re_px/update_id', data.records[0].T_OrderHeaderID, {root:true})
let user = one_user()
let item = data.records[0]
let rpt = "rpt_test"
if(item.ready_print !== 'Y')
rpt = "rpt_test_not_print"
var xurl = "/birt/frameset?__report=report/one/lab/"+rpt+".rptdesign&__format=pdf&username="+user.M_UserUsername+"&PID="+item.T_OrderHeaderID+"&tm="+Date.now()
context.commit('update_url_print', xurl)
//context.dispatch('re_px/search', null, {root:true})
//context.dispatch('info_req')
}
}
} catch(e) {
context.commit("update_search_status",3)
context.commit("update_search_error_message",e.message )
}
},
async info_req(context) {
context.commit("update_search_status", 1)
try {
let resp= await api.info_req(one_token(), context.state.selected_patient.T_OrderHeaderID)
if (resp.status != "OK") {
context.commit("update_search_status", 3)
context.commit("update_search_error_message", resp.message)
} else {
context.commit("update_search_status",2)
context.commit("update_search_error_message","")
context.commit('update_info_req', resp.data)
}
} catch(e) {
context.commit("update_search_status", 3)
context.commit("update_search_error_message", e.message )
}
},
async get_deliverytype(context) {
context.commit("update_search_status", 1)
try {
let resp= await api.getdeliverytype(one_token())
if (resp.status != "OK") {
context.commit("update_search_status", 3)
context.commit("update_search_error_message", resp.message)
} else {
context.commit("update_search_status",2)
context.commit("update_search_error_message","")
context.commit('update_deliveries', resp.data.records)
context.commit('update_selected_delivery', resp.data.records[0])
context.dispatch("search")
}
} catch(e) {
context.commit("update_search_status", 3)
context.commit("update_search_error_message", e.message )
}
}
}
}