// 1 => LOADING // 2 => DONE // 3 => ERROR import * as api from "../api/patient.js" export default { namespaced: true, state: { lastidx:0, lookup_status:0, lookup_error_message:'', search_patient: 0, search_error_message: '', start_date:moment(new Date()).format('YYYY-MM-DD'), end_date:moment(new Date()).format('YYYY-MM-DD'), search:'', total_patiens: 0, total_filter_patiens: 0, total_patients_all:0, patients: [], total_patient: 0, selected_patient: {totalbill:0}, save_error_message: '', statuses:[], selected_status:{}, open_alert_no_pay: false, msg_alert_no_pay: "Loh ... Gak jadi bayar dong ?", current_page:1, total_page:0, filters:[{id:'day',name:'Hari ini'},{id:'notsampled',name:'Belum sampling'},{id:'all',name:'Tampilkan semua'}], selected_filter:{id:'day',name:'Hari ini'}, promise_dialog:false, promises:[], errors:[], save_status:0, save_error_message:'', barcodes:[], dialog_barcode:false, autocomplete_status:0, companies:[], selected_company:{id:0,name:'Semua'}, dialog_details:false }, mutations: { update_dialog_details(state, val) { state.dialog_details = val }, update_companies(state, val) { state.companies = val }, update_selected_company(state, val) { state.selected_company = val }, update_dialog_barcode(state, val) { state.dialog_barcode = val }, update_statuses(state, val) { state.statuses = val }, update_total_patients_all(state, val) { state.total_patients_all = val }, update_save_status(state, val) { state.save_status = val }, update_save_error_message(state, val) { state.save_error_message = val }, update_lookup_error_message(state,val) { state.lookup_error_message = val }, update_lookup_status(state,status) { state.lookup_status = status }, update_promise_dialog(state, val) { state.promise_dialog = val }, update_promises(state, val) { state.promises = val }, update_errors(state, val) { state.errors = val }, update_lastidx(state, val) { state.lastidx = val }, update_selected_filter(state, val) { state.selected_filter = val }, update_filters(state, val) { state.filters = val }, update_total_page(state, val) { state.total_page = val }, update_total_patient(state, val) { state.total_patient = val }, update_current_page(state, val) { state.current_page = val }, update_search_error_message(state, patient) { state.search_error_message = patient }, update_search_patient(state, patient) { state.search_patient = patient }, update_patients(state, data) { state.patients = data }, update_selected_patient(state, val) { state.selected_patient = val }, update_start_date(state, val) { state.start_date = val }, update_autocomplete_status(state,val){ state.autocomplete_status = val }, update_end_date(state, val) { state.end_date = val }, update_search(state, val) { state.search = val }, update_selected_status(state, val) { state.selected_status = val }, update_open_alert_no_pay(state, val) { state.open_alert_no_pay = val }, update_msg_alert_no_pay(state, val) { state.msg_alert_no_pay = val } }, actions: { async search(context, prm) { context.commit("update_search_patient", 1) try { //console.log(prm) prm.token = one_token() let resp = await api.search(prm) if (resp.status != "OK") { context.commit("update_search_patient", 3) context.commit("update_search_error_message", resp.message) } else { context.commit("update_search_patient", 2) context.commit("update_search_error_message", "") let data = { records: resp.data.records } console.log(data.records) context.commit("update_patients", data.records) if(data.records.length > 0) context.commit("update_selected_patient", data.records[0]) } } catch (e) { context.commit("update_search_patient", 3) context.commit("update_search_error_message", e.message) console.log(e) } }, async lookup_statuses(context,prm) { context.commit("update_lookup_status",1) try { prm.token = one_token() let resp= await api.lookup_statuses(prm) if (resp.status != "OK") { context.commit("update_lookup_status",3) context.commit("update_lookup_error_message",resp.message) } else { context.commit("update_lookup_status",2) context.commit("update_lookup_error_message","") let data = { records : resp.data.records, total: resp.data.total } context.commit("update_statuses",data.records) //context.commit("update_promise_dialog",true) } } catch(e) { context.commit("update_lookup_status",3) context.commit("update_lookup_error_message",e.message ) } }, async getdatabarcodes(context,prm) { context.commit("update_lookup_status",1) try { prm.token = one_token() let resp= await api.getdatabarcodes(prm) if (resp.status != "OK") { context.commit("update_lookup_status",3) context.commit("update_lookup_error_message",resp.message) } else { context.commit("update_lookup_status",2) context.commit("update_lookup_error_message","") let data = { records : resp.data.records, total: resp.data.total } context.commit("update_barcodes",data.records) context.commit("update_dialog_barcode",true) } } catch(e) { context.commit("update_lookup_status",3) context.commit("update_lookup_error_message",e.message ) } }, async serahkan(context, prm) { context.commit("update_save_status", 1) try { prm.token = one_token() let resp = await api.serahkan(prm) if (resp.status != "OK") { context.commit("update_save_status", 3) context.commit("update_save_error_message", resp.message) } else { context.commit("update_save_status", 2) context.commit("update_save_error_message", "") let data = { records: resp.data.records, total: resp.data.total } var row_data = prm row_data.status = 'D' row_data.received_time = resp.data.records.received_time var patients = context.state.patients //console.log(patients) //console.log(prm.last_idx) //console.log(prm.last_detail_idx) //console.log(patients.details) patients[prm.spk_idx].details[prm.last_idx].details[prm.last_detail_idx] = row_data context.commit("update_patients",patients) context.commit("update_dialog_details", false) } } catch (e) { context.commit("update_save_status", 3) context.commit("update_save_error_message", e.message) console.log(e) } }, async searchcompany(context,prm) { context.commit("update_autocomplete_status",1) try { let resp= await api.searchcompany(one_token(),prm) if (resp.status != "OK") { context.commit("update_autocomplete_status",3) } else { context.commit("update_autocomplete_status",2) let data = { records : resp.data.records, total: resp.data.total } context.commit("update_companies",resp.data.records) } } catch(e) { context.commit("update_autocomplete_status",3) } } } }