1 import { Component, linkEvent } from "inferno";
2 import { T } from "inferno-i18next-dess";
7 } from "lemmy-js-client";
8 import { i18n } from "../../i18next";
9 import { CommentNode as CommentNodeI } from "../../interfaces";
10 import { WebSocketService } from "../../services";
11 import { authField, wsClient } from "../../utils";
12 import { Icon } from "../common/icon";
13 import { PersonListing } from "../person/person-listing";
14 import { CommentNode } from "./comment-node";
16 interface CommentReportProps {
17 report: CommentReportView;
20 export class CommentReport extends Component<CommentReportProps, any> {
21 constructor(props: any, context: any) {
22 super(props, context);
26 let r = this.props.report;
27 let comment = r.comment;
29 // Set the original post data ( a troll could change it )
30 comment.content = r.comment_report.original_comment_text;
32 let comment_view: CommentView = {
34 creator: r.comment_creator,
36 community: r.community,
37 creator_banned_from_community: r.creator_banned_from_community,
41 creator_blocked: false,
45 let node: CommentNodeI = {
55 enableDownvotes={true}
58 {i18n.t("reporter")}: <PersonListing person={r.creator} />
61 {i18n.t("reason")}: {r.comment_report.reason}
65 {r.comment_report.resolved ? (
66 <T i18nKey="resolved_by">
68 <PersonListing person={r.resolver} />
71 <T i18nKey="unresolved_by">
73 <PersonListing person={r.resolver} />
79 className="btn btn-link btn-animate text-muted py-0"
80 onClick={linkEvent(this, this.handleResolveReport)}
82 r.comment_report.resolved ? "unresolve_report" : "resolve_report"
85 r.comment_report.resolved ? "unresolve_report" : "resolve_report"
90 classes={`icon-inline ${
91 r.comment_report.resolved ? "text-success" : "text-danger"
99 handleResolveReport(i: CommentReport) {
100 let form: ResolveCommentReport = {
101 report_id: i.props.report.comment_report.id,
102 resolved: !i.props.report.comment_report.resolved,
105 WebSocketService.Instance.send(wsClient.resolveCommentReport(form));