@material-ui/pickers
Version:
React components, that implements material design pickers for material-ui v4
59 lines (58 loc) • 2.92 kB
JavaScript
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
result["default"] = mod;
return result;
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
var React = __importStar(require("react"));
var Year_1 = __importDefault(require("./Year"));
var styles_1 = require("@material-ui/core/styles");
var useUtils_1 = require("../../_shared/hooks/useUtils");
var Wrapper_1 = require("../../wrappers/Wrapper");
exports.useStyles = styles_1.makeStyles({
container: {
height: 300,
overflowY: 'auto',
},
}, { name: 'MuiPickersYearSelection' });
exports.YearSelection = function (_a) {
var date = _a.date, onChange = _a.onChange, onYearChange = _a.onYearChange, minDate = _a.minDate, maxDate = _a.maxDate, disablePast = _a.disablePast, disableFuture = _a.disableFuture, animateYearScrolling = _a.animateYearScrolling;
var utils = useUtils_1.useUtils();
var classes = exports.useStyles();
var currentVariant = React.useContext(Wrapper_1.VariantContext);
var selectedYearRef = React.useRef(null);
React.useEffect(function () {
if (selectedYearRef.current && selectedYearRef.current.scrollIntoView) {
try {
selectedYearRef.current.scrollIntoView({
block: currentVariant === 'static' ? 'nearest' : 'center',
behavior: animateYearScrolling ? 'smooth' : 'auto',
});
}
catch (e) {
// call without arguments in case when scrollIntoView works improperly (e.g. Firefox 52-57)
selectedYearRef.current.scrollIntoView();
}
}
}, []); // eslint-disable-line
var currentYear = utils.getYear(date);
var onYearSelect = React.useCallback(function (year) {
var newDate = utils.setYear(date, year);
if (onYearChange) {
onYearChange(newDate);
}
onChange(newDate, true);
}, [date, onChange, onYearChange, utils]);
return (React.createElement("div", { className: classes.container }, utils.getYearRange(minDate, maxDate).map(function (year) {
var yearNumber = utils.getYear(year);
var selected = yearNumber === currentYear;
return (React.createElement(Year_1.default, { key: utils.getYearText(year), selected: selected, value: yearNumber, onSelect: onYearSelect, ref: selected ? selectedYearRef : undefined, disabled: Boolean((disablePast && utils.isBeforeYear(year, utils.date())) ||
(disableFuture && utils.isAfterYear(year, utils.date()))) }, utils.getYearText(year)));
})));
};
;