-
Notifications
You must be signed in to change notification settings - Fork 9
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
✨ Applicant-facing PoolCandidate status chips #12164
Comments
@gobyrne the status Paused appears in the design, but not in the spreadsheet yet. Where is it supposed to fit? |
Paused is the status that should appear when an Applicant marks themselves as no longer interested on a Process they qualified in (not for an application). I'll summon a Josh. |
Josh removed "paused" from the list in slack. Let's just pull make it clear not to do it for this. |
If part of the purpose of this issue is to simplify statuses so that they are easier for everyone to understand, why is there a need to a two-tiered (internal, external) system for Unsuccessful? The statement "we’re unable to provide specific feedback why an application was rejected" also applies to the internal candidates. The other statement includes requesting an "informal conversation" which seems preferential to that of external opportunities and the statement to "please reach out to the functional community" is vague enough that with likely result in requests like "how do i reach out to the functional community". |
@tristan-orourke Strange policy, but if that is the case, why aren't there two statuses (government, non-government) for each real status? Creating a GC Digital Talent support ticket seems a circuitous and unintuitive way to get in touch with a functional community, no (unless functional communities are actually administered and owned by the GC Digital Talent helpdesk)? |
Currently the status chips are being computed on the client. Since the new statuses require access to assessments, this will not be possible. We will likely need to move this logic to the server. Since this reads from multiple tables, I don't think it would be very efficient to do this on fly and could be better if we store it as a computed value in the database similar to the final decision. |
Even if we ignore the assessment status and do this client side for now , it will not benefit us much for the release and we need to rewrite this anyways. |
For now, let's keep this logic on the frontend. We'll follow up with #12421 to make it work. |
@JamesHuf sorry for changing this after it's in dev, but I need you to remove the last 3 Recruitment Process statuses. We want to do a policy review before we re-implement them. I've crossed them off. Basically, once a user is in a recruitment process, they can toggle between "Open to jobs" and "Not interested". They don't get other information back about their status in the pool. |
@JamesHuf actually, please continue to show the "Hired" state as well. The description can be
I added a new tab to the spreadsheet to reflect this https://docs.google.com/spreadsheets/d/1ASOKPEV_FVbMM_cAs_e4o4i9eqn9RQiBsmRORYm6umE/edit?gid=810267830#gid=810267830 |
Not sure how to easily use tables in GitHub, so I'm attached a word file with the updated statuses, descriptions, and translations. status chips that need to be updated:
See the document for all the updated descriptions: 2025.01.17 Status table.docx |
✨ Feature
This task is to update the status chips used to represent the status of PoolCandidate objects to applicants.
Note: conceptuallly, PoolCandidate objects can be considered to represent two slightly different things at different points in their lifecycle. These are displayed separately, as Applications and as Recruitment Processes.
🕵️ Details
Status Pill logic - I attempted to work through the whole logic here
We only need to worry about showing a PoolCandidate object as a Recruitment Process if the user was Qualified in the process. ie finalDecisionAt is not null and finalDecision is one of
Note, QUALIFIED_PENDING indicates they're likely to be qualified, but finalDecision has not actually been made yet, and finalDecisionAt will be null. From the application's perspective, the application is still in assessment.
🎨 Design
@JoshBeveridge
[https://www.figma.com/design/oZhQe9ahidHFfaiqgREvxa/Dashboard-(All-users)?node-id=2086-63995&node-type=frame&t=1x50TV9VIcwOqroM-0](Figma link to where these appear in new dashboard designs.)
These statuses also appear on the old (current?) design, and thus this can be completed before #10788.
📸 Screenshot
Applications:
Recruitment processes:
🙋♀️ Proposed Implementation
Currently,
utils/poolCandidate.ts getCandidateStatusChip
generates the status chip that is shown to applicants when representing "Applications", whilecomponents/QualifiedRecruitmentCard/utils.ts getQualifiedRecruitmentInfo
generates the chip that appears to the applicant when represeinting a "Recruitment Process". I think we should move these both toutils/poolCandidate
, with some clear documentation on the distinctions. (computeInAssessmentStatusChip, also in utils/poolCandidate.ts, is shown to assessors.)Then, update the two functions which generate the chips shown to applicants, to match the logic described in this ticket and accompanying spreadsheet. Also, in addition to the color and label, these functions can return the longer description which matches them.
There's one case where the longer description for a status (Unsuccessful) differs depending on pool.areaOfSelection. (Pools which are only able to gov employees, not the public, allow unsuccessful applicants to reach out about why they were disqualified.) That means we may also have to pass pool.areaOfSelection into the getCandidateStatusChip function.
When it comes to distinguishing between Received, Under review, Pending assessment, and Under assessment, we can use the PoolCandidate.assessmentStatus (type AssessmentResultStatus).
If JobPoster has screening questions, numberOfApplicationScreeningSteps = 2. Otherwise numberOfApplicationScreeningSteps = 1.
If currentStep == 1 and assessmentStepStatuses is empty, status is Received
If currentStep <= numberOfApplicationScreeningSteps and assessmentStepStatuses is not empty, status is Under Review
If currentStep > numberOfApplicationScreeningSteps and length(assessmentStepStatus) <= numberOfApplicationScreeningSteps , status is Pending Assessment
If currentStep > numberOfApplicationScreeningSteps and length(assessmentStepStatus) > numberOfApplicationScreeningSteps , status is Under Assessment
🌎 Localization
Each status title, the thing that appears in a chip, has an associated longer description. See designs here: https://www.figma.com/design/oZhQe9ahidHFfaiqgREvxa/Dashboard-(All-users)?node-id=1721-27550&node-type=frame&t=1x50TV9VIcwOqroM-0
Applications
PausedYour application is still under review but has been paused due to missing information or a delay in the hiring process. If HR staff require information from you they will be in touch. We will notify you when your application review resumes.There is no paused status for applicationsRecruitment Processes (poolCandidates where Applicant is Qualified)
If you wish to continue receiving referrals, you can let us know by editing your status at the end of this dialog.ExpiredRecruitment processes usually retain talent for a limited amount of time, after which candidates need to be re-evaluated. If you're interested in similar roles, apply to opportunities on the "Browse jobs" page.RemovedYou’ve been removed from this recruitment process by HR staff due to unresponsiveness or another relevant reason. If you feel this was an error, please reach out to the functional community.✅ Acceptance Criteria
components/QualifiedRecruitmentCard/utils.ts getQualifiedRecruitmentInfo
with another function inutils/poolCandidate.ts
which returns colour, label, and description according to Recruitment process tab of spreadsheetThe text was updated successfully, but these errors were encountered: