diff --git a/api/app/Models/Classification.php b/api/app/Models/Classification.php index b0fb7b235bb..60ef232398a 100644 --- a/api/app/Models/Classification.php +++ b/api/app/Models/Classification.php @@ -52,8 +52,7 @@ protected function displayName(): Attribute { /** @disregard P1003 Not using values */ return Attribute::make( - get: fn (mixed $value, array $attributes) => $attributes['group'].'-'.sprintf('%02d', $attributes['level']), - + get: fn (mixed $value, array $attributes) => $attributes['group'].'-'.($attributes['level'] < 10 ? '0' : '').$attributes['level'], ); } diff --git a/api/app/Models/User.php b/api/app/Models/User.php index be7b36b3b95..d94edb3fa80 100644 --- a/api/app/Models/User.php +++ b/api/app/Models/User.php @@ -358,7 +358,9 @@ public function getClassification() $classification = $this->currentClassification()->first(); - return $classification->group.'-0'.$classification->level; + $leadingZero = $classification->level < 10 ? '0' : ''; + + return $classification->group.'-'.$leadingZero.$classification->level; } public function getDepartment() diff --git a/apps/playwright/tests/search-workflows.spec.ts b/apps/playwright/tests/search-workflows.spec.ts index c34364f6320..aedddab0523 100644 --- a/apps/playwright/tests/search-workflows.spec.ts +++ b/apps/playwright/tests/search-workflows.spec.ts @@ -134,7 +134,7 @@ test.describe("Talent search", () => { await expectNoCandidate(appPage.page); await classificationFilter.selectOption({ - value: `${classification.group}-0${classification.level}`, + value: `${classification.group}-${classification.level < 10 ? "0" : ""}${classification.level}`, }); const streamFilter = appPage.page.getByRole("combobox", { @@ -221,7 +221,7 @@ test.describe("Talent search", () => { await expect( appPage.page.getByText( new RegExp( - `${classification.group}-0${classification.level}: search pool`, + `${classification.group}-${classification.level < 10 ? "0" : ""}${classification.level}: search pool`, "i", ), ), diff --git a/apps/web/src/components/ExperienceCard/WorkContent/GovContent.tsx b/apps/web/src/components/ExperienceCard/WorkContent/GovContent.tsx index 45514c8ffe1..e7f4100ff40 100644 --- a/apps/web/src/components/ExperienceCard/WorkContent/GovContent.tsx +++ b/apps/web/src/components/ExperienceCard/WorkContent/GovContent.tsx @@ -78,7 +78,7 @@ const GovContent = ({ headingLevel={headingLevel} > {classification - ? `${classification.group}-0${classification.level}` + ? `${classification.group}-${classification.level < 10 ? "0" : ""}${classification.level}` : intl.formatMessage(commonMessages.notAvailable)} @@ -122,7 +122,7 @@ const GovContent = ({ headingLevel={headingLevel} > {classification - ? `${classification.group}-0${classification.level}` + ? `${classification.group}-${classification.level < 10 ? "0" : ""}${classification.level}` : intl.formatMessage(commonMessages.notAvailable)} diff --git a/apps/web/src/components/ExperienceFormFields/WorkFields/GovFields.tsx b/apps/web/src/components/ExperienceFormFields/WorkFields/GovFields.tsx index 9a5fc905da4..9a60778f1dc 100644 --- a/apps/web/src/components/ExperienceFormFields/WorkFields/GovFields.tsx +++ b/apps/web/src/components/ExperienceFormFields/WorkFields/GovFields.tsx @@ -164,9 +164,10 @@ const GovFields = ({ labels }: SubExperienceFormProps) => { .map((iterator) => { return { value: iterator.id.toString(), // change the value to id for the query - label: iterator.level.toString(), + label: iterator.level, }; - }); + }) + .sort((a, b) => a.label - b.label); /** * Reset classification level when group changes @@ -356,6 +357,7 @@ const GovFields = ({ labels }: SubExperienceFormProps) => { uiMessages.nullSelectionOptionLevel, )} options={levelOptions} + doNotSort /> diff --git a/apps/web/src/components/PoolCandidatesTable/PoolCandidateFilterDialog.tsx b/apps/web/src/components/PoolCandidatesTable/PoolCandidateFilterDialog.tsx index 858332d61df..16d2177ee21 100644 --- a/apps/web/src/components/PoolCandidatesTable/PoolCandidateFilterDialog.tsx +++ b/apps/web/src/components/PoolCandidatesTable/PoolCandidateFilterDialog.tsx @@ -206,7 +206,7 @@ const PoolCandidateFilterDialog = ({ label={intl.formatMessage(adminMessages.classifications)} options={classifications.map(({ group, level }) => ({ value: `${group}-${level}`, - label: `${group}-0${level}`, + label: `${group}-${level < 10 ? "0" : ""}${level}`, }))} /> { const classificationAbbr = pool.classification ? wrapAbbr( - `${pool.classification.group}-0${pool.classification.level}`, + `${pool.classification.group}-${pool.classification.level < 10 ? "0" : ""}${pool.classification.level}`, intl, ) : ""; diff --git a/apps/web/src/components/Profile/components/GovernmentInformation/Display.tsx b/apps/web/src/components/Profile/components/GovernmentInformation/Display.tsx index 834be2480cf..da2e0fa4ffa 100644 --- a/apps/web/src/components/Profile/components/GovernmentInformation/Display.tsx +++ b/apps/web/src/components/Profile/components/GovernmentInformation/Display.tsx @@ -133,7 +133,7 @@ const Display = ({ > {!!currentClassification?.group && !!currentClassification?.level ? wrapAbbr( - `${currentClassification?.group}-${currentClassification?.level}`, + `${currentClassification?.group}-${currentClassification?.level < 10 ? "0" : ""}${currentClassification?.level}`, intl, ) : notProvided} diff --git a/apps/web/src/components/Profile/components/GovernmentInformation/FormFields.tsx b/apps/web/src/components/Profile/components/GovernmentInformation/FormFields.tsx index 21d451608ba..0ee79b85742 100644 --- a/apps/web/src/components/Profile/components/GovernmentInformation/FormFields.tsx +++ b/apps/web/src/components/Profile/components/GovernmentInformation/FormFields.tsx @@ -114,7 +114,10 @@ const FormFields = ({ ]); const groupOptions = getGroupOptions([...classifications], intl); - const levelOptions = getLevelOptions([...classifications], groupSelection); + const levelOptions = getLevelOptions( + [...classifications], + groupSelection, + ).sort((a, b) => a.value - b.value); const hasPriorityEntitlement = priorityEntitlement === "yes"; const isGovEmployee = govEmployee === "yes"; const isPlaced = @@ -272,6 +275,7 @@ const FormFields = ({ uiMessages.nullSelectionOptionLevel, )} options={levelOptions} + doNotSort /> )} diff --git a/apps/web/src/components/Profile/components/GovernmentInformation/utils.ts b/apps/web/src/components/Profile/components/GovernmentInformation/utils.ts index 4c0d7de3ad7..c14ba928ddd 100644 --- a/apps/web/src/components/Profile/components/GovernmentInformation/utils.ts +++ b/apps/web/src/components/Profile/components/GovernmentInformation/utils.ts @@ -239,7 +239,7 @@ export const getLevelOptions = ( .filter((x) => x.group === groupSelection) .map((iterator) => { return { - value: iterator.level.toString(), + value: iterator.level, label: iterator.level.toString(), }; }); diff --git a/apps/web/src/components/SearchRequestFilters/SearchRequestFilters.tsx b/apps/web/src/components/SearchRequestFilters/SearchRequestFilters.tsx index 7ebe703db46..231c250c2e3 100644 --- a/apps/web/src/components/SearchRequestFilters/SearchRequestFilters.tsx +++ b/apps/web/src/components/SearchRequestFilters/SearchRequestFilters.tsx @@ -44,14 +44,20 @@ const ApplicantFilters = ({ // else set values if filters prop is of ApplicantFilterInput type const classificationsFromBrowserHistory = selectedClassifications?.map( (classification) => - wrapAbbr(`${classification?.group}-0${classification?.level}`, intl), + wrapAbbr( + `${classification?.group}-${classification && classification?.level < 10 ? "0" : ""}${classification?.level}`, + intl, + ), ); const classifications = applicantFilter?.qualifiedClassifications ?? []; const classificationsFromApplicantFilter = classifications .filter(notEmpty) .map((classification) => - wrapAbbr(`${classification?.group}-0${classification?.level}`, intl), + wrapAbbr( + `${classification?.group}-${classification?.level < 10 ? "0" : ""}${classification?.level}`, + intl, + ), ); const skills: string[] | undefined = applicantFilter?.skills?.map((skill) => { @@ -270,7 +276,7 @@ const SearchRequestFilters = ({ const classifications: string[] | undefined = poolCandidateFilter?.classifications?.map( (classification) => - `${classification?.group.toLocaleUpperCase()}-0${classification?.level}`, + `${classification?.group.toLocaleUpperCase()}-${classification && classification?.level < 10 ? "0" : ""}${classification?.level}`, ); const pools: Pool[] | undefined = poolCandidateFilter diff --git a/apps/web/src/components/SearchRequestTable/components/SearchRequestFilterDialog.tsx b/apps/web/src/components/SearchRequestTable/components/SearchRequestFilterDialog.tsx index 7e0e8c7f665..b81f27c320d 100644 --- a/apps/web/src/components/SearchRequestTable/components/SearchRequestFilterDialog.tsx +++ b/apps/web/src/components/SearchRequestTable/components/SearchRequestFilterDialog.tsx @@ -129,7 +129,7 @@ const SearchRequestFilterDialog = ({ label={intl.formatMessage(adminMessages.classifications)} options={classifications.map((classification) => ({ value: classification.id, - label: `${classification.group}-0${classification.level}`, + label: `${classification.group}-${classification.level < 10 ? "0" : ""}${classification.level}`, }))} /> `${c.group}-0${c.level}`) + ?.map((c) => `${c.group}-${c.level < 10 ? "0" : ""}${c.level}`) ?.join(", "); } @@ -34,10 +34,10 @@ export function classificationsCell( const chipsArray = filteredClassifications.map((classification) => { return ( - {`${classification.group}-0${classification.level}`} + {`${classification.group}-${classification.level < 10 ? "0" : ""}${classification.level}`} ); }); diff --git a/apps/web/src/components/UserProfile/ProfileSections/GovernmentInformationSection.tsx b/apps/web/src/components/UserProfile/ProfileSections/GovernmentInformationSection.tsx index b7ffb25f791..dfb74a4ba1f 100644 --- a/apps/web/src/components/UserProfile/ProfileSections/GovernmentInformationSection.tsx +++ b/apps/web/src/components/UserProfile/ProfileSections/GovernmentInformationSection.tsx @@ -110,7 +110,7 @@ const GovernmentInformationSection = ({ {wrapAbbr( - `${currentClassification?.group}-${currentClassification?.level}`, + `${currentClassification?.group}-${currentClassification?.level < 10 ? "0" : ""}${currentClassification?.level}`, intl, )} diff --git a/apps/web/src/pages/Auth/RegistrationPages/EmployeeInformationPage/EmployeeInformationPage.tsx b/apps/web/src/pages/Auth/RegistrationPages/EmployeeInformationPage/EmployeeInformationPage.tsx index 91ff03e397b..9b1951ce399 100644 --- a/apps/web/src/pages/Auth/RegistrationPages/EmployeeInformationPage/EmployeeInformationPage.tsx +++ b/apps/web/src/pages/Auth/RegistrationPages/EmployeeInformationPage/EmployeeInformationPage.tsx @@ -136,10 +136,11 @@ export const EmployeeInformationFormFields = ({ .filter((x) => x.group === groupSelection) .map((iterator) => { return { - value: iterator.level.toString(), + value: iterator.level, label: iterator.level.toString(), }; - }); + }) + .sort((a, b) => a.value - b.value); const isGovEmployee = govEmployee === "yes"; @@ -345,6 +346,7 @@ export const EmployeeInformationFormFields = ({ uiMessages.nullSelectionOptionLevel, )} options={levelOptions} + doNotSort /> diff --git a/apps/web/src/pages/Classifications/CreateClassificationPage.tsx b/apps/web/src/pages/Classifications/CreateClassificationPage.tsx index d1b57cdc1b3..0c0f243ddab 100644 --- a/apps/web/src/pages/Classifications/CreateClassificationPage.tsx +++ b/apps/web/src/pages/Classifications/CreateClassificationPage.tsx @@ -21,6 +21,7 @@ import pageTitles from "~/messages/pageTitles"; import Hero from "~/components/Hero"; import messages from "./messages"; +import { getClassificationLevels } from "./helpers"; type FormValues = CreateClassificationInput; @@ -168,17 +169,8 @@ export const CreateClassification = () => { rules={{ required: intl.formatMessage(errorMessages.required), }} - options={[ - { value: 1, label: "1" }, - { value: 2, label: "2" }, - { value: 3, label: "3" }, - { value: 4, label: "4" }, - { value: 5, label: "5" }, - { value: 6, label: "6" }, - { value: 7, label: "7" }, - { value: 8, label: "8" }, - { value: 9, label: "9" }, - ]} + options={getClassificationLevels()} + doNotSort /> { .sort((a, b) => a.level - b.level) .map((classification) => ({ value: classification.id, - label: `${classification.group}-0${classification.level}`, + label: `${classification.group}-${classification.level < 10 ? "0" : ""}${classification.level}`, }))} /> ({ - value: id, - label: `${group}-0${level} (${getLocalizedName(name, intl)})`, - }), + ({ id, group, level, name }) => { + return { + value: id, + label: `${group}-${level < 10 ? "0" : ""}${level} (${getLocalizedName(name, intl)})`, + }; + }, ); const departmentOptions: Option[] = departments.map(({ id, name }) => ({ diff --git a/apps/web/src/pages/Pools/EditPoolPage/components/EducationRequirementsSection.tsx b/apps/web/src/pages/Pools/EditPoolPage/components/EducationRequirementsSection.tsx index faf4c63c97e..4aab2dde610 100644 --- a/apps/web/src/pages/Pools/EditPoolPage/components/EducationRequirementsSection.tsx +++ b/apps/web/src/pages/Pools/EditPoolPage/components/EducationRequirementsSection.tsx @@ -87,7 +87,10 @@ const EducationRequirementsSection = ({ }); const classificationGroup = pool.classification?.group; const classificationAbbr = pool.classification - ? wrapAbbr(`${classificationGroup}-0${pool.classification.level}`, intl) + ? wrapAbbr( + `${classificationGroup}-${pool.classification.level < 10 ? "0" : ""}${pool.classification.level}`, + intl, + ) : ""; return ( diff --git a/apps/web/src/pages/Pools/EditPoolPage/components/PoolNameSection/utils.ts b/apps/web/src/pages/Pools/EditPoolPage/components/PoolNameSection/utils.ts index 7bb9f1a53ae..2c844ba9138 100644 --- a/apps/web/src/pages/Pools/EditPoolPage/components/PoolNameSection/utils.ts +++ b/apps/web/src/pages/Pools/EditPoolPage/components/PoolNameSection/utils.ts @@ -91,7 +91,7 @@ export const getClassificationOptions = ( ): Option[] => { return classifications.filter(notEmpty).map(({ id, group, level, name }) => ({ value: id, - label: `${group}-0${level} (${getLocalizedName(name, intl)})`, + label: `${group}-${level < 10 ? "0" : ""}${level} (${getLocalizedName(name, intl)})`, })); }; diff --git a/apps/web/src/pages/Pools/IndexPoolPage/components/PoolFilterDialog.tsx b/apps/web/src/pages/Pools/IndexPoolPage/components/PoolFilterDialog.tsx index 0b5136fd9dc..bb3716cc797 100644 --- a/apps/web/src/pages/Pools/IndexPoolPage/components/PoolFilterDialog.tsx +++ b/apps/web/src/pages/Pools/IndexPoolPage/components/PoolFilterDialog.tsx @@ -108,7 +108,7 @@ const PoolFilterDialog = ({ options={unpackMaybes(data?.classifications).map( ({ group, level }) => ({ value: `${group}-${level}`, - label: `${group}-0${level}`, + label: `${group}-${level < 10 ? "0" : ""}${level}`, }), )} /> diff --git a/apps/web/src/pages/Pools/IndexPoolPage/components/helpers.tsx b/apps/web/src/pages/Pools/IndexPoolPage/components/helpers.tsx index 05a98208d70..24e4d60aaf5 100644 --- a/apps/web/src/pages/Pools/IndexPoolPage/components/helpers.tsx +++ b/apps/web/src/pages/Pools/IndexPoolPage/components/helpers.tsx @@ -88,7 +88,7 @@ export function classificationAccessor( classification: Maybe> | undefined, ) { return classification - ? `${classification.group}-0${classification.level}` + ? `${classification.group}-${classification.level < 10 ? "0" : ""}${classification.level}` : ""; } @@ -99,7 +99,7 @@ export function classificationCell( return ( - {`${classification.group}-0${classification.level}`} + {`${classification.group}-${classification.level < 10 ? "0" : ""}${classification.level}`} ); } diff --git a/apps/web/src/pages/SearchRequests/SearchPage/utils.ts b/apps/web/src/pages/SearchRequests/SearchPage/utils.ts index cda3a7fc2e0..191c76985fe 100644 --- a/apps/web/src/pages/SearchRequests/SearchPage/utils.ts +++ b/apps/web/src/pages/SearchRequests/SearchPage/utils.ts @@ -25,7 +25,7 @@ export const getClassificationLabel = ( labels: Record, intl: IntlShape, ) => { - const key = `${group}-0${level}`; + const key = `${group}-${level < 10 ? "0" : ""}${level}`; return !hasKey(labels, key) ? key : intl.formatMessage(labels[key]); }; diff --git a/apps/web/src/utils/nameUtils.tsx b/apps/web/src/utils/nameUtils.tsx index f83f670f306..3ad0b652ee3 100644 --- a/apps/web/src/utils/nameUtils.tsx +++ b/apps/web/src/utils/nameUtils.tsx @@ -148,7 +148,7 @@ export const wrapAbbr = (text: ReactNode, intl: IntlShape, title?: string) => { ); } switch (stringifyText) { - // Regex that matches all IT classifications with levels + // Regex that matches IT classifications with levels from 01-09 case /[IT]-0\d/.exec(stringifyText)?.input: return ( @@ -157,6 +157,15 @@ export const wrapAbbr = (text: ReactNode, intl: IntlShape, title?: string) => { ); + // Regex that matches IT classifications with levels from 10 and up + case /[IT]-\d/.exec(stringifyText)?.input: + return ( + + + {text} + + + ); // Regex that matches all IT(en)/TI(fr) case /[IT][TI]/.exec(stringifyText)?.input: return ( @@ -164,7 +173,7 @@ export const wrapAbbr = (text: ReactNode, intl: IntlShape, title?: string) => { {text} ); - // Regex that matches all AS classifications with levels + // Regex that matches AS classifications with levels from 01-09 case /[AS]-0\d/.exec(stringifyText)?.input: return ( @@ -173,6 +182,15 @@ export const wrapAbbr = (text: ReactNode, intl: IntlShape, title?: string) => { ); + // Regex that matches AS classifications with levels from 10 and up + case /[AS]-\d/.exec(stringifyText)?.input: + return ( + + + {text} + + + ); case /AS/.exec(stringifyText)?.input: return ( diff --git a/apps/web/src/utils/poolUtils.tsx b/apps/web/src/utils/poolUtils.tsx index d2401ccc688..2d1ddc12d16 100644 --- a/apps/web/src/utils/poolUtils.tsx +++ b/apps/web/src/utils/poolUtils.tsx @@ -84,7 +84,7 @@ export const formatClassificationString = ({ group, level, }: formatClassificationStringProps): string => { - return `${group}-0${level}`; + return `${group}-${level < 10 ? "0" : ""}${level}`; }; interface formattedPoolPosterTitleProps { title: Maybe | undefined; @@ -456,7 +456,7 @@ export function getClassificationName( { group, level, name }: Pick, intl: IntlShape, ) { - const groupLevelStr = `${group}-0${level}`; + const groupLevelStr = `${group}-${level < 10 ? "0" : ""}${level}`; if (!name) { return groupLevelStr;