@primer/components 0.0.0-20211030163410 → 0.0.0-20211030175556
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/CHANGELOG.md +2 -28
- package/dist/browser.esm.js +591 -602
- package/dist/browser.esm.js.map +1 -1
- package/dist/browser.umd.js +200 -211
- package/dist/browser.umd.js.map +1 -1
- package/lib/ActionList/Divider.jsx +29 -0
- package/lib/ActionList/Group.jsx +23 -0
- package/lib/ActionList/Header.jsx +66 -0
- package/lib/ActionList/Item.js +3 -3
- package/lib/ActionList/Item.jsx +288 -0
- package/lib/ActionList/List.jsx +138 -0
- package/lib/ActionList/index.js +12 -23
- package/lib/ActionList2/Description.jsx +29 -0
- package/lib/ActionList2/Divider.jsx +22 -0
- package/lib/ActionList2/Group.jsx +54 -0
- package/lib/ActionList2/Header.d.ts +26 -0
- package/lib/ActionList2/Header.js +55 -0
- package/lib/ActionList2/Header.jsx +36 -0
- package/lib/ActionList2/Item.js +1 -3
- package/lib/ActionList2/Item.jsx +174 -0
- package/lib/ActionList2/LinkItem.jsx +28 -0
- package/lib/ActionList2/List.js +2 -1
- package/lib/ActionList2/List.jsx +41 -0
- package/lib/ActionList2/Selection.js +1 -3
- package/lib/ActionList2/Selection.jsx +50 -0
- package/lib/ActionList2/Visuals.jsx +48 -0
- package/lib/ActionList2/index.js +23 -41
- package/lib/ActionMenu.jsx +73 -0
- package/lib/AnchoredOverlay/AnchoredOverlay.jsx +100 -0
- package/lib/AnchoredOverlay/index.js +4 -12
- package/lib/Autocomplete/Autocomplete.d.ts +0 -1
- package/lib/Autocomplete/Autocomplete.jsx +100 -0
- package/lib/Autocomplete/AutocompleteContext.jsx +5 -0
- package/lib/Autocomplete/AutocompleteInput.d.ts +0 -1
- package/lib/Autocomplete/AutocompleteInput.jsx +113 -0
- package/lib/Autocomplete/AutocompleteMenu.js +13 -6
- package/lib/Autocomplete/AutocompleteMenu.jsx +190 -0
- package/lib/Autocomplete/AutocompleteOverlay.jsx +55 -0
- package/lib/Autocomplete/index.js +7 -14
- package/lib/Avatar.jsx +34 -0
- package/lib/AvatarPair.jsx +29 -0
- package/lib/AvatarStack.jsx +151 -0
- package/lib/BaseStyles.jsx +65 -0
- package/lib/BorderBox.jsx +18 -0
- package/lib/Box.jsx +10 -0
- package/lib/BranchName.jsx +20 -0
- package/lib/Breadcrumbs.jsx +71 -0
- package/lib/Button/Button.d.ts +0 -1
- package/lib/Button/Button.jsx +40 -0
- package/lib/Button/ButtonBase.jsx +33 -0
- package/lib/Button/ButtonClose.d.ts +1 -2
- package/lib/Button/ButtonClose.jsx +53 -0
- package/lib/Button/ButtonDanger.d.ts +0 -1
- package/lib/Button/ButtonDanger.jsx +43 -0
- package/lib/Button/ButtonGroup.jsx +55 -0
- package/lib/Button/ButtonInvisible.d.ts +0 -1
- package/lib/Button/ButtonInvisible.jsx +32 -0
- package/lib/Button/ButtonOutline.d.ts +0 -1
- package/lib/Button/ButtonOutline.jsx +43 -0
- package/lib/Button/ButtonPrimary.d.ts +0 -1
- package/lib/Button/ButtonPrimary.jsx +42 -0
- package/lib/Button/ButtonStyles.jsx +37 -0
- package/lib/Button/ButtonTableList.jsx +46 -0
- package/lib/Button/index.js +21 -70
- package/lib/Caret.jsx +93 -0
- package/lib/CircleBadge.jsx +42 -0
- package/lib/CircleOcticon.d.ts +0 -1
- package/lib/CircleOcticon.jsx +21 -0
- package/lib/CounterLabel.jsx +43 -0
- package/lib/Details.jsx +21 -0
- package/lib/Dialog/ConfirmationDialog.jsx +146 -0
- package/lib/Dialog/Dialog.jsx +279 -0
- package/lib/Dialog.d.ts +2 -3
- package/lib/Dialog.jsx +129 -0
- package/lib/Dropdown.d.ts +0 -4
- package/lib/Dropdown.jsx +131 -0
- package/lib/DropdownMenu/DropdownButton.d.ts +1 -2
- package/lib/DropdownMenu/DropdownButton.jsx +14 -0
- package/lib/DropdownMenu/DropdownMenu.jsx +70 -0
- package/lib/DropdownMenu/index.js +6 -20
- package/lib/DropdownStyles.js +18 -26
- package/lib/FilterList.d.ts +0 -1
- package/lib/FilterList.jsx +59 -0
- package/lib/FilteredActionList/FilteredActionList.jsx +100 -0
- package/lib/FilteredActionList/index.js +4 -12
- package/lib/FilteredSearch.jsx +28 -0
- package/lib/Flash.jsx +69 -0
- package/lib/Flex.jsx +15 -0
- package/lib/FormGroup.jsx +22 -0
- package/lib/Grid.jsx +15 -0
- package/lib/Header.jsx +83 -0
- package/lib/Heading.jsx +21 -0
- package/lib/Label.jsx +82 -0
- package/lib/LabelGroup.jsx +18 -0
- package/lib/Link.jsx +36 -0
- package/lib/NewButton/button-counter.jsx +14 -0
- package/lib/NewButton/button.jsx +279 -0
- package/lib/NewButton/index.js +5 -12
- package/lib/NewButton/types.js +2 -1
- package/lib/Overlay.d.ts +3 -5
- package/lib/Overlay.jsx +154 -0
- package/lib/Pagehead.jsx +17 -0
- package/lib/Pagination/Pagination.jsx +161 -0
- package/lib/Pagination/index.js +6 -12
- package/lib/Pagination/model.jsx +174 -0
- package/lib/PointerBox.jsx +25 -0
- package/lib/Popover.jsx +202 -0
- package/lib/Portal/Portal.jsx +79 -0
- package/lib/Portal/index.js +5 -16
- package/lib/Position.d.ts +4 -4
- package/lib/Position.jsx +46 -0
- package/lib/ProgressBar.jsx +39 -0
- package/lib/SelectMenu/SelectMenu.d.ts +4 -10
- package/lib/SelectMenu/SelectMenu.jsx +112 -0
- package/lib/SelectMenu/SelectMenuContext.jsx +5 -0
- package/lib/SelectMenu/SelectMenuDivider.jsx +42 -0
- package/lib/SelectMenu/SelectMenuFilter.jsx +58 -0
- package/lib/SelectMenu/SelectMenuFooter.jsx +45 -0
- package/lib/SelectMenu/SelectMenuHeader.jsx +42 -0
- package/lib/SelectMenu/SelectMenuItem.d.ts +1 -1
- package/lib/SelectMenu/SelectMenuItem.jsx +142 -0
- package/lib/SelectMenu/SelectMenuList.jsx +59 -0
- package/lib/SelectMenu/SelectMenuLoadingAnimation.jsx +22 -0
- package/lib/SelectMenu/SelectMenuModal.d.ts +1 -1
- package/lib/SelectMenu/SelectMenuModal.jsx +118 -0
- package/lib/SelectMenu/SelectMenuTab.jsx +92 -0
- package/lib/SelectMenu/SelectMenuTabPanel.jsx +42 -0
- package/lib/SelectMenu/SelectMenuTabs.jsx +57 -0
- package/lib/SelectMenu/hooks/useKeyboardNav.js +80 -96
- package/lib/SelectMenu/index.js +7 -14
- package/lib/SelectPanel/SelectPanel.jsx +105 -0
- package/lib/SelectPanel/index.js +4 -12
- package/lib/SideNav.jsx +173 -0
- package/lib/Spinner.jsx +35 -0
- package/lib/StateLabel.jsx +93 -0
- package/lib/StyledOcticon.jsx +18 -0
- package/lib/SubNav.jsx +101 -0
- package/lib/TabNav.jsx +58 -0
- package/lib/Text.jsx +14 -0
- package/lib/TextInput.jsx +23 -0
- package/lib/TextInputWithTokens.d.ts +0 -1
- package/lib/TextInputWithTokens.jsx +218 -0
- package/lib/ThemeProvider.jsx +130 -0
- package/lib/Timeline.jsx +123 -0
- package/lib/Token/AvatarToken.d.ts +1 -1
- package/lib/Token/AvatarToken.jsx +54 -0
- package/lib/Token/IssueLabelToken.d.ts +1 -1
- package/lib/Token/IssueLabelToken.jsx +125 -0
- package/lib/Token/Token.d.ts +1 -1
- package/lib/Token/Token.jsx +103 -0
- package/lib/Token/TokenBase.jsx +88 -0
- package/lib/Token/_RemoveTokenButton.jsx +108 -0
- package/lib/Token/_TokenTextContainer.jsx +49 -0
- package/lib/Token/index.js +11 -30
- package/lib/Tooltip.jsx +246 -0
- package/lib/Truncate.jsx +24 -0
- package/lib/UnderlineNav.jsx +88 -0
- package/lib/_TextInputWrapper.jsx +120 -0
- package/lib/_UnstyledTextInput.jsx +22 -0
- package/lib/behaviors/anchoredPosition.js +205 -234
- package/lib/behaviors/focusTrap.js +121 -157
- package/lib/behaviors/focusZone.js +434 -509
- package/lib/behaviors/scrollIntoViewingArea.js +18 -35
- package/lib/constants.js +39 -43
- package/lib/drafts.js +20 -30
- package/lib/hooks/index.js +16 -60
- package/lib/hooks/useAnchoredPosition.js +32 -40
- package/lib/hooks/useCombinedRefs.js +32 -36
- package/lib/hooks/useDetails.jsx +39 -0
- package/lib/hooks/useDialog.js +72 -96
- package/lib/hooks/useFocusTrap.js +43 -60
- package/lib/hooks/useFocusZone.js +54 -50
- package/lib/hooks/useOnEscapePress.js +25 -36
- package/lib/hooks/useOnOutsideClick.jsx +61 -0
- package/lib/hooks/useOpenAndCloseFocus.js +22 -34
- package/lib/hooks/useOverlay.jsx +15 -0
- package/lib/hooks/useProvidedRefOrCreate.js +10 -14
- package/lib/hooks/useProvidedStateOrCreate.js +13 -16
- package/lib/hooks/useRenderForcingRef.js +13 -17
- package/lib/hooks/useResizeObserver.js +15 -18
- package/lib/hooks/useSafeTimeout.js +22 -30
- package/lib/hooks/useScrollFlash.js +16 -23
- package/lib/index.d.ts +0 -5
- package/lib/index.js +163 -676
- package/lib/polyfills/eventListenerSignal.js +37 -45
- package/lib/sx.js +10 -22
- package/lib/theme-preval.js +64 -3169
- package/lib/theme.js +3 -12
- package/lib/utils/create-slots.jsx +65 -0
- package/lib/utils/deprecate.jsx +59 -0
- package/lib/utils/isNumeric.jsx +7 -0
- package/lib/utils/iterateFocusableElements.js +63 -85
- package/lib/utils/ssr.jsx +6 -0
- package/lib/utils/test-deprecations.jsx +20 -0
- package/lib/utils/test-helpers.jsx +8 -0
- package/lib/utils/test-matchers.jsx +100 -0
- package/lib/utils/testing.d.ts +1 -2
- package/lib/utils/testing.js +0 -29
- package/lib/utils/testing.jsx +206 -0
- package/lib/utils/theme.js +33 -47
- package/lib/utils/types/AriaRole.js +2 -1
- package/lib/utils/types/ComponentProps.js +2 -1
- package/lib/utils/types/Flatten.js +2 -1
- package/lib/utils/types/KeyPaths.js +2 -1
- package/lib/utils/types/MandateProps.js +16 -1
- package/lib/utils/types/Merge.js +2 -1
- package/lib/utils/types/index.js +16 -69
- package/lib/utils/uniqueId.js +5 -8
- package/lib/utils/use-force-update.js +8 -14
- package/lib/utils/useIsomorphicLayoutEffect.js +8 -11
- package/lib/utils/userAgent.js +8 -12
- package/lib-esm/ActionList/Item.js +3 -3
- package/lib-esm/ActionList2/Header.d.ts +26 -0
- package/lib-esm/ActionList2/Header.js +44 -0
- package/lib-esm/ActionList2/Item.js +1 -3
- package/lib-esm/ActionList2/List.js +2 -1
- package/lib-esm/ActionList2/Selection.js +1 -3
- package/lib-esm/Autocomplete/Autocomplete.d.ts +0 -1
- package/lib-esm/Autocomplete/AutocompleteInput.d.ts +0 -1
- package/lib-esm/Autocomplete/AutocompleteMenu.js +13 -3
- package/lib-esm/Button/Button.d.ts +0 -1
- package/lib-esm/Button/ButtonClose.d.ts +1 -2
- package/lib-esm/Button/ButtonDanger.d.ts +0 -1
- package/lib-esm/Button/ButtonInvisible.d.ts +0 -1
- package/lib-esm/Button/ButtonOutline.d.ts +0 -1
- package/lib-esm/Button/ButtonPrimary.d.ts +0 -1
- package/lib-esm/CircleOcticon.d.ts +0 -1
- package/lib-esm/Dialog.d.ts +2 -3
- package/lib-esm/Dropdown.d.ts +0 -4
- package/lib-esm/DropdownMenu/DropdownButton.d.ts +1 -2
- package/lib-esm/FilterList.d.ts +0 -1
- package/lib-esm/Overlay.d.ts +3 -5
- package/lib-esm/Position.d.ts +4 -4
- package/lib-esm/SelectMenu/SelectMenu.d.ts +4 -10
- package/lib-esm/SelectMenu/SelectMenuItem.d.ts +1 -1
- package/lib-esm/SelectMenu/SelectMenuModal.d.ts +1 -1
- package/lib-esm/TextInputWithTokens.d.ts +0 -1
- package/lib-esm/Token/AvatarToken.d.ts +1 -1
- package/lib-esm/Token/IssueLabelToken.d.ts +1 -1
- package/lib-esm/Token/Token.d.ts +1 -1
- package/lib-esm/index.d.ts +0 -5
- package/lib-esm/index.js +0 -4
- package/lib-esm/theme-preval.js +0 -446
- package/lib-esm/utils/testing.d.ts +1 -2
- package/lib-esm/utils/testing.js +0 -24
- package/package.json +6 -5
- package/lib/Checkbox.d.ts +0 -29
- package/lib/Checkbox.js +0 -64
- package/lib/CheckboxInputField.d.ts +0 -11
- package/lib/CheckboxInputField.js +0 -74
- package/lib/RadioInputField.d.ts +0 -9
- package/lib/RadioInputField.js +0 -83
- package/lib/TextInputField.d.ts +0 -581
- package/lib/TextInputField.js +0 -66
- package/lib/_InputCaption.d.ts +0 -6
- package/lib/_InputCaption.js +0 -23
- package/lib/_InputField/InputField.d.ts +0 -39
- package/lib/_InputField/InputField.js +0 -90
- package/lib/_InputField/InputFieldCaption.d.ts +0 -3
- package/lib/_InputField/InputFieldCaption.js +0 -28
- package/lib/_InputField/InputFieldLabel.d.ts +0 -9
- package/lib/_InputField/InputFieldLabel.js +0 -34
- package/lib/_InputField/InputFieldValidation.d.ts +0 -6
- package/lib/_InputField/InputFieldValidation.js +0 -17
- package/lib/_InputField/ToggleInputField.d.ts +0 -13
- package/lib/_InputField/ToggleInputField.js +0 -71
- package/lib/_InputField/ToggleInputLeadingVisual.d.ts +0 -3
- package/lib/_InputField/ToggleInputLeadingVisual.js +0 -22
- package/lib/_InputField/ValidationAnimationContainer.d.ts +0 -6
- package/lib/_InputField/ValidationAnimationContainer.js +0 -48
- package/lib/_InputField/index.d.ts +0 -1
- package/lib/_InputField/index.js +0 -15
- package/lib/_InputField/slots.d.ts +0 -13
- package/lib/_InputField/slots.js +0 -17
- package/lib/_InputLabel.d.ts +0 -8
- package/lib/_InputLabel.js +0 -44
- package/lib/_InputValidation.d.ts +0 -8
- package/lib/_InputValidation.js +0 -56
- package/lib/_VisuallyHidden.d.ts +0 -6
- package/lib/_VisuallyHidden.js +0 -39
- package/lib/utils/types/FormValidationStatus.d.ts +0 -1
- package/lib/utils/types/FormValidationStatus.js +0 -1
- package/lib-esm/Checkbox.d.ts +0 -29
- package/lib-esm/Checkbox.js +0 -44
- package/lib-esm/CheckboxInputField.d.ts +0 -11
- package/lib-esm/CheckboxInputField.js +0 -57
- package/lib-esm/RadioInputField.d.ts +0 -9
- package/lib-esm/RadioInputField.js +0 -66
- package/lib-esm/TextInputField.d.ts +0 -581
- package/lib-esm/TextInputField.js +0 -50
- package/lib-esm/_InputCaption.d.ts +0 -6
- package/lib-esm/_InputCaption.js +0 -12
- package/lib-esm/_InputField/InputField.d.ts +0 -39
- package/lib-esm/_InputField/InputField.js +0 -70
- package/lib-esm/_InputField/InputFieldCaption.d.ts +0 -3
- package/lib-esm/_InputField/InputFieldCaption.js +0 -16
- package/lib-esm/_InputField/InputFieldLabel.d.ts +0 -9
- package/lib-esm/_InputField/InputFieldLabel.js +0 -22
- package/lib-esm/_InputField/InputFieldValidation.d.ts +0 -6
- package/lib-esm/_InputField/InputFieldValidation.js +0 -7
- package/lib-esm/_InputField/ToggleInputField.d.ts +0 -13
- package/lib-esm/_InputField/ToggleInputField.js +0 -54
- package/lib-esm/_InputField/ToggleInputLeadingVisual.d.ts +0 -3
- package/lib-esm/_InputField/ToggleInputLeadingVisual.js +0 -11
- package/lib-esm/_InputField/ValidationAnimationContainer.d.ts +0 -6
- package/lib-esm/_InputField/ValidationAnimationContainer.js +0 -33
- package/lib-esm/_InputField/index.d.ts +0 -1
- package/lib-esm/_InputField/index.js +0 -1
- package/lib-esm/_InputField/slots.d.ts +0 -13
- package/lib-esm/_InputField/slots.js +0 -5
- package/lib-esm/_InputLabel.d.ts +0 -8
- package/lib-esm/_InputLabel.js +0 -32
- package/lib-esm/_InputValidation.d.ts +0 -8
- package/lib-esm/_InputValidation.js +0 -43
- package/lib-esm/_VisuallyHidden.d.ts +0 -6
- package/lib-esm/_VisuallyHidden.js +0 -26
- package/lib-esm/utils/types/FormValidationStatus.d.ts +0 -1
- package/lib-esm/utils/types/FormValidationStatus.js +0 -1
@@ -0,0 +1,29 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
exports.Divider = exports.StyledDivider = void 0;
|
7
|
+
const react_1 = __importDefault(require("react"));
|
8
|
+
const styled_components_1 = __importDefault(require("styled-components"));
|
9
|
+
const constants_1 = require("../constants");
|
10
|
+
exports.StyledDivider = styled_components_1.default.div `
|
11
|
+
height: 1px;
|
12
|
+
background: ${constants_1.get('colors.border.muted')};
|
13
|
+
margin-top: calc(${constants_1.get('space.2')} - 1px);
|
14
|
+
margin-bottom: ${constants_1.get('space.2')};
|
15
|
+
`;
|
16
|
+
/**
|
17
|
+
* Visually separates `Item`s or `Group`s in an `ActionList`.
|
18
|
+
*/
|
19
|
+
function Divider() {
|
20
|
+
return <exports.StyledDivider />;
|
21
|
+
}
|
22
|
+
exports.Divider = Divider;
|
23
|
+
/**
|
24
|
+
* `Divider` fulfills the `ItemPropsWithCustomRenderer` contract,
|
25
|
+
* so it can be used inline in an `ActionList`’s `items` prop.
|
26
|
+
* In other words, `items={[ActionList.Divider]}` is supported as a concise
|
27
|
+
* alternative to `items={[{renderItem: () => <ActionList.Divider />}]}`.
|
28
|
+
*/
|
29
|
+
Divider.renderItem = Divider;
|
@@ -0,0 +1,23 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
exports.Group = void 0;
|
7
|
+
const react_1 = __importDefault(require("react"));
|
8
|
+
const styled_components_1 = __importDefault(require("styled-components"));
|
9
|
+
const sx_1 = __importDefault(require("../sx"));
|
10
|
+
const Header_1 = require("./Header");
|
11
|
+
const StyledGroup = styled_components_1.default.div `
|
12
|
+
${sx_1.default}
|
13
|
+
`;
|
14
|
+
/**
|
15
|
+
* Collects related `Items` in an `ActionList`.
|
16
|
+
*/
|
17
|
+
function Group({ header, items, ...props }) {
|
18
|
+
return (<StyledGroup {...props}>
|
19
|
+
{header && <Header_1.Header {...header}/>}
|
20
|
+
{items}
|
21
|
+
</StyledGroup>);
|
22
|
+
}
|
23
|
+
exports.Group = Group;
|
@@ -0,0 +1,66 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
5
|
+
}) : (function(o, m, k, k2) {
|
6
|
+
if (k2 === undefined) k2 = k;
|
7
|
+
o[k2] = m[k];
|
8
|
+
}));
|
9
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
10
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
11
|
+
}) : function(o, v) {
|
12
|
+
o["default"] = v;
|
13
|
+
});
|
14
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
15
|
+
if (mod && mod.__esModule) return mod;
|
16
|
+
var result = {};
|
17
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
18
|
+
__setModuleDefault(result, mod);
|
19
|
+
return result;
|
20
|
+
};
|
21
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
22
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
23
|
+
};
|
24
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
25
|
+
exports.Header = exports.StyledHeader = void 0;
|
26
|
+
const react_1 = __importDefault(require("react"));
|
27
|
+
const styled_components_1 = __importStar(require("styled-components"));
|
28
|
+
const constants_1 = require("../constants");
|
29
|
+
const sx_1 = __importDefault(require("../sx"));
|
30
|
+
exports.StyledHeader = styled_components_1.default.div `
|
31
|
+
{
|
32
|
+
/* 6px vertical padding + 20px line height = 32px total height
|
33
|
+
*
|
34
|
+
* TODO: When rem-based spacing on a 4px scale lands, replace
|
35
|
+
* hardcoded '6px' with 'calc((${constants_1.get('space.s32')} - ${constants_1.get('space.20')}) / 2)'.
|
36
|
+
*/
|
37
|
+
}
|
38
|
+
padding: 6px ${constants_1.get('space.3')};
|
39
|
+
font-size: ${constants_1.get('fontSizes.0')};
|
40
|
+
font-weight: ${constants_1.get('fontWeights.bold')};
|
41
|
+
color: ${constants_1.get('colors.fg.muted')};
|
42
|
+
|
43
|
+
${({ variant }) => variant === 'filled' &&
|
44
|
+
styled_components_1.css `
|
45
|
+
background: ${constants_1.get('colors.canvas.subtle')};
|
46
|
+
margin: ${constants_1.get('space.2')} 0;
|
47
|
+
border-top: 1px solid ${constants_1.get('colors.neutral.muted')};
|
48
|
+
border-bottom: 1px solid ${constants_1.get('colors.neutral.muted')};
|
49
|
+
|
50
|
+
&:first-child {
|
51
|
+
margin-top: 0;
|
52
|
+
}
|
53
|
+
`}
|
54
|
+
|
55
|
+
${sx_1.default}
|
56
|
+
`;
|
57
|
+
/**
|
58
|
+
* Displays the name and description of a `Group`.
|
59
|
+
*/
|
60
|
+
function Header({ variant = 'subtle', title, auxiliaryText, children: _children, ...props }) {
|
61
|
+
return (<exports.StyledHeader role="heading" variant={variant} {...props}>
|
62
|
+
{title}
|
63
|
+
{auxiliaryText && <span>{auxiliaryText}</span>}
|
64
|
+
</exports.StyledHeader>);
|
65
|
+
}
|
66
|
+
exports.Header = Header;
|
package/lib/ActionList/Item.js
CHANGED
@@ -122,7 +122,7 @@ exports.TextContainer = TextContainer;
|
|
122
122
|
const BaseVisualContainer = _styledComponents.default.div.withConfig({
|
123
123
|
displayName: "Item__BaseVisualContainer",
|
124
124
|
componentId: "jqpvy8-4"
|
125
|
-
})(["height:20px;width:", ";margin-right:", ";display:flex;justify-content:center;align-items:center;
|
125
|
+
})(["height:20px;width:", ";margin-right:", ";display:flex;justify-content:center;align-items:center;"], (0, _constants.get)('space.3'), (0, _constants.get)('space.2'));
|
126
126
|
|
127
127
|
const ColoredVisualContainer = (0, _styledComponents.default)(BaseVisualContainer).withConfig({
|
128
128
|
displayName: "Item__ColoredVisualContainer",
|
@@ -134,7 +134,7 @@ const ColoredVisualContainer = (0, _styledComponents.default)(BaseVisualContaine
|
|
134
134
|
const LeadingVisualContainer = (0, _styledComponents.default)(ColoredVisualContainer).withConfig({
|
135
135
|
displayName: "Item__LeadingVisualContainer",
|
136
136
|
componentId: "jqpvy8-6"
|
137
|
-
})(["display:flex;flex-direction:column;justify-content:center;"]);
|
137
|
+
})(["flex-shrink:0;display:flex;flex-direction:column;justify-content:center;"]);
|
138
138
|
const TrailingContent = (0, _styledComponents.default)(ColoredVisualContainer).withConfig({
|
139
139
|
displayName: "Item__TrailingContent",
|
140
140
|
componentId: "jqpvy8-7"
|
@@ -151,7 +151,7 @@ const DescriptionContainer = _styledComponents.default.span.withConfig({
|
|
151
151
|
const MultiSelectIcon = _styledComponents.default.svg.withConfig({
|
152
152
|
displayName: "Item__MultiSelectIcon",
|
153
153
|
componentId: "jqpvy8-9"
|
154
|
-
})(["rect{fill:", ";stroke:", ";
|
154
|
+
})(["rect{fill:", ";stroke:", ";}path{fill:", ";boxshadow:", ";opacity:", ";}"], ({
|
155
155
|
selected
|
156
156
|
}) => selected ? (0, _constants.get)('colors.accent.fg') : (0, _constants.get)('colors.canvas.default'), ({
|
157
157
|
selected
|
@@ -0,0 +1,288 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
5
|
+
}) : (function(o, m, k, k2) {
|
6
|
+
if (k2 === undefined) k2 = k;
|
7
|
+
o[k2] = m[k];
|
8
|
+
}));
|
9
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
10
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
11
|
+
}) : function(o, v) {
|
12
|
+
o["default"] = v;
|
13
|
+
});
|
14
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
15
|
+
if (mod && mod.__esModule) return mod;
|
16
|
+
var result = {};
|
17
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
18
|
+
__setModuleDefault(result, mod);
|
19
|
+
return result;
|
20
|
+
};
|
21
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
22
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
23
|
+
};
|
24
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
25
|
+
exports.Item = exports.TextContainer = void 0;
|
26
|
+
const octicons_react_1 = require("@primer/octicons-react");
|
27
|
+
const react_1 = __importStar(require("react"));
|
28
|
+
const constants_1 = require("../constants");
|
29
|
+
const sx_1 = __importDefault(require("../sx"));
|
30
|
+
const Truncate_1 = __importDefault(require("../Truncate"));
|
31
|
+
const styled_components_1 = __importDefault(require("styled-components"));
|
32
|
+
const Header_1 = require("./Header");
|
33
|
+
const Divider_1 = require("./Divider");
|
34
|
+
const ThemeProvider_1 = require("../ThemeProvider");
|
35
|
+
const focusZone_1 = require("../behaviors/focusZone");
|
36
|
+
const ssr_1 = require("@react-aria/ssr");
|
37
|
+
const getItemVariant = (variant = 'default', disabled) => {
|
38
|
+
if (disabled) {
|
39
|
+
return {
|
40
|
+
color: constants_1.get('colors.primer.fg.disabled'),
|
41
|
+
iconColor: constants_1.get('colors.primer.fg.disabled'),
|
42
|
+
annotationColor: constants_1.get('colors.primer.fg.disabled'),
|
43
|
+
hoverCursor: 'default'
|
44
|
+
};
|
45
|
+
}
|
46
|
+
switch (variant) {
|
47
|
+
case 'danger':
|
48
|
+
return {
|
49
|
+
color: constants_1.get('colors.danger.fg'),
|
50
|
+
iconColor: constants_1.get('colors.danger.fg'),
|
51
|
+
annotationColor: constants_1.get('colors.fg.muted'),
|
52
|
+
hoverCursor: 'pointer',
|
53
|
+
hoverBg: constants_1.get('colors.actionListItem.danger.hoverBg'),
|
54
|
+
focusBg: constants_1.get('colors.actionListItem.danger.activeBg'),
|
55
|
+
hoverText: constants_1.get('colors.actionListItem.danger.hoverText')
|
56
|
+
};
|
57
|
+
default:
|
58
|
+
return {
|
59
|
+
color: constants_1.get('colors.fg.default'),
|
60
|
+
iconColor: constants_1.get('colors.fg.muted'),
|
61
|
+
annotationColor: constants_1.get('colors.fg.muted'),
|
62
|
+
hoverCursor: 'pointer',
|
63
|
+
hoverBg: constants_1.get('colors.actionListItem.default.hoverBg'),
|
64
|
+
focusBg: constants_1.get('colors.actionListItem.default.activeBg')
|
65
|
+
};
|
66
|
+
}
|
67
|
+
};
|
68
|
+
const DividedContent = styled_components_1.default.div `
|
69
|
+
display: flex;
|
70
|
+
min-width: 0;
|
71
|
+
|
72
|
+
/* Required for dividers */
|
73
|
+
position: relative;
|
74
|
+
flex-grow: 1;
|
75
|
+
`;
|
76
|
+
const MainContent = styled_components_1.default.div `
|
77
|
+
align-items: baseline;
|
78
|
+
display: flex;
|
79
|
+
min-width: 0;
|
80
|
+
flex-direction: var(--main-content-flex-direction);
|
81
|
+
flex-grow: 1;
|
82
|
+
`;
|
83
|
+
const StyledItem = styled_components_1.default.div `
|
84
|
+
/* 6px vertical padding + 20px line height = 32px total height
|
85
|
+
*
|
86
|
+
* TODO: When rem-based spacing on a 4px scale lands, replace
|
87
|
+
* hardcoded '6px' with 'calc((${constants_1.get('space.s32')} - ${constants_1.get('space.20')}) / 2)'.
|
88
|
+
*/
|
89
|
+
padding: 6px ${constants_1.get('space.2')};
|
90
|
+
display: flex;
|
91
|
+
border-radius: ${constants_1.get('radii.2')};
|
92
|
+
color: ${({ variant, item }) => getItemVariant(variant, item?.disabled).color};
|
93
|
+
// 2 frames on a 60hz monitor
|
94
|
+
transition: background 33.333ms linear;
|
95
|
+
text-decoration: none;
|
96
|
+
|
97
|
+
@media (hover: hover) and (pointer: fine) {
|
98
|
+
:hover {
|
99
|
+
// allow override in case another item in the list is active/focused
|
100
|
+
background: var(
|
101
|
+
--item-hover-bg-override,
|
102
|
+
${({ variant, item }) => getItemVariant(variant, item?.disabled).hoverBg}
|
103
|
+
);
|
104
|
+
color: ${({ variant, item }) => getItemVariant(variant, item?.disabled).hoverText};
|
105
|
+
cursor: ${({ variant, item }) => getItemVariant(variant, item?.disabled).hoverCursor};
|
106
|
+
}
|
107
|
+
}
|
108
|
+
|
109
|
+
// Item dividers
|
110
|
+
:not(:first-of-type):not(${Divider_1.StyledDivider} + &):not(${Header_1.StyledHeader} + &) {
|
111
|
+
margin-top: ${({ showDivider }) => (showDivider ? `1px` : '0')};
|
112
|
+
|
113
|
+
${DividedContent}::before {
|
114
|
+
content: ' ';
|
115
|
+
display: block;
|
116
|
+
position: absolute;
|
117
|
+
width: 100%;
|
118
|
+
top: -7px;
|
119
|
+
// NB: This 'get' won’t execute if it’s moved into the arrow function below.
|
120
|
+
border: 0 solid ${constants_1.get('colors.border.muted')};
|
121
|
+
border-top-width: ${({ showDivider }) => (showDivider ? `1px` : '0')};
|
122
|
+
}
|
123
|
+
}
|
124
|
+
|
125
|
+
// Item dividers should not be visible:
|
126
|
+
// - above Hovered
|
127
|
+
&:hover ${DividedContent}::before,
|
128
|
+
// - below Hovered
|
129
|
+
// '*' instead of '&' because '&' maps to separate class names depending on 'variant'
|
130
|
+
:hover + * ${DividedContent}::before {
|
131
|
+
// allow override in case another item in the list is active/focused
|
132
|
+
border-color: var(--item-hover-divider-border-color-override, transparent) !important;
|
133
|
+
}
|
134
|
+
|
135
|
+
// - above Focused
|
136
|
+
&:focus ${DividedContent}::before,
|
137
|
+
// - below Focused
|
138
|
+
// '*' instead of '&' because '&' maps to separate class names depending on 'variant'
|
139
|
+
:focus + * ${DividedContent}::before,
|
140
|
+
// - above Active Descendent
|
141
|
+
&[${focusZone_1.isActiveDescendantAttribute}] ${DividedContent}::before,
|
142
|
+
// - below Active Descendent
|
143
|
+
[${focusZone_1.isActiveDescendantAttribute}] + & ${DividedContent}::before {
|
144
|
+
// '!important' because all the ':not's above give higher specificity
|
145
|
+
border-color: transparent !important;
|
146
|
+
}
|
147
|
+
|
148
|
+
// Active Descendant
|
149
|
+
&[${focusZone_1.isActiveDescendantAttribute}='${focusZone_1.activeDescendantActivatedDirectly}'] {
|
150
|
+
background: ${({ variant, item }) => getItemVariant(variant, item?.disabled).focusBg};
|
151
|
+
}
|
152
|
+
&[${focusZone_1.isActiveDescendantAttribute}='${focusZone_1.activeDescendantActivatedIndirectly}'] {
|
153
|
+
background: ${({ variant, item }) => getItemVariant(variant, item?.disabled).hoverBg};
|
154
|
+
}
|
155
|
+
|
156
|
+
&:focus {
|
157
|
+
background: ${({ variant, item }) => getItemVariant(variant, item?.disabled).focusBg};
|
158
|
+
outline: none;
|
159
|
+
}
|
160
|
+
|
161
|
+
&:active {
|
162
|
+
background: ${({ variant, item }) => getItemVariant(variant, item?.disabled).focusBg};
|
163
|
+
}
|
164
|
+
|
165
|
+
${sx_1.default}
|
166
|
+
`;
|
167
|
+
exports.TextContainer = styled_components_1.default.span ``;
|
168
|
+
const BaseVisualContainer = styled_components_1.default.div `
|
169
|
+
// Match visual height to adjacent text line height.
|
170
|
+
// TODO: When rem-based spacing on a 4px scale lands, replace
|
171
|
+
// hardcoded '20px' with '${constants_1.get('space.s20')}'.
|
172
|
+
height: 20px;
|
173
|
+
width: ${constants_1.get('space.3')};
|
174
|
+
margin-right: ${constants_1.get('space.2')};
|
175
|
+
display: flex;
|
176
|
+
justify-content: center;
|
177
|
+
align-items: center;
|
178
|
+
`;
|
179
|
+
const ColoredVisualContainer = styled_components_1.default(BaseVisualContainer) `
|
180
|
+
svg {
|
181
|
+
fill: ${({ variant, disabled }) => getItemVariant(variant, disabled).iconColor};
|
182
|
+
font-size: ${constants_1.get('fontSizes.0')};
|
183
|
+
}
|
184
|
+
`;
|
185
|
+
const LeadingVisualContainer = styled_components_1.default(ColoredVisualContainer) `
|
186
|
+
flex-shrink: 0;
|
187
|
+
display: flex;
|
188
|
+
flex-direction: column;
|
189
|
+
justify-content: center;
|
190
|
+
`;
|
191
|
+
const TrailingContent = styled_components_1.default(ColoredVisualContainer) `
|
192
|
+
color: ${({ variant, disabled }) => getItemVariant(variant, disabled).annotationColor}};
|
193
|
+
margin-left: ${constants_1.get('space.2')};
|
194
|
+
margin-right: 0;
|
195
|
+
width: auto;
|
196
|
+
div:nth-child(2) {
|
197
|
+
margin-left: ${constants_1.get('space.2')};
|
198
|
+
}
|
199
|
+
`;
|
200
|
+
const DescriptionContainer = styled_components_1.default.span `
|
201
|
+
color: ${constants_1.get('colors.fg.muted')};
|
202
|
+
font-size: ${constants_1.get('fontSizes.0')};
|
203
|
+
// TODO: When rem-based spacing on a 4px scale lands, replace
|
204
|
+
// hardcoded '16px' with '${constants_1.get('lh-12')}'.
|
205
|
+
line-height: 16px;
|
206
|
+
margin-left: var(--description-container-margin-left);
|
207
|
+
min-width: 0;
|
208
|
+
flex-grow: 1;
|
209
|
+
flex-basis: var(--description-container-flex-basis);
|
210
|
+
`;
|
211
|
+
const MultiSelectIcon = styled_components_1.default.svg `
|
212
|
+
rect {
|
213
|
+
fill: ${({ selected }) => (selected ? constants_1.get('colors.accent.fg') : constants_1.get('colors.canvas.default'))};
|
214
|
+
stroke: ${({ selected }) => (selected ? constants_1.get('colors.accent.fg') : constants_1.get('colors.border.default'))};
|
215
|
+
}
|
216
|
+
path {
|
217
|
+
fill: ${constants_1.get('colors.fg.onEmphasis')};
|
218
|
+
boxshadow: ${constants_1.get('shadow.small')};
|
219
|
+
opacity: ${({ selected }) => (selected ? 1 : 0)};
|
220
|
+
}
|
221
|
+
`;
|
222
|
+
/**
|
223
|
+
* An actionable or selectable `Item` with an optional icon and description.
|
224
|
+
*/
|
225
|
+
exports.Item = react_1.default.forwardRef((itemProps, ref) => {
|
226
|
+
const { as: Component, text, description, descriptionVariant = 'inline', selected, selectionVariant, leadingVisual: LeadingVisual, trailingIcon: TrailingIcon, trailingVisual: TrailingVisual, trailingText, variant = 'default', showDivider, disabled, onAction, onKeyPress, children, onClick, id, ...props } = itemProps;
|
227
|
+
const labelId = ssr_1.useSSRSafeId();
|
228
|
+
const descriptionId = ssr_1.useSSRSafeId();
|
229
|
+
const keyPressHandler = react_1.useCallback(event => {
|
230
|
+
if (disabled) {
|
231
|
+
return;
|
232
|
+
}
|
233
|
+
onKeyPress?.(event);
|
234
|
+
if (!event.defaultPrevented && [' ', 'Enter'].includes(event.key)) {
|
235
|
+
onAction?.(itemProps, event);
|
236
|
+
}
|
237
|
+
}, [onAction, disabled, itemProps, onKeyPress]);
|
238
|
+
const clickHandler = react_1.useCallback(event => {
|
239
|
+
if (disabled) {
|
240
|
+
return;
|
241
|
+
}
|
242
|
+
onClick?.(event);
|
243
|
+
if (!event.defaultPrevented) {
|
244
|
+
onAction?.(itemProps, event);
|
245
|
+
}
|
246
|
+
}, [onAction, disabled, itemProps, onClick]);
|
247
|
+
const { theme } = ThemeProvider_1.useTheme();
|
248
|
+
return (<StyledItem ref={ref} as={Component} tabIndex={disabled ? undefined : -1} variant={variant} showDivider={showDivider} aria-selected={selected} aria-labelledby={text ? labelId : undefined} aria-describedby={description ? descriptionId : undefined} {...props} data-id={id} onKeyPress={keyPressHandler} onClick={clickHandler}>
|
249
|
+
{!!selected === selected && (<BaseVisualContainer>
|
250
|
+
{selectionVariant === 'multiple' ? (<>
|
251
|
+
{/**
|
252
|
+
* we use a svg instead of an input because there should not
|
253
|
+
* be an interactive element inside an option
|
254
|
+
* svg copied from primer/css
|
255
|
+
*/}
|
256
|
+
<MultiSelectIcon selected={selected} width="16" height="16" viewBox="0 0 16 16" xmlns="http://www.w3.org/2000/svg" aria-hidden="true">
|
257
|
+
<rect x="2" y="2" width="12" height="12" rx="4"></rect>
|
258
|
+
<path fillRule="evenodd" strokeWidth="0" d="M4.03231 8.69862C3.84775 8.20646 4.49385 7.77554 4.95539 7.77554C5.41693 7.77554 6.80154 9.85246 6.80154 9.85246C6.80154 9.85246 10.2631 4.314 10.4938 4.08323C10.7246 3.85246 11.8785 4.08323 11.4169 5.00631C11.0081 5.82388 7.26308 11.4678 7.26308 11.4678C7.26308 11.4678 6.80154 12.1602 6.34 11.4678C5.87846 10.7755 4.21687 9.19077 4.03231 8.69862Z"/>
|
259
|
+
</MultiSelectIcon>
|
260
|
+
</>) : (selected && <octicons_react_1.CheckIcon fill={theme?.colors.fg.default}/>)}
|
261
|
+
</BaseVisualContainer>)}
|
262
|
+
{LeadingVisual && (<LeadingVisualContainer variant={variant} disabled={disabled}>
|
263
|
+
<LeadingVisual />
|
264
|
+
</LeadingVisualContainer>)}
|
265
|
+
<DividedContent>
|
266
|
+
<MainContent style={{ '--main-content-flex-direction': descriptionVariant === 'inline' ? 'row' : 'column' }}>
|
267
|
+
{children}
|
268
|
+
{text ? <exports.TextContainer id={labelId}>{text}</exports.TextContainer> : null}
|
269
|
+
{description ? (<DescriptionContainer id={descriptionId} style={{
|
270
|
+
'--description-container-margin-left': descriptionVariant === 'inline' ? constants_1.get('space.2')(theme) : 0,
|
271
|
+
'--description-container-flex-basis': descriptionVariant === 'inline' ? 0 : 'auto'
|
272
|
+
}}>
|
273
|
+
{descriptionVariant === 'block' ? (description) : (<Truncate_1.default title={description} inline={true} maxWidth="100%">
|
274
|
+
{description}
|
275
|
+
</Truncate_1.default>)}
|
276
|
+
</DescriptionContainer>) : null}
|
277
|
+
</MainContent>
|
278
|
+
{/* backward compatibility: prefer TrailingVisual but fallback to TrailingIcon */}
|
279
|
+
{TrailingVisual ? (<TrailingContent variant={variant} disabled={disabled}>
|
280
|
+
{typeof TrailingVisual === 'function' ? <TrailingVisual /> : TrailingVisual}
|
281
|
+
</TrailingContent>) : TrailingIcon || trailingText ? (<TrailingContent variant={variant} disabled={disabled}>
|
282
|
+
{trailingText}
|
283
|
+
{TrailingIcon && <TrailingIcon />}
|
284
|
+
</TrailingContent>) : null}
|
285
|
+
</DividedContent>
|
286
|
+
</StyledItem>);
|
287
|
+
});
|
288
|
+
exports.Item.displayName = 'ActionList.Item';
|
@@ -0,0 +1,138 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
exports.List = void 0;
|
7
|
+
const react_1 = __importDefault(require("react"));
|
8
|
+
const Group_1 = require("./Group");
|
9
|
+
const Item_1 = require("./Item");
|
10
|
+
const Divider_1 = require("./Divider");
|
11
|
+
const styled_components_1 = __importDefault(require("styled-components"));
|
12
|
+
const constants_1 = require("../constants");
|
13
|
+
const focusZone_1 = require("../behaviors/focusZone");
|
14
|
+
/**
|
15
|
+
* Asserts that the given value fulfills the `GroupedListProps` contract.
|
16
|
+
* @param props A value which fulfills either the `ListPropsBase` or the `GroupedListProps` contract.
|
17
|
+
*/
|
18
|
+
function isGroupedListProps(props) {
|
19
|
+
return 'groupMetadata' in props;
|
20
|
+
}
|
21
|
+
const StyledList = styled_components_1.default.div `
|
22
|
+
font-size: ${constants_1.get('fontSizes.1')};
|
23
|
+
/* 14px font-size * 1.428571429 = 20px line height
|
24
|
+
*
|
25
|
+
* TODO: When rem-based spacing on a 4px scale lands, replace
|
26
|
+
* hardcoded '20px'
|
27
|
+
*/
|
28
|
+
line-height: 20px;
|
29
|
+
|
30
|
+
&[${focusZone_1.hasActiveDescendantAttribute}], &:focus-within {
|
31
|
+
--item-hover-bg-override: none;
|
32
|
+
--item-hover-divider-border-color-override: ${constants_1.get('colors.border.muted')};
|
33
|
+
}
|
34
|
+
`;
|
35
|
+
/**
|
36
|
+
* Returns `sx` prop values for `List` children matching the given `List` style variation.
|
37
|
+
* @param variant `List` style variation.
|
38
|
+
*/
|
39
|
+
function useListVariant(variant = 'inset') {
|
40
|
+
switch (variant) {
|
41
|
+
case 'full':
|
42
|
+
return {
|
43
|
+
headerStyle: { paddingX: constants_1.get('space.2') },
|
44
|
+
itemStyle: { borderRadius: 0 }
|
45
|
+
};
|
46
|
+
default:
|
47
|
+
return {
|
48
|
+
firstGroupStyle: { marginTop: constants_1.get('space.2') },
|
49
|
+
lastGroupStyle: { marginBottom: constants_1.get('space.2') },
|
50
|
+
itemStyle: { marginX: constants_1.get('space.2') }
|
51
|
+
};
|
52
|
+
}
|
53
|
+
}
|
54
|
+
/**
|
55
|
+
* Lists `Item`s, either grouped or ungrouped, with a `Divider` between each `Group`.
|
56
|
+
*/
|
57
|
+
exports.List = react_1.default.forwardRef((props, forwardedRef) => {
|
58
|
+
// Get `sx` prop values for `List` children matching the given `List` style variation.
|
59
|
+
const { firstGroupStyle, lastGroupStyle, headerStyle, itemStyle } = useListVariant(props.variant);
|
60
|
+
/**
|
61
|
+
* Render a `Group` using the first of the following renderers that is defined:
|
62
|
+
* A `Group`-level or `List`-level custom `Group` renderer, or
|
63
|
+
* the default `Group` renderer.
|
64
|
+
*/
|
65
|
+
const renderGroup = (groupProps) => {
|
66
|
+
const GroupComponent = (('renderGroup' in groupProps && groupProps.renderGroup) ?? props.renderGroup) || Group_1.Group;
|
67
|
+
return <GroupComponent {...groupProps} key={groupProps.groupId}/>;
|
68
|
+
};
|
69
|
+
/**
|
70
|
+
* Render an `Item` using the first of the following renderers that is defined:
|
71
|
+
* An `Item`-level, `Group`-level, or `List`-level custom `Item` renderer,
|
72
|
+
* or the default `Item` renderer.
|
73
|
+
*/
|
74
|
+
const renderItem = (itemProps, item, itemIndex) => {
|
75
|
+
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
|
76
|
+
const ItemComponent = ('renderItem' in itemProps && itemProps.renderItem) || props.renderItem || Item_1.Item;
|
77
|
+
const key = ('key' in itemProps ? itemProps.key : undefined) ?? itemProps.id?.toString() ?? itemIndex.toString();
|
78
|
+
return (<ItemComponent showDivider={props.showItemDividers} selectionVariant={props.selectionVariant} {...itemProps} key={key} sx={{ ...itemStyle, ...itemProps.sx }} item={item}/>);
|
79
|
+
};
|
80
|
+
/**
|
81
|
+
* An array of `Group`s, each with an associated `Header` and with an array of `Item`s belonging to that `Group`.
|
82
|
+
*/
|
83
|
+
let groups = [];
|
84
|
+
// Collect rendered `Item`s into `Group`s, avoiding excess iteration over the lists of `items` and `groupMetadata`:
|
85
|
+
if (!isGroupedListProps(props)) {
|
86
|
+
// When no `groupMetadata`s is provided, collect rendered `Item`s into a single anonymous `Group`.
|
87
|
+
groups = [{ items: props.items.map((item, index) => renderItem(item, item, index)), groupId: '0' }];
|
88
|
+
}
|
89
|
+
else {
|
90
|
+
// When `groupMetadata` is provided, collect rendered `Item`s into their associated `Group`s.
|
91
|
+
/**
|
92
|
+
* A map of group identifiers to `Group`s, each with an associated array of `Item`s belonging to that `Group`.
|
93
|
+
*/
|
94
|
+
const groupMap = props.groupMetadata.reduce((groupAccumulator, groupMetadata) => groupAccumulator.set(groupMetadata.groupId, groupMetadata), new Map());
|
95
|
+
for (const itemProps of props.items) {
|
96
|
+
// Look up the group associated with the current item.
|
97
|
+
const group = groupMap.get(itemProps.groupId);
|
98
|
+
const itemIndex = group?.items?.length ?? 0;
|
99
|
+
// Upsert the group to include the current item (rendered).
|
100
|
+
groupMap.set(itemProps.groupId, {
|
101
|
+
...group,
|
102
|
+
items: [
|
103
|
+
...(group?.items ?? []),
|
104
|
+
renderItem({
|
105
|
+
showDivider: group?.showItemDividers,
|
106
|
+
...(group && 'renderItem' in group && { renderItem: group.renderItem }),
|
107
|
+
...itemProps
|
108
|
+
}, itemProps, itemIndex)
|
109
|
+
]
|
110
|
+
});
|
111
|
+
}
|
112
|
+
groups = [...groupMap.values()];
|
113
|
+
}
|
114
|
+
return (<StyledList {...props} ref={forwardedRef}>
|
115
|
+
{groups.map(({ header, ...groupProps }, index) => {
|
116
|
+
const hasFilledHeader = header?.variant === 'filled';
|
117
|
+
const shouldShowDivider = index > 0 && !hasFilledHeader;
|
118
|
+
return (<react_1.default.Fragment key={groupProps.groupId}>
|
119
|
+
{shouldShowDivider ? <Divider_1.Divider key={`${groupProps.groupId}-divider`}/> : null}
|
120
|
+
{renderGroup({
|
121
|
+
sx: {
|
122
|
+
...(index === 0 && firstGroupStyle),
|
123
|
+
...(index === groups.length - 1 && lastGroupStyle),
|
124
|
+
...(index > 0 && !shouldShowDivider && { mt: 2 })
|
125
|
+
},
|
126
|
+
...(header && {
|
127
|
+
header: {
|
128
|
+
...header,
|
129
|
+
sx: { ...headerStyle, ...header.sx }
|
130
|
+
}
|
131
|
+
}),
|
132
|
+
...groupProps
|
133
|
+
})}
|
134
|
+
</react_1.default.Fragment>);
|
135
|
+
})}
|
136
|
+
</StyledList>);
|
137
|
+
});
|
138
|
+
exports.List.displayName = 'ActionList';
|
package/lib/ActionList/index.js
CHANGED
@@ -1,29 +1,18 @@
|
|
1
1
|
"use strict";
|
2
|
-
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
4
|
-
value: true
|
5
|
-
});
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
3
|
exports.ActionList = void 0;
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
var _Item = require("./Item");
|
13
|
-
|
14
|
-
var _Divider = require("./Divider");
|
15
|
-
|
4
|
+
const List_1 = require("./List");
|
5
|
+
const Group_1 = require("./Group");
|
6
|
+
const Item_1 = require("./Item");
|
7
|
+
const Divider_1 = require("./Divider");
|
16
8
|
/**
|
17
9
|
* Collection of list-related components.
|
18
10
|
*/
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
/** Visually separates `Item`s or `Group`s in an `ActionList`. */
|
27
|
-
Divider: _Divider.Divider
|
11
|
+
exports.ActionList = Object.assign(List_1.List, {
|
12
|
+
/** Collects related `Items` in an `ActionList`. */
|
13
|
+
Group: Group_1.Group,
|
14
|
+
/** An actionable or selectable `Item` with an optional icon and description. */
|
15
|
+
Item: Item_1.Item,
|
16
|
+
/** Visually separates `Item`s or `Group`s in an `ActionList`. */
|
17
|
+
Divider: Divider_1.Divider
|
28
18
|
});
|
29
|
-
exports.ActionList = ActionList;
|
@@ -0,0 +1,29 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
exports.Description = void 0;
|
7
|
+
const react_1 = __importDefault(require("react"));
|
8
|
+
const Box_1 = __importDefault(require("../Box"));
|
9
|
+
const sx_1 = require("../sx");
|
10
|
+
const Truncate_1 = __importDefault(require("../Truncate"));
|
11
|
+
const Item_1 = require("./Item");
|
12
|
+
const Description = ({ variant = 'inline', sx = {}, ...props }) => {
|
13
|
+
const styles = {
|
14
|
+
fontSize: 0,
|
15
|
+
lineHeight: '16px',
|
16
|
+
flexGrow: 1,
|
17
|
+
flexBasis: 0,
|
18
|
+
minWidth: 0,
|
19
|
+
marginLeft: variant === 'block' ? 0 : 2
|
20
|
+
};
|
21
|
+
return (<Item_1.Slot name={variant === 'block' ? 'BlockDescription' : 'InlineDescription'}>
|
22
|
+
{({ blockDescriptionId, inlineDescriptionId, disabled }) => variant === 'block' ? (<Box_1.default as="span" sx={sx_1.merge({ ...styles, color: disabled ? 'fg.disabled' : 'fg.muted' }, sx)} id={blockDescriptionId}>
|
23
|
+
{props.children}
|
24
|
+
</Box_1.default>) : (<Truncate_1.default id={inlineDescriptionId} sx={sx_1.merge({ ...styles, color: disabled ? 'fg.disabled' : 'fg.muted' }, sx)} title={props.children} inline={true} maxWidth="100%">
|
25
|
+
{props.children}
|
26
|
+
</Truncate_1.default>)}
|
27
|
+
</Item_1.Slot>);
|
28
|
+
};
|
29
|
+
exports.Description = Description;
|
@@ -0,0 +1,22 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
exports.Divider = void 0;
|
7
|
+
const react_1 = __importDefault(require("react"));
|
8
|
+
const Box_1 = __importDefault(require("../Box"));
|
9
|
+
const constants_1 = require("../constants");
|
10
|
+
/**
|
11
|
+
* Visually separates `Item`s or `Group`s in an `ActionList`.
|
12
|
+
*/
|
13
|
+
function Divider() {
|
14
|
+
return (<Box_1.default as="li" role="separator" sx={{
|
15
|
+
height: 1,
|
16
|
+
backgroundColor: 'actionListItem.inlineDivider',
|
17
|
+
marginTop: (theme) => `calc(${constants_1.get('space.2')(theme)} - 1px)`,
|
18
|
+
marginBottom: 2,
|
19
|
+
listStyle: 'none' // hide the ::marker inserted by browser's stylesheet
|
20
|
+
}} data-component="ActionList.Divider"/>);
|
21
|
+
}
|
22
|
+
exports.Divider = Divider;
|