123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
- /*
- * <<
- * Davinci
- * ==
- * Copyright (C) 2016 - 2017 EDP
- * ==
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- * >>
- */
- import React, { FC, useCallback, forwardRef } from 'react'
- import moment from 'moment'
- import { IControl } from '../types'
- import { DatePicker } from 'antd'
- const { WeekPicker, MonthPicker } = DatePicker
- const MultiDatePicker = React.lazy(() => import('components/MultiDatePicker'))
- import { DatePickerFormats } from '../constants'
- interface IDateProps {
- control: Omit<IControl, 'relatedItems' | 'relatedViews'>
- value?: any
- size?: 'large' | 'small' | 'default'
- onChange?: (value) => void
- }
- const Date: FC<IDateProps> = ({ control, value, size, onChange }, ref) => {
- const { Week, Month, Year, Datetime, DatetimeMinute } = DatePickerFormats
- const { multiple, dateFormat } = control
- const controlled = !!onChange
- if (multiple) {
- value = value || ''
- return (
- <MultiDatePicker
- ref={ref}
- placeholder="请选择"
- format={dateFormat}
- {...(size && { size })}
- {...(controlled && { value, onChange })}
- />
- )
- } else {
- value = moment.isMoment(value) ? value : null
- switch (dateFormat) {
- case Week:
- return (
- <WeekPicker
- ref={ref}
- placeholder="请选择"
- {...(size && { size })}
- {...(controlled && { value, onChange })}
- />
- )
- case Month:
- case Year:
- return (
- <MonthPicker
- ref={ref}
- placeholder="请选择"
- format={dateFormat}
- {...(size && { size })}
- {...(controlled && { value, onChange })}
- />
- )
- default:
- const isDatetimePicker = [Datetime, DatetimeMinute].includes(dateFormat)
- return (
- <DatePicker
- ref={ref}
- placeholder="请选择"
- showTime={isDatetimePicker}
- format={dateFormat}
- {...(size && { size })}
- {...(controlled && { value })}
- {...(controlled && { onChange })}
- {...(controlled && { onOk: onChange })}
- />
- )
- }
- }
- }
- export default forwardRef(Date)
|