@primer/components 0.0.0-20211030175556 → 0.0.0-20211030182910
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 +34 -2
- package/dist/browser.esm.js +186 -183
- package/dist/browser.esm.js.map +1 -1
- package/dist/browser.umd.js +190 -187
- package/dist/browser.umd.js.map +1 -1
- package/lib/ActionList/Item.js +3 -3
- package/lib/ActionList/index.js +23 -12
- package/lib/ActionList2/Item.js +3 -1
- package/lib/ActionList2/List.js +1 -2
- package/lib/ActionList2/Selection.js +3 -1
- package/lib/ActionList2/index.js +41 -23
- package/lib/AnchoredOverlay/index.js +12 -4
- package/lib/Autocomplete/Autocomplete.d.ts +1 -0
- package/lib/Autocomplete/AutocompleteInput.d.ts +1 -0
- package/lib/Autocomplete/index.js +14 -7
- package/lib/Avatar.d.ts +1 -2
- package/lib/Avatar.js +1 -1
- package/lib/BranchName.d.ts +1 -2
- package/lib/BranchName.js +1 -1
- package/lib/Button/Button.d.ts +1 -0
- package/lib/Button/ButtonClose.d.ts +2 -1
- package/lib/Button/ButtonDanger.d.ts +1 -0
- package/lib/Button/ButtonInvisible.d.ts +1 -0
- package/lib/Button/ButtonOutline.d.ts +1 -0
- package/lib/Button/ButtonPrimary.d.ts +1 -0
- package/lib/Button/index.js +70 -21
- package/lib/Checkbox.d.ts +29 -0
- package/lib/Checkbox.js +64 -0
- package/lib/CircleOcticon.d.ts +1 -0
- package/lib/Details.d.ts +1 -2
- package/lib/Details.js +1 -3
- package/lib/Dialog.d.ts +3 -2
- package/lib/Dropdown.d.ts +6 -66
- package/lib/DropdownMenu/DropdownButton.d.ts +2 -1
- package/lib/DropdownMenu/index.js +20 -6
- package/lib/DropdownStyles.js +26 -18
- package/lib/FilterList.d.ts +1 -0
- package/lib/FilteredActionList/index.js +12 -4
- package/lib/Heading.d.ts +1 -2
- package/lib/Heading.js +1 -6
- package/lib/NewButton/index.js +12 -5
- package/lib/NewButton/types.js +1 -2
- package/lib/Overlay.d.ts +5 -3
- package/lib/Pagination/index.js +12 -6
- package/lib/Portal/index.js +16 -5
- package/lib/Position.d.ts +4 -4
- package/lib/ProgressBar.d.ts +16 -11
- package/lib/ProgressBar.js +6 -10
- package/lib/SelectMenu/SelectMenu.d.ts +10 -4
- package/lib/SelectMenu/SelectMenuItem.d.ts +1 -1
- package/lib/SelectMenu/SelectMenuModal.d.ts +1 -1
- package/lib/SelectMenu/hooks/useKeyboardNav.js +96 -80
- package/lib/SelectMenu/index.js +14 -7
- package/lib/SelectPanel/index.js +12 -4
- package/lib/Spinner.d.ts +1 -2
- package/lib/Spinner.js +1 -3
- package/lib/TextInputWithTokens.d.ts +1 -0
- package/lib/Token/AvatarToken.d.ts +1 -1
- package/lib/Token/IssueLabelToken.d.ts +1 -1
- package/lib/Token/Token.d.ts +1 -1
- package/lib/Token/index.js +30 -11
- package/lib/behaviors/anchoredPosition.js +234 -205
- package/lib/behaviors/focusTrap.js +157 -121
- package/lib/behaviors/focusZone.js +509 -434
- package/lib/behaviors/scrollIntoViewingArea.js +35 -18
- package/lib/constants.js +43 -39
- package/lib/drafts.js +30 -20
- package/lib/hooks/index.js +60 -16
- package/lib/hooks/useAnchoredPosition.js +40 -32
- package/lib/hooks/useCombinedRefs.js +36 -32
- package/lib/hooks/useDialog.js +96 -72
- package/lib/hooks/useFocusTrap.js +60 -43
- package/lib/hooks/useFocusZone.js +50 -54
- package/lib/hooks/useOnEscapePress.js +36 -25
- package/lib/hooks/useOpenAndCloseFocus.js +34 -22
- package/lib/hooks/useProvidedRefOrCreate.js +14 -10
- package/lib/hooks/useProvidedStateOrCreate.js +16 -13
- package/lib/hooks/useRenderForcingRef.js +17 -13
- package/lib/hooks/useResizeObserver.js +18 -15
- package/lib/hooks/useSafeTimeout.js +30 -22
- package/lib/hooks/useScrollFlash.js +23 -16
- package/lib/index.d.ts +2 -0
- package/lib/index.js +652 -163
- package/lib/polyfills/eventListenerSignal.js +45 -37
- package/lib/sx.js +22 -10
- package/lib/theme-preval.js +3169 -64
- package/lib/theme.js +12 -3
- package/lib/utils/iterateFocusableElements.js +85 -63
- package/lib/utils/testing.d.ts +2 -1
- package/lib/utils/testing.js +29 -0
- package/lib/utils/theme.js +47 -33
- package/lib/utils/types/AriaRole.js +1 -2
- package/lib/utils/types/ComponentProps.js +1 -2
- package/lib/utils/types/Flatten.js +1 -2
- package/lib/utils/types/KeyPaths.js +1 -2
- package/lib/utils/types/MandateProps.js +1 -16
- package/lib/utils/types/Merge.js +1 -2
- package/lib/utils/types/index.js +69 -16
- package/lib/utils/uniqueId.js +8 -5
- package/lib/utils/use-force-update.js +14 -8
- package/lib/utils/useIsomorphicLayoutEffect.js +11 -8
- package/lib/utils/userAgent.js +12 -8
- package/lib-esm/ActionList/Item.js +3 -3
- package/lib-esm/ActionList2/Item.js +3 -1
- package/lib-esm/ActionList2/List.js +1 -2
- package/lib-esm/ActionList2/Selection.js +3 -1
- package/lib-esm/Autocomplete/Autocomplete.d.ts +1 -0
- package/lib-esm/Autocomplete/AutocompleteInput.d.ts +1 -0
- package/lib-esm/Avatar.d.ts +1 -2
- package/lib-esm/Avatar.js +2 -2
- package/lib-esm/BranchName.d.ts +1 -2
- package/lib-esm/BranchName.js +2 -2
- package/lib-esm/Button/Button.d.ts +1 -0
- package/lib-esm/Button/ButtonClose.d.ts +2 -1
- package/lib-esm/Button/ButtonDanger.d.ts +1 -0
- package/lib-esm/Button/ButtonInvisible.d.ts +1 -0
- package/lib-esm/Button/ButtonOutline.d.ts +1 -0
- package/lib-esm/Button/ButtonPrimary.d.ts +1 -0
- package/lib-esm/Checkbox.d.ts +29 -0
- package/lib-esm/Checkbox.js +44 -0
- package/lib-esm/CircleOcticon.d.ts +1 -0
- package/lib-esm/Details.d.ts +1 -2
- package/lib-esm/Details.js +1 -2
- package/lib-esm/Dialog.d.ts +3 -2
- package/lib-esm/Dropdown.d.ts +6 -66
- package/lib-esm/DropdownMenu/DropdownButton.d.ts +2 -1
- package/lib-esm/FilterList.d.ts +1 -0
- package/lib-esm/Heading.d.ts +1 -2
- package/lib-esm/Heading.js +2 -6
- package/lib-esm/Overlay.d.ts +5 -3
- package/lib-esm/Position.d.ts +4 -4
- package/lib-esm/ProgressBar.d.ts +16 -11
- package/lib-esm/ProgressBar.js +7 -11
- package/lib-esm/SelectMenu/SelectMenu.d.ts +10 -4
- package/lib-esm/SelectMenu/SelectMenuItem.d.ts +1 -1
- package/lib-esm/SelectMenu/SelectMenuModal.d.ts +1 -1
- package/lib-esm/Spinner.d.ts +1 -2
- package/lib-esm/Spinner.js +1 -2
- package/lib-esm/TextInputWithTokens.d.ts +1 -0
- 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 +2 -0
- package/lib-esm/index.js +1 -0
- package/lib-esm/theme-preval.js +446 -0
- package/lib-esm/utils/testing.d.ts +2 -1
- package/lib-esm/utils/testing.js +24 -0
- package/package.json +4 -5
- package/lib/ActionList/Divider.jsx +0 -29
- package/lib/ActionList/Group.jsx +0 -23
- package/lib/ActionList/Header.jsx +0 -66
- package/lib/ActionList/Item.jsx +0 -288
- package/lib/ActionList/List.jsx +0 -138
- package/lib/ActionList2/Description.jsx +0 -29
- package/lib/ActionList2/Divider.jsx +0 -22
- package/lib/ActionList2/Group.jsx +0 -54
- package/lib/ActionList2/Header.d.ts +0 -26
- package/lib/ActionList2/Header.js +0 -55
- package/lib/ActionList2/Header.jsx +0 -36
- package/lib/ActionList2/Item.jsx +0 -174
- package/lib/ActionList2/LinkItem.jsx +0 -28
- package/lib/ActionList2/List.jsx +0 -41
- package/lib/ActionList2/Selection.jsx +0 -50
- package/lib/ActionList2/Visuals.jsx +0 -48
- package/lib/ActionMenu.jsx +0 -73
- package/lib/AnchoredOverlay/AnchoredOverlay.jsx +0 -100
- package/lib/Autocomplete/Autocomplete.jsx +0 -100
- package/lib/Autocomplete/AutocompleteContext.jsx +0 -5
- package/lib/Autocomplete/AutocompleteInput.jsx +0 -113
- package/lib/Autocomplete/AutocompleteMenu.jsx +0 -190
- package/lib/Autocomplete/AutocompleteOverlay.jsx +0 -55
- package/lib/Avatar.jsx +0 -34
- package/lib/AvatarPair.jsx +0 -29
- package/lib/AvatarStack.jsx +0 -151
- package/lib/BaseStyles.jsx +0 -65
- package/lib/BorderBox.jsx +0 -18
- package/lib/Box.jsx +0 -10
- package/lib/BranchName.jsx +0 -20
- package/lib/Breadcrumbs.jsx +0 -71
- package/lib/Button/Button.jsx +0 -40
- package/lib/Button/ButtonBase.jsx +0 -33
- package/lib/Button/ButtonClose.jsx +0 -53
- package/lib/Button/ButtonDanger.jsx +0 -43
- package/lib/Button/ButtonGroup.jsx +0 -55
- package/lib/Button/ButtonInvisible.jsx +0 -32
- package/lib/Button/ButtonOutline.jsx +0 -43
- package/lib/Button/ButtonPrimary.jsx +0 -42
- package/lib/Button/ButtonStyles.jsx +0 -37
- package/lib/Button/ButtonTableList.jsx +0 -46
- package/lib/Caret.jsx +0 -93
- package/lib/CircleBadge.jsx +0 -42
- package/lib/CircleOcticon.jsx +0 -21
- package/lib/CounterLabel.jsx +0 -43
- package/lib/Details.jsx +0 -21
- package/lib/Dialog/ConfirmationDialog.jsx +0 -146
- package/lib/Dialog/Dialog.jsx +0 -279
- package/lib/Dialog.jsx +0 -129
- package/lib/Dropdown.jsx +0 -131
- package/lib/DropdownMenu/DropdownButton.jsx +0 -14
- package/lib/DropdownMenu/DropdownMenu.jsx +0 -70
- package/lib/FilterList.jsx +0 -59
- package/lib/FilteredActionList/FilteredActionList.jsx +0 -100
- package/lib/FilteredSearch.jsx +0 -28
- package/lib/Flash.jsx +0 -69
- package/lib/Flex.jsx +0 -15
- package/lib/FormGroup.jsx +0 -22
- package/lib/Grid.jsx +0 -15
- package/lib/Header.jsx +0 -83
- package/lib/Heading.jsx +0 -21
- package/lib/Label.jsx +0 -82
- package/lib/LabelGroup.jsx +0 -18
- package/lib/Link.jsx +0 -36
- package/lib/NewButton/button-counter.jsx +0 -14
- package/lib/NewButton/button.jsx +0 -279
- package/lib/Overlay.jsx +0 -154
- package/lib/Pagehead.jsx +0 -17
- package/lib/Pagination/Pagination.jsx +0 -161
- package/lib/Pagination/model.jsx +0 -174
- package/lib/PointerBox.jsx +0 -25
- package/lib/Popover.jsx +0 -202
- package/lib/Portal/Portal.jsx +0 -79
- package/lib/Position.jsx +0 -46
- package/lib/ProgressBar.jsx +0 -39
- package/lib/SelectMenu/SelectMenu.jsx +0 -112
- package/lib/SelectMenu/SelectMenuContext.jsx +0 -5
- package/lib/SelectMenu/SelectMenuDivider.jsx +0 -42
- package/lib/SelectMenu/SelectMenuFilter.jsx +0 -58
- package/lib/SelectMenu/SelectMenuFooter.jsx +0 -45
- package/lib/SelectMenu/SelectMenuHeader.jsx +0 -42
- package/lib/SelectMenu/SelectMenuItem.jsx +0 -142
- package/lib/SelectMenu/SelectMenuList.jsx +0 -59
- package/lib/SelectMenu/SelectMenuLoadingAnimation.jsx +0 -22
- package/lib/SelectMenu/SelectMenuModal.jsx +0 -118
- package/lib/SelectMenu/SelectMenuTab.jsx +0 -92
- package/lib/SelectMenu/SelectMenuTabPanel.jsx +0 -42
- package/lib/SelectMenu/SelectMenuTabs.jsx +0 -57
- package/lib/SelectPanel/SelectPanel.jsx +0 -105
- package/lib/SideNav.jsx +0 -173
- package/lib/Spinner.jsx +0 -35
- package/lib/StateLabel.jsx +0 -93
- package/lib/StyledOcticon.jsx +0 -18
- package/lib/SubNav.jsx +0 -101
- package/lib/TabNav.jsx +0 -58
- package/lib/Text.jsx +0 -14
- package/lib/TextInput.jsx +0 -23
- package/lib/TextInputWithTokens.jsx +0 -218
- package/lib/ThemeProvider.jsx +0 -130
- package/lib/Timeline.jsx +0 -123
- package/lib/Token/AvatarToken.jsx +0 -54
- package/lib/Token/IssueLabelToken.jsx +0 -125
- package/lib/Token/Token.jsx +0 -103
- package/lib/Token/TokenBase.jsx +0 -88
- package/lib/Token/_RemoveTokenButton.jsx +0 -108
- package/lib/Token/_TokenTextContainer.jsx +0 -49
- package/lib/Tooltip.jsx +0 -246
- package/lib/Truncate.jsx +0 -24
- package/lib/UnderlineNav.jsx +0 -88
- package/lib/_TextInputWrapper.jsx +0 -120
- package/lib/_UnstyledTextInput.jsx +0 -22
- package/lib/hooks/useDetails.jsx +0 -39
- package/lib/hooks/useOnOutsideClick.jsx +0 -61
- package/lib/hooks/useOverlay.jsx +0 -15
- package/lib/utils/create-slots.jsx +0 -65
- package/lib/utils/deprecate.jsx +0 -59
- package/lib/utils/isNumeric.jsx +0 -7
- package/lib/utils/ssr.jsx +0 -6
- package/lib/utils/test-deprecations.jsx +0 -20
- package/lib/utils/test-helpers.jsx +0 -8
- package/lib/utils/test-matchers.jsx +0 -100
- package/lib/utils/testing.jsx +0 -206
- package/lib-esm/ActionList2/Header.d.ts +0 -26
- package/lib-esm/ActionList2/Header.js +0 -44
package/lib/Tooltip.jsx
DELETED
@@ -1,246 +0,0 @@
|
|
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
|
-
const classnames_1 = __importDefault(require("classnames"));
|
7
|
-
const react_1 = __importDefault(require("react"));
|
8
|
-
const styled_components_1 = __importDefault(require("styled-components"));
|
9
|
-
const constants_1 = require("./constants");
|
10
|
-
const sx_1 = __importDefault(require("./sx"));
|
11
|
-
const TooltipBase = styled_components_1.default.span `
|
12
|
-
position: relative;
|
13
|
-
|
14
|
-
&::before {
|
15
|
-
position: absolute;
|
16
|
-
z-index: 1000001;
|
17
|
-
display: none;
|
18
|
-
width: 0px;
|
19
|
-
height: 0px;
|
20
|
-
color: ${constants_1.get('colors.neutral.emphasisPlus')};
|
21
|
-
pointer-events: none;
|
22
|
-
content: '';
|
23
|
-
border: 6px solid transparent;
|
24
|
-
opacity: 0;
|
25
|
-
}
|
26
|
-
|
27
|
-
&::after {
|
28
|
-
position: absolute;
|
29
|
-
z-index: 1000000;
|
30
|
-
display: none;
|
31
|
-
padding: 0.5em 0.75em;
|
32
|
-
font: normal normal 11px/1.5 ${constants_1.get('fonts.normal')};
|
33
|
-
-webkit-font-smoothing: subpixel-antialiased;
|
34
|
-
color: ${constants_1.get('colors.fg.onEmphasis')};
|
35
|
-
text-align: center;
|
36
|
-
text-decoration: none;
|
37
|
-
text-shadow: none;
|
38
|
-
text-transform: none;
|
39
|
-
letter-spacing: normal;
|
40
|
-
word-wrap: break-word;
|
41
|
-
white-space: pre;
|
42
|
-
pointer-events: none;
|
43
|
-
content: attr(aria-label);
|
44
|
-
background: ${constants_1.get('colors.neutral.emphasisPlus')};
|
45
|
-
border-radius: ${constants_1.get('radii.1')};
|
46
|
-
opacity: 0;
|
47
|
-
}
|
48
|
-
|
49
|
-
// delay animation for tooltip
|
50
|
-
@keyframes tooltip-appear {
|
51
|
-
from {
|
52
|
-
opacity: 0;
|
53
|
-
}
|
54
|
-
|
55
|
-
to {
|
56
|
-
opacity: 1;
|
57
|
-
}
|
58
|
-
}
|
59
|
-
|
60
|
-
&:hover,
|
61
|
-
&:active,
|
62
|
-
&:focus {
|
63
|
-
&::before,
|
64
|
-
&::after {
|
65
|
-
display: inline-block;
|
66
|
-
text-decoration: none;
|
67
|
-
animation-name: tooltip-appear;
|
68
|
-
animation-duration: 0.1s;
|
69
|
-
animation-fill-mode: forwards;
|
70
|
-
animation-timing-function: ease-in;
|
71
|
-
animation-delay: 0.4s;
|
72
|
-
}
|
73
|
-
}
|
74
|
-
|
75
|
-
&.tooltipped-no-delay:hover,
|
76
|
-
&.tooltipped-no-delay:active,
|
77
|
-
&.tooltipped-no-delay:focus {
|
78
|
-
&::before,
|
79
|
-
&::after {
|
80
|
-
animation-delay: 0s;
|
81
|
-
}
|
82
|
-
}
|
83
|
-
|
84
|
-
&.tooltipped-multiline:hover,
|
85
|
-
&.tooltipped-multiline:active,
|
86
|
-
&.tooltipped-multiline:focus {
|
87
|
-
&::after {
|
88
|
-
display: table-cell;
|
89
|
-
}
|
90
|
-
}
|
91
|
-
|
92
|
-
// Tooltipped south
|
93
|
-
&.tooltipped-s,
|
94
|
-
&.tooltipped-se,
|
95
|
-
&.tooltipped-sw {
|
96
|
-
&::after {
|
97
|
-
top: 100%;
|
98
|
-
right: 50%;
|
99
|
-
margin-top: 6px;
|
100
|
-
}
|
101
|
-
|
102
|
-
&::before {
|
103
|
-
top: auto;
|
104
|
-
right: 50%;
|
105
|
-
bottom: -7px;
|
106
|
-
margin-right: -6px;
|
107
|
-
border-bottom-color: ${constants_1.get('colors.neutral.emphasisPlus')};
|
108
|
-
}
|
109
|
-
}
|
110
|
-
|
111
|
-
&.tooltipped-se {
|
112
|
-
&::after {
|
113
|
-
right: auto;
|
114
|
-
left: 50%;
|
115
|
-
margin-left: -${constants_1.get('space.3')};
|
116
|
-
}
|
117
|
-
}
|
118
|
-
|
119
|
-
&.tooltipped-sw::after {
|
120
|
-
margin-right: -${constants_1.get('space.3')};
|
121
|
-
}
|
122
|
-
|
123
|
-
// Tooltips above the object
|
124
|
-
&.tooltipped-n,
|
125
|
-
&.tooltipped-ne,
|
126
|
-
&.tooltipped-nw {
|
127
|
-
&::after {
|
128
|
-
right: 50%;
|
129
|
-
bottom: 100%;
|
130
|
-
margin-bottom: 6px;
|
131
|
-
}
|
132
|
-
|
133
|
-
&::before {
|
134
|
-
top: -7px;
|
135
|
-
right: 50%;
|
136
|
-
bottom: auto;
|
137
|
-
margin-right: -6px;
|
138
|
-
border-top-color: ${constants_1.get('colors.neutral.emphasisPlus')};
|
139
|
-
}
|
140
|
-
}
|
141
|
-
|
142
|
-
&.tooltipped-ne {
|
143
|
-
&::after {
|
144
|
-
right: auto;
|
145
|
-
left: 50%;
|
146
|
-
margin-left: -${constants_1.get('space.3')};
|
147
|
-
}
|
148
|
-
}
|
149
|
-
|
150
|
-
&.tooltipped-nw::after {
|
151
|
-
margin-right: -${constants_1.get('space.3')};
|
152
|
-
}
|
153
|
-
|
154
|
-
// Move the tooltip body to the center of the object.
|
155
|
-
&.tooltipped-s::after,
|
156
|
-
&.tooltipped-n::after {
|
157
|
-
transform: translateX(50%);
|
158
|
-
}
|
159
|
-
|
160
|
-
// Tooltipped to the left
|
161
|
-
&.tooltipped-w {
|
162
|
-
&::after {
|
163
|
-
right: 100%;
|
164
|
-
bottom: 50%;
|
165
|
-
margin-right: 6px;
|
166
|
-
transform: translateY(50%);
|
167
|
-
}
|
168
|
-
|
169
|
-
&::before {
|
170
|
-
top: 50%;
|
171
|
-
bottom: 50%;
|
172
|
-
left: -7px;
|
173
|
-
margin-top: -6px;
|
174
|
-
border-left-color: ${constants_1.get('colors.neutral.emphasisPlus')};
|
175
|
-
}
|
176
|
-
}
|
177
|
-
|
178
|
-
// tooltipped to the right
|
179
|
-
&.tooltipped-e {
|
180
|
-
&::after {
|
181
|
-
bottom: 50%;
|
182
|
-
left: 100%;
|
183
|
-
margin-left: 6px;
|
184
|
-
transform: translateY(50%);
|
185
|
-
}
|
186
|
-
|
187
|
-
&::before {
|
188
|
-
top: 50%;
|
189
|
-
right: -7px;
|
190
|
-
bottom: 50%;
|
191
|
-
margin-top: -6px;
|
192
|
-
border-right-color: ${constants_1.get('colors.neutral.emphasisPlus')};
|
193
|
-
}
|
194
|
-
}
|
195
|
-
|
196
|
-
&.tooltipped-multiline {
|
197
|
-
&::after {
|
198
|
-
width: max-content;
|
199
|
-
max-width: 250px;
|
200
|
-
word-wrap: break-word;
|
201
|
-
white-space: pre-line;
|
202
|
-
border-collapse: separate;
|
203
|
-
}
|
204
|
-
|
205
|
-
&.tooltipped-s::after,
|
206
|
-
&.tooltipped-n::after {
|
207
|
-
right: auto;
|
208
|
-
left: 50%;
|
209
|
-
transform: translateX(-50%);
|
210
|
-
}
|
211
|
-
|
212
|
-
&.tooltipped-w::after,
|
213
|
-
&.tooltipped-e::after {
|
214
|
-
right: 100%;
|
215
|
-
}
|
216
|
-
}
|
217
|
-
|
218
|
-
&.tooltipped-align-right-2::after {
|
219
|
-
right: 0;
|
220
|
-
margin-right: 0;
|
221
|
-
}
|
222
|
-
|
223
|
-
&.tooltipped-align-right-2::before {
|
224
|
-
right: 15px;
|
225
|
-
}
|
226
|
-
|
227
|
-
&.tooltipped-align-left-2::after {
|
228
|
-
left: 0;
|
229
|
-
margin-left: 0;
|
230
|
-
}
|
231
|
-
|
232
|
-
&.tooltipped-align-left-2::before {
|
233
|
-
left: 10px;
|
234
|
-
}
|
235
|
-
|
236
|
-
${sx_1.default};
|
237
|
-
`;
|
238
|
-
function Tooltip({ direction = 'n', children, className, text, noDelay, align, wrap, ...rest }) {
|
239
|
-
const classes = classnames_1.default(className, `tooltipped-${direction}`, align && `tooltipped-align-${align}-2`, noDelay && 'tooltipped-no-delay', wrap && 'tooltipped-multiline');
|
240
|
-
return (<TooltipBase role="tooltip" aria-label={text} {...rest} className={classes}>
|
241
|
-
{children}
|
242
|
-
</TooltipBase>);
|
243
|
-
}
|
244
|
-
Tooltip.alignments = ['left', 'right'];
|
245
|
-
Tooltip.directions = ['n', 'ne', 'e', 'se', 's', 'sw', 'w', 'nw'];
|
246
|
-
exports.default = Tooltip;
|
package/lib/Truncate.jsx
DELETED
@@ -1,24 +0,0 @@
|
|
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
|
-
const styled_components_1 = __importDefault(require("styled-components"));
|
7
|
-
const styled_system_1 = require("styled-system");
|
8
|
-
const sx_1 = __importDefault(require("./sx"));
|
9
|
-
const Truncate = styled_components_1.default.div `
|
10
|
-
display: ${props => (props.inline ? 'inline-block' : 'inherit')};
|
11
|
-
overflow: hidden;
|
12
|
-
text-overflow: ellipsis;
|
13
|
-
vertical-align: ${props => (props.inline ? 'top' : 'initial')};
|
14
|
-
white-space: nowrap;
|
15
|
-
${styled_system_1.maxWidth}
|
16
|
-
${props => (props.expandable ? `&:hover { max-width: 10000px; }` : '')}
|
17
|
-
${sx_1.default};
|
18
|
-
`;
|
19
|
-
Truncate.defaultProps = {
|
20
|
-
expandable: false,
|
21
|
-
inline: false,
|
22
|
-
maxWidth: 125
|
23
|
-
};
|
24
|
-
exports.default = Truncate;
|
package/lib/UnderlineNav.jsx
DELETED
@@ -1,88 +0,0 @@
|
|
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
|
-
const classnames_1 = __importDefault(require("classnames"));
|
7
|
-
const react_1 = __importDefault(require("react"));
|
8
|
-
const styled_components_1 = __importDefault(require("styled-components"));
|
9
|
-
const constants_1 = require("./constants");
|
10
|
-
const sx_1 = __importDefault(require("./sx"));
|
11
|
-
const ITEM_CLASS = 'UnderlineNav-item';
|
12
|
-
const SELECTED_CLASS = 'selected';
|
13
|
-
const UnderlineNavBase = styled_components_1.default.nav `
|
14
|
-
display: flex;
|
15
|
-
justify-content: space-between;
|
16
|
-
border-bottom: 1px solid ${constants_1.get('colors.border.muted')};
|
17
|
-
&.UnderlineNav--right {
|
18
|
-
justify-content: flex-end;
|
19
|
-
|
20
|
-
.UnderlineNav-item {
|
21
|
-
margin-right: 0;
|
22
|
-
margin-left: ${constants_1.get('space.3')};
|
23
|
-
}
|
24
|
-
|
25
|
-
.UnderlineNav-actions {
|
26
|
-
flex: 1 1 auto;
|
27
|
-
}
|
28
|
-
}
|
29
|
-
&.UnderlineNav--full {
|
30
|
-
display: block;
|
31
|
-
}
|
32
|
-
|
33
|
-
.UnderlineNav-body {
|
34
|
-
display: flex;
|
35
|
-
margin-bottom: -1px;
|
36
|
-
}
|
37
|
-
|
38
|
-
.UnderlineNav-actions {
|
39
|
-
align-self: center;
|
40
|
-
}
|
41
|
-
|
42
|
-
${sx_1.default};
|
43
|
-
`;
|
44
|
-
function UnderlineNav({ actions, className, align, children, full, label, theme, ...rest }) {
|
45
|
-
const classes = classnames_1.default(className, 'UnderlineNav', align && `UnderlineNav--${align}`, full && 'UnderlineNav--full');
|
46
|
-
return (<UnderlineNavBase className={classes} aria-label={label} theme={theme} {...rest}>
|
47
|
-
<div className="UnderlineNav-body">{children}</div>
|
48
|
-
{actions && <div className="UnderlineNav-actions">{actions}</div>}
|
49
|
-
</UnderlineNavBase>);
|
50
|
-
}
|
51
|
-
const UnderlineNavLink = styled_components_1.default.a.attrs(props => ({
|
52
|
-
activeClassName: typeof props.to === 'string' ? 'selected' : '',
|
53
|
-
className: classnames_1.default(ITEM_CLASS, props.selected && SELECTED_CLASS, props.className)
|
54
|
-
})) `
|
55
|
-
padding: ${constants_1.get('space.3')} ${constants_1.get('space.2')};
|
56
|
-
margin-right: ${constants_1.get('space.3')};
|
57
|
-
font-size: ${constants_1.get('fontSizes.1')};
|
58
|
-
line-height: ${constants_1.get('lineHeights.default')};
|
59
|
-
color: ${constants_1.get('colors.fg.default')};
|
60
|
-
text-align: center;
|
61
|
-
border-bottom: 2px solid transparent;
|
62
|
-
text-decoration: none;
|
63
|
-
|
64
|
-
&:hover,
|
65
|
-
&:focus {
|
66
|
-
color: ${constants_1.get('colors.fg.default')};
|
67
|
-
text-decoration: none;
|
68
|
-
border-bottom-color: ${constants_1.get('colors.neutral.muted')};
|
69
|
-
transition: 0.2s ease;
|
70
|
-
|
71
|
-
.UnderlineNav-octicon {
|
72
|
-
color: ${constants_1.get('colors.fg.muted')};
|
73
|
-
}
|
74
|
-
}
|
75
|
-
|
76
|
-
&.selected {
|
77
|
-
color: ${constants_1.get('colors.fg.default')};
|
78
|
-
border-bottom-color: ${constants_1.get('colors.primer.border.active')};
|
79
|
-
|
80
|
-
.UnderlineNav-octicon {
|
81
|
-
color: ${constants_1.get('colors.fg.default')};
|
82
|
-
}
|
83
|
-
}
|
84
|
-
|
85
|
-
${sx_1.default};
|
86
|
-
`;
|
87
|
-
UnderlineNavLink.displayName = 'UnderlineNav.Link';
|
88
|
-
exports.default = Object.assign(UnderlineNav, { Link: UnderlineNavLink });
|
@@ -1,120 +0,0 @@
|
|
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
|
-
const styled_components_1 = __importStar(require("styled-components"));
|
26
|
-
const styled_system_1 = require("styled-system");
|
27
|
-
const constants_1 = require("./constants");
|
28
|
-
const sx_1 = __importDefault(require("./sx"));
|
29
|
-
const sizeVariants = styled_system_1.variant({
|
30
|
-
variants: {
|
31
|
-
small: {
|
32
|
-
minHeight: '28px',
|
33
|
-
px: 2,
|
34
|
-
py: '3px',
|
35
|
-
fontSize: 0,
|
36
|
-
lineHeight: '20px'
|
37
|
-
},
|
38
|
-
large: {
|
39
|
-
px: 2,
|
40
|
-
py: '10px',
|
41
|
-
fontSize: 3
|
42
|
-
}
|
43
|
-
}
|
44
|
-
});
|
45
|
-
const TextInputWrapper = styled_components_1.default.span `
|
46
|
-
display: inline-flex;
|
47
|
-
align-items: stretch;
|
48
|
-
min-height: 34px;
|
49
|
-
font-size: ${constants_1.get('fontSizes.1')};
|
50
|
-
line-height: 20px;
|
51
|
-
color: ${constants_1.get('colors.fg.default')};
|
52
|
-
vertical-align: middle;
|
53
|
-
background-repeat: no-repeat; // Repeat and position set for form states (success, error, etc)
|
54
|
-
background-position: right 8px center; // For form validation. This keeps images 8px from right and centered vertically.
|
55
|
-
border: 1px solid ${constants_1.get('colors.border.default')};
|
56
|
-
border-radius: ${constants_1.get('radii.2')};
|
57
|
-
outline: none;
|
58
|
-
box-shadow: ${constants_1.get('shadows.primer.shadow.inset')};
|
59
|
-
cursor: text;
|
60
|
-
|
61
|
-
${props => {
|
62
|
-
if (props.hasIcon) {
|
63
|
-
return styled_components_1.css `
|
64
|
-
padding: 0;
|
65
|
-
`;
|
66
|
-
}
|
67
|
-
else {
|
68
|
-
return styled_components_1.css `
|
69
|
-
padding: 6px 12px;
|
70
|
-
`;
|
71
|
-
}
|
72
|
-
}}
|
73
|
-
|
74
|
-
.TextInput-icon {
|
75
|
-
align-self: center;
|
76
|
-
color: ${constants_1.get('colors.fg.muted')};
|
77
|
-
margin: 0 ${constants_1.get('space.2')};
|
78
|
-
flex-shrink: 0;
|
79
|
-
}
|
80
|
-
|
81
|
-
&:focus-within {
|
82
|
-
border-color: ${constants_1.get('colors.accent.emphasis')};
|
83
|
-
box-shadow: ${constants_1.get('shadows.primer.shadow.focus')};
|
84
|
-
}
|
85
|
-
|
86
|
-
${props => props.contrast &&
|
87
|
-
styled_components_1.css `
|
88
|
-
background-color: ${constants_1.get('colors.canvas.inset')};
|
89
|
-
`}
|
90
|
-
|
91
|
-
${props => props.disabled &&
|
92
|
-
styled_components_1.css `
|
93
|
-
color: ${constants_1.get('colors.primer.fg.disabled')};
|
94
|
-
background-color: ${constants_1.get('colors.input.disabledBg')};
|
95
|
-
border-color: ${constants_1.get('colors.border.default')};
|
96
|
-
`}
|
97
|
-
|
98
|
-
${props => props.block &&
|
99
|
-
styled_components_1.css `
|
100
|
-
display: block;
|
101
|
-
width: 100%;
|
102
|
-
`}
|
103
|
-
|
104
|
-
${props => props.block &&
|
105
|
-
props.hasIcon &&
|
106
|
-
styled_components_1.css `
|
107
|
-
display: flex;
|
108
|
-
`}
|
109
|
-
|
110
|
-
// Ensures inputs don't zoom on mobile but are body-font size on desktop
|
111
|
-
@media (min-width: ${constants_1.get('breakpoints.1')}) {
|
112
|
-
font-size: ${constants_1.get('fontSizes.1')};
|
113
|
-
}
|
114
|
-
${styled_system_1.width}
|
115
|
-
${styled_system_1.minWidth}
|
116
|
-
${styled_system_1.maxWidth}
|
117
|
-
${sizeVariants}
|
118
|
-
${sx_1.default};
|
119
|
-
`;
|
120
|
-
exports.default = TextInputWrapper;
|
@@ -1,22 +0,0 @@
|
|
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
|
-
const styled_components_1 = __importDefault(require("styled-components"));
|
7
|
-
const sx_1 = __importDefault(require("./sx"));
|
8
|
-
const UnstyledTextInput = styled_components_1.default.input `
|
9
|
-
border: 0;
|
10
|
-
font-size: inherit;
|
11
|
-
font-family: inherit;
|
12
|
-
background-color: transparent;
|
13
|
-
-webkit-appearance: none;
|
14
|
-
color: inherit;
|
15
|
-
width: 100%;
|
16
|
-
&:focus {
|
17
|
-
outline: 0;
|
18
|
-
}
|
19
|
-
|
20
|
-
${sx_1.default};
|
21
|
-
`;
|
22
|
-
exports.default = UnstyledTextInput;
|
package/lib/hooks/useDetails.jsx
DELETED
@@ -1,39 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
const react_1 = require("react");
|
4
|
-
function useDetails({ ref, closeOnOutsideClick, defaultOpen, onClickOutside }) {
|
5
|
-
const [open, setOpen] = react_1.useState(defaultOpen);
|
6
|
-
const backupRef = react_1.useRef(null);
|
7
|
-
const customRef = ref ?? backupRef;
|
8
|
-
const onClickOutsideInternal = react_1.useCallback((event) => {
|
9
|
-
const { current } = customRef;
|
10
|
-
const eventTarget = event.target;
|
11
|
-
const closest = eventTarget.closest('details');
|
12
|
-
if (closest !== current) {
|
13
|
-
onClickOutside && onClickOutside(event);
|
14
|
-
if (!event.defaultPrevented) {
|
15
|
-
setOpen(false);
|
16
|
-
}
|
17
|
-
}
|
18
|
-
}, [customRef, setOpen, onClickOutside]);
|
19
|
-
// handles the overlay behavior - closing the menu when clicking outside of it
|
20
|
-
react_1.useEffect(() => {
|
21
|
-
if (open && closeOnOutsideClick) {
|
22
|
-
document.addEventListener('click', onClickOutsideInternal);
|
23
|
-
return () => {
|
24
|
-
document.removeEventListener('click', onClickOutsideInternal);
|
25
|
-
};
|
26
|
-
}
|
27
|
-
}, [open, closeOnOutsideClick, onClickOutsideInternal]);
|
28
|
-
const handleToggle = (e) => {
|
29
|
-
if (!e.defaultPrevented) {
|
30
|
-
const eventTarget = e.target;
|
31
|
-
setOpen(eventTarget.open);
|
32
|
-
}
|
33
|
-
};
|
34
|
-
const getDetailsProps = () => {
|
35
|
-
return { onToggle: handleToggle, open, ref: customRef };
|
36
|
-
};
|
37
|
-
return { open, setOpen, getDetailsProps };
|
38
|
-
}
|
39
|
-
exports.default = useDetails;
|
@@ -1,61 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.useOnOutsideClick = void 0;
|
4
|
-
const react_1 = require("react");
|
5
|
-
// Because events are handled at the document level, we provide a mechanism for early return.
|
6
|
-
const stopPropagation = true;
|
7
|
-
/**
|
8
|
-
* Calls all handlers in reverse order
|
9
|
-
* @param event The MouseEvent generated by the click event.
|
10
|
-
*/
|
11
|
-
function handleClick(event) {
|
12
|
-
if (!event.defaultPrevented) {
|
13
|
-
for (const handler of Object.values(registry).reverse()) {
|
14
|
-
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
|
15
|
-
if (handler(event) === stopPropagation || event.defaultPrevented) {
|
16
|
-
break;
|
17
|
-
}
|
18
|
-
}
|
19
|
-
}
|
20
|
-
}
|
21
|
-
const registry = {};
|
22
|
-
function register(id, handler) {
|
23
|
-
registry[id] = handler;
|
24
|
-
}
|
25
|
-
function deregister(id) {
|
26
|
-
delete registry[id];
|
27
|
-
}
|
28
|
-
// For auto-incrementing unique identifiers for registered handlers.
|
29
|
-
let handlerId = 0;
|
30
|
-
const useOnOutsideClick = ({ containerRef, ignoreClickRefs, onClickOutside }) => {
|
31
|
-
const id = react_1.useMemo(() => handlerId++, []);
|
32
|
-
const handler = react_1.useCallback(event => {
|
33
|
-
// don't call click handler if the mouse event was triggered by an auxiliary button (right click/wheel button/etc)
|
34
|
-
if (event instanceof MouseEvent && event.button > 0) {
|
35
|
-
return stopPropagation;
|
36
|
-
}
|
37
|
-
// don't call handler if the click happened inside of the container
|
38
|
-
if (containerRef.current?.contains(event.target)) {
|
39
|
-
return stopPropagation;
|
40
|
-
}
|
41
|
-
// don't call handler if click happened on an ignored ref
|
42
|
-
if (ignoreClickRefs && ignoreClickRefs.some(({ current }) => current?.contains(event.target))) {
|
43
|
-
return stopPropagation;
|
44
|
-
}
|
45
|
-
onClickOutside(event);
|
46
|
-
}, [containerRef, ignoreClickRefs, onClickOutside]);
|
47
|
-
react_1.useEffect(() => {
|
48
|
-
if (Object.keys(registry).length === 0) {
|
49
|
-
// use capture to ensure we get all events
|
50
|
-
document.addEventListener('mousedown', handleClick, { capture: true });
|
51
|
-
}
|
52
|
-
register(id, handler);
|
53
|
-
return () => {
|
54
|
-
deregister(id);
|
55
|
-
if (Object.keys(registry).length === 0) {
|
56
|
-
document.removeEventListener('mousedown', handleClick, { capture: true });
|
57
|
-
}
|
58
|
-
};
|
59
|
-
}, [id, handler]);
|
60
|
-
};
|
61
|
-
exports.useOnOutsideClick = useOnOutsideClick;
|
package/lib/hooks/useOverlay.jsx
DELETED
@@ -1,15 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.useOverlay = void 0;
|
4
|
-
const useOnOutsideClick_1 = require("./useOnOutsideClick");
|
5
|
-
const useOpenAndCloseFocus_1 = require("./useOpenAndCloseFocus");
|
6
|
-
const useOnEscapePress_1 = require("./useOnEscapePress");
|
7
|
-
const useProvidedRefOrCreate_1 = require("./useProvidedRefOrCreate");
|
8
|
-
const useOverlay = ({ overlayRef: _overlayRef, returnFocusRef, initialFocusRef, onEscape, ignoreClickRefs, onClickOutside, preventFocusOnOpen }) => {
|
9
|
-
const overlayRef = useProvidedRefOrCreate_1.useProvidedRefOrCreate(_overlayRef);
|
10
|
-
useOpenAndCloseFocus_1.useOpenAndCloseFocus({ containerRef: overlayRef, returnFocusRef, initialFocusRef, preventFocusOnOpen });
|
11
|
-
useOnOutsideClick_1.useOnOutsideClick({ containerRef: overlayRef, ignoreClickRefs, onClickOutside });
|
12
|
-
useOnEscapePress_1.useOnEscapePress(onEscape);
|
13
|
-
return { ref: overlayRef };
|
14
|
-
};
|
15
|
-
exports.useOverlay = useOverlay;
|
@@ -1,65 +0,0 @@
|
|
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
|
-
const react_1 = __importDefault(require("react"));
|
7
|
-
const use_force_update_1 = require("./use-force-update");
|
8
|
-
/** createSlots is a factory that can create a
|
9
|
-
* typesafe Slots + Slot pair to use in a component definition
|
10
|
-
* For example: ActionList.Item uses createSlots to get a Slots wrapper
|
11
|
-
* + Slot component that is used by LeadingVisual, Description
|
12
|
-
*/
|
13
|
-
const createSlots = (slotNames) => {
|
14
|
-
const SlotsContext = react_1.default.createContext({
|
15
|
-
registerSlot: () => null,
|
16
|
-
unregisterSlot: () => null,
|
17
|
-
context: {}
|
18
|
-
});
|
19
|
-
/** Slots uses a Double render strategy inspired by [reach-ui/descendants](https://github.com/reach/reach-ui/tree/develop/packages/descendants)
|
20
|
-
* Slot registers themself with the Slots parent.
|
21
|
-
* When all the children have mounted = registered themselves in slot,
|
22
|
-
* we re-render the parent component to render with slots
|
23
|
-
*/
|
24
|
-
const Slots = ({ context = {}, children }) => {
|
25
|
-
// initialise slots
|
26
|
-
const slotsDefinition = {};
|
27
|
-
slotNames.map(name => (slotsDefinition[name] = null));
|
28
|
-
const slotsRef = react_1.default.useRef(slotsDefinition);
|
29
|
-
const rerenderWithSlots = use_force_update_1.useForceUpdate();
|
30
|
-
const [isMounted, setIsMounted] = react_1.default.useState(false);
|
31
|
-
// fires after all the effects in children
|
32
|
-
react_1.default.useEffect(() => {
|
33
|
-
rerenderWithSlots();
|
34
|
-
setIsMounted(true);
|
35
|
-
}, [rerenderWithSlots]);
|
36
|
-
const registerSlot = react_1.default.useCallback((name, contents) => {
|
37
|
-
slotsRef.current[name] = contents;
|
38
|
-
// don't render until the component mounts = all slots are registered
|
39
|
-
if (isMounted)
|
40
|
-
rerenderWithSlots();
|
41
|
-
}, [isMounted, rerenderWithSlots]);
|
42
|
-
// Slot can be removed from the tree as well,
|
43
|
-
// we need to unregister them from the slot
|
44
|
-
const unregisterSlot = react_1.default.useCallback((name) => {
|
45
|
-
slotsRef.current[name] = null;
|
46
|
-
rerenderWithSlots();
|
47
|
-
}, [rerenderWithSlots]);
|
48
|
-
/**
|
49
|
-
* Slots uses a render prop API so abstract the
|
50
|
-
* implementation detail of using a context provider.
|
51
|
-
*/
|
52
|
-
const slots = slotsRef.current;
|
53
|
-
return (<SlotsContext.Provider value={{ registerSlot, unregisterSlot, context }}>{children(slots)}</SlotsContext.Provider>);
|
54
|
-
};
|
55
|
-
const Slot = ({ name, children }) => {
|
56
|
-
const { registerSlot, unregisterSlot, context } = react_1.default.useContext(SlotsContext);
|
57
|
-
react_1.default.useEffect(() => {
|
58
|
-
registerSlot(name, typeof children === 'function' ? children(context) : children);
|
59
|
-
return () => unregisterSlot(name);
|
60
|
-
}, [name, children, registerSlot, unregisterSlot, context]);
|
61
|
-
return null;
|
62
|
-
};
|
63
|
-
return { Slots, Slot };
|
64
|
-
};
|
65
|
-
exports.default = createSlots;
|