import React from 'react'; import styled, { CSSProperties } from 'styled-components'; type TextProps = { text: string; subtle?: boolean; maxWidth?: string; padding?: string; textAlign?: 'center'; ellipsisOverflow?: boolean; }; const StyledDefaultText = styled.div>` transition: var(--default-duration); max-width: ${props => (props.maxWidth ? props.maxWidth : '')}; padding: ${props => (props.padding ? props.padding : '')}; text-align: ${props => (props.textAlign ? props.textAlign : '')}; font-family: var(--font-default); color: ${props => (props.subtle ? 'var(--text-secondary-color)' : 'var(--text-primary-color)')}; white-space: ${props => (props.ellipsisOverflow ? 'nowrap' : null)}; overflow: ${props => (props.ellipsisOverflow ? 'hidden' : null)}; text-overflow: ${props => (props.ellipsisOverflow ? 'ellipsis' : null)}; `; export const Text = (props: TextProps) => { return {props.text}; }; export const TextWithChildren = ( props: Omit & { children: React.ReactNode } ) => { return {props.children}; }; type SpacerProps = { size: 'xl' | 'lg' | 'md' | 'sm' | 'xs'; style?: CSSProperties; }; const SpacerStyled = styled.div` height: ${props => props.size === 'xl' ? 'var(--margins-xl)' : props.size === 'lg' ? 'var(--margins-lg)' : props.size === 'md' ? 'var(--margins-md)' : props.size === 'sm' ? 'var(--margins-sm)' : 'var(--margins-xs)'}; width: ${props => props.size === 'xl' ? 'var(--margins-xl)' : props.size === 'lg' ? 'var(--margins-lg)' : props.size === 'md' ? 'var(--margins-md)' : props.size === 'sm' ? 'var(--margins-sm)' : 'var(--margins-xs)'}; `; const Spacer = (props: SpacerProps) => { return ; }; export const SpacerXL = (props: { style?: CSSProperties }) => { return ; }; export const SpacerLG = (props: { style?: CSSProperties }) => { return ; }; export const SpacerMD = (props: { style?: CSSProperties }) => { return ; }; export const SpacerSM = (props: { style?: CSSProperties }) => { return ; }; export const SpacerXS = (props: { style?: CSSProperties }) => { return ; }; type H3Props = { text: string; }; const StyledH3 = styled.div` transition: var(--default-duration); font-family: var(--font-default); font-size: var(--font-size-md); font-weight: 700; `; export const H3 = (props: H3Props) => {props.text};