From 0b29e5ffecc72f3561446d57f1f50987623296d4 Mon Sep 17 00:00:00 2001 From: Wes Souza Date: Mon, 25 Jul 2022 17:01:44 -0400 Subject: [PATCH] feat(hourglass): convert to TypeScript and export types --- src/Hourglass/Hourglass.js | 45 ------------------- src/Hourglass/Hourglass.mdx | 2 +- src/Hourglass/Hourglass.spec.js | 30 ------------- src/Hourglass/Hourglass.spec.tsx | 34 ++++++++++++++ ...glass.stories.js => Hourglass.stories.tsx} | 4 +- src/Hourglass/Hourglass.tsx | 34 ++++++++++++++ ...base64hourglass.js => base64hourglass.tsx} | 0 src/index.ts | 2 +- 8 files changed, 72 insertions(+), 79 deletions(-) delete mode 100644 src/Hourglass/Hourglass.js delete mode 100644 src/Hourglass/Hourglass.spec.js create mode 100644 src/Hourglass/Hourglass.spec.tsx rename src/Hourglass/{Hourglass.stories.js => Hourglass.stories.tsx} (82%) create mode 100644 src/Hourglass/Hourglass.tsx rename src/Hourglass/{base64hourglass.js => base64hourglass.tsx} (100%) diff --git a/src/Hourglass/Hourglass.js b/src/Hourglass/Hourglass.js deleted file mode 100644 index 3adc5250..00000000 --- a/src/Hourglass/Hourglass.js +++ /dev/null @@ -1,45 +0,0 @@ -import React from 'react'; -import propTypes from 'prop-types'; -import styled from 'styled-components'; -import base64hourglass from './base64hourglass'; - -const StyledContainer = styled.span` - display: inline-block; -`; - -const StyledHourglass = styled.span` - display: block; - background: ${base64hourglass}; - background-size: cover; - width: 100%; - height: 100%; -`; - -const Hourglass = React.forwardRef(function HourGlass(props, ref) { - const { size, style, ...otherProps } = props; - return ( - - - - ); -}); - -Hourglass.defaultProps = { - size: '30px', - style: {} -}; - -Hourglass.propTypes = { - size: propTypes.oneOfType([propTypes.string, propTypes.number]), - // eslint-disable-next-line react/forbid-prop-types - style: propTypes.object -}; -export default Hourglass; diff --git a/src/Hourglass/Hourglass.mdx b/src/Hourglass/Hourglass.mdx index 0d4b8b8e..e4ca81be 100644 --- a/src/Hourglass/Hourglass.mdx +++ b/src/Hourglass/Hourglass.mdx @@ -3,7 +3,7 @@ name: Hourglass menu: Components --- -import Hourglass from './Hourglass'; +import { Hourglass } from './Hourglass'; # Hourglass diff --git a/src/Hourglass/Hourglass.spec.js b/src/Hourglass/Hourglass.spec.js deleted file mode 100644 index 198b80df..00000000 --- a/src/Hourglass/Hourglass.spec.js +++ /dev/null @@ -1,30 +0,0 @@ -import React from 'react'; -import { render } from '@testing-library/react'; - -import Hourglass from './Hourglass'; - -describe('', () => { - it('should render hourglass', () => { - const { container } = render(); - const barEl = container.firstChild; - - expect(barEl).toBeInTheDocument(); - }); - - it('should render correct size', () => { - const { container } = render(); - const hourglass = container.firstChild; - - const computedStyles = window.getComputedStyle(hourglass); - expect(computedStyles.width).toBe('66px'); - expect(computedStyles.height).toBe('66px'); - }); - - it('should handle custom props', () => { - const customProps = { alt: 'hourglass' }; - const { container } = render(); - const hourglass = container.firstChild; - - expect(hourglass).toHaveAttribute('alt', 'hourglass'); - }); -}); diff --git a/src/Hourglass/Hourglass.spec.tsx b/src/Hourglass/Hourglass.spec.tsx new file mode 100644 index 00000000..46cdab07 --- /dev/null +++ b/src/Hourglass/Hourglass.spec.tsx @@ -0,0 +1,34 @@ +import { render } from '@testing-library/react'; +import React from 'react'; + +import { Hourglass } from './Hourglass'; + +describe('', () => { + it('should render hourglass', () => { + const { container } = render(); + const hourglass = container.firstElementChild; + + expect(hourglass).toBeInTheDocument(); + }); + + it('should render correct size', () => { + const { container } = render(); + const hourglass = container.firstElementChild; + + const computedStyles = hourglass + ? window.getComputedStyle(hourglass) + : null; + expect(computedStyles?.width).toBe('66px'); + expect(computedStyles?.height).toBe('66px'); + }); + + it('should handle custom props', () => { + const customProps: React.HTMLAttributes = { + title: 'hourglass' + }; + const { container } = render(); + const hourglass = container.firstElementChild; + + expect(hourglass).toHaveAttribute('title', 'hourglass'); + }); +}); diff --git a/src/Hourglass/Hourglass.stories.js b/src/Hourglass/Hourglass.stories.tsx similarity index 82% rename from src/Hourglass/Hourglass.stories.js rename to src/Hourglass/Hourglass.stories.tsx index db7dbd30..e0980e60 100644 --- a/src/Hourglass/Hourglass.stories.js +++ b/src/Hourglass/Hourglass.stories.tsx @@ -1,7 +1,7 @@ -import React from 'react'; import styled from 'styled-components'; import { Hourglass } from 'react95'; +import { ComponentMeta } from '@storybook/react'; const Wrapper = styled.div` padding: 5rem; @@ -12,7 +12,7 @@ export default { title: 'Hourglass', component: Hourglass, decorators: [story => {story()}] -}; +} as ComponentMeta; export function Default() { return ; diff --git a/src/Hourglass/Hourglass.tsx b/src/Hourglass/Hourglass.tsx new file mode 100644 index 00000000..e64ebd7b --- /dev/null +++ b/src/Hourglass/Hourglass.tsx @@ -0,0 +1,34 @@ +import { forwardRef } from 'react'; +import styled from 'styled-components'; +import { getSize } from '../common/utils'; +import base64hourglass from './base64hourglass'; + +type HourglassProps = { + size?: string | number; +}; + +const StyledContainer = styled.span>>` + display: inline-block; + height: ${({ size }) => getSize(size)}; + width: ${({ size }) => getSize(size)}; +`; + +const StyledHourglass = styled.span` + display: block; + background: ${base64hourglass}; + background-size: cover; + width: 100%; + height: 100%; +`; + +const Hourglass = forwardRef( + function Hourglass({ size = 30, ...otherProps }, ref) { + return ( + + + + ); + } +); + +export { Hourglass, HourglassProps }; diff --git a/src/Hourglass/base64hourglass.js b/src/Hourglass/base64hourglass.tsx similarity index 100% rename from src/Hourglass/base64hourglass.js rename to src/Hourglass/base64hourglass.tsx diff --git a/src/index.ts b/src/index.ts index ee3a0431..476a9447 100644 --- a/src/index.ts +++ b/src/index.ts @@ -15,7 +15,7 @@ export { default as Cutout } from './Cutout/Cutout'; export * from './Desktop/Desktop'; export * from './Divider/Divider'; export { default as Fieldset } from './Fieldset/Fieldset'; -export { default as Hourglass } from './Hourglass/Hourglass'; +export * from './Hourglass/Hourglass'; export { default as List } from './List/List'; export { default as ListItem } from './ListItem/ListItem'; export { default as LoadingIndicator } from './LoadingIndicator/LoadingIndicator';