From a15697faef83f19258e0031d2b2790927ab40d8d Mon Sep 17 00:00:00 2001 From: Justin Date: Wed, 30 Mar 2022 10:51:07 -0400 Subject: [PATCH] Convert UploadProgress to TSX --- .../features/chats/components/chat_box.js | 2 +- .../compose/components/upload-progress.tsx | 39 ++++++++++++++++ .../compose/components/upload_form.js | 4 +- .../compose/components/upload_progress.js | 45 ------------------- .../containers/upload_progress_container.js | 2 +- 5 files changed, 43 insertions(+), 49 deletions(-) create mode 100644 app/soapbox/features/compose/components/upload-progress.tsx delete mode 100644 app/soapbox/features/compose/components/upload_progress.js diff --git a/app/soapbox/features/chats/components/chat_box.js b/app/soapbox/features/chats/components/chat_box.js index 8a3569221..4467c9656 100644 --- a/app/soapbox/features/chats/components/chat_box.js +++ b/app/soapbox/features/chats/components/chat_box.js @@ -12,8 +12,8 @@ import { } from 'soapbox/actions/chats'; import { uploadMedia } from 'soapbox/actions/media'; import IconButton from 'soapbox/components/icon_button'; +import UploadProgress from 'soapbox/features/compose/components/upload-progress'; import UploadButton from 'soapbox/features/compose/components/upload_button'; -import UploadProgress from 'soapbox/features/compose/components/upload_progress'; import { truncateFilename } from 'soapbox/utils/media'; import ChatMessageList from './chat_message_list'; diff --git a/app/soapbox/features/compose/components/upload-progress.tsx b/app/soapbox/features/compose/components/upload-progress.tsx new file mode 100644 index 000000000..fd292eb29 --- /dev/null +++ b/app/soapbox/features/compose/components/upload-progress.tsx @@ -0,0 +1,39 @@ +import React from 'react'; +import { FormattedMessage } from 'react-intl'; +import spring from 'react-motion/lib/spring'; + +import Icon from 'soapbox/components/icon'; +import { useAppSelector } from 'soapbox/hooks'; + +import Motion from '../../ui/util/optional_motion'; + +const UploadProgress = () => { + const active = useAppSelector((state) => state.compose.get('is_uploading')); + const progress = useAppSelector((state) => state.compose.get('progress')); + + if (!active) { + return null; + } + + return ( +
+
+ +
+ +
+ + +
+ + {({ width }) => +
+ } + +
+
+
+ ); +}; + +export default UploadProgress; diff --git a/app/soapbox/features/compose/components/upload_form.js b/app/soapbox/features/compose/components/upload_form.js index f78203866..71e89517a 100644 --- a/app/soapbox/features/compose/components/upload_form.js +++ b/app/soapbox/features/compose/components/upload_form.js @@ -4,8 +4,8 @@ import ImmutablePropTypes from 'react-immutable-proptypes'; import ImmutablePureComponent from 'react-immutable-pure-component'; // import SensitiveButtonContainer from '../containers/sensitive_button_container'; +import UploadProgress from '../components/upload-progress'; import UploadContainer from '../containers/upload_container'; -import UploadProgressContainer from '../containers/upload_progress_container'; export default class UploadForm extends ImmutablePureComponent { @@ -21,7 +21,7 @@ export default class UploadForm extends ImmutablePureComponent { return (
- +
{mediaIds.map(id => ( diff --git a/app/soapbox/features/compose/components/upload_progress.js b/app/soapbox/features/compose/components/upload_progress.js deleted file mode 100644 index 2a66a67ed..000000000 --- a/app/soapbox/features/compose/components/upload_progress.js +++ /dev/null @@ -1,45 +0,0 @@ -import PropTypes from 'prop-types'; -import React from 'react'; -import { FormattedMessage } from 'react-intl'; -import spring from 'react-motion/lib/spring'; - -import Icon from 'soapbox/components/icon'; - -import Motion from '../../ui/util/optional_motion'; - -export default class UploadProgress extends React.PureComponent { - - static propTypes = { - active: PropTypes.bool, - progress: PropTypes.number, - }; - - render() { - const { active, progress } = this.props; - - if (!active) { - return null; - } - - return ( -
-
- -
- -
- - -
- - {({ width }) => -
- } - -
-
-
- ); - } - -} diff --git a/app/soapbox/features/compose/containers/upload_progress_container.js b/app/soapbox/features/compose/containers/upload_progress_container.js index 593ff3d3b..8113aadb6 100644 --- a/app/soapbox/features/compose/containers/upload_progress_container.js +++ b/app/soapbox/features/compose/containers/upload_progress_container.js @@ -1,6 +1,6 @@ import { connect } from 'react-redux'; -import UploadProgress from '../components/upload_progress'; +import UploadProgress from '../components/upload-progress'; const mapStateToProps = state => ({ active: state.getIn(['compose', 'is_uploading']),