mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-22 08:53:29 +08:00
daa9804824
* feat: select components add placement api * feat: select components add placement api * fix: delete placement * fix: change md demo and delete export * feat: cascader and tree-select add placement * feat: datapicker add placement api * fix: change repeat static declaration to single * test: updata test units * doc: change doc * fix: delete merge message & delete decalare ts * test: fix unit test * fix: add transName in select & treeSelect & cascader * fix: change common api in utils * fix: change useless if block to only * fix: change placement string to enum * fix: lint done Co-authored-by: 礼检 <ljj337009@antgroup.com>
120 lines
4.3 KiB
TypeScript
120 lines
4.3 KiB
TypeScript
import * as React from 'react';
|
|
import classNames from 'classnames';
|
|
import CalendarOutlined from '@ant-design/icons/CalendarOutlined';
|
|
import ClockCircleOutlined from '@ant-design/icons/ClockCircleOutlined';
|
|
import CloseCircleFilled from '@ant-design/icons/CloseCircleFilled';
|
|
import SwapRightOutlined from '@ant-design/icons/SwapRightOutlined';
|
|
import { RangePicker as RCRangePicker } from 'rc-picker';
|
|
import { GenerateConfig } from 'rc-picker/lib/generate/index';
|
|
import enUS from '../locale/en_US';
|
|
import { ConfigContext, ConfigConsumerProps } from '../../config-provider';
|
|
import SizeContext from '../../config-provider/SizeContext';
|
|
import LocaleReceiver from '../../locale-provider/LocaleReceiver';
|
|
import { getRangePlaceholder, transPlacement2DropdownAlign } from '../util';
|
|
import { RangePickerProps, PickerLocale, getTimeProps, Components } from '.';
|
|
import { PickerComponentClass } from './interface';
|
|
|
|
export default function generateRangePicker<DateType>(
|
|
generateConfig: GenerateConfig<DateType>,
|
|
): PickerComponentClass<RangePickerProps<DateType>> {
|
|
class RangePicker extends React.Component<RangePickerProps<DateType>> {
|
|
static contextType = ConfigContext;
|
|
|
|
context: ConfigConsumerProps;
|
|
|
|
pickerRef = React.createRef<RCRangePicker<DateType>>();
|
|
|
|
focus = () => {
|
|
if (this.pickerRef.current) {
|
|
this.pickerRef.current.focus();
|
|
}
|
|
};
|
|
|
|
blur = () => {
|
|
if (this.pickerRef.current) {
|
|
this.pickerRef.current.blur();
|
|
}
|
|
};
|
|
|
|
renderPicker = (contextLocale: PickerLocale) => {
|
|
const locale = { ...contextLocale, ...this.props.locale };
|
|
const { getPrefixCls, direction, getPopupContainer } = this.context;
|
|
const {
|
|
prefixCls: customizePrefixCls,
|
|
getPopupContainer: customGetPopupContainer,
|
|
className,
|
|
placement,
|
|
size: customizeSize,
|
|
bordered = true,
|
|
placeholder,
|
|
...restProps
|
|
} = this.props;
|
|
const { format, showTime, picker } = this.props as any;
|
|
const prefixCls = getPrefixCls('picker', customizePrefixCls);
|
|
|
|
let additionalOverrideProps: any = {};
|
|
|
|
additionalOverrideProps = {
|
|
...additionalOverrideProps,
|
|
...(showTime ? getTimeProps({ format, picker, ...showTime }) : {}),
|
|
...(picker === 'time' ? getTimeProps({ format, ...this.props, picker }) : {}),
|
|
};
|
|
const rootPrefixCls = getPrefixCls();
|
|
|
|
return (
|
|
<SizeContext.Consumer>
|
|
{size => {
|
|
const mergedSize = customizeSize || size;
|
|
|
|
return (
|
|
<RCRangePicker<DateType>
|
|
separator={
|
|
<span aria-label="to" className={`${prefixCls}-separator`}>
|
|
<SwapRightOutlined />
|
|
</span>
|
|
}
|
|
ref={this.pickerRef}
|
|
dropdownAlign={transPlacement2DropdownAlign(direction, placement)}
|
|
placeholder={getRangePlaceholder(picker, locale, placeholder)}
|
|
suffixIcon={picker === 'time' ? <ClockCircleOutlined /> : <CalendarOutlined />}
|
|
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`}
|
|
{...restProps}
|
|
{...additionalOverrideProps}
|
|
className={classNames(
|
|
{
|
|
[`${prefixCls}-${mergedSize}`]: mergedSize,
|
|
[`${prefixCls}-borderless`]: !bordered,
|
|
},
|
|
className,
|
|
)}
|
|
locale={locale!.lang}
|
|
prefixCls={prefixCls}
|
|
getPopupContainer={customGetPopupContainer || getPopupContainer}
|
|
generateConfig={generateConfig}
|
|
components={Components}
|
|
direction={direction}
|
|
/>
|
|
);
|
|
}}
|
|
</SizeContext.Consumer>
|
|
);
|
|
};
|
|
|
|
render() {
|
|
return (
|
|
<LocaleReceiver componentName="DatePicker" defaultLocale={enUS}>
|
|
{this.renderPicker}
|
|
</LocaleReceiver>
|
|
);
|
|
}
|
|
}
|
|
|
|
return RangePicker;
|
|
}
|