ui Linkage Center

This commit is contained in:
DESKTOP-1R2VSQH\Lenovo ThinkPad E490 2024-10-01 16:39:25 +07:00
parent efad04ba6f
commit ef0295d882
2 changed files with 206 additions and 1 deletions

View file

@ -0,0 +1,190 @@
<script setup lang="ts">
import { ref } from "vue";
import DialogHeader from "./DialogHeader.vue";
const modal = defineModel<boolean>("modal", { required: true });
const step = ref<number>(1);
const devices = ref<string>("");
const devicesData = ref<string[]>([
"Generic",
"EMV",
"Smartcard",
"Reader",
"0",
]);
const devicesOp = ref<string[]>([]);
/** 1.เสียบบัตรประชาชนเข้ากับเครื่องอ่าน*/
function fetchDeviceLists() {
step.value++;
}
/** 2.เลือกเครื่องอ่านบัตร*/
function readDevice() {
step.value++;
}
function verifyPin() {
step.value++;
}
/**
* function นหาขอมลของ Option
* @param val าทองการฟลเตอร
* @param update พเดทค
*/
function filterOption(val: string, update: Function) {
update(() => {
const newVal = val.toLocaleUpperCase();
devicesOp.value = devicesData.value.filter(
(v: string) => v.toLocaleUpperCase().indexOf(newVal) > -1
);
});
}
function onClose() {
modal.value = false;
step.value = 1;
devices.value = "";
}
</script>
<template>
<q-dialog v-model="modal" persistent>
<q-card style="width: 700px; max-width: 80vw">
<DialogHeader :tittle="'เข้าสู่ระบบ Linkage Center'" :close="onClose" />
<q-separator />
<q-card-section>
<q-card flat bordered>
<q-card-section>
<div
class="row"
style="
display: flex;
flex-direction: column;
align-items: flex-end;
"
>
<div class="text-red">
*องใชบน Windows และตองตดต Agent
</div>
<div>
<a
href="https://linkagemgmt.bora.dopa.go.th/app/LinkageManagement-v1.11.0.zip"
>งกดาวนโหลด Agent</a
>
</div>
</div>
<q-timeline color="primary">
<!-- เสยบบตรประชาชนเขากบเครองอาน -->
<q-timeline-entry
title="เสียบบัตรประชาชนเข้ากับเครื่องอ่าน"
:icon="
step === 1
? 'mdi-pencil'
: step > 1
? 'done'
: 'mdi-numeric-1'
"
>
<div class="row" v-if="step === 1">
<q-btn
color="primary"
label="ดำเนินการต่อ"
@click="fetchDeviceLists"
/>
</div>
</q-timeline-entry>
<!-- เลอกเครองอานบตร -->
<q-timeline-entry
title="เลือกเครื่องอ่านบัตร"
:icon="
step === 2
? 'mdi-pencil'
: step > 2
? 'done'
: 'mdi-numeric-2'
"
:color="step < 2 ? 'grey-4' : ''"
>
<div class="row" v-if="step === 2">
<q-form
greedy
@submit.prevent
@validation-success="readDevice"
>
<div class="q-col-gutter-sm">
<div>
<q-select
dense
v-model="devices"
label="เลือกเครื่องอ่านบัตร"
outlined
emit-value
map-options
fill-input
hide-selected
lazy-rules
hide-bottom-space
option-label="name"
option-value="id"
class="inputgreen"
:options="devicesOp"
use-input
:rules="[(val:string) => !!val || `${'กรุณาเลือกเลือกเครื่องอ่านบัตร'}`,]"
@filter="(inputValue:string,doneFn:Function) => filterOption(inputValue, doneFn) "
>
<template v-slot:no-option>
<q-item>
<q-item-section class="text-grey">
ไมอม
</q-item-section>
</q-item>
</template>
</q-select>
</div>
<div>
<q-btn
color="primary"
label="ดำเนินการต่อ"
type="submit"
/>
</div></div
></q-form>
</div>
</q-timeline-entry>
<!-- เชอมตอและใส PIN -->
<q-timeline-entry
title="เชื่อมต่อและใส่ PIN"
:icon="
step === 3
? 'mdi-pencil'
: step > 3
? 'done'
: 'mdi-numeric-3'
"
:color="step < 3 ? 'grey-4' : ''"
>
<div class="row" v-if="step === 3">
<q-btn
color="primary"
label="ดำเนินการต่อ"
@click="verifyPin"
/>
</div>
</q-timeline-entry>
</q-timeline>
</q-card-section>
</q-card>
</q-card-section>
</q-card>
</q-dialog>
</template>
<style lang="sass" scoped></style>

View file

@ -19,6 +19,8 @@ import type {
import { tabList, tabListPlacement } from "../interface/request/main/main";
import { useroleUserDataStore } from "@/stores/roleUser";
import LoginLinkage from "@/components/LoginLinkage.vue";
const { setVerticalScrollPosition, getVerticalScrollPosition } = scroll;
const store = useDataStore();
const route = useRoute();
@ -74,6 +76,7 @@ const options = ref<optionType[]>([
color: "indigo",
},
]);
const modalLoginLinkage = ref<boolean>(false); // Linkage Center
async function fetchmsgNoread() {
await http
@ -701,6 +704,16 @@ async function fetchPermissionsSys() {
{{ fullname }}
</div>
<div id="#logout">
<q-btn
color="blue"
label="เข้าสู่ระบบ Linkage Center"
push
size="sm"
v-close-popup
@click="modalLoginLinkage = true"
/>
</div>
<div id="#logout" class="q-mt-sm">
<q-btn
color="primary"
label="ออกจากระบบ"
@ -708,7 +721,7 @@ async function fetchPermissionsSys() {
size="sm"
v-close-popup
@click="doLogout"
/><!-- -->
/>
</div>
</div>
@ -1137,6 +1150,8 @@ async function fetchPermissionsSys() {
</q-page-container>
<full-loader :visibility="loader" />
</q-layout>
<LoginLinkage v-model:modal="modalLoginLinkage" />
</template>
<style>