daterange-picker-reactjs
Version:
A beautiful and customizable single date and date-range picker component for React.js applications
3 lines (2 loc) • 21.7 kB
JavaScript
import{jsx as t,jsxs as e}from"react/jsx-runtime";import{useCallback as n,useEffect as r,useState as o,useRef as a,useMemo as i}from"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 l=["January","February","March","April","May","June","July","August","September","October","November","December"];function s(){return t("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 100 200",width:"8",height:"40",className:"",children:t("rect",{x:"50",y:"-180",width:"16",height:"580",fill:"rgb(0 0 0 / 0.35)"})})}function d(i){var d=i.monthsRange,c=i.handleMonthChange,u=i.currentDate,h=i.setCurrentDate,p=i.showYearMonthDivider,g=o(!1),w=g[0],b=g[1],m=o(String(u.getFullYear())),f=m[0],x=m[1],y=a(null),v=a(null);return function(t,e,o){var a=n((function(t){e&&(null==e?void 0:e.current)&&!(null==e?void 0:e.current.contains(t.target))&&o(!1)}),[e,o]);r((function(){if(t)return document.addEventListener("click",a),function(){document.removeEventListener("click",a)}}),[t,a])}(w,y,b),e("div",{className:"flex gap-2 items-center",children:[e("div",{className:"block relative",children:[t("input",{ref:y,type:"text",value:d,className:"text-center w-24 text-sm border rounded bg-white py-2 cursor-pointer",readOnly:!0,onClick:function(){b(!0)}}),w&&t("div",{style:{animation:w?"fadeInSlideIn 0.2s ease-out":"fadeOutSlideOut 0.2s ease-out"},ref:v,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:l.map((function(e,n){return t("button",{className:"py-2 text-sm text-gray-700 hover:bg-slate-100 duration-200 ease-in-out transition-colors",onClick:function(){return c(n)},children:e},e)}))})]}),p&&t("span",{"data-testid":"yearMonthDivider",children:t(s,{})}),t("input",{type:"number",value:f,onChange:function(t){var e=t.target.value;/^\d{0,4}$/.test(e)&&(x(e),4===e.length&&h((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 c(){return t("svg",{width:"9",height:"18",viewBox:"0 0 9 18",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:t("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 u(e){var n=e.onClick,r=e.direction,o=e.extraStyles;return t("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(c,{})})}function h(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 p=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),l=new Array(i),s=new Date(a),d=0;d<i;d++)l[d]=new Date(s),s.setDate(s.getDate()+1);return l};function g(t,e){return t[e>11?e%12:e]}function w(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 b=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"];function m(t,e){var n=null!=e?e:b;return w(w([],n.slice(t),!0),n.slice(0,t),!0)}var f=function(n){var a=n.preSelectedDate,s=n.onChange,c=n.weekStartsOn,w=void 0===c?0:c,b=n.customDaysOfWeek,f=n.containerStyle,x=n.daysOfWeekStyles,y=n.visibleDatesStyle,v=n.isSelectedStyle,k=n.disabledDate,D=n.showYearMonthDivider,M=n.prevMonthBtnIcon,S=n.nextMonthBtnIcon,C=n.outlineStyle,N=function(t){var e=t.preSelectedDate,n=t.weekStartsOn,a=t.customDaysOfWeek,s=t.onChange,d=o(new Date),c=d[0],u=d[1],w=o(null),b=w[0],f=w[1],x=i((function(){return"".concat(g(l,c.getMonth()))}),[c]);r((function(){e&&f(e)}),[e]);var y=m(n,a),v=h({setCurrentDate:u}),k=v.handleMonthChange,D=v.handleNextMonth,M=v.handlePreviousMonth,S=p(c.getMonth(),c.getFullYear(),n);return{currentDate:c,setCurrentDate:u,selectedDate:b,monthsRange:x,daysOfWeek:y,handleMonthChange:k,handleNextMonth:D,handleDateChange:function(t){f(t),s(t)},handlePreviousMonth:M,dates:S}}({preSelectedDate:a,weekStartsOn:w,customDaysOfWeek:b,onChange:s}),O=null!=C?C:"outline-blue-500";return e("div",{"data-testid":"container",className:null!=f?f:"py-4 px-2 border rounded shadow-md",children:[e("div",{className:"flex justify-between items-center mb-4",children:[M?t("button",{"data-testid":"prevMonthBtnIcon",onClick:N.handlePreviousMonth,children:M}):t(u,{onClick:N.handlePreviousMonth,direction:"left",extraStyles:O}),t(d,{monthsRange:N.monthsRange,handleMonthChange:N.handleMonthChange,currentDate:N.currentDate,setCurrentDate:N.setCurrentDate,showYearMonthDivider:D}),S?t("button",{onClick:N.handleNextMonth,children:S}):t(u,{onClick:N.handleNextMonth,direction:"right",extraStyles:O})]}),t("div",{className:"grid grid-cols-7 gap-1 mb-2",children:N.daysOfWeek.map((function(e){return t("div",{"data-testid":"day-of-week",className:null!=x?x:"text-center font-medium text-black/70",children:e},e)}))}),t("div",{className:"grid grid-cols-7 gap-1 text-black text-opacity-55",children:N.dates.map((function(e){var n=e.getMonth()===N.currentDate.getMonth(),r=N.selectedDate&&e.toDateString()===N.selectedDate.toDateString(),o=e.toDateString()===(null==k?void 0:k.toDateString());return t("button",{className:"p-2 text-center rounded ".concat(n?r&&!o?"".concat(null!=v?v:"bg-blue-500 text-white"):o?"cursor-not-allowed hover:bg-transparent text-black text-opacity-25":"".concat(null!=y?y:"hover:bg-blue-100 cursor-pointer"):"invisible"),disabled:o,onClick:n?function(){return N.handleDateChange(e)}:void 0,children:e.getDate()},e.toISOString())}))})]})};function x(t,e){return t.getMonth()+e>11?t.getFullYear()+1:t.getFullYear()}var y=function(n){var d=n.onRangeChange,c=n.disabledDates,w=void 0===c?[]:c,b=n.weekStartsOn,f=void 0===b?0:b,y=n.visibleMonths,v=void 0===y?2:y,k=n.customDaysOfWeek,D=n.preSelectedRange,M=n.startDateStyle,S=n.endDateStyle,C=n.inRangeStyles,N=n.visibleDatesStyle,O=n.daysOfWeekStyles,z=n.monthTitleStyle,Y=n.showYearMonthDivider,I=void 0===Y||Y,R=n.outlineStyle,F=n.containerStyle,E=n.prevMonthBtnIcon,W=n.nextMonthBtnIcon,j=function(t){var e=t.disabledDates,n=t.weekStartsOn,l=t.onRangeChange,s=t.customDaysOfWeek,d=t.visibleMonths,c=void 0===d?1:d,u=t.preSelectedRange,w=o(new Date),b=w[0],f=w[1],x=o(!1),y=x[0],v=x[1],k=o(null!=u?u:{start:null,end:null}),D=k[0],M=k[1],S=o(null),C=S[0],N=S[1],O=o(String(b.getFullYear())),z=O[0],Y=O[1],I=m(n,s),R=i((function(){return["January","February","March","April","May","June","July","August","September","October","November","December"]}),[]),F=function(t){return null==e?void 0:e.some((function(e){return t.toDateString()===e.toDateString()}))},E=h({setCurrentDate:f,visibleMonths:c}),W=E.handleMonthChange,j=E.handleNextMonth,A=E.handlePreviousMonth,L=i((function(){return c>1?"".concat(g(R,b.getMonth())," - ").concat(g(R,b.getMonth()+(c-1))):g(R,b.getMonth())}),[b,R,c]),P=a(null),B=a(null);r((function(){Y(String(b.getFullYear()))}),[b]);var T=function(t){P.current&&!P.current.contains(t.target)&&v(!1)};return r((function(){if(y)return document.addEventListener("click",T),function(){document.removeEventListener("click",T)}}),[y]),{handleYearInputChange:function(t){var e=t.target.value;/^\d{0,4}$/.test(e)&&(Y(e),4===e.length&&f((function(t){return new Date(Number(e),t.getMonth(),1)})))},dropdownRef:B,inputRef:P,months:R,monthsRange:L,currentDate:b,handleMonthChange:W,handleNextMonth:j,handlePreviousMonth:A,handleDateClick:function(t){if(!F(t)){var e=D.start,n=D.end;!e||e&&n?M({start:t,end:null}):e&&!n&&(t<e?(M({start:t,end:e}),l&&l({start:t,end:e})):(M({start:e,end:t}),l&&l({start:e,end:t})))}},isInRange:function(t){var e=D.start,n=D.end;return e&&n?t>e&&t<n:!(!e||!C)&&(t>e&&t<C||t<e&&t>C)},isEndDate:function(t){return D.end&&D.end.toDateString()===t.toDateString()},isStartDate:function(t){return D.start&&D.start.toDateString()===t.toDateString()},isDateDisabled:F,setHoveredDate:N,isMonthDropdownVisible:y,setIsMonthDropdownVisible:v,yearInput:z,daysOfWeek:I,getCalendarDates:p}}({onRangeChange:d,disabledDates:w,weekStartsOn:f,visibleMonths:v,customDaysOfWeek:k,preSelectedRange:D}),A=null!=R?R:"outline-blue-500";return e("div",{className:null!=F?F:"py-4 px-2 border rounded shadow-md w-fit",children:[e("div",{className:"flex justify-between items-center mb-4",children:[E?t("button",{onClick:j.handlePreviousMonth,children:E}):t(u,{onClick:j.handlePreviousMonth,direction:"left",extraStyles:A}),e("div",{className:"flex gap-2 items-center",children:[e("div",{className:"block relative",children:[t("input",{ref:j.inputRef,type:"text",value:j.monthsRange,className:"text-center border ".concat(v>1?"w-40":"w-24"," text-sm ").concat(A," rounded py-2 cursor-pointer"),readOnly:!0,onClick:function(){j.setIsMonthDropdownVisible(!0)},onKeyDown:function(t){"Enter"!==t.key&&" "!==t.key||j.setIsMonthDropdownVisible(!0)}}),j.isMonthDropdownVisible&&t("div",{style:{animation:j.isMonthDropdownVisible?"fadeInSlideIn 0.2s ease-out":"fadeOutSlideOut 0.2s ease-out"},ref:j.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:j.months.map((function(e,n){return t("button",{className:"py-2 text-sm text-gray-700 hover:bg-slate-100 duration-200 ease-in-out transition-colors ".concat(A),onClick:function(){return j.handleMonthChange(n)},children:e},e)}))})]}),I&&t("span",{children:t(s,{})}),t("input",{type:"number",value:j.yearInput,onChange:j.handleYearInputChange,className:"w-20 p-2 text-sm border rounded text-center ".concat(A),placeholder:"Year"})]}),W?t("button",{onClick:j.handleNextMonth,children:W}):t(u,{onClick:j.handleNextMonth,direction:"right",extraStyles:A})]}),t("div",{className:"flex gap-4",children:Array.from({length:v}).map((function(n,r){var o=j.currentDate,a=new Date(x(o,r),o.getMonth()+r>11?(o.getMonth()+r)%12:o.getMonth()+r,1),i=j.getCalendarDates(a.getMonth(),a.getFullYear(),f);return e("div",{className:"w-80 transition-all duration-500 ease-in-out",children:[v>1&&e("p",{className:null!=z?z:"text-center font-semibold",children:[" ",g(l,o.getMonth()+r),","," ",x(o,r)]}),t("div",{className:"grid grid-cols-7 gap-1 my-2",children:j.daysOfWeek.map((function(e){return t("div",{className:"text-center ".concat(null!=O?O:"font-medium text-black/70"),children:e},e)}))}),t("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=j.isDateDisabled(e),i=j.isStartDate(e),l=j.isEndDate(e),s=j.isInRange(e),d=e.getDay()===f,c=e.getDay()===(f+6)%7,u=s?d?"rounded-l-full":c?"rounded-r-full":"":"";return t("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(A," ").concat(i&&n?"".concat(null!=M?M:"bg-blue-500 text-white rounded-l-full"):l&&n?"".concat(null!=S?S:"bg-blue-500 text-white rounded-r-full"):s&&n?"".concat(null!=C?C:"bg-blue-200 text-blue-800"," ").concat(u):n?"".concat(null!=N?N:"hover:bg-blue-100"):"invisible"),onClick:function(){return j.handleDateClick(e)},onMouseEnter:function(){return!a&&j.setHoveredDate(e)},onMouseLeave:function(){return j.setHoveredDate(null)},disabled:a,children:e.getDate()},e.toISOString())}))})]},a.toDateString())}))})]})};export{f as DatePicker,y as DateRangePicker};
//# sourceMappingURL=index.mjs.map