@bbl-digital/snorre 4.1.82 → 4.1.83

Sign up to get free protection for your applications and to get access to all the features.
package/dist/bundle.js CHANGED
@@ -25245,10 +25245,15 @@
25245
25245
  const [open, toggleOpen] = React.useState(false);
25246
25246
  const onClick = function () {
25247
25247
  toggleOpen(!open && !disabled);
25248
+ props.onOpenChange?.(!open);
25249
+ };
25250
+ const handleOpen = open => {
25251
+ toggleOpen(open);
25252
+ props.onOpenChange?.(open);
25248
25253
  };
25249
25254
  React.useEffect(() => {
25250
25255
  if (closeKey) {
25251
- toggleOpen(false);
25256
+ handleOpen(false);
25252
25257
  }
25253
25258
  // eslint-disable-next-line react-hooks/exhaustive-deps
25254
25259
  }, [closeKey]);
@@ -25258,7 +25263,7 @@
25258
25263
  if (node && node.contains(e.target)) {
25259
25264
  return;
25260
25265
  }
25261
- toggleOpen(false);
25266
+ handleOpen(false);
25262
25267
  };
25263
25268
  if (open) {
25264
25269
  const firstOption = ref.current?.querySelector('button, a, [tabindex]');
@@ -25276,7 +25281,7 @@
25276
25281
  const onChange = value => {
25277
25282
  if (props.onChange && !disabled) {
25278
25283
  props.onChange(value);
25279
- toggleOpen(false);
25284
+ handleOpen(false);
25280
25285
  }
25281
25286
  };
25282
25287
  const Label = jsxRuntime.jsx(StyledLabel$1, {
@@ -25312,7 +25317,7 @@
25312
25317
  tabIndex: disabled ? -1 : undefined,
25313
25318
  children: props.selectedValue ? props.selectedValue : props.text || ''
25314
25319
  }), jsxRuntime.jsx(OptionsWrapper$2, {
25315
- css: [input && styles$k.inputstyle(!!label), optionsWidth && styles$k.optionsWidth(optionsWidth), process.env.NODE_ENV === "production" ? "" : ";label:NonNative;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/packages/core/Select/index.tsx"],"names":[],"mappings":"AAiLQ","file":"../../../src/packages/core/Select/index.tsx","sourcesContent":["/** @jsxImportSource @emotion/react */\nimport React, {\n  ReactNode,\n  ReactElement,\n  useState,\n  createRef,\n  useEffect,\n} from 'react'\nimport { SerializedStyles } from '@emotion/react'\nimport Option from './Option'\nimport { SelectWrapper, OptionsWrapper, styles, StyledLabel } from './styles'\nimport InfoButton from '../InfoButton'\nimport IconHelp from '../../icons/General/IconHelp'\nimport Button from '../Button'\nimport IconChevronDown from '../../icons/General/IconChevronDown'\nimport List from '../List'\n\nexport { Option }\n\ninterface IProps {\n  /** Text when no option are selected */\n  text?: string\n  /** Current selected value. Leave empty for default text. */\n  selectedValue?: string\n  /** Style as an input */\n  input?: boolean\n  /** Adds a label if input is selected  */\n  label?: string\n  /** Callback handler for when clicking option element. */\n  onChange?: (value: string) => any\n  /** Option-elements, select list content */\n  children: ReactNode[]\n  /** Adds icon to select  */\n  icon?: React.ReactNode\n  /** Type of select, default is transparent, primary10 adds primary background with 10 opacity */\n  type?: 'default' | 'primary10' | 'opacity08'\n  /** Use native selector */\n  native?: boolean\n  /** Select button width */\n  width?: string\n  /** Options content width */\n  optionsWidth?: string\n  /** Options max height. If set will set overflow-y to scroll. */\n  maxHeight?: string\n  /** Autofocus */\n  focus?: boolean\n  /** Add custom css to select when in open state */\n  customOpenstyle?: SerializedStyles\n  /** Override with custom CSS */\n  customStyle?: SerializedStyles\n  /** Add a data-tracking-event attribute. */\n  trackingEvent?: string\n  /** Add a data-tracking-name attribute. */\n  trackingName?: string\n  /** Select is disabled. */\n  disabled?: boolean\n  /** Manual close by changing closeKey externally */\n  closeKey?: string\n  /** Add classname */\n  className?: string\n  /** Adds info-text button */\n  info?: string\n  /** Where the info tooltip will be placed relative to the button @default left */\n  infoPlacement?: 'top' | 'left' | 'right' | 'bottom'\n}\n\nconst Select: React.FC<IProps> = ({\n  input,\n  icon,\n  type = 'default',\n  native,\n  optionsWidth,\n  width,\n  maxHeight,\n  focus,\n  customOpenstyle,\n  customStyle,\n  trackingEvent,\n  trackingName,\n  disabled,\n  label,\n  closeKey,\n  className,\n  info,\n  infoPlacement = 'left',\n  ...props\n}: IProps) => {\n  const ref = createRef<HTMLSpanElement>()\n  const [open, toggleOpen] = useState(false)\n\n  const onClick = function () {\n    toggleOpen(!open && !disabled)\n  }\n\n  useEffect(() => {\n    if (closeKey) {\n      toggleOpen(false)\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [closeKey])\n\n  useEffect(() => {\n    const handleClickOutside = (e: any) => {\n      const node = ref.current\n      if (node && node.contains(e.target)) {\n        return\n      }\n      toggleOpen(false)\n    }\n\n    if (open) {\n      const firstOption = ref.current?.querySelector(\n        'button, a, [tabindex]'\n      ) as HTMLElement\n      if (firstOption) {\n        firstOption.focus()\n      }\n      document.addEventListener('mousedown', handleClickOutside)\n    } else {\n      document.removeEventListener('mousedown', handleClickOutside)\n    }\n\n    return () => {\n      document.removeEventListener('mousedown', handleClickOutside)\n    }\n  }, [open, ref])\n\n  const onChange = (value: string) => {\n    if (props.onChange && !disabled) {\n      props.onChange(value)\n      toggleOpen(false)\n    }\n  }\n\n  const Label = <StyledLabel withInfo={Boolean(info)}>{label}</StyledLabel>\n\n  const NonNative = (\n    <SelectWrapper\n      ref={ref}\n      className={className}\n      css={(theme) => [\n        styles.default,\n        input && styles.input(theme),\n        input && open && styles.open(theme),\n        type === 'primary10' && styles.primary10(theme),\n        icon && styles.withIcon,\n        type === 'opacity08' && styles.opacity08(theme),\n        width && styles.width(width),\n        maxHeight && styles.maxHeight(maxHeight),\n        customStyle && customStyle,\n        open && customOpenstyle && customOpenstyle,\n        disabled && styles.disabled(theme),\n      ]}\n      aria-expanded={open}\n      aria-label={label ? label : 'Select'}\n    >\n      {input && label && Label}\n      {info && (\n        <span css={styles.infoButton}>\n          <InfoButton icon={<IconHelp primary />} place={infoPlacement}>\n            {info}\n          </InfoButton>\n        </span>\n      )}\n      <Button\n        nostyle\n        afterIcon={<IconChevronDown flipVertical={open} size={14} />}\n        onClick={onClick}\n        beforeIcon={icon}\n        autoFocus={focus}\n        trackingName={trackingName}\n        trackingEvent={trackingEvent}\n        tabIndex={disabled ? -1 : undefined}\n      >\n        {props.selectedValue ? props.selectedValue : props.text || ''}\n      </Button>\n      <OptionsWrapper\n        css={[\n          input && styles.inputstyle(!!label),\n          optionsWidth && styles.optionsWidth(optionsWidth),\n        ]}\n      >\n        {open ? (\n          <List selectList>\n            {props.children\n              .filter((x) => x)\n              .map((child, key) => {\n                if (!child) {\n                  return null\n                }\n                return React.cloneElement(child as ReactElement, {\n                  onChange: onChange,\n                  key,\n                })\n              })}\n          </List>\n        ) : null}\n      </OptionsWrapper>\n    </SelectWrapper>\n  )\n\n  const Native = (\n    <select\n      className={className}\n      css={(theme) => [\n        styles.default,\n        input && styles.input(theme),\n        input && open && styles.open(theme),\n        type === 'primary10' && styles.primary10(theme),\n        icon && styles.withIcon,\n      ]}\n      value={props.selectedValue ? props.selectedValue : props.text || ''}\n      onChange={(e) => onChange(e.target.value)}\n    >\n      {props.children\n        .filter((x) => x)\n        .map((child: any, key: any) => {\n          if (!child) {\n            return null\n          }\n          return (\n            <option key={key} value={child.props.value}>\n              {child.props.children}\n            </option>\n          )\n        })}\n    </select>\n  )\n\n  return native ? Native : NonNative\n}\n\nexport default Select\n"]} */"],
25320
+ css: [input && styles$k.inputstyle(!!label), optionsWidth && styles$k.optionsWidth(optionsWidth), process.env.NODE_ENV === "production" ? "" : ";label:NonNative;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/packages/core/Select/index.tsx"],"names":[],"mappings":"AAyLQ","file":"../../../src/packages/core/Select/index.tsx","sourcesContent":["/** @jsxImportSource @emotion/react */\nimport React, {\n  ReactNode,\n  ReactElement,\n  useState,\n  createRef,\n  useEffect,\n} from 'react'\nimport { SerializedStyles } from '@emotion/react'\nimport Option from './Option'\nimport { SelectWrapper, OptionsWrapper, styles, StyledLabel } from './styles'\nimport InfoButton from '../InfoButton'\nimport IconHelp from '../../icons/General/IconHelp'\nimport Button from '../Button'\nimport IconChevronDown from '../../icons/General/IconChevronDown'\nimport List from '../List'\n\nexport { Option }\n\ninterface IProps {\n  /** Text when no option are selected */\n  text?: string\n  /** Current selected value. Leave empty for default text. */\n  selectedValue?: string\n  /** Style as an input */\n  input?: boolean\n  /** Adds a label if input is selected  */\n  label?: string\n  /** Callback handler for when clicking option element. */\n  onChange?: (value: string) => any\n  /** Callback handle for when opening the select */\n  onOpenChange?: (open: boolean) => any\n  /** Option-elements, select list content */\n  children: ReactNode[]\n  /** Adds icon to select  */\n  icon?: React.ReactNode\n  /** Type of select, default is transparent, primary10 adds primary background with 10 opacity */\n  type?: 'default' | 'primary10' | 'opacity08'\n  /** Use native selector */\n  native?: boolean\n  /** Select button width */\n  width?: string\n  /** Options content width */\n  optionsWidth?: string\n  /** Options max height. If set will set overflow-y to scroll. */\n  maxHeight?: string\n  /** Autofocus */\n  focus?: boolean\n  /** Add custom css to select when in open state */\n  customOpenstyle?: SerializedStyles\n  /** Override with custom CSS */\n  customStyle?: SerializedStyles\n  /** Add a data-tracking-event attribute. */\n  trackingEvent?: string\n  /** Add a data-tracking-name attribute. */\n  trackingName?: string\n  /** Select is disabled. */\n  disabled?: boolean\n  /** Manual close by changing closeKey externally */\n  closeKey?: string\n  /** Add classname */\n  className?: string\n  /** Adds info-text button */\n  info?: string\n  /** Where the info tooltip will be placed relative to the button @default left */\n  infoPlacement?: 'top' | 'left' | 'right' | 'bottom'\n}\n\nconst Select: React.FC<IProps> = ({\n  input,\n  icon,\n  type = 'default',\n  native,\n  optionsWidth,\n  width,\n  maxHeight,\n  focus,\n  customOpenstyle,\n  customStyle,\n  trackingEvent,\n  trackingName,\n  disabled,\n  label,\n  closeKey,\n  className,\n  info,\n  infoPlacement = 'left',\n  ...props\n}: IProps) => {\n  const ref = createRef<HTMLSpanElement>()\n  const [open, toggleOpen] = useState(false)\n\n  const onClick = function () {\n    toggleOpen(!open && !disabled)\n    props.onOpenChange?.(!open)\n  }\n\n  const handleOpen = (open: boolean) => {\n    toggleOpen(open)\n    props.onOpenChange?.(open)\n  }\n\n  useEffect(() => {\n    if (closeKey) {\n      handleOpen(false)\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [closeKey])\n\n  useEffect(() => {\n    const handleClickOutside = (e: any) => {\n      const node = ref.current\n      if (node && node.contains(e.target)) {\n        return\n      }\n      handleOpen(false)\n    }\n\n    if (open) {\n      const firstOption = ref.current?.querySelector(\n        'button, a, [tabindex]'\n      ) as HTMLElement\n      if (firstOption) {\n        firstOption.focus()\n      }\n      document.addEventListener('mousedown', handleClickOutside)\n    } else {\n      document.removeEventListener('mousedown', handleClickOutside)\n    }\n\n    return () => {\n      document.removeEventListener('mousedown', handleClickOutside)\n    }\n  }, [open, ref])\n\n  const onChange = (value: string) => {\n    if (props.onChange && !disabled) {\n      props.onChange(value)\n      handleOpen(false)\n    }\n  }\n\n  const Label = <StyledLabel withInfo={Boolean(info)}>{label}</StyledLabel>\n\n  const NonNative = (\n    <SelectWrapper\n      ref={ref}\n      className={className}\n      css={(theme) => [\n        styles.default,\n        input && styles.input(theme),\n        input && open && styles.open(theme),\n        type === 'primary10' && styles.primary10(theme),\n        icon && styles.withIcon,\n        type === 'opacity08' && styles.opacity08(theme),\n        width && styles.width(width),\n        maxHeight && styles.maxHeight(maxHeight),\n        customStyle && customStyle,\n        open && customOpenstyle && customOpenstyle,\n        disabled && styles.disabled(theme),\n      ]}\n      aria-expanded={open}\n      aria-label={label ? label : 'Select'}\n    >\n      {input && label && Label}\n      {info && (\n        <span css={styles.infoButton}>\n          <InfoButton icon={<IconHelp primary />} place={infoPlacement}>\n            {info}\n          </InfoButton>\n        </span>\n      )}\n      <Button\n        nostyle\n        afterIcon={<IconChevronDown flipVertical={open} size={14} />}\n        onClick={onClick}\n        beforeIcon={icon}\n        autoFocus={focus}\n        trackingName={trackingName}\n        trackingEvent={trackingEvent}\n        tabIndex={disabled ? -1 : undefined}\n      >\n        {props.selectedValue ? props.selectedValue : props.text || ''}\n      </Button>\n      <OptionsWrapper\n        css={[\n          input && styles.inputstyle(!!label),\n          optionsWidth && styles.optionsWidth(optionsWidth),\n        ]}\n      >\n        {open ? (\n          <List selectList>\n            {props.children\n              .filter((x) => x)\n              .map((child, key) => {\n                if (!child) {\n                  return null\n                }\n                return React.cloneElement(child as ReactElement, {\n                  onChange: onChange,\n                  key,\n                })\n              })}\n          </List>\n        ) : null}\n      </OptionsWrapper>\n    </SelectWrapper>\n  )\n\n  const Native = (\n    <select\n      className={className}\n      css={(theme) => [\n        styles.default,\n        input && styles.input(theme),\n        input && open && styles.open(theme),\n        type === 'primary10' && styles.primary10(theme),\n        icon && styles.withIcon,\n      ]}\n      value={props.selectedValue ? props.selectedValue : props.text || ''}\n      onChange={(e) => onChange(e.target.value)}\n    >\n      {props.children\n        .filter((x) => x)\n        .map((child: any, key: any) => {\n          if (!child) {\n            return null\n          }\n          return (\n            <option key={key} value={child.props.value}>\n              {child.props.children}\n            </option>\n          )\n        })}\n    </select>\n  )\n\n  return native ? Native : NonNative\n}\n\nexport default Select\n"]} */"],
25316
25321
  children: open ? jsxRuntime.jsx(List, {
25317
25322
  selectList: true,
25318
25323
  children: props.children.filter(x => x).map((child, key) => {
@@ -34,10 +34,15 @@ const Select = ({
34
34
  const [open, toggleOpen] = useState(false);
35
35
  const onClick = function () {
36
36
  toggleOpen(!open && !disabled);
37
+ props.onOpenChange?.(!open);
38
+ };
39
+ const handleOpen = open => {
40
+ toggleOpen(open);
41
+ props.onOpenChange?.(open);
37
42
  };
38
43
  useEffect(() => {
39
44
  if (closeKey) {
40
- toggleOpen(false);
45
+ handleOpen(false);
41
46
  }
42
47
  // eslint-disable-next-line react-hooks/exhaustive-deps
43
48
  }, [closeKey]);
@@ -47,7 +52,7 @@ const Select = ({
47
52
  if (node && node.contains(e.target)) {
48
53
  return;
49
54
  }
50
- toggleOpen(false);
55
+ handleOpen(false);
51
56
  };
52
57
  if (open) {
53
58
  const firstOption = ref.current?.querySelector('button, a, [tabindex]');
@@ -65,7 +70,7 @@ const Select = ({
65
70
  const onChange = value => {
66
71
  if (props.onChange && !disabled) {
67
72
  props.onChange(value);
68
- toggleOpen(false);
73
+ handleOpen(false);
69
74
  }
70
75
  };
71
76
  const Label = _jsx(StyledLabel, {
@@ -101,7 +106,7 @@ const Select = ({
101
106
  tabIndex: disabled ? -1 : undefined,
102
107
  children: props.selectedValue ? props.selectedValue : props.text || ''
103
108
  }), _jsx(OptionsWrapper, {
104
- css: [input && styles.inputstyle(!!label), optionsWidth && styles.optionsWidth(optionsWidth), process.env.NODE_ENV === "production" ? "" : ";label:NonNative;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/packages/core/Select/index.tsx"],"names":[],"mappings":"AAiLQ","file":"../../../src/packages/core/Select/index.tsx","sourcesContent":["/** @jsxImportSource @emotion/react */\nimport React, {\n  ReactNode,\n  ReactElement,\n  useState,\n  createRef,\n  useEffect,\n} from 'react'\nimport { SerializedStyles } from '@emotion/react'\nimport Option from './Option'\nimport { SelectWrapper, OptionsWrapper, styles, StyledLabel } from './styles'\nimport InfoButton from '../InfoButton'\nimport IconHelp from '../../icons/General/IconHelp'\nimport Button from '../Button'\nimport IconChevronDown from '../../icons/General/IconChevronDown'\nimport List from '../List'\n\nexport { Option }\n\ninterface IProps {\n  /** Text when no option are selected */\n  text?: string\n  /** Current selected value. Leave empty for default text. */\n  selectedValue?: string\n  /** Style as an input */\n  input?: boolean\n  /** Adds a label if input is selected  */\n  label?: string\n  /** Callback handler for when clicking option element. */\n  onChange?: (value: string) => any\n  /** Option-elements, select list content */\n  children: ReactNode[]\n  /** Adds icon to select  */\n  icon?: React.ReactNode\n  /** Type of select, default is transparent, primary10 adds primary background with 10 opacity */\n  type?: 'default' | 'primary10' | 'opacity08'\n  /** Use native selector */\n  native?: boolean\n  /** Select button width */\n  width?: string\n  /** Options content width */\n  optionsWidth?: string\n  /** Options max height. If set will set overflow-y to scroll. */\n  maxHeight?: string\n  /** Autofocus */\n  focus?: boolean\n  /** Add custom css to select when in open state */\n  customOpenstyle?: SerializedStyles\n  /** Override with custom CSS */\n  customStyle?: SerializedStyles\n  /** Add a data-tracking-event attribute. */\n  trackingEvent?: string\n  /** Add a data-tracking-name attribute. */\n  trackingName?: string\n  /** Select is disabled. */\n  disabled?: boolean\n  /** Manual close by changing closeKey externally */\n  closeKey?: string\n  /** Add classname */\n  className?: string\n  /** Adds info-text button */\n  info?: string\n  /** Where the info tooltip will be placed relative to the button @default left */\n  infoPlacement?: 'top' | 'left' | 'right' | 'bottom'\n}\n\nconst Select: React.FC<IProps> = ({\n  input,\n  icon,\n  type = 'default',\n  native,\n  optionsWidth,\n  width,\n  maxHeight,\n  focus,\n  customOpenstyle,\n  customStyle,\n  trackingEvent,\n  trackingName,\n  disabled,\n  label,\n  closeKey,\n  className,\n  info,\n  infoPlacement = 'left',\n  ...props\n}: IProps) => {\n  const ref = createRef<HTMLSpanElement>()\n  const [open, toggleOpen] = useState(false)\n\n  const onClick = function () {\n    toggleOpen(!open && !disabled)\n  }\n\n  useEffect(() => {\n    if (closeKey) {\n      toggleOpen(false)\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [closeKey])\n\n  useEffect(() => {\n    const handleClickOutside = (e: any) => {\n      const node = ref.current\n      if (node && node.contains(e.target)) {\n        return\n      }\n      toggleOpen(false)\n    }\n\n    if (open) {\n      const firstOption = ref.current?.querySelector(\n        'button, a, [tabindex]'\n      ) as HTMLElement\n      if (firstOption) {\n        firstOption.focus()\n      }\n      document.addEventListener('mousedown', handleClickOutside)\n    } else {\n      document.removeEventListener('mousedown', handleClickOutside)\n    }\n\n    return () => {\n      document.removeEventListener('mousedown', handleClickOutside)\n    }\n  }, [open, ref])\n\n  const onChange = (value: string) => {\n    if (props.onChange && !disabled) {\n      props.onChange(value)\n      toggleOpen(false)\n    }\n  }\n\n  const Label = <StyledLabel withInfo={Boolean(info)}>{label}</StyledLabel>\n\n  const NonNative = (\n    <SelectWrapper\n      ref={ref}\n      className={className}\n      css={(theme) => [\n        styles.default,\n        input && styles.input(theme),\n        input && open && styles.open(theme),\n        type === 'primary10' && styles.primary10(theme),\n        icon && styles.withIcon,\n        type === 'opacity08' && styles.opacity08(theme),\n        width && styles.width(width),\n        maxHeight && styles.maxHeight(maxHeight),\n        customStyle && customStyle,\n        open && customOpenstyle && customOpenstyle,\n        disabled && styles.disabled(theme),\n      ]}\n      aria-expanded={open}\n      aria-label={label ? label : 'Select'}\n    >\n      {input && label && Label}\n      {info && (\n        <span css={styles.infoButton}>\n          <InfoButton icon={<IconHelp primary />} place={infoPlacement}>\n            {info}\n          </InfoButton>\n        </span>\n      )}\n      <Button\n        nostyle\n        afterIcon={<IconChevronDown flipVertical={open} size={14} />}\n        onClick={onClick}\n        beforeIcon={icon}\n        autoFocus={focus}\n        trackingName={trackingName}\n        trackingEvent={trackingEvent}\n        tabIndex={disabled ? -1 : undefined}\n      >\n        {props.selectedValue ? props.selectedValue : props.text || ''}\n      </Button>\n      <OptionsWrapper\n        css={[\n          input && styles.inputstyle(!!label),\n          optionsWidth && styles.optionsWidth(optionsWidth),\n        ]}\n      >\n        {open ? (\n          <List selectList>\n            {props.children\n              .filter((x) => x)\n              .map((child, key) => {\n                if (!child) {\n                  return null\n                }\n                return React.cloneElement(child as ReactElement, {\n                  onChange: onChange,\n                  key,\n                })\n              })}\n          </List>\n        ) : null}\n      </OptionsWrapper>\n    </SelectWrapper>\n  )\n\n  const Native = (\n    <select\n      className={className}\n      css={(theme) => [\n        styles.default,\n        input && styles.input(theme),\n        input && open && styles.open(theme),\n        type === 'primary10' && styles.primary10(theme),\n        icon && styles.withIcon,\n      ]}\n      value={props.selectedValue ? props.selectedValue : props.text || ''}\n      onChange={(e) => onChange(e.target.value)}\n    >\n      {props.children\n        .filter((x) => x)\n        .map((child: any, key: any) => {\n          if (!child) {\n            return null\n          }\n          return (\n            <option key={key} value={child.props.value}>\n              {child.props.children}\n            </option>\n          )\n        })}\n    </select>\n  )\n\n  return native ? Native : NonNative\n}\n\nexport default Select\n"]} */"],
109
+ css: [input && styles.inputstyle(!!label), optionsWidth && styles.optionsWidth(optionsWidth), process.env.NODE_ENV === "production" ? "" : ";label:NonNative;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/packages/core/Select/index.tsx"],"names":[],"mappings":"AAyLQ","file":"../../../src/packages/core/Select/index.tsx","sourcesContent":["/** @jsxImportSource @emotion/react */\nimport React, {\n  ReactNode,\n  ReactElement,\n  useState,\n  createRef,\n  useEffect,\n} from 'react'\nimport { SerializedStyles } from '@emotion/react'\nimport Option from './Option'\nimport { SelectWrapper, OptionsWrapper, styles, StyledLabel } from './styles'\nimport InfoButton from '../InfoButton'\nimport IconHelp from '../../icons/General/IconHelp'\nimport Button from '../Button'\nimport IconChevronDown from '../../icons/General/IconChevronDown'\nimport List from '../List'\n\nexport { Option }\n\ninterface IProps {\n  /** Text when no option are selected */\n  text?: string\n  /** Current selected value. Leave empty for default text. */\n  selectedValue?: string\n  /** Style as an input */\n  input?: boolean\n  /** Adds a label if input is selected  */\n  label?: string\n  /** Callback handler for when clicking option element. */\n  onChange?: (value: string) => any\n  /** Callback handle for when opening the select */\n  onOpenChange?: (open: boolean) => any\n  /** Option-elements, select list content */\n  children: ReactNode[]\n  /** Adds icon to select  */\n  icon?: React.ReactNode\n  /** Type of select, default is transparent, primary10 adds primary background with 10 opacity */\n  type?: 'default' | 'primary10' | 'opacity08'\n  /** Use native selector */\n  native?: boolean\n  /** Select button width */\n  width?: string\n  /** Options content width */\n  optionsWidth?: string\n  /** Options max height. If set will set overflow-y to scroll. */\n  maxHeight?: string\n  /** Autofocus */\n  focus?: boolean\n  /** Add custom css to select when in open state */\n  customOpenstyle?: SerializedStyles\n  /** Override with custom CSS */\n  customStyle?: SerializedStyles\n  /** Add a data-tracking-event attribute. */\n  trackingEvent?: string\n  /** Add a data-tracking-name attribute. */\n  trackingName?: string\n  /** Select is disabled. */\n  disabled?: boolean\n  /** Manual close by changing closeKey externally */\n  closeKey?: string\n  /** Add classname */\n  className?: string\n  /** Adds info-text button */\n  info?: string\n  /** Where the info tooltip will be placed relative to the button @default left */\n  infoPlacement?: 'top' | 'left' | 'right' | 'bottom'\n}\n\nconst Select: React.FC<IProps> = ({\n  input,\n  icon,\n  type = 'default',\n  native,\n  optionsWidth,\n  width,\n  maxHeight,\n  focus,\n  customOpenstyle,\n  customStyle,\n  trackingEvent,\n  trackingName,\n  disabled,\n  label,\n  closeKey,\n  className,\n  info,\n  infoPlacement = 'left',\n  ...props\n}: IProps) => {\n  const ref = createRef<HTMLSpanElement>()\n  const [open, toggleOpen] = useState(false)\n\n  const onClick = function () {\n    toggleOpen(!open && !disabled)\n    props.onOpenChange?.(!open)\n  }\n\n  const handleOpen = (open: boolean) => {\n    toggleOpen(open)\n    props.onOpenChange?.(open)\n  }\n\n  useEffect(() => {\n    if (closeKey) {\n      handleOpen(false)\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [closeKey])\n\n  useEffect(() => {\n    const handleClickOutside = (e: any) => {\n      const node = ref.current\n      if (node && node.contains(e.target)) {\n        return\n      }\n      handleOpen(false)\n    }\n\n    if (open) {\n      const firstOption = ref.current?.querySelector(\n        'button, a, [tabindex]'\n      ) as HTMLElement\n      if (firstOption) {\n        firstOption.focus()\n      }\n      document.addEventListener('mousedown', handleClickOutside)\n    } else {\n      document.removeEventListener('mousedown', handleClickOutside)\n    }\n\n    return () => {\n      document.removeEventListener('mousedown', handleClickOutside)\n    }\n  }, [open, ref])\n\n  const onChange = (value: string) => {\n    if (props.onChange && !disabled) {\n      props.onChange(value)\n      handleOpen(false)\n    }\n  }\n\n  const Label = <StyledLabel withInfo={Boolean(info)}>{label}</StyledLabel>\n\n  const NonNative = (\n    <SelectWrapper\n      ref={ref}\n      className={className}\n      css={(theme) => [\n        styles.default,\n        input && styles.input(theme),\n        input && open && styles.open(theme),\n        type === 'primary10' && styles.primary10(theme),\n        icon && styles.withIcon,\n        type === 'opacity08' && styles.opacity08(theme),\n        width && styles.width(width),\n        maxHeight && styles.maxHeight(maxHeight),\n        customStyle && customStyle,\n        open && customOpenstyle && customOpenstyle,\n        disabled && styles.disabled(theme),\n      ]}\n      aria-expanded={open}\n      aria-label={label ? label : 'Select'}\n    >\n      {input && label && Label}\n      {info && (\n        <span css={styles.infoButton}>\n          <InfoButton icon={<IconHelp primary />} place={infoPlacement}>\n            {info}\n          </InfoButton>\n        </span>\n      )}\n      <Button\n        nostyle\n        afterIcon={<IconChevronDown flipVertical={open} size={14} />}\n        onClick={onClick}\n        beforeIcon={icon}\n        autoFocus={focus}\n        trackingName={trackingName}\n        trackingEvent={trackingEvent}\n        tabIndex={disabled ? -1 : undefined}\n      >\n        {props.selectedValue ? props.selectedValue : props.text || ''}\n      </Button>\n      <OptionsWrapper\n        css={[\n          input && styles.inputstyle(!!label),\n          optionsWidth && styles.optionsWidth(optionsWidth),\n        ]}\n      >\n        {open ? (\n          <List selectList>\n            {props.children\n              .filter((x) => x)\n              .map((child, key) => {\n                if (!child) {\n                  return null\n                }\n                return React.cloneElement(child as ReactElement, {\n                  onChange: onChange,\n                  key,\n                })\n              })}\n          </List>\n        ) : null}\n      </OptionsWrapper>\n    </SelectWrapper>\n  )\n\n  const Native = (\n    <select\n      className={className}\n      css={(theme) => [\n        styles.default,\n        input && styles.input(theme),\n        input && open && styles.open(theme),\n        type === 'primary10' && styles.primary10(theme),\n        icon && styles.withIcon,\n      ]}\n      value={props.selectedValue ? props.selectedValue : props.text || ''}\n      onChange={(e) => onChange(e.target.value)}\n    >\n      {props.children\n        .filter((x) => x)\n        .map((child: any, key: any) => {\n          if (!child) {\n            return null\n          }\n          return (\n            <option key={key} value={child.props.value}>\n              {child.props.children}\n            </option>\n          )\n        })}\n    </select>\n  )\n\n  return native ? Native : NonNative\n}\n\nexport default Select\n"]} */"],
105
110
  children: open ? _jsx(List, {
106
111
  selectList: true,
107
112
  children: props.children.filter(x => x).map((child, key) => {
@@ -14,6 +14,8 @@ interface IProps {
14
14
  label?: string;
15
15
  /** Callback handler for when clicking option element. */
16
16
  onChange?: (value: string) => any;
17
+ /** Callback handle for when opening the select */
18
+ onOpenChange?: (open: boolean) => any;
17
19
  /** Option-elements, select list content */
18
20
  children: ReactNode[];
19
21
  /** Adds icon to select */
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/packages/core/Select/index.tsx"],"names":[],"mappings":"AAAA,sCAAsC;AACtC,OAAO,KAAK,EAAE,EACZ,SAAS,EAKV,MAAM,OAAO,CAAA;AACd,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAA;AACjD,OAAO,MAAM,MAAM,UAAU,CAAA;AAQ7B,OAAO,EAAE,MAAM,EAAE,CAAA;AAEjB,UAAU,MAAM;IACd,uCAAuC;IACvC,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,4DAA4D;IAC5D,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,wBAAwB;IACxB,KAAK,CAAC,EAAE,OAAO,CAAA;IACf,yCAAyC;IACzC,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,yDAAyD;IACzD,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,GAAG,CAAA;IACjC,2CAA2C;IAC3C,QAAQ,EAAE,SAAS,EAAE,CAAA;IACrB,2BAA2B;IAC3B,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACtB,gGAAgG;IAChG,IAAI,CAAC,EAAE,SAAS,GAAG,WAAW,GAAG,WAAW,CAAA;IAC5C,0BAA0B;IAC1B,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,0BAA0B;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,4BAA4B;IAC5B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,gEAAgE;IAChE,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,gBAAgB;IAChB,KAAK,CAAC,EAAE,OAAO,CAAA;IACf,kDAAkD;IAClD,eAAe,CAAC,EAAE,gBAAgB,CAAA;IAClC,+BAA+B;IAC/B,WAAW,CAAC,EAAE,gBAAgB,CAAA;IAC9B,2CAA2C;IAC3C,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,0CAA0C;IAC1C,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,0BAA0B;IAC1B,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,mDAAmD;IACnD,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,oBAAoB;IACpB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,4BAA4B;IAC5B,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,iFAAiF;IACjF,aAAa,CAAC,EAAE,KAAK,GAAG,MAAM,GAAG,OAAO,GAAG,QAAQ,CAAA;CACpD;AAED,QAAA,MAAM,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,MAAM,CAoK5B,CAAA;AAED,eAAe,MAAM,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/packages/core/Select/index.tsx"],"names":[],"mappings":"AAAA,sCAAsC;AACtC,OAAO,KAAK,EAAE,EACZ,SAAS,EAKV,MAAM,OAAO,CAAA;AACd,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAA;AACjD,OAAO,MAAM,MAAM,UAAU,CAAA;AAQ7B,OAAO,EAAE,MAAM,EAAE,CAAA;AAEjB,UAAU,MAAM;IACd,uCAAuC;IACvC,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,4DAA4D;IAC5D,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,wBAAwB;IACxB,KAAK,CAAC,EAAE,OAAO,CAAA;IACf,yCAAyC;IACzC,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,yDAAyD;IACzD,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,GAAG,CAAA;IACjC,kDAAkD;IAClD,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,GAAG,CAAA;IACrC,2CAA2C;IAC3C,QAAQ,EAAE,SAAS,EAAE,CAAA;IACrB,2BAA2B;IAC3B,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACtB,gGAAgG;IAChG,IAAI,CAAC,EAAE,SAAS,GAAG,WAAW,GAAG,WAAW,CAAA;IAC5C,0BAA0B;IAC1B,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,0BAA0B;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,4BAA4B;IAC5B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,gEAAgE;IAChE,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,gBAAgB;IAChB,KAAK,CAAC,EAAE,OAAO,CAAA;IACf,kDAAkD;IAClD,eAAe,CAAC,EAAE,gBAAgB,CAAA;IAClC,+BAA+B;IAC/B,WAAW,CAAC,EAAE,gBAAgB,CAAA;IAC9B,2CAA2C;IAC3C,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,0CAA0C;IAC1C,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,0BAA0B;IAC1B,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,mDAAmD;IACnD,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,oBAAoB;IACpB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,4BAA4B;IAC5B,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,iFAAiF;IACjF,aAAa,CAAC,EAAE,KAAK,GAAG,MAAM,GAAG,OAAO,GAAG,QAAQ,CAAA;CACpD;AAED,QAAA,MAAM,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,MAAM,CA0K5B,CAAA;AAED,eAAe,MAAM,CAAA"}
@@ -34,10 +34,15 @@ const Select = ({
34
34
  const [open, toggleOpen] = useState(false);
35
35
  const onClick = function () {
36
36
  toggleOpen(!open && !disabled);
37
+ props.onOpenChange?.(!open);
38
+ };
39
+ const handleOpen = open => {
40
+ toggleOpen(open);
41
+ props.onOpenChange?.(open);
37
42
  };
38
43
  useEffect(() => {
39
44
  if (closeKey) {
40
- toggleOpen(false);
45
+ handleOpen(false);
41
46
  }
42
47
  // eslint-disable-next-line react-hooks/exhaustive-deps
43
48
  }, [closeKey]);
@@ -47,7 +52,7 @@ const Select = ({
47
52
  if (node && node.contains(e.target)) {
48
53
  return;
49
54
  }
50
- toggleOpen(false);
55
+ handleOpen(false);
51
56
  };
52
57
  if (open) {
53
58
  const firstOption = ref.current?.querySelector('button, a, [tabindex]');
@@ -65,7 +70,7 @@ const Select = ({
65
70
  const onChange = value => {
66
71
  if (props.onChange && !disabled) {
67
72
  props.onChange(value);
68
- toggleOpen(false);
73
+ handleOpen(false);
69
74
  }
70
75
  };
71
76
  const Label = _jsx(StyledLabel, {
@@ -101,7 +106,7 @@ const Select = ({
101
106
  tabIndex: disabled ? -1 : undefined,
102
107
  children: props.selectedValue ? props.selectedValue : props.text || ''
103
108
  }), _jsx(OptionsWrapper, {
104
- css: [input && styles.inputstyle(!!label), optionsWidth && styles.optionsWidth(optionsWidth), process.env.NODE_ENV === "production" ? "" : ";label:NonNative;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/packages/core/Select/index.tsx"],"names":[],"mappings":"AAiLQ","file":"../../../src/packages/core/Select/index.tsx","sourcesContent":["/** @jsxImportSource @emotion/react */\nimport React, {\n  ReactNode,\n  ReactElement,\n  useState,\n  createRef,\n  useEffect,\n} from 'react'\nimport { SerializedStyles } from '@emotion/react'\nimport Option from './Option'\nimport { SelectWrapper, OptionsWrapper, styles, StyledLabel } from './styles'\nimport InfoButton from '../InfoButton'\nimport IconHelp from '../../icons/General/IconHelp'\nimport Button from '../Button'\nimport IconChevronDown from '../../icons/General/IconChevronDown'\nimport List from '../List'\n\nexport { Option }\n\ninterface IProps {\n  /** Text when no option are selected */\n  text?: string\n  /** Current selected value. Leave empty for default text. */\n  selectedValue?: string\n  /** Style as an input */\n  input?: boolean\n  /** Adds a label if input is selected  */\n  label?: string\n  /** Callback handler for when clicking option element. */\n  onChange?: (value: string) => any\n  /** Option-elements, select list content */\n  children: ReactNode[]\n  /** Adds icon to select  */\n  icon?: React.ReactNode\n  /** Type of select, default is transparent, primary10 adds primary background with 10 opacity */\n  type?: 'default' | 'primary10' | 'opacity08'\n  /** Use native selector */\n  native?: boolean\n  /** Select button width */\n  width?: string\n  /** Options content width */\n  optionsWidth?: string\n  /** Options max height. If set will set overflow-y to scroll. */\n  maxHeight?: string\n  /** Autofocus */\n  focus?: boolean\n  /** Add custom css to select when in open state */\n  customOpenstyle?: SerializedStyles\n  /** Override with custom CSS */\n  customStyle?: SerializedStyles\n  /** Add a data-tracking-event attribute. */\n  trackingEvent?: string\n  /** Add a data-tracking-name attribute. */\n  trackingName?: string\n  /** Select is disabled. */\n  disabled?: boolean\n  /** Manual close by changing closeKey externally */\n  closeKey?: string\n  /** Add classname */\n  className?: string\n  /** Adds info-text button */\n  info?: string\n  /** Where the info tooltip will be placed relative to the button @default left */\n  infoPlacement?: 'top' | 'left' | 'right' | 'bottom'\n}\n\nconst Select: React.FC<IProps> = ({\n  input,\n  icon,\n  type = 'default',\n  native,\n  optionsWidth,\n  width,\n  maxHeight,\n  focus,\n  customOpenstyle,\n  customStyle,\n  trackingEvent,\n  trackingName,\n  disabled,\n  label,\n  closeKey,\n  className,\n  info,\n  infoPlacement = 'left',\n  ...props\n}: IProps) => {\n  const ref = createRef<HTMLSpanElement>()\n  const [open, toggleOpen] = useState(false)\n\n  const onClick = function () {\n    toggleOpen(!open && !disabled)\n  }\n\n  useEffect(() => {\n    if (closeKey) {\n      toggleOpen(false)\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [closeKey])\n\n  useEffect(() => {\n    const handleClickOutside = (e: any) => {\n      const node = ref.current\n      if (node && node.contains(e.target)) {\n        return\n      }\n      toggleOpen(false)\n    }\n\n    if (open) {\n      const firstOption = ref.current?.querySelector(\n        'button, a, [tabindex]'\n      ) as HTMLElement\n      if (firstOption) {\n        firstOption.focus()\n      }\n      document.addEventListener('mousedown', handleClickOutside)\n    } else {\n      document.removeEventListener('mousedown', handleClickOutside)\n    }\n\n    return () => {\n      document.removeEventListener('mousedown', handleClickOutside)\n    }\n  }, [open, ref])\n\n  const onChange = (value: string) => {\n    if (props.onChange && !disabled) {\n      props.onChange(value)\n      toggleOpen(false)\n    }\n  }\n\n  const Label = <StyledLabel withInfo={Boolean(info)}>{label}</StyledLabel>\n\n  const NonNative = (\n    <SelectWrapper\n      ref={ref}\n      className={className}\n      css={(theme) => [\n        styles.default,\n        input && styles.input(theme),\n        input && open && styles.open(theme),\n        type === 'primary10' && styles.primary10(theme),\n        icon && styles.withIcon,\n        type === 'opacity08' && styles.opacity08(theme),\n        width && styles.width(width),\n        maxHeight && styles.maxHeight(maxHeight),\n        customStyle && customStyle,\n        open && customOpenstyle && customOpenstyle,\n        disabled && styles.disabled(theme),\n      ]}\n      aria-expanded={open}\n      aria-label={label ? label : 'Select'}\n    >\n      {input && label && Label}\n      {info && (\n        <span css={styles.infoButton}>\n          <InfoButton icon={<IconHelp primary />} place={infoPlacement}>\n            {info}\n          </InfoButton>\n        </span>\n      )}\n      <Button\n        nostyle\n        afterIcon={<IconChevronDown flipVertical={open} size={14} />}\n        onClick={onClick}\n        beforeIcon={icon}\n        autoFocus={focus}\n        trackingName={trackingName}\n        trackingEvent={trackingEvent}\n        tabIndex={disabled ? -1 : undefined}\n      >\n        {props.selectedValue ? props.selectedValue : props.text || ''}\n      </Button>\n      <OptionsWrapper\n        css={[\n          input && styles.inputstyle(!!label),\n          optionsWidth && styles.optionsWidth(optionsWidth),\n        ]}\n      >\n        {open ? (\n          <List selectList>\n            {props.children\n              .filter((x) => x)\n              .map((child, key) => {\n                if (!child) {\n                  return null\n                }\n                return React.cloneElement(child as ReactElement, {\n                  onChange: onChange,\n                  key,\n                })\n              })}\n          </List>\n        ) : null}\n      </OptionsWrapper>\n    </SelectWrapper>\n  )\n\n  const Native = (\n    <select\n      className={className}\n      css={(theme) => [\n        styles.default,\n        input && styles.input(theme),\n        input && open && styles.open(theme),\n        type === 'primary10' && styles.primary10(theme),\n        icon && styles.withIcon,\n      ]}\n      value={props.selectedValue ? props.selectedValue : props.text || ''}\n      onChange={(e) => onChange(e.target.value)}\n    >\n      {props.children\n        .filter((x) => x)\n        .map((child: any, key: any) => {\n          if (!child) {\n            return null\n          }\n          return (\n            <option key={key} value={child.props.value}>\n              {child.props.children}\n            </option>\n          )\n        })}\n    </select>\n  )\n\n  return native ? Native : NonNative\n}\n\nexport default Select\n"]} */"],
109
+ css: [input && styles.inputstyle(!!label), optionsWidth && styles.optionsWidth(optionsWidth), process.env.NODE_ENV === "production" ? "" : ";label:NonNative;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/packages/core/Select/index.tsx"],"names":[],"mappings":"AAyLQ","file":"../../../src/packages/core/Select/index.tsx","sourcesContent":["/** @jsxImportSource @emotion/react */\nimport React, {\n  ReactNode,\n  ReactElement,\n  useState,\n  createRef,\n  useEffect,\n} from 'react'\nimport { SerializedStyles } from '@emotion/react'\nimport Option from './Option'\nimport { SelectWrapper, OptionsWrapper, styles, StyledLabel } from './styles'\nimport InfoButton from '../InfoButton'\nimport IconHelp from '../../icons/General/IconHelp'\nimport Button from '../Button'\nimport IconChevronDown from '../../icons/General/IconChevronDown'\nimport List from '../List'\n\nexport { Option }\n\ninterface IProps {\n  /** Text when no option are selected */\n  text?: string\n  /** Current selected value. Leave empty for default text. */\n  selectedValue?: string\n  /** Style as an input */\n  input?: boolean\n  /** Adds a label if input is selected  */\n  label?: string\n  /** Callback handler for when clicking option element. */\n  onChange?: (value: string) => any\n  /** Callback handle for when opening the select */\n  onOpenChange?: (open: boolean) => any\n  /** Option-elements, select list content */\n  children: ReactNode[]\n  /** Adds icon to select  */\n  icon?: React.ReactNode\n  /** Type of select, default is transparent, primary10 adds primary background with 10 opacity */\n  type?: 'default' | 'primary10' | 'opacity08'\n  /** Use native selector */\n  native?: boolean\n  /** Select button width */\n  width?: string\n  /** Options content width */\n  optionsWidth?: string\n  /** Options max height. If set will set overflow-y to scroll. */\n  maxHeight?: string\n  /** Autofocus */\n  focus?: boolean\n  /** Add custom css to select when in open state */\n  customOpenstyle?: SerializedStyles\n  /** Override with custom CSS */\n  customStyle?: SerializedStyles\n  /** Add a data-tracking-event attribute. */\n  trackingEvent?: string\n  /** Add a data-tracking-name attribute. */\n  trackingName?: string\n  /** Select is disabled. */\n  disabled?: boolean\n  /** Manual close by changing closeKey externally */\n  closeKey?: string\n  /** Add classname */\n  className?: string\n  /** Adds info-text button */\n  info?: string\n  /** Where the info tooltip will be placed relative to the button @default left */\n  infoPlacement?: 'top' | 'left' | 'right' | 'bottom'\n}\n\nconst Select: React.FC<IProps> = ({\n  input,\n  icon,\n  type = 'default',\n  native,\n  optionsWidth,\n  width,\n  maxHeight,\n  focus,\n  customOpenstyle,\n  customStyle,\n  trackingEvent,\n  trackingName,\n  disabled,\n  label,\n  closeKey,\n  className,\n  info,\n  infoPlacement = 'left',\n  ...props\n}: IProps) => {\n  const ref = createRef<HTMLSpanElement>()\n  const [open, toggleOpen] = useState(false)\n\n  const onClick = function () {\n    toggleOpen(!open && !disabled)\n    props.onOpenChange?.(!open)\n  }\n\n  const handleOpen = (open: boolean) => {\n    toggleOpen(open)\n    props.onOpenChange?.(open)\n  }\n\n  useEffect(() => {\n    if (closeKey) {\n      handleOpen(false)\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [closeKey])\n\n  useEffect(() => {\n    const handleClickOutside = (e: any) => {\n      const node = ref.current\n      if (node && node.contains(e.target)) {\n        return\n      }\n      handleOpen(false)\n    }\n\n    if (open) {\n      const firstOption = ref.current?.querySelector(\n        'button, a, [tabindex]'\n      ) as HTMLElement\n      if (firstOption) {\n        firstOption.focus()\n      }\n      document.addEventListener('mousedown', handleClickOutside)\n    } else {\n      document.removeEventListener('mousedown', handleClickOutside)\n    }\n\n    return () => {\n      document.removeEventListener('mousedown', handleClickOutside)\n    }\n  }, [open, ref])\n\n  const onChange = (value: string) => {\n    if (props.onChange && !disabled) {\n      props.onChange(value)\n      handleOpen(false)\n    }\n  }\n\n  const Label = <StyledLabel withInfo={Boolean(info)}>{label}</StyledLabel>\n\n  const NonNative = (\n    <SelectWrapper\n      ref={ref}\n      className={className}\n      css={(theme) => [\n        styles.default,\n        input && styles.input(theme),\n        input && open && styles.open(theme),\n        type === 'primary10' && styles.primary10(theme),\n        icon && styles.withIcon,\n        type === 'opacity08' && styles.opacity08(theme),\n        width && styles.width(width),\n        maxHeight && styles.maxHeight(maxHeight),\n        customStyle && customStyle,\n        open && customOpenstyle && customOpenstyle,\n        disabled && styles.disabled(theme),\n      ]}\n      aria-expanded={open}\n      aria-label={label ? label : 'Select'}\n    >\n      {input && label && Label}\n      {info && (\n        <span css={styles.infoButton}>\n          <InfoButton icon={<IconHelp primary />} place={infoPlacement}>\n            {info}\n          </InfoButton>\n        </span>\n      )}\n      <Button\n        nostyle\n        afterIcon={<IconChevronDown flipVertical={open} size={14} />}\n        onClick={onClick}\n        beforeIcon={icon}\n        autoFocus={focus}\n        trackingName={trackingName}\n        trackingEvent={trackingEvent}\n        tabIndex={disabled ? -1 : undefined}\n      >\n        {props.selectedValue ? props.selectedValue : props.text || ''}\n      </Button>\n      <OptionsWrapper\n        css={[\n          input && styles.inputstyle(!!label),\n          optionsWidth && styles.optionsWidth(optionsWidth),\n        ]}\n      >\n        {open ? (\n          <List selectList>\n            {props.children\n              .filter((x) => x)\n              .map((child, key) => {\n                if (!child) {\n                  return null\n                }\n                return React.cloneElement(child as ReactElement, {\n                  onChange: onChange,\n                  key,\n                })\n              })}\n          </List>\n        ) : null}\n      </OptionsWrapper>\n    </SelectWrapper>\n  )\n\n  const Native = (\n    <select\n      className={className}\n      css={(theme) => [\n        styles.default,\n        input && styles.input(theme),\n        input && open && styles.open(theme),\n        type === 'primary10' && styles.primary10(theme),\n        icon && styles.withIcon,\n      ]}\n      value={props.selectedValue ? props.selectedValue : props.text || ''}\n      onChange={(e) => onChange(e.target.value)}\n    >\n      {props.children\n        .filter((x) => x)\n        .map((child: any, key: any) => {\n          if (!child) {\n            return null\n          }\n          return (\n            <option key={key} value={child.props.value}>\n              {child.props.children}\n            </option>\n          )\n        })}\n    </select>\n  )\n\n  return native ? Native : NonNative\n}\n\nexport default Select\n"]} */"],
105
110
  children: open ? _jsx(List, {
106
111
  selectList: true,
107
112
  children: props.children.filter(x => x).map((child, key) => {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bbl-digital/snorre",
3
- "version": "4.1.82",
3
+ "version": "4.1.83",
4
4
  "description": "Design library for BBL Digital",
5
5
  "license": "MIT",
6
6
  "main": "./lib/index.js",