diff --git a/package.json b/package.json index 4e5a462..df91173 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "frontend", - "version": "5.2.3", + "version": "5.3.1", "description": "React frontend for the Cards 110", "author": "Daithi Hearn", "license": "MIT", diff --git a/public/manifest.json b/public/manifest.json index b89281a..d887752 100644 --- a/public/manifest.json +++ b/public/manifest.json @@ -1,7 +1,7 @@ { "short_name": "Cards 110", "name": "Cards 110", - "version": "5.2.3", + "version": "5.3.1", "icons": [ { "src": "./assets/favicon.png", @@ -13,4 +13,4 @@ "display": "standalone", "theme_color": "#000000", "background_color": "#ffffff" -} \ No newline at end of file +} diff --git a/src/caches/MyProfileSlice.ts b/src/caches/MyProfileSlice.ts index caf022c..a38e48f 100644 --- a/src/caches/MyProfileSlice.ts +++ b/src/caches/MyProfileSlice.ts @@ -9,6 +9,7 @@ const initialProfileState: MyProfile = { "", isPlayer: false, isAdmin: false, + lastAccess: "1970-01-01T00:00:00", } export const myProfileSlice = createSlice({ diff --git a/src/components/GameStats/PlayerSwitcher.tsx b/src/components/GameStats/PlayerSwitcher.tsx index 9e642b3..df34435 100644 --- a/src/components/GameStats/PlayerSwitcher.tsx +++ b/src/components/GameStats/PlayerSwitcher.tsx @@ -1,5 +1,5 @@ import { useSnackbar } from "notistack" -import { useCallback, useEffect, useState } from "react" +import { useCallback, useEffect, useMemo, useState } from "react" import { Dropdown, DropdownItem, @@ -25,10 +25,21 @@ const PlayerSwitcher: React.FC = () => { [showDropdown], ) + const sortedPlayers = useMemo( + () => + [...players].sort((a, b) => { + const aDate = new Date(a.lastAccess) + const bDate = new Date(b.lastAccess) + if (aDate === bDate) return 0 + return aDate > bDate ? -1 : 1 + }), + [players], + ) + useEffect(() => { const me = players.find(p => p.id === myProfile.id) if (me) setCurrentPlayer(me) - }, [players, myProfile]) + }, [sortedPlayers, myProfile]) useEffect(() => { if (currentPlayer) @@ -54,7 +65,7 @@ const PlayerSwitcher: React.FC = () => { - {players.map(p => { + {sortedPlayers.map(p => { return ( { const dispatch = useAppDispatch() @@ -95,6 +96,14 @@ const StartNewGame = () => { selector: row => row.name, sortable: true, }, + { + name: "Last Access", + id: "lastAccess", + selector: row => row.lastAccess, + format: row => moment(row.lastAccess).format("lll"), + sortable: true, + omit: true, + }, ] return ( @@ -140,6 +149,8 @@ const StartNewGame = () => { selectableRows customStyles={customStyles} onSelectedRowsChange={togglePlayer} + defaultSortFieldId="lastAccess" + defaultSortAsc={false} /> diff --git a/src/model/Player.ts b/src/model/Player.ts index 6b58050..19bc629 100644 --- a/src/model/Player.ts +++ b/src/model/Player.ts @@ -16,6 +16,7 @@ export interface PlayerProfile { id: string name: string picture: string + lastAccess: string } export interface Team extends Scorable { diff --git a/src/services/ProfileService.ts b/src/services/ProfileService.ts index a1de929..e8b0210 100644 --- a/src/services/ProfileService.ts +++ b/src/services/ProfileService.ts @@ -25,6 +25,7 @@ interface ProfileResponse { name: string picture: string pictureLocked: boolean + lastAccess: string } interface JWTToken { @@ -56,6 +57,7 @@ const updateProfile = isAdmin: decodedAccessToken.permissions.indexOf("read:admin") !== -1, accessToken: token, + lastAccess: response.data.lastAccess, }), ) }