UNPKG

react-aria

Version:
57 lines (50 loc) 2.61 kB
var $b8ffb0adc97ab95f$exports = require("../i18n/useDateFormatter.cjs"); var $d9mcG$react = require("react"); function $parcel$export(e, n, v, s) { Object.defineProperty(e, n, {get: v, set: s, enumerable: true, configurable: true}); } $parcel$export(module.exports, "useCalendarHeading", function () { return $d04662acd67ee4cd$export$72ad8e10aa105341; }); /* * Copyright 2026 Adobe. All rights reserved. * This file is licensed to you under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. You may obtain a copy * of the License at http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software distributed under * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS * OF ANY KIND, either express or implied. See the License for the specific language * governing permissions and limitations under the License. */ function $d04662acd67ee4cd$export$72ad8e10aa105341(props, state) { let startDate = (0, $d9mcG$react.useMemo)(()=>{ let currentMonth = state.visibleRange.start; if (props.offset) currentMonth = currentMonth.add(props.offset); return currentMonth; }, [ state.visibleRange.start, props.offset ]); let isDays = state.visibleDuration.days || state.visibleDuration.weeks; let formatter = (0, $b8ffb0adc97ab95f$exports.useDateFormatter)({ day: props.format?.day || (isDays ? 'numeric' : undefined), month: props.format?.month || 'long', year: props.format?.year || 'numeric', era: props.format?.era || startDate && startDate.calendar.identifier === 'gregory' && startDate.era === 'BC' ? 'short' : undefined, calendar: state.visibleRange?.start.calendar.identifier, timeZone: state.timeZone }); return (0, $d9mcG$react.useMemo)(()=>{ if (isDays) return formatter.formatRange(startDate.toDate(state.timeZone), state.visibleRange.end.toDate(state.timeZone)); // Custom calendars like the 4-5-4 fiscal calendar use getFormattableMonth to map // their internal month back to the Gregorian month that should be displayed. let displayDate = startDate.calendar.getFormattableMonth ? startDate.calendar.getFormattableMonth(startDate) : startDate; return formatter.format(displayDate.toDate(state.timeZone)); }, [ formatter, isDays, startDate, state.timeZone, state.visibleRange.end ]); } //# sourceMappingURL=useCalendarHeading.cjs.map