chowa
Version:
UI component library based on React
36 lines (35 loc) • 1.77 kB
JavaScript
/**
* @license chowa v1.1.3
*
* Copyright (c) Chowa Techonlogies Co.,Ltd.(http://www.chowa.cn).
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
;
Object.defineProperty(exports, "__esModule", { value: true });
const React = require("react");
const classnames_1 = require("classnames");
const moment = require("moment");
const utils_1 = require("../../utils");
const tool_1 = require("../tool");
const calendar_mode_1 = require("../calendar-mode");
const MinYear = (props) => {
const { values, each, display, disabledDate, rangeDate, onSelect, defaultMode } = props;
const activeValues = defaultMode === calendar_mode_1.YEAR_MODE ? values : [display];
const nodes = [];
for (let i = each.year() - 6; i <= each.year() + 5; i++) {
const year = moment([i]).startOf('month');
const disabled = tool_1.isDisabledDate(year, disabledDate);
const yearClass = classnames_1.default({
[utils_1.preClass('min-calendar-year')]: true,
[utils_1.preClass('min-calendar-selected')]: tool_1.hasActiveMoment(year, activeValues, 'year'),
[utils_1.preClass('min-calendar-inrange')]: tool_1.isRangeDate(year, rangeDate, 'year'),
[utils_1.preClass('min-calendar-disabled')]: disabled
});
nodes.push(React.createElement("li", { key: i, onClick: (disabled || !utils_1.isExist(onSelect)) ? null : onSelect.bind(this, year), className: yearClass }, i));
}
return (React.createElement("div", { className: utils_1.preClass('min-calendar-year-wrapper') },
React.createElement("ul", { className: utils_1.preClass('min-calendar-year-container') }, nodes)));
};
exports.default = MinYear;