diff --git a/app/soapbox/features/share/index.js b/app/soapbox/features/share/index.js
new file mode 100644
index 000000000..94220d3d9
--- /dev/null
+++ b/app/soapbox/features/share/index.js
@@ -0,0 +1,38 @@
+import React from 'react';
+import { connect } from 'react-redux';
+import { Redirect } from 'react-router-dom';
+import PropTypes from 'prop-types';
+import ImmutablePureComponent from 'react-immutable-pure-component';
+import { changeCompose } from '../../actions/compose';
+import { openModal } from '../../actions/modal';
+
+const mapDispatchToProps = dispatch => ({
+
+ onShare: (text) => {
+ dispatch(openModal('COMPOSE'));
+ dispatch(changeCompose(text));
+ },
+
+});
+
+export default @connect(null, mapDispatchToProps)
+class Share extends ImmutablePureComponent {
+
+ static propTypes = {
+ onShare: PropTypes.func.isRequired,
+ };
+
+ constructor(props) {
+ super(props);
+
+ const text = new URLSearchParams(window.location.search).get('text');
+ if (text) this.props.onShare(text);
+ }
+
+ render() {
+ return (
+
+ );
+ }
+
+}
diff --git a/app/soapbox/features/ui/index.js b/app/soapbox/features/ui/index.js
index 6e563da59..9eefbb7e9 100644
--- a/app/soapbox/features/ui/index.js
+++ b/app/soapbox/features/ui/index.js
@@ -109,6 +109,7 @@ import {
ModalContainer,
ProfileHoverCard,
RegisterInvite,
+ Share,
} from './util/async-components';
// Dummy import, to make sure that ends up in the application bundle.
@@ -305,6 +306,8 @@ class SwitchingColumnsArea extends React.PureComponent {
+
+
);
diff --git a/app/soapbox/features/ui/util/async-components.js b/app/soapbox/features/ui/util/async-components.js
index 139fd60c6..5a73fdfda 100644
--- a/app/soapbox/features/ui/util/async-components.js
+++ b/app/soapbox/features/ui/util/async-components.js
@@ -409,3 +409,7 @@ export function FollowRecommendations() {
export function RegisterInvite() {
return import(/* webpackChunkName: "features/register_invite" */'../../register_invite');
}
+
+export function Share() {
+ return import(/* webpackChunkName: "features/share" */'../../share');
+}
diff --git a/app/soapbox/features/ui/util/react_router_helpers.js b/app/soapbox/features/ui/util/react_router_helpers.js
index 2fa1970e0..4a636a738 100644
--- a/app/soapbox/features/ui/util/react_router_helpers.js
+++ b/app/soapbox/features/ui/util/react_router_helpers.js
@@ -84,7 +84,7 @@ class WrappedRoute extends React.Component {
const { component: Component, content, publicRoute, me, ...rest } = this.props;
if (!publicRoute && me === false) {
- const actualUrl = encodeURIComponent(this.props.computedMatch.url); // eslint-disable-line react/prop-types
+ const actualUrl = encodeURIComponent(`${this.props.computedMatch.url}${this.props.location.search}`); // eslint-disable-line react/prop-types
return ;
// return {
// window.location.href = `/auth/sign_in?redirect_uri=${actualUrl}`;