diff --git a/.changeset/tonic-ui-961.md b/.changeset/tonic-ui-961.md
new file mode 100644
index 0000000000..252d67c67c
--- /dev/null
+++ b/.changeset/tonic-ui-961.md
@@ -0,0 +1,5 @@
+---
+"@tonic-ui/react": minor
+---
+
+feat(react/date-pickers)!: deprecate `Calendar` and replace it with `DateCalendar`
diff --git a/packages/react-docs/config/sidebar-routes.js b/packages/react-docs/config/sidebar-routes.js
index 2e706cd90c..e35b0efdd2 100644
--- a/packages/react-docs/config/sidebar-routes.js
+++ b/packages/react-docs/config/sidebar-routes.js
@@ -139,7 +139,7 @@ export const routes = [
{ title: 'DATE PICKERS', heading: true },
{ title: 'Overview', path: 'components/date-pickers' },
- { title: 'Calendar', path: 'components/date-pickers/calendar' },
+ { title: 'DateCalendar', path: 'components/date-pickers/date-calendar' },
{ title: 'DatePicker', path: 'components/date-pickers/date-picker' },
{ title: 'FEEDBACK', heading: true },
diff --git a/packages/react-docs/pages/components/date-pickers/calendar/index.page.mdx b/packages/react-docs/pages/components/date-pickers/date-calendar/index.page.mdx
similarity index 91%
rename from packages/react-docs/pages/components/date-pickers/calendar/index.page.mdx
rename to packages/react-docs/pages/components/date-pickers/date-calendar/index.page.mdx
index 2f8fd68df0..ecd411bf96 100644
--- a/packages/react-docs/pages/components/date-pickers/calendar/index.page.mdx
+++ b/packages/react-docs/pages/components/date-pickers/date-calendar/index.page.mdx
@@ -1,10 +1,10 @@
-# Calendar
+# DateCalendar
## Import
```js
import {
- Calendar,
+ DateCalendar,
} from '@tonic-ui/react';
```
@@ -14,12 +14,11 @@ import {
## Props
-### Calendar
+### DateCalendar
| Name | Type | Default | Description |
| :--- | :--- | :------ | :---------- |
-| date | Date | | The selected date. |
-| defaultDate | Date | | The default selected date. |
+| defaultValue | Date | | The default selected date. |
| firstDayOfWeek | number | 0 | The first day of the week.
0 = Sunday
1 = Monday
2 = Tuesday
3 = Wednesday
4 = Thursday
5 = Friday
6 = Saturday |
| formatDate | function | | A callback called to return the formatted date string in the given format.
Signature
`function(date, format, options) => void`
_date_: The original date.
_format_: The string of [format tokens](https://www.unicode.org/reports/tr35/tr35-dates.html#Date_Field_Symbol_Table).
_options_: An object with options. |
| minDate | Date | | The minimum date that can be selected. |
@@ -27,3 +26,4 @@ import {
| onChange | function | | A callback called when the value (the selected date) changes.
Signature:
`function(value) => void`
_value_: The selected date. |
| onError | function | | An error-first callback called when the date validation returns an error (or the date is valid after error).
Signature
`function(error, value) => void`
_error_: The error message. It will be `undefined` if the date is valid after error.
_value_: The selected date. |
| shouldDisableDate | function | | Disable specific date.
Signature:
`function(date) => boolean`
_date_: The date to check.
_returns (boolean)_: Return `true` if the date will be disabled. |
+| value | Date | | The selected date. |
diff --git a/packages/react-docs/pages/components/date-pickers/calendar/usage.js b/packages/react-docs/pages/components/date-pickers/date-calendar/usage.js
similarity index 95%
rename from packages/react-docs/pages/components/date-pickers/calendar/usage.js
rename to packages/react-docs/pages/components/date-pickers/date-calendar/usage.js
index 405f8afc66..84c244804c 100644
--- a/packages/react-docs/pages/components/date-pickers/calendar/usage.js
+++ b/packages/react-docs/pages/components/date-pickers/date-calendar/usage.js
@@ -2,8 +2,8 @@ import {
Box,
Button,
ButtonGroup,
- Calendar,
Code,
+ DateCalendar,
Divider,
Flex,
Input,
@@ -90,8 +90,8 @@ const App = () => {
)}
- {
const options = {
@@ -102,11 +102,9 @@ const App = () => {
maxDate={maxDate ? new Date(maxDate) : undefined}
minDate={minDate ? new Date(minDate) : undefined}
onChange={(nextDate) => {
- console.log('onChange:', nextDate);
setDate(nextDate);
}}
onError={(error, value) => {
- console.log('onError:', error);
setError(error);
}}
shouldDisableDate={(date) => {
@@ -139,8 +137,8 @@ const App = () => {
{
- const value = event.target.getAttribute('value');
- setLocale(value);
+ const localeValue = event.target.getAttribute('value');
+ setLocale(localeValue);
}}
maxHeight={240}
minWidth={100}
@@ -170,13 +168,13 @@ const App = () => {
{`// format\nimport format from 'date-fns/format';\n\n// locale\nimport enLocale from 'date-fns/locale/en-US'; // English (United States)\nimport deLocale from 'date-fns/locale/de'; // Deutsch\nimport esLocale from 'date-fns/locale/es'; // Español\nimport frLocale from 'date-fns/locale/fr'; // Français\nimport itLocale from 'date-fns/locale/it'; // Italiano\nimport jaLocale from 'date-fns/locale/ja'; // 日本語\nimport koLocale from 'date-fns/locale/ko'; // 한국어\nimport zhCNLocale from 'date-fns/locale/zh-CN'; // 简体中文\nimport zhTWLocale from 'date-fns/locale/zh-TW'; // 繁體中文`}
- {`// Calendar component\nformatDate={(date, format, options) => {\n return format(date, format, { locale: enLocale });\n}}`}
+ {`// DateCalendar component\nformatDate={(date, format, options) => {\n return format(date, format, { locale: enLocale });\n}}`}
- Calendar props
+ DateCalendar props
diff --git a/packages/react-docs/pages/components/date-pickers/date-picker/usage.js b/packages/react-docs/pages/components/date-pickers/date-picker/usage.js
index 4904ab4a08..877f71f21f 100644
--- a/packages/react-docs/pages/components/date-pickers/date-picker/usage.js
+++ b/packages/react-docs/pages/components/date-pickers/date-picker/usage.js
@@ -94,7 +94,7 @@ const disableWeekends = (date) => {
const App = () => {
const [maxDate, setMaxDate] = useState('');
const [minDate, setMinDate] = useState('');
- const [closeOnSelect, toggleCloseOnSelect] = useToggle(false);
+ const [closeOnSelect, toggleCloseOnSelect] = useToggle(true);
const [dateOption, changeDateOptionBy] = useSelection('none');
const [firstDayOfWeek, changeFirstDayOfWeekBy] = useSelection(0);
const [inputFormat, changeInputFormatBy] = useSelection(inputFormats[0]);
@@ -139,15 +139,12 @@ const App = () => {
maxDate={maxDate ? new Date(maxDate) : undefined}
minDate={minDate ? new Date(minDate) : undefined}
onChange={(nextValue) => {
- console.log('onChange:', nextValue);
setValue(nextValue);
}}
onError={(error, value) => {
- console.log('onError:', error, value);
setError(error);
}}
shouldDisableDate={(date) => {
- console.log('shouldDisableDate:', date, shouldDisableDateOption);
if (shouldDisableDateOption === 'weekdays') {
return disableWeekdays(date);
}
@@ -159,7 +156,6 @@ const App = () => {
value={value}
inputFormat={inputFormat}
renderInput={({ error: inputError, inputProps }) => {
- console.log('renderInput:', inputError, inputProps);
return (
{
{
- const value = event.target.getAttribute('value');
- setLocale(value);
+ const localeValue = event.target.getAttribute('value');
+ setLocale(localeValue);
}}
maxHeight={240}
minWidth={100}
diff --git a/packages/react/__tests__/index.test.js b/packages/react/__tests__/index.test.js
index 1221a4e6de..8ad2e2bf7d 100644
--- a/packages/react/__tests__/index.test.js
+++ b/packages/react/__tests__/index.test.js
@@ -4,6 +4,7 @@ test('should match expected exports', () => {
const expectedExports = [
// deprecated
'AccordionCollapse',
+ 'Calendar',
'ToastProvider',
'useToast',
@@ -61,7 +62,7 @@ test('should match expected exports', () => {
'CSSBaseline',
// date-pickers
- 'Calendar',
+ 'DateCalendar',
'DatePicker',
// default-props
diff --git a/packages/react/src/date-pickers/Calendar/context.js b/packages/react/src/date-pickers/Calendar/context.js
deleted file mode 100644
index 993350d8fa..0000000000
--- a/packages/react/src/date-pickers/Calendar/context.js
+++ /dev/null
@@ -1,10 +0,0 @@
-import { createContext } from 'react';
-
-const CalendarContext = createContext();
-
-const CalendarProvider = CalendarContext.Provider;
-
-export {
- CalendarContext,
- CalendarProvider,
-};
diff --git a/packages/react/src/date-pickers/Calendar/index.js b/packages/react/src/date-pickers/Calendar/index.js
deleted file mode 100644
index abd4428bf5..0000000000
--- a/packages/react/src/date-pickers/Calendar/index.js
+++ /dev/null
@@ -1,3 +0,0 @@
-import Calendar from './Calendar';
-
-export default Calendar;
diff --git a/packages/react/src/date-pickers/Calendar/Calendar.js b/packages/react/src/date-pickers/DateCalendar/DateCalendar.js
similarity index 90%
rename from packages/react/src/date-pickers/Calendar/Calendar.js
rename to packages/react/src/date-pickers/DateCalendar/DateCalendar.js
index 95930f807a..51e0255008 100644
--- a/packages/react/src/date-pickers/Calendar/Calendar.js
+++ b/packages/react/src/date-pickers/DateCalendar/DateCalendar.js
@@ -1,8 +1,13 @@
-import { useConst, usePrevious } from '@tonic-ui/react-hooks';
+import {
+ useConst,
+ useOnceWhen,
+ usePrevious,
+} from '@tonic-ui/react-hooks';
import {
getActiveElement,
getAllFocusable,
isNullOrUndefined,
+ warnDeprecatedProps,
} from '@tonic-ui/utils';
import differenceInCalendarDays from 'date-fns/differenceInCalendarDays';
import addMonths from 'date-fns/addMonths';
@@ -21,10 +26,10 @@ import React, { forwardRef, useCallback, useEffect, useRef, useState } from 'rea
import { Box } from '../../box';
import { useDefaultProps } from '../../default-props';
import { validateDate } from '../validation';
-import { CalendarProvider } from './context';
+import { DateCalendarProvider } from './context';
import MonthDate from './MonthDate';
import YearMonthPicker from './YearMonthPicker';
-import { useCalendarStyle } from './styles';
+import { useDateCalendarStyle } from './styles';
const getMemoizedState = memoize(state => ({ ...state }));
@@ -46,11 +51,13 @@ const mapValueToEndOfDay = (value) => {
return (isDate(date) && isValid(date)) ? endOfDay(date) : null;
};
-const Calendar = forwardRef((inProps, ref) => {
- const {
+const DateCalendar = forwardRef((inProps, ref) => {
+ let {
+ date: dateProp, // deprecated
+ defaultDate: defaultDateProp, // deprecated
+
children, // eslint-disable-line no-unused-vars
- date: dateProp,
- defaultDate: defaultDateProp,
+ defaultValue: defaultValueProp,
firstDayOfWeek = 0, // 0 = Sunday, 1 = Monday, ...
formatDate: formatDateProp,
maxDate: maxDateProp,
@@ -58,10 +65,36 @@ const Calendar = forwardRef((inProps, ref) => {
onChange: onChangeProp,
onError: onErrorProp,
shouldDisableDate,
+ value: valueProp,
...rest
- } = useDefaultProps({ props: inProps, name: 'Calendar' });
+ } = useDefaultProps({ props: inProps, name: 'DateCalendar' });
+
+ { // deprecation warning
+ const prefix = `${DateCalendar.displayName}:`;
+
+ useOnceWhen(() => {
+ warnDeprecatedProps('date', {
+ prefix,
+ alternative: 'value',
+ willRemove: true,
+ });
+ }, (dateProp !== undefined));
+
+ useOnceWhen(() => {
+ warnDeprecatedProps('defaultDate', {
+ prefix,
+ alternative: 'defaultValue',
+ willRemove: true,
+ });
+ }, (defaultDateProp !== undefined));
+
+ // TODO: remove `date` and `defaultDate` props in next major version
+ valueProp = valueProp ?? dateProp;
+ defaultValueProp = defaultValueProp ?? defaultDateProp;
+ }
+
const initialDate = useConst(() => {
- const value = dateProp ?? defaultDateProp;
+ const value = valueProp ?? defaultValueProp;
return mapValueToDate(value);
});
const initialActiveDate = useConst(() => {
@@ -117,12 +150,12 @@ const Calendar = forwardRef((inProps, ref) => {
}, [date, onErrorProp, previousValidationError, validationError]);
useEffect(() => {
- const isControlled = (dateProp !== undefined);
+ const isControlled = (valueProp !== undefined);
if (isControlled) {
- const nextDate = dateProp;
+ const nextDate = valueProp;
setDate(nextDate);
}
- }, [dateProp]);
+ }, [valueProp]);
useEffect(() => {
const isDateChanged = !!date && (date !== previousDate);
@@ -155,13 +188,13 @@ const Calendar = forwardRef((inProps, ref) => {
}, [activeDate]); // Re-run effect when activeDate changes
const onChange = useCallback((nextDate) => {
- const isControlled = (dateProp !== undefined);
+ const isControlled = (valueProp !== undefined);
if (!isControlled) {
setDate(nextDate);
}
onChangeProp?.(nextDate);
- }, [dateProp, onChangeProp]);
+ }, [valueProp, onChangeProp]);
const calendarMonthDateEventHandler = {};
@@ -428,10 +461,10 @@ const Calendar = forwardRef((inProps, ref) => {
});
const tabIndex = -1;
- const styleProps = useCalendarStyle({ tabIndex });
+ const styleProps = useDateCalendarStyle({ tabIndex });
return (
-
+
{
{...calendarMonthDateEventHandler}
/>
-
+
);
});
-Calendar.displayName = 'Calendar';
+DateCalendar.displayName = 'DateCalendar';
-export default Calendar;
+export default DateCalendar;
diff --git a/packages/react/src/date-pickers/Calendar/MonthDate/Day.js b/packages/react/src/date-pickers/DateCalendar/MonthDate/Day.js
similarity index 94%
rename from packages/react/src/date-pickers/Calendar/MonthDate/Day.js
rename to packages/react/src/date-pickers/DateCalendar/MonthDate/Day.js
index 128587e08a..26c963dc2e 100644
--- a/packages/react/src/date-pickers/Calendar/MonthDate/Day.js
+++ b/packages/react/src/date-pickers/DateCalendar/MonthDate/Day.js
@@ -8,7 +8,7 @@ import isSameMonth from 'date-fns/isSameMonth';
import React, { forwardRef } from 'react';
import { Box } from '../../../box';
import { useDayStyle } from '../styles';
-import useCalendar from '../useCalendar';
+import useDateCalendar from '../useDateCalendar';
const Day = forwardRef((
{
@@ -17,7 +17,7 @@ const Day = forwardRef((
},
ref,
) => {
- const calendarContext = useCalendar();
+ const dateCalendarContext = useDateCalendar();
const {
activeDate,
date: selectedDate,
@@ -27,7 +27,7 @@ const Day = forwardRef((
onChange,
setActiveDate,
shouldDisableDate,
- } = { ...calendarContext };
+ } = { ...dateCalendarContext };
const isSelectable = (() => {
if (minDate && isBefore(date, minDate)) {
return false;
diff --git a/packages/react/src/date-pickers/Calendar/MonthDate/DaysOfWeek.js b/packages/react/src/date-pickers/DateCalendar/MonthDate/DaysOfWeek.js
similarity index 88%
rename from packages/react/src/date-pickers/Calendar/MonthDate/DaysOfWeek.js
rename to packages/react/src/date-pickers/DateCalendar/MonthDate/DaysOfWeek.js
index e3bc271d22..76f77bb1b3 100644
--- a/packages/react/src/date-pickers/Calendar/MonthDate/DaysOfWeek.js
+++ b/packages/react/src/date-pickers/DateCalendar/MonthDate/DaysOfWeek.js
@@ -3,16 +3,16 @@ import startOfWeek from 'date-fns/startOfWeek';
import React, { forwardRef } from 'react';
import { Box } from '../../../box';
import { Grid } from '../../../grid';
-import useCalendar from '../useCalendar';
+import useDateCalendar from '../useDateCalendar';
import { useDaysOfWeekStyle } from '../styles';
const DaysOfWeek = forwardRef((props, ref) => {
- const calendarContext = useCalendar();
+ const dateCalendarContext = useDateCalendar();
const {
activeDate,
firstDayOfWeek,
formatDate,
- } = { ...calendarContext };
+ } = { ...dateCalendarContext };
const startDateOfWeek = startOfWeek(activeDate, {
weekStartsOn: firstDayOfWeek,
});
diff --git a/packages/react/src/date-pickers/Calendar/MonthDate/MonthDate.js b/packages/react/src/date-pickers/DateCalendar/MonthDate/MonthDate.js
similarity index 100%
rename from packages/react/src/date-pickers/Calendar/MonthDate/MonthDate.js
rename to packages/react/src/date-pickers/DateCalendar/MonthDate/MonthDate.js
diff --git a/packages/react/src/date-pickers/Calendar/MonthDate/Week.js b/packages/react/src/date-pickers/DateCalendar/MonthDate/Week.js
similarity index 100%
rename from packages/react/src/date-pickers/Calendar/MonthDate/Week.js
rename to packages/react/src/date-pickers/DateCalendar/MonthDate/Week.js
diff --git a/packages/react/src/date-pickers/Calendar/MonthDate/Weeks.js b/packages/react/src/date-pickers/DateCalendar/MonthDate/Weeks.js
similarity index 90%
rename from packages/react/src/date-pickers/Calendar/MonthDate/Weeks.js
rename to packages/react/src/date-pickers/DateCalendar/MonthDate/Weeks.js
index 2eb8e36ab2..2b7d45c162 100644
--- a/packages/react/src/date-pickers/Calendar/MonthDate/Weeks.js
+++ b/packages/react/src/date-pickers/DateCalendar/MonthDate/Weeks.js
@@ -5,7 +5,7 @@ import startOfMonth from 'date-fns/startOfMonth';
import startOfWeek from 'date-fns/startOfWeek';
import React, { forwardRef } from 'react';
import { Grid } from '../../../grid';
-import useCalendar from '../useCalendar';
+import useDateCalendar from '../useDateCalendar';
import Week from './Week';
const isWeekInMonth = (startDateOfWeek, activeDate) => {
@@ -17,11 +17,11 @@ const Weeks = forwardRef((
props,
ref,
) => {
- const calendarContext = useCalendar();
+ const dateCalendarContext = useDateCalendar();
const {
activeDate,
firstDayOfWeek,
- } = { ...calendarContext };
+ } = { ...dateCalendarContext };
const weeks = [];
let startDateOfWeek = startOfWeek(startOfMonth(activeDate), {
weekStartsOn: firstDayOfWeek,
diff --git a/packages/react/src/date-pickers/Calendar/MonthDate/index.js b/packages/react/src/date-pickers/DateCalendar/MonthDate/index.js
similarity index 100%
rename from packages/react/src/date-pickers/Calendar/MonthDate/index.js
rename to packages/react/src/date-pickers/DateCalendar/MonthDate/index.js
diff --git a/packages/react/src/date-pickers/Calendar/YearMonthPicker/YearMonthPicker.js b/packages/react/src/date-pickers/DateCalendar/YearMonthPicker/YearMonthPicker.js
similarity index 97%
rename from packages/react/src/date-pickers/Calendar/YearMonthPicker/YearMonthPicker.js
rename to packages/react/src/date-pickers/DateCalendar/YearMonthPicker/YearMonthPicker.js
index 08f092f487..1a5db297d6 100644
--- a/packages/react/src/date-pickers/Calendar/YearMonthPicker/YearMonthPicker.js
+++ b/packages/react/src/date-pickers/DateCalendar/YearMonthPicker/YearMonthPicker.js
@@ -14,7 +14,7 @@ import React, { forwardRef, useCallback, useRef } from 'react';
import { Box } from '../../../box';
import { Button } from '../../../button';
import { Text } from '../../../text';
-import useCalendar from '../useCalendar';
+import useDateCalendar from '../useDateCalendar';
import {
useYearMonthPickerStyle,
useYearMonthPickerMonthButtonStyle,
@@ -24,12 +24,12 @@ import {
} from '../styles';
const YearMonthPicker = forwardRef((props, ref) => {
- const calendarContext = useCalendar();
+ const dateCalendarContext = useDateCalendar();
const {
activeDate,
formatDate,
setActiveDate,
- } = { ...calendarContext };
+ } = { ...dateCalendarContext };
const onClickPreviousYear = useEventCallback((event) => {
const nextActiveDate = subYears(activeDate, 1);
diff --git a/packages/react/src/date-pickers/Calendar/YearMonthPicker/index.js b/packages/react/src/date-pickers/DateCalendar/YearMonthPicker/index.js
similarity index 100%
rename from packages/react/src/date-pickers/Calendar/YearMonthPicker/index.js
rename to packages/react/src/date-pickers/DateCalendar/YearMonthPicker/index.js
diff --git a/packages/react/src/date-pickers/DateCalendar/context.js b/packages/react/src/date-pickers/DateCalendar/context.js
new file mode 100644
index 0000000000..0d6e0f993e
--- /dev/null
+++ b/packages/react/src/date-pickers/DateCalendar/context.js
@@ -0,0 +1,10 @@
+import { createContext } from 'react';
+
+const DateCalendarContext = createContext();
+
+const DateCalendarProvider = DateCalendarContext.Provider;
+
+export {
+ DateCalendarContext,
+ DateCalendarProvider,
+};
diff --git a/packages/react/src/date-pickers/DateCalendar/index.js b/packages/react/src/date-pickers/DateCalendar/index.js
new file mode 100644
index 0000000000..0f05e08981
--- /dev/null
+++ b/packages/react/src/date-pickers/DateCalendar/index.js
@@ -0,0 +1,3 @@
+import DateCalendar from './DateCalendar';
+
+export default DateCalendar;
diff --git a/packages/react/src/date-pickers/Calendar/styles.js b/packages/react/src/date-pickers/DateCalendar/styles.js
similarity index 98%
rename from packages/react/src/date-pickers/Calendar/styles.js
rename to packages/react/src/date-pickers/DateCalendar/styles.js
index 2910ba7980..ca5960a554 100644
--- a/packages/react/src/date-pickers/Calendar/styles.js
+++ b/packages/react/src/date-pickers/DateCalendar/styles.js
@@ -1,7 +1,7 @@
import { useColorMode } from '../../color-mode';
import { useColorStyle } from '../../color-style';
-const useCalendarStyle = ({ tabIndex }) => {
+const useDateCalendarStyle = ({ tabIndex }) => {
const [colorMode] = useColorMode();
const [colorStyle] = useColorStyle({ colorMode });
const borderColor = {
@@ -205,7 +205,7 @@ const useDaysOfWeekStyle = () => {
};
export {
- useCalendarStyle,
+ useDateCalendarStyle,
useYearMonthPickerStyle,
useYearMonthPickerMonthButtonStyle,
useYearMonthPickerYearStyle,
diff --git a/packages/react/src/date-pickers/Calendar/useCalendar.js b/packages/react/src/date-pickers/DateCalendar/useDateCalendar.js
similarity index 51%
rename from packages/react/src/date-pickers/Calendar/useCalendar.js
rename to packages/react/src/date-pickers/DateCalendar/useDateCalendar.js
index 9314115c9f..a12543cc44 100644
--- a/packages/react/src/date-pickers/Calendar/useCalendar.js
+++ b/packages/react/src/date-pickers/DateCalendar/useDateCalendar.js
@@ -1,13 +1,13 @@
import { useContext } from 'react';
-import { CalendarContext } from './context';
+import { DateCalendarContext } from './context';
-const useCalendar = () => {
+const useDateCalendar = () => {
if (!useContext) {
throw new Error('The `useContext` hook is not available with your React version.');
}
- const context = useContext(CalendarContext);
+ const context = useContext(DateCalendarContext);
return context;
};
-export default useCalendar;
+export default useDateCalendar;
diff --git a/packages/react/src/date-pickers/DatePicker/DatePicker.js b/packages/react/src/date-pickers/DatePicker/DatePicker.js
index c61abb91b2..545098951c 100644
--- a/packages/react/src/date-pickers/DatePicker/DatePicker.js
+++ b/packages/react/src/date-pickers/DatePicker/DatePicker.js
@@ -12,7 +12,7 @@ import { Box } from '../../box';
import { useDefaultProps } from '../../default-props';
import config from '../../shared/config';
import useAutoId from '../../utils/useAutoId';
-import Calendar from '../Calendar';
+import DateCalendar from '../DateCalendar';
import { validateDate } from '../validation';
import DatePickerContent from './DatePickerContent';
import DatePickerToggle from './DatePickerToggle';
@@ -141,7 +141,7 @@ const DatePicker = forwardRef((inProps, ref) => {
}
}, [error, value, minDate, maxDate, shouldDisableDate, onErrorProp]);
- const onCalendarChange = useCallback((nextDate) => {
+ const onDateCalendarChange = useCallback((nextDate) => {
const isControlled = (valueProp !== undefined);
if (!isControlled) {
setValue(nextDate);
@@ -160,7 +160,7 @@ const DatePicker = forwardRef((inProps, ref) => {
}
}, [valueProp, inputFormat, onChangeProp, closeOnSelect, onClose]);
- const onCalendarError = useCallback((error, value) => {
+ const onDateCalendarError = useCallback((error, value) => {
setError(error);
if (typeof onErrorProp === 'function') {
onErrorProp(error, value);
@@ -238,14 +238,14 @@ const DatePicker = forwardRef((inProps, ref) => {
}}
-
diff --git a/packages/react/src/date-pickers/index.js b/packages/react/src/date-pickers/index.js
index 0c80beb7c7..6811a8e8eb 100644
--- a/packages/react/src/date-pickers/index.js
+++ b/packages/react/src/date-pickers/index.js
@@ -1,7 +1,7 @@
-import Calendar from './Calendar';
+import DateCalendar from './DateCalendar';
import DatePicker from './DatePicker';
export {
- Calendar,
+ DateCalendar,
DatePicker,
};
diff --git a/packages/react/src/deprecated/Calendar.js b/packages/react/src/deprecated/Calendar.js
new file mode 100644
index 0000000000..412a082716
--- /dev/null
+++ b/packages/react/src/deprecated/Calendar.js
@@ -0,0 +1,26 @@
+import { useOnce } from '@tonic-ui/react-hooks';
+import React, { forwardRef } from 'react';
+import { useDefaultProps } from '../default-props';
+import { DateCalendar } from '../date-pickers';
+
+const Calendar = forwardRef((inProps, ref) => {
+ useOnce(() => {
+ console.error('Warning: The `Calendar` component is deprecated and will be removed in the next major release. Use the `DateCalendar` component instead.');
+ });
+
+ const {
+ date: valueProp,
+ defaultDate: defaultValueProp,
+ ...rest
+ } = useDefaultProps({ props: inProps, name: 'Calendar' });
+
+ return (
+
+ );
+});
+
+export default Calendar;
diff --git a/packages/react/src/deprecated/__tests__/AccordionCollapse.test.js b/packages/react/src/deprecated/__tests__/AccordionCollapse.test.js
new file mode 100644
index 0000000000..a7da5dbf74
--- /dev/null
+++ b/packages/react/src/deprecated/__tests__/AccordionCollapse.test.js
@@ -0,0 +1,17 @@
+import { render } from '@tonic-ui/react/test-utils/render';
+import { AccordionCollapse } from '@tonic-ui/react/src';
+import React from 'react';
+
+describe('AccordionCollapse component', () => {
+ it('logs a deprecation warning when used', () => {
+ const consoleErrorSpy = jest.spyOn(console, 'error').mockImplementation(() => {});
+
+ render();
+
+ expect(consoleErrorSpy).toHaveBeenCalledWith(
+ 'Warning: The `AccordionCollapse` component is deprecated and will be removed in the next major release. Use the `AccordionContent` component instead.'
+ );
+
+ consoleErrorSpy.mockRestore();
+ });
+});
diff --git a/packages/react/src/deprecated/__tests__/Calendar.test.js b/packages/react/src/deprecated/__tests__/Calendar.test.js
new file mode 100644
index 0000000000..aeeb422160
--- /dev/null
+++ b/packages/react/src/deprecated/__tests__/Calendar.test.js
@@ -0,0 +1,17 @@
+import { render } from '@tonic-ui/react/test-utils/render';
+import { Calendar } from '@tonic-ui/react/src';
+import React from 'react';
+
+describe('Calendar component', () => {
+ it('logs a deprecation warning when used', () => {
+ const consoleErrorSpy = jest.spyOn(console, 'error').mockImplementation(() => {});
+
+ render();
+
+ expect(consoleErrorSpy).toHaveBeenCalledWith(
+ 'Warning: The `Calendar` component is deprecated and will be removed in the next major release. Use the `DateCalendar` component instead.'
+ );
+
+ consoleErrorSpy.mockRestore();
+ });
+});
diff --git a/packages/react/src/deprecated/__tests__/ToastProvider.test.js b/packages/react/src/deprecated/__tests__/ToastProvider.test.js
new file mode 100644
index 0000000000..80cda65806
--- /dev/null
+++ b/packages/react/src/deprecated/__tests__/ToastProvider.test.js
@@ -0,0 +1,17 @@
+import { render } from '@tonic-ui/react/test-utils/render';
+import { ToastProvider } from '@tonic-ui/react/src';
+import React from 'react';
+
+describe('ToastProvider component', () => {
+ it('logs a deprecation warning when used', () => {
+ const consoleErrorSpy = jest.spyOn(console, 'error').mockImplementation(() => {});
+
+ render();
+
+ expect(consoleErrorSpy).toHaveBeenCalledWith(
+ 'Warning: The `ToastProvider` component is deprecated and will be removed in the next major release. Use the `ToastManager` component instead.'
+ );
+
+ consoleErrorSpy.mockRestore();
+ });
+});
diff --git a/packages/react/src/deprecated/__tests__/useToast.test.js b/packages/react/src/deprecated/__tests__/useToast.test.js
new file mode 100644
index 0000000000..0dee4200e8
--- /dev/null
+++ b/packages/react/src/deprecated/__tests__/useToast.test.js
@@ -0,0 +1,22 @@
+import { renderHook } from '@tonic-ui/react/test-utils/render';
+import { ToastManager, useToast } from '@tonic-ui/react/src';
+import React from 'react';
+
+describe('useToast hook', () => {
+ it('logs a deprecation warning when used', () => {
+ const consoleErrorSpy = jest.spyOn(console, 'error').mockImplementation(() => {});
+ const wrapper = ({ children }) => (
+
+ {children}
+
+ );
+
+ renderHook(() => useToast(), { wrapper }); // Wrap the hook with ToastManager
+
+ expect(consoleErrorSpy).toHaveBeenCalledWith(
+ 'Warning: The `useToast` Hook is deprecated and will be removed in the next major release. Use the `useToastManager` Hook instead.'
+ );
+
+ consoleErrorSpy.mockRestore();
+ });
+});
diff --git a/packages/react/src/index.js b/packages/react/src/index.js
index 7eb2ed63bd..0eb6d5c9e7 100644
--- a/packages/react/src/index.js
+++ b/packages/react/src/index.js
@@ -52,5 +52,6 @@ export * from './visually-hidden';
// deprecated
export { default as AccordionCollapse } from './deprecated/AccordionCollapse';
+export { default as Calendar } from './deprecated/Calendar';
export { default as ToastProvider } from './deprecated/ToastProvider';
export { default as useToast } from './deprecated/useToast';