test: refs #7073 add unit tests for VnDms component #1198
|
@ -198,6 +198,7 @@ async function fetch() {
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
state.set(modelValue, {});
|
state.set(modelValue, {});
|
||||||
originalData.value = {};
|
originalData.value = {};
|
||||||
|
throw e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -104,12 +104,14 @@ export function useArrayData(key = useRoute().meta.moduleName, userOptions) {
|
||||||
|
|
||||||
store.hasMoreData = limit && response.data.length >= limit;
|
store.hasMoreData = limit && response.data.length >= limit;
|
||||||
|
|
||||||
processData(response.data, { map: !!store.mapKey, append });
|
if (!append && !isDialogOpened() && updateRouter) {
|
||||||
if (!append && !isDialogOpened()) updateRouter && updateStateParams();
|
if (updateStateParams(response.data)?.redirect) return;
|
||||||
|
}
|
||||||
store.isLoading = false;
|
store.isLoading = false;
|
||||||
canceller = null;
|
canceller = null;
|
||||||
|
|
||||||
|
processData(response.data, { map: !!store.mapKey, append });
|
||||||
|
|
||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -239,7 +241,7 @@ export function useArrayData(key = useRoute().meta.moduleName, userOptions) {
|
||||||
if (Object.values(store.userParams).length) await fetch({});
|
if (Object.values(store.userParams).length) await fetch({});
|
||||||
}
|
}
|
||||||
|
|
||||||
function updateStateParams() {
|
function updateStateParams(data) {
|
||||||
if (!route?.path) return;
|
if (!route?.path) return;
|
||||||
const newUrl = { path: route.path, query: { ...(route.query ?? {}) } };
|
const newUrl = { path: route.path, query: { ...(route.query ?? {}) } };
|
||||||
if (store?.searchUrl)
|
if (store?.searchUrl)
|
||||||
|
@ -256,15 +258,15 @@ export function useArrayData(key = useRoute().meta.moduleName, userOptions) {
|
||||||
const { path } = matches.at(-1);
|
const { path } = matches.at(-1);
|
||||||
|
|
||||||
const to =
|
const to =
|
||||||
store?.data?.length === 1
|
data?.length === 1
|
||||||
? path.replace(/\/(list|:id)|-list/, `/${store.data[0].id}`)
|
? path.replace(/\/(list|:id)|-list/, `/${data[0].id}`)
|
||||||
: path.replace(/:id.*/, '');
|
: path.replace(/:id.*/, '');
|
||||||
|
|
||||||
if (route.path != to) {
|
if (route.path != to) {
|
||||||
const pushUrl = { path: to };
|
const pushUrl = { path: to };
|
||||||
if (to.endsWith('/list') || to.endsWith('/'))
|
if (to.endsWith('/list') || to.endsWith('/'))
|
||||||
pushUrl.query = newUrl.query;
|
pushUrl.query = newUrl.query;
|
||||||
return router.push(pushUrl);
|
return router.push(pushUrl) && { redirect: true };
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
export default function toDateHourMin(date) {
|
export default function toDateHourMin(date) {
|
||||||
const dateHour = new Date(date).toLocaleDateString('es-ES', {
|
if (!date) return date;
|
||||||
|
return new Date(date).toLocaleDateString('es-ES', {
|
||||||
timeZone: 'Europe/Madrid',
|
timeZone: 'Europe/Madrid',
|
||||||
year: 'numeric',
|
year: 'numeric',
|
||||||
month: '2-digit',
|
month: '2-digit',
|
||||||
|
@ -7,5 +8,4 @@ export default function toDateHourMin(date) {
|
||||||
hour: '2-digit',
|
hour: '2-digit',
|
||||||
minute: '2-digit',
|
minute: '2-digit',
|
||||||
});
|
});
|
||||||
return dateHour;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
export default function toDateHourMinSec(date) {
|
export default function toDateHourMinSec(date) {
|
||||||
const dateHour = new Date(date).toLocaleDateString('es-ES', {
|
if (!date) return date;
|
||||||
|
return new Date(date).toLocaleDateString('es-ES', {
|
||||||
timeZone: 'Europe/Madrid',
|
timeZone: 'Europe/Madrid',
|
||||||
year: 'numeric',
|
year: 'numeric',
|
||||||
month: '2-digit',
|
month: '2-digit',
|
||||||
|
@ -8,5 +9,4 @@ export default function toDateHourMinSec(date) {
|
||||||
minute: '2-digit',
|
minute: '2-digit',
|
||||||
second: '2-digit',
|
second: '2-digit',
|
||||||
});
|
});
|
||||||
return dateHour;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,21 +1,13 @@
|
||||||
<script setup>
|
<script setup>
|
||||||
import VnCard from 'components/common/VnCard.vue';
|
import VnCardBeta from 'components/common/VnCardBeta.vue';
|
||||||
import ClaimDescriptor from './ClaimDescriptor.vue';
|
import ClaimDescriptor from './ClaimDescriptor.vue';
|
||||||
import ClaimFilter from '../ClaimFilter.vue';
|
|
||||||
import filter from './ClaimFilter.js';
|
import filter from './ClaimFilter.js';
|
||||||
</script>
|
</script>
|
||||||
<template>
|
<template>
|
||||||
<VnCard
|
<VnCardBeta
|
||||||
data-key="Claim"
|
data-key="Claim"
|
||||||
base-url="Claims"
|
base-url="Claims"
|
||||||
:descriptor="ClaimDescriptor"
|
:descriptor="ClaimDescriptor"
|
||||||
:filter-panel="ClaimFilter"
|
|
||||||
search-data-key="ClaimList"
|
|
||||||
:filter="filter"
|
:filter="filter"
|
||||||
:searchbar-props="{
|
|
||||||
url: 'Claims/filter',
|
|
||||||
label: 'Search claim',
|
|
||||||
info: 'You can search by claim id or customer name',
|
|
||||||
}"
|
|
||||||
/>
|
/>
|
||||||
</template>
|
</template>
|
||||||
|
|
|
@ -2,18 +2,18 @@
|
||||||
import { ref, computed } from 'vue';
|
import { ref, computed } from 'vue';
|
||||||
import { useI18n } from 'vue-i18n';
|
import { useI18n } from 'vue-i18n';
|
||||||
import { toDate } from 'filters/index';
|
import { toDate } from 'filters/index';
|
||||||
import VnSearchbar from 'components/ui/VnSearchbar.vue';
|
|
||||||
import ClaimFilter from './ClaimFilter.vue';
|
import ClaimFilter from './ClaimFilter.vue';
|
||||||
import CustomerDescriptorProxy from 'src/pages/Customer/Card/CustomerDescriptorProxy.vue';
|
import CustomerDescriptorProxy from 'src/pages/Customer/Card/CustomerDescriptorProxy.vue';
|
||||||
import VnUserLink from 'src/components/ui/VnUserLink.vue';
|
import VnUserLink from 'src/components/ui/VnUserLink.vue';
|
||||||
import ClaimSummary from './Card/ClaimSummary.vue';
|
import ClaimSummary from './Card/ClaimSummary.vue';
|
||||||
import { useSummaryDialog } from 'src/composables/useSummaryDialog';
|
import { useSummaryDialog } from 'src/composables/useSummaryDialog';
|
||||||
import RightMenu from 'src/components/common/RightMenu.vue';
|
|
||||||
import VnTable from 'src/components/VnTable/VnTable.vue';
|
import VnTable from 'src/components/VnTable/VnTable.vue';
|
||||||
import ZoneDescriptorProxy from '../Zone/Card/ZoneDescriptorProxy.vue';
|
import ZoneDescriptorProxy from '../Zone/Card/ZoneDescriptorProxy.vue';
|
||||||
|
import VnSection from 'src/components/common/VnSection.vue';
|
||||||
|
|
||||||
const { t } = useI18n();
|
const { t } = useI18n();
|
||||||
const { viewSummary } = useSummaryDialog();
|
const { viewSummary } = useSummaryDialog();
|
||||||
|
const dataKey = 'ClaimList';
|
||||||
|
|
||||||
const claimFilterRef = ref();
|
const claimFilterRef = ref();
|
||||||
const columns = computed(() => [
|
const columns = computed(() => [
|
||||||
|
@ -125,48 +125,50 @@ const STATE_COLOR = {
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<VnSearchbar
|
<VnSection
|
||||||
data-key="ClaimList"
|
:data-key="dataKey"
|
||||||
:label="t('Search claim')"
|
:columns="columns"
|
||||||
:info="t('You can search by claim id or customer name')"
|
prefix="claim"
|
||||||
/>
|
:array-data-props="{
|
||||||
<RightMenu>
|
url: 'Claims/filter',
|
||||||
<template #right-panel>
|
order: ['cs.priority ASC', 'created ASC'],
|
||||||
|
}"
|
||||||
|
>
|
||||||
|
<template #rightMenu>
|
||||||
<ClaimFilter data-key="ClaimList" ref="claimFilterRef" />
|
<ClaimFilter data-key="ClaimList" ref="claimFilterRef" />
|
||||||
</template>
|
</template>
|
||||||
</RightMenu>
|
<template #body>
|
||||||
<VnTable
|
<VnTable
|
||||||
data-key="ClaimList"
|
:data-key="dataKey"
|
||||||
url="Claims/filter"
|
:columns="columns"
|
||||||
:order="['cs.priority ASC', 'created ASC']"
|
redirect="claim"
|
||||||
:columns="columns"
|
:right-search="false"
|
||||||
redirect="claim"
|
auto-load
|
||||||
:right-search="false"
|
>
|
||||||
>
|
<template #column-clientFk="{ row }">
|
||||||
<template #column-clientFk="{ row }">
|
<span class="link" @click.stop>
|
||||||
<span class="link" @click.stop>
|
{{ row.clientName }}
|
||||||
{{ row.clientName }}
|
<CustomerDescriptorProxy :id="row.clientFk" />
|
||||||
<CustomerDescriptorProxy :id="row.clientFk" />
|
</span>
|
||||||
</span>
|
</template>
|
||||||
|
<template #column-attendedBy="{ row }">
|
||||||
|
<span @click.stop>
|
||||||
|
<VnUserLink :name="row.workerName" :worker-id="row.workerFk" />
|
||||||
|
</span>
|
||||||
|
</template>
|
||||||
|
<template #column-zoneFk="{ row }">
|
||||||
|
<span class="link" @click.stop>
|
||||||
|
{{ row.zoneName }}
|
||||||
|
<ZoneDescriptorProxy :id="row.zoneId" />
|
||||||
|
</span>
|
||||||
|
</template>
|
||||||
|
</VnTable>
|
||||||
</template>
|
</template>
|
||||||
<template #column-attendedBy="{ row }">
|
</VnSection>
|
||||||
<span @click.stop>
|
|
||||||
<VnUserLink :name="row.workerName" :worker-id="row.workerFk" />
|
|
||||||
</span>
|
|
||||||
</template>
|
|
||||||
<template #column-zoneFk="{ row }">
|
|
||||||
<span class="link" @click.stop>
|
|
||||||
{{ row.zoneName }}
|
|
||||||
<ZoneDescriptorProxy :id="row.zoneId" />
|
|
||||||
</span>
|
|
||||||
</template>
|
|
||||||
</VnTable>
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<i18n>
|
<i18n>
|
||||||
es:
|
es:
|
||||||
Search claim: Buscar reclamación
|
|
||||||
You can search by claim id or customer name: Puedes buscar por id de la reclamación o nombre del cliente
|
|
||||||
params:
|
params:
|
||||||
stateCode: Estado
|
stateCode: Estado
|
||||||
en:
|
en:
|
||||||
|
|
|
@ -44,3 +44,5 @@ claim:
|
||||||
fileDescription: 'Claim id {claimId} from client {clientName} id {clientId}'
|
fileDescription: 'Claim id {claimId} from client {clientName} id {clientId}'
|
||||||
noData: 'There are no images/videos, click here or drag and drop the file'
|
noData: 'There are no images/videos, click here or drag and drop the file'
|
||||||
dragDrop: Drag and drop it here
|
dragDrop: Drag and drop it here
|
||||||
|
search: Search claims
|
||||||
|
searchInfo: You can search by claim id or customer name
|
||||||
|
|
|
@ -1,5 +1,3 @@
|
||||||
Search claim: Buscar reclamación
|
|
||||||
You can search by claim id or customer name: Puedes buscar por id de la reclamación o nombre del cliente
|
|
||||||
claim:
|
claim:
|
||||||
customer: Cliente
|
customer: Cliente
|
||||||
code: Código
|
code: Código
|
||||||
|
@ -46,3 +44,5 @@ claim:
|
||||||
fileDescription: 'ID de reclamación {claimId} del cliente {clientName} con ID {clientId}'
|
fileDescription: 'ID de reclamación {claimId} del cliente {clientName} con ID {clientId}'
|
||||||
noData: 'No hay imágenes/videos, haz clic aquí o arrastra y suelta el archivo'
|
noData: 'No hay imágenes/videos, haz clic aquí o arrastra y suelta el archivo'
|
||||||
dragDrop: Arrastra y suelta aquí
|
dragDrop: Arrastra y suelta aquí
|
||||||
|
search: Buscar reclamación
|
||||||
|
searchInfo: Puedes buscar por ID de la reclamación o nombre del cliente
|
||||||
|
|
|
@ -44,7 +44,10 @@ InvoiceIn:
|
||||||
country: Country
|
country: Country
|
||||||
params:
|
params:
|
||||||
search: Id or supplier name
|
search: Id or supplier name
|
||||||
account: Ledger account
|
|
||||||
correctingFk: Rectificative
|
|
||||||
correctedFk: Corrected
|
correctedFk: Corrected
|
||||||
isBooked: Is booked
|
isBooked: Is booked
|
||||||
|
invoicein:
|
||||||
|
params:
|
||||||
|
account: Ledger account
|
||||||
|
correctingFk: Rectificative
|
||||||
|
|
|
@ -42,6 +42,9 @@ InvoiceIn:
|
||||||
country: País
|
country: País
|
||||||
params:
|
params:
|
||||||
search: Id o nombre proveedor
|
search: Id o nombre proveedor
|
||||||
|
correctedFk: Rectificada
|
||||||
|
invoicein:
|
||||||
|
params:
|
||||||
account: Cuenta contable
|
account: Cuenta contable
|
||||||
correctingFk: Rectificativa
|
correctingFk: Rectificativa
|
||||||
correctedFk: Rectificada
|
|
||||||
|
|
|
@ -39,6 +39,7 @@ const getUrl = (section) => `#/supplier/${entityId.value}/${section}`;
|
||||||
:url="`Suppliers/${entityId}/getSummary`"
|
:url="`Suppliers/${entityId}/getSummary`"
|
||||||
@on-fetch="(data) => setData(data)"
|
@on-fetch="(data) => setData(data)"
|
||||||
data-key="SupplierSummary"
|
data-key="SupplierSummary"
|
||||||
|
module-name="Supplier"
|
||||||
>
|
>
|
||||||
<template #header>
|
<template #header>
|
||||||
<span>{{ supplier.id }} - {{ supplier.name }}</span>
|
<span>{{ supplier.id }} - {{ supplier.name }}</span>
|
||||||
|
|
|
@ -201,7 +201,7 @@ const getExpeditionState = async (expedition) => {
|
||||||
|
|
||||||
const openGrafana = (expeditionFk) => {
|
const openGrafana = (expeditionFk) => {
|
||||||
useOpenURL(
|
useOpenURL(
|
||||||
`https://grafana.verdnatura.es/d/d552ab74-85b4-4e7f-a279-fab7cd9c6124/control-de-expediciones?orgId=1&var-expeditionFk=${expeditionFk}`
|
`https://grafana.verdnatura.es/d/de1njb6p5answd/control-de-expediciones?orgId=1&var-expeditionFk=${expeditionFk}`
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -597,7 +597,7 @@ const getColor = (percentage) => {
|
||||||
v-if="entry.isCustomInspectionRequired"
|
v-if="entry.isCustomInspectionRequired"
|
||||||
name="warning"
|
name="warning"
|
||||||
color="negative"
|
color="negative"
|
||||||
size="xs"
|
size="md"
|
||||||
:title="t('requiresInspection')"
|
:title="t('requiresInspection')"
|
||||||
>
|
>
|
||||||
</QIcon>
|
</QIcon>
|
||||||
|
@ -627,7 +627,7 @@ const getColor = (percentage) => {
|
||||||
<QBtn
|
<QBtn
|
||||||
v-if="entry.evaNotes"
|
v-if="entry.evaNotes"
|
||||||
icon="comment"
|
icon="comment"
|
||||||
size="sm"
|
size="md"
|
||||||
flat
|
flat
|
||||||
color="primary"
|
color="primary"
|
||||||
>
|
>
|
||||||
|
|
|
@ -1,68 +1,28 @@
|
||||||
|
src/pages/Worker/Card/WorkerPBX.vue
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import { watch, ref } from 'vue';
|
|
||||||
import { useI18n } from 'vue-i18n';
|
|
||||||
import { useRoute } from 'vue-router';
|
|
||||||
|
|
||||||
import { useState } from 'src/composables/useState';
|
|
||||||
|
|
||||||
import FormModel from 'src/components/FormModel.vue';
|
import FormModel from 'src/components/FormModel.vue';
|
||||||
import VnRow from 'components/ui/VnRow.vue';
|
|
||||||
import VnInput from 'src/components/common/VnInput.vue';
|
import VnInput from 'src/components/common/VnInput.vue';
|
||||||
|
|
||||||
const { t } = useI18n();
|
|
||||||
const state = useState();
|
|
||||||
const route = useRoute();
|
|
||||||
const workerPBXForm = ref();
|
|
||||||
const extension = ref(null);
|
|
||||||
|
|
||||||
const filter = {
|
|
||||||
include: [
|
|
||||||
{
|
|
||||||
relation: 'sip',
|
|
||||||
},
|
|
||||||
],
|
|
||||||
};
|
|
||||||
|
|
||||||
watch(
|
|
||||||
() => route.params.id,
|
|
||||||
() => state.set('extension', null)
|
|
||||||
);
|
|
||||||
|
|
||||||
const onFetch = (data) => {
|
|
||||||
state.set('extension', data?.sip?.extension);
|
|
||||||
extension.value = state.get('extension');
|
|
||||||
};
|
|
||||||
|
|
||||||
const updateModelValue = (data) => {
|
|
||||||
state.set('extension', data);
|
|
||||||
workerPBXForm.value.hasChanges = true;
|
|
||||||
};
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<FormModel
|
<FormModel
|
||||||
ref="workerPBXForm"
|
model="WorkerPbx"
|
||||||
:filter="filter"
|
:url="`Workers/${$route.params.id}/sip`"
|
||||||
:url="`Workers/${route.params.id}`"
|
|
||||||
url-update="Sips"
|
url-update="Sips"
|
||||||
auto-load
|
|
||||||
:mapper="
|
:mapper="
|
||||||
() => ({
|
({ userFk, extension }) => ({
|
||||||
userFk: +route.params.id,
|
userFk,
|
||||||
extension,
|
extension,
|
||||||
})
|
})
|
||||||
"
|
"
|
||||||
model="DeviceProductionUser"
|
auto-load
|
||||||
@on-fetch="onFetch"
|
|
||||||
>
|
>
|
||||||
<template #form="{}">
|
<template #form="{ data }">
|
||||||
<VnRow>
|
<VnInput
|
||||||
<VnInput
|
:label="$t('worker.summary.sipExtension')"
|
||||||
:label="t('worker.summary.sipExtension')"
|
v-model="data.extension"
|
||||||
v-model="extension"
|
/>
|
||||||
@update:model-value="updateModelValue"
|
|
||||||
/>
|
|
||||||
</VnRow>
|
|
||||||
</template>
|
</template>
|
||||||
</FormModel>
|
</FormModel>
|
||||||
</template>
|
</template>
|
||||||
|
|
|
@ -345,7 +345,7 @@ const getMailStates = async (date) => {
|
||||||
const prevMonth = month == 1 ? 12 : month - 1;
|
const prevMonth = month == 1 ? 12 : month - 1;
|
||||||
const params = {
|
const params = {
|
||||||
month,
|
month,
|
||||||
year: selectedDateYear.value,
|
year: date.getFullYear(),
|
||||||
};
|
};
|
||||||
|
|
||||||
const curMonthStates = (await axios.get(url, { params })).data;
|
const curMonthStates = (await axios.get(url, { params })).data;
|
||||||
|
|
|
@ -102,8 +102,7 @@ const getWorkWeekElements = () => {
|
||||||
};
|
};
|
||||||
|
|
||||||
const paintWorkWeeks = async () => {
|
const paintWorkWeeks = async () => {
|
||||||
for (var i = 0; i < workWeeksElements.value.length; i++) {
|
for (const element of workWeeksElements.value) {
|
||||||
const element = workWeeksElements.value[i];
|
|
||||||
const week = Number(element.innerHTML);
|
const week = Number(element.innerHTML);
|
||||||
const weekState = workerTimeControlMailsMap.value.get(week);
|
const weekState = workerTimeControlMailsMap.value.get(week);
|
||||||
const { className, title } = stateClasses[weekState] || {};
|
const { className, title } = stateClasses[weekState] || {};
|
||||||
|
|
|
@ -4,7 +4,7 @@ import WorkerDepartmentTree from './WorkerDepartmentTree.vue';
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<VnSection data-key="WorkerDepartment">
|
<VnSection data-key="WorkerDepartment" :search-bar="false">
|
||||||
<template #body>
|
<template #body>
|
||||||
<div class="flex flex-center q-pa-md">
|
<div class="flex flex-center q-pa-md">
|
||||||
<WorkerDepartmentTree />
|
<WorkerDepartmentTree />
|
||||||
|
|
|
@ -1,19 +1,12 @@
|
||||||
import { RouterView } from 'vue-router';
|
import { RouterView } from 'vue-router';
|
||||||
|
|
||||||
export default {
|
const claimCard = {
|
||||||
name: 'Claim',
|
name: 'ClaimCard',
|
||||||
path: '/claim',
|
path: ':id',
|
||||||
|
component: () => import('src/pages/Claim/Card/ClaimCard.vue'),
|
||||||
|
redirect: { name: 'ClaimSummary' },
|
||||||
meta: {
|
meta: {
|
||||||
title: 'claims',
|
menu: [
|
||||||
icon: 'vn:claims',
|
|
||||||
moduleName: 'Claim',
|
|
||||||
keyBinding: 'r',
|
|
||||||
},
|
|
||||||
component: RouterView,
|
|
||||||
redirect: { name: 'ClaimMain' },
|
|
||||||
menus: {
|
|
||||||
main: ['ClaimList'],
|
|
||||||
card: [
|
|
||||||
'ClaimBasicData',
|
'ClaimBasicData',
|
||||||
'ClaimLines',
|
'ClaimLines',
|
||||||
'ClaimPhotos',
|
'ClaimPhotos',
|
||||||
|
@ -23,109 +16,125 @@ export default {
|
||||||
'ClaimLog',
|
'ClaimLog',
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
|
children: [
|
||||||
|
{
|
||||||
|
path: 'summary',
|
||||||
|
name: 'ClaimSummary',
|
||||||
|
meta: {
|
||||||
|
title: 'summary',
|
||||||
|
icon: 'launch',
|
||||||
|
},
|
||||||
|
component: () => import('src/pages/Claim/Card/ClaimSummary.vue'),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: 'basic-data',
|
||||||
|
name: 'ClaimBasicData',
|
||||||
|
meta: {
|
||||||
|
title: 'basicData',
|
||||||
|
icon: 'vn:settings',
|
||||||
|
acls: [{ model: 'Claim', props: 'findById', accessType: 'READ' }],
|
||||||
|
},
|
||||||
|
component: () => import('src/pages/Claim/Card/ClaimBasicData.vue'),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: 'lines',
|
||||||
|
name: 'ClaimLines',
|
||||||
|
meta: {
|
||||||
|
title: 'lines',
|
||||||
|
icon: 'vn:details',
|
||||||
|
},
|
||||||
|
component: () => import('src/pages/Claim/Card/ClaimLines.vue'),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: 'photos',
|
||||||
|
name: 'ClaimPhotos',
|
||||||
|
meta: {
|
||||||
|
title: 'photos',
|
||||||
|
icon: 'image',
|
||||||
|
},
|
||||||
|
component: () => import('src/pages/Claim/Card/ClaimPhoto.vue'),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: 'notes',
|
||||||
|
name: 'ClaimNotes',
|
||||||
|
meta: {
|
||||||
|
title: 'notes',
|
||||||
|
icon: 'draft',
|
||||||
|
},
|
||||||
|
component: () => import('src/pages/Claim/Card/ClaimNotes.vue'),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: 'development',
|
||||||
|
name: 'ClaimDevelopment',
|
||||||
|
meta: {
|
||||||
|
title: 'development',
|
||||||
|
icon: 'vn:traceability',
|
||||||
|
acls: [
|
||||||
|
{
|
||||||
|
model: 'ClaimDevelopment',
|
||||||
|
props: '*',
|
||||||
|
accessType: 'WRITE',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
component: () => import('src/pages/Claim/Card/ClaimDevelopment.vue'),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: 'action',
|
||||||
|
name: 'ClaimAction',
|
||||||
|
meta: {
|
||||||
|
title: 'action',
|
||||||
|
icon: 'vn:actions',
|
||||||
|
},
|
||||||
|
component: () => import('src/pages/Claim/Card/ClaimAction.vue'),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: 'log',
|
||||||
|
name: 'ClaimLog',
|
||||||
|
meta: {
|
||||||
|
title: 'log',
|
||||||
|
icon: 'history',
|
||||||
|
},
|
||||||
|
component: () => import('src/pages/Claim/Card/ClaimLog.vue'),
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}
|
||||||
|
|
||||||
|
export default {
|
||||||
|
name: 'Claim',
|
||||||
|
path: '/claim',
|
||||||
|
meta: {
|
||||||
|
title: 'claims',
|
||||||
|
icon: 'vn:claims',
|
||||||
|
moduleName: 'Claim',
|
||||||
|
keyBinding: 'r',
|
||||||
|
menu: ['ClaimList'],
|
||||||
|
},
|
||||||
|
component: RouterView,
|
||||||
|
redirect: { name: 'ClaimMain' },
|
||||||
children: [
|
children: [
|
||||||
{
|
{
|
||||||
name: 'ClaimMain',
|
name: 'ClaimMain',
|
||||||
path: '',
|
path: '',
|
||||||
component: () => import('src/components/common/VnModule.vue'),
|
component: () => import('src/components/common/VnModule.vue'),
|
||||||
redirect: { name: 'ClaimList' },
|
redirect: { name: 'ClaimIndexMain' },
|
||||||
children: [
|
children: [
|
||||||
{
|
{
|
||||||
name: 'ClaimList',
|
path: '',
|
||||||
path: 'list',
|
name: 'ClaimIndexMain',
|
||||||
meta: {
|
redirect: { name: 'ClaimList' },
|
||||||
title: 'list',
|
|
||||||
icon: 'view_list',
|
|
||||||
},
|
|
||||||
component: () => import('src/pages/Claim/ClaimList.vue'),
|
component: () => import('src/pages/Claim/ClaimList.vue'),
|
||||||
},
|
children: [
|
||||||
],
|
{
|
||||||
},
|
name: 'ClaimList',
|
||||||
{
|
path: 'list',
|
||||||
name: 'ClaimCard',
|
meta: {
|
||||||
path: ':id',
|
title: 'list',
|
||||||
component: () => import('src/pages/Claim/Card/ClaimCard.vue'),
|
icon: 'view_list',
|
||||||
redirect: { name: 'ClaimSummary' },
|
|
||||||
children: [
|
|
||||||
{
|
|
||||||
name: 'ClaimSummary',
|
|
||||||
path: 'summary',
|
|
||||||
meta: {
|
|
||||||
title: 'summary',
|
|
||||||
icon: 'launch',
|
|
||||||
},
|
|
||||||
component: () => import('src/pages/Claim/Card/ClaimSummary.vue'),
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: 'ClaimBasicData',
|
|
||||||
path: 'basic-data',
|
|
||||||
meta: {
|
|
||||||
title: 'basicData',
|
|
||||||
icon: 'vn:settings',
|
|
||||||
acls: [{ model: 'Claim', props: 'findById', accessType: 'READ' }],
|
|
||||||
},
|
|
||||||
component: () => import('src/pages/Claim/Card/ClaimBasicData.vue'),
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: 'ClaimLines',
|
|
||||||
path: 'lines',
|
|
||||||
meta: {
|
|
||||||
title: 'lines',
|
|
||||||
icon: 'vn:details',
|
|
||||||
},
|
|
||||||
component: () => import('src/pages/Claim/Card/ClaimLines.vue'),
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: 'ClaimPhotos',
|
|
||||||
path: 'photos',
|
|
||||||
meta: {
|
|
||||||
title: 'photos',
|
|
||||||
icon: 'image',
|
|
||||||
},
|
|
||||||
component: () => import('src/pages/Claim/Card/ClaimPhoto.vue'),
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: 'ClaimNotes',
|
|
||||||
path: 'notes',
|
|
||||||
meta: {
|
|
||||||
title: 'notes',
|
|
||||||
icon: 'draft',
|
|
||||||
},
|
|
||||||
component: () => import('src/pages/Claim/Card/ClaimNotes.vue'),
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: 'ClaimDevelopment',
|
|
||||||
path: 'development',
|
|
||||||
meta: {
|
|
||||||
title: 'development',
|
|
||||||
icon: 'vn:traceability',
|
|
||||||
acls: [
|
|
||||||
{
|
|
||||||
model: 'ClaimDevelopment',
|
|
||||||
props: '*',
|
|
||||||
accessType: 'WRITE',
|
|
||||||
},
|
},
|
||||||
],
|
},
|
||||||
},
|
claimCard,
|
||||||
component: () => import('src/pages/Claim/Card/ClaimDevelopment.vue'),
|
],
|
||||||
},
|
|
||||||
{
|
|
||||||
name: 'ClaimAction',
|
|
||||||
path: 'action',
|
|
||||||
meta: {
|
|
||||||
title: 'action',
|
|
||||||
icon: 'vn:actions',
|
|
||||||
},
|
|
||||||
component: () => import('src/pages/Claim/Card/ClaimAction.vue'),
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: 'ClaimLog',
|
|
||||||
path: 'log',
|
|
||||||
meta: {
|
|
||||||
title: 'log',
|
|
||||||
icon: 'history',
|
|
||||||
},
|
|
||||||
component: () => import('src/pages/Claim/Card/ClaimLog.vue'),
|
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in New Issue