Skip to content

Commit

Permalink
feat: swap start and enroll-by date in variant dropdown (#1321)
Browse files Browse the repository at this point in the history
  • Loading branch information
brobro10000 authored Sep 27, 2024
1 parent 5ebe94b commit 06819d8
Show file tree
Hide file tree
Showing 3 changed files with 112 additions and 17 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import { Dropdown, Stack } from '@openedx/paragon';
import dayjs from 'dayjs';
import PropTypes from 'prop-types';
import { useState } from 'react';
import classNames from 'classnames';
import { SHORT_MONTH_DATE_FORMAT } from '../data';

const messages = defineMessages({
Expand Down Expand Up @@ -40,7 +41,7 @@ const NewAssignmentModalDropdown = ({
if (clickedDropdownItem && clickedDropdownItem.key === courseRun.key) {
return null;
}
return 'text-muted';
return true;
};
const startLabel = ({ start }) => (dayjs(start).isBefore(dayjs()) ? 'Started' : 'Starts');
return (
Expand All @@ -66,13 +67,13 @@ const NewAssignmentModalDropdown = ({
onMouseUp={() => setClickedDropdownItem(null)}
>
<Stack>
{intl.formatMessage(messages.enrollBy, {
enrollByDate: dayjs(courseRun.enrollBy).format(SHORT_MONTH_DATE_FORMAT),
{intl.formatMessage(messages.startDate, {
startLabel: startLabel(courseRun),
startDate: dayjs(courseRun.start).format(SHORT_MONTH_DATE_FORMAT),
})}
<span className={`small ${getDropdownItemClassName(courseRun)}`}>
{intl.formatMessage(messages.startDate, {
startLabel: startLabel(courseRun),
startDate: dayjs(courseRun.start).format(SHORT_MONTH_DATE_FORMAT),
<span className={classNames('small', { 'text-muted': getDropdownItemClassName(courseRun) })}>
{intl.formatMessage(messages.enrollBy, {
enrollByDate: dayjs(courseRun.enrollBy).format(SHORT_MONTH_DATE_FORMAT),
})}
</span>
</Stack>
Expand Down
89 changes: 87 additions & 2 deletions src/components/learner-credit-management/data/tests/utils.test.js
Original file line number Diff line number Diff line change
@@ -1,10 +1,12 @@
import { createIntl } from '@edx/frontend-platform/i18n';
import dayjs from 'dayjs';
import {
transformSubsidySummary,
getBudgetStatus,
orderBudgets,
getTranslatedBudgetStatus,
getTranslatedBudgetTerm,
orderBudgets,
startAndEnrollBySortLogic,
transformSubsidySummary,
} from '../utils';
import { EXEC_ED_OFFER_TYPE } from '../constants';

Expand Down Expand Up @@ -258,3 +260,86 @@ describe('getTranslatedBudgetTerm', () => {
expect(getTranslatedBudgetTerm(mockintl, term2)).toEqual('');
});
});

describe('startAndEnrollBySortLogic', () => {
it.each([
// Unique start and enroll-by dates
{
sampleData: [
{
enrollBy: dayjs().add(1, 'day').toISOString(),
start: dayjs().add(3, 'day').toISOString(),
expectedOrder: 2,
},
{
enrollBy: dayjs().subtract(2, 'day').toISOString(),
start: dayjs().add(1, 'day').toISOString(),
expectedOrder: 1,
},
{
enrollBy: dayjs().subtract(6, 'day').toISOString(),
start: dayjs().add(12, 'day').toISOString(),
expectedOrder: 4,
},
{
enrollBy: dayjs().add(3, 'day').toISOString(),
start: dayjs().add(5, 'day').toISOString(),
expectedOrder: 3,
},
],
},
// unique start, same enroll by dates
{
sampleData: [
{
enrollBy: dayjs().add(1, 'day').toISOString(),
start: dayjs().add(3, 'day').toISOString(),
expectedOrder: 2,
},
{
enrollBy: dayjs().subtract(1, 'day').toISOString(),
start: dayjs().add(1, 'day').toISOString(),
expectedOrder: 1,
},
{
enrollBy: dayjs().subtract(6, 'day').toISOString(),
start: dayjs().add(12, 'day').toISOString(),
expectedOrder: 4,
},
{
enrollBy: dayjs().add(6, 'day').toISOString(),
start: dayjs().add(5, 'day').toISOString(),
expectedOrder: 3,
},
],
},
// unique enroll-by, same start dates
{
sampleData: [
{
enrollBy: dayjs().add(1, 'day').toISOString(),
start: dayjs().add(1, 'day').toISOString(),
expectedOrder: 1,
},
{
enrollBy: dayjs().subtract(2, 'day').toISOString(),
start: dayjs().add(1, 'day').toISOString(),
expectedOrder: 2,
},
{
enrollBy: dayjs().subtract(6, 'day').toISOString(),
start: dayjs().add(12, 'day').toISOString(),
expectedOrder: 4,
},
{
enrollBy: dayjs().add(3, 'day').toISOString(),
start: dayjs().add(12, 'day').toISOString(),
expectedOrder: 3,
},
],
},
])('sorts start date and enroll by date as expected', ({ sampleData }) => {
const sortedDates = sampleData.sort(startAndEnrollBySortLogic);
expect(sortedDates).toEqual(sampleData.sort((a, b) => a.expectedOrder - b.expectedOrder));
});
});
25 changes: 17 additions & 8 deletions src/components/learner-credit-management/data/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -648,6 +648,21 @@ const isEnrollByDateWithinThreshold = ({ hasEnrollBy, enrollBy, isLateRedemption
return dayjs(enrollBy).isAfter(enrollmentEffectiveDate, 'seconds');
};

export const startAndEnrollBySortLogic = (prev, next) => {
// Label relevant timestamps to milliseconds for the most granular sort
const prevEnrollByDateTimestamp = dayjs(prev.enrollBy).valueOf();
const nextEnrollByDateTimestamp = dayjs(next.enrollBy).valueOf();
const prevStartDateTimestamp = dayjs(prev.start).valueOf();
const nextStartDateTimestamp = dayjs(next.start).valueOf();

// When start dates are equivalent, compare enrollBy dates.
if (dayjs(prev.start).isSame(next.start, 'day')) {
return prevEnrollByDateTimestamp - nextEnrollByDateTimestamp;
}
// Otherwise, compare start dates
return prevStartDateTimestamp - nextStartDateTimestamp;
};

/**
* Filters assignable course runs based on the following criteria:
* - If the start date or enrollStart date (min date) is before the subsidy expiration - 14 day threshold
Expand Down Expand Up @@ -734,12 +749,6 @@ export const getAssignableCourseRuns = ({ courseRuns, subsidyExpirationDatetime,
enrollBy: getNormalizedEnrollByDate(courseRun.enrollBy),
};
});
// Sorts by the enrollBy date. If enrollBy is equivalent, sort by start.
const sortedAssignableCourseRuns = assignableCourseRuns.sort((a, b) => {
if (a.enrollBy === b.enrollBy) {
return dayjs(a.start).unix() - dayjs(b.start).unix();
}
return a.enrollBy - b.enrollBy;
});
return sortedAssignableCourseRuns;
// Sorts by the enrollBy date. If enrollBy is equivalent, sort by start
return assignableCourseRuns.sort(startAndEnrollBySortLogic);
};

0 comments on commit 06819d8

Please sign in to comment.