1 import { Component, linkEvent } from "inferno";
2 import { CommentSortType } from "lemmy-js-client";
3 import { i18n } from "../../i18next";
4 import { randomStr, relTags, sortingHelpUrl } from "../../utils";
5 import { Icon } from "./icon";
7 interface CommentSortSelectProps {
9 onChange?(val: CommentSortType): any;
12 interface CommentSortSelectState {
13 sort: CommentSortType;
16 export class CommentSortSelect extends Component<
17 CommentSortSelectProps,
18 CommentSortSelectState
20 private id = `sort-select-${randomStr()}`;
21 private emptyState: CommentSortSelectState = {
22 sort: this.props.sort,
25 constructor(props: any, context: any) {
26 super(props, context);
27 this.state = this.emptyState;
30 static getDerivedStateFromProps(props: any): CommentSortSelectState {
42 value={this.state.sort}
43 onChange={linkEvent(this, this.handleSortChange)}
44 className="custom-select w-auto mr-2 mb-2"
45 aria-label={i18n.t("sort_type")}
47 <option disabled aria-hidden="true">
50 <option value={CommentSortType.Hot}>{i18n.t("hot")}</option>,
51 <option value={CommentSortType.Top}>{i18n.t("top")}</option>,
52 <option value={CommentSortType.New}>{i18n.t("new")}</option>
53 <option value={CommentSortType.Old}>{i18n.t("old")}</option>
56 className="text-muted"
59 title={i18n.t("sorting_help")}
61 <Icon icon="help-circle" classes="icon-inline" />
67 handleSortChange(i: CommentSortSelect, event: any) {
68 i.props.onChange(event.target.value);