-
Notifications
You must be signed in to change notification settings - Fork 226
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
Manage Submissions #2248
base: master
Are you sure you want to change the base?
Manage Submissions #2248
Conversation
* Start Manage Submissions * Center checkbox in manage submission table (#1868) fix checkbox issue * Main Table UI * Updates with selecting students and buttons * Add Score Popup Icon * Icon spacing and codebase style --------- Co-authored-by: Michelle Liu <[email protected]>
* change icon to swap_vert, hide for file and actions headers * change icon on diff sort
* Adds score details without styling * address general styling for score details * refactor code * address pr issues
* Lint views/submissions (#1969) * Begin linting views/submissions * finish linting views/submissions * address issues in code_viewer * Prevent spoofing the author of an annotation (#1985) * Prevent spoofing the author of an annotation (cherry picked from commit d2ab510) * Remove submitted_by from createAnnotation * Update link to docs in PR template (#1991) Fix link to docs * Hide irrelevant cud fields for students (#1988) * Show edit CUD button for students * Hide irrelevant CUD fields from students * Lint views/autograders, fix help-block gap from input (#1963) * lint views/autograders, fix help block gap from input * update form path * Lint views/announcements and Touch-up UI (#1957) * lint views/announcements and touch-up UI * address nits * Add erblint to overcommit and github actions (#1994) * update erb-lint config, overcommit config to enable erb-lint as a pre-commit hook, run erblint --lint-all * update github actions to run erb-lint during linting phase * update pull request template to include erblint check * Display Grace Day usage on submission history table, improve management of assessment penalty settings (#1990) * Display of grace days used * Fix calculation of effective_late_penalty and effective_version_penalty * Show course default values when applicable * Show warning messages when late submissions allowed but config does not make sense * Fix tests * Update wording * Improve formatting * Revert changes to effective penalties * Simplify check * Add toggles * Update wording on courseFields * Fix version threshold logic * Correctly set version threshold to blank when using course default * Clear / default values when checkbox clicked * Remove bottom padding * Improve UI when checkboxes selected * Address AI nits * Handle malformed scoreboard results from autograder, fix error handling for scoreboards (#1982) * begin fixing broken redirects * add code to check that entries are arrays, return flash error if not valid entry * fix spacing * address nit * Add logging * Click into submissions from gradebook score (#1998) * Clickable gradebook scores * Only scores have links --------- Co-authored-by: kestertan <[email protected]> * Switch mossnet clean to use rails root instead of tilde expansion (#1997) use Rails root join function instead of ~/ to make sure moss clean script works across systems * Merge pull request from GHSA-h8wq-ghfq-5hfx * fixes * Add validation for handout, writeup, and handin_directory * Avoid use of and * Check that handout/writeup exists before checking path (#2001) Move present? check to front * Adds warning when assessment.rb file upload isn't a .rb file (#1999) * preliminary working version * only validates .rb files --------- Co-authored-by: Damian Ho <[email protected]> * Refactor Assessment name rules, remove config file requirement (#1987) * begin refactoring naming rules for assessments * continue working on file acceptance * add testing * fix autograde * work on backwards compatibility / revertibility * keep working on implementing revertability * Fix some code creating assessmentConfigFile before assessment id created * Add documentation to naming rules * add line about assessment name uniqueness * update error messages * fix tests * add error handling code to redirect user in case assessment config file can't be loaded, run robocop * address AI code review * remove redundant flash * Fix text * Fix reload assessment config button text * Add more error handling, revamp regex string to better reflect valid ruby module names, add better sanitization for display name -> name conversion, fix docs to reflect actually valid assessment names. * fix test * Address nits * Fix issue where assessment could affect another assessment's config file if they both had names that mapped to pre-PR config file name * Delete config/oauth_config.yml * Delete diff.patch * Delete assessment.patch * remove unnecessary files * more removals * Suppress confirmation dialog on edit assessment page when no changes made (#2004) * Extract logic, call functions directly * Remove extraneous space * Remove another extraneous space * Display submission version in gradebook (#2005) * First Commit: version info is on gradebook as new columns * Second commit: only add a ver column after each assignment * Delete database.docker.yml * Delete schema.rb * Deleted debug code * change gitignore to original version * Address nits * Fix tooltips * Simplify version logic * Stop overwriting headerCssClass * Fix tooltip for not_yet_submitted * Handle nil aud * Add version to gradebook CSV export * Render tooltips onMouseEnter too * Simplify version header * Simplify logic * Increase gradebook width --------- Co-authored-by: SimonMen65 <[email protected]> Co-authored-by: Simon Men <[email protected]> * Don't clear assessment penalty fields on initial load (#2006) * Don't clear on initial load * Remove extraneous spaces * No line breaks when generating base64 strings (#2008) * fix bug for long strings * Update base64.js using new TextEncoder * Show all courses for MOSS (#2015) * Show all courses, restore filter * Address AI nits * Fix use of autocomplete attribute * Add newline * Simplify toggleOptions implementation * Fix style of isArchive checkboxes * Correct use of javascript_include_tag * Fix failing test * Update styling of warning * Extract dropdown logic, use OR for filtering * Add newline * Add spacing between dropdowns * Use find instead of children, check for selector existence * Removed name from assessment yml (#1993) * Removed name from assessment yml * Modified test after removing name from assessment yml * Removed unnecessary test for wrong assessment name * Removed yml name check in assessments_controller --------- Co-authored-by: Nicholas Clark <[email protected]> * Account for hooks in viewFeedback instead of feedback output (#2003) * preliminary working version * resolve merge conflicts * use submission.scores instead of feedback array * don't show non autograded scores in autograded scores tab * rabbit ai suggestions * more rabbit.ai nits * make finishedAutograding not an instance variable * Remove element overlapping scrollbar hitbox (#2009) * Remove element overlapping scrollbar hitbox * Move style to annotation.scss --------- Co-authored-by: Damian Ho <[email protected]> * Attachment categories (#1983) * Add category_name field and update course attachment UI * Improve styling of list items * Remove anchor link for unreleased badge, simplify delete button logic * Hide assessment attachments from course landing page * Add release_at field, remove released field * Fix tests * Add fixtures * Simplify variable names * Remove bullet points * Group buttons together * Make font-family consistent * Hide category for assessment attachments * Add cancel button, remove delete button, improve styling * Improve migration to be backwards compatible / reversible * Use update instead of update_attribute * Display when attachment will be released * Update tests * Simplify code * Use Time instead of DateTime * Add download icon for students * Vertically align icons * Hide assessment attachments from course attachment index * Add vertical space above release date * Passwordless temporary login (#1984) * Passwordless temporary login created * Login using devise * User is not signed in before changing password * Removing unneeded files * Removing changes to user.rb * Removing unneeded files * Resetting password does not log you out * Added mailer * Added/removed newlines * Changed naming * Added checks for nil user or params * Error handling for passwords * Removed email after password reset * Added documentation * Updated documentation * Moved documentation to features * Renamed to admin-features * Added link in mkdocs.yml * Visual cue for assessments (#2016) * Add dates to assessment card * Add CSS formatting for date * Fix margin and card sizes to be more pretty * Show all students on gradesheet (#2019) * add course members with blank info if no submissions found * add email for no submission users * update bg color * Move submission version logic to be handled by AUD (#2024) * Move submission version logic to be handled by AUD * update migration variable naming * fix unit tests, version number for new auds * fix coderabbit issues * add version number to schema * change schema timestamp * Use ActiveStorage for attachments, add attachment size limit (#2023) * 1810 Use ActiveStorage for attachments * 1864 Add backwards compatibility to ActiveStorage Attachments * 1872 Add size limit to attachments * Set mime_type * Remove require * redirect to index on error * Rails 6.1.7.6 Migration (#2037) * Initial update to 6.1.7.6 * Lock fomantic-ui-sass to 2.8.8.1 * Update schema.rb * Avoid locking setup-ruby version * Include net-http in Gemfile to avoid errors * Run rubocop * Lock uri to 0.10.0 * Fix lint issue * Fix course_number values for roster export * Use flash for drop warning * Properly display submission errors * Only show invalid assessment warning to instructors * Ensure gradebook search bar renders correctly for CAs * Filter by lecture too when CA views section * Only show missing submissions from section if CA filters by section * Update tests * Better handling for submission errors * More specific error handling for save_entries * Better error display for statistics page * Return 404 for popover on non-existent submission * load Archive in files that use its methods * Update Ruby to 3.2.2, Misc fixes (#2040) * Update Ruby to 3.2.2 - update Capybara config so that it works with new ruby version and so that js can be enabled again on selenium test - update releaseSectionGrades redirect to go to viewGradesheet for CA's section - add some more status text / more informative flash when instructor drops student - redact tango key in getjob * Address nits, update bundler / github integration * add arm64-darwin-23 to platforms * fix users nit * Bump uri from 0.10.0 to 0.10.3 (#2039) Bumps [uri](https://github.com/ruby/uri) from 0.10.0 to 0.10.3. - [Release notes](https://github.com/ruby/uri/releases) - [Commits](ruby/uri@v0.10.0...v0.10.3) --- updated-dependencies: - dependency-name: uri dependency-type: direct:production ... Signed-off-by: dependabot[bot] <[email protected]> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * Update old migrations for Ruby 3 (#2044) Use splat on old migrations * Remove grading deadline (#2014) * Initial removal of grading_deadline * Add brackets around arguments to grading_complete? * Consistency fixes * Migration to remove grading deadline * Add guards to migration * Rename grading_complete? to grades_released? * Address issues from v2.8.0 testing, misc fixes/changes (#2038) * Fix command for promoting a user to admin * Extract aria/collapsible code, switch to path helpers * Automatically open first accordion * Fix docs for Tango info endpoint * Create user directory on autograde_done * Coalesce accordions, simplify js, remove admin options * Update doorkeeper translations * Remove extraneous quotes * Remove redundant / useless assessment nil check * Fix error display when calling downloadAll on invalid assessment * Simplify failure redirect logic for downloadAll * Deduplicate logic for autograde feedback path and handin file path * Remove unused ass_dir variable * Remove redundant gitignores * Uncoalesce accordions * Fix redirects for invalid assessment Previously, calling downloadAll with an invalid assessment led to infinite redirects * Update the API to allow retrieving group members (#1956) * Add a param to the index groups api to retriee group members * Add api show endpoint for groups * Update docs * Update api docs for groups#show * Compact group members api response * Move fetching group json to a private method * Remove empty line --------- Co-authored-by: Damian Ho <[email protected]> * Update index and show docs for Groups API (#2045) Update index and show docs * Main Table UI Changes (#1886) * Start Manage Submissions * Center checkbox in manage submission table (#1868) fix checkbox issue * Main Table UI * Updates with selecting students and buttons * Add Score Popup Icon * Icon spacing and codebase style --------- Co-authored-by: Michelle Liu <[email protected]> * Add sorting icons to new manage submissions (#1890) * change icon to swap_vert, hide for file and actions headers * change icon on diff sort * Adds Score Details (#1893) * Adds score details without styling * address general styling for score details * refactor code * address pr issues * bring back css * bring back div * add back class names * add back icons * addressed nits * address nits --------- Signed-off-by: dependabot[bot] <[email protected]> Co-authored-by: Joey Wildman <[email protected]> Co-authored-by: Nicholas Myers <[email protected]> Co-authored-by: Damian Ho <[email protected]> Co-authored-by: Kester <[email protected]> Co-authored-by: kestertan <[email protected]> Co-authored-by: SimonMen65 <[email protected]> Co-authored-by: Simon Men <[email protected]> Co-authored-by: Ugo <[email protected]> Co-authored-by: Nicholas AJ Clark <[email protected]> Co-authored-by: Nicholas Clark <[email protected]> Co-authored-by: lykimchee <[email protected]> Co-authored-by: Joanna Ge <[email protected]> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Umar Alkafaween <[email protected]> Co-authored-by: Victor Huang <[email protected]>
* merge conflicts * show annotation form on click * got problems to show up * got autofill results to show * consolidate shared functions * got annotations to save yay * check if autograded * deleted console.log statements, fixed bug where manage submissions doesn't show if submissions don't produce scores * if error grading, show dash for submission instead of hiding * got edit icon showing up * updated icons for tweaks * update tweak after submitting * revert schema.rb * address nits * fixed nits
* Style fixes * Fix formatting and styling * Fix undefined error showing up for all problems and scores * Strengthened checks and nil case * Changed styling and removed external stylesheet * Increased font size and used variables --------- Co-authored-by: Kester <[email protected]>
* html_safe RuboCop Safety * Comment out unrelated popover changes (TODO in separate PR) * Add regrade selected button * Use datatables toolbar instead of Buttons extension * Rubocop style fixes * Rubocop indenting fix * Make consistent with jquery * Fixed check all functionality and download all button * Added excuse all functionality * Added route for excuseBatch * Configured excuse and unexcuse popup * Removed console log and tidied up js code * Added confirm check for delete batch * Changed variables and empty check * addressed nits * added nil table check and addressed nits and ui issues * fixed destroy confirm * Use batch regrade instead of regrade to prevent redirect or ajax * Removed unecessary comments * Fixed styling and changed to variables * Addressed permissions * Changed colors to variables and made highlight of table lighter * Fixed all issues due to merge conflicts --------- Co-authored-by: Kester <[email protected]>
📝 WalkthroughWalkthroughThis pull request introduces comprehensive enhancements to the Autolab platform's submission and annotation management system. The changes span multiple components, including JavaScript modules, controllers, views, and stylesheets. Key improvements focus on annotation handling, submission management, and user interface refinements. The modifications introduce new methods for batch submission operations, enhanced annotation functionality, and improved styling across various components of the application. Changes
Sequence DiagramsequenceDiagram
participant User
participant SubmissionsController
participant AnnotationsController
participant Submission
participant Annotation
User->>SubmissionsController: Request batch operations
SubmissionsController->>Submission: Process batch actions
Submission-->>SubmissionsController: Return operation results
SubmissionsController->>User: Provide feedback
User->>AnnotationsController: Create/Update Annotation
AnnotationsController->>Annotation: Save annotation
Annotation-->>AnnotationsController: Confirm save
AnnotationsController->>User: Return annotation details
Possibly related PRs
📜 Recent review detailsConfiguration used: CodeRabbit UI 📒 Files selected for processing (1)
⏰ Context from checks skipped due to timeout of 90000ms (2)
🔇 Additional comments (2)
Finishing Touches
Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media? 🪧 TipsChatThere are 3 ways to chat with CodeRabbit:
Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (Invoked using PR comments)
Other keywords and placeholders
CodeRabbit Configuration File (
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 6
🧹 Nitpick comments (49)
app/assets/javascripts/autolab_component.js (4)
1-24
: Great usage documentation.Including an inline usage guide within the code is very helpful for future maintainers and consumers. Consider adopting JSDoc or a similar standard for even more structured, discoverable documentation.
27-31
: Consider validating element existence.It can be beneficial to validate whether the DOM element with
elementId
exists before proceeding. This ensures your component will not silently fail if a non-existent element ID is specified. For instance:function AutolabComponent(elementId, initialState = {}, template = () => {}) { - this.elementId = elementId; + if (!document.getElementById(elementId)) { + console.warn(`Element with ID "${elementId}" not found.`); + }
32-35
: Consider using a deep merge if needed.
$.extend
defaults to a shallow merge. If your state structure is nested, or you anticipate needing a deeper merge, you might want to use{ deep: true }
or consider using another library (e.g., Lodashmerge
) to prevent unintended references.
37-40
: Provide a more descriptive default template.The default template returns an empty
<div>
, which can be confusing if someone expects rendering. It might be more user-friendly to display a short placeholder message or instructions for overriding.app/views/submissions/index.html.erb (6)
5-8
: Encapsulate or version-check external libraries.
These stylesheet links reference external dependencies (jquery-ui
). Consider pinning specific versions or integrating via a package manager (e.g., Yarn, npm) for better maintainability and reproducibility.
10-39
: Avoid polluting the global JS namespace.
This inline script sets several global variables (is_autograded
,excused_cids
, etc.). Consider wrapping them in a namespace or an IIFE (Immediately Invoked Function Expression) to reduce potential naming collisions.
73-79
: Clarify the TODO comment on filtering missing submissions.
The code references a future “missing submissions” filter feature. If it’s not part of this PR’s scope, consider opening an issue to track its progress.
88-123
: Improve discoverability of batch actions.
Hiding the batch action buttons in placeholder divs is a good approach to keep the DOM minimal. Just ensure they remain keyboard-accessible and that toggling their visibility doesn’t conflict with screen readers.
257-264
: Modal structure and naming are consistent.
The modal for score details is straightforward. Consider lazy-loading content to reduce the page’s initial payload, if performance is a concern for large classes.
267-272
: Annotation modal usage aligns with the new annotation system.
Rendering_annotation_popup
inside of a modal helps keep the code modular. Make sure accessibility guidelines (focus management, ARIA roles) are followed for a seamless user experience.app/assets/javascripts/manage_submissions.js (6)
10-21
: Minor opportunity to reduce inline HTML in JS strings.
EditTweakButton
returns multiline HTML. Consider breaking out into a small templating function or partial for maintainability and clarity.
23-37
: Use short-circuit for error handling inget_score_details
.
Your promise logic is correct, but consider adding a.fail
or.catch
block in addition to the existing error callback for thorough coverage.
66-68
: Initializing modals immediately.
$('.modal').modal();
on document ready is standard. Confirm that no subsequent dynamic content injection is interfering with the materialize modal instance.
115-148
: Inlined logic for download vs. view button generation.
While functional, it might be more readable to refactor or unify the button creation logic in a small helper function to avoid repetition.
177-220
: DataTables usage with custom ordering and hidden search features.
The approach is fine. If performance becomes an issue with large data sets or many DOM manipulations, consider server-side processing or specialized DataTables modes.
370-381
: “only-latest” filter.
The DataTables custom filter is straightforward. If you expand filtering options (like date range or specific user), consider a uniform approach with a single function.app/controllers/submissions_controller.rb (6)
39-72
: Graceful error handling inscore_details
.
The JSON structure is well-formed, but inline rescue returningnil
after rendering might hide logic flow issues. Logging or re-raising the error after responding could aid debugging.
195-240
: Batch destroy logic and permission checks.
Your loop checks if the user “has permission” each time. This is correct but might be more concise with a single scoping query that filters out submissions the current user cannot delete.
Line range hint
270-290
: Check for@assessment
validity.
Returning early if no submissions exist helps avoid generating an empty zip. Keep in mind that showing an explicit message might be better than an abrupt return for the user’s clarity.
299-301
: No explicit feedback on empty selections.
Ifsubmissions.empty?
is true, we simply return. For user-friendliness, consider a flash or redirect to inform them that no valid submissions were found.
327-370
: Download batch logic.
This mostly mirrorsdownload_all
. Consider deduplicating shared logic (e.g., creation offiledata
, permission checks) into a helper to reduce future maintenance effort.
434-460
: Unexcuse flow.
Looks consistent with excuse flow. Ifsubmission
is nil oraud
is nil, consider quickly failing with a user-facing message rather than quietly proceeding.app/views/assessments/_excuse_popover.html.erb (1)
9-9
: Consider adding an explicithref
or event handler for the "CANCEL" button.
Currently, the "CANCEL" button has nohref
or JavaScript event handler. If it is intended to close the popover or navigate back, consider adding the appropriatehref
or click handler for clarity and user guidance.spec/features/manage_submissions_spec.rb (1)
31-31
: Expand or remove the TODO-style comment to ensure clarity of test coverage.
A single-line comment stating “Check user flow for adding tweaks is okay” provides limited context. Consider elaborating on the expected behavior or removing the comment if it’s already captured by actual test code.app/views/submissions/_annotation_form.html.erb (1)
26-31
: Enrich the conditional select element with labeling and default states.
Whenpopup
is true, the problem ID select field appears. Consider adding a label for accessibility (e.g.,<label for="problem-id">
) and a default “Select a problem” placeholder option to guide users, especially if multiple problems share similar names.app/assets/javascripts/annotations_helpers.js (3)
63-63
: UseNumber.isNaN
instead of globalisNaN
isNaN
can produce unexpected results due to type coercion. PreferNumber.isNaN
for safer numeric checks.- if (isNaN(n)) n = 0; + if (Number.isNaN(n)) n = 0;🧰 Tools
🪛 Biome (1.9.4)
[error] 63-63: isNaN is unsafe. It attempts a type coercion. Use Number.isNaN instead.
See the MDN documentation for more details.
Unsafe fix: Use Number.isNaN instead.(lint/suspicious/noGlobalIsNan)
73-73
: Avoid redeclaring function parameterYou are shadowing the
problem_id
function parameter by redeclaring it usingvar
. Rename the local variable to avoid potential confusion.function getProblemNameWithId(problem_id) { - var problem_id = parseInt(problem_id, 10); + const parsedProblemId = parseInt(problem_id, 10); var problem = _.findWhere(problems, { id: parsedProblemId }); if (problem == undefined) return "Deleted Problem(s)"; return problem.name; }🧰 Tools
🪛 Biome (1.9.4)
[error] 73-73: Shouldn't redeclare 'problem_id'. Consider to delete it or rename it.
'problem_id' is defined here:
(lint/suspicious/noRedeclare)
[error] 73-73: This variable is used before its declaration.
The variable is declared here:
(lint/correctness/noInvalidUseBeforeDeclaration)
85-85
: ReplacehasOwnProperty
withObject.hasOwn()
Silence the linter warning and align with recommended safer practices by calling
Object.hasOwn()
.- if (a.hasOwnProperty(attr)) + if (Object.hasOwn(a, attr))🧰 Tools
🪛 Biome (1.9.4)
[error] 85-85: Do not access Object.prototype method 'hasOwnProperty' from target object.
It's recommended using Object.hasOwn() instead of using Object.hasOwnProperty().
See MDN web docs for more details.(lint/suspicious/noPrototypeBuiltins)
spec/features/assessment_spec.rb (1)
103-104
: XPath usage clarityUsing
./parent::td
is a workable approach. However, consider a more direct selector for improved clarity (e.g., selecting the<tr>
directly). This is optional, as the current test still appears maintainable.app/assets/javascripts/annotations_popup.js (4)
1-7
: Consider adding error-handling or retry logic.
updateEditTweakButtons()
callsget_tweak_total
without a.catch()
block. If any request fails, there is no fallback path or messaging for the user. You might also want to display partial results while skipping the failures to improve resiliency.
8-23
: Use jQuery deferred or fetch-based promises directly.
get_tweak_total()
wraps$.ajax()
in a manually created Promise. Instead, consider using jQuery’s built-in promise methods (.done()
,.fail()
) orfetch()
+async/await
to streamline code and reduce potential promise mishandling.
24-103
: Consider breaking down the function for maintainability.
newAnnotationFormCode()
handles clone creation, UI event wiring, problem list generation, and form validation in a single block. Extract smaller helper functions (e.g.,populateProblemSelect()
,bindAnnotationEvents()
) for improved readability and testability.
138-157
: Add more granular success feedback to users.
updateAnnotation()
updates an annotation via AJAX but removes the UI only on success. Consider indicating a loading state before success and a confirmation message afterward, to assure users that their update was applied.app/views/submissions/view.html.erb (1)
1-1
: Enhance clarity with a short comment.You’re conditionally setting the page title to "Annotate Submission" only if the user is an instructor or course assistant. A brief comment explaining this logic can help future maintainers quickly identify why the title changes based on roles.
config/routes.rb (1)
223-224
: Prevent confusion of route naming.
excuse_popover
is introduced here, whileexcuse_batch
andunexcuse
appear at the collection level. Ensure naming is consistent and that it accurately reflects each action’s scope and behavior (singular vs. batch).spec/controllers/submissions_controller_spec.rb (3)
11-15
: Avoid unused lookups or store them in variables for clarity.
Currently,Course.find(cid).name
andAssessment.find(assessment_id).name
are being called, but their return values are not used or stored. If the intent is simply to verify presence, consider adding assertions or storing the names in a variable for clarity.
25-30
: Reduce duplication of retrieval logic.
This block replicates the logic from lines 11–15 above to fetchcud
,cid
,assessment_id
, and names. Consider extracting these lookups into a helper method or a before block to reduce duplication.
163-163
: Prevent potential duplication in “destroy-confirm-check”.
This line mirrors the logic in line 150. If you anticipate different behavior in different contexts, clarify or factor it out to a shared line. Otherwise, ensure the parameter presence is strictly enforced in the controller.app/models/submission.rb (1)
399-402
: Guard output inas_json
more thoroughly.
You’re already conditionally exposing scores and penalties only ifseen_by
is present. Consider logging or handling the scenario whereseen_by
isn’t provided or is unexpected.app/assets/stylesheets/_variables.scss (1)
14-23
: Maintain a consistent naming convention for newly added color variables.The new variables greatly enhance maintainability and consistency. However, notice that some variables use “gray” while others use “grey.” Standardizing on one naming approach (e.g., “grey”) may improve consistency across the codebase.
app/assets/stylesheets/datatable.adapter.css (6)
5-7
: Enhance layout consistency around.dataTables_filter
.The added padding and margin help spacing, but verify that the left float in
.dataTables_filter
still meets user interface expectations across different viewport sizes and themes.
10-11
: Ensure consistent font usage for.dataTables_filter input
.Specifying
"Source Sans Pro", sans-serif
directly here can cause inconsistency if other components rely on a shared font variable. Consider centralizing font declarations in a shared stylesheet or_variables.scss
for maintainability.
41-42
: Duplicate cursor property.
.paginate_button, .paginate_active
setscursor
twice:pointer
andhand
. Thehand
is non-standard in modern CSS. Remove or unify the cursor property to avoid confusion.a.paginate_button, a.paginate_active { display: inline-block; padding: 2px 4px; margin-left: 2px; - cursor: pointer; - cursor: hand; + cursor: pointer; }
49-53
: Improve button container alignment.The
.dt-buttons
container usesflex-wrap: wrap
with a fixed height of 75px. Depending on content, buttons may overflow or appear truncated. Consider removing the fixed height if you want truly responsive wrap behavior.
56-58
: Spacing between buttons.
.dt-button { margin-right: 10px !important; }
helps keep buttons tidy, but watch out for unintended spacing if the design eventually changes or if other utilities set global margins. Consolidate margin in one place to maintain layout consistency.
64-65
: Review margin around icons.
.dt-button i { margin: 0 6px 0 4px; }
ensures separation from surrounding text or elements, but if you add more icons, an inconsistent spacing approach could complicate design. Consider a reusable or variables-based approach for icon spacing too.app/assets/stylesheets/style.css.scss (3)
825-839
: Consider using CSS custom properties for magic numbers.The styles are well-structured, but consider extracting magic numbers into CSS custom properties for better maintainability.
+:root { + --submissions-td-padding: 5px; + --checkbox-left-spacing: 6px; + --checkbox-checked-left-spacing: 3px; +} + .submissions-td { border-style: none; - padding: 5px 0 5px 0; + padding: var(--submissions-td-padding) 0; } .submissions-cbox-label { display: flex; justify-content: center; span::before { - left: 6px; + left: var(--checkbox-left-spacing); }; [type="checkbox"]:checked + span:not(.lever):before { - left: 3px; + left: var(--checkbox-checked-left-spacing); }; }
1129-1136
: Use design system variables for colors.Replace hardcoded color values with design system variables for consistency.
.switch > label > b { font-size: 1.1rem; - color: black + color: $autolab-black; } label[for="switch"] { font-size: 1rem; - color: darkslategrey; + color: $autolab-dark-grey; }
1560-1724
: Well-structured styles with room for improvement.The manage submissions styles are well-organized and follow BEM naming convention. Consider these improvements:
- Simplify long selectors
- Extract magic numbers to CSS custom properties
- Consolidate button styles
+:root { + --submissions-button-padding: 5px; + --submissions-icon-spacing: 6px; + --submissions-border-radius: 11px; + --submissions-popover-padding: 12px; +} + +/* Base button styles */ +.btn--submissions { + margin: 0; + padding: var(--submissions-button-padding); + display: flex; + align-items: center; +} + .btn.submissions-main { - margin: 0; + @extend .btn--submissions; padding: 5px 10px 5px 5px; min-height: 36px; height: auto; line-height: 1.3; - display: flex; - align-items: center; } .btn.submissions-selected { - margin: 0; + @extend .btn--submissions; margin-right: 10px; padding: 0px 10px 0px 5px; - display: flex; }The styles are functional and maintainable, but these improvements would make them even more robust.
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (34)
app/assets/javascripts/annotations_helpers.js
(1 hunks)app/assets/javascripts/annotations_popup.js
(1 hunks)app/assets/javascripts/autolab_component.js
(1 hunks)app/assets/javascripts/manage_submissions.js
(1 hunks)app/assets/stylesheets/_variables.scss
(1 hunks)app/assets/stylesheets/annotations.scss
(0 hunks)app/assets/stylesheets/assessments.scss
(1 hunks)app/assets/stylesheets/assessments/quiz.css.scss
(1 hunks)app/assets/stylesheets/datatable.adapter.css
(2 hunks)app/assets/stylesheets/gradesheet.css.scss
(2 hunks)app/assets/stylesheets/instructor_gradebook.scss
(1 hunks)app/assets/stylesheets/manage_submissions.css
(1 hunks)app/assets/stylesheets/style.css.scss
(10 hunks)app/controllers/annotations_controller.rb
(1 hunks)app/controllers/assessments_controller.rb
(2 hunks)app/controllers/submissions_controller.rb
(10 hunks)app/form_builders/form_builder_with_date_time_input.rb
(1 hunks)app/helpers/application_helper.rb
(2 hunks)app/models/assessment.rb
(1 hunks)app/models/submission.rb
(2 hunks)app/views/assessments/_excuse_popover.html.erb
(1 hunks)app/views/assessments/show.html.erb
(1 hunks)app/views/submissions/_annotation.html.erb
(1 hunks)app/views/submissions/_annotation_form.html.erb
(1 hunks)app/views/submissions/_annotation_global.html.erb
(1 hunks)app/views/submissions/_annotation_popup.html.erb
(1 hunks)app/views/submissions/index.html.erb
(1 hunks)app/views/submissions/view.html.erb
(1 hunks)config/initializers/assets.rb
(1 hunks)config/routes.rb
(2 hunks)db/schema.rb
(1 hunks)spec/controllers/submissions_controller_spec.rb
(5 hunks)spec/features/assessment_spec.rb
(1 hunks)spec/features/manage_submissions_spec.rb
(1 hunks)
💤 Files with no reviewable changes (1)
- app/assets/stylesheets/annotations.scss
✅ Files skipped from review due to trivial changes (5)
- app/models/assessment.rb
- app/assets/stylesheets/assessments.scss
- app/assets/stylesheets/gradesheet.css.scss
- app/assets/stylesheets/manage_submissions.css
- app/form_builders/form_builder_with_date_time_input.rb
🧰 Additional context used
🪛 Biome (1.9.4)
app/assets/javascripts/annotations_helpers.js
[error] 85-85: Do not access Object.prototype method 'hasOwnProperty' from target object.
It's recommended using Object.hasOwn() instead of using Object.hasOwnProperty().
See MDN web docs for more details.
(lint/suspicious/noPrototypeBuiltins)
[error] 73-73: Shouldn't redeclare 'problem_id'. Consider to delete it or rename it.
'problem_id' is defined here:
(lint/suspicious/noRedeclare)
[error] 73-73: This variable is used before its declaration.
The variable is declared here:
(lint/correctness/noInvalidUseBeforeDeclaration)
[error] 63-63: isNaN is unsafe. It attempts a type coercion. Use Number.isNaN instead.
See the MDN documentation for more details.
Unsafe fix: Use Number.isNaN instead.
(lint/suspicious/noGlobalIsNan)
🔇 Additional comments (42)
app/views/submissions/index.html.erb (6)
56-72
: Enhanced button UI for submission management.
These changes introduce new submission management buttons. Be sure to confirm that each button’s route or path is only displayed to authorized users, especially for operations like “Download Final Submissions.”
80-86
: Good addition for managing extensions.
The “Manage Extensions” link is straightforward and consistent. Double-check user role checks (instructor vs. assistant) to ensure only authorized roles can manage extensions.
126-155
: Sortable columns logic looks consistent.
The dynamic insertion of icons and listening for sort actions is workable. Watch out for potential indexing issues if a column’s label changes, since you rely on exact string matches.
230-250
: Confirm autograded logic.
This block checks@autograded
to conditionally show a “Regrade” icon. Ensure that regrading is locked behind instructor or CA roles to avoid revealing it to unauthorized users.
159-186
: Ensure correct reference toignored_submission_style
helper.
The inline style callsignored_submission_style submission
. Verify that the helper is well-defined and handles edge cases (e.g., submission is nil).
44-49
: Validate external script dependencies.
Check that each included JavaScript plugin (e.g.,datatables-buttons
) is up-to-date and compatible with the existing code. Outdated plugins can introduce performance or security concerns.✅ Verification successful
Let me gather more information about the JavaScript dependencies.
Let me check the content of these JavaScript files to understand the dependency usage better.
Let me check how these external scripts are being loaded by looking at the helper implementation.
External script dependencies are properly managed through CDN with specific versions
Based on the verification, the external JavaScript dependencies are well-managed through Cloudflare's CDN with explicit version pinning in the
external_javascript_include_tag
helper:
- jquery-ui: v1.13.2 (latest stable version)
- jquery.dataTables: v1.13.4 (recent stable version)
- datatables-buttons: loaded from DataTables CDN (follows the DataTables version)
The implementation shows careful version management and use of official CDN sources, which helps with both security and performance. The dependencies are up-to-date and compatible with each other.
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Searching for plugin versions mentioned in the codebase rg "datatables-buttons" -A 2Length of output: 307
Script:
#!/bin/bash # Check for version information in package.json or similar files fd -e json | xargs rg -l "datatables|jquery-ui" # Look for any configuration files related to these dependencies fd "config|webpack" | xargs rg -l "datatables|jquery-ui" # Check for any asset manifest files fd "manifest|assets" | xargs rg -l "datatables|jquery-ui"Length of output: 297
Script:
#!/bin/bash # Check gradesheet.js.erb for DataTables/jQuery UI usage rg -A 3 "datatables|jquery-ui|DataTable" app/assets/javascripts/gradesheet.js.erb # Check gradebook.js for DataTables/jQuery UI usage rg -A 3 "datatables|jquery-ui|DataTable" app/assets/javascripts/gradebook.js # Look for external script loading patterns rg "external_javascript_include_tag" -A 1Length of output: 3650
Script:
#!/bin/bash # Check the implementation of external_javascript_include_tag helper cat app/helpers/application_helper.rbLength of output: 6943
app/assets/javascripts/manage_submissions.js (9)
1-4
: Centralize endpoint definitions.
Storing endpoints in a dedicatedmanage_submissions_endpoints
object is excellent for maintainability. Consider adding error handling or fallback logic if an endpoint is missing.
39-49
: Good pattern for dynamic path construction.
selectSubmission
updates path variables for annotations. Ensure that you sanitize or validate them if user-provided data is involved.
51-64
: Popup invocation flow.
selectTweak
triggers a modal after retrieving data. Double-check that all event handlers (.modal('open')
, etc.) are properly unbound on closure to avoid memory leaks if triggered repeatedly.
149-176
: Conditional display of submission details.
This block effectively renders each submission in a table row. Double-check that empty or invalid data forsubmission.filename
orsubmission.problems
is handled gracefully.
222-245
:selectedStudentCids
vs.selectedSubmissions
.
Tracking separate arrays is useful but be sure to keep them in sync. If an unexpected code path modifies one without handling the other, there could be inconsistent states.
246-308
: Batch button state toggles are well-organized.
changeButtonStates
reassigns thehref
with query params for each button. This is a clever approach—just confirm that large sets of selected submissions don’t exceed query string limits.
310-362
: Efficient row toggling.
ThetoggleRow
logic is well-structured. Confirm that removing a submission’s selection also removes its course_user_datum’s ID fromselectedStudentCids
if no other submission from that CUD is selected.
363-369
: Checkbox click differentiation.
Skipping event propagation for<input>
elements prevents accidental row toggling, which is user-friendly. No concerns here.
384-459
: Popover logic for excuses.
The popover flow is intuitive but be aware of potential concurrency if multiple popovers open quickly. For best UX, ensure only one popover is open at once—a scenario you’re already handling withcurrent_popover
.app/controllers/submissions_controller.rb (5)
13-14
: Checklist for newly added actions.
Includingtweak_total
in thebefore_action
list is consistent, but ensure it cannot be accessed by non-instructors if that would cause unintended data disclosure.
22-37
: Efficient data structure for@submissions_to_cud
.
Building a hash of submission IDs to CUD IDs is straightforward. Performance is fine for moderate submission counts. For extremely large classes, consider building a more direct DB query approach.
180-187
: Destructive action uses confirm-check.
This pattern is good, ensuring an intentional user action. However, if integrators bypass the UI, we rely onparams["destroy-confirm-check"]
still. Consider server-side role checks.
379-432
: Excusing multiple submissions.
Implementation is clear. One small potential improvement is to handle partial successes (some but not all submissions excused) with more granular feedback.
867-873
: Role-based redirect.
appropriate_redirect_path
cleanly routes TAs vs. students. Watch for new roles in the future that might not fit this logic.app/views/submissions/_annotation_popup.html.erb (1)
1-6
: Popup structure is well-defined.
Using a base hidden annotation line (.base-annotation-line
) is a good approach for dynamic form clones. Verify that the partial_annotation_form
has everything required for the popup context, e.g., ID uniqueness.app/views/submissions/_annotation_global.html.erb (1)
3-3
: Explicitpopup: false
parameter.
The additional argument clarifies usage in a non-popup context. Good consistency with_annotation_popup.html.erb
, preventing collisions or unexpected behavior.app/views/assessments/_excuse_popover.html.erb (1)
10-14
: Verify the unexcuse path and ensure users understand the action.
Linking directly tounexcuse_course_assessment_submissions_path
withmethod: :post
indicates a destructive action, so confirm that the user is aware it’s irreversible or has the ability to undo. Consider wrapping this link in a form with explicit labeling or adding an additional confirmation prompt for enhanced clarity.app/views/submissions/_annotation.html.erb (1)
7-7
: Confirm that passingpopup: false
aligns with the intended UI flow.
Adding thepopup: false
prop helps differentiate between in-page and popup annotations. Ensure that this updated behavior doesn’t conflict with other parts of the UI that may rely on popup-based conditions.app/controllers/annotations_controller.rb (1)
16-20
: Ensurefilename
fallback logic meets future file-handling needsThe conditional logic properly uses
@submission.handin_file_path
whenfilename
is blank. However, verify that other relevant file paths (e.g., multiple handin files) won’t be overlooked in the future.config/initializers/assets.rb (1)
41-42
: No issues with asset precompilation additionsThese additions ensure the new annotation JS files are compiled and served in production.
app/assets/javascripts/annotations_popup.js (1)
105-136
: Ensure concurrency safety when multiple annotations are submitted.
submitNewAnnotation()
sets global variables likefileNameStr
and does an AJAX POST without checking concurrency. If multiple submissions are triggered rapidly, the global state might be overwritten unexpectedly. Consider storing relevant data in local variables or scoping it to the form element.app/helpers/application_helper.rb (2)
8-10
: Validate that @Assessment is present before linking.
current_assessment_link
references@assessment.display_name
. In contexts without@assessment
, this might cause errors. Consider conditionally rendering the link only if@assessment
is defined.
189-190
: Maintain consistent DataTables version usage across the codebase.
jquery.dataTables
is upgraded to1.13.4
. Ensure other scripts or CDN references also match to avoid version conflicts or compatibility issues.config/routes.rb (1)
175-175
: Ensure authorized access.The
get "tweak_total"
route should be constrained to authorized users only, especially if it displays or modifies sensitive grading data. Validate that proper authorization checks are in place in the corresponding controller action.spec/controllers/submissions_controller_spec.rb (2)
150-150
: Confirm the destroy confirmation check.
Adding"destroy-confirm-check": "filled-in"
is a good way to ensure the user has confirmed their destructive action. Make sure the controller properly validates this parameter to avoid accidental deletions.
276-276
: Method rename consistency.
Renaming fromdownloadAll
todownload_all
aligns the test suite with Rails conventions. Confirm there are no broken references elsewhere in the test code or in the codebase.app/views/assessments/show.html.erb (1)
87-87
: Confirm that all references todownloadAll
are updated todownload_all
.
This updated link path properly reflects the renamed route and method. Double-check any partials or other views that might still reference the old path.db/schema.rb (1)
111-111
: Validate usage of the newhas_svn
column.
Ensure this new boolean attribute is backed by appropriate validations or conditionals if it drives new functionality. Without a default value specified, ensure this field is properly set or handled in migrations and forms.app/models/submission.rb (1)
258-260
: Expose or document usage ofglobal_annotations
.
This new method returns only global comments. Make sure whatever calls this method handles shared vs. global logic consistently and that the naming is clear to both maintainers and consumers.app/controllers/assessments_controller.rb (1)
48-50
: Clarify authorization for the new manage submissions action.By introducing
action_auth_level :excuse_popover, :course_assistant
, you've allowed TAs (course assistants) to access theexcuse_popover
action. Ensure this aligns with the intended scope of who can manage submission excuses (e.g., TAs vs. instructors). If the design calls for more specific role-based restrictions, consider adjusting the authorization.app/assets/stylesheets/datatable.adapter.css (2)
43-46
: Sticky header improvement.Setting
position: sticky
on table headers is helpful for large tables. Ensure you also handle potential z-index stacking contexts (e.g., nested containers) so the sticky header doesn’t appear behind other elements.
60-61
: Use a standard layout approach for.dt-button span
.
.dt-button span { display: flex; }
is quite flexible but might conflict with certain inline elements or icons. Confirm that the child elements rendering inside the<span>
remain visually aligned as intended.app/assets/stylesheets/assessments/quiz.css.scss (1)
18-18
: Great adoption of the new variable$autolab-light-grey
.Switching from a hardcoded color to a variable boosts consistency across the application. Ensure this variable is also applied where similar shades of grey were used, to maximize consistency.
app/assets/stylesheets/instructor_gradebook.scss (1)
136-136
: LGTM! Good use of design system variable.Using
$autolab-light-grey
instead of a hardcoded color value improves maintainability and ensures color consistency across the application.app/assets/stylesheets/style.css.scss (2)
754-754
: LGTM! Good use of design system variables.Using
$autolab-sky-blue
,$autolab-light-grey
, and$autolab-black
instead of hardcoded color values improves maintainability and ensures color consistency.Also applies to: 774-775
785-819
: LGTM! Well-structured sorting styles.The sorting styles are well-organized and follow BEM naming convention. The icon visibility toggling is handled cleanly.
$('.score-details').on('click', function () { | ||
// Get the email | ||
const course_user_datum_id = $(this).data('cuid'); | ||
const email = $(this).data('email'); | ||
|
||
var ids = []; | ||
$("input[type='checkbox']:checked").each(function() { | ||
ids.push($(this).val()); | ||
}); | ||
// Set the email | ||
$('#score-details-email').html(email); | ||
|
||
// Clear the modal content | ||
$('#score-details-content').html(''); | ||
|
||
// Add a loading bar | ||
$('#score-details-content').html(` | ||
<div class="progress"> | ||
<div class="indeterminate"></div> | ||
</div>`); | ||
|
||
// Open the modal | ||
$('#score-details-modal').modal('open'); | ||
|
||
// Fetch data and render it in the modal | ||
get_score_details(course_user_datum_id).then((data) => { | ||
const problem_headers = data.submissions[0].problems.map((problem) => { | ||
const max_score = problem.max_score; | ||
const autograded = problem.grader_id == null || problem.grader_id < 0 ? " (Autograded)" : ""; | ||
return `<th class="submission-th"> | ||
${problem.name} | ||
<br> | ||
<i> ${max_score} ${autograded} </i> | ||
</th>`; | ||
}).join(''); | ||
|
||
tweaks = []; | ||
|
||
var selectedSubmissions = []; | ||
const submissions_body = data.submissions.map((submission) => { | ||
const Tweak = new AutolabComponent(`tweak-value-${submission.id}`, { amount: null }); | ||
Tweak.template = function () { | ||
return EditTweakButton( this.state.amount ); | ||
} | ||
tweaks.push({tweak: Tweak, submission_id: submission.id, submission}); | ||
|
||
var initialBatchUrl = $("#batch-regrade").prop("href"); | ||
let tweak_value = data?.tweaks[submission.id]?.value ?? "None"; | ||
if (tweak_value != "None" && tweak_value > 0) { | ||
tweak_value = `+${tweak_value}`; | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Score details modal logic.
Populating HTML via innerHTML
is flexible but raises a potential for XSS if data
or email
is not sanitized server-side. Ensure content from the server is safe or properly escaped.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
🧹 Nitpick comments (7)
app/assets/stylesheets/style.css.scss (7)
781-793
: Consider using CSS Grid for better alignment.The nested flex layout for table headers could be simplified using CSS Grid for better maintainability.
.submissions-th { padding: 25px 0 25px 0; font-size: 0.9rem; div { - display: flex; - align-items: center; + display: grid; + grid-template-columns: auto auto; + align-items: center; + gap: 3px; } p { margin: 0; - float: left; - padding-right: 3px; } }
795-815
: Consider using a more maintainable approach for sort icons.The current implementation requires three separate icon elements in the HTML. Consider using a single icon element with CSS transforms.
-.sorting_desc { - .sort-icon__both, .sort-icon__up { - display: none; - } - .sort-icon__down { - display: inline; - } -} -.sorting_asc { - .sort-icon__both, .sort-icon__down { - display: none; - } - .sort-icon__up { - display: inline; - } -} - -.sort-icon__up, .sort-icon__down { - display: none; -} +.sort-icon { + transition: transform 0.2s ease; +} + +.sorting_desc .sort-icon { + transform: rotate(180deg); +}
821-835
: Improve checkbox alignment using CSS custom properties.The hardcoded pixel values for checkbox positioning could be replaced with CSS custom properties for better maintainability.
+:root { + --checkbox-offset: 6px; + --checkbox-checked-offset: 3px; +} + .submissions-cbox-label { display: flex; justify-content: center; span::before { - left: 6px; + left: var(--checkbox-offset); }; [type="checkbox"]:checked + span:not(.lever):before { - left: 3px; + left: var(--checkbox-checked-offset); }; }
1125-1132
: Use consistent font size units.The switch label uses both
rem
and absolute units. Consider usingrem
consistently for better scalability..switch > label > b { font-size: 1.1rem; color: black } label[for="switch"] { - font-size: 1rem; + font-size: 1rem; color: darkslategrey; }
1496-1499
: Use CSS custom property for animation.Consider extracting the rotation value to a CSS custom property for reusability.
+:root { + --rotation-full: 360deg; +} + @keyframes spin { from { transform: rotate(0deg); } to { - transform: rotate(360deg); + transform: rotate(var(--rotation-full)); } }
1537-1538
: Simplify box shadow declaration.The multiple box shadow declarations can be combined into a single, more maintainable rule.
- box-shadow: 0px -0.5px 0.5px 0px rgba(0, 0, 0, 0.15), - 0px 0.5px 0.5px 0.5px rgba(0, 0, 0, 0.15), - 0px 0.5px 0.5px -0.5px rgba(0, 0, 0, 0.15); + box-shadow: 0px 0px 1px 0px rgba(0, 0, 0, 0.15);
1554-1720
: Well-structured submissions management styles.The new submissions management styles are well-organized and follow good SCSS practices:
- Proper use of BEM-like naming conventions
- Logical grouping of related styles
- Consistent use of SCSS variables
- Clear separation of concerns
A few suggestions for improvement:
- Consider grouping related styles into separate partial files
- Add comments to document complex style interactions
- Consider using CSS Grid for some of the flex layouts
Example of extracting to a partial:
// _submissions.scss @import 'variables'; .submissions { &-main { ... } &-selected { ... } // ... other submission-related styles }
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (1)
app/assets/stylesheets/style.css.scss
(10 hunks)
🔇 Additional comments (2)
app/assets/stylesheets/style.css.scss (2)
689-691
: Remove duplicate CSS declaration.The
.field_with_errors
class is declared twice in the file. This is a duplicate of the existing declaration at line 28.
750-750
: Good use of SCSS variables!The change from hardcoded colors to SCSS variables (
$autolab-sky-blue
,$autolab-light-grey
,$autolab-black
) improves maintainability and consistency.Also applies to: 770-771
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Overall functionality works, I tested create submission, download final submissions, missing submissions, manage extensions, and regrade/delete/download/excuse selected.
One large issue I found was that after regrading a submission from create submission, the regrade was successful, but the updated score does not show up in the score column.
Other smaller issues that we can potentially address later (or ask new members to try fixing):
- Search bar is unintuitive, if you type the exact string the expected user shows up, but a bunch of unexpected users also show up. (eg. searching for "john f" also returns "john k")
- Might be desirable to have some indication if the autograder has not been run on a submission if it was created through create submissions or missing submissions
Description
This is an initial PR for the revamp of Manage Submissions.
How Has This Been Tested?
Navigate to Manage Submissions. Test that all buttons work as expected.
Types of changes
Checklist:
overcommit --install && overcommit --sign
to use pre-commit hook for linting