2022-03-26 14:52:54 +00:00
|
|
|
import type { HTMLAttributes, PropType } from 'vue';
|
2021-06-26 01:35:40 +00:00
|
|
|
import { defineComponent } from 'vue';
|
2023-01-27 08:00:17 +00:00
|
|
|
import useConfigInject from '../config-provider/hooks/useConfigInject';
|
2021-03-16 04:54:22 +00:00
|
|
|
import classNames from '../_util/classNames';
|
2022-03-12 01:56:32 +00:00
|
|
|
import type { Direction } from '../config-provider';
|
2021-03-16 04:54:22 +00:00
|
|
|
|
2023-02-12 01:56:57 +00:00
|
|
|
// CSSINJS
|
|
|
|
import useStyle from './style';
|
|
|
|
|
2021-03-16 04:54:22 +00:00
|
|
|
export interface TypographyProps extends HTMLAttributes {
|
2022-03-12 01:56:32 +00:00
|
|
|
direction?: Direction;
|
2021-03-16 04:54:22 +00:00
|
|
|
prefixCls?: string;
|
|
|
|
}
|
|
|
|
|
2021-11-09 06:36:15 +00:00
|
|
|
export interface InternalTypographyProps extends TypographyProps {
|
2021-03-16 04:54:22 +00:00
|
|
|
component?: string;
|
|
|
|
}
|
2022-03-26 14:52:54 +00:00
|
|
|
export const typographyProps = () => ({
|
|
|
|
prefixCls: String,
|
|
|
|
direction: String as PropType<Direction>,
|
|
|
|
// Form Internal use
|
|
|
|
component: String,
|
|
|
|
});
|
2021-03-16 04:54:22 +00:00
|
|
|
const Typography = defineComponent<InternalTypographyProps>({
|
|
|
|
name: 'ATypography',
|
|
|
|
inheritAttrs: false,
|
2022-03-26 14:52:54 +00:00
|
|
|
props: typographyProps() as any,
|
2021-03-16 04:54:22 +00:00
|
|
|
setup(props, { slots, attrs }) {
|
2022-03-12 01:56:32 +00:00
|
|
|
const { prefixCls, direction } = useConfigInject('typography', props);
|
2023-02-12 01:56:57 +00:00
|
|
|
|
|
|
|
// Style
|
|
|
|
const [wrapSSR, hashId] = useStyle(prefixCls);
|
|
|
|
|
2021-03-16 04:54:22 +00:00
|
|
|
return () => {
|
|
|
|
const {
|
|
|
|
prefixCls: _prefixCls,
|
|
|
|
class: _className,
|
2022-03-12 01:56:32 +00:00
|
|
|
direction: _direction,
|
2021-03-16 04:54:22 +00:00
|
|
|
component: Component = 'article' as any,
|
|
|
|
...restProps
|
|
|
|
} = { ...props, ...attrs };
|
2023-02-12 01:56:57 +00:00
|
|
|
return wrapSSR(
|
2022-03-12 01:56:32 +00:00
|
|
|
<Component
|
|
|
|
class={classNames(
|
|
|
|
prefixCls.value,
|
|
|
|
{ [`${prefixCls.value}-rtl`]: direction.value === 'rtl' },
|
|
|
|
attrs.class,
|
2023-02-12 01:56:57 +00:00
|
|
|
hashId.value,
|
2022-03-12 01:56:32 +00:00
|
|
|
)}
|
|
|
|
{...restProps}
|
|
|
|
>
|
2021-03-16 04:54:22 +00:00
|
|
|
{slots.default?.()}
|
2023-02-12 01:56:57 +00:00
|
|
|
</Component>,
|
2021-03-16 04:54:22 +00:00
|
|
|
);
|
|
|
|
};
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
2021-06-23 13:47:53 +00:00
|
|
|
export default Typography;
|