feat: refs #8326 wip added new style
gitea/salix-front/pipeline/pr-dev This commit is unstable Details

This commit is contained in:
Jon Elias 2025-02-28 12:03:23 +01:00
parent c3c8a78fd8
commit 0bfb1344dc
8 changed files with 461 additions and 416 deletions

View File

@ -35,6 +35,7 @@ const val = computed(() => $props.value);
:label="label" :label="label"
disable disable
dense dense
size="sm"
/> />
<template v-else> <template v-else>
<div v-if="label || $slots.label" class="label"> <div v-if="label || $slots.label" class="label">
@ -44,7 +45,7 @@ const val = computed(() => $props.value);
</div> </div>
<div class="value"> <div class="value">
<slot name="value"> <slot name="value">
<span :title="value"> <span :title="value" style="text-overflow: ellipsis">
{{ dash ? dashIfEmpty(value) : value }} {{ dash ? dashIfEmpty(value) : value }}
</span> </span>
</slot> </slot>

View File

@ -339,3 +339,26 @@ input::-webkit-inner-spin-button {
.containerShrinked { .containerShrinked {
width: 80%; width: 80%;
} }
.vn-card-group {
display: flex;
flex-direction: column;
}
.vn-card-content {
display: flex;
flex-direction: column;
text-overflow: ellipsis;
> div {
max-height: 80px;
}
}
@media (min-width: 1010px) {
.vn-card-group {
flex-direction: row;
}
.vn-card-content {
flex: 1;
}
}

View File

@ -205,113 +205,106 @@ const getLink = (param) => `#/invoice-in/${entityId.value}/${param}`;
<InvoiceInDescriptorMenu :invoice="entity" /> <InvoiceInDescriptorMenu :invoice="entity" />
</template> </template>
<template #body="{ entity }"> <template #body="{ entity }">
<!--Basic Data--> <QCard class="max-width">
<QCard class="vn-one"> <VnTitle
<QCardSection class="q-pa-none"> :url="getLink('basic-data')"
<VnTitle :text="t('globals.pageTitles.basicData')"
:url="getLink('basic-data')"
:text="t('globals.pageTitles.basicData')"
/>
</QCardSection>
<VnLv
:label="t('invoiceIn.list.supplier')"
:value="entity.supplier?.name"
>
<template #value>
<span class="link">
{{ entity.supplier?.name }}
<SupplierDescriptorProxy :id="entity.supplierFk" />
</span>
</template>
</VnLv>
<VnLv :label="t('invoiceIn.supplierRef')" :value="entity.supplierRef" />
<VnLv
:label="t('invoiceIn.summary.currency')"
:value="entity.currency?.code"
/> />
<VnLv :label="t('invoiceIn.serial')" :value="`${entity.serial}`" /> <div class="vn-card-group">
<VnLv <div class="vn-card-content">
:label="t('globals.country')" <VnLv
:value="entity.supplier?.country?.code" :label="t('invoiceIn.list.supplier')"
/> :value="entity.supplier?.name"
</QCard> >
<QCard class="vn-one"> <template #value>
<QCardSection class="q-pa-none"> <span class="link">
<VnTitle {{ entity.supplier?.name }}
:url="getLink('basic-data')" <SupplierDescriptorProxy :id="entity.supplierFk" />
:text="t('globals.pageTitles.basicData')" </span>
/> </template>
</QCardSection> </VnLv>
<VnLv <VnLv
:ellipsis-value="false" :label="t('invoiceIn.supplierRef')"
:label="t('invoiceIn.summary.issued')" :value="entity.supplierRef"
:value="toDate(entity.issued)" />
/> <VnLv
<VnLv :label="t('invoiceIn.summary.currency')"
:label="t('invoiceIn.summary.operated')" :value="entity.currency?.code"
:value="toDate(entity.operated)" />
/> <VnLv
<VnLv :label="t('invoiceIn.serial')"
:label="t('invoiceIn.summary.bookEntried')" :value="`${entity.serial}`"
:value="toDate(entity.bookEntried)" />
/> <VnLv
<VnLv :label="t('globals.country')"
:label="t('invoiceIn.summary.bookedDate')" :value="entity.supplier?.country?.code"
:value="toDate(entity.booked)" />
/> </div>
<VnLv :label="t('globals.isVies')" :value="entity.supplier?.isVies" /> <div class="vn-card-content">
</QCard> <VnLv
<QCard class="vn-one"> :ellipsis-value="false"
<QCardSection class="q-pa-none"> :label="t('invoiceIn.summary.issued')"
<VnTitle :value="toDate(entity.issued)"
:url="getLink('basic-data')" />
:text="t('globals.pageTitles.basicData')" <VnLv
/> :label="t('invoiceIn.summary.operated')"
</QCardSection> :value="toDate(entity.operated)"
<VnLv />
:label="t('invoiceIn.summary.sage')" <VnLv
:value="entity.sageWithholding?.withholding" :label="t('invoiceIn.summary.bookEntried')"
/> :value="toDate(entity.bookEntried)"
<VnLv />
:label="t('invoiceIn.summary.vat')" <VnLv
:value="entity.expenseDeductible?.name" :label="t('invoiceIn.summary.bookedDate')"
/> :value="toDate(entity.booked)"
<VnLv />
:label="t('invoiceIn.card.company')" <VnLv
:value="entity.company?.code" :label="t('globals.isVies')"
/> :value="entity.supplier?.isVies"
<VnLv :label="t('invoiceIn.isBooked')" :value="invoiceIn?.isBooked" /> />
</QCard> </div>
<QCard class="vn-one"> <div class="vn-card-content">
<QCardSection class="q-pa-none"> <VnLv
<VnTitle :label="t('invoiceIn.summary.sage')"
:url="getLink('basic-data')" :value="entity.sageWithholding?.withholding"
:text="t('globals.pageTitles.basicData')" />
/> <VnLv
</QCardSection> :label="t('invoiceIn.summary.vat')"
<QCardSection class="q-pa-none"> :value="entity.expenseDeductible?.name"
<VnLv />
:label="t('invoiceIn.summary.taxableBase')" <VnLv
:value="toCurrency(entity.totals.totalTaxableBase)" :label="t('invoiceIn.card.company')"
/> :value="entity.company?.code"
<VnLv label="Total" :value="toCurrency(entity.totals.totalVat)" /> />
<VnLv :label="t('invoiceIn.summary.dueTotal')"> <VnLv
<template #value> :label="t('invoiceIn.isBooked')"
<QChip :value="invoiceIn?.isBooked"
dense />
class="q-pa-xs" </div>
:color="amountsNotMatch ? 'negative' : 'transparent'" <div class="vn-card-content">
:title=" <VnLv
amountsNotMatch :label="t('invoiceIn.summary.taxableBase')"
? t('invoiceIn.summary.noMatch') :value="toCurrency(entity.totals.totalTaxableBase)"
: t('invoiceIn.summary.dueTotal') />
" <VnLv label="Total" :value="toCurrency(entity.totals.totalVat)" />
> <VnLv :label="t('invoiceIn.summary.dueTotal')">
{{ toCurrency(entity.totals.totalDueDay) }} <template #value>
</QChip> <QChip
</template> dense
</VnLv> class="q-pa-xs"
</QCardSection> :color="amountsNotMatch ? 'negative' : 'transparent'"
:title="
amountsNotMatch
? t('invoiceIn.summary.noMatch')
: t('invoiceIn.summary.dueTotal')
"
>
{{ toCurrency(entity.totals.totalDueDay) }}
</QChip>
</template>
</VnLv>
</div>
</div>
</QCard> </QCard>
<!--Vat--> <!--Vat-->
<QCard v-if="entity.invoiceInTax.length" class="vat"> <QCard v-if="entity.invoiceInTax.length" class="vat">

View File

@ -96,67 +96,67 @@ async function handleConfirm() {
<OrderDescriptorMenu :order="entity" /> <OrderDescriptorMenu :order="entity" />
</template> </template>
<template #body="{ entity }"> <template #body="{ entity }">
<QCard class="vn-one"> <QCard class="vn-two">
<VnTitle <VnTitle
:url="`#/order/${entity.id}/basic-data`" :url="`#/order/${entity.id}/basic-data`"
:text="t('globals.pageTitles.basicData')" :text="t('globals.pageTitles.basicData')"
/> />
<VnLv label="ID" :value="entity.id" /> <div class="vn-card-group">
<VnLv :label="t('globals.alias')" dash> <div class="vn-card-content">
<template #value> <VnLv label="ID" :value="entity.id" />
<span class="link"> <VnLv :label="t('globals.alias')" dash>
{{ dashIfEmpty(entity?.address?.nickname) }} <template #value>
<CustomerDescriptorProxy :id="entity?.clientFk" /> <span class="link">
</span> {{ dashIfEmpty(entity?.address?.nickname) }}
</template> <CustomerDescriptorProxy :id="entity?.clientFk" />
</VnLv> </span>
<VnLv </template>
:label="t('globals.company')" </VnLv>
:value="entity?.address?.companyFk" <VnLv
/> :label="t('globals.company')"
<VnLv :value="entity?.address?.companyFk"
:label="t('globals.confirmed')" />
:value="Boolean(entity?.isConfirmed)" <VnLv
/> :label="t('globals.confirmed')"
</QCard> :value="Boolean(entity?.isConfirmed)"
<QCard class="vn-one"> />
<VnTitle </div>
:url="`#/order/${entity.id}/basic-data`" <div class="vn-card-content">
:text="t('globals.pageTitles.basicData')" <VnLv
/> :label="t('order.summary.created')"
<VnLv :value="toDateHourMinSec(entity?.created)"
:label="t('order.summary.created')" />
:value="toDateHourMinSec(entity?.created)" <VnLv
/> :label="t('globals.confirmed')"
<VnLv :value="toDateHourMinSec(entity?.confirmed)"
:label="t('globals.confirmed')" />
:value="toDateHourMinSec(entity?.confirmed)" <VnLv
/> :label="t('globals.landed')"
<VnLv :value="toDateHourMinSec(entity?.landed)"
:label="t('globals.landed')" />
:value="toDateHourMinSec(entity?.landed)" <VnLv :label="t('globals.phone')">
/> <template #value>
<VnLv :label="t('globals.phone')"> {{ dashIfEmpty(entity?.address?.phone) }}
<template #value> <a
{{ dashIfEmpty(entity?.address?.phone) }} v-if="entity?.address?.phone"
<a :href="`tel:${entity?.address?.phone}`"
v-if="entity?.address?.phone" class="text-primary"
:href="`tel:${entity?.address?.phone}`" >
class="text-primary" <QIcon name="phone" />
> </a>
<QIcon name="phone" /> </template>
</a> </VnLv>
</template> <VnLv
</VnLv> :label="t('order.summary.createdFrom')"
<VnLv :value="entity?.sourceApp"
:label="t('order.summary.createdFrom')" />
:value="entity?.sourceApp" <VnLv
/> :label="t('order.summary.address')"
<VnLv :value="`${entity?.address?.street} - ${entity?.address?.city} (${entity?.address?.province?.name})`"
:label="t('order.summary.address')" class="order-summary-address"
:value="`${entity?.address?.street} - ${entity?.address?.city} (${entity?.address?.province?.name})`" />
class="order-summary-address" </div>
/> </div>
</QCard> </QCard>
<QCard class="vn-one"> <QCard class="vn-one">
<VnTitle :text="t('globals.pageTitles.notes')" /> <VnTitle :text="t('globals.pageTitles.notes')" />

View File

@ -137,118 +137,130 @@ onMounted(async () => {
<TicketDescriptorMenu :ticket="entity" /> <TicketDescriptorMenu :ticket="entity" />
</template> </template>
<template #body="{ entity }"> <template #body="{ entity }">
<QCard class="vn-one"> <QCard class="vn-two">
<VnTitle <VnTitle
:url="toTicketUrl('basic-data')" :url="toTicketUrl('basic-data')"
:text="t('globals.summary.basicData')" :text="t('globals.summary.basicData')"
/> />
<VnLv v-if="entity.ticketState" :label="t('globals.state')"> <div class="vn-card-group">
<template #value> <div class="vn-card-content">
<QBadge <VnLv v-if="entity.ticketState" :label="t('globals.state')">
text-color="black" <template #value>
:color="entity.ticketState.state.classColor" <QBadge
> text-color="black"
{{ entity.ticketState.state.name }} :color="entity.ticketState.state.classColor"
</QBadge> >
</template> {{ entity.ticketState.state.name }}
</VnLv> </QBadge>
<VnLv :label="t('globals.salesPerson')"> </template>
<template #value> </VnLv>
<VnUserLink <VnLv :label="t('globals.salesPerson')">
:name="entity.client?.salesPersonUser?.name" <template #value>
:worker-id="entity.client?.salesPersonFk" <VnUserLink
:name="entity.client?.salesPersonUser?.name"
:worker-id="entity.client?.salesPersonFk"
/>
</template>
</VnLv>
<VnLv
:label="t('globals.agency')"
:value="entity.agencyMode?.name"
/> />
</template> <VnLv :label="t('ticket.summary.zone')">
</VnLv> <template #value>
<VnLv :label="t('globals.agency')" :value="entity.agencyMode?.name" /> <span class="link" @click.stop>
<VnLv :label="t('ticket.summary.zone')"> {{ entity?.zone?.name }}
<template #value> <ZoneDescriptorProxy :id="entity.zoneFk" />
<span class="link" @click.stop> </span>
{{ entity?.zone?.name }} </template>
<ZoneDescriptorProxy :id="entity.zoneFk" /> </VnLv>
</span> <VnLv
</template> :label="t('globals.warehouse')"
</VnLv> :value="entity.warehouse?.name"
<VnLv :label="t('globals.warehouse')" :value="entity.warehouse?.name" /> />
<VnLv <VnLv
v-if="ticket?.ticketCollections?.length > 0" v-if="ticket?.ticketCollections?.length > 0"
:label="t('ticket.summary.collection')" :label="t('ticket.summary.collection')"
:value="ticket?.ticketCollections[0]?.collectionFk" :value="ticket?.ticketCollections[0]?.collectionFk"
>
<template #value>
<a
:href="`${grafanaUrl}/d/d552ab74-85b4-4e7f-a279-fab7cd9c6124/control-de-expediciones?orgId=1&var-collectionFk=${entity.ticketCollections[0]?.collectionFk}`"
target="_blank"
class="grafana"
> >
{{ entity.ticketCollections[0]?.collectionFk }} <template #value>
</a> <a
</template> :href="`${grafanaUrl}/d/d552ab74-85b4-4e7f-a279-fab7cd9c6124/control-de-expediciones?orgId=1&var-collectionFk=${entity.ticketCollections[0]?.collectionFk}`"
</VnLv> target="_blank"
<VnLv :label="t('ticket.summary.route')"> class="grafana"
<template #value> >
<span class="link"> {{ entity.ticketCollections[0]?.collectionFk }}
{{ entity.routeFk }} </a>
<RouteDescriptorProxy :id="entity.routeFk" /> </template>
</span> </VnLv>
</template> <VnLv :label="t('ticket.summary.route')">
</VnLv> <template #value>
<VnLv :label="t('ticket.summary.invoice')"> <span class="link">
<template #value> {{ entity.routeFk }}
<span :class="{ link: entity.refFk }"> <RouteDescriptorProxy :id="entity.routeFk" />
{{ dashIfEmpty(entity.refFk) }} </span>
<InvoiceOutDescriptorProxy </template>
:id="entity.invoiceOut.id" </VnLv>
v-if="entity.refFk" <VnLv :label="t('ticket.summary.invoice')">
/> <template #value>
</span> <span :class="{ link: entity.refFk }">
</template> {{ dashIfEmpty(entity.refFk) }}
</VnLv> <InvoiceOutDescriptorProxy
<VnLv :label="t('globals.weight')" :value="dashIfEmpty(entity.weight)" /> :id="entity.invoiceOut.id"
</QCard> v-if="entity.refFk"
<QCard class="vn-one"> />
<VnTitle </span>
:url="toTicketUrl('basic-data')" </template>
:text="t('globals.summary.basicData')" </VnLv>
/> <VnLv
<VnLv :label="t('globals.weight')"
:label="t('ticket.summary.shipped')" :value="dashIfEmpty(entity.weight)"
:value="toDate(entity.shipped)" />
/> </div>
<VnLv :label="t('globals.landed')" :value="toDate(entity.landed)" /> <div class="vn-card-content">
<VnLv :label="t('globals.packages')" :value="entity.packages" /> <VnLv
<VnLv :value="entity.address.phone"> :label="t('ticket.summary.shipped')"
<template #label> :value="toDate(entity.shipped)"
{{ t('ticket.summary.consigneePhone') }} />
<VnLinkPhone :phone-number="entity.address.phone" /> <VnLv
</template> :label="t('globals.landed')"
</VnLv> :value="toDate(entity.landed)"
<VnLv :value="entity.address.mobile"> />
<template #label> <VnLv :label="t('globals.packages')" :value="entity.packages" />
{{ t('ticket.summary.consigneeMobile') }} <VnLv :value="entity.address.phone">
<VnLinkPhone :phone-number="entity.address.mobile" /> <template #label>
</template> {{ t('ticket.summary.consigneePhone') }}
</VnLv> <VnLinkPhone :phone-number="entity.address.phone" />
<VnLv :value="entity.client.phone"> </template>
<template #label> </VnLv>
{{ t('ticket.summary.clientPhone') }} <VnLv :value="entity.address.mobile">
<VnLinkPhone :phone-number="entity.client.phone" /> <template #label>
</template> {{ t('ticket.summary.consigneeMobile') }}
</VnLv> <VnLinkPhone :phone-number="entity.address.mobile" />
<VnLv :value="entity.client.mobile"> </template>
<template #label> </VnLv>
{{ t('ticket.summary.clientMobile') }} <VnLv :value="entity.client.phone">
<VnLinkPhone :phone-number="entity.client.mobile" /> <template #label>
</template> {{ t('ticket.summary.clientPhone') }}
</VnLv> <VnLinkPhone :phone-number="entity.client.phone" />
<VnLv </template>
:label="t('ticket.summary.consignee')" </VnLv>
:value="`${entity.address?.nickname} #${entity.address?.id}`" <VnLv :value="entity.client.mobile">
/> <template #label>
<VnLv {{ t('ticket.summary.clientMobile') }}
:label="t('ticket.summary.consigneeStreet')" <VnLinkPhone :phone-number="entity.client.mobile" />
:value="formattedAddress" </template>
/> </VnLv>
<VnLv
:label="t('ticket.summary.consignee')"
:value="`${entity.address?.nickname} #${entity.address?.id}`"
/>
<VnLv
:label="t('ticket.summary.consigneeStreet')"
:value="formattedAddress"
/>
</div>
</div>
</QCard> </QCard>
<QCard class="vn-one" v-if="entity.notes.length"> <QCard class="vn-one" v-if="entity.notes.length">
<VnTitle <VnTitle

View File

@ -275,72 +275,68 @@ const getLink = (param) => `#/travel/${entityId.value}/${param}`;
<TravelDescriptorMenuItems :travel="entity" /> <TravelDescriptorMenuItems :travel="entity" />
</template> </template>
<template #body> <template #body>
<QCard class="vn-one"> <QCard class="full-width">
<QCardSection class="q-pa-none"> <VnTitle
<VnTitle :url="getLink('basic-data')"
:url="getLink('basic-data')" :text="t('globals.pageTitles.basicData')"
:text="t('globals.pageTitles.basicData')"
/>
</QCardSection>
<VnLv :label="t('globals.shipped')" :value="toDate(travel.shipped)" />
<VnLv
:label="t('globals.warehouseOut')"
:value="travel.warehouseOut?.name"
/>
<VnRow>
<QCheckbox
:label="t('travel.basicData.isRaid')"
v-model="travel.isRaid"
:disable="true"
/>
</VnRow>
<VnRow>
<QCheckbox
:label="t('travel.summary.delivered')"
v-model="travel.isDelivered"
:disable="true"
/>
</VnRow>
</QCard>
<QCard class="vn-one">
<QCardSection class="q-pa-none">
<VnTitle
:url="getLink('basic-data')"
:text="t('globals.pageTitles.basicData')"
/>
</QCardSection>
<VnLv :label="t('globals.landed')" :value="toDate(travel.landed)" />
<VnLv
:label="t('globals.warehouseIn')"
:value="travel.warehouseIn?.name"
/>
<VnLv
:label="t('travel.basicData.daysInForward')"
:value="travel?.daysInForward"
/>
<QCheckbox
:label="t('travel.summary.received')"
v-model="travel.isReceived"
:disable="true"
/>
</QCard>
<QCard class="vn-one">
<QCardSection class="q-pa-none">
<VnTitle
:url="getLink('basic-data')"
:text="t('globals.pageTitles.basicData')"
/>
</QCardSection>
<VnLv :label="t('globals.agency')" :value="travel.agency?.name" />
<VnLv :label="t('globals.reference')" :value="travel.ref" />
<VnLv label="m³" :value="travel.m3" />
<VnLv :label="t('globals.totalEntries')" :value="travel.totalEntries" />
<VnLv
:label="t('travel.summary.availabled')"
:value="
dashIfEmpty(toDateTimeFormat(travel.availabled))
"
/> />
<div class="vn-card-group">
<div class="vn-card-content">
<VnLv
:label="t('globals.shipped')"
:value="toDate(travel.shipped)"
/>
<VnLv
:label="t('globals.warehouseOut')"
:value="travel.warehouseOut?.name"
/>
<QCheckbox
:label="t('travel.basicData.isRaid')"
v-model="travel.isRaid"
:disable="true"
size="sm"
/>
<QCheckbox
:label="t('travel.summary.delivered')"
v-model="travel.isDelivered"
:disable="true"
size="sm"
/>
</div>
<div class="vn-card-content">
<VnLv
:label="t('globals.landed')"
:value="toDate(travel.landed)"
/>
<VnLv
:label="t('globals.warehouseIn')"
:value="travel.warehouseIn?.name"
/>
<VnLv
:label="t('travel.basicData.daysInForward')"
:value="travel?.daysInForward"
/>
<QCheckbox
:label="t('travel.summary.received')"
v-model="travel.isReceived"
:disable="true"
size="sm"
/>
</div>
<div class="vn-card-content">
<VnLv :label="t('globals.agency')" :value="travel.agency?.name" />
<VnLv :label="t('globals.reference')" :value="travel.ref" />
<VnLv label="m³" :value="travel.m3" />
<VnLv
:label="t('globals.totalEntries')"
:value="travel.totalEntries"
/>
<VnLv
:label="t('travel.summary.availabled')"
:value="dashIfEmpty(toDateTimeFormat(travel.availabled))"
/>
</div>
</div>
</QCard> </QCard>
<QCard class="full-width"> <QCard class="full-width">
<VnTitle :text="t('travel.summary.entries')" /> <VnTitle :text="t('travel.summary.entries')" />

View File

@ -47,77 +47,88 @@ onBeforeMount(async () => {
<WorkerDescriptorMenu :worker="entity" :is-excluded="workerExcluded" /> <WorkerDescriptorMenu :worker="entity" :is-excluded="workerExcluded" />
</template> </template>
<template #body="{ entity: worker }"> <template #body="{ entity: worker }">
<QCard class="vn-one"> <QCard class="vn-two">
<VnTitle :url="basicDataUrl" :text="t('globals.summary.basicData')" /> <VnTitle :url="basicDataUrl" :text="t('globals.summary.basicData')" />
<VnLv :label="t('globals.name')" :value="worker.user?.nickname" /> <div class="vn-card-group">
<VnLv :label="t('worker.list.department')"> <div class="vn-card-content">
<template #value> <VnLv :label="t('globals.name')" :value="worker.user?.nickname" />
<span class="link" v-text="worker.department?.department?.name" /> <VnLv :label="t('worker.list.department')">
<DepartmentDescriptorProxy <template #value>
:id="worker.department?.department?.id" <span
class="link"
v-text="worker.department?.department?.name"
/>
<DepartmentDescriptorProxy
:id="worker.department?.department?.id"
/>
</template>
</VnLv>
<VnLv :label="t('worker.summary.boss')" link>
<template #value>
<VnUserLink
v-if="worker.boss"
:name="dashIfEmpty(worker.boss?.name)"
:worker-id="worker.bossFk"
/>
</template>
</VnLv>
<VnLv :value="worker.mobileExtension">
<template #label>
{{ t('worker.summary.phoneExtension') }}
<VnLinkPhone :phone-number="worker.mobileExtension" />
</template>
</VnLv>
<VnLv :value="worker.phone">
<template #label>
{{ t('worker.summary.entPhone') }}
<VnLinkPhone :phone-number="worker.phone" />
</template>
</VnLv>
<VnLv :value="advancedSummary?.client?.phone">
<template #label>
{{ t('worker.summary.personalPhone') }}
<VnLinkPhone
:phone-number="advancedSummary?.client?.phone"
/>
</template>
</VnLv>
</div>
<div class="vn-card-content">
<VnLv
:label="t('worker.summary.fiDueDate')"
:value="toDate(advancedSummary.fiDueDate)"
/> />
</template> <VnLv :label="t('worker.summary.sex')" :value="worker.sex" />
</VnLv> <VnLv
<VnLv :label="t('worker.summary.boss')" link> :label="t('worker.summary.seniority')"
<template #value> :value="toDate(advancedSummary.seniority)"
<VnUserLink
v-if="worker.boss"
:name="dashIfEmpty(worker.boss?.name)"
:worker-id="worker.bossFk"
/> />
</template> <VnLv
</VnLv> :label="t('worker.summary.fi')"
<VnLv :value="worker.mobileExtension"> :value="advancedSummary.fi"
<template #label> />
{{ t('worker.summary.phoneExtension') }} <VnLv
<VnLinkPhone :phone-number="worker.mobileExtension" /> :label="t('worker.summary.birth')"
</template> :value="toDate(advancedSummary.birth)"
</VnLv> />
<VnLv :value="worker.phone"> <VnLv
<template #label> :label="t('worker.summary.isFreelance')"
{{ t('worker.summary.entPhone') }} :value="advancedSummary.isFreelance"
<VnLinkPhone :phone-number="worker.phone" /> />
</template> <VnLv
</VnLv> :label="t('worker.summary.isSsDiscounted')"
<VnLv :value="advancedSummary?.client?.phone"> :value="advancedSummary.isSsDiscounted"
<template #label> />
{{ t('worker.summary.personalPhone') }} <VnLv
<VnLinkPhone :phone-number="advancedSummary?.client?.phone" /> :label="t('worker.summary.hasMachineryAuthorized')"
</template> :value="advancedSummary.hasMachineryAuthorized"
</VnLv> />
</QCard> <VnLv
<QCard class="vn-one" v-if="advancedSummary"> :label="t('worker.summary.isDisable')"
<VnTitle :url="basicDataUrl" :text="t('globals.summary.basicData')" /> :value="advancedSummary.isDisable"
<VnLv />
:label="t('worker.summary.fiDueDate')" </div>
:value="toDate(advancedSummary.fiDueDate)" </div>
/>
<VnLv :label="t('worker.summary.sex')" :value="worker.sex" />
<VnLv
:label="t('worker.summary.seniority')"
:value="toDate(advancedSummary.seniority)"
/>
<VnLv :label="t('worker.summary.fi')" :value="advancedSummary.fi" />
<VnLv
:label="t('worker.summary.birth')"
:value="toDate(advancedSummary.birth)"
/>
<VnLv
:label="t('worker.summary.isFreelance')"
:value="advancedSummary.isFreelance"
/>
<VnLv
:label="t('worker.summary.isSsDiscounted')"
:value="advancedSummary.isSsDiscounted"
/>
<VnLv
:label="t('worker.summary.hasMachineryAuthorized')"
:value="advancedSummary.hasMachineryAuthorized"
/>
<VnLv
:label="t('worker.summary.isDisable')"
:value="advancedSummary.isDisable"
/>
</QCard> </QCard>
<QCard class="vn-one"> <QCard class="vn-one">
<VnTitle :text="t('worker.summary.userData')" /> <VnTitle :text="t('worker.summary.userData')" />

View File

@ -74,21 +74,30 @@ onMounted(async () => {
<template #body="{ entity: zone }"> <template #body="{ entity: zone }">
<QCard class="vn-one"> <QCard class="vn-one">
<VnTitle :url="zoneUrl + `basic-data`" :text="t('summary.basicData')" /> <VnTitle :url="zoneUrl + `basic-data`" :text="t('summary.basicData')" />
<VnLv :label="t('list.agency')" :value="zone.agencyMode?.name" /> <div class="vn-card-group">
<VnLv :label="t('list.price')" :value="toCurrency(zone.price)" /> <div class="vn-card-content">
<VnLv :label="t('zone.bonus')" :value="toCurrency(zone.bonus)" /> <VnLv :label="t('list.agency')" :value="zone.agencyMode?.name" />
<VnLv :label="t('list.price')" :value="toCurrency(zone.price)" />
<VnLv :label="t('zone.bonus')" :value="toCurrency(zone.bonus)" />
</div>
<div class="vn-card-content">
<VnLv
:label="t('summary.closeHour')"
:value="toTimeFormat(zone.hour)"
/>
<VnLv
:label="t('zone.travelingDays')"
:value="zone.travelingDays"
/>
<QCheckbox
:label="t('zone.volumetric')"
v-model="zone.isVolumetric"
:disable="true"
/>
</div>
</div>
</QCard> </QCard>
<QCard class="vn-one"> <QCard class="vn-one">
<VnTitle :url="zoneUrl + `basic-data`" :text="t('summary.basicData')" />
<VnLv :label="t('summary.closeHour')" :value="toTimeFormat(zone.hour)" />
<VnLv :label="t('zone.travelingDays')" :value="zone.travelingDays" />
<QCheckbox
:label="t('zone.volumetric')"
v-model="zone.isVolumetric"
:disable="true"
/>
</QCard>
<QCard class="full-width">
<VnTitle :url="zoneUrl + `warehouses`" :text="t('list.warehouse')" /> <VnTitle :url="zoneUrl + `warehouses`" :text="t('list.warehouse')" />
<QTable <QTable
:columns="columns" :columns="columns"