diff --git a/codecov.yml b/codecov.yml
index 426667acdf10e..1a350cc7a0e51 100644
--- a/codecov.yml
+++ b/codecov.yml
@@ -1,4 +1,6 @@
coverage:
+ ignore:
+ - '**/*.test.tsx'
status:
project:
default:
@@ -16,8 +18,6 @@ coverage:
- 'packages/x-date-pickers/src/AdapterMoment/AdapterMoment.ts'
- 'packages/x-date-pickers/src/AdapterMomentHijri/AdapterMomentHijri.ts'
- 'packages/x-date-pickers/src/AdapterMomentJalaali/AdapterMomentJalaali.ts'
- ignore:
- - '**/*.test.tsx'
patch: off
comment: false
diff --git a/packages/x-date-pickers/src/AdapterDateFns/AdapterDateFns.test.tsx b/packages/x-date-pickers/src/AdapterDateFns/AdapterDateFns.test.tsx
index 130c14f288215..6f8301a14602e 100644
--- a/packages/x-date-pickers/src/AdapterDateFns/AdapterDateFns.test.tsx
+++ b/packages/x-date-pickers/src/AdapterDateFns/AdapterDateFns.test.tsx
@@ -19,6 +19,14 @@ describe('', () => {
});
describe('Adapter localization', () => {
+ describe('Default locale', () => {
+ const adapter = new AdapterDateFns();
+
+ it('getCurrentLocaleCode: should return locale code', () => {
+ expect(adapter.getCurrentLocaleCode()).to.equal('en-US');
+ });
+ });
+
describe('English', () => {
const adapter = new AdapterDateFns({ locale: enUS });
const date = adapter.date(TEST_DATE_ISO_STRING)!;
diff --git a/packages/x-date-pickers/src/AdapterDateFns/AdapterDateFns.ts b/packages/x-date-pickers/src/AdapterDateFns/AdapterDateFns.ts
index 9bc30bf3dddf5..414637955b354 100644
--- a/packages/x-date-pickers/src/AdapterDateFns/AdapterDateFns.ts
+++ b/packages/x-date-pickers/src/AdapterDateFns/AdapterDateFns.ts
@@ -85,13 +85,16 @@ export class AdapterDateFns
implements MuiPickersAdapter
{
constructor({ locale, formats }: AdapterOptions = {}) {
- if (typeof addDays !== 'function') {
- throw new Error(
- [
- 'MUI: The `date-fns` package v3.x is not compatible with this adapter.',
- 'Please, install v2.x of the package or use the `AdapterDateFnsV3` instead.',
- ].join('\n'),
- );
+ /* istanbul ignore next */
+ if (process.env.NODE_ENV !== 'production') {
+ if (typeof addDays !== 'function') {
+ throw new Error(
+ [
+ 'MUI: The `date-fns` package v3.x is not compatible with this adapter.',
+ 'Please, install v2.x of the package or use the `AdapterDateFnsV3` instead.',
+ ].join('\n'),
+ );
+ }
}
super({ locale: locale ?? defaultLocale, formats, longFormatters });
}
diff --git a/packages/x-date-pickers/src/AdapterDateFnsBase/AdapterDateFnsBase.ts b/packages/x-date-pickers/src/AdapterDateFnsBase/AdapterDateFnsBase.ts
index 5cd1018dd5400..32f9f873d0aac 100644
--- a/packages/x-date-pickers/src/AdapterDateFnsBase/AdapterDateFnsBase.ts
+++ b/packages/x-date-pickers/src/AdapterDateFnsBase/AdapterDateFnsBase.ts
@@ -10,9 +10,9 @@ import { MakeRequired } from '../internals/models/helpers';
type DateFnsLocaleBase = {
formatLong?: {
- date?: any;
- time?: any;
- dateTime?: any;
+ date: (...args: Array) => any;
+ time: (...args: Array) => any;
+ dateTime: (...args: Array) => any;
};
code?: string;
};
@@ -115,7 +115,10 @@ type DateFnsAdapterBaseOptions = MakeRe
AdapterOptions,
'locale'
> & {
- longFormatters: Record<'p' | 'P', (token: string, formatLong: any) => string>;
+ longFormatters: Record<
+ 'p' | 'P',
+ (token: string, formatLong: DateFnsLocaleBase['formatLong']) => string
+ >;
lib?: string;
};
@@ -212,19 +215,15 @@ export class AdapterDateFnsBase
return value;
};
- public getCurrentLocaleCode = () => {
- return this.locale?.code || 'en-US';
+ public getCurrentLocaleCode = (): string => {
+ // `code` is undefined only in `date-fns` types, but all locales have it
+ return this.locale.code!;
};
// Note: date-fns input types are more lenient than this adapter, so we need to expose our more
// strict signature and delegate to the more lenient signature. Otherwise, we have downstream type errors upon usage.
public is12HourCycleInCurrentLocale = () => {
- if (this.locale) {
- return /a/.test(this.locale.formatLong!.time({ width: 'short' }));
- }
-
- // By default, date-fns is using en-US locale with am/pm enabled
- return true;
+ return /a/.test(this.locale.formatLong!.time({ width: 'short' }));
};
public expandFormat = (format: string) => {
diff --git a/packages/x-date-pickers/src/AdapterDateFnsJalali/AdapterDateFnsJalali.test.tsx b/packages/x-date-pickers/src/AdapterDateFnsJalali/AdapterDateFnsJalali.test.tsx
index 916be6d43e29f..b88d9390fced8 100644
--- a/packages/x-date-pickers/src/AdapterDateFnsJalali/AdapterDateFnsJalali.test.tsx
+++ b/packages/x-date-pickers/src/AdapterDateFnsJalali/AdapterDateFnsJalali.test.tsx
@@ -16,6 +16,12 @@ describe('', () => {
describeJalaliAdapter(AdapterDateFnsJalali, {});
describe('Adapter localization', () => {
+ it('getCurrentLocaleCode: should return locale code', () => {
+ const adapter = new AdapterDateFnsJalali({ locale: enUS });
+
+ expect(adapter.getCurrentLocaleCode()).to.equal('en-US');
+ });
+
it('Formatting', () => {
const adapter = new AdapterDateFnsJalali();
diff --git a/packages/x-date-pickers/src/AdapterDateFnsJalali/AdapterDateFnsJalali.ts b/packages/x-date-pickers/src/AdapterDateFnsJalali/AdapterDateFnsJalali.ts
index 99bd27d11cf1e..6fc2d35761f92 100644
--- a/packages/x-date-pickers/src/AdapterDateFnsJalali/AdapterDateFnsJalali.ts
+++ b/packages/x-date-pickers/src/AdapterDateFnsJalali/AdapterDateFnsJalali.ts
@@ -126,13 +126,16 @@ export class AdapterDateFnsJalali
implements MuiPickersAdapter
{
constructor({ locale, formats }: AdapterOptions = {}) {
- if (typeof addDays !== 'function') {
- throw new Error(
- [
- 'MUI: The `date-fns-jalali` package v3.x is not compatible with this adapter.',
- 'Please, install v2.x of the package or use the `AdapterDateFnsJalaliV3` instead.',
- ].join('\n'),
- );
+ /* istanbul ignore next */
+ if (process.env.NODE_ENV !== 'production') {
+ if (typeof addDays !== 'function') {
+ throw new Error(
+ [
+ 'MUI: The `date-fns-jalali` package v3.x is not compatible with this adapter.',
+ 'Please, install v2.x of the package or use the `AdapterDateFnsJalaliV3` instead.',
+ ].join('\n'),
+ );
+ }
}
super({
locale: locale ?? defaultLocale,
@@ -152,10 +155,6 @@ export class AdapterDateFnsJalali
return dateFnsParse(value, format, new Date(), { locale: this.locale });
};
- public getCurrentLocaleCode = (): string => {
- return this.locale?.code || 'fa-IR';
- };
-
public isValid = (value: Date | null): boolean => {
if (value == null) {
return false;
diff --git a/packages/x-date-pickers/src/AdapterDateFnsJalaliV3/AdapterDateFnsJalaliV3.ts b/packages/x-date-pickers/src/AdapterDateFnsJalaliV3/AdapterDateFnsJalaliV3.ts
index 2a74aa3c39bf8..1dc566b74605f 100644
--- a/packages/x-date-pickers/src/AdapterDateFnsJalaliV3/AdapterDateFnsJalaliV3.ts
+++ b/packages/x-date-pickers/src/AdapterDateFnsJalaliV3/AdapterDateFnsJalaliV3.ts
@@ -127,18 +127,21 @@ export class AdapterDateFnsJalali
implements MuiPickersAdapter
{
constructor({ locale, formats }: AdapterOptions = {}) {
- if (typeof addDays !== 'function') {
- throw new Error(
- [
- `MUI: The \`date-fns-jalali\` package v2.x is not compatible with this adapter.`,
- 'Please, install v3.x of the package or use the `AdapterDateFnsJalali` instead.',
- ].join('\n'),
- );
- }
- if (!longFormatters) {
- throw new Error(
- 'MUI: The minimum supported `date-fns-jalali` package version compatible with this adapter is `3.2.x`.',
- );
+ /* istanbul ignore next */
+ if (process.env.NODE_ENV !== 'production') {
+ if (typeof addDays !== 'function') {
+ throw new Error(
+ [
+ `MUI: The \`date-fns-jalali\` package v2.x is not compatible with this adapter.`,
+ 'Please, install v3.x of the package or use the `AdapterDateFnsJalali` instead.',
+ ].join('\n'),
+ );
+ }
+ if (!longFormatters) {
+ throw new Error(
+ 'MUI: The minimum supported `date-fns-jalali` package version compatible with this adapter is `3.2.x`.',
+ );
+ }
}
super({
locale: locale ?? defaultLocale,
@@ -159,10 +162,6 @@ export class AdapterDateFnsJalali
return dateFnsParse(value, format, new Date(), { locale: this.locale });
};
- public getCurrentLocaleCode = (): string => {
- return this.locale?.code || 'fa-IR';
- };
-
public isValid = (value: Date | null): boolean => {
if (value == null) {
return false;
diff --git a/packages/x-date-pickers/src/AdapterDateFnsV3/AdapterDateFnsV3.ts b/packages/x-date-pickers/src/AdapterDateFnsV3/AdapterDateFnsV3.ts
index a47b56c227d4b..9c5332b9e1fee 100644
--- a/packages/x-date-pickers/src/AdapterDateFnsV3/AdapterDateFnsV3.ts
+++ b/packages/x-date-pickers/src/AdapterDateFnsV3/AdapterDateFnsV3.ts
@@ -87,18 +87,21 @@ export class AdapterDateFns
implements MuiPickersAdapter
{
constructor({ locale, formats }: AdapterOptions = {}) {
- if (typeof addDays !== 'function') {
- throw new Error(
- [
- `MUI: The \`date-fns\` package v2.x is not compatible with this adapter.`,
- 'Please, install v3.x of the package or use the `AdapterDateFns` instead.',
- ].join('\n'),
- );
- }
- if (!longFormatters) {
- throw new Error(
- 'MUI: The minimum supported `date-fns` package version compatible with this adapter is `3.2.x`.',
- );
+ /* istanbul ignore next */
+ if (process.env.NODE_ENV !== 'production') {
+ if (typeof addDays !== 'function') {
+ throw new Error(
+ [
+ `MUI: The \`date-fns\` package v2.x is not compatible with this adapter.`,
+ 'Please, install v3.x of the package or use the `AdapterDateFns` instead.',
+ ].join('\n'),
+ );
+ }
+ if (!longFormatters) {
+ throw new Error(
+ 'MUI: The minimum supported `date-fns` package version compatible with this adapter is `3.2.x`.',
+ );
+ }
}
super({ locale: locale ?? enUS, formats, longFormatters });
}
diff --git a/packages/x-date-pickers/src/AdapterDayjs/AdapterDayjs.test.tsx b/packages/x-date-pickers/src/AdapterDayjs/AdapterDayjs.test.tsx
index 6c9db0b98d11c..dda1f5c56ab9b 100644
--- a/packages/x-date-pickers/src/AdapterDayjs/AdapterDayjs.test.tsx
+++ b/packages/x-date-pickers/src/AdapterDayjs/AdapterDayjs.test.tsx
@@ -39,6 +39,17 @@ describe('', () => {
},
});
+ describe('Adapter timezone', () => {
+ it('setTimezone: should throw warning if no plugin is available', () => {
+ const modifiedAdapter = new AdapterDayjs();
+ // @ts-ignore
+ modifiedAdapter.hasTimezonePlugin = () => false;
+
+ const date = modifiedAdapter.date(TEST_DATE_ISO_STRING)!;
+ expect(() => modifiedAdapter.setTimezone(date, 'Europe/London')).to.throw();
+ });
+ });
+
describe('Adapter localization', () => {
describe('English', () => {
const adapter = new AdapterDayjs({ locale: 'en' });
diff --git a/packages/x-date-pickers/src/AdapterDayjs/AdapterDayjs.ts b/packages/x-date-pickers/src/AdapterDayjs/AdapterDayjs.ts
index 0f76d85ad3043..1245f256ea809 100644
--- a/packages/x-date-pickers/src/AdapterDayjs/AdapterDayjs.ts
+++ b/packages/x-date-pickers/src/AdapterDayjs/AdapterDayjs.ts
@@ -248,6 +248,7 @@ export class AdapterDayjs implements MuiPickersAdapter {
let localeObject = locales[locale];
if (localeObject === undefined) {
+ /* istanbul ignore next */
if (process.env.NODE_ENV !== 'production') {
warnOnce([
'MUI X: Your locale has not been found.',
@@ -277,7 +278,7 @@ export class AdapterDayjs implements MuiPickersAdapter {
if (timezone !== 'UTC') {
const fixedValue = value.tz(this.cleanTimezone(timezone), true);
// @ts-ignore
- if ((fixedValue.$offset ?? 0) === (value.$offset ?? 0)) {
+ if (fixedValue.$offset === (value.$offset ?? 0)) {
return value;
}
// Change only what is needed to avoid creating a new object with unwanted data
diff --git a/packages/x-date-pickers/src/AdapterLuxon/AdapterLuxon.ts b/packages/x-date-pickers/src/AdapterLuxon/AdapterLuxon.ts
index 066a0ab572b6e..3fd21f704315a 100644
--- a/packages/x-date-pickers/src/AdapterLuxon/AdapterLuxon.ts
+++ b/packages/x-date-pickers/src/AdapterLuxon/AdapterLuxon.ts
@@ -485,6 +485,7 @@ export class AdapterLuxon implements MuiPickersAdapter {
};
public getWeekNumber = (value: DateTime) => {
+ /* istanbul ignore next */
return value.localWeekNumber ?? value.weekNumber;
};
diff --git a/packages/x-date-pickers/src/AdapterMomentJalaali/AdapterMomentJalaali.ts b/packages/x-date-pickers/src/AdapterMomentJalaali/AdapterMomentJalaali.ts
index 497cd0044f1c5..435022269f28d 100644
--- a/packages/x-date-pickers/src/AdapterMomentJalaali/AdapterMomentJalaali.ts
+++ b/packages/x-date-pickers/src/AdapterMomentJalaali/AdapterMomentJalaali.ts
@@ -228,6 +228,10 @@ export class AdapterMomentJalaali
return value.jDate();
};
+ public getDaysInMonth = (value: Moment) => {
+ return this.moment.jDaysInMonth(value.jYear(), value.jMonth());
+ };
+
public setYear = (value: Moment, year: number) => {
return value.clone().jYear(year);
};
diff --git a/test/utils/pickers/describeGregorianAdapter/testCalculations.ts b/test/utils/pickers/describeGregorianAdapter/testCalculations.ts
index 90b8f60581e99..10ef8845ec083 100644
--- a/test/utils/pickers/describeGregorianAdapter/testCalculations.ts
+++ b/test/utils/pickers/describeGregorianAdapter/testCalculations.ts
@@ -814,6 +814,10 @@ export const testCalculations: DescribeGregorianAdapterTestSuite = ({
expect(adapter.getDaysInMonth(adapter.addMonths(testDateIso, 1))).to.equal(30);
});
+ it('Method: getDayOfWeek', () => {
+ expect(adapter.getDayOfWeek(testDateIso)).to.equal(adapter.lib === 'luxon' ? 2 : 3);
+ });
+
describe('Method: getWeekArray', () => {
it('should work without timezones', () => {
const weekArray = adapter.getWeekArray(testDateIso);
@@ -866,7 +870,7 @@ export const testCalculations: DescribeGregorianAdapterTestSuite = ({
});
it('Method: getWeekNumber', () => {
- expect(adapter.getWeekNumber!(testDateIso)).to.equal(44);
+ expect(adapter.getWeekNumber(testDateIso)).to.equal(44);
});
it('Method: getYearRange', () => {
diff --git a/test/utils/pickers/describeHijriAdapter/testCalculations.ts b/test/utils/pickers/describeHijriAdapter/testCalculations.ts
index f6346f26adbfb..5a797868ff064 100644
--- a/test/utils/pickers/describeHijriAdapter/testCalculations.ts
+++ b/test/utils/pickers/describeHijriAdapter/testCalculations.ts
@@ -161,7 +161,7 @@ export const testCalculations: DescribeHijriAdapterTestSuite = ({ adapter }) =>
});
it('Method: getWeekNumber', () => {
- expect(adapter.getWeekNumber!(testDateIso)).to.equal(8);
+ expect(adapter.getWeekNumber(testDateIso)).to.equal(8);
});
describe('Method: getYearRange', () => {
diff --git a/test/utils/pickers/describeJalaliAdapter/testCalculations.ts b/test/utils/pickers/describeJalaliAdapter/testCalculations.ts
index 6fb2259778460..c1c2d7e9f4ea9 100644
--- a/test/utils/pickers/describeJalaliAdapter/testCalculations.ts
+++ b/test/utils/pickers/describeJalaliAdapter/testCalculations.ts
@@ -19,6 +19,19 @@ export const testCalculations: DescribeJalaliAdapterTestSuite = ({ adapter }) =>
expect(adapter.isEqual(testDateIso, anotherDate)).to.equal(true);
expect(adapter.isEqual(null, null)).to.equal(true);
+ expect(adapter.isEqual(testDateIso, null)).to.equal(false);
+ });
+
+ it('Method: isValid', () => {
+ expect(adapter.isValid(testDateIso)).to.equal(true);
+ expect(adapter.isValid(null)).to.equal(false);
+ if (adapter.lib !== 'moment-jalaali') {
+ expect(adapter.isValid(adapter.date('invalid'))).to.equal(false);
+ } else {
+ expect(() => adapter.isValid(adapter.date('invalid'))).toWarnDev(
+ 'Deprecation warning: value provided is not in a recognized RFC2822 or ISO format. moment construction falls back to js Date(), which is not rel',
+ );
+ }
});
it('Method: isSameYear', () => {
@@ -202,6 +215,10 @@ export const testCalculations: DescribeJalaliAdapterTestSuite = ({ adapter }) =>
expect(adapter.getDate(testDateIso)).to.equal(8);
});
+ it('Method: getHours', () => {
+ expect(adapter.getHours(testDateIso)).to.equal(11);
+ });
+
it('Method: getMinutes', () => {
expect(adapter.getMinutes(testDateIso)).to.equal(44);
});
@@ -242,6 +259,10 @@ export const testCalculations: DescribeJalaliAdapterTestSuite = ({ adapter }) =>
expect(adapter.setMilliseconds(testDateIso, 11)).toEqualDateTime('2018-10-30T11:44:00.011Z');
});
+ it('Method: getDaysInMonth', () => {
+ expect(adapter.getDaysInMonth(testDateIso)).to.equal(30);
+ });
+
it('Method: getWeekArray', () => {
const weekArray = adapter.getWeekArray(testDateIso);
const expectedDate = new Date('2018-10-20T00:00:00.000Z');
@@ -255,7 +276,7 @@ export const testCalculations: DescribeJalaliAdapterTestSuite = ({ adapter }) =>
});
it('Method: getWeekNumber', () => {
- expect(adapter.getWeekNumber!(testDateIso)).to.equal(33);
+ expect(adapter.getWeekNumber(testDateIso)).to.equal(33);
});
it('Method: getYearRange', () => {