Skip to content

Commit

Permalink
feat: input token (ant-design#44325)
Browse files Browse the repository at this point in the history
* feat: input token

* feat: input number token

* feat: input token

* fix: date-picker & calendar

* fix: calendar style

* fix: token use
  • Loading branch information
MadCcc authored Aug 22, 2023
1 parent f34ff52 commit d1d3b57
Show file tree
Hide file tree
Showing 10 changed files with 305 additions and 149 deletions.
24 changes: 9 additions & 15 deletions components/calendar/style/index.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,6 @@
import type { CSSObject } from '@ant-design/cssinjs';
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 { resetComponent } from '../../style';
import type { FullToken } from '../../theme/internal';
import { genComponentStyleHook, mergeToken } from '../../theme/internal';
Expand Down Expand Up @@ -40,7 +38,7 @@ export interface ComponentToken {
itemActiveBg: string;
}

interface CalendarToken extends InputToken<FullToken<'Calendar'>>, PickerPanelToken {
interface CalendarToken extends FullToken<'Calendar'>, PickerPanelToken {
calendarCls: string;
dateValueHeight: number;
weekHeight: number;
Expand Down Expand Up @@ -215,18 +213,14 @@ 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`,
dateValueHeight: token.controlHeightSM,
weekHeight: token.controlHeightSM * 0.75,
dateContentHeight:
(token.fontSizeSM * token.lineHeightSM + token.marginXS) * 3 + token.lineWidth * 2,
},
);
const calendarToken = mergeToken<CalendarToken>(token, initPickerPanelToken(token), {
calendarCls,
pickerCellInnerCls: `${token.componentCls}-cell-inner`,
dateValueHeight: token.controlHeightSM,
weekHeight: token.controlHeightSM * 0.75,
dateContentHeight:
(token.fontSizeSM * token.lineHeightSM + token.marginXS) * 3 + token.lineWidth * 2,
});

return [genCalendarStyles(calendarToken)];
},
Expand Down
43 changes: 21 additions & 22 deletions components/date-picker/style/index.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,11 @@
import type { CSSObject } from '@ant-design/cssinjs';
import { TinyColor } from '@ctrl/tinycolor';
import type { InputToken } from '../../input/style';
import type { SharedComponentToken, SharedInputToken } from '../../input/style';
import {
genActiveStyle,
genBasicInputStyle,
genHoverStyle,
initComponentToken,
initInputToken,
} from '../../input/style';
import { resetComponent, roundedArrow, textEllipsis } from '../../style';
Expand All @@ -22,7 +23,7 @@ import type { FullToken, GenerateStyle } from '../../theme/internal';
import { genComponentStyleHook, mergeToken } from '../../theme/internal';
import type { TokenWithCommonCls } from '../../theme/util/genComponentStyleHook';

export interface ComponentToken {
export interface ComponentToken extends Exclude<SharedComponentToken, 'addonBg'> {
/**
* @desc 预设区域宽度
* @descEN Width of preset area
Expand Down Expand Up @@ -61,9 +62,9 @@ export type PickerPanelToken = {
pickerControlIconBorderWidth: number;
};

type PickerToken = InputToken<FullToken<'DatePicker'>> & PickerPanelToken;
type PickerToken = FullToken<'DatePicker'> & PickerPanelToken & SharedInputToken;

type SharedPickerToken = Omit<PickerToken, 'zIndexPopup' | 'presetsWidth' | 'presetsMaxWidth'>;
type SharedPickerToken = TokenWithCommonCls<GlobalToken> & PickerPanelToken;

const genPikerPadding = (
token: PickerToken,
Expand Down Expand Up @@ -951,8 +952,8 @@ const genPickerStatusStyle: GenerateStyle<PickerToken> = (token) => {
[`&${componentCls}-focused, &:focus`]: {
...genActiveStyle(
mergeToken<PickerToken>(token, {
inputBorderActiveColor: colorError,
inputBorderHoverColor: colorError,
activeBorderColor: colorError,
hoverBorderColor: colorError,
controlOutline: colorErrorOutline,
}),
),
Expand All @@ -972,8 +973,8 @@ const genPickerStatusStyle: GenerateStyle<PickerToken> = (token) => {
[`&${componentCls}-focused, &:focus`]: {
...genActiveStyle(
mergeToken<PickerToken>(token, {
inputBorderActiveColor: colorWarning,
inputBorderHoverColor: colorWarning,
activeBorderColor: colorWarning,
hoverBorderColor: colorWarning,
controlOutline: colorWarningOutline,
}),
),
Expand All @@ -993,7 +994,7 @@ const genPickerStyle: GenerateStyle<PickerToken> = (token) => {
antCls,
controlHeight,
fontSize,
inputPaddingHorizontal,
paddingInline,
colorBgContainer,
lineWidth,
lineType,
Expand All @@ -1006,7 +1007,7 @@ const genPickerStyle: GenerateStyle<PickerToken> = (token) => {
controlHeightLG,
fontSizeLG,
controlHeightSM,
inputPaddingHorizontalSM,
paddingInlineSM,
paddingXS,
marginXS,
colorTextDescription,
Expand Down Expand Up @@ -1039,7 +1040,7 @@ const genPickerStyle: GenerateStyle<PickerToken> = (token) => {
{
[componentCls]: {
...resetComponent(token),
...genPikerPadding(token, controlHeight, fontSize, inputPaddingHorizontal),
...genPikerPadding(token, controlHeight, fontSize, paddingInline),
position: 'relative',
display: 'inline-flex',
alignItems: 'center',
Expand Down Expand Up @@ -1117,15 +1118,15 @@ const genPickerStyle: GenerateStyle<PickerToken> = (token) => {

// Size
'&-large': {
...genPikerPadding(token, controlHeightLG, fontSizeLG, inputPaddingHorizontal),
...genPikerPadding(token, controlHeightLG, fontSizeLG, paddingInline),

[`${componentCls}-input > input`]: {
fontSize: fontSizeLG,
},
},

'&-small': {
...genPikerPadding(token, controlHeightSM, fontSize, inputPaddingHorizontalSM),
...genPikerPadding(token, controlHeightSM, fontSize, paddingInlineSM),
},

[`${componentCls}-suffix`]: {
Expand Down Expand Up @@ -1195,7 +1196,7 @@ const genPickerStyle: GenerateStyle<PickerToken> = (token) => {

// Clear
[`${componentCls}-clear`]: {
insetInlineEnd: inputPaddingHorizontal,
insetInlineEnd: paddingInline,
},

'&:hover': {
Expand All @@ -1208,7 +1209,7 @@ const genPickerStyle: GenerateStyle<PickerToken> = (token) => {
[`${componentCls}-active-bar`]: {
bottom: -lineWidth,
height: lineWidthBold,
marginInlineStart: inputPaddingHorizontal,
marginInlineStart: paddingInline,
background: colorPrimary,
opacity: 0,
transition: `all ${motionDurationSlow} ease-out`,
Expand All @@ -1229,11 +1230,11 @@ const genPickerStyle: GenerateStyle<PickerToken> = (token) => {

[`&${componentCls}-small`]: {
[`${componentCls}-clear`]: {
insetInlineEnd: inputPaddingHorizontalSM,
insetInlineEnd: paddingInlineSM,
},

[`${componentCls}-active-bar`]: {
marginInlineStart: inputPaddingHorizontalSM,
marginInlineStart: paddingInlineSM,
},
},
},
Expand Down Expand Up @@ -1342,7 +1343,7 @@ const genPickerStyle: GenerateStyle<PickerToken> = (token) => {
position: 'absolute',
zIndex: 1,
display: 'none',
marginInlineStart: inputPaddingHorizontal * 1.5,
marginInlineStart: paddingInline * 1.5,
transition: `left ${motionDurationSlow} ease-out`,
...roundedArrow(
sizePopupArrow,
Expand Down Expand Up @@ -1501,10 +1502,7 @@ export const initPickerPanelToken = (token: TokenWithCommonCls<GlobalToken>): Pi
export default genComponentStyleHook(
'DatePicker',
(token) => {
const pickerToken = mergeToken<PickerToken>(
initInputToken<FullToken<'DatePicker'>>(token),
initPickerPanelToken(token),
);
const pickerToken = mergeToken<PickerToken>(initInputToken(token), initPickerPanelToken(token));
return [
genPickerStyle(pickerToken),
genPickerStatusStyle(pickerToken),
Expand All @@ -1517,6 +1515,7 @@ export default genComponentStyleHook(
];
},
(token) => ({
...initComponentToken(token),
presetsWidth: 120,
presetsMaxWidth: 200,
zIndexPopup: token.zIndexPopupBase + 50,
Expand Down
Loading

0 comments on commit d1d3b57

Please sign in to comment.