Date.tsx 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. /*
  2. * <<
  3. * Davinci
  4. * ==
  5. * Copyright (C) 2016 - 2017 EDP
  6. * ==
  7. * Licensed under the Apache License, Version 2.0 (the "License");
  8. * you may not use this file except in compliance with the License.
  9. * You may obtain a copy of the License at
  10. *
  11. * http://www.apache.org/licenses/LICENSE-2.0
  12. *
  13. * Unless required by applicable law or agreed to in writing, software
  14. * distributed under the License is distributed on an "AS IS" BASIS,
  15. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  16. * See the License for the specific language governing permissions and
  17. * limitations under the License.
  18. * >>
  19. */
  20. import React, { FC, useCallback, forwardRef } from 'react'
  21. import moment from 'moment'
  22. import { IControl } from '../types'
  23. import { DatePicker } from 'antd'
  24. const { WeekPicker, MonthPicker } = DatePicker
  25. const MultiDatePicker = React.lazy(() => import('components/MultiDatePicker'))
  26. import { DatePickerFormats } from '../constants'
  27. interface IDateProps {
  28. control: Omit<IControl, 'relatedItems' | 'relatedViews'>
  29. value?: any
  30. size?: 'large' | 'small' | 'default'
  31. onChange?: (value) => void
  32. }
  33. const Date: FC<IDateProps> = ({ control, value, size, onChange }, ref) => {
  34. const { Week, Month, Year, Datetime, DatetimeMinute } = DatePickerFormats
  35. const { multiple, dateFormat } = control
  36. const controlled = !!onChange
  37. if (multiple) {
  38. value = value || ''
  39. return (
  40. <MultiDatePicker
  41. ref={ref}
  42. placeholder="请选择"
  43. format={dateFormat}
  44. {...(size && { size })}
  45. {...(controlled && { value, onChange })}
  46. />
  47. )
  48. } else {
  49. value = moment.isMoment(value) ? value : null
  50. switch (dateFormat) {
  51. case Week:
  52. return (
  53. <WeekPicker
  54. ref={ref}
  55. placeholder="请选择"
  56. {...(size && { size })}
  57. {...(controlled && { value, onChange })}
  58. />
  59. )
  60. case Month:
  61. case Year:
  62. return (
  63. <MonthPicker
  64. ref={ref}
  65. placeholder="请选择"
  66. format={dateFormat}
  67. {...(size && { size })}
  68. {...(controlled && { value, onChange })}
  69. />
  70. )
  71. default:
  72. const isDatetimePicker = [Datetime, DatetimeMinute].includes(dateFormat)
  73. return (
  74. <DatePicker
  75. ref={ref}
  76. placeholder="请选择"
  77. showTime={isDatetimePicker}
  78. format={dateFormat}
  79. {...(size && { size })}
  80. {...(controlled && { value })}
  81. {...(controlled && { onChange })}
  82. {...(controlled && { onOk: onChange })}
  83. />
  84. )
  85. }
  86. }
  87. }
  88. export default forwardRef(Date)