Skip to content

Commit

Permalink
Refactor(web-react): Grid useGridStylesProps use new hooks for genera…
Browse files Browse the repository at this point in the history
…ting classes

- uses new hook for generate alignment classes
  • Loading branch information
pavelklibani committed Aug 30, 2024
1 parent b6e8c0e commit cadf167
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 35 deletions.
45 changes: 12 additions & 33 deletions packages/web-react/src/components/Grid/useGridStyleProps.ts
Original file line number Diff line number Diff line change
@@ -1,15 +1,8 @@
import classNames from 'classnames';
import { CSSProperties, ElementType } from 'react';
import { DirectionAxis } from '../../constants';
import { useClassNamePrefix, useSpacingStyle } from '../../hooks';
import { GridColsBreakpoints, GridCustomLayoutProps, SpiritGridProps } from '../../types';

type AlignmentOrCols =
| string
| number
| Pick<GridCustomLayoutProps, 'alignmentX' | 'alignmentY' | 'cols'>
| GridColsBreakpoints
| undefined;
import { useAlignmentClass, useClassNamePrefix, useSpacingStyle } from '../../hooks';
import { GridColsBreakpoints, SpiritGridProps, GridAlignmentYType, GridAlignmentXType } from '../../types';

interface GridCSSProperties extends CSSProperties {
[key: string]: string | undefined | number;
Expand All @@ -24,14 +17,6 @@ export interface GridStyles<T> {
styleProps: GridCSSProperties;
}

function capitalizeFirstLetter(str: string): string {
if (typeof str !== 'string') {
return str;
}

return str.charAt(0).toUpperCase() + str.slice(1);
}

export function useGridStyleProps(props: SpiritGridProps<ElementType>): GridStyles<SpiritGridProps<ElementType>> {
const { alignmentX, alignmentY, cols, spacing, spacingX, spacingY, ...restProps } = props;

Expand All @@ -46,36 +31,30 @@ export function useGridStyleProps(props: SpiritGridProps<ElementType>): GridStyl
...useSpacingStyle(spacingY, 'grid', DirectionAxis.Y),
};

function generateGridClass(componentClass: string, property: AlignmentOrCols, type: string) {
function generateColsClasses(
componentClass: string,
property: number | GridColsBreakpoints | undefined,
type: string,
) {
if (typeof property === 'object' && property !== null) {
// If the property is an object, we need to check if the mobile property is set.
// If not, we set it to stretch
if (!Object.keys(property).includes('mobile')) {
(property as Record<string, string>).mobile = 'stretch';
}

// We map over the object and generate the classes for each breakpoint
return Object.keys(property)
.map((key) => {
const infix = key === 'mobile' ? '' : `--${key}`;
const responsiveProperty = (property as Record<string, string>)[key];

return `${componentClass}${infix}--${type}${
responsiveProperty && typeof responsiveProperty === 'string'
? capitalizeFirstLetter(responsiveProperty)
: `-${responsiveProperty}`
}`;
return `${componentClass}${infix}--${type}-${responsiveProperty}`;
})
.join(' ');
}

return `${componentClass}--${type}${property && typeof property === 'string' ? capitalizeFirstLetter(property) : `-${property}`}`;
return `${componentClass}--${type}-${property}`;
}

const classes = classNames(gridClass, {
[generateGridClass(gridClass, alignmentX, 'alignmentX')]: alignmentX,
[generateGridClass(gridClass, alignmentY, 'alignmentY')]: alignmentY,
[generateGridClass(gridClass, cols, 'cols')]: cols,
[useAlignmentClass(gridClass, alignmentX as GridAlignmentXType, 'alignmentX')]: alignmentX,
[useAlignmentClass(gridClass, alignmentY as GridAlignmentYType, 'alignmentY')]: alignmentY,
[generateColsClasses(gridClass, cols, 'cols')]: cols,
});

return {
Expand Down
11 changes: 9 additions & 2 deletions packages/web-react/src/types/grid.ts
Original file line number Diff line number Diff line change
Expand Up @@ -41,9 +41,16 @@ export interface GridItemElementTypeProps<T extends ElementType = 'div'> {
elementType?: T | JSXElementConstructor<unknown>;
}

export type GridAlignmentXType =
| NonNullable<AlignmentXExtendedDictionaryType>
| { [key: string]: NonNullable<AlignmentXExtendedDictionaryType> };
export type GridAlignmentYType =
| NonNullable<AlignmentYExtendedDictionaryType>
| { [key: string]: NonNullable<AlignmentYExtendedDictionaryType> };

export interface GridCustomLayoutProps {
alignmentX?: AlignmentXExtendedDictionaryType | { [key: string]: AlignmentXExtendedDictionaryType };
alignmentY?: AlignmentYExtendedDictionaryType | { [key: string]: AlignmentYExtendedDictionaryType };
alignmentX?: GridAlignmentXType;
alignmentY?: GridAlignmentYType;
cols?: GridColumns | GridColsBreakpoints;
/** Custom spacing between items */
spacing?: SpaceToken | Partial<Record<BreakpointToken, SpaceToken>>;
Expand Down

0 comments on commit cadf167

Please sign in to comment.