@yahoo/uds-mobile 2.4.3 → 2.6.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.
Files changed (57) hide show
  1. package/dist/bin/fixtures/dist/index.mjs +20 -0
  2. package/dist/bin/uds-mobile.mjs +10 -2
  3. package/dist/components/Avatar.d.cts +1 -1
  4. package/dist/components/Avatar.d.ts +1 -1
  5. package/dist/components/Avatar.js.map +1 -1
  6. package/dist/components/Banner/Banner.cjs +179 -0
  7. package/dist/components/Banner/Banner.d.cts +59 -0
  8. package/dist/components/Banner/Banner.d.cts.map +1 -0
  9. package/dist/components/Banner/Banner.d.ts +59 -0
  10. package/dist/components/Banner/Banner.d.ts.map +1 -0
  11. package/dist/components/Banner/Banner.js +178 -0
  12. package/dist/components/Banner/Banner.js.map +1 -0
  13. package/dist/components/Banner/BannerContent.cjs +26 -0
  14. package/dist/components/Banner/BannerContent.d.cts +16 -0
  15. package/dist/components/Banner/BannerContent.d.cts.map +1 -0
  16. package/dist/components/Banner/BannerContent.d.ts +16 -0
  17. package/dist/components/Banner/BannerContent.d.ts.map +1 -0
  18. package/dist/components/Banner/BannerContent.js +25 -0
  19. package/dist/components/Banner/BannerContent.js.map +1 -0
  20. package/dist/components/Banner/BannerDescription.cjs +46 -0
  21. package/dist/components/Banner/BannerDescription.d.cts +37 -0
  22. package/dist/components/Banner/BannerDescription.d.cts.map +1 -0
  23. package/dist/components/Banner/BannerDescription.d.ts +37 -0
  24. package/dist/components/Banner/BannerDescription.d.ts.map +1 -0
  25. package/dist/components/Banner/BannerDescription.js +45 -0
  26. package/dist/components/Banner/BannerDescription.js.map +1 -0
  27. package/dist/components/Banner/BannerTitle.cjs +44 -0
  28. package/dist/components/Banner/BannerTitle.d.cts +35 -0
  29. package/dist/components/Banner/BannerTitle.d.cts.map +1 -0
  30. package/dist/components/Banner/BannerTitle.d.ts +35 -0
  31. package/dist/components/Banner/BannerTitle.d.ts.map +1 -0
  32. package/dist/components/Banner/BannerTitle.js +43 -0
  33. package/dist/components/Banner/BannerTitle.js.map +1 -0
  34. package/dist/components/Banner/index.cjs +11 -0
  35. package/dist/components/Banner/index.d.cts +6 -0
  36. package/dist/components/Banner/index.d.ts +6 -0
  37. package/dist/components/Banner/index.js +7 -0
  38. package/dist/components/Banner/utils.cjs +56 -0
  39. package/dist/components/Banner/utils.d.cts +27 -0
  40. package/dist/components/Banner/utils.d.cts.map +1 -0
  41. package/dist/components/Banner/utils.d.ts +27 -0
  42. package/dist/components/Banner/utils.d.ts.map +1 -0
  43. package/dist/components/Banner/utils.js +53 -0
  44. package/dist/components/Banner/utils.js.map +1 -0
  45. package/dist/components/Icon.d.cts +1 -1
  46. package/dist/components/Icon.d.ts +1 -1
  47. package/dist/types/dist/index.d.cts +19 -1
  48. package/dist/types/dist/index.d.cts.map +1 -1
  49. package/dist/types/dist/index.d.ts +19 -1
  50. package/dist/types/dist/index.d.ts.map +1 -1
  51. package/fonts/index.cjs +207 -207
  52. package/fonts/index.mjs +207 -207
  53. package/generated/styles.cjs +84 -0
  54. package/generated/styles.d.ts +77 -10
  55. package/generated/styles.mjs +84 -0
  56. package/generated/unistyles.d.ts +175 -0
  57. package/package.json +11 -1
@@ -1233,7 +1233,7 @@ export declare const styles: {
1233
1233
  | '2xl-invert'
1234
1234
  | undefined;
1235
1235
  iconSize?: 'xs' | 'sm' | 'md' | 'lg' | undefined;
1236
- avatarSize?: 'xs' | 'sm' | 'md' | 'lg' | 'xl' | undefined;
1236
+ avatarSize?: 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl' | '2xs' | '3xl' | undefined;
1237
1237
  }) => void;
1238
1238
  };
1239
1239
 
@@ -1259,25 +1259,25 @@ export declare const avatarStyles: {
1259
1259
  borderColor: string;
1260
1260
  borderRadius: number;
1261
1261
  fontSize: number;
1262
- iconSizeToken: 'lg' | 'md' | 'sm';
1262
+ iconSizeToken: 'lg' | 'xs' | 'md' | 'sm';
1263
1263
  lineHeight: number;
1264
1264
  };
1265
1265
  } & {
1266
1266
  useVariants: (
1267
1267
  variants:
1268
1268
  | {
1269
- size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl' | undefined;
1269
+ size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl' | '2xs' | '3xl' | undefined;
1270
1270
  icon?: 'primary' | 'secondary' | undefined;
1271
1271
  image?: 'primary' | 'secondary' | undefined;
1272
1272
  text?: 'primary' | 'secondary' | undefined;
1273
1273
  }
1274
1274
  | {
1275
- size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl' | undefined;
1275
+ size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl' | '2xs' | '3xl' | undefined;
1276
1276
  icon?: 'primary' | 'secondary' | undefined;
1277
1277
  text?: 'primary' | 'secondary' | undefined;
1278
1278
  }
1279
1279
  | {
1280
- size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl' | undefined;
1280
+ size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl' | '2xs' | '3xl' | undefined;
1281
1281
  icon?: 'primary' | 'secondary' | undefined;
1282
1282
  },
1283
1283
  ) => void;
@@ -1358,6 +1358,73 @@ export declare const badgeStyles: {
1358
1358
  ) => void;
1359
1359
  };
1360
1360
 
1361
+ export declare const bannerStyles: {
1362
+ root: {
1363
+ borderRadius: number;
1364
+ gap: number;
1365
+ paddingHorizontal: number;
1366
+ paddingVertical: number;
1367
+ backgroundColor: string;
1368
+ borderColor: string;
1369
+ borderWidth: number;
1370
+ };
1371
+ icon: { fontSize: number; iconSizeToken: 'md'; lineHeight: number; color: string };
1372
+ close: { fontSize: number; iconSizeToken: 'sm'; lineHeight: number };
1373
+ description: {
1374
+ fontFamily: 'YahooProductSans-Medium';
1375
+ fontSize: number;
1376
+ letterSpacing: number;
1377
+ lineHeight: number;
1378
+ };
1379
+ title: {
1380
+ fontFamily: 'YahooProductSans-Medium';
1381
+ fontSize: number;
1382
+ letterSpacing: number;
1383
+ lineHeight: number;
1384
+ };
1385
+ } & {
1386
+ useVariants: (
1387
+ variants:
1388
+ | {
1389
+ size?: undefined;
1390
+ variant?:
1391
+ | 'primary'
1392
+ | 'secondary'
1393
+ | 'brand'
1394
+ | 'alert'
1395
+ | 'warning'
1396
+ | 'info'
1397
+ | 'brand-secondary'
1398
+ | 'alert-secondary'
1399
+ | 'warning-secondary'
1400
+ | 'info-secondary'
1401
+ | 'success'
1402
+ | 'success-secondary'
1403
+ | undefined;
1404
+ }
1405
+ | {
1406
+ size?: undefined;
1407
+ variant?:
1408
+ | 'primary'
1409
+ | 'secondary'
1410
+ | 'brand'
1411
+ | 'alert'
1412
+ | 'warning'
1413
+ | 'info'
1414
+ | 'brand-secondary'
1415
+ | 'alert-secondary'
1416
+ | 'warning-secondary'
1417
+ | 'info-secondary'
1418
+ | 'success'
1419
+ | 'success-secondary'
1420
+ | undefined;
1421
+ }
1422
+ | { size?: undefined }
1423
+ | { size?: undefined }
1424
+ | { size?: undefined },
1425
+ ) => void;
1426
+ };
1427
+
1361
1428
  export declare const bottomSheetStyles: {
1362
1429
  root: {
1363
1430
  backgroundColor: string;
@@ -1981,16 +2048,16 @@ export declare const toastStyles: {
1981
2048
  variants:
1982
2049
  | {
1983
2050
  size?: undefined;
1984
- variant?: 'warning' | 'info' | 'error' | 'loading' | 'success' | undefined;
2051
+ variant?: 'warning' | 'info' | 'success' | 'error' | 'loading' | undefined;
1985
2052
  }
1986
- | { variant?: 'warning' | 'info' | 'error' | 'loading' | 'success' | undefined }
2053
+ | { variant?: 'warning' | 'info' | 'success' | 'error' | 'loading' | undefined }
1987
2054
  | {
1988
2055
  size?: undefined;
1989
- variant?: 'warning' | 'info' | 'error' | 'loading' | 'success' | undefined;
2056
+ variant?: 'warning' | 'info' | 'success' | 'error' | 'loading' | undefined;
1990
2057
  }
1991
2058
  | {
1992
2059
  size?: undefined;
1993
- variant?: 'warning' | 'info' | 'error' | 'loading' | 'success' | undefined;
2060
+ variant?: 'warning' | 'info' | 'success' | 'error' | 'loading' | undefined;
1994
2061
  }
1995
2062
  | { size?: undefined },
1996
2063
  ) => void;
@@ -3187,5 +3254,5 @@ export type StyleProps = {
3187
3254
  | '2xl-invert'
3188
3255
  | undefined;
3189
3256
  iconSize?: 'xs' | 'sm' | 'md' | 'lg' | undefined;
3190
- avatarSize?: 'xs' | 'sm' | 'md' | 'lg' | 'xl' | undefined;
3257
+ avatarSize?: 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl' | '2xs' | '3xl' | undefined;
3191
3258
  };
@@ -1329,6 +1329,9 @@ const styles = StyleSheet.create((theme) => ({
1329
1329
  md: { width: theme.avatarSize['md'], height: theme.avatarSize['md'] },
1330
1330
  lg: { width: theme.avatarSize['lg'], height: theme.avatarSize['lg'] },
1331
1331
  xl: { width: theme.avatarSize['xl'], height: theme.avatarSize['xl'] },
1332
+ '2xl': { width: theme.avatarSize['2xl'], height: theme.avatarSize['2xl'] },
1333
+ '2xs': { width: theme.avatarSize['2xs'], height: theme.avatarSize['2xs'] },
1334
+ '3xl': { width: theme.avatarSize['3xl'], height: theme.avatarSize['3xl'] },
1332
1335
  },
1333
1336
  },
1334
1337
  },
@@ -1354,6 +1357,9 @@ const avatarStyles = StyleSheet.create((theme) => ({
1354
1357
  root: {
1355
1358
  variants: {
1356
1359
  size: {
1360
+ '2xl': theme.components['avatar/size/2xl/root/rest'],
1361
+ '2xs': theme.components['avatar/size/2xs/root/rest'],
1362
+ '3xl': theme.components['avatar/size/3xl/root/rest'],
1357
1363
  lg: theme.components['avatar/size/lg/root/rest'],
1358
1364
  md: theme.components['avatar/size/md/root/rest'],
1359
1365
  sm: theme.components['avatar/size/sm/root/rest'],
@@ -1377,6 +1383,9 @@ const avatarStyles = StyleSheet.create((theme) => ({
1377
1383
  text: {
1378
1384
  variants: {
1379
1385
  size: {
1386
+ '2xl': theme.components['avatar/size/2xl/rootText/rest'],
1387
+ '2xs': theme.components['avatar/size/2xs/rootText/rest'],
1388
+ '3xl': theme.components['avatar/size/3xl/rootText/rest'],
1380
1389
  lg: theme.components['avatar/size/lg/rootText/rest'],
1381
1390
  md: theme.components['avatar/size/md/rootText/rest'],
1382
1391
  sm: theme.components['avatar/size/sm/rootText/rest'],
@@ -1396,6 +1405,9 @@ const avatarStyles = StyleSheet.create((theme) => ({
1396
1405
  icon: {
1397
1406
  variants: {
1398
1407
  size: {
1408
+ '2xl': theme.components['avatar/size/2xl/icon/rest'],
1409
+ '2xs': theme.components['avatar/size/2xs/icon/rest'],
1410
+ '3xl': theme.components['avatar/size/3xl/icon/rest'],
1399
1411
  lg: theme.components['avatar/size/lg/icon/rest'],
1400
1412
  md: theme.components['avatar/size/md/icon/rest'],
1401
1413
  sm: theme.components['avatar/size/sm/icon/rest'],
@@ -1500,6 +1512,77 @@ const badgeStyles = StyleSheet.create((theme) => ({
1500
1512
  },
1501
1513
  }));
1502
1514
 
1515
+ /**
1516
+ * Layer-based styles for Banner.
1517
+ * Uses compound variants for state-specific (disabled/pressed) styles.
1518
+ *
1519
+ * Usage:
1520
+ * ```tsx
1521
+ * bannerStyles.useVariants({
1522
+ * size,
1523
+ * variant,
1524
+ * disabled: isDisabled, // boolean
1525
+ * pressed: isPressed, // boolean
1526
+ * });
1527
+ * // Access: bannerStyles.root, bannerStyles.icon, etc.
1528
+ * ```
1529
+ */
1530
+ const bannerStyles = StyleSheet.create((theme) => ({
1531
+ root: {
1532
+ variants: {
1533
+ size: { default: theme.components['banner/size/default/root/rest'] },
1534
+ variant: {
1535
+ alert: theme.components['banner/variant/alert/root/rest'],
1536
+ 'alert-secondary': theme.components['banner/variant/alert-secondary/root/rest'],
1537
+ brand: theme.components['banner/variant/brand/root/rest'],
1538
+ 'brand-secondary': theme.components['banner/variant/brand-secondary/root/rest'],
1539
+ info: theme.components['banner/variant/info/root/rest'],
1540
+ 'info-secondary': theme.components['banner/variant/info-secondary/root/rest'],
1541
+ primary: theme.components['banner/variant/primary/root/rest'],
1542
+ secondary: theme.components['banner/variant/secondary/root/rest'],
1543
+ success: theme.components['banner/variant/success/root/rest'],
1544
+ 'success-secondary': theme.components['banner/variant/success-secondary/root/rest'],
1545
+ warning: theme.components['banner/variant/warning/root/rest'],
1546
+ 'warning-secondary': theme.components['banner/variant/warning-secondary/root/rest'],
1547
+ },
1548
+ },
1549
+ },
1550
+ icon: {
1551
+ variants: {
1552
+ size: { default: theme.components['banner/size/default/icon/rest'] },
1553
+ variant: {
1554
+ alert: theme.components['banner/variant/alert/icon/rest'],
1555
+ 'alert-secondary': theme.components['banner/variant/alert-secondary/icon/rest'],
1556
+ brand: theme.components['banner/variant/brand/icon/rest'],
1557
+ 'brand-secondary': theme.components['banner/variant/brand-secondary/icon/rest'],
1558
+ info: theme.components['banner/variant/info/icon/rest'],
1559
+ 'info-secondary': theme.components['banner/variant/info-secondary/icon/rest'],
1560
+ primary: theme.components['banner/variant/primary/icon/rest'],
1561
+ secondary: theme.components['banner/variant/secondary/icon/rest'],
1562
+ success: theme.components['banner/variant/success/icon/rest'],
1563
+ 'success-secondary': theme.components['banner/variant/success-secondary/icon/rest'],
1564
+ warning: theme.components['banner/variant/warning/icon/rest'],
1565
+ 'warning-secondary': theme.components['banner/variant/warning-secondary/icon/rest'],
1566
+ },
1567
+ },
1568
+ },
1569
+ close: {
1570
+ variants: {
1571
+ size: { default: theme.components['banner/size/default/close/rest'] },
1572
+ },
1573
+ },
1574
+ description: {
1575
+ variants: {
1576
+ size: { default: theme.components['banner/size/default/description/rest'] },
1577
+ },
1578
+ },
1579
+ title: {
1580
+ variants: {
1581
+ size: { default: theme.components['banner/size/default/title/rest'] },
1582
+ },
1583
+ },
1584
+ }));
1585
+
1503
1586
  /**
1504
1587
  * Layer-based styles for BottomSheet.
1505
1588
  * Uses compound variants for state-specific (disabled/pressed) styles.
@@ -4893,6 +4976,7 @@ export {
4893
4976
  styles,
4894
4977
  avatarStyles,
4895
4978
  badgeStyles,
4979
+ bannerStyles,
4896
4980
  bottomSheetStyles,
4897
4981
  buttonStyles,
4898
4982
  checkboxStyles,
@@ -40,6 +40,54 @@ interface ComponentTheme {
40
40
  borderColor: string;
41
41
  borderRadius: number;
42
42
  };
43
+ 'avatar/size/2xl/icon/rest': {
44
+ fontSize: number;
45
+ iconSizeToken: string;
46
+ lineHeight: number;
47
+ };
48
+ 'avatar/size/2xl/root/rest': {
49
+ borderWidth: number;
50
+ height: number;
51
+ width: number;
52
+ };
53
+ 'avatar/size/2xl/rootText/rest': {
54
+ fontFamily: string;
55
+ fontSize: number;
56
+ letterSpacing: number;
57
+ lineHeight: number;
58
+ };
59
+ 'avatar/size/2xs/icon/rest': {
60
+ fontSize: number;
61
+ iconSizeToken: string;
62
+ lineHeight: number;
63
+ };
64
+ 'avatar/size/2xs/root/rest': {
65
+ borderWidth: number;
66
+ height: number;
67
+ width: number;
68
+ };
69
+ 'avatar/size/2xs/rootText/rest': {
70
+ fontFamily: string;
71
+ fontSize: number;
72
+ letterSpacing: number;
73
+ lineHeight: number;
74
+ };
75
+ 'avatar/size/3xl/icon/rest': {
76
+ fontSize: number;
77
+ iconSizeToken: string;
78
+ lineHeight: number;
79
+ };
80
+ 'avatar/size/3xl/root/rest': {
81
+ borderWidth: number;
82
+ height: number;
83
+ width: number;
84
+ };
85
+ 'avatar/size/3xl/rootText/rest': {
86
+ fontFamily: string;
87
+ fontSize: number;
88
+ letterSpacing: number;
89
+ lineHeight: number;
90
+ };
43
91
  'avatar/size/lg/icon/rest': {
44
92
  fontSize: number;
45
93
  iconSizeToken: string;
@@ -344,6 +392,130 @@ interface ComponentTheme {
344
392
  'badge/variant/warning/rootText/rest': {
345
393
  color: string;
346
394
  };
395
+ 'banner/size/default/close/rest': {
396
+ fontSize: number;
397
+ iconSizeToken: string;
398
+ lineHeight: number;
399
+ };
400
+ 'banner/size/default/description/rest': {
401
+ fontFamily: string;
402
+ fontSize: number;
403
+ letterSpacing: number;
404
+ lineHeight: number;
405
+ };
406
+ 'banner/size/default/icon/rest': {
407
+ fontSize: number;
408
+ iconSizeToken: string;
409
+ lineHeight: number;
410
+ };
411
+ 'banner/size/default/root/rest': {
412
+ borderRadius: number;
413
+ gap: number;
414
+ paddingHorizontal: number;
415
+ paddingVertical: number;
416
+ };
417
+ 'banner/size/default/title/rest': {
418
+ fontFamily: string;
419
+ fontSize: number;
420
+ letterSpacing: number;
421
+ lineHeight: number;
422
+ };
423
+ 'banner/variant/alert-secondary/icon/rest': {
424
+ color: string;
425
+ };
426
+ 'banner/variant/alert-secondary/root/rest': {
427
+ backgroundColor: string;
428
+ borderColor: string;
429
+ borderWidth: number;
430
+ };
431
+ 'banner/variant/alert/icon/rest': {
432
+ color: string;
433
+ };
434
+ 'banner/variant/alert/root/rest': {
435
+ backgroundColor: string;
436
+ borderColor: string;
437
+ borderWidth: number;
438
+ };
439
+ 'banner/variant/brand-secondary/icon/rest': {
440
+ color: string;
441
+ };
442
+ 'banner/variant/brand-secondary/root/rest': {
443
+ backgroundColor: string;
444
+ borderColor: string;
445
+ borderWidth: number;
446
+ };
447
+ 'banner/variant/brand/icon/rest': {
448
+ color: string;
449
+ };
450
+ 'banner/variant/brand/root/rest': {
451
+ backgroundColor: string;
452
+ borderColor: string;
453
+ borderWidth: number;
454
+ };
455
+ 'banner/variant/info-secondary/icon/rest': {
456
+ color: string;
457
+ };
458
+ 'banner/variant/info-secondary/root/rest': {
459
+ backgroundColor: string;
460
+ borderColor: string;
461
+ borderWidth: number;
462
+ };
463
+ 'banner/variant/info/icon/rest': {
464
+ color: string;
465
+ };
466
+ 'banner/variant/info/root/rest': {
467
+ backgroundColor: string;
468
+ borderColor: string;
469
+ borderWidth: number;
470
+ };
471
+ 'banner/variant/primary/icon/rest': {
472
+ color: string;
473
+ };
474
+ 'banner/variant/primary/root/rest': {
475
+ backgroundColor: string;
476
+ borderColor: string;
477
+ borderWidth: number;
478
+ };
479
+ 'banner/variant/secondary/icon/rest': {
480
+ color: string;
481
+ };
482
+ 'banner/variant/secondary/root/rest': {
483
+ backgroundColor: string;
484
+ borderColor: string;
485
+ borderWidth: number;
486
+ };
487
+ 'banner/variant/success-secondary/icon/rest': {
488
+ color: string;
489
+ };
490
+ 'banner/variant/success-secondary/root/rest': {
491
+ backgroundColor: string;
492
+ borderColor: string;
493
+ borderWidth: number;
494
+ };
495
+ 'banner/variant/success/icon/rest': {
496
+ color: string;
497
+ };
498
+ 'banner/variant/success/root/rest': {
499
+ backgroundColor: string;
500
+ borderColor: string;
501
+ borderWidth: number;
502
+ };
503
+ 'banner/variant/warning-secondary/icon/rest': {
504
+ color: string;
505
+ };
506
+ 'banner/variant/warning-secondary/root/rest': {
507
+ backgroundColor: string;
508
+ borderColor: string;
509
+ borderWidth: number;
510
+ };
511
+ 'banner/variant/warning/icon/rest': {
512
+ color: string;
513
+ };
514
+ 'banner/variant/warning/root/rest': {
515
+ backgroundColor: string;
516
+ borderColor: string;
517
+ borderWidth: number;
518
+ };
347
519
  'bottomSheet/variant/default/handleIndicator/rest': {
348
520
  backgroundColor: string;
349
521
  };
@@ -4624,6 +4796,9 @@ export interface AppTheme {
4624
4796
  md: number;
4625
4797
  lg: number;
4626
4798
  xl: number;
4799
+ '2xl': number;
4800
+ '2xs': number;
4801
+ '3xl': number;
4627
4802
  };
4628
4803
  font: {
4629
4804
  sans: string;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@yahoo/uds-mobile",
3
- "version": "2.4.3",
3
+ "version": "2.6.0",
4
4
  "type": "module",
5
5
  "bin": {
6
6
  "uds-mobile": "./cli/uds-mobile.js"
@@ -40,6 +40,16 @@
40
40
  "default": "./dist/components/Badge.cjs"
41
41
  }
42
42
  },
43
+ "./Banner": {
44
+ "import": {
45
+ "types": "./dist/components/Banner/index.d.ts",
46
+ "default": "./dist/components/Banner/index.js"
47
+ },
48
+ "require": {
49
+ "types": "./dist/components/Banner/index.d.cts",
50
+ "default": "./dist/components/Banner/index.cjs"
51
+ }
52
+ },
43
53
  "./BlurTarget": {
44
54
  "import": {
45
55
  "types": "./dist/components/BlurTarget.d.ts",