diff --git a/src/components/DashboardHeader.tsx b/src/components/DashboardHeader.tsx index 2dc94983..07706613 100644 --- a/src/components/DashboardHeader.tsx +++ b/src/components/DashboardHeader.tsx @@ -1,5 +1,6 @@ import { PartySwitchItem } from '@pagopa/mui-italia/dist/components/PartySwitch'; import { Header } from '@pagopa/selfcare-common-frontend'; +import i18n from '@pagopa/selfcare-common-frontend/locale/locale-utils'; import { User } from '@pagopa/selfcare-common-frontend/model/User'; import { trackEvent } from '@pagopa/selfcare-common-frontend/services/analyticsService'; import { roleLabels } from '@pagopa/selfcare-common-frontend/utils/constants'; @@ -7,7 +8,6 @@ import { resolvePathVariables } from '@pagopa/selfcare-common-frontend/utils/rou import { useEffect, useMemo, useRef, useState } from 'react'; import { Trans, useTranslation } from 'react-i18next'; import { useHistory } from 'react-router-dom'; -import i18n from '@pagopa/selfcare-common-frontend/locale/locale-utils'; import withParties, { WithPartiesProps } from '../decorators/withParties'; import { useTokenExchange } from '../hooks/useTokenExchange'; import { Party } from '../model/Party'; @@ -16,7 +16,7 @@ import GenericEnvProductModal from '../pages/dashboardOverview/components/active import SessionModalInteropProduct from '../pages/dashboardOverview/components/activeProductsSection/components/SessionModalInteropProduct'; import { useAppSelector } from '../redux/hooks'; import { partiesSelectors } from '../redux/slices/partiesSlice'; -import ROUTES, { DASHBOARD_ROUTES } from '../routes'; +import ROUTES from '../routes'; import { ENV } from './../utils/env'; type Props = WithPartiesProps & { @@ -166,11 +166,8 @@ const DashboardHeader = ({ onExit, loggedUser, parties }: Props) => { party_id: selectedParty.id, }); onExit(() => { - const redirectRoute = party?.delegation - ? DASHBOARD_ROUTES.TECHPARTNER.path - : ROUTES.PARTY_DASHBOARD.path; history.push( - resolvePathVariables(redirectRoute, { + resolvePathVariables(ROUTES.PARTY_DASHBOARD.path, { partyId: selectedParty.id, }) ); diff --git a/src/model/Party.tsx b/src/model/Party.tsx index 1324a02e..96c74fef 100644 --- a/src/model/Party.tsx +++ b/src/model/Party.tsx @@ -20,7 +20,7 @@ export type Party = { urlLogo?: string; fiscalCode?: string; registeredOffice: string; - zipCode: string; + zipCode?: string; typology: string; institutionType?: string; recipientCode?: string; diff --git a/src/pages/dashboard/Dashboard.tsx b/src/pages/dashboard/Dashboard.tsx index 8e7a7159..35995254 100644 --- a/src/pages/dashboard/Dashboard.tsx +++ b/src/pages/dashboard/Dashboard.tsx @@ -1,10 +1,9 @@ import { Box, Grid, useTheme } from '@mui/material'; -import { useEffect, useMemo } from 'react'; +import { useMemo } from 'react'; import { useTranslation } from 'react-i18next'; import { useStore } from 'react-redux'; import { Route, Switch, matchPath, useHistory } from 'react-router'; import { useLocation } from 'react-router-dom'; -import { resolvePathVariables } from '@pagopa/selfcare-common-frontend/utils/routes-utils'; import withProductRolesMap from '../../decorators/withProductsRolesMap'; import withSelectedParty from '../../decorators/withSelectedParty'; import withSelectedProduct from '../../decorators/withSelectedPartyProduct'; @@ -139,15 +138,6 @@ const Dashboard = () => { strict: false, }); - useEffect(() => { - if (party) { - const redirectPath = party.delegation - ? DASHBOARD_ROUTES.TECHPARTNER.path - : DASHBOARD_ROUTES.OVERVIEW.path; - history.push(resolvePathVariables(redirectPath, { partyId: party?.partyId ?? '' })); - } - }, [party?.partyId]); - return party && products ? ( { +test('Test: Insurance company party cannot see the geotaxonomies', () => { const mockedInsuranceCompany = mockedParties[18]; renderWithProviders(); expect(screen.queryByText('Area geografica')).not.toBeInTheDocument(); }); + +test('Test: Party with taxCode and zipCode and without vatNumber', () => { + renderWithProviders(); + + expect(screen.queryByText('Partita IVA')).not.toBeInTheDocument(); + expect(screen.queryByText('Codice Fiscale')).not.toBeInTheDocument(); + expect(screen.queryByText('Codice Fiscale / P.IVA')).not.toBeInTheDocument(); + expect(mockedParties[22].registeredOffice).toBe('Via Roma, 10'); +}); + +test('Test: Party with vatNumber and without fiscalCode and zipCode', () => { + renderWithProviders(); + + expect(screen.queryByText('Partita IVA')).toBeInTheDocument(); + expect(screen.queryByText('Codice Fiscale')).not.toBeInTheDocument(); + expect(screen.queryByText('Codice Fiscale / P.IVA')).not.toBeInTheDocument(); + expect(mockedParties[23].registeredOffice).toBe('Via Garibaldi, 10'); +}); + +test('Test: Party with fiscalCode and without vatNumber and zipCode', () => { + renderWithProviders(); + + expect(screen.queryByText('Partita IVA')).not.toBeInTheDocument(); + expect(screen.queryByText('Codice Fiscale')).toBeInTheDocument(); + expect(screen.queryByText('Codice Fiscale / P.IVA')).not.toBeInTheDocument(); + expect(mockedParties[24].registeredOffice).toBe('Corso Vittorio Emanuele, 1'); +}); + +test('Test: Party with zipCode and without fiscalCode and vatNumber', () => { + renderWithProviders(); + + expect(screen.queryByText('Partita IVA')).not.toBeInTheDocument(); + expect(screen.queryByText('Codice Fiscale')).not.toBeInTheDocument(); + expect(screen.queryByText('Codice Fiscale / P.IVA')).not.toBeInTheDocument(); + expect(mockedParties[25].zipCode).toBe('38100'); +}); + +test('Test: Party with different vatNumber and fiscalCode without zipCode', () => { + renderWithProviders(); + + expect(screen.queryByText('Partita IVA')).toBeInTheDocument(); + expect(screen.queryByText('Codice Fiscale')).toBeInTheDocument(); + expect(screen.queryByText('Codice Fiscale / P.IVA')).not.toBeInTheDocument(); + expect(mockedParties[26].registeredOffice).toBe('Via Etnea, 100'); +}); + +test('Test: Party with zipCode and different fiscalCode and vatNumber', () => { + renderWithProviders(); + + expect(screen.queryByText('Partita IVA')).toBeInTheDocument(); + expect(screen.queryByText('Codice Fiscale')).toBeInTheDocument(); + expect(screen.queryByText('Codice Fiscale / P.IVA')).not.toBeInTheDocument(); + expect(mockedParties[27].zipCode).toBe('74100'); +}); + +test('Test: Party with zipCode and equal fiscalCode and vatNumber', () => { + renderWithProviders(); + + expect(screen.queryByText('Partita IVA')).not.toBeInTheDocument(); + expect(screen.queryByText('Codice Fiscale')).not.toBeInTheDocument(); + expect(screen.queryByText('Codice Fiscale / P.IVA')).toBeInTheDocument(); + expect(mockedParties[13].zipCode).toBe('20121'); +}); diff --git a/src/pages/dashboardOverview/components/partyCard/components/PartyDetail.tsx b/src/pages/dashboardOverview/components/partyCard/components/PartyDetail.tsx index 32d3f8d9..6694ae28 100644 --- a/src/pages/dashboardOverview/components/partyCard/components/PartyDetail.tsx +++ b/src/pages/dashboardOverview/components/partyCard/components/PartyDetail.tsx @@ -322,7 +322,8 @@ export default function PartyDetail({ party }: Props) { ) : undefined} - {(isInstitutionTypePA && !isTaxCodeEquals2Piva) || !isInstitutionTypePA ? ( + {(isInstitutionTypePA && !isTaxCodeEquals2Piva && party.fiscalCode) || + !isInstitutionTypePA ? ( <> {/* fiscalCode */} @@ -376,7 +377,7 @@ export default function PartyDetail({ party }: Props) { )} {/* fiscalCode */} - {isInstitutionTypePA && isTaxCodeEquals2Piva && ( + {isInstitutionTypePA && isTaxCodeEquals2Piva && party.fiscalCode && ( <> @@ -407,7 +408,7 @@ export default function PartyDetail({ party }: Props) { )} <> {/* vatNumber */} - {!isTaxCodeEquals2Piva && ( + {!isTaxCodeEquals2Piva && lastPartyVatNumber && ( <> @@ -472,7 +473,9 @@ export default function PartyDetail({ party }: Props) { arrow={true} > - {party.registeredOffice + ' - ' + party.zipCode} + {party.zipCode + ? party.registeredOffice + ' - ' + party.zipCode + : party.registeredOffice} diff --git a/src/services/__mocks__/partyService.ts b/src/services/__mocks__/partyService.ts index 51aaf24f..25e0eead 100644 --- a/src/services/__mocks__/partyService.ts +++ b/src/services/__mocks__/partyService.ts @@ -112,6 +112,42 @@ export const mockedBaseParties: Array = [ status: 'ACTIVE', userRole: 'ADMIN', }, + { + partyId: '46', + description: 'Comune di Alberobello', + status: 'ACTIVE', + userRole: 'ADMIN', + }, + { + partyId: '47', + description: 'Comune di Novara', + status: 'ACTIVE', + userRole: 'ADMIN', + }, + { + partyId: '48', + description: 'Comune di Salerno', + status: 'ACTIVE', + userRole: 'ADMIN', + }, + { + partyId: '49', + description: 'Comune di Trento', + status: 'ACTIVE', + userRole: 'ADMIN', + }, + { + partyId: '50', + description: 'Comune di Catania', + status: 'ACTIVE', + userRole: 'ADMIN', + }, + { + partyId: '51', + description: 'Comune di Taranto', + status: 'ACTIVE', + userRole: 'ADMIN', + }, { partyId: '5dbec5e1-4262-4d00-a493-916e6171856a', description: 'Asea Azienda Speciale', @@ -155,7 +191,6 @@ export const mockedParties: Array = [ institutionType: 'PA', recipientCode: 'CGDAS23A', geographicTaxonomies: undefined, - vatNumber: '111111111141', supportEmail: '', products: [ { @@ -816,7 +851,7 @@ export const mockedParties: Array = [ { code: '456723', desc: 'Carugate - Comune' }, { code: '665543', desc: 'Cernusco sul Naviglio - Comune' }, ], // Use case with three taxonomy - vatNumber: '34434356575', + vatNumber: '76859430212', supportEmail: '', products: [ // Use case with two delegable products @@ -826,7 +861,7 @@ export const mockedParties: Array = [ productOnBoardingStatus: ProductOnBoardingStatusEnum.ACTIVE, userRole: 'ADMIN', billing: { - vatNumber: '81001510528', + vatNumber: '76859430212', recipientCode: 'BBGG34D', publicServices: true, }, @@ -861,7 +896,7 @@ export const mockedParties: Array = [ productOnBoardingStatus: ProductOnBoardingStatusEnum.REJECTED, userRole: 'ADMIN', billing: { - vatNumber: '81001510528', + vatNumber: '76859430212', recipientCode: 'DDFFRT', publicServices: true, }, @@ -1260,6 +1295,219 @@ export const mockedParties: Array = [ }, ], }, + // Use case without vatNumber, taxCode and zipCode + { + description: 'Comune di Alberobello', + urlLogo: 'image', + partyId: '46', + digitalAddress: 'comune.Alberobello@pec.it', + category: 'Comuni e loro Consorzi e Associazioni', + registeredOffice: 'Via Roma, 10', + typology: 'Pubblica Amministrazione', + externalId: 'externalId4', + originId: 'originId4', + origin: 'IPA', + institutionType: 'PA', + recipientCode: 'PTSCMA44D', + geographicTaxonomies: [{ code: '5454732', desc: 'Alberobello - Comune' }], + supportEmail: 'support@comune.Alberobello.it', + products: [ + { + productId: 'prod-pagopa', + authorized: true, + productOnBoardingStatus: ProductOnBoardingStatusEnum.PENDING, + userRole: 'ADMIN', + billing: { + recipientCode: 'POIUYTRE', + publicServices: true, + }, + }, + { + productId: 'prod-pn', + authorized: true, + productOnBoardingStatus: ProductOnBoardingStatusEnum.ACTIVE, + userRole: 'ADMIN', + billing: { + recipientCode: 'pppp', + publicServices: true, + }, + }, + ], + delegation: false, + status: undefined, + userRole: undefined, + }, + // Use case with vatNumber and without fiscalCode and zipCode + { + description: 'Comune di Novara', + urlLogo: 'image', + partyId: '47', + digitalAddress: 'comune.novara@pec.it', + category: 'Comuni e loro Consorzi e Associazioni', + registeredOffice: 'Via Garibaldi, 10', + typology: 'Pubblica Amministrazione', + externalId: 'extId47', + originId: 'originId47', + origin: 'IPA', + institutionType: 'PA', + recipientCode: 'NOVCMA47Z', + geographicTaxonomies: [{ code: '4545554', desc: 'Novara - Comune' }], + vatNumber: '12345678901', + supportEmail: 'support@comune.novara.it', + products: [ + { + productId: 'prod-pagopa', + authorized: true, + productOnBoardingStatus: ProductOnBoardingStatusEnum.ACTIVE, + userRole: 'ADMIN', + billing: { + vatNumber: '98765432101', + recipientCode: 'NOVCMA47Z', + publicServices: true, + }, + }, + ], + delegation: false, + status: undefined, + userRole: undefined, + }, + // Use case with fiscalCode and without vatNumber and zipCode + { + description: 'Comune di Salerno', + urlLogo: 'image', + partyId: '48', + digitalAddress: 'comune.salerno@pec.it', + category: 'Comuni e loro Consorzi e Associazioni', + registeredOffice: 'Corso Vittorio Emanuele, 1', + typology: 'Pubblica Amministrazione', + externalId: 'extId48', + originId: 'originId48', + origin: 'IPA', + institutionType: 'PA', + recipientCode: 'SLRNCM48Y', + geographicTaxonomies: [{ code: '863413', desc: 'Salerno - Comune' }], + fiscalCode: '98765432101', + supportEmail: 'support@comune.salerno.it', + products: [ + { + productId: 'prod-pagopa', + authorized: true, + productOnBoardingStatus: ProductOnBoardingStatusEnum.PENDING, + userRole: 'ADMIN', + billing: { + recipientCode: 'SLRNCM48Y', + publicServices: true, + }, + }, + ], + delegation: false, + status: undefined, + userRole: undefined, + }, + // Use case with zipCode and without fiscalCode and vatNumber + { + description: 'Comune di Trento', + urlLogo: 'image', + partyId: '49', + digitalAddress: 'comune.trento@pec.it', + category: 'Comuni e loro Consorzi e Associazioni', + registeredOffice: 'Piazza Duomo, 1', + typology: 'Pubblica Amministrazione', + externalId: 'extId49', + originId: 'originId49', + origin: 'IPA', + institutionType: 'PA', + recipientCode: 'TRNTCM49X', + geographicTaxonomies: [{ code: '9944123', desc: 'Trento - Comune' }], + zipCode: '38100', + supportEmail: 'support@comune.trento.it', + products: [ + { + productId: 'prod-pagopa', + authorized: true, + productOnBoardingStatus: ProductOnBoardingStatusEnum.PENDING, + userRole: 'ADMIN', + billing: { + recipientCode: 'TRNTCM49X', + publicServices: true, + }, + }, + ], + delegation: false, + status: undefined, + userRole: undefined, + }, + // Use case with different vatNumber and fiscalCode without zipCode + { + description: 'Comune di Catania', + urlLogo: 'image', + partyId: '50', + digitalAddress: 'comune.catania@pec.it', + category: 'Comuni e loro Consorzi e Associazioni', + registeredOffice: 'Via Etnea, 100', + typology: 'Pubblica Amministrazione', + externalId: 'extId50', + originId: 'originId50', + origin: 'IPA', + institutionType: 'PA', + recipientCode: 'CTNCMA50W', + geographicTaxonomies: [{ code: '441234', desc: 'Catania - Comune' }], + vatNumber: '11223344556', + fiscalCode: '65432109876', + supportEmail: 'support@comune.catania.it', + products: [ + { + productId: 'prod-pagopa', + authorized: true, + productOnBoardingStatus: ProductOnBoardingStatusEnum.ACTIVE, + userRole: 'ADMIN', + billing: { + vatNumber: '11223344556', + recipientCode: 'CTNCMA50W', + publicServices: true, + }, + }, + ], + delegation: false, + status: undefined, + userRole: undefined, + }, + // Use case with all data + { + description: 'Comune di Taranto', + urlLogo: 'image', + partyId: '51', + digitalAddress: 'comune.taranto@pec.it', + category: 'Comuni e loro Consorzi e Associazioni', + registeredOffice: 'Via Garibaldi, 10', + typology: 'Pubblica Amministrazione', + externalId: 'extId51', + originId: 'originId51', + origin: 'IPA', + institutionType: 'PA', + recipientCode: 'TRNTMA51T', + geographicTaxonomies: [{ code: '4400001', desc: 'Taranto - Comune' }], + vatNumber: '98765432109', + fiscalCode: '12345678901', + zipCode: '74100', + supportEmail: 'support@comune.taranto.it', + products: [ + { + productId: 'prod-pagopa', + authorized: true, + productOnBoardingStatus: ProductOnBoardingStatusEnum.ACTIVE, + userRole: 'ADMIN', + billing: { + vatNumber: '98765432109', + recipientCode: 'TRNTMA51T', + publicServices: true, + }, + }, + ], + delegation: false, + status: 'ACTIVE', + userRole: 'ADMIN', + }, ]; export const mockedGeotaxonomies: Array = [