downlad แบบใบขอลา

This commit is contained in:
DESKTOP-1R2VSQH\Lenovo ThinkPad E490 2023-12-14 15:21:35 +07:00
parent 7dec131485
commit f7d5cbd899
4 changed files with 103 additions and 9 deletions

View file

@ -4,6 +4,7 @@ import { useRoute, useRouter } from "vue-router";
import { useQuasar } from "quasar";
import http from "@/plugins/http";
import config from "@/app.config";
import genReport from "@/plugins/genreport";
/** importStore */
import { useCounterMixin } from "@/stores/mixin";
@ -194,7 +195,9 @@ async function fetchDetailLeave(paramsId: string) {
formData.leavegovernmentDate =
data.leaveGovernmentDate && date2Thai(data.leaveGovernmentDate);
formData.leaveSalary = data.leaveSalary ? data.leaveSalary : "-";
formData.leaveSalaryText = data.leaveSalaryText ? data.leaveSalaryText : "-";
formData.leaveSalaryText = data.leaveSalaryText
? data.leaveSalaryText
: "-";
formData.leaveTypeDay =
data.leaveTypeDay && stores.convertLeaveDaytype(data.leaveTypeDay);
formData.wifeDayName = data.wifeDayName ? data.wifeDayName : "-";
@ -347,7 +350,7 @@ function checkLeaveType(leaveTypeId: string, leaveTypeName: string) {
}
/** Function dialog*/
const openModal = async (data: string) => {
async function openModal(data: string) {
if (data === "approve") {
modalApprove.value = true;
dialogTitle.value = "อนุมัติ";
@ -361,7 +364,7 @@ const openModal = async (data: string) => {
dialogTitle.value = "ส่งไปยังผู้มีอำนาจ";
dialogLabel.value = "ความคิดเห็น";
}
};
}
/** function ส่งไปผู้บังคับบัญชา*/
function sendToCommand() {
@ -458,6 +461,23 @@ function clickSave(reason: string) {
);
}
}
async function onClickDownloadFile(id: string, fileName: string) {
showLoader();
await http
.get(config.API.leaveReport(id))
.then(async (res) => {
console.log(res);
const data = res.data.result;
await genReport(data, fileName);
})
.catch((err) => {
messageError($q, err);
})
.finally(() => {
hideLoader();
});
}
</script>
<template>
<div class="toptitle text-dark col-12 row items-center">
@ -484,6 +504,7 @@ function clickSave(reason: string) {
flat
color="primary"
class="q-mr-sm"
@click="onClickDownloadFile(formData.id, formData.leaveTypeName)"
><q-tooltip>ดาวนโหลดไฟล</q-tooltip></q-btn
>
</div>
@ -502,7 +523,7 @@ function clickSave(reason: string) {
<q-icon name="attach_file" color="primary" />
</template>
</q-file> -->
<q-btn
<!-- <q-btn
v-if="filesUpload"
flat
round
@ -510,7 +531,7 @@ function clickSave(reason: string) {
icon="mdi-arrow-up-bold"
@click="upLoadFile"
><q-tooltip>ปโหลด</q-tooltip></q-btn
>
> -->
</div>
</div>
<q-card flat bordered class="col-12 q-mt-sm">

View file

@ -4,13 +4,12 @@ import { useRoute, useRouter } from "vue-router";
import { useQuasar } from "quasar";
import http from "@/plugins/http";
import config from "@/app.config";
import genReport from "@/plugins/genreport";
/** importStore */
import { useCounterMixin } from "@/stores/mixin";
import { useLeavelistDataStore } from "@/modules/09_leave/stores/LeaveStore";
import { useLeavelistDataStoreTest } from "@/modules/09_leave/stores/ListLeave";
import DialogReason from "@/components/Dialogs/PopupReason.vue";
const APIDATA = useLeavelistDataStoreTest();
/** importType */
import type {
@ -370,6 +369,23 @@ function clickSave() {
console.log("NOT");
}
}
async function onClickDownloadFile(id: string, fileName: string) {
showLoader();
await http
.get(config.API.leaveReportReject(id))
.then(async (res) => {
console.log(res);
const data = res.data.result;
await genReport(data, fileName);
})
.catch((err) => {
messageError($q, err);
})
.finally(() => {
hideLoader();
});
}
</script>
<template>
<div class="toptitle text-dark col-12 row items-center">
@ -387,7 +403,7 @@ function clickSave() {
/>
รายละเอยดการขอยกเลกของ {{ formData.fullName }}
</div>
<!-- <div>
<div>
<q-btn
icon="mdi-download"
unelevated
@ -396,9 +412,10 @@ function clickSave() {
flat
color="primary"
class="q-mr-sm"
@click="onClickDownloadFile(formData.id, formData.leaveTypeName)"
><q-tooltip>ดาวนโหลดไฟล</q-tooltip></q-btn
>
</div> -->
</div>
<q-space />
<!-- <q-file
v-model="filesUpload"