2019-12-07 13:28:52 +02:00
|
|
|
import React from 'react';
|
|
|
|
import { RouteComponentProps } from 'react-router-dom';
|
2020-07-22 13:01:12 +03:00
|
|
|
|
|
|
|
import { connect } from 'app/functions';
|
2020-05-24 02:08:24 +03:00
|
|
|
import { fetchAvailableApps, resetApp, deleteApp } from 'app/components/dev/apps/actions';
|
2019-12-07 21:02:00 +02:00
|
|
|
import ApplicationsIndex from 'app/components/dev/apps/ApplicationsIndex';
|
|
|
|
import { User } from 'app/components/user';
|
|
|
|
import { OauthAppResponse } from 'app/services/api/oauth';
|
2018-03-25 22:16:45 +03:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
interface Props extends RouteComponentProps {
|
2020-05-24 02:08:24 +03:00
|
|
|
user: User;
|
|
|
|
apps: OauthAppResponse[];
|
|
|
|
fetchAvailableApps: () => Promise<void>;
|
|
|
|
deleteApp: (clientId: string) => Promise<void>;
|
|
|
|
resetApp: (clientId: string, resetClientSecret: boolean) => Promise<void>;
|
2019-12-07 13:28:52 +02:00
|
|
|
}
|
2019-01-24 02:34:02 +03:00
|
|
|
|
2019-06-30 16:32:50 +03:00
|
|
|
type State = {
|
2020-05-24 02:08:24 +03:00
|
|
|
isLoading: boolean;
|
|
|
|
forceUpdate: boolean;
|
2019-11-27 11:03:32 +02:00
|
|
|
};
|
2019-01-24 02:34:02 +03:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
class ApplicationsListPage extends React.Component<Props, State> {
|
2020-05-24 02:08:24 +03:00
|
|
|
state = {
|
|
|
|
isLoading: false,
|
|
|
|
forceUpdate: false,
|
|
|
|
};
|
2018-03-25 22:16:45 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
componentDidMount() {
|
|
|
|
!this.props.user.isGuest && this.loadApplicationsList();
|
|
|
|
}
|
2018-03-25 22:16:45 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
componentDidUpdate({ user }: Props) {
|
|
|
|
if (this.props.user !== user) {
|
|
|
|
// eslint-disable-next-line react/no-did-update-set-state
|
|
|
|
this.setState({ forceUpdate: true });
|
|
|
|
this.loadApplicationsList();
|
|
|
|
}
|
2019-01-24 02:34:02 +03:00
|
|
|
}
|
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
render() {
|
|
|
|
const { user, apps, resetApp, deleteApp, location } = this.props;
|
|
|
|
const { isLoading, forceUpdate } = this.state;
|
|
|
|
const clientId = location.hash.substr(1) || null;
|
2018-03-25 22:16:45 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
return (
|
|
|
|
<ApplicationsIndex
|
|
|
|
displayForGuest={user.isGuest}
|
|
|
|
applications={forceUpdate ? [] : apps}
|
|
|
|
isLoading={isLoading}
|
|
|
|
deleteApp={deleteApp}
|
|
|
|
resetApp={resetApp}
|
|
|
|
clientId={clientId}
|
|
|
|
resetClientId={this.resetClientId}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
2018-03-25 22:16:45 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
loadApplicationsList = async () => {
|
|
|
|
this.setState({ isLoading: true });
|
|
|
|
await this.props.fetchAvailableApps();
|
|
|
|
this.setState({
|
|
|
|
isLoading: false,
|
|
|
|
forceUpdate: false,
|
|
|
|
});
|
|
|
|
};
|
2018-11-04 08:22:04 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
resetClientId = () => {
|
|
|
|
const { history, location } = this.props;
|
2018-11-04 08:22:04 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
if (location.hash) {
|
|
|
|
history.push({ ...location, hash: '' });
|
|
|
|
}
|
|
|
|
};
|
2018-03-25 22:16:45 +03:00
|
|
|
}
|
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
export default connect(
|
2020-07-22 13:01:12 +03:00
|
|
|
(state) => ({
|
2020-05-24 02:08:24 +03:00
|
|
|
user: state.user,
|
|
|
|
apps: state.apps.available,
|
|
|
|
}),
|
|
|
|
{
|
|
|
|
fetchAvailableApps,
|
|
|
|
resetApp,
|
|
|
|
deleteApp,
|
|
|
|
},
|
2019-11-27 11:03:32 +02:00
|
|
|
)(ApplicationsListPage);
|