mirror of
https://github.com/LemmyNet/lemmy-ui.git
synced 2025-01-10 20:15:50 +00:00
Add logic to filter view for denied registration applications (#2322)
* Add logic to filter view for denied registrations * Adjust filter criteria
This commit is contained in:
parent
b3d667edb4
commit
909e3e0fa8
1 changed files with 39 additions and 17 deletions
|
@ -28,9 +28,10 @@ import { RegistrationApplication } from "../common/registration-application";
|
||||||
import { UnreadCounterService } from "../../services";
|
import { UnreadCounterService } from "../../services";
|
||||||
import { getHttpBaseInternal } from "../../utils/env";
|
import { getHttpBaseInternal } from "../../utils/env";
|
||||||
|
|
||||||
enum UnreadOrAll {
|
enum RegistrationState {
|
||||||
Unread,
|
Unread,
|
||||||
All,
|
All,
|
||||||
|
Denied,
|
||||||
}
|
}
|
||||||
|
|
||||||
type RegistrationApplicationsData = RouteDataResponse<{
|
type RegistrationApplicationsData = RouteDataResponse<{
|
||||||
|
@ -40,7 +41,7 @@ type RegistrationApplicationsData = RouteDataResponse<{
|
||||||
interface RegistrationApplicationsState {
|
interface RegistrationApplicationsState {
|
||||||
appsRes: RequestState<ListRegistrationApplicationsResponse>;
|
appsRes: RequestState<ListRegistrationApplicationsResponse>;
|
||||||
siteRes: GetSiteResponse;
|
siteRes: GetSiteResponse;
|
||||||
unreadOrAll: UnreadOrAll;
|
registrationState: RegistrationState;
|
||||||
page: number;
|
page: number;
|
||||||
isIsomorphic: boolean;
|
isIsomorphic: boolean;
|
||||||
}
|
}
|
||||||
|
@ -53,7 +54,7 @@ export class RegistrationApplications extends Component<
|
||||||
state: RegistrationApplicationsState = {
|
state: RegistrationApplicationsState = {
|
||||||
appsRes: EMPTY_REQUEST,
|
appsRes: EMPTY_REQUEST,
|
||||||
siteRes: this.isoData.site_res,
|
siteRes: this.isoData.site_res,
|
||||||
unreadOrAll: UnreadOrAll.Unread,
|
registrationState: RegistrationState.Unread,
|
||||||
page: 1,
|
page: 1,
|
||||||
isIsomorphic: false,
|
isIsomorphic: false,
|
||||||
};
|
};
|
||||||
|
@ -132,7 +133,7 @@ export class RegistrationApplications extends Component<
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
unreadOrAllRadios() {
|
RegistrationStateRadios() {
|
||||||
const radioId = randomStr();
|
const radioId = randomStr();
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
@ -141,14 +142,14 @@ export class RegistrationApplications extends Component<
|
||||||
id={`${radioId}-unread`}
|
id={`${radioId}-unread`}
|
||||||
type="radio"
|
type="radio"
|
||||||
className="btn-check"
|
className="btn-check"
|
||||||
value={UnreadOrAll.Unread}
|
value={RegistrationState.Unread}
|
||||||
checked={this.state.unreadOrAll === UnreadOrAll.Unread}
|
checked={this.state.registrationState === RegistrationState.Unread}
|
||||||
onChange={linkEvent(this, this.handleUnreadOrAllChange)}
|
onChange={linkEvent(this, this.handleRegistrationStateChange)}
|
||||||
/>
|
/>
|
||||||
<label
|
<label
|
||||||
htmlFor={`${radioId}-unread`}
|
htmlFor={`${radioId}-unread`}
|
||||||
className={classNames("btn btn-outline-secondary pointer", {
|
className={classNames("btn btn-outline-secondary pointer", {
|
||||||
active: this.state.unreadOrAll === UnreadOrAll.Unread,
|
active: this.state.registrationState === RegistrationState.Unread,
|
||||||
})}
|
})}
|
||||||
>
|
>
|
||||||
{I18NextService.i18n.t("unread")}
|
{I18NextService.i18n.t("unread")}
|
||||||
|
@ -158,18 +159,35 @@ export class RegistrationApplications extends Component<
|
||||||
id={`${radioId}-all`}
|
id={`${radioId}-all`}
|
||||||
type="radio"
|
type="radio"
|
||||||
className="btn-check"
|
className="btn-check"
|
||||||
value={UnreadOrAll.All}
|
value={RegistrationState.All}
|
||||||
checked={this.state.unreadOrAll === UnreadOrAll.All}
|
checked={this.state.registrationState === RegistrationState.All}
|
||||||
onChange={linkEvent(this, this.handleUnreadOrAllChange)}
|
onChange={linkEvent(this, this.handleRegistrationStateChange)}
|
||||||
/>
|
/>
|
||||||
<label
|
<label
|
||||||
htmlFor={`${radioId}-all`}
|
htmlFor={`${radioId}-all`}
|
||||||
className={classNames("btn btn-outline-secondary pointer", {
|
className={classNames("btn btn-outline-secondary pointer", {
|
||||||
active: this.state.unreadOrAll === UnreadOrAll.All,
|
active: this.state.registrationState === RegistrationState.All,
|
||||||
})}
|
})}
|
||||||
>
|
>
|
||||||
{I18NextService.i18n.t("all")}
|
{I18NextService.i18n.t("all")}
|
||||||
</label>
|
</label>
|
||||||
|
|
||||||
|
<input
|
||||||
|
id={`${radioId}-denied`}
|
||||||
|
type="radio"
|
||||||
|
className="btn-check"
|
||||||
|
value={RegistrationState.Denied}
|
||||||
|
checked={this.state.registrationState === RegistrationState.Denied}
|
||||||
|
onChange={linkEvent(this, this.handleRegistrationStateChange)}
|
||||||
|
/>
|
||||||
|
<label
|
||||||
|
htmlFor={`${radioId}-denied`}
|
||||||
|
className={classNames("btn btn-outline-secondary pointer", {
|
||||||
|
active: this.state.registrationState === RegistrationState.Denied,
|
||||||
|
})}
|
||||||
|
>
|
||||||
|
{I18NextService.i18n.t("denied")}
|
||||||
|
</label>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -177,12 +195,15 @@ export class RegistrationApplications extends Component<
|
||||||
selects() {
|
selects() {
|
||||||
return (
|
return (
|
||||||
<div className="mb-2">
|
<div className="mb-2">
|
||||||
<span className="me-3">{this.unreadOrAllRadios()}</span>
|
<span className="me-3">{this.RegistrationStateRadios()}</span>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
applicationList(apps: RegistrationApplicationView[]) {
|
applicationList(apps: RegistrationApplicationView[]) {
|
||||||
|
if (this.state.registrationState === RegistrationState.Denied) {
|
||||||
|
apps = apps.filter(ra => !ra.creator_local_user.accepted_application);
|
||||||
|
}
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
{apps.map(ra => (
|
{apps.map(ra => (
|
||||||
|
@ -199,8 +220,8 @@ export class RegistrationApplications extends Component<
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
handleUnreadOrAllChange(i: RegistrationApplications, event: any) {
|
handleRegistrationStateChange(i: RegistrationApplications, event: any) {
|
||||||
i.setState({ unreadOrAll: Number(event.target.value), page: 1 });
|
i.setState({ registrationState: Number(event.target.value), page: 1 });
|
||||||
i.refetch();
|
i.refetch();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -227,7 +248,8 @@ export class RegistrationApplications extends Component<
|
||||||
}
|
}
|
||||||
|
|
||||||
async refetch() {
|
async refetch() {
|
||||||
const unread_only = this.state.unreadOrAll === UnreadOrAll.Unread;
|
const unread_only =
|
||||||
|
this.state.registrationState === RegistrationState.Unread;
|
||||||
this.setState({
|
this.setState({
|
||||||
appsRes: LOADING_REQUEST,
|
appsRes: LOADING_REQUEST,
|
||||||
});
|
});
|
||||||
|
@ -249,7 +271,7 @@ export class RegistrationApplications extends Component<
|
||||||
approveRes.data.registration_application,
|
approveRes.data.registration_application,
|
||||||
s.appsRes.data.registration_applications,
|
s.appsRes.data.registration_applications,
|
||||||
);
|
);
|
||||||
if (this.state.unreadOrAll === UnreadOrAll.Unread) {
|
if (this.state.registrationState === RegistrationState.Unread) {
|
||||||
this.refetch();
|
this.refetch();
|
||||||
UnreadCounterService.Instance.updateApplications();
|
UnreadCounterService.Instance.updateApplications();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue