Files
myprojplanet_vite/src/views/ecommerce/orderInfo/orderInfo.vue

307 lines
12 KiB
Vue
Raw Normal View History

2023-11-27 14:40:42 +01:00
<template>
<q-page>
<CTitleBanner title="Ordini"></CTitleBanner>
<q-spinner v-if="!endload" color="primary" size="3em" :thickness="2" />
2023-12-28 21:00:10 +01:00
<div class="q-gutter-md text-center">
<q-btn-toggle
v-model="cosa"
push
rounded
glossy
toggle-color="purple"
:options="[
{ value: shared_consts.PROD.TUTTI, slot: 'tutti' },
{ value: shared_consts.PROD.BOTTEGA, slot: 'bottega' },
{ value: shared_consts.PROD.GAS, slot: 'gas' },
]"
>
<template v-slot:tutti>
<div class="row items-center no-wrap">
<div class="text-center">
{{ t('gas.tutti') }}
<br />
{{ t('gas.x_prodotti_gas', { qta: productStore.getNumQtaGas()+productStore.getNumQtaBottega() }) }}
</div>
<q-icon right name="fas fa-user-friends" />
</div>
</template>
<template v-slot:gas>
<div class="row items-center no-wrap">
<div class="text-center">
{{ t('gas.ordina_sul_gas') }}
<br />
{{ t('gas.x_prodotti_gas', { qta: productStore.getNumQtaGas() }) }}
</div>
<q-icon right name="fas fa-user-friends" />
</div>
</template>
<template v-slot:bottega>
<div class="row items-center no-wrap">
<div class="text-center">
{{ t('gas.bottega') }}
<br />
{{
t('gas.x_prodotti_bottega', { qta: productStore.getNumQtaBottega() })
}}
</div>
<q-icon right name="fas fa-store" />
</div>
</template>
</q-btn-toggle>
</div>
˚
<div v-if="endload" class="panel">
2023-11-28 08:45:52 +01:00
<q-tabs v-model="taborders" inline-label class="text-blue">
2023-12-13 19:18:00 +01:00
<span v-for="(stat, index) of shared_consts.OrderStat" :key="index">
<q-tab
v-if="arrnumstatus[stat.value] > 0"
:class="stat.color"
:name="stat.value"
:icon="stat.icon"
:label="`(` + arrnumstatus[stat.value] + `) ` + stat.label"
/>
</span>
2023-11-27 14:40:42 +01:00
</q-tabs>
<div class="q-pa-sm">
<q-table
:grid="$q.screen.lt.sm"
:hide-header="$q.screen.lt.sm"
:columns="columns"
row-key="numorder"
2023-12-28 21:00:10 +01:00
:pagination="initialPagination"
2023-12-15 23:36:48 +01:00
:rows="getOrdersCartWithTotals()"
2023-11-28 08:45:52 +01:00
>
2023-11-27 14:40:42 +01:00
<template v-if="$q.screen.lt.sm" v-slot:item="props">
<div class="q-pa-xs col-xs-12 col-sm-6 col-md-4">
<q-card class="my-card-shadow yes_shadow">
<q-list dense>
2023-11-28 08:45:52 +01:00
<q-item v-for="col in getCols(props)" :key="col.name">
2023-11-27 14:40:42 +01:00
<q-item-section>
<q-item-label>{{ col.label }}</q-item-label>
</q-item-section>
<q-item-section side>
2023-11-28 08:45:52 +01:00
<q-item-label v-if="col.name === 'created_at'" caption
>{{ tools.getstrDateTime(col.value) }}
2023-11-27 14:40:42 +01:00
</q-item-label>
2023-12-17 16:20:50 +01:00
<q-item-label
v-else-if="col.name === 'nameSurname'"
caption
>
<span v-if="props.row.user">
<span
:class="
props.row.user.name !== 'TOTALI' ? '' : 'totali'
"
>{{ tools.getNomeUtenteByRecUser(props.row.user) }}
</span></span
>
</q-item-label>
2023-11-27 14:40:42 +01:00
<q-item-label v-else-if="col.name === 'items'" caption>
2023-11-28 08:45:52 +01:00
<div
v-for="(item, index) of props.row.items"
:key="index"
>
2023-12-15 23:36:48 +01:00
<div
2023-12-27 02:58:23 +01:00
v-if="!!item && item.order && item.order.product && item.order.product.productInfo"
2023-12-15 23:36:48 +01:00
>
2023-12-27 02:58:23 +01:00
{{ item.order.product.productInfo.name }} ({{
productStore.getQuantityByOrder(t, item.order)
2023-11-28 08:45:52 +01:00
}})<br />
2023-11-27 14:40:42 +01:00
</div>
</div>
</q-item-label>
2023-11-28 08:45:52 +01:00
<q-item-label
v-else-if="col.name === 'totalPrice'"
caption
>
2023-11-27 14:40:42 +01:00
{{ props.row.totalPrice }}
</q-item-label>
<q-item-label v-else-if="col.name === 'status'" caption>
{{ shared_consts.getStatusStr(props.row.status) }}
</q-item-label>
2023-12-17 16:20:50 +01:00
<q-item-label v-else-if="col.name === 'comandi'" caption>
<div
v-if="
tools.isManager() &&
props.row.user.name !== 'TOTALI'
"
class="q-pa-sm"
>
<q-btn-dropdown rounded dense label="Azioni">
<q-list class="text-primary">
<q-item
v-for="(
cmd, index
) of shared_consts.OrderCmdStr"
:key="index"
clickable
v-close-popup
@click="clickFunz(props.row, cmd.value)"
>
<q-item-section avatar>
<q-avatar
:icon="cmd.icon"
:color="cmd.color"
text-color="white"
/>
</q-item-section>
<q-item-section>
<q-item-label>{{ cmd.label }}</q-item-label>
</q-item-section>
</q-item>
</q-list>
</q-btn-dropdown>
</div>
</q-item-label>
2023-11-28 08:45:52 +01:00
<q-item-label v-else caption>{{
col.value
}}</q-item-label>
2023-11-27 14:40:42 +01:00
</q-item-section>
</q-item>
</q-list>
</q-card>
</div>
</template>
<template v-else v-slot:body="props">
<q-tr :props="props">
<q-td key="numorder" :props="props">
2023-12-15 23:36:48 +01:00
<span v-if="props.row.numorder">
&nbsp; n. {{ props.row.numorder }}</span
>
2023-11-27 14:40:42 +01:00
</q-td>
<q-td key="nameSurname" :props="props">
2023-12-15 23:36:48 +01:00
<span v-if="props.row.user">
<span
:class="props.row.user.name !== 'TOTALI' ? '' : 'totali'"
>{{ tools.getNomeUtenteByRecUser(props.row.user) }}
2023-12-17 16:20:50 +01:00
</span></span
2023-12-15 23:36:48 +01:00
>
2023-11-27 14:40:42 +01:00
</q-td>
<q-td key="created_at" :props="props">
{{ tools.getstrDateTime(props.row.created_at) }}
2023-12-13 19:18:00 +01:00
<span v-if="taborders === shared_consts.OrderStat.COMPLETATI">
2023-12-29 21:17:25 +01:00
<br />Consegnato il:<br />{{
tools.getstrDateTime(props.row.date_consegnato)
2023-11-28 08:45:52 +01:00
}}
2023-11-27 14:40:42 +01:00
</span>
</q-td>
<q-td key="items" :props="props">
2023-11-28 08:45:52 +01:00
<div v-for="(item, index) of props.row.items" :key="index">
2023-12-27 02:58:23 +01:00
<div v-if="!!item.order && item.order.product && item.order.product.productInfo">
{{ item.order.product.productInfo.name }} ({{
2023-12-21 01:34:39 +01:00
productStore.getQuantityByOrder($t, item.order)
2023-11-28 08:45:52 +01:00
}})<br />
2023-11-27 14:40:42 +01:00
</div>
</div>
<div v-if="props.row.note" class="note">
Note: {{ props.row.note }}
</div>
2023-11-27 14:40:42 +01:00
</q-td>
<q-td key="totalPrice" :props="props">
2023-12-15 23:36:48 +01:00
<span :class="props.row.user.name !== 'TOTALI' ? '' : 'totali'"
>{{ props.row.totalPrice }} </span
>
2023-11-27 14:40:42 +01:00
</q-td>
<q-td key="status" :props="props">
2023-11-28 08:45:52 +01:00
<span :class="props.row.status">{{
shared_consts.getStatusStr(props.row.status)
}}</span>
<br />
2023-12-13 19:18:00 +01:00
<div v-if="props.row.evaso" class="ordstat">
{{ tools.getstrDateTime(props.row.date_evaso) }}:
<span class="ordstat evaso">{{ $t('ecomm.evaso') }}</span>
2023-12-13 19:18:00 +01:00
</div>
<div v-if="props.row.pagato" class="ordstat">
{{ tools.getstrDateTime(props.row.date_pagato) }}:
<span class="ordstat">{{ $t('ecomm.pagato') }}</span>
</div>
2023-12-29 21:17:25 +01:00
<div v-if="props.row.consegnato" class="ordstat">
{{ tools.getstrDateTime(props.row.date_consegnato) }}:
<span class="ordstat">{{ $t('ecomm.consegnato') }}</span>
</div>
2023-12-13 19:18:00 +01:00
<div v-if="props.row.spedito">
{{ tools.getstrDateTime(props.row.date_spedito) }}:
<span class="ordstat">{{ $t('ecomm.spedito') }}</span>
</div>
<div v-if="props.row.ricevuto">
{{ tools.getstrDateTime(props.row.date_ricevuto) }}:
<span class="ordstat">{{ $t('ecomm.ricevuto') }}</span>
</div>
2023-11-27 14:40:42 +01:00
</q-td>
<q-td key="comandi" :props="props">
2023-12-15 23:36:48 +01:00
<div
v-if="tools.isManager() && props.row.user.name !== 'TOTALI'"
class="q-pa-sm"
>
2023-11-27 14:40:42 +01:00
<q-btn-dropdown rounded dense label="Azioni">
<q-list class="text-primary">
2023-11-28 08:45:52 +01:00
<q-item
2023-12-13 19:18:00 +01:00
v-for="(cmd, index) of shared_consts.OrderCmdStr"
:key="index"
2023-11-28 08:45:52 +01:00
clickable
v-close-popup
2023-12-13 19:18:00 +01:00
@click="clickFunz(props.row, cmd.value)"
2023-11-28 08:45:52 +01:00
>
2023-11-27 14:40:42 +01:00
<q-item-section avatar>
2023-11-28 08:45:52 +01:00
<q-avatar
2023-12-13 19:18:00 +01:00
:icon="cmd.icon"
:color="cmd.color"
2023-11-28 08:45:52 +01:00
text-color="white"
/>
2023-11-27 14:40:42 +01:00
</q-item-section>
<q-item-section>
2023-12-13 19:18:00 +01:00
<q-item-label>{{ cmd.label }}</q-item-label>
2023-11-27 14:40:42 +01:00
</q-item-section>
</q-item>
</q-list>
</q-btn-dropdown>
</div>
</q-td>
</q-tr>
</template>
</q-table>
</div>
<!--
<div v-for="(ordercart, index) in getOrdersCart" :key="index">
<div>
{{ ordercart.numorder }}<br>
</div>
<div class="container">
<div class="q-pa-sm col items-start q-gutter-xs" v-for="(itemorder, index) in ordercart.items" :key="index">
<CSingleCart :order="itemorder.order" :showall="true" :nomodif="true"/>
</div>
</div>
<q-separator></q-separator>
<div class="col-6 q-mr-sm" style="text-align: right">
<span class="text-grey q-mr-xs">Totale:</span> <span
class="text-subtitle1 q-mr-sm "> {{ ordercart.totalPrice.toFixed(2) }}</span>
</div>
<q-input v-model="ordercart.note" style="max-width: 400px;" label="Note aggiuntive:"
filled dense
debounce="1000"
autogrow
@input="change_field(ordercart.id, 'note')">
</q-input>
<br>
</div>
-->
</div>
</q-page>
</template>
<script lang="ts" src="./orderInfo.ts">
</script>
<style lang="scss" scoped>
@import './orderInfo';
</style>