Headless CMS and Content Managment Hub
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

95 lines
3.2 KiB

/*
* Squidex Headless CMS
*
* @license
* Copyright (c) Squidex UG (haftungsbeschränkt). All rights reserved.
*/
import { ChangeDetectorRef, Component, ElementRef, Input, OnChanges, QueryList, ViewChild, ViewChildren } from '@angular/core';
import { FormBuilder } from '@angular/forms';
import { Router } from '@angular/router';
import { AppsState, AuthService, CommentDto, CommentsService, CommentsState, ContributorsState, DialogService, ResourceOwner, UpsertCommentForm } from '@app/shared/internal';
import { MentionConfig } from 'angular-mentions';
import { timer } from 'rxjs';
import { onErrorResumeNext, switchMap } from 'rxjs/operators';
import { CommentComponent } from './comment.component';
@Component({
selector: 'sqx-comments',
styleUrls: ['./comments.component.scss'],
templateUrl: './comments.component.html',
})
export class CommentsComponent extends ResourceOwner implements OnChanges {
@ViewChild('commentsList', { static: false })
public commentsList: ElementRef<HTMLDivElement>;
@ViewChildren(CommentComponent)
public children: QueryList<CommentComponent>;
@Input()
public commentsId: string;
public commentsUrl: string;
public commentsState: CommentsState;
public commentForm = new UpsertCommentForm(this.formBuilder);
public mentionUsers = this.contributorsState.contributors;
public mentionConfig: MentionConfig = { dropUp: true, labelKey: 'contributorEmail' };
public userToken: string;
constructor(authService: AuthService,
private readonly appsState: AppsState,
private readonly commentsService: CommentsService,
private readonly contributorsState: ContributorsState,
private readonly changeDetector: ChangeDetectorRef,
private readonly dialogs: DialogService,
private readonly formBuilder: FormBuilder,
private readonly router: Router,
) {
super();
this.userToken = authService.user!.token;
}
public ngOnChanges() {
this.contributorsState.load();
this.commentsUrl = `apps/${this.appsState.appName}/comments/${this.commentsId}`;
this.commentsState = new CommentsState(this.commentsUrl, this.commentsService, this.dialogs);
this.own(timer(0, 4000).pipe(switchMap(() => this.commentsState.load(true).pipe(onErrorResumeNext()))));
}
public scrollDown() {
if (this.commentsList && this.commentsList.nativeElement) {
let isEditing = false;
this.children.forEach(x => {
isEditing = isEditing || x.snapshot.isEditing;
});
if (!isEditing) {
const height = this.commentsList.nativeElement.scrollHeight;
this.commentsList.nativeElement.scrollTop = height;
}
}
}
public comment() {
const value = this.commentForm.submit();
if (value && value.text && value.text.length > 0) {
this.commentsState.create(value.text, this.router.url);
this.changeDetector.detectChanges();
}
this.commentForm.submitCompleted();
}
public trackByComment(_index: number, comment: CommentDto) {
return comment.id;
}
}