You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
30 lines
806 B
TypeScript
30 lines
806 B
TypeScript
1 year ago
|
import { useContext } from 'react';
|
||
|
import { VariantContext } from '../context';
|
||
|
|
||
|
export const Variants = ['outlined', 'borderless', 'filled'] as const;
|
||
|
export type Variant = (typeof Variants)[number];
|
||
|
|
||
|
/**
|
||
|
* Compatible for legacy `bordered` prop.
|
||
|
*/
|
||
|
const useVariant = (
|
||
|
variant: Variant | undefined,
|
||
|
legacyBordered: boolean | undefined = undefined,
|
||
|
): [Variant, boolean] => {
|
||
|
const ctxVariant = useContext(VariantContext);
|
||
|
|
||
|
let mergedVariant: Variant;
|
||
|
if (typeof variant !== 'undefined') {
|
||
|
mergedVariant = variant;
|
||
|
} else if (legacyBordered === false) {
|
||
|
mergedVariant = 'borderless';
|
||
|
} else {
|
||
|
mergedVariant = ctxVariant ?? 'outlined';
|
||
|
}
|
||
|
|
||
|
const enableVariantCls = Variants.includes(mergedVariant);
|
||
|
return [mergedVariant, enableVariantCls];
|
||
|
};
|
||
|
|
||
|
export default useVariant;
|