From 0ece360ab51563f5bfee2c5ccf13102b08603e40 Mon Sep 17 00:00:00 2001 From: jcallison1 <152124968+jcallison1@users.noreply.github.com> Date: Fri, 20 Dec 2024 18:29:15 -0600 Subject: [PATCH] Improve documentation for units.js --- .../AdHocUpdateREADME.md | 20 +++++++++++++++++++ .../Admin/View/CompleteAssessmentTask/unit.js | 11 ++++++++++ 2 files changed, 31 insertions(+) create mode 100644 FrontEndReact/src/View/Admin/View/CompleteAssessmentTask/AdHocUpdateREADME.md diff --git a/FrontEndReact/src/View/Admin/View/CompleteAssessmentTask/AdHocUpdateREADME.md b/FrontEndReact/src/View/Admin/View/CompleteAssessmentTask/AdHocUpdateREADME.md new file mode 100644 index 000000000..5c9675eb1 --- /dev/null +++ b/FrontEndReact/src/View/Admin/View/CompleteAssessmentTask/AdHocUpdateREADME.md @@ -0,0 +1,20 @@ +!! Delete this file after Ad Hoc Teams have been integrated into unit.js and CompleteAssessmentTask.js !! + +Form.js and it's children have been transitioned to use units rather than reference specific database units. This allows Complete Assessment Task (CAT) data to be handled the same way regardless of the type of unit being handled. The logic for units is contained entirely in "unit.js" through the abstract class `ATUnit` and its children, `IndividualUnit` and `FixedTeamUnit`. These units are created in `generateUnitList()` and their own respective creation functions: `createIndividualUnit` and `createFixedTeamUnit`. An enum `UnitType` is used to help determine the type of a unit. + +"CompleteAssessmentTask.js" is in charge of fetching the unit information for all types of units from the backend, and calling `generateUnitList()` with the correct arguments. "unit.js" holds all of the logic for the unit classes and creation. + +Here's what we think will need to be changed to update these files for Ad Hoc teams: + +"CompleteAssessmentTask.js": +- Update Fetches to include Ad Hoc data +- Pass in new information into `generateUnitList()` + +"unit.js": +- Use ad hoc UnitType in enum +- Add new child class of ATUnit for ad hoc units +- Update unit list generation in generateUnitList +- Create new functions to createAdHocUnits +- Likely will need to track ad hoc team members with a CheckinTracker Object from cat_utils.js + +Check for any places that assume fixed teams. We removed as many of these as we could find, but we may have missed a couple. \ No newline at end of file diff --git a/FrontEndReact/src/View/Admin/View/CompleteAssessmentTask/unit.js b/FrontEndReact/src/View/Admin/View/CompleteAssessmentTask/unit.js index 1dd60f984..c64668a1f 100644 --- a/FrontEndReact/src/View/Admin/View/CompleteAssessmentTask/unit.js +++ b/FrontEndReact/src/View/Admin/View/CompleteAssessmentTask/unit.js @@ -10,6 +10,17 @@ export const UnitType = Object.freeze({ // ROCS Data - An object that stores information about how an assessment task has been completed. // This includes things like what checkboxes have been clicked and comments. This object // also includes information about the rubric it's based on. +// +// Structure: +// A map of rubric category names to category objects. +// Category objects: +// - comments: string - The comments for this category. +// - description: string - The description of this rubric category. This is the same as the description in the rubric itself. +// - observable_characteristics: string of 1s and 0s - Each 1 or 0 in the string represents if that checkbox is checked for Observable Characteristics. +// - suggestions: string of 1s and 0s - Has the same meaning as observable_characteristics except for Suggestions. +// - rating: integer - The rating for the category. +// - rating_json: map from tick mark position to tick mark name - Used for the tick mark names on the Ratings slider. +// This map also may contain "comments" and "done" entries. These are unused and a legacy artifact. // // Completed Assessment Task (CAT) - An object fetched by the completedAssessments route that // associates ROCS data and whether the AT is done or not with a user/team.