Flatten nested repos

This commit is contained in:
sas.fajri
2026-04-27 10:13:31 +07:00
parent 01c2963a43
commit 8347aef8f4
17935 changed files with 5015229 additions and 3 deletions

View File

@@ -0,0 +1,69 @@
<template>
<div v-show="show" class="orderbox">
<h3>Daftar Pemeriksaan
<v-progress-circular
style="height:20px"
v-show="loading" :indeterminate="true">
</v-progress-circular>
<v-icon style="float:right;top:-10px;height:20px;" @click="show=false"> close</v-icon>
</h3>
<div class="px" v-for="order in orders" >
{{order.name}}
</div>
</div>
</template>
<style scoped>
.orderbox{
position: fixed;
bottom:0px;
left:50%;
width: 640px;
height:300px;
margin-left:-320px;
z-index:99;
background-color: rgba(230, 255, 230,0.9);
color: #004d00;
padding:20px;
border-radius-top: 10px;
overflow-y:scroll;
overflow-x:hidden;
}
.px {
padding:5px;
width: 280px;
border: 1px solid #004d00;
display:inline-block;
margin: 0px 2px 0px 2px;
}
</style>
<script>
module.exports = {
components : {
},
computed: {
orders() {
return this.$store.state.order_info.orders
},
loading() {
return this.$store.state.order_info.loading
}
,show : {
get() { return this.$store.state.order_info.show}
,set(v) { return this.$store.commit("order_info/update_show",v) }
}
,sel_patient() {
return this.$store.state.samplecall.selected_patient
}
},
methods : {
},
watch : {
async sel_patient(n,o) {
this.$store.dispatch("order_info/search",{id:n.T_OrderHeaderID})
}
}
}
</script>

View File

@@ -0,0 +1,470 @@
<template>
<v-layout class="mb-2 mt-2" column >
<v-dialog
v-model="dialognote"
width="40%"
>
<v-card>
<v-card-title
class="headline white--text error"
primary-title
>
</v-card-title>
<v-card-text>
<v-layout v-if="selected_patient.fo_note != ''" mb-2 row>
<v-flex mb-2 xs3>
<span style="color: #0e6fbc" class="mono name">Catatan </span>
</v-flex>
<v-flex xs9>
<v-layout row>
<v-flex mb-1 xs12>
<code style="box-shadow: none !important;color: #0e6fbc !important;background-color: #2196f34d !important;">front office</code>
<div class="v-markdown">
<p style="margin-top:2px;margin-bottom:0">{{selected_patient.fo_note}}</p>
</div>
</v-flex>
</v-layout>
<!--<v-layout row>
<v-flex mb-1 xs12>
<code style="box-shadow: none !important;color: #0e6fbc !important;background-color: #2196f34d !important;">specimen</code>
<div class="v-markdown">
<p style="margin-bottom:0">Specifies which DOM element that this component</p>
</div>
</v-flex>
</v-layout>-->
</v-flex>
</v-layout>
<v-layout v-if="xnoterequirement.length > 0" mb-2 row>
<v-flex mb-2 xs3>
<span style="color: #c0341d" class="mono name">Requirement </span>
</v-flex>
<v-flex xs9>
<v-layout v-for="notereq in xnoterequirement" row>
<v-flex mb-1 xs12>
<code style="box-shadow: none !important;color: #c0341d !important;background-color: #fbe5e1 !important;">{{notereq.position}}</code>
<div class="v-markdown">
<p style="margin-top:2px;margin-bottom:0">{{notereq.requirements}}</p>
</div>
</v-flex>
</v-layout>
<!--<v-layout row>
<v-flex mb-1 xs12>
<code style="box-shadow: none !important;color: #c0341d !important;background-color: #fbe5e1 !important;">Specimen</code>
<div class="v-markdown">
<p style="margin-bottom:0">Tidak Puasa, Puasa Lebih, Obat Diuretik dan Cafein</p>
</div>
</v-flex>
</v-layout>-->
</v-flex>
</v-layout>
</v-card-text>
<v-divider></v-divider>
<v-card-actions>
<v-spacer></v-spacer>
<v-btn
color="grey"
dark
flat
text
@click="dialognote = false"
>
Tutup
</v-btn>
</v-card-actions>
</v-card>
</v-dialog>
<v-dialog
v-model="dialogformnote"
width="40%"
>
<v-card>
<v-card-title
class="headline white--text primary"
primary-title
>
</v-card-title>
<v-card-text>
<v-layout mb-2 row>
<v-flex xs12>
<v-textarea
outline
label="Catatan"
v-model="selected_patient.sampling_note"
></v-textarea>
</v-flex>
</v-layout>
</v-card-text>
<v-divider></v-divider>
<v-card-actions>
<v-spacer></v-spacer>
<v-btn
color="grey"
dark
flat
text
@click="searchPatientLastSelect"
>
Tutup
</v-btn>
<v-btn
color="primary"
dark
flat
text
@click="saveNoteSampling()"
>
Simpan
</v-btn>
</v-card-actions>
</v-card>
</v-dialog>
<v-dialog v-model="dialogrequirement" persistent max-width="45%">
<v-card>
<v-card-title color="success" class="headline">Pilih yang tidak terpenuhi</v-card-title>
<v-card-text>
<v-layout wrap>
<v-flex v-for="(req,idx) in requirements" xs6>
<one-x-check
:xdatalabel="req.name"
:xdatacbx="req.chex"
@update-data-cbx="(val) =>checkReq(val,idx)"
></one-x-check>
</v-flex>
</v-layout>
</v-card-text>
<v-card-actions>
<v-spacer></v-spacer>
<v-btn color="green darken-1" flat @click="saveRequirement">Tutup</v-btn>
<!--<v-btn color="green darken-1" flat @click="saveRequirement()">Simpan</v-btn>-->
</v-card-actions>
</v-card>
</v-dialog>
<v-card style="overflow-y: auto;max-height:550px" v-if="xsampletypes.length > 0">
<v-layout row>
<v-flex xs12>
<v-subheader style="background:#03a9f4;padding:5px">
<v-icon dark large left>assignment_ind</v-icon><h3 style="font-size:x-large" dark class="font-weight-bold white--text">{{staff.name.toUpperCase()}}</h3>
<v-flex text-md-right>
<v-btn v-if="selected_patient.fo_note !== '' || selected_patient.fo_requirements_status !== 'Y' || selected_patient.fo_verification_status !== 'X'" @click="openDialogFoNoteRequirement()" style="min-width:20px;margin-left:1px;margin-right:1px" deppressed small color="error"><v-icon small>info</v-icon></v-btn>
<v-btn @click="openDialogFormNote()" style="min-width:20px;margin-left:1px;margin-right:1px" deppressed small color="warning"><v-icon small>speaker_notes</v-icon></v-btn>
</v-flex>
</v-subheader>
<v-divider></v-divider>
<v-layout align-center pa-2 mb-1 class="grey lighten-2" row>
<v-flex xs4>
SPECIMEN
</v-flex>
<v-flex xs3>
BARCODE
</v-flex>
<v-flex xs2>
REQUIREMENT
</v-flex>
<v-flex class="text-xs-center" xs3>
AKSI
</v-flex>
</v-layout>
<v-layout pb-1 row v-for="(sampletype,idx) in xsampletypes" :key="sampletype.T_BarcodeLabBarcode">
<v-flex xs12>
<v-layout align-center class="pa-2 grey lighten-4" row>
<!--<v-flex class="text-xs-center" xs1>
<v-btn v-if="selected_patient.status !== 'Process'" depressed small style="min-width:30px" class="white--text" color="grey"><v-icon>block</v-icon></v-btn>
<v-btn @click="addNewLabel(sampletype)" v-if="selected_patient.status === 'Process'" small style="min-width:30px" class="white--text" color="#00bcd4"><v-icon>add</v-icon></v-btn>
</v-flex>-->
<v-flex pl-2 xs4>
{{sampletype.T_SampleTypeName}}
</v-flex>
<v-flex xs3>
<span v-if="sampletype.T_OrderSampleSampling === 'X'" style="text-decoration:line-through" class="red--text">{{sampletype.T_BarcodeLabBarcode}}</span>
<span v-if="sampletype.T_OrderSampleSampling !== 'X'" >{{sampletype.T_BarcodeLabBarcode}}</span>
</v-flex>
<v-flex xs2>
<div v-if="selected_patient.status === 'Process' || selected_patient.status === 'Done'">
<span @click="openDialogRequirement(sampletype,idx)" v-bind:class="{ 'white': sampletype.requirement_status === 'X', 'error': sampletype.requirement_status === 'N' }" class="icon-medium-fill-base-small white"><v-icon :dark="sampletype.requirement_status === 'N'">close</v-icon></span>
<span @click="confirmRequirement(sampletype,idx)" v-bind:class="{ 'white': sampletype.requirement_status === 'X', 'success': sampletype.requirement_status === 'Y' }" class="icon-medium-fill-base-small white"><v-icon :dark="sampletype.requirement_status === 'Y'">check</v-icon></span>
</div>
<div v-if="selected_patient.status === 'New' || selected_patient.status === 'Call' || selected_patient.status === 'Skip'">-</div>
</v-flex>
<v-flex class="text-xs-center" xs3>
<v-btn v-if="selected_patient.status === 'Process' || selected_patient.status === 'Done'" style="margin:3px 2px;" small color="warning">{{sampletype.process_date}} {{sampletype.process_time}}</v-btn>
<v-btn v-if="(selected_patient.status === 'Process' && sampletype.T_OrderSampleSampling === 'Y' ) && sampletype.requirement_status !== 'X'" @click="receiveSample(sampletype)" style="margin:3px 2px;" small color="success">{{sampletype.done_date}} {{sampletype.done_time}}</v-btn>
<v-btn depressed dark v-if="selected_patient.status === 'Process' && sampletype.T_OrderSampleReceive === 'N' && sampletype.requirement_status === 'X'" style="margin:3px 2px;" small color="grey">00-00-0000 00:00</v-btn>
<div v-if="selected_patient.status === 'New' || selected_patient.status === 'Call' || selected_patient.status === 'Skip'">-</div>
</v-flex>
</v-layout>
</v-flex>
</v-layout>
</v-flex>
</v-layout>
<v-divider></v-divider>
<v-layout row>
<v-flex xs12>
<v-layout wrap>
<v-flex v-for="inf in info" :key="inf.id" pb-1 pl-1 pr-1 xs3>
<v-btn block small color="primary" v-bind:class="{ 'success': inf.status_bahan === 'R', 'warning': inf.status_bahan === 'P' }" dark>{{inf.T_BahanName}}</v-btn>
</v-flex>
</v-layout>
</v-flex>
</v-layout>
</v-card>
</v-layout>
</template>
<style scoped>
.overline {
font-size: 0.625rem !important;
font-weight: 400;
letter-spacing: 0.1666666667em !important;
line-height: 1rem;
text-transform: uppercase;
}
.redcode {
box-shadow: none !important;
color: #c0341d !important;
background-color: #fbe5e1 !important;
}
</style>
<script>
module.exports = {
components : {
'one-x-check':httpVueLoader('../../common/onexcheck.vue')
},
data: () => ({
checkbox:false,
//dialognote:false,
dialognotecolor:'warning',
// msgnote:''
}),
computed: {
xnoterequirement(){
return this.$store.state.samplecall.note_requirement
},
xsampletypes(){
return this.$store.state.samplecall.sampletypes
},
xstatus(){
return this.$store.state.samplecall.selected_status
},
selected_patient(){
return this.$store.state.samplecall.selected_patient
},
dialogrequirement: {
get() {
return this.$store.state.samplecall.dialog_requirement
},
set(val) {
this.$store.commit("samplecall/update_dialog_requirement",val)
}
},
dialognote: {
get() {
return this.$store.state.samplecall.dialog_note
},
set(val) {
this.$store.commit("samplecall/update_dialog_note",val)
}
},
dialogformnote: {
get() {
return this.$store.state.samplecall.dialog_form_note
},
set(val) {
this.$store.commit("samplecall/update_dialog_form_note",val)
}
},
msgnote: {
get() {
return this.$store.state.samplecall.msg_note
},
set(val) {
this.$store.commit("samplecall/update_msg_note",val)
}
},
requirements: {
get() {
return this.$store.state.samplecall.requirements
},
set(val) {
this.$store.commit("samplecall/update_requirements",val)
}
},
info: {
get() {
return this.$store.state.samplecall.information_bahan
},
set(val) {
this.$store.commit("samplecall/update_information_bahan",val)
}
},
staff: {
get() {
return this.$store.state.samplecall.staff
},
set(val) {
this.$store.commit("samplecall/update_staff",val)
}
},
},
methods : {
processSample(sampletype){
var patient = this.$store.state.samplecall.selected_patient
var msg = "Anda yakin akan melakukan proses untuk "+sampletype.T_SampleTypeName+" dari "+patient.patient_fullname+" ? "
this.$store.commit("samplecall/update_msg_action",msg)
this.$store.commit("samplecall/update_act",'samplingprocess')
this.$store.commit("samplecall/update_selected_sampletype",sampletype)
this.$store.commit("samplecall/update_dialog_action",true)
},
doneSample(sampletype){
var patient = this.$store.state.samplecall.selected_patient
var msg = "Anda yakin proses untuk "+sampletype.T_SampleTypeName+" dari "+patient.patient_fullname+" telah selesai ? "
this.$store.commit("samplecall/update_msg_action",msg)
this.$store.commit("samplecall/update_act",'samplingdone')
this.$store.commit("samplecall/update_selected_sampletype",sampletype)
this.$store.commit("samplecall/update_dialog_action",true)
},
printBarcodeGroup(){
var id = this.selected_patient.T_OrderHeaderID
one_print_barcode_so_group(id)
},
printBarcode(sampletype){
var id = sampletype.T_OrderDetailID
one_print_barcode_so(id)
},
openDialogRequirement(value,idx){
if(value.status === 'D' && value.requirement_status === 'Y'){
}
else{
this.$store.commit("samplecall/update_selected_sample",value)
var sampletypes = this.$store.state.samplecall.sampletypes
sampletypes[idx].requirement_status = 'N'
this.$store.commit("samplecall/update_requirements", sampletypes[idx].requirements)
this.$store.commit("samplecall/update_dialog_requirement", true)
}
},
confirmRequirement(value,idx){
if(value.status === 'P'){
var sampletypes = this.$store.state.samplecall.sampletypes
sampletypes[idx].requirement_status = 'Y'
this.$store.commit("samplecall/update_sampletypes",sampletypes)
sampletypes[idx].requirements.forEach((el)=>{el.chex = "N"})
}
},
saveRequirement(){
//console.log(this.$store.state.samplecall.selected_sample)
var sampletypes = this.$store.state.samplecall.sampletypes
var selected_sample = this.$store.state.samplecall.selected_sample
var idx = _.findIndex(sampletypes, function(o) {
return o.T_BarcodeLabBarcode == selected_sample.T_BarcodeLabBarcode
})
if(sampletypes[idx].status === 'P'){
sampletypes[idx].requirements = this.$store.state.samplecall.requirements
}
this.$store.commit("samplecall/update_dialog_requirement",false)
},
checkReq(val,idx){
var xrequirements = this.requirements
console.log(xrequirements[idx])
if(xrequirements[idx].T_OrderSampleReceive === 'N'){
xrequirements[idx].chex = val
this.$store.commit("samplecall/update_requirements",xrequirements)
}
},
receiveSample(value){
var goaction = true
if(value.requirement_status === 'N'){
var req_check = _.filter(value.requirements, function(o) { return o.chex === 'Y' })
if(req_check.length === 0){
goaction = false
}
}
if(value.T_OrderSampleReceive === 'N' && value.requirement_status !== 'X' && goaction){
this.$store.commit("samplecall/update_act",'samplingdone')
var prm = this.selected_patient
prm.id = this.selected_patient.T_OrderHeaderID
prm.act = 'samplingdone'
prm.sample = value
prm.staff = this.$store.state.samplecall.staff
prm.search = {
name:this.$store.state.samplecall.name,
nolab:this.$store.state.samplecall.nolab,
stationid: this.$store.state.samplecall.selected_station.id,
statusid: this.$store.state.samplecall.selected_status.id,
companyid: this.$store.state.samplecall.selected_company.id,
lastid: this.$store.state.samplecall.last_id
}
this.$store.dispatch("samplecall/receivesample",prm)
}else{
//console.log('oeey')
if(value.status === 'P'){
this.$store.commit("samplecall/update_msg_info","Jalan - jalan ke gunung merapi, Requirement-nya tolong dilengkapi")
this.$store.commit("samplecall/update_open_dialog_info",true)
}
}
},
addNewLabel(sampletype){
this.$store.commit("samplecall/update_selected_sampletype",sampletype)
var sample = sampletype.T_SampleTypeName
var patient = this.$store.state.samplecall.selected_patient
var msg = "Anda yakin akan melakukan penambahan label spesimen "+sample+" untuk pasien "+patient.patient_fullname+" ? "
this.$store.commit("samplecall/update_msg_action",msg)
this.$store.commit("samplecall/update_act",'addnewlabel')
//this.closeDialogAction()
this.$store.commit("samplecall/update_dialog_action",true)
},
openDialogNote(){
this.msgnote = '<p><code color="red">catatan dari fo : </code></p>'
this.msgnote += '<p>'+this.$store.state.samplecall.selected_patient.T_OrderHeaderFoNote+'</p>'
this.dialognotecolor = 'warning'
this.dialognote = true
},
openDialogFormNote(){
this.dialogformnote = true
},
openDialogFoNoteRequirement(){
var prm = this.$store.state.samplecall.selected_patient
this.$store.dispatch("samplecall/getdatanoterequirement",prm)
},
searchPatientLastSelect() {
this.dialogformnote = false
this.$store.dispatch("samplecall/search",{
name:this.$store.state.samplecall.name,
nolab:this.$store.state.samplecall.nolab,
stationid: this.$store.state.samplecall.selected_station.id,
statusid: this.$store.state.samplecall.selected_status.id,
companyid: this.$store.state.samplecall.selected_company.id,
lastid: this.$store.state.samplecall.last_id
})
},
saveNoteSampling(){
var prm = this.$store.state.samplecall.selected_patient
prm.search = {
name:this.$store.state.samplecall.name,
nolab:this.$store.state.samplecall.nolab,
stationid: this.$store.state.samplecall.selected_station.id,
statusid: this.$store.state.samplecall.selected_status.id,
companyid: this.$store.state.samplecall.selected_company.id,
lastid: this.$store.state.samplecall.last_id
}
this.$store.dispatch("samplecall/savenotesampling",prm)
}
}
}
</script>

View File

@@ -0,0 +1,352 @@
<template>
<div>
<v-dialog v-model="xdialogaction" persistent max-width="350">
<v-card>
<v-card-title color="warning" class="headline">Konfirmasi</v-card-title>
<v-card-text v-html="xmsgaction">
</v-card-text>
<v-card-actions>
<v-spacer></v-spacer>
<v-btn color="primary darken-1" flat @click="closeDialogAction()">OK</v-btn>
<v-btn color="error darken-1" flat @click="xdialogaction = false">Tutup</v-btn>
</v-card-actions>
</v-card>
</v-dialog>
<v-layout wrap>
<v-flex xs12>
<v-card class="pt-1 pb-1 pr-1" elevation="3" color="light-blue">
<v-layout align-center justify-center row shrink fill-height>
<v-flex xs2>
<v-card flat>
<v-img
:src="xselected_patient.M_PatientPhotoThumb"
:lazy-src="xselected_patient.M_PatientPhotoThumb"
aspect-ratio="1"
width="100%"
class="light-blue"
contain
>
</v-card>
</v-flex>
<v-flex xs10>
<v-card flat>
<v-layout pt-1 pl-2 pb-1 pr-2 row>
<v-flex>
<v-subheader style="color:black;height:auto;padding:0px">
<h3 style="font-size:x-large" class="font-weight-bold">{{ xselected_patient.T_OrderHeaderLabNumber }}</h3>
<v-flex text-md-right>
<span @click="callPatient()" v-if="xselected_patient.statusid === '0' || xselected_patient.statusid === '2'" style="font-size:24px;" class="icon-medium-fill-base-small xs1 white--text info"><v-icon dark>volume_up</v-icon></span>
<span @click="skip()" v-if="xselected_patient.statusid === '1' || xselected_patient.statusid === '3'" style="font-size:24px;" class="icon-medium-fill-base-small xs1 white--text black"><v-icon dark>fast_rewind</v-icon></span>
<span @click="processNow(xselected_patient.statusid)" v-if="xselected_patient.statusid === '1'" v-bind:class="{ 'warning':xselected_patient.statusid === '1','grey':xselected_patient.statusid !== '1' }" style="font-size:24px;" class="icon-medium-fill-base-small xs1 white--text"><v-icon dark>loop</v-icon></span>
</v-flex>
</v-subheader>
</v-flex>
</v-layout>
<v-layout pl-2 pr-2 row>
<v-flex xs4>
<v-layout column>
<v-flex pt-1>
<v-text-field
v-model=" xselected_patient.M_PatientNoReg"
label="PID"
readonly
hide-details
>
</v-text-field>
</v-flex>
</v-layout>
</v-flex>
<v-flex xs8 pl-2>
<v-layout column>
<v-flex pt-1 >
<v-layout row>
<v-flex xs4>
<v-text-field
v-model="xselected_patient.patient_dob"
label="Tanggal lahir"
readonly
hide-details
>
</v-text-field>
</v-flex>
<v-flex xs8 pl-1>
<v-text-field
v-model=" xselected_patient.T_OrderHeaderM_PatientAge"
label="Umur"
readonly
hide-details
>
</v-text-field>
</v-flex>
</v-layout>
</v-flex>
</v-layout>
</v-flex>
</v-layout>
<v-layout pb-2 pt-1 pl-2 pr-2 row>
<v-flex xs8>
<v-text-field
v-model=" xselected_patient.patient_fullname"
label="Nama"
readonly
hide-details
>
</v-text-field>
</v-flex>
<v-flex xs4 pl-1>
<v-text-field
v-model="xselected_patient.M_PatientHP"
label="HP"
readonly
hide-details
>
</v-text-field>
</v-flex>
</v-layout>
</v-card>
</v-flex>
</v-layout>
</v-card>
</v-flex>
</v-layout>
<!--<v-card v-if="xselected_patient">
<v-layout row>
<v-flex xs12 pa-2>
<v-layout align-center row>
<v-flex xs2>
<v-card>
<v-img
:src="xselected_patient.M_PatientPhotoThumb"
aspect-ratio="1"
class="grey lighten-2 elevation-2"
>
</v-img>
</v-card>
</v-flex>
<v-flex xs10 pl-2 pt-1>
<v-card>
<v-layout pa-2 row>
<v-flex>
<v-subheader style="color:black;height:auto;padding:0px">
<h3 style="font-size:x-large" class="font-weight-bold">{{ xselected_patient.T_OrderHeaderLabNumber }}</h3>
<v-flex text-md-right>
<span @click="callPatient()" v-if="xselected_patient.statusid === '0' || xselected_patient.statusid === '2'" style="font-size:24px;" class="icon-medium-fill-base-small xs1 white--text info"><v-icon dark>volume_up</v-icon></span>
<span @click="skip()" v-if="xselected_patient.statusid === '1' || xselected_patient.statusid === '3'" style="font-size:24px;" class="icon-medium-fill-base-small xs1 white--text black"><v-icon dark>fast_rewind</v-icon></span>
<span @click="processNow(xselected_patient.statusid)" v-if="xselected_patient.statusid === '1'" v-bind:class="{ 'warning':xselected_patient.statusid === '1','grey':xselected_patient.statusid !== '1' }" style="font-size:24px;" class="icon-medium-fill-base-small xs1 white--text"><v-icon dark>loop</v-icon></span>
</v-flex>
</v-subheader>
</v-flex>
</v-layout>
<v-layout pa-2 row wrap>
<v-flex xs4>
<v-layout column>
<v-flex pt-1>
<v-text-field
v-model=" xselected_patient.M_PatientNoReg"
label="PID"
readonly
hide-details
>
</v-text-field>
</v-flex>
<v-flex pt-1 >
<v-text-field
v-model=" xselected_patient.patient_fullname"
label="Nama"
readonly
hide-details
>
</v-text-field>
</v-flex>
</v-layout>
</v-flex>
<v-flex xs8 pl-2>
<v-layout column>
<v-flex pt-1 >
<v-layout row>
<v-flex xs4>
<v-text-field
v-model="xselected_patient.patient_dob"
label="Tanggal lahir"
readonly
hide-details
>
</v-text-field>
</v-flex>
<v-flex xs8 pl-1>
<v-text-field
v-model=" xselected_patient.T_OrderHeaderM_PatientAge"
label="Umur"
readonly
hide-details
>
</v-text-field>
</v-flex>
</v-layout>
</v-flex>
<v-flex pt-1>
<v-text-field
v-model="xselected_patient.M_PatientHP"
label="HP"
readonly
hide-details
>
</v-text-field>
</v-flex>
</v-layout>
</v-flex>
</v-layout>
<v-card>
</v-flex>
</v-layout>
</v-flex>
</v-layout> -->
</div>
</template>
<style scoped>
</style>
<script>
module.exports = {
data: () => ({
}),
computed: {
xselected_patient:{
get() {
return this.$store.state.samplecall.selected_patient
},
set(val) {
this.$store.commit("samplecall/update_selected_patient",val)
}
},
xdialogaction:{
get() {
return this.$store.state.samplecall.dialog_action
},
set(val) {
this.$store.commit("samplecall/update_dialog_action",val)
}
},
xmsgaction:{
get() {
return this.$store.state.samplecall.msg_action
},
set(val) {
this.$store.commit("samplecall/update_msg_action",val)
}
}
},
methods : {
closeDialogAction(){
var act = this.$store.state.samplecall.act
var sample = this.$store.state.samplecall.selected_sampletype
var status = 1
if(act === 'process'){
status = 3
}
if(act === 'skip'){
status = 2
}
if(act === 'samplingprocess'){
status = 3
}
if(act === 'samplingdone'){
status = 4
}
if(act != 'addnewlabel'){
var patient = this.$store.state.samplecall.selected_patient
var lastid = this.$store.state.samplecall.last_id
this.$store.dispatch("samplecall/doaction",{
act:act,
id:patient.T_OrderHeaderID,
name:this.$store.state.samplecall.name,
nolab:this.$store.state.samplecall.nolab,
stationid: patient.T_SampleStationID,
statusid:this.$store.state.samplecall.selected_status.id,
statusnextid : status,
sample:sample,
lastid:lastid,
companyid: this.$store.state.samplecall.selected_company.id,
staff:this.$store.state.samplecall.staff
})
}
else{
var patient = this.$store.state.samplecall.selected_patient
var lastid = this.$store.state.samplecall.last_id
this.$store.dispatch("samplecall/addnewlabel",{
act:act,
id:patient.T_OrderHeaderID,
name:this.$store.state.samplecall.name,
nolab:this.$store.state.samplecall.nolab,
stationid: patient.T_SampleStationID,
statusid:this.$store.state.samplecall.selected_status.id,
statusnextid : status,
sample:this.$store.state.samplecall.selected_sampletype,
lastid:lastid,
companyid: this.$store.state.samplecall.selected_company.id,
staff:this.$store.state.samplecall.staff
})
}
},
callPatient(){
//var patient = this.$store.state.samplecall.selected_patient
//var msg = "Anda yakin akan melakukan panggilan kepada pasien "+patient.patient_fullname+" ? "
//this.$store.commit("samplecall/update_msg_action",msg)
this.$store.commit("samplecall/update_act",'call')
this.closeDialogAction()
//this.$store.commit("samplecall/update_dialog_action",true)
},
processNow(value){
if(value === '1'){
//var patient = this.$store.state.samplecall.selected_patient
//var msg = "Anda yakin akan merubah status <span style='color:ff5252;font-weight:bold'>PROCESS</span> untuk pasien "+patient.patient_fullname+" ? "
//this.$store.commit("samplecall/update_msg_action",msg)
this.$store.commit("samplecall/update_act",'process')
this.closeDialogAction()
//this.$store.commit("samplecall/update_dialog_action",true)
}
},
skip(){
//var patient = this.$store.state.samplecall.selected_patient
//var msg = "Anda yakin akan merubah status <span style='color:ff5252;font-weight:bold'>SKIP</span> untuk pasien "+patient.patient_fullname+" ? "
//this.$store.commit("samplecall/update_msg_action",msg)
this.$store.commit("samplecall/update_act",'skip')
this.closeDialogAction()
//this.$store.commit("samplecall/update_dialog_action",true)
},
patient_photo(){
var photo = "https://www.sgm-inc.com/wp-content/uploads/2014/06/no-profile-male-img.gif"
if(this.xselected_patient.M_PatientPhoto){
photo = this.xselected_patient.M_PatientPhoto
}
console.log(photo)
return photo
}
}
}
</script>

View File

@@ -0,0 +1,394 @@
<template>
<v-layout class="fill-height" column>
<v-dialog v-model="dialogsuccess" persistent max-width="290">
<v-card>
<v-card-title color="success" class="headline">Berhasil !</v-card-title>
<v-card-text>
{{msgsuccess}}
</v-card-text>
<v-card-actions>
<v-spacer></v-spacer>
<v-btn color="green darken-1" flat @click="closeDialogSuccess">OK</v-btn>
</v-card-actions>
</v-card>
</v-dialog>
<v-card class="mb-2 pa-2 searchbox">
<v-layout row>
<v-flex pt-1 xs4>
<v-text-field
style="font-size:14px"
label="No Reg"
class="mr-1"
outline
v-on:keyup.enter="searchPatient"
v-model="nolab"
hide-details
></v-text-field>
</v-flex>
<v-flex xs4>
<v-autocomplete
label="Kel. Pelanggan"
v-model="selected_company"
class="ma-1"
:items="xcompanies"
:search-input.sync="search_company"
auto-select-first
hide-details
style="font-size:14px"
outline
no-filter
item-text="name"
return-object
:loading="isLoading"
no-data-text="Semua Kel. Pelanggan"
>
<template slot="item" slot-scope="{ item }">
<v-list-tile-content>
<v-list-tile-title v-text="item.name"></v-list-tile-title>
</v-list-tile-content>
</template>
</v-autocomplete>
</v-flex>
<v-flex xs4>
<v-select class="mini-select ma-1" :items="xstations"
item-text="name"
return-object
style="font-size:14px"
v-model="xselectedstation"
label="Station" outline hide-details></v-select>
</v-flex>
</v-layout>
</v-card>
<v-card >
<v-layout row>
<v-flex xs12 pl-2 pr-2 pt-2 pb-2>
<v-data-table
:headers="headers"
:items="patients"
:loading="isLoading"
hide-actions
class="elevation-1">
<template slot="items" slot-scope="props">
<td class="text-xs-left pa-2" v-bind:class="{'amber lighten-4':isSelected(props.item),'teal white--text':props.item.coming === 'Y','amber':props.item.iscito === 'Y'}" @click="selectMe(props.item)">{{ format_date(props.item.T_OrderHeaderDate) }}</td>
<td class="text-xs-left pa-2" v-bind:class="{'amber lighten-4':isSelected(props.item),'teal white--text':props.item.coming === 'Y','amber':props.item.iscito === 'Y'}" @click="selectMe(props.item)">
<span class="font-weight-black caption">{{ props.item.T_OrderHeaderLabNumber }}</span>
<span style="color:#800000" class="font-weight-bold caption">{{props.item.T_OrderHeaderLabNumberExt}}</span>
</td>
<td class="text-xs-left pa-2" v-bind:class="{'amber lighten-4':isSelected(props.item),'teal white--text':props.item.coming === 'Y','amber':props.item.iscito === 'Y'}" @click="selectMe(props.item)">{{ props.item.M_CompanyName}}</td>
<td class="text-xs-left pa-2" v-bind:class="{'amber lighten-4':isSelected(props.item),'teal white--text':props.item.coming === 'Y','amber':props.item.iscito === 'Y'}" @click="selectMe(props.item)">{{ props.item.patient_fullname}}</td>
<td class="text-xs-center pa-2" v-bind:class="{'amber lighten-4':isSelected(props.item),'teal white--text':props.item.coming === 'Y','amber':props.item.iscito === 'Y'}" @click="selectMe(props.item)">{{ props.item.status}}</td>
</template>
</v-data-table>
</v-flex>
</v-layout>
</v-card>
<one-dialog-info :status="opendialoginfo" :msg="msginfo" @close-dialog-info="closeDialogInfo()"></one-dialog-info>
<one-dialog-alert :status="openalertconfirmation" :msg="msgalertconfirmation" @forget-dialog-alert="forgetAlertConfirmation()" @close-dialog-alert="closeAlertConfirmation()"></one-dialog-alert>
<one-order-info></one-order-info>
</v-layout>
</template>
<style scoped>
.searchbox .v-input.v-text-field .v-input__slot{
min-height:60px;
}
.v-table__overflow {
height:600px;
overflow-y:scroll;
}
.searchbox .v-btn {
min-height:60px;
}
table.v-table tbody td,table.v-table tbody th {
height: 40px;
}
table.v-table thead tr {
height: 40px;
}
table.v-table body {
height:500px;
overflow-y: scroll;
}
</style>
<script>
module.exports = {
components : {
'one-dialog-info':httpVueLoader('../../common/oneDialogInfo.vue'),
'one-dialog-alert':httpVueLoader('../../common/oneDialogAlert.vue'),
'one-order-info':httpVueLoader('./oneOrderInfo.vue')
},
mounted() {
//this.$store.dispatch("samplecall/getinitdata")
this.$store.dispatch("samplecall/getstationstatus",{
name:this.name,
nolab:this.nolab,
stationid: this.xselectedstation.id,
statusid: this.xselectedstatus.id,
companyid:this.selected_company.id,
// current_page:1,
lastid: -1
})
},
methods : {
format_date(d) {
return moment(d).format("DD.MM.YYYY")
},
isSelected(p) {
if(p.coming === 'Y' || p.iscito === 'Y')
return false
else
return p.T_OrderHeaderID == this.$store.state.samplecall.selected_patient.T_OrderHeaderID
},
searchPatient() {
this.$store.dispatch("samplecall/search",{
name:this.name,
nolab:this.nolab,
stationid: this.xselectedstation.id,
statusid: this.xselectedstatus.id,
companyid:this.selected_company.id,
//current_page:1,
lastid: -1
})
},
selectMe(pat) {
if(this.$store.state.samplecall.no_save == 0 ){
var patients = this.$store.state.samplecall.patients
this.$store.commit("samplecall/update_selected_patient",pat)
var idx = _.findIndex(patients, function(o) { return o.T_OrderHeaderID == pat.T_OrderHeaderID })
this.$store.commit("samplecall/update_last_id",idx)
this.$store.dispatch("samplecall/getsampletypes",{
orderid:pat.T_OrderHeaderID,
stationid: pat.T_SampleStationID,
statusid: pat.statusid
})
}else{
this.$store.commit("samplecall/update_open_alert_confirmation",true)
}
},
closeAlertConfirmation(){
this.$store.commit("samplecall/update_open_alert_confirmation",false)
},
forgetAlertConfirmation(){
this.$store.commit("samplecall/update_no_save",0)
this.$store.commit("samplecall/update_open_alert_confirmation",false)
},
updateAlert_success(val){
this.$store.commit("samplecall/update_alert_success",val)
},
setNewPatient(){
},
closeDialogSuccess(){
let arrPatient = this.$store.state.samplecall.patients
var idx = _.findIndex(arrPatient, item => item.M_PatientID === this.$store.state.samplecall.last_id)
console.log(idx)
var xcur_page = 1
this.$store.dispatch("samplecall/search",{
name:this.name,
nolab:this.nolab,
stationid: this.xselectedstation.id,
statusid: this.xselectedstatus.id,
lastid: idx
})
this.$store.commit("samplecall/update_dialog_success",false)
},
closeDialogInfo(){
this.$store.commit("samplecall/update_open_dialog_info",false)
},
thr_search_company: _.debounce(function() {
this.$store.dispatch("samplecall/searchcompany", this.search_company);
}, 2000),
},
computed: {
dialogsuccess: {
get() {
return this.$store.state.samplecall.dialog_success
},
set(val) {
this.$store.commit("samplecall/update_dialog_success",val)
}
},
msgsuccess(){
return this.$store.state.samplecall.msg_success
},
snackbar: {
get() {
return this.$store.state.samplecall.alert_success
},
set(val) {
this.$store.commit("samplecall/update_alert_success",val)
}
},
isLoading() {
return this.$store.state.samplecall.search_status == 1
},
xstations() {
return this.$store.state.samplecall.stations
},
xselectedstation: {
get() {
return this.$store.state.samplecall.selected_station
},
set(val) {
this.$store.commit("samplecall/update_selected_station",val)
this.searchPatient()
}
},
xstatuses() {
return this.$store.state.samplecall.statuses
},
xselectedstatus: {
get() {
return this.$store.state.samplecall.selected_status
},
set(val) {
this.$store.commit("samplecall/update_selected_status",val)
this.searchPatient()
}
},
patients() {
return this.$store.state.samplecall.patients
},
openalertconfirmation: {
get() {
return this.$store.state.samplecall.open_alert_confirmation
},
set(val) {
this.$store.commit("samplecall/update_open_alert_confirmation",val)
}
},
curr_page: {
get() {
return this.$store.state.samplecall.current_page
},
set(val) {
this.$store.commit("samplecall/update_current_page",val)
this.$store.dispatch("samplecall/search",{
name:this.name,
nolab:this.nolab,
stationid: this.xselectedstation.id,
statusid: this.xselectedstatus.id,
current_page:val,
lastid: idx
})
}
},
xtotal_page: {
get() {
return this.$store.state.samplecall.total_page
},
set(val) {
this.$store.commit("samplecall/update_total_page",val)
}
},
opendialoginfo: {
get() {
return this.$store.state.samplecall.open_dialog_info
},
set(val) {
this.$store.commit("samplecall/update_open_dialog_info",false)
}
},
msginfo(){
return this.$store.state.samplecall.msg_info
},
name: {
get() {
return this.$store.state.samplecall.name
},
set(val) {
this.$store.commit("samplecall/update_name",val)
}
},
nolab: {
get() {
return this.$store.state.samplecall.nolab
},
set(val) {
this.$store.commit("samplecall/update_nolab",val)
//this.searchPatient()
}
},
xcompanies() {
return this.$store.state.samplecall.companies;
},
selected_company: {
get() {
return this.$store.state.samplecall.selected_company;
},
set(val) {
this.$store.commit("samplecall/update_selected_company", val)
this.searchPatient()
}
},
},
watch: {
search_company(val, old) {
if (val == old) return;
if (!val) return;
if (val.length < 1) return;
if (this.$store.state.samplecall.update_autocomplete_status == 1) return;
this.thr_search_company();
}
},
data() {
return {
msgalertconfirmation:"Perubahan yang telah dilakukan belum disimpan dong !",
items: [],
search_company: "",
//isLoading: false,
page:1,
headers: [
{
text: "TANGGAL",
align: "left",
sortable: false,
value: "mr",
width: "10%",
class: "pa-2 blue lighten-3 white--text"
},
{
text: "NO REG",
align: "left",
sortable: false,
value: "mr",
width: "10%",
class: "pa-2 blue lighten-3 white--text"
},
{
text: "KEL. PELANGGAN",
align: "left",
sortable: false,
value: "lab",
width: "10%",
class: "pa-2 blue lighten-3 white--text"
},
{
text: "NAMA",
align: "left",
sortable: false,
value: "name",
width: "30%",
class: "pa-2 blue lighten-3 white--text"
},
{
text: "STATUS",
align: "center",
sortable: false,
value: "status",
width: "10%",
class: "pa-2 blue lighten-3 white--text"
}
]
};
}
}
</script>