@entur/dropdown 5.0.0-beta.1 → 5.0.0-beta.3

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.
@@ -29,28 +29,24 @@ export type DropdownBetaProps = {
29
29
  /** Callback når brukeren endrer valg */
30
30
  onChange?: (selectedItem: NormalizedDropdownItemType | null) => void;
31
31
  /** Lar brukeren velge ved å "tab-e" seg ut av komponenten */
32
- selectOnTab?: boolean;
33
- /** Om man skal vise items ved fokusering av input-feltet, før man skriver inn noe */
34
- openOnFocus?: boolean;
35
- /** Antall millisekunder man venter før man kaller en potensiell items-funksjon */
36
- debounceTimeout?: number;
32
+ selectOnBlur?: boolean;
37
33
  /** Om man skal ha mulighet for å nullstille Dropdown-en
38
34
  * @default false
39
35
  */
40
36
  clearable?: boolean;
41
37
  /** Ekstra klassenavn */
42
38
  className?: string;
43
- /** Marker første valgmulighet automatisk */
44
- highlightFirstItemOnOpen?: boolean;
45
39
  /** Styling som sendes ned til Dropdown-lista */
46
40
  listStyle?: {
47
41
  [key: string]: any;
48
42
  };
43
+ /** Styling for Dropdown-en */
44
+ style?: {
45
+ [key: string]: any;
46
+ };
49
47
  /** Plasserer labelen statisk på toppen av inputfeltet
50
48
  * @default false
51
49
  */
52
50
  disableLabelAnimation?: boolean;
53
- /** Alle ekstra props videresendes til Downshift */
54
- [key: string]: any;
55
51
  };
56
- export declare const DropdownBeta: ({ className, clearable, debounceTimeout, feedback, items: initialItems, label, listStyle, onChange, openOnFocus, placeholder, readonly, selectedItem, selectOnBlur, selectOnTab, variant, ...rest }: DropdownBetaProps) => JSX.Element;
52
+ export declare const DropdownBeta: ({ className, clearable, disabled, disableLabelAnimation, feedback, items: initialItems, label, labelTooltip, listStyle, loadingText, onChange, placeholder, prepend, readOnly, selectedItem, selectOnBlur, style, variant, ...rest }: DropdownBetaProps) => JSX.Element;
@@ -41,6 +41,14 @@ export type MultiSelectBetaProps = {
41
41
  * @default "Velg alle"
42
42
  */
43
43
  selectAllLabel?: string;
44
+ /** Teksten som vises for «Velg alle»-elementet i listen
45
+ * @default "Alle valgt"
46
+ */
47
+ allItemsSelectedLabel?: string;
48
+ /** Skjermleser-tekst som for å fjerne alle valg
49
+ * @default "Fjern valgte"
50
+ */
51
+ clearAllItemsAriaLabel?: string;
44
52
  /** Ekstra klassenavn */
45
53
  className?: string;
46
54
  /** Tekst for skjemleser på knapper for å fjerne valgt element
@@ -55,13 +63,14 @@ export type MultiSelectBetaProps = {
55
63
  * @default 250
56
64
  */
57
65
  debounceTimeout?: number;
66
+ maxTags?: number;
58
67
  /** Om en knapp for å fjerne alle valg skal vises
59
68
  * @default false
60
69
  */
61
70
  clearable?: boolean;
71
+ clearInputOnSelect?: boolean;
62
72
  selectOnBlur?: boolean;
63
- readonly?: boolean;
64
73
  loading?: boolean;
65
74
  style?: React.CSSProperties;
66
75
  };
67
- export declare const MultiSelectBeta: ({ ariaLabelRemoveSelected, className, clearable, debounceTimeout, feedback, hideSelectAll, items: initialItems, label, listStyle, onChange, openOnFocus, placeholder, readonly, selectAllLabel, selectedItems, selectOnBlur, style, variant, ...rest }: MultiSelectBetaProps) => JSX.Element;
76
+ export declare const MultiSelectBeta: ({ allItemsSelectedLabel, ariaLabelRemoveSelected, className, clearable, clearInputOnSelect, debounceTimeout, disabled, feedback, hideSelectAll, items: initialItems, label, listStyle, loadingText, maxTags, onChange, openOnFocus, placeholder, readOnly, clearAllItemsAriaLabel, selectAllLabel, selectedItems, selectOnBlur, style, variant, ...rest }: MultiSelectBetaProps) => JSX.Element;
@@ -1,4 +1,4 @@
1
- /// <reference types="react" />
1
+ import React from 'react';
2
2
  import { VariantType } from '@entur/form';
3
3
  import { NormalizedDropdownItemType } from '../useNormalizedItems';
4
4
  import { PotentiallyAsyncDropdownItemType } from '../useResolvedItems';
@@ -34,10 +34,16 @@ export type SearchableDropdownProps = {
34
34
  disableLabelAnimation?: boolean;
35
35
  /** Antall millisekunder man venter før man kaller en potensiell items-funksjon */
36
36
  debounceTimeout?: number;
37
+ /** Deaktiver dropdown-en */
38
+ disabled?: boolean;
37
39
  /** Gjør dropdown-en til å kun kunne leses
38
40
  * @default false
39
41
  */
40
- readonly?: boolean;
42
+ readOnly?: boolean;
43
+ /** Tekst eller ikon som kommer før dropdown-en */
44
+ prepend?: React.ReactNode;
45
+ /** En tekst som beskriver hva som skjer når man venter på items */
46
+ loadingText?: string;
41
47
  selectOnBlur?: boolean;
42
48
  /** Hvilken valideringsvariant som gjelder */
43
49
  variant?: VariantType;
@@ -52,4 +58,4 @@ export type SearchableDropdownProps = {
52
58
  [key: string]: any;
53
59
  };
54
60
  };
55
- export declare const SearchableDropdownBeta: ({ className, clearable, debounceTimeout, disableLabelAnimation, feedback, itemFilter, items: initialItems, label, listStyle, onChange, openOnFocus, placeholder, readonly, selectedItem: value, selectOnBlur, variant, ...rest }: SearchableDropdownProps) => JSX.Element;
61
+ export declare const SearchableDropdownBeta: ({ className, clearable, debounceTimeout, disabled, disableLabelAnimation, feedback, itemFilter, items: initialItems, label, listStyle, loadingText, onChange, openOnFocus, placeholder, prepend, readOnly, selectedItem: value, selectOnBlur, style, variant, ...rest }: SearchableDropdownProps) => JSX.Element;
@@ -1,24 +1,25 @@
1
+ import React from 'react';
1
2
  import { UseComboboxGetToggleButtonPropsOptions, UseMultipleSelectionGetSelectedItemPropsOptions } from 'downshift';
2
3
  import { NormalizedDropdownItemType } from '../../useNormalizedItems';
3
- import React from 'react';
4
4
  import './FieldComponents.scss';
5
- export declare const SelectedElementsTag: ({ getSelectedItemProps, removeSelectedItem, selectedItem, index, ariaLabelRemoveSelected, }: {
6
- getSelectedItemProps: (options: UseMultipleSelectionGetSelectedItemPropsOptions<NormalizedDropdownItemType>) => any;
5
+ export declare const SelectedItemTag: ({ ariaLabelRemoveSelected, disabled, getSelectedItemProps, index, readOnly, removeSelectedItem, selectedItem, }: {
6
+ ariaLabelRemoveSelected: string;
7
+ disabled?: boolean | undefined;
8
+ getSelectedItemProps?: ((options: UseMultipleSelectionGetSelectedItemPropsOptions<NormalizedDropdownItemType>) => any) | undefined;
9
+ index?: number | undefined;
10
+ readOnly?: boolean | undefined;
7
11
  removeSelectedItem: (item: NormalizedDropdownItemType) => void;
8
12
  selectedItem: NormalizedDropdownItemType;
9
- index: number;
10
- ariaLabelRemoveSelected: string;
11
13
  }) => JSX.Element;
12
14
  export declare const FieldAppend: React.FC<{
13
- selectedItems: (NormalizedDropdownItemType | null)[];
15
+ clearable?: boolean;
16
+ clearSelectedItemsLabel?: string;
17
+ disabled?: boolean;
18
+ focusable?: boolean;
19
+ getToggleButtonProps: (options?: UseComboboxGetToggleButtonPropsOptions | undefined) => any;
14
20
  isOpen: boolean;
15
- clearable: boolean;
16
21
  loading?: boolean;
17
22
  loadingText?: string;
18
- ariaLabelClearItems?: string;
19
- clearSelectedItemsLabel?: string;
20
- readOnly: boolean;
21
- focusable?: boolean;
22
23
  onClear: () => void;
23
- getToggleButtonProps: (options?: UseComboboxGetToggleButtonPropsOptions | undefined) => any;
24
+ selectedItems: (NormalizedDropdownItemType | null)[];
24
25
  }>;
@@ -1,4 +1,5 @@
1
1
  import { NormalizedDropdownItemType } from '../useNormalizedItems';
2
+ export declare const EMPTY_INPUT = "";
2
3
  export declare function lowerCaseFilterTest(item: NormalizedDropdownItemType, input: string | undefined): boolean;
3
4
  export declare const itemToString: (item: NormalizedDropdownItemType | null) => string;
4
5
  type useMultiselectUtilsType = {
@@ -11,6 +12,10 @@ export declare const useMultiselectUtils: ({ listItems, selectedItems, selectAll
11
12
  allListItemsAreSelected: boolean;
12
13
  clickedItemIsInSelectedItems: (clickedItem: NormalizedDropdownItemType) => boolean;
13
14
  clickedItemIsSelectAll: (clickedItem: NormalizedDropdownItemType) => boolean;
15
+ handleListItemClicked: ({ clickedItem, onChange, }: {
16
+ clickedItem: NormalizedDropdownItemType;
17
+ onChange: (value: NormalizedDropdownItemType[]) => void;
18
+ }) => void;
14
19
  hasSelectedItems: boolean;
15
20
  listItemsWithoutSelectAll: NormalizedDropdownItemType[];
16
21
  removeClickedItemFromSelectedItems: (clickedItem: NormalizedDropdownItemType, onChange: (value: NormalizedDropdownItemType[]) => void) => void;