Files
qris_bank_jatim/pages/Home.vue
2025-09-08 15:07:49 +07:00

776 lines
19 KiB
Vue

<template>
<div class="medical-payment-app">
<!-- Header -->
<v-container fluid class="pa-4">
<v-row justify="center" class="mb-6">
<v-col cols="12" md="8" lg="6">
<div class="text-center mb-4">
<div class="d-flex justify-center align-center flex-wrap mb-4">
<!-- Logos -->
<v-img
src="/api/placeholder/80/80"
width="80"
height="80"
class="ma-2"
contain
/>
<v-img
src="/api/placeholder/80/80"
width="80"
height="80"
class="ma-2"
contain
/>
<v-img
src="/api/placeholder/80/80"
width="80"
height="80"
class="ma-2"
contain
/>
<v-img
src="/api/placeholder/80/80"
width="80"
height="80"
class="ma-2"
contain
/>
</div>
<h1 class="display-1 mb-2">
<span class="text-orange">With Love </span>
<span class="text-dark">We Serve</span>
</h1>
<p class="subtitle-1 text-grey-darken-1">
Kami Menyediakan Layanan Medis yang Dapat Anda Percayai
</p>
</div>
</v-col>
</v-row>
</v-container>
<!-- Main Content -->
<v-container>
<v-row justify="center">
<v-col cols="12" md="6" lg="7">
<v-card class="payment-card mx-auto" rounded="xl">
<!-- Step 1: Contact Info -->
<div v-if="paymentStore.currentStep === 1">
<v-card-text class="pa-4">
<div class="mb-6">
<v-img
src="https://scontent.fcgk22-2.fna.fbcdn.net/v/t39.30808-6/481267190_3904366386504845_1409667601717073976_n.jpg?stp=dst-jpg_s960x960_tt6&_nc_cat=110&ccb=1-7&_nc_sid=cc71e4&_nc_ohc=1EijOtXRjUEQ7kNvwFf8ZY7&_nc_oc=Admd26Jbw1IeEOyHFjj4HiDEMtDA_PY83qxRWoy8hhdrfYe9yO6ZPv7pI4XJ79Vlb-I&_nc_zt=23&_nc_ht=scontent.fcgk22-2.fna&_nc_gid=tx2ZuC16d1ipgxGzCJ4SRw&oh=00_Afan6b2RW5WBSa9azzYS_sdYc781iAwqKv4dJjsC9MvAxw&oe=68C42CD8"
height="200"
class="rounded-lg"
cover
/>
</div>
<h2 class="text-h5 mb-6 text-center font-weight-bold">Hubungi Kami</h2>
<v-row>
<v-col cols="12" sm="6">
<v-btn
block
size="large"
color="orange"
variant="flat"
rounded="xl"
class="mb-4 text-no-wrap"
prepend-icon="mdi-whatsapp"
>
+62 815-5560-6668
</v-btn>
</v-col>
<v-col cols="12" sm="6">
<v-btn
block
size="large"
color="orange"
variant="flat"
rounded="xl"
class="mb-4 text-no-wrap"
prepend-icon="mdi-phone"
>
0341-362101
</v-btn>
</v-col>
<v-col cols="12">
<v-btn
block
size="large"
color="orange"
variant="flat"
rounded="xl"
class="mb-4 text-no-wrap"
prepend-icon="mdi-instagram"
>
rssaifulanwar
</v-btn>
</v-col>
<v-col cols="12">
<v-btn
block
size="large"
color="orange"
variant="flat"
rounded="xl"
class="mb-4 text-no-wrap"
prepend-icon="mdi-web"
>
rsusaifulanwar.jatimprov.go.id
</v-btn>
</v-col>
</v-row>
<div class="text-center mt-6">
<v-btn
color="primary"
size="large"
variant="flat"
rounded="xl"
@click="paymentStore.nextStep"
>
Lanjut ke Pembayaran
</v-btn>
</div>
</v-card-text>
</div>
<!-- Step 2: QR Code Payment -->
<div v-else-if="paymentStore.currentStep === 2">
<v-card-text class="pa-8 text-center">
<div class="mb-4">
<v-img
src="/api/placeholder/60/30"
width="60"
height="30"
class="mx-auto mb-2"
contain
/>
<v-img
src="/api/placeholder/100/30"
width="100"
height="30"
class="mx-auto"
contain
/>
</div>
<h2 class="text-h4 mb-6 font-weight-bold">PINDAI KODE QR</h2>
<!-- QR Code -->
<div class="qr-container mb-6">
<v-card
class="qr-code mx-auto"
width="280"
height="280"
elevation="0"
>
<div class="qr-pattern">
<!-- Simplified QR pattern -->
<svg viewBox="0 0 280 280" class="qr-svg">
<!-- Corner markers -->
<rect
x="10"
y="10"
width="60"
height="60"
fill="black"
/>
<rect
x="20"
y="20"
width="40"
height="40"
fill="white"
/>
<rect
x="30"
y="30"
width="20"
height="20"
fill="black"
/>
<rect
x="210"
y="10"
width="60"
height="60"
fill="black"
/>
<rect
x="220"
y="20"
width="40"
height="40"
fill="white"
/>
<rect
x="230"
y="30"
width="20"
height="20"
fill="black"
/>
<rect
x="10"
y="210"
width="60"
height="60"
fill="black"
/>
<rect
x="20"
y="220"
width="40"
height="40"
fill="white"
/>
<rect
x="30"
y="230"
width="20"
height="20"
fill="black"
/>
<!-- Random data pattern -->
<g class="data-pattern">
<rect
x="90"
y="90"
width="10"
height="10"
fill="black"
/>
<rect
x="110"
y="90"
width="10"
height="10"
fill="black"
/>
<rect
x="130"
y="90"
width="10"
height="10"
fill="black"
/>
<rect
x="90"
y="110"
width="10"
height="10"
fill="black"
/>
<rect
x="130"
y="110"
width="10"
height="10"
fill="black"
/>
<rect
x="150"
y="110"
width="10"
height="10"
fill="black"
/>
<rect
x="170"
y="110"
width="10"
height="10"
fill="black"
/>
<rect
x="90"
y="130"
width="10"
height="10"
fill="black"
/>
<rect
x="110"
y="130"
width="10"
height="10"
fill="black"
/>
<rect
x="150"
y="130"
width="10"
height="10"
fill="black"
/>
</g>
</svg>
</div>
<div class="qr-label">
<small class="text-grey-darken-1">QRIS</small>
</div>
</v-card>
</div>
<!-- Payment Details -->
<div class="payment-details">
<v-row dense class="mb-2">
<v-col cols="5" class="text-left">
<strong>NAMA PASIEN:</strong>
</v-col>
<v-col cols="7" class="text-left">
{{ paymentStore.patientInfo.name }}
</v-col>
</v-row>
<v-row dense class="mb-2">
<v-col cols="5" class="text-left">
<strong>NOMINAL:</strong>
</v-col>
<v-col cols="7" class="text-left">
{{ paymentStore.patientInfo.amount }}
</v-col>
</v-row>
<v-row dense class="mb-4">
<v-col cols="5" class="text-left">
<strong>BERLAKU SAMPAI:</strong>
</v-col>
<v-col cols="7" class="text-left text-red">
{{ paymentStore.patientInfo.expiry }}
</v-col>
</v-row>
</div>
<div class="d-flex gap-2 justify-center">
<v-btn
color="grey"
variant="outlined"
@click="paymentStore.prevStep"
>
Kembali
</v-btn>
<v-btn
color="primary"
variant="flat"
@click="paymentStore.nextStep"
>
Simulasi Pembayaran
</v-btn>
</div>
</v-card-text>
</div>
<!-- Step 3: Success -->
<div v-else-if="paymentStore.currentStep === 3">
<v-card-text class="pa-8 text-center">
<div class="success-container">
<v-icon
icon="mdi-check-circle"
size="80"
color="orange"
class="mb-4"
/>
<h2 class="text-h4 mb-4 font-weight-bold">
Pembayaran Berhasil
</h2>
<p class="text-h6 text-grey-darken-1 mb-6">
Silahkan Menunggu Bukti<br />Pembayaran
</p>
<v-btn
color="primary"
size="large"
variant="flat"
rounded="xl"
@click="paymentStore.reset"
>
Kembali ke Awal
</v-btn>
</div>
</v-card-text>
</div>
</v-card>
</v-col>
</v-row>
</v-container>
</div>
</template>
<script setup>
import { usePaymentStore } from "~/stores/payment";
const paymentStore = usePaymentStore();
// Auto advance simulation
onMounted(() => {
// Simulate QR code scanning after 10 seconds on QR step
const autoAdvance = () => {
if (paymentStore.currentStep === 2) {
setTimeout(() => {
if (paymentStore.currentStep === 2) {
paymentStore.nextStep();
}
}, 10000);
}
};
watch(() => paymentStore.currentStep, autoAdvance, { immediate: true });
});
</script>
<style scoped>
.medical-payment-app {
min-height: 100vh;
background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
}
/* Step 1 - Modern Landing Page Styles */
.main-content {
min-height: 100vh;
display: flex;
flex-direction: column;
}
.content-wrapper {
flex: 1;
display: flex;
flex-direction: column;
justify-content: center;
padding: 2rem 1rem;
}
.header-section {
position: absolute;
top: 0;
left: 0;
right: 0;
padding: 1rem;
background: rgba(255, 255, 255, 0.9);
backdrop-filter: blur(10px);
border-bottom: 1px solid rgba(0, 0, 0, 0.1);
z-index: 10;
}
.logo-container {
display: flex;
justify-content: center;
align-items: center;
gap: 2rem;
flex-wrap: wrap;
}
.logo-item {
transition: transform 0.3s ease;
}
.logo-item:hover {
transform: scale(1.1);
}
.hero-section {
text-align: center;
max-width: 900px;
margin: 0 auto;
padding-top: 100px;
}
.hero-title {
font-size: clamp(2rem, 5vw, 3.5rem);
font-weight: 700;
margin-bottom: 1rem;
line-height: 1.2;
}
.hero-subtitle {
font-size: clamp(1rem, 2vw, 1.25rem);
color: #64748b;
margin-bottom: 3rem;
font-weight: 400;
}
.media-banner {
margin-bottom: 3rem;
}
.banner-card {
background: white;
overflow: hidden;
}
.banner-content {
padding: 1rem;
}
.banner-image {
position: relative;
border-radius: 12px;
overflow: hidden;
}
.banner-overlay {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: linear-gradient(
135deg,
rgba(255, 152, 0, 0.8) 0%,
rgba(255, 193, 7, 0.8) 100%
);
display: flex;
align-items: center;
justify-content: center;
}
.overlay-content {
text-align: center;
padding: 2rem;
}
.info-cards {
margin-top: 1.5rem;
}
.info-card {
transition: all 0.3s ease;
height: 100%;
}
.info-card:hover {
transform: translateY(-4px);
box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
}
.cta-section {
margin-bottom: 2rem;
}
.cta-button {
padding: 1rem 3rem;
font-size: 1.1rem;
font-weight: 600;
letter-spacing: 0.5px;
transition: all 0.3s ease;
background: linear-gradient(135deg, #ff9800 0%, #ff5722 100%);
}
.cta-button:hover {
transform: translateY(-2px);
box-shadow: 0 12px 30px rgba(255, 152, 0, 0.4);
}
.footer-section {
background: white;
border-top: 1px solid #e2e8f0;
padding: 2rem 0;
margin-top: auto;
}
.contact-footer {
text-align: center;
}
.contact-title {
font-size: 1.5rem;
font-weight: 600;
color: #1e293b;
margin-bottom: 2rem;
}
.contact-card {
transition: all 0.3s ease;
border: 2px solid transparent;
height: 100%;
min-height: 100px;
}
.contact-card .v-card-text {
padding: 12px 8px !important;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
height: 100%;
}
.contact-card:hover {
border-color: #ff9800;
transform: translateY(-4px);
box-shadow: 0 8px 25px rgba(255, 152, 0, 0.2);
}
/* Step 2 & 3 - Payment and Success Styles */
.payment-card {
background: white;
box-shadow: 0 20px 60px rgba(0, 0, 0, 0.1);
}
.qr-container {
padding: 20px;
background: white;
border-radius: 16px;
display: inline-block;
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}
.qr-code {
position: relative;
background: white;
padding: 20px;
}
.qr-svg {
width: 100%;
height: 100%;
}
.qr-label {
position: absolute;
bottom: 5px;
right: 10px;
font-size: 10px;
font-weight: bold;
}
.payment-details {
max-width: 350px;
margin: 0 auto;
}
.success-container {
padding: 40px 20px;
}
.text-orange {
color: #ff9800 !important;
}
.text-dark {
color: #424242 !important;
}
/* Tablet Landscape Optimizations */
@media (orientation: landscape) and (min-width: 768px) {
.medical-payment-app {
height: 100vh;
overflow-y: auto;
}
.content-wrapper {
padding: 1rem;
justify-content: flex-start;
}
.hero-section {
padding-top: 80px;
}
.hero-title {
font-size: 2.5rem;
margin-bottom: 0.75rem;
}
.hero-subtitle {
font-size: 1rem;
margin-bottom: 2rem;
}
.media-banner {
margin-bottom: 2rem;
}
.banner-content .v-img {
height: 220px !important;
}
.footer-section {
padding: 1.5rem 0;
}
.contact-title {
font-size: 1.25rem;
margin-bottom: 1.5rem;
}
.logo-container {
gap: 1.5rem;
}
.logo-item .v-img {
width: 50px !important;
height: 50px !important;
}
/* Smaller QR code for landscape */
.qr-code {
width: 240px !important;
height: 240px !important;
}
.payment-card {
max-width: flex;
}
}
/* Small tablet adjustments */
@media (max-width: 900px) and (orientation: landscape) {
.hero-title {
font-size: 2rem;
}
.banner-content .v-img {
height: 180px !important;
}
.info-cards .v-col {
padding: 4px;
}
.contact-footer .v-col {
margin-bottom: 8px;
}
}
/* Very small tablet landscape */
@media (max-width: 768px) and (orientation: landscape) {
.hero-section {
padding-top: 60px;
}
.logo-container {
gap: 1rem;
}
.logo-item .v-img {
width: 40px !important;
height: 40px !important;
}
.banner-content .v-img {
height: 150px !important;
}
.hero-title {
font-size: 1.75rem;
}
.contact-footer .v-row .v-col {
flex: 0 0 50%;
max-width: 50%;
}
}
</style>