1
0

insetInput.tsx 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. import React from 'react';
  2. import { get } from 'lodash';
  3. import {
  4. InsetInputValue,
  5. Type,
  6. InsetInputChangeFoundationProps,
  7. } from '@douyinfe/semi-foundation/datePicker/inputFoundation';
  8. import Input, { InputProps } from '../input';
  9. export interface InsetDateInputProps {
  10. forwardRef: InputProps['forwardRef'];
  11. insetInputValue: InsetInputValue;
  12. placeholder: string;
  13. valuePath: string;
  14. onChange: (options: InsetInputChangeFoundationProps) => void;
  15. onFocus: InputProps['onFocus'];
  16. }
  17. export interface InsetTimeInputProps {
  18. disabled: boolean;
  19. insetInputValue: InsetInputValue;
  20. placeholder: string;
  21. valuePath: string;
  22. type: Type;
  23. onChange: (options: InsetInputChangeFoundationProps) => void;
  24. onFocus: InputProps['onFocus'];
  25. }
  26. export function InsetDateInput(props: InsetDateInputProps) {
  27. const { insetInputValue, valuePath, onFocus, onChange, placeholder, forwardRef } = props;
  28. const value = get(insetInputValue, valuePath);
  29. return (
  30. <Input
  31. value={value}
  32. onChange={(value, event) => {
  33. onChange({
  34. value,
  35. event,
  36. insetInputValue,
  37. valuePath,
  38. });
  39. }}
  40. onFocus={onFocus}
  41. placeholder={placeholder}
  42. ref={forwardRef}
  43. />
  44. );
  45. }
  46. export function InsetTimeInput(props: InsetTimeInputProps) {
  47. const { insetInputValue, valuePath, type, onFocus, onChange, placeholder, disabled } = props;
  48. const _isTimeType = type.includes('Time');
  49. if (!_isTimeType) {
  50. return null;
  51. }
  52. const value = get(insetInputValue, valuePath);
  53. return (
  54. <Input
  55. value={value}
  56. onChange={(value, event) => {
  57. onChange({
  58. value,
  59. event,
  60. insetInputValue,
  61. valuePath,
  62. });
  63. }}
  64. onFocus={onFocus}
  65. placeholder={placeholder}
  66. disabled={disabled}
  67. />
  68. );
  69. }