@helsenorge/designsystem-react 12.7.0 → 12.8.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.
Files changed (67) hide show
  1. package/AsChildSlot.js +74 -0
  2. package/AsChildSlot.js.map +1 -0
  3. package/CHANGELOG.md +37 -5
  4. package/Drawer.js +58 -4
  5. package/Drawer.js.map +1 -1
  6. package/HN.Designsystem.Dropdown.nb-NO.js +13 -0
  7. package/HN.Designsystem.Dropdown.nb-NO.js.map +1 -0
  8. package/HelpDetails.js +1 -1
  9. package/LinkList.js +1 -0
  10. package/LinkList.js.map +1 -1
  11. package/SingleSelectItem.js +96 -0
  12. package/SingleSelectItem.js.map +1 -0
  13. package/clamp.js +11 -0
  14. package/clamp.js.map +1 -0
  15. package/components/ArticleTeaser/styles.module.scss +3 -5
  16. package/components/AsChildSlot/AsChildSlot.d.ts +23 -0
  17. package/components/AsChildSlot/AsChildSlot.test.d.ts +1 -0
  18. package/components/AsChildSlot/index.d.ts +3 -0
  19. package/components/AsChildSlot/index.js +6 -0
  20. package/components/AsChildSlot/index.js.map +1 -0
  21. package/components/AsChildSlot/styles.module.scss +13 -0
  22. package/components/AsChildSlot/styles.module.scss.d.ts +9 -0
  23. package/components/Drawer/styles.module.scss +45 -26
  24. package/components/Drawer/styles.module.scss.d.ts +5 -0
  25. package/components/Dropdown/Dropdown.d.ts +19 -21
  26. package/components/Dropdown/Dropdown.test.d.ts +1 -0
  27. package/components/Dropdown/SingleSelect/SingleSelect.d.ts +18 -0
  28. package/components/Dropdown/SingleSelect/SingleSelect.test.d.ts +1 -0
  29. package/components/Dropdown/SingleSelect/SingleSelectItem.d.ts +21 -0
  30. package/components/Dropdown/SingleSelect/index.d.ts +3 -0
  31. package/components/Dropdown/SingleSelect/index.js +6 -0
  32. package/components/Dropdown/SingleSelect/index.js.map +1 -0
  33. package/components/Dropdown/SingleSelect/styles.module.scss +54 -0
  34. package/components/Dropdown/SingleSelect/styles.module.scss.d.ts +14 -0
  35. package/components/Dropdown/index.js +140 -76
  36. package/components/Dropdown/index.js.map +1 -1
  37. package/components/Dropdown/styles.module.scss +90 -136
  38. package/components/Dropdown/styles.module.scss.d.ts +8 -9
  39. package/components/DropdownOld/DropdownOld.d.ts +42 -0
  40. package/components/DropdownOld/index.d.ts +3 -0
  41. package/components/DropdownOld/index.js +194 -0
  42. package/components/DropdownOld/index.js.map +1 -0
  43. package/components/DropdownOld/resourceHelper.d.ts +3 -0
  44. package/components/DropdownOld/styles.module.scss +230 -0
  45. package/components/DropdownOld/styles.module.scss.d.ts +25 -0
  46. package/components/Icons/EmoticonAnnoyed.js +8 -11
  47. package/components/Icons/EmoticonAnnoyed.js.map +1 -1
  48. package/components/Icons/EmoticonDelighted.js +8 -4
  49. package/components/Icons/EmoticonDelighted.js.map +1 -1
  50. package/components/Icons/EmoticonDisappointed.js +8 -4
  51. package/components/Icons/EmoticonDisappointed.js.map +1 -1
  52. package/components/Icons/EmoticonHappy.js +8 -4
  53. package/components/Icons/EmoticonHappy.js.map +1 -1
  54. package/components/Icons/EmoticonMeh.js +8 -4
  55. package/components/Icons/EmoticonMeh.js.map +1 -1
  56. package/components/LinkList/styles.module.scss +47 -61
  57. package/components/LinkList/styles.module.scss.d.ts +1 -0
  58. package/components/ListEditMode/styles.module.scss +1 -0
  59. package/components/NotificationPanel/index.js +3 -1
  60. package/components/NotificationPanel/index.js.map +1 -1
  61. package/components/NotificationPanel/styles.module.scss +10 -5
  62. package/designsystem-react.css +10 -0
  63. package/package.json +1 -1
  64. package/scss/supernova/styles/colors.css +10 -0
  65. package/use-animate.js +1 -7
  66. package/use-animate.js.map +1 -1
  67. /package/{resources/index.d.ts → components/DropdownOld/DropdownOld.test.d.ts} +0 -0
@@ -0,0 +1,96 @@
1
+ import { jsx, jsxs, Fragment } from "react/jsx-runtime";
2
+ import React__default, { useId } from "react";
3
+ import classNames from "classnames";
4
+ import { A as AsChildSlot } from "./AsChildSlot.js";
5
+ import styles from "./components/Dropdown/SingleSelect/styles.module.scss";
6
+ const SingleSelectContext = React__default.createContext(null);
7
+ const SingleSelect = ({ name, disabled, defaultValue, onValueChange, children }) => {
8
+ const [selected, setSelected] = React__default.useState(defaultValue);
9
+ const context = React__default.useMemo(
10
+ () => ({
11
+ name,
12
+ disabled,
13
+ value: selected,
14
+ onValueChange: (v, e) => {
15
+ setSelected(v);
16
+ onValueChange == null ? void 0 : onValueChange(v, e);
17
+ }
18
+ }),
19
+ [name, disabled, selected, onValueChange]
20
+ );
21
+ return /* @__PURE__ */ jsx(SingleSelectContext.Provider, { value: context, children });
22
+ };
23
+ const useSingleSelect = () => React__default.useContext(SingleSelectContext);
24
+ const SingleSelectItem = React__default.forwardRef((props, ref) => {
25
+ const { text, value, testId, asChild = false, children, disabled, defaultSelected, ...rest } = props;
26
+ const generatedId = useId();
27
+ const inputId = props.inputId ?? generatedId;
28
+ const group = useSingleSelect();
29
+ const optionValue = typeof value === "string" && value.length > 0 ? value : inputId;
30
+ const isSelected = group ? group.value === optionValue : false;
31
+ const isDisabled = !!disabled || !!(group == null ? void 0 : group.disabled);
32
+ const asChildSlotRef = React__default.useRef(null);
33
+ React__default.useEffect(() => {
34
+ var _a;
35
+ if (defaultSelected && group && typeof group.value === "undefined") {
36
+ (_a = group.onValueChange) == null ? void 0 : _a.call(group, optionValue);
37
+ }
38
+ }, [defaultSelected, group, optionValue]);
39
+ const contentClasses = classNames(styles["single-select-item__content"], {
40
+ [styles["single-select-item__content--disabled"]]: isDisabled
41
+ });
42
+ const dotClasses = classNames(styles["single-select-item__dot"], {
43
+ [styles["single-select-item__dot--disabled"]]: isDisabled,
44
+ [styles["single-select-item__dot--checked"]]: isSelected
45
+ });
46
+ const childArray = React__default.Children.toArray(children).filter(React__default.isValidElement);
47
+ const childElement = childArray[0] ?? null;
48
+ const selectThis = (e) => {
49
+ var _a;
50
+ if (isDisabled) return;
51
+ if (group && group.value !== optionValue) {
52
+ (_a = group.onValueChange) == null ? void 0 : _a.call(group, optionValue, e);
53
+ }
54
+ };
55
+ const content = /* @__PURE__ */ jsxs(Fragment, { children: [
56
+ /* @__PURE__ */ jsx("span", { className: dotClasses, "aria-hidden": true }),
57
+ /* @__PURE__ */ jsx("span", { children: text })
58
+ ] });
59
+ const Component = asChild ? AsChildSlot : "button";
60
+ const componentProps = asChild ? {
61
+ ref: asChildSlotRef,
62
+ elementRef: ref,
63
+ className: contentClasses,
64
+ disabled: isDisabled,
65
+ onSelect: (e) => selectThis(e),
66
+ ariaCurrent: isSelected ? "true" : void 0,
67
+ children: childElement,
68
+ content
69
+ } : {
70
+ ...rest,
71
+ type: "button",
72
+ className: contentClasses,
73
+ disabled: isDisabled,
74
+ onClick: (e) => {
75
+ e.preventDefault();
76
+ selectThis(e);
77
+ },
78
+ onKeyDown: (e) => {
79
+ if (e.key === "Enter") {
80
+ e.preventDefault();
81
+ selectThis(e);
82
+ }
83
+ },
84
+ ref,
85
+ "aria-disabled": isDisabled || void 0,
86
+ "aria-current": isSelected ? "true" : void 0,
87
+ children: content
88
+ };
89
+ return /* @__PURE__ */ jsx("div", { "data-testid": testId, className: styles["single-select-item"], children: /* @__PURE__ */ jsx(Component, { ...componentProps }) });
90
+ });
91
+ SingleSelectItem.displayName = "Dropdown.SingleSelectItem";
92
+ export {
93
+ SingleSelectItem as S,
94
+ SingleSelect as a
95
+ };
96
+ //# sourceMappingURL=SingleSelectItem.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SingleSelectItem.js","sources":["../src/components/Dropdown/SingleSelect/SingleSelect.tsx","../src/components/Dropdown/SingleSelect/SingleSelectItem.tsx"],"sourcesContent":["import React from 'react';\n\ntype SingleSelectContextType = {\n name?: string;\n disabled?: boolean;\n required?: boolean;\n value?: string;\n onValueChange?: (newValue: string, e?: React.SyntheticEvent) => void;\n};\n\nconst SingleSelectContext = React.createContext<SingleSelectContextType | null>(null);\n\nexport interface SingleSelectProps {\n name?: string;\n disabled?: boolean;\n defaultValue?: string;\n onValueChange?: (newValue: string, e?: React.SyntheticEvent) => void;\n children: React.ReactNode;\n}\n\nexport const SingleSelect: React.FC<SingleSelectProps> = ({ name, disabled, defaultValue, onValueChange, children }) => {\n const [selected, setSelected] = React.useState<string | undefined>(defaultValue);\n\n const context = React.useMemo<SingleSelectContextType>(\n () => ({\n name,\n disabled,\n value: selected,\n onValueChange: (v, e): void => {\n setSelected(v);\n onValueChange?.(v, e);\n },\n }),\n [name, disabled, selected, onValueChange]\n );\n\n return <SingleSelectContext.Provider value={context}>{children}</SingleSelectContext.Provider>;\n};\n\nexport const useSingleSelect = (): SingleSelectContextType | null => React.useContext(SingleSelectContext);\n","import React, { useId } from 'react';\n\nimport classNames from 'classnames';\n\nimport { useSingleSelect } from './SingleSelect';\nimport AsChildSlot, { AsChildSlotHandle } from '../../AsChildSlot';\n\nimport styles from './styles.module.scss';\n\nexport interface SingleSelectItemProps extends Pick<React.ButtonHTMLAttributes<HTMLButtonElement>, 'disabled'> {\n /** The text to the singleSelectItem */\n text?: string;\n /** input id of the singleSelectItem */\n inputId?: string;\n /** Sets the data-testid attribute. */\n testId?: string;\n /** When true, onclick and keyboard events will be passed to the child Button or AnchorLink. */\n asChild?: boolean;\n /** Only use when asChild is set to true and only pass one child */\n children?: React.ReactNode;\n /** Value for this singleSelectItem option - used by the parent wrapper to keep track of the context */\n value?: string;\n /** aria-describedby passthrough if needed */\n ['aria-describedby']?: string;\n /** Marks this option as initially selected */\n defaultSelected?: boolean;\n}\n\nexport const SingleSelectItem = React.forwardRef((props: SingleSelectItemProps, ref: React.Ref<HTMLElement>) => {\n const { text, value, testId, asChild = false, children, disabled, defaultSelected, ...rest } = props;\n\n const generatedId = useId();\n const inputId = props.inputId ?? generatedId;\n const group = useSingleSelect();\n const optionValue = typeof value === 'string' && value.length > 0 ? value : inputId;\n const isSelected = group ? group.value === optionValue : false;\n const isDisabled = !!disabled || !!group?.disabled;\n const asChildSlotRef = React.useRef<AsChildSlotHandle | null>(null);\n\n React.useEffect(() => {\n if (defaultSelected && group && typeof group.value === 'undefined') {\n group.onValueChange?.(optionValue);\n }\n }, [defaultSelected, group, optionValue]);\n\n const contentClasses = classNames(styles['single-select-item__content'], {\n [styles['single-select-item__content--disabled']]: isDisabled,\n });\n const dotClasses = classNames(styles['single-select-item__dot'], {\n [styles['single-select-item__dot--disabled']]: isDisabled,\n [styles['single-select-item__dot--checked']]: isSelected,\n });\n\n const childArray = React.Children.toArray(children).filter(React.isValidElement) as React.ReactElement[];\n const childElement = childArray[0] ?? null;\n\n const selectThis = (e?: React.SyntheticEvent): void => {\n if (isDisabled) return;\n if (group && group.value !== optionValue) {\n group.onValueChange?.(optionValue, e);\n }\n };\n\n const content = (\n <>\n <span className={dotClasses} aria-hidden />\n <span>{text}</span>\n </>\n );\n\n const Component = (asChild ? AsChildSlot : 'button') as React.ElementType;\n\n const componentProps = asChild\n ? {\n ref: asChildSlotRef,\n elementRef: ref as React.Ref<HTMLElement>,\n className: contentClasses,\n disabled: isDisabled,\n onSelect: (e: React.SyntheticEvent): void => selectThis(e),\n ariaCurrent: isSelected ? 'true' : undefined,\n children: childElement,\n content,\n }\n : {\n ...rest,\n type: 'button' as const,\n className: contentClasses,\n disabled: isDisabled,\n onClick: (e: React.MouseEvent<HTMLButtonElement>): void => {\n e.preventDefault();\n selectThis(e);\n },\n onKeyDown: (e: React.KeyboardEvent<HTMLButtonElement>): void => {\n if (e.key === 'Enter') {\n e.preventDefault();\n selectThis(e);\n }\n },\n ref: ref as React.Ref<HTMLButtonElement>,\n 'aria-disabled': isDisabled || undefined,\n 'aria-current': isSelected ? 'true' : undefined,\n children: content,\n };\n\n return (\n <div data-testid={testId} className={styles['single-select-item']}>\n <Component {...componentProps} />\n </div>\n );\n});\n\nSingleSelectItem.displayName = 'Dropdown.SingleSelectItem';\n\nexport default SingleSelectItem;\n"],"names":["React"],"mappings":"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"}
package/clamp.js ADDED
@@ -0,0 +1,11 @@
1
+ const clamp = (min, max, v) => {
2
+ if (v > max)
3
+ return max;
4
+ if (v < min)
5
+ return min;
6
+ return v;
7
+ };
8
+ export {
9
+ clamp as c
10
+ };
11
+ //# sourceMappingURL=clamp.js.map
package/clamp.js.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"clamp.js","sources":["../../../node_modules/motion/dist/es/framer-motion/dist/es/utils/clamp.mjs"],"sourcesContent":["const clamp = (min, max, v) => {\n if (v > max)\n return max;\n if (v < min)\n return min;\n return v;\n};\n\nexport { clamp };\n"],"names":[],"mappings":"AAAK,MAAC,QAAQ,CAAC,KAAK,KAAK,MAAM;AAC3B,MAAI,IAAI;AACJ,WAAO;AACX,MAAI,IAAI;AACJ,WAAO;AACX,SAAO;AACX;","x_google_ignoreList":[0]}
@@ -61,7 +61,7 @@
61
61
  }
62
62
 
63
63
  &:active {
64
- background-color: var(--core-color-blueberry-800);
64
+ background-color: var(--color-action-background-onlight-active);
65
65
  }
66
66
 
67
67
  &--expanded {
@@ -70,13 +70,11 @@
70
70
  border: 1px solid var(--color-action-border-onlight);
71
71
 
72
72
  &:hover {
73
- // @todo: endre denne når ny token er laget
74
- background-color: var(--color-action-graphics-ondark-hover);
73
+ background-color: var(--color-action-background-like-transparent-but-opaque-onlight-hover);
75
74
  }
76
75
 
77
76
  &:active {
78
- // @todo: endre denne når ny token er laget
79
- background-color: var(--color-action-graphics-ondark);
77
+ background-color: var(--color-action-background-like-transparent-but-opaque-onlight-hoverselected);
80
78
  }
81
79
  }
82
80
  }
@@ -0,0 +1,23 @@
1
+ import { default as React } from 'react';
2
+ export interface AsChildSlotHandle {
3
+ /** Click the child’s DOM node */
4
+ click: () => void;
5
+ }
6
+ export interface AsChildSlotProps {
7
+ /** Pass one element/component that we will map to a DOM element (<a>, <button>, React Router <Link>) */
8
+ children?: React.ReactNode;
9
+ /** Class names to apply to the visible element */
10
+ className?: string;
11
+ /** Content to render inside the visible element - For example the text and icons of the parent component that renders AsChildSlot */
12
+ content?: React.ReactNode;
13
+ /** Disabled state passed down (merged with child’s disabled/aria-disabled) */
14
+ disabled?: boolean;
15
+ /** Called before the child’s onClick when visible */
16
+ onSelect?: (e: React.SyntheticEvent) => void;
17
+ /** Optional states to apply to the DOM element */
18
+ ariaCurrent?: 'page' | 'true';
19
+ /** DOM ref for the element we end up rendering */
20
+ elementRef?: React.Ref<HTMLElement>;
21
+ }
22
+ export declare const AsChildSlot: React.ForwardRefExoticComponent<AsChildSlotProps & React.RefAttributes<AsChildSlotHandle>>;
23
+ export default AsChildSlot;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,3 @@
1
+ import { default as AsChildSlot } from './AsChildSlot';
2
+ export * from './AsChildSlot';
3
+ export default AsChildSlot;
@@ -0,0 +1,6 @@
1
+ import { A as AsChildSlot } from "../../AsChildSlot.js";
2
+ export {
3
+ AsChildSlot,
4
+ AsChildSlot as default
5
+ };
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
@@ -0,0 +1,13 @@
1
+ .as-child-reset {
2
+ all: unset;
3
+ display: block;
4
+ width: 100%;
5
+ box-sizing: border-box;
6
+ text-decoration: none;
7
+ background: transparent;
8
+ border: 0;
9
+ padding: 0;
10
+ margin: 0;
11
+ cursor: pointer;
12
+ outline: none !important;
13
+ }
@@ -0,0 +1,9 @@
1
+ export type Styles = {
2
+ 'as-child-reset': string;
3
+ };
4
+
5
+ export type ClassNames = keyof Styles;
6
+
7
+ declare const styles: Styles;
8
+
9
+ export default styles;
@@ -5,23 +5,6 @@
5
5
  @use '../../scss/breakpoints' as breakpoints;
6
6
  @import '../../scss/supernova/styles/colors.css';
7
7
 
8
- @mixin drawer-scroll-shadow {
9
- // Scroll shadow
10
- // Inspired by: https://css-tricks.com/books/greatest-css-tricks/scroll-shadows/
11
- background:
12
- linear-gradient(white 30%, rgb(255 255 255 / 0%)) center top,
13
- linear-gradient(rgb(255 255 255 / 0%), white 70%) center bottom,
14
- linear-gradient(rgb(0 0 0 / 46%), rgb(0 0 0 / 0%)) center top,
15
- linear-gradient(rgb(0 0 0 / 0%), rgb(0 0 0 / 46%)) center bottom;
16
- background-repeat: no-repeat;
17
- background-size:
18
- 100% 40px,
19
- 100% 40px,
20
- 100% 16px,
21
- 100% 16px;
22
- background-attachment: local, local, scroll, scroll;
23
- }
24
-
25
8
  .drawer {
26
9
  position: fixed;
27
10
  inset: 0;
@@ -43,7 +26,6 @@
43
26
  position: fixed;
44
27
  width: 100%;
45
28
  max-height: 90dvh;
46
- overflow: hidden;
47
29
  transform: translateY(100%);
48
30
  background-color: var(--core-color-white);
49
31
  border-radius: 0.75rem 0.75rem 0 0;
@@ -81,8 +63,6 @@
81
63
  @include breakpoints.tiny-screens-media-query {
82
64
  overflow-y: auto;
83
65
 
84
- @include drawer-scroll-shadow;
85
-
86
66
  &:focus-visible {
87
67
  outline: 1px solid palette.$black;
88
68
  outline-offset: -1px;
@@ -130,22 +110,61 @@
130
110
 
131
111
  &__content {
132
112
  overflow-y: auto;
133
- padding: spacers.getSpacer(xs) spacers.getSpacer(2xs);
134
113
 
135
114
  &:focus-visible {
136
115
  outline: 1px solid palette.$black;
137
116
  outline-offset: -1px;
138
117
  }
139
118
 
140
- @media (min-width: map.get(breakpoints.$grid-breakpoints, md)) {
141
- padding: spacers.getSpacer(s) spacers.getSpacer(xs);
142
- }
143
-
144
119
  @include breakpoints.tiny-screens-media-query {
145
120
  overflow-y: unset;
146
121
  }
147
122
 
148
- @include drawer-scroll-shadow;
123
+ &__children {
124
+ padding: spacers.getSpacer(xs) spacers.getSpacer(2xs);
125
+
126
+ @media (min-width: map.get(breakpoints.$grid-breakpoints, md)) {
127
+ padding: spacers.getSpacer(s) spacers.getSpacer(xs);
128
+ }
129
+ }
130
+
131
+ &__shadow {
132
+ position: absolute;
133
+ z-index: 10;
134
+ height: 16px;
135
+ width: 100%;
136
+ transition: opacity 0.5s;
137
+ opacity: 0;
138
+ pointer-events: none;
139
+
140
+ @include breakpoints.tiny-screens-media-query {
141
+ display: none;
142
+ }
143
+
144
+ &--top {
145
+ top: 0;
146
+ margin-bottom: calc(0rem - spacers.getSpacer(xs));
147
+ background: linear-gradient(0deg, rgb(0 0 0 / 0%) 0%, rgb(0 0 0 / 45.7%) 100%);
148
+
149
+ @media (min-width: map.get(breakpoints.$grid-breakpoints, md)) {
150
+ margin-bottom: calc(0rem - spacers.getSpacer(s));
151
+ }
152
+ }
153
+
154
+ &--bottom {
155
+ bottom: 0;
156
+ background: linear-gradient(180deg, rgb(0 0 0 / 0%) 0%, rgb(0 0 0 / 45.7%) 100%);
157
+ margin-top: calc(0rem - spacers.getSpacer(xs));
158
+
159
+ @media (min-width: map.get(breakpoints.$grid-breakpoints, md)) {
160
+ margin-top: calc(0rem - spacers.getSpacer(s));
161
+ }
162
+ }
163
+
164
+ &--show {
165
+ opacity: 1;
166
+ }
167
+ }
149
168
  }
150
169
 
151
170
  &__footer {
@@ -4,6 +4,11 @@ export type Styles = {
4
4
  drawer__container__inner: string;
5
5
  'drawer__container--right': string;
6
6
  drawer__content: string;
7
+ drawer__content__children: string;
8
+ drawer__content__shadow: string;
9
+ 'drawer__content__shadow--bottom': string;
10
+ 'drawer__content__shadow--show': string;
11
+ 'drawer__content__shadow--top': string;
7
12
  drawer__footer: string;
8
13
  drawer__header: string;
9
14
  'drawer__header__close-button': string;
@@ -1,34 +1,24 @@
1
- import { default as React } from 'react';
1
+ import { default as React, ComponentType } from 'react';
2
+ import { SingleSelectItemProps } from './SingleSelect/SingleSelectItem';
2
3
  import { HNDesignsystemDropdown } from '../../resources/Resources';
3
- export declare enum DropdownOnColor {
4
- onwhite = "onwhite",
5
- ongrey = "ongrey",
6
- onblueberry = "onblueberry",
7
- oncherry = "oncherry"
8
- }
4
+ import { SvgIcon } from '../Icon';
5
+ import { IconName } from '../Icons/IconNames';
6
+ type DropdownVariants = 'fill' | 'transparent' | 'borderless';
9
7
  export interface DropdownProps {
10
- /** Label for dropdown. Visible for screen readers */
11
- label: string;
12
8
  /** Text on the trigger button that opens the dropdown */
13
- placeholder: string;
9
+ triggerText: string;
14
10
  /** Sets the dropdown content */
15
11
  children: React.ReactNode;
16
- /** @deprecated Close button text */
17
- closeText?: string;
18
- /** Minimum width for the dropdown in pixels. Does not affect trigger button */
12
+ /** Minimum width for the dropdown in pixels. Does not affect trigger button. */
19
13
  dropdownMinWidth?: number;
20
- /** No close button */
14
+ /** Minimum width for the trigger in pixels. Does not apply for borderless variant */
15
+ triggerMinWidth?: number;
16
+ /** Disables rendring of the close button in the list */
21
17
  noCloseButton?: boolean;
22
18
  /** Called when dropdown is open/closed */
23
19
  onToggle?: (isOpen: boolean) => void;
24
20
  /** Whether the dropdown is open or not */
25
21
  open?: boolean;
26
- /** Changes the visuals of the dropdown */
27
- onColor?: keyof typeof DropdownOnColor;
28
- /** Makes the background of the trigger transparent */
29
- transparent?: boolean;
30
- /** Makes the width of the full component adjust to its parent */
31
- fluid?: boolean;
32
22
  /** Makes the dropdown disabled */
33
23
  disabled?: boolean;
34
24
  /** Sets the data-testid attribute on the dropdown button */
@@ -37,6 +27,14 @@ export interface DropdownProps {
37
27
  zIndex?: number;
38
28
  /** Resources for component */
39
29
  resources?: Partial<HNDesignsystemDropdown>;
30
+ /** Adds an icon to the trigger */
31
+ svgIcon?: SvgIcon | IconName;
32
+ /** Sets the visual variant of the Dropdown */
33
+ variant?: DropdownVariants;
34
+ }
35
+ export declare const DropdownBase: React.FC<DropdownProps>;
36
+ export interface DropdownCompound extends React.FC<DropdownProps> {
37
+ SingleSelectItem: ComponentType<SingleSelectItemProps>;
40
38
  }
41
- declare const Dropdown: React.FC<DropdownProps>;
39
+ declare const Dropdown: DropdownCompound;
42
40
  export default Dropdown;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,18 @@
1
+ import { default as React } from 'react';
2
+ type SingleSelectContextType = {
3
+ name?: string;
4
+ disabled?: boolean;
5
+ required?: boolean;
6
+ value?: string;
7
+ onValueChange?: (newValue: string, e?: React.SyntheticEvent) => void;
8
+ };
9
+ export interface SingleSelectProps {
10
+ name?: string;
11
+ disabled?: boolean;
12
+ defaultValue?: string;
13
+ onValueChange?: (newValue: string, e?: React.SyntheticEvent) => void;
14
+ children: React.ReactNode;
15
+ }
16
+ export declare const SingleSelect: React.FC<SingleSelectProps>;
17
+ export declare const useSingleSelect: () => SingleSelectContextType | null;
18
+ export {};
@@ -0,0 +1,21 @@
1
+ import { default as React } from 'react';
2
+ export interface SingleSelectItemProps extends Pick<React.ButtonHTMLAttributes<HTMLButtonElement>, 'disabled'> {
3
+ /** The text to the singleSelectItem */
4
+ text?: string;
5
+ /** input id of the singleSelectItem */
6
+ inputId?: string;
7
+ /** Sets the data-testid attribute. */
8
+ testId?: string;
9
+ /** When true, onclick and keyboard events will be passed to the child Button or AnchorLink. */
10
+ asChild?: boolean;
11
+ /** Only use when asChild is set to true and only pass one child */
12
+ children?: React.ReactNode;
13
+ /** Value for this singleSelectItem option - used by the parent wrapper to keep track of the context */
14
+ value?: string;
15
+ /** aria-describedby passthrough if needed */
16
+ ['aria-describedby']?: string;
17
+ /** Marks this option as initially selected */
18
+ defaultSelected?: boolean;
19
+ }
20
+ export declare const SingleSelectItem: React.ForwardRefExoticComponent<SingleSelectItemProps & React.RefAttributes<HTMLElement>>;
21
+ export default SingleSelectItem;
@@ -0,0 +1,3 @@
1
+ import { default as SingleSelectItem } from './SingleSelectItem';
2
+ export * from './SingleSelectItem';
3
+ export default SingleSelectItem;
@@ -0,0 +1,6 @@
1
+ import { S as SingleSelectItem } from "../../../SingleSelectItem.js";
2
+ export {
3
+ SingleSelectItem,
4
+ SingleSelectItem as default
5
+ };
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
@@ -0,0 +1,54 @@
1
+ @use 'sass:map';
2
+ @use 'sass:meta';
3
+ @use 'sass:string';
4
+ @import '../../../scss/supernova/styles/colors.css';
5
+ @import '../../../scss/supernova/styles/spacers.css';
6
+
7
+ .single-select-item {
8
+ cursor: pointer;
9
+
10
+ :focus-visible {
11
+ outline: none;
12
+ }
13
+
14
+ &__content {
15
+ all: unset;
16
+ width: 100%;
17
+ box-sizing: border-box;
18
+ display: flex;
19
+ align-items: baseline;
20
+ cursor: pointer;
21
+ padding: var(--core-space-2xs) 0 var(--core-space-2xs) var(--core-space-s);
22
+ line-height: 1.75rem;
23
+
24
+ &--disabled {
25
+ cursor: default;
26
+ }
27
+ }
28
+
29
+ &__dot {
30
+ appearance: none;
31
+ cursor: pointer;
32
+ display: flex;
33
+ justify-content: center;
34
+ align-items: center;
35
+ margin: 0 0.667rem 0 0;
36
+ background-color: transparent;
37
+ min-width: 0.67rem;
38
+ min-height: 0.67rem;
39
+ border-radius: 10rem;
40
+ outline: none;
41
+
42
+ &:checked {
43
+ background-color: var(--core-color-black);
44
+ }
45
+
46
+ &--checked {
47
+ background-color: var(--core-color-black);
48
+ }
49
+
50
+ &--disabled {
51
+ cursor: default;
52
+ }
53
+ }
54
+ }
@@ -0,0 +1,14 @@
1
+ export type Styles = {
2
+ 'single-select-item': string;
3
+ 'single-select-item__content': string;
4
+ 'single-select-item__content--disabled': string;
5
+ 'single-select-item__dot': string;
6
+ 'single-select-item__dot--checked': string;
7
+ 'single-select-item__dot--disabled': string;
8
+ };
9
+
10
+ export type ClassNames = keyof Styles;
11
+
12
+ declare const styles: Styles;
13
+
14
+ export default styles;