@box/blueprint-web 12.103.3 → 12.105.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/lib-esm/accordion/accordion.module.js +1 -1
- package/dist/lib-esm/avatar/avatar.module.js +1 -1
- package/dist/lib-esm/badge/base-badge.module.js +1 -1
- package/dist/lib-esm/breadcrumb/breadcrumb.js +44 -5
- package/dist/lib-esm/breadcrumb/types.d.ts +2 -0
- package/dist/lib-esm/card-tooltip/card-tooltip.module.js +1 -1
- package/dist/lib-esm/card-tooltip-v2/card-tooltip-v2.module.js +1 -1
- package/dist/lib-esm/checkbox/checkbox.module.js +1 -1
- package/dist/lib-esm/combobox/combobox.module.js +1 -1
- package/dist/lib-esm/combobox-group/combobox-group.module.js +1 -1
- package/dist/lib-esm/content-card/content-card.module.js +1 -1
- package/dist/lib-esm/data-table/cell/sticky-cell.module.js +1 -1
- package/dist/lib-esm/data-table/data-table.module.js +1 -1
- package/dist/lib-esm/date-picker/date-picker.module.js +1 -1
- package/dist/lib-esm/empty-state/empty-state.module.js +1 -1
- package/dist/lib-esm/index.css +1147 -1077
- package/dist/lib-esm/input-chip/input-chip.module.js +1 -1
- package/dist/lib-esm/loading-indicator/loading-indicator.module.js +1 -1
- package/dist/lib-esm/modal/modal.module.js +1 -1
- package/dist/lib-esm/page-section/page-section.module.js +1 -1
- package/dist/lib-esm/password-input/password-input.module.js +1 -1
- package/dist/lib-esm/primitives/base-button/base-button.module.js +1 -1
- package/dist/lib-esm/primitives/base-text-input/base-text-input.module.js +1 -1
- package/dist/lib-esm/primitives/calendar/calendar.module.js +1 -1
- package/dist/lib-esm/primitives/context-menu/context-menu.module.js +1 -1
- package/dist/lib-esm/primitives/dropdown-menu/dropdown-menu.module.js +1 -1
- package/dist/lib-esm/primitives/notification/notification.module.js +1 -1
- package/dist/lib-esm/primitives/popover/popover.module.js +1 -1
- package/dist/lib-esm/primitives/select-menu-grid/select-menu-grid-option.module.js +1 -1
- package/dist/lib-esm/primitives/tabs/tabs.module.js +1 -1
- package/dist/lib-esm/radio-group/radio-group.module.js +1 -1
- package/dist/lib-esm/select/select-context.d.ts +12 -0
- package/dist/lib-esm/select/select-context.js +55 -0
- package/dist/lib-esm/select/select.js +115 -34
- package/dist/lib-esm/select/select.module.js +1 -1
- package/dist/lib-esm/select/types.d.ts +45 -0
- package/dist/lib-esm/side-panel/side-panel.module.js +1 -1
- package/dist/lib-esm/switch/switch.module.js +1 -1
- package/dist/lib-esm/text/text.module.js +1 -1
- package/dist/lib-esm/text-area/text-area-autosize/text-area-autosize.module.js +1 -1
- package/dist/lib-esm/text-area/text-area.module.js +1 -1
- package/dist/lib-esm/text-button/text-button.module.js +1 -1
- package/dist/lib-esm/text-input/text-input.module.js +1 -1
- package/dist/lib-esm/time-picker/time-picker.module.js +1 -1
- package/dist/lib-esm/toolbar/toolbar.module.js +1 -1
- package/dist/lib-esm/trigger-button/trigger-button.module.js +1 -1
- package/dist/lib-esm/util-components/base-grid-list-item/base-grid-list-item.module.js +1 -1
- package/dist/lib-esm/util-components/interactive-icon/interactive-icon.module.js +1 -1
- package/dist/lib-esm/utils/throwOnDev.d.ts +6 -0
- package/dist/lib-esm/utils/throwOnDev.js +14 -0
- package/package.json +3 -3
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import '../index.css';
|
|
2
|
-
var styles = {"accordionItem":"bp_accordion_module_accordionItem--
|
|
2
|
+
var styles = {"accordionItem":"bp_accordion_module_accordionItem--def2b","accordionContent":"bp_accordion_module_accordionContent--def2b","accordion":"bp_accordion_module_accordion--def2b","accordionContentWrapper":"bp_accordion_module_accordionContentWrapper--def2b","accordionInlineErrorWrapper":"bp_accordion_module_accordionInlineErrorWrapper--def2b","accordionFixedContent":"bp_accordion_module_accordionFixedContent--def2b","accordionHeader":"bp_accordion_module_accordionHeader--def2b","accordionHeaderTrigger":"bp_accordion_module_accordionHeaderTrigger--def2b","accordionStatus":"bp_accordion_module_accordionStatus--def2b","accordionIconWrapper":"bp_accordion_module_accordionIconWrapper--def2b","bgOnly":"bp_accordion_module_bgOnly--def2b","withIcon":"bp_accordion_module_withIcon--def2b","accordionTrigger":"bp_accordion_module_accordionTrigger--def2b","accordionTriggerIcon":"bp_accordion_module_accordionTriggerIcon--def2b"};
|
|
3
3
|
|
|
4
4
|
export { styles as default };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import '../index.css';
|
|
2
|
-
var styles = {"avatar":"bp_avatar_module_avatar--
|
|
2
|
+
var styles = {"avatar":"bp_avatar_module_avatar--2a8c5","small":"bp_avatar_module_small--2a8c5","length-1":"bp_avatar_module_length-1--2a8c5","text":"bp_avatar_module_text--2a8c5","length-2":"bp_avatar_module_length-2--2a8c5","medium":"bp_avatar_module_medium--2a8c5","large":"bp_avatar_module_large--2a8c5","length-3":"bp_avatar_module_length-3--2a8c5","length-4":"bp_avatar_module_length-4--2a8c5","xlarge":"bp_avatar_module_xlarge--2a8c5","xxlarge":"bp_avatar_module_xxlarge--2a8c5","badge":"bp_avatar_module_badge--2a8c5","image":"bp_avatar_module_image--2a8c5","loading":"bp_avatar_module_loading--2a8c5","anonymousAvatar":"bp_avatar_module_anonymousAvatar--2a8c5","iconContainer":"bp_avatar_module_iconContainer--2a8c5"};
|
|
3
3
|
|
|
4
4
|
export { styles as default };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import '../index.css';
|
|
2
|
-
var styles = {"badgeContainer":"bp_base_badge_module_badgeContainer--
|
|
2
|
+
var styles = {"badgeContainer":"bp_base_badge_module_badgeContainer--749fd","badge":"bp_base_badge_module_badge--749fd","smallSizeBadge":"bp_base_badge_module_smallSizeBadge--749fd","mediumSizeBadge":"bp_base_badge_module_mediumSizeBadge--749fd","largeSizeBadge":"bp_base_badge_module_largeSizeBadge--749fd","xlargeSizeBadge":"bp_base_badge_module_xlargeSizeBadge--749fd","xxlargeSizeBadge":"bp_base_badge_module_xxlargeSizeBadge--749fd","iconBadge":"bp_base_badge_module_iconBadge--749fd","interactiveWrapper":"bp_base_badge_module_interactiveWrapper--749fd","statusBadge":"bp_base_badge_module_statusBadge--749fd","numericBadge":"bp_base_badge_module_numericBadge--749fd","numericBadgeSingleDigit":"bp_base_badge_module_numericBadgeSingleDigit--749fd","numericBadgeMoreDigits":"bp_base_badge_module_numericBadgeMoreDigits--749fd"};
|
|
3
3
|
|
|
4
4
|
export { styles as default };
|
|
@@ -7,6 +7,7 @@ import noop from 'lodash/noop';
|
|
|
7
7
|
import { DropdownMenu } from '../primitives/dropdown-menu/index.js';
|
|
8
8
|
import { IconButton } from '../primitives/icon-button/icon-button.js';
|
|
9
9
|
import { Text } from '../text/text.js';
|
|
10
|
+
import { useBreakpoint, Breakpoint } from '../utils/useBreakpoint.js';
|
|
10
11
|
import { PageLink } from './page-link.js';
|
|
11
12
|
import styles from './breadcrumb.module.js';
|
|
12
13
|
import { getSeparatorSize } from './utils.js';
|
|
@@ -19,6 +20,7 @@ const Breadcrumb = /*#__PURE__*/forwardRef((props, forwardedRef) => {
|
|
|
19
20
|
rootIconAriaLabel,
|
|
20
21
|
rootIconVariant,
|
|
21
22
|
isInteractive = true,
|
|
23
|
+
isResponsiveEnabled,
|
|
22
24
|
size = 'medium',
|
|
23
25
|
truncationMethod = 'ellipsis',
|
|
24
26
|
onPageLinkClick = noop,
|
|
@@ -27,9 +29,15 @@ const Breadcrumb = /*#__PURE__*/forwardRef((props, forwardedRef) => {
|
|
|
27
29
|
const handlePageLinkClick = useCallback(crumbId => () => {
|
|
28
30
|
onPageLinkClick(crumbId);
|
|
29
31
|
}, [onPageLinkClick]);
|
|
32
|
+
// Responsive detection: mobile/tablet takes priority over consumer-controlled truncationMethod
|
|
33
|
+
const breakpoint = useBreakpoint();
|
|
34
|
+
const isMobile = isResponsiveEnabled || breakpoint <= Breakpoint.Medium;
|
|
30
35
|
// If there are more than 7 crumbs, break up crumbs into first link, ellipsis icon button, and current page ancestor
|
|
31
36
|
const shouldTruncateCrumbs = crumbs?.length > 7;
|
|
32
|
-
const shouldUseEllipsisTruncation = truncationMethod === 'ellipsis' && shouldTruncateCrumbs && crumbs;
|
|
37
|
+
const shouldUseEllipsisTruncation = !isMobile && truncationMethod === 'ellipsis' && shouldTruncateCrumbs && crumbs;
|
|
38
|
+
// Get the current page (last crumb) and all ancestors (all crumbs except last)
|
|
39
|
+
const currentPage = crumbs?.[crumbs.length - 1];
|
|
40
|
+
const ancestorCrumbs = crumbs?.slice(0, -1);
|
|
33
41
|
return jsx("nav", {
|
|
34
42
|
ref: forwardedRef,
|
|
35
43
|
"aria-label": breadcrumbAriaLabel,
|
|
@@ -37,7 +45,7 @@ const Breadcrumb = /*#__PURE__*/forwardRef((props, forwardedRef) => {
|
|
|
37
45
|
...rest,
|
|
38
46
|
children: jsxs("ol", {
|
|
39
47
|
className: styles.breadcrumb,
|
|
40
|
-
children: [rootIconVariant && jsxs("li", {
|
|
48
|
+
children: [!isMobile && rootIconVariant && jsxs("li", {
|
|
41
49
|
className: styles.pageLink,
|
|
42
50
|
children: [rootIconVariant === 'home' ? jsx(Home, {
|
|
43
51
|
"aria-label": rootIconAriaLabel
|
|
@@ -48,6 +56,38 @@ const Breadcrumb = /*#__PURE__*/forwardRef((props, forwardedRef) => {
|
|
|
48
56
|
role: "presentation",
|
|
49
57
|
width: getSeparatorSize(size)
|
|
50
58
|
})]
|
|
59
|
+
}), isMobile && crumbs && currentPage && jsxs(Fragment, {
|
|
60
|
+
children: [jsxs("li", {
|
|
61
|
+
className: styles.pageLink,
|
|
62
|
+
children: [jsxs(DropdownMenu.Root, {
|
|
63
|
+
children: [jsx(DropdownMenu.Trigger, {
|
|
64
|
+
children: jsx(IconButton, {
|
|
65
|
+
"aria-label": truncatedLinksIconAriaLabel,
|
|
66
|
+
icon: FolderTree,
|
|
67
|
+
size: "small"
|
|
68
|
+
})
|
|
69
|
+
}), jsx(DropdownMenu.Content, {
|
|
70
|
+
align: "start",
|
|
71
|
+
children: ancestorCrumbs?.map(crumb => jsx(DropdownMenu.Item, {
|
|
72
|
+
onSelect: handlePageLinkClick(crumb.id),
|
|
73
|
+
children: jsx(Text, {
|
|
74
|
+
as: "span",
|
|
75
|
+
children: crumb.name
|
|
76
|
+
})
|
|
77
|
+
}, crumb.id))
|
|
78
|
+
})]
|
|
79
|
+
}), jsx(PointerRight, {
|
|
80
|
+
height: getSeparatorSize(size),
|
|
81
|
+
role: "presentation",
|
|
82
|
+
width: getSeparatorSize(size)
|
|
83
|
+
})]
|
|
84
|
+
}), jsx(PageLink, {
|
|
85
|
+
crumb: currentPage,
|
|
86
|
+
isInteractive: isInteractive,
|
|
87
|
+
isLast: true,
|
|
88
|
+
onPageLinkClick: onPageLinkClick,
|
|
89
|
+
size: size
|
|
90
|
+
})]
|
|
51
91
|
}), shouldUseEllipsisTruncation && jsxs(Fragment, {
|
|
52
92
|
children: [jsx(PageLink, {
|
|
53
93
|
crumb: crumbs[0],
|
|
@@ -61,7 +101,6 @@ const Breadcrumb = /*#__PURE__*/forwardRef((props, forwardedRef) => {
|
|
|
61
101
|
children: [jsx(DropdownMenu.Trigger, {
|
|
62
102
|
children: jsx(IconButton, {
|
|
63
103
|
"aria-label": truncatedLinksIconAriaLabel,
|
|
64
|
-
className: styles.iconButtonInline,
|
|
65
104
|
icon: Ellipsis,
|
|
66
105
|
size: "small"
|
|
67
106
|
})
|
|
@@ -89,13 +128,13 @@ const Breadcrumb = /*#__PURE__*/forwardRef((props, forwardedRef) => {
|
|
|
89
128
|
onPageLinkClick: onPageLinkClick,
|
|
90
129
|
size: size
|
|
91
130
|
}), jsx(PageLink, {
|
|
92
|
-
crumb:
|
|
131
|
+
crumb: currentPage,
|
|
93
132
|
isInteractive: isInteractive,
|
|
94
133
|
isLast: true,
|
|
95
134
|
onPageLinkClick: onPageLinkClick,
|
|
96
135
|
size: size
|
|
97
136
|
})]
|
|
98
|
-
}), !shouldUseEllipsisTruncation && crumbs?.map((crumb, index) => {
|
|
137
|
+
}), !isMobile && !shouldUseEllipsisTruncation && crumbs?.map((crumb, index) => {
|
|
99
138
|
return jsx(PageLink, {
|
|
100
139
|
crumb: crumb,
|
|
101
140
|
isInteractive: isInteractive,
|
|
@@ -15,6 +15,8 @@ export type BreadcrumbProps = {
|
|
|
15
15
|
crumbs: Crumb[];
|
|
16
16
|
/** Controls whether individual crumbs (items) and icons are interactive, or clickable. */
|
|
17
17
|
isInteractive?: boolean;
|
|
18
|
+
/** Forces responsive view regardless of viewport size. Useful for testing. */
|
|
19
|
+
isResponsiveEnabled?: boolean;
|
|
18
20
|
/** Callback for breadcrumb click. Used to trigger navigation to the clicked folder. */
|
|
19
21
|
onPageLinkClick?: (id: string) => void;
|
|
20
22
|
/** Controls the height and width of icons and crumbs. */
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import '../index.css';
|
|
2
|
-
var styles = {"content":"bp_card_tooltip_module_content--
|
|
2
|
+
var styles = {"content":"bp_card_tooltip_module_content--3d185","card":"bp_card_tooltip_module_card--3d185"};
|
|
3
3
|
|
|
4
4
|
export { styles as default };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import '../index.css';
|
|
2
|
-
var styles = {"option":"bp_checkbox_module_option--
|
|
2
|
+
var styles = {"option":"bp_checkbox_module_option--dcf4a","checkbox":"bp_checkbox_module_checkbox--dcf4a","indicator":"bp_checkbox_module_indicator--dcf4a","label":"bp_checkbox_module_label--dcf4a","description":"bp_checkbox_module_description--dcf4a","disabled":"bp_checkbox_module_disabled--dcf4a"};
|
|
3
3
|
|
|
4
4
|
export { styles as default };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import '../index.css';
|
|
2
|
-
var styles = {"container":"bp_combobox_module_container--
|
|
2
|
+
var styles = {"container":"bp_combobox_module_container--ee53f","label":"bp_combobox_module_label--ee53f","textInput":"bp_combobox_module_textInput--ee53f","popover":"bp_combobox_module_popover--ee53f","disabled":"bp_combobox_module_disabled--ee53f","hiddenLabel":"bp_combobox_module_hiddenLabel--ee53f","comboboxContainer":"bp_combobox_module_comboboxContainer--ee53f","withComboboxButtons":"bp_combobox_module_withComboboxButtons--ee53f","error":"bp_combobox_module_error--ee53f","textInputWrapper":"bp_combobox_module_textInputWrapper--ee53f","comboboxButtons":"bp_combobox_module_comboboxButtons--ee53f","withChips":"bp_combobox_module_withChips--ee53f","inlineError":"bp_combobox_module_inlineError--ee53f","option":"bp_combobox_module_option--ee53f","indicator":"bp_combobox_module_indicator--ee53f","indicatorIcon":"bp_combobox_module_indicatorIcon--ee53f","optionWithIndicator":"bp_combobox_module_optionWithIndicator--ee53f","loadingIndicator":"bp_combobox_module_loadingIndicator--ee53f"};
|
|
3
3
|
|
|
4
4
|
export { styles as default };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import '../index.css';
|
|
2
|
-
var styles = {"container":"bp_combobox_group_module_container--
|
|
2
|
+
var styles = {"container":"bp_combobox_group_module_container--b313e","trailing":"bp_combobox_group_module_trailing--b313e","leading":"bp_combobox_group_module_leading--b313e","label":"bp_combobox_group_module_label--b313e","comboboxContainer":"bp_combobox_group_module_comboboxContainer--b313e","comboboxGroupcontainer":"bp_combobox_group_module_comboboxGroupcontainer--b313e","disabled":"bp_combobox_group_module_disabled--b313e","errorCombobox":"bp_combobox_group_module_errorCombobox--b313e","errorSelect":"bp_combobox_group_module_errorSelect--b313e","selectHasFocus":"bp_combobox_group_module_selectHasFocus--b313e","comboboxHasFocus":"bp_combobox_group_module_comboboxHasFocus--b313e"};
|
|
3
3
|
|
|
4
4
|
export { styles as default };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import '../index.css';
|
|
2
|
-
var styles = {"card":"bp_content_card_module_card--
|
|
2
|
+
var styles = {"card":"bp_content_card_module_card--f6e1d","ghostCard":"bp_content_card_module_ghostCard--f6e1d","cardContent":"bp_content_card_module_cardContent--f6e1d","cardTitle":"bp_content_card_module_cardTitle--f6e1d","cardTitleText":"bp_content_card_module_cardTitleText--f6e1d","cardBody":"bp_content_card_module_cardBody--f6e1d","cardBodyText":"bp_content_card_module_cardBodyText--f6e1d","cardIcon":"bp_content_card_module_cardIcon--f6e1d","cardBackground":"bp_content_card_module_cardBackground--f6e1d","image":"bp_content_card_module_image--f6e1d","iconGhost":"bp_content_card_module_iconGhost--f6e1d","titleGhost":"bp_content_card_module_titleGhost--f6e1d","bodyGhost":"bp_content_card_module_bodyGhost--f6e1d","pillGhostContainer":"bp_content_card_module_pillGhostContainer--f6e1d","pillGhost":"bp_content_card_module_pillGhost--f6e1d"};
|
|
3
3
|
|
|
4
4
|
export { styles as default };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import '../../index.css';
|
|
2
|
-
var styles = {"stickyCell":"bp_sticky_cell_module_stickyCell--
|
|
2
|
+
var styles = {"stickyCell":"bp_sticky_cell_module_stickyCell--17573","childrenWrapper":"bp_sticky_cell_module_childrenWrapper--17573","verticalBar":"bp_sticky_cell_module_verticalBar--17573","isScrolledX":"bp_sticky_cell_module_isScrolledX--17573","stickyCellBelow":"bp_sticky_cell_module_stickyCellBelow--17573","stickyCellOuterLeft":"bp_sticky_cell_module_stickyCellOuterLeft--17573"};
|
|
3
3
|
|
|
4
4
|
export { styles as default };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import '../index.css';
|
|
2
|
-
var styles = {"dataTableWrapper":"bp_data_table_module_dataTableWrapper--
|
|
2
|
+
var styles = {"dataTableWrapper":"bp_data_table_module_dataTableWrapper--2dfe3","isScrolledX":"bp_data_table_module_isScrolledX--2dfe3","hideActionWrapperRight":"bp_data_table_module_hideActionWrapperRight--2dfe3"};
|
|
3
3
|
|
|
4
4
|
export { styles as default };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import '../index.css';
|
|
2
|
-
var styles = {"datePicker":"bp_date_picker_module_datePicker--
|
|
2
|
+
var styles = {"datePicker":"bp_date_picker_module_datePicker--8b5fc","label":"bp_date_picker_module_label--8b5fc","group":"bp_date_picker_module_group--8b5fc","disabled":"bp_date_picker_module_disabled--8b5fc","groupContainer":"bp_date_picker_module_groupContainer--8b5fc","error":"bp_date_picker_module_error--8b5fc","groupContainerInput":"bp_date_picker_module_groupContainerInput--8b5fc","groupContainerInputSegment":"bp_date_picker_module_groupContainerInputSegment--8b5fc","button":"bp_date_picker_module_button--8b5fc","clear":"bp_date_picker_module_clear--8b5fc","inlineError":"bp_date_picker_module_inlineError--8b5fc","datePickerPopoverContent":"bp_date_picker_module_datePickerPopoverContent--8b5fc"};
|
|
3
3
|
|
|
4
4
|
export { styles as default };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import '../index.css';
|
|
2
|
-
var styles = {"emptyState":"bp_empty_state_module_emptyState--
|
|
2
|
+
var styles = {"emptyState":"bp_empty_state_module_emptyState--cda72","illustration":"bp_empty_state_module_illustration--cda72","body":"bp_empty_state_module_body--cda72","heading":"bp_empty_state_module_heading--cda72","button":"bp_empty_state_module_button--cda72","small":"bp_empty_state_module_small--cda72"};
|
|
3
3
|
|
|
4
4
|
export { styles as default };
|