From cd4e0ab3c2cfd615e4771fb9181a31ce237b5ceb Mon Sep 17 00:00:00 2001 From: Dessalines Date: Wed, 8 Jul 2020 01:02:14 -0400 Subject: HTML title bugs. - Fixing HTML titles for some pages. Fixes #801 - Removing WebSocketService.Instance.site, fetching site on demand now. --- ui/src/components/create-community.tsx | 56 +++++++++++++++++++++++++++++----- 1 file changed, 49 insertions(+), 7 deletions(-) (limited to 'ui/src/components/create-community.tsx') diff --git a/ui/src/components/create-community.tsx b/ui/src/components/create-community.tsx index 5c7a0a9b..86929894 100644 --- a/ui/src/components/create-community.tsx +++ b/ui/src/components/create-community.tsx @@ -1,19 +1,44 @@ import { Component } from 'inferno'; +import { Subscription } from 'rxjs'; +import { retryWhen, delay, take } from 'rxjs/operators'; import { CommunityForm } from './community-form'; -import { Community } from '../interfaces'; +import { + Community, + UserOperation, + WebSocketJsonResponse, + GetSiteResponse, +} from '../interfaces'; +import { toast, wsJsonToRes } from '../utils'; import { WebSocketService } from '../services'; import { i18n } from '../i18next'; -export class CreateCommunity extends Component { +interface CreateCommunityState { + enableNsfw: boolean; +} + +export class CreateCommunity extends Component { + private subscription: Subscription; + private emptyState: CreateCommunityState = { + enableNsfw: null, + }; constructor(props: any, context: any) { super(props, context); this.handleCommunityCreate = this.handleCommunityCreate.bind(this); + this.state = this.emptyState; + + this.subscription = WebSocketService.Instance.subject + .pipe(retryWhen(errors => errors.pipe(delay(3000), take(10)))) + .subscribe( + msg => this.parseMessage(msg), + err => console.error(err), + () => console.log('complete') + ); + + WebSocketService.Instance.getSite(); } - componentDidMount() { - document.title = `${i18n.t('create_community')} - ${ - WebSocketService.Instance.site.name - }`; + componentWillUnmount() { + this.subscription.unsubscribe(); } render() { @@ -22,7 +47,10 @@ export class CreateCommunity extends Component {
{i18n.t('create_community')}
- +
@@ -32,4 +60,18 @@ export class CreateCommunity extends Component { handleCommunityCreate(community: Community) { this.props.history.push(`/c/${community.name}`); } + + parseMessage(msg: WebSocketJsonResponse) { + console.log(msg); + let res = wsJsonToRes(msg); + if (msg.error) { + toast(i18n.t(msg.error), 'danger'); + return; + } else if (res.op == UserOperation.GetSite) { + let data = res.data as GetSiteResponse; + this.state.enableNsfw = data.site.enable_nsfw; + this.setState(this.state); + document.title = `${i18n.t('create_community')} - ${data.site.name}`; + } + } } -- cgit v1.2.3 From 50e6d81d0b40e1d9caa0db83d20026adf3aef631 Mon Sep 17 00:00:00 2001 From: Dessalines Date: Thu, 9 Jul 2020 20:03:47 -0400 Subject: Redirect to login page for votes, comments, pages, etc. Fixes #849 (#926) --- ui/src/components/create-community.tsx | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) (limited to 'ui/src/components/create-community.tsx') diff --git a/ui/src/components/create-community.tsx b/ui/src/components/create-community.tsx index 86929894..3a5d943d 100644 --- a/ui/src/components/create-community.tsx +++ b/ui/src/components/create-community.tsx @@ -9,7 +9,7 @@ import { GetSiteResponse, } from '../interfaces'; import { toast, wsJsonToRes } from '../utils'; -import { WebSocketService } from '../services'; +import { WebSocketService, UserService } from '../services'; import { i18n } from '../i18next'; interface CreateCommunityState { @@ -26,6 +26,11 @@ export class CreateCommunity extends Component { this.handleCommunityCreate = this.handleCommunityCreate.bind(this); this.state = this.emptyState; + if (!UserService.Instance.user) { + toast(i18n.t('not_logged_in'), 'danger'); + this.context.router.history.push(`/login`); + } + this.subscription = WebSocketService.Instance.subject .pipe(retryWhen(errors => errors.pipe(delay(3000), take(10)))) .subscribe( -- cgit v1.2.3