Skip to content

Commit

Permalink
refactor[IOBP-1119]: Adapt IDPay custom table and list to design syst…
Browse files Browse the repository at this point in the history
…em components (#6597)

## Short description
> [!WARNING]
> This PR depends on #6586 

This pull request focuses on enhancing the integration of the design
system list components for IDPay screens currently utilizing custom
tables and lists

## List of changes proposed in this pull request
- Apply `ListItem` to IDPay timeline screens
- Apply `ListItem` to IDPay initiative screens
- Delete unused custom `Table` component moving its type in main file

## How to test
Ensure that all replaced components are properly aligned with design
standards

## Preview


https://github.com/user-attachments/assets/f5da985d-9c37-43ef-b80f-558645997f5c

---------

Co-authored-by: Alessandro <[email protected]>
  • Loading branch information
LeleDallas and Hantex9 authored Jan 17, 2025
1 parent 58557e7 commit d76c8c9
Show file tree
Hide file tree
Showing 9 changed files with 257 additions and 346 deletions.
50 changes: 0 additions & 50 deletions ts/features/idpay/common/components/Table.tsx

This file was deleted.

192 changes: 104 additions & 88 deletions ts/features/idpay/details/components/BeneficiaryDetailsContent.tsx
Original file line number Diff line number Diff line change
@@ -1,11 +1,20 @@
import { Body, BodySmall, VSpacer } from "@pagopa/io-app-design-system";
import {
Body,
BodySmall,
Divider,
ListItemHeader,
ListItemInfo,
ListItemTransaction,
VSpacer,
WithTestID
} from "@pagopa/io-app-design-system";
import { NonEmptyString } from "@pagopa/ts-commons/lib/strings";
import { useNavigation } from "@react-navigation/native";
import { sequenceS } from "fp-ts/lib/Apply";
import * as O from "fp-ts/lib/Option";
import { pipe } from "fp-ts/lib/function";
import React from "react";
import { StyleSheet, View } from "react-native";
import { View } from "react-native";
import Placeholder from "rn-placeholder";
import {
InitiativeDTO,
Expand All @@ -17,22 +26,25 @@ import {
RewardValueDTO,
RewardValueTypeEnum
} from "../../../../../definitions/idpay/RewardValueDTO";
import { IOStyles } from "../../../../components/core/variables/IOStyles";
import I18n from "../../../../i18n";
import {
AppParamsList,
IOStackNavigationProp
} from "../../../../navigation/params/AppParamsList";
import { format } from "../../../../utils/dates";
import { SERVICES_ROUTES } from "../../../services/common/navigation/routes";
import { Table, TableRow } from "../../common/components/Table";
import { formatNumberCurrencyOrDefault } from "../../common/utils/strings";
import { IdPayUnsubscriptionRoutes } from "../../unsubscription/navigation/routes";
import {
InitiativeRulesInfoBox,
InitiativeRulesInfoBoxSkeleton
} from "./InitiativeRulesInfoBox";

type TableRow = WithTestID<{
label: string;
value: string | React.ReactNode;
}>;

export type BeneficiaryDetailsProps =
| {
isLoading?: false;
Expand Down Expand Up @@ -210,80 +222,95 @@ const BeneficiaryDetailsContent = (props: BeneficiaryDetailsProps) => {
);
};

const summaryData = [
{
label: I18n.t("idpay.initiative.beneficiaryDetails.status"),
value: statusString,
testID: "statusTestID"
},
{
label: I18n.t("idpay.initiative.beneficiaryDetails.endDate"),
value: endDateString,
testID: "endDateTestID"
},
{
label: I18n.t("idpay.initiative.beneficiaryDetails.amount"),
value: formatNumberCurrencyOrDefault(initiativeDetails.amountCents),
testID: "amountTestID"
},
...getTypeDependantTableRows()
];

const enrollmentData = [
{
label: I18n.t("idpay.initiative.beneficiaryDetails.enrollmentDate"),
value: onboardingDateString,
testID: "onboardingDateTestID"
},
{
label: I18n.t("idpay.initiative.beneficiaryDetails.protocolNumber"),
value: "-",
testID: "protocolTestID"
}
];

const spendingRulesData = [
{
label: I18n.t("idpay.initiative.beneficiaryDetails.spendFrom"),
value: fruitionStartDateString,
testID: "fruitionStartDateTestID"
},
{
label: I18n.t("idpay.initiative.beneficiaryDetails.spendTo"),
value: fruitionEndDateString,
testID: "fruitionEndDateTestID"
},
rewardRuleRow
];

const renderTableRow = (data: Array<TableRow>) =>
data.map((row, i) => (
<>
<ListItemInfo
key={row.testID}
label={row.label}
value={row.value}
testID={row.testID}
/>
{i !== data.length - 1 && <Divider />}
</>
));

return (
<>
{ruleInfoBox}
<Table
title={I18n.t("idpay.initiative.beneficiaryDetails.summary")}
rows={[
{
label: I18n.t("idpay.initiative.beneficiaryDetails.status"),
value: statusString,
testID: "statusTestID"
},
{
label: I18n.t("idpay.initiative.beneficiaryDetails.endDate"),
value: endDateString,
testID: "endDateTestID"
},
{
label: I18n.t("idpay.initiative.beneficiaryDetails.amount"),
value: formatNumberCurrencyOrDefault(initiativeDetails.amountCents),
testID: "amountTestID"
},
...getTypeDependantTableRows()
]}
<ListItemHeader
label={I18n.t("idpay.initiative.beneficiaryDetails.summary")}
/>
{renderTableRow(summaryData)}
<VSpacer size={8} />
<BodySmall weight="Regular" color="bluegrey">
{lastUpdateString}
</BodySmall>
<VSpacer size={8} />
<Table
title={I18n.t("idpay.initiative.beneficiaryDetails.spendingRules")}
rows={[
{
label: I18n.t("idpay.initiative.beneficiaryDetails.spendFrom"),
value: fruitionStartDateString,
testID: "fruitionStartDateTestID"
},
{
label: I18n.t("idpay.initiative.beneficiaryDetails.spendTo"),
value: fruitionEndDateString,
testID: "fruitionEndDateTestID"
},
rewardRuleRow
]}
<ListItemHeader
label={I18n.t("idpay.initiative.beneficiaryDetails.spendingRules")}
/>
<VSpacer size={8} />
<Table
title={I18n.t("idpay.initiative.beneficiaryDetails.enrollmentDetails")}
rows={[
{
label: I18n.t("idpay.initiative.beneficiaryDetails.enrollmentDate"),
value: onboardingDateString,
testID: "onboardingDateTestID"
},
{
label: I18n.t("idpay.initiative.beneficiaryDetails.protocolNumber"),
value: "-",
testID: "protocolTestID"
}
]}
{renderTableRow(spendingRulesData)}
<ListItemHeader
label={I18n.t("idpay.initiative.beneficiaryDetails.enrollmentDetails")}
/>
<VSpacer size={24} />
<View style={styles.linkRow}>
<Body weight="Semibold" asLink onPress={handlePrivacyLinkPress}>
{I18n.t("idpay.initiative.beneficiaryDetails.buttons.privacy")}
</Body>
</View>
<View style={styles.linkRow}>
<Body weight="Semibold" asLink onPress={handleUnsubscribePress}>
{I18n.t("idpay.initiative.beneficiaryDetails.buttons.unsubscribe", {
initiativeName
})}
</Body>
</View>
{renderTableRow(enrollmentData)}
<VSpacer size={16} />
<Body weight="Semibold" asLink onPress={handlePrivacyLinkPress}>
{I18n.t("idpay.initiative.beneficiaryDetails.buttons.privacy")}
</Body>
<VSpacer size={16} />
<Body weight="Semibold" asLink onPress={handleUnsubscribePress}>
{I18n.t("idpay.initiative.beneficiaryDetails.buttons.unsubscribe", {
initiativeName
})}
</Body>
<VSpacer size={48} />
</>
);
Expand All @@ -297,22 +324,17 @@ const BeneficiaryDetailsContentSkeleton = () => (
<VSpacer size={32} />
<Placeholder.Box animate="fade" height={24} width={"40%"} radius={4} />
<VSpacer size={8} />
{Array.from({ length: 5 }).map((_, j) => (
{Array.from({ length: 2 }).map((_, j) => (
<View key={j}>
<View style={IOStyles.rowSpaceBetween}>
<Placeholder.Box
animate="fade"
height={24}
width={100}
radius={4}
/>
<Placeholder.Box
animate="fade"
height={24}
width={150}
radius={4}
/>
</View>
<ListItemTransaction
isLoading
subtitle=""
title=""
transaction={{
amountAccessibilityLabel: "",
amount: "0"
}}
/>
<VSpacer size={8} />
</View>
))}
Expand All @@ -321,10 +343,4 @@ const BeneficiaryDetailsContentSkeleton = () => (
</>
);

const styles = StyleSheet.create({
linkRow: {
paddingVertical: 16
}
});

export { BeneficiaryDetailsContent };
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { H6, ListItemNav, VSpacer } from "@pagopa/io-app-design-system";
import { ListItemHeader, ListItemNav } from "@pagopa/io-app-design-system";
import { useNavigation } from "@react-navigation/core";
import * as O from "fp-ts/lib/Option";
import { pipe } from "fp-ts/lib/function";
Expand Down Expand Up @@ -84,12 +84,11 @@ const InitiativeDiscountSettingsComponent = (props: Props) => {

return (
<View testID={"IDPayDetailsSettingsTestID"}>
<H6>
{I18n.t(
<ListItemHeader
label={I18n.t(
"idpay.initiative.details.initiativeDetailsScreen.configured.settings.header"
)}
</H6>
<VSpacer size={8} />
/>
{instrumentsSettingsButton}
</View>
);
Expand Down
Original file line number Diff line number Diff line change
@@ -1,8 +1,7 @@
import {
H6,
ListItemHeader,
ListItemNav,
ListItemNavAlert,
VSpacer
ListItemNavAlert
} from "@pagopa/io-app-design-system";
import { useNavigation } from "@react-navigation/core";
import * as O from "fp-ts/lib/Option";
Expand Down Expand Up @@ -171,12 +170,11 @@ const InitiativeRefundSettingsComponent = (props: Props) => {

return (
<View testID={"IDPayDetailsSettingsTestID"}>
<H6>
{I18n.t(
<ListItemHeader
label={I18n.t(
"idpay.initiative.details.initiativeDetailsScreen.configured.settings.header"
)}
</H6>
<VSpacer size={8} />
/>
{instrumentsSettingsButton}
{ibanSettingsButton}
</View>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,8 @@ import {
Divider,
H6,
BodySmall,
VSpacer
VSpacer,
ListItemHeader
} from "@pagopa/io-app-design-system";
import * as pot from "@pagopa/ts-commons/lib/pot";
import { useNavigation } from "@react-navigation/native";
Expand Down Expand Up @@ -73,8 +74,20 @@ const InitiativeTimelineComponent = ({ initiativeId, size = 3 }: Props) => {

return (
<View testID="IDPayTimelineTestID">
<TimelineHeaderComponent onShowMorePress={navigateToOperationsList} />
<VSpacer size={8} />
<ListItemHeader
label={I18n.t(
"idpay.initiative.details.initiativeDetailsScreen.configured.yourOperations"
)}
endElement={{
type: "buttonLink",
componentProps: {
label: I18n.t(
"idpay.initiative.details.initiativeDetailsScreen.configured.settings.showMore"
),
onPress: navigateToOperationsList
}
}}
/>
{renderTimelineContent()}
{detailsBottomSheet.bottomSheet}
</View>
Expand Down
Loading

0 comments on commit d76c8c9

Please sign in to comment.