mirror of
https://gitee.com/ant-design/ant-design.git
synced 2024-12-14 08:51:26 +08:00
c3e51506cc
* feat: add Space.Compact * feat: update input style * feat: add CompactItem for context memoize * feat: add demo * feat: update button style * feat: update input style * feat: 提取 getCompactClassNames 公用方法 * feat: update button style * feat: update picker * feat: add block prop for Space.Compact * feat: use Space.Compact for Input#addonBefore/After * feat: update addon * refactor: compact * feat: update * feat: update * feat: migrate styles to compact for new Input/Input.Search * feat: organize input demo * feat: add more button compact demo * feat: resolve select border collapse * feat: fix input addon select style * feat: add input addon demo in Space * feat: add useCompactItemContext hook * feat: update compact-item style * feat: rollback input#addon implements * feat: rollback input#addon and input.search style * feat: select border collapse * feat: add Space.Compact demo * feat: Space.Compact vertical for Button * refactor: useCompactItemContext * feat: update Button vertical demo * feat: rtl for compact mixin * feat: rtl for compact button * feat: input rtl * feat: add docs for Space.Compact * test: add some tests for Space.Compact * test: add tests * feat: select style * feat: handle select focus style * feat: add useCompactItemContext for Picker and Cascader * style: add compact-item style for cascader * feat: support nested Space.Compact * style: Input.Search in Space.Compact * chore: clean * feat: add useCompactItemContext for TreeSelect * fix: lint issues * fix: style lint * docs: update demos for Space.Compact * docs: update demo * fix: add deps-lint-skip for space * fix: add deps-lint-skip for space * fix: handle edge case for useCompactItemContext * test: add search test case * chore: + bundlesize * style: merge button compact style into one file * style: improve style for nested compact * fix: stylelint * docs: update Space.Compact docs * test: update demo snapshot * test: update input debug test snapshot * docs: update doccs for Space.Compact * test: improve test cases for Compact * docs: clean demos for Compact * refactor: improve Space.Compact * fix: add useCompactItemContext for Input.Search * style: improve compact border-radius implementation * refactor: use context to make nested compact works * fix: input-number focused style * refactor: remove useless style * refactor: improve style for vertical compact * test: update snapshot * test: update snapshot for input * refactor: improve compact-item-border-radius * fix: search group in RTL * style: improve style for button compact * style: use after * fix: stylelint * chore: update snapshot * style: improve button compact * refactor: improve btn-icon-only style in compact
186 lines
7.5 KiB
TypeScript
186 lines
7.5 KiB
TypeScript
import CalendarOutlined from '@ant-design/icons/CalendarOutlined';
|
|
import ClockCircleOutlined from '@ant-design/icons/ClockCircleOutlined';
|
|
import CloseCircleFilled from '@ant-design/icons/CloseCircleFilled';
|
|
import classNames from 'classnames';
|
|
import RCPicker from 'rc-picker';
|
|
import type { GenerateConfig } from 'rc-picker/lib/generate/index';
|
|
import type { PickerMode } from 'rc-picker/lib/interface';
|
|
import * as React from 'react';
|
|
import { forwardRef, useContext, useImperativeHandle } from 'react';
|
|
import { useCompactItemContext } from '../../space/Compact';
|
|
import type { PickerDateProps, PickerProps, PickerTimeProps } from '.';
|
|
import { Components, getTimeProps } from '.';
|
|
import { ConfigContext } from '../../config-provider';
|
|
import DisabledContext from '../../config-provider/DisabledContext';
|
|
import SizeContext from '../../config-provider/SizeContext';
|
|
import { FormItemInputContext } from '../../form/context';
|
|
import LocaleReceiver from '../../locale-provider/LocaleReceiver';
|
|
import type { InputStatus } from '../../_util/statusUtils';
|
|
import { getMergedStatus, getStatusClassNames } from '../../_util/statusUtils';
|
|
import warning from '../../_util/warning';
|
|
import enUS from '../locale/en_US';
|
|
import { getPlaceholder, transPlacement2DropdownAlign } from '../util';
|
|
import type { CommonPickerMethods, DatePickRef, PickerComponentClass } from './interface';
|
|
|
|
export default function generatePicker<DateType>(generateConfig: GenerateConfig<DateType>) {
|
|
type DatePickerProps = PickerProps<DateType> & {
|
|
status?: InputStatus;
|
|
/**
|
|
* @deprecated `dropdownClassName` is deprecated which will be removed in next major
|
|
* version.Please use `popupClassName` instead.
|
|
*/
|
|
dropdownClassName?: string;
|
|
popupClassName?: string;
|
|
};
|
|
function getPicker<InnerPickerProps extends DatePickerProps>(
|
|
picker?: PickerMode,
|
|
displayName?: string,
|
|
) {
|
|
const Picker = forwardRef<DatePickRef<DateType> | CommonPickerMethods, InnerPickerProps>(
|
|
(props, ref) => {
|
|
const {
|
|
prefixCls: customizePrefixCls,
|
|
getPopupContainer: customizeGetPopupContainer,
|
|
className,
|
|
size: customizeSize,
|
|
bordered = true,
|
|
placement,
|
|
placeholder,
|
|
popupClassName,
|
|
dropdownClassName,
|
|
disabled: customDisabled,
|
|
status: customStatus,
|
|
...restProps
|
|
} = props;
|
|
|
|
const { getPrefixCls, direction, getPopupContainer } = useContext(ConfigContext);
|
|
const prefixCls = getPrefixCls('picker', customizePrefixCls);
|
|
const { compactSize, compactItemClassnames } = useCompactItemContext(prefixCls, direction);
|
|
const innerRef = React.useRef<RCPicker<DateType>>(null);
|
|
const { format, showTime } = props as any;
|
|
|
|
useImperativeHandle(ref, () => ({
|
|
focus: () => innerRef.current?.focus(),
|
|
blur: () => innerRef.current?.blur(),
|
|
}));
|
|
|
|
const additionalProps = {
|
|
showToday: true,
|
|
};
|
|
|
|
let additionalOverrideProps: any = {};
|
|
if (picker) {
|
|
additionalOverrideProps.picker = picker;
|
|
}
|
|
const mergedPicker = picker || props.picker;
|
|
|
|
additionalOverrideProps = {
|
|
...additionalOverrideProps,
|
|
...(showTime ? getTimeProps({ format, picker: mergedPicker, ...showTime }) : {}),
|
|
...(mergedPicker === 'time'
|
|
? getTimeProps({ format, ...props, picker: mergedPicker })
|
|
: {}),
|
|
};
|
|
const rootPrefixCls = getPrefixCls();
|
|
|
|
// =================== Warning =====================
|
|
warning(
|
|
picker !== 'quarter',
|
|
displayName!,
|
|
`DatePicker.${displayName} is legacy usage. Please use DatePicker[picker='${picker}'] directly.`,
|
|
);
|
|
|
|
warning(
|
|
!dropdownClassName,
|
|
'DatePicker',
|
|
'`dropdownClassName` is deprecated which will be removed in next major version. Please use `popupClassName` instead.',
|
|
);
|
|
// ===================== Size =====================
|
|
const size = React.useContext(SizeContext);
|
|
const mergedSize = compactSize || customizeSize || size;
|
|
|
|
// ===================== Disabled =====================
|
|
const disabled = React.useContext(DisabledContext);
|
|
const mergedDisabled = customDisabled ?? disabled;
|
|
|
|
// ===================== FormItemInput =====================
|
|
const formItemContext = useContext(FormItemInputContext);
|
|
const { hasFeedback, status: contextStatus, feedbackIcon } = formItemContext;
|
|
|
|
const suffixNode = (
|
|
<>
|
|
{mergedPicker === 'time' ? <ClockCircleOutlined /> : <CalendarOutlined />}
|
|
{hasFeedback && feedbackIcon}
|
|
</>
|
|
);
|
|
|
|
return (
|
|
<LocaleReceiver componentName="DatePicker" defaultLocale={enUS}>
|
|
{contextLocale => {
|
|
const locale = { ...contextLocale, ...props.locale };
|
|
|
|
return (
|
|
<RCPicker<DateType>
|
|
ref={innerRef}
|
|
placeholder={getPlaceholder(mergedPicker, locale, placeholder)}
|
|
suffixIcon={suffixNode}
|
|
dropdownAlign={transPlacement2DropdownAlign(direction, placement)}
|
|
dropdownClassName={popupClassName || dropdownClassName}
|
|
clearIcon={<CloseCircleFilled />}
|
|
prevIcon={<span className={`${prefixCls}-prev-icon`} />}
|
|
nextIcon={<span className={`${prefixCls}-next-icon`} />}
|
|
superPrevIcon={<span className={`${prefixCls}-super-prev-icon`} />}
|
|
superNextIcon={<span className={`${prefixCls}-super-next-icon`} />}
|
|
allowClear
|
|
transitionName={`${rootPrefixCls}-slide-up`}
|
|
{...additionalProps}
|
|
{...restProps}
|
|
{...additionalOverrideProps}
|
|
locale={locale!.lang}
|
|
className={classNames(
|
|
{
|
|
[`${prefixCls}-${mergedSize}`]: mergedSize,
|
|
[`${prefixCls}-borderless`]: !bordered,
|
|
},
|
|
getStatusClassNames(
|
|
prefixCls as string,
|
|
getMergedStatus(contextStatus, customStatus),
|
|
hasFeedback,
|
|
),
|
|
compactItemClassnames,
|
|
className,
|
|
)}
|
|
prefixCls={prefixCls}
|
|
getPopupContainer={customizeGetPopupContainer || getPopupContainer}
|
|
generateConfig={generateConfig}
|
|
components={Components}
|
|
direction={direction}
|
|
disabled={mergedDisabled}
|
|
/>
|
|
);
|
|
}}
|
|
</LocaleReceiver>
|
|
);
|
|
},
|
|
);
|
|
|
|
if (displayName) {
|
|
Picker.displayName = displayName;
|
|
}
|
|
|
|
return Picker as unknown as PickerComponentClass<InnerPickerProps>;
|
|
}
|
|
|
|
const DatePicker = getPicker<DatePickerProps>();
|
|
const WeekPicker = getPicker<Omit<PickerDateProps<DateType>, 'picker'>>('week', 'WeekPicker');
|
|
const MonthPicker = getPicker<Omit<PickerDateProps<DateType>, 'picker'>>('month', 'MonthPicker');
|
|
const YearPicker = getPicker<Omit<PickerDateProps<DateType>, 'picker'>>('year', 'YearPicker');
|
|
const TimePicker = getPicker<Omit<PickerTimeProps<DateType>, 'picker'>>('time', 'TimePicker');
|
|
const QuarterPicker = getPicker<Omit<PickerTimeProps<DateType>, 'picker'>>(
|
|
'quarter',
|
|
'QuarterPicker',
|
|
);
|
|
|
|
return { DatePicker, WeekPicker, MonthPicker, YearPicker, TimePicker, QuarterPicker };
|
|
}
|