forked from verdnatura/salix-front
refactor: refs #7404 route list add table
This commit is contained in:
parent
61bd1eaf04
commit
11266b602c
|
@ -1,7 +1,6 @@
|
||||||
<script setup>
|
<script setup>
|
||||||
import { onMounted, onUnmounted, ref } from 'vue';
|
import { onMounted, onBeforeUnmount, ref, nextTick } from 'vue';
|
||||||
import { useStateStore } from 'stores/useStateStore';
|
import { useStateStore } from 'stores/useStateStore';
|
||||||
import { onBeforeRouteLeave } from 'vue-router';
|
|
||||||
|
|
||||||
const stateStore = useStateStore();
|
const stateStore = useStateStore();
|
||||||
const actions = ref(null);
|
const actions = ref(null);
|
||||||
|
@ -26,10 +25,7 @@ onMounted(() => {
|
||||||
if (data.value) observer.observe(data.value, opts);
|
if (data.value) observer.observe(data.value, opts);
|
||||||
});
|
});
|
||||||
|
|
||||||
onUnmounted(() => {
|
onBeforeUnmount(() => stateStore.toggleSubToolbar());
|
||||||
stateStore.toggleSubToolbar();
|
|
||||||
});
|
|
||||||
onBeforeRouteLeave((to, from) => {});
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
|
|
|
@ -240,7 +240,24 @@ onMounted(() => {
|
||||||
/>
|
/>
|
||||||
<FetchData url="AgencyModes" @on-fetch="(data) => (agencyList = data)" auto-load />
|
<FetchData url="AgencyModes" @on-fetch="(data) => (agencyList = data)" auto-load />
|
||||||
<FetchData url="Vehicles" @on-fetch="(data) => (vehicleList = data)" auto-load />
|
<FetchData url="Vehicles" @on-fetch="(data) => (vehicleList = data)" auto-load />
|
||||||
<VnSubToolbar>
|
<VnSubToolbar />
|
||||||
|
<VnTable
|
||||||
|
ref="tableRef"
|
||||||
|
data-key="RouteList"
|
||||||
|
url="Routes/filter"
|
||||||
|
:columns="columns"
|
||||||
|
:right-search="true"
|
||||||
|
default-mode="table"
|
||||||
|
:is-editable="true"
|
||||||
|
:create="{
|
||||||
|
urlCreate: 'Routes',
|
||||||
|
title: t('Create route'),
|
||||||
|
onDataSaved: () => tableRef.reload(),
|
||||||
|
}"
|
||||||
|
save-url="WorkerIncomes/crud"
|
||||||
|
:disable-option="{ card: true }"
|
||||||
|
>
|
||||||
|
<template #moreBeforeActions>
|
||||||
<QBtn
|
<QBtn
|
||||||
icon="vn:clone"
|
icon="vn:clone"
|
||||||
color="primary"
|
color="primary"
|
||||||
|
@ -268,23 +285,8 @@ onMounted(() => {
|
||||||
>
|
>
|
||||||
<QTooltip>{{ t('Mark as served') }}</QTooltip>
|
<QTooltip>{{ t('Mark as served') }}</QTooltip>
|
||||||
</QBtn>
|
</QBtn>
|
||||||
</VnSubToolbar>
|
</template>
|
||||||
<VnTable
|
</VnTable>
|
||||||
ref="tableRef"
|
|
||||||
data-key="RouteList"
|
|
||||||
url="Routes/filter"
|
|
||||||
:columns="columns"
|
|
||||||
:right-search="true"
|
|
||||||
default-mode="table"
|
|
||||||
:is-editable="true"
|
|
||||||
:create="{
|
|
||||||
urlCreate: 'Routes',
|
|
||||||
title: t('Create route'),
|
|
||||||
onDataSaved: () => tableRef.reload(),
|
|
||||||
}"
|
|
||||||
save-url="WorkerIncomes/crud"
|
|
||||||
:disable-option="{ card: true }"
|
|
||||||
/>
|
|
||||||
|
|
||||||
<!-- >
|
<!-- >
|
||||||
<VnPaginate
|
<VnPaginate
|
||||||
|
|
|
@ -14,7 +14,6 @@ onMounted(() => (stateStore.leftDrawer = false));
|
||||||
</QScrollArea>
|
</QScrollArea>
|
||||||
</QDrawer>
|
</QDrawer>
|
||||||
<QPageContainer>
|
<QPageContainer>
|
||||||
<VnSubToolbar />
|
<RouterView></RouterView>
|
||||||
<RouterView v-if="stateStore.isSubToolbarShown()"></RouterView>
|
|
||||||
</QPageContainer>
|
</QPageContainer>
|
||||||
</template>
|
</template>
|
||||||
|
|
|
@ -17,7 +17,7 @@ export const useStateStore = defineStore('stateStore', () => {
|
||||||
|
|
||||||
function toggleSubToolbar() {
|
function toggleSubToolbar() {
|
||||||
subToolbar.value = !subToolbar.value;
|
subToolbar.value = !subToolbar.value;
|
||||||
/* console.log('subToolbar.value: ', subToolbar.value); */
|
console.log('subToolbar.value: ', subToolbar.value);
|
||||||
}
|
}
|
||||||
|
|
||||||
function setMounted() {
|
function setMounted() {
|
||||||
|
|
|
@ -0,0 +1,39 @@
|
||||||
|
describe('AgencyWorkCenter', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
cy.viewport(1920, 1080);
|
||||||
|
cy.login('developer');
|
||||||
|
cy.visit(`/#/agency/11/workCenter`);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('assign workCenter', () => {
|
||||||
|
cy.get('.q-page-sticky > div > .q-btn > .q-btn__content > .q-icon').click();
|
||||||
|
cy.get(
|
||||||
|
'.vn-row > .q-field > .q-field__inner > .q-field__control > .q-field__control-container'
|
||||||
|
).type('workCenterOne{enter}');
|
||||||
|
cy.get('.q-notification__message').should('have.text', 'Data created');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('delete workCenter', () => {
|
||||||
|
cy.get('.q-item__section--side > .q-btn > .q-btn__content > .q-icon').click();
|
||||||
|
cy.get('.q-notification__message').should(
|
||||||
|
'have.text',
|
||||||
|
'WorkCenter removed successfully'
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('error on duplicate workCenter', () => {
|
||||||
|
cy.get('.q-page-sticky > div > .q-btn > .q-btn__content > .q-icon').click();
|
||||||
|
cy.get(
|
||||||
|
'.vn-row > .q-field > .q-field__inner > .q-field__control > .q-field__control-container'
|
||||||
|
).type('workCenterOne{enter}');
|
||||||
|
cy.get('.q-notification__message').should('have.text', 'Data created');
|
||||||
|
cy.get('.q-page-sticky > div > .q-btn > .q-btn__content > .q-icon').click();
|
||||||
|
cy.get(
|
||||||
|
'.vn-row > .q-field > .q-field__inner > .q-field__control > .q-field__control-container'
|
||||||
|
).type('workCenterOne{enter}');
|
||||||
|
|
||||||
|
cy.get(
|
||||||
|
':nth-child(2) > .q-notification__wrapper > .q-notification__content > .q-notification__message'
|
||||||
|
).should('have.text', 'This workCenter is already assigned to this agency');
|
||||||
|
});
|
||||||
|
});
|
|
@ -0,0 +1,21 @@
|
||||||
|
/// <reference types="cypress" />
|
||||||
|
describe('VnBreadcrumbs', () => {
|
||||||
|
const firstCard = '.q-infinite-scroll > :nth-child(1)';
|
||||||
|
const lastBreadcrumb = '.q-breadcrumbs--last > .q-breadcrumbs__el';
|
||||||
|
beforeEach(() => {
|
||||||
|
cy.login('developer');
|
||||||
|
cy.visit('/');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should not be breadcrumbs', () => {
|
||||||
|
cy.get('.q-breadcrumbs').should('not.exist');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should get the correct breadcrumbs', () => {
|
||||||
|
cy.visit('#/customer/list');
|
||||||
|
cy.get('.q-breadcrumbs__el').should('have.length', 2);
|
||||||
|
|
||||||
|
cy.get(firstCard).click();
|
||||||
|
cy.get(`${lastBreadcrumb} > .q-icon`).should('have.text', 'launch');
|
||||||
|
});
|
||||||
|
});
|
|
@ -0,0 +1,56 @@
|
||||||
|
const locationOptions = '[role="listbox"] > div.q-virtual-scroll__content > .q-item';
|
||||||
|
describe('VnLocation', () => {
|
||||||
|
const dialogInputs = '.q-dialog label input';
|
||||||
|
describe('Worker Create', () => {
|
||||||
|
const inputLocation = '.q-form input[aria-label="Location"]';
|
||||||
|
beforeEach(() => {
|
||||||
|
cy.viewport(1280, 720);
|
||||||
|
cy.login('developer');
|
||||||
|
cy.visit('/#/worker/create', { timeout: 5000 });
|
||||||
|
cy.waitForElement('.q-card');
|
||||||
|
});
|
||||||
|
it('Show all options', function () {
|
||||||
|
cy.get(inputLocation).click();
|
||||||
|
cy.get(locationOptions).should('have.length.at.least', 5);
|
||||||
|
});
|
||||||
|
it('input filter location as "al"', function () {
|
||||||
|
cy.get(inputLocation).click();
|
||||||
|
cy.get(inputLocation).clear();
|
||||||
|
cy.get(inputLocation).type('al');
|
||||||
|
cy.get(locationOptions).should('have.length.at.least', 3);
|
||||||
|
});
|
||||||
|
it('input filter location as "ecuador"', function () {
|
||||||
|
cy.get(inputLocation).click();
|
||||||
|
cy.get(inputLocation).clear();
|
||||||
|
cy.get(inputLocation).type('ecuador');
|
||||||
|
cy.get(locationOptions).should('have.length.at.least', 1);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
describe('Fiscal-data', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
cy.viewport(1280, 720);
|
||||||
|
cy.login('developer');
|
||||||
|
cy.visit('/#/supplier/567/fiscal-data', { timeout: 7000 });
|
||||||
|
cy.waitForElement('.q-form');
|
||||||
|
});
|
||||||
|
it('Create postCode', function () {
|
||||||
|
cy.get('.q-form > .q-card > .vn-row:nth-child(6) .--add-icon').click();
|
||||||
|
cy.get('.q-card > h1').should('have.text', 'New postcode');
|
||||||
|
cy.get(dialogInputs).eq(0).clear('12');
|
||||||
|
cy.get(dialogInputs).eq(0).type('1234453');
|
||||||
|
cy.selectOption(
|
||||||
|
'.q-dialog__inner > .column > #formModel > .q-card > :nth-child(4) > .q-select > .q-field__inner > .q-field__control ',
|
||||||
|
'Valencia'
|
||||||
|
);
|
||||||
|
cy.selectOption(
|
||||||
|
'.q-dialog__inner > .column > #formModel > .q-card > :nth-child(5) > .q-select > .q-field__inner > .q-field__control ',
|
||||||
|
'Province one'
|
||||||
|
);
|
||||||
|
cy.selectOption(
|
||||||
|
'.q-dialog__inner > .column > #formModel > .q-card > :nth-child(6) > .q-select > .q-field__inner > .q-field__control ',
|
||||||
|
'España'
|
||||||
|
);
|
||||||
|
cy.get('.q-mt-lg > .q-btn--standard').click();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
|
@ -0,0 +1,25 @@
|
||||||
|
/// <reference types="cypress" />
|
||||||
|
describe('VnLog', () => {
|
||||||
|
const chips = [
|
||||||
|
':nth-child(1) > :nth-child(1) > .q-item__label > .q-chip > .q-chip__content',
|
||||||
|
':nth-child(2) > :nth-child(1) > .q-item__label > .q-chip > .q-chip__content',
|
||||||
|
];
|
||||||
|
beforeEach(() => {
|
||||||
|
cy.login('developer');
|
||||||
|
cy.visit(`/#/claim/${1}/log`);
|
||||||
|
cy.openRightMenu();
|
||||||
|
});
|
||||||
|
// Se tiene que cambiar el Accept-Language a 'en', ya hay una tarea para eso #7189.
|
||||||
|
xit('should filter by insert actions', () => {
|
||||||
|
cy.checkOption(':nth-child(7) > .q-checkbox');
|
||||||
|
cy.get('.q-page').click();
|
||||||
|
cy.validateContent(chips[0], 'Document');
|
||||||
|
cy.validateContent(chips[1], 'Beginning');
|
||||||
|
});
|
||||||
|
|
||||||
|
xit('should filter by entity', () => {
|
||||||
|
cy.selectOption('.q-drawer--right .q-item > .q-select', 'Claim');
|
||||||
|
cy.get('.q-page').click();
|
||||||
|
cy.validateContent(chips[0], 'Claim');
|
||||||
|
});
|
||||||
|
});
|
|
@ -0,0 +1,36 @@
|
||||||
|
/// <reference types="cypress" />
|
||||||
|
describe('VnSearchBar', () => {
|
||||||
|
const employeeId = ' #1';
|
||||||
|
const salesPersonId = ' #18';
|
||||||
|
const idGap = '.q-item > .q-item__label';
|
||||||
|
const vnTableRow = '.q-virtual-scroll__content';
|
||||||
|
beforeEach(() => {
|
||||||
|
cy.login('developer');
|
||||||
|
cy.visit('#/customer/list');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should redirect to customer summary page', () => {
|
||||||
|
searchAndCheck('1', employeeId);
|
||||||
|
searchAndCheck('salesPerson', salesPersonId);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should stay on the list page if there are several results or none', () => {
|
||||||
|
cy.writeSearchbar('salesA{enter}');
|
||||||
|
checkTableLength(2);
|
||||||
|
|
||||||
|
cy.clearSearchbar();
|
||||||
|
|
||||||
|
cy.writeSearchbar('0{enter}');
|
||||||
|
checkTableLength(0);
|
||||||
|
});
|
||||||
|
|
||||||
|
const searchAndCheck = (searchTerm, expectedText) => {
|
||||||
|
cy.clearSearchbar();
|
||||||
|
cy.writeSearchbar(`${searchTerm}{enter}`);
|
||||||
|
cy.get(idGap).should('have.text', expectedText);
|
||||||
|
};
|
||||||
|
|
||||||
|
const checkTableLength = (expectedLength) => {
|
||||||
|
cy.get(vnTableRow).find('tr').should('have.length', expectedLength);
|
||||||
|
};
|
||||||
|
});
|
Loading…
Reference in New Issue