import { None } from "@sniptt/monads"; import { Component, linkEvent } from "inferno"; import { T } from "inferno-i18next-dess"; import { CommentReportView, CommentView, ResolveCommentReport, SubscribedType, } from "lemmy-js-client"; import { i18n } from "../../i18next"; import { CommentNode as CommentNodeI } from "../../interfaces"; import { WebSocketService } from "../../services"; import { auth, wsClient } from "../../utils"; import { Icon } from "../common/icon"; import { PersonListing } from "../person/person-listing"; import { CommentNode } from "./comment-node"; interface CommentReportProps { report: CommentReportView; } export class CommentReport extends Component { constructor(props: any, context: any) { super(props, context); } render() { let r = this.props.report; let comment = r.comment; let tippyContent = i18n.t( r.comment_report.resolved ? "unresolve_report" : "resolve_report" ); // Set the original post data ( a troll could change it ) comment.content = r.comment_report.original_comment_text; let comment_view: CommentView = { comment, creator: r.comment_creator, post: r.post, community: r.community, creator_banned_from_community: r.creator_banned_from_community, counts: r.counts, subscribed: SubscribedType.NotSubscribed, saved: false, creator_blocked: false, recipient: None, my_vote: r.my_vote, }; let node: CommentNodeI = { comment_view, }; return (
{i18n.t("reporter")}:
{i18n.t("reason")}: {r.comment_report.reason}
{r.resolver.match({ some: resolver => (
{r.comment_report.resolved ? ( # ) : ( # )}
), none: <>, })}
); } handleResolveReport(i: CommentReport) { let form = new ResolveCommentReport({ report_id: i.props.report.comment_report.id, resolved: !i.props.report.comment_report.resolved, auth: auth().unwrap(), }); WebSocketService.Instance.send(wsClient.resolveCommentReport(form)); } }