1 import { Component, linkEvent } from "inferno";
2 import { PersonView, Site, SiteAggregates } from "lemmy-js-client";
3 import { i18n } from "../../i18next";
4 import { mdToHtml } from "../../utils";
5 import { Badges } from "../common/badges";
6 import { BannerIconHeader } from "../common/banner-icon-header";
7 import { Icon } from "../common/icon";
8 import { PersonListing } from "../person/person-listing";
10 interface SiteSidebarProps {
13 counts?: SiteAggregates;
14 admins?: PersonView[];
17 interface SiteSidebarState {
21 export class SiteSidebar extends Component<SiteSidebarProps, SiteSidebarState> {
22 state: SiteSidebarState = {
26 constructor(props: any, context: any) {
27 super(props, context);
32 <section id="sidebarInfo" className="card border-secondary mb-3">
33 <div className="card-body">
35 <div className="mb-2">{this.siteName()}</div>
36 {!this.state.collapsed && (
38 <BannerIconHeader banner={this.props.site.banner} />
50 <h5 className="mb-0 d-inline">
51 {this.props.site.name}
53 className="btn btn-sm text-muted"
54 onClick={linkEvent(this, this.handleCollapseSidebar)}
55 aria-label={i18n.t("collapse")}
56 data-tippy-content={i18n.t("collapse")}
58 {this.state.collapsed ? (
59 <Icon icon="plus-square" classes="icon-inline" />
61 <Icon icon="minus-square" classes="icon-inline" />
69 const site = this.props.site;
72 {site.description && <h6>{site.description}</h6>}
73 {site.sidebar && this.siteSidebar(site.sidebar)}
74 {this.props.counts && <Badges counts={this.props.counts} />}
75 {this.props.admins && this.admins(this.props.admins)}
80 siteSidebar(sidebar: string) {
82 <div className="md-div" dangerouslySetInnerHTML={mdToHtml(sidebar)} />
86 admins(admins: PersonView[]) {
88 <ul className="mt-1 list-inline small mb-0">
89 <li className="list-inline-item">{i18n.t("admins")}:</li>
91 <li key={av.person.id} className="list-inline-item">
92 <PersonListing person={av.person} />
99 handleCollapseSidebar(i: SiteSidebar) {
100 i.setState({ collapsed: !i.state.collapsed });