diff --git a/app/soapbox/components/icon-button.tsx b/app/soapbox/components/icon-button.tsx index 71f1109956..9927ae8df9 100644 --- a/app/soapbox/components/icon-button.tsx +++ b/app/soapbox/components/icon-button.tsx @@ -90,7 +90,7 @@ const IconButton: React.FC = ({ type='button' >
-
{text && {text}} diff --git a/app/soapbox/components/icon.tsx b/app/soapbox/components/icon.tsx index f03f405801..8e875ed0ec 100644 --- a/app/soapbox/components/icon.tsx +++ b/app/soapbox/components/icon.tsx @@ -1,27 +1,28 @@ /** - * Icon: abstract icon class that can render icons from multiple sets. + * Icon: abstact component to render SVG icons. * @module soapbox/components/icon - * @see soapbox/components/fork_awesome_icon - * @see soapbox/components/svg_icon */ +import classNames from 'clsx'; import React from 'react'; +import InlineSVG from 'react-inlinesvg'; // eslint-disable-line no-restricted-imports -import ForkAwesomeIcon, { IForkAwesomeIcon } from './fork-awesome-icon'; -import SvgIcon, { ISvgIcon } from './svg-icon'; +export interface IIcon extends React.HTMLAttributes { + src: string, + id?: string, + alt?: string, + className?: string, +} -export type IIcon = IForkAwesomeIcon | ISvgIcon; - -const Icon: React.FC = (props) => { - if ((props as ISvgIcon).src) { - const { src, ...rest } = (props as ISvgIcon); - - return ; - } else { - const { id, fixedWidth, ...rest } = (props as IForkAwesomeIcon); - - return ; - } +const Icon: React.FC = ({ src, alt, className, ...rest }) => { + return ( +
+ } /> +
+ ); }; export default Icon; diff --git a/app/soapbox/components/status-content.tsx b/app/soapbox/components/status-content.tsx index df35a90ac3..c361c22898 100644 --- a/app/soapbox/components/status-content.tsx +++ b/app/soapbox/components/status-content.tsx @@ -26,7 +26,7 @@ interface IReadMoreButton { const ReadMoreButton: React.FC = ({ onClick }) => ( ); diff --git a/app/soapbox/components/svg-icon.tsx b/app/soapbox/components/svg-icon.tsx deleted file mode 100644 index cd8942f68c..0000000000 --- a/app/soapbox/components/svg-icon.tsx +++ /dev/null @@ -1,29 +0,0 @@ -/** - * SvgIcon: abstact component to render SVG icons. - * @module soapbox/components/svg_icon - * @see soapbox/components/icon - */ - -import classNames from 'clsx'; -import React from 'react'; -import InlineSVG from 'react-inlinesvg'; // eslint-disable-line no-restricted-imports - -export interface ISvgIcon extends React.HTMLAttributes { - src: string, - id?: string, - alt?: string, - className?: string, -} - -const SvgIcon: React.FC = ({ src, alt, className, ...rest }) => { - return ( -
- } /> -
- ); -}; - -export default SvgIcon; diff --git a/app/soapbox/features/list-adder/components/list.tsx b/app/soapbox/features/list-adder/components/list.tsx index f1fb3ee40f..b02800c921 100644 --- a/app/soapbox/features/list-adder/components/list.tsx +++ b/app/soapbox/features/list-adder/components/list.tsx @@ -37,7 +37,7 @@ const List: React.FC = ({ listId }) => { return (
- + {list.title} diff --git a/app/soapbox/features/lists/index.tsx b/app/soapbox/features/lists/index.tsx index 082da7c5d2..3dc8b4c90a 100644 --- a/app/soapbox/features/lists/index.tsx +++ b/app/soapbox/features/lists/index.tsx @@ -85,7 +85,7 @@ const Lists: React.FC = () => { > {lists.map((list: any) => ( - + {list.title} diff --git a/app/soapbox/features/soapbox-config/components/icon-picker-dropdown.tsx b/app/soapbox/features/soapbox-config/components/icon-picker-dropdown.tsx index d23e9f004f..9a5f903992 100644 --- a/app/soapbox/features/soapbox-config/components/icon-picker-dropdown.tsx +++ b/app/soapbox/features/soapbox-config/components/icon-picker-dropdown.tsx @@ -3,7 +3,7 @@ import { defineMessages, useIntl } from 'react-intl'; // @ts-ignore import Overlay from 'react-overlays/lib/Overlay'; -import Icon from 'soapbox/components/icon'; +import ForkAwesomeIcon from 'soapbox/components/fork-awesome-icon'; import IconPickerMenu from './icon-picker-menu'; @@ -68,7 +68,7 @@ const IconPickerDropdown: React.FC = ({ value, onPickEmoji onKeyDown={onToggle} tabIndex={0} > - +
diff --git a/app/soapbox/features/ui/components/list-panel.tsx b/app/soapbox/features/ui/components/list-panel.tsx deleted file mode 100644 index 8160217e9f..0000000000 --- a/app/soapbox/features/ui/components/list-panel.tsx +++ /dev/null @@ -1,45 +0,0 @@ -import React, { useEffect } from 'react'; -import { NavLink } from 'react-router-dom'; -import { createSelector } from 'reselect'; - -import { fetchLists } from 'soapbox/actions/lists'; -import Icon from 'soapbox/components/icon'; -import { useAppDispatch, useAppSelector } from 'soapbox/hooks'; - -import type { List as ImmutableList } from 'immutable'; -import type { RootState } from 'soapbox/store'; -import type { List as ListEntity } from 'soapbox/types/entities'; - -const getOrderedLists = createSelector([(state: RootState) => state.lists], lists => { - if (!lists) { - return lists; - } - - return lists.toList().filter(item => !!item).sort((a, b) => (a as ListEntity).title.localeCompare((b as ListEntity).title)).take(4) as ImmutableList; -}); - -const ListPanel = () => { - const dispatch = useAppDispatch(); - - const lists = useAppSelector((state) => getOrderedLists(state)); - - useEffect(() => { - dispatch(fetchLists()); - }, []); - - if (!lists || lists.isEmpty()) { - return null; - } - - return ( -
-
- - {lists.map(list => ( - {list.title} - ))} -
- ); -}; - -export default ListPanel; diff --git a/app/soapbox/features/ui/components/promo-panel.tsx b/app/soapbox/features/ui/components/promo-panel.tsx index 12798dc063..778302f11b 100644 --- a/app/soapbox/features/ui/components/promo-panel.tsx +++ b/app/soapbox/features/ui/components/promo-panel.tsx @@ -1,6 +1,6 @@ import React from 'react'; -import Icon from 'soapbox/components/icon'; +import ForkAwesomeIcon from 'soapbox/components/fork-awesome-icon'; import { Widget, Stack, Text } from 'soapbox/components/ui'; import { useInstance, useSettings, useSoapboxConfig } from 'soapbox/hooks'; @@ -20,7 +20,7 @@ const PromoPanel: React.FC = () => { {promoItems.map((item, i) => ( - + {item.textLocales.get(locale) || item.text}