1 import { Component, linkEvent } from "inferno";
2 import { SortType } from "lemmy-js-client";
3 import { i18n } from "../../i18next";
4 import { randomStr, relTags, sortingHelpUrl } from "../../utils";
5 import { Icon } from "./icon";
7 interface SortSelectProps {
9 onChange?(val: SortType): any;
11 hideMostComments?: boolean;
14 interface SortSelectState {
18 export class SortSelect extends Component<SortSelectProps, SortSelectState> {
19 private id = `sort-select-${randomStr()}`;
20 private emptyState: SortSelectState = {
21 sort: this.props.sort,
24 constructor(props: any, context: any) {
25 super(props, context);
26 this.state = this.emptyState;
29 static getDerivedStateFromProps(props: any): SortSelectState {
41 value={this.state.sort}
42 onChange={linkEvent(this, this.handleSortChange)}
43 className="custom-select w-auto mr-2 mb-2"
44 aria-label={i18n.t("sort_type")}
46 <option disabled aria-hidden="true">
49 {!this.props.hideHot && [
50 <option key={SortType.Hot} value={SortType.Hot}>
53 <option key={SortType.Active} value={SortType.Active}>
57 <option value={SortType.New}>{i18n.t("new")}</option>
58 <option value={SortType.Old}>{i18n.t("old")}</option>
59 {!this.props.hideMostComments && [
60 <option key={SortType.MostComments} value={SortType.MostComments}>
61 {i18n.t("most_comments")}
63 <option key={SortType.NewComments} value={SortType.NewComments}>
64 {i18n.t("new_comments")}
67 <option disabled aria-hidden="true">
70 <option value={SortType.TopDay}>{i18n.t("top_day")}</option>
71 <option value={SortType.TopWeek}>{i18n.t("top_week")}</option>
72 <option value={SortType.TopMonth}>{i18n.t("top_month")}</option>
73 <option value={SortType.TopYear}>{i18n.t("top_year")}</option>
74 <option value={SortType.TopAll}>{i18n.t("top_all")}</option>
77 className="text-muted"
80 title={i18n.t("sorting_help")}
82 <Icon icon="help-circle" classes="icon-inline" />
88 handleSortChange(i: SortSelect, event: any) {
89 i.props.onChange(event.target.value);