Skip to content

Commit

Permalink
update DrawerList types
Browse files Browse the repository at this point in the history
  • Loading branch information
snorrekim committed Oct 22, 2024
1 parent 9023d38 commit ef84dd5
Show file tree
Hide file tree
Showing 9 changed files with 65 additions and 67 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -97,30 +97,30 @@ The following is an overview of all the types that the `data` prop accepts. (The
type CONTENT = string | React.Node | (string | React.Node)[]

// An array item
type ITEM = {
type ARRAY_OBJECT = {
content: CONTENT
selectedKey?: string | number
selected_value?: string | React.Node
suffix_value?: string | React.Node
}

// `data` as an array. A list of "ITEM" types is preferred,
// `data` as an array. A list of "ARRAY_OBJECT" types is preferred,
// but the "CONTENT" type can be useful for simple lists.
type ARRAY = (CONTENT | ITEM)[]
type ARRAY = (CONTENT | ARRAY_OBJECT)[]

// `data` as an object. Can only contain the "CONTENT" type.
// Each `key` behaves like the "ITEM"'s `selectedKey`.
type OBJECT = Record<string, CONTENT>
// Each `key` behaves like the "ARRAY_OBJECT"'s `selectedKey`.
type RECORD = Record<string, CONTENT>

// An object or array that represents the entire DrawerList list.
type DATA = ARRAY | OBJECT
type BASIC_DATA = ARRAY | RECORD

// A JSON stringified object/array of the "DATA" type
// A JSON stringified object/array of the "BASIC_DATA" type
type JSON_DATA = string

// a dunction that returns an object/array of the "DATA" type
type FUNCTION_DATA = () => DATA
// a dunction that returns an object/array of the "BASIC_DATA" type
type FUNCTION_DATA = () => BASIC_DATA

// The final type of the `data` prop.
type data = DATA | FUNCTION_DATA | JSON_DATA
type DATA = BASIC_DATA | FUNCTION_DATA | JSON_DATA
```
Original file line number Diff line number Diff line change
Expand Up @@ -23,8 +23,8 @@ import {
} from '@testing-library/react'
import {
DrawerListData,
DrawerListDataObject,
DrawerListDataObjectUnion,
DrawerListDataArrayObject,
DrawerListDataArray,
} from '../../../fragments/drawer-list'
import { Provider } from '../../../shared'

Expand All @@ -42,7 +42,7 @@ const props: AutocompleteAllProps = {
skip_portal: true,
}

const mockData: DrawerListDataObjectUnion[] = [
const mockData: DrawerListDataArray = [
'AA c',
'BB cc zethx',
{ content: ['CC', 'cc'] },
Expand Down Expand Up @@ -385,7 +385,7 @@ describe('Autocomplete component', () => {

const nodes1 = document.querySelectorAll('.dnb-sr-only')
expect(nodes1[nodes1.length - 1].textContent).toBe('2 alternativer')
const content = (mockData[2] as DrawerListDataObject).content
const content = (mockData[2] as DrawerListDataArrayObject).content
expect(
document.querySelectorAll('li.dnb-drawer-list__option')[0]
.textContent
Expand Down Expand Up @@ -763,7 +763,7 @@ describe('Autocomplete component', () => {
fireEvent.change(inputElement, {
target: { value: 'cc' },
})
const content = (mockData[2] as DrawerListDataObject).content
const content = (mockData[2] as DrawerListDataArrayObject).content
expect(optionElements()[0].textContent).toBe(
(content as string[]).join('')
)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ import { SubmitButton } from '../../input/Input'
import { format } from '../../number-format/NumberUtils'
import {
DrawerListData,
DrawerListDataObjectUnion,
DrawerListDataArray,
} from '../../../fragments/DrawerList'

export default {
Expand Down Expand Up @@ -856,7 +856,7 @@ const WideStyle = styled.div`
export function DataSuffix() {
const { locale } = React.useContext(Context)
const ban = format(21001234567, { ban: true, locale }) as string
const numbers: DrawerListDataObjectUnion[] = [
const numbers: DrawerListDataArray = [
{
selected_value: `Brukskonto (${ban})`,
suffix_value: (
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,8 @@ import {
testDirectionObserver,
} from '../../../fragments/drawer-list/__tests__/DrawerListTestMocks'
import {
DrawerListDataObject,
DrawerListDataObjectUnion,
DrawerListDataArrayObject,
DrawerListDataArray,
} from '../../../fragments/drawer-list'

// use no_animation so we don't need to wait
Expand All @@ -28,7 +28,7 @@ const props: DropdownAllProps = {
no_animation: true,
}

const mockData: DrawerListDataObjectUnion[] = [
const mockData: DrawerListDataArray = [
{
selected_value: 'Brukskonto - Kari Nordmann',
content: ['1234 56 78901', 'Brukskonto - Kari Nordmann'],
Expand Down Expand Up @@ -72,7 +72,9 @@ describe('Dropdown component', () => {

expect(
document.querySelector('.dnb-dropdown__text__inner').textContent
).toBe((mockData[props.value] as DrawerListDataObject).selected_value)
).toBe(
(mockData[props.value] as DrawerListDataArrayObject).selected_value
)

keydown(32) // space

Expand All @@ -96,7 +98,7 @@ describe('Dropdown component', () => {
expect(
document.querySelector('.dnb-dropdown__text__inner').textContent
).toBe(
(mockData[(props.value as number) + 1] as DrawerListDataObject)
(mockData[(props.value as number) + 1] as DrawerListDataArrayObject)
.selected_value
)
})
Expand Down Expand Up @@ -507,7 +509,7 @@ describe('Dropdown component', () => {
rerender(<Dropdown {...props} value={value} data={mockData} />)

expect(document.querySelector('.dnb-dropdown__text').textContent).toBe(
(mockData[value] as DrawerListDataObject).selected_value
(mockData[value] as DrawerListDataArrayObject).selected_value
)

rerender(<Dropdown {...props} value={undefined} data={mockData} />)
Expand All @@ -520,7 +522,7 @@ describe('Dropdown component', () => {
rerender(<Dropdown {...props} value={value} data={mockData} />)

expect(document.querySelector('.dnb-dropdown__text').textContent).toBe(
(mockData[value] as DrawerListDataObject).selected_value
(mockData[value] as DrawerListDataArrayObject).selected_value
)

rerender(<Dropdown {...props} value={null} data={mockData} />)
Expand Down Expand Up @@ -1073,7 +1075,7 @@ describe('Dropdown component', () => {
expect(
document.querySelector('.dnb-dropdown__text__inner').textContent
).toBe(
(mockData[(props.value as number) + 1] as DrawerListDataObject)
(mockData[(props.value as number) + 1] as DrawerListDataArrayObject)
.selected_value
)
})
Expand All @@ -1082,7 +1084,9 @@ describe('Dropdown component', () => {
render(<Dropdown {...props} data={mockData} />)
expect(
document.querySelector('.dnb-dropdown__text__inner').textContent
).toBe((mockData[props.value] as DrawerListDataObject).selected_value)
).toBe(
(mockData[props.value] as DrawerListDataArrayObject).selected_value
)
})

it('has correct selected value after new selection', () => {
Expand All @@ -1094,7 +1098,9 @@ describe('Dropdown component', () => {

expect(
document.querySelector('.dnb-dropdown__text__inner').textContent
).toBe((mockData[props.value] as DrawerListDataObject).selected_value)
).toBe(
(mockData[props.value] as DrawerListDataArrayObject).selected_value
)
})

it('has correct value after useEffect value state change', () => {
Expand All @@ -1113,7 +1119,9 @@ describe('Dropdown component', () => {

expect(
document.querySelector('.dnb-dropdown__text__inner').textContent
).toBe((mockData[newValue] as DrawerListDataObject).selected_value)
).toBe(
(mockData[newValue] as DrawerListDataArrayObject).selected_value
)

open()

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ import {
GlobalStatus,
} from '../..'
import { Flex, Link } from '../../..'
import { DrawerListDataObjectUnion } from '../../../fragments/DrawerList'
import { DrawerListDataArray } from '../../../fragments/DrawerList'
import { Provider } from '../../../shared'

export default {
Expand Down Expand Up @@ -628,7 +628,7 @@ export const DropdownSandbox = () => (
</CustomStyle>
)

let dropdownData: DrawerListDataObjectUnion[] = [
let dropdownData: DrawerListDataArray = [
{
selected_value: 'Brukskonto - Kari Nordmann',
content: (
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ import {
} from '../..'
import { Link } from '../../..'
import { format } from '../../number-format/NumberUtils'
import { DrawerListDataObject } from '../../../fragments/DrawerList'
import { DrawerListDataArray } from '../../../fragments/DrawerList'

export default {
title: 'Eufemia/Components/FormStatus',
Expand Down Expand Up @@ -228,7 +228,7 @@ export const GlobalStatusExample = () => {
export const SuffixAndStretchedStatus = () => {
const ban = format(21001234567, { ban: true }) as string

const numbers: DrawerListDataObject[] = [
const numbers: DrawerListDataArray = [
{
selected_value: `Brukskonto (${ban})`,
suffix_value: (
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ import {
} from '../SelectCountry'
import useErrorMessage from '../../hooks/useErrorMessage'
import useTranslation from '../../hooks/useTranslation'
import { DrawerListDataObject } from '../../../../fragments/DrawerList'
import { DrawerListDataArrayItem } from '../../../../fragments/DrawerList'

export type Props = FieldHelpProps &
FieldPropsWithExtraValue<
Expand Down Expand Up @@ -84,7 +84,7 @@ function PhoneNumber(props: Props) {

const countryCodeRef = React.useRef<Props['value']>(props?.emptyValue)
const numberRef = React.useRef<Props['value']>(props?.emptyValue)
const dataRef = React.useRef<Array<DrawerListDataObject>>(null)
const dataRef = React.useRef<Array<DrawerListDataArrayItem>>(null)
const langRef = React.useRef<string>(lang)
const wasFilled = React.useRef<boolean>(false)

Expand Down
46 changes: 18 additions & 28 deletions packages/dnb-eufemia/src/fragments/drawer-list/DrawerList.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,27 +13,30 @@ export type DrawerListWrapperElement =
| React.ReactNode;
export type DrawerListDefaultValue = string | number;
export type DrawerListValue = string | number;
export type DrawerListDataObject = {
export type DrawerListDataObject = DrawerListDataArrayObject; // deprecated, use "DrawerListDataArrayObject"
export type DrawerListDataArrayObject = {
selected_value?: string | React.ReactNode;
selectedKey?: string | number;
selected_key?: string | number;
suffix_value?: string | React.ReactNode;
content?: string | React.ReactNode | string[];
content?: DrawerListContent;
search_content?: string | React.ReactNode | string[];
};
export type DrawerListDataObjectUnion =
| string
| React.ReactNode
| DrawerListDataObject;
export type DrawerListDataObjectUnion = DrawerListDataArrayItem; // deprecated, use "DrawerListDataArrayItem"
export type DrawerListDataArrayItem =
| DrawerListDataArrayObject
| DrawerListContent;
export type DrawerListDataArray = DrawerListDataArrayItem[];
export type DrawerListDataRecord = Record<string, DrawerListContent>;
export type DrawerListDataAll = DrawerListDataRecord | DrawerListDataArray;
export type DrawerListData =
| string
| ((...args: any[]) => any)
| ((...args: any[]) => DrawerListDataAll)
| DrawerListDataAll;
export type DrawerListContent =
| string
| React.ReactNode
| Record<string, unknown>
| DrawerListDataObjectUnion[];
export type DrawerListSelectedValue = string | React.ReactNode;
export type DrawerListSuffixValue = string | React.ReactNode;
export type DrawerListContent = string | React.ReactNode | string[];
| (string | React.ReactNode)[];
export type DrawerListRawData =
| any[]
| Record<string, unknown>
Expand Down Expand Up @@ -108,7 +111,7 @@ export interface DrawerListProps {
*/
default_value?: DrawerListDefaultValue;
/**
* Define a preselected data entry (index) or key inside an array item. Can be a string or integer.
* Define a preselected `data` entry. In order of priority, `value` can be set to: object key (if `data` is an object), `selectedKey` prop (if `data` is an array), array index (if no `selectedKey`) or content (if `value` is a non-integer string).
*/
value?: DrawerListValue;
/**
Expand Down Expand Up @@ -146,12 +149,9 @@ export interface DrawerListProps {
skip_keysearch?: boolean;
opened?: boolean;
/**
* The data we want to fill the list with. Provide the data as a JSON string, array, or object in the specified data structure. If you don't have to define a value, you can also send in a function which will be called once the user opens the DrawerList.
* The data we want to fill the list with. The data can be provided as an array or object. Or as a function that returns the data (called when user opens the list), or a JSON stringified version of the data.`
*/
data?: DrawerListData;
selected_value?: DrawerListSelectedValue;
suffix_value?: DrawerListSuffixValue;
content?: DrawerListContent;
prepared_data?: any[];
raw_data?: DrawerListRawData;
/**
Expand Down Expand Up @@ -188,18 +188,8 @@ export type DrawerListOptionsProps = {
export type DrawerListItemProps = {
children: React.ReactNode;
selected: boolean;
/**
* Define a preselected data entry (index) or key inside an array item. Can be a string or integer.
*/
value: string;
on_click: ({
value
}: {
/**
* Define a preselected data entry (index) or key inside an array item. Can be a string or integer.
*/
value: string;
}) => void;
on_click: ({ value }: { value: string }) => void;
};
export type DrawerListAllProps = DrawerListProps &
SpacingProps &
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import { axeComponent, loadScss } from '../../../core/jest/jestSetup'
import { act, render, screen, waitFor } from '@testing-library/react'
import DrawerList, {
DrawerListAllProps,
DrawerListDataObjectUnion,
DrawerListDataArray,
DrawerListData,
} from '../DrawerList'

Expand All @@ -32,7 +32,7 @@ const props: DrawerListAllProps = {
no_animation: true,
}

const mockData: DrawerListDataObjectUnion[] = [
const mockData: DrawerListDataArray = [
{
content: ['1234 56 78901', 'Brukskonto - Kari Nordmann'],
},
Expand Down Expand Up @@ -185,7 +185,7 @@ describe('DrawerList component', () => {
const { rerender } = render(
<DrawerList
{...props}
data={Object.freeze(mockData) as DrawerListDataObjectUnion}
data={Object.freeze(mockData) as DrawerListDataArray}
on_select={on_select}
/>
)
Expand All @@ -204,7 +204,7 @@ describe('DrawerList component', () => {
rerender(
<DrawerList
{...props}
data={Object.freeze(mockData) as DrawerListDataObjectUnion}
data={Object.freeze(mockData) as DrawerListDataArray}
on_select={on_select}
opened={null}
/>
Expand All @@ -214,7 +214,7 @@ describe('DrawerList component', () => {
rerender(
<DrawerList
{...props}
data={Object.freeze(mockData) as DrawerListDataObjectUnion}
data={Object.freeze(mockData) as DrawerListDataArray}
on_select={on_select}
opened={true}
/>
Expand Down

0 comments on commit ef84dd5

Please sign in to comment.