Files
FE_CPONE/test/vuex/cpone-control-card/index.php
2026-04-27 10:13:31 +07:00

491 lines
23 KiB
PHP

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>CPONE</title>
<link rel="stylesheet" href="../../../libs/vendor/css/google-fonts.css">
<link rel="stylesheet" href="../../../libs/vendor/css/icomoon-fonts.css">
<link rel="stylesheet" href="../../../libs/vendor/css/vuetify.min.css">
</head>
<body>
<div v-cloak id="app">
<v-app id="smartApp">
<!--<one-navbar></one-navbar>-->
<v-dialog
v-model="status_selesai"
max-width="290"
persistent>
<v-card>
<v-card-title class="headline">Selamat !</v-card-title>
<v-card-text>
Anda telah selesai melakukan seluruh pemeriksaan medical check up, silahkan mengisi survey
</v-card-text>
<v-card-actions>
<v-spacer></v-spacer>
<v-btn
color="primary darken-1"
flat="flat"
@click="goToSurvey()">
Klik untuk isi surve
</v-btn>
</v-card-actions>
</v-card>
</v-dialog>
<v-content style="background:#F5E8DF!important">
<v-container fluid>
<template>
<div
id="e3"
style="max-width: 400px; margin:auto"
class="grey lighten-3">
<v-toolbar>
<v-btn icon>
<v-icon>assignment</v-icon>
</v-btn>
<v-toolbar-title>Kartu Kontrol</v-toolbar-title>
<v-spacer></v-spacer>
<!--<v-btn icon>
<v-icon>search</v-icon>
</v-btn>-->
</v-toolbar>
<v-card>
<v-container
fluid
grid-list-lg>
<v-layout row wrap>
<v-flex xs12>
<v-card flat class="pb-4">
<v-img
class="mt-2"
:src="photo_qr"
height="115px"
contain></v-img>
</v-card>
<v-card color="primary" class="white--text">
<v-layout row>
<v-flex xs7>
<v-card-title primary-title>
<div>
<div class="headline mb-1">{{data_patient.labnumber}}</div>
<p class="mb-0">{{data_patient.patient_name}} <span v-if="data_patient.nip">/ {{data_patient.nip}}</span></p>
<p class="mb-0 caption">{{data_patient.patient_age}}</p>
<!--<div class="caption">{{data_patient.order_date}}</div>-->
<p class="mb-0 caption font-weight-bold">{{data_patient.corporate_name}}</p>
</div>
</v-card-title>
</v-flex>
<v-flex xs5>
<v-img
class="mt-2"
:src="data_patient.photo"
height="115px"
contain></v-img>
</v-flex>
</v-layout>
<v-divider light></v-divider>
<v-card-actions class="pa-3">
{{data_patient.gender}}
<v-spacer></v-spacer>
<p class="mb-0">{{data_patient.dob}}</p>
</v-card-actions>
</v-card>
<v-list class="mt-4" subheader>
<v-subheader>Pemeriksaan</v-subheader>
<v-list-group
v-if="data_packet.length > 0"
v-for="item in data_packet"
:key="item.packet_name"
v-model="item.active"
:prepend-icon="item.action"
no-action>
<template v-slot:activator>
<v-list-tile>
<v-list-tile-content>
<v-list-tile-title>{{ item.packet_name }}</v-list-tile-title>
</v-list-tile-content>
</v-list-tile>
</template>
<v-list-tile
v-for="subItem in item.details"
:key="subItem.test_name"
@click="">
<v-list-tile-content>
<v-list-tile-title>{{ subItem.test_name }}</v-list-tile-title>
</v-list-tile-content>
<v-list-tile-action>
<v-icon>{{ subItem.action }}</v-icon>
</v-list-tile-action>
</v-list-tile>
</v-list-group>
<!-- <v-card v-if="data_tests.length > 0" flat>
<v-form>
<v-text-field
v-for="(test,k_test) in data_tests"
:key="test.test_name"
label=""
prepend-inner-icon="label_important"
:value="test.test_name"
single-line
full-width
hide-details></v-text-field>
<v-divider v-if="k_test <= data.tests.length - 1"></v-divider>
</v-form>
</v-card> -->
<v-card v-if="data_tests.length > 0" flat>
<v-form>
<template v-for="(test, k_test) in data_tests">
<v-text-field
:key="test.test_name"
label=""
prepend-inner-icon="label_important"
:value="test.test_name"
single-line
full-width
hide-details></v-text-field>
<v-divider
v-if="k_test < data_tests.length - 1"></v-divider>
</template>
</v-form>
</v-card>
</v-list>
<v-subheader>Pemeriksaan / Pengambilan Sample</v-subheader>
<!--<v-subheader v-if="data_sample_lab.length > 0" inset>Laboratorium</v-subheader>-->
<v-list-tile
v-if="data_sample_lab.length > 0"
v-for="sample in data_sample_lab"
:key="sample.barcode"
avatar
@click=""
three-line
class="mb-2">
<v-list-tile-avatar>
<v-icon class="blue white--text">colorize</v-icon>
</v-list-tile-avatar>
<v-list-tile-content>
<v-list-tile-title>{{ sample.sampletype_name }}</v-list-tile-title>
<!--<v-list-tile-sub-title>{{ sample.receive_date }} {{ sample.receive_time }}</v-list-tile-sub-title>-->
<v-list-tile-sub-title class="font-weight-bold">{{sample.staff_name}}</v-list-tile-sub-title>
<v-list-tile-sub-title class="caption">{{ sample.receive_date }} {{ sample.receive_time }}</v-list-tile-sub-title>
</v-list-tile-content>
<v-list-tile-action>
<v-btn icon ripple>
<v-icon v-if="sample.is_sampling == 'N' || sample.is_received == 'N'" color="grey lighten-1">info</v-icon>
<v-icon v-if="sample.is_sampling == 'Y' && sample.is_received == 'Y'" color="success lighten-1">check_circle</v-icon>
</v-btn>
</v-list-tile-action>
</v-list-tile>
<!--<v-subheader v-if="data_sample_radiodiagnostic.length > 0" inset>Radiodiagnostik</v-subheader>-->
<v-list-tile
v-if="data_sample_radiodiagnostic.length > 0"
v-for="sample in data_sample_radiodiagnostic"
:key="sample.barcode"
avatar
@click=""
three-line
class="mb-2">
<v-list-tile-avatar>
<v-icon class="amber white--text">assignment_ind</v-icon>
</v-list-tile-avatar>
<v-list-tile-content>
<v-list-tile-title>{{ sample.sampletype_name }}</v-list-tile-title>
<v-list-tile-sub-title class="font-weight-bold">{{sample.staff_name}}</v-list-tile-sub-title>
<v-list-tile-sub-title class="caption">{{ sample.receive_date }} {{ sample.receive_time }}</v-list-tile-sub-title>
</v-list-tile-content>
<v-list-tile-action>
<v-btn icon ripple>
<v-icon v-if="sample.is_sampling == 'N' || sample.is_received == 'N'" color="grey lighten-1">info</v-icon>
<v-icon v-if="sample.is_sampling == 'Y' && sample.is_received == 'Y'" color="success lighten-1">check_circle</v-icon>
</v-btn>
</v-list-tile-action>
</v-list-tile>
<!--<v-subheader v-if="data_sample_electromedic.length > 0" inset>Elektromedik</v-subheader>-->
<v-list-tile
v-if="data_sample_electromedic.length > 0"
v-for="sample in data_sample_electromedic"
:key="sample.barcode"
avatar
@click=""
three-line
class="mb-2">
<v-list-tile-avatar>
<v-icon class="teal white--text">contacts</v-icon>
</v-list-tile-avatar>
<v-list-tile-content>
<v-list-tile-title>{{ sample.sampletype_name }}</v-list-tile-title>
<v-list-tile-sub-title class="font-weight-bold">{{sample.staff_name}}</v-list-tile-sub-title>
<v-list-tile-sub-title class="caption">{{ sample.receive_date }} {{ sample.receive_time }}</v-list-tile-sub-title>
</v-list-tile-content>
<v-list-tile-action>
<v-btn icon ripple>
<v-icon v-if="sample.is_sampling == 'N' || sample.is_received == 'N'" color="grey lighten-1">info</v-icon>
<v-icon v-if="sample.is_sampling == 'Y' && sample.is_received == 'Y'" color="success lighten-1">check_circle</v-icon>
</v-btn>
</v-list-tile-action>
</v-list-tile>
<!--<v-subheader v-if="data_sample_other.length > 0" inset>Layanan Klinik</v-subheader>-->
<v-list-tile
v-if="data_sample_other.length > 0"
v-for="sample in data_sample_other"
:key="sample.barcode"
avatar
@click=""
three-line
class="mb-2">
<v-list-tile-avatar>
<v-icon class="orange darken-2 white--text">accessibility</v-icon>
</v-list-tile-avatar>
<v-list-tile-content>
<v-list-tile-title>{{ sample.sampletype_name }}</v-list-tile-title>
<v-list-tile-sub-title class="font-weight-bold">{{sample.staff_name}}</v-list-tile-sub-title>
<v-list-tile-sub-title class="caption">{{ sample.receive_date }} {{ sample.receive_time }}</v-list-tile-sub-title>
</v-list-tile-content>
<v-list-tile-action>
<v-btn icon ripple>
<v-icon v-if="sample.is_sampling == 'N' || sample.is_received == 'N'" color="grey lighten-1">info</v-icon>
<v-icon v-if="sample.is_sampling == 'Y' && sample.is_received == 'Y'" color="success lighten-1">check_circle</v-icon>
</v-btn>
</v-list-tile-action>
</v-list-tile>
<v-list-tile
avatar
@click="goToSurvey()">
<v-list-tile-avatar>
<v-icon class="purple darken-2 white--text">assignment</v-icon>
</v-list-tile-avatar>
<v-list-tile-content>
<v-list-tile-title>{{ data_survey.sampletype_name }}</v-list-tile-title>
<v-list-tile-sub-title>{{ data_survey.receive_date }} {{ data_survey.receive_time }}</v-list-tile-sub-title>
</v-list-tile-content>
<v-list-tile-action>
<v-btn icon ripple>
<v-icon v-if="data_survey.is_sampling == 'N' || data_survey.is_received == 'N'" color="grey lighten-1">info</v-icon>
<v-icon v-if="data_survey.is_sampling == 'Y' && data_survey.is_received == 'Y'" color="success lighten-1">check_circle</v-icon>
</v-btn>
</v-list-tile-action>
</v-list-tile>
</v-list>
</v-flex>
</v-layout>
</v-container>
</v-card>
<v-card class="mt-1 pt-1 pa-2">
<v-btn block color="primary" @click="openscanner()">
Refresh
</v-btn>
<qr-scanner></qr-scanner>
</v-card>
</div>
</template>
</v-container>
</v-content>
<!--<one-footer> </one-footer>-->
</v-app>
</div>
<!-- Vendor -->
<script src="../../../libs/vendor/html5-qrcode.min.js"></script>
<script src="../../../libs/vendor/moment.min.js"></script>
<script src="../../../libs/vendor/numeral.min.js"></script>
<script src="../../../libs/vendor/moment-locale-id.js"></script>
<script src="../../../libs/vendor/lodash.js"></script>
<script src="../../../libs/vendor/axios.min.js"></script>
<script src="../../../libs/vendor/vue.js"></script>
<script src="../../../libs/vendor/vuex.js"></script>
<script src="../../../libs/vendor/vuetify.js"></script>
<script src="../../../libs/vendor/httpVueLoader.js"></script>
<script src="../../../libs/one_global.js"></script>
<script src="../../../libs/one_print_barcode.js"></script>
<script src="../../../libs/one_print_robo.js"></script>
<!-- App Script -->
<?php
$ts = "?ts=" . Date("ymdhis");
?>
<script type="module">
window.calculate_age = function(inp_dob) {
var now = moment(new Date())
var dob = moment(new Date(inp_dob))
var year = now.diff(dob, 'years')
dob.add(year, 'years')
var month = now.diff(dob, 'months')
dob.add(month, 'months')
var day = now.diff(dob, 'days')
if (isNaN(year)) return ''
return `${year} tahun ${month} bulan ${day} hari`
}
import {
store
} from './store.js<?php echo $ts ?>';
//for testing
window.store = store;
new Vue({
store,
el: '#app',
components: {
'one-navbar': httpVueLoader('../../../apps/components/oneNavbarComponent.vue'),
'one-footer': httpVueLoader('../../../apps/components/oneFooter.vue'),
'one-patient-list': httpVueLoader('./components/onePatientList.vue'),
'qr-scanner': httpVueLoader('./components/oneQRscanner.vue')
},
mounted: function() {
var url_string = window.location.href
var url = new URL(url_string);
var id = url.searchParams.get("id");
var noreg = url.searchParams.get("noreg");
this.$store.commit('patient/update_order_id', id)
this.$store.commit('patient/update_noreg', noreg)
this.$store.dispatch('patient/load_data')
},
methods: {
goToSurvey: function() {
console.log('aloha')
let order_id = this.$store.state.patient.order_id
let noreg = this.$store.state.patient.noreg
window.location = "/one-ui/test/vuex/cpone-control-card-survey/?noreg=" + noreg + "&id=" + order_id
},
openscanner() {
//this.dialog_scanner = true
location.reload()
}
},
computed: {
photo_qr() {
return this.$store.state.patient.photo_qr
},
status_selesai() {
return this.$store.state.patient.status_selesai
},
dialog_scanner: {
get() {
return this.$store.state.patient.dialog_scanner
},
set(val) {
this.$store.commit("patient/update_dialog_scanner", val)
}
},
data_patient() {
return this.$store.state.patient.data_patient
},
data_packet() {
return this.$store.state.patient.data_packet
},
data_tests() {
return this.$store.state.patient.data_tests
},
data_sample_lab() {
return this.$store.state.patient.data_sample_lab
},
data_sample_radiodiagnostic() {
return this.$store.state.patient.data_sample_radiodiagnostic
},
data_sample_electromedic() {
return this.$store.state.patient.data_sample_electromedic
},
data_sample_other() {
return this.$store.state.patient.data_sample_other
},
data_survey() {
return this.$store.state.patient.data_survey
},
},
data() {
return {
items2: [{
icon: 'assignment',
iconClass: 'blue white--text',
title: 'Vacation itinerary',
subtitle: 'Jan 20, 2014'
},
{
icon: 'call_to_action',
iconClass: 'amber white--text',
title: 'Kitchen remodel',
subtitle: 'Jan 10, 2014'
}
],
items: [{
action: 'healing',
title: 'Paket Pria 2024',
items: [{
title: 'List Item'
},
{
title: 'List Item'
},
{
title: 'List Item'
}
]
}]
}
}
})
</script>
<style>
[v-cloak] {
display: none
}
.left {}
.right {}
</style>
</body>
</html>