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

Grading Overview: TS/Tremor -> AG/Blueprint Migration #2893

Merged
Merged
Changes from 1 commit
Commits
Show all changes
100 commits
Select commit Hold shift + click to select a range
97a1ae4
added filterable columns in grading overview
InfinityTwo Feb 28, 2024
567a471
some cleanup code
InfinityTwo Feb 28, 2024
0c5df89
merge conflicts
InfinityTwo Mar 6, 2024
5a5eaab
moved some grading overview FE components from tremor to blueprint
InfinityTwo Mar 6, 2024
852da3c
missing code from previous commit
InfinityTwo Mar 6, 2024
c4f0ddf
halfway done for porting tanstack/tremor to ag grid/blueprint
InfinityTwo Mar 13, 2024
34f8d9a
Merge pull request #4 from InfinityTwo/grading-filterable-columns
InfinityTwo Mar 13, 2024
b22cb6f
more changes to grading table - animation whilst loading, filter/edit…
InfinityTwo Mar 20, 2024
30014c8
Merge pull request #5 from InfinityTwo/grading-filterable-columns
InfinityTwo Mar 20, 2024
63932c6
code refactoring
InfinityTwo Mar 23, 2024
5a4eb0d
Merge pull request #6 from InfinityTwo/grading-filterable-columns
InfinityTwo Mar 23, 2024
de27b6d
filterable columns, backend sorting shell, and some partial removal o…
InfinityTwo Mar 26, 2024
48684a5
more component migrations, refactoring and preparation for backend sort
InfinityTwo Mar 27, 2024
1e7eafc
multi -> single sorting, moved over all ts/tremor components to ag/bp…
InfinityTwo Mar 30, 2024
f7021b0
fix table cutoff on small horizontal resolution and missing hover eff…
InfinityTwo Mar 30, 2024
e54fe6e
refresh button for table
InfinityTwo Mar 30, 2024
6ae6df5
Merge branch 'master' of https://github.com/source-academy/frontend i…
RichDom2185 Apr 1, 2024
c16e3ae
fixed richard's comments (mostly), and added a fix for josh's comment…
InfinityTwo Apr 3, 2024
d1d4a09
fixed edge case of attempted/submitted on filter from prev commit
InfinityTwo Apr 3, 2024
2db1749
mock files, change josh's pr 2nd issue to remove non-submitted filter…
InfinityTwo Apr 3, 2024
83f00cf
fixed wrong username and text overflow
InfinityTwo Apr 3, 2024
f1f8652
eslint
InfinityTwo Apr 6, 2024
2ed0eec
prettier checks
InfinityTwo Apr 6, 2024
2d5cae3
Merge branch 'source-academy:master' into grading-overview-ag-bp-migr…
InfinityTwo Apr 6, 2024
886c976
backend mock changes
InfinityTwo Apr 6, 2024
d901660
minor adjustments and cleanups
InfinityTwo Apr 6, 2024
768cb8a
minor ui adjustments for better mobile compatability
InfinityTwo Apr 6, 2024
20fe50a
Merge branch 'source-academy:master' into grading-overview-ag-bp-migr…
InfinityTwo Apr 10, 2024
ca6ac7e
preparation for P2 merge
InfinityTwo Apr 10, 2024
b73044b
Merge branch 'grading-overview-ag-bp-migration' of https://github.com…
InfinityTwo Apr 10, 2024
651e457
eslint prettier
InfinityTwo Apr 10, 2024
2dc8125
compile erros
InfinityTwo Apr 10, 2024
480bbfc
compile error and eslint
InfinityTwo Apr 10, 2024
2aa51e5
Merge branch 'source-academy:master' into grading-overview-ag-bp-migr…
InfinityTwo Apr 11, 2024
9dad80b
master conflicts
InfinityTwo Apr 14, 2024
f608c87
prettier checks
InfinityTwo Apr 14, 2024
e849778
minor ui adjustments
InfinityTwo Apr 14, 2024
fef4031
Merge branch 'master' of https://github.com/source-academy/frontend i…
RichDom2185 Apr 14, 2024
3c4c939
Revert change back to raw strings
RichDom2185 Apr 14, 2024
d57f0d8
typescript v5 fixes and richard's comments
InfinityTwo Apr 14, 2024
4b76614
Merge branch 'source-academy:master' into grading-overview-ag-bp-migr…
InfinityTwo Apr 14, 2024
3c5edf1
more typescript v5 fixes
InfinityTwo Apr 14, 2024
fbba60a
prettier
InfinityTwo Apr 14, 2024
b03cfe9
some refactoring and bug fixing
InfinityTwo Apr 14, 2024
9b2348e
Merge branch 'source-academy:master' into grading-overview-ag-bp-migr…
InfinityTwo Apr 15, 2024
505de5f
null value error in empty cell & wider actions col
InfinityTwo Apr 16, 2024
d161760
added submitted to unpublished allowed filters
InfinityTwo Apr 16, 2024
a4ff982
Merge branch 'master' into grading-overview-ag-bp-migration
InfinityTwo Apr 18, 2024
db2961c
Merge branch 'master' of https://github.com/source-academy/frontend i…
RichDom2185 May 1, 2024
e93a8d5
Merge branch 'master' into grading-overview-ag-bp-migration
RichDom2185 May 3, 2024
04cc13e
Merge branch 'master' into grading-overview-ag-bp-migration
RichDom2185 May 3, 2024
8b02ad1
Merge branch 'master' of https://github.com/source-academy/frontend i…
RichDom2185 May 5, 2024
86a431b
Merge branch 'master' of https://github.com/source-academy/frontend i…
RichDom2185 May 6, 2024
c4134c0
Fix format
RichDom2185 May 12, 2024
f7ea428
Merge branch 'master' of https://github.com/source-academy/frontend i…
RichDom2185 May 12, 2024
7449edf
Fix compile error post-merge
RichDom2185 May 12, 2024
5428c57
Refactor GradingFlex
RichDom2185 May 12, 2024
ceebfb9
Refactor GradingText
RichDom2185 May 12, 2024
916680c
Update BackendSaga.ts
RichDom2185 May 12, 2024
8a1cad8
Refactor GradingFilterable.tsx
RichDom2185 May 12, 2024
847a6ab
Refactor GradingActions
RichDom2185 May 12, 2024
1f4108f
Simplify conditions in conditionals
RichDom2185 May 12, 2024
d2756bc
Refactor conditions
RichDom2185 May 12, 2024
71eb6d6
Refactor GradingColumnCustomHeaders.tsx
RichDom2185 May 12, 2024
a14c365
Refactor GradingColumnFilters.tsx
RichDom2185 May 12, 2024
70fbc0f
Refactor GradingBadges.tsx
RichDom2185 May 12, 2024
3d1ec43
Add missing React import
RichDom2185 May 12, 2024
0d91ae8
Merge branch 'master' into grading-overview-ag-bp-migration
RichDom2185 May 12, 2024
f79be42
Merge branch 'master' into grading-overview-ag-bp-migration
RichDom2185 May 12, 2024
da2e269
Merge branch 'master' into grading-overview-ag-bp-migration
RichDom2185 May 12, 2024
fa7a309
Merge branch 'master' of https://github.com/source-academy/frontend i…
RichDom2185 May 13, 2024
14b8360
Fix imports and format post merge
RichDom2185 May 13, 2024
e8e68c5
Merge branch 'master' into grading-overview-ag-bp-migration
lhw-1 May 16, 2024
72f301f
Merge branch 'master' of https://github.com/InfinityTwo/sourceacademy…
InfinityTwo Jun 4, 2024
e08d9b5
hw review changes and child key error fix
InfinityTwo Jun 4, 2024
086460d
Merge branch 'grading-overview-ag-bp-migration' of https://github.com…
InfinityTwo Jun 4, 2024
5f88cd2
fixed randomly broken grading table headers and merge conflicts
InfinityTwo Aug 6, 2024
a858c18
prettier
InfinityTwo Aug 6, 2024
f02d792
Merge branch 'master' into grading-overview-ag-bp-migration
RichDom2185 Aug 11, 2024
f6664ac
Merge branch 'master' into grading-overview-ag-bp-migration
RichDom2185 Aug 15, 2024
c9bf19c
Merge branch 'master' of https://github.com/source-academy/frontend i…
RichDom2185 Aug 16, 2024
6d21dca
Reformat post-lint updates
RichDom2185 Aug 16, 2024
e48bb8f
Merge branch 'master' into grading-overview-ag-bp-migration
RichDom2185 Aug 17, 2024
d2db6d2
Add TODO
RichDom2185 Aug 19, 2024
057dd5a
Remove unused CSS class
RichDom2185 Aug 19, 2024
74aa4e7
Scope most styles to CSS modules
RichDom2185 Aug 19, 2024
9544a0c
Migrate more styles to CSS modules
RichDom2185 Aug 19, 2024
21fb5f6
Simplify to use new actions format
RichDom2185 Aug 19, 2024
286a204
Migrate more classes to CSS modules
RichDom2185 Aug 19, 2024
de628df
Refactor grading badge styles to separate module file
RichDom2185 Aug 19, 2024
23d330f
Remove hardcoded CSS namespace
RichDom2185 Aug 19, 2024
24fffed
Make fix less hacky
RichDom2185 Aug 19, 2024
5c95916
Remove unnecessary default with enum type
RichDom2185 Aug 19, 2024
8960ade
Refactor column builder to separate file
RichDom2185 Aug 19, 2024
874ae71
Remove unnecessary space
RichDom2185 Aug 19, 2024
1b32f44
Improve readability
RichDom2185 Aug 19, 2024
3abcdad
Remove unused param
RichDom2185 Aug 19, 2024
248c03f
Remove unnecessary `={true}`
RichDom2185 Aug 19, 2024
fedce2a
Add TODO
RichDom2185 Aug 19, 2024
9bc2656
Refactor grading badge
RichDom2185 Aug 19, 2024
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
Prev Previous commit
Next Next commit
prettier checks
  • Loading branch information
InfinityTwo committed Apr 6, 2024

Verified

This commit was signed with the committer’s verified signature.
wezm Wesley Moore
commit 2ed0eec18086ab0f8d906551eb9d100fc98e614a
31 changes: 19 additions & 12 deletions src/commons/grading/GradingFlex.tsx
Original file line number Diff line number Diff line change
@@ -1,27 +1,34 @@
import { Property } from "csstype";
import { Property } from 'csstype';

type GradingFlexProps = {
justifyContent?: Property.JustifyContent;
alignItems?: Property.AlignItems;
flexDirection?: Property.FlexDirection;
children?: React.ReactNode;
style?: React.CSSProperties;
className?: string;
justifyContent?: Property.JustifyContent;
alignItems?: Property.AlignItems;
flexDirection?: Property.FlexDirection;
children?: React.ReactNode;
style?: React.CSSProperties;
className?: string;
} & React.RefAttributes<HTMLDivElement>;

const GradingFlex: React.FC<GradingFlexProps> = ({ justifyContent, alignItems, flexDirection, children, style, className, }: GradingFlexProps) => {
const GradingFlex: React.FC<GradingFlexProps> = ({
justifyContent,
alignItems,
flexDirection,
children,
style,
className
}: GradingFlexProps) => {
const defaultStyle: React.CSSProperties = {
display: "flex",
display: 'flex',
justifyContent: justifyContent,
alignItems: alignItems,
flexDirection: flexDirection,
flexDirection: flexDirection
};

return (
<div className={className} style={{...defaultStyle, ...style}}>
<div className={className} style={{ ...defaultStyle, ...style }}>
{children}
</div>
);
}
};

export default GradingFlex;
21 changes: 13 additions & 8 deletions src/commons/grading/GradingText.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Text } from "@blueprintjs/core";
import { Text } from '@blueprintjs/core';

type GradingTextProps = {
children?: React.ReactNode;
@@ -7,20 +7,25 @@ type GradingTextProps = {
className?: string;
} & React.RefAttributes<HTMLDivElement>;

const GradingText: React.FC<GradingTextProps> = ({ children, style, secondaryText, className = "", }: GradingTextProps) => {
const GradingText: React.FC<GradingTextProps> = ({
children,
style,
secondaryText,
className = ''
}: GradingTextProps) => {
const defaultStyle: React.CSSProperties = {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Unnecessary type annotation

width: "max-content",
margin: "auto 0"
width: 'max-content',
margin: 'auto 0'
};

return (
<Text
className={"bp5-ui-text " + className + (secondaryText ? " bp5-text-muted" : "")}
style={{...defaultStyle, ...style}}
<Text
className={'bp5-ui-text ' + className + (secondaryText ? ' bp5-text-muted' : '')}
style={{ ...defaultStyle, ...style }}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Don't use raw class names because this is very fragile. Use the abstracted class names from Classes instead.

>
{children}
</Text>
);
}
};

export default GradingText;
52 changes: 34 additions & 18 deletions src/pages/academy/grading/Grading.tsx
Original file line number Diff line number Diff line change
@@ -9,7 +9,11 @@ import GradingFlex from 'src/commons/grading/GradingFlex';
import GradingText from 'src/commons/grading/GradingText';
import SimpleDropdown from 'src/commons/SimpleDropdown';
import { useSession, useTypedSelector } from 'src/commons/utils/Hooks';
import { decreaseRequestCounter, increaseRequestCounter, setGradingHasLoadedBefore } from 'src/commons/workspace/WorkspaceActions';
import {
decreaseRequestCounter,
increaseRequestCounter,
setGradingHasLoadedBefore
} from 'src/commons/workspace/WorkspaceActions';
import { numberRegExp } from 'src/features/academy/AcademyTypes';
import { GradingOverview } from 'src/features/grading/GradingTypes';
import {
@@ -59,8 +63,7 @@ const Grading: React.FC = () => {

const updateGradingOverviewsCallback = useCallback(
(page: number, filterParams: Object) => {

// Prevents es-lint missing dependency warning
// Prevents es-lint missing dependency warning
if (refreshQuery) {
return setRefreshQuery(false);
}
@@ -73,25 +76,28 @@ const Grading: React.FC = () => {
ungradedToBackendParams(showAllSubmissions),
paginationToBackendParams(page, pageSize),
filterParams,
allColsSortStates,
allColsSortStates
)
);
},
[dispatch, showAllGroups, showAllSubmissions, pageSize, allColsSortStates, refreshQuery]
);

useEffect(() => {
setSubmissions(gradingOverviews?.data?.map(e =>
!e.studentName
? {
...e,
studentName: Array.isArray(e.studentNames) ? e.studentNames.join(', ') : e.studentNames
}
: e
) ?? []);
setSubmissions(
gradingOverviews?.data?.map(e =>
!e.studentName
? {
...e,
studentName: Array.isArray(e.studentNames)
? e.studentNames.join(', ')
: e.studentNames
}
: e
) ?? []
);
// }
dispatch(decreaseRequestCounter());

}, [gradingOverviews, dispatch]);

// If submissionId or questionId is defined but not numeric, redirect back to the Grading overviews page
@@ -133,9 +139,11 @@ const Grading: React.FC = () => {
) : (
<GradingFlex flexDirection="column" className="grading-table-wrapper">
<GradingFlex justifyContent="space-between">
<GradingFlex justifyContent="flex-start" style={{columnGap: "1.5rem"}}>
<GradingText style={{fontSize: "1.125rem", opacity: 0.9}}>Submissions</GradingText>
<Button
<GradingFlex justifyContent="flex-start" style={{ columnGap: '1.5rem' }}>
<GradingText style={{ fontSize: '1.125rem', opacity: 0.9 }}>
Submissions
</GradingText>
<Button
minimal={true}
icon={IconNames.EXPORT}
onClick={() => exportGradingCSV(gradingOverviews.data)}
@@ -145,7 +153,10 @@ const Grading: React.FC = () => {
</Button>
</GradingFlex>
</GradingFlex>
<GradingFlex justifyContent="flex-start" style={{columnGap: "0.5rem", marginTop: "0.5rem"}}>
<GradingFlex
justifyContent="flex-start"
style={{ columnGap: '0.5rem', marginTop: '0.5rem' }}
>
<GradingText>Viewing</GradingText>
<SimpleDropdown
options={showOptions}
@@ -171,7 +182,12 @@ const Grading: React.FC = () => {
buttonProps={{ minimal: true, rightIcon: 'caret-down' }}
/>
<GradingText>entries per page.</GradingText>
<Button className={"grading-refresh" + (requestCounter !== 0 ? "-loop" : "") } minimal={true} style={{ padding: 0 }} onClick={(e) => setRefreshQuery((prev) => !prev)}>
<Button
className={'grading-refresh' + (requestCounter !== 0 ? '-loop' : '')}
minimal={true}
style={{ padding: 0 }}
onClick={e => setRefreshQuery(prev => !prev)}
>
<Icon htmlTitle="Refresh" icon={IconNames.REFRESH} />
</Button>
</GradingFlex>
20 changes: 17 additions & 3 deletions src/pages/academy/grading/subcomponents/GradingActions.tsx
Original file line number Diff line number Diff line change
@@ -48,18 +48,32 @@ const GradingActions: React.FC<Props> = ({ submissionId, style }) => {
};

return (
<GradingFlex justifyContent="flex-start" className="grading-actions-btn-wrappers" style={{columnGap: "5px", ...style}}>
<GradingFlex
justifyContent="flex-start"
className="grading-actions-btn-wrappers"
style={{ columnGap: '5px', ...style }}
>
<Link to={`/courses/${courseId}/grading/${submissionId}`}>
<GradingFlex alignItems="center" className="grading-action-icons grading-action-icons-bg">
<Icon htmlTitle="Grade" icon={IconNames.EDIT} />
</GradingFlex>
</Link>

<Button className="grading-action-icons" minimal={true} style={{ padding: 0 }} onClick={handleReautogradeClick}>
<Button
className="grading-action-icons"
minimal={true}
style={{ padding: 0 }}
onClick={handleReautogradeClick}
>
<Icon htmlTitle="Reautograde" icon={IconNames.REFRESH} />
</Button>

<Button className="grading-action-icons" minimal={true} style={{ padding: 0 }} onClick={handleUnsubmitClick}>
<Button
className="grading-action-icons"
minimal={true}
style={{ padding: 0 }}
onClick={handleUnsubmitClick}
>
<Icon htmlTitle="Unsubmit" icon={IconNames.UNDO} />
</Button>
</GradingFlex>
15 changes: 7 additions & 8 deletions src/pages/academy/grading/subcomponents/GradingBadges.tsx
Original file line number Diff line number Diff line change
@@ -4,8 +4,8 @@ import { ReactNode } from 'react';
import { GradingStatus } from 'src/commons/assessment/AssessmentTypes';
import { ColumnFilter } from 'src/features/grading/GradingTypes';

declare const sizeValues: readonly ["xs", "sm", "md", "lg", "xl"];
declare type Size = typeof sizeValues[number];
declare const sizeValues: readonly ['xs', 'sm', 'md', 'lg', 'xl'];
declare type Size = (typeof sizeValues)[number];

interface BadgeProps {
text: string;
@@ -16,18 +16,17 @@ interface BadgeProps {

const Badge: React.FC<BadgeProps> = (props: BadgeProps) => {
return (
<div
className={"grading-badge grading-badge-" + (props.size ? props.size : "sm")}
<div
className={'grading-badge grading-badge-' + (props.size ? props.size : 'sm')}
style={{
color: (props.color ? props.color[1] : "#000000"),
backgroundColor: (props.color ? (props.color[0] + "40") : "")
color: props.color ? props.color[1] : '#000000',
backgroundColor: props.color ? props.color[0] + '40' : ''
}}
>
{props.icon ? props.icon() : <></>}
<span className="grading-badge-text">{props.text}</span>
</div>
);

};

// First colour is bg, second is text (text is more saturated/darker). Colours are referenced from tailwind css.
@@ -38,7 +37,7 @@ const AVAILABLE_COLORS = {
green: ['#4ade80', '#15803d'],
yellow: ['#fde047', '#ca8a04'],
red: ['#f87171', '#b91c1c'],
gray: ['#9ca3af', '#374151'],
gray: ['#9ca3af', '#374151']
};

const BADGE_COLORS = {
Original file line number Diff line number Diff line change
@@ -12,16 +12,17 @@ export interface GradingColumnCustomHeadersProps extends CustomHeaderProps {
disabledSortCols: string[];
}

const GradingColumnCustomHeaders: React.FC<GradingColumnCustomHeadersProps> = (props: GradingColumnCustomHeadersProps) => {

const GradingColumnCustomHeaders: React.FC<GradingColumnCustomHeadersProps> = (
props: GradingColumnCustomHeadersProps
) => {
// The values correspond to the available icons in the BlueprintJS library. "sort" means unsorted.
const [sortState, setSortState] = useState<SortStates>(SortStates.NONE);
const colsSortState = useTypedSelector(state => state.workspaces.grading.allColsSortStates);

const nextSortState = () => {
setSortState((prev) => getNextSortState(prev));
setSortState(prev => getNextSortState(prev));
props.updateSortState(props.column.getColId(), getNextSortState(sortState));
}
};

useEffect(() => {
if (colsSortState.sortBy !== props.column.getColId()) {
@@ -31,24 +32,27 @@ const GradingColumnCustomHeaders: React.FC<GradingColumnCustomHeadersProps> = (p

return (
<div className={String(props.eGridHeader.classList)}>

<span className="ag-header-cell-text">{props.displayName}</span>

{
!props.disabledSortCols.includes(props.column.getColId()) ?
<div className="grading-table-col-icons grading-table-sort-cols" onClick={(e) => nextSortState()}>
<Icon icon={sortState} />
</div>
: <></>
}

<div className="grading-table-col-icons grading-table-hide-cols" onClick={(e) => props.hideColumn(props.column.getColId())}>
{!props.disabledSortCols.includes(props.column.getColId()) ? (
<div
className="grading-table-col-icons grading-table-sort-cols"
onClick={e => nextSortState()}
>
<Icon icon={sortState} />
</div>
) : (
<></>
)}

<div
className="grading-table-col-icons grading-table-hide-cols"
onClick={e => props.hideColumn(props.column.getColId())}
>
<Icon icon="eye-off" />
</div>

</div>
);

};

export default GradingColumnCustomHeaders;
export default GradingColumnCustomHeaders;
Original file line number Diff line number Diff line change
@@ -6,7 +6,12 @@ type FilterableProps = {

const GradingFilterable: React.FC<FilterableProps> = ({ value, children, filterMode }) => {
return (
<button type="button" className={filterMode ? "grading-overview-filterable-btns" : "grading-overview-unfilterable-btns"}>
<button
type="button"
className={
filterMode ? 'grading-overview-filterable-btns' : 'grading-overview-unfilterable-btns'
}
>
{children || value}
</button>
);
Original file line number Diff line number Diff line change
@@ -10,7 +10,7 @@ type Props = {

const GradingSubmissionFilters: React.FC<Props> = ({ filters, onFilterRemove }) => {
return (
<GradingFlex justifyContent="flex-start" style={{columnGap: "5px"}}>
<GradingFlex justifyContent="flex-start" style={{ columnGap: '5px' }}>
{filters.map(filter => (
<FilterBadge filter={filter} onRemove={onFilterRemove} key={filter.id} />
))}
Loading
Loading