Date

General

Use the parent container to control the width, default 100%


 
 
Show Code
import React from "react";
import Date from 'funda-ui/Date';
 
// component styles
import 'funda-ui/Date/index.css';
 
export default () => {
 
    return (
        <>
 
            <Date
                name="name"
                label="Date"
                value="2024-03-13"
                type="date"
                placeholder="yyyy/MM/dd"
                onChange={(input: HTMLInputElement, dateRes: any, isValidDate: boolean, allSplittingInputs: any[]) => {
                    console.log(isValidDate, input, dateRes, dateRes !== null && typeof dateRes !== 'string' ? dateRes.res : dateRes, allSplittingInputs)
                }}
                onLoad={(initValue: string, dateRes: any, allSplittingInputs: any[]) => {
                    console.log(initValue, dateRes, allSplittingInputs)
                }}
                onPressEnter={(control: HTMLElement, allControls: HTMLElement[]) => {
                    // ...
                }}
            />
 
 
 
            <Date
                name="name"
                label="Date & Time (no seconds)"
                value="2024-03-14 10:22"
                type="datetime-local"
                placeholder="yyyy/MM/dd HH:mm"
                onChange={(input: HTMLInputElement, dateRes: any, isValidDate: boolean, allSplittingInputs: any[]) => {
                    console.log(isValidDate, input, dateRes, dateRes !== null && typeof dateRes !== 'string' ? dateRes.res : dateRes, allSplittingInputs)
                }}
                onLoad={(initValue: string, dateRes: any, allSplittingInputs: any[]) => {
                    console.log(initValue, dateRes, allSplittingInputs)
                }}
                truncateSeconds
            />
 
 
            <Date
                name="name"
                label="Time"
                value="07:30:38"
                placeholder="HH:mm:ss"
                type="time"
                onChange={(input: HTMLInputElement, dateRes: any, isValidDate: boolean, allSplittingInputs: any[]) => {
                    console.log(isValidDate, input, dateRes, dateRes !== null && typeof dateRes !== 'string' ? dateRes.res : dateRes, allSplittingInputs)
                }}
                onLoad={(initValue: string, dateRes: any, allSplittingInputs: any[]) => {
                    console.log(initValue, dateRes, allSplittingInputs)
                }}
                onlyTime
            />
 
          
        </>
    );
}

No spacing


 
Show Code
import React from "react";
import Date from 'funda-ui/Date';
 
// component styles
import 'funda-ui/Date/index.css';
 
export default () => {
 
 
    return (
        <>
 
            <Date
                ...
                wrapperClassName="position-relative"
                ...
            />
 
             <Date
                ...
                wrapperClassName=""
                ...
            />
 
        </>
    );
}

Use asynchronous to specify a value

When you make asynchronous changes, the time widget is rendered in real time, so you need to update the action when you lose focus. If you only need the default value to be loaded once, you can use defaultValue.


 
2024-12-23
Show Code
import React, { useState } from 'react';
import Date from 'funda-ui/Date';
 
// component styles
import 'funda-ui/Date/index.css';
 
 
 
export default () => {
 
    const [myValue, setMyValue] = useState<string>('2024-12-23');
    
    /**
     * Zero Padding
     * @param {Number} num
     * @param {Boolean} padZeroEnabled 
     * @returns {String}  '01', '05', '12'
     */
    const padZero = (num, padZeroEnabled = true) => {
        if (padZeroEnabled) {
            return num < 10 ? '0' + num : num.toString();
        } else {
            return num.toString();
        }
 
    };
 
    return (
 
        <>
 
             <Date
                value={myValue}
                // defaultValue={myValue}
                type="date"
                placeholder="yyyy/MM/dd"
                onBlur={(e: any, allSplittingInputs: any[]) => {
                    const _curDate = `${allSplittingInputs[0].value}-${padZero(Number(allSplittingInputs[1].value))}-${padZero(Number(allSplittingInputs[2].value))}`;
                    setMyValue(_curDate);
                    console.log('current value is ', _curDate);
                    // location.hash = xxxxxxx;
                }}
            />
 
             <small>{myValue}</small>
 
        </>
    )
}

Auto/Custom Width

You can also set a parent container to control the width.


 
 
Show Code
import React from "react";
import Date from 'funda-ui/Date';
 
// component styles
import 'funda-ui/Date/index.css';
 
export default () => {
 
    return (
        <>
 
            <Date 
                triggerClassName="w-auto"
                ...
            />
 
 
            <div style={{ width: '300px'}}>
                <Date
                    ...
                />
            </div>
 
 
        </>
    );
}

Remove Date Control border and background color


 
Show Code
import React from "react";
import Date from 'funda-ui/Date';
 
// component styles
import 'funda-ui/Date/index.css';
 
export default () => {
 
 
    return (
        <>
 
            <div style={{ background: '#d7fcf7', borderRadius: '0.35rem'}}>
 
                <Date
                    ...
                    style={{border: 'none', background: 'transparent', fontSize: '0.75rem'}}
                    ...
                />
 
            </div>
 
 
 
        </>
    );
}

Asynchronous Usage


 
Show Code
import React, { useEffect, useState } from "react";
import Date from 'funda-ui/Date';
 
// component styles
import 'funda-ui/Date/index.css';
 
export default () => {
 
    const defaultVal = '2024-03-14 10:22:05';
    const [customDate, setCustomDate] = useState<string>('');
 
 
    useEffect(() => {
       setCustomDate(defaultVal);
    }, []);
 
 
    return (
        <>
 
 
           <Date
                name="name"
                defaultValue={customDate} // Don't use the "value" attribute to specify a state that changes in real time
                type="datetime-local"
                placeholder="yyyy/MM/dd HH:mm:ss"
                onChange={(input: HTMLInputElement, dateRes: any, isValidDate: boolean, allSplittingInputs: any[]) => {
                    let _valRes = dateRes !== null && typeof dateRes !== 'string' ? dateRes.res : dateRes;
                    _valRes = _valRes.split(':').length === 3 ? _valRes : `${_valRes}:00`;
                    if (_valRes === ':00') _valRes = '';
 
                    console.log(_valRes);
                    setCustomDate(_valRes);
                }}
            />
 
 
        </>
    );
}

Change language


 
Show Code
import React from "react";
import Date from 'funda-ui/Date';
 
// component styles
import 'funda-ui/Date/index.css';
 
export default () => {
 
    return (
        <>
 
            <Date 
                langHoursTitle="时"
                langMinutesTitle="分"
                langSecondsTitle="秒"
                langWeek={['星期一', '星期二', '星期三', '星期四', '星期五', '星期六', '星期日']}
                langMonths={['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月']}
                langMonthsFull={['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月']}
                langToday="今天"
                ...
            />
 
 
 
            <Date 
                localization="zh_CN"
                ...
            />
 
        </>
    );
}

Popup closes automatically after a minute of tapping

Lets you callback the handle exposed as attribute popupRef.


 
Show Code
import React, {useRef} from "react";
import Date from 'funda-ui/Date';
 
// component styles
import 'funda-ui/Date/index.css';
 
export default () => {
 
    const popupRef = useRef<any>();
 
 
    return (
        <>
 
 
 
           <Date
                popupRef={popupRef}
                name="name"
                label="Date & Time (no seconds)"
                value="2024-03-14 10:22"
                placeholder="yyyy/MM/dd HH:mm"
                type="datetime-local"
                onChange={(input: HTMLInputElement, dateRes: any, isValidDate: boolean, allSplittingInputs: any[]) => {
                    console.log(isValidDate, input, dateRes, dateRes !== null && typeof dateRes !== 'string' ? dateRes.res : dateRes, allSplittingInputs)
                }}
                onLoad={(initValue: string, dateRes: any, allSplittingInputs: any[]) => {
                    console.log(initValue, dateRes, allSplittingInputs)
                }}
                truncateSeconds
                onChangeMinutes={(dateRes: any) => {
                    console.log(dateRes);
 
                    // close popup
                    if (popupRef.current) popupRef.current.close();
                }}
                onChangeToday={(dateRes: any) => {
                    // close popup
                    if (datePopupRef.current) datePopupRef.current.close();
                }}
            />
 
 
        </>
    );
}

Focus hours's input control when popup opens


Show Code
import React from "react";
import Date from 'funda-ui/Date';
 
// component styles
import 'funda-ui/Date/index.css';
 
export default () => {
 
    return (
        <>
 
            <Date
                name="name"
                value="16:36"
                type="time" 
                truncateSeconds
                onOpenPopup={(allSplittingInputs: any[]) => {
 
                    console.log(allSplittingInputs);
            
                    // focus hours input
                    if (allSplittingInputs[3] !== null) {
                        allSplittingInputs[3].select();
                    }
                }}
                onlyTime
            />
 
 
        </>
    );
}

The default value sets a click initialization time for the null value


 
Show Code
import React from "react";
import Date from 'funda-ui/Date';
 
// component styles
import 'funda-ui/Date/index.css';
 
export default () => {
 
    return (
        <>
 
            <Date
                name="name"
                value=""
                clickInitValue="2024-03-14 10:22:00"
                type="datetime-local"
            />
 
 
        </>
    );
}

Focus year's input control and set a default value when component rendered

Lets you callback the handle exposed as attribute contentRef.


 
Show Code
import React, {useRef} from "react";
import Date from 'funda-ui/Date';
 
// component styles
import 'funda-ui/Date/index.css';
 
export default () => {
 
    const inputRef = useRef<any>();
 
    return (
        <>
 
            <Date
                contentRef={inputRef}
                name="name"
                value=""
                type="datetime-local"
                onLoad={(initValue: string, dateRes: any, allSplittingInputs: any[]) => {
                    console.log(allSplittingInputs)
 
                    // focus hours input
                    if (allSplittingInputs[0] !== null) {
 
                        // Make sure it is not affected by other rendering
                        setTimeout(() => {
                            if (inputRef.current) inputRef.current.set('2024-04-18 21:54:09', () => { console.log('callback') });
                        }, 0);
 
                        setTimeout(() => {
                            allSplittingInputs[0].select();
                        }, 150);
 
                        setTimeout(() => {
                            if (inputRef.current) {
                                inputRef.current.clear();
                                inputRef.current.blur();
                            }
                        }, 5000);
                    }
                }}
            />
 
 
        </>
    );
}

Use the exposed method to assign and empty

Lets you callback the handle exposed as attribute contentRef.


Set Empty Value  |  Set Custom Value (first - 17:33:20)  |  Set Custom Value (second - 2024-09-03 22:10:01)
 
Show Code
import React, { useRef } from 'react';
import Date from 'funda-ui/Date';
 
// component styles
import 'funda-ui/Date/index.css';
 
 
 
export default () => {
 
    const popupRef = useRef<any>();
    const popupRef2 = useRef<any>();
    const contentRef = useRef<any>();
    const contentRef2 = useRef<any>();
    
    return (
 
        <>
 
            <a 
                href="#"
                onClick={(e: React.MouseEvent) => {
                    e.preventDefault();
                    if (contentRef.current) contentRef.current.clear();
                    if (contentRef2.current) contentRef2.current.clear();
                }}
            >Set Empty Value</a>
            &nbsp;&nbsp;|&nbsp;&nbsp;
            <a 
                href="#"
                onClick={(e: React.MouseEvent) => {
                    e.preventDefault();
                    if (contentRef.current) contentRef.current.set('17:33:20', () => { console.log('callback') });
                }}
            >Set Custom Value (first - 17:33:20)</a>
            &nbsp;&nbsp;|&nbsp;&nbsp;
            <a 
                href="#"
                onClick={(e: React.MouseEvent) => {
                    e.preventDefault();
                    if (contentRef2.current) contentRef2.current.set('2024-09-03 22:10:01', () => { console.log('callback') });
                }}
            >Set Custom Value (second - 2024-09-03 22:10:01)</a>
 
 
            <Date
                popupRef={popupRef}
                contentRef={contentRef}
                name="start_time"
                value=""
                type="time"
                onChangeSeconds={(dateRes: any) => {
                    // close popup
                    if (popupRef.current) popupRef.current.close();
                }}
                onOpenPopup={(allSplittingInputs: any[]) => {
 
                    // focus hours input
                    if (allSplittingInputs[3] !== null) {
                        allSplittingInputs[3].select();
                    }
                }}
                onlyTime
 
            />
 
 
            <Date
                popupRef={popupRef2}
                contentRef={contentRef2}
                name="end_time"
                value=""
                type="datetime-local"
                onChangeSeconds={(dateRes: any) => {
                    // close popup
                    if (popupRef2.current) popupRef2.current.close();
                }}
            />  
 
        </>
    )
}

API

Date

import Date from 'funda-ui/Date';
PropertyTypeDefaultDescriptionRequired
refReact.ForwardedRef-It is the return element of this component.-
contentRefReact.ForwardedRef-It exposes the following methods:
  1. contentRef.current.control()
  2. contentRef.current.clear(() => { console.log('callback') })
  3. contentRef.current.blur(() => { console.log('callback') })
  4. contentRef.current.set('2024-04-25 21:54:18', () => { console.log('callback') })
DO NOT USE it in the onChange and onChange*** of this component, otherwise it will cause infinite rendering
-
popupRefReact.ForwardedRef-It exposes the following methods when the component's popup opens or closes:
  1. popupRef.current.close()
-
depthnumber1055Set the depth value of the control to control the display of the pop-up layer appear above. Please set it when multiple controls are used at the same time.-
enableEntireAreaPopupbooleanfalseEnable the entire area popup. If it is false, you need to click the icon to pop up.-
delimiterstring/Specify a delimiter from a date string. such as /, -, , .-
hideClearButtonbooleanfalseHide the Clear button-
showToolsWhenHoverbooleanfalseThe tool icon is displayed when hovering over the mouse-
offsetnumber10Position offset of top and bottom.-
exceededSidePosOffsetnumber15Offset px that exceeds the far right or left side of the screen-
popupClassNamestring-The class name of the popup.-
triggerClassNamestring-The class name of the date trigger.-
wrapperClassNamestringmb-3 position-relativeThe class name of the control wrapper.-
controlClassNamestringform-controlThe class name of the control.-
controlGroupWrapperClassNamestringinput-groupThe class name of the control group wrapper.-
controlGroupTextClassNamestringinput-group-textThe class name of the control group text.-
localizationen_US | zh_CNen_USLocalization in the component of all. You could also use lang* to set the language individually.-
typedate | datetime-local | timedateThe type of date control.-
onlyTimebooleanfalseOnly the time is displayed, not the date. such as 2024-03-22 18:33:23 to 18:33:23.
It can be used in conjunction with truncateSeconds
-
truncateSecondsbooleanfalseTruncate the number of seconds of time. such as 18:33:23 to 18:33-
valueUseSlashbooleanfalseReplace the dash with a slash as the result. such as 2024-03-22 to 2024/03/22.-
customTodayDatestring-Specify a default today. such as 2023-11-16-
langHoursTitlestringHoursLocalization in the component of hours section title.-
langMinutesTitlestringMinutesLocalization in the component of minutes section title.-
langSecondsTitlestringSecondsLocalization in the component of seconds section title.-
langWeekarray['MON', 'TUE', 'WED', 'THU', 'FRI', 'SAT', 'SUN']Localization in the component of week sequence.
Support html tags.
such as ['<small>MON</small>', '<small>TUE</small>', '<small>WED</small>', '<small>THU</small>', '<small>FRI</small>', '<small>SAT</small>', '<small>SUN</small>']
-
langWeekFullarray['MONDAY', 'TUESDAY', 'WEDNESDAY', 'THURSDAY', 'FRIDAY', 'SATURDAY', 'SUNDAY']Localization in the component of full week sequence.
This attribute is not valid yet
-
langMonthsarray['JAN', 'FEB', 'MAR', 'APR', 'MAY', 'JUN', 'JUL', 'AUG', 'SEP', 'OCT', 'NOV', 'DEC']Localization in the component of months sequence.-
langMonthsFullarray['January', 'Febuary', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December']Localization in the component of full months sequence.-
langTodaystringTodayLocalization in the component of today button.-
defaultValuestring-Specifies the default value. Use when the component is not controlled. It does not re-render the component because the incoming value changes.-
valuestring-Set a default value for this control-
clickInitValuestring-If the default value does not exist, the time is automatically initialized when the input is focused, and if not set, the current time is defaulted.-
minstring-The minimum date & time to accept. such as 2024-02-26 08:05:00-
maxstring-The maximum date & time to accept. such as 2024-02-26 09:25:45-
placeholderstringyyyy/MM/dd HH:mm:ssSpecifies a short hint that describes.-
labelstring | ReactNode-It is used to specify a label for an element of a form.
Support html tags
-
requiredLabelstring | ReactNode<span className="position-absolute end-0 top-0 my-2 mx-2"><span className="text-danger">*</span></span>It is used to specify a label for an element required.-
unitsstring-Specify a unit identification string. Such as em, px, and so on.-
namestring-Name is not deprecated when used with form fields.-
readOnlybooleanfalseWhen present, it specifies that this component field is read-only.-
disabledbooleanfalseWhether it is disabled-
requiredbooleanfalseWhen present, it specifies that a field must be filled out before submitting the form.-
iconLeftReactNode-Set the left icon of this control-
iconRightReactNode-Set the right icon of this control-
onLoadfunction-Call a function when the value of an HTML element is changed. It returns three callback values.
  1. The first is the value at which the requirement was initialized (String)
  2. The second is the current date info (JSON Object)
  3. The last is the existing time-splitting inputs (Array)
-
onChangefunction-Call a function when the value of an HTML element is changed. It returns four callback values.
  1. The first is the control (HTML Element)
  2. The second is the current date info (JSON Object | String)
  3. The third is the boolean value that determine whether the date is valid (Boolean)
  4. The last is the existing time-splitting inputs (Array)
-
onBlurfunction-Call a function when a user leaves an form field. It returns two callback values.
  1. The first is the control (HTML Element)
  2. The last is the existing time-splitting inputs (Array)
Changes of year/month/day/hours/minutes/seconds/popup will trigger
-
onFocusfunction-Call a function when an form field gets focus. It returns two callback values.
  1. The first is the control (HTML Element)
  2. The last is the existing time-splitting inputs (Array)
-
onOpenPopupfunction-Call a function when open popup. It returns only one value which is the existing time-splitting inputs (Array)-
onClosePopupfunction-Call a function when close popup. It returns only one value which is the existing time-splitting inputs (Array)-
onChangeDatefunction-Call a function when a date area is clicked. The function receives the selected date (yyyy-MM-dd). Triggered when the date cell selection button is clicked. It returns only one value which is the current value (JSON Object)-
onChangeMonthfunction-Called when the date moves to a new month. The function receives the selected month (0-11). Triggered when the previous, next or month selection button is clicked. It returns only one value which is the current value (JSON Object)-
onChangeYearfunction-Called when the date moves to a new year. The function receives the selected year. Triggered when the year selection button is clicked. It returns only one value which is the current value (JSON Object)-
onChangeTodayfunction-Called when the date moves to today. Triggered when the today selection button is clicked. It returns only one value which is the current value (JSON Object)-
onChangeHoursfunction-Called when the date moves to hours. Triggered when the hours selection button is clicked. It returns only one value which is the current value (JSON Object)-
onChangeMinutesfunction-Called when the date moves to minutes. Triggered when the minutes selection button is clicked. It returns only one value which is the current value (JSON Object)-
onChangeSecondsfunction-Called when the date moves to seconds. Triggered when the seconds selection button is clicked. It returns only one value which is the current value (JSON Object)-
onPressEnterfunction-The callback function that is triggered when Enter key is pressed. It returns two callback values.
  1. The first is the control (HTML Element)
  2. The last is the existing time-splitting inputs (Array)
-
onClearfunction-Clicking the empty button is triggered. It returns only one callback value which is the current value (JSON Object)-