498 lines
24 KiB
Vue
498 lines
24 KiB
Vue
<template>
|
|
<v-layout class="mb-2" column>
|
|
<v-dialog v-model="dialogconfirmationdelete" persistent max-width="290">
|
|
<v-card>
|
|
<v-card-title dark class="headline error pt-2 pb-2" primary-title style="color:white">
|
|
<h4 dark>Konfirmasi</h4>
|
|
</v-card-title>
|
|
<v-card-text>
|
|
{{msgconfirmationdelete}}
|
|
</v-card-text>
|
|
<v-card-actions>
|
|
<v-spacer></v-spacer>
|
|
<v-btn small color="error darken-1 text-sm-left" flat @click="doDeleteTrx()">Hapus</v-btn>
|
|
<v-btn small color="primary darken-1 text-sm-right" flat @click="dialogconfirmationdelete = false">Batal</v-btn>
|
|
</v-card-actions>
|
|
</v-card>
|
|
</v-dialog>
|
|
<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()">Ya</v-btn>
|
|
<v-btn color="error darken-1" flat @click="xdialogaction = false">Tutup</v-btn>
|
|
</v-card-actions>
|
|
</v-card>
|
|
</v-dialog>
|
|
<v-layout row>
|
|
|
|
<v-flex xs12>
|
|
<v-card>
|
|
<v-subheader red--text text--lighten-1> FORM SURAT JALAN
|
|
<span v-if="xact !== 'new'"> [ <span style="color:#2196F3;font-weight: 900;">{{xnumbering}}</span> ]</span>
|
|
<span v-if="xact !== 'new' && currStatus === 'CREATED'">
|
|
<v-btn small @click="releaseToCourier()" color="warning">RILIS SURAT JALAN</v-btn>
|
|
</span>
|
|
<!--
|
|
<span v-if="xact !== 'new' && currStatus === 'RELEASEC'">
|
|
<v-btn small @click="receiveCompany()" color="info">DITERIMA LAB PERUJUK</v-btn>
|
|
</span>
|
|
<span v-if="xact !== 'new' && currStatus === 'RCVDOC'">
|
|
<v-btn small @click="receiveFromCourier()" color="primary">TERIMA DARI KURIR</v-btn>
|
|
</span>
|
|
<span v-if="xact !== 'new' && currStatus === 'PARTDONE'">
|
|
<v-btn small @click="forceClose()" color="success">TUTUP TRANSAKSI MANUAL</v-btn>
|
|
</span>
|
|
-->
|
|
<v-flex text-md-right>
|
|
<v-btn v-if="xact !== 'new' && currStatus === 'CREATED'" @click="deleteTrx()" small color="error">Hapus</v-btn>
|
|
<v-btn v-if="( xact !== 'new' && currStatus === 'CREATED') || xact === 'new'" @click="saveTrx()" small color="primary">Simpan</v-btn>
|
|
</v-flex>
|
|
</v-subheader>
|
|
<v-divider></v-divider>
|
|
<v-layout class="pb-2" row wrap>
|
|
<v-flex xs12 pa-2>
|
|
<v-layout row>
|
|
<v-flex xs2 pa-1>
|
|
<v-text-field label="Tanggal Transaksi*" placeholder="dd-mm-yyyy" mask="##-##-####" v-model="xtrxdate" :disabled="xact === 'edit' && currStatus !== 'CREATED'"></v-text-field>
|
|
|
|
</v-flex>
|
|
<v-flex pa-1 xs4>
|
|
<v-select :search-input.sync="searchCompany" item-text="name" return-object :items="xcompanys" v-model="xselectedcompany" :disabled="xact === 'edit'" label="Kelompok Pelanggan*" autocomplete></v-select>
|
|
<p v-if="checkError('requirecompany')" class="error pl-2 pr-2" style="color:#fff">Kelompok Pelanggan dipilih dulu dong</p>
|
|
</v-flex>
|
|
<v-flex pa-1 xs4>
|
|
<v-select :search-input.sync="searchCourier" item-text="name" return-object :disabled="xact === 'edit' && currStatus !== 'CREATED'" :items="xcouriers" v-model="xselectedcourier"
|
|
label="Kurir" autocomplete></v-select>
|
|
<p v-if="checkError('requirecourier')" class="error pl-2 pr-2" style="color:#fff">Yang ngirim siapa dong ?</p>
|
|
</v-flex>
|
|
</v-layout>
|
|
<v-layout row>
|
|
<v-flex xs12 pa-1>
|
|
<v-textarea filled outline label="Catatan" v-model="xnote" rows="3"></v-textarea>
|
|
</v-flex>
|
|
</v-layout>
|
|
</v-flex>
|
|
</v-layout>
|
|
</v-card>
|
|
<v-layout class="pt-2 mb-2" column>
|
|
<v-card>
|
|
<v-layout row>
|
|
<v-flex xs12>
|
|
<v-subheader red--text text--lighten-1> DETAIL TRANSAKSI</v-subheader>
|
|
<v-divider></v-divider>
|
|
<v-layout row wrap>
|
|
<v-flex xs12 pa-2>
|
|
<v-layout v-if="xact === 'new'" row>
|
|
<v-flex xs12 pa-1>
|
|
<v-data-table :headers="headers" :items="details" :loading="isLoading" hide-actions class="elevation-1">
|
|
<template slot="items" slot-scope="props">
|
|
<td class="text-xs-left pa-2">{{ props.item.labnumberref }}</td>
|
|
<td class="text-xs-left pa-2">{{ props.item.patient_fullname }}</td>
|
|
<td class="text-xs-center pa-2">{{ props.item.samplename }}</td>
|
|
<td class="text-xs-center pa-2">
|
|
<div>
|
|
<v-btn @click="changeActive(props.item)" v-if="props.item.active === 'N'" small color="error">
|
|
<v-icon left>close</v-icon> Belum dipilih</v-btn>
|
|
<v-btn @click="changeActive(props.item)" v-if="props.item.active === 'Y'" flat small color="success">
|
|
<v-icon left>check</v-icon> Sudah terpilih</v-btn>
|
|
</div>
|
|
</template>
|
|
</v-data-table>
|
|
</v-flex>
|
|
</v-layout>
|
|
<v-layout v-if="xact !== 'new'" row>
|
|
<v-flex xs12 pa-1>
|
|
<v-data-table :headers="headerreceive" :items="details" :loading="isLoading" hide-actions class="elevation-1">
|
|
<template slot="items" slot-scope="props">
|
|
<td class="text-xs-left pa-2">{{ props.item.labnumberref }}</td>
|
|
<td class="text-xs-left pa-2">{{ props.item.patient_fullname }}</td>
|
|
<td class="text-xs-center pa-2">{{ props.item.samplename }}</td>
|
|
</template>
|
|
</v-data-table>
|
|
</v-flex>
|
|
</v-layout>
|
|
</v-flex>
|
|
</v-layout>
|
|
</v-flex>
|
|
</v-flex>
|
|
</v-card>
|
|
|
|
</v-layout>
|
|
</v-flex>
|
|
</v-flex>
|
|
</v-layout>
|
|
</template>
|
|
|
|
<style scoped>
|
|
table,
|
|
td,
|
|
th {
|
|
border: 1px solid #ddd;
|
|
text-align: left;
|
|
}
|
|
|
|
table {
|
|
border-collapse: collapse;
|
|
width: 100%;
|
|
}
|
|
|
|
th,
|
|
td {
|
|
padding-top: 5px;
|
|
padding-bottom: 5px;
|
|
padding-left: 8px;
|
|
padding-right: 5px;
|
|
}
|
|
|
|
.mini-input .v-input {
|
|
margin-top: 0px;
|
|
}
|
|
|
|
.mini-input .v-input,
|
|
.mini-input .v-input--selection-controls,
|
|
.mini-input .v-input__slot {
|
|
margin-top: 0px;
|
|
margin-bottom: 0px;
|
|
margin-left: 3px;
|
|
}
|
|
|
|
.mini-input .v-messages {
|
|
min-height: 0px;
|
|
}
|
|
|
|
input.fhm-input {
|
|
border: 1px solid black;
|
|
border-radius: 2px;
|
|
-webkit-box-shadow: inset 0 0 2px rgba(0, 0, 0, 0.1),
|
|
0 0 4px rgba(0, 0, 0, 0.1);
|
|
-moz-box-shadow: inset 0 0 2px rgba(0, 0, 0, 0.1),
|
|
0 0 4px rgba(0, 0, 0, 0.1);
|
|
box-shadow: inset 0 0 2px rgba(0, 0, 0, 0.1),
|
|
0 0 4px rgba(0, 0, 0, 0.1);
|
|
padding: 2px 4px;
|
|
background: rgba(255, 255, 255, 0.5);
|
|
margin: 0 0 1px 0;
|
|
width: 30px;
|
|
text-align: center;
|
|
}
|
|
</style>
|
|
|
|
<script>
|
|
module.exports = {
|
|
data: () => ({
|
|
menutrxdate: false,
|
|
date: new Date().toISOString().substr(0, 10),
|
|
isLoading: false,
|
|
searchCompany: '',
|
|
searchCourier: '',
|
|
headers: [{
|
|
text: "NOLAB REFERENSI",
|
|
align: "left",
|
|
sortable: false,
|
|
width: "15%",
|
|
class: "pa-2 blue lighten-3 white--text"
|
|
},
|
|
{
|
|
text: "PASIEN",
|
|
align: "left",
|
|
sortable: false,
|
|
width: "20%",
|
|
class: "pa-2 blue lighten-3 white--text"
|
|
},
|
|
{
|
|
text: "SAMPLE",
|
|
align: "center",
|
|
sortable: false,
|
|
width: "10%",
|
|
class: "pa-2 blue lighten-3 white--text"
|
|
},
|
|
|
|
{
|
|
text: "AKSI",
|
|
align: "center",
|
|
sortable: false,
|
|
width: "20%",
|
|
class: "pa-2 blue lighten-3 white--text"
|
|
}
|
|
],
|
|
headerreceive: [{
|
|
text: "NOLAB REFERENSI",
|
|
align: "left",
|
|
sortable: false,
|
|
width: "15%",
|
|
class: "pa-2 blue lighten-3 white--text"
|
|
},
|
|
{
|
|
text: "PASIEN",
|
|
align: "left",
|
|
sortable: false,
|
|
width: "20%",
|
|
class: "pa-2 blue lighten-3 white--text"
|
|
},
|
|
{
|
|
text: "SAMPLE",
|
|
align: "center",
|
|
sortable: false,
|
|
width: "10%",
|
|
class: "pa-2 blue lighten-3 white--text"
|
|
}
|
|
],
|
|
}),
|
|
computed: {
|
|
xact: {
|
|
get() {
|
|
return this.$store.state.receivereferencedelivery.act
|
|
},
|
|
set(val) {
|
|
this.$store.commit("receivereferencedelivery/update_act", val)
|
|
}
|
|
},
|
|
xnumbering() {
|
|
if (this.$store.state.receivereferencedelivery.selected_transaction)
|
|
return this.$store.state.receivereferencedelivery.selected_transaction.trx_numbering
|
|
else
|
|
return '-'
|
|
},
|
|
currStatus() {
|
|
if (this.$store.state.receivereferencedelivery.selected_transaction)
|
|
return this.$store.state.receivereferencedelivery.selected_transaction.status
|
|
else
|
|
return 'NONE'
|
|
},
|
|
xselectedtransaction() {
|
|
return this.$store.state.receivereferencedelivery.selected_transaction
|
|
},
|
|
xtrxdate: {
|
|
get() {
|
|
return this.$store.state.receivereferencedelivery.trx_date
|
|
},
|
|
set(val) {
|
|
this.$store.commit("receivereferencedelivery/update_trx_date", val)
|
|
}
|
|
},
|
|
dialogconfirmationdelete: {
|
|
get() {
|
|
return this.$store.state.receivereferencedelivery.dialog_confirmation_delete
|
|
},
|
|
set(val) {
|
|
this.$store.commit("receivereferencedelivery/update_dialog_confirmation_delete", val)
|
|
}
|
|
},
|
|
msgconfirmationdelete() {
|
|
return this.$store.state.receivereferencedelivery.msg_confirmation_delete
|
|
},
|
|
filterComputedDateFormattedTrx() {
|
|
return this.formatDate(this.xtrxdate)
|
|
},
|
|
xselectedcompany: {
|
|
get() {
|
|
return this.$store.state.receivereferencedelivery.selected_company
|
|
},
|
|
set(val) {
|
|
this.$store.commit("receivereferencedelivery/update_selected_company", val)
|
|
this.$store.dispatch("receivereferencedelivery/getordersamples", {
|
|
companyid: val.id
|
|
})
|
|
}
|
|
},
|
|
xcompanys() {
|
|
return this.$store.state.receivereferencedelivery.companys
|
|
},
|
|
xselectedcourier: {
|
|
get() {
|
|
return this.$store.state.receivereferencedelivery.selected_courier
|
|
},
|
|
set(val) {
|
|
this.$store.commit("receivereferencedelivery/update_selected_courier", val)
|
|
|
|
}
|
|
},
|
|
xcouriers() {
|
|
return this.$store.state.receivereferencedelivery.couriers
|
|
},
|
|
xnote: {
|
|
get() {
|
|
return this.$store.state.receivereferencedelivery.trx_note
|
|
},
|
|
set(val) {
|
|
this.$store.commit("receivereferencedelivery/update_trx_note", val)
|
|
}
|
|
},
|
|
details() {
|
|
return this.$store.state.receivereferencedelivery.details
|
|
},
|
|
xdialogaction: {
|
|
get() {
|
|
return this.$store.state.receivereferencedelivery.dialog_action
|
|
},
|
|
set(val) {
|
|
this.$store.commit("receivereferencedelivery/update_dialog_action", val)
|
|
}
|
|
},
|
|
xmsgaction: {
|
|
get() {
|
|
return this.$store.state.receivereferencedelivery.msg_action
|
|
},
|
|
set(val) {
|
|
this.$store.commit("receivereferencedelivery/update_msg_action", val)
|
|
}
|
|
}
|
|
},
|
|
methods: {
|
|
checkError(value) {
|
|
var errors = this.$store.state.receivereferencedelivery.errors
|
|
if (errors.includes(value)) {
|
|
return true
|
|
} else {
|
|
return false
|
|
}
|
|
},
|
|
formatDate(date) {
|
|
if (!date) return null
|
|
|
|
const [year, month, day] = date.split('-')
|
|
return `${day}-${month}-${year}`
|
|
},
|
|
deFormatedDate(date) {
|
|
if (!date) return null
|
|
|
|
const [day, month, year] = date.split('-')
|
|
return `${year}-${month.padStart(2, '0')}-${day.padStart(2, '0')}`
|
|
},
|
|
saveTrx() {
|
|
this.$store.commit("receivereferencedelivery/update_errors", [])
|
|
var errors = this.$store.state.receivereferencedelivery.errors
|
|
if (_.isEmpty(this.xselectedcompany)) {
|
|
errors.push("requirecompany")
|
|
}
|
|
if (_.isEmpty(this.xselectedcourier)) {
|
|
errors.push("requirecourier")
|
|
}
|
|
if (errors.length === 0) {
|
|
if (this.$store.state.receivereferencedelivery.details.length > 0) {
|
|
var details = this.$store.state.receivereferencedelivery.details
|
|
var prm = {}
|
|
console.log(this.xact)
|
|
if (this.xact === 'new')
|
|
prm.trx_id = 0
|
|
else
|
|
prm.trx_id = this.$store.state.receivereferencedelivery.selected_transaction.trx_id
|
|
|
|
console.log(prm.trx_id)
|
|
prm.details = details
|
|
prm.trx_date = moment(this.xtrxdate, 'DDMMYYYY', true)
|
|
prm.trx_note = this.xnote
|
|
prm.company = this.xselectedcompany
|
|
prm.courier = this.xselectedcourier
|
|
prm.startdate = this.$store.state.receivereferencedelivery.start_date
|
|
prm.enddate = this.$store.state.receivereferencedelivery.end_date
|
|
prm.search = this.$store.state.receivereferencedelivery.name_lab
|
|
prm.lastid = -1
|
|
this.$store.dispatch("receivereferencedelivery/save", prm)
|
|
} else {
|
|
var msg = "Belum ada sample yang dipilih dong "
|
|
this.$store.commit("receivereferencedelivery/update_msg_info", msg)
|
|
this.$store.commit("receivereferencedelivery/update_open_dialog_info", true)
|
|
}
|
|
}
|
|
},
|
|
changeFlagImage(value) {
|
|
console.log('changeFlagImage')
|
|
if (this.xact === 'new' || (this.xact !== 'new' && this.currStatus === 'CREATED')) {
|
|
let arr = this.$store.state.receivereferencedelivery.details
|
|
var idx = _.findIndex(arr, item => item.orderid === value.orderid && item.sampleid === value.sampleid)
|
|
arr[idx].flag_image = value.flag_image === 'N' ? 'Y' : 'N'
|
|
this.$store.commit("receivereferencedelivery/update_details", arr)
|
|
}
|
|
},
|
|
changeActive(value) {
|
|
console.log('changeActive')
|
|
if (this.xact === 'new' || (this.xact !== 'new' && this.currStatus === 'CREATED')) {
|
|
let arr = this.$store.state.receivereferencedelivery.details
|
|
var idx = _.findIndex(arr, item => item.rpatientid === value.rpatientid && item.sampleid === value.sampleid)
|
|
arr[idx].active = value.active === 'N' ? 'Y' : 'N'
|
|
this.$store.commit("receivereferencedelivery/update_details", arr)
|
|
}
|
|
},
|
|
changeFlagImageReceive(value) {
|
|
console.log('changeFlagImageReceive')
|
|
if (this.xact !== 'new' && this.currStatus !== 'DONE') {
|
|
let arr = this.$store.state.receivereferencedelivery.details
|
|
var idx = _.findIndex(arr, item => item.orderid === value.orderid && item.sampleid === value.sampleid)
|
|
arr[idx].flag_image_receive = value.flag_image_receive === 'N' ? 'Y' : 'N'
|
|
this.$store.commit("receivereferencedelivery/update_details", arr)
|
|
}
|
|
},
|
|
changeFlagResultReceive(value) {
|
|
console.log('changeFlagResultReceive')
|
|
if (this.xact !== 'new' && this.currStatus !== 'DONE') {
|
|
let arr = this.$store.state.receivereferencedelivery.details
|
|
var idx = _.findIndex(arr, item => item.T_ReceiveReferenceDeliveryDetailT_ReceiveReferencePatientID === value.T_ReceiveReferenceDeliveryDetailT_ReceiveReferencePatientID && item.sampleid === value.sampleid)
|
|
arr[idx].active = value.active === 'N' ? 'Y' : 'N'
|
|
this.$store.commit("receivereferencedelivery/update_details", arr)
|
|
}
|
|
},
|
|
deleteTrx() {
|
|
var trx = this.$store.state.receivereferencedelivery.selected_transaction
|
|
console.log(trx)
|
|
let msg = "Yakin, akan menghapus data transaksi " + trx.trx_numbering + " ?"
|
|
this.$store.commit("receivereferencedelivery/update_msg_confirmation_delete", msg)
|
|
this.$store.commit("receivereferencedelivery/update_dialog_confirmation_delete", true)
|
|
},
|
|
doDeleteTrx() {
|
|
var trx = this.$store.state.receivereferencedelivery.selected_transaction
|
|
this.$store.dispatch("receivereferencedelivery/deletetrx", trx)
|
|
},
|
|
releaseToCourier() {
|
|
var trx = this.$store.state.receivereferencedelivery.selected_transaction
|
|
var msg = "Anda yakin akan menyerahkan dokumen transaksi " + trx.trx_numbering + " ke kurir ? "
|
|
this.$store.commit("receivereferencedelivery/update_msg_action", msg)
|
|
this.$store.commit("receivereferencedelivery/update_act", 'RELEASEC')
|
|
this.$store.commit("receivereferencedelivery/update_dialog_action", true)
|
|
},
|
|
receiveCompany() {
|
|
var trx = this.$store.state.receivereferencedelivery.selected_transaction
|
|
var msg = "Dokumen transaksi " + trx.trx_numbering + " telah diterima lab perujuk ? "
|
|
this.$store.commit("receivereferencedelivery/update_msg_action", msg)
|
|
this.$store.commit("receivereferencedelivery/update_act", 'RCVLAB')
|
|
this.$store.commit("receivereferencedelivery/update_dialog_action", true)
|
|
},
|
|
receiveFromCourier() {
|
|
var trx = this.$store.state.receivereferencedelivery.selected_transaction
|
|
var msg = "Dokumen transaksi " + trx.trx_numbering + " diterima dari kurir ? "
|
|
this.$store.commit("receivereferencedelivery/update_msg_action", msg)
|
|
this.$store.commit("receivereferencedelivery/update_act", 'DONE')
|
|
this.$store.commit("receivereferencedelivery/update_dialog_action", true)
|
|
},
|
|
forceClose() {
|
|
var trx = this.$store.state.receivereferencedelivery.selected_transaction
|
|
var msg = "Dokumen transaksi " + trx.trx_numbering + " ditutup ? "
|
|
this.$store.commit("receivereferencedelivery/update_msg_action", msg)
|
|
this.$store.commit("receivereferencedelivery/update_act", 'FORCEDONE')
|
|
this.$store.commit("receivereferencedelivery/update_dialog_action", true)
|
|
},
|
|
closeDialogAction() {
|
|
var act = this.$store.state.receivereferencedelivery.act
|
|
var trx = this.$store.state.receivereferencedelivery.selected_transaction
|
|
let arrtrx = this.$store.state.receivereferencedelivery.transactions
|
|
var idx = _.findIndex(arrtrx, item => item.trx_id === trx.trx_id)
|
|
var prm = {}
|
|
prm.act = act
|
|
prm.trx = trx
|
|
prm.startdate = this.$store.state.receivereferencedelivery.start_date
|
|
prm.enddate = this.$store.state.receivereferencedelivery.end_date
|
|
prm.search = this.$store.state.receivereferencedelivery.name_lab
|
|
prm.stationid = this.$store.state.receivereferencedelivery.selected_station.id
|
|
prm.lastid = idx
|
|
prm.details = this.$store.state.receivereferencedelivery.details
|
|
prm.trx_note = this.xnote
|
|
this.$store.dispatch("receivereferencedelivery/doaction", prm)
|
|
},
|
|
}
|
|
}
|
|
</script> |