Files
FE_CPONE/test/vuex/one-receive-reference-delivery/components/oneReceiveReferenceDeliveryDetail.vue
2026-04-27 10:13:31 +07:00

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'"> &nbsp;[ <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>