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

69 lines
1.7 KiB
TypeScript
Raw Normal View History

import React, { Component } from 'react';
import { FormModel } from 'app/components/ui/form';
import ApplicationForm from 'app/components/dev/apps/applicationForm/ApplicationForm';
import oauth from 'app/services/api/oauth';
import { browserHistory } from 'app/services/history';
import { OauthAppResponse } from 'app/services/api/oauth';
import { ApplicationType } from 'app/components/dev/apps';
const app: OauthAppResponse = {
2020-05-24 02:08:24 +03:00
clientId: '',
clientSecret: '',
countUsers: 0,
createdAt: 0,
type: 'application',
name: '',
description: '',
websiteUrl: '',
redirectUri: '',
minecraftServerIp: '',
};
2019-12-07 13:28:52 +02:00
interface State {
2020-05-24 02:08:24 +03:00
type: ApplicationType | null;
2019-12-07 13:28:52 +02:00
}
export default class CreateNewApplicationPage extends Component<{}, State> {
2020-05-24 02:08:24 +03:00
state: State = {
type: null,
};
2020-05-24 02:08:24 +03:00
form: FormModel = new FormModel();
2020-05-24 02:08:24 +03:00
render() {
return (
<ApplicationForm
form={this.form}
displayTypeSwitcher
onSubmit={this.onSubmit}
type={this.state.type}
setType={this.setType}
app={app}
/>
);
}
2020-05-24 02:08:24 +03:00
onSubmit = async () => {
const { form } = this;
const { type } = this.state;
2018-05-05 12:01:25 +03:00
2020-05-24 02:08:24 +03:00
if (!type) {
throw new Error('Form was submitted without specified type');
}
2020-05-24 02:08:24 +03:00
form.beginLoading();
const result = await oauth.create(type, form.serialize());
form.endLoading();
2020-05-24 02:08:24 +03:00
this.goToMainPage(result.data.clientId);
};
2020-05-24 02:08:24 +03:00
setType = (type: ApplicationType) => {
this.setState({
type,
});
};
2020-05-24 02:08:24 +03:00
goToMainPage = (hash?: string) => browserHistory.push(`/dev/applications${hash ? `#${hash}` : ''}`);
}