feat(ticket_boxing): add section
gitea/salix-front/pipeline/head This commit looks good
Details
gitea/salix-front/pipeline/head This commit looks good
Details
This commit is contained in:
parent
22b5d06fca
commit
7f42655b1d
|
@ -61,7 +61,9 @@ export default {
|
||||||
expedition: 'Expedition',
|
expedition: 'Expedition',
|
||||||
item: 'Item',
|
item: 'Item',
|
||||||
created: 'Created',
|
created: 'Created',
|
||||||
worker: 'Worker'
|
worker: 'Worker',
|
||||||
|
selectTime: 'Select time:',
|
||||||
|
selectVideo: 'Select video:'
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
components: {
|
components: {
|
||||||
|
|
|
@ -61,7 +61,9 @@ export default {
|
||||||
expedition: 'Expedición',
|
expedition: 'Expedición',
|
||||||
item: 'Artículo',
|
item: 'Artículo',
|
||||||
created: 'Creado',
|
created: 'Creado',
|
||||||
worker: 'Trabajador'
|
worker: 'Trabajador',
|
||||||
|
selectTime: 'Seleccionar hora:',
|
||||||
|
selectVideo: 'Seleccionar video:'
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
components: {
|
components: {
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<script setup>
|
<script setup>
|
||||||
import { ref } from 'vue';
|
import { ref } from 'vue';
|
||||||
import { useState } from 'src/composables/useState';
|
import { useState } from 'src/composables/useState';
|
||||||
import LeftMenu from 'src/components/LeftMenu.vue';
|
//import LeftMenu from 'src/components/LeftMenu.vue';
|
||||||
|
|
||||||
const state = useState();
|
const state = useState();
|
||||||
const miniState = ref(true);
|
const miniState = ref(true);
|
||||||
|
|
|
@ -17,8 +17,13 @@ const entityId = computed(function () {
|
||||||
});
|
});
|
||||||
|
|
||||||
const expeditions = ref({});
|
const expeditions = ref({});
|
||||||
const url = ref({});
|
const lastExpedition = ref();
|
||||||
//const video = ref({});
|
const slide = ref(null);
|
||||||
|
const videoList = ref([]);
|
||||||
|
const time = ref({
|
||||||
|
min: 0,
|
||||||
|
max: 24,
|
||||||
|
});
|
||||||
|
|
||||||
async function fetch() {
|
async function fetch() {
|
||||||
const filter = {
|
const filter = {
|
||||||
|
@ -26,84 +31,126 @@ async function fetch() {
|
||||||
ticketFk: entityId.value,
|
ticketFk: entityId.value,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
const { data } = await axios.get(`/api/Expeditions/filter`, {
|
const { data } = await axios.get(`/Expeditions/filter`, {
|
||||||
params: { filter },
|
params: { filter },
|
||||||
});
|
});
|
||||||
|
|
||||||
if (data) expeditions.value = data;
|
if (data) expeditions.value = data;
|
||||||
console.log(expeditions.value);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async function selectVideo(expeditionId) {
|
async function getVideoList(expeditionId, timed) {
|
||||||
url.value = `${window.location.origin}/api/Boxings/getVideo?id=${expeditionId}`;
|
console.log('entry');
|
||||||
}
|
lastExpedition.value = expeditionId;
|
||||||
|
const params = {
|
||||||
|
id: expeditionId,
|
||||||
|
};
|
||||||
|
|
||||||
/*async function getVideo(expeditionId) {
|
if (timed) {
|
||||||
const { data } = await axios.get(`/api/Boxings/getVideo?id=${expeditionId}`);
|
Object.assign(params, { from: timed.min, to: timed.max });
|
||||||
const myUrl = window.URL.createObjectURL(new Blob([data]));
|
}
|
||||||
console.log(myUrl);
|
const { data } = await axios.get(`/Boxings/getVideoList`, { params: params });
|
||||||
if (data) url.value = data;
|
const list = [];
|
||||||
}*/
|
|
||||||
|
for (const video of data) {
|
||||||
|
const videName = video.split('.')[0].split('T')[1].replaceAll('-', ':');
|
||||||
|
list.push({
|
||||||
|
label: videName,
|
||||||
|
value: video,
|
||||||
|
url: `api/Boxings/getVideo?id=${expeditionId}&filename=${video}`,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log(list);
|
||||||
|
videoList.value = list.reverse();
|
||||||
|
if (list[0]) {
|
||||||
|
slide.value = list[0].value;
|
||||||
|
console.log({ min: list[0].label.split(':')[0], max: list[list.length - 1].label.split(':')[0] });
|
||||||
|
time.value = {
|
||||||
|
min: parseInt(list[0].label.split(':')[0]),
|
||||||
|
max: parseInt(list[list.length - 1].label.split(':')[0]),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
console.log('slide', slide);
|
||||||
|
console.log('videoList', videoList);
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<q-layout view="hHh Lpr lff" container class="shadow-2 rounded-borders q-gutter-md">
|
<q-layout view="hhh lpr ffr" class="fit">
|
||||||
<q-drawer
|
<q-drawer show-if-above side="right" bordered>
|
||||||
v-model="drawerLeft"
|
<q-scroll-area class="fit">
|
||||||
show-if-above
|
<q-list bordered separator style="max-width: 318px">
|
||||||
:width="200"
|
<q-item v-if="lastExpedition">
|
||||||
:breakpoint="700"
|
<q-item-section>
|
||||||
elevated
|
<q-item-label class="text-h6">
|
||||||
class="bg-primary text-white"
|
{{ t('ticket.boxing.selectTime') }} ({{ time.min }}-{{ time.max }})
|
||||||
|
</q-item-label>
|
||||||
|
<q-range
|
||||||
|
v-model="time"
|
||||||
|
@change="getVideoList(lastExpedition, time)"
|
||||||
|
:min="0"
|
||||||
|
:max="24"
|
||||||
|
:step="1"
|
||||||
|
:left-label-value="time.min + ':00'"
|
||||||
|
:right-label-value="time.max + ':00'"
|
||||||
|
label
|
||||||
|
markers
|
||||||
|
snap
|
||||||
|
color="orange"
|
||||||
|
/>
|
||||||
|
</q-item-section>
|
||||||
|
</q-item>
|
||||||
|
<q-item v-if="lastExpedition">
|
||||||
|
<q-item-section>
|
||||||
|
<q-select
|
||||||
|
color="orange"
|
||||||
|
v-model="slide"
|
||||||
|
:options="videoList"
|
||||||
|
:label="t('ticket.boxing.selectVideo')"
|
||||||
|
emit-value
|
||||||
|
map-options
|
||||||
>
|
>
|
||||||
<q-scroll-area class="fit">
|
<template #prepend>
|
||||||
<q-card class="q-pa-md col">
|
<q-icon name="schedule" />
|
||||||
<q-video :title="url" :src="url" v-if="Object.keys(url).length !== 0" :ratio="16 / 9" />
|
</template>
|
||||||
</q-card>
|
</q-select>
|
||||||
</q-scroll-area>
|
</q-item-section>
|
||||||
</q-drawer>
|
</q-item>
|
||||||
</q-layout>
|
<q-item
|
||||||
</template>
|
|
||||||
<!--
|
|
||||||
<template>
|
|
||||||
<q-page class="q-pa-md row q-gutter-md">
|
|
||||||
<q-card class="q-pa-md col-2">
|
|
||||||
<q-scroll-area class="fit">
|
|
||||||
<q-list class="q-pa-xs q-gutter-md">
|
|
||||||
<q-card
|
|
||||||
v-for="expedition in expeditions"
|
v-for="expedition in expeditions"
|
||||||
:key="expedition.id"
|
:key="expedition.id"
|
||||||
@click="selectVideo(expedition.id)"
|
@click="getVideoList(expedition.id)"
|
||||||
clickable
|
clickable
|
||||||
v-ripple
|
v-ripple
|
||||||
>
|
>
|
||||||
<q-card-section>
|
|
||||||
<q-item class="q-pa-none">
|
|
||||||
<q-item-section>
|
<q-item-section>
|
||||||
<q-item-label class="text-h6">#{{ expedition.id }}</q-item-label>
|
<q-item-label class="text-h6">#{{ expedition.id }}</q-item-label>
|
||||||
</q-item-section>
|
</q-item-section>
|
||||||
</q-item>
|
|
||||||
<q-separator spaced color="orange" />
|
|
||||||
<q-item class="q-pa-none">
|
|
||||||
<q-item-section>
|
<q-item-section>
|
||||||
<q-item-label caption>{{ t('ticket.boxing.created') }}</q-item-label>
|
<q-item-label caption>{{ t('ticket.boxing.created') }}</q-item-label>
|
||||||
<q-item-label>
|
<q-item-label>
|
||||||
{{ date.formatDate(expedition.created, 'YYYY-MM-DD HH:mm:ss') }}</q-item-label
|
{{ date.formatDate(expedition.created, 'YYYY-MM-DD HH:mm:ss') }}
|
||||||
>
|
</q-item-label>
|
||||||
<q-item-label caption>{{ t('ticket.boxing.item') }}</q-item-label>
|
<q-item-label caption>{{ t('ticket.boxing.item') }}</q-item-label>
|
||||||
<q-item-label>{{ expedition.packagingItemFk }}</q-item-label>
|
<q-item-label>{{ expedition.packagingItemFk }}</q-item-label>
|
||||||
<q-item-label caption>{{ t('ticket.boxing.worker') }}</q-item-label>
|
<q-item-label caption>{{ t('ticket.boxing.worker') }}</q-item-label>
|
||||||
<q-item-label>{{ expedition.userName }}</q-item-label>
|
<q-item-label>{{ expedition.userName }}</q-item-label>
|
||||||
</q-item-section>
|
</q-item-section>
|
||||||
</q-item>
|
</q-item>
|
||||||
</q-card-section>
|
|
||||||
</q-card>
|
|
||||||
</q-list>
|
</q-list>
|
||||||
</q-scroll-area>
|
</q-scroll-area>
|
||||||
</q-card>
|
</q-drawer>
|
||||||
<q-card class="q-pa-md col">
|
|
||||||
<q-video :title="url" :src="url" v-if="Object.keys(url).length !== 0" :ratio="16 / 9" />
|
<q-page-container>
|
||||||
|
<q-page>
|
||||||
|
<q-card>
|
||||||
|
<q-carousel animated v-model="slide" height="max-content">
|
||||||
|
<q-carousel-slide v-for="video in videoList" :key="video.value" :name="video.value">
|
||||||
|
<q-video :src="video.url" :ratio="16 / 9" />
|
||||||
|
</q-carousel-slide>
|
||||||
|
</q-carousel>
|
||||||
</q-card>
|
</q-card>
|
||||||
</q-page>
|
</q-page>
|
||||||
|
</q-page-container>
|
||||||
|
</q-layout>
|
||||||
</template>
|
</template>
|
||||||
-->
|
|
||||||
|
|
|
@ -1,23 +1,23 @@
|
||||||
<script setup>
|
<script setup>
|
||||||
import { computed } from 'vue';
|
//import { computed } from 'vue';
|
||||||
import { useState } from 'src/composables/useState';
|
//import { useState } from 'src/composables/useState';
|
||||||
import { useRouter } from 'vue-router';
|
//import { useRouter } from 'vue-router';
|
||||||
|
|
||||||
const state = useState();
|
//const state = useState();
|
||||||
const router = useRouter();
|
//const router = useRouter();
|
||||||
const entityId = computed(function () {
|
/*const entityId = computed(function () {
|
||||||
return router.currentRoute.value.params.id;
|
return router.currentRoute.value.params.id;
|
||||||
});
|
});*/
|
||||||
</script>
|
</script>
|
||||||
<template>
|
<template>
|
||||||
<q-drawer v-model="state.drawer.value" show-if-above :width="200" :breakpoint="500">
|
<!--<q-drawer v-model="state.drawer.value" show-if-above :width="200" :breakpoint="500">
|
||||||
<q-scroll-area class="fit text-grey-8">
|
<q-scroll-area class="fit text-grey-8">
|
||||||
<router-link :to="{ path: '/customer/list' }">
|
<router-link :to="{ path: '/customer/list' }">
|
||||||
<q-icon name="arrow_back" size="md" color="primary" />
|
<q-icon name="arrow_back" size="md" color="primary" />
|
||||||
</router-link>
|
</router-link>
|
||||||
<div>Customer ID: {{ entityId }}</div>
|
<div>Customer ID: {{ entityId }}</div>
|
||||||
</q-scroll-area>
|
</q-scroll-area>
|
||||||
</q-drawer>
|
</q-drawer>-->
|
||||||
<q-page-container>
|
<q-page-container>
|
||||||
<router-view></router-view>
|
<router-view></router-view>
|
||||||
</q-page-container>
|
</q-page-container>
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<script setup>
|
<script setup>
|
||||||
import { ref } from 'vue';
|
import { ref } from 'vue';
|
||||||
import { useState } from 'src/composables/useState';
|
import { useState } from 'src/composables/useState';
|
||||||
import LeftMenu from 'src/components/LeftMenu.vue';
|
//import LeftMenu from 'src/components/LeftMenu.vue';
|
||||||
|
|
||||||
const state = useState();
|
const state = useState();
|
||||||
const miniState = ref(true);
|
const miniState = ref(true);
|
||||||
|
@ -18,9 +18,9 @@ const miniState = ref(true);
|
||||||
:width="256"
|
:width="256"
|
||||||
:breakpoint="500"
|
:breakpoint="500"
|
||||||
>
|
>
|
||||||
<q-scroll-area class="fit text-grey-8">
|
<!--<q-scroll-area class="fit text-grey-8">
|
||||||
<LeftMenu />
|
<LeftMenu />
|
||||||
</q-scroll-area>
|
</q-scroll-area>-->
|
||||||
</q-drawer>
|
</q-drawer>
|
||||||
<q-page-container>
|
<q-page-container>
|
||||||
<router-view></router-view>
|
<router-view></router-view>
|
||||||
|
|
Loading…
Reference in New Issue