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>
96 lines (86 loc) • 11.3 kB
JavaScript
import * as React from "react";
import PropTypes from "prop-types";
import "./style";
import Icon from "../icon";
import { getDefaultMaxDate, getDefaultMinDate } from "./core";
var prefix = "adui-date";
var Caption = function Caption(_ref) {
var date = _ref.date,
maxDate = _ref.maxDate,
minDate = _ref.minDate,
onDateChange = _ref.onDateChange;
var handleYearChange = function handleYearChange(e) {
var newYear = parseInt(e.currentTarget.value, 10);
var newDate = new Date(date.getTime());
newDate.setFullYear(newYear);
onDateChange(newDate, e);
};
var handleMonthChange = function handleMonthChange(e) {
var newMonth = parseInt(e.currentTarget.value, 10);
var newDate = new Date(date.getTime());
newDate.setMonth(newMonth);
onDateChange(newDate, e);
};
var minYear = minDate.getFullYear();
var maxYear = maxDate.getFullYear();
var years = [maxYear];
for (var year = maxYear - 1; year >= minYear; year -= 1) {
years.push(year);
}
var displayMonth = date.getMonth();
var displayYear = date.getFullYear();
var startMonth = displayYear === minYear ? minDate.getMonth() : 0;
var endMonth = displayYear === maxYear ? maxDate.getMonth() + 1 : 12;
var months = [startMonth];
for (var month = startMonth + 1; month < endMonth; month += 1) {
months.push(month);
}
if (!months.includes(displayMonth)) {
months.unshift(displayMonth);
}
return React.createElement("div", {
className: "".concat(prefix, "-caption")
}, React.createElement("div", {
className: "".concat(prefix, "-selects")
}, React.createElement("div", {
className: "".concat(prefix, "-selectYear")
}, React.createElement("select", {
name: "year",
onChange: handleYearChange,
value: displayYear
}, years.map(function (year) {
return React.createElement("option", {
key: year,
value: year
}, year, "\u5E74");
})), React.createElement(Icon, {
icon: "triangle-down"
})), React.createElement("div", {
className: "".concat(prefix, "-selectMonth")
}, React.createElement("select", {
name: "month",
onChange: handleMonthChange,
value: displayMonth,
"data-value": displayMonth
}, months.map(function (month) {
return React.createElement("option", {
key: month,
value: month
}, month + 1, "\u6708");
})), React.createElement(Icon, {
icon: "triangle-down"
}))));
};
Caption.propTypes = {
date: PropTypes.any,
maxDate: PropTypes.any,
minDate: PropTypes.any,
onDateChange: PropTypes.func.isRequired
};
Caption.defaultProps = {
date: new Date(),
maxDate: getDefaultMaxDate(),
minDate: getDefaultMinDate()
};
export default Caption;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","PropTypes","Icon","getDefaultMaxDate","getDefaultMinDate","prefix","Caption","date","maxDate","minDate","onDateChange","handleYearChange","e","newYear","parseInt","currentTarget","value","newDate","Date","getTime","setFullYear","handleMonthChange","newMonth","setMonth","minYear","getFullYear","maxYear","years","year","push","displayMonth","getMonth","displayYear","startMonth","endMonth","months","month","includes","unshift","map","propTypes","any","func","isRequired","defaultProps"],"sources":["../../components/date-picker/Caption.tsx"],"sourcesContent":["import * as React from \"react\"\nimport PropTypes from \"prop-types\"\nimport \"./style\"\nimport Icon from \"../icon\"\nimport { getDefaultMaxDate, getDefaultMinDate } from \"./core\"\n\nconst prefix = \"adui-date\"\n\nexport interface ICaptionProps {\n  [key: string]: any\n  date: Date\n  maxDate: Date\n  minDate: Date\n  onDateChange: (date: Date, e: React.FormEvent<HTMLSelectElement>) => void\n}\n\n/**\n * 日期选择 Caption\n */\nconst Caption: React.FC<ICaptionProps> = ({\n  date,\n  maxDate,\n  minDate,\n  onDateChange,\n}: ICaptionProps) => {\n  const handleYearChange = (e: React.FormEvent<HTMLSelectElement>) => {\n    const newYear = parseInt(e.currentTarget.value, 10)\n    const newDate = new Date(date.getTime())\n    newDate.setFullYear(newYear)\n    onDateChange(newDate, e)\n  }\n\n  const handleMonthChange = (e: React.FormEvent<HTMLSelectElement>) => {\n    const newMonth = parseInt(e.currentTarget.value, 10)\n    const newDate = new Date(date.getTime())\n    newDate.setMonth(newMonth)\n    onDateChange(newDate, e)\n  }\n\n  const minYear = minDate.getFullYear()\n  const maxYear = maxDate.getFullYear()\n  const years = [maxYear]\n  for (let year = maxYear - 1; year >= minYear; year -= 1) {\n    years.push(year)\n  }\n\n  const displayMonth = date.getMonth()\n  const displayYear = date.getFullYear()\n\n  const startMonth = displayYear === minYear ? minDate.getMonth() : 0\n  const endMonth = displayYear === maxYear ? maxDate.getMonth() + 1 : 12\n  const months = [startMonth]\n  for (let month = startMonth + 1; month < endMonth; month += 1) {\n    months.push(month)\n  }\n\n  if (!months.includes(displayMonth)) {\n    months.unshift(displayMonth)\n  }\n\n  return (\n    <div className={`${prefix}-caption`}>\n      <div className={`${prefix}-selects`}>\n        <div className={`${prefix}-selectYear`}>\n          <select name=\"year\" onChange={handleYearChange} value={displayYear}>\n            {years.map((year) => (\n              <option key={year} value={year}>\n                {year}年\n              </option>\n            ))}\n          </select>\n          <Icon icon=\"triangle-down\" />\n        </div>\n        <div className={`${prefix}-selectMonth`}>\n          <select\n            name=\"month\"\n            onChange={handleMonthChange}\n            value={displayMonth}\n            data-value={displayMonth}\n          >\n            {months.map((month) => (\n              <option key={month} value={month}>\n                {month + 1}月\n              </option>\n            ))}\n          </select>\n          <Icon icon=\"triangle-down\" />\n        </div>\n      </div>\n    </div>\n  )\n}\n\nCaption.propTypes = {\n  /**\n   * 日期\n   */\n  date: PropTypes.any,\n  /**\n   * 最大限制日期\n   */\n  maxDate: PropTypes.any,\n  /**\n   * 最小限制日期\n   */\n  minDate: PropTypes.any,\n  /**\n   * handler\n   */\n  onDateChange: PropTypes.func.isRequired,\n}\n\nCaption.defaultProps = {\n  date: new Date(),\n  maxDate: getDefaultMaxDate(),\n  minDate: getDefaultMinDate(),\n}\n\nexport default Caption\n"],"mappings":"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"}