feat(ticket_boxing): add section
gitea/salix-front/pipeline/head This commit looks good Details

This commit is contained in:
Alex Moreno 2022-09-06 13:59:00 +02:00
parent 22b5d06fca
commit 7f42655b1d
6 changed files with 130 additions and 79 deletions

View File

@ -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: {

View File

@ -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: {

View File

@ -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);

View File

@ -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,
};
if (timed) {
Object.assign(params, { from: timed.min, to: timed.max });
}
const { data } = await axios.get(`/Boxings/getVideoList`, { params: params });
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}`,
});
} }
/*async function getVideo(expeditionId) { console.log(list);
const { data } = await axios.get(`/api/Boxings/getVideo?id=${expeditionId}`); videoList.value = list.reverse();
const myUrl = window.URL.createObjectURL(new Blob([data])); if (list[0]) {
console.log(myUrl); slide.value = list[0].value;
if (data) url.value = data; 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" />
</q-card>
</q-scroll-area>
</q-drawer>
</q-layout>
</template> </template>
<!-- </q-select>
<template> </q-item-section>
<q-page class="q-pa-md row q-gutter-md"> </q-item>
<q-card class="q-pa-md col-2"> <q-item
<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>
-->

View File

@ -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>

View File

@ -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>