Merge pull request #423 from shariquerik/files-uploader-fix
This commit is contained in:
commit
482c720ddf
@ -63,10 +63,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div
|
<div v-else-if="title == 'Tasks'" class="px-3 pb-3 sm:px-10 sm:pb-5">
|
||||||
v-else-if="title == 'Tasks'"
|
|
||||||
class="px-3 pb-3 sm:px-10 sm:pb-5 overflow-x-auto sm:w-full w-max"
|
|
||||||
>
|
|
||||||
<TaskArea :modalRef="modalRef" :tasks="activities" :doctype="doctype" />
|
<TaskArea :modalRef="modalRef" :tasks="activities" :doctype="doctype" />
|
||||||
</div>
|
</div>
|
||||||
<div v-else-if="title == 'Calls'" class="activity">
|
<div v-else-if="title == 'Calls'" class="activity">
|
||||||
@ -100,7 +97,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div
|
<div
|
||||||
v-else-if="title == 'Attachments'"
|
v-else-if="title == 'Attachments'"
|
||||||
class="px-3 pb-3 sm:px-10 sm:pb-5 overflow-x-auto sm:w-full w-max"
|
class="px-3 pb-3 sm:px-10 sm:pb-5"
|
||||||
>
|
>
|
||||||
<AttachmentArea
|
<AttachmentArea
|
||||||
:attachments="activities"
|
:attachments="activities"
|
||||||
|
|||||||
@ -5,8 +5,8 @@
|
|||||||
class="activity flex cursor-pointer gap-6 rounded p-2.5 duration-300 ease-in-out hover:bg-gray-50"
|
class="activity flex cursor-pointer gap-6 rounded p-2.5 duration-300 ease-in-out hover:bg-gray-50"
|
||||||
@click="modalRef.showTask(task)"
|
@click="modalRef.showTask(task)"
|
||||||
>
|
>
|
||||||
<div class="flex flex-1 flex-col gap-1.5 text-base">
|
<div class="flex flex-1 flex-col gap-1.5 text-base truncate">
|
||||||
<div class="font-medium text-gray-900">
|
<div class="font-medium text-gray-900 truncate">
|
||||||
{{ task.title }}
|
{{ task.title }}
|
||||||
</div>
|
</div>
|
||||||
<div class="flex gap-1.5 text-gray-800">
|
<div class="flex gap-1.5 text-gray-800">
|
||||||
|
|||||||
@ -28,7 +28,7 @@
|
|||||||
v-if="
|
v-if="
|
||||||
filesUploaderArea?.showWebLink || filesUploaderArea?.showCamera
|
filesUploaderArea?.showWebLink || filesUploaderArea?.showCamera
|
||||||
"
|
"
|
||||||
:label="__('Back to file upload')"
|
:label="isMobileView ? __('Back') : __('Back to file upload')"
|
||||||
@click="
|
@click="
|
||||||
() => {
|
() => {
|
||||||
filesUploaderArea.showWebLink = false
|
filesUploaderArea.showWebLink = false
|
||||||
@ -103,6 +103,7 @@
|
|||||||
<script setup>
|
<script setup>
|
||||||
import FilesUploaderArea from '@/components/FilesUploader/FilesUploaderArea.vue'
|
import FilesUploaderArea from '@/components/FilesUploader/FilesUploaderArea.vue'
|
||||||
import FilesUploadHandler from './filesUploaderHandler'
|
import FilesUploadHandler from './filesUploaderHandler'
|
||||||
|
import { isMobileView } from '@/composables/settings'
|
||||||
import { createToast } from '@/utils'
|
import { createToast } from '@/utils'
|
||||||
import { ref, computed } from 'vue'
|
import { ref, computed } from 'vue'
|
||||||
|
|
||||||
|
|||||||
@ -60,9 +60,9 @@
|
|||||||
<div
|
<div
|
||||||
v-for="file in files"
|
v-for="file in files"
|
||||||
:key="file.name"
|
:key="file.name"
|
||||||
class="flex items-center justify-between py-3"
|
class="flex items-center justify-between gap-2 py-3"
|
||||||
>
|
>
|
||||||
<div class="flex items-center gap-4">
|
<div class="flex items-center gap-4 truncate">
|
||||||
<div
|
<div
|
||||||
class="size-11 rounded overflow-hidden flex-shrink-0 flex justify-center items-center"
|
class="size-11 rounded overflow-hidden flex-shrink-0 flex justify-center items-center"
|
||||||
:class="{ border: !file.type?.startsWith('image') }"
|
:class="{ border: !file.type?.startsWith('image') }"
|
||||||
@ -75,8 +75,8 @@
|
|||||||
/>
|
/>
|
||||||
<component v-else class="size-4" :is="fileIcon(file.type)" />
|
<component v-else class="size-4" :is="fileIcon(file.type)" />
|
||||||
</div>
|
</div>
|
||||||
<div class="flex flex-col gap-1 text-sm text-gray-600">
|
<div class="flex flex-col gap-1 text-sm text-gray-600 truncate">
|
||||||
<div class="text-base text-gray-800">
|
<div class="text-base text-gray-800 truncate">
|
||||||
{{ file.name }}
|
{{ file.name }}
|
||||||
</div>
|
</div>
|
||||||
<div class="mb-1">
|
<div class="mb-1">
|
||||||
@ -201,21 +201,29 @@ function onFileInput(event) {
|
|||||||
|
|
||||||
const video = ref(null)
|
const video = ref(null)
|
||||||
const facingMode = ref('environment')
|
const facingMode = ref('environment')
|
||||||
|
const stream = ref(null)
|
||||||
|
|
||||||
async function startCamera() {
|
async function startCamera() {
|
||||||
showCamera.value = true
|
showCamera.value = true
|
||||||
|
|
||||||
let stream = await navigator.mediaDevices.getUserMedia({
|
stream.value = await navigator.mediaDevices.getUserMedia({
|
||||||
video: {
|
video: {
|
||||||
facingMode: facingMode.value,
|
facingMode: facingMode.value,
|
||||||
},
|
},
|
||||||
audio: false,
|
audio: false,
|
||||||
})
|
})
|
||||||
video.value.srcObject = stream
|
video.value.srcObject = stream.value
|
||||||
|
}
|
||||||
|
|
||||||
|
function stopStream() {
|
||||||
|
stream.value.getTracks().forEach((track) => track.stop())
|
||||||
|
showCamera.value = false
|
||||||
|
cameraImage.value = null
|
||||||
}
|
}
|
||||||
|
|
||||||
function switchCamera() {
|
function switchCamera() {
|
||||||
facingMode.value = facingMode.value === 'environment' ? 'user' : 'environment'
|
facingMode.value = facingMode.value === 'environment' ? 'user' : 'environment'
|
||||||
|
stopStream()
|
||||||
startCamera()
|
startCamera()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user