From fabff42fb8742d0999799ed5c8f6523eaacf79c8 Mon Sep 17 00:00:00 2001 From: Anurag Date: Tue, 17 Nov 2020 13:16:35 +0530 Subject: [PATCH] chore(accordion): refactored & cleaned up accordion types --- src/accordion/AccordionState.ts | 2 +- src/accordion/types.ts | 69 ++++++++++++++------------------- 2 files changed, 31 insertions(+), 40 deletions(-) diff --git a/src/accordion/AccordionState.ts b/src/accordion/AccordionState.ts index 18add4657..cb98b4a72 100644 --- a/src/accordion/AccordionState.ts +++ b/src/accordion/AccordionState.ts @@ -2,6 +2,7 @@ import * as React from "react"; import { useCompositeState } from "reakit"; import { useControllableState } from "@chakra-ui/hooks"; import { + SelectedIdPair, AccordionState, AccordionActions, AccordionReturns, @@ -10,7 +11,6 @@ import { AccordionInitialState, AccordionInitialStateMulti, AccordionInitialStateSingle, - SelectedIdPair, } from "./types"; export type AccordionStateReturn = AccordionActions & diff --git a/src/accordion/types.ts b/src/accordion/types.ts index 25e692f9d..d2fcb379f 100644 --- a/src/accordion/types.ts +++ b/src/accordion/types.ts @@ -1,9 +1,12 @@ +import { Dispatch, SetStateAction } from "react"; import { CompositeState, CompositeActions, CompositeInitialState, } from "reakit"; +export type StringOrNull = string | null; + export type AccordionState = CompositeState & { /** * Allow to open multiple accordion items @@ -44,7 +47,7 @@ export type AccordionActions = CompositeActions & { unregisterPanel: CompositeActions["unregisterItem"]; }; -export interface CommonAccordionProps { +export type CommonAccordionProps = { /** * Whether the accodion selection should be manual. * @default true @@ -55,23 +58,16 @@ export interface CommonAccordionProps { * @default false */ allowToggle: boolean; -} +}; export type SelectedIdPair = { - /** - * The current selected accordion's `id`. - */ - selectedId?: string | null; - /** - * Initial selected accordion's `id`. - * @default [] - */ - selectedIds?: (string | null)[]; - setSelectedId?: React.Dispatch>; - setSelectedIds?: React.Dispatch>; + selectedId?: StringOrNull; + selectedIds?: StringOrNull[]; + setSelectedId?: Dispatch>; + setSelectedIds?: Dispatch>; }; -export interface SingleAccordionProps extends CommonAccordionProps { +export type SingleAccordionProps = CommonAccordionProps & { /** * Allow to open multiple accordion items * @default false @@ -80,20 +76,20 @@ export interface SingleAccordionProps extends CommonAccordionProps { /** * The current selected accordion's `id`. */ - selectedId?: string | null; + selectedId?: StringOrNull; /** * Set default selected id(uncontrolled) * * @default null */ - defaultSelectedId?: string | null; + defaultSelectedId?: StringOrNull; /** * Handler that is called when the selectedId changes. */ - onSelectedIdChange?: (value: string | null) => void; -} + onSelectedIdChange?: (value: StringOrNull) => void; +}; -export interface MultiAccordionProps extends CommonAccordionProps { +export type MultiAccordionProps = CommonAccordionProps & { /** * Allow to open multiple accordion items * @default true @@ -103,60 +99,55 @@ export interface MultiAccordionProps extends CommonAccordionProps { * Initial selected accordion's `id`. * @default [] */ - selectedIds?: (string | null)[]; + selectedIds?: StringOrNull[]; /** * Set default selected ids(uncontrolled) * * @default [] */ - defaultSelectedIds?: (string | null)[]; + defaultSelectedIds?: StringOrNull[]; /** * Handler that is called when the selectedIds changes. */ - onSelectedIdsChange?: (value: (string | null)[]) => void; -} + onSelectedIdsChange?: (value: StringOrNull[]) => void; +}; // State return types // -export interface SingleReturn { +export type SingleReturn = { /** * Allow to open multiple accordion items - * @default false */ allowMultiple: false; /** * The current selected accordion's `id`. */ - selectedId: string | null | undefined; + selectedId: SelectedIdPair["selectedId"] | undefined; /** * Sets `selectedId`. */ - setSelectedId: React.Dispatch>; -} + setSelectedId: NonNullable; +}; -export interface MultiReturn { +export type MultiReturn = { /** * Allow to open multiple accordion items - * @default true */ allowMultiple: true; /** * The current selected accordion's `id`. */ - selectedIds: (string | null)[] | undefined; + selectedIds: SelectedIdPair["selectedIds"] | undefined; /** * Sets `selectedIds`. */ - setSelectedIds: React.Dispatch>; -} + setSelectedIds: NonNullable; +}; // Overload signatures for useAccordionState -export type SingleOverloadReturn = AccordionActions & - AccordionState & - SingleReturn; -export type MultiOverloadReturn = AccordionActions & - AccordionState & - MultiReturn; +type AccordionStateActions = AccordionActions & AccordionState; +export type SingleOverloadReturn = AccordionStateActions & SingleReturn; +export type MultiOverloadReturn = AccordionStateActions & MultiReturn; type AccordionProps = SingleAccordionProps | MultiAccordionProps; export type AccordionReturns = MultiReturn | SingleReturn;