@carbon/ibm-products 2.90.0 → 2.91.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 (81) hide show
  1. package/css/index-full-carbon.css +244 -1
  2. package/css/index-full-carbon.css.map +1 -1
  3. package/css/index-full-carbon.min.css +1 -1
  4. package/css/index-full-carbon.min.css.map +1 -1
  5. package/css/index-without-carbon-released-only.css +219 -41
  6. package/css/index-without-carbon-released-only.css.map +1 -1
  7. package/css/index-without-carbon-released-only.min.css +1 -1
  8. package/css/index-without-carbon-released-only.min.css.map +1 -1
  9. package/css/index-without-carbon.css +244 -1
  10. package/css/index-without-carbon.css.map +1 -1
  11. package/css/index-without-carbon.min.css +1 -1
  12. package/css/index-without-carbon.min.css.map +1 -1
  13. package/css/index.css +283 -40
  14. package/css/index.css.map +1 -1
  15. package/css/index.min.css +1 -1
  16. package/css/index.min.css.map +1 -1
  17. package/es/components/CoachmarkOverlayElements/CoachmarkOverlayElements.js +1 -1
  18. package/es/components/DataSpreadsheet/DataSpreadsheet.d.ts +1 -0
  19. package/es/components/DataSpreadsheet/DataSpreadsheet.d.ts.map +1 -1
  20. package/es/components/DataSpreadsheet/DataSpreadsheet.js +6 -0
  21. package/es/components/Datagrid/utils/filterPropsForTesting.d.ts +2 -2
  22. package/es/components/Datagrid/utils/getBatchActions.d.ts +2 -2
  23. package/es/components/InterstitialScreen/InterstitialScreen.d.ts.map +1 -1
  24. package/es/components/InterstitialScreen/InterstitialScreen.js +1 -7
  25. package/es/components/InterstitialScreen/InterstitialScreenBody.d.ts.map +1 -1
  26. package/es/components/InterstitialScreen/InterstitialScreenBody.js +35 -22
  27. package/es/components/InterstitialScreen/context.d.ts +0 -1
  28. package/es/components/InterstitialScreen/context.d.ts.map +1 -1
  29. package/es/components/NotificationsPanel/NotificationsPanel_data.d.ts +2 -2
  30. package/es/components/PageHeader/PageHeader.d.ts.map +1 -1
  31. package/es/components/PageHeader/PageHeader.js +0 -3
  32. package/es/components/Tearsheet/next/Tearsheet.d.ts.map +1 -1
  33. package/es/components/Tearsheet/next/Tearsheet.js +6 -1
  34. package/es/global/js/hooks/index.d.ts +1 -0
  35. package/es/global/js/hooks/useCarbonFeatureFlagsObject.d.ts +17 -0
  36. package/es/global/js/hooks/useCarbonFeatureFlagsObject.d.ts.map +1 -0
  37. package/es/global/js/hooks/useCarbonFeatureFlagsObject.js +35 -0
  38. package/lib/components/CoachmarkOverlayElements/CoachmarkOverlayElements.js +1 -1
  39. package/lib/components/DataSpreadsheet/DataSpreadsheet.d.ts +1 -0
  40. package/lib/components/DataSpreadsheet/DataSpreadsheet.d.ts.map +1 -1
  41. package/lib/components/DataSpreadsheet/DataSpreadsheet.js +6 -0
  42. package/lib/components/Datagrid/utils/filterPropsForTesting.d.ts +2 -2
  43. package/lib/components/Datagrid/utils/getBatchActions.d.ts +2 -2
  44. package/lib/components/InterstitialScreen/InterstitialScreen.d.ts.map +1 -1
  45. package/lib/components/InterstitialScreen/InterstitialScreen.js +1 -7
  46. package/lib/components/InterstitialScreen/InterstitialScreenBody.d.ts.map +1 -1
  47. package/lib/components/InterstitialScreen/InterstitialScreenBody.js +34 -21
  48. package/lib/components/InterstitialScreen/context.d.ts +0 -1
  49. package/lib/components/InterstitialScreen/context.d.ts.map +1 -1
  50. package/lib/components/NotificationsPanel/NotificationsPanel_data.d.ts +2 -2
  51. package/lib/components/PageHeader/PageHeader.d.ts.map +1 -1
  52. package/lib/components/PageHeader/PageHeader.js +0 -3
  53. package/lib/components/Tearsheet/next/Tearsheet.d.ts.map +1 -1
  54. package/lib/components/Tearsheet/next/Tearsheet.js +6 -1
  55. package/lib/global/js/hooks/index.d.ts +1 -0
  56. package/lib/global/js/hooks/useCarbonFeatureFlagsObject.d.ts +17 -0
  57. package/lib/global/js/hooks/useCarbonFeatureFlagsObject.d.ts.map +1 -0
  58. package/lib/global/js/hooks/useCarbonFeatureFlagsObject.js +36 -0
  59. package/package.json +17 -17
  60. package/scss/components/InterstitialScreen/_interstitial-screen.scss +1 -2
  61. package/scss/components/PageHeader/_page-header.scss +2 -1
  62. package/es/global/js/utils/carousel/carousel-test.d.ts +0 -2
  63. package/es/global/js/utils/carousel/carousel-test.d.ts.map +0 -1
  64. package/es/global/js/utils/carousel/carousel.d.ts +0 -15
  65. package/es/global/js/utils/carousel/carousel.d.ts.map +0 -1
  66. package/es/global/js/utils/carousel/index.d.ts +0 -9
  67. package/es/global/js/utils/carousel/index.d.ts.map +0 -1
  68. package/es/global/js/utils/carousel/swipeEvents.d.ts +0 -8
  69. package/es/global/js/utils/carousel/swipeEvents.d.ts.map +0 -1
  70. package/es/global/js/utils/carousel/types.d.ts +0 -39
  71. package/es/global/js/utils/carousel/types.d.ts.map +0 -1
  72. package/lib/global/js/utils/carousel/carousel-test.d.ts +0 -2
  73. package/lib/global/js/utils/carousel/carousel-test.d.ts.map +0 -1
  74. package/lib/global/js/utils/carousel/carousel.d.ts +0 -15
  75. package/lib/global/js/utils/carousel/carousel.d.ts.map +0 -1
  76. package/lib/global/js/utils/carousel/index.d.ts +0 -9
  77. package/lib/global/js/utils/carousel/index.d.ts.map +0 -1
  78. package/lib/global/js/utils/carousel/swipeEvents.d.ts +0 -8
  79. package/lib/global/js/utils/carousel/swipeEvents.d.ts.map +0 -1
  80. package/lib/global/js/utils/carousel/types.d.ts +0 -39
  81. package/lib/global/js/utils/carousel/types.d.ts.map +0 -1
package/css/index.css CHANGED
@@ -15206,8 +15206,8 @@ button.c4p--add-select__global-filter-toggle--open {
15206
15206
  opacity: 1;
15207
15207
  }
15208
15208
  .c4p--page-header__next .c4p--page-header__content {
15209
- padding: 1.5rem 0;
15210
15209
  background-color: var(--cds-layer);
15210
+ padding-block-start: 1.5rem;
15211
15211
  }
15212
15212
  @media (max-width: 41.98rem) {
15213
15213
  .c4p--page-header__next .c4p--page-header__content__title-wrapper {
@@ -15297,6 +15297,7 @@ button.c4p--add-select__global-filter-toggle--open {
15297
15297
  letter-spacing: var(--cds-body-01-letter-spacing, 0.16px);
15298
15298
  margin-block-start: 0.5rem;
15299
15299
  max-inline-size: 40rem;
15300
+ padding-block-end: 1.5rem;
15300
15301
  }
15301
15302
  .c4p--page-header__next [data-hidden]:not([data-fixed]) {
15302
15303
  display: none;
@@ -22394,69 +22395,246 @@ th.c4p--datagrid__select-all-toggle-on.button {
22394
22395
 
22395
22396
  /* stylelint-disable max-nesting-depth */
22396
22397
  /* stylelint-disable declaration-no-important */
22397
- .c4p--carousel {
22398
+ /**
22399
+ * Copyright IBM Corp. 2025
22400
+ *
22401
+ * This source code is licensed under the Apache-2.0 license found in the
22402
+ * LICENSE file in the root directory of this source tree.
22403
+ **/
22404
+ /**
22405
+ * Copyright IBM Corp. 2025
22406
+ *
22407
+ * This source code is licensed under the Apache-2.0 license found in the
22408
+ * LICENSE file in the root directory of this source tree.
22409
+ */
22410
+ /**
22411
+ * Copyright IBM Corp. 2025
22412
+ *
22413
+ * This source code is licensed under the Apache-2.0 license found in the
22414
+ * LICENSE file in the root directory of this source tree.
22415
+ **/
22416
+ .carousel__view-stack .carousel__itemsWrapper {
22398
22417
  position: relative;
22399
- /* stylelint-disable-next-line max-nesting-depth */
22400
- }
22401
- .c4p--carousel:focus {
22402
- outline: none;
22418
+ overflow: hidden;
22419
+ block-size: 100%;
22420
+ inline-size: 100%;
22421
+ min-inline-size: 20vh;
22403
22422
  }
22404
22423
 
22405
- .c4p--carousel__elements-container {
22424
+ :host(.carousel__live-region),
22425
+ .carousel__live-region {
22426
+ position: absolute;
22406
22427
  overflow: hidden;
22428
+ padding: 0;
22429
+ border: 0;
22430
+ margin: -1px;
22431
+ block-size: 1px;
22432
+ clip: rect(0 0 0 0);
22433
+ -webkit-clip-path: inset(50%);
22434
+ clip-path: inset(50%);
22435
+ inline-size: 1px;
22436
+ white-space: nowrap;
22407
22437
  }
22408
22438
 
22409
- .c4p--carousel__elements-container--scrolled,
22410
- .c4p--carousel__elements-container--scroll-max {
22411
- position: absolute;
22412
- z-index: 1;
22413
- inline-size: 2rem;
22414
- inset-block: 0;
22415
- pointer-events: none;
22439
+ :host(.carousel__view),
22440
+ .carousel__view {
22441
+ visibility: hidden;
22416
22442
  }
22417
22443
 
22418
- .c4p--carousel__elements-container--scrolled {
22419
- inset-inline-start: 0;
22444
+ :host(.carousel__view-active),
22445
+ .carousel__view-active,
22446
+ :host(.carousel__view-recycle-out),
22447
+ .carousel__view-recycle-out,
22448
+ :host(.carousel__view-recycle-in),
22449
+ .carousel__view-recycle-in {
22450
+ visibility: visible;
22420
22451
  }
22421
22452
 
22422
- .c4p--carousel__elements-container--scroll-max {
22423
- inset-inline-end: 0;
22453
+ @keyframes out-to-active {
22454
+ from {
22455
+ transform: translateX(-100%);
22456
+ }
22457
+ to {
22458
+ transform: translateX(-200%);
22459
+ }
22460
+ }
22461
+ @keyframes active-to-out {
22462
+ from {
22463
+ transform: translateX(-100%);
22464
+ }
22465
+ to {
22466
+ transform: translateX(0);
22467
+ }
22468
+ }
22469
+ :host(.carousel__view),
22470
+ .carousel__view {
22471
+ z-index: 80;
22472
+ overflow: hidden auto;
22473
+ block-size: 100%;
22474
+ inline-size: 100%;
22475
+ inset-inline-start: 100%;
22476
+ transform: translateX(0);
22477
+ }
22478
+ @media (prefers-reduced-motion: no-preference) {
22479
+ :host(.carousel__view),
22480
+ .carousel__view {
22481
+ transition: transform 240ms cubic-bezier(0.5, 0, 0.1, 1);
22482
+ }
22483
+ }
22484
+ @media (prefers-reduced-motion: reduce) {
22485
+ :host(.carousel__view),
22486
+ .carousel__view {
22487
+ animation: none;
22488
+ transition: none;
22489
+ }
22424
22490
  }
22425
22491
 
22426
- .c4p--carousel__elements {
22427
- display: flex;
22428
- overflow: scroll;
22429
- -ms-overflow-style: none;
22430
- scroll-behavior: smooth;
22431
- scroll-snap-type: x mandatory;
22432
- scrollbar-width: none;
22433
- -webkit-touch-callout: none;
22434
- -webkit-user-select: none;
22435
- -khtml-user-select: none;
22436
- -moz-user-select: none;
22437
- -ms-user-select: none;
22438
- user-select: none;
22492
+ :host(.carousel__view:focus),
22493
+ .carousel__view:focus {
22494
+ outline: 2px solid var(--cds-focus, #0f62fe);
22495
+ outline-offset: -2px;
22439
22496
  }
22440
- .c4p--carousel__elements:focus {
22497
+ @media screen and (prefers-contrast) {
22498
+ :host(.carousel__view:focus),
22499
+ .carousel__view:focus {
22500
+ outline-style: dotted;
22501
+ }
22502
+ }
22503
+
22504
+ :host(.carousel__view-active),
22505
+ .carousel__view-active {
22506
+ z-index: 100;
22507
+ overflow: hidden auto;
22508
+ block-size: 100%;
22509
+ inline-size: 100%;
22510
+ inset-inline-start: 100%;
22511
+ transform: translateX(-100%);
22512
+ }
22513
+ @media (prefers-reduced-motion: no-preference) {
22514
+ :host(.carousel__view-active),
22515
+ .carousel__view-active {
22516
+ transition: transform 240ms cubic-bezier(0.5, 0, 0.1, 1);
22517
+ }
22518
+ }
22519
+ @media (prefers-reduced-motion: reduce) {
22520
+ :host(.carousel__view-active),
22521
+ .carousel__view-active {
22522
+ animation: none;
22523
+ transition: none;
22524
+ }
22525
+ }
22526
+
22527
+ :host(.carousel__view-active:focus),
22528
+ .carousel__view-active:focus {
22441
22529
  outline: 2px solid var(--cds-focus, #0f62fe);
22442
22530
  outline-offset: -2px;
22443
22531
  }
22444
22532
  @media screen and (prefers-contrast) {
22445
- .c4p--carousel__elements:focus {
22533
+ :host(.carousel__view-active:focus),
22534
+ .carousel__view-active:focus {
22446
22535
  outline-style: dotted;
22447
22536
  }
22448
22537
  }
22449
- .c4p--carousel__elements {
22450
- /* stylelint-disable-next-line max-nesting-depth */
22538
+
22539
+ :host(.carousel__view-in-stack),
22540
+ .carousel__view-in-stack {
22541
+ z-index: 90;
22542
+ overflow: hidden auto;
22543
+ block-size: 100%;
22544
+ inline-size: 100%;
22545
+ inset-inline-start: 100%;
22546
+ transform: translateX(-200%);
22451
22547
  }
22452
- @media (prefers-reduced-motion) {
22453
- .c4p--carousel__elements {
22454
- scroll-behavior: auto;
22548
+ @media (prefers-reduced-motion: no-preference) {
22549
+ :host(.carousel__view-in-stack),
22550
+ .carousel__view-in-stack {
22551
+ transition: transform 240ms cubic-bezier(0.5, 0, 0.1, 1);
22552
+ }
22553
+ }
22554
+ @media (prefers-reduced-motion: reduce) {
22555
+ :host(.carousel__view-in-stack),
22556
+ .carousel__view-in-stack {
22557
+ animation: none;
22558
+ transition: none;
22455
22559
  }
22456
22560
  }
22457
22561
 
22458
- .c4p--carousel__elements::-webkit-scrollbar {
22459
- display: none;
22562
+ :host(.carousel__view-in-stack:focus),
22563
+ .carousel__view-in-stack:focus {
22564
+ outline: 2px solid var(--cds-focus, #0f62fe);
22565
+ outline-offset: -2px;
22566
+ }
22567
+ @media screen and (prefers-contrast) {
22568
+ :host(.carousel__view-in-stack:focus),
22569
+ .carousel__view-in-stack:focus {
22570
+ outline-style: dotted;
22571
+ }
22572
+ }
22573
+
22574
+ :host(.carousel__view-recycle-in),
22575
+ .carousel__view-recycle-in {
22576
+ z-index: 100;
22577
+ overflow: hidden auto;
22578
+ block-size: 100%;
22579
+ inline-size: 100%;
22580
+ }
22581
+ @media (prefers-reduced-motion: no-preference) {
22582
+ :host(.carousel__view-recycle-in),
22583
+ .carousel__view-recycle-in {
22584
+ animation: out-to-active 240ms cubic-bezier(0.5, 0, 0.1, 1) forwards;
22585
+ }
22586
+ }
22587
+ @media (prefers-reduced-motion: reduce) {
22588
+ :host(.carousel__view-recycle-in),
22589
+ .carousel__view-recycle-in {
22590
+ animation: none;
22591
+ transition: none;
22592
+ }
22593
+ }
22594
+
22595
+ :host(.carousel__view-recycle-in:focus),
22596
+ .carousel__view-recycle-in:focus {
22597
+ outline: 2px solid var(--cds-focus, #0f62fe);
22598
+ outline-offset: -2px;
22599
+ }
22600
+ @media screen and (prefers-contrast) {
22601
+ :host(.carousel__view-recycle-in:focus),
22602
+ .carousel__view-recycle-in:focus {
22603
+ outline-style: dotted;
22604
+ }
22605
+ }
22606
+
22607
+ :host(.carousel__view-recycle-out),
22608
+ .carousel__view-recycle-out {
22609
+ z-index: 90;
22610
+ overflow: hidden auto;
22611
+ block-size: 100%;
22612
+ inline-size: 100%;
22613
+ }
22614
+ @media (prefers-reduced-motion: no-preference) {
22615
+ :host(.carousel__view-recycle-out),
22616
+ .carousel__view-recycle-out {
22617
+ animation: active-to-out 240ms cubic-bezier(0.5, 0, 0.1, 1) forwards;
22618
+ }
22619
+ }
22620
+ @media (prefers-reduced-motion: reduce) {
22621
+ :host(.carousel__view-recycle-out),
22622
+ .carousel__view-recycle-out {
22623
+ animation: none;
22624
+ transition: none;
22625
+ }
22626
+ }
22627
+
22628
+ :host(.carousel__view-recycle-out:focus),
22629
+ .carousel__view-recycle-out:focus {
22630
+ outline: 2px solid var(--cds-focus, #0f62fe);
22631
+ outline-offset: -2px;
22632
+ }
22633
+ @media screen and (prefers-contrast) {
22634
+ :host(.carousel__view-recycle-out:focus),
22635
+ .carousel__view-recycle-out:focus {
22636
+ outline-style: dotted;
22637
+ }
22460
22638
  }
22461
22639
 
22462
22640
  .c4p--interstitial-screen--body {
@@ -23304,6 +23482,71 @@ th.c4p--datagrid__select-all-toggle-on.button {
23304
23482
  }
23305
23483
 
23306
23484
  /* stylelint-disable max-nesting-depth */
23485
+ .c4p--carousel {
23486
+ position: relative;
23487
+ /* stylelint-disable-next-line max-nesting-depth */
23488
+ }
23489
+ .c4p--carousel:focus {
23490
+ outline: none;
23491
+ }
23492
+
23493
+ .c4p--carousel__elements-container {
23494
+ overflow: hidden;
23495
+ }
23496
+
23497
+ .c4p--carousel__elements-container--scrolled,
23498
+ .c4p--carousel__elements-container--scroll-max {
23499
+ position: absolute;
23500
+ z-index: 1;
23501
+ inline-size: 2rem;
23502
+ inset-block: 0;
23503
+ pointer-events: none;
23504
+ }
23505
+
23506
+ .c4p--carousel__elements-container--scrolled {
23507
+ inset-inline-start: 0;
23508
+ }
23509
+
23510
+ .c4p--carousel__elements-container--scroll-max {
23511
+ inset-inline-end: 0;
23512
+ }
23513
+
23514
+ .c4p--carousel__elements {
23515
+ display: flex;
23516
+ overflow: scroll;
23517
+ -ms-overflow-style: none;
23518
+ scroll-behavior: smooth;
23519
+ scroll-snap-type: x mandatory;
23520
+ scrollbar-width: none;
23521
+ -webkit-touch-callout: none;
23522
+ -webkit-user-select: none;
23523
+ -khtml-user-select: none;
23524
+ -moz-user-select: none;
23525
+ -ms-user-select: none;
23526
+ user-select: none;
23527
+ }
23528
+ .c4p--carousel__elements:focus {
23529
+ outline: 2px solid var(--cds-focus, #0f62fe);
23530
+ outline-offset: -2px;
23531
+ }
23532
+ @media screen and (prefers-contrast) {
23533
+ .c4p--carousel__elements:focus {
23534
+ outline-style: dotted;
23535
+ }
23536
+ }
23537
+ .c4p--carousel__elements {
23538
+ /* stylelint-disable-next-line max-nesting-depth */
23539
+ }
23540
+ @media (prefers-reduced-motion) {
23541
+ .c4p--carousel__elements {
23542
+ scroll-behavior: auto;
23543
+ }
23544
+ }
23545
+
23546
+ .c4p--carousel__elements::-webkit-scrollbar {
23547
+ display: none;
23548
+ }
23549
+
23307
23550
  .c4p--coachmark-overlay-elements__element-stepped-media {
23308
23551
  padding: 0 1rem;
23309
23552
  /* stylelint-disable-next-line function-no-unknown -- to-rem carbon replacement for rem */