219 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			219 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			Vue
		
	
	
| import type { CSSObject } from '../../_util/cssinjs';
 | |
| import { resetComponent } from '../../style';
 | |
| import type { PickerPanelToken } from '../../date-picker/style';
 | |
| import { genPanelStyle, initPickerPanelToken } from '../../date-picker/style';
 | |
| import type { InputToken } from '../../input/style';
 | |
| import { initInputToken } from '../../input/style';
 | |
| import type { FullToken } from '../../theme/internal';
 | |
| import { genComponentStyleHook, mergeToken } from '../../theme/internal';
 | |
| 
 | |
| export interface ComponentToken {
 | |
|   yearControlWidth: number;
 | |
|   monthControlWidth: number;
 | |
|   miniContentHeight: number;
 | |
| }
 | |
| 
 | |
| interface CalendarToken extends InputToken<FullToken<'Calendar'>>, PickerPanelToken {
 | |
|   calendarCls: string;
 | |
|   calendarFullBg: string;
 | |
|   calendarFullPanelBg: string;
 | |
|   calendarItemActiveBg: string;
 | |
|   dateValueHeight: number;
 | |
|   weekHeight: number;
 | |
|   dateContentHeight: number;
 | |
| }
 | |
| 
 | |
| export const genCalendarStyles = (token: CalendarToken): CSSObject => {
 | |
|   const { calendarCls, componentCls, calendarFullBg, calendarFullPanelBg, calendarItemActiveBg } =
 | |
|     token;
 | |
|   return {
 | |
|     [calendarCls]: {
 | |
|       ...genPanelStyle(token),
 | |
|       ...resetComponent(token),
 | |
|       background: calendarFullBg,
 | |
|       '&-rtl': {
 | |
|         direction: 'rtl',
 | |
|       },
 | |
|       [`${calendarCls}-header`]: {
 | |
|         display: 'flex',
 | |
|         justifyContent: 'flex-end',
 | |
|         padding: `${token.paddingSM}px 0`,
 | |
| 
 | |
|         [`${calendarCls}-year-select`]: {
 | |
|           minWidth: token.yearControlWidth,
 | |
|         },
 | |
|         [`${calendarCls}-month-select`]: {
 | |
|           minWidth: token.monthControlWidth,
 | |
|           marginInlineStart: token.marginXS,
 | |
|         },
 | |
|         [`${calendarCls}-mode-switch`]: {
 | |
|           marginInlineStart: token.marginXS,
 | |
|         },
 | |
|       },
 | |
|     },
 | |
|     [`${calendarCls} ${componentCls}-panel`]: {
 | |
|       background: calendarFullPanelBg,
 | |
|       border: 0,
 | |
|       borderTop: `${token.lineWidth}px ${token.lineType} ${token.colorSplit}`,
 | |
|       borderRadius: 0,
 | |
|       [`${componentCls}-month-panel, ${componentCls}-date-panel`]: {
 | |
|         width: 'auto',
 | |
|       },
 | |
|       [`${componentCls}-body`]: {
 | |
|         padding: `${token.paddingXS}px 0`,
 | |
|       },
 | |
|       [`${componentCls}-content`]: {
 | |
|         width: '100%',
 | |
|       },
 | |
|     },
 | |
|     [`${calendarCls}-mini`]: {
 | |
|       borderRadius: token.borderRadiusLG,
 | |
|       [`${calendarCls}-header`]: {
 | |
|         paddingInlineEnd: token.paddingXS,
 | |
|         paddingInlineStart: token.paddingXS,
 | |
|       },
 | |
|       [`${componentCls}-panel`]: {
 | |
|         borderRadius: `0 0 ${token.borderRadiusLG}px ${token.borderRadiusLG}px`,
 | |
|       },
 | |
|       [`${componentCls}-content`]: {
 | |
|         height: token.miniContentHeight,
 | |
|         th: {
 | |
|           height: 'auto',
 | |
|           padding: 0,
 | |
|           lineHeight: `${token.weekHeight}px`,
 | |
|         },
 | |
|       },
 | |
|       [`${componentCls}-cell::before`]: {
 | |
|         pointerEvents: 'none',
 | |
|       },
 | |
|     },
 | |
|     [`${calendarCls}${calendarCls}-full`]: {
 | |
|       [`${componentCls}-panel`]: {
 | |
|         display: 'block',
 | |
|         width: '100%',
 | |
|         textAlign: 'end',
 | |
|         background: calendarFullBg,
 | |
|         border: 0,
 | |
|         [`${componentCls}-body`]: {
 | |
|           'th, td': {
 | |
|             padding: 0,
 | |
|           },
 | |
|           th: {
 | |
|             height: 'auto',
 | |
|             paddingInlineEnd: token.paddingSM,
 | |
|             paddingBottom: token.paddingXXS,
 | |
|             lineHeight: `${token.weekHeight}px`,
 | |
|           },
 | |
|         },
 | |
|       },
 | |
|       [`${componentCls}-cell`]: {
 | |
|         '&::before': {
 | |
|           display: 'none',
 | |
|         },
 | |
|         '&:hover': {
 | |
|           [`${calendarCls}-date`]: {
 | |
|             background: token.controlItemBgHover,
 | |
|           },
 | |
|         },
 | |
|         [`${calendarCls}-date-today::before`]: {
 | |
|           display: 'none',
 | |
|         },
 | |
|         // >>> Selected
 | |
|         [`&-in-view${componentCls}-cell-selected`]: {
 | |
|           [`${calendarCls}-date, ${calendarCls}-date-today`]: {
 | |
|             background: calendarItemActiveBg,
 | |
|           },
 | |
|         },
 | |
|         '&-selected, &-selected:hover': {
 | |
|           [`${calendarCls}-date, ${calendarCls}-date-today`]: {
 | |
|             [`${calendarCls}-date-value`]: {
 | |
|               color: token.colorPrimary,
 | |
|             },
 | |
|           },
 | |
|         },
 | |
|       },
 | |
|       [`${calendarCls}-date`]: {
 | |
|         display: 'block',
 | |
|         width: 'auto',
 | |
|         height: 'auto',
 | |
|         margin: `0 ${token.marginXS / 2}px`,
 | |
|         padding: `${token.paddingXS / 2}px ${token.paddingXS}px 0`,
 | |
|         border: 0,
 | |
|         borderTop: `${token.lineWidthBold}px ${token.lineType} ${token.colorSplit}`,
 | |
|         borderRadius: 0,
 | |
|         transition: `background ${token.motionDurationSlow}`,
 | |
|         '&-value': {
 | |
|           lineHeight: `${token.dateValueHeight}px`,
 | |
|           transition: `color ${token.motionDurationSlow}`,
 | |
|         },
 | |
|         '&-content': {
 | |
|           position: 'static',
 | |
|           width: 'auto',
 | |
|           height: token.dateContentHeight,
 | |
|           overflowY: 'auto',
 | |
|           color: token.colorText,
 | |
|           lineHeight: token.lineHeight,
 | |
|           textAlign: 'start',
 | |
|         },
 | |
|         '&-today': {
 | |
|           borderColor: token.colorPrimary,
 | |
|           [`${calendarCls}-date-value`]: {
 | |
|             color: token.colorText,
 | |
|           },
 | |
|         },
 | |
|       },
 | |
|     },
 | |
|     [`@media only screen and (max-width: ${token.screenXS}px) `]: {
 | |
|       [`${calendarCls}`]: {
 | |
|         [`${calendarCls}-header`]: {
 | |
|           display: 'block',
 | |
|           [`${calendarCls}-year-select`]: {
 | |
|             width: '50%',
 | |
|           },
 | |
|           [`${calendarCls}-month-select`]: {
 | |
|             width: `calc(50% - ${token.paddingXS}px)`,
 | |
|           },
 | |
|           [`${calendarCls}-mode-switch`]: {
 | |
|             width: '100%',
 | |
|             marginTop: token.marginXS,
 | |
|             marginInlineStart: 0,
 | |
|             '> label': {
 | |
|               width: '50%',
 | |
|               textAlign: 'center',
 | |
|             },
 | |
|           },
 | |
|         },
 | |
|       },
 | |
|     },
 | |
|   };
 | |
| };
 | |
| 
 | |
| export default genComponentStyleHook(
 | |
|   'Calendar',
 | |
|   token => {
 | |
|     const calendarCls = `${token.componentCls}-calendar`;
 | |
|     const calendarToken = mergeToken<CalendarToken>(
 | |
|       initInputToken<FullToken<'Calendar'>>(token),
 | |
|       initPickerPanelToken(token),
 | |
|       {
 | |
|         calendarCls,
 | |
|         pickerCellInnerCls: `${token.componentCls}-cell-inner`,
 | |
|         calendarFullBg: token.colorBgContainer,
 | |
|         calendarFullPanelBg: token.colorBgContainer,
 | |
|         calendarItemActiveBg: token.controlItemBgActive,
 | |
|         dateValueHeight: token.controlHeightSM,
 | |
|         weekHeight: token.controlHeightSM * 0.75,
 | |
|         dateContentHeight:
 | |
|           (token.fontSizeSM * token.lineHeightSM + token.marginXS) * 3 + token.lineWidth * 2,
 | |
|       },
 | |
|     );
 | |
| 
 | |
|     return [genCalendarStyles(calendarToken)];
 | |
|   },
 | |
|   {
 | |
|     yearControlWidth: 80,
 | |
|     monthControlWidth: 70,
 | |
|     miniContentHeight: 256,
 | |
|   },
 | |
| );
 |