adui
Version:
<div> <img src="https://wxa.wxs.qq.com/mpweb/delivery/legacy/wxadtouch/upload/t1/od834zef_52939fc6.png" style="margin:40px 0 0 -8px; background-color: #fcfcfc; box-shadow: none;" /> </div>
223 lines (186 loc) • 29 kB
JavaScript
var _excluded = ["currentHour", "currentMinute", "disabledHours", "disabledMinutes", "disabledSeconds", "maxTime", "minTime", "onChange", "onlyHour", "size", "selectedValue", "type"];
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
import React, { forwardRef, useContext, useImperativeHandle, useRef, useEffect, memo } from "react";
import PropTypes from "prop-types";
import classNames from "classnames";
import { getRequestAnimationFrame } from "../_util/raf";
import "./style";
import { extractHMSFromTime, hours, minutes, seconds } from "./core";
import { ConfigContext, getComputedSize } from "../config-provider";
var prefix = "adui-time";
var noop = function noop() {};
var scrollTo = function scrollTo(element, to, duration) {
var reqAnimFrame = getRequestAnimationFrame();
if (duration <= 0) {
element.scrollTop = to;
return;
}
var difference = to - element.scrollTop;
var perTick = difference / duration * 10;
reqAnimFrame(function () {
element.scrollTop += perTick;
if (element.scrollTop === to) {
return;
}
scrollTo(element, to, duration - 10);
});
};
var TimeSelect = forwardRef(function (_ref, ref) {
var currentHour = _ref.currentHour,
currentMinute = _ref.currentMinute,
disabledHours = _ref.disabledHours,
disabledMinutes = _ref.disabledMinutes,
disabledSeconds = _ref.disabledSeconds,
maxTime = _ref.maxTime,
minTime = _ref.minTime,
onChange = _ref.onChange,
onlyHour = _ref.onlyHour,
size = _ref.size,
selectedValue = _ref.selectedValue,
type = _ref.type,
otherProps = _objectWithoutProperties(_ref, _excluded);
var selectRef = useRef(null);
useImperativeHandle(ref, function () {
return {
select: selectRef
};
});
var handleClick = function handleClick(item) {
onChange(item, type);
};
var _useContext = useContext(ConfigContext),
sizeContext = _useContext.size;
var isDisabled = function isDisabled(value, minHour, minMinute, minSecond, maxHour, maxMinute, maxSecond, isOnlyHour) {
if (type === "hour") {
return value < minHour || value > (isOnlyHour && !maxTime ? "24:00" : maxHour);
}
if (type === "minute") {
if (minHour === maxHour) {
return value < minMinute || value > maxMinute;
}
if (minHour === currentHour) {
return value < minMinute;
}
if (maxHour === currentHour) {
return value > maxMinute;
}
}
if (type === "second") {
if (minHour === maxHour) {
if (minMinute === maxMinute) {
return value < minSecond || value > maxSecond;
}
if (minMinute === currentMinute) {
return value < minSecond;
}
if (maxMinute === currentMinute) {
return value > maxSecond;
}
}
if (minHour === currentHour) {
if (minMinute === currentMinute) {
return value < minSecond;
}
}
if (maxHour === currentHour) {
if (maxMinute === currentMinute) {
return value > maxSecond;
}
}
}
return false;
};
var updateScrollTop = function updateScrollTop(duration) {
if (selectRef !== null && selectRef !== void 0 && selectRef.current) {
var activeItem = selectRef.current.getElementsByClassName("".concat(prefix, "-active"))[0];
if (activeItem) {
var offsetTop = activeItem.offsetTop;
if (offsetTop !== undefined) {
if (duration) {
scrollTo(selectRef.current, offsetTop, duration);
} else {
selectRef.current.scrollTop = offsetTop;
}
}
}
}
};
useEffect(function () {
updateScrollTop(0);
}, []);
useEffect(function () {
updateScrollTop(120);
}, [selectedValue]);
var classSet = classNames("".concat(prefix, "-timeSelect"), "".concat(prefix, "-").concat(getComputedSize(size, sizeContext)), _defineProperty({}, "".concat(prefix, "-integerTimeSelect"), onlyHour));
var _extractHMSFromTime = extractHMSFromTime(minTime),
minHour = _extractHMSFromTime.hour,
minMinute = _extractHMSFromTime.minute,
minSecond = _extractHMSFromTime.second;
var _extractHMSFromTime2 = extractHMSFromTime(maxTime),
maxHour = _extractHMSFromTime2.hour,
maxMinute = _extractHMSFromTime2.minute,
maxSecond = _extractHMSFromTime2.second;
var items = [];
if (type === "second") {
items = seconds;
} else if (type === "minute") {
items = minutes;
} else {
items = hours;
}
return React.createElement("div", _extends({
className: classSet,
ref: selectRef
}, otherProps), items.map(function (value) {
var _classNames2;
var disabled = isDisabled(parseInt(value, 10), parseInt(minHour || "00", 10), parseInt(minMinute || "00", 10), parseInt(minSecond || "00", 10), parseInt(maxHour || "24", 10), parseInt(maxMinute || "59", 10), parseInt(maxSecond || "59", 10), onlyHour);
if ((disabled || disabledHours && disabledHours(value)) && type === "hour" || disabledMinutes && disabledMinutes(value) && type === "minute" || disabledSeconds && disabledSeconds(value) && type === "second") {
return null;
}
var itemClassSet = classNames("".concat(prefix, "-item"), (_classNames2 = {}, _defineProperty(_classNames2, "".concat(prefix, "-active"), selectedValue === value), _defineProperty(_classNames2, "".concat(prefix, "-disabled"), disabled), _classNames2));
return React.createElement("div", {
role: "none",
className: itemClassSet,
key: value,
onClick: function onClick() {
if (!disabled) {
handleClick(value);
}
}
}, onlyHour ? "".concat(value, ":00") : value);
}));
});
TimeSelect.displayName = "TimeSelect";
TimeSelect.propTypes = {
currentHour: PropTypes.number,
currentMinute: PropTypes.number,
disabledHours: PropTypes.func,
disabledMinutes: PropTypes.func,
disabledSeconds: PropTypes.func,
maxTime: PropTypes.string,
minTime: PropTypes.string,
onChange: PropTypes.any,
onlyHour: PropTypes.bool,
selectedValue: PropTypes.string,
size: PropTypes.oneOf(["mini", "small", "medium", "large"]),
type: PropTypes.any
};
TimeSelect.defaultProps = {
currentHour: null,
currentMinute: null,
disabledHours: noop,
disabledMinutes: noop,
disabledSeconds: noop,
maxTime: "24:00",
minTime: "00:00",
onChange: noop,
onlyHour: false,
selectedValue: null,
size: "small",
type: "hour"
};
export default memo(TimeSelect);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","forwardRef","useContext","useImperativeHandle","useRef","useEffect","memo","PropTypes","classNames","getRequestAnimationFrame","extractHMSFromTime","hours","minutes","seconds","ConfigContext","getComputedSize","prefix","noop","scrollTo","element","to","duration","reqAnimFrame","scrollTop","difference","perTick","TimeSelect","ref","currentHour","currentMinute","disabledHours","disabledMinutes","disabledSeconds","maxTime","minTime","onChange","onlyHour","size","selectedValue","type","otherProps","selectRef","select","handleClick","item","sizeContext","isDisabled","value","minHour","minMinute","minSecond","maxHour","maxMinute","maxSecond","isOnlyHour","updateScrollTop","current","activeItem","getElementsByClassName","offsetTop","undefined","classSet","hour","minute","second","items","map","disabled","parseInt","itemClassSet","displayName","propTypes","number","func","string","any","bool","oneOf","defaultProps"],"sources":["../../components/time-picker/TimeSelect.tsx"],"sourcesContent":["import React, {\n  forwardRef,\n  useContext,\n  useImperativeHandle,\n  useRef,\n  useEffect,\n  memo,\n} from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport { getRequestAnimationFrame } from \"../_util/raf\"\nimport \"./style\"\nimport { extractHMSFromTime, hours, minutes, seconds } from \"./core\"\nimport { ConfigContext, getComputedSize } from \"../config-provider\"\n\nconst prefix = \"adui-time\"\nconst noop = () => {}\n\nexport interface ITimeSelectProps {\n  [key: string]: any\n  currentHour?: number | null\n  currentMinute?: number | null\n  disabledHours?: (hour?: string | null) => boolean | void\n  disabledMinutes?: (minute?: string | null) => boolean | void\n  disabledSeconds?: (second?: string | null) => boolean | void\n  maxTime?: string | null\n  minTime?: string | null\n  onChange: (value: string, type: \"hour\" | \"minute\" | \"second\") => void\n  onlyHour?: boolean\n  size?: \"mini\" | \"small\" | \"medium\" | \"large\"\n  selectedValue?: null | string\n  type: \"hour\" | \"minute\" | \"second\"\n}\n\nconst scrollTo = (element: HTMLDivElement, to: number, duration: number) => {\n  const reqAnimFrame = getRequestAnimationFrame()\n\n  if (duration <= 0) {\n    element.scrollTop = to\n    return\n  }\n  const difference = to - element.scrollTop\n  const perTick = (difference / duration) * 10\n\n  reqAnimFrame(() => {\n    element.scrollTop += perTick\n    if (element.scrollTop === to) {\n      return\n    }\n    scrollTo(element, to, duration - 10)\n  })\n}\n\nconst TimeSelect: React.ForwardRefExoticComponent<\n  ITimeSelectProps & React.RefAttributes<any>\n> = forwardRef(\n  (\n    {\n      currentHour,\n      currentMinute,\n      disabledHours,\n      disabledMinutes,\n      disabledSeconds,\n      maxTime,\n      minTime,\n      onChange,\n      onlyHour,\n      size,\n      selectedValue,\n      type,\n      ...otherProps\n    }: ITimeSelectProps,\n    ref\n  ) => {\n    const selectRef = useRef<any>(null)\n    useImperativeHandle(ref, () => ({\n      select: selectRef,\n    }))\n\n    const handleClick = (item: string) => {\n      onChange(item, type)\n    }\n\n    const { size: sizeContext } = useContext(ConfigContext)\n\n    const isDisabled = (\n      value: number,\n      minHour: number,\n      minMinute: number,\n      minSecond: number,\n      maxHour: number,\n      maxMinute: number,\n      maxSecond: number,\n      isOnlyHour?: boolean\n    ) => {\n      if (type === \"hour\") {\n        // 这里要注意把整点选择 24:00 的情况特殊处理\n        return (\n          value < minHour ||\n          value > (isOnlyHour && !maxTime ? \"24:00\" : maxHour)\n        )\n      }\n      if (type === \"minute\") {\n        // 在同一个小时内\n        if (minHour === maxHour) {\n          return value < minMinute || value > maxMinute\n        }\n        // 在最小的小时内时，这时候要把 minMinute 以下的 disabled\n        if (minHour === currentHour) {\n          return value < minMinute\n        }\n        // 在最大的小时内时，这时候要把 maxMinute 以上的 disabled\n        if (maxHour === currentHour) {\n          return value > maxMinute\n        }\n      }\n      if (type === \"second\") {\n        // 在同一个小时内\n        if (minHour === maxHour) {\n          // 在同一个分钟内\n          if (minMinute === maxMinute) {\n            return value < minSecond || value > maxSecond\n          }\n          // 在最小的分钟内时，这时候要把 minSecond 以下的 disabled\n          if (minMinute === currentMinute) {\n            return value < minSecond\n          }\n          // 在最大的分钟内时，这时候要把 maxSecond 以上的 disabled\n          if (maxMinute === currentMinute) {\n            return value > maxSecond\n          }\n        }\n        // 在最小的小时内时，这时候要把 minMinute 以下的 disabled\n        if (minHour === currentHour) {\n          // 在最小的小时内时，这时候要把 minMinute 以下的 disabled\n          if (minMinute === currentMinute) {\n            return value < minSecond\n          }\n        }\n        // 在最大的小时内时，这时候要把 maxMinute 以上的 disabled\n        if (maxHour === currentHour) {\n          // 在最大的小时内时，这时候要把 maxMinute 以上的 disabled\n          if (maxMinute === currentMinute) {\n            return value > maxSecond\n          }\n        }\n      }\n\n      return false\n    }\n\n    const updateScrollTop = (duration: number) => {\n      if (selectRef?.current) {\n        const activeItem: Partial<HTMLDivElement> =\n          selectRef.current.getElementsByClassName(`${prefix}-active`)[0]\n        if (activeItem) {\n          const { offsetTop } = activeItem\n          if (offsetTop !== undefined) {\n            if (duration) {\n              scrollTo(selectRef.current, offsetTop, duration)\n            } else {\n              selectRef.current.scrollTop = offsetTop\n            }\n          }\n        }\n      }\n    }\n\n    useEffect(() => {\n      updateScrollTop(0)\n    }, [])\n\n    useEffect(() => {\n      updateScrollTop(120)\n    }, [selectedValue])\n\n    const classSet = classNames(\n      `${prefix}-timeSelect`,\n      `${prefix}-${getComputedSize(size, sizeContext)}`,\n      {\n        [`${prefix}-integerTimeSelect`]: onlyHour,\n      }\n    )\n\n    const {\n      hour: minHour,\n      minute: minMinute,\n      second: minSecond,\n    } = extractHMSFromTime(minTime)\n    const {\n      hour: maxHour,\n      minute: maxMinute,\n      second: maxSecond,\n    } = extractHMSFromTime(maxTime)\n\n    let items: string[] = []\n    if (type === \"second\") {\n      items = seconds\n    } else if (type === \"minute\") {\n      items = minutes\n    } else {\n      items = hours\n    }\n\n    return (\n      <div className={classSet} ref={selectRef} {...otherProps}>\n        {items.map((value) => {\n          const disabled = isDisabled(\n            parseInt(value, 10),\n            parseInt(minHour || \"00\", 10),\n            parseInt(minMinute || \"00\", 10),\n            parseInt(minSecond || \"00\", 10),\n            parseInt(maxHour || \"24\", 10),\n            parseInt(maxMinute || \"59\", 10),\n            parseInt(maxSecond || \"59\", 10),\n            onlyHour\n          )\n\n          if (\n            ((disabled || (disabledHours && disabledHours(value))) &&\n              type === \"hour\") ||\n            (disabledMinutes && disabledMinutes(value) && type === \"minute\") ||\n            (disabledSeconds && disabledSeconds(value) && type === \"second\")\n          ) {\n            // 小时的 disabled 直接不显示，而不是做 disabled 处理\n            // 分钟的 disabled 显示，如果传入了 disabledMinutes 则不显示\n            return null\n          }\n\n          const itemClassSet = classNames(`${prefix}-item`, {\n            [`${prefix}-active`]: selectedValue === value,\n            [`${prefix}-disabled`]: disabled,\n          })\n          return (\n            <div\n              role=\"none\"\n              className={itemClassSet}\n              key={value}\n              onClick={() => {\n                if (!disabled) {\n                  handleClick(value)\n                }\n              }}\n            >\n              {onlyHour ? `${value}:00` : value}\n            </div>\n          )\n        })}\n      </div>\n    )\n  }\n)\n\nTimeSelect.displayName = \"TimeSelect\"\n\nTimeSelect.propTypes = {\n  /**\n   * 当前小时值\n   */\n  currentHour: PropTypes.number,\n  /**\n   * 当前分钟值\n   */\n  currentMinute: PropTypes.number,\n  /**\n   * 不可选的小时\n   */\n  disabledHours: PropTypes.func,\n  /**\n   * 不可选的分钟\n   */\n  disabledMinutes: PropTypes.func,\n  /**\n   * 不可选的秒\n   */\n  disabledSeconds: PropTypes.func,\n  /**\n   * 可选时间段的最大值\n   */\n  maxTime: PropTypes.string,\n  /**\n   * 可选时间段的最小值\n   */\n  minTime: PropTypes.string,\n  /**\n   * 改变选择的值\n   */\n  onChange: PropTypes.any,\n  /**\n   * 判断是否是整点\n   */\n  onlyHour: PropTypes.bool,\n  /**\n   * 已经选择的值\n   */\n  selectedValue: PropTypes.string,\n  /**\n   * 设置尺寸\n   */\n  size: PropTypes.oneOf([\"mini\", \"small\", \"medium\", \"large\"]),\n  /**\n   * 判断选择框的类型\n   */\n  type: PropTypes.any,\n}\n\nTimeSelect.defaultProps = {\n  currentHour: null,\n  currentMinute: null,\n  disabledHours: noop,\n  disabledMinutes: noop,\n  disabledSeconds: noop,\n  maxTime: \"24:00\",\n  minTime: \"00:00\",\n  onChange: noop,\n  onlyHour: false,\n  selectedValue: null,\n  size: \"small\",\n  type: \"hour\",\n}\n\nexport default memo(TimeSelect)\n"],"mappings":"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"}