accounts-frontend/packages/app/pages/dev/ApplicationsListPage.tsx

88 lines
2.4 KiB
TypeScript
Raw Normal View History

2019-12-07 13:28:52 +02:00
import React from 'react';
import { RouteComponentProps } from 'react-router-dom';
import { connect } from 'react-redux';
2020-05-24 02:08:24 +03:00
import { fetchAvailableApps, resetApp, deleteApp } from 'app/components/dev/apps/actions';
import ApplicationsIndex from 'app/components/dev/apps/ApplicationsIndex';
import { User } from 'app/components/user';
import { OauthAppResponse } from 'app/services/api/oauth';
import { RootState } from 'app/reducers';
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
}
type State = {
2020-05-24 02:08:24 +03:00
isLoading: boolean;
forceUpdate: boolean;
};
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,
};
2020-05-24 02:08:24 +03:00
componentDidMount() {
!this.props.user.isGuest && this.loadApplicationsList();
}
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();
}
}
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;
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}
/>
);
}
2020-05-24 02:08:24 +03:00
loadApplicationsList = async () => {
this.setState({ isLoading: true });
await this.props.fetchAvailableApps();
this.setState({
isLoading: false,
forceUpdate: false,
});
};
2020-05-24 02:08:24 +03:00
resetClientId = () => {
const { history, location } = this.props;
2020-05-24 02:08:24 +03:00
if (location.hash) {
history.push({ ...location, hash: '' });
}
};
}
2019-12-07 13:28:52 +02:00
export default connect(
2020-05-24 02:08:24 +03:00
(state: RootState) => ({
user: state.user,
apps: state.apps.available,
}),
{
fetchAvailableApps,
resetApp,
deleteApp,
},
)(ApplicationsListPage);