mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-16 14:17:22 +01:00
* Issue 10605 - Don't pointlessly format dates * fix(10605): Be defensive about setting plan termination dates
24 lines
857 B
JavaScript
24 lines
857 B
JavaScript
import moment from 'moment';
|
|
|
|
const DEFAULT_REMAINING_DAYS = 30;
|
|
const DEFAULT_REMAINING_DAYS_FOR_GROUP_PLAN = 2;
|
|
|
|
export default function calculateSubscriptionTerminationDate (
|
|
nextBill, purchasedPlan, groupPlanCustomerId,
|
|
) {
|
|
const defaultRemainingDays = purchasedPlan.customerId === groupPlanCustomerId
|
|
? DEFAULT_REMAINING_DAYS_FOR_GROUP_PLAN : DEFAULT_REMAINING_DAYS;
|
|
|
|
const remaining = nextBill
|
|
? moment(nextBill).diff(new Date(), 'days', true)
|
|
: defaultRemainingDays;
|
|
|
|
const extraMonths = Math.max(purchasedPlan.extraMonths, 0);
|
|
const extraDays = Math.ceil(30.5 * extraMonths);
|
|
|
|
const calculatedTerminationDate = moment().startOf('day').add({ days: remaining + extraDays });
|
|
|
|
return calculatedTerminationDate.isBefore(purchasedPlan.terminationDate)
|
|
? purchasedPlan.terminationDate : calculatedTerminationDate.toDate();
|
|
}
|