@pagopa/io-app-design-system 3.1.0 → 4.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/commonjs/components/alert/Alert.js +1 -2
- package/lib/commonjs/components/alert/Alert.js.map +1 -1
- package/lib/commonjs/components/alert/AlertEdgeToEdge.js +2 -2
- package/lib/commonjs/components/alert/AlertEdgeToEdge.js.map +1 -1
- package/lib/commonjs/components/banner/Banner.js +1 -1
- package/lib/commonjs/components/banner/Banner.js.map +1 -1
- package/lib/commonjs/components/banner/__test__/__snapshots__/banner.test.tsx.snap +2 -2
- package/lib/commonjs/components/buttons/ButtonLink.js +1 -1
- package/lib/commonjs/components/buttons/ButtonLink.js.map +1 -1
- package/lib/commonjs/components/buttons/ButtonOutline.js +1 -1
- package/lib/commonjs/components/buttons/ButtonOutline.js.map +1 -1
- package/lib/commonjs/components/buttons/__test__/__snapshots__/button.test.tsx.snap +3 -3
- package/lib/commonjs/components/featureInfo/FeatureInfo.js +3 -2
- package/lib/commonjs/components/featureInfo/FeatureInfo.js.map +1 -1
- package/lib/commonjs/components/layout/HeaderFirstLevel.js +1 -0
- package/lib/commonjs/components/layout/HeaderFirstLevel.js.map +1 -1
- package/lib/commonjs/components/listitems/ListItemCheckbox.js +1 -1
- package/lib/commonjs/components/listitems/ListItemCheckbox.js.map +1 -1
- package/lib/commonjs/components/listitems/ListItemInfo.js +1 -1
- package/lib/commonjs/components/listitems/ListItemInfo.js.map +1 -1
- package/lib/commonjs/components/listitems/ListItemInfoCopy.js +1 -1
- package/lib/commonjs/components/listitems/ListItemInfoCopy.js.map +1 -1
- package/lib/commonjs/components/listitems/ListItemNav.js +1 -1
- package/lib/commonjs/components/listitems/ListItemNav.js.map +1 -1
- package/lib/commonjs/components/listitems/ListItemNavAlert.js +1 -1
- package/lib/commonjs/components/listitems/ListItemNavAlert.js.map +1 -1
- package/lib/commonjs/components/listitems/ListItemRadio.js +1 -1
- package/lib/commonjs/components/listitems/ListItemRadio.js.map +1 -1
- package/lib/commonjs/components/listitems/ListItemRadioWithAmount.js +2 -2
- package/lib/commonjs/components/listitems/ListItemRadioWithAmount.js.map +1 -1
- package/lib/commonjs/components/listitems/ListItemSwitch.js +1 -1
- package/lib/commonjs/components/listitems/ListItemSwitch.js.map +1 -1
- package/lib/commonjs/components/listitems/ListItemTransaction.js +2 -2
- package/lib/commonjs/components/listitems/ListItemTransaction.js.map +1 -1
- package/lib/commonjs/components/listitems/__test__/__snapshots__/listitem.test.tsx.snap +7 -7
- package/lib/commonjs/components/modules/ModuleAttachment.js +1 -1
- package/lib/commonjs/components/modules/ModuleAttachment.js.map +1 -1
- package/lib/commonjs/components/modules/ModuleCheckout.js +1 -1
- package/lib/commonjs/components/modules/ModuleCheckout.js.map +1 -1
- package/lib/commonjs/components/modules/ModuleCredential.js +1 -1
- package/lib/commonjs/components/modules/ModuleCredential.js.map +1 -1
- package/lib/commonjs/components/modules/ModuleNavigation.js +3 -2
- package/lib/commonjs/components/modules/ModuleNavigation.js.map +1 -1
- package/lib/commonjs/components/modules/ModulePaymentNotice.js +2 -2
- package/lib/commonjs/components/modules/ModulePaymentNotice.js.map +1 -1
- package/lib/commonjs/components/modules/ModuleSummary.js +1 -1
- package/lib/commonjs/components/modules/ModuleSummary.js.map +1 -1
- package/lib/commonjs/components/otpInput/BoxedInput.js +4 -6
- package/lib/commonjs/components/otpInput/BoxedInput.js.map +1 -1
- package/lib/commonjs/components/otpInput/OTPInput.js +5 -4
- package/lib/commonjs/components/otpInput/OTPInput.js.map +1 -1
- package/lib/commonjs/components/tabs/TabItem.js +1 -1
- package/lib/commonjs/components/tabs/TabItem.js.map +1 -1
- package/lib/commonjs/components/textInput/TextInputBase.js +2 -2
- package/lib/commonjs/components/textInput/TextInputBase.js.map +1 -1
- package/lib/commonjs/components/typography/{LabelSmall.js → BodySmall.js} +8 -10
- package/lib/commonjs/components/typography/BodySmall.js.map +1 -0
- package/lib/commonjs/components/typography/ButtonText.js +1 -3
- package/lib/commonjs/components/typography/ButtonText.js.map +1 -1
- package/lib/commonjs/components/typography/H3.js +3 -6
- package/lib/commonjs/components/typography/H3.js.map +1 -1
- package/lib/commonjs/components/typography/H6.js +4 -5
- package/lib/commonjs/components/typography/H6.js.map +1 -1
- package/lib/commonjs/components/typography/__test__/__snapshots__/typography.test.tsx.snap +118 -161
- package/lib/commonjs/components/typography/__test__/typography.test.js +6 -18
- package/lib/commonjs/components/typography/__test__/typography.test.js.map +1 -1
- package/lib/commonjs/components/typography/index.js +28 -72
- package/lib/commonjs/components/typography/index.js.map +1 -1
- package/lib/module/components/alert/Alert.js +2 -3
- package/lib/module/components/alert/Alert.js.map +1 -1
- package/lib/module/components/alert/AlertEdgeToEdge.js +2 -2
- package/lib/module/components/alert/AlertEdgeToEdge.js.map +1 -1
- package/lib/module/components/banner/Banner.js +2 -2
- package/lib/module/components/banner/Banner.js.map +1 -1
- package/lib/module/components/banner/__test__/__snapshots__/banner.test.tsx.snap +2 -2
- package/lib/module/components/buttons/ButtonLink.js +1 -1
- package/lib/module/components/buttons/ButtonLink.js.map +1 -1
- package/lib/module/components/buttons/ButtonOutline.js +1 -1
- package/lib/module/components/buttons/ButtonOutline.js.map +1 -1
- package/lib/module/components/buttons/__test__/__snapshots__/button.test.tsx.snap +3 -3
- package/lib/module/components/featureInfo/FeatureInfo.js +4 -3
- package/lib/module/components/featureInfo/FeatureInfo.js.map +1 -1
- package/lib/module/components/layout/HeaderFirstLevel.js +1 -0
- package/lib/module/components/layout/HeaderFirstLevel.js.map +1 -1
- package/lib/module/components/listitems/ListItemCheckbox.js +2 -2
- package/lib/module/components/listitems/ListItemCheckbox.js.map +1 -1
- package/lib/module/components/listitems/ListItemInfo.js +2 -2
- package/lib/module/components/listitems/ListItemInfo.js.map +1 -1
- package/lib/module/components/listitems/ListItemInfoCopy.js +2 -2
- package/lib/module/components/listitems/ListItemInfoCopy.js.map +1 -1
- package/lib/module/components/listitems/ListItemNav.js +2 -2
- package/lib/module/components/listitems/ListItemNav.js.map +1 -1
- package/lib/module/components/listitems/ListItemNavAlert.js +2 -2
- package/lib/module/components/listitems/ListItemNavAlert.js.map +1 -1
- package/lib/module/components/listitems/ListItemRadio.js +2 -2
- package/lib/module/components/listitems/ListItemRadio.js.map +1 -1
- package/lib/module/components/listitems/ListItemRadioWithAmount.js +3 -3
- package/lib/module/components/listitems/ListItemRadioWithAmount.js.map +1 -1
- package/lib/module/components/listitems/ListItemSwitch.js +2 -2
- package/lib/module/components/listitems/ListItemSwitch.js.map +1 -1
- package/lib/module/components/listitems/ListItemTransaction.js +3 -3
- package/lib/module/components/listitems/ListItemTransaction.js.map +1 -1
- package/lib/module/components/listitems/__test__/__snapshots__/listitem.test.tsx.snap +7 -7
- package/lib/module/components/modules/ModuleAttachment.js +2 -2
- package/lib/module/components/modules/ModuleAttachment.js.map +1 -1
- package/lib/module/components/modules/ModuleCheckout.js +2 -2
- package/lib/module/components/modules/ModuleCheckout.js.map +1 -1
- package/lib/module/components/modules/ModuleCredential.js +2 -2
- package/lib/module/components/modules/ModuleCredential.js.map +1 -1
- package/lib/module/components/modules/ModuleNavigation.js +4 -3
- package/lib/module/components/modules/ModuleNavigation.js.map +1 -1
- package/lib/module/components/modules/ModulePaymentNotice.js +3 -3
- package/lib/module/components/modules/ModulePaymentNotice.js.map +1 -1
- package/lib/module/components/modules/ModuleSummary.js +2 -2
- package/lib/module/components/modules/ModuleSummary.js.map +1 -1
- package/lib/module/components/otpInput/BoxedInput.js +5 -7
- package/lib/module/components/otpInput/BoxedInput.js.map +1 -1
- package/lib/module/components/otpInput/OTPInput.js +5 -4
- package/lib/module/components/otpInput/OTPInput.js.map +1 -1
- package/lib/module/components/tabs/TabItem.js +2 -2
- package/lib/module/components/tabs/TabItem.js.map +1 -1
- package/lib/module/components/textInput/TextInputBase.js +3 -3
- package/lib/module/components/textInput/TextInputBase.js.map +1 -1
- package/lib/module/components/typography/{LabelSmall.js → BodySmall.js} +6 -8
- package/lib/module/components/typography/BodySmall.js.map +1 -0
- package/lib/module/components/typography/ButtonText.js +1 -3
- package/lib/module/components/typography/ButtonText.js.map +1 -1
- package/lib/module/components/typography/H3.js +3 -6
- package/lib/module/components/typography/H3.js.map +1 -1
- package/lib/module/components/typography/H6.js +4 -5
- package/lib/module/components/typography/H6.js.map +1 -1
- package/lib/module/components/typography/__test__/__snapshots__/typography.test.tsx.snap +118 -161
- package/lib/module/components/typography/__test__/typography.test.js +6 -18
- package/lib/module/components/typography/__test__/typography.test.js.map +1 -1
- package/lib/module/components/typography/index.js +6 -10
- package/lib/module/components/typography/index.js.map +1 -1
- package/lib/typescript/components/alert/Alert.d.ts.map +1 -1
- package/lib/typescript/components/banner/Banner.d.ts +1 -1
- package/lib/typescript/components/banner/Banner.d.ts.map +1 -1
- package/lib/typescript/components/featureInfo/FeatureInfo.d.ts.map +1 -1
- package/lib/typescript/components/layout/HeaderFirstLevel.d.ts.map +1 -1
- package/lib/typescript/components/listitems/ListItemSwitch.d.ts.map +1 -1
- package/lib/typescript/components/modules/ModuleNavigation.d.ts.map +1 -1
- package/lib/typescript/components/otpInput/BoxedInput.d.ts.map +1 -1
- package/lib/typescript/components/otpInput/OTPInput.d.ts.map +1 -1
- package/lib/typescript/components/typography/Body.d.ts +1 -1
- package/lib/typescript/components/typography/Body.d.ts.map +1 -1
- package/lib/typescript/components/typography/BodySmall.d.ts +13 -0
- package/lib/typescript/components/typography/BodySmall.d.ts.map +1 -0
- package/lib/typescript/components/typography/ButtonText.d.ts.map +1 -1
- package/lib/typescript/components/typography/H3.d.ts +2 -0
- package/lib/typescript/components/typography/H3.d.ts.map +1 -1
- package/lib/typescript/components/typography/H6.d.ts.map +1 -1
- package/lib/typescript/components/typography/LabelMini.d.ts +1 -1
- package/lib/typescript/components/typography/LabelMini.d.ts.map +1 -1
- package/lib/typescript/components/typography/index.d.ts +6 -10
- package/lib/typescript/components/typography/index.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/components/alert/Alert.tsx +3 -4
- package/src/components/alert/AlertEdgeToEdge.tsx +3 -3
- package/src/components/banner/Banner.tsx +7 -5
- package/src/components/banner/__test__/__snapshots__/banner.test.tsx.snap +2 -2
- package/src/components/buttons/ButtonLink.tsx +1 -1
- package/src/components/buttons/ButtonOutline.tsx +1 -1
- package/src/components/buttons/__test__/__snapshots__/button.test.tsx.snap +3 -3
- package/src/components/featureInfo/FeatureInfo.tsx +6 -6
- package/src/components/layout/HeaderFirstLevel.tsx +1 -0
- package/src/components/listitems/ListItemCheckbox.tsx +3 -3
- package/src/components/listitems/ListItemInfo.tsx +3 -3
- package/src/components/listitems/ListItemInfoCopy.tsx +3 -3
- package/src/components/listitems/ListItemNav.tsx +3 -3
- package/src/components/listitems/ListItemNavAlert.tsx +3 -3
- package/src/components/listitems/ListItemRadio.tsx +3 -3
- package/src/components/listitems/ListItemRadioWithAmount.tsx +5 -5
- package/src/components/listitems/ListItemSwitch.tsx +4 -4
- package/src/components/listitems/ListItemTransaction.tsx +5 -5
- package/src/components/listitems/__test__/__snapshots__/listitem.test.tsx.snap +7 -7
- package/src/components/modules/ModuleAttachment.tsx +3 -3
- package/src/components/modules/ModuleCheckout.tsx +3 -3
- package/src/components/modules/ModuleCredential.tsx +3 -3
- package/src/components/modules/ModuleNavigation.tsx +6 -4
- package/src/components/modules/ModulePaymentNotice.tsx +5 -5
- package/src/components/modules/ModuleSummary.tsx +3 -3
- package/src/components/otpInput/BoxedInput.tsx +6 -5
- package/src/components/otpInput/OTPInput.tsx +23 -8
- package/src/components/tabs/TabItem.tsx +3 -3
- package/src/components/textInput/TextInputBase.tsx +5 -5
- package/src/components/typography/Body.tsx +1 -1
- package/src/components/typography/{LabelSmall.tsx → BodySmall.tsx} +7 -14
- package/src/components/typography/ButtonText.tsx +2 -4
- package/src/components/typography/H3.tsx +11 -8
- package/src/components/typography/H6.tsx +5 -6
- package/src/components/typography/LabelMini.tsx +1 -1
- package/src/components/typography/__test__/__snapshots__/typography.test.tsx.snap +118 -161
- package/src/components/typography/__test__/typography.test.tsx +8 -24
- package/src/components/typography/index.tsx +6 -10
- package/lib/commonjs/components/typography/BaseTypography.js +0 -52
- package/lib/commonjs/components/typography/BaseTypography.js.map +0 -1
- package/lib/commonjs/components/typography/Chip.js +0 -41
- package/lib/commonjs/components/typography/Chip.js.map +0 -1
- package/lib/commonjs/components/typography/Factory.js +0 -62
- package/lib/commonjs/components/typography/Factory.js.map +0 -1
- package/lib/commonjs/components/typography/Label.js +0 -51
- package/lib/commonjs/components/typography/Label.js.map +0 -1
- package/lib/commonjs/components/typography/LabelSmall.js.map +0 -1
- package/lib/module/components/typography/BaseTypography.js +0 -44
- package/lib/module/components/typography/BaseTypography.js.map +0 -1
- package/lib/module/components/typography/Chip.js +0 -32
- package/lib/module/components/typography/Chip.js.map +0 -1
- package/lib/module/components/typography/Factory.js +0 -55
- package/lib/module/components/typography/Factory.js.map +0 -1
- package/lib/module/components/typography/Label.js +0 -42
- package/lib/module/components/typography/Label.js.map +0 -1
- package/lib/module/components/typography/LabelSmall.js.map +0 -1
- package/lib/typescript/components/typography/BaseTypography.d.ts +0 -29
- package/lib/typescript/components/typography/BaseTypography.d.ts.map +0 -1
- package/lib/typescript/components/typography/Chip.d.ts +0 -13
- package/lib/typescript/components/typography/Chip.d.ts.map +0 -1
- package/lib/typescript/components/typography/Factory.d.ts +0 -43
- package/lib/typescript/components/typography/Factory.d.ts.map +0 -1
- package/lib/typescript/components/typography/Label.d.ts +0 -13
- package/lib/typescript/components/typography/Label.d.ts.map +0 -1
- package/lib/typescript/components/typography/LabelSmall.d.ts +0 -13
- package/lib/typescript/components/typography/LabelSmall.d.ts.map +0 -1
- package/src/components/typography/BaseTypography.tsx +0 -71
- package/src/components/typography/Chip.tsx +0 -33
- package/src/components/typography/Factory.tsx +0 -98
- package/src/components/typography/Label.tsx +0 -62
package/package.json
CHANGED
|
@@ -29,9 +29,8 @@ import { IOAlertSpacing } from "../../core/IOSpacing";
|
|
|
29
29
|
import { WithTestID } from "../../utils/types";
|
|
30
30
|
import { IOIconSizeScale, IOIcons, Icon } from "../icons";
|
|
31
31
|
import { VSpacer } from "../spacer";
|
|
32
|
-
import { ButtonText } from "../typography";
|
|
32
|
+
import { Body, ButtonText } from "../typography";
|
|
33
33
|
import { H4 } from "../typography/H4";
|
|
34
|
-
import { Label } from "../typography/Label";
|
|
35
34
|
|
|
36
35
|
const iconSize: IOIconSizeScale = 24;
|
|
37
36
|
|
|
@@ -197,14 +196,14 @@ export const Alert = React.forwardRef<View, AlertType>(
|
|
|
197
196
|
<VSpacer size={8} />
|
|
198
197
|
</>
|
|
199
198
|
)}
|
|
200
|
-
<
|
|
199
|
+
<Body
|
|
201
200
|
color={mapVariantStates[variant].foreground}
|
|
202
201
|
weight={"Regular"}
|
|
203
202
|
accessibilityRole="text"
|
|
204
203
|
onTextLayout={onTextLayout}
|
|
205
204
|
>
|
|
206
205
|
{content}
|
|
207
|
-
</
|
|
206
|
+
</Body>
|
|
208
207
|
{action && (
|
|
209
208
|
<>
|
|
210
209
|
<VSpacer size={8} />
|
|
@@ -33,7 +33,7 @@ import { IOStyles } from "../../core/IOStyles";
|
|
|
33
33
|
import { makeFontStyleObject } from "../../utils/fonts";
|
|
34
34
|
import { WithTestID } from "../../utils/types";
|
|
35
35
|
import { IOIconSizeScale, IOIcons, Icon } from "../icons";
|
|
36
|
-
import {
|
|
36
|
+
import { Body } from "../typography";
|
|
37
37
|
|
|
38
38
|
const iconSize: IOIconSizeScale = 24;
|
|
39
39
|
|
|
@@ -161,7 +161,7 @@ export const AlertEdgeToEdge = ({
|
|
|
161
161
|
/>
|
|
162
162
|
</View>
|
|
163
163
|
<View style={IOStyles.flex}>
|
|
164
|
-
<
|
|
164
|
+
<Body
|
|
165
165
|
color={mapVariantStates[variant].foreground}
|
|
166
166
|
weight={"Regular"}
|
|
167
167
|
accessibilityRole="text"
|
|
@@ -182,7 +182,7 @@ export const AlertEdgeToEdge = ({
|
|
|
182
182
|
{` ${action}`}
|
|
183
183
|
</Text>
|
|
184
184
|
)}
|
|
185
|
-
</
|
|
185
|
+
</Body>
|
|
186
186
|
</View>
|
|
187
187
|
</>
|
|
188
188
|
);
|
|
@@ -33,7 +33,7 @@ import {
|
|
|
33
33
|
PictogramBleed
|
|
34
34
|
} from "../pictograms";
|
|
35
35
|
import { VSpacer } from "../spacer";
|
|
36
|
-
import { H6,
|
|
36
|
+
import { H6, BodySmall } from "../typography";
|
|
37
37
|
|
|
38
38
|
/* Styles */
|
|
39
39
|
const colorTitle: IOColors = "blueIO-850";
|
|
@@ -157,7 +157,7 @@ export const Banner = ({
|
|
|
157
157
|
onClose,
|
|
158
158
|
accessibilityHint,
|
|
159
159
|
accessibilityLabel,
|
|
160
|
-
testID
|
|
160
|
+
testID
|
|
161
161
|
}: Banner) => {
|
|
162
162
|
const isPressed: Animated.SharedValue<number> = useSharedValue(0);
|
|
163
163
|
|
|
@@ -197,7 +197,9 @@ export const Banner = ({
|
|
|
197
197
|
|
|
198
198
|
/* Generates a complete fallbackAccessibilityLabel by concatenating the title, content, and action
|
|
199
199
|
if they are present. */
|
|
200
|
-
const fallbackAccessibilityLabel = [title, content, action]
|
|
200
|
+
const fallbackAccessibilityLabel = [title, content, action]
|
|
201
|
+
.filter(Boolean)
|
|
202
|
+
.join(" ");
|
|
201
203
|
|
|
202
204
|
const renderMainBlock = () => (
|
|
203
205
|
<>
|
|
@@ -219,9 +221,9 @@ export const Banner = ({
|
|
|
219
221
|
)}
|
|
220
222
|
{content && (
|
|
221
223
|
<>
|
|
222
|
-
<
|
|
224
|
+
<BodySmall color={colorContent} weight={"Regular"}>
|
|
223
225
|
{content}
|
|
224
|
-
</
|
|
226
|
+
</BodySmall>
|
|
225
227
|
{action && <VSpacer size={8} />}
|
|
226
228
|
</>
|
|
227
229
|
)}
|
|
@@ -82,7 +82,7 @@ exports[`Test Banner Components - Experimental Enabled Banner Snapshot 1`] = `
|
|
|
82
82
|
{
|
|
83
83
|
"color": "#031344",
|
|
84
84
|
"fontFamily": "Titillio",
|
|
85
|
-
"fontSize":
|
|
85
|
+
"fontSize": 16,
|
|
86
86
|
"fontStyle": "normal",
|
|
87
87
|
"fontWeight": "600",
|
|
88
88
|
"lineHeight": 24,
|
|
@@ -546,7 +546,7 @@ exports[`Test Banner Components Banner Snapshot 1`] = `
|
|
|
546
546
|
"fontFamily": "Titillium Sans Pro",
|
|
547
547
|
"fontSize": 16,
|
|
548
548
|
"fontStyle": "normal",
|
|
549
|
-
"fontWeight": "
|
|
549
|
+
"fontWeight": "600",
|
|
550
550
|
"lineHeight": undefined,
|
|
551
551
|
},
|
|
552
552
|
{
|
|
@@ -238,7 +238,7 @@ export const ButtonLink = React.forwardRef<View, ButtonLinkProps>(
|
|
|
238
238
|
accessibilityElementsHidden
|
|
239
239
|
importantForAccessibility="no-hide-descendants"
|
|
240
240
|
font={isExperimental ? "Titillio" : "TitilliumSansPro"}
|
|
241
|
-
weight={
|
|
241
|
+
weight={"Semibold"}
|
|
242
242
|
size={buttonTextFontSize}
|
|
243
243
|
style={
|
|
244
244
|
disabled
|
|
@@ -375,7 +375,7 @@ export const ButtonOutline = React.forwardRef<View, ButtonOutline>(
|
|
|
375
375
|
)}
|
|
376
376
|
<AnimatedIOText
|
|
377
377
|
font={isExperimental ? "Titillio" : "TitilliumSansPro"}
|
|
378
|
-
weight={
|
|
378
|
+
weight={"Semibold"}
|
|
379
379
|
size={buttonTextFontSize}
|
|
380
380
|
accessible={false}
|
|
381
381
|
accessibilityElementsHidden
|
|
@@ -805,7 +805,7 @@ exports[`Test Buttons Components ButtonLink Snapshot 1`] = `
|
|
|
805
805
|
"fontFamily": "Titillium Sans Pro",
|
|
806
806
|
"fontSize": 16,
|
|
807
807
|
"fontStyle": "normal",
|
|
808
|
-
"fontWeight": "
|
|
808
|
+
"fontWeight": "600",
|
|
809
809
|
"lineHeight": undefined,
|
|
810
810
|
},
|
|
811
811
|
{
|
|
@@ -911,7 +911,7 @@ exports[`Test Buttons Components ButtonOutline Snapshot 1`] = `
|
|
|
911
911
|
"fontFamily": "Titillium Sans Pro",
|
|
912
912
|
"fontSize": 16,
|
|
913
913
|
"fontStyle": "normal",
|
|
914
|
-
"fontWeight": "
|
|
914
|
+
"fontWeight": "600",
|
|
915
915
|
"lineHeight": undefined,
|
|
916
916
|
},
|
|
917
917
|
[
|
|
@@ -1031,7 +1031,7 @@ exports[`Test Buttons Components ButtonSolid Snapshot 1`] = `
|
|
|
1031
1031
|
"fontFamily": "Titillium Sans Pro",
|
|
1032
1032
|
"fontSize": 16,
|
|
1033
1033
|
"fontStyle": "normal",
|
|
1034
|
-
"fontWeight": "
|
|
1034
|
+
"fontWeight": "600",
|
|
1035
1035
|
"lineHeight": 20,
|
|
1036
1036
|
},
|
|
1037
1037
|
{
|
|
@@ -1,14 +1,13 @@
|
|
|
1
1
|
import React, { ReactNode } from "react";
|
|
2
2
|
import { GestureResponderEvent, View } from "react-native";
|
|
3
3
|
import {
|
|
4
|
-
|
|
4
|
+
BodySmall,
|
|
5
5
|
HSpacer,
|
|
6
6
|
IOIconSizeScale,
|
|
7
7
|
IOIcons,
|
|
8
8
|
IOPictogramSizeScale,
|
|
9
9
|
IOPictograms,
|
|
10
10
|
Icon,
|
|
11
|
-
Label,
|
|
12
11
|
Pictogram,
|
|
13
12
|
VSpacer
|
|
14
13
|
} from "../../components";
|
|
@@ -44,9 +43,9 @@ const DEFAULT_PICTOGRAM_SIZE: IOPictogramSizeScale = 48;
|
|
|
44
43
|
const renderNode = (body: FeatureInfoProps["body"]) => {
|
|
45
44
|
if (typeof body === "string") {
|
|
46
45
|
return (
|
|
47
|
-
<
|
|
46
|
+
<BodySmall color="grey-700" testID="infoScreenBody">
|
|
48
47
|
{body}
|
|
49
|
-
</
|
|
48
|
+
</BodySmall>
|
|
50
49
|
);
|
|
51
50
|
}
|
|
52
51
|
|
|
@@ -75,7 +74,8 @@ export const FeatureInfo = ({
|
|
|
75
74
|
This verbose code could be deleted once we got "gap"
|
|
76
75
|
property support */}
|
|
77
76
|
{body && <VSpacer size={4} />}
|
|
78
|
-
<
|
|
77
|
+
<BodySmall
|
|
78
|
+
weight="Semibold"
|
|
79
79
|
asLink
|
|
80
80
|
onPress={action.onPress}
|
|
81
81
|
accessible
|
|
@@ -83,7 +83,7 @@ export const FeatureInfo = ({
|
|
|
83
83
|
accessibilityElementsHidden={false}
|
|
84
84
|
>
|
|
85
85
|
{action.label}
|
|
86
|
-
</
|
|
86
|
+
</BodySmall>
|
|
87
87
|
</>
|
|
88
88
|
)}
|
|
89
89
|
</View>
|
|
@@ -24,7 +24,7 @@ import {
|
|
|
24
24
|
import { AnimatedCheckbox } from "../checkbox/AnimatedCheckbox";
|
|
25
25
|
import { IOIcons, Icon } from "../icons";
|
|
26
26
|
import { HSpacer, VSpacer } from "../spacer";
|
|
27
|
-
import { H6,
|
|
27
|
+
import { H6, BodySmall } from "../typography";
|
|
28
28
|
|
|
29
29
|
type Props = {
|
|
30
30
|
value: string;
|
|
@@ -188,9 +188,9 @@ export const ListItemCheckbox = ({
|
|
|
188
188
|
<VSpacer
|
|
189
189
|
size={IOSelectionListItemVisualParams.descriptionMargin}
|
|
190
190
|
/>
|
|
191
|
-
<
|
|
191
|
+
<BodySmall weight="Regular" color={theme["textBody-tertiary"]}>
|
|
192
192
|
{description}
|
|
193
|
-
</
|
|
193
|
+
</BodySmall>
|
|
194
194
|
</View>
|
|
195
195
|
)}
|
|
196
196
|
</Animated.View>
|
|
@@ -12,7 +12,7 @@ import { ButtonLink, IconButton } from "../buttons";
|
|
|
12
12
|
import { LogoPaymentWithFallback } from "../common/LogoPaymentWithFallback";
|
|
13
13
|
import { IOIconSizeScale, IOIcons, Icon } from "../icons";
|
|
14
14
|
import { IOLogoPaymentType } from "../logos";
|
|
15
|
-
import { H6,
|
|
15
|
+
import { H6, BodySmall } from "../typography";
|
|
16
16
|
|
|
17
17
|
type ButtonLinkActionProps = {
|
|
18
18
|
type: "buttonLink";
|
|
@@ -84,9 +84,9 @@ export const ListItemInfo = ({
|
|
|
84
84
|
const itemInfoTextComponent = useMemo(
|
|
85
85
|
() => (
|
|
86
86
|
<View accessible={Platform.OS === "ios"}>
|
|
87
|
-
<
|
|
87
|
+
<BodySmall weight="Regular" color={theme["textBody-tertiary"]}>
|
|
88
88
|
{label}
|
|
89
|
-
</
|
|
89
|
+
</BodySmall>
|
|
90
90
|
{typeof value === "string" ? (
|
|
91
91
|
<H6 color={theme["textBody-default"]} numberOfLines={numberOfLines}>
|
|
92
92
|
{value}
|
|
@@ -22,7 +22,7 @@ import {
|
|
|
22
22
|
} from "../../core";
|
|
23
23
|
import { WithTestID } from "../../utils/types";
|
|
24
24
|
import { IOIcons, Icon } from "../icons";
|
|
25
|
-
import {
|
|
25
|
+
import { BodySmall, H6 } from "../typography";
|
|
26
26
|
|
|
27
27
|
export type ListItemInfoCopy = WithTestID<{
|
|
28
28
|
label: string;
|
|
@@ -69,9 +69,9 @@ export const ListItemInfoCopy = ({
|
|
|
69
69
|
|
|
70
70
|
const listItemInfoCopyContent = (
|
|
71
71
|
<>
|
|
72
|
-
<
|
|
72
|
+
<BodySmall weight="Regular" color={theme["textBody-tertiary"]}>
|
|
73
73
|
{label}
|
|
74
|
-
</
|
|
74
|
+
</BodySmall>
|
|
75
75
|
{/* Let developer using a custom component (e.g: skeleton) */}
|
|
76
76
|
{typeof value === "string" ? (
|
|
77
77
|
<H6 color={foregroundColor} numberOfLines={numberOfLines}>
|
|
@@ -33,7 +33,7 @@ import { Badge } from "../badge";
|
|
|
33
33
|
import { IOIcons, Icon } from "../icons";
|
|
34
34
|
import { LoadingSpinner } from "../loadingSpinner";
|
|
35
35
|
import { HSpacer, VSpacer } from "../spacer";
|
|
36
|
-
import { Caption, H6,
|
|
36
|
+
import { Caption, H6, BodySmall } from "../typography";
|
|
37
37
|
|
|
38
38
|
type ListItemTopElementProps =
|
|
39
39
|
| {
|
|
@@ -161,9 +161,9 @@ export const ListItemNav = ({
|
|
|
161
161
|
{description && (
|
|
162
162
|
<>
|
|
163
163
|
{typeof description === "string" ? (
|
|
164
|
-
<
|
|
164
|
+
<BodySmall weight="Regular" color={theme["textBody-tertiary"]}>
|
|
165
165
|
{description}
|
|
166
|
-
</
|
|
166
|
+
</BodySmall>
|
|
167
167
|
) : (
|
|
168
168
|
description
|
|
169
169
|
)}
|
|
@@ -22,7 +22,7 @@ import {
|
|
|
22
22
|
} from "../../core";
|
|
23
23
|
import { WithTestID } from "../../utils/types";
|
|
24
24
|
import { Icon } from "../icons";
|
|
25
|
-
import { H6,
|
|
25
|
+
import { H6, BodySmall } from "../typography";
|
|
26
26
|
|
|
27
27
|
export type ListItemNavAlert = WithTestID<{
|
|
28
28
|
value: string | React.ReactNode;
|
|
@@ -82,9 +82,9 @@ export const ListItemNavAlert = ({
|
|
|
82
82
|
{description && (
|
|
83
83
|
<>
|
|
84
84
|
{typeof description === "string" ? (
|
|
85
|
-
<
|
|
85
|
+
<BodySmall weight="Semibold" color={theme.errorText}>
|
|
86
86
|
{description}
|
|
87
|
-
</
|
|
87
|
+
</BodySmall>
|
|
88
88
|
) : (
|
|
89
89
|
description
|
|
90
90
|
)}
|
|
@@ -27,7 +27,7 @@ import { IOIcons, Icon } from "../icons";
|
|
|
27
27
|
import { IOLogoPaymentType, LogoPayment } from "../logos";
|
|
28
28
|
import { AnimatedRadio } from "../radio/AnimatedRadio";
|
|
29
29
|
import { HSpacer, VSpacer } from "../spacer";
|
|
30
|
-
import { H6,
|
|
30
|
+
import { H6, BodySmall } from "../typography";
|
|
31
31
|
|
|
32
32
|
type ListItemRadioGraphicProps =
|
|
33
33
|
| { icon?: never; paymentLogo: IOLogoPaymentType; uri?: never }
|
|
@@ -287,9 +287,9 @@ export const ListItemRadio = ({
|
|
|
287
287
|
<VSpacer
|
|
288
288
|
size={IOSelectionListItemVisualParams.descriptionMargin}
|
|
289
289
|
/>
|
|
290
|
-
<
|
|
290
|
+
<BodySmall weight="Regular" color={theme["textBody-tertiary"]}>
|
|
291
291
|
{description}
|
|
292
|
-
</
|
|
292
|
+
</BodySmall>
|
|
293
293
|
</View>
|
|
294
294
|
)}
|
|
295
295
|
</Animated.View>
|
|
@@ -5,7 +5,7 @@ import { IOColors, useIOTheme } from "../../core";
|
|
|
5
5
|
import { Icon } from "../icons";
|
|
6
6
|
import { AnimatedRadio } from "../radio/AnimatedRadio";
|
|
7
7
|
import { HSpacer, VSpacer } from "../spacer";
|
|
8
|
-
import { H6,
|
|
8
|
+
import { H6, BodySmall } from "../typography";
|
|
9
9
|
import { PressableListItemBase } from "./PressableListItemsBase";
|
|
10
10
|
|
|
11
11
|
export type ListItemRadioWithAmountProps = {
|
|
@@ -55,22 +55,22 @@ export const ListItemRadioWithAmount = ({
|
|
|
55
55
|
}}
|
|
56
56
|
>
|
|
57
57
|
<View style={{ flexShrink: 1 }}>
|
|
58
|
-
<
|
|
58
|
+
<BodySmall
|
|
59
59
|
weight="Semibold"
|
|
60
60
|
numberOfLines={1}
|
|
61
61
|
color={theme["textBody-default"]}
|
|
62
62
|
>
|
|
63
63
|
{label}
|
|
64
|
-
</
|
|
64
|
+
</BodySmall>
|
|
65
65
|
{isSuggested && (
|
|
66
66
|
<>
|
|
67
67
|
<VSpacer size={4} />
|
|
68
68
|
<View style={styles.rowCenter}>
|
|
69
69
|
<Icon name="sparkles" size={16} color={suggestColor} />
|
|
70
70
|
<HSpacer size={4} />
|
|
71
|
-
<
|
|
71
|
+
<BodySmall weight="Regular" color={suggestColor}>
|
|
72
72
|
{suggestReason}
|
|
73
|
-
</
|
|
73
|
+
</BodySmall>
|
|
74
74
|
</View>
|
|
75
75
|
</>
|
|
76
76
|
)}
|
|
@@ -1,18 +1,18 @@
|
|
|
1
1
|
import React, { useMemo } from "react";
|
|
2
2
|
import { GestureResponderEvent, Platform, Switch, View } from "react-native";
|
|
3
|
-
import { WithTestID } from "../../utils/types";
|
|
4
3
|
import {
|
|
5
4
|
IOSelectionListItemStyles,
|
|
6
5
|
IOSelectionListItemVisualParams,
|
|
7
6
|
useIOTheme
|
|
8
7
|
} from "../../core";
|
|
8
|
+
import { WithTestID } from "../../utils/types";
|
|
9
9
|
import { Badge } from "../badge";
|
|
10
10
|
import { IOIcons, Icon } from "../icons";
|
|
11
11
|
import { LoadingSpinner } from "../loadingSpinner";
|
|
12
12
|
import { IOLogoPaymentType, LogoPayment } from "../logos";
|
|
13
13
|
import { HSpacer, VSpacer } from "../spacer";
|
|
14
14
|
import { NativeSwitch } from "../switch/NativeSwitch";
|
|
15
|
-
import { H6, LabelMini
|
|
15
|
+
import { BodySmall, H6, LabelMini } from "../typography";
|
|
16
16
|
|
|
17
17
|
type PartialProps = WithTestID<{
|
|
18
18
|
label: string;
|
|
@@ -178,9 +178,9 @@ export const ListItemSwitch = React.memo(
|
|
|
178
178
|
{description && (
|
|
179
179
|
<>
|
|
180
180
|
<VSpacer size={IOSelectionListItemVisualParams.descriptionMargin} />
|
|
181
|
-
<
|
|
181
|
+
<BodySmall weight="Regular" color={theme["textBody-tertiary"]}>
|
|
182
182
|
{description}
|
|
183
|
-
</
|
|
183
|
+
</BodySmall>
|
|
184
184
|
</>
|
|
185
185
|
)}
|
|
186
186
|
{action && (
|
|
@@ -21,7 +21,7 @@ import { IOIconSizeScale, Icon } from "../icons";
|
|
|
21
21
|
import { IOLogoPaymentType } from "../logos";
|
|
22
22
|
import { VSpacer } from "../spacer";
|
|
23
23
|
import { HStack } from "../stack";
|
|
24
|
-
import { H6,
|
|
24
|
+
import { H6, BodySmall } from "../typography";
|
|
25
25
|
import {
|
|
26
26
|
PressableBaseProps,
|
|
27
27
|
PressableListItemBase
|
|
@@ -146,16 +146,16 @@ export const ListItemTransaction = ({
|
|
|
146
146
|
</View>
|
|
147
147
|
)}
|
|
148
148
|
<View style={{ flexShrink: 1 }}>
|
|
149
|
-
<
|
|
149
|
+
<BodySmall
|
|
150
150
|
numberOfLines={numberOfLines}
|
|
151
151
|
color={theme["textBody-default"]}
|
|
152
152
|
weight="Semibold"
|
|
153
153
|
>
|
|
154
154
|
{title}
|
|
155
|
-
</
|
|
156
|
-
<
|
|
155
|
+
</BodySmall>
|
|
156
|
+
<BodySmall weight="Regular" color={theme["textBody-tertiary"]}>
|
|
157
157
|
{subtitle}
|
|
158
|
-
</
|
|
158
|
+
</BodySmall>
|
|
159
159
|
</View>
|
|
160
160
|
</HStack>
|
|
161
161
|
<HStack style={{ alignItems: "center" }}>
|
|
@@ -262,7 +262,7 @@ exports[`Test List Item Components - Experimental Enabled ListItemInfo Snapshot
|
|
|
262
262
|
{
|
|
263
263
|
"color": "#0E0F13",
|
|
264
264
|
"fontFamily": "Titillio",
|
|
265
|
-
"fontSize":
|
|
265
|
+
"fontSize": 16,
|
|
266
266
|
"fontStyle": "normal",
|
|
267
267
|
"fontWeight": "600",
|
|
268
268
|
"lineHeight": 24,
|
|
@@ -384,7 +384,7 @@ exports[`Test List Item Components - Experimental Enabled ListItemInfoCopy Snap
|
|
|
384
384
|
{
|
|
385
385
|
"color": "#0B3EE3",
|
|
386
386
|
"fontFamily": "Titillio",
|
|
387
|
-
"fontSize":
|
|
387
|
+
"fontSize": 16,
|
|
388
388
|
"fontStyle": "normal",
|
|
389
389
|
"fontWeight": "600",
|
|
390
390
|
"lineHeight": 24,
|
|
@@ -551,7 +551,7 @@ exports[`Test List Item Components - Experimental Enabled ListItemNav Snapshot
|
|
|
551
551
|
{
|
|
552
552
|
"color": "#0E0F13",
|
|
553
553
|
"fontFamily": "Titillio",
|
|
554
|
-
"fontSize":
|
|
554
|
+
"fontSize": 16,
|
|
555
555
|
"fontStyle": "normal",
|
|
556
556
|
"fontWeight": "600",
|
|
557
557
|
"lineHeight": 24,
|
|
@@ -780,7 +780,7 @@ exports[`Test List Item Components - Experimental Enabled ListItemNavAlert Snap
|
|
|
780
780
|
{
|
|
781
781
|
"color": "#0E0F13",
|
|
782
782
|
"fontFamily": "Titillio",
|
|
783
|
-
"fontSize":
|
|
783
|
+
"fontSize": 16,
|
|
784
784
|
"fontStyle": "normal",
|
|
785
785
|
"fontWeight": "600",
|
|
786
786
|
"lineHeight": 24,
|
|
@@ -1082,7 +1082,7 @@ exports[`Test List Item Components - Experimental Enabled ListItemRadioWithAmou
|
|
|
1082
1082
|
{
|
|
1083
1083
|
"color": "#0B3EE3",
|
|
1084
1084
|
"fontFamily": "Titillio",
|
|
1085
|
-
"fontSize":
|
|
1085
|
+
"fontSize": 16,
|
|
1086
1086
|
"fontStyle": "normal",
|
|
1087
1087
|
"fontWeight": "600",
|
|
1088
1088
|
"lineHeight": 24,
|
|
@@ -1366,7 +1366,7 @@ exports[`Test List Item Components - Experimental Enabled ListItemRadioWithAmou
|
|
|
1366
1366
|
{
|
|
1367
1367
|
"color": "#0B3EE3",
|
|
1368
1368
|
"fontFamily": "Titillio",
|
|
1369
|
-
"fontSize":
|
|
1369
|
+
"fontSize": 16,
|
|
1370
1370
|
"fontStyle": "normal",
|
|
1371
1371
|
"fontWeight": "600",
|
|
1372
1372
|
"lineHeight": 24,
|
|
@@ -1774,7 +1774,7 @@ exports[`Test List Item Components ListItemAction Snapshot 1`] = `
|
|
|
1774
1774
|
"fontFamily": "Titillium Sans Pro",
|
|
1775
1775
|
"fontSize": 16,
|
|
1776
1776
|
"fontStyle": "normal",
|
|
1777
|
-
"fontWeight": "
|
|
1777
|
+
"fontWeight": "600",
|
|
1778
1778
|
"lineHeight": 20,
|
|
1779
1779
|
},
|
|
1780
1780
|
]
|
|
@@ -7,7 +7,7 @@ import { Badge } from "../badge";
|
|
|
7
7
|
import { Icon } from "../icons";
|
|
8
8
|
import { LoadingSpinner } from "../loadingSpinner";
|
|
9
9
|
import { HStack, VStack } from "../stack";
|
|
10
|
-
import {
|
|
10
|
+
import { Body } from "../typography";
|
|
11
11
|
import { ModuleStatic } from "./ModuleStatic";
|
|
12
12
|
import { PressableModuleBase } from "./PressableModuleBase";
|
|
13
13
|
|
|
@@ -66,13 +66,13 @@ const ModuleAttachmentContent = ({
|
|
|
66
66
|
space={4}
|
|
67
67
|
style={{ alignItems: "flex-start", flexShrink: 1, flexGrow: 1 }}
|
|
68
68
|
>
|
|
69
|
-
<
|
|
69
|
+
<Body
|
|
70
70
|
weight="Semibold"
|
|
71
71
|
numberOfLines={2}
|
|
72
72
|
color={theme["interactiveElem-default"]}
|
|
73
73
|
>
|
|
74
74
|
{title}
|
|
75
|
-
</
|
|
75
|
+
</Body>
|
|
76
76
|
<Badge text={format.toUpperCase()} variant="default" />
|
|
77
77
|
</VStack>
|
|
78
78
|
<IconOrActivityIndicatorComponent />
|
|
@@ -15,7 +15,7 @@ import {
|
|
|
15
15
|
import { ButtonLink } from "../buttons";
|
|
16
16
|
import { IOLogoPaymentType, LogoPayment } from "../logos";
|
|
17
17
|
import { HStack, VStack } from "../stack";
|
|
18
|
-
import { H6,
|
|
18
|
+
import { H6, BodySmall } from "../typography";
|
|
19
19
|
import { ModuleStatic } from "./ModuleStatic";
|
|
20
20
|
import { PressableModuleBase } from "./PressableModuleBase";
|
|
21
21
|
|
|
@@ -70,9 +70,9 @@ export const ModuleCheckout = (props: ModuleCheckoutProps) => {
|
|
|
70
70
|
<View style={{ flexGrow: 1, flexShrink: 1 }}>
|
|
71
71
|
<H6 color={theme["textBody-default"]}>{title}</H6>
|
|
72
72
|
{subtitle && (
|
|
73
|
-
<
|
|
73
|
+
<BodySmall weight="Regular" color={theme["textBody-tertiary"]}>
|
|
74
74
|
{subtitle}
|
|
75
|
-
</
|
|
75
|
+
</BodySmall>
|
|
76
76
|
)}
|
|
77
77
|
</View>
|
|
78
78
|
</HStack>
|
|
@@ -20,7 +20,7 @@ import { Badge } from "../badge";
|
|
|
20
20
|
import { IOIcons, Icon } from "../icons";
|
|
21
21
|
import { LoadingSpinner } from "../loadingSpinner";
|
|
22
22
|
import { HStack } from "../stack/Stack";
|
|
23
|
-
import {
|
|
23
|
+
import { BodySmall } from "../typography";
|
|
24
24
|
import { ModuleStatic } from "./ModuleStatic";
|
|
25
25
|
import {
|
|
26
26
|
PressableModuleBase,
|
|
@@ -89,7 +89,7 @@ const ModuleCredential = (props: WithTestID<ModuleCredentialProps>) => {
|
|
|
89
89
|
{/* Graphical assets */}
|
|
90
90
|
{iconComponent ?? imageComponent}
|
|
91
91
|
|
|
92
|
-
<
|
|
92
|
+
<BodySmall
|
|
93
93
|
color={theme["interactiveElem-default"]}
|
|
94
94
|
weight="Semibold"
|
|
95
95
|
numberOfLines={2}
|
|
@@ -97,7 +97,7 @@ const ModuleCredential = (props: WithTestID<ModuleCredentialProps>) => {
|
|
|
97
97
|
style={{ flexShrink: 1 }}
|
|
98
98
|
>
|
|
99
99
|
{label}
|
|
100
|
-
</
|
|
100
|
+
</BodySmall>
|
|
101
101
|
</HStack>
|
|
102
102
|
<View style={IOStyles.row}>
|
|
103
103
|
{badge ? (
|
|
@@ -18,7 +18,7 @@ import { WithTestID } from "../../utils/types";
|
|
|
18
18
|
import { Badge } from "../badge";
|
|
19
19
|
import { IOIcons, Icon } from "../icons";
|
|
20
20
|
import { HStack, VStack } from "../stack";
|
|
21
|
-
import {
|
|
21
|
+
import { LabelMini, BodySmall } from "../typography";
|
|
22
22
|
import { ModuleStatic } from "./ModuleStatic";
|
|
23
23
|
import {
|
|
24
24
|
PressableModuleBase,
|
|
@@ -79,7 +79,7 @@ export const ModuleNavigation = (props: WithTestID<ModuleNavigationProps>) => {
|
|
|
79
79
|
{iconComponent ?? imageComponent}
|
|
80
80
|
|
|
81
81
|
<View style={{ flexShrink: 1 }}>
|
|
82
|
-
<
|
|
82
|
+
<BodySmall
|
|
83
83
|
color={theme["interactiveElem-default"]}
|
|
84
84
|
weight="Semibold"
|
|
85
85
|
numberOfLines={2}
|
|
@@ -87,9 +87,11 @@ export const ModuleNavigation = (props: WithTestID<ModuleNavigationProps>) => {
|
|
|
87
87
|
style={{ flexShrink: 1 }}
|
|
88
88
|
>
|
|
89
89
|
{title}
|
|
90
|
-
</
|
|
90
|
+
</BodySmall>
|
|
91
91
|
{subtitle && (
|
|
92
|
-
<
|
|
92
|
+
<LabelMini weight="Regular" color={theme["textBody-tertiary"]}>
|
|
93
|
+
{subtitle}
|
|
94
|
+
</LabelMini>
|
|
93
95
|
)}
|
|
94
96
|
</View>
|
|
95
97
|
</HStack>
|