@salt-ds/lab 1.0.0-alpha.10 → 1.0.0-alpha.12
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-cjs/accordion/Accordion.css.js +1 -1
- package/dist-cjs/accordion/Accordion.js +33 -108
- package/dist-cjs/accordion/Accordion.js.map +1 -1
- package/dist-cjs/accordion/AccordionContext.js +15 -11
- package/dist-cjs/accordion/AccordionContext.js.map +1 -1
- package/dist-cjs/accordion/AccordionGroup.js +23 -0
- package/dist-cjs/accordion/AccordionGroup.js.map +1 -0
- package/dist-cjs/accordion/AccordionHeader.css.js +6 -0
- package/dist-cjs/accordion/AccordionHeader.css.js.map +1 -0
- package/dist-cjs/accordion/AccordionHeader.js +50 -0
- package/dist-cjs/accordion/AccordionHeader.js.map +1 -0
- package/dist-cjs/accordion/AccordionPanel.css.js +6 -0
- package/dist-cjs/accordion/AccordionPanel.css.js.map +1 -0
- package/dist-cjs/accordion/AccordionPanel.js +45 -0
- package/dist-cjs/accordion/AccordionPanel.js.map +1 -0
- package/dist-cjs/common-hooks/useKeyboardNavigation.js +0 -3
- package/dist-cjs/common-hooks/useKeyboardNavigation.js.map +1 -1
- package/dist-cjs/dialog/DialogTitle.css.js +1 -1
- package/dist-cjs/dialog/DialogTitle.js +2 -3
- package/dist-cjs/dialog/DialogTitle.js.map +1 -1
- package/dist-cjs/dropdown/Dropdown.js +5 -2
- package/dist-cjs/dropdown/Dropdown.js.map +1 -1
- package/dist-cjs/dropdown/useDropdown.js +12 -0
- package/dist-cjs/dropdown/useDropdown.js.map +1 -1
- package/dist-cjs/form-field-legacy/FormFieldLegacy.css.js +1 -1
- package/dist-cjs/index.js +23 -10
- package/dist-cjs/index.js.map +1 -1
- package/dist-cjs/list/useList.js +0 -1
- package/dist-cjs/list/useList.js.map +1 -1
- package/dist-cjs/list-deprecated/ListItem.css.js +1 -1
- package/dist-cjs/list-next/ListItemNext.css.js +6 -0
- package/dist-cjs/list-next/ListItemNext.css.js.map +1 -0
- package/dist-cjs/list-next/ListItemNext.js +74 -0
- package/dist-cjs/list-next/ListItemNext.js.map +1 -0
- package/dist-cjs/list-next/ListNext.css.js +6 -0
- package/dist-cjs/list-next/ListNext.css.js.map +1 -0
- package/dist-cjs/list-next/ListNext.js +92 -0
- package/dist-cjs/list-next/ListNext.js.map +1 -0
- package/dist-cjs/list-next/ListNextContext.js +18 -0
- package/dist-cjs/list-next/ListNextContext.js.map +1 -0
- package/dist-cjs/list-next/useList.js +188 -0
- package/dist-cjs/list-next/useList.js.map +1 -0
- package/dist-cjs/logo/Logo.css.js +1 -1
- package/dist-cjs/logo/Logo.js +4 -36
- package/dist-cjs/logo/Logo.js.map +1 -1
- package/dist-cjs/logo/LogoImage.js +24 -0
- package/dist-cjs/logo/LogoImage.js.map +1 -0
- package/dist-cjs/logo/LogoSeparator.css.js +6 -0
- package/dist-cjs/logo/LogoSeparator.css.js.map +1 -0
- package/dist-cjs/logo/LogoSeparator.js +32 -0
- package/dist-cjs/logo/LogoSeparator.js.map +1 -0
- package/dist-cjs/multiline-input/MultilineInput.css.js +6 -0
- package/dist-cjs/multiline-input/MultilineInput.css.js.map +1 -0
- package/dist-cjs/multiline-input/MultilineInput.js +150 -0
- package/dist-cjs/multiline-input/MultilineInput.js.map +1 -0
- package/dist-cjs/pill/Pill.css.js +1 -1
- package/dist-cjs/query-input/internal/QueryInputBody.js +5 -5
- package/dist-cjs/query-input/internal/QueryInputBody.js.map +1 -1
- package/dist-cjs/tabs-next/OverflowMenu.js +49 -0
- package/dist-cjs/tabs-next/OverflowMenu.js.map +1 -0
- package/dist-cjs/tabs-next/TabNext.css.js +6 -0
- package/dist-cjs/tabs-next/TabNext.css.js.map +1 -0
- package/dist-cjs/tabs-next/TabNext.js +87 -0
- package/dist-cjs/tabs-next/TabNext.js.map +1 -0
- package/dist-cjs/tabs-next/TabNextContext.js +23 -0
- package/dist-cjs/tabs-next/TabNextContext.js.map +1 -0
- package/dist-cjs/tabs-next/TabstripNext.css.js +6 -0
- package/dist-cjs/tabs-next/TabstripNext.css.js.map +1 -0
- package/dist-cjs/tabs-next/TabstripNext.js +180 -0
- package/dist-cjs/tabs-next/TabstripNext.js.map +1 -0
- package/dist-cjs/toggle-button/ToggleButton.css.js +1 -1
- package/dist-cjs/toggle-button/ToggleButton.js +44 -74
- package/dist-cjs/toggle-button/ToggleButton.js.map +1 -1
- package/dist-cjs/toggle-button-group/ToggleButtonGroup.css.js +6 -0
- package/dist-cjs/toggle-button-group/ToggleButtonGroup.js +111 -0
- package/dist-cjs/toggle-button-group/ToggleButtonGroup.js.map +1 -0
- package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js +15 -0
- package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js.map +1 -0
- package/dist-cjs/tokenized-input/TokenizedInput.css.js +1 -1
- package/dist-cjs/toolbar/ToolbarButton.css.js +1 -1
- package/dist-es/accordion/Accordion.css.js +1 -1
- package/dist-es/accordion/Accordion.js +35 -110
- package/dist-es/accordion/Accordion.js.map +1 -1
- package/dist-es/accordion/AccordionContext.js +15 -11
- package/dist-es/accordion/AccordionContext.js.map +1 -1
- package/dist-es/accordion/AccordionGroup.js +19 -0
- package/dist-es/accordion/AccordionGroup.js.map +1 -0
- package/dist-es/accordion/AccordionHeader.css.js +4 -0
- package/dist-es/accordion/AccordionHeader.css.js.map +1 -0
- package/dist-es/accordion/AccordionHeader.js +46 -0
- package/dist-es/accordion/AccordionHeader.js.map +1 -0
- package/dist-es/accordion/AccordionPanel.css.js +4 -0
- package/dist-es/accordion/AccordionPanel.css.js.map +1 -0
- package/dist-es/accordion/AccordionPanel.js +41 -0
- package/dist-es/accordion/AccordionPanel.js.map +1 -0
- package/dist-es/common-hooks/useKeyboardNavigation.js +0 -3
- package/dist-es/common-hooks/useKeyboardNavigation.js.map +1 -1
- package/dist-es/dialog/DialogTitle.css.js +1 -1
- package/dist-es/dialog/DialogTitle.js +3 -4
- package/dist-es/dialog/DialogTitle.js.map +1 -1
- package/dist-es/dropdown/Dropdown.js +5 -2
- package/dist-es/dropdown/Dropdown.js.map +1 -1
- package/dist-es/dropdown/useDropdown.js +12 -0
- package/dist-es/dropdown/useDropdown.js.map +1 -1
- package/dist-es/form-field-legacy/FormFieldLegacy.css.js +1 -1
- package/dist-es/index.js +12 -5
- package/dist-es/index.js.map +1 -1
- package/dist-es/list/useList.js +0 -1
- package/dist-es/list/useList.js.map +1 -1
- package/dist-es/list-deprecated/ListItem.css.js +1 -1
- package/dist-es/list-next/ListItemNext.css.js +4 -0
- package/dist-es/list-next/ListItemNext.css.js.map +1 -0
- package/dist-es/list-next/ListItemNext.js +70 -0
- package/dist-es/list-next/ListItemNext.js.map +1 -0
- package/dist-es/list-next/ListNext.css.js +4 -0
- package/dist-es/list-next/ListNext.css.js.map +1 -0
- package/dist-es/list-next/ListNext.js +88 -0
- package/dist-es/list-next/ListNext.js.map +1 -0
- package/dist-es/list-next/ListNextContext.js +13 -0
- package/dist-es/list-next/ListNextContext.js.map +1 -0
- package/dist-es/list-next/useList.js +184 -0
- package/dist-es/list-next/useList.js.map +1 -0
- package/dist-es/logo/Logo.css.js +1 -1
- package/dist-es/logo/Logo.js +5 -37
- package/dist-es/logo/Logo.js.map +1 -1
- package/dist-es/logo/LogoImage.js +20 -0
- package/dist-es/logo/LogoImage.js.map +1 -0
- package/dist-es/logo/LogoSeparator.css.js +4 -0
- package/dist-es/logo/LogoSeparator.css.js.map +1 -0
- package/dist-es/logo/LogoSeparator.js +28 -0
- package/dist-es/logo/LogoSeparator.js.map +1 -0
- package/dist-es/multiline-input/MultilineInput.css.js +4 -0
- package/dist-es/multiline-input/MultilineInput.css.js.map +1 -0
- package/dist-es/multiline-input/MultilineInput.js +146 -0
- package/dist-es/multiline-input/MultilineInput.js.map +1 -0
- package/dist-es/pill/Pill.css.js +1 -1
- package/dist-es/query-input/internal/QueryInputBody.js +5 -5
- package/dist-es/query-input/internal/QueryInputBody.js.map +1 -1
- package/dist-es/tabs-next/OverflowMenu.js +45 -0
- package/dist-es/tabs-next/OverflowMenu.js.map +1 -0
- package/dist-es/tabs-next/TabNext.css.js +4 -0
- package/dist-es/tabs-next/TabNext.css.js.map +1 -0
- package/dist-es/tabs-next/TabNext.js +79 -0
- package/dist-es/tabs-next/TabNext.js.map +1 -0
- package/dist-es/tabs-next/TabNextContext.js +18 -0
- package/dist-es/tabs-next/TabNextContext.js.map +1 -0
- package/dist-es/tabs-next/TabstripNext.css.js +4 -0
- package/dist-es/tabs-next/TabstripNext.css.js.map +1 -0
- package/dist-es/tabs-next/TabstripNext.js +172 -0
- package/dist-es/tabs-next/TabstripNext.js.map +1 -0
- package/dist-es/toggle-button/ToggleButton.css.js +1 -1
- package/dist-es/toggle-button/ToggleButton.js +45 -75
- package/dist-es/toggle-button/ToggleButton.js.map +1 -1
- package/dist-es/toggle-button-group/ToggleButtonGroup.css.js +4 -0
- package/dist-es/toggle-button-group/ToggleButtonGroup.js +107 -0
- package/dist-es/toggle-button-group/ToggleButtonGroup.js.map +1 -0
- package/dist-es/toggle-button-group/ToggleButtonGroupContext.js +10 -0
- package/dist-es/toggle-button-group/ToggleButtonGroupContext.js.map +1 -0
- package/dist-es/tokenized-input/TokenizedInput.css.js +1 -1
- package/dist-es/toolbar/ToolbarButton.css.js +1 -1
- package/dist-types/accordion/Accordion.d.ts +22 -6
- package/dist-types/accordion/AccordionContext.d.ts +8 -8
- package/dist-types/accordion/AccordionGroup.d.ts +4 -0
- package/dist-types/accordion/AccordionHeader.d.ts +4 -0
- package/dist-types/accordion/AccordionPanel.d.ts +4 -0
- package/dist-types/accordion/index.d.ts +3 -4
- package/dist-types/dropdown/useDropdown.d.ts +1 -1
- package/dist-types/index.d.ts +4 -0
- package/dist-types/list-next/ListItemNext.d.ts +11 -0
- package/dist-types/list-next/ListNext.d.ts +10 -0
- package/dist-types/list-next/ListNextContext.d.ts +10 -0
- package/dist-types/list-next/index.d.ts +2 -0
- package/dist-types/list-next/useList.d.ts +29 -0
- package/dist-types/logo/Logo.d.ts +3 -31
- package/dist-types/logo/LogoImage.d.ts +5 -0
- package/dist-types/logo/LogoSeparator.d.ts +3 -0
- package/dist-types/logo/index.d.ts +2 -0
- package/dist-types/multiline-input/MultilineInput.d.ts +40 -0
- package/dist-types/multiline-input/index.d.ts +1 -0
- package/dist-types/tabs-next/OverflowMenu.d.ts +11 -0
- package/dist-types/tabs-next/TabNext.d.ts +5 -0
- package/dist-types/tabs-next/TabNextContext.d.ts +17 -0
- package/dist-types/tabs-next/TabstripNext.d.ts +10 -0
- package/dist-types/tabs-next/index.d.ts +2 -0
- package/dist-types/toggle-button/ToggleButton.d.ts +6 -11
- package/dist-types/toggle-button/index.d.ts +0 -1
- package/dist-types/toggle-button-group/ToggleButtonGroup.d.ts +25 -0
- package/dist-types/toggle-button-group/ToggleButtonGroupContext.d.ts +10 -0
- package/dist-types/toggle-button-group/index.d.ts +2 -0
- package/package.json +7 -5
- package/dist-cjs/accordion/AccordionDetails.js +0 -87
- package/dist-cjs/accordion/AccordionDetails.js.map +0 -1
- package/dist-cjs/accordion/AccordionSection.js +0 -111
- package/dist-cjs/accordion/AccordionSection.js.map +0 -1
- package/dist-cjs/accordion/AccordionSectionContext.js +0 -24
- package/dist-cjs/accordion/AccordionSectionContext.js.map +0 -1
- package/dist-cjs/accordion/AccordionSummary.js +0 -64
- package/dist-cjs/accordion/AccordionSummary.js.map +0 -1
- package/dist-cjs/accordion/utils.js +0 -8
- package/dist-cjs/accordion/utils.js.map +0 -1
- package/dist-cjs/logo/internal/LogoTitle.js +0 -28
- package/dist-cjs/logo/internal/LogoTitle.js.map +0 -1
- package/dist-cjs/toggle-button/ToggleButtonGroup.css.js +0 -6
- package/dist-cjs/toggle-button/ToggleButtonGroup.js +0 -147
- package/dist-cjs/toggle-button/ToggleButtonGroup.js.map +0 -1
- package/dist-cjs/toggle-button/internal/ToggleButtonGroupContext.js +0 -10
- package/dist-cjs/toggle-button/internal/ToggleButtonGroupContext.js.map +0 -1
- package/dist-es/accordion/AccordionDetails.js +0 -83
- package/dist-es/accordion/AccordionDetails.js.map +0 -1
- package/dist-es/accordion/AccordionSection.js +0 -107
- package/dist-es/accordion/AccordionSection.js.map +0 -1
- package/dist-es/accordion/AccordionSectionContext.js +0 -19
- package/dist-es/accordion/AccordionSectionContext.js.map +0 -1
- package/dist-es/accordion/AccordionSummary.js +0 -60
- package/dist-es/accordion/AccordionSummary.js.map +0 -1
- package/dist-es/accordion/utils.js +0 -4
- package/dist-es/accordion/utils.js.map +0 -1
- package/dist-es/logo/internal/LogoTitle.js +0 -24
- package/dist-es/logo/internal/LogoTitle.js.map +0 -1
- package/dist-es/toggle-button/ToggleButtonGroup.css.js +0 -4
- package/dist-es/toggle-button/ToggleButtonGroup.js +0 -143
- package/dist-es/toggle-button/ToggleButtonGroup.js.map +0 -1
- package/dist-es/toggle-button/internal/ToggleButtonGroupContext.js +0 -6
- package/dist-es/toggle-button/internal/ToggleButtonGroupContext.js.map +0 -1
- package/dist-types/accordion/AccordionDetails.d.ts +0 -8
- package/dist-types/accordion/AccordionSection.d.ts +0 -9
- package/dist-types/accordion/AccordionSectionContext.d.ts +0 -8
- package/dist-types/accordion/AccordionSummary.d.ts +0 -5
- package/dist-types/accordion/utils.d.ts +0 -1
- package/dist-types/logo/internal/LogoTitle.d.ts +0 -6
- package/dist-types/toggle-button/ToggleButtonGroup.d.ts +0 -18
- package/dist-types/toggle-button/internal/ToggleButtonGroupContext.d.ts +0 -14
- /package/dist-cjs/{toggle-button → toggle-button-group}/ToggleButtonGroup.css.js.map +0 -0
- /package/dist-es/{toggle-button → toggle-button-group}/ToggleButtonGroup.css.js.map +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ListNext.js","sources":["../src/list-next/ListNext.tsx"],"sourcesContent":["import { makePrefixer, useForkRef, useId } from \"@salt-ds/core\";\nimport {\n FocusEvent,\n forwardRef,\n HTMLAttributes,\n KeyboardEvent,\n MouseEvent,\n useRef,\n} from \"react\";\nimport { clsx } from \"clsx\";\nimport { useList } from \"./useList\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport listNextCss from \"./ListNext.css\";\nimport { ListNextContext } from \"./ListNextContext\";\n\nconst withBaseName = makePrefixer(\"saltListNext\");\n\nexport interface ListNextProps extends HTMLAttributes<HTMLUListElement> {\n /**\n * If true, all items in list will be disabled.\n */\n disabled?: boolean;\n /* Value for the uncontrolled version. */\n selected?: string;\n /* Initial value for the uncontrolled version. */\n defaultSelected?: string;\n}\n\nexport const ListNext = forwardRef<HTMLUListElement, ListNextProps>(\n function ListNext(\n {\n children,\n className,\n disabled,\n id,\n onSelect,\n onFocus,\n onBlur,\n onKeyDown,\n onMouseDown,\n selected,\n defaultSelected,\n ...rest\n },\n ref\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-list-next\",\n css: listNextCss,\n window: targetWindow,\n });\n\n const listId = useId(id);\n const listRef = useRef<HTMLUListElement>(null);\n const handleRef = useForkRef(listRef, ref);\n\n const {\n focusHandler,\n keyDownHandler,\n blurHandler,\n mouseDownHandler,\n activeDescendant,\n contextValue,\n } = useList({\n disabled,\n selected,\n defaultSelected,\n id: listId,\n ref: listRef,\n });\n\n const handleFocus = (event: FocusEvent<HTMLUListElement>) => {\n focusHandler();\n onFocus?.(event);\n };\n\n const handleKeyDown = (event: KeyboardEvent<HTMLUListElement>) => {\n keyDownHandler(event);\n onKeyDown?.(event);\n };\n\n const handleBlur = (event: FocusEvent<HTMLUListElement>) => {\n blurHandler();\n onBlur?.(event);\n };\n\n const handleMouseDown = (event: MouseEvent<HTMLUListElement>) => {\n mouseDownHandler();\n onMouseDown?.(event);\n };\n\n return (\n <ListNextContext.Provider value={contextValue}>\n <ul\n ref={handleRef}\n id={listId}\n className={clsx(withBaseName(), className)}\n role=\"listbox\"\n tabIndex={disabled ? -1 : 0}\n aria-activedescendant={disabled ? undefined : activeDescendant}\n aria-disabled={disabled}\n onFocus={handleFocus}\n onKeyDown={handleKeyDown}\n onBlur={handleBlur}\n onMouseDown={handleMouseDown}\n {...rest}\n >\n {children}\n </ul>\n </ListNextContext.Provider>\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","ListNext","useWindow","useComponentCssInjection","listNextCss","useId","useRef","useForkRef","useList","jsx","ListNextContext","clsx"],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var core = require('@salt-ds/core');
|
|
6
|
+
var React = require('react');
|
|
7
|
+
|
|
8
|
+
const ListNextContext = core.createContext(
|
|
9
|
+
"ListNextContext",
|
|
10
|
+
void 0
|
|
11
|
+
);
|
|
12
|
+
function useListItem() {
|
|
13
|
+
return React.useContext(ListNextContext);
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
exports.ListNextContext = ListNextContext;
|
|
17
|
+
exports.useListItem = useListItem;
|
|
18
|
+
//# sourceMappingURL=ListNextContext.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ListNextContext.js","sources":["../src/list-next/ListNextContext.tsx"],"sourcesContent":["import { createContext } from \"@salt-ds/core\";\nimport { SyntheticEvent, useContext } from \"react\";\n\nexport interface ListNextContextValue {\n disabled?: boolean;\n id?: string;\n select: (event: SyntheticEvent<HTMLLIElement>) => void;\n isSelected: (id: string) => boolean;\n isFocused: (id: string) => boolean;\n}\n\nexport const ListNextContext = createContext<ListNextContextValue | undefined>(\n \"ListNextContext\",\n undefined\n);\n\nexport function useListItem() {\n return useContext(ListNextContext);\n}\n"],"names":["createContext","useContext"],"mappings":";;;;;;;AAWO,MAAM,eAAkB,GAAAA,kBAAA;AAAA,EAC7B,iBAAA;AAAA,EACA,KAAA,CAAA;AACF,EAAA;AAEO,SAAS,WAAc,GAAA;AAC5B,EAAA,OAAOC,iBAAW,eAAe,CAAA,CAAA;AACnC;;;;;"}
|
|
@@ -0,0 +1,188 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var React = require('react');
|
|
6
|
+
var core = require('@salt-ds/core');
|
|
7
|
+
|
|
8
|
+
const useList = ({
|
|
9
|
+
disabled = false,
|
|
10
|
+
selected: selectedProp,
|
|
11
|
+
defaultSelected,
|
|
12
|
+
onChange,
|
|
13
|
+
id,
|
|
14
|
+
ref
|
|
15
|
+
}) => {
|
|
16
|
+
const [activeDescendant, setActiveDescendant] = React.useState(
|
|
17
|
+
void 0
|
|
18
|
+
);
|
|
19
|
+
const [showFocusRing, setShowFocusRing] = React.useState(false);
|
|
20
|
+
const [selectedItem, setSelectedItem] = core.useControlled({
|
|
21
|
+
controlled: selectedProp,
|
|
22
|
+
default: defaultSelected,
|
|
23
|
+
name: "ListNext",
|
|
24
|
+
state: "selected"
|
|
25
|
+
});
|
|
26
|
+
const getOptions = React.useCallback(() => {
|
|
27
|
+
var _a, _b;
|
|
28
|
+
return Array.from(
|
|
29
|
+
(_b = (_a = ref.current) == null ? void 0 : _a.querySelectorAll('[role="option"]:not([aria-disabled])')) != null ? _b : []
|
|
30
|
+
);
|
|
31
|
+
}, [ref]);
|
|
32
|
+
const updateScroll = React.useCallback(
|
|
33
|
+
(currentTarget) => {
|
|
34
|
+
const list = ref.current;
|
|
35
|
+
if (!list || !currentTarget)
|
|
36
|
+
return;
|
|
37
|
+
const { offsetTop, offsetHeight } = currentTarget;
|
|
38
|
+
const listHeight = list == null ? void 0 : list.clientHeight;
|
|
39
|
+
const listScrollTop = list == null ? void 0 : list.scrollTop;
|
|
40
|
+
if (offsetTop < listScrollTop) {
|
|
41
|
+
list.scrollTop = offsetTop;
|
|
42
|
+
} else if (offsetTop + offsetHeight > listScrollTop + listHeight) {
|
|
43
|
+
list.scrollTop = offsetTop + offsetHeight - listHeight;
|
|
44
|
+
}
|
|
45
|
+
},
|
|
46
|
+
[ref]
|
|
47
|
+
);
|
|
48
|
+
const updateActiveDescendant = React.useCallback(
|
|
49
|
+
(element) => {
|
|
50
|
+
setActiveDescendant(element.id);
|
|
51
|
+
updateScroll(element);
|
|
52
|
+
},
|
|
53
|
+
[setActiveDescendant, updateScroll]
|
|
54
|
+
);
|
|
55
|
+
const selectItem = React.useCallback(
|
|
56
|
+
(element) => {
|
|
57
|
+
const newValue = element == null ? void 0 : element.dataset.value;
|
|
58
|
+
if (newValue) {
|
|
59
|
+
setSelectedItem(newValue);
|
|
60
|
+
updateActiveDescendant(element);
|
|
61
|
+
}
|
|
62
|
+
},
|
|
63
|
+
[setSelectedItem, updateActiveDescendant]
|
|
64
|
+
);
|
|
65
|
+
const focusAndMoveActive = (element) => {
|
|
66
|
+
setShowFocusRing(true);
|
|
67
|
+
updateActiveDescendant(element);
|
|
68
|
+
};
|
|
69
|
+
const focusFirstItem = () => {
|
|
70
|
+
const activeOptions = getOptions();
|
|
71
|
+
const firstItem = activeOptions[0];
|
|
72
|
+
if (firstItem) {
|
|
73
|
+
focusAndMoveActive(firstItem);
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
const focusLastItem = () => {
|
|
77
|
+
const activeOptions = getOptions();
|
|
78
|
+
const lastItem = activeOptions[activeOptions.length - 1];
|
|
79
|
+
if (lastItem) {
|
|
80
|
+
focusAndMoveActive(lastItem);
|
|
81
|
+
updateScroll(lastItem);
|
|
82
|
+
}
|
|
83
|
+
};
|
|
84
|
+
const findNextOption = (currentOption, moves) => {
|
|
85
|
+
const activeOptions = getOptions();
|
|
86
|
+
const nextOptionIndex = currentOption ? activeOptions.indexOf(currentOption) + moves : 0;
|
|
87
|
+
return activeOptions[nextOptionIndex] || activeOptions[activeOptions.length - 1];
|
|
88
|
+
};
|
|
89
|
+
const findPreviousOption = (currentOption, moves) => {
|
|
90
|
+
const activeOptions = getOptions();
|
|
91
|
+
const currentOptionIndex = activeOptions.findIndex(
|
|
92
|
+
(i) => i.id === currentOption.id
|
|
93
|
+
);
|
|
94
|
+
return activeOptions[currentOptionIndex - moves] || activeOptions[0];
|
|
95
|
+
};
|
|
96
|
+
const select = React.useCallback(
|
|
97
|
+
(event) => {
|
|
98
|
+
const newValue = event.currentTarget.dataset.value;
|
|
99
|
+
if (event.type === "click") {
|
|
100
|
+
setShowFocusRing(false);
|
|
101
|
+
}
|
|
102
|
+
const activeOptions = getOptions();
|
|
103
|
+
const isActiveOption = activeOptions.findIndex((i) => i.id === event.currentTarget.id) !== -1;
|
|
104
|
+
if (newValue && selectedItem !== newValue && isActiveOption) {
|
|
105
|
+
selectItem(event.currentTarget);
|
|
106
|
+
onChange == null ? void 0 : onChange(event, { value: newValue });
|
|
107
|
+
}
|
|
108
|
+
},
|
|
109
|
+
[selectItem, selectedItem, onChange, getOptions]
|
|
110
|
+
);
|
|
111
|
+
const isSelected = React.useCallback(
|
|
112
|
+
(id2) => selectedItem === id2,
|
|
113
|
+
[selectedItem]
|
|
114
|
+
);
|
|
115
|
+
const isFocused = React.useCallback(
|
|
116
|
+
(id2) => activeDescendant === id2 && showFocusRing,
|
|
117
|
+
[activeDescendant, showFocusRing]
|
|
118
|
+
);
|
|
119
|
+
const getActiveItem = () => {
|
|
120
|
+
const activeOptions = getOptions();
|
|
121
|
+
const activeIndex = activeOptions.findIndex(
|
|
122
|
+
(i) => i.id === activeDescendant
|
|
123
|
+
);
|
|
124
|
+
return activeOptions[activeIndex !== -1 ? activeIndex : 0];
|
|
125
|
+
};
|
|
126
|
+
const blurHandler = () => {
|
|
127
|
+
setShowFocusRing(false);
|
|
128
|
+
};
|
|
129
|
+
const mouseDownHandler = () => {
|
|
130
|
+
setShowFocusRing(false);
|
|
131
|
+
};
|
|
132
|
+
const focusHandler = () => {
|
|
133
|
+
const activeElement = getActiveItem();
|
|
134
|
+
focusAndMoveActive(activeElement);
|
|
135
|
+
};
|
|
136
|
+
const keyDownHandler = (event) => {
|
|
137
|
+
const { key } = event;
|
|
138
|
+
const currentItem = getActiveItem();
|
|
139
|
+
let nextItem = currentItem;
|
|
140
|
+
if (!currentItem) {
|
|
141
|
+
return;
|
|
142
|
+
}
|
|
143
|
+
switch (key) {
|
|
144
|
+
case "ArrowUp":
|
|
145
|
+
case "ArrowDown":
|
|
146
|
+
nextItem = key === "ArrowUp" ? findPreviousOption(currentItem, 1) : findNextOption(currentItem, 1);
|
|
147
|
+
if (nextItem && nextItem !== currentItem) {
|
|
148
|
+
event.preventDefault();
|
|
149
|
+
focusAndMoveActive(nextItem);
|
|
150
|
+
}
|
|
151
|
+
break;
|
|
152
|
+
case "Home":
|
|
153
|
+
event.preventDefault();
|
|
154
|
+
focusFirstItem();
|
|
155
|
+
break;
|
|
156
|
+
case "End":
|
|
157
|
+
event.preventDefault();
|
|
158
|
+
focusLastItem();
|
|
159
|
+
break;
|
|
160
|
+
case " ":
|
|
161
|
+
case "Enter":
|
|
162
|
+
event.preventDefault();
|
|
163
|
+
nextItem && selectItem(nextItem);
|
|
164
|
+
break;
|
|
165
|
+
}
|
|
166
|
+
};
|
|
167
|
+
const contextValue = React.useMemo(
|
|
168
|
+
() => ({
|
|
169
|
+
disabled,
|
|
170
|
+
id,
|
|
171
|
+
select,
|
|
172
|
+
isSelected,
|
|
173
|
+
isFocused
|
|
174
|
+
}),
|
|
175
|
+
[disabled, id, select, isSelected, isFocused]
|
|
176
|
+
);
|
|
177
|
+
return {
|
|
178
|
+
focusHandler,
|
|
179
|
+
keyDownHandler,
|
|
180
|
+
blurHandler,
|
|
181
|
+
mouseDownHandler,
|
|
182
|
+
activeDescendant,
|
|
183
|
+
contextValue
|
|
184
|
+
};
|
|
185
|
+
};
|
|
186
|
+
|
|
187
|
+
exports.useList = useList;
|
|
188
|
+
//# sourceMappingURL=useList.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useList.js","sources":["../src/list-next/useList.ts"],"sourcesContent":["import {\n KeyboardEvent,\n RefObject,\n SyntheticEvent,\n useCallback,\n useMemo,\n useState,\n} from \"react\";\nimport { useControlled } from \"@salt-ds/core\";\n\ninterface UseListProps {\n /**\n * If true, all items in list will be disabled.\n */\n disabled?: boolean;\n /* Value for the uncontrolled version. */\n selected?: string;\n /* Initial value for the uncontrolled version. */\n defaultSelected?: string;\n /* Callback for the controlled version. */\n onChange?: (e: SyntheticEvent, data: { value: string }) => void;\n id?: string;\n ref: RefObject<HTMLUListElement>;\n}\n\nexport const useList = ({\n disabled = false,\n selected: selectedProp,\n defaultSelected,\n onChange,\n id,\n ref,\n}: UseListProps) => {\n const [activeDescendant, setActiveDescendant] = useState<string | undefined>(\n undefined\n );\n\n const [showFocusRing, setShowFocusRing] = useState<boolean>(false);\n const [selectedItem, setSelectedItem] = useControlled({\n controlled: selectedProp,\n default: defaultSelected,\n name: \"ListNext\",\n state: \"selected\",\n });\n\n const getOptions: () => HTMLElement[] = useCallback(() => {\n return Array.from(\n ref.current?.querySelectorAll('[role=\"option\"]:not([aria-disabled])') ??\n []\n );\n }, [ref]);\n\n const updateScroll = useCallback(\n (currentTarget: Element) => {\n const list = ref.current;\n if (!list || !currentTarget) return;\n const { offsetTop, offsetHeight } = currentTarget as HTMLLIElement;\n const listHeight = list?.clientHeight;\n const listScrollTop = list?.scrollTop;\n if (offsetTop < listScrollTop) {\n list.scrollTop = offsetTop;\n } else if (offsetTop + offsetHeight > listScrollTop + listHeight) {\n list.scrollTop = offsetTop + offsetHeight - listHeight;\n }\n },\n [ref]\n );\n\n const updateActiveDescendant = useCallback(\n (element: HTMLElement) => {\n setActiveDescendant(element.id);\n updateScroll(element);\n },\n [setActiveDescendant, updateScroll]\n );\n const selectItem = useCallback(\n (element: HTMLElement) => {\n const newValue = element?.dataset.value;\n if (newValue) {\n setSelectedItem(newValue);\n updateActiveDescendant(element);\n }\n },\n [setSelectedItem, updateActiveDescendant]\n );\n\n const focusAndMoveActive = (element: HTMLElement) => {\n setShowFocusRing(true);\n updateActiveDescendant(element);\n };\n\n const focusFirstItem = () => {\n // Find first active item\n const activeOptions = getOptions();\n const firstItem = activeOptions[0];\n if (firstItem) {\n focusAndMoveActive(firstItem);\n }\n };\n const focusLastItem = () => {\n // Find last active item\n const activeOptions = getOptions();\n const lastItem = activeOptions[activeOptions.length - 1];\n if (lastItem) {\n focusAndMoveActive(lastItem);\n updateScroll(lastItem);\n }\n };\n\n const findNextOption = (\n currentOption: HTMLElement | null,\n moves: number\n ): HTMLElement => {\n const activeOptions = getOptions();\n // Returns next item, if no current option it will return 0\n const nextOptionIndex = currentOption\n ? activeOptions.indexOf(currentOption) + moves\n : 0;\n return (\n activeOptions[nextOptionIndex] || activeOptions[activeOptions.length - 1]\n );\n };\n\n const findPreviousOption = (\n currentOption: HTMLElement,\n moves: number\n ): HTMLElement => {\n // Return the previous option if it exists; otherwise, returns first option\n const activeOptions = getOptions();\n const currentOptionIndex = activeOptions.findIndex(\n (i) => i.id === currentOption.id\n );\n return activeOptions[currentOptionIndex - moves] || activeOptions[0];\n };\n\n // CONTEXT CALLBACKS\n const select = useCallback(\n (event: SyntheticEvent<HTMLLIElement>) => {\n const newValue = event.currentTarget.dataset.value;\n if (event.type === \"click\") {\n setShowFocusRing(false);\n }\n const activeOptions = getOptions();\n const isActiveOption =\n activeOptions.findIndex((i) => i.id === event.currentTarget.id) !== -1;\n if (newValue && selectedItem !== newValue && isActiveOption) {\n selectItem(event.currentTarget);\n onChange?.(event, { value: newValue });\n }\n },\n [selectItem, selectedItem, onChange, getOptions]\n );\n\n const isSelected = useCallback(\n (id: string) => selectedItem === id,\n [selectedItem]\n );\n\n const isFocused = useCallback(\n (id: string | undefined) => activeDescendant === id && showFocusRing,\n [activeDescendant, showFocusRing]\n );\n\n const getActiveItem = () => {\n const activeOptions = getOptions();\n const activeIndex = activeOptions.findIndex(\n (i) => i.id === activeDescendant\n );\n return activeOptions[activeIndex !== -1 ? activeIndex : 0];\n };\n\n // HANDLERS\n const blurHandler = () => {\n setShowFocusRing(false);\n };\n\n const mouseDownHandler = () => {\n // When list gets focused, we can't guarantee that focus happens after click event.\n // If first focus (where !activeDescendant) happens from a click, list shouldn't render focus ring in the first element.\n setShowFocusRing(false);\n };\n\n // takes care of focus when using keyboard navigation\n const focusHandler = () => {\n const activeElement = getActiveItem();\n focusAndMoveActive(activeElement);\n };\n\n // takes care of keydown when using keyboard navigation\n const keyDownHandler = (event: KeyboardEvent<HTMLUListElement>) => {\n const { key } = event;\n const currentItem = getActiveItem();\n let nextItem = currentItem;\n if (!currentItem) {\n return;\n }\n switch (key) {\n case \"ArrowUp\":\n case \"ArrowDown\":\n nextItem =\n key === \"ArrowUp\"\n ? findPreviousOption(currentItem, 1)\n : findNextOption(currentItem, 1);\n\n if (nextItem && nextItem !== currentItem) {\n event.preventDefault();\n focusAndMoveActive(nextItem);\n }\n break;\n case \"Home\":\n event.preventDefault();\n focusFirstItem();\n break;\n case \"End\":\n event.preventDefault();\n focusLastItem();\n break;\n case \" \":\n case \"Enter\":\n event.preventDefault();\n nextItem && selectItem(nextItem);\n break;\n default:\n break;\n }\n };\n\n // CONTEXT\n const contextValue = useMemo(\n () => ({\n disabled,\n id,\n select,\n isSelected,\n isFocused,\n }),\n [disabled, id, select, isSelected, isFocused]\n );\n\n return {\n focusHandler,\n keyDownHandler,\n blurHandler,\n mouseDownHandler,\n activeDescendant,\n contextValue,\n };\n};\n"],"names":["useState","useControlled","useCallback","id","useMemo"],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var css_248z = "
|
|
3
|
+
var css_248z = "/* Styles for Logo */\n.saltLogo {\n display: inline-flex;\n position: relative;\n align-items: center;\n justify-content: center;\n height: var(--salt-size-base);\n}\n\n.saltLogo svg {\n fill: var(--salt-text-secondary-foreground);\n stroke: none;\n}\n";
|
|
4
4
|
|
|
5
5
|
module.exports = css_248z;
|
|
6
6
|
//# sourceMappingURL=Logo.css.js.map
|
package/dist-cjs/logo/Logo.js
CHANGED
|
@@ -6,55 +6,23 @@ var jsxRuntime = require('react/jsx-runtime');
|
|
|
6
6
|
var React = require('react');
|
|
7
7
|
var clsx = require('clsx');
|
|
8
8
|
var core = require('@salt-ds/core');
|
|
9
|
-
var LogoTitle = require('./internal/LogoTitle.js');
|
|
10
9
|
var window = require('@salt-ds/window');
|
|
11
10
|
var styles = require('@salt-ds/styles');
|
|
12
11
|
var Logo$1 = require('./Logo.css.js');
|
|
13
12
|
|
|
14
13
|
const withBaseName = core.makePrefixer("saltLogo");
|
|
15
14
|
const Logo = React.forwardRef(function Logo2(props, ref) {
|
|
16
|
-
const {
|
|
17
|
-
appTitle,
|
|
18
|
-
className,
|
|
19
|
-
compact,
|
|
20
|
-
src,
|
|
21
|
-
ImageProps,
|
|
22
|
-
LogoImageComponent = "img",
|
|
23
|
-
TitleProps,
|
|
24
|
-
...rest
|
|
25
|
-
} = props;
|
|
15
|
+
const { className, ...rest } = props;
|
|
26
16
|
const targetWindow = window.useWindow();
|
|
27
17
|
styles.useComponentCssInjection({
|
|
28
18
|
testId: "salt-logo",
|
|
29
19
|
css: Logo$1,
|
|
30
20
|
window: targetWindow
|
|
31
21
|
});
|
|
32
|
-
return /* @__PURE__ */ jsxRuntime.
|
|
33
|
-
className: clsx.clsx(withBaseName(), className,
|
|
34
|
-
[withBaseName("compact")]: compact
|
|
35
|
-
}),
|
|
22
|
+
return /* @__PURE__ */ jsxRuntime.jsx("span", {
|
|
23
|
+
className: clsx.clsx(withBaseName(), className),
|
|
36
24
|
ref,
|
|
37
|
-
...rest
|
|
38
|
-
children: [
|
|
39
|
-
/* @__PURE__ */ jsxRuntime.jsx("span", {
|
|
40
|
-
className: withBaseName("wrapper"),
|
|
41
|
-
children: /* @__PURE__ */ jsxRuntime.jsx(LogoImageComponent, {
|
|
42
|
-
...ImageProps,
|
|
43
|
-
className: clsx.clsx(withBaseName("logo"), ImageProps == null ? void 0 : ImageProps.className),
|
|
44
|
-
src,
|
|
45
|
-
alt: (ImageProps == null ? void 0 : ImageProps.alt) || "Logo"
|
|
46
|
-
})
|
|
47
|
-
}),
|
|
48
|
-
/* @__PURE__ */ jsxRuntime.jsx(LogoTitle.LogoTitle, {
|
|
49
|
-
...TitleProps,
|
|
50
|
-
className: clsx.clsx(withBaseName("appTitle"), TitleProps == null ? void 0 : TitleProps.className),
|
|
51
|
-
label: appTitle,
|
|
52
|
-
separatorClassname: clsx.clsx(
|
|
53
|
-
withBaseName("titlePipe"),
|
|
54
|
-
TitleProps == null ? void 0 : TitleProps.separatorClassname
|
|
55
|
-
)
|
|
56
|
-
})
|
|
57
|
-
]
|
|
25
|
+
...rest
|
|
58
26
|
});
|
|
59
27
|
});
|
|
60
28
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Logo.js","sources":["../src/logo/Logo.tsx"],"sourcesContent":["import { ComponentPropsWithoutRef,
|
|
1
|
+
{"version":3,"file":"Logo.js","sources":["../src/logo/Logo.tsx"],"sourcesContent":["import { ComponentPropsWithoutRef, forwardRef } from \"react\";\nimport { clsx } from \"clsx\";\nimport { makePrefixer } from \"@salt-ds/core\";\n\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport logoCss from \"./Logo.css\";\n\nexport type LogoProps = ComponentPropsWithoutRef<\"span\">;\n\nconst withBaseName = makePrefixer(\"saltLogo\");\n\nexport const Logo = forwardRef<HTMLSpanElement, LogoProps>(function Logo(\n props,\n ref\n) {\n const { className, ...rest } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-logo\",\n css: logoCss,\n window: targetWindow,\n });\n\n return (\n <span className={clsx(withBaseName(), className)} ref={ref} {...rest} />\n );\n});\n"],"names":["makePrefixer","forwardRef","Logo","useWindow","useComponentCssInjection","logoCss","jsx","clsx"],"mappings":";;;;;;;;;;;;AAWA,MAAM,YAAA,GAAeA,kBAAa,UAAU,CAAA,CAAA;AAErC,MAAM,IAAO,GAAAC,gBAAA,CAAuC,SAASC,KAAAA,CAClE,OACA,GACA,EAAA;AACA,EAAM,MAAA,EAAE,SAAc,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAE/B,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,WAAA;AAAA,IACR,GAAK,EAAAC,MAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAA,uBACGC,cAAA,CAAA,MAAA,EAAA;AAAA,IAAK,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,IAAG,GAAA;AAAA,IAAW,GAAG,IAAA;AAAA,GAAM,CAAA,CAAA;AAE1E,CAAC;;;;"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
6
|
+
var React = require('react');
|
|
7
|
+
var clsx = require('clsx');
|
|
8
|
+
var core = require('@salt-ds/core');
|
|
9
|
+
|
|
10
|
+
const withBaseName = core.makePrefixer("saltLogoImage");
|
|
11
|
+
const LogoImage = React.forwardRef(
|
|
12
|
+
function LogoImage2(props, ref) {
|
|
13
|
+
const { className, alt, ...rest } = props;
|
|
14
|
+
return /* @__PURE__ */ jsxRuntime.jsx("img", {
|
|
15
|
+
...rest,
|
|
16
|
+
alt,
|
|
17
|
+
className: clsx.clsx(withBaseName(), className),
|
|
18
|
+
ref
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
);
|
|
22
|
+
|
|
23
|
+
exports.LogoImage = LogoImage;
|
|
24
|
+
//# sourceMappingURL=LogoImage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LogoImage.js","sources":["../src/logo/LogoImage.tsx"],"sourcesContent":["import { ComponentPropsWithoutRef, forwardRef } from \"react\";\nimport { clsx } from \"clsx\";\nimport { makePrefixer } from \"@salt-ds/core\";\n\nexport interface LogoImageProps\n extends Omit<ComponentPropsWithoutRef<\"img\">, \"alt\"> {\n alt: string;\n}\n\nconst withBaseName = makePrefixer(\"saltLogoImage\");\n\nexport const LogoImage = forwardRef<HTMLImageElement, LogoImageProps>(\n function LogoImage(props, ref) {\n const { className, alt, ...rest } = props;\n\n return (\n <img\n {...rest}\n alt={alt}\n className={clsx(withBaseName(), className)}\n ref={ref}\n />\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","LogoImage","jsx","clsx"],"mappings":";;;;;;;;;AASA,MAAM,YAAA,GAAeA,kBAAa,eAAe,CAAA,CAAA;AAE1C,MAAM,SAAY,GAAAC,gBAAA;AAAA,EACvB,SAASC,UAAU,CAAA,KAAA,EAAO,GAAK,EAAA;AAC7B,IAAA,MAAM,EAAE,SAAA,EAAW,GAAQ,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAEpC,IAAA,uBACGC,cAAA,CAAA,KAAA,EAAA;AAAA,MACE,GAAG,IAAA;AAAA,MACJ,GAAA;AAAA,MACA,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MACzC,GAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var css_248z = "/* Styles for LogoSeparator */\n.saltLogoSeparator {\n height: var(--salt-size-separator-height);\n margin: 0 var(--salt-spacing-100);\n border-right: var(--salt-size-border) var(--salt-separable-borderStyle) var(--salt-separable-primary-borderColor);\n}\n";
|
|
4
|
+
|
|
5
|
+
module.exports = css_248z;
|
|
6
|
+
//# sourceMappingURL=LogoSeparator.css.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LogoSeparator.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
6
|
+
var React = require('react');
|
|
7
|
+
var clsx = require('clsx');
|
|
8
|
+
var core = require('@salt-ds/core');
|
|
9
|
+
var window = require('@salt-ds/window');
|
|
10
|
+
var styles = require('@salt-ds/styles');
|
|
11
|
+
var LogoSeparator$1 = require('./LogoSeparator.css.js');
|
|
12
|
+
|
|
13
|
+
const withBaseName = core.makePrefixer("saltLogoSeparator");
|
|
14
|
+
const LogoSeparator = React.forwardRef(
|
|
15
|
+
function LogoSeparator2(props, ref) {
|
|
16
|
+
const { className, ...rest } = props;
|
|
17
|
+
const targetWindow = window.useWindow();
|
|
18
|
+
styles.useComponentCssInjection({
|
|
19
|
+
testId: "salt-logo-separator",
|
|
20
|
+
css: LogoSeparator$1,
|
|
21
|
+
window: targetWindow
|
|
22
|
+
});
|
|
23
|
+
return /* @__PURE__ */ jsxRuntime.jsx("span", {
|
|
24
|
+
...rest,
|
|
25
|
+
className: clsx.clsx(withBaseName(), className),
|
|
26
|
+
ref
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
);
|
|
30
|
+
|
|
31
|
+
exports.LogoSeparator = LogoSeparator;
|
|
32
|
+
//# sourceMappingURL=LogoSeparator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LogoSeparator.js","sources":["../src/logo/LogoSeparator.tsx"],"sourcesContent":["import { ComponentPropsWithoutRef, forwardRef } from \"react\";\nimport { clsx } from \"clsx\";\nimport { makePrefixer } from \"@salt-ds/core\";\n\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport logoSeparatorCss from \"./LogoSeparator.css\";\n\nexport type LogoSeparatorProps = ComponentPropsWithoutRef<\"span\">;\n\nconst withBaseName = makePrefixer(\"saltLogoSeparator\");\n\nexport const LogoSeparator = forwardRef<HTMLImageElement, LogoSeparatorProps>(\n function LogoSeparator(props, ref) {\n const { className, ...rest } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-logo-separator\",\n css: logoSeparatorCss,\n window: targetWindow,\n });\n\n return (\n <span {...rest} className={clsx(withBaseName(), className)} ref={ref} />\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","LogoSeparator","useWindow","useComponentCssInjection","logoSeparatorCss","jsx","clsx"],"mappings":";;;;;;;;;;;;AAWA,MAAM,YAAA,GAAeA,kBAAa,mBAAmB,CAAA,CAAA;AAE9C,MAAM,aAAgB,GAAAC,gBAAA;AAAA,EAC3B,SAASC,cAAc,CAAA,KAAA,EAAO,GAAK,EAAA;AACjC,IAAM,MAAA,EAAE,SAAc,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAE/B,IAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,IAAyBC,+BAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,qBAAA;AAAA,MACR,GAAK,EAAAC,eAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAA,uBACGC,cAAA,CAAA,MAAA,EAAA;AAAA,MAAM,GAAG,IAAA;AAAA,MAAM,SAAW,EAAAC,SAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MAAG,GAAA;AAAA,KAAU,CAAA,CAAA;AAAA,GAE1E;AACF;;;;"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var css_248z = "/* Style applied to the root element */\n.saltMultilineInput {\n --multilineInput-borderColor: var(--salt-editable-borderColor);\n --multilineInput-borderStyle: var(--salt-editable-borderStyle);\n --multilineInput-outlineColor: var(--salt-focused-outlineColor);\n --multilineInput-paddingLeft: var(--salt-spacing-100);\n --multilineInput-border: none;\n --multilineInput-activationIndicator-borderWidth: var(--salt-size-border);\n\n align-items: center;\n background: var(--multilineInput-background);\n border: var(--multilineInput-border);\n color: var(--salt-text-primary-foreground);\n display: inline-flex;\n font-family: var(--salt-text-fontFamily);\n font-size: var(--salt-text-fontSize);\n height: auto;\n line-height: var(--salt-text-lineHeight);\n min-height: var(--salt-size-base);\n min-width: 4em;\n padding-inline: var(--salt-spacing-100);\n position: relative;\n width: 100%;\n}\n\n/* Style applied on hover */\n.saltMultilineInput:hover {\n --multilineInput-borderStyle: var(--salt-editable-borderStyle-hover);\n --multilineInput-borderColor: var(--salt-editable-borderColor-hover);\n\n background: var(--multilineInput-background-hover);\n cursor: var(--salt-editable-cursor-hover);\n}\n\n/* Style applied when active */\n.saltMultilineInput:active {\n --multilineInput-borderColor: var(--salt-editable-borderColor-active);\n --multilineInput-borderStyle: var(--salt-editable-borderStyle-active);\n --multilineInput-activationIndicator-borderWidth: var(--salt-editable-borderWidth-active);\n\n background: var(--multilineInput-background-active);\n cursor: var(--salt-editable-cursor-active);\n}\n\n/* Class applied if `variant=\"primary\"` */\n.saltMultilineInput-primary {\n --multilineInput-background: var(--salt-editable-primary-background);\n --multilineInput-background-active: var(--salt-editable-primary-background-active);\n --multilineInput-background-hover: var(--salt-editable-primary-background-hover);\n --multilineInput-background-disabled: var(--salt-editable-primary-background-disabled);\n --multilineInput-background-readonly: var(--salt-editable-primary-background-readonly);\n}\n\n/* Class applied if `variant=\"secondary\"` */\n.saltMultilineInput-secondary {\n --multilineInput-background: var(--salt-editable-secondary-background);\n --multilineInput-background-active: var(--salt-editable-secondary-background-active);\n --multilineInput-background-hover: var(--salt-editable-secondary-background-active);\n --multilineInput-background-disabled: var(--salt-editable-secondary-background-disabled);\n --multilineInput-background-readonly: var(--salt-editable-secondary-background-readonly);\n}\n\n/* Style applied to input if `validationState=\"error\"` */\n.saltMultilineInput-error,\n.saltMultilineInput-error:hover {\n --multilineInput-background: var(--salt-status-error-background);\n --multilineInput-background-active: var(--salt-status-error-background);\n --multilineInput-background-hover: var(--salt-status-error-background);\n --multilineInput-borderColor: var(--salt-status-error-borderColor);\n --multilineInput-outlineColor: var(--salt-status-error-borderColor);\n}\n\n/* Style applied to input if `validationState=\"warning\"` */\n.saltMultilineInput-warning,\n.saltMultilineInput-warning:hover {\n --multilineInput-background: var(--salt-status-warning-background);\n --multilineInput-background-active: var(--salt-status-warning-background);\n --multilineInput-background-hover: var(--salt-status-warning-background);\n --multilineInput-borderColor: var(--salt-status-warning-borderColor);\n --multilineInput-outlineColor: var(--salt-status-warning-borderColor);\n}\n\n/* Style applied to input if `validationState=\"success\"` */\n.saltMultilineInput-success,\n.saltMultilineInput-success:hover {\n --multilineInput-background: var(--salt-status-success-background);\n --multilineInput-background-active: var(--salt-status-success-background);\n --multilineInput-background-hover: var(--salt-status-success-background);\n --multilineInput-borderColor: var(--salt-status-success-borderColor);\n --multilineInput-outlineColor: var(--salt-status-success-borderColor);\n}\n\n/* Style applied to inner textarea element */\n.saltMultilineInput-textarea {\n background: none;\n border: none;\n box-sizing: content-box;\n color: inherit;\n cursor: inherit;\n display: block;\n flex: 1;\n font: inherit;\n letter-spacing: 0;\n margin: 0;\n min-width: 0;\n overflow: hidden;\n resize: none;\n padding: var(--salt-spacing-100) 0;\n text-align: var(--multilineInput-textAlign);\n width: 100%;\n}\n\n/* Reset in the class */\n.saltMultilineInput-textarea:focus {\n outline: none;\n}\n\n/* Style applied to selected input */\n.saltMultilineInput-textarea::selection {\n background: var(--salt-text-background-selected);\n}\n\n/* Styling when focused */\n.saltMultilineInput-focused {\n --multilineInput-borderColor: var(--multilineInput-outlineColor);\n --multilineInput-activationIndicator-borderWidth: var(--salt-editable-borderWidth-active);\n\n outline: var(--salt-focused-outlineWidth) var(--salt-focused-outlineStyle) var(--multilineInput-outlineColor);\n}\n\n/* Style applied if `readOnly={true}` */\n.saltMultilineInput.saltMultilineInput-readOnly,\n.saltMultilineInput.saltMultilineInput-readOnly:active,\n.saltMultilineInput.saltMultilineInput-readOnly:hover {\n --multilineInput-borderColor: var(--salt-editable-borderColor-readonly);\n --multilineInput-borderStyle: var(--salt-editable-borderStyle-readonly);\n --multilineInput-activationIndicator-borderWidth: var(--salt-size-border);\n --multilineInput-paddingLeft: 0;\n\n background: var(--multilineInput-background-readonly);\n cursor: var(--salt-editable-cursor-readonly);\n}\n\n/* Style applied to selected text if `disabled={true}` */\n.saltMultilineInput-disabled .saltMultilineInput-textarea::selection {\n background: none;\n}\n\n/* Style applied when `disabled={true}` */\n.saltMultilineInput-disabled,\n.saltMultilineInput-disabled:hover,\n.saltMultilineInput-disabled:active {\n --multilineInput-borderColor: var(--salt-editable-borderColor-disabled);\n --multilineInput-borderStyle: var(--salt-editable-borderStyle-disabled);\n --multilineInput-activationIndicator-borderWidth: var(--salt-size-border);\n\n background: var(--multilineInput-background-disabled);\n cursor: var(--salt-editable-cursor-disabled);\n color: var(--salt-text-primary-foreground-disabled);\n}\n\n/* Style for activation indicator */\n.saltMultilineInput-activationIndicator {\n left: 0;\n bottom: 0;\n width: 100%;\n position: absolute;\n border-bottom: var(--multilineInput-activationIndicator-borderWidth) var(--multilineInput-borderStyle) var(--multilineInput-borderColor);\n}\n\n/* Style applied if `fullBorder={true}` */\n.saltMultilineInput.saltMultilineInput-fullBorder {\n --multilineInput-border: var(--salt-size-border) var(--salt-container-borderStyle) var(--multilineInput-borderColor);\n --multilineInput-paddingLeft: var(--salt-spacing-100);\n --multilineInput-activationIndicator-borderWidth: 0;\n}\n\n/* Style applied if active or focused when `fullBorder={true}` */\n.saltMultilineInput-fullBorder:active,\n.saltMultilineInput-fullBorder.saltMultilineInput-focused {\n --multilineInput-activationIndicator-borderWidth: var(--salt-editable-borderWidth-active);\n}\n\n/* Styling when focused if `disabled={true}` or `readOnly={true}` when `fullBorder={true}` */\n.saltMultilineInput-fullBorder.saltMultilineInput-readOnly:hover,\n.saltMultilineInput-fullBorder.saltMultilineInput-disabled:hover {\n --multilineInput-activationIndicator-borderWidth: 0;\n}\n\n/* Style applied to adornment containers */\n.saltMultilineInput-endAdornmentContainer,\n.saltMultilineInput-startAdornmentContainer {\n align-items: center;\n display: inline-flex;\n min-height: calc(var(--salt-size-base) + var(--salt-spacing-100));\n column-gap: var(--salt-spacing-100);\n}\n\n/* Style applied to start adornment container */\n.saltMultilineInput-startAdornmentContainer {\n align-self: self-start;\n padding-right: var(--salt-spacing-100);\n}\n\n/* Style applied to end adornment container */\n.saltMultilineInput-endAdornmentContainer {\n align-self: self-end;\n padding-left: var(--salt-spacing-100);\n}\n\n/* Style applied to status adornment container */\n.saltMultilineInput-statusAdornmentContainer {\n align-self: self-end;\n display: inline-flex;\n min-height: calc(var(--salt-size-base) + var(--salt-spacing-100));\n}\n\n/* Style applied to button start adornment if first child */\n.saltMultilineInput-startAdornmentContainer .saltButton:first-child {\n margin-left: calc(var(--salt-spacing-50) * -1);\n}\n\n/* Style applied to button end adornment if last child */\n.saltMultilineInput-endAdornmentContainer .saltButton:last-child {\n margin-right: calc(var(--salt-spacing-50) * -1);\n}\n\n/* Styles for button adornment */\n.saltMultilineInput .saltButton {\n --saltButton-padding: 0;\n --saltButton-height: calc(var(--salt-size-base) - var(--salt-spacing-50));\n --saltButton-width: calc(var(--salt-size-base) - var(--salt-spacing-50));\n}\n";
|
|
4
|
+
|
|
5
|
+
module.exports = css_248z;
|
|
6
|
+
//# sourceMappingURL=MultilineInput.css.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MultilineInput.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
6
|
+
var clsx = require('clsx');
|
|
7
|
+
var React = require('react');
|
|
8
|
+
var core = require('@salt-ds/core');
|
|
9
|
+
var styles = require('@salt-ds/styles');
|
|
10
|
+
var window = require('@salt-ds/window');
|
|
11
|
+
var MultilineInput$1 = require('./MultilineInput.css.js');
|
|
12
|
+
|
|
13
|
+
const withBaseName = core.makePrefixer("saltMultilineInput");
|
|
14
|
+
const MultilineInput = React.forwardRef(
|
|
15
|
+
function MultilineInput2({
|
|
16
|
+
"aria-activedescendant": ariaActiveDescendant,
|
|
17
|
+
"aria-expanded": ariaExpanded,
|
|
18
|
+
"aria-owns": ariaOwns,
|
|
19
|
+
className: classNameProp,
|
|
20
|
+
disabled,
|
|
21
|
+
endAdornment,
|
|
22
|
+
fullBorder = false,
|
|
23
|
+
id,
|
|
24
|
+
textAreaProps = {},
|
|
25
|
+
textAreaRef,
|
|
26
|
+
placeholder,
|
|
27
|
+
readOnly,
|
|
28
|
+
role,
|
|
29
|
+
rows = 3,
|
|
30
|
+
startAdornment,
|
|
31
|
+
value: valueProp,
|
|
32
|
+
defaultValue: defaultValueProp = valueProp === void 0 ? "" : void 0,
|
|
33
|
+
validationStatus: validationStatusProp,
|
|
34
|
+
variant = "primary",
|
|
35
|
+
...other
|
|
36
|
+
}, ref) {
|
|
37
|
+
const targetWindow = window.useWindow();
|
|
38
|
+
styles.useComponentCssInjection({
|
|
39
|
+
testId: "salt-multiline-input",
|
|
40
|
+
css: MultilineInput$1,
|
|
41
|
+
window: targetWindow
|
|
42
|
+
});
|
|
43
|
+
const restA11yProps = {
|
|
44
|
+
"aria-activedescendant": ariaActiveDescendant,
|
|
45
|
+
"aria-expanded": ariaExpanded,
|
|
46
|
+
"aria-owns": ariaOwns
|
|
47
|
+
};
|
|
48
|
+
const [focused, setFocused] = React.useState(false);
|
|
49
|
+
const {
|
|
50
|
+
"aria-describedby": textAreaDescribedBy,
|
|
51
|
+
"aria-labelledby": textAreaLabelledBy,
|
|
52
|
+
onBlur,
|
|
53
|
+
onChange,
|
|
54
|
+
onFocus,
|
|
55
|
+
required: textAreaRequired,
|
|
56
|
+
...restTextAreaProps
|
|
57
|
+
} = textAreaProps;
|
|
58
|
+
const {
|
|
59
|
+
a11yProps: {
|
|
60
|
+
"aria-describedby": formFieldDescribedBy,
|
|
61
|
+
"aria-labelledby": formFieldLabelledBy
|
|
62
|
+
} = {},
|
|
63
|
+
disabled: formFieldDisabled,
|
|
64
|
+
readOnly: formFieldReadOnly,
|
|
65
|
+
necessity: formFieldRequired,
|
|
66
|
+
validationStatus: formFieldValidationStatus
|
|
67
|
+
} = core.useFormFieldProps();
|
|
68
|
+
const isDisabled = disabled || formFieldDisabled;
|
|
69
|
+
const isReadOnly = readOnly || formFieldReadOnly;
|
|
70
|
+
const validationStatus = formFieldValidationStatus != null ? formFieldValidationStatus : validationStatusProp;
|
|
71
|
+
const isRequired = formFieldRequired ? ["required", "asterisk"].includes(formFieldRequired) : textAreaRequired;
|
|
72
|
+
const [value, setValue] = core.useControlled({
|
|
73
|
+
controlled: valueProp,
|
|
74
|
+
default: defaultValueProp,
|
|
75
|
+
name: "MultilineInput",
|
|
76
|
+
state: "value"
|
|
77
|
+
});
|
|
78
|
+
const handleChange = (event) => {
|
|
79
|
+
const value2 = event.target.value;
|
|
80
|
+
setValue(value2);
|
|
81
|
+
onChange == null ? void 0 : onChange(event);
|
|
82
|
+
};
|
|
83
|
+
const handleBlur = (event) => {
|
|
84
|
+
onBlur == null ? void 0 : onBlur(event);
|
|
85
|
+
setFocused(false);
|
|
86
|
+
};
|
|
87
|
+
const handleFocus = (event) => {
|
|
88
|
+
onFocus == null ? void 0 : onFocus(event);
|
|
89
|
+
setFocused(true);
|
|
90
|
+
};
|
|
91
|
+
return /* @__PURE__ */ jsxRuntime.jsxs("div", {
|
|
92
|
+
className: clsx.clsx(
|
|
93
|
+
withBaseName(),
|
|
94
|
+
withBaseName(variant),
|
|
95
|
+
{
|
|
96
|
+
[withBaseName("fullBorder")]: fullBorder,
|
|
97
|
+
[withBaseName("focused")]: !isDisabled && !isReadOnly && focused,
|
|
98
|
+
[withBaseName("disabled")]: isDisabled,
|
|
99
|
+
[withBaseName("readOnly")]: isReadOnly,
|
|
100
|
+
[withBaseName(validationStatus || "")]: validationStatus
|
|
101
|
+
},
|
|
102
|
+
classNameProp
|
|
103
|
+
),
|
|
104
|
+
ref,
|
|
105
|
+
...other,
|
|
106
|
+
children: [
|
|
107
|
+
startAdornment && /* @__PURE__ */ jsxRuntime.jsx("div", {
|
|
108
|
+
className: withBaseName("startAdornmentContainer"),
|
|
109
|
+
children: startAdornment
|
|
110
|
+
}),
|
|
111
|
+
/* @__PURE__ */ jsxRuntime.jsx("textarea", {
|
|
112
|
+
"aria-describedby": clsx.clsx(formFieldDescribedBy, textAreaDescribedBy),
|
|
113
|
+
"aria-labelledby": clsx.clsx(formFieldLabelledBy, textAreaLabelledBy),
|
|
114
|
+
className: clsx.clsx(withBaseName("textarea"), textAreaProps == null ? void 0 : textAreaProps.className),
|
|
115
|
+
disabled: isDisabled,
|
|
116
|
+
id,
|
|
117
|
+
readOnly: isReadOnly,
|
|
118
|
+
ref: textAreaRef,
|
|
119
|
+
required: isRequired,
|
|
120
|
+
role,
|
|
121
|
+
rows,
|
|
122
|
+
tabIndex: isReadOnly || isDisabled ? -1 : 0,
|
|
123
|
+
onBlur: handleBlur,
|
|
124
|
+
onChange: handleChange,
|
|
125
|
+
onFocus: !isDisabled && !isReadOnly ? handleFocus : void 0,
|
|
126
|
+
placeholder,
|
|
127
|
+
value,
|
|
128
|
+
...restA11yProps,
|
|
129
|
+
...restTextAreaProps
|
|
130
|
+
}),
|
|
131
|
+
!isDisabled && !isReadOnly && validationStatus && /* @__PURE__ */ jsxRuntime.jsx("div", {
|
|
132
|
+
className: withBaseName("statusAdornmentContainer"),
|
|
133
|
+
children: /* @__PURE__ */ jsxRuntime.jsx(core.StatusAdornment, {
|
|
134
|
+
status: validationStatus
|
|
135
|
+
})
|
|
136
|
+
}),
|
|
137
|
+
endAdornment && /* @__PURE__ */ jsxRuntime.jsx("div", {
|
|
138
|
+
className: withBaseName("endAdornmentContainer"),
|
|
139
|
+
children: endAdornment
|
|
140
|
+
}),
|
|
141
|
+
/* @__PURE__ */ jsxRuntime.jsx("div", {
|
|
142
|
+
className: withBaseName("activationIndicator")
|
|
143
|
+
})
|
|
144
|
+
]
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
);
|
|
148
|
+
|
|
149
|
+
exports.MultilineInput = MultilineInput;
|
|
150
|
+
//# sourceMappingURL=MultilineInput.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MultilineInput.js","sources":["../src/multiline-input/MultilineInput.tsx"],"sourcesContent":["import { clsx } from \"clsx\";\nimport {\n ChangeEvent,\n ComponentPropsWithoutRef,\n FocusEvent,\n forwardRef,\n ReactNode,\n Ref,\n TextareaHTMLAttributes,\n useState,\n} from \"react\";\nimport {\n makePrefixer,\n StatusAdornment,\n useControlled,\n useFormFieldProps,\n} from \"@salt-ds/core\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport multilineInputCss from \"./MultilineInput.css\";\n\nconst withBaseName = makePrefixer(\"saltMultilineInput\");\n\nexport interface MultilineInputProps\n extends Omit<ComponentPropsWithoutRef<\"div\">, \"defaultValue\">,\n Pick<\n ComponentPropsWithoutRef<\"input\">,\n \"disabled\" | \"value\" | \"defaultValue\" | \"placeholder\"\n > {\n /**\n * End adornment component\n */\n endAdornment?: ReactNode;\n /**\n * Styling variant with full border. Defaults to false\n */\n fullBorder?: boolean;\n /**\n * [Attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/textarea#Attributes) applied to the `textarea` element.\n */\n textAreaProps?: TextareaHTMLAttributes<HTMLTextAreaElement>;\n /**\n * Optional ref for the textarea component\n */\n textAreaRef?: Ref<HTMLTextAreaElement>;\n /**\n * If `true`, the component is read only.\n */\n readOnly?: boolean;\n /**\n * Start adornment component\n */\n startAdornment?: ReactNode;\n /**\n * Validation status.\n */\n validationStatus?: \"error\" | \"warning\" | \"success\";\n /**\n * Styling variant. Defaults to \"primary\".\n */\n variant?: \"primary\" | \"secondary\";\n /**\n * Number of rows. Defaults to 3\n */\n rows?: number;\n}\n\nexport const MultilineInput = forwardRef<HTMLDivElement, MultilineInputProps>(\n function MultilineInput(\n {\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-expanded\": ariaExpanded,\n \"aria-owns\": ariaOwns,\n className: classNameProp,\n disabled,\n endAdornment,\n fullBorder = false,\n id,\n textAreaProps = {},\n textAreaRef,\n placeholder,\n readOnly,\n role,\n rows = 3,\n startAdornment,\n value: valueProp,\n defaultValue: defaultValueProp = valueProp === undefined ? \"\" : undefined,\n validationStatus: validationStatusProp,\n variant = \"primary\",\n ...other\n },\n ref\n ) {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-multiline-input\",\n css: multilineInputCss,\n window: targetWindow,\n });\n\n const restA11yProps = {\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-expanded\": ariaExpanded,\n \"aria-owns\": ariaOwns,\n };\n\n const [focused, setFocused] = useState(false);\n\n const {\n \"aria-describedby\": textAreaDescribedBy,\n \"aria-labelledby\": textAreaLabelledBy,\n onBlur,\n onChange,\n onFocus,\n required: textAreaRequired,\n ...restTextAreaProps\n } = textAreaProps;\n\n const {\n a11yProps: {\n \"aria-describedby\": formFieldDescribedBy,\n \"aria-labelledby\": formFieldLabelledBy,\n } = {},\n disabled: formFieldDisabled,\n readOnly: formFieldReadOnly,\n necessity: formFieldRequired,\n validationStatus: formFieldValidationStatus,\n } = useFormFieldProps();\n\n const isDisabled = disabled || formFieldDisabled;\n const isReadOnly = readOnly || formFieldReadOnly;\n const validationStatus = formFieldValidationStatus ?? validationStatusProp;\n const isRequired = formFieldRequired\n ? [\"required\", \"asterisk\"].includes(formFieldRequired)\n : undefined ?? textAreaRequired;\n\n const [value, setValue] = useControlled({\n controlled: valueProp,\n default: defaultValueProp,\n name: \"MultilineInput\",\n state: \"value\",\n });\n\n const handleChange = (event: ChangeEvent<HTMLTextAreaElement>) => {\n const value = event.target.value;\n setValue(value);\n onChange?.(event);\n };\n\n const handleBlur = (event: FocusEvent<HTMLTextAreaElement>) => {\n onBlur?.(event);\n setFocused(false);\n };\n\n const handleFocus = (event: FocusEvent<HTMLTextAreaElement>) => {\n onFocus?.(event);\n setFocused(true);\n };\n\n return (\n <div\n className={clsx(\n withBaseName(),\n withBaseName(variant),\n {\n [withBaseName(\"fullBorder\")]: fullBorder,\n [withBaseName(\"focused\")]: !isDisabled && !isReadOnly && focused,\n [withBaseName(\"disabled\")]: isDisabled,\n [withBaseName(\"readOnly\")]: isReadOnly,\n [withBaseName(validationStatus || \"\")]: validationStatus,\n },\n classNameProp\n )}\n ref={ref}\n {...other}\n >\n {startAdornment && (\n <div className={withBaseName(\"startAdornmentContainer\")}>\n {startAdornment}\n </div>\n )}\n <textarea\n aria-describedby={clsx(formFieldDescribedBy, textAreaDescribedBy)}\n aria-labelledby={clsx(formFieldLabelledBy, textAreaLabelledBy)}\n className={clsx(withBaseName(\"textarea\"), textAreaProps?.className)}\n disabled={isDisabled}\n id={id}\n readOnly={isReadOnly}\n ref={textAreaRef}\n required={isRequired}\n role={role}\n rows={rows}\n tabIndex={isReadOnly || isDisabled ? -1 : 0}\n onBlur={handleBlur}\n onChange={handleChange}\n onFocus={!isDisabled && !isReadOnly ? handleFocus : undefined}\n placeholder={placeholder}\n value={value}\n {...restA11yProps}\n {...restTextAreaProps}\n />\n {!isDisabled && !isReadOnly && validationStatus && (\n <div className={withBaseName(\"statusAdornmentContainer\")}>\n <StatusAdornment status={validationStatus} />\n </div>\n )}\n {endAdornment && (\n <div className={withBaseName(\"endAdornmentContainer\")}>\n {endAdornment}\n </div>\n )}\n <div className={withBaseName(\"activationIndicator\")} />\n </div>\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","MultilineInput","useWindow","useComponentCssInjection","multilineInputCss","useState","useFormFieldProps","useControlled","value","jsxs","clsx","jsx","StatusAdornment"],"mappings":"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"}
|