fix:privacy

This commit is contained in:
DESKTOP-1R2VSQH\Lenovo ThinkPad E490 2026-01-19 14:47:32 +07:00
parent 9793df1c57
commit 8b26530d52
6 changed files with 120 additions and 12 deletions

View file

@ -4,9 +4,11 @@ import { loadModules } from 'esri-loader'
import axios from 'axios'
import { useCounterMixin } from '@/stores/mixin'
import { useQuasar } from 'quasar'
import { usePrivacyStore } from '@/stores/privacy'
const mixin = useCounterMixin()
const { messageError } = mixin
const privacyStore = usePrivacyStore()
// import type { LocationObject } from '@/interface/index/Main'
const mapElement = ref<HTMLElement | null>(null)
@ -200,6 +202,16 @@ async function initializeMap() {
const locationGranted = ref(false)
// Function to request location permission
const requestLocationPermission = () => {
// privacy
if (!privacyStore.isAccepted) {
$q.notify({
type: 'warning',
message: 'กรุณายอมรับนโยบายคุ้มครองข้อมูลส่วนบุคคลก่อนใช้งานแผนที่',
position: 'top',
})
return
}
if (!navigator.geolocation) {
messageError(
$q,
@ -261,7 +273,10 @@ defineExpose({
})
onMounted(async () => {
await initializeMap()
// privacy
if (privacyStore.isAccepted) {
await initializeMap()
}
})
</script>

View file

@ -1,7 +1,12 @@
<script setup lang="ts">
import { ref, computed } from 'vue'
import { useQuasar } from 'quasar'
import http from '@/plugins/http'
import config from '@/app.config'
import { usePrivacyStore } from '@/stores/privacy'
const $q = useQuasar()
const privacyStore = usePrivacyStore()
const modal = defineModel<boolean>('modal', {
required: true,
@ -70,13 +75,11 @@ const handleAccept = async () => {
system: 'checkin',
accept: true,
})
privacyStore.setAccepted(true)
modal.value = false
} catch (error) {}
}
const handleDecline = () => {
modal.value = false
}
const toggleDetails = () => {
showDetails.value = !showDetails.value
}
@ -103,7 +106,6 @@ const toggleDetails = () => {
dense
class="absolute-top-right q-ma-sm"
v-close-popup
@click="handleDecline"
/>
</q-card-section>
@ -237,7 +239,6 @@ const toggleDetails = () => {
unelevated
no-caps
class="action-btn"
@click="handleDecline"
v-close-popup
/>
</q-card-actions>

View file

@ -0,0 +1,51 @@
import { useQuasar } from 'quasar'
import { usePrivacyStore } from '@/stores/privacy'
export function usePermissions() {
const $q = useQuasar()
const privacyStore = usePrivacyStore()
const checkCameraPermission = (): boolean => {
if (!privacyStore.isAccepted) {
privacyStore.modalPrivacy = true
$q.notify({
type: 'warning',
message: 'กรุณายอมรับนโยบายคุ้มครองข้อมูลส่วนบุคคลก่อนใช้งานกล้อง',
position: 'top',
})
return false
}
return true
}
const checkLocationPermission = (): boolean => {
if (!privacyStore.isAccepted) {
privacyStore.modalPrivacy = true
$q.notify({
type: 'warning',
message: 'กรุณายอมรับนโยบายคุ้มครองข้อมูลส่วนบุคคลก่อนใช้งานแผนที่',
position: 'top',
})
return false
}
return true
}
const checkPrivacyAccepted = (): boolean => {
if (!privacyStore.isAccepted) {
$q.notify({
type: 'warning',
message: 'กรุณายอมรับนโยบายคุ้มครองข้อมูลส่วนบุคคลก่อนใช้งาน',
position: 'top',
})
return false
}
return true
}
return {
checkCameraPermission,
checkLocationPermission,
checkPrivacyAccepted,
}
}

22
src/stores/privacy.ts Normal file
View file

@ -0,0 +1,22 @@
import { defineStore } from 'pinia'
import { ref } from 'vue'
export const usePrivacyStore = defineStore('privacy', () => {
const modalPrivacy = ref<boolean>(false)
const isAccepted = ref<boolean>(false)
const setAccepted = (value: boolean) => {
isAccepted.value = value
}
const reset = () => {
isAccepted.value = false
}
return {
modalPrivacy,
isAccepted,
setAccepted,
reset,
}
})

View file

@ -7,6 +7,8 @@ import Camera from 'simple-vue-camera'
import config from '@/app.config'
import http from '@/plugins/http'
import { useCounterMixin } from '@/stores/mixin'
import { usePermissions } from '@/composables/usePermissions'
import { usePrivacyStore } from '@/stores/privacy'
import type { FormRef, OptionReason } from '@/interface/response/checkin'
@ -15,6 +17,8 @@ import MapCheck from '@/components/AscGISMap.vue'
const mixin = useCounterMixin()
const { date2Thai, showLoader, hideLoader, messageError, dialogConfirm } = mixin
const $q = useQuasar()
const { checkCameraPermission, checkLocationPermission } = usePermissions()
const privacyStore = usePrivacyStore()
const modalTime = ref<boolean>(false) // Dailog
const checkStatus = ref<string>('')
@ -261,6 +265,12 @@ async function stopChecking() {
/** function เปิดกล้อง*/
async function openCamera() {
// privacy
if (!checkCameraPermission()) {
return
}
// change camera device
if (cameraIsOn.value) {
await camera.value?.stop()
@ -336,6 +346,11 @@ const timeChickin = ref<string>('') //เวลาเข้างาน,เว
/** function ยืนยันการลงเวลาเข้า - ออก*/
async function confirm() {
// privacy
if (!checkLocationPermission() || !checkCameraPermission()) {
return
}
if (!formLocation.POI || !formLocation.lat || !formLocation.lng) {
mapRef.value?.requestLocationPermission()
return
@ -473,7 +488,11 @@ onMounted(async () => {
isLoadingCheckTime.value = true
updateClock()
startChecking() // status #1
mapRef.value?.requestLocationPermission()
// privacy
if (privacyStore.isAccepted) {
mapRef.value?.requestLocationPermission()
}
})
</script>

View file

@ -8,6 +8,7 @@ import config from '@/app.config'
import avatar from '@/assets/avatar_user.jpg'
import { logout, tokenParsed, getCookie } from '@/plugins/auth'
import { useCounterMixin } from '@/stores/mixin'
import { usePrivacyStore } from '@/stores/privacy'
import type { notiType } from '@/interface/index/Main'
import type { Noti } from '@/interface/response/Main'
@ -16,6 +17,7 @@ import DialogHeader from '@/components/DialogHeader.vue'
import PopupPrivacy from '@/components/PopupPrivacy.vue'
const mixin = useCounterMixin()
const privacyStore = usePrivacyStore()
const {
date2Thai,
hideLoader,
@ -56,8 +58,6 @@ const isPwdOld = ref<boolean>(true)
const isPwdNewOld = ref<boolean>(true)
const isPwdReNewOld = ref<boolean>(true)
const modalPrivacy = ref<boolean>(false)
/**
* งกนดงขอมลจำนวนการแจงเตอน
*/
@ -173,7 +173,7 @@ async function fetchKeycloakPosition() {
.get(config.API.keycloakPosition())
.then(async (res) => {
const data = await res.data.result
modalPrivacy.value = !data.privacyCheckin ? true : false
privacyStore.modalPrivacy = !data.privacyCheckin ? true : false
//
if (data.avatarName) {
await getImg(data.profileId, data.avatarName)
@ -606,7 +606,7 @@ onMounted(async () => {
</q-card>
</q-dialog>
<popup-privacy v-model:modal="modalPrivacy" />
<popup-privacy v-model:modal="privacyStore.modalPrivacy" />
</template>
<style>