2018-03-25 22:16:45 +03:00
|
|
|
// @flow
|
2018-05-05 12:01:25 +03:00
|
|
|
import type { OauthAppResponse } from 'services/api/oauth';
|
2018-03-25 22:16:45 +03:00
|
|
|
import React, { Component } from 'react';
|
2018-05-05 12:01:25 +03:00
|
|
|
import { connect } from 'react-redux';
|
|
|
|
import logger from 'services/logger';
|
2018-03-25 22:16:45 +03:00
|
|
|
import { FormModel } from 'components/ui/form';
|
|
|
|
import { browserHistory } from 'services/history';
|
|
|
|
import oauth from 'services/api/oauth';
|
|
|
|
import loader from 'services/loader';
|
|
|
|
import PageNotFound from 'pages/404/PageNotFound';
|
2018-05-05 12:01:25 +03:00
|
|
|
import { getApp, fetchApp } from 'components/dev/apps/actions';
|
|
|
|
import ApplicationForm from 'components/dev/apps/applicationForm/ApplicationForm';
|
2018-03-25 22:16:45 +03:00
|
|
|
|
2019-06-30 16:32:50 +03:00
|
|
|
type OwnProps = {|
|
2018-03-25 22:16:45 +03:00
|
|
|
match: {
|
|
|
|
params: {
|
|
|
|
clientId: string,
|
|
|
|
},
|
|
|
|
},
|
2019-06-30 16:32:50 +03:00
|
|
|
|}
|
2018-03-25 22:16:45 +03:00
|
|
|
|
2019-06-30 16:32:50 +03:00
|
|
|
type Props = {
|
|
|
|
...OwnProps,
|
2018-03-25 22:16:45 +03:00
|
|
|
app: ?OauthAppResponse,
|
2018-05-05 12:01:25 +03:00
|
|
|
fetchApp: (string) => Promise<void>,
|
2019-06-30 16:32:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
class UpdateApplicationPage extends Component<Props, {
|
2018-03-25 22:16:45 +03:00
|
|
|
isNotFound: bool,
|
|
|
|
}> {
|
2018-05-05 12:01:25 +03:00
|
|
|
form: FormModel = new FormModel();
|
2018-03-25 22:16:45 +03:00
|
|
|
|
|
|
|
state = {
|
|
|
|
isNotFound: false,
|
|
|
|
};
|
|
|
|
|
2018-05-05 12:01:25 +03:00
|
|
|
componentDidMount() {
|
2018-03-25 22:16:45 +03:00
|
|
|
this.props.app === null && this.fetchApp();
|
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
|
|
|
const { app } = this.props;
|
2018-05-05 12:01:25 +03:00
|
|
|
|
2018-03-25 22:16:45 +03:00
|
|
|
if (this.state.isNotFound) {
|
|
|
|
return (
|
|
|
|
<PageNotFound />
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!app) {
|
2018-05-05 12:01:25 +03:00
|
|
|
// we are loading
|
|
|
|
return null;
|
2018-03-25 22:16:45 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<ApplicationForm
|
|
|
|
form={this.form}
|
|
|
|
onSubmit={this.onSubmit}
|
|
|
|
app={app}
|
|
|
|
type={app.type}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
async fetchApp() {
|
|
|
|
const { fetchApp, match } = this.props;
|
2018-05-05 12:01:25 +03:00
|
|
|
|
2018-03-25 22:16:45 +03:00
|
|
|
try {
|
|
|
|
loader.show();
|
|
|
|
await fetchApp(match.params.clientId);
|
|
|
|
} catch (resp) {
|
|
|
|
const { status } = resp.originalResponse;
|
2018-05-05 12:01:25 +03:00
|
|
|
|
2018-03-25 22:16:45 +03:00
|
|
|
if (status === 403) {
|
|
|
|
this.goToMainPage();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (status === 404) {
|
|
|
|
this.setState({
|
|
|
|
isNotFound: true,
|
|
|
|
});
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-05-05 12:01:25 +03:00
|
|
|
logger.unexpected('Error fetching app', resp);
|
2018-03-25 22:16:45 +03:00
|
|
|
} finally {
|
|
|
|
loader.hide();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
onSubmit = async () => {
|
|
|
|
const { form } = this;
|
|
|
|
const { app } = this.props;
|
2018-05-05 12:01:25 +03:00
|
|
|
|
2018-03-25 22:16:45 +03:00
|
|
|
if (!app || !app.clientId) {
|
|
|
|
throw new Error('Form has an invalid state');
|
|
|
|
}
|
|
|
|
|
|
|
|
form.beginLoading();
|
|
|
|
const result = await oauth.update(app.clientId, form.serialize());
|
|
|
|
form.endLoading();
|
|
|
|
|
|
|
|
this.goToMainPage(result.data.clientId);
|
|
|
|
};
|
|
|
|
|
|
|
|
goToMainPage = (hash?: string) => browserHistory.push(`/dev/applications${hash ? `#${hash}` : ''}`);
|
|
|
|
}
|
|
|
|
|
2019-06-30 16:32:50 +03:00
|
|
|
export default connect<Props, OwnProps, _, _, _, _>((state, props) => ({
|
2018-03-25 22:16:45 +03:00
|
|
|
app: getApp(state, props.match.params.clientId),
|
|
|
|
}), {
|
|
|
|
fetchApp,
|
|
|
|
})(UpdateApplicationPage);
|