UNPKG

@alifd/next

Version:

A configurable component library for web built on React.

52 lines (43 loc) 1.52 kB
import { datejs } from '../util'; import { DATE_INPUT_TYPE } from './constant'; export function setTime(targetVal, sourceVal) { if (sourceVal && targetVal) { return targetVal.hour(sourceVal.hour()).minute(sourceVal.minute()).second(sourceVal.second()).millisecond(sourceVal.millisecond()); } return targetVal; } export function switchInputType(inputType) { var BEGIN = DATE_INPUT_TYPE.BEGIN, END = DATE_INPUT_TYPE.END; return inputType === BEGIN ? END : BEGIN; } export function mode2unit(mode) { return mode === 'date' ? 'day' : mode; } /** * 获取输入框值 * @param {*} value 日期值 * @param {string | funtion} format 日期格式 * @returns {string | string[]} */ export function fmtValue(value, fmt) { var formater = function formater(v, idx) { var _fmt = fmt; if (Array.isArray(fmt)) { _fmt = fmt[idx]; } return v ? typeof _fmt === 'function' ? _fmt(v) : v.format(_fmt) : ''; }; return Array.isArray(value) ? value.map(function (v, idx) { return formater(v, idx); }) : formater(value); } /** * 判断值是否改变 * @param {dayjs.ConfigType}} newValue * @param {dayjs.ConfigType} oldValue * @returns {boolean} */ export function isValueChanged(newValue, oldValue) { return Array.isArray(newValue) ? isValueChanged(newValue[0], oldValue && oldValue[0]) || isValueChanged(newValue[1], oldValue && oldValue[1]) : newValue !== oldValue && !datejs(newValue).isSame(oldValue); }