From 4ed3bd24a9eed53689243c126ef70620a3895c06 Mon Sep 17 00:00:00 2001 From: marcelhillesheim Date: Wed, 4 Dec 2024 23:12:26 +0100 Subject: [PATCH 1/3] UI: added auto completion for add vip and add console admin --- .../form/custom/PlayerAutocompletion.jsx | 87 +++++++++++++++++++ .../pages/settings/console-admins/index.jsx | 10 +-- rcongui/src/pages/settings/vip/index.jsx | 10 +-- 3 files changed, 91 insertions(+), 16 deletions(-) create mode 100644 rcongui/src/components/form/custom/PlayerAutocompletion.jsx diff --git a/rcongui/src/components/form/custom/PlayerAutocompletion.jsx b/rcongui/src/components/form/custom/PlayerAutocompletion.jsx new file mode 100644 index 000000000..eace3f3b2 --- /dev/null +++ b/rcongui/src/components/form/custom/PlayerAutocompletion.jsx @@ -0,0 +1,87 @@ +import React, {useEffect, useMemo, useRef} from "react"; +import {debounce} from "lodash"; +import {handle_http_errors, postData, showResponse} from "@/utils/fetchUtils"; +import Autocomplete from "@mui/material/Autocomplete"; +import Typography from "@mui/material/Typography"; +import {Avatar, Box} from "@mui/material"; +import TextField from "@mui/material/TextField"; + +export default function PlayerAutocompletion({state, setState}) { + + const [suggestions, setSuggestions] = React.useState([]); + + const nameRef = useRef(state.name); + + useEffect(() => { + debouncedFetchSuggestions(); + nameRef.current = state.name; + }, [state.name]); + + const fetchSuggestions = () => { + setSuggestions([]); + + if (!nameRef.current) { + return; + } + + const params = {page_size: 15, + page: 1, + player_name: nameRef.current, + exact_name_match: false, + ignore_accent: true, + }; + postData( + `${process.env.REACT_APP_API_URL}get_players_history`, + params + ) + .then((response) => showResponse(response, "get_players_history")) + .then((data) => { + if (data.failed) { + return; + } + setSuggestions(data.result.players); + }) + .catch(handle_http_errors); + }; + + const debouncedFetchSuggestions = useMemo( + () => debounce(fetchSuggestions, 300), + [] + ); + + return options} + onChange={(event, value, reason) => { + setState(prev => ({...prev, + name: value?.names[0]?.name ?? '', + player_id: value?.player_id ?? prev.player_id, + })); + }} + getOptionLabel={(option) => option.names[0]?.name} + renderOption={(props, option) => { + return + + {option.names[0]?.name[0].toUpperCase()} + + {option.names[0]?.name} + + } + } + inputValue={state.name} + onInputChange={(event, value) => setState(prev => ({...prev, name: value}))} + renderInput={(params) => + } + /> +}; diff --git a/rcongui/src/pages/settings/console-admins/index.jsx b/rcongui/src/pages/settings/console-admins/index.jsx index f13e1650c..679c3f94b 100644 --- a/rcongui/src/pages/settings/console-admins/index.jsx +++ b/rcongui/src/pages/settings/console-admins/index.jsx @@ -28,6 +28,7 @@ import debounce from "lodash/debounce"; import { InputFileUpload } from "@/components/shared/InputFileUpload"; import exportFile from "@/utils/exportFile"; import { usePlayerSidebar } from "@/hooks/usePlayerSidebar"; +import PlayerAutocompletion from "@/components/form/custom/PlayerAutocompletion"; const INTENT = { ADD_ADMIN: "add_admin", @@ -274,14 +275,7 @@ const ConsoleAdminsPage = () => { }} > - + { }} > - + Date: Sun, 15 Dec 2024 13:22:59 +0100 Subject: [PATCH 2/3] UI: console admin default role --- rcongui/src/pages/settings/console-admins/index.jsx | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/rcongui/src/pages/settings/console-admins/index.jsx b/rcongui/src/pages/settings/console-admins/index.jsx index 679c3f94b..6f42645b6 100644 --- a/rcongui/src/pages/settings/console-admins/index.jsx +++ b/rcongui/src/pages/settings/console-admins/index.jsx @@ -66,14 +66,15 @@ export const action = async ({ request }) => { return results; }; -const initialAdmin = { - player_id: "", - name: "", - role: "", -}; - const ConsoleAdminsPage = () => { const { admins: serverAdmins, adminGroups } = useLoaderData(); + + const initialAdmin = { + player_id: "", + name: "", + role: adminGroups.includes("spectator") ? "spectator" : "", + }; + const [admins, setAdmins] = useState(serverAdmins); const [checked, setChecked] = useState(new Set()); const [searched, setSearched] = useState(""); From 3c786ae328b193b712a97e9766cc140d525236b7 Mon Sep 17 00:00:00 2001 From: marcelhillesheim Date: Mon, 16 Dec 2024 13:11:15 +0100 Subject: [PATCH 3/3] UI: MR-Issue: updated prop name --- .../form/custom/PlayerAutocompletion.jsx | 20 +++++++++---------- .../pages/settings/console-admins/index.jsx | 2 +- rcongui/src/pages/settings/vip/index.jsx | 2 +- 3 files changed, 12 insertions(+), 12 deletions(-) diff --git a/rcongui/src/components/form/custom/PlayerAutocompletion.jsx b/rcongui/src/components/form/custom/PlayerAutocompletion.jsx index eace3f3b2..5e781176a 100644 --- a/rcongui/src/components/form/custom/PlayerAutocompletion.jsx +++ b/rcongui/src/components/form/custom/PlayerAutocompletion.jsx @@ -1,4 +1,4 @@ -import React, {useEffect, useMemo, useRef} from "react"; +import React, {useEffect, useMemo, useRef, useState} from "react"; import {debounce} from "lodash"; import {handle_http_errors, postData, showResponse} from "@/utils/fetchUtils"; import Autocomplete from "@mui/material/Autocomplete"; @@ -6,16 +6,16 @@ import Typography from "@mui/material/Typography"; import {Avatar, Box} from "@mui/material"; import TextField from "@mui/material/TextField"; -export default function PlayerAutocompletion({state, setState}) { +export default function PlayerAutocompletion({player, setPlayer}) { - const [suggestions, setSuggestions] = React.useState([]); + const [suggestions, setSuggestions] = useState([]); - const nameRef = useRef(state.name); + const nameRef = useRef(player.name); useEffect(() => { debouncedFetchSuggestions(); - nameRef.current = state.name; - }, [state.name]); + nameRef.current = player.name; + }, [player.name]); const fetchSuggestions = () => { setSuggestions([]); @@ -56,7 +56,7 @@ export default function PlayerAutocompletion({state, setState}) { options={suggestions} filterOptions={(options) => options} onChange={(event, value, reason) => { - setState(prev => ({...prev, + setPlayer(prev => ({...prev, name: value?.names[0]?.name ?? '', player_id: value?.player_id ?? prev.player_id, })); @@ -74,12 +74,12 @@ export default function PlayerAutocompletion({state, setState}) { } } - inputValue={state.name} - onInputChange={(event, value) => setState(prev => ({...prev, name: value}))} + inputValue={player.name} + onInputChange={(event, value) => setPlayer(prev => ({...prev, name: value}))} renderInput={(params) => } diff --git a/rcongui/src/pages/settings/console-admins/index.jsx b/rcongui/src/pages/settings/console-admins/index.jsx index 6f42645b6..0b12001d7 100644 --- a/rcongui/src/pages/settings/console-admins/index.jsx +++ b/rcongui/src/pages/settings/console-admins/index.jsx @@ -276,7 +276,7 @@ const ConsoleAdminsPage = () => { }} > - + { }} > - +