entangle-ui 0.8.2 → 0.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +77 -0
- package/dist/esm/assets/src/components/controls/Combobox/Combobox.css.ts.vanilla-B7B5ttkq.css +210 -0
- package/dist/esm/assets/src/components/controls/FileUploader/FileUploader.css.ts.vanilla-T4nRiI7s.css +194 -0
- package/dist/esm/assets/src/components/controls/MultiSelect/MultiSelect.css.ts.vanilla-CdYayqaF.css +311 -0
- package/dist/esm/assets/src/components/controls/TagInput/TagInput.css.ts.vanilla-hnkMOPp1.css +141 -0
- package/dist/esm/assets/src/components/data/DataTable/DataTable.css.ts.vanilla-CmRgtjIW.css +231 -0
- package/dist/esm/assets/src/components/feedback/Alert/{Alert.css.ts.vanilla-CRAI-xHx.css → Alert.css.ts.vanilla-CfCDsIEg.css} +2 -0
- package/dist/esm/assets/src/components/feedback/CommandPalette/CommandPalette.css.ts.vanilla-DGdrLKYZ.css +160 -0
- package/dist/esm/assets/src/components/feedback/Drawer/Drawer.css.ts.vanilla-CLPTOUrA.css +247 -0
- package/dist/esm/assets/src/components/feedback/Skeleton/SkeletonLayout.css.ts.vanilla-Db7bpqiI.css +75 -0
- package/dist/esm/assets/src/components/feedback/Stat/Stat.css.ts.vanilla-GBk3JAMB.css +69 -0
- package/dist/esm/assets/src/components/layout/Card/Card.css.ts.vanilla-Ducn1gUX.css +124 -0
- package/dist/esm/assets/src/components/navigation/Pagination/Pagination.css.ts.vanilla-CmlFyyjh.css +103 -0
- package/dist/esm/assets/src/components/primitives/HoverCard/HoverCard.css.ts.vanilla-BYT0qbLp.css +41 -0
- package/dist/esm/components/Icons/CloudUploadIcon.js +24 -0
- package/dist/esm/components/Icons/CloudUploadIcon.js.map +1 -0
- package/dist/esm/components/Icons/ExternalLinkIcon.js +26 -0
- package/dist/esm/components/Icons/ExternalLinkIcon.js.map +1 -0
- package/dist/esm/components/Icons/FirstIcon.js +23 -0
- package/dist/esm/components/Icons/FirstIcon.js.map +1 -0
- package/dist/esm/components/Icons/LastIcon.js +23 -0
- package/dist/esm/components/Icons/LastIcon.js.map +1 -0
- package/dist/esm/components/Icons/UnlinkIcon.js +26 -0
- package/dist/esm/components/Icons/UnlinkIcon.js.map +1 -0
- package/dist/esm/components/controls/Combobox/Combobox.css.js +20 -0
- package/dist/esm/components/controls/Combobox/Combobox.css.js.map +1 -0
- package/dist/esm/components/controls/Combobox/Combobox.js +354 -0
- package/dist/esm/components/controls/Combobox/Combobox.js.map +1 -0
- package/dist/esm/components/controls/FileUploader/FileUploader.css.js +20 -0
- package/dist/esm/components/controls/FileUploader/FileUploader.css.js.map +1 -0
- package/dist/esm/components/controls/FileUploader/FileUploader.js +264 -0
- package/dist/esm/components/controls/FileUploader/FileUploader.js.map +1 -0
- package/dist/esm/components/controls/MultiSelect/MultiSelect.css.js +23 -0
- package/dist/esm/components/controls/MultiSelect/MultiSelect.css.js.map +1 -0
- package/dist/esm/components/controls/MultiSelect/MultiSelect.js +269 -0
- package/dist/esm/components/controls/MultiSelect/MultiSelect.js.map +1 -0
- package/dist/esm/components/controls/Select/Select.js +5 -4
- package/dist/esm/components/controls/Select/Select.js.map +1 -1
- package/dist/esm/components/controls/TagInput/TagInput.css.js +12 -0
- package/dist/esm/components/controls/TagInput/TagInput.css.js.map +1 -0
- package/dist/esm/components/controls/TagInput/TagInput.js +189 -0
- package/dist/esm/components/controls/TagInput/TagInput.js.map +1 -0
- package/dist/esm/components/controls/TreeView/TreeNode.js +87 -1
- package/dist/esm/components/controls/TreeView/TreeNode.js.map +1 -1
- package/dist/esm/components/controls/VectorInput/VectorInput.js +87 -4
- package/dist/esm/components/controls/VectorInput/VectorInput.js.map +1 -1
- package/dist/esm/components/data/DataTable/DataTable.css.js +25 -0
- package/dist/esm/components/data/DataTable/DataTable.css.js.map +1 -0
- package/dist/esm/components/data/DataTable/DataTable.js +502 -0
- package/dist/esm/components/data/DataTable/DataTable.js.map +1 -0
- package/dist/esm/components/editor/ChatPanel/ChatCodeBlock.js +87 -5
- package/dist/esm/components/editor/ChatPanel/ChatCodeBlock.js.map +1 -1
- package/dist/esm/components/editor/ChatPanel/ChatInput.js +87 -5
- package/dist/esm/components/editor/ChatPanel/ChatInput.js.map +1 -1
- package/dist/esm/components/editor/ChatPanel/ChatMessage.js +87 -2
- package/dist/esm/components/editor/ChatPanel/ChatMessage.js.map +1 -1
- package/dist/esm/components/editor/PropertyInspector/PropertyRow.js +87 -3
- package/dist/esm/components/editor/PropertyInspector/PropertyRow.js.map +1 -1
- package/dist/esm/components/editor/PropertyInspector/PropertySection.js +87 -3
- package/dist/esm/components/editor/PropertyInspector/PropertySection.js.map +1 -1
- package/dist/esm/components/feedback/Alert/Alert.css.js +1 -1
- package/dist/esm/components/feedback/Alert/Alert.js +3 -2
- package/dist/esm/components/feedback/Alert/Alert.js.map +1 -1
- package/dist/esm/components/feedback/CommandPalette/CommandPalette.css.js +20 -0
- package/dist/esm/components/feedback/CommandPalette/CommandPalette.css.js.map +1 -0
- package/dist/esm/components/feedback/CommandPalette/CommandPalette.js +261 -0
- package/dist/esm/components/feedback/CommandPalette/CommandPalette.js.map +1 -0
- package/dist/esm/components/feedback/CommandPalette/fuzzySearch.js +86 -0
- package/dist/esm/components/feedback/CommandPalette/fuzzySearch.js.map +1 -0
- package/dist/esm/components/feedback/CommandPalette/useRecentItems.js +63 -0
- package/dist/esm/components/feedback/CommandPalette/useRecentItems.js.map +1 -0
- package/dist/esm/components/feedback/Dialog/DialogHeader.js +2 -1
- package/dist/esm/components/feedback/Dialog/DialogHeader.js.map +1 -1
- package/dist/esm/components/feedback/Drawer/Drawer.css.js +17 -0
- package/dist/esm/components/feedback/Drawer/Drawer.css.js.map +1 -0
- package/dist/esm/components/feedback/Drawer/Drawer.js +120 -0
- package/dist/esm/components/feedback/Drawer/Drawer.js.map +1 -0
- package/dist/esm/components/feedback/Drawer/useDrawerAnimation.js +74 -0
- package/dist/esm/components/feedback/Drawer/useDrawerAnimation.js.map +1 -0
- package/dist/esm/components/feedback/Skeleton/SkeletonLayout.css.js +18 -0
- package/dist/esm/components/feedback/Skeleton/SkeletonLayout.css.js.map +1 -0
- package/dist/esm/components/feedback/Skeleton/SkeletonLayout.js +95 -0
- package/dist/esm/components/feedback/Skeleton/SkeletonLayout.js.map +1 -0
- package/dist/esm/components/feedback/Stat/Stat.css.js +15 -0
- package/dist/esm/components/feedback/Stat/Stat.css.js.map +1 -0
- package/dist/esm/components/feedback/Stat/Stat.js +55 -0
- package/dist/esm/components/feedback/Stat/Stat.js.map +1 -0
- package/dist/esm/components/feedback/Toast/ToastItem.js +12 -15
- package/dist/esm/components/feedback/Toast/ToastItem.js.map +1 -1
- package/dist/esm/components/layout/Accordion/Accordion.js +2 -1
- package/dist/esm/components/layout/Accordion/Accordion.js.map +1 -1
- package/dist/esm/components/layout/Accordion/AccordionTrigger.js +2 -3
- package/dist/esm/components/layout/Accordion/AccordionTrigger.js.map +1 -1
- package/dist/esm/components/layout/Card/Card.css.js +18 -0
- package/dist/esm/components/layout/Card/Card.css.js.map +1 -0
- package/dist/esm/components/layout/Card/Card.js +66 -0
- package/dist/esm/components/layout/Card/Card.js.map +1 -0
- package/dist/esm/components/navigation/Breadcrumbs/BreadcrumbEllipsis.js +1 -0
- package/dist/esm/components/navigation/Breadcrumbs/BreadcrumbEllipsis.js.map +1 -1
- package/dist/esm/components/navigation/Breadcrumbs/BreadcrumbItem.js +1 -0
- package/dist/esm/components/navigation/Breadcrumbs/BreadcrumbItem.js.map +1 -1
- package/dist/esm/components/navigation/Breadcrumbs/Breadcrumbs.js +5 -0
- package/dist/esm/components/navigation/Breadcrumbs/Breadcrumbs.js.map +1 -1
- package/dist/esm/components/navigation/Pagination/Pagination.css.js +12 -0
- package/dist/esm/components/navigation/Pagination/Pagination.css.js.map +1 -0
- package/dist/esm/components/navigation/Pagination/Pagination.js +107 -0
- package/dist/esm/components/navigation/Pagination/Pagination.js.map +1 -0
- package/dist/esm/components/navigation/Pagination/usePagination.js +143 -0
- package/dist/esm/components/navigation/Pagination/usePagination.js.map +1 -0
- package/dist/esm/components/primitives/Avatar/Avatar.js +87 -1
- package/dist/esm/components/primitives/Avatar/Avatar.js.map +1 -1
- package/dist/esm/components/primitives/Badge/Badge.js +87 -1
- package/dist/esm/components/primitives/Badge/Badge.js.map +1 -1
- package/dist/esm/components/primitives/Checkbox/Checkbox.js +5 -2
- package/dist/esm/components/primitives/Checkbox/Checkbox.js.map +1 -1
- package/dist/esm/components/primitives/Collapsible/Collapsible.js +2 -3
- package/dist/esm/components/primitives/Collapsible/Collapsible.js.map +1 -1
- package/dist/esm/components/primitives/HoverCard/HoverCard.css.js +7 -0
- package/dist/esm/components/primitives/HoverCard/HoverCard.css.js.map +1 -0
- package/dist/esm/components/primitives/HoverCard/HoverCard.js +169 -0
- package/dist/esm/components/primitives/HoverCard/HoverCard.js.map +1 -0
- package/dist/esm/components/primitives/Icon/Icon.js +16 -2
- package/dist/esm/components/primitives/Icon/Icon.js.map +1 -1
- package/dist/esm/components/primitives/Link/Link.js +3 -3
- package/dist/esm/components/primitives/Link/Link.js.map +1 -1
- package/dist/esm/components/primitives/Popover/PopoverClose.js +2 -3
- package/dist/esm/components/primitives/Popover/PopoverClose.js.map +1 -1
- package/dist/esm/components/primitives/Radio/Radio.js +1 -1
- package/dist/esm/hooks/useBreakpoint/useBreakpoint.js +44 -0
- package/dist/esm/hooks/useBreakpoint/useBreakpoint.js.map +1 -0
- package/dist/esm/hooks/useDebounced/useDebouncedCallback.js +97 -0
- package/dist/esm/hooks/useDebounced/useDebouncedCallback.js.map +1 -0
- package/dist/esm/hooks/useDebounced/useDebouncedValue.js +35 -0
- package/dist/esm/hooks/useDebounced/useDebouncedValue.js.map +1 -0
- package/dist/esm/hooks/useIntersectionObserver/useIntersectionObserver.js +73 -0
- package/dist/esm/hooks/useIntersectionObserver/useIntersectionObserver.js.map +1 -0
- package/dist/esm/hooks/useListboxNav/useListboxNav.js +181 -0
- package/dist/esm/hooks/useListboxNav/useListboxNav.js.map +1 -0
- package/dist/esm/hooks/useMediaQuery/useMediaQuery.js +54 -0
- package/dist/esm/hooks/useMediaQuery/useMediaQuery.js.map +1 -0
- package/dist/esm/hooks/useThrottledCallback/useThrottledCallback.js +78 -0
- package/dist/esm/hooks/useThrottledCallback/useThrottledCallback.js.map +1 -0
- package/dist/esm/index.js +25 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/theme/breakpoints.js +27 -0
- package/dist/esm/theme/breakpoints.js.map +1 -0
- package/dist/esm/theme/index.js +1 -0
- package/dist/esm/theme/index.js.map +1 -1
- package/dist/tokens/tokens.dark.css +1 -1
- package/dist/tokens/tokens.json +1 -1
- package/dist/tokens/tokens.light.css +1 -1
- package/dist/types/components/Icons/CloudUploadIcon.d.ts +27 -0
- package/dist/types/components/Icons/ExternalLinkIcon.d.ts +29 -0
- package/dist/types/components/Icons/FirstIcon.d.ts +26 -0
- package/dist/types/components/Icons/LastIcon.d.ts +26 -0
- package/dist/types/components/Icons/UnlinkIcon.d.ts +29 -0
- package/dist/types/components/controls/Combobox/Combobox.d.ts +29 -0
- package/dist/types/components/controls/Combobox/Combobox.types.d.ts +109 -0
- package/dist/types/components/controls/FileUploader/FileUploader.d.ts +34 -0
- package/dist/types/components/controls/FileUploader/FileUploader.types.d.ts +94 -0
- package/dist/types/components/controls/MultiSelect/MultiSelect.d.ts +31 -0
- package/dist/types/components/controls/MultiSelect/MultiSelect.types.d.ts +85 -0
- package/dist/types/components/controls/TagInput/TagInput.d.ts +24 -0
- package/dist/types/components/controls/TagInput/TagInput.types.d.ts +100 -0
- package/dist/types/components/data/DataTable/DataTable.d.ts +8 -0
- package/dist/types/components/data/DataTable/DataTable.types.d.ts +159 -0
- package/dist/types/components/feedback/Alert/Alert.d.ts +1 -0
- package/dist/types/components/feedback/Alert/Alert.types.d.ts +7 -0
- package/dist/types/components/feedback/CommandPalette/CommandPalette.d.ts +29 -0
- package/dist/types/components/feedback/CommandPalette/CommandPalette.types.d.ts +61 -0
- package/dist/types/components/feedback/CommandPalette/fuzzySearch.d.ts +6 -0
- package/dist/types/components/feedback/Drawer/Drawer.d.ts +12 -0
- package/dist/types/components/feedback/Drawer/Drawer.types.d.ts +70 -0
- package/dist/types/components/feedback/Skeleton/Skeleton.types.d.ts +44 -1
- package/dist/types/components/feedback/Skeleton/SkeletonLayout.d.ts +314 -0
- package/dist/types/components/feedback/Stat/Stat.d.ts +23 -0
- package/dist/types/components/feedback/Stat/Stat.types.d.ts +38 -0
- package/dist/types/components/layout/Accordion/Accordion.types.d.ts +7 -0
- package/dist/types/components/layout/Card/Card.d.ts +12 -0
- package/dist/types/components/layout/Card/Card.types.d.ts +54 -0
- package/dist/types/components/navigation/Pagination/Pagination.d.ts +22 -0
- package/dist/types/components/navigation/Pagination/Pagination.types.d.ts +49 -0
- package/dist/types/components/primitives/Button/Button.d.ts +1 -1
- package/dist/types/components/primitives/HoverCard/HoverCard.d.ts +10 -0
- package/dist/types/components/primitives/HoverCard/HoverCard.types.d.ts +64 -0
- package/dist/types/components/primitives/Icon/Icon.d.ts +14 -1
- package/dist/types/components/primitives/IconButton/IconButton.d.ts +1 -1
- package/dist/types/hooks/useBreakpoint/useBreakpoint.d.ts +19 -0
- package/dist/types/hooks/useBreakpoint/useBreakpoint.types.d.ts +20 -0
- package/dist/types/hooks/useDebounced/useDebounced.types.d.ts +15 -0
- package/dist/types/hooks/useDebounced/useDebouncedCallback.d.ts +22 -0
- package/dist/types/hooks/useDebounced/useDebouncedValue.d.ts +16 -0
- package/dist/types/hooks/useIntersectionObserver/useIntersectionObserver.d.ts +22 -0
- package/dist/types/hooks/useIntersectionObserver/useIntersectionObserver.types.d.ts +22 -0
- package/dist/types/hooks/useListboxNav/useListboxNav.d.ts +75 -0
- package/dist/types/hooks/useMediaQuery/useMediaQuery.d.ts +19 -0
- package/dist/types/hooks/useMediaQuery/useMediaQuery.types.d.ts +6 -0
- package/dist/types/hooks/useThrottledCallback/useThrottledCallback.d.ts +23 -0
- package/dist/types/hooks/useThrottledCallback/useThrottledCallback.types.d.ts +13 -0
- package/dist/types/index.d.ts +43 -1
- package/dist/types/theme/breakpoints.d.ts +22 -0
- package/dist/types/theme/index.d.ts +1 -0
- package/package.json +3 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Select.js","sources":["../../../../../../src/components/controls/Select/Select.tsx"],"sourcesContent":[null],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Select.js","sources":["../../../../../../src/components/controls/Select/Select.tsx"],"sourcesContent":[null],"names":[],"mappings":";;;;;;;;;;;;;AAuCA;AAEA;AAGE;AACF;AAEA;;AAIE;AACE;;;;AAGE;;;AAGJ;AACF;AAEA;AAIE;;AAEF;AAEA;AAEA;AACE;AACA;AACA;;AAGF;AAEA;;;;;;;;;;;;;;;;;;;AAmBG;;AA+BD;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;;AAGA;;;;AAQA;;;AAIA;;AAGA;AACA;AACE;AAAiC;AACjC;;;AAIF;;AAMA;AACE;AACA;;AAEA;;AAEA;AAGA;;AAGI;AAEJ;;AAEE;AACA;AACE;;AAEI;AACD;AACH;AACH;AACH;AAEA;AACE;;;;AAGA;AACA;;AAEF;AAEA;;;AAGE;AACA;AACA;AACF;AAEA;;;;AAKI;AACA;;;;;AAQA;;;;AAII;AACF;;;;;;AAOJ;;AAEA;AACE;;;AAKE;;AAEJ;AAEA;;AAEF;;AAGA;;AAIO;AAIP;AAEI;;AAEA;;;AAIE;AACE;;AAEF;;;AAGA;;AAGI;AAEA;;;;;;AAKJ;AACE;;;;;;;;;AASN;;AAKF;AAEI;;AAEA;AACE;AACA;AACA;;;AAGI;;;AAGJ;;;AAGI;;;;;;AASV;AAEI;AACE;;;;AAIA;;;;AAIA;;;;AAIA;;;;AAIA;;;AAII;AAEA;AACA;AACE;;;;AAIN;;AAEE;;;AAGN;AAIF;;;AAIE;AAIF;AACA;;AAGA;AAEI;AACA;;;;AAGG;AACC;;AAEN;;;AAMA;AACE;;;;AAMF;;;AAGI;AACE;;AAEA;AAEA;AAIM;AACA;AACF;;;;AAON;AACF;;AAGF;AACF;AAEA;AACE;AACA;AAEA;AAOM;AACA;AACA;AACD;AAEC;AACE;;AAEJ;AAEE;;;;AAcR;AAEA;;;AA8BQ;;;;AAID;AAmCD;AAkBU;AACA;AACF;AA0BhB;AAEA;;"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import './../../../assets/src/components/controls/TagInput/TagInput.css.ts.vanilla-hnkMOPp1.css';
|
|
2
|
+
import { createRuntimeFn } from '@vanilla-extract/recipes/createRuntimeFn';
|
|
3
|
+
|
|
4
|
+
var containerStyle = 'TagInput_containerStyle__16f33bk0';
|
|
5
|
+
var inputStyle = 'TagInput_inputStyle__16f33bkm';
|
|
6
|
+
var tagLabelStyle = 'TagInput_tagLabelStyle__16f33bkk';
|
|
7
|
+
var tagRecipe = createRuntimeFn({defaultClassName:'TagInput_tagRecipe__16f33bke',variantClassNames:{size:{sm:'TagInput_tagRecipe_size_sm__16f33bkf',md:'TagInput_tagRecipe_size_md__16f33bkg',lg:'TagInput_tagRecipe_size_lg__16f33bkh'},invalid:{true:'TagInput_tagRecipe_invalid_true__16f33bki',false:'TagInput_tagRecipe_invalid_false__16f33bkj'}},defaultVariants:{size:'md',invalid:false},compoundVariants:[]});
|
|
8
|
+
var tagRemoveStyle = 'TagInput_tagRemoveStyle__16f33bkl';
|
|
9
|
+
var wrapperRecipe = createRuntimeFn({defaultClassName:'TagInput_wrapperRecipe__16f33bk1',variantClassNames:{size:{sm:'TagInput_wrapperRecipe_size_sm__16f33bk2',md:'TagInput_wrapperRecipe_size_md__16f33bk3',lg:'TagInput_wrapperRecipe_size_lg__16f33bk4'},variant:{'default':'TagInput_wrapperRecipe_variant_default__16f33bk5',ghost:'TagInput_wrapperRecipe_variant_ghost__16f33bk6',filled:'TagInput_wrapperRecipe_variant_filled__16f33bk7'},focused:{true:'TagInput_wrapperRecipe_focused_true__16f33bk8',false:'TagInput_wrapperRecipe_focused_false__16f33bk9'},error:{true:'TagInput_wrapperRecipe_error_true__16f33bka',false:'TagInput_wrapperRecipe_error_false__16f33bkb'},disabled:{true:'TagInput_wrapperRecipe_disabled_true__16f33bkc',false:'TagInput_wrapperRecipe_disabled_false__16f33bkd'}},defaultVariants:{size:'md',variant:'default',focused:false,error:false,disabled:false},compoundVariants:[]});
|
|
10
|
+
|
|
11
|
+
export { containerStyle, inputStyle, tagLabelStyle, tagRecipe, tagRemoveStyle, wrapperRecipe };
|
|
12
|
+
//# sourceMappingURL=TagInput.css.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TagInput.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;"}
|
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
3
|
+
import React, { useId, useState, useRef, useMemo, useCallback } from 'react';
|
|
4
|
+
import { CloseIcon } from '../../Icons/CloseIcon.js';
|
|
5
|
+
import { FormHelperText } from '../../form/FormHelperText.js';
|
|
6
|
+
import { FormLabel } from '../../form/FormLabel.js';
|
|
7
|
+
import { useControlledState } from '../../../hooks/useControlledState/useControlledState.js';
|
|
8
|
+
import { useMergedRef } from '../../../hooks/useMergedRef/useMergedRef.js';
|
|
9
|
+
import { cx } from '../../../utils/cx.js';
|
|
10
|
+
import { inputStyle, wrapperRecipe, containerStyle, tagLabelStyle, tagRemoveStyle, tagRecipe } from './TagInput.css.js';
|
|
11
|
+
|
|
12
|
+
const SEPARATOR_KEY = {
|
|
13
|
+
Enter: 'Enter',
|
|
14
|
+
Comma: ',',
|
|
15
|
+
Space: ' ',
|
|
16
|
+
Tab: 'Tab',
|
|
17
|
+
};
|
|
18
|
+
const DEFAULT_SEPARATORS = ['Enter', 'Comma'];
|
|
19
|
+
function defaultNormalize(value) {
|
|
20
|
+
return value.trim();
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Multi-value input that captures a list of strings ("tags") rendered as
|
|
24
|
+
* removable chips. Supports controlled and uncontrolled modes, validation,
|
|
25
|
+
* configurable commit keys, and custom chip rendering.
|
|
26
|
+
*
|
|
27
|
+
* @example
|
|
28
|
+
* ```tsx
|
|
29
|
+
* <TagInput
|
|
30
|
+
* label="Keywords"
|
|
31
|
+
* placeholder="Add a keyword..."
|
|
32
|
+
* defaultValue={['react', 'typescript']}
|
|
33
|
+
* onChange={setTags}
|
|
34
|
+
* />
|
|
35
|
+
* ```
|
|
36
|
+
*/
|
|
37
|
+
function TagInput({ value, defaultValue, onChange, placeholder, separators = DEFAULT_SEPARATORS, addOnBlur = false, allowDuplicates = false, max, validate, normalize = defaultNormalize, onValidate, renderTag, size = 'md', variant = 'default', label, helperText, error = false, errorMessage, disabled = false, required = false, readOnly = false, name, inputAriaLabel, inputRef: inputRefProp, className, style, testId, id: idProp, ref, ...rest }) {
|
|
38
|
+
const autoId = useId();
|
|
39
|
+
const fieldId = idProp ?? autoId;
|
|
40
|
+
const labelId = `${fieldId}-label`;
|
|
41
|
+
const helperId = `${fieldId}-helper`;
|
|
42
|
+
const [tags, setTags] = useControlledState({
|
|
43
|
+
value,
|
|
44
|
+
defaultValue,
|
|
45
|
+
onChange,
|
|
46
|
+
fallback: [],
|
|
47
|
+
});
|
|
48
|
+
const [draft, setDraft] = useState('');
|
|
49
|
+
const [focused, setFocused] = useState(false);
|
|
50
|
+
const innerInputRef = useRef(null);
|
|
51
|
+
const wrapperRef = useRef(null);
|
|
52
|
+
const setInputRef = useMergedRef(innerInputRef, inputRefProp);
|
|
53
|
+
const setWrapperRef = useMergedRef(wrapperRef, ref);
|
|
54
|
+
const atMax = typeof max === 'number' && tags.length >= max;
|
|
55
|
+
const inputDisabled = disabled || readOnly || atMax;
|
|
56
|
+
const separatorKeys = useMemo(() => new Set(separators.map(s => SEPARATOR_KEY[s])), [separators]);
|
|
57
|
+
const tryAppend = useCallback((current, raw) => {
|
|
58
|
+
const normalized = normalize(raw);
|
|
59
|
+
if (normalized.length === 0) {
|
|
60
|
+
if (raw.length > 0)
|
|
61
|
+
onValidate?.(raw, 'empty');
|
|
62
|
+
return null;
|
|
63
|
+
}
|
|
64
|
+
if (typeof max === 'number' && current.length >= max) {
|
|
65
|
+
onValidate?.(raw, 'max');
|
|
66
|
+
return null;
|
|
67
|
+
}
|
|
68
|
+
if (!allowDuplicates && current.includes(normalized)) {
|
|
69
|
+
onValidate?.(raw, 'duplicate');
|
|
70
|
+
return null;
|
|
71
|
+
}
|
|
72
|
+
if (validate) {
|
|
73
|
+
const result = validate(normalized, current);
|
|
74
|
+
if (result === false) {
|
|
75
|
+
onValidate?.(raw, 'invalid');
|
|
76
|
+
return null;
|
|
77
|
+
}
|
|
78
|
+
if (typeof result === 'string') {
|
|
79
|
+
onValidate?.(raw, result);
|
|
80
|
+
return null;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
return [...current, normalized];
|
|
84
|
+
}, [allowDuplicates, max, normalize, onValidate, validate]);
|
|
85
|
+
const commitTag = useCallback((raw) => {
|
|
86
|
+
const next = tryAppend(tags, raw);
|
|
87
|
+
if (!next)
|
|
88
|
+
return false;
|
|
89
|
+
setTags(next);
|
|
90
|
+
return true;
|
|
91
|
+
}, [setTags, tags, tryAppend]);
|
|
92
|
+
const removeTagAt = useCallback((index) => {
|
|
93
|
+
if (index < 0 || index >= tags.length)
|
|
94
|
+
return;
|
|
95
|
+
const next = tags.slice(0, index).concat(tags.slice(index + 1));
|
|
96
|
+
setTags(next);
|
|
97
|
+
}, [setTags, tags]);
|
|
98
|
+
const handleKeyDown = useCallback((event) => {
|
|
99
|
+
if (inputDisabled)
|
|
100
|
+
return;
|
|
101
|
+
if (separatorKeys.has(event.key)) {
|
|
102
|
+
// Tab as separator: only commit when there's a draft, otherwise let
|
|
103
|
+
// the focus move out naturally.
|
|
104
|
+
if (event.key === 'Tab' && draft.length === 0)
|
|
105
|
+
return;
|
|
106
|
+
if (draft.length > 0) {
|
|
107
|
+
event.preventDefault();
|
|
108
|
+
if (commitTag(draft))
|
|
109
|
+
setDraft('');
|
|
110
|
+
}
|
|
111
|
+
else if (event.key === 'Enter') {
|
|
112
|
+
// Prevent submitting an enclosing form on empty Enter.
|
|
113
|
+
event.preventDefault();
|
|
114
|
+
}
|
|
115
|
+
return;
|
|
116
|
+
}
|
|
117
|
+
if (event.key === 'Backspace' && draft.length === 0 && tags.length > 0) {
|
|
118
|
+
event.preventDefault();
|
|
119
|
+
removeTagAt(tags.length - 1);
|
|
120
|
+
}
|
|
121
|
+
}, [commitTag, draft, inputDisabled, removeTagAt, separatorKeys, tags.length]);
|
|
122
|
+
const handleChange = useCallback((event) => {
|
|
123
|
+
const next = event.target.value;
|
|
124
|
+
// If the user typed/pasted a separator character (e.g. comma), commit
|
|
125
|
+
// each piece. Newlines are split too so multi-line paste still works.
|
|
126
|
+
const splitChars = Array.from(separatorKeys).filter(k => k !== 'Enter' && k !== 'Tab');
|
|
127
|
+
if (splitChars.length === 0 || !splitChars.some(c => next.includes(c))) {
|
|
128
|
+
setDraft(next);
|
|
129
|
+
return;
|
|
130
|
+
}
|
|
131
|
+
const pattern = new RegExp(`[${splitChars.map(c => `\\${c}`).join('')}]`);
|
|
132
|
+
const parts = next.split(pattern);
|
|
133
|
+
const trailing = parts.pop() ?? '';
|
|
134
|
+
let working = tags;
|
|
135
|
+
for (const part of parts) {
|
|
136
|
+
if (part.length === 0)
|
|
137
|
+
continue;
|
|
138
|
+
const appended = tryAppend(working, part);
|
|
139
|
+
if (appended)
|
|
140
|
+
working = appended;
|
|
141
|
+
}
|
|
142
|
+
if (working !== tags)
|
|
143
|
+
setTags(working);
|
|
144
|
+
setDraft(trailing);
|
|
145
|
+
}, [separatorKeys, setTags, tags, tryAppend]);
|
|
146
|
+
const handleBlur = useCallback(() => {
|
|
147
|
+
setFocused(false);
|
|
148
|
+
if (addOnBlur && draft.length > 0) {
|
|
149
|
+
if (commitTag(draft))
|
|
150
|
+
setDraft('');
|
|
151
|
+
}
|
|
152
|
+
}, [addOnBlur, commitTag, draft]);
|
|
153
|
+
const handleWrapperMouseDown = useCallback((event) => {
|
|
154
|
+
// Forward clicks on empty padding to the input, but do not steal focus
|
|
155
|
+
// from chip remove buttons.
|
|
156
|
+
if (event.target === wrapperRef.current) {
|
|
157
|
+
event.preventDefault();
|
|
158
|
+
innerInputRef.current?.focus();
|
|
159
|
+
}
|
|
160
|
+
}, []);
|
|
161
|
+
const renderChip = (tag, index) => {
|
|
162
|
+
const remove = () => removeTagAt(index);
|
|
163
|
+
if (renderTag) {
|
|
164
|
+
const state = {
|
|
165
|
+
tag,
|
|
166
|
+
index,
|
|
167
|
+
disabled,
|
|
168
|
+
remove,
|
|
169
|
+
};
|
|
170
|
+
return (jsx(React.Fragment, { children: renderTag(state) }, `${tag}-${String(index)}`));
|
|
171
|
+
}
|
|
172
|
+
return (jsxs("span", { className: tagRecipe({ size }), "data-testid": testId ? `${testId}-tag-${String(index)}` : undefined, children: [jsx("span", { className: tagLabelStyle, children: tag }), !readOnly && (jsx("button", { type: "button", tabIndex: -1, disabled: disabled, "aria-label": `Remove ${tag}`, className: tagRemoveStyle, onClick: remove, children: jsx(CloseIcon, { size: "sm", decorative: true }) }))] }, `${tag}-${String(index)}`));
|
|
173
|
+
};
|
|
174
|
+
const showHelperText = error && errorMessage ? errorMessage : helperText;
|
|
175
|
+
const formValue = tags.join(',');
|
|
176
|
+
return (jsxs("div", { className: cx(containerStyle, className), style: style, children: [label && (jsx(FormLabel, { id: labelId, htmlFor: fieldId, required: required, disabled: disabled, children: label })), jsxs("div", { ref: setWrapperRef, className: wrapperRecipe({
|
|
177
|
+
size,
|
|
178
|
+
variant,
|
|
179
|
+
focused,
|
|
180
|
+
error,
|
|
181
|
+
disabled,
|
|
182
|
+
}), onMouseDown: handleWrapperMouseDown, "data-testid": testId, ...rest, children: [tags.map((tag, index) => renderChip(tag, index)), !readOnly && (jsx("input", { ref: setInputRef, id: fieldId, type: "text", value: draft, placeholder: tags.length === 0 ? placeholder : undefined, disabled: inputDisabled, required: required && tags.length === 0, "aria-label": inputAriaLabel, "aria-labelledby": !inputAriaLabel && label ? labelId : undefined, "aria-describedby": showHelperText ? helperId : undefined, "aria-invalid": error || undefined, className: inputStyle, onChange: handleChange, onKeyDown: handleKeyDown, onFocus: () => {
|
|
183
|
+
setFocused(true);
|
|
184
|
+
}, onBlur: handleBlur }))] }), name && jsx("input", { type: "hidden", name: name, value: formValue }), showHelperText && (jsx(FormHelperText, { id: helperId, error: error, children: showHelperText }))] }));
|
|
185
|
+
}
|
|
186
|
+
TagInput.displayName = 'TagInput';
|
|
187
|
+
|
|
188
|
+
export { TagInput };
|
|
189
|
+
//# sourceMappingURL=TagInput.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TagInput.js","sources":["../../../../../../src/components/controls/TagInput/TagInput.tsx"],"sourcesContent":[null],"names":[],"mappings":";;;;;;;;;;;AAuBA;AACE;AACA;AACA;AACA;;AAGF;AAEA;AACE;AACF;AAEA;;;;;;;;;;;;;;AAcG;;AAiCD;AACA;AACA;AACA;AAEA;;;;AAIE;AACD;;;AAKD;AACA;;;AAKA;AACA;AAEA;;AAOI;AACA;AACE;AAAoB;AACpB;;;AAGA;AACA;;;AAGA;AACA;;;;AAIA;AACE;AACA;;AAEF;AACE;AACA;;;AAGJ;AACF;AAIF;;AAGI;AAAW;;AAEX;;AAKJ;;;;;AAKE;AAIF;AAEI;;;;;;;AAME;;;;;AAGO;;;;;;AAOT;;AAEE;;AAEJ;AAIF;AAEI;;;;;;;;;;;;AAeA;AACE;;;AAEA;;;;;;;AAQN;;;;;;;AAOA;;;;;AAMM;;;AAMN;;;AAGI;;;;;;;;AAaF;AAqBF;AAEA;;;;;;;;;;AAiDU;AAeZ;AAEA;;"}
|
|
@@ -2,6 +2,92 @@
|
|
|
2
2
|
import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
3
3
|
import { useState, useRef, useCallback } from 'react';
|
|
4
4
|
import { assignInlineVars } from '@vanilla-extract/dynamic';
|
|
5
|
+
import '../../Icons/AddIcon.js';
|
|
6
|
+
import '../../Icons/AiChatIcon.js';
|
|
7
|
+
import '../../Icons/AiSparklesIcon.js';
|
|
8
|
+
import '../../Icons/ArrowDownIcon.js';
|
|
9
|
+
import '../../Icons/ArrowLeftIcon.js';
|
|
10
|
+
import '../../Icons/ArrowRightIcon.js';
|
|
11
|
+
import '../../Icons/ArrowUpIcon.js';
|
|
12
|
+
import '../../Icons/BookmarkIcon.js';
|
|
13
|
+
import '../../Icons/CalendarIcon.js';
|
|
14
|
+
import '../../Icons/ChevronDownIcon.js';
|
|
15
|
+
import '../../Icons/ChevronUpIcon.js';
|
|
16
|
+
import '../../Icons/ClockIcon.js';
|
|
17
|
+
import '../../Icons/CloseIcon.js';
|
|
18
|
+
import '../../Icons/CloudUploadIcon.js';
|
|
19
|
+
import '../../Icons/CodeIcon.js';
|
|
20
|
+
import '../../Icons/CopyIcon.js';
|
|
21
|
+
import '../../Icons/CutIcon.js';
|
|
22
|
+
import '../../Icons/DownloadIcon.js';
|
|
23
|
+
import '../../Icons/EditIcon.js';
|
|
24
|
+
import '../../Icons/ErrorIcon.js';
|
|
25
|
+
import '../../Icons/ExternalLinkIcon.js';
|
|
26
|
+
import '../../Icons/EyeDropperIcon.js';
|
|
27
|
+
import '../../Icons/EyeIcon.js';
|
|
28
|
+
import '../../Icons/FilterIcon.js';
|
|
29
|
+
import '../../Icons/FirstIcon.js';
|
|
30
|
+
import '../../Icons/FolderIcon.js';
|
|
31
|
+
import '../../Icons/FullscreenIcon.js';
|
|
32
|
+
import '../../Icons/GridIcon.js';
|
|
33
|
+
import '../../Icons/HeartIcon.js';
|
|
34
|
+
import '../../Icons/HelpIcon.js';
|
|
35
|
+
import '../../Icons/HomeIcon.js';
|
|
36
|
+
import '../../Icons/InfoIcon.js';
|
|
37
|
+
import '../../Icons/LastIcon.js';
|
|
38
|
+
import '../../Icons/LinkIcon.js';
|
|
39
|
+
import '../../Icons/ListIcon.js';
|
|
40
|
+
import '../../Icons/LockIcon.js';
|
|
41
|
+
import '../../Icons/MaximizeIcon.js';
|
|
42
|
+
import '../../Icons/MenuIcon.js';
|
|
43
|
+
import '../../Icons/MinimizeIcon.js';
|
|
44
|
+
import '../../Icons/PasteIcon.js';
|
|
45
|
+
import '../../Icons/PlayIcon.js';
|
|
46
|
+
import '../../Icons/RedoIcon.js';
|
|
47
|
+
import '../../Icons/RefreshIcon.js';
|
|
48
|
+
import '../../Icons/RobotIcon.js';
|
|
49
|
+
import '../../Icons/SaveIcon.js';
|
|
50
|
+
import '../../Icons/SearchIcon.js';
|
|
51
|
+
import '../../Icons/SettingsIcon.js';
|
|
52
|
+
import '../../Icons/SortIcon.js';
|
|
53
|
+
import '../../Icons/StarIcon.js';
|
|
54
|
+
import '../../Icons/SuccessIcon.js';
|
|
55
|
+
import '../../Icons/TagIcon.js';
|
|
56
|
+
import '../../Icons/TrashIcon.js';
|
|
57
|
+
import '../../Icons/UndoIcon.js';
|
|
58
|
+
import '../../Icons/UnlinkIcon.js';
|
|
59
|
+
import '../../Icons/UnlockIcon.js';
|
|
60
|
+
import '../../Icons/UploadIcon.js';
|
|
61
|
+
import '../../Icons/UserIcon.js';
|
|
62
|
+
import '../../Icons/WarningIcon.js';
|
|
63
|
+
import '../../Icons/ZoomInIcon.js';
|
|
64
|
+
import '../../Icons/ZoomOutIcon.js';
|
|
65
|
+
import '../../Icons/CheckIcon.js';
|
|
66
|
+
import '../../Icons/CircleIcon.js';
|
|
67
|
+
import '../../Icons/TangentFreeIcon.js';
|
|
68
|
+
import '../../Icons/TangentAlignedIcon.js';
|
|
69
|
+
import '../../Icons/TangentMirroredIcon.js';
|
|
70
|
+
import '../../Icons/TangentAutoIcon.js';
|
|
71
|
+
import '../../Icons/TangentLinearIcon.js';
|
|
72
|
+
import '../../Icons/TangentStepIcon.js';
|
|
73
|
+
import '../../Icons/ArchiveIcon.js';
|
|
74
|
+
import '../../Icons/DotsVerticalIcon.js';
|
|
75
|
+
import '../../Icons/DotsHorizontalIcon.js';
|
|
76
|
+
import '../../Icons/ChevronLeftIcon.js';
|
|
77
|
+
import { ChevronRightIcon } from '../../Icons/ChevronRightIcon.js';
|
|
78
|
+
import '../../Icons/FolderOpenIcon.js';
|
|
79
|
+
import '../../Icons/FolderCogIcon.js';
|
|
80
|
+
import '../../Icons/UsersIcon.js';
|
|
81
|
+
import '../../Icons/BuildingIcon.js';
|
|
82
|
+
import '../../Icons/FileTextIcon.js';
|
|
83
|
+
import '../../Icons/PauseIcon.js';
|
|
84
|
+
import '../../Icons/StopIcon.js';
|
|
85
|
+
import '../../Icons/SendIcon.js';
|
|
86
|
+
import '../../Icons/TerminalIcon.js';
|
|
87
|
+
import '../../Icons/GitBranchIcon.js';
|
|
88
|
+
import '../../Icons/BugIcon.js';
|
|
89
|
+
import '../../Icons/MinusIcon.js';
|
|
90
|
+
import '../../Icons/PinIcon.js';
|
|
5
91
|
import { guideLineStyle, guideLineLeftVar, chevronRecipe, iconRecipe, renameInputRecipe, labelRecipe, actionsStyle, paddingLeftVar, rowRecipe } from './TreeNode.css.js';
|
|
6
92
|
|
|
7
93
|
// --- Size configurations ---
|
|
@@ -29,7 +115,7 @@ const sizeConfig = {
|
|
|
29
115
|
},
|
|
30
116
|
};
|
|
31
117
|
// --- Chevron icon SVG ---
|
|
32
|
-
const ChevronSvg = ({ size }) => (jsx(
|
|
118
|
+
const ChevronSvg = ({ size }) => (jsx(ChevronRightIcon, { size: size, color: "currentColor", decorative: true }));
|
|
33
119
|
const TreeNodeComponent = ({ node, depth, size, indent, isSelected, isExpanded, isFocused, isFirst, isLast, showChevrons, showGuideLines, renamable, nodeId, renderNode, renderActions, onToggleExpand, onClick, onDoubleClick, onContextMenu, onRename, }) => {
|
|
34
120
|
const [isRenaming, setIsRenaming] = useState(false);
|
|
35
121
|
const [renameValue, setRenameValue] = useState(node.label);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TreeNode.js","sources":["../../../../../../src/components/controls/TreeView/TreeNode.tsx"],"sourcesContent":[null],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"TreeNode.js","sources":["../../../../../../src/components/controls/TreeView/TreeNode.tsx"],"sourcesContent":[null],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAsBA;AAEA;AAUE;AACE;AACA;AACA;AACA;AACA;AACD;AACD;AACE;AACA;AACA;AACA;AACA;AACD;AACD;AACE;AACA;AACA;AACA;AACA;AACD;;AAGH;AAEA;;;AAoDE;AACA;AAEA;AACA;AAEA;AACE;AACA;AACA;;;;;;AAOF;;;AAIM;;AAEJ;AAIF;AAEI;;AACA;;AAKJ;;;;;;AAOM;;AAEE;AACA;;;;AAKJ;;AAKJ;AAEI;AACF;AAIF;;;;;AAKA;AAEA;AACE;;AAEF;AAEA;AAEI;AACE;;AACK;AACL;;AAEJ;;AAKF;;AAOY;AACD;;AAKX;;AAUM;AACA;AACA;AACD;AAEC;;AAaI;;;AAGD;AAyCX;AAEA;;"}
|
|
@@ -7,6 +7,92 @@ import '../../../utils/devWarn.js';
|
|
|
7
7
|
import '../../../utils/mathExpression.js';
|
|
8
8
|
import { FormLabel } from '../../form/FormLabel.js';
|
|
9
9
|
import { FormHelperText } from '../../form/FormHelperText.js';
|
|
10
|
+
import '../../Icons/AddIcon.js';
|
|
11
|
+
import '../../Icons/AiChatIcon.js';
|
|
12
|
+
import '../../Icons/AiSparklesIcon.js';
|
|
13
|
+
import '../../Icons/ArrowDownIcon.js';
|
|
14
|
+
import '../../Icons/ArrowLeftIcon.js';
|
|
15
|
+
import '../../Icons/ArrowRightIcon.js';
|
|
16
|
+
import '../../Icons/ArrowUpIcon.js';
|
|
17
|
+
import '../../Icons/BookmarkIcon.js';
|
|
18
|
+
import '../../Icons/CalendarIcon.js';
|
|
19
|
+
import '../../Icons/ChevronDownIcon.js';
|
|
20
|
+
import '../../Icons/ChevronUpIcon.js';
|
|
21
|
+
import '../../Icons/ClockIcon.js';
|
|
22
|
+
import '../../Icons/CloseIcon.js';
|
|
23
|
+
import '../../Icons/CloudUploadIcon.js';
|
|
24
|
+
import '../../Icons/CodeIcon.js';
|
|
25
|
+
import '../../Icons/CopyIcon.js';
|
|
26
|
+
import '../../Icons/CutIcon.js';
|
|
27
|
+
import '../../Icons/DownloadIcon.js';
|
|
28
|
+
import '../../Icons/EditIcon.js';
|
|
29
|
+
import '../../Icons/ErrorIcon.js';
|
|
30
|
+
import '../../Icons/ExternalLinkIcon.js';
|
|
31
|
+
import '../../Icons/EyeDropperIcon.js';
|
|
32
|
+
import '../../Icons/EyeIcon.js';
|
|
33
|
+
import '../../Icons/FilterIcon.js';
|
|
34
|
+
import '../../Icons/FirstIcon.js';
|
|
35
|
+
import '../../Icons/FolderIcon.js';
|
|
36
|
+
import '../../Icons/FullscreenIcon.js';
|
|
37
|
+
import '../../Icons/GridIcon.js';
|
|
38
|
+
import '../../Icons/HeartIcon.js';
|
|
39
|
+
import '../../Icons/HelpIcon.js';
|
|
40
|
+
import '../../Icons/HomeIcon.js';
|
|
41
|
+
import '../../Icons/InfoIcon.js';
|
|
42
|
+
import '../../Icons/LastIcon.js';
|
|
43
|
+
import { LinkIcon } from '../../Icons/LinkIcon.js';
|
|
44
|
+
import '../../Icons/ListIcon.js';
|
|
45
|
+
import '../../Icons/LockIcon.js';
|
|
46
|
+
import '../../Icons/MaximizeIcon.js';
|
|
47
|
+
import '../../Icons/MenuIcon.js';
|
|
48
|
+
import '../../Icons/MinimizeIcon.js';
|
|
49
|
+
import '../../Icons/PasteIcon.js';
|
|
50
|
+
import '../../Icons/PlayIcon.js';
|
|
51
|
+
import '../../Icons/RedoIcon.js';
|
|
52
|
+
import '../../Icons/RefreshIcon.js';
|
|
53
|
+
import '../../Icons/RobotIcon.js';
|
|
54
|
+
import '../../Icons/SaveIcon.js';
|
|
55
|
+
import '../../Icons/SearchIcon.js';
|
|
56
|
+
import '../../Icons/SettingsIcon.js';
|
|
57
|
+
import '../../Icons/SortIcon.js';
|
|
58
|
+
import '../../Icons/StarIcon.js';
|
|
59
|
+
import '../../Icons/SuccessIcon.js';
|
|
60
|
+
import '../../Icons/TagIcon.js';
|
|
61
|
+
import '../../Icons/TrashIcon.js';
|
|
62
|
+
import '../../Icons/UndoIcon.js';
|
|
63
|
+
import { UnlinkIcon } from '../../Icons/UnlinkIcon.js';
|
|
64
|
+
import '../../Icons/UnlockIcon.js';
|
|
65
|
+
import '../../Icons/UploadIcon.js';
|
|
66
|
+
import '../../Icons/UserIcon.js';
|
|
67
|
+
import '../../Icons/WarningIcon.js';
|
|
68
|
+
import '../../Icons/ZoomInIcon.js';
|
|
69
|
+
import '../../Icons/ZoomOutIcon.js';
|
|
70
|
+
import '../../Icons/CheckIcon.js';
|
|
71
|
+
import '../../Icons/CircleIcon.js';
|
|
72
|
+
import '../../Icons/TangentFreeIcon.js';
|
|
73
|
+
import '../../Icons/TangentAlignedIcon.js';
|
|
74
|
+
import '../../Icons/TangentMirroredIcon.js';
|
|
75
|
+
import '../../Icons/TangentAutoIcon.js';
|
|
76
|
+
import '../../Icons/TangentLinearIcon.js';
|
|
77
|
+
import '../../Icons/TangentStepIcon.js';
|
|
78
|
+
import '../../Icons/ArchiveIcon.js';
|
|
79
|
+
import '../../Icons/DotsVerticalIcon.js';
|
|
80
|
+
import '../../Icons/DotsHorizontalIcon.js';
|
|
81
|
+
import '../../Icons/ChevronLeftIcon.js';
|
|
82
|
+
import '../../Icons/ChevronRightIcon.js';
|
|
83
|
+
import '../../Icons/FolderOpenIcon.js';
|
|
84
|
+
import '../../Icons/FolderCogIcon.js';
|
|
85
|
+
import '../../Icons/UsersIcon.js';
|
|
86
|
+
import '../../Icons/BuildingIcon.js';
|
|
87
|
+
import '../../Icons/FileTextIcon.js';
|
|
88
|
+
import '../../Icons/PauseIcon.js';
|
|
89
|
+
import '../../Icons/StopIcon.js';
|
|
90
|
+
import '../../Icons/SendIcon.js';
|
|
91
|
+
import '../../Icons/TerminalIcon.js';
|
|
92
|
+
import '../../Icons/GitBranchIcon.js';
|
|
93
|
+
import '../../Icons/BugIcon.js';
|
|
94
|
+
import '../../Icons/MinusIcon.js';
|
|
95
|
+
import '../../Icons/PinIcon.js';
|
|
10
96
|
import { cx } from '../../../utils/cx.js';
|
|
11
97
|
import { vars } from '../../../theme/contract.css.js';
|
|
12
98
|
import { axisInputStyle, axisColorVar, axisLabelRecipe, linkButtonRecipe, gapVar, vectorRowRecipe, vectorContainerStyle } from './VectorInput.css.js';
|
|
@@ -43,9 +129,6 @@ function getAxisLabels(labelPreset, axisLabels, dimension) {
|
|
|
43
129
|
}
|
|
44
130
|
return Array.from({ length: dimension }, (_, i) => String(i));
|
|
45
131
|
}
|
|
46
|
-
// SVG icons for link/unlink
|
|
47
|
-
const LinkIcon = ({ size }) => (jsx("svg", { width: size, height: size, viewBox: "0 0 16 16", fill: "none", children: jsx("path", { d: "M6.5 9.5L9.5 6.5M5.5 7.5L4.146 8.854a2 2 0 002.708 2.708L8.5 10.5M7.5 5.5l1.646-1.646a2 2 0 012.708 2.708L10.5 8.5", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round" }) }));
|
|
48
|
-
const UnlinkIcon = ({ size }) => (jsx("svg", { width: size, height: size, viewBox: "0 0 16 16", fill: "none", children: jsx("path", { d: "M5.5 7.5L4.146 8.854a2 2 0 002.708 2.708L8.5 10.5M7.5 5.5l1.646-1.646a2 2 0 012.708 2.708L10.5 8.5M4 4l8 8", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round" }) }));
|
|
49
132
|
/**
|
|
50
133
|
* A grouped numeric input for Vec2, Vec3, and Vec4 vectors.
|
|
51
134
|
*
|
|
@@ -124,7 +207,7 @@ const VectorInput = ({ value: controlledValue, defaultValue, dimension = 3, labe
|
|
|
124
207
|
// Fallback to theme secondary text color when no axis color
|
|
125
208
|
const resolvedColor = axisColor ?? vars.colors.text.secondary;
|
|
126
209
|
return (jsxs("div", { className: axisInputStyle, children: [jsx("div", { className: axisLabelRecipe({ size }), style: assignInlineVars({ [axisColorVar]: resolvedColor }), children: axisLabel }), jsx(NumberInput, { value: axisValue, onChange: (val) => handleAxisChange(i, val), onBlur: handleCommit, min: min, max: max, step: step, precisionStep: precisionStep, largeStep: largeStep, precision: precision, unit: unit, size: size, disabled: disabled, showStepButtons: false, "aria-label": `${axisLabel} axis` })] }, i));
|
|
127
|
-
}), showLink && (jsx("button", { type: "button", className: linkButtonRecipe({ active: isLinked, size }), onClick: handleLinkToggle, disabled: disabled, "aria-pressed": isLinked, "aria-label": isLinked ? 'Unlink axes' : 'Link axes', title: isLinked ? 'Unlink axes' : 'Link axes', children: isLinked ? (jsx(LinkIcon, { size: iconSize })) : (jsx(UnlinkIcon, { size: iconSize })) }))] }), (error && errorMessage) || helperText ? (jsx(FormHelperText, { error: error && !!errorMessage, children: error && errorMessage ? errorMessage : helperText })) : null] }));
|
|
210
|
+
}), showLink && (jsx("button", { type: "button", className: linkButtonRecipe({ active: isLinked, size }), onClick: handleLinkToggle, disabled: disabled, "aria-pressed": isLinked, "aria-label": isLinked ? 'Unlink axes' : 'Link axes', title: isLinked ? 'Unlink axes' : 'Link axes', children: isLinked ? (jsx(LinkIcon, { size: iconSize, color: "currentColor", decorative: true })) : (jsx(UnlinkIcon, { size: iconSize, color: "currentColor", decorative: true })) }))] }), (error && errorMessage) || helperText ? (jsx(FormHelperText, { error: error && !!errorMessage, children: error && errorMessage ? errorMessage : helperText })) : null] }));
|
|
128
211
|
};
|
|
129
212
|
VectorInput.displayName = 'VectorInput';
|
|
130
213
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VectorInput.js","sources":["../../../../../../src/components/controls/VectorInput/VectorInput.tsx"],"sourcesContent":[null],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"VectorInput.js","sources":["../../../../../../src/components/controls/VectorInput/VectorInput.tsx"],"sourcesContent":[null],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAqBA;AAEA;;;AAGE;;AAGF;AAEA;AACA;AAEA;AAKE;AACE;;AAEF;AACE;;AAEF;AACE;;;AAGF;AACF;AAEA;AAKE;AACE;;AAEF;;;;;AAKF;AAEA;;;;;;;;;;;;;;;;AAgBG;;;AAmCD;AAGA;;;AAIA;;AAGA;;AAGA;AACE;AACF;;AAGA;AACE;AACA;;;AAGA;;;;AAME;AACA;;;AAIE;;AAEE;;;;;AAMA;;;;;;;AAWJ;AAEA;;;AAGA;;;AAMJ;AACE;AACF;;;;AAOA;;;;;;;AA+CM;AA4BR;AAEA;;"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import './../../../assets/src/components/data/DataTable/DataTable.css.ts.vanilla-CmRgtjIW.css';
|
|
2
|
+
import { createRuntimeFn } from '@vanilla-extract/recipes/createRuntimeFn';
|
|
3
|
+
|
|
4
|
+
var bodyStyle = 'DataTable_bodyStyle__v4olr8o';
|
|
5
|
+
var cellRecipe = createRuntimeFn({defaultClassName:'DataTable_cellRecipe__v4olr8v',variantClassNames:{align:{left:'DataTable_cellRecipe_align_left__v4olr8w',center:'DataTable_cellRecipe_align_center__v4olr8x',right:'DataTable_cellRecipe_align_right__v4olr8y'},sticky:{true:'DataTable_cellRecipe_sticky_true__v4olr8z'},selectColumn:{true:'DataTable_cellRecipe_selectColumn_true__v4olr810'}},defaultVariants:{},compoundVariants:[]});
|
|
6
|
+
var emptyStateStyle = 'DataTable_emptyStateStyle__v4olr811';
|
|
7
|
+
var gridTemplateColumnsVar = 'var(--gridTemplateColumnsVar__v4olr82)';
|
|
8
|
+
var headerCellInnerStyle = 'DataTable_headerCellInnerStyle__v4olr8k';
|
|
9
|
+
var headerCellRecipe = createRuntimeFn({defaultClassName:'DataTable_headerCellRecipe__v4olr8d',variantClassNames:{align:{left:'DataTable_headerCellRecipe_align_left__v4olr8e',center:'DataTable_headerCellRecipe_align_center__v4olr8f',right:'DataTable_headerCellRecipe_align_right__v4olr8g'},sortable:{true:'DataTable_headerCellRecipe_sortable_true__v4olr8h'},sticky:{true:'DataTable_headerCellRecipe_sticky_true__v4olr8i'},selectColumn:{true:'DataTable_headerCellRecipe_selectColumn_true__v4olr8j'}},defaultVariants:{},compoundVariants:[]});
|
|
10
|
+
var headerStyle = createRuntimeFn({defaultClassName:'DataTable_headerStyle__v4olr8b',variantClassNames:{sticky:{true:'DataTable_headerStyle_sticky_true__v4olr8c'}},defaultVariants:{},compoundVariants:[]});
|
|
11
|
+
var innerWrapperStyle = 'DataTable_innerWrapperStyle__v4olr8a';
|
|
12
|
+
var resizeHandleStyle = 'DataTable_resizeHandleStyle__v4olr8n';
|
|
13
|
+
var rootRecipe = createRuntimeFn({defaultClassName:'DataTable_rootRecipe__v4olr85',variantClassNames:{density:{comfortable:'DataTable_rootRecipe_density_comfortable__v4olr86',compact:'DataTable_rootRecipe_density_compact__v4olr87',dense:'DataTable_rootRecipe_density_dense__v4olr88'}},defaultVariants:{density:'comfortable'},compoundVariants:[]});
|
|
14
|
+
var rowRecipe = createRuntimeFn({defaultClassName:'DataTable_rowRecipe__v4olr8q',variantClassNames:{virtualized:{true:'DataTable_rowRecipe_virtualized_true__v4olr8r'},interactive:{true:'DataTable_rowRecipe_interactive_true__v4olr8s'},selected:{true:'DataTable_rowRecipe_selected_true__v4olr8t'},active:{true:'DataTable_rowRecipe_active_true__v4olr8u'}},defaultVariants:{},compoundVariants:[]});
|
|
15
|
+
var scrollContainerStyle = 'DataTable_scrollContainerStyle__v4olr89';
|
|
16
|
+
var skeletonBarStyle = 'DataTable_skeletonBarStyle__v4olr814';
|
|
17
|
+
var skeletonCellStyle = 'DataTable_skeletonCellStyle__v4olr813';
|
|
18
|
+
var skeletonRowStyle = 'DataTable_skeletonRowStyle__v4olr812';
|
|
19
|
+
var sortIndicatorRecipe = createRuntimeFn({defaultClassName:'DataTable_sortIndicatorRecipe__v4olr8l',variantClassNames:{active:{true:'DataTable_sortIndicatorRecipe_active_true__v4olr8m'}},defaultVariants:{},compoundVariants:[]});
|
|
20
|
+
var tableMinWidthVar = 'var(--tableMinWidthVar__v4olr83)';
|
|
21
|
+
var totalHeightVar = 'var(--totalHeightVar__v4olr80)';
|
|
22
|
+
var virtualBodyStyle = 'DataTable_virtualBodyStyle__v4olr8p';
|
|
23
|
+
|
|
24
|
+
export { bodyStyle, cellRecipe, emptyStateStyle, gridTemplateColumnsVar, headerCellInnerStyle, headerCellRecipe, headerStyle, innerWrapperStyle, resizeHandleStyle, rootRecipe, rowRecipe, scrollContainerStyle, skeletonBarStyle, skeletonCellStyle, skeletonRowStyle, sortIndicatorRecipe, tableMinWidthVar, totalHeightVar, virtualBodyStyle };
|
|
25
|
+
//# sourceMappingURL=DataTable.css.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DataTable.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;"}
|