daterange-picker-reactjs
Version:
A beautiful and customizable single date and date-range picker component for React.js applications
3 lines (2 loc) • 22 kB
JavaScript
"use strict";var t=require("react/jsx-runtime"),e=require("react");!function(t,e){void 0===e&&(e={});var n=e.insertAt;if("undefined"!=typeof document){var r=document.head||document.getElementsByTagName("head")[0],o=document.createElement("style");o.type="text/css","top"===n&&r.firstChild?r.insertBefore(o,r.firstChild):r.appendChild(o),o.styleSheet?o.styleSheet.cssText=t:o.appendChild(document.createTextNode(t))}}('*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4}body{line-height:inherit;margin:0}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{color:#9ca3af;opacity:1}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.invisible{visibility:hidden}.absolute{position:absolute}.relative{position:relative}.left-0{left:0}.top-10{top:2.5rem}.my-2{margin-top:.5rem}.mb-2,.my-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.block{display:block}.flex{display:flex}.grid{display:grid}.h-72{height:18rem}.max-h-64{max-height:16rem}.w-20{width:5rem}.w-24{width:6rem}.w-40{width:10rem}.w-80{width:20rem}.w-fit{width:-moz-fit-content;width:fit-content}.w-full{width:100%}.rotate-180{--tw-rotate:180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-y-2{row-gap:.5rem}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-l-full{border-bottom-left-radius:9999px;border-top-left-radius:9999px}.rounded-r-full{border-bottom-right-radius:9999px;border-top-right-radius:9999px}.border{border-width:1px}.bg-blue-200{--tw-bg-opacity:1;background-color:rgb(191 219 254/var(--tw-bg-opacity,1))}.bg-blue-500{--tw-bg-opacity:1;background-color:rgb(59 130 246/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.p-2{padding:.5rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-2\\.5{padding-bottom:.625rem;padding-top:.625rem}.py-4{padding-bottom:1rem;padding-top:1rem}.text-center{text-align:center}.text-sm{font-size:.875rem;line-height:1.25rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.text-black{--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity,1))}.text-black\\/55{color:rgba(0,0,0,.55)}.text-black\\/70{color:rgba(0,0,0,.7)}.text-blue-800{--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-opacity-25{--tw-text-opacity:0.25}.text-opacity-55{--tw-text-opacity:0.55}.shadow-md{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-md,.shadow-xl{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color)}.outline{outline-style:solid}.outline-blue-500{outline-color:#3b82f6}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}@keyframes fadeInSlideIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOutSlideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(30px)}}.hover\\:bg-blue-100:hover{--tw-bg-opacity:1;background-color:rgb(219 234 254/var(--tw-bg-opacity,1))}.hover\\:bg-gray-100:hover{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.hover\\:bg-slate-100:hover{--tw-bg-opacity:1;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.hover\\:bg-transparent:hover{background-color:transparent}.disabled\\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\\:text-opacity-40:disabled{--tw-text-opacity:0.4}.disabled\\:hover\\:bg-transparent:hover:disabled{background-color:transparent}',{insertAt:"top"});var n=["January","February","March","April","May","June","July","August","September","October","November","December"];function r(){return t.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 100 200",width:"8",height:"40",className:"",children:t.jsx("rect",{x:"50",y:"-180",width:"16",height:"580",fill:"rgb(0 0 0 / 0.35)"})})}function o(o){var a=o.monthsRange,i=o.handleMonthChange,s=o.currentDate,l=o.setCurrentDate,c=o.showYearMonthDivider,d=e.useState(!1),u=d[0],h=d[1],p=e.useState(String(s.getFullYear())),g=p[0],w=p[1],b=e.useRef(null),f=e.useRef(null);return function(t,n,r){var o=e.useCallback((function(t){n&&(null==n?void 0:n.current)&&!(null==n?void 0:n.current.contains(t.target))&&r(!1)}),[n,r]);e.useEffect((function(){if(t)return document.addEventListener("click",o),function(){document.removeEventListener("click",o)}}),[t,o])}(u,b,h),t.jsxs("div",{className:"flex gap-2 items-center",children:[t.jsxs("div",{className:"block relative",children:[t.jsx("input",{ref:b,type:"text",value:a,className:"text-center w-24 text-sm border rounded bg-white py-2 cursor-pointer",readOnly:!0,onClick:function(){h(!0)}}),u&&t.jsx("div",{style:{animation:u?"fadeInSlideIn 0.2s ease-out":"fadeOutSlideOut 0.2s ease-out"},ref:f,className:"dropdown max-h-64 my-2 transition-all duration-200 ease-in-out absolute top-10 left-0 bg-white h-72 overflow-y-auto flex flex-col w-full shadow-xl",children:n.map((function(e,n){return t.jsx("button",{className:"py-2 text-sm text-gray-700 hover:bg-slate-100 duration-200 ease-in-out transition-colors",onClick:function(){return i(n)},children:e},e)}))})]}),c&&t.jsx("span",{"data-testid":"yearMonthDivider",children:t.jsx(r,{})}),t.jsx("input",{type:"number",value:g,onChange:function(t){var e=t.target.value;/^\d{0,4}$/.test(e)&&(w(e),4===e.length&&l((function(t){return new Date(Number(e),t.getMonth(),1)})))},className:"w-20 p-2 text-sm border rounded bg-white text-center",placeholder:"Year"})]})}function a(){return t.jsx("svg",{width:"9",height:"18",viewBox:"0 0 9 18",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:t.jsx("path",{d:"M8.0975 16.84L1.5775 10.32C0.8075 9.55 0.8075 8.29 1.5775 7.52L8.0975 1",stroke:"#292D32",strokeWidth:"1.5",strokeMiterlimit:"10",strokeLinecap:"round",strokeLinejoin:"round"})})}function i(e){var n=e.onClick,r=e.direction,o=e.extraStyles;return t.jsx("button",{name:r,"data-testid":r,onClick:n,className:"py-2.5 px-3 text-sm transition-colors duration-300 ease-in-out ".concat(o," rounded ").concat("right"===r?"rotate-180":""," hover:bg-gray-100"),children:t.jsx(a,{})})}function s(t){var e=t.setCurrentDate,n=t.visibleMonths;return{handleMonthChange:function(t){e((function(e){return new Date(e.getFullYear(),t,1)}))},handleNextMonth:function(){return e(n?function(t){return new Date(t.getFullYear(),t.getMonth()+n,1)}:function(t){return new Date(t.getFullYear(),t.getMonth()+1,1)})},handlePreviousMonth:function(){return e(n?function(t){return new Date(t.getFullYear(),t.getMonth()-n,1)}:function(t){return new Date(t.getFullYear(),t.getMonth()-1,1)})}}}var l=function(t,e,n){for(var r=new Date(e,t,1),o=new Date(e,t+1,0),a=new Date(r.getFullYear(),r.getMonth(),r.getDate()-(r.getDay()-(null!=n?n:0)+7)%7),i=7*Math.ceil((o.getDate()+(r.getDay()-(null!=n?n:0)+7)%7)/7),s=new Array(i),l=new Date(a),c=0;c<i;c++)s[c]=new Date(l),l.setDate(l.getDate()+1);return s};function c(t,e){return t[e>11?e%12:e]}function d(t,e,n){if(n||2===arguments.length)for(var r,o=0,a=e.length;o<a;o++)!r&&o in e||(r||(r=Array.prototype.slice.call(e,0,o)),r[o]=e[o]);return t.concat(r||Array.prototype.slice.call(e))}"function"==typeof SuppressedError&&SuppressedError;var u=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"];function h(t,e){var n=null!=e?e:u;return d(d([],n.slice(t),!0),n.slice(0,t),!0)}function p(t,e){return t.getMonth()+e>11?t.getFullYear()+1:t.getFullYear()}exports.DatePicker=function(r){var a=r.preSelectedDate,d=r.onChange,u=r.weekStartsOn,p=void 0===u?0:u,g=r.customDaysOfWeek,w=r.containerStyle,b=r.daysOfWeekStyles,f=r.visibleDatesStyle,m=r.isSelectedStyle,x=r.disabledDate,y=r.showYearMonthDivider,v=r.prevMonthBtnIcon,k=r.nextMonthBtnIcon,D=r.outlineStyle,M=function(t){var r=t.preSelectedDate,o=t.weekStartsOn,a=t.customDaysOfWeek,i=t.onChange,d=e.useState(new Date),u=d[0],p=d[1],g=e.useState(null),w=g[0],b=g[1],f=e.useMemo((function(){return"".concat(c(n,u.getMonth()))}),[u]);e.useEffect((function(){r&&b(r)}),[r]);var m=h(o,a),x=s({setCurrentDate:p}),y=x.handleMonthChange,v=x.handleNextMonth,k=x.handlePreviousMonth,D=l(u.getMonth(),u.getFullYear(),o);return{currentDate:u,setCurrentDate:p,selectedDate:w,monthsRange:f,daysOfWeek:m,handleMonthChange:y,handleNextMonth:v,handleDateChange:function(t){b(t),i(t)},handlePreviousMonth:k,dates:D}}({preSelectedDate:a,weekStartsOn:p,customDaysOfWeek:g,onChange:d}),S=null!=D?D:"outline-blue-500";return t.jsxs("div",{"data-testid":"container",className:null!=w?w:"py-4 px-2 border rounded shadow-md",children:[t.jsxs("div",{className:"flex justify-between items-center mb-4",children:[v?t.jsx("button",{"data-testid":"prevMonthBtnIcon",onClick:M.handlePreviousMonth,children:v}):t.jsx(i,{onClick:M.handlePreviousMonth,direction:"left",extraStyles:S}),t.jsx(o,{monthsRange:M.monthsRange,handleMonthChange:M.handleMonthChange,currentDate:M.currentDate,setCurrentDate:M.setCurrentDate,showYearMonthDivider:y}),k?t.jsx("button",{onClick:M.handleNextMonth,children:k}):t.jsx(i,{onClick:M.handleNextMonth,direction:"right",extraStyles:S})]}),t.jsx("div",{className:"grid grid-cols-7 gap-1 mb-2",children:M.daysOfWeek.map((function(e){return t.jsx("div",{"data-testid":"day-of-week",className:null!=b?b:"text-center font-medium text-black/70",children:e},e)}))}),t.jsx("div",{className:"grid grid-cols-7 gap-1 text-black text-opacity-55",children:M.dates.map((function(e){var n=e.getMonth()===M.currentDate.getMonth(),r=M.selectedDate&&e.toDateString()===M.selectedDate.toDateString(),o=e.toDateString()===(null==x?void 0:x.toDateString());return t.jsx("button",{className:"p-2 text-center rounded ".concat(n?r&&!o?"".concat(null!=m?m:"bg-blue-500 text-white"):o?"cursor-not-allowed hover:bg-transparent text-black text-opacity-25":"".concat(null!=f?f:"hover:bg-blue-100 cursor-pointer"):"invisible"),disabled:o,onClick:n?function(){return M.handleDateChange(e)}:void 0,children:e.getDate()},e.toISOString())}))})]})},exports.DateRangePicker=function(o){var a=o.onRangeChange,d=o.disabledDates,u=void 0===d?[]:d,g=o.weekStartsOn,w=void 0===g?0:g,b=o.visibleMonths,f=void 0===b?2:b,m=o.customDaysOfWeek,x=o.preSelectedRange,y=o.startDateStyle,v=o.endDateStyle,k=o.inRangeStyles,D=o.visibleDatesStyle,M=o.daysOfWeekStyles,S=o.monthTitleStyle,C=o.showYearMonthDivider,j=void 0===C||C,N=o.outlineStyle,O=o.containerStyle,z=o.prevMonthBtnIcon,Y=o.nextMonthBtnIcon,I=function(t){var n=t.disabledDates,r=t.weekStartsOn,o=t.onRangeChange,a=t.customDaysOfWeek,i=t.visibleMonths,d=void 0===i?1:i,u=t.preSelectedRange,p=e.useState(new Date),g=p[0],w=p[1],b=e.useState(!1),f=b[0],m=b[1],x=e.useState(null!=u?u:{start:null,end:null}),y=x[0],v=x[1],k=e.useState(null),D=k[0],M=k[1],S=e.useState(String(g.getFullYear())),C=S[0],j=S[1],N=h(r,a),O=e.useMemo((function(){return["January","February","March","April","May","June","July","August","September","October","November","December"]}),[]),z=function(t){return null==n?void 0:n.some((function(e){return t.toDateString()===e.toDateString()}))},Y=s({setCurrentDate:w,visibleMonths:d}),I=Y.handleMonthChange,R=Y.handleNextMonth,E=Y.handlePreviousMonth,F=e.useMemo((function(){return d>1?"".concat(c(O,g.getMonth())," - ").concat(c(O,g.getMonth()+(d-1))):c(O,g.getMonth())}),[g,O,d]),W=e.useRef(null),A=e.useRef(null);e.useEffect((function(){j(String(g.getFullYear()))}),[g]);var L=function(t){W.current&&!W.current.contains(t.target)&&m(!1)};return e.useEffect((function(){if(f)return document.addEventListener("click",L),function(){document.removeEventListener("click",L)}}),[f]),{handleYearInputChange:function(t){var e=t.target.value;/^\d{0,4}$/.test(e)&&(j(e),4===e.length&&w((function(t){return new Date(Number(e),t.getMonth(),1)})))},dropdownRef:A,inputRef:W,months:O,monthsRange:F,currentDate:g,handleMonthChange:I,handleNextMonth:R,handlePreviousMonth:E,handleDateClick:function(t){if(!z(t)){var e=y.start,n=y.end;!e||e&&n?v({start:t,end:null}):e&&!n&&(t<e?(v({start:t,end:e}),o&&o({start:t,end:e})):(v({start:e,end:t}),o&&o({start:e,end:t})))}},isInRange:function(t){var e=y.start,n=y.end;return e&&n?t>e&&t<n:!(!e||!D)&&(t>e&&t<D||t<e&&t>D)},isEndDate:function(t){return y.end&&y.end.toDateString()===t.toDateString()},isStartDate:function(t){return y.start&&y.start.toDateString()===t.toDateString()},isDateDisabled:z,setHoveredDate:M,isMonthDropdownVisible:f,setIsMonthDropdownVisible:m,yearInput:C,daysOfWeek:N,getCalendarDates:l}}({onRangeChange:a,disabledDates:u,weekStartsOn:w,visibleMonths:f,customDaysOfWeek:m,preSelectedRange:x}),R=null!=N?N:"outline-blue-500";return t.jsxs("div",{className:null!=O?O:"py-4 px-2 border rounded shadow-md w-fit",children:[t.jsxs("div",{className:"flex justify-between items-center mb-4",children:[z?t.jsx("button",{onClick:I.handlePreviousMonth,children:z}):t.jsx(i,{onClick:I.handlePreviousMonth,direction:"left",extraStyles:R}),t.jsxs("div",{className:"flex gap-2 items-center",children:[t.jsxs("div",{className:"block relative",children:[t.jsx("input",{ref:I.inputRef,type:"text",value:I.monthsRange,className:"text-center border ".concat(f>1?"w-40":"w-24"," text-sm ").concat(R," rounded py-2 cursor-pointer"),readOnly:!0,onClick:function(){I.setIsMonthDropdownVisible(!0)},onKeyDown:function(t){"Enter"!==t.key&&" "!==t.key||I.setIsMonthDropdownVisible(!0)}}),I.isMonthDropdownVisible&&t.jsx("div",{style:{animation:I.isMonthDropdownVisible?"fadeInSlideIn 0.2s ease-out":"fadeOutSlideOut 0.2s ease-out"},ref:I.dropdownRef,className:"dropdown my-2 transition-all duration-200 ease-in-out absolute top-10 left-0 bg-white h-72 overflow-y-auto flex flex-col w-full shadow-xl",children:I.months.map((function(e,n){return t.jsx("button",{className:"py-2 text-sm text-gray-700 hover:bg-slate-100 duration-200 ease-in-out transition-colors ".concat(R),onClick:function(){return I.handleMonthChange(n)},children:e},e)}))})]}),j&&t.jsx("span",{children:t.jsx(r,{})}),t.jsx("input",{type:"number",value:I.yearInput,onChange:I.handleYearInputChange,className:"w-20 p-2 text-sm border rounded text-center ".concat(R),placeholder:"Year"})]}),Y?t.jsx("button",{onClick:I.handleNextMonth,children:Y}):t.jsx(i,{onClick:I.handleNextMonth,direction:"right",extraStyles:R})]}),t.jsx("div",{className:"flex gap-4",children:Array.from({length:f}).map((function(e,r){var o=I.currentDate,a=new Date(p(o,r),o.getMonth()+r>11?(o.getMonth()+r)%12:o.getMonth()+r,1),i=I.getCalendarDates(a.getMonth(),a.getFullYear(),w);return t.jsxs("div",{className:"w-80 transition-all duration-500 ease-in-out",children:[f>1&&t.jsxs("p",{className:null!=S?S:"text-center font-semibold",children:[" ",c(n,o.getMonth()+r),","," ",p(o,r)]}),t.jsx("div",{className:"grid grid-cols-7 gap-1 my-2",children:I.daysOfWeek.map((function(e){return t.jsx("div",{className:"text-center ".concat(null!=M?M:"font-medium text-black/70"),children:e},e)}))}),t.jsx("div",{className:"grid grid-cols-7 gap-y-2 text-black/55",children:i.map((function(e){var n=e.getMonth()===(o.getMonth()+r>11?(o.getMonth()+r)%12:o.getMonth()+r),a=I.isDateDisabled(e),i=I.isStartDate(e),s=I.isEndDate(e),l=I.isInRange(e),c=e.getDay()===w,d=e.getDay()===(w+6)%7,u=l?c?"rounded-l-full":d?"rounded-r-full":"":"";return t.jsx("button",{className:"p-2 disabled:cursor-not-allowed disabled:hover:bg-transparent disabled:text-opacity-40 transition-all duration-500 ease-in-out text-center cursor-pointer ".concat(R," ").concat(i&&n?"".concat(null!=y?y:"bg-blue-500 text-white rounded-l-full"):s&&n?"".concat(null!=v?v:"bg-blue-500 text-white rounded-r-full"):l&&n?"".concat(null!=k?k:"bg-blue-200 text-blue-800"," ").concat(u):n?"".concat(null!=D?D:"hover:bg-blue-100"):"invisible"),onClick:function(){return I.handleDateClick(e)},onMouseEnter:function(){return!a&&I.setHoveredDate(e)},onMouseLeave:function(){return I.setHoveredDate(null)},disabled:a,children:e.getDate()},e.toISOString())}))})]},a.toDateString())}))})]})};
//# sourceMappingURL=index.js.map