Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Customizable Tables #401

Open
wants to merge 48 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 40 commits
Commits
Show all changes
48 commits
Select commit Hold shift + click to select a range
84a1244
Configurable Columns Prototype
Nov 26, 2021
83ed7e8
get Player Column
Nov 26, 2021
4bfd88a
Unified Column Configuration
Nov 29, 2021
4d73f00
Merge branch 'zengm-games:master' into master
Vac1911 Nov 29, 2021
53433f1
Better Column Labels
Nov 29, 2021
a6e6b26
Merge remote-tracking branch 'origin/master'
Nov 29, 2021
47c8f66
sortable columns prototype
Nov 30, 2021
cb81b1f
Merge branch 'zengm-games:master' into master
Vac1911 Dec 1, 2021
6b82538
Proper column sorting
Dec 1, 2021
bad4720
associative row data
Dec 1, 2021
ed233c7
Added Legacy Table Compatability
Dec 2, 2021
2217416
converted some legacy tables
Dec 2, 2021
4f61e53
updated more tables
Dec 3, 2021
5463199
converted tables
Dec 6, 2021
8d2fe2e
merge
Dec 6, 2021
9cffa89
merge
Dec 6, 2021
6f4226c
Fixed Boxscores
Dec 6, 2021
eee31cf
Converted All Remaining tables to legacy
Dec 6, 2021
c4a9295
fixed negotiate button bug and added options for stat rounding
Dec 7, 2021
9c940ab
player stats customizable by statType
Dec 7, 2021
07ff3b2
tested and linted
Dec 8, 2021
f323586
reverted development change
Dec 8, 2021
0bf1cae
Categorized Column Configuration
Dec 8, 2021
75ed206
Added support for challenge modes
Dec 8, 2021
e94bb92
bug fix
Dec 8, 2021
a1e151d
Increased Clickable Area In Columns Modal
Dec 8, 2021
dbcacde
playerBios separate config from playerRatings
Dec 8, 2021
770b0bd
refactored ColTemp interface
Dec 8, 2021
a6af182
updating attrs
Dec 8, 2021
4f61197
updated render method for revised ColTemp interface
Dec 8, 2021
9266cc6
offer bug fix
Dec 8, 2021
49b3939
offer bug fix
Dec 8, 2021
8877f6e
trade bug fix
Dec 9, 2021
0d725bd
renamed prop to "Rename to enableCustomizeColumns" for clarity
Dec 9, 2021
3164b09
Removed redundent cols
Dec 9, 2021
039069d
cleaner table update than refreshing page
Dec 10, 2021
aec23e3
removed debug
Dec 10, 2021
65b58c9
updating on stat and rating views
Dec 10, 2021
4a829a5
fixed boxscore sortbys
Dec 13, 2021
f8fe613
fixed trading block updating
Dec 13, 2021
020f5ac
fixed player bios
Dec 17, 2021
b62ed36
removed reference to react-bootstrap for css components
Dec 17, 2021
e411fff
removed refs
Dec 17, 2021
4ecbc61
fixed package.json
Dec 17, 2021
206bf00
Merge branch 'master' into master
Vac1911 Dec 17, 2021
1bf28af
Combined column files and fixed injury table
Jan 3, 2022
fa3e2c6
Updated Draft
Jan 3, 2022
fb535f7
Merge Upstream
Jan 17, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
"deploy": "yarn run lint && yarn test && node tools/deploy.mjs",
"deploy-all": "yarn run lint && yarn test && node tools/deploy-all.mjs",
"start-watch": "concurrently --kill-others \"yarn run start\" \"yarn run watch\"",
"watch": "yarn run ajv-hack && node --openssl-legacy-provider tools/watch.js",
"watch": "yarn run ajv-hack && node tools/watch.js",
Vac1911 marked this conversation as resolved.
Show resolved Hide resolved
"lint": "concurrently --raw \"yarn run lint-js\" \"yarn run lint-ts\"",
"lint-js": "eslint \"*.{mjs,js,ts,tsx}\" \"public/*.js\" \"src/**/*.{mjs,js,ts,tsx}\" \"tools/**/*.{mjs,js,ts,tsx}\"",
"lint-ts": "node tools/pre-test.mjs && yarn run tsc",
Expand Down
3 changes: 1 addition & 2 deletions public/css/dark.scss
Original file line number Diff line number Diff line change
Expand Up @@ -324,7 +324,6 @@ input[type="checkbox"][disabled]:not(.custom-control-input) {
}
}

.sorting_asc,
.sorting_desc {
.sorted {
background-color: #5f583c !important;
}
3 changes: 1 addition & 2 deletions public/css/light.scss
Original file line number Diff line number Diff line change
Expand Up @@ -1299,7 +1299,6 @@ code {
transition: none !important;
}

.sorting_asc,
.sorting_desc {
.sorted {
background-color: #ffeeba !important;
}
9 changes: 5 additions & 4 deletions src/common/getCols.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
import type { Col } from "../ui/components/DataTable";
import type { LegacyCol } from "../ui/components/DataTable";
import bySport from "./bySport";
import isSport from "./isSport";

type ColTemp = Omit<Col, "title"> & {
type ColTemp = Omit<LegacyCol, "title"> & {
title?: string;
};

Expand Down Expand Up @@ -2083,6 +2083,7 @@ const cols: {
},
"Draft Picks": {
sortSequence: [],
sortType: "draftPick",
},
"Draft Year": {
sortType: "number",
Expand Down Expand Up @@ -2625,8 +2626,8 @@ const cols: {

export default (
titles: string[],
overrides: Record<string, Partial<Col>> = {},
): Col[] => {
overrides: Record<string, Partial<LegacyCol>> = {},
): LegacyCol[] => {
return titles.map(title => {
if (!cols.hasOwnProperty(title)) {
throw new Error(`Unknown column: "${title}"`);
Expand Down
2 changes: 1 addition & 1 deletion src/common/types.basketball.ts
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@ export type AwardPlayerDefense = {

export type Awards<
PlayerOverride = AwardPlayer,
PlayerDefenseOverride = AwardPlayerDefense
PlayerDefenseOverride = AwardPlayerDefense,
> = {
season: number;
bestRecord: AwardTeam;
Expand Down
1 change: 1 addition & 0 deletions src/common/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1625,6 +1625,7 @@ export type UpdateEvents = (
| "team"
| "teamFinances"
| "watchList"
| "customizeTable"
)[];

export type RealPlayerPhotos = Record<string, string>;
Expand Down
7 changes: 4 additions & 3 deletions src/ui/components/BoxScore.basketball.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
import PropTypes from "prop-types";
import ResponsiveTableWrapper from "./ResponsiveTableWrapper";
import SafeHtml from "../components/SafeHtml";
import { getCols, helpers } from "../util";
import { helpers } from "../util";
import getCols from "../util/columns/getCols";
import { sortByStats, StatsHeader } from "./BoxScore.football";
import { MouseEvent, useState } from "react";
import type { SortBy } from "./DataTable";
Expand All @@ -22,13 +23,13 @@ const StatsTable = ({
}) => {
const [sortBys, setSortBys] = useState<SortBy[]>([]);

const onClick = (event: MouseEvent, i: number) => {
const onClick = (event: MouseEvent, colKey: string) => {
setSortBys(prevSortBys => {
const newSortBys =
updateSortBys({
cols,
event,
i,
colKey,
prevSortBys,
}) ?? [];

Expand Down
26 changes: 14 additions & 12 deletions src/ui/components/BoxScore.football.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
import PropTypes from "prop-types";
import { memo, Fragment, MouseEvent, ReactNode, useState } from "react";
import ResponsiveTableWrapper from "./ResponsiveTableWrapper";
import { getCols, processPlayerStats } from "../util";
import { processPlayerStats } from "../util";
import getCols from "../util/columns/getCols";
import { filterPlayerStats, getPeriodName, helpers } from "../../common";
import { PLAYER_GAME_STATS } from "../../common/constants.football";
import type { Col, SortBy } from "./DataTable";
Expand Down Expand Up @@ -39,7 +40,7 @@ export const StatsHeader = ({
sortable,
}: {
cols: Col[];
onClick: (b: MouseEvent, a: number) => void;
onClick: (b: MouseEvent, a: string) => void;
sortBys: SortBy[];
sortable: boolean;
}) => {
Expand All @@ -53,7 +54,7 @@ export const StatsHeader = ({
if (sortable) {
className = "sorting";
for (const sortBy of sortBys) {
if (sortBy[0] === i) {
if (sortBy[0] === col.key) {
className = sortBy[1] === "asc" ? "sorting_asc" : "sorting_desc";
break;
}
Expand All @@ -65,7 +66,7 @@ export const StatsHeader = ({
className={className}
key={i}
onClick={event => {
onClick(event, i);
onClick(event, col.key);
}}
title={desc}
>
Expand All @@ -84,7 +85,7 @@ export const sortByStats = (
) => {
return (a: any, b: any) => {
for (const [index, order] of sortBys) {
const stat = stats[index];
const stat = index.includes(":") ? index.split(":")[1] : index;
dumbmatter marked this conversation as resolved.
Show resolved Hide resolved

const aValue = getValue?.(a, stat) ?? a.processed[stat];
const bValue = getValue?.(b, stat) ?? b.processed[stat];
Expand Down Expand Up @@ -115,20 +116,21 @@ const StatsTableIndividual = ({

const [sortBys, setSortBys] = useState(() => {
return PLAYER_GAME_STATS[type].sortBy.map(
stat => [stats.indexOf(stat), "desc"] as SortBy,
stat => [`stat:${stat}`, "desc"] as SortBy,
);
});

const onClick = (event: MouseEvent, i: number) => {
setSortBys(
prevSortBys =>
const onClick = (event: MouseEvent, colKey: string) => {
setSortBys(prevSortBys => {
return (
updateSortBys({
cols,
event,
i,
colKey,
prevSortBys,
}) ?? [],
);
}) ?? []
);
});
};

const players = t.players
Expand Down
20 changes: 11 additions & 9 deletions src/ui/components/BoxScore.hockey.tsx
Original file line number Diff line number Diff line change
@@ -1,14 +1,15 @@
import PropTypes from "prop-types";
import { memo, Fragment, MouseEvent, ReactNode, useState } from "react";
import { Fragment, memo, MouseEvent, ReactNode, useState } from "react";
import ResponsiveTableWrapper from "./ResponsiveTableWrapper";
import { getCols, helpers, processPlayerStats } from "../util";
import { helpers, processPlayerStats } from "../util";
import { filterPlayerStats, getPeriodName } from "../../common";
import type { PlayByPlayEventScore } from "../../worker/core/GameSim.hockey/PlayByPlayLogger";
import { formatClock } from "../util/processLiveGameEvents.hockey";
import { PLAYER_GAME_STATS } from "../../common/constants.hockey";
import { sortByStats, StatsHeader } from "./BoxScore.football";
import updateSortBys from "./DataTable/updateSortBys";
import type { SortBy } from "./DataTable";
import getCols from "../util/columns/getCols";

type Team = {
abbrev: string;
Expand Down Expand Up @@ -42,20 +43,21 @@ const StatsTable = ({

const [sortBys, setSortBys] = useState(() => {
return PLAYER_GAME_STATS[type].sortBy.map(
stat => [stats.indexOf(stat), "desc"] as SortBy,
stat => [`stat:${stat}`, "desc"] as SortBy,
);
});

const onClick = (event: MouseEvent, i: number) => {
setSortBys(
prevSortBys =>
const onClick = (event: MouseEvent, colKey: string) => {
setSortBys(prevSortBys => {
return (
updateSortBys({
cols,
event,
i,
colKey,
prevSortBys,
}) ?? [],
);
}) ?? []
);
});
};

const players = t.players
Expand Down
12 changes: 9 additions & 3 deletions src/ui/components/DataTable/Controls.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ const style = {

const Controls = ({
enableFilters,
enableCustomizeColumns,
hideAllControls,
name,
onExportCSV,
Expand All @@ -26,6 +27,7 @@ const Controls = ({
searchText,
}: {
enableFilters: boolean;
enableCustomizeColumns: boolean;
hideAllControls?: boolean;
name: string;
onExportCSV: () => void;
Expand Down Expand Up @@ -131,9 +133,13 @@ const Controls = ({
<span className="glyphicon glyphicon-option-vertical text-muted" />
</Dropdown.Toggle>
<Dropdown.Menu>
<Dropdown.Item onClick={onSelectColumns}>
Customize Columns
</Dropdown.Item>
{enableCustomizeColumns ? (
<Dropdown.Item onClick={onSelectColumns}>
Customize Columns
</Dropdown.Item>
) : (
""
)}
<Dropdown.Item onClick={onExportCSV}>
Download Spreadsheet
</Dropdown.Item>
Expand Down
Loading