Skip to content

Commit

Permalink
feat(Title): add title font customization
Browse files Browse the repository at this point in the history
  • Loading branch information
DaryaLari committed Dec 28, 2024
1 parent 11dbeb0 commit aa56b33
Show file tree
Hide file tree
Showing 5 changed files with 84 additions and 15 deletions.
34 changes: 24 additions & 10 deletions src/plugins/Title/Title.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,33 +4,47 @@ import {Plugin, PluginWidgetProps} from '../../typings';
import {cn} from '../../utils/cn';
import {PLUGIN_ROOT_ATTR_NAME} from '../constants';

import './Title.scss';
import type {TitleFontDataProps} from './types';

export type PluginTitleSize = 'xl' | 'l' | 'm' | 's' | 'xs';
import './Title.scss';

export interface PluginTitleProps extends PluginWidgetProps {
data: {
size: PluginTitleSize;
text: string;
showInTOC: boolean;
} & PluginWidgetProps['data'];
} & TitleFontDataProps &
PluginWidgetProps['data'];
}

const b = cn('dashkit-plugin-title');

export class PluginTitle extends React.Component<PluginTitleProps> {
render() {
const {data} = this.props;
export const PluginTitle = React.forwardRef<HTMLDivElement, PluginTitleProps>(
function PluginTitle_(props, ref) {
const {data} = props;
const text = data.text ? data.text : '';
const size = data.size ? data.size : false;
const styles =
data.fontSize && data.lineHeight
? {
fontSize: `${data.fontSize}px`,
lineHeight: `${data.lineHeight}px`,
}
: {};
const id = data.showInTOC && text ? encodeURIComponent(text) : undefined;

return (
<div id={id} className={b({size})} {...{[PLUGIN_ROOT_ATTR_NAME]: 'title'}}>
<div
ref={ref}
id={id}
style={styles}
className={b({size})}
{...{[PLUGIN_ROOT_ATTR_NAME]: 'title'}}
>
{text}
</div>
);
}
}
},
);

const plugin: Plugin<PluginTitleProps> = {
type: 'title',
Expand Down
23 changes: 18 additions & 5 deletions src/plugins/Title/__stories__/Title.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
import React from 'react';

import {Flex} from '@gravity-ui/uikit';
import {Card, Flex} from '@gravity-ui/uikit';
import {Meta, StoryObj} from '@storybook/react';

import {PluginTitle, PluginTitleSize} from '../Title';
import {PluginTitle} from '../Title';
import {PluginTitleSize} from '../types';

export default {
title: 'Components/Title',
Expand All @@ -18,12 +19,24 @@ export const Size: Story = {
render: ({data: _, ...args}) => (
<Flex direction="column" gap={2}>
{sizes.map((size) => (
<Card key={size}>
<PluginTitle
data={{size, text: `Title size=${size}`, showInTOC: true}}
{...args}
/>
</Card>
))}
<Card key="custom">
<PluginTitle
key={size}
data={{size, text: `Title size=${size}`, showInTOC: true}}
data={{
fontSize: 40,
lineHeight: 100,
text: `Title with custom font params`,
showInTOC: true,
}}
{...args}
/>
))}
</Card>
</Flex>
),
};
24 changes: 24 additions & 0 deletions src/plugins/Title/constants.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
import {PluginTitleSize, TitleFontParams} from './types';

export const TITLE_DEFAULT_SIZES: Record<PluginTitleSize, TitleFontParams> = {
xl: {
fontSize: 32,
lineHeight: 40,
},
l: {
fontSize: 24,
lineHeight: 28,
},
m: {
fontSize: 20,
lineHeight: 24,
},
s: {
fontSize: 17,
lineHeight: 24,
},
xs: {
fontSize: 15,
lineHeight: 20,
},
};
2 changes: 2 additions & 0 deletions src/plugins/Title/index.ts
Original file line number Diff line number Diff line change
@@ -1,2 +1,4 @@
export * from './Title';
export {default as pluginTitle} from './Title';
export {PluginTitleSize, TitleFontParams} from './types';
export {TITLE_DEFAULT_SIZES} from './constants';
16 changes: 16 additions & 0 deletions src/plugins/Title/types.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
export type PluginTitleSize = 'xl' | 'l' | 'm' | 's' | 'xs';

export interface TitleFontParams {
fontSize: number;
lineHeight: number;
}

interface FontSizeProps {
size: PluginTitleSize;
}

type UndefinedProps<T extends Object> = Partial<Record<keyof T, undefined>>;

export type TitleFontDataProps =
| (FontSizeProps & UndefinedProps<TitleFontParams>)
| (UndefinedProps<FontSizeProps> & TitleFontParams);

0 comments on commit aa56b33

Please sign in to comment.