Files
FE_CPONE/test/vuex/cpone-queue-ticket/components/display.vue
2026-04-27 10:13:31 +07:00

461 lines
14 KiB
Vue

<template>
<v-layout
id="display_parent"
class="pa-3"
style="
width: 100%;
height: 96vh;
background-color: white;
border-radius: 24px;
overflow: auto;
"
column
>
<!-- <v-toolbar dark color="primary" style="border-radius: 24px 24px 0px 0px;"> -->
<!-- <v-toolbar-side-icon></v-toolbar-side-icon> -->
<!-- <v-toolbar-title class="display-1 font-weight-bold white--text">
ANTRIAN
</v-toolbar-title> -->
<!-- <v-spacer></v-spacer>
<span class="display-1 font-weight-bold" id="realTimeDateTime"></span> -->
<!-- </v-toolbar> -->
<v-container fluid>
<v-layout row wrap>
<v-flex xs12 class="text-xs-right subheading mb-3">
Ticket Booth : {{ dataTicket.ticketBoothName }}
</v-flex>
<v-flex xs12 class="text-xs-center headline mb-3">
Laboratoriun Westerindo
</v-flex>
<v-flex xs12 class="text-xs-center headline mb-3">
{{ dataTicket.M_BranchName }}
</v-flex>
<v-flex xs12 class="text-xs-center subheading mb-3">
{{ dataTicket.queueStatusTicket }}
</v-flex>
<!-- <v-flex xs12 class="text-xs-center title mb-3"> NOMOR ANTRIAN </v-flex> -->
<v-flex xs12 class="text-xs-center subheading mb-3">
{{ dataTicket.serviceName }}
<p class="subheading mt-3" v-if="statusStation.length > 0">
{{ dataPatient.T_OrderHeaderLabNumber }} -
{{ dataPatient.M_PatientName }}
</p>
</v-flex>
<v-flex xs12 class="text-xs-center display-3 mb-3 font-weight-bold">
{{ dataTicket.queueNumber }}
</v-flex>
<v-flex
xs12
class="text-xs-center title mb-3 font-weight-bold"
v-if="statusStation.length === 0"
>
<v-chip
color="primary"
@click="vibrate()"
class="title"
v-if="dataTicket.queueStatusID === '2' || dataTicket.queueStatusID === '5' || dataTicket.queueStatusID === '3'"
text-color="white"
>{{ dataTicket.statusName }}
</v-chip>
<v-chip
color="orange"
@click="vibrate()"
v-if="dataTicket.queueStatusID === '1'"
class="title"
text-color="white"
>{{ dataTicket.statusName }}
</v-chip>
<v-chip
color="green"
@click="vibrate()"
v-if="dataTicket.queueStatusID === '4'"
class="title"
text-color="white"
>{{ dataTicket.statusName }}
</v-chip>
</v-flex>
<v-flex
xs12
class="text-xs-center title mb-3 font-weight-bold"
v-if="statusStation.length > 0"
>
<p v-if="!isObjectEmpty(selectedStatusStation)">
{{ selectedStatusStation.T_SampleStationName }}
</p>
<v-chip
color="primary"
@click="vibrate()"
v-if="!isObjectEmpty(selectedStatusStation)"
class="title"
text-color="white"
>{{ selectedStatusStation.T_SamplingQueueStatusName }}
</v-chip>
<v-chip
color="primary"
@click="vibrate()"
v-if="isObjectEmpty(selectedStatusStation) && statusDone === 'N'"
class="title"
text-color="white"
>WAITING
</v-chip>
<v-chip
color="green"
@click="vibrate()"
v-if="statusDone === 'Y'"
class="title"
text-color="white"
>DONE
</v-chip>
</v-flex>
<v-flex xs12 class="text-xs-center">
<v-data-table
:headers="headers"
:items="statusFO"
class="elevation-1"
hide-actions
>
<template v-slot:items="props">
<td class="text-xs-left">{{ props.item.status }}</td>
<td class="text-xs-center">{{ props.item.time }}</td>
</template>
</v-data-table>
</v-flex>
<v-flex
xs12
class="text-xs-center mt-3"
v-if="statusStation.length > 0"
>
<v-divider></v-divider>
<v-data-table
:headers="headersStation"
:items="statusStation"
class="elevation-1 mt-3"
hide-actions
>
<template v-slot:items="props">
<td class="text-xs-left">{{ props.item.T_SampleStationName }}</td>
<td class="text-xs-center">
{{ props.item.T_SamplingQueueStatusName }}
</td>
</template>
</v-data-table>
</v-flex>
</v-layout>
</v-container>
</v-layout>
</template>
<style scoped></style>
<script>
// const { data } = require("./onePriceHeader.vue");
module.exports = {
// components: {
// "one-dialog-info": httpVueLoader("../../common/oneDialogInfo.vue"),
// "one-dialog-alert": httpVueLoader("../../common/oneDialogAlert.vue"),
// },
mounted() {
console.log("ini mi=ounted");
document.addEventListener("DOMContentLoaded", this.updateDateTime());
// this.$store.dispatch("queue/getStation");
// this.$store.dispatch("queue/getStation");
const element = document.getElementById("display_parent");
const height = element.offsetHeight;
console.log("Offset Height:", height);
},
methods: {
isEmptyObject(obj) {
return Object.keys(obj).length === 0 && obj.constructor === Object;
},
vibrate() {
// navigator.vibrate(2000);
},
getHeight() {
const element = document.getElementById("display_parent");
const height = element.offsetHeight;
if (this.queueList.length == 1) {
return height;
} else {
return height / 2;
}
},
fullscreen() {
var elem = document.documentElement;
if (elem.requestFullscreen) {
elem.requestFullscreen();
} else if (elem.webkitRequestFullscreen) {
/* Safari */
elem.webkitRequestFullscreen();
} else if (elem.msRequestFullscreen) {
/* IE11 */
elem.msRequestFullscreen();
}
},
back() {
this.screen = "setting";
},
adjustCardHeights() {
// Ambil tinggi layout-container
const layout = document.getElementById("display_parent");
const height = layout.offsetHeight;
// Hitung tinggi untuk setiap kartu
const cards = document.querySelectorAll(".card-wrapper");
const rows = Math.ceil(this.items.length / 2); // Maksimal 2 item per baris
const cardHeight = height / rows;
// Set tinggi untuk setiap kartu
cards.forEach((card) => {
card.style.height = `${cardHeight}px`;
});
},
getGridClass(length, index) {
// Atur grid berdasarkan jumlah item
if (length === 1) return "xs12 fill-height"; // 1 item: 1 kolom penuh
if (length === 2) return "xs12 "; // 2 item: 1 kolom per baris
if (length === 3) return index < 2 ? "xs6 " : "xs12 "; // 3 item: 2 atas, 1 bawah
if (length === 4) return "xs6 "; // 4 item: 2 atas, 2 bawah
},
updateDateTime() {
const dateTimeElement = document.getElementById("realTimeDateTime"); // Ganti dengan ID elemen HTML Anda
const monthNames = [
"Januari",
"Februari",
"Maret",
"April",
"Mei",
"Juni",
"Juli",
"Agustus",
"September",
"Oktober",
"November",
"Desember",
];
function formatDateTime() {
const now = new Date();
const day = now.getDate();
const month = monthNames[now.getMonth()];
const year = now.getFullYear();
const hours = String(now.getHours()).padStart(2, "0");
const minutes = String(now.getMinutes()).padStart(2, "0");
return `${day} ${month} ${year} ${hours}:${minutes}`;
}
function refresh() {
dateTimeElement.textContent = formatDateTime();
}
refresh(); // Menampilkan waktu saat pertama kali
setInterval(refresh, 1000); // Perbarui setiap detik
},
isObjectEmpty(obj) {
return Object.keys(obj).length === 0 && obj.constructor === Object;
},
save() {
if (this.loading) return;
if (this.title.trim() === "") {
alert("Judul tidak boleh Kosong");
return;
}
if (this.isObjectEmpty(this.selectedBranch)) {
alert("Pilih salah satu cabang");
return;
}
if (this.selectedStation.length === 0) {
alert("Pilih station terlebih dahulu");
return;
}
if (this.selectedStation.length > 4) {
alert("Pilih station maksimal 4");
return;
}
this.screen = "display";
},
},
computed: {
statusDone: {
get() {
return this.$store.state.queue.statusDone;
},
set(val) {
this.$store.commit("queue/update_statusDone", val);
},
},
selectedStatusStation: {
get() {
return this.$store.state.queue.selectedStatusStation;
},
set(val) {
this.$store.commit("queue/update_selectedStatusStation", val);
},
},
statusStation: {
get() {
return this.$store.state.queue.statusStation;
},
set(val) {
this.$store.commit("queue/update_statusStation", val);
},
},
dataPatient: {
get() {
return this.$store.state.queue.dataPatient;
},
set(val) {
this.$store.commit("queue/update_dataPatient", val);
},
},
dataTicket: {
get() {
return this.$store.state.queue.dataTicket;
},
set(val) {
this.$store.commit("queue/update_dataTicket", val);
},
},
statusFO: {
get() {
return this.$store.state.queue.statusFO;
},
set(val) {
this.$store.commit("queue/update_statusFO", val);
},
},
queueList: {
get() {
return this.$store.state.queue.queueList;
},
set(val) {
this.$store.commit("queue/update_queueList", val);
},
},
screen: {
get() {
return this.$store.state.queue.screen;
},
set(val) {
this.$store.commit("queue/update_screen", val);
},
},
title: {
get() {
return this.$store.state.queue.title;
},
set(val) {
this.$store.commit("queue/update_title", val);
},
},
loading: {
get() {
return this.$store.state.queue.loading;
},
set(val) {
this.$store.commit("queue/update_loading", val);
},
},
stationList: {
get() {
return this.$store.state.queue.stationList;
},
set(val) {
this.$store.commit("queue/update_stationList", val);
},
},
selectedStation: {
get() {
return this.$store.state.queue.selectedStation;
},
set(val) {
this.$store.commit("queue/update_selectedStation", val);
},
},
branchList: {
get() {
return this.$store.state.queue.branchList;
},
set(val) {
this.$store.commit("queue/update_branchList", val);
},
},
selectedBranch: {
get() {
return this.$store.state.queue.selectedBranch;
},
set(val) {
this.$store.commit("queue/update_selectedBranch", val);
},
},
},
watch: {},
data() {
return {
selected_delivery: {},
search_company: "",
search_test: "",
menufilterdatestart: false,
menufilterdateend: false,
date: new Date().toISOString().substr(0, 10),
items: [],
menustartdate: false,
menuenddate: false,
errors: [],
sheet: false,
indeterminatex: false,
checkednotall: false,
bar_chx_all: false,
selected_barcode: [],
dialogtimeline: false,
search_doctor: "",
dialogWarning: false,
dialogWarningMsg: "",
rules: {
min: (v) => v > 0 || "Minimum value 1",
maxPersen: (v) => v <= 100 || "Maximum value 100",
},
headers: [
{
text: "STATUS",
align: "center",
sortable: false,
value: "lab",
width: "50%",
class: "pa-2 blue darken-2 white--text",
},
{
text: "TIME",
align: "center",
sortable: false,
value: "lab",
width: "50%",
class: "pa-2 blue darken-2 white--text",
},
],
headersStation: [
{
text: "STATION",
align: "center",
sortable: false,
value: "lab",
width: "50%",
class: "pa-2 blue darken-2 white--text",
},
{
text: "STATUS",
align: "center",
sortable: false,
value: "lab",
width: "50%",
class: "pa-2 blue darken-2 white--text",
},
],
};
},
};
</script>