@arc-ui/components 13.7.0 → 13.8.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 (169) hide show
  1. package/lib/Alert/styles.css +1 -1
  2. package/lib/Align/styles.css +1 -1
  3. package/lib/AppButton/styles.css +1 -1
  4. package/lib/Avatar/Avatar.cjs +2 -2
  5. package/lib/Avatar/Avatar.mjs +2 -2
  6. package/lib/Avatar/styles.css +1 -1
  7. package/lib/AvatarGroup/AvatarGroup.cjs +2 -2
  8. package/lib/AvatarGroup/AvatarGroup.mjs +2 -2
  9. package/lib/AvatarGroup/styles.css +1 -1
  10. package/lib/Badge/styles.css +1 -1
  11. package/lib/Banner/Banner.cjs +5 -5
  12. package/lib/Banner/Banner.mjs +5 -5
  13. package/lib/Box/styles.css +1 -1
  14. package/lib/BrandLogo/styles.css +1 -1
  15. package/lib/Breadcrumbs/styles.css +1 -1
  16. package/lib/Button/styles.css +1 -1
  17. package/lib/ButtonGroup/styles.css +1 -1
  18. package/lib/ButtonV2/styles.css +1 -1
  19. package/lib/Calendar/Calendar.cjs +2 -2
  20. package/lib/Calendar/Calendar.mjs +2 -2
  21. package/lib/Calendar/styles.css +1 -1
  22. package/lib/CardFooter/styles.css +1 -1
  23. package/lib/CardHeading/CardHeading.cjs +1 -1
  24. package/lib/CardHeading/CardHeading.mjs +1 -1
  25. package/lib/CardHeading/styles.css +1 -1
  26. package/lib/Carousel/Carousel.cjs +1 -1
  27. package/lib/Carousel/Carousel.mjs +1 -1
  28. package/lib/Carousel/styles.css +1 -1
  29. package/lib/Checkbox/styles.css +1 -1
  30. package/lib/CheckboxIcon/styles.css +1 -1
  31. package/lib/Columns/styles.css +1 -1
  32. package/lib/ComboBox/styles.css +1 -1
  33. package/lib/ContentSwitcher/styles.css +1 -1
  34. package/lib/ContentSwitcherDropdown/styles.css +1 -1
  35. package/lib/DatePicker/DatePicker.cjs +2 -2
  36. package/lib/DatePicker/DatePicker.mjs +2 -2
  37. package/lib/DatePicker/styles.css +1 -1
  38. package/lib/Disclosure/styles.css +1 -1
  39. package/lib/DisclosureMini/styles.css +1 -1
  40. package/lib/Download/styles.css +1 -1
  41. package/lib/Drawer/styles.css +1 -1
  42. package/lib/Elevation/styles.css +1 -1
  43. package/lib/Filter/styles.css +1 -1
  44. package/lib/FormControl/styles.css +1 -1
  45. package/lib/GhostedHeroBanner/GhostedHeroBanner.cjs +2 -2
  46. package/lib/GhostedHeroBanner/GhostedHeroBanner.mjs +2 -2
  47. package/lib/GhostedHeroBanner/styles.css +1 -1
  48. package/lib/GradientPageBackground/GradientPageBackground.cjs +2 -2
  49. package/lib/GradientPageBackground/GradientPageBackground.mjs +2 -2
  50. package/lib/GradientPageBackground/styles.css +1 -1
  51. package/lib/Grid/styles.css +1 -1
  52. package/lib/Group/styles.css +1 -1
  53. package/lib/Heading/styles.css +1 -1
  54. package/lib/HeroBanner/HeroBanner.cjs +5 -5
  55. package/lib/HeroBanner/HeroBanner.mjs +5 -5
  56. package/lib/HeroBanner/styles.css +1 -1
  57. package/lib/HeroButton/styles.css +1 -1
  58. package/lib/HeroVideoBanner/HeroVideoBanner.cjs +1 -1
  59. package/lib/HeroVideoBanner/HeroVideoBanner.mjs +1 -1
  60. package/lib/HeroVideoBanner/styles.css +1 -1
  61. package/lib/Hidden/styles.css +1 -1
  62. package/lib/HorizontalCard/HorizontalCard.cjs +3 -3
  63. package/lib/HorizontalCard/HorizontalCard.mjs +3 -3
  64. package/lib/HorizontalCard/styles.css +1 -1
  65. package/lib/Icon/styles.css +1 -1
  66. package/lib/Image/Image.cjs +1 -1
  67. package/lib/Image/Image.mjs +1 -1
  68. package/lib/Image/styles.css +1 -1
  69. package/lib/ImpactCard/ImpactCard.cjs +3 -3
  70. package/lib/ImpactCard/ImpactCard.mjs +3 -3
  71. package/lib/ImpactCard/styles.css +1 -1
  72. package/lib/InformationCard/InformationCard.cjs +5 -5
  73. package/lib/InformationCard/InformationCard.mjs +5 -5
  74. package/lib/InformationCard/styles.css +1 -1
  75. package/lib/Link/styles.css +1 -1
  76. package/lib/Markup/styles.css +1 -1
  77. package/lib/MediaCard/MediaCard.cjs +3 -3
  78. package/lib/MediaCard/MediaCard.mjs +3 -3
  79. package/lib/MediaCard/styles.css +1 -1
  80. package/lib/Menu/styles.css +1 -1
  81. package/lib/Modal/styles.css +1 -1
  82. package/lib/NavigationHeader/NavigationHeader.cjs +2 -2
  83. package/lib/NavigationHeader/NavigationHeader.mjs +2 -2
  84. package/lib/NavigationHeader/styles.css +1 -1
  85. package/lib/Pagination/styles.css +1 -1
  86. package/lib/PaginationSimple/styles.css +1 -1
  87. package/lib/Popover/styles.css +1 -1
  88. package/lib/Poster/Poster.cjs +1 -1
  89. package/lib/Poster/Poster.mjs +1 -1
  90. package/lib/Poster/styles.css +1 -1
  91. package/lib/ProgressBar/styles.css +1 -1
  92. package/lib/ProgressStepper/styles.css +1 -1
  93. package/lib/ProgressStepperOverflow/styles.css +1 -1
  94. package/lib/RadioCardGroup/styles.css +1 -1
  95. package/lib/RadioGroup/styles.css +1 -1
  96. package/lib/Rule/styles.css +1 -1
  97. package/lib/ScrollToTop/styles.css +1 -1
  98. package/lib/Section/styles.css +1 -1
  99. package/lib/Select/styles.css +1 -1
  100. package/lib/SemanticButton/styles.css +1 -1
  101. package/lib/SemanticHeading/styles.css +1 -1
  102. package/lib/SemanticLink/styles.css +1 -1
  103. package/lib/SiteFooter/styles.css +1 -1
  104. package/lib/SiteFooterV2/styles.css +1 -1
  105. package/lib/SiteHeaderV2/SiteHeaderV2.cjs +1 -1
  106. package/lib/SiteHeaderV2/SiteHeaderV2.mjs +1 -1
  107. package/lib/SiteHeaderV2/styles.css +1 -1
  108. package/lib/Skeleton/styles.css +1 -1
  109. package/lib/SkipLink/styles.css +1 -1
  110. package/lib/Spacing/styles.css +1 -1
  111. package/lib/Spinner/styles.css +1 -1
  112. package/lib/Surface/styles.css +1 -1
  113. package/lib/Switch/styles.css +1 -1
  114. package/lib/TabbedBanner/TabbedBanner.cjs +5 -5
  115. package/lib/TabbedBanner/TabbedBanner.mjs +5 -5
  116. package/lib/TabbedBanner/styles.css +1 -1
  117. package/lib/Tabs/styles.css +1 -1
  118. package/lib/Tag/styles.css +1 -1
  119. package/lib/TemplateBanner/TemplateBanner.cjs +5 -5
  120. package/lib/TemplateBanner/TemplateBanner.mjs +5 -5
  121. package/lib/TemplateBanner/styles.css +1 -1
  122. package/lib/Text/styles.css +1 -1
  123. package/lib/TextArea/styles.css +1 -1
  124. package/lib/TextInput/styles.css +1 -1
  125. package/lib/Theme/Theme.cjs +1 -1
  126. package/lib/Theme/Theme.mjs +1 -1
  127. package/lib/Theme/styles.css +1 -1
  128. package/lib/ThemeIcon/styles.css +1 -1
  129. package/lib/ThumbnailSignpost/ThumbnailSignpost.cjs +1 -1
  130. package/lib/ThumbnailSignpost/ThumbnailSignpost.mjs +1 -1
  131. package/lib/ThumbnailSignpost/styles.css +1 -1
  132. package/lib/Toast/styles.css +1 -1
  133. package/lib/Tooltip/styles.css +1 -1
  134. package/lib/Truncate/styles.css +1 -1
  135. package/lib/TypographyCard/TypographyCard.cjs +2 -2
  136. package/lib/TypographyCard/TypographyCard.mjs +2 -2
  137. package/lib/TypographyCard/styles.css +1 -1
  138. package/lib/UniversalHeader/styles.css +1 -1
  139. package/lib/VerticalSpace/styles.css +1 -1
  140. package/lib/VideoPlayer/VideoPlayer.cjs +1 -1
  141. package/lib/VideoPlayer/VideoPlayer.mjs +1 -1
  142. package/lib/VideoPlayer/styles.css +1 -1
  143. package/lib/Visible/styles.css +1 -1
  144. package/lib/VisuallyHidden/styles.css +1 -1
  145. package/lib/_shared/cjs/{Avatar-CYXaBl4s.cjs → Avatar-CZWcGXSS.cjs} +1 -1
  146. package/lib/_shared/cjs/{BannerImage-CYHLvtfL.cjs → BannerImage-qK8-w9rt.cjs} +1 -1
  147. package/lib/_shared/cjs/{Calendar-x-TJC12N.cjs → Calendar-Q9uMzEz3.cjs} +1 -1
  148. package/lib/_shared/cjs/{CardHeading-XASxN-OQ.cjs → CardHeading-Bpf5n0XL.cjs} +3 -1
  149. package/lib/_shared/cjs/{Image-MS1rBzbW.cjs → Image-CSe0KpDN.cjs} +1 -1
  150. package/lib/_shared/cjs/{TemplateBanner-fi8Xp8R7.cjs → TemplateBanner-F_Rg2_Cz.cjs} +2 -2
  151. package/lib/_shared/cjs/{VideoPlayer-K5n2domz.cjs → VideoPlayer-twcsIdyi.cjs} +2 -2
  152. package/lib/_shared/cjs/{arc-breakpoints-BFeZhupn.cjs → arc-breakpoints-tsWgo8xz.cjs} +1 -1
  153. package/lib/_shared/cjs/{index.es-brnNzCzO.cjs → index.es-BCRii7UY.cjs} +1 -1
  154. package/lib/_shared/esm/{Avatar-DAjYTtU7.mjs → Avatar-CSuCV2yI.mjs} +1 -1
  155. package/lib/_shared/esm/{BannerImage-BdPAHkVD.mjs → BannerImage-CgjgaYkJ.mjs} +1 -1
  156. package/lib/_shared/esm/{Calendar-dD3cX6aM.mjs → Calendar-DwD_EyRo.mjs} +1 -1
  157. package/lib/_shared/esm/{CardHeading-CVpRimLm.mjs → CardHeading-CXUirbtk.mjs} +3 -1
  158. package/lib/_shared/esm/{Image-DLYifxlu.mjs → Image-LemsonUX.mjs} +1 -1
  159. package/lib/_shared/esm/{TemplateBanner-CBGSP4hM.mjs → TemplateBanner-DdtVEQjE.mjs} +2 -2
  160. package/lib/_shared/esm/{VideoPlayer-qxBM7l1V.mjs → VideoPlayer-D0PmRdOH.mjs} +2 -2
  161. package/lib/_shared/esm/{arc-breakpoints-Cd4sS7mw.mjs → arc-breakpoints-YfOePBVY.mjs} +1 -1
  162. package/lib/_shared/esm/{index.es-mnMhOE77.mjs → index.es-DiB7SLf_.mjs} +1 -1
  163. package/lib/index.cjs +13 -11
  164. package/lib/index.cjs.map +1 -1
  165. package/lib/index.js.map +1 -1
  166. package/lib/index.mjs +13 -11
  167. package/lib/index.mjs.map +1 -1
  168. package/lib/styles.css +4 -4
  169. package/package.json +7 -7
package/lib/index.mjs CHANGED
@@ -647,7 +647,7 @@ var Image = function (_a) {
647
647
  "arc-Image-img--fade": fadeOnLoad,
648
648
  "arc-Image-img--fadeVisible": fadeOnLoad && visible,
649
649
  };
650
- var img = (React__default.createElement("img", { ref: imageRef, className: classNames("arc-Image-img", animationClasses), alt: alt, height: fit === "cover" ? undefined : height, loading: loading, sizes: children ? undefined : sizes, src: src, srcSet: children ? undefined : srcSet, width: fit === "cover" ? undefined : width, fetchpriority: fetchPriority }));
650
+ var img = (React__default.createElement("img", { ref: imageRef, className: classNames("arc-Image-img", animationClasses), alt: alt, height: fit === "cover" ? undefined : height, loading: loading, sizes: children ? undefined : sizes, src: src, srcSet: children ? undefined : srcSet, width: fit === "cover" ? undefined : width, fetchPriority: fetchPriority }));
651
651
  return (React__default.createElement("div", __assign({ className: classNames((_b = {
652
652
  "arc-Image": true,
653
653
  "arc-Image--cover": fit === "cover"
@@ -1403,7 +1403,7 @@ var debounce = /*@__PURE__*/getDefaultExportFromCjs(debounceExports);
1403
1403
 
1404
1404
  /**
1405
1405
  * Do not edit directly
1406
- * Generated on Thu, 26 Mar 2026 15:14:44 GMT
1406
+ * Generated on Fri, 10 Apr 2026 14:35:57 GMT
1407
1407
  */
1408
1408
  var ArcSizeBreakpointsXs = "320px";
1409
1409
  var ArcSizeBreakpointsS = "636px";
@@ -22169,8 +22169,8 @@ var VideoPlayer$1 = function (_a) {
22169
22169
  React__default.createElement("div", { "data-testid": "arc-video-player", className: classNames("arc-VideoPlayer-wrapper", {
22170
22170
  "arc-VideoPlayer-wrapper--borderRadius": isBorderRadius,
22171
22171
  }) }, isVimeo
22172
- ? isClient && React__default.createElement(ReactPlayerVimeo, __assign({}, playerProps))
22173
- : isClient && React__default.createElement(ReactPlayerYoutube, __assign({}, playerProps))),
22172
+ ? isClient && (React__default.createElement(ReactPlayerVimeo, __assign({}, playerProps, { config: { playerOptions: { playsinline: true } } })))
22173
+ : isClient && (React__default.createElement(ReactPlayerYoutube, __assign({}, playerProps, { config: { playerVars: { playsinline: 1 } } })))),
22174
22174
  React__default.createElement(TextWrapper, null,
22175
22175
  React__default.createElement(VerticalSpace, { size: "24" }),
22176
22176
  React__default.createElement(Heading, { level: "3", size: "s", isWordWrap: titleWordWrap }, title),
@@ -22279,9 +22279,11 @@ var CardFooter = function (_a) {
22279
22279
 
22280
22280
  /** Use `CardHeading` internally within card components to display a title, icon, or leading content at the top of a card. */
22281
22281
  var CardHeading = function (_a) {
22282
- var onClick = _a.onClick, onMouseEnter = _a.onMouseEnter, onMouseLeave = _a.onMouseLeave, onBlur = _a.onBlur, onFocus = _a.onFocus, href = _a.href, heading = _a.heading, _b = _a.size, size = _b === void 0 ? "m" : _b, _c = _a.linkData, linkData = _c === void 0 ? {} : _c, _d = _a.headingLevel, headingLevel = _d === void 0 ? "2" : _d, _e = _a.headingWordWrap, headingWordWrap = _e === void 0 ? false : _e, _f = _a.isContained, isContained = _f === void 0 ? true : _f;
22282
+ var onClick = _a.onClick, onMouseEnter = _a.onMouseEnter, onMouseLeave = _a.onMouseLeave, onBlur = _a.onBlur, onFocus = _a.onFocus, href = _a.href, heading = _a.heading, _b = _a.size, size = _b === void 0 ? "m" : _b, _c = _a.linkData, linkData = _c === void 0 ? {} : _c, _d = _a.headingLevel, headingLevel = _d === void 0 ? "2" : _d, _e = _a.headingWordWrap, headingWordWrap = _e === void 0 ? false : _e, _f = _a.isContained, isContained = _f === void 0 ? true : _f, _g = _a.isHovered, isHovered = _g === void 0 ? false : _g, _h = _a.isDarkPathway, isDarkPathway = _h === void 0 ? false : _h;
22283
22283
  return (React__default.createElement(Heading, { level: headingLevel, size: size, isWordWrap: headingWordWrap }, href ? (React__default.createElement("a", __assign({ className: classNames("arc-CardHeading-link", {
22284
22284
  "arc-CardHeading--isUncontained": !isContained,
22285
+ "arc-CardHeading--isHovered": isHovered,
22286
+ "arc-CardHeading--isDarkPathway": isDarkPathway,
22285
22287
  }), href: href, onClick: onClick, onMouseEnter: onMouseEnter, onMouseLeave: onMouseLeave, onFocus: onFocus, onBlur: onBlur }, filterAttrs(linkData)), heading)) : (heading)));
22286
22288
  };
22287
22289
 
@@ -22297,7 +22299,7 @@ var HorizontalCard = function (_a) {
22297
22299
  React__default.createElement(Image, __assign({ fit: "cover", anchor: "C" }, img)))),
22298
22300
  React__default.createElement("div", { className: "arc-HorizontalCard-content" },
22299
22301
  React__default.createElement(VerticalSpace, { size: "12" }),
22300
- React__default.createElement(CardHeading, { heading: heading, headingLevel: headingLevel, href: url, onClick: onClick, onMouseEnter: handleShowHoverState(true), onMouseLeave: handleShowHoverState(false), onFocus: handleShowHoverState(true), onBlur: handleShowHoverState(false) }),
22302
+ React__default.createElement(CardHeading, { heading: heading, headingLevel: headingLevel, href: url, onClick: onClick, onMouseEnter: handleShowHoverState(true), onMouseLeave: handleShowHoverState(false), onFocus: handleShowHoverState(true), onBlur: handleShowHoverState(false), isHovered: showHoverState }),
22301
22303
  React__default.createElement(VerticalSpace, { size: "12" }),
22302
22304
  React__default.createElement(Text, null, text),
22303
22305
  React__default.createElement(VerticalSpace, { size: "24" }),
@@ -22338,7 +22340,7 @@ var ImpactCard = function (_a) {
22338
22340
  label && (React__default.createElement("div", { className: "arc-ImpactCard-label" },
22339
22341
  React__default.createElement(Heading, { level: labelLevel, fontStyle: "overline" }, label),
22340
22342
  React__default.createElement(VerticalSpace, { size: "16" }))),
22341
- React__default.createElement(CardHeading, { heading: heading, size: headingSize, headingLevel: headingLevel, linkData: linkData, href: url, onClick: onClick, onMouseEnter: handleShowHoverState(true), onMouseLeave: handleShowHoverState(false), onFocus: handleShowHoverState(true), onBlur: handleShowHoverState(false), headingWordWrap: headingWordWrap })),
22343
+ React__default.createElement(CardHeading, { heading: heading, size: headingSize, headingLevel: headingLevel, linkData: linkData, href: url, onClick: onClick, onMouseEnter: handleShowHoverState(true), onMouseLeave: handleShowHoverState(false), onFocus: handleShowHoverState(true), onBlur: handleShowHoverState(false), headingWordWrap: headingWordWrap, isHovered: showHoverState && !isDarkPathway })),
22342
22344
  React__default.createElement(CardFooter, { buttonIcon: buttonIcon, showButton: true, isDarkPathway: isDarkPathway, isHovered: showHoverState }))));
22343
22345
  };
22344
22346
 
@@ -22422,7 +22424,7 @@ var InformationCard = function (_a) {
22422
22424
  label && (React__default.createElement(React__default.Fragment, null,
22423
22425
  React__default.createElement("div", { className: "arc-InformationCard-label" },
22424
22426
  React__default.createElement(Heading, { level: labelLevel, fontStyle: "overline" }, label)))),
22425
- React__default.createElement(CardHeading, { heading: heading, headingLevel: headingLevel, href: cardUrl, onClick: onClick, onMouseEnter: handleShowHoverState(true), onMouseLeave: handleShowHoverState(false), onFocus: handleShowHoverState(true), onBlur: handleShowHoverState(false), headingWordWrap: headingWordWrap }),
22427
+ React__default.createElement(CardHeading, { heading: heading, headingLevel: headingLevel, href: cardUrl, onClick: onClick, onMouseEnter: handleShowHoverState(true), onMouseLeave: handleShowHoverState(false), onFocus: handleShowHoverState(true), onBlur: handleShowHoverState(false), headingWordWrap: headingWordWrap, isHovered: showHoverState }),
22426
22428
  text && React__default.createElement(CardText, { text: text })),
22427
22429
  (button || badges || footerLogo) && (React__default.createElement("div", { className: "arc-InformationCard-footer" },
22428
22430
  badges && (React__default.createElement(React__default.Fragment, null,
@@ -22508,7 +22510,7 @@ var MediaCard = function (_a) {
22508
22510
  label && (React__default.createElement("div", { className: "arc-MediaCard-label" },
22509
22511
  React__default.createElement(Heading, { level: labelLevel, fontStyle: "overline" }, label),
22510
22512
  React__default.createElement(VerticalSpace, { size: "16" }))),
22511
- React__default.createElement(CardHeading, { heading: heading, headingLevel: headingLevel, href: media.type !== "video" ? url : undefined, onClick: media.type !== "video" ? onClick : undefined, onMouseEnter: handleShowHoverState(true), onMouseLeave: handleShowHoverState(false), onFocus: handleShowHoverState(true), onBlur: handleShowHoverState(false), headingWordWrap: headingWordWrap, isContained: isContained }),
22513
+ React__default.createElement(CardHeading, { heading: heading, headingLevel: headingLevel, href: media.type !== "video" ? url : undefined, onClick: media.type !== "video" ? onClick : undefined, onMouseEnter: handleShowHoverState(true), onMouseLeave: handleShowHoverState(false), onFocus: handleShowHoverState(true), onBlur: handleShowHoverState(false), headingWordWrap: headingWordWrap, isContained: isContained, isHovered: showHoverState }),
22512
22514
  !text && isContained && React__default.createElement(VerticalSpace, null),
22513
22515
  React__default.createElement("div", { className: "arc-MediaCard-textContainer" }, text && (React__default.createElement(React__default.Fragment, null,
22514
22516
  React__default.createElement(VerticalSpace, { size: "16" }),
@@ -26174,7 +26176,7 @@ var TextArea = function (_a) {
26174
26176
  var package_default = {
26175
26177
  name: "@arc-ui/helpers",
26176
26178
  private: true,
26177
- version: "13.7.0",
26179
+ version: "13.8.0",
26178
26180
  type: "module",
26179
26181
  homepage: "https://ui.digital-ent-int.bt.com",
26180
26182
  author: "BT Enterprise Digital UI Team <ui-digital-ent-int@bt.com>",
@@ -27283,7 +27285,7 @@ var TypographyCard = function (_a) {
27283
27285
  label && (React__default.createElement("div", { className: "arc-TypographyCard-label" },
27284
27286
  React__default.createElement(Heading, { level: labelLevel, fontStyle: "overline" }, label),
27285
27287
  React__default.createElement(VerticalSpace, { size: "16" }))),
27286
- React__default.createElement(CardHeading, { size: headingSize, linkData: linkData, heading: heading, headingLevel: headingLevel, href: url, onClick: onClick, onMouseEnter: handleShowHoverState(true), onMouseLeave: handleShowHoverState(false), onFocus: handleShowHoverState(true), onBlur: handleShowHoverState(false), headingWordWrap: headingWordWrap }),
27288
+ React__default.createElement(CardHeading, { size: headingSize, linkData: linkData, heading: heading, headingLevel: headingLevel, href: url, onClick: onClick, onMouseEnter: handleShowHoverState(true), onMouseLeave: handleShowHoverState(false), onFocus: handleShowHoverState(true), onBlur: handleShowHoverState(false), headingWordWrap: headingWordWrap, isHovered: showHoverState, isDarkPathway: isDarkPathway }),
27287
27289
  text && (React__default.createElement(React__default.Fragment, null,
27288
27290
  React__default.createElement(VerticalSpace, { size: "16" }),
27289
27291
  React__default.createElement(CardText, { text: text })))),