@skyscanner/backpack-web 42.0.0 → 42.2.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 (153) hide show
  1. package/bpk-component-banner-alert/src/BpkBannerAlert.js +0 -7
  2. package/bpk-component-breakpoint/src/BpkBreakpoint.js +3 -1
  3. package/bpk-component-button/src/BpkButton.d.ts +1 -1
  4. package/bpk-component-button/src/BpkButton.js +17 -3
  5. package/bpk-component-button/src/BpkButton.module.css +1 -1
  6. package/bpk-component-button/src/common-types.d.ts +2 -0
  7. package/bpk-component-calendar/src/utils.js +1 -1
  8. package/bpk-component-card/index.d.ts +4 -1
  9. package/bpk-component-card/index.js +3 -1
  10. package/bpk-component-card/src/BpkCardV2/BpkCardV2.d.ts +27 -0
  11. package/bpk-component-card/src/BpkCardV2/BpkCardV2.js +57 -0
  12. package/bpk-component-card/src/BpkCardV2/BpkCardV2.module.css +18 -0
  13. package/bpk-component-card/src/BpkCardV2/common-types.d.ts +124 -0
  14. package/bpk-component-card/src/BpkCardV2/common-types.js +102 -0
  15. package/bpk-component-card/src/BpkCardV2/subcomponents/Body.d.ts +36 -0
  16. package/bpk-component-card/src/BpkCardV2/subcomponents/Body.js +65 -0
  17. package/bpk-component-card/src/BpkCardV2/subcomponents/Divider.d.ts +13 -0
  18. package/bpk-component-card/src/BpkCardV2/subcomponents/Divider.js +37 -0
  19. package/bpk-component-card/src/BpkCardV2/subcomponents/Footer.d.ts +24 -0
  20. package/bpk-component-card/src/BpkCardV2/subcomponents/Footer.js +60 -0
  21. package/bpk-component-card/src/BpkCardV2/subcomponents/Header.d.ts +24 -0
  22. package/bpk-component-card/src/BpkCardV2/subcomponents/Header.js +60 -0
  23. package/bpk-component-card/src/BpkCardV2/subcomponents/Root.d.ts +28 -0
  24. package/bpk-component-card/src/BpkCardV2/subcomponents/Root.js +68 -0
  25. package/bpk-component-card/src/BpkCardV2/subcomponents/Section.d.ts +22 -0
  26. package/bpk-component-card/src/BpkCardV2/subcomponents/Section.js +53 -0
  27. package/bpk-component-card/src/BpkCardV2/subcomponents/resolveDirectionalPadding.d.ts +16 -0
  28. package/bpk-component-card/src/BpkCardV2/subcomponents/resolveDirectionalPadding.js +32 -0
  29. package/bpk-component-card-list/src/BpkCardList.module.css +1 -1
  30. package/bpk-component-card-list/src/BpkCardListRowRail/BpkCardListCarousel.js +3 -3
  31. package/bpk-component-chatbot-input/index.d.ts +7 -0
  32. package/bpk-component-chatbot-input/index.js +23 -0
  33. package/bpk-component-chatbot-input/src/BpkChatbotInput.d.ts +4 -0
  34. package/bpk-component-chatbot-input/src/BpkChatbotInput.js +118 -0
  35. package/bpk-component-chatbot-input/src/BpkChatbotInput.module.css +18 -0
  36. package/bpk-component-chatbot-input/src/InputField/InputField.d.ts +3 -0
  37. package/bpk-component-chatbot-input/src/InputField/InputField.js +82 -0
  38. package/bpk-component-chatbot-input/src/InputField.module.css +18 -0
  39. package/bpk-component-chatbot-input/src/SendButton/SendButton.d.ts +9 -0
  40. package/bpk-component-chatbot-input/src/SendButton/SendButton.js +47 -0
  41. package/bpk-component-chatbot-input/src/TextAreaField/TextAreaField.d.ts +10 -0
  42. package/bpk-component-chatbot-input/src/TextAreaField/TextAreaField.js +93 -0
  43. package/bpk-component-chatbot-input/src/TextAreaField.module.css +18 -0
  44. package/bpk-component-chatbot-input/src/common-types.d.ts +37 -0
  45. package/bpk-component-chatbot-input/src/common-types.js +23 -0
  46. package/bpk-component-chatbot-input/src/constants.d.ts +5 -0
  47. package/bpk-component-chatbot-input/src/constants.js +22 -0
  48. package/bpk-component-chatbot-input/src/hooks/index.d.ts +4 -0
  49. package/bpk-component-chatbot-input/src/hooks/index.js +22 -0
  50. package/bpk-component-chatbot-input/src/hooks/useChatbotInput.d.ts +32 -0
  51. package/bpk-component-chatbot-input/src/hooks/useChatbotInput.js +111 -0
  52. package/bpk-component-chatbot-input/src/hooks/useChatbotInputManager.d.ts +20 -0
  53. package/bpk-component-chatbot-input/src/hooks/useChatbotInputManager.js +83 -0
  54. package/bpk-component-chatbot-input/src/hooks/useInputHandlers.d.ts +8 -0
  55. package/bpk-component-chatbot-input/src/hooks/useInputHandlers.js +54 -0
  56. package/bpk-component-chatbot-input/src/hooks/useTextAreaAutoResize.d.ts +22 -0
  57. package/bpk-component-chatbot-input/src/hooks/useTextAreaAutoResize.js +137 -0
  58. package/bpk-component-chatbot-input/src/themeAttributes.d.ts +14 -0
  59. package/bpk-component-chatbot-input/src/themeAttributes.js +34 -0
  60. package/bpk-component-checkbox/index.d.ts +7 -1
  61. package/bpk-component-checkbox/index.js +3 -1
  62. package/bpk-component-checkbox/src/BpkCheckboxV2/BpkCheckboxV2.d.ts +9 -0
  63. package/bpk-component-checkbox/src/BpkCheckboxV2/BpkCheckboxV2.js +33 -0
  64. package/bpk-component-checkbox/src/BpkCheckboxV2/BpkCheckboxV2.module.css +18 -0
  65. package/bpk-component-checkbox/src/BpkCheckboxV2/BpkCheckboxV2Control.d.ts +6 -0
  66. package/bpk-component-checkbox/src/BpkCheckboxV2/BpkCheckboxV2Control.js +30 -0
  67. package/bpk-component-checkbox/src/BpkCheckboxV2/BpkCheckboxV2Description.d.ts +6 -0
  68. package/bpk-component-checkbox/src/BpkCheckboxV2/BpkCheckboxV2Description.js +32 -0
  69. package/bpk-component-checkbox/src/BpkCheckboxV2/BpkCheckboxV2HiddenInput.d.ts +2 -0
  70. package/bpk-component-checkbox/src/BpkCheckboxV2/BpkCheckboxV2HiddenInput.js +25 -0
  71. package/bpk-component-checkbox/src/BpkCheckboxV2/BpkCheckboxV2Indicator.d.ts +2 -0
  72. package/bpk-component-checkbox/src/BpkCheckboxV2/BpkCheckboxV2Indicator.js +23 -0
  73. package/bpk-component-checkbox/src/BpkCheckboxV2/BpkCheckboxV2Label.d.ts +6 -0
  74. package/bpk-component-checkbox/src/BpkCheckboxV2/BpkCheckboxV2Label.js +30 -0
  75. package/bpk-component-checkbox/src/BpkCheckboxV2/BpkCheckboxV2Root.d.ts +16 -0
  76. package/bpk-component-checkbox/src/BpkCheckboxV2/BpkCheckboxV2Root.js +49 -0
  77. package/bpk-component-checkbox/src/BpkCheckboxV2/themeAttributes.d.ts +2 -0
  78. package/bpk-component-checkbox/src/BpkCheckboxV2/themeAttributes.js +20 -0
  79. package/bpk-component-checkbox-card/index.d.ts +3 -0
  80. package/bpk-component-checkbox-card/index.js +20 -0
  81. package/bpk-component-checkbox-card/src/BpkCheckboxCard.d.ts +128 -0
  82. package/bpk-component-checkbox-card/src/BpkCheckboxCard.js +216 -0
  83. package/bpk-component-checkbox-card/src/BpkCheckboxCard.module.css +18 -0
  84. package/bpk-component-checkbox-card/src/BpkCheckboxCardRoot.d.ts +95 -0
  85. package/bpk-component-checkbox-card/src/BpkCheckboxCardRoot.js +101 -0
  86. package/bpk-component-checkbox-card/src/CheckboxCardContext.d.ts +27 -0
  87. package/bpk-component-checkbox-card/src/CheckboxCardContext.js +47 -0
  88. package/bpk-component-checkbox-card/src/common-types.d.ts +27 -0
  89. package/bpk-component-checkbox-card/src/common-types.js +43 -0
  90. package/bpk-component-checkbox-card/src/themeAttributes.d.ts +46 -0
  91. package/bpk-component-checkbox-card/src/themeAttributes.js +87 -0
  92. package/bpk-component-icon/scripts/generate-figma-connect.js +267 -0
  93. package/bpk-component-inset-banner/index.d.ts +4 -1
  94. package/bpk-component-inset-banner/index.js +2 -1
  95. package/bpk-component-inset-banner/src/BpkInsetBannerV3/BpkInsetBannerV3.d.ts +56 -0
  96. package/bpk-component-inset-banner/src/BpkInsetBannerV3/BpkInsetBannerV3.js +118 -0
  97. package/bpk-component-inset-banner/src/BpkInsetBannerV3/BpkInsetBannerV3.module.css +18 -0
  98. package/bpk-component-layout/src/BpkProvider.d.ts +9 -4
  99. package/bpk-component-layout/src/BpkProvider.js +87 -8
  100. package/bpk-component-layout/src/types.d.ts +2 -2
  101. package/bpk-component-link/src/common-types.d.ts +1 -1
  102. package/bpk-component-modal/index.d.ts +2 -1
  103. package/bpk-component-modal/index.js +2 -1
  104. package/bpk-component-modal/src/BpkModalV3/BpkModalV3.d.ts +14 -0
  105. package/bpk-component-modal/src/BpkModalV3/BpkModalV3.js +43 -0
  106. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Body/BpkModalV3Body.d.ts +7 -0
  107. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Body/BpkModalV3Body.js +30 -0
  108. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Body.module.css +18 -0
  109. package/bpk-component-modal/src/BpkModalV3/BpkModalV3CloseTrigger/BpkModalV3CloseTrigger.d.ts +7 -0
  110. package/bpk-component-modal/src/BpkModalV3/BpkModalV3CloseTrigger/BpkModalV3CloseTrigger.js +49 -0
  111. package/bpk-component-modal/src/BpkModalV3/BpkModalV3CloseTrigger.module.css +18 -0
  112. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Content/BpkModalV3Content.d.ts +7 -0
  113. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Content/BpkModalV3Content.js +38 -0
  114. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Content.module.css +18 -0
  115. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Context.d.ts +3 -0
  116. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Context.js +22 -0
  117. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Description/BpkModalV3Description.d.ts +7 -0
  118. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Description/BpkModalV3Description.js +28 -0
  119. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Header/BpkModalV3Header.d.ts +7 -0
  120. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Header/BpkModalV3Header.js +34 -0
  121. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Header.module.css +18 -0
  122. package/bpk-component-modal/src/BpkModalV3/BpkModalV3HeroImage/BpkModalV3HeroImage.d.ts +10 -0
  123. package/bpk-component-modal/src/BpkModalV3/BpkModalV3HeroImage/BpkModalV3HeroImage.js +44 -0
  124. package/bpk-component-modal/src/BpkModalV3/BpkModalV3HeroImage.module.css +18 -0
  125. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Portal/BpkModalV3Portal.d.ts +7 -0
  126. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Portal/BpkModalV3Portal.js +26 -0
  127. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Root/BpkModalV3Root.d.ts +13 -0
  128. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Root/BpkModalV3Root.js +44 -0
  129. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Scrim/BpkModalV3Scrim.d.ts +2 -0
  130. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Scrim/BpkModalV3Scrim.js +32 -0
  131. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Scrim.module.css +18 -0
  132. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Title/BpkModalV3Title.d.ts +7 -0
  133. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Title/BpkModalV3Title.js +31 -0
  134. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Title.module.css +18 -0
  135. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Trigger/BpkModalV3Trigger.d.ts +8 -0
  136. package/bpk-component-modal/src/BpkModalV3/BpkModalV3Trigger/BpkModalV3Trigger.js +30 -0
  137. package/bpk-component-modal/src/BpkModalV3/common-types.d.ts +1 -0
  138. package/bpk-component-modal/src/BpkModalV3/common-types.js +1 -0
  139. package/bpk-component-page-indicator/src/NavButton.d.ts +2 -1
  140. package/bpk-component-scrollable-calendar/src/BpkScrollableCalendarGridList.js +40 -22
  141. package/bpk-component-scrollable-calendar/src/BpkScrollableCalendarGridList.module.css +1 -1
  142. package/bpk-component-segmented-control/src/BpkSegmentedControlV2/BpkSegmentedControlV2.js +37 -16
  143. package/bpk-component-skeleton/src/BpkBaseSkeleton.d.d.ts +1 -0
  144. package/bpk-component-skeleton/src/BpkSkeleton.d.d.ts +1 -0
  145. package/bpk-component-table/index.d.ts +2 -1
  146. package/bpk-component-table/index.js +2 -1
  147. package/bpk-component-table/src/BpkTable.module.css +1 -1
  148. package/bpk-component-table/src/BpkTableBody.d.ts +4 -1
  149. package/bpk-component-table/src/BpkTableBody.js +19 -4
  150. package/bpk-component-table/src/common-types.d.ts +5 -0
  151. package/bpk-component-table/src/common-types.js +22 -0
  152. package/bpk-react-utils/src/Portal.d.ts +1 -1
  153. package/package.json +2 -2
@@ -0,0 +1,65 @@
1
+ /*
2
+ * Backpack - Skyscanner's Design System
3
+ *
4
+ * Copyright 2016 Skyscanner Ltd
5
+ *
6
+ * Licensed under the Apache License, Version 2.0 (the "License");
7
+ * you may not use this file except in compliance with the License.
8
+ * You may obtain a copy of the License at
9
+ *
10
+ * http://www.apache.org/licenses/LICENSE-2.0
11
+ *
12
+ * Unless required by applicable law or agreed to in writing, software
13
+ * distributed under the License is distributed on an "AS IS" BASIS,
14
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ * See the License for the specific language governing permissions and
16
+ * limitations under the License.
17
+ */
18
+
19
+ import { BpkGrid, BpkSpacing } from "../../../../bpk-component-layout";
20
+ import { getDataComponentAttribute } from "../../../../bpk-react-utils";
21
+ import { jsx as _jsx } from "react/jsx-runtime";
22
+ /**
23
+ * Body subcomponent for BpkCardV2.
24
+ *
25
+ * Renders the main content area of the card as a BpkGrid container.
26
+ * Defaults to a single-column vertical layout with base padding.
27
+ * Use templateColumns for multi-column layouts. Include `auto` for each Divider child.
28
+ * All BpkGrid props can be used to customise the layout.
29
+ *
30
+ * @example
31
+ * // Simple body
32
+ * <BpkCardV2.Body>Content here</BpkCardV2.Body>
33
+ *
34
+ * @example
35
+ * // Multi-column layout
36
+ * <BpkCardV2.Body templateColumns={{ base: '1fr', tablet: '1fr 2fr 1fr' }}>
37
+ * <BpkCardV2.Section>Left</BpkCardV2.Section>
38
+ * <BpkCardV2.Section>Center (2x wide)</BpkCardV2.Section>
39
+ * <BpkCardV2.Section>Right</BpkCardV2.Section>
40
+ * </BpkCardV2.Body>
41
+ *
42
+ * @example
43
+ * // Multi-column with divider (include auto for the divider)
44
+ * <BpkCardV2.Body templateColumns={{ base: '1fr', tablet: '7fr auto 3fr' }}>
45
+ * <BpkCardV2.Section>Main content</BpkCardV2.Section>
46
+ * <BpkCardV2.Divider />
47
+ * <BpkCardV2.Section>Sidebar</BpkCardV2.Section>
48
+ * </BpkCardV2.Body>
49
+ *
50
+ * @returns {JSX.Element} Body component
51
+ */
52
+ const Body = ({
53
+ children,
54
+ padding = BpkSpacing.Base,
55
+ templateColumns = '1fr',
56
+ ...rest
57
+ }) => /*#__PURE__*/_jsx(BpkGrid, {
58
+ templateColumns: templateColumns,
59
+ padding: padding,
60
+ ...getDataComponentAttribute('CardV2.Body'),
61
+ ...rest,
62
+ children: children
63
+ });
64
+ Body.displayName = 'BpkCardV2.Body';
65
+ export default Body;
@@ -0,0 +1,13 @@
1
+ /**
2
+ * Divider between Section children in multi-column layout.
3
+ *
4
+ * Renders as a horizontal line on mobile and a vertical line on desktop.
5
+ * Styled via SCSS for breakpoint handling.
6
+ *
7
+ * @returns {JSX.Element} Divider component
8
+ */
9
+ declare const Divider: {
10
+ (): import("react/jsx-runtime").JSX.Element;
11
+ displayName: string;
12
+ };
13
+ export default Divider;
@@ -0,0 +1,37 @@
1
+ /*
2
+ * Backpack - Skyscanner's Design System
3
+ *
4
+ * Copyright 2016 Skyscanner Ltd
5
+ *
6
+ * Licensed under the Apache License, Version 2.0 (the "License");
7
+ * you may not use this file except in compliance with the License.
8
+ * You may obtain a copy of the License at
9
+ *
10
+ * http://www.apache.org/licenses/LICENSE-2.0
11
+ *
12
+ * Unless required by applicable law or agreed to in writing, software
13
+ * distributed under the License is distributed on an "AS IS" BASIS,
14
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ * See the License for the specific language governing permissions and
16
+ * limitations under the License.
17
+ */
18
+
19
+ import { cssModules, getDataComponentAttribute } from "../../../../bpk-react-utils";
20
+ import STYLES from "../BpkCardV2.module.css";
21
+ import { jsx as _jsx } from "react/jsx-runtime";
22
+ const getClassName = cssModules(STYLES);
23
+
24
+ /**
25
+ * Divider between Section children in multi-column layout.
26
+ *
27
+ * Renders as a horizontal line on mobile and a vertical line on desktop.
28
+ * Styled via SCSS for breakpoint handling.
29
+ *
30
+ * @returns {JSX.Element} Divider component
31
+ */
32
+ const Divider = () => /*#__PURE__*/_jsx("div", {
33
+ className: getClassName('bpk-card-v2__divider'),
34
+ ...getDataComponentAttribute('CardV2.Divider')
35
+ });
36
+ Divider.displayName = 'BpkCardV2.Divider';
37
+ export default Divider;
@@ -0,0 +1,24 @@
1
+ import type { BpkCardV2FooterProps } from '../common-types';
2
+ /**
3
+ * Footer subcomponent for BpkCardV2.
4
+ *
5
+ * Renders a BpkFlex container positioned at the bottom of the card.
6
+ * Defaults to horizontal (row) direction with base padding on bottom, start
7
+ * and end, and no top padding. All BpkFlex props can be used to customise the layout.
8
+ *
9
+ * @example
10
+ * <BpkCardV2.Footer>Footer content</BpkCardV2.Footer>
11
+ *
12
+ * @example
13
+ * <BpkCardV2.Footer justify="flex-end" gap={BpkSpacing.SM}>
14
+ * <BpkButton>Cancel</BpkButton>
15
+ * <BpkButton>Save</BpkButton>
16
+ * </BpkCardV2.Footer>
17
+ *
18
+ * @returns {JSX.Element} Footer component
19
+ */
20
+ declare const Footer: {
21
+ ({ children, padding, paddingBottom, paddingEnd, paddingStart, paddingTop, ...rest }: BpkCardV2FooterProps): import("react/jsx-runtime").JSX.Element;
22
+ displayName: string;
23
+ };
24
+ export default Footer;
@@ -0,0 +1,60 @@
1
+ /*
2
+ * Backpack - Skyscanner's Design System
3
+ *
4
+ * Copyright 2016 Skyscanner Ltd
5
+ *
6
+ * Licensed under the Apache License, Version 2.0 (the "License");
7
+ * you may not use this file except in compliance with the License.
8
+ * You may obtain a copy of the License at
9
+ *
10
+ * http://www.apache.org/licenses/LICENSE-2.0
11
+ *
12
+ * Unless required by applicable law or agreed to in writing, software
13
+ * distributed under the License is distributed on an "AS IS" BASIS,
14
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ * See the License for the specific language governing permissions and
16
+ * limitations under the License.
17
+ */
18
+
19
+ import { BpkFlex, BpkSpacing } from "../../../../bpk-component-layout";
20
+ import { getDataComponentAttribute } from "../../../../bpk-react-utils";
21
+ import resolveDirectionalPadding from "./resolveDirectionalPadding";
22
+ import { jsx as _jsx } from "react/jsx-runtime";
23
+ /**
24
+ * Footer subcomponent for BpkCardV2.
25
+ *
26
+ * Renders a BpkFlex container positioned at the bottom of the card.
27
+ * Defaults to horizontal (row) direction with base padding on bottom, start
28
+ * and end, and no top padding. All BpkFlex props can be used to customise the layout.
29
+ *
30
+ * @example
31
+ * <BpkCardV2.Footer>Footer content</BpkCardV2.Footer>
32
+ *
33
+ * @example
34
+ * <BpkCardV2.Footer justify="flex-end" gap={BpkSpacing.SM}>
35
+ * <BpkButton>Cancel</BpkButton>
36
+ * <BpkButton>Save</BpkButton>
37
+ * </BpkCardV2.Footer>
38
+ *
39
+ * @returns {JSX.Element} Footer component
40
+ */
41
+ const Footer = ({
42
+ children,
43
+ padding,
44
+ paddingBottom,
45
+ paddingEnd,
46
+ paddingStart,
47
+ paddingTop,
48
+ ...rest
49
+ }) => /*#__PURE__*/_jsx(BpkFlex, {
50
+ padding: padding,
51
+ paddingTop: resolveDirectionalPadding(padding, paddingTop, BpkSpacing.None),
52
+ paddingStart: resolveDirectionalPadding(padding, paddingStart, BpkSpacing.Base),
53
+ paddingEnd: resolveDirectionalPadding(padding, paddingEnd, BpkSpacing.Base),
54
+ paddingBottom: resolveDirectionalPadding(padding, paddingBottom, BpkSpacing.Base),
55
+ ...getDataComponentAttribute('CardV2.Footer'),
56
+ ...rest,
57
+ children: children
58
+ });
59
+ Footer.displayName = 'BpkCardV2.Footer';
60
+ export default Footer;
@@ -0,0 +1,24 @@
1
+ import type { BpkCardV2HeaderProps } from '../common-types';
2
+ /**
3
+ * Header subcomponent for BpkCardV2.
4
+ *
5
+ * Renders a BpkFlex container positioned at the top of the card.
6
+ * Defaults to horizontal (row) direction with base padding on top, start
7
+ * and end, and no bottom padding. All BpkFlex props can be used to customise the layout.
8
+ *
9
+ * @example
10
+ * <BpkCardV2.Header>Card title</BpkCardV2.Header>
11
+ *
12
+ * @example
13
+ * <BpkCardV2.Header justify="space-between" align="center">
14
+ * <BpkText>Title</BpkText>
15
+ * <BpkText>Action</BpkText>
16
+ * </BpkCardV2.Header>
17
+ *
18
+ * @returns {JSX.Element} Header component
19
+ */
20
+ declare const Header: {
21
+ ({ children, padding, paddingBottom, paddingEnd, paddingStart, paddingTop, ...rest }: BpkCardV2HeaderProps): import("react/jsx-runtime").JSX.Element;
22
+ displayName: string;
23
+ };
24
+ export default Header;
@@ -0,0 +1,60 @@
1
+ /*
2
+ * Backpack - Skyscanner's Design System
3
+ *
4
+ * Copyright 2016 Skyscanner Ltd
5
+ *
6
+ * Licensed under the Apache License, Version 2.0 (the "License");
7
+ * you may not use this file except in compliance with the License.
8
+ * You may obtain a copy of the License at
9
+ *
10
+ * http://www.apache.org/licenses/LICENSE-2.0
11
+ *
12
+ * Unless required by applicable law or agreed to in writing, software
13
+ * distributed under the License is distributed on an "AS IS" BASIS,
14
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ * See the License for the specific language governing permissions and
16
+ * limitations under the License.
17
+ */
18
+
19
+ import { BpkFlex, BpkSpacing } from "../../../../bpk-component-layout";
20
+ import { getDataComponentAttribute } from "../../../../bpk-react-utils";
21
+ import resolveDirectionalPadding from "./resolveDirectionalPadding";
22
+ import { jsx as _jsx } from "react/jsx-runtime";
23
+ /**
24
+ * Header subcomponent for BpkCardV2.
25
+ *
26
+ * Renders a BpkFlex container positioned at the top of the card.
27
+ * Defaults to horizontal (row) direction with base padding on top, start
28
+ * and end, and no bottom padding. All BpkFlex props can be used to customise the layout.
29
+ *
30
+ * @example
31
+ * <BpkCardV2.Header>Card title</BpkCardV2.Header>
32
+ *
33
+ * @example
34
+ * <BpkCardV2.Header justify="space-between" align="center">
35
+ * <BpkText>Title</BpkText>
36
+ * <BpkText>Action</BpkText>
37
+ * </BpkCardV2.Header>
38
+ *
39
+ * @returns {JSX.Element} Header component
40
+ */
41
+ const Header = ({
42
+ children,
43
+ padding,
44
+ paddingBottom,
45
+ paddingEnd,
46
+ paddingStart,
47
+ paddingTop,
48
+ ...rest
49
+ }) => /*#__PURE__*/_jsx(BpkFlex, {
50
+ padding: padding,
51
+ paddingTop: resolveDirectionalPadding(padding, paddingTop, BpkSpacing.Base),
52
+ paddingStart: resolveDirectionalPadding(padding, paddingStart, BpkSpacing.Base),
53
+ paddingEnd: resolveDirectionalPadding(padding, paddingEnd, BpkSpacing.Base),
54
+ paddingBottom: resolveDirectionalPadding(padding, paddingBottom, BpkSpacing.None),
55
+ ...getDataComponentAttribute('CardV2.Header'),
56
+ ...rest,
57
+ children: children
58
+ });
59
+ Header.displayName = 'BpkCardV2.Header';
60
+ export default Header;
@@ -0,0 +1,28 @@
1
+ import { type BpkCardV2Props } from '../common-types';
2
+ /**
3
+ * BpkCardV2.Root is the root container for the card component.
4
+ *
5
+ * It supports explicit multi-section composition (Header, Body, Footer), flexible
6
+ * multi-column layouts (Section/Divider), and customizable surface colors. The component
7
+ * is mobile-first and automatically adapts layout across breakpoints.
8
+ *
9
+ * @example
10
+ * <BpkCardV2.Root>
11
+ * <BpkCardV2.Header>Title</BpkCardV2.Header>
12
+ * <BpkCardV2.Body>Content</BpkCardV2.Body>
13
+ * <BpkCardV2.Footer>Footer</BpkCardV2.Footer>
14
+ * </BpkCardV2.Root>
15
+ *
16
+ * @example
17
+ * // Multi-column layout (70/30 on desktop, stacked on mobile).
18
+ * // The `auto` column in templateColumns reserves space for the Divider.
19
+ * <BpkCardV2.Root bgColor={CARD_V2_SURFACE_COLORS.surfaceElevated}>
20
+ * <BpkCardV2.Body templateColumns={{ base: '1fr', tablet: '7fr auto 3fr' }}>
21
+ * <BpkCardV2.Section>Main content</BpkCardV2.Section>
22
+ * <BpkCardV2.Divider />
23
+ * <BpkCardV2.Section>Sidebar</BpkCardV2.Section>
24
+ * </BpkCardV2.Body>
25
+ * </BpkCardV2.Root>
26
+ */
27
+ declare const Root: import("react").ForwardRefExoticComponent<BpkCardV2Props & import("react").RefAttributes<HTMLDivElement>>;
28
+ export default Root;
@@ -0,0 +1,68 @@
1
+ /*
2
+ * Backpack - Skyscanner's Design System
3
+ *
4
+ * Copyright 2016 Skyscanner Ltd
5
+ *
6
+ * Licensed under the Apache License, Version 2.0 (the "License");
7
+ * you may not use this file except in compliance with the License.
8
+ * You may obtain a copy of the License at
9
+ *
10
+ * http://www.apache.org/licenses/LICENSE-2.0
11
+ *
12
+ * Unless required by applicable law or agreed to in writing, software
13
+ * distributed under the License is distributed on an "AS IS" BASIS,
14
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ * See the License for the specific language governing permissions and
16
+ * limitations under the License.
17
+ */
18
+
19
+ import { forwardRef } from 'react';
20
+ import { cssModules, getDataComponentAttribute } from "../../../../bpk-react-utils";
21
+ import { CARD_V2_SURFACE_COLORS, CARD_V2_VARIANTS } from "../common-types";
22
+ import STYLES from "../BpkCardV2.module.css";
23
+ import { jsx as _jsx } from "react/jsx-runtime";
24
+ const getClassName = cssModules(STYLES);
25
+ const toKebab = s => s.replace(/[A-Z]/g, m => `-${m.toLowerCase()}`);
26
+
27
+ /**
28
+ * BpkCardV2.Root is the root container for the card component.
29
+ *
30
+ * It supports explicit multi-section composition (Header, Body, Footer), flexible
31
+ * multi-column layouts (Section/Divider), and customizable surface colors. The component
32
+ * is mobile-first and automatically adapts layout across breakpoints.
33
+ *
34
+ * @example
35
+ * <BpkCardV2.Root>
36
+ * <BpkCardV2.Header>Title</BpkCardV2.Header>
37
+ * <BpkCardV2.Body>Content</BpkCardV2.Body>
38
+ * <BpkCardV2.Footer>Footer</BpkCardV2.Footer>
39
+ * </BpkCardV2.Root>
40
+ *
41
+ * @example
42
+ * // Multi-column layout (70/30 on desktop, stacked on mobile).
43
+ * // The `auto` column in templateColumns reserves space for the Divider.
44
+ * <BpkCardV2.Root bgColor={CARD_V2_SURFACE_COLORS.surfaceElevated}>
45
+ * <BpkCardV2.Body templateColumns={{ base: '1fr', tablet: '7fr auto 3fr' }}>
46
+ * <BpkCardV2.Section>Main content</BpkCardV2.Section>
47
+ * <BpkCardV2.Divider />
48
+ * <BpkCardV2.Section>Sidebar</BpkCardV2.Section>
49
+ * </BpkCardV2.Body>
50
+ * </BpkCardV2.Root>
51
+ */
52
+ const Root = /*#__PURE__*/forwardRef(({
53
+ bgColor = CARD_V2_SURFACE_COLORS.surfaceDefault,
54
+ children,
55
+ variant = CARD_V2_VARIANTS.default,
56
+ ...rest
57
+ }, ref) => /*#__PURE__*/_jsx("div", {
58
+ ref: ref,
59
+ ...getDataComponentAttribute('CardV2'),
60
+ ...rest,
61
+ // className and style are placed after {...rest} so any values smuggled
62
+ // past the TypeScript Omit (e.g. via `as any`) are safely overwritten.
63
+ className: getClassName('bpk-card-v2', `bpk-card-v2--${toKebab(variant)}`, `bpk-card-v2--${toKebab(bgColor)}`),
64
+ style: undefined,
65
+ children: children
66
+ }));
67
+ Root.displayName = 'BpkCardV2.Root';
68
+ export default Root;
@@ -0,0 +1,22 @@
1
+ import type { BpkCardV2SectionProps } from '../common-types';
2
+ /**
3
+ * Section subcomponent for multi-column layouts in BpkCardV2.
4
+ *
5
+ * Generic content area used with the `columns` prop on BpkCardV2.Body.
6
+ * Flex value is injected by Body via cloneElement based on the columns spec.
7
+ * All BpkBox props can be used to customise the layout.
8
+ *
9
+ * @returns {JSX.Element} Section component
10
+ *
11
+ * @example
12
+ * <BpkCardV2.Body templateColumns="1fr 2fr 1fr">
13
+ * <BpkCardV2.Section>Left</BpkCardV2.Section>
14
+ * <BpkCardV2.Section>Center</BpkCardV2.Section>
15
+ * <BpkCardV2.Section>Right</BpkCardV2.Section>
16
+ * </BpkCardV2.Body>
17
+ */
18
+ declare const Section: {
19
+ ({ children, display, flexDirection, padding, ...rest }: BpkCardV2SectionProps): import("react/jsx-runtime").JSX.Element;
20
+ displayName: string;
21
+ };
22
+ export default Section;
@@ -0,0 +1,53 @@
1
+ /*
2
+ * Backpack - Skyscanner's Design System
3
+ *
4
+ * Copyright 2016 Skyscanner Ltd
5
+ *
6
+ * Licensed under the Apache License, Version 2.0 (the "License");
7
+ * you may not use this file except in compliance with the License.
8
+ * You may obtain a copy of the License at
9
+ *
10
+ * http://www.apache.org/licenses/LICENSE-2.0
11
+ *
12
+ * Unless required by applicable law or agreed to in writing, software
13
+ * distributed under the License is distributed on an "AS IS" BASIS,
14
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ * See the License for the specific language governing permissions and
16
+ * limitations under the License.
17
+ */
18
+
19
+ import { BpkBox, BpkSpacing } from "../../../../bpk-component-layout";
20
+ import { getDataComponentAttribute } from "../../../../bpk-react-utils";
21
+ import { jsx as _jsx } from "react/jsx-runtime";
22
+ /**
23
+ * Section subcomponent for multi-column layouts in BpkCardV2.
24
+ *
25
+ * Generic content area used with the `columns` prop on BpkCardV2.Body.
26
+ * Flex value is injected by Body via cloneElement based on the columns spec.
27
+ * All BpkBox props can be used to customise the layout.
28
+ *
29
+ * @returns {JSX.Element} Section component
30
+ *
31
+ * @example
32
+ * <BpkCardV2.Body templateColumns="1fr 2fr 1fr">
33
+ * <BpkCardV2.Section>Left</BpkCardV2.Section>
34
+ * <BpkCardV2.Section>Center</BpkCardV2.Section>
35
+ * <BpkCardV2.Section>Right</BpkCardV2.Section>
36
+ * </BpkCardV2.Body>
37
+ */
38
+ const Section = ({
39
+ children,
40
+ display = 'flex',
41
+ flexDirection = 'column',
42
+ padding = BpkSpacing.Base,
43
+ ...rest
44
+ }) => /*#__PURE__*/_jsx(BpkBox, {
45
+ display: display,
46
+ flexDirection: flexDirection,
47
+ padding: padding,
48
+ ...getDataComponentAttribute('CardV2.Section'),
49
+ ...rest,
50
+ children: children
51
+ });
52
+ Section.displayName = 'BpkCardV2.Section';
53
+ export default Section;
@@ -0,0 +1,16 @@
1
+ import type { BpkFlexProps } from '../../../../bpk-component-layout';
2
+ type PaddingValue = BpkFlexProps['padding'];
3
+ /**
4
+ * Resolves a directional padding value for Header/Footer subcomponents.
5
+ *
6
+ * When the shorthand `padding` prop is set, directional overrides are passed
7
+ * through as-is (BpkFlex handles shorthand + directional merging).
8
+ * When no shorthand is set, the directional value falls back to a default.
9
+ *
10
+ * @param {PaddingValue} padding - The shorthand padding prop value
11
+ * @param {PaddingValue} directional - The directional padding override
12
+ * @param {PaddingValue} fallback - The default value when no shorthand or directional is set
13
+ * @returns {PaddingValue} The resolved padding value
14
+ */
15
+ declare const resolveDirectionalPadding: (padding: PaddingValue, directional: PaddingValue, fallback: PaddingValue) => PaddingValue;
16
+ export default resolveDirectionalPadding;
@@ -0,0 +1,32 @@
1
+ /*
2
+ * Backpack - Skyscanner's Design System
3
+ *
4
+ * Copyright 2016 Skyscanner Ltd
5
+ *
6
+ * Licensed under the Apache License, Version 2.0 (the "License");
7
+ * you may not use this file except in compliance with the License.
8
+ * You may obtain a copy of the License at
9
+ *
10
+ * http://www.apache.org/licenses/LICENSE-2.0
11
+ *
12
+ * Unless required by applicable law or agreed to in writing, software
13
+ * distributed under the License is distributed on an "AS IS" BASIS,
14
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ * See the License for the specific language governing permissions and
16
+ * limitations under the License.
17
+ */
18
+
19
+ /**
20
+ * Resolves a directional padding value for Header/Footer subcomponents.
21
+ *
22
+ * When the shorthand `padding` prop is set, directional overrides are passed
23
+ * through as-is (BpkFlex handles shorthand + directional merging).
24
+ * When no shorthand is set, the directional value falls back to a default.
25
+ *
26
+ * @param {PaddingValue} padding - The shorthand padding prop value
27
+ * @param {PaddingValue} directional - The directional padding override
28
+ * @param {PaddingValue} fallback - The default value when no shorthand or directional is set
29
+ * @returns {PaddingValue} The resolved padding value
30
+ */
31
+ const resolveDirectionalPadding = (padding, directional, fallback) => padding !== undefined ? directional : directional ?? fallback;
32
+ export default resolveDirectionalPadding;
@@ -15,4 +15,4 @@
15
15
  * See the License for the specific language governing permissions and
16
16
  * limitations under the License.
17
17
  */
18
- .bpk-card-list{display:flex;flex-direction:column;overflow:clip;gap:1.5rem}@media(max-width: 32rem){.bpk-card-list{gap:1rem}}.bpk-card-list--card-list{display:flex;flex-direction:column}
18
+ .bpk-card-list{display:flex;flex-direction:column;gap:1.5rem}@media(max-width: 32rem){.bpk-card-list{gap:1rem}}.bpk-card-list--card-list{display:flex;margin:calc(-1*0.25rem);padding:.25rem;flex-direction:column;overflow:hidden}
@@ -133,10 +133,10 @@ const BpkCardListCarousel = props => {
133
133
  cardDimensionStyle.height = `${firstCardHeightRef.current}px`;
134
134
  }
135
135
  const isPageStart = index % initiallyShownCards === 0;
136
+ const cardKey = `carousel-card-${index.toString()}`;
136
137
  const commonProps = {
137
138
  className: getClassName(`bpk-card-list-row-rail__${layout}__card`, isPageStart && 'bpk-card-list-row-rail__card--page-start'),
138
139
  style: shownNumberStyle,
139
- key: `carousel-card-${index.toString()}`,
140
140
  role: 'group'
141
141
  };
142
142
 
@@ -157,7 +157,7 @@ const BpkCardListCarousel = props => {
157
157
  className: getClassName('bpk-card-list-row-rail__card-slot'),
158
158
  children: card
159
159
  })
160
- });
160
+ }, cardKey);
161
161
  }
162
162
  return /*#__PURE__*/_jsx("div", {
163
163
  ...commonProps,
@@ -167,7 +167,7 @@ const BpkCardListCarousel = props => {
167
167
  className: getClassName('bpk-card-list-row-rail__card-slot'),
168
168
  children: card
169
169
  })
170
- });
170
+ }, cardKey);
171
171
  })
172
172
  });
173
173
  };
@@ -0,0 +1,7 @@
1
+ import BpkChatbotInput from './src/BpkChatbotInput';
2
+ export type { BpkChatbotInputProps } from './src/common-types';
3
+ export { CHATBOT_INPUT_TYPES } from './src/common-types';
4
+ export type { ChatbotInputType } from './src/common-types';
5
+ export { useChatbotInputManager } from './src/hooks';
6
+ export { default as themeAttributes } from './src/themeAttributes';
7
+ export default BpkChatbotInput;
@@ -0,0 +1,23 @@
1
+ /*
2
+ * Backpack - Skyscanner's Design System
3
+ *
4
+ * Copyright 2016 Skyscanner Ltd
5
+ *
6
+ * Licensed under the Apache License, Version 2.0 (the "License");
7
+ * you may not use this file except in compliance with the License.
8
+ * You may obtain a copy of the License at
9
+ *
10
+ * http://www.apache.org/licenses/LICENSE-2.0
11
+ *
12
+ * Unless required by applicable law or agreed to in writing, software
13
+ * distributed under the License is distributed on an "AS IS" BASIS,
14
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ * See the License for the specific language governing permissions and
16
+ * limitations under the License.
17
+ */
18
+
19
+ import BpkChatbotInput from "./src/BpkChatbotInput";
20
+ export { CHATBOT_INPUT_TYPES } from "./src/common-types";
21
+ export { useChatbotInputManager } from "./src/hooks";
22
+ export { default as themeAttributes } from "./src/themeAttributes";
23
+ export default BpkChatbotInput;
@@ -0,0 +1,4 @@
1
+ import type { BpkChatbotInputProps } from './common-types';
2
+ export type { BpkChatbotInputProps };
3
+ declare const BpkChatbotInput: ({ inputType, inputValue, isPolling, isSending, loadingAriaLabel, maxCharacters, onInputBlur, onInputChange, onInputClick, onInputFocus, onKeyDown, onSubmit, placeholder, sendAriaLabel, }: BpkChatbotInputProps) => import("react/jsx-runtime").JSX.Element;
4
+ export default BpkChatbotInput;