2018-03-25 22:16:45 +03:00
|
|
|
import React, { Component } from 'react';
|
2019-12-07 21:02:00 +02:00
|
|
|
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';
|
2018-03-25 22:16:45 +03:00
|
|
|
|
|
|
|
const app: OauthAppResponse = {
|
2020-05-24 02:08:24 +03:00
|
|
|
clientId: '',
|
|
|
|
clientSecret: '',
|
|
|
|
countUsers: 0,
|
|
|
|
createdAt: 0,
|
|
|
|
type: 'application',
|
|
|
|
name: '',
|
|
|
|
description: '',
|
|
|
|
websiteUrl: '',
|
|
|
|
redirectUri: '',
|
|
|
|
minecraftServerIp: '',
|
2018-03-25 22:16:45 +03:00
|
|
|
};
|
|
|
|
|
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,
|
|
|
|
};
|
2018-03-25 22:16:45 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
form: FormModel = new FormModel();
|
2018-03-25 22:16:45 +03:00
|
|
|
|
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}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
2018-03-25 22:16:45 +03:00
|
|
|
|
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');
|
|
|
|
}
|
2018-03-25 22:16:45 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
form.beginLoading();
|
|
|
|
const result = await oauth.create(type, form.serialize());
|
|
|
|
form.endLoading();
|
2018-03-25 22:16:45 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
this.goToMainPage(result.data.clientId);
|
|
|
|
};
|
2018-03-25 22:16:45 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
setType = (type: ApplicationType) => {
|
|
|
|
this.setState({
|
|
|
|
type,
|
|
|
|
});
|
|
|
|
};
|
2018-03-25 22:16:45 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
goToMainPage = (hash?: string) => browserHistory.push(`/dev/applications${hash ? `#${hash}` : ''}`);
|
2018-03-25 22:16:45 +03:00
|
|
|
}
|